/* ============================================================
   THE BARBER SHOP — W Broadway · "brass ledger"
   Mobile-first responsive system. X9 Lab Media draft proposal.
   ============================================================ */

:root{
  /* base — warm espresso */
  --ink:        #15110c;
  --ink-2:      #1d1812;
  --ink-3:      #261f16;
  --hair-dark:  rgba(206,178,120,0.22);

  /* ledger paper */
  --paper:      #ece2cd;
  --paper-2:    #e3d8bf;
  --paper-ink:  #2a2317;
  --paper-mute: #6f6450;
  --sanguine:   #9c4a32;

  /* metal accent (overridable by Tweaks) */
  --m1: #f4e1ad;
  --m2: #cda85f;
  --m3: #8a6630;
  --metal-solid: #c49a52;

  /* text on dark */
  --cream:      #efe7d4;
  --cream-mute: rgba(239,231,212,0.56);
  --cream-faint:rgba(239,231,212,0.30);

  --wrap: 1240px;
  --gutter: clamp(20px, 5vw, 56px);
  --nav-h: 66px;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--ink);
  color:var(--cream);
  font-family:"Newsreader", Georgia, serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* page root + film grain (fixed so it covers the whole scroll) */
.tbs{ position:relative; }
.tbs::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
  opacity:0.045; mix-blend-mode:overlay;
}
.tbs > *{ position:relative; z-index:1; }

/* ---------- layout container ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
section{ padding-block:clamp(64px, 9vw, 132px); position:relative; scroll-margin-top:calc(var(--nav-h) + 10px); }

/* ---------- fonts ---------- */
.f-display{ font-family:"Cormorant Garamond", Georgia, serif; }
.f-body{ font-family:"Newsreader", Georgia, serif; }
.f-mono{ font-family:"IBM Plex Mono", ui-monospace, monospace; }

/* ---------- metal text ---------- */
.metal{
  background:linear-gradient(176deg, var(--m1) 0%, var(--m2) 46%, var(--m3) 100%);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  text-shadow:0 1px 0 rgba(0,0,0,0.18);
}
.metal-line{ background:linear-gradient(90deg,var(--m3),var(--m2),var(--m1),var(--m2),var(--m3)); }

/* ---------- eyebrow / labels ---------- */
.eyebrow{
  font-family:"IBM Plex Mono", monospace;
  font-size:12px; letter-spacing:0.32em; text-transform:uppercase;
  font-weight:700;
}

/* section heading helpers */
.h-sec{ font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:600; line-height:1.02;
  font-size:clamp(2rem, 4.4vw, 3.4rem); letter-spacing:-0.01em; margin:14px 0 0; }
.prose{ max-width:70ch; }
.prose p{ font-size:clamp(1.05rem, 1.4vw, 1.2rem); line-height:1.62; color:rgba(239,231,212,0.82); margin:0 0 1.1em; }
.prose.on-dark p:last-child{ margin-bottom:0; }

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50; height:var(--nav-h);
  background:rgba(21,17,12,0.78); backdrop-filter:blur(12px) saturate(1.2);
  border-bottom:1px solid var(--hair-dark);
}
.nav .wrap{ height:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.nav-mark{ font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:600;
  font-size:23px; color:var(--cream); text-decoration:none; white-space:nowrap; letter-spacing:0.01em; }
.nav-mark b{ font-weight:600; }
.nav-links{ display:none; align-items:center; gap:clamp(18px,2.4vw,34px); margin-left:auto; }
.nav-links a{
  font-family:"IBM Plex Mono",monospace; font-size:11.5px; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--cream-mute); text-decoration:none; transition:color .25s; white-space:nowrap;
}
.nav-links a:hover{ color:var(--m1); }
.nav-tel{
  font-family:"IBM Plex Mono",monospace; font-size:12px; font-weight:700; letter-spacing:0.12em;
  color:var(--ink); text-decoration:none; padding:9px 16px; border-radius:3px; white-space:nowrap;
  background:linear-gradient(177deg, var(--m1), var(--m2) 60%, var(--m3));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5);
}
.nav-tel.is-desktop{ display:none; }
.burger{
  display:inline-flex; flex-direction:column; gap:5px; width:42px; height:42px;
  align-items:center; justify-content:center; background:transparent; border:1px solid var(--hair-dark);
  border-radius:4px; cursor:pointer; margin-left:auto;
}
.burger span{ display:block; width:18px; height:1.5px; background:var(--cream); transition:.3s; }
.nav.open .burger span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.nav.open .burger span:nth-child(2){ opacity:0; }
.nav.open .burger span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

