*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  /* ── Salon Palette: Deep Charcoal + Warm Rose + Champagne ── */
  --ink:       #1a1714;
  --ink2:      #2c2826;
  --rose:      #c4756a;
  --rose-lt:   #d9948b;
  --rose-pale: #f0dbd8;
  --champ:     #e8d5b0;
  --champ-lt:  #f4ecd8;
  --champ-dk:  #c9b48a;
  --linen:     #faf6f0;
  --linen2:    #f2ebe0;
  --stone:     #8c8279;
  --dim:       rgba(26,23,20,0.55);

  --pad-x: clamp(1.2rem, 7vw, 7rem);
  --sec:   clamp(4.5rem,11vh,9rem);
  --rad:   2px;
}

body{background:var(--linen);color:var(--ink);font-family:'Jost',sans-serif;font-weight:300;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}

/* ── TYPE ── */
.tag{font-family:'Jost',sans-serif;font-size:clamp(.55rem,1.1vw,.65rem);font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--rose)}
.display{font-family:'Cormorant',serif;font-weight:400;line-height:1.06}
.display em{font-style:italic;color:var(--rose)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:'Jost',sans-serif;font-size:.65rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;padding:.85rem 2rem;cursor:pointer;border:none;transition:.28s ease}
.btn-rose{background:var(--rose);color:#fff}
.btn-rose:hover{background:var(--rose-lt);transform:translateY(-2px)}
.btn-border{background:transparent;border:1px solid var(--ink);color:var(--ink)}
.btn-border:hover{background:var(--ink);color:var(--linen)}
.btn-border-w{background:transparent;border:1px solid rgba(255,255,255,.45);color:#fff}
.btn-border-w:hover{background:#fff;color:var(--ink)}

/* ── REVEAL ── */
.rev{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease}
.rev.on{opacity:1;transform:none}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
nav{
  position:fixed;inset-block-start:0;inset-inline:0;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--pad-x);
  background:rgba(250,246,240,.94);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(196,117,106,.15);
  transition:padding .3s;
}
.nav-brand{font-family:'Cormorant',serif;font-size:clamp(.95rem,2.2vw,1.2rem);font-weight:500;letter-spacing:.05em;color:var(--ink)}
.nav-brand span{color:var(--rose)}
.nav-links{display:flex;gap:clamp(1rem,3vw,2.4rem);list-style:none}
.nav-links a{font-family:'Jost',sans-serif;font-size:.62rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);transition:color .22s}
.nav-links a:hover{color:var(--rose)}
.nav-cta{display:none}

/* hamburger */
.ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.ham span{display:block;width:22px;height:1.5px;background:var(--ink);transition:transform .3s,opacity .3s}
.ham.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* drawer */
.drawer{
  display:none;
  position:fixed;inset:0;z-index:250;
  flex-direction:column;justify-content:center;align-items:center;gap:2.5rem;
  background:var(--linen);
  opacity:0;pointer-events:none;transition:opacity .32s;
}
.drawer.open{opacity:1;pointer-events:all}
.drawer a{font-family:'Cormorant',serif;font-size:clamp(2rem,9vw,3rem);font-weight:400;color:var(--ink);transition:color .22s}
.drawer a:hover{color:var(--rose)}
.drawer-close{position:absolute;top:1.5rem;right:var(--pad-x);background:none;border:none;cursor:pointer;font-size:1.8rem;color:var(--stone)}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero{
  min-height:100svh;
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr;
  overflow:hidden;
}

/* LEFT — text */
.hero-l{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(6rem,13vh,10rem) var(--pad-x) clamp(3rem,6vh,5rem);
  position:relative;z-index:2;
  background:var(--linen);
}
.hero-tag{margin-bottom:2rem;opacity:0;animation:fu .8s .15s forwards}
.hero-h1{
  font-family:'Cormorant',serif;
  font-size:clamp(3rem,6vw,6.5rem);
  font-weight:300;line-height:1.02;
  margin-bottom:1.8rem;
  opacity:0;animation:fu .8s .35s forwards;
}
.hero-h1 em{font-style:italic;color:var(--rose);font-weight:400}
.hero-h1 strong{font-weight:600;display:block}
.hero-sub{
  font-size:clamp(1rem,1.5vw,1.15rem);
  line-height:1.78;
  color:var(--stone);
  max-width:390px;
  margin-bottom:2.8rem;
  opacity:0;animation:fu .8s .55s forwards;
}
.hero-btns{
  display:flex;flex-wrap:wrap;gap:.9rem;
  margin-bottom:3rem;
  opacity:0;animation:fu .8s .75s forwards;
}
.hero-rating{
  display:flex;align-items:center;gap:1.2rem;
  padding-top:2rem;
  border-top:1px solid rgba(196,117,106,.2);
  opacity:0;animation:fu .8s .95s forwards;
}
.rating-stars{color:var(--rose);font-size:1rem;letter-spacing:2px}
.rating-num{font-family:'Cormorant',serif;font-size:2rem;font-weight:500;color:var(--ink);line-height:1}
.rating-sub{font-size:.8rem;color:var(--stone);line-height:1.4}

/* RIGHT — photo collage */
.hero-r{
  position:relative;
  display:grid;
  grid-template-rows:55% 45%;
  grid-template-columns:1fr 1fr;
  gap:4px;
  background:var(--ink);
}
.hero-photo{overflow:hidden;position:relative}
.hero-photo.big{grid-row:1/-1;grid-column:1}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.88) saturate(.95);
  transition:transform 6s ease;
}
.hero-photo:hover img{transform:scale(1.04)}

