@import"https://fonts.googleapis.com/css2?family=Fira+Code:wght@300;400;500;600;700&family=Fira+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Bebas+Neue&display=swap";@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600&display=swap";:root{--bg-void: #09090b;--bg-base: #111113;--bg-surface: #18181b;--bg-elevated: #27272a;--bg-card: #161618;--bg-input: #09090b;--bg-glass: rgba(24, 24, 27, .85);--border-dim: rgba(255, 255, 255, .08);--border-muted: rgba(255, 255, 255, .14);--border-base: rgba(255, 255, 255, .22);--border-glow: rgba(20, 184, 166, .3);--border-cyan: rgba(56, 189, 248, .25);--accent: #14b8a6;--accent-hot: #0d9488;--accent-dim: rgba(20, 184, 166, .12);--accent-glow: rgba(20, 184, 166, .06);--cyan: #38bdf8;--cyan-dim: rgba(56, 189, 248, .1);--cyan-glow: rgba(56, 189, 248, .06);--ok: #22c55e;--ok-dim: rgba(34, 197, 94, .12);--ok-glow: rgba(34, 197, 94, .08);--warn: #f59e0b;--warn-dim: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-dim: rgba(239, 68, 68, .12);--danger-glow: rgba(239, 68, 68, .08);--info: #38bdf8;--info-dim: rgba(56, 189, 248, .1);--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-accent: #14b8a6;--text-cyan: #38bdf8;--font-display: "Bebas Neue", sans-serif;--font-ui: "Fira Sans", sans-serif;--font-mono: "Fira Code", "JetBrains Mono", monospace;--shadow-card: 0 8px 32px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.25);--shadow-glow: 0 0 24px rgba(20, 184, 166, .15);--shadow-cyan: 0 0 20px rgba(56, 189, 248, .15);--shadow-danger: 0 0 24px rgba(239, 68, 68, .2);--shadow-deep: 0 20px 60px rgba(0,0,0,.7);--shadow-ok: 0 0 20px rgba(34, 197, 94, .15);--trans-fast: .15s cubic-bezier(.4, 0, .2, 1);--trans-base: .25s cubic-bezier(.4, 0, .2, 1);--trans-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;width:100%;max-width:100%;overflow-x:hidden}@media (max-width: 768px){*,*:before,*:after{max-width:100%;min-width:0}html,body,#root,main{overflow-x:hidden!important;width:100%!important}img,video,canvas,iframe{max-width:100%;height:auto}.font-mono,[style*=font-mono],code,pre,kbd,samp,td,th,.badge,.form-input,.card,.device-card,.page-subtitle,.page-title{overflow-wrap:anywhere;word-break:break-word}table,pre{overflow-x:hidden;display:block}[style*="minWidth: 600"],[style*="min-width: 600"]{min-width:0!important;width:100%!important}}body{font-family:var(--font-ui);background:var(--bg-void);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;max-width:100%;overflow-x:hidden;margin:0;padding:0}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.025) 2px,rgba(0,0,0,.025) 4px);pointer-events:none;z-index:9998}body:after{content:"";position:fixed;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.3;z-index:9999;pointer-events:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}h1,h2,h3{font-family:var(--font-display);letter-spacing:.05em}h4,h5,h6{font-family:var(--font-ui);font-weight:600;letter-spacing:.02em}.mono{font-family:var(--font-mono)}.label{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted)}@media (max-width: 480px){.topbar-brand-text{font-size:11px!important;letter-spacing:.05em!important}.stat-grid{grid-template-columns:1fr 1fr!important;gap:6px!important;margin-bottom:14px!important}.stat-card{padding:10px 12px!important;border-radius:8px!important}.stat-value{font-size:20px!important;margin-bottom:2px!important}.stat-label{font-size:8px!important}.page-title{font-size:17px!important;margin-bottom:2px!important}.page-subtitle{font-size:8.5px!important}.page-header{margin-bottom:14px!important}.btn{font-size:11px!important;padding:5px 10px!important}.device-card{padding:14px 16px!important}.badge{font-size:8.5px!important;padding:2px 6px!important}.card-header{padding:10px 14px!important}.card-body,.main-content{padding:12px!important}.main-content{padding:10px 14px!important}.mobile-hidden,.topbar-brand-text,.topbar-dot{display:none!important}.topbar{padding:0 10px!important;gap:8px!important}.topbar [class*=role-]+span,.topbar>div:last-child>div>span:last-child{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px!important}}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.app-shell{display:grid;grid-template-columns:224px 1fr;grid-template-rows:52px 1fr;height:100vh;height:100dvh;width:100%;max-width:100%;overflow-x:hidden;position:relative}@media (max-width: 768px){.app-shell{grid-template-columns:100%;grid-template-rows:52px 1fr}}.topbar{grid-column:1 / -1;grid-row:1;height:52px;background:#060e1c;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;padding:0 16px;gap:12px;position:relative;z-index:200;flex-shrink:0}@media (max-width: 768px){.topbar{grid-column:1;grid-row:1;padding:0 12px}.role-pill{display:none}}.topbar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,#f59e0b 30%,#00d4ff 70%,transparent 100%);opacity:.5}.sidebar{grid-column:1;grid-row:2;background:#060e1c;border-right:1px solid rgba(255,255,255,.06);padding:16px 0 24px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden}@media (max-width: 768px){.sidebar{position:absolute;top:52px;left:-100vw;transform:none!important;bottom:0;width:260px;z-index:9999;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:10px 0 30px #00000080;background:#060e1c;border-right:1px solid rgba(255,255,255,.06);display:flex!important;visibility:visible!important}.sidebar.mobile-open-active{left:0!important;transform:none!important;z-index:999999!important;opacity:1!important;visibility:visible!important}.mobile-menu-btn{display:block!important}}.dashboard-main-grid{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}@media (max-width: 768px){.dashboard-main-grid{grid-template-columns:1fr;gap:16px}}.main-content{grid-column:2;grid-row:2;overflow-y:auto;padding:24px 28px;background:var(--bg-base);position:relative}@media (max-width: 768px){.main-content{grid-column:1;grid-row:2;padding:16px}}.nav-section-label{padding:18px 18px 7px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;font-weight:600;text-transform:uppercase;color:var(--text-secondary)}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 18px;margin:0 8px;color:var(--text-secondary);cursor:pointer;border:none;background:none;width:calc(100% - 16px);text-align:left;font-family:var(--font-ui);font-size:13.5px;font-weight:500;letter-spacing:.01em;transition:all var(--trans-fast);border-radius:6px;border-left:2px solid transparent;position:relative;overflow:hidden}.nav-item:hover{color:var(--text-primary);background:#f59e0b0f;border-left-color:#f59e0b4d}.nav-item.active{color:var(--accent);background:var(--accent-dim);border-left-color:var(--accent);text-shadow:0 0 12px rgba(20,184,166,.4)}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);box-shadow:0 0 8px var(--accent)}.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-family:var(--font-mono);font-size:9px;font-weight:700;padding:1px 6px;border-radius:10px;animation:pulse-badge 2s ease-in-out infinite;box-shadow:0 0 8px #ef444480}@keyframes pulse-badge{0%,to{opacity:1;box-shadow:0 0 8px #ef444480}50%{opacity:.7;box-shadow:0 0 16px #ef4444cc}}.card{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:border-color var(--trans-base)}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent)}.card-header{padding:14px 18px;border-bottom:1px solid var(--border-dim);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-body{padding:18px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:24px}@media (max-width: 600px){.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:12px 14px}.stat-value{font-size:22px!important}.stat-label{font-size:9px!important;letter-spacing:.08em}}.stat-card{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;padding:18px 20px;position:relative;overflow:hidden;transition:all var(--trans-base);cursor:default}.stat-card:hover{border-color:var(--border-muted);transform:translateY(-1px)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-hot));opacity:.7}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--accent-glow) 0%,transparent 60%);pointer-events:none}.stat-card.ok:before{background:linear-gradient(90deg,var(--ok),#4ade80)}.stat-card.ok:after{background:linear-gradient(135deg,var(--ok-glow) 0%,transparent 60%)}.stat-card.warn:before{background:linear-gradient(90deg,var(--warn),var(--accent-hot))}.stat-card.danger:before{background:linear-gradient(90deg,var(--danger),#f87171)}.stat-card.danger:after{background:linear-gradient(135deg,var(--danger-glow) 0%,transparent 60%)}.stat-card.info:before{background:linear-gradient(90deg,var(--info),#67e8f9)}.stat-card.info:after{background:linear-gradient(135deg,var(--info-dim) 0%,transparent 60%)}.stat-value{font-family:var(--font-display);font-size:36px;line-height:1;color:var(--text-primary);margin-bottom:5px;letter-spacing:.03em;position:relative;z-index:1}.stat-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);position:relative;z-index:1}.btn{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:6px;border:1px solid transparent;font-family:var(--font-ui);font-size:13px;font-weight:500;letter-spacing:.02em;cursor:pointer;transition:all var(--trans-fast);white-space:nowrap;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff0;transition:background var(--trans-fast)}.btn:hover:before{background:#ffffff0a}.btn:active:before{background:#0000001a}.btn-primary{background:linear-gradient(135deg,var(--accent),#d97706);color:#000;border-color:var(--accent);font-weight:600;box-shadow:0 0 0 0 var(--accent);transition:all var(--trans-fast),box-shadow var(--trans-fast)}.btn-primary:hover{background:linear-gradient(135deg,var(--accent-hot),var(--accent));box-shadow:0 0 16px #f59e0b4d;filter:brightness(1.05)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-muted)}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-base);background:#ffffff0a}.btn-danger{background:transparent;color:var(--danger);border-color:#ef44444d}.btn-danger:hover{background:var(--danger-dim);border-color:#ef444480;box-shadow:0 0 12px #ef444426}.btn-ok{background:var(--ok-dim);color:var(--ok);border-color:#22c55e40}.btn-ok:hover{background:#22c55e33;border-color:#22c55e80;box-shadow:0 0 12px #22c55e26}.btn-cyan{background:var(--cyan-dim);color:var(--cyan);border-color:var(--border-cyan)}.btn-cyan:hover{background:#00d4ff26;box-shadow:var(--shadow-cyan)}.btn-sm{padding:5px 10px;font-size:12px;gap:5px}.btn-icon{padding:6px}.btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:4px;font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.badge-online{background:var(--ok-dim);color:var(--ok);border:1px solid rgba(34,197,94,.2);text-shadow:0 0 8px rgba(34,197,94,.4)}.badge-offline{background:#47556926;color:var(--text-muted);border:1px solid rgba(71,85,105,.2)}.badge-tampered{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(239,68,68,.25);text-shadow:0 0 8px rgba(239,68,68,.5);animation:tamper-badge-pulse 1.5s ease-in-out infinite}@keyframes tamper-badge-pulse{0%,to{box-shadow:0 0 #ef44444d}50%{box-shadow:0 0 0 4px #ef44441a}}.badge-info{background:var(--info-dim);color:var(--info);border:1px solid rgba(0,212,255,.2)}.badge-warning{background:var(--warn-dim);color:var(--warn);border:1px solid rgba(245,158,11,.2)}.badge-critical{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(239,68,68,.25);text-shadow:0 0 8px rgba(239,68,68,.5)}.badge-armed{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(245,158,11,.2);text-shadow:0 0 8px rgba(245,158,11,.4)}.badge-disarmed{background:#4755691f;color:var(--text-muted);border:1px solid rgba(71,85,105,.2)}.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.status-dot.pulsing{animation:pulse-dot 2s ease-in-out infinite;box-shadow:0 0 0 0 currentColor}@keyframes pulse-dot{0%{opacity:1;box-shadow:0 0 0 0 currentColor}50%{opacity:.7;box-shadow:0 0 0 3px #22c55e00}to{opacity:1;box-shadow:0 0 0 0 currentColor}}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-secondary);font-weight:600}.form-input,.form-select,.form-textarea,.input{background:var(--bg-input);border:1px solid var(--border-muted);border-radius:6px;color:var(--text-primary);font-family:var(--font-mono);font-size:13px;padding:9px 12px;transition:border-color var(--trans-fast),box-shadow var(--trans-fast);outline:none;width:100%;color-scheme:dark}.form-input:focus,.form-select:focus,.form-textarea:focus,.input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #f59e0b26,0 0 8px #f59e0b1a}.form-input::placeholder,.input::placeholder{color:var(--text-muted);font-family:var(--font-mono)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-textarea{resize:vertical;min-height:80px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 600px){.form-grid-2{grid-template-columns:1fr;gap:12px}}@media (min-width: 769px){.responsive-provision-grid{grid-template-columns:1fr 1fr 1fr auto}}@media (max-width: 768px){.responsive-provision-grid{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;align-items:stretch!important}.responsive-split-grid{grid-template-columns:1fr!important}}.form-input:-webkit-autofill,.form-input:-webkit-autofill:hover,.form-input:-webkit-autofill:focus,.input:-webkit-autofill,.input:-webkit-autofill:hover,.input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #080f1e inset!important;-webkit-text-fill-color:#f1f5f9!important;border-color:#ffffff17!important;caret-color:#f1f5f9;transition:background-color 600000s 0s!important}.login-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#000;border:1px solid #f59e0b;border-radius:8px;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;box-shadow:0 0 20px #f59e0b40,0 2px 8px #0006;transition:all .2s ease;margin-top:4px}.login-btn:hover{background:linear-gradient(135deg,#fbbf24,#f59e0b);box-shadow:0 0 32px #f59e0b66,0 4px 16px #0006;transform:translateY(-1px)}.login-btn:active{transform:translateY(0);box-shadow:0 0 16px #f59e0b33}.login-btn:disabled{background:#f59e0b33;color:#00000080;border-color:#f59e0b4d;box-shadow:none;cursor:not-allowed;transform:none}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:10px 14px;font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border-dim);white-space:nowrap;background:#0003}.data-table td{padding:11px 14px;border-bottom:1px solid var(--border-dim);color:var(--text-secondary);vertical-align:middle;transition:background var(--trans-fast),color var(--trans-fast)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#14b8a60d;color:var(--text-primary)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:12px}}.page-title{font-family:var(--font-display);font-size:30px;letter-spacing:.07em;color:var(--text-primary);line-height:1}.page-subtitle{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.14em;margin-top:5px}@media (max-width: 600px){.page-title{font-size:22px;letter-spacing:.05em}.page-subtitle{font-size:9px;letter-spacing:.1em}.page-header>div:last-child{width:100%;flex-wrap:wrap}.page-header>div:last-child .btn{flex:1 1 auto;min-width:0}}@media (max-width: 600px){.data-table{font-size:11px}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block;width:100%}.data-table tr{border-bottom:1px solid var(--border-dim);padding:8px 0}.data-table td{padding:4px 12px;text-align:left}}.app-shell{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.main-content{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(268px,1fr));gap:14px}@media (max-width: 600px){.device-grid{grid-template-columns:1fr;gap:12px}.card-header{padding:10px 12px;flex-wrap:wrap;gap:8px}.card-body{padding:12px}}.device-card{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;padding:18px;cursor:pointer;transition:all var(--trans-base);position:relative;overflow:hidden}.device-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--cyan) 0%,transparent 60%);opacity:0;transition:opacity var(--trans-base)}.device-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(0,212,255,.03) 0%,transparent 50%);opacity:0;transition:opacity var(--trans-base)}.device-card:hover{border-color:var(--border-cyan);box-shadow:0 0 0 1px #00d4ff1a,var(--shadow-cyan);transform:translateY(-2px)}.device-card:hover:before{opacity:1}.device-card:hover:after{opacity:1}.device-card.armed{border-color:#f59e0b40;background:linear-gradient(135deg,rgba(245,158,11,.04) 0%,var(--bg-card) 40%)}.device-card.armed:before{background:linear-gradient(90deg,var(--accent) 0%,transparent 60%);opacity:1}.device-card.tampered{border-color:#ef444466;animation:tamper-pulse 2s ease-in-out infinite}@keyframes tamper-pulse{0%,to{box-shadow:0 0 #ef444400;border-color:#ef444466}50%{box-shadow:0 0 16px #ef444433;border-color:#ef444499}}.device-card.alarmed{border-color:#ef4444d9;animation:alarm-flash .9s ease-in-out infinite}.device-card.alarmed:before{background:linear-gradient(90deg,var(--danger) 0%,transparent 60%);opacity:1}@keyframes alarm-flash{0%,to{box-shadow:0 0 #ef444400;border-color:#ef44448c}50%{box-shadow:0 0 24px #ef444499;border-color:#ef4444}}.live-feed{display:flex;flex-direction:column;gap:0;max-height:440px;overflow-y:auto}.feed-item{display:grid;grid-template-columns:100px 70px 1fr auto;align-items:center;gap:12px;padding:9px 16px;border-bottom:1px solid var(--border-dim);font-size:12px;transition:background var(--trans-fast);animation:feed-slide-in .3s ease-out}.feed-item:last-child{border-bottom:none}.feed-item:hover{background:#00d4ff06}@keyframes feed-slide-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.feed-time{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}.feed-action{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.05em;color:var(--text-secondary)}.feed-desc{color:var(--text-secondary);font-size:12px}.sev-info{color:var(--info)}.sev-warning{color:var(--warn)}.sev-critical{color:var(--danger);text-shadow:0 0 8px rgba(239,68,68,.4)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:overlay-in .15s ease-out}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-elevated);border:1px solid var(--border-muted);border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a;animation:modal-in .2s cubic-bezier(.34,1.56,.64,1)}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:18px 22px;border-bottom:1px solid var(--border-dim);display:flex;align-items:center;justify-content:space-between;position:relative}.modal-header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--accent),transparent);opacity:.3}.modal-body{padding:22px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:14px 22px;border-top:1px solid var(--border-dim);display:flex;justify-content:flex-end;gap:10px}.filter-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.search-input-wrap{position:relative;flex:1;min-width:200px}.search-input-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input-wrap .form-input{padding-left:36px}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px}.page-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:5px;border:1px solid var(--border-muted);background:transparent;color:var(--text-secondary);font-family:var(--font-mono);font-size:11px;cursor:pointer;transition:all var(--trans-fast)}.page-btn:hover{border-color:var(--accent);color:var(--accent)}.page-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);box-shadow:0 0 8px #f59e0b33}.week-grid{display:grid;grid-template-columns:60px repeat(7,1fr);gap:1px;background:var(--border-dim);border-radius:8px;overflow:hidden}.week-cell{background:var(--bg-card);padding:8px 6px;font-family:var(--font-mono);font-size:10px;text-align:center;min-height:40px;position:relative}.schedule-block{position:absolute;left:2px;right:2px;border-radius:3px;padding:2px 4px;font-size:9px;font-weight:600;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;transition:filter var(--trans-fast)}.schedule-block:hover{filter:brightness(1.2)}.schedule-block.high_alert{background:#ef444433;color:var(--danger);border-left:2px solid var(--danger)}.schedule-block.locked{background:#f59e0b33;color:var(--accent);border-left:2px solid var(--accent)}.schedule-block.patrol{background:#00d4ff26;color:var(--info);border-left:2px solid var(--info)}.schedule-block.disarmed{background:#47556940;color:var(--text-muted);border-left:2px solid var(--text-muted)}.alert-item{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-bottom:1px solid var(--border-dim);transition:background var(--trans-fast);border-left:3px solid transparent}.alert-item.critical{border-left-color:var(--danger);background:linear-gradient(90deg,rgba(239,68,68,.04) 0%,transparent 40%)}.alert-item.warning{border-left-color:var(--warn);background:linear-gradient(90deg,rgba(245,158,11,.04) 0%,transparent 40%)}.alert-item:hover{background:#ffffff05}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:var(--text-muted);text-align:center}.empty-state svg{opacity:.2}.empty-state h3{font-family:var(--font-display);font-size:20px;color:var(--text-secondary);letter-spacing:.06em}.empty-state p{font-size:13px;max-width:320px;color:var(--text-muted)}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:skeleton-shimmer 1.8s ease-in-out infinite;border-radius:4px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(245,158,11,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{min-height:100vh;background:var(--bg-void);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 50% at 50% 100%,rgba(245,158,11,.07) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 80% 20%,rgba(0,212,255,.04) 0%,transparent 60%),radial-gradient(ellipse 30% 30% at 20% 80%,rgba(239,68,68,.03) 0%,transparent 60%)}.login-card{background:#0a1628e6;border:1px solid var(--border-muted);border-radius:14px;padding:44px 38px;width:100%;max-width:400px;position:relative;box-shadow:0 32px 80px #0009,0 0 0 1px #ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);animation:login-rise .4s cubic-bezier(.34,1.56,.64,1)}.login-card:before{content:"";position:absolute;top:0;left:24px;right:24px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--cyan),transparent);opacity:.6}@keyframes login-rise{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-logo{font-family:var(--font-display);font-size:26px;letter-spacing:.12em;color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:6px;text-shadow:0 0 20px rgba(245,158,11,.3)}.login-tagline{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:30px}.topbar-logo{font-family:var(--font-display);font-size:17px;letter-spacing:.14em;color:var(--accent);display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer;text-shadow:0 0 16px rgba(245,158,11,.3);transition:text-shadow var(--trans-fast)}.topbar-logo:hover{text-shadow:0 0 24px rgba(245,158,11,.5)}.topbar-dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok),0 0 16px #22c55e66;animation:pulse-dot 2s ease-in-out infinite}.role-pill{padding:2px 8px;border-radius:4px;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;font-weight:600}.role-superadmin{background:#ef44441f;color:var(--danger);border:1px solid rgba(239,68,68,.2);text-shadow:0 0 8px rgba(239,68,68,.4)}.role-admin{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(245,158,11,.2)}.role-user{background:var(--info-dim);color:var(--info);border:1px solid rgba(0,212,255,.15)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-sm{font-size:12px}.text-xs{font-size:11px}.font-mono{font-family:var(--font-mono)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.text-danger{color:var(--danger)}.text-ok{color:var(--ok)}.text-cyan{color:var(--cyan)}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.w-full{width:100%}.page-enter{animation:page-in .2s ease-out}@keyframes page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.hud-corner{position:relative}.hud-corner:before,.hud-corner:after{content:"";position:absolute;width:12px;height:12px;border-color:var(--cyan);border-style:solid;opacity:.4}.hud-corner:before{top:0;left:0;border-width:1px 0 0 1px}.hud-corner:after{bottom:0;right:0;border-width:0 1px 1px 0}.divider{height:1px;background:var(--border-dim);margin:16px 0}.glow-text-amber{text-shadow:0 0 12px rgba(245,158,11,.5);color:var(--accent)}.glow-text-cyan{text-shadow:0 0 12px rgba(0,212,255,.5);color:var(--cyan)}.glow-text-ok{text-shadow:0 0 12px rgba(34,197,94,.5);color:var(--ok)}.glow-text-danger{text-shadow:0 0 12px rgba(239,68,68,.5);color:var(--danger)}.data-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-dim);font-size:13px}.data-row:last-child{border-bottom:none}.data-row .key{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.data-row .val{font-family:var(--font-mono);font-size:12px;color:var(--text-primary)}@media (max-width: 768px){.app-shell{grid-template-columns:1fr;grid-template-rows:52px auto 1fr}.sidebar{display:none}.main-content{padding:16px}.stat-grid{grid-template-columns:repeat(2,1fr)}}
