/* Universal reset — home.css is loaded standalone (not after site.css), so the
   browser default body margin:8px and other default margins/padding would
   otherwise apply. This matches the *{margin:0;padding:0;box-sizing:border-box}
   reset that site.css has. Without it, body shrinks by 16px horizontally,
   pushing all content (incl. the injected footer) inward and making the home
   footer ~16px narrower / ~28px taller than every other page's footer. */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body.home-page{
  --ivory:#FAF8F5;
  --beige:#F0EBE3;
  --beige-deep:#E6DFD4;
  --ink:#18160F;
  --ink-muted:#4A443B;
  --charcoal:#1c1915;
  --gold:#B8955C;
  --gold-text:#8A6A2E;
  --border:rgba(24,22,15,0.14);
  --border-card:rgba(24,22,15,0.2);
  --radius:12px;
  --shell:1240px;
  --ease-out:cubic-bezier(.22,1,.36,1);
  --fd:'Cormorant Garamond',Georgia,serif;
  --fb:'Jost',sans-serif;
  --marble-grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.032 0.068' numOctaves='5' seed='11'/%3E%3CfeColorMatrix values='0 0 0 0 0.97 0 0 0 0 0.94 0 0 0 0 0.88 0 0 0 0.2 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  --marble-veins:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='480' height='480'%3E%3Cfilter id='v'%3E%3CfeTurbulence type='turbulence' baseFrequency='0.012 0.045' numOctaves='3' seed='42'/%3E%3CfeColorMatrix values='0 0 0 0 0.77 0 0 0 0 0.66 0 0 0 0 0.42 0 0 0 0.28 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23v)'/%3E%3C/svg%3E");
  --texture-linen:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64'%3E%3Cpath d='M0 32h64M32 0v64' stroke='%23c4a96b' stroke-width='.35' opacity='.12'/%3E%3Cpath d='M0 0l64 64M64 0L0 64' stroke='%23a88d50' stroke-width='.2' opacity='.06'/%3E%3C/svg%3E");
  --texture-paper:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='p'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.08 0.12' numOctaves='4' seed='3'/%3E%3CfeColorMatrix values='0 0 0 0 0.92 0 0 0 0 0.88 0 0 0 0 0.82 0 0 0 0.18 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23p)'/%3E%3C/svg%3E");
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--fb);
  font-weight:400;
  line-height:1.65;
  overflow-x:clip;
}
body.home-page .home-shell{
  box-sizing:border-box;
  width:min(var(--shell),100%);
  margin:0 auto;
  padding:0 clamp(40px,5vw,64px);
}
body.home-page .kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:14px;
}
body.home-page .kicker::before{content:'';width:24px;height:1px;background:var(--gold)}
body.home-page .h-serif{font-family:var(--fd);font-weight:400;line-height:1.08;color:var(--ink);text-wrap:balance}
body.home-page .h-serif em{font-style:italic;color:var(--gold-text)}
body.home-page .lead{color:var(--ink-muted);font-size:17px;line-height:1.75;max-width:46ch}
body.home-page .btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--fb);font-size:11px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;text-decoration:none;
  padding:14px 28px;border-radius:var(--radius);transition:background .25s,color .25s,border-color .25s,transform .16s var(--ease-out);
}
body.home-page .btn-primary{background:var(--ink);color:#fff;border:1px solid var(--ink)}
body.home-page .btn-primary:hover{background:#2a2720;transform:translateY(-1px)}
body.home-page .btn-outline{background:transparent;color:var(--ink);border:1px solid rgba(24,22,15,.38)}
body.home-page .btn-outline:hover{border-color:var(--ink);transform:translateY(-1px)}
body.home-page .btn:active{transform:scale(.97)}
body.home-page .section{padding:clamp(48px,6vw,72px) 0}
body.home-page .section-head{text-align:center;max-width:560px;margin:0 auto 40px}
body.home-page .section-head .h-serif{font-size:clamp(36px,4.4vw,60px);letter-spacing:-.01em}
body.home-page #services.section{padding-block:clamp(72px,8vw,88px)}
body.home-page #story.section{padding-block:clamp(80px,9vw,96px)}
body.home-page #stylists.section{padding-block:clamp(72px,8vw,88px)}
body.home-page .home-shell.section{padding:clamp(64px,7vw,80px) clamp(40px,5vw,64px)}
body.home-page .section-head .h-serif,
body.home-page .home-amenities-head .h-serif,
body.home-page .home-story-copy .h-serif,
body.home-page .home-convert-col .h-serif{font-weight:600}
body.home-page .home-review-src{display:block;margin-top:8px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-style:normal}

body.home-page #siteHeaderBar .announce{
  background:var(--ink);color:#fff;font-size:12px;letter-spacing:.06em;
  text-transform:none;padding:10px 20px;
}
body.home-page #siteHeaderBar .announce a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
body.home-page #siteHeaderBar nav{
  background:rgba(250,248,245,.98);border-bottom:1px solid var(--border);
  backdrop-filter:blur(12px);
}
body.home-page #siteHeaderBar .nav-left a,
body.home-page #siteHeaderBar .nav-right a{color:var(--ink-muted);font-weight:500;font-size:11px}
body.home-page #siteHeaderBar .nav-left a:hover,
body.home-page #siteHeaderBar .nav-right a:hover{color:var(--ink)}
body.home-page #siteHeaderBar .nav-book{
  background:var(--ink)!important;color:#fff!important;border-radius:var(--radius)!important;
}
body.home-page #siteHeaderBar .nav-book:hover{background:#2a2720!important;color:#fff!important}

