/* =========================================================
   AAIRA · ORGANICS & WELLNESS
   Relaxed spa · warm off-white & layered greys
   ========================================================= */

:root {
  /* ---- Layout tokens ---- */
  --nav-h: 80px;          /* fixed nav height — hero offsets content below this */

  /* ---- Palette: warm off-white base with layered greys + blush accents ---- */
  --paper:       #f2f0ec;   /* page base — warm off-white */
  --paper-2:     #e8e5df;   /* panels / alternating sections */
  --mist:        #dcd9d3;   /* borders, dividers */
  --stone:       #b8b4ac;   /* muted secondary */
  --slate:       #6e6b66;   /* body secondary / eyebrow */
  --ink:         #2f2e2c;   /* primary text */
  --char:        #1e1d1b;   /* near-black for headings / buttons */
  --charcoal:    #3a3836;   /* dark section backgrounds */

  /* Blossom accents — subtle pink highlights throughout */
  --blush-pale:  #f7e7e3;   /* very soft, for backgrounds */
  --blush:       #e8c3ba;   /* eyebrow accents, tags */
  --blossom:     #d89a92;   /* main accent — petals, key hover states */
  --rose-deep:   #a96357;   /* for italic emphasis, underlines */

  /* Silver palette — pure silver tones for heading emphasis and image glints.
     Calibrated so they read as silver-on-cream, not just gray text. */
  --silver-deep:   #6e6c70;  /* deep cool silver — shadow tone */
  --silver-mid:    #8e8c92;  /* mid silver — main body of the metal */
  --silver-bright: #c5c4cc;  /* bright silver — the highlight pass */
  --silver-warm:   #8a8478;  /* legacy alias, used in image glints */
  --silver:        #9c958a;  /* legacy alias */
  --silver-cool:   #7a7a82;  /* legacy alias */
  --silver-light:  #b8b0a0;  /* legacy alias */

  /* Type — Montserrat across the board, per client request */
  --serif: 'Montserrat', system-ui, sans-serif;
  --sans:  'Montserrat', system-ui, sans-serif;

  /* Rhythm */
  --maxw: 1280px;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --r-sm: 4px;
  --r-md: 10px;
  --r-lg: 20px;
  --r-pill: 999px;

  /* Shadows — very soft, spa-like */
  --shadow-sm: 0 2px 10px -4px rgba(30, 29, 27, 0.08);
  --shadow-md: 0 20px 50px -24px rgba(30, 29, 27, 0.18);
  --shadow-lg: 0 40px 80px -30px rgba(30, 29, 27, 0.22);

  /* Easing — slow, relaxed */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --slow: 0.7s;
  --med:  0.45s;
}

/* =========================================================
   RESET
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul, ol { list-style: none; }
em { font-style: italic; }

::selection { background: var(--slate); color: var(--paper); }

/* =========================================================
   SHARED PRIMITIVES
   ========================================================= */
.eyebrow {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  /* Animated silver shimmer over rose-deep — a flash of polished silver
     periodically passes across the rose brand color */
  background: linear-gradient(
    100deg,
    var(--rose-deep) 0%,
    var(--rose-deep) 30%,
    var(--silver-mid) 42%,
    var(--silver-bright) 50%,
    var(--silver-mid) 58%,
    var(--rose-deep) 70%,
    var(--rose-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 6s ease-in-out infinite;
}
@keyframes shimmer-sweep {
  0%   { background-position: 100% 0; }
  50%  { background-position: 0% 0; }
  100% { background-position: 100% 0; }
}
/* Tiny decorative blossom before each eyebrow — unifies the site visually */
.eyebrow::before {
  content: '';
  flex-shrink: 0;
  width: 14px;
  height: 14px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cg fill='%23a96357'%3E%3Ccircle cx='7' cy='2.5' r='1.7' opacity='0.9'/%3E%3Ccircle cx='11' cy='5.5' r='1.7' opacity='0.7'/%3E%3Ccircle cx='9.5' cy='10' r='1.7' opacity='0.85'/%3E%3Ccircle cx='4.5' cy='10' r='1.7' opacity='0.7'/%3E%3Ccircle cx='3' cy='5.5' r='1.7' opacity='0.9'/%3E%3Ccircle cx='7' cy='6.5' r='1.1' fill='%23d89a92'/%3E%3C/g%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 0.85;
  transition: transform var(--slow) var(--ease);
}
/* Subtle rotate on section hover — parent context matters, use group-like parent */
.section-title:hover + .eyebrow::before,
.philosophy__left:hover .eyebrow::before,
.treatments__head:hover .eyebrow::before { transform: rotate(20deg); }

.eyebrow--light { color: var(--blush); }
.eyebrow--light::before { opacity: 0.7; }

.section-title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.25rem, 5vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--char);
  margin-bottom: 1.25rem;
  position: relative;
  /* The silver hairline accent gets attached via ::after */
}
/* Tasteful silver flourish — a thin hairline of polished silver beneath each
   section heading. Animates a subtle shimmer-sweep so it gleams periodically. */
.section-title::after {
  content: '';
  display: block;
  width: 64px;
  height: 1px;
  margin-top: 1rem;
  background: linear-gradient(
    100deg,
    transparent 0%,
    var(--silver-deep) 15%,
    var(--silver-mid) 35%,
    var(--silver-bright) 50%,
    var(--silver-mid) 65%,
    var(--silver-deep) 85%,
    transparent 100%
  );
  background-size: 200% 100%;
  background-position: 100% 0;
  animation: shimmer-sweep 8s ease-in-out infinite;
}
/* Center-aligned section titles get a centered hairline */
.treatments__head .section-title::after,
.pricing__head .section-title::after,
.reviews__head .section-title::after {
  margin-left: auto;
  margin-right: auto;
}
.section-title em {
  font-style: italic;
  font-weight: 500;
  /* Pure silver shimmer — like polished silverware catching light.
     No rose this time — keeps the silver tasteful and clean. */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 25%,
    var(--silver-mid) 40%,
    var(--silver-bright) 50%,
    var(--silver-mid) 60%,
    var(--silver-deep) 75%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 7s ease-in-out infinite;
}
/* Per-section stagger so emphasised words don't gleam in lockstep
   as the user scrolls down the page. Each section gets its own offset. */
.philosophy .section-title em       { animation-delay: 0s; }
.treatments__head .section-title em { animation-delay: -1s; }
.laser .section-title em            { animation-delay: -2s; }
.lashbrow .section-title em         { animation-delay: -3s; }
.pricing__head .section-title em    { animation-delay: -4s; }
.tips .section-title em             { animation-delay: -5s; }
.reviews__head .section-title em    { animation-delay: -6s; }
.visit .section-title em            { animation-delay: -3.5s; }
.section-title--light { color: var(--paper); }
.section-title--light em { color: var(--blush); }

.lede {
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  font-weight: 400;
  line-height: 1.55;
  color: var(--slate);
  max-width: 58ch;
}
.lede--light { color: var(--mist); }
.lede a { color: var(--ink); border-bottom: 1px solid var(--stone); transition: border-color var(--med) var(--ease); }
.lede a:hover { border-bottom-color: var(--ink); }

/* buttons */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem 1.75rem;
  font-family: var(--sans);
  font-weight: 400;
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  transition: background var(--med) var(--ease),
              color var(--med) var(--ease),
              transform var(--med) var(--ease),
              box-shadow var(--med) var(--ease),
              border-color var(--med) var(--ease);
  will-change: transform;
  overflow: hidden;
  isolation: isolate;
}
/* Soft warm shimmer that sweeps across on hover — barely-there, spa-elegant */
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    110deg,
    transparent 20%,
    rgba(216, 154, 146, 0.18) 45%,
    rgba(247, 231, 227, 0.3) 50%,
    rgba(216, 154, 146, 0.18) 55%,
    transparent 80%
  );
  transform: translateX(-110%);
  transition: transform 0.9s var(--ease);
  pointer-events: none;
  z-index: -1;
}
.btn:hover::before { transform: translateX(110%); }
.btn--primary {
  background: var(--char);
  color: var(--paper);
}
.btn--primary:hover {
  background: var(--ink);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.btn--on-dark { background: var(--paper); color: var(--char); }
.btn--on-dark:hover { background: var(--mist); color: var(--char); }
.btn--ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--stone);
}
.btn--ghost:hover {
  background: var(--char);
  color: var(--paper);
  border-color: var(--char);
}
.btn--block { width: 100%; }

/* reveal animation — slow and gentle */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--slow) var(--ease),
              transform var(--slow) var(--ease);
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ----- Decorative section divider ----- */
/* Small blossom framed by two hairlines — used between major sections */
.divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  padding: 3rem var(--gutter);
  max-width: var(--maxw);
  margin: 0 auto;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1.2s var(--ease), transform 1.2s var(--ease);
}
.divider.is-visible { opacity: 1; transform: translateY(0); }
.divider::before,
.divider::after {
  content: '';
  flex: 1;
  max-width: 180px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--stone), transparent);
}
.divider__bloom {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  color: var(--blossom);
  animation: bloom-drift 12s ease-in-out infinite;
}

/* =========================================================
   LOADING SCREEN
   Full-bleed branded loader. Fades out after JS triggers it.
   ========================================================= */
.loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--paper);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  /* Fades out smoothly when JS adds .is-done — slower fade + subtle scale-up
     for an "lifting away" feel rather than a hard disappear */
  opacity: 1;
  pointer-events: auto;
  transform: scale(1);
  transform-origin: center;
  transition:
    opacity 1.4s var(--ease),
    transform 1.4s var(--ease),
    visibility 0s 1.4s;
}
.loader.is-done {
  opacity: 0;
  transform: scale(1.04);
  pointer-events: none;
  visibility: hidden;
}

