/* ═══════════════════════════════════════════════════════════════
   BROZ MARTIAL ARTS - Redcliffe
   Monochrome black/bone + electric blue accent (#4564fd)
═══════════════════════════════════════════════════════════════ */

:root{
  --ink:        #0a0a0a;
  --ink-2:      #141414;
  --ink-3:      #1f1f1f;
  --bone:       #f5f3ef;
  --bone-2:     #ebe8e2;
  --paper:      #ffffff;
  --line:       #2a2a2a;
  --line-soft:  rgba(10,10,10,0.08);

  --blood:      #4564fd;
  --blood-hot:  #5b78ff;
  --blood-dim:  rgba(69,100,253,0.10);
  --blood-glow: rgba(69,100,253,0.35);

  --body:       #3a3a38;
  --muted:      #6a6862;
  --faint:      #9e9a92;

  --f-display:  'Oswald', 'Anton', 'Arial Narrow', sans-serif;
  --f-body:     'Inter', system-ui, sans-serif;

  --container:  1240px;
  --pad:        clamp(20px, 4vw, 60px);
  --section:    clamp(80px, 10vw, 140px);
  --nav-h:      76px;

  --ease:       cubic-bezier(.32,.72,0,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.65;
  color:var(--body);
  background:var(--bone);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;color:var(--ink);line-height:1.02;letter-spacing:-0.01em}
ul{list-style:none}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad);position:relative;z-index:2}

::selection{background:var(--ink);color:var(--bone)}

/* ═══ UTILS ═══ */
.eyebrow{
  font-family:var(--f-body);
  font-size:12px;
  font-weight:600;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--blood);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:'';
  width:28px;height:2px;
  background:var(--blood);
  display:inline-block;
}
.section-head{text-align:left;margin-bottom:64px;max-width:820px}
.section-head.centered{text-align:center;margin-left:auto;margin-right:auto}
.section-head.centered .eyebrow::before{display:none}
.section-head.centered .eyebrow{padding-left:38px;padding-right:38px;position:relative}
.section-head.centered .eyebrow::after,
.section-head.centered .eyebrow::before{
  content:'';position:absolute;top:50%;width:28px;height:2px;background:var(--blood);display:block;
}
.section-head.centered .eyebrow::before{left:0;transform:translateY(-50%)}
.section-head.centered .eyebrow::after{right:0;transform:translateY(-50%)}

.section-title{
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(40px,5.5vw,76px);
  text-transform:uppercase;
  letter-spacing:-0.01em;
  line-height:0.98;
  color:var(--ink);
  margin-top:16px;
}
.section-title .slash{color:var(--blood)}
.section-title em{font-style:normal;color:var(--blood)}
.section-sub{
  margin-top:20px;
  font-size:18px;
  line-height:1.6;
  color:var(--muted);
  max-width:640px;
}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.on{opacity:1;transform:none}
.stagger>.reveal:nth-child(1){transition-delay:0s}
.stagger>.reveal:nth-child(2){transition-delay:.08s}
.stagger>.reveal:nth-child(3){transition-delay:.16s}
.stagger>.reveal:nth-child(4){transition-delay:.24s}
.stagger>.reveal:nth-child(5){transition-delay:.32s}

/* ═══ BUTTONS ═══ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--f-display);font-weight:600;
  font-size:14px;letter-spacing:0.14em;text-transform:uppercase;
  padding:16px 28px;
  border:2px solid transparent;
  transition:all .25s var(--ease);
  white-space:nowrap;
  cursor:pointer;
  position:relative;
  clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
}
.btn-lg{padding:20px 36px;font-size:15px}
.btn-sm{padding:12px 22px;font-size:12px}

.btn-primary{background:var(--blood);color:#fff;border-color:var(--blood)}
.btn-primary:hover{background:var(--blood-hot);box-shadow:0 8px 24px var(--blood-glow);transform:translateY(-1px)}

.btn-ink{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.btn-ink:hover{background:#fff;color:var(--ink);border-color:#fff}

.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--bone)}

.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,0.3)}
.btn-outline-light:hover{background:#fff;color:var(--ink);border-color:#fff}

.btn-arrow{display:inline-block;transition:transform .25s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}

.btn-block{width:100%}

/* ═══ NAV ═══ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .3s var(--ease),border-color .3s var(--ease), backdrop-filter .3s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(10,10,10,0.92);backdrop-filter:blur(10px);border-bottom-color:var(--line)}
.nav.light.scrolled{background:rgba(245,243,239,0.94);border-bottom-color:var(--line-soft)}
.nav-inner{
  max-width:var(--container);margin:0 auto;width:100%;
  padding:0 var(--pad);
  display:flex;align-items:center;gap:32px;
}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-logo img{width:40px;height:40px;filter:invert(1)}
.nav.light .nav-logo img{filter:invert(0)}
.nav-logo-text{
  font-family:var(--f-display);font-weight:700;text-transform:uppercase;
  font-size:20px;letter-spacing:0.08em;color:#fff;
}
.nav.light .nav-logo-text{color:var(--ink)}

.nav-links{display:flex;gap:28px;flex:1;justify-content:center}
.nav-links a{
  font-size:13px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(255,255,255,0.75);
  padding:8px 0;position:relative;
  transition:color .2s var(--ease);
}
.nav.light .nav-links a{color:var(--ink)}
.nav-links a:hover{color:#fff}
.nav.light .nav-links a:hover{color:var(--blood)}
.nav-links a::after{
  content:'';position:absolute;left:0;right:0;bottom:2px;height:2px;
  background:var(--blood);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.nav-links a:hover::after{transform:scaleX(1)}

.nav-right{display:flex;gap:16px;align-items:center}
.nav-phone{
  font-family:var(--f-display);font-weight:600;font-size:15px;letter-spacing:0.06em;
  color:#fff;
}
.nav.light .nav-phone{color:var(--ink)}
.nav-phone:hover{color:var(--blood)}

.hamburger{
  display:none;
  width:42px;height:42px;
  flex-direction:column;gap:5px;justify-content:center;align-items:center;
}
.hamburger span{width:22px;height:2px;background:#fff;transition:transform .3s var(--ease),opacity .3s}
.nav.light .hamburger span{background:var(--ink)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:880px){
  .nav-links,.nav-phone,.nav-right .btn{display:none}
  .nav-right{margin-left:auto}
  .hamburger{display:flex}
}

/* Mobile overlay */
.nav-overlay{
  position:fixed;inset:0;z-index:99;
  background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;
  opacity:0;pointer-events:none;transition:opacity .3s;
  padding:80px 40px 40px;
}
.nav-overlay.open{opacity:1;pointer-events:all}
.nav-overlay a{
  font-family:var(--f-display);font-weight:600;font-size:28px;
  color:var(--bone);text-transform:uppercase;letter-spacing:0.04em;
}
.nav-overlay a.accent{color:var(--blood)}

