
:root{
  --c-primary:#a8341a;
  --c-primary-hover:#8a2810;
  --c-ink:#1d1d1d;
  --c-ink-soft:#2d2d2d;
  --c-text:#4c4c4c;
  --c-bg:#ffffff;
  --c-bg-soft:#f9f9f9;
  --c-border:#f1f1f1;
  --c-white:#ffffff;
  --c-dim:rgba(255,255,255,.72);
  --c-dim-2:rgba(255,255,255,.55);

  --f-head:'Oswald', sans-serif;
  --f-body:'Open Sans', sans-serif;
  --f-script:'Covered By Your Grace', cursive;

  --r:0px;
  --pad-x:clamp(20px, 4vw, 60px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  color:var(--c-text);
  background:var(--c-bg);
  line-height:1.7;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}

.btn{
  display:inline-block;
  padding:15px 28px;
  font-family:var(--f-head);
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:13px;
  border-radius:var(--r);
  transition:transform .18s ease, background .2s ease, color .2s ease, border-color .2s ease;
  will-change:transform;
}
.btn:hover{transform:scale(.96)}

.btn--ghost{
  color:#fff;
  border:1px solid rgba(255,255,255,.85);
  background:transparent;
}
.btn--ghost:hover{background:#fff;color:var(--c-ink)}

.topbar{
  position:absolute;
  inset:0 0 auto 0;
  z-index:50;
  padding:22px var(--pad-x);
}
.topbar__wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.topbar__brand{display:inline-block}
.topbar__logo{
  width:auto;
  height:48px;
  max-width:170px;
  object-fit:contain;
  filter:brightness(0) invert(1) drop-shadow(0 2px 8px rgba(0,0,0,.4));
}

.topbar__burger{
  width:46px;
  height:46px;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r);
  transition:background .2s;
}
.topbar__burger:hover{background:rgba(0,0,0,.55)}
.topbar__burger span{
  display:block;
  width:22px;
  height:2px;
  background:#fff;
  transition:transform .25s, opacity .2s;
}
.topbar__burger.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.topbar__burger.is-active span:nth-child(2){opacity:0}
.topbar__burger.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.topbar__drop{
  position:absolute;
  left:0;right:0;
  top:100%;
  background:rgba(15,15,15,.96);
  backdrop-filter:blur(6px);
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease;
  z-index:51;
}
.topbar__drop.is-open{max-height:540px}
.topbar__list{
  padding:24px var(--pad-x) 32px;
  text-align:center;
}
.topbar__list li{padding:10px 0}
.topbar__list a{
  font-family:var(--f-head);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:13px;
  color:#fff;
  padding:6px 4px;
  display:inline-block;
  border-bottom:1px solid transparent;
  transition:border-color .2s, color .2s;
}
.topbar__list a:hover{border-color:var(--c-primary);color:var(--c-primary)}

.hero{
  position:relative;
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  align-items:center;
  justify-content:center;
  isolation:isolate;
  padding:120px var(--pad-x) 60px;
}
.hero__bg-img{
  position:absolute;
  inset:0;
  z-index:-2;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  clip-path:inset(0);
}
.hero__veil{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.35) 50%, rgba(0,0,0,.7) 100%);
}

.hero__inner{
  width:100%;
  max-width:760px;
  text-align:center;
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:26px;
}
.hero__line{
  display:block;
  width:min(340px, 70%);
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.7), transparent);
}
.hero__brand{display:flex;flex-direction:column;align-items:center;gap:14px}
.hero__logo{
  width:auto;
  height:clamp(80px, 14vw, 150px);
  max-width:340px;
  object-fit:contain;
  filter:brightness(0) invert(1) drop-shadow(0 6px 24px rgba(0,0,0,.55));
}
.hero__tag{
  margin:0;
  font-family:var(--f-script);
  font-size:clamp(18px, 2.4vw, 26px);
  color:rgba(255,255,255,.92);
  letter-spacing:.04em;
}
.hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
  margin-top:6px;
}
.hero__age{
  margin:8px 0 0;
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
}

.foot{
  position:relative;
  background:#0e0e0e;
  color:#fff;
  padding:80px var(--pad-x) 0;
  isolation:isolate;
  overflow:hidden;
}
.foot__bg{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(circle at 10% 10%, rgba(168,52,26,.18), transparent 40%),
    radial-gradient(circle at 90% 90%, rgba(168,52,26,.12), transparent 45%),
    #0e0e0e;
}
.foot__bg::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 8% 30%, rgba(255,255,255,.04) 0 60px, transparent 61px),
    radial-gradient(circle at 92% 70%, rgba(255,255,255,.04) 0 50px, transparent 51px);
  background-size:600px 600px;
  opacity:.6;
}

