/* ===========================================================
   VENTURE : CLASSIC SAGA — landing page
   Dark gothic, gold-on-black, inspired by Sorcery TCG
   =========================================================== */

:root{
  --black:#0a0806;
  --bg:#0c0a07;
  --bg-2:#100d0a;
  --panel:#15110c;

  --gold:#c8a45c;
  --gold-bright:#ecd6a3;
  --gold-deep:#8a6a32;
  --gold-50:#c8a45c80;
  --gold-line:rgba(200,164,92,.22);
  --gold-line-soft:rgba(200,164,92,.12);

  --cream:#ece2cd;
  --cream-dim:#beb39c;
  --cream-faint:#8d8675;

  --dragon:#8a3330;
  --elem:#1f6450;
  --spell:#155a55;

  --shadow-deep:0 40px 90px -30px rgba(0,0,0,.9);

  --serif:"EB Garamond", Georgia, serif;
  --display:"Cinzel", "EB Garamond", Georgia, serif;

  --hero-dark:.62;          /* tweakable hero scrim */
  --maxw:1240px;
  --gut:clamp(20px,5vw,64px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--cream);
  font-family:var(--serif);
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---- fixed atmospheric background ---- */
.bg-atmos{position:fixed;inset:0;z-index:-2;background:
  radial-gradient(120% 80% at 50% -10%, rgba(200,164,92,.10), transparent 55%),
  radial-gradient(90% 70% at 50% 120%, rgba(120,80,30,.07), transparent 60%),
  var(--bg);
}
.bg-grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}

/* ===================== shared type ===================== */
.overline{
  font-family:var(--display);
  font-weight:600;
  font-size:.72rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 1.1rem;
  padding-left:.42em;
}
.display{
  font-family:var(--display);
  font-weight:700;
  line-height:1.04;
  letter-spacing:.01em;
  color:var(--cream);
  margin:0;
  text-wrap:balance;
}
.lede{color:var(--cream-dim);font-size:1.12rem;line-height:1.75;text-wrap:pretty}

/* flanked section title (Sorcery "LATEST NEWS" style) */
.rule-title{
  display:flex;align-items:center;gap:clamp(16px,3vw,40px);
  justify-content:center;margin:0 auto 3.2rem;max-width:760px;
}
.rule-title::before,.rule-title::after{
  content:"";flex:1;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-line),transparent);
}
.rule-title h2{
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.5rem,3.4vw,2.4rem);letter-spacing:.12em;
  text-transform:uppercase;margin:0;white-space:nowrap;color:var(--cream);
}

/* ===================== buttons ===================== */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--display);font-weight:600;
  font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.95em 1.9em;border-radius:2px;
  border:1px solid var(--gold-line);
  transition:.35s cubic-bezier(.2,.7,.3,1);
  position:relative;white-space:nowrap;
}
.btn--gold{
  background:linear-gradient(180deg,var(--gold-bright),var(--gold) 55%,var(--gold-deep));
  color:#241a0c;border-color:transparent;
  box-shadow:0 10px 30px -12px rgba(200,164,92,.55);
}
.btn--gold:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn--ghost{color:var(--gold);background:rgba(20,16,10,.35);backdrop-filter:blur(4px)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-bright);background:rgba(40,30,16,.45);transform:translateY(-2px)}

/* --- alternate "sobre" button direction (dark fill + gold rule) --- */
body[data-btn="sobre"] .btn--gold{
  background:linear-gradient(180deg,#241b10,#14100a);
  color:var(--gold-bright);
  border:1px solid var(--gold);
  box-shadow:0 10px 26px -16px rgba(0,0,0,.85);
}
body[data-btn="sobre"] .btn--gold:hover{
  filter:none;border-color:var(--gold-bright);color:#fff6e2;
  background:linear-gradient(180deg,#2d2214,#1a130b);transform:translateY(-2px);
}

/* ===================== header (announcement + nav stacked) ===================== */
.siteheader{position:fixed;top:0;left:0;right:0;z-index:60}
.topbar{
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:1em;
  padding:.55em 3em;
  background:linear-gradient(180deg,#171109,#0d0a06);
  border-bottom:1px solid var(--gold-line-soft);
  font-family:var(--display);font-size:.66rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold-bright);text-align:center;white-space:nowrap;
}
.topbar b{color:var(--cream)}
.topbar__close{
  position:absolute;right:1.1em;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--cream-faint);font-size:1rem;
  line-height:1;padding:.2em .4em;transition:.2s;
}
.topbar__close:hover{color:var(--gold)}
body.topbar-hidden .topbar{display:none}

/* ===================== header / nav ===================== */
.nav{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;padding:1.15rem var(--gut);
  transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,6,4,.86);backdrop-filter:blur(12px) saturate(1.2);
  border-bottom-color:var(--gold-line-soft);padding-top:.8rem;padding-bottom:.8rem;
}
.brand{display:flex;flex-direction:column;gap:.28em;flex:0 0 auto}
.brand__mark{
  width:176px;height:auto;aspect-ratio:2675/472;display:block;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,.4));
}
.brand__sub{
  font-family:var(--display);font-size:.56rem;letter-spacing:.55em;
  text-transform:uppercase;color:var(--gold);padding-left:.4em;
}
.nav__links{display:flex;align-items:center;gap:clamp(1.1rem,2.4vw,2.4rem);list-style:none;margin:0;padding:0}
.nav__links a{
  font-family:var(--display);font-weight:500;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--cream);
  position:relative;padding:.4em 0;transition:color .25s;white-space:nowrap;
}
.nav__links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;
  background:var(--gold);transition:right .3s ease;
}
.nav__links a:hover{color:var(--gold-bright)}
.nav__links a:hover::after{right:0}
.nav__right{display:flex;align-items:center;gap:1.2rem;flex:0 0 auto}

