/* Ironwood Fitness — fitness studio & personal training, Kharkiv.
   Concept: high-voltage black + lime energy; Archivo display + Inter body;
   overlay-image hero with bold lime slash accent. Raw, kinetic, zero fluff. */

:root {
  --bg: #0d0d0d;
  --surface: #141414;
  --surface-2: #1c1c1c;
  --ink: #f0f0f0;
  --muted: #888888;
  --primary: #c6f135;
  --primary-ink: #0d0d0d;
  --accent: #c6f135;
  --accent-dark: #9fc000;
  --border: #2a2a2a;
  --border-bright: #3a3a3a;
  --radius: 6px;
  --radius-lg: 12px;
  --shadow: 0 12px 32px -10px rgba(0,0,0,.8);
  --shadow-lime: 0 0 40px -10px rgba(198,241,53,.25);
  --maxw: 1180px;
  --pad: clamp(1rem, 4vw, 2.5rem);
  --h1: clamp(2.6rem, 6.5vw, 4.2rem);
  --h2: clamp(1.7rem, 3.5vw, 2.6rem);
  --font-head: 'Archivo', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
.nav-lock { overflow: hidden; }

h1, h2, h3 {
  font-family: var(--font-head);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -.02em;
  text-transform: uppercase;
}
h1 { font-size: var(--h1); margin: 0 0 .45em; }
h2 { font-size: var(--h2); margin: 0 0 .5em; }
h3 { font-size: 1.15rem; margin: 0 0 .4em; letter-spacing: -.01em; }
p { margin: 0 0 1rem; }
a { color: inherit; }
img { max-width: 100%; display: block; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.section { padding: clamp(3.5rem, 9vw, 7rem) 0; }
.section--alt { background: var(--surface); border-block: 1px solid var(--border); }
.section--dark { background: var(--surface-2); border-block: 1px solid var(--border); }

.eyebrow {
  text-transform: uppercase;
  letter-spacing: .2em;
  font-size: .72rem;
  font-weight: 700;
  color: var(--primary);
  margin: 0 0 .9rem;
  display: block;
}
.lead { font-size: 1.1rem; color: var(--muted); max-width: 58ch; }
.center { text-align: center; margin-inline: auto; }

/* ── BUTTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .9rem 1.7rem;
  border-radius: var(--radius);
  font-family: var(--font-head);
  font-weight: 700;
  font-size: .92rem;
  text-transform: uppercase;
  letter-spacing: .07em;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn--primary {
  background: var(--primary);
  color: var(--primary-ink);
  border-color: var(--primary);
}
.btn--primary:hover { background: #d4f84a; border-color: #d4f84a; box-shadow: var(--shadow-lime); }
.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--border-bright);
}
.btn--ghost:hover { border-color: var(--primary); color: var(--primary); }
.btn--outline-lime {
  background: transparent;
  color: var(--primary);
  border-color: var(--primary);
}
.btn--outline-lime:hover { background: var(--primary); color: var(--primary-ink); }

/* ── HEADER / NAV ── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(13,13,13,.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
}
.brand {
  font-family: var(--font-head);
  font-weight: 900;
  font-size: 1.2rem;
  text-decoration: none;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: .5rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.brand-mark {
  width: 28px;
  height: 28px;
  background: var(--primary);
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.brand-mark svg { width: 16px; height: 16px; }
.nav-menu {
  display: flex;
  align-items: center;
  gap: 1.8rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-menu a {
  text-decoration: none;
  font-weight: 600;
  font-size: .88rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  transition: color .15s;
}
.nav-menu a:hover { color: var(--primary); }
.nav-menu .btn { padding: .55rem 1.2rem; color: var(--primary-ink); }
.nav-menu .btn:hover { color: var(--primary-ink); }

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: 0;
  cursor: pointer;
  padding: 8px;
}
.nav-toggle span { width: 26px; height: 2px; background: var(--ink); transition: .25s; display: block; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── HERO (overlay-image) ── */
.hero {
  position: relative;
  min-height: clamp(520px, 85vh, 860px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}
.hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    170deg,
    rgba(13,13,13,.15) 0%,
    rgba(13,13,13,.55) 40%,
    rgba(13,13,13,.92) 100%
  );
}
/* Signature lime slash */
.hero__bg::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 4px;
  height: 100%;
  background: var(--primary);
  z-index: 2;
  box-shadow: var(--shadow-lime);
}
.hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: clamp(2.5rem, 6vw, 5rem) 0 clamp(3rem, 7vw, 6rem);
}
.hero__inner { max-width: 680px; }
.hero__inner h1 { color: #fff; line-height: 1; }
.hero__inner h1 em {
  font-style: normal;
  color: var(--primary);
}
.hero__inner .lead { color: rgba(240,240,240,.75); max-width: 52ch; margin-bottom: 1.6rem; }
.hero__cta { display: flex; gap: .8rem; flex-wrap: wrap; }
.hero__strip {
  margin-top: 2.5rem;
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  align-items: center;
  padding-top: 1.6rem;
  border-top: 1px solid rgba(198,241,53,.2);
}
.hero__strip-item { font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; color: rgba(240,240,240,.6); }
.hero__strip-item strong { color: var(--primary); font-family: var(--font-head); font-size: 1.5rem; display: block; letter-spacing: -.02em; }

/* ── STATS BAND ── */
.stats-band {
  background: var(--primary);
  padding: clamp(2rem, 5vw, 3rem) 0;
}
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; text-align: center; }
.stat__value {
  font-family: var(--font-head);
  font-size: clamp(2.2rem, 4.5vw, 3.2rem);
  color: var(--primary-ink);
  font-weight: 900;
  line-height: 1;
}
.stat__label { color: rgba(13,13,13,.7); font-size: .82rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; margin-top: .3rem; }

