﻿/* Maxima Hair shared site.css v1 */
body.has-mobile-actions{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}
@media(min-width:1081px){body.has-mobile-actions{padding-bottom:0}}
/* .mobile-action-bar styling moved to site-components.js COMPONENT_CSS so the
   component is self-contained (the markup is injected there too); shared with
   home page which doesn't load this file. */
/* .home-hero-mobile-actions was an orphan here — only used inside index.html
   which loads home.css (not this file). Live rules are in home.css. */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--cream:#F6F1EB;--cream-deep:#EDE5DA;--warm-white:#FDFAF6;--charcoal:#18160F;--charcoal2:#2C2A22;--mid:#7A756A;--light:#B0A99E;--gold:#C4A96B;--gold-dim:#A88D50;--gold-pale:#E8D9BC;--nav-h:80px;--fd:'Cormorant Garamond',Georgia,serif;--fb:'Jost',sans-serif}
html{scroll-behavior:smooth}
body{background:transparent;color:var(--charcoal);font-family:var(--fb);font-weight:300;line-height:1.7;overflow-x:hidden;position:relative;z-index:1;min-height:100vh}


.announce{background:var(--charcoal);color:var(--gold-pale);text-align:center;font-size:12px;letter-spacing:.18em;text-transform:uppercase;padding:10px 20px}
.announce a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
nav{position:sticky;top:0;height:var(--nav-h);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 56px;background:rgba(253,250,246,.97);backdrop-filter:blur(16px);border-bottom:1px solid rgba(196,169,107,.2);z-index:200;transition:box-shadow .3s}
nav.scrolled{box-shadow:0 2px 32px rgba(24,22,15,.08)}



