/* ============================================================
   MAREN & CO. — Couture editorial-luxe / Vogue masthead
   Display: Cormorant Garamond (very light, very large)
   Body / labels: Jost (wide-tracked caps)
   Palette: --ink #1A1614 · --oat #E7D8C9 · --clay #C99B7A · --cream #F5EFE8
   Shape language: thin rules, huge margins, per-letter type.
   ============================================================ */

:root{
  --ink:#1A1614;
  --oat:#E7D8C9;
  --clay:#C99B7A;
  --cream:#F5EFE8;

  --ink-2:#3A322C;
  --cream-2:#EFE7DC;
  --oat-deep:#D8C5B2;
  --line:#D6C7B6;            /* hairline on cream */
  --line-2:#C9B7A2;
  --line-ink:rgba(245,239,232,.20);  /* hairline on ink */
  --muted:#6B5F54;
  --muted-ink:#B7A795;
  --clay-soft:rgba(201,155,122,.14);

  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Jost',system-ui,-apple-system,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-soft:cubic-bezier(.33,.1,.25,1);
  --gutter:clamp(20px,5vw,72px);
  --maxw:1320px;

  --hdr-h:88px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  font-weight:300;
  line-height:1.7;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img,svg{display:block;max-width:100%}
h1,h2,h3,h4{margin:0;font-family:var(--serif);font-weight:300;line-height:1;overflow-wrap:break-word}
p{margin:0}
::selection{background:var(--clay);color:var(--cream)}

a:focus-visible,button:focus-visible,summary:focus-visible,
input:focus-visible,textarea:focus-visible,select:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--clay);
  outline-offset:4px;
}

/* ---------- Skip link ---------- */
.skip{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--ink);color:var(--cream);
  padding:12px 20px;font-family:var(--sans);
  text-transform:uppercase;letter-spacing:.22em;font-size:11px;
}
.skip:focus{left:12px;top:12px}

/* ---------- Layout shell ---------- */
.shell{width:min(var(--maxw),calc(100% - (var(--gutter)*2)));margin-inline:auto}
.shell-wide{width:min(1560px,calc(100% - (var(--gutter)*2)));margin-inline:auto}

/* ---------- The label voice (Jost wide caps) ---------- */
.label{
  font-family:var(--sans);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:11px;
  line-height:1.5;
  color:var(--muted);
}
.label-clay{color:var(--clay)}
.label-ink{color:var(--ink)}
.eyebrow{
  display:inline-flex;align-items:baseline;gap:14px;
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.34em;font-size:11px;color:var(--clay);
}
.eyebrow::before{
  content:"";align-self:center;width:34px;height:1px;background:var(--clay);
}
.folio{
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.3em;font-size:11px;color:var(--muted);
}
.serif-it{font-style:italic}

