*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#13253F;
  --teal:#0E7A6E;
  --teal-h:#0d6b61;
  --gold:#C9973A;
  --gold-h:#b8862e;
  --cream:#FAF8F3;
  --muted:#6B7280;
  --border:#E5E7EB;
  --white:#fff;
  --text:#1E293B;
}
html,body{
  height:100%;
  font-family:'DM Sans',sans-serif;
  background:var(--cream);
  color:var(--text);
  overflow:hidden;
}

/* ── NAV ── */
nav{
  display:flex;align-items:center;
  height:68px;
  padding:0 32px;
  background:var(--white);
  border-bottom:1px solid var(--border);
  gap:0;
}
.logo{display:flex;align-items:center;gap:9px;text-decoration:none;flex-shrink:0}
.logo-svg{width:42px;height:42px}
.logo-txt{line-height:1.15}
.logo-brand{font-size:1.0rem;font-weight:700;letter-spacing:-0.2px;line-height:1;white-space:nowrap}
.logo-brand .c1{color:var(--navy)}
.logo-brand .c2{color:var(--teal)}
.logo-tag{font-size:0.65rem;color:var(--muted);font-weight:400;margin-top:1px}
.nav-links{display:flex;gap:32px;list-style:none;flex:1;justify-content:center}
.nav-links a{text-decoration:none;color:var(--text);font-size:0.85rem;font-weight:500}
.nav-links a:hover{color:var(--teal)}
.nav-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.nav-phone{display:flex;align-items:center;gap:5px;font-size:0.875rem;font-weight:600;color:var(--text);text-decoration:none;white-space:nowrap}
.nav-phone svg{width:15px;height:15px;stroke:var(--teal);fill:none;stroke-width:2.2}
.btn-gold{
  background:var(--gold);color:var(--white);
  border:none;border-radius:7px;
  padding:9px 20px;
  font-family:'DM Sans',sans-serif;font-size:0.85rem;font-weight:600;
  cursor:pointer;white-space:nowrap;
}
.btn-gold:hover{background:var(--gold-h)}

/* ── MAIN ── */
main{
  display:flex;flex-direction:column;
  height:calc(100vh - 68px);
}

/* ── HERO ── */
.hero{
  flex:1;
  display:grid;
  grid-template-columns:240px 1fr 420px;
  gap:0;
  padding:28px 0 0 32px;
  background:var(--cream);
  min-height:0;
}

/* LEFT */
.left{
  display:flex;flex-direction:column;justify-content:flex-start;
  padding-right:20px;
  padding-top:4px;
  opacity:0.82;
}
.badge{display:flex;align-items:center;gap:7px;margin-bottom:14px}
.badge-circle{
  width:26px;height:26px;border-radius:50%;
  background:rgba(201,151,58,0.13);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.badge-circle svg{width:13px;height:13px;stroke:var(--gold);fill:none;stroke-width:2.5}
.badge-txt{font-size:0.67rem;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold)}
h1{
  font-family:'Playfair Display',serif;
  font-size:2.4rem;line-height:1.12;
  color:var(--navy);
  font-weight:700;
  margin-bottom:14px;
}
h1 .teal{color:var(--teal)}
.sub{font-size:0.85rem;color:var(--muted);line-height:1.65;margin-bottom:18px;max-width:260px}
.trust-row{display:flex;gap:18px;margin-bottom:18px}
.ti{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}
.ti-circle{
  width:48px;height:48px;border-radius:50%;
  background:rgba(14,122,110,0.07);
  border:1.5px solid rgba(14,122,110,0.14);
  display:flex;align-items:center;justify-content:center;
}
.ti-circle svg{width:20px;height:20px;stroke:var(--teal);fill:none;stroke-width:2}
.ti-lbl{font-size:0.67rem;font-weight:600;color:var(--text);max-width:68px;line-height:1.3}
.review{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);border:1px solid var(--border);
  border-radius:8px;padding:8px 13px;
}
.stars{color:var(--gold);font-size:0.9rem;letter-spacing:1px}
.rev-txt{font-size:0.75rem;color:var(--muted)}
.rev-txt strong{color:var(--text)}

/* CENTER COLLAGE */
.center{
  padding:0 14px 0 30px;
  display:flex;flex-direction:column;gap:6px;
  min-height:0;
  opacity:0.78;
}
.col-top img,.col-bot img{
  width:100%;height:185px;
  object-fit:cover;border-radius:10px;display:block;
}
.col-mid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.col-mid img{width:100%;height:130px;object-fit:cover;border-radius:10px;display:block}

