:root{--bg:#07101d;--bg2:#0a1423;--panel:#101c2d;--panel2:#142238;--panel3:#182941;--line:#263953;--text:#edf4ff;--muted:#8fa2bc;--primary:#4c8dff;--primary2:#2d6de0;--normal:#27ae60;--caution:#f39c12;--warning:#e74c3c;--critical:#8e44ad;--inactive:#95a5a6;--shadow:0 16px 40px rgba(0,0,0,.28);--radius:12px}
html[data-theme="light"]{--bg:#eef3f8;--bg2:#f7f9fc;--panel:#fff;--panel2:#f7f9fc;--panel3:#edf2f8;--line:#d8e1ec;--text:#14243b;--muted:#697b91;--shadow:0 12px 30px rgba(36,56,82,.12)}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Pretendard,"Noto Sans KR",Inter,Arial,sans-serif;font-size:14px;overflow:hidden}button,input,select,textarea{font:inherit}.app-shell{display:flex;height:100vh}.sidebar{width:236px;background:linear-gradient(180deg,#0a1728,#08111f);border-right:1px solid var(--line);display:flex;flex-direction:column;transition:.22s;z-index:20}.sidebar.collapsed{width:74px}.brand{height:72px;padding:16px;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--line);cursor:pointer}.brand-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#66a3ff,#315dd9);display:grid;place-items:center;color:white;font-weight:900;box-shadow:0 8px 20px rgba(76,141,255,.3)}.brand-copy{display:flex;flex-direction:column;white-space:nowrap}.brand-copy strong{font-size:17px;letter-spacing:.2px}.brand-copy span{font-size:11px;color:#8fa2bc;margin-top:2px}.main-nav{padding:14px 10px;display:flex;flex-direction:column;gap:4px;flex:1}.nav-item{border:0;background:transparent;color:#a7b7cb;display:flex;align-items:center;gap:12px;width:100%;height:44px;border-radius:9px;padding:0 13px;cursor:pointer;text-align:left;white-space:nowrap;transition:.18s}.nav-item:hover{background:rgba(76,141,255,.09);color:#fff}.nav-item.active{background:linear-gradient(90deg,rgba(76,141,255,.23),rgba(76,141,255,.08));color:#fff;box-shadow:inset 3px 0 var(--primary)}.nav-icon{width:20px;font-size:18px;text-align:center}.nav-item em{font-style:normal;font-size:9px;margin-left:auto;padding:2px 5px;border-radius:4px;background:#263954;color:#9db4d1}.nav-divider{height:1px;background:var(--line);margin:10px}.sidebar-footer{padding:12px 10px;border-top:1px solid var(--line);display:flex;align-items:center;gap:6px}.edge-status{background:#0e1d30;border:1px solid #223853;border-radius:9px;min-height:42px;display:flex;align-items:center;gap:7px;padding:0 10px;flex:1;white-space:nowrap;overflow:hidden}.edge-status i,.system-health i{width:7px;height:7px;background:var(--normal);border-radius:50%;box-shadow:0 0 0 4px rgba(39,174,96,.13)}.edge-status span{font-size:11px;color:#c5d2e3}.edge-status b{font-size:10px;color:#71859f;margin-left:auto}.collapse-btn{width:34px;height:42px;border:1px solid #223853;background:#0e1d30;color:#9fb0c6;border-radius:9px;cursor:pointer;font-size:23px}.sidebar.collapsed .brand-copy,.sidebar.collapsed .nav-item span:not(.nav-icon),.sidebar.collapsed .nav-item em,.sidebar.collapsed .edge-status{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:0}.sidebar.collapsed .collapse-btn{transform:rotate(180deg);width:100%}.main-area{min-width:0;flex:1;background:var(--bg);display:flex;flex-direction:column}.topbar{height:72px;padding:0 22px;border-bottom:1px solid var(--line);background:var(--bg2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:12px}.topbar h1{font-size:19px;margin:0 0 3px}.topbar p{margin:0;color:var(--muted);font-size:11px}.topbar-right{display:flex;align-items:center;gap:13px}.system-health{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:8px 12px;color:var(--muted);font-size:11px}.theme-toggle{width:76px;height:32px;border:1px solid var(--line);background:var(--panel);border-radius:18px;color:var(--muted);display:flex;align-items:center;justify-content:space-around;cursor:pointer}.theme-toggle i{width:24px;height:24px;border-radius:50%;background:var(--primary);position:absolute;transform:translateX(17px);transition:.2s;box-shadow:0 3px 10px rgba(0,0,0,.3)}html[data-theme="light"] .theme-toggle i{transform:translateX(-17px)}.theme-toggle span{font-size:12px}.notification-btn{width:36px;height:36px;border:1px solid var(--line);background:var(--panel);color:var(--text);border-radius:9px;position:relative;cursor:pointer}.notification-btn b{position:absolute;right:-4px;top:-4px;background:var(--warning);color:#fff;border:2px solid var(--bg2);font-size:9px;border-radius:10px;min-width:17px;height:17px;display:grid;place-items:center}.user-menu{display:flex;align-items:center;gap:8px}.avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#355a8a,#6e8caf);display:grid;place-items:center;color:#fff;font-weight:700}.user-menu div:nth-child(2){display:flex;flex-direction:column}.user-menu strong{font-size:12px}.user-menu span{font-size:9px;color:var(--muted);margin-top:2px}.user-menu button{border:0;background:none;color:var(--muted)}.mobile-menu{display:none;background:none;border:0;color:var(--text);font-size:20px}.view-host{flex:1;min-height:0;overflow:auto;padding:16px 18px 22px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 3px 10px rgba(0,0,0,.05)}.panel-header{min-height:48px;padding:0 15px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line)}.panel-header h3{font-size:13px;margin:0}.panel-header p{color:var(--muted);font-size:10px;margin:3px 0 0}.panel-body{padding:15px}.btn{height:34px;padding:0 13px;border-radius:8px;border:1px solid var(--line);background:var(--panel2);color:var(--text);cursor:pointer;font-weight:650;font-size:11px}.btn:hover{filter:brightness(1.08)}.btn.primary{background:var(--primary2);border-color:#4e89ed;color:white}.btn.danger{background:rgba(231,76,60,.12);border-color:rgba(231,76,60,.35);color:#ff8d82}.btn.success{background:rgba(39,174,96,.14);border-color:rgba(39,174,96,.4);color:#61d993}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border-radius:20px;font-size:10px;font-weight:750}.badge.normal{color:#63dd92;background:rgba(39,174,96,.14)}.badge.caution{color:#ffc04d;background:rgba(243,156,18,.14)}.badge.warning{color:#ff8579;background:rgba(231,76,60,.15)}.badge.critical{color:#d990f1;background:rgba(142,68,173,.18);animation:pulse 1.6s infinite}.badge.inactive{color:#afbbc5;background:rgba(149,165,166,.14)}@keyframes pulse{50%{box-shadow:0 0 0 5px rgba(142,68,173,.08)}}
.dashboard-layout{height:100%;min-height:720px;display:grid;grid-template-columns:minmax(0,1fr) 338px;gap:14px}.monitor-column{min-width:0;display:flex;flex-direction:column;gap:12px}.scenario-bar{display:grid;grid-template-columns:minmax(180px,1.2fr) auto auto minmax(230px,1.4fr);gap:10px;align-items:center;padding:11px 12px}.scenario-select{height:42px;border:1px solid var(--line);background:var(--panel2);border-radius:9px;padding:0 12px;color:var(--text);min-width:0}.run-control{display:flex;align-items:center;gap:9px;border-left:1px solid var(--line);padding-left:12px}.run-button{width:42px;height:42px;border:0;border-radius:50%;background:rgba(39,174,96,.18);color:#62da92;font-size:18px;cursor:pointer}.run-copy strong{display:block;color:#58d48a;font-size:12px}.run-copy span{font-size:10px;color:var(--muted)}.scenario-metrics{display:flex;gap:6px}.metric-chip{padding:7px 9px;background:var(--panel2);border-radius:8px;border:1px solid var(--line);text-align:center}.metric-chip b{display:block;font-size:12px}.metric-chip span{font-size:9px;color:var(--muted)}.device-mini{display:flex;align-items:center;justify-content:flex-end;gap:7px;min-width:0}.device-mini .device-dot{width:34px;height:34px;border-radius:8px;background:var(--panel2);border:1px solid var(--line);display:grid;place-items:center;position:relative}.device-dot i{position:absolute;right:3px;top:3px;width:6px;height:6px;background:var(--normal);border-radius:50%}.camera-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;flex:1;min-height:0}.camera-card{position:relative;min-height:330px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#0b1119}.camera-scene{position:absolute;inset:0;background:linear-gradient(180deg,#17263a 0 44%,#253140 44% 48%,#17202c 48%);overflow:hidden}.camera-scene:before{content:"";position:absolute;left:0;right:0;bottom:0;height:52%;background:repeating-linear-gradient(90deg,transparent 0 70px,rgba(255,255,255,.035) 71px 73px),linear-gradient(150deg,transparent 0 45%,rgba(255,255,255,.05) 46% 48%,transparent 49%)}.building{position:absolute;background:#24354a;border-top:3px solid #425873;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03)}.building.one{width:22%;height:43%;left:3%;top:6%}.building.two{width:31%;height:35%;right:5%;top:14%}.building:after{content:"";position:absolute;inset:10px;background:repeating-linear-gradient(0deg,#87a4c4 0 3px,transparent 3px 13px);opacity:.25}.person{position:absolute;width:8px;height:18px;border-radius:4px 4px 3px 3px;background:#6cc4ff;box-shadow:0 0 0 1px rgba(255,255,255,.25),0 0 10px rgba(76,141,255,.3)}.person:before{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:#bfe5ff;top:-5px;left:1px}.person.warn{background:#ff9a8c}.person.warn:before{background:#ffd7d0}.bbox{position:absolute;border:1px solid #52a7ff;border-radius:2px}.bbox.warn{border-color:#ff6658}.heatmap{position:absolute;width:200px;height:120px;border-radius:50%;filter:blur(22px);background:radial-gradient(circle,rgba(231,76,60,.5),rgba(243,156,18,.25) 35%,rgba(76,141,255,.05) 70%);left:45%;top:51%;opacity:.78}.zone-poly{position:absolute;inset:45% 5% 7% 6%;border:2px dashed var(--caution);clip-path:polygon(6% 24%,81% 0,100% 81%,22% 100%);background:rgba(243,156,18,.05)}.camera-overlay-top,.camera-overlay-bottom{position:absolute;left:10px;right:10px;display:flex;align-items:flex-start;justify-content:space-between;z-index:3}.camera-overlay-top{top:10px}.camera-overlay-bottom{bottom:9px;align-items:flex-end}.camera-name{padding:6px 8px;border-radius:7px;background:rgba(6,12,20,.72);backdrop-filter:blur(8px);color:white}.camera-name strong{display:block;font-size:11px}.camera-name span{font-size:9px;color:#b9c6d8}.camera-stats{padding:6px 8px;background:rgba(6,12,20,.72);border-radius:7px;color:#d3deeb;font-size:9px;line-height:1.5}.density-big{position:absolute;top:11px;left:50%;transform:translateX(-50%);z-index:3;background:rgba(6,12,20,.68);border:1px solid rgba(255,255,255,.12);padding:7px 12px;border-radius:7px;color:#fff;text-align:center}.density-big b{font-size:18px}.density-big span{font-size:9px;color:#c0ccda}.overlay-tools{display:flex;gap:5px}.overlay-tools button{width:30px;height:28px;background:rgba(6,12,20,.72);border:1px solid rgba(255,255,255,.12);border-radius:6px;color:#dce7f5;cursor:pointer;font-size:10px}.overlay-tools button.active{border-color:#61a0ff;color:#61a0ff}.camera-strip{display:flex;gap:9px;overflow-x:auto;padding:9px}.camera-thumb{min-width:190px;height:86px;display:grid;grid-template-columns:92px 1fr;overflow:hidden;border:1px solid var(--line);background:var(--panel2);border-radius:9px;cursor:pointer}.thumb-scene{background:linear-gradient(160deg,#223349,#101722);position:relative}.thumb-scene:after{content:"";position:absolute;inset:20px 10px 10px;background:linear-gradient(140deg,transparent 49%,rgba(255,255,255,.14) 50% 52%,transparent 53%)}.thumb-info{padding:9px}.thumb-info strong{font-size:10px;display:block}.thumb-info span{font-size:9px;color:var(--muted)}.gauge{height:4px;background:#27374b;border-radius:4px;margin:9px 0 6px;overflow:hidden}.gauge i{display:block;height:100%;background:var(--caution);width:63%}.chat-panel{display:flex;flex-direction:column;min-height:0}.chat-tabs{height:48px;border-bottom:1px solid var(--line);display:flex;padding:0 12px}.chat-tabs button{border:0;background:none;color:var(--muted);padding:0 10px;cursor:pointer;font-weight:700;font-size:11px}.chat-tabs button.active{color:var(--primary);border-bottom:2px solid var(--primary)}.chat-body{padding:12px;overflow-y:auto;flex:1}.chat-day{text-align:center;font-size:9px;color:var(--muted);margin:4px 0 13px}.message{display:flex;gap:8px;margin-bottom:12px}.ai-icon{width:27px;height:27px;display:grid;place-items:center;border-radius:8px;background:linear-gradient(135deg,#3a7cdd,#704ac7);font-size:11px;color:#fff;flex-shrink:0}.message-card{background:var(--panel2);border:1px solid var(--line);border-radius:4px 10px 10px 10px;padding:10px;line-height:1.55;color:#c8d5e5;font-size:10px;max-width:100%}.message-card strong{color:var(--text);display:block;margin-bottom:3px}.message-card.alert{border-color:rgba(231,76,60,.38);background:rgba(231,76,60,.08)}.suggestion-actions{display:flex;gap:5px;margin-top:9px;flex-wrap:wrap}.suggestion-actions .btn{height:28px;font-size:9px;padding:0 9px}.quick-chips{padding:8px 10px;display:flex;gap:5px;overflow-x:auto;border-top:1px solid var(--line)}.quick-chips button{white-space:nowrap;border:1px solid var(--line);background:var(--panel2);color:var(--muted);border-radius:15px;padding:6px 9px;font-size:9px;cursor:pointer}.chat-input{padding:10px;border-top:1px solid var(--line);display:flex;gap:7px}.chat-input textarea{height:42px;resize:none;flex:1;border:1px solid var(--line);background:var(--panel2);border-radius:8px;padding:10px;color:var(--text);outline:none;font-size:10px}.chat-input button{width:42px;border:0;border-radius:8px;background:var(--primary2);color:#fff;cursor:pointer}
.split-view{display:grid;grid-template-columns:292px minmax(0,1fr);gap:13px;min-height:calc(100vh - 112px)}.left-list{display:flex;flex-direction:column;min-height:0}.search-row{padding:12px;display:flex;gap:7px}.input,.select,.textarea{width:100%;border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:8px;padding:9px 10px;outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary)}.list-items{padding:0 8px 10px;overflow:auto}.list-card{padding:12px;border:1px solid transparent;border-radius:9px;cursor:pointer;display:flex;gap:9px;align-items:center;margin-bottom:5px}.list-card:hover{background:var(--panel2)}.list-card.active{border-color:rgba(76,141,255,.45);background:rgba(76,141,255,.09)}.list-card .list-icon{width:34px;height:34px;border-radius:8px;background:var(--panel3);display:grid;place-items:center}.list-copy{min-width:0;flex:1}.list-copy strong{display:block;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-copy span{display:block;color:var(--muted);font-size:9px;margin-top:3px}.dot{width:7px;height:7px;border-radius:50%;display:inline-block}.dot.normal{background:var(--normal)}.dot.warning{background:var(--warning)}.detail-panel{min-width:0}.content-tabs{display:flex;gap:3px;padding:10px 14px 0;border-bottom:1px solid var(--line)}.content-tabs button{padding:10px 13px;border:0;background:none;color:var(--muted);cursor:pointer;font-size:11px}.content-tabs button.active{color:var(--primary);border-bottom:2px solid var(--primary)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-group label{display:block;font-size:10px;color:var(--muted);margin-bottom:6px}.form-group.full{grid-column:1/-1}.form-section{padding:16px;border-bottom:1px solid var(--line)}.form-section h4{margin:0 0 13px;font-size:12px}.form-actions{position:sticky;bottom:0;background:var(--panel);border-top:1px solid var(--line);padding:12px 16px;display:flex;justify-content:flex-end;gap:7px}.thresholds{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}.threshold-box{padding:12px;border:1px solid var(--line);border-radius:9px;background:var(--panel2)}.threshold-box strong{font-size:11px}.threshold-box input{width:100%;margin-top:9px}.video-preview{height:170px;border-radius:9px;background:linear-gradient(155deg,#26374d,#111a27);position:relative;overflow:hidden;border:1px solid var(--line)}.video-preview:after{content:"ZONE A";position:absolute;inset:28% 13% 12% 18%;border:2px dashed var(--caution);clip-path:polygon(5% 20%,85% 0,100% 80%,15% 100%);color:#ffc15a;padding:8px;font-size:9px}.schedule{display:grid;grid-template-columns:54px repeat(7,1fr);border:1px solid var(--line);border-radius:9px;overflow:hidden}.schedule div{min-height:31px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);font-size:9px;display:grid;place-items:center;color:var(--muted);position:relative}.schedule .head{background:var(--panel3);color:var(--text);font-weight:700}.schedule .block{background:rgba(76,141,255,.25);color:#90baff;font-weight:700}.table-wrap{overflow:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-size:9px;color:var(--muted);font-weight:600;background:var(--panel2);padding:10px;border-bottom:1px solid var(--line);white-space:nowrap}.data-table td{padding:11px 10px;border-bottom:1px solid var(--line);font-size:10px;white-space:nowrap}.data-table tr:hover td{background:rgba(76,141,255,.035)}.progress{width:100px;height:5px;background:var(--panel3);border-radius:5px;overflow:hidden}.progress i{display:block;height:100%;background:var(--primary);width:70%}.resource-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.stat-card{padding:14px}.stat-card label{font-size:9px;color:var(--muted)}.stat-card b{font-size:20px;display:block;margin:7px 0 4px}.stat-card span{font-size:9px;color:#6fd49b}.map-canvas{height:calc(100vh - 170px);position:relative;overflow:hidden;background:linear-gradient(35deg,var(--panel2),var(--panel));background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:34px 34px}.map-road{position:absolute;background:#2b3b50;box-shadow:inset 0 0 0 1px #3d4f66}.map-road.r1{width:120%;height:80px;transform:rotate(-12deg);left:-10%;top:45%}.map-road.r2{height:120%;width:65px;transform:rotate(8deg);left:52%;top:-10%}.map-node{position:absolute;width:45px;height:45px;border-radius:50%;background:#0f1c2d;border:3px solid var(--normal);display:grid;place-items:center;box-shadow:0 0 0 8px rgba(39,174,96,.11);cursor:pointer}.map-node.warn{border-color:var(--warning);box-shadow:0 0 0 8px rgba(231,76,60,.11)}.map-node b{font-size:10px}.report-grid{display:grid;grid-template-columns:2fr 1fr;gap:12px}.chart{height:220px;padding:20px 13px 12px;display:flex;align-items:flex-end;gap:8px;border-top:1px solid var(--line)}.bar{flex:1;background:linear-gradient(180deg,#4c8dff,#2856a1);border-radius:5px 5px 0 0;min-width:12px;position:relative}.bar span{position:absolute;bottom:-20px;width:100%;text-align:center;font-size:8px;color:var(--muted)}.donut{width:150px;height:150px;margin:22px auto;border-radius:50%;background:conic-gradient(var(--normal) 0 58%,var(--caution) 58% 78%,var(--warning) 78% 93%,var(--critical) 93%);position:relative}.donut:after{content:"92%\A 정상 운영";white-space:pre;position:absolute;inset:25px;border-radius:50%;background:var(--panel);display:grid;place-items:center;text-align:center;font-size:11px;font-weight:700}.right-drawer{position:fixed;right:0;top:0;width:380px;height:100vh;background:var(--panel);border-left:1px solid var(--line);z-index:60;transform:translateX(100%);transition:.22s;box-shadow:var(--shadow)}.right-drawer.open{transform:none}.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.42);z-index:50;opacity:0;pointer-events:none;transition:.2s}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer-head{height:72px;padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.drawer-head h3{margin:0;font-size:15px}.drawer-head p{margin:4px 0 0;color:var(--muted);font-size:10px}.drawer-head button{border:0;background:none;color:var(--muted);font-size:24px;cursor:pointer}.drawer-tabs{display:flex;border-bottom:1px solid var(--line);padding:0 14px}.drawer-tabs button{height:43px;border:0;background:none;color:var(--muted);font-size:10px}.drawer-tabs button.active{color:var(--primary);border-bottom:2px solid var(--primary)}.alert-list{padding:12px}.alert-item{display:flex;gap:10px;padding:12px;border-bottom:1px solid var(--line)}.alert-symbol{width:30px;height:30px;border-radius:8px;background:rgba(231,76,60,.12);color:#ff8177;display:grid;place-items:center}.alert-item strong{display:block;font-size:10px}.alert-item p{font-size:9px;color:var(--muted);line-height:1.5;margin:4px 0}.alert-item time{font-size:8px;color:#607289}.toast-stack{position:fixed;right:18px;bottom:18px;z-index:100;display:flex;flex-direction:column;gap:8px}.toast{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:9px;padding:11px 14px;box-shadow:var(--shadow);font-size:10px;animation:slideIn .2s}@keyframes slideIn{from{transform:translateX(20px);opacity:0}}
@media(max-width:1180px){.dashboard-layout{grid-template-columns:1fr}.chat-panel{min-height:420px}.scenario-bar{grid-template-columns:1fr auto auto}.device-mini{display:none}.resource-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){body{overflow:auto}.app-shell{min-height:100vh;height:auto}.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%)}.sidebar.mobile-open{transform:none}.main-area{min-height:100vh}.mobile-menu{display:block}.system-health,.user-menu div:nth-child(2){display:none}.topbar{padding:0 12px}.view-host{padding:10px}.split-view{grid-template-columns:1fr}.camera-grid{grid-template-columns:1fr}.scenario-bar{grid-template-columns:1fr 1fr}.scenario-metrics{display:none}.form-grid,.thresholds,.report-grid{grid-template-columns:1fr}.right-drawer{width:min(100%,380px)}}
/* v2 requirements */
.dashboard-page{display:flex;flex-direction:column;gap:10px;height:100%}.dashboard-subnav{margin:0}.device-command-panel{padding:10px 12px}.panel-header.compact{min-height:auto;padding:0 0 8px}.device-command-grid{display:grid;grid-template-columns:minmax(230px,38%) 1fr;gap:12px}.device-choice-list{display:flex;gap:7px;overflow-x:auto}.device-choice{min-width:150px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);border-radius:8px;padding:9px;display:grid;grid-template-columns:24px 1fr 8px;align-items:center;text-align:left}.device-choice.active{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}.device-output{display:grid;grid-template-columns:90px 1fr;gap:7px;align-items:center;font-size:10px}.device-output label{color:var(--muted)}.output-message,.device-output code{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:7px}.camera-monitor-scroll{min-height:0;overflow-y:auto;padding-right:4px}.camera-grid-six{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:minmax(210px,1fr)}.camera-grid-six .camera-card{min-height:210px}.cctv-control-area{padding:10px 12px}.cctv-list-row{display:flex;gap:7px;overflow-x:auto;padding-bottom:3px}.cctv-list-chip{white-space:nowrap;border:1px solid var(--border);background:var(--panel-2);border-radius:7px;padding:7px 9px;font-size:9px}.cctv-list-chip b{color:var(--primary);margin-right:7px}.ops-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:12px;height:100%}.ops-scenarios{display:flex;flex-direction:column;min-height:0}.ops-actions{margin-top:auto;padding:12px;display:flex;gap:8px}.timetable-panel{min-width:0}.timetable-scroll{overflow:auto;max-height:calc(100vh - 245px)}.schedule-hourly{grid-template-columns:65px repeat(7,minmax(95px,1fr));min-width:780px}.schedule-cell{border:1px solid var(--border);background:transparent;color:var(--muted);min-height:28px;font-size:8px}.schedule-cell.block{color:#fff}.schedule-cell.workday{background:rgba(76,141,255,.55)}.schedule-cell.weekend{background:rgba(243,156,18,.55)}.schedule-cell.selected{outline:2px solid var(--primary);outline-offset:-2px;background:rgba(76,141,255,.35)}.schedule-legend{display:flex;gap:18px;padding:0 14px 10px;font-size:9px;color:var(--muted)}.legend{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:5px}.legend.workday{background:#4c8dff}.legend.weekend{background:#f39c12}.scenario-manage{display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;height:100%}.scenario-resource-panel{padding:12px;display:grid;gap:10px}.resource-strip-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:7px}.resource-strip-head h4{margin:0}.resource-strip-head span{font-size:8px;color:var(--muted)}.resource-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.resource-card{min-width:170px;display:grid;grid-template-columns:24px 1fr;gap:2px 7px;text-align:left;border:1px solid var(--border);background:var(--panel-2);color:var(--text);border-radius:8px;padding:9px}.resource-card.selected{border-color:var(--primary)}.resource-card small,.resource-card em{grid-column:2;font-size:8px;color:var(--muted)}.resource-card em{color:var(--primary);font-style:normal}.mindmap-editor{height:330px;position:relative;border:1px dashed var(--border);border-radius:10px;background:radial-gradient(circle at 50% 50%,rgba(76,141,255,.1),transparent 38%)}.mind-node{position:absolute;width:150px;padding:9px;border:1px solid var(--border);border-radius:8px;background:var(--panel);box-shadow:var(--shadow);z-index:2}.mind-node span,.mind-node small{display:block;font-size:8px;color:var(--muted)}.mind-node b{display:block;font-size:10px;margin:3px 0}.mind-node.main{left:50%;top:50%;transform:translate(-50%,-50%);border-color:var(--warning)}.mind-node.n1{left:7%;top:12%}.mind-node.n2{left:7%;bottom:12%}.mind-node.n3{right:7%;top:8%}.mind-node.n4{right:7%;top:40%}.mind-node.n5{right:7%;bottom:7%}.mindmap-line{position:absolute;height:1px;background:var(--primary);opacity:.45;left:25%;right:25%;top:50%}.applied-device-list{display:grid;gap:7px}.applied-device-list>div{display:grid;grid-template-columns:12px 1fr 150px auto;align-items:center;gap:8px;border:1px solid var(--border);border-radius:7px;padding:8px}.stream-status{display:flex;align-items:center;gap:8px}.stream-status>i{width:10px;height:10px;border-radius:50%;background:var(--normal);box-shadow:0 0 8px var(--normal)}.stream-status div{display:flex;flex-direction:column}.stream-status span{font-size:8px;color:var(--muted)}.enhanced-preview{position:relative;min-height:330px;overflow:hidden}.preview-overlays{position:absolute;right:10px;bottom:10px;display:flex;gap:5px;z-index:8}.preview-overlays button{border:1px solid var(--border);background:var(--panel);color:var(--muted);border-radius:5px;padding:5px 8px;font-size:8px}.preview-overlays button.active{background:var(--primary);color:#fff}.hidden{display:none!important}.hide-track .bbox{display:none}.hide-direction:after{display:none}.json-editor{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;line-height:1.55}.json-help{font-size:9px;color:var(--muted);margin:7px 0}.inline-actions{display:flex;gap:8px;margin-top:10px}.section-title-row{display:flex;justify-content:space-between;align-items:start;gap:12px}.section-title-row p{font-size:9px;color:var(--muted);margin:3px 0 0}
@media(max-width:1100px){.ops-layout{grid-template-columns:1fr}.ops-scenarios{max-height:300px}.camera-grid-six{grid-template-columns:1fr}.device-command-grid{grid-template-columns:1fr}.mindmap-editor{overflow:auto}.mind-node{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;transform:none!important;margin:8px}.mindmap-line{display:none}}
/* v3 revision */
.dashboard-page{height:100%;min-height:0}.dashboard-layout{height:calc(100% - 42px);min-height:0;overflow:hidden}.dashboard-center-scroll{overflow-y:auto;min-height:0;padding-right:4px}.dashboard-layout>.chat-panel{height:100%;position:sticky;top:0;overflow:hidden}.device-command-grid.dropdown-mode{grid-template-columns:minmax(230px,32%) 1fr}.cctv-add-control{display:flex;align-items:center;gap:8px}.cctv-add-control .select{min-width:260px}.cctv-live-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.cctv-live-grid .camera-card{min-height:210px}.cctv-live-grid .density-big b{font-size:15px}.cctv-live-grid .camera-name strong{font-size:10px}.cctv-control-area{margin-bottom:2px}
.scenario-manage-v3{display:grid;grid-template-columns:450px minmax(0,1fr);grid-template-rows:auto minmax(0,1fr);align-content:start;gap:12px;height:100%;min-height:0}.scenario-resource-list{display:flex;flex-direction:column;min-height:0;overflow:hidden}.resource-switch{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--line)}.resource-switch button{height:48px;border:0;background:transparent;color:var(--muted);font-size:11px;font-weight:700}.resource-switch button.active{color:var(--primary);box-shadow:inset 0 -2px var(--primary)}.resource-switch span{display:inline-grid;place-items:center;min-width:20px;height:18px;padding:0 5px;margin-left:4px;border-radius:10px;background:var(--panel2);font-size:9px}.resource-list-body{padding:9px;overflow-y:auto;display:flex;flex-direction:column;gap:7px}.resource-list-item{display:grid;grid-template-columns:minmax(0,1fr) 118px 74px;gap:8px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:9px;background:var(--panel2);color:var(--text);text-align:left;cursor:pointer}.resource-list-item.selected{border-color:var(--primary);box-shadow:inset 3px 0 var(--primary)}.resource-list-icon{width:28px;height:28px;border-radius:7px;background:rgba(76,141,255,.12);display:grid;place-items:center;color:var(--primary)}.resource-list-item b{display:block;font-size:10px}.resource-list-item small{display:block;color:var(--muted);font-size:8px;margin-top:3px}.resource-list-item em{font-style:normal;color:var(--primary);font-size:8px;white-space:nowrap}.scenario-device-row{grid-template-columns:minmax(0,1fr) 86px}.scenario-detail{min-width:0;overflow:auto}.mindmap-editor{height:420px;overflow:hidden;position:relative}.mindmap-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.mindmap-svg path{fill:none;stroke:var(--primary);stroke-width:2;opacity:.75}.mindmap-svg circle{fill:var(--primary)}.mind-node{transform:translate(-50%,-50%);cursor:move;user-select:none}.mind-node.main{left:50%;top:50%}.node-port{position:absolute;top:50%;width:12px;height:12px;border-radius:50%;background:var(--panel);border:2px solid var(--primary);transform:translateY(-50%);cursor:crosshair}.node-port.in{left:-7px}.node-port.out{right:-7px}.mindmap-hint{position:absolute;left:10px;bottom:8px;font-size:8px;color:var(--muted);background:var(--panel);border:1px solid var(--line);padding:5px 7px;border-radius:6px;z-index:3}.empty-state{padding:18px;text-align:center;color:var(--muted);font-size:10px;border:1px dashed var(--line);border-radius:8px}
.vlm-settings{padding:4px 0 12px}.model-picker{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.model-result-list{display:grid;gap:7px;margin-top:10px}.model-result{display:flex;align-items:center;justify-content:space-between;text-align:left;border:1px solid var(--line);background:var(--panel2);color:var(--text);padding:10px;border-radius:8px;cursor:pointer}.model-result.selected{border-color:var(--primary)}.model-result b{font-size:10px}.model-result span{font-size:8px;color:var(--muted)}
@media(max-width:1280px){.cctv-live-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:1100px){.dashboard-layout{height:auto;overflow:visible}.dashboard-center-scroll{overflow:visible}.dashboard-layout>.chat-panel{position:relative;height:420px}.scenario-manage-v3{grid-template-columns:1fr;height:auto}.scenario-resource-list{max-height:360px}.mind-node{transform:none}.cctv-live-grid{grid-template-columns:1fr}.cctv-add-control{flex-wrap:wrap}.cctv-add-control .select{min-width:180px}}

/* v4 통합관제 스크롤 및 CCTV 관제영역 */
.view-host:has(.dashboard-page){overflow:hidden}
.dashboard-page{overflow:hidden}
.dashboard-layout{grid-template-columns:minmax(0,1fr) 338px;gap:14px;overflow:hidden}
.dashboard-center-scroll{overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding-right:8px}
.dashboard-scenario-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:10px}.dashboard-camera-card{border:1px solid var(--line);border-radius:12px;background:var(--panel);overflow:hidden;min-width:0}.dashboard-camera-card.management{border-color:#57a4ff;box-shadow:0 0 0 1px rgba(76,141,255,.42),0 0 22px rgba(76,141,255,.12)}.dashboard-camera-card.linked{border-color:rgba(137,162,195,.35)}.dashboard-camera-video{position:relative;aspect-ratio:16/9;background:#050a11;overflow:hidden}.dashboard-stream-image{display:block;width:100%;height:100%;object-fit:cover;background:#050a11}.dashboard-stream-placeholder{position:absolute;inset:0;display:grid;place-items:center;color:#91a5bd;font-size:11px;background:linear-gradient(135deg,#08111d,#101f32)}.dashboard-video-title{position:absolute;left:9px;top:9px;z-index:10;max-width:58%;padding:6px 8px;border-radius:7px;background:rgba(5,13,23,.76);backdrop-filter:blur(8px)}.dashboard-video-title strong{display:block;font-size:10px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-video-title span{display:block;margin-top:2px;font-size:8px;color:#b8c7d8}.dashboard-camera-video>.badge{position:absolute;right:9px;top:9px;z-index:10}.dashboard-live-preview .preview-status{left:9px;top:52px;max-width:min(350px,calc(100% - 230px));padding:7px 9px}.dashboard-live-preview .preview-model-badge{right:9px;top:44px;max-width:210px;padding:7px 9px;font-size:9px}.dashboard-preview-switch{position:absolute;right:12px;bottom:52px;z-index:11}.dashboard-live-preview .preview-controls{right:12px;bottom:12px;max-width:calc(100% - 24px)}.dashboard-live-preview .switch-pill span{height:29px;padding:0 9px;font-size:9px}.dashboard-risk-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;padding:9px;border-top:1px solid var(--line);background:rgba(10,24,41,.72)}.dashboard-risk-summary div{min-width:0;border:1px solid rgba(255,255,255,.08);border-radius:7px;padding:7px;background:rgba(255,255,255,.025)}.dashboard-risk-summary span{display:block;font-size:8px;color:var(--muted);margin-bottom:3px}.dashboard-risk-summary b{display:block;font-size:12px;color:#eef5ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-risk-summary b.caution{color:#ffc04d}.dashboard-risk-summary b.warning{color:#ff8579}.dashboard-risk-summary b.critical{color:#d990f1}.dashboard-risk-summary small{font-size:8px;color:var(--muted);margin-left:2px}.dashboard-risk-summary p{grid-column:1/-1;margin:0;border:1px solid rgba(255,255,255,.08);border-radius:7px;padding:7px;color:#cbd8e8;font-size:9px;line-height:1.45;background:rgba(255,255,255,.025)}.dashboard-risk-summary p strong{display:inline-block;margin-right:6px;color:#fff}.dashboard-risk-summary p em{display:block;margin-top:4px;color:#88a0bd;font-style:normal}.dashboard-cctv-toolbar{display:flex;gap:7px;align-items:center}.dashboard-cctv-toolbar .select{width:220px;height:34px}.dashboard-control-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));padding:10px;gap:10px}.dashboard-control-camera{position:relative;border:1px solid var(--line);border-radius:10px;background:var(--panel2);overflow:hidden;cursor:grab}.dashboard-control-camera.dragging{opacity:.55}.dashboard-control-camera strong{display:block;padding:8px 10px;font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-control-video{position:relative;aspect-ratio:16/9;background:#050a11;overflow:hidden}.remove-dashboard-cctv{position:absolute;right:7px;top:7px;z-index:4;width:24px;height:24px;border:0;border-radius:6px;background:rgba(231,76,60,.8);color:#fff;cursor:pointer;font-size:15px;line-height:1}
.camera-monitor-scroll{overflow:visible;min-height:auto;padding-right:0}
.dashboard-layout>.chat-panel{position:relative;top:auto;overflow:hidden;min-width:0}
.dashboard-center-scroll::-webkit-scrollbar{width:10px}
.dashboard-center-scroll::-webkit-scrollbar-track{background:transparent}
.dashboard-center-scroll::-webkit-scrollbar-thumb{background:#465c77;border:2px solid var(--bg);border-radius:10px}
.dashboard-center-scroll::-webkit-scrollbar-thumb:hover{background:#5b7390}

.cctv-live-grid{align-items:start}
.control-camera-card{min-height:205px;cursor:zoom-in;transition:transform .16s,border-color .16s,box-shadow .16s}
.control-camera-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 10px 28px rgba(0,0,0,.22)}
.control-camera-title{position:absolute;left:9px;top:9px;z-index:5;background:rgba(5,13,23,.86);border:1px solid rgba(255,255,255,.08);border-radius:7px;padding:7px 9px;max-width:calc(100% - 52px)}
.control-camera-title strong,.control-camera-title span{display:block}
.control-camera-title strong{font-size:10px;color:#fff}
.control-camera-title span{font-size:8px;color:#9fb0c6;margin-top:2px}
.control-camera-remove{position:absolute;right:9px;top:9px;z-index:8;width:28px;height:28px;border-radius:7px;border:1px solid rgba(231,76,60,.45);background:rgba(9,17,28,.88);color:#ff8d82;font-size:20px;line-height:1;cursor:pointer}
.control-camera-remove:hover{background:var(--warning);color:#fff}
.control-camera-expand{position:absolute;left:50%;bottom:10px;z-index:5;transform:translateX(-50%) translateY(6px);opacity:0;background:rgba(5,13,23,.82);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:5px 10px;color:#dbe8f8;font-size:9px;transition:.16s;pointer-events:none}
.control-camera-card:hover .control-camera-expand{opacity:1;transform:translateX(-50%) translateY(0)}
.empty-control-cctv{grid-column:1/-1;min-height:150px;border:1px dashed var(--line);border-radius:10px;display:grid;place-items:center;color:var(--muted);font-size:11px}

.camera-modal{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:28px}
.camera-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.74);backdrop-filter:blur(4px)}
.camera-modal-dialog{position:relative;width:min(1180px,94vw);height:min(760px,88vh);background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 30px 90px rgba(0,0,0,.55);overflow:hidden;display:flex;flex-direction:column}
.camera-modal-head{height:58px;flex:0 0 auto;padding:0 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line)}
.camera-modal-head div{display:flex;flex-direction:column}.camera-modal-head strong{font-size:15px}.camera-modal-head span{font-size:10px;color:var(--muted);margin-top:3px}.camera-modal-head button{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:var(--panel2);color:var(--text);font-size:22px;cursor:pointer}
.camera-modal-view{position:relative;flex:1;min-height:0;overflow:hidden;background:#080d14}
.camera-modal-view .camera-scene{inset:0}
.camera-modal-view .camera-overlay-top,.camera-modal-view .camera-overlay-bottom{z-index:6}
.camera-modal-view .density-big{position:absolute;left:16px;top:16px}
.camera-modal-view>.camera-overlay-top{left:0;right:0;top:0}
.camera-modal-view>.camera-overlay-bottom{left:16px;right:16px;bottom:16px}

@media(max-width:1100px){.view-host:has(.dashboard-page){overflow:auto}.dashboard-page{overflow:visible}.dashboard-center-scroll{overflow:visible;padding-right:0}.camera-modal{padding:10px}.camera-modal-dialog{width:96vw;height:80vh}}

/* v5: scenario CCTV order + VLM/LLM analysis */
.scenario-camera-object{position:relative;display:flex;flex-direction:column;min-width:0;border:1px solid var(--line);border-radius:11px;background:var(--panel);overflow:hidden}
.scenario-camera-object>.camera-card{border:0;border-radius:0;min-height:210px;flex:0 0 210px}
.scenario-camera-order{height:30px;display:flex;align-items:center;justify-content:space-between;padding:0 10px;background:var(--panel2);border-bottom:1px solid var(--line);font-size:9px;color:var(--muted)}
.scenario-camera-order b{display:grid;place-items:center;width:19px;height:19px;border-radius:50%;background:var(--primary2);color:#fff;font-size:9px}
.scenario-camera-order span:first-child{color:var(--primary);font-weight:700}
.vlm-analysis-panel{border-top:1px solid var(--line);background:rgba(5,14,25,.72);padding:8px 10px 9px;min-height:88px}
.vlm-analysis-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:5px}
.vlm-analysis-head strong{font-size:9px;color:#8eb8ff}
.vlm-analysis-head span{font-size:8px;color:var(--muted);white-space:nowrap}
.vlm-analysis-scroll{height:47px;overflow-y:auto;padding-right:6px;font-size:9px;line-height:1.55;color:#c7d4e4;scrollbar-width:thin;scrollbar-color:var(--primary) transparent}
.vlm-analysis-scroll::-webkit-scrollbar{width:5px}.vlm-analysis-scroll::-webkit-scrollbar-thumb{background:var(--primary);border-radius:5px}.vlm-analysis-scroll::-webkit-scrollbar-track{background:transparent}
.camera-grid-six{grid-auto-rows:auto!important;align-items:start}
@media(max-width:1100px){.scenario-camera-object>.camera-card{flex-basis:230px}}

/* v6: CCTV management preview, overlay switches, GPS, polygon zone editor */
.cctv-detail .content-tabs{padding-top:0}
.preview-label{display:block;font-size:10px;color:var(--muted);margin-bottom:9px;font-weight:700}
.cctv-preview-frame{position:relative;height:360px;border:1px solid var(--line);border-radius:10px;background:#0b1119;overflow:hidden}
.cctv-preview-frame .camera-scene{position:absolute;inset:0}
.stream-preview-image{position:absolute;inset:0;z-index:1;width:100%;height:100%;object-fit:cover;background:#050a11}
.live-preview-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;pointer-events:none}
.preview-background-canvas{z-index:1;background:#050a11}
.live-overlay-canvas{z-index:4}
.preview-image{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#050a11}
.preview-status{position:absolute;left:12px;top:12px;z-index:10;display:grid;grid-template-columns:10px minmax(0,1fr);gap:2px 8px;align-items:center;max-width:min(420px,calc(100% - 24px));padding:8px 10px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:rgba(5,13,23,.78);backdrop-filter:blur(8px)}
.preview-status i{grid-row:1/3;width:10px;height:10px;border-radius:50%;background:var(--inactive);box-shadow:0 0 10px rgba(149,165,166,.5)}
.preview-status.ok i{background:var(--normal);box-shadow:0 0 12px var(--normal)}
.preview-status.error i{background:var(--warning);box-shadow:0 0 12px var(--warning)}
.preview-status strong{font-size:11px;color:#fff}.preview-status span{font-size:9px;color:#aebdd0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.preview-model-badge{position:absolute;right:12px;top:12px;z-index:10;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:rgba(5,13,23,.78);color:#dbe8f8;padding:8px 10px;font-size:10px;font-weight:800}
.overlay-switches{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-top:10px}
.preview-controls{position:absolute;right:12px;bottom:12px;z-index:10;margin-top:0}
.switch-pill{display:inline-flex;align-items:center;cursor:pointer;user-select:none}
.switch-pill input{position:absolute;opacity:0;pointer-events:none}
.switch-pill span{display:inline-flex;align-items:center;justify-content:center;height:31px;padding:0 12px;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:rgba(5,13,23,.82);color:#c3cfdd;font-size:10px;font-weight:800;backdrop-filter:blur(8px)}
.switch-pill input:checked+span{background:var(--primary);border-color:#6da3ff;color:#fff}
.switch-pill.mini span{height:28px;min-width:66px;padding:0 8px;font-size:9px}.header-switch span{min-width:94px}

/* v9: field device API URL and model registry controls */
.chat-model-setting{padding:10px;border-bottom:1px solid var(--line);display:grid;gap:6px}
.chat-model-setting label{font-size:9px;color:var(--muted);font-weight:700}
.model-toolbar{display:grid;grid-template-columns:minmax(220px,1fr) auto auto;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line)}
.compact-model-form{padding-top:12px;padding-bottom:12px}
.toggle-switch{min-width:52px;height:28px;border:1px solid var(--line);border-radius:16px;background:var(--panel2);color:var(--muted);font-size:9px;font-weight:850;cursor:pointer}
.toggle-switch.on{background:rgba(39,174,96,.17);border-color:rgba(39,174,96,.45);color:#69de99}
.agent-model-groups{display:grid;gap:10px;padding:14px 16px}
.agent-provider{border:1px solid var(--line);border-radius:9px;overflow:hidden;background:var(--panel2)}
.agent-provider h4{margin:0;padding:10px 12px;border-bottom:1px solid var(--line);font-size:11px;text-transform:lowercase;color:var(--primary)}
.agent-model-item{width:100%;min-height:42px;border:0;border-bottom:1px solid var(--line);background:transparent;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;text-align:left;cursor:pointer}
.agent-model-item:last-child{border-bottom:0}
.agent-model-item.active{background:rgba(76,141,255,.12);box-shadow:inset 3px 0 var(--primary)}
.agent-model-item b{font-size:10px}
.agent-model-item span{font-size:8px;color:var(--muted)}
@media(max-width:900px){.model-toolbar{grid-template-columns:1fr}.agent-model-item{align-items:flex-start;flex-direction:column}}

/* v10: scenario composition, threshold profiles, CCTV VLM settings */
.scenario-top-row{grid-column:1/-1;display:grid;grid-template-columns:450px minmax(0,1fr);gap:14px;align-items:stretch}.scenario-list-top{padding:0 16px 16px;box-sizing:border-box;overflow:hidden}.scenario-list-top .panel-header{padding-left:0;padding-right:0;min-height:66px}.scenario-list-top .form-grid{margin-top:0}.scenario-list-controls{min-width:0}.scenario-preview-panel{min-width:0;box-sizing:border-box;padding:14px 16px 16px;border:1px solid var(--line);border-radius:12px;background:var(--panel);box-shadow:var(--shadow);overflow:hidden}.scenario-preview-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.scenario-preview-head h3{margin:0;font-size:12px}.scenario-preview-head p{margin:4px 0 0;color:var(--muted);font-size:9px}.scenario-preview-frame{position:relative;aspect-ratio:16/9;width:100%;height:auto;max-height:146px;border:1px solid var(--line);border-radius:10px;background:#050a11;overflow:hidden}.scenario-preview-frame .preview-status{top:10px;left:10px;max-width:360px}.scenario-stream-image{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#050a11}.scenario-preview-placeholder{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:var(--muted);background:linear-gradient(145deg,#101a29,#07101c)}.scenario-preview-placeholder strong,.scenario-preview-placeholder span{display:block}.scenario-preview-placeholder strong{color:var(--text);font-size:13px}.scenario-preview-placeholder span{font-size:10px;margin-top:5px}.scenario-preview-actions{position:absolute;right:10px;bottom:10px;z-index:12;display:flex;gap:7px}
.weekly-timetable-panel .timetable-scroll{overflow:auto;max-height:calc(100vh - 270px);padding:0 14px 12px}.weekly-schedule-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line);font-size:10px}.weekly-schedule-summary strong{font-size:13px}.weekly-schedule-summary span{display:flex;align-items:center;gap:8px;color:var(--muted)}.weekly-timetable-grid{display:grid;grid-template-columns:68px repeat(7,minmax(96px,1fr));min-width:820px;border:1px solid var(--line);border-radius:9px;overflow:hidden}.weekly-time-head,.weekly-day-head,.weekly-time-label{background:var(--panel2);border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;place-items:center;font-size:9px;color:var(--muted);font-weight:700}.weekly-day-head{color:var(--text)}.weekly-time-label{min-height:32px}.weekly-schedule-cell{min-height:32px;border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.015);color:#b7cdf0;cursor:pointer;font-size:8px}.weekly-schedule-cell:hover{background:rgba(76,141,255,.16)}.weekly-schedule-cell.active{background:rgba(76,141,255,.58);color:#fff;font-weight:700}.scenario-save-actions{padding:12px 16px;display:flex;justify-content:flex-end;gap:7px;border-top:1px solid var(--line);background:var(--panel)}body.dragging-scenario-flow{overscroll-behavior:none;user-select:none}.flow-scroll-lock{overflow:hidden!important;scrollbar-gutter:stable}.scenario-flow-map.dragging{cursor:grabbing;touch-action:none}.scenario-flow-map.dragging .scenario-flow-node{cursor:grabbing}
.scenario-tabs{padding-top:0}
.scenario-flow-map{height:432px;position:relative;border:1px dashed var(--line);border-radius:10px;background:radial-gradient(circle at 50% 50%,rgba(76,141,255,.08),transparent 42%);overflow:hidden}
.scenario-flow-links{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.scenario-flow-links path{fill:none;stroke:var(--primary);stroke-width:.55;opacity:.78}.scenario-flow-links circle{fill:var(--primary);opacity:.9}
.scenario-flow-node{position:absolute;min-width:230px;max-width:300px;transform:translate(-50%,-50%);padding:12px 13px;border:1px solid var(--line);border-radius:10px;background:rgba(10,24,41,.94);box-shadow:0 10px 24px rgba(0,0,0,.18);z-index:2;cursor:move;user-select:none;touch-action:none}
.scenario-flow-node.management{border-color:#4c8dff;box-shadow:0 0 0 1px rgba(76,141,255,.35),0 0 32px rgba(76,141,255,.14)}
.scenario-flow-node.linked{border-color:rgba(76,141,255,.55)}
.scenario-flow-node.active{outline:2px solid var(--primary);outline-offset:2px}
.scenario-flow-node span,.scenario-flow-node small{display:block;font-size:8px;color:var(--muted)}
.scenario-flow-node b{display:block;font-size:10px;margin:3px 0}
.flow-port{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;border:2px solid var(--primary);background:var(--panel);transform:translateY(-50%);cursor:crosshair;z-index:3}.flow-port-in{left:-8px}.flow-port-out{right:-8px}.flow-port:hover{box-shadow:0 0 0 5px rgba(76,141,255,.18)}
.node-thresholds{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-top:7px}.node-thresholds label{font-size:8px;color:var(--muted)}.node-thresholds .input{height:26px;padding:4px 6px;font-size:9px}
.device-blocks{display:grid;gap:6px;margin-top:8px}.device-code-block{position:relative;border:1px solid var(--line);border-radius:8px;background:var(--panel2);padding:8px;display:grid;grid-template-columns:92px minmax(0,1fr);gap:6px}.device-code-block>b{grid-column:1/-1}.device-code-block>.block-level{grid-column:1/-1}.device-code-block label{font-size:8px;color:var(--muted)}.device-code-block .block-key-field{grid-column:1}.device-code-block .block-value-field{grid-column:2}.device-code-block .select,.device-code-block .input{height:28px;padding:4px 6px;font-size:9px}.remove-device-block{position:absolute;right:5px;top:5px;border:0;background:rgba(231,76,60,.15);color:#ff8d82;border-radius:5px;width:22px;height:22px;cursor:pointer;font-size:9px}
.risk-index-card{position:absolute;left:14px;top:56px;z-index:11;width:min(25%,310px);min-width:230px;border:1px solid rgba(255,255,255,.14);border-left:4px solid var(--primary);border-radius:10px;background:rgba(5,13,23,.78);backdrop-filter:blur(8px);padding:10px;display:grid;grid-template-columns:1fr 1fr;gap:8px;color:#dbe8f8;box-shadow:0 12px 28px rgba(0,0,0,.22)}.risk-index-card.idle{display:block}.risk-index-card.caution{border-left-color:var(--caution)}.risk-index-card.warning,.risk-index-card.critical{border-left-color:var(--warning)}.risk-index-card b{display:block;font-size:8px;color:var(--muted);margin-bottom:2px}.risk-index-card strong{font-size:14px}.risk-index-card small{font-size:8px;color:var(--muted);margin-left:3px}.risk-index-card span{font-size:11px;font-weight:700}.risk-index-card p{grid-column:1/-1;margin:0;padding-top:4px;border-top:1px solid rgba(255,255,255,.08);font-size:9px;color:#b9c7da;line-height:1.4}
.risk-weight-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.risk-weight-grid label{font-size:9px;color:var(--muted)}.risk-calibration-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.risk-calibration-preview>div{padding:12px;border:1px solid var(--line);border-radius:9px;background:var(--panel2)}.risk-calibration-preview b{display:block;font-size:16px}.risk-calibration-preview span{font-size:9px;color:var(--muted)}.risk-calibration-preview p{grid-column:1/-1;margin:0;color:var(--muted);font-size:10px}
.risk-suggestion-panel{border:1px solid var(--line);border-radius:9px;background:var(--panel2);padding:12px;color:var(--muted);font-size:10px;line-height:1.55}.risk-suggestion-panel div{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.risk-suggestion-panel b{color:var(--primary);font-size:11px}.risk-suggestion-panel span{font-size:9px}.risk-suggestion-panel p{margin:0;color:#c8d5e5}
.risk-diagnostic-log{margin-top:10px;border-top:1px solid var(--line);padding-top:8px}.risk-diagnostic-log summary{cursor:pointer;color:#8eb8ff;font-weight:700}.risk-diagnostic-log pre{margin:8px 0 0;max-height:240px;overflow:auto;white-space:pre-wrap;background:#081421;border:1px solid var(--line);border-radius:7px;padding:9px;color:#d7e3f2;font-size:9px;line-height:1.5}
.applied-device-list label{display:grid;grid-template-columns:26px minmax(0,1fr) minmax(120px,auto);gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--line)}
.applied-device-list label:last-child{border-bottom:0}
.applied-device-list small{display:block;font-size:8px;color:var(--muted);margin-top:3px}.applied-device-list code{color:#dbe8f8}
.threshold-profile-list{display:grid;gap:9px;padding:0 16px 16px}
.threshold-profile-row{display:grid;grid-template-columns:minmax(180px,1fr) repeat(3,120px);gap:10px;align-items:end;padding:12px;border:1px solid var(--line);border-radius:9px;background:var(--panel2)}

/* v11: field device command editor */
.device-code-editor{display:grid;gap:8px}.device-code-head,.device-code-row{display:grid;grid-template-columns:minmax(160px,1fr) minmax(220px,1.4fr) 74px;gap:8px;align-items:center}.device-code-head{font-size:9px;color:var(--muted);font-weight:800;padding:0 2px}.device-code-row .btn{height:35px}
.threshold-profile-row b{display:block;font-size:11px}.threshold-profile-row span{display:block;color:var(--muted);font-size:8px;margin-top:3px}.threshold-profile-row label{font-size:9px;color:var(--muted)}
.vlm-test-result{border:1px solid var(--line);border-radius:9px;background:var(--panel2);padding:11px;min-height:96px}
.vlm-test-result strong{display:block;font-size:10px;color:#8eb8ff;margin-bottom:6px}.vlm-test-result p{margin:0;color:#d4dfec;font-size:10px;line-height:1.55;white-space:pre-wrap}.vlm-test-result span{display:block;margin-top:8px;color:var(--muted);font-size:8px}
@media(max-width:900px){.threshold-profile-row{grid-template-columns:1fr}.scenario-top-row{grid-template-columns:1fr;height:auto}.scenario-list-top,.scenario-preview-panel{height:auto}.scenario-preview-frame{max-height:none}.scenario-flow-map{height:520px}.scenario-flow-node{position:relative;left:auto!important;top:auto!important;transform:none;margin:10px}}
.zone-editor{display:flex;flex-direction:column;gap:12px}
.zone-editor-layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:13px;align-items:start}
.zone-editor .cctv-preview-frame{height:330px;cursor:crosshair}
.zone-editor-svg{position:absolute;inset:0;width:100%;height:100%;z-index:6;pointer-events:none}
.zone-editor-svg polygon{fill:rgba(76,141,255,.12);stroke:#8eb8ff;stroke-width:3;stroke-dasharray:9 7}
.zone-editor-svg polygon.active{fill:rgba(243,156,18,.18);stroke:var(--caution);stroke-width:4}
.zone-point{fill:#fff;stroke:var(--caution);stroke-width:3;filter:drop-shadow(0 2px 5px rgba(0,0,0,.45))}
.zone-point.editable{fill:#ffe2a8}
.zone-side{display:flex;flex-direction:column;gap:10px}
.zone-list{display:grid;gap:7px;max-height:128px;overflow:auto}
.zone-list-item{text-align:left;border:1px solid var(--line);background:var(--panel2);color:var(--text);border-radius:8px;padding:9px;cursor:pointer}
.zone-list-item.active{border-color:var(--primary);box-shadow:inset 3px 0 var(--primary)}
.zone-list-item b,.zone-list-item span{display:block}.zone-list-item b{font-size:10px}.zone-list-item span{font-size:8px;color:var(--muted);margin-top:3px}
.zone-actions{display:flex;gap:7px;flex-wrap:wrap}.zone-actions .btn{flex:1 1 auto}
.hide-zone .zone-editor-svg,.hide-zone .zone-poly{display:none}.hide-heatmap .heatmap{display:none}
.check-row{height:38px;display:flex;align-items:center;gap:8px;color:var(--text);font-size:10px;border:1px solid var(--line);background:var(--panel2);border-radius:8px;padding:0 10px}.check-row input{width:auto}
@media(max-width:1100px){.zone-editor-layout{grid-template-columns:1fr}.zone-side{display:grid;grid-template-columns:1fr 1fr;align-items:start}.zone-list,.zone-actions{grid-column:1/-1}.cctv-preview-frame{height:300px}}

/* v28: dashboard chat alignment and compact VLM analysis */
.message.user-message{flex-direction:row-reverse;justify-content:flex-start}
.message.user-message .message-card{border-radius:10px 4px 10px 10px;background:rgba(76,141,255,.18);border-color:rgba(76,141,255,.36);color:#eaf2ff}
.message.user-message .ai-icon{background:linear-gradient(135deg,#4c8dff,#8a5cf6)}
.message-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:3px}
.message-meta strong{margin-bottom:0}
.message-meta time{font-size:8px;color:var(--muted);white-space:nowrap}
.dashboard-risk-summary p span{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.dashboard-risk-summary p em{display:block}

/* v29: branded logo, dashboard device command table, chat alerts */
.brand{justify-content:center;padding:10px 14px}.brand-logo{display:block;max-width:100%;max-height:54px;object-fit:contain}.sidebar.collapsed .brand-logo{max-width:46px;max-height:46px}
.dashboard-device-table-wrap{overflow:auto;max-height:180px}.dashboard-device-table{min-width:900px}.dashboard-device-table td,.dashboard-device-table th{font-size:9px}.dashboard-device-table .btn{height:27px;padding:0 9px;font-size:9px}
.modal-backdrop{position:fixed;inset:0;z-index:100;display:grid;place-items:center;background:rgba(0,0,0,.55);padding:20px}.modal-panel{width:min(980px,96vw);max-height:86vh;overflow:auto;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 70px rgba(0,0,0,.45)}
.message-card.alert{border-left:4px solid var(--caution);background:rgba(243,156,18,.1)}.message-card.alert.strong-alert{border-left-width:7px;border-left-color:var(--warning);background:rgba(231,76,60,.12)}
