:root{--bg: #0e1116;--panel: #161a22;--panel2: #1d222c;--border: #2a3142;--fg: #e6edf3;--muted: #8b949e;--accent: #4cc38a;--accent-2: #a87bff;--info: #5fcfff;--ok: #5fd4a4;--warn: #f0883e;--danger: #ff6b6b;--chart-h: 280px;--left-w: 280px;--right-w: 320px;--touch-target: 44px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--muted) 60%,transparent);border-radius:999px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--accent) 80%,transparent);background-clip:padding-box}*::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--muted) 60%,transparent) transparent}body{background:var(--bg);color:var(--fg);font-family:-apple-system,Segoe UI,Pretendard,sans-serif;font-size:14px;-webkit-tap-highlight-color:transparent}button{background:var(--panel2);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:6px 12px;cursor:pointer;font-size:13px}button:hover{border-color:var(--accent)}button.active{background:var(--accent);color:#000;border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}input,select{background:var(--panel2);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:6px 8px;width:100%;font-size:14px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:12px}.panel h3{margin:0 0 8px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-size:24px;font-weight:600}.kpi-unit{font-size:12px;color:var(--muted);margin-left:4px}.muted{color:var(--muted)}.dashboard{display:grid;grid-template-columns:var(--left-w) 8px 1fr 8px var(--right-w);grid-template-rows:50px 1fr var(--chart-h);gap:4px;padding:6px;height:100vh;overflow:hidden}.topbar{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;background:var(--panel);border:1px solid var(--border);border-radius:6px}.topbar-left{display:flex;align-items:center;min-width:0;overflow:hidden;flex:0 0 auto;max-width:30%}.topbar-tools{display:flex;gap:12px;align-items:center;flex:1;justify-content:center;flex-wrap:wrap}.topbar-right{display:flex;align-items:center;gap:8px;flex:0 0 auto}.tool-group{display:flex;gap:2px;align-items:center;background:var(--panel2);border:1px solid var(--border);border-radius:6px;padding:2px}.tool-group .tool-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:0 6px}.tool-group button{background:transparent;border:none;padding:4px 10px;border-radius:4px;font-size:12px}.tool-group button:hover{background:var(--border);border:none}.tool-group button.active{background:var(--accent);color:#000}.hamburger-btn{display:none;background:var(--panel2);border:1px solid var(--border);border-radius:6px;width:36px;height:36px;align-items:center;justify-content:center;font-size:18px;line-height:1;cursor:pointer}.hamburger-btn:hover{border-color:var(--accent)}.clock{color:var(--fg);font-size:12px;font-variant-numeric:tabular-nums}.clock strong{color:var(--accent);margin-left:4px}.left{grid-column:1;grid-row:2;overflow-y:auto;flex-direction:column;gap:8px;min-width:0}.left-handle{grid-column:2;grid-row:2}.center{grid-column:3;grid-row:2;min-width:0;min-height:0}.right-handle{grid-column:4;grid-row:2}.right{grid-column:5;grid-row:2;overflow-y:auto;flex-direction:column;gap:8px;min-width:0}.bottom{grid-column:1 / -1;grid-row:3;position:relative;flex-direction:column;min-height:0}.resize-handle-v{cursor:ew-resize;background:var(--panel2);border-left:1px solid var(--border);border-right:1px solid var(--border);align-self:stretch;display:flex;align-items:center;justify-content:center;position:relative}.resize-handle-v:after{content:"║";color:var(--muted);font-size:18px;line-height:1}.resize-handle-v:hover{background:var(--accent)}.resize-handle-v:hover:after{color:#000}.resize-handle{height:10px;cursor:ns-resize;background:var(--panel2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative}.resize-handle:after{content:"═══";color:var(--muted);font-size:8px;letter-spacing:-1px;line-height:1}.resize-handle:hover{background:var(--accent)}.resize-handle:hover:after{color:#000}.login-screen{height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.login-card{width:100%;max-width:360px;padding:28px;background:var(--panel);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;gap:12px}.login-card h1{margin:0;font-size:20px}.login-card .muted{color:var(--muted);font-size:12px}.login-tab{display:flex;gap:4px;margin-bottom:8px}.login-tab button{flex:1}.actuator-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.actuator-row:last-child{border-bottom:none}.actuator-name{flex:1 1 100px;font-size:13px;min-width:0}.actuator-bar{flex:2 1 80px;height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.actuator-bar-fill{height:100%;background:var(--accent);transition:width .3s}.actuator-pct{width:40px;text-align:right;font-variant-numeric:tabular-nums;font-size:12px}.mode-pill{font-size:10px;padding:2px 6px;border-radius:999px;text-transform:uppercase}.actuator-card{display:flex;flex-direction:column;gap:6px;padding:8px 10px;margin-bottom:6px;background:var(--panel2);border:1px solid var(--border);border-radius:6px}.actuator-card:last-child{margin-bottom:0}.actuator-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.actuator-card-name{font-size:13px;display:flex;align-items:center;gap:6px;min-width:0}.actuator-card-value{font-size:12px;font-variant-numeric:tabular-nums;color:var(--fg);white-space:nowrap}.actuator-card-bar{height:6px;background:var(--bg);border-radius:3px;overflow:hidden}.actuator-card-bar-fill{height:100%;background:var(--accent);transition:width .3s}.actuator-card-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:4px;border-top:1px dashed var(--border)}.master-mode-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.master-mode-toggle button{flex:1;padding:8px 10px;border-radius:0;background:transparent;font-size:13px}.master-mode-toggle button.active{background:var(--accent);color:#000;font-weight:600}.master-mode-caption{font-size:11px;color:var(--muted);margin-top:4px;margin-bottom:10px;line-height:1.4}.readonly-badge{display:inline-block;margin-left:6px;font-size:10px;padding:2px 6px;border-radius:999px;background:var(--border);color:var(--muted);text-transform:none;letter-spacing:0}.mode-auto{background:var(--border);color:var(--muted)}.mode-manual{background:var(--warn);color:#000}.folder-tabs{display:flex;align-items:flex-end;gap:2px;padding:0 4px;margin-bottom:-1px;position:relative;z-index:1}.folder-tab{background:var(--panel2);color:var(--muted);border:1px solid var(--border);border-bottom:none;border-radius:6px 6px 0 0;padding:5px 12px;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .1s,color .1s}.folder-tab:hover{color:var(--fg)}.folder-tab.active{background:var(--panel);color:var(--fg);font-weight:600;padding:7px 14px;margin-bottom:0;position:relative}.folder-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--panel)}.folder-tab .badge-dot{width:6px;height:6px;border-radius:50%;background:var(--warn);display:inline-block}.folder-tab .badge-text{font-size:10px;color:var(--warn);font-variant-numeric:tabular-nums}.folder-panel{background:var(--panel);border:1px solid var(--border);border-radius:0 6px 6px;padding:12px;flex:1;min-height:0;overflow-y:auto}.tab-container{display:flex;flex-direction:column;flex:1;min-height:0}.decision-row{border:1px solid var(--border);border-radius:6px;padding:10px;margin-bottom:8px;background:#161a22b3}.decision-row-header{display:flex;justify-content:space-between;align-items:baseline;gap:8px;flex-wrap:wrap;margin-bottom:4px}.outcome-badge{font-size:10px;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}.outcome-user_select{background:var(--accent);color:#000}.outcome-auto_apply{background:var(--warn);color:#000}.outcome-expired{background:var(--border);color:var(--muted)}.outcome-pending{background:var(--panel2);color:var(--accent);border:1px solid var(--accent)}.weather-widget{display:flex;flex-direction:column;gap:8px}.weather-main{display:flex;gap:12px;align-items:baseline;flex-wrap:wrap}.weather-temp{font-size:36px;font-weight:600}.weather-meta{color:var(--muted);font-size:12px}.forecast-bars{display:flex;gap:2px;align-items:flex-end;height:50px}.forecast-bars .bar{flex:1;min-height:2px;border-radius:2px 2px 0 0;background:linear-gradient(180deg,#f0883e,#4cc38a);opacity:.85}.forecast-labels{display:flex;gap:2px;font-size:9px;color:var(--muted)}.forecast-labels span{flex:1;text-align:center}.sensor-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadein .15s}.sensor-drawer{width:100%;max-width:720px;background:var(--panel);border:1px solid var(--border);border-radius:8px 8px 0 0;padding:16px;animation:slideup .2s}@keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes slideup{0%{transform:translateY(40px)}to{transform:translateY(0)}}@media(max-width:900px){.hamburger-btn{display:inline-flex}.topbar-left{max-width:50%}.topbar-tools{display:none;position:fixed;top:60px;right:8px;left:8px;background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:8px;z-index:50;flex-direction:column;gap:8px;box-shadow:0 4px 16px #0006}.dashboard.tools-open .topbar-tools{display:flex}.topbar-tools .tool-group{width:100%;justify-content:flex-start}.topbar-tools .tool-group button{min-height:var(--touch-target);flex:1}.topbar button,.hamburger-btn{min-height:36px}}@media(max-width:768px){.dashboard{grid-template-columns:1fr;grid-template-rows:50px auto auto auto var(--chart-h);height:auto;min-height:100vh;overflow:visible}.left{grid-column:1;grid-row:2;overflow-y:visible}.center{grid-column:1;grid-row:3;height:60vh;min-height:380px;max-height:560px;touch-action:none}.right{grid-column:1;grid-row:4;overflow-y:visible}.bottom{grid-column:1;grid-row:5}.left-handle,.right-handle,.resize-handle,.hide-on-mobile{display:none}.topbar{padding:0 8px}.left,.right{display:grid!important;grid-template-columns:1fr 1fr;gap:8px}.left .panel.weather-widget,.right .panel,.right .tab-container{grid-column:1 / -1}.right .folder-panel{max-height:none;overflow-y:visible}.kpi-value{font-size:20px}.sensor-drawer{max-width:100%}}@media(max-width:480px){.left,.right{grid-template-columns:1fr!important}.weather-temp{font-size:28px}}
