.toast-container{display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:9999}.toast{background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;margin:0;max-width:400px;min-width:300px;opacity:0;padding:0;pointer-events:auto;transform:translateX(100%);transition:all .3s cubic-bezier(.4,0,.2,1)}.toast-visible{opacity:1;transform:translateX(0)}.toast-leaving{opacity:0;transform:translateX(100%)}.toast-content{align-items:flex-start;display:flex;gap:12px;padding:16px}.toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:20px;justify-content:center;margin-top:2px;width:20px}.toast-message{word-wrap:break-word;color:#374151;flex:1 1;font-size:14px;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:20px;justify-content:center;padding:0;transition:all .2s ease;width:20px}.toast-close:hover{background-color:#f3f4f6;color:#6b7280}.toast-success{border-left-color:#10b981}.toast-success .toast-icon{background-color:#d1fae5;color:#065f46}.toast-error{border-left-color:#ef4444}.toast-error .toast-icon{background-color:#fee2e2;color:#991b1b}.toast-warning{border-left-color:#f59e0b}.toast-warning .toast-icon{background-color:#fef3c7;color:#92400e}.toast-info{border-left-color:#3b82f6}.toast-info .toast-icon{background-color:#dbeafe;color:#1e40af}.toast:hover{box-shadow:0 6px 16px #0003;transform:translateX(-4px)}.toast-leaving:hover{transform:translateX(100%)}@media (max-width:480px){.toast-container{left:10px;max-width:none;right:10px;top:10px}.toast{max-width:none;min-width:auto}}.toast:first-child{animation-delay:0ms}.toast:nth-child(2){animation-delay:.1s}.toast:nth-child(3){animation-delay:.2s}.toast:nth-child(4){animation-delay:.3s}.toast:nth-child(5){animation-delay:.4s}.disabled{cursor:not-allowed;opacity:.5}.cam360-controls.hidden,.cam360-quad-zoom-overlay.hidden,.camera-info-overlay.hidden,.recording-overlay.hidden{opacity:0;pointer-events:none;transform:translateY(10px)}.cam360-controls.visible,.cam360-quad-zoom-overlay.visible,.camera-info-overlay.visible,.recording-overlay.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.cam360-controls,.cam360-quad-zoom-overlay,.camera-info-overlay,.recording-overlay{transition:all .3s ease}.cam360-controls{contain:layout;overflow:hidden}.cam360-controls,.cam360-controls *{box-sizing:border-box}.control-btn{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.control-btn:focus{outline:2px solid #ffffff4d;outline-offset:2px}.primary-btn{background:#ffffffe6!important;color:#000!important}.secondary-btn{background:#ffffff1a!important;color:#fff!important}.mode-btn{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.preset-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;padding-right:28px!important}.cam360-root{border:1px solid #ffffff14;border-radius:12px;box-shadow:0 4px 20px #0000004d,0 1px 3px #0003;gap:0}.cam360-root,.cam360-stage{background:#000;display:flex;flex-direction:column;margin:0;padding:0}.cam360-stage{align-items:stretch;border-radius:12px;box-shadow:inset 0 2px 8px #0000004d;height:100%;justify-content:stretch;position:relative;width:100%}.cam360-canvas,.cam360-stage{flex:1 1 auto;overflow:hidden}.cam360-canvas{border-radius:8px;display:block;height:100%!important;object-fit:cover!important;transition:transform .2s ease;width:100%!important}.cam360-video-hidden{height:0;opacity:0;pointer-events:none;position:absolute;width:0}.cam360-controls{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000d9;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 8px 32px #0006;display:flex;flex-wrap:wrap;gap:12px;padding:12px 20px}.cam360-controls button,.cam360-controls select{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;box-shadow:0 2px 8px #0000004d;color:#fff;cursor:pointer;font-weight:600;padding:10px 14px;transition:all .2s ease}.cam360-controls button:hover{background:#fff3;box-shadow:0 4px 12px #0006;transform:scale(1.05)}.cam360-speed{align-items:center}.cam360-presets,.cam360-speed{display:flex;gap:6px}.cam360-timeline{align-items:center;display:flex;gap:10px}.cam360-timeline input[type=range]{flex:1 1}.cam360-time{font:12px/1.2 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;opacity:.8}.cam360-error{background:#ffe9ec;color:#b00020;padding:6px 8px}.cam360-quad{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;height:100vh;margin:0;padding:0}.cam360-quad-cell{align-items:center;background:#000;border-radius:12px;display:flex;justify-content:center;margin:0;overflow:hidden;padding:0;position:relative}.cam360-quad-cell .cam360-canvas{display:block;height:100%;object-fit:cover;width:100%}.cam360-quad-grid{align-items:stretch;border:1px solid #ffffff14;border-radius:12px;box-shadow:0 4px 16px #0000004d,0 1px 3px #0003;box-sizing:border-box;flex-direction:row;flex-wrap:nowrap;gap:4px;padding:4px;width:100%}.cam360-quad-grid,.cam360-quad-item{background:#000;display:flex;height:100%;justify-content:center;margin:0;overflow:hidden}.cam360-quad-item{align-items:center;border:1px solid #ffffff26;border-radius:8px;box-shadow:0 2px 8px #0000004d,0 1px 2px #0003;cursor:pointer;flex:1 1 auto;min-height:0;min-width:0;position:relative;transition:all .3s ease;width:25%}.cam360-quad-item:hover{border-color:#22c55e99;box-shadow:0 4px 16px #22c55e4d;transform:scale(1.02)}.cam360-quad-item .cam360-canvas{border-radius:8px;display:block;height:100%;image-rendering:high-quality;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:auto;image-rendering:smooth;object-fit:contain;transform:translateZ(0);transition:transform .2s ease;width:100%}.cam360-quad-label{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;border-radius:8px;bottom:12px;box-shadow:0 2px 8px #0000004d;color:#fff;font-size:13px;font-weight:600;left:12px;padding:6px 12px;pointer-events:none;position:absolute}.cam360-mode-toggle{display:flex;gap:8px}.cam360-mode-toggle button{background:#fafafa;border:1px solid #ccc;border-radius:8px;padding:6px 10px}.cam360-mode-toggle .active{background:#eaeaea}.cam360-minimap{border:1px solid #fff3;border-radius:10px;box-shadow:0 6px 16px #00000059;overflow:hidden}.cam360-minimap.hover{outline:2px solid #fff3}.cam360-ptz{align-items:center;display:flex;gap:10px}.cam360-ptz .ptz-pad{flex-direction:column}.cam360-ptz .lr,.cam360-ptz .ptz-pad{align-items:center;display:flex;gap:4px}.cam360-ptz button{background:#f6f6f6;cursor:pointer}.cam360-ptz .ptz-presets,.cam360-ptz button{border:1px solid #ccc;border-radius:8px;padding:6px 10px}.cam360-ptz .ptz-presets{background:#fff}.cam360-pip{background:#000;border-radius:10px;bottom:16px;box-shadow:0 10px 24px #00000073;height:180px;overflow:hidden;position:fixed;right:16px;width:280px;z-index:10}.cam360-pip .pip-header{align-items:center;background:#ffffff1a;color:#fff;cursor:move;display:flex;justify-content:space-between;padding:4px 8px}.cam360-pip .pip-header button{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:2px 6px}.cam360-quad-label{align-items:center;display:flex;gap:8px}.cam360-quad-label .pip-pin{background:#00000040;border:1px solid #fff6;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;margin-left:8px;padding:2px 6px}.quad-zoom-indicator{background:#000000b3;border-radius:4px;bottom:8px;color:#fff;font-size:11px;opacity:.8;padding:2px 6px;pointer-events:none;position:absolute;right:8px}.cam360-quad-zoom-overlay{bottom:120px;left:12px;pointer-events:none;position:absolute;z-index:1000}.zoom-controls-compact{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#000000d9;border:1px solid #ffffff26;border-radius:12px;box-shadow:0 4px 16px #0006,0 1px 3px #0003;display:flex;flex-direction:column;gap:6px;min-width:180px;padding:10px 14px;pointer-events:auto}.zoom-slider-container{align-items:center;display:flex;gap:8px}.zoom-label{color:#fff;font-size:12px;font-weight:600;min-width:40px}.zoom-slider{-webkit-appearance:none;appearance:none;background:#fff3;border-radius:2px;cursor:pointer;flex:1 1;height:4px;outline:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#3b82f6;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:16px;-webkit-transition:all .2s ease;transition:all .2s ease;width:16px}.zoom-slider::-webkit-slider-thumb:hover{background:#2563eb;transform:scale(1.1)}.zoom-slider::-moz-range-thumb{background:#3b82f6;border:none;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:16px;width:16px}.zoom-value{color:#a1a1aa;font-size:11px;font-weight:600;min-width:35px;text-align:right}.reset-zoom-btn{align-items:center;align-self:flex-end;background:#3b82f6cc;border:none;border-radius:8px;box-shadow:0 2px 8px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.reset-zoom-btn:hover{background:#3b82f6;box-shadow:0 4px 12px #3b82f666;transform:scale(1.05)}.cam360-quad-zoom-overlay.bottom-left{bottom:120px;left:12px;right:auto;top:auto}.cam360-quad-zoom-overlay.bottom-right{bottom:120px;right:16px;top:auto}.cam360-quad-zoom-overlay.top-left{left:16px;right:auto;top:16px}@media (max-width:768px){.zoom-controls-compact{min-width:180px;padding:10px 12px}.zoom-label{font-size:11px;min-width:35px}.zoom-value{font-size:10px;min-width:30px}.reset-zoom-btn{font-size:12px;height:28px;width:28px}}.cam360-quad-zoom{align-items:center;display:flex;font-size:14px;gap:8px}.cam360-quad-zoom input[type=range]{cursor:pointer}.cam360-canvas{image-rendering:high-quality;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;image-rendering:auto;image-rendering:smooth;image-rendering:optimize-quality;transform:translateZ(0);will-change:transform}.cam360-quad-grid[data-cols="2"]{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.cam360-quad-grid[data-cols="3"]{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}.cam360-quad-grid[data-cols="4"]{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr)}.cam360-quad-item,.cam360-quad-item .cam360-canvas{will-change:transform}.cam360-quad-label{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000c!important;border:1px solid #ffffff1a}.cam360-quad-info{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 12px #0000004d}.cam360-adaptive-toggle{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:4px}.cam360-adaptive-toggle input[type=checkbox]{cursor:pointer}.cam360-camera-type-indicator{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid #fff3;box-shadow:0 2px 8px #0000004d}.cam360-quad-grid-2x2{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.cam360-quad-grid-1x4{grid-template-columns:repeat(4,1fr);grid-template-rows:1fr}.cam360-quad-grid-4x1{grid-template-columns:1fr;grid-template-rows:repeat(4,1fr)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.camera-info-overlay .live-indicator{animation:pulse 2s infinite}.cam360-controls button,.cam360-quad-item,.cam360-quad-label{animation:fadeIn .3s ease-out}.cam360-controls button:focus,.cam360-quad-item:focus{outline:2px solid #22c55ecc;outline-offset:2px}.cam360-error{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#ef4444;font-weight:500;padding:12px 16px}.cam360-root{height:80vh;overflow:hidden;position:relative;width:100%}.info-overlay-wrapper{align-items:flex-start;bottom:12px;display:flex;flex-direction:column;font-family:Roboto Mono,monospace;gap:6px;left:12px;position:absolute;z-index:120}.info-toggle-btn{align-items:center;background:#0000008c;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;gap:6px;padding:6px 10px}.info-overlay{background:#000000bf;border-radius:10px;box-shadow:0 6px 18px #00000080;color:#fff;font-size:13px;max-width:420px;min-width:300px;padding:10px 12px}.info-row{display:flex;gap:12px;justify-content:space-between;margin:4px 0}.info-row span:first-child{color:#9ee7ff;opacity:.9}.info-title{border-bottom:1px solid #ffffff0f;font-weight:600;margin-bottom:8px;padding-bottom:6px}@media (max-height:600px){.cam360-root{height:80vh}.cam360-canvas{height:100%!important}}@media (max-height:400px){.cam360-root{height:80vh}.cam360-stage{height:100%}.cam360-canvas{height:100%!important}}@media (max-width:768px){.cam360-root{height:80vh}.cam360-root,.cam360-stage{border-radius:8px}.cam360-canvas{border-radius:6px}}.dashboard-layout{background-color:#fff;display:flex;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:240px;transition:margin-left .3s ease}.main-content.sidebar-collapsed{margin-left:60px}.content-area{background:#fafafa;flex:1 1;padding:1rem .5rem}.header{align-content:center;background:#212121;border-radius:8px;height:80px;justify-content:space-between;margin:.5rem .5rem 0;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.mobile-menu-btn{background:none;border:none;border-radius:.375rem;color:#374151;cursor:pointer;display:none;font-size:1.25rem;padding:.5rem}.mobile-menu-btn:hover{background:#f3f4f6}.page-title{color:#2932e5}.header-title,.page-title{font-size:30px;font-weight:400;letter-spacing:0;line-height:45px;margin:0}.header-title{color:#fff}.page-subtitle{leading-trim:NONE;color:#4a5565;font-size:14px;font-style:Regular;font-weight:400;letter-spacing:0;line-height:21px}.logo-time{color:#2932e5}.current-page,.logo-machine{color:#1f2937}.header-actions,.header-right{align-items:center;display:flex}.header-actions{gap:1rem}.notification-btn{align-items:center;background:none;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;justify-content:center;padding:.5rem;transition:background-color .2s ease}.notification-btn:hover{background:#ffffff1a;color:#fff}.user-menu{position:relative}.user-menu-btn{align-items:center;background:none;border:none;border-radius:.5rem;cursor:pointer;display:flex;gap:.75rem;padding:.5rem 1rem;transition:background-color .2s ease}.user-menu-btn:hover{background:#f3f4f6}.user-avatar{align-items:center;background:#2932e5;border:2px solid #e5e7eb;border-radius:50%;color:#fff;display:flex;font-size:.875rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-name{color:#374151;font-size:.875rem;font-weight:500}.dropdown-arrow{color:#9ca3af;font-size:.75rem;transition:transform .2s ease}.user-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:.5rem;min-width:200px;position:absolute;right:0;top:100%;z-index:100}.dropdown-header{padding:1rem}.dropdown-user-info{text-align:left}.dropdown-user-name{color:#1f2937;font-size:.875rem;font-weight:600}.dropdown-user-email{color:#6b7280;font-size:.75rem;margin-top:.25rem}.dropdown-divider{border-top:1px solid #e5e7eb}.dropdown-menu{padding:.5rem 0}.dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background-color .2s ease;width:100%}.dropdown-item:hover{background:#f3f4f6}.dropdown-overlay{bottom:0;right:0;z-index:10}.dropdown-overlay,.sidebar{left:0;position:fixed;top:0}.sidebar{background:#212121;border-radius:20px 20px 0 0;box-shadow:2px 0 10px #0000001a;color:#fff;display:flex;flex-direction:column;height:100vh;transition:width .3s ease;width:280px;z-index:1000}.sidebar.collapsed{width:80px}.sidebar-header{justify-content:center;min-height:80px}.logo,.sidebar-header{align-items:center;display:flex}.logo{gap:.75rem;height:48px;width:120px}.logo-icon{font-size:1.5rem;text-align:center;width:32px}.logo-text{color:#2932e5;font-size:1.5rem;font-weight:700;letter-spacing:-.025em}.sidebar-nav{flex:1 1;padding:1rem 0}.nav-list{list-style:none;margin:0;padding:0}.nav-link{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#ff855533;border-right:3.2px solid #ff8555;color:#fff;font-weight:500;position:relative}.nav-link.active:after{border-bottom:8px solid #0000;border-left:8px solid #2932e5;border-top:8px solid #0000;height:0;position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);width:0}.nav-link.has-submenu{position:relative}.submenu-arrow{font-size:12px;margin-left:auto;transition:transform .2s ease}.submenu-arrow.expanded{transform:rotate(180deg)}.submenu{background-color:#f3f4f6;border-radius:8px;list-style:none;margin:8px 0 0;overflow:hidden;padding:0}.submenu-item{margin:0}.submenu-link{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:.8rem;gap:.5rem;padding:.5rem 1rem .5rem 3rem;text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.submenu-link:hover{background-color:#e5e7eb;color:#374151;transform:translateX(4px)}.submenu-link.active{color:#2932e5;font-weight:500}.submenu-icon{font-size:14px}.submenu-label{white-space:nowrap}.nav-icon{color:#fff;flex-shrink:0;font-size:1.125rem;text-align:center;width:20px}.nav-icon svg{stroke:#fff;color:#fff}.nav-label{flex:1 1;overflow:hidden;white-space:nowrap}.sidebar-footer{border-top:1px solid #e5e7eb;padding:1rem 1.5rem}.footer{background-color:#fafafa;border-top:1px solid #f3f4f6;bottom:0;margin-top:auto;position:-webkit-sticky;position:sticky;z-index:9999}.footer,.footer-content{align-items:center;display:flex;justify-content:space-between;padding:0 1rem;width:100%}.footer-left{flex:1 1;text-align:left}.footer-center{flex:1 1;text-align:center}.footer-right{flex:1 1;text-align:right}.ready-text{font-weight:500}.copyright-text,.ready-text{color:#6b7280;font-size:.875rem}.allcad-logo,.copyright-text,.ready-text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.allcad-logo{align-items:center;display:inline-flex;font-size:1rem;font-weight:600}.logo-image{max-width:14rem;width:auto}.logo-text-fallback{align-items:center;display:inline-flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;font-weight:600}.logo-a{color:#3b82f6;position:relative}.logo-a:before{border-bottom:4px solid #ef4444;border-left:3px solid #0000;border-right:3px solid #0000;content:"";height:0;left:-3px;position:absolute;top:-2px;width:0}.logo-ll{color:#10b981}.logo-cad{color:#1e40af}@media (max-width:768px){.main-content,.main-content.sidebar-collapsed{margin-left:0}.header{padding:0 1rem}.mobile-menu-btn{display:block}.page-title{font-size:1.25rem}.footer-content{flex-direction:column;gap:.5rem;text-align:center}.footer-center,.footer-left,.footer-right{flex:none;text-align:center}.copyright-text,.ready-text{font-size:.75rem}.allcad-logo{font-size:.875rem}.user-name{display:none}.sidebar{transform:translateX(-100%);transition:transform .3s ease}.sidebar.open{transform:translateX(0)}.sidebar.collapsed{transform:translateX(-100%);width:280px}}body{font-family:Roboto,sans-serif;font-size:14px;font-style:Regular;font-weight:400;line-height:1.5}.login-container{background:#fff;height:100vh;width:100vw}.login-container,.login-left-panel{display:flex;overflow:hidden;position:relative}.login-left-panel{align-items:center;color:#fff;height:100%;width:60%}.login-left-panel,.login-left-panel:before{background:url(/static/media/login-background.7fda610271c5e5e69e1d.png) 50%/cover no-repeat}.login-left-panel:before{content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.login-branding{margin-left:3rem;max-width:550px}.logo-image{height:48px;object-fit:contain;position:relative;width:120px}.logo-footer{max-width:10rem;object-fit:contain;padding:.5rem}.login-copyright{color:#6b7280;font-size:1rem;margin-top:2rem;text-align:center}.brand-title{color:#f26a56;font-family:Inter,sans-serif;font-size:72px;font-weight:900;line-height:1.2;margin-bottom:8vh;text-align:start}.brand-subtitle{bottom:4rem;font-size:4rem;font-style:italic;font-weight:500;position:absolute}.brand-features{font-size:18px;line-height:1.8;margin-bottom:10vh}.feature-item{margin-bottom:6px;margin-left:16px}.feature-item-bullet{margin-right:8px}.brand-tagline{color:#f26a56;font-size:28px}.login-right-panel{align-items:center;background:#fff;display:flex;justify-content:center;width:40%}.login-form-container{text-align:left;width:360px}.form-title{color:#333;display:flex;font-family:Inter,sans-serif;font-size:28px;font-weight:700;justify-content:center;margin-bottom:8vh;text-align:start}.form-subtitle{margin-bottom:10px}.form-description{margin-bottom:20px}.title-orange{color:#f26a56}.login-form{display:flex;flex-direction:column;gap:20px;margin-top:1.5rem}.form-group input{border:1px solid #ccc;border-radius:6px;font-family:Inter,sans-serif;font-size:15px;padding:12px 14px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#5055f5;outline:none}.form-group input.error{border-color:#ef4444}.error-message{color:#ef4444;font-size:12px;margin-top:4px}.otp-sent-message{animation:fadeIn .3s ease-in-out;background-color:#e6ffed;border:1px solid #a7f3d0;border-radius:8px;color:#057a55;font-size:.95rem;padding:10px 14px;text-align:center}.login-button{background-color:#5055f5;border:none;border-radius:6px;box-shadow:1px 10px 20px #00000024;color:#fff;cursor:pointer;font-weight:700;padding:14px;transition:all .3s ease}.login-button:hover:not(:disabled){background-color:#3d4af0;transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.6}.error-alert{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#f87171;font-size:14px;padding:10px 15px;text-align:center}.login-footer{align-items:center;display:flex;font-size:14px;gap:8px;margin-top:20px}.forgot-text{color:#333;font-weight:400}.forgot-link{color:#333;font-weight:700;text-decoration:underline;transition:color .3s ease}.forgot-link:hover{color:#5055f5}.permissions-page,.roles-page,.users-page{margin:0 auto}.breadcrumbs{color:#6b7280;display:flex;flex-direction:column;font-size:.875rem;gap:1px;min-height:49px;min-width:322.85px;opacity:1;padding:1rem 1.5rem}.breadcrumb-item{color:#ff8555;font-size:20px;font-size:16px;line-height:24px}.breadcrumb-Desc,.breadcrumb-item{font-style:normal;font-weight:400;letter-spacing:0;overflow:visible;white-space:nowrap}.breadcrumb-Desc{color:#4a5565;font-family:Roboto,sans-serif;font-size:14px;line-height:21px;margin-top:-7px;min-height:21px;opacity:1;position:relative;top:.13px}.breadcrumb-item:hover{color:#374151}.breadcrumb-separator{color:#9ca3af}.page-header{align-items:center;background:#f2f2f2;border:1.07px solid #f3f4f6;border-radius:10px;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px 0 #0000001a;display:flex;justify-content:space-between;margin-bottom:1rem;opacity:1;padding:10px;width:100%}.header-left h1.page-title{color:#1f2937;font-size:2rem;font-weight:700}.page-subtitle{color:#6b7280;font-size:1rem;margin:0}.header-right .btn{border:1.07px solid #d1d5dc;border-radius:8px;box-shadow:none!important;font-style:Medium;gap:.5rem;padding:.3rem 1rem}.btn-primary,.header-right .btn{align-items:center;cursor:pointer;display:flex;font-size:14px;font-weight:500;letter-spacing:0;line-height:20px;text-transform:none;transition:all .2s ease}.btn-primary{background:#fafafa;border:1.07px solid #d1d5dc;border-radius:10px;color:#404040;font-family:Roboto,sans-serif;font-style:normal;gap:5px;justify-content:center;min-width:95px;opacity:1;padding:.75rem!important}.btn-primary:hover{background-color:#2932e5}.btn-secondary{align-items:center;background-color:initial;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-style:normal;font-weight:500;gap:5px;justify-content:center;letter-spacing:0;line-height:20px;padding:.75rem 1.5rem;text-transform:none;transition:all .2s ease}.btn-secondary:hover{background-color:#ffebee;border-color:#f26a56}.btn-filters{background-color:#fafafa;border:2px solid #d1d5dc;border-radius:8px;cursor:pointer;font-weight:500;gap:.5rem;max-width:-webkit-fit-content;max-width:fit-content;padding:.75rem;transition:all .2s ease;white-space:nowrap}.btn-filters,.page-filters{align-items:center;display:flex}.page-filters{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.search-filters-container{align-items:center;display:flex;gap:7rem;justify-content:flex-start}.search-container{max-width:400px;min-width:200px;position:relative}.search-input{background:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;padding:.75rem 1rem .75rem 2.5rem;width:25rem}.search-input:focus{border-color:#2932e5;box-shadow:0 0 0 3px #f45b491a;outline:none}.search-icon{color:#9ca3af;left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.active-filters,.filter-actions{display:flex;gap:.5rem}.active-filters{flex-direction:column;margin-right:1rem}.filter-count{align-self:flex-start;background-color:#dbeafe;border-radius:12px;color:#1e40af;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.filter-tags{display:flex;flex-wrap:wrap;gap:.5rem}.filter-tag{background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;color:#374151;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;padding:.75rem}.permissions-table-container,.roles-table-container,.users-table-container{background:#f2f2f2;border-radius:12px;border-top:1.07px solid #f3f4f6;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px 0 #0000001a;overflow:hidden}.roles-cards-container{width:100%}.roles-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,365.47px);justify-content:start;padding:1rem 0}.role-card{background:#f2f2f2;border:1.07px solid #e5e7eb;border-radius:14px;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px 0 #0000001a;display:flex;flex-direction:column;gap:.75rem;height:373.27px;justify-content:space-between;opacity:1;padding:1.5rem;transition:all .3s ease;width:365.47px}.role-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.role-card-top{justify-content:space-between;margin-bottom:.5rem}.role-card-top,.role-icon{align-items:center;display:flex}.role-icon{border-radius:10px;height:48px;justify-content:center;opacity:1;padding-right:0;width:48px}.role-shield-icon{height:32px;object-fit:contain;width:32px}.action-dropdown-btn-vertical{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem .5rem;transition:color .2s ease}.action-dropdown-btn-vertical:hover{color:#374151}.role-card-name{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 .35rem}.role-card-description{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;color:#6b7280;display:-webkit-box;flex:1 1;font-size:.875rem;line-height:1.5;margin:0;max-height:4.5em;overflow:hidden;text-overflow:ellipsis}.role-card-field{display:flex;flex-direction:column;gap:.35rem}.permissions-container-full,.role-card-field .permissions-container{display:flex;flex-wrap:wrap;gap:.5rem}.permissions-container-full{align-content:flex-start;margin-top:auto;min-height:60px;padding-top:.5rem;width:100%}.role-card-label{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.role-card-value{color:#4a5565;font-size:.875rem;line-height:1.5;margin:0}.role-users-header{align-items:center;display:flex;justify-content:space-between}.role-users-count{color:#4a5565;font-size:.875rem;font-weight:600}.role-progress-bar{background-color:#e5e7eb;border-radius:10px;height:8px;margin-top:.5rem;overflow:hidden;width:100%}.role-progress-fill{background:linear-gradient(90deg,#2932e5,#4f5bff);border-radius:10px;height:100%;transition:width .3s ease}@media (max-width:1600px){.roles-cards-grid{grid-template-columns:repeat(auto-fit,365.47px);justify-content:center}}@media (max-width:1200px){.roles-cards-grid{grid-template-columns:repeat(auto-fit,minmax(320px,365.47px));justify-content:center}.role-card{max-width:365.47px;width:100%}}@media (max-width:640px){.roles-cards-grid{grid-template-columns:1fr}.role-card{max-width:100%;width:100%}}.permissions-table,.roles-table,.users-table{border-collapse:collapse;width:100%}.permissions-table th,.roles-table th,.users-table th{background-color:#f2f2f2;border-bottom:1px solid #e5e7eb;color:#4a5565;font-size:.875rem;font-weight:400;padding:1rem;text-align:left}.permissions-table td,.roles-table td,.users-table td{background-color:#f2f2f2;border-bottom:1px solid #f3f4f6;color:#4a5565;font-weight:400;padding:1rem;vertical-align:middle}.permissions-table tr:hover td,.roles-table tr:hover td,.users-table tr:hover td{background-color:#f9fafb}.permissions-table tr,.roles-table tr,.users-table tr{border-bottom:2px solid #e5e7eb}.permission-info,.role-info,.user-info{align-items:center;gap:.75rem}.user-info{position:relative}.status-indicator{border-radius:50%;flex-shrink:0;height:16px;margin-right:.5rem;width:16px}.status-indicator.active{size:16px;background-color:#4caf50}.status-indicator.inactive{background-color:#f44336}.permission-avatar,.role-avatar,.user-avatar{align-items:center;background-color:#2932e5;border-radius:50%;color:#fff;display:flex;font-weight:600;height:40px;justify-content:center;width:40px}.role-avatar{background-color:#10b981}.permission-avatar{background-color:#f59e0b}.permission-name,.role-name,.user-name{color:#4a5565;cursor:pointer;font-weight:400;text-decoration:none}.permissions-container,.roles-container{display:flex;flex-wrap:wrap;gap:.25rem}.permission-badge,.role-badge{border:1px solid #e5e7eb;border-radius:5px;color:#4a5565;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.status-badge{color:#fff}.status-badge,.status-badge-role{background-color:#2932e5;border:1px solid #2932e5;border-radius:5px;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.status-badge-role{color:#fff!important}.status-badge.inactive{background-color:#fb2c36;border:1px solid #fb2c36}.permission-badge{background-color:#2932e515;color:#2932e5}.permission-badge.more{background-color:#0a108215;color:#2932e5}.category-badge{background-color:#ffebee;border:1px solid #ffcdd2;border-radius:12px;color:#2932e5}.action-badge,.category-badge{font-size:.75rem;font-weight:500;padding:.25rem .5rem}.action-badge{background-color:#e3f2fd;border:1px solid #bbdefb;border-radius:12px;color:#1976d2}.no-permissions,.no-roles{color:#9ca3af;font-size:.875rem;font-style:italic}.status-toggle{border:none;border-radius:20px;cursor:pointer;font-size:.75rem;font-weight:500;padding:.25rem .75rem;transition:all .2s ease}.status-toggle.active{background-color:#4caf50;color:#fff}.status-toggle.inactive{background-color:#f44336;color:#fff}.action-buttons{display:flex;gap:.5rem}.btn-icon{align-items:center;background:#0000;border:none;display:inline-flex;font-size:16px;height:16px;justify-content:center;line-height:16px;opacity:1;width:16px}.btn-edit:hover{background-color:#dbeafe;transform:scale(1.05)}.btn-delete:hover{background-color:#fef2f2;transform:scale(1.05)}.action-dropdown{display:inline-block;position:relative}.action-dropdown-btn{align-items:center;background-color:initial;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;font-size:1.2rem;height:2rem;justify-content:center;transition:all .2s ease;width:2rem}.action-dropdown-btn:hover{background-color:#f3f4f6;color:#374151}.action-dropdown-menu{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:block;margin-top:0;min-width:150px;position:absolute;right:0;top:100%;z-index:1000!important}.action-dropdown-menu:before{background:#0000;content:"";height:.5rem;left:0;position:absolute;right:0;top:-.5rem}.action-dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background-color .2s ease;width:100%}.action-dropdown-item:hover{background:#f3f4f6}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:2rem 2rem 1rem}.modal-header h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.modal-close{background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .2s ease}.modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:1rem 2rem}.camera-form,.permission-form,.role-form,.user-form{display:flex;flex-direction:column;gap:1.5rem}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.75rem}.form-group label{color:#6b7280;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.form-group input,.form-group select,.form-group textarea{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;padding:.75rem 1rem;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background-color:#fff;border-color:#2932e5;outline:none}.form-group textarea{min-height:80px;resize:vertical}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{padding-right:3rem;width:100%}.password-toggle{color:#6b7280;cursor:pointer;font-size:1rem;position:absolute;right:1rem}.password-toggle:hover{color:#374151}.toggle-container{margin-top:.5rem}.toggle-label{align-items:center;cursor:pointer;display:flex;gap:1rem}.toggle-text{color:#374151;font-size:.875rem;font-weight:500}.toggle-switch{align-items:center;display:flex;gap:.75rem}.toggle-input{display:none}.toggle-slider{background-color:#e5e7eb;border-radius:16px;cursor:pointer;height:32px;position:relative;transition:all .3s ease;width:60px}.toggle-knob{background-color:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:28px;left:2px;position:absolute;top:2px;transition:all .3s ease;width:28px}.toggle-input:checked+.toggle-slider{background-color:#4caf50}.toggle-input:checked+.toggle-slider .toggle-knob{transform:translateX(28px)}.toggle-status{color:#374151;font-size:.875rem;font-weight:500;min-width:20px}.permission-builder{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.permission-builder h4{color:#374151;font-size:1rem;font-weight:600;margin:0 0 1rem}.builder-divider{color:#6b7280;font-weight:500;margin:1rem 0;position:relative;text-align:center}.builder-divider:before{background-color:#e5e7eb;content:"";height:1px;left:0;position:absolute;right:0;top:50%;z-index:1}.builder-divider:after{background-color:#f9fafb;content:"OR";padding:0 1rem;position:relative;z-index:2}.permissions-grid{background-color:#f9fafb;border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));max-height:200px;padding:.5rem}.checkbox-label{align-items:flex-start;border-radius:6px;padding:.5rem;transition:background-color .2s ease}.checkbox-label:hover{background-color:#f3f4f6}.checkbox-label input[type=checkbox]{margin:.125rem 0 0}.checkbox-label span{color:#374151;font-size:.875rem;font-weight:500}.permission-description{color:#4a5565;display:block;font-size:14px;font-style:italic;margin-top:.25rem}.status-display{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:.5rem;padding:.75rem 1rem}.form-sections-row{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.form-section{display:flex;flex-direction:column;gap:1.5rem}.form-help,.form-hint{color:#6b7280;font-size:.75rem;margin-top:.25rem}.form-hint{font-style:italic}.field-error{color:#ef4444;font-size:.75rem;margin-top:.25rem}.form-error.submit-error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#b91c1c;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.permissions-grid{grid-gap:.75rem;border:1px solid #e5e7eb;border-radius:6px;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));justify-items:start;max-height:300px;overflow-y:auto;padding:1rem}.multi-select{min-height:100px;padding:.5rem}.multi-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.modal-footer{background-color:initial;border-top:none;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem 2rem}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{color:#dc2626;margin-bottom:1rem}.empty-state{color:#6b7280;padding:3rem;text-align:center}.pagination{align-items:center;display:flex;justify-content:space-between;padding:1rem}.pagination-info{color:#6b7280;font-size:.875rem}.pagination-controls{align-items:center;display:flex;gap:.5rem}.pagination button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;border-radius:100%;color:#374151;cursor:pointer;display:flex;height:40px;justify-content:center;min-width:40px;padding:.5rem 1rem;transition:all .2s ease}.pagination button:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.pagination button.active{background-color:#2932e5;border-color:#2932e5;color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination span{color:#6b7280;font-size:.875rem}.dashboard{margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:.5rem}.dashboard-header p{color:#6b7280;font-size:1rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.stat-icon{align-items:center;background:#2932e5;border-radius:12px;display:flex;flex-shrink:0;font-size:2rem;height:60px;justify-content:center;width:60px}.stat-content{flex:1 1}.stat-title{color:#6b7280;font-size:.875rem;font-weight:500;margin:0 0 .5rem}.stat-value{color:#1f2937;display:block;font-size:1.875rem;font-weight:700;margin-bottom:.25rem}.stat-change{font-size:.75rem;font-weight:500}.stat-change.positive{color:#059669}.stat-change.negative{color:#dc2626}.dashboard-content{margin-top:2rem}.content-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:2fr 1fr}.section-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;padding:1.5rem}.section-card h2{color:#1f2937;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.chart-placeholder{align-items:center;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;display:flex;flex-direction:column;height:300px;justify-content:center}.chart-bars{align-items:end;display:flex;gap:8px;height:120px;margin-bottom:1rem}.bar{animation:growUp .8s ease-out;background:#2932e5;border-radius:2px 2px 0 0;width:20px}@keyframes growUp{0%{height:0}to{height:100%;height:var(--height,100%)}}.chart-label{color:#6b7280;font-size:.875rem;margin:0}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:background-color .2s ease}.activity-item:hover{background:#f3f4f6}.activity-avatar{align-items:center;background:#2932e5;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:40px;justify-content:center;width:40px}.activity-content{flex:1 1}.activity-user{color:#1f2937;font-size:.875rem;font-weight:500}.activity-action{color:#6b7280;font-size:.75rem;margin:.25rem 0}.activity-time{color:#9ca3af;font-size:.75rem}.analytics-page{margin:0 auto}.analytics-content{margin-top:2rem}.settings-page{margin:0 auto}.settings-content{margin-top:2rem}.settings-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.settings-section{margin-bottom:2rem}.settings-form{gap:1rem}.settings-form,.system-info{display:flex;flex-direction:column}.system-info{gap:.75rem}.info-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.5rem 0}.info-label{color:#374151;font-weight:500}.info-value{color:#6b7280}.status-online{color:#059669;font-weight:500}.form-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;padding:.75rem}.form-select:focus{border-color:#2932e5;box-shadow:0 0 0 3px #f45b491a;outline:none}@media (max-width:768px){.dashboard-header h1{font-size:1.5rem}.content-grid,.stats-grid{gap:1rem;grid-template-columns:1fr}.section-card,.stat-card{padding:1rem}.chart-placeholder{height:200px}}@media (max-width:480px){.login-card{padding:2rem}.login-header h1{font-size:1.5rem}}
/*# sourceMappingURL=main.30880c3a.css.map*/