/* ── GRIDS ── */
.grid { display: grid; gap: 1.2rem; }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.grid--4 { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }

/* ── CARDS ── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.7rem;
  position: relative;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.card:hover { border-color: var(--primary); box-shadow: 0 0 0 1px var(--primary), var(--shadow-lime); }
.card--media { padding: 0; display: flex; flex-direction: column; }
.card--media img { width: 100%; height: 210px; object-fit: cover; flex-shrink: 0; }
.card--media .card__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.card--media .card__body ul { margin-top: auto; padding-top: .7rem; }
.card ul { margin: .7rem 0 0; padding-left: 1.1rem; color: var(--muted); }
.card li { margin: .25rem 0; font-size: .93rem; }
.card .card__num {
  font-family: var(--font-head);
  font-size: 3.5rem;
  font-weight: 900;
  color: rgba(198,241,53,.08);
  position: absolute;
  top: .5rem;
  right: 1rem;
  line-height: 1;
  pointer-events: none;
  letter-spacing: -.04em;
}
.tag {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-bottom: .4rem;
  border: 1px solid rgba(198,241,53,.3);
  padding: .15rem .55rem;
  border-radius: 3px;
}

/* ── SPLIT FEATURE ── */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: center;
}
.split img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  width: 100%;
  object-fit: cover;
  aspect-ratio: 4/3;
}
.split--reverse { }
.split--reverse > *:first-child { order: 2; }
.split--reverse > *:last-child { order: 1; }

/* ── PROCESS STEPS ── */
.steps { display: grid; gap: 1px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.step {
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 2rem 1.5rem;
  position: relative;
}
.step:first-child { border-radius: var(--radius-lg) 0 0 var(--radius-lg); }
.step:last-child { border-radius: 0 var(--radius-lg) var(--radius-lg) 0; }
.step::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 100%;
  background: var(--border);
}
.step.active::before, .step:hover::before { background: var(--primary); }
.step__num {
  font-family: var(--font-head);
  font-size: .75rem;
  font-weight: 700;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: .18em;
  margin-bottom: .8rem;
  display: block;
}
.step h3 { color: var(--ink); }
.step p { color: var(--muted); font-size: .92rem; margin: 0; }

/* ── WHY US ── */
.why-grid { display: grid; gap: 1.2rem; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
.why-card {
  border-left: 3px solid var(--primary);
  padding: 1.4rem 1.4rem 1.4rem 1.6rem;
  background: var(--surface);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
}
.why-card h3 { color: var(--ink); font-size: 1.05rem; }
.why-card p { color: var(--muted); font-size: .92rem; margin: 0; }

/* ── TESTIMONIALS ── */
.quote {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.8rem;
  position: relative;
}
.quote::before {
  content: '\201C';
  font-family: var(--font-head);
  font-size: 5rem;
  line-height: .8;
  color: var(--primary);
  opacity: .3;
  position: absolute;
  top: 1rem;
  left: 1.2rem;
}
.quote p { font-size: 1rem; color: var(--ink); font-style: italic; padding-top: 2.2rem; margin: 0; }
.quote footer { margin-top: 1rem; font-style: normal; font-weight: 700; font-size: .9rem; color: var(--ink); }
.quote footer span { display: block; font-weight: 400; color: var(--muted); font-size: .82rem; margin-top: .2rem; }

/* ── FAQ ── */
.faq details {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.1rem 1.4rem;
  margin-bottom: .7rem;
  transition: border-color .15s;
}
.faq details:hover { border-color: var(--border-bright); }
.faq details[open] { border-color: var(--primary); }
.faq summary {
  cursor: pointer;
  font-weight: 700;
  font-family: var(--font-head);
  font-size: .95rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--ink);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: '+';
  color: var(--primary);
  font-size: 1.4rem;
  line-height: 1;
  flex-shrink: 0;
}
.faq details[open] summary::after { content: '–'; }
.faq details p { margin: .8rem 0 0; color: var(--muted); font-size: .95rem; }

/* ── CTA BANNER ── */
.cta-banner {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  padding: clamp(3rem, 7vw, 5.5rem) clamp(1.5rem, 5vw, 4rem);
  text-align: center;
  color: #fff;
}
.cta-banner__bg {
  position: absolute;
  inset: 0;
}
.cta-banner__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cta-banner__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(13,13,13,.85), rgba(13,13,13,.95));
}
.cta-banner__content {
  position: relative;
  z-index: 2;
}
.cta-banner h2 { color: #fff; }
.cta-banner h2 em { font-style: normal; color: var(--primary); }
.cta-banner p { color: rgba(255,255,255,.7); max-width: 48ch; margin-inline: auto; }

/* ── PAGE HERO (inner pages) ── */
.page-hero {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: clamp(3rem, 8vw, 6rem) 0;
  position: relative;
  overflow: hidden;
}
.page-hero::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), transparent);
}
.page-hero .eyebrow { color: var(--primary); }
.page-hero h1 { color: var(--ink); max-width: 800px; }
.page-hero p { color: var(--muted); max-width: 60ch; }

