:root{--bg-deepest:#04060b;--bg-deep:#090d15;--bg-surface:#0e1520;--bg-card:rgba(15,21,34,.82);--bg-elevated:#162236;--accent:#c8aa6e;--accent-strong:#f6d18b;--accent-rgb:200,170,110;--ally:#22c55e;--conflict:#ef4444;--complex:#a855f7;--text-primary:#f4efe2;--text-secondary:#c4b7a1;--text-muted:#8d8578;--border:rgba(255,255,255,.08);--border-strong:rgba(200,170,110,.22);--shadow-sm:0 8px 24px rgba(0,0,0,.18);--shadow-md:0 18px 40px rgba(0,0,0,.28);--shadow-lg:0 28px 80px rgba(0,0,0,.46);--font-heading:"Cinzel",serif;--font-body:"Manrope",sans-serif;--container-max:1360px;--section-pad:108px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg-deep)}
body{min-height:100vh;background:radial-gradient(circle at top,rgba(31,45,78,.25),transparent 32%),linear-gradient(180deg,#070a10 0%,#05070d 36%,#04060b 100%);color:var(--text-primary);font-family:var(--font-body);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;position:relative}
body::before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 20% 20%,rgba(200,170,110,.06),transparent 18%),radial-gradient(circle at 80% 12%,rgba(96,165,250,.08),transparent 20%),radial-gradient(circle at 60% 72%,rgba(168,85,247,.08),transparent 20%);z-index:-2}
body::after{content:"";position:fixed;inset:0;pointer-events:none;background:linear-gradient(rgba(255,255,255,.015) 50%,rgba(0,0,0,.015) 50%);background-size:100% 4px;opacity:.12;z-index:-1}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button,input{font:inherit}button{border:0;background:none}
:focus-visible{outline:2px solid var(--accent-strong);outline-offset:3px}
::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-deep)}::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),.45);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:rgba(var(--accent-rgb),.7)}
.accent{color:var(--accent)}.hidden{display:none!important}

.site-switcher-toast {
    position: fixed;
    left: 50%;
    top: 50%;
    bottom: auto;
    transform: translate(-50%, -44%);
    max-width: calc(100vw - 24px);
    padding: 10px 16px;
    border: 1px solid var(--border-accent, var(--border-strong, var(--border)));
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(10, 14, 26, 0.97), rgba(30, 41, 75, 0.94));
    color: var(--text-primary);
    font-family: var(--font-heading);
    font-size: 0.86rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-align: center;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.45), inset 0 0 0 1px rgba(var(--accent-rgb), 0.15);
    backdrop-filter: blur(8px);
    z-index: 10001;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.site-switcher-toast.visible {
    opacity: 1;
    transform: translate(-50%, -50%);
}

@media (max-width: 640px) {
    .site-switcher-toast {
        padding: 10px 12px;
        font-size: 0.8rem;
        letter-spacing: 0.05em;
    }
}

#loading-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 40%,rgba(200,170,110,.1),transparent 32%),linear-gradient(180deg,rgba(4,6,11,.98),rgba(4,6,11,1));z-index:10000;transition:opacity .45s ease,visibility .45s ease}
#loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-content{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}
.loader-logo{width:92px;filter:drop-shadow(0 0 20px rgba(200,170,110,.4));animation:loaderFloat 2.6s ease-in-out infinite}
.loader-text{font-family:var(--font-heading);font-size:.95rem;letter-spacing:.36rem;color:var(--text-secondary);text-transform:uppercase}
.loader-bar{width:240px;height:3px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.08)}
.loader-bar-fill{width:0;height:100%;background:linear-gradient(90deg,transparent 0%,var(--accent) 30%,var(--accent-strong) 65%,transparent 100%);animation:loaderSweep 1.6s ease-out forwards}
@keyframes loaderFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.04)}}
@keyframes loaderSweep{0%{width:0;transform:translateX(-12%)}100%{width:100%;transform:translateX(0)}}

#hero{position:relative;min-height:100vh;padding:120px 28px 72px;overflow:hidden}
.hero-bg-effects{position:absolute;inset:0;pointer-events:none}
.hero-noise{position:absolute;inset:0;opacity:.12;background:radial-gradient(circle at 15% 18%,rgba(255,255,255,.05) 0 1px,transparent 1px),radial-gradient(circle at 65% 32%,rgba(255,255,255,.04) 0 1px,transparent 1px),radial-gradient(circle at 78% 70%,rgba(255,255,255,.04) 0 1px,transparent 1px),radial-gradient(circle at 35% 72%,rgba(255,255,255,.04) 0 1px,transparent 1px)}
.hex-grid{position:absolute;inset:-12% -10%;opacity:.12;background-image:linear-gradient(30deg,rgba(200,170,110,.12) 12%,transparent 12.5%,transparent 87%,rgba(200,170,110,.12) 87.5%,rgba(200,170,110,.12)),linear-gradient(150deg,rgba(200,170,110,.12) 12%,transparent 12.5%,transparent 87%,rgba(200,170,110,.12) 87.5%,rgba(200,170,110,.12)),linear-gradient(90deg,rgba(200,170,110,.07) 2%,transparent 2.5%,transparent 97%,rgba(200,170,110,.07) 97.5%,rgba(200,170,110,.07));background-size:110px 190px;mask-image:linear-gradient(180deg,rgba(0,0,0,.9),transparent 90%)}
.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);animation:heroPulse 10s ease-in-out infinite}
.hero-glow-a{width:640px;height:640px;top:-16%;left:-10%;background:radial-gradient(circle,rgba(200,170,110,.18),transparent 68%)}
.hero-glow-b{width:580px;height:580px;right:-10%;top:16%;background:radial-gradient(circle,rgba(96,165,250,.14),transparent 68%);animation-delay:-4s}
.hero-ring{position:absolute;width:520px;height:520px;right:10%;top:50%;transform:translateY(-50%);border:1px solid rgba(200,170,110,.18);border-radius:50%;box-shadow:0 0 0 28px rgba(200,170,110,.04),0 0 0 58px rgba(200,170,110,.02)}
.hero-sigil{position:absolute;border-radius:50%;border:1px solid rgba(200,170,110,.2);background:radial-gradient(circle,rgba(200,170,110,.1),transparent 70%);animation:orbitDrift 12s ease-in-out infinite}
.hero-sigil-a{width:74px;height:74px;top:18%;right:30%}.hero-sigil-b{width:42px;height:42px;top:28%;right:18%;animation-delay:-3s}.hero-sigil-c{width:58px;height:58px;bottom:18%;right:26%;animation-delay:-6s}
@keyframes heroPulse{0%,100%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}
@keyframes orbitDrift{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(10px,-12px,0)}}