/* Atmospheric background washes — matches the hero so the transition feels seamless */
.loader__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 80% 15%, rgba(247, 231, 227, 0.7), transparent 55%),
    radial-gradient(ellipse at 15% 85%, rgba(247, 231, 227, 0.55), transparent 55%),
    radial-gradient(ellipse at 50% 50%, rgba(232, 229, 223, 0.5), transparent 70%);
  pointer-events: none;
}

/* Petal layer — petals are spawned here by JS */
.loader__petals {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 2;
}
.loader__petals .petal {
  position: absolute;
  top: -80px;
  width: 28px;
  height: 28px;
  background-image: url('img/blossom-petal.png');
  background-size: contain;
  background-repeat: no-repeat;
  will-change: transform, opacity;
  opacity: 0;
}
/* Fallback petal if PNG not available — soft pink dot */
.loader__petals .petal::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 35% 35%, var(--blush), var(--blossom) 60%, transparent 75%);
  border-radius: 50% 0 50% 0;
  opacity: 0.6;
  z-index: -1;
}

/* Centered composition — logo + wordmark + bar */
.loader__center {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 var(--gutter);
  width: 100%;
  max-width: 600px;
}

/* Logo with halo — same treatment as hero, but standalone */
.loader__brand-wrap {
  position: relative;
  display: inline-block;
  margin-bottom: 1.75rem;
}
.loader__brand-wrap::before {
  content: '';
  position: absolute;
  inset: -38%;
  background: radial-gradient(
    ellipse at center,
    rgba(247, 231, 227, 0.85) 0%,
    rgba(242, 240, 236, 0.95) 25%,
    rgba(242, 240, 236, 0.7) 50%,
    rgba(242, 240, 236, 0.3) 72%,
    transparent 92%
  );
  z-index: 0;
  pointer-events: none;
  animation: loader-halo-bloom 2.4s var(--ease) both;
}
@keyframes loader-halo-bloom {
  0% {
    opacity: 0;
    transform: scale(0.4);
  }
  60% {
    opacity: 1;
    transform: scale(1.06);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.loader__logo {
  position: relative;
  z-index: 1;
  width: clamp(220px, 28vw, 360px);
  height: auto;
  aspect-ratio: 1;
  object-fit: contain;
  display: block;
  filter: contrast(1.1) drop-shadow(0 8px 28px rgba(30, 29, 27, 0.14));
  /* Cinematic arrival: scales up, blurs to sharp, fades in */
  animation: loader-logo-arrive 2s var(--ease) 0.3s both;
}
@keyframes loader-logo-arrive {
  0% {
    opacity: 0;
    transform: scale(0.8) translateY(15px);
    filter: contrast(1.1) blur(10px) drop-shadow(0 8px 28px rgba(30, 29, 27, 0));
  }
  60% {
    opacity: 1;
    transform: scale(1.04) translateY(0);
    filter: contrast(1.1) blur(0.5px) drop-shadow(0 8px 28px rgba(30, 29, 27, 0.14));
  }
  100% {
    opacity: 1;
    transform: scale(1);
    filter: contrast(1.1) blur(0) drop-shadow(0 8px 28px rgba(30, 29, 27, 0.14));
  }
}

/* Wordmark — fades in below the logo */
.loader__text {
  position: relative;
  z-index: 3;
  margin-bottom: 2.5rem;
  opacity: 0;
  animation: loader-text-in 1s var(--ease) 1.6s both;
}
@keyframes loader-text-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.loader__name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: 0.02em;
  color: var(--char);
  line-height: 1;
  margin-bottom: 0.5rem;
}
.loader__tag {
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--rose-deep);
  font-weight: 400;
}

/* Hairline progress bar — fills over ~2.2s */
.loader__bar {
  position: relative;
  width: 220px;
  height: 1px;
  background: rgba(184, 180, 172, 0.3);
  overflow: hidden;
  opacity: 0;
  animation: loader-text-in 1s var(--ease) 1.9s both;
}
.loader__bar-fill {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 0%;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--blossom) 30%,
    var(--rose-deep) 60%,
    var(--blossom) 90%,
    transparent 100%
  );
  /* Fills from 1.4s onwards over 3.2s — completes ~4.6s, just before the loader fades */
  animation: loader-bar-fill 3.2s var(--ease) 1.4s forwards;
}
@keyframes loader-bar-fill {
  0%   { width: 0%; }
  100% { width: 100%; }
}

/* Mobile tweaks */
@media (max-width: 720px) {
  .loader__logo { width: clamp(180px, 50vw, 240px); }
  .loader__name { font-size: 1.75rem; }
  .loader__tag  { font-size: 0.65rem; letter-spacing: 0.36em; }
  .loader__bar  { width: 160px; }
}

/* Reduced motion — skip the cinematic, just show & hide quickly */
@media (prefers-reduced-motion: reduce) {
  .loader__brand-wrap::before,
  .loader__logo,
  .loader__text,
  .loader__bar,
  .loader__bar-fill {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    width: 100%;
  }
}

/* =========================================================
   NAVIGATION
   ========================================================= */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 1rem var(--gutter);
  background: rgba(242, 240, 236, 0.7);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  /* Start hidden — slid up out of view. Reveals when .is-visible is added. */
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.5s var(--ease),
              opacity 0.4s var(--ease),
              padding var(--med) var(--ease),
              background var(--med) var(--ease),
              box-shadow var(--med) var(--ease);
}
.nav.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.nav.is-scrolled {
  padding: 0.6rem var(--gutter);
  background: rgba(242, 240, 236, 0.9);
  box-shadow: 0 1px 0 rgba(30, 29, 27, 0.06);
}
.nav__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.nav__brand {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  color: var(--ink);
}
.nav__mark {
  width: 56px; height: 56px;
  object-fit: contain;
  filter: contrast(1.1);
  transition: transform var(--slow) var(--ease);
}
.nav__brand:hover .nav__mark { transform: rotate(-4deg); }
.nav__name { display: flex; flex-direction: column; line-height: 1; }
.nav__name-main {
  font-family: var(--serif);
  font-size: 1.5rem;
  letter-spacing: 0.06em;
  color: var(--char);
}
.nav__name-sub {
  font-family: var(--sans);
  font-size: 0.58rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--slate);
  margin-top: 3px;
}
.nav__links {
  display: flex;
  gap: 2.25rem;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
}
.nav__links a {
  position: relative;
  padding: 0.25rem 0;
  color: var(--slate);
  transition: color var(--med) var(--ease);
}
.nav__links a::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: var(--char);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--slow) var(--ease);
}
.nav__links a:hover { color: var(--char); }
.nav__links a:hover::after { transform: scaleX(1); transform-origin: left; }

.nav__cta {
  padding: 0.75rem 1.5rem;
  border-radius: var(--r-pill);
  background: var(--char);
  color: var(--paper);
  font-size: 0.72rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 400;
  transition: background var(--med) var(--ease),
              transform var(--med) var(--ease);
}
.nav__cta:hover { background: var(--slate); transform: translateY(-1px); }

.nav__burger {
  display: none;
  width: 32px; height: 32px;
  position: relative;
}
.nav__burger span {
  position: absolute;
  left: 4px; right: 4px;
  height: 1.5px;
  background: var(--ink);
  transition: all var(--med) var(--ease);
}
.nav__burger span:nth-child(1) { top: 10px; }
.nav__burger span:nth-child(2) { top: 15.5px; }
.nav__burger span:nth-child(3) { top: 21px; }
.nav__burger.is-open span:nth-child(1) { transform: rotate(45deg); top: 15.5px; }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: rotate(-45deg); top: 15.5px; }

