:root{
  --daylight-white:#F6F9FB;
  --studio-sky:#3297DB;
  --deep-lake:#166199;
  --deep-lake-dark:#114F7D;
  --sky-wash:#EAF3FA;
  --slate-ink:#15212B;
  --deep-harbor:#102A3D;
  --white:#ffffff;
  --rail-w:152px;
  --container:1200px;
  --spring:cubic-bezier(.34,1.32,.5,1);
}
*{box-sizing:border-box}
html{background-color:#F6F9FB;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background-color:#F6F9FB;
  color:var(--slate-ink);
  font-family:'Work Sans',system-ui,sans-serif;
  font-size:17px;
  line-height:1.6;
  padding-top:env(safe-area-inset-top,0px);
  /* daylight vertical wash — never flat pure white */
  background-image:linear-gradient(180deg,#FBFDFE 0%,#F6F9FB 38%,#EEF4F9 100%);
  background-attachment:fixed;
  overflow-x:hidden;
}
/* ~3% noise overlay */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:'Spectral',Georgia,serif;font-weight:600;line-height:1.12;margin:0;color:var(--slate-ink);letter-spacing:-.01em}
p{margin:0}
:focus-visible{outline:3px solid var(--deep-lake);outline-offset:3px;border-radius:3px}

/* ---------- type scale ---------- */
.h1{font-size:clamp(2rem,5.2vw,3rem)}
.h2{font-size:clamp(1.625rem,3.6vw,2.25rem)}
.h3{font-size:clamp(1.25rem,2.2vw,1.5rem)}
.lead{font-family:'Spectral',serif;font-style:italic;font-weight:500;font-size:clamp(1.25rem,2.4vw,1.5rem);line-height:1.45;color:var(--slate-ink)}
.prose{max-width:66ch}
.cap{font-size:.875rem;color:#48606f}

/* eyebrow on a rail tick */
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--deep-lake)}
.eyebrow::before{content:'';width:30px;height:2px;background:var(--studio-sky);border-radius:2px;flex:none}
.on-dark .eyebrow,.eyebrow.on-dark{color:#8FCBF0}
.on-dark .eyebrow::before{background:var(--studio-sky)}

/* ---------- layout shell ---------- */
.main{margin-left:var(--rail-w);position:relative;z-index:2}
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,4vw,4rem)}
section{padding:clamp(4rem,8vw,6rem) 0;position:relative}
.sky{background:var(--sky-wash)}
.harbor{background:var(--deep-harbor);color:#E8F1F8}
.harbor h1,.harbor h2,.harbor h3{color:#fff}

/* ---------- side rail (desktop) ---------- */
.rail{
  position:fixed;top:0;left:0;bottom:0;width:var(--rail-w);z-index:1000;
  background-color:#F6F9FB;border-right:1px solid #DCE7EF;
  display:flex;flex-direction:column;align-items:stretch;
  padding:1.6rem 0 calc(1.4rem + env(safe-area-inset-bottom,0px));
}
.rail-line{position:absolute;left:26px;top:118px;bottom:128px;width:2px;background:linear-gradient(180deg,var(--studio-sky),#9AD0F0);border-radius:2px;transform-origin:top;}
.js .rail-line{animation:raildraw .9s ease .15s both}
@keyframes raildraw{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.rail-brand{padding:0 1.1rem 1.4rem;display:block}
.rail-brand img{width:96px;height:auto}
.rail-nav{display:flex;flex-direction:column;gap:.1rem;padding:0 1.1rem;margin-top:.4rem}
.rail-nav a{
  position:relative;text-decoration:none;color:var(--slate-ink);
  font-size:.84rem;font-weight:500;letter-spacing:.04em;
  padding:.62rem 0 .62rem .9rem;border-radius:6px;
  transition:color .2s ease,background-color .2s ease;
}
.rail-nav a::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%) scaleX(0);transform-origin:left;width:14px;height:2px;background:var(--studio-sky);border-radius:2px;transition:transform .25s var(--spring)}
.rail-nav a:hover{color:var(--deep-lake)}
.rail-nav a:hover::before,.rail-nav a[aria-current="page"]::before{transform:translateY(-50%) scaleX(1)}
.rail-nav a[aria-current="page"]{color:var(--deep-lake);font-weight:600}
.rail-foot{margin-top:auto;padding:0 1.1rem;display:flex;flex-direction:column;gap:.7rem}
.rail-call{display:inline-flex;align-items:center;gap:.4rem;text-decoration:none;color:#3d5563;font-size:.8rem;font-weight:500;transition:color .2s}
.rail-call:hover{color:var(--deep-lake)}
.rail-call svg{width:14px;height:14px}

/* ---------- top bar (mobile) ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;display:none;
  align-items:center;justify-content:space-between;
  background-color:#F6F9FB;border-bottom:1px solid #DCE7EF;
  padding:calc(.7rem + env(safe-area-inset-top,0px)) calc(1.1rem + env(safe-area-inset-right,0px)) .7rem calc(1.1rem + env(safe-area-inset-left,0px));
}
.topbar img{width:104px;height:auto}
.toggle{appearance:none;border:1px solid #CBDDEA;background:#fff;border-radius:10px;width:46px;height:46px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--slate-ink)}
.toggle svg{width:24px;height:24px}
.toggle .x{display:none}

/* overlay menu (mobile) */
.overlay{
  position:fixed;inset:0;z-index:999;background-color:#F6F9FB;
  display:flex;flex-direction:column;justify-content:center;gap:.2rem;
  padding:calc(5rem + env(safe-area-inset-top,0px)) 2rem 2rem;
  transform:translateX(100%);transition:transform .4s var(--spring);visibility:hidden;
}
.overlay.open{transform:none;visibility:visible}
.overlay a{font-family:'Spectral',serif;font-size:2rem;font-weight:600;color:var(--slate-ink);text-decoration:none;padding:.55rem 0;border-bottom:1px solid #E2ECF3}
.overlay a[aria-current="page"]{color:var(--deep-lake)}
.overlay .ov-foot{margin-top:1.6rem;display:flex;flex-direction:column;gap:1rem}

/* mobile sticky action bar */
.actionbar{
  position:fixed;left:0;right:0;bottom:0;z-index:998;display:none;gap:.6rem;
  background-color:#F6F9FB;border-top:1px solid #DCE7EF;
  padding:.6rem calc(.8rem + env(safe-area-inset-right,0px)) calc(.6rem + env(safe-area-inset-bottom,0px)) calc(.8rem + env(safe-area-inset-left,0px));
}
.actionbar a{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:48px;border-radius:11px;text-decoration:none;font-weight:600;font-size:.95rem}
.actionbar .ab-start{background:var(--deep-lake);color:#fff}
.actionbar .ab-call{background:#fff;color:var(--deep-lake);border:1.5px solid #CBDDEA}
.actionbar svg{width:18px;height:18px}

/* ---------- buttons ---------- */
.btn-rail{
  position:relative;display:inline-flex;align-items:center;gap:.5rem;
  background:var(--deep-lake);color:#fff;text-decoration:none;font-weight:600;font-size:.96rem;
  padding:.85rem 1.5rem;border-radius:11px;border:none;cursor:pointer;
  transition:transform .35s var(--spring),background-color .25s ease,box-shadow .25s ease;
  box-shadow:0 6px 18px rgba(22,97,153,.18);
}
.btn-rail::before{content:'';position:absolute;left:.5rem;right:.5rem;bottom:-7px;height:3px;border-radius:2px;background:var(--studio-sky);opacity:.55;transition:opacity .25s}
.btn-rail:hover{transform:translateX(6px);background:var(--deep-lake-dark);box-shadow:0 10px 24px rgba(22,97,153,.26)}
.btn-rail:hover::before{opacity:.9}
.btn-rail:active{transform:translateX(2px)}
.btn-rail svg{width:17px;height:17px}
.btn-ghost{display:inline-flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--deep-lake);font-weight:600;font-size:.95rem;padding:.4rem 0;position:relative}
.btn-ghost::after{content:'';position:absolute;left:0;bottom:.15rem;width:100%;height:2px;background:var(--deep-lake);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--spring)}
.btn-ghost:hover::after{transform:scaleX(1)}
.btn-ghost svg{width:15px;height:15px;transition:transform .25s var(--spring)}
.btn-ghost:hover svg{transform:translateX(3px)}
.cta-row{display:flex;flex-wrap:wrap;align-items:center;gap:1.1rem 1.6rem;margin-top:2rem}

/* ---------- reveal (progressive enhancement: visible by default) ---------- */
.reveal{opacity:1}
.js .reveal{opacity:0;transform:translateY(14px);transition:opacity .45s ease,transform .45s ease}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d1{transition-delay:.05s}
.js .reveal.d2{transition-delay:.1s}
.js .reveal.d3{transition-delay:.15s}

/* ---------- hero ---------- */
.hero{padding-top:clamp(3.5rem,7vw,5.5rem);padding-bottom:0}
.hero-inner{max-width:960px}
.hero h1{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:500;line-height:1.08;margin-top:1.4rem}
.hero h1 .reg{color:var(--slate-ink)}
/* carriage word */
.carriage-word{position:relative;display:inline-block;white-space:nowrap;padding:0 .12em}
.carriage-word .cw-text{color:var(--deep-lake);font-weight:600;position:relative;z-index:2}
.carriage-word .cw-rail{position:absolute;left:-.35em;right:-.35em;bottom:.04em;height:4px;border-radius:3px;background:var(--studio-sky);opacity:.5;z-index:1}
.carriage-word .cw-block{position:absolute;left:-.42em;top:.04em;bottom:.04em;width:.2em;border-radius:5px;background:var(--studio-sky);opacity:.85;z-index:1}
.js .carriage-word{transform:translateX(-46px);opacity:0}
.js .carriage-word.glide{animation:carriageGlide .72s var(--spring) .35s forwards}
@keyframes carriageGlide{to{transform:translateX(0);opacity:1}}
.hero-sub{margin-top:1.6rem;font-size:1.125rem;color:#33485a;max-width:60ch}
.hero-band{margin-top:clamp(2.4rem,5vw,3.6rem)}

/* full-bleed photo band */
.band{width:100%;position:relative;overflow:hidden;background:var(--sky-wash)}
.band img{width:100%;height:100%;object-fit:cover;aspect-ratio:1920/800;max-height:540px}
.band.tall img{aspect-ratio:1920/800}
.band-cap{position:absolute;left:0;bottom:0;padding:1.4rem clamp(1.25rem,4vw,3rem);background:linear-gradient(0deg,rgba(16,42,61,.72),rgba(16,42,61,0));color:#fff;font-size:.9rem;width:100%;max-width:680px}
.js a.band-link img{transition:transform .5s ease}
.js a.band-link:hover img{transform:scale(1.03)}

/* ---------- generic blocks ---------- */
.sec-head{max-width:760px;margin-bottom:clamp(2rem,4vw,3rem)}
.sec-head .h2{margin-top:1rem}
.sec-head p{margin-top:1rem;color:#33485a}

/* two studios two-up */
.studios2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.4rem)}
.studio-card{background:#fff;border:1px solid #E0EAF2;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 14px 36px rgba(20,40,60,.06)}
.studio-card .sc-media{aspect-ratio:16/10;overflow:hidden;background:var(--sky-wash)}
.studio-card .sc-media img{width:100%;height:100%;object-fit:cover}
.studio-card .sc-body{padding:1.6rem 1.7rem 1.9rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.studio-card .sc-tag{font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;font-weight:600;color:var(--deep-lake)}
.studio-card .sc-addr{color:#3d5563;font-size:.95rem;display:flex;gap:.5rem;align-items:flex-start}
.studio-card .sc-addr svg{width:17px;height:17px;color:var(--studio-sky);flex:none;margin-top:.15rem}
.studio-card .sc-foot{margin-top:auto;padding-top:.6rem}
/* FP-KNAPP graceful fallback panel (type + rail motif, NOT a placeholder box) */
.knapp-fallback{aspect-ratio:16/10;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;
  background:linear-gradient(135deg,#EAF3FA 0%,#DCEAF6 100%);overflow:hidden}
.knapp-fallback .kf-rail{position:absolute;left:26px;top:20%;bottom:20%;width:3px;border-radius:2px;background:linear-gradient(180deg,var(--studio-sky),#9AD0F0);opacity:.75}
.knapp-fallback .kf-carriage{position:absolute;left:21px;top:42%;width:13px;height:40px;border-radius:5px;background:var(--studio-sky);opacity:.9;box-shadow:0 8px 20px rgba(50,151,219,.32)}
.knapp-fallback .kf-txt{position:relative;z-index:2;padding:1.4rem 1.6rem 1.4rem 2.8rem;max-width:90%}
.knapp-fallback .kf-txt strong{font-family:'Spectral',serif;font-size:1.15rem;color:var(--deep-harbor);display:block;margin-bottom:.3rem}
.knapp-fallback .kf-txt span{font-size:.86rem;color:#3d5563}

/* offering rows */
.offers{display:flex;flex-direction:column;border-top:1px solid #DDE8F0}
.offer-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:.4rem 1.4rem;align-items:center;
  padding:1.7rem .4rem;border-bottom:1px solid #DDE8F0;text-decoration:none;color:inherit;position:relative;
}
.offer-row .or-tick{width:18px;height:2px;background:var(--studio-sky);border-radius:2px;transition:width .3s var(--spring);align-self:center}
.offer-row .or-main{min-width:0}
.offer-row .or-title{font-family:'Spectral',serif;font-size:clamp(1.3rem,2.4vw,1.7rem);font-weight:600;color:var(--slate-ink);display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap;transition:transform .3s var(--spring)}
.offer-row .or-feat{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--deep-lake);padding:.18rem .5rem;border-radius:5px}
.offer-row .or-desc{color:#3d5563;font-size:.98rem;margin-top:.4rem;max-width:62ch}
.offer-row .or-offer{font-size:.85rem;font-weight:600;color:var(--deep-lake);white-space:nowrap;justify-self:end;text-align:right}
.offer-row .or-arrow{width:20px;height:20px;color:var(--studio-sky);transition:transform .3s var(--spring);justify-self:end}
.js a.offer-row:hover .or-tick{width:42px}
.js a.offer-row:hover .or-title{transform:translateX(6px)}
.js a.offer-row:hover .or-arrow{transform:translateX(5px)}
@media(max-width:560px){
  .offer-row{grid-template-columns:auto 1fr;gap:.3rem .9rem}
  .offer-row .or-offer{grid-column:2;justify-self:start;text-align:left;margin-top:.5rem}
  .offer-row .or-arrow{display:none}
}

/* credential band (Deep Harbor) */
.cred-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.cred-quote{font-family:'Spectral',serif;font-style:italic;font-weight:500;font-size:clamp(1.4rem,2.8vw,1.9rem);line-height:1.4;color:#fff;margin:1.4rem 0}
.cred-list{list-style:none;padding:0;margin:1.4rem 0 0;display:flex;flex-direction:column;gap:.9rem}
.cred-list li{display:flex;gap:.7rem;align-items:flex-start;color:#CFE3F2;font-size:1rem}
.cred-list li svg{width:18px;height:18px;color:var(--studio-sky);flex:none;margin-top:.18rem}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem 1.2rem;margin-top:.4rem}
.stat .num{font-family:'Spectral',serif;font-weight:600;font-size:clamp(2.2rem,4vw,3rem);color:var(--studio-sky);line-height:1}
.stat .lbl{font-size:.84rem;color:#A9C6DD;margin-top:.4rem;line-height:1.35}
@media(max-width:760px){.cred-grid{grid-template-columns:1fr}}

/* intro offers */
.intro3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,1.8rem)}
.intro-card{background:#fff;border:1px solid #E0EAF2;border-radius:16px;padding:1.7rem 1.6rem;display:flex;flex-direction:column;gap:.55rem;box-shadow:0 10px 30px rgba(20,40,60,.05)}
.intro-card .ic-kicker{font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;font-weight:700;color:var(--deep-lake)}
.intro-card .ic-price{font-family:'Spectral',serif;font-size:2rem;font-weight:600;color:var(--slate-ink);line-height:1}
.intro-card .ic-price small{font-size:.95rem;font-weight:500;color:#6a8092}
.intro-card p{color:#3d5563;font-size:.95rem}
@media(max-width:760px){.intro3{grid-template-columns:1fr}}

/* proof pull-quotes */
.proofs{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,3vw,2.2rem)}
.proof{background:#fff;border-left:3px solid var(--studio-sky);border-radius:0 14px 14px 0;padding:1.6rem 1.8rem;box-shadow:0 10px 28px rgba(20,40,60,.05)}
.proof q{font-family:'Spectral',serif;font-style:italic;font-size:1.18rem;line-height:1.5;color:var(--slate-ink);quotes:'"' '"'}
.proof .by{margin-top:1rem;font-weight:600;font-size:.92rem;color:var(--deep-lake)}
.proof .by span{color:#6a8092;font-weight:500}
.proof-meta{display:flex;flex-wrap:wrap;gap:.8rem 1.6rem;margin-top:1.8rem;align-items:center}
.proof-meta .pm{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--slate-ink);font-size:.95rem}
.proof-meta .stars{color:var(--studio-sky);letter-spacing:.1em}
.proof-meta .note{font-size:.82rem;color:#6a8092;font-weight:500}
@media(max-width:680px){.proofs{grid-template-columns:1fr}}

/* visit teaser */
.visit-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(1.6rem,3.5vw,3rem);align-items:center}
.visit-mini{display:flex;flex-direction:column;gap:1.1rem}
.mini-loc{display:flex;gap:.7rem;align-items:flex-start}
.mini-loc svg{width:18px;height:18px;color:var(--studio-sky);flex:none;margin-top:.2rem}
.mini-loc b{font-family:'Spectral',serif;font-size:1.05rem;display:block;margin-bottom:.15rem}
.mini-loc span{color:#3d5563;font-size:.93rem}
.visit-media{border-radius:18px;overflow:hidden;box-shadow:0 16px 40px rgba(20,40,60,.1)}
.visit-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
@media(max-width:860px){.visit-grid{grid-template-columns:1fr}}

/* facades (mindbody + maps) */
.facade{position:relative;border:1px solid #CFE0EC;border-radius:16px;background:var(--sky-wash);overflow:hidden}
.facade .fc-inner{display:flex;flex-direction:column;align-items:flex-start;gap:.9rem;padding:1.8rem}
.facade .fc-skel{display:flex;align-items:center;gap:.6rem;color:#4a6577;font-size:.9rem;font-weight:500}
.facade .fc-skel svg{width:18px;height:18px;color:var(--studio-sky)}
.facade iframe{width:100%;height:420px;border:0;display:block;background:#fff}
.fc-actions{display:flex;flex-wrap:wrap;gap:.7rem 1rem;align-items:center}

/* ---------- footer (two studios) ---------- */
.site-footer{background:var(--deep-harbor);color:#CFE3F2;padding:clamp(3.5rem,7vw,6rem) 0 0}
.foot-top{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:clamp(2rem,4vw,3.4rem);padding-bottom:3rem;border-bottom:1px solid #244658}
.foot-brand .fb-mark{font-family:'Spectral',serif;font-size:1.7rem;font-weight:600;color:#fff;letter-spacing:.01em}
.foot-brand p{color:#9FBDD3;font-size:.95rem;margin-top:.8rem;max-width:34ch}
.foot-brand .btn-rail{margin-top:1.6rem}
.foot-studio h3{font-family:'Spectral',serif;font-size:1.15rem;color:#fff;margin:0 0 .2rem;font-weight:600}
.foot-studio .fs-tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--studio-sky);font-weight:700;margin-bottom:.7rem;display:block}
.foot-studio .fs-line{display:flex;gap:.55rem;align-items:flex-start;color:#B6D0E3;font-size:.92rem;margin-bottom:.7rem;text-decoration:none}
.foot-studio a.fs-line:hover{color:#fff}
.foot-studio .fs-line svg{width:16px;height:16px;color:var(--studio-sky);flex:none;margin-top:.16rem}
.foot-legal{display:flex;flex-wrap:wrap;gap:.8rem 1.6rem;justify-content:space-between;align-items:center;padding:1.6rem 0 calc(1.8rem + env(safe-area-inset-bottom,0px));font-size:.82rem;color:#7E9DB4}
.foot-legal nav{display:flex;flex-wrap:wrap;gap:1.1rem}
.foot-legal a{color:#9FBDD3;text-decoration:none}
.foot-legal a:hover{color:#fff;text-decoration:underline}
.foot-legal .powered a{color:#9FBDD3}
@media(max-width:860px){.foot-top{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}
@media(max-width:560px){.foot-top{grid-template-columns:1fr}}

/* ---------- responsive nav switch ---------- */
@media(max-width:1023px){
  .rail{display:none}
  .topbar{display:flex}
  .actionbar{display:flex}
  .main{margin-left:0;padding-top:calc(64px + env(safe-area-inset-top,0px));padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}
  .studios2{grid-template-columns:1fr}
}
@media(min-width:1024px){.overlay,.topbar,.actionbar{display:none!important}}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms!important;animation-delay:0ms!important;transition-duration:.001ms!important}
  .js .reveal{opacity:1!important;transform:none!important}
  .js .carriage-word{opacity:1!important;transform:none!important}
  .js .rail-line{transform:none!important}
}

/* ============ INNER-PAGE COMPONENTS ============ */
/* page header */
.page-head{padding-top:clamp(3.5rem,7vw,5.5rem);padding-bottom:clamp(2.5rem,5vw,4rem)}
.page-head .h1{margin-top:1.2rem;max-width:18ch}
.page-head p{margin-top:1.2rem;color:#33485a}
.head-split{display:grid;grid-template-columns:1.3fr .85fr;gap:clamp(1.8rem,4vw,3.4rem);align-items:center}
@media(max-width:860px){.head-split{grid-template-columns:1fr}}

/* generic content block: text + photo band rhythm */
.block-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3.4rem);align-items:center}
.block-grid.rev{direction:rtl}.block-grid.rev>*{direction:ltr}
@media(max-width:860px){.block-grid{grid-template-columns:1fr}.block-grid.rev{direction:ltr}}
.block-media{border-radius:18px;overflow:hidden;box-shadow:0 16px 40px rgba(20,40,60,.09)}
.block-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/10}
.block-media.sq img{aspect-ratio:1/1}
.kicker-line{display:flex;flex-direction:column;gap:.4rem;margin-top:1.4rem}
.fact{display:flex;gap:.7rem;align-items:flex-start;padding:.55rem 0;color:#33485a}
.fact svg{width:18px;height:18px;color:var(--studio-sky);flex:none;margin-top:.2rem}
.fact b{color:var(--slate-ink)}
.pricetag{display:inline-flex;align-items:baseline;gap:.5rem;background:var(--sky-wash);border:1px solid #CFE0EC;border-radius:11px;padding:.7rem 1.1rem;margin-top:1.2rem;font-weight:600;color:var(--slate-ink)}
.pricetag .pt-big{font-family:'Spectral',serif;font-size:1.5rem;color:var(--deep-lake)}
.pricetag .pt-note{font-size:.82rem;font-weight:500;color:#6a8092}
.note-flag{display:flex;gap:.5rem;align-items:flex-start;font-size:.82rem;color:#6a8092;margin-top:.9rem;max-width:62ch}
.note-flag svg{width:16px;height:16px;color:var(--deep-lake);flex:none;margin-top:.12rem}

/* course tracks — type-led list, not icon cards */
.tracks{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(2rem,5vw,4rem);border-top:1px solid #DDE8F0;margin-top:.6rem}
.track{display:flex;gap:.9rem;align-items:baseline;padding:1.1rem .2rem;border-bottom:1px solid #DDE8F0}
.track .tnum{font-family:'Spectral',serif;font-size:.95rem;color:var(--studio-sky);font-weight:600;min-width:1.6rem}
.track .tname{font-family:'Spectral',serif;font-size:1.15rem;color:var(--slate-ink)}
.track .tmeta{font-size:.84rem;color:#6a8092;margin-left:.2rem}
@media(max-width:680px){.tracks{grid-template-columns:1fr}}
.track-meta{display:flex;flex-wrap:wrap;gap:.7rem 1.6rem;margin-top:1.6rem;color:#33485a;font-size:.92rem}
.track-meta span{display:inline-flex;align-items:center;gap:.45rem}
.track-meta svg{width:16px;height:16px;color:var(--studio-sky)}

/* team roster */
.roster{display:grid;grid-template-columns:repeat(3,1fr);gap:.2rem 1.4rem;margin-top:.4rem;border-top:1px solid #DDE8F0}
.roster .member{padding:1rem .2rem;border-bottom:1px solid #DDE8F0;display:flex;flex-direction:column;gap:.1rem}
.roster .member b{font-family:'Spectral',serif;font-weight:600;font-size:1.1rem;color:var(--slate-ink)}
.roster .member span{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:#6a8092}
@media(max-width:860px){.roster{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.roster{grid-template-columns:1fr}}

/* Ahmé credential fallback (FP-AHME) — type-led, rail motif, no fabricated portrait */
.ahme-fallback{position:relative;background:linear-gradient(150deg,#102A3D 0%,#163b54 100%);color:#E8F1F8;border-radius:20px;padding:2.2rem 2rem;overflow:hidden;box-shadow:0 20px 48px rgba(16,42,61,.22)}
.ahme-fallback .af-rail{position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--studio-sky),#163b54)}
.ahme-fallback .af-carriage{position:absolute;left:-2px;top:32%;width:14px;height:42px;border-radius:5px;background:var(--studio-sky);box-shadow:0 8px 22px rgba(50,151,219,.4)}
.ahme-fallback .af-eyebrow{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:#8FCBF0;font-weight:700}
.ahme-fallback .af-name{color:#fff;font-family:'Spectral',serif;font-weight:600;font-size:1.7rem;margin:.7rem 0 .2rem}
.ahme-fallback .af-role{color:#A9C6DD;font-size:.95rem;margin-bottom:1.1rem}
.ahme-fallback ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}
.ahme-fallback li{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;color:#CFE3F2}
.ahme-fallback li svg{width:16px;height:16px;color:var(--studio-sky);flex:none;margin-top:.2rem}
.ahme-fallback .af-note{margin-top:1.2rem;font-size:.78rem;color:#7E9DB4;font-style:italic}

/* hours */
.hours-list{list-style:none;margin:1rem 0 0;padding:0;max-width:360px}
.hours-list li{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid #E2ECF3;font-size:.95rem}
.hours-list li b{font-weight:600;color:var(--slate-ink)}
.hours-list li span{color:#3d5563}

/* facade extras */
.facade .fc-inner{min-height:120px}
.fc-loading{display:flex;align-items:center;gap:.6rem;padding:2rem;color:#4a6577;font-weight:500;background:#fff;width:100%}
.spinner{width:20px;height:20px;border:3px solid #CFE0EC;border-top-color:var(--deep-lake);border-radius:50%;animation:spin .8s linear infinite;flex:none}
@keyframes spin{to{transform:rotate(360deg)}}
.facade.loaded{background:#fff}
.facade.map-facade .fc-skel svg{color:var(--studio-sky)}
.fc-ext svg{width:13px;height:13px;margin-left:.1rem}

/* studio location block */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3rem);align-items:start}
@media(max-width:860px){.loc-grid{grid-template-columns:1fr}}
.loc-info h2{margin-bottom:.4rem}
.loc-media{border-radius:18px;overflow:hidden;box-shadow:0 16px 40px rgba(20,40,60,.09)}
.loc-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/10}

/* knapp fallback (wide, for studios page hero of the block) */
.knapp-wide{aspect-ratio:16/10;border-radius:18px}

/* contact form */
.form-wrap{background:#fff;border:1px solid #E0EAF2;border-radius:20px;padding:clamp(1.6rem,3vw,2.4rem);box-shadow:0 16px 40px rgba(20,40,60,.07)}
.form-note{display:flex;gap:.6rem;align-items:flex-start;background:var(--sky-wash);border-radius:12px;padding:.9rem 1.1rem;font-size:.88rem;color:#33485a;margin-bottom:1.6rem}
.form-note svg{width:18px;height:18px;color:var(--deep-lake);flex:none;margin-top:.1rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.2rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field.full{grid-column:1/-1}
.field label{font-size:.84rem;font-weight:600;color:var(--slate-ink)}
.field label .req{color:var(--deep-lake)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:1rem;color:var(--slate-ink);background:#FBFDFE;
  border:1.5px solid #D3E1EC;border-radius:10px;padding:.7rem .85rem;width:100%;transition:border-color .2s,box-shadow .2s;
}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--deep-lake);box-shadow:0 0 0 3px rgba(22,97,153,.14)}
.field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23166199' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M4 6l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2.4rem}
.form-actions{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-top:1.6rem}
.btn-rail[type="submit"]{position:relative}
.btn-rail.loading{pointer-events:none;color:transparent}
.btn-rail.loading::after{content:'';position:absolute;left:50%;top:50%;width:18px;height:18px;margin:-9px 0 0 -9px;border:3px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}
.btn-rail.loading::before{opacity:0}
.form-status{margin-top:1.4rem;padding:1rem 1.2rem;border-radius:12px;font-weight:500;font-size:.95rem}
.form-status.ok{background:#E6F4EA;border:1px solid #BCE3C6;color:#1d5b2e}
.form-status.err{background:#FBEAEA;border:1px solid #E9C5C5;color:#8a2b2b}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}

/* shared section CTA band helper */
.cta-band{text-align:left}
.cta-band .h2{max-width:20ch}
.cta-band p{margin-top:1rem;max-width:56ch}
.harbor .cta-band p{color:#A9C6DD}