/* ═══ HERO ═══ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:stretch;
  background:var(--ink);color:#fff;overflow:hidden;
}
.hero-photo{position:absolute;inset:0;z-index:0}
.hero-photo-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center 30%;
  filter:grayscale(0.9) contrast(1.05) brightness(0.7) saturate(0.8);
  z-index:0;
}
.hero-photo::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 50% 55%, rgba(10,10,10,0.15) 0%, rgba(10,10,10,0.65) 65%, rgba(10,10,10,0.92) 100%),
    linear-gradient(to top, var(--ink) 0%, rgba(10,10,10,0.55) 15%, rgba(10,10,10,0.35) 45%, rgba(10,10,10,0.7) 100%);
  pointer-events:none;
}
.hero-stripes{display:none}

.hero-redbar{
  position:absolute;left:0;right:0;bottom:0;
  height:6px;
  background:linear-gradient(90deg,transparent 0%, var(--blood) 20%, var(--blood) 80%, transparent 100%);
  z-index:3;
}

.hero-content{
  position:relative;z-index:3;
  max-width:var(--container);margin:0 auto;width:100%;
  padding:calc(var(--nav-h) + 80px) var(--pad) 120px;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;
}
.hero-inner{max-width:880px;width:100%;display:flex;flex-direction:column;align-items:center}

.hero-eyebrow{
  font-family:var(--f-body);font-size:12px;font-weight:600;
  letter-spacing:0.24em;text-transform:uppercase;
  color:var(--blood);
  display:inline-flex;align-items:center;gap:12px;
  margin-bottom:28px;
}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:40px;height:2px;background:var(--blood)}

.hero-title{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(52px,9vw,128px);
  line-height:0.92;
  letter-spacing:-0.015em;
  color:#fff;
  text-transform:uppercase;
  margin-bottom:28px;
}
.hero-title .line{display:block}
.hero-title .line-cycle{
  display:block;
  min-height:1em;
  position:relative;
}
.hero-title .cycle{
  color:var(--blood);
  display:inline-block;
  position:relative;
}
.hero-title .cycle .cycle-ghost{
  visibility:hidden;
  display:inline-block;
  pointer-events:none;
}
.hero-title .cycle .cycle-word{
  position:absolute;
  inset:0;
  display:block;
  text-align:center;
  white-space:nowrap;
}
.hero-title .cycle .cycle-word.fade{animation:cycleFade .5s ease}
@keyframes cycleFade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.hero-sub{
  font-size:clamp(17px,1.6vw,21px);
  line-height:1.55;
  color:rgba(255,255,255,0.85);
  font-weight:500;
  max-width:680px;
  margin-bottom:40px;
}
.hero-sub strong{color:#fff;font-weight:700}
.highlight-half{
  background-image:linear-gradient(transparent 55%, rgba(10,10,10,0.85) 55%);
  padding:0 6px;
  box-decoration-break:clone;
  -webkit-box-decoration-break:clone;
}

.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px;justify-content:center}

.hero-proof{
  display:flex;align-items:center;gap:16px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,0.12);
  max-width:540px;
  justify-content:center;
}
.proof-avatars{display:flex}
.proof-avatars span{
  width:40px;height:40px;border-radius:50%;
  border:2px solid var(--blood);
  background:#2a2a2a;
  margin-left:-10px;
  background-size:cover;background-position:center;
  filter:grayscale(1) contrast(1.1);
}
.proof-avatars span:first-child{margin-left:0}
.proof-text{
  font-size:13px;line-height:1.5;color:rgba(255,255,255,0.8);text-align:left;
}
.proof-text strong{color:#fff;font-weight:700}

.hero-stats{
  display:flex;gap:clamp(24px,5vw,56px);
  margin-top:40px;padding-top:28px;
  border-top:1px solid rgba(255,255,255,0.12);
  justify-content:center;flex-wrap:wrap;max-width:720px;width:100%;
}
.hero-stat{text-align:center}
.hero-stat .num{font-family:var(--f-display);font-size:clamp(28px,3vw,38px);color:#fff;font-weight:600;line-height:1}
.hero-stat .num em{font-style:normal;color:var(--blood)}
.hero-stat .lab{font-size:11px;color:rgba(255,255,255,0.65);text-transform:uppercase;letter-spacing:0.18em;margin-top:6px}

.scroll-cue{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:3;
  font-size:10px;letter-spacing:0.3em;text-transform:uppercase;
  color:rgba(255,255,255,0.6);
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.scroll-cue::after{
  content:'';width:1px;height:40px;background:linear-gradient(to bottom,var(--blood),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{opacity:0.3;transform:scaleY(0.5)}50%{opacity:1;transform:scaleY(1)}}
@media (max-width:880px){.scroll-cue{display:none}}

/* VSL */
.vsl{
  background:var(--ink);color:var(--bone);
  padding:clamp(56px,7vw,96px) 0 clamp(56px,7vw,96px);
  position:relative;overflow:hidden;
}
.vsl::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:64px 64px;pointer-events:none;
}
.vsl .container{max-width:1400px}
.vsl-head{text-align:center;max-width:900px;margin:0 auto clamp(32px,4vw,52px);position:relative;z-index:2}
.vsl-head .eyebrow{color:var(--blood);justify-content:center}
.vsl-head h2{
  font-family:var(--f-display);font-size:clamp(40px,6vw,84px);
  text-transform:uppercase;color:#fff;line-height:0.95;margin:18px 0 0;letter-spacing:-0.015em;
}
.vsl-head h2 em{font-style:normal;color:var(--blood)}

.vsl-frame{
  position:relative;aspect-ratio:16/9;
  width:100%;max-width:1280px;margin:0 auto;
  background:#0a0a0a;
  border:1px solid var(--line);
  overflow:hidden;cursor:pointer;
  z-index:2;
}
.vsl-frame::before{
  content:'';position:absolute;top:-1px;left:-1px;width:56px;height:56px;
  border-top:3px solid var(--blood);border-left:3px solid var(--blood);z-index:3;
}
.vsl-frame::after{
  content:'';position:absolute;bottom:-1px;right:-1px;width:56px;height:56px;
  border-bottom:3px solid var(--blood);border-right:3px solid var(--blood);z-index:3;
}
.vsl-thumb{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease), filter .3s var(--ease);
}
.vsl-frame:hover .vsl-thumb{transform:scale(1.03);filter:brightness(0.92)}
.vsl-overlay{display:none}
.vsl-content{
  position:absolute;inset:0;z-index:3;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;
  padding:24px;pointer-events:none;
}
.vsl-play{
  width:clamp(72px,9vw,112px);height:clamp(72px,9vw,112px);
  border-radius:50%;
  background:var(--blood);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 0 rgba(69,100,253,0.5);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.vsl-frame:hover .vsl-play{transform:scale(1.12);box-shadow:0 0 0 14px rgba(69,100,253,0.18)}
.vsl-play svg{width:36px;height:36px;margin-left:4px}
.vsl-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:5}
.vsl-frame.playing .vsl-thumb,
.vsl-frame.playing .vsl-overlay,
.vsl-frame.playing .vsl-content{display:none}

