/* -------------------------------------------------------------
   UNO DENTAL — shared site stylesheet
   Color palette:
     --ink        #161A1F   primary text
     --paper      #FAF6EE   warm cream background
     --shell      #F2EADC   secondary surface
     --steel      #384C5D   deep dental teal-grey (brand accent)
     --ember      #E86A33   primary CTA orange
   Typography:
     Display: Unbounded · Body: Albert Sans · Eyebrow: Josefin Sans
------------------------------------------------------------- */
:root{
  /* Patientli-inspired palette: soft mint background, deep forest teal,
     warm coral CTA. Healthcare-calm. */
  --ink:#102F33;        /* deep forest teal (primary text) */
  --paper:#E6F2EF;      /* soft mint cream (page background) */
  --shell:#D4E6E0;      /* deeper mint surface */
  --steel:#2C5A60;      /* medium teal accent */
  --steel-2:#1A3F44;    /* darker teal */
  --ember:#F26B47;      /* warm coral CTA */
  --ember-soft:#FBD5C6; /* soft peach */
  --mint:#A8D4C2;       /* mid mint highlight */
  --line:#102F33;
  --radius:18px;
  --radius-lg:32px;
  --shadow:0 6px 24px rgba(16,47,51,.10);
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Albert Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;}

/* typography */
.eyebrow{font-family:'Josefin Sans',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.22em;font-size:14.5px;color:var(--steel);}
h1,h2,h3,h4{font-family:'Unbounded',sans-serif;font-weight:700;letter-spacing:-.01em;line-height:1.05;color:var(--ink);}
h1{font-size:clamp(48px, 7vw, 96px); font-weight:800;}
h2{font-size:clamp(36px, 4.5vw, 64px);}
h3{font-size:clamp(24px, 2.4vw, 32px);}
h4{font-size:clamp(18px, 1.4vw, 22px); font-weight:600;}
p{font-size:17px; color:#3A3F46;}
.lead{font-size:20px; color:#3A3F46;}

/* layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
section{padding:120px 0;}
@media(max-width:760px){
  section{padding:80px 0;}
  h1{line-height:1;}
}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:999px;font-weight:600;font-size:15px;transition:transform .15s ease, background .2s ease, color .2s ease;white-space:nowrap;}
.btn:hover{transform:translateY(-1px);}
.btn-primary{background:var(--ember); color:#fff;}
.btn-primary:hover{background:#D8543A; box-shadow:0 6px 18px rgba(242,107,71,.35);}
.btn-dark{background:var(--ink); color:#fff;}
.btn-dark:hover{background:var(--ember); color:#fff; box-shadow:0 6px 18px rgba(242,107,71,.35);}
.btn-ghost{background:transparent; color:var(--ink); border:1.5px solid var(--ink);}
.btn-ghost:hover{background:var(--ember); color:#fff; border-color:var(--ember);}
.btn-arrow::after{content:"→";font-size:18px;}

/* promo banner */
.promo{background:var(--ink); color:#fff;text-align:center; font-size:14px;padding:11px 16px;font-weight:500;}
.promo strong{color:var(--ember-soft);}
.promo a{text-decoration:underline; text-underline-offset:3px; margin-left:6px;}

/* nav — dark teal sticky bar */
nav.top{position:sticky; top:0; z-index:50;background:#102F33;border-bottom:1px solid rgba(255,255,255,.08);color:#fff;}
nav.top .row{display:flex; align-items:center; justify-content:space-between;height:78px;}
.brand{display:inline-flex;align-items:center;}
.brand img{height:42px;width:auto;display:block;}
nav.top .brand img{filter:brightness(0) invert(1);}
footer .brand img{filter:brightness(0) invert(1);height:38px;}
.nav-links{display:flex;gap:32px;align-items:center;font-weight:500;}
.nav-links a{font-size:15px;color:#fff;}
.nav-links a:hover{color:var(--ember);}
.nav-cta{display:flex;gap:12px;align-items:center;}
.nav-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4);}
.nav-cta .btn-ghost:hover{background:var(--ember);border-color:var(--ember);color:#fff;}
.menu-toggle{display:none;}
@media(max-width:900px){
  .nav-links{display:none;}
  .nav-cta .btn-ghost{display:none;}
  .menu-toggle{display:inline-flex;font-size:24px;padding:6px 10px;border:1px solid rgba(255,255,255,.4);border-radius:10px;color:#fff;}
}

/* hero */
.hero{padding:80px 0 120px;background:radial-gradient(1100px 600px at 80% 20%, rgba(232,106,51,.18), transparent 60%),radial-gradient(900px 500px at 10% 80%, rgba(56,76,93,.12), transparent 70%),var(--paper);overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;}
.hero h1 span.script{font-family:'Josefin Sans',serif;font-style:italic;font-weight:600;color:var(--ember);letter-spacing:0;}
.hero p.lead{margin:24px 0 36px; max-width:520px;}
.hero-ctas{display:flex; gap:14px; flex-wrap:wrap;}
.rating-badge{margin-top:36px;display:inline-flex;align-items:center;gap:14px;padding:14px 22px;background:#fff;border-radius:999px;box-shadow:var(--shadow);}
.stars{color:var(--ember); letter-spacing:2px; font-size:18px;}
.rating-text{font-weight:600;font-size:14px;}
.rating-text small{display:block;color:#6A7079;font-weight:400;}
.hero-art{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);background:var(--shell);overflow:hidden;box-shadow:0 30px 60px rgba(22,26,31,.18);}
.hero-photo{position:absolute; inset:0;width:100%; height:100%;object-fit:cover; object-position:center;}
.hero-chip{position:absolute; padding:14px 18px;background:#fff; border-radius:18px;box-shadow:var(--shadow);font-size:14px; font-weight:600;display:flex;align-items:center;gap:10px;}
.chip-1{top:36px; left:-30px; transform:rotate(-4deg);}
.chip-2{bottom:60px; right:-22px; transform:rotate(3deg);}
.chip-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;}
.chip-icon.green{background:var(--mint);}
.chip-icon.peach{background:var(--ember-soft);}
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr; gap:48px;}
  .hero-art{max-width:420px; margin:0 auto;}
  .chip-1{left:-10px;} .chip-2{right:-10px;}
}

/* bigger hero video window */
.hero-art-big{aspect-ratio:5/6 !important; max-width:none;}
.hero .hero-grid:has(.hero-art-big){grid-template-columns:0.85fr 1.15fr;}
@media(max-width:900px){.hero .hero-grid:has(.hero-art-big){grid-template-columns:1fr;} .hero-art-big{aspect-ratio:4/5 !important; max-width:520px;}}

/* video testimonials */
.video-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:8px;}
.video-card{position:relative; aspect-ratio:9/16; border-radius:var(--radius); overflow:hidden; background:var(--ink); box-shadow:var(--shadow); cursor:pointer;}
.video-card video{width:100%; height:100%; object-fit:cover; display:block;}
.video-card .vc-meta{position:absolute; bottom:0; left:0; right:0; padding:18px; background:linear-gradient(to top, rgba(16,47,51,.85), transparent); color:#fff; pointer-events:none;}
.video-card .vc-meta strong{font-family:'Unbounded',sans-serif; font-weight:600; font-size:18px; display:block;}
.video-card .vc-meta span{font-size:13px; opacity:.85;}
.video-card .vc-mute{position:absolute; top:14px; right:14px; width:38px; height:38px; border-radius:50%; background:rgba(0,0,0,.55); color:#fff; display:flex; align-items:center; justify-content:center; font-size:18px; backdrop-filter:blur(4px);}
/* big prominent "Click to hear" tap target overlaying each video */
.video-card .vc-tap{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(16,47,51,.18); transition:opacity .25s, background .25s; pointer-events:none;}
.video-card:hover .vc-tap{background:rgba(16,47,51,.35);}
.video-card .vc-tap span{background:var(--ember); color:#fff; font-family:'Unbounded',sans-serif; font-weight:700; font-size:15px; padding:14px 22px; border-radius:999px; box-shadow:0 6px 20px rgba(0,0,0,.35); letter-spacing:.02em;}
.video-card.playing .vc-tap{opacity:0;}
@media(max-width:900px){.video-grid{grid-template-columns:1fr; max-width:420px; margin:0 auto;}}

/* "All services" tab content list */
.svc-all-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px;}
.svc-all-grid a{padding:18px 20px; border-radius:14px; background:rgba(255,255,255,.06); color:#fff; border:1px solid rgba(255,255,255,.12); transition:all .2s; display:block; font-weight:600; font-size:15px;}
.svc-all-grid a:hover{background:var(--ember); border-color:var(--ember); transform:translateY(-2px);}
.svc-all-grid a small{display:block; font-weight:400; font-size:13px; opacity:.7; margin-top:4px;}
@media(max-width:760px){.svc-all-grid{grid-template-columns:1fr;}}

/* marquee */
.marquee{background:var(--ink); color:var(--paper);padding:22px 0; overflow:hidden;border-top:1px solid #2A2F36; border-bottom:1px solid #2A2F36;}
.marquee-track{display:flex; gap:60px; width:max-content;animation:scroll 40s linear infinite;font-family:'Unbounded',sans-serif;font-weight:600; font-size:22px;align-items:center;}
.marquee-track span{display:inline-flex;align-items:center;gap:20px;}
.dot{width:10px;height:10px;border-radius:50%;background:var(--ember);display:inline-block;}
@keyframes scroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* steps */
.steps{background:var(--paper);}
.steps .head{max-width:780px; margin-bottom:72px;}
.steps-grid{display:grid; grid-template-columns:repeat(3,1fr);gap:32px;}
.step{background:#fff;border-radius:var(--radius-lg);padding:40px 32px 36px;border:1px solid rgba(22,26,31,.06);position:relative;transition:transform .2s ease;}
.step:hover{transform:translateY(-4px);}
.step-num{font-family:'Unbounded',sans-serif;font-weight:800; font-size:64px;color:var(--ember);line-height:1;margin-bottom:18px;}
.step h3{margin-bottom:10px;}
@media(max-width:900px){.steps-grid{grid-template-columns:1fr;}}

/* services (homepage) */
.services{background:var(--steel);color:#fff;border-radius:48px 48px 0 0;}
.services h2, .services h3, .services h4{color:#fff;}
.services .eyebrow{color:var(--ember-soft);}
.services p{color:rgba(255,255,255,.78);}
.services .head{display:flex;justify-content:space-between;align-items:end;margin-bottom:56px;gap:32px;flex-wrap:wrap;}
.services .head h2{max-width:640px;}
.service-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px;}
.tab{padding:12px 20px; border-radius:999px;background:rgba(255,255,255,.08);color:#fff;font-size:14px; font-weight:600;border:1px solid rgba(255,255,255,.14);transition:all .2s;}
.tab.active{background:var(--ember); border-color:var(--ember);}
.tab:hover:not(.active){background:rgba(255,255,255,.16);}
.service-panel{display:none;background:var(--steel-2);border-radius:var(--radius-lg);padding:48px;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.service-panel.active{display:grid;}
.service-panel .pic{aspect-ratio:1;border-radius:24px;overflow:hidden;background:var(--shell);}
.service-panel .pic img{width:100%;height:100%;object-fit:cover;display:block;}
.service-panel h3{font-size:36px;margin-bottom:12px;}
.service-bullets{margin:24px 0 32px; list-style:none;}
.service-bullets li{padding:10px 0; padding-left:30px;border-bottom:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.85);position:relative;}
.service-bullets li::before{content:"✓"; color:var(--ember);position:absolute; left:0; top:10px;font-weight:700;}
@media(max-width:900px){
  .services{border-radius:32px 32px 0 0;}
  .service-panel{padding:32px 24px;grid-template-columns:1fr;}
}

/* compare */
.compare{background:var(--shell);}
.compare .head{text-align:center; max-width:760px; margin:0 auto 64px;}
.table-wrap{background:#fff; border-radius:var(--radius-lg);overflow:hidden; box-shadow:var(--shadow);max-width:980px; margin:0 auto;}
table{width:100%; border-collapse:collapse;}
th, td{padding:22px 24px; text-align:left; border-bottom:1px solid rgba(22,26,31,.06);}
thead th{background:var(--ink); color:#fff;font-family:'Unbounded',sans-serif; font-weight:600; font-size:15px;}
thead th:nth-child(2){background:var(--ember);}
tbody td{font-size:15px;}
tbody td:nth-child(1){font-weight:600;}
tbody td:nth-child(2){background:rgba(232,106,51,.06); font-weight:600;}
.check{color:var(--ember); font-weight:700; font-size:18px;}
.x{color:#9CA1A8; font-size:18px;}
@media(max-width:760px){th, td{padding:14px 12px; font-size:13px;}}

/* reviews */
.reviews{background:var(--paper);}
.reviews .head{display:flex;justify-content:space-between;align-items:end;margin-bottom:56px;gap:32px;flex-wrap:wrap;}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.review{background:#fff; border-radius:var(--radius);padding:32px; border:1px solid rgba(22,26,31,.06);display:flex; flex-direction:column;}
.review .stars{margin-bottom:14px;}
.review p{font-size:16px; color:var(--ink); margin-bottom:24px; flex:1;}
.reviewer{display:flex; align-items:center; gap:12px;}
.avatar{width:44px;height:44px;border-radius:50%;background:var(--shell);color:var(--steel);display:flex;align-items:center;justify-content:center;font-family:'Unbounded',sans-serif;font-weight:700;}
.reviewer-meta{font-size:14px;}
.reviewer-meta strong{display:block;}
.reviewer-meta small{color:#6A7079;}
@media(max-width:900px){.review-grid{grid-template-columns:1fr;}}

/* team */
.team{background:var(--shell);}
.team .head{text-align:center;max-width:680px;margin:0 auto 64px;}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.doctor{text-align:center;}
.doctor .portrait{aspect-ratio:4/5;border-radius:var(--radius);background:var(--shell);margin-bottom:20px;overflow:hidden;}
.doctor .portrait img{width:100%;height:100%;object-fit:cover;display:block;}
.team-grid.two{grid-template-columns:repeat(2,1fr);max-width:780px;margin:0 auto;gap:48px;}
@media(max-width:760px){.team-grid.two{grid-template-columns:1fr;max-width:380px;}}
.doctor h4{margin-bottom:4px;}
.doctor .role{font-family:'Josefin Sans',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--steel);}
@media(max-width:900px){.team-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto;}}

/* location */
.location{background:var(--paper);}
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.location h2{margin-bottom:18px;}
.location-detail{margin:24px 0;}
.location-detail dt{font-family:'Josefin Sans',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--steel);margin-bottom:6px;}
.location-detail dd{font-size:18px;font-weight:600;margin-bottom:18px;}
.map-frame{aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(22,26,31,.08);}
.map-frame iframe{width:100%;height:100%;border:0;display:block;}
@media(max-width:900px){.location-grid{grid-template-columns:1fr;}}

/* faq */
.faq{background:var(--shell);}
.faq .head{max-width:680px;margin:0 auto 56px;text-align:center;}
.faq-list{max-width:820px;margin:0 auto;}
.faq-item{background:#fff; border-radius:18px;margin-bottom:14px; padding:0;border:1px solid rgba(22,26,31,.06);overflow:hidden;}
.faq-q{width:100%;text-align:left;padding:24px 28px;display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:'Unbounded',sans-serif;font-weight:600;font-size:18px;}
.faq-q .plus{font-size:28px; line-height:1;transition:transform .25s ease;color:var(--ember);}
.faq-item.open .plus{transform:rotate(45deg);}
.faq-a{max-height:0; overflow:hidden;transition:max-height .3s ease, padding .3s ease;padding:0 28px;color:#3A3F46;}
.faq-item.open .faq-a{max-height:400px;padding:0 28px 24px;}

/* partners */
.partners{background:var(--shell); padding:80px 0 90px;}
.ins-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:14px; max-width:1100px; margin:0 auto;}
.ins-pill{display:flex; align-items:center; justify-content:center; padding:18px 14px; border-radius:14px; background:#fff; color:var(--ink); font-weight:600; font-size:14px; text-align:center; border:1px solid rgba(16,47,51,.1); transition:transform .2s, border-color .2s, box-shadow .2s;}
.ins-pill:hover{transform:translateY(-2px); border-color:var(--ember); box-shadow:0 6px 18px rgba(242,107,71,.15); color:var(--ember);}
@media(max-width:900px){.ins-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:520px){.ins-grid{grid-template-columns:repeat(2,1fr);}}
.partners .head{text-align:center; margin-bottom:48px;}
.partners .head{text-align:center; margin-bottom:40px;}
.partner-row{display:flex; flex-wrap:wrap; align-items:center; justify-content:center;gap:48px 64px;}
.partner-row img{height:42px; width:auto; opacity:.7;filter:grayscale(1);transition:opacity .2s, filter .2s;}
.partner-row img:hover{opacity:1; filter:grayscale(0);}
.partners-divider{height:1px; background:rgba(22,26,31,.08); margin:48px auto; max-width:560px;}
.partner-label{display:block; text-align:center; font-family:'Josefin Sans',sans-serif;font-weight:700; text-transform:uppercase; letter-spacing:.16em;font-size:12px; color:var(--steel); margin-bottom:24px;}

/* smile gallery */
.smiles{background:var(--paper);}
.smiles .head{display:flex; justify-content:space-between; align-items:end; gap:32px; flex-wrap:wrap; margin-bottom:48px;}
.smiles-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.smile-card{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background:#fff;position:relative;box-shadow:var(--shadow);padding:10px;}
.smile-card img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .4s ease;border-radius:calc(var(--radius) - 6px);}
.smile-card:hover img{transform:scale(1.04);}
.smile-card .label{position:absolute; bottom:14px; left:14px;background:rgba(255,255,255,.95); color:var(--ink);font-size:13px; font-weight:600;padding:8px 14px; border-radius:999px;}
@media(max-width:760px){.smiles-grid{grid-template-columns:1fr;}}

/* cta band */
.cta-band{background:var(--ember); color:#fff;padding:90px 0;text-align:center;}
.cta-band h2{color:#fff;margin-bottom:18px;}
.cta-band p{color:rgba(255,255,255,.9);font-size:19px; max-width:580px; margin:0 auto 32px;}
.cta-band .btn-dark{background:#fff;color:var(--ink);}
.cta-band .btn-dark:hover{background:var(--ink);color:#fff;}

/* footer */
footer{background:var(--ink); color:rgba(255,255,255,.72);padding:80px 0 36px;}
.foot-grid{display:grid; grid-template-columns:2fr 1fr 1fr 1fr;gap:48px; margin-bottom:64px;}
footer h5{font-family:'Josefin Sans',sans-serif; font-weight:700;text-transform:uppercase; letter-spacing:.16em;font-size:13px; color:#fff;margin-bottom:20px;}
footer ul{list-style:none; display:flex; flex-direction:column; gap:12px;}
footer ul a:hover{color:var(--ember);}
footer p.about{color:rgba(255,255,255,.6); margin:18px 0 28px; max-width:380px;}
footer .brand{color:#fff;}
.socials{display:flex;gap:12px;}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:inline-flex;align-items:center;justify-content:center;transition:background .2s;}
.socials a:hover{background:var(--ember);border-color:var(--ember);}
.legal{display:flex;justify-content:space-between;align-items:center;padding-top:32px; border-top:1px solid rgba(255,255,255,.1);font-size:13px; color:rgba(255,255,255,.5);flex-wrap:wrap; gap:16px;}
.legal a:hover{color:#fff;}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr; gap:36px;}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr;}}

/* hours card — Open Now badge + today highlight */
#hours-card table td{padding:8px 0; font-size:15px; border-bottom:1px solid rgba(22,26,31,.06);}
#hours-card table tr:last-child td{border-bottom:0;}
#hours-card table td:first-child{font-weight:600; width:42%;}
#hours-card table td:last-child{color:#3A3F46; text-align:right;}
#hours-card table tr.today td{background:rgba(168,212,194,.18); color:var(--ink); font-weight:700;}
#hours-card table tr.today td:first-child{padding-left:10px; border-left:3px solid var(--ember);}
.open-badge{display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:999px; font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; background:#E5E5E5; color:#666;}
.open-badge.open{background:#D7F5E2; color:#0D7A3A;}
.open-badge.open::before{content:""; width:8px; height:8px; border-radius:50%; background:#16B85E; box-shadow:0 0 0 4px rgba(22,184,94,.2);}
.open-badge.closed{background:#FEEAEA; color:#B8403F;}
.open-badge.closed::before{content:""; width:8px; height:8px; border-radius:50%; background:#E54B4B;}

/* booking modal — keeps the patient on-site instead of redirecting */
.book-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;animation:bm-in .2s ease;}
.book-modal[hidden]{display:none;}
.book-modal-backdrop{position:absolute;inset:0;background:rgba(16,47,51,.65);backdrop-filter:blur(6px);}
.book-modal-card{position:relative;background:#fff;border-radius:var(--radius-lg);width:min(900px,95vw);height:min(760px,92vh);box-shadow:0 30px 80px rgba(0,0,0,.4);overflow:hidden;display:flex;flex-direction:column;}
.book-modal-header{padding:14px 20px;border-bottom:1px solid rgba(22,26,31,.08);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;}
.book-modal-header strong{font-family:'Unbounded',sans-serif;font-size:16px;}
.book-modal-card iframe{flex:1;width:100%;border:0;display:block;}
.book-modal-close{width:34px;height:34px;border-radius:50%;background:transparent;border:1px solid rgba(22,26,31,.2);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;}
.book-modal-close:hover{background:var(--ember);color:#fff;border-color:var(--ember);}
@keyframes bm-in{from{opacity:0}to{opacity:1}}

/* mobile drawer */
.mobile-drawer{display:none;position:fixed; inset:0;background:var(--paper); z-index:60;padding:32px 28px;}
.mobile-drawer.open{display:flex;flex-direction:column;}
.mobile-drawer .close{align-self:flex-end;font-size:28px;border:1px solid var(--ink);border-radius:10px;padding:4px 14px;}
.mobile-drawer nav{display:flex;flex-direction:column;gap:24px;margin-top:48px;font-family:'Unbounded',sans-serif;font-size:24px;}
.mobile-drawer .btn{margin-top:32px;justify-content:center;}

/* ============== SUBPAGE ADDITIONS ============== */
.subhero{padding:120px 0 80px !important;}
.subhero h1{font-size:clamp(40px, 5.5vw, 76px);}
.two-col{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;}
.two-col-img img{width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--radius-lg);}
@media(max-width:760px){.two-col{grid-template-columns:1fr;}}
.feature-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.feature-card{background:#fff; border-radius:var(--radius); padding:32px 28px; border:1px solid rgba(22,26,31,.06);}
.feature-num{font-family:'Unbounded',sans-serif; font-weight:800; font-size:32px; color:var(--ember); margin-bottom:14px;}
@media(max-width:760px){.feature-grid{grid-template-columns:1fr;}}
.rich-bullets{list-style:none; padding:0;}
.rich-bullets li{padding:18px 0; padding-left:36px; border-bottom:1px solid rgba(22,26,31,.08); position:relative; font-size:17px; color:#3A3F46;}
.rich-bullets li::before{content:"✓"; color:var(--ember); position:absolute; left:0; top:18px; font-weight:800; font-size:20px;}
.rich-bullets li strong{color:var(--ink); font-weight:600;}
.doctor-bio{display:grid; grid-template-columns:1fr 2fr; gap:48px; align-items:start; padding:64px 0; border-bottom:1px solid rgba(22,26,31,.08);}
.doctor-bio:last-child{border-bottom:0;}
.doctor-bio img{width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--radius);}
@media(max-width:760px){.doctor-bio{grid-template-columns:1fr;}}
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start;}
.contact-card{background:#fff; padding:36px; border-radius:var(--radius); border:1px solid rgba(22,26,31,.06); margin-bottom:18px;}
.contact-card h4{margin-bottom:8px;}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;}}
.price-card{background:#fff; padding:48px; border-radius:var(--radius-lg); border:1px solid rgba(22,26,31,.08); text-align:center; max-width:520px; margin:0 auto; box-shadow:var(--shadow);}
.price-card .amount{font-family:'Unbounded',sans-serif; font-weight:800; font-size:64px; color:var(--ember); line-height:1;}
.price-card .per{color:#6A7079; margin-top:6px;}
.price-card ul{list-style:none; text-align:left; margin:32px 0;}
.price-card ul li{padding:10px 0; padding-left:28px; position:relative;}
.price-card ul li::before{content:"✓"; color:var(--ember); position:absolute; left:0; top:10px; font-weight:700;}
.gallery-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.gallery-grid .g-cell{aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden; background:#fff; padding:12px; box-shadow:var(--shadow);}
.gallery-grid .g-cell img{width:100%; height:100%; object-fit:contain; border-radius:calc(var(--radius) - 6px);}
@media(max-width:760px){.gallery-grid{grid-template-columns:1fr 1fr;}}
.legal-prose{max-width:760px;}
.legal-prose h2{margin-top:48px; font-size:28px;}
.legal-prose p{margin-top:16px;}
.svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.svc-card{background:#fff; border-radius:var(--radius); overflow:hidden; border:1px solid rgba(22,26,31,.06); display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s;}
.svc-card:hover{transform:translateY(-4px); box-shadow:var(--shadow);}
.svc-img{aspect-ratio:4/3; overflow:hidden; background:var(--shell);}
.svc-img img{width:100%; height:100%; object-fit:cover;}
.svc-body{padding:28px;}
.svc-body h3{font-size:22px; margin-bottom:8px;}
.svc-link{display:inline-block; margin-top:18px; color:var(--ember); font-weight:600; font-size:15px;}
@media(max-width:760px){.svc-grid{grid-template-columns:1fr;}}


/* ============== V3 DESIGN TOKENS (added in v3 rollout) ============== */
:root{
  --ab2-cream:#FBFAF5;
  --ab2-ink:#1A1A1A;
  --ab2-ember:#FF5C39;
  --ab2-peach:#FFCBB8;
  --ab2-soft-peach:#FFE4D9;
  --ab2-line:#EAE5DA;
}

/* GleamBar logo in nav — replaces text link */
.nav-links a.gleam { line-height:1; display:inline-flex; align-items:center; }
.v3-drawer a.gleam { line-height:1; display:flex; align-items:center; }
.nav-links a.gleam .gleam-nav-logo,
.gleam-nav-logo { height:60px !important; width:auto !important; max-width:240px !important; display:block; flex-shrink:0; }
.v3-drawer a.gleam .gleam-nav-logo,
.v3-drawer .gleam-nav-logo { height:72px !important; width:auto !important; max-width:280px !important; }
