/* =====================================================================
   Snow Dance Studio — Homepage
   Aesthetic: Editorial + soft snow.
   Palette pulled from logo.jpg: pale mint → soft sky → lilac.
   Cool slate ink. Fraunces display + Inter sans.
   ===================================================================== */

:root {
  /* Palette — sampled from the brand logo (mint / sky / lilac gradient) */
  --snow:        #FFFFFF;
  --paper:       #FAFCFC;   /* page base — faintest cool wash */
  --paper-warm:  #F2F6F8;   /* alternating section bg (cool mist) */
  --paper-cool:  #E8EEF1;   /* deeper mist */

  --ink:         #2A3340;   /* cool slate near-black */
  --ink-2:       #5A6573;
  --ink-3:       #9099A6;

  /* Accent trio — pulled directly from the logo gradient */
  --mint:        #C9E5DA;   /* logo, left */
  --mint-soft:   #DFEFE8;
  --mint-tint:   #ECF6F1;

  --sky:         #B6CCDD;   /* logo, middle */
  --sky-soft:    #D6E2EE;
  --sky-tint:    #E8F0F7;

  --lilac:       #C5BFDE;   /* logo, right */
  --lilac-soft:  #DDD8EB;
  --lilac-tint:  #ECE9F3;

  --accent:      #8E84B8;   /* deeper lilac — usable for buttons, type accents */
  --accent-2:    #6F8FB3;   /* deeper sky — secondary accent */

  --rule:        #DCE3E8;
  --rule-soft:   #E8EDF1;

  /* Type */
  --font-display: 'Fraunces', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-sans:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;

  --fs-display: clamp(2.75rem, 5.5vw + .75rem, 6.25rem);
  --fs-h2:      clamp(2rem, 2.8vw + 1rem, 3.5rem);
  --fs-h3:      clamp(1.125rem, .4vw + 1rem, 1.375rem);
  --fs-lead:    clamp(1.0625rem, .35vw + 1rem, 1.25rem);
  --fs-body:    1rem;
  --fs-small:   .8125rem;
  --fs-tiny:    .6875rem;

  /* Spacing */
  --container: 1400px;
  --gutter: clamp(1.25rem, 3vw, 2.5rem);
  --section-y: clamp(4.5rem, 8vw, 9rem);

  /* Radius / shadow — soft, papery, cool */
  --r-sm: 4px;
  --r-md: 10px;
  --r-lg: 18px;
  --shadow-sm: 0 1px 2px rgba(42, 51, 64, .05);
  --shadow-md: 0 12px 30px -16px rgba(42, 51, 64, .18), 0 2px 6px rgba(42, 51, 64, .04);
  --shadow-lg: 0 40px 80px -40px rgba(42, 51, 64, .28);

  --easing: cubic-bezier(.2, .7, .2, 1);

  /* Signature gradient — echo of the logo */
  --grad-logo: linear-gradient(110deg, var(--mint) 0%, var(--sky) 50%, var(--lilac) 100%);
  --grad-logo-soft: linear-gradient(110deg, var(--mint-tint) 0%, var(--sky-tint) 50%, var(--lilac-tint) 100%);
}

/* =============== Reset & base =============== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: 1.55;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, picture, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ul, ol { list-style: none; padding: 0; }
hr { border: 0; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 2px; }
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: absolute; left: -9999px; top: .5rem; background: var(--ink); color: var(--paper); padding: .5rem .75rem; border-radius: var(--r-sm); z-index: 100; }
.skip-link:focus { left: .5rem; }

/* =============== Typography =============== */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 360; letter-spacing: -.015em; line-height: 1.05; color: var(--ink); }
h1.display, .display { font-size: var(--fs-display); font-weight: 360; line-height: 1.02; letter-spacing: -.025em; font-variation-settings: 'opsz' 120, 'SOFT' 80, 'WONK' 1; }
.display--m { font-size: var(--fs-h2); line-height: 1.08; font-variation-settings: 'opsz' 60, 'SOFT' 50, 'WONK' 0; }
.display__soft { color: var(--ink-2); font-style: italic; font-weight: 320; font-variation-settings: 'opsz' 144, 'SOFT' 100; }
.ampersand {
  font-style: italic;
  font-weight: 320;
  background: var(--grad-logo);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  padding: 0 .1em;
}
em { font-style: italic; color: var(--accent); }

.eyebrow {
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.lead {
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: var(--ink-2);
  max-width: 56ch;
}
.muted { color: var(--ink-3); }
strong { font-weight: 600; }

/* =============== Layout =============== */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding-inline: var(--gutter); }
main > section { padding-block: var(--section-y); }

.section-head { display: grid; gap: .9rem; margin-bottom: clamp(2rem, 4vw, 3.5rem); max-width: 60ch; }
.section-head--row { grid-template-columns: 1fr auto; align-items: end; max-width: none; gap: 2rem 4rem; }
@media (max-width: 720px) { .section-head--row { grid-template-columns: 1fr; } }

/* =============== Image placeholders =============== */
.img-placeholder {
  position: relative;
  width: 100%;
  background:
    radial-gradient(140% 90% at 100% 0%, var(--mint-tint) 0%, transparent 55%),
    radial-gradient(120% 100% at 0% 100%, var(--lilac-tint) 0%, transparent 60%),
    repeating-linear-gradient(45deg, transparent 0 12px, rgba(42, 51, 64, .025) 12px 13px),
    var(--sky-tint);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  overflow: hidden;
  display: grid;
  place-items: center;
  isolation: isolate;
}
.img-placeholder::before {
  content: '';
  position: absolute; inset: .5rem;
  border: 1px dashed color-mix(in srgb, var(--accent) 40%, transparent);
  border-radius: calc(var(--r-md) - 4px);
  pointer-events: none;
}
.ph__caption {
  font-family: var(--font-sans);
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--paper);
  padding: .35rem .65rem;
  border: 1px solid var(--rule);
  border-radius: 999px;
}
.ph__pin {
  position: absolute;
  top: 38%; left: 52%;
  transform: translate(-50%, -50%);
  font-size: 2rem;
  color: var(--accent);
  text-shadow: 0 2px 16px rgba(142, 132, 184, .35);
}
.ar-1x1 { aspect-ratio: 1 / 1; }
.ar-4x3 { aspect-ratio: 4 / 3; }
.ar-3x2 { aspect-ratio: 3 / 2; }
.ar-4x5 { aspect-ratio: 4 / 5; }

/* Live image frame (hotlinked from snowdancestudio.sg) */
.img-frame {
  position: relative;
  width: 100%;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
}
.img-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .8s var(--easing);
}
.img-frame:hover img { transform: scale(1.03); }

/* =============== Buttons =============== */
.btn {
  display: inline-flex; align-items: center; gap: .5em;
  padding: .85em 1.4em;
  border-radius: 999px;
  font-weight: 500;
  font-size: .95rem;
  line-height: 1;
  letter-spacing: .01em;
  transition: transform .25s var(--easing), background .25s var(--easing), color .25s var(--easing), border-color .25s var(--easing), box-shadow .25s var(--easing);
  border: 1px solid transparent;
  white-space: nowrap;
}
.btn--sm { padding: .65em 1.05em; font-size: .85rem; }
.btn--gold { background: var(--accent); color: var(--paper); }
.btn--gold:hover { background: var(--ink); color: var(--lilac-soft); }
.btn--ink { background: var(--ink); color: var(--paper); }
.btn--ink:hover { background: var(--accent); color: var(--paper); }
.btn--outline { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn--outline:hover { background: var(--ink); color: var(--paper); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { color: var(--accent); }

.link-arrow {
  display: inline-flex; align-items: center; gap: .4em;
  font-weight: 500;
  font-size: .9rem;
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
  padding-bottom: .15em;
  transition: color .25s var(--easing), border-color .25s var(--easing), gap .25s var(--easing);
}
.link-arrow:hover { color: var(--accent); border-color: var(--accent); gap: .65em; }
.link-arrow--lg { font-size: 1rem; }

.dot {
  display: inline-block;
  width: .5em; height: .5em;
  border-radius: 50%;
  background: var(--accent);
  margin-right: .4em;
  vertical-align: middle;
  box-shadow: 0 0 0 4px var(--lilac-tint);
}

.badge {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .25em .65em;
  border: 1px solid var(--rule);
  border-radius: 999px;
  color: var(--ink-2);
  background: var(--paper);
  vertical-align: middle;
}
.badge--cool { color: var(--accent-2); border-color: var(--sky-soft); background: color-mix(in srgb, var(--sky-tint) 60%, var(--paper)); }

.num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 380;
  color: var(--accent);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}

/* =============== Header =============== */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--rule-soft);
}
.header-grid {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 2rem;
  min-height: 76px;
}
.brand {
  display: inline-flex; align-items: center; gap: .75rem;
  text-decoration: none;
}
.brand__mark {
  width: 40px; height: 40px;
  border-radius: 10px;
  object-fit: cover;
  box-shadow: 0 0 0 1px rgba(42, 51, 64, .08), 0 4px 12px -6px rgba(42, 51, 64, .25);
}
.brand__word {
  font-family: var(--font-sans);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink);
  line-height: 1;
}
.brand--lg .brand__mark { width: 56px; height: 56px; border-radius: 14px; }
.brand--lg .brand__word { font-size: 1rem; letter-spacing: .2em; }

.primary-nav ul { display: flex; gap: clamp(1rem, 2.2vw, 2rem); justify-content: center; }
.primary-nav a {
  font-size: .9rem;
  color: var(--ink-2);
  padding: .25em 0;
  border-bottom: 1px solid transparent;
  transition: color .25s var(--easing), border-color .25s var(--easing);
}
.primary-nav a:hover { color: var(--ink); border-color: var(--accent); }
.primary-nav a[aria-current="page"],
.primary-nav a.is-section { color: var(--ink); }