.home-hero{
  margin:0 calc(50% - 50vw) clamp(56px,7vw,72px);width:100vw;
  /* Audit P1 #2: subtract --site-header-h so hero+header fills viewport, no scroll-past-fold.
     svh handles mobile address-bar show/hide without layout jump. */
  min-height:clamp(480px,calc(88svh - var(--site-header-h,128px)),720px);
  display:flex;align-items:center;overflow:hidden;
  /* Strong left-to-right panel so the copy sits on a dark area, not over the
     team. Photo focus shifted right (68%) so faces land in the clear zone. */
  background-image:
    linear-gradient(95deg,rgba(13,10,7,.95) 0%,rgba(13,10,7,.9) 44%,rgba(13,10,7,.58) 60%,rgba(13,10,7,.2) 80%,rgba(13,10,7,0) 100%),
    url('/assets/staff/hero-team.webp');
  background-position:68% 20%,68% 20%;
  background-size:cover,cover;
  background-attachment:scroll,scroll;
  background-repeat:no-repeat,no-repeat;
}
.home-hero-copy{
  display:block;width:100%;max-width:none;padding:clamp(64px,11vh,128px) 0;
}
.home-hero-text{max-width:640px}
body.home-page .home-hero-copy .kicker{color:#E8D9BC}
body.home-page .home-hero-copy .kicker::before{background:#E8D9BC}
body.home-page .home-hero-copy .h-serif{font-size:clamp(48px,6.4vw,92px);line-height:1.0;margin-bottom:22px;color:#FAF8F5;letter-spacing:-.01em}
body.home-page .home-hero-copy .h-serif em{color:#E8D9BC;font-style:italic;text-decoration:none}
.home-hero-merge{font-family:var(--fb);font-size:clamp(13px,1.6vw,15px);letter-spacing:.06em;color:rgba(232,217,188,.92);margin:-8px 0 18px;max-width:46ch;line-height:1.55;font-weight:400}
body.home-page .home-hero-copy .lead{color:rgba(250,248,245,.9);font-size:18px;max-width:42ch}
.home-section-intro{color:var(--ink-muted);font-size:16px;line-height:1.75;max-width:58ch;margin-top:14px}
.home-hero-info{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:10px;font-size:14.5px;letter-spacing:.03em;color:rgba(250,248,245,.95)}
.home-hero-info span{display:inline-flex;align-items:center}
.home-hero-info span+span::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--gold);margin-right:16px}
.home-hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 28px}
.home-hero-mobile-actions{display:none;flex-wrap:wrap;gap:10px;margin:0 0 20px}
.home-hero-mobile-actions .btn{min-height:48px;flex:1;min-width:140px;text-align:center}
@media(max-width:768px){.home-hero-mobile-actions{display:flex}}
body.home-page .home-hero .btn-primary{background:#fff;color:var(--ink);border-color:#fff}
body.home-page .home-hero .btn-primary:hover{background:#E8D9BC;border-color:#E8D9BC}
body.home-page .home-hero .btn-outline{color:#fff;border-color:rgba(255,255,255,.55)}
body.home-page .home-hero .btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.12)}
.home-hero-meta{display:flex;flex-wrap:wrap;gap:14px;max-width:none;margin-top:6px}
.home-hero-meta .meta-card{
  display:flex;gap:10px;align-items:center;padding:12px 18px;
  background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.4);border-radius:var(--radius);
}
.home-hero-meta .meta-card svg{flex-shrink:0;color:var(--gold);margin-top:2px}
.home-hero-meta strong{display:block;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:4px}
.home-hero-meta span{font-size:13px;color:var(--ink-muted);line-height:1.45}

.home-stats{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:0;padding:clamp(40px,5vw,48px) 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.home-stat{
  text-align:center;padding:4px clamp(28px,5vw,72px);background:none;border:0;border-radius:0;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.home-stat+.home-stat{border-left:1px solid var(--border)}
.home-stat-icon{display:none}
.home-stat-num{font-family:var(--fd);font-style:italic;font-size:clamp(36px,3.6vw,50px);line-height:1;color:var(--ink)}
.home-stat-label{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted)}

.home-services-grid{
  display:grid;grid-template-columns:repeat(6,minmax(0,1fr));
  column-gap:clamp(28px,3vw,48px);row-gap:0;
}
/* Editorial layout: 2 / 3 staggered rows (5 services) */
.home-svc:nth-child(1){grid-column:2/span 2}
.home-svc:nth-child(2){grid-column:4/span 2}
.home-svc:nth-child(3){grid-column:1/span 2}
.home-svc:nth-child(4){grid-column:3/span 2}
.home-svc:nth-child(5){grid-column:5/span 2}
.home-svc{
  background:none;border:0;border-top:1px solid var(--border);border-radius:0;
  padding:clamp(20px,1.8vw,26px) 0;display:grid;grid-template-columns:auto 1fr auto;
  column-gap:14px;row-gap:6px;align-items:baseline;
}
.home-svc-icon{grid-column:1;grid-row:1/span 2;align-self:center;color:var(--gold-text);width:22px;height:22px}
.home-svc h3{grid-column:2;grid-row:1;font-family:var(--fd);font-size:clamp(21px,1.7vw,26px);font-weight:500;line-height:1.1;color:var(--ink);margin:0}
.home-svc-price{grid-column:3;grid-row:1;justify-self:end;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-text);font-weight:600}
.home-svc p{grid-column:2/4;grid-row:2;font-size:14px;color:var(--ink-muted);line-height:1.6;margin:0}

/* Audit P1 #3: intermediate breakpoint between pyramid (6-col) and 2-col stack.
   At 1080-1280px the pyramid would put titles+price in fight for narrow cards,
   so step down to a clean 3-col before the final 2-col cascade at 1080. */
@media(max-width:1280px) and (min-width:1081px){
  .home-services-grid{grid-template-columns:repeat(3,minmax(0,1fr));column-gap:clamp(24px,2.6vw,40px)}
  .home-svc:nth-child(n){grid-column:span 1}
}
.home-services-cta{text-align:center;margin-top:32px}

.home-band-beige{
  background:var(--beige);
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
  width:100vw;padding:clamp(64px,7vw,80px) 0;
}
.home-amenities-head{max-width:480px;margin-bottom:24px}
.home-amenities-head .h-serif{font-size:clamp(28px,3.2vw,40px)}
.home-amenities-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2vw,24px);align-items:stretch}
.home-amenity{
  background:#fff;border:1px solid var(--border-card);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;height:100%;
}
.home-amenity-photo{height:clamp(280px,28vw,360px);overflow:hidden;background:var(--beige-deep);flex-shrink:0}
.home-amenity-photo img{width:100%;height:100%;object-fit:cover;display:block}
.home-amenity-body{padding:24px 22px 26px;flex:1;display:flex;flex-direction:column}
.home-amenity-body h3{font-family:var(--fd);font-size:22px;font-weight:500;margin-bottom:8px}
.home-amenity-body p{font-size:15px;color:var(--ink-muted);line-height:1.65}

