
:root {
  --bg: #030507;
  --ink: #f2ebdc;
  --gold-strong: #f1c46a;
  --serif: Georgia, "Times New Roman", serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
html { background: var(--bg); color: var(--ink); }
body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--sans);
  color: var(--ink);
  background: #010204;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.site-shell {
  position: relative;
  min-height: 100vh;
  width: min(1920px, 100%);
  margin: 0 auto;
  overflow: hidden;
  background: #010204;
}
.site-header {
  position: absolute;
  z-index: 35;
  top: 0; left: 0; right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(1rem, 2vw, 2.25rem);
  padding: clamp(1rem, 1.65vw, 1.65rem) clamp(1.25rem, 3vw, 3rem);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: .66rem;
  color: var(--gold-strong);
  font-family: var(--serif);
  font-size: clamp(.94rem, 1.05vw, 1.25rem);
  letter-spacing: .08em;
  text-transform: uppercase;
  text-shadow: 0 0 24px rgba(208, 163, 84, .25);
}
.brand img { width: 1.85rem; height: 1.85rem; opacity: .92; }
.main-nav {
  display: flex;
  align-items: center;
  gap: clamp(.82rem, 1.45vw, 1.9rem);
  margin-left: auto;
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: rgba(242,235,220,.82);
}
.main-nav a { position: relative; padding: .55rem .05rem; transition: color .2s ease, opacity .2s ease; }
.main-nav a:hover, .main-nav a.active, .main-nav a[aria-current="page"] { color: #fff2c7; }
.home-stage {
  position: relative;
  min-height: 100vh;
  isolation: isolate;
  overflow: hidden;
  display: grid;
  align-items: start;
  padding: clamp(5.0rem, 6.4vw, 6.0rem) clamp(1.35rem, 4.6vw, 5.5rem) clamp(3.5rem, 6vw, 6rem);
}
.hero-bg {
  position: absolute; inset: 0; z-index: -12;
  background-image: url("assets/hero/homepage-bg-locked.webp");
  background-size: cover; background-position: center center;
  transform: scale(1.014);
  filter: saturate(.92) contrast(1.05) brightness(.70);
}
.cinema-vignette {
  position: absolute; inset: 0; z-index: -10; pointer-events: none;
  background:
    radial-gradient(circle at 70% 48%, transparent 0 25%, rgba(0,0,0,.22) 48%, rgba(0,0,0,.68) 100%),
    linear-gradient(90deg, rgba(0,0,0,.92) 0%, rgba(0,0,0,.78) 28%, rgba(0,0,0,.18) 54%, rgba(0,0,0,.18) 78%, rgba(0,0,0,.62) 100%),
    linear-gradient(180deg, rgba(0,0,0,.54) 0%, transparent 28%, transparent 55%, rgba(0,0,0,.62) 100%);
}
.storm-sheen {
  position: absolute; inset: 0; z-index: -9; pointer-events: none; opacity: .33;
  background:
    radial-gradient(circle at 20% 22%, rgba(75,145,220,.10), transparent 22rem),
    radial-gradient(circle at 83% 50%, rgba(255,156,54,.07), transparent 18rem),
    linear-gradient(115deg, transparent 0 40%, rgba(255,255,255,.024) 46%, transparent 54% 100%);
}
.cloud-layer {
  position: absolute; z-index: -8; pointer-events: none; opacity: .16; mix-blend-mode: screen;
  filter: blur(14px);
}
.cloud-layer-a {
  top: -2vh; left: -12vw; width: 94vw; height: 32vh;
  background:
    radial-gradient(ellipse at 18% 40%, rgba(120,150,210,.14), transparent 18%),
    radial-gradient(ellipse at 45% 52%, rgba(110,135,190,.12), transparent 24%),
    radial-gradient(ellipse at 74% 42%, rgba(145,165,220,.10), transparent 20%);
}
.cloud-layer-b {
  top: 5vh; left: 0vw; width: 66vw; height: 20vh; opacity: .12;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(160,175,220,.10), transparent 21%),
    radial-gradient(ellipse at 52% 46%, rgba(120,145,200,.09), transparent 20%),
    radial-gradient(ellipse at 82% 48%, rgba(145,165,220,.08), transparent 18%);
}
.cloud-layer-c {
  top: 1vh; left: 18vw; width: 58vw; height: 17vh; opacity: .09;
  background:
    radial-gradient(ellipse at 12% 50%, rgba(120,145,210,.09), transparent 18%),
    radial-gradient(ellipse at 42% 52%, rgba(132,155,215,.08), transparent 16%),
    radial-gradient(ellipse at 74% 46%, rgba(150,170,220,.07), transparent 15%);
}
.moon-glow {
  position: absolute; z-index: -7; pointer-events: none;
  left: 10%; top: 4.2%; width: min(15rem, 17vw); aspect-ratio: 1;
  border-radius: 50%; mix-blend-mode: screen;
  background:
    radial-gradient(circle, rgba(235,245,255,.32) 0 12%, rgba(196,217,255,.13) 25%, rgba(130,165,230,.06) 40%, rgba(130,165,230,0) 68%),
    radial-gradient(circle, rgba(218,232,255,.14) 0 38%, rgba(218,232,255,0) 70%);
  filter: blur(10px);
  opacity: .34;
}
.hero-copy {
  position: relative; z-index: 20; width: min(47rem, 50vw);
  margin-top: clamp(.1rem, .8vh, .75rem);
}
.title-art {
  display: block;
  width: min(100%, 40rem);
  height: auto;
  opacity: .93;
  filter: drop-shadow(0 9px 3px rgba(0,0,0,.50)) drop-shadow(0 22px 52px rgba(0,0,0,.92));
}
.enter-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: clamp(.85rem, 1.25vw, 1rem) 0 0 .38rem;
  padding: .82rem 1.22rem .78rem;
  border: 1px solid rgba(232,194,122,.42);
  border-radius: 999px;
  color: rgba(255,244,213,.95);
  background: linear-gradient(180deg, rgba(99,38,24,.38), rgba(22,10,6,.74));
  box-shadow: 0 12px 34px rgba(0,0,0,.50), inset 0 1px 0 rgba(255,239,190,.14);
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  text-shadow: 0 0 18px rgba(232,194,122,.25);
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.enter-button:hover {
  transform: translateY(-1px);
  border-color: rgba(255,223,156,.72);
  background: linear-gradient(180deg, rgba(128,47,28,.50), rgba(27,12,7,.80));
  box-shadow: 0 16px 40px rgba(0,0,0,.58), 0 0 28px rgba(232,126,58,.12), inset 0 1px 0 rgba(255,239,190,.20);
}
.fog {
  display: none;
}
.fog-a { bottom: 0vh; height: 35vh; opacity: .22; }
.fog-b { bottom: 8vh; height: 27vh; opacity: .18; }
.fog-c { top: 16vh; height: 19vh; opacity: .07; }
.fog-d { bottom: 16vh; height: 21vh; opacity: .10; }
.fog-e { bottom: -4vh; height: 43vh; opacity: .14; }
.fog-f { top: 26vh; height: 18vh; opacity: .06; }
.embers { position: absolute; inset: 0; z-index: 8; pointer-events: none; overflow: hidden; }
.embers .ember {
  position: absolute; bottom: -2.5vh; width: var(--size); height: var(--size); left: var(--startX);
  opacity: 0; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(255,248,210,.95) 0 18%, rgba(255,188,94,.84) 24%, rgba(255,126,33,.54) 55%, rgba(255,126,33,0) 70%);
  box-shadow: 0 0 7px rgba(255,169,64,.34), 0 0 14px rgba(255,120,30,.14);
  filter: blur(var(--blur));
  animation: emberDrift var(--dur) linear infinite;
  animation-delay: var(--delay);
}
.embers .ember::after {
  content: ""; position: absolute; inset: -70% -25% 55% -25%;
  background: linear-gradient(180deg, rgba(255,186,80,.14), rgba(255,186,80,0));
  transform: translateY(100%);
}
@keyframes emberDrift {
  0% { transform: translate3d(0,0,0) scale(.65); opacity: 0; }
  8% { opacity: var(--alpha); }
  60% { opacity: calc(var(--alpha) * .66); }
  100% { transform: translate3d(var(--driftX), calc(-1 * var(--rise)), 0) scale(1.06); opacity: 0; }
}
@media (max-width: 980px) {
  .site-header { flex-wrap: wrap; align-items: flex-start; }
  .main-nav { width: 100%; justify-content: flex-end; flex-wrap: wrap; gap: .7rem 1rem; }
  .home-stage { align-items: end; }
  .hero-copy { width: min(40rem, 100%); margin-top: 4.75rem; }
  .title-art { width: min(100%, 34rem); }
}
@media (max-width: 700px) {
  .site-header { padding: 1rem 1rem .5rem; }
  .main-nav { justify-content: flex-start; font-size: .62rem; letter-spacing: .16em; }
  .home-stage { padding: 6.7rem 1rem 2.5rem; }
  .hero-copy { width: min(29rem, 100%); margin-top: 3.2rem; }
  .title-art { width: min(100%, 26rem); }
}
@media (prefers-reduced-motion: reduce) {
  .embers .ember { animation: none !important; }
  .fog, .cloud-layer, .storm-sheen, .moon-glow { transform: none !important; opacity: initial !important; }
}