/* --- Primary-nav mega menu --- */
.primary-nav { align-self: stretch; }
.primary-nav ul { height: 100%; align-items: stretch; }
.primary-nav > ul > li { display: flex; align-items: center; }
.primary-nav a { display: inline-flex; align-items: center; gap: .3em; }
.nav-caret { width: 12px; height: 12px; transition: transform .25s var(--easing); }
.has-dropdown:hover .nav-caret,
.has-dropdown:focus-within .nav-caret { transform: rotate(180deg); }

/* The .mega spans the full header width (a transparent hover bridge so the
   pointer never crosses a dead gap); the visible card is centred inside it.
   Positioned against .site-header, which is a containing block. */
.mega {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  padding-top: .6rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  /* On close, hold the panel fully open for a .26s grace period — enough
     time for the pointer to travel from the nav item down onto it — then
     fade out. visibility flips to hidden only once it has faded. */
  transition:
    opacity .2s var(--easing) .26s,
    transform .2s var(--easing) .26s,
    visibility 0s .46s;
  z-index: 60;
}
.has-dropdown:hover .mega,
.has-dropdown:focus-within .mega {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  z-index: 61;
  /* Open with no delay; the hovered panel sits above any that is still
     fading out, so switching between menus never lags. */
  transition:
    opacity .18s var(--easing),
    transform .18s var(--easing),
    visibility 0s;
}
.mega__panel {
  width: min(820px, calc(100vw - 3rem));
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: .5rem;
  padding: .6rem;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
}
.mega__links { display: grid; gap: 2px; align-content: start; }
.mega .mega__link {
  display: grid;
  gap: .12rem;
  padding: .7rem .85rem;
  border: 0;
  border-radius: var(--r-md);
  white-space: normal;
  transition: background .2s var(--easing);
}
.mega .mega__link:hover,
.mega .mega__link[aria-current="page"] { background: var(--paper-warm); }
.mega__link-label { font-size: .95rem; font-weight: 500; color: var(--ink); line-height: 1.25; }
.mega__link-desc { font-size: .8rem; color: var(--ink-3); line-height: 1.3; }

.mega .mega__feature {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 0;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--paper-warm);
  transition: background .2s var(--easing);
}
.mega .mega__feature:hover { background: var(--paper-cool); }
.mega__feature-media { display: block; aspect-ratio: 16 / 10; background: var(--paper-cool); }
.mega__feature-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mega__feature-body { display: grid; gap: .2rem; padding: .8rem .95rem 1rem; }
.mega__feature-title { font-family: var(--font-display); font-size: 1.15rem; font-variation-settings: 'opsz' 40; color: var(--ink); line-height: 1.2; }
.mega__feature-text { font-size: .85rem; color: var(--ink-2); line-height: 1.4; }
.mega .mega__feature .link-arrow { margin-top: .4rem; font-size: .85rem; }

.header-aux { display: flex; align-items: center; gap: 1rem; justify-self: end; }
.lang-toggle {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .8rem; color: var(--ink-3);
  font-family: var(--font-sans);
  letter-spacing: .04em;
}
.lang-btn {
  padding: .2em .35em;
  border-radius: 4px;
  transition: color .2s var(--easing);
}
.lang-btn.is-active { color: var(--ink); font-weight: 600; }
.lang-btn:hover { color: var(--ink); }

.nav-toggle {
  display: none;
  width: 40px; height: 40px;
  padding: 10px;
  border: 1px solid var(--rule);
  border-radius: 8px;
}
.nav-toggle span {
  display: block; width: 100%; height: 1.5px;
  background: var(--ink);
  margin: 0 0 4px; transition: transform .25s var(--easing);
}
.nav-toggle span:last-child { margin-bottom: 0; }

.mobile-drawer {
  background: var(--paper);
  border-top: 1px solid var(--rule-soft);
  padding: 1rem var(--gutter) 1.5rem;
}
.mobile-drawer nav ul { display: grid; gap: .25rem; padding-block: .5rem; }
.mobile-drawer a {
  display: block;
  padding: .85rem .5rem;
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--ink);
  border-bottom: 1px solid var(--rule-soft);
}
.mobile-drawer .btn { margin-top: 1rem; }
.drawer-sub { padding-left: 1rem; }
.mobile-drawer .drawer-sub a {
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 500;
  color: var(--ink-2);
  padding: .6rem .5rem;
}

/* =============== HERO =============== */
.hero {
  padding-top: clamp(3rem, 6vw, 5.5rem);
  /* extra bottom padding to make room for the stacked deck peeking below */
  padding-bottom: clamp(5rem, 8vw, 8rem);
  position: relative;
  /* faint logo-echo wash on the page */
  background:
    radial-gradient(60% 60% at 90% 0%, var(--lilac-tint) 0%, transparent 60%),
    radial-gradient(50% 50% at 0% 30%, var(--mint-tint) 0%, transparent 60%),
    var(--paper);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(2rem, 4vw, 4.5rem);
  align-items: center;
}
.hero-copy {
  display: grid;
  gap: clamp(1.25rem, 2vw, 1.75rem);
  min-width: 0;  /* let grid item shrink instead of overflow */
}
.hero-copy .display {
  /* override the root --fs-display — at this hero density, capping
     around 4.75rem keeps the headline readable on one or two lines */
  font-size: clamp(2.5rem, 3.4vw + .75rem, 4.75rem);
  max-width: none;
  text-wrap: balance;
}
.hero-copy .lead { max-width: 54ch; }
.hero-copy .eyebrow,
.hero-copy .hero-foot { max-width: 58ch; }

.cta-row { display: flex; flex-wrap: wrap; gap: .65rem; margin-top: .25rem; }
.hero-foot { font-size: var(--fs-small); color: var(--ink-3); }

.hero-media { position: relative; margin: 0; }

/* Hero — 3D stacked-deck slider */
.hero-slider {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  perspective: 1600px;
  perspective-origin: 50% 50%;
  /* Allow cards to fly up and out the top; clip rest */
  overflow: visible;
  isolation: isolate;
}
.hero-slider::before {
  /* Soft floor shadow under the deck */
  content: '';
  position: absolute;
  left: 6%; right: 6%; bottom: -18px;
  height: 30px;
  background: radial-gradient(60% 100% at 50% 0%, rgba(42, 51, 64, .25), transparent 70%);
  filter: blur(8px);
  z-index: 0;
}
.hero-slide {
  position: absolute;
  inset: 0;
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow:
    0 22px 40px -16px rgba(42, 51, 64, .35),
    0 6px 12px rgba(42, 51, 64, .12);
  transition:
    transform 1.05s var(--easing),
    opacity 1.05s var(--easing),
    filter 1.05s var(--easing),
    box-shadow .6s var(--easing);
  transform-origin: 50% 50%;
  will-change: transform, opacity, filter;
  backface-visibility: hidden;
}

/* Stacked positions — cards peek BELOW the active, fanned slightly */
.hero-slide[data-offset="0"] {
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
  opacity: 1;
  z-index: 3;
  filter: none;
}
.hero-slide[data-offset="1"] {
  transform: translate3d(14px, 52px, -60px) rotate(2.5deg) scale(0.94);
  opacity: 0.85;
  z-index: 2;
  pointer-events: none;
  filter: saturate(.85);
  box-shadow: 0 22px 32px -14px rgba(42, 51, 64, .35);
}
.hero-slide[data-offset="2"] {
  transform: translate3d(28px, 100px, -130px) rotate(5deg) scale(0.88);
  opacity: 0.55;
  z-index: 1;
  pointer-events: none;
  filter: saturate(.7) blur(.8px);
  box-shadow: 0 18px 26px -14px rgba(42, 51, 64, .28);
}
/* Slides deeper than the visible 3-card deck (a hero has 3 slides, the
   home-page gallery has 8) — parked invisibly at the back-of-stack
   position, so they fade in smoothly once they reach offset 2. */
.hero-slide:not([data-offset="0"]):not([data-offset="1"]):not([data-offset="2"]) {
  transform: translate3d(28px, 100px, -130px) rotate(5deg) scale(0.88);
  opacity: 0;
  z-index: 0;
  pointer-events: none;
  filter: saturate(.7) blur(.8px);
}

/* Recycling card: flies STRAIGHT UP and away in one smooth motion, then
   holds invisibly at the back of the deck. The fade back in is handed to
   the per-offset rules + .hero-slide transition, so this works whether
   the deck has 3 cards (hero) or 8 (gallery). */
.hero-slide.is-recycling {
  animation: hero-recycle 1.25s cubic-bezier(.45, 0, .25, 1) forwards;
  pointer-events: none;
}
@keyframes hero-recycle {
  /* Single smooth upward flight, 0 → 50 % */
  0%   { z-index: 4; transform: translate3d(0, 0, 0)                rotate(0deg)    scale(1);    opacity: 1; filter: none; }
  50%  { z-index: 4; transform: translate3d(0, -130%, 240px)        rotate(-10deg)  scale(1.12); opacity: 0; filter: blur(2px); }
  /* Snap (still invisible) to back-of-stack and hold there */
  51%  { z-index: 0; transform: translate3d(28px, 100px, -130px)    rotate(5deg)    scale(0.88); opacity: 0; filter: saturate(.7) blur(.8px); }
  100% { z-index: 0; transform: translate3d(28px, 100px, -130px)    rotate(5deg)    scale(0.88); opacity: 0; filter: saturate(.7) blur(.8px); }
}

.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.06);
  transition: transform 7s var(--easing);
}
.hero-slide[data-offset="0"] img { transform: scale(1); }

.hero-slide__tag {
  position: absolute;
  top: 1.1rem;
  left: 1.1rem;
  background: color-mix(in srgb, var(--ink) 75%, transparent);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .45em 1em;
  border-radius: 999px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  transition: opacity .6s var(--easing) .25s;
  z-index: 4;
}
.hero-slide[data-offset="0"] .hero-slide__tag { opacity: 1; }

