/* =====================================================================
   NATURAL NAILS & BEAUTY — "Warm Minimal Luxury"
   Quiet-luxury beauty editorial · espresso anchor · champagne metallic
   ===================================================================== */

/* ───────────────────────────  TOKENS  ─────────────────────────── */
:root{
  /* Base & surfaces */
  --bone:#F4F0E9; --porcelain:#FBFAF6; --oat:#ECE5DA;
  /* Nude mids */
  --blush:#E4CDBE; --clay:#C9A892;
  /* Deep anchor */
  --espresso:#2E2520; --espresso-90:#3A302A;
  /* Metallic */
  --champagne:#B89B6E; --champagne-li:#CBAB85;
  /* Text */
  --ink:#241D19; --muted:#6E635A; --ink-on-dark:#EDE6DC; --muted-on-dark:#A9998C;
  /* Lines */
  --hairline:#D9CFC2; --hairline-d:#4A3F38;

  /* Semantic aliases */
  --bg:var(--bone); --surface:var(--porcelain); --surface-alt:var(--oat);
  --text:var(--ink); --text-muted:var(--muted); --accent:var(--champagne);
  --on-dark:var(--ink-on-dark); --on-dark-muted:var(--muted-on-dark);
  --line:var(--hairline); --line-dark:var(--hairline-d);

  /* Fonts */
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  /* Type scale (root = 18px) */
  --fs-display:clamp(3.25rem,9vw,6.10rem);
  --fs-h1:clamp(2.6rem,6vw,4.30rem);
  --fs-h2:clamp(2.1rem,4.4vw,3.05rem);
  --fs-h3:clamp(1.6rem,2.6vw,2.00rem);
  --fs-h4:1.40rem;
  --fs-lede:clamp(1.25rem,2.2vw,1.50rem);
  --fs-body-lg:1.25rem;
  --fs-body:1.00rem;
  --fs-small:0.83rem;
  --fs-eyebrow:0.72rem;
  --fs-micro:0.66rem;

  /* Spacing (8pt) */
  --s1:8px; --s2:16px; --s3:24px; --s4:40px; --s5:64px; --s6:96px; --s7:136px; --s8:200px;

  /* Layout */
  --maxw:1280px;
  --pad:clamp(24px,5vw,96px);
  --gutter:24px;

  /* Motion */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --dur-fast:250ms; --dur:700ms; --dur-slow:1000ms;

  --header-h:96px;
}

/* ───────────────────────────  RESET / BASE  ─────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{font-size:112.5%;-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 16px)}
@media (max-width:768px){html{font-size:106%}}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-sans);font-size:var(--fs-body);line-height:1.65;
  font-weight:400;letter-spacing:0;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
h1,h2,h3,h4,p,dl,dd,figure,blockquote{margin:0}
ul{margin:0;padding:0;list-style:none}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
em{font-style:italic}
address{font-style:normal}
/* focus ring: espresso on light (champagne fails contrast on bone), champagne on dark */
:focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:2px}
.dark :focus-visible,.cta :focus-visible,.footer :focus-visible,.menu :focus-visible{outline-color:var(--champagne)}
#main:focus{outline:none} /* skip-link scroll target, not an interactive control */
::selection{background:var(--blush);color:var(--espresso)}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--oat)}
::-webkit-scrollbar-thumb{background:var(--clay);border-radius:10px}

.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:8px;left:8px;z-index:10000;background:var(--espresso);color:var(--on-dark);
  padding:10px 16px;border-radius:2px;font-size:var(--fs-small);transform:translateY(-200%);transition:transform .2s}
.skip-link:focus{transform:translateY(0)}

/* ───────────────────────────  LAYOUT  ─────────────────────────── */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);column-gap:var(--gutter);row-gap:0}
.section{padding-block:var(--s7);position:relative}
.surface-alt{background:var(--surface-alt)}
.dark{background:var(--espresso);color:var(--on-dark)}
.dark{--text:var(--on-dark);--text-muted:var(--on-dark-muted);--line:var(--hairline-d)}
.section.dark{padding-block:var(--s8)}
@media (max-width:768px){
  .section{padding-block:var(--s5)}
  .section.dark{padding-block:var(--s6)}
  .grid{grid-template-columns:repeat(4,1fr);column-gap:16px}
}

