:root{--bg: #f3f7fb;--sidebar: #0b2230;--sidebar-2: #0f3140;--surface: #ffffff;--surface-soft: #f8fbfd;--surface-blue: #edf8fc;--line: #d8e5ed;--line-strong: #bdd0dc;--text: #172330;--muted: #65798a;--cyan: #00a8c8;--blue: #2563eb;--green: #1f9d63;--amber: #d88a00;--red: #e5484d;--shadow: 0 18px 38px rgba(28, 57, 75, .12);font-family:Inter,Segoe UI,Arial,sans-serif}*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;min-width:1180px;min-height:100vh;color:var(--text);background:var(--bg)}button,input{font:inherit}button{cursor:pointer}.portal{min-height:100vh;display:grid;grid-template-columns:282px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;padding:22px 18px;color:#d9f5fb;background:linear-gradient(180deg,rgba(0,168,200,.13),transparent 34%),var(--sidebar);display:flex;flex-direction:column;gap:20px}.sidebar-brand{display:flex;align-items:center;gap:13px;padding:8px 8px 18px;border-bottom:1px solid rgba(202,239,248,.16)}.brand-icon{width:46px;height:46px;display:grid;place-items:center;color:#38ddf1;border:1px solid rgba(56,221,241,.35);background:#00a8c824;border-radius:8px}.sidebar-brand strong,.sidebar-brand span{display:block}.sidebar-brand strong{font-size:17px;letter-spacing:0}.sidebar-brand span{margin-top:3px;font-size:12px;color:#94bac7}.side-nav{display:grid;gap:6px}.side-nav button{min-height:44px;display:flex;align-items:center;gap:11px;padding:0 13px;color:#bed9e2;background:transparent;border:1px solid transparent;border-radius:7px;text-align:left;transition:background .16s ease,border-color .16s ease,color .16s ease}.side-nav button:hover,.side-nav button.active{color:#fff;background:var(--sidebar-2);border-color:#4bd7ed52}.side-nav button.active{box-shadow:inset 3px 0 0 var(--cyan)}.sidebar-footer{margin-top:auto;padding:14px;background:#ffffff0f;border:1px solid rgba(202,239,248,.12);border-radius:8px}.sidebar-footer span,.sidebar-footer small{display:block;color:#95bac7;font-size:12px}.sidebar-footer strong{display:block;margin:6px 0;font-size:14px;color:#fff}.workspace{min-width:0;padding:20px 24px 32px}.topbar-portal{min-height:86px;display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:18px;padding:18px 20px;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 24px #1c394b14}.topbar-portal h1{margin:0 0 5px;font-size:24px;line-height:1.1;letter-spacing:0}.topbar-portal p{margin:0;color:var(--muted);font-size:14px;max-width:760px}.topbar-actions{display:flex;align-items:center;gap:9px}.search-box{width:330px;height:42px;display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--surface-soft);border:1px solid var(--line);border-radius:7px;color:var(--muted)}.search-box input{width:100%;border:0;outline:0;background:transparent;color:var(--text);font-size:13px}.topbar-actions button,.page-header button,.toolbar-row button,.button-row button,.action-stack button,.form-stack button{height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 13px;color:var(--text);background:var(--surface);border:1px solid var(--line-strong);border-radius:7px;font-weight:700;font-size:13px}.topbar-actions button:hover,.page-header button:hover,.toolbar-row button:hover,.button-row button:hover,.action-stack button:hover,.form-stack button:hover{border-color:var(--cyan);color:#006f86}.topbar-actions .primary,.button-row .primary,.form-stack .primary{color:#052532;background:#3edbe8;border-color:#3edbe8}.module-shell{display:grid;gap:18px}.page-grid{display:grid;grid-template-columns:minmax(0,1fr) 352px;gap:18px;align-items:start}.overview-layout{grid-template-columns:minmax(0,1fr) 340px}.main-column,.right-column{min-width:0;display:grid;gap:16px;align-content:start}.page-header,.panel,.table-card,.kanban section{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 24px #1c394b0f}.page-header{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 20px}.page-header h2{margin:0;font-size:26px;line-height:1.15;letter-spacing:0}.page-header p{margin:7px 0 0;color:var(--muted);font-size:14px;line-height:1.45}.panel{min-width:0;padding:18px 20px}.panel-title{display:flex;align-items:center;gap:9px;margin-bottom:16px;color:#087c93}.panel-title h3{margin:0;color:var(--text);font-size:16px;line-height:1.2}.kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi{min-height:104px;display:grid;align-content:center;gap:8px;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 22px #1c394b0f}.kpi svg{color:var(--cyan)}.kpi span{color:var(--muted);font-size:13px}.kpi strong{font-size:31px;line-height:1}.kpi.danger strong,.priority.p1{color:var(--red)}.kpi.warn strong,.priority.p2{color:var(--amber)}.kpi.info strong,.priority.p3{color:var(--blue)}.content-grid.two{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(360px,.65fr);gap:16px}.ops-map{position:relative;min-height:390px;overflow:hidden;background:linear-gradient(90deg,rgba(15,77,93,.06) 1px,transparent 1px),linear-gradient(0deg,rgba(15,77,93,.06) 1px,transparent 1px),linear-gradient(135deg,#f8fcff,#e8f6fb 54%,#eef7f1);background-size:56px 56px,56px 56px,auto;border:1px solid var(--line);border-radius:7px}.river-line{position:absolute;left:-8%;top:52%;width:122%;height:54px;transform:rotate(-9deg);background:linear-gradient(90deg,#68d8ec,#208af0);border-radius:999px;box-shadow:0 0 0 18px #4cb2db2e}.risk-area{position:absolute;left:45%;top:34%;width:210px;height:150px;background:#e5484d21;border:1px dashed rgba(229,72,77,.8);border-radius:8px}.map-pin{position:absolute;width:72px;height:34px;color:#fff;border:2px solid #ffffff;border-radius:999px;font-size:12px;font-weight:800;box-shadow:0 9px 20px #14324638}.map-pin.critical,.node-tile.alert,.station-card.critical{background:var(--red)}.map-pin.warning,.map-pin.watch,.node-tile.watch,.station-card.warning,.station-card.watch{background:var(--amber)}.map-pin.normal,.node-tile.normal,.station-card.normal{background:var(--green)}.forecast-chart{height:220px;display:flex;align-items:end;gap:9px;padding:14px 12px 0;background:linear-gradient(0deg,var(--line) 1px,transparent 1px),var(--surface-soft);background-size:100% 44px;border:1px solid var(--line);border-radius:7px}.forecast-chart button{flex:1;min-height:22px;border:0;border-radius:5px 5px 0 0;background:linear-gradient(180deg,#4adfeb,#228cf2);transition:transform .14s ease,filter .14s ease}.forecast-chart button:hover{transform:translateY(-4px);filter:brightness(1.04)}.compact-list,.alert-list,.action-stack,.checklist,.form-stack{display:grid;gap:10px}.info-row{min-height:42px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--surface-soft);border:1px solid var(--line);border-radius:7px}.info-row span{color:var(--muted);font-size:13px}.info-row strong{text-align:right;font-size:13px}.alert-list button{min-height:66px;display:grid;grid-template-columns:44px 1fr;gap:10px;align-items:center;padding:10px;background:var(--surface-soft);border:1px solid var(--line);border-radius:7px;text-align:left}.alert-list button:hover{border-color:var(--cyan);background:#edfafd}.alert-list strong,.alert-list span{display:block}.alert-list span{margin-top:3px;color:var(--muted);font-size:12px}.action-stack button{width:100%;justify-content:flex-start;background:var(--surface-soft)}.toolbar-row{display:flex;gap:8px}.toolbar-row button{background:var(--surface)}.toolbar-row button.active{color:#05303a;background:#dffbff;border-color:var(--cyan)}.table-card{overflow:auto}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:13px 15px;border-bottom:1px solid var(--line);text-align:left;font-size:13px;white-space:nowrap}th{color:#526777;background:var(--surface-soft);font-size:12px;text-transform:uppercase;letter-spacing:0}tbody tr{transition:background .14s ease}tbody tr:hover,tbody tr.selected{background:#e9f9fc}.small-table{max-height:430px}.priority{min-width:34px;display:inline-grid;place-items:center;padding:4px 8px;border-radius:999px;background:#f1f6f9;font-weight:800;font-size:12px}.detail-card{padding:14px;background:var(--surface-soft);border:1px solid var(--line);border-radius:7px}.detail-card span{color:var(--muted);font-size:12px}.detail-card h3{margin:8px 0;font-size:20px}.detail-card p{margin:0 0 12px;color:#405566;line-height:1.45}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.button-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.checklist div{min-height:42px;display:flex;align-items:center;gap:9px;padding:10px 12px;background:var(--surface-soft);border:1px solid var(--line);border-radius:7px}.checklist svg{color:var(--green);flex:0 0 auto}.checklist span{font-size:13px;color:#334b5d}.station-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.station-card{min-height:144px;display:grid;gap:12px;padding:16px;color:#fff;border:0;border-radius:8px;text-align:left;box-shadow:var(--shadow)}.station-card strong,.station-card span,.station-card em{display:block}.station-card strong{font-size:18px}.station-card span{margin-top:4px;color:#ffffffd4;font-size:13px}.station-card em{justify-self:start;padding:5px 10px;color:#09212a;background:#ffffffd6;border-radius:999px;font-style:normal;font-weight:800;font-size:12px}.station-values{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.station-values span{margin:0;padding:9px;background:#ffffff26;border:1px solid rgba(255,255,255,.22);border-radius:6px;color:#fff;font-weight:800;text-align:center}.node-board{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.node-tile{min-height:100px;display:grid;gap:4px;align-content:center;padding:12px;color:#fff;border:0;border-radius:8px;text-align:left;box-shadow:0 9px 20px #1b364b1f}.node-tile strong{font-size:20px}.node-tile span{font-size:13px;color:#ffffffdb}.node-tile em{margin-top:4px;font-style:normal;font-size:22px;font-weight:900}.video-workspace{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:14px}.video-player{padding:14px;background:#0d1f28;border-radius:8px;box-shadow:var(--shadow)}.video-scene-work{position:relative;height:472px;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.13),transparent 34%),linear-gradient(120deg,#425766,#263e4d 44%,#132832);border:1px solid rgba(255,255,255,.12);border-radius:7px}.video-scene-work:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0 1px,transparent 1px 5px),radial-gradient(circle at 20% 20%,rgba(255,255,255,.14),transparent 18%);opacity:.65}.road{position:absolute;left:-5%;bottom:108px;width:112%;height:98px;transform:rotate(-3deg);background:#4f5f67;border-top:8px solid rgba(255,255,255,.35);border-bottom:8px solid rgba(255,255,255,.18)}.bridge{position:absolute;left:18%;right:10%;bottom:175px;height:45px;background:#e1e5e2c7;box-shadow:90px 55px #d2dedbb3,310px 53px #d2dedbb3}.water{position:absolute;left:-4%;right:-4%;bottom:0;height:190px;background:repeating-linear-gradient(0deg,rgba(255,255,255,.12) 0 2px,transparent 2px 16px),linear-gradient(180deg,#3ce1e8d9,#146d94);animation:waterShift 6s linear infinite}.video-scene-work.detected .water{height:238px}.threshold{position:absolute;left:0;right:0;bottom:224px;padding-right:20px;border-top:3px dashed #ff5776;color:#fff;font-weight:800;text-align:right;text-shadow:0 1px 3px rgba(0,0,0,.45)}.ai-box{position:absolute;left:28%;bottom:210px;width:250px;height:118px;display:grid;place-items:start center;padding-top:11px;color:#051f29;background:#3edbe824;border:3px solid #ffd05a;font-weight:900}.osd{position:absolute;left:18px;right:18px;bottom:18px;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;color:#fff;background:#061821c7;border-radius:7px}.osd strong,.osd span{position:relative;z-index:1}.play{position:absolute;left:18px;top:18px;width:48px;height:48px;display:grid;place-items:center;color:#fff;background:#061821ad;border:1px solid rgba(255,255,255,.28);border-radius:999px}.camera-grid{display:grid;gap:10px;align-content:start}.camera-grid button{min-height:82px;display:grid;grid-template-columns:20px 1fr;gap:4px 9px;align-items:center;padding:12px;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:7px;text-align:left}.camera-grid button.active{border-color:var(--cyan);background:#e7fbff}.camera-grid strong{font-size:14px}.camera-grid span,.camera-grid em{grid-column:2;color:var(--muted);font-style:normal;font-size:12px}.form-stack label{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:700}.form-stack input{height:42px;padding:0 11px;color:var(--text);background:var(--surface-soft);border:1px solid var(--line);border-radius:7px}.kanban{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.kanban section{min-height:500px;padding:13px}.kanban h3{margin:0 0 12px;font-size:15px}.work-card{width:100%;min-height:134px;display:grid;gap:7px;margin-bottom:10px;padding:13px;background:var(--surface-soft);border:1px solid var(--line);border-left:4px solid var(--cyan);border-radius:7px;text-align:left}.work-card:hover{background:#e9f9fc}.work-card span,.work-card small,.work-card em{color:var(--muted);font-size:12px;font-style:normal}.work-card strong{font-size:15px;line-height:1.25}.report-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.report-card{min-height:142px;display:grid;gap:8px;align-content:center;padding:18px;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:8px;text-align:left;box-shadow:0 10px 22px #1c394b0f}.report-card:hover{border-color:var(--cyan);background:#f1fcff}.report-card svg{color:var(--cyan)}.report-card strong,.report-card span,.report-card em{display:block}.report-card span,.report-card em{color:var(--muted);font-size:13px;font-style:normal}@keyframes waterShift{0%{background-position:0 0,0 0}to{background-position:0 48px,0 0}}@media(max-width:1320px){.portal{grid-template-columns:246px minmax(0,1fr)}.topbar-portal{align-items:flex-start;flex-direction:column}.search-box{width:300px}.content-grid.two,.video-workspace{grid-template-columns:1fr}.camera-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