/* Prev / next chevron buttons */
.hero-slider__nav {
  position: absolute;
  top: 50%;
  width: 44px; height: 44px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  color: var(--ink);
  border: 1px solid var(--rule-soft);
  border-radius: 50%;
  cursor: pointer;
  padding: 0;
  z-index: 5;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 6px 16px rgba(42, 51, 64, .18);
  transition:
    background .25s var(--easing),
    transform .3s var(--easing),
    box-shadow .25s var(--easing),
    opacity .25s var(--easing);
}
.hero-slider__nav svg { width: 20px; height: 20px; }
.hero-slider__nav--prev { left: .85rem; transform: translateY(-50%); }
.hero-slider__nav--next { right: .85rem; transform: translateY(-50%); }
.hero-slider__nav:hover {
  background: var(--paper);
  box-shadow: 0 10px 24px rgba(42, 51, 64, .28);
}
.hero-slider__nav--prev:hover { transform: translateY(-50%) translateX(-3px) scale(1.06); }
.hero-slider__nav--next:hover { transform: translateY(-50%) translateX(3px)  scale(1.06); }
.hero-slider__nav:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

.hero-slider__dots {
  position: absolute;
  bottom: 1.1rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: .5rem;
  z-index: 5;
}
.hero-slider__dots button {
  width: 26px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, .4);
  padding: 0;
  border: 0;
  cursor: pointer;
  transition: background .3s var(--easing), width .4s var(--easing);
}
.hero-slider__dots button:hover { background: rgba(255, 255, 255, .7); }
.hero-slider__dots button.is-active {
  background: rgba(255, 255, 255, .95);
  width: 44px;
}
.hero-slider__dots button:focus-visible {
  outline: 2px solid var(--paper);
  outline-offset: 3px;
}

/* Hero slider intentionally ignores prefers-reduced-motion —
   override the global reduced-motion blanket so the deck still animates */
@media (prefers-reduced-motion: reduce) {
  .hero-slide {
    transition: transform 1.05s var(--easing),
                opacity 1.05s var(--easing),
                filter 1.05s var(--easing),
                box-shadow .6s var(--easing) !important;
  }
  .hero-slide.is-recycling {
    animation: hero-recycle 1.25s cubic-bezier(.45, 0, .25, 1) forwards !important;
  }
  .hero-slide img {
    transition: transform 7s var(--easing) !important;
  }
}

.hero-strip {
  margin-top: clamp(3.5rem, 6vw, 5.5rem);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding-block: clamp(1.25rem, 2vw, 1.75rem);
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  align-items: center;
  gap: clamp(1rem, 3vw, 3rem);
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1.2vw + 1rem, 1.65rem);
  font-weight: 360;
  letter-spacing: -.01em;
  font-variation-settings: 'opsz' 60;
}
.strip-item { display: inline-flex; align-items: baseline; gap: .8rem; }
.strip-item .num { font-size: 1.4em; color: var(--accent-2); }
.strip-rule { height: 1px; background: var(--rule); width: 100%; }

@media (max-width: 880px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-media {
    order: -1;
    /* Room for the deck cards that translate below the active slide */
    margin-bottom: clamp(5rem, 14vw, 7rem);
  }
  .hero-strip { grid-template-columns: 1fr; gap: .75rem; text-align: left; }
  .hero-strip .strip-rule { display: none; }
}

/* =============== ABOUT =============== */
.about { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.about-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(1.5rem, 4vw, 4rem); align-items: start; }
.about-grid .eyebrow { padding-top: .5rem; }
.about-grid .display { max-width: 24ch; }
.about-meta { display: grid; gap: 1.5rem; align-self: end; max-width: 42ch; color: var(--ink-2); }
@media (max-width: 800px) {
  .about-grid { grid-template-columns: 1fr; }
}

/* =============== STUDIOS =============== */
.studios { background: var(--paper); }
.studio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}
.studio-card {
  position: relative;
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .5s var(--easing), box-shadow .5s var(--easing), border-color .5s var(--easing);
}
.studio-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--lilac-soft); }
.studio-card:hover .img-frame img { transform: scale(1.03); }
.studio-card--feature {
  background: linear-gradient(165deg, var(--lilac-tint) 0%, var(--sky-tint) 50%, var(--mint-tint) 100%);
}
.studio-num {
  position: absolute; top: 1rem; right: 1.25rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 3rem;
  color: var(--accent);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  line-height: 1;
  pointer-events: none;
  z-index: 1;
}
.studio-card:nth-child(2) .studio-num { color: var(--accent-2); }
.studio-img { padding: 1rem 1rem 0; }
.studio-body { padding: 1.25rem 1.5rem 1.75rem; display: grid; gap: .65rem; }
.studio-body h3 { font-size: clamp(1.35rem, 1vw + 1rem, 1.75rem); }
.studio-body h3 .badge { font-family: var(--font-sans); margin-left: .35em; }
.studio-meta { font-size: var(--fs-small); color: var(--ink-3); letter-spacing: .02em; }
.studio-features { display: grid; gap: .3rem; font-size: .92rem; color: var(--ink-2); }
.studio-features li { padding-left: 1rem; position: relative; }
.studio-features li::before { content: '·'; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.price-line { margin-top: .3rem; font-size: .95rem; color: var(--ink); }
.price-line strong { font-family: var(--font-display); font-size: 1.4em; font-weight: 380; font-variation-settings: 'opsz' 60; }

.studio-cta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .75rem 1rem;
  margin-top: .5rem;
}

@media (max-width: 980px) { .studio-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .studio-grid { grid-template-columns: 1fr; } }

/* =============== PRICING TEASER =============== */
.pricing { background: var(--paper); }
.price-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}
.price-card {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  padding: clamp(1.5rem, 2.5vw, 2.25rem);
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  transition: transform .5s var(--easing), box-shadow .5s var(--easing), border-color .5s var(--easing);
}
.price-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--lilac-soft); }
.price-card:nth-child(2):hover { border-color: var(--sky-soft); }
.price-card:hover .link-arrow { color: var(--accent); border-color: var(--accent); gap: .65em; }
.price-card__amount {
  margin-top: .15rem;
  font-family: var(--font-display);
  font-size: clamp(2.75rem, 1.5vw + 2.25rem, 3.75rem);
  font-weight: 380;
  font-variation-settings: 'opsz' 144;
  line-height: 1;
  color: var(--ink);
}
.price-card__unit {
  margin-left: .15em;
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 500;
  color: var(--ink-3);
}
.price-card p { color: var(--ink-2); font-size: .95rem; }
.price-card .link-arrow { margin-top: auto; align-self: start; }
.price-card--media { padding: 0; gap: 0; overflow: hidden; }
.price-card__media { display: block; aspect-ratio: 16 / 10; overflow: hidden; background: var(--paper-cool); }
.price-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s var(--easing); }
.price-card--media:hover .price-card__media img { transform: scale(1.05); }
.price-card__body { display: flex; flex-direction: column; gap: .5rem; flex: 1; padding: clamp(1.5rem, 2.5vw, 2.1rem); }
.price-note {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
  max-width: 72ch;
  color: var(--ink-3);
  font-size: var(--fs-small);
}
@media (max-width: 820px) { .price-grid { grid-template-columns: 1fr; } }

/* =============== HOW TO BOOK · STEPS =============== */
.steps { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.step-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1.25rem, 3vw, 2.5rem);
  margin: 0;
  padding: 0;
  list-style: none;
}
.step {
  display: grid;
  gap: .4rem;
  align-content: start;
  padding-top: 1.1rem;
  border-top: 2px solid var(--lilac-soft);
}
.step:nth-child(even) { border-top-color: var(--sky-soft); }
.step__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2.5rem, 2vw + 1.75rem, 3.25rem);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  line-height: 1;
  color: var(--accent);
}
.step:nth-child(even) .step__num { color: var(--accent-2); }
.step h3 { font-size: var(--fs-h3); }
.step p { color: var(--ink-2); font-size: .95rem; }
.steps-foot {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 2rem;
  margin-top: clamp(2rem, 4vw, 3.5rem);
}
.steps-foot .muted { font-size: var(--fs-small); }
@media (max-width: 860px) { .step-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .step-grid { grid-template-columns: 1fr; } }

/* =============== CLASSES =============== */
.classes { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.class-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 1.5vw, 1.5rem);
}
.class-card {
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .4s var(--easing), box-shadow .4s var(--easing);
}
.class-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.class-img { padding: .75rem .75rem 0; }
.class-body { padding: 1rem 1.1rem 1.25rem; display: grid; gap: .35rem; flex: 1; }
.class-when { font-family: var(--font-sans); font-size: var(--fs-small); letter-spacing: .08em; text-transform: uppercase; color: var(--accent); font-weight: 600; }
.class-body h3 { font-size: 1.35rem; }
.class-meta { font-size: var(--fs-small); color: var(--ink-3); }
.class-price { font-size: .92rem; color: var(--ink-2); margin-top: .25rem; }
.class-price strong { color: var(--ink); font-size: 1.05rem; }
.class-body .btn { margin-top: auto; align-self: start; }

.packages {
  margin-top: clamp(2rem, 3vw, 3rem);
  padding: clamp(1rem, 2vw, 1.5rem) clamp(1.25rem, 2.5vw, 2rem);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
}
.packages p { font-size: .98rem; color: var(--ink-2); line-height: 1.7; }
.packages .eyebrow { display: inline-block; margin-right: .85em; padding: .25em .6em; background: var(--mint-tint); color: var(--ink); border-radius: 999px; border: 1px solid var(--mint-soft); }
.packages strong { color: var(--ink); }

@media (max-width: 980px) { .class-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .class-grid { grid-template-columns: 1fr; } }

