/* ============================================================
   "5" — A Supernatural Thriller — site styles
   ============================================================ */
:root{
  --bg:#0a0a0c;
  --bg-2:#0e1014;
  --panel:#14161c;
  --panel-2:#191c23;
  --ink:#ece8de;          /* bone white */
  --muted:#9a958a;
  --faint:#6c6961;
  --line:rgba(236,232,222,.10);
  --line-strong:rgba(236,232,222,.18);
  --gold:#c9a24a;
  --gold-bright:#e7c879;
  --ember:#d8682f;
  --blood:#8e2020;
  --cold:#6f93ad;
  --parchment:#d9cbab;
  --shadow:0 24px 60px -20px rgba(0,0,0,.8);
  --maxw:1180px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"EB Garamond",Georgia,"Times New Roman",serif;
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* film grain + vignette over everything */
body::before{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;
  background:radial-gradient(120% 120% at 50% 40%,transparent 55%,rgba(0,0,0,.55) 100%);
  mix-blend-mode:multiply;
}

h1,h2,h3,.display{
  font-family:"Oswald","Arial Narrow",sans-serif;
  font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  line-height:1.05;margin:0;
}
.cinzel{font-family:"Cinzel",Georgia,serif;text-transform:none;letter-spacing:.02em}
.mono{font-family:"Special Elite","Courier New",monospace}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px)}
.section{padding:clamp(72px,10vw,130px) 0;position:relative}
.eyebrow{
  font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.32em;
  font-size:.78rem;color:var(--gold);font-weight:500;margin:0 0 14px
}
.section-title{
  font-size:clamp(2rem,5.4vw,3.6rem);margin:0 0 .35em;
}
.lead{font-size:clamp(1.05rem,2.2vw,1.3rem);color:var(--ink);max-width:60ch}
.muted{color:var(--muted)}
.divider-num{
  font-family:"Oswald",sans-serif;font-weight:700;color:rgba(201,162,74,.10);
  font-size:clamp(8rem,22vw,18rem);line-height:.7;position:absolute;
  right:2vw;top:-.15em;pointer-events:none;user-select:none;z-index:0
}

/* ---------- NAV ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,4vw,40px);
  transition:background .35s ease,padding .35s ease,border-color .35s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,8,10,.82);backdrop-filter:blur(10px);
  padding-top:12px;padding-bottom:12px;border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:12px;font-family:"Oswald",sans-serif;
  letter-spacing:.3em;text-transform:uppercase;font-size:.82rem;color:var(--ink)}
.brand .mark{
  font-family:"Oswald",sans-serif;font-weight:700;font-size:1.5rem;letter-spacing:0;
  width:38px;height:38px;display:grid;place-items:center;color:var(--bg);
  background:linear-gradient(160deg,var(--gold-bright),var(--gold));
  border-radius:6px;box-shadow:0 6px 20px -6px rgba(201,162,74,.6)
}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{
  font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.12em;
  font-size:.82rem;color:var(--muted);transition:color .2s;position:relative;padding:4px 0
}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--gold);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px}
.nav-toggle svg{width:26px;height:26px}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding-bottom:clamp(48px,8vh,90px);overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(to top,var(--bg) 2%,rgba(10,10,12,.35) 45%,rgba(10,10,12,.55) 100%),
    radial-gradient(80% 60% at 70% 30%,transparent,rgba(0,0,0,.5))}
#snow{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-meta{
  font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.34em;
  font-size:.74rem;color:var(--gold);margin-bottom:18px
}
.hero-num{
  font-family:"Oswald",sans-serif;font-weight:700;font-size:clamp(6rem,20vw,15rem);
  line-height:.78;letter-spacing:-.02em;margin:0;
  background:linear-gradient(180deg,#fff 0%,var(--ink) 35%,#8a8478 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 30px 80px rgba(0,0,0,.6)
}
.hero-tag{
  font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.16em;
  font-size:clamp(1rem,3.4vw,1.9rem);font-weight:500;margin:6px 0 6px;color:#fff
}
.hero-sub{color:var(--muted);font-style:italic;font-size:1.05rem;margin:0 0 30px;max-width:48ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.scroll-hint{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;
  color:var(--faint);font-family:"Oswald",sans-serif;letter-spacing:.3em;font-size:.62rem;
  text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-hint .line{width:1px;height:38px;background:linear-gradient(var(--gold),transparent);
  animation:pulse 2.2s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.14em;
  font-size:.82rem;font-weight:500;padding:14px 26px;border-radius:4px;
  border:1px solid var(--line-strong);background:transparent;color:var(--ink);
  transition:transform .2s,background .25s,border-color .25s,color .25s
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  background:linear-gradient(160deg,var(--gold-bright),var(--gold));color:#15130c;
  border-color:transparent;box-shadow:0 14px 34px -12px rgba(201,162,74,.7)
}
.btn-primary:hover{box-shadow:0 18px 40px -10px rgba(201,162,74,.85)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-bright)}

/* ---------- STORY ---------- */
#story{background:
  linear-gradient(var(--bg),var(--bg-2))}
