:root {
  --sharp-black: #101010;
  --charcoal: #1A1A1A;
  --graphite: #2B2B2B;
  --blade-silver: #D9D9D2;
  --line-green: #1F6B4F;
  --warm-gold: #C9A45C;
  --soft-sand: #EFE7D4;
  --white: #FFFFFF;
  --muted: rgba(217, 217, 210, .72);
  --faint: rgba(217, 217, 210, .11);
  --container: 1160px;
  --radius: 24px;
  --radius-lg: 34px;
  --header: 76px;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  background: var(--sharp-black);
}

body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--blade-silver);
  background:
    radial-gradient(circle at 82% 4%, rgba(31, 107, 79, .34), transparent 34rem),
    radial-gradient(circle at 2% 30%, rgba(31, 107, 79, .14), transparent 30rem),
    var(--sharp-black);
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.75), transparent 80%);
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
mark { color: var(--warm-gold); background: transparent; }

.container {
  width: min(100% - 38px, var(--container));
  margin-inline: auto;
}

.skip-link {
  position: absolute;
  left: -999px;
  top: 12px;
  z-index: 100;
  background: var(--soft-sand);
  color: var(--sharp-black);
  padding: 10px 14px;
  border-radius: 10px;
}
.skip-link:focus { left: 12px; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  min-height: var(--header);
  background: rgba(10,10,10,.78);
  border-bottom: 1px solid var(--faint);
  backdrop-filter: blur(18px);
}
.site-header.is-scrolled {
  background: rgba(10,10,10,.94);
}

.header-inner {
  min-height: var(--header);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}

.brand img {
  width: 285px;
  max-width: 42vw;
  height: auto;
}

.desktop-nav {
  display: flex;
  align-items: center;
  gap: 27px;
  color: rgba(217,217,210,.78);
  font-size: .76rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 900;
}
.desktop-nav a:hover { color: var(--white); }

.btn {
  border: 1px solid transparent;
  border-radius: 999px;
  min-height: 52px;
  padding: 0 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: .84rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  line-height: 1;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.btn:hover { transform: translateY(-1px); }

.btn-primary {
  color: var(--white);
  background: linear-gradient(135deg, #20805c, var(--line-green));
  box-shadow: 0 16px 50px rgba(31,107,79,.24);
}
.btn-primary::before {
  content: "◉";
  margin-right: 9px;
  font-size: .74rem;
}

.btn-secondary {
  color: var(--blade-silver);
  border-color: rgba(201,164,92,.72);
  background: rgba(201,164,92,.04);
}
.btn-secondary:hover { border-color: var(--warm-gold); background: rgba(201,164,92,.1); }

.btn-small {
  min-height: 42px;
  padding-inline: 18px;
  font-size: .72rem;
}

.menu-btn {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--faint);
  background: rgba(217,217,210,.04);
  border-radius: 14px;
  padding: 10px;
}
.menu-btn span {
  display: block;
  height: 2px;
  background: var(--blade-silver);
  margin: 5px 0;
  border-radius: 20px;
}

.mobile-nav { display: none; }

.hero {
  border-bottom: 1px solid var(--faint);
  position: relative;
  overflow: hidden;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.03fr .84fr;
  align-items: center;
  min-height: 590px;
  gap: 34px;
  padding: 50px 0 42px;
}

.eyebrow,
.section-kicker {
  margin: 0 0 14px;
  color: var(--line-green);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .76rem;
  font-weight: 900;
}

.eyebrow span {
  display: inline-block;
  width: 34px;
  height: 2px;
  background: var(--line-green);
  border-radius: 99px;
  margin-right: 11px;
  vertical-align: middle;
}

h1, h2, h3 {
  margin: 0;
  font-family: Oswald, Impact, sans-serif;
  text-transform: uppercase;
  letter-spacing: -.03em;
  line-height: .97;
  color: var(--white);
}

h1 {
  font-size: clamp(4.2rem, 8vw, 8.3rem);
  max-width: 8.8ch;
}
h1 strong {
  color: var(--line-green);
  display: block;
  font-weight: inherit;
}

h2 { font-size: clamp(2.1rem, 4.5vw, 4.45rem); }
h3 { font-size: 1.32rem; }

p {
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}

.hero-sub {
  font-size: 1.1rem;
  max-width: 570px;
  margin-top: 22px;
}

.hero-actions {
  margin-top: 26px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.hero-image-card {
  position: relative;
  min-height: 500px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid rgba(217,217,210,.1);
  background: var(--charcoal);
  box-shadow: 0 28px 110px rgba(0,0,0,.5);
}
.hero-image-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(16,16,16,.24), transparent 30%);
  pointer-events: none;
}
.hero-image-card img {
  width: 100%;
  height: 100%;
  min-height: 500px;
  object-fit: cover;
  object-position: 58% 42%;
}

