/* =====================================================================
   BUCK ROPE RODEO & DANCE — design system
   Cinematic dark · brand gold · ember energy
   ===================================================================== */

:root{
  /* ----- color ----- */
  --ink:        #0b0a08;
  --ink-soft:   #100d09;
  --panel:      #16110b;
  --panel-2:    #1e1810;
  --panel-3:    #261d12;
  --line:       rgba(196,146,47,.20);
  --line-soft:  rgba(243,236,221,.08);

  --bone:       #f4ecdb;
  --bone-2:     #d9cdb4;
  --muted:      #998d74;
  --muted-2:    #6f6555;

  --gold:       #c4922f;
  --gold-2:     #e7c061;
  --gold-3:     #f4d98a;
  --ember:      #cf4a26;
  --ember-2:    #f2682f;

  --grad-gold:  linear-gradient(135deg,#f4d98a 0%,#e7c061 38%,#c4922f 100%);
  --grad-ember: linear-gradient(135deg,#f2682f 0%,#cf4a26 60%,#9c2f17 100%);

  /* ----- type ----- */
  --f-display: "Anton", "Oswald", system-ui, sans-serif;
  --f-cond:    "Oswald", system-ui, sans-serif;
  --f-body:    "Inter", system-ui, -apple-system, sans-serif;
  --f-script:  "Kaushan Script", cursive;

  /* ----- metrics ----- */
  --container: 1240px;
  --gut: clamp(20px, 5vw, 64px);
  --r:    14px;
  --r-lg: 22px;
  --r-xl: 30px;

  --shadow:    0 30px 70px -28px rgba(0,0,0,.85);
  --shadow-sm: 0 14px 34px -16px rgba(0,0,0,.7);
  --glow-gold: 0 0 0 1px rgba(231,192,97,.35), 0 18px 50px -16px rgba(231,192,97,.35);

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* =====================================================================
   reset / base
   ===================================================================== */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:84px; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--bone);
  background:var(--ink);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--gold); color:var(--ink); }

/* film grain + vignette overlay (whole page) */
body::before{
  content:""; position:fixed; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(130% 100% at 50% -10%, transparent 70%, rgba(0,0,0,.32) 100%),
    radial-gradient(130% 120% at 50% 120%, transparent 72%, rgba(0,0,0,.26) 100%);
  mix-blend-mode:multiply;
}
.grain{
  position:fixed; inset:-50%; z-index:2; 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>");
  animation:grain 7s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 16%{transform:translate(-4%,2%)} 33%{transform:translate(3%,-3%)}
  50%{transform:translate(-2%,4%)} 66%{transform:translate(4%,1%)} 83%{transform:translate(-3%,-2%)} 100%{transform:translate(0,0)}
}

/* =====================================================================
   layout helpers
   ===================================================================== */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gut); }
.section{ position:relative; z-index:3; padding-block:clamp(72px,10vw,140px); }
.section--tight{ padding-block:clamp(54px,7vw,90px); }
.center{ text-align:center; }
.stack{ display:flex; flex-direction:column; }

/* =====================================================================
   typography
   ===================================================================== */
.kicker{
  font-family:var(--f-cond); font-weight:600;
  text-transform:uppercase; letter-spacing:.34em;
  font-size:.78rem; color:var(--gold-2);
  display:inline-flex; align-items:center; gap:.7em;
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--grad-gold); border-radius:2px; }
.kicker.is-centered{ justify-content:center; }
.kicker.is-centered::after{ content:""; width:26px; height:2px; background:var(--grad-gold); border-radius:2px; }

.display{
  font-family:var(--f-display); font-weight:400;
  line-height:.92; letter-spacing:.005em; text-transform:uppercase;
  margin:0; color:var(--bone);
  text-wrap:balance;
}
.display--xxl{ font-size:clamp(3.4rem,11vw,9rem); }
.display--xl{  font-size:clamp(2.7rem,7vw,5.4rem); }
.display--lg{  font-size:clamp(2.1rem,5vw,3.6rem); }
.script{ font-family:var(--f-script); text-transform:none; font-weight:400; }
.txt-gold{ color:var(--gold-2); }
.txt-grad{ background:var(--grad-gold); -webkit-background-clip:text; background-clip:text; color:transparent; }
.txt-ember{ background:var(--grad-ember); -webkit-background-clip:text; background-clip:text; color:transparent; }

.lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--bone-2); max-width:60ch; }
.muted{ color:var(--muted); }
.section-head{ max-width:760px; }
.section-head .lead{ margin-top:18px; }
.section-head.is-centered{ margin-inline:auto; }

/* =====================================================================
   buttons
   ===================================================================== */
.btn{
  --pad:16px 26px;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  padding:var(--pad); border-radius:999px; border:1px solid transparent;
  font-family:var(--f-cond); font-weight:600; text-transform:uppercase;
  letter-spacing:.12em; font-size:.86rem; line-height:1;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s, border-color .25s;
  white-space:nowrap;
}
.btn svg{ width:1.05em; height:1.05em; }
.btn--gold{ background:var(--grad-gold); color:#1a1206; box-shadow:var(--glow-gold); }
.btn--gold:hover{ transform:translateY(-3px); box-shadow:0 0 0 1px rgba(231,192,97,.5),0 26px 60px -16px rgba(231,192,97,.5); }
.btn--ember{ background:var(--grad-ember); color:#fff; box-shadow:0 18px 50px -16px rgba(207,74,38,.5); }
.btn--ember:hover{ transform:translateY(-3px); }
.btn--ghost{ border-color:var(--line); color:var(--bone); background:rgba(244,236,219,.02); }
.btn--ghost:hover{ border-color:var(--gold-2); color:var(--gold-2); transform:translateY(-3px); }
.btn--lg{ --pad:19px 34px; font-size:.95rem; }
.btn--block{ width:100%; }

.btn-play{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.14em;
  font-weight:600; font-size:.86rem; color:var(--bone);
  background:none; border:none; transition:color .25s;
}
.btn-play .ico{
  width:46px; height:46px; border-radius:999px; display:grid; place-items:center;
  background:var(--grad-gold); color:#1a1206; box-shadow:var(--glow-gold);
  transition:transform .25s var(--ease);
}
.btn-play:hover{ color:var(--gold-2); }
.btn-play:hover .ico{ transform:scale(1.08); }

/* small pill / tags */
.pill{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.16em;
  font-size:.7rem; font-weight:600;
  padding:7px 13px; border-radius:999px; border:1px solid var(--line);
  color:var(--bone-2); background:rgba(0,0,0,.25); backdrop-filter:blur(6px);
}
.pill .dot{ width:7px; height:7px; border-radius:999px; background:var(--gold-2); box-shadow:0 0 10px var(--gold-2); }
.pill .dot.is-live{ background:#46d27e; box-shadow:0 0 10px #46d27e; animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%,100%{opacity:1} 50%{opacity:.35} }

/* =====================================================================
   navigation
   ===================================================================== */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:18px var(--gut);
  transition:background .35s, backdrop-filter .35s, padding .35s, border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(11,10,8,.82); backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--line); padding-block:12px;
}
.nav__brand{ display:flex; align-items:center; gap:12px; z-index:2; }
.nav__brand img{ height:38px; width:auto; filter:drop-shadow(0 2px 10px rgba(0,0,0,.6)); transition:height .35s; }
.nav.is-stuck .nav__brand img{ height:32px; }
.nav__links{ display:flex; align-items:center; gap:30px; }
.nav__links a{
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.14em;
  font-size:.82rem; font-weight:500; color:var(--bone-2); position:relative; padding:4px 0;
  transition:color .25s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--grad-gold); transition:width .3s var(--ease);
}
.nav__links a:hover{ color:var(--bone); }
.nav__links a:hover::after{ width:100%; }
.nav__cta{ display:flex; align-items:center; gap:14px; }
.nav__burger{ display:none; }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:60; display:none;
  background:rgba(8,7,5,.96); backdrop-filter:blur(8px);
  flex-direction:column; padding:90px var(--gut) 40px;
}
.drawer.is-open{ display:flex; }
.drawer a{
  font-family:var(--f-display); text-transform:uppercase; font-size:2rem;
  padding:14px 0; border-bottom:1px solid var(--line-soft); color:var(--bone);
}
.drawer a .num{ font-family:var(--f-cond); font-size:.8rem; color:var(--gold-2); margin-right:14px; vertical-align:super; }
.drawer__close{ position:absolute; top:24px; right:var(--gut); background:none; border:none; color:var(--bone); width:40px; height:40px; }

