/* =====================================================================
   007 FIRST LIGHT — Unofficial Wiki & Guide
   Design system: "MI6 Classified Dossier"
   Near-black noir + 007 gold + danger crimson.
   Display serif (the gentleman) x monospace (the operative).
   ===================================================================== */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,400;0,500;0,600;0,700;1,500&family=Saira+Semi+Condensed:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ---------- Tokens ---------- */
:root {
  --bg:        #0a0a0b;
  --bg-2:      #111113;
  --bg-3:      #17171a;
  --panel:     #131316;
  --line:      #2a2a2f;
  --line-soft: #1d1d21;

  --gold:      #c9a24b;
  --gold-soft: #d8bd7e;
  --gold-deep: #8a6d2c;
  --crimson:   #b11226;
  --crimson-l: #d8273c;

  --ink:       #ece9e1;   /* primary text */
  --ink-2:     #b6b4ac;   /* secondary */
  --ink-3:     #7d7c77;   /* muted / labels */

  --serif: 'Cormorant', Georgia, serif;
  --sans:  'Saira Semi Condensed', system-ui, sans-serif;
  --mono:  'JetBrains Mono', ui-monospace, monospace;

  --maxw: 1180px;
  --r: 2px;

  --shadow: 0 24px 60px -24px rgba(0,0,0,.85);
  --glow:   0 0 0 1px rgba(201,162,75,.25), 0 0 36px -10px rgba(201,162,75,.35);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.6;
  font-size: 17px;
  letter-spacing: .01em;
  overflow-x: hidden;
  position: relative;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* film grain + vignette atmosphere */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  mix-blend-mode: overlay; opacity: .6;
}
body::after {
  content: "";
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(120% 90% at 50% -10%, transparent 55%, rgba(0,0,0,.55) 100%);
}
main, header, footer { position: relative; z-index: 2; }

/* ---------- Typography ---------- */
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 600; line-height: 1.05; letter-spacing: -.01em; }
.eyebrow {
  font-family: var(--mono);
  font-size: .72rem; letter-spacing: .32em; text-transform: uppercase;
  color: var(--gold); font-weight: 500;
}
.eyebrow.danger { color: var(--crimson-l); }
.dim { color: var(--ink-3); }
.serif-em { font-style: italic; color: var(--gold-soft); }

