/* ═══════════════════════════════════════════════════════════
   DM Shots — Nachtwacht Media
   D&D Beyond-inspired premium e-commerce aesthetic
   ═══════════════════════════════════════════════════════════ */

:root{
  /* Background — deep navy-teal (dndbeyond-style) */
  --bg:#0e1622;
  --bg-2:#141d2c;
  --bg-3:#0a121c;
  --bg-card:#1a2536;
  --bg-card-hover:#202c40;

  /* Foreground — soft off-cream */
  --fg:#e8e3d4;
  --fg-soft:#a8a89c;
  --fg-dim:#6f6e62;

  /* Primary accent — D&D red (iconic) */
  --red:#e63946;
  --red-bright:#ff4655;
  --red-dark:#b8242f;
  --red-glow:rgba(230,57,70,.28);

  /* Secondary — refined champagne gold for premium touches */
  --gold:#d4b46a;
  --gold-light:#ecd6a3;
  --gold-glow:rgba(212,180,106,.2);

  /* Lines & borders */
  --line:rgba(255,255,255,.07);
  --line-strong:rgba(255,255,255,.12);
  --line-gold:rgba(212,180,106,.22);

  /* Card surface */
  --card-shadow:0 2px 8px rgba(0,0,0,.32),0 12px 32px rgba(0,0,0,.4);
  --card-shadow-hover:0 4px 14px rgba(0,0,0,.45),0 24px 50px rgba(0,0,0,.55),0 0 30px var(--red-glow);

  /* Typography */
  --sans:'Inter','SF Pro Text',-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif;
  --serif-h:'Cinzel',Georgia,serif;
  --serif-b:'Lora',Georgia,serif;

  /* Easings */
  --ease-out:cubic-bezier(.16,.84,.32,1);
  --ease-soft:cubic-bezier(.25,.46,.45,.94);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{
  background:var(--bg);color:var(--fg);
  font-family:var(--sans);
  min-height:100vh;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-size:16px;line-height:1.55;
}

body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse at 12% 8%,rgba(230,57,70,.06),transparent 50%),
    radial-gradient(ellipse at 88% 90%,rgba(212,180,106,.05),transparent 55%),
    linear-gradient(180deg,#0e1622 0%,#0c1320 50%,#0a121c 100%);
}
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.7'/></svg>");
}

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ═══════════════════════════════════════════════════════════
   TOP NAV — sticky, dndbeyond style
   ═══════════════════════════════════════════════════════════ */
.topnav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 5%;
  background:rgba(10,18,28,.78);backdrop-filter:blur(20px) saturate(140%);
  border-bottom:1px solid var(--line);
  transition:background .3s var(--ease-out),padding .3s var(--ease-out);
}
.topnav.scrolled{
  background:rgba(8,14,22,.92);padding:10px 5%;
  box-shadow:0 6px 24px rgba(0,0,0,.4);
}
.topnav-brand{
  display:flex;align-items:center;gap:12px;
  font-family:var(--serif-h);font-weight:700;
  font-size:1.05rem;letter-spacing:.22em;color:#f4ecd2;
  text-transform:uppercase;
}
.topnav-brand img{width:28px;height:28px;border-radius:50%}
.topnav-links{display:flex;align-items:center;gap:6px}
.topnav-links a{
  padding:8px 16px;font-size:.88rem;color:var(--fg-soft);
  border-radius:6px;transition:color .25s,background .25s;
  font-weight:500;letter-spacing:.02em;
}
.topnav-links a:hover{color:#fff;background:rgba(255,255,255,.04)}
.topnav-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 18px;
  background:var(--red);color:#fff;
  border-radius:6px;font-size:.85rem;font-weight:600;letter-spacing:.02em;
  transition:background .25s var(--ease-out),transform .25s,box-shadow .25s;
}
.topnav-cta:hover{
  background:var(--red-bright);transform:translateY(-1px);
  box-shadow:0 6px 20px var(--red-glow);
}
.topnav-session{display:flex;align-items:center;gap:10px;font-size:.85rem}
.topnav-session img{width:28px;height:28px;border-radius:50%;border:1px solid var(--line-strong)}
.topnav-session button{
  background:none;border:none;color:var(--fg-soft);cursor:pointer;
  font:inherit;font-size:.78rem;padding:4px 8px;border-radius:4px;
}
.topnav-session button:hover{color:var(--red-bright)}
@media(max-width:760px){
  .topnav-links{display:none}
}