/* =============== INSTRUCTORS =============== */
.instructors {
  background: var(--paper);
  border-top: 1px solid var(--rule-soft);
}

.instructor-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(1rem, 2vw, 2rem) clamp(.75rem, 1.5vw, 1.5rem);
}
.instructor-card {
  display: grid;
  gap: .5rem;
  justify-items: center;
  text-align: center;
  padding: .5rem;
}

.instructor-avatar {
  width: clamp(96px, 11vw, 140px);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  transition: transform .4s var(--easing), box-shadow .4s var(--easing), border-color .4s var(--easing);
}
.instructor-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.instructor-card:hover .instructor-avatar {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 14px 28px -12px rgba(42, 51, 64, .25);
  border-color: var(--lilac-soft);
}

/* tinted backgrounds vary per card via data-tint */
.instructor-avatar[data-tint="lilac"] { background: linear-gradient(165deg, var(--lilac-tint), var(--paper)); border-color: var(--lilac-soft); }
.instructor-avatar[data-tint="mint"]  { background: linear-gradient(165deg, var(--mint-tint),  var(--paper)); border-color: var(--mint-soft); }
.instructor-avatar[data-tint="sky"]   { background: linear-gradient(165deg, var(--sky-tint),   var(--paper)); border-color: var(--sky-soft); }

.instructor-card h3 {
  font-size: clamp(1.15rem, .35vw + 1rem, 1.35rem);
  line-height: 1.15;
  margin-top: .35rem;
}
.instructor-role {
  font-family: var(--font-sans);
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--accent);
}
.instructor-card:nth-child(3n+2) .instructor-role { color: var(--accent-2); }
.instructor-meta {
  font-family: var(--font-display);
  font-size: .9rem;
  font-style: italic;
  color: var(--ink-3);
  font-variation-settings: 'opsz' 60, 'SOFT' 100;
}

.instructors-foot {
  margin-top: clamp(2rem, 4vw, 3rem);
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule-soft);
  font-size: var(--fs-small);
  color: var(--ink-3);
  text-align: center;
}
.instructors-foot a {
  color: var(--ink);
  border-bottom: 1px solid var(--accent);
  padding-bottom: .1em;
  font-weight: 500;
  margin-left: .25em;
  transition: color .25s var(--easing);
}
.instructors-foot a:hover { color: var(--accent); }

@media (max-width: 980px) {
  .instructor-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
  .instructor-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem .75rem; }
}

/* =============== RENTAL · RATE-CARD SLIDER =============== */
.rental {
  background:
    radial-gradient(50% 50% at 100% 0%, var(--lilac-tint) 0%, transparent 60%),
    radial-gradient(40% 60% at 0% 100%, var(--mint-tint) 0%, transparent 60%),
    var(--paper);
}
.section-head__cta { align-self: end; justify-self: end; }

/* Rate-card filter chips */
.quote-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: clamp(1rem, 2vw, 1.5rem);
}
.quote-filter {
  font-family: var(--font-sans);
  font-size: .88rem;
  font-weight: 500;
  padding: .55em 1.1em;
  border: 1px solid var(--rule);
  border-radius: 999px;
  background: var(--paper);
  color: var(--ink-2);
  cursor: pointer;
  white-space: nowrap;
  transition: background .25s var(--easing), color .25s var(--easing), border-color .25s var(--easing);
}
.quote-filter:hover {
  color: var(--ink);
  border-color: var(--ink-3);
}
.quote-filter.is-active {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.quote-filter span {
  opacity: .55;
  margin-left: .25em;
  font-size: .85em;
  font-feature-settings: 'tnum';
}
.quote-filter.is-active span { opacity: .7; }
.quote-filter:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

.quote-slider-wrap {
  position: relative;
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
}
.quote-slider {
  display: flex;
  gap: clamp(1rem, 1.5vw, 1.5rem);
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 1rem var(--gutter) 2.5rem;
  scroll-padding-inline: var(--gutter);
  cursor: grab;
}
.quote-slider::-webkit-scrollbar { display: none; }
.quote-slider:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -8px;
  border-radius: var(--r-md);
}
.quote-slider.is-dragging {
  cursor: grabbing;
  scroll-snap-type: none;     /* free-scroll while dragging */
  scroll-behavior: auto;
  user-select: none;
}
.quote-slider.is-dragging * { user-select: none; }
.quote-slider.is-dragging a { pointer-events: none; }

/* receipt-styled card — concise */
.quote-card {
  flex: 0 0 clamp(260px, 24vw, 320px);
  scroll-snap-align: start;
  background:
    radial-gradient(70% 50% at 100% 0%, var(--lilac-tint) 0%, transparent 60%),
    radial-gradient(50% 50% at 0% 100%, var(--mint-tint) 0%, transparent 60%),
    linear-gradient(180deg, var(--paper) 0%, var(--paper-warm) 100%);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: clamp(1rem, 1.2vw, 1.35rem);
  position: relative;
  font-feature-settings: 'tnum', 'ss01';
  display: flex;
  flex-direction: column;
  gap: .85rem;
  box-shadow: var(--shadow-sm);
  transition: transform .5s var(--easing), box-shadow .5s var(--easing), border-color .5s var(--easing);
}
.quote-card:hover, .quote-card.is-current {
  transform: translateY(-3px);
  border-color: var(--lilac-soft);
  box-shadow: var(--shadow-md);
}
.quote-card--feature {
  background:
    radial-gradient(70% 50% at 100% 0%, var(--lilac-soft) 0%, transparent 60%),
    radial-gradient(50% 50% at 0% 100%, var(--mint-soft) 0%, transparent 60%),
    linear-gradient(180deg, var(--paper) 0%, var(--lilac-tint) 100%);
}

/* header — numeral + title only */
.quote-card__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0 .75rem;
  align-items: center;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--rule);
}
.quote-card__num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 380;
  font-size: 2.25rem;
  line-height: 1;
  color: var(--accent);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.quote-card--feature .quote-card__num { color: var(--accent-2); }
.quote-card__title { display: grid; gap: .1rem; min-width: 0; }
.quote-card__title .eyebrow { font-size: 9px; letter-spacing: .16em; }
.quote-card__title h3 { font-size: 1.15rem; line-height: 1.15; }
.quote-card__sub { font-size: var(--fs-tiny); color: var(--ink-3); letter-spacing: .02em; }

/* includes + add-ons — tighter */
.quote-card__sec { display: grid; gap: .3rem; }
.quote-card__label {
  font-family: var(--font-sans);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.quote-card__sec ul { display: grid; gap: .1rem; }
.quote-card__sec li {
  font-size: .825rem;
  color: var(--ink-2);
  padding-left: .7rem;
  position: relative;
  line-height: 1.4;
}
.quote-card__sec li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
}

.quote-card__rule { display: none; }

/* pricing — 2 × 2 grid */
.quote-card__rates {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .55rem .85rem;
  margin-top: auto;
  padding-top: .65rem;
  border-top: 1px solid var(--rule);
}
.quote-card__rates > div {
  display: grid;
  grid-template-columns: 1fr;
  gap: .1rem;
}
.quote-card__rates dt {
  font-size: 9px;
  color: var(--ink-3);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 600;
}
.quote-card__rates dd { font-size: .9rem; color: var(--ink); line-height: 1.1; }
.quote-card__rates strong {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 400;
  font-variation-settings: 'opsz' 60;
}

.quote-card__note {
  font-size: 10px;
  color: var(--ink-3);
  letter-spacing: .04em;
  line-height: 1.45;
  padding-top: .15rem;
}

/* slider controls — counter + progress + nav */
.slider-controls {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(1rem, 3vw, 2.5rem);
  margin-top: .5rem;
}
.slider-counter {
  font-family: var(--font-display);
  font-variation-settings: 'opsz' 60;
  font-size: 1.5rem;
  letter-spacing: -.01em;
  color: var(--ink-2);
}
.slider-counter__cur { color: var(--ink); font-weight: 400; }
.slider-counter__sep { margin: 0 .3em; color: var(--ink-3); font-style: italic; }
.slider-counter__tot { color: var(--ink-3); }

.slider-progress {
  height: 2px;
  background: var(--rule);
  border-radius: 2px;
  overflow: hidden;
  max-width: 480px;
  justify-self: stretch;
}
.slider-progress__bar {
  display: block;
  height: 100%;
  width: 8.33%; /* 1 of 12 default */
  background: var(--grad-logo);
  border-radius: 2px;
  transition: width .4s var(--easing);
}

.slider-nav { display: flex; gap: .5rem; }
.slider-btn {
  width: 44px; height: 44px;
  display: grid;
  place-items: center;
  border: 1px solid var(--rule);
  border-radius: 999px;
  background: var(--paper);
  color: var(--ink);
  transition: transform .25s var(--easing), background .25s var(--easing), color .25s var(--easing), border-color .25s var(--easing), opacity .25s var(--easing);
}
.slider-btn svg { width: 18px; height: 18px; }
.slider-btn:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.slider-btn:disabled { opacity: .35; cursor: not-allowed; }
.slider-btn:disabled:hover { background: var(--paper); color: var(--ink); border-color: var(--rule); }

.rental-fineprint {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
}
.rental-fineprint p { font-size: var(--fs-small); color: var(--ink-3); max-width: 80ch; }

@media (max-width: 720px) {
  .section-head__cta { align-self: start; justify-self: start; }
  .slider-controls { grid-template-columns: auto auto; gap: 1rem; }
  .slider-progress { grid-column: 1 / -1; order: 3; }
  .slider-counter { order: 1; }
  .slider-nav { order: 2; justify-self: end; }
}

