/* =====================================================================
   O'SULLIVAN FAMILY DENTAL — SHARED STYLESHEET
   demo-index.html · demo-about.html · demo-services.html · demo-contact.html
   ===================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --white:#F4ECDB;
  --bone:#F9F4E6;
  --off-white:#E5D8BC;
  --warm:#EDE1C8;
  --beige:#DDC9A1;
  --sage-mist:#EFF2EA;
  --sage-pale:#DDE3CF;
  --sage:#A8B79E;
  --sage-deep:#6B7A65;
  --forest:#3F5640;
  --forest-dark:#2A3A2C;
  --blue-deep:#3F5640;
  --blue:#6B7A65;
  --blue-mid:#8A9A82;
  --blue-light:#C8D4BD;
  --blue-pale:#EFF2EA;
  --blue-ghost:#F0EBDC;
  --copper:#6B7A65;
  --copper-light:#A0B098;
  --copper-deep:#3F5640;
  --copper-glow:#D5DCC9;
  --brass:#6B7A65;
  --brass-light:#A0B098;
  --brass-deep:#3F5640;
  --gold:#6B7A65;
  --ink:#1F2D20;
  --ink-dim:#4A5A48;
  --ink-faint:#8A988A;
  --espresso:#2A3A2C;
  --rule:rgba(31,45,32,0.10);
  --rule-strong:rgba(31,45,32,0.18);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
  --shadow:0 4px 24px rgba(31,45,32,0.07);
  --shadow-lg:0 18px 50px rgba(31,45,32,0.13);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-smooth:cubic-bezier(0.4,0,0.2,1);
  --ease-soft:cubic-bezier(0.65,0,0.35,1);
  --radius:6px;
  --grad-forest:linear-gradient(135deg,#3F5640 0%,#2A3A2C 55%,#1F2A20 100%);
}

html{scroll-behavior:smooth}
body{background:var(--white);color:var(--ink);font-family:var(--sans);font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;letter-spacing:0.005em}
a{color:inherit;text-decoration:none}
::selection{background:var(--blue-light);color:var(--blue-deep)}
img{max-width:100%;display:block}

body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}

/* ── BACK-TO-MTMN BUTTON (top-left, links to parent agency site) ── */
.mtmn-back{
  position:fixed;top:96px;left:28px;z-index:101;
  display:inline-flex;align-items:center;gap:9px;
  padding:9px 16px 9px 13px;
  background:rgba(244,236,219,0.72);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(107,122,101,0.22);
  border-radius:999px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;
  font-weight:500;
  color:var(--ink-dim);
  text-decoration:none;
  box-shadow:0 4px 18px rgba(31,45,32,0.06);
  transition:background .35s var(--ease-out),border-color .35s var(--ease-out),color .35s var(--ease-out),transform .35s var(--ease-out);
}
.mtmn-back:hover{border-color:rgba(200,162,75,0.55);color:var(--ink);transform:translateY(-1px)}
.mtmn-back-arrow{font-size:11px;letter-spacing:0;opacity:.55;transition:transform .3s var(--ease-out),opacity .3s var(--ease-out)}
.mtmn-back:hover .mtmn-back-arrow{transform:translateX(-3px);opacity:.9}
.mtmn-back-dot{width:6px;height:6px;border-radius:50%;background:#c8a24b;box-shadow:0 0 10px rgba(200,162,75,0.55)}
@media(max-width:900px){
  .mtmn-back{top:auto;bottom:18px;left:18px;padding:8px 12px 8px 10px;font-size:8.5px;letter-spacing:.18em;gap:7px}
  .mtmn-back-dot{width:5px;height:5px}
}

/* ── NAV ── */
nav{
  position:fixed;top:20px;left:50%;transform:translateX(-50%);
  z-index:100;width:95%;max-width:1480px;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:40px;
  padding:14px 28px 14px 24px;
  background:rgba(244,236,219,0.72);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(107,122,101,0.22);border-radius:999px;
  transition:
    width .65s var(--ease-out),
    background .55s var(--ease-out),
    box-shadow .55s var(--ease-out),
    border-color .55s var(--ease-out),
    backdrop-filter .55s var(--ease-out),
    padding .55s var(--ease-out);
  box-shadow:0 4px 24px rgba(31,45,32,0.08),inset 0 1px 0 rgba(255,255,255,0.5);
}

/* iOS-style glass nav when scrolled */
nav.scrolled{
  width:60%;
  background:rgba(244,236,219,0.06);
  backdrop-filter:blur(56px) saturate(2.4) brightness(1.06);
  -webkit-backdrop-filter:blur(56px) saturate(2.4) brightness(1.06);
  border-color:rgba(255,255,255,0.28);
  box-shadow:
    0 24px 72px rgba(31,45,32,0.22),
    0 4px 16px rgba(31,45,32,0.10),
    inset 0 1.5px 0 rgba(255,255,255,0.44),
    inset 0 -1px 0 rgba(31,45,32,0.05);
  padding:10px 22px 10px 18px;
}

.nav-brand{display:flex;align-items:center;gap:14px}
.nav-logo-mark{width:36px;height:36px;flex-shrink:0}
.nav-brand-name{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);line-height:1.1;letter-spacing:.02em;text-transform:uppercase}
.nav-brand-sub{font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--copper);font-family:var(--mono);font-weight:500;margin-top:2px}
nav ul{display:flex;gap:42px;list-style:none;justify-content:center}
nav ul a{font-size:11px;font-weight:500;color:var(--ink-dim);letter-spacing:.22em;text-transform:uppercase;transition:color .3s var(--ease-out);position:relative;font-family:var(--mono)}
nav ul a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--copper);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
nav ul a:hover,nav ul a.active{color:var(--copper)}
nav ul a:hover::after,nav ul a.active::after{transform:scaleX(1)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;background:transparent;color:var(--ink);border:1px solid var(--copper);border-radius:999px;font-size:10.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;font-family:var(--mono);transition:all .4s var(--ease-out)}
.nav-cta:hover{background:var(--copper);color:#fff}

/* ── SECTION BREAK (green gradient divider between beige sections) ── */
.section-break{
  height:44px;
  background:linear-gradient(180deg,#2A3A2C 0%,#3F5640 48%,#2A3A2C 100%);
  position:relative;overflow:hidden;
}
.section-break::before{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.03;pointer-events:none;
}
.section-break::after{
  content:"";position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:140px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(213,220,201,0.28) 25%,rgba(213,220,201,0.50) 50%,rgba(213,220,201,0.28) 75%,transparent);
}

/* ── HERO ── */
.hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:center;justify-content:center;overflow:hidden;contain:layout paint}
.hero-bg{position:absolute;inset:0;z-index:0;will-change:transform;transform:translateZ(0)}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;animation:kenburns 44s ease-in-out infinite alternate;will-change:transform;transform:translateZ(0);backface-visibility:hidden}
@keyframes kenburns{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(-1.2%,-0.8%,0) scale(1.05)}}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(160deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.04) 40%, rgba(0,0,0,0.06) 100%),
    radial-gradient(ellipse 140% 100% at 50% 45%, rgba(244,236,219,0.52) 0%, rgba(230,218,196,0.70) 55%, rgba(210,198,172,0.82) 100%);
}
.hero-content-center{position:relative;z-index:2;text-align:center;max-width:900px;padding:0 40px}