/* ═══════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════ */
.hero{
  position:relative;min-height:92vh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:140px 6% 90px;overflow:hidden;
  z-index:2;
}
.hero-bg{
  position:absolute;inset:-5%;z-index:-3;
  background-size:cover;background-position:center 35%;
  filter:saturate(.75) brightness(.42) contrast(1.05);
  animation:hero-zoom 28s ease-in-out infinite alternate;
}
@keyframes hero-zoom{
  0%{transform:scale(1.05) translateY(0)}
  100%{transform:scale(1.18) translateY(-2%)}
}
.hero::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse at 50% 100%,rgba(10,18,28,.96) 0%,transparent 70%),
    radial-gradient(ellipse at 50% 0%,rgba(10,18,28,.85) 0%,transparent 60%),
    linear-gradient(180deg,rgba(10,18,28,.5) 0%,rgba(10,18,28,.3) 35%,rgba(10,18,28,.95) 100%);
}
.embers{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.ember{
  position:absolute;bottom:-20px;
  width:3px;height:3px;border-radius:50%;
  background:radial-gradient(circle,rgba(236,214,163,.85),rgba(212,180,106,0));
  filter:blur(.5px);
  animation:ember-rise linear infinite;
  opacity:0;
}
@keyframes ember-rise{
  0%{transform:translateY(0) translateX(0) scale(.7);opacity:0}
  10%{opacity:.7}
  60%{opacity:.55}
  100%{transform:translateY(-115vh) translateX(var(--drift,40px)) scale(1.05);opacity:0}
}
.hero > *{position:relative;z-index:1}

.brand-mark{
  display:inline-flex;align-items:center;gap:18px;
  font-family:var(--serif-h);font-weight:500;
  font-size:12px;letter-spacing:.42em;color:var(--gold-light);
  text-transform:uppercase;margin-bottom:30px;
}
.brand-mark::before,.brand-mark::after{
  content:'';width:40px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-light));
}
.brand-mark::after{background:linear-gradient(90deg,var(--gold-light),transparent)}