#main-nav{position:fixed;top:0;left:0;right:0;z-index:1200;display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:rgba(4,6,11,.7);border-bottom:1px solid rgba(255,255,255,.06);backdrop-filter:blur(20px)}
.nav-logo{display:inline-flex;align-items:center;gap:14px;position:relative;z-index:1202}
.nav-logo-mark{width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;padding:6px;background:radial-gradient(circle at top,rgba(200,170,110,.18),rgba(200,170,110,.02));border:1px solid var(--border-strong);box-shadow:inset 0 0 24px rgba(200,170,110,.08)}
.nav-logo-text{font-family:var(--font-heading);font-size:1.2rem;letter-spacing:.18rem}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-link{color:var(--text-secondary);font-size:.95rem;letter-spacing:.08rem;text-transform:uppercase;transition:color .24s ease}
.nav-link:hover,.nav-link:focus-visible{color:var(--text-primary)}
.nav-kofi-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 18px;border:1px solid var(--border-strong);border-radius:999px;background:rgba(var(--accent-rgb),.08);color:var(--accent-strong);font-size:.9rem;letter-spacing:.08rem;text-transform:uppercase;transition:transform .24s ease,border-color .24s ease,box-shadow .24s ease}
.nav-kofi-btn:hover,.nav-kofi-btn:focus-visible{transform:translateY(-2px);border-color:rgba(var(--accent-rgb),.52);box-shadow:0 16px 30px rgba(var(--accent-rgb),.16)}
.mobile-menu-toggle{width:44px;height:44px;display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:1px solid var(--border-strong);border-radius:12px;background:rgba(var(--accent-rgb),.06);position:relative;z-index:1202}
.menu-bar{width:20px;height:2px;background:var(--accent);transition:transform .24s ease,opacity .24s ease}
.mobile-menu-toggle.active .menu-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-toggle.active .menu-bar:nth-child(2){opacity:0}
.mobile-menu-toggle.active .menu-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.hero-layout{position:relative;z-index:2;width:100%;max-width:var(--container-max);margin:0 auto;min-height:calc(100vh - 160px);display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,460px);align-items:center;gap:52px}
.hero-content{max-width:720px}
.hero-badge{display:inline-flex;align-items:center;min-height:34px;padding:0 14px;border:1px solid var(--border-strong);border-radius:999px;background:rgba(var(--accent-rgb),.08);color:var(--accent-strong);font-size:.8rem;letter-spacing:.14rem;text-transform:uppercase;margin-bottom:20px}
.hero-title{font-family:var(--font-heading);font-size:clamp(3rem,8vw,5.5rem);line-height:.98;text-transform:uppercase;margin-bottom:22px;letter-spacing:.08rem}
.hero-title-line{display:block}
.accent-line{color:transparent;-webkit-text-stroke:1px var(--accent);position:relative}
.accent-line::after{content:"RUNETERRA";position:absolute;inset:0;color:rgba(var(--accent-rgb),.18);filter:blur(16px);z-index:-1}
.hero-subtitle{font-size:1.12rem;max-width:58ch;color:var(--text-secondary)}
.hero-actions{display:flex;align-items:center;flex-wrap:wrap;gap:18px;margin:34px 0}
.hero-cta{display:inline-flex;align-items:center;gap:12px;min-height:52px;padding:0 22px;border-radius:18px;border:1px solid rgba(var(--accent-rgb),.5);background:linear-gradient(135deg,rgba(var(--accent-rgb),.18),rgba(var(--accent-rgb),.04)),rgba(0,0,0,.12);color:var(--accent-strong);font-weight:700;letter-spacing:.08rem;text-transform:uppercase;box-shadow:0 18px 32px rgba(var(--accent-rgb),.14);transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease}
.hero-cta:hover,.hero-cta:focus-visible{transform:translateY(-3px);box-shadow:0 24px 40px rgba(var(--accent-rgb),.2);border-color:rgba(var(--accent-rgb),.7)}
.hero-secondary-link{color:var(--text-secondary);font-size:.96rem;transition:color .24s ease}
.hero-secondary-link:hover,.hero-secondary-link:focus-visible{color:var(--text-primary)}
.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.stat-item{padding:18px 18px 16px;border-radius:18px;background:rgba(9,13,21,.68);border:1px solid rgba(255,255,255,.06);box-shadow:inset 0 1px 0 rgba(255,255,255,.03)}
.stat-number{display:block;font-family:var(--font-heading);font-size:clamp(1.8rem,4vw,2.7rem);line-height:1;color:var(--accent-strong);margin-bottom:8px}
.stat-label{display:block;color:var(--text-muted);font-size:.82rem;letter-spacing:.2rem;text-transform:uppercase}
.hero-keywords{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.keyword-pill{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:var(--text-secondary);font-size:.82rem}

.hero-intel-panel{position:relative;padding:30px;border-radius:28px;border:1px solid var(--border-strong);background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015)),rgba(8,11,18,.88);box-shadow:var(--shadow-lg),inset 0 1px 0 rgba(255,255,255,.04);overflow:hidden}
.hero-intel-panel::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(200,170,110,.16),transparent 34%),linear-gradient(135deg,rgba(96,165,250,.08),transparent 42%);pointer-events:none}
.panel-topline{position:relative;z-index:1;color:var(--accent-strong);font-size:.8rem;letter-spacing:.16rem;text-transform:uppercase;margin-bottom:10px}
.hero-panel-title{position:relative;z-index:1;font-family:var(--font-heading);font-size:1.9rem;line-height:1.1;margin-bottom:14px}
.hero-panel-copy{position:relative;z-index:1;color:var(--text-secondary);margin-bottom:24px}
.hero-panel-grid{position:relative;z-index:1;display:grid;gap:14px}
.intel-tile{padding:16px;border-radius:18px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.06)}
.intel-tile strong{display:block;font-family:var(--font-heading);font-size:1.6rem;color:var(--text-primary);margin-bottom:6px}
.intel-tile p{color:var(--text-secondary);font-size:.9rem}
.hero-watchlist{position:relative;z-index:1;display:grid;gap:10px;margin-top:18px}
.watch-item{display:flex;align-items:center;gap:14px;width:100%;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03);color:var(--text-primary);text-align:left;transition:transform .24s ease,border-color .24s ease,background .24s ease;cursor:pointer}
.watch-item:hover,.watch-item:focus-visible{transform:translateX(6px);border-color:rgba(var(--accent-rgb),.38);background:rgba(var(--accent-rgb),.08)}
.watch-index{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(var(--accent-rgb),.1);color:var(--accent-strong);font-size:.86rem;font-weight:700;flex-shrink:0}
.watch-copy strong{display:block;font-size:.95rem;margin-bottom:2px}.watch-copy span{color:var(--text-secondary);font-size:.84rem}

.scroll-indicator{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:2;opacity:.7}
.scroll-track{width:2px;height:54px;background:linear-gradient(180deg,rgba(var(--accent-rgb),.9),rgba(var(--accent-rgb),0));border-radius:999px}
.scroll-arrow{width:16px;height:16px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(45deg);animation:scrollBounce 1.9s ease-in-out infinite}
@keyframes scrollBounce{0%,100%{transform:translateY(0) rotate(45deg)}50%{transform:translateY(8px) rotate(45deg)}}

.section-shell{position:relative;width:100%;max-width:var(--container-max);margin:0 auto;padding:var(--section-pad) 28px 0}
.section-header{text-align:center;max-width:860px;margin:0 auto 38px}
.section-badge{display:inline-flex;align-items:center;min-height:34px;padding:0 14px;border-radius:999px;border:1px solid var(--border-strong);background:rgba(var(--accent-rgb),.08);color:var(--accent-strong);font-size:.76rem;letter-spacing:.16rem;text-transform:uppercase;margin-bottom:16px}
.section-title{font-family:var(--font-heading);font-size:clamp(2rem,4vw,3.3rem);line-height:1.08;text-transform:uppercase;margin-bottom:14px}
.section-desc{font-size:1rem;color:var(--text-secondary)}
.section-slab{position:relative;padding:28px;border-radius:32px;border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)),rgba(8,12,18,.78);box-shadow:var(--shadow-md),inset 0 1px 0 rgba(255,255,255,.02);overflow:hidden}
.section-slab::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(200,170,110,.08),transparent 24%),radial-gradient(circle at bottom left,rgba(96,165,250,.06),transparent 24%);pointer-events:none}

.briefing-slab{padding-bottom:24px}
.briefing-layout{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,620px);gap:28px;align-items:start;margin-bottom:28px}
.briefing-lead{padding:28px;border-radius:24px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06)}
.briefing-kicker{font-size:1.05rem;color:var(--text-primary);margin-bottom:24px}
.briefing-quote{padding:18px 20px;border-left:3px solid var(--accent);background:rgba(var(--accent-rgb),.08);border-radius:18px;color:var(--text-secondary);font-size:.98rem}
.briefing-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.briefing-card{padding:22px;border-radius:22px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.briefing-label{display:block;color:var(--text-muted);font-size:.75rem;letter-spacing:.16rem;text-transform:uppercase;margin-bottom:8px}
.briefing-card strong{display:block;font-family:var(--font-heading);font-size:1.6rem;color:var(--accent-strong);line-height:1.15;margin-bottom:8px}
.briefing-card p{color:var(--text-secondary);font-size:.94rem}
.flashpoints-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.flashpoint-card{width:100%;padding:20px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015)),rgba(8,12,18,.92);border:1px solid rgba(255,255,255,.06);text-align:left;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .24s ease,border-color .24s ease,box-shadow .24s ease}
.flashpoint-card:hover,.flashpoint-card:focus-visible{transform:translateY(-6px);border-color:rgba(var(--accent-rgb),.36);box-shadow:0 22px 34px rgba(0,0,0,.28)}
.flashpoint-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.flashpoint-icon{width:48px;height:48px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(var(--accent-rgb),.28);background:rgba(var(--accent-rgb),.1);flex-shrink:0}
.flashpoint-title{font-family:var(--font-heading);font-size:1.05rem}.flashpoint-subtitle{font-size:.84rem;color:var(--text-muted)}
.flashpoint-score{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}
.flashpoint-score span{color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.12rem}
.flashpoint-score strong{font-family:var(--font-heading);font-size:1.2rem;color:var(--accent-strong)}
.flashpoint-desc{color:var(--text-secondary);font-size:.92rem;margin-bottom:14px}
.flashpoint-meta,.info-chip,.faction-filters{display:flex;flex-wrap:wrap;gap:8px}
.info-chip{align-items:center;min-height:30px;padding:0 10px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:var(--text-secondary);font-size:.79rem;line-height:1}

