:root{color-scheme:dark;--bg: #07111f;--bg-soft: #0d1830;--panel: rgba(11, 22, 40, .8);--panel-strong: rgba(15, 28, 49, .94);--line: rgba(132, 167, 255, .16);--ink: #edf3ff;--muted: #91a2c4;--accent: #7dd3fc;--accent-soft: #162846;--shadow: 0 28px 100px rgba(1, 7, 18, .55)}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Helvetica Neue,sans-serif;color:var(--ink);background:radial-gradient(circle at top left,rgba(90,118,255,.18),transparent 24%),radial-gradient(circle at top right,rgba(0,214,201,.12),transparent 22%),linear-gradient(180deg,#081121,#09162a 35%,#07111f);min-height:100vh}button,select,input{font:inherit}#root{min-height:100vh}.app-shell{position:relative;padding:28px}.top-shell{margin-bottom:20px}.hero-bar{position:relative;display:flex;justify-content:space-between;align-items:flex-end;gap:12px;padding:14px 20px 12px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0c1628eb;border:1px solid rgba(126,165,255,.12);border-bottom:0;border-radius:24px 24px 0 0;box-shadow:var(--shadow)}.hero-bar:before{content:"";position:absolute;inset:0 0 auto;height:3px;background:linear-gradient(90deg,#ff5f87,#ff9d4d,#ffe06d,#53e0a1,#7dd3fc);border-radius:24px 24px 0 0}.backdrop{position:fixed;inset:0;background-image:linear-gradient(rgba(115,153,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(115,153,255,.06) 1px,transparent 1px);background-size:36px 36px;pointer-events:none}.control-bar,.map-panel,.detail-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--panel);border:1px solid rgba(126,165,255,.12);box-shadow:var(--shadow)}.eyebrow{margin:0 0 10px;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;color:var(--accent)}h1,h2,h3,p{margin:0}h1{max-width:12ch;font-size:clamp(2.2rem,5vw,4.4rem);line-height:.96}.lede{margin-top:14px;max-width:60ch;color:var(--muted);line-height:1.6}.detail-item{padding:16px;border-radius:18px;background:var(--panel-strong);border:1px solid rgba(102,140,230,.12)}.detail-item span{display:block;margin-bottom:8px;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.detail-item strong{font-size:1.08rem}.control-bar{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;margin-bottom:0;padding:8px 20px 12px;border-radius:0 0 24px 24px;background:#0c1628eb}.control-copy h1{max-width:none;font-size:clamp(1.9rem,3vw,2.8rem)}.control-copy .lede{margin-top:8px;max-width:44ch}.control-bar label{display:grid;gap:8px;color:var(--muted)}.control-field{align-self:stretch}.toolbar-spacer{min-width:8px}.hero-stats{display:flex;gap:8px;flex-wrap:wrap}.metric-pill{min-width:118px;padding:8px 10px;border-radius:8px;border:1px solid rgba(126,165,255,.12);background:#0d1830e6}.metric-pill strong{display:block;color:#f4d78b;font-size:.95rem}.metric-pill span{display:block;margin-top:2px;color:var(--muted);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em}.timeline-card{display:grid;gap:12px;padding:0;border-radius:0;background:transparent;border:0}.timeline-heading,.timeline-actions,.timeline-presets{display:flex;align-items:center;justify-content:space-between;gap:10px}.timeline-label{display:block;margin-bottom:4px;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.timeline-heading strong{display:block;font-size:1.15rem;text-transform:capitalize}.timeline-range{color:var(--muted);font-size:.88rem;white-space:nowrap}.timeline-warning{padding:10px 12px;border-radius:14px;background:#ff9d4d1f;border:1px solid rgba(255,157,77,.26);color:#ffd7b2;font-size:.88rem;line-height:1.45}.timeline-step,.timeline-play,.timeline-presets button{border:1px solid rgba(125,159,245,.16);color:var(--ink);background:#101f3aeb;border-radius:999px;padding:9px 12px;cursor:pointer}.timeline-play{background:linear-gradient(135deg,#173254,#224875)}.timeline-step:disabled{cursor:default;opacity:.45}.timeline-slider{gap:0}.timeline-slider input[type=range]{width:100%;accent-color:var(--accent)}.timeline-marks{position:relative;min-height:18px;color:var(--muted);font-size:.72rem}.timeline-marks span{position:absolute;transform:translate(-50%);white-space:nowrap}.timeline-presets{justify-content:flex-start;flex-wrap:wrap}.timeline-presets button{padding:7px 10px;font-size:.84rem}.timeline-presets button.is-active{border-color:#7dd3fc80;background:#1f4470f2}.control-bar select{min-width:220px;color:var(--ink);border:1px solid rgba(125,159,245,.16);background:#091427e6;padding:10px 12px;border-radius:12px}.toggle{display:flex!important;align-items:center;gap:10px}.reset-view,.hot-list button{border:0;border-radius:999px;background:linear-gradient(135deg,#173254,#224875);color:#eef6ff;padding:10px 14px;cursor:pointer}.layout{display:grid;grid-template-columns:minmax(0,1.75fr) minmax(360px,.95fr);gap:20px;align-items:start}.map-panel{border-radius:30px;padding:18px 18px 14px}.panel-heading{display:flex;align-items:start;justify-content:space-between;gap:16px;margin-bottom:18px}.panel-badges{display:flex;gap:6px;flex-wrap:wrap}.panel-badge{padding:4px 8px;border-radius:999px;border:1px solid rgba(126,165,255,.12);color:var(--muted);background:#091427d9;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em}.map-stage{position:relative}.map-controls{position:absolute;left:14px;bottom:14px;z-index:5;display:flex;flex-direction:column;gap:6px}.map-control{min-width:34px;height:34px;padding:0 10px;border-radius:8px;border:1px solid rgba(126,165,255,.14);background:#0c1628f0;color:var(--ink);cursor:pointer}.map-control-fit{height:auto;padding:8px 10px;font-size:.72rem}.panel-heading p{margin-top:6px;color:var(--muted)}.legend{display:flex;gap:10px;flex-wrap:wrap;font-size:.76rem;color:var(--muted)}.legend div{display:flex;align-items:center;gap:8px}.legend i{display:inline-block;width:18px;height:8px;border-radius:999px}.network-map{width:100%;aspect-ratio:1.2 / 1;border-radius:24px;cursor:grab;background:radial-gradient(circle at 50% 40%,rgba(70,103,199,.14),transparent 32%),linear-gradient(180deg,#091427db,#040a16fa)}.network-map.is-dragging{cursor:grabbing}.map-ocean{fill:#050c19}.map-frame{fill:#070f1e2e;stroke:#6e92eb14;stroke-width:1.5}.country-fill{fill:#1a2d4ae6}.country-outline{fill:none;stroke:#a0c2ff6b;stroke-width:2}.map-note{margin-top:12px;color:var(--muted);font-size:.92rem;line-height:1.55}.route-hit{cursor:pointer;transition:opacity .14s ease}.node-dot{fill:#dff7ff;stroke:#5793fff2;stroke-width:2}.node-label{fill:#f0f5ff;font-size:11px;letter-spacing:.02em;paint-order:stroke;stroke:#050c19eb;stroke-width:3px;stroke-linejoin:round}.side-panel{display:grid;gap:14px;position:sticky;top:24px}.detail-card{border-radius:28px;padding:18px}.detail-card h3{margin-bottom:14px;font-size:.95rem}.detail-summary{padding-bottom:14px}.timeline-panel{padding-bottom:16px}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.summary-grid{grid-template-columns:1fr}.history-empty{display:grid;gap:16px}.history-chart{display:grid;gap:12px}.inspector-card,.route-inspector{display:grid;gap:14px}.inspector-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.inspector-subtitle{margin-top:4px;color:var(--muted);font-size:.86rem;line-height:1.4}.inspector-chip{padding:5px 8px;border-radius:999px;background:#0d1830e6;border:1px solid rgba(126,165,255,.12);color:#f4d78b;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.inspector-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.history-title{font-size:.96rem;color:var(--ink)}.history-legend{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.86rem}.history-legend span{display:inline-flex;align-items:center;gap:8px}.history-legend i{width:18px;height:3px;border-radius:999px;display:inline-block}.history-flow{background:#7dd3fc}.history-capacity{background:#ff9d4d}.history-svg{width:100%;overflow:visible}.history-frame{fill:#081223c7;stroke:#7d9ff51f}.history-grid{stroke:#91a2c41f;stroke-dasharray:4 6}.history-flow-line,.history-capacity-line{fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-width:3}.history-flow-line{stroke:#7dd3fc}.history-capacity-line{stroke:#ff9d4d;opacity:.9}.history-marker{stroke:#edf3ff38;stroke-dasharray:4 5}.history-marker-dot{fill:#7dd3fc;stroke:#f4f8ff;stroke-width:2}.history-axis{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:.78rem}.history-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.empty-copy{color:var(--muted);line-height:1.6}.hot-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.hot-list button{width:100%;display:flex;align-items:center;justify-content:space-between;text-align:left;background:var(--panel-strong);color:var(--ink);border:1px solid rgba(102,140,230,.12);border-radius:18px}.hot-list strong{color:#ff9ab0}.compact-toggle{min-width:210px;align-self:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:1080px){.layout{grid-template-columns:1fr}.side-panel{position:static;top:auto}.hero-bar{flex-direction:column;align-items:stretch}.control-bar{grid-template-columns:1fr}.timeline-actions{flex-wrap:wrap}.history-stats,.inspector-stats{grid-template-columns:1fr}}@media(max-width:720px){.app-shell{padding:16px}.control-bar{align-items:stretch}.hero-stats,.panel-badges,.legend{justify-content:flex-start}.timeline-heading,.timeline-actions{align-items:stretch;flex-direction:column}.timeline-range{white-space:normal}.reset-view{width:100%}.detail-grid{grid-template-columns:1fr}.inspector-head{flex-direction:column}}