.hero h1{
  font-family:var(--serif-h);font-weight:900;
  font-size:clamp(3.2rem,9vw,6.5rem);
  letter-spacing:.12em;line-height:1;
  color:#f8f1da;
  text-shadow:0 0 80px rgba(230,57,70,.2),0 6px 30px rgba(0,0,0,.7);
  margin-bottom:14px;
}
.hero-sub{
  font-family:var(--serif-h);font-weight:500;
  font-size:clamp(.82rem,1.2vw,.95rem);letter-spacing:.5em;
  color:var(--gold);text-transform:uppercase;margin-bottom:36px;
}
.hero-tagline{
  font-family:var(--sans);font-weight:400;
  font-size:clamp(1.05rem,1.5vw,1.25rem);
  color:#cdc7b6;max-width:680px;line-height:1.65;margin:0 auto 44px;
  text-shadow:0 2px 16px rgba(0,0,0,.7);
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-scroll-hint{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  font-family:var(--serif-h);font-size:.62rem;letter-spacing:.35em;
  color:var(--fg-soft);text-transform:uppercase;font-weight:500;
  animation:bob 2.4s ease-in-out infinite;
}
.hero-scroll-hint::after{
  content:'';display:block;width:1px;height:30px;margin:10px auto 0;
  background:linear-gradient(180deg,var(--gold),transparent);
}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ═══════════════════════════════════════════════════════════
   BUTTONS — dndbeyond style: red CTA, ghost secondary
   ═══════════════════════════════════════════════════════════ */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;
  background:var(--red);color:#fff;
  border:none;border-radius:6px;
  font-family:var(--sans);font-weight:600;letter-spacing:.04em;font-size:.88rem;
  cursor:pointer;transition:background .25s var(--ease-out),transform .25s,box-shadow .3s;
  text-transform:none;overflow:hidden;
}
.btn:hover{
  background:var(--red-bright);
  box-shadow:0 8px 24px var(--red-glow);
  transform:translateY(-1px);
}
.btn.ghost{
  background:transparent;color:var(--fg);
  border:1px solid var(--line-strong);
}
.btn.ghost:hover{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.22);
  box-shadow:none;
}
.btn.locked{
  background:rgba(255,255,255,.04);color:var(--fg-dim);
  border:1px solid var(--line);cursor:not-allowed;
}
.btn.locked:hover{transform:none;box-shadow:none;background:rgba(255,255,255,.04)}
.btn.free{
  background:#3a9d5f;color:#fff;
}
.btn.free:hover{background:#46b86d;box-shadow:0 8px 24px rgba(58,157,95,.3)}
.btn.big{padding:16px 32px;font-size:.96rem}
.btn.gold{
  background:linear-gradient(180deg,#e9c87f,var(--gold));
  color:#1a1408;font-weight:700;letter-spacing:.06em;
}
.btn.gold:hover{
  background:linear-gradient(180deg,#f3d999,#dec27a);
  box-shadow:0 10px 28px var(--gold-glow);
}

/* ═══════════════════════════════════════════════════════════
   SECTION HEADS
   ═══════════════════════════════════════════════════════════ */
section{position:relative;z-index:2;padding:96px 6%}
.section-head{text-align:center;margin-bottom:52px;max-width:760px;margin-left:auto;margin-right:auto}
.kicker{
  display:inline-block;
  font-family:var(--serif-h);font-weight:500;letter-spacing:.4em;
  color:var(--red);font-size:.72rem;text-transform:uppercase;
}
.section-head h2{
  font-family:var(--serif-h);font-weight:900;
  font-size:clamp(2.1rem,4.2vw,3.2rem);
  letter-spacing:.04em;color:#f8f1da;
  margin:14px 0 14px;
  line-height:1.15;
}
.section-head .lead{
  font-family:var(--sans);font-weight:400;
  color:var(--fg-soft);font-size:1.04rem;line-height:1.65;
}
.divider-ornate{
  display:flex;align-items:center;justify-content:center;
  margin:16px auto 0;gap:16px;
  color:var(--gold);
}
.divider-ornate::before,.divider-ornate::after{
  content:'';width:72px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-light));
}
.divider-ornate::after{background:linear-gradient(90deg,var(--gold-light),transparent)}
.divider-ornate svg{width:22px;height:22px;color:var(--gold)}

/* ═══════════════════════════════════════════════════════════
   VALUE STRIP
   ═══════════════════════════════════════════════════════════ */
.value-strip{
  position:relative;z-index:2;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  padding:56px 6%;
  background:rgba(20,29,44,.5);
  border-bottom:1px solid var(--line);
}
.value-item{
  text-align:center;padding:0 24px;
  border-right:1px solid var(--line);
}
.value-item:last-child{border-right:none}
.value-icon{
  width:44px;height:44px;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  color:var(--red);
}
.value-icon svg{width:100%;height:100%}
.value-title{
  font-family:var(--sans);font-weight:700;font-size:.95rem;
  letter-spacing:.04em;color:#fff;margin-bottom:8px;
}
.value-text{
  font-family:var(--sans);font-size:.9rem;
  color:var(--fg-soft);line-height:1.55;
}
@media(max-width:760px){
  .value-strip{grid-template-columns:repeat(2,1fr);padding:36px 5%;gap:20px}
  .value-item{padding:14px;border:none}
}

/* ═══════════════════════════════════════════════════════════
   FEATURED CARD
   ═══════════════════════════════════════════════════════════ */
.featured{
  position:relative;display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:48px;
  align-items:center;
  padding:48px;
  background:var(--bg-card);
  border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--card-shadow);
  max-width:1240px;margin:0 auto;
}
.featured-images{
  position:relative;border-radius:10px;overflow:hidden;
  aspect-ratio:4/3;
  box-shadow:0 16px 50px rgba(0,0,0,.65);
}
.featured-images::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 50%,rgba(10,18,28,.35) 100%);
}
.featured-images img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:0;transition:opacity 1.4s var(--ease-soft);
}
.featured-images img.active{opacity:1;animation:slow-ken-burns 8s ease-in-out forwards}
@keyframes slow-ken-burns{
  0%{transform:scale(1)}100%{transform:scale(1.06)}
}

