*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:15px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Noto Sans SC,sans-serif}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}a{color:inherit;text-decoration:none}input,select,textarea{font-family:inherit;font-size:inherit}:root,[data-theme=dark]{--bg:#0a1118;--bg-card:#111b26;--bg-card-hover:#162230;--bg-sidebar:#0c1520;--bg-input:#111b26;--text:#c8d6e5;--text-muted:#4a6a85;--text-dim:#304860;--card-border:#2846641f;--border-light:#2846642e;--shadow:0 2px 12px #00000040;--accent:#00d4ff;--success:#2ed573;--danger:#ff4757;--warning:#f1c40f;--info:#2e86de;--radius:10px;--sidebar-w:220px}[data-theme=light]{--bg:#f5f7fa;--bg-card:#fff;--bg-card-hover:#f0f4f8;--bg-sidebar:#1a2332;--bg-input:#fff;--text:#1a2332;--text-muted:#6b7d95;--text-dim:#99a8bb;--card-border:#0000000f;--border-light:#0000001a;--shadow:0 2px 12px #0000000f;--radius:10px;--sidebar-w:220px}.app-layout{background:var(--bg);min-height:100vh;color:var(--text);display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);z-index:100;border-right:1px solid #ffffff0a;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.sidebar-logo{align-items:center;gap:10px;display:flex}.sidebar-logo-icon{font-size:24px}.sidebar-logo-title{color:#c8d6e5;letter-spacing:.03em;font-size:15px;font-weight:800}.sidebar-logo-sub{color:#4a6a85;letter-spacing:.02em;font-size:9px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px;display:flex}.nav-item{white-space:nowrap;color:#5a7a95;border-radius:8px;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:600;transition:all .15s;display:flex;overflow:hidden}.nav-item:hover{color:#8aa8c0;background:#ffffff0d}.nav-item.active{color:#00d4ff;background:#00d4ff14}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:15px}.nav-label{text-overflow:ellipsis;overflow:hidden}.sidebar-footer{border-top:1px solid #ffffff0d;padding:10px 14px}.sidebar-user{align-items:center;gap:8px;margin-bottom:8px;display:flex}.sidebar-user-avatar{color:#00d4ff;background:#00d4ff26;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.sidebar-user-name{color:#c8d6e5;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.sidebar-user-role{color:#4a6a85;font-size:9px}.btn-logout{color:#5a7a85;border-radius:6px;align-items:center;gap:6px;width:100%;padding:6px 8px;font-size:11px;display:flex}.btn-logout:hover{color:#ff4757;background:#ff475714}.sidebar-overlay{z-index:99;background:#00000080;position:fixed;inset:0}.app-main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}[data-sidebar=closed] .app-main{margin-left:0}.app-content{flex-direction:column;flex:1;padding:0;display:flex}@media (width<=768px){.app-content{padding:0}}.topbar{background:var(--bg-card);border-bottom:1px solid var(--card-border);z-index:50;justify-content:space-between;align-items:center;gap:12px;min-width:0;height:48px;padding:0 16px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:10px;min-width:0;display:flex;overflow:hidden}.topbar-location{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.topbar-status{color:#2ed573;white-space:nowrap;flex-shrink:0;font-size:11px}.topbar-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.topbar-time{color:var(--text-muted);white-space:nowrap;align-items:center;gap:8px;font-family:SF Mono,Cascadia Code,monospace;font-size:13px;display:flex}.topbar-date{color:var(--text-dim);font-size:11px}.topbar-user{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:12px;overflow:hidden}.btn-icon{color:var(--text-muted);border-radius:6px;padding:5px 9px;font-size:16px;transition:all .15s}.btn-icon:hover{background:var(--bg-card-hover)}.btn-menu{display:none}@media (width<=768px){.sidebar{display:none}.app-main{margin-left:0!important}.btn-menu{display:block}[data-sidebar=open] .sidebar{display:flex}}.page{flex-direction:column;flex:1;padding:16px 20px;display:flex}.page-loading{height:60vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px}.error-banner{color:#ff4757;background:#ff475714;border:1px solid #ff475726;border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:12px}.table-wrap{max-height:480px;overflow:auto}.card{background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:14px;padding:20px 24px}@media (width<=768px){.card{padding:16px}}.card-hd{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.card h3{color:var(--text);letter-spacing:.02em;font-size:14px;font-weight:700}.btn-primary{background:var(--accent);color:#0a1118;border-radius:8px;padding:9px 22px;font-size:14px;font-weight:700;transition:all .15s}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-sec{border:1px solid var(--card-border);color:var(--text-muted);border-radius:8px;padding:9px 22px;font-size:13px;font-weight:600;transition:all .15s}.btn-sec:hover{border-color:var(--border-light);color:var(--text)}.btn-sm{background:var(--accent);color:#0a1118;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .15s}.btn-sm.danger{color:#ff4757;background:#ff47571f}.btn-sm.danger:disabled{opacity:.3}.input-group{margin-bottom:12px}.input-group label{color:var(--text-muted);letter-spacing:.02em;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.input-group input,.input-group select{border:1px solid var(--card-border);background:var(--bg-input);width:100%;color:var(--text);border-radius:7px;outline:none;padding:9px 12px;font-size:14px;transition:border-color .15s}.input-group input:focus,.input-group select:focus{border-color:var(--accent)}.tbl{border-collapse:collapse;table-layout:fixed;width:100%;font-size:13px}.tbl th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--card-border);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:600}.tbl td{border-bottom:1px solid var(--card-border);text-overflow:ellipsis;white-space:nowrap;padding:10px 12px;overflow:hidden}.tbl tr:hover td{background:var(--bg-card-hover)}.status-badge{border-radius:99px;padding:2px 10px;font-size:11px;font-weight:700}.modal-overlay{z-index:200;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:12px;width:100%;max-width:440px;padding:24px;box-shadow:0 8px 40px #0006}.modal h3{margin-bottom:14px;font-size:15px;font-weight:700}.modal-actions{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.login-page{background:linear-gradient(135deg,#0a1118 0%,#142030 50%,#0c1824 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#111b26;border:1px solid #2846642e;border-radius:16px;width:100%;max-width:400px;padding:44px 32px;box-shadow:0 8px 40px #0006}.login-header{text-align:center;margin-bottom:32px}.login-logo{margin-bottom:10px;font-size:44px}.login-header h1{color:#c8d6e5;letter-spacing:.03em;font-size:20px;font-weight:800}.login-header p{color:#4a6a85;margin-top:6px;font-size:12px}.login-form{flex-direction:column;gap:4px;display:flex}.login-form .input-group{margin-bottom:14px}.login-form .input-group label{color:#6b7d95;letter-spacing:.02em;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.login-form .input-group input{color:#c8d6e5;background:#0d1620;border:1px solid #28466440;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .15s}.login-form .input-group input:focus{border-color:#00d4ff}.login-form .btn-primary{width:100%;margin-top:12px;padding:12px;font-size:15px}.login-error{color:#ff4757;background:#ff47571a;border-radius:8px;margin-bottom:8px;padding:10px 12px;font-size:13px}.login-footer{text-align:center;color:#304860;margin-top:20px;font-size:11px}.orch{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.orch-bar{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--card-border);justify-content:space-between;align-items:center;gap:12px;padding:12px 18px;display:flex}.orch-bar-left{align-items:center;gap:8px;display:flex}.orch-icon{font-size:20px}.orch-title{color:var(--text);font-size:12px;font-weight:700}.orch-sub{color:var(--text-muted);font-size:8px}.orch-bar-ctr{align-items:center;gap:10px;display:flex}.orch-mode{color:var(--text-muted);background:#283c5a33;border-radius:99px;padding:2px 10px;font-size:10px;font-weight:700}.mode-ai_auto{color:#2ed573!important;background:#2ecc711f!important}.mode-ai_advisory{color:#9b59b6!important;background:#9b59b61f!important}.mode-safe_fallback{color:#ff4757!important;background:#ff47571f!important}.orch-pipe{align-items:center;gap:2px;display:flex}.pipe-step{color:var(--text-dim);background:#28374b26;border-radius:3px;padding:1px 4px;font-size:7px;font-weight:600;transition:all .3s}.pipe-step.on{color:var(--accent)!important;background:#00d4ff14!important}.pipe-arrow{color:var(--text-dim);font-size:7px}.orch-bar-right{align-items:center;display:flex}.orch-target em{color:var(--text-muted);font-size:8px;font-style:normal}.orch-target{color:var(--accent);font-family:SF Mono,monospace;font-size:11px;font-weight:700}.orch-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}@media (width<=640px){.orch-grid{grid-template-columns:repeat(2,1fr)}.orch-bar{flex-direction:column;align-items:flex-start}}.agent-card{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--card-border);padding:12px 14px;transition:all .3s;position:relative}.agent-card-bar{border-radius:2px 2px 0 0;height:2px;position:absolute;top:0;left:0;right:0}.agent-card-hd{align-items:center;gap:7px;padding-top:2px;display:flex}.agent-card-avatar{background:#28374b1f;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;display:flex}.agent-card-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:700;overflow:hidden}.agent-card-role{letter-spacing:.04em;flex-shrink:0;font-size:7px;font-weight:600}.agent-card-dot{opacity:.3;border-radius:50%;flex-shrink:0;width:5px;height:5px;margin-left:auto}.agent-card-bd{flex-direction:column;gap:3px;margin-top:7px;display:flex}.agent-card-desc{color:var(--text-muted);font-size:8px;line-height:1.3}.agent-card-detail{align-items:center;gap:3px;font-size:9px;font-weight:600;display:flex}.agent-card-val{text-align:center;color:var(--accent);background:#00d4ff0f;border-radius:6px;margin-top:6px;padding:2px 10px;font-family:SF Mono,monospace;font-size:16px;font-weight:800}.orch-trigger{justify-content:center;align-items:center;gap:14px;margin-bottom:10px;display:flex}.btn-tick{background:var(--bg-card);border:1px solid var(--card-border);color:var(--text-muted);letter-spacing:.04em;border-radius:10px;align-items:center;gap:6px;padding:8px 22px;font-size:12px;font-weight:700;transition:all .3s;display:flex}.btn-tick:hover:not(:disabled){color:#6a9ab5;border-color:#00d4ff4d}.btn-tick:disabled{opacity:.4;cursor:not-allowed}.tick-result{background:#2ecc710f;border:1px solid #2ecc711a;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;display:flex}.tick-label{color:var(--text-muted);font-size:9px}.tick-val{color:#2ed573;font-family:SF Mono,monospace;font-size:15px;font-weight:800}.tick-clip{color:#f1c40f;background:#f1c40f1a;border-radius:3px;padding:1px 5px;font-size:8px}.spin-icon{animation:1s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.kpi-strip{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;display:grid}.kpi-item{background:var(--bg-card);border:1px solid var(--card-border);border-radius:8px;align-items:center;gap:8px;padding:10px 14px;display:flex}.kpi-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.kpi-info{flex-direction:column;gap:1px;min-width:0;display:flex}.kpi-label{color:var(--text-muted);font-size:10px}.kpi-value{font-size:15px;font-weight:700}.kpi-value small{color:var(--text-dim);margin-left:2px;font-size:9px;font-weight:400}.ctrl-page .card{margin-bottom:8px}.mode-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px;display:grid}.mode-btn{border:1px solid var(--card-border);text-align:left;background:var(--bg-input);border-radius:8px;padding:10px;transition:all .15s}.mode-btn:hover{border-color:var(--border-light)}.mode-btn-label{margin-bottom:2px;font-size:12px;font-weight:700}.mode-btn-desc{color:var(--text-muted);font-size:9px}.target-grid{flex-wrap:wrap;gap:4px;margin-bottom:10px;display:flex}.target-btn{border:1px solid var(--card-border);background:var(--bg-input);border-radius:6px;padding:5px 12px;font-size:11px;font-weight:600;transition:all .15s}.target-btn:hover{border-color:var(--border-light)}.target-btn.active{border-color:var(--accent);color:var(--accent);background:#00d4ff0f}.ctrl-action{text-align:center}.result-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;display:grid}.result-item{flex-direction:column;gap:2px;display:flex}.result-label{color:var(--text-muted);font-size:9px}.result-val{font-size:16px;font-weight:800}.result-reason{color:var(--text-muted);background:#00d4ff0a;border-radius:6px;margin-top:10px;padding:8px 10px;font-size:11px;line-height:1.4}.exec-grid{flex-direction:column;gap:6px;display:flex}.exec-item{align-items:center;gap:8px;display:flex}.exec-bar-label{width:60px;color:var(--text-muted);flex-shrink:0;font-size:10px}.exec-bar-wrap{background:var(--bg-input);border-radius:3px;flex:1;height:6px;overflow:hidden}.exec-bar{border-radius:3px;height:100%;transition:width .5s}.exec-bar-val{text-align:right;width:40px;font-size:10px;font-weight:700}.filter-stages{flex-direction:column;gap:10px;display:flex}.filter-stage{background:var(--bg-input);border-radius:8px;padding:10px}.filter-stage-hd{justify-content:space-between;margin-bottom:6px;display:flex}.filter-stage-name{font-size:12px;font-weight:700}.filter-stage-status{font-size:10px;font-weight:600}.filter-stage-gauge{background:#28374b26;border-radius:3px;height:6px;margin-bottom:4px;overflow:hidden}.gauge-fill{border-radius:3px;height:100%;transition:width .5s}.filter-stage-info{color:var(--text-muted);flex-wrap:wrap;gap:12px;font-size:9px;display:flex}.filter-stage-info span{white-space:nowrap}.filter-cost{background:var(--bg-input);border-radius:8px;gap:16px;margin-top:10px;padding:10px;display:flex}.cost-item{color:var(--text-muted);flex-direction:column;gap:2px;font-size:10px;display:flex}.cost-item strong{color:var(--warning);font-size:14px;font-weight:800}.filter-suggest{color:var(--warning);background:#f1c40f0f;border-radius:6px;margin-top:8px;padding:8px 10px;font-size:10px;line-height:1.4}.safety-checks{flex-direction:column;gap:6px;display:flex}.safety-check{border:1px solid var(--card-border);border-radius:8px;padding:10px}.safety-check.block{background:#ff47570a;border-color:#ff475733}.safety-check.degrade{background:#f1c40f0a;border-color:#f1c40f26}.safety-check-hd{justify-content:space-between;align-items:center;gap:8px;margin-bottom:3px;display:flex}.safety-check-layer{white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;overflow:hidden}.safety-check-verdict{flex-shrink:0;font-size:10px;font-weight:700}.safety-check-verdict.block{color:#ff4757}.safety-check-verdict.pass{color:#2ed573}.safety-check-reason{color:var(--text-muted);word-break:break-word;font-size:10px}.safety-allowed{color:var(--text-muted);margin-top:8px;font-size:10px}.history-list{flex-direction:column;gap:2px;max-height:400px;display:flex;overflow-y:auto}.history-item{border-radius:6px;align-items:center;gap:10px;padding:6px 8px;font-size:10px;display:flex}.history-item:hover{background:var(--bg-card-hover)}.history-time{color:var(--text-dim);width:60px;font-family:SF Mono,monospace}.history-mode{width:70px;color:var(--info);font-weight:600}.history-target{color:var(--text-muted);flex:1}.history-val{font-weight:700}.energy-total{align-items:baseline;gap:6px;display:flex}.energy-total em{color:var(--text-muted);font-size:9px;font-style:normal}.energy-total strong{color:var(--warning);font-size:16px;font-weight:800}.energy-total small{color:var(--text-dim);font-size:9px}.energy-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px;display:grid}.energy-card{background:var(--bg-input);border:1px solid var(--card-border);border-radius:8px;gap:10px;padding:12px;display:flex}.energy-card-icon{background:#28374b1a;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:22px;display:flex}.energy-card-label{color:var(--text-muted);font-size:10px}.energy-card-val{font-size:15px;font-weight:800}.energy-card-sub{color:var(--text-dim);font-size:9px}.energy-hours-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px;display:grid}.energy-hour-item{background:var(--bg-input);border:1px solid var(--card-border);text-align:center;border-radius:6px;padding:8px 10px}.energy-hour-mode{color:var(--text-muted);margin-bottom:2px;font-size:10px}.energy-hour-val{color:var(--accent);font-family:monospace;font-size:13px;font-weight:700}.energy-summary{flex-direction:column;gap:4px;margin-top:10px;display:flex}.summary-row{border-radius:4px;gap:16px;padding:4px 8px;font-size:11px;display:flex}.summary-row:hover{background:var(--bg-card-hover)}.summary-mode{width:100px;color:var(--info);white-space:nowrap;font-weight:600}.summary-cost{white-space:nowrap;width:100px;font-weight:700}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px;display:grid}.settings-row{align-items:center;gap:12px;padding:8px 0;font-size:13px;display:flex}.form-actions{margin-top:10px}.dash-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.btn-tick-dash{background:var(--accent);color:#0a1118;border-radius:8px;flex-shrink:0;padding:8px 18px;font-size:13px;font-weight:700;transition:all .15s}.btn-tick-dash:hover:not(:disabled){filter:brightness(1.1)}.btn-tick-dash:disabled{opacity:.4;cursor:not-allowed}.dash-grid-4{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px;display:grid}.dash-grid-2{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px;display:grid}.dash-grid-3{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px;display:grid}@media (width<=1200px){.dash-grid-4,.dash-grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.dash-grid-4,.dash-grid-2,.dash-grid-3{grid-template-columns:1fr}}.stat-card{background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius);cursor:default;padding:14px 16px;transition:all .2s}.stat-head{align-items:center;gap:8px;margin-bottom:8px;display:flex}.stat-icon{font-size:20px}.stat-label{color:var(--text-muted);font-size:12px;font-weight:600}.stat-body{align-items:baseline;gap:6px;display:flex}.stat-value{color:var(--text);font-size:24px;font-weight:800}.stat-unit{color:var(--text-dim);font-size:12px}.stat-trend{border-radius:4px;padding:1px 6px;font-size:11px;font-weight:700}.stat-trend.up{color:#2ed573;background:#2ed57314}.stat-trend.down{color:#ff4757;background:#ff475714}.stat-desc{color:var(--text-dim);margin-top:6px;font-size:10px}.panel{background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius);padding:16px 18px;position:relative}.panel-title{color:var(--text);margin-bottom:12px;font-size:13px;font-weight:700}.legend-light{gap:16px;margin-top:8px;font-size:11px;display:flex}.filter-cards{flex-direction:column;gap:12px;display:flex}.filter-mini{flex-direction:column;gap:4px;display:flex}.filter-mini-info{color:var(--text);justify-content:space-between;font-size:11px;font-weight:600;display:flex}.filter-bar-bg{background:#ffffff0f;border-radius:4px;height:8px;overflow:hidden}.filter-bar-fill{border-radius:4px;height:100%;transition:width 1s}.safety-badge{margin-bottom:10px}.safety-list{flex-direction:column;gap:6px;display:flex}.safety-item{align-items:flex-start;gap:8px;display:flex}.safety-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:3px}.safety-dot.green{background:#2ed573}.safety-dot.red{background:#ff4757}.agent-log{flex-direction:column;gap:6px;max-height:200px;display:flex;overflow-y:auto}.agent-entry{align-items:center;gap:8px;padding:4px 0;display:flex}.agent-tag{color:#fff;border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:9px;font-weight:700}.agent-msg{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.agent-time{color:var(--text-dim);font-family:monospace;font-size:9px}.tick-feedback-bar{animation:1.5s ease-in-out pulse-bar}@keyframes pulse-bar{0%,to{opacity:1}50%{opacity:.7}}.dashboard-layout{grid-template-columns:1fr 380px;align-items:start;gap:16px;display:grid}@media (width<=1024px){.dashboard-layout{grid-template-columns:1fr}}.dashboard-chat{max-height:calc(100vh - 80px);position:sticky;top:64px}.facility-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:6px;display:grid}@media (width<=640px){.facility-grid{grid-template-columns:1fr}}.ai-chat{background:var(--bg-card);border:1px solid var(--card-border);border-radius:var(--radius);flex-direction:column;height:calc(100vh - 96px);display:flex;overflow:hidden}.ai-chat-hd{cursor:pointer;border-bottom:1px solid var(--card-border);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.ai-chat-title{align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.ai-chat-dot{background:#2ed573;border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 6px #2ed573}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.ai-chat-toggle{color:var(--text-muted);font-size:10px}.ai-chat-bd{flex-direction:column;flex:1;display:flex;overflow:hidden}.ai-chat-msgs{flex-direction:column;flex:1;gap:10px;padding:12px 14px;display:flex;overflow-y:auto}.ai-msg{gap:8px;display:flex}.ai-msg-avatar{background:#283c5a26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.ai-msg.ai .ai-msg-avatar{background:#00d4ff1a}.ai-msg-bubble{flex:1;min-width:0}.ai-msg-text{color:var(--text);white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.55}.ai-msg.ai .ai-msg-text{color:#a0c8e0}.ai-msg-images{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.ai-msg-images img{border:1px solid var(--card-border);object-fit:cover;border-radius:6px;max-width:100px;max-height:80px}.ai-msg-files{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.ai-file-tag{color:var(--text-muted);background:#283c5a1f;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:10px;display:inline-flex}.ai-file-tag button{color:var(--text-dim);padding:0 2px;font-size:10px}.ai-file-tag button:hover{color:#ff4757}.ai-typing{gap:2px;padding:2px 0;display:inline-flex}.ai-typing span{background:var(--text-muted);border-radius:50%;width:4px;height:4px;animation:1.2s ease-in-out infinite typing-bounce}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.trend-tabs{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.trend-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=768px){.trend-grid{grid-template-columns:1fr}}.trend-card{min-height:320px}.trend-chart{width:100%;height:300px}.alert-rules-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;display:grid}.alert-rule-card{border:1px solid var(--card-border);background:var(--bg-input);border-left:3px solid;border-radius:8px;padding:12px 14px;transition:all .15s}.alert-rule-card.disabled{opacity:.4}.alert-rule-hd{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.alert-rule-name{text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}.alert-rule-detail{color:var(--text-muted);margin-bottom:6px;font-family:monospace;font-size:10px}.alert-rule-toggle{color:#ff4757;background:#ff47571a;border-radius:99px;padding:2px 10px;font-size:9px;font-weight:700;transition:all .15s}.alert-rule-toggle.on{color:#2ed573;background:#2ecc711a}.report-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=768px){.report-grid{grid-template-columns:1fr}}.ai-chat-input-area{border-top:1px solid var(--card-border);padding:8px 10px}.ai-preview-imgs{flex-wrap:wrap;gap:4px;margin-bottom:6px;display:flex}.ai-preview-img{position:relative}.ai-preview-img img{border:1px solid var(--card-border);object-fit:cover;border-radius:6px;width:48px;height:48px}.ai-preview-rm{color:#fff;background:#ff4757;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:8px;display:flex;position:absolute;top:-4px;right:-4px}.ai-preview-files{flex-wrap:wrap;gap:4px;margin-bottom:6px;display:flex}.ai-chat-input-row{align-items:flex-end;gap:4px;display:flex}.ai-input-btn{width:32px;height:32px;color:var(--text-muted);background:#283c5a14;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.ai-input-btn:hover{color:var(--accent);background:#00d4ff1a}.ai-input-btn.listening{color:#ff4757;background:#ff47571f;animation:1s ease-in-out infinite pulse-dot}.ai-chat-input{resize:none;border:1px solid var(--card-border);background:var(--bg-input);color:var(--text);border-radius:8px;outline:none;flex:1;min-height:32px;max-height:80px;padding:7px 10px;font-family:inherit;font-size:12px;line-height:1.4}.ai-chat-input:focus{border-color:var(--accent)}.ai-chat-input::placeholder{color:var(--text-dim)}.ai-send-btn{background:var(--accent);color:#0a1118;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;transition:all .15s;display:flex}.ai-send-btn:disabled{opacity:.3;cursor:not-allowed}.ai-send-btn:hover:not(:disabled){filter:brightness(1.15)}
