/* ============================================================
   Orthocare Physiotherapy Clinic — Shared Stylesheet
   Edit colors / fonts here once and every page updates.
   ============================================================ */

:root{
  /* Palette */
  --bg:           #f7f4ee;   /* warm off-white page background */
  --surface:      #ffffff;   /* cards */
  --ink:          #15302c;   /* primary text (deep pine) */
  --ink-soft:     #4c5f5a;   /* secondary text */
  --primary:      #0e6b62;   /* brand teal */
  --primary-dark: #0a4d46;
  --primary-tint: #e3efec;   /* pale teal wash */
  --accent:       #e08a4b;   /* warm amber accent */
  --line:         #e2ddd2;   /* hairlines / borders */

  --radius:       18px;
  --radius-sm:    12px;
  --shadow:       0 18px 40px -24px rgba(14,70,62,.45);
  --shadow-soft:  0 8px 24px -18px rgba(14,70,62,.5);
  --maxw:         1140px;

  --serif: "Fraunces", Georgia, serif;
  --sans:  "Hanken Grotesk", system-ui, sans-serif;
}

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

html{ scroll-behavior:smooth; }

body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.1; letter-spacing:-.02em; }
h1{ font-size:clamp(2.4rem,6vw,4rem); }
h2{ font-size:clamp(1.9rem,4vw,2.8rem); }
h3{ font-size:1.25rem; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }

section{ padding:clamp(64px,9vw,120px) 0; }

.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:.8rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--primary);
  margin-bottom:18px;
}
.eyebrow::before{
  content:""; width:26px; height:2px; background:var(--accent);
}