.featured-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:600;
  font-size:.74rem;letter-spacing:.08em;color:var(--gold-light);
  padding:6px 14px;background:rgba(212,180,106,.1);
  border:1px solid var(--line-gold);border-radius:24px;
  text-transform:uppercase;margin-bottom:20px;
}
.featured h3{
  font-family:var(--serif-h);font-weight:700;
  font-size:clamp(1.75rem,3.2vw,2.5rem);
  letter-spacing:.04em;color:#f8f1da;line-height:1.15;margin-bottom:20px;
}
.featured .blurb{
  font-family:var(--sans);
  color:var(--fg);line-height:1.7;margin-bottom:26px;font-size:1rem;
}
.dropcap{
  float:left;font-family:var(--serif-h);font-weight:900;
  font-size:3.8rem;line-height:.85;
  color:var(--red);
  padding:6px 12px 0 0;margin-top:4px;
}
.featured-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:10px;margin-bottom:28px;
}
.featured-stats .stat{
  text-align:center;padding:14px 8px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:6px;
}
.featured-stats .stat-val{
  font-family:var(--serif-h);font-weight:700;
  font-size:1.5rem;color:#f8f1da;margin-bottom:2px;
}
.featured-stats .stat-key{
  font-family:var(--sans);font-weight:600;
  font-size:.7rem;letter-spacing:.1em;color:var(--fg-soft);text-transform:uppercase;
}
.featured-actions{display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:920px){
  .featured{grid-template-columns:1fr;padding:32px;gap:32px}
}

/* ═══════════════════════════════════════════════════════════
   PACK GRID
   ═══════════════════════════════════════════════════════════ */