/* Construction-style entrance reveals */
@keyframes hero-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes hero-word-up{from{transform:translateY(110%)}to{transform:translateY(0)}}
@keyframes hero-divider-grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}

.hero-eyebrow{display:inline-flex;align-items:center;gap:16px;font-family:var(--mono);font-size:10.5px;letter-spacing:.36em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:30px;font-weight:500;opacity:0;animation:hero-rise .8s var(--ease-out) .25s forwards}
.hero-eyebrow::before,.hero-eyebrow::after{content:"";width:32px;height:1px;background:var(--brass)}
.hero-content-center h1{font-family:var(--serif);font-weight:300;font-size:clamp(62px,9.5vw,132px);line-height:.90;letter-spacing:-.02em;color:var(--ink);text-transform:uppercase;text-shadow:0 1px 0 rgba(255,255,255,0.35)}
.hero-content-center h1 .h-line{display:block;overflow:hidden}
.hero-content-center h1 .h-word{display:inline-block;transform:translateY(110%);animation:hero-word-up .95s var(--ease-out) forwards}
.hero-content-center h1 .h-line:nth-child(1) .h-word{animation-delay:.4s}
.hero-content-center h1 .h-line:nth-child(2) .h-word{animation-delay:.55s}
.hero-content-center h1 em{font-style:italic;font-weight:300;display:block;text-transform:none;letter-spacing:-.03em;color:var(--forest)}
.hero-divider{width:56px;height:1px;background:rgba(31,45,32,0.22);margin:28px auto;transform:scaleX(0);animation:hero-divider-grow .7s var(--ease-out) .95s forwards}
.hero-lede{font-size:15px;color:var(--ink-dim);line-height:1.75;max-width:500px;margin:0 auto 38px;font-weight:300;letter-spacing:.01em;opacity:0;animation:hero-rise .8s var(--ease-out) 1.05s forwards}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center;justify-content:center;opacity:0;animation:hero-rise .8s var(--ease-out) 1.2s forwards}
.btn-hero-primary{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:rgba(31,45,32,0.92);color:#fff;border:1px solid rgba(31,45,32,0.70);border-radius:2px;font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;transition:background .4s var(--ease-out),border-color .4s var(--ease-out),transform .4s var(--ease-out);font-family:var(--mono);cursor:pointer;text-decoration:none}
.btn-hero-primary:hover{background:var(--ink);border-color:var(--ink)}
.btn-hero-secondary{display:inline-flex;align-items:center;gap:8px;padding:16px 24px;color:var(--ink-dim);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;transition:color .3s var(--ease-out);font-family:var(--mono);cursor:pointer;background:transparent;border:none;text-decoration:none}
.btn-hero-secondary:hover{color:var(--ink)}
.hero-scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--mono);font-size:8.5px;letter-spacing:.40em;text-transform:uppercase;color:rgba(31,45,32,0.45);opacity:0;animation:hero-rise .8s var(--ease-out) 1.4s forwards}
.hero-scroll-line{width:1px;height:38px;background:rgba(31,45,32,0.28);transform-origin:top;animation:scrollPulse 2.2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(1);opacity:.32}50%{transform:scaleY(0.3);opacity:.08}}

/* ── HERO META BAR ── */
.hero-meta-bar{background:var(--white);border-bottom:1px solid var(--rule);padding:28px 52px}
.hero-meta-bar-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:36px;max-width:1560px;margin:0 auto}
.hero-meta{display:flex;flex-direction:column;gap:3px}
.hero-meta-label{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint)}
.hero-meta-val{font-size:14px;color:var(--ink-dim)}
.hero-meta-val a{color:var(--copper);transition:opacity .3s var(--ease-out)}
.hero-meta-val a:hover{opacity:.7}

/* ── INNER PAGE HEADER (about/services/contact pages) ── */
.page-header{background:var(--white);padding:200px 52px 80px;border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.page-header-inner{max-width:1560px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end}
.page-header h1{font-family:var(--serif);font-weight:300;font-size:clamp(54px,7vw,110px);line-height:.96;letter-spacing:-.025em;color:var(--ink);text-transform:uppercase}
.page-header h1 em{font-style:italic;font-weight:300;display:block;text-transform:none;letter-spacing:-.03em;color:var(--forest)}
.page-header-sub{font-size:15px;color:var(--ink-dim);line-height:1.75;max-width:420px;justify-self:end;padding-bottom:14px}
.page-header-eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--mono);font-size:10.5px;letter-spacing:.36em;text-transform:uppercase;color:var(--brass);margin-bottom:24px;font-weight:500}
.page-header-eyebrow::before{content:"";width:32px;height:1px;background:var(--brass)}

