*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0f172a,#1e293b);color:#e2e8f0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.loading-screen{align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.spinner{animation:spin .8s linear infinite;border:3px solid #3b82f633;border-radius:50%;border-top-color:#3b82f6;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-screen p{color:#94a3b8;font-size:1.1rem}@media (max-width:768px){.spinner{border-width:2.5px;height:40px;width:40px}.loading-screen p{font-size:1rem;padding:0 1rem;text-align:center}}@media (max-width:480px){.spinner{border-width:2px;height:35px;width:35px}.loading-screen p{font-size:.9rem}}@media (prefers-reduced-motion:reduce){.spinner{animation-duration:1.5s}}:root{--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a}.dark-mode,:root.dark{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-tertiary:#94a3b8;--border-color:#334155;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #00000080;--shadow-lg:0 10px 15px -3px #000000b3}body{background-color:#fff;background-color:var(--bg-primary);color:#0f172a;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.card,.modal-content,.navbar,.sidebar,.widget{background-color:#f8fafc;background-color:var(--bg-secondary);border-color:#e2e8f0;border-color:var(--border-color);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transition:background-color .3s ease,border-color .3s ease}h1,h2,h3,h4,h5,h6{color:#0f172a;color:var(--text-primary)}div,p,span{color:#475569;color:var(--text-secondary)}input,select,textarea{background-color:#f1f5f9;background-color:var(--bg-tertiary);border-color:#e2e8f0;border-color:var(--border-color);color:#0f172a;color:var(--text-primary)}input:focus,select:focus,textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.btn-secondary{background-color:#f1f5f9;background-color:var(--bg-tertiary);border-color:#e2e8f0;border-color:var(--border-color);color:#0f172a;color:var(--text-primary)}.btn-secondary:hover,table{background-color:#f8fafc;background-color:var(--bg-secondary)}thead{background-color:#f1f5f9;background-color:var(--bg-tertiary);color:#0f172a;color:var(--text-primary)}tbody tr{border-bottom-color:#e2e8f0;border-bottom-color:var(--border-color)}tbody tr:hover{background-color:#f1f5f9;background-color:var(--bg-tertiary)}.dark-mode-toggle{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;bottom:20px;box-shadow:0 4px 12px #0000004d;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:20px;transition:all .3s ease;width:56px;z-index:9000}.dark-mode-toggle:hover{box-shadow:0 6px 20px #0006;transform:scale(1.1)}.dark-mode-toggle:active{transform:scale(.95)}.offline-indicator{animation:slideDown .3s ease;background:#f59e0b;border-radius:20px;box-shadow:0 4px 12px #0003;color:#fff;font-size:14px;font-weight:500;left:50%;padding:8px 20px;position:fixed;top:70px;transform:translateX(-50%);z-index:10000}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.pwa-install-prompt{align-items:center;animation:slideUp .3s ease;background:#fff;border-radius:12px;bottom:80px;box-shadow:0 8px 24px #0003;display:flex;gap:16px;left:50%;max-width:400px;padding:16px 24px;position:fixed;transform:translateX(-50%);z-index:9000}.dark-mode .pwa-install-prompt{background:#1e293b;color:#f1f5f9}@keyframes slideUp{0%{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.pwa-install-prompt button{border:none;border-radius:8px;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s}.pwa-install-btn{background:#3b82f6;color:#fff}.pwa-install-btn:hover{background:#2563eb}.pwa-dismiss-btn{background:#0000;color:#64748b}.pwa-dismiss-btn:hover{color:#0f172a}.brand-logo{align-items:center;display:inline-flex;flex-shrink:0}.brand-logo-image{display:block;object-fit:contain;width:auto}.brand-logo-full .brand-logo-image,.brand-logo-mark .brand-logo-image{height:32px}.brand-logo-framed{background:#fffffff5;border-radius:12px;box-shadow:0 8px 24px #0f172a2e;padding:.45rem .7rem}.brand-logo-compact .brand-logo-image{height:28px}.login-page{align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1e293bcc;border:1px solid #3b82f633;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:420px;padding:2.5rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-brand-logo{margin-bottom:1rem}.login-header h1{color:#3b82f6;font-size:2rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:#94a3b8;font-size:.95rem}.alert{border-radius:8px;font-size:.9rem;margin-bottom:1.5rem;padding:.75rem 1rem}.alert-error{background:#ef444426;border:1px solid #ef44444d;color:#ef4444}.alert-warning{align-items:center;background:#f59e0b26;border:1px solid #f59e0b4d;color:#f59e0b;display:flex}.alert-success{background:#22c55e26;border:1px solid #22c55e4d;color:#22c55e}.login-form{gap:1.25rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#cbd5e1;font-size:.95rem;font-weight:500}.form-group input{background:#0f172a80;border:1px solid #3b82f64d;border-radius:8px;color:#e2e8f0;font-size:1rem;padding:.75rem 1rem;transition:all .2s;width:100%}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:.875rem;transition:all .2s;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 8px 16px #3b82f64d;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.login-footer{margin-top:1.5rem;text-align:center}.link-button{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:.95rem;padding:0;text-decoration:underline}.link-button:hover{color:#60a5fa}@media (max-width:768px){.login-page{align-items:flex-start;padding:10vh 1rem 1rem}.login-container{border-radius:12px;max-width:100%;padding:2rem 1.5rem}.login-header h1{font-size:1.75rem}.login-header p{font-size:.9rem}.form-group input{font-size:16px;padding:.875rem 1rem}.btn-primary{font-size:1rem;padding:1rem}}@media (max-width:480px){.login-page{padding:5vh .75rem .75rem}.login-container{border-radius:10px;padding:1.5rem 1.25rem}.login-header{margin-bottom:1.5rem}.login-header h1{font-size:1.5rem}.login-form{gap:1rem}.form-group label{font-size:.9rem}.alert{font-size:.85rem;padding:.625rem .875rem}.login-footer{margin-top:1.25rem}.link-button{font-size:.9rem}}@media (hover:none) and (pointer:coarse){.btn-primary,.form-group input{min-height:48px}.link-button{align-items:center;display:inline-flex;min-height:44px;padding:.5rem}}@media (max-height:500px) and (orientation:landscape){.login-page{align-items:flex-start;padding-top:1rem}.login-container{padding:1.25rem}.login-header{margin-bottom:1rem}.login-header h1{font-size:1.25rem}.login-form{gap:.75rem}}.layout-with-sidebar{display:flex;flex-direction:column;min-height:100vh}.top-navbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f172afa;border-bottom:1px solid #3b82f633;height:56px;justify-content:space-between;left:0;padding:0 1rem;position:fixed;right:0;top:0;z-index:1000}.navbar-left,.top-navbar{align-items:center;display:flex}.navbar-left{gap:1rem}.navbar-brand{align-items:center;display:flex;line-height:0}.navbar-brand .brand-logo-image{height:34px}.navbar-right{align-items:center;display:flex;gap:.75rem}.navbar-alarm-icon{align-items:center;border-radius:8px;color:#94a3b8;display:flex;height:40px;justify-content:center;margin-right:.5rem;position:relative;text-decoration:none;transition:all .2s;width:40px}.navbar-alarm-icon:hover{background:#94a3b81a;color:#e2e8f0}.navbar-alarm-icon.has-alarms{color:#f87171}.navbar-alarm-icon.has-alarms.priority-critical{animation:pulse-critical 2s infinite;color:#c084fc}.navbar-alarm-icon.has-alarms.priority-high{color:#f87171}.navbar-alarm-icon.has-alarms.priority-medium{color:#fbbf24}.navbar-alarm-icon.has-alarms.priority-low{color:#60a5fa}.alarm-badge{align-items:center;background:#ef4444;border-radius:9px;color:#fff;display:flex;font-size:.65rem;font-weight:600;height:18px;justify-content:center;line-height:1;min-width:18px;padding:0 5px;position:absolute;right:2px;top:2px}.navbar-alarm-icon.priority-critical .alarm-badge{background:#a855f7}.navbar-alarm-icon.priority-high .alarm-badge{background:#ef4444}.navbar-alarm-icon.priority-medium .alarm-badge{background:#f59e0b}.navbar-alarm-icon.priority-low .alarm-badge{background:#3b82f6}.navbar-alarm-icon.alarm-sounding{animation:alarm-shake .5s ease-in-out infinite}.navbar-alarm-icon.alarm-sounding .alarm-badge{animation:alarm-pulse-badge 1s ease-in-out infinite}@keyframes alarm-shake{0%,to{transform:rotate(0deg)}15%{transform:rotate(12deg)}30%{transform:rotate(-10deg)}45%{transform:rotate(8deg)}60%{transform:rotate(-6deg)}75%{transform:rotate(3deg)}}@keyframes alarm-pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.navbar-alarm-silence{align-items:center;animation:alarm-pulse-badge 1s ease-in-out infinite;background:#ef444433;border:none;border-radius:8px;color:#f87171;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.navbar-alarm-silence:hover{background:#ef444466;color:#fca5a5}@keyframes pulse-critical{0%,to{opacity:1}50%{opacity:.7}}.btn-logout{align-items:center;background:#0000;border:1px solid #ef444480;border-radius:8px;color:#ef4444;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-logout:hover{background:#ef44441a;border-color:#ef4444}.mobile-menu-toggle{background:#0000;border:none;color:#94a3b8;cursor:pointer;display:none;padding:.5rem}.sidebar{background:#0f172afa;border-right:1px solid #3b82f626;bottom:0;display:flex;flex-direction:column;left:0;overflow:hidden;position:fixed;top:56px;transition:width .3s ease;width:240px;z-index:900}.sidebar.collapsed{width:60px}.sidebar-toggle{align-items:center;background:#0000;border:none;border-bottom:1px solid #3b82f61a;color:#64748b;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s;width:100%}.sidebar-toggle:hover{background:#3b82f61a;color:#3b82f6}.sidebar-content{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:.5rem 0}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-track{background:#0000}.sidebar-content::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:2px}.sidebar-section{padding:.25rem 0}.sidebar-section-title{color:#64748b;font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:.75rem 1rem .5rem;text-transform:uppercase}.sidebar-divider{background:#3b82f626;height:1px;margin:.5rem .75rem}.sidebar-link{align-items:center;background:#0000;border:none;color:#94a3b8;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.625rem 1rem;text-align:left;text-decoration:none;transition:all .2s;white-space:nowrap;width:100%}.sidebar-link:hover{background:#3b82f61a;color:#e2e8f0}.sidebar-link.active{background:#3b82f626;border-left:3px solid #3b82f6;color:#3b82f6;padding-left:calc(1rem - 3px)}.sidebar-link svg{flex-shrink:0}.sidebar-link-text{flex:1 1;overflow:hidden;text-overflow:ellipsis}.folder-arrow{margin-left:auto;opacity:.6}.sidebar.collapsed .sidebar-link{justify-content:center;padding:.75rem}.sidebar.collapsed .sidebar-link.active{border-left:3px solid #3b82f6;padding-left:.75rem}.sidebar-children{background:#0003}.main-content-area{background:linear-gradient(135deg,#0f172a,#1e293b);margin-left:240px;margin-top:56px;min-height:calc(100vh - 56px);overflow-x:hidden;padding:1.5rem;transition:margin-left .3s ease}.layout-with-sidebar.sidebar-collapsed .main-content-area{margin-left:60px}@media (max-width:768px){.mobile-menu-toggle{display:flex}.sidebar{display:none}.main-content-area{margin-left:0;padding:1rem}.layout-with-sidebar.sidebar-collapsed .main-content-area{margin-left:0}.btn-logout .logout-text{display:none}.btn-logout{padding:.5rem}.navbar-alarm-icon{height:36px;margin-right:.25rem;width:36px}.mobile-backdrop{background:#0009;inset:0;position:fixed;z-index:1100}.mobile-sidebar{animation:slideIn .3s ease;background:#0f172afa;bottom:0;display:flex;flex-direction:column;left:0;position:fixed;top:0;width:280px;z-index:1200}.mobile-sidebar-header{align-items:center;border-bottom:1px solid #3b82f633;display:flex;gap:.75rem;padding:1rem}.mobile-sidebar-header .brand-logo-image{height:30px}.mobile-sidebar-header button{background:#0000;border:none;color:#94a3b8;cursor:pointer;margin-left:auto;padding:.25rem}.mobile-sidebar-content{flex:1 1;overflow-y:auto;padding:.5rem 0}.mobile-logout-btn{align-items:center;background:#ef44441a;border:none;border-top:1px solid #ef444433;color:#ef4444;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;justify-content:center;padding:1rem}.mobile-logout-btn:hover{background:#ef444433}.mobile-sidebar .sidebar-link-text,.mobile-sidebar .sidebar-section-title{display:inline!important}.mobile-sidebar .sidebar-link{justify-content:flex-start;padding:.75rem 1rem}}@media (min-width:769px) and (max-width:1024px){.sidebar{width:200px}.sidebar.collapsed{width:60px}.main-content-area{margin-left:200px}.layout-with-sidebar.sidebar-collapsed .main-content-area{margin-left:60px}}@media (min-width:1400px){.sidebar{width:260px}.main-content-area{margin-left:260px}}.desktop-only{display:flex}@media (max-width:768px){.desktop-only{display:none}}.license-banner{align-items:center;display:flex;font-size:.85rem;font-weight:600;height:36px;justify-content:center;left:0;letter-spacing:.02em;position:fixed;right:0;top:56px;z-index:950}.license-banner-expired{background:linear-gradient(90deg,#dc2626,#ef4444);color:#fff}.license-banner-demo,.license-banner-warning{background:linear-gradient(90deg,#d97706,#f59e0b);color:#fff}.license-banner-content{align-items:center;display:flex;gap:.5rem}.license-banner-link{color:#fff;font-weight:700;margin-left:.5rem;opacity:.9;text-decoration:underline;transition:opacity .2s}.license-banner-link:hover{color:#fff;opacity:1}.sidebar.with-license-banner{top:92px}.main-content-area.with-license-banner{margin-top:92px}@media (max-width:768px){.license-banner{font-size:.75rem;height:32px}.main-content-area.with-license-banner{margin-top:88px}}.toast-container{display:flex;flex-direction:column;gap:10px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:9999}.toast-notification{align-items:center;animation:slideIn .3s ease-out;background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;max-width:450px;min-width:300px;padding:16px;pointer-events:auto}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.toast-notification.toast-exit{animation:slideOut .3s ease-out}@keyframes slideOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(400px)}}.toast-icon{align-items:center;display:flex;flex-shrink:0}.toast-message{color:#1f2937;flex:1 1;font-size:14px;line-height:1.5}.toast-close{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:background-color .2s}.toast-close:hover{background-color:#f3f4f6}.toast-close:active{background-color:#e5e7eb}@media (max-width:768px){.toast-container{bottom:20px;left:10px;right:10px;top:auto}.toast-notification{border-radius:10px;gap:10px;max-width:100%;min-width:auto;padding:14px;width:100%}.toast-message{font-size:13px}@keyframes slideIn{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100px)}}}@media (max-width:480px){.toast-container{bottom:10px;left:8px;right:8px}.toast-notification{border-radius:8px;gap:8px;padding:12px}.toast-message{font-size:12px}.toast-close{padding:6px}}@media (hover:none) and (pointer:coarse){.toast-close{min-height:44px;min-width:44px;padding:8px}}