/* ===========================================================
   Mount Zion Dental — premium preview
   Warm spa palette extracted from live site
   =========================================================== */
:root{
  --espresso:#2a2623;
  --bark:#4a4036;
  --taupe:#8a8074;
  --taupe-soft:#a79e92;
  --caramel:#b38560;
  --bronze:#9b6a3b;
  --bronze-deep:#855a30;
  --cream:#fbfaf7;
  --sand:#f2eee9;
  --linen:#f7f2e6;
  --dune:#ede6da;
  --navy:#143c6c;
  --leaf:#7dc445;
  --white:#ffffff;
  --line:rgba(42,38,35,.10);
  --line-soft:rgba(42,38,35,.06);
  --shadow-sm:0 1px 2px rgba(42,38,35,.06), 0 4px 14px rgba(42,38,35,.05);
  --shadow-md:0 10px 30px rgba(42,38,35,.08), 0 2px 8px rgba(42,38,35,.05);
  --shadow-lg:0 30px 70px rgba(42,38,35,.16), 0 8px 24px rgba(42,38,35,.08);
  --radius:18px;
  --radius-lg:26px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--espresso);
  background:var(--cream);line-height:1.65;font-size:17px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;
  letter-spacing:-.01em;color:var(--espresso);margin:0}
p{margin:0}
::selection{background:var(--caramel);color:#fff}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.section{padding:clamp(64px,9vw,128px) 0}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--sans);font-weight:600;font-size:12.5px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--bronze);
  margin:0 0 18px;
}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;
  background:var(--leaf);box-shadow:0 0 0 4px rgba(125,196,69,.16)}
.eyebrow.center{justify-content:center}
.lead{font-size:clamp(19px,2.1vw,22px);color:var(--bark);line-height:1.6}
.muted{color:var(--taupe)}
.center{text-align:center}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:15.5px;letter-spacing:.005em;
  padding:15px 26px;border-radius:100px;border:1px solid transparent;
  cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .25s,color .25s;
  white-space:nowrap;line-height:1}
.btn svg{width:18px;height:18px;flex:none}
.btn-primary{background:var(--caramel);color:#fff;
  box-shadow:0 10px 24px rgba(155,106,59,.30)}
.btn-primary:hover{background:var(--bronze);transform:translateY(-2px);
  box-shadow:0 16px 34px rgba(155,106,59,.38)}
.btn-ghost{background:transparent;color:var(--espresso);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--caramel);color:var(--bronze);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--espresso);box-shadow:var(--shadow-sm)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--bronze)}
.btn-block{width:100%}

/* ===== Announcement bar ===== */
.topbar{background:var(--espresso);color:#f3ede3;font-size:13.5px}
.topbar .wrap{display:flex;align-items:center;justify-content:center;gap:26px;
  min-height:42px;flex-wrap:wrap;padding-top:7px;padding-bottom:7px}
.topbar a{color:#f3ede3}
.topbar .ti{display:inline-flex;align-items:center;gap:8px;opacity:.92}
.topbar .ti svg{width:15px;height:15px;color:var(--leaf)}
.topbar .dot{width:4px;height:4px;border-radius:50%;background:rgba(243,237,227,.4)}
@media(max-width:760px){.topbar .ti.hide-sm{display:none}.topbar .dot.hide-sm{display:none}}

/* ===== Header ===== */
.header{position:sticky;top:0;z-index:60;
  background:rgba(251,250,247,.82);backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s, box-shadow .3s, background .3s}
.header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(42,38,35,.05)}
.nav{display:flex;align-items:center;gap:26px;min-height:74px}
.brand{display:flex;align-items:center;flex:none}
.brand img{height:42px;width:auto}
.nav-links{display:flex;align-items:center;gap:32px;margin-left:14px}
.nav-links a{font-weight:500;font-size:15px;color:var(--bark);position:relative;
  padding:6px 0;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--caramel);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--espresso)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:14px;margin-left:auto}

/* language toggle */
.lang{display:inline-flex;align-items:center;background:var(--sand);
  border:1px solid var(--line);border-radius:100px;padding:3px;position:relative}
.lang button{font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.04em;
  border:0;background:transparent;color:var(--taupe);cursor:pointer;
  padding:6px 13px;border-radius:100px;position:relative;z-index:1;transition:color .25s}