/* ---------- Thin rules (signature shape) ---------- */
.rule{height:1px;background:var(--line);border:0;margin:0}
.rule-ink{height:1px;background:var(--line-ink);border:0;margin:0}
.rule-clay{height:1px;background:var(--clay);border:0;margin:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  min-height:54px;padding:0 30px;
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.24em;font-size:11px;
  border:1px solid var(--ink);
  background:var(--ink);color:var(--cream);
  cursor:pointer;border-radius:0;
  transition:background .4s var(--ease),color .4s var(--ease),transform .2s var(--ease);
}
.btn:hover{background:transparent;color:var(--ink)}
.btn:active{transform:translateY(1px)}
.btn .arr{display:inline-block;transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(6px)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-on-ink{background:var(--cream);border-color:var(--cream);color:var(--ink)}
.btn-on-ink:hover{background:transparent;color:var(--cream)}
.btn-clay{background:var(--clay);border-color:var(--clay);color:var(--cream)}
.btn-clay:hover{background:transparent;color:var(--ink);border-color:var(--ink)}

/* ---------- Link with pen-stroke underline (SECOND-READ) ---------- */
.pen{position:relative;display:inline-block}
.pen::after{
  content:"";position:absolute;left:0;bottom:-2px;
  width:100%;height:1px;background:currentColor;
  transform:scaleX(0);transform-origin:left center;
  transition:transform .5s var(--ease);
}
.pen:hover::after,.pen:focus-visible::after{transform:scaleX(1)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* per-letter reveal */
.lt{display:inline-block;opacity:0;transform:translateY(.16em) rotate(2deg);
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
.letters.in .lt{opacity:1;transform:none}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:90;
  background:color-mix(in srgb, var(--cream) 88%, transparent);
  backdrop-filter:saturate(1.1) blur(10px);
  -webkit-backdrop-filter:saturate(1.1) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease),background .4s var(--ease);
}
.site-header.condensed{
  border-bottom-color:var(--line);
  background:color-mix(in srgb, var(--cream) 95%, transparent);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  min-height:var(--hdr-h);gap:24px;
  transition:min-height .4s var(--ease);
}
.site-header.condensed .nav{min-height:68px}
.brand{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.4vw,28px);letter-spacing:.02em;
  line-height:1;white-space:nowrap;display:inline-flex;align-items:baseline;gap:.2em;
}
.brand .amp{font-style:italic;color:var(--clay)}
.brand-sub{
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.3em;font-size:8.5px;color:var(--muted);
  margin-left:.5em;align-self:center;
}
.nav-links{display:flex;align-items:center;gap:clamp(20px,2.4vw,40px);list-style:none;margin:0;padding:0}
.nav-links a{
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.2em;font-size:11px;color:var(--ink);
  position:relative;padding:4px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;
  background:var(--clay);transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{transform:scaleX(1)}
.nav-links a[aria-current="page"]{color:var(--clay)}
.nav-cta{display:flex;align-items:center;gap:18px}
.nav-cta .btn{min-height:46px;padding:0 22px}

.hamburger{
  display:none;width:46px;height:46px;border:1px solid var(--line-2);
  background:transparent;cursor:pointer;align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
}
.hamburger span{display:block;width:20px;height:1px;background:var(--ink);transition:transform .35s var(--ease),opacity .25s var(--ease)}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-menu{
  display:none;position:fixed;inset:var(--hdr-h) 0 0 0;z-index:80;
  background:var(--cream);
  padding:40px var(--gutter) 60px;
  flex-direction:column;
  transform:translateY(-12px);opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease),transform .4s var(--ease);
  overflow-y:auto;
}
.mobile-menu.open{opacity:1;transform:none;pointer-events:auto}
.mobile-menu a{
  font-family:var(--serif);font-weight:300;font-size:38px;
  padding:14px 0;border-bottom:1px solid var(--line);
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
}
.mobile-menu a .mm-no{
  font-family:var(--sans);font-size:20px;line-height:1;color:var(--clay);
  align-self:center;opacity:.55;
  transition:transform .35s var(--ease),opacity .35s var(--ease);
}
.mobile-menu a:hover .mm-no,.mobile-menu a:focus-visible .mm-no{transform:translateX(6px);opacity:1}
.mobile-menu .mm-foot{margin-top:auto;padding-top:36px}
.mobile-menu .mm-foot .btn{
  width:100%;justify-content:center;text-align:center;
  /* .mobile-menu a sets 38px serif; the button must use its own 11px caps,
     otherwise the long label renders huge and clips at 320–375px */
  font-family:var(--sans);font-size:11px;font-weight:400;letter-spacing:.24em;
}

/* =========================================================
   HERO — TYPE IS THE LAYOUT (giant Cormorant word)
   ========================================================= */
