/* ============================================================
   Headon Dental · Family Dentistry at LIV — Homepage mockup
   Design system / stylesheet
   ============================================================ */

:root{
  /* Brand palette (from ColorPaletteforWebsite.png) */
  --forest:#2A3B27;      /* deep forest green — headers, anchors, primary CTA */
  --sage:#70805D;        /* sage green — accents, Headon secondary */
  --slate:#55738D;       /* steel blue — LIV primary, secondary CTA */
  --soft-slate:#96A7B6;  /* soft slate — LIV secondary */
  --warm-grey:#CBC8C4;   /* warm neutral grey */

  /* Derived warm neutrals */
  --cream:#F6F3EC;       /* warm off-white page background */
  --cream-deep:#EFEADF;  /* slightly deeper cream for alternating bands */
  --ink:#23291F;         /* warm near-black text */
  --ink-soft:#4C5347;    /* muted body text */
  --line:#E2DCD0;        /* hairline on cream */
  --white:#FFFDF9;       /* warm white cards */

  /* Location identity colours */
  --headon:#2A3B27;
  --headon-soft:#70805D;
  --liv:#55738D;
  --liv-soft:#96A7B6;

  /* Type */
  --display:"Newsreader", Georgia, "Times New Roman", serif;
  --body:"Mulish", system-ui, sans-serif;

  /* Shape */
  --radius:14px;
  --radius-lg:26px;
  --radius-pill:999px;
  --btn-radius:12px;

  /* Layout */
  --maxw:1240px;
  --gutter:clamp(20px,5vw,72px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--body);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:500;
  line-height:1.06;
  letter-spacing:-0.012em;
  margin:0;
  color:var(--forest);
  text-wrap:balance;
}
em,.it{font-style:italic;font-weight:500;}
p{margin:0;text-wrap:pretty;}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
.section{padding-block:clamp(64px,8vw,120px);}
.eyebrow{
  font-family:var(--body);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--sage);
  display:inline-flex;
  align-items:center;
  gap:.6em;
}
.eyebrow.center::before{display:none;}

/* section numeral label (editorial device) */
.signpost{
  display:flex;align-items:baseline;gap:14px;
  font-family:var(--body);font-weight:700;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage);
}
.signpost .num{
  font-family:var(--display);font-style:italic;font-weight:400;font-size:1.15rem;letter-spacing:0;color:var(--soft-slate);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--body);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  padding:.92em 1.6em;border-radius:var(--btn-radius);
  transition:transform .18s ease, background .2s ease, box-shadow .2s ease, color .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--primary-cta,var(--sage));color:#FFFFFF;box-shadow:0 1px 0 rgba(0,0,0,.04);}
.btn-primary:hover{filter:brightness(.92);box-shadow:0 10px 26px -12px rgba(42,59,39,.6);}
.btn-secondary{background:var(--slate);color:#F1F5F8;}
.btn-secondary:hover{background:#47627a;box-shadow:0 10px 26px -12px rgba(85,115,141,.7);}
.btn-ghost{background:transparent;color:var(--forest);box-shadow:inset 0 0 0 1.5px rgba(42,59,39,.28);}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--forest);background:rgba(42,59,39,.04);}
.btn-light{background:rgba(255,253,249,.94);color:var(--forest);}
.btn-light:hover{background:#fff;}
.btn-sm{padding:.62em 1.05em;font-size:.86rem;}
.btn .arr{transition:transform .2s;}
.btn:hover .arr{transform:translateX(3px);}

/* pill variant */
[data-shape="pill"] .btn{border-radius:var(--radius-pill);}

/* link with underline grow */
.tlink{
  display:inline-flex;align-items:center;gap:.5em;font-weight:700;color:var(--slate);
  font-size:.95rem;position:relative;
}
.tlink::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:100%;background:currentColor;transform:scaleX(.0);transform-origin:left;transition:transform .25s;}
.tlink:hover::after{transform:scaleX(1);}