.nav__mobile {
  display: none;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem var(--gutter) 2rem;
  background: var(--paper);
  border-top: 1px solid var(--mist);
}
.nav__mobile a {
  font-family: var(--serif);
  font-size: 1.6rem;
  color: var(--ink);
}
.nav__mobile-cta {
  margin-top: 1rem;
  padding: 0.85rem 1.5rem;
  background: var(--char);
  color: var(--paper) !important;
  border-radius: var(--r-pill);
  text-align: center;
  font-family: var(--sans) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

/* =========================================================
   HERO
   ========================================================= */
.hero {
  position: relative;
  /* LOCKED to exactly the viewport height. Never shorter, never taller. */
  height: 100vh;
  height: 100dvh;
  min-height: 560px;
  /* Nav is hidden over the hero — overlays without taking space.
     Just a small breathing room at the top, frees up vertical space for content. */
  padding: clamp(1rem, 2vh, 1.75rem) var(--gutter) 0;
  overflow: hidden;
  isolation: isolate;
  display: flex;
  flex-direction: column;
  --scroll: 0;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.hero__wash {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 80% 15%, rgba(247, 231, 227, 0.55), transparent 55%),
    radial-gradient(ellipse at 15% 85%, rgba(247, 231, 227, 0.4), transparent 55%),
    radial-gradient(ellipse at 50% 50%, rgba(232, 229, 223, 0.45), transparent 70%);
}
.hero__grain {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
  opacity: 0.06;
  mix-blend-mode: multiply;
  pointer-events: none;
}

/* Corner blossoms — dominant, cascading from the corners */
.hero__blossom {
  position: absolute;
  pointer-events: none;
  z-index: 1;
  max-width: none;
  /* Scale with viewport — no artificial cap, they ARE the visual statement */
  width: 65vw;
  min-width: 420px;
  height: auto;
  user-select: none;
  transition: transform 0.1s linear, opacity 0.2s linear;
}
.hero__blossom--tr {
  top: 0;
  right: 0;
  /* Pulled inward — blossoms reach toward the centre composition */
  margin-top: -10%;
  margin-right: -4%;
  transform-origin: 100% 0%;
  animation: blossom-sway-tr 12s ease-in-out infinite;
  transform:
    translate(calc(var(--scroll) * 60%), calc(var(--scroll) * -70%))
    rotate(calc(var(--scroll) * 25deg))
    scale(calc(1 + var(--scroll) * 0.15));
  opacity: calc(1 - var(--scroll) * 1.3);
}
.hero__blossom--bl {
  bottom: 0;
  left: 0;
  margin-bottom: -8%;
  margin-left: -6%;
  transform-origin: 0% 100%;
  animation: blossom-sway-bl 14s ease-in-out infinite;
  transform:
    translate(calc(var(--scroll) * -60%), calc(var(--scroll) * 70%))
    rotate(calc(var(--scroll) * -25deg))
    scale(calc(1 + var(--scroll) * 0.15));
  opacity: calc(1 - var(--scroll) * 1.3);
}

/* On short laptop viewports, proportionally shrink blossoms so both fit.
   (Detailed hero content overrides live AFTER the base rules, below.) */
@media (max-height: 1024px) {
  .hero__blossom {
    width: 58vw;
    min-width: 400px;
  }
}
@media (max-height: 680px) {
  .hero__blossom {
    width: 48vw;
    min-width: 320px;
  }
}
/* Sway only runs while still — tiny drift as decoration */
@keyframes blossom-sway-tr {
  0%, 100% { filter: none; }
  50%      { filter: brightness(1.02); }
}
@keyframes blossom-sway-bl {
  0%, 100% { filter: none; }
  50%      { filter: brightness(1.02); }
}

/* Falling petals layer — also fades as hero scrolls out */
.hero__petals {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 2;
  opacity: calc(1 - var(--scroll) * 1.4);
  transition: opacity 0.1s linear;
}
.petal {
  position: absolute;
  top: -80px;
  width: 28px;
  height: 28px;
  background-image: url('img/blossom-petal.png');
  background-size: contain;
  background-repeat: no-repeat;
  will-change: transform, opacity;
  opacity: 0;
}

/* Centered content — also shifts up slightly on scroll for parallax */
.hero__center {
  position: relative;
  z-index: 3;
  flex: 1 1 auto;
  min-height: 0;  /* allow flex child to shrink below content size */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 1.5rem 0 2.5rem;
  max-width: 780px;
  width: 100%;
  margin: 0 auto;
  transform: translateY(calc(var(--scroll) * -40px));
  opacity: calc(1 - var(--scroll) * 0.6);
  transition: transform 0.1s linear, opacity 0.2s linear;
  overflow: hidden;
}
.hero__brand-wrap {
  position: relative;
  display: inline-block;
  margin-bottom: 0.5rem;
}
/* Soft expansive halo — fades AND blooms in as page loads, then breathes gently.
   Animations are paused until html.loader-done is added (after loader fades). */
.hero__brand-wrap::before {
  content: '';
  position: absolute;
  inset: -35%;
  background: radial-gradient(
    ellipse at center,
    rgba(247, 231, 227, 0.7) 0%,
    rgba(242, 240, 236, 0.92) 22%,
    rgba(242, 240, 236, 0.7) 48%,
    rgba(242, 240, 236, 0.3) 72%,
    transparent 92%
  );
  z-index: 0;
  pointer-events: none;
  opacity: 0;
  animation:
    halo-bloom 1.8s var(--ease) both,
    brand-halo 9s ease-in-out 1.8s infinite;
  animation-play-state: paused;
}
html.loader-done .hero__brand-wrap::before {
  animation-play-state: running;
}
@keyframes halo-bloom {
  0% {
    opacity: 0;
    transform: scale(0.4);
  }
  60% {
    opacity: 1;
    transform: scale(1.08);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes brand-halo {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.92; transform: scale(1.04); }
}

.hero__brand {
  position: relative;
  z-index: 1;
  /* Bigger again — we reclaimed space by overlaying the nav instead of reserving for it */
  width: clamp(320px, 36vw, 480px);
  height: auto;
  aspect-ratio: 1;
  object-fit: contain;
  display: block;
  filter: contrast(1.1) drop-shadow(0 8px 28px rgba(30, 29, 27, 0.14));
  /* Cinematic entrance gated on html.loader-done so hero animation
     starts AFTER the loader fades, not during it. */
  opacity: 0;
  animation:
    brand-arrive 1.6s var(--ease) 0.3s both,
    hero-float 11s ease-in-out 1.9s infinite;
  animation-play-state: paused;
}
html.loader-done .hero__brand {
  animation-play-state: running;
}
@keyframes brand-arrive {
  0% {
    opacity: 0;
    transform: scale(0.85) translateY(12px);
    filter: contrast(1.1) blur(8px) drop-shadow(0 8px 28px rgba(30, 29, 27, 0));
  }
  60% {
    opacity: 1;
    transform: scale(1.03) translateY(0);
    filter: contrast(1.1) blur(0.5px) drop-shadow(0 8px 28px rgba(30, 29, 27, 0.14));
  }
  100% {
    opacity: 1;
    transform: scale(1) translateY(0);
    filter: contrast(1.1) blur(0) drop-shadow(0 8px 28px rgba(30, 29, 27, 0.14));
  }
}
@keyframes hero-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
.hero__center .eyebrow {
  margin-bottom: 1rem;
  font-size: 0.82rem;
  letter-spacing: 0.36em;
}
.hero__title {
  font-family: var(--serif);
  font-weight: 500;
  /* Slightly smaller than the Cormorant version since Montserrat reads chunkier */
  font-size: clamp(2.5rem, min(8vw, 10vh), 6.5rem);
  line-height: 1.0;
  letter-spacing: -0.03em;
  color: var(--char);
  margin-bottom: 0.75rem;
}
.hero__title em {
  font-weight: 500;
  /* Pure silver shimmer for the dramatic 'in.' accent —
     the most prominent silver moment on the site */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 22%,
    var(--silver-mid) 38%,
    var(--silver-bright) 50%,
    var(--silver-mid) 62%,
    var(--silver-deep) 78%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 8s ease-in-out infinite;
}
.hero__sub {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.1rem, 1.8vw, 1.5rem);
  color: var(--slate);
  margin-bottom: 1.5rem;
  letter-spacing: 0.01em;
}
.hero__lede {
  font-family: var(--serif);
  font-size: clamp(1rem, 1.3vw, 1.2rem);
  font-weight: 400;
  line-height: 1.55;
  color: var(--ink);
  max-width: 56ch;
  margin: 0 auto 2rem;
}
.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

/* Marquee */
.hero__marquee {
  position: relative;
  z-index: 3;
  margin-top: auto;
  padding: 1.75rem 0;
  border-top: 1px solid var(--mist);
  border-bottom: 1px solid var(--mist);
  overflow: hidden;
  background: rgba(242, 240, 236, 0.6);
  backdrop-filter: blur(2px);
}
.hero__marquee::before,
.hero__marquee::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}
.hero__marquee::before { left: 0; background: linear-gradient(to right, var(--paper), transparent); }
.hero__marquee::after  { right: 0; background: linear-gradient(to left, var(--paper), transparent); }
.marquee__track {
  display: flex;
  gap: 2.25rem;
  animation: marquee 55s linear infinite;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 1.15rem;
  letter-spacing: 0.02em;
  white-space: nowrap;
  color: var(--ink);
  transition: animation-play-state var(--slow) var(--ease);
}
.hero__marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__track span:nth-child(even) { color: var(--stone); }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ==== Hero content compression on short viewports ====
   These live AFTER the base rules so they actually override them. */
@media (max-height: 1024px) {
  .hero__brand { width: clamp(280px, 28vw, 400px); margin-bottom: 0.4rem; }
  .hero__center .eyebrow { margin-bottom: 0.7rem; font-size: 0.72rem; letter-spacing: 0.3em; }
  .hero__title { margin-bottom: 0.4rem; line-height: 1.0; }
  .hero__sub { font-size: clamp(1rem, 1.4vw, 1.25rem); margin-bottom: 0.9rem; }
  .hero__lede { font-size: 1rem; margin-bottom: 1rem; line-height: 1.5; }
  .hero__center { padding: 0.5rem 0 1.25rem; }
  .hero__marquee { padding: 1.1rem 0; }
  .marquee__track { font-size: 1.2rem; }
}
@media (max-height: 800px) {
  .hero__brand { width: clamp(240px, 24vw, 340px); margin-bottom: 0.4rem; }
  .hero__title { font-size: clamp(2rem, min(6vw, 8vh), 4rem); margin-bottom: 0.4rem; }
  .hero__sub { font-size: 1rem; margin-bottom: 0.8rem; }
  .hero__lede { font-size: 0.95rem; margin-bottom: 0.9rem; line-height: 1.45; }
  .hero__center { padding: 0.4rem 0 1rem; }
}
@media (max-height: 680px) {
  .hero__brand { width: clamp(190px, 18vw, 260px); margin-bottom: 0.25rem; }
  .hero__title { margin-bottom: 0.3rem; }
  .hero__sub { font-size: 0.95rem; margin-bottom: 0.6rem; }
  .hero__lede { display: none; }
  .hero__center .eyebrow { margin-bottom: 0.45rem; font-size: 0.66rem; }
  .hero__center { padding: 0 0 1rem; }
  .hero__marquee { padding: 0.9rem 0; }
  .marquee__track { font-size: 1rem; }
}

/* =========================================================
   PHILOSOPHY  —  layered collage w/ blossom accents
   ========================================================= */
.philosophy {
  padding: 7rem var(--gutter);
  max-width: var(--maxw);
  margin: 0 auto;
  position: relative;
}
.philosophy__inner {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 5rem;
  align-items: center;
}
.philosophy__left { position: relative; }
.philosophy__lede {
  margin-top: 1.5rem;
  margin-bottom: 3rem;
}

/* Layered image composition */
.philosophy__collage {
  position: relative;
  aspect-ratio: 5 / 4;
  max-width: 560px;
  margin-top: 1rem;
}
.philosophy__img {
  position: absolute;
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  background:
    radial-gradient(circle at 30% 30%, var(--mist), transparent 55%),
    linear-gradient(135deg, var(--stone), var(--slate));
}
/* Silver glint — slow diagonal silver light sweep crosses every ~14s,
   like a polished silver surface catching light when slightly turned. */