/* ── RIGHT FORM — spotlight column, pops over trust strip ── */
.right{
  display:flex;flex-direction:column;
  min-height:0;
  background:transparent;
  border-radius:14px 0 0 0;
  margin-top:-28px;
  padding:24px 32px 0 20px;
  position:relative;
  z-index:10;
}
.form-card{
  background:var(--white);
  border-radius:12px;
  border:none;
  box-shadow:0 32px 80px rgba(0,0,0,0.50), 0 8px 24px rgba(0,0,0,0.20);
  overflow:hidden;
  display:flex;flex-direction:column;
  flex:1;
  min-height:0;
  /* pull the card down to overlap the trust strip */
  margin-bottom:-52px;
}
.fc-head{
  background:linear-gradient(135deg,#0E7A6E 0%,#12A090 100%);
  padding:16px 22px 14px;
  flex-shrink:0;
}
.fc-head h2{
  font-family:'Playfair Display',serif;
  color:var(--white);font-size:1.12rem;line-height:1.25;
  text-align:center;margin-bottom:3px;
}
.fc-head p{color:rgba(255,255,255,0.8);font-size:0.73rem;text-align:center}
/* step tracker */
.tracker{display:flex;align-items:center;justify-content:center;margin-top:12px;gap:0}
.sd{display:flex;flex-direction:column;align-items:center;gap:3px;position:relative;z-index:1}
.sc{
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,0.18);
  border:2px solid rgba(255,255,255,0.35);
  display:flex;align-items:center;justify-content:center;
  font-size:0.78rem;font-weight:700;color:rgba(255,255,255,0.55);
  transition:.3s;
}
.sd.active .sc{background:var(--gold);border-color:var(--gold);color:var(--white)}
.sd.done .sc{background:rgba(255,255,255,0.85);border-color:var(--white);color:var(--teal)}
.sn{font-size:0.6rem;color:rgba(255,255,255,0.55);font-weight:500;white-space:nowrap}
.sd.active .sn{color:var(--white);font-weight:600}
.sl{flex:1;height:2px;background:rgba(255,255,255,0.22);min-width:24px;margin-bottom:12px;transition:.3s}
.sl.done{background:rgba(255,255,255,0.65)}

.fc-body{padding:14px 18px;flex:1;overflow-y:auto;display:flex;flex-direction:column}
.fc-body::-webkit-scrollbar{width:4px}
.fc-body::-webkit-scrollbar-track{background:transparent}
.fc-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.fq{font-size:0.84rem;font-weight:600;color:var(--text);margin-bottom:2px}
.fs{font-size:0.71rem;color:var(--muted);margin-bottom:8px}

/* service grid — min-height:0 lets it shrink so the button stays visible */
.sg{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5px;margin-bottom:10px;
  flex:1;min-height:0;overflow-y:auto;
}
.sc2{
  border:1.5px solid var(--border);border-radius:8px;
  padding:7px 8px;cursor:pointer;
  display:flex;align-items:flex-start;gap:7px;
  background:var(--white);transition:all .18s;
}
.sc2:hover{border-color:var(--teal);background:rgba(14,122,110,0.03)}
.sc2.sel{border-color:var(--teal);background:rgba(14,122,110,0.06)}
.si{width:24px;height:24px;flex-shrink:0;stroke:var(--teal);fill:none;stroke-width:1.8}
.st h4{font-size:0.70rem;font-weight:600;color:var(--text);margin-bottom:1px;line-height:1.2}
.st p{font-size:0.61rem;color:var(--muted);line-height:1.25}

.btn-next{
  width:100%;padding:10px;border:none;border-radius:8px;
  background:var(--gold);color:var(--white);
  font-family:'DM Sans',sans-serif;font-size:0.875rem;font-weight:600;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;
  flex-shrink:0;
}
.btn-next:hover{background:var(--gold-h)}
.btn-next svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5}
.secure{
  display:flex;align-items:center;justify-content:center;gap:4px;
  font-size:0.67rem;color:var(--muted);margin-top:6px;flex-shrink:0;
}
.secure svg{width:11px;height:11px;stroke:var(--muted);fill:none;stroke-width:2}

/* other steps */
.sp{display:none;flex-direction:column;flex:1}
.sp.active{display:flex}
.field{margin-bottom:9px}
.field label{display:block;font-size:0.68rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.field input,.field select,.field textarea{
  width:100%;border:1.5px solid var(--border);border-radius:7px;
  padding:8px 10px;font-family:'DM Sans',sans-serif;font-size:0.82rem;
  color:var(--text);background:var(--white);outline:none;transition:border-color .2s;
  -webkit-appearance:none;appearance:none;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal)}
