/* =========================================================
   Acorn Hill Family Dentistry — site stylesheet
   Brand Foundation v1. Warm neutrals + sage + terracotta.
   ========================================================= */

:root{
  /* Palette */
  --linen:    #FAF5EC;
  --oat:      #EFE6D5;
  --oat-deep: #E4D7C0;
  --cream:    #FFFDF9;
  --bark:     #8A6F52;
  --acorn:    #433426;
  --hearth:   #2B231C;
  --sage:     #788C6A;
  --sage-deep:#4F6043;
  --terra:    #BC6A45;
  --terra-deep:#9C4F2F;

  /* Tints used for soft fills */
  --sage-tint:  rgba(120,140,106,.12);
  --terra-tint: rgba(188,106,69,.10);

  --serif: 'Lora', Georgia, 'Times New Roman', serif;
  --sans:  'Source Sans 3', system-ui, -apple-system, sans-serif;

  --maxw: 1180px;
  --nav-h: 76px;

  --shadow-sm: 0 1px 2px rgba(67,52,38,.05), 0 2px 6px rgba(67,52,38,.05);
  --shadow-md: 0 4px 14px rgba(67,52,38,.08), 0 10px 30px rgba(67,52,38,.07);
  --shadow-lg: 0 10px 40px rgba(67,52,38,.14);

  --radius: 16px;
  --radius-sm: 10px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--linen);
  color:var(--hearth);
  font-family:var(--sans);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3,h4,h5{ font-family:var(--serif); color:var(--acorn); font-weight:600; line-height:1.12; margin:0; }
p{ margin:0 0 1em; }
a{ color:var(--terra-deep); }
img{ max-width:100%; display:block; }
:focus-visible{ outline:3px solid var(--sage-deep); outline-offset:2px; border-radius:4px; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.narrow{ max-width:780px; margin-left:auto; margin-right:auto; }
.eyebrow{ font-family:var(--sans); font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--sage-deep); margin:0 0 14px; }
.lead{ font-size:21px; line-height:1.55; color:var(--bark); }
.serif-italic{ font-family:var(--serif); font-style:italic; }
.center{ text-align:center; }

