/* =========================================================================
   MUSICALITY CO-OP - Level Up Your Bachata
   Aesthetic: dark-fantasy / souls-like (honest hand-built CSS atmosphere,
   not an official design system). Theme is dark-locked by design intent.
   Accent locked: tarnished gold. Ember-orange = fire atmosphere only.
   Crimson = reserved semantic "danger / title-card" moment (finale).
   ========================================================================= */

:root{
  /* surfaces */
  --bg:        #0c0a08;
  --bg-2:      #110d0a;
  --panel:     #15110c;
  --panel-2:   #1a140d;

  /* ink */
  --ink:       #ddd2bb;
  --ink-dim:   #a1957d;
  --ink-faint: #71685600;          /* unused alpha guard */
  --ink-mute:  #6f6655;

  /* accent: tarnished gold (THE accent, used everywhere) */
  --gold:        #c8a55a;
  --gold-bright: #eccd84;
  --gold-deep:   #8a6f33;

  /* fire atmosphere (not a UI accent) */
  --ember:      #e8853a;
  --ember-deep: #b8531f;

  /* semantic danger / title card only */
  --crimson:        #7c1715;
  --crimson-bright: #c23227;

  /* lines */
  --line:      rgba(200,165,90,.20);
  --line-soft: rgba(221,210,187,.08);

  /* type */
  --f-display: 'Cinzel', 'Times New Roman', serif;
  --f-deco:    'Cinzel Decorative', 'Cinzel', serif;
  --f-body:    'EB Garamond', Georgia, serif;

  /* metrics */
  --wrap: 1200px;
  --nav-h: 72px;
  --ease: cubic-bezier(.16,1,.3,1);

  /* z-scale */
  --z-canvas: 0;
  --z-fog: 1;
  --z-vignette: 2;
  --z-content: 3;
  --z-nav: 50;
  --z-mobile: 60;
  --z-grain: 80;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--f-body);
  font-size:18px;
  line-height:1.7;
  color:var(--ink);
  background:var(--bg);
  background-image:
    radial-gradient(120% 80% at 50% -10%, #16100a 0%, transparent 55%),
    radial-gradient(90% 60% at 50% 120%, #1c1107 0%, transparent 60%);
  background-attachment:fixed;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

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

::selection{ background:rgba(200,165,90,.28); color:#fff7e6; }

/* focus visibility */
a:focus-visible, button:focus-visible, input:focus-visible, [tabindex]:focus-visible{
  outline:2px solid var(--gold-bright);
  outline-offset:3px;
}

/* ---------------------------------------------------------------- ATMOSPHERE */
#embers{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:var(--z-canvas); pointer-events:none;
}
.fog{
  position:fixed; inset:-20%; z-index:var(--z-fog); pointer-events:none;
  background:
    radial-gradient(40% 40% at 20% 30%, rgba(232,133,58,.07), transparent 70%),
    radial-gradient(45% 45% at 80% 70%, rgba(200,165,90,.06), transparent 70%),
    radial-gradient(50% 50% at 60% 15%, rgba(124,23,21,.05), transparent 70%);
  filter:blur(20px);
  animation:fogdrift 34s ease-in-out infinite alternate;
}
@keyframes fogdrift{
  0%{ transform:translate3d(-2%, -1%, 0) scale(1.05); }
  100%{ transform:translate3d(3%, 2%, 0) scale(1.12); }
}
.vignette{
  position:fixed; inset:0; z-index:var(--z-vignette); pointer-events:none;
  background:radial-gradient(120% 100% at 50% 35%, transparent 40%, rgba(0,0,0,.55) 100%);
}
.grain{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:var(--z-grain); pointer-events:none;
  opacity:.045; mix-blend-mode:overlay;
}

/* keep main content above atmosphere */
main, .nav, .foot{ position:relative; z-index:var(--z-content); }

/* ---------------------------------------------------------------- SKIP LINK */
.skip-link{
  position:fixed; top:-60px; left:16px; z-index:100;
  background:var(--gold); color:#1a1206; padding:.6rem 1rem;
  font-family:var(--f-display); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase;
  transition:top .2s var(--ease);
}
.skip-link:focus{ top:14px; }

/* ---------------------------------------------------------------- TYPE HELPERS */
.wrap{ max-width:var(--wrap); margin-inline:auto; padding-inline:clamp(1.25rem,5vw,3rem); }

section{ scroll-margin-top:calc(var(--nav-h) + 10px); }

.section-title{
  font-family:var(--f-display); font-weight:700;
  font-size:clamp(2rem,4.6vw,3.2rem); line-height:1.08; letter-spacing:.01em;
  color:#f0e6cf; margin:0 0 1rem;
  text-shadow:0 2px 30px rgba(0,0,0,.6);
}
.section-title--center{ text-align:center; }
.section-kicker{
  display:inline-block; font-family:var(--f-display); font-weight:600;
  font-size:.74rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--gold); margin:0 0 1rem;
}
.section-kicker::before{ content:""; display:inline-block; width:28px; height:1px;
  background:var(--gold-deep); vertical-align:middle; margin-right:.7em; }

.lead{
  font-size:clamp(1.05rem,1.5vw,1.22rem); color:var(--ink-dim);
  line-height:1.75; max-width:60ch; margin:0;
}
.lead--center{ margin-inline:auto; text-align:center; }

.eyebrow{
  font-family:var(--f-body); font-style:italic; font-size:1.05rem;
  color:var(--gold); letter-spacing:.02em; margin:0 0 1.4rem;
}

/* shared "engraved panel" look + diagonal corner brackets */
.attributes, .cpanel, .pass, .note, .signup, .perk, .boss-callout{
  position:relative;
  background:linear-gradient(160deg, var(--panel) 0%, var(--bg-2) 100%);
  border:1px solid var(--line);
  box-shadow:inset 0 1px 0 rgba(255,240,210,.05), 0 24px 50px -30px rgba(0,0,0,.9);
}
.attributes::before, .cpanel::before, .pass::before, .note::before, .signup::before, .perk::before,
.attributes::after, .cpanel::after, .pass::after, .note::after, .signup::after, .perk::after{
  content:""; position:absolute; width:14px; height:14px; pointer-events:none;
}
.attributes::before, .cpanel::before, .pass::before, .note::before, .signup::before, .perk::before{
  top:-1px; left:-1px; border-top:2px solid var(--gold); border-left:2px solid var(--gold);
}
.attributes::after, .cpanel::after, .pass::after, .note::after, .signup::after, .perk::after{
  bottom:-1px; right:-1px; border-bottom:2px solid var(--gold); border-right:2px solid var(--gold);
}

/* ---------------------------------------------------------------- BUTTONS */
.btn{
  --pad-y:.85rem; --pad-x:1.5rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--f-display); font-weight:600; font-size:.82rem;
  letter-spacing:.14em; text-transform:uppercase; white-space:nowrap;
  padding:var(--pad-y) var(--pad-x); cursor:pointer; border:1px solid transparent;
  border-radius:0; transition:transform .18s var(--ease), background .25s var(--ease),
    color .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.btn--lg{ --pad-y:1.05rem; --pad-x:2.1rem; font-size:.86rem; }

.btn--gold{
  background:linear-gradient(180deg, var(--gold-bright), var(--gold) 60%, #a9863f);
  color:#1a1206;
  border-color:var(--gold-bright);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4), 0 0 0 rgba(232,133,58,0);
}
.btn--gold:hover{
  transform:translateY(-2px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5), 0 10px 30px -8px rgba(232,133,58,.5);
}
.btn--gold:active{ transform:translateY(1px) scale(.99); }

.btn--ghost{
  background:rgba(200,165,90,.04); color:var(--gold-bright);
  border-color:var(--gold-deep);
}
.btn--ghost:hover{
  background:rgba(200,165,90,.12); border-color:var(--gold); color:#fbeccb;
  transform:translateY(-2px);
}
.btn--ghost:active{ transform:translateY(1px) scale(.99); }

/* ---------------------------------------------------------------- NAV */
.nav{
  position:fixed; top:0; left:0; right:0; height:var(--nav-h);
  z-index:var(--z-nav);
  display:flex; align-items:center; gap:1.5rem;
  padding-inline:clamp(1.25rem,5vw,3rem);
  background:linear-gradient(180deg, rgba(8,6,5,.85), rgba(8,6,5,0));
  transition:background .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(9,7,5,.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  box-shadow:0 10px 30px -20px #000;
}
.brand{ display:inline-flex; align-items:center; gap:.65rem; color:var(--ink); }
.brand__sigil{ width:30px; height:30px; color:var(--gold); display:inline-block; flex:none; }
.brand__sigil svg{ width:100%; height:100%; }
.brand__name{ font-family:var(--f-display); font-weight:700; font-size:1.02rem; letter-spacing:.16em; text-transform:uppercase; }
.brand__co{ color:var(--gold); }

.nav__links{ display:flex; gap:1.6rem; margin-left:auto; }
.nav__links a{
  font-family:var(--f-display); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-dim); position:relative; padding:.3rem 0; transition:color .25s var(--ease);
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--gold);
  transition:width .3s var(--ease);
}
.nav__links a:hover{ color:var(--gold-bright); }
.nav__links a:hover::after{ width:100%; }

