/* -------------------------------------------------------------
   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 — UNIFIED v16. UNO DENTAL ink→ember gradient (classic editorial),
   1100px wrap, 4 equal cols, divider after brand, contact list (pin/phone/envelope)
   under About, socials below, circle social icons. GleamBar pages override this
   locally with their own purple gradient. */
footer{
  background:linear-gradient(135deg, #0B2226 0%, #102F33 50%, #1A4A52 100%);
  color:#fff;
  padding:80px 0 40px;
}
footer .wrap{max-width:1100px;margin:0 auto;padding:0 28px;}
.foot-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:64px;
  align-items:start;
}
/* Divider between brand col and link cols (drawn on col 2's left border, no width steal) */
.foot-grid > div:nth-child(2){
  padding-left:24px;
  border-left:1px solid rgba(255,255,255,.22);
}
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; padding:0; margin:0;}
footer ul li a{color:rgba(255,255,255,.85);text-decoration:none;transition:color .2s;}
footer ul a:hover{color:#FFCBB8;}
footer p.about{color:rgba(255,255,255,.78); margin:18px 0 22px; max-width:380px; line-height:1.55;}
footer .brand{color:#fff; display:inline-block;}
footer .brand img{filter:brightness(0) invert(1);height:38px;display:block;}

/* Contact list: pin/phone/envelope icons + text under About */
.foot-contact{
  list-style:none;
  padding:0; margin:0 0 22px;
  display:flex; flex-direction:column; gap:10px;
}
.foot-contact li{
  display:flex; align-items:center; gap:10px;
  font-size:14px; color:rgba(255,255,255,.85);
}
.foot-contact-icon{
  width:16px; height:16px; flex-shrink:0;
  color:rgba(255,255,255,.75);
}
.foot-contact li a{
  color:rgba(255,255,255,.92);
  text-decoration:none;
  transition:color .2s;
}
.foot-contact li a:hover{ color:#FFCBB8; }

/* Socials — 40×40 circles, soft white border, hover lift */
.socials{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px;}
.socials a{
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,255,255,.30);
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.85);
  transition:background .2s,border-color .2s,transform .18s,color .2s;
}
.socials a:hover{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.55);
  color:#fff;
  transform:translateY(-2px);
}
.socials a svg{width:18px;height:18px;}

