/* ============================================================
   AEVUM HEALTH & PHYSIOTHERAPY
   Shared design system. Used by every page.
   Brand palette sampled directly from logo.
   ============================================================ */

:root{
  --bg:          #f6f2e9;
  --bg-2:        #ede6d3;
  --ink:         #1a2421;
  --green:       #50a840;
  --green-deep:  #2e8a3a;
  --green-light: #70b840;
  --forest:      #1a4d24;
  --grey:        #6e7575;
  --grey-soft:   #a8aeac;
  --cream:       #fbf8f1;
  --gold:        #b8915a;

  --maxw:1240px;
  --ease:cubic-bezier(.22,1,.36,1);
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Manrope',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
body.menu-open{overflow:hidden}
body{
  font-family:var(--font-body);font-weight:400;
  color:var(--ink);background:var(--bg);
  line-height:1.7;font-size:1.02rem;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.55;mix-blend-mode:multiply;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:300;line-height:1.05;letter-spacing:-.01em}
::selection{background:var(--green);color:var(--cream)}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,5vw,56px);position:relative;z-index:2}
.section{padding:clamp(80px,12vw,180px) 0;position:relative}
.section-sm{padding:clamp(60px,8vw,110px) 0}

.eyebrow{
  font-family:var(--font-body);font-size:.72rem;letter-spacing:.32em;
  text-transform:uppercase;font-weight:500;color:var(--green-deep);
  margin-bottom:1.6rem;display:inline-flex;align-items:center;gap:.9rem;
}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--green-deep)}
em{font-family:var(--font-display);font-style:italic;font-weight:400;
   background:linear-gradient(180deg,var(--green-light),var(--green-deep));
   -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1rem 1.9rem;font-family:var(--font-body);font-weight:500;
  font-size:.92rem;letter-spacing:.04em;border:1px solid currentColor;
  border-radius:0;cursor:pointer;background:transparent;color:var(--ink);
  transition:all .5s var(--ease);position:relative;overflow:hidden;
}
.btn::before{content:"";position:absolute;inset:0;background:var(--green-deep);transform:translateY(101%);transition:transform .5s var(--ease);z-index:-1}
.btn:hover::before{transform:translateY(0)}
.btn:hover{color:var(--cream);border-color:var(--green-deep)}
.btn-light{color:var(--cream);border-color:var(--cream)}
.btn-light::before{background:var(--green)}
.btn-light:hover{color:var(--cream);border-color:var(--green)}
.btn-fill{background:var(--green-deep);color:var(--cream);border-color:var(--green-deep)}
.btn-fill::before{background:var(--forest)}
.btn-fill:hover{color:var(--cream);border-color:var(--forest)}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(22px,5vw,56px);
  background:transparent;transition:.5s var(--ease);
}
.site-header.scrolled{
  background:rgba(246,242,233,.92);backdrop-filter:blur(20px);
  padding:.7rem clamp(22px,5vw,56px);
  border-bottom:1px solid rgba(26,36,33,.08);
}
.site-header .brand-logo{
  height:58px;width:auto;transition:height .5s var(--ease),filter .5s var(--ease);
  filter:brightness(0) invert(1);
}
.site-header.scrolled .brand-logo,
.site-header.always-light .brand-logo{filter:none;height:48px}
.site-header.always-light{
  background:rgba(246,242,233,.92);backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(26,36,33,.08);
}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;position:relative;color:var(--cream);transition:color .4s;padding:.4rem 0}
.site-header.scrolled .nav a,
.site-header.always-light .nav a{color:var(--ink)}
.nav a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:currentColor;transition:width .35s var(--ease)}
.nav a:hover::after,.nav a.current::after{width:100%}

.nav .has-drop{position:relative}
.dropdown{
  position:absolute;top:140%;left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--cream);min-width:240px;padding:.7rem;
  box-shadow:0 24px 48px -20px rgba(26,36,33,.25);
  opacity:0;visibility:hidden;transition:.35s var(--ease);
}
.has-drop:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{display:block;padding:.7rem 1rem;color:var(--ink)!important;font-size:.84rem;letter-spacing:.06em;transition:.25s}
.dropdown a:hover{background:var(--bg);color:var(--green-deep)!important}
.dropdown a::after{display:none}

.menu-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:6px;padding:14px;margin:-6px}
.menu-toggle span{width:26px;height:2px;background:var(--cream);transition:all .4s var(--ease);transform-origin:center}
.menu-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.site-header.scrolled .menu-toggle span,
.site-header.always-light .menu-toggle span{background:var(--ink)}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;min-height:100svh;display:flex;align-items:flex-end;
  position:relative;overflow:hidden;color:var(--cream);
  padding-bottom:clamp(60px,10vw,120px);
}
.hero--short{min-height:78vh;min-height:78svh}
.hero__bg{position:absolute;inset:-10%;z-index:0;background-size:cover;background-position:center;will-change:transform}
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(26,77,36,.2) 0%,rgba(26,36,33,.55) 55%,rgba(26,36,33,.92) 100%);
}
.hero__inner{position:relative;z-index:2;width:100%}
.hero__meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:2.5rem;font-size:.74rem;letter-spacing:.3em;
  text-transform:uppercase;opacity:.85;flex-wrap:wrap;gap:1rem;
}
.hero h1{
  font-size:clamp(2.6rem,7.5vw,7rem);font-weight:300;
  max-width:18ch;line-height:.98;letter-spacing:-.025em;margin-bottom:2rem;
}
.hero--big h1{font-size:clamp(3rem,8.5vw,7.5rem);max-width:14ch}
.hero h1 em{background:linear-gradient(180deg,var(--green-light),var(--green));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero h1 .word{display:inline-block;overflow:hidden;padding-bottom:.05em}
.hero h1 .word span{display:inline-block;transform:translateY(110%);transition:transform 1s var(--ease)}
.hero.loaded h1 .word span{transform:translateY(0)}
.hero h1 .word:nth-child(1) span{transition-delay:.2s}
.hero h1 .word:nth-child(2) span{transition-delay:.32s}
.hero h1 .word:nth-child(3) span{transition-delay:.44s}
.hero h1 .word:nth-child(4) span{transition-delay:.56s}
.hero h1 .word:nth-child(5) span{transition-delay:.68s}
.hero h1 .word:nth-child(6) span{transition-delay:.80s}
.hero h1 .word:nth-child(7) span{transition-delay:.92s}

.hero__sub{
  display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem;
  opacity:0;transform:translateY(20px);
  transition:opacity 1s var(--ease) 1s,transform 1s var(--ease) 1s;
}
.hero.loaded .hero__sub{opacity:1;transform:translateY(0)}
.hero__sub p{max-width:48ch;font-size:1.02rem;opacity:.92;line-height:1.6}

.scroll-indicator{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cream);opacity:.7;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
}
.scroll-indicator::after{content:"";width:1px;height:50px;background:var(--cream);animation:slideDown 2s var(--ease) infinite}
@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}50%{opacity:1}100%{transform:translateY(0);opacity:0}}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-stagger.in > *{opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.15s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.25s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.35s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.45s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.55s}
.split-words .word{display:inline-block;overflow:hidden;padding-bottom:.06em;vertical-align:bottom}
.split-words .word span{display:inline-block;transform:translateY(110%);transition:transform 1.1s var(--ease)}
.split-words.in .word span{transform:translateY(0)}
.split-words.in .word:nth-child(n) span{transition-delay:calc(var(--i,0) * .08s)}