/* hairline divider that closes most light sections */
.section:not(.dark) + .section:not(.dark)::before{
  content:"";position:absolute;top:0;left:var(--pad);right:var(--pad);height:1px;background:var(--hairline)
}

/* ───────────────────────────  TYPOGRAPHY  ─────────────────────────── */
.eyebrow{
  font-family:var(--font-sans);font-weight:600;font-size:var(--fs-eyebrow);
  text-transform:uppercase;letter-spacing:.22em;color:var(--muted);
  display:flex;align-items:center;gap:.7em;margin:0
}
.dark .eyebrow{color:var(--champagne)}
.eyebrow__tick{width:26px;height:1px;background:var(--champagne);display:inline-block}
.eyebrow--center{justify-content:center}

/* numbered section label (folio) */
.label{
  grid-column:1 / 13;display:flex;align-items:baseline;gap:.55em;margin:0 0 var(--s4);
  font-family:var(--font-sans);
}
.label__num{font-family:var(--font-display);font-style:italic;font-weight:400;color:var(--champagne);
  font-size:var(--fs-h4);line-height:1;font-variation-settings:"opsz" 40}
.label__dash{color:var(--champagne);font-size:var(--fs-small)}
.label__word{font-weight:600;font-size:var(--fs-eyebrow);text-transform:uppercase;letter-spacing:.22em;color:var(--muted)}
.label--on-dark .label__word{color:var(--champagne)}
.label__rule{flex:1;height:1px;background:var(--hairline);transform:scaleX(0);transform-origin:left;margin-left:.4em;
  align-self:center;opacity:.9;transition:transform var(--dur) var(--ease-out)}
.label--on-dark .label__rule{background:var(--hairline-d);opacity:1}
.is-in .label__rule,.no-js .label__rule{transform:scaleX(1)}

h2,h3{font-family:var(--font-display);font-weight:300;color:var(--text);text-wrap:balance}
.lede,.intro__lede{text-wrap:pretty}

/* ───────────────────────────  BUTTONS / LINKS  ─────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-sans);font-weight:500;
  font-size:var(--fs-small);letter-spacing:.02em;cursor:pointer;position:relative;
  transition:color var(--dur-fast) var(--ease-soft),background-color var(--dur-fast) var(--ease-soft),border-color var(--dur-fast) var(--ease-soft)
}
.btn__arrow{transition:transform var(--dur-fast) var(--ease-out)}
.btn:hover .btn__arrow{transform:translateX(5px)}

.btn--solid{background:var(--espresso);color:var(--on-dark);padding:.95em 1.7em;border-radius:999px}
.btn--solid:hover{background:var(--espresso-90)}
.btn--solid-light{background:var(--bone);color:var(--espresso);padding:.95em 1.7em;border-radius:999px;border:1px solid var(--champagne)}
.btn--solid-light:hover{background:#fff}

.btn--pill-outline{border:1px solid var(--champagne);color:var(--ink);padding:.6em 1.35em;border-radius:999px}
.btn--pill-outline:hover{background:var(--champagne);color:var(--bone)}

.btn--underline{color:var(--ink);padding:.95em 0;position:relative}
.btn--underline::after{content:"";position:absolute;left:0;bottom:.65em;width:100%;height:1px;background:currentColor;
  transform:scaleX(1);transform-origin:left;transition:transform var(--dur-fast) var(--ease-out);opacity:.6}
.btn--underline:hover::after{transform:scaleX(0);transform-origin:right}
.btn--on-dark{color:var(--on-dark)}

.link-underline{position:relative;color:inherit;display:inline-block}
.link-underline::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:var(--champagne);
  transform:scaleX(0);transform-origin:left;transition:transform .26s var(--ease-out)}
.link-underline:hover::after,.link-underline:focus-visible::after{transform:scaleX(1)}

/* ───────────────────────────  ICONS  ─────────────────────────── */
/* Stroke props are inheritable, so colour flows into <use> clones via currentColor. */
.ico{width:40px;height:40px;flex:none;color:var(--espresso);
  fill:none;stroke:currentColor;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round;
  transition:color .25s var(--ease-out)}
.ico--sm{stroke-width:1.5}
.ico--sm{width:17px;height:17px;display:inline-block;vertical-align:-3px;margin-right:.45em}
.dark .ico{color:var(--on-dark)}

