:root{
  --ink:#1c1916;
  --ink-soft:#28231f;
  --ink-line:rgba(244,239,230,.12);
  --cream:#f4efe6;
  --paper:#fbf8f2;
  --mahogany:#9a4f2b;
  --mahogany-bright:#d08552;
  --mahogany-deep:#6e371c;
  --barber-red:#b8392f;
  --text:#33291f;
  --steel-dark:#74695d;
  --steel-light:#c9c0b3;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:'Work Sans', sans-serif;
  background:var(--cream);
  color:var(--text);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3{
  font-family:'Oswald', sans-serif;
  text-transform:uppercase;
  line-height:1.08;
  font-weight:600;
  letter-spacing:.02em;
  color:var(--ink);
}

.section-inner{
  max-width:1180px;
  margin:0 auto;
  padding: clamp(4rem,9vw,7rem) clamp(1.25rem,5vw,2.5rem);
}

.eyebrow{
  font-family:'Space Mono', monospace;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--mahogany);
  margin-bottom:.9rem;
}
.eyebrow-light{ color:var(--mahogany-bright); }

.section-lead{
  max-width:46ch;
  font-size:1.05rem;
  color:var(--steel-dark);
  margin-bottom:2.5rem;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-family:'Oswald', sans-serif;
  text-transform:uppercase;
  letter-spacing:.1em;
  font-size:.85rem;
  font-weight:600;
  padding:.95rem 1.85rem;
  border-radius:2px;
  border:1px solid transparent;
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .15s ease;
  cursor:pointer;
}
.btn-primary{ background:var(--mahogany-bright); color:var(--ink); }
.btn-primary:hover{ background:#e29a6a; transform:translateY(-2px); }
.btn-ghost{ border-color:currentColor; }
.btn-ghost:hover{ background:rgba(244,239,230,.1); transform:translateY(-2px); }

a:focus-visible, button:focus-visible{
  outline:2px solid var(--mahogany-bright);
  outline-offset:3px;
}
.skip-link{
  position:absolute; left:-999px; top:0;
  background:var(--mahogany-bright); color:var(--ink);
  padding:.6rem 1.1rem; z-index:999;
  font-family:'Space Mono',monospace; font-size:.85rem;
}
.skip-link:focus{ left:0; }

/* ---------- signature stripe divider (barber pole) ---------- */
.stripe{
  height:14px;
  background:repeating-linear-gradient(45deg,
    var(--cream) 0 22px,
    var(--ink) 22px 44px,
    var(--mahogany) 44px 66px,
    var(--barber-red) 66px 88px);
}

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(28,25,22,.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--ink-line);
}
.nav-inner{
  max-width:1180px; margin:0 auto;
  padding:.8rem clamp(1.25rem,5vw,2.5rem);
  display:flex; align-items:center; gap:2rem;
  position:relative;
}
.brand{ display:flex; align-items:center; gap:.75rem; margin-right:auto; color:var(--cream); }
.brand-mark{
  height:46px; width:46px; object-fit:contain;
  background:var(--cream);
  border-radius:50%;
  padding:5px;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.brand-text{ font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:.95rem; letter-spacing:.04em; line-height:1.25; }
.brand-text span{ display:block; font-size:.65rem; letter-spacing:.32em; color:var(--steel-light); }

.nav-links{
  display:flex; gap:1.85rem; align-items:center;
  font-family:'Oswald',sans-serif; font-size:.85rem; letter-spacing:.06em;
}
.nav-links a{
  position:relative;
  color:var(--steel-light); font-weight:600; text-transform:uppercase;
  white-space:nowrap; padding-bottom:.45rem;
  transition:color .2s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:3px; background:var(--mahogany-bright);
  transform:scaleX(0); transform-origin:left;
  transition:transform .25s ease;
}
.nav-links a:hover{ color:var(--cream); }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-links a.nav-cta-inline{ color:var(--ink); padding-bottom:0; }
.nav-links a.nav-cta-inline::after{ display:none; }
.nav-cta{ color:var(--ink); white-space:nowrap; }

.nav-toggle{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:30px; height:24px; background:none; border:0; cursor:pointer; padding:0;
}
.nav-toggle span{ display:block; height:2px; width:100%; background:var(--cream); transition:transform .2s, opacity .2s; }

.nav-cta-inline{ display:none; }

@media (max-width:840px){
  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:flex-start; gap:1.1rem;
    background:var(--ink);
    padding:0 clamp(1.25rem,5vw,2.5rem);
    max-height:0; overflow:hidden;
    border-bottom:1px solid var(--ink-line);
    transition:max-height .3s ease, padding .3s ease;
  }
  .nav-links.is-open{ max-height:360px; padding:1.5rem clamp(1.25rem,5vw,2.5rem) 1.75rem; }
  .nav-toggle{ display:flex; }
  .nav-cta{ display:none; }
  .nav-cta-inline{ display:inline-flex; margin-top:.4rem; }
}
@media (max-width:380px){
  .brand-text{ font-size:.85rem; }
}

