/* ============================================
   ARC Barbershop — Dark cinematic
   ============================================ */
:root {
  --bg: #0D0B08;
  --bg-2: #15120D;
  --bg-3: #1E1A14;
  --ink: #E8DFD2;
  --ink-soft: #A8A192;
  --ink-dim: #75695A;
  --line: rgba(232, 223, 210, 0.10);
  --line-2: rgba(232, 223, 210, 0.22);
  --amber: #D9A55A;
  --amber-deep: #B88639;
  --burnt: #C8551F;
  --red: #9E2727;

  --ff-display: "Syne", "Noto Sans JP", sans-serif;
  --ff-mono: "IBM Plex Mono", monospace;
  --ff-jp: "Noto Sans JP", sans-serif;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --pad-x: clamp(1.25rem, 3vw, 2.5rem);

  --side-w: 80px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { background: var(--bg); color: var(--ink); overflow-x: clip; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-feature-settings: "palt" 1, "kern" 1; }
body { background: var(--bg); color: var(--ink); font-family: var(--ff-jp); font-size: 16px; line-height: 1.8; letter-spacing: 0.02em; overflow-x: clip; width: 100%; max-width: 100vw; }
body.is-loading { overflow: hidden; height: 100svh; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--amber); color: var(--bg); }

/* NOISE + VIGNETTE */
.noise { position: fixed; inset: 0; pointer-events: none; z-index: 9997; opacity: 0.08; mix-blend-mode: overlay; background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>"); background-size: 240px 240px; animation: noise 7s steps(6) infinite; }
@keyframes noise { 0%,100% { transform: translate(0,0); } 25% { transform: translate(-2%,-2%); } 50% { transform: translate(2%,1%); } 75% { transform: translate(-1%,2%); } }
.vignette { position: fixed; inset: 0; pointer-events: none; z-index: 9996; background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,0.45) 100%); }
.spotlight { position: fixed; inset: 0; pointer-events: none; z-index: 9995; background: radial-gradient(400px 400px at var(--mx, 50%) var(--my, 50%), rgba(217,165,90,0.08), transparent 70%); transition: background-position 0.1s; }

/* LOADER */
.loader { position: fixed; inset: 0; z-index: 9990; background: var(--bg); display: grid; grid-template-rows: auto 1fr auto; padding: clamp(1.5rem, 4vw, 2.5rem); gap: 2rem; }
.loader__grid { display: flex; justify-content: space-between; font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.2em; color: var(--ink-soft); text-transform: uppercase; }
.loader__grid em { color: var(--amber); font-style: normal; }
.loader__mono--r { text-align: right; }
.loader__bars { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0.4rem; align-self: center; padding: 0 clamp(2rem, 10vw, 6rem); }
.loader__bars span { height: 4px; background: var(--ink); transform-origin: left; transform: scaleX(0); }

