:root{color-scheme:dark;--bg:#0a1118;--surface:#0f1720;--panel:#162330;--panel-hover:#1a2a3a;--muted:#8aa3b8;--text:#eff6fb;--accent:#f59e0b;--accent-dim:rgba(245,158,11,0.12);--accent-border:rgba(245,158,11,0.35);--line:rgba(138,163,184,0.15);--line-strong:rgba(138,163,184,0.28);--danger:#ef4444;--success:#22c55e;--info:#3b82f6;--faction-1:#6b8cae;--faction-2:#5a9e6f;--faction-3:#4a9e9e;--sidebar-w:220px}*{box-sizing:border-box;margin:0}body{background:var(--bg);color:var(--text);font-family:IBM Plex Sans,Inter,system-ui,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}.app-layout{display:flex;min-height:100vh}.main-content{flex:1 1;min-width:0;padding:28px 32px 60px;margin-left:var(--sidebar-w)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:20px 12px;z-index:100}.sidebar-brand{gap:10px;padding:8px 12px 20px}.sidebar-brand,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--accent-dim);border:1px solid var(--accent-border);color:var(--accent);font-weight:800;font-size:13px;letter-spacing:-.5px}.sidebar-title{font-weight:700;font-size:15px;letter-spacing:-.3px}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted);font-size:14px;font-weight:500;transition:all .15s}.sidebar-link:hover{background:rgba(255,255,255,.04);color:var(--text)}.sidebar-link.is-active{background:var(--accent-dim);color:var(--accent);font-weight:600}.sidebar-footer{margin-top:auto;padding:12px}.lang-switch{display:flex;align-items:center;justify-content:center;width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.lang-switch:hover{background:rgba(255,255,255,.04);color:var(--text);border-color:var(--accent-border)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.page-title{font-size:22px;font-weight:700;letter-spacing:-.3px}.page-subtitle{color:var(--muted);font-size:13px;margin-top:2px}.panel{border:1px solid var(--line);border-radius:16px;background:var(--panel);padding:20px}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.grid-2{grid-template-columns:repeat(2,1fr);grid-gap:16px}.grid-2,.grid-3{display:grid;gap:16px}.grid-3{grid-template-columns:repeat(3,1fr);grid-gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px}.gap-20{gap:20px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:700}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600}.status-pill--active{background:rgba(34,197,94,.12);color:#86efac;border:1px solid rgba(34,197,94,.25)}.status-pill--phase{background:var(--accent-dim);color:#ffd89f;border:1px solid var(--accent-border)}.status-pill--dead{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}.metric{font-size:28px;font-weight:700;margin:4px 0 2px;letter-spacing:-.5px}.metric-sm{font-size:20px;font-weight:700;letter-spacing:-.3px}.metric-label{color:var(--muted);font-size:12px}.metric-bar{display:flex;align-items:center;gap:8px}.metric-bar-label{color:var(--muted);font-size:12px;min-width:80px;text-transform:capitalize}.metric-bar-track{flex:1 1;height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}.metric-bar-fill{height:100%;border-radius:3px;background:var(--accent);transition:width .3s ease}.metric-bar-value{font-size:12px;font-weight:600;min-width:32px;text-align:right;color:var(--muted)}.faction-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600}.faction-dot{width:8px;height:8px;border-radius:50%}.progress-bar{display:flex;align-items:center;gap:10px}.progress-track{flex:1 1;height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .3s}.progress-label{font-size:13px;font-weight:600;min-width:48px;text-align:right}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table td,.data-table th{padding:10px 12px;border-bottom:1px solid var(--line);font-size:13px}.data-table th{color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.sortable-th{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sortable-th:hover{color:var(--text)}.sort-arrow{font-size:10px;color:var(--accent)}.data-table tbody tr:hover{background:rgba(255,255,255,.02)}.morale-inline{display:inline-flex;align-items:center;gap:6px}.morale-bar-mini{width:40px;height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}.morale-bar-mini-fill{height:100%;border-radius:2px;transition:width .3s}.advance-btn-group{display:inline-flex;gap:6px}.advance-btn{display:inline-flex;align-items:center;padding:7px 14px;border-radius:8px;border:1px solid var(--line-strong);background:var(--panel);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.advance-btn:hover{background:var(--panel-hover)}.advance-btn--warn{border-color:var(--accent-border);background:var(--accent-dim);color:var(--accent)}.advance-btn--cancel{color:var(--muted)}.advance-btn--done{color:var(--success);border-color:rgba(34,197,94,.3);cursor:default}.advance-btn--error{color:var(--danger);border-color:rgba(239,68,68,.3);cursor:default}.event-feed{margin-top:8px}.event-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px}.event-tab{padding:5px 10px;border-radius:6px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:12px;font-weight:500;text-transform:capitalize;transition:all .15s}.event-tab:hover{color:var(--text);background:rgba(255,255,255,.03)}.event-tab.is-active{background:rgba(255,255,255,.06);color:var(--text);font-weight:600}.event-list-compact{display:flex;flex-direction:column;gap:2px;max-height:360px;overflow-y:auto}.event-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:12px}.event-row:hover{background:rgba(255,255,255,.02)}.event-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.event-type{font-weight:600;min-width:120px}.event-actor{color:var(--muted);min-width:80px}.event-target,.event-time{color:var(--muted);font-size:11px}.event-time{margin-left:auto;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.collapsible{border:1px solid var(--line);border-radius:12px;overflow:hidden}.collapsible-header{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border:none;background:transparent;color:var(--text);text-align:left}.collapsible-header:hover{background:rgba(255,255,255,.02)}.collapsible-arrow{font-size:10px;color:var(--muted)}.collapsible-body{padding:0 16px 16px}.objective-card{display:flex;flex-direction:column;gap:8px;padding:14px;border:1px solid var(--line);border-radius:12px;background:rgba(12,20,28,.4)}.objective-name{font-weight:600;font-size:13px}.objective-kind{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.siege-bar{height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}.siege-bar-fill{height:100%;border-radius:2px;background:var(--danger)}.agent-profile{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:12px;gap:12px}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-value{font-size:18px;font-weight:700;letter-spacing:-.3px}.stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.territory-map{position:relative;width:100%;min-height:500px}.territory-map svg{width:100%;height:100%}.map-layer-label{fill:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em}.map-node{cursor:pointer;transition:opacity .15s}.map-node:hover{opacity:.85}.map-tooltip{position:absolute;padding:10px 14px;border-radius:10px;background:var(--panel);border:1px solid var(--line-strong);box-shadow:0 8px 24px rgba(0,0,0,.5);font-size:12px;pointer-events:none;z-index:10;min-width:160px}.podium{display:grid;grid-template-columns:1fr 1.2fr 1fr;grid-gap:16px;gap:16px;align-items:end;margin-bottom:32px}.podium-card{border:1px solid var(--line);border-radius:16px;background:var(--panel);padding:20px;text-align:center}.podium-card--gold{border-color:rgba(245,158,11,.4);background:linear-gradient(180deg,rgba(245,158,11,.08) 0,var(--panel) 100%)}.podium-rank{font-size:32px;font-weight:800;color:var(--accent)}.podium-name{font-size:16px;font-weight:700;margin:8px 0 4px}.podium-score{color:var(--muted);font-size:13px}.replay-layout{display:grid;grid-template-columns:minmax(240px,280px) minmax(0,1fr);grid-gap:20px;gap:20px;align-items:start}.detail-stack,.timeline-panel{min-width:0}.detail-stack{display:grid;grid-gap:16px;gap:16px}.timeline-list{gap:6px;margin-top:12px}.timeline-link,.timeline-list{display:flex;flex-direction:column}.timeline-link{gap:4px;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:rgba(12,20,28,.35);font-size:12px;transition:all .15s}.timeline-link:hover{border-color:var(--line-strong)}.timeline-link.is-active{border-color:var(--accent-border);background:var(--accent-dim)}.timeline-head{display:flex;justify-content:space-between;font-weight:600}.timeline-copy,.timeline-meta{color:var(--muted);font-size:11px}.empty-state{color:var(--muted);text-align:center;padding:40px 20px;font-size:13px}.watch-container{position:fixed;inset:0;z-index:200;background:var(--bg);color:var(--text);overflow:hidden}.watch-connecting{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:var(--muted);font-size:14px}.watch-pulse{width:12px;height:12px;border-radius:50%;background:var(--accent);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.watch-topbar{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--line);flex-wrap:wrap}.watch-season-info{gap:10px}.watch-logo,.watch-season-info{display:flex;align-items:center}.watch-logo{justify-content:center;width:28px;height:28px;border-radius:6px;background:var(--accent-dim);border:1px solid var(--accent-border);color:var(--accent);font-weight:800;font-size:11px}.watch-title{font-weight:700;font-size:14px;letter-spacing:-.3px}.watch-phase-bar{display:flex;align-items:center;gap:12px;margin-left:auto}.watch-phase-tag{padding:4px 10px;border-radius:6px;background:var(--accent-dim);border:1px solid var(--accent-border);color:var(--accent);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.watch-phase-tag--final{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:#fca5a5}.watch-progress{display:flex;align-items:center;gap:8px}.watch-progress-track{width:100px;height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}.watch-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .5s ease}.watch-progress-label{font-size:12px;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.watch-status-dot{width:8px;height:8px;border-radius:50%;background:#555}.watch-status-dot--live{background:#22c55e;box-shadow:0 0 6px rgba(34,197,94,.5)}.watch-phase-detail{font-size:12px;color:var(--muted)}.watch-finalized{padding:4px 12px;border-radius:6px;background:rgba(239,68,68,.12);color:#fca5a5;font-size:12px;font-weight:600}.watch-main{display:grid;grid-template-columns:1fr 340px;grid-gap:0;gap:0;height:calc(100vh - 52px)}.watch-map-panel{padding:16px 20px;overflow-y:auto}.watch-map-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.watch-faction-legend{display:flex;gap:12px}.watch-layer{margin-bottom:16px}.watch-layer-label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.watch-territory-row{display:flex;gap:8px;flex-wrap:wrap}.watch-territory{flex:1 1;min-width:120px;max-width:200px;border:1px solid;border-radius:10px;overflow:hidden;background:rgba(12,20,28,.5);transition:border-color .3s}.watch-territory-header{display:flex;justify-content:space-between;align-items:center;padding:8px 10px}.watch-territory-name{font-size:12px;font-weight:600}.watch-territory-garrison{font-size:13px;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.watch-territory-faction{display:block;padding:2px 10px 6px;font-size:11px;font-weight:600}.watch-siege{padding:4px 10px 8px;display:flex;align-items:center;gap:6px}.watch-siege-bar{flex:1 1;height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}.watch-siege-fill{height:100%;background:var(--danger);border-radius:2px;transition:width .5s}.watch-siege-text{font-size:10px;color:var(--danger);font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.watch-movements{margin-top:12px;display:flex;flex-direction:column;gap:6px}.watch-movement-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;background:rgba(255,255,255,.02);font-size:12px}.watch-movement-status{margin-left:auto;color:var(--muted);font-size:11px}.watch-sidebar{border-left:1px solid var(--line);display:flex;flex-direction:column;overflow-y:auto;background:var(--surface)}.watch-leaderboard{padding:16px;border-bottom:1px solid var(--line)}.watch-agent-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}.watch-agent-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,.02);transition:background .15s}.watch-agent-card:hover{background:rgba(255,255,255,.04)}.watch-agent-card--dead{opacity:.4}.watch-agent-rank{font-size:18px;font-weight:800;min-width:24px;text-align:center}.watch-agent-info{flex:1 1;min-width:0}.watch-agent-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.watch-agent-meta{display:flex;gap:8px;font-size:11px;color:var(--muted);margin-top:2px}.watch-agent-stats{display:flex;gap:12px}.watch-stat{display:flex;flex-direction:column;align-items:center}.watch-stat-value{font-size:14px;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.watch-stat-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.watch-events{padding:16px;flex:1 1;overflow-y:auto}.watch-event-list{display:flex;flex-direction:column;gap:4px;margin-top:12px}.watch-event-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;font-size:12px}.watch-event-item:hover{background:rgba(255,255,255,.02)}.watch-event-type{font-weight:600;min-width:110px;color:var(--accent)}.watch-event-detail{color:var(--muted)}@media (max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.sidebar{display:none}.main-content{margin-left:0}.agent-profile,.grid-2,.grid-3,.grid-4,.podium,.replay-layout{grid-template-columns:1fr}}.table-link{color:var(--text);font-weight:600}.table-link:hover{color:var(--accent)}