/* ---------- hero ---------- */
.hero{
  position:relative; min-height:100vh;
  display:flex; align-items:center;
  color:var(--cream); overflow:hidden;
}
.hero-media{
  position:absolute; inset:0;
  background:url('images/interior.jpg') center 58% / cover no-repeat;
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(28,25,22,.45) 0%, rgba(28,25,22,.78) 55%, rgba(28,25,22,.97) 100%);
}
.hero-content{
  position:relative; z-index:2;
  max-width:1180px; width:100%;
  margin:0 auto;
  padding: 7rem clamp(1.25rem,5vw,2.5rem) 4rem;
}
.hero-content h1{
  font-size:clamp(3rem, 11vw, 6.75rem);
  font-weight:700; letter-spacing:.02em;
  color:var(--cream);
}
.hero-content h1 span{
  display:block;
  font-size:.42em;
  letter-spacing:.42em;
  color:var(--mahogany-bright);
  margin-top:.35em;
}
.hero-lead{
  max-width:42ch; font-size:1.1rem;
  color:var(--steel-light);
  margin:1.75rem 0 1.5rem;
}
.hero-rating{
  display:flex; align-items:center; gap:.6rem;
  font-family:'Space Mono',monospace; font-size:.9rem;
  color:var(--steel-light); margin-bottom:2.25rem;
}
.hero-rating .stars{ color:var(--mahogany-bright); letter-spacing:.12em; }
.hero-actions{ display:flex; gap:1rem; flex-wrap:wrap; }
.hero-actions .btn-ghost{ border-color:var(--steel-light); }

/* ---------- about ---------- */
.about{ background:var(--cream); }
.about-grid{
  display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(2rem,6vw,4.5rem); align-items:center;
}
.about-text p{ margin-bottom:1.1rem; }
.about-facts{
  list-style:none; display:flex; flex-wrap:wrap; gap:.65rem;
  margin-top:1.5rem;
}
.about-facts li{
  font-family:'Space Mono',monospace; font-size:.82rem;
  border:1px solid var(--ink); padding:.5rem .95rem; border-radius:2px;
}
.about-facts li strong{ color:var(--mahogany); margin-right:.4rem; }
.about-photo{
  border-radius:4px; overflow:hidden;
  box-shadow:0 25px 60px -25px rgba(28,25,22,.45);
  aspect-ratio:4/3;
}
.about-photo img{ width:100%; height:100%; object-fit:cover; }

@media (max-width:900px){
  .about-grid{ grid-template-columns:1fr; }
  .about-photo{ order:-1; }
}

/* ---------- services ---------- */
.services{ background:var(--ink); color:var(--cream); }
.services h2, .services .eyebrow{ color:var(--cream); }
.services .eyebrow{ color:var(--mahogany-bright); }
.services .section-lead{ color:var(--steel-light); }

.ticket-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(260px,1fr));
  gap:1.25rem;
}
.ticket{
  position:relative; background:var(--ink-soft);
  padding:1.85rem 1.5rem 1.5rem 2.35rem; border-radius:2px;
  display:flex; flex-direction:column; justify-content:space-between;
  min-height:188px;
}
.ticket::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:9px;
  background:repeating-linear-gradient(135deg,
    var(--cream) 0 5px, var(--ink) 5px 10px,
    var(--mahogany-bright) 10px 15px, var(--barber-red) 15px 20px);
}
.ticket h3{ color:var(--cream); font-size:1.15rem; margin-bottom:.5rem; }
.ticket p{ color:var(--steel-light); font-size:.92rem; margin-bottom:1.5rem; }
.ticket-foot{
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; border-top:1px solid var(--ink-line); padding-top:1rem;
}
.price{ font-family:'Space Mono',monospace; font-weight:700; font-size:1.2rem; color:var(--mahogany-bright); }
.ticket-link{
  font-family:'Space Mono',monospace; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.1em; color:var(--cream);
  border-bottom:1px solid transparent; transition:color .2s, border-color .2s;
}
.ticket-link:hover{ color:var(--mahogany-bright); border-color:var(--mahogany-bright); }
.ticket .badge{
  position:absolute; top:-.6rem; right:1.1rem;
  background:var(--mahogany-bright); color:var(--ink);
  font-family:'Space Mono',monospace; font-size:.68rem; text-transform:uppercase;
  letter-spacing:.12em; padding:.28rem .65rem; border-radius:2px;
}