.philosophy__img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 30%,
    rgba(180, 178, 188, 0.15) 42%,
    rgba(220, 218, 228, 0.55) 50%,
    rgba(180, 178, 188, 0.15) 58%,
    transparent 70%
  );
  background-size: 250% 250%;
  background-position: 100% 0;
  pointer-events: none;
  mix-blend-mode: overlay;
  animation: silver-glint 14s ease-in-out infinite;
  z-index: 2;
}
.philosophy__img--accent::after { animation-delay: -7s; } /* offset so they don't sync */
@keyframes silver-glint {
  0%, 8% {
    background-position: 100% 0;
  }
  35%, 100% {
    background-position: -50% 0;
  }
}
.philosophy__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s var(--ease), transform 1.2s var(--ease);
}
.philosophy__img img.is-loaded { opacity: 1; }
.philosophy__img:hover img { transform: scale(1.04); }

/* Main image — tall, left-aligned */
.philosophy__img--main {
  top: 0;
  left: 0;
  width: 62%;
  height: 100%;
  z-index: 2;
}

/* Accent image — smaller, bottom-right, paper-bordered so it reads as "stacked" */
.philosophy__img--accent {
  bottom: -2rem;
  right: 0;
  width: 52%;
  aspect-ratio: 1 / 1;
  z-index: 3;
  border: 6px solid var(--paper);
  box-shadow: var(--shadow-lg);
}

/* Big line-drawn blossom tucked between the two images */
.philosophy__blossom {
  position: absolute;
  top: 4%;
  right: 36%;
  width: 96px;
  height: 96px;
  color: var(--blossom);
  z-index: 4;
  opacity: 0.9;
  animation: bloom-drift 9s ease-in-out infinite;
  filter: drop-shadow(0 4px 16px rgba(216, 154, 146, 0.35));
  pointer-events: none;
}
@keyframes bloom-drift {
  0%, 100% { transform: rotate(-8deg) translateY(0); }
  50%      { transform: rotate(4deg) translateY(-6px); }
}

/* Tiny 5-dot bloom, bottom-left of collage */
.philosophy__bloom-sm {
  position: absolute;
  bottom: 0.5rem;
  left: -1.25rem;
  width: 56px;
  height: 56px;
  color: var(--blush);
  z-index: 4;
  animation: bloom-drift 11s ease-in-out infinite reverse;
  animation-delay: -3s;
  filter: drop-shadow(0 3px 12px rgba(232, 195, 186, 0.5));
  pointer-events: none;
}

/* ----- Right column ----- */
.philosophy__right { position: relative; }

.philosophy__pillars {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.pillar {
  padding: 1.75rem 0 0;
  border-top: 1px solid var(--mist);
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 1.75rem;
  align-items: start;
  position: relative;
  transition: border-color var(--slow) var(--ease);
}
/* Subtle blossom-pink dot fades in on hover at top-left */
.pillar::before {
  content: '';
  position: absolute;
  top: -4px;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--blossom);
  opacity: 0;
  transform: scale(0.5);
  transition: opacity var(--med) var(--ease), transform var(--med) var(--ease);
}
.pillar:hover::before { opacity: 1; transform: scale(1); }
.pillar:hover { border-top-color: var(--blush); }
.pillar__num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.4rem;
  line-height: 1;
  padding-top: 0.15rem;
  /* Silver shimmer — subtle metallic numbers reading like jewelry-card numerals.
     Each pillar number is offset so they don't all gleam at once. */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 25%,
    var(--silver-mid) 40%,
    var(--silver-bright) 50%,
    var(--silver-mid) 60%,
    var(--silver-deep) 75%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 9s ease-in-out infinite;
}
.pillar:nth-child(2) .pillar__num { animation-delay: -3s; }
.pillar:nth-child(3) .pillar__num { animation-delay: -6s; }
.pillar h4 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.45rem;
  margin-bottom: 0.5rem;
  color: var(--char);
}
.pillar p {
  color: var(--slate);
  font-size: 0.98rem;
  line-height: 1.6;
}

/* Bottom accent note with 5-dot blossom cluster */
.philosophy__note {
  margin-top: 2.75rem;
  padding: 1.5rem 1.75rem;
  background: var(--blush-pale);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  gap: 1.25rem;
  border-left: 3px solid var(--blossom);
}
.philosophy__note-bloom {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  color: var(--blossom);
}
.philosophy__note p {
  font-family: var(--serif);
  font-size: 1.02rem;
  line-height: 1.5;
  color: var(--ink);
  margin: 0;
}
.philosophy__note p em {
  display: block;
  margin-top: 0.25rem;
  font-size: 1.1rem;
  font-style: italic;
  /* Pure silver shimmer — unifies emphasis treatment site-wide */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 25%,
    var(--silver-mid) 40%,
    var(--silver-bright) 50%,
    var(--silver-mid) 60%,
    var(--silver-deep) 75%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 8s ease-in-out infinite;
}

/* =========================================================
   TREATMENTS  —  image wall
   ========================================================= */
.treatments {
  padding: 4rem 0 4.5rem;
  background: var(--paper-2);
  position: relative;
  overflow: hidden; /* contain any full-bleed overflow */
}
.treatments__head {
  max-width: var(--maxw);
  margin: 0 auto 2rem;
  padding: 0 var(--gutter);
  text-align: center;
}
.treatments__head .lede { margin: 0 auto; }

/* ----- The wall: shared bg + tile grid ----- */
.wall {
  /* Full-width break-out — spans edge to edge regardless of section gutter */
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  position: relative;
  overflow: hidden;
  /* Height: fit comfortably in the viewport with room for heading above */
  height: clamp(420px, 60vh, 620px);
  box-shadow: var(--shadow-lg);
  background: var(--charcoal);
}
/* Silver glaze sweep — a slow diagonal shine across the active image,
   like sunlight catching the surface. Sits above scrim, below tiles. */
.wall::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 60%;
  height: 200%;
  background: linear-gradient(
    100deg,
    transparent 0%,
    rgba(232, 230, 220, 0.04) 30%,
    rgba(235, 230, 220, 0.18) 48%,
    rgba(255, 252, 244, 0.28) 50%,
    rgba(235, 230, 220, 0.18) 52%,
    rgba(232, 230, 220, 0.04) 70%,
    transparent 100%
  );
  z-index: 1;
  pointer-events: none;
  transform: rotate(20deg);
  animation: wall-glaze 14s ease-in-out infinite;
  mix-blend-mode: screen;
}
@keyframes wall-glaze {
  0%, 100% { transform: rotate(20deg) translateX(-30%); opacity: 0; }
  20%      { opacity: 1; }
  60%      { opacity: 1; }
  80%      { transform: rotate(20deg) translateX(280%); opacity: 0; }
}

/* Background stack — all images layered, only .is-active is visible */
.wall__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.wall__img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s var(--ease), transform 14s linear;
  transform: scale(1.02);
}
.wall__img.is-active {
  opacity: 1;
  transform: scale(1.08); /* slow Ken Burns-style drift while active */
}
/* Dark scrim on top of the image so text reads cleanly */
.wall__scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(30, 29, 27, 0.45), rgba(30, 29, 27, 0.7));
  z-index: 1;
  pointer-events: none;
}

/* ----- Tile grid ----- */
.wall__grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr 1fr;
  height: 100%;
  width: 100%;
}

.tile {
  position: relative;
  padding: 1.75rem 1.5rem 1.5rem;
  color: var(--paper);
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  cursor: pointer;
  overflow: hidden;
  transition: background var(--slow) var(--ease);
  border-right: 1px solid rgba(242, 240, 236, 0.15);
  border-bottom: 1px solid rgba(242, 240, 236, 0.15);
}
/* Last column — no right border */
.tile:nth-child(3n) { border-right: none; }
/* Last row — no bottom border */
.tile:nth-child(n+4) { border-bottom: none; }

/* Subtle darken of non-active tiles when one is active */
.wall[data-active] .tile {
  transition: background var(--slow) var(--ease), opacity var(--slow) var(--ease);
}
.wall .tile {
  background: rgba(30, 29, 27, 0.0);
}
/* Tiles that aren't the active one — slightly darker overlay */
.wall .tile:not(.is-active) {
  background: rgba(30, 29, 27, 0.18);
}
.wall .tile.is-active {
  background: rgba(30, 29, 27, 0.0);
}

.tile__tag {
  font-family: var(--sans);
  font-size: 0.62rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--blush);
  margin-bottom: 0.55rem;
  opacity: 0.95;
  transition: color var(--slow) var(--ease);
}
.tile__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.2rem, 1.75vw, 1.55rem);
  line-height: 1.1;
  color: var(--paper);
  margin-bottom: 0.55rem;
  letter-spacing: -0.005em;
  text-align: left;
  transition: transform var(--slow) var(--ease);
}
.tile__sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.85rem;
  line-height: 1.35;
  color: var(--mist);
  max-width: 16rem;
  opacity: 0.85;
  transition: opacity var(--slow) var(--ease);
}

/* On hover, title nudges up a touch */
.tile:hover .tile__title,
.tile.is-active .tile__title { transform: translateY(-2px); }
.tile:hover .tile__tag,
.tile.is-active .tile__tag { color: var(--blossom); }

/* Active tile gets a subtle top accent bar in blossom color */
.tile::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--blossom);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.6s var(--ease);
}
.tile.is-active::before,
.tile:hover::before { transform: scaleX(1); }

