/* ============================================================
   THE BARBER SHOP — component styles
   ============================================================ */

/* ---------- HERO ---------- */
.hero{ padding-top:34px; padding-bottom:0; }
.hero-head{ margin-bottom:22px; }
.hero h1{ margin:14px 0 0; }
.hero-lede{
  font-family:var(--ff-body); font-size:16.5px; line-height:1.56;
  color:var(--ink-soft); margin-top:22px; text-wrap:pretty; max-width:40ch;
}
.hero .est{
  font-family:var(--ff-mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-mute); margin-top:18px; display:flex; gap:16px; align-items:center;
}
.hero .est .ln{ flex:1; height:1px; background:var(--line); }
.hero-img-wrap{
  position:relative; margin:26px calc(var(--pad) * -1) 0; overflow:hidden;
}
.hero-img{ height:62vh; min-height:380px; max-height:560px; width:100%; }
.hero-img .ph-tag{ margin:14px; }
.hero-pole{
  position:absolute; left:0; top:0; bottom:0; width:8px; z-index:3;
  background:repeating-linear-gradient(180deg,
     var(--oxblood) 0 14px, var(--cream) 14px 28px, var(--brass) 28px 42px);
  background-size:100% 56px;
  animation:poleScroll 2.4s linear infinite;
  box-shadow:1px 0 0 var(--line);
}
@keyframes poleScroll{ to{ background-position:0 -56px; } }
.hero-float{
  position:absolute; right:14px; bottom:14px; z-index:4;
  background:var(--cream); border:1px solid var(--line);
  padding:12px 14px; max-width:200px;
}
.hero-float .meta{ display:block; margin-bottom:4px; color:var(--brass-2); }
.hero-float p{ font-family:var(--ff-display); font-style:italic; font-size:16px; line-height:1.25; color:var(--ink); }

/* headline lines — visible by default; JS animates when the clock is live */
.hl-line{ display:block; opacity:1; }

/* ---------- ESSAY ---------- */
.essay{ background:var(--cream); }
.essay-body{ font-size:21px; line-height:1.62; color:var(--ink); font-weight:400; text-wrap:pretty; }
.essay-body .drop{
  float:left; font-family:var(--ff-display); font-weight:700;
  font-size:78px; line-height:.74; margin:6px 12px 0 0; color:var(--oxblood);
}
.essay-body p+p{ margin-top:20px; }
.essay-sign{
  font-family:var(--ff-display); font-style:italic; font-size:22px; color:var(--ink-soft);
  margin-top:26px;
}

/* ---------- SERVICES ---------- */
.svc-list{ margin-top:30px; border-top:1px solid var(--line); }
.svc{
  display:flex; align-items:baseline; gap:14px; padding:18px 0;
  border-bottom:1px solid var(--line); cursor:pointer;
  transition:padding-left .35s var(--ease);
}
.svc:hover{ padding-left:10px; }
.svc-name{ font-family:var(--ff-display); font-size:25px; font-weight:600; color:var(--ink); white-space:nowrap; }
.svc:hover .svc-name{ font-style:italic; }
.svc-dots{ flex:1; border-bottom:1.5px dotted var(--line); transform:translateY(-5px); }
.svc-price{ font-family:var(--ff-mono); font-size:15px; font-weight:600; color:var(--ink); }
.svc-sub{ font-family:var(--ff-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-mute); margin-top:3px; }
.svc-foot{ margin-top:24px; }

/* ---------- BARBERS ---------- */
.barbers{ background:var(--paper); }
.barber-rail{
  display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory;
  margin:28px calc(var(--pad) * -1) 0; padding:4px var(--pad) 16px;
  -webkit-overflow-scrolling:touch;
}
.barber-rail::-webkit-scrollbar{ height:0; }
.barber-card{ flex:0 0 75%; scroll-snap-align:center; }
.barber-supply{ display:flex; flex-direction:column; gap:14px; }
.barber-ph{ aspect-ratio:3/4; }
.barber-info{ display:flex; justify-content:space-between; align-items:baseline; margin-top:12px; }
.barber-name{ font-family:var(--ff-display); font-size:24px; font-weight:600; }
.barber-yrs{ font-family:var(--ff-mono); font-size:11px; color:var(--brass-2); letter-spacing:.08em; }
.barber-role{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); margin-top:4px; }
.rail-hint{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); margin-top:6px; display:flex; gap:8px; align-items:center; }

/* ---------- GALLERY ---------- */
.gallery{ background:var(--espresso); }
.gal-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:26px; }
.gal-grid .ph{ aspect-ratio:1; }
.gal-grid .tall{ aspect-ratio:1/1.5; grid-row:span 2; }