/* ── FOREST GRADIENT BAND ── */
.gradient-band{
  background:var(--grad-forest);
  padding:60px 52px;
  position:relative;overflow:hidden;
}
.gradient-band::before{
  content:"";position:absolute;top:-120px;right:-80px;
  width:420px;height:420px;
  border:1px solid rgba(213,220,201,0.10);border-radius:50%;pointer-events:none;
}
.gradient-band::after{
  content:"";position:absolute;bottom:-180px;left:-60px;
  width:340px;height:340px;
  border:1px solid rgba(213,220,201,0.07);border-radius:50%;pointer-events:none;
}
.gradient-band-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
  max-width:1200px;margin:0 auto;
  position:relative;z-index:1;
}
.gradient-stat{text-align:center;padding:14px 28px;border-right:1px solid rgba(213,220,201,0.14)}
.gradient-stat:last-child{border-right:none}
.gradient-stat-num{
  font-family:var(--serif);font-size:clamp(40px,4.5vw,64px);font-weight:300;
  color:#fff;line-height:1;margin-bottom:10px;letter-spacing:-.03em;
}
.gradient-stat-num em{font-style:italic;color:var(--copper-glow)}
.gradient-stat-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;
  text-transform:uppercase;color:rgba(255,255,255,0.52);font-weight:500;
}

/* ── GRADIENT ACCENT STRIP ── */
.gradient-strip{
  background:var(--grad-forest);
  padding:44px 52px;
  position:relative;overflow:hidden;
  text-align:center;
}
.gradient-strip::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.04'/></svg>");pointer-events:none}
.gradient-strip-text{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(24px,3vw,38px);color:rgba(255,255,255,0.82);letter-spacing:-.01em;position:relative;z-index:1;max-width:700px;margin:0 auto}
.gradient-strip-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.36em;text-transform:uppercase;color:var(--copper-glow);margin-bottom:14px;font-weight:500;position:relative;z-index:1}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:12px;padding:18px 32px;background:var(--copper);color:#fff;border-radius:2px;font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;transition:background .4s var(--ease-out),transform .3s var(--ease-out);border:1px solid var(--copper);cursor:pointer;font-family:var(--mono);text-decoration:none}
.btn-primary:hover{background:var(--copper-deep);border-color:var(--copper-deep);transform:translateY(-1px)}
.btn-secondary{display:inline-flex;align-items:center;gap:12px;padding:18px 32px;background:transparent;color:var(--ink);border-radius:2px;font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;transition:all .4s var(--ease-out);border:1px solid var(--copper);cursor:pointer;font-family:var(--mono);text-decoration:none}
.btn-secondary:hover{background:var(--copper);color:#fff;transform:translateY(-1px)}

/* ── TRUST BAR ── */
.trust-bar{background:var(--white);border-bottom:1px solid var(--rule);padding:32px 52px}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap;max-width:1400px;margin:0 auto}
.trust-label{font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--brass);flex-shrink:0;font-weight:500}
.trust-items{display:flex;gap:36px;flex-wrap:wrap;justify-content:center;align-items:center}
.trust-item{font-family:var(--serif);font-size:16px;color:var(--ink-dim);font-style:italic;display:flex;align-items:center;gap:10px;letter-spacing:-.005em}
.trust-item svg{width:20px;height:20px;opacity:.6;flex-shrink:0;color:var(--copper)}
.trust-divider{width:1px;height:18px;background:var(--rule-strong)}

/* ── SECTION BASE ── */
section{position:relative}
.section-inner{padding:100px 52px;max-width:1560px;margin:0 auto}
.section-eyebrow{display:inline-flex;align-items:center;gap:14px;font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--brass);margin-bottom:22px;font-weight:500}
.section-eyebrow::before{content:"";width:32px;height:1px;background:var(--brass)}
.section-title{font-family:var(--serif);font-weight:300;font-size:clamp(42px,5vw,72px);line-height:1.02;letter-spacing:-.025em;color:var(--ink);margin-bottom:20px}
.section-title em{font-style:italic;color:var(--copper)}
.section-sub{font-size:16px;color:var(--ink-dim);max-width:580px;line-height:1.7}

/* ── ABOUT ── */
.about{background:var(--blue-ghost)}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.about-image{position:relative;display:flex;justify-content:center;align-items:flex-start}
.about-image-frame{width:100%;max-width:500px;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;position:relative;box-shadow:var(--shadow-lg);background:linear-gradient(145deg,var(--warm) 0%,var(--off-white) 100%)}
.about-image-frame img{width:100%;height:100%;object-fit:cover;filter:sepia(0.10) saturate(0.94);transition:transform 1.2s var(--ease-out)}
.about-image-frame:hover img{transform:scale(1.04)}
.about-image-frame::after{content:"Est. 1987";position:absolute;bottom:24px;right:24px;background:rgba(244,236,219,0.96);backdrop-filter:blur(8px);border-radius:2px;padding:10px 18px;font-family:var(--serif);font-size:21px;font-style:italic;font-weight:500;color:var(--ink);box-shadow:var(--shadow);border:1px solid var(--rule)}
.about-corner{position:absolute;top:-22px;left:-22px;width:130px;height:130px;border:1px solid var(--brass);border-radius:var(--radius);z-index:-1;opacity:.6}
.about-content p{font-size:16px;color:var(--ink-dim);line-height:1.8;margin-bottom:20px}
.about-content p:last-of-type{margin-bottom:32px}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:40px}
.about-value{background:var(--bone);border-radius:var(--radius);padding:24px;border:1px solid var(--rule);transition:border-color .4s var(--ease-out),transform .4s var(--ease-out)}
.about-value:hover{border-color:var(--brass-light);transform:translateY(-2px)}
.about-value .val-icon{font-size:22px;margin-bottom:12px;opacity:.85}
.about-value h4{font-family:var(--serif);font-size:20px;font-weight:500;color:var(--ink);margin-bottom:6px;letter-spacing:-.005em}
.about-value p{font-size:13px;color:var(--ink-dim);line-height:1.6;margin-bottom:0}