.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--faint);
  border-inline: 1px solid var(--faint);
  background: rgba(26,26,26,.58);
}

.trust-strip div {
  min-height: 82px;
  padding: 18px 20px;
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 2px 12px;
  align-content: center;
  border-right: 1px solid var(--faint);
}
.trust-strip div:last-child { border-right: 0; }
.trust-strip span { grid-row: span 2; font-size: 1.7rem; color: var(--line-green); }
.trust-strip .icon-gold { color: var(--warm-gold); }
.trust-strip strong {
  color: var(--white);
  text-transform: uppercase;
  font-size: .78rem;
  letter-spacing: .12em;
}
.trust-strip small { color: var(--muted); }

.section {
  padding: 78px 0;
  border-bottom: 1px solid rgba(217,217,210,.08);
}

.section-row {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
  margin-bottom: 26px;
}

.inline-link {
  color: var(--line-green);
  text-transform: uppercase;
  letter-spacing: .13em;
  font-weight: 900;
  font-size: .8rem;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}

.service-card {
  overflow: hidden;
  border: 1px solid rgba(201,164,92,.32);
  background: linear-gradient(140deg, rgba(217,217,210,.06), rgba(217,217,210,.025));
  border-radius: 17px;
  min-height: 260px;
  transition: transform .2s ease, border-color .2s ease;
}
.service-card:hover { transform: translateY(-3px); border-color: rgba(201,164,92,.72); }

.service-image {
  height: 102px;
  background-size: cover;
  background-position: center;
  filter: saturate(.95) contrast(1.08);
}

.service-image.tools {
  background-image: linear-gradient(rgba(0,0,0,.08), rgba(0,0,0,.42)), url("assets/images/barbershop-fade.jpg");
  background-position: 54% 48%;
}
.service-image.fade {
  background-image: linear-gradient(rgba(0,0,0,.06), rgba(0,0,0,.38)), url("assets/images/fade-line-card.jpg");
  background-position: 60% 36%;
}
.service-image.beard {
  background-image: linear-gradient(rgba(0,0,0,.08), rgba(0,0,0,.40)), url("assets/images/haircut-beard-card.jpg");
  background-position: 48% 42%;
}
.service-image.mobile {
  background-image: linear-gradient(rgba(0,0,0,.08), rgba(0,0,0,.42)), url("assets/images/mobile-suite.jpg");
  background-position: 48% 48%;
}
.service-image.groom {
  background-image: linear-gradient(rgba(0,0,0,.08), rgba(0,0,0,.40)), url("assets/images/groom-ready-card.jpg");
  background-position: 50% 44%;
}
.service-image.wedding {
  background-image: linear-gradient(rgba(0,0,0,.08), rgba(0,0,0,.42)), url("assets/images/wedding-suite.jpg");
  background-position: 58% 46%;
}

.service-body { padding: 18px; }
.service-body span { color: var(--warm-gold); font-size: .76rem; font-weight: 900; }
.service-body h3 { margin: 12px 0 8px; font-size: 1.18rem; }
.service-body p { font-size: .9rem; }

.split-section { padding-top: 0; }
.split-grid {
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  gap: 0;
  border: 1px solid var(--faint);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: rgba(26,26,26,.5);
}

.how-card {
  padding: 34px;
  background: radial-gradient(circle at left, rgba(31,107,79,.11), transparent 28rem);
}
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 38px;
}
.steps b {
  width: 42px;
  height: 42px;
  border: 1px solid var(--line-green);
  color: var(--line-green);
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin-bottom: 28px;
}
.steps h3 { font-size: 1rem; margin-bottom: 8px; }
.steps p { font-size: .85rem; }

.feature-card {
  display: grid;
  grid-template-columns: .9fr .82fr;
  min-height: 355px;
  border-left: 1px solid var(--faint);
}
.feature-copy { padding: 34px; }
.section-kicker em {
  color: var(--warm-gold);
  border: 1px solid rgba(201,164,92,.45);
  border-radius: 999px;
  padding: 4px 8px;
  font-style: normal;
  margin-left: 8px;
  letter-spacing: .08em;
}
.feature-copy h2 { font-size: 2.35rem; }
.feature-copy > p { margin-top: 13px; }
.feature-card picture { min-height: 100%; }
.feature-card img { width: 100%; height: 100%; object-fit: cover; }