.nav-menu{
  position:fixed; top:var(--nav-h); left:0; right:0; z-index:49;
  background:rgba(21,17,12,0.97); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--hair-dark);
  display:grid; gap:2px; padding:10px var(--gutter) 22px;
  transform:translateY(-12px); opacity:0; pointer-events:none; transition:.32s cubic-bezier(.2,.8,.2,1);
}
.nav-menu.open{ transform:none; opacity:1; pointer-events:auto; }
.nav-menu a{
  font-family:"IBM Plex Mono",monospace; font-size:13px; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--cream); text-decoration:none; padding:16px 4px; border-bottom:1px solid var(--hair-dark);
}
.nav-menu a:last-of-type{ border-bottom:0; }
.nav-menu .menu-tel{ margin-top:14px; }

@media (min-width:820px){
  .nav-links{ display:flex; }
  .nav-tel.is-desktop{ display:inline-block; }
  .burger{ display:none; }
}

/* ---------- buttons ---------- */
.btn-brass{
  appearance:none; border:0; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:"IBM Plex Mono", monospace; font-weight:700;
  font-size:13px; letter-spacing:0.18em; text-transform:uppercase;
  color:#231806; padding:17px 26px; border-radius:3px; min-height:52px;
  background:linear-gradient(177deg, var(--m1) 0%, var(--m2) 52%, var(--m3) 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.55), inset 0 -2px 3px rgba(0,0,0,0.28), 0 10px 24px -10px rgba(0,0,0,0.7);
  position:relative; overflow:hidden; text-decoration:none; white-space:nowrap;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s;
}
.btn-brass::after{
  content:""; position:absolute; top:0; bottom:0; width:42%; left:-60%; transform:skewX(-18deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.55),transparent);
  animation:sheen 4.6s ease-in-out infinite;
}
.btn-brass:hover{ transform:translateY(-2px); box-shadow:inset 0 1px 0 rgba(255,255,255,0.6), inset 0 -2px 3px rgba(0,0,0,0.3), 0 16px 30px -12px rgba(0,0,0,0.8); }
.btn-brass:active{ transform:translateY(0) scale(0.99); }
@keyframes sheen{ 0%{left:-60%} 28%{left:130%} 100%{left:130%} }

.btn-ghost{
  appearance:none; cursor:pointer; background:transparent; display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:1px solid var(--hair-dark);
  font-family:"IBM Plex Mono", monospace; font-weight:700;
  font-size:12.5px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--cream); padding:16px 24px; border-radius:3px; min-height:52px; text-decoration:none; white-space:nowrap;
  transition:border-color .25s, color .25s, background .25s;
}
.btn-ghost:hover{ border-color:var(--m2); color:var(--m1); background:rgba(205,168,95,0.06); }

.link-quiet{
  appearance:none; cursor:pointer; background:transparent; border:0; text-decoration:none;
  font-family:"IBM Plex Mono", monospace; font-weight:500;
  font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--cream-mute); padding:8px 2px; transition:color .25s; display:inline-block;
}
.link-quiet:hover{ color:var(--m1); }

