/* ============================================================
   Cape Town Physiotherapy — refresh concept
   "Cape light, careful hands" · shared stylesheet
   ============================================================ */
:root{
  --ink:#22334E;
  --sea:#16243B;
  --sea-deep:#101B2D;
  --gold:#C2A264;
  --gold-deep:#A98B4C;
  --bone:#F6F1E8;
  --white:#FCFAF5;
  --line:rgba(34,51,78,.14);
  --serif:'Sentient', Georgia, serif;
  --sans:'Satoshi', -apple-system, sans-serif;
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:48px; --s6:64px; --s7:96px; --s8:128px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
html.lenis{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto}
body{
  font-family:var(--sans);
  background:var(--bone);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
::selection{background:var(--gold);color:var(--sea)}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--bone)}
::-webkit-scrollbar-thumb{background:rgba(194,162,100,.55);border-radius:5px;border:2px solid var(--bone)}
::-webkit-scrollbar-thumb:hover{background:var(--gold-deep)}

/* film grain */
body::after{
  content:'';position:fixed;inset:-100px;z-index:99;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- preloader ---------- */
#loader{
  position:fixed;inset:0;z-index:200;background:var(--bone);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px;
  transition:opacity .9s cubic-bezier(.7,0,.2,1), visibility .9s;
}
#loader.done{opacity:0;visibility:hidden}
#loader img{width:190px;opacity:0;animation:loaderIn 1.1s .15s cubic-bezier(.2,.7,.2,1) forwards}
#loader .ld-line{width:0;height:1px;background:var(--gold);animation:loaderLine 1.2s .5s cubic-bezier(.7,0,.2,1) forwards}
@keyframes loaderIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes loaderLine{to{width:190px}}

/* ---------- progress bar ---------- */
#progress{position:fixed;top:0;left:0;height:2px;background:var(--gold);width:0;z-index:150}

/* ---------- nav ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px clamp(20px,4vw,56px);
  transition:background .5s, box-shadow .5s, padding .5s;
}
nav .n-logo img{height:46px;display:block;transition:filter .5s}
nav.on-dark .n-logo img{filter:brightness(0) invert(1)}
nav.scrolled{background:rgba(246,241,232,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding:12px clamp(20px,4vw,56px)}
nav.scrolled .n-logo img{filter:none}
.n-links{display:flex;align-items:center;gap:clamp(16px,2.2vw,32px)}
.n-links a{color:var(--ink);text-decoration:none;font-size:14.5px;font-weight:500;letter-spacing:.02em;position:relative;transition:color .5s}
nav.on-dark:not(.scrolled) .n-links a{color:#fff}
.n-links a:not(.n-cta)::after{content:'';position:absolute;left:0;bottom:-5px;width:100%;height:1.5px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.7,0,.2,1)}
.n-links a:not(.n-cta):hover::after,.n-links a.active:not(.n-cta)::after{transform:scaleX(1);transform-origin:left}
.n-phone{font-variant-numeric:tabular-nums}
.n-cta{
  background:var(--gold);color:var(--sea)!important;padding:11px 22px;border-radius:100px;
  font-weight:700;transition:background .3s, transform .3s;
}
.n-cta:hover{background:#d4b578;transform:translateY(-1px)}

/* hamburger + overlay menu */
#menuBtn{
  display:none;background:none;border:0;cursor:pointer;padding:10px;margin-left:6px;
  flex-direction:column;gap:5px;z-index:181;position:relative;
}
#menuBtn span{display:block;width:24px;height:2px;background:var(--ink);transition:transform .4s cubic-bezier(.7,0,.2,1), opacity .3s, background .4s}
nav.on-dark:not(.scrolled) #menuBtn span{background:#fff}
body.menu-open #menuBtn span{background:#fff}
body.menu-open #menuBtn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open #menuBtn span:nth-child(2){opacity:0}
body.menu-open #menuBtn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:900px){
  .n-links a:not(.n-cta){display:none}
  #menuBtn{display:flex}
}
#menu{
  position:fixed;inset:0;z-index:180;background:var(--sea-deep);
  display:flex;flex-direction:column;justify-content:center;padding:0 clamp(28px,8vw,80px);
  opacity:0;visibility:hidden;transition:opacity .5s cubic-bezier(.7,0,.2,1), visibility .5s;
}
body.menu-open #menu{opacity:1;visibility:visible}
#menu::before{content:'';position:absolute;inset:0;background:radial-gradient(700px 500px at 85% 10%, rgba(194,162,100,.14), transparent 60%);pointer-events:none}
#menu a.m-link{
  font-family:var(--serif);font-size:clamp(34px,9vw,54px);color:#fff;text-decoration:none;
  padding:10px 0;line-height:1.15;display:flex;align-items:baseline;gap:18px;
  opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.2,.7,.2,1), transform .6s cubic-bezier(.2,.7,.2,1), color .3s;
}
#menu a.m-link .idx{font-family:var(--sans);font-size:12px;color:var(--gold);letter-spacing:.14em;font-weight:700}
#menu a.m-link:hover,#menu a.m-link.active{color:var(--gold)}
body.menu-open #menu a.m-link{opacity:1;transform:none}
body.menu-open #menu a.m-link:nth-of-type(1){transition-delay:.1s}
body.menu-open #menu a.m-link:nth-of-type(2){transition-delay:.17s}
body.menu-open #menu a.m-link:nth-of-type(3){transition-delay:.24s}
body.menu-open #menu a.m-link:nth-of-type(4){transition-delay:.31s}
body.menu-open #menu a.m-link:nth-of-type(5){transition-delay:.38s}
body.menu-open #menu a.m-link:nth-of-type(6){transition-delay:.45s}
#menu .m-foot{margin-top:44px;display:flex;flex-direction:column;gap:8px;font-size:15px;color:rgba(252,250,245,.6);opacity:0;transition:opacity .6s .5s}
body.menu-open #menu .m-foot{opacity:1}
#menu .m-foot a{color:var(--gold);text-decoration:none;font-weight:700}