/* ── CONTACT ── */
.contact-grid {
  display: grid;
  grid-template-columns: 1.3fr .7fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.field { margin-bottom: 1.1rem; }
.field label {
  display: block;
  font-weight: 600;
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: .4rem;
  color: var(--muted);
}
.field input,
.field textarea,
.field select {
  width: 100%;
  padding: .85rem 1rem;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font: inherit;
  font-size: .95rem;
  background: var(--surface-2);
  color: var(--ink);
  transition: border-color .15s, box-shadow .15s;
}
.field input:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(198,241,53,.15);
}
.check { display: flex; gap: .65rem; align-items: flex-start; font-size: .9rem; color: var(--muted); margin-bottom: .5rem; }
.check input { margin-top: .25rem; accent-color: var(--primary); width: auto; }
.check a { color: var(--primary); }
.form-note { margin-top: .7rem; font-size: .9rem; min-height: 1.2em; }
.form-note.error { color: #ff5c5c; }
.form-note.ok { color: var(--primary); }
.contact-info-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem;
}
.info-list { list-style: none; padding: 0; margin: 0; }
.info-list li { padding: .85rem 0; border-bottom: 1px solid var(--border); }
.info-list li:last-child { border-bottom: none; }
.info-list strong {
  display: block;
  color: var(--primary);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-bottom: .2rem;
}
.info-list a { color: var(--ink); text-decoration: none; }
.info-list a:hover { color: var(--primary); }
.map-box {
  margin-top: 1.5rem;
  height: 190px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: repeating-linear-gradient(
    45deg,
    #1a1a1a,
    #1a1a1a 12px,
    #141414 12px,
    #141414 24px
  );
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .1em;
}

/* ── LEGAL PAGES ── */
.legal { max-width: 760px; margin: 0 auto; }
.legal h2 { margin-top: 2.2rem; font-size: 1.35rem; text-transform: none; letter-spacing: -.01em; }
.legal h3 { margin-top: 1.5rem; font-size: 1.05rem; text-transform: none; }
.legal p { color: var(--muted); }
.legal ul { color: var(--muted); padding-left: 1.2rem; }
.legal li { margin: .4rem 0; }
.legal a { color: var(--primary); }
.legal .updated { color: var(--muted); font-size: .88rem; margin-bottom: 2rem; display: block; }

/* ── FOOTER ── */
.site-footer {
  background: #080808;
  border-top: 1px solid var(--border);
  color: var(--muted);
  padding: 4rem 0 1.8rem;
  margin-top: 0;
}
.site-footer a { color: var(--muted); text-decoration: none; transition: color .15s; }
.site-footer a:hover { color: var(--primary); }
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 2.5rem;
  margin-bottom: 3rem;
}
.footer-brand { margin-bottom: .8rem; }
.footer-brand .brand { color: var(--ink); }
.footer-grid p { font-size: .9rem; max-width: 30ch; line-height: 1.6; }
.footer-grid h4 {
  color: var(--ink);
  font-family: var(--font-head);
  font-weight: 700;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .15em;
  margin: 0 0 1rem;
}
.footer-grid ul { list-style: none; padding: 0; margin: 0; }
.footer-grid li { margin: .5rem 0; font-size: .9rem; }
.footer-bottom {
  border-top: 1px solid var(--border);
  padding-top: 1.3rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .7rem;
  font-size: .82rem;
  color: #888;
}
.footer-bottom span { display: flex; align-items: center; gap: .4rem; }

/* ── COOKIE BANNER ── */
.cookie {
  position: fixed;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 80;
  background: #1a1a1a;
  border: 1px solid var(--border-bright);
  color: var(--ink);
  border-radius: var(--radius-lg);
  padding: 1.2rem 1.5rem;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,.9);
  display: flex;
  gap: 1.2rem;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 720px;
  margin: 0 auto;
}
.cookie p { margin: 0; font-size: .9rem; }
.cookie a { color: var(--primary); }
.cookie__btns { display: flex; gap: .6rem; flex-shrink: 0; }
.cookie .btn { padding: .55rem 1.1rem; font-size: .85rem; }

/* ── VALUES GRID (about page) ── */
.values-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.value-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.8rem 1.6rem;
  border-top: 3px solid var(--primary);
}
.value-card h3 { color: var(--ink); margin-bottom: .5rem; font-size: 1rem; }
.value-card p { color: var(--muted); font-size: .92rem; margin: 0; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .nav-toggle { display: flex; }
  .nav-menu {
    position: fixed;
    inset: 60px 0 auto 0;
    flex-direction: column;
    align-items: flex-start;
    gap: .3rem;
    background: #111;
    border-bottom: 1px solid var(--border);
    padding: 1.2rem var(--pad);
    transform: translateY(-130%);
    transition: transform .3s ease, visibility .3s;
    box-shadow: 0 20px 40px -10px rgba(0,0,0,.8);
    z-index: 49;
    visibility: hidden;
    pointer-events: none;
  }
  .nav-menu.is-open {
    transform: translateY(0);
    visibility: visible;
    pointer-events: auto;
  }
  .nav-menu li { width: 100%; }
  .nav-menu a { display: block; padding: .6rem 0; width: 100%; font-size: 1rem; }
  .nav-menu .btn { width: 100%; justify-content: center; margin-top: .6rem; }
  .split { grid-template-columns: 1fr; }
  .split--reverse > *:first-child { order: unset; }
  .split--reverse > *:last-child { order: unset; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .step:first-child, .step:last-child { border-radius: var(--radius-lg); }
  .steps { gap: 1rem; }
}
@media (max-width: 600px) {
  .hero__strip { gap: 1.2rem; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .cta-banner { padding: 2.5rem 1.2rem; }
}
@media (max-width: 360px) {
  :root { --pad: .75rem; }
  .stats { grid-template-columns: 1fr 1fr; gap: .7rem; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; scroll-behavior: auto; }
}


/* === QA pass: consent checkbox + form row normalization === */
.field.check{display:flex !important;gap:.6rem;align-items:flex-start;flex-wrap:nowrap}
.field.check input[type="checkbox"]{
  width:18px !important;height:18px !important;min-width:18px;max-width:18px;
  flex:0 0 18px;margin:.18rem 0 0 0;padding:0;box-sizing:border-box}
.field.check label{margin:0;font-weight:400;line-height:1.5;flex:1 1 auto}

/* enrichment sections */

/* ── PRICING PLANS ── */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.2rem;
  align-items: stretch;
}
.pricing-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem 1.8rem;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: border-color .2s, box-shadow .2s;
}
.pricing-card:hover { border-color: var(--border-bright); }
.pricing-card--featured {
  border-color: var(--primary);
  box-shadow: var(--shadow-lime);
}
.pricing-card--featured:hover { box-shadow: 0 0 0 1px var(--primary), var(--shadow-lime); }
.pricing-badge {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--primary);
  color: var(--primary-ink);
  font-family: var(--font-head);
  font-size: .65rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .18em;
  padding: .2rem .8rem;
  border-radius: 20px;
  white-space: nowrap;
}
.pricing-card__name {
  font-family: var(--font-head);
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--primary);
  margin-bottom: .6rem;
}
.pricing-card__price {
  font-family: var(--font-head);
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 900;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -.03em;
  margin-bottom: .3rem;
}
.pricing-card__price sup {
  font-size: .55em;
  font-weight: 700;
  vertical-align: super;
  color: var(--muted);
}
.pricing-card__price span {
  font-size: .55em;
  color: var(--muted);
  font-weight: 500;
  letter-spacing: 0;
}
.pricing-card__desc {
  color: var(--muted);
  font-size: .9rem;
  margin: .5rem 0 1.4rem;
  line-height: 1.55;
}
.pricing-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 1.8rem;
  flex: 1;
}
.pricing-card__features li {
  padding: .5rem 0;
  border-bottom: 1px solid var(--border);
  font-size: .92rem;
  color: var(--ink);
  display: flex;
  align-items: flex-start;
  gap: .55rem;
}
.pricing-card__features li:last-child { border-bottom: none; }
.pricing-card__features li::before {
  content: '✓';
  color: var(--primary);
  font-weight: 900;
  font-size: .85rem;
  margin-top: .05rem;
  flex-shrink: 0;
}
.pricing-card__features li.dim { color: var(--muted); }
.pricing-card__features li.dim::before { color: var(--border-bright); content: '–'; }
.pricing-card .btn { width: 100%; justify-content: center; }