/* ---------- REVIEWS ---------- */
.reviews{ background:var(--cream); }
.rev{ padding:26px 0; border-bottom:1px solid var(--line); }
.rev:last-child{ border-bottom:none; }
.rev-stars{ color:var(--brass-2); font-size:14px; letter-spacing:3px; }
.rev-quote{ font-family:var(--ff-display); font-size:22px; line-height:1.3; font-weight:500; margin:12px 0; text-wrap:pretty; }
.rev-by{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); }

/* ---------- LOCATION ---------- */
.location{ background:var(--espresso); color:var(--cream); }
.hours-row{ display:flex; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--line-cream); font-family:var(--ff-mono); font-size:13px; letter-spacing:.04em; }
.hours-row.closed{ color:oklch(0.62 0.01 80); }
.hours-row .day{ text-transform:uppercase; font-size:11px; letter-spacing:.14em; }
.map-ph{ aspect-ratio:16/10; margin-top:24px; }

/* ============================================================
   BOOKING SHEET
   ============================================================ */
.sheet-scrim{
  position:fixed; inset:0; z-index:200;
  background:oklch(0.13 0.01 50 / .55);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  opacity:0; pointer-events:none; transition:opacity .4s var(--ease);
  display:flex; justify-content:center; align-items:flex-end;
}
.sheet-scrim.open{ opacity:1; pointer-events:auto; }
.sheet{
  position:relative; width:100%; max-width:var(--maxw);
  background:var(--cream); color:var(--ink);
  border-radius:26px 26px 0 0;
  transform:translateY(101%); transition:transform .5s var(--ease-out);
  max-height:92%; display:flex; flex-direction:column;
  box-shadow:0 -20px 60px oklch(0 0 0 / .4);
}
.sheet-scrim.open .sheet{ transform:none; }
@media (min-width:520px){ .sheet{ border-radius:26px; margin-bottom:0; } .sheet-scrim{ align-items:center; padding:20px; } }
.sheet-grip{ width:38px; height:4px; border-radius:4px; background:var(--line); margin:12px auto 0; }
.sheet-head{ padding:14px var(--pad) 16px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--line); }
.sheet-steps{ display:flex; gap:6px; }
.step-pip{ width:24px; height:3px; border-radius:3px; background:var(--line); transition:background .3s; }
.step-pip.active{ background:var(--oxblood); }
.step-pip.done{ background:var(--brass); }
.sheet-close{ background:none; border:none; cursor:pointer; font-family:var(--ff-mono); font-size:18px; color:var(--ink-mute); line-height:1; }
.sheet-body{ padding:22px var(--pad); overflow-y:auto; flex:1; }
.sheet-body::-webkit-scrollbar{ width:0; }
.step-q{ font-family:var(--ff-display); font-size:30px; font-weight:600; line-height:1; margin-bottom:4px; }
.step-hint{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:20px; }

.opt{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px; border:1px solid var(--line); border-radius:14px; cursor:pointer;
  margin-bottom:10px; background:var(--cream);
  transition:border-color .25s, background .25s, transform .15s;
}
.opt:active{ transform:scale(.99); }
.opt.sel{ border-color:var(--ink); background:var(--paper); }
.opt-main{ font-family:var(--ff-display); font-size:20px; font-weight:600; }
.opt-sub{ font-family:var(--ff-mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-mute); margin-top:2px; }
.opt-right{ font-family:var(--ff-mono); font-size:14px; font-weight:600; }
.opt-check{ width:20px; height:20px; border-radius:50%; border:1.5px solid var(--line); flex:0 0 auto; display:grid; place-items:center; }
.opt.sel .opt-check{ background:var(--ink); border-color:var(--ink); }
.opt.sel .opt-check::after{ content:""; width:7px; height:7px; border-radius:50%; background:var(--cream); }

.chip-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.chip{
  font-family:var(--ff-mono); font-size:12px; padding:13px 4px; text-align:center;
  border:1px solid var(--line); border-radius:11px; cursor:pointer; background:var(--cream);
  transition:border-color .2s, background .2s, transform .15s; line-height:1.3;
}
.chip:active{ transform:scale(.96); }
.chip.sel{ background:var(--ink); color:var(--cream); border-color:var(--ink); }
.chip.off{ opacity:.35; pointer-events:none; text-decoration:line-through; }
.chip .cd{ display:block; font-size:9px; letter-spacing:.1em; text-transform:uppercase; opacity:.7; margin-bottom:2px; }

.summary{ border:1px solid var(--line); border-radius:14px; padding:6px 16px; margin-bottom:18px; }
.summary-row{ display:flex; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--line-soft); font-size:14px; }
.summary-row:last-child{ border-bottom:none; }
.summary-row .k{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-mute); }
.summary-row .v{ font-family:var(--ff-display); font-size:17px; font-weight:600; }
.summary-row.total .v{ color:var(--oxblood); }