.hero{position:relative;padding:clamp(40px,7vh,90px) 0 clamp(36px,6vh,72px);overflow:hidden}
.hero-top{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:24px;flex-wrap:wrap;margin-bottom:clamp(20px,5vh,56px);
}
.hero-top .est{font-family:var(--serif);font-style:italic;font-size:clamp(16px,2vw,20px);color:var(--muted)}
.hero-word-wrap{position:relative}
.hero-word{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(80px,26vw,360px);
  line-height:.82;letter-spacing:-.02em;
  margin:0;color:var(--ink);
  text-align:center;
  /* single word: never split mid-word — keep it whole even during the
     web-font swap / on devices whose serif fallback measures wider */
  white-space:nowrap;max-width:100%;
  overflow-wrap:normal;word-break:keep-all;hyphens:none;
}
.hero-word .lt{will-change:transform,opacity}
/* fine-line botanical threading through a counter */
.hero-botanical{
  position:absolute;pointer-events:none;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(96%,1200px);height:auto;opacity:.9;z-index:2;
}
.hero-botanical .stem{
  stroke:var(--clay);stroke-width:1.4;fill:none;
  stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1400;stroke-dashoffset:1400;
  animation:draw 3.4s var(--ease) .9s forwards;
}
.hero-botanical .leaf{fill:var(--clay);opacity:0;animation:fadeLeaf .9s var(--ease) 2.6s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes fadeLeaf{to{opacity:.55}}

.hero-foot{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:clamp(16px,3vw,40px);
  margin-top:clamp(20px,4vh,44px);
}
.hero-foot>*{min-width:0}
.hero-foot .rule{flex:1}
.hero-tag{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(19px,2.6vw,32px);line-height:1.2;color:var(--ink);
  text-align:center;
}
.hero-meta{
  display:flex;flex-direction:column;gap:4px;text-align:right;
}
.hero-meta.left{text-align:left}
.hero-scroll{
  display:flex;align-items:center;gap:12px;justify-content:center;
  margin-top:clamp(28px,6vh,64px);
}
.hero-scroll .label{display:inline-flex;align-items:center;gap:12px}
.hero-scroll .tick{width:1px;height:38px;background:var(--line-2);position:relative;overflow:hidden}
.hero-scroll .tick::after{content:"";position:absolute;inset:0;background:var(--clay);animation:tickrun 2.6s var(--ease) infinite}
@keyframes tickrun{0%{transform:translateY(-100%)}55%,100%{transform:translateY(100%)}}

/* =========================================================
   SECTION SCAFFOLD
   ========================================================= */
.sec{padding:clamp(64px,11vh,144px) 0;position:relative}
.sec-head{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(16px,3vw,48px);
  align-items:start;margin-bottom:clamp(40px,7vh,84px);
}
.sec-head>*{min-width:0}
.sec-no{
  font-family:var(--sans);font-weight:400;letter-spacing:.2em;
  font-size:12px;color:var(--clay);padding-top:.6em;white-space:nowrap;
}
.sec-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,7vw,104px);line-height:.94;letter-spacing:-.015em;
}
.sec-title .it{font-style:italic;color:var(--clay)}
.sec-lede{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(20px,2.6vw,30px);line-height:1.42;color:var(--ink-2);
  max-width:46ch;margin-top:clamp(20px,3vh,32px);
}
.sec-lede.indent{margin-left:auto;max-width:50ch}

/* =========================================================
   INTRO / STATEMENT
   ========================================================= */
.statement{padding:clamp(72px,13vh,168px) 0}
.statement .big{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,5vw,66px);line-height:1.18;letter-spacing:-.01em;
  max-width:18ch;
}
.statement .big .it{font-style:italic;color:var(--clay)}
.statement-grid{
  display:grid;grid-template-columns:1fr;gap:clamp(36px,6vw,80px);
  margin-top:clamp(40px,6vh,72px);
}
.statement-cols{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px);
  padding-top:clamp(28px,4vh,40px);border-top:1px solid var(--line);
}
.statement-cols>*{min-width:0}
.stat-col h4{font-family:var(--serif);font-size:clamp(22px,2.4vw,28px);margin-bottom:10px}
.stat-col p{font-size:14.5px;color:var(--muted);line-height:1.75}
.stat-col .label{margin-bottom:14px;display:block}

/* =========================================================
   PRICE INDEX (contents-page) — services.html + home preview
   ========================================================= */
.index-wrap{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,56px)}
.index-tabs{
  display:flex;flex-wrap:wrap;gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.index-tab{
  appearance:none;background:transparent;border:0;cursor:pointer;
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.22em;font-size:11px;color:var(--muted);
  padding:18px 22px 16px;position:relative;
  transition:color .35s var(--ease);
}
.index-tab::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:center;
  transition:transform .45s var(--ease);
}
.index-tab[aria-selected="true"]{color:var(--ink)}
.index-tab[aria-selected="true"]::after{transform:scaleX(1)}
.index-tab .ix-no{color:var(--clay);margin-right:10px}

.index-panel{display:none}
.index-panel.active{display:block;animation:panelIn .6s var(--ease)}
@keyframes panelIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.price-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;
  gap:clamp(14px,2.4vw,32px);
  padding:clamp(20px,3vh,30px) 0;border-bottom:1px solid var(--line);
  position:relative;
}
.price-row>*{min-width:0}
.price-row .pr-no{font-family:var(--sans);font-size:11px;letter-spacing:.2em;color:var(--clay);padding-top:.7em}
.price-name{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(26px,3.6vw,46px);line-height:1.05;
  position:relative;display:inline-block;cursor:default;
}
.price-name::after{
  content:"";position:absolute;left:0;bottom:.04em;height:1px;width:100%;
  background:var(--ink);transform:scaleX(0);transform-origin:left center;
  transition:transform .55s var(--ease);
}
.price-row:hover .price-name::after,.price-name:focus-visible::after{transform:scaleX(1)}
.price-desc{font-size:13.5px;color:var(--muted);line-height:1.65;margin-top:8px;max-width:52ch}
.price-meta{display:flex;flex-direction:column;gap:6px;text-align:right;align-items:flex-end}
.price-fig{
  font-family:var(--serif);font-weight:300;font-size:clamp(24px,3vw,38px);
  line-height:1;white-space:nowrap;
}
.price-fig .from{font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px}
.price-dur{font-family:var(--sans);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay)}
/* hand-annotated note */
.price-note{
  font-family:var(--serif);font-style:italic;font-size:15px;color:var(--clay);
  position:relative;padding-left:24px;margin-top:4px;
}
.price-note::before{content:"❧";position:absolute;left:0;top:-2px;font-style:normal;color:var(--clay)}