.foot__grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:40px;
  max-width:1280px;
  margin:0 auto;
  padding-bottom:60px;
}
.foot__col--brand{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.foot__logo{
  width:auto;
  height:64px;
  max-width:180px;
  object-fit:contain;
  filter:brightness(0) invert(1);
}
.foot__tag{
  margin:0;
  font-family:var(--f-head);
  font-weight:300;
  letter-spacing:.22em;
  font-size:11px;
  line-height:1.9;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.foot__tag em{
  font-family:var(--f-script);
  font-style:normal;
  font-size:22px;
  letter-spacing:.02em;
  color:#fff;
  text-transform:none;
  display:inline-block;
  margin:2px 0;
}

.foot__h{
  font-family:var(--f-head);
  font-weight:500;
  font-size:15px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#fff;
  margin:0 0 18px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.foot__links li{margin-bottom:10px}
.foot__links a{
  color:rgba(255,255,255,.7);
  font-size:14px;
  transition:color .2s, padding-left .2s;
}
.foot__links a:hover{color:var(--c-primary);padding-left:6px}

.foot__p{
  margin:0 0 16px;
  color:rgba(255,255,255,.6);
  font-size:13px;
  line-height:1.7;
}
.foot__mail{
  display:inline-block;
  font-family:var(--f-head);
  letter-spacing:.1em;
  font-size:14px;
  color:#fff;
  border-bottom:1px solid var(--c-primary);
  padding:2px 0;
  margin-bottom:18px;
}
.foot__mail:hover{color:var(--c-primary)}
.foot__age{
  margin:14px 0 0;
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.24em;
  color:var(--c-primary);
}

.foot__copy{
  border-top:1px solid rgba(255,255,255,.08);
  padding:22px 0;
  text-align:center;
}
.foot__copy p{
  margin:0;
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.22em;
  color:rgba(255,255,255,.45);
  text-transform:uppercase;
}

.alertbar{
  position:relative;
  z-index:25;
  background:linear-gradient(90deg, #7a1010 0%, #b51e1e 50%, #7a1010 100%);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.alertbar__wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  padding:9px var(--pad-x);
  flex-wrap:wrap;
}
.alertbar__pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;height:24px;
  background:#fff;
  color:#7a1010;
  font-family:var(--f-head);
  font-weight:700;
  font-size:11px;
  letter-spacing:.05em;
  flex-shrink:0;
}
.alertbar__msg{
  margin:0;
  font-family:var(--f-head);
  font-weight:400;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:center;
  line-height:1.5;
}

.hero{min-height:calc(100vh - 42px); min-height:calc(100dvh - 42px)}

.foot__regs{
  max-width:1280px;
  margin:0 auto;
  padding:36px 0 30px;
  border-top:1px solid rgba(255,255,255,.08);
}
.foot__regs-h{
  margin:0 0 22px;
  font-family:var(--f-head);
  font-weight:400;
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(255,255,255,.45);
  text-align:center;
}
.foot__regs-row{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:30px 50px;
}
.foot__reg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:38px;
  opacity:.6;
  transition:opacity .25s, transform .25s;
}
.foot__reg:hover{opacity:1;transform:translateY(-2px)}
.foot__reg img{
  max-height:42px;
  max-width:160px;
  width:auto;
  filter:brightness(0) invert(1);
}

.foot__notice{
  max-width:1280px;
  margin:0 auto;
  padding:32px 0 38px;
  border-top:1px solid rgba(255,255,255,.08);
}
.foot__notice-wrap{
  max-width:780px;
  margin:0 auto;
  text-align:center;
}
.foot__notice-badge{
  display:inline-block;
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--c-primary);
  padding:6px 14px;
  border:1px solid rgba(168,52,26,.5);
  margin-bottom:18px;
}
.foot__notice-lead{
  margin:0 0 20px;
  font-size:14px;
  line-height:1.75;
  color:rgba(255,255,255,.78);
}
.foot__notice-list{
  text-align:left;
  display:inline-block;
  max-width:680px;
}
.foot__notice-list li{
  position:relative;
  padding:7px 0 7px 24px;
  font-size:13px;
  color:rgba(255,255,255,.62);
  line-height:1.6;
}
.foot__notice-list li::before{
  content:"";
  position:absolute;
  left:0;top:14px;
  width:10px;height:1px;
  background:var(--c-primary);
}
.foot__notice-list strong{color:#fff;font-weight:600}

.agegate{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  animation:agefade .35s ease;
}
.agegate[hidden]{display:none !important}
.agegate.is-leaving{
  animation:agefadeOut .25s ease forwards;
  pointer-events:none;
}
@keyframes agefade{from{opacity:0}to{opacity:1}}
@keyframes agefadeOut{from{opacity:1}to{opacity:0}}
.agegate__veil{
  position:absolute;inset:0;
  background:rgba(8,4,2,.92);
  backdrop-filter:blur(8px);
}
.agegate__card{
  position:relative;
  background:#171010;
  color:#fff;
  border:1px solid rgba(168,52,26,.4);
  max-width:480px;
  width:100%;
  padding:42px 32px 36px;
  text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
  animation:agepop .4s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes agepop{from{transform:translateY(20px) scale(.95);opacity:0}to{transform:none;opacity:1}}
.agegate__badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:64px;height:64px;
  background:var(--c-primary);
  color:#fff;
  font-family:var(--f-head);
  font-weight:700;
  font-size:22px;
  letter-spacing:.04em;
  margin-bottom:18px;
}
.agegate__title{
  margin:0 0 14px;
  font-family:var(--f-head);
  font-weight:500;
  font-size:24px;
  letter-spacing:.06em;
  text-transform:uppercase;
  line-height:1.25;
}
.agegate__copy{
  margin:0 0 12px;
  font-size:14px;
  line-height:1.65;
  color:rgba(255,255,255,.78);
}
.agegate__copy--mini{
  font-size:12px;
  color:rgba(255,255,255,.55);
  margin-bottom:24px;
}
.agegate__yes{
  display:block;
  width:100%;
  padding:16px 24px;
  background:var(--c-primary);
  color:#fff;
  font-family:var(--f-head);
  font-weight:500;
  font-size:14px;
  letter-spacing:.18em;
  text-transform:uppercase;
  transition:background .2s, transform .15s;
}
.agegate__yes:hover{background:var(--c-primary-hover);transform:scale(.98)}
.agegate__under{
  margin:18px 0 0;
  font-size:12px;
  color:rgba(255,255,255,.4);
  letter-spacing:.04em;
}
.agegate__under a{
  color:rgba(255,255,255,.7);
  text-decoration:underline;
  text-underline-offset:3px;
}

.cookies{
  position:fixed;
  left:16px;right:16px;
  bottom:16px;
  z-index:9000;
  background:#141414;
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 50px rgba(0,0,0,.5);
  transform:translateY(20px);
  opacity:0;
  transition:transform .3s ease, opacity .3s ease;
}
.cookies.is-up{transform:translateY(0);opacity:1}
.cookies__wrap{
  display:flex;
  align-items:center;
  gap:24px;
  padding:18px 22px;
  flex-wrap:wrap;
}
.cookies__text{flex:1 1 320px}
.cookies__title{
  display:block;
  font-family:var(--f-head);
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:4px;
}
.cookies__text p{
  margin:0;
  font-size:13px;
  line-height:1.6;
  color:rgba(255,255,255,.68);
}
.cookies__text a{color:var(--c-primary);text-decoration:underline;text-underline-offset:3px}
.cookies__btns{display:flex;gap:10px;flex-shrink:0}
.cookies__btn{
  padding:11px 20px;
  font-family:var(--f-head);
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  transition:background .2s, color .2s, border-color .2s;
}
.cookies__btn--ghost{
  background:transparent;
  color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.2);
}
.cookies__btn--ghost:hover{color:#fff;border-color:#fff}
.cookies__btn--solid{
  background:var(--c-primary);
  color:#fff;
}
.cookies__btn--solid:hover{background:var(--c-primary-hover)}

.kicker{
  display:inline-block;
  margin:0 0 14px;
  font-family:var(--f-script);
  font-size:22px;
  color:var(--c-primary);
  letter-spacing:.02em;
}
.kicker--light{color:#ffb88c}
.h-2{
  margin:0 0 22px;
  font-family:var(--f-head);
  font-weight:500;
  font-size:clamp(28px, 3.4vw, 42px);
  line-height:1.18;
  letter-spacing:.02em;
  color:var(--c-ink-soft);
  text-transform:uppercase;
}
.h-2--center{text-align:center}
.h-2--light{color:#fff}
.h-2__accent{color:var(--c-primary);display:inline-block}

.btn--solid{
  background:var(--c-primary);
  color:#fff;
  border:1px solid var(--c-primary);
}
.btn--solid:hover{background:var(--c-primary-hover);border-color:var(--c-primary-hover)}
.btn--text{
  color:var(--c-primary);
  font-family:var(--f-head);
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:15px 4px;
  border-bottom:1px solid transparent;
  display:inline-block;
}
.btn--text:hover{border-color:var(--c-primary);transform:none}

.about{
  position:relative;
  padding:90px var(--pad-x);
  background:#fff;
  isolation:isolate;
}
.about__bg{
  position:absolute;inset:0;z-index:-1;
  background-image:
    radial-gradient(circle at 92% 10%, rgba(168,52,26,.06) 0 220px, transparent 221px),
    radial-gradient(circle at 6% 90%, rgba(168,52,26,.04) 0 180px, transparent 181px);
}
.about__inner{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:5fr 6fr;
  gap:60px;
  align-items:center;
}
.about__media{position:relative}
.about__shot{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  display:block;
  background:#1a0805;
}
.about__chip{
  position:absolute;
  bottom:18px;left:18px;
  background:#fff;
  color:var(--c-ink);
  padding:8px 16px;
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
}

.about__copy p{
  margin:0 0 16px;
  font-size:15px;
  line-height:1.75;
  color:var(--c-text);
}
.about__signoff{
  font-style:italic;
  color:var(--c-ink-soft);
  border-left:2px solid var(--c-primary);
  padding-left:16px;
  margin-top:24px !important;
}

.why{
  padding:90px var(--pad-x);
  background:#f6f3ef;
}
.why__head{
  max-width:760px;
  margin:0 auto 50px;
  text-align:center;
}
.why__grid{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.why__card{
  background:#fff;
  padding:36px 28px 30px;
  border:1px solid #ece6df;
  position:relative;
  transition:transform .25s, box-shadow .25s;
}
.why__card:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 40px rgba(0,0,0,.06);
}
.why__card--shift{margin-top:30px}
.why__num{
  font-family:var(--f-head);
  font-size:42px;
  font-weight:300;
  color:var(--c-primary);
  line-height:1;
  margin-bottom:14px;
  opacity:.8;
}
.why__h{
  margin:0 0 12px;
  font-family:var(--f-head);
  font-size:18px;
  font-weight:500;
  letter-spacing:.04em;
  color:var(--c-ink-soft);
  text-transform:uppercase;
  line-height:1.3;
}
.why__card p{
  margin:0;
  font-size:14px;
  line-height:1.7;
  color:var(--c-text);
}

.preview{
  padding:100px var(--pad-x);
  background:linear-gradient(180deg, #1a0e08 0%, #2d1610 100%);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.preview::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,140,60,.08), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(168,52,26,.12), transparent 50%);
  pointer-events:none;
}
.preview__inner{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:6fr 5fr;
  gap:60px;
  align-items:center;
  position:relative;
}
.preview__art{position:relative}
.preview__shot{
  display:block;
  width:100%;
  height:auto;
  position:relative;
  z-index:2;
  border:2px solid #4a2818;
  background:#0a0604;
}
.preview__glow{
  position:absolute;
  inset:-30px;
  z-index:1;
  background:radial-gradient(circle, rgba(255,140,60,.15) 0%, transparent 60%);
  filter:blur(20px);
}
.preview__copy{position:relative;z-index:2}
.preview__copy .h-2{color:#fff}
.preview__copy p{
  margin:0 0 18px;
  font-size:15px;
  line-height:1.75;
  color:rgba(255,255,255,.78);
}
.preview__cta{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  margin-top:28px;
}

.faqcta{
  position:relative;
  padding:80px var(--pad-x);
  isolation:isolate;
  text-align:center;
  color:#fff;
  overflow:hidden;
}
.faqcta__bg{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(circle at 30% 50%, rgba(168,52,26,.5), transparent 50%),
    linear-gradient(135deg, #2d1610 0%, #0a0402 100%);
}
.faqcta__bg::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 12% 20%, rgba(255,255,255,.05) 0 60px, transparent 61px),
    radial-gradient(circle at 88% 80%, rgba(255,255,255,.05) 0 50px, transparent 51px);
  background-size:400px 400px;
}
.faqcta__inner{max-width:680px;margin:0 auto}
.faqcta__lead{
  margin:0 0 28px;
  font-size:15px;
  line-height:1.75;
  color:rgba(255,255,255,.78);
}

.reviews{
  padding:100px var(--pad-x);
  background:#fff;
}
.reviews__head{
  max-width:780px;
  margin:0 auto 50px;
  text-align:center;
}
.reviews__grid{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  align-items:start;
}
.rev{
  background:#faf7f3;
  padding:26px 24px;
  border:1px solid #ede6dd;
  position:relative;
}
.rev--shift{transform:translateY(20px)}
.rev--wide{grid-column:span 2}
.rev__top{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.rev__av{
  width:42px;height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--f-head);
  font-weight:600;
  color:#fff;
  font-size:16px;
  letter-spacing:.05em;
  flex-shrink:0;
}
.rev__av--a{background:linear-gradient(135deg,#a8341a,#6b1f0a)}
.rev__av--b{background:linear-gradient(135deg,#3a5b6b,#1e3140)}
.rev__av--c{background:linear-gradient(135deg,#6b4a2a,#3a2818)}
.rev__av--d{background:linear-gradient(135deg,#5a4a8b,#332a55)}
.rev__av--e{background:linear-gradient(135deg,#3a6b3a,#1f3f1f)}
.rev__who{flex:1;min-width:0}
.rev__who strong{
  display:block;
  font-family:var(--f-head);
  font-size:14px;
  letter-spacing:.06em;
  color:var(--c-ink-soft);
  text-transform:uppercase;
}
.rev__who span{
  display:block;
  font-size:12px;
  color:var(--c-text);
  margin-top:2px;
}
.rev__stars{
  font-size:13px;
  color:#d49b1c;
  letter-spacing:.04em;
}
.rev p{
  margin:0 0 14px;
  font-size:14px;
  line-height:1.7;
  color:var(--c-text);
}
.rev__date{
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.22em;
  color:#a8a098;
  text-transform:uppercase;
}

.gallery{
  padding:80px var(--pad-x) 100px;
  background:#f6f3ef;
}
.gallery__head{
  max-width:780px;
  margin:0 auto 50px;
  text-align:center;
}
.gallery__grid{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
.gallery__cell{
  margin:0;
  background:#fff;
  border:1px solid #ede6dd;
  overflow:hidden;
}
.gallery__img{
  width:100%;
  aspect-ratio:1/1;
  display:block;
  object-fit:cover;
  background:#1a0805;
}
.gallery__cell figcaption{
  padding:14px 16px 16px;
  font-size:12px;
  line-height:1.55;
  color:var(--c-text);
}

.pagehead{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  padding:140px var(--pad-x) 80px;
  color:#fff;
  text-align:center;
}
.pagehead__bg{
  position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(circle at 25% 30%, #b53e1e 0%, transparent 50%),
    radial-gradient(circle at 75% 70%, #5a1a08 0%, transparent 55%),
    linear-gradient(135deg,#2a0f06 0%,#150603 100%);
}
.pagehead__bg::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 18% 25%, rgba(255,180,90,.12) 0 6px, transparent 7px),
    radial-gradient(circle at 78% 35%, rgba(255,90,60,.1) 0 10px, transparent 11px),
    radial-gradient(circle at 42% 80%, rgba(255,200,100,.09) 0 8px, transparent 9px);
  background-size:280px 280px,320px 320px,260px 260px;
  opacity:.6;
}
.pagehead__veil{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg, rgba(0,0,0,.4) 0%, rgba(0,0,0,.65) 100%);
}
.pagehead__inner{
  max-width:760px;
  margin:0 auto;
  position:relative;
}
.pagehead__crumb{
  display:inline-flex;
  gap:10px;
  align-items:center;
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  margin-bottom:20px;
}
.pagehead__crumb a{color:rgba(255,255,255,.75)}
.pagehead__crumb a:hover{color:var(--c-primary)}
.pagehead__crumb span{color:rgba(255,255,255,.3)}
.pagehead__title{
  margin:0 0 14px;
  font-family:var(--f-head);
  font-weight:500;
  font-size:clamp(32px, 4.4vw, 52px);
  letter-spacing:.04em;
  text-transform:uppercase;
  line-height:1.15;
}
.pagehead__sub{
  margin:0;
  font-family:var(--f-script);
  font-size:clamp(20px, 2.4vw, 26px);
  color:#ffb88c;
}

.doc{
  padding:80px var(--pad-x) 100px;
  background:#fff;
}
.doc__wrap{
  max-width:820px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr;
  gap:0;
}
.doc__meta{
  display:flex;
  flex-wrap:wrap;
  gap:18px 32px;
  padding:18px 22px;
  background:#faf7f3;
  border-left:3px solid var(--c-primary);
  margin-bottom:40px;
  font-size:13px;
  color:var(--c-text);
}
.doc__meta strong{
  display:block;
  font-family:var(--f-head);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  margin-bottom:4px;
}
.doc h2{
  margin:46px 0 16px;
  font-family:var(--f-head);
  font-weight:500;
  font-size:22px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  padding-bottom:10px;
  border-bottom:1px solid #ede6dd;
}
.doc h2:first-of-type{margin-top:0}
.doc h3{
  margin:26px 0 10px;
  font-family:var(--f-head);
  font-weight:500;
  font-size:16px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--c-primary);
}
.doc p{
  margin:0 0 16px;
  font-size:15px;
  line-height:1.78;
  color:var(--c-text);
}
.doc ul,.doc ol{
  margin:0 0 20px;
  padding-left:22px;
}
.doc li{
  font-size:15px;
  line-height:1.75;
  color:var(--c-text);
  margin-bottom:8px;
}
.doc strong{color:var(--c-ink-soft)}
.doc em{
  font-style:italic;
  color:var(--c-ink-soft);
}
.doc a{
  color:var(--c-primary);
  text-decoration:underline;
  text-underline-offset:3px;
}
.doc a:hover{color:var(--c-primary-hover)}
.doc__callout{
  background:#fff5ed;
  border:1px solid #f3d4bc;
  padding:18px 22px;
  margin:24px 0 28px;
}
.doc__callout p{margin:0;font-size:14px;color:var(--c-ink-soft)}
.doc__callout p strong{color:var(--c-primary)}

.faq{
  padding:80px var(--pad-x) 100px;
  background:#fff;
}
.faq__wrap{
  max-width:820px;
  margin:0 auto;
}
.faq__intro{
  margin:0 0 36px;
  font-size:15px;
  line-height:1.75;
  color:var(--c-text);
  padding-left:18px;
  border-left:2px solid var(--c-primary);
}
.qa{
  border:1px solid #ede6dd;
  background:#fff;
  margin-bottom:12px;
  transition:border-color .2s, box-shadow .2s;
}
.qa[open]{
  border-color:var(--c-primary);
  box-shadow:0 8px 30px rgba(168,52,26,.08);
}
.qa summary{
  list-style:none;
  cursor:pointer;
  padding:22px 24px;
  display:flex;
  align-items:center;
  gap:18px;
  user-select:none;
}
.qa summary::-webkit-details-marker{display:none}
.qa__num{
  font-family:var(--f-head);
  font-weight:500;
  font-size:13px;
  letter-spacing:.18em;
  color:var(--c-primary);
  flex-shrink:0;
  width:32px;
}
.qa__q{
  flex:1;
  font-family:var(--f-head);
  font-weight:500;
  font-size:16px;
  letter-spacing:.02em;
  color:var(--c-ink-soft);
  text-transform:uppercase;
  line-height:1.4;
}
.qa__chev{
  flex-shrink:0;
  width:32px;
  height:32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:var(--f-head);
  font-size:22px;
  font-weight:300;
  color:var(--c-primary);
  border:1px solid #ede6dd;
  transition:transform .25s, background .25s, color .25s;
}
.qa[open] .qa__chev{
  transform:rotate(45deg);
  background:var(--c-primary);
  color:#fff;
  border-color:var(--c-primary);
}
.qa__a{
  padding:0 24px 24px;
  border-top:1px solid #f3eee6;
  margin-top:0;
}
.qa__a p{
  margin:18px 0 0;
  font-size:15px;
  line-height:1.78;
  color:var(--c-text);
}
.qa__a a{
  color:var(--c-primary);
  text-decoration:underline;
  text-underline-offset:3px;
}
.faq__after{
  margin-top:38px;
  padding:22px 24px;
  background:#faf7f3;
  border-left:3px solid var(--c-primary);
  text-align:center;
}
.faq__after p{
  margin:0;
  font-size:14px;
  color:var(--c-text);
}
.faq__after a{
  color:var(--c-primary);
  text-decoration:underline;
  text-underline-offset:3px;
}

.slot{
  padding:60px var(--pad-x) 80px;
  background:linear-gradient(180deg, #1a0e08 0%, #2d1610 60%, #1a0e08 100%);
  color:#fff;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.slot::before{
  content:"";
  position:absolute;inset:0;z-index:-1;
  background-image:
    radial-gradient(circle at 15% 25%, rgba(255,140,60,.1), transparent 40%),
    radial-gradient(circle at 85% 75%, rgba(168,52,26,.15), transparent 50%);
  pointer-events:none;
}
.slot__shell{
  max-width:1080px;
  margin:0 auto;
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:32px;
  align-items:start;
}
.slot__head{
  grid-column:1 / -1;
  text-align:center;
  margin-bottom:14px;
}
.slot__head .kicker{color:#ffb88c}
.slot__head .h-2{color:#fff;margin-bottom:8px}
.slot__head p{
  margin:0;
  font-size:14px;
  color:rgba(255,255,255,.65);
  max-width:560px;
  margin-left:auto;
  margin-right:auto;
}

.cab{
  background:linear-gradient(180deg, #3a1c10 0%, #1a0a04 100%);
  border:3px solid #6b3018;
  padding:28px 24px 24px;
  box-shadow:0 30px 70px rgba(0,0,0,.5), inset 0 0 0 1px rgba(255,180,80,.15);
  position:relative;
}
.cab::before{
  content:"FRUIT MAX";
  position:absolute;
  top:-14px;left:50%;
  transform:translateX(-50%);
  background:var(--c-primary);
  padding:5px 22px;
  font-family:var(--f-head);
  font-weight:700;
  font-size:13px;
  letter-spacing:.32em;
  color:#fff;
}
.cab__hud{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:0 4px 14px;
  border-bottom:1px dashed #6b3018;
  margin-bottom:14px;
}
.cab__hud-cell{
  font-family:var(--f-head);
  letter-spacing:.18em;
}
.cab__hud-label{
  display:block;
  font-size:10px;
  color:rgba(255,184,140,.6);
  margin-bottom:4px;
}
.cab__hud-val{
  display:block;
  font-size:20px;
  font-weight:500;
  color:#ffd9a8;
}
.cab__hud-val--win{color:#62d97f}
.cab__hud-val--lose{color:#ff6a55}

.grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:6px;
  background:#0a0604;
  padding:10px;
  border:1px solid #6b3018;
}
.cell{
  aspect-ratio:1/1;
  background:#fff;
  border:1px solid #d4a060;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  transition:transform .15s ease, box-shadow .25s ease;
}
.cell img{
  width:72%;
  height:72%;
  object-fit:contain;
  user-select:none;
  pointer-events:none;
}
.cell.is-spin{
  animation:cellSpin .35s linear infinite;
}
.cell.is-hit{
  box-shadow:0 0 0 2px #ffd24a, 0 0 24px rgba(255,210,74,.7);
  background:#fff7d8;
  animation:cellPulse .8s ease infinite;
}
@keyframes cellSpin{
  0%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
  100%{transform:translateY(0)}
}
@keyframes cellPulse{
  0%,100%{box-shadow:0 0 0 2px #ffd24a, 0 0 24px rgba(255,210,74,.7)}
  50%{box-shadow:0 0 0 2px #ffd24a, 0 0 36px rgba(255,210,74,1)}
}

.cab__ctrl{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:18px;
  padding-top:14px;
  border-top:1px dashed #6b3018;
  flex-wrap:wrap;
}
.cab__bet{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--f-head);
  font-size:12px;
  letter-spacing:.16em;
  color:#ffb88c;
}
.cab__bet button{
  width:30px;height:30px;
  background:#1a0a04;
  border:1px solid #6b3018;
  color:#ffd9a8;
  font-size:18px;
  font-weight:700;
  transition:background .2s;
}
.cab__bet button:hover{background:#3a1c10}
.cab__bet-val{
  min-width:42px;
  text-align:center;
  font-size:16px;
  color:#ffd9a8;
}
.cab__spin{
  background:linear-gradient(180deg, #c44a1f 0%, #8a2810 100%);
  color:#fff;
  font-family:var(--f-head);
  font-weight:700;
  font-size:16px;
  letter-spacing:.28em;
  padding:14px 32px;
  border:1px solid #ffb88c;
  text-transform:uppercase;
  transition:transform .15s, filter .2s;
  flex:1;
  min-width:140px;
}
.cab__spin:hover{filter:brightness(1.15)}
.cab__spin:active{transform:scale(.97)}
.cab__spin:disabled{opacity:.5;cursor:not-allowed}

.cab__msg{
  margin-top:14px;
  padding:12px 18px;
  text-align:center;
  font-family:var(--f-head);
  font-size:13px;
  letter-spacing:.2em;
  text-transform:uppercase;
  border:1px solid transparent;
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .3s;
}
.cab__msg.is-win{
  background:rgba(98,217,127,.12);
  border-color:#62d97f;
  color:#62d97f;
}
.cab__msg.is-lose{
  background:rgba(255,106,85,.1);
  border-color:#ff6a55;
  color:#ff6a55;
}
.cab__msg.is-idle{color:rgba(255,255,255,.4)}

.side{display:flex;flex-direction:column;gap:18px}
.side__panel{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,184,140,.18);
  padding:22px 22px 24px;
}
.side__h{
  margin:0 0 14px;
  font-family:var(--f-head);
  font-weight:500;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#ffb88c;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,184,140,.2);
}
.side__rules{padding:0;margin:0}
.side__rules li{
  position:relative;
  padding:6px 0 6px 20px;
  font-size:13px;
  line-height:1.6;
  color:rgba(255,255,255,.78);
}
.side__rules li::before{
  content:"›";
  position:absolute;
  left:4px;top:5px;
  color:var(--c-primary);
  font-weight:700;
}
.side__rules strong{color:#fff}
.side__pay{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.side__pay-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:6px 8px;
  background:rgba(0,0,0,.25);
}
.side__pay-row img{width:24px;height:24px;object-fit:contain}
.side__pay-row span{
  font-family:var(--f-head);
  font-size:12px;
  letter-spacing:.12em;
  color:#ffd9a8;
}

.aware{
  margin:36px auto 0;
  max-width:1080px;
  padding:22px 26px;
  background:rgba(255,255,255,.04);
  border-left:3px solid var(--c-primary);
  display:flex;
  gap:18px;
  align-items:flex-start;
  flex-wrap:wrap;
}
.aware__ico{
  flex-shrink:0;
  width:42px;height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--c-primary);
  color:#fff;
  font-family:var(--f-head);
  font-weight:700;
  font-size:14px;
  letter-spacing:.04em;
}
.aware__txt{flex:1;min-width:240px}
.aware__txt strong{
  display:block;
  font-family:var(--f-head);
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#ffb88c;
  margin-bottom:6px;
}
.aware__txt p{
  margin:0;
  font-size:13px;
  line-height:1.65;
  color:rgba(255,255,255,.7);
}
.aware__txt a{color:#ffb88c;text-decoration:underline;text-underline-offset:3px}

.bigwarn{
  position:relative;
  padding:64px var(--pad-x);
  background:linear-gradient(135deg, #6b1f0a 0%, #2d0a04 100%);
  color:#fff;
  isolation:isolate;
  overflow:hidden;
  border-top:3px solid var(--c-primary);
  border-bottom:3px solid var(--c-primary);
}
.bigwarn__bg{
  position:absolute;inset:0;z-index:-1;
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,.02) 0 12px,
      transparent 12px 24px
    );
}
.bigwarn__inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:36px;
  align-items:center;
}
.bigwarn__badge{
  display:flex;
  align-items:center;
  justify-content:center;
}
.bigwarn__age{
  display:flex;
  align-items:center;
  justify-content:center;
  width:130px;height:130px;
  border:4px solid #fff;
  font-family:var(--f-head);
  font-weight:700;
  font-size:46px;
  letter-spacing:.05em;
  background:rgba(255,255,255,.06);
  box-shadow:0 0 0 8px rgba(255,255,255,.08), inset 0 0 30px rgba(0,0,0,.3);
}
.bigwarn__kicker{
  margin:0 0 8px;
  font-family:var(--f-script);
  font-size:22px;
  color:#ffb88c;
}
.bigwarn__h{
  margin:0 0 14px;
  font-family:var(--f-head);
  font-weight:500;
  font-size:clamp(24px, 3vw, 34px);
  letter-spacing:.04em;
  text-transform:uppercase;
  line-height:1.2;
  color:#fff;
}
.bigwarn__lead{
  margin:0 0 16px;
  font-size:15px;
  line-height:1.7;
  color:rgba(255,255,255,.85);
}
.bigwarn__list{
  margin:0;
  padding:0;
  list-style:none;
}
.bigwarn__list li{
  position:relative;
  padding:6px 0 6px 22px;
  font-size:14px;
  line-height:1.65;
  color:rgba(255,255,255,.8);
}
.bigwarn__list li::before{
  content:"›";
  position:absolute;
  left:4px;top:5px;
  color:#ffb88c;
  font-weight:700;
}
.bigwarn__list a{
  color:#ffb88c;
  text-decoration:underline;
  text-underline-offset:3px;
}
.bigwarn__list a:hover{color:#fff}

.howplay{
  padding:80px var(--pad-x);
  background:#faf7f3;
}
.howplay__inner{
  max-width:880px;
  margin:0 auto;
}
.howplay__head{
  text-align:center;
  margin-bottom:32px;
}
.howplay__body{
  background:#fff;
  border:1px solid #ede6dd;
  border-left:3px solid var(--c-primary);
  padding:30px 34px;
}
.howplay__body p{
  margin:0 0 16px;
  font-size:15px;
  line-height:1.78;
  color:var(--c-text);
}
.howplay__body p:last-child{margin-bottom:0}

@media (max-width: 1024px){
  .foot__grid{grid-template-columns:repeat(2, 1fr); gap:36px}
  .about__inner{grid-template-columns:1fr; gap:40px}
  .about__media{max-width:420px;margin:0 auto}
  .why__grid{grid-template-columns:repeat(2, 1fr)}
  .why__card--shift{margin-top:0}
  .preview__inner{grid-template-columns:1fr;gap:50px}
  .preview__art{max-width:480px;margin:0 auto;width:100%}
  .reviews__grid{grid-template-columns:repeat(2, 1fr)}
  .rev--shift{transform:none}
  .rev--wide{grid-column:span 2}
  .gallery__grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width: 767px){
  :root{--pad-x:18px}
  .topbar{padding:16px var(--pad-x)}
  .topbar__logo{height:38px}
  .hero{padding-top:100px}
  .hero__cta{flex-direction:column;width:100%;max-width:280px}
  .hero__cta .btn{width:100%;text-align:center}
  .foot{padding-top:60px}
  .foot__grid{grid-template-columns:1fr; gap:32px}
  .foot__col--brand{align-items:center;text-align:center}

  .alertbar__wrap{padding:8px 14px;gap:10px}
  .alertbar__msg{font-size:10px;letter-spacing:.1em}

  .foot__regs-row{gap:22px 24px}
  .foot__reg{height:auto}
  .foot__reg img{max-height:32px;max-width:120px;padding:5px 8px}

  .agegate__card{padding:34px 22px 28px}
  .agegate__title{font-size:20px}

  .cookies{left:10px;right:10px;bottom:10px}
  .cookies__wrap{padding:16px;gap:14px}
  .cookies__btns{width:100%}
  .cookies__btn{flex:1}

  .about,.why,.preview,.reviews,.gallery,.faqcta{padding-top:64px;padding-bottom:64px}
  .why__grid{grid-template-columns:1fr;gap:18px}
  .reviews__grid{grid-template-columns:1fr}
  .rev--wide{grid-column:span 1}
  .gallery__grid{grid-template-columns:1fr 1fr;gap:12px}
  .preview__cta{flex-direction:column;align-items:flex-start;gap:10px}
  .preview__cta .btn{width:100%;text-align:center}

  .pagehead{padding:110px 18px 60px}
  .doc{padding:50px 18px 70px}
  .doc h2{font-size:18px}
  .doc p,.doc li{font-size:14px}

  .faq{padding:50px 18px 70px}
  .qa summary{padding:18px 16px;gap:12px}
  .qa__q{font-size:14px}
  .qa__a{padding:0 16px 18px}
  .qa__a p{font-size:14px}

  .slot{padding:40px 14px 60px}
  .slot__shell{grid-template-columns:1fr;gap:22px}
  .cab{padding:24px 14px 18px}
  .cab__hud-val{font-size:16px}
  .grid{gap:4px;padding:6px}
  .cab__spin{font-size:13px;padding:12px 18px;letter-spacing:.18em}
  .aware{padding:18px;gap:14px}

  .bigwarn{padding:48px 18px}
  .bigwarn__inner{grid-template-columns:1fr;gap:24px;text-align:center}
  .bigwarn__age{width:96px;height:96px;font-size:32px;border-width:3px}
  .bigwarn__list{text-align:left;display:inline-block}
  .howplay{padding:50px 18px 60px}
  .howplay__body{padding:22px 20px}
}
