/* =========================================================
   Flood Dry Elite — brand system
   ========================================================= */

:root{
  /* palette */
  --navy:        #0e2538;
  --navy-2:      #14304a;
  --navy-3:      #1a3d5c;
  --blue:        #1f6f8b;
  --blue-2:      #2f8aa8;
  --red:         #d23a26;
  --red-dark:    #a52817;
  --red-ink:     #6b1810;
  --sun:         #f4c84a;
  --paper:       #f6f1e6;
  --paper-2:     #efe8d7;
  --paper-3:     #e6dec8;
  --ink:         #14110d;
  --ink-2:       #2d2823;
  --mute:        #6a635a;
  --line:        rgba(20,17,13,0.12);
  --line-strong: rgba(20,17,13,0.22);

  /* type — Flood Titan-style restoration industry pairing */
  --display: 'Oswald', 'Arial Narrow', system-ui, sans-serif;
  --ui:      'Open Sans', system-ui, -apple-system, Segoe UI, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* rhythm */
  --container: 1240px;
  --gutter: 28px;
  --radius: 14px;
  --radius-lg: 22px;
  --shadow: 0 1px 0 rgba(20,17,13,.04), 0 18px 40px -22px rgba(14,37,56,.25);
  --shadow-lg: 0 24px 80px -28px rgba(14,37,56,.45);
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--ui);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;}
img{display:block;max-width:100%;}

/* =========================================================
   Type scale
   ========================================================= */
.display{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:-0.005em;
  line-height:1.05;
  color:var(--ink);
  margin:0;
  text-wrap:balance;
  text-transform:uppercase;
}
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--mute);
}
.eyebrow.on-dark{color:rgba(246,241,230,.7);}
.mono{font-family:var(--mono); font-size:13px; letter-spacing:.02em;}
.lede{font-size:18px; line-height:1.55; color:var(--ink-2); max-width:62ch; text-wrap:pretty;}

h1,h2,h3,h4{
  margin:0;
  font-family:var(--display);
  font-weight:600;
  letter-spacing:-0.005em;
  line-height:1.08;
  text-wrap:balance;
  text-transform:uppercase;
}
h1{font-size:clamp(42px, 5.8vw, 84px); font-weight:700; letter-spacing:-0.01em;}
h2{font-size:clamp(32px, 3.8vw, 52px); font-weight:600;}
h3{font-size:clamp(22px, 1.9vw, 28px); font-weight:600;}
h4{font-size:18px; line-height:1.25; font-weight:600;}
p{margin:0; text-wrap:pretty;}

/* =========================================================
   Layout
   ========================================================= */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}
.section{padding: clamp(56px, 7vw, 112px) 0;}
.section-tight{padding: clamp(40px, 5vw, 72px) 0;}
.divider{height:1px; background:var(--line);}

/* =========================================================
   Header
   ========================================================= */
.topbar{
  background:var(--navy);
  color:#f6f1e6;
  font-size:13px;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 0;
}
.topbar a{display:inline-flex; align-items:center; gap:8px;}
.topbar .dot{
  width:7px; height:7px; border-radius:50%;
  background:#46d27a; box-shadow:0 0 0 4px rgba(70,210,122,0.2);
  animation: pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px rgba(70,210,122,0.2);}
  50%    {box-shadow:0 0 0 7px rgba(70,210,122,0.05);}
}

.header{
  position:sticky; top:0; z-index:50;
  background:rgba(246,241,230,0.92);
  backdrop-filter: blur(10px) saturate(1.1);
  -webkit-backdrop-filter: blur(10px) saturate(1.1);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:74px; gap:24px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  font-family:var(--display); font-weight:600; font-size:22px;
  letter-spacing:0.01em;
  text-transform:uppercase;
}
.brand-mark{
  width:38px; height:38px;
  background:var(--navy);
  color:#f6f1e6;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:700; font-size:18px;
  letter-spacing:0.02em;
  position:relative;
  overflow:hidden;
}
.brand-mark::after{
  content:""; position:absolute; inset:auto 0 0 0; height:32%;
  background:linear-gradient(180deg, transparent, rgba(31,111,139,0.7));
}
.brand-name{display:flex; flex-direction:column; line-height:1;}
.brand-name span{font-family:var(--mono); font-size:10px; color:var(--mute); letter-spacing:.12em; text-transform:uppercase; margin-top:3px;}