.check-list {
  display: grid;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 20px 0 22px;
}
.check-list li { color: var(--blade-silver); font-weight: 800; font-size: .86rem; }
.check-list li::before { content: "✓"; color: var(--line-green); margin-right: 9px; }

.why-grid {
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 0;
  border: 1px solid var(--faint);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: rgba(26,26,26,.43);
}
.why-image img { width: 100%; height: 100%; min-height: 480px; object-fit: cover; }
.why-copy { padding: 42px; }
.why-copy > p:not(.section-kicker) { margin-top: 18px; max-width: 700px; }

.standards-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 30px 0;
}
.standards-grid div { border-left: 1px solid rgba(201,164,92,.35); padding-left: 15px; }
.standards-grid span { color: var(--warm-gold); }
.standards-grid strong { display: block; color: var(--white); margin: 8px 0 4px; }
.standards-grid small { color: var(--muted); }

.hotels-card {
  display: grid;
  grid-template-columns: .82fr 1fr;
  border: 1px solid rgba(201,164,92,.22);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: radial-gradient(circle at left, rgba(201,164,92,.08), transparent 28rem), rgba(26,26,26,.5);
}
.hotels-copy { padding: 44px; }
.hotels-copy p:not(.section-kicker) { margin-top: 17px; }
.pill-row { display: flex; flex-wrap: wrap; gap: 9px; margin: 25px 0; }
.pill-row span {
  border: 1px solid rgba(201,164,92,.48);
  border-radius: 999px;
  color: var(--blade-silver);
  padding: 9px 12px;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.hotels-image img { width: 100%; height: 100%; object-fit: cover; }

.pricing-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
.pricing-grid article {
  position: relative;
  min-height: 135px;
  border: 1px solid rgba(201,164,92,.42);
  border-radius: 16px;
  background: linear-gradient(150deg, rgba(217,217,210,.065), rgba(217,217,210,.025));
  padding: 20px;
  display: grid;
  align-content: center;
  text-align: center;
}
.pricing-grid span {
  color: var(--blade-silver);
  font-size: .75rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .13em;
}
.pricing-grid small { color: var(--muted); margin-top: 9px; }
.pricing-grid strong {
  color: var(--white);
  font-family: Oswald, sans-serif;
  font-size: 2rem;
  margin-top: 3px;
}
.pricing-grid i {
  position: absolute;
  right: -4px;
  top: 13px;
  background: var(--warm-gold);
  color: #101010;
  transform: rotate(35deg);
  font-size: .62rem;
  font-weight: 900;
  padding: 4px 14px;
  font-style: normal;
}
.pricing-note { text-align: center; font-size: .9rem; margin-top: 18px; }

.proof-grid { display: grid; grid-template-columns: .72fr 1.28fr; gap: 22px; }
.areas-card, .reviews-card {
  border: 1px solid var(--faint);
  border-radius: var(--radius);
  padding: 27px;
  background: rgba(26,26,26,.46);
}
.areas-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 13px; }
.areas-list span { color: var(--blade-silver); font-weight: 800; }
.areas-list span::before { content: "⌖"; color: var(--line-green); margin-right: 8px; }

.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.review-grid article {
  border: 1px solid rgba(201,164,92,.34);
  border-radius: 16px;
  padding: 18px;
  background: rgba(217,217,210,.03);
}
.review-grid strong { color: var(--white); }
.review-grid span { display: block; color: var(--warm-gold); letter-spacing: .08em; margin: 8px 0; }
.review-grid p { font-size: .88rem; }

.faq-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 18px; }
details {
  border: 1px solid var(--faint);
  background: rgba(26,26,26,.5);
  border-radius: 14px;
  padding: 0 18px;
}
summary {
  list-style: none;
  cursor: pointer;
  color: var(--white);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 0;
  font-weight: 800;
}
summary::-webkit-details-marker { display: none; }
summary::after { content: "+"; color: var(--warm-gold); }
details[open] summary::after { content: "−"; }
details p { padding-bottom: 18px; font-size: .9rem; }

.final-cta {
  border-bottom: 1px solid var(--faint);
  background:
    radial-gradient(circle at 20% 50%, rgba(31,107,79,.22), transparent 24rem),
    linear-gradient(90deg, rgba(26,26,26,.9), rgba(16,16,16,.82));
}
.final-cta-inner {
  min-height: 155px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 20px;
}
.final-cta h2 {
  font-size: clamp(2rem, 4vw, 3.3rem);
  text-transform: none;
  font-family: Inter, sans-serif;
  letter-spacing: -.04em;
}
.final-cta p {
  color: var(--line-green);
  font-family: Oswald, sans-serif;
  text-transform: uppercase;
  font-size: 1.55rem;
  letter-spacing: .06em;
}
.final-cta small {
  grid-column: 2;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 900;
  text-align: center;
}