.page-hero{background:radial-gradient(ellipse 85% 65% at 70% 20%,rgba(196,169,107,.12),transparent 50%),linear-gradient(168deg,#242018 0%,#18160f 55%,#12100c 100%);padding:96px 72px 80px;position:relative;overflow:hidden}
.eyebrow-hero{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:400;opacity:0;animation:fadeUp .7s .2s forwards}
.eyebrow-hero::before{content:'';display:block;width:28px;height:1px;background:var(--gold)}
.page-hero h1{font-family:var(--fd);font-size:clamp(44px,5vw,80px);font-weight:300;line-height:1.05;color:var(--warm-white);margin-bottom:24px;opacity:0;animation:fadeUp .7s .35s forwards}
.page-hero h1 em{font-style:italic;color:var(--gold)}
.page-hero p{font-size:15px;color:rgba(255,255,255,.5);max-width:520px;line-height:1.85;font-weight:300;opacity:0;animation:fadeUp .7s .5s forwards}
.page-hero-merge{font-size:clamp(14px,1.5vw,16px);color:rgba(232,217,188,.88);max-width:520px;line-height:1.6;margin-bottom:16px;font-weight:400;letter-spacing:.02em;opacity:0;animation:fadeUp .7s .44s forwards}


.breadcrumb{background:linear-gradient(158deg,rgba(253,250,246,.95) 0%,var(--cream-deep) 45%,#e0d4c4 100%);padding:14px 72px;border-bottom:1px solid rgba(24,22,15,.08);display:flex;align-items:center;gap:8px;font-size:12px;color:var(--mid)}
.breadcrumb a{color:var(--mid);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--charcoal)}
.breadcrumb span{color:var(--light)}


.eyebrow{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:400}
.eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--gold);flex-shrink:0}
h2.section-title{font-family:var(--fd);font-size:clamp(34px,3.5vw,58px);font-weight:300;line-height:1.1;color:var(--charcoal)}
.section-title em{font-style:italic;color:var(--gold-dim)}
section.reviews-section>h2.section-title{color:var(--charcoal);margin-bottom:64px}
section.reviews-section>h2.section-title em{color:var(--gold-dim)}
.btn-dark{display:inline-block;text-align:center;background:var(--charcoal);color:var(--warm-white);font-family:var(--fb);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;padding:15px 36px;transition:background .25s,transform .15s}
.btn-dark:hover{background:var(--gold-dim);transform:translateY(-1px)}
.btn-outline{display:inline-block;text-align:center;border:1px solid rgba(24,22,15,.2);color:var(--charcoal);font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;padding:14px 36px;transition:border-color .2s,background .2s}
.btn-outline:hover{border-color:var(--gold);background:rgba(196,169,107,.05)}
.r{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.r.vis{opacity:1;transform:none}
.r2{opacity:0;transform:translateY(20px);transition:opacity .7s .15s ease,transform .7s .15s ease}
.r2.vis{opacity:1;transform:none}
.r3{opacity:0;transform:translateY(20px);transition:opacity .7s .3s ease,transform .7s .3s ease}
.r3.vis{opacity:1;transform:none}


.story-split{display:grid;grid-template-columns:1fr 1fr;min-height:600px}
.story-media{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:3px;background:var(--charcoal)}
.story-cell{overflow:hidden;background:var(--cream-deep)}
.story-cell:first-child{grid-row:span 2}
.story-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s ease;filter:brightness(.97) saturate(.9)}
.story-cell:hover img{transform:scale(1.04);filter:brightness(1) saturate(1)}
.story-body{background:linear-gradient(152deg,#fdfbf7 0%,var(--cream) 40%,#e8dfd0 100%);display:flex;flex-direction:column;justify-content:center;padding:clamp(56px,6vw,96px) clamp(40px,5vw,80px)}
/* Constrain heading + body copy line measure for readability. Heading at ~14ch
   gives a clean 2-line break; paragraphs at ~52ch (~390px) is the comfortable
   reading width and lets the right side of the column breathe instead of
   running to the padded edge. */
.story-body h2.section-title{max-width:14ch}
.story-body p{font-size:15px;color:var(--mid);line-height:1.9;margin-bottom:20px;font-weight:300;max-width:52ch}
.story-body p:last-of-type{margin-bottom:40px}
.story-body .btn-dark{align-self:flex-start}


.team-section{padding:80px 72px 120px;background:transparent}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:64px}
.team-card{text-align:center}
.team-photo{width:100%;height:auto;display:block;background:var(--cream-deep);transition:filter .3s;filter:saturate(.85)}
.team-card:hover .team-photo{filter:saturate(1)}
.team-placeholder{width:100%;aspect-ratio:3/4;background:var(--cream-deep);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-family:var(--fd);font-size:64px;font-weight:300;color:rgba(196,169,107,.35)}
.team-name{font-family:var(--fd);font-size:22px;font-weight:400;color:var(--charcoal);margin-bottom:4px}
.team-role{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;font-weight:400}
.team-bio{font-size:13px;color:var(--mid);line-height:1.7}


.info-strip{display:grid;grid-template-columns:1fr 1fr 1fr;border-top:1px solid rgba(24,22,15,.08);border-bottom:1px solid rgba(24,22,15,.08);background:linear-gradient(158deg,rgba(253,250,246,.98) 0%,var(--cream-deep) 42%,#e3d8c9 100%)}
.info-cell{padding:56px 48px;border-right:1px solid rgba(24,22,15,.08);transition:background .3s}
.info-cell:last-child{border-right:none}
.info-cell:hover{background:var(--cream)}
.info-cell h3{font-family:var(--fd);font-size:26px;font-weight:400;color:var(--charcoal);margin-bottom:16px}
.info-cell p,.info-cell address{font-size:14px;color:var(--mid);line-height:1.8;font-style:normal}
.info-cell a{color:var(--gold-dim);text-decoration:none;font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-top:16px;display:inline-block;transition:color .2s}
.info-cell a:hover{color:var(--charcoal)}


.hours-tbl{width:100%;border-collapse:collapse;margin-top:20px}
.hours-tbl tr{border-bottom:1px solid rgba(24,22,15,.08)}
.hours-tbl tr:last-child{border-bottom:none}
.hours-tbl td{padding:12px 0;font-size:14px;font-weight:300}
.hours-tbl td:last-child{text-align:right;color:var(--mid)}
.hours-tbl tr.today td{color:var(--gold-dim);font-weight:500}


.reviews-section{padding:120px 72px;background:radial-gradient(ellipse 90% 70% at 50% 0%,rgba(196,169,107,.12),transparent 52%),linear-gradient(172deg,#242018 0%,#18160f 55%,#12100c 100%)}
.reviews-section .eyebrow{color:var(--gold)}
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.08)}
.review-card{background:var(--charcoal);padding:48px 40px;transition:background .3s}
.review-card:hover{background:var(--charcoal2)}
.review-stars{color:var(--gold);font-size:13px;letter-spacing:4px;margin-bottom:20px}
.review-open{font-family:var(--fd);font-size:64px;color:var(--gold);opacity:.3;line-height:.6;display:block;margin-bottom:16px}
.review-text{font-family:var(--fd);font-size:19px;font-style:italic;font-weight:300;line-height:1.65;color:rgba(255,255,255,.88);margin-bottom:24px}
.review-author{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.35)}


.cta-strip{background:linear-gradient(120deg,rgba(253,250,246,.9) 0%,var(--cream) 35%,rgba(232,217,188,.35) 100%);padding:80px 72px;display:flex;align-items:center;justify-content:space-between;gap:48px;border-top:1px solid rgba(196,169,107,.2);border-bottom:1px solid rgba(196,169,107,.2)}
.cta-text h2{font-family:var(--fd);font-size:clamp(32px,3vw,48px);font-weight:300;line-height:1.1;margin-bottom:8px}
.cta-text h2 em{font-style:italic;color:var(--gold-dim)}
.cta-text p{font-size:14px;color:var(--mid);max-width:400px}


















@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:1080px){
  nav{padding:0 28px;grid-template-columns:44px 1fr 44px;gap:0}
  .nav-left,.nav-right{display:none}
  .hamburger{display:flex;grid-column:3;grid-row:1;justify-self:center}
  .nav-logo-wrap{grid-column:2;grid-row:1;justify-content:center}
  .page-hero{padding:72px 32px 64px}
  .breadcrumb{padding:14px 32px}
  .story-split{grid-template-columns:1fr}
  .story-media{height:min(72vw,440px);min-height:280px}
  .story-body{padding:56px 32px}
  .team-section{padding:56px 28px 80px}
  .team-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .info-strip{grid-template-columns:1fr}
  .info-cell{border-right:none;border-bottom:1px solid rgba(24,22,15,.08)}
  .reviews-section{padding:80px 32px}
  .reviews-grid{grid-template-columns:1fr 1fr}
  .cta-strip{flex-direction:column;align-items:flex-start;padding:64px 32px}
  
  
  
}
@media(max-width:600px){.team-grid{grid-template-columns:repeat(2,1fr);gap:16px}.reviews-grid{grid-template-columns:1fr}}
@media(max-width:480px){.team-grid{grid-template-columns:repeat(2,1fr);gap:12px}.team-name{font-size:18px}.team-bio{font-size:12px}}
.hero-svc-link{display:inline-block;margin-top:18px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(196,169,107,.45);padding-bottom:3px;transition:color .2s,border-color .2s;opacity:0;animation:fadeUp .7s .58s forwards}
.hero-svc-link:hover{color:var(--gold-pale);border-bottom-color:rgba(232,217,188,.65)}

/* Team index */
.team-section{padding:96px 72px;background:transparent;position:relative}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:64px;padding:3px;background:linear-gradient(180deg,rgba(196,169,107,.1),rgba(232,217,188,.14));border:1px solid rgba(196,169,107,.16);border-radius:4px}
.team-grid>*:last-child{grid-column:span 3}

.team-card{position:relative;overflow:hidden;isolation:isolate;background-color:var(--warm-white);background-image:radial-gradient(ellipse 92% 64% at 14% 16%,rgba(253,250,246,.98) 0%,transparent 56%),radial-gradient(ellipse 74% 50% at 88% 84%,rgba(196,169,107,.2) 0%,transparent 54%),radial-gradient(ellipse 54% 38% at 52% 46%,rgba(168,141,80,.08) 0%,transparent 52%),radial-gradient(ellipse 66% 42% at 22% 88%,rgba(232,217,188,.42) 0%,transparent 48%),linear-gradient(154deg,var(--warm-white) 0%,var(--cream) 32%,rgba(232,217,188,.55) 56%,var(--cream-deep) 100%);border:1px solid rgba(196,169,107,.22);cursor:pointer;text-decoration:none;display:block;box-shadow:inset 0 1px 0 rgba(255,255,255,.72),0 2px 10px rgba(24,22,15,.05);transition:box-shadow .35s ease,transform .35s ease,border-color .35s ease}
.team-card::before{content:"";position:absolute;inset:-24% -12%;pointer-events:none;z-index:0;opacity:.34;background:linear-gradient(118deg,transparent 36%,rgba(196,169,107,.16) 48%,transparent 59%),linear-gradient(162deg,transparent 50%,rgba(232,217,188,.38) 60%,transparent 71%),linear-gradient(28deg,transparent 42%,rgba(168,141,80,.1) 49%,transparent 57%);transform:rotate(-2deg)}
.team-card::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.32;mix-blend-mode:multiply;background-image:linear-gradient(125deg,transparent 40%,rgba(196,169,107,.08) 47%,transparent 54%),var(--marble-veins),var(--marble-grain);background-size:auto,480px 480px,200px 200px}
.team-card:nth-child(even){background-image:radial-gradient(ellipse 90% 60% at 82% 12%,rgba(253,250,246,.95) 0%,transparent 54%),radial-gradient(ellipse 72% 48% at 10% 78%,rgba(196,169,107,.17) 0%,transparent 52%),radial-gradient(ellipse 50% 36% at 46% 56%,rgba(168,141,80,.07) 0%,transparent 50%),radial-gradient(ellipse 62% 40% at 84% 86%,rgba(232,217,188,.36) 0%,transparent 46%),linear-gradient(148deg,var(--cream) 0%,var(--warm-white) 38%,rgba(232,217,188,.48) 66%,#e8dfd0 100%)}
.team-card:nth-child(even)::before{transform:rotate(2deg);opacity:.3}
.team-card:nth-child(even)::after{transform:scaleX(-1);opacity:.36}
.team-card:hover{border-color:rgba(196,169,107,.38);box-shadow:inset 0 1px 0 rgba(255,255,255,.88),0 16px 36px rgba(24,22,15,.09);transform:translateY(-2px)}
.team-card:hover::before{opacity:.42}
.team-card:hover .tc-photo-wrap img{transform:scale(1.05)}
.team-card:hover .tc-overlay{opacity:1}
.tc-photo-wrap{aspect-ratio:3/4;overflow:hidden;background:linear-gradient(180deg,var(--cream-deep),var(--warm-white));position:relative;z-index:1;border-bottom:1px solid rgba(196,169,107,.18)}
.tc-photo-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease;filter:saturate(.88) brightness(.98)}
.tc-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:80px;font-weight:300;color:rgba(196,169,107,.3)}
.tc-overlay{position:absolute;inset:0;background:rgba(24,22,15,.65);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;opacity:0;transition:opacity .35s;padding:32px;text-align:center}
.tc-overlay-bio{font-size:14px;color:rgba(255,255,255,.8);line-height:1.7;font-weight:300}
.tc-overlay-btn{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(196,169,107,.5);padding:8px 20px;font-family:var(--fb);font-weight:400}
.tc-body{padding:28px 28px 32px;position:relative;z-index:1;background:linear-gradient(180deg,rgba(253,250,246,.55) 0%,rgba(246,241,235,.82) 100%);border-top:1px solid rgba(196,169,107,.12)}
.tc-name{font-family:var(--fd);font-size:24px;font-weight:400;color:var(--charcoal);margin-bottom:4px}
.tc-role{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-ink);font-weight:400;margin-bottom:12px}
.tc-tags{display:flex;flex-wrap:wrap;gap:6px}
.tc-tag{font-size:11px;background:rgba(253,250,246,.78);border:1px solid rgba(196,169,107,.2);color:var(--ink-soft);padding:4px 10px;letter-spacing:.04em;box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.tc-ig{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:12px;color:var(--mid);text-decoration:none;transition:color .2s}
.tc-ig:hover{color:var(--gold-dim)}
.tc-ig svg{width:14px;height:14px;flex-shrink:0}
.tc-learn-more{margin-top:14px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-ink);font-weight:500;display:inline-flex;align-items:center;gap:4px;transition:gap .2s}
a.team-card:hover .tc-learn-more{gap:8px}
.values-strip{background:radial-gradient(ellipse 90% 70% at 50% 0%,rgba(196,169,107,.12),transparent 52%),linear-gradient(172deg,#242018 0%,#18160f 55%,#12100c 100%);padding:80px 72px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px}
.value-cell{background:var(--charcoal);padding:48px 40px}
.value-num{font-family:var(--fd);font-size:56px;font-weight:300;color:var(--gold);line-height:1;margin-bottom:12px;opacity:.7}
.value-title{font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--warm-white);margin-bottom:10px;font-weight:400}
.value-desc{font-size:13px;color:rgba(255,255,255,.45);line-height:1.75;font-weight:300}
.cta-bar{background:linear-gradient(120deg,rgba(253,250,246,.72) 0%,rgba(246,241,235,.85) 35%,rgba(232,217,188,.4) 100%);backdrop-filter:blur(8px);padding:80px 72px;display:flex;align-items:center;justify-content:space-between;gap:40px;border-top:1px solid rgba(196,169,107,.22)}
.cta-bar h2{font-family:var(--fd);font-size:clamp(28px,3vw,44px);font-weight:300;line-height:1.1}
.cta-bar h2 em{font-style:italic;color:var(--gold-dim)}
.cta-bar p{font-size:14px;color:var(--mid);margin-top:6px}
.btn-dark{display:inline-block;text-align:center;background:var(--charcoal);color:var(--warm-white);font-family:var(--fb);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;padding:15px 36px;transition:background .25s,transform .15s}
.btn-dark:hover{background:var(--gold-dim);transform:translateY(-1px)}
.js-reveal .r{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}.js-reveal .r.vis{opacity:1;transform:none}
.js-reveal .r2{opacity:0;transform:translateY(20px);transition:opacity .7s .15s ease,transform .7s .15s ease}.js-reveal .r2.vis{opacity:1;transform:none}
.js-reveal .r3{opacity:0;transform:translateY(20px);transition:opacity .7s .3s ease,transform .7s .3s ease}.js-reveal .r3.vis{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js-reveal .r,.js-reveal .r2,.js-reveal .r3{opacity:1!important;transform:none!important;transition:none}}

/* Contact */
.contact-wrap{display:grid;grid-template-columns:1fr minmax(320px,400px);min-height:min(640px,70svh)}


.map-panel{background:linear-gradient(156deg,rgba(253,250,246,.9) 0%,var(--cream-deep) 38%,#e0d4c4 100%);position:relative;overflow:hidden}
.map-embed{width:100%;height:100%;min-height:500px;border:none;display:block;filter:saturate(.8) brightness(.96)}
.map-pin{position:absolute;bottom:32px;left:32px;background:var(--warm-white);border:1px solid rgba(24,22,15,.1);padding:18px 22px;box-shadow:0 8px 32px rgba(24,22,15,.12)}
.map-pin strong{display:block;font-family:var(--fd);font-size:18px;font-weight:400;color:var(--charcoal);margin-bottom:2px}
.map-pin span{font-size:13px;color:var(--mid)}


.info-panel{background:linear-gradient(152deg,#fdfbf7 0%,var(--cream) 40%,#e8dfd0 100%);padding:64px 56px;display:flex;flex-direction:column;gap:40px;overflow-y:auto}
.ip-section h3{font-family:var(--fd);font-size:24px;font-weight:400;color:var(--charcoal);margin-bottom:16px}
.hours-tbl{width:100%;border-collapse:collapse}
.hours-tbl tr{border-bottom:1px solid rgba(24,22,15,.07)}
.hours-tbl tr:last-child{border-bottom:none}
.hours-tbl td{padding:11px 0;font-size:13px;font-weight:300}
.hours-tbl td:last-child{text-align:right;color:var(--mid)}
.hours-tbl tr.today td{color:var(--gold-dim);font-weight:500}
.ip-divider{height:1px;background:rgba(24,22,15,.08)}
.contact-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid rgba(24,22,15,.07);font-size:13px;color:var(--charcoal);text-decoration:none;transition:color .2s;font-weight:300}
.contact-row:last-child{border-bottom:none}
.contact-row:hover{color:var(--gold-dim)}
.cr-icon{width:36px;height:36px;background:var(--cream-deep);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.btn-dark{display:block;text-align:center;background:var(--charcoal);color:var(--warm-white);font-family:var(--fb);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;padding:15px 24px;transition:background .25s}.btn-dark:hover{background:var(--gold-dim)}
.btn-outline{display:block;text-align:center;border:1px solid rgba(24,22,15,.2);color:var(--charcoal);font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;padding:14px 24px;margin-top:10px;transition:border-color .2s,background .2s}.btn-outline:hover{border-color:var(--gold);background:rgba(196,169,107,.05)}
.nearby-section{background:radial-gradient(ellipse 90% 70% at 50% 0%,rgba(196,169,107,.12),transparent 52%),linear-gradient(172deg,#242018 0%,#18160f 55%,#12100c 100%);padding:80px 72px}
.nearby-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);margin-top:48px}
.nearby-cell{background:var(--charcoal);padding:36px 28px;transition:background .2s}
.nearby-cell:hover{background:var(--charcoal2)}
.nearby-name{font-family:var(--fd);font-size:18px;font-weight:400;color:var(--warm-white);margin-bottom:4px}
.nearby-dist{font-size:12px;color:rgba(255,255,255,.35);letter-spacing:.08em}

/* Staff profiles */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--cream:#F6F1EB;--cream-deep:#EDE5DA;--warm-white:#FDFAF6;--charcoal:#18160F;--charcoal2:#2C2A22;--mid:#7A756A;--light:#B0A99E;--gold:#C4A96B;--gold-dim:#A88D50;--gold-pale:#E8D9BC;--nav-h:80px;--fd:'Cormorant Garamond',Georgia,serif;--fb:'Jost',sans-serif}
html{scroll-behavior:smooth}body{background:var(--warm-white);color:var(--charcoal);font-family:var(--fb);font-weight:300;line-height:1.7;overflow-x:hidden}

nav{position:sticky;top:0;height:var(--nav-h);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 56px;background:rgba(253,250,246,.97);backdrop-filter:blur(16px);border-bottom:1px solid rgba(196,169,107,.2);z-index:200;transition:box-shadow .3s}
nav.scrolled{box-shadow:0 2px 32px rgba(24,22,15,.08)}


.breadcrumb{background:linear-gradient(158deg,rgba(253,250,246,.95) 0%,var(--cream-deep) 45%,#e0d4c4 100%);padding:14px 72px;border-bottom:1px solid rgba(24,22,15,.08);display:flex;align-items:center;gap:8px;font-size:12px;color:var(--mid)}
.breadcrumb a{color:var(--mid);text-decoration:none;transition:color .2s}.breadcrumb a:hover{color:var(--charcoal)}
.breadcrumb span.sep{color:var(--light)}


.profile-hero{display:grid;grid-template-columns:minmax(220px,300px) 1fr;min-height:0;align-items:start}
.profile-photo{background:var(--cream-deep);position:relative;overflow:hidden}
.profile-photo .placeholder{width:100%;height:100%;min-height:220px;max-height:400px;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:140px;font-weight:300;color:rgba(196,169,107,.25)}
.profile-content{padding:36px 48px 32px;background:linear-gradient(152deg,#fdfbf7 0%,var(--cream) 40%,#e8dfd0 100%);display:flex;flex-direction:column;justify-content:flex-start}
.profile-eyebrow{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:400;opacity:0;animation:fadeUp .7s .2s forwards}
.profile-eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--gold)}
.profile-name{font-family:var(--fd);font-size:clamp(48px,5vw,80px);font-weight:300;line-height:1.0;color:var(--charcoal);margin-bottom:6px;opacity:0;animation:fadeUp .7s .35s forwards}
.profile-role{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:32px;font-weight:400;opacity:0;animation:fadeUp .7s .45s forwards}
.profile-bio{font-size:15px;color:var(--mid);line-height:1.9;max-width:480px;margin-bottom:40px;font-weight:300;opacity:0;animation:fadeUp .7s .55s forwards}
.btn-dark{display:inline-block;text-align:center;background:var(--charcoal);color:var(--warm-white);font-family:var(--fb);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;padding:15px 36px;transition:background .25s,transform .15s}
.btn-dark:hover{background:var(--gold-dim);transform:translateY(-1px)}
.btn-outline{display:inline-block;text-align:center;border:1px solid rgba(24,22,15,.2);color:var(--charcoal);font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;padding:14px 36px;transition:border-color .2s,background .2s}
.btn-outline:hover{border-color:var(--gold);background:rgba(196,169,107,.05)}


.profile-details{padding:80px 72px;display:grid;grid-template-columns:1fr 1fr 340px;gap:56px;align-items:start}
.pd-section h3{font-family:var(--fd);font-size:28px;font-weight:400;color:var(--charcoal);margin-bottom:20px}
.specialty-list{display:flex;flex-direction:column;gap:0}
.spec-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid rgba(24,22,15,.07);font-size:14px;color:var(--mid);font-weight:300}
.spec-item:last-child{border-bottom:none}
.spec-item::before{content:'';display:block;width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}

.exp-list{display:flex;flex-direction:column;gap:0}
.exp-item{padding:18px 0;border-bottom:1px solid rgba(24,22,15,.07)}
.exp-item:last-child{border-bottom:none}
.exp-year{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;font-weight:400}
.exp-title{font-size:15px;color:var(--charcoal);font-weight:400;margin-bottom:2px}
.exp-sub{font-size:13px;color:var(--mid);font-weight:300}


.profile-content-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px;width:100%;max-width:720px}
.profile-content-cards .ps-card{height:100%}


.profile-sidebar{display:flex;flex-direction:column;gap:20px}
.ps-card{border:1px solid rgba(24,22,15,.09);padding:28px;background:var(--warm-white)}
.ps-card h4{font-family:var(--fd);font-size:20px;font-weight:400;color:var(--charcoal);margin-bottom:12px}
.ps-card p{font-size:13px;color:var(--mid);line-height:1.8;margin-bottom:18px;font-weight:300}

.ig-link{display:inline-flex;align-items:center;gap:12px;font-size:14px;font-weight:500;color:var(--charcoal);text-decoration:none;padding:14px 20px;border:2px solid var(--gold);border-radius:2px;background:linear-gradient(180deg,rgba(196,169,107,.22),rgba(196,169,107,.08));box-shadow:0 4px 22px rgba(24,22,15,.1);transition:border-color .2s,background .2s,transform .2s,box-shadow .2s}
.ig-link:hover{border-color:var(--gold-dim);background:linear-gradient(180deg,rgba(196,169,107,.32),rgba(237,229,218,.95));transform:translateY(-2px);box-shadow:0 8px 28px rgba(24,22,15,.12)}
.ig-link svg{width:22px;height:22px;flex-shrink:0;color:#E1306C}

.staff-book-wrap{padding:48px 72px 80px;background:linear-gradient(180deg,var(--warm-white) 0%,var(--cream) 55%,#ebe3d6 100%);border-top:1px solid rgba(24,22,15,.06)}
.staff-book-inner{max-width:min(100%,920px);margin:0 auto;background:linear-gradient(180deg,rgba(253,250,246,.98) 0%,var(--warm-white) 30%);border:1px solid rgba(24,22,15,.1);border-radius:14px;box-shadow:0 20px 56px rgba(24,22,15,.07),0 0 0 1px rgba(255,255,255,.5) inset;overflow:visible}
.staff-vagaro-stage{min-height:0;width:100%;background:var(--warm-white)}
.staff-book-wrap .staff-vagaro{width:100%!important;margin:0!important;padding:0!important;line-height:0;font-size:0;min-height:0}
.staff-book-wrap .staff-vagaro iframe{display:block!important;width:100%!important;min-height:420px!important;margin:0!important;padding:0!important;border:0!important;vertical-align:top}
#frameTitle.staff-frame-title:empty{display:none!important}
#frameTitle.staff-frame-title:not(:empty){font-size:clamp(15px,1.35vw,18px);color:var(--charcoal2);font-family:var(--fd),Georgia,serif;font-weight:400;line-height:1.35;padding:18px clamp(16px,3vw,28px) 14px;text-align:center;box-sizing:border-box;letter-spacing:.02em;border-bottom:1px solid rgba(24,22,15,.06);background:rgba(253,250,246,.9)}
.staff-book-wrap .vagaro a[href*="vagaro.com/pro"]{display:none!important}
.staff-book-wrap .staff-vagaro>a:first-child{display:none!important}


.reviews-section{padding:80px 72px;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(196,169,107,.08),transparent 55%),linear-gradient(180deg,var(--warm-white) 0%,rgba(253,250,246,.6) 100%)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.review-card{background:var(--warm-white);border:1px solid rgba(24,22,15,.08);padding:36px 32px}
/* This light .review-card overrides the earlier dark-card design's background,
   but the dark design's white text colors (.review-text / .review-author) had
   no light override — leaving white text on a cream card. Restore dark text. */
.review-card .review-text{color:var(--charcoal)}
.review-card .review-author{color:#6b655c}
.rv-stars{color:var(--gold);font-size:13px;letter-spacing:3px;margin-bottom:16px}
.rv-text{font-family:var(--fd);font-size:18px;font-style:italic;font-weight:300;color:var(--charcoal);line-height:1.65;margin-bottom:20px}
.rv-author{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--light)}

.r{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}.r.vis{opacity:1;transform:none}
.r2{opacity:0;transform:translateY(20px);transition:opacity .7s .15s ease,transform .7s .15s ease}.r2.vis{opacity:1;transform:none}
.r3{opacity:0;transform:translateY(20px);transition:opacity .7s .3s ease,transform .7s .3s ease}.r3.vis{opacity:1;transform:none}














@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.services-guide{padding:clamp(48px,8vw,80px) clamp(24px,5vw,72px);background:linear-gradient(180deg,var(--warm-white) 0%,var(--cream) 100%);border-bottom:1px solid rgba(24,22,15,.08)}
.services-guide-lead{max-width:68ch;font-size:15px;color:var(--mid);line-height:1.85;margin-top:20px}
.services-guide-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,32px);margin-top:48px}
.service-block{padding:28px 24px;background:var(--warm-white);border:1px solid rgba(24,22,15,.09);border-radius:12px;scroll-margin-top:calc(var(--site-header-h,128px) + 16px)}
.service-block h2{font-family:var(--fd);font-size:clamp(22px,2.5vw,28px);font-weight:400;color:var(--charcoal);margin-bottom:12px}
.service-block p{font-size:14px;color:var(--mid);line-height:1.8;margin-bottom:12px}
.service-block ul{margin:0 0 16px 1.1em;font-size:14px;color:var(--mid);line-height:1.75}
.service-block .service-from{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:12px}
.service-block .service-stylists{font-size:13px;color:var(--charcoal2);margin-top:8px}
@media(max-width:768px){.services-guide-grid{grid-template-columns:1fr}}
@media(max-width:1080px){nav{padding:0 28px;grid-template-columns:44px 1fr 44px;gap:0}.nav-left,.nav-right{display:none}.hamburger{display:flex;grid-column:3;grid-row:1;justify-self:center}.nav-logo-wrap{grid-column:2;grid-row:1;justify-content:center}.breadcrumb{padding:14px 32px}.profile-hero{grid-template-columns:1fr}.profile-photo{display:none}.profile-content{padding:56px 32px}.profile-content-cards{grid-template-columns:1fr;gap:20px;margin-top:24px}.profile-details{grid-template-columns:1fr;padding:56px 32px}.ig-section{padding:64px 32px}.ig-grid{grid-template-columns:repeat(3,1fr)}.reviews-section{padding:64px 32px}.reviews-grid{grid-template-columns:1fr}.staff-book-wrap{padding:32px 16px 56px}}
@media(max-width:600px){.ig-grid{grid-template-columns:repeat(3,1fr)}}

/* ============================================================
   Reveal-visibility failsafe.
   .r/.r2/.r3 start at opacity:0 and rely on an IntersectionObserver
   adding .vis. On pages where the observer never fires for content far
   below the fold (and there's no .js-reveal head-script failsafe), that
   content stays permanently invisible — this is what blanked the /ratings/
   review cards and the About-page reviews.
   So: whenever the page is NOT in active js-reveal animation mode, force
   the reveal elements fully visible. Pages that DO opt into animation set
   .js-reveal on <html> (head script + 2.5s failsafe timer); when that timer
   fires it removes .js-reveal, and this rule then guarantees visibility.
   ============================================================ */
html:not(.js-reveal) .r,
html:not(.js-reveal) .r2,
html:not(.js-reveal) .r3{opacity:1!important;transform:none!important}

/* About-page team grid: the staff-index rule
   ".team-grid>*:last-child{grid-column:span 3}" (for that page's full-width
   CTA) bled onto the About grid via the shared .team-grid class and made the
   last card (Kylie) span 3 columns. Scope it back to a single cell here. */
#team .team-grid>*:last-child{grid-column:auto}

/* ---- CRITICAL mobile re-assert ----
   site.css is concatenated, and the staff-page ".team-grid{repeat(4,1fr)}" +
   ".team-section{padding:96px 72px}" base rules are defined LATER than the
   responsive @media rules earlier in the file — so on phones the desktop
   4-column grid + 72px padding won the cascade. The grid couldn't fit in
   device-width, the mobile layout viewport expanded (~584px) to contain it,
   and the whole /staff (and /about) page overflowed horizontally. Re-assert
   the responsive layout here so it wins. .values-strip had NO mobile rule at
   all (3 cols + 72px pad also overflowed) — fixed too. minmax(0,1fr) stops a
   card's min-content from forcing the track (and the page) wider. */
@media(max-width:1080px){
  .team-section{padding:clamp(48px,8vw,72px) clamp(20px,5vw,32px)}
  .team-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:600px){
  .team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .team-grid>*:last-child{grid-column:1/-1}
  .values-strip{grid-template-columns:1fr;padding:clamp(40px,9vw,64px) clamp(20px,5vw,28px)}
  .value-cell{padding:clamp(28px,6vw,40px) clamp(24px,5vw,32px)}
}
/* Keep at least 2 stylists per row at every width — a single full-screen card
   is too much. Tighten the gap so the 2-up fits the narrowest phones without
   overflow; name/bio type is already reduced at this breakpoint. */
@media(max-width:480px){
  .team-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
}

/* The staff-page "Ready to book with your stylist?" CTA (.cta-bar) is a flex
   row (heading | button) with 72px side padding — on a 375px phone the heading
   column is left ~230px and breaks one word per line. Stack it vertically, trim
   the padding, and let the button stretch to a full-width tap target. */
@media(max-width:768px){
  .cta-bar{flex-direction:column;align-items:stretch;gap:22px;padding:clamp(44px,9vw,64px) clamp(20px,6vw,30px)}
}

/* Card links default to the browser's blue (rgb(0,0,238)) because there is no
   global <a> color reset and the card wrappers set no color of their own. Make
   any card-wrapper link inherit the page text color. (The About grid escaped
   this via an inline color:inherit; this covers the Staff grid and any future
   card link too.) */
a.team-card,a.tc-card,a.home-stylist,a.review-card,a.rv-card{color:inherit;text-decoration:none}