.nav__cta{ margin-left:.4rem; }
.nav__burger{
  display:none; margin-left:auto; width:42px; height:42px; background:transparent;
  border:1px solid var(--gold-deep); cursor:pointer; flex-direction:column; gap:5px;
  align-items:center; justify-content:center;
}
.nav__burger span{ width:20px; height:2px; background:var(--gold); transition:transform .25s var(--ease), opacity .2s; }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{
  position:fixed; top:var(--nav-h); left:0; right:0; z-index:var(--z-mobile);
  background:rgba(9,7,5,.97); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  display:flex; flex-direction:column; gap:.4rem; padding:1.2rem clamp(1.25rem,5vw,3rem) 1.8rem;
}
.mobile-menu[hidden]{ display:none; }
.mobile-menu a{
  font-family:var(--f-display); font-size:.95rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); padding:.7rem 0; border-bottom:1px solid var(--line-soft);
}
.mobile-menu .btn{ margin-top:.8rem; }

/* ---------------------------------------------------------------- HERO */
.hero{
  position:relative; min-height:100dvh;
  display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:2rem;
  max-width:var(--wrap); margin-inline:auto;
  padding:calc(var(--nav-h) + 2rem) clamp(1.25rem,5vw,3rem) 4rem;
}
.hero__glow{
  position:absolute; right:2%; top:50%; transform:translateY(-50%);
  width:min(60vw,640px); aspect-ratio:1; pointer-events:none;
  background:radial-gradient(circle, rgba(232,133,58,.20) 0%, rgba(184,83,31,.10) 30%, transparent 65%);
  filter:blur(8px); animation:pulseglow 6s ease-in-out infinite;
}
@keyframes pulseglow{ 0%,100%{ opacity:.7; transform:translateY(-50%) scale(1);} 50%{ opacity:1; transform:translateY(-50%) scale(1.06);} }

.hero__content{ position:relative; max-width:38rem; }
.hero__title{ margin:0 0 1.5rem; }
.hero__title-lvl{
  display:block; font-family:var(--f-display); font-weight:500;
  font-size:clamp(1rem,2.4vw,1.6rem); letter-spacing:.42em; text-transform:uppercase;
  color:var(--gold); margin-left:.3em; margin-bottom:.35rem;
}
.hero__title-main{
  display:block; font-family:var(--f-deco); font-weight:900;
  font-size:clamp(3.6rem,11vw,7.5rem); line-height:.92; letter-spacing:.01em;
  color:#f4ead2;
  text-shadow:0 0 40px rgba(232,133,58,.25), 0 4px 20px rgba(0,0,0,.7);
}
.hero__sub{
  font-size:clamp(1.08rem,1.6vw,1.28rem); color:var(--ink-dim);
  max-width:34rem; line-height:1.7; margin:0 0 2.2rem;
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:1rem; }