.legal{display:flex;justify-content:space-between;align-items:center;padding-top:32px; border-top:1px solid rgba(255,255,255,.18);font-size:13px; color:rgba(255,255,255,.65);flex-wrap:wrap; gap:16px;}
.legal a{color:rgba(255,255,255,.65);text-decoration:none;}
.legal a:hover{color:#fff;}

/* Gleaming gold line hover — TOP-LEVEL header nav + footer titles & links.
   Scoped via direct-child selectors so it never reaches dropdown anchors. */
nav.top .nav-links > .nav-item > a.parent,
nav.top .nav-links > a:not(.gleam),
footer .foot-grid h5 a,
footer .foot-grid ul li a,
footer .foot-contact li a{
  position:relative;
  text-decoration:none;
  transition:color .25s ease;
}
nav.top .nav-links > .nav-item > a.parent::before,
nav.top .nav-links > a:not(.gleam)::before,
footer .foot-grid h5 a::before,
footer .foot-grid ul li a::before,
footer .foot-contact li a::before{
  content:""; position:absolute; left:50%; bottom:-2px;
  width:0; height:2px;
  background:linear-gradient(90deg, transparent 0%, #FFD27D 30%, #FFCBB8 50%, #FFD27D 70%, transparent 100%);
  transition:width .35s ease, left .35s ease;
  pointer-events:none;
}
nav.top .nav-links > .nav-item > a.parent:hover::before,
nav.top .nav-links > a:not(.gleam):hover::before,
footer .foot-grid h5 a:hover::before,
footer .foot-grid ul li a:hover::before,
footer .foot-contact li a:hover::before{
  width:100%; left:0;
}
nav.top .nav-links > .nav-item > a.parent:hover,
nav.top .nav-links > a:not(.gleam):hover,
footer .foot-grid h5 a:hover,
footer .foot-grid ul li a:hover,
footer .foot-contact li a:hover{
  color:#FFE9C0;
}
footer .foot-grid h5 a{
  color:inherit; font:inherit; letter-spacing:inherit; text-transform:inherit;
}
/* Dropdown anchors stay block-level (defensive) */
nav.top .nav-dropdown a{ display:block; }
nav.top .nav-dropdown a::before{ content:none; }

/* MOBILE/TABLET — brand col full-width on top, 3 link cols in a 3-col row below */
@media(max-width:900px){
  .foot-grid{
    grid-template-columns:repeat(3, 1fr);
    grid-template-areas:
      "brand brand brand"
      "links1 links2 links3";
    gap:28px 20px;
  }
  .foot-grid > div:nth-child(1){
    grid-area:brand;
    display:grid;
    grid-template-columns:1.5fr 1fr;
    gap:24px 32px;
    align-items:start;
  }
  .foot-grid > div:nth-child(1) > .brand,
  .foot-grid > div:nth-child(1) > .socials{ grid-column:1 / -1; }
  .foot-grid > div:nth-child(1) > .socials{ margin-top:0; }
  .foot-grid > div:nth-child(1) > .about{ grid-column:1; margin-bottom:0; }
  .foot-grid > div:nth-child(1) > .foot-contact{ grid-column:2; margin-bottom:0; }
  .foot-grid > div:nth-child(2){
    grid-area:links1;
    padding-left:0;
    padding-top:24px;
    border-left:0;
    border-top:1px solid rgba(255,255,255,.22);
  }
  .foot-grid > div:nth-child(3){
    grid-area:links2;
    padding-top:24px;
    border-top:1px solid rgba(255,255,255,.22);
  }
  .foot-grid > div:nth-child(4){
    grid-area:links3;
    padding-top:24px;
    border-top:1px solid rgba(255,255,255,.22);
  }
  .foot-grid > div h5{ font-size:11px; margin-bottom:14px; letter-spacing:.14em; }
  .foot-grid > div ul{ gap:9px; }
  .foot-grid > div ul li a{ font-size:13px; }
}
@media(max-width:560px){
  .foot-grid{ gap:24px 14px; }
  .foot-grid > div:nth-child(1){ grid-template-columns:1fr; gap:14px; }
  .foot-grid > div:nth-child(1) > .about,
  .foot-grid > div:nth-child(1) > .foot-contact{ grid-column:1; }
  .foot-grid > div h5{ font-size:10px; }
  .foot-grid > div ul li a{ font-size:12px; }
  footer .wrap{ padding:60px 18px 32px; }
}
@media(max-width:340px){
  .foot-grid{
    grid-template-areas:
      "brand brand"
      "links1 links2"
      "links3 links3";
    grid-template-columns:1fr 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);height:min(760px,92dvh);overscroll-behavior:contain;box-shadow:0 30px 80px rgba(0,0,0,.4);overflow:hidden;display:flex;flex-direction:column;}
@media(max-width:760px){.book-modal-card{width:100vw;height:100dvh;border-radius:0;max-width:none;}}
.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:44px;height:44px;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-mint:#E6F2EF;       /* original light mint — cool side of the palette */
  --ab2-mint-deep:#D4E6E0;  /* deeper mint surface */
  --ab2-teal:#1F3A40;       /* warm dark teal */
  --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,

/* ============================================================================
   v4 ELEVATION — UNO DENTAL palette only (ink / ember / peach / cream).
   Adds glass containers + ember gradient + subtle ambience to .ab2-* sections.
   GleamBar pages have their own purple/iridescent treatment locally;
   this block does NOT touch them.
   ============================================================================ */

/* ---- HOW IT WORKS — keep ink base, add ember glow + glass step cards ---- */
.ab2-how {
  background:
    radial-gradient(45% 55% at 18% 12%, rgba(255,92,57,.18), transparent 60%),
    radial-gradient(50% 60% at 82% 88%, rgba(255,203,184,.12), transparent 60%),
    var(--ab2-ink, #1A1A1A) !important;
  position: relative;
  overflow: hidden;
}
.ab2-how-step {
  position: relative;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  padding: 36px 32px !important;
  margin: 0 8px;
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  box-shadow: 0 30px 70px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.10);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.ab2-how-step:hover {
  transform: translateY(-4px);
  border-color: rgba(255,203,184,.45);
  box-shadow: 0 30px 70px rgba(255,92,57,.18), inset 0 1px 0 rgba(255,255,255,.14);
}
.ab2-how-step:first-child { padding-left: 32px !important; border-left: 1px solid rgba(255,255,255,.14); }
.ab2-how-grid { gap: 20px !important; }
@media(max-width:900px) {
  .ab2-how-step, .ab2-how-step:first-child { margin: 0; padding: 32px 28px !important; border-left: 1px solid rgba(255,255,255,.14); border-top: 1px solid rgba(255,255,255,.14); }
}

/* ---- WHAT WE DO accordion — soft glass panels ---- */
.ab2-acc-panel {
  position: relative;
  border-radius: 22px !important;
  overflow: hidden;
  transition: border-color .35s ease, box-shadow .35s ease, transform .25s ease;
}
.ab2-acc-panel.is-open {
  background: rgba(255,255,255,.82) !important;
  border: 2px solid rgba(255,92,57,.32) !important;
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  box-shadow: 0 22px 48px rgba(255,92,57,.14), inset 0 1px 0 rgba(255,255,255,.9) !important;
}

/* ---- WHY UNO — glass cards (not purple) ---- */
.ab2-why-card {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 24px !important;
  backdrop-filter: blur(12px) saturate(1.3);
  -webkit-backdrop-filter: blur(12px) saturate(1.3);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.ab2-why-card:not(.featured):hover {
  transform: translateY(-4px);
  border-color: rgba(255,203,184,.42) !important;
  box-shadow: 0 22px 48px rgba(0,0,0,.30) !important;
}
.ab2-why-card.featured {
  /* Kept the original ember-coral featured card, just adding glass + glow */
  background: linear-gradient(135deg, rgba(255,92,57,.95) 0%, rgba(232,82,46,.92) 100%) !important;
  border: 2px solid rgba(255,203,184,.55) !important;
  box-shadow: 0 30px 70px rgba(255,92,57,.45), inset 0 1px 0 rgba(255,255,255,.20) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.ab2-why-card.featured .badge { background: rgba(255,255,255,.30) !important; color: #fff !important; }
.ab2-why-card.featured li::before { color: #FFE4D9 !important; }

/* ---- PATIENT STORIES — soft glass on the cream/peach background ---- */
.ab2-stories {
  background:
    radial-gradient(45% 55% at 25% 30%, rgba(255,203,184,.55), transparent 65%),
    radial-gradient(50% 60% at 78% 72%, rgba(255,92,57,.10), transparent 65%),
    var(--ab2-soft-peach, #FFE4D9) !important;
  position: relative;
}
.ab2-st-panel {
  background: rgba(255,255,255,.62) !important;
  border: 1px solid rgba(255,255,255,.7) !important;
  border-radius: 22px !important;
  backdrop-filter: blur(14px) saturate(1.3) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.3) !important;
  box-shadow: 0 18px 38px rgba(0,0,0,.06), inset 0 1px 0 rgba(255,255,255,.9) !important;
  transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease !important;
}
.ab2-st-panel:hover {
  border-color: rgba(255,92,57,.32) !important;
  transform: translateY(-2px);
}
.ab2-st-panel.is-open {
  border-color: rgba(255,92,57,.40) !important;
  box-shadow: 0 22px 48px rgba(255,92,57,.14), inset 0 1px 0 rgba(255,255,255,.9) !important;
}

/* ---- INSURANCE WALL — glass container around the carriers grid ---- */
.ab2-ins-wall {
  position: relative;
  background:
    radial-gradient(50% 60% at 50% 0%, rgba(255,203,184,.30), transparent 70%),
    var(--ab2-cream, #FBFAF5) !important;
}
.ab2-ins-wall-inner {
  background: rgba(255,255,255,.78) !important;
  border: 1.5px solid rgba(26,26,26,.08) !important;
  border-radius: 28px !important;
  padding: 44px 32px !important;
  backdrop-filter: blur(12px) saturate(1.3) !important;
  -webkit-backdrop-filter: blur(12px) saturate(1.3) !important;
  box-shadow: 0 22px 48px rgba(26,26,26,.06), inset 0 1px 0 rgba(255,255,255,.95) !important;
  max-width: 1200px;
  margin: 0 auto;
}

/* ---- FAQ — glass panels with ember-tinted hover (not gold) ---- */
.ab2-faq {
  background:
    radial-gradient(45% 55% at 22% 22%, rgba(255,203,184,.30), transparent 65%),
    radial-gradient(40% 50% at 78% 78%, rgba(255,92,57,.06), transparent 65%),
    var(--ab2-cream, #FBFAF5) !important;
  position: relative;
}
.ab2-faq-card, .ab2-faq-item, .ab2-faq-q {
  background: rgba(255,255,255,.78) !important;
  border: 1px solid rgba(26,26,26,.08) !important;
  border-radius: 16px !important;
  backdrop-filter: blur(10px) saturate(1.2);
  -webkit-backdrop-filter: blur(10px) saturate(1.2);
  transition: border-color .25s ease, box-shadow .25s ease, transform .15s ease;
}
.ab2-faq-card:hover, .ab2-faq-item:hover, .ab2-faq-q:hover {
  border-color: rgba(255,92,57,.40) !important;
  box-shadow: 0 14px 32px rgba(255,92,57,.08);
  transform: translateY(-2px);
}

/* ---- VISIT US — glass card around contact block ---- */
.ab2-visit-card, .ab2-visit-contact, .ab2-visit-info {
  background: rgba(255,255,255,.85) !important;
  border: 1.5px solid rgba(26,26,26,.08) !important;
  border-radius: 22px !important;
  backdrop-filter: blur(12px) saturate(1.3);
  -webkit-backdrop-filter: blur(12px) saturate(1.3);
  box-shadow: 0 22px 48px rgba(26,26,26,.06), inset 0 1px 0 rgba(255,255,255,.95) !important;
  padding: 36px 32px !important;
}

/* ---- SMILE BIGGER CTA — official UNO DENTAL ink → ember gradient ---- */
.ab2-final {
  background: linear-gradient(135deg, var(--ab2-ink, #1A1A1A) 0%, var(--ab2-ember, #FF5C39) 100%) !important;
  position: relative;
  overflow: hidden;
}
.ab2-final::before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(45% 55% at 80% 18%, rgba(255,203,184,.22), transparent 60%),
    radial-gradient(50% 60% at 20% 82%, rgba(255,228,217,.16), transparent 60%);
  pointer-events:none;
}
.ab2-final h2,
.ab2-final p,
.ab2-final * { position: relative; z-index: 1; }
.ab2-final .ab2-final-cta,
.ab2-final .btn,
.ab2-final a[class*="cta"]:not(.ab2-final-ghost) {
  background: rgba(255,255,255,.95) !important;
  color: var(--ab2-ink, #1A1A1A) !important;
  border: 1px solid rgba(255,255,255,.6) !important;
  box-shadow: 0 14px 32px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.9) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: transform .15s ease, box-shadow .15s ease;
}
.ab2-final .ab2-final-cta:hover,
.ab2-final .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 48px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.9) !important;
}
.ab2-final .ab2-final-ghost {
  background: transparent !important;
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,.55) !important;
}
.ab2-final .ab2-final-ghost:hover {
  background: rgba(255,255,255,.10) !important;
  border-color: #fff !important;
}

/* ---- HERO — soft glass shadow under headline+CTA cluster ---- */
.ab2-hero .ab2-hero-content,
.ab2-hero .hero-content,
.ab2-hero-inner {
  position: relative;
  z-index: 2;
}
.ab2-hero .ab2-hero-content::before {
  content:""; position:absolute;
  inset: -28px -36px;
  background: linear-gradient(180deg, rgba(0,0,0,.30) 0%, transparent 80%);
  border-radius: 32px;
  filter: blur(14px);
  z-index: -1;
  pointer-events: none;
}

/* ---- Hover: ember-tinted gleaming line on UNO DENTAL nav + footer (replaces gold for UNO pages) ---- */
nav.top .nav-links > .nav-item > a.parent::before,
nav.top .nav-links > a:not(.gleam)::before,
footer .foot-grid h5 a::before,
footer .foot-grid ul li a::before,
footer .foot-contact li a::before {
  background: linear-gradient(90deg, transparent 0%, #FF5C39 30%, #FFCBB8 50%, #FF5C39 70%, transparent 100%) !important;
}
nav.top .nav-links > .nav-item > a.parent:hover,
nav.top .nav-links > a:not(.gleam):hover,
footer .foot-grid h5 a:hover,
footer .foot-grid ul li a:hover,
footer .foot-contact li a:hover {
  color: #FFE4D9 !important;
}

/* ============================================================================
   v4.1 PATCH — restore accordion COLOR POP, full-size videos like service pages,
   glass buttons, fix Smile Bigger card. UNO DENTAL palette only.
   ============================================================================ */

/* ---- Accordion: kill the white-glass override, let original colors WIN ---- */
.ab2-acc-panel.is-open {
  background: revert !important;            /* let original [data-color] colors render */
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
/* Restore vibrant per-product backgrounds + add glass edge */
.ab2-acc-panel.is-open[data-color="coral"]  { background: #FF6B5B !important; box-shadow: 0 30px 70px rgba(255,107,91,.32),  inset 0 1px 0 rgba(255,255,255,.30) !important; border: 0 !important; }
.ab2-acc-panel.is-open[data-color="cream"]  { background: linear-gradient(155deg,#FFF8F0 0%,#FFE4D9 100%) !important; box-shadow: 0 30px 70px rgba(255,203,184,.32), inset 0 1px 0 rgba(255,255,255,.95) !important; border: 0 !important; }
.ab2-acc-panel.is-open[data-color="lilac"]  { background: #C9B8E8 !important; box-shadow: 0 30px 70px rgba(201,184,232,.45), inset 0 1px 0 rgba(255,255,255,.40) !important; border: 0 !important; }
.ab2-acc-panel.is-open[data-color="mint"]   { background: #B8E6CF !important; box-shadow: 0 30px 70px rgba(184,230,207,.45), inset 0 1px 0 rgba(255,255,255,.50) !important; border: 0 !important; }
.ab2-acc-panel.is-open[data-color="ember"]  { background: var(--ab2-ember,#FF5C39) !important; box-shadow: 0 30px 70px rgba(255,92,57,.45), inset 0 1px 0 rgba(255,255,255,.20) !important; border: 0 !important; }
.ab2-acc-panel.is-open[data-color="peach"]  { background: #FFD8C8 !important; box-shadow: 0 30px 70px rgba(255,216,200,.45), inset 0 1px 0 rgba(255,255,255,.50) !important; border: 0 !important; }
.ab2-acc-panel.is-open[data-color="rose"]   { background: #FFC4B0 !important; box-shadow: 0 30px 70px rgba(255,196,176,.45), inset 0 1px 0 rgba(255,255,255,.50) !important; border: 0 !important; }
/* Hover state for closed panels gets a soft glass POP */
.ab2-acc-panel:not(.is-open):hover {
  background: rgba(255,255,255,.85) !important;
  border-color: rgba(255,92,57,.32) !important;
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(0,0,0,.08);
}

/* ---- Accordion videos — full-size like service pages (svp-hero-visual recipe) ---- */
.ab2-acc-vid {
  aspect-ratio: 9/13 !important;
  max-height: none !important;
  max-width: 380px;
  margin-left: auto;
  border-radius: 24px !important;
  box-shadow: 0 24px 60px rgba(16,16,16,.22) !important;
  background: #000;
  overflow: hidden;
}
.ab2-acc-vid video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}
@media(max-width: 760px) {
  .ab2-acc-vid {
    aspect-ratio: 9/12 !important;
    max-width: 300px;
    margin: 0 auto;
  }
}

/* ---- Glass treatment on PRIMARY homepage CTA buttons ---- */
.ab2-btn-primary,
.ab2-how-cta-primary,
.ab2-final .ab2-btn-primary {
  position: relative;
  background: linear-gradient(135deg, var(--ab2-ember,#FF5C39) 0%, #FF7253 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.30) !important;
  box-shadow:
    0 14px 32px rgba(255,92,57,.42),
    inset 0 1px 0 rgba(255,255,255,.30),
    inset 0 -1px 0 rgba(0,0,0,.10) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease !important;
  overflow: hidden;
}
.ab2-btn-primary::after,
.ab2-how-cta-primary::after,
.ab2-final .ab2-btn-primary::after {
  content: "";
  position: absolute;
  top: 0; left: -120%;
  width: 60%; height: 100%;
  background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,.45) 50%, transparent 100%);
  transition: left .55s ease;
  pointer-events: none;
}
.ab2-btn-primary:hover::after,
.ab2-how-cta-primary:hover::after,
.ab2-final .ab2-btn-primary:hover::after {
  left: 140%;
}
.ab2-btn-primary:hover,
.ab2-how-cta-primary:hover,
.ab2-final .ab2-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 22px 48px rgba(255,92,57,.55),
    inset 0 1px 0 rgba(255,255,255,.35),
    inset 0 -1px 0 rgba(0,0,0,.10) !important;
}

/* On dark final-CTA background, primary becomes white-glass */
.ab2-final .ab2-btn-primary {
  background: rgba(255,255,255,.94) !important;
  color: var(--ab2-ink,#1A1A1A) !important;
  box-shadow:
    0 18px 40px rgba(0,0,0,.30),
    inset 0 1px 0 rgba(255,255,255,.90) !important;
}
.ab2-final .ab2-btn-primary:hover {
  background: #fff !important;
  box-shadow:
    0 24px 56px rgba(0,0,0,.40),
    inset 0 1px 0 rgba(255,255,255,.90) !important;
}

/* ---- Ghost buttons get glass too ---- */
.ab2-btn-ghost,
.ab2-how-cta-ghost,
.ab2-final-ghost {
  position: relative;
  background: rgba(255,255,255,.06) !important;
  border: 1.5px solid rgba(255,255,255,.40) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: background .2s ease, border-color .2s ease, transform .15s ease !important;
}
.ab2-btn-ghost:hover,
.ab2-how-cta-ghost:hover,
.ab2-final-ghost:hover {
  background: rgba(255,255,255,.15) !important;
  border-color: rgba(255,255,255,.85) !important;
  transform: translateY(-2px);
}

/* ---- FIX Smile Bigger / Final CTA: kill the broad `*` z-index rule that was wrapping everything ---- */
.ab2-final h2,
.ab2-final p,
.ab2-final .eyebrow,
.ab2-final .ab2-final-cta { position: relative; z-index: 1; }
/* Reset the dangerous .ab2-final * rule from v4 — let descendants have their own z-index */
.ab2-final * { z-index: auto; }
.ab2-final h2,
.ab2-final p,
.ab2-final .eyebrow,
.ab2-final .ab2-final-cta { z-index: 2 !important; }

/* Re-affirm Smile Bigger gradient (was already correct, but make sure nothing overrides it) */
section.ab2-final {
  background: linear-gradient(135deg, var(--ab2-ink,#1A1A1A) 0%, var(--ab2-ember,#FF5C39) 100%) !important;
}

/* ============================================================================
   UDSF AMBIENT BACKGROUND VIDEO
   A subtle full-page UDSF_BGC_1 video, fixed, very low opacity, sits behind
   all sections so semi-transparent (cream/peach) sections let it peek through.
   Sections with opaque backgrounds (ink, hero video, footer) block it naturally.
   ============================================================================ */
.udsf-ambient {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.udsf-ambient video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(.92) blur(1px);
  transform: scale(1.04);
  will-change: opacity;
}
/* Solo ambient (only one video) */
.udsf-ambient > video:only-child { opacity: .12; }
/* Crossfade pair: A and B alternate every 15s with a 5s overlap (30s cycle) */
.udsf-ambient .udsf-bg-a,
.udsf-ambient .udsf-bg-b {
  opacity: 0;
  animation: udsf-fade 30s ease-in-out infinite;
}
.udsf-ambient .udsf-bg-a { animation-delay: 0s; }
.udsf-ambient .udsf-bg-b { animation-delay: 15s; }
@keyframes udsf-fade {
  0%   { opacity: .28; }
  40%  { opacity: .28; }
  50%  { opacity: 0; }
  90%  { opacity: 0; }
  100% { opacity: .28; }
}
@media (prefers-reduced-motion: reduce) {
  .udsf-ambient .udsf-bg-a,
  .udsf-ambient .udsf-bg-b { animation: none; opacity: .20; }
}
/* Body needs a transparent layer on cream-ish sections so the video shows */
body.has-udsf-ambient { background: transparent; }

/* Make the cream-ish UNO sections semi-translucent so the video peeks through */
body.has-udsf-ambient .ab2-stories,
body.has-udsf-ambient .ab2-ins-wall,
body.has-udsf-ambient .ab2-faq,
body.has-udsf-ambient .ab2-visit,
body.has-udsf-ambient .ab2-meet,
body.has-udsf-ambient .ab2-smiles {
  background: transparent !important;
  position: relative;
}
body.has-udsf-ambient .ab2-stories::before,
body.has-udsf-ambient .ab2-ins-wall::before,
body.has-udsf-ambient .ab2-faq::before,
body.has-udsf-ambient .ab2-visit::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
body.has-udsf-ambient .ab2-stories::before {
  background:
    radial-gradient(45% 55% at 25% 30%, rgba(255,203,184,.50), transparent 65%),
    radial-gradient(50% 60% at 78% 72%, rgba(255,92,57,.10), transparent 65%),
    rgba(255,228,217,.80);
}
body.has-udsf-ambient .ab2-ins-wall::before,
body.has-udsf-ambient .ab2-faq::before,
body.has-udsf-ambient .ab2-visit::before {
  background:
    radial-gradient(45% 55% at 22% 22%, rgba(255,203,184,.32), transparent 65%),
    rgba(251,250,245,.76);
}

/* === SITEWIDE CTA UNIFICATION (v3.29) ============================
   Every NexHealth-pointing CTA with a primary/cta class collapses to
   one ember-ink gradient pill. Targets: .btn-primary, .btn.btn-primary,
   .cu-btn-primary, .pf-final-primary, .loc-cta-primary, .ab2-btn-primary
================================================================== */
a[href*="app.nexhealth.com/appt/unodental"].btn-primary,
a[href*="app.nexhealth.com/appt/unodental"].btn.btn-primary,
a[href*="app.nexhealth.com/appt/unodental"].cu-btn-primary,
a[href*="app.nexhealth.com/appt/unodental"].pf-final-primary,
a[href*="app.nexhealth.com/appt/unodental"].loc-cta-primary,
a[href*="app.nexhealth.com/appt/unodental"].ab2-btn-primary,
a[href*="app.nexhealth.com/appt/unodental"].btn.btn-dark.btn-arrow {
  background: linear-gradient(135deg, var(--ab2-ink, #1A1A1A) 0%, var(--ab2-ember, #FF5C39) 100%) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 14px 28px !important;
  font-family: 'Unbounded', 'Albert Sans', system-ui, sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  box-shadow: 0 12px 32px rgba(255,92,57,.28), 0 1px 0 rgba(255,255,255,.08) inset !important;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease !important;
}
a[href*="app.nexhealth.com/appt/unodental"].btn-primary:hover,
a[href*="app.nexhealth.com/appt/unodental"].btn.btn-primary:hover,
a[href*="app.nexhealth.com/appt/unodental"].cu-btn-primary:hover,
a[href*="app.nexhealth.com/appt/unodental"].pf-final-primary:hover,
a[href*="app.nexhealth.com/appt/unodental"].loc-cta-primary:hover,
a[href*="app.nexhealth.com/appt/unodental"].ab2-btn-primary:hover,
a[href*="app.nexhealth.com/appt/unodental"].btn.btn-dark.btn-arrow:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 18px 44px rgba(255,92,57,.40), 0 1px 0 rgba(255,255,255,.10) inset !important;
  filter: brightness(1.05) !important;
}

/* === SITEWIDE FOOTER UNIFICATION (v3.30) ============================
   Match homepage footer treatment everywhere — kill any per-page
   overrides that don't conform.
================================================================== */
html body footer{
  background:linear-gradient(135deg, #0B2226 0%, #102F33 50%, #1A4A52 100%) !important;
  color:#fff !important;
  padding:80px 0 40px !important;
  margin-bottom:0 !important;
}
html body footer h5{
  color:#fff !important;
  font-family:'Josefin Sans',sans-serif !important;
  font-weight:700 !important;
  text-transform:uppercase !important;
  letter-spacing:.16em !important;
  font-size:13px !important;
  margin-bottom:20px !important;
  opacity:1 !important;
  display:block !important;
  visibility:visible !important;
}
html body footer ul{
  list-style:none !important;
  padding:0 !important;
  margin:0 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:12px !important;
}
html body footer ul li{margin:0 !important;}
html body footer ul li a{
  color:rgba(255,255,255,.85) !important;
  font-size:14.5px !important;
  text-decoration:none !important;
  transition:color .15s ease !important;
}
html body footer ul li a:hover,
html body footer h5 a:hover{color:#FFCBB8 !important;}
html body footer .about{color:rgba(255,255,255,.72) !important;}
html body footer .foot-contact a{color:rgba(255,255,255,.85) !important;}
html body .ud-tm-disclaimer + footer{margin-top:0 !important;}