/* ----- The mini info card that pops up over hovered tile ----- */
.tile__card {
  position: absolute;
  left: 1rem;
  right: 1rem;
  top: 1rem;
  background: var(--paper);
  color: var(--ink);
  padding: 1.1rem 1.25rem 1rem;
  border-radius: var(--r-md);
  box-shadow: 0 20px 50px -15px rgba(0, 0, 0, 0.5);
  opacity: 0;
  transform: translateY(8px) scale(0.97);
  transform-origin: top center;
  pointer-events: none;
  transition: opacity 0.4s var(--ease), transform 0.4s var(--ease);
  z-index: 4;
  text-align: left;
  border: 1px solid var(--mist);
  border-left: 3px solid var(--blossom);
}
/* subtle little pointer / nothing at top — keeps it clean */
.tile:hover .tile__card,
.tile.is-active .tile__card {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
/* Small delay so the card doesn't flash on rapid hover-through */
.tile:hover .tile__card { transition-delay: 0.12s; }

.tile__card-tag {
  display: inline-block;
  font-size: 0.58rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--rose-deep);
  margin-bottom: 0.45rem;
}
.tile__card h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.05rem;
  line-height: 1.2;
  color: var(--char);
  margin-bottom: 0.4rem;
}
.tile__card p {
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--slate);
  margin-bottom: 0.75rem;
}
.tile__card-foot {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-top: 0.55rem;
  border-top: 1px solid var(--mist);
}
.tile__card-price {
  font-family: var(--serif);
  font-size: 1rem;
  color: var(--char);
  font-weight: 500;
}
.tile__card-link {
  font-size: 0.66rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--char);
  transition: color var(--med) var(--ease), letter-spacing var(--slow) var(--ease);
}
.tile__card-link:hover {
  color: var(--rose-deep);
  letter-spacing: 0.32em;
}

/* =========================================================
   LASER (dark section)
   ========================================================= */
.laser {
  background: var(--paper-2);
  color: var(--ink);
  padding: 7rem var(--gutter);
  position: relative;
  overflow: hidden;
}
.laser::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(247, 231, 227, 0.4), transparent 60%);
  border-radius: 50%;
  pointer-events: none;
}
/* subtle blossom-blush accent on the left */
.laser::after {
  content: '';
  position: absolute;
  bottom: -150px; left: -150px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(216, 154, 146, 0.08), transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}
.laser__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
  position: relative;
}
.laser__feats {
  margin: 2rem 0 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.laser__feats li {
  display: flex;
  gap: 1rem;
  color: var(--slate);
  font-size: 1rem;
}
.laser__feats li span {
  color: var(--rose-deep);
  font-family: var(--serif);
  font-size: 1.2rem;
}

/* Laser right column — photo sits behind price card, slightly offset */
.laser__right {
  position: relative;
}
.laser__photo {
  position: absolute;
  top: -30px;
  left: -40px;
  width: 70%;
  aspect-ratio: 3 / 4;
  border-radius: var(--r-md);
  overflow: hidden;
  z-index: 0;
  box-shadow: var(--shadow-md);
  /* fallback gradient if photo fails */
  background:
    radial-gradient(circle at 30% 30%, var(--stone), transparent 55%),
    radial-gradient(circle at 70% 70%, var(--ink), transparent 60%),
    linear-gradient(135deg, var(--slate), var(--char));
}
/* Silver glint — same effect as philosophy images, offset timing */
.laser__photo::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 30%,
    rgba(180, 178, 188, 0.18) 42%,
    rgba(220, 218, 228, 0.6) 50%,
    rgba(180, 178, 188, 0.18) 58%,
    transparent 70%
  );
  background-size: 250% 250%;
  background-position: 100% 0;
  pointer-events: none;
  mix-blend-mode: overlay;
  animation: silver-glint 14s ease-in-out -3s infinite;
  z-index: 2;
}
.laser__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s var(--ease);
}
.laser__photo img.is-loaded { opacity: 1; }
.laser__photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(30, 29, 27, 0.5));
}

.price-card {
  background: var(--paper);
  color: var(--ink);
  padding: 2.75rem;
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  position: relative;
  z-index: 1;
  margin-top: 60px;
  margin-left: 80px;
}
.price-card::before {
  content: '';
  position: absolute;
  top: -8px; left: -8px;
  width: 80px; height: 80px;
  border-top: 1px solid var(--stone);
  border-left: 1px solid var(--stone);
  border-radius: var(--r-md) 0 0 0;
  pointer-events: none;
  opacity: 0.5;
}
.price-card::after {
  content: '';
  position: absolute;
  bottom: -8px; right: -8px;
  width: 80px; height: 80px;
  border-bottom: 1px solid var(--stone);
  border-right: 1px solid var(--stone);
  border-radius: 0 0 var(--r-md) 0;
  pointer-events: none;
  opacity: 0.5;
}
.price-card h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.75rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--mist);
  color: var(--char);
}
.price-card__list {
  display: flex;
  flex-direction: column;
}
.price-card__list li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.75rem 0;
  border-bottom: 1px dashed var(--mist);
  font-size: 0.95rem;
}
.price-card__list li:last-child { border-bottom: none; }
.price-card__list li span { color: var(--slate); }
.price-card__list li em {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1.05rem;
  color: var(--char);
}

/* =========================================================
   BEFORE & AFTER RESULTS
   ========================================================= */
.results {
  padding: 7rem var(--gutter);
  background: var(--mist);
}

.results__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}

.results__head {
  text-align: center;
  margin-bottom: 4rem;
}

.results__head .lede {
  max-width: 480px;
  margin: 0.75rem auto 0;
  color: var(--slate);
  font-size: 0.95rem;
}

.results .section-title em { animation-delay: -7s; }

/* Alternating image/text rows */
.results__rows {
  display: flex;
  flex-direction: column;
  gap: 5rem;
  margin-top: 4rem;
}

.results__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.results__row--flip {
  direction: ltr;
}

.results__row--flip .results__row-text { order: 1; }
.results__row--flip .results__row-slider { order: 2; }

.results__row-text {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.results__row-text h3 {
  font-family: var(--serif);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 400;
  color: var(--char);
  line-height: 1.2;
  margin: 0;
}

.results__row-text h3 em {
  font-style: italic;
  color: var(--rose-deep);
}

.results__row-text p:not(.eyebrow) {
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--slate);
  max-width: 38ch;
  margin: 0;
}

/* Slider inside a row — landscape default */
.results__row-slider .ba-slider {
  aspect-ratio: 2 / 1;
  max-width: 100%;
}

/* Portrait override for DMC — constrained, centred */
.results__row-slider .ba-slider--portrait {
  aspect-ratio: 3 / 4;
  max-width: 300px;
  margin: 0 auto;
}

@media (max-width: 760px) {
  .results__row {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .results__row--flip .results__row-text { order: 1; }
  .results__row--flip .results__row-slider { order: 2; }
  .results__rows {
    gap: 3.5rem;
  }
}

/* ---- Dynamic before/after labels ---- */
.ba-slider__label {
  position: absolute;
  top: 1rem;
  z-index: 5;
  font-family: var(--sans);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.35rem 0.75rem;
  border-radius: var(--r-pill);
  pointer-events: none;
  transition: opacity 0.25s ease, background 0.25s ease, color 0.25s ease, box-shadow 0.25s ease;
}

.ba-slider__label--before {
  left: 1rem;
  background: rgba(242, 240, 236, 0.55);
  color: rgba(80, 72, 65, 0.5);
  box-shadow: none;
}

.ba-slider__label--after {
  right: 1rem;
  background: rgba(168, 99, 87, 0.12);
  color: rgba(168, 99, 87, 0.45);
  box-shadow: none;
}

/* When divider is left of centre — BEFORE is dominant */
.ba-slider.is-before .ba-slider__label--before {
  background: rgba(242, 240, 236, 0.92);
  color: var(--slate);
  box-shadow: 0 1px 8px rgba(0,0,0,0.10);
}

/* When divider is right of centre — AFTER is dominant */
.ba-slider.is-after .ba-slider__label--after {
  background: rgba(168, 99, 87, 0.88);
  color: #fff;
  box-shadow: 0 1px 8px rgba(168,99,87,0.30);
}

/* ---- Slider component ---- */
.ba-slider {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  cursor: col-resize;
  user-select: none;
  -webkit-user-select: none;
  aspect-ratio: 2 / 1;
  background: var(--mist);
}

/* Hero override AFTER base rule so it wins the cascade */
.ba-slider.ba-slider--hero {
  aspect-ratio: 2 / 1;
  margin-bottom: 0;
}

/* Fail-safe: before image always visible if JS hasn't run */
.ba-slider__before,
.ba-slider__after {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.ba-slider__before img,
.ba-slider__after img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  pointer-events: none;
}

/* After panel clips from the right; JS will set clip-path */
.ba-slider__after {
  clip-path: inset(0 50% 0 0);
}

/* Handle */
.ba-slider__handle {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%; /* JS will move this */
  width: 0;
  z-index: 10;
  pointer-events: none;
}

.ba-slider__line {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 2px;
  background: rgba(255, 255, 255, 0.85);
  transform: translateX(-50%);
  box-shadow: 0 0 8px rgba(0,0,0,0.18);
}

.ba-slider__btn {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(-50%, -50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 16px rgba(0,0,0,0.18), 0 0 0 1.5px rgba(255,255,255,0.6);
  color: var(--rose-deep);
  transition: box-shadow 0.2s;
}

.ba-slider:hover .ba-slider__btn {
  box-shadow: 0 4px 24px rgba(0,0,0,0.22), 0 0 0 2px rgba(168,99,87,0.3);
}

/* Caption */
.ba-slider__caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 6;
  margin: 0;
  padding: 1.5rem 1rem 1rem;
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(to top, rgba(30,28,26,0.52) 0%, transparent 100%);
  pointer-events: none;
}

/* =========================================================
   LASH & BROW
   ========================================================= */
.lashbrow {
  padding: 7rem var(--gutter);
  max-width: var(--maxw);
  margin: 0 auto;
}
.lashbrow__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
}
.lashbrow__text { max-width: 700px; }
.lashbrow__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.mini-card {
  padding: 2.25rem;
  border: 1px solid var(--mist);
  border-radius: var(--r-md);
  background: var(--paper);
  transition: transform var(--slow) var(--ease),
              box-shadow var(--slow) var(--ease),
              border-color var(--slow) var(--ease);
}
.mini-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--stone);
}
.mini-card--accent {
  background: var(--paper-2);
  border-color: var(--stone);
}
.mini-card h4 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.5rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--mist);
  /* Pure silver shimmer — same treatment as section title em */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 25%,
    var(--silver-mid) 40%,
    var(--silver-bright) 50%,
    var(--silver-mid) 60%,
    var(--silver-deep) 75%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 8s ease-in-out infinite;
}
/* Stagger the 3 cards so they don't shimmer in sync */
.mini-card:nth-child(2) h4 { animation-delay: -2.7s; }
.mini-card:nth-child(3) h4 { animation-delay: -5.4s; }
.mini-card ul {
  display: flex;
  flex-direction: column;
}
.mini-card li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.65rem 0;
  gap: 1rem;
  font-size: 0.92rem;
}
.mini-card li span { color: var(--slate); }
.mini-card li em {
  font-family: var(--serif);
  font-style: normal;
  font-size: 1.05rem;
  color: var(--char);
  white-space: nowrap;
}