/* decorative vertical line */
.hero-l::after{
  content:'';
  position:absolute;top:15%;bottom:15%;right:0;
  width:1px;background:linear-gradient(to bottom,transparent,rgba(196,117,106,.35),transparent);
}

/* floating tag on photo */
.photo-tag{
  position:absolute;bottom:1.2rem;left:1.2rem;z-index:2;
  background:rgba(250,246,240,.92);backdrop-filter:blur(8px);
  padding:.5rem 1.1rem;
  font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink);
}

/* ══════════════════════════════════════
   RIBBON
══════════════════════════════════════ */
.ribbon{overflow:hidden;background:var(--ink);padding:.78rem 0;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.ribbon-track{display:flex;width:max-content;animation:marquee 30s linear infinite}
.ribbon-track span{
  font-family:'Jost',sans-serif;font-size:.6rem;letter-spacing:.28em;
  text-transform:uppercase;color:rgba(255,255,255,.6);
  padding:0 2.8rem;white-space:nowrap;
}
.ribbon-track .dot{color:var(--rose);opacity:.9}

/* ══════════════════════════════════════
   ABOUT
══════════════════════════════════════ */
.about{
  padding:var(--sec) var(--pad-x);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(3rem,9vw,8rem);
  align-items:center;
  background:var(--linen);
}
.about-copy .tag{margin-bottom:1.4rem}
.about-copy .display{font-size:clamp(2.2rem,4.5vw,4rem);margin-bottom:2rem}
.about-copy p{font-size:clamp(1rem,1.5vw,1.13rem);line-height:1.85;color:var(--stone);margin-bottom:1.1rem}
.about-copy .btn{margin-top:.8rem}

.stats-col{display:flex;flex-direction:column;gap:1px}
.stat-card{
  padding:2.2rem 2.5rem;
  background:var(--champ-lt);
  border-left:3px solid var(--rose);
  position:relative;overflow:hidden;
  transition:background .3s;
}
.stat-card:hover{background:var(--rose-pale)}
.stat-n{font-family:'Cormorant',serif;font-size:clamp(2.8rem,5vw,4rem);font-weight:400;color:var(--rose);line-height:1}
.stat-l{font-family:'Jost',sans-serif;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-top:.4rem}

/* ══════════════════════════════════════
   GALLERY
══════════════════════════════════════ */
.gallery{padding:var(--sec) var(--pad-x);background:var(--ink)}
.gal-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem;gap:1rem}
.gal-hd .tag{color:var(--rose-lt)}
.gal-hd .display{font-size:clamp(2rem,4vw,3.6rem);color:var(--champ-lt)}
.gal-grid{
  display:grid;
  grid-template-columns:1.7fr 1fr 1fr;
  grid-template-rows:265px 265px;
  gap:5px;
}
.gi{overflow:hidden;position:relative}
.gi.tall{grid-row:1/-1}
.gi img{width:100%;height:100%;object-fit:cover;filter:brightness(.78) saturate(.9);transition:transform .6s ease,filter .4s}
.gi:hover img{transform:scale(1.07);filter:brightness(.9) saturate(1.05)}
.gi-caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:1rem 1.3rem;
  background:linear-gradient(to top,rgba(26,23,20,.7) 0%,transparent 100%);
  font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.7);
  opacity:0;transition:opacity .35s;
}
.gi:hover .gi-caption{opacity:1}

