/* ===== TOKENS ===== */
:root{
  --ink:#0a0a0a;
  --ink-2:#101012;
  --panel:#161618;
  --line:#2a2a2e;
  --fog:#8c8c92;
  --paper:#f4f2ee;
  --paper-dim:#b9b8b4;
  --accent:#ffffff;
  --radius:4px;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:"Jost",system-ui,sans-serif;
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;line-height:1.05;letter-spacing:.01em}

/* photos render in full colour */
.about__img,.feature__media img,.visit__media img,.work-grid__item img{filter:saturate(1.03)}

/* ===== HELPERS ===== */
.eyebrow{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--paper-dim);font-weight:500;margin-bottom:1.1rem;
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.95rem 2rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;border-radius:var(--radius);transition:all .35s var(--ease);
  border:1px solid transparent;cursor:pointer;white-space:nowrap;
}
.btn--solid{background:var(--paper);color:#0a0a0a}
.btn--solid:hover{background:#fff;transform:translateY(-2px)}
.btn--line{border-color:var(--line);color:var(--paper)}
.btn--line:hover{border-color:var(--paper);color:#fff}
.btn--ghost{border-color:rgba(255,255,255,.2);color:var(--paper);padding:.7rem 1.4rem}
.btn--ghost:hover{border-color:var(--paper);background:var(--paper);color:#0a0a0a}
.btn--wa{background:#25d366;color:#06351a;gap:.6rem}
.btn--wa:hover{background:#2eea73;transform:translateY(-2px)}
.btn--wa svg{flex:none}

.section-head{max-width:640px;margin:0 auto 4rem;text-align:center;padding:0 1.5rem}
.section-head h2{font-size:clamp(2.6rem,6vw,4.2rem)}
.section-head__lede{color:var(--paper-dim);margin-top:1rem}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s var(--ease),border-color .4s var(--ease),padding .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;padding:1.4rem 1.8rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.nav.scrolled{background:rgba(10,10,10,.82);backdrop-filter:blur(14px);border-color:var(--line)}
.nav.scrolled .nav__inner{padding-top:.9rem;padding-bottom:.9rem}

.brand{display:flex;align-items:center;gap:.8rem}
.brand__logo{width:42px;height:42px;flex:none;filter:invert(1)}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__text strong{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:1.15rem;letter-spacing:.02em}
.brand__text em{font-style:normal;font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--fog)}

.nav__links{display:flex;gap:2.2rem}
.nav__links a{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper-dim);transition:color .3s}
.nav__links a:hover{color:#fff}
.nav__cta{margin-left:.5rem}
.nav__toggle{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.nav__toggle span{width:24px;height:2px;background:var(--paper);transition:.3s}

/* ===== HERO (barbershop interior + logo) ===== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
  text-align:center;background:#0a0a0a;overflow:hidden;
}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media picture{position:absolute;inset:0;display:block}
.hero__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.04) brightness(.9) contrast(1.02);transform:scale(1.04);animation:heroZoom 14s var(--ease) forwards}
.hero__scrim{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 100% at 50% 40%,rgba(8,8,8,.3),rgba(8,8,8,.66) 72%),
    linear-gradient(180deg,rgba(8,8,8,.55) 0%,rgba(8,8,8,.16) 34%,rgba(8,8,8,.42) 64%,rgba(8,8,8,.9) 100%);
}
.hero__inner{max-width:780px;padding:7rem 1.5rem 5rem;position:relative;z-index:1}

.hero__logo{
  position:relative;width:auto;height:auto;margin:0 auto 2rem;
  display:grid;place-items:center;
  opacity:0;transform:scale(.84);animation:logoIn 1.2s var(--ease) .1s forwards;
}
.hero__logo img{width:104px;height:104px;filter:invert(1) drop-shadow(0 4px 18px rgba(0,0,0,.6));position:relative;z-index:2}

.hero__eyebrow,.hero__title,.hero__lede,.hero__actions{opacity:0;animation:fadeUp .9s var(--ease) forwards}
.hero__eyebrow{animation-delay:.55s}
.hero__title{animation-delay:.7s}
.hero__lede{animation-delay:.85s}
.hero__actions{animation-delay:1s}

.hero__eyebrow,.hero__title,.hero__lede,.hero__rating{text-shadow:0 1px 18px rgba(0,0,0,.6)}
.hero__title{font-size:clamp(2.8rem,7.5vw,5.2rem);line-height:1;margin:.2rem 0 1.6rem}
.hero__title span{
  display:block;font-family:"Jost",sans-serif;font-weight:400;
  font-size:.2em;letter-spacing:.55em;text-transform:uppercase;
  margin-top:1.1rem;padding-left:.55em;color:#dad8d3;
}
.hero__lede{max-width:34rem;margin:0 auto;color:#d4d2ce;font-size:1.06rem}
.hero__actions{display:flex;gap:1rem;margin-top:2.6rem;flex-wrap:wrap;justify-content:center}
.hero__rating{opacity:0;animation:fadeUp .9s var(--ease) 1.15s forwards;margin-top:1.8rem;font-size:.82rem;letter-spacing:.1em;color:var(--paper-dim)}
.hero__rating .stars{color:#fff;letter-spacing:.15em;margin-right:.4rem}

.hero__scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:1;
  font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--fog);
  opacity:0;animation:fadeUp .9s var(--ease) 1.3s forwards;
}
.hero__scroll::after{content:"";display:block;width:1px;height:34px;margin:.6rem auto 0;
  background:linear-gradient(var(--paper),transparent);animation:scroll 1.8s var(--ease) infinite}

@keyframes logoIn{to{opacity:1;transform:scale(1)}}
@keyframes heroZoom{to{transform:scale(1)}}
@keyframes pulse{0%{transform:scale(.92);opacity:.55}70%{opacity:0}100%{transform:scale(1.55);opacity:0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes scroll{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1)}100%{transform:scaleY(.2);transform-origin:bottom}}

/* ===== MARQUEE ===== */
.marquee{border-block:1px solid var(--line);background:var(--ink-2);overflow:hidden;padding:1.1rem 0}
.marquee__track{display:flex;align-items:center;gap:2.4rem;width:max-content;animation:slide 34s linear infinite}
.marquee span{font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-style:italic;color:var(--paper-dim);white-space:nowrap}
.marquee i{color:var(--paper);font-style:normal;font-size:.7rem}
@keyframes slide{to{transform:translateX(-50%)}}

/* ===== STATS ===== */
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);max-width:var(--maxw);
  margin:0 auto;border-bottom:1px solid var(--line);
}
.stat{padding:2.6rem 1.5rem;text-align:center;border-left:1px solid var(--line)}
.stat:first-child{border-left:0}
.stat strong{display:block;font-family:"Cormorant Garamond",serif;font-weight:600;font-size:2.6rem;line-height:1}
.stat strong span{font-size:1.4rem;vertical-align:top;margin-left:.1em}
.stat__label{display:block;margin-top:.5rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fog)}

/* ===== ABOUT ===== */
.about{max-width:var(--maxw);margin:0 auto;padding:7rem 1.8rem}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:center}
.about__imgs{position:relative;display:grid;grid-template-columns:1.2fr .9fr;gap:1.2rem;align-items:end}
.about__img{border-radius:var(--radius);overflow:hidden}
.about__img--tall{aspect-ratio:3/4.2}
.about__img--small{aspect-ratio:3/3.4;margin-bottom:2.5rem}
.about__copy h2{font-size:clamp(2.2rem,4vw,3.2rem);margin-bottom:1.4rem}
.about__copy p{color:var(--paper-dim);margin-bottom:1.1rem}
.about__points{list-style:none;margin-top:2rem;display:grid;gap:1.1rem}
.about__points li{display:flex;flex-direction:column;padding-left:1.3rem;border-left:2px solid var(--paper)}
.about__points strong{font-weight:500;letter-spacing:.03em}
.about__points span{color:var(--fog);font-size:.9rem}

/* ===== SERVICES MENU ===== */
.services{padding:7rem 1.8rem;background:var(--ink-2);border-block:1px solid var(--line)}
.menu{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem 4rem}
.menu__group{margin-bottom:2.6rem}
.menu__group:last-child{margin-bottom:0}
.menu__cat{
  font-size:.8rem;letter-spacing:.26em;text-transform:uppercase;color:var(--fog);
  font-family:"Jost",sans-serif;font-weight:500;
  padding-bottom:1rem;margin-bottom:.6rem;border-bottom:1px solid var(--line);
}
.menu__group ul{list-style:none}
.menu__row{
  display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  padding:.85rem 0;border-bottom:1px dashed var(--line);transition:padding .3s var(--ease);
}
.menu__row:last-child{border-bottom:0}
.menu__row:hover{padding-left:.5rem}
.menu__name{font-size:1.15rem;font-family:"Cormorant Garamond",serif;font-weight:600;color:var(--paper)}
.menu__name em{font-style:normal;font-family:"Jost",sans-serif;font-weight:300;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fog);margin-left:.5rem}
.menu__price{white-space:nowrap;font-size:.82rem;letter-spacing:.08em;color:var(--paper-dim)}
.services__cta{text-align:center;margin-top:3.5rem;display:flex;flex-direction:column;align-items:center;gap:1.2rem}
.svc-note{color:var(--fog);font-size:.82rem;margin:0}

/* ===== OUR WORK GALLERY ===== */
.work{max-width:var(--maxw);margin:0 auto;padding:7rem 1.8rem}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.work-grid__item{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:1/1;background:var(--panel)}
.work-grid__item img{transition:transform .8s var(--ease)}
.work-grid__item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.35),transparent 45%);opacity:0;transition:opacity .4s var(--ease)}
.work-grid__item:hover img{transform:scale(1.06)}
.work-grid__item:hover::after{opacity:1}