/* ═══ MARQUEE ═══ */
.marquee{
  background:var(--ink);
  color:var(--bone);
  padding:22px 0;
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.marquee-track{
  display:flex;gap:60px;
  animation:marq 40s linear infinite;
  white-space:nowrap;
  width:max-content;
}
.marquee-item{
  font-family:var(--f-display);text-transform:uppercase;
  font-size:clamp(22px,2.4vw,32px);letter-spacing:0.04em;font-weight:500;
  display:inline-flex;align-items:center;gap:60px;
}
.marquee-item .dot{
  width:10px;height:10px;border-radius:50%;background:var(--blood);
  display:inline-block;flex-shrink:0;
}
.marquee-item .muted{color:rgba(255,255,255,0.35)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══ MISSION ═══ */
.mission{padding:var(--section) 0;background:var(--bone);position:relative}
.mission-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center;
}
@media (max-width:880px){.mission-grid{grid-template-columns:1fr;gap:48px}}

.mission-body{font-size:18px;line-height:1.7;color:var(--body);margin:24px 0 32px}
.mission-body p{margin-bottom:18px}
.mission-body strong{color:var(--ink);font-weight:600}

.mission-image{
  position:relative;
  aspect-ratio:4/5;
  background:var(--ink-2);
  overflow:hidden;
}
.mission-image::after{
  content:'';position:absolute;top:-1px;left:-1px;width:48px;height:48px;
  border-top:3px solid var(--blood);border-left:3px solid var(--blood);
  z-index:2;
}
.mission-image img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.6) contrast(1.05) brightness(0.82);
}
.mission-badge{
  position:absolute;bottom:24px;left:24px;right:24px;
  padding:20px 24px;
  background:rgba(10,10,10,0.85);backdrop-filter:blur(10px);
  border-left:3px solid var(--blood);
  color:#fff;
  z-index:3;
}
.mission-badge .label{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--blood);margin-bottom:6px}
.mission-badge .line{font-family:var(--f-display);font-size:20px;text-transform:uppercase;color:#fff;letter-spacing:0.02em}

/* ═══ BENEFITS ═══ */
.benefits{padding:var(--section) 0;background:var(--ink);color:var(--bone);position:relative;overflow:hidden}
.benefits::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.03) 1px,transparent 1px);
  background-size:64px 64px;
  pointer-events:none;
}
.benefits .eyebrow{color:var(--blood)}
.benefits .section-title{color:#fff}
.benefits .section-sub{color:rgba(255,255,255,0.65)}

.benefits-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  margin-top:72px;
  background:var(--line);
  border:1px solid var(--line);
}
@media (max-width:880px){.benefits-grid{grid-template-columns:1fr}}

.benefit{
  background:var(--ink);
  position:relative;
  transition:background .3s var(--ease);
  display:flex;flex-direction:column;
}
.benefit:hover{background:var(--ink-2)}
.benefit-img{
  display:block;width:100%;
  height:clamp(140px, 15vw, 220px);
  object-fit:cover;
  flex-shrink:0;
  filter:grayscale(0.5) contrast(1.05) brightness(0.88);
  transition:filter 0.35s var(--ease);
}
.benefit:hover .benefit-img{filter:grayscale(0) contrast(1.05) brightness(1)}
.benefit-body{padding:40px 36px 44px;flex:1;display:flex;flex-direction:column}
.benefit-num{
  font-family:var(--f-display);font-size:14px;font-weight:600;
  letter-spacing:0.2em;color:var(--blood);margin-bottom:24px;
  display:flex;align-items:center;gap:12px;
}
.benefit-num::after{content:'';flex:1;height:1px;background:var(--line);max-width:80px}
.benefit h3{
  font-family:var(--f-display);font-size:28px;text-transform:uppercase;
  color:#fff;line-height:1.05;margin-bottom:18px;letter-spacing:-0.005em;
}
.benefit ul li{
  position:relative;padding-left:22px;margin-bottom:10px;
  font-size:15px;line-height:1.6;color:rgba(255,255,255,0.72);
}
.benefit ul li::before{
  content:'';position:absolute;left:0;top:10px;width:10px;height:2px;background:var(--blood);
}

/* ═══ TIMETABLE ═══ */
.timetable{padding:var(--section) 0;background:var(--bone)}
.timetable-wrap{overflow-x:auto;margin-top:40px;border:1px solid var(--line-soft);background:#fff}
.timetable-grid{
  display:grid;grid-template-columns:repeat(6,minmax(140px,1fr));
  min-width:780px;
}
.tt-h{
  padding:16px 10px;background:var(--ink);color:#fff;
  font-family:var(--f-display);font-size:13px;letter-spacing:0.18em;text-transform:uppercase;
  text-align:center;border-right:1px solid var(--line);
}
.tt-h:last-child{border-right:0}
.tt-c{
  padding:18px 10px;min-height:84px;
  text-align:center;
  border-right:1px solid var(--line-soft);border-top:1px solid var(--line-soft);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  background:#fff;transition:background .2s;
}
.tt-c:hover{background:var(--bone-2)}
.tt-c:nth-child(6n){border-right:0}
.tt-c.empty{background:var(--bone-2)}
.tt-c.empty:hover{background:var(--bone-2)}
.tt-c .name{font-family:var(--f-display);font-size:14px;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:0.04em;line-height:1.2}
.tt-c .time{font-size:12px;color:var(--muted);letter-spacing:0.04em}
.tt-c .tag{font-size:10px;color:var(--blood);font-weight:700;letter-spacing:0.14em;text-transform:uppercase;margin-top:2px}
.tt-c.mma .name{color:var(--blood)}

.timetable-note{
  font-size:14px;color:var(--muted);text-align:center;margin-top:20px;font-style:italic;
}
.kids-note{
  margin-top:20px;
  font-size:13px;color:var(--muted);font-style:italic;letter-spacing:0.02em;
}

/* ═══ INLINE CTA ═══ */
.inline-cta{
  padding:clamp(48px,6vw,72px) var(--pad) 0;
  text-align:center;
}
.inline-cta .btn{margin-bottom:14px}
.cta-micro{
  font-size:13px;color:var(--muted);font-family:var(--f-body);
  letter-spacing:0.02em;
}
.inline-cta.on-dark .cta-micro{color:rgba(255,255,255,0.55)}

/* COMPARISON */
.compare{padding:var(--section) 0;background:var(--bone-2);position:relative;overflow:hidden}
.compare::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:320px;height:320px;
  background:
    repeating-linear-gradient(45deg,rgba(10,10,10,0.04) 0 1px,transparent 1px 14px);
  pointer-events:none;
  z-index:1;
}
/* BROZ watermark, low-opacity stencil behind the comparison grid */
.compare::after{
  content:'BROZ';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(-8deg);
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(200px,30vw,420px);
  color:rgba(10,10,10,0.035);
  letter-spacing:-0.04em;
  line-height:0.9;
  white-space:nowrap;
  pointer-events:none;
  user-select:none;
  z-index:0;
}
.compare > .container{position:relative;z-index:2}
/* Flat 2-col grid: each row has a negative cell + a positive cell, grid auto-height locks them in sync */
.compare-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
  background:var(--ink);border:1px solid var(--ink);
  margin-top:48px;
}