/* ---------- Editorial blocks ---------- */
.editorial{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,7vw,8rem);align-items:end}
.editorial__num{
  font-family:var(--font-display);font-size:clamp(5rem,15vw,11rem);
  line-height:.85;font-weight:300;letter-spacing:-.04em;
  background:linear-gradient(180deg,var(--green-light),var(--green-deep));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.editorial h2{font-size:clamp(2.2rem,4.6vw,3.8rem);max-width:18ch;margin-bottom:1.5rem;color:var(--ink)}
.editorial p{font-size:1.08rem;color:#3a443e;max-width:42ch}
.editorial p+p{margin-top:1.1rem}

/* ---------- Prose ---------- */
.prose{max-width:64ch;font-size:1.05rem;color:#3a443e}
.prose p{margin-bottom:1.2rem}
.prose h2{font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--ink);margin:2.5rem 0 1rem;max-width:22ch}
.prose h3{font-size:clamp(1.3rem,2.4vw,1.8rem);color:var(--forest);margin:2rem 0 .8rem;font-weight:400}
.prose a{color:var(--green-deep);font-weight:500;border-bottom:1px solid var(--green-light)}
.prose a:hover{color:var(--forest)}
.prose ul,.prose ol{margin:1rem 0 1.5rem 1.5rem;padding-left:.5rem}
.prose li{margin-bottom:.5rem}
.prose blockquote{font-family:var(--font-display);font-style:italic;font-size:1.4rem;color:var(--forest);border-left:2px solid var(--green);padding-left:1.6rem;margin:2rem 0}

/* ---------- Pull quote ---------- */
.pullquote{
  text-align:center;padding:clamp(80px,15vw,180px) 0;
  font-family:var(--font-display);font-style:italic;font-weight:300;
  font-size:clamp(1.6rem,4vw,3.1rem);line-height:1.25;
  max-width:24ch;margin:0 auto;color:var(--forest);position:relative;
}
.pullquote::before,.pullquote::after{content:"";display:block;width:1px;height:60px;background:var(--green);margin:0 auto 2rem}
.pullquote::after{margin:2rem auto 0}

/* ---------- Pin section ---------- */
.pin-section{position:relative;background:var(--bg-2)}
.pin-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0}
.pin-text{padding:clamp(80px,10vw,140px) clamp(22px,5vw,56px)}
.pin-text h2{font-size:clamp(2rem,4vw,3.4rem);margin-bottom:1.5rem;max-width:14ch}
.pin-text p{font-size:1.05rem;color:#3a443e;max-width:38ch}
.pin-image{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;background:var(--forest)}
.pin-image .layer{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s var(--ease)}
.pin-image .layer.active{opacity:1}
.pin-image::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(26,77,36,.3))}
.pin-list{list-style:none;margin-top:3rem}
.pin-list li{
  border-top:1px solid rgba(26,36,33,.15);padding:1.5rem 0;
  font-family:var(--font-display);font-size:1.4rem;font-weight:400;color:var(--ink);
  cursor:pointer;transition:.4s var(--ease);display:flex;justify-content:space-between;align-items:center;
}
.pin-list li:last-child{border-bottom:1px solid rgba(26,36,33,.15)}
.pin-list li.active,.pin-list li:hover{color:var(--green-deep);padding-left:1rem}
.pin-list li a{display:contents}
.pin-list li .num{font-size:.7rem;letter-spacing:.2em;color:var(--green);font-family:var(--font-body);font-weight:500}