.nav{display:flex; gap:4px; align-items:center;}
.nav a{
  position:relative;
  padding:8px 12px; border-radius:8px;
  font-weight:500; font-size:14.5px; color:var(--ink-2);
  transition: background .15s, color .15s;
}
.nav a:hover{background:rgba(20,17,13,0.05); color:var(--ink);}
.nav a.active{color:var(--ink); background:rgba(14,37,56,0.06);}
.nav-cta{display:flex; align-items:center; gap:10px;}
.phone-link{
  display:flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:14px; font-weight:500;
  padding:6px 0;
}
.phone-link strong{font-weight:600; color:var(--ink);}

/* Mobile nav */
.menu-toggle{display:none;}
@media (max-width: 940px){
  .nav, .nav-cta .phone-link span:not(.phone-num){display:none;}
}
@media (max-width: 760px){
  .header-inner{height:62px;}
  .nav{display:none;}
  .nav.open{
    display:flex; flex-direction:column;
    position:fixed; inset:62px 0 auto 0;
    background:var(--paper); padding:16px 20px 24px;
    border-bottom:1px solid var(--line); gap:0;
    box-shadow:var(--shadow);
  }
  .nav.open a{padding:14px 8px; border-bottom:1px solid var(--line); border-radius:0; font-size:17px;}
  .menu-toggle{
    display:flex; align-items:center; justify-content:center;
    width:42px; height:42px; border-radius:10px;
    background:var(--paper-2); color:var(--ink);
  }
  .nav-cta .phone-link{display:none;}
  .brand-name span{display:none;}
}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 24px;
  border-radius:6px;
  font-family:var(--display); font-weight:600; font-size:15px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  transition: transform .12s, box-shadow .15s, background .15s, color .15s, border-color .15s;
  white-space:nowrap;
  cursor:pointer;
  border:1.5px solid transparent;
}
.btn:active{transform: translateY(1px);}
.btn-primary{
  background:var(--red); color:#fff; border-color:var(--red-dark);
  box-shadow: 0 1px 0 rgba(255,255,255,0.2) inset, 0 8px 22px -8px rgba(210,58,38,0.55);
}
.btn-primary:hover{background:var(--red-dark);}
.btn-primary.lg{padding:18px 28px; font-size:16px;}
.btn-ghost{
  background:transparent; color:var(--ink);
  border-color:var(--line-strong);
}
.btn-ghost:hover{background:rgba(20,17,13,0.04); border-color:var(--ink);}
.btn-ghost.on-dark{color:#f6f1e6; border-color:rgba(246,241,230,0.35);}
.btn-ghost.on-dark:hover{background:rgba(246,241,230,0.08); border-color:#f6f1e6;}
.btn-light{
  background:#fff; color:var(--red); border-color:#fff;
  box-shadow: 0 8px 22px -10px rgba(0,0,0,0.3);
}
.btn-light:hover{background:var(--paper);}
.btn-sm{padding:9px 16px; font-size:13.5px;}

.btn .ico{width:18px; height:18px;}

/* =========================================================
   Trust bar
   ========================================================= */
.trust-bar{
  background:var(--paper-2);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:14px 0;
}
.trust-bar-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; flex-wrap:wrap;
}
.trust-item{
  display:flex; align-items:center; gap:10px;
  font-size:14px; color:var(--ink-2);
}
.trust-item svg{flex-shrink:0; color:var(--blue);}
.trust-item strong{color:var(--ink); font-weight:600;}

/* =========================================================
   Hero — full-bleed image with dark overlay
   ========================================================= */
.hero{
  background:var(--paper);
  padding: 0;
  position:relative;
  overflow:hidden;
  min-height: clamp(560px, 78vh, 760px);
  display:flex;
  align-items:stretch;
}
.hero-bg{
  position:absolute; inset:0; z-index:0;
}
.hero-bg .photo{
  width:100%; height:100%;
  border-radius:0;
}
.hero-bg .photo .photo-label{display:none;}
/* darker industrial hero photo */
.photo.hero{
  background:
    linear-gradient(135deg, #18181b 0%, #27272a 40%, #3f3f46 75%, #52525b 100%);
}
.photo.hero::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, transparent 0 22px, rgba(255,255,255,0.025) 22px 23px),
    repeating-linear-gradient(-45deg, transparent 0 60px, rgba(0,0,0,0.08) 60px 61px);
}

