/* ============================================================
   Restoration Medix — Landing Page
   Design system derived from the Brand Guide v1.0
============================================================ */

:root{
  --navy:#0d2137;
  --navy-2:#13314f;
  --navy-3:#1c4068;
  --teal:#5bcece;
  --teal-2:#9ce0e0;
  --teal-3:#2e9b9b;
  --teal-ink:#1d6e7a;
  --orange:#f5a623;
  --orange-2:#fbc46d;
  --orange-3:#c97f10;
  --white:#ffffff;
  --paper:#f7f5f1;
  --paper-2:#efece5;
  --gray:#5a6a7a;
  --gray-2:#8a96a3;
  --gray-3:#c6ccd2;
  --line:rgba(13,33,55,0.12);
  --line-2:rgba(13,33,55,0.08);

  /* tweakable */
  --cta:#f5a623;
  --cta-ink:#0d2137;

  --maxw:1200px;
  --shadow-card:0 18px 44px -22px rgba(13,33,55,.32), 0 4px 12px -6px rgba(13,33,55,.12);
  --shadow-soft:0 10px 30px -16px rgba(13,33,55,.22);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Nunito',system-ui,sans-serif;
  color:var(--navy);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.6;
}
h1,h2,h3,h4,h5{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  letter-spacing:-0.02em;
  line-height:1.04;
  color:var(--navy);
  margin:0;
}
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.mono{ font-family:'JetBrains Mono',monospace; }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:96px 0; }
.section.tight{ padding:72px 0; }
.eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--orange-3); font-weight:500;
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--orange); display:inline-block; }
.eyebrow.center{ justify-content:center; }
.eyebrow.light{ color:var(--orange); }
.eyebrow.teal{ color:var(--teal-3); }
.eyebrow.teal::before{ background:var(--teal-3); }
.label-mono{
  font-family:'JetBrains Mono',monospace;
  font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gray);
}
.lead{ font-size:19px; line-height:1.6; color:var(--gray); }
.muted{ color:var(--gray); }

.h-hero{ font-size:clamp(40px,6.2vw,76px); line-height:0.98; letter-spacing:-0.03em; }
.h-sec{ font-size:clamp(32px,4.4vw,52px); line-height:1.0; letter-spacing:-0.025em; }
.h-sub{ font-size:clamp(22px,2.6vw,30px); line-height:1.08; }