/* ---------- Numbers ---------- */
.numbers{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:clamp(2rem,5vw,4rem)}
.numbers .item .n{font-family:var(--font-display);font-weight:300;font-size:clamp(3rem,6vw,5rem);line-height:1;letter-spacing:-.03em;color:var(--forest)}
.numbers .item .n em{background:linear-gradient(180deg,var(--green-light),var(--green-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.numbers .item .lbl{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:#5a655d;margin-top:.9rem;max-width:18ch}

/* ---------- Horizontal scroll ---------- */
.h-scroll{padding:clamp(80px,10vw,140px) 0 clamp(60px,8vw,100px)}
.h-scroll .head{display:flex;justify-content:space-between;align-items:end;padding:0 clamp(22px,5vw,56px);margin-bottom:3rem;flex-wrap:wrap;gap:1.5rem}
.h-scroll h2{font-size:clamp(2rem,4.5vw,3.6rem);max-width:14ch}
.h-track{display:flex;gap:1.6rem;padding:1rem clamp(22px,5vw,56px);overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;cursor:grab}
.h-track::-webkit-scrollbar{display:none}
.h-track.dragging{cursor:grabbing}
.h-card{
  flex:0 0 clamp(280px,32vw,380px);scroll-snap-align:start;
  background:var(--cream);padding:2.4rem 2rem;position:relative;overflow:hidden;
  border:1px solid rgba(26,36,33,.08);transition:transform .5s var(--ease),background .5s var(--ease);
  display:flex;flex-direction:column;
}
.h-card:hover{transform:translateY(-6px);background:var(--bg)}
.h-card::before{content:"";position:absolute;top:0;left:0;width:3px;height:0;background:linear-gradient(180deg,var(--green-light),var(--green-deep));transition:height .5s var(--ease)}
.h-card:hover::before{height:100%}
.h-card .n{font-family:var(--font-display);font-size:.95rem;color:var(--green-deep);letter-spacing:.1em}
.h-card h3{font-family:var(--font-display);font-weight:400;font-size:1.7rem;margin:1.5rem 0 .8rem;color:var(--ink);line-height:1.15}
.h-card p{font-size:.96rem;color:#4a554e;line-height:1.65;margin-bottom:1.5rem;flex-grow:1}
.h-card .arrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green-deep);font-weight:500;display:inline-flex;align-items:center;gap:.5rem;transition:gap .3s var(--ease);margin-top:auto}
.h-card:hover .arrow{gap:.9rem}

/* ---------- Standard service grid (alternative to h-scroll) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.6rem;margin-top:3rem}
.svc-grid .h-card{flex:1}

/* ---------- Two-column media + text ---------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,6vw,6rem);align-items:center}
.split.reverse{direction:rtl}.split.reverse>*{direction:ltr}
.media-frame{overflow:hidden;position:relative;aspect-ratio:4/5}
.media-frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.media-frame:hover img{transform:scale(1.05)}

/* ---------- FAQ accordion ---------- */
.faq-item{border-top:1px solid rgba(26,36,33,.15)}
.faq-item:last-child{border-bottom:1px solid rgba(26,36,33,.15)}
.faq-q{
  width:100%;background:none;border:0;text-align:left;
  padding:1.6rem 0;font-family:var(--font-display);font-size:1.4rem;font-weight:400;
  color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  transition:color .4s var(--ease);
}
.faq-q:hover,.faq-item.open .faq-q{color:var(--green-deep)}
.faq-q .icon{font-family:var(--font-body);font-weight:300;font-size:1.5rem;color:var(--green);transition:transform .5s var(--ease)}
.faq-item.open .faq-q .icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .6s var(--ease)}
.faq-a-inner{padding:0 0 1.6rem;color:#3a443e;max-width:60ch;line-height:1.7}

/* ---------- Booking band ---------- */
.booking{background:var(--forest);color:var(--cream);position:relative;overflow:hidden}
.booking::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 40%,rgba(112,184,64,.18),transparent 50%),radial-gradient(circle at 80% 70%,rgba(184,145,90,.15),transparent 50%)}
.booking .container{position:relative;z-index:2}
.booking h2{font-size:clamp(2.2rem,5vw,4rem);max-width:18ch;margin-bottom:1.5rem;color:var(--cream)}
.booking h2 em{background:linear-gradient(180deg,var(--green-light),var(--green));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.booking .grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:4rem}
.book-card{border:1px solid rgba(251,248,241,.18);padding:2.5rem;transition:.5s var(--ease);position:relative;overflow:hidden}
.book-card:hover{background:rgba(251,248,241,.05);transform:translateY(-4px);border-color:var(--green-light)}
.book-card .loc{font-family:var(--font-display);font-style:italic;color:var(--green-light);font-size:1.1rem;margin-bottom:.5rem}
.book-card h3{font-family:var(--font-display);font-weight:300;font-size:2.2rem;color:var(--cream);margin-bottom:1rem}
.book-card .addr{opacity:.7;font-size:.92rem;margin-bottom:2rem;line-height:1.6}
.book-card .phone{font-family:var(--font-display);font-style:italic;font-size:1.4rem;color:var(--cream);display:block;margin-top:1.4rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#9aa59f;padding:clamp(60px,8vw,100px) 0 2.5rem}
.site-footer .container{position:relative;z-index:2}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem}
.site-footer h4{color:var(--cream);font-family:var(--font-body);font-weight:500;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.5rem}
.site-footer a{display:block;padding:.3rem 0;font-size:.95rem;color:#9aa59f;transition:color .3s}
.site-footer a:hover{color:var(--green-light)}
.f-loc strong{display:block;color:var(--cream);font-family:var(--font-display);font-style:italic;font-weight:400;font-size:1.15rem;margin-top:1.2rem}
.f-bottom{margin-top:4rem;padding-top:1.6rem;border-top:1px solid rgba(251,248,241,.1);font-size:.8rem;opacity:.6;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-logo{height:72px;margin-bottom:1rem;filter:brightness(0) invert(1);opacity:.9}
.socials{display:flex;gap:.8rem;margin-top:1.2rem}
.socials a{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid rgba(251,248,241,.2);border-radius:50%;color:var(--cream);transition:.35s var(--ease);font-size:.9rem}
.socials a:hover{background:var(--green);border-color:var(--green);color:var(--cream)}

/* ---------- Medical technology section ---------- */
.med-tech{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);position:relative;padding:clamp(80px,12vw,180px) 0}
.med-tech__intro{max-width:64ch;margin-bottom:clamp(3rem,6vw,5rem)}
.med-tech__intro h2{font-size:clamp(2.2rem,4.6vw,3.8rem);max-width:20ch;margin-bottom:1.5rem;color:var(--ink)}
.med-tech__intro p{font-size:1.08rem;color:#3a443e;max-width:54ch}
.med-tech__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(26,36,33,.18)}
.med-tech__card{
  padding:clamp(1.8rem,3vw,2.6rem) clamp(1.5rem,2.5vw,2rem);
  border-right:1px solid rgba(26,36,33,.18);
  border-bottom:1px solid rgba(26,36,33,.18);
  position:relative;transition:.5s var(--ease);overflow:hidden;
}
.med-tech__card:nth-child(3n){border-right:0}
.med-tech__card:nth-last-child(-n+3){border-bottom:0}
.med-tech__card:hover{background:var(--cream)}
.med-tech__card::after{
  content:"";position:absolute;bottom:-1px;left:0;
  width:0;height:2px;background:linear-gradient(90deg,var(--green-light),var(--green-deep));
  transition:width .6s var(--ease);
}
.med-tech__card:hover::after{width:100%}
.med-tech__card .num{
  font-family:var(--font-display);font-size:.85rem;font-weight:500;
  color:var(--gold);letter-spacing:.18em;margin-bottom:1.8rem;display:inline-block;
}
.med-tech__card h3{
  font-family:var(--font-display);font-weight:400;font-size:clamp(1.2rem,1.8vw,1.45rem);
  line-height:1.2;color:var(--ink);margin-bottom:.9rem;max-width:20ch;
}
.med-tech__card p{font-size:.94rem;color:#4a554e;line-height:1.65;max-width:32ch}

@media(max-width:1000px){
  .med-tech__grid{grid-template-columns:repeat(2,1fr)}
  .med-tech__card:nth-child(3n){border-right:1px solid rgba(26,36,33,.18)}
  .med-tech__card:nth-child(2n){border-right:0}
  .med-tech__card:nth-last-child(-n+3){border-bottom:1px solid rgba(26,36,33,.18)}
  .med-tech__card:nth-last-child(-n+2){border-bottom:0}
}
@media(max-width:600px){
  .med-tech__grid{grid-template-columns:1fr}
  .med-tech__card,.med-tech__card:nth-child(n){border-right:0;border-bottom:1px solid rgba(26,36,33,.18)}
  .med-tech__card:last-child{border-bottom:0}
}

/* ---------- Med-tech image strip (parallax frames) ---------- */
.tech-strip{
  display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:1.4rem;
  margin-bottom:clamp(3rem,6vw,5rem);align-items:start;
}
.tech-strip__frame{margin:0;position:relative}
.tech-strip__frame .tech-strip__img{
  aspect-ratio:4/3;background-size:cover;background-position:center;
  overflow:hidden;will-change:transform;
}
.tech-strip__frame--tall .tech-strip__img{aspect-ratio:3/3.6}
.tech-strip__frame:nth-child(1){margin-top:2.5rem}
.tech-strip__frame:nth-child(3){margin-top:4rem}
.tech-strip__frame figcaption{
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--grey);margin-top:.9rem;font-weight:500;
}
@media(max-width:760px){
  .tech-strip{grid-template-columns:1fr 1fr}
  .tech-strip__frame:nth-child(3){display:none}
  .tech-strip__frame:nth-child(n){margin-top:0}
}

/* ---------- Mask reveal for media frames ---------- */
.media-frame{clip-path:inset(0 0 100% 0);transition:clip-path 1.3s var(--ease)}
.media-frame.in,.media-frame.reveal.in{clip-path:inset(0 0 0% 0)}
.media-frame.reveal{opacity:1;transform:none}

/* ---------- Blog ---------- */
.blog-featured{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;
  background:var(--cream);border:1px solid rgba(26,36,33,.08);
  overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.blog-featured:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(26,36,33,.3)}
.blog-featured__img{min-height:360px;background-size:cover;background-position:center}
.blog-featured__body{padding:clamp(2rem,4vw,3.5rem);display:flex;flex-direction:column;justify-content:center}
.blog-featured__body h2{font-size:clamp(1.8rem,3.2vw,2.8rem);color:var(--ink);margin:1rem 0;line-height:1.1}
.blog-featured__body p{color:#4a554e;font-size:1.05rem;margin-bottom:1.5rem;max-width:46ch}
.blog-featured__meta{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green-deep);font-weight:500;display:inline-flex;align-items:center;gap:.6rem}
.blog-featured__meta .arrow{transition:transform .4s var(--ease)}
.blog-featured:hover .blog-featured__meta .arrow{transform:translateX(5px)}

.blog-cat{font-family:var(--font-body);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--gold)}

.blog-filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:3rem}
.blog-filter{
  background:transparent;border:1px solid rgba(26,36,33,.2);
  padding:.55rem 1.2rem;font-family:var(--font-body);font-size:.82rem;
  letter-spacing:.04em;color:var(--ink);cursor:pointer;transition:.35s var(--ease);border-radius:0;
}
.blog-filter:hover{border-color:var(--green-deep);color:var(--green-deep)}
.blog-filter.active{background:var(--green-deep);color:var(--cream);border-color:var(--green-deep)}