/* ───────────────────────────  GRAIN / CURSOR  ─────────────────────────── */
.grain{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.cursor{position:fixed;top:0;left:0;z-index:9998;pointer-events:none;mix-blend-mode:multiply;display:none;
  opacity:0;transition:opacity .3s ease}
.cursor.is-ready{opacity:1}
@media (pointer:fine){.cursor{display:block}}
.cursor__dot,.cursor__ring{position:absolute;top:0;left:0;border-radius:50%;transform:translate(-50%,-50%)}
.cursor__dot{width:6px;height:6px;background:var(--espresso)}
.cursor__ring{width:34px;height:34px;border:1px solid var(--champagne);transition:width .25s var(--ease-out),height .25s var(--ease-out),opacity .25s;opacity:.7}
.cursor.is-hover .cursor__ring{width:52px;height:52px;opacity:1}
.cursor.is-hover .cursor__dot{opacity:0}
@media (pointer:fine){.has-cursor *{cursor:none}}

/* ───────────────────────────  FOLIO THREAD  ─────────────────────────── */
.folio{position:fixed;top:0;bottom:0;left:var(--rail-x,28px);width:1px;z-index:5;pointer-events:none;
  background:var(--hairline);opacity:0;transition:opacity .6s}
.folio__fill{position:absolute;top:0;left:0;width:100%;height:var(--folio-progress,0%);
  background:linear-gradient(var(--champagne),var(--champagne-li));transform-origin:top}
.js .folio{opacity:.9}
@media (max-width:1024px){.folio{display:none}}

/* ───────────────────────────  HEADER  ─────────────────────────── */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:100;
  transition:background-color .4s var(--ease-soft),box-shadow .4s var(--ease-soft)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);transition:height .4s var(--ease-soft)}
.site-header.is-scrolled{background:rgba(251,250,246,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 1px 0 var(--hairline)}
.site-header.is-scrolled .site-header__inner{height:68px}

.wordmark{font-family:var(--font-display);font-weight:400;font-size:1.22rem;color:var(--ink);letter-spacing:.01em;
  transition:font-size .4s var(--ease-soft);line-height:1}
.is-scrolled .wordmark{font-size:1.05rem}
.wordmark em{font-style:italic}
.wordmark__amp{color:var(--champagne);font-style:italic}

.nav{display:flex;align-items:center;gap:var(--s4)}
.nav__list{display:flex;gap:var(--s3)}
.nav__list a{font-weight:500;font-size:var(--fs-small);letter-spacing:.04em;color:var(--ink);position:relative;padding:.3em 0}
.nav__list a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--ink);
  transform:scaleX(0);transform-origin:left;transition:transform .26s var(--ease-out)}
.nav__list a:hover::after{transform:scaleX(1)}