.lang button.active{color:#fff}
.lang .glider{position:absolute;top:3px;bottom:3px;width:calc(50% - 3px);
  background:var(--caramel);border-radius:100px;transition:transform .3s var(--ease);
  box-shadow:0 4px 10px rgba(155,106,59,.3)}
.lang[data-lang="es"] .glider{transform:translateX(100%)}

.menu-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);
  background:#fff;border-radius:12px;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle svg{width:22px;height:22px;color:var(--espresso)}
.nav-cta-phone{color:var(--bark);font-weight:600;font-size:15px;display:inline-flex;
  align-items:center;gap:8px}
.nav-cta-phone svg{width:17px;height:17px;color:var(--caramel)}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(1100px 620px at 84% -8%, rgba(179,133,96,.16), transparent 60%),
    radial-gradient(800px 500px at -5% 30%, rgba(237,230,218,.6), transparent 55%),
    var(--cream)}
.hero-grid{display:grid;grid-template-columns:1.02fr 1fr;gap:clamp(30px,5vw,72px);
  align-items:center;padding:clamp(48px,7vw,92px) 0 clamp(56px,7vw,96px)}
.hero h1{font-size:clamp(40px,6vw,68px);letter-spacing:-.02em;margin:0 0 22px}
.hero h1 em{font-style:italic;color:var(--bronze)}
.hero .sub{font-size:clamp(18px,2vw,21px);color:var(--bark);max-width:30em;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero-proof{display:flex;align-items:center;gap:12px;color:var(--taupe);font-size:14.5px}
.hero-proof svg{width:18px;height:18px;color:var(--caramel);flex:none}
.hero-chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:26px}
.chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);
  border-radius:100px;padding:8px 15px;font-size:13.5px;font-weight:500;color:var(--bark);
  box-shadow:var(--shadow-sm)}
.chip svg{width:15px;height:15px;color:var(--caramel)}

/* hero media */
.hero-media{position:relative}
.hero-photo{position:relative;border-radius:240px 240px 26px 26px;overflow:hidden;
  aspect-ratio:4/4.6;box-shadow:var(--shadow-lg);background:var(--dune)}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(42,38,35,.12))}
.hero-float{position:absolute;left:-22px;bottom:34px;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border:1px solid var(--line-soft);border-radius:16px;
  padding:13px 17px 13px 13px;display:flex;align-items:center;gap:13px;
  box-shadow:var(--shadow-md);max-width:270px}
.hero-float img{width:50px;height:50px;border-radius:12px;object-fit:cover;object-position:50% 26%;flex:none}
.hero-float .hf-name{font-family:var(--serif);font-size:16px;font-weight:600;line-height:1.15}
.hero-float .hf-sub{font-size:12px;color:var(--taupe);margin-top:2px}
.hero-badge{position:absolute;top:24px;right:-10px;background:var(--espresso);color:#fff;
  border-radius:100px;padding:9px 16px;font-size:13px;font-weight:600;letter-spacing:.02em;
  box-shadow:var(--shadow-md);display:inline-flex;align-items:center;gap:8px}
.hero-badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--leaf);
  box-shadow:0 0 0 0 rgba(125,196,69,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(125,196,69,.5)}70%{box-shadow:0 0 0 9px rgba(125,196,69,0)}100%{box-shadow:0 0 0 0 rgba(125,196,69,0)}}

/* ===== Trust strip ===== */
.trust{background:var(--espresso);color:#efe8dd}
.trust .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;
  flex-wrap:wrap;padding-top:26px;padding-bottom:26px}