/* TOP BAR (minimal, readable) */
.tb {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 1.5rem;
  padding: 1rem var(--pad-x);
  background: rgba(13,11,8,0);
  transition: background 0.35s, border-color 0.35s, backdrop-filter 0.35s;
  border-bottom: 1px solid transparent;
}
.tb.is-scrolled { background: rgba(13,11,8,0.85); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom-color: var(--line); }
.tb__brand { display: inline-flex; align-items: center; gap: 0.55rem; color: var(--ink); }
.tb__brand-n { font-family: var(--ff-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.2em; }
.tb__brand-t { font-family: var(--ff-display); font-weight: 700; font-size: 22px; letter-spacing: 0.1em; color: var(--ink); }
.tb__center { justify-self: center; display: inline-flex; align-items: center; gap: 0.9rem; }
.tb__center-label { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--ink-soft); text-transform: uppercase; padding: 0.25rem 0.7rem; border: 1px solid var(--line-2); border-radius: 999px; }
.tb__clock { font-family: var(--ff-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.12em; font-feature-settings: "tnum"; }
.tb__burger { display: inline-flex; align-items: center; gap: 0.7rem; padding: 0.55rem 0.8rem 0.55rem 1rem; background: transparent; border: 1px solid var(--line-2); border-radius: 999px; cursor: pointer; font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.2em; color: var(--ink); text-transform: uppercase; transition: background 0.2s, border-color 0.2s; }
.tb__burger:hover { background: rgba(232,223,210,0.05); border-color: var(--amber); }
.tb__burger i { display: inline-flex; flex-direction: column; gap: 3px; width: 18px; }
.tb__burger i em { height: 1.5px; width: 100%; background: var(--ink); transition: transform 0.3s var(--ease), opacity 0.3s; }
.tb__burger i em:nth-child(2) { width: 60%; align-self: flex-start; transition-delay: 0.05s; }
.tb__burger[aria-expanded="true"] i em:nth-child(1) { transform: translateY(4.5px) rotate(45deg); }
.tb__burger[aria-expanded="true"] i em:nth-child(2) { opacity: 0; }
.tb__burger[aria-expanded="true"] i em:nth-child(3) { transform: translateY(-4.5px) rotate(-45deg); width: 100%; }

@media (max-width: 640px) {
  .tb__center { display: none; }
  .tb__burger span { display: none; }
}

/* FULLSCREEN OVERLAY NAV */
.fnav {
  position: fixed; inset: 0; z-index: 55;
  background: var(--bg);
  display: grid; align-items: stretch;
  opacity: 0; visibility: hidden;
  transition: opacity 0.5s var(--ease), visibility 0.5s;
}
.fnav.is-open { opacity: 1; visibility: visible; }
.fnav__inner {
  max-width: 1400px; width: 100%;
  margin: auto;
  padding: clamp(5rem, 12vh, 8rem) var(--pad-x) clamp(2rem, 5vh, 3.5rem);
  display: grid; grid-template-rows: 1fr auto;
  gap: 2rem;
}
.fnav__list { list-style: none; display: flex; flex-direction: column; gap: 0; }
.fnav__list li { border-top: 1px solid var(--line); }
.fnav__list li:last-child { border-bottom: 1px solid var(--line); }
.fnav__list a {
  display: grid; grid-template-columns: 80px 1fr;
  align-items: baseline; gap: 1.5rem;
  padding: 1rem 0.5rem;
  color: var(--ink);
  transition: color 0.3s, padding 0.3s var(--ease), background 0.3s;
}
.fnav__list a:hover { color: var(--amber); padding-left: 1.5rem; background: rgba(217,165,90,0.04); }
.fnav__list a.is-on { color: var(--amber); }
.fnav__n { font-family: var(--ff-mono); font-size: 12px; letter-spacing: 0.22em; color: var(--amber); }
.fnav__t { font-family: var(--ff-display); font-weight: 600; font-size: clamp(1.8rem, 5vw, 3.75rem); letter-spacing: -0.02em; line-height: 1; }
.fnav__t em { font-style: normal; font-family: var(--ff-mono); font-size: 0.35em; color: var(--amber); margin-left: 0.3em; letter-spacing: 0.1em; }
.fnav__foot { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--line); }
.fnav__foot div { display: flex; flex-direction: column; gap: 0.35rem; }
.fnav__foot em { font-style: normal; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.2em; color: var(--amber); text-transform: uppercase; }
.fnav__foot a, .fnav__foot div { font-family: var(--ff-mono); font-size: 13px; color: var(--ink-soft); }
.fnav__foot a:hover { color: var(--ink); }

/* no more body offset — body starts at 0 */
body { padding-left: 0; }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.95rem 1.6rem; border-radius: 0; font-family: var(--ff-mono); font-weight: 500; font-size: 12px; letter-spacing: 0.18em; line-height: 1; text-transform: uppercase; cursor: pointer; border: 1px solid transparent; transition: transform 0.3s var(--ease), background 0.3s, color 0.3s, border-color 0.3s; white-space: nowrap; }
.btn--amber { background: var(--amber); color: var(--bg); }
.btn--amber:hover { background: var(--ink); transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-2); }
.btn--ghost:hover { background: var(--ink); color: var(--bg); border-color: var(--ink); }