/* ── CLIENT RESULTS / CASE CARDS ── */
.result-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.8rem;
  display: flex;
  flex-direction: column;
  gap: .7rem;
  transition: border-color .2s, box-shadow .2s;
}
.result-card:hover { border-color: var(--primary); box-shadow: 0 0 0 1px var(--primary), var(--shadow-lime); }
.result-card__metric {
  font-family: var(--font-head);
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 900;
  color: var(--primary);
  line-height: 1;
  letter-spacing: -.03em;
}
.result-card__label {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--muted);
  margin-top: -.4rem;
}
.result-card__body { color: var(--ink); font-size: .95rem; line-height: 1.6; flex: 1; }
.result-card__client {
  font-size: .82rem;
  color: var(--muted);
  border-top: 1px solid var(--border);
  padding-top: .7rem;
  font-style: italic;
}

/* ── TEAM GRID ── */
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.2rem;
}
.team-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.8rem 1.6rem;
  text-align: center;
  transition: border-color .2s;
}
.team-card:hover { border-color: var(--primary); }
.team-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head);
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--primary);
  margin: 0 auto 1rem;
  flex-shrink: 0;
}
.team-card__name {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 800;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: -.01em;
  margin-bottom: .15rem;
}
.team-card__role {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--primary);
  font-weight: 700;
  margin-bottom: .6rem;
}
.team-card__bio {
  font-size: .88rem;
  color: var(--muted);
  line-height: 1.55;
}
.team-card__certs {
  margin-top: .8rem;
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
  justify-content: center;
}
.cert-chip {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--primary);
  border: 1px solid rgba(198,241,53,.25);
  padding: .1rem .45rem;
  border-radius: 3px;
}

/* ── CERTIFICATIONS / PARTNERS STRIP ── */
.cert-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  padding: 1.6rem 0 .4rem;
}
.cert-badge {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .7rem 1.3rem;
  display: flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--font-head);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--muted);
  transition: border-color .2s, color .2s;
}
.cert-badge:hover { border-color: var(--primary); color: var(--ink); }
.cert-badge__icon {
  width: 28px;
  height: 28px;
  background: rgba(198,241,53,.12);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  flex-shrink: 0;
}

/* ── PROGRESS BAND (secondary stats) ── */
.progress-band { background: var(--surface-2); border-block: 1px solid var(--border); padding: clamp(2.5rem, 6vw, 4rem) 0; }
.progress-items { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 2rem; }
.progress-item__label {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--muted);
  margin-bottom: .5rem;
}
.progress-bar {
  height: 6px;
  background: var(--border);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: .4rem;
}
.progress-bar__fill {
  height: 100%;
  background: var(--primary);
  border-radius: 3px;
}
.progress-item__value {
  font-family: var(--font-head);
  font-size: .88rem;
  font-weight: 700;
  color: var(--primary);
}

/* ── COMPARISON TABLE ── */
.compare-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.compare-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 600px;
  font-size: .92rem;
}
.compare-table th, .compare-table td {
  padding: .9rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.compare-table thead th {
  font-family: var(--font-head);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--muted);
  background: var(--surface-2);
  font-weight: 700;
  vertical-align: bottom;
}
.compare-table thead th:first-child { border-radius: var(--radius-lg) 0 0 0; }
.compare-table thead th:last-child { border-radius: 0 var(--radius-lg) 0 0; }
.compare-table tbody tr:hover td { background: rgba(198,241,53,.03); }
.compare-table td:first-child { color: var(--ink); font-weight: 500; }
.compare-table td { color: var(--muted); }
.compare-table td.yes { color: var(--primary); font-weight: 700; }
.compare-table td.no { color: var(--muted); }
.compare-table .col-featured { background: rgba(198,241,53,.05); border-left: 2px solid var(--primary); border-right: 2px solid var(--primary); }
.compare-table thead .col-featured { border-top: 2px solid var(--primary); color: var(--primary); }
.compare-table tbody tr:last-child .col-featured { border-bottom: 2px solid var(--primary); border-radius: 0 0 var(--radius) var(--radius); }