/* =========================================================
   SERVICE CARDS (home preview tiles)
   ========================================================= */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc-grid>*{min-width:0}
.svc-card{
  background:var(--cream);padding:clamp(28px,3.5vw,52px);
  display:flex;flex-direction:column;gap:18px;min-height:clamp(260px,32vw,360px);
  position:relative;transition:background .5s var(--ease);
}
.svc-card:hover{background:var(--cream-2)}
.svc-card .svc-no{font-family:var(--sans);font-size:11px;letter-spacing:.24em;color:var(--clay)}
.svc-card h3{font-family:var(--serif);font-size:clamp(28px,3.6vw,46px);line-height:1.02}
.svc-card h3 .pen{display:inline-block}
.svc-card p{font-size:14px;color:var(--muted);line-height:1.7}
.svc-card .svc-foot{margin-top:auto;display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding-top:18px;border-top:1px solid var(--line)}
.svc-card .svc-price{font-family:var(--serif);font-size:clamp(20px,2.4vw,26px)}
.svc-card .svc-go{font-family:var(--sans);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--clay)}
.svc-figure{height:64px;margin-bottom:4px}
.svc-figure svg{height:100%;width:auto}

/* =========================================================
   LOOKBOOK SWATCHES + LIGHTBOX
   ========================================================= */
.look-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,2vw,28px);
}
.look-grid>*{min-width:0}
.look-item{
  position:relative;border:0;padding:0;cursor:pointer;background:transparent;
  display:block;overflow:hidden;
}
.look-frame{position:relative;width:100%;overflow:hidden;background:var(--oat)}
.look-frame::after{
  content:"";position:absolute;inset:0;background:rgba(26,22,20,0);
  transition:background .5s var(--ease);
}
.look-item:hover .look-frame::after,.look-item:focus-visible .look-frame::after{background:rgba(26,22,20,.12)}
.look-art{width:100%;height:100%;display:block}
.look-cap{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding:14px 2px 0;text-align:left;
}
.look-cap .lk-title{font-family:var(--serif);font-size:clamp(18px,2vw,24px);line-height:1.1}
.look-cap .lk-no{font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;color:var(--clay);white-space:nowrap}
.look-item .look-plus{
  position:absolute;top:14px;right:14px;width:34px;height:34px;
  border:1px solid var(--cream);color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:scale(.85);transition:opacity .4s var(--ease),transform .4s var(--ease);
  font-family:var(--sans);font-size:18px;line-height:1;mix-blend-mode:difference;
}
.look-item:hover .look-plus,.look-item:focus-visible .look-plus{opacity:1;transform:none}

