@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&family=UnifrakturMaguntia&display=swap";:root{--gold:#c8960a;--gold-bright:#e8b420;--gold-dim:#7a5c08;--gold-glow:#c8960a59;--ember:#c84010;--ember-dim:#7a2808;--ink:#080604;--ink-mid:#120e08;--ink-light:#1e1608;--parchment:#d9c090;--parchment-dim:#8a7050;--text-main:#c8a870;--text-dim:#6a5535;--text-faint:#3a2e18;--held:#1a603099;--contested:#8b1a1a99;--fallen:#080604d9}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--ink);width:100%;height:100%;color:var(--text-main);cursor:default;-webkit-user-select:none;user-select:none;font-family:Crimson Pro,Georgia,serif;overflow:hidden}.screen{opacity:0;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;transition:opacity 1.2s;display:flex;position:absolute;inset:0}.screen.active{opacity:1;pointer-events:all}#screen-landing{background:var(--ink);overflow:hidden}.landing-bg-img{object-fit:cover;object-position:center;opacity:0;filter:brightness(.25)sepia(.5);width:100%;height:100%;transition:opacity 3s;position:absolute;inset:0}.landing-bg-img.visible{opacity:1}.landing-vignette{pointer-events:none;background:radial-gradient(#0000 0%,#08060480 50%,#080604f2 100%);position:absolute;inset:0}.landing-content{z-index:2;flex-direction:column;align-items:center;gap:0;display:flex;position:relative}.landing-eyebrow{letter-spacing:.6em;color:var(--gold-dim);text-transform:uppercase;opacity:0;margin-bottom:16px;font-family:Cinzel,serif;font-size:10px;transition:opacity 1.5s,transform 1.5s;transform:translateY(8px)}.landing-eyebrow.visible{opacity:1;transform:translateY(0)}.landing-title{color:var(--gold);letter-spacing:.25em;text-align:center;text-shadow:0 0 40px var(--gold-glow), 0 0 80px #c8960a26;opacity:0;font-family:Cinzel,serif;font-size:clamp(36px,7vw,72px);font-weight:900;line-height:1;transition:opacity 2s .5s,transform 2s .5s;transform:translateY(16px)}.landing-title.visible{opacity:1;transform:translateY(0)}.landing-subtitle{color:var(--text-dim);letter-spacing:.3em;opacity:0;margin-top:12px;font-family:Crimson Pro,serif;font-size:clamp(14px,2vw,18px);font-style:italic;transition:opacity 2s 1.5s}.landing-subtitle.visible{opacity:1}.landing-rule{opacity:0;align-items:center;gap:16px;width:320px;margin:32px 0;transition:opacity 2s 2s;display:flex}.landing-rule.visible{opacity:1}.landing-rule-line{background:linear-gradient(to right, transparent, var(--gold-dim), transparent);flex:1;height:1px}.landing-rule-glyph{color:var(--gold-dim);font-size:12px}.landing-enter{letter-spacing:.5em;text-transform:uppercase;color:var(--text-faint);border:1px solid var(--text-faint);cursor:pointer;opacity:0;background:0 0;padding:14px 40px;font-family:Cinzel,serif;font-size:11px;font-weight:600;transition:opacity 2s 2.5s,color .4s,border-color .4s,box-shadow .4s,transform .4s}.landing-enter.visible{opacity:1}.landing-enter:hover{color:var(--gold);border-color:var(--gold-dim);box-shadow:0 0 20px var(--gold-glow), inset 0 0 20px #c8960a0d;transform:translateY(-1px)}.ember{background:var(--gold);pointer-events:none;opacity:0;border-radius:50%;width:2px;height:2px;animation:linear infinite ember-float;position:absolute}@keyframes ember-float{0%{opacity:0;transform:translateY(0)translate(0)}10%{opacity:.8}90%{opacity:.4}to{transform:translateY(-120px) translateX(var(--dx,20px));opacity:0}}#transition-overlay{background:var(--ink);z-index:100;opacity:0;pointer-events:none;transition:opacity .8s;position:fixed;inset:0}#transition-overlay.active{opacity:1;pointer-events:all}#screen-hub{background:var(--ink-mid);flex-direction:row;justify-content:flex-start;align-items:stretch}.sidebar{background:var(--ink);border-right:1px solid var(--text-faint);flex-direction:column;flex-shrink:0;width:220px;padding:0;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--text-faint);padding:24px 20px 20px}.sidebar-title{letter-spacing:.2em;color:var(--gold);text-shadow:0 0 12px var(--gold-glow);font-family:Cinzel,serif;font-size:13px;font-weight:700}.sidebar-sub{color:var(--text-faint);letter-spacing:.1em;margin-top:2px;font-family:Crimson Pro,serif;font-size:11px;font-style:italic}.sidebar-nav{flex-direction:column;flex:1;padding:12px 0;display:flex;overflow-y:auto}.nav-section-label{letter-spacing:.35em;color:var(--text-faint);text-transform:uppercase;padding:12px 20px 6px;font-family:Cinzel,serif;font-size:8px}.nav-btn{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 20px;transition:background .2s;display:flex;position:relative}.nav-btn:hover{background:#c8960a0d}.nav-btn.active{background:#c8960a14}.nav-btn.active:before{content:"";background:var(--gold);width:2px;box-shadow:0 0 8px var(--gold-glow);position:absolute;top:0;bottom:0;left:0}.nav-icon{text-align:center;width:18px;color:var(--text-dim);flex-shrink:0;font-size:14px}.nav-btn.active .nav-icon{color:var(--gold)}.nav-label{letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase;font-family:Cinzel,serif;font-size:10px}.nav-btn.active .nav-label{color:var(--gold)}.nav-badge{background:var(--ember-dim);color:#fa8;letter-spacing:.1em;border-radius:2px;margin-left:auto;padding:2px 5px;font-family:Cinzel,serif;font-size:8px}.sidebar-footer{border-top:1px solid var(--text-faint);padding:16px 20px}.session-info{letter-spacing:.2em;color:var(--text-faint);font-family:Cinzel,serif;font-size:8px;line-height:1.8}.hub-main{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.hub-topbar{border-bottom:1px solid var(--text-faint);background:#08060466;flex-shrink:0;align-items:center;gap:16px;height:48px;padding:0 24px;display:flex}.topbar-title{letter-spacing:.3em;color:var(--text-dim);text-transform:uppercase;font-family:Cinzel,serif;font-size:11px}.topbar-status{letter-spacing:.2em;color:var(--text-faint);align-items:center;gap:6px;margin-left:auto;font-family:Cinzel,serif;font-size:8px;display:flex}.status-dot{background:#2a6040;border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot;box-shadow:0 0 6px #2a6040cc}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.hub-content{flex:1;position:relative;overflow:hidden}.tab-panel{opacity:0;pointer-events:none;transition:opacity .4s;position:absolute;inset:0;overflow-y:auto}.tab-panel.active{opacity:1;pointer-events:all}#tab-map{background:var(--ink-mid);overflow:hidden}.map-container{width:100%;height:100%;position:relative;overflow:hidden}.map-image{object-fit:cover;object-position:center;filter:brightness(.7)saturate(.8);width:100%;height:100%;transition:filter .5s;position:absolute;inset:0}.map-overlay{pointer-events:none;background:radial-gradient(#0000 30%,#0806044d 70%,#080604b3 100%);position:absolute;inset:0}.district-zone{cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex;position:absolute}.district-zone:hover .district-label{opacity:1}.district-zone:hover{transform:scale(1.05)}.district-label{letter-spacing:.2em;color:var(--gold);text-shadow:0 0 8px var(--gold-glow), 0 2px 4px #000c;text-align:center;opacity:.7;pointer-events:none;text-transform:uppercase;white-space:nowrap;font-family:Cinzel,serif;font-size:10px;line-height:1.4;transition:opacity .3s}.district-zone.held .district-label{color:#4aaa70}.district-zone.contested .district-label{color:#c64}.district-zone.fallen .district-label{color:#4a3a30}.district-zone.fallen:after{content:"";pointer-events:none;background:#080604b3;border-radius:50%;position:absolute;inset:-10px}.district-zone.contested:after{content:"";pointer-events:none;background:#64140a4d;border-radius:50%;animation:3s infinite contested-pulse;position:absolute;inset:-5px}@keyframes contested-pulse{0%,to{opacity:.5}50%{opacity:1}}.map-legend{border:1px solid var(--text-faint);background:#080604d9;flex-direction:column;gap:8px;padding:12px 16px;display:flex;position:absolute;bottom:20px;right:20px}.legend-item{letter-spacing:.2em;color:var(--text-dim);text-transform:uppercase;align-items:center;gap:8px;font-family:Cinzel,serif;font-size:8px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.legend-dot.held{background:#2a6040;box-shadow:0 0 6px #2a604099}.legend-dot.contested{background:#8b2a1a;box-shadow:0 0 6px #8b2a1a99}.legend-dot.fallen{background:#1a1208;border:1px solid #2a1a10}.district-info{border:1px solid var(--text-faint);border-left:2px solid var(--gold-dim);opacity:0;pointer-events:none;background:#080604eb;max-width:260px;padding:16px 20px;transition:opacity .3s,transform .3s;position:absolute;top:20px;left:20px;transform:translate(-8px)}.district-info.visible{opacity:1;transform:translate(0)}.district-info-name{letter-spacing:.2em;color:var(--gold);margin-bottom:4px;font-family:Cinzel,serif;font-size:12px}.district-info-status{letter-spacing:.25em;text-transform:uppercase;margin-bottom:10px;font-family:Cinzel,serif;font-size:8px}.district-info-status.held{color:#4aaa70}.district-info-status.contested{color:#c64}.district-info-status.fallen{color:#4a3a30}.district-info-desc{color:var(--text-dim);font-size:12px;font-style:italic;line-height:1.6}.tab-placeholder{flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;display:flex}.tab-placeholder-icon{opacity:.2;font-size:32px}.tab-placeholder-title{letter-spacing:.4em;color:var(--text-faint);text-transform:uppercase;font-family:Cinzel,serif;font-size:12px}.tab-placeholder-sub{color:var(--text-faint);opacity:.6;font-size:13px;font-style:italic}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--ink)}::-webkit-scrollbar-thumb{background:var(--text-faint);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.tooltip{border:1px solid var(--text-faint);letter-spacing:.2em;color:var(--text-dim);pointer-events:none;opacity:0;z-index:50;white-space:nowrap;background:#080604f2;padding:8px 12px;font-family:Cinzel,serif;font-size:9px;transition:opacity .2s;position:fixed}.tooltip.visible{opacity:1}