.nav-toggle{display:none;width:40px;height:40px;flex-direction:column;justify-content:center;gap:6px;align-items:center}
.nav-toggle span{width:24px;height:1px;background:var(--ink);transition:transform .3s var(--ease-soft),opacity .3s}
.nav-toggle[aria-expanded="true"] span:first-child{transform:translateY(3.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:last-child{transform:translateY(-3.5px) rotate(-45deg)}

@media (max-width:880px){
  .nav{display:none}
  .nav-toggle{display:flex}
}

/* mobile nav */
.mobile-nav{position:fixed;inset:0;z-index:99;background:var(--bone);padding:var(--header-h) var(--pad) var(--pad);
  display:flex;align-items:center}
.mobile-nav[hidden]{display:none}
.mobile-nav nav{width:100%}
.mobile-nav ul{display:flex;flex-direction:column;gap:.2em;margin-bottom:var(--s4)}
.mobile-nav a{font-family:var(--font-display);font-weight:300;font-size:2.4rem;color:var(--ink);
  opacity:0;transform:translateY(16px)}
.mobile-nav.is-open a{animation:mnav .5s var(--ease-out) forwards}
.mobile-nav.is-open a:nth-child(1){animation-delay:.05s}
.mobile-nav.is-open a:nth-child(2){animation-delay:.1s}
.mobile-nav.is-open a:nth-child(3){animation-delay:.15s}
.mobile-nav.is-open a:nth-child(4){animation-delay:.2s}
.mobile-nav.is-open a:nth-child(5){animation-delay:.25s}
@keyframes mnav{to{opacity:1;transform:none}}

/* ───────────────────────────  HERO  ─────────────────────────── */
.hero{min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;position:relative;
  padding-top:var(--header-h);padding-bottom:var(--s6);overflow:hidden}
.hero__inner{position:relative;display:grid;grid-template-columns:repeat(12,1fr);column-gap:var(--gutter);
  align-items:center;flex:1;align-content:center}
.hero__eyebrow{grid-column:1 / 8;margin-bottom:var(--s3)}

.hero__heading{grid-column:1 / 11;font-family:var(--font-display);font-weight:300;
  font-size:var(--fs-display);line-height:.96;letter-spacing:-.02em;color:var(--ink);
  font-variation-settings:"opsz" 144;margin-left:-.03em;position:relative;text-wrap:balance}
.hero__heading .word{display:inline-block}
.hero__heading em{font-style:italic;font-weight:300}
.hero__break{display:inline-block}
.hero__precision{position:relative;display:inline-block}
.lacquer{position:absolute;left:-2%;bottom:-.16em;width:104%;height:.36em;overflow:visible}
.lacquer__stroke{fill:none;stroke:var(--champagne);stroke-width:2;stroke-linecap:round}
.lacquer__bead{fill:var(--champagne)}

/* gloss / top-coat sweep */
.gloss{position:absolute;inset:0;font-family:var(--font-display);font-weight:300;font-size:var(--fs-display);
  line-height:.96;letter-spacing:-.02em;font-variation-settings:"opsz" 144;
  pointer-events:none;color:transparent;
  background:linear-gradient(100deg,transparent 38%,var(--champagne-li) 50%,transparent 62%);
  background-size:240% 100%;background-position:160% 0;background-repeat:no-repeat;
  -webkit-background-clip:text;background-clip:text;mix-blend-mode:soft-light;opacity:0}
.hero__heading .gloss{margin-left:-.03em}
.gloss.is-sweep{animation:gloss 1.1s var(--ease-out) forwards}
@keyframes gloss{0%{opacity:0;background-position:160% 0}10%{opacity:1}100%{opacity:0;background-position:-60% 0}}

.hero__aside{grid-column:8 / 13;align-self:end;justify-self:end;text-align:right;max-width:34ch;margin-top:var(--s5)}
.hero__lede{font-family:var(--font-display);font-weight:300;font-size:var(--fs-lede);font-style:italic;
  color:var(--ink);line-height:1.4;margin-bottom:var(--s3)}
.hero__cta{display:flex;gap:var(--s3);justify-content:flex-end;align-items:center;flex-wrap:wrap}

.hero__slot{grid-column:7 / 11;grid-row:1;align-self:center;justify-self:end;
  width:min(320px,30vw);aspect-ratio:3/4;z-index:-1;opacity:.9}

.hero__locations{display:flex;align-items:center;gap:1.4em;justify-content:center;
  padding-top:var(--s3);border-top:1px solid var(--hairline);
  font-family:var(--font-sans);font-weight:600;font-size:var(--fs-eyebrow);text-transform:uppercase;
  letter-spacing:.22em;color:var(--muted)}
.hero__locations .dash{color:var(--champagne)}

@media (max-width:880px){
  .hero__heading{grid-column:1 / 13}
  .hero__aside{grid-column:1 / 13;justify-self:start;text-align:left;align-self:start;margin-top:var(--s4)}
  .hero__cta{justify-content:flex-start}
  .hero__slot{display:none}
  .hero__locations{flex-wrap:wrap;gap:.8em;justify-content:flex-start}
}

/* ───────────────────────────  SLOTS (placeholder imagery)  ─────────────────────────── */
.slot{position:relative;overflow:hidden;border-radius:2px;background:var(--oat);isolation:isolate}
.slot__grad{position:absolute;inset:0;z-index:0;transform:scale(1.04);transition:transform 1s var(--ease-out),opacity 1s;
  box-shadow:inset 0 0 70px rgba(36,29,25,.14), inset 0 -40px 60px -28px rgba(36,29,25,.26)}
.slot[data-tone="blush"] .slot__grad{background:linear-gradient(var(--ang,135deg),var(--blush),var(--clay) 70%,var(--oat))}
.slot[data-tone="clay"] .slot__grad{background:linear-gradient(var(--ang,135deg),var(--clay),#b8967e 60%,var(--espresso-90))}
.slot[data-tone="oat"] .slot__grad{background:linear-gradient(var(--ang,135deg),var(--oat),var(--blush) 80%,var(--clay))}
.slot::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.slot.is-in .slot__grad{transform:scale(1)}
.slot__cap{position:absolute;left:14px;bottom:12px;z-index:2;font-size:var(--fs-micro);text-transform:uppercase;
  letter-spacing:.18em;color:var(--espresso);background:rgba(244,240,233,.92);padding:5px 9px;border-radius:2px}
@supports ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){
  .slot__cap{background:rgba(244,240,233,.62);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
}
.slot__alt{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ───────────────────────────  01 · INTRO  ─────────────────────────── */
.intro__body{grid-column:3 / 8}
.intro__lede{font-size:var(--fs-h2);font-family:var(--font-display);font-weight:300;line-height:1.12;color:var(--ink);
  margin-bottom:var(--s4)}
.intro__lede em{color:var(--ink);font-style:italic}
.intro__body p{font-size:var(--fs-body-lg);color:var(--text-muted);max-width:62ch;margin-bottom:var(--s3)}
.intro__marks{display:flex;gap:var(--s5);margin-top:var(--s4);flex-wrap:wrap}
.intro__marks li{font-size:var(--fs-small);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);
  display:flex;align-items:baseline;gap:.5em}
.intro__marknum{font-family:var(--font-display);font-style:italic;font-size:var(--fs-h3);color:var(--champagne)}
.intro__slot{grid-column:9 / 13;grid-row:2;aspect-ratio:3/4;margin-top:var(--s4);align-self:start}

@media (max-width:880px){
  .intro__body{grid-column:1 / 5}
  .intro__slot{grid-column:1 / 5;grid-row:auto;margin-top:var(--s4);aspect-ratio:4/3;max-height:420px}
  .intro__marks{gap:var(--s4)}
}

/* ───────────────────────────  02 · SERVICES  ─────────────────────────── */
.services__list{grid-column:2 / 8;border-top:1px solid var(--hairline)}
.service{display:flex;align-items:flex-start;gap:var(--s3);padding:var(--s3) 0;border-bottom:1px solid var(--hairline);
  transition:padding-left .25s var(--ease-out)}
.service:hover{padding-left:8px}
.service .ico{margin-top:2px}
.service__name{font-family:var(--font-display);font-weight:400;font-size:var(--fs-h4);color:var(--ink);line-height:1.2}
.service__desc{font-size:var(--fs-small);color:var(--text-muted);margin-top:.25em;max-width:48ch}
.service:hover .ico{color:var(--champagne)}

.services__word{grid-column:8 / 13;grid-row:1;align-self:center;justify-self:center;position:relative;
  min-height:1.2em;display:grid;place-items:center;pointer-events:none}
.services__cycle{grid-area:1/1;font-family:var(--font-display);font-weight:300;font-style:italic;
  font-size:var(--fs-h1);color:var(--clay);opacity:0;filter:blur(6px);transition:opacity .6s var(--ease-soft),filter .6s var(--ease-soft);
  font-variation-settings:"opsz" 144;text-align:center;white-space:nowrap}
.services__cycle.is-active{opacity:.85;filter:blur(0)}

@media (max-width:880px){
  .services__list{grid-column:1 / 5}
  .services__word{display:none}
}

/* ───────────────────────────  03 · MENU  ─────────────────────────── */
.menu .label{margin-bottom:var(--s5)}
.menu__inner{grid-column:2 / 12;display:grid;grid-template-columns:1fr 1fr;gap:var(--s5) var(--s6);
  padding:var(--s5);border:1px solid var(--hairline-d)}
.menu__cat{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:var(--fs-h3);color:var(--champagne);
  margin-bottom:var(--s3);font-variation-settings:"opsz" 40}
.menu__list{display:flex;flex-direction:column;gap:.55em}
.menu__row{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:.5em;position:relative}
.menu__row dt{font-family:var(--font-sans);font-weight:400;font-size:var(--fs-body);color:var(--on-dark);
  background:var(--espresso);padding-right:.5em;position:relative;z-index:1}
.menu__row::before{content:"";position:absolute;left:0;right:0;bottom:.34em;z-index:0;
  border-bottom:1px dotted var(--hairline-d)}
.menu__row .price{font-family:var(--font-display);font-weight:500;font-size:var(--fs-body);color:var(--on-dark);
  background:var(--espresso);padding-left:.5em;position:relative;z-index:1;font-variation-settings:"opsz" 40;
  white-space:nowrap;letter-spacing:.02em}
.menu__note{grid-column:2 / 10;margin-top:var(--s4);font-family:var(--font-display);font-style:italic;
  font-size:var(--fs-small);color:var(--on-dark-muted)}
@media (max-width:880px){
  .menu__inner{grid-column:1 / 5;grid-template-columns:1fr;gap:var(--s4);padding:var(--s3)}
  .menu__note{grid-column:1 / 5}
}

/* ───────────────────────────  04 · LOOKBOOK  ─────────────────────────── */
.lookbook__head{grid-column:1 / 13;display:flex;align-items:baseline;justify-content:space-between;
  gap:var(--s3);margin-bottom:var(--s4);flex-wrap:wrap}
.lookbook__head .label{margin-bottom:0;grid-column:auto}
.lookbook__follow{font-size:var(--fs-small);color:var(--ink)}
.mosaic{grid-column:1 / 13;display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:190px;gap:var(--gutter)}
.mosaic__item{display:block;border:1px solid var(--hairline);transition:border-color .3s var(--ease-out)}
.mosaic__item--hero{grid-column:1 / 7;grid-row:1 / 3}
.mosaic__item:nth-child(2){grid-column:7 / 13;grid-row:1 / 2}
.mosaic__item:nth-child(3){grid-column:7 / 10;grid-row:2 / 3}
.mosaic__item:nth-child(4){grid-column:10 / 13;grid-row:2 / 3}
.mosaic__item:nth-child(5){grid-column:1 / 13;grid-row:3 / 4}  /* full-width closing strip — no dangling gap */
/* vary gradient angle per tile so they don't read as one repeated smear */
.mosaic__item:nth-child(1){--ang:120deg}
.mosaic__item:nth-child(2){--ang:160deg}
.mosaic__item:nth-child(3){--ang:100deg}
.mosaic__item:nth-child(4){--ang:205deg}
.mosaic__item:nth-child(5){--ang:90deg}
.mosaic__item:hover{border-color:var(--champagne)}
.slot__tag{position:absolute;left:14px;bottom:14px;z-index:2;font-size:var(--fs-micro);text-transform:uppercase;
  letter-spacing:.16em;color:var(--espresso)}
.slot__ig{position:absolute;right:14px;top:14px;z-index:2;font-size:var(--fs-micro);letter-spacing:.08em;
  color:var(--espresso);opacity:0;transform:translateY(-4px);transition:opacity .3s,transform .3s}
.mosaic__item:hover .slot__ig{opacity:1;transform:none}
.mosaic__item:hover .slot__grad{transform:scale(1.06)}
@media (max-width:880px){
  .mosaic{grid-auto-rows:130px;gap:14px}
  .mosaic__item,.mosaic__item--hero,.mosaic__item:nth-child(n){grid-column:span 6}
  .mosaic__item--hero{grid-column:1 / -1;grid-row:span 2}
}

/* ───────────────────────────  05 · STUDIOS  ─────────────────────────── */
.salons__list{grid-column:2 / 13;border-top:1px solid var(--hairline)}
.salon{display:grid;grid-template-columns:64px 1fr 168px;gap:var(--s4);align-items:center;
  padding:var(--s5) 0;border-bottom:1px solid var(--hairline);position:relative;
  transition:background-color .3s var(--ease-out),padding-left .3s var(--ease-out)}
.salon::after{content:"";position:absolute;left:0;bottom:-1px;height:1px;width:100%;background:var(--champagne);
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.salon:hover{background:var(--porcelain);padding-left:var(--s2)}
.salon:hover::after{transform:scaleX(1)}
.salon--offset{transform:translateY(24px)}
.salon__index{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:var(--fs-h2);color:var(--champagne);
  line-height:1;font-variation-settings:"opsz" 144}
.salon__name{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h2);color:var(--ink);line-height:1.05;margin-bottom:.25em}
.salon__tag{font-size:var(--fs-body-lg);color:var(--text-muted);margin-bottom:var(--s2);max-width:46ch}
.salon__meta{display:flex;flex-direction:column;gap:.35em;font-size:var(--fs-small);color:var(--muted);margin-bottom:var(--s2)}
.salon__meta .ico{color:var(--champagne)}
.salon__phone{color:var(--ink);width:max-content}
.salon__confirm{color:var(--muted);font-style:italic}
.salon__hourslink{color:var(--ink);text-decoration:underline;text-decoration-color:var(--champagne);text-underline-offset:2px}
.salon__hourslink:hover{color:var(--champagne)}
.salon__book{display:inline-flex;align-items:center;gap:.5em;font-size:var(--fs-small);font-weight:500;color:var(--ink);
  border:1px solid var(--hairline);border-radius:999px;padding:.5em 1.15em;width:max-content;
  transition:border-color .3s var(--ease-out),background-color .3s var(--ease-out)}
.salon__book span{display:inline-block;transition:transform .3s var(--ease-out)}
.salon:hover .salon__book{border-color:var(--champagne)}
.salon:hover .salon__book span,.salon__book:hover span{transform:translateX(6px)}
.salon__sliver{width:100%;height:120px;align-self:stretch;min-height:100%}
@media (max-width:880px){
  .salons__list{grid-column:1 / 5}
  .salon{grid-template-columns:1fr;gap:var(--s2);padding:var(--s4) 0}
  .salon--offset{transform:none}
  .salon__index{font-size:var(--fs-h3)}
  .salon__sliver{height:90px;order:-1}
}

/* ───────────────────────────  06 · TESTIMONIALS  ─────────────────────────── */
.quotes{grid-column:2 / 11;position:relative;min-height:clamp(220px,30vh,300px)}
.quotes__mark{position:absolute;left:-.1em;top:-.55em;font-family:var(--font-display);font-style:italic;
  font-size:13rem;line-height:1;color:var(--champagne);opacity:.16;z-index:0;pointer-events:none}
.quote{position:absolute;inset:0;opacity:0;transform:translateY(10px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out);
  display:flex;flex-direction:column;gap:var(--s4);justify-content:center}
.quote.is-active{opacity:1;transform:none;position:relative}
.quote__text{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:var(--fs-h2);
  line-height:1.25;color:var(--on-dark);max-width:24ch}
.quote__by{font-family:var(--font-sans);font-weight:600;font-size:var(--fs-eyebrow);text-transform:uppercase;
  letter-spacing:.22em;color:var(--on-dark-muted)}
.quotes__nav{display:flex;align-items:center;gap:var(--s2);margin-top:var(--s5)}
.quotes__dots{display:flex;gap:.2em}
.quotes__dot{width:26px;height:26px;display:grid;place-items:center;background:none;border:0}
.quotes__dot::before{content:"";width:9px;height:9px;border-radius:50%;border:1px solid var(--champagne);transition:background-color .3s}
.quotes__dot.is-active::before,.quotes__dot[aria-current="true"]::before{background:var(--champagne)}
.quotes__pp{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--hairline-d);border-radius:50%;
  transition:border-color .3s}
.quotes__pp:hover{border-color:var(--champagne)}
.quotes__pp-ico{display:block}
.quotes__pp[aria-pressed="false"] .quotes__pp-ico{width:9px;height:11px;border-left:3px solid var(--champagne);border-right:3px solid var(--champagne)}
.quotes__pp[aria-pressed="true"] .quotes__pp-ico{width:0;height:0;margin-left:2px;border-left:10px solid var(--champagne);border-top:6px solid transparent;border-bottom:6px solid transparent}
@media (max-width:880px){.quotes{grid-column:1 / 5}.quotes__mark{font-size:8rem}}

/* ───────────────────────────  FINAL CTA  ─────────────────────────── */
.cta{background:var(--espresso-90);color:var(--on-dark);text-align:center;position:relative;overflow:hidden}
.cta{--text:var(--on-dark);--text-muted:var(--on-dark-muted)}
.cta::before{content:"";position:absolute;top:0;left:var(--pad);right:var(--pad);height:1px;background:var(--champagne);opacity:.6}
.cta__inner{max-width:760px;margin-inline:auto;display:flex;flex-direction:column;align-items:center;gap:var(--s3);position:relative}
.cta__heading{font-family:var(--font-display);font-weight:300;font-size:var(--fs-h1);color:var(--on-dark);
  line-height:1.05;font-variation-settings:"opsz" 144;position:relative}
.cta__heading em{font-style:italic;border-bottom:1px solid var(--champagne);padding-bottom:.04em;color:var(--champagne)}
.gloss--cta{font-size:var(--fs-h1);line-height:1.05}
.cta__sub{font-size:var(--fs-body-lg);color:var(--on-dark-muted);max-width:48ch}
.cta__btns{display:flex;gap:var(--s3);flex-wrap:wrap;justify-content:center;margin-top:var(--s2)}
.cta__ghost{margin-top:var(--s4);font-size:var(--fs-eyebrow);text-transform:uppercase;letter-spacing:.24em;color:var(--on-dark-muted);opacity:.6}

/* ───────────────────────────  FOOTER  ─────────────────────────── */
.footer{background:var(--espresso);color:var(--on-dark);padding-top:var(--s6);position:relative}
.footer{--text:var(--on-dark);--text-muted:var(--on-dark-muted)}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--champagne);opacity:.7}
.footer__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--s4) var(--gutter);padding-bottom:var(--s5)}
.footer__brand{grid-column:1 / 5}
.footer__studios{grid-column:5 / 9}
.footer__explore{grid-column:9 / 11}
.footer__visit{grid-column:11 / 13}
.wordmark--footer{font-size:1.5rem;color:var(--on-dark);display:inline-block;margin-bottom:var(--s2)}
.wordmark--footer em{color:var(--on-dark)}
.footer__tag{font-family:var(--font-display);font-style:italic;font-size:var(--fs-body-lg);color:var(--on-dark-muted);margin-bottom:var(--s3)}
.footer__socials{display:flex;gap:var(--s3);font-size:var(--fs-small)}
.footer__h{font-family:var(--font-sans);font-weight:600;font-size:var(--fs-eyebrow);text-transform:uppercase;
  letter-spacing:.22em;color:var(--champagne);margin-bottom:var(--s3)}