/* =============== MEMBERSHIP =============== */
.membership {
  background: linear-gradient(180deg, var(--paper-warm) 0%, var(--lilac-tint) 100%);
  border-top: 1px solid var(--rule-soft);
}
.membership-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
.membership-copy { display: grid; gap: 1.5rem; max-width: 38ch; }
.perks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.25rem, 2.5vw, 2rem);
}
.perks li {
  background: var(--paper);
  padding: clamp(1.25rem, 2vw, 1.75rem);
  border-radius: var(--r-md);
  border: 1px solid var(--rule-soft);
  display: grid; gap: .5rem;
}
.perks .num { font-size: 2.5rem; line-height: 1; margin-bottom: .25rem; }
.perks li:nth-child(1) .num { color: var(--accent); }
.perks li:nth-child(2) .num { color: var(--accent-2); }
.perks li:nth-child(3) .num { color: var(--accent); }
.perks li:nth-child(4) .num { color: var(--accent-2); }
.perks h3 { font-size: 1.25rem; line-height: 1.2; }
.perks p { color: var(--ink-2); font-size: .95rem; }

@media (max-width: 880px) {
  .membership-grid { grid-template-columns: 1fr; }
}
@media (max-width: 540px) { .perks { grid-template-columns: 1fr; } }

/* =============== EVENTS =============== */
.events { background: var(--paper); }
.event-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}
.event-card {
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .4s var(--easing), box-shadow .4s var(--easing);
}
.event-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.event-img { padding: 1rem 1rem 0; }
.event-body { padding: 1.25rem 1.5rem 1.75rem; display: grid; gap: .65rem; }
.event-body h3 { font-size: 1.5rem; }
.event-body p { color: var(--ink-2); font-size: .95rem; }

.partners { margin-top: clamp(3rem, 5vw, 4.5rem); padding-top: 2rem; border-top: 1px solid var(--rule); }
.partners-label { font-family: var(--font-display); font-style: italic; font-size: 1.1rem; color: var(--ink-2); margin-bottom: 1.25rem; font-variation-settings: 'opsz' 60, 'SOFT' 100; }
.partners-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  filter: grayscale(1);
  opacity: .55;
  transition: opacity .3s var(--easing), filter .3s var(--easing);
}
.partners-strip:hover { opacity: 1; filter: grayscale(0); }
.partners-strip img {
  height: clamp(28px, 4vw, 44px);
  width: auto;
  object-fit: contain;
}
.partners-strip a { display: inline-flex; align-items: center; }

/* student collab cards */
.collabs {
  margin-top: clamp(2.5rem, 5vw, 4rem);
  padding-top: clamp(2rem, 4vw, 3rem);
  border-top: 1px solid var(--rule);
}
.collabs-head {
  display: grid;
  gap: .65rem;
  max-width: 60ch;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
}
.collabs-title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.6vw + 1rem, 2.25rem);
  font-weight: 360;
  line-height: 1.1;
  letter-spacing: -.015em;
  font-variation-settings: 'opsz' 60, 'SOFT' 50;
}

.collab-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}

.collab-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: clamp(1.25rem, 2vw, 1.75rem);
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-md);
  transition: transform .4s var(--easing), box-shadow .4s var(--easing), border-color .4s var(--easing);
}
.collab-card:hover {
  transform: translateY(-3px);
  border-color: var(--lilac-soft);
  box-shadow: var(--shadow-md);
}
.collab-card--active {
  background: linear-gradient(165deg, var(--mint-tint), var(--paper) 65%);
  border-color: var(--mint-soft);
}

.collab-card > header { display: grid; gap: .45rem; }
.collab-card h4 {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, .5vw + 1rem, 1.45rem);
  font-weight: 360;
  line-height: 1.2;
  letter-spacing: -.01em;
}
.collab-card__for { font-size: var(--fs-small); color: var(--ink-3); line-height: 1.4; }

.collab-badge {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .3em .65em;
  border-radius: 999px;
  width: fit-content;
}
.collab-badge--active {
  background: color-mix(in srgb, #5fb591 18%, var(--paper));
  color: #2e6850;
  border: 1px solid color-mix(in srgb, #5fb591 35%, transparent);
}
.collab-badge--active::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #5fb591;
  box-shadow: 0 0 0 3px color-mix(in srgb, #5fb591 25%, transparent);
}
.collab-badge--pending {
  background: var(--paper-cool);
  color: var(--ink-2);
  border: 1px dashed var(--rule);
}

.collab-prices {
  display: grid;
  gap: .35rem;
  padding-block: .85rem;
  border-block: 1px solid var(--rule);
}
.collab-prices > div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: .1rem 0;
}
.collab-prices dt {
  font-size: var(--fs-small);
  color: var(--ink-2);
  letter-spacing: .01em;
}
.collab-prices dd {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 400;
  font-variation-settings: 'opsz' 60;
  color: var(--ink);
}

.collab-meta { font-size: .88rem; color: var(--ink-2); line-height: 1.55; }
.collab-card .link-arrow { margin-top: auto; align-self: start; }

@media (max-width: 980px) { .collab-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .collab-grid { grid-template-columns: 1fr; } }

@media (max-width: 880px) { .event-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .event-grid { grid-template-columns: 1fr; } }

/* =============== LOCATION =============== */
.location { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.location-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.location-copy { display: grid; gap: 1.25rem; max-width: 44ch; }
.address {
  font-style: normal;
  font-family: var(--font-display);
  font-size: 1.35rem;
  line-height: 1.5;
  color: var(--ink);
  font-variation-settings: 'opsz' 60;
  padding: 1.25rem 1.5rem;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  width: fit-content;
}
.transit { display: grid; gap: .5rem; }
.transit li { display: flex; align-items: center; gap: .75rem; font-size: .98rem; color: var(--ink-2); }

.location-map figcaption { margin-top: .75rem; text-align: center; font-size: var(--fs-small); color: var(--ink-3); }
.location-map figcaption a {
  color: var(--accent);
  border-bottom: 1px solid var(--accent);
  padding-bottom: .08em;
  margin-left: .25em;
  white-space: nowrap;
  transition: opacity .2s var(--easing);
}
.location-map figcaption a:hover { opacity: .75; }

.map-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: var(--r-md);
  overflow: hidden;
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  box-shadow: var(--shadow-sm);
}
.map-frame iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  filter: saturate(.9);
}

@media (max-width: 880px) { .location-grid { grid-template-columns: 1fr; } }

/* =============== CONTACT =============== */
.contact { background: var(--paper); }
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}
.contact-card {
  display: grid; gap: .5rem;
  padding: clamp(1.5rem, 2.5vw, 2.25rem);
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  transition: transform .4s var(--easing), box-shadow .4s var(--easing), border-color .4s var(--easing);
  color: var(--ink);
}
.contact-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--lilac-soft); }
.contact-card__icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--paper);
  border: 1px solid var(--rule);
  color: var(--accent);
  margin-bottom: .35rem;
  transition: background .3s var(--easing), color .3s var(--easing), border-color .3s var(--easing);
}
.contact-card__icon svg { width: 22px; height: 22px; }
.contact-card:hover .contact-card__icon {
  background: var(--accent);
  color: var(--paper);
  border-color: var(--accent);
}
.contact-card:nth-child(2) .contact-card__icon { color: var(--accent-2); }
.contact-card:nth-child(2):hover .contact-card__icon { background: var(--accent-2); border-color: var(--accent-2); color: var(--paper); }
.contact-card h3 { font-size: 1.5rem; }
.contact-card p { color: var(--ink-2); font-size: .95rem; }
.contact-card .link-arrow { margin-top: .5rem; align-self: start; }
.contact-card--feature { background: linear-gradient(165deg, var(--lilac-tint) 0%, var(--sky-tint) 100%); }

.contact-direct {
  margin-top: clamp(2rem, 4vw, 3.5rem);
  padding-top: 2rem;
  border-top: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  align-items: end;
}
.contact-direct ul { display: grid; gap: .35rem; margin-top: .75rem; font-size: 1rem; }
.contact-direct a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--rule); text-underline-offset: 3px; transition: color .25s var(--easing), text-decoration-color .25s var(--easing); }
.contact-direct a:hover { text-decoration-color: var(--accent); }
.contact-direct a:hover { color: var(--accent); border-color: var(--accent); }
.contact-note { font-size: var(--fs-small); color: var(--ink-3); max-width: 38ch; text-align: right; justify-self: end; }

@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } .contact-direct { grid-template-columns: 1fr; } .contact-note { text-align: left; justify-self: start; } }

/* =============== FOOTER =============== */
.site-footer {
  background: var(--ink);
  color: color-mix(in srgb, var(--paper) 80%, transparent);
  padding: clamp(3rem, 6vw, 5rem) 0 1.5rem;
  position: relative;
  isolation: isolate;
}
/* faint logo-echo wash on the footer */
.site-footer::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(40% 60% at 100% 0%, color-mix(in srgb, var(--lilac) 18%, transparent) 0%, transparent 60%),
    radial-gradient(40% 60% at 0% 100%, color-mix(in srgb, var(--mint) 15%, transparent) 0%, transparent 60%);
  pointer-events: none;
  z-index: -1;
}
.site-footer .brand__word { color: var(--paper); }

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
  gap: clamp(2rem, 4vw, 3rem);
  padding-bottom: clamp(2rem, 4vw, 3rem);
  border-bottom: 1px solid rgba(255, 255, 255, .1);
}
.footer-tag { margin-top: 1rem; font-family: var(--font-display); font-style: italic; font-size: 1.1rem; color: var(--lilac-soft); max-width: 22ch; font-variation-settings: 'opsz' 60, 'SOFT' 100; }
.footer-col__title { font-size: var(--fs-tiny); font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--lilac-soft); margin-bottom: 1rem; }
.footer-col address { font-style: normal; line-height: 1.7; color: color-mix(in srgb, var(--paper) 70%, transparent); }
.footer-col ul { display: grid; gap: .55rem; }
.footer-col a { color: color-mix(in srgb, var(--paper) 75%, transparent); font-size: .95rem; transition: color .2s var(--easing); }
.footer-col a:hover { color: var(--lilac); }