.site-footer { background: #070707; padding: 52px 0 34px; }
.footer-grid { display: grid; grid-template-columns: 1.4fr .8fr 1fr .72fr; gap: 38px; }
.footer-brand img { width: 285px; max-width: 100%; }
.footer-brand p { margin-top: 17px; }
.footer-grid div { display: flex; flex-direction: column; gap: 9px; }
.footer-grid strong { color: var(--line-green); text-transform: uppercase; letter-spacing: .16em; font-size: .78rem; }
.footer-grid a { color: var(--muted); font-size: .92rem; }
.footer-grid a:hover { color: var(--white); }
.payment-grid { display: grid !important; grid-template-columns: repeat(2, 1fr); gap: 8px !important; }
.payment-grid span {
  background: var(--white);
  color: #101010;
  border-radius: 7px;
  padding: 8px 9px;
  text-align: center;
  font-size: .72rem;
  font-weight: 900;
}
.footer-bottom {
  margin-top: 42px;
  padding-top: 20px;
  border-top: 1px solid var(--faint);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: rgba(217,217,210,.45);
  font-size: .82rem;
}

.sticky-wa { display: none; }

a:focus-visible, button:focus-visible, summary:focus-visible {
  outline: 2px solid var(--warm-gold);
  outline-offset: 4px;
}

@media (max-width: 1080px) {
  .desktop-nav, .header-cta { display: none; }
  .menu-btn { display: block; }
  .brand img { width: 230px; max-width: 50vw; }

  .mobile-nav {
    display: none;
    width: min(100% - 38px, var(--container));
    margin: 0 auto 16px;
    padding: 18px;
    border: 1px solid var(--faint);
    border-radius: 20px;
    background: rgba(16,16,16,.96);
  }
  .mobile-nav.is-open { display: grid; gap: 14px; }
  .mobile-nav a:not(.btn) {
    padding: 10px 0;
    color: var(--blade-silver);
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .86rem;
    font-weight: 900;
  }

  .hero-grid, .feature-card, .why-grid, .hotels-card, .proof-grid { grid-template-columns: 1fr; }
  .hero-grid { padding-top: 40px; }
  .hero-image-card { min-height: 420px; }
  .hero-image-card img { min-height: 420px; }
  .trust-strip, .service-grid, .pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .service-card { min-height: 235px; }
  .split-grid { grid-template-columns: 1fr; }
  .feature-card { border-left: 0; border-top: 1px solid var(--faint); }
  .standards-grid, .review-grid, .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 720px) {
  .container { width: min(100% - 30px, var(--container)); }
  .site-header { min-height: 66px; }
  .header-inner { min-height: 66px; }
  .brand img { width: 190px; max-width: 58vw; }

  .hero-grid { min-height: auto; gap: 24px; }
  h1 { font-size: clamp(3.2rem, 17vw, 5.1rem); max-width: 8.5ch; }
  .hero-sub { font-size: 1rem; }
  .hero-actions { display: grid; grid-template-columns: 1fr; }
  .btn { width: 100%; }

  .hero-image-card { border-radius: 24px; min-height: 360px; }
  .hero-image-card img { min-height: 360px; }

  .trust-strip, .service-grid, .steps, .pricing-grid, .standards-grid, .review-grid, .faq-grid, .footer-grid {
    grid-template-columns: 1fr;
  }
  .trust-strip div { border-right: 0; border-bottom: 1px solid var(--faint); }

  .section { padding: 56px 0; }
  .section-row { display: grid; gap: 12px; }

  .service-grid { gap: 12px; }
  .service-card { display: grid; grid-template-columns: 136px 1fr; min-height: 140px; }
  .service-image { height: 100%; min-height: 140px; }
  .service-body { padding: 18px 18px 18px 20px; }
  .service-body h3 { font-size: 1.08rem; margin-top: 10px; }
  .service-body p { font-size: .92rem; line-height: 1.45; }

  .split-grid, .why-grid, .hotels-card { border-radius: 24px; }
  .how-card, .feature-copy, .why-copy, .hotels-copy, .areas-card, .reviews-card { padding: 24px; }

  .feature-copy h2 { font-size: 2rem; }
  .feature-card img, .why-image img, .hotels-image img { min-height: 340px; }

  .final-cta-inner { grid-template-columns: 1fr; padding: 28px 0 90px; text-align: center; }
  .final-cta small { grid-column: auto; }

  .footer-bottom { flex-direction: column; padding-bottom: 74px; }

  .sticky-wa {
    position: fixed;
    z-index: 80;
    display: flex;
    left: 15px;
    right: 15px;
    bottom: 13px;
    min-height: 56px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(135deg, #20805c, var(--line-green));
    color: var(--white);
    text-transform: uppercase;
    font-size: .86rem;
    letter-spacing: .08em;
    font-weight: 900;
    box-shadow: 0 22px 60px rgba(0,0,0,.46);
  }
}


/* v4.1 final QA polish */
.brand {
  display: inline-flex;
  align-items: center;
}

.brand img,
.footer-brand img {
  object-fit: contain;
}

.service-card:nth-child(1) .service-image,
.service-card:nth-child(2) .service-image,
.service-card:nth-child(3) .service-image {
  filter: saturate(.94) contrast(1.12) brightness(.92);
}

.service-card:nth-child(4) .service-image,
.service-card:nth-child(5) .service-image,
.service-card:nth-child(6) .service-image {
  filter: saturate(.98) contrast(1.08) brightness(.88);
}

@media (max-width: 720px) {
  .site-header {
    min-height: 70px;
  }

  .header-inner {
    min-height: 70px;
  }

  .menu-btn {
    flex: 0 0 auto;
  }
}


/* v4.2 unique service image crops */
.service-card:nth-child(1) .service-image { background-position: 55% 48%; }
.service-card:nth-child(2) .service-image { background-position: 62% 35%; }
.service-card:nth-child(3) .service-image { background-position: 48% 42%; }
.service-card:nth-child(4) .service-image { background-position: 48% 48%; }
.service-card:nth-child(5) .service-image { background-position: 50% 43%; }
.service-card:nth-child(6) .service-image { background-position: 58% 46%; }

@media (max-width: 720px) {
  .service-card:nth-child(2) .service-image { background-position: 62% 34%; }
  .service-card:nth-child(3) .service-image { background-position: 45% 43%; }
  .service-card:nth-child(5) .service-image { background-position: 50% 43%; }
}


/* v4.3 service conversion polish */
.service-card {
  position: relative;
}

.featured-service {
  border-color: rgba(31, 107, 79, .72);
  box-shadow: 0 18px 70px rgba(31, 107, 79, .12);
}

.featured-service::after {
  content: "POPULAR";
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  background: var(--line-green);
  color: var(--white);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: .58rem;
  font-weight: 900;
  letter-spacing: .12em;
}

.service-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 16px;
  color: var(--line-green);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .72rem;
  font-weight: 900;
}

.service-link::after {
  content: "→";
  transform: translateY(-1px);
}

.service-card:hover .service-link {
  color: var(--warm-gold);
}

.service-image {
  position: relative;
}

.service-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, transparent 45%, rgba(16,16,16,.55)),
    radial-gradient(circle at 25% 10%, rgba(31,107,79,.16), transparent 55%);
  pointer-events: none;
}