/* ---------- announcement bar ---------- */
.announce{
  background:var(--forest);color:#EAEFE3;
  font-size:.86rem;font-weight:600;letter-spacing:.01em;
  text-align:center;padding:9px 16px;
  display:flex;align-items:center;justify-content:center;gap:.6em;
}
.announce .pip{width:7px;height:7px;border-radius:50%;background:var(--soft-slate);box-shadow:0 0 0 3px rgba(150,167,182,.28);}

/* ---------- header ---------- */
.header{position:sticky;top:0;z-index:60;background:rgba(246,243,236,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.header-in{display:flex;align-items:center;gap:28px;padding-block:14px;}
.brandlock{display:flex;align-items:center;gap:13px;flex-shrink:0;}
.brandlock .mark{width:40px;height:40px;flex-shrink:0;}
.brandlock .wordmark{font-family:var(--display);font-weight:600;font-size:clamp(.95rem,2.1vw,1.16rem);color:var(--forest);letter-spacing:-0.012em;line-height:1.04;display:flex;align-items:center;gap:.45em;white-space:nowrap;}
.brandlock .wordmark .wm-slash{color:var(--soft-slate);font-weight:400;}
.brandlock .wordmark .wm-liv{color:var(--forest);}
.nav{display:flex;align-items:center;gap:26px;margin-left:auto;}
.nav a{font-weight:600;font-size:.96rem;color:var(--ink-soft);transition:color .2s;position:relative;}
.nav a:hover{color:var(--forest);}
.nav a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--sage);transform:scaleX(0);transform-origin:center;transition:transform .22s;}
.nav a:hover::after{transform:scaleX(1);}
.header-cta{display:flex;align-items:center;gap:16px;}
.phones-mini{display:flex;flex-direction:column;gap:1px;text-align:right;}
.phones-mini a{font-size:.8rem;font-weight:700;color:var(--forest);display:flex;align-items:center;gap:.4em;justify-content:flex-end;}
.phones-mini .lbl{color:var(--soft-slate);font-weight:700;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;}
.menu-btn{display:none;}

/* ---------- HERO shared ---------- */
.hero{position:relative;overflow:hidden;}
.hero-eyebrow{color:var(--sage);}
.hero h1{
  font-size:clamp(2.3rem,4.4vw,3.95rem);
  line-height:1.07;
  letter-spacing:-0.018em;
  margin-top:.32em;
}
.hero h1 em{color:var(--slate);}
.hero-sub{display:block;font-family:var(--display);font-style:italic;font-weight:500;font-size:clamp(1.25rem,2vw,1.7rem);color:var(--sage);margin-top:.85em;line-height:1.25;}
.hero-support{font-size:1.08rem;color:var(--ink-soft);max-width:46ch;margin-top:1.2em;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.9em;}
.hero-phones{display:flex;gap:30px;margin-top:2.2em;flex-wrap:wrap;}
.hero-phone{display:flex;flex-direction:column;gap:3px;}
.hero-phone .tag{font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;}
.hero-phone .num{font-family:var(--display);font-size:1.32rem;font-weight:600;color:var(--forest);display:flex;align-items:center;gap:.4em;white-space:nowrap;}
.hero-phone.headon .tag{color:var(--headon-soft);}
.hero-phone.liv .tag{color:var(--liv);}

/* dot leader between phone columns */
.hero-phone-divider{width:1px;align-self:stretch;background:var(--line);}

/* Editorial split hero */
.hero-editorial .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,76px);align-items:center;padding-block:clamp(54px,7vw,96px);}
.hero-figure{position:relative;}
.hero-figure .main-img{width:100%;aspect-ratio:4/4.6;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 40px 80px -50px rgba(42,59,39,.6);}
.hero-figure image-slot{width:100%;height:100%;}
.hero-figure .sub-img{position:absolute;left:-42px;bottom:-30px;width:46%;aspect-ratio:1/1.04;border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 60px -34px rgba(0,0,0,.45);border:6px solid var(--cream);}
.hero-figure .badge{
  position:absolute;top:18px;right:10px;background:var(--white);border-radius:var(--radius);
  padding:14px 18px;box-shadow:0 24px 50px -28px rgba(0,0,0,.4);display:flex;align-items:center;gap:12px;
}
.hero-figure .badge .stars{color:#C7A24B;font-size:.95rem;letter-spacing:1px;}
.hero-figure .badge .b-num{font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--forest);line-height:1;}
.hero-figure .badge .b-cap{font-size:.7rem;color:var(--ink-soft);font-weight:600;}