.footer-bottom {
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  padding-top: 1.5rem; font-size: var(--fs-small);
  color: color-mix(in srgb, var(--paper) 50%, transparent);
}
.footer-bottom .muted { color: color-mix(in srgb, var(--paper) 40%, transparent); }

@media (max-width: 880px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 520px) { .footer-grid { grid-template-columns: 1fr; } }

/* =============== Mobile header =============== */
@media (max-width: 980px) {
  .primary-nav, .header-aux .lang-toggle, .header-aux .btn { display: none; }
  .nav-toggle { display: block; }
}
body.nav-open { overflow: hidden; }

/* =============== Reveal animation =============== */
/* Scroll-reveal — only hides content once JS has confirmed it can reveal it
   again (the .js gate). No JS, no hiding. */
.reveal { transition: opacity .8s var(--easing), transform .8s var(--easing); }
.js .reveal { opacity: 0; transform: translateY(14px); }
.js .reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
}

/* =============== Floating WhatsApp =============== */
.whatsapp-fab {
  position: fixed;
  bottom: clamp(1rem, 2vw, 1.5rem);
  right: clamp(1rem, 2vw, 1.5rem);
  z-index: 60;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  height: clamp(52px, 5.6vw, 60px);
  padding-inline: .55rem;
  background: #25D366;
  color: #FFFFFF;
  border-radius: 999px;
  box-shadow:
    0 10px 28px -10px rgba(37, 211, 102, .6),
    0 4px 10px rgba(42, 51, 64, .15);
  transition: transform .25s var(--easing), box-shadow .25s var(--easing), padding-right .35s var(--easing);
  isolation: isolate;
  text-decoration: none;
}
.whatsapp-fab svg {
  width: 28px; height: 28px;
  fill: currentColor;
  flex-shrink: 0;
}
.whatsapp-fab__label {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .01em;
  padding-right: .55rem;
}
.whatsapp-fab:hover {
  transform: translateY(-3px);
  box-shadow:
    0 16px 36px -10px rgba(37, 211, 102, .7),
    0 8px 14px rgba(42, 51, 64, .2);
}
.whatsapp-fab:focus-visible {
  outline: 3px solid #FFFFFF;
  outline-offset: 3px;
}

/* soft pulse ring — disabled by reduced-motion via the global rule */
.whatsapp-fab::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: #25D366;
  z-index: -1;
  opacity: 0;
  animation: wa-pulse 2.6s ease-out infinite;
}
@keyframes wa-pulse {
  0%   { transform: scale(1);    opacity: .35; }
  80%  { transform: scale(1.35); opacity: 0; }
  100% { transform: scale(1.35); opacity: 0; }
}

/* mobile — icon only, label hidden, smaller tap target */
@media (max-width: 640px) {
  .whatsapp-fab {
    width: 56px; height: 56px;
    padding-inline: 0;
    justify-content: center;
    border-radius: 50%;
  }
  .whatsapp-fab::before { border-radius: 50%; }
  .whatsapp-fab__label { display: none; }
}

/* =============== Snowfall =============== */
#snowfall {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 9;
}

/* =============== Print =============== */
@media print {
  .site-header, .site-footer, .nav-toggle, .mobile-drawer, .cta-row, .btn, .lang-toggle, .whatsapp-fab { display: none !important; }
  body { background: white; color: black; }
}

/* =====================================================================
   Doorway homepage — chooser, gallery teaser, stub pages
   Added for the multi-page redesign. Reuses the existing tokens above.
   ===================================================================== */

/* --- Active nav state (multi-page) --- */
.primary-nav a[aria-current="page"] { color: var(--ink); border-color: var(--accent); }
.mobile-drawer a[aria-current="page"] { color: var(--accent); }

/* --- Doorway: hero intro + chooser --- */
.doorway {
  background:
    radial-gradient(60% 60% at 90% 0%, var(--lilac-tint) 0%, transparent 60%),
    radial-gradient(50% 50% at 0% 20%, var(--mint-tint) 0%, transparent 60%),
    var(--paper);
}
.doorway-intro { display: grid; gap: clamp(1rem, 2vw, 1.5rem); max-width: 34ch; }
.doorway-intro .display {
  font-size: clamp(2.5rem, 3.4vw + .75rem, 4.75rem);
  text-wrap: balance;
}
.doorway-intro .lead { max-width: 52ch; }

.chooser-head {
  margin-top: clamp(2.5rem, 6vw, 4.5rem);
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
  display: grid;
  gap: .6rem;
}

.chooser {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1rem, 2vw, 1.75rem);
}
.chooser-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  overflow: hidden;
  color: var(--ink);
  transition: transform .5s var(--easing), box-shadow .5s var(--easing), border-color .5s var(--easing);
}
.chooser-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: var(--lilac-soft);
}
.chooser-card__media {
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--paper-cool);
}
.chooser-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .8s var(--easing);
}
.chooser-card:hover .chooser-card__media img { transform: scale(1.04); }
.chooser-card__body {
  padding: clamp(1.35rem, 2.2vw, 2rem);
  display: grid;
  gap: .55rem;
  position: relative;
}
.chooser-card__num {
  position: absolute;
  top: clamp(1.35rem, 2.2vw, 2rem);
  right: clamp(1.35rem, 2.2vw, 2rem);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 380;
  font-size: 2.4rem;
  line-height: 1;
  color: var(--accent);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  pointer-events: none;
}
.chooser-card:nth-child(2) .chooser-card__num,
.chooser-card:nth-child(3) .chooser-card__num { color: var(--accent-2); }
.chooser-card__body h3 {
  font-size: clamp(1.5rem, 1.2vw + 1rem, 2rem);
  padding-right: 2.5rem;
}
.chooser-card__body p { color: var(--ink-2); font-size: .98rem; max-width: 40ch; }
.chooser-card .link-arrow { margin-top: .35rem; align-self: start; }
.chooser-card:hover .link-arrow { color: var(--accent); border-color: var(--accent); gap: .65em; }

@media (max-width: 720px) {
  .chooser { grid-template-columns: 1fr; }
}

/* --- Gallery · stacked-deck slider --- */
.gallery-teaser {
  background: var(--paper-warm);
  border-top: 1px solid var(--rule-soft);
  border-bottom: 1px solid var(--rule-soft);
}
.gallery-slider {
  max-width: 760px;
  /* Bottom space lets the deck's lower cards peek out without crowding
     the next section; top space separates it from the heading. */
  margin: clamp(2rem, 4vw, 3rem) auto clamp(5.5rem, 8vw, 7rem);
}

/* =====================================================================
   About page — page hero, stats, two-column split, CTA band
   ===================================================================== */
.page-hero {
  background:
    radial-gradient(55% 70% at 92% -10%, var(--lilac-tint) 0%, transparent 60%),
    radial-gradient(45% 60% at -8% 115%, var(--mint-tint) 0%, transparent 55%),
    var(--paper);
  border-bottom: 1px solid var(--rule-soft);
}
.page-hero .display { max-width: 20ch; margin-top: .6rem; }
.page-hero .lead { max-width: 56ch; margin-top: 1.4rem; }

.about-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 2.5vw, 2.5rem);
  margin-top: clamp(2.5rem, 5vw, 4rem);
  padding-top: clamp(1.5rem, 3vw, 2.25rem);
  border-top: 1px solid var(--rule);
}
.stat__value {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1vw + 1.3rem, 2.1rem);
  font-weight: 380;
  font-variation-settings: 'opsz' 72;
  line-height: 1.1;
  color: var(--ink);
}
.stat__label { margin-top: .3rem; font-size: var(--fs-small); color: var(--ink-3); }

/* Get-to-know-us spaces — reuses the .studio-card grid */
.spaces { background: var(--paper); }
.studio-desc { color: var(--ink-2); font-size: .95rem; }

/* Two-column split — used by the team section */
.team { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.split-grid {
  display: grid;
  grid-template-columns: 1.02fr .98fr;
  gap: clamp(1.75rem, 4vw, 4.5rem);
  align-items: center;
}
.split-copy { display: grid; gap: 1rem; max-width: 52ch; }
.split-copy p { color: var(--ink-2); }
.split-copy .link-arrow { margin-top: .5rem; justify-self: start; }
.split-figure { margin: 0; }
.split-grid--rev .split-figure { order: -1; }

/* Closing CTA band */
.cta-band {
  background: var(--grad-logo-soft);
  border-top: 1px solid var(--rule-soft);
  text-align: center;
}
.cta-band .display { margin-top: .5rem; }
.cta-band__lead { max-width: 54ch; margin: 1rem auto 0; color: var(--ink-2); }
.cta-band .cta-row { justify-content: center; margin-top: 1.75rem; }

@media (max-width: 900px) {
  .split-grid { grid-template-columns: 1fr; gap: clamp(1.5rem, 5vw, 2.5rem); }
  .split-grid--rev .split-figure { order: 0; }
}
@media (max-width: 680px) {
  .about-stats { grid-template-columns: 1fr 1fr; gap: 1.25rem 1rem; }
}

/* =====================================================================
   Dance classes page — style tags, path cards, FAQ accordion
   ===================================================================== */
.style-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.4rem; }
.page-hero .cta-row { margin-top: 1.6rem; }

/* Video hero — looping background clip with a scrim for text contrast */
.page-hero--video {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: flex;
  align-items: center;
  min-height: clamp(460px, 66vh, 680px);
  background: var(--ink);
  border-bottom: 1px solid var(--rule-soft);
}
.page-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -2;
}
.page-hero__scrim {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(95deg,
    rgba(24, 28, 36, .92) 0%,
    rgba(24, 28, 36, .74) 40%,
    rgba(24, 28, 36, .42) 72%,
    rgba(24, 28, 36, .26) 100%);
}
.page-hero--video .eyebrow { color: var(--lilac-soft); }
.page-hero--video .display { color: var(--paper); }
.page-hero--video .lead { color: rgba(255, 255, 255, .82); }
.page-hero--video .btn--outline { color: var(--paper); border-color: rgba(255, 255, 255, .5); }
.page-hero--video .btn--outline:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }

.paths { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.path-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}
.path-card {
  display: flex;
  flex-direction: column;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform .5s var(--easing), box-shadow .5s var(--easing), border-color .5s var(--easing);
}
.path-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--lilac-soft); }
.path-card__media { aspect-ratio: 16 / 10; overflow: hidden; background: var(--paper-cool); }
.path-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s var(--easing); }
.path-card:hover .path-card__media img { transform: scale(1.05); }
.path-card__body {
  display: flex;
  flex-direction: column;
  gap: .85rem;
  flex: 1;
  padding: clamp(1.5rem, 2.5vw, 2.1rem);
}
.path-card h3 { font-size: var(--fs-h3); }
.path-card ul { display: grid; gap: .4rem; }
.path-card li {
  position: relative;
  padding-left: 1.1rem;
  font-size: .95rem;
  color: var(--ink-2);
}
.path-card li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .5em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}
.path-card .link-arrow { margin-top: auto; align-self: start; }

.faq { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.faq-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: start;
}
.faq-col { display: grid; gap: clamp(1.5rem, 3vw, 2.5rem); align-content: start; }
.faq-group__title {
  margin-bottom: .85rem;
  padding-bottom: .55rem;
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-sans);
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
}
.faq-list { display: grid; gap: .5rem; }
@media (max-width: 760px) { .faq-cols { grid-template-columns: 1fr; gap: clamp(1.5rem, 5vw, 2.5rem); } }
.faq-item {
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-md);
}
.faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.05rem 1.25rem;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-variation-settings: 'opsz' 40;
  color: var(--ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '';
  flex: none;
  width: 9px;
  height: 9px;
  border-right: 2px solid var(--accent);
  border-bottom: 2px solid var(--accent);
  transform: rotate(45deg);
  transition: transform .25s var(--easing);
}
.faq-item[open] summary::after { transform: rotate(-135deg); }
.faq-item summary:hover { color: var(--accent); }
.faq-item p {
  margin: 0;
  padding: 0 1.25rem 1.2rem;
  max-width: 70ch;
  color: var(--ink-2);
  font-size: .95rem;
}

/* What you get · community · hangouts */
.included { background: var(--paper); }
.checklist { display: grid; gap: .65rem; }
.checklist--cols { grid-template-columns: 1fr 1fr; gap: .65rem 2rem; max-width: 720px; }
.checklist li {
  position: relative;
  padding-left: 1.85rem;
  color: var(--ink-2);
}
.checklist li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .12em;
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 50%;
  background: var(--accent) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 13l4 4L19 7' fill='none' stroke='%23ffffff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / .68rem no-repeat;
}
.community { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.hangouts { background: var(--paper); }
.hangouts .link-arrow { margin-top: 1.3rem; }

/* Moments gallery — masonry */
.moments { background: var(--paper); }
.moments-grid {
  columns: 3;
  column-gap: clamp(.75rem, 1.5vw, 1.1rem);
}
.moments-tile {
  break-inside: avoid;
  margin-bottom: clamp(.75rem, 1.5vw, 1.1rem);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-md);
  overflow: hidden;
}
.moments-tile img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .8s var(--easing);
}
.moments-tile:hover img { transform: scale(1.04); }

/* Videos — YouTube gallery */
.videos { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.videos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.6rem);
}
.video-tile { display: flex; flex-direction: column; gap: .7rem; }
.video-tile__thumb {
  display: block;
  position: relative;
  aspect-ratio: 16 / 9;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--paper-cool);
}
.video-tile__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s var(--easing); }
.video-tile:hover .video-tile__thumb img { transform: scale(1.05); }
.video-tile__play { position: absolute; inset: 0; display: grid; place-items: center; }
.video-tile__play::after {
  content: '';
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(42, 51, 64, .72) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M8 5v14l11-7z' fill='%23ffffff'/%3E%3C/svg%3E") 54% / 20px no-repeat;
  transition: background-color .25s var(--easing), transform .25s var(--easing);
}
.video-tile:hover .video-tile__play::after { background-color: var(--accent); transform: scale(1.1); }
.video-tile__title { font-size: .95rem; font-weight: 500; color: var(--ink); transition: color .2s var(--easing); }
.video-tile:hover .video-tile__title { color: var(--accent); }

/* Book now — location landmarks */
.places { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.places-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}
.place-card { margin: 0; display: grid; gap: .85rem; }
.place-card__cap { display: grid; gap: .2rem; }
.place-card__cap strong {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.15rem;
  font-variation-settings: 'opsz' 40;
  color: var(--ink);
}
.place-card__cap span { font-size: .92rem; color: var(--ink-2); }

/* Payment options */
.payment { background: var(--paper); }
.payment-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1rem, 2vw, 1.5rem);
}
.payment-card {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2vw, 1.5rem);
  padding: clamp(1.25rem, 2.2vw, 1.75rem);
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
}
.payment-card__qr {
  flex: none;
  width: clamp(108px, 13vw, 148px);
  aspect-ratio: 1;
  padding: .4rem;
  background: #fff;
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-md);
}
.payment-card__qr img { width: 100%; height: 100%; object-fit: contain; display: block; }
.payment-card__body { display: grid; gap: .12rem; }
.payment-card__num {
  margin-bottom: .15rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--accent);
}
.payment-card__body h3 { font-size: var(--fs-h3); }
.payment-card__sub { color: var(--ink-2); font-size: .95rem; }
.payment-card__meta { color: var(--ink-3); font-size: var(--fs-small); }
.payment-note {
  margin-top: clamp(1.25rem, 2.5vw, 2rem);
  max-width: 76ch;
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  background: var(--lilac-tint);
  border-radius: var(--r-lg);
}
.payment-note ul { display: grid; gap: .55rem; margin-top: .6rem; }
.payment-note li {
  position: relative;
  padding-left: 1.15rem;
  color: var(--ink-2);
  font-size: .95rem;
}
.payment-note li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .55em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--accent);
}

@media (max-width: 860px) { .videos-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 820px) { .path-grid { grid-template-columns: 1fr; } }
@media (max-width: 760px) { .moments-grid { columns: 2; } }
@media (max-width: 720px) { .payment-grid { grid-template-columns: 1fr; } .places-grid { grid-template-columns: 1fr; } }
@media (max-width: 560px) { .checklist--cols { grid-template-columns: 1fr; } .videos-grid { grid-template-columns: 1fr; } }
@media (max-width: 460px) { .moments-grid { columns: 1; } }

/* =====================================================================
   Music & Vocal page — instructors, instrument cards, coming-soon
   ===================================================================== */
.instructors { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.instructors .split-grid + .split-grid { margin-top: clamp(2.5rem, 6vw, 4.5rem); }

.instruments { background: var(--paper); }
.instrument-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1rem, 2vw, 1.75rem);
}
.instrument-card {
  display: grid;
  gap: .5rem;
  align-content: start;
  padding: clamp(1.5rem, 2.5vw, 2.1rem);
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
}
.instrument-card h3 { font-size: var(--fs-h3); }
.instrument-card__tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  font-variation-settings: 'opsz' 40, 'SOFT' 100;
  color: var(--accent);
}
.instrument-card p { color: var(--ink-2); font-size: .95rem; }

.coming-soon {
  margin-top: clamp(1.75rem, 3.5vw, 2.75rem);
  padding-top: clamp(1.5rem, 3vw, 2.25rem);
  border-top: 1px solid var(--rule);
}
.coming-soon h3 { font-size: var(--fs-h3); }
.coming-soon p { margin-top: .35rem; color: var(--ink-2); font-size: .95rem; }
.coming-soon .style-tags { margin-top: 1rem; }

.boutique { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.why-music { background: var(--paper); }

@media (max-width: 720px) { .instrument-grid { grid-template-columns: 1fr; } }

/* --- Stub / coming-soon pages --- */
.stub {
  min-height: clamp(60vh, 70vh, 760px);
  display: grid;
  place-items: center;
  text-align: center;
  background:
    radial-gradient(55% 55% at 85% 5%, var(--lilac-tint) 0%, transparent 60%),
    radial-gradient(50% 50% at 10% 95%, var(--mint-tint) 0%, transparent 60%),
    var(--paper);
}
.stub-inner {
  display: grid;
  gap: 1.15rem;
  justify-items: center;
  max-width: 56ch;
}
.stub-inner .display { font-size: clamp(2.5rem, 4vw + 1rem, 4.5rem); }
.stub-tag {
  display: inline-flex;
  align-items: center;
  gap: .5em;
  font-family: var(--font-sans);
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: .4em .9em;
  border-radius: 999px;
}
.stub-tag::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}
.stub-inner .lead { color: var(--ink-2); }
.stub-inner .cta-row { justify-content: center; margin-top: .5rem; }

/* --- Class schedule --- */
.schedule { background: var(--paper); }
.steps { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }

/* Calendar module */
.cal {
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  padding: clamp(1rem, 2.5vw, 2rem);
}
.cal__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .35rem .9rem;
  margin-bottom: clamp(1rem, 2.5vw, 1.5rem);
}
.cal__month {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.4vw + 1.1rem, 2.1rem);
  font-variation-settings: 'opsz' 72, 'SOFT' 60;
  color: var(--ink);
}
.cal__sub { font-size: var(--fs-small); color: var(--ink-3); }
.cal__weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-bottom: 6px;
}
.cal__weekday {
  text-align: center;
  padding: .35rem 0;
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.cal__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}
.cal-cell {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  min-width: 0;
  min-height: 152px;
  padding: .55rem;
  background: var(--snow);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-md);
}
.cal-cell--blank { background: transparent; }
.cal-cell--today { box-shadow: inset 0 0 0 2px var(--accent); }
.cal-cell__head { display: flex; align-items: baseline; gap: .4rem; }
.cal-cell__wd {
  display: none;
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.cal-cell__date { font-family: var(--font-display); font-size: 1rem; color: var(--ink-2); }
.cal-cell--today .cal-cell__date { color: var(--accent); }
.cal-cell__classes { display: grid; gap: .3rem; }
.cal-class {
  display: block;
  padding: .35rem .45rem;
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  transition: filter .2s var(--easing);
}
a.cal-class:hover { filter: brightness(.965); }
.cal-class__time {
  display: block;
  font-size: var(--fs-tiny);
  letter-spacing: .02em;
  color: var(--ink-3);
}
.cal-class__name {
  display: block;
  font-size: .82rem;
  font-weight: 500;
  line-height: 1.25;
  color: var(--ink);
}
.cal-class--barbie    { background: var(--lilac-tint); border-color: var(--lilac-soft); }
.cal-class--jas       { background: var(--sky-tint);   border-color: var(--sky-soft); }
.cal-class--pearly    { background: var(--mint-tint);  border-color: var(--mint-soft); }
.cal-class--jaspearly { background: var(--paper-cool); border-color: var(--rule); }
.cal-class--muted     { background: var(--paper-cool); border-color: var(--rule); }
.cal-class--muted .cal-class__name { color: var(--ink-3); font-weight: 400; font-style: italic; }
.cal-cell__status {
  display: flex;
  align-items: center;
  gap: .45em;
  margin-top: auto;
  padding-top: .35rem;
  font-size: var(--fs-tiny);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.cal-dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.cal-dot--confirmed { background: var(--accent); }
.cal-dot--waitlist { border: 1.5px solid var(--ink-3); }

/* Calendar legend */
.cal-legend {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(244px, 1fr));
  gap: clamp(1rem, 2.5vw, 1.75rem);
  margin-top: clamp(1.5rem, 3vw, 2.25rem);
}
.cal-legend__group {
  display: grid;
  gap: .7rem;
  align-content: start;
  padding: clamp(1.1rem, 2vw, 1.5rem);
  background: var(--paper-warm);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
}
.cal-legend__title {
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
}
.cal-key { display: flex; align-items: center; gap: .65rem; }
.cal-key__swatch { width: 22px; height: 22px; border-radius: 6px; border: 1px solid var(--rule); flex: none; }
.cal-key__swatch--barbie    { background: var(--lilac-soft); border-color: var(--lilac); }
.cal-key__swatch--jas       { background: var(--sky-soft);   border-color: var(--sky); }
.cal-key__swatch--pearly    { background: var(--mint-soft);  border-color: var(--mint); }
.cal-key__swatch--jaspearly { background: var(--paper-cool); border-color: var(--rule); }
.cal-key__name { font-size: .95rem; color: var(--ink); }
.cal-key__name span { color: var(--ink-3); }
.cal-status-row { display: flex; align-items: start; gap: .55rem; font-size: .92rem; color: var(--ink-2); }
.cal-status-row .cal-dot { margin-top: .35em; }
.cal-status-row strong { font-weight: 600; color: var(--ink); }
.cal-social { display: flex; flex-wrap: wrap; gap: .4rem; }
.cal-social li {
  font-size: .82rem;
  color: var(--ink-2);
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: 999px;
  padding: .25rem .7rem;
}
.cal-legend__note { font-size: var(--fs-small); color: var(--ink-3); }

@media (max-width: 900px) {
  .cal__weekdays { display: none; }
  .cal__grid { grid-template-columns: 1fr; gap: .5rem; }
  .cal-cell { min-height: 0; }
  .cal-cell--blank { display: none; }
  .cal-cell__wd { display: inline; }
}

.sched-note {
  margin-top: clamp(1.75rem, 3.5vw, 2.75rem);
  max-width: 74ch;
  color: var(--ink-3);
  font-size: var(--fs-small);
}

.steps__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(238px, 1fr));
  gap: clamp(1rem, 2vw, 1.75rem);
}
.step-card {
  display: grid;
  gap: .5rem;
  align-content: start;
  padding: clamp(1.5rem, 2.5vw, 2.1rem);
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
}
.step-card__num {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-variation-settings: 'opsz' 90, 'SOFT' 80;
  line-height: 1;
  color: var(--accent);
}
.step-card h3 { font-size: var(--fs-h3); }
.step-card p { color: var(--ink-2); font-size: .95rem; }

.sched-note a, .price-note a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .25s var(--easing);
}
.sched-note a:hover, .price-note a:hover { color: var(--ink); }

/* --- Auto-icons on action buttons. Matches .btn links by href; the icon is
   masked so it inherits the button's text colour via background-color. --- */
.btn[href^="https://wa.me"]::before,
.btn[href^="https://api.whatsapp.com"]::before,
.btn[href^="mailto:"]::before,
.btn[href^="tel:"]::before,
.btn[href*="google.com/maps"]::before {
  content: '';
  display: inline-block;
  width: 1.05em;
  height: 1.05em;
  margin-right: .55em;
  background-color: currentColor;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  vertical-align: -.2em;
}
.btn[href^="https://wa.me"]::before,
.btn[href^="https://api.whatsapp.com"]::before {
  -webkit-mask-image: url('/icons/wa.svg');
          mask-image: url('/icons/wa.svg');
}
.btn[href^="mailto:"]::before {
  -webkit-mask-image: url('/icons/email.svg');
          mask-image: url('/icons/email.svg');
}
.btn[href^="tel:"]::before {
  -webkit-mask-image: url('/icons/phone.svg');
          mask-image: url('/icons/phone.svg');
}
.btn[href*="google.com/maps"]::before {
  -webkit-mask-image: url('/icons/maps.svg');
          mask-image: url('/icons/maps.svg');
}

/* --- Partners strip (home page) --- */
.partners { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.partners .partners-strip { justify-content: center; margin-top: clamp(1.25rem, 2.5vw, 2rem); }
.partners-note { margin-top: clamp(1.25rem, 2.5vw, 2rem); text-align: center; color: var(--ink-3); font-size: var(--fs-small); }
.partners .section-head { text-align: center; margin-left: auto; margin-right: auto; }

/* --- Dense gallery grid + lightbox --- */
.moments-grid--dense { columns: 4; }
.moments-grid--dense .moments-tile { cursor: zoom-in; }
@media (max-width: 1100px) { .moments-grid--dense { columns: 3; } }
@media (max-width: 700px)  { .moments-grid--dense { columns: 2; } }

.lb {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(15, 18, 24, .92);
  padding: clamp(1rem, 4vw, 3rem);
}
.lb.is-open { display: flex; }
body.lb-open { overflow: hidden; }
.lb__figure {
  margin: 0;
  max-width: 100%;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
.lb__img {
  max-width: 100%;
  max-height: calc(100vh - 10rem);
  object-fit: contain;
  border-radius: var(--r-md);
  background: #000;
}
.lb__caption {
  color: var(--paper);
  font-size: var(--fs-small);
  text-align: center;
  opacity: .8;
  max-width: 60ch;
}
.lb__counter {
  position: absolute;
  top: clamp(.75rem, 2vw, 1.25rem);
  left: 50%;
  transform: translateX(-50%);
  color: var(--paper);
  font-size: var(--fs-tiny);
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .7;
}
.lb__close, .lb__nav {
  position: absolute;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, .25);
  color: var(--paper);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  font-size: 1.6rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .2s var(--easing), border-color .2s var(--easing);
}
.lb__close:hover, .lb__nav:hover { background: rgba(255, 255, 255, .1); border-color: rgba(255, 255, 255, .5); }
.lb__close { top: clamp(.75rem, 2vw, 1.25rem); right: clamp(.75rem, 2vw, 1.25rem); }
.lb__nav--prev { left: clamp(.75rem, 2vw, 1.25rem); top: 50%; transform: translateY(-50%); }
.lb__nav--next { right: clamp(.75rem, 2vw, 1.25rem); top: 50%; transform: translateY(-50%); }
@media (max-width: 640px) {
  .lb__nav--prev { left: .5rem; }
  .lb__nav--next { right: .5rem; }
}

/* --- Classes hub --- */
.teach { background: var(--paper-warm); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.teach-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3.5vw, 3rem);
}
.teach-group { display: grid; gap: .85rem; align-content: start; }
@media (max-width: 760px) { .teach-grid { grid-template-columns: 1fr; } }

/* --- Studio rental — rate table --- */
.rates { background: var(--paper); }
.rate-table-wrap {
  overflow-x: auto;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
}
.rate-table { width: 100%; border-collapse: collapse; min-width: 600px; }
.rate-table th,
.rate-table td {
  padding: .9rem 1.15rem;
  text-align: left;
  border-bottom: 1px solid var(--rule-soft);
}
.rate-table thead th {
  font-family: var(--font-sans);
  font-size: var(--fs-tiny);
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
  white-space: nowrap;
}
.rate-table tbody tr:last-child td { border-bottom: 0; }
.rate-table tbody tr:hover { background: var(--paper-warm); }
.rate-table td { color: var(--ink-2); font-size: .95rem; white-space: nowrap; }
.rate-table td:first-child { color: var(--ink); font-weight: 500; white-space: normal; }
.rate-table__sub {
  display: block;
  margin-top: .15rem;
  font-size: var(--fs-tiny);
  font-weight: 400;
  color: var(--ink-3);
}
.rate-note {
  margin-top: clamp(1.25rem, 2.5vw, 1.75rem);
  max-width: 76ch;
  color: var(--ink-3);
  font-size: var(--fs-small);
}