/* selection */
::selection { background: var(--gold); color: #0a0a0b; }

/* scrollbar */
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: #2a2a2f; border: 3px solid var(--bg); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold-deep); }

/* ---------- Layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: clamp(56px, 9vw, 110px) 0; }
.section-tight { padding: clamp(40px, 6vw, 70px) 0; }
.divider { height: 1px; background: linear-gradient(90deg, transparent, var(--line), transparent); }

.sec-head { margin-bottom: 44px; max-width: 760px; }
.sec-head h2 { font-size: clamp(2.1rem, 5vw, 3.4rem); margin: 12px 0 14px; }
.sec-head p { color: var(--ink-2); font-size: 1.05rem; }

/* ---------- Classified top bar ---------- */
.classbar {
  font-family: var(--mono); font-size: .66rem; letter-spacing: .28em;
  text-transform: uppercase; color: var(--ink-3);
  border-bottom: 1px solid var(--line-soft);
  background: #060607;
}
.classbar .wrap { display: flex; justify-content: space-between; align-items: center; height: 30px; gap: 16px; }
.classbar .stamp { color: var(--crimson-l); }
.classbar .blink::after { content: "●"; color: var(--gold); margin-left: 8px; animation: blink 1.6s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* ---------- Header / Nav ---------- */
.site-head {
  position: sticky; top: 0; z-index: 50;
  background: rgba(8,8,9,.82);
  backdrop-filter: blur(14px) saturate(120%);
  border-bottom: 1px solid var(--line-soft);
}
.site-head .wrap { display: flex; align-items: center; justify-content: space-between; height: 66px; }
.brand { display: flex; align-items: center; gap: 12px; font-family: var(--serif); }
.brand .seal {
  width: 34px; height: 34px; flex: 0 0 auto;
  border: 1.5px solid var(--gold); border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--mono); font-weight: 700; font-size: .7rem; color: var(--gold);
  position: relative;
}
.brand .seal::after {
  content:""; position:absolute; inset:4px; border:1px solid rgba(201,162,75,.35); border-radius:50%;
}
.brand b { font-size: 1.25rem; font-weight: 700; letter-spacing: .02em; }
.brand b i { color: var(--gold); font-style: normal; }
.brand small { display:block; font-family: var(--mono); font-size:.56rem; letter-spacing:.3em; color: var(--ink-3); text-transform: uppercase; margin-top:-2px;}

.nav { display: flex; align-items: center; gap: 6px; }
.nav a {
  font-family: var(--sans); font-size: .82rem; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ink-2); padding: 8px 13px; border-radius: var(--r);
  transition: color .2s, background .2s; position: relative;
}
.nav a:hover { color: var(--ink); }
.nav a.active { color: var(--gold); }
.nav a.active::after {
  content:""; position:absolute; left:13px; right:13px; bottom:2px; height:1px; background: var(--gold);
}
.nav-cta {
  font-family: var(--mono) !important; font-size: .74rem !important; letter-spacing: .14em !important;
  border: 1px solid var(--gold); color: var(--gold) !important;
  padding: 9px 16px !important; margin-left: 8px;
}
.nav-cta:hover { background: var(--gold); color: #0a0a0b !important; }
.nav-toggle { display: none; background: none; border: 1px solid var(--line); color: var(--ink); width: 42px; height: 38px; border-radius: var(--r); cursor: pointer; }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content:""; display:block; width:18px; height:1.5px; background: var(--ink); position: relative; margin: 0 auto;
}
.nav-toggle span::before { position:absolute; top:-6px; } .nav-toggle span::after { position:absolute; top:6px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: .82rem; letter-spacing: .14em; text-transform: uppercase;
  padding: 14px 26px; border-radius: var(--r); border: 1px solid transparent;
  cursor: pointer; transition: all .22s ease; white-space: nowrap;
}
.btn .arr { transition: transform .22s; }
.btn:hover .arr { transform: translateX(4px); }
.btn-gold { background: var(--gold); color: #0a0a0b; font-weight: 700; }
.btn-gold:hover { background: var(--gold-soft); box-shadow: var(--glow); }
.btn-ghost { border-color: var(--line); color: var(--ink); }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); }
.btn-crimson { background: var(--crimson); color: #fff; font-weight: 700; }
.btn-crimson:hover { background: var(--crimson-l); }

/* ---------- HERO ---------- */
.hero { position: relative; overflow: hidden; padding: clamp(60px, 9vw, 120px) 0 clamp(50px, 7vw, 90px); }
.hero::before { /* gun-barrel rifling */
  content:""; position:absolute; top:-22%; right:-14%; width: 720px; height: 720px; pointer-events:none; opacity:.5;
  background:
    radial-gradient(circle at center, transparent 28%, rgba(201,162,75,.10) 28.4%, transparent 30%),
    radial-gradient(circle at center, transparent 40%, rgba(201,162,75,.08) 40.4%, transparent 42%),
    radial-gradient(circle at center, transparent 52%, rgba(201,162,75,.06) 52.4%, transparent 54%),
    radial-gradient(circle at center, rgba(177,18,38,.18) 0%, transparent 22%);
  filter: blur(.3px);
}
.hero .wrap { position: relative; z-index: 3; }
.hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 56px; align-items: center; }
.hero-kicker { display:flex; align-items:center; gap:14px; margin-bottom: 22px; }
.hero-kicker .rule { height:1px; width:54px; background: var(--gold); }
.hero h1 {
  font-size: clamp(3.4rem, 9vw, 6.6rem); line-height: .92; margin: 0 0 8px;
  text-transform: uppercase; letter-spacing: -.02em;
}
.hero h1 .o7 { color: var(--gold); }
.hero h1 .light { font-style: italic; font-weight: 500; color: var(--ink); display:block; }
.hero .tag {
  font-family: var(--mono); font-size: .9rem; letter-spacing: .26em; text-transform: uppercase;
  color: var(--gold-soft); margin: 18px 0 26px; padding-left: 16px; border-left: 2px solid var(--crimson);
}
.hero .lede { font-size: 1.12rem; color: var(--ink-2); max-width: 540px; margin-bottom: 34px; }
.hero .cta-row { display: flex; gap: 14px; flex-wrap: wrap; }

