/* ============================================================
   Bonita Chiropractic Center — Homepage sections
   ============================================================ */

/* ---------- Hero: light coastal split with arched photo ---------- */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(900px 480px at 88% -10%, rgba(95,122,95,.14), transparent 65%),
    linear-gradient(180deg, var(--paper) 0%, #F7F2E8 100%);
  border-bottom:1px solid var(--sand);
}
.hero .container{
  display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(36px,5vw,72px);
  align-items:center;padding-block:clamp(56px,7vw,104px);
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--sage-line);
  color:var(--sage-deep);font-weight:700;font-size:13.5px;letter-spacing:.14em;text-transform:uppercase;
  padding:9px 18px;border-radius:999px;margin-bottom:26px;box-shadow:var(--shadow-1);
}
.hero-eyebrow svg{width:15px;height:15px}
.hero h1{max-width:15ch}
.hero h1 em{font-style:italic;color:var(--sage-deep)}
.hero .hero-lede{margin-top:22px;font-size:clamp(18px,2vw,20.5px);max-width:50ch}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-proof{display:flex;flex-wrap:wrap;gap:26px;margin-top:40px;padding-top:28px;border-top:1px solid var(--sand)}
.hero-proof li{display:flex;flex-direction:column;gap:2px}
.hero-proof b{font-family:var(--serif);font-size:26px;color:var(--navy);font-weight:600}
.hero-proof span{font-size:13.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}

.hero-visual{position:relative}
.hero-arch{
  border-radius:300px 300px var(--r-lg) var(--r-lg);overflow:hidden;
  border:1px solid var(--sand);box-shadow:var(--shadow-2);
}
.hero-arch img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.7}
.hero-chip{
  position:absolute;left:-26px;bottom:42px;background:#fff;border:1px solid var(--sand);
  border-radius:var(--r-md);box-shadow:var(--shadow-2);padding:16px 20px;
  display:flex;align-items:center;gap:13px;max-width:270px;
}
.hero-chip .hc-i{
  width:44px;height:44px;flex:none;border-radius:50%;background:var(--sage-soft);
  display:grid;place-items:center;color:var(--sage-deep);
}
.hero-chip .hc-i svg{width:22px;height:22px}
.hero-chip b{display:block;color:var(--navy);font-size:15.5px;line-height:1.3}
.hero-chip small{color:var(--ink-faint);font-size:13px}

/* ---------- Trust band (years strip) ---------- */
.trust-strip{background:var(--navy);color:var(--mist)}
.trust-strip .container{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;
  gap:18px;padding-block:20px;font-size:15.5px;
}
.trust-strip span{display:inline-flex;align-items:center;gap:10px}
.trust-strip svg{width:18px;height:18px;color:#A8C3A4}

/* ---------- Story / 35 years split ---------- */
.story-img{
  border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--sand);box-shadow:var(--shadow-2);
  position:relative;
}
.story-img img{width:100%;object-fit:cover;aspect-ratio:4/3.4}
.story-badge{
  position:absolute;right:22px;bottom:22px;background:var(--navy);color:#fff;
  border-radius:var(--r-md);padding:18px 22px;text-align:center;box-shadow:var(--shadow-2);
}
.story-badge b{display:block;font-family:var(--serif);font-size:34px;line-height:1;font-weight:600}
.story-badge small{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#A8C3A4;font-weight:700}
.story-points{margin-top:26px;display:grid;gap:14px}
.story-points li{display:flex;gap:14px;align-items:flex-start;font-size:16.5px;color:var(--ink-soft)}
.story-points svg{width:22px;height:22px;flex:none;color:var(--sage-deep);margin-top:2px}
.story-points b{color:var(--navy)}

/* ---------- Stats band ---------- */
.stats-band .container{
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px);text-align:center;
}
.stat b{font-family:var(--serif);font-size:clamp(40px,5vw,58px);color:#fff;font-weight:600;display:block;line-height:1.05;font-variant-numeric:tabular-nums}
.stat b sup{font-size:.55em;color:#A8C3A4}
.stat span{display:block;margin-top:8px;font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);font-weight:600}

/* ---------- Services (home) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc-feature{
  grid-row:span 2;display:flex;flex-direction:column;justify-content:flex-end;gap:14px;
  border-radius:var(--r-md);overflow:hidden;position:relative;min-height:480px;
  border:1px solid var(--sand);box-shadow:var(--shadow-1);color:#fff;padding:34px;
}
.svc-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.svc-feature::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(200deg,rgba(14,34,51,0) 30%,rgba(14,34,51,.86) 82%);
}
.svc-feature>*{position:relative;z-index:2}
.svc-feature h3{color:#fff;font-size:clamp(24px,2.6vw,30px)}
.svc-feature p{color:#D7E0E6;font-size:16px;max-width:46ch}
.svc-feature .card-link{color:#CFE0CC;font-weight:700;display:inline-flex;gap:8px;align-items:center}
.svc-feature .card-link svg{width:17px;height:17px}
.svc-feature:hover .card-link{color:#fff}

/* ---------- Doctor band ---------- */
.doc-wrap{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(34px,5vw,70px);align-items:center}
.doc-photo{
  border-radius:260px 260px var(--r-lg) var(--r-lg);overflow:hidden;
  border:1px solid rgba(255,255,255,.16);box-shadow:var(--shadow-2);
}
.doc-photo img{width:100%;object-fit:cover;aspect-ratio:3/3.7}
.doc-quote{
  font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,25px);line-height:1.45;
  color:#fff;border-left:3px solid var(--sage);padding-left:24px;margin:26px 0;
}
.doc-creds{display:grid;gap:12px;margin-top:24px}
.doc-creds li{display:flex;gap:13px;align-items:flex-start;color:var(--mist);font-size:16px}
.doc-creds svg{width:20px;height:20px;flex:none;color:#A8C3A4;margin-top:3px}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{
  background:#fff;border:1px solid var(--sand);border-radius:var(--r-md);padding:32px;
  counter-increment:step;position:relative;box-shadow:var(--shadow-1);
}
.step::before{
  content:"0" counter(step);font-family:var(--serif);font-size:52px;font-weight:600;
  color:var(--sage-soft);position:absolute;top:18px;right:24px;line-height:1;
  -webkit-text-stroke:1px var(--sage-line);
}
.step h3{font-size:21px;margin-bottom:10px;max-width:12ch}
.step p{font-size:15.5px}