@media (max-width: 720px) {
  body {
    padding-bottom: 74px;
  }

  .service-grid {
    gap: 16px;
  }

  .service-card {
    grid-template-columns: 148px 1fr;
    min-height: 156px;
    border-radius: 20px;
  }

  .service-image {
    min-height: 156px;
  }

  .service-body {
    align-self: center;
  }

  .service-body span {
    font-size: .72rem;
  }

  .service-link {
    margin-top: 12px;
    font-size: .68rem;
  }

  .featured-service::after {
    top: 9px;
    right: 9px;
    font-size: .52rem;
    padding: 5px 8px;
  }

  #services {
    padding-bottom: 96px;
  }
}

@media (max-width: 430px) {
  .service-card {
    grid-template-columns: 132px 1fr;
  }

  .service-body {
    padding: 16px;
  }

  .service-body h3 {
    font-size: 1rem;
  }

  .service-body p {
    font-size: .86rem;
  }
}


/* v4.4 production legal and footer polish */
.footer-bottom a {
  color: rgba(217,217,210,.62);
}

.footer-bottom a:hover {
  color: var(--white);
}

.legal-page {
  min-height: calc(100vh - var(--header));
  padding: 72px 0;
  background:
    radial-gradient(circle at 20% 10%, rgba(31,107,79,.18), transparent 28rem),
    var(--sharp-black);
}

.legal-card {
  max-width: 860px;
  border: 1px solid rgba(217,217,210,.12);
  border-radius: 32px;
  background: rgba(26,26,26,.64);
  padding: 42px;
}

.legal-card h1 {
  font-size: clamp(3rem, 8vw, 5.8rem);
  margin-bottom: 26px;
}

