/* Game Convention Central — "Tabletop Directory" design system
   Crimson + charcoal-ink + amber, Bricolage Grotesque display / Figtree body.
   Hand-rolled CSS (Grid + Flexbox). No UI framework, no scroll-reveal lib.
   Content is visible with CSS alone; JS is enhancement only. */

:root{
  --crimson:#b21f24; --crimson-bright:#d62828; --crimson-dark:#8a161b;
  --ink:#1f2430; --ink-2:#2a3040;
  --amber:#e8a029; --amber-soft:#f2b134;
  --parchment:#f7f3ec; --parchment-2:#efe7d9; --card:#ffffff;
  --text:#2a303a; --text-light:#5f6774; --line:#e6ddcd;
  --display:'Bricolage Grotesque', 'Trebuchet MS', system-ui, sans-serif;
  --body:'Figtree', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --shadow:0 12px 30px rgba(20,20,30,.12);
  --radius:14px;
}

/* ---------- base ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--text);background:var(--parchment);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{text-wrap:balance}
a{color:var(--crimson-dark)}
:focus-visible{outline:2px solid var(--crimson);outline-offset:2px;border-radius:4px}
.wrap{width:100%;max-width:1160px;margin:0 auto;padding:0 clamp(1rem,3vw,1.75rem)}
.skip{position:absolute;left:-9999px}
.skip:focus{left:1rem;top:1rem;position:fixed;background:#fff;color:var(--crimson-dark);padding:.6rem 1rem;border-radius:8px;z-index:300;box-shadow:var(--shadow)}
/* Safeguard: content is never hidden waiting on JS (progressive enhancement only). */
[data-aos]{opacity:1 !important;transform:none !important;}

/* ---------- header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:var(--ink);color:#fff;transition:box-shadow .2s}
.site-header.scrolled{box-shadow:0 6px 22px rgba(0,0,0,.28)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:66px}
.brand{display:flex;align-items:center;gap:.6rem;color:#fff;text-decoration:none;font-family:var(--display);font-weight:800;font-size:1.16rem;letter-spacing:-.01em;line-height:1}
.brand-mark{flex:0 0 auto}
.brand-name em{font-style:normal;color:var(--amber)}
.main-nav .nav-list{list-style:none;display:flex;align-items:center;gap:.15rem;margin:0;padding:0}
.nav-list a,.dd-top{color:#e7e9ee;text-decoration:none;font-weight:600;font-size:.95rem;font-family:inherit;padding:.55rem .72rem;border-radius:9px;display:inline-flex;align-items:center;gap:.32rem;background:none;border:0;cursor:pointer;line-height:1.2}
.nav-list a:hover,.dd-top:hover,.nav-list a:focus-visible,.dd-top:focus-visible{background:rgba(255,255,255,.09);color:#fff}
.nav-list .is-active>a{color:var(--amber)}
.has-dd[data-active] .dd-top{color:var(--amber)}
.chev{opacity:.75;transition:transform .18s}
.has-dd:hover .chev,.has-dd:focus-within .chev{transform:rotate(180deg)}
.nav-cta a{background:var(--crimson);color:#fff;padding:.55rem 1rem;margin-left:.35rem}
.nav-cta a:hover{background:var(--crimson-bright);color:#fff}
.has-dd{position:relative}
.dd-menu{list-style:none;margin:0;padding:.4rem;position:absolute;top:calc(100% + 8px);left:0;min-width:260px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 44px rgba(20,20,30,.22);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .16s,transform .16s,visibility .16s}
.has-dd:hover .dd-menu,.has-dd:focus-within .dd-menu{opacity:1;visibility:visible;transform:none}
.dd-menu a{display:block;color:var(--text);padding:.5rem .6rem;border-radius:9px;font-weight:600;font-size:.92rem}
.dd-menu a:hover{background:var(--parchment-2);color:var(--crimson-dark)}
.dd-codes{display:block;font-size:.73rem;color:var(--text-light);font-weight:500;margin-top:2px;letter-spacing:.01em}
.nav-toggle,.nav-burger{display:none}

/* ---------- hero ---------- */
.hero{position:relative;isolation:isolate;overflow:hidden;background:var(--ink)}
.hero-content{position:relative;z-index:3;padding:clamp(3rem,7vw,5.6rem) 0;max-width:840px}
.hero-image{min-height:clamp(340px,44vw,510px);display:flex;align-items:flex-end}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero-scrim{position:absolute;inset:0;z-index:2;background:
  linear-gradient(180deg,rgba(20,23,32,.28) 0%,rgba(20,23,32,.30) 34%,rgba(20,23,32,.88) 100%),
  linear-gradient(90deg,rgba(20,23,32,.72),rgba(20,23,32,.05) 62%)}