/* =====================================================================
   hero
   ===================================================================== */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding-bottom:clamp(40px,7vw,90px); overflow:hidden; isolation:isolate;
}
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img,.hero__media video{ width:100%; height:100%; object-fit:cover; }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(11,10,8,.55) 0%, rgba(11,10,8,.2) 35%, rgba(11,10,8,.72) 78%, var(--ink) 100%),
    radial-gradient(120% 80% at 18% 90%, rgba(207,74,38,.22), transparent 60%),
    radial-gradient(100% 70% at 85% 12%, rgba(231,192,97,.16), transparent 55%);
}
.hero__inner{ position:relative; width:100%; }
.hero__top{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; margin-bottom:28px; }
.hero__logo{ width:min(640px,84vw); margin:0 0 26px -2px; filter:drop-shadow(0 8px 30px rgba(0,0,0,.7)); }
.hero h1{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); }
.hero__tagline{
  font-family:var(--f-display); text-transform:uppercase; line-height:.95;
  font-size:clamp(2.4rem,6.4vw,5rem); margin:0 0 18px;
}
.hero__tagline .script{ font-size:1.18em; }
.hero__sub{ max-width:50ch; font-size:clamp(1.05rem,1.5vw,1.28rem); color:var(--bone-2); margin:0 0 30px; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:16px 22px; align-items:center; }
.hero__meta{
  display:flex; flex-wrap:wrap; gap:10px 26px; margin-top:34px; padding-top:24px;
  border-top:1px solid var(--line-soft); align-items:center;
}
.hero__meta .label{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.2em; font-size:.72rem; color:var(--muted); }
.hero__meta strong{ font-family:var(--f-cond); font-weight:600; letter-spacing:.05em; color:var(--bone); }
.scroll-cue{
  position:absolute; left:50%; bottom:22px; transform:translateX(-50%); z-index:4;
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.3em; font-size:.62rem; color:var(--muted);
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.scroll-cue span{ width:1px; height:42px; background:linear-gradient(var(--gold-2),transparent); animation:cue 2s var(--ease) infinite; }
@keyframes cue{ 0%{transform:scaleY(.2);transform-origin:top;opacity:.3} 50%{transform:scaleY(1);opacity:1} 100%{transform:scaleY(.2);transform-origin:bottom;opacity:.3} }

/* =====================================================================
   marquee
   ===================================================================== */
.marquee{
  position:relative; z-index:3; overflow:hidden;
  border-block:1px solid var(--line); background:var(--ink-soft);
  padding-block:16px;
}
.marquee--gold{ background:var(--grad-gold); border-color:transparent; }
.marquee__track{ display:flex; gap:0; width:max-content; animation:scroll 38s linear infinite; }
.marquee--rev .marquee__track{ animation-direction:reverse; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__item{
  font-family:var(--f-display); text-transform:uppercase; font-size:clamp(1.1rem,2.4vw,1.7rem);
  letter-spacing:.02em; color:var(--bone); display:inline-flex; align-items:center; gap:34px; padding-right:34px;
}
.marquee--gold .marquee__item{ color:#1a1206; }
.marquee__item .star{ color:var(--gold-2); font-size:.7em; }
.marquee--gold .marquee__item .star{ color:#1a1206; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* =====================================================================
   experience / feature cards
   ===================================================================== */
.exp__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; }
.feature{
  position:relative; padding:30px 26px 28px; border-radius:var(--r-lg);
  background:linear-gradient(180deg,var(--panel-2),var(--panel)); border:1px solid var(--line);
  overflow:hidden; transition:transform .35s var(--ease), border-color .35s, box-shadow .35s;
}
.feature::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(120% 80% at 20% 0%, rgba(231,192,97,.10), transparent 60%);
  opacity:0; transition:opacity .35s;
}
.feature:hover{ transform:translateY(-6px); border-color:var(--gold); box-shadow:var(--shadow-sm); }
.feature:hover::after{ opacity:1; }
.feature__ico{
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center; margin-bottom:20px;
  background:linear-gradient(160deg,rgba(231,192,97,.18),rgba(207,74,38,.12)); border:1px solid var(--line);
  color:var(--gold-2);
}
.feature__ico svg{ width:26px; height:26px; }
.feature__n{ font-family:var(--f-cond); font-size:.72rem; letter-spacing:.2em; color:var(--muted-2); text-transform:uppercase; }
.feature h3{ font-family:var(--f-display); text-transform:uppercase; font-size:1.5rem; line-height:1; margin:.5rem 0 .55rem; }
.feature p{ margin:0; font-size:.95rem; color:var(--bone-2); }

/* feature flip cards (image front, copy on back) */
.flip-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
.flip{
  -webkit-appearance:none; appearance:none; border:0; margin:0; padding:0; background:none; text-align:left; font:inherit; color:var(--bone);
  display:block; width:100%; aspect-ratio:3/4; perspective:1500px; cursor:pointer; border-radius:var(--r-lg);
}
.flip:focus-visible{ outline:2px solid var(--gold-2); outline-offset:3px; }
.flip__inner{ position:relative; width:100%; height:100%; transition:transform .65s var(--ease); transform-style:preserve-3d; }
.flip.is-flipped .flip__inner{ transform:rotateY(180deg); }
.flip__face{
  position:absolute; inset:0; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line);
  -webkit-backface-visibility:hidden; backface-visibility:hidden; display:flex; flex-direction:column;
  box-shadow:var(--shadow-sm); transition:border-color .3s;
}
.flip:hover .flip__face{ border-color:var(--gold); }
.flip__front img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.flip:hover .flip__front img{ transform:scale(1.05); }
.flip__shade{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(11,10,8,.05) 0%, rgba(11,10,8,.1) 38%, rgba(11,10,8,.86) 100%); }
.flip__num{ position:relative; margin:18px 18px 0; font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.18em; font-size:.7rem; color:var(--gold-2); text-shadow:0 1px 8px rgba(0,0,0,.6); }
.flip__front-foot{ position:relative; margin-top:auto; padding:18px; display:flex; flex-direction:column; gap:12px; }
.flip__title{ font-family:var(--f-display); text-transform:uppercase; font-size:clamp(1.3rem,2vw,1.7rem); line-height:.95; text-shadow:0 2px 14px rgba(0,0,0,.6); }
.flip__cue{ display:inline-flex; align-items:center; gap:7px; font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.14em; font-size:.68rem; color:var(--bone-2); }
.flip__cue svg{ color:var(--gold-2); width:14px; height:14px; }
.flip__front .flip__cue{ align-self:flex-start; padding:7px 13px; border-radius:999px; background:rgba(0,0,0,.42); border:1px solid var(--line); backdrop-filter:blur(6px); }
.flip__back{ transform:rotateY(180deg); background:linear-gradient(180deg,var(--panel-2),var(--panel)); padding:26px 24px; }
.flip__back::after{ content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; background:radial-gradient(120% 70% at 20% 0%, rgba(231,192,97,.10), transparent 60%); }
.flip__back .feature__ico{ margin-bottom:16px; }
.flip__back .feature__n{ display:block; font-family:var(--f-cond); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-2); }
.flip__back h3{ font-family:var(--f-display); text-transform:uppercase; font-size:1.5rem; line-height:1; margin:.4rem 0 .6rem; }
.flip__back p{ margin:0; font-size:.96rem; color:var(--bone-2); position:relative; }
.flip__cue--back{ margin-top:auto; padding-top:18px; }
.flip-hint-global{ margin-top:26px; font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.18em; font-size:.74rem; }

