/* ============================================================
   Medical Foot Care Podiatry — shared stylesheet
   Brand: indigo #293C8F + cyan #2C91D0
   ============================================================ */

:root{
  --ink:#16223F;
  --ink-soft:#46557A;
  --ink-faint:#6A7593;
  --blue:#293C8F;            /* brand indigo, primary */
  --blue-deep:#1E2C6E;       /* darker indigo, hover */
  --blue-accent:#2C91D0;     /* brand cyan, accent/focus */
  --blue-50:#EDF1FA;
  --blue-100:#D9E1F3;
  --cyan-50:#E8F4FB;
  --paper:#F5F8FC;
  --white:#FFFFFF;
  --border:#DBE2F0;
  --border-soft:#E8EDF7;
  --teal:#2C91D0;
  --amber:#E8A33D;

  --font-head:"Source Serif 4",Georgia,"Times New Roman",serif;
  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --fs-eyebrow:.78rem;
  --fs-small:.94rem;
  --fs-body:1.0625rem;
  --fs-lead:clamp(1.15rem,1rem + .6vw,1.3rem);
  --fs-h3:clamp(1.25rem,1.1rem + .7vw,1.5rem);
  --fs-h2:clamp(1.75rem,1.4rem + 1.7vw,2.6rem);
  --fs-h1:clamp(2.3rem,1.7rem + 3vw,3.9rem);

  --radius-sm:10px;
  --radius:16px;
  --radius-lg:24px;
  --radius-pill:999px;

  --shadow-xs:0 1px 2px rgba(22,34,63,.06);
  --shadow-sm:0 2px 8px rgba(22,34,63,.06),0 1px 2px rgba(22,34,63,.04);
  --shadow-md:0 10px 30px -12px rgba(41,60,143,.22),0 4px 10px -6px rgba(22,34,63,.08);
  --shadow-lg:0 30px 60px -20px rgba(41,60,143,.28),0 10px 24px -12px rgba(22,34,63,.12);

  --maxw:1160px;
  --gut:clamp(1.1rem,4vw,2.5rem);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:1.65;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.12;letter-spacing:-.01em;color:var(--ink);margin:0;font-weight:600}
h1{font-size:var(--fs-h1);letter-spacing:-.02em}
h2{font-size:var(--fs-h2);letter-spacing:-.018em}
h3{font-size:var(--fs-h3)}
p{margin:0}
a{color:var(--blue-deep);text-decoration:none}
a:hover{text-decoration:underline}
img,svg{display:block;max-width:100%}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit;font-size:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--blue-accent);outline-offset:3px;border-radius:6px}