/* ===== FEATURE ===== */
.feature{display:grid;grid-template-columns:1.15fr 1fr;align-items:stretch;min-height:62vh}
.feature__media{overflow:hidden}
.feature__copy{display:flex;flex-direction:column;justify-content:center;padding:5rem clamp(1.8rem,6vw,6rem)}
.feature__copy h2{font-size:clamp(2.2rem,4vw,3.4rem);margin-bottom:1.3rem}
.feature__copy p{color:var(--paper-dim);max-width:34rem;margin-bottom:2rem}

/* ===== VISIT ===== */
.visit{padding:7rem 1.8rem;background:var(--ink-2);border-top:1px solid var(--line)}
.visit__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.visit__media{min-height:520px;overflow:hidden}
.visit__panel{padding:clamp(2.4rem,5vw,4rem);background:var(--panel)}
.visit__panel h2{font-size:clamp(2.2rem,4vw,3.2rem);margin-bottom:2rem}
.visit__block{margin-bottom:2.2rem}
.visit__block h4{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--paper);
  font-family:"Jost",sans-serif;font-weight:500;margin-bottom:1rem}
.hours{list-style:none;display:grid;gap:.7rem}
.hours li{display:flex;justify-content:space-between;border-bottom:1px dashed var(--line);padding-bottom:.6rem;color:var(--paper-dim);font-size:.95rem}
.visit__line{color:var(--paper-dim);margin-bottom:.8rem;font-size:.98rem;line-height:1.5}
.visit__link{display:inline-block;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);border-bottom:1px solid var(--line);padding-bottom:.2rem;transition:border-color .3s,color .3s}
.visit__link:hover{color:#fff;border-color:#fff}
.visit__phone{display:inline-block;font-family:"Cormorant Garamond",serif;font-size:1.6rem;color:var(--paper);transition:color .3s}
.visit__phone:hover{color:#25d366}
.visit__actions{display:flex;gap:1rem;margin-top:.5rem;flex-wrap:wrap}
.visit__small{color:var(--fog);font-size:.78rem;margin-top:1.6rem}

/* ===== MAP / DIRECTIONS BAND ===== */
.map-card{
  max-width:var(--maxw);margin:1.4rem auto 0;
  display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;
  padding:2.2rem 2.4rem;border:1px solid var(--line);border-radius:var(--radius);
  background:
    repeating-linear-gradient(0deg,transparent 0 38px,rgba(255,255,255,.035) 38px 39px),
    repeating-linear-gradient(90deg,transparent 0 38px,rgba(255,255,255,.035) 38px 39px),
    radial-gradient(60% 120% at 18% 50%,rgba(255,255,255,.06),transparent 60%),
    var(--panel);
  transition:border-color .35s var(--ease),transform .35s var(--ease);
}
.map-card:hover{border-color:#42424a;transform:translateY(-3px)}
.map-card__pin{
  flex:none;display:grid;place-items:center;width:54px;height:54px;border-radius:50%;
  border:1px solid var(--line);background:var(--ink);color:var(--paper);
}
.map-card__text{display:flex;flex-direction:column;gap:.25rem;margin-right:auto}
.map-card__text strong{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:1.4rem}
.map-card__text span{color:var(--paper-dim);font-size:.92rem}
.map-card__cta{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);
  border:1px solid var(--line);padding:.85rem 1.5rem;border-radius:var(--radius);transition:all .35s var(--ease)}
.map-card:hover .map-card__cta{background:var(--paper);color:#0a0a0a;border-color:var(--paper)}

/* ===== FOOTER ===== */
.footer{padding:3.5rem 1.8rem 2rem;border-top:1px solid var(--line)}
.footer__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  gap:2rem;flex-wrap:wrap;padding-bottom:2.5rem;border-bottom:1px solid var(--line)}
.brand--footer .brand__logo{width:38px;height:38px}
.footer__links{display:flex;gap:1.8rem}
.footer__links a,.footer__social a{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--paper-dim);transition:color .3s}
.footer__links a:hover,.footer__social a:hover{color:#fff}
.footer__social{display:flex;gap:1.4rem}
.footer__copy{max-width:var(--maxw);margin:1.8rem auto 0;text-align:center;color:var(--fog);font-size:.78rem;letter-spacing:.05em}

/* ===== REVEAL ===== */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal].in{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:920px){
  .about__grid,.feature,.visit__grid{grid-template-columns:1fr}
  .menu{gap:2.4rem 3rem}
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .feature__media{min-height:46vh}
  .visit__media{min-height:340px}
  .feature{display:flex;flex-direction:column}
}
@media(max-width:680px){
  .nav__links,.nav__cta{
    position:fixed;top:0;right:0;height:100vh;width:74%;max-width:320px;
    flex-direction:column;justify-content:center;gap:2rem;
    background:rgba(10,10,10,.97);backdrop-filter:blur(16px);
    transform:translateX(100%);transition:transform .45s var(--ease);padding:2rem;
  }
  .nav__links{z-index:60;display:flex}
  .nav__cta{display:flex;z-index:60;top:auto;bottom:14%;height:auto;width:auto;right:50%;transform:translateX(50%) translateY(40px);opacity:0}
  .nav.open .nav__links{transform:none}
  .nav.open .nav__cta{transform:translateX(50%);opacity:1}
  .nav__toggle{display:flex;z-index:70}
  .nav.open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.open .nav__toggle span:nth-child(2){opacity:0}
  .nav.open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav__links a{font-size:1.1rem}
  .menu{grid-template-columns:1fr;gap:0}
  .work-grid{grid-template-columns:1fr 1fr;gap:.7rem}
  .stats{grid-template-columns:1fr}
  .stat{border-left:0;border-top:1px solid var(--line);padding:2rem 1.5rem}
  .stat:first-child{border-top:0}
  .about__imgs{grid-template-columns:1fr 1fr}
  .hero__actions .btn{flex:1}
  /* keep the rating clear of the scroll cue */
  .hero__scroll{display:none}
  .hero__inner{padding-bottom:4rem}
  /* the B&W mobile chair is already dark — lighten image + soften scrim */
  .hero__media img{filter:saturate(1) brightness(1) contrast(1.06)}
  .hero__scrim{background:
    radial-gradient(120% 100% at 50% 42%,rgba(8,8,8,.30),rgba(8,8,8,.66) 76%),
    linear-gradient(180deg,rgba(8,8,8,.5) 0%,rgba(8,8,8,.1) 36%,rgba(8,8,8,.4) 66%,rgba(8,8,8,.9) 100%);}
  /* Visit: stop the panel clipping off the right edge */
  .visit{padding:4.5rem 1.1rem}
  .visit__grid,.visit__media,.visit__panel{min-width:0}
  .visit__panel{padding:2rem 1.35rem}
  .visit__actions{flex-direction:column;align-items:stretch}
  .visit__actions .btn{width:100%}
  .visit__phone{font-size:1.4rem}
  .hours li{font-size:.9rem}
  /* Footer: center and let links wrap instead of clipping */
  .footer{padding:3rem 1.2rem 1.6rem}
  .footer__inner{justify-content:center;text-align:center}
  .footer__links,.footer__social{flex-wrap:wrap;justify-content:center;gap:.9rem 1.2rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  .hero__eyebrow,.hero__title,.hero__lede,.hero__actions,.hero__logo,.hero__scroll{opacity:1!important;transform:none!important}
}
