:root{--primary: #3BA6D9;--primary-dark: #2B7FB0;--bg: #F5FAFD;--surface: #fff;--text: #1F2D3A;--muted: #6B7C8A;--border: #DCE7EF;--ok: #2E9E6B;--warn: #E8A13A;--crit: #D6493B;--offline: #8794A0;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 3px rgba(31, 45, 58, .08), 0 1px 2px rgba(31, 45, 58, .04);--shadow-lg: 0 8px 28px rgba(31, 45, 58, .16);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}html.dark-mode{--bg: #121E26;--surface: #1B2C38;--text: #EAF2F8;--border: #2A3C48;--muted: #92A6B4;--shadow: 0 1px 3px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .5)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{margin:0 0 12px;font-weight:600;color:var(--text)}h1{font-size:22px}h2{font-size:18px}h3{font-size:15px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--muted);font-size:15px}.app-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:24px 20px 48px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-header h1{margin:0}.topbar{display:flex;align-items:center;gap:16px;height:56px;padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1500;box-shadow:var(--shadow)}.logo{display:inline-flex;align-items:baseline;gap:1px;font-size:18px;font-weight:700;letter-spacing:-.2px;color:var(--text);cursor:pointer;white-space:nowrap}.logo .logo-mark{color:var(--primary)}.logo .logo-sub{color:var(--muted);font-weight:600}.topbar-nav{display:flex;align-items:center;gap:4px;margin-left:8px}.nav-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:7px 12px;border-radius:var(--radius);font-size:13px;font-weight:500;font-family:var(--font);color:var(--muted);transition:all .15s;white-space:nowrap}.nav-btn:hover{background:var(--bg);color:var(--text)}.nav-btn.active{background:#3ba6d91f;color:var(--primary-dark)}html.dark-mode .nav-btn.active{background:#3ba6d933;color:var(--primary)}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--crit);color:#fff;font-size:11px;font-weight:700;line-height:1}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.dropdown{position:relative}.dropdown-trigger{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid transparent;cursor:pointer;padding:7px 10px;border-radius:var(--radius);font-size:13px;font-weight:500;font-family:var(--font);color:var(--text);transition:all .15s}.dropdown-trigger:hover{background:var(--bg)}.dropdown-trigger.active{background:#3ba6d91f;color:var(--primary-dark)}.dropdown-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:6px;z-index:2000}.dropdown-menu.left{left:0;right:auto}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:8px 10px;border-radius:6px;font-size:13px;color:var(--text);font-family:var(--font);transition:background .12s}.dropdown-item:hover{background:var(--bg)}.dropdown-item.danger{color:var(--crit)}.dropdown-divider{height:1px;background:var(--border);margin:6px 4px}.burger-btn{display:none;background:none;border:none;cursor:pointer;width:36px;height:36px;padding:0;flex-direction:column;align-items:center;justify-content:center;gap:4px}.burger-line{width:20px;height:2px;background:var(--primary);border-radius:1px;transition:all .2s}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);background:none;border:1px solid var(--border);cursor:pointer;color:var(--muted);font-size:16px;transition:all .15s}.icon-btn:hover{color:var(--primary);border-color:var(--primary)}.nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:1400;display:none}.impersonate-select{background:#e8a13a24;color:var(--warn);border:1px solid rgba(232,161,58,.4);border-radius:var(--radius);padding:6px 8px;font-size:12px;font-family:var(--font);max-width:220px;cursor:pointer}html.dark-mode .impersonate-select{background:#e8a13a2e}.impersonate-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#e8a13a29;color:#8a5a14;padding:8px 20px;font-size:13px;border-bottom:1px solid rgba(232,161,58,.4)}html.dark-mode .impersonate-banner{color:#f0c170}.impersonate-banner button{background:var(--surface);border:1px solid rgba(232,161,58,.5);color:inherit;border-radius:6px;padding:4px 10px;cursor:pointer;font-size:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:18px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.loc-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--offline);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:18px;cursor:pointer;transition:transform .12s,box-shadow .12s;display:flex;flex-direction:column;gap:12px}.loc-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.loc-card.s-ok{border-left-color:var(--ok)}.loc-card.s-warn{border-left-color:var(--warn)}.loc-card.s-crit{border-left-color:var(--crit)}.loc-card.s-offline{border-left-color:var(--offline)}.loc-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.loc-card-name{font-size:16px;font-weight:600}.loc-card-tip{font-size:12px;color:var(--muted);text-transform:capitalize}.loc-temp{display:flex;align-items:baseline;gap:6px}.loc-temp-val{font-size:34px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}.loc-temp-unit{font-size:16px;color:var(--muted)}.loc-temp-na{font-size:18px;color:var(--muted);font-weight:500}.loc-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;color:var(--muted)}.metric-row{display:flex;gap:18px;flex-wrap:wrap}.metric{display:flex;flex-direction:column;gap:2px}.metric-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.metric-value{font-size:18px;font-weight:600;font-variant-numeric:tabular-nums}.semaphore{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:14px;font-size:12px;font-weight:600;line-height:1.4;white-space:nowrap}.semaphore .dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}.sem-ok{background:#2e9e6b24;color:var(--ok)}.sem-warn{background:#e8a13a29;color:#b97d1f}html.dark-mode .sem-warn{color:var(--warn)}.sem-crit{background:#d6493b24;color:var(--crit)}.sem-offline{background:#8794a029;color:var(--offline)}.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:12px;font-size:11px;font-weight:600;background:var(--bg);color:var(--muted);border:1px solid var(--border)}.pill.ok{background:#2e9e6b24;color:var(--ok);border-color:transparent}.pill.warn{background:#e8a13a29;color:#b97d1f;border-color:transparent}.pill.crit{background:#d6493b24;color:var(--crit);border-color:transparent}.pill.muted{background:#8794a029;color:var(--offline);border-color:transparent}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th{text-align:left;padding:12px 14px;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap}table.data td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}table.data tbody tr:last-child td{border-bottom:none}table.data tbody tr:hover{background:var(--bg)}table.data tr.clickable{cursor:pointer}.cell-mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.cell-strong{font-weight:600}.empty-state{padding:48px 20px;text-align:center;color:var(--muted);font-size:14px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all .15s;white-space:nowrap}.btn:hover{border-color:var(--primary);color:var(--primary)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn:disabled:hover{border-color:var(--border);color:var(--text)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}.btn-danger{background:var(--crit);color:#fff;border-color:var(--crit)}.btn-danger:hover{background:#b93a2e;border-color:#b93a2e;color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.btn-full{width:100%;justify-content:center;padding:11px}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:var(--bg);border-color:transparent;color:var(--text)}.btn-group{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.btn-group button{background:var(--surface);border:none;cursor:pointer;padding:7px 14px;font-size:12px;font-weight:500;font-family:var(--font);color:var(--muted);border-right:1px solid var(--border);transition:all .15s}.btn-group button:last-child{border-right:none}.btn-group button:hover{background:var(--bg);color:var(--text)}.btn-group button.active{background:var(--primary);color:#fff}.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.toolbar .spacer{flex:1}.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.fg label{font-size:12px;font-weight:500;color:var(--muted)}.fg input,.fg select,.fg textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:9px 11px;color:var(--text);font-size:14px;font-family:var(--font);outline:none;width:100%;transition:border-color .15s}.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--primary)}.fg textarea{resize:vertical;min-height:72px}.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.fg-hint{font-size:11px;color:var(--muted)}.checkbox-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:14px;cursor:pointer}.checkbox-row input{margin-top:2px;width:16px;height:16px;flex-shrink:0;cursor:pointer}.checkbox-row span{font-size:13px;color:var(--text)}.field-select,.field-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 11px;color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s}.field-select:focus,.field-input:focus{border-color:var(--primary)}.form-error{background:#d6493b1a;color:var(--crit);border:1px solid rgba(214,73,59,.3);border-radius:var(--radius);padding:9px 12px;font-size:13px;margin-bottom:14px}.form-ok{background:#2e9e6b1a;color:var(--ok);border:1px solid rgba(46,158,107,.3);border-radius:var(--radius);padding:9px 12px;font-size:13px;margin-bottom:14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f2d3a73;z-index:3000;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:520px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden}.modal.wide{width:640px}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-title{font-size:16px;font-weight:600}.modal-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:22px;line-height:1;padding:0 4px}.modal-close:hover{color:var(--text)}.modal-body{padding:20px;overflow-y:auto}.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.legal-html{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;font-size:13px;line-height:1.6;color:var(--text);max-height:320px;overflow-y:auto;margin-bottom:14px}.legal-html p{margin:0 0 10px}.legal-html p:last-child{margin-bottom:0}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(900px 500px at 50% -10%,rgba(59,166,217,.14),transparent 60%),var(--bg)}.login-card{width:400px;max-width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px 28px}.login-brand{text-align:center;margin-bottom:24px}.login-brand .logo{font-size:26px;justify-content:center}.login-brand p{margin:8px 0 0;color:var(--muted);font-size:13px}.toast-stack{position:fixed;bottom:20px;right:20px;z-index:4000;display:flex;flex-direction:column;gap:8px;max-width:360px}.toast{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:12px 14px;font-size:13px;color:var(--text)}.toast.ok{border-left-color:var(--ok)}.toast.warn{border-left-color:var(--warn)}.toast.crit{border-left-color:var(--crit)}.muted{color:var(--muted)}.text-ok{color:var(--ok)}.text-warn{color:var(--warn)}.text-crit{color:var(--crit)}.text-offline{color:var(--offline)}.section-gap{margin-top:28px}.spinner-inline{color:var(--muted);font-size:13px;padding:40px;text-align:center}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:18px}.chart-card h3{display:flex;align-items:center;justify-content:space-between;gap:12px}@media(max-width:700px){.burger-btn{display:flex;order:-1}.topbar{padding:0 14px;gap:10px}.topbar-nav{position:fixed;top:56px;left:0;bottom:0;width:260px;background:var(--surface);border-right:1px solid var(--border);flex-direction:column;align-items:stretch;gap:2px;padding:12px;margin-left:0;z-index:1500;transform:translate(-110%);transition:transform .22s ease;box-shadow:var(--shadow-lg);overflow-y:auto}.topbar-nav.open{transform:translate(0)}.topbar-nav .nav-btn{width:100%;justify-content:flex-start;padding:11px 12px;font-size:14px}.topbar-nav .dropdown{width:100%}.topbar-nav .dropdown-trigger{width:100%;justify-content:flex-start}.topbar-nav .dropdown-menu{position:static;box-shadow:none;border:none;padding:0 0 0 12px;min-width:auto}.nav-backdrop{display:block}.main-content{padding:18px 14px 40px}.user-name-text{display:none}.impersonate-select{max-width:150px}.fg-row{grid-template-columns:1fr}}