/* ============ LAYOUT HELPERS ============ */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(3.5rem,7vw,6.5rem)}
.section--paper{background:var(--paper)}
.section--blue{background:linear-gradient(160deg,#293C8F,#2C91D0);color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:var(--fs-eyebrow);font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-accent);font-family:var(--font-body)}
.eyebrow::before{content:"";width:1.6rem;height:2px;background:var(--blue-accent);border-radius:2px}
.section--blue .eyebrow{color:#CDE6F6}
.section--blue .eyebrow::before{background:#9FD2EE}
.lead{font-size:var(--fs-lead);color:var(--ink-soft);line-height:1.6}
.section-head{max-width:46rem;margin-bottom:clamp(2rem,4vw,3rem)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}
.section-head h2{margin-top:.7rem}
.section-head p{margin-top:1rem}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-weight:700;font-size:1rem;border:1.5px solid transparent;border-radius:var(--radius-sm);padding:.85rem 1.4rem;transition:transform .15s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease);text-decoration:none;line-height:1.1;min-height:48px}
.btn:hover{text-decoration:none}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn-primary{background:var(--blue);color:#fff;box-shadow:var(--shadow-md)}
.btn-primary:hover{background:var(--blue-deep);transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.btn-primary:active{transform:translateY(0)}
.btn-ghost{background:#fff;color:var(--blue-deep);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--blue-accent);background:var(--blue-50)}
.btn-light{background:#fff;color:var(--blue-deep)}
.btn-light:hover{background:var(--blue-50);transform:translateY(-1px)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-outline-light:hover{background:rgba(255,255,255,.12)}
.btn-block{width:100%}

/* ============ HEADER ============ */
.skip{position:absolute;left:1rem;top:-4rem;background:#fff;color:var(--blue-deep);padding:.7rem 1.1rem;border-radius:var(--radius-sm);font-weight:700;z-index:200;box-shadow:var(--shadow-md);transition:top .2s var(--ease)}
.skip:focus{top:1rem}

.topbar{background:var(--blue-deep);color:#fff;font-size:var(--fs-small)}
.topbar .wrap{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;align-items:center;justify-content:center;padding-block:.5rem}
.topbar a{color:#fff}
.topbar a:hover{text-decoration:underline}
.topbar .dot{width:5px;height:5px;border-radius:50%;background:#9FD2EE}
.topbar-item{display:inline-flex;align-items:center;gap:.45rem}
.topbar-item svg{width:1em;height:1em;opacity:.85}

header.site{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid transparent;transition:box-shadow .25s var(--ease),border-color .25s var(--ease)}
header.site.scrolled{box-shadow:var(--shadow-sm);border-bottom-color:var(--border-soft)}
.nav{display:flex;align-items:center;gap:1.2rem;padding-block:.7rem}
.brand{display:flex;align-items:center;gap:.7rem;flex:none}
.brand:hover{text-decoration:none}
.brand img{height:46px;width:auto}
.nav-links{display:flex;gap:.2rem;margin-left:auto;align-items:center}
.nav-links a:not(.btn){color:var(--ink-soft);font-weight:600;font-size:.96rem;padding:.5rem .65rem;border-radius:8px;transition:color .15s,background .15s;white-space:nowrap}
.nav-links a:not(.btn):hover{color:var(--blue-deep);background:var(--blue-50);text-decoration:none}
.nav-links a.active:not(.btn){color:var(--blue);background:var(--blue-50)}

/* dropdown */
.has-sub{position:relative}
.has-sub>button{display:inline-flex;align-items:center;gap:.3rem;background:none;border:0;color:var(--ink-soft);font-weight:600;font-size:.96rem;padding:.5rem .65rem;border-radius:8px;white-space:nowrap;transition:color .15s,background .15s}
.has-sub>button:hover,.has-sub[data-open="true"]>button{color:var(--blue-deep);background:var(--blue-50)}
.has-sub>button svg{width:1em;height:1em;transition:transform .2s var(--ease)}
.has-sub[data-open="true"]>button svg{transform:rotate(180deg)}
.submenu{position:absolute;top:calc(100% + .4rem);left:0;min-width:18rem;background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.5rem;display:none;grid-template-columns:1fr;gap:.1rem;z-index:120}
.submenu::before{content:"";position:absolute;top:-.6rem;left:0;right:0;height:.6rem}
.has-sub[data-open="true"] .submenu{display:grid}
.submenu a{display:flex;flex-direction:column;padding:.6rem .8rem;border-radius:10px;color:var(--ink);font-weight:600;font-size:.95rem}
.submenu a small{font-weight:500;color:var(--ink-faint);font-size:.82rem}
.submenu a:hover{background:var(--blue-50);text-decoration:none;color:var(--blue-deep)}

.nav-cta{display:flex;align-items:center;gap:.9rem;flex:none}
.nav-phones{display:flex;flex-direction:column;gap:.1rem;align-items:flex-start}
.nav-phone{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;font-size:.9rem;color:var(--ink);white-space:nowrap}
.nav-phone:hover{color:var(--blue-deep);text-decoration:none}
.nav-phone svg{width:1.05em;height:1.05em;color:var(--blue-accent)}
.nav-toggle{display:none;background:#fff;border:1.5px solid var(--border);border-radius:10px;width:48px;height:48px;align-items:center;justify-content:center;color:var(--ink);margin-left:auto}
.nav-toggle svg{width:24px;height:24px}

@media(max-width:1180px){ .nav-links{gap:0} .nav-links a:not(.btn){padding:.5rem .5rem} }
@media(max-width:980px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:inline-flex}
  .nav-links.open{display:flex;position:absolute;left:0;right:0;top:100%;flex-direction:column;background:#fff;padding:1rem var(--gut) 1.4rem;box-shadow:var(--shadow-lg);border-top:1px solid var(--border-soft);gap:.15rem;max-height:80vh;overflow:auto}
  .nav-links.open a:not(.btn){padding:.85rem .6rem;font-size:1.05rem;border-radius:10px}
  .nav-links.open .has-sub{width:100%}
  .nav-links.open .has-sub>button{width:100%;justify-content:space-between;padding:.85rem .6rem;font-size:1.05rem}
  .nav-links.open .submenu{position:static;display:grid;box-shadow:none;border:0;padding:.2rem .2rem .6rem 1rem;min-width:0}
  .nav-links.open .mobile-cta{display:flex;flex-direction:column;gap:.6rem;margin-top:.8rem}
  .nav-links.open .mobile-cta .btn{width:100%}
}
.mobile-cta{display:none}
@media(max-width:980px){.mobile-cta{display:flex}}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 88% -10%,var(--blue-50) 0%,rgba(237,241,250,0) 55%),
  radial-gradient(90% 70% at 0% 110%,var(--cyan-50) 0%,rgba(232,244,251,0) 60%),
  #fff}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:26px 26px;opacity:.5;-webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;padding-block:clamp(3rem,6vw,5.5rem)}
.hero-copy{max-width:38rem}
.trust-pills{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.4rem}
.pill{display:inline-flex;align-items:center;gap:.45rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-pill);padding:.4rem .85rem;font-size:.82rem;font-weight:600;color:var(--ink-soft);box-shadow:var(--shadow-xs)}
.pill svg{width:1.05em;height:1.05em;color:var(--teal)}
.hero h1{margin-bottom:1.1rem}
.hero h1 .accent{color:var(--blue-accent)}
.hero-lead{font-size:var(--fs-lead);color:var(--ink-soft);margin-bottom:1.7rem;max-width:34rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.reassure{display:flex;flex-wrap:wrap;gap:.4rem 1.3rem;margin-top:1.5rem;font-size:.9rem;color:var(--ink-soft)}
.reassure span{display:inline-flex;align-items:center;gap:.45rem}
.reassure svg{width:1.05em;height:1.05em;color:var(--blue-accent)}

.hero-visual{position:relative}
.hero-figure{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/4.4;background:var(--blue-50)}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.info-card{position:absolute;left:-1.2rem;bottom:-1.2rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:1.05rem 1.2rem;display:flex;gap:.9rem;align-items:center;max-width:17rem;border:1px solid var(--border-soft)}
.info-card .ic-icon{width:46px;height:46px;border-radius:12px;background:var(--blue-50);display:grid;place-items:center;color:var(--blue-accent);flex:none}
.info-card .ic-icon svg{width:24px;height:24px}
.info-card strong{display:block;font-size:1rem;color:var(--ink)}
.info-card span{font-size:.85rem;color:var(--ink-soft)}
.rating-card{position:absolute;right:-.8rem;top:1.2rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);padding:.7rem .95rem;display:flex;align-items:center;gap:.6rem;border:1px solid var(--border-soft)}
.rating-card .stars{color:var(--amber);display:flex;gap:1px}
.rating-card .stars svg{width:15px;height:15px}
.rating-card small{display:block;font-size:.74rem;color:var(--ink-soft);font-weight:600}
.rating-card b{font-size:.92rem}

@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{max-width:30rem;margin-inline:auto;width:100%}
  .hero-copy{max-width:none}
}

/* ============ PAGE HERO (inner pages) ============ */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#293C8F,#2C91D0);color:#fff}
.page-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.14) 1px,transparent 1px);background-size:24px 24px;opacity:.6;pointer-events:none}
.page-hero .wrap{position:relative;padding-block:clamp(2.6rem,5vw,4.2rem)}
.page-hero .eyebrow{color:#CDE6F6}
.page-hero .eyebrow::before{background:#9FD2EE}
.page-hero h1{color:#fff;margin-top:.7rem;max-width:20ch}
.page-hero p{color:#DCE8F6;font-size:var(--fs-lead);margin-top:1rem;max-width:54ch}
.crumb{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.86rem;color:#C2D6EC;margin-bottom:.2rem}
.crumb a{color:#fff;font-weight:600}
.crumb a:hover{text-decoration:underline}
.crumb svg{width:.9em;height:.9em;opacity:.7}

/* ============ TRUST STRIP ============ */
.trust-strip{border-block:1px solid var(--border-soft);background:#fff}
.trust-strip .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem 2rem;padding-block:1.5rem}
.trust-strip .ts-lead{font-weight:600;color:var(--ink-soft);font-size:.92rem;max-width:15rem}
.trust-badges{display:flex;flex-wrap:wrap;gap:.7rem 1.4rem;align-items:center}
.tbadge{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;color:var(--ink);font-size:.95rem}
.tbadge svg{width:1.4rem;height:1.4rem;color:var(--blue-accent);flex:none}
.tbadge small{display:block;font-weight:500;font-size:.74rem;color:var(--ink-faint);letter-spacing:.02em}

/* ============ CARD GRID (conditions / services) ============ */
.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:1.1rem}
.cond-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1.4rem;display:flex;flex-direction:column;gap:.7rem;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);position:relative}
.cond-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue-100)}
.cond-icon{width:52px;height:52px;border-radius:14px;background:var(--blue-50);display:grid;place-items:center;color:var(--blue-accent);transition:background .25s,color .25s}
.cond-card:hover .cond-icon{background:var(--blue);color:#fff}
.cond-icon svg{width:27px;height:27px}
.cond-card h3{font-size:1.18rem;font-weight:600}
.cond-card p{color:var(--ink-soft);font-size:.96rem}
.cond-link{margin-top:auto;font-weight:700;font-size:.93rem;color:var(--blue-accent);display:inline-flex;align-items:center;gap:.35rem}
.cond-card:hover .cond-link{gap:.6rem}
.cond-link svg{width:1.05em;height:1.05em;transition:transform .2s var(--ease)}
.cond-card a.cond-link::after{content:"";position:absolute;inset:0;border-radius:var(--radius)}
.cond-link:hover{text-decoration:none}

/* ============ SERVICES (numbered list) ============ */
.svc-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}
.svc{display:flex;gap:1.05rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem 1.4rem;transition:box-shadow .25s var(--ease),border-color .25s}
.svc:hover{box-shadow:var(--shadow-sm);border-color:var(--blue-100)}
.svc-num{font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--blue-accent);background:var(--blue-50);width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex:none}
.svc h3{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}
.svc p{color:var(--ink-soft);font-size:.95rem}
.svc-cta{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:.8rem 1.2rem;align-items:center;background:var(--blue-50);border:1px solid var(--blue-100);border-radius:var(--radius);padding:1.2rem 1.5rem}
.svc-cta p{font-weight:600;color:var(--ink);margin-right:auto}
.svc-cta p span{display:block;font-weight:500;color:var(--ink-soft);font-size:.92rem}

/* ============ ABOUT / FEATURE ============ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-figure{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:5/5.4;box-shadow:var(--shadow-lg);background:var(--blue-50)}
.about-figure img{width:100%;height:100%;object-fit:cover}
.about-stats{position:absolute;right:1rem;bottom:1rem;left:1rem;display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.stat{background:rgba(255,255,255,.96);border-radius:14px;padding:.85rem 1rem;backdrop-filter:blur(6px);box-shadow:var(--shadow-sm)}
.stat b{font-family:var(--font-head);font-size:1.5rem;color:var(--blue);display:block;line-height:1}
.stat span{font-size:.8rem;color:var(--ink-soft);font-weight:600}
.feature-list{display:grid;gap:1.1rem;margin-top:1.6rem}
.feat{display:flex;gap:.9rem}
.feat-ic{width:44px;height:44px;border-radius:12px;background:var(--blue-50);color:var(--blue-accent);display:grid;place-items:center;flex:none}
.feat-ic svg{width:23px;height:23px}
.feat h3{font-size:1.05rem;font-weight:600;margin-bottom:.15rem}
.feat p{color:var(--ink-soft);font-size:.95rem}
@media(max-width:840px){.about-grid{grid-template-columns:1fr}.about-figure{max-width:30rem;margin-inline:auto;width:100%}}

/* ============ TEAM ============ */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.2rem}
.member{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s var(--ease);display:flex;flex-direction:column}
.member:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.member-photo{aspect-ratio:4/3.6;background:var(--blue-50);position:relative;overflow:hidden}
.member-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.member-body{padding:1.2rem 1.3rem 1.4rem;display:flex;flex-direction:column;flex:1}
.member h3{font-size:1.18rem;font-weight:600}
.member .qual{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:700;color:var(--blue-accent);background:var(--blue-50);padding:.25rem .65rem;border-radius:var(--radius-pill);margin-block:.5rem .55rem;align-self:flex-start}
.member .locs{font-size:.82rem;color:var(--ink-faint);font-weight:600;margin-bottom:.6rem}
.member p{color:var(--ink-soft);font-size:.93rem}
.member .member-book{margin-top:1rem}
.team-photo{margin:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--blue-50)}
.team-photo img{display:block;width:100%;height:auto}
.team-photo figcaption{padding:1rem 1.3rem;font-size:.92rem;color:var(--ink-soft);text-align:center;background:#fff;border-top:1px solid var(--border-soft)}
.roster{list-style:none;margin:2rem 0 0;padding:0;display:flex;flex-direction:column;gap:.8rem}
.roster li{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.3rem}
.roster strong{display:block;color:var(--blue-deep);font-size:1.08rem;font-weight:600}
.roster span{display:block;color:var(--ink-soft);font-size:.9rem;margin-top:.2rem}
.roster .btn{flex:none}
@media(max-width:560px){.roster li{flex-direction:column;align-items:stretch}.roster .btn{width:100%}}

/* ============ TESTIMONIALS ============ */
.tgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.2rem}
.tcard{background:#fff;border:1px solid var(--border-soft);border-radius:var(--radius);padding:1.5rem 1.5rem 1.3rem;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:1rem}
.tstars{display:flex;gap:2px;color:var(--amber)}
.tstars svg{width:18px;height:18px}
.tcard blockquote{margin:0;font-size:1.02rem;color:var(--ink);line-height:1.6}
.tcard .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.tavatar{width:42px;height:42px;border-radius:50%;background:var(--blue-100);color:var(--blue-deep);display:grid;place-items:center;font-weight:700;font-family:var(--font-head);flex:none}
.tcard .who b{font-size:.95rem}
.tcard .who div span{display:block;font-size:.82rem;color:var(--ink-faint);font-weight:500}

/* ============ LOCATIONS ============ */
.loc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.1rem}
.loc-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem 1.4rem 1.3rem;display:flex;flex-direction:column;gap:.55rem;transition:box-shadow .25s var(--ease),border-color .25s,transform .25s var(--ease)}
.loc-card:hover{box-shadow:var(--shadow-md);border-color:var(--blue-100);transform:translateY(-3px)}
.loc-card .loc-name{display:flex;align-items:center;gap:.55rem;font-family:var(--font-head);font-weight:600;font-size:1.2rem;color:var(--ink)}
.loc-card .loc-name svg{width:1.15em;height:1.15em;color:var(--blue-accent);flex:none}
.loc-card .venue{font-weight:600;color:var(--ink-soft);font-size:.95rem}
.loc-card address{font-style:normal;color:var(--ink-soft);font-size:.95rem;line-height:1.5}
.loc-card .loc-phone{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--blue-deep);margin-top:.2rem}
.loc-card .loc-phone svg{width:1.05em;height:1.05em;color:var(--blue-accent)}
.loc-card .loc-foot{margin-top:auto;padding-top:.9rem}

/* ============ PROSE (service / about article) ============ */
.layout-2col{display:grid;grid-template-columns:1fr 19rem;gap:clamp(2rem,4vw,3.5rem);align-items:start}
@media(max-width:900px){.layout-2col{grid-template-columns:1fr}}
.prose{max-width:68ch}
.prose>*+*{margin-top:1.1rem}
.prose h2{font-size:clamp(1.5rem,1.2rem + 1.2vw,2rem);margin-top:2.4rem}
.prose h3{font-size:var(--fs-h3);margin-top:1.8rem}
.prose p{color:var(--ink-soft)}
.prose strong{color:var(--ink)}
.prose ul.ticks{display:grid;gap:.6rem;margin-top:1rem}
.prose ul.ticks li{position:relative;padding-left:2rem;color:var(--ink-soft)}
.prose ul.ticks li::before{content:"";position:absolute;left:0;top:.1em;width:1.35rem;height:1.35rem;border-radius:50%;background:var(--blue-50);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232C91D0' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-size:.85rem;background-repeat:no-repeat;background-position:center}
.prose figure{margin:1.6rem 0}
.prose figure img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.prose figcaption{font-size:.85rem;color:var(--ink-faint);margin-top:.5rem}
.lead-img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);aspect-ratio:16/8;object-fit:cover;margin-bottom:1.8rem}

/* sticky aside card */
.aside-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.6rem 1.5rem;box-shadow:var(--shadow-sm);position:sticky;top:96px}
.aside-card h3{font-size:1.25rem;margin-bottom:.5rem}
.aside-card p{color:var(--ink-soft);font-size:.95rem;margin-bottom:1.1rem}
.aside-card .btn{margin-bottom:.6rem}
.aside-card .call{display:inline-flex;align-items:center;gap:.5rem;color:var(--blue-deep);font-weight:700}
.aside-card .call svg{width:1.05em;height:1.05em;color:var(--blue-accent)}
.aside-card hr{border:0;border-top:1px solid var(--border-soft);margin:1.2rem 0}
.aside-card .mini-list{display:grid;gap:.5rem;font-size:.92rem;color:var(--ink-soft)}
.aside-card .mini-list a{font-weight:600;color:var(--blue-deep)}
@media(max-width:900px){.aside-card{position:static}}

