/* ============================================================
   Apollonia Dental Arts — clean & modern theme
   Montserrat everywhere · brand color #94BCCD on white
   ============================================================ */

:root{
  color-scheme: light only;       /* stop browser/Chrome auto-dark inversion */

  --accent:#94BCCD;               /* brand color */
  --accent-d:#6fa3ba;             /* darker accent (gradients / hover) */
  --accent-l:#c2dbe5;
  --accent-text:#3a7d96;          /* accessible accent for small text/links */

  --blue-700:#2c6e86;             /* primary deep button */
  --blue-800:#225a6f;
  --navy:#173643;                 /* dark sections, footer, deep headings */
  --navy-d:#102832;

  --ink:#1d2c32;
  --ink-soft:#586a71;
  --muted:#8aa0a8;
  --line:#e4ecef;
  --tint:#e9f2f6;                 /* light chip / icon background */
  --tint-2:#f4f9fb;               /* section tint background */
  --white:#ffffff;
  --bg:#ffffff;
  --star:#e6a92b;

  --shadow-sm:0 4px 16px rgba(23,54,67,.06);
  --shadow:0 22px 54px -22px rgba(23,54,67,.30);
  --shadow-accent:0 16px 32px -12px rgba(111,163,186,.55);
  --radius:18px;
  --radius-lg:26px;
  --maxw:1180px;
  --font:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;color-scheme:light only}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* Force Montserrat on every text element (bulletproof) */