.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.6rem}
.blog-card{
  display:flex;flex-direction:column;background:var(--cream);
  border:1px solid rgba(26,36,33,.08);overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px -28px rgba(26,36,33,.3)}
.blog-card__img{height:200px;background-size:cover;background-position:center}
.blog-card__body{padding:1.8rem;display:flex;flex-direction:column;flex-grow:1}
.blog-card__body h3{font-family:var(--font-display);font-weight:400;font-size:1.4rem;color:var(--ink);line-height:1.2;margin:.8rem 0}
.blog-card__body p{font-size:.95rem;color:#4a554e;line-height:1.6;flex-grow:1}
.blog-card__meta{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);margin-top:1.4rem;font-weight:500}


/* ---------- Video & media frames (paediatric & service pages) ---------- */
.media-video{position:relative;width:100%;overflow:hidden;background:var(--forest)}
.media-video video{display:block;width:100%;height:100%;object-fit:cover}
.media-video figcaption,.media-photo figcaption{
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--grey);margin-top:.9rem;font-weight:500;
}
.media-photo{position:relative;overflow:hidden}
.media-photo img{display:block;width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.media-photo:hover img{transform:scale(1.04)}

/* Editorial media grid — staggered, magazine-style */
.media-duo{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;align-items:start;margin-top:1rem}
.media-duo .media-photo:nth-child(1),.media-duo .media-video:nth-child(1){margin-top:2.4rem}
.media-duo .tall{aspect-ratio:3/4}
.media-duo .wide{aspect-ratio:4/3}

/* Full-bleed showcase video band */
.video-band{position:relative;overflow:hidden;background:var(--forest)}
.video-band video{display:block;width:100%;height:100%;object-fit:cover;max-height:78vh}
.video-band__overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(1.5rem,4vw,3.5rem);
  background:linear-gradient(180deg,transparent 50%,rgba(26,77,36,.55));color:var(--cream);pointer-events:none;
}
.video-band__overlay .eyebrow{color:var(--green-light)}
.video-band__overlay h3{font-family:var(--font-display);font-weight:300;font-size:clamp(1.6rem,3.5vw,2.6rem);max-width:20ch;color:var(--cream)}

@media(max-width:760px){
  .media-duo{grid-template-columns:1fr;gap:1.1rem}
  .media-duo .media-photo:nth-child(1),.media-duo .media-video:nth-child(1){margin-top:0}
  .media-duo .tall,.media-duo .wide{aspect-ratio:4/3}
  .video-band video{max-height:62vh}
}

/* Portrait video band — center tall video, contain height */
.video-band--portrait{display:flex;justify-content:center;background:var(--forest);max-height:80vh}
.video-band--portrait video{width:auto;max-width:100%;height:auto;max-height:80vh;object-fit:contain}
.video-band--portrait .video-band__overlay{background:linear-gradient(180deg,rgba(26,77,36,.25) 0%,transparent 30%,transparent 60%,rgba(26,77,36,.65) 100%)}
@media(max-width:760px){
  .video-band--portrait{max-height:72vh}
  .video-band--portrait video{max-height:72vh}
}

/* ============================================================
   TEAM PAGE
   ============================================================ */