/* ---------- shared type / sections ---------- */
section{position:relative}
.wrap{max-width:1360px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.sec-label{
  font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);
  display:flex;align-items:center;gap:14px;margin-bottom:22px;
}
.sec-label::before{content:'';width:36px;height:1px;background:var(--gold)}
h1.pg,h2{font-family:var(--serif);font-weight:400;font-size:clamp(34px,4.2vw,58px);line-height:1.12;letter-spacing:-.01em}
h2 em,h1.pg em{font-style:italic;color:var(--gold-deep)}
.eyebrow{
  font-size:12.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);display:flex;align-items:center;gap:14px;
}
.eyebrow::before{content:'';width:36px;height:1px;background:var(--gold)}

/* reveal on scroll */
.rv{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--gold);color:var(--sea);text-decoration:none;
  padding:17px 34px;border-radius:100px;font-weight:700;font-size:16px;
  transition:background .3s, transform .3s, box-shadow .3s;
  border:0;cursor:pointer;font-family:var(--sans);
}
.btn svg{transition:transform .3s}
.btn:hover{background:#d4b578;transform:translateY(-2px);box-shadow:0 14px 34px -12px rgba(194,162,100,.55)}
.btn:hover svg{transform:translateX(4px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-weight:500;font-size:15.5px;
  padding:15px 28px;border:1px solid rgba(252,250,245,.35);border-radius:100px;transition:border-color .3s, background .3s;cursor:pointer;font-family:var(--sans);background:none;
}
.btn-ghost:hover{border-color:var(--gold);background:rgba(194,162,100,.12)}
.btn-ghost.dark{color:var(--ink);border-color:rgba(34,51,78,.3)}
.btn-ghost.dark:hover{border-color:var(--gold-deep);background:rgba(194,162,100,.1)}

/* ---------- inner page hero ---------- */
.page-hero{position:relative;min-height:64vh;display:flex;align-items:flex-end;overflow:clip;background:var(--sea)}
.page-hero.tall{min-height:78vh}
.ph-media{position:absolute;inset:0}
.ph-media img,.ph-media video{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0}
.ph-media img.drift{animation:heroDrift 28s ease-in-out infinite alternate}
.ph-scrim{position:absolute;inset:0;background:
  linear-gradient(78deg, rgba(12,20,34,.72) 0%, rgba(12,20,34,.42) 40%, rgba(12,20,34,.06) 70%),
  linear-gradient(to top, rgba(12,20,34,.6) 0%, transparent 36%)}
.ph-inner{position:relative;z-index:2;width:100%;max-width:1360px;margin:0 auto;padding:140px clamp(20px,4vw,56px) clamp(44px,7vh,72px)}
.ph-inner h1{font-family:var(--serif);font-weight:400;color:#fff;font-size:clamp(40px,5.6vw,84px);line-height:1.06;letter-spacing:-.012em;margin:20px 0 18px;max-width:16ch}
.ph-inner h1 em{font-style:italic;color:var(--gold)}
.ph-inner p.lead{color:rgba(252,250,245,.85);max-width:52ch;font-size:clamp(16px,1.3vw,18.5px)}
@keyframes heroDrift{from{transform:scale(1)}to{transform:scale(1.07)}}

/* ---------- marquee ---------- */
.marquee{
  background:var(--sea);color:rgba(252,250,245,.75);
  padding:17px 0;overflow:clip;white-space:nowrap;
  border-top:1px solid rgba(194,162,100,.25);
}
.marquee-track{display:inline-flex;gap:0;animation:marq 46s linear infinite}
.marquee span{font-size:13.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;padding:0 26px;position:relative}
.marquee span::after{content:'·';position:absolute;right:-4px;color:var(--gold)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- full-bleed photo band ---------- */
.band{position:relative;height:clamp(300px,44vh,460px);overflow:clip}
.band img,.band video{position:absolute;inset:-12% 0;width:100%;height:124%;object-fit:cover;will-change:transform}
.band .band-scrim{position:absolute;inset:0;background:linear-gradient(to right, rgba(22,36,59,.55), rgba(22,36,59,.1) 55%)}
.band .band-quote{
  position:absolute;left:clamp(20px,4vw,56px);bottom:clamp(28px,5vh,52px);z-index:2;color:#fff;
  font-family:var(--serif);font-style:italic;font-size:clamp(22px,2.6vw,34px);max-width:22ch;line-height:1.3;
}
.band .band-quote span{display:block;font-family:var(--sans);font-style:normal;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:14px;font-weight:700}

/* ---------- pills ---------- */
.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill{font-size:13px;font-weight:500;letter-spacing:.04em;padding:8px 16px;border:1px solid rgba(169,139,76,.4);border-radius:100px;color:var(--gold-deep);background:rgba(194,162,100,.07)}

/* ---------- CTA banner (shared pre-footer) ---------- */
.final{background:var(--sea);color:#fff;padding:var(--s8) 0 0;position:relative;overflow:clip}
.final::before{content:'';position:absolute;inset:0;background:radial-gradient(900px 500px at 50% -20%, rgba(194,162,100,.16), transparent 65%)}
.final-inner{position:relative;z-index:2;text-align:center;max-width:820px;margin:0 auto;padding:0 24px}
.final h2{color:#fff;font-size:clamp(38px,5vw,72px)}
.final h2 em{color:var(--gold)}
.final p{color:rgba(252,250,245,.75);margin:24px auto 40px;max-width:44ch}
.final .btn{font-size:17px;padding:19px 42px}
.final .call-line{margin-top:22px;font-size:14.5px;color:rgba(252,250,245,.6)}
.final .call-line a{color:var(--gold);text-decoration:none;font-weight:700}
footer{position:relative;z-index:2;margin-top:var(--s7);border-top:1px solid rgba(252,250,245,.12);padding:38px clamp(20px,4vw,56px)}
.f-top{display:grid;grid-template-columns:auto 1fr auto;gap:34px;align-items:start;max-width:1360px;margin:0 auto}
footer .f-logo img{height:40px;filter:brightness(0) invert(1);opacity:.85}
.f-nav{display:flex;gap:26px;flex-wrap:wrap;justify-content:center}
.f-nav a{color:rgba(252,250,245,.65);text-decoration:none;font-size:14px;transition:color .3s}
.f-nav a:hover{color:var(--gold)}
footer .f-social{display:flex;gap:14px;justify-content:flex-end}
footer .f-social a{width:38px;height:38px;border:1px solid rgba(252,250,245,.25);border-radius:50%;display:grid;place-items:center;color:rgba(252,250,245,.8);transition:border-color .3s, color .3s, transform .3s;text-decoration:none}
footer .f-social a:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.f-bottom{max-width:1360px;margin:26px auto 0;padding-top:22px;border-top:1px solid rgba(252,250,245,.08);font-size:13px;color:rgba(252,250,245,.45);text-align:center}
.f-bottom a{color:rgba(252,250,245,.7);text-decoration:none}
@media(max-width:800px){.f-top{grid-template-columns:1fr;justify-items:center;gap:22px}}
.concept-note{position:relative;z-index:2;text-align:center;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(252,250,245,.35);padding:20px 20px 26px}

/* ============================================================
   HOME
   ============================================================ */
.hero{position:relative;height:100svh;min-height:640px;overflow:clip;background:var(--sea)}
.hero-media{position:absolute;inset:0}
.hero-media video,.hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.hero-media .hero-img{position:absolute;inset:0;animation:heroDrift 26s ease-in-out infinite alternate}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(78deg, rgba(12,20,34,.72) 0%, rgba(12,20,34,.45) 38%, rgba(12,20,34,.05) 68%),
  linear-gradient(to top, rgba(12,20,34,.55) 0%, transparent 34%)}
.hero-inner{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 clamp(20px,4vw,56px) clamp(48px,8vh,88px);
  max-width:1680px;margin:0 auto;
}
.hero h1{
  font-family:var(--serif);font-weight:400;color:#fff;
  font-size:clamp(46px,7.2vw,116px);line-height:1.04;letter-spacing:-.015em;
  margin:22px 0 26px;max-width:12ch;
}
.hero h1 em{font-style:italic;color:var(--gold);position:relative;white-space:nowrap}
.hero h1 em .sweep{position:absolute;inset:0;background:linear-gradient(100deg,transparent 20%,rgba(255,240,210,.45) 50%,transparent 80%);background-size:250% 100%;background-position:120% 0;-webkit-background-clip:text;background-clip:text;color:transparent;pointer-events:none}
.hero-sub{color:rgba(252,250,245,.88);max-width:47ch;font-size:clamp(16px,1.35vw,19px);margin-bottom:38px}
.hero-cta-row{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.hero-call{color:#fff;text-decoration:none;font-weight:500;font-size:15.5px;border-bottom:1px solid rgba(255,255,255,.35);padding-bottom:2px;transition:border-color .3s}
.hero-call:hover{border-color:var(--gold)}
.hero-stars{margin-top:30px;display:flex;align-items:center;gap:10px;color:rgba(252,250,245,.85);font-size:14.5px}
.hero-stars .st{color:var(--gold);letter-spacing:2px;font-size:15px}
.hero-scroll{position:absolute;right:clamp(20px,4vw,56px);bottom:clamp(48px,8vh,88px);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(255,255,255,.6);font-size:11px;letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl}
.hero-scroll::after{content:'';width:1px;height:44px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2.2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(.6);transform-origin:top}50%{opacity:1;transform:scaleY(1)}}
@media(max-width:700px){.hero-scroll{display:none}}
.hi{opacity:0;transform:translateY(28px);transition:opacity 1.1s cubic-bezier(.2,.7,.2,1), transform 1.1s cubic-bezier(.2,.7,.2,1)}
body.ready .hi{opacity:1;transform:none}
body.ready .hi:nth-child(1){transition-delay:.15s}
body.ready .hi:nth-child(2){transition-delay:.3s}
body.ready .hi:nth-child(3){transition-delay:.5s}
body.ready .hi:nth-child(4){transition-delay:.68s}
body.ready .hi:nth-child(5){transition-delay:.85s}

/* resonance / stats */
.resonance{padding:var(--s8) 0 var(--s7)}
.res-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(40px,6vw,110px);align-items:end}
.res-grid p.big{font-family:var(--serif);font-size:clamp(24px,2.6vw,36px);line-height:1.42;letter-spacing:-.005em}
.res-grid p.big em{font-style:italic;color:var(--gold-deep)}
.stats{display:flex;flex-direction:column;gap:30px;border-left:1px solid var(--line);padding-left:clamp(24px,3vw,48px)}
.stat .num{font-family:var(--serif);font-size:clamp(40px,3.6vw,56px);line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}
.stat .num sup{font-size:.5em;color:var(--gold-deep)}
.stat .lbl{font-size:13.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(34,51,78,.6);margin-top:6px;font-weight:500}
@media(max-width:900px){.res-grid{grid-template-columns:1fr}.stats{flex-direction:row;flex-wrap:wrap;gap:26px;border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:26px}}

/* services grid (home) */
.services{padding:var(--s7) 0 var(--s8);background:var(--white);border-top:1px solid var(--line)}
.svc-head{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;margin-bottom:var(--s6)}
.svc-head p{max-width:44ch;color:rgba(34,51,78,.75)}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
a.svc{
  background:var(--white);padding:34px 28px 40px;position:relative;overflow:clip;
  min-height:230px;display:flex;flex-direction:column;text-decoration:none;color:var(--ink);
  opacity:0;transform:translateY(24px);
  transition:background .45s, opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
.svc-grid.in a.svc{opacity:1;transform:none}
a.svc::after{content:'';position:absolute;left:0;bottom:0;height:3px;width:100%;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.7,0,.2,1)}
a.svc:hover{background:#fffdf8}
a.svc:hover::after{transform:scaleX(1)}
a.svc .no{font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--gold-deep)}
a.svc h3{font-family:var(--serif);font-weight:500;font-size:21px;line-height:1.25;margin:52px 0 10px;letter-spacing:-.005em}
a.svc p{font-size:14.5px;line-height:1.6;color:rgba(34,51,78,.72)}
a.svc .go{position:absolute;top:28px;right:26px;width:30px;height:30px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--gold-deep);opacity:0;transform:translate(-6px,6px);transition:opacity .4s,transform .4s}
a.svc:hover .go{opacity:1;transform:none}
/* hover image reveal */
a.svc .no,a.svc .go,a.svc h3,a.svc p{position:relative;z-index:2;transition:color .45s}
a.svc .svc-bg{position:absolute;inset:0;z-index:1;opacity:0;transition:opacity .55s cubic-bezier(.2,.7,.2,1)}
a.svc .svc-bg img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.06);transition:transform 1.4s cubic-bezier(.2,.7,.2,1)}
a.svc .svc-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top, rgba(16,27,45,.86) 8%, rgba(16,27,45,.45) 60%, rgba(16,27,45,.3))}
a.svc:hover .svc-bg{opacity:1}
a.svc:hover .svc-bg img{transform:scale(1)}
a.svc:hover h3{color:#fff}
a.svc:hover p{color:rgba(252,250,245,.82)}
a.svc:hover .no{color:var(--gold)}
a.svc:hover .go{color:var(--gold);border-color:rgba(194,162,100,.6)}
@media(max-width:1100px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}a.svc{min-height:0}a.svc h3{margin-top:26px}}