.packs{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;max-width:1240px;margin:0 auto;
}
.pack{
  position:relative;background:var(--bg-card);
  border:1px solid var(--line);border-radius:12px;overflow:hidden;
  transition:transform .35s var(--ease-out),border-color .35s,box-shadow .35s;
  display:flex;flex-direction:column;
  box-shadow:var(--card-shadow);
}
.pack:hover{
  transform:translateY(-5px);border-color:rgba(230,57,70,.35);
  background:var(--bg-card-hover);
  box-shadow:var(--card-shadow-hover);
}
.pack-thumb{
  aspect-ratio:16/10;width:100%;
  background-size:cover;background-position:center;
  position:relative;
  transition:transform .8s var(--ease-soft);
}
.pack:hover .pack-thumb{transform:scale(1.04)}
.pack-thumb::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(10,18,28,.6) 100%);
}
.pack-thumb-tag{
  position:absolute;top:12px;left:12px;z-index:2;
  font-family:var(--sans);font-weight:700;
  font-size:.68rem;letter-spacing:.1em;color:#fff;
  padding:5px 11px;background:rgba(230,57,70,.92);
  border-radius:4px;text-transform:uppercase;
}
.pack-thumb-tag.free{background:#3a9d5f}
.pack-head{padding:20px 22px 10px}
.pack-name{
  font-family:var(--serif-h);font-weight:700;
  font-size:1.18rem;color:#f8f1da;letter-spacing:.02em;line-height:1.25;
}
.pack-tagline{
  font-family:var(--sans);font-style:italic;
  color:var(--fg-soft);font-size:.88rem;margin-top:6px;
}
.pack-body{padding:0 22px 14px;flex:1}
.pack-blurb{font-family:var(--sans);font-size:.92rem;line-height:1.6;color:var(--fg-soft)}
.pack-foot{
  padding:14px 22px 18px;display:flex;flex-direction:column;gap:10px;
  border-top:1px solid var(--line);
}
.pack-price{
  font-family:var(--sans);font-weight:600;font-size:.92rem;
  color:var(--gold-light);letter-spacing:.02em;
}
.pack-actions{display:flex;flex-wrap:wrap;gap:8px}
.pack-actions .btn{padding:9px 16px;font-size:.78rem}

/* ═══════════════════════════════════════════════════════════
   EXTRAS
   ═══════════════════════════════════════════════════════════ */
.extras{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;max-width:1240px;margin:0 auto;
}
.extra{
  position:relative;display:flex;flex-direction:column;
  padding:30px 26px 24px;
  background:var(--bg-card);border:1px solid var(--line);border-radius:12px;
  transition:transform .35s var(--ease-out),border-color .35s,box-shadow .35s;
  box-shadow:var(--card-shadow);
}
.extra:hover{
  transform:translateY(-4px);border-color:rgba(230,57,70,.3);
  background:var(--bg-card-hover);
  box-shadow:var(--card-shadow-hover);
}
.extra-icon{
  width:48px;height:48px;margin-bottom:18px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(230,57,70,.12);border:1px solid rgba(230,57,70,.25);
  border-radius:50%;color:var(--red);
}
.extra-icon svg{width:24px;height:24px}
.extra-name{
  font-family:var(--serif-h);font-weight:700;
  font-size:1.15rem;color:#f8f1da;letter-spacing:.02em;
  margin-bottom:6px;
}
.extra-tagline{
  font-family:var(--sans);font-style:italic;
  color:var(--fg-soft);font-size:.86rem;margin-bottom:16px;
}
.extra-desc{
  font-family:var(--sans);
  color:var(--fg-soft);font-size:.9rem;line-height:1.65;
  flex:1;margin-bottom:20px;
}
.extra-foot{
  display:flex;flex-direction:column;gap:10px;
  padding-top:16px;border-top:1px solid var(--line);
}
.extra-price{
  font-family:var(--sans);font-weight:600;
  color:var(--gold-light);font-size:.98rem;
}
.extra-hint{
  font-family:var(--sans);font-style:italic;
  font-size:.78rem;color:var(--fg-soft);
}

/* ═══════════════════════════════════════════════════════════
   TIERS
   ═══════════════════════════════════════════════════════════ */
.tiers{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1100px;margin:0 auto;
}
.tier{
  position:relative;
  background:var(--bg-card);border:1px solid var(--line);border-radius:14px;
  padding:38px 28px 28px;display:flex;flex-direction:column;
  transition:transform .35s var(--ease-out),border-color .35s,box-shadow .35s;
  box-shadow:var(--card-shadow);
}
.tier:hover{
  transform:translateY(-4px);border-color:var(--line-strong);
  box-shadow:var(--card-shadow-hover);
}
.tier.featured-tier{
  border-color:var(--red);
  background:linear-gradient(180deg,#1f2638,#161d2c);
  box-shadow:0 4px 14px rgba(0,0,0,.45),0 24px 60px rgba(0,0,0,.55),0 0 50px var(--red-glow);
  transform:translateY(-8px);
}
.tier-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  font-family:var(--sans);font-weight:700;
  font-size:.7rem;letter-spacing:.16em;
  padding:7px 18px;
  background:var(--red);color:#fff;border-radius:24px;text-transform:uppercase;
  box-shadow:0 6px 18px var(--red-glow);
}
.tier-name{
  font-family:var(--serif-h);font-weight:700;
  font-size:1.45rem;color:#f8f1da;letter-spacing:.06em;margin-bottom:6px;
}
.tier-tagline{
  font-family:var(--sans);font-style:italic;
  color:var(--fg-soft);font-size:.94rem;margin-bottom:22px;
}
.tier-price{
  font-family:var(--serif-h);font-weight:700;
  font-size:2.6rem;color:#f8f1da;letter-spacing:.01em;
}
.tier-period{
  font-family:var(--sans);font-size:.9rem;color:var(--fg-soft);margin-left:4px;
}
.tier-divider{
  height:1px;margin:24px 0;
  background:linear-gradient(90deg,transparent,var(--line-strong),transparent);
}
.tier-perks{list-style:none;padding:0;margin:0 0 26px;flex:1}
.tier-perks li{
  padding:9px 0 9px 26px;font-family:var(--sans);font-size:.93rem;
  color:var(--fg);line-height:1.5;position:relative;
}
.tier-perks li::before{
  content:'';position:absolute;left:0;top:14px;
  width:14px;height:14px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='%23e63946' d='M6.5 11L3 7.5 4 6.5l2.5 2.5L11.5 4l1 1z'/></svg>") no-repeat center/contain;
}
.tier-description{
  font-family:var(--sans);
  color:var(--fg-soft);font-size:.92rem;
  line-height:1.6;margin-bottom:22px;
}
@media(max-width:920px){
  .tiers{grid-template-columns:1fr;max-width:480px;gap:28px}
  .tier.featured-tier{transform:none}
}

/* ═══════════════════════════════════════════════════════════
   REVEAL
   ═══════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════════════════════
   BANNERS, FOOTER
   ═══════════════════════════════════════════════════════════ */
.unlock-banner{
  position:relative;z-index:2;
  margin:0 6% 28px;padding:14px 22px;
  background:rgba(58,157,95,.12);border:1px solid rgba(58,157,95,.3);
  border-radius:8px;text-align:center;color:#a4d8b8;font-size:.95rem;
}

footer{
  position:relative;z-index:2;
  padding:48px 24px 30px;text-align:center;
  font-family:var(--sans);color:var(--fg-dim);font-size:.86rem;
  border-top:1px solid var(--line);
}
footer .footer-mark{
  font-family:var(--serif-h);font-weight:500;letter-spacing:.32em;
  color:var(--gold);font-size:.72rem;margin-bottom:14px;
  text-transform:uppercase;
}
footer a{color:var(--fg-soft);margin:0 8px}
footer a:hover{color:var(--red-bright)}

section[id]{scroll-margin-top:80px}

/* ═══════════════════════════════════════════════════════════
   LEGAL PAGES
   ═══════════════════════════════════════════════════════════ */
.legal-page{
  position:relative;z-index:2;
  max-width:780px;margin:0 auto;padding:140px 24px 80px;
  font-family:var(--sans);
}
.legal-page .back{
  display:inline-block;color:var(--fg-soft);font-size:.86rem;
  margin-bottom:28px;transition:color .25s;
}
.legal-page .back:hover{color:var(--red-bright)}
.legal-page h1{
  font-family:var(--serif-h);font-weight:900;
  font-size:clamp(2.1rem,4.5vw,2.8rem);
  color:#f8f1da;letter-spacing:.06em;margin-bottom:12px;
}
.legal-page .meta{
  color:var(--fg-soft);font-style:italic;font-size:.86rem;margin-bottom:32px;
}
.legal-page h2{
  font-family:var(--serif-h);font-weight:700;
  color:var(--red);font-size:1.05rem;letter-spacing:.04em;
  margin:38px 0 12px;
}
.legal-page p,.legal-page li{
  color:var(--fg);font-size:1rem;line-height:1.75;
}
.legal-page p{margin-bottom:12px}
.legal-page ul{margin:8px 0 12px 24px}
.legal-page li{margin-bottom:6px}
.legal-page a{color:var(--red-bright);text-decoration:none;border-bottom:1px solid rgba(230,57,70,.4)}
.legal-page a:hover{border-bottom-color:var(--red-bright)}
.legal-page strong{color:#fff}
.legal-page code{
  background:rgba(255,255,255,.06);border:1px solid var(--line);
  padding:1px 6px;border-radius:3px;font-size:.86em;
  color:var(--gold-light);font-family:'SF Mono',Menlo,monospace;
}
.legal-page .divider{
  margin:44px 0;height:1px;
  background:linear-gradient(90deg,transparent,var(--line-strong),transparent);
}
.legal-page .footer-mark{
  font-family:var(--serif-h);font-weight:500;letter-spacing:.32em;
  color:var(--gold);font-size:.7rem;text-transform:uppercase;margin-bottom:6px;
}