/* Full-bleed hero */
.hero-fullbleed{min-height:min(86vh,760px);display:flex;align-items:flex-end;position:relative;color:#FBFAF5;}
.hero-fullbleed .bg{position:absolute;inset:0;}
.hero-fullbleed .bg image-slot{width:100%;height:100%;}
.hero-fullbleed .scrim{position:absolute;inset:0;background:linear-gradient(75deg,rgba(31,44,29,.86) 0%,rgba(31,44,29,.5) 42%,rgba(42,59,39,.08) 78%);}
.hero-fullbleed .wrap{position:relative;padding-block:clamp(48px,7vw,88px);width:100%;}
.hero-fullbleed h1{color:#FBFAF5;max-width:22ch;}
.hero-fullbleed .hero-eyebrow{color:#CBD8BE;}
.hero-fullbleed .hero-sub{color:#D9E3CC;}
.hero-fullbleed .hero-support{color:rgba(251,250,245,.9);}
.hero-fullbleed .fb-card{
  margin-top:2.2em;display:inline-flex;gap:0;background:rgba(246,243,236,.12);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.22);border-radius:var(--radius-lg);overflow:hidden;
}
.hero-fullbleed .fb-card .fbc{padding:18px 26px;}
.hero-fullbleed .fb-card .fbc + .fbc{border-left:1px solid rgba(255,255,255,.2);}
.hero-fullbleed .fb-card .tag{font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;}
.hero-fullbleed .fb-card.headon .tag{color:#C6D6AE;}
.hero-fullbleed .fb-card .liv .tag{color:#B7C9D6;}
.hero-fullbleed .fb-card .num{font-family:var(--display);font-size:1.3rem;font-weight:600;color:#fff;margin-top:3px;}

/* Diptych hero */
.hero-diptych{position:relative;isolation:isolate;}
.hero-diptych .dip-bg{position:absolute;inset:0;z-index:-1;overflow:hidden;}
.hero-diptych .dip-bg img{width:100%;height:100%;object-fit:cover;object-position:center 32%;}
.hero-diptych .dip-bg .dip-bg-wash{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(251,247,238,0) 58%,rgba(251,247,238,.72) 82%,var(--white) 100%);}
.hero-diptych .wrap{padding-top:clamp(18px,2.6vw,38px);padding-bottom:clamp(40px,5vw,64px);position:relative;z-index:1;}
.hero-diptych .dip-head{text-align:center;max-width:820px;margin:0 auto 40px;}
.hero-diptych .dip-head h1{max-width:24ch;margin-inline:auto;text-wrap:balance;}
.hero-diptych .dip-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.hero-diptych .dip{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1/1.04;}
.hero-diptych .dip image-slot{width:100%;height:100%;}
.hero-diptych .dip .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;}
.hero-diptych .dip.h .ov{background:linear-gradient(to top,rgba(31,44,29,.82),rgba(31,44,29,.05) 60%);}
.hero-diptych .dip.l .ov{background:linear-gradient(to top,rgba(40,57,73,.84),rgba(40,57,73,.05) 60%);}
.hero-diptych .dip .loc{font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.82);}
.hero-diptych .dip .name{font-family:var(--display);font-size:1.7rem;color:#fff;font-weight:600;margin-top:4px;}
.hero-diptych .dip .ph{color:rgba(255,255,255,.9);font-weight:700;margin-top:8px;font-size:.95rem;}
.hero-diptych .dip-cta{display:flex;justify-content:center;gap:14px;margin-top:38px;flex-wrap:wrap;}

/* ---------- wave seam divider (echoes logo wave) ---------- */
.seam{display:block;width:100%;height:auto;}

/* ---------- trust / dual-location bar ---------- */
.trust{background:var(--forest);color:#E9EEE2;}
.trust .wrap{display:flex;flex-wrap:wrap;align-items:center;gap:24px 40px;padding-block:26px;}
.trust .badge-new{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:.95rem;}
.trust .badge-new .dot{width:9px;height:9px;border-radius:50%;background:#A9C48A;box-shadow:0 0 0 4px rgba(169,196,138,.25);}
.trust .est{font-family:var(--display);font-style:italic;font-size:1.12rem;color:#CBD8BE;}
.trust .tr-locs{margin-left:auto;display:flex;gap:34px;flex-wrap:wrap;}
.trust .tr-loc{display:flex;flex-direction:column;gap:1px;}
.trust .tr-loc .l{font-size:.64rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--soft-slate);}
.trust .tr-loc a{font-weight:700;color:#fff;display:flex;align-items:center;gap:.4em;}
.trust .tr-loc.headon .l{color:#A9C48A;}

/* ---------- section heading block ---------- */
.head-block{max-width:60ch;}
.head-block.center{margin-inline:auto;text-align:center;}
.head-block h2{font-size:clamp(2rem,3.6vw,3.05rem);margin-top:.3em;}
.head-block .lede{font-size:1.1rem;color:var(--ink-soft);margin-top:1em;}

/* ---------- reviews ---------- */
.reviews{background:var(--cream-deep);position:relative;}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px;}
.rev-card{background:var(--white);border-radius:var(--radius-lg);padding:34px 30px 30px;display:flex;flex-direction:column;gap:18px;box-shadow:0 30px 60px -46px rgba(42,59,39,.5);position:relative;border:1px solid var(--line);}
.rev-card .quote-mark{font-family:var(--display);font-style:italic;font-size:3.4rem;line-height:.6;color:var(--soft-slate);height:28px;}
.rev-card .stars{color:#C7A24B;letter-spacing:2px;font-size:.95rem;}
.rev-card p{font-family:var(--display);font-size:1.12rem;line-height:1.45;color:var(--ink);}
.rev-card .who{margin-top:auto;display:flex;align-items:center;gap:12px;padding-top:6px;}
.rev-card .who .av{width:38px;height:38px;border-radius:50%;background:var(--sage);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-family:var(--body);font-size:.95rem;}
.rev-card .who .nm{font-weight:700;font-size:.95rem;color:var(--forest);}
.rev-card .who .src{font-size:.78rem;color:var(--ink-soft);}
.rev-foot{display:flex;justify-content:center;margin-top:34px;}
.rev-controls{display:none;}

/* ---------- team ---------- */
.team{background:var(--cream);}
.team-feature{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(34px,5vw,70px);align-items:center;}
.team-portrait{position:relative;}
.team-portrait .frame{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/4.7;box-shadow:0 40px 80px -50px rgba(42,59,39,.55);background:var(--warm-grey);}
.team-portrait image-slot{width:100%;height:100%;}
.team-portrait .tag{position:absolute;left:-22px;bottom:30px;background:var(--white);padding:14px 20px;border-radius:var(--radius);box-shadow:0 24px 50px -28px rgba(0,0,0,.4);}
.team-portrait .tag .nm{font-family:var(--display);font-weight:600;font-size:1.25rem;color:var(--forest);}
.team-portrait .tag .rl{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sage);}
.team-feature h2{font-size:clamp(2rem,3.6vw,3.05rem);margin-top:.32em;}
.team-feature .body{font-size:1.1rem;color:var(--ink-soft);margin-top:1.1em;}
.team-subs{margin-top:34px;display:grid;gap:24px;}
.team-sub{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;}
.team-sub .ic{width:46px;height:46px;border-radius:13px;background:rgba(112,128,93,.14);color:var(--sage);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.team-sub h3{font-family:var(--display);font-size:1.28rem;font-weight:600;color:var(--forest);}
.team-sub p{margin-top:5px;color:var(--ink-soft);font-size:1rem;}

/* associates row */
.assoc{margin-top:clamp(56px,7vw,92px);}
.assoc-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:30px;}
.assoc-head h3{font-size:clamp(1.5rem,2.4vw,2rem);}
.assoc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.doc{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:0 24px 50px -46px rgba(42,59,39,.5);transition:transform .25s ease, box-shadow .25s ease;}
.doc:hover{transform:translateY(-5px);box-shadow:0 36px 64px -42px rgba(42,59,39,.55);}
.doc .ph{aspect-ratio:1/1.08;overflow:hidden;background:var(--warm-grey);}
.doc .ph img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.doc .meta{padding:20px 22px 24px;}
.doc .nm{font-family:var(--display);font-size:1.32rem;font-weight:600;color:var(--forest);}
.doc .cred{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-top:3px;}
.doc .bio{font-size:.93rem;color:var(--ink-soft);margin-top:11px;line-height:1.5;}

/* ---------- team showcase (6 doctors) ---------- */
.team .head-block{max-width:64ch;}
.doc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
.docard{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:0 24px 50px -46px rgba(42,59,39,.5);transition:transform .25s ease, box-shadow .25s ease;display:flex;flex-direction:column;}
.docard:hover{transform:translateY(-5px);box-shadow:0 36px 64px -42px rgba(42,59,39,.55);}
.docard .ph{aspect-ratio:1/1.04;overflow:hidden;background:var(--warm-grey);position:relative;}
.docard .ph img{width:100%;height:100%;object-fit:cover;}
.ph-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(160deg,#7d8c69,#5f6e4c);color:#EAEFE2;}
.ph-ph .ini{font-family:var(--display);font-size:2.8rem;font-weight:600;line-height:1;}
.ph-ph .ph-note{font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.72);}
.docard .meta{padding:22px 24px 24px;display:flex;flex-direction:column;gap:4px;flex:1;}
.docard .meta .nm{font-family:var(--display);font-size:1.4rem;font-weight:600;color:var(--forest);}
.docard .meta .ttl{font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--slate);}
.docard .docbio-link{margin-top:14px;align-self:flex-start;display:inline-flex;align-items:center;gap:.5em;font-family:var(--body);font-weight:700;font-size:.92rem;color:var(--sage);}
.docard .docbio-link .arr{display:inline-flex;transition:transform .2s;}
.docard .docbio-link:hover .arr{transform:translateX(3px);}

/* carousel variant */
.doc-carousel{position:relative;margin-top:50px;}
.dc-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 18px;scrollbar-width:none;}
.dc-track::-webkit-scrollbar{display:none;}
.dc-track .docard{flex:0 0 calc((100% - 48px)/3);scroll-snap-align:start;}
.dc-arrow{position:absolute;top:36%;z-index:3;width:48px;height:48px;border-radius:50%;background:var(--white);box-shadow:0 14px 30px -14px rgba(42,59,39,.5);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--forest);transition:transform .2s,background .2s,color .2s;}
.dc-arrow:hover{background:var(--sage);color:#fff;transform:scale(1.06);}
.dc-arrow svg{width:20px;height:20px;}
.dc-arrow.prev{left:-20px;}
.dc-arrow.prev svg{transform:rotate(180deg);}
.dc-arrow.next{right:-20px;}

/* team sub-points strip */
.team-strip{margin-top:46px;display:grid;grid-template-columns:1fr 1fr;gap:28px;border-top:1px solid var(--line);padding-top:36px;}

/* doctor bio modal */
.docmodal{position:fixed;inset:0;z-index:200;background:rgba(31,44,29,.55);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;animation:dm-fade .2s ease;}
@keyframes dm-fade{from{opacity:0;}to{opacity:1;}}
.docmodal-card{background:var(--white);border-radius:var(--radius-lg);max-width:780px;width:100%;max-height:90vh;overflow:auto;display:grid;grid-template-columns:.82fr 1.18fr;position:relative;animation:dm-rise .25s ease;}
@keyframes dm-rise{from{transform:translateY(16px);opacity:.6;}to{transform:translateY(0);opacity:1;}}
.docmodal-ph{background:var(--warm-grey);min-height:360px;}
.docmodal-ph img{width:100%;height:100%;object-fit:cover;}
.docmodal-ph .ph-ph .ini{font-size:3.4rem;}
.docmodal-body{padding:38px 40px;display:flex;flex-direction:column;}
.docmodal-body .nm{font-family:var(--display);font-size:1.95rem;font-weight:600;color:var(--forest);}
.docmodal-body .ttl{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);margin-top:5px;}
.docmodal-body p{color:var(--ink-soft);font-size:1rem;line-height:1.62;margin-top:18px;}
.docmodal-cta{margin-top:auto;padding-top:26px;}
.docmodal-x{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);box-shadow:0 6px 16px -8px rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;font-size:1.05rem;color:var(--forest);z-index:4;}
.docmodal-x:hover{background:#fff;}

/* ---------- association logos ---------- */
.assoclogos{background:var(--cream-deep);}
.assoclogos .wrap{padding-block:26px;display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap;}
.assoclogos .lab{font-size:.66rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap;flex-shrink:0;}
.assoc-row{display:flex;align-items:center;gap:clamp(28px,4vw,52px);flex-wrap:wrap;justify-content:center;}
.assoc-logo{height:38px;width:auto;opacity:.78;transition:opacity .2s;}
.assoc-logo:hover{opacity:1;}

/* ---------- services ---------- */
.services{background:var(--cream);}
.serv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:50px;}
.serv{position:relative;background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;}
.serv-media{position:relative;aspect-ratio:16/9;background:var(--warm-grey);overflow:hidden;}
.serv-media::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--sage);z-index:2;}
.serv:nth-child(2) .serv-media::after{background:var(--slate);}
.serv:nth-child(3) .serv-media::after{background:var(--soft-slate);}
.serv:nth-child(4) .serv-media::after{background:var(--forest);}
.serv-media image-slot{width:100%;height:100%;display:block;}
.serv-body{padding:28px 32px 32px;display:flex;flex-direction:column;gap:14px;flex:1;}
.serv:hover{transform:translateY(-4px);box-shadow:0 34px 64px -44px rgba(42,59,39,.5);}
.serv h3{font-family:var(--display);font-size:1.55rem;font-weight:600;color:var(--forest);}
.serv p{color:var(--ink-soft);font-size:1rem;flex:1;}
.serv .tlink{margin-top:4px;}

/* ---------- locations ---------- */
.locations{background:var(--cream-deep);}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:48px;}
.loc-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 64px -50px rgba(42,59,39,.5);display:flex;flex-direction:column;}
.loc-card .top{padding:30px 32px 26px;color:#fff;position:relative;overflow:hidden;}
.loc-card.headon .top{background:var(--forest);}
.loc-card.liv .top{background:var(--slate);}
.loc-card .top .wavebg{position:absolute;right:-30px;top:-30px;width:200px;opacity:.16;}
.loc-card .loc-kicker{font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;opacity:.85;}
.loc-card .loc-name{font-family:var(--display);font-size:1.85rem;font-weight:600;margin-top:6px;position:relative;}
.loc-card .loc-since{font-family:var(--display);font-style:italic;font-size:.98rem;opacity:.85;margin-top:6px;}
.loc-card .body{padding:26px 32px 30px;display:flex;flex-direction:column;gap:18px;flex:1;}
.loc-card .blurb{color:var(--ink-soft);font-size:1rem;}
.loc-row{display:flex;gap:12px;align-items:flex-start;font-size:.97rem;}
.loc-row .ic{flex-shrink:0;margin-top:2px;color:var(--sage);}
.loc-card.liv .loc-row .ic{color:var(--slate);}
.loc-row .addr{color:var(--ink);font-weight:600;}
.loc-row .phone{font-family:var(--display);font-weight:600;font-size:1.2rem;color:var(--forest);white-space:nowrap;}
.loc-card.liv .loc-row .phone{color:var(--slate);}
.hours{border-top:1px solid var(--line);padding-top:16px;}
.hours .hr{display:flex;justify-content:space-between;font-size:.9rem;padding:3px 0;}
.hours .hr .d{color:var(--ink-soft);font-weight:600;}
.hours .hr .t{color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;}
.hours .hr.closed .t{color:var(--soft-slate);}
.hours .note{font-size:.78rem;color:var(--ink-soft);font-style:italic;margin-top:8px;}
.loc-card .note{font-size:.78rem;color:var(--ink-soft);font-style:italic;margin-top:8px;}
.loc-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px;}
.loc-intro{max-width:54ch;}