/* dark gradient scrim over the photo */
.hero-scrim{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(100deg,
      rgba(10,10,10,0.92) 0%,
      rgba(10,10,10,0.78) 38%,
      rgba(10,10,10,0.45) 65%,
      rgba(10,10,10,0.15) 100%),
    radial-gradient(800px 500px at 90% 90%, rgba(234,88,12,0.18), transparent 60%);
  pointer-events:none;
}

.hero-container{
  position:relative; z-index:2;
  width:100%;
  padding-top: clamp(56px, 7vw, 96px);
  padding-bottom: clamp(56px, 7vw, 96px);
  display:flex;
  align-items:center;
  min-height: clamp(560px, 78vh, 760px);
}
.hero-content{
  max-width: 680px;
  color:#fff;
  position:relative;
}
.hero h1{
  color:#fff;
  text-shadow: 0 2px 30px rgba(0,0,0,0.4);
}
.hero .accent-mark{
  color:var(--sun);
  font-weight:500;
}
.hero .lede.on-dark{color:rgba(255,255,255,0.82);}

.hero-tag.on-dark{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(8px);
  color:rgba(255,255,255,0.95);
  display:inline-flex; align-items:center; gap:10px;
  border-radius:6px;
  padding:6px 14px 6px 6px;
  font-size:13px;
  margin-bottom:22px;
}

.hero .meta-row.on-dark{
  display:flex; gap:18px; align-items:center; flex-wrap:wrap;
  margin-top:32px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.15);
  font-size:13.5px;
  color:rgba(255,255,255,0.78);
}
.hero .meta-row.on-dark .sep{opacity:.35; color:#fff;}

/* on-dark ghost button override */
.btn-ghost.on-dark{
  background:rgba(255,255,255,0.06);
  color:#fff;
  border-color:rgba(255,255,255,0.4);
  backdrop-filter: blur(6px);
}
.btn-ghost.on-dark:hover{
  background:rgba(255,255,255,0.14);
  border-color:#fff;
}

/* Floating testimonial card, bottom-right of hero */
.hero-card-floating{
  position:absolute;
  right:0; bottom:0;
  width:340px;
  background:rgba(20,17,13,0.65);
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:10px;
  padding:20px 22px;
  color:#fff;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.hero-card-row{
  display:flex; align-items:center; gap:12px;
  margin-bottom:10px;
}
.hero-card-floating .av{
  width:38px; height:38px; border-radius:50%;
  background:var(--red);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:700; font-size:13px;
  letter-spacing:0.02em;
  flex-shrink:0;
}
.hero-card-floating .stars{
  color:var(--sun); letter-spacing:2px; font-size:14px;
}
.hero-card-floating p{
  font-family:var(--ui); font-style:italic;
  font-size:14px; line-height:1.5;
  color:rgba(255,255,255,0.95);
  text-wrap:pretty;
  margin:0;
}
.hero-card-foot{
  margin-top:10px;
  font-size:11.5px;
  color:rgba(255,255,255,0.6);
  font-family:var(--mono);
  letter-spacing:0.02em;
}

/* photo caption at bottom-left of hero */
.hero-caption{
  position:absolute;
  left:0; bottom:24px;
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:11px;
  text-transform:uppercase; letter-spacing:0.08em;
  color:rgba(255,255,255,0.7);
}
.hero-caption-dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--red);
  box-shadow: 0 0 0 4px rgba(234,88,12,0.25);
  animation: pulse-hero 2s infinite;
}
@keyframes pulse-hero{
  0%,100%{box-shadow: 0 0 0 4px rgba(234,88,12,0.25);}
  50%    {box-shadow: 0 0 0 8px rgba(234,88,12,0.05);}
}