.legal-card p {
  margin-bottom: 18px;
  max-width: 720px;
}

.legal-card .btn {
  margin-top: 18px;
}

@media (max-width: 720px) {
  .legal-page {
    padding: 42px 0 110px;
  }

  .legal-card {
    padding: 26px;
    border-radius: 24px;
  }
}


/* v4.5 trust-ready polish */
.trust-grid article span {
  color: var(--line-green);
  font-size: .75rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.pricing-note-soft {
  color: rgba(217,217,210,.55);
  margin-top: 7px;
}

.final-cta-with-qr {
  grid-template-columns: 1fr auto 118px;
}

.final-action-stack {
  display: grid;
  gap: 10px;
  justify-items: center;
}

.final-action-stack small {
  grid-column: auto;
}

.qr-mini-card {
  border: 1px solid rgba(201,164,92,.34);
  background: rgba(239,231,212,.96);
  border-radius: 18px;
  padding: 10px;
  display: grid;
  gap: 7px;
  justify-items: center;
  color: var(--sharp-black);
  box-shadow: 0 18px 54px rgba(0,0,0,.24);
}

.qr-mini-card img {
  width: 92px;
  height: 92px;
  border-radius: 10px;
}

.qr-mini-card span {
  font-size: .68rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

@media (max-width: 900px) {
  .final-cta-with-qr {
    grid-template-columns: 1fr;
  }

  .qr-mini-card {
    display: none;
  }
}


/* v4.6 quick booking widget */
.quick-booking {
  margin-top: 24px;
  border: 1px solid rgba(217,217,210,.13);
  border-radius: 24px;
  background:
    radial-gradient(circle at 0% 0%, rgba(31,107,79,.18), transparent 18rem),
    rgba(26,26,26,.66);
  padding: 18px;
  max-width: 760px;
  box-shadow: 0 20px 70px rgba(0,0,0,.18);
}

.quick-booking-label {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.quick-booking-label strong {
  color: var(--white);
  font-family: Oswald, Impact, sans-serif;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 1.25rem;
}

.quick-booking-label span {
  color: rgba(217,217,210,.62);
  font-size: .88rem;
}

.quick-booking-grid {
  display: grid;
  grid-template-columns: 1.1fr .95fr .82fr auto;
  gap: 10px;
  align-items: end;
}

.quick-booking label {
  display: grid;
  gap: 7px;
}

.quick-booking label span {
  color: var(--warm-gold);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .62rem;
  font-weight: 900;
}

.quick-booking select,
.quick-booking input {
  min-height: 48px;
  width: 100%;
  border: 1px solid rgba(217,217,210,.13);
  border-radius: 999px;
  background: rgba(16,16,16,.82);
  color: var(--blade-silver);
  padding: 0 15px;
  outline: none;
  font-weight: 700;
}

.quick-booking select:focus,
.quick-booking input:focus {
  border-color: rgba(31,107,79,.82);
  box-shadow: 0 0 0 3px rgba(31,107,79,.18);
}

.quick-booking input::placeholder {
  color: rgba(217,217,210,.38);
}

.quick-booking-btn {
  min-height: 48px;
  padding-inline: 18px;
  font-size: .72rem;
}

.booking-strip {
  padding: 18px 0;
  border-bottom: 1px solid rgba(217,217,210,.08);
}

.booking-strip-inner {
  border: 1px solid rgba(217,217,210,.1);
  border-radius: 18px;
  background: rgba(26,26,26,.46);
  padding: 16px 18px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
}

.booking-strip strong {
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .78rem;
}

.booking-strip span {
  color: var(--muted);
  font-size: .92rem;
}

.booking-strip a {
  color: var(--line-green);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 900;
  font-size: .72rem;
}

@media (max-width: 980px) {
  .quick-booking-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .quick-booking-btn {
    grid-column: span 2;
  }

  .booking-strip-inner {
    grid-template-columns: 1fr;
    text-align: center;
  }
}

@media (max-width: 720px) {
  .quick-booking {
    border-radius: 22px;
    padding: 16px;
  }

  .quick-booking-label {
    display: grid;
    gap: 4px;
  }

  .quick-booking-grid {
    grid-template-columns: 1fr;
  }

  .quick-booking-btn {
    grid-column: auto;
  }

  .quick-booking select,
  .quick-booking input {
    min-height: 52px;
  }

  .booking-strip {
    display: none;
  }
}


/* v4.7 credibility polish */
.audience-section {
  background:
    radial-gradient(circle at 80% 5%, rgba(31,107,79,.13), transparent 26rem),
    rgba(16,16,16,.08);
}

.audience-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.audience-grid article {
  border: 1px solid rgba(217,217,210,.11);
  background:
    linear-gradient(145deg, rgba(217,217,210,.055), rgba(217,217,210,.018)),
    rgba(26,26,26,.54);
  border-radius: 24px;
  padding: 26px;
  min-height: 260px;
  display: flex;
  flex-direction: column;
}

.audience-grid article span {
  color: var(--warm-gold);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .18em;
}

.audience-grid h3 {
  margin: 50px 0 12px;
  font-size: 1.55rem;
}

.audience-grid p {
  font-size: .94rem;
}

.audience-grid a {
  margin-top: auto;
  padding-top: 20px;
  color: var(--line-green);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .72rem;
  font-weight: 900;
}

.audience-grid a::after {
  content: " →";
}

.footer-note {
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.55;
  max-width: 250px;
}

@media (max-width: 900px) {
  .audience-grid {
    grid-template-columns: 1fr;
  }

  .audience-grid article {
    min-height: auto;
  }

  .audience-grid h3 {
    margin-top: 28px;
  }
}


/* v4.8 launch-safe polish */
.launch-note {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 14px;
}

.launch-note span {
  border: 1px solid rgba(217,217,210,.12);
  background: rgba(217,217,210,.045);
  color: rgba(217,217,210,.72);
  border-radius: 999px;
  padding: 8px 11px;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 900;
}

.pilot-section {
  background:
    radial-gradient(circle at 15% 0%, rgba(201,164,92,.09), transparent 24rem),
    rgba(7,7,7,.34);
}

.pilot-card {
  border: 1px solid rgba(217,217,210,.11);
  border-radius: 32px;
  background:
    linear-gradient(145deg, rgba(217,217,210,.06), rgba(217,217,210,.018)),
    rgba(26,26,26,.62);
  padding: 34px;
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 28px;
  align-items: center;
}

.pilot-card h2 {
  font-size: clamp(2.2rem, 4.8vw, 4.2rem);
}

.pilot-card p:not(.section-kicker) {
  margin-top: 16px;
}

.pilot-points {
  display: grid;
  gap: 12px;
}

.pilot-points article {
  border: 1px solid rgba(201,164,92,.20);
  border-radius: 18px;
  padding: 18px;
  background: rgba(16,16,16,.36);
}

.pilot-points strong {
  display: block;
  color: var(--white);
  font-family: Oswald, Impact, sans-serif;
  text-transform: uppercase;
  letter-spacing: .02em;
  font-size: 1.18rem;
  margin-bottom: 6px;
}

.pilot-points span {
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.5;
}

.footer-muted {
  color: rgba(217,217,210,.46);
  font-size: .92rem;
}

@media (max-width: 900px) {
  .pilot-card {
    grid-template-columns: 1fr;
    padding: 26px;
  }
}

@media (max-width: 720px) {
  .launch-note span {
    font-size: .66rem;
    padding: 7px 9px;
  }
}


/* v4.9 B2B funnel pages */
.subpage-hero {
  padding: 72px 0 54px;
  border-bottom: 1px solid rgba(217,217,210,.08);
  background:
    radial-gradient(circle at 85% 8%, rgba(31,107,79,.24), transparent 28rem),
    radial-gradient(circle at 5% 70%, rgba(201,164,92,.08), transparent 24rem);
}

.subpage-hero-grid {
  display: grid;
  grid-template-columns: 1fr .82fr;
  gap: 36px;
  align-items: center;
}

.subpage-hero h1 {
  font-size: clamp(3.6rem, 8vw, 7.4rem);
  max-width: 9.5ch;
}

.subpage-visual {
  border: 1px solid rgba(217,217,210,.12);
  border-radius: 32px;
  overflow: hidden;
  min-height: 480px;
  background: rgba(26,26,26,.6);
  box-shadow: 0 28px 100px rgba(0,0,0,.36);
}

.subpage-visual img {
  width: 100%;
  height: 100%;
  min-height: 480px;
  object-fit: cover;
}

.offer-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.offer-grid article {
  border: 1px solid rgba(217,217,210,.11);
  background:
    linear-gradient(145deg, rgba(217,217,210,.055), rgba(217,217,210,.018)),
    rgba(26,26,26,.54);
  border-radius: 24px;
  padding: 26px;
  min-height: 250px;
}

.offer-grid span {
  color: var(--warm-gold);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .18em;
}

.offer-grid h3 {
  margin: 48px 0 12px;
  font-size: 1.45rem;
}

.dark-process {
  background: rgba(7,7,7,.34);
}

.process-card {
  border: 1px solid rgba(217,217,210,.11);
  border-radius: 32px;
  background:
    radial-gradient(circle at 0% 0%, rgba(31,107,79,.15), transparent 24rem),
    rgba(26,26,26,.58);
  padding: 34px;
}

.mini-process {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 24px;
}

.mini-process div {
  border: 1px solid rgba(201,164,92,.20);
  border-radius: 18px;
  padding: 18px;
  background: rgba(16,16,16,.34);
}

.mini-process b {
  width: 38px;
  height: 38px;
  border: 1px solid var(--line-green);
  color: var(--line-green);
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin-bottom: 28px;
}

.mini-process h3 {
  font-size: 1rem;
  margin-bottom: 8px;
}

.mini-process p {
  font-size: .88rem;
}

@media (max-width: 980px) {
  .subpage-hero-grid,
  .offer-grid,
  .mini-process {
    grid-template-columns: 1fr;
  }

  .subpage-visual,
  .subpage-visual img {
    min-height: 380px;
  }

  .offer-grid article {
    min-height: auto;
  }

  .offer-grid h3 {
    margin-top: 28px;
  }
}

@media (max-width: 720px) {
  .subpage-hero {
    padding: 46px 0 34px;
  }

  .subpage-hero h1 {
    font-size: clamp(3rem, 16vw, 5rem);
  }

  .subpage-visual,
  .subpage-visual img {
    min-height: 330px;
    border-radius: 24px;
  }

  .process-card {
    padding: 24px;
    border-radius: 24px;
  }
}


/* v5 booking funnel page */
.booking-page {
  padding: 72px 0;
  border-bottom: 1px solid rgba(217,217,210,.08);
  background:
    radial-gradient(circle at 82% 10%, rgba(31,107,79,.22), transparent 28rem),
    radial-gradient(circle at 6% 80%, rgba(201,164,92,.08), transparent 24rem),
    var(--sharp-black);
}

.booking-page-grid {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 34px;
  align-items: start;
}

.booking-page-copy h1 {
  font-size: clamp(3.7rem, 8vw, 7.6rem);
  max-width: 8ch;
}

.booking-form-card {
  border: 1px solid rgba(217,217,210,.12);
  border-radius: 32px;
  background:
    linear-gradient(145deg, rgba(217,217,210,.065), rgba(217,217,210,.018)),
    rgba(26,26,26,.68);
  padding: 28px;
  box-shadow: 0 28px 90px rgba(0,0,0,.26);
}

.booking-form-card > div {
  display: grid;
  gap: 16px;
}

.booking-form-card label {
  display: grid;
  gap: 8px;
}

.booking-form-card label span {
  color: var(--warm-gold);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .68rem;
  font-weight: 900;
}

.booking-form-card input,
.booking-form-card select,
.booking-form-card textarea {
  width: 100%;
  border: 1px solid rgba(217,217,210,.13);
  border-radius: 18px;
  background: rgba(16,16,16,.76);
  color: var(--blade-silver);
  padding: 15px 16px;
  outline: none;
  font: inherit;
  font-weight: 700;
}

.booking-form-card input,
.booking-form-card select {
  min-height: 54px;
}

.booking-form-card textarea {
  resize: vertical;
  min-height: 112px;
}

.booking-form-card input:focus,
.booking-form-card select:focus,
.booking-form-card textarea:focus {
  border-color: rgba(31,107,79,.82);
  box-shadow: 0 0 0 3px rgba(31,107,79,.18);
}

.booking-form-card .btn {
  width: 100%;
  margin-top: 20px;
}

.booking-form-note {
  margin-top: 14px;
  font-size: .88rem;
  text-align: center;
}

.booking-support-section {
  padding-top: 58px;
}

@media (max-width: 900px) {
  .booking-page-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .booking-page {
    padding: 46px 0 110px;
  }

  .booking-form-card {
    padding: 22px;
    border-radius: 24px;
  }

  .booking-page-copy h1 {
    font-size: clamp(3.2rem, 16vw, 5.2rem);
  }
}


/* v5.2 final mobile nav and publish polish */
.mobile-nav .btn {
  margin-top: 6px;
}

@media (max-width: 1080px) {
  .site-header .header-inner {
    position: relative;
  }

  .site-header .menu-btn {
    margin-left: auto;
  }
}

@media (max-width: 720px) {
  .mobile-nav {
    margin-bottom: 12px;
  }

  .mobile-nav .btn {
    width: 100%;
  }

  .header-inner {
    gap: 12px;
  }
}

/* Keep legal / utility pages usable on mobile */
.legal-page .btn,
.error-page .btn {
  width: auto;
}