/* ══════════════════════════════════════
   SERVICES
══════════════════════════════════════ */
.services{padding:var(--sec) var(--pad-x);background:var(--linen2)}
.svc-hd .tag{margin-bottom:1.2rem}
.svc-hd .display{font-size:clamp(2.2rem,4.5vw,3.8rem);margin-bottom:clamp(2.5rem,5vw,5rem)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.svc-card{
  background:var(--linen);
  padding:2.8rem 2.4rem;
  position:relative;overflow:hidden;
  border-bottom:2px solid transparent;
  transition:border-color .32s,transform .28s,box-shadow .28s;
}
.svc-card:hover{border-color:var(--rose);transform:translateY(-5px);box-shadow:0 16px 48px rgba(196,117,106,.12)}
.svc-ico{
  width:48px;height:48px;border-radius:50%;
  background:var(--rose-pale);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:1.8rem;
  transition:background .3s;
}
.svc-card:hover .svc-ico{background:var(--rose);color:#fff}
.svc-num{font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.25em;text-transform:uppercase;color:var(--rose);margin-bottom:1rem}
.svc-name{font-family:'Cormorant',serif;font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:400;margin-bottom:.9rem}
.svc-desc{font-size:clamp(.9rem,1.3vw,1.02rem);line-height:1.78;color:var(--stone);margin-bottom:1.6rem}
.svc-price{font-family:'Cormorant',serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:500;color:var(--rose)}

/* ══════════════════════════════════════
   REVIEWS
══════════════════════════════════════ */
.reviews{padding:var(--sec) var(--pad-x);background:var(--champ-lt)}
.rv-hd .tag{margin-bottom:1.2rem;color:var(--rose)}
.rv-hd .display{font-size:clamp(2.2rem,4.5vw,3.8rem);margin-bottom:clamp(2.5rem,5vw,5rem)}
.rv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.rv-card{
  background:#fff;
  padding:2.4rem;
  border-top:3px solid transparent;
  transition:border-color .28s,transform .28s;
}
.rv-card:hover{border-color:var(--rose);transform:translateY(-4px)}
.rv-stars{color:var(--rose);font-size:.82rem;letter-spacing:2px;margin-bottom:1rem}
.rv-q{font-family:'Cormorant',serif;font-size:4rem;color:var(--rose);opacity:.22;line-height:.5;margin-bottom:.8rem}
.rv-text{font-size:clamp(.9rem,1.3vw,1.02rem);line-height:1.82;color:var(--stone);font-style:italic;margin-bottom:1.5rem}
.rv-author{font-family:'Jost',sans-serif;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rose)}

/* ══════════════════════════════════════
   CTA BANNER
══════════════════════════════════════ */
.cta-banner{
  background:var(--ink);
  padding:clamp(4rem,9vw,7rem) var(--pad-x);
  display:flex;align-items:center;justify-content:space-between;
  gap:2.5rem;flex-wrap:wrap;
}
.cta-copy .tag{color:var(--rose-lt);margin-bottom:1.2rem}
.cta-copy .display{font-size:clamp(2rem,4.5vw,3.8rem);color:var(--champ-lt)}
.cta-copy .display em{color:var(--rose-lt)}
.cta-btns{display:flex;gap:1rem;flex-wrap:wrap;flex-shrink:0}

/* ══════════════════════════════════════
   CONTACT
══════════════════════════════════════ */
.contact{padding:var(--sec) var(--pad-x);background:var(--linen)}
.contact-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(3rem,9vw,8rem);
  align-items:start;
}
.contact-l .tag{margin-bottom:1.2rem}
.contact-l .display{font-size:clamp(2.2rem,4.5vw,3.8rem);margin-bottom:2.5rem}
.ci{display:flex;gap:1.3rem;padding:1.5rem 0;border-bottom:1px solid rgba(196,117,106,.18)}
.ci:last-of-type{border:none}
.ci-icon{
  width:40px;height:40px;flex-shrink:0;border-radius:50%;
  background:var(--rose-pale);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;
}
.ci-lbl{font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rose);margin-bottom:.35rem}
.ci-val{font-size:clamp(.95rem,1.4vw,1.1rem);line-height:1.65;color:var(--ink)}
.ci-val a{color:var(--rose)}
.ci-val a:hover{text-decoration:underline}