.hero-gradient{background:
  radial-gradient(1100px 460px at 82% -18%,rgba(214,40,40,.5),transparent 62%),
  linear-gradient(135deg,#1f2430 0%,#262c3b 52%,#2c2030 100%)}
.hero-gradient::before{content:"";position:absolute;inset:0;z-index:1;
  background-image:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);
  background-size:34px 34px;
  -webkit-mask-image:linear-gradient(160deg,rgba(0,0,0,.7),transparent 68%);mask-image:linear-gradient(160deg,rgba(0,0,0,.7),transparent 68%)}
.hero-kicker{display:inline-flex;align-items:center;gap:.5rem;color:var(--amber);font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}
.hero-kicker svg{flex:0 0 auto}
.hero-title{font-family:var(--display);font-weight:800;color:#fff;font-size:clamp(1.95rem,4.6vw,3.15rem);line-height:1.05;letter-spacing:-.022em;margin:0 0 .85rem}
.hero-tagline{color:#e8e4da;font-size:clamp(1.02rem,1.6vw,1.2rem);line-height:1.55;max-width:660px;margin:0}
.hero-actions{margin-top:1.6rem;display:flex;gap:.7rem;flex-wrap:wrap}
.hero-404{min-height:auto}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--amber);color:#20242e;font-weight:700;text-decoration:none;padding:.82rem 1.6rem;border-radius:999px;transition:transform .16s,background .16s;font-size:1rem;font-family:var(--body)}
.btn:hover{background:var(--amber-soft);transform:translateY(-2px);color:#20242e}
.btn svg{stroke:currentColor}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-outline:hover{background:rgba(255,255,255,.12);color:#fff}

/* ---------- region grid ---------- */
.grid-bg{background-color:var(--parchment);
  background-image:linear-gradient(rgba(31,36,48,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(31,36,48,.045) 1px,transparent 1px);
  background-size:30px 30px}
.region-section{padding:clamp(2.6rem,5vw,3.8rem) 0;border-bottom:1px solid var(--line)}
.section-head{margin-bottom:1.5rem}
.kicker{display:inline-block;color:var(--crimson);font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.45rem}
.section-title{font-family:var(--display);font-weight:800;font-size:clamp(1.55rem,3vw,2.1rem);letter-spacing:-.02em;margin:0;color:var(--ink)}
.region-group-title{font-family:var(--display);font-weight:700;font-size:.98rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.07em;margin:1.7rem 0 .95rem}
.region-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));gap:.9rem}
.region-card{display:flex;flex-direction:column;gap:.22rem;height:100%;background:var(--card);border:1px solid var(--line);border-left:4px solid var(--crimson);border-radius:12px;padding:1.05rem 1.15rem;text-decoration:none;transition:transform .16s,box-shadow .16s,border-color .16s;box-shadow:0 1px 2px rgba(20,20,30,.05)}
.region-card:hover{border-left-color:var(--amber);transform:translateY(-3px);box-shadow:var(--shadow)}
.region-card-name{font-family:var(--display);font-weight:700;font-size:1.14rem;color:var(--ink);line-height:1.15}
.region-card-codes{font-size:.77rem;color:var(--text-light);font-weight:600;letter-spacing:.02em}
.region-card-go{margin-top:.55rem;font-size:.82rem;font-weight:700;color:var(--crimson);display:inline-flex;align-items:center;gap:.35rem}
.region-card:hover .region-card-go{color:var(--crimson-dark);gap:.5rem}

/* ---------- article / prose ---------- */
.article-wrap{padding:clamp(2.4rem,5vw,3.8rem) 0}
.prose{max-width:770px;margin:0 auto;font-size:1.06rem;line-height:1.72;color:var(--text)}
.prose>p:first-of-type{font-size:1.17rem;color:#39424e;line-height:1.66}
.prose h2{font-family:var(--display);font-weight:800;font-size:clamp(1.42rem,2.7vw,1.9rem);letter-spacing:-.015em;color:var(--ink);margin:2.4rem 0 .85rem;display:flex;align-items:center;gap:.65rem}
.prose h2::before{content:"";width:14px;height:14px;background:var(--crimson);transform:rotate(45deg);border-radius:3px;flex:0 0 auto;box-shadow:0 0 0 3px rgba(232,160,41,.3)}
.prose h3{font-family:var(--display);font-weight:700;font-size:1.26rem;color:var(--ink);margin:1.8rem 0 .5rem}
.prose p{margin:0 0 1.15rem}
.prose ul{margin:0 0 1.35rem;padding:0;list-style:none}
.prose ul li{position:relative;padding-left:1.7rem;margin:0 0 .62rem}
.prose ul li::before{content:"";position:absolute;left:.25rem;top:.62em;width:8px;height:8px;background:var(--amber);transform:rotate(45deg);border-radius:2px}
.prose a{color:var(--crimson-dark);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1.5px;font-weight:600}
.prose a:hover{color:var(--crimson-bright)}
.prose strong{color:var(--ink);font-weight:700}

/* ---------- inline figure ---------- */
.inline-figure{margin:1.9rem 0 2.1rem;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.inline-figure img{width:100%;height:auto}

/* ---------- form ---------- */
.prose form{background:var(--parchment-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;margin:1.7rem 0 2rem}
.prose form label{display:block;font-weight:600;color:var(--ink);margin:0 0 1rem;font-size:.95rem}
.prose form input,.prose form textarea{width:100%;margin-top:.4rem;padding:.72rem .82rem;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:1rem;background:#fff;color:var(--text)}
.prose form input:focus,.prose form textarea:focus{outline:2px solid var(--crimson);outline-offset:1px;border-color:var(--crimson)}
.prose form textarea{resize:vertical;min-height:120px}
.prose form button{background:var(--crimson);color:#fff;border:0;border-radius:10px;padding:.82rem 1.7rem;font:inherit;font-weight:700;font-size:1rem;cursor:pointer;transition:background .16s,transform .16s;margin-top:.3rem}
.prose form button:hover{background:var(--crimson-bright);transform:translateY(-1px)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;isolation:isolate;overflow:hidden;background:
  radial-gradient(820px 300px at 12% 0%,rgba(214,40,40,.42),transparent 60%),
  linear-gradient(135deg,#1f2430,#2a2130);color:#fff;padding:clamp(2.5rem,5vw,3.5rem) 0;text-align:center}
.cta-band h2{font-family:var(--display);font-weight:800;font-size:clamp(1.45rem,3vw,2.05rem);margin:0 0 .55rem;color:#fff;letter-spacing:-.02em}
.cta-band p{color:#d9d5cc;margin:0 auto 1.5rem;max-width:580px}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#c7cbd4}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;padding:clamp(2.6rem,5vw,3.6rem) 0}
.brand-footer{margin-bottom:.9rem;font-size:1.08rem}
.footer-blurb{font-size:.92rem;line-height:1.6;color:#a7adba;max-width:330px;margin:0}
.footer-col h4{font-family:var(--display);color:#fff;font-size:.9rem;letter-spacing:.05em;text-transform:uppercase;margin:0 0 .85rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin:0 0 .5rem}
.footer-col a{color:#b8bdc8;text-decoration:none;font-size:.9rem}
.footer-col a:hover{color:var(--amber)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08)}
.footer-bottom-inner{display:flex;justify-content:space-between;gap:1.5rem;padding:1.2rem 0;align-items:center;flex-wrap:wrap}
.footer-note{font-size:.78rem;color:#8b909c;max-width:730px;margin:0;line-height:1.5}
.footer-copy{font-size:.82rem;color:#a7adba;margin:0;white-space:nowrap}

/* ---------- entrance (CSS-only, ends visible, reduced-motion safe) ----------
   Deliberately opacity-safe: the hero (which holds the page's H1) only slides,
   it never fades from 0, so text can never be left invisible even mid-animation
   or if animations misbehave. Region cards use a gentle fade but are decorative
   navigation (also duplicated in the footer). Nothing here is gated on JS. */
@media (prefers-reduced-motion:no-preference){
  .hero-content{animation:slideIn .55s cubic-bezier(.2,.7,.3,1) both}
  .region-card{animation:riseIn .5s cubic-bezier(.2,.7,.3,1) both}
  @keyframes slideIn{from{transform:translateY(14px)}to{transform:none}}
  @keyframes riseIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .nav-burger{display:inline-flex;flex-direction:column;gap:5px;width:46px;height:42px;align-items:center;justify-content:center;cursor:pointer;border-radius:9px}
  .nav-burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.22s}
  .nav-toggle:checked ~ .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked ~ .nav-burger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .main-nav{display:none;position:absolute;left:0;right:0;top:100%;background:var(--ink);border-top:1px solid rgba(255,255,255,.08);padding:.7rem;max-height:82vh;overflow:auto;box-shadow:0 18px 30px rgba(0,0,0,.3)}
  .nav-toggle:checked ~ .main-nav{display:block}
  .main-nav .nav-list{flex-direction:column;align-items:stretch;gap:.12rem}
  .nav-list>li>a,.dd-top{width:100%;justify-content:flex-start;font-size:1rem;padding:.7rem .75rem}
  .has-dd{position:static}
  .dd-top{cursor:default}
  .has-dd .chev{margin-left:auto}
  .dd-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:transparent;padding:.1rem 0 .5rem 1.1rem;min-width:0}
  .dd-menu a{color:#c9cdd6}
  .dd-menu a:hover{background:rgba(255,255,255,.08);color:#fff}
  .nav-cta a{margin:.4rem 0 0;justify-content:center;background:var(--crimson)}
}
@media (max-width:820px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start;gap:.6rem}
}
@media (max-width:520px){
  .footer-grid{grid-template-columns:1fr}
  .region-grid{grid-template-columns:1fr}
}