.map-toolbar{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.map-controls{display:flex;flex-wrap:wrap;gap:10px}
.map-btn,.faction-filter-btn{min-height:40px;padding:0 16px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:var(--text-secondary);cursor:pointer;transition:transform .18s ease,color .18s ease,border-color .18s ease,background .18s ease}
.map-btn:hover,.map-btn.active,.faction-filter-btn:hover,.faction-filter-btn.active{background:rgba(var(--accent-rgb),.16);border-color:rgba(var(--accent-rgb),.4);color:var(--accent-strong)}
.map-hint,.faction-results{color:var(--text-muted);font-size:.92rem}
.map-container{position:relative;z-index:1;width:100%;height:72vh;min-height:520px;border-radius:26px;overflow:hidden;background:radial-gradient(circle at top,rgba(39,57,96,.2),transparent 32%),linear-gradient(180deg,#09101a 0%,#06080f 100%);border:1px solid rgba(255,255,255,.06)}
.map-container.fullscreen{position:fixed;inset:0;width:100vw;height:100vh;z-index:2000;border-radius:0}
canvas{display:block;width:100%;height:100%}
.map-container canvas{position:relative;z-index:1;cursor:grab}
.map-zoom-controls{position:absolute;left:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:2}
.zoom-btn{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(var(--accent-rgb),.24);background:rgba(4,6,11,.78);color:var(--text-primary);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .18s ease,border-color .18s ease,color .18s ease,background .18s ease}
.zoom-btn svg{pointer-events:none}.zoom-btn:hover,.zoom-btn:focus-visible{transform:translateY(-2px);border-color:rgba(var(--accent-rgb),.5);background:rgba(var(--accent-rgb),.14);color:var(--accent-strong)}
.map-base-legend{position:relative;z-index:1;display:flex;justify-content:center;flex-wrap:wrap;gap:18px 34px;margin-top:20px}
.legend-item{display:inline-flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:.88rem}
.legend-line{width:34px;height:4px;border-radius:999px}.legend-line-alliance{background:var(--ally)}.legend-line-conflict{background:var(--conflict)}.legend-line-complex{background:var(--complex)}
.node-tooltip{position:absolute;width:280px;padding:16px;border-radius:20px;background:rgba(6,10,16,.94);border:1px solid rgba(var(--accent-rgb),.24);box-shadow:0 20px 40px rgba(0,0,0,.42);pointer-events:none;z-index:3}
.node-tooltip h4{display:flex;align-items:center;gap:10px;font-family:var(--font-heading);font-size:1rem;margin-bottom:8px}.node-tooltip h4 span svg{width:100%;height:100%}.node-tooltip p{color:var(--text-secondary);font-size:.9rem}.node-tooltip .tooltip-cta{margin-top:10px;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.14rem;font-size:.72rem}

.faction-controls{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:14px}
.search-box{position:relative;width:min(100%,420px)}
.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}
.search-box input{width:100%;min-height:48px;padding:0 16px 0 48px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:var(--text-primary)}
.search-box input::placeholder{color:var(--text-muted)}
.search-box input:focus{outline:none;border-color:rgba(var(--accent-rgb),.42);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.12)}
.faction-results{position:relative;z-index:1;margin-bottom:20px}
.factions-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.faction-card{position:relative;display:flex;flex-direction:column;gap:16px;padding:24px;border-radius:24px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)),rgba(8,12,18,.96);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .24s ease,border-color .24s ease,box-shadow .24s ease;text-align:left}
.faction-card::before{content:"";position:absolute;left:24px;right:24px;top:0;height:3px;border-radius:999px;background:var(--card-accent,var(--accent));opacity:.9}
.faction-card:hover,.faction-card:focus-visible{transform:translateY(-8px);border-color:rgba(var(--accent-rgb),.3);box-shadow:0 24px 40px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.04)}
.card-eyebrow{color:var(--text-muted);font-size:.74rem;letter-spacing:.14rem;text-transform:uppercase}
.card-header{display:flex;align-items:flex-start;gap:14px}
.card-icon{width:54px;height:54px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.card-icon svg{width:28px;height:28px}.card-title{font-family:var(--font-heading);font-size:1.35rem;line-height:1.1;margin-bottom:4px}.card-alignment{color:var(--text-secondary);font-size:.9rem}
.card-desc{color:var(--text-secondary);font-size:.95rem;flex-grow:1}
.card-traits{display:flex;flex-wrap:wrap;gap:8px}
.card-trait{min-height:30px;padding:0 10px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.035);color:var(--text-secondary);font-size:.78rem;display:inline-flex;align-items:center}
.card-members-row{display:flex;align-items:center;flex-wrap:wrap;gap:0}
.card-member-avatar,.card-member-more{width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(8,12,18,.92);margin-left:-10px;background:var(--bg-elevated);color:var(--text-primary);font-size:.78rem;font-weight:700;box-shadow:0 8px 18px rgba(0,0,0,.2)}
.card-member-avatar:first-child,.card-member-more:first-child{margin-left:0}
.card-member-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;object-position:center 20%}
.card-member-avatar{padding:0;cursor:pointer;position:relative;z-index:1;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.card-member-avatar:hover,.card-member-avatar:focus-visible{transform:translateY(-2px);border-color:rgba(var(--accent-rgb),.52);box-shadow:0 10px 22px rgba(0,0,0,.26),0 0 0 2px rgba(var(--accent-rgb),.16);z-index:4}
.card-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}
.card-stat{color:var(--text-muted);font-size:.8rem;letter-spacing:.1rem;text-transform:uppercase}
.card-view-btn{color:var(--accent-strong);font-weight:700;text-transform:uppercase;letter-spacing:.08rem;font-size:.82rem}
.empty-state{position:relative;z-index:1;padding:26px;border-radius:22px;background:rgba(255,255,255,.03);border:1px dashed rgba(255,255,255,.12);color:var(--text-secondary);text-align:center}
.pill-tag{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:var(--pill-color,var(--text-primary));cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}
.pill-tag:hover,.pill-tag:focus-visible{transform:translateY(-1px);border-color:rgba(var(--accent-rgb),.3);background:rgba(255,255,255,.07)}
.pill-tag.inline{min-height:36px;padding:0 12px;margin:0 3px;gap:10px;font-size:.92em;vertical-align:middle}
.pill-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.pill-icon svg,.pill-icon img{width:100%;height:100%}
.pill-tag.inline .pill-icon{width:20px;height:20px}
.pill-tag.inline.champion-pill .pill-icon{width:22px;height:22px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.18)}
.pill-icon img{border-radius:50%;object-fit:cover}
.pill-tag.inline.champion-pill .pill-icon img{object-position:center 20%}
.champion-pill{color:var(--text-primary)}

.modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(2,4,8,.82);backdrop-filter:blur(10px);z-index:1600;opacity:0;pointer-events:none;transition:opacity .28s ease}
.modal-overlay.visible{opacity:1;pointer-events:auto}
.modal{position:relative;width:min(960px,100%);max-height:min(92vh,960px);overflow-y:auto;border-radius:30px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)),rgba(7,10,16,.98);border:1px solid rgba(255,255,255,.08);box-shadow:0 40px 90px rgba(0,0,0,.55);padding:0 30px 30px;transform:translateY(18px) scale(.98);transition:transform .28s ease}
.modal-overlay.visible .modal{transform:translateY(0) scale(1)}
.hero-modal{width:min(860px,100%)}
.modal-accent-bar{height:4px;margin:0 -30px 24px;border-radius:30px 30px 0 0;background:linear-gradient(90deg,rgba(var(--accent-rgb),.35),var(--accent),rgba(96,165,250,.45))}
.modal-close{position:absolute;top:20px;right:20px;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:var(--text-secondary);font-size:1.8rem;line-height:1;cursor:pointer;transition:color .18s ease,border-color .18s ease,background .18s ease}
.modal-close:hover,.modal-close:focus-visible{color:var(--accent-strong);border-color:rgba(var(--accent-rgb),.34);background:rgba(var(--accent-rgb),.1)}
.modal-header{display:flex;align-items:center;gap:18px;margin-bottom:24px;padding-top:74px}.hero-modal-header{align-items:flex-start}
.modal-icon,.hero-modal-portrait{width:88px;height:88px;border-radius:24px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.03);border:1px solid rgba(var(--accent-rgb),.24);overflow:hidden}
.modal-icon svg{width:46px;height:46px}.hero-modal-portrait{border-radius:50%;box-shadow:0 0 0 6px rgba(var(--accent-rgb),.08)}
.hero-modal-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.modal-title{font-family:var(--font-heading);font-size:clamp(2rem,4vw,3rem);line-height:1.05;margin-bottom:6px}
.modal-alignment,.hero-modal-subtitle{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.22);color:var(--accent-strong);font-size:.82rem;letter-spacing:.12rem;text-transform:uppercase}
.modal-summary-grid,.rel-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:26px}
.summary-card{padding:16px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.summary-label{display:block;color:var(--text-muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.14rem;margin-bottom:6px}
.summary-value{display:block;color:var(--text-primary);font-size:1rem;line-height:1.35}
.modal-body{display:grid;gap:28px}
.modal-section h3{font-family:var(--font-heading);font-size:1.2rem;color:var(--accent-strong);margin-bottom:12px}
.modal-section p{color:var(--text-secondary)}
.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.member-chip{display:flex;align-items:center;gap:12px;width:100%;padding:12px;border-radius:18px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.06);color:var(--text-primary);text-align:left;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}
.member-chip:hover,.member-chip:focus-visible{transform:translateY(-2px);border-color:rgba(var(--accent-rgb),.32);background:rgba(var(--accent-rgb),.08)}
.member-chip-img{width:46px;height:46px;border-radius:50%;object-fit:cover;object-position:center 20%;flex-shrink:0;border:1px solid rgba(var(--accent-rgb),.24)}
.member-name{display:block;font-weight:700;margin-bottom:2px}.member-role{display:block;color:var(--text-muted);font-size:.84rem}
.relationship-list{min-height:40px;display:grid;gap:24px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}.modal-intel-grid{display:grid;gap:16px}
.intel-category{display:grid;gap:10px}
.intel-category.intel-alliance{--intel-color:var(--ally)}
.intel-category.intel-conflict{--intel-color:var(--conflict)}
.intel-category.intel-complex{--intel-color:var(--complex)}
.intel-label{display:inline-flex;align-items:center;gap:8px;min-height:24px;color:var(--intel-color,var(--text-muted));font-size:.74rem;font-weight:700;letter-spacing:.14rem;text-transform:uppercase}
.intel-type-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}
.intel-type-icon svg{width:14px;height:14px}
.intel-category .intel-type-icon{color:var(--intel-color,var(--text-muted))}
.intel-chips{display:flex;flex-wrap:wrap;gap:10px}
.relationship-list .pill-tag{min-height:34px;padding:0 12px;border-radius:8px}
.intel-deep-dive{position:relative;overflow:hidden;display:grid;gap:10px;width:100%;padding:18px 20px;border-radius:10px;border:1px solid rgba(var(--accent-rgb),.26);background:linear-gradient(90deg,rgba(var(--accent-rgb),.16),rgba(255,255,255,.03) 42%,rgba(255,255,255,.01));text-align:left;color:var(--text-primary);cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .2s ease}
.intel-deep-dive::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,rgba(var(--accent-rgb),.86),rgba(var(--accent-rgb),.24))}
.intel-deep-dive:hover,.intel-deep-dive:focus-visible{border-color:rgba(var(--accent-rgb),.44);background:linear-gradient(90deg,rgba(var(--accent-rgb),.22),rgba(255,255,255,.05) 42%,rgba(255,255,255,.01));transform:translateY(-1px)}
.intel-deep-dive-eyebrow{font-size:.66rem;font-weight:700;letter-spacing:.18rem;text-transform:uppercase;color:var(--accent-strong)}
.intel-deep-dive-title{font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:.08rem}
.modal-status-copy{padding:16px 18px;border-radius:18px;border:1px solid rgba(var(--accent-rgb),.18);background:rgba(var(--accent-rgb),.08)}
.hero-affiliation-list{display:flex;flex-direction:column;gap:10px}
.journey-section-title{font-size:.68rem;font-weight:700;letter-spacing:.16rem;color:var(--text-muted);text-transform:uppercase}
.hero-affiliation-card{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:var(--text-primary);text-align:left;cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}
.hero-affiliation-card:hover,.hero-affiliation-card:focus-visible{border-color:rgba(var(--accent-rgb),.34);background:rgba(var(--accent-rgb),.08);transform:translateY(-1px)}
.hero-affiliation-card.former{opacity:.72}
.hero-affiliation-card.former:hover,.hero-affiliation-card.former:focus-visible{opacity:1}
.hero-affiliation-logo{width:40px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.1);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-affiliation-logo svg{width:22px;height:22px}
.hero-affiliation-info{display:flex;flex-direction:column;gap:2px;flex:1}
.hero-affiliation-name{font-weight:700}
.hero-affiliation-role{font-size:.8rem;color:var(--text-muted)}
.hero-affiliation-status{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-size:.64rem;font-weight:700;letter-spacing:.14rem;text-transform:uppercase}

.rel-interface{position:relative;z-index:1;display:grid;grid-template-columns:320px minmax(0,1fr);gap:22px;align-items:start}
.rel-selector-sidebar,.rel-focus-display{position:relative;z-index:1;min-height:100%;border-radius:24px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.rel-selector-sidebar{padding:22px}
.rel-selector-header h3{font-family:var(--font-heading);font-size:1.2rem;margin-bottom:8px}
.rel-selector-header p{color:var(--text-muted);font-size:.92rem;margin-bottom:16px}
.rel-faction-list{display:flex;flex-direction:column;gap:10px;max-height:620px;overflow-y:auto;overflow-x:hidden;padding-right:8px}
.rel-faction-btn{display:flex;align-items:center;gap:12px;width:100%;min-height:48px;padding:12px 14px;border-radius:16px;border:1px solid transparent;background:rgba(255,255,255,.02);color:var(--text-primary);text-align:left;cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}
.rel-faction-btn svg{width:22px;height:22px;flex-shrink:0}
.rel-faction-btn:hover,.rel-faction-btn:focus-visible,.rel-faction-btn.active{border-color:rgba(var(--accent-rgb),.3);background:rgba(var(--accent-rgb),.1);transform:translateX(4px)}
.rel-focus-display{padding:26px}
.rel-placeholder{min-height:320px;display:grid;place-items:center;text-align:center;border-radius:22px;border:1px dashed rgba(255,255,255,.12);color:var(--text-secondary)}
.rel-placeholder h3{font-family:var(--font-heading);margin-bottom:10px}
.rel-focus-header{display:flex;align-items:flex-start;gap:18px;margin-bottom:22px}
.rel-focus-icon{width:84px;height:84px;border-radius:24px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.03)}
.rel-focus-icon svg{width:42px;height:42px}
.rel-focus-info h3{font-family:var(--font-heading);font-size:2rem;margin-bottom:8px}
.rel-focus-info p{color:var(--text-secondary);margin-bottom:12px}
.rel-categories{display:grid;gap:22px}
.rel-cat-section h4{font-family:var(--font-heading);font-size:1rem;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.12rem;margin-bottom:14px}
.rel-cat-title{display:inline-flex;align-items:center;gap:8px}
.rel-cat-title-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px}
.rel-cat-title-icon svg{width:14px;height:14px}
.rel-cat-title-alliance,.rel-cat-title-alliance .rel-cat-title-icon{color:var(--ally)}
.rel-cat-title-conflict,.rel-cat-title-conflict .rel-cat-title-icon{color:var(--conflict)}
.rel-cat-title-complex,.rel-cat-title-complex .rel-cat-title-icon{color:var(--complex)}
.rel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.rel-mini-card{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:8px;width:100%;padding:16px;border-radius:18px;border:1px solid rgba(255,255,255,.08);border-left:2px solid transparent;background:rgba(255,255,255,.03);color:var(--text-primary);text-align:left;cursor:pointer;transition:transform .2s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease;--rel-glow:rgba(var(--accent-rgb),.2)}
.rel-mini-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,50%),var(--rel-glow),transparent 72%);opacity:0;transition:opacity .24s ease;pointer-events:none}
.rel-mini-card:hover,.rel-mini-card:focus-visible{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.22)}
.rel-mini-card:hover::after,.rel-mini-card:focus-visible::after{opacity:.85}
.rel-mini-card.alliance{border-left-color:var(--ally);background:rgba(34,197,94,.06);--rel-glow:rgba(34,197,94,.28)}
.rel-mini-card.conflict{border-left-color:var(--conflict);background:rgba(239,68,68,.06);--rel-glow:rgba(239,68,68,.28)}
.rel-mini-card.complex{border-left-color:var(--complex);background:rgba(168,85,247,.06);--rel-glow:rgba(168,85,247,.3)}
.rel-mini-header{display:flex;align-items:center;justify-content:space-between;gap:10px}
.rel-mini-target{display:flex;align-items:center;gap:10px;font-weight:700;min-width:0}
.rel-mini-target svg{width:18px;height:18px}
.rel-mini-type-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}
.rel-mini-type-icon svg{width:14px;height:14px}
.rel-mini-type-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.14rem;color:var(--text-muted)}
.rel-mini-card.alliance .rel-mini-type-icon,.rel-mini-card.alliance .rel-mini-type-label{color:var(--ally)}
.rel-mini-card.conflict .rel-mini-type-icon,.rel-mini-card.conflict .rel-mini-type-label{color:var(--conflict)}
.rel-mini-card.complex .rel-mini-type-icon,.rel-mini-card.complex .rel-mini-type-label{color:var(--complex)}
.rel-mini-desc{color:var(--text-secondary);font-size:.9rem}