/* lang toggle */
.lang{display:inline-flex;align-items:center;border:1px solid var(--gold-line);border-radius:2px;overflow:hidden}
.lang button{
  background:none;border:none;color:var(--cream-faint);
  font-family:var(--display);font-weight:600;font-size:.68rem;letter-spacing:.14em;
  padding:.42em .7em;transition:.25s;
}
.lang button.active{background:var(--gold);color:#221809}
.lang button:not(.active):hover{color:var(--gold)}

.nav__cta{display:inline-flex}

.burger{display:none;background:none;border:none;color:var(--gold);flex-direction:column;gap:5px;padding:6px}
.burger span{width:24px;height:2px;background:currentColor;display:block}

/* ===================== hero ===================== */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  align-items:center;justify-content:flex-end;overflow:hidden;isolation:isolate;border-bottom: .15rem solid var(--gold-50);}
.hero__art{position:absolute;inset:0;z-index:-3;background-size:cover;background-position:center 32%;
  transform:scale(1.06);transition:opacity .6s}
body[data-hero="sea"]    .hero__art{background-image:url("assets/banner-sea.jpg")}
body[data-hero="jungle"] .hero__art{background-image:url("assets/jungle.png")}
body[data-hero="marble"] .hero__art{
  background:
   radial-gradient(60% 50% at 50% 34%, rgba(200,164,92,.16), transparent 60%),
   conic-gradient(from 200deg at 30% 40%, #14100b, #1d160d, #0c0907, #1a130c, #0e0a07),
   #0a0806;
  filter:contrast(1.05);transform:none}
body[data-hero="cards"]  .hero__art{
  background:
   radial-gradient(50% 46% at 50% 58%, rgba(200,164,92,.20), transparent 62%),
   radial-gradient(120% 80% at 50% 120%, rgba(120,80,30,.10), transparent 60%),
   #08060400;transform:none}
.hero__veil{position:absolute;inset:0;z-index:-2;background:
  linear-gradient(180deg, rgba(8,6,4,.78) 0%, rgba(8,6,4,calc(var(--hero-dark) - .25)) 30%, rgba(10,8,6,calc(var(--hero-dark) - .1)) 58%, var(--bg) 99%),
  radial-gradient(80% 60% at 50% 42%, rgba(8,6,4,calc(var(--hero-dark) - .35)), rgba(8,6,4,var(--hero-dark)));
}

.hero__inner{position:relative;z-index:2;text-align:center;max-width:980px;
  padding:0 var(--gut);margin-top:clamp(96px,16vh,180px)}
.hero .overline{padding-left:0;opacity:0;animation:rise .9s .15s both}
.hero__title{font-size:clamp(2.6rem,7vw,5.6rem);
  text-shadow:0 4px 40px rgba(0,0,0,.7);opacity:0;animation:rise 1s .28s both}
.hero__sub{margin:1.6rem auto 0;max-width:620px;font-size:clamp(1.05rem,1.7vw,1.3rem);
  color:var(--cream-dim);opacity:0;animation:rise 1s .46s both}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  margin-top:2.4rem;opacity:0;animation:rise 1s .62s both}

@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* card fan */
.fan{position:relative;z-index:2;display:flex;justify-content:center;align-items:flex-end;
  margin-top:clamp(30px,5vh,60px);height:clamp(290px,42vh,440px);width:100%;
  perspective:1500px;pointer-events:none}
.fan__card{position:absolute;bottom:-70px;width:clamp(196px,19vw,300px);
  border-radius:13px;box-shadow:var(--shadow-deep);pointer-events:auto;
  transform-style:preserve-3d;will-change:transform;
  transform:translate(var(--tx),var(--ty)) rotate(var(--rot));
  transition:transform .45s cubic-bezier(.2,.7,.3,1), box-shadow .4s;
  opacity:0;}
.fan__card img{width:100%;border-radius:13px;display:block}
.fan__card:hover{transform:translate(var(--tx),var(--ty)) rotate(var(--rot)) scale(1.1);
  box-shadow:0 50px 110px -30px rgba(0,0,0,.95),0 0 44px -8px rgba(200,164,92,.4)}
/* resting fan positions + in-hand stacking (each card behind its right neighbour) */
.fan__card.c0{--rot:-18deg;--tx:-372px;--ty:48px;z-index:1}
.fan__card.c1{--rot:-8.5deg;--tx:-186px;--ty:10px;z-index:2}
.fan__card.c2{--rot:0deg;--tx:0;--ty:-16px;z-index:3}
.fan__card.c3{--rot:8.5deg;--tx:186px;--ty:10px;z-index:4}
.fan__card.c4{--rot:18deg;--tx:372px;--ty:48px;z-index:5}
body.fan-in .fan__card{opacity:1;animation:fan-deal .9s cubic-bezier(.2,.7,.3,1) backwards}
.fan__card.c0{animation-delay:.05s!important}
.fan__card.c4{animation-delay:.12s!important}
.fan__card.c1{animation-delay:.19s!important}
.fan__card.c3{animation-delay:.26s!important}
.fan__card.c2{animation-delay:.34s!important}
@keyframes fan-deal{
  from{opacity:0;transform:translate(0,120px) rotate(0deg) scale(.86)}
  to{opacity:1;transform:translate(var(--tx),var(--ty)) rotate(var(--rot))}
}
@media(max-width:760px){
  .fan__card.c0,.fan__card.c4{display:none}
  .fan__card.c1{--tx:-150px}.fan__card.c3{--tx:150px}
}

/* ===================== generic section ===================== */
.section{position:relative;padding:clamp(80px,12vh,150px) var(--gut)}
.wrap{max-width:var(--maxw);margin:0 auto}

/* ---- full-bleed lore band ---- */
.band{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden}
.band__art{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:right -186px bottom;}
.lore .band__art{background-image:url("assets/banner-sea.jpg")}
.band__veil{position:absolute;inset:0;z-index:-1}
.lore .band__veil{background:linear-gradient(90deg,rgba(8,6,4,.94) 0%,rgba(8,6,4,.8) 38%,rgba(8,6,4,.45) 70%,rgba(8,6,4,.7) 100%)}
.band__content{max-width:560px;padding:clamp(60px,9vh,110px) var(--gut)}
.band__content .display{font-size:clamp(2rem,4.6vw,3.4rem)}
.band__content .lede{margin:1.6rem 0 0}

/* ===================== featured cards ===================== */
.cards-feature{text-align:center}
.cards-feature .subhead{color:var(--cream-dim);font-style:italic;font-size:1.15rem;
  max-width:560px;margin:-2rem auto 3.6rem}
.cards-cta{text-align:center;margin-top:clamp(40px,6vh,72px)}
.gallery{display:flex;justify-content:center;align-items:flex-start;gap:clamp(20px,4vw,56px);
  flex-wrap:wrap;perspective:1500px}
.tcard{width:clamp(230px,26vw,310px);text-align:center;transform-style:preserve-3d;will-change:transform}
.tcard__frame{position:relative;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-deep);transition:box-shadow .4s;transform-style:preserve-3d}
.tcard__frame img{width:100%;display:block;backface-visibility:hidden}
.tcard__frame::after{content:"";position:absolute;inset:0;border-radius:14px;
  box-shadow:inset 0 0 0 1px rgba(200,164,92,.18);pointer-events:none}