/* ---------- barber pole ---------- */
.pole-wrap{ display:inline-flex; flex-direction:column; align-items:center; }
.pole-cap{
  width:46px; height:14px; border-radius:3px;
  background:linear-gradient(180deg,var(--m1),var(--m2) 55%,var(--m3));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 2px 5px rgba(0,0,0,.5);
}
.pole-glass{
  width:34px; height:148px; overflow:hidden; position:relative; border-radius:5px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.35), 0 6px 22px -6px rgba(0,0,0,.7);
}
.pole-stripes{
  position:absolute; inset:-50% 0;
  background:repeating-linear-gradient(-62deg,
    #b23a2c 0 13px, #efe7d4 13px 26px, #2a3f6b 26px 39px, #efe7d4 39px 52px);
  animation:poleSpin 2.4s linear infinite;
}
.pole-glass::after{
  content:""; position:absolute; inset:0; border-radius:5px;
  background:linear-gradient(90deg, rgba(0,0,0,.34) 0%, rgba(255,255,255,.34) 28%, rgba(255,255,255,.05) 50%, rgba(0,0,0,.3) 100%);
}
@keyframes poleSpin{ to{ background-position:0 52px; } }

/* ---------- rules / ornament ---------- */
.dbl{ display:flex; flex-direction:column; }
.dbl .thick{ height:2px; }
.dbl .thin{ height:1px; margin-top:3px; opacity:0.5; }
.ornament{ display:flex; align-items:center; gap:14px; color:var(--m2); font-size:12px; letter-spacing:0.3em; }
.ornament::before,.ornament::after{ content:""; flex:1; height:1px; background:linear-gradient(90deg,transparent,var(--m3),transparent); }

/* ---------- HERO ---------- */
.hero{ padding-top:calc(var(--nav-h) + clamp(40px,7vw,86px)); padding-bottom:clamp(56px,8vw,110px); overflow:hidden; }
.hero-top{ display:flex; justify-content:space-between; align-items:center; gap:16px; margin-bottom:clamp(28px,4vw,46px); flex-wrap:wrap; }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:clamp(36px,5vw,64px); align-items:center; }
.hero-mark{ font-family:"IBM Plex Mono",monospace; font-size:12px; letter-spacing:0.34em; text-transform:uppercase; color:var(--cream-mute); margin-bottom:20px; }
.hero h1{
  margin:0; font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:700;
  font-size:clamp(2.4rem, 5.4vw, 4.8rem); line-height:1.0; letter-spacing:-0.015em;
}
.hero h1 span{ display:block; white-space:nowrap; }
.hero-lede{ max-width:52ch; margin:clamp(20px,2.6vw,30px) 0 clamp(26px,3vw,34px);
  font-size:clamp(1.05rem,1.45vw,1.22rem); line-height:1.58; color:var(--cream-mute); }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }

.hero-visual{ position:relative; }
.hero-visual .ph{ width:100%; height:clamp(280px, 56vw, 540px); border-radius:6px; }
.hero-visual .pole-host{ position:absolute; left:18px; bottom:22px; }

@media (min-width:1024px){
  .hero-grid{ grid-template-columns:1.15fr 0.85fr; align-items:stretch; }
  .hero-copy{ align-self:center; }
  .hero-visual .ph{ height:min(620px, 62vh); }
}

/* ---------- MARQUEE ---------- */
.marquee{ overflow:hidden; white-space:nowrap; border-top:1px solid var(--hair-dark); border-bottom:1px solid var(--hair-dark); background:var(--ink-2); padding:14px 0; }
.marquee-track{ display:inline-flex; gap:0; animation:marquee 30s linear infinite; }
.marquee-track > span{ display:inline-flex; }
.marquee-track span span{ font-family:"IBM Plex Mono",monospace; font-size:13px; font-weight:700; letter-spacing:0.26em; text-transform:uppercase; color:var(--cream-mute); padding:0 26px; display:inline-flex; align-items:center; gap:26px; }
.marquee-track span span::after{ content:"✦"; color:var(--m2); font-size:9px; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- ESSAY (asymmetric) ---------- */
.essay-grid{ display:grid; grid-template-columns:1fr; gap:clamp(24px,4vw,56px); }
.essay-head .h-sec{ margin-top:14px; }
.pullquote{ font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:600;
  font-size:clamp(1.5rem,2.4vw,2rem); line-height:1.24; color:var(--sanguine);
  border-left:2px solid var(--sanguine); padding-left:22px; margin:1.4em 0 0; max-width:24ch; }
.dropcap::first-letter{ font-family:"Cormorant Garamond",serif; font-weight:700; float:left; font-size:3.6em; line-height:0.74; padding:0.06em 0.12em 0 0; color:var(--m2); }
@media (min-width:1024px){
  .essay-grid{ grid-template-columns:0.82fr 1.18fr; gap:clamp(40px,5vw,80px); }
  .essay-head{ position:sticky; top:calc(var(--nav-h) + 28px); align-self:start; }
  .essay.flip .essay-head{ order:2; }
}

/* ---------- LEDGER ---------- */
.paper{ background:linear-gradient(0deg, var(--paper-2), var(--paper)); color:var(--paper-ink); }
.paper::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:0.4;
  background:repeating-linear-gradient(180deg, transparent 0 33px, rgba(60,90,120,0.13) 33px 34px);
}
.paper .eyebrow{ color:var(--sanguine); }
.ledger-sheet{ max-width:920px; margin-inline:auto; }
.ledger-list{ display:grid; grid-template-columns:1fr; gap:0 56px; margin-top:8px; }
@media (min-width:760px){ .ledger-list{ grid-template-columns:1fr 1fr; } }
.ledger-row{
  display:flex; align-items:baseline; gap:12px; padding:16px 2px; position:relative;
  border-bottom:1px solid rgba(42,35,23,0.16);
}
.ledger-no{ font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--paper-mute); width:24px; flex:none; }
.ledger-name{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:23px; font-weight:600; line-height:1; }
.ledger-sub{ font-family:"IBM Plex Mono",monospace; font-size:10.5px; color:var(--paper-mute); letter-spacing:.04em; margin-top:4px; display:block; }
.ledger-lead{ flex:1; border-bottom:1.5px dotted rgba(42,35,23,0.4); transform:translateY(-4px); min-width:18px; }
.ledger-price{ font-family:"IBM Plex Mono",monospace; font-size:16px; font-weight:600; letter-spacing:.02em; color:var(--sanguine); }

