@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&display=swap";:root{--bg-base:#f0f2f5;--bg-surface:#fff;--bg-elevated:#fff;--bg-card:#f9fafb;--bg-hover:#f0f1f5;--border:#e2e4ea;--border-light:#d0d3dc;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--accent:#f97316;--accent-glow:#e53e3e40;--accent-dim:#e53e3e14;--green:#16a34a;--green-dim:#16a34a1a;--orange:#ea580c;--orange-dim:#ea580c1a;--red:#dc2626;--red-dim:#dc26261a;--blue:#2563eb;--blue-dim:#2563eb1a;--gray:#6b7280;--gray-dim:#6b72801a;--sidebar-width:256px;--radius:10px;--radius-sm:6px;--sidebar-bg:#141519;--sidebar-border:#ffffff14;--sidebar-hover:#ffffff0d;--sidebar-text-primary:#f1f5f9;--sidebar-text-secondary:#94a3b8;--sidebar-text-muted:#64748b;color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;font-family:Montserrat,system-ui,sans-serif;font-size:17px;line-height:1.55}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-base);color:var(--text-primary);margin:0}#root{width:100%;min-height:100vh;display:flex}h1,h2,h3,h4,h5{color:var(--text-primary);font-weight:600;line-height:1.3}p{margin:0}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select,textarea{outline:none;font-family:inherit;font-size:16px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);z-index:200;flex-direction:column;flex-shrink:0;height:100vh;transition:transform .3s;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;padding:20px 16px 18px}.sidebar-brand{align-items:center;gap:11px;display:flex}.sidebar-brand-icon{background:linear-gradient(135deg,#f97316,#e53e3e);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 2px 12px #e53e3e66}.sidebar-brand-text{flex-direction:column;min-width:0;display:flex}.sidebar-brand-name{color:var(--sidebar-text-primary);letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;font-size:22px;font-weight:900}.sidebar-brand-sub{color:var(--sidebar-text-muted);letter-spacing:.5px;text-transform:uppercase;font-size:13px;font-weight:600}.sidebar-nav{scrollbar-width:thin;scrollbar-color:var(--sidebar-border) transparent;flex:1;padding:8px 0 4px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--sidebar-border);border-radius:2px}.nav-section-label{color:var(--sidebar-text-muted);text-transform:uppercase;letter-spacing:1.2px;padding:14px 16px 5px;font-size:12px;font-weight:600;display:block}.nav-item{color:var(--sidebar-text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-left:3px solid #0000;border-radius:0;align-items:center;gap:10px;width:100%;padding:11px 16px;font-size:15px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:var(--sidebar-text-primary);background:var(--sidebar-hover)}.nav-item.active{color:#f97316;background:#f973161f;border-left-color:#f97316;font-weight:600}.nav-item-icon{opacity:.7;flex-shrink:0;width:18px;height:18px}.nav-item.active .nav-item-icon,.nav-item:hover .nav-item-icon{opacity:1}.room-group{margin-bottom:1px}.room-toggle{color:var(--sidebar-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;justify-content:space-between;align-items:center;padding:9px 16px;font-size:15px;font-weight:500;transition:background .15s,color .15s;display:flex}.room-toggle:hover{color:var(--sidebar-text-primary);background:var(--sidebar-hover)}.room-toggle-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.room-icon{opacity:.55;flex-shrink:0;width:16px;height:16px}.room-toggle-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.room-cam-count{color:var(--sidebar-text-muted);background:var(--sidebar-border);border-radius:10px;flex-shrink:0;padding:1px 7px;font-size:12px}.room-chevron{color:var(--sidebar-text-muted);flex-shrink:0;margin-left:6px;font-size:9px;transition:transform .22s}.room-chevron.open{transform:rotate(90deg)}.camera-list{max-height:0;transition:max-height .28s;overflow:hidden}.camera-list.open{max-height:600px}.camera-item{color:var(--sidebar-text-muted);cursor:pointer;border-left:3px solid #0000;align-items:center;gap:8px;padding:7px 16px 7px 34px;font-size:14px;font-weight:400;text-decoration:none;transition:background .15s,color .15s;display:flex}.camera-item:hover{color:var(--sidebar-text-primary);background:var(--sidebar-hover)}.camera-item.active{color:#f97316;background:#f973161a;border-left-color:#f97316;font-weight:600}.camera-status-dot{background:var(--sidebar-text-muted);border-radius:50%;flex-shrink:0;width:6px;height:6px;transition:background .2s}.camera-item.active .camera-status-dot{background:#f97316}.camera-status-dot.online{background:#22c55e;box-shadow:0 0 0 2px #22c55e33}.camera-status-dot.offline{background:#6b7280}.sidebar-loading{padding:8px 16px}.skeleton-line{background:var(--sidebar-hover);border-radius:5px;height:12px;margin-bottom:10px;animation:1.4s infinite skel-shimmer}.skeleton-line.short{width:55%}.skeleton-line.indent{width:65%;margin-left:18px}@keyframes skel-shimmer{0%,to{opacity:.45}50%{opacity:.9}}.sidebar-footer{border-top:1px solid var(--sidebar-border);flex-direction:column;flex-shrink:0;gap:6px;padding:14px 16px;display:flex}.sidebar-user-info{align-items:center;gap:10px;padding:4px 0;display:flex}.sidebar-user-info-btn{border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;width:100%;padding:7px 8px;transition:all .18s}.sidebar-user-info-btn:hover{background:var(--sidebar-hover);border-color:var(--sidebar-border)}.sidebar-user-avatar{color:#fff;background:#f97316;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.sidebar-user-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sidebar-user-name{color:var(--sidebar-text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:700;overflow:hidden}.sidebar-user-sub{color:var(--sidebar-text-muted);font-size:12px;font-weight:400}.btn-logout{border:1px solid var(--sidebar-border);border-radius:var(--radius-sm);width:100%;color:var(--sidebar-text-muted);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:8px;padding:9px 12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.btn-logout:hover{color:#e53e3e;background:#e53e3e1a;border-color:#e53e3e4d}@media (width<=768px){.sidebar{z-index:200;height:100vh;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.is-open{transform:translate(0);box-shadow:4px 0 24px #0006}}.dashboard-layout{background:var(--bg-base);width:100%;min-height:100vh;display:flex;overflow:hidden}.dashboard-main-wrapper{flex-direction:row;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden}.dashboard-center{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.dashboard-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px;height:70px;padding:16px;display:none}.camera-page-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px;display:flex}.camera-header-title{color:var(--text-primary);font-size:26px;font-weight:900}.camera-header-breadcrumb{color:var(--text-muted);margin-top:2px;font-size:15px}.camera-header-description{color:var(--text-muted);opacity:.8;max-width:480px;margin-top:5px;font-size:13px;line-height:1.5}.topbar-status-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:14px;font-weight:600;display:flex}.topbar-status-badge.online{color:#16a34a;background:#22c55e1f}.topbar-status-badge.offline{color:#6b7280;background:#6b72801f}.topbar-dot{background:currentColor;border-radius:50%;width:7px;height:7px}.topbar-dot.pulse{animation:2s infinite topbar-pulse}@keyframes topbar-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.dashboard-content-scroll{scrollbar-width:thin;scrollbar-color:var(--border-light) transparent;flex:1;padding:16px;overflow-y:auto}.dashboard-content-scroll::-webkit-scrollbar{width:5px}.dashboard-content-scroll::-webkit-scrollbar-track{background:0 0}.dashboard-content-scroll::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.video-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.video-grid.single{grid-template-columns:1fr}.video-grid.two{grid-template-columns:repeat(2,1fr)}.video-cell{border-radius:var(--radius);aspect-ratio:16/9;border:2px solid var(--border);background:#0a0a0a;transition:border-color .3s,box-shadow .3s;position:relative;overflow:hidden}.video-cell:hover{border-color:var(--border-light)}.video-cell.is-selected{border-color:#f97316;box-shadow:0 0 0 3px #f9731633}.video-cell.is-alarm{border-color:#ef4444;animation:1.2s ease-in-out infinite cell-alarm-pulse;box-shadow:0 0 0 3px #ef44444d}@keyframes cell-alarm-pulse{0%,to{box-shadow:0 0 0 3px #ef44444d}50%{box-shadow:0 0 0 8px #ef444414}}.video-cell img{object-fit:fill;width:100%;height:100%;display:block}.video-cell-placeholder{color:#555;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;height:100%;display:flex}.video-cell-placeholder .spinner{border:2px solid #333;border-top-color:#f97316;border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.video-cell-placeholder span{text-align:center;max-width:140px;font-size:13px}.video-cell-label{background:linear-gradient(#0000 0%,#000000bf 100%);align-items:center;gap:6px;padding:20px 10px 8px;display:flex;position:absolute;bottom:0;left:0;right:0}.video-cell-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:600;overflow:hidden}.video-cell-status{border-radius:50%;flex-shrink:0;width:7px;height:7px}.video-cell-status.online{background:#22c55e;box-shadow:0 0 4px #22c55ecc}.video-cell-status.offline{background:#6b7280}.video-cell-alarm-overlay{pointer-events:none;background:#ef44442e;justify-content:flex-end;align-items:flex-start;padding:8px;display:flex;position:absolute;inset:0}.video-cell-alarm-badge{color:#fff;letter-spacing:.5px;background:#ef4444;border-radius:4px;padding:4px 9px;font-size:12px;font-weight:700;animation:.8s step-start infinite cell-badge-blink}@keyframes cell-badge-blink{0%,to{opacity:1}50%{opacity:0}}.dashboard-empty{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:60px 20px;display:flex}.dashboard-empty svg{opacity:.3}.dashboard-empty p{max-width:260px;font-size:15px;line-height:1.7}.right-panel{background:var(--bg-surface);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:450px;min-width:400px;height:100vh;display:flex;overflow:hidden}.right-panel-scroll{scrollbar-width:thin;scrollbar-color:var(--border-light) transparent;flex:1;overflow-y:auto}.right-panel-scroll::-webkit-scrollbar{width:4px}.right-panel-scroll::-webkit-scrollbar-track{background:0 0}.right-panel-scroll::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}.rp-section{border-bottom:1px solid var(--border);padding:16px 18px}.rp-section:last-child{border-bottom:none}.rp-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.rp-section-title{text-transform:uppercase;letter-spacing:.9px;color:var(--text-primary);align-items:center;gap:6px;font-size:13px;font-weight:700;display:flex}.rp-section-badge{background:var(--bg-card);color:var(--text-muted);border-radius:10px;padding:2px 7px;font-size:12px;font-weight:600}.rp-section-badge.alert{color:#ef4444;background:#ef44441f}.sensor-row{flex-direction:column;gap:10px;display:flex}.sensor-bar-item{flex-direction:column;gap:4px;display:flex}.sensor-bar-header{justify-content:space-between;align-items:center;display:flex}.sensor-bar-label{color:var(--text-secondary);align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.sensor-bar-value{color:var(--text-primary);font-size:15px;font-weight:700}.sensor-bar-value.danger{color:#ef4444}.sensor-bar-value.warning{color:#f97316}.sensor-bar-track{background:var(--bg-card);border:1px solid var(--border);border-radius:3px;height:6px;overflow:hidden}.sensor-bar-fill{border-radius:3px;height:100%;transition:width .5s,background-color .4s}.sensor-bar-fill.safe{background:#22c55e}.sensor-bar-fill.warning{background:#f97316}.sensor-bar-fill.danger{background:#ef4444}.sensor-binary-row{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.sensor-binary-item{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);flex-direction:column;flex:1;align-items:center;gap:4px;min-width:80px;padding:9px 10px;transition:all .3s;display:flex}.sensor-binary-item.triggered{background:#ef44440f;border-color:#ef444466;animation:1.5s infinite pulse-border}.sensor-binary-icon{font-size:20px;line-height:1}.sensor-binary-label{color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:500}.sensor-binary-status{text-align:center;font-size:13px;font-weight:700}.sensor-binary-status.safe{color:#22c55e}.sensor-binary-status.danger{color:#ef4444}.sensor-binary-status.neutral{color:var(--text-muted)}.sensor-waiting{color:var(--text-muted);align-items:center;gap:8px;padding:8px 0;font-size:14px;display:flex}.sensor-waiting-dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.2s infinite skel-shimmer}.rp-alert-list{flex-direction:column;gap:8px;display:flex}.rp-alert-item{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);padding:11px 12px;transition:all .2s}.rp-alert-item.unresolved{background:#ef444408;border-left:3px solid #ef4444}.rp-alert-item.resolved{opacity:.72;border-left:3px solid #22c55e}.rp-alert-time{color:var(--text-muted);margin-bottom:3px;font-size:13px}.rp-alert-msg{color:var(--text-secondary);margin-bottom:4px;font-size:14px;line-height:1.5}.rp-alert-cam{color:var(--text-muted);align-items:center;gap:4px;margin-bottom:6px;font-size:13px;display:flex}.rp-alert-thumb{object-fit:cover;border-radius:4px;width:100%;height:80px;margin-bottom:6px;display:block}.btn-resolve-sm{color:#ef4444;cursor:pointer;background:#ef444414;border:1px solid #ef444433;border-radius:4px;justify-content:center;align-items:center;gap:5px;width:100%;padding:6px 10px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.btn-resolve-sm:hover:not(:disabled){background:#ef444429}.btn-resolve-sm:disabled{opacity:.5;cursor:not-allowed}.rp-resolved-tag{color:#16a34a;align-items:center;gap:4px;font-size:13px;font-weight:600;display:flex}.chart-wrapper{margin-top:4px}.chart-no-data{color:var(--text-muted);text-align:center;padding:16px 0;font-size:14px}.fire-banner{border-radius:var(--radius);color:#fca5a5;letter-spacing:.3px;background:linear-gradient(135deg,#7f1d1d,#991b1b);border:1px solid #ef4444;flex-direction:column;gap:8px;margin:0 0 14px;padding:14px 18px;font-size:16px;font-weight:700;animation:.85s ease-in-out infinite fire-flash;display:flex;box-shadow:0 0 24px #ef444459}.fire-banner-img{object-fit:cover;border-radius:6px;width:100%;max-height:160px;display:block}@keyframes fire-flash{0%,to{opacity:1}50%{opacity:.7}}@media (width<=1024px){.dashboard-main-wrapper{flex-direction:column;overflow:hidden auto}.dashboard-center{flex:none;height:auto;overflow:visible}.dashboard-topbar{align-items:center;display:flex}.topbar-status-badge{font-size:12px}.camera-header-title{font-size:20px}.dashboard-content-scroll{flex:none;padding:16px 16px 12px;overflow:visible}.video-grid,.video-grid.two{grid-template-columns:1fr}.right-panel{width:auto;min-width:unset;border:1px solid var(--border);border-radius:var(--radius);height:auto;margin:0 16px 24px;overflow:visible}.right-panel-scroll{overflow:visible}}.ovd-grid{grid-template-rows:auto auto;grid-template-columns:1fr 1fr;gap:4px;display:grid}.ovd-cell{border-radius:var(--radius);border:2px solid var(--border);cursor:grab;background:#0a0a0a;flex-direction:column;height:400px;transition:border-color .3s,box-shadow .3s;display:flex;overflow:hidden}.ovd-cell:active{cursor:grabbing}.ovd-cell:hover{border-color:var(--border-light)}.ovd-cell.is-alarm{border-color:#ef4444;animation:1s ease-in-out infinite ovd-alarm-pulse;box-shadow:0 0 0 3px #ef444459}@keyframes ovd-alarm-pulse{0%,to{box-shadow:0 0 0 3px #ef444459}50%{box-shadow:0 0 0 10px #ef444412}}.ovd-video-wrap{background:#0a0a0a;flex:1;min-height:0;position:relative;overflow:hidden}.ovd-video-img{object-fit:fill;width:100%;height:100%;display:block}.ovd-video-placeholder{color:#555;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;height:100%;min-height:180px;padding:20px;display:flex}.ovd-video-placeholder span{color:#666;text-align:center;font-size:13px}.ovd-spinner{border:2px solid #333;border-top-color:#f97316;border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.ovd-video-label{background:linear-gradient(#0000 0%,#000c 100%);align-items:center;gap:6px;padding:22px 10px 7px;display:flex;position:absolute;bottom:0;left:0;right:0}.ovd-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.ovd-status-dot.online{background:#22c55e;box-shadow:0 0 4px #22c55ecc}.ovd-status-dot.offline{background:#6b7280}.ovd-cam-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:700;overflow:hidden}.ovd-room-name{color:#ffffff8c;white-space:nowrap;flex-shrink:0;font-size:11px}.ovd-clear-btn{color:#fff;cursor:pointer;z-index:10;opacity:0;background:#0006;border:1px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:all .2s;display:flex;position:absolute;top:10px;right:10px}.ovd-cell:hover .ovd-clear-btn{opacity:1}.ovd-clear-btn:hover{background:#ef4444e6;border-color:#ef4444;transform:scale(1.1)}.ovd-alarm-overlay{pointer-events:none;background:#ef444438;justify-content:center;align-items:center;animation:.75s step-start infinite ovd-red-flash;display:flex;position:absolute;inset:0}@keyframes ovd-red-flash{0%,to{background:#ef444438}50%{background:#ef44440d}}.ovd-alarm-badge{color:#fff;letter-spacing:.8px;text-shadow:0 1px 4px #00000080;background:#ef4444;border-radius:6px;padding:8px 18px;font-size:15px;font-weight:800;animation:.75s step-start infinite ovd-badge-blink;box-shadow:0 4px 20px #ef444480}@keyframes ovd-badge-blink{0%,to{opacity:1}50%{opacity:0}}.ovd-sensor-bar{background:var(--bg-surface);border-top:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:5px;min-height:38px;padding:6px 10px;display:flex}.ovd-sensor-chip{white-space:nowrap;letter-spacing:.3px;border-radius:20px;padding:3px 8px;font-size:11px;font-weight:600}.ovd-sensor-chip.ok{color:#16a34a;background:#16a34a1a}.ovd-sensor-chip.warn{color:#ea580c;background:#ea580c1a}.ovd-sensor-chip.danger{color:#dc2626;background:#dc26261f}.ovd-empty-slot{background:var(--bg-card);cursor:default;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:28px 16px;display:flex}.ovd-empty-icon{color:var(--border-light);font-size:36px;font-weight:300;line-height:1}.ovd-empty-hint{color:var(--text-muted);text-align:center;font-size:13px}.ovd-camera-select{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-sm);width:100%;max-width:220px;color:var(--text-primary);cursor:pointer;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .2s}.ovd-camera-select:focus{border-color:var(--accent);outline:none}.ovd-camera-select option{background:var(--bg-surface)}@media (width<=1080px){.ovd-grid{grid-template-columns:1fr}.ovd-cell{height:300px}}.ah-unresolved-badge{color:#ef4444;letter-spacing:.2px;background:#ef44441f;border-radius:20px;padding:3px 10px;font-size:13px;font-weight:700}.ah-table th,.ah-table td{vertical-align:middle}.ah-row-unresolved td{background:#ef444408}.ah-row-unresolved td:first-child{border-left:3px solid #ef4444}.ah-td-time{white-space:nowrap}.ah-time-primary{color:var(--text-primary);font-size:15px;font-weight:600;display:block}.ah-time-secondary{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.ah-cam-cell{align-items:flex-start;gap:8px;padding-top:2px;display:flex}.ah-cam-name{color:var(--text-primary);font-size:15px;font-weight:600;line-height:1.3}.ah-room-name{color:var(--text-muted);margin-top:2px;font-size:12px}.ah-thumb{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:zoom-in;vertical-align:middle;width:80px;height:50px;transition:transform .2s,box-shadow .2s;display:inline-block}.ah-thumb:hover{transform:scale(1.08);box-shadow:0 4px 14px #0000002e}.ah-video-thumb-wrap{cursor:pointer;border-radius:var(--radius-sm);vertical-align:middle;display:inline-block;position:relative;overflow:hidden}.ah-video-thumb-wrap .ah-thumb{display:block}.ah-video-thumb-wrap:hover .ah-thumb{transform:scale(1.08);box-shadow:0 4px 14px #0000002e}.ah-play-icon{color:#fff;text-shadow:0 1px 6px #0009;pointer-events:none;justify-content:center;align-items:center;font-size:18px;transition:transform .18s;display:flex;position:absolute;inset:0}.ah-video-thumb-wrap:hover .ah-play-icon{transform:scale(1.15)}.ah-lightbox{z-index:9999;background:#000000d1;justify-content:center;align-items:center;animation:.18s ah-lb-in;display:flex;position:fixed;inset:0}@keyframes ah-lb-in{0%{opacity:0}to{opacity:1}}.ah-lightbox-img{border-radius:var(--radius);object-fit:contain;max-width:90vw;max-height:85vh;box-shadow:0 16px 60px #0009}.ah-lightbox-video{border-radius:var(--radius);background:#000;outline:none;max-width:90vw;max-height:85vh;box-shadow:0 16px 60px #0009}.ah-lightbox-close{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;transition:background .18s;display:flex;position:absolute;top:20px;right:24px}.ah-lightbox-close:hover{background:#ffffff38}.ah-status-badge{white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:13px;font-weight:700;display:inline-block}.ah-status-badge.resolved{background:var(--green);color:#fff}.ah-status-badge.unresolved{background:var(--red);color:#fff}.ah-resolve-btn{background:var(--red);color:#fff;border:1px solid var(--red);cursor:pointer;white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:7px 13px;font-size:13px;font-weight:700;transition:all .18s;display:inline-flex}.ah-resolve-btn:hover:not(:disabled){background:#ef44442e;transform:translateY(-1px)}.ah-resolve-btn:disabled{opacity:.55;cursor:not-allowed}.ah-done-tag{color:#16a34a;align-items:center;gap:4px;font-size:13px;font-weight:600;display:inline-flex}.ah-btn-spinner{opacity:.7;border:2px solid;border-top-color:#0000;border-radius:50%;width:13px;height:13px;animation:.7s linear infinite spin;display:inline-block}.ah-loading-state{flex-direction:column;gap:2px;padding:12px 0;display:flex}.ah-skeleton-row{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:14px;display:flex}.ah-skeleton-cell{background:var(--bg-card);border-radius:6px;flex-shrink:0;height:14px;animation:1.4s infinite skel-shimmer}.ah-skeleton-cell.wide{width:140px}.ah-skeleton-cell{width:120px}.ah-skeleton-cell.thumb{border-radius:4px;width:80px;height:46px}.ah-skeleton-cell.narrow{width:90px}.app-container{background:var(--bg-base);width:100%;height:100vh;display:flex;overflow:hidden}.main-area{background:var(--bg-base);flex:1;min-width:0;overflow-y:auto}.management-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);align-items:center;gap:16px;height:70px;padding:0 16px;display:none}.page-content{min-height:100%;padding:28px 32px}.page-header{border-bottom:1px solid var(--border);margin-bottom:28px;padding-bottom:20px}.page-title{color:var(--text-primary);align-items:center;gap:10px;font-size:25px;font-weight:700;display:flex}.page-description{color:var(--text-secondary);margin-top:6px;font-size:16px}.sensor-dashboard{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:24px;display:grid}.sensor-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);text-align:center;padding:20px 16px;transition:all .3s;position:relative;overflow:hidden}.sensor-card:before{content:"";background:var(--border-light);height:3px;transition:background .3s;position:absolute;top:0;left:0;right:0}.sensor-card h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-size:13px;font-weight:600}.sensor-card .value{font-size:26px;font-weight:700;display:block}.sensor-card.safe:before{background:var(--green)}.sensor-card.danger-card:before{background:var(--red)}.sensor-card.danger-card{background:#dc26260d;border-color:#dc262659;animation:1.5s infinite pulse-border}.text-safe{color:var(--green)}.text-warning{color:var(--orange)}.text-danger{color:var(--red)}.text-neutral{color:var(--text-secondary)}@keyframes pulse-border{0%{box-shadow:0 0 #dc262666}70%{box-shadow:0 0 0 10px #dc262600}to{box-shadow:0 0 #dc262600}}.alert-banner{color:#fca5a5;border-radius:var(--radius);text-align:center;letter-spacing:.5px;background:linear-gradient(135deg,#7f1d1d,#991b1b);border:1px solid #ef4444;margin-bottom:20px;padding:14px 20px;font-size:17px;font-weight:700;animation:.8s infinite fire-flash;box-shadow:0 0 24px #ef444466}.video-wrapper{border:2px solid var(--border-light);border-radius:var(--radius);aspect-ratio:4/3;background:#000;justify-content:center;align-items:center;height:60vh;display:flex;position:relative;overflow:hidden}.video-wrapper img{object-fit:fill;width:100%;height:100%;display:block}.video-placeholder{color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:20px;font-size:16px;display:flex}.video-placeholder .spinner{border:3px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.history-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;height:60vh;padding:16px;display:flex;overflow-y:auto}.history-panel h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border);margin-bottom:6px;padding-bottom:10px;font-size:16px;font-weight:600}.alert-item{background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);flex-shrink:0;padding:10px 12px}.alert-item-meta{flex-direction:column;gap:2px;margin-bottom:8px;display:flex}.alert-item-meta .time{color:var(--text-muted);font-size:14px;font-weight:500}.alert-item-meta .location{color:var(--text-secondary);font-size:14px}.alert-item img{border-radius:var(--radius-sm);width:100%;display:block}.empty-state{text-align:center;color:var(--text-muted);padding:30px 10px;font-size:15px}.management-grid{grid-template-columns:1fr 1fr;align-items:start;gap:24px;display:grid}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-header{border-bottom:1px solid var(--border);gap:8px;padding:18px 22px}.card-header h3{font-size:18px;font-weight:600}.card-body{padding:22px}.form-group{margin-bottom:18px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;margin-bottom:7px;font-size:14px;font-weight:600;display:block}.form-control{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);padding:11px 14px;transition:border-color .2s}.form-control:focus{border-color:var(--accent)}.form-control::placeholder{color:var(--text-muted)}select.form-control option{background:var(--bg-card)}.btn{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:11px 22px;font-size:16px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;border:none}.btn-primary:hover{box-shadow:0 4px 12px var(--accent-glow);background:#f97416c5;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-full{justify-content:center;width:100%}.data-table{border-collapse:collapse;width:100%;font-size:16px}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border);padding:11px 14px;font-size:13px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:13px 14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-hover);color:var(--text-primary)}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.badge{border-radius:20px;padding:3px 9px;font-size:15px;font-weight:800;display:inline-block}.badge-green{background:var(--green);color:#fff}.badge-red{background:var(--red);color:#fff}.badge-blue{background:var(--blue);color:#fff}.badge-yellow{background:var(--orange);color:#fff}.toast{background:var(--bg-elevated);border-radius:var(--radius);z-index:9999;align-items:center;gap:10px;max-width:400px;padding:14px 20px;font-size:16px;font-weight:500;animation:.3s toast-in;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 24px #0000001f}.toast.toast-success{border:1.5px solid var(--green)}.toast.toast-error{border:1.5px solid var(--red)}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login-page{background-image:url(../background.png);background-position:50%;background-size:cover;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex}.login-card{background-color:#fff;border-radius:16px;width:100%;max-width:420px;padding:40px 36px;box-shadow:0 8px 40px #00000014}.login-icon{justify-content:center;margin-bottom:16px;display:flex}.login-title{text-align:center;color:var(--text-primary);text-transform:uppercase;margin-bottom:4px;font-size:30px;font-weight:900}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:28px;font-size:16px}.login-error{background:var(--red-dim);color:var(--red);border-radius:var(--radius-sm);border:1px solid #dc262640;align-items:center;gap:8px;margin-bottom:12px;padding:11px 14px;font-size:15px;display:flex}.btn-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.dot-online{background:var(--green);box-shadow:0 0 0 3px var(--green-dim);animation:2s infinite pulse-online}.dot-offline{background:var(--gray)}@keyframes pulse-online{0%,to{box-shadow:0 0 0 3px var(--green-dim)}50%{box-shadow:0 0 0 6px #16a34a0d}}.alert-unresolved{border-left:3px solid var(--red);background:#dc26260a}.alert-resolved{border-left:3px solid var(--green);opacity:.8;background:#16a34a0a}.btn-resolve{width:100%;color:var(--red);border-radius:var(--radius-sm);cursor:pointer;background:#dc262614;border:1px solid #dc262640;justify-content:center;align-items:center;gap:6px;margin-top:8px;padding:8px 14px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.btn-resolve:hover:not(:disabled){background:#dc262626;transform:translateY(-1px)}.btn-resolve:disabled{opacity:.6;cursor:not-allowed}.resolved-badge{color:var(--green);align-items:center;gap:5px;margin-top:8px;font-size:14px;font-weight:600;display:flex}.tab-switch{background:var(--bg-card);border-radius:var(--radius-sm);gap:4px;width:100%;padding:3px;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex:1;padding:8px 12px;font-size:15px;font-weight:500;transition:all .2s}.tab-btn.active{background:var(--bg-surface);color:var(--text-primary);font-weight:600;box-shadow:0 1px 4px #00000014}.form-hint{background:var(--blue-dim);border-radius:var(--radius-sm);color:var(--blue);border:1px solid #2563eb33;align-items:flex-start;gap:8px;padding:11px 14px;font-size:14px;line-height:1.6;display:flex}.alert-border{animation:1.5s infinite pulse-border;box-shadow:0 0 20px #dc26264d;border-color:var(--red)!important}.table-actions{align-items:center;gap:6px;display:flex}.btn-action{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:20px;align-items:center;gap:4px;padding:5px 11px;font-size:15px;font-weight:800;transition:all .18s;display:inline-flex}.btn-action-edit{background:var(--orange);color:#fff}.btn-action-edit:hover{background:var(--orange-dim);color:var(--orange)}.btn-action-delete{background:var(--red);color:#fff}.btn-action-delete:hover{background:var(--red-dim);color:var(--red)}.row-editing td{background:#f973160f!important}.btn-cancel{color:var(--text-secondary);border:1px solid var(--border-light);background:0 0}.cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.action-btn-group{flex-direction:column;gap:8px;margin-top:4px;display:flex}.form-section-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:10px;margin:22px 0 16px;font-size:13px;font-weight:600;display:flex}.form-section-divider:before,.form-section-divider:after{content:"";background:var(--border);flex:1;height:1px}.form-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-control-readonly{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-muted);cursor:not-allowed;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:11px 14px;font-size:16px;display:flex}.profile-grid{grid-template-columns:290px 1fr;align-items:start;gap:24px;display:grid}.profile-info-card{position:sticky;top:24px}.profile-avatar{color:#fff;background:#f97316;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;font-size:30px;font-weight:800;display:flex}.profile-display-name{color:var(--text-primary);margin-bottom:4px;font-size:20px;font-weight:700}.profile-username{color:var(--text-secondary);margin-bottom:2px;font-size:15px}.profile-email{color:var(--text-muted);word-break:break-all;margin-bottom:20px;font-size:14px}.profile-meta-list{text-align:left;border-top:1px solid var(--border);flex-direction:column;gap:10px;margin-top:4px;padding-top:16px;display:flex}.profile-meta-item{justify-content:space-between;align-items:center;gap:8px;display:flex}.profile-meta-label{color:var(--text-muted);font-size:14px;font-weight:500}.hamburger-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--text-primary);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:none}.hamburger-btn:hover{background:var(--bg-hover)}.mobile-topbar-brand{flex-direction:column;justify-content:center;display:flex}.mobile-brand-name{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;padding-top:2px;font-size:20px;font-weight:900;line-height:1.1}.mobile-brand-sub{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.sidebar-overlay{z-index:199;background:#00000080;animation:.2s fade-in;display:none;position:fixed;inset:0}.sidebar-overlay.active{display:block}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media (width<=1024px){.page-content{padding:22px 24px}.page-title{font-size:22px}.management-grid,.profile-grid{grid-template-columns:1fr}}@media (width<=768px){.hamburger-btn,.management-topbar{display:flex}.page-content{padding:16px}.page-title{font-size:20px}.management-grid,.profile-grid{grid-template-columns:1fr}.profile-info-card{position:static}.form-row-2{grid-template-columns:1fr}.table-wrapper{-webkit-overflow-scrolling:touch;border-radius:var(--radius);overflow-x:auto}.data-table{min-width:560px}.toast{max-width:none;bottom:12px;left:12px;right:12px}.sensor-card .value{font-size:22px}}@keyframes toastSlideIn{0%{opacity:0;transform:translate(40px)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}