/* ── INSIGHTS / NEWS CARDS ── */
.news-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.8rem;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  transition: border-color .2s, box-shadow .2s;
}
.news-card:hover { border-color: var(--primary); box-shadow: 0 0 0 1px var(--primary), var(--shadow-lime); }
.news-card__date {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--primary);
}
.news-card__title {
  font-family: var(--font-head);
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: -.01em;
  line-height: 1.2;
}
.news-card__body { font-size: .92rem; color: var(--muted); line-height: 1.6; flex: 1; }
.news-card__tag { margin-top: auto; }

/* ── MILESTONES TIMELINE (about page) ── */
.timeline { position: relative; padding-left: 2.4rem; }
.timeline::before {
  content: '';
  position: absolute;
  left: 0;
  top: .4rem;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--primary), var(--border));
}
.timeline-item {
  position: relative;
  padding-bottom: 2.4rem;
}
.timeline-item:last-child { padding-bottom: 0; }
.timeline-item::before {
  content: '';
  position: absolute;
  left: -2.4rem;
  top: .4rem;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--primary);
  border: 2px solid var(--bg);
  box-shadow: 0 0 0 2px var(--primary);
}
.timeline-item__year {
  font-family: var(--font-head);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--primary);
  margin-bottom: .25rem;
}
.timeline-item__title {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 800;
  color: var(--ink);
  text-transform: uppercase;
  margin-bottom: .35rem;
}
.timeline-item__body { font-size: .92rem; color: var(--muted); line-height: 1.6; max-width: 55ch; }

/* ── GUARANTEE CARDS ── */
.guarantee-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.2rem;
}
.guarantee-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.8rem;
  display: flex;
  flex-direction: column;
  gap: .7rem;
  transition: border-color .2s;
}
.guarantee-card:hover { border-color: var(--primary); }
.guarantee-icon {
  width: 48px;
  height: 48px;
  background: rgba(198,241,53,.1);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}
.guarantee-card__title {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 800;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: -.01em;
}
.guarantee-card__body { font-size: .92rem; color: var(--muted); line-height: 1.6; }

/* ── RESPONSIVE: enrichment sections ── */
@media (max-width: 900px) {
  .pricing-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
  .team-grid { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
  .progress-items { grid-template-columns: repeat(2, 1fr); }
  .timeline { padding-left: 1.8rem; }
  .timeline-item::before { left: -1.8rem; }
}
@media (max-width: 600px) {
  .pricing-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .progress-items { grid-template-columns: 1fr 1fr; }
  .cert-strip { gap: .6rem; }
  .cert-badge { padding: .55rem .9rem; font-size: .65rem; }
  .guarantee-grid { grid-template-columns: 1fr; }
}
@media (max-width: 360px) {
  .team-grid { grid-template-columns: 1fr; }
  .progress-items { grid-template-columns: 1fr; }
}


/* === QA pass 2: contain negative-z overlays so light text never falls on a light bg === */
.cta-banner{isolation:isolate;position:relative}
.hero{isolation:isolate}
.page-hero{isolation:isolate}
.hero__media,.hero-media{isolation:isolate}

/* polish: depth */

/* Hero — richer gradient overlay with a faint lime glow from bottom-left */
.hero__bg::after {
  background: linear-gradient(
    160deg,
    rgba(13,13,13,.10) 0%,
    rgba(13,13,13,.50) 35%,
    rgba(13,13,13,.90) 75%,
    rgba(13,13,13,.97) 100%
  ),
  radial-gradient(ellipse 60% 50% at 0% 100%, rgba(198,241,53,.06) 0%, transparent 70%);
}

/* Stats band — subtle two-stop inner gradient so it doesn't read as flat lime block */
.stats-band {
  background: linear-gradient(135deg, #bfe82e 0%, #c6f135 50%, #d2f54a 100%);
}

/* Section --alt — faint radial glow at top-right for warmth */
.section--alt {
  background:
    radial-gradient(ellipse 70% 55% at 100% 0%, rgba(198,241,53,.04) 0%, transparent 65%),
    var(--surface);
}

/* Section --dark — subtle diagonal tint */
.section--dark {
  background:
    linear-gradient(135deg, rgba(198,241,53,.025) 0%, transparent 60%),
    var(--surface-2);
}

/* Progress band — a restrained radial glow */
.progress-band {
  background:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(198,241,53,.05) 0%, transparent 70%),
    var(--surface-2);
}

/* Process steps row — hairline top accent */
.steps {
  border-top: 2px solid rgba(198,241,53,.15);
  padding-top: 1px;
}

/* CTA banner — add a secondary lime glow to the existing overlay */
.cta-banner__bg::after {
  background: linear-gradient(135deg, rgba(13,13,13,.82) 0%, rgba(13,13,13,.96) 100%),
    radial-gradient(ellipse 60% 70% at 20% 80%, rgba(198,241,53,.07) 0%, transparent 65%);
}

/* Pricing section — subtle background tint behind the cards */
#pricing {
  background:
    radial-gradient(ellipse 55% 45% at 50% 0%, rgba(198,241,53,.04) 0%, transparent 60%),
    var(--bg);
}

/* Services grid — very faint lime glow emanating from centre */
#services {
  background:
    radial-gradient(ellipse 70% 50% at 50% 50%, rgba(198,241,53,.03) 0%, transparent 65%),
    var(--bg);
}

/* FAQ section — hairline left-edge accent behind the container */
.faq details[open] {
  background: linear-gradient(90deg, rgba(198,241,53,.04) 0%, transparent 40%), var(--surface);
}