@media (max-width: 940px){
  .hero{min-height:auto;}
  .hero-container{
    flex-direction:column;
    align-items:flex-start;
    padding-top: 56px;
    padding-bottom: 56px;
    gap:36px;
    min-height:auto;
  }
  .hero-card-floating{
    position:relative;
    right:auto; bottom:auto;
    width:100%;
    max-width:none;
  }
  .hero-caption{
    position:relative;
    left:auto; bottom:auto;
    order:-1;
    margin-bottom:8px;
  }
}

/* hero photo */
.hero-photos{position:relative;}
.hero-photo-main{
  aspect-ratio: 5/6;
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
}
.hero-photo-strip{
  display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:12px;
}
.hero-photo-strip .photo{aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden;}

.badge-floating{
  position:absolute; left:-14px; bottom:24px;
  background:#fff;
  border-radius:14px;
  padding:14px 16px;
  box-shadow:var(--shadow-lg);
  display:flex; align-items:center; gap:12px;
  max-width:260px;
}
.badge-floating .av{
  width:42px; height:42px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg, var(--blue), var(--navy));
  color:#f6f1e6; display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:700;
}
.badge-floating .copy{font-size:13px; line-height:1.35;}
.badge-floating .copy strong{display:block; color:var(--ink);}
.badge-floating .copy span{color:var(--mute);}

.hero-tag{
  display:inline-flex; align-items:center; gap:10px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 14px 6px 6px;
  font-size:13px;
  color:var(--ink-2);
  margin-bottom:18px;
}
.hero-tag .pill{
  background:var(--red); color:#fff;
  font-family:var(--mono); font-size:11px; font-weight:600;
  padding:3px 10px; border-radius:999px;
  letter-spacing:.06em;
}

/* =========================================================
   Photo placeholder system
   ========================================================= */