.footer__studios ul{display:flex;flex-direction:column;gap:var(--s3)}
.footer__studios li{display:flex;flex-direction:column;gap:.2em;font-size:var(--fs-small);color:var(--on-dark-muted)}
.footer__sname{color:var(--on-dark);font-weight:500;font-size:var(--fs-body)}
.footer__studios a[href^="tel"]{color:var(--on-dark-muted)}
.footer__explore ul{display:flex;flex-direction:column;gap:.6em}
.footer__explore a{font-size:var(--fs-small);color:var(--on-dark);position:relative;width:max-content}
.footer__explore a:hover{color:var(--champagne)}
.footer__visit p{font-size:var(--fs-small);color:var(--on-dark-muted);margin-bottom:var(--s2)}
.footer__note{color:var(--champagne)!important}
.footer__legal{display:flex;align-items:center;justify-content:space-between;gap:var(--s2);
  padding-block:var(--s3);border-top:1px solid var(--hairline-d);font-size:var(--fs-micro);
  text-transform:uppercase;letter-spacing:.14em;color:var(--on-dark-muted);flex-wrap:wrap}
.footer__top{color:var(--champagne)}
@media (max-width:880px){
  .footer__grid{grid-template-columns:repeat(4,1fr)}
  .footer__brand,.footer__studios,.footer__explore,.footer__visit{grid-column:1 / 5}
}

