html,body.novo-body{height:100%;margin:0}
body.novo-body{background:#0b0807;color:#fff;overflow-x:hidden}

/* overlay nav sits above slides */
.nav.nav--overlay{
  position:fixed;inset:0 0 auto 0;
  background:linear-gradient(180deg,rgba(11,8,7,.6) 0%,rgba(11,8,7,0) 100%);
  backdrop-filter:none;border-bottom:0;
}
.nav.nav--overlay .brand__text,.nav.nav--overlay .nav__links a{color:#fff}
.nav.nav--overlay .nav__links a:hover{background:rgba(255,255,255,.12)}
.nav.nav--overlay .nav__cta{background:var(--red);color:#fff !important}
.nav.nav--overlay .nav__cta:hover{background:var(--red-d) !important}
.nav.nav--overlay .nav__toggle span{background:#fff}
.nav__links .is-current{background:rgba(255,255,255,.14)}

/* snap container */
.slides{
  height:100vh;height:100dvh;
  overflow-y:auto;overflow-x:hidden;
  scroll-snap-type:y mandatory;
  scroll-behavior:smooth;
}

.slide{
  position:relative;
  height:100vh;height:100dvh;
  scroll-snap-align:start;scroll-snap-stop:always;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.slide__bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  transform:scale(1.04);transition:transform 1.2s ease-out;
}
.slide--in .slide__bg{transform:scale(1)}
.slide__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,8,7,.55) 0%,rgba(11,8,7,.35) 40%,rgba(11,8,7,.75) 100%);
}
.slide__bg--placeholder{
  background:
    radial-gradient(1200px 700px at 80% 20%,rgba(228,161,27,.25),transparent 60%),
    radial-gradient(900px 500px at 10% 90%,rgba(184,20,26,.35),transparent 60%),
    #1a0e0a;
}
.slide__bg--placeholder::after{background:linear-gradient(180deg,rgba(11,8,7,.2),rgba(11,8,7,.6))}
/* pass svg fills and uses its own gradient bg — lighter overlay so text and card both read */
.slide__bg--solid{background-color:#2a0607}
.slide__bg--solid::after{background:linear-gradient(90deg,rgba(11,8,7,.82) 0%,rgba(11,8,7,.45) 55%,rgba(11,8,7,.15) 100%)}

.slide__content{
  position:relative;z-index:2;
  max-width:900px;padding:0 24px;
  text-align:center;
  transform:translateY(30px);opacity:0;
  transition:opacity .8s ease-out .15s,transform .8s ease-out .15s;
}
.slide--in .slide__content{opacity:1;transform:none}

.slide__kicker{
  text-transform:uppercase;letter-spacing:.3em;
  font-size:13px;font-weight:700;color:var(--gold,#e4a11b);
  margin:0 0 18px;
}
.slide h1{
  font-family:"Bebas Neue",sans-serif;
  font-size:clamp(52px,10vw,140px);line-height:.95;letter-spacing:.02em;
  margin:0 0 22px;color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.4);
}
.slide__sub{
  font-family:"Bebas Neue",sans-serif;font-size:clamp(22px,2.6vw,32px);
  letter-spacing:.06em;margin:-8px 0 20px;color:var(--gold,#e4a11b);line-height:1.15;
}
.slide__lead{
  font-size:clamp(17px,2vw,22px);max-width:640px;margin:0 auto 30px;
  color:rgba(255,255,255,.88);line-height:1.5;
}
.slide--left .slide__lead,.slide--right .slide__lead{margin-left:0;margin-right:0}
.mystery{
  display:inline-block;font-family:"Bebas Neue",sans-serif;
  font-size:clamp(40px,7vw,90px);letter-spacing:.3em;
  color:rgba(255,255,255,.4);margin-bottom:12px;line-height:1;
  animation:blink 2s steps(3,end) infinite;
}
@keyframes blink{
  0%,100%{opacity:.25}
  50%{opacity:.85}
}
.slide__cta{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}
.slide .btn--primary{background:var(--red);color:#fff}
.slide .btn--ghost{background:transparent;color:#fff;border-color:#fff}
.slide .btn--ghost:hover{background:#fff;color:var(--ink)}

/* left/right alignment variants */
.slide--left .slide__content{text-align:left;margin-right:auto;margin-left:max(6vw,24px)}
.slide--right .slide__content{text-align:right;margin-left:auto;margin-right:max(6vw,24px)}
.slide--center .slide__content{text-align:center;margin:0 auto}
.slide--dark .slide__bg::after{background:linear-gradient(180deg,rgba(11,8,7,.75),rgba(11,8,7,.92))}

/* accent word */
.slide h1 .accent{color:var(--red);font-style:italic}
.slide h1 .mask{
  background:rgba(255,255,255,.08);
  padding:4px 20px;border:1px dashed rgba(255,255,255,.3);
  font-size:.55em;letter-spacing:.1em;
}

/* price tag on hero */
.slide__price{
  display:inline-block;background:var(--red);color:#fff;
  font-family:"Bebas Neue",sans-serif;letter-spacing:.06em;
  padding:10px 22px;border-radius:999px;font-size:26px;margin-bottom:18px;
  box-shadow:0 10px 40px rgba(184,20,26,.55);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{transform:scale(1);box-shadow:0 10px 40px rgba(184,20,26,.5)}
  50%{transform:scale(1.04);box-shadow:0 14px 50px rgba(184,20,26,.7)}
}

/* badges row */
.slide__badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px;justify-content:inherit}
.slide--center .slide__badges{justify-content:center}
.slide--right .slide__badges{justify-content:flex-end}
.badge{
  display:inline-block;padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.12);color:#fff;
  font-size:13px;font-weight:700;letter-spacing:.04em;
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
}
.badge--red{background:var(--red);border-color:var(--red)}
.badge--ok{background:#1f7a34;border-color:#1f7a34}

/* slide counter */
.counter{
  position:absolute;bottom:24px;right:32px;z-index:3;
  font-family:"Bebas Neue",sans-serif;font-size:18px;letter-spacing:.15em;
  color:rgba(255,255,255,.55);
}
.counter span{color:rgba(255,255,255,.35)}

/* intro special */
.slide--intro h1{font-size:clamp(58px,11vw,160px)}

/* dots */
.dots{
  position:fixed;right:22px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:12px;z-index:20;
}
.dots__d{
  width:11px;height:11px;border-radius:50%;
  background:rgba(255,255,255,.35);border:2px solid transparent;
  transition:.2s;display:block;
}
.dots__d:hover{background:#fff}
.dots__d.is-active{background:var(--red);border-color:#fff;transform:scale(1.25)}

/* scroll hint */
.scroll-hint{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#fff;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(6px);z-index:20;
  transition:opacity .3s;
  animation:bounce 2s infinite;
}
.scroll-hint.is-hidden{opacity:0;pointer-events:none}
@keyframes bounce{
  0%,100%{transform:translate(-50%,0)}
  50%{transform:translate(-50%,6px)}
}

@media (max-width:860px){
  .dots{right:12px;gap:10px}
  .dots__d{width:9px;height:9px}
  .slide--left .slide__content,.slide--right .slide__content{text-align:center;margin:0 auto}
}
@media (max-height:600px){
  .slide h1{font-size:clamp(40px,8vw,80px)}
}