h1,h2,h3,h4,h5,h6,p,a,span,li,div,button,input,select,textarea,
blockquote,figcaption,label,strong,em,small{font-family:var(--font)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.15;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

.ico{width:22px;height:22px;flex:0 0 auto}
.ico--sm{width:16px;height:16px}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--blue-700);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:13px 26px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease,border-color .25s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
/* primary = the brand color */
.btn--gold{background:linear-gradient(135deg,var(--accent),var(--accent-d));color:var(--navy);box-shadow:var(--shadow-accent)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 20px 40px -12px rgba(111,163,186,.7)}
.btn--teal{background:var(--blue-700);color:#fff}
.btn--teal:hover{background:var(--blue-800);transform:translateY(-2px)}
.btn--ghost{background:transparent;border-color:var(--blue-700);color:var(--blue-700)}
.btn--ghost:hover{background:var(--blue-700);color:#fff}
.btn--light{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.45)}
.btn--light:hover{background:#fff;color:var(--blue-700)}
.btn--outline{background:transparent;border-color:var(--line);color:var(--ink)}
.btn--outline:hover{border-color:var(--accent);color:var(--blue-700)}
.btn--lg{padding:16px 34px;font-size:1.02rem}

/* ---------- Topbar ---------- */
.topbar{background:var(--navy);color:#cfe0e6;font-size:.82rem;font-weight:500}
.topbar__inner{display:flex;align-items:center;gap:14px;height:40px}
.topbar__item{display:inline-flex;align-items:center;gap:6px;color:#cfe0e6}
.topbar__item strong{color:var(--accent)}
.topbar a.topbar__item:hover{color:#fff}
.topbar__sep{opacity:.4}
.topbar__spacer{flex:1}
@media(max-width:720px){.topbar__item--hide,.topbar__sep{display:none}}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s,background .3s}
.header.is-scrolled{box-shadow:var(--shadow-sm);background:rgba(255,255,255,.97)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{display:inline-flex;align-items:center;gap:12px}
.brand__mark{
  width:44px;height:44px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(140deg,var(--accent),var(--blue-700));
  color:#fff;font-weight:800;font-size:1.5rem;font-family:var(--font);
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.25);
}
.brand__text{display:flex;flex-direction:column;line-height:1.04}
.brand__name{font-weight:800;font-size:1.18rem;letter-spacing:-.02em;color:var(--navy)}
.brand__sub{font-weight:600;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent-text)}

.nav{display:flex;align-items:center;gap:6px}
.nav__link{font-weight:600;font-size:.93rem;color:var(--ink-soft);padding:9px 14px;border-radius:999px;position:relative;transition:color .2s,background .2s}
.nav__link:hover{color:var(--blue-700)}
.nav__link.is-active{color:var(--blue-700)}
.nav__link.is-active::after{content:"";position:absolute;left:14px;right:14px;bottom:2px;height:2px;background:var(--accent);border-radius:2px}
.nav__cta{margin-left:8px;padding:11px 22px}
.nav__close{display:none}
.header__actions{display:flex;align-items:center;gap:10px}
.header__call{display:none}
.nav__toggle,.nav__close{background:none;border:none;color:var(--navy);cursor:pointer;padding:6px;display:none}
.nav__toggle .ico{width:26px;height:26px}

@media(max-width:980px){
  .nav__cta{display:none}
  .header__call{display:inline-flex}
  .nav__toggle{display:inline-flex}
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:#fff;
    flex-direction:column;align-items:stretch;gap:4px;padding:90px 26px 40px;
    transform:translateX(105%);transition:transform .35s cubic-bezier(.5,0,.2,1);
    box-shadow:-20px 0 60px -20px rgba(23,54,67,.4);z-index:120;
  }
  .nav.is-open{transform:translateX(0)}
  .nav__link{font-size:1.08rem;padding:14px 12px;border-bottom:1px solid var(--line)}
  .nav__link.is-active::after{display:none}
  .nav__cta{display:inline-flex;margin:18px 0 0}
  .nav__close{display:inline-flex;position:absolute;top:22px;right:22px}
  body.nav-open{overflow:hidden}
  .nav-scrim{position:fixed;inset:0;background:rgba(23,54,67,.45);opacity:0;visibility:hidden;transition:.35s;z-index:110}
  .nav-scrim.is-open{opacity:1;visibility:visible}
}

/* ---------- Section primitives ---------- */
.section{padding:96px 0}
.section--tint{background:var(--tint-2)}
.section--teal{background:linear-gradient(160deg,var(--navy),var(--navy-d));color:#dbe8ed}
.section__head{max-width:680px;margin:0 auto 56px;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-text);margin-bottom:14px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent);border-radius:2px}
.eyebrow--center{justify-content:center}
.section__title{font-size:clamp(1.9rem,3.6vw,2.85rem);font-weight:800}
.section--teal .section__title{color:#fff}
.section__sub{margin-top:16px;color:var(--ink-soft);font-size:1.05rem}
.section--teal .section__sub{color:#a9c6cf}

/* ---------- Hero (light) ---------- */
.hero{position:relative;background:linear-gradient(180deg,#eef6f9 0%,#f7fbfc 55%,#ffffff 100%);color:var(--ink);overflow:hidden;padding:84px 0 96px}
.hero::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 59h60M59 0v60' stroke='%23173643' stroke-opacity='0.035' stroke-width='1'/%3E%3C/svg%3E");pointer-events:none}
.hero__glow{position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(148,188,205,.55),transparent 65%);top:-180px;right:-120px;filter:blur(8px)}
.hero__inner{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center}
.hero__pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--accent-l);color:var(--blue-700);font-weight:600;font-size:.8rem;letter-spacing:.02em;padding:8px 16px;border-radius:999px;margin-bottom:24px;box-shadow:var(--shadow-sm)}
.hero__pill strong,.hero__pill{color:var(--blue-700)}
.hero__title{font-size:clamp(2.4rem,5vw,3.85rem);font-weight:800;line-height:1.06;color:var(--navy);letter-spacing:-.03em}
.hero__title em{font-style:italic;font-weight:600;color:var(--accent-text)}
.hero__text{margin:22px 0 32px;font-size:1.12rem;color:var(--ink-soft);max-width:520px}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.hero__trust{display:flex;gap:30px;margin-top:40px;flex-wrap:wrap}
.hero__trust div{display:flex;flex-direction:column}
.hero__trust b{font-size:1.6rem;font-weight:800;color:var(--navy);line-height:1}
.hero__trust span{font-size:.82rem;color:var(--ink-soft);margin-top:5px}

.hero__visual{position:relative}
.hero__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow);color:var(--ink);position:relative}
.hero__smile{height:220px;border-radius:18px;background:linear-gradient(135deg,var(--accent-l),var(--accent));display:grid;place-items:center;overflow:hidden;position:relative}
.hero__smile svg{width:120px;height:120px;color:#fff;opacity:.95}
.hero__smile::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(255,255,255,.35),transparent 60%)}
.hero__cardrow{display:flex;align-items:center;gap:14px;margin-top:22px}
.hero__avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(140deg,var(--accent),var(--blue-700));color:#fff;font-weight:800;display:grid;place-items:center;font-size:1.1rem}
.hero__cardrow h4{font-size:1rem;margin-bottom:2px;color:var(--navy)}
.hero__cardrow p{font-size:.82rem;color:var(--ink-soft)}
.hero__stars{margin-left:auto;color:var(--star);font-weight:700;font-size:.9rem;white-space:nowrap}
.hero__floating{position:absolute;left:-26px;bottom:30px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;font-weight:600;font-size:.85rem;color:var(--navy)}
.hero__floating .ico{color:var(--accent-text)}