/* spans */
.sp-3{grid-column:span 3}.sp-4{grid-column:span 4}.sp-5{grid-column:span 5}
.sp-6{grid-column:span 6}.sp-7{grid-column:span 7}.sp-8{grid-column:span 8}
.r-tall .look-frame{padding-bottom:128%}
.r-mid .look-frame{padding-bottom:84%}
.r-wide .look-frame{padding-bottom:64%}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:120;display:none;
  align-items:center;justify-content:center;
  padding:clamp(20px,5vw,72px);
  background:color-mix(in srgb,var(--ink) 86%,transparent);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.lightbox.open{display:flex;animation:lbIn .4s var(--ease)}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lb-stage{
  position:relative;width:min(960px,100%);max-height:88vh;
  display:grid;grid-template-columns:1fr;gap:0;
  background:var(--cream);border:1px solid var(--line-ink);
}
.lb-art{width:100%;aspect-ratio:4/3;background:var(--oat);overflow:hidden}
.lb-art svg{width:100%;height:100%}
.lb-info{padding:clamp(22px,3vw,40px);display:flex;flex-direction:column;gap:12px}
.lb-info .label{margin:0}
.lb-info h3{font-family:var(--serif);font-size:clamp(28px,4vw,44px);line-height:1}
.lb-info p{font-size:14px;color:var(--muted);line-height:1.7;max-width:54ch}
.lb-credit{display:flex;gap:20px;flex-wrap:wrap;padding-top:14px;border-top:1px solid var(--line);margin-top:4px}
.lb-credit div{display:flex;flex-direction:column;gap:3px}
.lb-credit .label{font-size:10px}
.lb-credit span{font-family:var(--serif);font-size:17px}
.lb-close{
  position:absolute;top:-1px;right:-1px;width:54px;height:54px;
  background:var(--ink);color:var(--cream);border:0;cursor:pointer;
  font-size:22px;display:flex;align-items:center;justify-content:center;z-index:3;
}
.lb-close:hover{background:var(--clay)}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border:1px solid var(--line);background:var(--cream);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:24px;color:var(--ink);z-index:3;
  transition:background .3s var(--ease),color .3s var(--ease);
}
.lb-nav:hover{background:var(--ink);color:var(--cream)}
.lb-prev{left:-24px}.lb-next{right:-24px}
.lb-count{font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;color:var(--clay)}

/* =========================================================
   TESTIMONIAL CAROUSEL
   ========================================================= */
.quotes{background:var(--ink);color:var(--cream)}
.quotes .sec-no{color:var(--clay)}
.quotes .label{color:var(--muted-ink)}
.quotes .rule,.quotes .rule-ink{background:var(--line-ink)}
.carousel{position:relative;overflow:hidden}
.carousel-track{display:flex;transition:transform .8s var(--ease)}
.quote-slide{flex:0 0 100%;min-width:0;padding:clamp(8px,2vw,24px) 0}
.quote-mark{font-family:var(--serif);font-style:italic;font-size:clamp(64px,12vw,140px);line-height:.6;color:var(--clay);height:.5em;margin-bottom:.2em}
.quote-text{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(24px,3.8vw,52px);line-height:1.22;letter-spacing:-.01em;
  max-width:24ch;
}
.quote-text .it{font-style:italic;color:var(--clay)}
.quote-by{margin-top:clamp(24px,4vh,44px);display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}
.quote-by .qb-name{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,26px)}
.quote-by .qb-meta{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-ink)}
.quote-by .qb-stars{color:var(--clay);letter-spacing:.2em;font-size:13px}
.carousel-ctrl{display:flex;align-items:center;gap:24px;margin-top:clamp(32px,5vh,56px)}
.car-btn{
  width:54px;height:54px;border:1px solid var(--line-ink);background:transparent;color:var(--cream);
  cursor:pointer;font-family:var(--serif);font-size:24px;
  display:flex;align-items:center;justify-content:center;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
}
.car-btn:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.car-dots{display:flex;gap:10px;margin-left:auto}
.car-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--muted-ink);background:transparent;cursor:pointer;padding:0;transition:background .3s var(--ease)}
.car-dot[aria-selected="true"]{background:var(--clay);border-color:var(--clay)}

/* =========================================================
   STYLISTS
   ========================================================= */
.stylist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,44px)}
.stylist-grid>*{min-width:0}
.stylist{display:flex;flex-direction:column;gap:18px}
.stylist-portrait{aspect-ratio:3/4;background:var(--oat);overflow:hidden;position:relative}
.stylist-portrait svg{width:100%;height:100%}
.stylist-no{position:absolute;top:14px;left:14px;font-family:var(--sans);font-size:11px;letter-spacing:.24em;color:var(--ink);mix-blend-mode:multiply}
.stylist h3{font-family:var(--serif);font-size:clamp(26px,3vw,36px);line-height:1}
.stylist .st-role{font-family:var(--sans);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--clay);margin-top:6px}
.stylist p{font-size:13.5px;color:var(--muted);line-height:1.7;margin-top:8px}
.stylist .st-spec{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.st-spec span{font-family:var(--sans);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);border:1px solid var(--line);padding:5px 10px}

/* =========================================================
   FAQ
   ========================================================= */