/* =========================================================
   ATMOSPHERIC BANNER
   ========================================================= */
.banner {
  position: relative;
  height: clamp(300px, 50vh, 520px);
  overflow: hidden;
  /* fallback gradient */
  background:
    radial-gradient(circle at 30% 30%, var(--stone), transparent 55%),
    radial-gradient(circle at 70% 70%, var(--ink), transparent 60%),
    linear-gradient(135deg, var(--slate), var(--charcoal));
}
/* Silver glint sweep — slowest of all banners since this is a focal showpiece */
.banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 30%,
    rgba(180, 178, 188, 0.22) 42%,
    rgba(220, 218, 228, 0.65) 50%,
    rgba(180, 178, 188, 0.22) 58%,
    transparent 70%
  );
  background-size: 250% 250%;
  background-position: 100% 0;
  pointer-events: none;
  mix-blend-mode: overlay;
  animation: silver-glint 18s ease-in-out -10s infinite;
  z-index: 2;
}
.banner img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.85) saturate(0.92);
  opacity: 0;
  transform: scale(1.05);
  transition: opacity 1.2s var(--ease), transform 12s linear;
}
.banner img.is-loaded {
  opacity: 1;
  transform: scale(1);
}
.banner__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(30, 29, 27, 0.2), rgba(30, 29, 27, 0.4));
  padding: 2rem var(--gutter);
  text-align: center;
  z-index: 3;
}
.banner__text {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.2rem, 2.5vw, 2rem);
  color: var(--paper);
  letter-spacing: 0.01em;
  max-width: 800px;
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.4);
}

/* =========================================================
   PRICING (full table)
   ========================================================= */
.pricing {
  padding: 6rem var(--gutter);
  background: var(--paper-2);
  position: relative;
}
.pricing__head {
  max-width: var(--maxw);
  margin: 0 auto 3.5rem;
  text-align: center;
}
.pricing__head .lede { margin: 0 auto; }

.pricing__table {
  max-width: 900px;
  margin: 0 auto;
  background: var(--paper);
  color: var(--ink);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--mist);
}
.pricing__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
  padding: 1.15rem 2rem;
  border-bottom: 1px solid var(--mist);
  transition: background var(--med) var(--ease);
  position: relative;
  overflow: hidden;
}
/* Rose accent bar slides in from left on hover */
.pricing__row::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 3px;
  background: var(--blossom);
  transform: scaleY(0);
  transform-origin: center;
  transition: transform var(--slow) var(--ease);
}
.pricing__row:last-child { border-bottom: none; }
.pricing__row:hover {
  background: var(--blush-pale);
}
.pricing__row:hover::before { transform: scaleY(1); }
.pricing__row:hover .pricing__price {
  /* Silver text can't change color via `color:` — bump brightness so the
     shimmer looks polished and bright on hover. */
  filter: brightness(1.25) saturate(1.1);
}
.pricing__name strong {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.15rem;
  color: var(--char);
  display: block;
}
.pricing__name small {
  display: block;
  font-size: 0.82rem;
  color: var(--slate);
  margin-top: 2px;
}
.pricing__price {
  font-family: var(--serif);
  font-size: 1.35rem;
  font-weight: 500;
  /* Silver shimmer — like fancy menu prices in a luxe restaurant.
     Each row's price is offset so they don't all gleam in lockstep. */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 25%,
    var(--silver-mid) 40%,
    var(--silver-bright) 50%,
    var(--silver-mid) 60%,
    var(--silver-deep) 75%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 9s ease-in-out infinite;
  transition: filter var(--slow) var(--ease);
}
/* Stagger the shimmer so prices catch light at different moments —
   creates a gentle wave effect down the price list. */
.pricing__row:nth-child(2) .pricing__price  { animation-delay: -0.6s; }
.pricing__row:nth-child(3) .pricing__price  { animation-delay: -1.2s; }
.pricing__row:nth-child(4) .pricing__price  { animation-delay: -1.8s; }
.pricing__row:nth-child(5) .pricing__price  { animation-delay: -2.4s; }
.pricing__row:nth-child(6) .pricing__price  { animation-delay: -3.0s; }
.pricing__row:nth-child(7) .pricing__price  { animation-delay: -3.6s; }
.pricing__row:nth-child(8) .pricing__price  { animation-delay: -4.2s; }
.pricing__row:nth-child(9) .pricing__price  { animation-delay: -4.8s; }
.pricing__row:nth-child(10) .pricing__price { animation-delay: -5.4s; }
.pricing__row:nth-child(11) .pricing__price { animation-delay: -6.0s; }
.pricing__row:nth-child(12) .pricing__price { animation-delay: -6.6s; }
.pricing__row:nth-child(13) .pricing__price { animation-delay: -7.2s; }
.pricing__row:nth-child(14) .pricing__price { animation-delay: -7.8s; }
.pricing__row:nth-child(15) .pricing__price { animation-delay: -8.4s; }
.pricing__footnote {
  max-width: 900px;
  margin: 2rem auto 0;
  text-align: center;
  font-size: 0.82rem;
  color: var(--slate);
  letter-spacing: 0.08em;
}
.pricing__footnote strong { color: var(--ink); font-weight: 500; }

/* =========================================================
   TIPS / BLOG  —  connected step-flow
   ========================================================= */
.tips {
  padding: 7rem var(--gutter);
  background: var(--paper);
}
.tips__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}

/* ----- Step-flow grid ----- */
.tips-flow {
  --row-gap: 4.5rem;
  --node-size: 72px;
  --compact-h: 180px;
  --expanded-h: 300px;
  position: relative;
  margin-top: 5rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: 1.25rem;
  row-gap: var(--row-gap);
  padding: 0 1.5rem;
}

/* Connecting SVG path runs behind everything. JS sets its width/height/d. */
.tips-flow__path {
  position: absolute;
  inset: 0;
  color: var(--blush);
  pointer-events: none;
  z-index: 0;
  overflow: visible;
}
.tips-flow__stroke {
  transition: stroke-dashoffset 2.8s var(--ease);
}

/* ----- Individual step ----- */
.tip-step {
  position: relative;
  z-index: 1;
  min-height: var(--compact-h);
}

.tip-step__btn {
  width: 100%;
  height: 100%;
  min-height: var(--compact-h);
  padding: calc(var(--node-size) / 2 + 1rem) 1rem 1.25rem;
  background: var(--paper);
  border-radius: var(--r-md);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  cursor: pointer;
  transition: background var(--slow) var(--ease),
              box-shadow var(--slow) var(--ease),
              transform var(--slow) var(--ease);
}

/* Node — the circular icon at the top of each step */
.tip-step__node {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: var(--node-size);
  height: var(--node-size);
  background: var(--paper);
  border: 1.5px solid var(--blush);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--rose-deep);
  transition: background var(--slow) var(--ease),
              color var(--slow) var(--ease),
              border-color var(--slow) var(--ease),
              transform var(--slow) var(--ease),
              box-shadow var(--slow) var(--ease);
}
.tip-step__node svg {
  width: 32px;
  height: 32px;
  transition: transform var(--slow) var(--ease);
}

.tip-step__num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.85rem;
  color: var(--stone);
  letter-spacing: 0.1em;
  margin-bottom: 0.4rem;
  transition: color var(--slow) var(--ease);
}
.tip-step__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.15rem;
  line-height: 1.2;
  color: var(--char);
  margin-bottom: 0.5rem;
  transition: color var(--slow) var(--ease);
}
.tip-step__short {
  font-size: 0.85rem;
  color: var(--slate);
  line-height: 1.4;
  margin: 0;
  transition: opacity var(--med) var(--ease),
              max-height var(--slow) var(--ease),
              margin var(--slow) var(--ease);
  max-height: 3em;
  overflow: hidden;
}

/* Long text — hidden by default, revealed when expanded */
.tip-step__long {
  font-size: 0.88rem;
  color: var(--ink);
  line-height: 1.55;
  margin: 0;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.7s var(--ease),
              opacity 0.5s var(--ease),
              margin 0.5s var(--ease);
  text-align: left;
}