.sheet-foot{ padding:16px var(--pad) 26px; border-top:1px solid var(--line); }

/* confirmation */
.confirm{ text-align:center; padding:30px 0 10px; }
.confirm .seal{
  width:88px; height:88px; border-radius:50%; margin:0 auto 22px;
  border:1.5px solid var(--brass-2); display:grid; place-items:center;
  font-family:var(--ff-display); font-size:38px; color:var(--oxblood);
  position:relative; animation:sealPop .6s var(--ease-out) both;
}
.confirm .seal::before{
  content:""; position:absolute; inset:7px; border-radius:50%; border:1px dotted var(--brass-2);
}
@keyframes sealPop{ from{ transform:scale(.4); opacity:0; } to{ transform:scale(1); opacity:1; } }
.confirm h3{ font-size:32px; margin-bottom:8px; }
.confirm .meta{ margin-bottom:22px; }

/* ============================================================
   OWNER-TO-SUPPLY PLACEHOLDERS
   ============================================================ */
.supply-cap{
  font-family:var(--ff-ledger); font-style:italic; font-weight:500;
  color:var(--oxblood); font-size:16px; line-height:1.3;
}
.dark .supply-cap, .gallery .supply-cap{ color:var(--brass); }
.supply-tag{
  font-family:var(--ff-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass-2); font-weight:500;
}
.dark .supply-tag{ color:var(--brass); }

/* dashed-brass drop card */
.supply-card{
  border:1.5px dashed var(--brass-2);
  border-radius:4px;
  background:
    repeating-linear-gradient(135deg, oklch(0.715 0.088 78 / .05) 0 10px, transparent 10px 20px);
  padding:18px;
}
.dark .supply-card{ border-color:var(--brass); background:repeating-linear-gradient(135deg, oklch(0.715 0.088 78 / .07) 0 10px, transparent 10px 20px); }

/* ============================================================
   THE LEDGER (services)
   ============================================================ */
.ledger-list{ margin-top:28px; border-top:1px solid var(--line); }
.ledger-row{
  display:flex; align-items:baseline; gap:12px; padding:17px 0;
  border-bottom:1px solid var(--line);
}
.ledger-name{ font-family:var(--ff-ledger); font-style:italic; font-weight:600; font-size:30px; color:var(--ink); white-space:nowrap; line-height:1; }
.ledger-dots{ flex:1; border-bottom:1.5px dotted var(--line); transform:translateY(-6px); }
.ledger-price{ font-family:var(--ff-mono); font-size:14px; font-weight:500; color:var(--brass-2); letter-spacing:.04em; white-space:nowrap; }
.ledger-note{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.04em; color:var(--ink-mute); margin-top:18px; line-height:1.5; }

/* ============================================================
   CTA ROW
   ============================================================ */
.cta-row{ display:flex; flex-direction:column; gap:10px; }
.cta-row .btn{ width:100%; text-decoration:none; }
.cta-tel{ font-family:var(--ff-mono); letter-spacing:.04em; }

/* ============================================================
   MAP EMBED (degrades to a labelled placeholder if the
   third-party frame is blocked by the preview sandbox)
   ============================================================ */
.map-wrap{
  position:relative; width:100%; aspect-ratio:16/10; margin-top:24px;
  border:1px solid var(--line-cream); overflow:hidden;
  background-color:var(--espresso-2);
  background-image:repeating-linear-gradient(135deg, oklch(1 0 0 / .04) 0 9px, transparent 9px 18px);
}
.map-embed{
  position:absolute; inset:0; width:100%; height:100%; border:0; display:block;
  filter:grayscale(1) contrast(.95) brightness(.92);
}
.map-cap{
  position:absolute; left:0; bottom:0; z-index:2; pointer-events:none;
  font-family:var(--ff-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:oklch(0.78 0.01 80); background:var(--espresso); border-top:1px solid var(--line-cream); border-right:1px solid var(--line-cream);
  padding:6px 10px;
}

/* ============================================================
   REVIEWS / 376
   ============================================================ */
.rev-count{ font-family:var(--ff-display); font-style:italic; font-weight:900; font-size:64px; line-height:.9; color:var(--ink); letter-spacing:-.02em; }
.rev-count small{ font-family:var(--ff-mono); font-style:normal; font-weight:500; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); display:block; margin-top:8px; }
.rev-supply{ margin-top:26px; display:flex; flex-direction:column; gap:12px; }
.rev-supply .supply-card{ display:flex; flex-direction:column; gap:8px; }