/* ---------- Countdown ---------- */
.countdown-card {
  background: linear-gradient(160deg, var(--bg-3), var(--bg-2));
  border: 1px solid var(--line); border-radius: 4px; padding: 30px 30px 26px;
  box-shadow: var(--shadow); position: relative;
}
.countdown-card::before {
  content:"// LAUNCH SEQUENCE"; position:absolute; top:-9px; left:24px;
  font-family: var(--mono); font-size:.6rem; letter-spacing:.28em; color: var(--gold);
  background: var(--bg-2); padding: 0 8px;
}
.countdown-card .cd-head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom: 20px; }
.countdown-card .cd-head .lab { font-family: var(--mono); font-size:.68rem; letter-spacing:.2em; color: var(--ink-3); text-transform:uppercase; }
.countdown-card .cd-head .date { font-family: var(--serif); font-size: 1.3rem; color: var(--gold-soft); font-style: italic; }
.cd-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.cd-cell { text-align: center; background: #0c0c0e; border: 1px solid var(--line-soft); border-radius: 3px; padding: 16px 6px 10px; }
.cd-cell .num { font-family: var(--mono); font-weight: 700; font-size: clamp(1.8rem, 5vw, 2.7rem); color: var(--ink); line-height: 1; font-variant-numeric: tabular-nums; }
.cd-cell .lbl { font-family: var(--mono); font-size: .58rem; letter-spacing: .2em; color: var(--ink-3); text-transform: uppercase; margin-top: 8px; }
.cd-foot { margin-top: 18px; font-family: var(--mono); font-size: .68rem; letter-spacing: .12em; color: var(--ink-3); display:flex; align-items:center; gap:8px; }
.cd-foot .dot { width:7px; height:7px; border-radius:50%; background: var(--crimson-l); box-shadow:0 0 10px var(--crimson-l); animation: blink 1.4s steps(1) infinite; }
.cd-live { color: var(--gold); }

/* ---------- Quick facts strip ---------- */
.facts { border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); background: #08080a; }
.facts .wrap { display:grid; grid-template-columns: repeat(4,1fr); }
.fact { padding: 26px 22px; border-left:1px solid var(--line-soft); }
.fact:first-child { border-left:none; }
.fact .k { font-family: var(--mono); font-size:.62rem; letter-spacing:.22em; color: var(--ink-3); text-transform:uppercase; margin-bottom:8px; }
.fact .v { font-family: var(--serif); font-size: 1.5rem; color: var(--ink); line-height:1.1; }
.fact .v small { display:block; font-family: var(--sans); font-size:.8rem; color: var(--ink-3); margin-top:4px; letter-spacing:.04em; }

/* ---------- Cards / grids ---------- */
.grid { display: grid; gap: 22px; }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }

.card {
  background: var(--panel); border: 1px solid var(--line-soft); border-radius: 4px;
  padding: 28px; transition: border-color .25s, transform .25s; position: relative; overflow: hidden;
}
.card::after { content:""; position:absolute; top:0; left:0; width:0; height:2px; background: var(--gold); transition: width .3s; }
.card:hover { border-color: var(--line); transform: translateY(-3px); }
.card:hover::after { width: 100%; }
.card .idx { font-family: var(--mono); font-size:.66rem; letter-spacing:.2em; color: var(--gold-deep); }
.card h3 { font-size: 1.5rem; margin: 10px 0 10px; }
.card p { color: var(--ink-2); font-size: .98rem; }
.card .more { font-family: var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color: var(--gold); margin-top:16px; display:inline-flex; gap:8px; }

/* dossier / nav cards (home) */
.dossier { display:flex; flex-direction:column; min-height: 200px; }
.dossier .tagno { font-family: var(--mono); font-size:.62rem; letter-spacing:.2em; color: var(--ink-3); }
.dossier h3 { margin-top: auto; }

