/* ===========================================================================
   ThwipNet — 1997 Marvel/AOL-era chrome + Spider-Man "rip through the page" hero
   =========================================================================== */
:root{
  --ink:#e9e9f4; --muted:#a6a6c0; --bg:#07070e; --panel:#11111e; --panel2:#181830;
  --line:#2c2c4a; --red:#e8161f; --red2:#b3121b; --blue:#2350e6; --blue2:#16308f;
  --green:#39ff14; --green2:#1f9c12; --gold:#ffcf33;
  --chrome1:#e4e7ef; --chrome2:#9aa0b2; --chrome3:#5f6478;
  --display:"Arial Black","Arial Bold",Impact,system-ui,sans-serif;
  --body:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:"Courier New",Courier,monospace;
}
*{box-sizing:border-box}
html{background:#000}
body{
  margin:0;color:var(--ink);font-family:var(--body);line-height:1.55;
  background:
    radial-gradient(900px 500px at 80% -5%, rgba(35,80,230,.16), transparent 60%),
    radial-gradient(700px 500px at 0% 100%, rgba(232,22,31,.12), transparent 60%),
    repeating-linear-gradient(0deg, rgba(255,255,255,.018) 0 1px, transparent 1px 3px),
    var(--bg);
}
img{max-width:100%;display:block}
a{color:var(--gold)}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:#000;color:#fff;padding:8px;z-index:50}
code{font-family:var(--mono);color:var(--green);background:#000;padding:1px 5px;border:1px solid var(--line);border-radius:3px;font-size:.85em}

/* ---- marquee ---- */
.marquee{overflow:hidden;background:#000;border-bottom:2px solid var(--green2);white-space:nowrap}
.marquee__track{display:inline-flex;animation:marq 34s linear infinite}
.marquee__track span{font-family:var(--mono);font-weight:bold;color:var(--green);
  font-size:.82rem;letter-spacing:.12em;padding:5px 0;text-shadow:0 0 6px rgba(57,255,20,.55)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- masthead ---- */
.masthead{position:relative;text-align:center;padding:18px 14px 10px;border-bottom:3px solid var(--red2);
  background:linear-gradient(180deg,#0c0c1a,#07070e)}
.wordmark{display:inline-block;text-decoration:none;font-family:var(--display);font-style:italic;
  font-size:clamp(2.4rem,9vw,4.6rem);line-height:.9;letter-spacing:-1px;position:relative}
.wordmark__thwip{color:var(--red);text-shadow:2px 2px 0 #000,4px 4px 0 var(--red2),6px 7px 10px rgba(0,0,0,.7)}
.wordmark__net{color:var(--blue);text-shadow:2px 2px 0 #000,4px 4px 0 var(--blue2),6px 7px 10px rgba(0,0,0,.7)}
.wordmark__tm{position:absolute;top:-4px;right:-46px;font-family:var(--mono);font-style:normal;font-size:.6rem;
  color:var(--gold);letter-spacing:.18em;border:1px solid var(--gold);padding:1px 4px;transform:rotate(6deg)}
.masthead__tag{margin:.35rem 0 0;font-style:italic;color:var(--muted);font-size:.95rem}
.navtoggle{display:none;position:absolute;right:12px;top:14px;font-family:var(--mono);font-weight:bold;
  background:linear-gradient(#3a3f52,#14172a);color:var(--chrome1);border:2px outset var(--chrome2);
  padding:8px 12px;border-radius:5px;cursor:pointer}

/* ---- layout ---- */
.layout{display:flex;gap:0;align-items:flex-start;width:100%;max-width:1140px;margin:0 auto}
.content{flex:1 1 0;min-width:0;padding:20px clamp(14px,3vw,30px) 40px}

/* ---- brushed-metal sidebar ---- */
.sidenav{flex:0 0 212px;padding:16px 10px;position:sticky;top:0}
.sidenav__plate{padding:9px;border-radius:8px;
  background:linear-gradient(180deg,#eef0f6,#b9bece 9%,#888ea2 50%,#b9bece 91%,#eef0f6);
  box-shadow:inset 0 0 0 1px #fff, inset 0 0 0 2px #6b7184, 0 6px 18px rgba(0,0,0,.55);
  background-image:linear-gradient(180deg,#eef0f6,#b9bece 9%,#888ea2 50%,#b9bece 91%,#eef0f6),
    repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 1px,transparent 1px 3px)}
.navbtn{display:flex;align-items:center;gap:8px;text-decoration:none;font-family:var(--display);
  text-transform:uppercase;letter-spacing:.04em;font-size:.86rem;color:#eef0fb;margin:6px 0;padding:9px 10px;
  background:linear-gradient(#363b51,#15182a);border:2px outset #4a5066;border-radius:5px;
  box-shadow:0 1px 0 rgba(255,255,255,.12) inset, 0 2px 4px rgba(0,0,0,.5);text-shadow:1px 1px 0 #000}
.navbtn:hover{background:linear-gradient(#1f49d6,#16308f);color:#fff;border-color:#6f8bff}
.navbtn--on{background:linear-gradient(var(--red),var(--red2));border-color:#ff6a70;color:#fff}
.navbtn__i{font-size:1rem;filter:drop-shadow(0 1px 0 #000)}
.sidenav__badge{margin-top:12px;border:1px solid var(--line);border-radius:8px;background:#000;padding:10px;text-align:center}
.sidenav__hits{font-family:var(--mono);font-size:.7rem;color:var(--green);letter-spacing:.14em}
.sidenav__hits b{display:inline-block;margin-top:4px;font-size:1.25rem;letter-spacing:.22em;color:#bfffc9b;
  background:#020;padding:3px 8px;border:1px solid var(--green2);border-radius:3px}
.sidenav__note{margin-top:8px;font-size:.68rem;color:var(--muted);line-height:1.4}

/* ---- HERO: Spider-Man ripping through the page ---- */
.hero{position:relative;width:100%;overflow:hidden;border:3px solid #000;border-radius:10px;
  min-height:clamp(380px,58vh,560px);margin-bottom:8px;
  background:
    radial-gradient(60% 70% at 72% 40%, rgba(35,80,230,.22), transparent 60%),
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.05) 0 2px, transparent 2px) 0 0/22px 22px,
    linear-gradient(160deg,#0e0e20,#06060d);
  box-shadow:inset 0 0 70px rgba(0,0,0,.7)}
.hero__portal{position:absolute;top:-6%;right:-4%;width:74%;height:112%;z-index:1;
  clip-path:polygon(10% 6%,22% 2%,33% 11%,45% 1%,58% 10%,70% 2%,82% 11%,95% 4%,99% 20%,
    91% 33%,99% 47%,90% 60%,99% 73%,90% 86%,97% 97%,82% 95%,69% 99%,57% 90%,45% 99%,
    33% 91%,20% 99%,6% 90%,2% 74%,9% 60%,1% 46%,9% 33%,2% 19%);
  background:
    radial-gradient(circle at 50% 44%, #fff 0%, rgba(186,222,255,.95) 9%, rgba(120,170,255,.55) 22%, transparent 46%),
    repeating-radial-gradient(circle at 50% 44%, rgba(255,255,255,.16) 0 4px, transparent 4px 13px),
    conic-gradient(from 0deg at 50% 44%, #2350e6, #7a1bd1, #e8161f, #ffcf33, #2350e6);
  filter:drop-shadow(3px 0 0 #fff) drop-shadow(-3px 0 0 #fff) drop-shadow(0 3px 0 #f3f3ff) drop-shadow(0 -3px 0 #f3f3ff) drop-shadow(0 0 22px rgba(120,170,255,.6));
  animation:portalspin 16s linear infinite, portalpulse 4.5s ease-in-out infinite}
@keyframes portalspin{to{background-position:0 0,0 0,0 0;filter:drop-shadow(3px 0 0 #fff) drop-shadow(-3px 0 0 #fff) drop-shadow(0 3px 0 #f3f3ff) drop-shadow(0 -3px 0 #f3f3ff) drop-shadow(0 0 22px rgba(120,170,255,.6))}}
.hero__portal::after{content:"";position:absolute;inset:0;
  background:conic-gradient(from 0deg at 50% 44%, transparent, rgba(0,0,0,.0) 40%);
  animation:spin 16s linear infinite;mix-blend-mode:overlay}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes portalpulse{0%,100%{opacity:.92;transform:scale(1)}50%{opacity:1;transform:scale(1.025)}}
.hero__spidey{position:absolute;right:2%;bottom:-2%;height:118%;width:auto;max-width:none;z-index:3;
  filter:drop-shadow(0 16px 26px rgba(0,0,0,.7));animation:swing 5.5s ease-in-out infinite, ghost 7s steps(1) infinite}
@keyframes swing{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(-2deg)}}
@keyframes ghost{0%,90%,100%{}93%{filter:drop-shadow(4px 0 0 #00e5ff) drop-shadow(-4px 0 0 #ff003c) drop-shadow(0 16px 26px rgba(0,0,0,.7))}}
.hero__copy{position:absolute;left:0;bottom:0;z-index:4;max-width:min(60%,560px);padding:22px clamp(16px,3vw,30px)}
.hero__kicker{font-family:var(--mono);color:var(--green);font-size:.72rem;letter-spacing:.18em;margin:0 0 6px;
  text-shadow:0 0 8px rgba(57,255,20,.6)}
.hero__title{font-family:var(--display);font-style:italic;font-size:clamp(1.9rem,5.2vw,3.3rem);line-height:.95;margin:0;
  color:#fff;text-shadow:2px 2px 0 #000,4px 4px 0 var(--blue2)}
.hero__title span{color:var(--red);text-shadow:2px 2px 0 #000,4px 4px 0 var(--red2)}
.hero__sub{margin:.7rem 0 1rem;font-size:.98rem;color:#eef;text-shadow:0 2px 6px #000,0 0 18px #000}
.hero__sub b{color:var(--gold)}

/* ---- buttons ---- */
.btn{display:inline-block;font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;text-decoration:none;
  font-size:.92rem;color:#fff;background:linear-gradient(var(--red),var(--red2));border:2px outset #ff6a70;border-radius:6px;
  padding:10px 16px;box-shadow:0 3px 0 #6a0a0e,0 5px 10px rgba(0,0,0,.5);text-shadow:1px 1px 0 #000}
.btn:hover{filter:brightness(1.12);transform:translateY(-1px)}
.btn--alt{background:linear-gradient(var(--blue),var(--blue2));border-color:#6f8bff;box-shadow:0 3px 0 #0c1d57,0 5px 10px rgba(0,0,0,.5)}
.hero__cta{display:flex;gap:10px;flex-wrap:wrap}

/* ---- headings / panels ---- */
.panelhead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:26px 0 12px;
  border-bottom:2px solid var(--line);padding-bottom:6px}
.panelhead h2{font-family:var(--display);font-style:italic;margin:0;font-size:1.3rem;color:#fff;
  text-shadow:1px 1px 0 #000,2px 2px 0 var(--blue2)}
.panelhead--good h2{text-shadow:1px 1px 0 #000,2px 2px 0 var(--green2)}
.panelhead--bad h2{text-shadow:1px 1px 0 #000,2px 2px 0 var(--red2)}
.seeall{font-family:var(--mono);font-size:.78rem;color:var(--gold);white-space:nowrap}
.pagehead{border-bottom:3px double var(--red2);padding-bottom:12px;margin-bottom:18px}
.pagehead h1{font-family:var(--display);font-style:italic;font-size:clamp(1.7rem,5vw,2.7rem);margin:0 0 4px;color:#fff;
  text-shadow:2px 2px 0 #000,4px 4px 0 var(--red2)}
.pagehead p{margin:0;color:var(--muted);max-width:60ch}
.crumb{font-family:var(--mono);font-size:.82rem;margin:0 0 10px}
.note{font-size:.82rem;color:var(--muted);margin:14px 0;font-style:italic}
.note--big{font-style:normal;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:14px 16px}
.note--big code{font-style:normal}
.pill{display:inline-block;font-family:var(--mono);font-size:.74rem;color:#000;background:var(--gold);
  padding:1px 7px;border-radius:10px;font-weight:bold}

/* ---- poster grids ---- */
.postergrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.postergrid--wide{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.poster{position:relative;text-decoration:none;color:var(--ink);background:#000;border:2px solid var(--line);
  border-radius:6px;overflow:hidden;display:flex;flex-direction:column}
.poster:hover{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 6px 16px rgba(0,0,0,.6)}
.poster img{aspect-ratio:2/3;object-fit:cover;width:100%}
.poster__ph,.poster__ph--lg{aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;text-align:center;
  padding:10px;font-family:var(--display);font-style:italic;color:#fff;
  background:repeating-linear-gradient(45deg,#1a1a30 0 10px,#12121f 10px 20px)}
.poster__cap{padding:6px 8px;font-size:.78rem;font-weight:bold;background:linear-gradient(#15152a,#0a0a16)}
.poster__cap i{color:var(--muted);font-weight:normal}
.poster__score{position:absolute;top:6px;right:6px;background:var(--gold);color:#000;font-family:var(--mono);
  font-weight:bold;font-size:.74rem;padding:1px 6px;border-radius:4px}

/* ---- char strip + chips (home) ---- */
.charstrip{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}
.charchip{text-decoration:none;color:var(--ink);text-align:center;background:#000;border:2px solid var(--line);
  border-radius:8px;padding:6px;font-size:.74rem;font-weight:bold}
.charchip:hover{border-color:var(--blue)}
.charchip img{aspect-ratio:1/1;object-fit:cover;border-radius:6px;margin-bottom:4px}

/* ---- character card grid ---- */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:14px}
.ccard{text-decoration:none;color:var(--ink);background:var(--panel);border:2px solid var(--line);border-radius:10px;
  overflow:hidden;display:flex;flex-direction:column;transition:transform .08s}
.ccard:hover{transform:translateY(-3px)}
.ccard--good:hover{border-color:var(--green2);box-shadow:0 0 0 1px var(--green2)}
.ccard--bad:hover{border-color:var(--red);box-shadow:0 0 0 1px var(--red)}
.ccard__pic{position:relative}
.ccard__pic img{aspect-ratio:3/4;object-fit:cover;width:100%}
.ccard__align{position:absolute;top:6px;left:6px;font-family:var(--mono);font-size:.62rem;font-weight:bold;
  padding:1px 6px;border-radius:3px;background:#000a;border:1px solid #fff3}
.ccard--good .ccard__align{color:var(--green)}.ccard--bad .ccard__align{color:#ff6a70}
.ccard h3{font-family:var(--display);font-style:italic;margin:8px 10px 0;font-size:1rem;color:#fff}
.ccard__real{margin:0 10px;font-size:.72rem;color:var(--muted)}
.statmini{display:flex;flex-direction:column;gap:3px;padding:8px 10px 10px;margin-top:auto}
.statmini span{font-family:var(--mono);font-size:.6rem;color:var(--muted);display:grid;grid-template-columns:30px 1fr;
  align-items:center;gap:6px}
.statmini i{display:block;height:6px;background:linear-gradient(90deg,var(--blue),var(--red));border-radius:3px}

/* ---- character dossier ---- */
.dossier{display:grid;grid-template-columns:280px 1fr;gap:22px;background:var(--panel);border:2px solid var(--line);
  border-radius:12px;padding:18px;align-items:start}
.dossier__pic{position:relative;border:2px solid #000;border-radius:8px;overflow:hidden}
.dossier__pic img{width:100%;display:block}
.dossier__ph{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;color:#666;font-family:var(--mono)}
.dossier__align{position:absolute;top:8px;left:8px;font-family:var(--mono);font-weight:bold;font-size:.7rem;
  padding:2px 8px;border-radius:4px;background:#000c}
.dossier--good .dossier__align{color:var(--green)}.dossier--bad .dossier__align{color:#ff6a70}
.dossier__body h1{font-family:var(--display);font-style:italic;margin:0;color:#fff;font-size:2rem;
  text-shadow:2px 2px 0 #000,3px 3px 0 var(--red2)}
.dossier__real{margin:.2rem 0 1rem;color:var(--gold);font-size:1rem}
.dossier__facts{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;margin:0 0 16px;font-size:.9rem}
.dossier__facts dt{color:var(--muted);font-family:var(--mono);font-size:.72rem;text-transform:uppercase;align-self:center}
.dossier__facts dd{margin:0}
.statbars{display:flex;flex-direction:column;gap:8px}
.statbar{display:grid;grid-template-columns:96px 1fr 34px;align-items:center;gap:10px}
.statbar__l{font-family:var(--mono);font-size:.72rem;color:var(--muted);text-transform:uppercase}
.statbar__t{height:14px;background:#000;border:1px solid var(--line);border-radius:7px;overflow:hidden}
.statbar__t i{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--red));
  box-shadow:0 0 8px rgba(232,22,31,.5)}
.statbar__v{font-family:var(--mono);font-weight:bold;color:#fff;text-align:right}

/* ---- comics grid ---- */
.comicgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}
.comic{text-decoration:none;color:var(--ink);display:flex;flex-direction:column;background:#000;
  border:2px solid var(--line);border-radius:6px;overflow:hidden}
.comic:hover{border-color:var(--gold)}
.comic__cover img{aspect-ratio:2/3;object-fit:cover;width:100%}
.comic__title{padding:6px 8px 0;font-size:.78rem;font-weight:bold}
.comic__by{padding:2px 8px 0;font-size:.66rem;color:var(--gold);line-height:1.25}
.comic__date{padding:2px 8px 8px;font-family:var(--mono);font-size:.68rem;color:var(--muted)}
.pager{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin:22px 0}
.pager a{font-family:var(--display);text-transform:uppercase;font-size:.8rem;color:#fff;text-decoration:none;
  background:linear-gradient(var(--blue),var(--blue2));border:2px outset #6f8bff;border-radius:6px;padding:7px 12px}
.pager a:hover{filter:brightness(1.15)}
.pager__cur{font-family:var(--mono);color:var(--gold);font-weight:bold;padding:0 6px}

/* ---- shows list ---- */
.showlist{display:flex;flex-direction:column;gap:12px}
.showrow{display:grid;grid-template-columns:96px 1fr;gap:14px;text-decoration:none;color:var(--ink);
  background:var(--panel);border:2px solid var(--line);border-radius:10px;padding:10px;align-items:start}
.showrow:hover{border-color:var(--blue)}
.showrow__pic img{aspect-ratio:2/3;object-fit:cover;border-radius:5px}
.showrow__meta h3{font-family:var(--display);font-style:italic;margin:0 0 4px;color:#fff}
.showrow__meta .yr{color:var(--muted);font-size:.85rem}
.showrow__meta p{margin:0 0 8px;font-size:.88rem;color:var(--muted)}

/* ---- title detail ---- */
.titledetail{display:grid;grid-template-columns:300px 1fr;gap:24px;background:var(--panel);border:2px solid var(--line);
  border-radius:12px;padding:20px}
.titledetail__poster img{width:100%;border-radius:8px;border:2px solid #000}
.titledetail__body h1{font-family:var(--display);font-style:italic;margin:0;color:#fff;font-size:2rem;
  text-shadow:2px 2px 0 #000,3px 3px 0 var(--red2)}
.titledetail__body .yr{color:var(--muted);font-size:1.1rem}
.tagline{font-style:italic;color:var(--gold);margin:.3rem 0 1rem}
.scorerow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.score{font-family:var(--mono);font-size:.78rem;background:#000;border:1px solid var(--line);border-radius:5px;padding:3px 8px}
.score b{color:#fff}.score--imdb b{color:var(--gold)}.score--rt b{color:#ff6347}.score--tmdb b{color:#01b4e4}
.overview{font-size:.98rem;margin:0 0 16px}
.facts{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;margin:0 0 16px;font-size:.9rem}
.facts dt{color:var(--muted);font-family:var(--mono);font-size:.72rem;text-transform:uppercase;align-self:center}
.facts dd{margin:0}
.titledetail__cta{display:flex;gap:10px;flex-wrap:wrap}

/* ---- two-col + tick lists (home) ---- */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.ticklist{list-style:none;padding:0;margin:0}
.ticklist li{padding:7px 0;border-bottom:1px dotted var(--line);font-size:.9rem}
.ticklist i{color:var(--muted);font-style:normal;font-size:.8rem}
.ticklist a{color:var(--ink);text-decoration:none}.ticklist a:hover{color:var(--gold)}

/* ---- news ---- */
.newslist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.newslist li{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--red);border-radius:6px;padding:12px 14px}
.newslist__t{font-weight:bold;color:#fff;text-decoration:none;font-size:1rem}
.newslist__t:hover{color:var(--gold)}
.newslist__meta{font-family:var(--mono);font-size:.72rem;color:var(--muted);margin:3px 0}
.newslist__meta .src{color:var(--green)}
.newslist__s{margin:4px 0 0;font-size:.86rem;color:var(--muted)}

/* ---- physical media ---- */
.prose{max-width:62ch;font-size:1rem}
.prose p{margin:0 0 1rem}
.signoff{color:var(--green);font-style:italic;font-weight:bold}
.pmgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.pmcard{display:flex;flex-direction:column;gap:4px;text-decoration:none;color:var(--ink);background:var(--panel);
  border:2px solid var(--line);border-radius:10px;padding:14px}
.pmcard:hover{border-color:var(--gold)}
.pmcard__disc{font-size:1.6rem}
.pmcard__t{font-weight:bold;color:#fff}
.pmcard__b{font-size:.82rem;color:var(--muted)}
.pmcard__buy{margin-top:6px;font-family:var(--mono);font-size:.78rem;color:var(--gold)}
.legalbox{margin-top:24px;background:#000;border:1px solid var(--line);border-radius:8px;padding:16px}
.legalbox h3{margin:0 0 8px;font-family:var(--display);font-style:italic;color:#fff}
.legalbox p{margin:0;font-size:.82rem;color:var(--muted)}

/* ---- games ---- */
.gamegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.gcard{display:flex;flex-direction:column;text-decoration:none;color:var(--ink);background:var(--panel);border:2px solid var(--line);border-radius:10px;overflow:hidden;transition:transform .08s}
.gcard:hover{border-color:var(--blue);transform:translateY(-2px)}
.gcard__art{position:relative;aspect-ratio:16/9;background:#0a0a14}
.gcard__art img{width:100%;height:100%;object-fit:cover}
.gcard__mc{position:absolute;top:6px;right:6px;font-family:var(--mono);font-weight:bold;font-size:.72rem;padding:2px 7px;border-radius:4px;background:var(--gold);color:#000}
.gcard__body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:6px}
.gcard__head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.gcard__head h3{font-family:var(--display);font-style:italic;margin:0;color:#fff;font-size:1rem;line-height:1.12}
.gcard__yr{font-family:var(--mono);color:var(--gold);font-weight:bold;font-size:.78rem;white-space:nowrap}
.gcard__plats{display:flex;flex-wrap:wrap;gap:5px}
.chip{font-family:var(--mono);font-size:.6rem;color:#cfe;background:#10204a;border:1px solid #2a47a0;border-radius:10px;padding:2px 7px}
.gcard__dev{font-size:.72rem;color:var(--green);margin:0}
.gamedetail{background:var(--panel);border:2px solid var(--line);border-radius:12px;padding:18px;margin-bottom:8px}
.gamedetail__art{border-radius:10px;overflow:hidden;border:2px solid #000;margin-bottom:14px;max-height:380px}
.gamedetail__art img{width:100%;height:100%;object-fit:cover;display:block}
.gamedetail h1{font-family:var(--display);font-style:italic;margin:0 0 8px;color:#fff;font-size:2rem;text-shadow:2px 2px 0 #000,3px 3px 0 var(--blue2)}
.gamedetail h1 .yr{color:var(--muted);font-size:1.1rem}

/* ---- fun facts ---- */
.ff{max-width:620px;margin:0 auto;text-align:center}
.ff-card{background:var(--panel);border:2px solid var(--line);border-radius:14px;padding:26px 22px;min-height:170px;
  display:flex;flex-direction:column;justify-content:center;gap:12px;box-shadow:inset 0 0 34px rgba(35,80,230,.14)}
.ff-cat{align-self:center;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:#000;background:var(--gold);border-radius:12px;padding:3px 12px;font-weight:bold}
.ff-text{font-size:1.12rem;line-height:1.55;color:#fff;margin:0}
.ff-text b{color:var(--gold)} .ff-text i{color:#bcd}
.ff-pop{animation:ffpop .28s ease}
@keyframes ffpop{from{transform:scale(.97);opacity:.45}to{transform:scale(1);opacity:1}}
#ff-btn{margin-top:16px}

/* ---- guestbook ---- */
.flash{padding:10px 14px;border-radius:6px;font-weight:bold}
.flash--ok{background:#06270a;border:1px solid var(--green2);color:#b6ffb0}
.flash--err{background:#2a0509;border:1px solid var(--red2);color:#ffb0b8}
.gbform{background:var(--panel);border:2px solid var(--line);border-radius:10px;padding:16px;margin-bottom:8px}
.gbform__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gbform label{display:block;font-family:var(--mono);font-size:.78rem;color:var(--muted);margin-bottom:10px}
.gbform input,.gbform textarea{width:100%;background:#000;color:var(--ink);border:1px solid var(--line);
  border-radius:5px;padding:8px;font-family:var(--body);font-size:.95rem;margin-top:3px}
.gbform input:focus,.gbform textarea:focus{outline:2px solid var(--red);border-color:var(--red)}
.hp{position:absolute;left:-9999px}
.gblist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.gbentry{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:6px;padding:10px 12px}
.gbentry__head{font-size:.85rem;margin-bottom:4px}
.gbentry__head b{color:#fff}.gbentry__head .loc{color:var(--muted);font-style:italic}
.gbentry__head .date{float:right;font-family:var(--mono);font-size:.72rem;color:var(--muted)}
.gbentry p{margin:0;font-size:.92rem}

/* ---- 404 ---- */
.notfound{text-align:center;padding:40px 16px}
.notfound h1{font-family:var(--display);font-style:italic;font-size:6rem;margin:0;color:var(--red);
  text-shadow:3px 3px 0 #000,6px 6px 0 var(--blue2)}
.notfound__big{font-family:var(--display);font-style:italic;font-size:1.4rem;color:#fff;margin:.2rem 0 .6rem}
.notfound__cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}

.gbcta{text-align:center;margin:30px 0 0;background:var(--panel);border:2px solid var(--line);border-radius:10px;padding:16px}
.gbcta p{margin:.3rem 0}.gbcta b{color:var(--gold);font-family:var(--mono)}

/* ---- footer ---- */
.sitefoot{border-top:3px solid var(--red2);margin-top:90px;padding:20px 14px 46px;background:#04040a;text-align:center;position:relative;overflow:visible}
.sitefoot > *{position:relative;z-index:2}
.sitefoot .footer-spidey{position:absolute;z-index:1;right:clamp(4px,5vw,80px);bottom:0;height:clamp(190px,28vw,380px);
  width:auto;pointer-events:none;filter:drop-shadow(0 -4px 12px rgba(0,0,0,.5))}
@media(max-width:560px){.sitefoot .footer-spidey{height:165px;right:2px;opacity:.92}}
.webring{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 14px;
  background:#000;border:1px solid var(--line);border-radius:8px;padding:12px;max-width:680px;margin:0 auto}
.webring-badge{image-rendering:pixelated;border:1px solid #333}
.webring-head{font-family:var(--display);font-style:italic;color:var(--green)}
.webring-nav a{font-family:var(--mono);font-size:.85rem;color:var(--gold);margin:0 4px}
.webring-tag{flex-basis:100%;font-size:.72rem;color:var(--muted);font-style:italic}
.badges88{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:16px 0}
.b88{width:88px;height:31px;font-family:var(--mono);font-size:.5rem;line-height:1.15;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;border:1px solid #000;border-radius:2px;color:#fff;
  box-shadow:1px 1px 0 #000}
.b88 b{font-size:.62rem}
.b88--netscape{background:linear-gradient(#3a3a3a,#111)}
.b88--mac{background:linear-gradient(#5a5f6e,#2b2f3a)}
.b88--html{background:linear-gradient(var(--blue),var(--blue2))}
.b88--ring{background:linear-gradient(var(--red),var(--red2))}
.disclaimer{max-width:760px;margin:14px auto 0;font-size:.72rem;color:#8a8aa6;line-height:1.5}
.copyline{margin:12px auto 0;font-size:.74rem;color:var(--muted)}
.copyline a{color:var(--gold)}

/* ---- responsive ---- */
@media(max-width:820px){
  .navtoggle{display:block}
  .layout{display:block}
  .sidenav{position:fixed;top:0;left:0;bottom:0;width:250px;z-index:40;transform:translateX(-100%);
    transition:transform .25s;overflow-y:auto;background:#05050c;border-right:2px solid var(--red2)}
  body.nav-open .sidenav{transform:translateX(0)}
  .navscrim{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:35;opacity:0;pointer-events:none;transition:opacity .25s}
  body.nav-open .navscrim{opacity:1;pointer-events:auto}
  .twocol{grid-template-columns:1fr}
  .dossier{grid-template-columns:1fr}
  .titledetail{grid-template-columns:1fr}
  .titledetail__poster{max-width:240px;margin:0 auto}
  .hero__copy{max-width:100%;background:linear-gradient(0deg,#000d 60%,transparent)}
  .hero__spidey{opacity:.85}
}
@media(prefers-reduced-motion:reduce){
  .marquee__track,.hero__portal,.hero__portal::after,.hero__spidey{animation:none}
}