/* ----- Expanded state (hover + .is-open via JS for touch) ----- */
.tip-step:hover .tip-step__btn,
.tip-step.is-open .tip-step__btn {
  background: var(--paper);
  box-shadow: var(--shadow-lg);
  transform: translateY(-6px);
  z-index: 2;
}
.tip-step:hover .tip-step__node,
.tip-step.is-open .tip-step__node {
  background: var(--rose-deep);
  color: var(--paper);
  border-color: var(--rose-deep);
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 10px 30px -10px rgba(169, 99, 87, 0.4);
}
.tip-step:hover .tip-step__node svg,
.tip-step.is-open .tip-step__node svg {
  transform: rotate(-6deg);
}
.tip-step:hover .tip-step__num,
.tip-step.is-open .tip-step__num {
  color: var(--rose-deep);
}
.tip-step:hover .tip-step__title,
.tip-step.is-open .tip-step__title {
  color: var(--ink);
}
.tip-step:hover .tip-step__short,
.tip-step.is-open .tip-step__short {
  opacity: 0;
  max-height: 0;
  margin: 0;
}
.tip-step:hover .tip-step__long,
.tip-step.is-open .tip-step__long {
  max-height: 280px;
  opacity: 1;
  margin-top: 0.25rem;
}

/* =========================================================
   REVIEWS  —  real Google reviews, silver-accented cards
   ========================================================= */
.reviews {
  padding: 7rem var(--gutter);
  background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
  color: var(--ink);
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--mist);
  border-bottom: 1px solid var(--mist);
}
.reviews::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 15% 25%, rgba(216, 154, 146, 0.08), transparent 50%),
    radial-gradient(ellipse at 85% 75%, rgba(247, 231, 227, 0.4), transparent 55%);
  pointer-events: none;
}
.reviews__head {
  position: relative;
  max-width: var(--maxw);
  margin: 0 auto 4rem;
  text-align: center;
}
.reviews__head .lede { margin: 0 auto; }
.reviews__head .section-title::after { margin-left: auto; margin-right: auto; }

/* Reviews controls — prev/next + dots */
.reviews__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  margin-top: 2.5rem;
  position: relative;
  z-index: 2;
}

.reviews__btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--mist);
  background: rgba(242, 240, 236, 0.85);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: var(--slate);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.15s;
  flex-shrink: 0;
}

.reviews__btn:hover {
  background: var(--paper);
  border-color: var(--rose-deep);
  color: var(--rose-deep);
  transform: scale(1.06);
}

.reviews__btn:active {
  transform: scale(0.96);
}

.reviews__dots {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.reviews__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--mist);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background 0.25s, transform 0.25s;
  flex-shrink: 0;
}

.reviews__dot.is-active {
  background: var(--rose-deep);
  transform: scale(1.35);
}

.reviews__dot:hover:not(.is-active) {
  background: var(--stone);
}

/* Reviews carousel — spa-quiet horizontal slide. Front card sits centred and
   prominent. Side cards peek in slightly smaller and dimmer, no 3D rotation,
   no perspective tilt. Just a calm sideways flow that doesn't fight the
   silver-shimmer or petals already in motion on the page. */
.reviews__carousel {
  position: relative;
  max-width: var(--maxw);
  margin: 0 auto;
  /* Generous height so absolute-positioned cards have room. */
  height: 540px;
}
/* Edge mask — only applied when JS is ready, so it doesn't hide a fallback
   layout if scripts fail. */
.reviews__carousel.is-ready {
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 6%, #000 94%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0, #000 6%, #000 94%, transparent 100%);
}
/* Track is just a positioning context — the cards are absolute */
.reviews__track {
  position: relative;
  width: 100%;
  height: 100%;
}

/* FALLBACK: until JS adds .is-ready to the track, just show the first card
   centred. This way the section is never blank — even if scripts fail to load,
   the user sees a review. */
.reviews__track > .review {
  position: absolute;
  top: 0;
  left: 50%;
  width: clamp(280px, 30vw, 420px);
  transform: translate(-50%, 0);
  opacity: 0;
  pointer-events: none;
  z-index: 0;
}
.reviews__track:not(.is-ready) > .review:first-child {
  opacity: 1;
  pointer-events: auto;
  z-index: 5;
}

/* Once JS is ready, all cards become eligible for slot positioning.
   Cards without a slot class get the hidden default. */
.reviews__track.is-ready > .review {
  transform: translate(-50%, 0) scale(0.7);
  transition:
    transform 1.1s var(--ease),
    opacity 1.1s var(--ease);
  will-change: transform, opacity;
}

/* Slot positions — gentle horizontal spread, soft scale fall-off. No rotation. */
.reviews__track.is-ready > .review.is-front {
  transform: translate(-50%, 0) scale(1);
  opacity: 1;
  pointer-events: auto;
  z-index: 5;
}
.reviews__track.is-ready > .review.is-left {
  transform: translate(calc(-50% - 280px), 0) scale(0.9);
  opacity: 0.65;
  z-index: 4;
}
.reviews__track.is-ready > .review.is-right {
  transform: translate(calc(-50% + 280px), 0) scale(0.9);
  opacity: 0.65;
  z-index: 4;
}
.reviews__track.is-ready > .review.is-far-left {
  transform: translate(calc(-50% - 500px), 0) scale(0.78);
  opacity: 0.3;
  z-index: 3;
}
.reviews__track.is-ready > .review.is-far-right {
  transform: translate(calc(-50% + 500px), 0) scale(0.78);
  opacity: 0.3;
  z-index: 3;
}

/* Individual review card. Note: card transforms are owned by the coverflow
   positioning rules above (.is-front etc.) — don't add base transitions here
   that would interfere with the carousel's transform animations. */
.review {
  padding: 2.5rem 2rem 2rem;
  background: var(--paper);
  border: 1px solid var(--mist);
  border-radius: var(--r-md);
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
}
/* Silver hairline along the top edge — accent that ties the cards to silver story */
.review::before {
  content: '';
  position: absolute;
  top: 0;
  left: 2rem;
  right: 2rem;
  height: 1px;
  background: linear-gradient(
    100deg,
    transparent 0%,
    var(--silver-deep) 15%,
    var(--silver-mid) 35%,
    var(--silver-bright) 50%,
    var(--silver-mid) 65%,
    var(--silver-deep) 85%,
    transparent 100%
  );
  background-size: 200% 100%;
  background-position: 100% 0;
  animation: shimmer-sweep 8s ease-in-out infinite;
}
.review:nth-child(2)::before { animation-delay: -1.6s; }
.review:nth-child(3)::before { animation-delay: -3.2s; }
.review:nth-child(4)::before { animation-delay: -4.8s; }
.review:nth-child(5)::before { animation-delay: -6.4s; }

/* Note: no hover transform on .review — the coverflow JS owns the transforms.
   Hover behavior is implicit via the front card being interactive. */

/* Star row at top */
.review__stars {
  display: flex;
  gap: 0.15rem;
  margin-bottom: 0.85rem;
  font-size: 0.95rem;
  letter-spacing: 0.05em;
  /* Silver shimmer on the stars themselves — gives them the polished feel */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 25%,
    var(--silver-mid) 40%,
    var(--silver-bright) 50%,
    var(--silver-mid) 60%,
    var(--silver-deep) 75%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 7s ease-in-out infinite;
  width: max-content;
}

.review__mark {
  width: 32px;
  height: 32px;
  color: var(--blossom);
  opacity: 0.7;
  margin-bottom: 0.85rem;
}

.review blockquote {
  font-family: var(--serif);
  font-weight: 400;
  font-style: italic;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--ink);
  margin: 0 0 1.5rem;
  flex-grow: 1;
}
.review blockquote em {
  font-style: italic;
  /* Same pure silver shimmer as the rest of the heading emphasis */
  background: linear-gradient(
    100deg,
    var(--silver-deep) 0%,
    var(--silver-deep) 25%,
    var(--silver-mid) 40%,
    var(--silver-bright) 50%,
    var(--silver-mid) 60%,
    var(--silver-deep) 75%,
    var(--silver-deep) 100%
  );
  background-size: 250% 100%;
  background-position: 100% 0;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-sweep 9s ease-in-out infinite;
}

.review cite {
  display: block;
  padding-top: 1rem;
  border-top: 1px solid var(--mist);
  font-style: normal;
}
.review__name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.05rem;
  color: var(--char);
}

/* =========================================================
   VISIT / BOOKING
   ========================================================= */
.visit {
  padding: 7rem var(--gutter);
  background: var(--paper);
}
.visit__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}
.visit__info {
  margin-top: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
}
.visit__info > div {
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--mist);
}
.visit__info > div:last-child { border-bottom: none; }
.visit__info dt {
  font-size: 0.68rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 0.5rem;
}
.visit__info dd {
  font-family: var(--serif);
  font-size: 1.2rem;
  line-height: 1.5;
  color: var(--char);
}
.visit__info dd a {
  color: var(--char);
  border-bottom: 1px solid transparent;
  transition: border-color var(--med) var(--ease);
}
.visit__info dd a:hover { border-bottom-color: var(--stone); }