/* ---------- value props ---------- */
.values{background:var(--forest);color:#EAEFE2;}
.values h2{color:#fff;}
.values .head-block .lede,.values .eyebrow{color:#BFD0AE;}
.values .eyebrow{color:#A9C48A;}
.val-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;margin-top:50px;background:rgba(255,255,255,.12);border-radius:var(--radius-lg);overflow:hidden;}
.val{background:var(--forest);padding:40px 38px;display:flex;flex-direction:column;gap:14px;transition:background .25s;}
.val:hover{background:#243520;}
.val .vn{display:flex;align-items:center;gap:14px;}
.val .vn .ic{width:50px;height:50px;border-radius:14px;background:rgba(169,196,138,.16);color:#BFD79E;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.val h3{font-family:var(--display);font-size:1.5rem;font-weight:600;color:#fff;line-height:1.1;}
.val p{color:#C9D3BE;font-size:1rem;}
.val .tlink{color:#BFD79E;align-self:flex-start;margin-top:2px;}

/* ---------- insurance band ---------- */
.insurance{background:var(--sage);color:#fff;position:relative;overflow:hidden;}
.insurance .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;padding-block:clamp(54px,7vw,84px);position:relative;z-index:1;}
.insurance h2{color:#fff;font-size:clamp(1.9rem,3.2vw,2.7rem);}
.insurance p{color:rgba(255,255,255,.92);margin-top:.9em;font-size:1.08rem;max-width:50ch;}
.insurance .ins-cta{display:flex;flex-direction:column;gap:14px;align-items:flex-start;}
.insurance .ins-phones{display:flex;gap:24px;flex-wrap:wrap;}
.insurance .ins-phones .ph{color:#fff;}
.insurance .ins-phones .l{font-size:.64rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:.82;}
.insurance .ins-phones .n{font-family:var(--display);font-weight:600;font-size:1.18rem;display:flex;align-items:center;gap:.4em;}
.insurance .leaf{position:absolute;right:-60px;bottom:-80px;width:360px;opacity:.12;z-index:0;}

/* ---------- connect ---------- */
.connect{position:relative;min-height:560px;display:flex;align-items:center;color:#FBFAF5;overflow:hidden;}
@media(min-width:1000px){.connect{min-height:740px;}}
.connect .bg{position:absolute;inset:0;}
.connect .bg image-slot{width:100%;height:100%;}
.connect .scrim{position:absolute;inset:0;background:radial-gradient(ellipse 90% 80% at 50% 42%,rgba(31,44,29,.58),rgba(31,44,29,.82) 100%);}
.connect .wrap{position:relative;z-index:1;padding-block:clamp(64px,8vw,110px);display:flex;flex-direction:column;align-items:center;text-align:center;}
.connect h2{color:#fff;font-size:clamp(2.1rem,4vw,3.4rem);max-width:18ch;text-shadow:0 2px 24px rgba(20,28,18,.4);}
.connect .eyebrow{color:#BFD79E;}
.connect p{color:rgba(251,250,245,.95);font-size:1.12rem;max-width:54ch;margin-top:1.1em;text-shadow:0 1px 16px rgba(20,28,18,.4);}
.connect .c-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:2em;justify-content:center;}

/* ---------- footer ---------- */
.footer{background:#1d2719;color:#C3CDB7;font-size:.93rem;}
.footer .wrap{padding-block:64px 30px;}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;}
.foot-brand .logos{display:flex;flex-wrap:wrap;gap:14px;align-items:stretch;}
.foot-logo{background:var(--white);border-radius:14px;padding:14px 20px;display:flex;align-items:center;justify-content:center;min-width:150px;}
.foot-logo img{height:60px;width:auto;}
.foot-logo-liv{background:transparent;border:1.5px dashed rgba(255,255,255,.26);padding:14px 24px;}
.foot-logo-headon{background:#fff;padding:16px 22px;}
.foot-logo-headon img{height:64px;width:auto;display:block;}
.foot-logo-livimg img{height:52px;}
.foot-logo .liv-ph{display:flex;flex-direction:column;gap:3px;text-align:center;}
.foot-logo .liv-ph .lab{font-family:var(--display);font-size:1.18rem;color:#C3CDB7;font-weight:600;}
.foot-logo .liv-ph .sub{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:#8FA67C;font-weight:700;}
.foot-brand .tag{font-family:var(--display);font-style:italic;color:#9FB58A;margin-top:22px;font-size:1.05rem;}
.foot-col h4{font-family:var(--body);font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#8FA67C;margin-bottom:16px;}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;}
.foot-col a{color:#C3CDB7;transition:color .2s;}
.foot-col a:hover{color:#fff;}
.foot-loc{margin-bottom:18px;}
.foot-loc .l{font-size:.64rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8FA67C;}
.foot-loc .nm{font-weight:700;color:#fff;margin-top:3px;}
.foot-loc .ad{color:#A9B59C;margin-top:2px;line-height:1.4;}
.foot-loc .ph{color:#fff;font-weight:700;margin-top:3px;display:inline-block;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:48px;padding-top:24px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.foot-bottom .legal{font-size:.82rem;color:#869579;}
.foot-bottom .legal a{color:#A9B59C;}
.foot-bottom .legal a:hover{color:#fff;}
.foot-social{display:flex;gap:12px;}
.foot-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#C3CDB7;transition:background .2s,color .2s;}
.foot-social a:hover{background:var(--sage);color:#fff;}

.rebrand-note{font-size:.74rem;color:#6f7d63;margin-top:14px;font-style:italic;}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav{display:none;}
  .phones-mini{display:none;}
  .menu-btn{display:inline-flex;}
  .hero-editorial .wrap{grid-template-columns:1fr;}
  .hero-figure{order:-1;max-width:520px;}
  .team-feature{grid-template-columns:1fr;}
  .assoc-grid{grid-template-columns:repeat(2,1fr);}
  .doc-grid{grid-template-columns:repeat(2,1fr);}
  .dc-track .docard{flex-basis:calc((100% - 24px)/2);}
  .dc-arrow.prev{left:4px;}
  .dc-arrow.next{right:4px;}
  .docmodal-card{grid-template-columns:1fr;}
  .docmodal-ph{min-height:230px;}
  .team-strip{grid-template-columns:1fr;gap:20px;}
  .insurance .wrap{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:760px){
  body{font-size:17px;}
  .rev-grid{grid-template-columns:1fr;}
  .serv-grid{grid-template-columns:1fr;}
  .loc-grid{grid-template-columns:1fr;}
  .val-grid{grid-template-columns:1fr;}
  .hero-diptych .dip-grid{grid-template-columns:1fr;}
  .assoc-grid{grid-template-columns:1fr 1fr;}
  .doc-grid{grid-template-columns:1fr 1fr;}
  .dc-track .docard{flex-basis:82%;}
  .trust .tr-locs{margin-left:0;width:100%;}
  .foot-top{grid-template-columns:1fr;}
}
@media(max-width:460px){
  .assoc-grid{grid-template-columns:1fr;}
  .doc-grid{grid-template-columns:1fr;}
}