.compare-col-header{
  padding:24px 40px 20px;
  font-family:var(--f-display);font-size:22px;text-transform:uppercase;
  letter-spacing:0.02em;
  border-bottom:2px solid var(--line-soft);
}
.compare-col-header.negative{background:#fafaf8;color:var(--muted)}
.compare-col-header.positive{background:#fff;color:var(--ink);border-bottom-color:var(--blood)}

.compare-item{
  padding:18px 40px 18px 72px;
  font-size:15px;line-height:1.6;
  border-bottom:1px solid var(--line-soft);
  position:relative;
  display:flex;align-items:center;
}
.compare-item:nth-last-child(-n+2){border-bottom:0}
.compare-item.negative{background:#fafaf8;color:var(--muted)}
.compare-item.positive{background:#fff;color:var(--ink);font-weight:500}
.compare-item::before{
  position:absolute;left:40px;top:50%;transform:translateY(-50%);
  width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;
}
.compare-item.negative::before{
  content:'✕';color:var(--muted);background:rgba(10,10,10,0.06);
}
.compare-item.positive::before{
  content:'✓';color:#fff;background:var(--blood);
}

/* Mobile: single column, group negatives first then positives using CSS order */
@media (max-width:780px){
  .compare-grid{grid-template-columns:1fr}
  .compare-col-header.negative{order:1}
  .compare-item.negative{order:2}
  .compare-col-header.positive{order:3;border-top:3px solid var(--border,var(--line-soft))}
  .compare-item.positive{order:4}
  .compare-item{padding:16px 24px 16px 56px}
  .compare-item::before{left:24px}
  .compare-col-header{padding:20px 24px 16px}
}

/* ═══ INSTRUCTORS ═══ */
.instructors{padding:var(--section) 0;background:var(--bone)}
.coach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
@media (max-width:880px){.coach-grid{grid-template-columns:1fr}}

.coach{
  background:var(--ink);color:#fff;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .4s var(--ease);
}
.coach:hover{transform:translateY(-6px)}
.coach-photo{
  aspect-ratio:4/5;
  position:relative;overflow:hidden;flex-shrink:0;
  background:linear-gradient(180deg,#2a2a2a 0%,#0e0e0e 100%);
}
.coach-photo img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.6) contrast(1.05);
  transition:filter .3s var(--ease),transform .5s var(--ease);
}
.coach:hover .coach-photo img{filter:grayscale(0) contrast(1.05);transform:scale(1.03)}
.coach-tag{
  position:absolute;top:16px;left:16px;
  font-family:var(--f-display);font-size:11px;letter-spacing:0.18em;
  color:#fff;text-transform:uppercase;font-weight:600;
  background:var(--blood);padding:6px 12px;
  z-index:2;
}
.coach-body{
  padding:28px 28px 32px;
  display:flex;flex-direction:column;gap:14px;
  flex:1;
}
.coach-body h3{
  font-family:var(--f-display);font-size:30px;color:#fff;
  text-transform:uppercase;line-height:1;letter-spacing:-0.005em;
}
.coach-body .role{
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--blood);font-weight:600;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.coach-bio{
  font-size:14px;line-height:1.65;color:rgba(255,255,255,0.72);
}
.coach-bio em{font-style:italic;color:#fff}

/* GUARANTEE */
.guarantee{padding:var(--section) 0;background:var(--bone)}
.guarantee-card{
  max-width:880px;margin:0 auto;
  background:var(--ink);color:#fff;
  padding:clamp(40px,6vw,72px);
  position:relative;
  overflow:hidden;
}
.guarantee-card::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:6px;
  background:var(--blood);
}
.guarantee-card::after{
  content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;
  border:2px solid rgba(69,100,253,0.22);transform:rotate(45deg);
}
.guarantee-stamp{
  display:inline-block;
  font-family:var(--f-display);font-size:12px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--blood);font-weight:700;
  padding:8px 16px;border:1px solid var(--blood);margin-bottom:24px;
}
.guarantee-card h2{
  font-family:var(--f-display);font-size:clamp(32px,4.5vw,56px);
  color:#fff;text-transform:uppercase;line-height:1;margin-bottom:24px;letter-spacing:-0.01em;
}
.guarantee-card h2 em{font-style:normal;color:var(--blood)}
.guarantee-card p{
  font-size:17px;line-height:1.7;color:rgba(255,255,255,0.8);margin-bottom:18px;max-width:640px;
}
.guarantee-card .btn{margin-top:16px}

/* ═══ PRICING ═══ */
.pricing{padding:var(--section) 0;background:var(--bone-2)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px;align-items:stretch}
@media (max-width:880px){.pricing-grid{grid-template-columns:1fr}}

.price-card{
  background:#fff;padding:40px 32px;
  border:1px solid var(--line-soft);
  position:relative;
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease),border-color .3s;
}
.price-card:hover{transform:translateY(-4px);border-color:var(--ink)}
.price-card.popular{
  background:var(--ink);color:#fff;
  border-color:var(--ink);
  transform:scale(1.04);
}
.price-card.popular:hover{transform:scale(1.04) translateY(-4px)}
.price-card.popular::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--blood);
}