/* =====================================================================
   production split
   ===================================================================== */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,64px); align-items:center; }
.split--rev{ direction:rtl; } .split--rev > *{ direction:ltr; }
.media-frame{
  position:relative; border-radius:var(--r-xl); overflow:hidden; border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.media-frame img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.media-frame--tall img{ aspect-ratio:3/4; }
.media-frame__tag{
  position:absolute; left:16px; bottom:16px; z-index:2;
}
.media-frame::after{ content:""; position:absolute; inset:0; background:linear-gradient(200deg,transparent 50%,rgba(11,10,8,.5)); pointer-events:none; }
.prod-list{ margin-top:30px; display:grid; gap:2px; }
.prod-list li{
  display:flex; align-items:center; gap:16px; padding:15px 4px; border-bottom:1px solid var(--line-soft);
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.04em; font-size:1.05rem; color:var(--bone);
}
.prod-list li .x{ color:var(--gold-2); font-size:1.1rem; }
.prod-list li span.sub{ font-family:var(--f-body); text-transform:none; letter-spacing:0; color:var(--muted); font-size:.86rem; margin-left:auto; }

/* =====================================================================
   promo video feature
   ===================================================================== */
.promo{ position:relative; overflow:hidden; }
.promo__bg{ position:absolute; inset:0; z-index:-2; }
.promo__bg video,.promo__bg img{ width:100%; height:100%; object-fit:cover; opacity:.28; }
.promo__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,var(--ink),rgba(11,10,8,.6),var(--ink)); }
.promo__wrap{ display:grid; grid-template-columns:1.4fr .9fr; gap:clamp(30px,5vw,70px); align-items:center; }
.promo__player{
  position:relative; border-radius:var(--r-xl); overflow:hidden; border:1px solid var(--line);
  box-shadow:var(--shadow); aspect-ratio:16/9; background:#000;
}
.promo__player img{ width:100%; height:100%; object-fit:cover; }
.promo__player .play-overlay{
  position:absolute; inset:0; display:grid; place-items:center;
  background:radial-gradient(60% 60% at 50% 50%, rgba(0,0,0,.15), rgba(0,0,0,.5));
  transition:background .3s;
}
.promo__player:hover .play-overlay{ background:radial-gradient(60% 60% at 50% 50%, rgba(0,0,0,0), rgba(0,0,0,.35)); }
.play-overlay .big{
  width:84px; height:84px; border-radius:999px; display:grid; place-items:center;
  background:var(--grad-gold); color:#1a1206; box-shadow:var(--glow-gold); transition:transform .3s var(--ease);
}
.promo__player:hover .big{ transform:scale(1.1); }
.phone{
  position:relative; width:min(260px,70%); margin-inline:auto;
  border-radius:34px; padding:9px; background:linear-gradient(160deg,#2a2118,#0c0a07);
  border:1px solid var(--line); box-shadow:var(--shadow);
}
.phone video{ width:100%; border-radius:26px; aspect-ratio:9/19.5; object-fit:cover; background:#000; }
.phone__notch{ position:absolute; top:18px; left:50%; transform:translateX(-50%); width:90px; height:7px; border-radius:99px; background:rgba(0,0,0,.6); z-index:2; }

/* =====================================================================
   stats band
   ===================================================================== */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.stat{ padding:8px 6px; border-left:1px solid var(--line); }
.stat:first-child{ border-left:none; }
.stat .num{ font-family:var(--f-display); font-size:clamp(2.6rem,5vw,3.8rem); line-height:.9; color:var(--gold-2); }
.stat .num small{ font-size:.42em; color:var(--bone); vertical-align:super; margin-left:2px; }
.stat .cap{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.16em; font-size:.78rem; color:var(--bone-2); margin-top:10px; }

/* =====================================================================
   tour
   ===================================================================== */
.tour__head{ display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-end; gap:24px; }
.tour__list{ margin-top:46px; border-top:1px solid var(--line); }
.tour-row{
  display:grid; grid-template-columns:130px 1fr auto auto; gap:24px; align-items:center;
  padding:22px 8px; border-bottom:1px solid var(--line-soft);
  transition:background .25s, padding .25s; position:relative;
}
.tour-row:hover{ background:linear-gradient(90deg,rgba(231,192,97,.06),transparent); }
.tour-row.is-feat{ background:linear-gradient(90deg,rgba(231,192,97,.10),transparent); }
.tour-row__date{ font-family:var(--f-display); text-transform:uppercase; line-height:.95; }
.tour-row__date .d{ font-size:1.7rem; color:var(--bone); }
.tour-row__date .m{ font-size:.8rem; letter-spacing:.18em; color:var(--gold-2); font-family:var(--f-cond); display:block; }
.tour-row__venue .v{ font-family:var(--f-cond); font-weight:600; font-size:1.18rem; text-transform:uppercase; letter-spacing:.02em; }
.tour-row__venue .c{ color:var(--muted); font-size:.9rem; }
.tour-row__venue .feat-tag{ display:inline-block; margin-left:10px; font-family:var(--f-cond); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:#1a1206; background:var(--grad-gold); padding:3px 8px; border-radius:6px; vertical-align:middle; }
.tour-row__status{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.14em; font-size:.74rem; display:inline-flex; align-items:center; gap:7px; }
.tour-row__status .dot{ width:7px; height:7px; border-radius:99px; }
.s-onsale{ color:#7ee0a3; } .s-onsale .dot{ background:#46d27e; box-shadow:0 0 8px #46d27e; }
.s-presale{ color:var(--gold-2); } .s-presale .dot{ background:var(--gold-2); box-shadow:0 0 8px var(--gold-2); }
.s-soon{ color:var(--bone-2); } .s-soon .dot{ background:var(--muted); }
.s-soldout{ color:var(--ember-2); } .s-soldout .dot{ background:var(--ember-2); }
.tour-row__cta .btn{ --pad:11px 20px; font-size:.74rem; }
.tour-row__cta .sold{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.14em; font-size:.74rem; color:var(--muted-2); padding:11px 20px; display:inline-block; }
.tour__note{ margin-top:28px; display:flex; flex-wrap:wrap; gap:16px 24px; align-items:center; justify-content:space-between; }
.tour__note p{ margin:0; color:var(--muted); font-size:.88rem; }

/* =====================================================================
   merch
   ===================================================================== */
.merch__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:50px; }
.product{
  border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  background:var(--panel); transition:transform .3s var(--ease), border-color .3s, box-shadow .3s;
  display:flex; flex-direction:column;
}
.product:hover{ transform:translateY(-6px); border-color:var(--gold); box-shadow:var(--shadow-sm); }
.product__img{
  position:relative; aspect-ratio:1/1; display:grid; place-items:center; padding:24px; overflow:hidden;
}
.product__img img{ width:74%; height:auto; object-fit:contain; filter:drop-shadow(0 10px 24px rgba(0,0,0,.55)); transition:transform .4s var(--ease); }
.product:hover .product__img img{ transform:scale(1.06) rotate(-1deg); }
.product__img::before{ content:""; position:absolute; inset:0; background:radial-gradient(80% 70% at 50% 30%, rgba(255,255,255,.10), transparent 70%); }
.product__img.bg-black{ background:radial-gradient(120% 100% at 50% 0,#241d14,#0c0a07); }
.product__img.bg-gold{ background:radial-gradient(120% 100% at 50% 0,#caa044,#7a5a1d); }
.product__img.bg-ember{ background:radial-gradient(120% 100% at 50% 0,#c44a29,#6e2412); }
.product__img.bg-bone{ background:radial-gradient(120% 100% at 50% 0,#e9e0cc,#a99c80); }
.product__tag{ position:absolute; top:12px; left:12px; z-index:2; font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.14em; font-size:.6rem; padding:5px 9px; border-radius:7px; background:rgba(0,0,0,.55); color:var(--bone); border:1px solid var(--line); }
.product__tag.is-hot{ background:var(--grad-ember); color:#fff; border-color:transparent; }
.product__body{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:4px; flex:1; }
.product__name{ font-family:var(--f-cond); font-weight:600; text-transform:uppercase; letter-spacing:.03em; font-size:1.02rem; }
.product__sub{ color:var(--muted); font-size:.82rem; }
.product__row{ margin-top:auto; padding-top:14px; display:flex; align-items:center; justify-content:space-between; }
.product__price{ font-family:var(--f-display); font-size:1.4rem; color:var(--gold-2); }
.product__add{
  border:1px solid var(--line); background:rgba(244,236,219,.03); color:var(--bone);
  border-radius:999px; padding:9px 16px; font-family:var(--f-cond); text-transform:uppercase;
  letter-spacing:.12em; font-size:.72rem; transition:.25s;
}
.product__add:hover{ background:var(--grad-gold); color:#1a1206; border-color:transparent; }
.product__add[disabled]{ opacity:.4; cursor:not-allowed; }
.merch__foot{ margin-top:42px; text-align:center; }

/* =====================================================================
   booking / for arenas
   ===================================================================== */
.book{ position:relative; overflow:hidden; }
.book__bg{ position:absolute; inset:0; z-index:-2; }
.book__bg img{ width:100%; height:100%; object-fit:cover; opacity:.16; }
.book__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,var(--ink),rgba(11,10,8,.82)); }
.book__wrap{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:start; }
.book__points{ margin-top:30px; display:grid; gap:18px; }
.book__point{ display:flex; gap:16px; align-items:flex-start; }
.book__point .ico{ flex:none; width:42px; height:42px; border-radius:11px; display:grid; place-items:center; background:linear-gradient(160deg,rgba(231,192,97,.18),rgba(207,74,38,.12)); border:1px solid var(--line); color:var(--gold-2); }
.book__point .ico svg{ width:21px; height:21px; }
.book__point h4{ margin:0 0 3px; font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.05em; font-size:1.05rem; }
.book__point p{ margin:0; color:var(--bone-2); font-size:.92rem; }

.form-card{
  background:linear-gradient(180deg,var(--panel-2),var(--panel)); border:1px solid var(--line);
  border-radius:var(--r-xl); padding:clamp(24px,3vw,38px); box-shadow:var(--shadow);
}
.form-card h3{ font-family:var(--f-display); text-transform:uppercase; font-size:1.7rem; margin:0 0 4px; }
.form-card .sub{ color:var(--muted); font-size:.9rem; margin-bottom:22px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.12em; font-size:.7rem; color:var(--bone-2); margin-bottom:7px; }
.field input,.field select,.field textarea{
  width:100%; padding:13px 15px; border-radius:12px; background:rgba(0,0,0,.35);
  border:1px solid var(--line); color:var(--bone); font-family:var(--f-body); font-size:.95rem;
  transition:border-color .25s, box-shadow .25s;
}
.field input::placeholder,.field textarea::placeholder{ color:var(--muted-2); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold-2); box-shadow:0 0 0 3px rgba(231,192,97,.14); }
.field textarea{ resize:vertical; min-height:96px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-note{ font-size:.78rem; color:var(--muted-2); margin-top:12px; text-align:center; }
.hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; overflow:hidden; }
.form-success{
  display:none; text-align:center; padding:30px 10px;
}
.form-success.is-on{ display:block; }
.form-success .ok{ width:62px; height:62px; border-radius:999px; display:grid; place-items:center; margin:0 auto 16px; background:var(--grad-gold); color:#1a1206; }
.form-success h3{ margin:0 0 8px; }

/* =====================================================================
   footer
   ===================================================================== */
.footer{ position:relative; z-index:3; border-top:1px solid var(--line); background:var(--ink-soft); padding-block:64px 30px; }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.footer__brand img{ height:54px; margin-bottom:18px; }
.footer__brand p{ color:var(--muted); max-width:34ch; font-size:.9rem; }
.footer__oyd{ display:inline-flex; flex-direction:column; gap:6px; margin-top:22px; }
.footer__oyd span{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.22em; font-size:.62rem; color:var(--muted-2); }
.footer__oyd img{ height:30px; width:auto; opacity:.92; transition:opacity .25s, transform .25s; }
.footer__oyd:hover img{ opacity:1; transform:translateY(-2px); }
.footer h5{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.16em; font-size:.74rem; color:var(--gold-2); margin:6px 0 16px; }
.footer__col a{ display:block; color:var(--bone-2); padding:6px 0; font-size:.92rem; transition:color .2s; }
.footer__col a:hover{ color:var(--gold-2); }
.socials{ display:flex; gap:12px; margin-top:8px; }
.socials a{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; border:1px solid var(--line); color:var(--bone-2); transition:.25s; }
.socials a:hover{ color:var(--gold-2); border-color:var(--gold-2); transform:translateY(-3px); }
.socials svg{ width:18px; height:18px; }
.footer__bottom{ margin-top:50px; padding-top:24px; border-top:1px solid var(--line-soft); display:flex; flex-wrap:wrap; gap:14px 24px; justify-content:space-between; align-items:center; }
.footer__bottom p{ margin:0; color:var(--muted-2); font-size:.82rem; }
.footer__bottom a{ color:var(--gold-2); }

/* =====================================================================
   video modal
   ===================================================================== */
.modal{ position:fixed; inset:0; z-index:90; display:none; place-items:center; padding:24px; background:rgba(5,4,3,.9); backdrop-filter:blur(8px); }
.modal.is-open{ display:grid; }
.modal__inner{ width:min(1040px,100%); aspect-ratio:16/9; border-radius:16px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); background:#000; }
.modal__inner video{ width:100%; height:100%; }
.modal__close{ position:absolute; top:20px; right:24px; width:46px; height:46px; border-radius:999px; border:1px solid var(--line); background:rgba(0,0,0,.4); color:var(--bone); display:grid; place-items:center; transition:.25s; }
.modal__close:hover{ border-color:var(--gold-2); color:var(--gold-2); }

/* =====================================================================
   reveal animation
   ===================================================================== */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s } .reveal[data-d="2"]{ transition-delay:.16s }
.reveal[data-d="3"]{ transition-delay:.24s } .reveal[data-d="4"]{ transition-delay:.32s }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; } .grain{ animation:none; } }

/* =====================================================================
   color-sample badge — only renders on the alternate-palette preview
   pages (they include the .theme-badge markup; the live main does not).
   Default swatches = gold + ember; theme overrides recolor them.
   ===================================================================== */
.theme-badge{
  position:fixed; left:50%; bottom:22px; transform:translateX(-50%); z-index:80;
  display:flex; align-items:center; gap:12px; padding:10px 16px; border-radius:999px;
  background:rgba(11,10,8,.86); backdrop-filter:blur(10px); border:1px solid var(--line);
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:.14em; font-size:.72rem; color:var(--bone-2);
  box-shadow:var(--shadow-sm);
}
.theme-badge .sw{ display:inline-flex; gap:5px; }
.theme-badge .sw i{ width:13px; height:13px; border-radius:999px; display:block; }
.theme-badge .sw .g{ background:var(--grad-gold); }
.theme-badge .sw .e{ background:var(--grad-ember); }
.theme-badge a{ color:var(--gold-2); }
@media (max-width:620px){ .theme-badge{ font-size:.64rem; padding:8px 12px; } }

/* =====================================================================
   responsive
   ===================================================================== */
@media (max-width:1080px){
  .exp__grid{ grid-template-columns:repeat(2,1fr); }
  .flip-grid{ grid-template-columns:repeat(2,1fr); }
  .merch__grid{ grid-template-columns:repeat(3,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); gap:30px 20px; }
  .stat:nth-child(3){ border-left:none; }
}
@media (max-width:900px){
  .nav__links,.nav__cta .btn{ display:none; }
  .nav__burger{ display:grid; place-items:center; width:46px; height:46px; border-radius:11px; border:1px solid var(--line); background:rgba(0,0,0,.3); color:var(--bone); }
  .split,.promo__wrap,.book__wrap{ grid-template-columns:1fr; }
  .split--rev{ direction:ltr; }
  .promo__wrap .phone{ display:none; }
  .scroll-cue{ display:none; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .tour-row{ grid-template-columns:84px 1fr auto; }
  .tour-row__status{ display:none; }
}
@media (max-width:620px){
  .merch__grid{ grid-template-columns:repeat(2,1fr); }
  .exp__grid{ grid-template-columns:1fr; }
  /* one big image-forward card per row on phones — fronts read large and
     the flipped copy has room to breathe */
  .flip-grid{ grid-template-columns:1fr; gap:16px; }
  .flip{ aspect-ratio:4/5; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:1fr 1fr; }
  .form-row{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; gap:30px; }
  .tour-row{ grid-template-columns:70px 1fr; gap:14px; row-gap:6px; }
  .tour-row__cta{ grid-column:2; justify-self:start; }
  .hero__meta{ gap:8px 18px; }
}