/* related services chips */
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{display:inline-flex;align-items:center;flex:0 0 auto;white-space:nowrap;gap:.4rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-pill);padding:.6rem 1.1rem;font-size:.9rem;font-weight:600;color:var(--blue-deep);transition:border-color .2s,background .2s}
.chip svg{flex:0 0 auto;width:1.15rem;height:1.15rem}
.chip:hover{border-color:var(--blue-accent);background:var(--blue-50);text-decoration:none}

/* ============ FAQ ============ */
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.faq-list{display:grid;gap:.7rem}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq-item[open]{border-color:var(--blue-100);box-shadow:var(--shadow-sm)}
.faq-item summary{list-style:none;cursor:pointer;padding:1.15rem 1.3rem;display:flex;align-items:center;gap:1rem;font-weight:600;font-size:1.05rem;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:focus-visible{outline:3px solid var(--blue-accent);outline-offset:-3px}
.faq-q{flex:1}
.faq-ic{width:30px;height:30px;border-radius:8px;background:var(--blue-50);color:var(--blue-accent);display:grid;place-items:center;flex:none;transition:transform .25s var(--ease),background .2s,color .2s}
.faq-ic svg{width:18px;height:18px}
.faq-item[open] .faq-ic{background:var(--blue);color:#fff;transform:rotate(45deg)}
.faq-body{padding:0 1.3rem 1.2rem;color:var(--ink-soft);font-size:.97rem}
.faq-body p{max-width:62ch}
.faq-body p+p{margin-top:.7rem}
.faq-aside{background:linear-gradient(165deg,#293C8F,#2C91D0);color:#fff;border-radius:var(--radius-lg);padding:2rem 1.8rem;position:sticky;top:96px;box-shadow:var(--shadow-lg)}
.faq-aside .eyebrow{color:#CDE6F6}
.faq-aside .eyebrow::before{background:#9FD2EE}
.faq-aside h3{color:#fff;font-size:1.5rem;margin:.6rem 0}
.faq-aside p{color:#DCE8F6;margin-bottom:1.4rem}
.faq-aside .btn{margin-bottom:.7rem}
.faq-aside .call{display:inline-flex;align-items:center;gap:.5rem;color:#fff;font-weight:700;font-size:1.1rem}
.faq-aside .call:hover{text-decoration:none;opacity:.9}
.faq-aside .call svg{width:1.1em;height:1.1em}
@media(max-width:860px){.faq-grid{grid-template-columns:1fr}.faq-aside{position:static;order:-1}}

/* ============ CONTACT / FORM ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3rem);align-items:start}
.contact-info{display:grid;gap:1rem}
.cinfo{display:flex;gap:1rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.3rem}
.cinfo-ic{width:46px;height:46px;border-radius:12px;background:var(--blue-50);color:var(--blue-accent);display:grid;place-items:center;flex:none}
.cinfo-ic svg{width:23px;height:23px}
.cinfo h3{font-size:1.02rem;font-weight:600;margin-bottom:.15rem}
.cinfo p,.cinfo a{color:var(--ink-soft);font-size:.96rem}
.cinfo a{font-weight:600;color:var(--blue-deep)}
.hours-row{display:flex;justify-content:space-between;gap:1rem;padding:.35rem 0;border-bottom:1px dashed var(--border);font-size:.95rem}
.hours-row:last-child{border-bottom:0}
.hours-row span:first-child{color:var(--ink-soft)}
.hours-row span:last-child{font-weight:600}

.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.2rem);box-shadow:var(--shadow-md)}
.form-card h3{font-size:1.4rem;margin-bottom:.3rem}
.form-card .sub{color:var(--ink-soft);font-size:.96rem;margin-bottom:1.4rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;font-size:.92rem;margin-bottom:.4rem;color:var(--ink)}
.field label .req{color:#C0392B}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.8rem .9rem;min-height:48px;transition:border-color .15s,box-shadow .15s,background .15s}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-accent);background:#fff;box-shadow:0 0 0 3px rgba(44,145,208,.18)}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#C0392B;background:#FEF6F5}
.field .err{display:none;color:#B33122;font-size:.84rem;font-weight:600;margin-top:.35rem}
.field.invalid .err{display:block}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-note{font-size:.82rem;color:var(--ink-faint);margin-top:.4rem}
.form-status{display:none;align-items:flex-start;gap:.7rem;background:#ECFBF4;border:1px solid #B7E8CF;color:#0B6B43;border-radius:var(--radius-sm);padding:1rem 1.1rem;font-weight:600;font-size:.96rem;margin-bottom:1.2rem}
.form-status.show{display:flex}
.form-status svg{width:1.3rem;height:1.3rem;flex:none;margin-top:1px}
.form-error{display:none;align-items:flex-start;gap:.7rem;background:#FCEDED;border:1px solid #F2C2C2;color:#9B2226;border-radius:var(--radius-sm);padding:1rem 1.1rem;font-weight:600;font-size:.96rem;margin-bottom:1.2rem}
.form-error.show{display:flex}
.form-error svg{width:1.3rem;height:1.3rem;flex:none;margin-top:1px}
.form-error a{color:inherit;text-decoration:underline}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
@media(max-width:460px){.field-row{grid-template-columns:1fr}}

/* booking embed */
.booking-embed{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:#fff;padding:1rem 1rem .4rem;overflow:hidden}
#ob-iframe-container{width:100%}
#ob-iframe{display:block;width:100%;min-height:800px;border:0;border-radius:var(--radius)}
.booking-note{margin:.9rem .3rem 0;font-size:.88rem;color:var(--ink-soft);line-height:1.55;text-align:center}
.booking-note a{font-weight:600}

/* ============ CTA BAND ============ */
.cta-band{background:linear-gradient(135deg,#1E2C6E,#293C8F 45%,#2C91D0);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 80% 0%,rgba(255,255,255,.14),transparent 60%);pointer-events:none}
.cta-band .wrap{position:relative}
.cta-band h2{color:#fff}
.cta-band p{color:#DCE8F6;max-width:38rem;margin:.9rem auto 1.8rem;font-size:var(--fs-lead)}
.cta-band .hero-actions{justify-content:center}

/* ============ FOOTER ============ */
footer.site{background:#101B36;color:#AEBBD4;font-size:.95rem;padding-block:clamp(3rem,5vw,4rem) 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem}
.foot-brand img{height:52px;width:auto;margin-bottom:.9rem;filter:brightness(0) invert(1)}
.foot-brand p{max-width:24rem;line-height:1.6}
footer.site h4{color:#fff;font-family:var(--font-body);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 1rem}
.foot-links{display:grid;gap:.55rem}
.foot-links a,.foot-contact a{color:#AEBBD4}
.foot-links a:hover,.foot-contact a:hover{color:#fff;text-decoration:none}
.foot-contact{display:grid;gap:.7rem}
.foot-contact .row{display:flex;gap:.6rem;align-items:flex-start}
.foot-contact svg{width:1.1em;height:1.1em;color:#9FD2EE;flex:none;margin-top:.25rem}
.socials{display:flex;gap:.6rem;margin-top:1.1rem}
.socials a{width:40px;height:40px;border-radius:10px;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;color:#CFE0F2}
.socials a:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none}
.socials svg{width:19px;height:19px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;padding-top:1.5rem;display:flex;flex-wrap:wrap;gap:.6rem 1.5rem;align-items:center;justify-content:space-between;font-size:.86rem;color:#8B9AB8}
.foot-bottom a{color:#8B9AB8}
.foot-bottom a:hover{color:#fff;text-decoration:none}
.foot-bottom .legal{display:flex;flex-wrap:wrap;gap:.4rem 1.2rem}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}
@media(max-width:480px){.foot-grid{grid-template-columns:1fr}}

/* ============ STICKY MOBILE BOOKING BAR ============ */
.mobile-book{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:.6rem;padding:.7rem var(--gut);padding-bottom:calc(.7rem + env(safe-area-inset-bottom));background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-top:1px solid var(--border);box-shadow:0 -6px 20px -10px rgba(22,34,63,.3)}
.mobile-book .btn{flex:1;min-height:50px}
@media(max-width:980px){.mobile-book{display:flex}body{padding-bottom:74px}}

/* ============ REVEAL ============ */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}