/* === QA pass 3: hidden-attr must win so cookie banner truly dismisses === */
[hidden]{display:none!important}

/* TV1 — Featured single quote */
.tv1{max-width:60rem;margin:0 auto;text-align:center}
.tv1__mark{display:block;font-size:5rem;line-height:.6;color:var(--accent);font-family:Georgia,serif}
.tv1__quote{font-size:clamp(1.4rem,3.2vw,2.15rem);line-height:1.4;color:var(--ink);font-weight:500;margin:.5rem 0 1.4rem;border:0;padding:0}
.tv1__author{color:var(--muted);font-weight:700;letter-spacing:.02em}

/* RV1 — Results as oversized metric band */
.rv1{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem;text-align:center}
.rv1__item{padding:1rem;border-left:2px solid var(--border)}
.rv1__item:first-child{border-left:0}
.rv1__item strong{display:block;font-size:clamp(2rem,4vw,3rem);color:var(--accent);line-height:1}
.rv1__item span{display:block;margin-top:.6rem;color:var(--muted);font-size:.9rem;line-height:1.4}
@media(max-width:760px){.rv1__item{border-left:0}}

/* WV2 — Why-us as big accent-bar rows (single column) */
.wv2{display:grid;gap:1.2rem;max-width:62rem;margin:0 auto}
.wv2__item{padding:1.4rem 1.6rem;border-left:4px solid var(--accent);background:var(--surface);border-radius:0 10px 10px 0}
.wv2__item h3{margin:0 0 .3rem;color:var(--ink)}
.wv2__item p{margin:0;color:var(--muted);line-height:1.55}

/* PV2 — Process as vertical left-rail timeline */
.pv2{list-style:none;margin:0 auto;padding:0;max-width:48rem;position:relative}
.pv2__step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:1.2rem;padding:0 0 2rem 0}
.pv2__step::before{content:"";position:absolute;left:1.05rem;top:2.2rem;bottom:0;width:2px;background:var(--border)}
.pv2__step:last-child::before{display:none}
.pv2__n{width:2.2rem;height:2.2rem;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:var(--bg);font-weight:800;position:relative;z-index:1}
.pv2__step h3{margin:.2rem 0 .3rem;color:var(--ink)}
.pv2__step p{margin:0;color:var(--muted);line-height:1.55}

/* === uniq-layout-system START === */ w:1180,h:hairline,s:rows,n:border,f:brandled,c:soft */
:root{--maxw:1180px}
.section .center{text-align:left;margin-inline:0}
.section .eyebrow.center{display:block;border-top:2px solid var(--ink);padding-top:1rem;width:100%}
.section h2.center{font-size:clamp(1.9rem,4.3vw,3rem);line-height:1.1}
.section .lead.center{max-width:62ch}
.site-header{border-top:4px solid var(--accent)}
.nav{padding:1.05rem 0}
.card{border-radius:16px;box-shadow:0 12px 30px rgba(0,0,0,.08)}
#services .grid{display:grid !important;grid-template-columns:1fr !important;gap:1.4rem}
#services .card{display:grid;grid-template-columns:300px 1fr;align-items:stretch;border-radius:14px;overflow:hidden;padding:0}
#services .card>img{width:100%;height:100%;min-height:190px;object-fit:cover;border-radius:0}
#services .card__body{padding:1.6rem 1.8rem}
@media(max-width:680px){#services .card{grid-template-columns:1fr}}
.footer-grid{grid-template-columns:1.7fr 1fr 1fr;gap:2.5rem;border-top:1px solid var(--border);padding-top:.3rem}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr !important;text-align:left !important}.footer-grid>:first-child{grid-column:auto;order:0}}
/* === uniq-layout-system END === */


/* =====================================================================
   ENHANCEMENTS 2026 — global scale-up + topbar, marquee, gallery,
   parallax, stats-v2, rich footer, scroll reveal.
   Stays inside the constitution: black + lime, Archivo/Inter, lime slash.
   ===================================================================== */

/* ── GLOBAL SCALE-UP (desktop legibility) ── */
:root{
  --maxw: 1340px;
  --h1: clamp(2.9rem, 6.4vw, 5.2rem);
  --h2: clamp(2.05rem, 4.2vw, 3.4rem);
}
body{ font-size: 17px; }
@media (min-width:1280px){ body{ font-size: 18px; } }
.lead{ font-size: 1.2rem; line-height: 1.7; }
.section{ padding: clamp(4rem, 9vw, 8rem) 0; }
.section h2.center{ font-size: clamp(2.05rem, 4.6vw, 3.4rem); line-height: 1.08; }
.section .lead.center{ max-width: 64ch; }
.eyebrow{ font-size: .8rem; }
.brand{ font-size: 1.35rem; }
.nav-menu a{ font-size: .95rem; }
.nav-menu .btn{ font-size: .92rem; }
h3{ font-size: 1.28rem; }
.btn{ font-size: 1rem; }
.card li{ font-size: 1rem; }
.hero__inner .lead{ font-size: 1.25rem; }
.hero__strip-item strong{ font-size: 1.8rem; }