section{ position:relative; }
.sec{ padding:84px 0; }
.sec-sm{ padding:56px 0; }
.sec.oat{ background:var(--oat); }
.sec.cream{ background:var(--cream); }
.sec.acorn{ background:var(--acorn); color:var(--linen); }
.sec.acorn h1,.sec.acorn h2,.sec.acorn h3{ color:var(--linen); }
.sec.acorn .eyebrow{ color:#A9BE95; }
.sec.acorn .lead{ color:rgba(250,245,236,.8); }
.sec.sage{ background:var(--sage); color:var(--linen); }
.sec.sage h2,.sec.sage h3{ color:#fff; }
.sec.sage .eyebrow{ color:#EAF0E2; }

/* paper wash */
.paper::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:
    radial-gradient(circle at 12% 18%, rgba(138,111,82,.05), transparent 55%),
    radial-gradient(circle at 88% 82%, rgba(120,140,106,.05), transparent 55%);
}
.paper > .wrap{ position:relative; z-index:1; }

/* Headings scale */
.h-display{ font-size:clamp(40px, 6vw, 66px); line-height:1.03; letter-spacing:-.5px; }
.h1{ font-size:clamp(34px, 4.6vw, 50px); line-height:1.06; }
.h2{ font-size:clamp(28px, 3.4vw, 38px); }
.h3{ font-size:clamp(21px, 2.2vw, 26px); }
em.warm{ font-style:italic; color:var(--terra-deep); font-weight:500; }
.sec.acorn em.warm{ color:#E0936E; }

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--sans); font-weight:600; font-size:16px; letter-spacing:.01em;
  padding:14px 26px; border-radius:11px; border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; transition:transform .12s, background .18s, box-shadow .18s, color .18s;
  line-height:1.1;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--terra-deep); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:#874327; }
.btn-sage{ background:var(--sage-deep); color:#fff; }
.btn-sage:hover{ background:#445437; }
.btn-ghost{ background:transparent; color:var(--acorn); border-color:var(--oat-deep); }
.btn-ghost:hover{ background:var(--oat); border-color:var(--bark); }
.sec.acorn .btn-ghost{ color:var(--linen); border-color:rgba(250,245,236,.35); }
.sec.acorn .btn-ghost:hover{ background:rgba(250,245,236,.1); }
.btn-lg{ font-size:18px; padding:17px 32px; }
.btn-sm{ font-size:14px; padding:10px 18px; border-radius:9px; }
.btn svg{ width:18px; height:18px; }

/* ---------------- Top navigation ---------------- */
.nav{
  position:sticky; top:0; z-index:200;
  background:rgba(250,245,236,.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--oat-deep);
}
.nav-inner{ max-width:var(--maxw); margin:0 auto; padding:0 28px; height:var(--nav-h); display:flex; align-items:center; gap:30px; }
.brand{ display:flex; align-items:center; gap:11px; text-decoration:none; flex:none; }
.brand svg{ width:36px; height:36px; }
.brand .bt{ font-family:var(--serif); font-weight:600; font-size:20px; color:var(--acorn); line-height:1; letter-spacing:.2px; }
.brand .bt small{ display:block; font-family:var(--sans); font-size:10.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--bark); margin-top:3px; }
.nav-links{ display:flex; align-items:center; gap:1px; margin-left:10px; }
.nav-links a{ font-size:14.5px; font-weight:500; color:var(--hearth); text-decoration:none; padding:9px 10px; border-radius:8px; transition:background .15s,color .15s; white-space:nowrap; }
.nav-links a:hover{ background:var(--oat); color:var(--acorn); }
.nav-links a.active{ color:var(--acorn); font-weight:600; }

/* "More" dropdown */
.nav-more{ position:relative; }
.nav-more-btn{ display:inline-flex; align-items:center; gap:5px; font-family:var(--sans); font-size:15px; font-weight:500; color:var(--hearth); background:none; border:none; cursor:pointer; padding:9px 12px; border-radius:8px; transition:background .15s,color .15s; }
.nav-more-btn:hover,.nav-more-btn.active{ background:var(--oat); color:var(--acorn); }
.nav-more-btn.active{ font-weight:600; }
.nav-more-btn svg{ width:15px; height:15px; transition:transform .2s; }
.nav-more.open .nav-more-btn svg{ transform:rotate(180deg); }
.nav-more-menu{ position:absolute; top:calc(100% + 8px); right:0; min-width:206px; background:var(--cream); border:1px solid var(--oat-deep); border-radius:12px; box-shadow:var(--shadow-md); padding:7px; opacity:0; visibility:hidden; transform:translateY(-6px); transition:opacity .16s, transform .16s, visibility .16s; z-index:210; }
.nav-more.open .nav-more-menu{ opacity:1; visibility:visible; transform:translateY(0); }
.nav-more-menu a{ display:block; font-size:15px; font-weight:500; color:var(--hearth); text-decoration:none; padding:10px 13px; border-radius:8px; white-space:nowrap; }
.nav-more-menu a:hover{ background:var(--oat); color:var(--acorn); }
.nav-more-menu a.active{ color:var(--terra-deep); font-weight:600; }
.nav-cta{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.nav-phone{ display:flex; align-items:center; gap:7px; font-weight:600; font-size:15px; color:var(--acorn); text-decoration:none; }
.nav-phone:hover{ color:var(--terra-deep); }
.nav-toggle{ display:none; margin-left:auto; background:none; border:1.5px solid var(--oat-deep); border-radius:9px; padding:9px 11px; cursor:pointer; }
.nav-toggle svg{ width:22px; height:22px; color:var(--acorn); }

/* mobile drawer */
.nav-drawer{ display:none; position:fixed; inset:var(--nav-h) 0 0; z-index:190; background:var(--linen); padding:20px 28px 120px; overflow-y:auto; }
.nav-drawer.open{ display:block; }
.nav-drawer a{ display:block; font-size:19px; font-weight:500; color:var(--acorn); text-decoration:none; padding:15px 4px; border-bottom:1px solid var(--oat-deep); font-family:var(--serif); }
.nav-drawer .btn{ width:100%; margin-top:22px; }

/* ---------------- Trust strip ---------------- */
.trust{ background:var(--acorn); color:var(--linen); }
.trust-inner{ max-width:var(--maxw); margin:0 auto; padding:11px 28px; display:flex; align-items:center; justify-content:center; gap:30px; flex-wrap:wrap; font-size:14px; }
.trust .ti{ display:flex; align-items:center; gap:9px; color:rgba(250,245,236,.92); }
.trust .ti svg{ width:17px; height:17px; color:#A9BE95; flex:none; }
.trust .ti strong{ color:#fff; font-weight:600; }
.trust .stars{ color:#E0A24E; letter-spacing:1px; }
.trust .dot{ width:4px; height:4px; border-radius:50%; background:rgba(250,245,236,.35); }

/* ---------------- Cards ---------------- */
.card{ background:var(--cream); border:1px solid var(--oat-deep); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow-sm); }
.card.on-oat{ background:var(--cream); }
.grid{ display:grid; gap:20px; }
.g2{ grid-template-columns:repeat(2,1fr); }
.g3{ grid-template-columns:repeat(3,1fr); }
.g4{ grid-template-columns:repeat(4,1fr); }

.icon-badge{ width:52px; height:52px; border-radius:13px; display:flex; align-items:center; justify-content:center; background:var(--sage-tint); color:var(--sage-deep); margin-bottom:16px; }
.icon-badge svg{ width:26px; height:26px; }
.icon-badge.terra{ background:var(--terra-tint); color:var(--terra-deep); }

/* service card */
.svc{ display:block; text-decoration:none; color:inherit; background:var(--cream); border:1px solid var(--oat-deep); border-radius:var(--radius); padding:26px; transition:transform .15s, box-shadow .18s, border-color .18s; }
.svc:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--sage); }
.svc h3{ font-size:21px; margin-bottom:7px; }
.svc p{ font-size:15px; color:var(--bark); margin:0; }
.svc .more{ display:inline-flex; align-items:center; gap:6px; margin-top:14px; font-weight:600; font-size:14px; color:var(--sage-deep); }

/* ---------------- Pills / chips ---------------- */
.chip{ display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:600; color:var(--sage-deep); background:var(--cream); border:1px solid var(--oat-deep); border-radius:999px; padding:7px 15px; }
.chip svg{ width:15px; height:15px; }

/* ---------------- Forms ---------------- */
label{ display:block; font-size:14px; font-weight:600; color:var(--acorn); margin-bottom:7px; }
.field{ margin-bottom:18px; }
input[type=text],input[type=email],input[type=tel],input[type=date],select,textarea{
  width:100%; font-family:var(--sans); font-size:16px; color:var(--hearth);
  background:var(--cream); border:1.5px solid var(--oat-deep); border-radius:10px; padding:13px 15px;
  transition:border-color .15s, box-shadow .15s;
}
input:focus,select:focus,textarea:focus{ outline:none; border-color:var(--sage); box-shadow:0 0 0 3px var(--sage-tint); }
select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238A6F52' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; padding-right:40px; }

/* toggle switch */
.switch{ display:inline-flex; align-items:center; gap:12px; cursor:pointer; user-select:none; }
.switch input{ position:absolute; opacity:0; width:0; height:0; }
.switch .track{ width:48px; height:28px; border-radius:999px; background:var(--oat-deep); position:relative; transition:background .18s; flex:none; }
.switch .track::after{ content:""; position:absolute; top:3px; left:3px; width:22px; height:22px; border-radius:50%; background:#fff; box-shadow:var(--shadow-sm); transition:transform .18s; }
.switch input:checked + .track{ background:var(--sage-deep); }
.switch input:checked + .track::after{ transform:translateX(20px); }
.switch .lbl{ font-weight:600; font-size:15px; color:var(--acorn); }

/* ---------------- Accordion ---------------- */
.acc{ border-top:1px solid var(--oat-deep); }
.acc-item{ border-bottom:1px solid var(--oat-deep); }
.acc-q{ width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:22px 4px; display:flex; align-items:center; justify-content:space-between; gap:20px; font-family:var(--serif); font-size:19px; font-weight:600; color:var(--acorn); }
.acc-q .pm{ flex:none; width:26px; height:26px; border-radius:50%; border:1.5px solid var(--bark); position:relative; transition:transform .2s, background .2s, border-color .2s; }
.acc-q .pm::before,.acc-q .pm::after{ content:""; position:absolute; background:var(--bark); border-radius:2px; top:50%; left:50%; transform:translate(-50%,-50%); }
.acc-q .pm::before{ width:11px; height:2px; }
.acc-q .pm::after{ width:2px; height:11px; transition:transform .2s; }
.acc-item.open .pm{ background:var(--sage-deep); border-color:var(--sage-deep); }
.acc-item.open .pm::before,.acc-item.open .pm::after{ background:#fff; }
.acc-item.open .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.acc-a{ max-height:0; overflow:hidden; transition:max-height .28s ease; }
.acc-a .inner{ padding:0 4px 24px; color:var(--hearth); font-size:16.5px; max-width:64ch; }

/* ---------------- Booking modal ---------------- */
.modal-back{ position:fixed; inset:0; z-index:500; background:rgba(43,35,28,.55); backdrop-filter:blur(3px); display:none; align-items:center; justify-content:center; padding:24px; }
.modal-back.open{ display:flex; }
.modal{ background:var(--linen); border-radius:20px; width:100%; max-width:560px; max-height:92vh; overflow-y:auto; box-shadow:var(--shadow-lg); position:relative; }
.modal-head{ padding:28px 32px 18px; border-bottom:1px solid var(--oat-deep); position:sticky; top:0; background:var(--linen); border-radius:20px 20px 0 0; }
.modal-head .eyebrow{ margin-bottom:8px; }
.modal-head h3{ font-size:26px; }
.modal-body{ padding:24px 32px 32px; }
.modal-close{ position:absolute; top:20px; right:20px; width:38px; height:38px; border-radius:50%; border:none; background:var(--oat); cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--acorn); }
.modal-close:hover{ background:var(--oat-deep); }
.modal-close svg{ width:20px; height:20px; }
.sms-note{ display:flex; gap:10px; align-items:flex-start; background:var(--sage-tint); border-radius:11px; padding:13px 15px; font-size:14px; color:var(--sage-deep); margin-top:6px; }
.sms-note svg{ width:18px; height:18px; flex:none; margin-top:1px; }
.book-success{ text-align:center; padding:20px 6px; }
.book-success .ok{ width:64px; height:64px; border-radius:50%; background:var(--sage-tint); color:var(--sage-deep); display:flex; align-items:center; justify-content:center; margin:0 auto 18px; }
.book-success .ok svg{ width:34px; height:34px; }

/* ---------------- Footer ---------------- */
.footer{ background:var(--acorn); color:rgba(250,245,236,.78); padding:64px 0 30px; font-size:15px; }
.footer a{ color:rgba(250,245,236,.78); text-decoration:none; }
.footer a:hover{ color:#fff; }
.footer h4{ color:var(--linen); font-family:var(--sans); font-size:13px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; margin-bottom:16px; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:40px; padding-bottom:44px; border-bottom:1px solid rgba(250,245,236,.16); }
.footer .brand .bt{ color:var(--linen); }
.footer .brand .bt small{ color:rgba(250,245,236,.6); }
.footer ul{ list-style:none; margin:0; padding:0; }
.footer ul li{ margin-bottom:11px; }
.footer .badges{ display:flex; gap:12px; flex-wrap:wrap; margin-top:6px; }
.footer .badge{ border:1px solid rgba(250,245,236,.25); border-radius:9px; padding:9px 12px; font-size:11px; line-height:1.3; color:rgba(250,245,236,.72); font-weight:600; letter-spacing:.04em; }
.footer-bottom{ padding-top:26px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13px; color:rgba(250,245,236,.55); }
.footer-bottom .socials{ display:flex; gap:14px; }
.footer-bottom .socials a{ display:flex; }
.footer-bottom .socials svg{ width:19px; height:19px; }
.footer.footer-min{ padding:30px 0; }

/* ---------------- Mobile sticky bottom bar ---------------- */
.mbar{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:180; background:var(--cream); border-top:1px solid var(--oat-deep); padding:9px 14px calc(9px + env(safe-area-inset-bottom)); gap:10px; box-shadow:0 -4px 20px rgba(67,52,38,.1); }
.mbar a{ flex:1; }
.mbar .btn{ width:100%; padding:14px; }
.mbar .btn-call{ background:var(--sage-deep); color:#fff; }

/* ---------------- Hero ---------------- */
.hero{ padding:72px 0 80px; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center; }
.hero h1{ font-size:clamp(38px, 5.4vw, 62px); line-height:1.02; letter-spacing:-.5px; }
.hero .sub{ font-size:20px; color:var(--bark); margin-top:22px; max-width:50ch; }
.hero .hero-cta{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
.hero .micro{ margin-top:20px; font-size:14px; color:var(--bark); display:flex; align-items:center; gap:8px; }
.hero .micro svg{ width:16px; height:16px; color:var(--sage-deep); }
.hero-art{ position:relative; }
.hero-art image-slot{ border-radius:20px; box-shadow:var(--shadow-md); }
.hero-badge{ position:absolute; bottom:-22px; left:-22px; background:var(--cream); border:1px solid var(--oat-deep); border-radius:15px; padding:16px 20px; box-shadow:var(--shadow-md); display:flex; align-items:center; gap:13px; }
.hero-badge .num{ font-family:var(--serif); font-size:34px; font-weight:700; color:var(--terra-deep); line-height:1; }
.hero-badge .cap{ font-size:13px; color:var(--bark); line-height:1.3; font-weight:600; }

/* page header band */
.page-head{ padding:64px 0 56px; }
.page-head .eyebrow{ margin-bottom:16px; }
.page-head h1{ font-size:clamp(36px,4.8vw,54px); line-height:1.04; }
.page-head p{ font-size:20px; color:var(--bark); max-width:60ch; margin-top:18px; }

/* misc */
.divider{ height:1px; background:var(--oat-deep); border:none; margin:0; }
.stat{ font-family:var(--serif); font-size:44px; font-weight:700; color:var(--terra-deep); line-height:1; }
.stat-cap{ font-size:14px; color:var(--bark); margin-top:8px; }
ul.checks{ list-style:none; padding:0; margin:0; }
ul.checks li{ display:flex; gap:12px; align-items:flex-start; margin-bottom:14px; font-size:16.5px; }
ul.checks li svg{ width:22px; height:22px; flex:none; color:var(--sage-deep); margin-top:2px; }

.pull{ font-family:var(--serif); font-style:italic; font-size:clamp(24px,3vw,33px); line-height:1.4; color:var(--acorn); }
.byline{ font-size:15px; font-weight:600; color:var(--bark); font-style:normal; font-family:var(--sans); margin-top:18px; }

/* ---------------- Reusable cost calculator widget ---------------- */
.ac-calc{ display:grid; grid-template-columns:1.2fr .8fr; gap:28px; align-items:start; }
.ac-calc-controls{ background:var(--cream); border:1px solid var(--oat-deep); border-radius:18px; padding:30px; }
.ac-qty{ display:flex; align-items:center; border:1.5px solid var(--oat-deep); border-radius:10px; width:fit-content; overflow:hidden; }
.ac-qty button{ width:46px; height:46px; border:none; background:var(--oat); font-size:22px; color:var(--acorn); cursor:pointer; }
.ac-qty button:hover{ background:var(--oat-deep); }
.ac-qty span{ width:54px; text-align:center; font-weight:600; font-size:18px; }
.ac-fine{ font-size:14px; color:var(--bark); margin:6px 0 0; }
.ac-calc-out{ background:var(--acorn); color:var(--linen); border-radius:18px; padding:30px 32px; position:sticky; top:96px; }
.ac-calc-out .eyebrow{ color:#A9BE95; }
.ac-est{ font-family:var(--serif); font-size:46px; font-weight:700; line-height:1; color:#fff; }
.ac-estsub{ font-size:14px; color:rgba(250,245,236,.7); margin-top:6px; }
.ac-lines{ margin-top:22px; }
.ac-line{ display:flex; justify-content:space-between; gap:16px; padding:12px 0; border-bottom:1px solid rgba(250,245,236,.16); font-size:15px; }
.ac-line:last-child{ border-bottom:none; }
.ac-line span:last-child{ color:#fff; font-weight:600; text-align:right; }
.ac-nosurprise{ display:flex; gap:11px; align-items:flex-start; background:var(--sage-tint); border:1px solid var(--sage); border-radius:13px; padding:16px 18px; margin-top:22px; }
.ac-nosurprise svg{ width:22px; height:22px; color:#A9BE95; flex:none; margin-top:1px; }
.ac-nosurprise strong{ color:#fff; }
.ac-nosurprise span{ font-size:14.5px; color:rgba(250,245,236,.9); }
@media(max-width:760px){ .ac-calc{ grid-template-columns:1fr; } .ac-calc-out{ position:static; } }

/* integration placeholder note — marks where a HIPAA-compliant vendor wires in */
.integration-note{ display:flex; gap:10px; align-items:flex-start; background:var(--terra-tint); border:1.5px dashed var(--terra); border-radius:11px; padding:12px 15px; font-size:13.5px; line-height:1.4; color:var(--terra-deep); font-weight:600; margin-bottom:18px; }
.integration-note svg{ width:18px; height:18px; flex:none; margin-top:1px; }
.integration-note .badge{ font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; background:var(--terra-deep); color:#fff; padding:2px 7px; border-radius:5px; margin-right:2px; }

/* ---------------- Reusable treatment finder widget ---------------- */
.panel{ background:var(--cream); border:1px solid var(--oat-deep); border-radius:20px; padding:36px; box-shadow:var(--shadow-md); }
.quiz{ min-height:340px; }
.q-opts{ display:grid; gap:12px; margin-top:24px; }
.q-opt{ display:flex; align-items:center; gap:16px; width:100%; text-align:left; background:var(--linen); border:1.5px solid var(--oat-deep); border-radius:14px; padding:18px 22px; cursor:pointer; font-family:var(--sans); font-size:17px; font-weight:600; color:var(--acorn); transition:border-color .15s, background .15s, transform .1s; }
.q-opt:hover{ border-color:var(--sage); background:var(--cream); transform:translateX(3px); }
.q-opt .qic{ width:44px; height:44px; border-radius:11px; background:var(--sage-tint); color:var(--sage-deep); display:flex; align-items:center; justify-content:center; flex:none; }
.q-opt .qic svg{ width:24px; height:24px; }
.q-progress{ display:flex; gap:6px; margin-bottom:24px; }
.q-progress .b{ height:5px; flex:1; border-radius:3px; background:var(--oat-deep); transition:background .2s; }
.q-progress .b.on{ background:var(--sage); }
.result-ic{ width:72px; height:72px; border-radius:18px; background:var(--terra-tint); color:var(--terra-deep); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.result-ic svg{ width:38px; height:38px; }

/* ---------------- Reusable insurance verify widget ---------------- */
.verify-card{ background:var(--cream); border:1px solid var(--oat-deep); border-radius:20px; padding:34px; box-shadow:var(--shadow-md); }
.verify-result{ display:none; margin-top:22px; border-radius:14px; padding:20px 22px; }
.verify-result.ok{ background:var(--sage-tint); border:1px solid var(--sage); }
.verify-result.maybe{ background:var(--terra-tint); border:1px solid var(--terra); }
.verify-result h4{ font-size:19px; display:flex; align-items:center; gap:10px; }
.verify-result h4 svg{ width:22px; height:22px; flex:none; }

/* ---------------- Responsive ---------------- */
@media (max-width:1060px){
  .nav-links,.nav-more{ display:none; }
  .nav-toggle{ display:block; }
  .nav-cta .nav-phone span{ display:none; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .g4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px){
  body{ font-size:17px; }
  .sec{ padding:56px 0; }
  .hero{ padding:40px 0 56px; }
  .hero-grid{ grid-template-columns:1fr; gap:36px; }
  .hero-art{ order:-1; }
  .hero-badge{ left:auto; right:14px; bottom:-18px; }
  .g2,.g3{ grid-template-columns:1fr; }
  .mbar{ display:flex; }
  body{ padding-bottom:74px; }
  .footer-grid{ grid-template-columns:1fr; }
  .nav-cta .btn span.full{ display:none; }
}

/* ---------------- Demo presentation overrides ---------------- */
/* Hide internal "Dev / integration here" scaffolding notes for the client demo.
   Remove this block to reveal the integration markers again. */
.integration-note{ display:none !important; }