.tcard:hover .tcard__frame{box-shadow:0 46px 100px -42px rgba(0,0,0,.95),0 0 36px -18px var(--glow,rgba(200,164,92,.4))}
.tcard__type{display:inline-flex;align-items:center;gap:.75em;margin:2rem 0 .55rem;
  font-family:var(--display);font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold);padding:0;border:none;background:none}
.tcard__type::before,.tcard__type::after{content:"";width:20px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-line) 60%,transparent)}
.tcard[data-type="dragon"] .tcard__type{color:#d39184}
.tcard[data-type="elem"] .tcard__type{color:#82c6ac}
.tcard[data-type="saga"] .tcard__type{color:var(--gold-bright)}
.tcard__name{font-family:var(--display);font-weight:600;font-size:1.05rem;
  letter-spacing:.02em;color:var(--cream);margin:.2rem 0 .5rem;min-height:2.5em;
  display:flex;align-items:center;justify-content:center}
.tcard__flavor{color:var(--cream-faint);font-style:italic;font-size:.92rem;line-height:1.55}

/* ===================== split bands (play / community) ===================== */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(36px,6vw,90px);
  max-width:var(--maxw);margin:0 auto}
.split--rev .split__text{order:2}
.split__text .display{font-size:clamp(1.9rem,4vw,3rem)}
.split__text .lede{margin:1.4rem 0 2.2rem}
.split__cta{display:flex;gap:1rem;flex-wrap:wrap}
.split__media{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;
  box-shadow:var(--shadow-deep);border:1px solid var(--gold-line)}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__media::after{content:"";position:absolute;inset:0;
  box-shadow:inset 0 0 90px 20px rgba(8,6,4,.6);pointer-events:none}
.play .split__media img{object-position:center}
.divider{height:1px;max-width:var(--maxw);margin:0 auto;
  background:linear-gradient(90deg,transparent,var(--gold-line),transparent)}

/* ===================== creators ===================== */
.creators{text-align:center}
.creators .subhead{color:var(--cream-dim);font-style:italic;font-size:1.15rem;
  max-width:560px;margin:-2rem auto 4rem}
.creators__list{max-width:var(--maxw);margin:0 auto;display:flex;flex-direction:column;
  gap:clamp(56px,9vh,104px)}
.creator{display:flex;flex-direction:row;align-items:center;
  gap:clamp(36px,6vw,80px);text-align:left}
.creator--rev .creator__media{order:2}
.creator__media{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:5/6;
  box-shadow:var(--shadow-deep);border:1px solid var(--gold-line);width: 25rem;}
.creator__media img{width:100%;height:100%;object-fit:cover;object-position:center top}
.creator__media::after{content:"";position:absolute;inset:0;border-radius:14px;
  box-shadow:inset 0 0 80px 14px rgba(8,6,4,.55),inset 0 0 0 1px rgba(200,164,92,.18);
  pointer-events:none}
.creator__text {width: fit-content;}
.creator__text .overline{padding-left:0;margin-bottom:.9rem}
.creator__name{font-family:var(--display);font-weight:700;
  font-size:clamp(1.6rem,3vw,2.3rem);letter-spacing:.01em;color:var(--cream);
  margin:0 0 1rem}
.creator__role{color:var(--gold-bright);font-style:italic;font-size:1.06rem;
  line-height:1.6;margin:0 0 1.1rem;text-wrap:pretty}
.creator__bio{color:var(--cream-dim);font-size:1.04rem;line-height:1.75;margin:0;
  text-wrap:pretty}

/* ===================== footer ===================== */
.footer{position:relative;padding:clamp(70px,9vh,110px) var(--gut) 2.5rem;
  background:linear-gradient(180deg,transparent,#08060400 0,#070504 30%);
  border-top:1px solid var(--gold-line-soft)}
.footer__grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:1.7fr 1fr 1fr;gap:clamp(30px,6vw,90px)}
.footer__brand .brand__mark{width:210px}
.footer__brand p{color:var(--cream-faint);font-size:.9rem;margin:1.6rem 0 0;max-width:300px}
.fcol h4{font-family:var(--display);font-size:.74rem;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);margin:0 0 1.2rem}
.fcol ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}
.fcol a{color:var(--cream-dim);font-size:.96rem;transition:color .2s}
.fcol a:hover{color:var(--gold-bright)}
.news label{display:block;font-family:var(--display);font-size:.74rem;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.news__row{display:flex;gap:.5rem}
.news input{flex:1;min-width:0;background:rgba(20,16,10,.6);border:1px solid var(--gold-line);
  border-radius:2px;color:var(--cream);padding:.7em .9em;font-family:var(--serif);font-size:.92rem}
.news input::placeholder{color:var(--cream-faint)}
.news input:focus{outline:none;border-color:var(--gold)}
.news__btn{background:var(--gold);border:none;color:#221809;font-family:var(--display);
  font-weight:600;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  padding:0 1.1em;border-radius:2px;transition:.25s}
.news__btn:hover{background:var(--gold-bright)}
.socials{display:flex;gap:.7rem;margin-top:1.6rem}
.socials a{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--gold-line);color:var(--cream-dim);transition:.25s}
.socials a:hover{border-color:var(--gold);color:var(--gold-bright);transform:translateY(-2px)}
.socials svg{width:17px;height:17px;fill:currentColor}
.footer__base{max-width:var(--maxw);margin:3.4rem auto 0;padding-top:1.8rem;
  border-top:1px solid var(--gold-line-soft);display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;color:var(--cream-faint);font-size:.82rem;letter-spacing:.04em}