/* HERO */
.hero { position: relative; min-height: 100svh; overflow: hidden; display: grid; grid-template-rows: 1fr auto; }
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.85) saturate(1.05); will-change: transform; }
.hero__veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(13,11,8,0.35) 0%, rgba(13,11,8,0.6) 60%, rgba(13,11,8,0.9) 100%); }
.hero__overlay { position: relative; z-index: 2; padding: clamp(6rem, 14vh, 10rem) var(--pad-x) 3rem; max-width: 1100px; }
.hero__meta { display: inline-flex; align-items: center; gap: 0.6rem; font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.24em; color: var(--amber); text-transform: uppercase; margin-bottom: 2.5rem; }
.hero__meta-mark { font-size: 8px; }
.hero__h1 { font-family: var(--ff-display); font-weight: 700; color: var(--ink); letter-spacing: -0.04em; line-height: 0.92; margin-bottom: 2rem; }
.hero__h1 .line { display: block; overflow: hidden; font-size: clamp(3.5rem, 10vw, 9rem); }
.hero__h1 .line > * { display: inline-block; will-change: transform; }
.hero__h1 em { font-family: var(--ff-display); font-style: italic; font-weight: 500; color: var(--amber); }
.hero__lede { font-size: clamp(0.95rem, 1.1vw, 1.05rem); line-height: 1.85; color: var(--ink-soft); margin-bottom: 2rem; max-width: 44ch; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.hero__ticker { position: relative; z-index: 2; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 1rem 0; overflow: hidden; background: rgba(13, 11, 8, 0.35); backdrop-filter: blur(6px); }
.hero__ticker-track { display: inline-flex; white-space: nowrap; gap: 2rem; font-family: var(--ff-display); font-weight: 700; font-size: clamp(1.25rem, 3vw, 2rem); color: var(--ink); letter-spacing: 0.01em; will-change: transform; }
.hero__ticker-track span { flex-shrink: 0; }
.hero__ticker-track .t-sep { color: var(--amber); font-family: var(--ff-mono); font-size: 0.75em; font-weight: 400; opacity: 0.7; }
.hero__scroll { position: absolute; right: clamp(1.5rem, 3vw, 2.5rem); bottom: 3.5rem; z-index: 3; display: inline-flex; flex-direction: column; align-items: center; gap: 0.5rem; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--ink-soft); text-transform: uppercase; writing-mode: vertical-rl; }
.hero__scroll em { width: 1px; height: 34px; background: linear-gradient(180deg, var(--amber), transparent); transform-origin: top; animation: scroll 2.6s var(--ease) infinite; display: inline-block; }
@keyframes scroll { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 51% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }
@media (max-width: 900px) { .hero__overlay { padding-top: 7rem; } .hero__scroll { display: none; } }

/* SHARED */
.tag { display: inline-block; padding: 0.35rem 0.8rem; background: rgba(232, 223, 210, 0.06); border: 1px solid var(--line-2); font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.2em; color: var(--amber); text-transform: uppercase; margin-bottom: 1.25rem; }
.tag--mono { border-radius: 0; }
.h2 { font-family: var(--ff-display); font-weight: 700; font-size: clamp(2rem, 5.5vw, 4.5rem); line-height: 1.05; letter-spacing: -0.03em; color: var(--ink); margin-bottom: 1rem; }
.h2 em { font-family: var(--ff-display); font-style: italic; font-weight: 500; color: var(--amber); }
.h2--light em { color: var(--amber); }
.p { font-size: 14.5px; line-height: 1.95; color: var(--ink-soft); margin-bottom: 1rem; max-width: 58ch; }