.home-shell.home-story{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);
  gap:clamp(40px,5vw,80px);align-items:center;
}
.home-story-gallery{display:grid;grid-template-columns:1.3fr 1fr;grid-template-rows:1fr 1fr;gap:12px;height:clamp(380px,40vw,500px)}
.home-story-gallery .cell{overflow:hidden;border-radius:var(--radius);background:var(--beige-deep)}
.home-story-gallery .cell:first-child{grid-row:1/span 2}
.home-story-gallery img{width:100%;height:100%;object-fit:cover;display:block}
.home-story-copy{text-align:left}
.home-story-copy .h-serif{font-size:clamp(38px,4.4vw,62px);margin-bottom:22px;line-height:1.04}
.home-story-copy p{color:var(--ink-muted);font-size:17px;margin-bottom:16px;line-height:1.85;max-width:54ch}
.home-story-copy .btn{margin-top:12px}

.home-stylists-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(18px,2vw,26px)}
.home-stylist{
  text-align:left;padding:0;background:#fff;overflow:hidden;
  border:1px solid var(--border-card);border-radius:var(--radius);
  transition:box-shadow .3s var(--ease-out),transform .3s var(--ease-out),border-color .3s;
}
.home-stylist:hover{border-color:rgba(184,149,92,.45);box-shadow:0 16px 38px rgba(24,22,15,.09);transform:translateY(-3px)}
.home-stylist img{
  width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;object-position:center top;
  display:block;border:0;
}
.home-stylist-body{padding:20px 20px 22px}
.home-stylist h3{font-family:var(--fd);font-size:23px;font-weight:500;margin-bottom:4px}
.home-stylist-role{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-text);margin-bottom:10px}
.home-stylist-note{font-size:14.5px;color:var(--ink-muted);line-height:1.6;margin-bottom:14px;min-height:3em}
.home-stylist-link{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;border-bottom:1px solid rgba(24,22,15,.25);
  padding-bottom:2px;transition:border-color .2s,color .2s;
}
.home-stylist-link:hover{color:var(--gold);border-color:var(--gold)}
.home-stylists-cta{text-align:center;margin-top:28px}