.team-hero{padding:clamp(40px,6vw,70px) 0 clamp(40px,6vw,70px);position:relative;overflow:hidden}
.team-hero__title{font-size:clamp(2.6rem,8vw,6rem);font-weight:300;line-height:.98;letter-spacing:-.025em;max-width:16ch;margin-bottom:1.8rem;color:var(--ink)}
.team-hero__title em{background:linear-gradient(180deg,var(--green-light),var(--green-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.team-hero__sub{max-width:54ch;font-size:1.1rem;color:#3a443e;line-height:1.6}
.team-stats{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,5vw,4rem);margin-top:3rem;padding-top:2.5rem;border-top:1px solid rgba(26,36,33,.15)}
.team-stat{display:flex;flex-direction:column}
.team-stat .n{font-family:var(--font-display);font-weight:300;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;color:var(--forest)}
.team-stat .l{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#5a655d;margin-top:.5rem;font-weight:500}

/* Filters */
.team-filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem}
.team-filter{background:transparent;border:1px solid rgba(26,36,33,.2);padding:.55rem 1.2rem;font-family:var(--font-body);font-size:.82rem;letter-spacing:.04em;color:var(--ink);cursor:pointer;transition:.35s var(--ease);border-radius:0}
.team-filter:hover{border-color:var(--green-deep);color:var(--green-deep)}
.team-filter.active{background:var(--green-deep);color:var(--cream);border-color:var(--green-deep)}

/* Grid — editorial, asymmetric rhythm */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.team-card{position:relative;overflow:hidden;background:var(--bg-2);cursor:default;transition:transform .6s var(--ease);transition-delay:var(--d,0s)}
.team-card__img{position:relative;aspect-ratio:3/4;overflow:hidden}
.team-card__img img{width:100%;height:100%;object-fit:cover;filter:grayscale(18%) contrast(1.02);transition:transform 1.1s var(--ease),filter .6s var(--ease)}
.team-card:hover .team-card__img img{transform:scale(1.06);filter:grayscale(0%) contrast(1.05)}
.team-card__scrim{position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(26,36,33,.15) 65%,rgba(26,36,33,.82) 100%);transition:opacity .5s var(--ease)}
.team-card__meta{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.3rem;color:var(--cream);z-index:2;transform:translateY(0);transition:transform .5s var(--ease)}
.team-card__meta h3{font-family:var(--font-display);font-weight:400;font-size:1.45rem;line-height:1.05;margin-bottom:.2rem;color:var(--cream)}
.team-card__meta p{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;color:var(--green-light);line-height:1.3}
/* Accent bar grows on hover */
.team-card__meta::before{content:"";position:absolute;left:1.3rem;top:0;width:0;height:2px;background:linear-gradient(90deg,var(--green-light),var(--green-deep));transition:width .6s var(--ease)}
.team-card:hover .team-card__meta::before{width:42px}

/* Make some cards taller for editorial rhythm on desktop */
@media(min-width:901px){
  .team-card:nth-child(8n+1){grid-row:span 1}
  .team-grid{grid-auto-rows:1fr}
}

/* Tablet */
@media(max-width:900px){
  .team-grid{grid-template-columns:repeat(3,1fr);gap:1rem}
  .team-card__meta h3{font-size:1.3rem}
}
/* Mobile — 2 columns, still elegant */
@media(max-width:620px){
  .team-grid{grid-template-columns:repeat(2,1fr);gap:.7rem}
  .team-card__img{aspect-ratio:3/4}
  .team-card__meta{padding:1rem .95rem}
  .team-card__meta h3{font-size:1.1rem}
  .team-card__meta p{font-size:.62rem;letter-spacing:.08em}
  .team-card__scrim{background:linear-gradient(180deg,transparent 38%,rgba(26,36,33,.25) 60%,rgba(26,36,33,.85) 100%)}
  .team-filters{gap:.45rem}
  .team-filter{padding:.5rem .9rem;font-size:.76rem}
  .team-stats{gap:1.5rem 2rem}
}
/* Very small phones — keep 2 col but tighten */
@media(max-width:380px){
  .team-card__meta h3{font-size:1rem}
}

/* ============================================================
   PAEDIATRIC PAGE — playful, colourful, brand-aligned
   ============================================================ */
/* Floating organic blobs in brand greens (decorative, behind content) */
.paeds-blobs{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.paeds-blob{position:absolute;border-radius:46% 54% 58% 42% / 48% 44% 56% 52%;opacity:.5;filter:blur(8px);will-change:transform}
.paeds-blob--1{width:280px;height:280px;background:radial-gradient(circle at 35% 35%,var(--green-light),var(--green));top:-60px;right:-40px;animation:blobFloat 14s ease-in-out infinite}
.paeds-blob--2{width:200px;height:200px;background:radial-gradient(circle at 40% 40%,#8ed07a,var(--green-deep));bottom:-50px;left:-30px;animation:blobFloat 18s ease-in-out infinite reverse}
.paeds-blob--3{width:140px;height:140px;background:radial-gradient(circle at 40% 40%,var(--gold),#d9b37a);top:40%;left:8%;opacity:.32;animation:blobFloat 22s ease-in-out infinite}
@keyframes blobFloat{
  0%,100%{transform:translate(0,0) rotate(0deg) scale(1)}
  33%{transform:translate(24px,-30px) rotate(8deg) scale(1.06)}
  66%{transform:translate(-18px,18px) rotate(-6deg) scale(.96)}
}

/* Colourful section intro with animated leaf accent */
.paeds-intro{position:relative}
.paeds-leaf{display:inline-block;width:34px;height:34px;vertical-align:middle;margin-right:.6rem;animation:leafSway 3.5s ease-in-out infinite;transform-origin:bottom center}
@keyframes leafSway{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}

/* Animated gradient underline that draws in on reveal */
.paeds-underline{position:relative;display:inline-block}
.paeds-underline::after{content:"";position:absolute;left:0;bottom:-.15em;height:.12em;width:0;border-radius:2px;
  background:linear-gradient(90deg,var(--green-light),var(--green),var(--green-deep));transition:width 1.1s var(--ease) .3s}
.reveal.in .paeds-underline::after,.paeds-underline.in::after{width:100%}

/* Colourful stat chips */
.paeds-chips{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.paeds-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.1rem;border-radius:100px;
  font-size:.84rem;font-weight:600;letter-spacing:.02em;color:var(--forest);
  background:linear-gradient(135deg,rgba(112,184,64,.18),rgba(46,138,58,.12));
  border:1px solid rgba(80,168,64,.3);transition:.4s var(--ease)}
.paeds-chip:hover{transform:translateY(-3px);background:linear-gradient(135deg,rgba(112,184,64,.3),rgba(46,138,58,.2))}
.paeds-chip .dot{width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,var(--green-light),var(--green-deep));flex-shrink:0}

/* Equipment feature cards with colourful top accent */
.paeds-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem;margin-top:3rem}
.paeds-feature{position:relative;background:var(--cream);padding:2rem 1.7rem;overflow:hidden;
  border:1px solid rgba(26,36,33,.07);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.paeds-feature::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--green-light),var(--green),var(--gold));
  transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.paeds-feature:hover{transform:translateY(-6px);box-shadow:0 26px 50px -28px rgba(46,138,58,.45)}
.paeds-feature:hover::before{transform:scaleX(1)}
.paeds-feature__icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:linear-gradient(135deg,var(--green-light),var(--green-deep));color:#fff;font-size:1.4rem;
  box-shadow:0 8px 20px -8px rgba(46,138,58,.6)}
.paeds-feature h3{font-family:var(--font-display);font-weight:500;font-size:1.3rem;color:var(--ink);margin-bottom:.6rem;line-height:1.15}
.paeds-feature p{font-size:.94rem;color:#4a554e;line-height:1.6}

/* Playful animated divider (wavy dots in brand colours) */
.paeds-divider{display:flex;justify-content:center;gap:.7rem;padding:clamp(2rem,5vw,3.5rem) 0}
.paeds-divider span{width:12px;height:12px;border-radius:50%;animation:dotBounce 1.4s ease-in-out infinite}
.paeds-divider span:nth-child(1){background:var(--green-light);animation-delay:0s}
.paeds-divider span:nth-child(2){background:var(--green);animation-delay:.15s}
.paeds-divider span:nth-child(3){background:var(--green-deep);animation-delay:.3s}
.paeds-divider span:nth-child(4){background:var(--gold);animation-delay:.45s}
@keyframes dotBounce{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(-14px);opacity:1}}

/* Colourful settings cards (in-clinic/home/school/hydro) */
.paeds-settings{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.3rem;margin-top:2.5rem}
.paeds-setting{position:relative;padding:2rem 1.6rem;background:var(--cream);overflow:hidden;
  border-radius:18px;transition:transform .5s var(--ease)}
.paeds-setting:nth-child(1){background:linear-gradient(160deg,#eaf6e4,#f6f2e9)}
.paeds-setting:nth-child(2){background:linear-gradient(160deg,#e4f0ea,#f6f2e9)}
.paeds-setting:nth-child(3){background:linear-gradient(160deg,#f0f3e0,#f6f2e9)}
.paeds-setting:nth-child(4){background:linear-gradient(160deg,#eef4e2,#f6f2e9)}
.paeds-setting:hover{transform:translateY(-6px) rotate(-1deg)}
.paeds-setting__num{font-family:var(--font-display);font-size:2.4rem;font-weight:300;line-height:1;
  background:linear-gradient(135deg,var(--green-light),var(--green-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.6rem}
.paeds-setting h3{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);margin-bottom:.5rem}
.paeds-setting p{font-size:.92rem;color:#4a554e;line-height:1.55}

/* Media frame with colourful animated border on reveal */
.paeds-framed{position:relative;padding:6px;border-radius:20px;overflow:hidden;background:var(--bg-2)}
.paeds-framed::before{content:"";position:absolute;inset:0;border-radius:20px;padding:3px;
  background:linear-gradient(120deg,var(--green-light),var(--green),var(--green-deep),var(--gold));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity 1s var(--ease)}
.paeds-framed.in::before,.reveal.in .paeds-framed::before{opacity:1}
.paeds-framed img,.paeds-framed video{display:block;width:100%;border-radius:15px;position:relative;z-index:1}

@media(prefers-reduced-motion:reduce){
  .paeds-blob,.paeds-leaf,.paeds-divider span{animation:none!important}
}
@media(max-width:620px){
  .paeds-blob--1{width:180px;height:180px}
  .paeds-blob--2{width:130px;height:130px}
  .paeds-blob--3{display:none}
  .paeds-feature{padding:1.6rem 1.4rem}
}

/* paeds-responsive-v2 — comprehensive mobile fixes */
/* Media-photo figures: ensure caption never overlaps image */
.media-photo{display:flex;flex-direction:column}
.media-photo img{flex:1;min-height:0}
.media-photo figcaption{flex-shrink:0}

/* media-duo: the staggered offset can cause overlap at some widths — contain it */
.media-duo{align-items:start}
.media-duo > figure{margin:0}
.media-duo .media-photo.tall img{aspect-ratio:3/4}
.media-duo .media-photo.wide img{aspect-ratio:4/3}

/* Video bands: contain height responsively, never let overlay text overflow */
.video-band{max-height:80vh}
.video-band__overlay{padding:clamp(1.2rem,4vw,3.5rem)}
.video-band__overlay h3{font-size:clamp(1.3rem,3.5vw,2.6rem)}

/* Tablet */
@media(max-width:900px){
  .paeds-features{grid-template-columns:repeat(2,1fr);gap:1.1rem}
  .paeds-settings{grid-template-columns:repeat(2,1fr)}
  .video-band{max-height:70vh}
}

/* Mobile */
@media(max-width:680px){
  .media-duo{grid-template-columns:1fr;gap:1rem}
  .media-duo .media-photo:nth-child(1),.media-duo .media-video:nth-child(1){margin-top:0}
  .media-duo .media-photo.tall img,.media-duo .media-photo.wide img{aspect-ratio:4/3}
  .paeds-features{grid-template-columns:1fr;gap:1rem}
  .paeds-settings{grid-template-columns:1fr;gap:1rem}
  .paeds-chips{gap:.55rem}
  .paeds-chip{padding:.5rem .9rem;font-size:.78rem}
  .video-band{max-height:none}
  .video-band--portrait{max-height:80vh}
  .paeds-framed{padding:4px}
  .paeds-framed img,.paeds-framed video{border-radius:12px}
  /* Section vertical rhythm tightened on mobile */
  .section-sm{padding:2rem 0}
}

/* Small phones */
@media(max-width:400px){
  .paeds-divider{gap:.5rem}
  .paeds-divider span{width:9px;height:9px}
  .video-band__overlay h3{font-size:1.2rem}
}

/* ---------- Breadcrumbs ---------- */
.breadcrumb{max-width:var(--maxw);margin:0 auto;padding:1.5rem clamp(22px,5vw,56px) 0;position:relative;z-index:2;font-size:.8rem;letter-spacing:.04em}
/* In-hero breadcrumb — sits over the dark hero image, above the title */
.breadcrumb--inhero{padding:0 0 1.2rem 0;margin:0;max-width:none}
.breadcrumb--inhero ol{justify-content:flex-start}
.breadcrumb--inhero li{color:rgba(255,255,255,.7)}
.breadcrumb--inhero li:not(:last-child)::after{color:rgba(255,255,255,.45)}
.breadcrumb--inhero a{color:rgba(255,255,255,.92)}
.breadcrumb--inhero a:hover{color:#fff}
.breadcrumb--inhero li[aria-current]{color:#fff}
@media(max-width:620px){.breadcrumb--inhero{padding-bottom:.9rem;font-size:.72rem}}

/* Standalone breadcrumb (pages without a dark hero) — clear the fixed header */
.breadcrumb--standalone{padding-top:calc(72px + 1.5rem)}
@media(max-width:900px){.breadcrumb--standalone{padding-top:calc(64px + 1rem)}}
.always-light + .breadcrumb--standalone{color:var(--ink)}

.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin:0;padding:0}
.breadcrumb li{display:flex;align-items:center;gap:.5rem;color:var(--grey)}
.breadcrumb li:not(:last-child)::after{content:"/";color:var(--grey-soft);margin-left:.5rem}
.breadcrumb a{color:var(--green-deep);transition:color .3s}
.breadcrumb a:hover{color:var(--forest)}
.breadcrumb li[aria-current]{color:var(--ink)}

/* Media zone with connecting streamer */
.paeds-media-zone{position:relative}
.paeds-stream-wrap{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.paeds-stream{position:absolute;top:0;left:0;width:100%;height:100%;min-height:100%}
.stream-path{stroke-dasharray:14 22;animation:streamFlow 26s linear infinite}
.stream-path--2{animation-duration:34s;animation-direction:reverse}
@keyframes streamFlow{to{stroke-dashoffset:-720}}
/* Keep all media content above the streamer */
.paeds-media-zone > section,.paeds-media-zone > .paeds-divider{position:relative;z-index:1}

/* Right-aligned portrait video band */
.video-band--right{justify-content:flex-end}
.video-band--right .video-band__overlay{text-align:left}
@media(max-width:680px){
  .video-band--right{justify-content:center}
}

/* Media captions under framed images */
.media-cap{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey);margin-top:.9rem;font-weight:500}

@media(prefers-reduced-motion:reduce){
  .stream-path{animation:none}
}

/* Two-column split: media + text side by side */
.paeds-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.paeds-split--reverse .paeds-split__text{order:1}
.paeds-split--reverse .paeds-split__media{order:2}
.paeds-split__media{margin:0}
.paeds-split__text .editorial__num{margin-bottom:0}
.paeds-split__text h2{font-size:clamp(1.8rem,3.5vw,2.8rem);line-height:1.1}
.paeds-split__media--portrait{display:flex;justify-content:flex-end}
/* On mobile, stack: media first, then text */
@media(max-width:780px){
  .paeds-split{grid-template-columns:1fr;gap:1.5rem}
  .paeds-split--reverse .paeds-split__text{order:2}
  .paeds-split--reverse .paeds-split__media{order:1}
  .paeds-split__media--portrait{justify-content:center}
  .paeds-split__media--portrait .paeds-framed{max-width:300px!important;margin:0 auto!important}
}

/* paeds-perf — scroll performance + responsive hardening */
/* GPU hints for animated decorative layers */
.paeds-blob{will-change:transform}
.stream-path{will-change:stroke-dashoffset}
.paeds-stream-wrap{will-change:auto;contain:strict}
/* Disable the heavier streamer animation on touch/mobile for smooth scrolling */
@media(hover:none),(max-width:780px){
  .stream-path{animation:none}
  .paeds-stream{opacity:.7}
}
/* Hero background: avoid fixed attachment jank, ensure smooth paint */
.hero__bg{will-change:transform;backface-visibility:hidden}
/* Prevent horizontal overflow that causes scroll stutter on mobile */
html,body{overflow-x:hidden;max-width:100%}
.paeds-media-zone,.paeds-split{max-width:100%}
img,video{max-width:100%}

/* Tighten section rhythm so the page isn't excessively long on mobile */
@media(max-width:780px){
  .paeds-split{gap:1.25rem}
  .paeds-divider{padding:1.5rem 0}
  .section-sm{padding:1.75rem 0}
}
@media(max-width:480px){
  .paeds-split__text h2{font-size:1.55rem}
  .media-cap{font-size:.68rem}
}

/* Video hero background */
.hero__bg--video{position:absolute;inset:0;overflow:hidden;z-index:0}
.hero__bg--video video{width:100%;height:100%;object-fit:cover;display:block}
.hero__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(26,36,33,.35) 0%,rgba(26,36,33,.15) 40%,rgba(26,36,33,.6) 100%)}
.hero__inner{position:relative;z-index:2}
@media(max-width:680px){
  /* On mobile keep the video but ensure text legibility */
  .hero__scrim{background:linear-gradient(180deg,rgba(26,36,33,.45) 0%,rgba(26,36,33,.3) 40%,rgba(26,36,33,.72) 100%)}
}

/* Review widgets (LocalImpact / ROMW embeds) */
.testimonials-section{background:var(--bg-2)}
.romw-embed{min-height:60px}
.romw-embed .romw-reviews{max-width:100%}
.footer-badge{display:inline-block}
.footer-badge .romw-embed,.footer-badge>div{max-width:240px}
/* Ensure embedded widgets never cause horizontal overflow */
.romw-embed *{max-width:100%;box-sizing:border-box}

/* Split logo with glowing leaf (homepage only) */
.brand-split{display:inline-flex;align-items:center;gap:.55rem}
.brand-split .brand-leaf{
  height:42px;width:auto;
  transition:height .5s var(--ease),filter .5s var(--ease);
  animation:leafGlow 6s cubic-bezier(0.45,0,0.55,1) infinite;
  will-change:filter;
}
.brand-split .brand-word{
  height:30px;width:auto;
  transition:height .5s var(--ease),filter .5s var(--ease);
  filter:brightness(0) invert(1);
}
/* Over the dark hero: word goes white, leaf keeps its green + glow */
.site-header.scrolled .brand-split .brand-word,
.site-header.always-light .brand-split .brand-word{filter:none;height:26px}
.site-header.scrolled .brand-split .brand-leaf,
.site-header.always-light .brand-split .brand-leaf{height:36px}

/* The gentle glow — a soft green halo that breathes in and out */
@keyframes leafGlow{
  0%,100%{filter:drop-shadow(0 0 0px rgba(112,184,64,0)) drop-shadow(0 0 0px rgba(80,168,64,0)) brightness(1)}
  25%{filter:drop-shadow(0 0 5px rgba(112,184,64,.45)) drop-shadow(0 0 10px rgba(80,168,64,.22)) brightness(1.04)}
  50%{filter:drop-shadow(0 0 9px rgba(112,184,64,.8)) drop-shadow(0 0 18px rgba(80,168,64,.42)) brightness(1.07)}
  75%{filter:drop-shadow(0 0 5px rgba(112,184,64,.45)) drop-shadow(0 0 10px rgba(80,168,64,.22)) brightness(1.04)}
}
@media(prefers-reduced-motion:reduce){
  .brand-split .brand-leaf{animation:none}
}
@media(max-width:680px){
  .brand-split .brand-leaf{height:34px}
  .brand-split .brand-word{height:24px}
  .site-header.scrolled .brand-split .brand-word,
  .site-header.always-light .brand-split .brand-word{height:22px}
}

/* Bike fitting video showcase */
.bike-video-section{background:var(--bg-2)}
.bike-video-frame{position:relative;max-width:1000px;margin:0 auto;padding:6px;border-radius:20px;background:var(--bg-2)}
.bike-video-frame::before{content:"";position:absolute;inset:0;border-radius:20px;padding:3px;
  background:linear-gradient(120deg,var(--green-light),var(--green),var(--green-deep),var(--gold));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity 1s var(--ease)}
.bike-video-frame.in::before,.reveal.in .bike-video-frame::before{opacity:1}
.bike-video-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:15px;overflow:hidden;
  background:var(--forest);box-shadow:0 30px 60px -30px rgba(26,77,36,.5)}
.bike-video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
@media(max-width:680px){
  .bike-video-frame{padding:4px}
  .bike-video-embed{border-radius:12px}
}

/* ============================================================
   BIKE FITTING — scroll-driven realistic cyclist on a grey road
   ============================================================ */
.cyclist-band{position:relative;overflow-x:clip;overflow-y:visible;height:clamp(280px,38vw,440px);margin:clamp(1.5rem,5vw,3.5rem) 0}
.cyclist-track{position:absolute;inset:0}



/* Rider image — realistic silhouette; JS drives --ride (0..1) */
.cyclist-rider{
  position:absolute;left:0;
  bottom:clamp(34px,6vw,64px);
  width:clamp(160px,23vw,300px);
  transform:translateX(calc(var(--ride,0) * (100vw + 320px) - 320px));
  will-change:transform;
}
.cyclist-img{width:100%;height:auto;display:block;position:relative;z-index:2;
  filter:drop-shadow(0 10px 14px rgba(46,138,58,.3));
  animation:none}

@media(prefers-reduced-motion:reduce){
  .cyclist-img{animation:none}
  .cyclist-road .road-line{opacity:.5}
}
@media(max-width:680px){
  .cyclist-band{height:clamp(150px,42vw,220px)}
}


/* bike-fitting-responsive-v2 — comprehensive mobile polish */
/* Cyclist band: scale down sensibly, keep rider fully visible */
@media(max-width:900px){
  .cyclist-band{height:clamp(220px,38vw,300px)}
  .cyclist-rider{width:clamp(150px,30vw,230px)}
}
@media(max-width:680px){
  .cyclist-band{height:clamp(180px,48vw,240px);margin:1.5rem 0;padding-top:16px}
  .cyclist-rider{width:clamp(130px,38vw,190px);bottom:clamp(26px,7vw,44px)}
  .cyclist-img{filter:drop-shadow(0 6px 10px rgba(46,138,58,.28))}
}
@media(max-width:420px){
  .cyclist-band{height:170px}
  .cyclist-rider{width:135px}
}

/* Video section tighter on mobile */
@media(max-width:680px){
  .bike-video-section{padding:2.25rem 0}
  .bike-video-frame{padding:4px;border-radius:14px}
  .bike-video-embed{border-radius:10px}
}

/* Editorial sections: reduce huge top numbers + spacing on mobile */
@media(max-width:680px){
  .editorial__num{font-size:2.4rem}
  .section{padding:2.5rem 0}
  .editorial .eyebrow{margin-top:1.25rem!important}
}

/* Hero: ensure title + sub fit small screens without overflow */
@media(max-width:560px){
  .hero--short{min-height:72vh;min-height:72svh}
  .hero__meta{flex-wrap:wrap;gap:.4rem}
}

/* Conditions h-scroll: smaller cards + visible scroll hint on mobile */
@media(max-width:680px){
  .h-scroll .head{padding:0 1.25rem}
  .h-card{min-width:78vw}
}

/* Global mobile guards already exist; reinforce no horizontal overflow here */
.cyclist-band,.bike-video-section{max-width:100vw;overflow-x:clip}

/* Deep-dish wheel overlays — positioned over the cyclist silhouette */
.cyclist-rider{position:relative}
.cyc-wheel-overlay{
  position:absolute;z-index:0;
  width:36.7%;height:auto;aspect-ratio:1;
  /* Spin driven by --spin (set by JS, degrees) */
  transform:rotate(calc(var(--spin,0) * 1deg));
  will-change:transform;
  pointer-events:none;
}
/* Rear wheel: centre at 21.8% x, 78.5% y of the image */
.cyc-wheel-overlay--rear{left:3.4%;top:59.1%}
/* Front wheel: centre at 80.0% x, 78.5% y */
.cyc-wheel-overlay--front{left:61.7%;top:59.1%}
@media(prefers-reduced-motion:reduce){
  .cyc-wheel-overlay{transform:none}
}


/* ============================================================
   VO2 MAX — scroll-drawn ECG + parallax image gallery
   ============================================================ */
/* ECG heart rate background — draws as user scrolls */
.vo2-ecg-wrap{position:fixed;top:0;left:0;right:0;height:100vh;pointer-events:none;z-index:0;opacity:0;transition:opacity .6s}
.vo2-ecg-wrap.active{opacity:1}
.vo2-ecg{width:100%;height:100%}
.ecg-line{
  stroke-dasharray:8000;
  stroke-dashoffset:8000;
  /* --ecg-draw (0..1) set by JS */
  transition:none;
  will-change:stroke-dashoffset;
}

/* Image gallery — staggered, asymmetric, with parallax */
.vo2-showcase{position:relative;z-index:1}
.vo2-gallery{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2.5rem);align-items:start}
.vo2-img{margin:0;overflow:visible}
.vo2-img--left{margin-top:0}
.vo2-img--right{margin-top:clamp(3rem,6vw,5rem)}
.vo2-img__frame{overflow:hidden;position:relative;aspect-ratio:3/4}
.vo2-img__frame img{width:100%;height:120%;object-fit:cover;position:absolute;top:0;left:0;
  transition:transform 0.1s linear;will-change:transform}
/* Reveal animation: slide up + fade */
.vo2-img{opacity:0;transform:translateY(60px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.vo2-img--right{transition-delay:.2s}
.vo2-img.in{opacity:1;transform:translateY(0)}

/* Green accent line on image frames */
.vo2-img__frame::after{content:"";position:absolute;bottom:0;left:0;width:0;height:3px;
  background:linear-gradient(90deg,var(--green-light),var(--green-deep));transition:width 1s var(--ease) .4s}
.vo2-img.in .vo2-img__frame::after{width:100%}

@media(max-width:780px){
  .vo2-gallery{grid-template-columns:1fr;gap:1.5rem}
  .vo2-img--right{margin-top:0}
  .vo2-img__frame{aspect-ratio:4/3}
}
@media(max-width:480px){
  .vo2-img__frame{aspect-ratio:1}
}

/* Ensure editorial sections sit above the ECG background */
.vo2-ecg-wrap ~ section,.vo2-ecg-wrap ~ .section{position:relative;z-index:1}

/* VO2 page section vertical rhythm on mobile */
@media(max-width:680px){
  .vo2-showcase{padding:2rem 0}
}
@media(prefers-reduced-motion:reduce){
  .ecg-line{stroke-dashoffset:0!important}
  .vo2-img{opacity:1;transform:none}
}


/* FAQ sections using native details/summary */
.faq-section{padding:clamp(3rem,6vw,5rem) 0}
.faq-list{max-width:760px}
.faq-list details{border-top:1px solid rgba(26,36,33,.15)}
.faq-list details:last-child{border-bottom:1px solid rgba(26,36,33,.15)}
.faq-list summary{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.3rem 0;cursor:pointer;
  font-family:var(--font-display);font-weight:400;font-size:clamp(1.1rem,2.5vw,1.4rem);
  color:var(--ink);list-style:none;transition:color .3s var(--ease);
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";font-family:var(--font-body);font-weight:300;font-size:1.6rem;color:var(--green);
  transition:transform .4s var(--ease);flex-shrink:0}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list summary:hover{color:var(--green-deep)}
.faq-answer{padding:0 0 1.5rem;color:#3a443e;max-width:60ch;line-height:1.7;font-size:.96rem}
@media(max-width:680px){
  .faq-list summary{font-size:1.05rem;padding:1.1rem 0}
  .faq-answer{font-size:.92rem}
}


/* ---------- Mobile sticky call bar ---------- */
.call-bar{display:none}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .editorial,.booking .grid,.f-grid,.hero__sub,.split{grid-template-columns:1fr;display:grid}

  /* --- Pin section: image rides on top (sticky) while list scrolls beneath --- */
  .pin-wrap{display:grid;grid-template-columns:1fr}
  .pin-image{order:-1;position:sticky;top:0;height:42svh;min-height:300px;z-index:1}
  .pin-image::after{background:linear-gradient(180deg,transparent 55%,rgba(26,77,36,.35))}
  .pin-text{padding-top:2.6rem}
  .pin-list li{font-size:1.2rem;padding:1.25rem 0}
  .pin-list li.active,.pin-list li:hover{padding-left:.6rem}

  /* --- Full-screen mobile menu --- */
  .nav{position:fixed;inset:0;background:var(--bg);flex-direction:column;align-items:flex-start;justify-content:center;padding:clamp(2rem,8vw,3.5rem);transform:translateX(102%);transition:transform .55s var(--ease);z-index:55;gap:.4rem;overflow-y:auto}
  .nav.open{transform:translateX(0)}
  .nav a{color:var(--ink)!important;font-size:1.25rem;font-family:var(--font-display);font-weight:400;text-transform:none;letter-spacing:0;padding:.55rem 0;display:block;width:100%}
  .nav a::after{display:none}
  .dropdown{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:none;padding:.2rem 0 .6rem 1.2rem;min-width:0;border-left:1px solid rgba(46,138,58,.3)}
  .has-drop{width:100%}
  .has-drop:hover .dropdown{transform:none}
  .dropdown a{padding:.45rem 0;font-size:1rem;color:#3a443e!important}
  .menu-toggle{display:flex;z-index:60}
  .nav.open~.menu-toggle span,.site-header:has(.nav.open) .menu-toggle span{background:var(--ink)}

  /* --- Hero comfort on phones --- */
  .hero{padding-bottom:clamp(84px,16vw,120px)}
  .hero h1{font-size:clamp(2.5rem,11.5vw,4.6rem)}
  .hero--big h1{font-size:clamp(2.7rem,12.5vw,5rem)}
  .hero__meta{font-size:.66rem;letter-spacing:.22em;gap:.6rem}
  .hero__sub{gap:1.4rem}
  .hero__sub .btn{width:100%;justify-content:center}
  .scroll-indicator{display:none}

  /* --- Type & spacing --- */
  .section{padding:clamp(64px,14vw,110px) 0}
  .editorial{gap:2.2rem;align-items:start}
  .editorial__num{font-size:clamp(4rem,18vw,6.5rem)}
  .pullquote{padding:clamp(64px,16vw,110px) 0}
  .numbers{grid-template-columns:repeat(2,1fr);gap:2rem 1.4rem}
  .h-card{flex:0 0 min(82vw,340px)}
  .h-scroll .head{margin-bottom:2rem}
  .book-card{padding:1.8rem}
  .book-card .btn{width:100%;justify-content:center}
  .btn{padding:1.05rem 1.6rem}
  .media-frame{aspect-ratio:4/3.2}
  .faq-q{font-size:1.15rem;padding:1.3rem 0}

  /* --- Blog responsive --- */
  .blog-featured{grid-template-columns:1fr}
  .blog-featured__img{min-height:240px}
  .blog-grid{grid-template-columns:1fr}
  .blog-filters{gap:.45rem}
  .blog-filter{padding:.5rem .9rem;font-size:.78rem}

  /* --- Sticky call bar with iPhone safe area --- */
  .call-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:80;font-family:var(--font-body);font-weight:500;font-size:.92rem;letter-spacing:.05em;padding-bottom:env(safe-area-inset-bottom)}
  .call-bar a{flex:1;text-align:center;padding:1.05rem .5rem;color:#fff;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:52px}
  .call-bar .c1{background:var(--forest)}
  .call-bar .c2{background:var(--green-deep)}
  body{padding-bottom:calc(54px + env(safe-area-inset-bottom))}
}

/* Small phones */
@media(max-width:430px){
  .container{padding:0 18px}
  .hero h1,.hero--big h1{font-size:clamp(2.3rem,12.5vw,3.2rem)}
  .editorial h2,.h-scroll h2{font-size:clamp(1.7rem,8vw,2.2rem)}
  .booking h2{font-size:clamp(1.8rem,8.5vw,2.4rem)}
  .tech-strip{grid-template-columns:1fr;gap:1.2rem}
  .tech-strip__frame:nth-child(3){display:block}
  .tech-strip__frame .tech-strip__img{aspect-ratio:16/10}
  .tech-strip__frame--tall .tech-strip__img{aspect-ratio:16/10}
  .med-tech__card{padding:1.5rem 1.2rem}
  .numbers .item .n{font-size:2.6rem}
  .f-bottom{flex-direction:column;gap:.4rem}
}

/* Touch devices: calm the parallax (perf + feel) */
@media(pointer:coarse){
  [data-parallax]{transform:none!important}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}.parallax__bg,.hero__bg{transform:none!important}}
