:root{--void-black:#0a0a0a;--void-deep:#0d0015;--void-purple:#7b2fff;--void-purple-dim:#4a1a99;--void-purple-glow:#9b4dff;--void-magenta:#ff00ff;--void-magenta-dim:#aa00aa;--void-pink:#ff44cc;--void-gold:#ffd700;--void-blue:#4466ff;--void-red:#ff4444;--void-text:#c8b8e8;--void-text-dim:#7a6a9a;--era-color:var(--void-purple)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--void-black);color:var(--void-text);font-family:'VT323',monospace;font-size:18px;overflow-x:hidden}
body.loading{overflow:hidden}
::selection{background:var(--void-purple);color:#fff}

/* LOADING SCREEN */
.load-screen{position:fixed;inset:0;z-index:99999;background:var(--void-black);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;overflow:visible}
.load-screen.phase-opening{cursor:default}
.load-screen.phase-opening .load-text,.load-screen.phase-opening .load-prompt{opacity:0!important;transition:opacity .4s ease}
.load-screen.phase-reveal{background:transparent;transition:background 1.5s ease}
.load-screen.phase-reveal .load-portal{opacity:0;transition:opacity 1.5s ease .3s}
.load-screen.phase-done{display:none}
.load-portal{position:relative;width:300px;height:300px;transition:transform 2s cubic-bezier(.25,.1,.25,1);overflow:visible}
.load-screen.phase-opening .load-portal{transform:scale(3.5)}
.load-portal canvas{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:700px;height:700px;overflow:visible}
.load-text{font-family:'Press Start 2P',cursive;font-size:clamp(16px,4vw,28px);color:var(--void-purple);text-shadow:0 0 20px var(--void-purple),0 0 60px rgba(123,47,255,.4);margin-top:2rem;opacity:0;animation:lt-fade 2s ease 1.5s both;letter-spacing:3px;text-align:center;line-height:1.4}
.load-prompt{font-family:'Silkscreen',cursive;font-size:12px;color:var(--void-text-dim);letter-spacing:2px;text-transform:uppercase;margin-top:1.5rem;opacity:0;animation:lt-fade 1.5s ease 2.5s both}
.load-prompt span{animation:lt-blink 1.5s ease-in-out infinite}
@keyframes lt-fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes lt-blink{0%,100%{opacity:.4}50%{opacity:1}}

/* Hero elements hidden until site reveal */
.hero-logo,.hero .sub,.hero .tagline,.hero .tagline-2,.hero .cta,.hero .sd{opacity:0;transform:translateY(15px)}
body.site-revealed .hero .sub{animation:site-in .8s ease .6s both}
body.site-revealed .hero .tagline{animation:site-in .8s ease .9s both}
body.site-revealed .hero .tagline-2{animation:site-in .8s ease 1.1s both}
body.site-revealed .hero .cta{animation:site-in .8s ease 1.3s both}
body.site-revealed .hero .sd{animation:site-in .8s ease 1.5s both}
/* Nav and filter bar hidden until reveal */
nav,.filter-bar,.audio-player{opacity:0;transition:opacity .6s ease}
body.site-revealed nav{opacity:1;transition-delay:.2s}
body.site-revealed .filter-bar{opacity:1;transition-delay:.4s}
body.site-revealed .audio-player{opacity:1;transition-delay:.6s}
@keyframes site-in{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--void-deep)}::-webkit-scrollbar-thumb{background:var(--void-purple-dim)}
body::after{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);pointer-events:none;z-index:10000}
.starfield{position:fixed;inset:0;z-index:0;overflow:hidden}
.star-layer{position:absolute;width:100%;height:200%;will-change:transform}
nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,10,10,.95);backdrop-filter:blur(8px);border-bottom:2px solid var(--void-purple-dim);height:50px;display:flex;align-items:center;padding:0 1rem;gap:1.5rem}
nav .logo{font-family:'Press Start 2P',cursive;font-size:11px;color:var(--void-purple);text-shadow:0 0 10px var(--void-purple-glow);white-space:nowrap;letter-spacing:1px}
nav a{color:var(--void-text-dim);text-decoration:none;font-family:'Silkscreen',cursive;font-size:11px;letter-spacing:1px;text-transform:uppercase;transition:.2s}
nav a:hover{color:var(--void-purple-glow);text-shadow:0 0 8px var(--void-purple)}
.filter-bar{position:fixed;top:50px;left:0;right:0;z-index:999;background:rgba(10,10,10,.92);backdrop-filter:blur(4px);border-bottom:1px solid rgba(123,47,255,.2);padding:8px 1rem 8px 1rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-bar label{font-family:'Silkscreen',cursive;font-size:10px;color:var(--void-text-dim);letter-spacing:1px;text-transform:uppercase;margin-right:4px}
.fbtn{font-family:'Silkscreen',cursive;font-size:10px;padding:4px 10px;background:transparent;border:1px solid var(--void-purple-dim);color:var(--void-text-dim);cursor:pointer;text-transform:uppercase;letter-spacing:1px;transition:.2s}
.fbtn:hover{border-color:var(--void-purple);color:var(--void-purple-glow)}
.fbtn.on{background:var(--void-purple);color:#fff;border-color:var(--void-purple)}
.fbtn.on[data-t="cataclysm"]{background:var(--void-magenta);border-color:var(--void-magenta)}
.fbtn.on[data-t="war"]{background:var(--void-red);border-color:var(--void-red)}
.fbtn.on[data-t="creation"]{background:#cc8800;border-color:#cc8800}
.fbtn.on[data-t="discovery"]{background:var(--void-blue);border-color:var(--void-blue)}
.fbtn.on[data-t="character"]{background:var(--void-pink);border-color:var(--void-pink)}
.minimap{position:fixed;right:10px;top:115px;bottom:30px;width:26px;z-index:998;display:flex;flex-direction:column;gap:2px}
.mm-e{min-height:4px;border:1px solid rgba(123,47,255,.3);cursor:pointer;transition:.2s;position:relative;opacity:.4}
.mm-e:hover{opacity:.8;transform:scaleX(1.4);transform-origin:right}
.mm-e.act{opacity:1;border-color:#fff;box-shadow:0 0 6px rgba(255,255,255,.3)}
.mm-e .mml{position:absolute;right:34px;top:50%;transform:translateY(-50%);font-family:'Silkscreen',cursive;font-size:8px;color:var(--void-text-dim);white-space:nowrap;opacity:0;transition:.2s;pointer-events:none}
.mm-e:hover .mml{opacity:1}
.mm-pos{position:absolute;right:-3px;width:32px;height:2px;background:#fff;box-shadow:0 0 6px #fff;transition:top .12s ease;pointer-events:none;z-index:2}
.ctt{position:fixed;z-index:9000;background:rgba(13,0,21,.97);border:2px solid var(--void-purple);padding:12px;width:270px;pointer-events:none;opacity:0;transition:opacity .15s;box-shadow:0 0 20px rgba(123,47,255,.3)}
.ctt.vis{opacity:1}
.ctt .ct-img{width:60px;height:60px;object-fit:cover;image-rendering:pixelated;border:2px solid var(--void-purple-dim);margin-bottom:8px;display:none}
.ctt .ct-img.has-img{display:block}
.ctt .ci{font-size:28px;margin-bottom:6px;display:block}
.ctt .ci.has-img{display:none}
.ctt .cn{font-family:'Silkscreen',cursive;font-size:13px;color:var(--void-purple-glow);margin-bottom:3px}
.ctt .ct2{font-family:'VT323',monospace;font-size:16px;color:var(--void-magenta-dim);margin-bottom:6px}
.ctt .cd{font-family:'VT323',monospace;font-size:15px;color:var(--void-text-dim);line-height:1.5}
.hero{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;overflow:hidden}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:35vh;background:linear-gradient(to bottom,transparent 0%,rgba(10,10,10,.4) 30%,rgba(10,10,10,.85) 65%,var(--void-black) 100%);pointer-events:none;z-index:2}

/* THE MAW — swirling vortex canvas */
.maw{position:absolute;width:700px;height:700px;pointer-events:none}
.maw canvas{position:absolute;inset:0;width:100%;height:100%}
.maw-ring{position:absolute;border-radius:50%;border:2px solid rgba(123,47,255,.12);animation:maw-spin linear infinite}
.maw-ring.r1{inset:-10px;animation-duration:30s;border-color:rgba(123,47,255,.15)}
.maw-ring.r2{inset:-35px;border-color:rgba(170,0,255,.08);animation-duration:45s;animation-direction:reverse;border-style:dashed}
.maw-ring.r3{inset:-65px;border-color:rgba(255,0,255,.05);animation-duration:60s;border-width:1px}
.maw-ring.r4{inset:-100px;border-color:rgba(123,47,255,.03);animation-duration:80s;border-width:1px;border-style:dotted}
@keyframes maw-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Accretion disk — particles spiralling into the maw */
.accretion-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}

/* Logo */
.hero-logo{position:relative;z-index:3;width:clamp(200px,35vw,340px);height:auto;image-rendering:pixelated;filter:drop-shadow(0 0 30px rgba(123,47,255,.5)) drop-shadow(0 0 60px rgba(123,47,255,.2));margin-bottom:1.5rem}
body.site-revealed .hero-logo{animation:site-in .8s ease .3s both,logo-float 6s ease-in-out 1.1s infinite}
@keyframes logo-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* Hero text */
.hero .sub{font-family:'VT323',monospace;font-size:clamp(16px,2.5vw,24px);color:var(--void-text-dim);letter-spacing:4px;text-transform:uppercase;margin-bottom:1.5rem;z-index:3;position:relative}
.hero .tagline{font-family:'VT323',monospace;font-size:18px;color:var(--void-text-dim);max-width:540px;line-height:1.7;margin-bottom:.8rem;z-index:3;position:relative}
.hero .tagline em{color:var(--void-magenta-dim);font-style:normal}
.hero .tagline-2{font-family:'VT323',monospace;font-size:17px;color:var(--void-text-dim);max-width:480px;line-height:1.6;margin-bottom:2rem;z-index:3;position:relative}
.hero .cta{font-family:'Silkscreen',cursive;font-size:13px;padding:12px 30px;background:transparent;color:var(--void-purple);border:3px solid var(--void-purple);cursor:pointer;text-transform:uppercase;letter-spacing:2px;z-index:3;position:relative;text-decoration:none;display:inline-block;transition:.3s}
.hero .cta:hover{background:var(--void-purple);color:#fff;box-shadow:0 0 20px var(--void-purple),0 0 40px rgba(123,47,255,.3);transform:translateY(-2px)}
.yt-link{position:relative;z-index:3;margin-top:20px;font-family:'Silkscreen',cursive;font-size:10px;color:var(--void-text-dim);text-decoration:none;letter-spacing:2px;display:inline-block;transition:.3s;opacity:0;transform:translateY(15px)}
body.site-revealed .yt-link{animation:site-in .8s ease 1.6s both}
.yt-link:hover{color:var(--void-purple-glow)}

.sd{position:absolute;bottom:2rem;z-index:3;animation:bd 2s ease-in-out infinite}
.sd span{display:block;width:12px;height:12px;border-right:2px solid var(--void-purple-dim);border-bottom:2px solid var(--void-purple-dim);transform:rotate(45deg);margin:-4px auto}
@keyframes bd{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(8px);opacity:1}}
.era-s{position:relative;z-index:1;padding:5rem 0 2rem;min-height:50vh}
.era-s.fout{display:none}
.era-hd{text-align:center;padding:0 2rem 2rem;position:relative;z-index:2}
.era-num{font-family:'Press Start 2P',cursive;font-size:11px;letter-spacing:3px;margin-bottom:6px;text-transform:uppercase}
.era-nm{font-family:'Press Start 2P',cursive;font-size:clamp(16px,3vw,26px);margin-bottom:8px;text-shadow:0 0 12px currentColor;line-height:1.3}
.era-sp{font-family:'VT323',monospace;font-size:18px;color:var(--void-text-dim);margin-bottom:12px;letter-spacing:2px}
.era-ds{font-family:'VT323',monospace;font-size:20px;color:var(--void-text-dim);max-width:700px;margin:0 auto;line-height:1.6;padding:0 1rem}
.vtl{position:relative;max-width:860px;margin:0 auto;padding:1rem 2rem 2rem}
.vtl::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%)}
.evt{position:relative;display:flex;margin-bottom:1.5rem;opacity:0;transform:translateY(25px);transition:opacity .5s ease,transform .5s ease}
.evt.vis{opacity:1;transform:translateY(0)}
.evt.fout{display:none}
.evt.L{flex-direction:row-reverse}.evt.R{flex-direction:row}
.evt .ec{width:calc(50% - 36px);cursor:pointer}
.evt .es{width:calc(50% - 36px)}
.evt .nd{position:absolute;left:50%;top:18px;width:14px;height:14px;border:2px solid var(--era-color);background:var(--void-deep);transform:translateX(-50%);z-index:3;transition:.3s}
.evt .nd.diamond{transform:translateX(-50%) rotate(45deg)}
.evt .nd.circle{border-radius:50%}
.evt .nd.major{width:20px;height:20px;border-width:3px;box-shadow:0 0 8px color-mix(in srgb,var(--era-color) 50%,transparent)}
.evt:hover .nd{background:var(--era-color);box-shadow:0 0 12px var(--era-color)}
.ecard{background:rgba(13,0,21,.85);border:2px solid rgba(123,47,255,.2);padding:12px 14px;transition:.3s}
.evt:hover .ecard{border-color:var(--era-color);box-shadow:0 0 16px color-mix(in srgb,var(--era-color) 15%,transparent)}
.ecard .dt{font-family:'Press Start 2P',cursive;font-size:9px;color:var(--void-magenta-dim);margin-bottom:6px;letter-spacing:1px}
.ecard .tt{font-family:'Silkscreen',cursive;font-size:16px;margin-bottom:6px;line-height:1.4}
.ecard .ds{font-family:'VT323',monospace;font-size:19px;color:var(--void-text-dim);line-height:1.5}
.ecard .tgs{margin-top:6px;display:flex;gap:3px;flex-wrap:wrap}
.etag{font-family:'Silkscreen',cursive;font-size:9px;padding:3px 7px;border:1px solid;text-transform:uppercase;letter-spacing:1px}
.etag.cataclysm{color:var(--void-magenta);border-color:var(--void-magenta-dim)}
.etag.creation{color:var(--void-gold);border-color:rgba(255,215,0,.4)}
.etag.war{color:var(--void-red);border-color:rgba(255,68,68,.4)}
.etag.discovery{color:var(--void-blue);border-color:rgba(68,102,255,.4)}
.etag.character{color:var(--void-pink);border-color:rgba(255,68,204,.4)}
.ecard .exh{font-family:'Silkscreen',cursive;font-size:10px;color:var(--void-text-dim);margin-top:8px;opacity:0;transition:.2s;letter-spacing:1px}
.evt:hover .exh{opacity:.5}
.edtl{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease,border-width .2s;background:rgba(13,0,21,.95);border:0 solid rgba(123,47,255,.15);margin-top:0}
.edtl.open{max-height:50vh;padding:12px 14px;border-width:2px;margin-top:6px;overflow-y:auto}
.edtl::-webkit-scrollbar{width:5px}
.edtl::-webkit-scrollbar-track{background:rgba(13,0,21,.5)}
.edtl::-webkit-scrollbar-thumb{background:var(--void-purple-dim);border:1px solid var(--void-purple)}
.edtl{scrollbar-width:thin;scrollbar-color:var(--void-purple-dim) rgba(13,0,21,.5)}
.edtl .lore{font-family:'VT323',monospace;font-size:19px;color:var(--void-text);line-height:1.7}
.edtl .cref{display:flex;align-items:center;gap:8px;margin-top:10px;padding:8px;border:1px solid var(--void-purple-dim);background:rgba(123,47,255,.05);cursor:default}
.cref .cico{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:22px;border:2px solid var(--void-purple-dim);background:rgba(13,0,21,.8);flex-shrink:0}
.cref .cinf .cname{font-family:'Silkscreen',cursive;font-size:13px;color:var(--void-purple-glow)}
.cref .cinf .ctit{font-family:'VT323',monospace;font-size:16px;color:var(--void-text-dim)}
.ediv{height:80px;position:relative;z-index:2;display:flex;align-items:center;justify-content:center}
.ediv::before{content:'';position:absolute;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--void-purple-dim),transparent)}
.ediv .dia{width:8px;height:8px;border:2px solid var(--void-purple-dim);transform:rotate(45deg);background:var(--void-deep);z-index:1}
/* AUDIO PLAYER */
.audio-player{position:fixed;bottom:12px;left:12px;z-index:999;background:rgba(13,0,21,.95);border:2px solid var(--void-purple-dim);padding:8px 12px;display:flex;align-items:center;gap:10px;font-family:'Silkscreen',cursive;font-size:10px;color:var(--void-text-dim);letter-spacing:1px;transition:border-color .2s,box-shadow .2s;backdrop-filter:blur(6px)}
.audio-player:hover{border-color:var(--void-purple);box-shadow:0 0 12px rgba(123,47,255,.2)}
.ap-btn{background:none;border:2px solid var(--void-purple-dim);color:var(--void-purple);width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:.2s;padding:0;font-family:'VT323',monospace}
.ap-btn:hover{border-color:var(--void-purple);background:rgba(123,47,255,.15);box-shadow:0 0 8px rgba(123,47,255,.3)}
.ap-btn.playing{border-color:var(--void-magenta-dim);color:var(--void-magenta)}
.ap-title{text-transform:uppercase;max-width:200px;overflow:hidden;white-space:nowrap;position:relative}
.ap-title .ap-title-inner{display:inline-block;position:relative}
.ap-title.scrolling .ap-title-inner{animation:title-scroll var(--scroll-dur,6s) ease-in-out infinite alternate}
@keyframes title-scroll{0%,15%{transform:translateX(0)}85%,100%{transform:translateX(var(--scroll-dist,-50px))}}
.ap-vol{-webkit-appearance:none;appearance:none;width:60px;height:4px;background:var(--void-purple-dim);outline:none;cursor:pointer;border-radius:0}
.ap-vol::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;background:var(--void-purple);border:none;cursor:pointer}
.ap-vol::-moz-range-thumb{width:10px;height:10px;background:var(--void-purple);border:none;cursor:pointer;border-radius:0}
.ap-sfx{background:none;border:1px solid var(--void-purple-dim);color:var(--void-text-dim);font-family:'Silkscreen',cursive;font-size:8px;padding:3px 6px;cursor:pointer;letter-spacing:1px;transition:.2s;text-transform:uppercase}
.ap-sfx:hover{border-color:var(--void-purple);color:var(--void-purple-glow)}
.ap-sfx.off{opacity:.4}
.ap-no-track{font-style:italic;font-family:'VT323',monospace;font-size:13px;color:var(--void-text-dim)}
footer{position:relative;z-index:2;border-top:2px solid var(--void-purple-dim);padding:1.5rem;text-align:center;font-family:'Silkscreen',cursive;font-size:10px;color:var(--void-text-dim);letter-spacing:1px}
/* SPA PAGES */
.spa-page{display:none;position:relative;z-index:1;min-height:100vh;padding-top:100px}
.spa-page.active{display:block;animation:page-in .5s ease both}
@keyframes page-in{from{opacity:0}to{opacity:1}}
.page-home.active{padding-top:0}
.page-map{padding-top:50px!important}