/* RITUAL */
.ritual { padding: clamp(5rem, 10vh, 8rem) var(--pad-x); background: var(--bg); border-top: 1px solid var(--line); }
.ritual__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem, 6vw, 5rem); max-width: 1400px; margin: 0 auto; align-items: center; }
.ritual__text h2 { margin-bottom: 1.75rem; }
.ritual__text .w { display: inline-block; margin-right: 0.08em; transition: color 0.8s var(--ease); }
.ritual__text .w-em { font-style: italic; font-family: var(--ff-display); font-weight: 500; }
.ritual__dl { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--line); }
.ritual__dl div { display: flex; flex-direction: column; gap: 0.3rem; }
.ritual__dl dt { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.15em; color: var(--ink-dim); text-transform: uppercase; }
.ritual__dl dd { font-family: var(--ff-display); font-weight: 600; font-size: clamp(1.25rem, 2vw, 1.75rem); color: var(--ink); letter-spacing: -0.02em; display: flex; align-items: baseline; gap: 0.15em; line-height: 1; }
.ritual__dl dd em { font-family: var(--ff-mono); font-style: normal; font-weight: 400; font-size: 11px; color: var(--ink-dim); letter-spacing: 0; }
.ritual__fig { position: relative; }
.ritual__fig img { width: 100%; aspect-ratio: 3/4; object-fit: cover; filter: brightness(0.9); }
.ritual__fig figcaption { display: block; margin-top: 0.9rem; font-family: var(--ff-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.1em; }
@media (max-width: 900px) { .ritual__grid { grid-template-columns: 1fr; } .ritual__dl { grid-template-columns: repeat(2, 1fr); } }

/* MENU dense list */
.menu { padding: clamp(5rem, 10vh, 8rem) var(--pad-x); background: var(--bg-2); border-top: 1px solid var(--line); }
.menu__head { max-width: 1200px; margin: 0 auto 3rem; display: grid; grid-template-columns: auto 1fr; gap: 2.5rem; align-items: end; }
.menu__head .p { margin-left: auto; max-width: 50ch; }
.menu__list { list-style: none; max-width: 1200px; margin: 0 auto; }
.menu__list li { display: grid; grid-template-columns: 60px 1fr auto; gap: 1.5rem; align-items: baseline; padding: 2rem 0; border-bottom: 1px solid var(--line); transition: background 0.3s, padding 0.3s; }
.menu__list li:hover { background: rgba(217,165,90,0.03); padding-left: 1rem; padding-right: 1rem; border-color: transparent; }
.menu__list .m-n { font-family: var(--ff-mono); font-size: 13px; color: var(--ink-dim); letter-spacing: 0.15em; }
.menu__list h3 { font-family: var(--ff-display); font-weight: 600; font-size: clamp(1.3rem, 2.4vw, 2rem); color: var(--ink); letter-spacing: -0.02em; margin-bottom: 0.5rem; }
.menu__list .m-body p { font-family: var(--ff-mono); font-size: 12.5px; color: var(--ink-soft); line-height: 1.7; letter-spacing: 0.02em; }
.menu__list .m-p { font-family: var(--ff-display); font-weight: 500; font-size: clamp(1.25rem, 2.2vw, 1.8rem); color: var(--amber); letter-spacing: -0.02em; }
.menu__note { max-width: 1200px; margin: 2rem auto 0; padding-top: 1.5rem; border-top: 1px solid var(--line); font-family: var(--ff-mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.05em; }
@media (max-width: 760px) { .menu__head { grid-template-columns: 1fr; align-items: start; } .menu__list li { grid-template-columns: 40px 1fr; row-gap: 0.5rem; } .menu__list .m-p { grid-column: 2; } }

/* SIGNATURE pinned */
.sig { background: var(--bg); border-top: 1px solid var(--line); overflow: clip; position: relative; }
.sig__shell { padding: clamp(4rem, 8vh, 6rem) 0; overflow: clip; }
.sig__head { padding: 0 var(--pad-x); max-width: 1400px; margin: 0 auto 3rem; }
.sig__track { display: flex; gap: 2rem; padding: 0 var(--pad-x); will-change: transform; }
.sc { flex-shrink: 0; width: clamp(320px, 36vw, 520px); display: flex; flex-direction: column; gap: 1rem; color: var(--ink); }
.sc__meta { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.sc__n { font-family: var(--ff-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.2em; }
.sc__meta h3 { font-family: var(--ff-display); font-weight: 600; font-size: clamp(1.4rem, 2.4vw, 2rem); color: var(--ink); letter-spacing: -0.02em; }
.sc__fig { aspect-ratio: 4/5; overflow: hidden; }
.sc__fig img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.9); transition: transform 1.5s var(--ease); }
.sc:hover .sc__fig img { transform: scale(1.05); }
.sc p { font-family: var(--ff-mono); font-size: 12.5px; line-height: 1.8; color: var(--ink-soft); letter-spacing: 0.01em; }
.sc__p { font-family: var(--ff-display); font-weight: 500; font-size: clamp(1rem, 1.6vw, 1.25rem); color: var(--amber); letter-spacing: -0.01em; }

/* BARBERS CTA */
.bcta { padding: clamp(5rem, 10vh, 7rem) var(--pad-x); background: var(--bg-2); border-top: 1px solid var(--line); }
.bcta__inner { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem, 5vw, 4rem); max-width: 1400px; margin: 0 auto; align-items: center; }
.bcta__row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.bchip { display: flex; flex-direction: column; gap: 0.75rem; position: relative; }
.bchip img { width: 100%; aspect-ratio: 3/4; object-fit: cover; filter: brightness(0.9); transition: filter 0.4s; }
.bchip:hover img { filter: brightness(1); }
.bchip span { font-family: var(--ff-mono); font-size: 11px; color: var(--ink); letter-spacing: 0.12em; text-transform: uppercase; }
.bchip span em { font-style: normal; color: var(--amber); font-weight: 500; text-transform: none; font-size: 10px; letter-spacing: 0.08em; }
@media (max-width: 900px) { .bcta__inner { grid-template-columns: 1fr; } .bcta__row { grid-template-columns: repeat(2, 1fr); } }

/* FIRST VISIT */
.first { padding: clamp(5rem, 10vh, 7rem) var(--pad-x); background: var(--bg); border-top: 1px solid var(--line); }
.first__inner { max-width: 880px; margin: 0 auto; }
.first header { margin-bottom: 3rem; }
.first__steps { list-style: none; counter-reset: step; }
.first__steps li { display: grid; grid-template-columns: auto 1fr; gap: 1.75rem; padding: 1.5rem 0; border-bottom: 1px solid var(--line); align-items: start; }
.first__steps li:last-child { border-bottom: none; }
.fs-n { font-family: var(--ff-mono); font-size: 13px; color: var(--amber); letter-spacing: 0.2em; padding-top: 0.45rem; width: 40px; }
.first__steps h4 { font-family: var(--ff-display); font-weight: 600; font-size: 18px; letter-spacing: -0.01em; color: var(--ink); margin-bottom: 0.4rem; }
.first__steps p { font-family: var(--ff-mono); font-size: 12.5px; line-height: 1.8; color: var(--ink-soft); letter-spacing: 0.02em; }

/* ACCESS */
.access { padding: clamp(5rem, 10vh, 7rem) var(--pad-x); background: var(--bg-2); border-top: 1px solid var(--line); }
.access__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); max-width: 1400px; margin: 0 auto; align-items: center; }
.info { list-style: none; margin-top: 1.5rem; }
.info div { display: grid; grid-template-columns: 80px 1fr; gap: 1rem; padding: 0.75rem 0; border-bottom: 1px solid var(--line); font-family: var(--ff-mono); font-size: 12.5px; }
.info div:last-child { border-bottom: none; }
.info dt { color: var(--amber); letter-spacing: 0.15em; text-transform: uppercase; font-size: 10.5px; }
.info dd { color: var(--ink); }
.mapwrap { aspect-ratio: 4/3; }
.mapbox { position: relative; width: 100%; height: 100%; background: var(--bg-3); border: 1px solid var(--line-2); overflow: hidden; }
.map-grid { position: absolute; inset: 0; background-image: linear-gradient(to right, rgba(232,223,210,0.06) 1px, transparent 1px), linear-gradient(to bottom, rgba(232,223,210,0.06) 1px, transparent 1px); background-size: 40px 40px; }
.map-bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 60% 40%, rgba(217,165,90,0.08), transparent 50%); }
.map-pin { position: absolute; top: 50%; left: 50%; width: 14px; height: 14px; background: var(--amber); border: 3px solid var(--bg-3); border-radius: 50%; transform: translate(-50%,-50%); box-shadow: 0 0 0 0 rgba(217,165,90,0.6); animation: pinPulse 2s ease-in-out infinite; }
@keyframes pinPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(217,165,90,0.5); } 50% { box-shadow: 0 0 0 16px rgba(217,165,90,0); } }
.map-label { position: absolute; top: 1rem; left: 1rem; font-family: var(--ff-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.12em; }
@media (max-width: 900px) { .access__inner { grid-template-columns: 1fr; } }

/* BOOK */
.book { padding: clamp(5rem, 10vh, 7rem) var(--pad-x); background: var(--bg); border-top: 1px solid var(--line); }
.book__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); max-width: 1400px; margin: 0 auto; align-items: start; }
.book__text .h2 { margin-bottom: 1.5rem; }
.book__text .h2 .line { display: block; overflow: hidden; }
.book__text .h2 .line > * { display: inline-block; }
.book__panels { display: flex; flex-direction: column; gap: 0.75rem; }
.bp { display: grid; grid-template-columns: 64px 1fr; gap: 1.5rem; padding: 1.75rem 1.5rem; background: var(--bg-2); border: 1px solid var(--line); transition: border-color 0.3s, background 0.3s, transform 0.3s var(--ease); }
.bp:hover { border-color: var(--amber); background: rgba(217,165,90,0.05); transform: translateY(-2px); }
.bp__n { font-family: var(--ff-display); font-style: italic; font-weight: 500; font-size: 32px; color: var(--amber); letter-spacing: -0.02em; }
.bp h4 { font-family: var(--ff-display); font-weight: 600; font-size: 18px; color: var(--ink); margin-bottom: 0.4rem; letter-spacing: -0.01em; }
.bp p { font-family: var(--ff-mono); font-size: 12.5px; line-height: 1.7; color: var(--ink-soft); margin-bottom: 0.75rem; }
.bp__cta { font-family: var(--ff-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.15em; text-transform: uppercase; transition: letter-spacing 0.3s; }
.bp:hover .bp__cta { letter-spacing: 0.22em; }
@media (max-width: 900px) { .book__grid { grid-template-columns: 1fr; } }

/* FOOTER */
.ft { background: var(--bg-3); border-top: 1px solid var(--line); margin-top: 2rem; }
.ft__top { display: flex; justify-content: space-between; align-items: center; padding: 2.5rem var(--pad-x); border-bottom: 1px solid var(--line); gap: 2rem; flex-wrap: wrap; }
.ft__clock { display: flex; flex-direction: column; gap: 0.5rem; }
.ft__clock-label { font-family: var(--ff-mono); font-size: 10.5px; color: var(--amber); letter-spacing: 0.2em; text-transform: uppercase; }
.ft__clock-time { font-family: var(--ff-display); font-weight: 500; font-size: clamp(2rem, 5vw, 3.5rem); color: var(--ink); letter-spacing: -0.02em; font-feature-settings: "tnum"; line-height: 1; }
.ft__say { font-family: var(--ff-display); font-style: italic; font-weight: 500; font-size: clamp(1rem, 1.5vw, 1.3rem); color: var(--amber); letter-spacing: 0.02em; }
.ft__ribbon { overflow: hidden; padding: 1.25rem 0; border-bottom: 1px solid var(--line); background: var(--amber); }
.ft__ribbon-track { display: inline-flex; gap: 2rem; white-space: nowrap; font-family: var(--ff-display); font-weight: 700; font-size: clamp(1.25rem, 3vw, 2rem); color: var(--bg); will-change: transform; letter-spacing: 0.02em; }
.ft__ribbon-track .sp { color: var(--bg); opacity: 0.5; font-size: 0.7em; font-weight: 400; }
.ft__bot { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 2rem; padding: 2.5rem var(--pad-x); align-items: start; }
.ft__brand { font-family: var(--ff-display); font-weight: 700; font-size: 28px; color: var(--ink); letter-spacing: 0.08em; display: inline-block; margin-bottom: 0.75rem; }
.ft__bot p { font-family: var(--ff-mono); font-size: 11px; color: var(--ink-soft); line-height: 1.9; letter-spacing: 0.02em; }
.ft__meta p { display: flex; gap: 0.75rem; padding: 0.35rem 0; font-size: 11.5px; color: var(--ink); align-items: baseline; }
.ft__meta em { font-family: var(--ff-mono); font-style: normal; font-weight: 400; color: var(--amber); letter-spacing: 0.2em; text-transform: uppercase; font-size: 9.5px; min-width: 56px; }
.ft__meta a { transition: color 0.2s; }
.ft__meta a:hover { color: var(--amber); }
.ft__sign { font-family: var(--ff-mono); font-size: 10.5px; color: var(--ink-dim); letter-spacing: 0.1em; text-align: right; line-height: 1.85; }
@media (max-width: 800px) { .ft__bot { grid-template-columns: 1fr; } .ft__sign { text-align: left; } }

/* SAMPLE TAG */
.sample-tag { position: fixed; bottom: 12px; left: calc(var(--side-w) + 12px); z-index: 90; padding: 0.3rem 0.65rem; background: rgba(232,223,210,0.1); border: 1px solid var(--line-2); color: var(--ink-soft); font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; pointer-events: none; }
@media (max-width: 900px) { .sample-tag { left: 12px; bottom: 12px; } }

/* ============ SUB PAGE (barbers) ============ */
.is-sub .hero { display: none; }
.sub-hero { padding: clamp(7rem, 14vh, 10rem) var(--pad-x) clamp(3rem, 6vh, 5rem); background: var(--bg); border-bottom: 1px solid var(--line); }
.sub-hero__inner { max-width: 1200px; margin: 0 auto; }
.crumb { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--ff-mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 2rem; }
.crumb a { color: var(--ink-soft); transition: color 0.2s; }
.crumb a:hover { color: var(--amber); }
.sub-h { font-family: var(--ff-display); font-weight: 700; color: var(--ink); letter-spacing: -0.04em; line-height: 0.95; margin-bottom: 2rem; }
.sub-h .line { display: block; overflow: hidden; font-size: clamp(2.5rem, 8vw, 7rem); }
.sub-h .line > * { display: inline-block; will-change: transform; }
.sub-h em { font-family: var(--ff-display); font-style: italic; font-weight: 500; color: var(--amber); }

/* Roster */
.roster { padding: clamp(3rem, 6vh, 5rem) var(--pad-x); background: var(--bg); }
.roster__list { list-style: none; max-width: 1200px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; }
.bb { display: grid; grid-template-columns: 60px 0.9fr 1.1fr; gap: clamp(1.5rem, 3vw, 2.5rem); align-items: start; padding: 3rem 0; border-bottom: 1px solid var(--line); transition: background 0.3s; }
.bb:hover { background: rgba(217,165,90,0.025); }
.bb:last-child { border-bottom: none; }
.bb--alt { grid-template-columns: 60px 1.1fr 0.9fr; }
.bb--alt .bb__fig { order: 2; }
.bb__idx { font-family: var(--ff-mono); font-size: 12px; color: var(--amber); letter-spacing: 0.2em; padding-top: 0.5rem; }
.bb__fig { aspect-ratio: 3/4; overflow: hidden; }
.bb__fig img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.9); transition: filter 0.5s; }
.bb:hover .bb__fig img { filter: brightness(1); }
.bb__body { }
.bb__role { display: inline-block; padding: 0.3rem 0.7rem; background: rgba(217,165,90,0.1); border: 1px solid var(--amber); font-family: var(--ff-mono); font-size: 10px; color: var(--amber); letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 1rem; }
.bb__name { font-family: var(--ff-display); font-weight: 600; font-size: clamp(1.75rem, 3.2vw, 2.6rem); color: var(--ink); letter-spacing: -0.03em; line-height: 1.05; margin-bottom: 0.5rem; }
.bb__name em { font-family: var(--ff-mono); font-style: normal; font-weight: 400; font-size: 0.4em; color: var(--ink-dim); letter-spacing: 0.1em; margin-left: 0.4em; }
.bb__year { font-family: var(--ff-mono); font-size: 11.5px; color: var(--amber); letter-spacing: 0.1em; margin-bottom: 1rem; }
.bb__bio { font-size: 14px; line-height: 1.9; color: var(--ink-soft); margin-bottom: 1.25rem; }
.bb__spec { list-style: none; margin-bottom: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.bb__spec div { display: grid; grid-template-columns: 100px 1fr; gap: 1rem; padding: 0.55rem 0; border-bottom: 1px solid var(--line); font-family: var(--ff-mono); font-size: 12px; }
.bb__spec div:last-child { border-bottom: none; }
.bb__spec dt { color: var(--ink-dim); letter-spacing: 0.15em; font-size: 10px; text-transform: uppercase; }
.bb__spec dd { color: var(--ink); }
.link-a { display: inline-flex; align-items: center; gap: 0.4rem; font-family: var(--ff-mono); font-size: 12px; color: var(--amber); letter-spacing: 0.15em; text-transform: uppercase; padding-bottom: 0.3rem; border-bottom: 1px solid var(--amber); transition: letter-spacing 0.3s, color 0.2s; }
.link-a:hover { letter-spacing: 0.22em; color: var(--ink); border-color: var(--ink); }
@media (max-width: 900px) { .bb, .bb--alt { grid-template-columns: 1fr; } .bb--alt .bb__fig { order: -1; } .bb__idx { display: none; } }

.back-book { padding: clamp(5rem, 10vh, 7rem) var(--pad-x); background: var(--bg-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.back-book__inner { max-width: 1000px; margin: 0 auto; text-align: center; }
.back-book .h2 .line { display: block; overflow: hidden; }
.back-book .h2 .line > * { display: inline-block; will-change: transform; }
.bb-cta { display: flex; justify-content: center; gap: 0.75rem; margin-top: 2rem; flex-wrap: wrap; }

@media (prefers-reduced-motion: reduce) { * { animation: none !important; transition: none !important; scroll-behavior: auto !important; } }