/* approach (home) */
.approach{padding:var(--s8) 0;background:var(--bone)}
.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,110px);align-items:center}
.app-copy h2{margin-bottom:26px}
.app-copy p{color:rgba(34,51,78,.8);margin-bottom:18px;max-width:52ch}
.app-copy .pill-row{margin-top:28px}
.app-img{position:relative;border-radius:18px;overflow:clip;aspect-ratio:4/3.4;box-shadow:0 30px 70px -30px rgba(22,36,59,.35)}
.app-img img,.app-img video{width:100%;height:100%;object-fit:cover;display:block}
.app-img img{animation:heroDrift 30s ease-in-out infinite alternate}
.app-img .tag{
  position:absolute;left:18px;bottom:18px;background:rgba(252,250,245,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.6);border-radius:12px;padding:12px 18px;font-size:13.5px;font-weight:500;color:var(--ink);
  box-shadow:0 10px 30px -12px rgba(22,36,59,.3);z-index:2;
}
@media(max-width:900px){.app-grid{grid-template-columns:1fr}}

/* team (home) */
.team{padding:var(--s8) 0;background:var(--white);border-top:1px solid var(--line)}
.team-head{margin-bottom:var(--s6);max-width:700px}
.team-head p{margin-top:18px;color:rgba(34,51,78,.75)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,36px)}
.tcard{position:relative;text-decoration:none;color:var(--ink);display:block}
.tcard .ph{border-radius:16px;overflow:clip;aspect-ratio:1/1.08;position:relative;box-shadow:0 24px 55px -28px rgba(22,36,59,.35)}
.tcard .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s cubic-bezier(.2,.7,.2,1)}
.tcard:hover .ph img{transform:scale(1.045)}
.tcard .ph::after{content:'';position:absolute;inset:0;background:linear-gradient(to top, rgba(22,36,59,.28), transparent 45%)}
.tcard h3{font-family:var(--serif);font-weight:500;font-size:24px;margin:22px 0 2px}
.tcard .role{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700}
.tcard p{font-size:15px;color:rgba(34,51,78,.75);margin-top:12px;max-width:38ch}
@media(max-width:900px){.team-grid{grid-template-columns:1fr;max-width:460px}}