.story-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(36px,6vw,80px);align-items:start}
.logline{
  font-family:"EB Garamond",serif;font-size:clamp(1.25rem,3vw,1.7rem);
  line-height:1.5;color:var(--ink)
}
.logline .drop{
  float:left;font-family:"Cinzel",serif;font-weight:700;font-size:4.4rem;line-height:.8;
  padding:6px 14px 0 0;color:var(--gold)
}
.atmos{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:26px 28px;box-shadow:var(--shadow)}
.atmos h3{font-size:1rem;letter-spacing:.18em;color:var(--gold);margin-bottom:6px}
.atmos .place{color:var(--muted);font-style:italic;margin:0 0 18px;font-size:.95rem}
.atmos ul{list-style:none;margin:0;padding:0}
.atmos li{padding:11px 0 11px 26px;position:relative;border-top:1px solid var(--line);font-size:1rem}
.atmos li:first-child{border-top:0}
.atmos li::before{content:"";position:absolute;left:2px;top:18px;width:8px;height:8px;
  background:var(--ember);border-radius:50%;box-shadow:0 0 12px var(--ember)}
.atmos li b{color:var(--ink)}

/* ---------- RULES dossier ---------- */
#rules{background:var(--bg-2)}
.dossier{
  position:relative;background:
    linear-gradient(135deg,var(--panel-2),var(--panel));
  border:1px solid var(--line-strong);border-radius:8px;padding:clamp(28px,5vw,52px);
  box-shadow:var(--shadow);overflow:hidden
}
.dossier::after{content:"CONFIDENTIAL";position:absolute;right:-46px;top:30px;
  transform:rotate(28deg);font-family:"Oswald",sans-serif;letter-spacing:.3em;
  border:3px solid rgba(142,32,32,.5);color:rgba(142,32,32,.55);
  padding:8px 60px;font-size:1.1rem;font-weight:600;pointer-events:none}
.rules-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:14px;margin-bottom:6px}
.rules-head .lat{font-family:"Cinzel",serif;color:var(--gold);font-size:1.05rem;letter-spacing:.06em}
.rules-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:34px}
.rule{display:flex;gap:16px}
.rule .n{font-family:"Oswald",sans-serif;font-weight:700;font-size:2rem;color:var(--gold);
  line-height:1;min-width:42px}
.rule h4{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.1em;
  font-size:.95rem;margin:0 0 4px;color:var(--ink)}
.rule p{margin:0;color:var(--muted);font-size:.98rem}
.stakes{margin-top:30px;display:inline-flex;align-items:center;gap:14px;
  border:2px solid rgba(142,32,32,.6);color:#e7a3a3;background:rgba(142,32,32,.12);
  font-family:"Oswald",sans-serif;letter-spacing:.16em;text-transform:uppercase;
  padding:10px 22px;border-radius:4px;font-size:.92rem}
.stakes b{color:#ff6b6b}

/* ---------- ARBITERS ---------- */
#arbiters{background:linear-gradient(var(--bg-2),var(--bg))}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.fig-card{
  position:relative;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;overflow:hidden;box-shadow:var(--shadow);
  transition:transform .3s,border-color .3s
}
.fig-card:hover{transform:translateY(-6px);border-color:var(--line-strong)}
.fig-photo{position:relative;aspect-ratio:4/5;overflow:hidden;background:#000}
.fig-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;
  transition:transform .6s ease;filter:saturate(.92) contrast(1.02)}