/* PAGE HEADERS */
.pg-header{text-align:center;padding:0 2rem 3rem;position:relative;z-index:2}
.pg-header h2{font-family:'Press Start 2P',cursive;font-size:clamp(16px,3vw,26px);color:var(--void-purple);text-shadow:0 0 15px var(--void-purple);margin-bottom:.8rem}
.pg-header p{font-family:'VT323',monospace;font-size:20px;color:var(--void-text-dim);max-width:600px;margin:0 auto;line-height:1.6}

/* CHARACTERS PAGE */
.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;padding:0 3rem 4rem;max-width:1200px;margin:0 auto}
.char-card{background:rgba(13,0,21,.85);border:2px solid var(--void-purple-dim);overflow:hidden;transition:.3s;position:relative}
.char-card:hover{border-color:var(--void-purple);box-shadow:0 0 25px rgba(123,47,255,.2);transform:translateY(-4px)}
.char-card .char-img{width:100%;aspect-ratio:1;object-fit:cover;image-rendering:pixelated;display:block;border-bottom:2px solid var(--void-purple-dim)}
.char-card .char-placeholder{width:100%;aspect-ratio:1;background:rgba(123,47,255,.05);display:flex;align-items:center;justify-content:center;font-size:64px;border-bottom:2px solid var(--void-purple-dim)}
.char-card .char-body{padding:16px}
.char-card .char-name{font-family:'Silkscreen',cursive;font-size:16px;color:var(--void-purple-glow);margin-bottom:4px}
.char-card .char-title{font-family:'VT323',monospace;font-size:17px;color:var(--void-magenta-dim);margin-bottom:4px}
.char-card .char-era{font-family:'Silkscreen',cursive;font-size:9px;color:var(--void-text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.char-card .char-desc{font-family:'VT323',monospace;font-size:18px;color:var(--void-text-dim);line-height:1.5}
.char-card .char-role{display:inline-block;font-family:'Silkscreen',cursive;font-size:9px;padding:3px 8px;border:1px solid;text-transform:uppercase;letter-spacing:1px;margin-top:10px}
.char-card .char-role.deity{color:var(--void-purple);border-color:var(--void-purple-dim)}
.char-card .char-role.empress{color:var(--void-magenta);border-color:var(--void-magenta-dim)}
.char-card .char-role.villain{color:var(--void-red);border-color:rgba(255,68,68,.4)}
.char-theme-btn{display:inline-flex;align-items:center;gap:6px;font-family:'Silkscreen',cursive;font-size:9px;color:var(--void-text-dim);border:1px solid var(--void-purple-dim);background:rgba(13,0,21,.6);padding:4px 10px;cursor:pointer;letter-spacing:1px;margin-top:10px;margin-left:8px;transition:.3s;vertical-align:middle}
.char-theme-btn:hover{border-color:var(--void-purple);color:var(--void-purple-glow)}
.char-theme-btn.playing{border-color:var(--void-purple);color:var(--void-purple-glow);background:rgba(123,47,255,.08)}
.char-theme-btn .ctb-icon{font-size:12px;line-height:1}
.char-card .char-role.trainer{color:var(--void-gold);border-color:rgba(255,215,0,.4)}
.char-card .char-role.historical{color:var(--void-blue);border-color:rgba(68,102,255,.4)}

/* LOCATIONS PAGE */
.loc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;padding:0 3rem 4rem;max-width:1200px;margin:0 auto}
.loc-card{background:rgba(13,0,21,.85);border:2px solid var(--void-purple-dim);padding:20px;transition:.3s}
.loc-card:hover{border-color:var(--void-purple);box-shadow:0 0 20px rgba(123,47,255,.15)}
.loc-card .loc-name{font-family:'Silkscreen',cursive;font-size:16px;color:var(--void-purple-glow);margin-bottom:6px}
.loc-card .loc-sub{font-family:'VT323',monospace;font-size:16px;color:var(--void-magenta-dim);margin-bottom:10px}
.loc-card .loc-desc{font-family:'VT323',monospace;font-size:18px;color:var(--void-text-dim);line-height:1.5;margin-bottom:12px}
.loc-danger{display:flex;align-items:center;gap:6px;font-family:'Silkscreen',cursive;font-size:10px;text-transform:uppercase;letter-spacing:1px}
.loc-danger .bar{display:flex;gap:2px}
.loc-danger .pip{width:8px;height:12px;border:1px solid var(--void-purple-dim);background:transparent}
.loc-danger .pip.filled{background:var(--void-purple)}
.loc-danger .pip.filled.high{background:var(--void-red)}
.loc-danger .pip.filled.extreme{background:var(--void-magenta)}

/* CODEX PAGE */
.codex-grid{max-width:800px;margin:0 auto;padding:0 2rem 4rem}
.codex-entry{background:rgba(13,0,21,.85);border:2px solid var(--void-purple-dim);margin-bottom:1rem;transition:.3s}
.codex-entry:hover{border-color:var(--void-purple)}
.codex-head{padding:14px 18px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.codex-head h3{font-family:'Silkscreen',cursive;font-size:15px;color:var(--void-purple-glow)}
.codex-head .codex-arrow{font-family:'VT323',monospace;font-size:20px;color:var(--void-text-dim);transition:transform .3s}
.codex-entry.open .codex-arrow{transform:rotate(90deg)}
.codex-body{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.codex-entry.open .codex-body{max-height:60vh;padding:0 18px 18px;overflow-y:auto}
.codex-body::-webkit-scrollbar{width:5px}
.codex-body::-webkit-scrollbar-track{background:rgba(13,0,21,.5)}
.codex-body::-webkit-scrollbar-thumb{background:var(--void-purple-dim);border:1px solid var(--void-purple)}
.codex-body{scrollbar-width:thin;scrollbar-color:var(--void-purple-dim) rgba(13,0,21,.5)}
.codex-body p{font-family:'VT323',monospace;font-size:19px;color:var(--void-text-dim);line-height:1.6;margin-bottom:10px;word-wrap:break-word}
.codex-body p:last-child{margin-bottom:0}
.codex-cat{font-family:'Press Start 2P',cursive;font-size:11px;color:var(--void-text-dim);letter-spacing:2px;text-transform:uppercase;padding:2rem 0 1rem;text-align:center}

/* BLOG PAGE */
.blog-list{max-width:750px;margin:0 auto;padding:0 2rem 4rem}
.blog-post{background:rgba(13,0,21,.85);border:2px solid var(--void-purple-dim);padding:20px;margin-bottom:1.5rem;transition:.3s}
.blog-post:hover{border-color:var(--void-purple)}
.blog-post .blog-date{font-family:'Press Start 2P',cursive;font-size:8px;color:var(--void-magenta-dim);margin-bottom:8px;letter-spacing:1px}
.blog-post h3{font-family:'Silkscreen',cursive;font-size:16px;color:var(--void-purple-glow);margin-bottom:10px}
.blog-post p{font-family:'VT323',monospace;font-size:19px;color:var(--void-text-dim);line-height:1.6}

/* FACTIONS PAGE */
.faction-grid{max-width:900px;margin:0 auto;padding:0 2rem 4rem;display:flex;flex-direction:column;gap:1.5rem}
.faction-card{background:rgba(13,0,21,.85);border:2px solid var(--void-purple-dim);padding:22px;transition:.3s;position:relative}
.faction-card:hover{border-color:var(--void-purple);box-shadow:0 0 20px rgba(123,47,255,.15)}
.faction-card .fc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.faction-card .fc-name{font-family:'Silkscreen',cursive;font-size:17px;color:var(--void-purple-glow)}
.faction-card .fc-status{font-family:'Silkscreen',cursive;font-size:9px;padding:3px 8px;border:1px solid;text-transform:uppercase;letter-spacing:1px}
.fc-status.active{color:var(--void-gold);border-color:rgba(255,215,0,.4)}
.fc-status.defunct{color:var(--void-text-dim);border-color:rgba(122,106,154,.4)}
.fc-status.extinct{color:var(--void-red);border-color:rgba(255,68,68,.3)}
.fc-status.destroyed{color:var(--void-magenta);border-color:var(--void-magenta-dim)}
.faction-card .fc-sub{font-family:'VT323',monospace;font-size:17px;color:var(--void-magenta-dim);margin-bottom:12px}
.faction-card .fc-desc{font-family:'VT323',monospace;font-size:19px;color:var(--void-text-dim);line-height:1.6}
.faction-card .fc-desc p{margin-bottom:10px}
.faction-card .fc-desc p:last-child{margin-bottom:0}

/* FACTION BADGES on timeline events */
.etag.faction{color:var(--void-gold);border-color:rgba(255,215,0,.3);cursor:pointer;transition:.2s}
.etag.faction:hover{background:rgba(255,215,0,.15);border-color:var(--void-gold)}

/* BACK TO TOP */
.btt{position:fixed;bottom:60px;right:20px;z-index:998;width:40px;height:40px;background:rgba(13,0,21,.9);border:2px solid var(--void-purple-dim);color:var(--void-purple-glow);font-family:'VT323',monospace;font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transition:.3s}
.btt.vis{opacity:1;pointer-events:auto}
.btt:hover{border-color:var(--void-purple);box-shadow:0 0 12px rgba(123,47,255,.3)}

/* SEARCH */
.search-toggle{cursor:pointer;font-family:'Silkscreen',cursive;font-size:9px;color:var(--void-text-dim);letter-spacing:1px;transition:.2s}
.search-toggle:hover{color:var(--void-purple-glow)}
.search-overlay{position:fixed;inset:0;z-index:10000;background:rgba(10,10,10,.95);display:none;flex-direction:column;align-items:center;padding-top:15vh}
.search-overlay.open{display:flex}
.search-box{width:90%;max-width:500px;margin-bottom:1.5rem;position:relative}
.search-box input{width:100%;background:rgba(13,0,21,.9);border:2px solid var(--void-purple-dim);color:var(--void-text);font-family:'VT323',monospace;font-size:20px;padding:12px 16px;outline:none}
.search-box input:focus{border-color:var(--void-purple)}
.search-box input::placeholder{color:var(--void-text-dim)}
.search-results{width:90%;max-width:500px;max-height:50vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--void-purple-dim) rgba(13,0,21,.5)}
.search-results::-webkit-scrollbar{width:5px}
.search-results::-webkit-scrollbar-track{background:rgba(13,0,21,.5)}
.search-results::-webkit-scrollbar-thumb{background:var(--void-purple-dim)}
.sr-item{padding:12px 16px;border-bottom:1px solid rgba(123,47,255,.15);cursor:pointer;transition:.2s}
.sr-item:hover{background:rgba(123,47,255,.08)}
.sr-item .sr-page{font-family:'Silkscreen',cursive;font-size:8px;color:var(--void-magenta-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.sr-item .sr-title{font-family:'Silkscreen',cursive;font-size:13px;color:var(--void-purple-glow);margin-bottom:4px}
.sr-item .sr-ctx{font-family:'VT323',monospace;font-size:16px;color:var(--void-text-dim);line-height:1.4}
.sr-item .sr-ctx mark{background:none;color:var(--void-gold);font-weight:bold}
.search-close{position:absolute;top:20px;right:20px;font-size:28px;color:var(--void-text-dim);cursor:pointer;font-family:'VT323',monospace}
.search-close:hover{color:var(--void-purple-glow)}
.search-hint{font-family:'VT323',monospace;font-size:16px;color:var(--void-text-dim);text-align:center}

/* VOID MAP */
.void-map-wrap{position:relative;width:100%;height:calc(100vh - 50px);overflow:hidden;background:var(--void-black);user-select:none}
.void-map-wrap canvas{width:100%;height:100%;cursor:grab}
.void-map-wrap canvas:active{cursor:grabbing}
/* Two-level map selection: Map Type (Realms/Planes) + Layer (Void/Voidspace/etc) */
.map-type-selector{position:absolute;top:12px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:5}
.map-type-row{display:flex;gap:2px}
.mt-btn{background:rgba(13,0,21,.95);border:1px solid var(--void-purple-dim);color:var(--void-text-dim);font-family:'Silkscreen',cursive;font-size:10px;padding:5px 16px;cursor:pointer;transition:.2s;letter-spacing:1px;text-transform:uppercase}
.mt-btn:hover{border-color:var(--void-purple);color:var(--void-text)}
.mt-btn.active{border-color:var(--void-purple);color:var(--void-purple-glow);background:rgba(123,47,255,.15)}
.map-layers{display:flex;gap:2px}
.ml-btn{background:rgba(13,0,21,.9);border:1px solid var(--void-purple-dim);color:var(--void-text-dim);font-family:'Silkscreen',cursive;font-size:9px;padding:6px 14px;cursor:pointer;transition:.2s;letter-spacing:1px}
.ml-btn:hover{border-color:var(--void-purple);color:var(--void-text)}
.ml-btn.active{border-color:var(--void-purple);color:var(--void-purple-glow);background:rgba(123,47,255,.12)}
/* The Source layer button — distinct gold glow for mana theme */
.ml-btn[data-layer="source"].active{border-color:var(--void-gold);color:var(--void-gold);background:rgba(255,215,0,.08)}
.ml-btn[data-layer="source"]:hover{border-color:var(--void-gold);color:var(--void-gold)}
/* Planar map — placeholder styling */
.ml-btn[data-layer="planar"].active{border-color:var(--void-blue);color:var(--void-blue);background:rgba(68,102,255,.08)}
.ml-btn[data-layer="planar"]:hover{border-color:var(--void-blue);color:var(--void-blue)}
/* Hidden state for layer panels */
.map-layers-hidden{display:none}
.map-controls{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:4px;z-index:5}
.mc-btn{width:32px;height:32px;background:rgba(13,0,21,.9);border:1px solid var(--void-purple-dim);color:var(--void-text-dim);font-family:'VT323',monospace;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.mc-btn:hover{border-color:var(--void-purple);color:var(--void-purple-glow)}
.mc-btn.mc-font-toggle{font-size:14px}
.mc-btn.mc-font-toggle.active{border-color:var(--void-gold);color:var(--void-gold);background:rgba(255,215,0,.1)}
.map-font-hint{position:absolute;top:180px;right:12px;max-width:180px;font-family:'VT323',monospace;font-size:12px;color:var(--void-gold);background:rgba(13,0,21,.9);border:1px solid rgba(255,215,0,.3);padding:8px;opacity:0;transition:opacity .3s;pointer-events:none;line-height:1.4}
.map-font-hint.vis{opacity:1}
.map-tooltip{position:fixed;z-index:9000;background:rgba(13,0,21,.97);border:2px solid var(--void-purple);padding:14px;width:280px;pointer-events:none;opacity:0;transition:opacity .15s;box-shadow:0 0 20px rgba(123,47,255,.3)}
.map-tooltip.vis{opacity:1}
.map-tooltip .mt-name{font-family:'Silkscreen',cursive;font-size:14px;color:var(--void-purple-glow);margin-bottom:4px}
.map-tooltip .mt-sub{font-family:'VT323',monospace;font-size:16px;color:var(--void-magenta-dim);margin-bottom:8px}
.map-tooltip .mt-desc{font-family:'VT323',monospace;font-size:15px;color:var(--void-text-dim);line-height:1.5;margin-bottom:6px}
.map-tooltip .mt-danger{font-family:'Silkscreen',cursive;font-size:9px;letter-spacing:1px}
.map-tooltip .mt-hint{font-family:'Silkscreen',cursive;font-size:8px;color:var(--void-text-dim);margin-top:6px;letter-spacing:1px}
.map-depth{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);font-family:'Silkscreen',cursive;font-size:10px;color:var(--void-text-dim);letter-spacing:2px;pointer-events:none;text-transform:uppercase;opacity:.6}
.map-hint-bar{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);font-family:'VT323',monospace;font-size:14px;color:var(--void-text-dim);pointer-events:none;opacity:.5;white-space:nowrap;transition:opacity 2s}

/* SHARE BUTTON */
.share-btn{position:absolute;top:10px;right:10px;background:rgba(13,0,21,.8);border:1px solid var(--void-purple-dim);color:var(--void-text-dim);font-family:'Silkscreen',cursive;font-size:8px;padding:4px 8px;cursor:pointer;opacity:0;transition:.2s;z-index:2}
.char-card:hover .share-btn,.faction-card:hover .share-btn{opacity:1}
.share-btn:hover{border-color:var(--void-purple);color:var(--void-purple-glow)}
.share-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:rgba(13,0,21,.95);border:2px solid var(--void-purple);color:var(--void-purple-glow);font-family:'VT323',monospace;font-size:16px;padding:10px 20px;z-index:10001;opacity:0;transition:opacity .3s;pointer-events:none}
.share-toast.vis{opacity:1}

/* CLASSES PAGE (placeholder) */
.classes-coming{text-align:center;padding:4rem 2rem;font-family:'VT323',monospace;font-size:22px;color:var(--void-text-dim)}
.classes-coming .icon{font-size:48px;margin-bottom:1rem;display:block}

@media(max-width:768px){
  body{font-size:20px}
  .vtl::before{left:20px}
  .vtl{padding:1rem .5rem 2rem 2.5rem}
  .evt{flex-direction:row!important}
  .evt .ec{width:100%;margin-left:24px}
  .evt .es{display:none}
  .evt .nd{left:20px;width:12px;height:12px}
  .evt .nd.major{width:16px;height:16px}
  .ecard .dt{font-size:9px}
  .ecard .tt{font-size:15px}
  .ecard .ds{font-size:17px;line-height:1.5}
  .ecard .exh{font-size:9px}
  .etag{font-size:8px;padding:3px 7px}
  .edtl .lore{font-size:17px;line-height:1.7}
  .era-nm{font-size:clamp(14px,5vw,22px)}
  .era-ds{font-size:18px;line-height:1.6;padding:0 .5rem}
  .era-sp{font-size:17px}
  .era-num{font-size:10px}
  .minimap{display:none}
  .filter-bar{padding:6px 8px;top:44px}
  .filter-bar label{font-size:9px}
  .fbtn{font-size:9px;padding:5px 8px}
  .hero .tagline,.hero .tagline-2{font-size:17px;padding:0 1rem}
  .hero .sub{font-size:clamp(14px,3.5vw,22px)}
  .audio-player{bottom:8px;left:8px;padding:6px 10px;gap:6px}
  .ap-title{font-size:9px;max-width:100px}
  .ap-vol{width:40px}
  .cref .cico{width:30px;height:30px;font-size:16px}
  .cref .cinf .cname{font-size:10px}
  .cref .cinf .ctit{font-size:12px}
  nav{height:44px;gap:1rem;padding:0 .8rem}
  nav .logo{font-size:9px}
  nav a{font-size:9px}
  nav{flex-wrap:wrap;height:auto;padding:8px .8rem;gap:.5rem}
  .char-grid{grid-template-columns:1fr;padding:0 1rem 3rem;gap:1.5rem}
  .loc-grid{grid-template-columns:1fr;padding:0 1rem 3rem;gap:1.5rem}
  .codex-grid{padding:0 1rem 3rem}
  .codex-head{padding:12px 14px}
  .codex-head h3{font-size:14px}
  .codex-entry.open .codex-body{padding:0 14px 14px}
  .codex-body p{font-size:17px;line-height:1.7}
  .blog-list{padding:0 1rem 3rem}
  .faction-grid{padding:0 1rem 3rem}
  .btt{bottom:52px;right:12px;width:36px;height:36px;font-size:18px}
  .search-overlay{padding-top:10vh}
  .share-btn{opacity:.6;font-size:7px;padding:3px 6px}
  .pg-header{padding:0 1rem 2rem}
  .pg-header h2{font-size:clamp(14px,5vw,22px)}
  .pg-header p{font-size:17px}
  .spa-page{padding-top:80px}
}