/* freeman */
.freeman{background:var(--sea);color:#fff;padding:var(--s8) 0;position:relative;overflow:clip}
.freeman::before{content:'';position:absolute;top:-160px;right:-160px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle, rgba(194,162,100,.14), transparent 65%)}
.fm-grid{display:grid;grid-template-columns:auto 1fr;gap:clamp(36px,5vw,80px);align-items:center;max-width:1160px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.fm-photo{width:clamp(150px,16vw,220px);aspect-ratio:1/1;border-radius:50%;overflow:clip;border:3px solid rgba(194,162,100,.5);box-shadow:0 26px 60px -20px rgba(0,0,0,.5);position:relative}
.fm-photo img{width:100%;height:100%;object-fit:cover;object-position:14% center;display:block}
.fm-quote .qm{font-family:var(--serif);font-size:84px;line-height:0;color:var(--gold);display:block;height:34px}
.fm-quote blockquote{font-family:var(--serif);font-size:clamp(21px,2.35vw,31px);line-height:1.45;font-weight:400;letter-spacing:-.005em;color:rgba(252,250,245,.96)}
.fm-quote blockquote strong{color:var(--gold);font-weight:500}
.fm-cite{margin-top:26px;display:flex;align-items:center;gap:16px}
.fm-cite .nm{font-weight:700;font-size:16px}
.fm-cite .rl{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:rgba(252,250,245,.55)}
.fm-cite .dash{width:34px;height:1px;background:var(--gold)}
@media(max-width:760px){.fm-grid{grid-template-columns:1fr;justify-items:start}}

/* reviews */
.reviews{padding:var(--s8) 0;background:var(--bone)}
.rev-head{display:grid;grid-template-columns:1fr auto;gap:36px;align-items:end;margin-bottom:var(--s6)}
.g-badge{display:flex;align-items:center;gap:18px;background:var(--white);border:1px solid var(--line);border-radius:16px;padding:18px 26px;box-shadow:0 14px 40px -22px rgba(22,36,59,.25)}
.g-badge .score{font-family:var(--serif);font-size:44px;line-height:1}
.g-badge .meta{font-size:13.5px;color:rgba(34,51,78,.7);line-height:1.45}
.g-badge .meta .st{color:var(--gold-deep);letter-spacing:2px;font-size:14px}
.rev-grid{columns:3;column-gap:22px}
.rev{
  break-inside:avoid;background:var(--white);border:1px solid var(--line);border-radius:16px;
  padding:28px;margin-bottom:22px;transition:transform .4s, box-shadow .4s;
}
.rev:hover{transform:translateY(-4px);box-shadow:0 20px 46px -24px rgba(22,36,59,.28)}
.rev .st{color:var(--gold-deep);letter-spacing:2.5px;font-size:13px;margin-bottom:14px}
.rev p{font-size:15px;line-height:1.7;color:rgba(34,51,78,.85)}
.rev .who{margin-top:18px;font-weight:700;font-size:14px}
.rev .when{font-size:12.5px;color:rgba(34,51,78,.5);margin-top:2px}
.rev-more{margin-top:34px;font-size:14.5px}
.rev-more a{color:var(--gold-deep);font-weight:700;text-decoration:none;border-bottom:1px solid rgba(169,139,76,.4);padding-bottom:2px;transition:border-color .3s}
.rev-more a:hover{border-color:var(--gold-deep)}
@media(max-width:1000px){.rev-grid{columns:2}}
@media(max-width:640px){.rev-grid{columns:1}.rev-head{grid-template-columns:1fr}}

/* consult */
.consult{padding:0 0 var(--s8);background:var(--bone)}
.consult-card{
  position:relative;border-radius:24px;overflow:clip;background:var(--sea);
  padding:clamp(44px,6vw,84px) clamp(28px,5vw,84px);color:#fff;
}
.consult-card::before{content:'';position:absolute;inset:0;background:
  radial-gradient(700px 420px at 88% -10%, rgba(194,162,100,.28), transparent 60%),
  radial-gradient(520px 380px at -6% 110%, rgba(194,162,100,.14), transparent 60%)}
.consult-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(32px,5vw,80px);align-items:center}
.consult h2{color:#fff}
.consult h2 em{color:var(--gold)}
.consult p{color:rgba(252,250,245,.82);margin-top:20px;max-width:50ch}
.consult .fine{font-size:13.5px;color:rgba(252,250,245,.6);margin-top:16px}
.consult-cta{display:flex;flex-direction:column;gap:16px;align-items:flex-start}
@media(max-width:860px){.consult-inner{grid-template-columns:1fr}}

/* visit */
.visit{background:var(--white);border-top:1px solid var(--line);padding:var(--s8) 0}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:center}
.visit-img{border-radius:18px;overflow:clip;aspect-ratio:16/11;box-shadow:0 30px 70px -30px rgba(22,36,59,.35)}
.visit-img img,.visit-img video{width:100%;height:100%;object-fit:cover;display:block}
.visit-img img{animation:heroDrift 32s ease-in-out infinite alternate}
.visit-info h2{margin-bottom:30px}
.v-row{display:grid;grid-template-columns:110px 1fr;gap:18px;padding:16px 0;border-top:1px solid var(--line);font-size:15.5px}
.v-row:last-of-type{border-bottom:1px solid var(--line)}
.v-row .k{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);padding-top:3px}
.v-row a{color:var(--ink);font-weight:500;text-decoration:none;border-bottom:1px solid rgba(34,51,78,.25);transition:border-color .3s}
.v-row a:hover{border-color:var(--gold-deep)}
.v-row .sub{color:rgba(34,51,78,.6);font-size:14px}
@media(max-width:900px){.visit-grid{grid-template-columns:1fr}}