/* Diagonal corner ribbon for Most Popular */
.price-card.popular{overflow:hidden}
.price-badge{
  position:absolute;top:0;right:0;
  background:var(--blood);color:#fff;
  font-family:var(--f-display);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  font-weight:700;
  padding:6px 40px;
  transform:translate(30%,60%) rotate(45deg);
  transform-origin:center;
  box-shadow:0 4px 10px rgba(0,0,0,0.35);
  z-index:4;
}
.price-name{
  font-family:var(--f-display);font-size:22px;text-transform:uppercase;
  letter-spacing:0.02em;line-height:1;margin-bottom:12px;
}
.price-card .price-name{color:var(--ink)}
.price-card.popular .price-name{color:#fff}
.price-desc{font-size:14px;color:var(--muted);margin-bottom:28px;line-height:1.5;min-height:42px}
.price-card.popular .price-desc{color:rgba(255,255,255,0.7)}

.price-amount{
  display:flex;align-items:baseline;gap:6px;margin-bottom:4px;
}
.price-amount .n{font-family:var(--f-display);font-size:56px;font-weight:600;line-height:1;color:var(--ink)}
.price-card.popular .price-amount .n{color:#fff}
.price-amount .p{font-size:14px;color:var(--muted);font-weight:500}
.price-card.popular .price-amount .p{color:rgba(255,255,255,0.6)}
.price-bill{font-size:12px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:28px}
.price-card.popular .price-bill{color:rgba(255,255,255,0.55)}

.price-card ul{flex:1;margin-bottom:28px}
.price-card li{
  padding:10px 0 10px 26px;position:relative;font-size:14px;
  border-bottom:1px solid var(--line-soft);
  color:var(--body);
}
.price-card.popular li{color:rgba(255,255,255,0.82);border-bottom-color:rgba(255,255,255,0.1)}
.price-card li:last-child{border-bottom:0}
.price-card li::before{
  content:'';position:absolute;left:0;top:17px;width:14px;height:2px;background:var(--blood);
}

.price-foot{font-size:11px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase;margin-top:14px;text-align:center}
.price-card.popular .price-foot{color:rgba(255,255,255,0.5)}

/* ═══ BOOKING ═══ */
.booking{padding:var(--section) 0;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.booking::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);
  background-size:48px 48px;
  pointer-events:none;
}
.booking .eyebrow{color:var(--blood)}
.booking .section-title{color:#fff}
.booking-wrap{
  max-width:880px;margin:56px auto 0;
  background:var(--ink-2);
  border:1px solid var(--line);
  padding:clamp(32px,5vw,56px);
  position:relative;
}
.booking-wrap::before{
  content:'';position:absolute;top:-1px;left:-1px;width:40px;height:40px;
  border-top:3px solid var(--blood);border-left:3px solid var(--blood);
}
.booking-wrap::after{
  content:'';position:absolute;bottom:-1px;right:-1px;width:40px;height:40px;
  border-bottom:3px solid var(--blood);border-right:3px solid var(--blood);
}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media (max-width:640px){.form-row{grid-template-columns:1fr}}
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-field label{
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(255,255,255,0.6);font-weight:600;
}
.form-field input,.form-field select,.form-field textarea{
  background:rgba(255,255,255,0.04);
  border:1px solid var(--line);
  padding:14px 16px;
  color:#fff;font-family:var(--f-body);font-size:15px;
  transition:border-color .2s;
  width:100%;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--blood);background:rgba(255,255,255,0.06);
}
.form-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%23999' stroke-width='2'/></svg>");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.form-field select option{background:var(--ink-2);color:#fff}
.form-fine{
  font-size:12px;color:rgba(255,255,255,0.55);margin-top:16px;line-height:1.5;
}
.form-submit{margin-top:24px;width:100%}

/* Booking: step progress indicator */
.booking-steps{
  display:flex;align-items:center;gap:12px;margin-bottom:32px;
  font-family:var(--f-display);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.4);
}
.booking-step{display:flex;align-items:center;gap:10px}
.booking-step .dot{
  width:26px;height:26px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:13px;font-weight:600;
}
.booking-step.active{color:var(--blood)}
.booking-step.active .dot{background:var(--blood);border-color:var(--blood);color:#fff}
.booking-step.done .dot{background:var(--ink-3);border-color:var(--blood);color:var(--blood)}
.booking-steps .sep{flex:1;height:1px;background:var(--line)}

.booking-step-wrap{display:none}
.booking-step-wrap.active{display:block}

/* Booking Step 2: day / period / time picker */

.booking-group{margin-bottom:28px;position:relative}
.booking-group-label{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-family:var(--f-display);font-size:12px;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;color:#fff;
  margin-bottom:14px;
}
.booking-group-label .idx{color:var(--blood);font-weight:700;margin-right:8px}
.booking-group-label .hint{
  font-family:var(--f-body);font-weight:500;font-size:11px;
  letter-spacing:0.08em;text-transform:none;color:rgba(255,255,255,0.4);
}

/* Day cards */
.booking-days{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.booking-day{
  position:relative;
  padding:16px 12px 14px;
  background:var(--ink-3);border:1px solid var(--line);
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
  transition:all 0.2s var(--ease);
  overflow:hidden;
  cursor:pointer;
  clip-path:polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.booking-day:hover{border-color:var(--blood);background:var(--ink-2)}
.booking-day.selected{
  background:var(--blood);border-color:var(--blood);
  box-shadow:0 10px 28px var(--blood-glow);
}
.booking-day .weekday{
  font-family:var(--f-display);font-weight:600;font-size:11px;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--blood);
  margin-bottom:8px;transition:color 0.2s var(--ease);
}
.booking-day.selected .weekday{color:rgba(255,255,255,0.9)}
.booking-day .relative{
  font-family:var(--f-display);font-weight:600;font-size:18px;
  color:#fff;letter-spacing:-0.01em;line-height:1.1;text-transform:uppercase;
}
.booking-day .absolute{
  margin-top:3px;font-size:12px;color:rgba(255,255,255,0.6);
  transition:color 0.2s var(--ease);
}
.booking-day.selected .absolute{color:rgba(255,255,255,0.85)}
.booking-day .tap{
  margin-top:10px;
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-body);font-size:10px;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--blood);
  padding:4px 8px;border:1px solid var(--blood);
  background:rgba(69,100,253,0.08);
  transition:all 0.2s var(--ease);
  clip-path:polygon(3px 0, 100% 0, calc(100% - 3px) 100%, 0 100%);
}
.booking-day:hover .tap{background:var(--blood);color:#fff}
.booking-day.selected .tap{background:#fff;border-color:#fff;color:var(--blood)}
.booking-day.selected .tap::before{content:'✓ ';margin-right:2px}
.booking-day.selected .tap-text{display:none}
.booking-day.selected .tap::after{content:'Selected'}

@media (max-width:420px){
  .booking-day{padding:14px 10px 12px}
  .booking-day .relative{font-size:15px}
  .booking-day .tap{font-size:9px;padding:3px 6px}
}

/* AM/PM segmented */
.booking-segmented{
  position:relative;
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--ink-3);border:1px solid var(--line);
  padding:4px;gap:4px;
}
.seg-btn{
  position:relative;z-index:1;
  padding:14px 10px;
  font-family:var(--f-display);font-weight:600;font-size:14px;
  letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.5);
  transition:all 0.25s var(--ease);
  display:flex;align-items:center;justify-content:center;gap:10px;
  clip-path:polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
  background:transparent;cursor:pointer;
}
.seg-btn:hover:not(.active){background:var(--ink-2);color:#fff}
.seg-btn .icon{width:16px;height:16px;opacity:0.7;transition:opacity 0.25s var(--ease)}
.seg-btn .range{
  font-family:var(--f-body);font-weight:500;font-size:11px;
  letter-spacing:0.06em;text-transform:none;opacity:0.75;
}
.seg-btn.active{
  background:var(--blood);color:#fff;
  box-shadow:0 6px 18px var(--blood-glow);
}
.seg-btn.active .icon{opacity:1}

/* Mobile: stack icon / label / range vertically so the time range doesn't get squished next to the label */
@media (max-width:540px){
  .seg-btn{
    flex-direction:column;
    gap:4px;
    padding:12px 8px;
  }
  .seg-btn .range{font-size:10px}
}

/* Time grid */
.booking-times-wrap{position:relative;min-height:60px}
.booking-times{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media (min-width:500px){.booking-times{grid-template-columns:repeat(4,1fr)}}
.time-btn{
  position:relative;
  padding:14px 6px;
  background:var(--ink-3);border:1px solid var(--line);
  font-family:var(--f-display);font-weight:500;font-size:15px;color:#fff;
  text-align:center;letter-spacing:0.02em;
  transition:all 0.15s var(--ease);
  animation:slot-in 0.4s var(--ease) backwards;
  cursor:pointer;
  clip-path:polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
}
.time-btn:hover:not(:disabled):not(.selected){
  border-color:var(--blood);background:var(--ink-2);transform:translateY(-1px);
}
.time-btn.selected{
  background:var(--blood);border-color:var(--blood);color:#fff;
  box-shadow:0 6px 18px var(--blood-glow);
}
.time-btn:disabled{opacity:0.28;cursor:not-allowed;text-decoration:line-through}
@keyframes slot-in{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

/* Locked placeholder */
.booking-locked{
  display:flex;align-items:center;gap:12px;
  padding:16px 18px;
  border:1px dashed rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.6);font-size:13px;
  background:rgba(0,0,0,0.25);font-family:var(--f-body);
}
.booking-locked .arrow{
  font-family:var(--f-display);color:var(--blood);
  font-size:18px;font-weight:700;
}
.booking-placeholder{
  display:flex;align-items:center;gap:12px;
  padding:18px;border:1px dashed rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.6);font-size:13px;
  background:rgba(0,0,0,0.2);font-family:var(--f-body);
  grid-column:1 / -1;
}
.booking-placeholder .dot{width:8px;height:8px;background:var(--blood);flex-shrink:0}

[data-hidden="true"]{display:none}
.reveal-group{animation:group-in 0.4s var(--ease) backwards}
@keyframes group-in{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

/* Sticky summary bar */
.summary-bar{
  position:fixed;left:50%;bottom:20px;
  transform:translate(-50%, 140%);
  width:calc(100% - 40px);max-width:580px;
  background:var(--ink-2);border:1px solid var(--blood);
  padding:12px 12px 12px 18px;
  display:flex;align-items:center;gap:14px;
  z-index:103;
  box-shadow:0 20px 60px rgba(0,0,0,0.6), 0 0 30px var(--blood-glow);
  transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1), opacity 0.3s var(--ease);
  opacity:0;
  clip-path:polygon(12px 0, 100% 0, calc(100% - 12px) 100%, 0 100%);
}
.summary-bar.visible{transform:translate(-50%, 0);opacity:1}
.summary-text{flex:1;min-width:0}
.summary-label{
  font-family:var(--f-display);font-size:10px;font-weight:600;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--blood);margin-bottom:2px;
}
.summary-value{
  font-family:var(--f-display);font-weight:600;font-size:15px;color:#fff;
  letter-spacing:0;text-transform:uppercase;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.summary-bar .btn-primary{
  flex-shrink:0;padding:14px 22px;
  font-size:13px;letter-spacing:0.16em;
  clip-path:polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
@media (max-width:440px){
  .summary-value{font-size:13px}
  .summary-bar .btn-primary{padding:12px 16px;font-size:12px}
}

/* Mobile: unstick the summary bar so it doesn't get covered by the sticky
   .mobile-cta bar. Render inline at the bottom of Step 2 once visible and
   stack text over a full-width (centred) submit button. */
@media (max-width:720px){
  .summary-bar{
    position:static;
    left:auto;right:auto;bottom:auto;
    transform:none;
    width:100%;max-width:none;
    margin-top:24px;
    padding:14px 18px;
    box-shadow:none;
    clip-path:none;
    opacity:1;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:12px;
  }
  .summary-bar.visible{
    display:flex;
    transform:none;
    animation:summary-inline-in 0.3s var(--ease);
  }
  .summary-bar .summary-text{text-align:center}
  .summary-bar .summary-value{white-space:normal;overflow:visible}
  .summary-bar .btn-primary{
    clip-path:none;
    width:100%;
    justify-content:center;
  }
}
@keyframes summary-inline-in{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:none}
}

.slot-loading{
  padding:40px 20px;text-align:center;color:rgba(255,255,255,0.5);font-size:14px;
  grid-column:1 / -1;
}

/* How it works timeline */
.booking-how{
  margin-top:40px;padding-top:32px;border-top:1px solid var(--line);
}
.booking-how h4{
  font-family:var(--f-display);font-size:16px;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.8);margin-bottom:20px;
}
.booking-how ol{
  list-style:none;counter-reset:how;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media (max-width:720px){.booking-how ol{grid-template-columns:1fr;gap:16px}}
.booking-how li{
  padding-left:44px;position:relative;counter-increment:how;
  font-size:14px;line-height:1.55;color:rgba(255,255,255,0.72);
}
.booking-how li::before{
  content:counter(how);
  position:absolute;left:0;top:-4px;
  font-family:var(--f-display);font-size:20px;color:var(--blood);font-weight:600;
  width:30px;height:30px;
  border:1px solid var(--blood);
  display:flex;align-items:center;justify-content:center;
}
.booking-how strong{color:#fff;font-weight:600;display:block;margin-bottom:4px;font-family:var(--f-display);text-transform:uppercase;letter-spacing:0.04em;font-size:14px}

.back-btn{
  background:none;border:none;color:rgba(255,255,255,0.6);
  font-family:var(--f-body);font-size:13px;cursor:pointer;
  padding:12px 0;margin-top:16px;letter-spacing:0.04em;
  display:inline-flex;align-items:center;gap:8px;
}
.back-btn:hover{color:#fff}

.form-error{
  background:rgba(192,39,45,0.12);border:1px solid rgba(192,39,45,0.4);
  color:#ff7a7a;padding:12px 16px;font-size:14px;margin-bottom:16px;
}

/* ═══ FAQ ═══ */
.faq{padding:var(--section) 0;background:var(--bone)}
.faq-list{max-width:860px;margin:48px auto 0}
.faq-item{
  border-bottom:1px solid var(--line-soft);
}
.faq-item:first-child{border-top:1px solid var(--line-soft)}
.faq-q{
  width:100%;padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  text-align:left;
  font-family:var(--f-display);font-size:clamp(18px,2vw,22px);text-transform:uppercase;
  color:var(--ink);letter-spacing:0.005em;
  transition:color .2s;
}
.faq-q:hover{color:var(--blood)}
.faq-icon{
  width:36px;height:36px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--ink);
  font-size:18px;font-weight:400;
  transition:transform .3s var(--ease),background .3s,border-color .3s,color .3s;
}
.faq-item.open .faq-icon{
  background:var(--blood);border-color:var(--blood);color:#fff;
  transform:rotate(180deg);
}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .4s var(--ease);
}
.faq-a-inner{
  padding:0 0 28px;
  font-size:16px;line-height:1.7;color:var(--body);
  max-width:720px;
}
.faq-a-inner strong{color:var(--ink)}
.faq-a-inner em{color:var(--ink)}

.faq-loading{
  text-align:center;padding:40px 20px;color:var(--muted);font-size:14px;
}

/* ═══ CTA BANNER ═══ */
.cta-banner{
  position:relative;
  padding:clamp(80px,10vw,120px) 0;
  background:var(--blood);color:#fff;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg,rgba(0,0,0,0.06) 0 1px,transparent 1px 24px);
  pointer-events:none;
}
.cta-banner .container{text-align:center}
.cta-banner h2{
  font-family:var(--f-display);font-size:clamp(40px,6vw,88px);
  text-transform:uppercase;color:#fff;line-height:0.95;margin-bottom:24px;
  letter-spacing:-0.01em;
}
.cta-banner p{
  font-size:18px;color:rgba(255,255,255,0.92);max-width:620px;margin:0 auto 36px;
}
.cta-banner .btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-banner .btn-white{background:#fff;color:var(--ink);border-color:#fff}
.cta-banner .btn-white:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.cta-banner .btn-outline-w{background:transparent;color:#fff;border-color:#fff}
.cta-banner .btn-outline-w:hover{background:#fff;color:var(--blood)}

/* ═══ FOOTER ═══ */
.footer{
  background:var(--ink);color:rgba(255,255,255,0.7);
  padding:80px 0 32px;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid var(--line);
}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{width:56px;height:56px;filter:invert(1);margin-bottom:16px}
.footer-brand .tag{font-family:var(--f-display);font-size:18px;color:#fff;text-transform:uppercase;letter-spacing:0.04em;line-height:1.2;margin-bottom:12px}
.footer-brand p{font-size:14px;color:rgba(255,255,255,0.6);line-height:1.6;margin-bottom:20px;max-width:280px}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);color:rgba(255,255,255,0.7);transition:all .2s;
}
.footer-social a:hover{background:var(--blood);border-color:var(--blood);color:#fff}
.footer-social svg{width:16px;height:16px}

.footer-col h4{
  font-family:var(--f-display);font-size:13px;letter-spacing:0.22em;text-transform:uppercase;
  color:#fff;margin-bottom:20px;
}
.footer-col a,.footer-col div{
  display:block;font-size:14px;color:rgba(255,255,255,0.7);
  margin-bottom:12px;line-height:1.5;transition:color .2s;
}
.footer-col a:hover{color:var(--blood)}

.footer-bottom{
  padding-top:32px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12px;color:rgba(255,255,255,0.45);letter-spacing:0.04em;
}
.footer-bottom a{color:rgba(255,255,255,0.7)}

/* ═══ MOBILE CTA BAR ═══ */
.mobile-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:102;
  background:var(--ink);border-top:1px solid var(--line);
  padding:12px 16px;
  gap:10px;
}
.mobile-cta .btn{flex:1}
.mobile-cta .call{
  width:52px;flex:0 0 52px;padding:0;
  background:#fff;color:var(--ink);border-color:#fff;
  display:flex;align-items:center;justify-content:center;
  clip-path:none;
}
.mobile-cta .call svg{width:20px;height:20px}
@media (max-width:720px){
  .mobile-cta{display:flex}
  body{padding-bottom:80px}
}

/* Small refinements */
@media (max-width:640px){
  .section-head{margin-bottom:40px}
  .hero-title{font-size:clamp(48px,12vw,88px)}
}

/* ═══════════════════════════════════════════════════════════════
   REVIEWS WIDGET - floating badge + off-canvas drawer
═══════════════════════════════════════════════════════════════ */

.reviews-badge{
  position:fixed;
  bottom:28px;right:28px;
  z-index:500;
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:50px;
  padding:10px 18px 10px 12px;
  display:flex;align-items:center;gap:10px;
  cursor:pointer;
  box-shadow:0 4px 24px rgba(0,0,0,0.45),0 1px 6px rgba(0,0,0,0.3),0 0 0 1px rgba(255,255,255,0.04);
  transition:transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  user-select:none;
}
.reviews-badge:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 32px rgba(0,0,0,0.55),0 2px 8px rgba(0,0,0,0.35),0 0 0 1px rgba(255,255,255,0.08);
  border-color:rgba(255,255,255,0.12);
}
.reviews-badge:focus-visible{outline:2px solid var(--blood);outline-offset:3px}
.reviews-badge-google{
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;background:#fff;border-radius:50%;flex-shrink:0;
}
.reviews-badge-google svg{width:16px;height:16px}
.reviews-badge-info{display:flex;flex-direction:column;gap:1px}
.reviews-badge-stars{color:#FBBC04;font-size:13px;letter-spacing:-0.5px;line-height:1}
.reviews-badge-text{
  font-size:10px;font-weight:500;letter-spacing:0.06em;
  text-transform:uppercase;color:rgba(255,255,255,0.6);line-height:1;
}
.reviews-badge-tap{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--blood);color:#fff;
  font-size:10px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;
  padding:5px 12px;border-radius:50px;margin-left:4px;white-space:nowrap;
  box-shadow:0 2px 8px rgba(69,100,253,0.3);
  transition:background 0.2s ease, box-shadow 0.2s ease;
  animation:badge-glow 2.5s ease-in-out infinite;
}
@keyframes badge-glow{
  0%,100%{box-shadow:0 2px 8px rgba(69,100,253,0.3)}
  50%{box-shadow:0 2px 14px rgba(69,100,253,0.55)}
}
.reviews-badge:hover .reviews-badge-tap{
  background:var(--blood-hot);
  box-shadow:0 4px 16px rgba(69,100,253,0.5);
}

.badge-text-desktop{display:none}
.badge-text-mobile{display:inline}

@media (min-width:961px){
  .reviews-badge{
    padding:14px 24px 14px 16px;gap:14px;border-radius:60px;
    animation:badge-entrance 0.6s cubic-bezier(0.34,1.56,0.64,1) 1.5s both;
  }
  .reviews-badge-google{width:36px;height:36px}
  .reviews-badge-google svg{width:20px;height:20px}
  .reviews-badge-stars{font-size:16px}
  .reviews-badge-text{font-size:12px}
  .reviews-badge-tap{font-size:12px;padding:8px 20px}
  .badge-text-desktop{display:inline}
  .badge-text-mobile{display:none}
}
@keyframes badge-entrance{
  0%{opacity:0;transform:translateY(24px) scale(0.9)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

.reviews-backdrop{
  position:fixed;inset:0;z-index:599;
  background:rgba(0,0,0,0);pointer-events:none;
  transition:background 0.35s ease;
}
.reviews-backdrop.open{background:rgba(0,0,0,0.55);pointer-events:all}

.reviews-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:600;
  width:420px;max-width:100vw;
  background:var(--ink-2);
  border-left:1px solid var(--line);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform 0.38s cubic-bezier(0.32,0.72,0,1);
  box-shadow:-8px 0 40px rgba(0,0,0,0.5);
}
.reviews-drawer.open{transform:translateX(0)}

.reviews-drawer-header{
  padding:24px 24px 20px;border-bottom:1px solid var(--line);
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  flex-shrink:0;
}
.reviews-drawer-title{
  font-family:var(--f-display);font-size:20px;font-weight:700;
  color:#fff;margin-bottom:8px;text-transform:uppercase;letter-spacing:0.02em;
}
.reviews-overall{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.reviews-overall-stars{color:#FBBC04;font-size:16px;letter-spacing:-0.5px}
.reviews-overall-score{font-family:var(--f-display);font-size:18px;font-weight:700;color:#fff}
.reviews-overall-count{font-size:13px;color:rgba(255,255,255,0.6)}

.reviews-verify-link{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--blood-hot);margin-top:8px;transition:color 0.2s ease;
}
.reviews-verify-link:hover{color:#8fa2ff}
.reviews-verify-link:focus-visible{outline:2px solid var(--blood);outline-offset:2px}

.reviews-close{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:16px;color:rgba(255,255,255,0.6);
  background:none;cursor:pointer;
  transition:color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}
.reviews-close:hover{color:#fff;border-color:rgba(255,255,255,0.2);background:rgba(255,255,255,0.05)}
.reviews-close:focus-visible{outline:2px solid var(--blood);outline-offset:2px}

.reviews-list{
  overflow-y:auto;flex:1;
  padding:16px 24px 32px;
  display:flex;flex-direction:column;gap:16px;
  scrollbar-width:thin;scrollbar-color:var(--line) transparent;
}

.review-card{
  background:var(--ink);border:1px solid var(--line);
  padding:20px;transition:border-color 0.2s ease;
}
.review-card:hover{border-color:rgba(255,255,255,0.12)}
.review-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.review-avatar{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:600;color:#fff;flex-shrink:0;
}
.review-avatar--photo{
  width:40px;height:40px;border-radius:50%;
  object-fit:cover;flex-shrink:0;
}
.review-meta{flex:1;min-width:0}
.review-name{
  font-size:14px;font-weight:500;color:#fff;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.review-date{font-size:11px;color:rgba(255,255,255,0.5)}
.review-stars{color:#FBBC04;font-size:13px;letter-spacing:-0.5px;margin-bottom:10px}
.review-text{font-size:13px;color:rgba(255,255,255,0.75);line-height:1.7}
.review-source{
  display:flex;align-items:center;gap:6px;margin-top:12px;
  font-size:11px;color:rgba(255,255,255,0.5);letter-spacing:0.02em;
}
.review-source svg{flex-shrink:0}

@keyframes shimmer{
  0%{background-position:-400px 0}
  100%{background-position:400px 0}
}
.review-skeleton{
  padding:20px;background:var(--ink);border:1px solid var(--line);margin-bottom:12px;
}
.review-skeleton-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.review-skeleton-avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(90deg,#2a2a2a 25%,#333 50%,#2a2a2a 75%);
  background-size:800px 100%;animation:shimmer 1.4s infinite linear;
}
.review-skeleton-meta{flex:1;display:flex;flex-direction:column;gap:8px}
.review-skeleton-line{
  height:11px;border-radius:4px;
  background:linear-gradient(90deg,#2a2a2a 25%,#333 50%,#2a2a2a 75%);
  background-size:800px 100%;animation:shimmer 1.4s infinite linear;
}
.review-skeleton-line--name{width:55%}
.review-skeleton-line--date{width:30%}
.review-skeleton-line--stars{width:70px;margin-bottom:10px}
.review-skeleton-line--short{width:45%;margin-top:6px}

.reviews-error{
  padding:32px 20px;text-align:center;
  color:rgba(255,255,255,0.6);font-size:14px;line-height:1.6;
}
.reviews-error a{
  display:inline-block;margin-top:12px;color:var(--blood-hot);
  text-decoration:none;font-size:13px;letter-spacing:0.02em;transition:opacity 0.2s ease;
}
.reviews-error a:hover{opacity:0.75}
.reviews-error a:focus-visible{outline:2px solid var(--blood);outline-offset:3px;border-radius:2px}

.reviews-empty{
  padding:32px 20px;text-align:center;
  color:rgba(255,255,255,0.5);font-size:14px;
}

@media (max-width:900px){
  .reviews-drawer{width:100vw}
  .reviews-badge{bottom:16px;right:16px}
}
@media (max-width:960px){
  .reviews-badge{
    bottom:100px;
    left:0;
    right:0;
    margin-inline:auto;
    width:fit-content;
  }
}

/* ═══════════════════════════════════════════════════════════════
   STATIC PAGE LAYOUTS (privacy, info-policies, thank-you)
═══════════════════════════════════════════════════════════════ */

.page-hero{
  background:var(--ink);color:#fff;
  padding:calc(var(--nav-h) + 80px) var(--pad) 80px;
  text-align:center;
}
.page-hero h1{
  font-family:var(--f-display);font-size:clamp(40px,6vw,72px);
  color:#fff;text-transform:uppercase;letter-spacing:-0.01em;line-height:1;
}
.page-hero h1 em{font-style:normal;color:var(--blood)}
.page-hero p{
  max-width:620px;margin:20px auto 0;
  font-size:17px;color:rgba(255,255,255,0.7);line-height:1.6;
}

.static-content{padding:80px 0;background:var(--bone)}
.static-content h2{
  font-family:var(--f-display);font-size:28px;text-transform:uppercase;
  color:var(--ink);margin-top:40px;margin-bottom:16px;
}
.static-content h2:first-child{margin-top:0}
.static-content h3{
  font-family:var(--f-display);font-size:20px;text-transform:uppercase;
  color:var(--ink);margin-top:28px;margin-bottom:12px;
}
.static-content p{margin-bottom:16px;color:var(--body);line-height:1.7}
.static-content ul{list-style:disc;padding-left:24px;margin-bottom:16px}
.static-content li{margin-bottom:8px;color:var(--body)}
.static-content a:not(.btn){color:var(--blood);text-decoration:underline}
.static-content strong{color:var(--ink)}
.static-content hr{border:0;border-top:1px solid var(--line-soft);margin:40px 0}
.static-content .muted{color:var(--muted);font-size:14px;font-style:italic}

/* Info & Policies tabs */
.tab-nav{
  display:flex;gap:4px;margin-bottom:40px;
  border-bottom:1px solid var(--line-soft);
}
.tab-btn{
  padding:16px 28px;background:none;border:0;border-bottom:3px solid transparent;
  font-family:var(--f-display);font-size:14px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--muted);cursor:pointer;transition:all .2s;
}
.tab-btn:hover{color:var(--ink)}
.tab-btn.active{color:var(--blood);border-bottom-color:var(--blood)}

.tab-panel{display:none}
.tab-panel.active{display:block}

.policy-item{
  display:flex;gap:20px;padding:20px 0;border-bottom:1px solid var(--line-soft);
}
.policy-num{
  font-family:var(--f-display);font-size:14px;font-weight:600;color:var(--blood);
  letter-spacing:0.14em;flex-shrink:0;min-width:36px;
}
.policy-body{font-size:15px;line-height:1.7;color:var(--body)}
.policy-body strong{color:var(--ink)}

.kb-count{
  font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:16px;display:inline-block;
}

/* Thank-you page */
.thankyou-card{
  max-width:720px;margin:-40px auto 0;padding:40px;
  background:#fff;border:1px solid var(--line-soft);
  position:relative;z-index:3;
}
.thankyou-confirm{
  padding:20px;background:var(--bone-2);border-left:3px solid var(--blood);
  margin-bottom:32px;
}
.thankyou-confirm .lab{
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--blood);font-weight:600;margin-bottom:6px;
}
.thankyou-confirm .val{
  font-family:var(--f-display);font-size:20px;color:var(--ink);
}

.thankyou-steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:32px 0;
}
@media (max-width:700px){.thankyou-steps{grid-template-columns:1fr}}
.thankyou-step{
  padding:24px;background:var(--bone);border:1px solid var(--line-soft);
}
.thankyou-step .num{
  font-family:var(--f-display);color:var(--blood);font-size:14px;font-weight:600;
  letter-spacing:0.18em;margin-bottom:10px;
}
.thankyou-step h4{
  font-family:var(--f-display);font-size:18px;text-transform:uppercase;
  color:var(--ink);margin-bottom:8px;
}
.thankyou-step p{font-size:14px;color:var(--body);line-height:1.5}

.expect-list{list-style:none;padding:0;margin:24px 0}
.expect-list li{
  padding:12px 0 12px 32px;position:relative;
  border-bottom:1px solid var(--line-soft);font-size:15px;color:var(--body);
}
.expect-list li::before{
  content:'✓';position:absolute;left:0;top:14px;
  color:#fff;background:var(--blood);
  width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;
}