/* ---------- CARD GRID (bench) ---------- */
.card-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:clamp(16px,2vw,26px); }
.bench-card .ph{ width:100%; aspect-ratio:3/4; border-radius:5px; margin-bottom:14px; }
.bench-card h3{ margin:0; font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:600; font-size:22px; color:var(--cream-mute); }
.bench-meta{ display:flex; justify-content:space-between; align-items:baseline; }

/* ---------- GALLERY ---------- */
.gallery{ background:var(--ink-2); }
.gal-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(10px,1.4vw,16px); grid-auto-rows:1fr; }
.gal-grid .ph{ width:100%; aspect-ratio:1/1; border-radius:4px; }
@media (min-width:760px){ .gal-grid{ grid-template-columns:repeat(3,1fr); } .gal-grid .ph.tall{ grid-row:span 2; aspect-ratio:auto; height:100%; } }
@media (min-width:1100px){ .gal-grid{ grid-template-columns:repeat(4,1fr); } }

/* ---------- RATING band ---------- */
.rating{ text-align:center; }
.rating .big{ font-family:"Cormorant Garamond",serif; font-weight:600; line-height:0.86; font-size:clamp(5rem, 12vw, 9rem); }

/* ---------- VISIT ---------- */
.visit-grid{ display:grid; grid-template-columns:1fr; gap:clamp(26px,3.5vw,44px); align-items:stretch; }
.visit-map{ position:relative; min-height:300px; border-radius:6px; overflow:hidden; border:1px solid var(--hair-dark); }
.visit-map iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; filter:grayscale(0.35) contrast(0.96) sepia(0.12); }
.visit-info{ display:flex; flex-direction:column; }
.hours-card{ border:1px solid var(--hair-dark); border-radius:6px; overflow:hidden; }
.hours-row{ display:flex; justify-content:space-between; padding:13px 16px; }
.hours-row + .hours-row{ border-top:1px solid var(--hair-dark); }
.hours-row:nth-child(even){ background:rgba(255,255,255,0.012); }
@media (min-width:860px){ .visit-grid{ grid-template-columns:1.25fr 0.75fr; } .visit-map{ min-height:440px; } }

/* ---------- FOOTER ---------- */
.tbs-foot{ border-top:1px solid var(--hair-dark); padding-block:clamp(46px,6vw,72px); text-align:center; }

/* ---------- placeholder ---------- */
.ph{ position:relative; overflow:hidden; background:var(--ink-3); display:flex; align-items:flex-end; border:1px solid var(--hair-dark); }
.ph::before{ content:""; position:absolute; inset:0; background:repeating-linear-gradient(45deg, rgba(206,178,120,0.07) 0 9px, transparent 9px 18px); }
.ph.on-paper{ background:var(--paper-2); border-color:rgba(42,35,23,0.2); }
.ph.on-paper::before{ background:repeating-linear-gradient(45deg, rgba(42,35,23,0.08) 0 9px, transparent 9px 18px); }
.ph-cap{ position:relative; margin:12px; font-family:"IBM Plex Mono",monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--cream-mute); background:rgba(0,0,0,.34); padding:5px 8px; border-radius:2px; backdrop-filter:blur(2px); }
.ph.on-paper .ph-cap{ color:var(--paper-mute); background:rgba(255,255,255,.45); }

/* ---------- reveal (transform-only; never hides content) ---------- */
.reveal{ transform:translateY(24px); transition:transform .85s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ transform:none; }

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  .reveal{ transform:none; transition:none; }
  .pole-stripes,.marquee-track,.btn-brass::after{ animation:none; }
  .btn-brass::after{ left:130%; }
}
.no-motion .reveal{ transform:none; transition:none; }
.no-motion .pole-stripes,.no-motion .marquee-track,.no-motion .btn-brass::after{ animation:none; }
.no-motion .btn-brass::after{ left:130%; }