/* ============================================================
   SERVICES page
   ============================================================ */
.svc-layout{display:grid;grid-template-columns:250px 1fr;gap:clamp(36px,5vw,90px);padding:var(--s7) 0 var(--s8)}
.svc-nav{position:sticky;top:110px;align-self:start;display:flex;flex-direction:column;gap:2px}
.svc-nav a{
  font-size:14px;color:rgba(34,51,78,.6);text-decoration:none;padding:9px 0 9px 18px;
  border-left:1.5px solid var(--line);transition:color .3s, border-color .3s;line-height:1.35;
}
.svc-nav a:hover{color:var(--ink)}
.svc-nav a.active{color:var(--gold-deep);border-color:var(--gold);font-weight:700}
@media(max-width:900px){.svc-layout{grid-template-columns:1fr}.svc-nav{display:none}}
.svc-detail{display:flex;flex-direction:column;gap:var(--s7)}
.sd{scroll-margin-top:110px}
.sd .sd-media{border-radius:18px;overflow:clip;aspect-ratio:16/8.5;position:relative;box-shadow:0 26px 60px -30px rgba(22,36,59,.35);margin-bottom:34px}
.sd .sd-media img{width:100%;height:100%;object-fit:cover;display:block;animation:heroDrift 30s ease-in-out infinite alternate}
.sd .sd-media .sd-no{
  position:absolute;right:22px;bottom:14px;font-family:var(--serif);font-size:clamp(60px,7vw,96px);
  color:#fff;opacity:.85;line-height:1;text-shadow:0 4px 30px rgba(0,0,0,.4);font-style:italic;
}
.sd h2{font-size:clamp(28px,3.2vw,42px);margin-bottom:16px}
.sd .sd-body{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(26px,4vw,60px)}
.sd .sd-body>p{color:rgba(34,51,78,.8);max-width:54ch}
.sd-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.sd-list li{list-style:none;padding:11px 0 11px 26px;border-bottom:1px solid var(--line);font-size:14.5px;color:rgba(34,51,78,.8);position:relative}
.sd-list li::before{content:'';position:absolute;left:4px;top:19px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.sd-cta{margin-top:24px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.sd-cta .mini{font-size:14px;color:rgba(34,51,78,.6)}
.sd-cta .mini a{color:var(--gold-deep);font-weight:700;text-decoration:none}
@media(max-width:760px){.sd .sd-body{grid-template-columns:1fr}}
/* special breastfeeding card */
.bf-card{
  background:var(--sea);border-radius:22px;color:#fff;padding:clamp(34px,4.5vw,60px);
  position:relative;overflow:clip;
}
.bf-card::before{content:'';position:absolute;inset:0;background:radial-gradient(600px 400px at 90% -10%, rgba(194,162,100,.25), transparent 60%)}
.bf-grid{position:relative;z-index:2;display:grid;grid-template-columns:auto 1fr;gap:clamp(26px,4vw,54px);align-items:center}
.bf-photo{width:clamp(120px,13vw,180px);aspect-ratio:1;border-radius:50%;overflow:clip;border:3px solid rgba(194,162,100,.5)}
.bf-photo img{width:100%;height:100%;object-fit:cover}
.bf-card h2{color:#fff}
.bf-card h2 em{color:var(--gold)}
.bf-card p{color:rgba(252,250,245,.82);margin-top:14px;max-width:56ch}
.bf-card .wa{margin-top:24px}
@media(max-width:700px){.bf-grid{grid-template-columns:1fr}}

/* ============================================================
   ABOUT page
   ============================================================ */
.story{padding:var(--s8) 0;background:var(--bone)}
.story-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(40px,6vw,110px);align-items:center}
.story-img{border-radius:18px;overflow:clip;aspect-ratio:1/1.15;box-shadow:0 30px 70px -30px rgba(22,36,59,.35);position:relative}
.story-img img{width:100%;height:100%;object-fit:cover;display:block}
.story-copy h2{margin-bottom:24px}
.story-copy p{color:rgba(34,51,78,.8);margin-bottom:18px;max-width:56ch}
@media(max-width:900px){.story-grid{grid-template-columns:1fr}}
.quali{padding:var(--s8) 0;background:var(--white);border-top:1px solid var(--line)}
.quali-head{max-width:720px;margin-bottom:var(--s6)}
.quali-head p{margin-top:16px;color:rgba(34,51,78,.75)}
.timeline{position:relative;max-width:860px}
.timeline::before{content:'';position:absolute;left:7px;top:6px;bottom:6px;width:1.5px;background:var(--line)}
.tl-item{position:relative;padding:0 0 30px 44px}
.tl-item::before{content:'';position:absolute;left:0;top:7px;width:15px;height:15px;border-radius:50%;background:var(--bone);border:2px solid var(--gold)}
.tl-item .yr{font-size:12.5px;font-weight:700;letter-spacing:.16em;color:var(--gold-deep)}
.tl-item .ttl{font-family:var(--serif);font-size:20px;margin-top:4px}
.tl-item .dsc{font-size:14.5px;color:rgba(34,51,78,.65);margin-top:4px}
.affil{display:flex;gap:34px;align-items:center;margin-top:var(--s6);flex-wrap:wrap}
.affil img{height:64px;opacity:.85}
.affil .a-note{font-size:13.5px;color:rgba(34,51,78,.6);max-width:36ch}

/* ============================================================
   REVIEWS page
   ============================================================ */
.rev-hero-stats{display:flex;gap:clamp(28px,5vw,72px);align-items:center;margin-top:30px;flex-wrap:wrap}
.rev-hero-stats .rh-num{font-family:var(--serif);font-size:clamp(46px,5vw,72px);color:#fff;line-height:1}
.rev-hero-stats .rh-num sup{font-size:.45em;color:var(--gold)}
.rev-hero-stats .rh-lbl{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(252,250,245,.6);margin-top:8px;font-weight:500}
.rev-wall{padding:var(--s7) 0 var(--s8)}

/* ============================================================
   CONTACT page
   ============================================================ */
.contact-body{padding:var(--s7) 0 var(--s8)}
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,90px);align-items:start}
.ct-form{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:clamp(28px,3.4vw,48px);box-shadow:0 24px 60px -32px rgba(22,36,59,.3)}
.ct-form h3{font-family:var(--serif);font-weight:500;font-size:26px;margin-bottom:8px}
.ct-form .sub{font-size:14.5px;color:rgba(34,51,78,.65);margin-bottom:26px}
.fld{margin-bottom:18px}
.fld label{display:block;font-size:12.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:8px}
.fld input,.fld textarea,.fld select{
  width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:var(--bone);
  font-family:var(--sans);font-size:15.5px;color:var(--ink);outline:none;transition:border-color .3s, box-shadow .3s;
}
.fld input:focus,.fld textarea:focus,.fld select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,162,100,.18)}
.fld textarea{min-height:120px;resize:vertical}
.map-card{border-radius:20px;overflow:clip;border:1px solid var(--line);box-shadow:0 24px 60px -32px rgba(22,36,59,.3);margin-top:26px}
.map-card iframe{width:100%;height:300px;display:block;border:0;filter:saturate(.85)}
.direct-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
@media(max-width:900px){.ct-grid{grid-template-columns:1fr}}