/* ---------- gallery ---------- */
.gallery{ background:var(--cream); }
.gallery-grid{
  display:grid; grid-template-columns:2fr 1fr; gap:1.25rem; align-items:stretch;
}
.gallery-item{
  position:relative; overflow:hidden; border-radius:4px;
  box-shadow:0 25px 60px -25px rgba(28,25,22,.4);
}
.gallery-item img{ width:100%; height:100%; object-fit:cover; }
.gallery-item.is-wide{ aspect-ratio:16/10.2; }
.gallery-item figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding:.85rem 1.1rem;
  font-family:'Space Mono',monospace; font-size:.78rem; letter-spacing:.06em;
  color:var(--cream);
  background:linear-gradient(180deg, transparent, rgba(28,25,22,.85));
}
@media (max-width:860px){
  .gallery-grid{ grid-template-columns:1fr; }
  .gallery-item.is-wide{ aspect-ratio:16/10; }
  .gallery-item:not(.is-wide){ aspect-ratio:4/3; }
}

/* ---------- reviews ---------- */
.reviews{ background:var(--ink); color:var(--cream); }
.reviews h2, .reviews .eyebrow{ color:var(--cream); }
.reviews .eyebrow{ color:var(--mahogany-bright); }
.reviews-head{
  display:flex; flex-wrap:wrap; justify-content:space-between;
  align-items:flex-end; gap:2rem; margin-bottom:2.75rem;
}
.rating-badge{ font-family:'Space Mono',monospace; text-align:right; }
.rating-number{ font-size:3rem; font-weight:700; color:var(--mahogany-bright); display:block; line-height:1; }
.rating-badge .stars{ color:var(--mahogany-bright); letter-spacing:.18em; }
.rating-count{ display:block; color:var(--steel-light); font-size:.85rem; margin-top:.4rem; }

.review-track-wrap{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.review-track{
  display:flex; width:max-content;
}
.review-card{
  flex:0 0 min(340px, 80vw); margin-right:1.25rem;
  background:var(--ink-soft); padding:1.85rem;
  border-radius:2px; border-top:3px solid var(--mahogany-bright);
}
.review-card p{ font-size:1rem; margin-bottom:1.1rem; color:var(--cream); }
.review-card cite{ font-family:'Space Mono',monospace; font-size:.8rem; color:var(--steel-light); font-style:normal; }
.reviews-actions{ margin-top:2.5rem; }

@media (prefers-reduced-motion: no-preference){
  .review-track{ animation:review-scroll 38s linear infinite; }
  .review-track-wrap:hover .review-track,
  .review-track-wrap:focus-within .review-track{ animation-play-state:paused; }
}
@keyframes review-scroll{
  from{ transform:translateX(-50%); }
  to{ transform:translateX(0%); }
}
@media (prefers-reduced-motion: reduce){
  .review-track-wrap{ overflow-x:auto; -webkit-mask-image:none; mask-image:none; }
  .review-track .review-card[aria-hidden="true"]{ display:none; }
}

/* ---------- footer ---------- */
.site-footer{ background:var(--ink-soft); color:var(--steel-light); }
.footer-grid{
  display:grid; grid-template-columns:1.2fr .9fr .9fr 1.3fr;
  gap:2.75rem;
}
.footer-brand img{
  height:60px; margin-bottom:1rem;
  background:var(--cream); border-radius:50%; padding:6px;
}
.footer-brand p{ margin-bottom:.9rem; max-width:28ch; }
.footer-ig{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:'Space Mono',monospace; font-size:.85rem; color:var(--mahogany-bright);
}
.footer-col h3{
  font-family:'Oswald',sans-serif; text-transform:uppercase; letter-spacing:.08em;
  font-size:.95rem; color:var(--cream); margin-bottom:1.1rem;
}
.footer-col p{ margin-bottom:.6rem; }
.footer-col a{ color:var(--mahogany-bright); }
.footer-col .btn{ margin-top:.75rem; }
.hours-table{ font-family:'Space Mono',monospace; font-size:.85rem; width:100%; border-collapse:collapse; }
.hours-table td{ padding:.4rem 0; border-bottom:1px solid var(--ink-line); }
.hours-table td:last-child{ text-align:right; color:var(--cream); white-space:nowrap; }
.footer-map{ border-radius:2px; overflow:hidden; }
.footer-map iframe{ width:100%; height:210px; border:0; filter:grayscale(.35) contrast(1.05); display:block; }
.footer-bottom{
  border-top:1px solid var(--ink-line);
  padding:1.4rem clamp(1.25rem,5vw,2.5rem);
  text-align:center; font-family:'Space Mono',monospace; font-size:.78rem;
  letter-spacing:.04em;
}
@media (max-width:900px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .footer-grid{ grid-template-columns:1fr; }
}

/* ---------- reveal animation ---------- */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
  .reveal.is-visible{ opacity:1; transform:none; }
}