/* ---------- Spec tables ---------- */
.spec-wrap { display:grid; grid-template-columns: repeat(2,1fr); gap: 22px; }
.spec {
  background: var(--panel); border:1px solid var(--line-soft); border-radius:4px; overflow:hidden;
}
.spec.rec { border-color: var(--gold-deep); }
.spec-top { padding: 20px 24px; border-bottom:1px solid var(--line-soft); display:flex; justify-content:space-between; align-items:center; }
.spec-top .tier { font-family: var(--serif); font-size: 1.7rem; }
.spec.rec .spec-top { background: linear-gradient(90deg, rgba(201,162,75,.10), transparent); }
.spec-top .target { font-family: var(--mono); font-size:.7rem; letter-spacing:.14em; color: var(--gold); border:1px solid var(--gold-deep); padding:4px 10px; border-radius:2px; }
.spec table { width:100%; border-collapse: collapse; }
.spec td { padding: 13px 24px; border-bottom:1px solid var(--line-soft); vertical-align: top; }
.spec tr:last-child td { border-bottom:none; }
.spec td:first-child { font-family: var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-3); width: 34%; white-space:nowrap; }
.spec td:last-child { color: var(--ink); font-size:.96rem; }

/* ---------- Generic data table ---------- */
.dtable { width:100%; border-collapse: collapse; background: var(--panel); border:1px solid var(--line-soft); border-radius:4px; overflow:hidden; }
.dtable th { font-family: var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color: var(--gold); text-align:left; padding:16px 20px; background:#0c0c0e; border-bottom:1px solid var(--line); }
.dtable td { padding:15px 20px; border-bottom:1px solid var(--line-soft); color: var(--ink-2); font-size:.96rem; vertical-align: top; }
.dtable tr:last-child td { border-bottom:none; }
.dtable td b, .dtable td strong { color: var(--ink); font-weight:600; }
.dtable tr:hover td { background: rgba(201,162,75,.03); }

/* ---------- Character cards ---------- */
.char {
  background: var(--panel); border:1px solid var(--line-soft); border-radius:4px; padding:26px;
  position: relative; transition: border-color .25s, transform .25s;
}
.char:hover { border-color: var(--gold-deep); transform: translateY(-3px); }
.char .avatar {
  width:60px; height:60px; border-radius:50%; border:1.5px solid var(--gold);
  display:grid; place-items:center; font-family:var(--serif); font-size:1.6rem; color: var(--gold);
  margin-bottom:18px; background: radial-gradient(circle, rgba(201,162,75,.12), transparent 70%);
}
.char h3 { font-size: 1.45rem; }
.char .actor { font-family: var(--mono); font-size:.72rem; letter-spacing:.12em; color: var(--gold); text-transform:uppercase; margin: 4px 0 12px; }
.char p { color: var(--ink-2); font-size:.95rem; }
.char .role-tag { position:absolute; top:22px; right:22px; font-family:var(--mono); font-size:.56rem; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-3); border:1px solid var(--line); padding:3px 8px; border-radius:2px; }
.char.villain .avatar { border-color: var(--crimson-l); color: var(--crimson-l); background: radial-gradient(circle, rgba(177,18,38,.18), transparent 70%); }
.char.villain .role-tag { color: var(--crimson-l); border-color: rgba(177,18,38,.5); }

/* ---------- Gadget list ---------- */
.gadget { display:flex; gap:18px; padding:22px; background: var(--panel); border:1px solid var(--line-soft); border-radius:4px; transition: border-color .25s; }
.gadget:hover { border-color: var(--gold-deep); }
.gadget .ico { flex:0 0 auto; width:46px; height:46px; border:1px solid var(--gold-deep); border-radius:3px; display:grid; place-items:center; color: var(--gold); }
.gadget .ico svg { width:24px; height:24px; }
.gadget h4 { font-family: var(--serif); font-size:1.3rem; margin-bottom:4px; }
.gadget p { color: var(--ink-2); font-size:.92rem; }