.visit__form {
  background: var(--paper-2);
  padding: 2.75rem;
  border-radius: var(--r-md);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  border: 1px solid var(--mist);
}
.visit__form h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.75rem;
  color: var(--char);
}
.visit__form-lede {
  font-size: 0.9rem;
  color: var(--slate);
  margin-bottom: 0.5rem;
}
.visit__form label {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.visit__form label > span {
  font-size: 0.68rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--slate);
}
.visit__form label small { text-transform: none; letter-spacing: 0; opacity: 0.7; }
.visit__form input,
.visit__form select,
.visit__form textarea {
  font-family: var(--sans);
  font-size: 1rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--mist);
  border-radius: var(--r-sm);
  background: var(--paper);
  color: var(--ink);
  transition: border-color var(--med) var(--ease),
              background var(--med) var(--ease),
              box-shadow var(--med) var(--ease);
  font-weight: 400;
}
.visit__form input:focus,
.visit__form select:focus,
.visit__form textarea:focus {
  outline: none;
  border-color: var(--blossom);
  background: var(--paper);
  box-shadow: 0 0 0 4px rgba(216, 154, 146, 0.12);
}
.visit__form textarea { resize: vertical; }
.visit__form-note {
  font-size: 0.95rem;
  font-family: var(--serif);
  color: var(--ink);
  padding: 1rem 1.25rem;
  background: var(--blush-pale);
  border-left: 3px solid var(--blossom);
  border-radius: var(--r-sm);
  animation: form-note-in 0.6s var(--ease);
}
@keyframes form-note-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer {
  background: var(--char);
  color: var(--paper);
  padding: 5rem var(--gutter) 2rem;
}
.footer__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.3fr 1.3fr 1fr;
  gap: 4rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid rgba(220, 217, 211, 0.15);
}
.footer__brand {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.footer__mark {
  /* Bigger — client request */
  width: 110px; height: 110px;
  object-fit: contain;
  filter: invert(1) contrast(1.15) drop-shadow(0 2px 10px rgba(0, 0, 0, 0.2));
  opacity: 1;
}
.footer__name {
  font-family: var(--serif);
  font-size: 2.25rem;
  color: var(--paper);
  line-height: 1;
}
.footer__tag {
  font-size: 0.68rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--stone);
  margin-top: 4px;
}
.footer__nav {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  align-items: flex-start;
}
.footer__nav a {
  font-size: 0.9rem;
  color: var(--mist);
  transition: color var(--med) var(--ease);
  position: relative;
}
.footer__nav a::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 1px;
  background: var(--blush);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--slow) var(--ease);
}
.footer__nav a:hover { color: var(--paper); }
.footer__nav a:hover::after { transform: scaleX(1); transform-origin: left; }
.footer__meta p {
  font-size: 0.9rem;
  color: var(--mist);
  margin-bottom: 0.4rem;
}
.footer__meta a { color: var(--paper); border-bottom: 1px solid transparent; transition: border-color var(--med) var(--ease); }
.footer__meta a:hover { border-bottom-color: var(--stone); }
.footer__socials {
  margin-top: 1.25rem;
  display: flex;
  gap: 0.75rem;
  align-items: center;
  font-size: 0.8rem;
}
.footer__socials span { opacity: 0.4; }

.footer__bottom {
  max-width: var(--maxw);
  margin: 2rem auto 0;
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: rgba(220, 217, 211, 0.5);
  letter-spacing: 0.06em;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px) {
  .laser__inner,
  .visit__inner { grid-template-columns: 1fr; gap: 3.5rem; }
  .philosophy__inner { grid-template-columns: 1fr; gap: 3rem; }
  .philosophy__collage { max-width: 100%; margin-bottom: 3rem; }
  .treatments__grid { grid-template-columns: repeat(2, 1fr); }
  .card--wide { grid-column: span 2; }
  /* Reviews carousel at tablet — pull side cards in tighter, no 3D */
  .reviews__carousel { height: 480px; }
  .reviews__track > .review { width: clamp(260px, 50vw, 380px); }
  .reviews__track.is-ready > .review.is-left {
    transform: translate(calc(-50% - 200px), 0) scale(0.86);
  }
  .reviews__track.is-ready > .review.is-right {
    transform: translate(calc(-50% + 200px), 0) scale(0.86);
  }
  .reviews__track.is-ready > .review.is-far-left,
  .reviews__track.is-ready > .review.is-far-right { opacity: 0; pointer-events: none; }

  /* Wall on tablet: 2 cols × 3 rows, natural height from rows */
  .wall { aspect-ratio: auto; min-height: 0; }
  .wall__grid { grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(3, minmax(260px, auto)); }
  .tile:nth-child(3n) { border-right: 1px solid rgba(242, 240, 236, 0.15); }
  .tile:nth-child(2n) { border-right: none; }
  .tile:nth-child(n+4) { border-bottom: 1px solid rgba(242, 240, 236, 0.15); }
  .tile:nth-child(n+5) { border-bottom: none; }
  .lashbrow__cards { grid-template-columns: 1fr; }
  .tips-flow { grid-template-columns: repeat(2, 1fr); row-gap: 5rem; }
  /* Hide flow path on tablet — gets too complex with 2 cols */
  .tips-flow__path { display: none; }
  .footer__inner { grid-template-columns: 1fr 1fr; gap: 2.5rem; }

  .hero__blossom--tr { width: 45vw; max-width: 420px; }
  .hero__blossom--bl { width: 50vw; max-width: 460px; }

  /* On tablet & below, stack photo above the price card instead of layering */
  .laser__photo {
    position: relative;
    top: 0; left: 0;
    width: 100%;
    aspect-ratio: 16 / 9;
    margin-bottom: 1.5rem;
  }
  .price-card { margin-top: 0; margin-left: 0; }
}

@media (max-width: 720px) {
  .nav__links, .nav__cta { display: none; }
  .nav__burger { display: block; }
  .nav.is-open .nav__mobile { display: flex; }

  .hero { padding-top: 6rem; }
  .hero__blossom--tr { width: 60vw; max-width: 320px; top: -3%; right: -6%; }
  .hero__blossom--bl { width: 70vw; max-width: 360px; bottom: -2%; left: -10%; }
  .hero__brand { width: 200px; }
  .marquee__track { font-size: 1.1rem; gap: 1.5rem; }

  .treatments__grid { grid-template-columns: 1fr; }
  .card--wide { grid-column: span 1; flex-direction: column; }
  .card--wide .card__image { min-height: 220px; }
  .card--wide .card__body { padding: 1.75rem; }

  /* Reviews on mobile: just the front card visible, no side peek */
  .reviews { padding: 4rem var(--gutter); }
  .reviews__head { margin-bottom: 2.5rem; }
  .reviews__carousel { height: 460px; }
  .reviews__track > .review { width: min(85vw, 360px); }
  .reviews__track.is-ready > .review.is-left,
  .reviews__track.is-ready > .review.is-right,
  .reviews__track.is-ready > .review.is-far-left,
  .reviews__track.is-ready > .review.is-far-right {
    opacity: 0;
    pointer-events: none;
  }
  .review { padding: 2rem 1.5rem 1.5rem; }
  .review blockquote { font-size: 0.95rem; }

  /* Wall on mobile: 2 cols × 3 rows, all 6 visible at once */
  .treatments { padding: 2.5rem 0 3rem; }
  .treatments__head { margin-bottom: 1.25rem; }
  .treatments__head .section-title { font-size: clamp(1.75rem, 7vw, 2.5rem); margin-bottom: 0.5rem; }
  .treatments__head .lede { font-size: 0.95rem; line-height: 1.45; }
  .wall {
    aspect-ratio: auto;
    min-height: 0;
    /* Keep short so heading + wall fit in a phone viewport */
    height: clamp(420px, 65vh, 560px);
  }
  .wall__grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, 1fr);
  }
  /* Reset borders for 2×3 layout */
  .tile { border-right: 1px solid rgba(242, 240, 236, 0.15); border-bottom: 1px solid rgba(242, 240, 236, 0.15); padding: 1.25rem 1rem 1rem; }
  .tile:nth-child(2n) { border-right: none; }
  .tile:nth-child(n+5) { border-bottom: none; }

  /* Smaller tile content to fit narrow columns */
  .tile__tag { font-size: 0.54rem; letter-spacing: 0.24em; margin-bottom: 0.35rem; }
  .tile__title { font-size: 1.05rem; line-height: 1.1; margin-bottom: 0.35rem; }
  .tile__sub { font-size: 0.72rem; line-height: 1.3; max-width: 100%; }

  /* Mini card: shrink to fit inside a single short tile, no overflow */
  .tile__card { left: 0.4rem; right: 0.4rem; top: 0.4rem; bottom: 0.4rem; padding: 0.7rem 0.8rem 0.65rem; border-radius: var(--r-sm); overflow: hidden; }
  .tile__card-tag { font-size: 0.5rem; letter-spacing: 0.22em; margin-bottom: 0.2rem; }
  .tile__card h3 { font-size: 0.82rem; line-height: 1.1; margin-bottom: 0.25rem; }
  .tile__card p {
    font-size: 0.66rem;
    line-height: 1.3;
    margin-bottom: 0.35rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .tile__card-foot { padding-top: 0.3rem; }
  .tile__card-price { font-size: 0.78rem; }
  .tile__card-link { font-size: 0.54rem; letter-spacing: 0.2em; }

  .tips-flow {
    grid-template-columns: 1fr;
    row-gap: 4.5rem;
    margin-top: 3.5rem;
    padding: 0;
  }
  .tip-step__btn { min-height: auto; padding-top: 3.2rem; padding-bottom: 1.5rem; }

  /* Philosophy collage — shrink blossom accents on mobile */
  .philosophy { padding: 5rem var(--gutter); }
  .philosophy__collage { aspect-ratio: 4 / 3.5; margin-bottom: 2.5rem; }
  .philosophy__img--main { width: 68%; }
  .philosophy__img--accent { width: 55%; bottom: -1.5rem; border-width: 4px; }
  .philosophy__blossom { width: 64px; height: 64px; top: 2%; right: 30%; }
  .philosophy__bloom-sm { width: 40px; height: 40px; bottom: 0; left: -0.5rem; }
  .philosophy__note { flex-direction: column; align-items: flex-start; gap: 0.75rem; padding: 1.25rem 1.5rem; }
  .pillar { grid-template-columns: 44px 1fr; gap: 1rem; }

  .banner { height: clamp(220px, 35vh, 320px); }
  .banner__text { font-size: 1.2rem; }

  .pricing__row { padding: 1rem 1.25rem; gap: 1rem; }
  .pricing__name strong { font-size: 1.02rem; }
  .pricing__price { font-size: 1.15rem; }

  .visit__form, .price-card { padding: 1.75rem; }

  .footer__inner { grid-template-columns: 1fr; gap: 2rem; }
  .footer__bottom { flex-direction: column; gap: 0.5rem; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}