.trust-item{display:flex;align-items:center;gap:11px;font-size:14.5px;font-weight:500}
.trust-item svg{width:21px;height:21px;color:var(--leaf);flex:none}
.trust-item b{font-family:var(--serif);font-weight:600;font-size:17px;color:#fff}
.trust-sep{width:1px;height:30px;background:rgba(239,232,221,.18)}
@media(max-width:900px){.trust-sep{display:none}.trust .wrap{gap:18px 26px}}

/* ===== Section heads ===== */
.shead{max-width:680px;margin:0 0 52px}
.shead.center{margin-left:auto;margin-right:auto;text-align:center}
.shead h2{font-size:clamp(30px,4.2vw,46px);margin-bottom:16px}
.shead p{font-size:18px;color:var(--taupe)}

/* ===== Approach (split) ===== */
.approach{background:var(--cream)}
.split{display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(34px,5vw,76px);align-items:center}
.split.reverse{grid-template-columns:1.04fr 1fr}
.approach-photo{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:5/4.2;
  box-shadow:var(--shadow-lg);background:var(--dune);position:relative}
.approach-photo img{width:100%;height:100%;object-fit:cover}
.values{list-style:none;padding:0;margin:30px 0 0;display:grid;gap:18px}
.values li{display:flex;gap:15px;align-items:flex-start}
.values .vi{flex:none;width:42px;height:42px;border-radius:12px;background:var(--linen);
  display:flex;align-items:center;justify-content:center;border:1px solid var(--line-soft)}
.values .vi svg{width:21px;height:21px;color:var(--bronze)}
.values h4{font-size:17.5px;font-family:var(--sans);font-weight:700;margin-bottom:2px;letter-spacing:0}
.values p{font-size:15px;color:var(--taupe);line-height:1.55}

/* ===== Services ===== */
.services{background:linear-gradient(180deg,var(--sand),var(--linen))}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:30px 28px 28px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .3s}
.svc-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--caramel),var(--bronze));transition:width .45s var(--ease)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--line)}
.svc-card:hover::before{width:100%}
.svc-ic{width:54px;height:54px;border-radius:15px;background:var(--linen);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
  border:1px solid var(--line-soft);transition:background .3s}
.svc-card:hover .svc-ic{background:#f0e3d6}
.svc-ic svg{width:27px;height:27px;color:var(--bronze)}
.svc-card h3{font-size:22px;margin-bottom:9px}
.svc-card p{font-size:15px;color:var(--taupe);line-height:1.6}
.svc-more{margin-top:34px;text-align:center;font-size:15.5px;color:var(--bark)}
.svc-more b{font-weight:600;color:var(--espresso)}

/* ===== Smile band ===== */
.smile{position:relative;overflow:hidden;
  background:linear-gradient(120deg,var(--bronze) 0%, var(--caramel) 60%, #c79a73 100%);
  color:#fff}
.smile .wrap{position:relative;z-index:2}
.smile-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,64px);align-items:center}
.smile .eyebrow{color:#ffe9d6}.smile .eyebrow::before{background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.2)}
.smile h2{color:#fff;font-size:clamp(30px,4.4vw,50px);margin-bottom:18px}
.smile p{color:rgba(255,255,255,.92);font-size:19px;max-width:30em;margin-bottom:30px}
.smile-photo{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;
  box-shadow:0 30px 70px rgba(75,45,20,.4);border:5px solid rgba(255,255,255,.18)}
.smile-photo img{width:100%;height:100%;object-fit:cover}
.smile::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;
  border-radius:50%;background:rgba(255,255,255,.10)}

/* ===== About Dr. Cook ===== */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(34px,5vw,72px);align-items:center}
.about-photo{position:relative;border-radius:26px 26px 26px 120px;overflow:hidden;
  aspect-ratio:4/4.7;box-shadow:var(--shadow-lg);background:var(--dune)}
.about-photo img{width:100%;height:100%;object-fit:cover;object-position:60% center}
.about-quote{position:absolute;left:18px;right:18px;bottom:18px;background:rgba(255,255,255,.94);
  backdrop-filter:blur(6px);border-radius:16px;padding:17px 20px;box-shadow:var(--shadow-md)}
.about-quote p{font-family:var(--serif);font-style:italic;font-size:16.5px;line-height:1.45;color:var(--bark)}
.about-lead{font-size:clamp(19px,2.1vw,23px);font-family:var(--serif);color:var(--bark);
  line-height:1.5;margin:8px 0 18px}
.about-body{font-size:16.5px;color:var(--taupe);line-height:1.72;margin-bottom:24px}
.creds{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.cred{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:10px 15px;font-size:13.5px;font-weight:600;color:var(--bark);
  box-shadow:var(--shadow-sm)}
.cred svg{width:16px;height:16px;color:var(--bronze)}

/* ===== Specials / What's new ===== */
.news{background:var(--espresso);color:#f3ede3;position:relative;overflow:hidden}
.news::before{content:"";position:absolute;left:-140px;bottom:-140px;width:380px;height:380px;
  border-radius:50%;background:radial-gradient(circle,rgba(179,133,96,.35),transparent 70%)}
.news .eyebrow{color:#e9bf98}.news h2{color:#fff}
.news .shead p{color:rgba(243,237,227,.7)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:2}
.news-card{background:rgba(255,255,255,.045);border:1px solid rgba(243,237,227,.14);
  border-radius:var(--radius);padding:26px 24px;transition:transform .4s var(--ease),background .3s}
.news-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.07)}
.news-tag{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;
  letter-spacing:.13em;text-transform:uppercase;color:var(--leaf);margin-bottom:14px}
.news-tag .nd{width:6px;height:6px;border-radius:50%;background:var(--leaf)}
.news-card h3{color:#fff;font-size:20px;margin-bottom:8px}
.news-card p{color:rgba(243,237,227,.72);font-size:14.5px;line-height:1.6}

/* ===== Testimonials ===== */
.testi{background:linear-gradient(180deg,var(--linen),var(--sand))}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.testi-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.quote-mark{font-family:var(--serif);font-size:54px;line-height:.6;color:var(--caramel);
  opacity:.5;height:30px}
.testi-card p{font-size:16px;color:var(--bark);line-height:1.62;margin:8px 0 22px;flex:1}
.testi-by{display:flex;align-items:center;gap:13px;border-top:1px solid var(--line-soft);padding-top:18px}
.testi-av{width:44px;height:44px;border-radius:50%;flex:none;display:flex;align-items:center;
  justify-content:center;font-family:var(--serif);font-weight:600;font-size:18px;color:#fff;
  background:linear-gradient(135deg,var(--caramel),var(--bronze))}
.testi-name{font-weight:700;font-size:15px}
.testi-role{font-size:13px;color:var(--taupe)}

/* ===== Visit / contact ===== */
.visit{background:var(--cream)}
.visit-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,64px);align-items:stretch}
.visit-info{display:flex;flex-direction:column;gap:20px}
.info-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:24px 26px;box-shadow:var(--shadow-sm);display:flex;gap:16px;align-items:flex-start}
.info-card .ii{flex:none;width:46px;height:46px;border-radius:13px;background:var(--linen);
  display:flex;align-items:center;justify-content:center;border:1px solid var(--line-soft)}