/* ── TOP UTILITY BAR ── */
.topbar{ background:#070707; border-bottom:1px solid var(--border); font-size:.82rem; color:var(--muted); }
.topbar__inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.5rem 0; flex-wrap:wrap; }
.topbar__hours{ margin:0; display:flex; align-items:center; gap:.5rem; letter-spacing:.02em; }
.topbar__open{ color:var(--primary); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:.74rem; }
.topbar__right{ display:flex; align-items:center; gap:1.4rem; }
.topbar__loc{ display:flex; align-items:center; gap:.4rem; }
.topbar__phone{ display:flex; align-items:center; gap:.4rem; color:var(--ink); text-decoration:none; font-weight:600; }
.topbar__phone:hover{ color:var(--primary); }
.topbar__ic{ width:15px; height:15px; color:var(--primary); flex-shrink:0; }
.topbar__socials{ display:flex; align-items:center; gap:.7rem; }
.topbar__socials a{ color:var(--muted); display:inline-flex; }
.topbar__socials a:hover{ color:var(--primary); }
.topbar__socials svg{ width:16px; height:16px; }
@media (max-width:860px){ .topbar__loc{ display:none; } .topbar__hours{ font-size:.74rem; } }
@media (max-width:560px){ .topbar__inner{ justify-content:center; } .topbar__hours{ display:none; } .topbar__right{ gap:1.1rem; } }

/* ── KINETIC MARQUEE ── */
.marquee{ overflow:hidden; background:var(--primary); border-block:3px solid var(--bg); padding:.55rem 0; white-space:nowrap; }
.marquee__track{ display:inline-flex; align-items:center; gap:1.4rem; padding-left:1.4rem; animation:ironwood-marquee 38s linear infinite; will-change:transform; }
.marquee__word{ font-family:var(--font-head); font-weight:900; font-size:clamp(1.4rem,3vw,2.6rem); text-transform:uppercase; letter-spacing:-.01em; color:var(--bg); line-height:1; }
.marquee__word--out{ color:transparent; -webkit-text-stroke:1.5px rgba(13,13,13,.65); }
.marquee__star{ color:var(--bg); font-size:.9rem; opacity:.55; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
@keyframes ironwood-marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee__track{ animation:none; } }