.faq{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{
  list-style:none;cursor:pointer;padding:clamp(22px,3.4vh,32px) 0;
  display:grid;grid-template-columns:auto 1fr auto;gap:clamp(14px,2.4vw,32px);align-items:baseline;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary>*{min-width:0}
.faq .fq-no{font-family:var(--sans);font-size:11px;letter-spacing:.2em;color:var(--clay)}
.faq .fq-q{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.8vw,34px);line-height:1.1}
.faq .fq-icon{width:18px;height:18px;position:relative;align-self:center}
.faq .fq-icon::before,.faq .fq-icon::after{content:"";position:absolute;background:var(--clay);transition:transform .4s var(--ease)}
.faq .fq-icon::before{top:50%;left:0;width:18px;height:1px;transform:translateY(-50%)}
.faq .fq-icon::after{left:50%;top:0;height:18px;width:1px;transform:translateX(-50%)}
.faq details[open] .fq-icon::after{transform:translateX(-50%) scaleY(0)}
.faq .fq-a{padding:0 0 clamp(22px,3.4vh,32px) 0;max-width:62ch}
.faq .fq-a p{font-size:15px;color:var(--muted);line-height:1.78}
.faq summary .fq-spacer{grid-column:1}

/* =========================================================
   BOOKING FORM (contact)
   ========================================================= */
.book-grid{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px)}
.book-form{display:grid;grid-template-columns:1fr;gap:0}
.field{position:relative;padding:18px 0 22px;border-bottom:1px solid var(--line)}
.field>label,.field .field-label{
  display:block;font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.22em;font-size:10.5px;color:var(--muted);margin-bottom:12px;
}
.field input,.field textarea,.field select{
  width:100%;border:0;background:transparent;
  font-family:var(--serif);font-weight:300;font-size:clamp(20px,2.4vw,26px);
  color:var(--ink);padding:4px 0;line-height:1.3;
}
.field input::placeholder,.field textarea::placeholder{color:var(--oat-deep);font-style:italic}
.field textarea{resize:vertical;min-height:90px}
.field select{appearance:none;cursor:pointer}
.field .field-msg{
  font-family:var(--sans);font-size:10.5px;letter-spacing:.1em;color:var(--clay);
  margin-top:8px;min-height:14px;opacity:0;transition:opacity .3s var(--ease);
}
.field.invalid{border-bottom-color:var(--clay)}
.field.invalid .field-msg{opacity:1}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,40px)}
.field-row>*{min-width:0}