/* ── SERVICES ── */
.services{background:var(--off-white)}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px;gap:40px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service-card{background:var(--bone);border:1px solid var(--rule);border-radius:var(--radius);padding:36px;transition:transform .6s var(--ease-out),box-shadow .6s var(--ease-out),border-color .4s;position:relative;overflow:hidden;--mx:50%;--my:50%}
.service-card::before{content:"";position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx) var(--my),rgba(184,153,104,0.08),transparent 55%);opacity:0;transition:opacity .5s var(--ease-out);pointer-events:none}
.service-card:hover{border-color:var(--brass-light);transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.service-card:hover::before{opacity:1}
.service-card>*{position:relative}
.service-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;color:var(--copper)}
.service-icon svg{width:30px;height:30px}
.service-card h3{font-family:var(--serif);font-size:24px;font-weight:500;color:var(--ink);margin-bottom:12px;line-height:1.2;letter-spacing:-.005em}
.service-card p{font-size:14.5px;color:var(--ink-dim);line-height:1.7;margin-bottom:22px}
.service-tag{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);background:transparent;padding:0;border-radius:0;border-top:1px solid var(--rule);padding-top:14px;width:100%}

/* ── TEAM ── */
.team{background:var(--blue-ghost)}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:56px;width:100%}
.team-card{background:var(--bone);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .6s var(--ease-out),box-shadow .6s var(--ease-out);display:flex;flex-direction:column;border:1px solid var(--rule)}
.team-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.team-photo{aspect-ratio:16/9;background:linear-gradient(145deg,var(--warm) 0%,var(--off-white) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center 25%;filter:sepia(0.08) saturate(0.94);transition:transform 1s var(--ease-out)}
.team-card:hover .team-photo img{transform:scale(1.05)}
.team-role-badge{position:absolute;top:18px;left:18px;background:rgba(42,58,44,0.94);backdrop-filter:blur(6px);color:#fff;font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;padding:6px 12px;border-radius:2px;z-index:2;font-weight:500}
.team-body{padding:34px;flex:1}
.team-name{font-family:var(--serif);font-size:28px;font-weight:500;color:var(--ink);margin-bottom:6px;letter-spacing:-.01em}
.team-qual{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:16px;font-weight:500}
.team-bio{font-size:14.5px;color:var(--ink-dim);line-height:1.7}
.team-qualifications{margin-top:20px;display:flex;flex-wrap:wrap;gap:6px;padding-top:18px;border-top:1px solid var(--rule)}
.team-qual-tag{font-size:10.5px;background:transparent;color:var(--ink-dim);border-radius:2px;padding:4px 10px;font-family:var(--mono);letter-spacing:.08em;border:1px solid var(--rule-strong)}

/* ── PATIENT JOURNEY ── */
.journey{background:var(--sage-pale)}
.journey-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:56px}
.journey-step{padding:32px 28px;border-left:1px solid var(--rule-strong);transition:border-color .5s var(--ease-out)}
.journey-step:hover{border-left-color:var(--brass)}
.step-num{font-family:var(--serif);font-size:32px;font-weight:300;font-style:italic;color:var(--brass);margin-bottom:18px;display:block;letter-spacing:-.02em}
.journey-step h4{font-family:var(--serif);font-size:21px;font-weight:500;color:var(--ink);margin-bottom:10px;line-height:1.2;letter-spacing:-.005em}
.journey-step p{font-size:13.5px;color:var(--ink-dim);line-height:1.7}

/* ── TESTIMONIALS CAROUSEL ── */
.testimonials{
  background:var(--bone);color:var(--ink);
  position:relative;overflow:hidden;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.testimonials .section-inner{padding-bottom:80px}
.testimonials-header{text-align:center;margin-bottom:64px}
.testimonials-header .section-eyebrow{justify-content:center;display:inline-flex}
.testimonials-header .section-title{margin-bottom:0}
.testimonials-carousel-wrap{display:flex;align-items:center;gap:24px;max-width:820px;margin:0 auto}
.testimonials-track{flex:1;position:relative;min-height:300px;overflow:hidden}
.testimonial-slide{
  position:absolute;width:100%;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:0 16px;gap:0;opacity:0;pointer-events:none;
}
.testimonial-slide:first-child{opacity:1;pointer-events:auto}
.testimonial-qmark{font-family:var(--serif);font-size:72px;color:var(--brass);line-height:0.7;margin-bottom:20px;opacity:.5;font-style:italic;display:block;user-select:none}
.testimonial-quote-text{font-family:var(--serif);font-size:clamp(19px,2.4vw,27px);font-weight:300;font-style:italic;line-height:1.55;color:var(--ink-dim);letter-spacing:-.005em;max-width:640px;margin-bottom:34px}
.testimonial-author{display:flex;flex-direction:column;align-items:center;gap:5px;padding-top:20px;border-top:1px solid var(--rule);width:180px}
.testimonial-name{font-size:14px;font-weight:500;color:var(--ink);letter-spacing:.005em}
.testimonial-meta{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-deep);margin-top:2px}
.testimonial-btn{
  width:52px;height:52px;border-radius:50%;
  border:1px solid var(--rule-strong);background:var(--white);
  color:var(--ink-dim);cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .3s var(--ease-out);
}
.testimonial-btn:hover{border-color:var(--brass);color:var(--brass);background:rgba(107,122,101,0.06);transform:scale(1.06)}
.testimonial-btn:active{transform:scale(0.96)}
.testimonials-dots{display:flex;justify-content:center;gap:8px;margin-top:44px}
.testimonial-dot{width:7px;height:7px;border-radius:50%;background:rgba(107,122,101,0.25);border:none;cursor:pointer;padding:0;transition:all .4s var(--ease-out)}
.testimonial-dot.dot-active{background:var(--brass);width:26px;border-radius:4px}

/* ── BOOKING CTA (full / dark) ── */
.booking-cta{background:var(--grad-forest);position:relative;overflow:hidden}
.booking-cta::before{content:"";position:absolute;top:-200px;left:-100px;width:500px;height:500px;border:1px solid rgba(213,220,201,0.12);border-radius:50%;pointer-events:none}
.booking-cta::after{content:"";position:absolute;bottom:-300px;right:-150px;width:600px;height:600px;border:1px solid rgba(213,220,201,0.08);border-radius:50%;pointer-events:none}
.booking-cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1400px;margin:0 auto;padding:100px 52px;position:relative;z-index:1}
.booking-cta-left{padding-right:60px;border-right:1px solid rgba(213,220,201,0.18)}
.booking-cta-label{font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--copper-glow);margin-bottom:26px;display:flex;align-items:center;gap:14px;font-weight:500}
.booking-cta-label::before{content:"";width:28px;height:1px;background:var(--copper-glow)}
.booking-cta-heading{font-family:var(--serif);font-weight:300;font-size:clamp(48px,5.5vw,84px);line-height:1;letter-spacing:-.03em;color:#fff;margin-bottom:24px}
.booking-cta-heading em{font-style:italic;color:var(--copper-glow);font-weight:400}
.booking-cta-sub{font-size:15px;color:rgba(255,255,255,0.7);line-height:1.7;max-width:380px;margin-bottom:42px}
.booking-cta-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-book-main{padding:18px 32px;background:transparent;color:#fff;border:1px solid var(--copper-glow);font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:all .4s var(--ease-out);text-decoration:none;display:inline-flex;align-items:center}
.btn-book-main:hover{background:var(--copper-glow);color:var(--ink);transform:translateY(-1px)}
.btn-book-call{padding:18px 32px;background:transparent;color:rgba(255,255,255,0.85);border:1px solid rgba(255,255,255,0.25);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;border-radius:2px;transition:all .4s var(--ease-out);display:inline-flex;align-items:center;font-family:var(--mono);cursor:pointer;text-decoration:none}
.btn-book-call:hover{border-color:#fff;color:#fff}
.booking-cta-right{padding-left:60px;display:flex;flex-direction:column;gap:44px;justify-content:center}
.hours-title{font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--brass-light);margin-bottom:18px;font-weight:500}
.hours-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.08);font-size:14px;color:rgba(255,255,255,0.78)}
.hours-row:last-of-type{border-bottom:none}
.hours-emerg{margin-top:14px;font-family:var(--mono);font-size:10px;color:rgba(255,255,255,0.4);letter-spacing:.14em;font-style:italic}
.find-us-text{font-size:14px;color:rgba(255,255,255,0.7);line-height:1.7;margin-bottom:14px}
.find-us-map{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-light);transition:color .3s var(--ease-out);font-weight:500}
.find-us-map:hover{color:#fff}

/* ── BOOKING CTA — light variant (contact page) ── */
.booking-cta-light{background:var(--bone);border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.booking-cta-light::before{content:"";position:absolute;top:-180px;right:-100px;width:420px;height:420px;border:1px solid rgba(107,122,101,0.10);border-radius:50%;pointer-events:none}
.booking-cta-light::after{content:"";position:absolute;bottom:-220px;left:-80px;width:380px;height:380px;border:1px solid rgba(107,122,101,0.08);border-radius:50%;pointer-events:none}
.booking-cta-light .booking-cta-inner-centered{max-width:760px;margin:0 auto;padding:140px 52px 90px;position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center}
.booking-cta-light .booking-cta-label{color:var(--brass);justify-content:center}
.booking-cta-light .booking-cta-label::before{background:var(--brass)}
.booking-cta-light .booking-cta-heading{color:var(--ink)}
.booking-cta-light .booking-cta-heading em{color:var(--copper)}
.booking-cta-light .booking-cta-sub{color:var(--ink-dim);max-width:520px;margin-left:auto;margin-right:auto}
.booking-cta-light .booking-cta-actions{justify-content:center}
.booking-cta-light .btn-book-main{background:var(--copper);color:#fff;border-color:var(--copper)}
.booking-cta-light .btn-book-main:hover{background:var(--copper-deep);border-color:var(--copper-deep);color:#fff}
.booking-cta-light .btn-book-call{color:var(--ink-dim);border-color:var(--rule-strong)}
.booking-cta-light .btn-book-call:hover{border-color:var(--ink);color:var(--ink)}

/* ── FOOTER ── */
footer{background:linear-gradient(180deg,#2A3A2C 0%,#1F2D20 100%);color:rgba(244,236,219,0.65);position:relative}
.footer-mark{padding:64px 24px 36px;text-align:center;border-bottom:1px solid rgba(213,220,201,0.10)}
.footer-mark-logo{display:inline-block;margin-bottom:18px}
.footer-mark-logo svg{width:48px;height:48px;opacity:.9}
.footer-mark-tagline{font-family:var(--mono);font-size:10.5px;letter-spacing:.42em;text-transform:uppercase;color:var(--copper-glow);font-weight:500}
.footer-top{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:1px solid rgba(213,220,201,0.10);max-width:1400px;margin:0 auto}
.footer-panel{padding:48px 36px}
.footer-panel-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--copper-glow);margin-bottom:22px;font-weight:500}
.footer-panel h3,.footer-panel-sub,.footer-contact-label,.footer-divider{display:none}
.footer-panel p{font-size:13px;line-height:1.8;color:rgba(244,236,219,0.55)}
.footer-contact-item{display:flex;flex-direction:column;gap:3px;margin-bottom:14px}
.footer-contact-item:last-child{margin-bottom:0}
.footer-contact-val{font-size:13.5px;color:rgba(244,236,219,0.7);transition:color .3s var(--ease-out)}
.footer-contact-val:hover{color:var(--copper-glow)}
.footer-services-list{display:flex;flex-direction:column;gap:10px}
.footer-services-list a{font-size:13.5px;color:rgba(244,236,219,0.55);transition:color .3s var(--ease-out)}
.footer-services-list a:hover{color:var(--copper-glow)}
.footer-bottom{padding:24px 36px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;max-width:1400px;margin:0 auto}
.footer-copy{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:rgba(244,236,219,0.35);text-transform:uppercase}
.footer-accreds{display:flex;gap:8px}
.footer-accred{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,236,219,0.4);border:1px solid rgba(213,220,201,0.18);padding:4px 10px;border-radius:2px}

/* ── REVEAL ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1.1s var(--ease-out),transform 1.1s var(--ease-out)}
.reveal.in-view{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}
.reveal-delay-2{transition-delay:.24s}
.reveal-delay-3{transition-delay:.36s}
.reveal-delay-4{transition-delay:.48s}

/* ── MOBILE FAB ── */
.mobile-call-fab{display:none;position:fixed;bottom:18px;right:18px;z-index:90;background:var(--copper);color:#fff;padding:14px 22px;border-radius:999px;font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;font-family:var(--mono);box-shadow:0 8px 28px rgba(63,86,64,0.4);align-items:center;gap:8px;text-decoration:none;transition:all .4s var(--ease-out)}
.mobile-call-fab:active{transform:scale(0.96)}

/* =====================================================================
   CALENDAR BOOKING SYSTEM (demo-contact.html only)
   ===================================================================== */
.booking-calendar{background:var(--white);position:relative}
.booking-calendar-inner{max-width:1100px;margin:0 auto;padding:80px 52px 120px}

.booking-steps-bar{display:flex;justify-content:center;gap:0;margin-bottom:64px;border-bottom:1px solid var(--rule);padding-bottom:0;flex-wrap:wrap}
.booking-step-pill{display:flex;align-items:center;gap:14px;padding:18px 28px;font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .4s var(--ease-out)}
.booking-step-pill .step-num-circle{width:24px;height:24px;border-radius:50%;border:1px solid var(--rule-strong);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-faint);font-weight:400;letter-spacing:0;transition:all .4s var(--ease-out)}
.booking-step-pill.is-active{color:var(--ink);border-bottom-color:var(--copper)}
.booking-step-pill.is-active .step-num-circle{background:var(--copper);color:#fff;border-color:var(--copper)}
.booking-step-pill.is-done{color:var(--ink-dim)}
.booking-step-pill.is-done .step-num-circle{background:var(--sage-deep);color:#fff;border-color:var(--sage-deep)}

.booking-step-panel{display:none;animation:fadeUp .5s var(--ease-out) both}
.booking-step-panel.is-active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.booking-step-heading{font-family:var(--serif);font-weight:300;font-size:clamp(32px,3.6vw,46px);line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin-bottom:14px}
.booking-step-heading em{font-style:italic;color:var(--copper)}
.booking-step-sub{font-size:14.5px;color:var(--ink-dim);line-height:1.7;max-width:520px;margin-bottom:42px}

.service-options{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.service-option{background:var(--bone);border:1px solid var(--rule);border-radius:var(--radius);padding:28px 24px;text-align:left;cursor:pointer;transition:all .4s var(--ease-out);font-family:inherit;color:inherit;position:relative;overflow:hidden}
.service-option:hover{border-color:var(--brass-light);transform:translateY(-3px);box-shadow:var(--shadow)}
.service-option.is-selected{border-color:var(--copper);background:rgba(107,122,101,0.06);box-shadow:0 0 0 3px rgba(107,122,101,0.10)}
.service-option.is-selected::after{content:"✓";position:absolute;top:14px;right:16px;width:22px;height:22px;border-radius:50%;background:var(--copper);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}
.service-option-name{font-family:var(--serif);font-size:21px;font-weight:500;color:var(--ink);margin-bottom:6px;letter-spacing:-.005em;line-height:1.2}
.service-option-desc{font-size:13px;color:var(--ink-dim);line-height:1.55;margin-bottom:18px}
.service-option-duration{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-deep);font-weight:500;display:flex;align-items:center;gap:8px;padding-top:14px;border-top:1px solid var(--rule)}
.service-option-duration::before{content:"";width:18px;height:1px;background:var(--brass-light)}

.booking-step-actions{display:flex;justify-content:space-between;align-items:center;margin-top:42px;gap:16px;flex-wrap:wrap}
.booking-back-link{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);background:none;border:none;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:8px;padding:8px 0;transition:color .3s var(--ease-out)}
.booking-back-link:hover{color:var(--ink)}
.booking-next-btn{padding:16px 32px;background:var(--copper);color:#fff;border:1px solid var(--copper);border-radius:2px;cursor:pointer;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;transition:all .4s var(--ease-out)}
.booking-next-btn:hover:not(:disabled){background:var(--copper-deep);border-color:var(--copper-deep);transform:translateY(-1px)}
.booking-next-btn:disabled{opacity:.4;cursor:not-allowed}

.calendar-wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.calendar{background:var(--bone);border:1px solid var(--rule);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--rule)}
.calendar-month{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);letter-spacing:-.005em}
.calendar-month em{font-style:italic;color:var(--copper);font-weight:400;margin-left:6px}
.calendar-nav{display:flex;gap:6px}
.calendar-nav-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--rule-strong);background:var(--white);color:var(--ink-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease-out)}
.calendar-nav-btn:hover:not(:disabled){border-color:var(--copper);color:var(--copper)}
.calendar-nav-btn:disabled{opacity:.3;cursor:not-allowed}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.calendar-dow{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;text-align:center;padding:8px 0 14px}
.calendar-day{aspect-ratio:1;border-radius:var(--radius);background:transparent;border:1px solid transparent;display:flex;align-items:center;justify-content:center;font-size:13.5px;color:var(--ink);cursor:pointer;transition:all .25s var(--ease-out);font-family:inherit;font-weight:400;position:relative}
.calendar-day:hover:not(:disabled):not(.is-other-month):not(.is-closed):not(.is-past){background:rgba(107,122,101,0.10);border-color:var(--brass-light)}
.calendar-day.is-today{font-weight:600;color:var(--copper-deep)}
.calendar-day.is-today::after{content:"";position:absolute;bottom:5px;width:4px;height:4px;border-radius:50%;background:var(--copper)}
.calendar-day.is-selected{background:var(--copper);color:#fff;border-color:var(--copper);font-weight:500}
.calendar-day.is-selected.is-today{color:#fff}
.calendar-day.is-selected.is-today::after{background:#fff}
.calendar-day.is-other-month{color:var(--ink-faint);opacity:.32;cursor:default;pointer-events:none}
.calendar-day.is-past{color:var(--ink-faint);opacity:.42;cursor:not-allowed;text-decoration:line-through;text-decoration-color:rgba(31,45,32,0.18)}
.calendar-day.is-closed{color:var(--ink-faint);opacity:.42;cursor:not-allowed}
.calendar-day.is-closed::before{content:"";position:absolute;width:18px;height:1px;background:rgba(31,45,32,0.20);transform:rotate(-25deg)}
.calendar-key{margin-top:22px;padding-top:18px;border-top:1px solid var(--rule);display:flex;flex-wrap:wrap;gap:18px;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);font-weight:500}
.calendar-key-item{display:flex;align-items:center;gap:8px}
.calendar-key-swatch{width:14px;height:14px;border-radius:3px;border:1px solid var(--rule-strong)}
.calendar-key-swatch.swatch-available{background:var(--bone)}
.calendar-key-swatch.swatch-selected{background:var(--copper);border-color:var(--copper)}
.calendar-key-swatch.swatch-closed{background:rgba(31,45,32,0.06);position:relative;overflow:hidden}
.calendar-key-swatch.swatch-closed::after{content:"";position:absolute;inset:0;background:linear-gradient(-25deg,transparent 47%,rgba(31,45,32,0.4) 47%,rgba(31,45,32,0.4) 53%,transparent 53%)}

.timeslots-panel{background:var(--bone);border:1px solid var(--rule);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);min-height:420px;display:flex;flex-direction:column}
.timeslots-header{padding-bottom:18px;border-bottom:1px solid var(--rule);margin-bottom:22px}
.timeslots-day-name{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--ink);letter-spacing:-.005em;margin-bottom:4px}
.timeslots-day-meta{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);font-weight:500}
.timeslots-empty{display:flex;align-items:center;justify-content:center;flex:1;font-family:var(--serif);font-style:italic;color:var(--ink-faint);text-align:center;font-size:16px;line-height:1.5;padding:40px 20px}
.timeslots-note{margin-top:18px;padding:14px 16px;background:rgba(107,122,101,0.06);border:1px dashed var(--rule-strong);border-radius:4px;font-family:var(--serif);font-style:italic;font-size:14px;line-height:1.55;color:var(--ink-dim);text-align:center}
.timeslots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;align-content:start}
.timeslot{padding:11px 6px;border:1px solid var(--rule-strong);border-radius:4px;background:var(--white);color:var(--ink);font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.05em;cursor:pointer;transition:all .25s var(--ease-out);text-align:center}
.timeslot:hover:not(:disabled){border-color:var(--copper);background:rgba(107,122,101,0.08);color:var(--copper-deep)}
.timeslot.is-selected{background:var(--copper);border-color:var(--copper);color:#fff}
.timeslot:disabled,.timeslot.is-booked,.timeslot.is-too-short{cursor:not-allowed;background:rgba(31,45,32,0.04);color:var(--ink-faint);border-color:var(--rule);text-decoration:line-through;text-decoration-color:rgba(31,45,32,0.18)}
.timeslot.is-booked{opacity:.45}
.timeslot.is-too-short{opacity:.30}

.booking-details-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start}
.booking-summary{background:var(--bone);border:1px solid var(--rule);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.booking-summary-title{font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--rule)}
.booking-summary-row{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--rule);gap:16px}
.booking-summary-row:last-child{border-bottom:none}
.booking-summary-label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;flex-shrink:0}
.booking-summary-value{font-family:var(--serif);font-size:18px;color:var(--ink);text-align:right;letter-spacing:-.005em;line-height:1.3}
.booking-summary-value em{font-style:italic;color:var(--copper)}
.booking-form{display:flex;flex-direction:column;gap:22px}
.field-group{display:flex;flex-direction:column;gap:7px}
.field-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-dim);font-weight:500}
.field-input,.field-textarea{background:var(--bone);border:1px solid var(--rule-strong);border-radius:4px;padding:14px 16px;font-family:var(--sans);font-size:14.5px;color:var(--ink);transition:all .3s var(--ease-out);font-weight:300}
.field-input:focus,.field-textarea:focus{outline:none;border-color:var(--copper);background:#fff;box-shadow:0 0 0 3px rgba(107,122,101,0.10)}
.field-input.is-error,.field-textarea.is-error{border-color:#B8533F;background:rgba(184,83,63,0.04);box-shadow:0 0 0 3px rgba(184,83,63,0.10)}
.field-textarea{min-height:96px;resize:vertical;font-family:inherit}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.booking-submit{padding:18px 32px;background:var(--copper);color:#fff;border:1px solid var(--copper);border-radius:2px;cursor:pointer;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;transition:all .4s var(--ease-out);align-self:flex-start}
.booking-submit:hover{background:var(--copper-deep);border-color:var(--copper-deep);transform:translateY(-1px)}
.booking-confirm{text-align:center;padding:60px 20px;background:var(--bone);border:1px solid var(--rule);border-radius:var(--radius)}
.booking-confirm-tick{width:72px;height:72px;border-radius:50%;background:var(--sage-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 28px;color:var(--forest)}
.booking-confirm h3{font-family:var(--serif);font-weight:300;font-size:clamp(34px,4vw,52px);line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin-bottom:18px}
.booking-confirm h3 em{font-style:italic;color:var(--copper)}
.booking-confirm p{font-size:15.5px;color:var(--ink-dim);line-height:1.7;max-width:480px;margin:0 auto 36px}
.booking-confirm-summary{display:inline-block;background:var(--white);border:1px solid var(--rule);border-radius:var(--radius);padding:24px 36px;text-align:left;margin-bottom:36px}
.booking-confirm-summary .booking-summary-row{padding:10px 0;min-width:280px}
.booking-confirm .booking-secondary{background:transparent;color:var(--ink-dim);border:1px solid var(--rule-strong);padding:14px 28px;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;border-radius:2px;cursor:pointer;transition:all .3s var(--ease-out)}
.booking-confirm .booking-secondary:hover{border-color:var(--copper);color:var(--copper)}

/* ── INTERMEDIATE: prevent scrolled nav distortion between mobile and wide desktop ── */
@media(min-width:901px) and (max-width:1280px){
  nav{gap:24px}
  nav ul{gap:26px}
  nav.scrolled{width:82%;gap:20px}
}

/* ── TABLET ── */
@media(max-width:1100px){
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-image-frame{max-width:380px}
  .gradient-band-inner{grid-template-columns:repeat(2,1fr)}
  .gradient-stat{border-right:none;border-bottom:1px solid rgba(213,220,201,0.14)}
  .gradient-stat:nth-child(odd){border-right:1px solid rgba(213,220,201,0.14)}
  .gradient-stat:nth-last-child(-n+2){border-bottom:none}
  .calendar-wrap{grid-template-columns:1fr;gap:24px}
  .booking-details-grid{grid-template-columns:1fr;gap:32px}
  .service-options{grid-template-columns:repeat(2,1fr)}
  .page-header-inner{grid-template-columns:1fr;gap:30px}
  .page-header-sub{justify-self:start;padding-bottom:0}
}

/* ── MOBILE ── */
@media(max-width:900px){
  nav{padding:10px 12px 10px 14px;grid-template-columns:1fr auto;gap:10px;width:95%}
  nav.scrolled{width:92%}
  .nav-brand{gap:9px;min-width:0}
  .nav-brand-text{min-width:0}
  .nav-logo-mark{width:26px;height:26px}
  .nav-brand-name{font-size:12px;letter-spacing:.01em;line-height:1.15;white-space:normal}
  .nav-brand-sub{display:none}
  nav ul{display:none}
  .nav-cta{padding:8px 12px;font-size:8.5px;letter-spacing:.12em;gap:6px;white-space:nowrap}
  .hero-content-center{padding:0 24px}
  .hero-content-center h1{font-size:clamp(46px,12vw,78px)}
  .hero-lede{font-size:14px}
  .btn-hero-primary{padding:14px 24px;font-size:10px}
  .btn-hero-secondary{font-size:10px}
  .hero-meta-bar{padding:20px 16px}
  .hero-meta-bar-inner{grid-template-columns:1fr 1fr;gap:20px}
  .gradient-band{padding:40px 20px}
  .gradient-band-inner{grid-template-columns:repeat(2,1fr)}
  .gradient-strip{padding:32px 20px}
  .trust-bar{padding:20px 16px}
  .trust-inner{gap:14px}
  .trust-items{gap:18px}
  .trust-item{font-size:13px}
  .trust-divider{display:none}
  .section-inner{padding:70px 20px}
  .services-grid{grid-template-columns:1fr}
  .services-head{flex-direction:column;align-items:flex-start}
  .team-grid{grid-template-columns:1fr;gap:24px}
  .team-body{padding:24px}
  .team-name{font-size:22px}
  .journey-steps{grid-template-columns:1fr 1fr;gap:32px}
  .testimonials-carousel-wrap{gap:12px}
  .testimonial-btn{width:40px;height:40px}
  .testimonials-track{min-height:320px}
  .footer-top{grid-template-columns:1fr}
  .footer-panel{padding:32px 20px}
  .booking-cta-inner{grid-template-columns:1fr;padding:52px 20px}
  .booking-cta-left{padding-right:0;border-right:none;border-bottom:1px solid rgba(255,255,255,0.12);padding-bottom:40px}
  .booking-cta-right{padding-left:0}
  .booking-cta-light .booking-cta-inner-centered{padding:120px 20px 70px}
  .mobile-call-fab{display:inline-flex}
  .booking-calendar-inner{padding:60px 20px 90px}
  .service-options{grid-template-columns:1fr}
  .booking-steps-bar{gap:0}
  .booking-step-pill{padding:14px 14px;font-size:9px;letter-spacing:.18em}
  .timeslots-grid{grid-template-columns:repeat(2,1fr)}
  .field-row{grid-template-columns:1fr}
  .page-header{padding:160px 20px 60px}
  .section-break{height:32px}
}

/* ── EXTRA-NARROW PHONES ── */
@media(max-width:480px){
  nav{padding:9px 10px 9px 12px;gap:8px}
  .nav-brand{gap:7px}
  .nav-logo-mark{width:24px;height:24px}
  .nav-brand-name{font-size:10.5px;max-width:140px}
  .nav-cta{padding:7px 10px;font-size:8px;letter-spacing:.08em}
}

/* ── MOBILE NAV DROPDOWN (trigger pill + panel; hidden on desktop) ── */
.nav-mobile-trigger,.nav-mobile-panel{display:none}

@media(max-width:900px){
  .nav-mobile-trigger{
    display:inline-flex;
    position:fixed;top:74px;left:50%;transform:translateX(-50%);
    z-index:99;
    align-items:center;justify-content:center;gap:9px;
    padding:9px 18px;
    background:rgba(244,236,219,0.82);
    backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    border:1px solid rgba(107,122,101,0.28);
    border-radius:999px;
    color:var(--ink-dim);
    font-family:var(--mono);font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
    cursor:pointer;
    box-shadow:0 6px 18px rgba(31,45,32,0.10);
    transition:background .35s var(--ease-out),border-color .35s var(--ease-out),color .35s var(--ease-out);
  }
  .nav-mobile-trigger:hover,
  .nav-mobile-trigger[aria-expanded="true"]{
    border-color:var(--copper);
    color:var(--ink);
    background:rgba(244,236,219,0.95);
  }
  .nav-mobile-chev{
    width:11px;height:11px;flex-shrink:0;
    transition:transform .35s var(--ease-out);
  }
  .nav-mobile-trigger[aria-expanded="true"] .nav-mobile-chev{transform:rotate(180deg)}

  .nav-mobile-panel{
    display:flex;flex-direction:column;
    position:fixed;top:118px;left:50%;
    transform:translateX(-50%) translateY(-10px);
    z-index:98;
    width:min(92%,320px);
    background:rgba(244,236,219,0.96);
    backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
    border:1px solid rgba(107,122,101,0.28);
    border-radius:14px;
    box-shadow:0 22px 50px rgba(31,45,32,0.18);
    opacity:0;pointer-events:none;
    overflow:hidden;
    transition:opacity .42s var(--ease-out),transform .42s var(--ease-out);
  }
  .nav-mobile-panel.open{
    opacity:1;pointer-events:auto;
    transform:translateX(-50%) translateY(0);
  }
  .nav-mobile-panel a{
    padding:14px 22px;
    font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
    color:var(--ink-dim);
    border-top:1px solid rgba(31,45,32,0.08);
    transition:background .25s var(--ease-out),color .25s var(--ease-out),padding-left .25s var(--ease-out);
  }
  .nav-mobile-panel a:first-child{border-top:none}
  .nav-mobile-panel a:hover,
  .nav-mobile-panel a.active{
    background:rgba(107,122,101,0.10);
    color:var(--copper);
    padding-left:30px;
  }
}