/* ───────────────────────────  SCROLL REVEAL  ─────────────────────────── */
.js [data-reveal]{opacity:0;transform:translateY(32px);filter:blur(6px);
  transition:opacity .8s var(--ease-out),transform .8s var(--ease-out),filter .8s var(--ease-out)}
.js [data-reveal].is-in{opacity:1;transform:none;filter:blur(0)}
.js .hero [data-stagger]{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.js .hero.is-ready [data-stagger]{opacity:1;transform:none}
.js .hero.is-ready [data-stagger]{transition-delay:calc(var(--i,0) * 90ms)}

/* ───────────────────────────  REDUCED MOTION  ─────────────────────────── */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.15s!important;scroll-behavior:auto!important}
  .js [data-reveal],.js .hero [data-stagger]{opacity:1!important;transform:none!important;filter:none!important}
  .slot__grad{transform:none!important}
  .hero__slot{transform:none!important}
  .gloss{opacity:.12;animation:none;background-position:50% 0}
  .lacquer__stroke{stroke-dasharray:none!important;stroke-dashoffset:0!important}
  .folio__fill{height:100%!important;opacity:.5}
  .cursor{display:none!important}
  .has-cursor *{cursor:auto!important}
}

/* no-js: everything visible */
.no-js [data-reveal],.no-js [data-stagger]{opacity:1!important;transform:none!important;filter:none!important}
.no-js .lacquer__stroke{stroke-dashoffset:0}
.no-js .folio{display:none}