/* stylist selector */
.stylist-pick{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:14px}
.stylist-pick>*{min-width:0}
.pick{
  position:relative;border:1px solid var(--line);padding:16px 18px;cursor:pointer;
  display:flex;flex-direction:column;gap:4px;
  transition:border-color .35s var(--ease),background .35s var(--ease);
}
.pick input{position:absolute;opacity:0;inset:0;width:100%;height:100%;cursor:pointer;margin:0}
.pick .pk-name{font-family:var(--serif);font-size:20px;line-height:1}
.pick .pk-role{font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.pick:has(input:checked){border-color:var(--ink);background:var(--cream-2)}
.pick:has(input:checked) .pk-name{color:var(--ink)}
.pick:has(input:focus-visible){outline:2px solid var(--clay);outline-offset:3px}
.pick .pk-tick{position:absolute;top:14px;right:16px;color:var(--clay);opacity:0;font-family:var(--serif);font-size:18px;transition:opacity .3s var(--ease)}
.pick:has(input:checked) .pk-tick{opacity:1}

.book-submit{margin-top:clamp(28px,4vh,40px);display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.book-submit .btn{min-width:240px;justify-content:center}
.book-note{font-size:12.5px;color:var(--muted);max-width:30ch;line-height:1.6}

.form-success{display:none;border:1px solid var(--line);padding:clamp(32px,5vw,56px);text-align:center}
.form-success.show{display:block;animation:panelIn .6s var(--ease)}
.form-success .fs-mark{font-family:var(--serif);font-size:clamp(48px,8vw,88px);color:var(--clay);line-height:1;margin-bottom:18px}
.form-success h3{font-family:var(--serif);font-size:clamp(30px,5vw,52px);margin-bottom:16px}
.form-success p{color:var(--muted);max-width:46ch;margin:0 auto 8px}
.form-success .fs-ref{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--clay);margin-top:18px}

/* =========================================================
   CONTACT INFO BLOCKS
   ========================================================= */
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,4vw,56px)}
.info-grid>*{min-width:0}
.info-block{padding-top:24px;border-top:1px solid var(--line)}
.info-block .label{margin-bottom:14px;display:block}
.info-block .big{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.6vw,30px);line-height:1.25}
.info-block .big a{position:relative}
.info-block p{font-size:14px;color:var(--muted);line-height:1.7;margin-top:6px}
.hours-list{list-style:none;margin:0;padding:0}
.hours-list li{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--line);font-size:14px}
.hours-list li:last-child{border-bottom:0}
.hours-list .hr-day{font-family:var(--sans);letter-spacing:.14em;text-transform:uppercase;font-size:11px;color:var(--muted)}
.hours-list .hr-time{font-family:var(--serif);font-size:18px}
/* self-contained SVG map sketch (no third-party embed) */
.map-frame{position:relative;border:1px solid var(--line);width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--cream-2)}
.map-frame svg{width:100%;height:100%;display:block}
.map-frame .mp-street{stroke:var(--line-2);fill:none}
.map-frame .mp-street-main{stroke:var(--oat-deep);fill:none}
.map-frame .mp-block{fill:var(--oat);opacity:.5}
.map-frame .mp-water{fill:var(--clay-soft)}
.map-frame .mp-pin{fill:var(--clay)}
.map-frame .mp-pin-ring{fill:none;stroke:var(--clay);opacity:.5;transform-origin:center;animation:mpPulse 2.8s var(--ease) infinite}
@keyframes mpPulse{0%{transform:scale(.4);opacity:.6}70%,100%{transform:scale(1.4);opacity:0}}
.map-frame .mp-label{
  position:absolute;left:18px;bottom:16px;
  background:var(--cream);border:1px solid var(--line);
  padding:10px 14px;display:flex;flex-direction:column;gap:2px;max-width:74%;
}
.map-frame .mp-label .mp-name{font-family:var(--serif);font-size:18px;line-height:1.05}
.map-frame .mp-label .mp-addr{font-family:var(--sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.map-frame .mp-link{
  position:absolute;top:14px;right:14px;
  font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);background:var(--cream);border:1px solid var(--line);padding:8px 12px;
  display:inline-flex;align-items:center;gap:8px;
  transition:background .35s var(--ease),color .35s var(--ease);
}
.map-frame .mp-link:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* =========================================================
   CTA STRIP
   ========================================================= */
.cta{background:var(--ink);color:var(--cream);text-align:center;padding:clamp(72px,13vh,160px) 0}
.cta .eyebrow{color:var(--clay);justify-content:center}
.cta h2{font-family:var(--serif);font-weight:300;font-size:clamp(52px,10vw,140px);line-height:.96;letter-spacing:-.015em;margin:clamp(20px,3vh,32px) 0}
.cta h2 .it{font-style:italic;color:var(--clay)}
.cta p{color:var(--muted-ink);max-width:44ch;margin:0 auto clamp(28px,4vh,40px);font-size:15px}
.cta .btn-on-ink{min-width:260px;justify-content:center}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--cream);border-top:1px solid var(--line);padding:clamp(56px,9vh,104px) 0 36px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(32px,5vw,64px);margin-bottom:clamp(48px,7vh,80px)}
.footer-top>*{min-width:0}
.foot-brand{font-family:var(--serif);font-weight:300;font-size:clamp(40px,6vw,72px);line-height:.92}
.foot-brand .amp{font-style:italic;color:var(--clay)}
.foot-brand .fb-sub{display:block;font-family:var(--sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:18px}
.foot-col h4{font-family:var(--sans);font-weight:400;text-transform:uppercase;letter-spacing:.24em;font-size:11px;color:var(--clay);margin-bottom:20px}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.foot-col a,.foot-col p{font-family:var(--serif);font-size:18px;color:var(--ink-2)}
.foot-col a{display:inline-block}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:32px;border-top:1px solid var(--line)}
.footer-bottom .label{font-size:10.5px}
.made{font-family:var(--sans);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.made a{color:var(--ink);position:relative}

/* =========================================================
   PAGE HEADER (interior pages)
   ========================================================= */
.page-head{padding:clamp(48px,8vh,104px) 0 clamp(40px,6vh,72px);position:relative}
.page-head .folio{margin-bottom:clamp(20px,3vh,28px)}
.page-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(52px,13vw,200px);line-height:.86;letter-spacing:-.02em;
  /* single word: keep it whole — no mid-word break during font swap */
  white-space:nowrap;max-width:100%;
  overflow-wrap:normal;word-break:keep-all;hyphens:none;
}
.page-title .it{font-style:italic;color:var(--clay)}
.page-head-foot{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:flex-end;margin-top:clamp(28px,4vh,44px)}
.page-head-foot .pd-lede{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2.2vw,26px);color:var(--ink-2);max-width:34ch;line-height:1.3}