.fig-card:hover .fig-photo img{transform:scale(1.05)}
.fig-photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,var(--panel) 2%,transparent 45%)}
.fig-body{padding:4px 24px 26px;position:relative}
.fig-name{font-size:1.7rem;margin:0 0 2px;color:#fff}
.fig-role{font-family:"Special Elite",monospace;font-size:.82rem;color:var(--gold);
  letter-spacing:.02em;margin-bottom:14px}
.attr{display:flex;gap:8px;padding:7px 0;border-top:1px solid var(--line);font-size:.92rem}
.attr .k{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.1em;
  font-size:.68rem;color:var(--faint);min-width:78px;padding-top:3px}
.attr .v{color:var(--ink)}
.tag-demon{color:var(--ember)!important}
.tag-angel{color:var(--cold)!important}
.dynamic-note{margin-top:34px;text-align:center;font-style:italic;color:var(--muted);
  font-size:1.05rem}
.dynamic-note b{color:var(--gold);font-style:normal}

/* Lucifer feature band */
.lucifer{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,60px);
  align-items:center;margin-top:64px;background:
  radial-gradient(120% 120% at 0% 0%,rgba(142,32,32,.16),transparent 60%),var(--panel);
  border:1px solid var(--line);border-radius:12px;overflow:hidden;padding:0}