.section-head{ max-width:680px; }
.section-head .h-sec{ margin-top:16px; }
.section-head p{ margin-top:16px; }
.center-head{ margin-left:auto; margin-right:auto; text-align:center; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:'Space Grotesk',sans-serif; font-weight:700; letter-spacing:.01em;
  padding:16px 26px; border-radius:8px; font-size:16px;
  border:none; cursor:pointer; text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn-cta{ background:var(--cta); color:var(--cta-ink); box-shadow:0 10px 24px -10px rgba(245,166,35,.7); }
.btn-cta:hover{ background:var(--orange-2); box-shadow:0 14px 30px -10px rgba(245,166,35,.8); }
.btn-teal{ background:var(--teal); color:var(--navy); }
.btn-teal:hover{ background:var(--teal-2); }
.btn-navy{ background:var(--navy); color:#fff; }
.btn-navy:hover{ background:var(--navy-2); }
.btn-ghost-light{ background:rgba(255,255,255,.06); color:#fff; border:1.5px solid rgba(255,255,255,.28); }
.btn-ghost-light:hover{ background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.5); }
.btn-ghost-dark{ background:transparent; color:var(--navy); border:1.5px solid var(--navy); }
.btn-ghost-dark:hover{ background:var(--navy); color:#fff; }
.btn-lg{ padding:19px 34px; font-size:18px; }
.btn-block{ width:100%; }
.btn svg{ flex-shrink:0; }

/* ---------- wordmark ---------- */
.wordmark{
  font-family:'Space Grotesk',sans-serif; font-weight:700;
  letter-spacing:-0.025em; line-height:.92; color:var(--navy);
}
.wordmark .medix{ color:var(--teal-3); }
.wordmark.invert{ color:#fff; }
.wordmark.invert .medix{ color:var(--teal); }
.lockup{ display:inline-flex; align-items:center; gap:12px; }
.lockup img{ flex-shrink:0; }

/* ---------- utility top bar ---------- */
.utility{
  background:var(--navy); color:rgba(255,255,255,.82);
  font-family:'JetBrains Mono',monospace; font-size:12px; letter-spacing:.06em;
}
.utility .wrap{ display:flex; align-items:center; justify-content:space-between; height:42px; gap:18px; }
.utility .u-left{ display:flex; align-items:center; gap:18px; }
.utility .u-dot{ width:7px; height:7px; border-radius:50%; background:#43d17e; box-shadow:0 0 0 4px rgba(67,209,126,.18); display:inline-block; }
.utility .u-right{ display:flex; align-items:center; gap:18px; }
.utility a.u-phone{ color:var(--orange-2); font-weight:500; }
.utility .u-sep{ color:rgba(255,255,255,.25); }

/* ---------- header / nav ---------- */
.header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.92); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.header .wrap{ display:flex; align-items:center; justify-content:space-between; height:76px; gap:24px; }
.nav{ display:flex; align-items:center; gap:26px; }
.nav a{ font-family:'Space Grotesk',sans-serif; font-weight:600; font-size:15px; color:var(--navy); opacity:.78; transition:opacity .15s; white-space:nowrap; }
.nav a:hover{ opacity:1; }
.header-cta{ display:flex; align-items:center; gap:16px; }
.header-phone{ display:flex; flex-direction:column; align-items:flex-end; line-height:1.1; }
.header-phone .lbl{ font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray); }
.header-phone .num{ font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:19px; color:var(--navy); white-space:nowrap; }

/* ---------- hero ---------- */
.hero{ position:relative; background:var(--navy); color:#fff; overflow:hidden; }
.hero .bg-slot{ position:absolute; inset:0; width:100%; height:100%; }
.hero .bg-slot image-slot{ width:100%; height:100%; }
.hero .scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(100deg, rgba(8,18,31,.96) 0%, rgba(8,18,31,.9) 38%, rgba(8,18,31,.62) 70%, rgba(8,18,31,.42) 100%);
}
.hero .grid-tex{
  position:absolute; inset:0; opacity:.5; mix-blend-mode:overlay;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:44px 44px;
}
.hero .wrap{ position:relative; z-index:2; display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:center; padding-top:72px; padding-bottom:84px; }
.hero h1{ color:#fff; max-width:14ch; }
.hero h1 .accent{ color:var(--teal); }
.hero .hero-sub{ font-size:19px; line-height:1.55; color:rgba(255,255,255,.78); max-width:46ch; margin-top:22px; }
.hero .hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }
.hero .call-line{ display:flex; align-items:center; gap:14px; margin-top:22px; }
.hero .call-line .num{ font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:26px; color:#fff; }
.hero .call-line .lbl{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--teal); }
.hero-badges{ display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:36px; padding-top:26px; border-top:1px solid rgba(255,255,255,.16); }
.hero-badge{ display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:rgba(255,255,255,.9); }
.hero-badge svg{ color:var(--teal); flex-shrink:0; }

/* lead form card */
.lead-card{
  background:#fff; color:var(--navy); border-radius:16px; padding:30px;
  box-shadow:0 30px 70px -28px rgba(0,0,0,.6);
  position:relative;
}
.lead-card .lc-top{ display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.lead-card .lc-pill{ background:var(--cta); color:var(--cta-ink); font-family:'Space Grotesk'; font-weight:700; font-size:11px; letter-spacing:.06em; padding:5px 10px; border-radius:4px; text-transform:uppercase; }
.lead-card h3{ font-size:24px; line-height:1.05; margin-top:8px; }
.lead-card .lc-sub{ font-size:14px; color:var(--gray); margin-top:6px; }
.field{ margin-top:14px; }
.field label{ font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray); display:block; margin-bottom:6px; }
.field input, .field select{
  width:100%; font-family:'Nunito',sans-serif; font-size:15px; color:var(--navy);
  background:var(--paper); border:1.5px solid var(--line); border-radius:8px; padding:13px 14px;
  transition:border-color .15s, background .15s;
}
.field input:focus, .field select:focus{ outline:none; border-color:var(--teal-3); background:#fff; }
.field input::placeholder{ color:var(--gray-2); }
.lead-card .lc-note{ font-size:12px; color:var(--gray); margin-top:14px; text-align:center; display:flex; align-items:center; justify-content:center; gap:7px; }
.lead-card .lc-or{ text-align:center; font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.1em; color:var(--gray-2); margin:16px 0 4px; position:relative; }

/* hero light variant (tweak) */
body[data-herostyle="light"] .hero{ background:var(--paper); color:var(--navy); }
body[data-herostyle="light"] .hero .scrim{
  background:linear-gradient(100deg, rgba(247,245,241,.97) 0%, rgba(247,245,241,.9) 42%, rgba(247,245,241,.55) 72%, rgba(247,245,241,.3) 100%);
}
body[data-herostyle="light"] .hero .grid-tex{
  mix-blend-mode:normal; opacity:.5;
  background-image:
    linear-gradient(to right, rgba(13,33,55,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(13,33,55,.05) 1px, transparent 1px);
}
body[data-herostyle="light"] .hero h1{ color:var(--navy); }
body[data-herostyle="light"] .hero h1 .accent{ color:var(--teal-3); }
body[data-herostyle="light"] .hero .hero-sub{ color:var(--gray); }
body[data-herostyle="light"] .hero .eyebrow.light{ color:var(--orange-3); }
body[data-herostyle="light"] .hero .call-line .num{ color:var(--navy); }
body[data-herostyle="light"] .hero .call-line .lbl{ color:var(--teal-3); }
body[data-herostyle="light"] .hero-badges{ border-top-color:var(--line); }
body[data-herostyle="light"] .hero-badge{ color:var(--navy); }
body[data-herostyle="light"] .hero-badge svg{ color:var(--teal-3); }
body[data-herostyle="light"] .hero .btn-ghost-light{ background:transparent; color:var(--navy); border-color:var(--navy); }
body[data-herostyle="light"] .hero .btn-ghost-light:hover{ background:var(--navy); color:#fff; }

/* ---------- trust strip ---------- */
.trust{ background:var(--paper); border-bottom:1px solid var(--line); }
.trust .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding:26px 28px; flex-wrap:wrap; }
.trust-item{ display:flex; align-items:center; gap:12px; }
.trust-item .ic{ width:38px; height:38px; border-radius:9px; background:#fff; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:var(--teal-3); flex-shrink:0; }
.trust-item .tt{ font-family:'Space Grotesk'; font-weight:700; font-size:15px; line-height:1.05; }
.trust-item .ts{ font-size:12px; color:var(--gray); }

/* ---------- press / as seen on (top strip) ---------- */
.press-strip{
  display:block; background:var(--paper); border-bottom:1px solid var(--line);
  transition:background .15s;
}
.press-strip:hover{ background:var(--paper-2); }
.press-strip .wrap{ display:flex; align-items:center; gap:14px; min-height:52px; padding:10px 28px; flex-wrap:nowrap; overflow:hidden; }
.press-strip .ps-label{
  font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gray); white-space:nowrap; flex-shrink:0;
}
.press-strip .ps-divider{ width:1px; height:20px; background:var(--line); flex-shrink:0; }
.press-strip .ps-pub{
  font-family:'Playfair Display',Georgia,serif; font-weight:700; font-size:22px; letter-spacing:-0.01em; color:var(--navy); line-height:1; white-space:nowrap; flex-shrink:0;
}
.press-strip .ps-sub{ font-size:13px; color:var(--gray); font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.press-strip .ps-link{
  margin-left:auto; font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:13px; color:var(--teal-3);
  display:inline-flex; align-items:center; gap:6px; white-space:nowrap; flex-shrink:0;
}
.press-strip:hover .ps-link{ color:var(--navy); }

/* ---------- services ---------- */
.services{ background:#fff; }
.svc-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.svc-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; grid-auto-rows:1fr; gap:20px; margin-top:48px; }
.svc{ position:relative; border-radius:14px; overflow:hidden; background:var(--paper); border:1px solid var(--line); display:flex; flex-direction:column; min-height:240px; }
.svc .svc-media{ position:relative; height:170px; background:var(--navy); }
.svc .svc-media image-slot{ width:100%; height:100%; }
.svc .svc-body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.svc .svc-num{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.14em; color:var(--orange-3); }
.svc h3{ font-size:21px; margin-top:8px; }
.svc p{ font-size:14px; color:var(--gray); margin-top:8px; }
.svc .svc-link{ margin-top:auto; padding-top:14px; font-family:'Space Grotesk'; font-weight:700; font-size:14px; color:var(--navy); display:inline-flex; align-items:center; gap:7px; }
.svc.feature{ grid-row:span 2; }
.svc.feature .svc-media{ height:300px; }
.svc.feature .svc-body{ padding:26px; }
.svc.feature h3{ font-size:30px; }
.svc.feature p{ font-size:15px; }
.svc .badge-em{ position:absolute; top:14px; left:14px; z-index:3; background:var(--cta); color:var(--cta-ink); font-family:'Space Grotesk'; font-weight:700; font-size:11px; letter-spacing:.06em; padding:6px 11px; border-radius:5px; display:flex; align-items:center; gap:7px; }
.svc ul{ list-style:none; padding:0; margin:14px 0 0; display:flex; flex-direction:column; gap:7px; }
.svc ul li{ font-size:13.5px; color:var(--gray); display:flex; gap:9px; align-items:center; }
.svc ul li::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--orange); flex-shrink:0; }

/* ---------- why us ---------- */
.why{ background:var(--navy); color:#fff; position:relative; overflow:hidden; }
.why .drop-wm{ position:absolute; right:-160px; top:50%; transform:translateY(-50%); width:560px; opacity:.06; pointer-events:none; }
.why .wrap{ position:relative; z-index:2; }
.why h2{ color:#fff; }
.why .why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:52px; }
.why-card{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:13px; padding:28px; transition:background .15s, border-color .15s; }
.why-card:hover{ background:rgba(255,255,255,.07); border-color:rgba(91,206,206,.4); }
.why-card .ic{ width:46px; height:46px; border-radius:11px; background:rgba(91,206,206,.14); color:var(--teal); display:flex; align-items:center; justify-content:center; }
.why-card h3{ color:#fff; font-size:20px; margin-top:18px; }
.why-card p{ color:rgba(255,255,255,.7); font-size:14.5px; margin-top:9px; }
.why-stats{ display:flex; flex-wrap:wrap; gap:14px; margin-top:42px; }
.why-stat{ flex:1; min-width:160px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:13px; padding:24px 26px; }
.why-stat .n{ font-family:'Space Grotesk'; font-weight:700; font-size:42px; line-height:.9; }
.why-stat .n.teal{ color:var(--teal); } .why-stat .n.orange{ color:var(--orange); }
.why-stat .l{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-top:12px; }

/* ---------- before/after ---------- */
.results{ background:var(--paper); }
.ba-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:48px; }
.ba-card{ background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden; box-shadow:var(--shadow-soft); }
.ba-pair{ display:grid; grid-template-columns:1fr 1fr; gap:2px; background:var(--line); position:relative; }
.ba-pair image-slot{ width:100%; height:230px; }
.ba-tag{ position:absolute; top:12px; font-family:'Space Grotesk'; font-weight:700; font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:5px 10px; border-radius:4px; z-index:3; }
.ba-tag.before{ left:12px; background:rgba(13,33,55,.82); color:#fff; }
.ba-tag.after{ right:12px; background:var(--teal); color:var(--navy); }
.ba-info{ padding:20px 22px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.ba-info h3{ font-size:18px; }
.ba-info .meta{ font-size:13px; color:var(--gray); margin-top:4px; }
.ba-info .days{ font-family:'Space Grotesk'; font-weight:700; font-size:13px; color:var(--teal-3); background:rgba(46,155,155,.1); padding:6px 12px; border-radius:999px; white-space:nowrap; }

/* ---------- reviews ---------- */
.reviews{ background:#fff; }
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px; }
.rev-card{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:28px; display:flex; flex-direction:column; }
.stars{ display:flex; gap:3px; color:var(--orange); }
.rev-card .quote{ font-family:'Space Grotesk'; font-weight:600; font-size:18px; line-height:1.32; margin-top:16px; color:var(--navy); }
.rev-card .who{ display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:22px; }
.rev-card .av{ width:42px; height:42px; border-radius:50%; background:var(--teal); color:var(--navy); display:flex; align-items:center; justify-content:center; font-family:'Space Grotesk'; font-weight:700; font-size:15px; flex-shrink:0; }
.rev-card .who .nm{ font-family:'Space Grotesk'; font-weight:700; font-size:15px; }
.rev-card .who .loc{ font-size:13px; color:var(--gray); }
.rev-meta{ display:flex; align-items:center; gap:16px; margin-top:18px; flex-wrap:wrap; }
.rev-score{ display:flex; align-items:center; gap:12px; background:var(--navy); color:#fff; border-radius:12px; padding:14px 20px; }
.rev-score .big{ font-family:'Space Grotesk'; font-weight:700; font-size:34px; line-height:1; }

/* ---------- service area ---------- */
.areas{ background:var(--navy); color:#fff; }
.areas h2{ color:#fff; }
.area-layout{ display:grid; grid-template-columns:1fr 1.1fr; gap:56px; align-items:center; }
.area-list{ display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; }
.area-chip{ font-family:'Space Grotesk'; font-weight:600; font-size:15px; color:#fff; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.14); border-radius:999px; padding:10px 18px; transition:background .15s, border-color .15s; }
.area-chip:hover{ background:rgba(91,206,206,.14); border-color:var(--teal); }
.area-map{ position:relative; border-radius:16px; overflow:hidden; border:1px solid rgba(255,255,255,.14); }
.area-map image-slot{ width:100%; height:380px; }
.area-note{ display:flex; align-items:center; gap:10px; margin-top:24px; font-size:14px; color:rgba(255,255,255,.7); }

/* ---------- final cta band ---------- */
.cta-band{ background:var(--cta); color:var(--cta-ink); position:relative; overflow:hidden; }
.cta-band .wrap{ display:flex; align-items:center; justify-content:space-between; gap:40px; padding:64px 28px; flex-wrap:wrap; }
.cta-band h2{ color:var(--cta-ink); font-size:clamp(30px,3.6vw,46px); line-height:1.0; }
.cta-band p{ font-size:18px; color:rgba(13,33,55,.78); margin-top:12px; max-width:44ch; }
.cta-band .cb-actions{ display:flex; flex-direction:column; gap:12px; align-items:flex-start; }
.cta-band .cb-phone{ font-family:'Space Grotesk'; font-weight:700; font-size:40px; color:var(--navy); display:flex; align-items:center; gap:14px; }
.cta-band .cb-small{ font-family:'JetBrains Mono',monospace; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:rgba(13,33,55,.7); }
.cta-band .wm{ position:absolute; right:-60px; bottom:-90px; width:360px; opacity:.16; pointer-events:none; }

/* ---------- footer ---------- */
.footer{ background:var(--navy); color:rgba(255,255,255,.7); padding:64px 0 0; }
.footer .f-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.12); }
.footer h4{ color:#fff; font-size:14px; font-family:'JetBrains Mono',monospace; font-weight:500; letter-spacing:.14em; text-transform:uppercase; margin-bottom:18px; }
.footer .f-link{ display:block; font-size:15px; color:rgba(255,255,255,.7); padding:6px 0; transition:color .15s; }
.footer .f-link:hover{ color:var(--teal); }
.footer .f-about p{ font-size:15px; color:rgba(255,255,255,.66); margin-top:18px; max-width:34ch; }
.footer .f-badges{ display:flex; gap:8px; margin-top:20px; flex-wrap:wrap; }
.f-tag{ font-family:'Space Grotesk'; font-weight:700; font-size:11px; letter-spacing:.05em; padding:6px 10px; border-radius:4px; border:1.5px solid rgba(255,255,255,.2); color:rgba(255,255,255,.8); }
.footer .f-bottom{ display:flex; align-items:center; justify-content:space-between; padding:24px 0; gap:20px; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,.5); }
.footer .f-bottom .mono{ letter-spacing:.06em; }

/* ---------- sticky mobile call bar ---------- */
.mobile-bar{ display:none; }

/* ---------- placeholder caption styling for image-slots ---------- */
image-slot{ --slot-bg:rgba(255,255,255,.04); }

/* ============================================================
   Responsive
============================================================ */
@media (max-width:1020px){
  .hero .wrap{ grid-template-columns:1fr; gap:40px; }
  .lead-card{ max-width:520px; }
  .svc-grid{ grid-template-columns:1fr 1fr; }
  .svc.feature{ grid-row:span 1; grid-column:span 2; }
  .svc.feature .svc-media{ height:240px; }
  .why .why-grid{ grid-template-columns:1fr 1fr; }
  .rev-grid{ grid-template-columns:1fr; }
  .area-layout{ grid-template-columns:1fr; gap:36px; }
  .footer .f-top{ grid-template-columns:1fr 1fr; gap:32px; }
  .header-phone{ display:none; }
  .nav{ gap:20px; }
}
@media (max-width:760px){
  .section{ padding:64px 0; }
  .nav{ display:none; }
  .utility .u-left .u-hide{ display:none; }
  .utility .wrap{ gap:12px; font-size:11px; height:40px; }
  .utility .u-left, .utility .u-right{ gap:12px; }
  .header .wrap{ height:64px; }
  .header-phone{ display:none; }
  .ba-grid{ grid-template-columns:1fr; }
  .svc-grid{ grid-template-columns:1fr; }
  .svc.feature{ grid-column:span 1; }
  .why .why-grid{ grid-template-columns:1fr; }
  .footer .f-top{ grid-template-columns:1fr 1fr; }
  .cta-band .wrap{ padding:48px 28px; }
  body{ padding-bottom:72px; }
  .mobile-bar{
    display:flex; position:fixed; bottom:0; left:0; right:0; z-index:80;
    background:var(--navy); border-top:1px solid rgba(255,255,255,.12);
    padding:10px 14px; gap:10px;
    box-shadow:0 -10px 30px -12px rgba(0,0,0,.5);
  }
  .mobile-bar .mb-call{ flex:2; }
  .mobile-bar .mb-quote{ flex:1; }
}
@media (max-width:480px){
  .wrap{ padding:0 18px; }
  .u-hide-sm{ display:none; }
  .utility .wrap{ font-size:10px; letter-spacing:.03em; gap:10px; height:auto; min-height:38px; padding-top:7px; padding-bottom:7px; }
  .utility .u-dot{ box-shadow:0 0 0 3px rgba(67,209,126,.18); }
  .lockup img{ width:38px !important; }
  .wordmark{ font-size:18px !important; }
  .header .wrap{ gap:12px; }
  .btn-cta{ padding:13px 18px; font-size:15px; }
  .trust .wrap{ gap:16px; }
  .footer .f-top{ grid-template-columns:1fr; }
  .press-strip .ps-sub{ display:none; }
  .press-strip .ps-pub{ font-size:20px; }
  .press-strip .ps-link{ font-size:12px; }
}

/* ── INSURANCE STRIP ───────────────────────────────────────── */
.ins-section{
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:48px 0 36px;
}
.ins-head{
  text-align:center;
  margin-bottom:32px;
}
.ins-sub{
  font-size:16px;
  color:var(--gray);
  margin-top:10px;
}

/* scrolling marquee track */
.ins-track-wrap{
  overflow:hidden;
  mask-image:linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
}
.ins-track{
  display:flex;
  align-items:center;
  gap:56px;
  width:max-content;
  animation:ins-scroll 28s linear infinite;
}
.ins-track img{
  height:52px;
  width:auto;
  object-fit:contain;
  filter:grayscale(100%) opacity(0.65);
  transition:filter .25s;
  flex-shrink:0;
}
.ins-track img:hover{
  filter:grayscale(0%) opacity(1);
}
@keyframes ins-scroll{
  0%  { transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}
.ins-section:hover .ins-track{
  animation-play-state:paused;
}

/* IICRC badge */
.iicrc-badge{
  height:64px;
  width:auto;
  object-fit:contain;
  opacity:.8;
  margin-top:4px;
}

/* ── AREA MAP ───────────────────────────────────────────────── */
.area-map-inner{
  background:rgba(0,0,0,.22);
  border:1px solid rgba(91,206,206,.18);
  border-radius:14px;
  padding:24px 20px 20px;
}
.map-title{
  font-family:'Space Grotesk',sans-serif;
  font-size:13px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--teal-2); text-align:center;
  margin-bottom:16px;
}
.map-legend{
  display:flex; gap:24px; justify-content:center;
  margin-top:14px;
}
.ml-item{
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:rgba(255,255,255,.6);
  font-family:'JetBrains Mono',monospace;
}
.ml-dot{
  width:12px; height:12px; border-radius:50%; flex-shrink:0;
}
.ml-dot.primary{ background:var(--teal); }
.ml-dot.secondary{ background:rgba(91,206,206,.38); border:1px solid rgba(91,206,206,.55); }

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ transition:none !important; }
  .ins-track{ animation:none; }
}