.footer__base a{color:var(--cream-faint)}.footer__base a:hover{color:var(--gold)}

/* ===================== tweaks panel ===================== */
.tweaks{position:fixed;right:18px;bottom:18px;z-index:200;width:300px;
  background:rgba(14,11,7,.96);border:1px solid var(--gold-line);border-radius:8px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.9);backdrop-filter:blur(14px);
  font-family:var(--serif);transform:translateY(20px);opacity:0;pointer-events:none;
  transition:.3s;overflow:hidden}
.tweaks.open{transform:none;opacity:1;pointer-events:auto}
.tweaks__head{display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1.1rem;border-bottom:1px solid var(--gold-line-soft);
  background:linear-gradient(180deg,#1a140c,#120e08)}
.tweaks__head h3{font-family:var(--display);font-size:.8rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold-bright);margin:0}
.tweaks__close{background:none;border:none;color:var(--cream-faint);font-size:1.1rem;line-height:1}
.tweaks__close:hover{color:var(--gold)}
.tweaks__body{padding:1.1rem;display:flex;flex-direction:column;gap:1.3rem;max-height:70vh;overflow:auto}
.tw-group>span{display:block;font-family:var(--display);font-size:.66rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--cream-dim);margin-bottom:.7rem}
.seg{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.seg button{background:rgba(30,24,15,.6);border:1px solid var(--gold-line-soft);color:var(--cream-dim);
  font-family:var(--display);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.6em .4em;border-radius:3px;transition:.2s}
.seg button.active{background:var(--gold);color:#221809;border-color:var(--gold)}
.seg button:not(.active):hover{border-color:var(--gold);color:var(--gold)}
.tw-range{display:flex;align-items:center;gap:.7rem}
.tw-range input[type=range]{flex:1;accent-color:var(--gold)}
.tw-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.tw-toggle .sw{width:42px;height:23px;border-radius:20px;background:rgba(60,48,30,.7);
  border:1px solid var(--gold-line);position:relative;transition:.25s}
.tw-toggle .sw::after{content:"";position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;
  background:var(--cream-dim);transition:.25s}
.tw-toggle input{display:none}
.tw-toggle input:checked + .sw{background:var(--gold)}
.tw-toggle input:checked + .sw::after{transform:translateX(19px);background:#221809}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s,transform .9s}
.reveal.in{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
}

/* ===================== responsive ===================== */
@media(max-width:1080px){
  .footer__grid{grid-template-columns:1fr 1fr;row-gap:48px}
  .footer__brand{grid-column:1/-1}
}
@media(max-width:880px){
  .nav__links,.nav__cta{display:none}
  .burger{display:flex}
  .split{grid-template-columns:1fr;gap:40px}
  .split--rev .split__text{order:0}
  .split--rev .split__media{order:-1}
  .band__veil{background:linear-gradient(180deg,rgba(8,6,4,.6),rgba(8,6,4,.92))!important}
  .band__content{max-width:none}
  .fan {margin-top: 0;}
  .creator{flex-direction:column;text-align:center;justify-items:center}
  .creator__media{order:-1;width:min(320px,80%)}
  .creator--rev .creator__media{order:-1}
  .creator__text .overline{padding-left:0}
}
@media(max-width:560px){
  body{font-size:17px}
  .footer__grid{grid-template-columns:1fr}
  .footer__base{flex-direction:column}
  .topbar{font-size:.6rem;letter-spacing:.16em;padding:.5em 2.4em;white-space:normal}
}

/* mobile nav drawer */
.drawer{position:fixed;inset:0;z-index:80;background:rgba(8,6,4,.97);backdrop-filter:blur(10px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;
  opacity:0;pointer-events:none;transition:.35s}
.drawer.open{opacity:1;pointer-events:auto}
.drawer a{font-family:var(--display);font-size:1.3rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream)}
.drawer a:hover{color:var(--gold-bright)}
.drawer__close{position:absolute;top:24px;right:28px;background:none;border:none;color:var(--gold);font-size:2rem}