.lucifer .l-img{aspect-ratio:3/4;overflow:hidden;background:#000}
.lucifer .l-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.1) contrast(1.05)}
.lucifer .l-body{padding:clamp(26px,4vw,46px) clamp(20px,4vw,46px) clamp(26px,4vw,46px) 0}
.lucifer h3{font-size:clamp(1.8rem,4vw,2.8rem);color:#fff}
.lucifer .loop{margin-top:18px;padding:16px 20px;border-left:3px solid var(--blood);
  background:rgba(142,32,32,.1);font-style:italic;color:var(--parchment)}
.l-attrs{margin-top:18px}
.l-attrs p{margin:10px 0;color:var(--muted)}
.l-attrs b{color:var(--ink);font-family:"Oswald",sans-serif;text-transform:uppercase;
  letter-spacing:.08em;font-size:.82rem;font-weight:500;display:block;color:var(--gold)}

/* ---------- THE FIVE (case files) ---------- */
#five{background:var(--bg)}
.files{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px;margin-top:50px}
.file{
  background:linear-gradient(180deg,#1b1d24,#13151a);border:1px solid var(--line);
  border-radius:8px;overflow:hidden;box-shadow:var(--shadow);
  transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column
}
.file:hover{transform:translateY(-6px) rotate(-.4deg);box-shadow:0 30px 60px -20px rgba(0,0,0,.9)}
.file-top{position:relative;aspect-ratio:1/1;overflow:hidden;background:#0c0d10}
.file-top img{width:100%;height:100%;object-fit:cover;object-position:center 22%;
  filter:grayscale(.25) contrast(1.05)}
.file-top::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,#13151a,transparent 55%)}
.file-no{position:absolute;left:12px;top:10px;z-index:2;font-family:"Oswald",sans-serif;
  font-weight:700;font-size:.7rem;letter-spacing:.18em;color:var(--gold);
  background:rgba(0,0,0,.55);border:1px solid var(--line-strong);padding:3px 9px;border-radius:3px}
.file-body{padding:6px 18px 22px;flex:1;display:flex;flex-direction:column}
.file-arche{font-family:"Special Elite",monospace;font-size:.72rem;color:var(--gold);
  letter-spacing:.02em;margin-bottom:2px}
.file-name{font-size:1.45rem;color:#fff;margin:0 0 12px;line-height:1}
.sin-chip{align-self:flex-start;font-family:"Oswald",sans-serif;text-transform:uppercase;
  letter-spacing:.1em;font-size:.62rem;padding:4px 10px;border-radius:20px;margin-bottom:12px;
  border:1px solid rgba(142,32,32,.5);color:#e79a9a;background:rgba(142,32,32,.12)}
.file-sin{font-size:.92rem;color:var(--muted);margin:0}
.file-sin b{color:var(--ink);font-family:"Oswald",sans-serif;letter-spacing:.06em;
  text-transform:uppercase;font-size:.66rem;font-weight:500;color:var(--gold);display:block;margin-bottom:3px}
.connection{margin-top:30px;text-align:center;color:var(--muted);font-style:italic}
.connection b{color:var(--gold);font-style:normal}

/* ---------- JUDGMENTS timeline ---------- */
#reckoning{background:linear-gradient(var(--bg),var(--bg-2))}
.spoiler-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:24px 0 8px;
  padding:16px 22px;border:1px solid var(--line-strong);border-radius:8px;
  background:rgba(142,32,32,.08)}
.spoiler-bar .warn{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.16em;
  font-size:.78rem;color:#e79a9a;flex:1;min-width:200px}
.timeline{position:relative;margin-top:46px;padding-left:0}
.timeline.locked .tl-item{filter:blur(9px);opacity:.5;pointer-events:none;user-select:none}
.tl-line{position:absolute;left:calc(50% - 1px);top:0;bottom:0;width:2px;
  background:linear-gradient(var(--gold),transparent);opacity:.4}
.tl-item{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:40px;
  align-items:center;margin-bottom:54px}
.tl-item .tl-media{border-radius:10px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);aspect-ratio:16/10;background:#0c0d10}
.tl-item .tl-media img{width:100%;height:100%;object-fit:cover}
.tl-item .tl-text .step{font-family:"Oswald",sans-serif;color:var(--gold);letter-spacing:.2em;
  text-transform:uppercase;font-size:.72rem;margin-bottom:6px}
.tl-item .tl-text h3{font-size:clamp(1.4rem,3vw,2rem);color:#fff;margin-bottom:10px}
.tl-item .tl-text p{color:var(--muted);margin:0}
.tl-item .tl-text p b{color:var(--ink)}
.tl-dot{position:absolute;left:calc(50% - 9px);top:calc(50% - 9px);width:18px;height:18px;
  border-radius:50%;background:var(--bg);border:2px solid var(--gold);z-index:2;
  box-shadow:0 0 0 6px var(--bg-2),0 0 18px rgba(201,162,74,.6)}
.tl-item:nth-child(even) .tl-media{order:2}
.tl-item.no-media{grid-template-columns:1fr;max-width:560px;margin-left:auto;margin-right:auto;text-align:center}
.tl-item.no-media .tl-text{padding:26px 30px;border:1px dashed var(--line-strong);border-radius:10px;
  background:var(--panel)}

/* ---------- GALLERY ---------- */
#gallery{background:var(--bg-2)}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:14px;margin-top:46px}
.gal-cell{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;
  border:1px solid var(--line);aspect-ratio:16/9;background:#0c0d10}
.gal-cell img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .4s;
  filter:saturate(.9) brightness(.82)}
.gal-cell:hover img{transform:scale(1.07);filter:saturate(1) brightness(1)}
.gal-cell::after{content:"";position:absolute;inset:0;border:1px solid transparent;border-radius:8px;
  transition:border-color .3s}
.gal-cell:hover::after{border-color:var(--gold)}

/* video modal (teaser) */
.vmodal{position:fixed;inset:0;z-index:5500;background:rgba(5,5,7,.96);
  display:none;align-items:center;justify-content:center;padding:4vw}
.vmodal.open{display:flex}
.vm-frame{position:relative;width:min(1100px,92vw);aspect-ratio:16/9;background:#0c0d10;
  border:1px solid var(--line-strong);border-radius:8px;overflow:hidden;
  box-shadow:0 40px 90px rgba(0,0,0,.9);display:grid;place-items:center}
.vm-frame iframe,.vm-frame video{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.vm-soon{display:grid;place-items:center;text-align:center;gap:14px;padding:30px;
  background:radial-gradient(120% 120% at 50% 35%,rgba(201,162,74,.08),transparent 60%)}
.vm-soon .m{font-family:"Oswald",sans-serif;font-weight:700;font-size:3rem;color:var(--gold);line-height:1}
.vm-soon h3{font-size:1.5rem;color:#fff}
.vm-soon p{color:var(--muted);font-style:italic;max-width:38ch;margin:0}
.vm-close{position:absolute;top:16px;right:24px;background:none;border:0;color:var(--ink);
  font-size:2.6rem;cursor:pointer;line-height:1;z-index:2;transition:color .2s}
.vm-close:hover{color:var(--gold)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:5000;background:rgba(5,5,7,.95);
  display:none;align-items:center;justify-content:center;padding:34px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:6px;box-shadow:0 40px 90px rgba(0,0,0,.9)}
.lb-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(20,20,24,.7);
  border:1px solid var(--line-strong);color:var(--ink);width:54px;height:54px;border-radius:50%;
  cursor:pointer;font-size:1.6rem;display:grid;place-items:center;transition:background .2s}
.lb-btn:hover{background:var(--gold);color:#000}
.lb-prev{left:22px}.lb-next{right:22px}
.lb-close{position:absolute;top:22px;right:24px;background:none;border:0;color:var(--ink);
  font-size:2rem;cursor:pointer;line-height:1}
.lb-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);
  font-family:"Oswald",sans-serif;letter-spacing:.2em;color:var(--muted);font-size:.8rem}

/* ---------- TEASER ---------- */
#teaser{position:relative;padding:0}
.teaser-band{position:relative;min-height:64vh;display:grid;place-items:center;text-align:center;
  overflow:hidden}
.teaser-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(.4) saturate(.8);z-index:0}
.teaser-band::after{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 50% 50%,transparent,rgba(0,0,0,.7))}
.teaser-inner{position:relative;z-index:2;padding:40px 20px}
.play{width:84px;height:84px;border-radius:50%;border:2px solid var(--gold);
  display:grid;place-items:center;margin:0 auto 24px;cursor:pointer;
  background:rgba(0,0,0,.3);transition:transform .25s,background .25s}
.play:hover{transform:scale(1.08);background:rgba(201,162,74,.2)}
.play svg{width:30px;height:30px;margin-left:5px;fill:var(--gold)}
.teaser-inner h2{font-size:clamp(1.6rem,5vw,3rem);color:#fff}
.teaser-inner p{color:var(--parchment);font-style:italic;letter-spacing:.04em}

/* ---------- PRODUCTION ---------- */
#production{background:var(--bg)}
.prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,70px);align-items:center}
.prod-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-bottom:30px}
.fact{background:var(--panel);padding:20px 22px}
.fact .k{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.14em;
  font-size:.66rem;color:var(--faint);margin-bottom:5px}
.fact .v{font-size:1.05rem;color:var(--ink)}
.contact-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:clamp(28px,4vw,42px);box-shadow:var(--shadow)}
.contact-card h3{font-size:1.6rem;margin-bottom:6px;color:#fff}
.contact-card .by{font-style:italic;color:var(--muted);margin:0 0 22px}
.contact-list{list-style:none;margin:0 0 26px;padding:0}
.contact-list li{display:flex;gap:12px;align-items:center;padding:10px 0;border-top:1px solid var(--line)}
.contact-list li:first-child{border-top:0}
.contact-list .ico{color:var(--gold);width:20px;flex:none}
.contact-list a:hover{color:var(--gold-bright)}

/* ---------- FOOTER ---------- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding:48px 0 40px;text-align:center}
.footer .fmark{font-family:"Oswald",sans-serif;font-weight:700;font-size:2.4rem;color:var(--gold);
  line-height:1;margin-bottom:10px}
.footer p{color:var(--faint);font-size:.82rem;margin:5px 0}
.footer .conf{font-family:"Special Elite",monospace;letter-spacing:.2em;font-size:.7rem;
  color:rgba(142,32,32,.7);margin-top:14px}

/* reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;
    justify-content:center;gap:26px;background:rgba(8,8,10,.97);backdrop-filter:blur(14px);
    transform:translateX(100%);transition:transform .35s ease;border-left:1px solid var(--line);z-index:1001}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.1rem}
  .nav-toggle{display:block;z-index:1002}
  .story-grid{grid-template-columns:1fr}
  .cards-3{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
  .lucifer{grid-template-columns:1fr}
  .lucifer .l-body{padding:0 24px 32px}
  .rules-grid{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:1fr}
  .tl-item,.tl-item:nth-child(even) .tl-media{grid-template-columns:1fr;order:0}
  .tl-item{gap:16px}
  .tl-line,.tl-dot{display:none}
  .tl-item .tl-media{margin-bottom:4px}
}
@media(max-width:520px){
  body{font-size:17px}
  .prod-facts{grid-template-columns:1fr}
  .dossier::after{font-size:.85rem;right:-50px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