.hero__visual{ position:relative; display:grid; place-items:center; min-height:340px; }
.bonfire{
  position:relative; width:min(40vw,260px); color:var(--gold);
  cursor:pointer; display:grid; place-items:center; background:none; border:none;
}
.bonfire__halo{
  position:absolute; inset:-30% -30% -10%; border-radius:50%;
  background:radial-gradient(circle at 50% 70%, rgba(232,133,58,.35), rgba(184,83,31,.12) 40%, transparent 70%);
  filter:blur(6px); animation:flicker 3.2s ease-in-out infinite;
}
@keyframes flicker{
  0%,100%{ opacity:.85; transform:scale(1); }
  25%{ opacity:1; transform:scale(1.04); }
  50%{ opacity:.7; transform:scale(.98); }
  75%{ opacity:.95; transform:scale(1.03); }
}
.bonfire__sword{ position:relative; width:60%; }
.bonfire__flames path{ fill:var(--ember); animation:bolt-flicker 1.1s steps(4,end) infinite; transform-origin:center; }
.bonfire__flames path:nth-child(2){ animation-delay:.2s; }
.bonfire__flames path:nth-child(3){ animation-delay:.4s; }
@keyframes flamewave{ 0%,100%{ transform:scaleY(1) translateY(0);} 50%{ transform:scaleY(1.12) translateY(-2px);} }
@keyframes bolt-flicker{ 0%,100%{ opacity:1; } 30%{ opacity:.3; } 45%{ opacity:1; } 65%{ opacity:.55; } 80%{ opacity:1; } }
.bonfire__hint{
  position:absolute; bottom:-2.4rem; left:50%; transform:translateX(-50%);
  font-family:var(--f-display); font-size:.66rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink-mute); white-space:nowrap; transition:color .3s var(--ease);
}
.bonfire:hover .bonfire__hint{ color:var(--gold); }

.hero__scrollnote{ display:none; }

/* ---------------------------------------------------------------- QUETE */
.quete{ padding-block:clamp(5rem,10vw,8rem); }
.quete__grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.quete__text .lead{ margin-bottom:2rem; }

.boss-callout{ padding:1.4rem 1.6rem; border-left:3px solid var(--gold); }
.boss-callout__label{
  display:block; font-family:var(--f-display); font-weight:600; font-size:.7rem;
  letter-spacing:.3em; text-transform:uppercase; color:var(--ember); margin-bottom:.5rem;
}
.boss-callout p{ margin:0; color:var(--ink); font-size:1.08rem; }
.boss-callout::before, .boss-callout::after{ display:none; } /* uses left-border accent instead of brackets */

.attributes{ padding:1.6rem 1.7rem; }
.attributes__head{
  display:flex; justify-content:space-between; font-family:var(--f-display);
  font-size:.66rem; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-mute);
  padding-bottom:1rem; border-bottom:1px solid var(--line);
}
.attributes__list{ list-style:none; margin:0; padding:0; }
.attr{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:1rem;
  padding:1.15rem 0; border-bottom:1px solid var(--line-soft); }