/* ── GALLERY CAROUSEL ── */
.carousel{ position:relative; margin-top:2.6rem; }
.carousel__viewport{ overflow-x:auto; overflow-y:hidden; scroll-snap-type:x mandatory; scroll-behavior:smooth; scrollbar-width:none; -webkit-overflow-scrolling:touch; cursor:grab; }
.carousel__viewport::-webkit-scrollbar{ display:none; }
.carousel__viewport.is-dragging{ cursor:grabbing; scroll-snap-type:none; scroll-behavior:auto; }
.carousel__viewport:focus-visible{ outline:2px solid var(--primary); outline-offset:4px; border-radius:var(--radius-lg); }
.carousel__track{ display:flex; gap:1rem; padding:0 var(--pad); }
.slide{ position:relative; flex:0 0 clamp(280px,42vw,460px); margin:0; scroll-snap-align:center; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); background:var(--surface); }
.slide img{ width:100%; height:clamp(280px,32vw,400px); object-fit:cover; display:block; transition:transform .5s ease; }
.slide:hover img{ transform:scale(1.05); }
.slide figcaption{ position:absolute; left:0; right:0; bottom:0; padding:2.6rem 1.2rem 1rem; background:linear-gradient(to top,rgba(13,13,13,.94),rgba(13,13,13,.55) 55%,transparent); color:#fff; font-family:var(--font-head); font-weight:800; text-transform:uppercase; font-size:.98rem; letter-spacing:.01em; display:flex; align-items:center; gap:.6rem; }
.slide__num{ color:var(--primary); font-size:.8rem; letter-spacing:.1em; }
.carousel__btn{ position:absolute; top:calc(50% - 1.4rem); transform:translateY(-50%); width:54px; height:54px; border-radius:50%; border:0; background:var(--primary); color:var(--primary-ink); display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:3; box-shadow:var(--shadow); transition:transform .15s ease, background .15s ease; }
.carousel__btn svg{ width:24px; height:24px; }
.carousel__btn:hover{ background:#d4f84a; transform:translateY(-50%) scale(1.08); }
.carousel__btn--prev{ left:.5rem; }
.carousel__btn--next{ right:.5rem; }
.carousel__btn[disabled]{ opacity:.3; pointer-events:none; }
.carousel__dots{ display:flex; justify-content:center; gap:.5rem; margin-top:1.6rem; }
.carousel__dots button{ width:9px; height:9px; border-radius:50%; border:0; background:var(--border-bright); cursor:pointer; padding:0; transition:background .2s, transform .2s; }
.carousel__dots button.is-active{ background:var(--primary); transform:scale(1.35); }
@media (max-width:600px){ .carousel__btn{ width:46px; height:46px; } .slide{ flex-basis:80vw; } }

/* ── PARALLAX SECTIONS ── */
.parallax{ position:relative; overflow:hidden; isolation:isolate; display:flex; align-items:center; min-height:clamp(460px,72vh,720px); border-block:1px solid var(--border); }
.parallax__bg{ position:absolute; inset:-12% 0; z-index:-2; will-change:transform; }
.parallax__bg img{ width:100%; height:100%; object-fit:cover; object-position:center 35%; }
.parallax__overlay{ position:absolute; inset:0; z-index:-1; background:linear-gradient(115deg,rgba(13,13,13,.93) 0%,rgba(13,13,13,.72) 48%,rgba(13,13,13,.5) 100%), radial-gradient(ellipse 50% 65% at 0% 100%, rgba(198,241,53,.1), transparent 70%); }
.parallax__content{ position:relative; z-index:1; max-width:700px; padding-block:clamp(3rem,7vw,5rem); }
.parallax__statement{ color:#fff; font-size:clamp(2.4rem,6vw,4.8rem); line-height:1.02; margin-bottom:1.2rem; text-transform:uppercase; }
.parallax__statement em{ font-style:normal; color:var(--primary); }
.parallax__content p{ color:rgba(240,240,240,.82); font-size:1.18rem; max-width:48ch; margin-bottom:1.8rem; }
.parallax--quote .parallax__overlay{ background:linear-gradient(180deg,rgba(13,13,13,.82),rgba(13,13,13,.93)), radial-gradient(ellipse 60% 60% at 50% 45%, rgba(198,241,53,.09), transparent 70%); }
.parallax__content--center{ max-width:940px; margin-inline:auto; text-align:center; }
.parallax__mark{ display:block; font-family:Georgia,serif; font-size:6rem; line-height:.4; color:var(--primary); margin-bottom:1.2rem; }
.parallax__quote{ font-family:var(--font-head); font-weight:800; text-transform:uppercase; color:#fff; font-size:clamp(1.7rem,3.8vw,3rem); line-height:1.22; letter-spacing:-.01em; margin:0 auto 1.5rem; max-width:20ch; border:0; padding:0; }
.parallax__quote em{ font-style:normal; color:var(--primary); }
.parallax__cite{ color:var(--muted); font-weight:700; letter-spacing:.06em; text-transform:uppercase; font-size:.86rem; }

/* ── STATS V2 (replaces stats-band) ── */
.stats-v2{ position:relative; overflow:hidden; isolation:isolate; padding:clamp(3.5rem,8vw,6.5rem) 0; border-block:1px solid var(--border); }
.stats-v2__bg{ position:absolute; inset:-12% 0; z-index:-2; will-change:transform; opacity:.16; }
.stats-v2__bg img{ width:100%; height:100%; object-fit:cover; }
.stats-v2__overlay{ position:absolute; inset:0; z-index:-1; background:radial-gradient(ellipse 70% 70% at 50% 0%, rgba(198,241,53,.07), transparent 60%), linear-gradient(180deg, rgba(13,13,13,.88), rgba(13,13,13,.96)); }
.stats-v2__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.stat-v2{ text-align:center; padding:1rem .5rem; position:relative; }
.stat-v2:not(:first-child)::before{ content:""; position:absolute; left:0; top:18%; bottom:18%; width:1px; background:var(--border); }
.stat-v2__num{ font-family:var(--font-head); font-weight:900; font-size:clamp(3rem,7vw,5.6rem); line-height:1; color:var(--primary); letter-spacing:-.03em; font-variant-numeric:tabular-nums; }
.stat-v2__label{ margin-top:.6rem; color:var(--ink); font-size:.86rem; font-weight:600; text-transform:uppercase; letter-spacing:.12em; }
@media (max-width:760px){ .stats-v2__grid{ grid-template-columns:1fr 1fr; gap:2.2rem 1rem; } .stat-v2:nth-child(odd)::before{ display:none; } }
@media (max-width:380px){ .stats-v2__grid{ grid-template-columns:1fr; } .stat-v2::before{ display:none !important; } }

/* ── RICH FOOTER ── */
.footer-cta{ display:flex; align-items:center; justify-content:space-between; gap:2rem; flex-wrap:wrap; padding-bottom:2.6rem; margin-bottom:2.8rem; border-bottom:1px solid var(--border); }
.footer-cta h3{ color:var(--ink); font-size:1.5rem; margin:0 0 .35rem; }
.footer-cta p{ margin:0; font-size:.96rem; max-width:46ch; }
.footer-sub{ display:flex; gap:.6rem; flex:0 1 440px; }
.footer-sub input{ flex:1; min-width:0; padding:.85rem 1rem; border:1.5px solid var(--border); border-radius:var(--radius); background:var(--surface-2); color:var(--ink); font:inherit; font-size:.95rem; }
.footer-sub input:focus{ outline:none; border-color:var(--primary); box-shadow:0 0 0 3px rgba(198,241,53,.15); }
.footer-sub .btn{ white-space:nowrap; }
.footer-col--brand p{ margin-top:.4rem; }
.footer-socials{ display:flex; gap:.7rem; margin-top:1.2rem; }
.footer-socials a{ width:38px; height:38px; border:1px solid var(--border); border-radius:50%; display:inline-flex; align-items:center; justify-content:center; color:var(--muted); transition:border-color .2s, color .2s, background .2s, transform .2s; }
.footer-socials a:hover{ border-color:var(--primary); color:var(--primary-ink); background:var(--primary); transform:translateY(-2px); }
.footer-socials svg{ width:18px; height:18px; }
.footer-address{ font-style:normal; margin:0 0 1.2rem; font-size:.92rem; }
.footer-address p{ margin:0 0 .8rem; line-height:1.65; }
.footer-address__line{ display:block; color:var(--ink); font-weight:700; }
.footer-address a{ color:var(--muted); }
.footer-address a:hover{ color:var(--primary); }
.footer-hours{ list-style:none; padding:0; margin:0; }
.footer-hours li{ display:flex; justify-content:space-between; gap:1rem; padding:.4rem 0; border-bottom:1px solid var(--border); font-size:.88rem; }
.footer-hours li:last-child{ border-bottom:0; }
.footer-hours li span:first-child{ color:var(--muted); }
.footer-hours li span:last-child{ color:var(--ink); font-weight:600; }
.footer-legal-links{ display:flex; gap:1.3rem; }
.footer-grid{ grid-template-columns:1.7fr 1fr 1fr 1.35fr; }
@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; } .footer-cta{ flex-direction:column; align-items:flex-start; } .footer-sub{ flex:1 1 100%; width:100%; } }
@media (max-width:600px){ .footer-grid{ grid-template-columns:1fr !important; } }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ── SCROLL REVEAL ── */
.js .reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.js .reveal.is-visible{ opacity:1; transform:none; }
.stats-v2__grid .reveal:nth-child(1){ transition-delay:.05s; }
.stats-v2__grid .reveal:nth-child(2){ transition-delay:.12s; }
.stats-v2__grid .reveal:nth-child(3){ transition-delay:.19s; }
.stats-v2__grid .reveal:nth-child(4){ transition-delay:.26s; }
@media (prefers-reduced-motion:reduce){ .js .reveal{ opacity:1 !important; transform:none !important; } }