/* about specifics */
.about-portrait{aspect-ratio:4/5;background:var(--oat);overflow:hidden;position:relative}
.about-portrait svg{width:100%;height:100%}
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,84px);align-items:center}
.about-split>*{min-width:0}
.about-prose p{font-family:var(--serif);font-size:clamp(18px,2.1vw,23px);line-height:1.55;color:var(--ink-2);margin-bottom:1.2em}
.about-prose p .it{font-style:italic;color:var(--clay)}
.about-prose .drop::first-letter{
  font-family:var(--serif);font-size:4.6em;line-height:.74;float:left;
  padding:.06em .12em 0 0;color:var(--clay);font-weight:300;
}
.timeline{list-style:none;margin:0;padding:0}
.timeline li{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,3vw,44px);padding:clamp(22px,3vh,32px) 0;border-bottom:1px solid var(--line)}
.timeline li>*{min-width:0}
.timeline .tl-year{font-family:var(--serif);font-size:clamp(28px,4vw,52px);line-height:1;color:var(--clay)}
.timeline .tl-body h4{font-family:var(--serif);font-size:clamp(20px,2.2vw,26px);margin-bottom:8px}
.timeline .tl-body p{font-size:14px;color:var(--muted);line-height:1.7}

.creed-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.creed-grid>*{min-width:0}
.creed{background:var(--cream);padding:clamp(28px,3.4vw,48px);display:flex;flex-direction:column;gap:14px}
.creed .cr-no{font-family:var(--sans);font-size:11px;letter-spacing:.24em;color:var(--clay)}
.creed h4{font-family:var(--serif);font-size:clamp(24px,2.8vw,34px);line-height:1.05}
.creed p{font-size:14px;color:var(--muted);line-height:1.72}

/* marquee strip (subtle) */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(20px,3vh,30px) 0;overflow:hidden}
.strip-track{display:flex;gap:clamp(28px,4vw,56px);white-space:nowrap;animation:marquee 36s linear infinite;align-items:baseline}
.strip-track span{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,30px);color:var(--ink-2);display:inline-flex;align-items:center;gap:clamp(28px,4vw,56px)}
.strip-track span::after{content:"✦";font-style:normal;color:var(--clay);font-size:.6em}
/* three identical sets -> translate one third for a seamless tile on wide screens */
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-33.3333%)}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .footer-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1 / -1}
  .stylist-grid{grid-template-columns:repeat(2,1fr)}
  .statement-cols{grid-template-columns:1fr;gap:28px}
  .statement-cols .stat-col{padding-top:24px;border-top:1px solid var(--line)}
}
@media (max-width:880px){
  .nav-links,.nav-cta .btn{display:none}
  .hamburger{display:flex}
  .mobile-menu{display:flex}
  .about-split{grid-template-columns:1fr;gap:36px}
  .hero-foot{grid-template-columns:1fr;gap:18px;text-align:center}
  .hero-foot .rule{display:none}
  .hero-meta,.hero-meta.left{text-align:center}
}
@media (max-width:720px){
  /* botanical was hand-tuned to thread the desktop word; below this it floats — fade it back to a faint trace */
  .hero-botanical{opacity:.3}
  .svc-grid{grid-template-columns:1fr}
  .creed-grid{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr}
  .stylist-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr;gap:0}
  .stylist-pick{grid-template-columns:1fr}
  .sec-head{grid-template-columns:1fr;gap:14px}
  .price-row{grid-template-columns:1fr;gap:6px}
  .price-row .pr-no{display:none}
  .price-meta{text-align:left;align-items:flex-start;margin-top:8px}
  .lb-prev{left:6px}.lb-next{right:6px}
  .lb-nav{background:color-mix(in srgb,var(--cream) 90%,transparent)}
  .footer-top{grid-template-columns:1fr}
  /* lookbook collapses to a simple 2-up then 1-up */
  .look-grid{grid-template-columns:repeat(2,1fr)}
  .sp-3,.sp-4,.sp-5,.sp-6,.sp-7,.sp-8{grid-column:span 1}
  .r-tall .look-frame,.r-mid .look-frame,.r-wide .look-frame{padding-bottom:118%}
}
@media (max-width:420px){
  .look-grid{grid-template-columns:1fr}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;
  }
  .reveal{opacity:1;transform:none}
  .lt{opacity:1;transform:none}
  .hero-botanical .stem{stroke-dashoffset:0}
  .hero-botanical .leaf{opacity:.55}
  .hero-scroll .tick::after{display:none}
  .strip-track{animation:none}
  .carousel-track{transition:none}
}