/* ---------- Insurance strip ---------- */
.ins-band{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:22px;
  background:#fff;border:1.5px solid var(--sage-line);border-radius:var(--r-lg);
  padding:clamp(26px,4vw,42px);box-shadow:var(--shadow-1);
}
.ins-band h3{font-size:clamp(22px,2.6vw,28px);max-width:24ch}
.ins-band p{font-size:16px;margin-top:8px;max-width:52ch}

/* ---------- Contact band (home) ---------- */
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4vw,60px);align-items:start}
.contact-info{display:grid;gap:10px}
.ci-row{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--sand);border-radius:var(--r-md);padding:20px 22px}
.ci-row .ci-i{width:46px;height:46px;flex:none;border-radius:50%;background:var(--sage-soft);display:grid;place-items:center;color:var(--sage-deep)}
.ci-row .ci-i svg{width:21px;height:21px}
.ci-row b{display:block;color:var(--navy);font-size:16.5px}
.ci-row a{font-weight:600}
.ci-row p,.ci-row span{font-size:15.5px;color:var(--ink-soft);max-width:none}
.map-frame{border:1px solid var(--sand);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-1)}
.map-frame iframe{width:100%;height:340px;border:0;display:block}

/* ---------- Hours table ---------- */
.hours{width:100%;border-collapse:collapse;font-size:15.5px}
.hours td{padding:9px 2px;border-bottom:1px solid var(--sand);color:var(--ink-soft)}
.hours td:last-child{text-align:right;font-weight:600;color:var(--navy)}
.hours tr.today td{color:var(--sage-deep);font-weight:700}

/* ---------- Responsive ---------- */
@media (max-width:1060px){
  .steps{grid-template-columns:1fr 1fr}
  .stats-band .container{grid-template-columns:1fr 1fr;row-gap:34px}
}
@media (max-width:760px){
  .hero .container{grid-template-columns:1fr;padding-block:44px}
  .hero-visual{order:-1}
  .hero-arch{border-radius:160px 160px var(--r-md) var(--r-md)}
  .hero-arch img{aspect-ratio:4/3.6}
  .hero-chip{left:10px;bottom:-18px;padding:13px 16px}
  .hero-proof{gap:18px}
  .svc-grid{grid-template-columns:1fr}
  .svc-feature{min-height:380px}
  .doc-wrap{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .contact-split{grid-template-columns:1fr}
  .ins-band{flex-direction:column;align-items:flex-start}
}