/* ============================================================
   BOOK page
   ============================================================ */
.book-body{padding:var(--s6) 0 var(--s8)}
.bk-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:clamp(30px,4vw,70px);align-items:start}
.bk-layout>*{min-width:0}
@media(max-width:960px){.bk-layout{grid-template-columns:1fr}}
.bk-step{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:clamp(24px,3vw,40px);margin-bottom:24px}
.bk-step .st-head{display:flex;align-items:baseline;gap:16px;margin-bottom:22px}
.bk-step .st-no{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--gold-deep);line-height:1}
.bk-step h3{font-family:var(--serif);font-weight:500;font-size:23px}
.chip-grid{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  padding:11px 20px;border:1px solid var(--line);border-radius:100px;background:var(--bone);
  font-size:14.5px;font-weight:500;color:var(--ink);cursor:pointer;font-family:var(--sans);
  transition:border-color .3s, background .3s, color .3s, transform .2s;
}
.chip:hover{border-color:var(--gold);transform:translateY(-1px)}
.chip.sel{background:var(--sea);color:#fff;border-color:var(--sea)}
.ther-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:640px){.ther-grid{grid-template-columns:1fr}}
.ther{
  border:1px solid var(--line);border-radius:16px;background:var(--bone);padding:18px;text-align:center;
  cursor:pointer;transition:border-color .3s, background .3s, transform .2s;font-family:var(--sans);
}
.ther:hover{border-color:var(--gold);transform:translateY(-2px)}
.ther.sel{border-color:var(--gold);background:#fffdf6;box-shadow:0 12px 30px -18px rgba(194,162,100,.6)}
.ther img{width:74px;height:74px;border-radius:50%;object-fit:cover;margin:0 auto 12px;display:block}
.ther .t-any{width:74px;height:74px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;background:rgba(194,162,100,.15);color:var(--gold-deep);font-family:var(--serif);font-size:26px;font-style:italic}
.ther .t-nm{font-weight:700;font-size:15px;color:var(--ink)}
.ther .t-rl{font-size:12px;color:rgba(34,51,78,.55);letter-spacing:.08em;text-transform:uppercase;margin-top:3px}
.day-strip{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px}
.day{
  min-width:86px;padding:13px 10px;border:1px solid var(--line);border-radius:14px;background:var(--bone);
  text-align:center;cursor:pointer;transition:border-color .3s, background .3s;font-family:var(--sans);
}
.day:hover{border-color:var(--gold)}
.day.sel{background:var(--sea);color:#fff;border-color:var(--sea)}
.day .d-dow{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--gold-deep)}
.day.sel .d-dow{color:var(--gold)}
.day .d-num{font-family:var(--serif);font-size:23px;margin-top:2px}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:10px;margin-top:18px}
.slot{
  padding:11px 6px;border:1px solid var(--line);border-radius:10px;background:var(--bone);text-align:center;
  font-size:14px;font-weight:500;cursor:pointer;transition:all .25s;font-family:var(--sans);color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.slot:hover{border-color:var(--gold)}
.slot.sel{background:var(--gold);border-color:var(--gold);color:var(--sea);font-weight:700}
.slot.taken{opacity:.32;pointer-events:none;text-decoration:line-through}
.bk-summary{position:sticky;top:110px;background:var(--sea);border-radius:20px;color:#fff;padding:clamp(26px,3vw,40px);overflow:clip;position:sticky}
.bk-summary::before{content:'';position:absolute;inset:0;background:radial-gradient(440px 300px at 90% -10%, rgba(194,162,100,.25), transparent 60%);pointer-events:none}
.bk-summary h3{font-family:var(--serif);font-weight:400;font-size:26px;margin-bottom:20px;position:relative}
.bs-row{display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-top:1px solid rgba(252,250,245,.12);font-size:14.5px;position:relative}
.bs-row .k{color:rgba(252,250,245,.55);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;padding-top:2px}
.bs-row .v{text-align:right;font-weight:500}
.bs-row .v.empty{color:rgba(252,250,245,.35);font-style:italic;font-weight:400}
.bk-summary .note{font-size:13px;color:rgba(252,250,245,.55);margin:18px 0;position:relative}
.bk-summary .btn{width:100%;justify-content:center;position:relative}
.bk-summary .btn.disabled{opacity:.45;pointer-events:none}
.bk-alt{margin-top:18px;font-size:13.5px;color:rgba(252,250,245,.6);text-align:center;position:relative}
.bk-alt a{color:var(--gold);font-weight:700;text-decoration:none}
/* confirm overlay */
#bkModal{
  position:fixed;inset:0;z-index:190;background:rgba(16,27,45,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:grid;place-items:center;padding:22px;opacity:0;visibility:hidden;transition:opacity .45s, visibility .45s;
}
#bkModal.open{opacity:1;visibility:visible}
.bk-modal-card{
  background:var(--bone);border-radius:22px;max-width:520px;width:100%;padding:clamp(30px,4vw,48px);
  text-align:center;transform:translateY(24px);transition:transform .45s cubic-bezier(.2,.7,.2,1);
  max-height:88vh;overflow:auto;
}
#bkModal.open .bk-modal-card{transform:none}
.bk-modal-card .tick{width:64px;height:64px;border-radius:50%;background:rgba(194,162,100,.16);display:grid;place-items:center;margin:0 auto 20px;color:var(--gold-deep)}
.bk-modal-card h3{font-family:var(--serif);font-weight:500;font-size:27px;margin-bottom:12px}
.bk-modal-card p{font-size:15px;color:rgba(34,51,78,.75);margin-bottom:10px}
.bk-modal-card .sum{font-size:14.5px;background:var(--white);border:1px solid var(--line);border-radius:14px;padding:16px 20px;margin:18px 0 22px;text-align:left}
.bk-modal-card .sum b{color:var(--gold-deep)}
.bk-modal-card .row{display:flex;flex-direction:column;gap:12px}
.bk-modal-card .row .btn,.bk-modal-card .row .btn-ghost{justify-content:center;width:100%}
.bk-modal-card .row .btn-ghost{color:var(--ink);border-color:rgba(34,51,78,.3)}
.bk-modal-card .row .btn-ghost:hover{border-color:var(--gold-deep);background:rgba(194,162,100,.1)}
.bk-modal-card .close-x{position:absolute;top:16px;right:20px;background:none;border:0;font-size:26px;color:rgba(34,51,78,.5);cursor:pointer;line-height:1}
/* rates + packages */
.rates{padding:var(--s7) 0 var(--s8);background:var(--white);border-top:1px solid var(--line)}
.rate-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px);margin-top:var(--s5)}
@media(max-width:900px){.rate-grid{grid-template-columns:1fr}}
.rate{
  border:1px solid var(--line);border-radius:20px;background:var(--bone);padding:clamp(26px,3vw,38px);
  display:flex;flex-direction:column;transition:transform .4s, box-shadow .4s;
}
.rate:hover{transform:translateY(-4px);box-shadow:0 22px 50px -26px rgba(22,36,59,.3)}
.rate.hi-rate{background:var(--sea);color:#fff;border-color:var(--sea)}
.rate .r-name{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep)}
.rate.hi-rate .r-name{color:var(--gold)}
.rate .r-price{font-family:var(--serif);font-size:clamp(34px,3.2vw,44px);margin:14px 0 4px;line-height:1}
.rate .r-price .r-per{font-size:15px;font-family:var(--sans);color:rgba(34,51,78,.55)}
.rate.hi-rate .r-price .r-per{color:rgba(252,250,245,.55)}
.rate p{font-size:14.5px;line-height:1.65;color:rgba(34,51,78,.75);margin-top:10px}
.rate.hi-rate p{color:rgba(252,250,245,.78)}
.rate ul{margin-top:14px;padding-left:0}
.rate li{list-style:none;font-size:14px;padding:8px 0 8px 24px;border-top:1px solid var(--line);position:relative;color:rgba(34,51,78,.8)}
.rate.hi-rate li{border-color:rgba(252,250,245,.12);color:rgba(252,250,245,.82)}
.rate li::before{content:'';position:absolute;left:2px;top:15px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.rate .r-note{margin-top:auto;padding-top:18px;font-size:12.5px;color:rgba(34,51,78,.5)}
.rate.hi-rate .r-note{color:rgba(252,250,245,.5)}
/* contact quick actions */
.qa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:30px}
@media(max-width:640px){.qa-grid{grid-template-columns:1fr}}
.qa{
  display:flex;flex-direction:column;gap:6px;text-decoration:none;border:1px solid var(--line);border-radius:16px;
  padding:20px;background:var(--white);color:var(--ink);transition:border-color .3s, transform .3s, box-shadow .3s;
}
.qa:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 16px 40px -22px rgba(22,36,59,.3)}
.qa .qa-k{font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep)}
.qa .qa-v{font-weight:700;font-size:16.5px}
.qa .qa-s{font-size:13px;color:rgba(34,51,78,.6)}