.timeline-overview{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:26px}
.timeline-overview-card{padding:18px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.timeline-overview-card span{display:block;color:var(--text-muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.14rem;margin-bottom:6px}
.timeline-overview-card strong{display:block;font-family:var(--font-heading);font-size:1.5rem;margin-bottom:6px}
.timeline-overview-card p{color:var(--text-secondary);font-size:.9rem}
.timeline-slab{position:relative;padding:8px;background:transparent;border:none;box-shadow:none}
.timeline-slab::before{display:none}
.timeline-container{position:relative;z-index:1;max-width:1040px;margin:0 auto;padding:12px 0 4px 62px}
.timeline-container::before{content:"";position:absolute;left:22px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent 0%,rgba(var(--accent-rgb),.82) 12%,rgba(var(--accent-rgb),.68) 86%,transparent 100%);box-shadow:0 0 18px rgba(var(--accent-rgb),.22);z-index:1}
.timeline-item{position:relative;width:100%;left:0;margin-bottom:28px;padding:0;opacity:0;transform:translateX(28px);transition:opacity .56s cubic-bezier(.16,1,.3,1),transform .56s cubic-bezier(.16,1,.3,1);transition-delay:var(--timeline-delay,0s)}
.timeline-item.visible{opacity:1;transform:translateX(0)}
.timeline-left,.timeline-right{left:0;width:100%;padding:0}
.timeline-item::before{content:"";position:absolute;left:-40px;top:34px;width:12px;height:12px;background:var(--bg-deepest);border:2px solid var(--accent);transform:rotate(45deg);box-shadow:0 0 16px rgba(var(--accent-rgb),.28);z-index:4;animation:timelinePulse 3.2s ease-in-out infinite}
.timeline-item::after{content:"";position:absolute;left:-34px;top:39px;width:34px;height:2px;background:linear-gradient(90deg,rgba(var(--accent-rgb),.9),transparent);z-index:2}
.timeline-left::after,.timeline-right::after{left:-34px;right:auto}
.timeline-content{position:relative;padding:24px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)),var(--bg-card);border:1px solid rgba(255,255,255,.06);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .22s ease,box-shadow .22s ease}
.timeline-content::before{content:"";position:absolute;inset:9px;border-radius:15px;border:1px solid rgba(255,255,255,.035);pointer-events:none}
.timeline-content:hover,.timeline-content:focus-within{transform:translateY(-3px);box-shadow:0 20px 36px rgba(0,0,0,.3)}
.timeline-date{display:inline-flex;align-items:center;min-height:30px;padding:4px 14px;border-radius:6px;background:rgba(var(--accent-rgb),.14);color:var(--accent-strong);font-size:.75rem;font-weight:700;letter-spacing:.14rem;text-transform:uppercase;margin-bottom:14px}
.timeline-heading{font-family:var(--font-heading);font-size:1.28rem;line-height:1.2;margin-bottom:10px}.timeline-desc{color:var(--text-secondary);line-height:1.7;margin-bottom:16px}.timeline-faction-tags{display:flex;flex-wrap:wrap;gap:10px;padding-top:8px}
.timeline-ripples{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}
.ripple-header{display:flex;align-items:center;gap:10px;font-size:.7rem;font-weight:700;letter-spacing:.14rem;text-transform:uppercase;color:var(--accent-strong);margin-bottom:12px}
.ripple-header::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,rgba(var(--accent-rgb),.3),transparent)}
.ripple-list{display:grid;gap:12px}
.timeline-ripple-item{display:grid;gap:8px;padding:0 0 0 16px;border:none;border-left:2px solid rgba(var(--accent-rgb),.18);background:none;text-align:left;cursor:pointer;transition:border-left-color .18s ease,transform .18s ease}
.timeline-ripple-item:hover,.timeline-ripple-item:focus-visible{border-left-color:rgba(var(--accent-rgb),.55);transform:translateX(2px)}
.ripple-faction{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;font-weight:700;letter-spacing:.1rem;text-transform:uppercase}
.ripple-faction-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}
.ripple-faction-icon svg{width:14px;height:14px}
.ripple-impact{font-size:.88rem;color:var(--text-secondary);line-height:1.5}
@keyframes timelinePulse{0%,100%{box-shadow:0 0 16px rgba(var(--accent-rgb),.28)}50%{box-shadow:0 0 24px rgba(var(--accent-rgb),.45)}}

#footer{max-width:var(--container-max);margin:0 auto;padding:96px 28px 40px}
.footer-grid{display:grid;grid-template-columns:minmax(0,1.2fr) repeat(2,minmax(0,.9fr));gap:28px;padding:28px;border-radius:30px;border:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01)),rgba(7,10,16,.84)}
.footer-logo{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-heading);font-size:1.4rem;margin-bottom:14px}
.footer-logo img{width:42px;height:42px}.footer-copy{color:var(--text-secondary);max-width:52ch;margin-bottom:18px}
.footer-support{display:inline-flex;align-items:center;min-height:42px;padding:0 16px;border-radius:999px;border:1px solid rgba(var(--accent-rgb),.28);background:rgba(var(--accent-rgb),.08);color:var(--accent-strong);text-transform:uppercase;letter-spacing:.08rem;font-size:.86rem}
.footer-links-group h3{font-family:var(--font-heading);font-size:1rem;margin-bottom:12px}
.footer-links-group a,.footer-note{display:block;color:var(--text-secondary);margin-bottom:8px}
.footer-links-group a:hover,.footer-links-group a:focus-visible{color:var(--text-primary)}
.back-to-top{position:fixed;right:26px;bottom:26px;width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(var(--accent-rgb),.28);background:rgba(4,6,11,.82);color:var(--accent-strong);box-shadow:var(--shadow-sm);opacity:0;visibility:hidden;transition:opacity .18s ease,visibility .18s ease,transform .18s ease;z-index:1400}
.back-to-top.visible{opacity:1;visibility:visible}.back-to-top:hover,.back-to-top:focus-visible{transform:translateY(-2px)}