.hours-tbl{width:100%;border-collapse:collapse;margin-top:2rem}
.hours-tbl tr{border-bottom:1px solid rgba(196,117,106,.15)}
.hours-tbl tr:last-child{border:none}
.hours-tbl td{padding:.7rem 0;font-size:clamp(.88rem,1.3vw,.98rem)}
.hours-tbl .day{font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:var(--stone);padding-right:1.8rem;width:40%}
.closed-row{opacity:.3}

.contact-r{display:flex;flex-direction:column;gap:1.2rem}
.map-box{width:100%;aspect-ratio:4/3;overflow:hidden;border:1px solid rgba(196,117,106,.2)}
.map-box iframe{width:100%;height:100%;border:none;filter:saturate(.5) hue-rotate(340deg) brightness(1.05)}
.contact-btns{display:flex;gap:1rem;flex-wrap:wrap}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer{
  background:var(--ink2);
  padding:3rem var(--pad-x);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1.5rem;
}
.foot-brand{font-family:'Cormorant',serif;font-size:clamp(.95rem,2vw,1.15rem);font-weight:400;color:var(--champ)}
.foot-brand span{color:var(--rose-lt)}
.foot-links{display:flex;gap:2rem;list-style:none}
.foot-links a{font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);transition:color .22s}
.foot-links a:hover{color:var(--rose-lt)}
.foot-copy{font-family:'Jost',sans-serif;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.2)}

/* ══════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════ */
@keyframes fu{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══════════════════════════════════════
   RESPONSIVE — TABLET ≤ 900px
══════════════════════════════════════ */
@media(max-width:900px){
  .nav-links,.nav-cta{display:none}
  .ham{display:flex}
  .drawer{display:flex}

  .hero{grid-template-columns:1fr;min-height:100svh}
  .hero-r{order:0;height:55vw;min-height:220px;grid-template-rows:1fr;grid-template-columns:1fr 1fr 1fr}
  .hero-photo.big{grid-row:auto;grid-column:auto}
  .hero-l{order:1;padding-top:3rem}
  .hero-l::after{display:none}
  .hero-h1{font-size:clamp(2.8rem,8vw,4.5rem)}

  .about{grid-template-columns:1fr}
  .stats-col{flex-direction:row;flex-wrap:wrap}
  .stat-card{flex:1;min-width:160px}

  .gal-hd{flex-direction:column;align-items:flex-start;gap:.8rem}
  .gal-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:190px 190px 190px;
  }
  .gi.tall{grid-row:auto;grid-column:1/-1}

  .svc-grid{grid-template-columns:1fr 1fr}
  .rv-grid{grid-template-columns:1fr 1fr}

  .cta-banner{justify-content:center;text-align:center}

  .contact-inner{grid-template-columns:1fr}
  footer{flex-direction:column;align-items:flex-start}
  .foot-links{flex-wrap:wrap}
}

/* ══════════════════════════════════════
   RESPONSIVE — MOBILE ≤ 540px
══════════════════════════════════════ */
@media(max-width:540px){
  .hero-r{height:65vw;grid-template-columns:1fr 1fr}
  .hero-photo.big{display:none}
  .hero-sub{max-width:100%}

  .stats-col{flex-direction:column}

  .gal-grid{
    grid-template-columns:1fr;
    grid-template-rows:210px 170px 170px 170px 170px;
  }
  .gi.tall{grid-column:auto}

  .svc-grid{grid-template-columns:1fr}
  .rv-grid{grid-template-columns:1fr}

  .foot-links{display:none}
}