.field textarea{resize:none;height:58px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.btn-back{
  background:none;border:none;color:var(--muted);
  font-family:'DM Sans',sans-serif;font-size:0.75rem;
  cursor:pointer;text-align:center;padding:6px 0 0;flex-shrink:0;
}
.btn-back:hover{color:var(--teal)}
.btn-submit{
  width:100%;padding:11px;border:none;border-radius:8px;
  background:linear-gradient(135deg,var(--teal) 0%,#12A090 100%);
  color:var(--white);font-family:'DM Sans',sans-serif;
  font-size:0.875rem;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:6px;flex-shrink:0;
}
.btn-submit svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5}
.submit-error{
  color:#e53e3e;font-size:0.78rem;text-align:center;
  margin-top:6px;flex-shrink:0;display:none;
}
.success{display:none;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:10px}
.ck{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--teal),#12A090);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.ck svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2.8}
.success h3{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--text);margin-bottom:7px}
.success p{font-size:0.8rem;color:var(--muted);line-height:1.55}

/* ── TRUST STRIP ── */
.trust-strip{
  background:#EDF2EC;
  border-top:1px solid #D5E2D3;
  padding:20px 32px;
  flex-shrink:0;
  position:relative;
  z-index:1;
}
.ts-title{
  text-align:center;font-size:0.88rem;font-weight:600;color:var(--text);
  display:flex;align-items:center;gap:14px;justify-content:center;
  margin-bottom:16px;
}
.ts-title::before,.ts-title::after{content:'';flex:1;height:1px;background:#C8D9C6;max-width:100px}
.ts-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tc{display:flex;align-items:flex-start;gap:10px}
.tc svg{width:32px;height:32px;flex-shrink:0;stroke:var(--teal);fill:none;stroke-width:1.7}
.tc-txt h4{font-size:0.8rem;font-weight:600;color:var(--text);margin-bottom:2px}
.tc-txt p{font-size:0.72rem;color:var(--muted);line-height:1.4}

/* ═══════════════════════════════════════════
   MOBILE  ≤ 768px
   Desktop styles above are untouched.
═══════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── Page scrolls naturally ── */
  html, body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  /* ── NAV ── */
  nav {
    height: 60px;
    padding: 0 16px;
    position: sticky;
    top: 0;
    z-index: 200;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
  }
  .nav-links { display: none; }
  .logo-tag  { display: none; }
  .nav-phone-num { display: none; }
  .nav-right { gap: 10px; }
  .btn-gold  { padding: 8px 16px; font-size: 0.82rem; }

  /* ── MAIN ── */
  main { height: auto; }

  /* ── HERO — single column, form first ── */
  .hero {
    display: flex;
    flex-direction: column;
    padding: 0;
    min-height: auto;
    overflow: visible;
  }

  /* Form on top */
  .right {
    order: -1;
    margin: 0;
    border-radius: 0;
    padding: 16px 16px 24px;
    min-height: auto;
    box-shadow: none;
  }

  /* Card flows with content — no fixed height tricks */
  .form-card {
    flex: none;
    min-height: auto;
    margin-bottom: 0;
    transform: none;
    box-shadow: 0 6px 28px rgba(0,0,0,0.16);
    border-radius: 12px;
  }

  /* Body scrolls with the page, not internally */
  .fc-body {
    flex: none;
    overflow-y: visible;
    padding: 16px;
  }

  /* Service grid — natural height */
  .sg {
    flex: none;
    min-height: auto;
    overflow-y: visible;
    gap: 8px;
    margin-bottom: 14px;
  }

  .sp { flex: none; }

  /* ── LEFT content — below form ── */
  .left {
    order: 0;
    opacity: 1;
    padding: 28px 20px 20px;
  }

  h1 { font-size: 2.1rem; }
  .sub { max-width: 100%; }
  .trust-row { gap: 14px; }

  /* ── Hide image collage on mobile ── */
  .center { display: none; }

  /* ── TRUST STRIP ── */
  .trust-strip {
    position: static;
    padding: 24px 20px 20px;
    margin-top: 0;
  }
  .ts-cols {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .tc { align-items: flex-start; }
}

/* ── Small phones ≤ 480px ── */
@media (max-width: 480px) {
  h1 { font-size: 1.85rem; }

  .sc2 { padding: 8px; gap: 8px; }
  .si  { width: 22px; height: 22px; }

  .trust-row { gap: 10px; }
  .ti-circle { width: 42px; height: 42px; }
  .ti-lbl    { font-size: 0.62rem; max-width: 60px; }

  .ts-cols { grid-template-columns: 1fr; gap: 14px; }
  .tc svg  { width: 26px; height: 26px; }
}