/* ---------- Editions ---------- */
.ed-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:18px; align-items: start; }
.edition { background: var(--panel); border:1px solid var(--line-soft); border-radius:4px; padding:26px 22px; display:flex; flex-direction:column; position:relative; }
.edition.feat { border-color: var(--gold); box-shadow: var(--glow); }
.edition.feat::before { content:"BEST VALUE"; position:absolute; top:-10px; left:50%; transform:translateX(-50%); font-family:var(--mono); font-size:.58rem; letter-spacing:.22em; background: var(--gold); color:#0a0a0b; padding:3px 12px; border-radius:2px; font-weight:700; }
.edition .ename { font-family: var(--serif); font-size:1.5rem; margin-bottom:6px; }
.edition .price { font-family: var(--mono); font-size:1.6rem; color: var(--gold); font-weight:700; margin-bottom:4px; }
.edition .price small { font-size:.8rem; color: var(--ink-3); }
.edition ul { margin:18px 0 22px; display:flex; flex-direction:column; gap:10px; }
.edition li { font-size:.9rem; color: var(--ink-2); padding-left:20px; position:relative; }
.edition li::before { content:"+"; position:absolute; left:0; color: var(--gold); font-family:var(--mono); }
.edition .btn { margin-top:auto; width:100%; justify-content:center; }

/* ---------- Store buttons ---------- */
.stores { display:grid; grid-template-columns: repeat(3,1fr); gap:14px; }
.store { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:18px 22px; background: var(--panel); border:1px solid var(--line-soft); border-radius:4px; transition: all .2s; }
.store:hover { border-color: var(--gold); background: var(--bg-3); }
.store b { font-family: var(--serif); font-size:1.2rem; }
.store small { display:block; font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; color: var(--ink-3); text-transform:uppercase; }
.store .arr { color: var(--gold); }

/* ---------- FAQ ---------- */
.faq { border:1px solid var(--line-soft); border-radius:4px; overflow:hidden; background: var(--panel); }
.faq details { border-bottom:1px solid var(--line-soft); }
.faq details:last-child { border-bottom:none; }
.faq summary { cursor:pointer; list-style:none; padding:22px 26px; display:flex; justify-content:space-between; align-items:center; gap:16px; font-family: var(--serif); font-size:1.3rem; color: var(--ink); transition: color .2s; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary:hover { color: var(--gold); }
.faq summary .q { font-family:var(--mono); font-size:.66rem; color: var(--gold-deep); letter-spacing:.16em; margin-right:6px; }
.faq summary .pm { font-family:var(--mono); color: var(--gold); flex:0 0 auto; transition: transform .25s; }
.faq details[open] summary .pm { transform: rotate(45deg); }
.faq .ans { padding: 0 26px 24px; color: var(--ink-2); font-size:.98rem; }
.faq .ans a { color: var(--gold); border-bottom:1px solid var(--gold-deep); }

/* ---------- Prose (article body) ---------- */
.prose { max-width: 760px; }
.prose p { margin-bottom: 20px; color: var(--ink-2); font-size:1.05rem; }
.prose h3 { font-size: 1.9rem; margin: 40px 0 16px; color: var(--ink); }
.prose h3::before { content:"// "; color: var(--gold); font-family:var(--mono); font-size:1rem; }
.prose strong { color: var(--ink); }
.prose ul.bullets { margin: 0 0 22px; display:flex; flex-direction:column; gap:10px; }
.prose ul.bullets li { padding-left:22px; position:relative; color: var(--ink-2); }
.prose ul.bullets li::before { content:"▸"; position:absolute; left:0; color: var(--gold); }
.prose blockquote { border-left:2px solid var(--crimson); padding:6px 0 6px 22px; margin:26px 0; font-family:var(--serif); font-style:italic; font-size:1.3rem; color: var(--gold-soft); }
.prose blockquote cite { display:block; font-family:var(--mono); font-style:normal; font-size:.72rem; letter-spacing:.14em; color: var(--ink-3); margin-top:10px; text-transform:uppercase; }

/* aside dossier box */
.dossier-box { background:#0c0c0e; border:1px solid var(--line); border-radius:4px; padding:24px; position:relative; }
.dossier-box::before { content:"CLASSIFIED // EYES ONLY"; position:absolute; top:-9px; left:18px; background:#0c0c0e; padding:0 8px; font-family:var(--mono); font-size:.58rem; letter-spacing:.2em; color: var(--crimson-l); }
.dossier-box dl { display:grid; grid-template-columns:auto 1fr; gap:12px 18px; }
.dossier-box dt { font-family:var(--mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-3); padding-top:3px; }
.dossier-box dd { color: var(--ink); font-size:.96rem; }

/* page hero (interior) */
.phero { padding: clamp(50px,7vw,90px) 0 clamp(30px,4vw,50px); border-bottom:1px solid var(--line-soft); position:relative; }
.phero h1 { font-size: clamp(2.6rem, 7vw, 5rem); text-transform:uppercase; margin:14px 0 16px; letter-spacing:-.02em; }
.phero h1 em { color: var(--gold); font-style:normal; }
.phero p { color: var(--ink-2); max-width: 640px; font-size:1.1rem; }
.breadcrumb { font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-3); }
.breadcrumb a:hover { color: var(--gold); }
.breadcrumb span { color: var(--gold); }

/* mini countdown banner (interior pages) */
.mini-cd { display:flex; align-items:center; gap:18px; flex-wrap:wrap; background:#0c0c0e; border:1px solid var(--line); border-radius:4px; padding:16px 22px; }
.mini-cd .ml { font-family:var(--mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color: var(--ink-3); }
.mini-cd .mv { font-family:var(--mono); font-weight:700; color: var(--gold); font-size:1.05rem; letter-spacing:.06em; }

/* ---------- CTA band ---------- */
.cta-band { background: linear-gradient(120deg, var(--bg-3), var(--bg)); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); text-align:center; }
.cta-band h2 { font-size: clamp(2rem,5vw,3.2rem); margin-bottom:14px; }
.cta-band p { color: var(--ink-2); max-width:560px; margin:0 auto 30px; }
.cta-band .cta-row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.site-foot { background:#060607; border-top:1px solid var(--line-soft); padding: 56px 0 30px; }
.foot-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:34px; margin-bottom:40px; }
.site-foot h5 { font-family:var(--mono); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color: var(--gold); margin-bottom:16px; }
.site-foot ul li { margin-bottom:9px; }
.site-foot a { color: var(--ink-3); font-size:.92rem; transition: color .2s; }
.site-foot a:hover { color: var(--ink); }
.foot-brand p { color: var(--ink-3); font-size:.9rem; max-width:300px; margin-top:14px; }
.disclaimer { border-top:1px solid var(--line-soft); padding-top:24px; font-size:.78rem; color: var(--ink-3); display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.disclaimer .mono { font-family:var(--mono); letter-spacing:.06em; }

/* ---------- Reveal animation ---------- */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .facts .wrap { grid-template-columns: repeat(2,1fr); }
  .fact:nth-child(3) { border-left:none; }
  .fact:nth-child(n+3) { border-top:1px solid var(--line-soft); }
  .grid-3, .grid-4 { grid-template-columns: repeat(2,1fr); }
  .spec-wrap { grid-template-columns: 1fr; }
  .ed-grid { grid-template-columns: repeat(2,1fr); }
  .stores { grid-template-columns: repeat(2,1fr); }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  body { font-size: 16px; }
  .nav { position: fixed; inset: 66px 0 auto 0; flex-direction: column; align-items: stretch; gap:0;
    background: rgba(8,8,9,.98); border-bottom:1px solid var(--line); padding: 10px 16px 18px;
    transform: translateY(-130%); transition: transform .3s; max-height: calc(100vh - 66px); overflow:auto; }
  .nav.open { transform: none; }
  .nav a { padding: 13px 8px; border-bottom:1px solid var(--line-soft); }
  .nav-cta { margin: 12px 0 0; text-align:center; justify-content:center; }
  .nav-toggle { display:block; }
  .grid-2, .grid-3, .grid-4, .ed-grid, .stores { grid-template-columns: 1fr; }
  .facts .wrap { grid-template-columns: 1fr 1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .cd-grid { grid-template-columns: repeat(4,1fr); gap:6px; }
  .cd-cell { padding:12px 2px 8px; }
}
@media (max-width: 460px) {
  .foot-grid { grid-template-columns: 1fr; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal { opacity:1; transform:none; }
}