.attr:last-child{ border-bottom:none; }
.attr__rune{
  font-family:var(--f-display); font-weight:700; font-size:1.05rem; color:var(--gold);
  width:2.4rem; height:2.4rem; display:grid; place-items:center;
  border:1px solid var(--gold-deep); background:rgba(200,165,90,.05);
}
.attr__body h3{ font-family:var(--f-display); font-weight:600; font-size:1.05rem; margin:0 0 .15rem; color:#ece0c6; letter-spacing:.02em; }
.attr__body p{ margin:0; font-size:.95rem; color:var(--ink-dim); }
.attr__val{ font-family:var(--f-display); font-size:.8rem; letter-spacing:.1em; color:var(--gold); white-space:nowrap; }

/* ---------------------------------------------------------------- CLASS SELECT */
.classes{ padding-block:clamp(5rem,10vw,8rem); }
.classes__head{ max-width:52rem; margin:0 auto 3rem; text-align:center; }
.classes__head .lead{ margin-top:1.2rem; }

.select{ display:grid; grid-template-columns:300px 1fr; gap:2rem; align-items:start; }
.select__tabs{ display:flex; flex-direction:column; gap:.8rem; }
.ctab{
  display:flex; align-items:center; gap:1rem; text-align:left; cursor:pointer;
  padding:1.05rem 1.1rem; background:linear-gradient(160deg, var(--panel), var(--bg-2));
  border:1px solid var(--line); color:var(--ink);
  transition:border-color .25s var(--ease), background .25s var(--ease), transform .2s var(--ease);
}
.ctab:hover{ border-color:var(--gold-deep); transform:translateX(3px); }
.ctab.is-active{
  border-color:var(--gold);
  background:linear-gradient(160deg, rgba(200,165,90,.12), var(--bg-2));
  box-shadow:-3px 0 0 var(--gold), 0 18px 40px -28px #000;
}
.ctab__glyph{ width:40px; height:40px; color:var(--gold); flex:none; opacity:.8; transition:opacity .25s; }
.ctab.is-active .ctab__glyph{ opacity:1; }
.ctab__glyph svg{ width:100%; height:100%; }
.ctab__meta{ display:flex; flex-direction:column; gap:.15rem; }
.ctab__meta strong{ font-family:var(--f-display); font-weight:600; font-size:.98rem; letter-spacing:.06em; }
.ctab__meta em{ font-style:normal; font-size:.78rem; color:var(--ink-mute); letter-spacing:.04em; }
.ctab.is-active .ctab__meta em{ color:var(--gold); }

.select__stage{ position:relative; }
.cpanel{ padding:clamp(1.6rem,3vw,2.4rem); }
.cpanel[hidden]{ display:none; }
.cpanel.is-active{ animation:panelin .5s var(--ease); }
@keyframes panelin{ from{ opacity:0; transform:translateY(16px);} to{ opacity:1; transform:translateY(0);} }
.cpanel__head{ display:flex; flex-wrap:wrap; align-items:baseline; gap:.5rem 1rem; margin-bottom:.9rem;
  padding-bottom:1.1rem; border-bottom:1px solid var(--line); }
.cpanel__head h3{ font-family:var(--f-display); font-weight:700; font-size:clamp(1.5rem,3vw,2rem); margin:0; color:#f0e6cf; }
.cpanel__tag{ font-family:var(--f-display); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.cpanel__desc{ color:var(--ink-dim); margin:0 0 1.6rem; max-width:54ch; }

.skills{ list-style:none; margin:0; padding:0; display:grid; gap:1.25rem; }
.skills li{ display:grid; grid-template-columns:minmax(140px,1fr) 1.4fr; align-items:center; gap:.4rem 1.2rem;
  position:relative; padding-bottom:1.25rem; border-bottom:1px solid var(--line-soft); }
.skills li:last-child{ border-bottom:none; }
.skills__name{ font-family:var(--f-display); font-weight:600; font-size:.96rem; color:#e7dcc2; letter-spacing:.03em; }
.skills__txt{ font-size:.95rem; color:var(--ink-dim); }
.skills__bar{ grid-column:1 / -1; height:3px; background:rgba(200,165,90,.12); position:relative; margin-top:.2rem; }
.skills__bar::after{
  content:""; position:absolute; left:0; top:0; height:100%; width:0;
  background:linear-gradient(90deg, var(--gold-deep), var(--gold) 60%, var(--gold-bright));
  box-shadow:0 0 10px rgba(232,133,58,.4);
  transition:width 1s var(--ease);
}
.cpanel.is-active .skills__bar::after{ width:var(--lvl); }
.cpanel__foot{ margin:1.6rem 0 0; padding-top:1.2rem; border-top:1px solid var(--line);
  font-style:italic; color:var(--gold); font-size:1rem; }

/* ---------------------------------------------------------------- JACK & JILL ARENA */
.arena{ padding-block:clamp(4rem,8vw,7rem); }
.arena__head{ max-width:48rem; margin:0 auto 2.6rem; }
.arena__head .lead{ margin-top:1.1rem; }
.arena__panel{
  position:relative; max-width:780px; margin-inline:auto; padding:clamp(1.6rem,3vw,2.4rem);
  border-color:var(--gold);
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(232,133,58,.15), transparent 55%),
    linear-gradient(160deg, var(--panel-2), var(--bg-2));
  box-shadow:0 0 0 1px rgba(232,133,58,.18), 0 30px 60px -34px rgba(232,125,58,.45);
}
.arena__glow{
  position:absolute; right:-4%; top:-14%; width:46%; aspect-ratio:1; z-index:0; pointer-events:none;
  background:radial-gradient(circle, rgba(232,133,58,.22), transparent 66%);
  filter:blur(14px); animation:flicker 4s ease-in-out infinite;
}
.arena__panel > *{ position:relative; z-index:1; }
.arena__panel .cpanel__head h3{ color:#f3e7cc; }
.arena__panel .cpanel__tag{ color:var(--ember); }
.arena__panel.is-revealed .skills__bar::after,
.arena__panel.is-visible .skills__bar::after{ width:var(--lvl); }

/* ---------------------------------------------------------------- ADMISSION */
.admission{ padding-block:clamp(5rem,10vw,8rem); }
.admission__head{ max-width:46rem; margin-bottom:3.4rem; }

.quest{ list-style:none; margin:0 0 3rem; padding:0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; position:relative; }
.quest::before{ content:""; position:absolute; top:24px; left:8%; right:8%; height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-deep), transparent); }
.quest__step{ position:relative; text-align:center; padding:0 .5rem; }
.quest__node{
  width:50px; height:50px; margin:0 auto 1.3rem; display:grid; place-items:center;
  font-family:var(--f-display); font-weight:700; font-size:1.2rem; color:var(--gold-bright);
  background:var(--bg); border:1px solid var(--gold); position:relative; z-index:1;
  box-shadow:0 0 0 6px var(--bg), 0 0 24px -4px rgba(232,133,58,.4);
  transform:rotate(45deg);
}
.quest__node > span{ display:block; transform:rotate(-45deg); }
.quest__step h3{ font-family:var(--f-display); font-weight:600; font-size:1.12rem; color:#ece0c6; margin:0 0 .5rem; letter-spacing:.02em; }
.quest__step p{ margin:0; font-size:.96rem; color:var(--ink-dim); max-width:26ch; margin-inline:auto; }

.admission__notes{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.note{ padding:1.5rem 1.6rem; }
.note h4{ font-family:var(--f-display); font-weight:600; font-size:1rem; letter-spacing:.06em; color:var(--gold); margin:0 0 .6rem; }
.note p{ margin:0; color:var(--ink-dim); font-size:1rem; }

/* ---------------------------------------------------------------- BOUTIQUE */
.boutique{ padding-block:clamp(5rem,10vw,8rem); }
.boutique__head{ max-width:52rem; margin:0 auto 3.2rem; }
.boutique__head .lead{ margin-top:1.2rem; }

.passes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; align-items:stretch; }
.pass{ padding:2rem 1.7rem 1.9rem; display:flex; flex-direction:column; }
.pass--legendary{
  border-color:var(--gold);
  background:linear-gradient(165deg, rgba(200,165,90,.14), var(--bg-2) 70%);
  box-shadow:0 0 0 1px rgba(200,165,90,.25), 0 30px 60px -34px rgba(232,133,58,.5);
  transform:translateY(-10px);
}
.pass__rarity{
  font-family:var(--f-display); font-size:.66rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink-mute); margin-bottom:1rem;
}
.pass__rarity--leg{ color:var(--gold-bright); }
.pass__name{ font-family:var(--f-display); font-weight:700; font-size:1.5rem; margin:0 0 .8rem; color:#f0e6cf; }
.pass__price{ font-family:var(--f-display); font-weight:700; font-size:2.8rem; line-height:1; color:var(--gold-bright); margin:0 0 1.2rem; }
.pass__cur{ font-family:var(--f-body),sans-serif; font-size:1.5rem; color:var(--gold); margin-left:.12rem; }
.pass__per{ font-family:var(--f-body); font-size:1rem; font-weight:400; color:var(--ink-mute); letter-spacing:0; }
.pass__desc{ color:var(--ink-dim); font-size:1rem; margin:0 0 1.4rem; }
.pass__feat{ list-style:none; margin:0 0 1.8rem; padding:0; display:grid; gap:.6rem; }
.pass__feat li{ position:relative; padding-left:1.5rem; font-size:.98rem; color:var(--ink); }
.pass__feat li::before{ content:""; position:absolute; left:0; top:.55em; width:7px; height:7px;
  background:var(--gold); transform:rotate(45deg); }
.pass__pick{ margin-top:auto; width:100%; }

/* ---------------------------------------------------------------- BONUS */
.bonus{ padding-block:clamp(5rem,10vw,8rem); }
.bonus__head{ max-width:44rem; margin-bottom:3rem; }
.perks{ display:grid; grid-template-columns:1.3fr 1fr; grid-auto-rows:1fr; gap:1.3rem; }
.perk{ padding:1.8rem; display:flex; flex-direction:column; gap:.7rem; }
.perk--feature{
  grid-row:span 2;
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(232,133,58,.14), transparent 55%),
    linear-gradient(160deg, var(--panel-2), var(--bg-2));
  justify-content:flex-end;
}
.perk__rune{ width:42px; height:42px; color:var(--gold); margin-bottom:.4rem; }
.perk--feature .perk__rune{ width:52px; height:52px; }
.perk__rune svg{ width:100%; height:100%; }
.perk h3{ font-family:var(--f-display); font-weight:600; font-size:1.25rem; margin:0; color:#ece0c6; letter-spacing:.02em; }
.perk--feature h3{ font-size:1.7rem; }
.perk p{ margin:0; color:var(--ink-dim); font-size:1rem; }
.bonus__when{ text-align:center; margin:2.6rem 0 0; font-family:var(--f-display);
  font-size:.92rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); }

/* ---------------------------------------------------------------- FINALE */
.finale{ padding-bottom:clamp(4rem,8vw,7rem); }
.finale__banner{
  position:relative; min-height:62vh; display:grid; place-content:center; text-align:center;
  padding:6rem 1.5rem; margin-bottom:clamp(3rem,6vw,5rem);
  background:
    radial-gradient(80% 80% at 50% 50%, rgba(124,23,21,.42), transparent 62%),
    linear-gradient(180deg, #0a0706, #0a0706);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  overflow:hidden;
}
.finale__banner::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(60% 60% at 50% 50%, transparent 55%, rgba(0,0,0,.7));
}
.finale__pre{ position:relative; z-index:1; font-family:var(--f-body); font-style:italic;
  font-size:clamp(1rem,2vw,1.3rem); color:#c9a08f; letter-spacing:.04em; margin:0 0 1rem; }
.finale__title{
  position:relative; z-index:1; margin:0;
  font-family:var(--f-display); font-weight:700;
  font-size:clamp(2.4rem,7vw,5.4rem); line-height:1.05; letter-spacing:.04em; text-transform:uppercase;
  color:#d8453a;
  text-shadow:0 0 60px rgba(194,50,39,.6), 0 0 18px rgba(124,23,21,.8);
  background:linear-gradient(180deg, #e85a4a, #8f1c18);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}

.finale__body{ }
.signup{ max-width:680px; margin-inline:auto; padding:clamp(1.8rem,4vw,2.8rem); }
.signup__lead{ text-align:center; color:var(--ink-dim); margin:0 0 2rem; font-size:1.08rem; }

.form{ display:grid; gap:1.5rem; }
.field{ display:grid; gap:.5rem; }
.field label, .field__label{ font-family:var(--f-display); font-weight:600; font-size:.78rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--gold); }
.field input{
  width:100%; padding:.95rem 1rem; background:#0f0b07; border:1px solid var(--gold-deep);
  color:var(--ink); font-family:var(--f-body); font-size:1.08rem; border-radius:0;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.field input::placeholder{ color:#8a8069; }
.field input:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 1px var(--gold), 0 0 22px -6px rgba(232,133,58,.5); }
.field input[aria-invalid="true"]{ border-color:var(--crimson-bright); box-shadow:0 0 0 1px var(--crimson-bright); }
.field__help{ margin:0; font-size:.88rem; color:var(--ink-mute); }
.field__error{ margin:0; font-size:.9rem; color:#e8736a; font-style:italic; }

.chooser{ display:flex; flex-wrap:wrap; gap:.6rem; }
.chip{
  font-family:var(--f-display); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.6rem 1rem; background:transparent; border:1px solid var(--gold-deep); color:var(--ink-dim);
  cursor:pointer; transition:all .2s var(--ease);
}
.chip:hover{ border-color:var(--gold); color:var(--gold-bright); }
.chip.is-on{ background:var(--gold); border-color:var(--gold-bright); color:#1a1206; }

.form__submit{ margin-top:.4rem; }
.form__success{
  text-align:center; margin:.4rem 0 0; padding:1rem 1.2rem; font-style:italic; font-size:1.05rem;
  color:#e9dcc0; border:1px solid var(--gold); background:rgba(200,165,90,.08);
}

/* video file picker */
.filepick{ display:inline-flex; align-items:center; gap:.8rem; flex-wrap:wrap; cursor:pointer; margin-top:.2rem; }
.filepick input[type="file"]{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); border:0; }
.filepick__btn{
  font-family:var(--f-display); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  padding:.6rem 1rem; border:1px solid var(--gold-deep); color:var(--gold-bright);
  transition:border-color .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
}
.filepick:hover .filepick__btn{ border-color:var(--gold); background:rgba(200,165,90,.1); color:#fbeccb; }
.filepick__name{ font-size:.9rem; color:var(--ink-mute); font-style:italic; }

/* ---------------------------------------------------------------- FOOTER */
.foot{ border-top:1px solid var(--line); padding-top:clamp(3rem,6vw,4.5rem); padding-bottom:2rem;
  background:linear-gradient(180deg, transparent, rgba(8,6,5,.7)); }
.foot__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.5rem; padding-bottom:3rem; }
.foot__brand .brand__sigil{ width:40px; height:40px; color:var(--gold); margin-bottom:1rem; }
.foot__name{ font-family:var(--f-display); font-weight:700; font-size:1.1rem; letter-spacing:.14em;
  text-transform:uppercase; margin:0 0 .5rem; }
.foot__tag{ margin:0; color:var(--ink-dim); font-size:.98rem; max-width:24ch; }
.foot h4{ font-family:var(--f-display); font-weight:600; font-size:.74rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--gold); margin:0 0 1.1rem; }
.foot__nav{ display:flex; flex-direction:column; gap:.6rem; }
.foot__nav a{ color:var(--ink-dim); font-size:.98rem; transition:color .2s var(--ease); }
.foot__nav a:hover{ color:var(--gold-bright); }
.foot__info p{ margin:0 0 .4rem; color:var(--ink-dim); font-size:.98rem; }
.foot__sched{ color:var(--ink-mute) !important; font-size:.9rem !important; }
.foot__cta .btn{ margin-bottom:1rem; }
.foot__creed{ margin:0; font-style:italic; color:var(--gold); font-size:1rem; }
.foot__base{ max-width:var(--wrap); margin-inline:auto; padding:1.6rem clamp(1.25rem,5vw,3rem) 0;
  border-top:1px solid var(--line-soft); display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; }
.foot__base p{ margin:0; font-size:.84rem; letter-spacing:.04em; color:var(--ink-mute); }

/* ---------------------------------------------------------------- SOUND TOGGLE */
.sound-toggle{
  position:fixed; right:18px; bottom:18px; z-index:65;
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.62rem .85rem; cursor:pointer;
  background:rgba(9,7,5,.82); backdrop-filter:blur(8px);
  border:1px solid var(--gold-deep); color:var(--gold);
  font-family:var(--f-display); font-size:.64rem; letter-spacing:.22em; text-transform:uppercase;
  transition:border-color .25s var(--ease), color .25s var(--ease), background .25s var(--ease);
}
.sound-toggle:hover, .sound-toggle.is-playing{ border-color:var(--gold); color:var(--gold-bright); background:rgba(15,11,7,.9); }
.sound-toggle__bars{ display:inline-flex; align-items:flex-end; gap:2px; height:14px; }
.sound-toggle__bars i{ width:2px; height:3px; background:currentColor; }
.sound-toggle.is-playing .sound-toggle__bars i{ animation:eq .9s ease-in-out infinite; }
.sound-toggle.is-playing .sound-toggle__bars i:nth-child(2){ animation-delay:.12s; }
.sound-toggle.is-playing .sound-toggle__bars i:nth-child(3){ animation-delay:.26s; }
.sound-toggle.is-playing .sound-toggle__bars i:nth-child(4){ animation-delay:.4s; }
@keyframes eq{ 0%,100%{ height:3px; } 50%{ height:14px; } }
@media (max-width:640px){
  .sound-toggle{ right:12px; bottom:12px; padding:.55rem; }
  .sound-toggle__label{ display:none; }
}

/* ---------------------------------------------------------------- REVEAL */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
.reveal-banner .finale__pre,
.reveal-banner .finale__title{ opacity:0; }
.reveal-banner.is-visible .finale__pre{ animation:fadeup .9s .1s var(--ease) forwards; }
.reveal-banner.is-visible .finale__title{ animation:youdied 1.6s .2s var(--ease) forwards; }
@keyframes fadeup{ from{ opacity:0; transform:translateY(14px);} to{ opacity:1; transform:none;} }
@keyframes youdied{
  0%{ opacity:0; transform:scale(1.42); letter-spacing:.22em; filter:blur(6px); }
  55%{ opacity:1; filter:blur(0); }
  100%{ opacity:1; transform:scale(1); letter-spacing:.04em; }
}

/* ---------------------------------------------------------------- RESPONSIVE */
@media (max-width:980px){
  .nav__links, .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
  .hero{ grid-template-columns:1fr; text-align:left; min-height:auto; padding-top:calc(var(--nav-h) + 3rem); padding-bottom:3rem; gap:1rem; }
  .hero__visual{ order:-1; min-height:240px; margin-bottom:2.8rem; }
  .bonfire{ width:200px; }
  .hero__glow{ right:50%; transform:translate(50%,-50%); top:34%; }
  .quete__grid{ grid-template-columns:1fr; }
  .select{ grid-template-columns:1fr; }
  .select__tabs{ flex-direction:row; flex-wrap:wrap; }
  .ctab{ flex:1 1 200px; }
  .perks{ grid-template-columns:1fr; }
  .perk--feature{ grid-row:auto; }
  .foot__grid{ grid-template-columns:1fr 1fr; gap:2rem; }
}
@media (max-width:640px){
  body{ font-size:17px; }
  .passes{ grid-template-columns:1fr; }
  .pass--legendary{ transform:none; }
  .quest{ grid-template-columns:1fr; gap:2.2rem; }
  .quest::before{ top:8%; bottom:8%; left:24px; right:auto; width:1px; height:auto;
    background:linear-gradient(180deg, transparent, var(--gold-deep), transparent); }
  .quest__step{ display:grid; grid-template-columns:50px 1fr; text-align:left; gap:0 1.2rem; align-items:start; }
  .quest__node{ margin:0; }
  .quest__step h3, .quest__step p{ text-align:left; margin-inline:0; max-width:none; }
  .quest__step h3{ padding-top:.4rem; }
  .admission__notes{ grid-template-columns:1fr; }
  .foot__grid{ grid-template-columns:1fr; }
  .ctab__meta strong{ font-size:.9rem; }
  .skills li{ grid-template-columns:1fr; }
}

/* =========================================================================
   CINEMATIC SOULS LAYER
   Intro title screen, boss-HP HUD (scroll progress), area-discovered cards,
   fog gates, parallax, richer ornaments and micro-interactions.
   ========================================================================= */

:root{ --z-hud:75; --z-areacard:90; --z-intro:200; }

/* ---- scroll lock while the intro is up ---- */
body.intro-open{ overflow:hidden; }

/* ---------------------------------------------------------------- INTRO */
.intro{
  position:fixed; inset:0; z-index:var(--z-intro);
  display:grid; place-items:center; text-align:center;
  background:radial-gradient(circle at 50% 42%, #16100a 0%, #070605 68%);
}
.intro[hidden]{ display:none; }
.intro__glow{
  position:absolute; left:50%; top:42%; transform:translate(-50%,-50%);
  width:min(90vw,720px); aspect-ratio:1; pointer-events:none;
  background:radial-gradient(circle, rgba(232,133,58,.22), rgba(184,83,31,.08) 38%, transparent 66%);
  filter:blur(10px); animation:pulseglow 6s ease-in-out infinite;
}
.intro__inner{ position:relative; display:grid; justify-items:center; gap:.4rem; padding:2rem; }
.intro__sigil{ width:84px; height:84px; color:var(--gold); opacity:0; animation:intro-pop 1s .15s var(--ease) forwards; }
.intro__sigil svg{ width:100%; height:100%; filter:drop-shadow(0 0 24px rgba(232,133,58,.5)); }
.intro__brand{
  margin:.8rem 0 0; font-family:var(--f-display); font-weight:700;
  font-size:clamp(1.6rem,4vw,2.6rem); letter-spacing:.3em; text-transform:uppercase; color:#f1e7cf;
  opacity:0; animation:intro-rise 1s .4s var(--ease) forwards;
}
.intro__tagline{
  margin:.2rem 0 1.6rem; font-family:var(--f-deco); font-weight:700;
  font-size:clamp(2.4rem,8vw,5rem); line-height:1; color:#f4ead2;
  text-shadow:0 0 40px rgba(232,133,58,.3);
  opacity:0; animation:intro-rise 1.1s .65s var(--ease) forwards;
}
.intro__enter{
  margin-top:.6rem; padding:.85rem 2rem; cursor:pointer;
  background:transparent; border:1px solid var(--gold-deep); color:var(--gold-bright);
  font-family:var(--f-display); font-size:.8rem; letter-spacing:.24em; text-transform:uppercase;
  opacity:0; animation:intro-rise 1s 1s var(--ease) forwards, hud-pulse 2.4s 2s ease-in-out infinite;
  transition:background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease);
}
.intro__enter:hover{ background:rgba(200,165,90,.12); border-color:var(--gold); color:#fbeccb; }
.intro.is-leaving{ animation:intro-out .8s var(--ease) forwards; }
@keyframes intro-pop{ from{ opacity:0; transform:scale(.6); } to{ opacity:1; transform:scale(1); } }
@keyframes intro-rise{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
@keyframes intro-out{ to{ opacity:0; visibility:hidden; transform:scale(1.04); } }

/* ---------------------------------------------------------------- HUD (boss bar) */
.hud{
  position:fixed; left:50%; bottom:18px; transform:translateX(-50%);
  z-index:var(--z-hud); width:min(46vw,380px); pointer-events:none; text-align:center;
  opacity:0; transition:opacity .6s var(--ease);
}
.hud.is-on{ opacity:1; }
.hud__area{
  margin:0 0 .45rem; font-family:var(--f-display); font-weight:600;
  font-size:.66rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold);
  text-shadow:0 1px 8px #000; transition:opacity .4s var(--ease);
}
.hud__bar{
  position:relative; height:7px; padding:1px;
  background:linear-gradient(180deg, rgba(0,0,0,.7), rgba(0,0,0,.5));
  border:1px solid var(--gold-deep);
  box-shadow:inset 0 0 6px rgba(0,0,0,.8), 0 0 18px -6px rgba(124,23,21,.6);
}
.hud__bar::before, .hud__bar::after{
  content:""; position:absolute; top:-3px; bottom:-3px; width:2px; background:var(--gold);
}
.hud__bar::before{ left:-1px; } .hud__bar::after{ right:-1px; }
.hud__fill{
  display:block; height:100%; transform-origin:left; transform:scaleX(1);
  background:linear-gradient(90deg, #5c1210, #b0291f 60%, #d8453a);
  box-shadow:0 0 10px rgba(194,50,39,.7);
}
@supports (animation-timeline: scroll()){
  .hud__fill{
    animation-name:hud-deplete; animation-timing-function:linear;
    animation-fill-mode:both; animation-duration:auto;
    animation-timeline:scroll(root block);
  }
}
@keyframes hud-deplete{ to{ transform:scaleX(.04); } }
@keyframes hud-pulse{ 0%,100%{ opacity:.7; } 50%{ opacity:1; } }

/* ---------------------------------------------------------------- AREA CARD */
.areacard{
  position:fixed; left:50%; top:40%; transform:translate(-50%,-50%);
  z-index:var(--z-areacard); pointer-events:none; text-align:center; opacity:0; width:max-content; max-width:90vw;
}
.areacard__rule{
  display:block; height:1px; width:min(58vw,440px); margin:.7rem auto;
  transform:scaleX(0); transform-origin:center;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.areacard__name{
  margin:0; font-family:var(--f-display); font-weight:700;
  font-size:clamp(1.7rem,5vw,3.3rem); letter-spacing:.16em; text-transform:uppercase; color:#efe3c6;
  text-shadow:0 2px 30px #000, 0 0 44px rgba(232,133,58,.3);
}
.areacard.is-shown{ animation:area-card 2.9s var(--ease) forwards; }
.areacard.is-shown .areacard__name{ animation:area-name 2.9s var(--ease) forwards; }
.areacard.is-shown .areacard__rule{ animation:area-rule 2.9s var(--ease) forwards; }
@keyframes area-card{ 0%{ opacity:0; } 12%{ opacity:1; } 80%{ opacity:1; } 100%{ opacity:0; } }
@keyframes area-name{
  0%{ opacity:0; letter-spacing:.42em; transform:translateY(10px); filter:blur(5px); }
  18%{ opacity:1; letter-spacing:.16em; transform:none; filter:blur(0); }
  80%{ opacity:1; } 100%{ opacity:.5; }
}
@keyframes area-rule{ 0%{ transform:scaleX(0); opacity:0; } 22%{ transform:scaleX(1); opacity:1; } 80%{ transform:scaleX(1); opacity:1; } 100%{ transform:scaleX(1); opacity:0; } }

/* ---------------------------------------------------------------- FOG GATES */
main > section{ position:relative; isolation:isolate; }
main > section + section::before{
  content:""; position:absolute; left:0; right:0; top:0; height:160px; z-index:-1; pointer-events:none;
  background:
    radial-gradient(120% 100% at 50% 0%, rgba(150,140,120,.10), transparent 60%),
    linear-gradient(180deg, rgba(12,10,8,.6), transparent);
  -webkit-mask-image:linear-gradient(180deg, #000, transparent);
  mask-image:linear-gradient(180deg, #000, transparent);
  animation:fogdrift 30s ease-in-out infinite alternate;
}
main > section + section::after{
  content:""; position:absolute; left:50%; top:0; transform:translateX(-50%); z-index:-1; pointer-events:none;
  width:min(70%,560px); height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-deep) 35%, var(--gold) 50%, var(--gold-deep) 65%, transparent);
  opacity:.5;
}

/* ---------------------------------------------------------------- PARALLAX (progressive) */
@supports (animation-timeline: view()){
  @media (prefers-reduced-motion: no-preference){
    .hero__visual{
      animation-name:para-rise; animation-timing-function:linear;
      animation-fill-mode:both; animation-duration:auto;
      animation-timeline:view(); animation-range:entry 10% exit 90%;
    }
  }
}
@keyframes para-rise{ from{ transform:translateY(40px); } to{ transform:translateY(-40px); } }

/* ---------------------------------------------------------------- ENHANCED REVEALS */
.reveal{ transition:opacity .85s var(--ease), transform .85s var(--ease); }
.reveal:not(.is-visible){ transform:translateY(34px) scale(.985); }
/* stagger children of grids that carry .reveal */
.passes.reveal:not(.is-visible) > *, .perks.reveal:not(.is-visible) > *,
.quest.reveal:not(.is-visible) > *, .admission__notes.reveal:not(.is-visible) > *{ opacity:0; }
.passes.reveal.is-visible > *, .perks.reveal.is-visible > *,
.quest.reveal.is-visible > *, .admission__notes.reveal.is-visible > *{ animation:stagger-in .7s var(--ease) backwards; }
.passes.reveal.is-visible > *:nth-child(2), .perks.reveal.is-visible > *:nth-child(2),
.quest.reveal.is-visible > *:nth-child(2), .admission__notes.reveal.is-visible > *:nth-child(2){ animation-delay:.1s; }
.passes.reveal.is-visible > *:nth-child(3), .perks.reveal.is-visible > *:nth-child(3),
.quest.reveal.is-visible > *:nth-child(3){ animation-delay:.2s; }
@keyframes stagger-in{ from{ opacity:0; transform:translateY(22px); } to{ opacity:1; transform:none; } }

/* ---------------------------------------------------------------- MICRO-INTERACTIONS */
/* ember sweep across primary/ghost buttons on hover */
.btn{ position:relative; overflow:hidden; }
.btn::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(110deg, transparent 30%, rgba(255,236,200,.35) 50%, transparent 70%);
  transform:translateX(-120%); transition:transform .6s var(--ease);
}
.btn:hover::after{ transform:translateX(120%); }
.btn--gold::after{ background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,.5) 50%, transparent 70%); }

/* class emblems gently breathe; lift the whole panel on reveal */
.ctab.is-active .ctab__glyph{ animation:emblem-breathe 3.4s ease-in-out infinite; }
@keyframes emblem-breathe{ 0%,100%{ transform:scale(1); filter:drop-shadow(0 0 0 transparent); } 50%{ transform:scale(1.06); filter:drop-shadow(0 0 10px rgba(232,133,58,.5)); } }

/* price gets a faint "souls" glow */
.pass--legendary .pass__price{ animation:price-glow 4s ease-in-out infinite; }
@keyframes price-glow{ 0%,100%{ text-shadow:0 0 0 transparent; } 50%{ text-shadow:0 0 24px rgba(232,200,120,.45); } }

/* bonfire breathes a little stronger now */
.hero__glow{ animation:pulseglow 5s ease-in-out infinite; }
.bonfire__sword{ animation:bonfire-float 5s ease-in-out infinite; }
@keyframes bonfire-float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-5px); } }

/* ---------------------------------------------------------------- HUD/AREACARD MOBILE */
@media (max-width:640px){
  .hud{ width:min(64vw,240px); bottom:14px; }
  .areacard{ top:38%; }
}

/* ---------------------------------------------------------------- REDUCED MOTION (extended) */
@media (prefers-reduced-motion: reduce){
  .intro__sigil, .intro__brand, .intro__tagline, .intro__enter{ animation:none; opacity:1; }
  .intro__glow{ animation:none; }
  .hud__fill{ animation:none; }
  .areacard{ display:none !important; }
  main > section + section::before{ animation:none; }
  .ctab.is-active .ctab__glyph, .pass--legendary .pass__price, .bonfire__sword, .btn::after{ animation:none; }
  .reveal:not(.is-visible){ transform:none; }
  .passes.reveal.is-visible > *, .perks.reveal.is-visible > *,
  .quest.reveal.is-visible > *, .admission__notes.reveal.is-visible > *{ animation:none; opacity:1; }
}

/* ---------------------------------------------------------------- REDUCED MOTION (base) */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; }
  .reveal{ opacity:1; transform:none; }
  .reveal-banner .finale__pre, .reveal-banner .finale__title{ opacity:1; }
  .fog, .hero__glow, .bonfire__halo, .bonfire__flames path{ animation:none; }
  .cpanel.is-active .skills__bar::after{ transition:none; }
}