/* Client work gallery */
.home-work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.4vw,18px)}
.home-work{position:relative;margin:0;overflow:hidden;border-radius:var(--radius);background:var(--beige-deep);aspect-ratio:4/5}
.home-work img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .7s var(--ease-out)}
.home-work:hover img{transform:scale(1.05)}
@media(max-width:1080px){.home-work-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.home-work-grid{grid-template-columns:1fr 1fr;gap:8px}}

.home-reviews{
  background:var(--ink);color:#fff;
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
  width:100vw;padding:clamp(56px,6vw,76px) 0;
}
.home-reviews .section-head .kicker{color:var(--gold)}
.home-reviews .section-head .kicker::before{background:var(--gold)}
.home-reviews .section-head .h-serif{color:#fff;margin:0}
.home-reviews .section-head .h-serif em{color:var(--gold)}
body.home-page .home-reviews .section-head{text-align:left;max-width:none;margin:0 0 clamp(28px,3vw,42px);display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:20px}
.home-reviews-meta{display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.home-reviews-rating{font-size:14px;color:rgba(255,255,255,.85)}
.home-reviews-rating span{color:var(--gold);letter-spacing:.14em;margin-right:6px}
.home-reviews-readall{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(184,149,92,.45);padding-bottom:3px;transition:color .2s,border-color .2s}
.home-reviews-readall:hover{color:#fff;border-color:#fff}
/* Condensed editorial: borderless quote columns separated by hairline rules with a
   short gold tick, uniform weight (no oversized featured card). */
.home-reviews-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:clamp(28px,3.4vw,52px);row-gap:clamp(30px,3vw,46px)}
.home-review{
  position:relative;margin:0;background:none;border:0;border-radius:0;
  padding:26px 0 0;display:flex;flex-direction:column;
  border-top:1px solid rgba(255,255,255,.16);
}
.home-review::before{content:"";position:absolute;top:-1px;left:0;width:34px;height:1px;background:var(--gold)}
.home-review-stars{color:var(--gold);font-size:12px;letter-spacing:.22em;margin:0 0 14px}
.home-review q{
  display:block;font-family:var(--fd);font-style:italic;font-weight:400;
  font-size:clamp(17px,1.4vw,21px);line-height:1.5;color:rgba(255,255,255,.92);
  margin:0 0 18px;flex:1;
}
.home-review cite{display:block;font-style:normal;font-size:12px;letter-spacing:.04em;color:rgba(255,255,255,.66);margin:0}

.home-convert{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,28px)}
.home-convert-col{padding:clamp(36px,3.4vw,52px);border:1px solid var(--border-card);border-radius:16px;background:#fff}
.home-convert-col .h-serif{font-size:clamp(28px,2.6vw,40px);margin-bottom:16px}
.home-convert-col p{font-size:15px;color:var(--ink-muted);line-height:1.7;margin-bottom:8px}
.home-visit-addr{font-style:normal;font-size:16px;line-height:1.5;color:var(--ink)}
.home-visit-phone{font-size:16px;color:var(--ink);text-decoration:none;border-bottom:1px solid rgba(24,22,15,.28);padding-bottom:2px;transition:border-color .2s}
.home-visit-phone:hover{border-color:var(--ink)}
.home-visit-hours{width:100%;max-width:300px}
.home-visit-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.home-hours-mini{width:100%;border-collapse:collapse;font-size:14px}
.home-hours-mini th{font-weight:500;text-align:left;color:var(--ink);padding:5px 0;white-space:nowrap}
.home-hours-mini td{text-align:right;color:var(--ink-muted);padding:5px 0;font-variant-numeric:tabular-nums}
.home-hours-mini tr+tr th,.home-hours-mini tr+tr td{border-top:1px solid var(--border-card)}
.home-visit{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:18px}
body.home-page .home-visit>*{margin:0}
.home-book{background:var(--ink);border-color:var(--ink);display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px}
body.home-page .home-book .h-serif{color:#fff}
body.home-page .home-book .h-serif em{color:var(--gold)}
.home-book p{color:rgba(255,255,255,.8)}
.home-book-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.home-book-giftlink{margin-top:16px;font-size:13px;letter-spacing:.03em;color:rgba(255,255,255,.72);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.32);padding-bottom:2px;transition:color .2s,border-color .2s}
.home-book-giftlink:hover{color:#fff;border-color:#fff}
body.home-page .home-book .btn-primary{background:#fff;color:var(--ink);border-color:#fff}
body.home-page .home-book .btn-primary:hover{background:#E8D9BC;border-color:#E8D9BC}

/* Reveal-on-scroll: visible by default. Only hidden once JS confirms it can
   reveal (.js-reveal class on <html>, set by inline head script with a 2.5s
   failsafe timer). Prevents content from being stuck invisible if the
   IntersectionObserver hiccups, the tab is throttled, or JS errors out. */
.home-reveal{opacity:1;transform:none}
.js-reveal .home-reveal{opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
.js-reveal .home-reveal.vis{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  body.home-page .home-reveal{transition-duration:.001ms;transform:none}
  body.home-page .btn:hover,body.home-page .btn:active{transform:none}
  body.home-page .home-hero{background-attachment:scroll,scroll}
}

/* On phones the copy is full-width, so a left-to-right panel can't cover it.
   Use a vertical scrim instead: dark through the text zone (top ~70%), photo
   reading lower down. */
@media(max-width:640px){
  .home-hero{
    background-image:
      linear-gradient(179deg,rgba(13,10,7,.93) 0%,rgba(13,10,7,.9) 50%,rgba(13,10,7,.7) 72%,rgba(13,10,7,.52) 100%),
      url('/assets/staff/hero-team.webp');
    background-position:50% 12%,50% 12%;
  }
}

@media(max-width:1080px){
  body.home-page .home-shell{padding:0 24px}
  body.home-page .home-shell.section{padding-inline:24px}
  .home-hero{margin:0 calc(50% - 50vw) clamp(40px,6vw,56px);min-height:clamp(440px,calc(72svh - var(--site-header-h,128px)),580px)}
  .home-hero-copy{padding:clamp(48px,9vh,96px) 0}
  .home-services-grid{grid-template-columns:repeat(2,minmax(0,1fr));column-gap:clamp(20px,3vw,40px)}
  .home-svc:nth-child(n){grid-column:span 1}
  /* On narrow cards the price would crowd the title — stack price below title instead. */
  .home-svc{grid-template-columns:auto 1fr}
  .home-svc h3{grid-column:2;grid-row:1}
  .home-svc-price{grid-column:2;grid-row:2;justify-self:start;margin-top:2px}
  .home-svc p{grid-column:2;grid-row:3;margin-top:6px}
  .home-svc-icon{grid-row:1/span 3;align-self:start;margin-top:4px}
  .home-amenities-grid{grid-template-columns:1fr}
  .home-shell.home-story{grid-template-columns:1fr;gap:32px}
  .home-story-copy{text-align:center}
  .home-story-copy p{margin-inline:auto}
  .home-story-gallery{height:clamp(320px,52vw,440px)}
  .home-stylists-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .home-reviews-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .home-convert{grid-template-columns:1fr}
}
@media(max-width:600px){
  body.home-page .home-shell{padding:0 18px}
  body.home-page .home-shell.section{padding-inline:18px}
  .home-stats{flex-direction:column}
  .home-stat{padding:18px 0}
  .home-stat+.home-stat{border-left:0;border-top:1px solid var(--border)}
  .home-stylists-grid{grid-template-columns:1fr 1fr}
  .home-reviews-grid{grid-template-columns:1fr}
  .home-story-gallery{grid-template-columns:1fr 1fr}
  .home-book-actions .btn{flex:1}
  .home-services-grid{grid-template-columns:1fr;column-gap:0}
}

/* Keep at least 2 stylists per row even on the narrowest phones (per request —
   a full-screen card is too much). Cards run ~150px, so tighten the gap/padding
   and trim the name + note type; keep the enlarged "Book with X" tap target. */
@media(max-width:480px){
  .home-stylists-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .home-stylist-body{padding:14px 14px 16px}
  .home-stylist h3{font-size:18px}
  .home-stylist-note{font-size:12.5px}
  .home-stylist-link{display:inline-flex;align-items:center;min-height:44px;padding:10px 0}
}

/* Marble textures — home page only. Reuses the same feTurbulence SVG
   engine as salon-textures.css; mirrors the /alt/ redesign treatment.
   Fixed wash sits behind content (z-index:-1); per-component overlays
   add a faint multiply veil. No image assets, no markup changes. */
body.home-page::before,
body.home-page::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:-1}
body.home-page::before{
  background:
    radial-gradient(ellipse 120% 80% at 50% -10%,rgba(232,217,188,.5),transparent 60%),
    radial-gradient(ellipse 95% 60% at 100% 4%,rgba(184,149,92,.12),transparent 55%),
    radial-gradient(ellipse 85% 60% at 0% 72%,rgba(184,149,92,.08),transparent 55%),
    radial-gradient(ellipse 145% 108% at 50% 44%,transparent 50%,rgba(120,96,54,.13) 100%),
    linear-gradient(168deg,var(--ivory) 0%,#F2ECDF 38%,var(--beige) 72%,var(--beige-deep) 100%);
}
body.home-page::after{
  background-image:
    linear-gradient(125deg,transparent 36%,rgba(184,149,92,.10) 47%,transparent 57%),
    linear-gradient(32deg,transparent 40%,rgba(232,217,188,.13) 50%,transparent 60%),
    var(--marble-veins),
    var(--marble-veins),
    var(--marble-grain);
  background-size:auto,auto,760px 760px,420px 420px,210px 210px;
  opacity:.5;mix-blend-mode:multiply;
}

.home-hero-meta .meta-card,
.home-stat,
.home-svc,
.home-amenity{position:relative;overflow:hidden}
.home-hero-meta .meta-card::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  opacity:.2;mix-blend-mode:multiply;
  background-image:var(--texture-paper),var(--marble-grain);
  background-size:200px 200px,160px 160px;
}
.home-amenity::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  opacity:.18;mix-blend-mode:multiply;
  background-image:var(--marble-veins),var(--marble-grain);
  background-size:480px 480px,200px 200px;
}

.home-band-beige{position:relative;overflow:hidden}
.home-band-beige::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  opacity:.3;mix-blend-mode:multiply;
  background-image:var(--texture-linen),var(--marble-grain);
  background-size:64px 64px,200px 200px;
}

/* Keep card content crisp above the marble veil (content rides z-index:1) */
.home-hero-meta .meta-card > *,
.home-stat > *,
.home-svc > *,
.home-amenity > *,
.home-band-beige > *{position:relative;z-index:1}

.home-story-gallery .cell{position:relative}
.home-story-gallery .cell::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  opacity:.14;mix-blend-mode:multiply;
  background-image:var(--texture-paper),var(--marble-grain);
  background-size:200px 200px,180px 180px;
}