.info-card .ii svg{width:22px;height:22px;color:var(--bronze)}
.info-card h4{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--taupe);margin-bottom:7px}
.info-card .big{font-size:18px;font-weight:600;color:var(--espresso);line-height:1.4}
.info-card a.big:hover{color:var(--bronze)}
.hours-row{display:flex;justify-content:space-between;gap:18px;font-size:15px;padding:3px 0;color:var(--bark)}
.hours-row span:first-child{color:var(--taupe)}
.hours-row b{font-weight:600;color:var(--espresso)}
.visit-map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);
  border:1px solid var(--line);min-height:420px;height:100%}
.visit-map iframe{width:100%;height:100%;min-height:420px;border:0;display:block;filter:saturate(.92)}

/* ===== Booking form (inline section) ===== */
.book{background:linear-gradient(160deg,var(--linen),var(--dune))}
.book-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  overflow:hidden;display:grid;grid-template-columns:.85fr 1.15fr;max-width:1060px;margin:0 auto}
.book-aside{background:var(--espresso);color:#f3ede3;padding:46px 40px;position:relative;overflow:hidden}
.book-aside::after{content:"";position:absolute;right:-90px;bottom:-90px;width:260px;height:260px;
  border-radius:50%;background:radial-gradient(circle,rgba(179,133,96,.4),transparent 70%)}
.book-aside .eyebrow{color:#e9bf98}
.book-aside h3{color:#fff;font-size:30px;line-height:1.1;margin-bottom:14px;position:relative}
.book-aside p{color:rgba(243,237,227,.75);font-size:15.5px;position:relative;margin-bottom:26px}
.book-aside ul{list-style:none;padding:0;margin:0;display:grid;gap:14px;position:relative}
.book-aside li{display:flex;gap:11px;align-items:center;font-size:14.5px;color:#f3ede3}
.book-aside li svg{width:19px;height:19px;color:var(--leaf);flex:none}
.book-form{padding:40px;}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--bark);margin-bottom:7px;letter-spacing:.01em}
.field input,.field select,.field textarea{width:100%;font-family:var(--sans);font-size:15.5px;
  color:var(--espresso);background:var(--cream);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;transition:border-color .2s,box-shadow .2s;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--caramel);
  box-shadow:0 0 0 4px rgba(179,133,96,.14);background:#fff}
.field textarea{resize:vertical;min-height:74px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-note{font-size:12.5px;color:var(--taupe);margin-top:6px;text-align:center}
.form-success{display:none;text-align:center;padding:24px 10px}
.form-success.show{display:block;animation:fadein .5s var(--ease)}
.form-success .sc{width:64px;height:64px;border-radius:50%;background:rgba(125,196,69,.14);
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.form-success .sc svg{width:32px;height:32px;color:#5a9e2c}
.form-success h4{font-size:23px;margin-bottom:10px}
.form-success p{color:var(--taupe);font-size:15.5px;max-width:30em;margin:0 auto}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ===== Footer ===== */
.footer{background:#211d1a;color:#cabfb1;padding:64px 0 26px;font-size:14.5px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;
  padding-bottom:44px;border-bottom:1px solid rgba(202,191,177,.14)}
.footer-brand img{height:40px;width:auto;margin-bottom:18px;filter:brightness(0) invert(1);opacity:.95}
.footer-brand p{color:rgba(202,191,177,.7);max-width:26em;line-height:1.6}
.footer h5{font-family:var(--sans);font-weight:700;font-size:12.5px;letter-spacing:.13em;
  text-transform:uppercase;color:#8f8579;margin:0 0 16px}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer ul a:hover{color:#fff}
.footer .fcontact{display:grid;gap:10px}
.footer .fcontact a:hover{color:#fff}
.footbot{display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding-top:22px;flex-wrap:wrap;color:rgba(202,191,177,.55);font-size:13px}
.footbot .prev{display:inline-flex;align-items:center;gap:8px}
.footbot .prev .pd{width:6px;height:6px;border-radius:50%;background:var(--caramel)}

/* ===== Mobile sticky bar ===== */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;
  background:rgba(251,250,247,.94);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  gap:10px}
.mbar .btn{flex:1;padding:14px}

/* ===== Mobile drawer ===== */
.drawer-overlay{position:fixed;inset:0;background:rgba(42,38,35,.5);z-index:70;opacity:0;
  pointer-events:none;transition:opacity .3s}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(86vw,340px);background:var(--cream);
  z-index:71;transform:translateX(100%);transition:transform .38s var(--ease);
  box-shadow:var(--shadow-lg);display:flex;flex-direction:column;padding:22px}
.drawer.open{transform:none}
.drawer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.drawer-top img{height:38px}
.drawer-close{width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:11px;
  cursor:pointer;display:flex;align-items:center;justify-content:center}
.drawer-close svg{width:20px;height:20px}
.drawer nav{display:grid;gap:4px}
.drawer nav a{font-family:var(--serif);font-size:21px;color:var(--espresso);padding:13px 0;
  border-bottom:1px solid var(--line-soft)}
.drawer .btn{margin-top:22px}
.drawer-foot{margin-top:auto;font-size:14px;color:var(--taupe)}
.drawer-foot a{color:var(--bronze);font-weight:600}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}.hero-badge .pulse{animation:none}
}

/* ===== Responsive ===== */
@media(max-width:1000px){
  .svc-grid,.news-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-media{max-width:460px;margin:0 auto;width:100%}
  .hero-photo{aspect-ratio:4/3.6;border-radius:200px 200px 22px 22px}
  .split,.split.reverse,.about-grid,.smile-grid,.visit-grid{grid-template-columns:1fr;gap:34px}
  .split.reverse .approach-photo{order:-1}
  .book-card{grid-template-columns:1fr}
  .book-aside{padding:36px 32px}
}
@media(max-width:860px){
  .nav-links,.nav-cta-phone{display:none}
  .menu-toggle{display:flex}
  .header .lang{display:none}
  .nav-right .btn-primary{display:none}
  .mbar{display:flex}
  body{padding-bottom:72px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:600px){
  body{font-size:16px}
  .wrap{padding:0 18px}
  .svc-grid,.news-grid,.testi-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .hero-float{left:0;max-width:240px}
  .footer-grid{grid-template-columns:1fr}
  .book-form{padding:28px 22px}
  .about-photo{border-radius:22px 22px 22px 80px}
}