/* ---------- SITE SWITCHER ---------- */
.site-switcher { position: relative; }
.site-switcher-toggle { padding: 0; border: none; background: none; color: inherit; cursor: pointer; display: inline-flex; align-items: center; gap: 12px; }
.site-switcher-toggle:focus-visible { outline: 2px solid var(--accent); outline-offset: 6px; border-radius: 4px; }
.site-switcher-caret { width: 9px; height: 9px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg); margin-top: -3px; opacity: 0.8; transition: transform 0.25s ease, color 0.25s ease, opacity 0.25s ease; }
.site-switcher.open .site-switcher-caret { transform: rotate(-135deg) translateY(-1px); color: var(--accent); opacity: 1; }
.site-switcher-menu { position: absolute; top: calc(100% + 10px); left: 0; min-width: 250px; width: max-content; padding: 8px; border-radius: 8px; background: rgba(5, 7, 15, 0.98); border: 1px solid var(--border-strong, var(--border)); box-shadow: 0 16px 32px rgba(0, 0, 0, 0.45); backdrop-filter: blur(18px); z-index: 1205; }
.site-switcher-menu[hidden] { display: none; }
.site-switcher-link { display: flex; align-items: center; gap: 14px; width: 100%; padding: 12px 14px; border-radius: 6px; font-family: var(--font-heading); font-weight: 600; text-transform: uppercase; color: var(--text-primary); transition: background 0.25s ease; text-decoration: none; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; transform: translateZ(0); }
.site-switcher-link-icon { width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.site-switcher-link-icon img { width: 100%; height: 100%; object-fit: contain; }
.site-switcher-link-label { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; text-align: left; font-size: 0.65rem; letter-spacing: 2px; color: var(--text-muted); transition: color 0.2s ease, opacity 0.2s ease; }
.site-switcher-link-accent { font-size: 0.9rem; letter-spacing: 1.4px; color: var(--text-primary); transition: color 0.25s ease; }
.site-switcher-link:hover, .site-switcher-link:focus-visible { background: rgba(255, 255, 255, 0.08); }
.site-switcher-link:hover .site-switcher-link-label { color: rgba(255,255,255,0.7); }
.site-switcher-link:hover .site-switcher-link-accent { color: var(--accent); }

/* Overwatch Factions (Sombra Purple) */
.site-switcher-link.ow-link .site-switcher-link-accent { color: #d28cff; text-shadow: 0 0 10px rgba(187, 41, 255, 0.55); }
.site-switcher-link.ow-link:hover, .site-switcher-link.ow-link:focus-visible { background: rgba(187, 41, 255, 0.16); }
.site-switcher-link.ow-link:hover .site-switcher-link-accent, .site-switcher-link.ow-link:focus-visible .site-switcher-link-accent { color: #f5edff; }

/* Marvel Rivals (Galacta Pink/Red) */
.site-switcher-link.mr-link .site-switcher-link-accent { color: #ff6b8b; text-shadow: 0 0 10px rgba(255, 107, 139, 0.55); }
.site-switcher-link.mr-link:hover, .site-switcher-link.mr-link:focus-visible { background: rgba(255, 107, 139, 0.16); }
.site-switcher-link.mr-link:hover .site-switcher-link-accent, .site-switcher-link.mr-link:focus-visible .site-switcher-link-accent { color: #ffe3e9; }

/* CP Night City (Netrunner Yellow) */
.site-switcher-link.cp-link .site-switcher-link-accent { color: #fcee0a; text-shadow: 0 0 12px rgba(252, 238, 10, 0.55); }
.site-switcher-link.cp-link:hover, .site-switcher-link.cp-link:focus-visible { background: rgba(252, 238, 10, 0.14); }
.site-switcher-link.cp-link:hover .site-switcher-link-accent, .site-switcher-link.cp-link:focus-visible .site-switcher-link-accent { color: #ffffff; text-shadow: 0 0 16px rgba(252, 238, 10, 0.8); }

/* AoT Titans (Ymir Orange) */
.site-switcher-link.ymir-link .site-switcher-link-accent { color: #ff9a3c; text-shadow: 0 0 12px rgba(255, 154, 60, 0.55); }
.site-switcher-link.ymir-link:hover, .site-switcher-link.ymir-link:focus-visible { background: rgba(255, 154, 60, 0.16); }
.site-switcher-link.ymir-link:hover .site-switcher-link-accent, .site-switcher-link.ymir-link:focus-visible .site-switcher-link-accent { color: #ffe7cf; text-shadow: 0 0 16px rgba(255, 154, 60, 0.8); }

/* Ninja Scrolls (Naruto Orange) */
.site-switcher-link.shinobi-link .site-switcher-link-accent { color: #ffb15e; text-shadow: 0 0 12px rgba(249, 115, 22, 0.5); }
.site-switcher-link.shinobi-link:hover, .site-switcher-link.shinobi-link:focus-visible { background: rgba(249, 115, 22, 0.14); }
.site-switcher-link.shinobi-link:hover .site-switcher-link-accent, .site-switcher-link.shinobi-link:focus-visible .site-switcher-link-accent { color: #fff3e0; text-shadow: 0 0 16px rgba(249, 115, 22, 0.78); }

/* Wrestling Chronicles (Arena Cyan) */
.site-switcher-link.wf-link .site-switcher-link-accent { color: #22d3ee; text-shadow: 0 0 12px rgba(34, 211, 238, 0.5); }
.site-switcher-link.wf-link:hover, .site-switcher-link.wf-link:focus-visible { background: rgba(34, 211, 238, 0.14); }
.site-switcher-link.wf-link:hover .site-switcher-link-accent, .site-switcher-link.wf-link:focus-visible .site-switcher-link-accent { color: #bff5ff; text-shadow: 0 0 16px rgba(34, 211, 238, 0.78); }
.nav-logo-icon-container { display: flex; align-items: center; justify-content: center; flex-shrink: 0; width: 42px; height: 42px; border-radius: 50%; padding: 6px; background: radial-gradient(circle at top,rgba(200,170,110,.18),rgba(200,170,110,.02)); border: 1px solid var(--border-strong); box-shadow: inset 0 0 24px rgba(200,170,110,.08); }
.nav-logo-icon { width: 100%; height: 100%; object-fit: contain; }
@media (max-width: 768px) {
    .site-switcher-menu { left: 0; min-width: 220px; }
    .site-switcher-link { font-size: 0.72rem; letter-spacing: 1.2px; }
}

@media (max-width:1240px){.flashpoints-grid,.factions-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-layout,.briefing-layout{grid-template-columns:1fr}.hero-content{max-width:100%}.hero-intel-panel{max-width:760px}}
@media (max-width:1080px){.rel-interface{grid-template-columns:1fr}.rel-faction-list{max-height:320px}.timeline-container{padding-left:54px}.timeline-container::before{left:18px}.timeline-item::before{left:-34px;top:32px}.timeline-item::after,.timeline-left::after,.timeline-right::after{left:-28px;top:37px;width:28px}}
@media (max-width:900px){.briefing-metrics,.modal-summary-grid,.rel-summary-grid,.timeline-overview,.footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.rel-grid{grid-template-columns:1fr}.map-toolbar{flex-direction:column;align-items:flex-start}}
@media (max-width:768px){:root{--section-pad:86px}#hero,.section-shell,#footer{padding-left:20px;padding-right:20px}#main-nav{padding:14px 20px}.mobile-menu-toggle{display:inline-flex}.nav-links{position:fixed;inset:0;padding:104px 24px 32px;display:none;flex-direction:column;align-items:flex-start;gap:18px;background:rgba(4,6,11,.96);backdrop-filter:blur(22px);z-index:1201}.nav-links.active{display:flex}.nav-link,.nav-kofi-btn{font-size:1rem}.hero-ring,.hero-sigil{display:none}.hero-layout{gap:32px;min-height:auto;padding-top:52px}.hero-stats,.briefing-metrics,.flashpoints-grid,.factions-grid,.modal-summary-grid,.rel-summary-grid,.timeline-overview,.footer-grid{grid-template-columns:1fr}.hero-actions{flex-direction:column;align-items:stretch}.hero-cta{justify-content:center}.section-slab,.hero-intel-panel,.modal{padding-left:20px;padding-right:20px}.modal{max-height:94vh;padding-bottom:22px}.modal-accent-bar{margin-left:-20px;margin-right:-20px}.modal-header,.rel-focus-header{flex-direction:column;align-items:flex-start}.members-grid{grid-template-columns:1fr}.map-container{min-height:460px}.map-zoom-controls{left:auto;right:16px;bottom:16px}}
@media (max-width:560px){.hero-title{font-size:2.5rem}.nav-logo-text{font-size:.95rem;letter-spacing:.1rem}.nav-logo-mark{width:36px;height:36px}.hero-subtitle,.section-desc{font-size:.96rem}.card-footer{flex-direction:column;align-items:flex-start}.back-to-top{right:18px;bottom:18px}}
@media (max-width:768px){.timeline-slab{padding:6px}.timeline-container{padding-left:46px}.timeline-container::before{left:14px}.timeline-item{margin-bottom:24px;transform:translateX(18px)}.timeline-item::before{left:-30px;top:29px}.timeline-item::after,.timeline-left::after,.timeline-right::after{left:-24px;top:34px;width:24px}.timeline-content{padding:20px}.timeline-content::before{inset:7px;border-radius:13px}.timeline-heading{font-size:1.14rem}.timeline-desc{font-size:.94rem}}
@media (prefers-reduced-motion:reduce){.timeline-item{opacity:1;transform:none;transition:none}.timeline-item::before{animation:none}.timeline-content{transition:none}}

/* Reset toward the OW/MR family while keeping the Runeterra theme. */
#hero{display:flex;flex-direction:column;justify-content:center;align-items:stretch}
#hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:160px;background:linear-gradient(to bottom,transparent,rgba(4,6,11,.94) 72%,var(--bg-deepest));pointer-events:none;z-index:1}
.hero-banner-container{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;animation:runeterraBannerDrift 18s ease-in-out infinite alternate}
.hero-banner-art{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%;opacity:.68;filter:saturate(.92) contrast(1.06) brightness(.7)}
.hero-banner-mark{display:none}
.hero-banner-fade{position:absolute;inset:0;background:radial-gradient(circle at 72% 26%,rgba(var(--accent-rgb),.16),transparent 38%),linear-gradient(90deg,rgba(4,6,11,.92) 0%,rgba(4,6,11,.8) 33%,rgba(4,6,11,.42) 62%,rgba(4,6,11,.66) 100%),linear-gradient(180deg,rgba(4,6,11,.18) 0%,rgba(4,6,11,.78) 100%)}
@keyframes runeterraBannerDrift{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(-18px,-10px,0) scale(1.04)}}
.hero-glow-a{width:560px;height:560px;top:-20%;left:-14%}
.hero-glow-b{width:430px;height:430px;right:-4%;top:28%;opacity:.75}
.hero-ring,.hero-sigil{display:none}
.hero-layout{display:block;max-width:var(--container-max);min-height:calc(100vh - 190px);padding-top:86px;text-align:center}
.hero-content{position:relative;z-index:2;max-width:860px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.hero-title{font-family:var(--font-heading);font-weight:700;font-size:clamp(3.5rem,8vw,5.5rem);margin-bottom:16px;letter-spacing:.05rem;line-height:1;text-shadow:0 12px 30px rgba(0,0,0,0.6)}
.accent-line{color:transparent;background:linear-gradient(180deg,#fff4d4 0%,#e1c28c 30%,#a8864f 100%);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 4px 12px rgba(200,170,110,0.4));position:relative;-webkit-text-stroke:0}
.accent-line::after{content:"RUNETERRA";position:absolute;inset:0;color:rgba(200,170,110,.4);filter:blur(24px);z-index:-1}
.hero-subtitle{max-width:60ch;font-size:1.15rem;color:var(--text-secondary);text-shadow:0 4px 12px rgba(0,0,0,0.8);margin-bottom:34px}
.hero-actions{margin:0 0 42px;gap:20px;display:flex;align-items:center;justify-content:center}
.hero-cta{min-height:54px;display:inline-flex;align-items:center;padding:0 26px;border-radius:999px;font-size:.88rem;letter-spacing:.14rem;background:linear-gradient(135deg,rgba(200,170,110,.25),rgba(200,170,110,.05)),rgba(0,0,0,.4);border:1px solid rgba(200,170,110,.4);color:var(--accent-strong);transition:all 0.3s ease}
.hero-cta:hover{background:linear-gradient(135deg,rgba(200,170,110,.35),rgba(200,170,110,.1)),rgba(0,0,0,.6);transform:translateY(-3px);border-color:var(--accent-strong);box-shadow:0 12px 24px rgba(200,170,110,.2)}
.hero-secondary-link{font-size:.84rem;letter-spacing:.12rem;text-transform:uppercase}
.hero-stats{display:flex;justify-content:center;flex-wrap:wrap;gap:18px;max-width:100%}
.stat-item{min-width:150px;padding:18px 20px 16px;border-radius:18px;background:linear-gradient(180deg,rgba(200,170,110,.04),transparent),rgba(7,10,16,.5);border:1px solid rgba(200,170,110,.16);backdrop-filter:blur(16px);box-shadow:0 12px 24px rgba(0,0,0,0.4)}
.stat-number{font-size:clamp(1.65rem,3.5vw,2.4rem);margin-bottom:6px;display:block;text-shadow:0 4px 12px rgba(200,170,110,.3)}
.stat-label{font-size:.78rem;letter-spacing:.16rem;color:var(--text-secondary);display:block}
.scroll-indicator{bottom:20px}

.section-shell{padding-top:96px}
.section-header{max-width:780px;margin:0 auto 28px}
.section-badge{margin-bottom:12px;font-size:.72rem;letter-spacing:.18rem}
.section-title{font-size:clamp(1.9rem,3.5vw,2.8rem);margin-bottom:12px}
.section-slab{padding:24px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.008)),rgba(7,10,16,.88);box-shadow:0 18px 44px rgba(0,0,0,.24)}
.section-slab::before{background:linear-gradient(180deg,rgba(var(--accent-rgb),.06),transparent 30%),radial-gradient(circle at bottom right,rgba(96,165,250,.05),transparent 24%);opacity:.7}
.map-container{height:68vh;min-height:500px;border-radius:20px}
.faction-card,.rel-selector-sidebar,.rel-focus-display,.timeline-overview-card,.timeline-content{border-radius:20px}
.faction-card{padding:22px}
.rel-interface{gap:18px}
.timeline-overview{gap:12px}

#footer{max-width:none;margin:0;padding:50px 8%;background:var(--bg-deep);border-top:1px solid var(--border)}
.footer-content{text-align:center;max-width:640px;margin:0 auto}
.footer-logo{display:flex;align-items:center;justify-content:center;gap:12px;font-family:var(--font-heading);font-size:1.06rem;letter-spacing:.12rem;margin-bottom:18px;color:var(--text-muted)}
.footer-logo img{width:34px;height:34px;opacity:.86;filter:drop-shadow(0 0 10px rgba(var(--accent-rgb),.18))}
.footer-note{display:block;font-size:.8rem;line-height:1.6;color:var(--text-muted);margin-bottom:8px}
.footer-credit-link,.kofi-link{color:var(--accent);font-weight:600;text-decoration:none;transition:all .2s ease;padding:2px 6px;border-radius:4px}
.footer-credit-link:hover,.footer-credit-link:focus-visible,.kofi-link:hover,.kofi-link:focus-visible{color:#fff;background:rgba(var(--accent-rgb),.2)}

@media (max-width:1240px){.hero-layout{min-height:auto;padding-top:72px}.hero-banner-art{object-position:center 36%}}
@media (max-width:900px){.hero-banner-art{object-position:center 32%;opacity:.62}}
@media (max-width:768px){#hero{padding-top:104px}#hero::after{height:120px}.hero-layout{padding-top:36px}.hero-content{align-items:center;text-align:center;margin:0 auto}.hero-subtitle{max-width:36ch}.hero-actions{justify-content:center}.hero-stats{justify-content:center}.hero-banner-art{object-position:center 28%;opacity:.54}.hero-banner-fade{background:linear-gradient(180deg,rgba(4,6,11,.26) 0%,rgba(4,6,11,.5) 30%,var(--bg-deepest) 88%),linear-gradient(90deg,rgba(4,6,11,.54) 0%,rgba(4,6,11,.14) 60%,rgba(4,6,11,.54) 100%)}.section-header{margin-bottom:24px}.section-slab{padding:22px}}
@media (max-width:560px){.hero-title{font-size:2.4rem}.stat-item{min-width:min(100%,220px)}}
@media (max-width:768px){.hero-actions{align-items:center}.hero-cta{width:auto}.hero-secondary-link{text-align:center}}
@media (max-width:768px){
    #main-nav{overflow:visible}
    .map-zoom-controls{left:16px;right:auto;bottom:16px}
    .nav-links{
        position:absolute;
        top:calc(100% + 1px);
        left:0;
        right:0;
        bottom:auto;
        min-height:calc(100vh - 74px);
        padding:28px 20px 34px;
        gap:14px;
        align-items:center;
        justify-content:flex-start;
        border-top:1px solid rgba(var(--accent-rgb),.22);
        background:
            radial-gradient(circle at 50% -10%,rgba(var(--accent-rgb),.16),transparent 46%),
            linear-gradient(180deg,rgba(5,8,14,.98) 0%,rgba(4,6,11,.995) 60%,rgba(3,5,10,1) 100%);
        -webkit-backdrop-filter:blur(22px);
        backdrop-filter:blur(22px);
        overflow-y:auto;
        overscroll-behavior:contain;
        box-shadow:0 20px 46px rgba(0,0,0,.55);
    }
    .nav-links .nav-link{
        width:min(320px,100%);
        min-height:46px;
        display:inline-flex;
        align-items:center;
        justify-content:center;
        text-align:center;
        border-radius:14px;
        border:1px solid rgba(255,255,255,.08);
        background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
        color:var(--text-primary);
        font-family:var(--font-heading);
        font-size:.94rem;
        letter-spacing:.12rem;
    }
    .nav-links .nav-link:hover,
    .nav-links .nav-link:focus-visible{
        border-color:rgba(var(--accent-rgb),.45);
        background:linear-gradient(180deg,rgba(var(--accent-rgb),.2),rgba(var(--accent-rgb),.08));
        color:var(--accent-strong);
    }
    .nav-links .nav-kofi-btn{
        width:min(320px,100%);
        justify-content:center;
        margin-top:8px;
        border-color:rgba(var(--accent-rgb),.4);
        background:linear-gradient(135deg,rgba(var(--accent-rgb),.22),rgba(var(--accent-rgb),.08)),rgba(0,0,0,.24);
        letter-spacing:.12rem;
    }
}

.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.map-a11y-hint{margin:6px auto 18px;color:var(--text-muted);font-size:.88rem;max-width:760px;line-height:1.45}
.map-btn:focus-visible,.zoom-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2)}
#network-canvas:focus-visible{box-shadow:inset 0 0 0 2px var(--accent),inset 0 0 0 4px rgba(var(--accent-rgb),.25)}

.modal-back{position:absolute;top:20px;left:20px;min-width:112px;height:38px;padding:0 14px;border-radius:999px;background:rgba(255,255,255,.05);color:var(--text-secondary);font-size:.72rem;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;transition:all .25s ease;z-index:10;border:1px solid rgba(255,255,255,.08);cursor:pointer}
.modal-back:hover,.modal-back:focus-visible{color:var(--accent-strong);border-color:rgba(var(--accent-rgb),.4);background:rgba(var(--accent-rgb),.16)}
.modal-back.hidden{display:none}

.modal-body{position:relative}
.modal-body.is-loading>*:not(.modal-skeleton-overlay){opacity:0;pointer-events:none}
.modal-skeleton-overlay{position:absolute;inset:24px;display:none;gap:14px}
.modal-body.is-loading .modal-skeleton-overlay{display:grid}
.skeleton-line,.skeleton-chip{border-radius:6px;background:linear-gradient(90deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.18) 45%,rgba(255,255,255,.05) 100%);background-size:220% 100%;animation:skeletonFlow 1.2s ease-in-out infinite}
.skeleton-line{height:14px}
.skeleton-line.long{width:100%}
.skeleton-line.medium{width:72%}
.skeleton-line.short{width:42%}
.skeleton-chip{height:56px}
.img-skeleton{background:linear-gradient(90deg,rgba(255,255,255,.08) 0%,rgba(255,255,255,.2) 45%,rgba(255,255,255,.08) 100%);background-size:220% 100%;animation:skeletonFlow 1.2s ease-in-out infinite;color:transparent!important}
@keyframes skeletonFlow{0%{background-position:200% 0}100%{background-position:-30% 0}}

.command-palette{position:fixed;inset:0;z-index:10030;background:rgba(4,7,14,.85);backdrop-filter:blur(8px) saturate(140%);padding:18vh 24px 24px}
.command-palette.hidden{display:none}
.command-palette-panel{max-width:760px;margin:0 auto;border:1px solid rgba(var(--accent-rgb),.42);background:linear-gradient(180deg,rgba(19,24,39,.96),rgba(12,16,26,.98));border-radius:10px;box-shadow:0 25px 80px rgba(0,0,0,.65),0 0 28px rgba(var(--accent-rgb),.18);overflow:hidden}
.command-palette-head{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.08)}
.command-palette-head h2{margin:0;font-family:var(--font-heading);font-size:.9rem;letter-spacing:2px;text-transform:uppercase;color:var(--accent)}
.command-shortcut-hint{font-size:.68rem;letter-spacing:1px;color:var(--text-muted);border:1px solid rgba(255,255,255,.12);padding:4px 8px;border-radius:4px}
.command-input-wrap{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.05)}
#command-palette-input{width:100%;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:rgba(255,255,255,.04);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;padding:12px 14px}
#command-palette-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2)}
.command-results{max-height:min(52vh,460px);overflow-y:auto;padding:8px}
.command-result{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;width:100%;border:1px solid transparent;border-radius:6px;padding:10px 12px;background:transparent;color:var(--text-primary);text-align:left;cursor:pointer;transition:all .2s ease}
.command-result:hover,.command-result.active{background:rgba(var(--accent-rgb),.14);border-color:rgba(var(--accent-rgb),.45)}
.command-result-icon{font-size:.75rem;letter-spacing:1px;text-transform:uppercase;color:var(--accent)}
.command-result-label{font-family:var(--font-heading);font-weight:700;letter-spacing:.6px}
.command-result-meta{color:var(--text-muted);font-size:.76rem;text-transform:uppercase;letter-spacing:1px}
.command-empty{padding:14px;color:var(--text-muted);font-size:.9rem}

@media (max-width:768px){
    .modal-back{top:12px;left:12px;height:36px;min-width:102px;padding:0 12px;font-size:.68rem}
    .modal-close{top:12px;right:12px;width:38px;height:38px}
    .command-palette{padding:12vh 12px 12px}
    .command-palette-head{padding:12px}
    .command-input-wrap{padding:10px}
    .command-result{padding:9px 10px}
}

/* Hub Link Center */
.nav-hub-link-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: opacity 0.2s ease;
    z-index: 10;
}
.nav-hub-link-center:hover {
    opacity: 0.7;
}
.nav-hub-icon {
    width: 38px;
    height: 38px;
}
@media (max-width: 768px) {
    .nav-hub-link-center .nav-hub-text { display: none; }
}

@media (max-width: 768px) {
    #main-nav {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
        align-items: center;
        column-gap: 10px;
    }
    .site-switcher {
        justify-self: start;
        min-width: 0;
    }
    .site-switcher-toggle {
        gap: 8px;
        min-width: 0;
    }
    .nav-logo {
        gap: 8px;
        min-width: 0;
        max-width: 100%;
    }
    .nav-logo-mark {
        width: 32px;
        height: 32px;
        padding: 5px;
    }
    .nav-logo-text {
        font-size: 0.84rem;
        letter-spacing: 0.1rem;
        white-space: nowrap;
    }
    .nav-hub-link-center {
        position: static;
        transform: none;
        justify-self: center;
    }
    .nav-hub-icon {
        width: 32px;
        height: 32px;
    }
    .mobile-menu-toggle {
        justify-self: end;
    }
}

.site-switcher-menu {
    min-width: 300px;
    max-width: min(340px, calc(100vw - 32px));
    padding: 10px;
}

.site-switcher-link {
    position: relative;
    align-items: center;
    gap: 14px;
    min-height: 58px;
    padding: 12px 14px 12px 16px;
    overflow: hidden;
}

.site-switcher-link::before {
    content: "";
    position: absolute;
    top: 12px;
    bottom: 12px;
    left: 0;
    width: 2px;
    background: var(--switcher-accent, var(--accent));
    opacity: 0.45;
}

.site-switcher-link:hover::before,
.site-switcher-link:focus-visible::before {
    opacity: 1;
    box-shadow: 0 0 14px var(--switcher-glow, rgba(255, 255, 255, 0.4));
}

.site-switcher-link-icon {
    flex: 0 0 34px;
    width: 34px;
    height: 34px;
}

.site-switcher-link-label {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 4px;
    line-height: 1.12;
    letter-spacing: 0;
}

.site-switcher-link-kicker {
    color: var(--text-muted, rgba(255, 255, 255, 0.58));
    font-size: 0.56rem;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.site-switcher-link-accent {
    font-size: 0.92rem;
    letter-spacing: 1.45px;
    text-transform: uppercase;
}

.site-switcher-link.ow-link { --switcher-accent: #d28cff; --switcher-glow: rgba(187, 41, 255, 0.55); }
.site-switcher-link.mr-link { --switcher-accent: #ff5c7a; --switcher-glow: rgba(255, 47, 96, 0.5); }
.site-switcher-link.cp-link { --switcher-accent: #fcee09; --switcher-glow: rgba(252, 238, 9, 0.55); }
.site-switcher-link.lol-link { --switcher-accent: #c8aa6e; --switcher-glow: rgba(200, 170, 110, 0.48); }
.site-switcher-link.ymir-link { --switcher-accent: #ff8a3d; --switcher-glow: rgba(255, 122, 48, 0.48); }
.site-switcher-link.shinobi-link { --switcher-accent: #ff9d3d; --switcher-glow: rgba(249, 115, 22, 0.55); }
.site-switcher-link.wf-link { --switcher-accent: #22d3ee; --switcher-glow: rgba(34, 211, 238, 0.55); }
.site-switcher-link.cod-link { --switcher-accent: #d8d7c4; --switcher-glow: rgba(216, 215, 196, 0.5); }
.site-switcher-link.tes-link { --switcher-accent: #d8b36a; --switcher-glow: rgba(216, 179, 106, 0.48); }

.site-switcher-link .site-switcher-link-accent {
    color: var(--switcher-accent, currentColor);
    text-shadow: 0 0 12px var(--switcher-glow, transparent);
}

.site-switcher-toggle .nav-logo-icon-container,
.site-switcher-toggle .nav-logo-mark {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.site-switcher-link[aria-disabled="true"] {
    opacity: 0.68;
    cursor: default;
}

.site-switcher-link[aria-disabled="true"]:hover,
.site-switcher-link[aria-disabled="true"]:focus-visible {
    opacity: 0.78;
    background: rgba(255, 255, 255, 0.05);
}

.language-switcher {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 12px;
    border: 1px solid var(--border-strong, var(--border, rgba(255, 255, 255, 0.16)));
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-primary);
}

.language-switcher label {
    color: var(--text-secondary, rgba(255, 255, 255, 0.68));
    font-size: 0.68rem;
    letter-spacing: 0.08rem;
    text-transform: uppercase;
}

.language-switcher select {
    min-width: 96px;
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    font-size: 0.82rem;
    text-transform: uppercase;
    outline: 0;
}

.language-switcher select option {
    color: #111827;
    background: #ffffff;
}

@media (max-width: 768px) {
    .language-switcher {
        width: 100%;
        justify-content: space-between;
    }

    .language-switcher select {
        flex: 1;
        text-align: right;
    }
}

@media (max-width: 640px) {
    .rel-interface {
        gap: 16px;
    }
    .rel-selector-sidebar {
        min-width: 0;
        padding: 14px;
    }
    .rel-faction-list {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 6px;
        max-height: none;
        overflow: visible;
        padding-right: 0;
    }
    .rel-faction-btn {
        min-width: 0;
        min-height: 66px;
        flex-direction: column;
        justify-content: center;
        gap: 6px;
        padding: 9px 5px;
        text-align: center;
        white-space: normal;
        font-size: 0.68rem;
        line-height: 1.18;
        font-weight: 800;
        overflow-wrap: anywhere;
    }
    .rel-faction-btn:hover,
    .rel-faction-btn:focus-visible,
    .rel-faction-btn.active {
        transform: translateY(-1px);
    }
    .rel-faction-btn svg {
        width: 22px;
        height: 22px;
    }
    .rel-faction-btn span {
        display: block;
        max-width: 100%;
        overflow-wrap: anywhere;
    }
}