.photo{
  position:relative;
  background:
    linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 60%, var(--blue) 100%);
  color:rgba(246,241,230,0.9);
  overflow:hidden;
}
.photo::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(800px 400px at 70% 20%, rgba(255,255,255,0.12), transparent 50%),
    radial-gradient(400px 300px at 20% 80%, rgba(244,200,74,0.18), transparent 60%);
}
.photo::after{
  content:"";
  position:absolute; inset:0;
  background-image: repeating-linear-gradient(45deg, transparent 0 22px, rgba(255,255,255,0.03) 22px 23px);
}
.photo .photo-label{
  position:absolute; left:14px; bottom:12px; z-index:2;
  font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(20,17,13,0.55);
  padding:5px 10px; border-radius:6px;
  backdrop-filter: blur(4px);
}
.photo.warm{
  background:linear-gradient(135deg, #6b3520 0%, #a04018 50%, #d2602a 100%);
}
.photo.water{
  background:linear-gradient(135deg, #0e2538 0%, #1f6f8b 60%, #2f8aa8 100%);
}
.photo.fire{
  background:linear-gradient(135deg, #2a0e0a 0%, #6b1810 45%, #c0381f 100%);
}
.photo.mold{
  background:linear-gradient(135deg, #1d2818 0%, #3d5c2e 60%, #6b8a4a 100%);
}
.photo.warm-sun{
  background:linear-gradient(135deg, #2a1f0a 0%, #8a6b1a 50%, #f4c84a 100%);
}
.photo.neutral{
  background:linear-gradient(135deg, #2d2823 0%, #5a4f44 60%, #8a7f72 100%);
}

/* =========================================================
   Service cards (homepage)
   ========================================================= */
.svc-grid{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap:18px;
}
@media (max-width: 1080px){.svc-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width: 640px){.svc-grid{grid-template-columns:1fr 1fr;}}
.svc-card{
  display:flex; flex-direction:column;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition: transform .2s, box-shadow .2s, border-color .2s;
  cursor:pointer;
}
.svc-card:hover{
  transform: translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--line-strong);
}
.svc-card.span-2{grid-column: span 2;}
.svc-card .photo{height:140px;}
.svc-card .body{padding:18px;}
.svc-card h3{font-size:21px; margin-bottom:6px;}
.svc-card p{font-size:13.5px; color:var(--mute); line-height:1.5;}
.svc-card .more{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; color:var(--blue); font-weight:600;
  margin-top:12px;
}

/* =========================================================
   Why us
   ========================================================= */
.why-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
@media (max-width: 900px){.why-grid{grid-template-columns:1fr 1fr;}}
@media (max-width: 520px){.why-grid{grid-template-columns:1fr;}}
.why-card{
  background:var(--paper-2);
  border-radius:var(--radius);
  padding:24px;
  display:flex; flex-direction:column; gap:10px;
  border:1px solid var(--line);
  transition: background .2s, border-color .2s;
}
.why-card:hover{background:#fff; border-color:var(--line-strong);}
.why-num{
  font-family:var(--display);
  font-weight:700; font-size:36px; line-height:1;
  color:var(--blue); letter-spacing:0.01em;
}
.why-card h4{font-size:19px; font-family:var(--display); text-transform:uppercase; letter-spacing:0.01em;}
.why-card p{font-size:13.5px; color:var(--ink-2); line-height:1.5;}

/* =========================================================
   Process steps
   ========================================================= */
.process{
  background:var(--navy);
  color:#f6f1e6;
  border-radius:var(--radius-lg);
  padding: clamp(40px, 5vw, 72px);
  position:relative;
  overflow:hidden;
}
.process::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(600px 300px at 80% 10%, rgba(31,111,139,0.45), transparent 60%),
    radial-gradient(500px 300px at 10% 90%, rgba(244,200,74,0.18), transparent 60%);
  pointer-events:none;
}
.process-head{position:relative;}
.process-head .eyebrow{color:var(--sun);}
.process-head h2{color:#f6f1e6; max-width:18ch; margin-top:8px;}
.process-head p{color:rgba(246,241,230,0.75); margin-top:12px; max-width:46ch;}

.process-steps{
  position:relative;
  margin-top: clamp(32px, 4vw, 56px);
  display:grid; grid-template-columns:repeat(5,1fr); gap:0;
}
.process-step{
  position:relative;
  padding:22px 18px 6px 0;
}
.process-step:not(:last-child){border-right:1px solid rgba(246,241,230,0.12); padding-right:20px;}
.process-step:not(:first-child){padding-left:20px;}
.process-step .step-num{
  font-family:var(--mono); font-size:12px; font-weight:600;
  color:var(--sun); letter-spacing:.12em;
}
.process-step h4{
  margin-top:8px; font-size:20px; color:#f6f1e6;
}
.process-step p{
  font-size:13.5px; color:rgba(246,241,230,0.7); line-height:1.5;
  margin-top:6px;
}
.process-step .marker{
  width:14px; height:14px; border-radius:50%;
  background:var(--red);
  box-shadow:0 0 0 6px rgba(210,58,38,0.18);
  margin-bottom:10px;
}
@media (max-width: 940px){.process-steps{grid-template-columns:1fr 1fr;} .process-step{border-right:none !important; padding-left:0 !important; padding-right:0 !important; border-bottom:1px solid rgba(246,241,230,0.1); padding-bottom:16px;}}
@media (max-width: 520px){.process-steps{grid-template-columns:1fr;}}

/* =========================================================
   Service area
   ========================================================= */
.area{
  display:grid; grid-template-columns: 1fr 1.2fr; gap:48px; align-items:center;
}
@media (max-width: 900px){.area{grid-template-columns:1fr;}}
.area-map{
  position:relative;
  aspect-ratio: 4/3;
  border-radius:var(--radius-lg);
  background: var(--paper-2);
  border:1px solid var(--line);
  overflow:hidden;
}
.city-chips{display:flex; gap:8px; flex-wrap:wrap; margin-top:16px;}
.chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  font-size:13.5px; color:var(--ink-2);
  transition: background .15s, border-color .15s;
  cursor:pointer;
}
.chip:hover{background:var(--paper-2); border-color:var(--line-strong);}
.chip .pin{
  width:8px; height:8px; border-radius:50%;
  background:var(--red);
}

/* =========================================================
   About strip
   ========================================================= */
.about-strip{
  display:grid; grid-template-columns:1.1fr 1fr; gap:48px; align-items:center;
}
@media (max-width: 900px){.about-strip{grid-template-columns:1fr;}}
.about-photos{
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
.about-photos .photo{aspect-ratio:4/5; border-radius:var(--radius);}
.about-photos .photo:nth-child(1){transform: translateY(-12px);}
.about-photos .photo:nth-child(2){transform: translateY(12px);}

.signature{
  font-family:'Caveat', cursive;
  font-size:28px;
  color:var(--blue);
  margin-top:18px;
  line-height:1;
}

/* =========================================================
   Final CTA band
   ========================================================= */
.final-cta{
  background:linear-gradient(135deg, var(--red-dark), var(--red));
  color:#fff;
  border-radius:var(--radius-lg);
  padding: clamp(36px, 5vw, 64px);
  position:relative;
  overflow:hidden;
}
.final-cta::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(600px 300px at 90% -10%, rgba(255,255,255,0.18), transparent 60%),
    radial-gradient(500px 300px at -10% 110%, rgba(0,0,0,0.2), transparent 60%);
  pointer-events:none;
}
.final-cta-inner{
  display:flex; align-items:center; justify-content:space-between; gap:32px;
  flex-wrap:wrap;
  position:relative;
}
.final-cta h2{color:#fff; max-width:20ch;}
.final-cta p{color:rgba(255,255,255,0.85); margin-top:8px; max-width:48ch;}
.final-cta .ctas{display:flex; gap:12px; flex-wrap:wrap;}

/* =========================================================
   Footer
   ========================================================= */
.footer{
  background:var(--navy);
  color:rgba(246,241,230,0.78);
  padding: 64px 0 32px;
  font-size:14px;
}
.footer a:hover{color:#fff;}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr 1.2fr;
  gap:40px;
}
@media (max-width: 900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width: 560px){.footer-grid{grid-template-columns:1fr;}}
.footer h5{
  font-family:var(--ui); font-size:12px; font-weight:600;
  text-transform:uppercase; letter-spacing:.14em;
  color:#fff; margin:0 0 14px;
}
.footer ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px;}
.footer .brand{color:#f6f1e6;}
.footer .brand-mark{background:#fff; color:var(--navy);}
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:48px; padding-top:24px;
  border-top:1px solid rgba(246,241,230,0.12);
  font-size:13px; color:rgba(246,241,230,0.55);
  flex-wrap:wrap; gap:12px;
}

/* =========================================================
   Page header (sub-pages)
   ========================================================= */
.page-head{
  padding: 56px 0 40px;
  background:
    radial-gradient(900px 400px at 90% 0%, rgba(31,111,139,0.14), transparent 60%),
    var(--paper);
  border-bottom:1px solid var(--line);
}
.crumbs{
  display:flex; gap:8px; align-items:center;
  font-family:var(--mono); font-size:12px; color:var(--mute);
  letter-spacing:.04em;
  margin-bottom:18px;
}
.crumbs a:hover{color:var(--ink);}
.crumbs .sep{opacity:.4;}
.page-head h1{font-size: clamp(40px, 4.6vw, 60px);}
.page-head .lede{margin-top:14px;}
.page-head .head-meta{
  display:flex; gap:32px; flex-wrap:wrap; margin-top:24px;
  padding-top:24px; border-top:1px solid var(--line);
}
.head-meta .stat{min-width:140px;}
.head-meta .stat .v{font-family:var(--display); font-weight:600; font-size:32px; color:var(--navy); line-height:1; letter-spacing:0.005em;}
.head-meta .stat .l{font-size:13px; color:var(--mute); margin-top:4px;}

/* =========================================================
   Service page (sub-pages)
   ========================================================= */
.svc-hero{
  display:grid; grid-template-columns: 1.1fr 0.9fr; gap:48px; align-items:center;
}
@media (max-width: 900px){.svc-hero{grid-template-columns:1fr;}}
.svc-hero .photo{aspect-ratio: 5/4; border-radius:var(--radius-lg);}

.list-checks{list-style:none; padding:0; margin:0; display:grid; gap:12px;}
.list-checks li{display:flex; gap:12px; align-items:flex-start; font-size:15px;}
.list-checks .ck{
  flex-shrink:0;
  width:22px; height:22px; border-radius:50%;
  background:var(--blue); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; margin-top:1px;
}

.scenarios{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:18px;
}
@media (max-width: 900px){.scenarios{grid-template-columns:1fr;}}
.scenario{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius); padding:24px;
}
.scenario h4{font-size:20px; margin-bottom:8px;}
.scenario p{font-size:14px; color:var(--mute); line-height:1.55;}
.scenario .tag{
  display:inline-block; font-family:var(--mono); font-size:11px; color:var(--red);
  letter-spacing:.08em; text-transform:uppercase; margin-bottom:8px;
}

.before-after{
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
}
@media (max-width: 600px){.before-after{grid-template-columns:1fr;}}
.before-after .photo{aspect-ratio:4/3; border-radius:var(--radius);}
.ba-pair{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius); padding:16px;
}
.ba-pair h5{font-family:var(--display); font-size:18px; margin:12px 0 4px;}
.ba-pair p{font-size:13px; color:var(--mute);}

.faq summary{
  list-style:none;
  cursor:pointer;
  padding:22px 0;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:var(--display); font-weight:500; font-size:22px;
  letter-spacing:0.005em; text-transform:uppercase;
  color:var(--ink);
  border-top:1px solid var(--line);
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{
  content:"+"; font-size:24px; color:var(--mute);
  transition: transform .2s;
}
.faq details[open] summary::after{content:"−";}
.faq details:last-of-type{border-bottom:1px solid var(--line);}
.faq .answer{
  padding:0 0 22px;
  font-size:15.5px; color:var(--ink-2); line-height:1.6; max-width:70ch;
}

/* =========================================================
   Form
   ========================================================= */
.form-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding: clamp(24px, 3vw, 36px);
  box-shadow:var(--shadow);
}
.form-row{display:grid; gap:18px;}
.form-row.two{grid-template-columns:1fr 1fr;}
@media (max-width: 600px){.form-row.two{grid-template-columns:1fr;}}
.field{display:flex; flex-direction:column; gap:6px;}
.field label{font-size:13px; font-weight:500; color:var(--ink-2);}
.field label .req{color:var(--red); margin-left:2px;}
.field input, .field textarea, .field select{
  width:100%;
  padding:13px 14px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:10px;
  font-family:var(--ui); font-size:15px; color:var(--ink);
  transition: border-color .15s, background .15s;
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none;
  border-color:var(--blue);
  background:#fff;
  box-shadow: 0 0 0 4px rgba(31,111,139,0.12);
}
.field textarea{min-height:110px; resize:vertical;}
.field .err{font-size:12px; color:var(--red); font-weight:500;}
.field.has-err input, .field.has-err textarea, .field.has-err select{border-color:var(--red);}

.choice-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:8px;
}
@media (max-width: 600px){.choice-grid{grid-template-columns:1fr 1fr;}}
.choice{
  display:flex; align-items:center; gap:10px;
  padding:12px 14px; border-radius:10px;
  background:var(--paper); border:1.5px solid var(--line);
  font-size:14.5px; color:var(--ink-2);
  cursor:pointer;
  transition: all .15s;
  user-select:none;
}
.choice:hover{border-color:var(--line-strong);}
.choice.selected{
  background:var(--paper-2);
  border-color:var(--navy); color:var(--ink);
  font-weight:500;
}
.choice .ico{width:18px;}

/* success state */
.form-success{
  text-align:center; padding:32px 12px;
}
.form-success .ck-big{
  width:64px; height:64px; border-radius:50%;
  background:#46d27a; color:#fff;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 18px;
  box-shadow: 0 0 0 12px rgba(70,210,122,0.18);
}
.form-success h3{margin-bottom:8px;}
.form-success p{color:var(--ink-2); max-width:42ch; margin:0 auto;}

/* =========================================================
   Mobile call-bar (sticky bottom)
   ========================================================= */
.mobile-callbar{
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:60;
  background:var(--red);
  color:#fff;
  padding:10px 16px;
  border-top:2px solid var(--red-dark);
  box-shadow:0 -10px 30px rgba(0,0,0,0.18);
  align-items:center; justify-content:space-between; gap:12px;
}
@media (max-width: 760px){
  .mobile-callbar{display:flex;}
  body{padding-bottom:72px;}
}
.mobile-callbar .label{font-size:12px; opacity:.9; line-height:1;}
.mobile-callbar .num{font-family:var(--mono); font-size:18px; font-weight:600; line-height:1; margin-top:2px;}
.mobile-callbar .btn{background:#fff; color:var(--red); padding:11px 18px;}

/* =========================================================
   Misc utilities
   ========================================================= */
.section-head{margin-bottom: clamp(28px, 3.5vw, 48px); max-width:60ch;}
.section-head .eyebrow{margin-bottom:14px;}
.section-head .lede{margin-top:14px;}
.flex{display:flex;}
.between{justify-content:space-between;}
.center{align-items:center;}
.gap-12{gap:12px;} .gap-16{gap:16px;} .gap-24{gap:24px;}
.mt-12{margin-top:12px;} .mt-24{margin-top:24px;}

/* page transitions */
.page-enter{animation: fadeUp .35s ease both;}
@keyframes fadeUp{
  from{opacity:0; transform:translateY(8px);}
  to{opacity:1; transform:none;}
}

/* Testimonial card */
.testi{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
}
.testi .stars{color:var(--sun); font-size:16px; letter-spacing:2px;}
.testi blockquote{
  font-family:var(--ui); font-weight:400; font-size:17px; line-height:1.5; color:var(--ink);
  margin:14px 0; text-wrap:pretty; font-style:italic;
}
.testi .who{
  display:flex; align-items:center; gap:12px;
  font-size:13px; color:var(--mute);
}
.testi .who .av{
  width:36px; height:36px; border-radius:50%;
  background:linear-gradient(135deg, var(--blue), var(--navy));
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:600; font-size:14px;
}
.testi .who strong{color:var(--ink); font-weight:600; display:block;}

.testi-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
@media (max-width: 900px){.testi-grid{grid-template-columns:1fr;}}

/* =========================================================
   Version banner (compare v1 vs v2)
   ========================================================= */
.version-banner{
  position:fixed; bottom:20px; right:20px; z-index:70;
  background:#fff;
  border:1px solid var(--line-strong);
  border-radius:999px;
  padding:8px 8px 8px 18px;
  box-shadow: 0 24px 60px -16px rgba(20,17,13,0.25), 0 6px 12px rgba(20,17,13,0.06);
  display:flex; align-items:center; gap:14px;
  font-size:13px; font-weight:500; color:var(--ink-2);
}
.version-banner strong{color:var(--ink); font-weight:600;}
.version-banner a{
  background:var(--navy); color:#fff;
  padding:8px 16px; border-radius:999px;
  font-weight:600; font-size:12.5px;
  transition: background .15s;
}
.version-banner a:hover{background:var(--ink);}
@media (max-width: 760px){
  .version-banner{bottom:90px; left:20px; right:20px; justify-content:space-between;}
}