.lead{ font-size:1.12rem; color:var(--ink-soft); max-width:54ch; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--sans); font-weight:700; font-size:1rem;
  padding:15px 28px; border-radius:999px; cursor:pointer;
  border:2px solid transparent; transition:transform .25s, box-shadow .25s, background .25s;
}
.btn-primary{ background:var(--primary); color:#fff; box-shadow:var(--shadow-soft); }
.btn-primary:hover{ background:var(--primary-dark); transform:translateY(-3px); }
.btn-ghost{ background:transparent; color:var(--primary); border-color:var(--primary); }
.btn-ghost:hover{ background:var(--primary); color:#fff; transform:translateY(-3px); }

/* ============================================================
   Header / Nav
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(247,244,238,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; min-height:74px;
}
.brand{ flex:0 0 auto; display:flex; align-items:center; gap:11px; font-family:var(--serif); font-weight:600; font-size:1.35rem; }
.brand .mark{
  width:38px; height:38px; border-radius:11px; flex:none;
  background:var(--primary); color:#fff;
  display:grid; place-items:center; font-size:1.2rem;
}
/* Logo image (header) */
.logo-img{ height:54px; width:auto; max-width:260px; display:block; }
.brand small{ display:block; font-family:var(--sans); font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-soft); font-weight:600; }

.nav-links{ display:flex; align-items:center; gap:34px; list-style:none; }
.nav-links a{ font-weight:600; font-size:.98rem; position:relative; padding:4px 0; color:var(--ink-soft); transition:color .2s; }
.nav-links a:hover,
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{
  content:""; position:absolute; left:0; bottom:-3px; width:100%; height:2px; background:var(--accent); border-radius:2px;
}
.nav-cta{ display:flex; align-items:center; gap:14px; }

.nav-toggle{ display:none; background:none; border:0; cursor:pointer; width:42px; height:42px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px auto; transition:transform .3s ease, opacity .2s ease; }
.nav-toggle.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity:0; }
.nav-toggle.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Nav dropdown (Treatments) ---------- */
.has-drop{ position:relative; }
.has-drop > a::after{ content:"\25BE"; margin-left:6px; font-size:.72em; color:var(--primary); vertical-align:middle; }
.has-drop::after{ content:""; position:absolute; left:0; right:0; top:100%; height:18px; }
.drop-toggle{ display:none; }
.drop{
  list-style:none; position:absolute; top:calc(100% + 14px); left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:280px; background:#fff; border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow); padding:8px; z-index:60;
  opacity:0; visibility:hidden; transition:opacity .22s ease, transform .22s ease;
}
.has-drop:hover .drop, .has-drop:focus-within .drop{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.drop li{ width:100%; }
.drop a{ display:block; padding:11px 16px; border-radius:9px; font-size:.93rem; font-weight:600; color:var(--ink-soft); white-space:nowrap; }
.drop a::after{ display:none; }
.drop a:hover{ background:var(--primary-tint); color:var(--primary); }
.card[id]{ scroll-margin-top:96px; }

/* ============================================================
   Hero
   ============================================================ */
.hero{ position:relative; padding:clamp(70px,10vw,120px) 0 clamp(60px,8vw,100px); }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }
.hero h1 span{ color:var(--primary); font-style:italic; }
.hero .lead{ margin:24px 0 34px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-stats{ display:flex; flex-wrap:wrap; gap:38px; margin-top:46px; }
.hero-stats .num{ font-family:var(--serif); font-size:2rem; color:var(--primary); }
.hero-stats .lbl{ font-size:.85rem; color:var(--ink-soft); }

.hero-visual{ position:relative; }
.hero-visual .photo{
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  aspect-ratio:4/5; background:var(--primary-tint);
}
.hero-visual .photo img{ width:100%; height:100%; object-fit:cover; }
.hero-badge{
  position:absolute; bottom:-24px; left:-24px;
  background:var(--surface); border-radius:var(--radius-sm);
  padding:18px 22px; box-shadow:var(--shadow); display:flex; align-items:center; gap:14px;
}
.hero-badge .ico{ width:44px; height:44px; border-radius:12px; background:var(--primary-tint); display:grid; place-items:center; font-size:1.3rem; }
.hero-badge b{ display:block; font-family:var(--serif); }
.hero-badge small{ color:var(--ink-soft); }

/* ============================================================
   Trust bar
   ============================================================ */
.trust{ background:var(--primary); color:#fff; padding:26px 0; }
.trust .wrap{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:24px; align-items:center; }
.trust-item{ display:flex; align-items:center; gap:12px; font-weight:600; }
.trust-item .ico{ font-size:1.4rem; opacity:.9; }

/* ============================================================
   Section heading block
   ============================================================ */
.sec-head{ max-width:640px; margin-bottom:54px; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head.center .eyebrow{ }
.sec-head p{ margin-top:16px; color:var(--ink-soft); font-size:1.08rem; }

/* ============================================================
   Service cards
   ============================================================ */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 30px; transition:transform .3s, box-shadow .3s, border-color .3s;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.card .ico{
  width:58px; height:58px; border-radius:15px; background:var(--primary-tint);
  display:grid; place-items:center; font-size:1.6rem; margin-bottom:22px;
}
.card h3{ margin-bottom:10px; }
.card p{ color:var(--ink-soft); font-size:.98rem; }
.card .more{ display:inline-flex; align-items:center; gap:6px; margin-top:18px; font-weight:700; color:var(--primary); font-size:.92rem; }
.card .more:hover{ gap:11px; transition:gap .2s; }

/* ============================================================
   Feature / About split
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.split .photo{ border-radius:var(--radius); overflow:hidden; aspect-ratio:5/4; box-shadow:var(--shadow); background:var(--primary-tint); }
.split .photo img{ width:100%; height:100%; object-fit:cover; }
.check-list{ list-style:none; margin-top:26px; display:grid; gap:14px; }
.check-list li{ display:flex; gap:13px; align-items:flex-start; color:var(--ink-soft); }
.check-list .tick{ flex:none; width:24px; height:24px; border-radius:50%; background:var(--primary); color:#fff; display:grid; place-items:center; font-size:.8rem; margin-top:3px; }

/* ============================================================
   Steps
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; counter-reset:s; }
.step{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:34px 30px; position:relative; }
.step::before{
  counter-increment:s; content:counter(s,decimal-leading-zero);
  font-family:var(--serif); font-size:1.6rem; color:var(--accent); font-weight:600;
}
.step h3{ margin:12px 0 8px; }
.step p{ color:var(--ink-soft); font-size:.96rem; }

/* ============================================================
   Testimonials
   ============================================================ */
.t-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.t-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:32px 30px; display:flex; flex-direction:column; gap:18px; }
.stars{ color:var(--accent); letter-spacing:2px; }
.t-card blockquote{ font-size:1.04rem; color:var(--ink); }
.t-card .who{ display:flex; align-items:center; gap:13px; margin-top:auto; }
.t-card .avatar{ width:46px; height:46px; border-radius:50%; background:var(--primary-tint); color:var(--primary); display:grid; place-items:center; font-family:var(--serif); font-size:1.1rem; font-weight:600; }
.t-card .who b{ display:block; }
.t-card .who small{ color:var(--ink-soft); }

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{ background:var(--primary); color:#fff; border-radius:var(--radius); padding:clamp(40px,6vw,72px); text-align:center; }
.cta-band h2{ color:#fff; }
.cta-band p{ color:rgba(255,255,255,.85); margin:16px auto 30px; max-width:50ch; }
.cta-band .btn-primary{ background:#fff; color:var(--primary); }
.cta-band .btn-primary:hover{ background:var(--bg); }

/* ============================================================
   Contact / Form
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:54px; align-items:start; }
.info-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:30px; margin-bottom:18px; display:flex; gap:16px; align-items:flex-start; }
.info-card .ico{ width:48px; height:48px; flex:none; border-radius:13px; background:var(--primary-tint); display:grid; place-items:center; font-size:1.3rem; }
.info-card h3{ font-size:1.05rem; margin-bottom:4px; }
.info-card p, .info-card a{ color:var(--ink-soft); }
.info-card a:hover{ color:var(--primary); }

.form{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,4vw,40px); box-shadow:var(--shadow-soft); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-weight:600; font-size:.92rem; margin-bottom:8px; }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--sans); font-size:1rem; color:var(--ink);
  padding:14px 16px; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  background:var(--bg); transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:0; border-color:var(--primary); box-shadow:0 0 0 4px var(--primary-tint);
}
.field textarea{ resize:vertical; min-height:120px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form .btn-primary{ width:100%; }
.form-note{ font-size:.85rem; color:var(--ink-soft); margin-top:14px; text-align:center; }

.map-embed{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); margin-top:40px; height:340px; }
.map-embed iframe{ width:100%; height:100%; border:0; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:760px; margin-inline:auto; }
.faq details{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); padding:4px 24px; margin-bottom:14px; }
.faq summary{ cursor:pointer; font-family:var(--serif); font-size:1.15rem; padding:18px 0; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-size:1.5rem; color:var(--primary); transition:transform .3s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ padding-bottom:20px; color:var(--ink-soft); }

/* ============================================================
   Clinic gallery (cards)
   ============================================================ */
.gallery{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.gcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:12px 12px 6px; box-shadow:var(--shadow-soft); transition:transform .3s, box-shadow .3s; }
.gcard:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.gcard .pic{ border-radius:12px; overflow:hidden; aspect-ratio:16/9; }
.gcard .pic img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gcard:hover .pic img{ transform:scale(1.06); }
.gcard .cap{ text-align:center; padding:13px 8px 8px; font-weight:600; color:var(--ink); font-size:.98rem; }
@media (max-width:680px){ .gallery{ grid-template-columns:1fr; } }

/* ============================================================
   Pricing / charges
   ============================================================ */
.price-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:26px; align-items:start; }
.price-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:34px 32px; }
.price-card.accent{ background:var(--primary); color:#fff; }
.price-card h3{ margin-bottom:20px; }
.price-list{ list-style:none; display:grid; gap:0; }
.price-list li{ display:flex; justify-content:space-between; gap:18px; padding:13px 0; border-bottom:1px dashed var(--line); }
.price-list li:last-child{ border-bottom:0; }
.price-list .name{ color:var(--ink-soft); }
.price-list .amt{ font-weight:700; white-space:nowrap; }
.price-sub{ font-size:.9rem; color:var(--ink-soft); padding-left:16px; }
.price-card.accent .price-tag{ font-family:var(--serif); font-size:2.2rem; display:block; margin:6px 0 4px; }
.price-card.accent .badge{ display:inline-block; background:rgba(255,255,255,.18); padding:5px 12px; border-radius:999px; font-size:.78rem; font-weight:700; letter-spacing:.08em; margin-bottom:16px; }
.price-card.accent ul{ list-style:none; display:grid; gap:11px; margin-top:8px; }
.price-card.accent li{ display:flex; gap:11px; align-items:flex-start; font-size:.96rem; color:rgba(255,255,255,.92); }
.price-card.accent li::before{ content:"●"; color:#fff; font-size:.6rem; margin-top:7px; }
.price-note{ text-align:center; color:var(--ink-soft); font-size:.9rem; margin-top:22px; }
@media (max-width:780px){ .price-grid{ grid-template-columns:1fr; } }

/* Poster banner */
.poster-banner{ max-width:760px; margin:0 auto; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); }
.poster-banner img{ width:100%; display:block; }
.page-hero{ background:var(--primary-tint); padding:clamp(56px,8vw,96px) 0; text-align:center; }
.page-hero .crumb{ font-size:.85rem; color:var(--ink-soft); margin-bottom:14px; letter-spacing:.04em; }
.page-hero .crumb a:hover{ color:var(--primary); }
.page-hero p{ margin:18px auto 0; color:var(--ink-soft); max-width:56ch; font-size:1.08rem; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ position:relative; background:var(--ink); color:#aebbb6; padding:72px 0 0; }
.site-footer::before{ content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,#19C3B4,#0e6b62 55%,#e08a4b); }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1.1fr 1.25fr 1.5fr; gap:42px; }

.foot-head{ font-family:var(--sans); font-size:.92rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#2bd4c4; margin-bottom:20px; }
.foot-head-sm{ margin:28px 0 16px; font-size:.82rem; }

.foot-about .brand-footer img{ height:54px; width:auto; margin-bottom:18px; }
.foot-about p{ font-size:.95rem; color:#a3b2ad; line-height:1.7; max-width:38ch; }

.foot-social{ display:flex; gap:11px; }
.foot-social a{ width:38px; height:38px; border-radius:9px; display:grid; place-items:center; color:#fff; transition:transform .2s, filter .2s; }
.foot-social a:hover{ transform:translateY(-3px); filter:brightness(1.1); }
.foot-social .s-ig{ background:#E1306C; }
.foot-social .s-fb{ background:#1877F2; }
.foot-social .s-yt{ background:#FF0000; }
.foot-social .s-wa{ background:#25D366; }

.foot-links{ list-style:none; display:grid; gap:0; }
.foot-links li{ border-bottom:1px solid rgba(255,255,255,.08); }
.foot-links a{ display:flex; align-items:center; gap:9px; padding:11px 0; font-size:.95rem; color:#bcc8c3; transition:color .2s, padding-left .2s; overflow-wrap:anywhere; }
.foot-links a::before{ content:"›"; color:#2bd4c4; font-size:1.15rem; line-height:1; font-weight:700; }
.foot-links a:hover{ color:#fff; padding-left:6px; }

.foot-contact{ display:flex; gap:13px; align-items:flex-start; margin-bottom:18px; }
.foot-contact .ci{ flex:none; width:34px; height:34px; border-radius:50%; background:rgba(43,212,196,.14); color:#2bd4c4; display:grid; place-items:center; }
.foot-contact > div{ font-size:.95rem; color:#bcc8c3; line-height:1.6; overflow-wrap:anywhere; word-break:break-word; }
.foot-contact b{ color:#e7eeeb; font-weight:600; }
.foot-contact a{ color:#bcc8c3; }
.foot-contact a:hover{ color:#fff; }

.foot-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:56px; padding:22px 0; text-align:center; font-size:.86rem; color:#7f9590; }

/* ---------- Floating action buttons (WhatsApp / Call / Back-to-top) ---------- */
.fab-stack{ position:fixed; right:22px; bottom:22px; z-index:60; display:flex; flex-direction:column; gap:13px; align-items:center; }
.fab{ width:56px; height:56px; border-radius:50%; display:grid; place-items:center; color:#fff; border:0; cursor:pointer; box-shadow:0 10px 28px -8px rgba(0,0,0,.45); transition:transform .25s, background .2s, opacity .25s, visibility .25s; }
.fab:hover{ transform:scale(1.08); }
.wa-float{ background:#25d366; box-shadow:0 10px 28px -8px rgba(37,211,102,.7); }
.call-float{ background:var(--primary); box-shadow:0 12px 28px -8px rgba(14,107,98,.65); }
.call-float:hover{ background:var(--primary-dark); }
.to-top{ background:var(--ink); opacity:0; visibility:hidden; transform:translateY(12px); }
.to-top.show{ opacity:1; visibility:visible; transform:none; }
.to-top:hover{ background:var(--primary-dark); transform:translateY(-3px); }
@media (max-width:430px){ .fab-stack{ right:16px; bottom:16px; gap:11px; } .fab{ width:52px; height:52px; } }

/* ---------- Reveal on scroll ---------- */
.reveal{ transition:opacity .7s ease, transform .7s ease; }
.reveal.pre{ opacity:0; transform:translateY(26px); }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:980px){
  .nav-links{
    position:fixed; inset:74px 0 auto 0; z-index:45; background:var(--bg);
    flex-direction:column; gap:0; padding:10px 24px 24px;
    border-bottom:1px solid var(--line); transform:translateY(-130%);
    transition:transform .35s ease; box-shadow:var(--shadow);
    max-height:calc(100vh - 74px); overflow-y:auto;
  }
  .nav-links.open{ transform:none; }
  .nav-links li{ width:100%; }
  .nav-links > li > a{ display:block; padding:14px 0; border-bottom:1px solid var(--line); }
  .nav .nav-cta .btn{ display:none; }
  .nav-toggle{ display:block; }
  .has-drop{ display:flex; flex-wrap:wrap; align-items:stretch; }
  .has-drop > a{ flex:1; }
  .has-drop > a::after{ display:none; }
  .has-drop::after{ display:none; }
  .drop-toggle{ display:flex; align-items:center; justify-content:center; width:46px; background:none; border:0; border-bottom:1px solid var(--line); cursor:pointer; }
  .drop-toggle span{ display:block; width:9px; height:9px; border-right:2px solid var(--ink-soft); border-bottom:2px solid var(--ink-soft); transform:rotate(45deg); margin-top:-4px; transition:transform .3s; }
  .drop-toggle.open span{ transform:rotate(-135deg); margin-top:3px; }
  .drop{
    position:static; transform:none; opacity:1; visibility:visible;
    box-shadow:none; border:0; border-radius:0; min-width:0; width:100%; padding:0;
    max-height:0; overflow:hidden; transition:max-height .35s ease;
  }
  .drop.open{ max-height:760px; }
  .drop a{ padding:12px 0 12px 18px; border-bottom:1px solid var(--line); white-space:normal; font-weight:600; }
  .drop a:hover{ background:transparent; color:var(--primary); }
  .has-drop:hover .drop, .has-drop:focus-within .drop{ transform:none; opacity:1; visibility:visible; }
}
@media (max-width:900px){
  .hero-grid, .split, .contact-grid{ grid-template-columns:1fr; gap:42px; }
  .hero-visual{ order:-1; max-width:440px; margin-inline:auto; }
  .cards, .steps, .t-grid{ grid-template-columns:1fr 1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .cards, .steps, .t-grid, .field-row, .foot-grid{ grid-template-columns:1fr; }
  .logo-img{ height:42px; }
  .hero-stats{ gap:26px; }
  .hero-badge{ left:0; }
}
@media (max-width:430px){
  .wrap{ padding:0 18px; }
  .hero-stats{ gap:18px 28px; }
  .hero-stats .num{ font-size:1.7rem; }
  .btn{ padding:13px 22px; font-size:.95rem; }
  .hero-actions .btn{ width:100%; }
  .card, .step, .t-card, .info-card, .price-card{ padding:26px 22px; }
  .map-embed{ height:260px; }
}

/* ============================================================
   Bold home hero + modern sections
   ============================================================ */
.hero-banner{ position:relative; min-height:clamp(540px,84vh,720px); display:flex; align-items:center; overflow:hidden; }
.hero-banner .hero-bg{ position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.04); }
.hero-banner::after{ content:""; position:absolute; inset:0; background:linear-gradient(102deg, rgba(8,38,34,.94) 0%, rgba(12,62,55,.86) 42%, rgba(14,70,62,.5) 100%); }
.hero-banner-inner{ position:relative; z-index:2; color:#fff; max-width:700px; padding:48px 0; }
.hero-banner .eyebrow{ color:#7fe3d6; }
.hero-banner .eyebrow::before{ background:var(--accent); }
.hero-banner h1{ color:#fff; font-size:clamp(2.6rem,6.2vw,4.5rem); }
.hero-banner h1 span{ color:#5be3d5; font-style:italic; }
.hero-banner .lead{ color:rgba(255,255,255,.92); font-size:1.16rem; max-width:56ch; margin:22px 0 32px; }
.btn-light{ background:#fff; color:var(--primary); }
.btn-light:hover{ background:var(--bg); color:var(--primary-dark); transform:translateY(-3px); }
.hero-chips{ display:flex; flex-wrap:wrap; gap:14px 26px; margin-top:36px; }
.hero-chips .chip{ display:flex; align-items:center; gap:10px; color:#fff; font-weight:600; font-size:.96rem; }
.hero-chips .chip .ic{ width:36px; height:36px; border-radius:10px; background:rgba(255,255,255,.16); display:grid; place-items:center; font-size:1.1rem; }

.stat-strip{ position:relative; z-index:5; }
.stat-strip .wrap{ margin-top:-58px; }
.stat-strip .inner{ background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); padding:30px clamp(18px,4vw,40px); display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.stat-strip .st{ text-align:center; padding:6px 10px; }
.stat-strip .st + .st{ border-left:1px solid var(--line); }
.stat-strip .st .n{ font-family:var(--serif); font-size:clamp(1.7rem,3vw,2.4rem); color:var(--primary); line-height:1; }
.stat-strip .st .l{ font-size:.85rem; color:var(--ink-soft); margin-top:7px; }

.review-band{ background:var(--ink); }
.review-band .quote{ max-width:780px; margin:0 auto; text-align:center; color:#fff; }
.review-band .stars{ color:var(--accent); font-size:1.5rem; letter-spacing:4px; }
.review-band blockquote{ font-family:var(--serif); font-weight:500; font-size:clamp(1.4rem,3vw,2.05rem); line-height:1.32; margin:20px 0 24px; color:#fff; }
.review-band .by{ color:rgba(255,255,255,.72); font-weight:600; font-size:.98rem; }

@media (max-width:680px){
  .stat-strip .inner{ grid-template-columns:1fr 1fr; gap:18px 6px; }
  .stat-strip .st + .st{ border-left:0; }
  .stat-strip .st:nth-child(n+2){ border-left:0; }
  .stat-strip .st:nth-child(2n){ border-left:1px solid var(--line); }
}

/* ============================================================
   Contact page
   ============================================================ */
.hero-banner.compact{ min-height:clamp(300px,42vw,420px); }
.hero-banner .crumb{ color:rgba(255,255,255,.82); font-size:.9rem; margin-bottom:14px; letter-spacing:.04em; }
.hero-banner .crumb a:hover{ color:#fff; }
.contact-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cc{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:28px 22px; text-align:center; transition:transform .25s, box-shadow .25s, border-color .25s; }
.cc:hover{ transform:translateY(-5px); box-shadow:var(--shadow); border-color:transparent; }
.cc .ic{ width:54px; height:54px; border-radius:15px; background:var(--primary-tint); display:grid; place-items:center; font-size:1.5rem; margin:0 auto 16px; }
.cc h3{ font-size:1.05rem; margin-bottom:6px; }
.cc a, .cc p{ color:var(--ink-soft); font-size:.95rem; overflow-wrap:anywhere; }
.cc a:hover{ color:var(--primary); }
.hours-card{ background:var(--bg); border:1px solid var(--line); border-radius:var(--radius); padding:26px 28px; }
.hours-card h3{ margin-bottom:12px; }
.hours-row{ display:flex; justify-content:space-between; gap:14px; padding:9px 0; border-bottom:1px dashed var(--line); font-size:.96rem; }
.hours-row:last-child{ border-bottom:0; }
.hours-row .d{ color:var(--ink-soft); }
.hours-row .t{ font-weight:600; }
.hours-row .t.closed{ color:var(--accent); }
@media (max-width:900px){ .contact-cards{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .contact-cards{ grid-template-columns:1fr; } }

/* ============================================================
   Gallery lightbox + video grid
   ============================================================ */
.gallery a.pic{ display:block; cursor:zoom-in; }
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(8,20,18,.94); display:none; align-items:center; justify-content:center; padding:20px; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:0 20px 60px -10px rgba(0,0,0,.6); }
.lb-btn{ position:absolute; background:rgba(255,255,255,.14); color:#fff; border:0; width:48px; height:48px; border-radius:50%; font-size:1.6rem; line-height:1; cursor:pointer; display:grid; place-items:center; transition:background .2s; }
.lb-btn:hover{ background:rgba(255,255,255,.3); }
.lb-close{ top:18px; right:18px; }
.lb-prev{ left:14px; top:50%; transform:translateY(-50%); }
.lb-next{ right:14px; top:50%; transform:translateY(-50%); }
@media (max-width:560px){ .lb-btn{ width:42px; height:42px; font-size:1.3rem; } .lb-prev{ left:6px; } .lb-next{ right:6px; } }

.video-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.video-card{ background:#000; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); aspect-ratio:16/9; }
.video-card video{ width:100%; height:100%; object-fit:cover; display:block; background:#000; }
@media (max-width:760px){ .video-grid{ grid-template-columns:1fr; } }

/* ============================================================
   Chat assistant (guided questions -> WhatsApp)
   ============================================================ */
.chat-fab{ position:fixed; left:22px; bottom:22px; z-index:70; display:flex; align-items:center; gap:10px;
  background:var(--primary); color:#fff; border:0; cursor:pointer; padding:11px 18px 11px 11px; border-radius:999px;
  box-shadow:0 12px 28px -8px rgba(14,107,98,.6); font-family:var(--sans); font-weight:700; font-size:.94rem; transition:transform .25s; }
.chat-fab:hover{ transform:translateY(-3px); }
.chat-fab .av{ width:34px; height:34px; border-radius:50%; background:#fff; display:grid; place-items:center; flex:none; }
.chat-fab.hide{ display:none; }
.chat-panel{ position:fixed; left:22px; bottom:22px; z-index:71; width:344px; max-width:calc(100vw - 32px);
  background:#fff; border-radius:18px; overflow:hidden; box-shadow:0 26px 60px -16px rgba(8,30,26,.55); display:none; flex-direction:column; }
.chat-panel.open{ display:flex; }
.chat-head{ background:var(--primary); color:#fff; padding:15px 18px; display:flex; align-items:center; gap:12px; }
.chat-head .av{ width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.16); display:grid; place-items:center; flex:none; }
.chat-head b{ display:block; font-family:var(--serif); font-size:1.05rem; line-height:1.1; }
.chat-head small{ opacity:.85; font-size:.76rem; }
.chat-head .x{ margin-left:auto; background:rgba(255,255,255,.14); border:0; color:#fff; font-size:1.4rem; cursor:pointer; line-height:1; width:34px; height:34px; border-radius:50%; display:grid; place-items:center; flex:none; transition:background .2s; }
.chat-head .x:hover{ background:rgba(255,255,255,.3); }
.chat-body{ padding:18px; background:var(--bg); max-height:58vh; overflow-y:auto; display:flex; flex-direction:column; gap:10px; }
.chat-msg{ max-width:84%; padding:11px 14px; border-radius:14px; font-size:.92rem; line-height:1.5; white-space:pre-line; }
.chat-msg.bot{ background:#fff; border:1px solid var(--line); align-self:flex-start; border-bottom-left-radius:4px; }
.chat-msg.user{ background:var(--primary); color:#fff; align-self:flex-end; border-bottom-right-radius:4px; }
.chat-opts{ display:flex; flex-wrap:wrap; gap:8px; align-self:flex-start; }
.chat-opt{ background:#fff; border:1.5px solid var(--primary); color:var(--primary); border-radius:999px; padding:8px 14px; font-size:.86rem; font-weight:600; cursor:pointer; transition:background .2s,color .2s; }
.chat-opt:hover{ background:var(--primary); color:#fff; }
.chat-wa{ display:flex; align-items:center; justify-content:center; gap:9px; background:#25d366; color:#fff; padding:13px; border-radius:12px; font-weight:700; font-size:.95rem; align-self:stretch; }
.chat-foot{ padding:8px 14px; text-align:center; font-size:.7rem; color:var(--ink-soft); background:#fff; border-top:1px solid var(--line); }
@media (max-width:480px){ .chat-fab{ left:16px; bottom:16px; } .chat-fab .lbl{ display:none; } .chat-fab{ padding:11px; }
  .chat-panel{ left:0; right:0; bottom:0; width:100%; max-width:100%; border-radius:18px 18px 0 0; } }

/* ============================================================
   YouTube video carousel + video lightbox (homepage)
   ============================================================ */
.yt-wrap{ position:relative; max-width:1000px; margin:0 auto; }
.yt-carousel{ display:flex; gap:18px; overflow-x:auto; scroll-behavior:smooth; padding:4px 2px 16px; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; }
.yt-carousel::-webkit-scrollbar{ height:6px; }
.yt-carousel::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.25); border-radius:10px; }
.yt-card{ flex:0 0 290px; scroll-snap-align:start; cursor:pointer; border-radius:14px; overflow:hidden; position:relative; background:#000; box-shadow:var(--shadow-soft); transition:transform .25s; }
.yt-card:hover{ transform:translateY(-4px); }
.yt-card .thumb{ position:relative; aspect-ratio:16/9; }
.yt-card img{ width:100%; height:100%; object-fit:cover; display:block; }
.yt-card .play{ position:absolute; inset:0; display:grid; place-items:center; }
.yt-card .play svg{ width:56px; height:40px; filter:drop-shadow(0 4px 10px rgba(0,0,0,.45)); }
.yt-card .ttl{ position:absolute; left:0; right:0; top:0; padding:12px 14px 22px; color:#fff; font-weight:600; font-size:.9rem; line-height:1.3; background:linear-gradient(180deg, rgba(0,0,0,.78), transparent); }
.yt-arrow{ position:absolute; top:calc(50% - 16px); transform:translateY(-50%); width:44px; height:44px; border-radius:50%; border:0; background:#fff; color:var(--primary); cursor:pointer; display:grid; place-items:center; box-shadow:var(--shadow-soft); z-index:3; font-size:1.4rem; line-height:1; }
.yt-arrow.prev{ left:-10px; } .yt-arrow.next{ right:-10px; }
@media (max-width:600px){ .yt-card{ flex-basis:240px; } .yt-arrow{ display:none; } }

.vlightbox{ position:fixed; inset:0; z-index:210; background:rgba(8,20,18,.95); display:none; align-items:center; justify-content:center; padding:20px; }
.vlightbox.open{ display:flex; }
.vlightbox .frame{ width:min(960px,94vw); aspect-ratio:16/9; background:#000; border-radius:12px; overflow:hidden; box-shadow:0 24px 60px -12px rgba(0,0,0,.6); }
.vlightbox .frame iframe{ width:100%; height:100%; border:0; }
.vlightbox .vclose{ position:absolute; top:18px; right:18px; width:46px; height:46px; border-radius:50%; border:0; background:rgba(255,255,255,.16); color:#fff; font-size:1.5rem; cursor:pointer; display:grid; place-items:center; }
.vlightbox .vclose:hover{ background:rgba(255,255,255,.3); }

/* ============================================================
   Video feature (auto-updating YouTube channel playlist)
   ============================================================ */
.video-feature{ display:grid; grid-template-columns:1fr 1.15fr; gap:48px; align-items:center; }
.vf-list{ list-style:none; display:grid; gap:11px; margin:22px 0 28px; }
.vf-list li{ color:#cdd9d5; font-size:.98rem; display:flex; gap:11px; align-items:center; }
.vf-list li::before{ content:"\2713"; color:#5be3d5; font-weight:700; }
.yt-sub{ background:#FF0000; color:#fff; }
.yt-sub:hover{ background:#d90000; color:#fff; transform:translateY(-3px); }
.vf-handle{ margin-top:16px; color:rgba(255,255,255,.6); font-weight:600; font-size:.9rem; }
.vf-frame{ position:relative; aspect-ratio:16/9; border-radius:var(--radius); overflow:hidden; box-shadow:0 24px 60px -18px rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.12); background:#000; }
.vf-frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
@media (max-width:880px){ .video-feature{ grid-template-columns:1fr; gap:30px; } }