@media(max-width:880px){
  .hero{padding:60px 0 72px}
  .hero__inner{grid-template-columns:1fr;gap:44px}
  .hero__visual{max-width:440px}
  .hero__floating{left:0}
}

/* ---------- Badges row ---------- */
.badges{background:var(--white);margin-top:-46px;position:relative;z-index:5;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:10px;border:1px solid var(--line)}
.badges__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.badge{display:flex;align-items:center;gap:14px;padding:22px 24px;border-right:1px solid var(--line)}
.badge:last-child{border-right:none}
.badge__ico{width:48px;height:48px;border-radius:14px;background:var(--tint);color:var(--blue-700);display:grid;place-items:center;flex:0 0 auto}
.badge h4{font-size:.97rem;font-weight:700;color:var(--navy)}
.badge p{font-size:.82rem;color:var(--ink-soft)}
@media(max-width:860px){.badges__grid{grid-template-columns:repeat(2,1fr)}.badge:nth-child(2){border-right:none}.badge:nth-child(1),.badge:nth-child(2){border-bottom:1px solid var(--line)}}
@media(max-width:520px){.badges__grid{grid-template-columns:1fr}.badge{border-right:none;border-bottom:1px solid var(--line)}.badge:last-child{border-bottom:none}}

/* ---------- Services / cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px;transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--accent),var(--blue-700));transform:scaleX(0);transform-origin:left;transition:transform .35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card__ico{width:58px;height:58px;border-radius:16px;background:var(--tint);color:var(--blue-700);display:grid;place-items:center;margin-bottom:20px;transition:background .3s,color .3s}
.card:hover .card__ico{background:linear-gradient(140deg,var(--accent),var(--blue-700));color:#fff}
.card__ico .ico{width:28px;height:28px}
.card h3{font-size:1.16rem;margin-bottom:10px;color:var(--navy)}
.card p{color:var(--ink-soft);font-size:.94rem}
.card__link{margin-top:16px;display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:.88rem;color:var(--blue-700)}
.card__link .ico{transition:transform .25s}
.card:hover .card__link .ico{transform:translateX(4px)}
@media(max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards{grid-template-columns:1fr}}

/* ---------- Split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split--reverse .split__media{order:2}
.split__media{position:relative}
.split__photo{aspect-ratio:4/5;border-radius:var(--radius-lg);background:linear-gradient(155deg,var(--accent),var(--blue-700));display:grid;place-items:center;overflow:hidden;box-shadow:var(--shadow);position:relative}
.split__photo svg{width:96px;height:96px;color:rgba(255,255,255,.9)}
.split__photo .monogram{font-size:7rem;font-weight:800;color:rgba(255,255,255,.55);font-family:var(--font)}
.split__badge{position:absolute;right:-22px;bottom:34px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 22px;box-shadow:var(--shadow);text-align:center}
.split__badge b{display:block;font-size:1.9rem;font-weight:800;color:var(--blue-700);line-height:1}
.split__badge span{font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.split__title{font-size:clamp(1.7rem,3.2vw,2.5rem);font-weight:800;margin:14px 0 18px;color:var(--navy)}
.split p{color:var(--ink-soft);margin-bottom:16px}
.checklist{list-style:none;display:grid;gap:12px;margin:22px 0 28px}
.checklist li{display:flex;align-items:flex-start;gap:12px;font-weight:500;color:var(--ink)}
.checklist .ico{color:var(--accent-text);margin-top:3px}
@media(max-width:840px){.split{grid-template-columns:1fr;gap:40px}.split--reverse .split__media{order:0}.split__media{max-width:420px}.split__badge{right:10px}}

/* ---------- Why / features (dark band) ---------- */
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat__item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:28px}
.section--teal .feat__item h3{color:#fff;font-size:1.1rem;margin-bottom:8px}
.section--teal .feat__item p{color:#a9c6cf;font-size:.92rem}
.feat__ico{width:52px;height:52px;border-radius:14px;background:rgba(148,188,205,.2);color:var(--accent);display:grid;place-items:center;margin-bottom:18px}
@media(max-width:860px){.feat{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.feat{grid-template-columns:1fr}}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.member{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s}
.member:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.member__photo{aspect-ratio:1;background:linear-gradient(150deg,var(--accent-l),var(--accent));display:grid;place-items:center;position:relative}
.member__photo .mono{width:84px;height:84px;border-radius:50%;background:#fff;color:var(--blue-700);display:grid;place-items:center;font-weight:800;font-size:1.7rem;box-shadow:var(--shadow-sm)}
.member__body{padding:20px}
.member__body h3{font-size:1.08rem;color:var(--navy)}
.member__role{color:var(--accent-text);font-weight:600;font-size:.82rem;margin:4px 0 12px}
.member__bio{color:var(--ink-soft);font-size:.9rem}
@media(max-width:960px){.team{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.team{grid-template-columns:1fr}}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;position:relative;transition:transform .3s,box-shadow .3s}
.quote:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.quote__mark{color:var(--accent);opacity:.55;width:38px;height:38px;margin-bottom:6px}
.quote__stars{color:var(--star);letter-spacing:2px;font-size:.85rem;margin-bottom:12px}
.quote p{color:var(--ink);font-size:.97rem;font-style:italic;margin-bottom:18px}
.quote__by{display:flex;align-items:center;gap:12px}
.quote__av{width:42px;height:42px;border-radius:50%;background:var(--tint);color:var(--blue-700);display:grid;place-items:center;font-weight:700;font-size:.9rem}
.quote__by b{font-size:.92rem;color:var(--navy)}
.quote__by span{font-size:.78rem;color:var(--ink-soft);display:block}
@media(max-width:900px){.quotes{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.quotes{grid-template-columns:1fr}}

/* ---------- Stats strip (in dark band) ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat b{display:block;font-size:clamp(2rem,4vw,2.8rem);font-weight:800;color:var(--accent);line-height:1}
.stat span{font-size:.86rem;color:#a9c6cf;margin-top:8px;display:block;font-weight:500}
@media(max-width:620px){.stats{grid-template-columns:1fr 1fr;gap:32px 20px}}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;display:grid;gap:14px}
.faq__item{background:var(--white);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:box-shadow .3s,border-color .3s}
.faq__item.is-open{box-shadow:var(--shadow-sm);border-color:var(--accent)}
.faq__q{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--font);font-weight:600;font-size:1.02rem;color:var(--navy);padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.faq__q .ico{color:var(--blue-700);transition:transform .3s;flex:0 0 auto}
.faq__item.is-open .faq__q .ico{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--ink-soft)}
.faq__a p{padding:0 24px 22px;font-size:.96rem}

/* ---------- CTA band (brand color) ---------- */
.ctaband{background:linear-gradient(120deg,var(--accent),var(--accent-d));padding:64px 0}
.ctaband__inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.ctaband__eyebrow{font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.76rem;color:#0f3744}
.ctaband__title{font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:800;color:var(--navy);margin:8px 0 6px}
.ctaband__text{color:#1c4250;font-weight:500}
.ctaband__actions{display:flex;gap:14px;flex-wrap:wrap}
.ctaband .btn--gold{background:var(--navy);color:#fff;box-shadow:0 14px 30px -12px rgba(16,40,50,.6)}
.ctaband .btn--gold:hover{background:var(--navy-d)}
.ctaband .btn--light{background:rgba(255,255,255,.9);color:var(--navy);border-color:transparent}
.ctaband .btn--light:hover{background:#fff}

/* ---------- Footer ---------- */
.footer{background:linear-gradient(160deg,var(--navy),var(--navy-d));color:#a9c6cf;padding:64px 0 0}
.brand--footer .brand__name{color:#fff}
.brand--footer .brand__sub{color:var(--accent)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.footer__tag{font-style:italic;color:var(--accent);margin:16px 0 8px;font-size:1.02rem;font-weight:500}
.footer__blurb{font-size:.9rem;color:#8fb1bb;max-width:300px}
.footer__rating{margin-top:14px;display:flex;align-items:center;gap:7px;font-size:.88rem}
.footer__rating .ico{color:var(--star)}
.footer__rating strong{color:#fff}
.footer__head{color:#fff;font-size:.86rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:7px}
.footer__head .ico{color:var(--accent)}
.footer__link{display:block;color:#a9c6cf;font-size:.92rem;padding:5px 0;transition:color .2s,padding .2s}
.footer__link:hover{color:var(--accent);padding-left:4px}
.footer__line{font-size:.9rem;color:#8fb1bb;margin-bottom:8px}
.footer__bar{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding:22px 0}
.footer__bar-inner{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem;color:#7fa3ad}
.footer__credit a{color:var(--accent)}
@media(max-width:840px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.locs{display:grid;gap:20px}
.loc{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.loc h3{display:flex;align-items:center;gap:9px;font-size:1.18rem;margin-bottom:6px;color:var(--navy)}
.loc h3 .ico{color:var(--accent-text)}
.loc__addr{color:var(--ink-soft);font-size:.94rem;margin-bottom:14px}
.loc__phone{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--blue-700);margin-bottom:16px}
.hours{display:grid;gap:6px;font-size:.88rem;border-top:1px dashed var(--line);padding-top:14px}
.hours__row{display:flex;justify-content:space-between}
.hours__row span:first-child{color:var(--ink-soft)}
.hours__row span:last-child{font-weight:600;color:var(--ink)}
.hours__row.is-closed span:last-child{color:#b15858}
.loc__dir{margin-top:14px;display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:.86rem;color:var(--blue-700)}

.formcard{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow-sm)}
.formcard h2{font-size:1.5rem;margin-bottom:6px;color:var(--navy)}
.formcard__sub{color:var(--ink-soft);font-size:.94rem;margin-bottom:24px}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.84rem;margin-bottom:7px;color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--font);font-size:.95rem;padding:13px 15px;border:1.5px solid var(--line);
  border-radius:11px;background:var(--tint-2);color:var(--ink);transition:border-color .2s,box-shadow .2s,background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--tint);background:#fff}
.field textarea{resize:vertical;min-height:110px}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.formnote{font-size:.8rem;color:var(--ink-soft);margin-top:6px}
.alert{padding:14px 18px;border-radius:12px;font-size:.92rem;font-weight:500;margin-bottom:22px;display:flex;align-items:center;gap:10px}
.alert--ok{background:var(--tint);color:var(--blue-800)}
.alert--err{background:#fbe7e7;color:#a23a3a}
@media(max-width:840px){.contact{grid-template-columns:1fr}.field--row{grid-template-columns:1fr}}

/* ---------- Page hero (inner pages) ---------- */
.pagehero{background:linear-gradient(160deg,var(--navy),var(--navy-d));color:#eaf3f6;padding:64px 0 70px;text-align:center;position:relative;overflow:hidden}
.pagehero .hero__glow{top:-200px;right:-120px;background:radial-gradient(circle,rgba(148,188,205,.4),transparent 65%)}
.pagehero .eyebrow{color:var(--accent)}
.pagehero .eyebrow::before{background:var(--accent)}
.pagehero h1{font-size:clamp(2rem,4.4vw,3.1rem);font-weight:800;color:#fff;position:relative}
.pagehero p{color:#bcd6dd;max-width:600px;margin:14px auto 0;position:relative}
.crumbs{position:relative;font-size:.82rem;color:#8fb1bb;margin-top:18px}
.crumbs a:hover{color:var(--accent)}

/* ============================================================
   Imagery components (added v4)
   ============================================================ */

/* Hero photo + floating chips */
.hero__imgwrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5;border:6px solid #fff}
.hero__img{width:100%;height:100%;object-fit:cover}
.hero__chip{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:12px 16px;display:flex;align-items:center;gap:11px}
.hero__chip h4{font-size:.92rem;color:var(--navy);margin-bottom:1px}
.hero__chip p{font-size:.76rem;color:var(--ink-soft)}
.hero__chip .hero__stars{color:var(--star);font-size:.78rem;margin:0}
.hero__chip--rating{left:-28px;bottom:72px}
.hero__chip--badge{right:-16px;top:38px;font-weight:600;font-size:.85rem;color:var(--navy)}
.hero__chip--badge .ico{color:var(--accent-text)}
@media(max-width:880px){.hero__chip--rating{left:0}.hero__chip--badge{right:0}}
@media(max-width:420px){.hero__chip--rating{bottom:8px;padding:9px 12px}.hero__chip--rating h4{font-size:.82rem}}

/* Photo inside split / member tiles */
.split__photo--img{padding:0;background:none}
.split__photo--img img{width:100%;height:100%;object-fit:cover}
.member__photo--img{padding:0}
.member__photo--img img{width:100%;height:100%;object-fit:cover}

/* Before / After slider */
.ba{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow);background:var(--tint);touch-action:pan-y}
.ba--teaser{aspect-ratio:4/5}
.ba__after,.ba__before{position:absolute;top:0;left:0;height:100%}
.ba__after{width:100%}
.ba__after img,.ba__before img{height:100%;width:100%;object-fit:cover;display:block}
.ba__before{width:50%;overflow:hidden;border-right:3px solid #fff}
.ba__before img{width:100%} /* JS sets px width = container width to keep alignment */
.ba__before-img{filter:saturate(.62) brightness(.9) contrast(.96) sepia(.4)}
.ba__range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize}
.ba__handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;box-shadow:0 6px 18px rgba(16,40,50,.3);display:grid;place-items:center;color:var(--blue-700);pointer-events:none;z-index:3}
.ba__handle .ico{width:20px;height:20px}
.ba__handle::before{content:"";position:absolute;right:100%;margin-right:8px;width:8px;height:8px;border-top:2px solid #fff;border-left:2px solid #fff;transform:rotate(-45deg);opacity:0}
.ba__tag{position:absolute;bottom:14px;padding:5px 12px;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#fff;z-index:2}
.ba__tag--before{left:14px;background:rgba(23,54,67,.72)}
.ba__tag--after{right:14px;background:rgba(111,163,186,.92)}

.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.ba-case__cap{padding-top:18px}
.ba-case__cap h3{font-size:1.12rem;color:var(--navy);margin-bottom:6px}
.ba-case__cap p{color:var(--ink-soft);font-size:.92rem}
.ba-note{text-align:center;margin-top:34px;color:var(--ink-soft);font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:8px}
.ba-note .ico{color:var(--accent-text)}
@media(max-width:900px){.ba-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.ba-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}}

/* Masonry gallery */
.masonry{column-count:3;column-gap:18px}
.masonry__item{break-inside:avoid;margin:0 0 18px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.masonry__item img{width:100%;display:block;transition:transform .5s ease}
.masonry__item:hover img{transform:scale(1.06)}
@media(max-width:860px){.masonry{column-count:2}}
@media(max-width:520px){.masonry{column-count:1}}

/* Featured testimonial */
.feature-quote{display:grid;grid-template-columns:.85fr 1.15fr;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.feature-quote__media img{width:100%;height:100%;object-fit:cover;min-height:340px}
.feature-quote__body{padding:44px}
.feature-quote__mark{color:var(--accent);width:46px;height:46px;opacity:.55;margin-bottom:6px}
.feature-quote__text{font-size:1.22rem;line-height:1.6;color:var(--ink);font-style:italic;margin:8px 0 22px}
@media(max-width:760px){.feature-quote{grid-template-columns:1fr}.feature-quote__media img{min-height:240px}.feature-quote__body{padding:30px}.feature-quote__text{font-size:1.08rem}}

/* ---------- Reveal animation ----------
   Content is VISIBLE by default. It only starts hidden when JS is active
   (html.js), so a JS hiccup can never blank the page. */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.is-in{opacity:1;transform:none}
.js .reveal[data-d="1"]{transition-delay:.08s}
.js .reveal[data-d="2"]{transition-delay:.16s}
.js .reveal[data-d="3"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
