/* ============================================================
   VIC-TORY BARBERSHOP — SHARED STYLESHEET
   One stylesheet for every page. Per LLC² brief: never duplicate
   CSS inside individual HTML files. Edit here once, applies sitewide.

   Aesthetic carried from the original prototype:
   - Dark/oxblood + patriotic navy + white (matches shop's actual logo)
   - Bebas Neue (display) + Inter (body)
   - Hex-grid background motif (echoes the LED ceiling in-shop)
   - Card hover polish: 4px lift, soft shadow, oxblood border warm-up
   - Mobile-first; 16px body minimum; 48px tap targets
============================================================ */


/* ─── 1. CSS Reset + base ─────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: #0c0c0d;
  color: #f5f5f4;
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
  font-size: 16px;       /* WCAG-readable mobile baseline */
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, svg, picture, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { border: none; background: none; color: inherit; cursor: pointer; font: inherit; }
::selection { background: #e02b3a; color: #fff; }


/* ─── 2. Design tokens ────────────────────────────────────── */
:root {
  /* Surfaces (matches the shop's black walls) */
  --ink:   #0c0c0d;
  --ink-2: #111114;
  --ink-3: #17171a;
  --line:  rgba(255, 255, 255, 0.07);

  /* Brand red — sampled from the logo's barber pole stripes */
  --ox:    #c52030;
  --ox-2:  #e02b3a;
  --ox-d:  #8a1620;

  /* Patriotic navy — barber pole blue field */
  --nv:    #1d3a78;
  --nv-2:  #2750a0;

  /* Text */
  --fg:        #f5f5f4;
  --fg-mute:   #d4d4d2;
  --fg-quiet:  #a3a39e;
  --fg-faint:  #6b6b67;
  --fg-ghost:  #404040;

  /* Layout */
  --container: 1280px;
  --gutter:    clamp(20px, 4vw, 40px);
  --radius:    0;       /* sharp/masculine — no rounded corners on cards */
  --tap:       48px;    /* WCAG tap-target minimum */
}


/* ─── 3. Typography ───────────────────────────────────────── */
.display {
  font-family: 'Bebas Neue', Impact, Arial Narrow, sans-serif;
  letter-spacing: 0.01em;
  font-weight: 400;
  line-height: 0.95;
}
h1, h2, h3, h4 { font-family: 'Bebas Neue', Impact, sans-serif; line-height: 1.05; }
h1 { font-size: clamp(2.5rem, 7vw, 5rem); letter-spacing: -0.005em; }
h2 { font-size: clamp(2rem, 5vw, 3.5rem); letter-spacing: 0.005em; margin-bottom: 0.5em; }
h3 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
p  { color: var(--fg-mute); }
.eyebrow {
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ox-2);
  font-weight: 600;
}
.lead { font-size: 1.125rem; color: var(--fg-mute); line-height: 1.7; }


/* ─── 4. Layout primitives ────────────────────────────────── */
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.section   { padding: clamp(60px, 10vw, 112px) 0; }
.section--alt { background: var(--ink-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.section-header { max-width: 720px; margin-bottom: clamp(40px, 6vw, 64px); }
.section-header.center { margin-left: auto; margin-right: auto; text-align: center; }
.divider { height: 1px; background: var(--line); margin: 0; border: 0; }


/* ─── 5. Barber-pole stripe + hex-grid motifs ─────────────── */
.barber-rule {
  height: 3px;
  background: repeating-linear-gradient(90deg,
    var(--ox-2) 0 14px,
    #f5f5f4 14px 28px,
    var(--nv) 28px 42px,
    #f5f5f4 42px 56px);
  opacity: 0.8;
  border: 0;
}
.hex-bg {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='84' height='96' viewBox='0 0 84 96'><g fill='none' stroke='%23ffffff' stroke-width='1.2' stroke-opacity='0.05'><polygon points='42,2 80,24 80,72 42,94 4,72 4,24'/><polygon points='42,26 60,36 60,60 42,70 24,60 24,36'/></g></svg>");
  background-repeat: repeat;
}


/* ─── 6. Buttons + CTAs ───────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: var(--tap);
  padding: 14px 24px;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: background-color 0.25s ease, color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
  border: 1px solid transparent;
}
.btn--primary {
  background: var(--ox-2);
  color: #fff;
  box-shadow: 0 8px 24px -10px rgba(224, 43, 58, 0.5);
}
.btn--primary:hover, .btn--primary:focus-visible {
  background: var(--ox);
  transform: translateY(-1px);
  box-shadow: 0 12px 28px -12px rgba(224, 43, 58, 0.65);
}
.btn--ghost {
  background: transparent;
  color: var(--fg);
  border-color: rgba(255, 255, 255, 0.2);
}
.btn--ghost:hover { background: rgba(255, 255, 255, 0.05); border-color: rgba(255, 255, 255, 0.4); }
.btn--small { padding: 10px 16px; font-size: 12px; min-height: 40px; }
.btn-arrow::after {
  content: '→';
  margin-left: 4px;
  transition: transform 0.25s ease;
}
.btn:hover .btn-arrow::after { transform: translateX(3px); }

/* CTA block — used after every H2 per the LLC² brief */
.cta-block {
  margin: 32px 0 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}


/* ─── 7. Site nav (shared header) ─────────────────────────── */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(12, 12, 13, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
/* 3-column grid: 1fr | auto | 1fr → brand and right cluster claim equal
   space on either side so the nav links sit DEAD CENTER on every page
   regardless of brand width or right-side cluster width. */
.nav-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
  height: 72px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: var(--tap);
  justify-self: start;     /* pin to left edge of column 1 */
}
.brand-logo { width: 56px; height: auto; }
.brand-tag {
  display: none;            /* hidden on narrow screens */
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--fg-quiet);
  white-space: nowrap;
}
@media (min-width: 760px) { .brand-tag { display: inline-block; } }
.nav-links {
  display: flex;
  align-items: center;
  gap: 28px;
  justify-self: center;    /* dead-centered in column 2 */
}
.nav-links a {
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-quiet);
  padding: 8px 0;
  transition: color 0.25s ease;
  min-height: var(--tap);
  display: inline-flex;
  align-items: center;
}
.nav-links a:hover, .nav-links a:focus-visible { color: var(--fg); }
.nav-links a.active { color: var(--ox-2); }

/* Right cluster — Book CTA + mobile hamburger. col-start:3 keeps it pinned
   to column 3 even when .nav-links is hidden/positioned-fixed on mobile,
   so the cluster never drifts into the middle column. */
.nav-right {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-self: end;
  grid-column-start: 3;
}
.btn-cta {
  display: inline-flex;
  align-items: center;
  background: var(--ox-2);
  color: #fff;
  padding: 10px 16px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  min-height: var(--tap);
  transition: background-color 0.25s ease;
}
.btn-cta:hover, .btn-cta:focus-visible { background: var(--ox); color: #fff; }

/* Hamburger button — three lines that morph into an X when open */
.nav-toggle {
  display: none;
  position: relative;
  background: none;
  border: none;
  cursor: pointer;
  padding: 12px;
  min-height: var(--tap);
  min-width: var(--tap);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
}
.nav-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--fg);
  margin: 0;
  transition: transform 0.28s ease, opacity 0.18s ease;
  transform-origin: center;
}
/* X-state when the menu is open (toggled via aria-expanded on the button) */
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav slide-in */
@media (max-width: 880px) {
  .nav-links {
    position: fixed;
    top: 72px; left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    background: var(--ink);
    border-bottom: 1px solid var(--line);
    padding: 12px var(--gutter) 28px;
    gap: 0;
    transform: translateY(-110%);
    transition: transform 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
    max-height: calc(100vh - 72px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .nav-links.open { transform: translateY(0); }
  .nav-links a {
    padding: 16px 4px;
    font-size: 14px;
    border-bottom: 1px solid var(--line);
    letter-spacing: 0.16em;
    min-height: var(--tap);
  }
  .nav-links a:last-child { border-bottom: none; }
  .nav-links a.btn-cta {
    margin-top: 16px;
    border-radius: 0;
    padding: 14px;
    justify-content: center;
    border-bottom: none;
  }
  .nav-toggle { display: inline-flex; }
  /* Top-bar Book Now: shrink so it sits next to the hamburger without crowding */
  .nav-right .btn-cta {
    padding: 9px 14px;
    font-size: 11px;
    letter-spacing: 0.14em;
  }
  .nav-right { gap: 8px; }
}

/* Narrow-viewport tightening — phones under 420px (iPhone SE width is 375) */
@media (max-width: 420px) {
  .nav-inner { padding: 0 16px; height: 64px; }
  .nav-links { top: 64px; max-height: calc(100vh - 64px); }
  .brand-logo { width: 44px; }
  .nav-right .btn-cta {
    padding: 8px 12px;
    font-size: 10.5px;
    letter-spacing: 0.12em;
  }
  .nav-right { gap: 6px; }
  .nav-toggle { padding: 10px; min-width: 44px; min-height: 44px; }
  .nav-toggle span { width: 22px; }
}


/* ─── 8. Hero (used on every page) ─────────────────────────── */
.hero {
  position: relative;
  padding: clamp(60px, 12vw, 130px) 0 clamp(50px, 8vw, 80px);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse at top left, rgba(224, 43, 58, 0.08), transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(29, 58, 120, 0.06), transparent 50%);
  pointer-events: none;
}
.hero-inner { position: relative; z-index: 1; max-width: 900px; }
.hero-inner > * + * { margin-top: 16px; }
.hero h1 { margin-top: 12px; }
.hero p { font-size: 1.15rem; max-width: 640px; }
.trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 24px;
  align-items: center;
  margin-top: 24px;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-quiet);
}
.trust-strip .star { color: var(--ox-2); font-size: 14px; letter-spacing: 0.05em; }
.trust-strip .dot { width: 4px; height: 4px; background: var(--ox-2); border-radius: 50%; display: inline-block; }


/* ─── 9. Cards (services, barbers, gallery, content blocks) ─ */
.card {
  background: var(--ink-3);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 28px;
  transition:
    border-color 0.35s ease,
    transform 0.35s cubic-bezier(0.2, 0.7, 0.2, 1),
    box-shadow 0.35s ease;
}
.card:hover {
  border-color: rgba(224, 43, 58, 0.55);
  transform: translateY(-4px);
  box-shadow:
    0 1px 0 rgba(224, 43, 58, 0.18) inset,
    0 18px 38px -22px rgba(0, 0, 0, 0.85),
    0 2px 0 rgba(224, 43, 58, 0.10);
}
.card h3 { margin-bottom: 8px; }
.card p  { font-size: 0.95rem; color: var(--fg-mute); }
.card-chip {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ox-2);
  margin-bottom: 12px;
  font-weight: 600;
}
.card .price { font-family: 'Bebas Neue', sans-serif; font-size: 2.5rem; line-height: 1; color: var(--fg); }


/* Grid layouts */
.grid-2 { display: grid; grid-template-columns: 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: 1fr; gap: 16px; }
.grid-4 { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 600px) {
  .grid-2 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
  .grid-4 { grid-template-columns: repeat(4, 1fr); }
}


/* ─── 10. Barber card (circular portrait) ─────────────────── */
.barber-card { text-align: center; padding: 24px; }
.barber-card .photo {
  position: relative;
  width: 100%;
  max-width: 180px;
  aspect-ratio: 1;
  margin: 0 auto 16px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.barber-card .photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.barber-card:hover .photo img { transform: scale(1.06); }
.barber-card h3 { margin-top: 16px; font-size: 1.5rem; }
.barber-card p  { font-size: 0.9rem; color: var(--fg-quiet); margin-top: 6px; }


/* ─── 11. Gallery grid ────────────────────────────────────── */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
@media (min-width: 720px) { .gallery-grid { grid-template-columns: repeat(3, 1fr); gap: 16px; } }
.gallery-grid figure {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.05);
}
.gallery-grid figure img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.7s ease;
}
.gallery-grid figure:hover img { transform: scale(1.06); }
.gallery-grid figure.feature {
  grid-row: span 2;
  aspect-ratio: 1 / 2;
}
@media (max-width: 719px) {
  .gallery-grid figure.feature { grid-row: auto; aspect-ratio: 1; }
}


/* ─── 12. FAQ blocks (used on /faq/) ──────────────────────── */
.faq-list { display: grid; gap: 12px; max-width: 880px; }
.faq-item {
  background: var(--ink-3);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 24px 28px;
}
.faq-item h2 {
  font-size: 1.5rem;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: 0;
  margin-bottom: 12px;
  color: var(--fg);
}
.faq-item h3 {
  display: none;  /* H3 is the answer per the brief; we render as <p> instead for cleaner accessibility */
}
.faq-item p { font-size: 0.98rem; line-height: 1.7; }


/* ─── 13. Booking page treatment ──────────────────────────── */
/* Compact header for /book-west-chester-pa/ — keeps the H1 for SEO but
   shrinks vertical space so the widget is the first thing visible. */
.book-top {
  padding: clamp(20px, 3vw, 36px) 0 clamp(8px, 1.5vw, 16px);
  text-align: center;
  background: var(--ink);
}
.book-top .eyebrow { margin: 0 auto 10px; }
.book-h1 {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  letter-spacing: -0.005em;
  margin-bottom: 8px;
}
.book-lead {
  color: var(--fg-quiet);
  font-size: 0.95rem;
  max-width: 540px;
  margin: 0 auto;
}
.book-widget-section {
  padding: clamp(16px, 2vw, 24px) 0 clamp(40px, 6vw, 80px);
  background: var(--ink);
}

.booking-frame {
  background: var(--ink-3);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 0;
  min-height: 540px;
  display: block;
  text-align: left;
  overflow: hidden;
}

/* Vagaro widget placeholder — structured mockup that mimics Vagaro's UI
   so the page looks like a real widget is sitting there.
   When the real Vagaro <script> embed goes in, this whole .vagaro-widget
   block gets replaced. */
.vagaro-widget {
  display: flex;
  flex-direction: column;
  background: #fafafa;
  color: #111;
  font-family: 'Inter', sans-serif;
}
.vw-header {
  background: #fff;
  border-bottom: 1px solid #e6e6e6;
  padding: 18px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.vw-brand { display: flex; align-items: center; gap: 12px; }
.vw-logo {
  width: 40px; height: 40px;
  background: var(--ox);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 24px; line-height: 1;
  border-radius: 6px;
}
.vw-bizname { font-weight: 600; font-size: 1rem; margin: 0; color: #111; }
.vw-bizmeta { font-size: 0.78rem; color: #777; margin: 2px 0 0; }
.vw-steps {
  display: flex; flex-wrap: wrap; gap: 0;
  border-top: 1px solid #f0f0f0;
  padding-top: 14px;
}
.vw-step {
  flex: 1 1 auto;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: #aaa;
  padding: 6px 4px;
  text-align: center;
  border-bottom: 2px solid transparent;
  min-width: 100px;
}
.vw-step--active { color: var(--ox); border-bottom-color: var(--ox); font-weight: 600; }
.vw-body { padding: 28px 24px; background: #fafafa; flex: 1; }
.vw-stage {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #888;
  margin: 0 0 18px;
}
.vw-svc-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.vw-svc {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid #e8e8e8;
  border-radius: 8px;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.vw-svc:hover { border-color: var(--ox); box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04); }
.vw-svc-name { font-weight: 600; font-size: 0.95rem; }
.vw-svc-meta { color: #888; font-size: 0.78rem; }
.vw-svc-price { color: var(--ox); font-weight: 700; font-size: 0.95rem; }
.vw-actions { margin-top: 24px; text-align: center; }
.vw-cta {
  display: inline-block;
  background: var(--ox);
  color: #fff;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.05rem;
  letter-spacing: 0.06em;
  padding: 14px 32px;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.15s;
}
.vw-cta:hover { background: var(--ox-d); }
.vw-note {
  margin-top: 12px;
  font-size: 0.78rem;
  color: #777;
  max-width: 380px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
}
.vw-footer {
  background: #f0f0f0;
  border-top: 1px solid #e0e0e0;
  padding: 12px 24px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 0.72rem;
  color: #666;
}


/* ─── 14. Footer (shared) ─────────────────────────────────── */
.site-footer {
  background: var(--ink-2);
  border-top: 1px solid var(--line);
  padding: 0 0 24px;
  margin-top: 0;
}

/* Booking CTA strip — top of every footer */
.footer-cta {
  background:
    linear-gradient(135deg, rgba(197, 32, 48, 0.18) 0%, rgba(29, 58, 120, 0.18) 100%),
    var(--ink-3);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: clamp(40px, 6vw, 64px) var(--gutter);
}
.footer-cta-inner {
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  text-align: center;
}
@media (min-width: 720px) {
  .footer-cta-inner {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    text-align: left;
    gap: 48px;
  }
  .footer-cta-inner > div { max-width: 60%; }
}
.footer-cta h3 {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  letter-spacing: 0.01em;
  margin: 0;
}
.footer-cta p {
  color: var(--fg-quiet);
  font-size: 0.95rem;
  margin: 4px 0 0;
}
.footer-grid {
  margin-top: clamp(48px, 8vw, 88px);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
@media (min-width: 720px) { .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1.2fr; } }
.footer-col h4 {
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--fg-quiet);
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  margin-bottom: 16px;
}
.footer-col p, .footer-col li, .footer-col a { font-size: 0.92rem; color: var(--fg-quiet); }
.footer-col a:hover { color: var(--fg); }
.footer-col ul { list-style: none; }
.footer-col ul li { padding: 4px 0; }
.footer-col .footer-row { display: flex; justify-content: space-between; gap: 8px; padding: 3px 0; }

.footer-brand { margin-bottom: 12px; }
.footer-brand img { width: 100px; height: auto; }

.footer-social { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px; height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--fg-quiet);
  transition: border-color 0.25s ease, color 0.25s ease, background 0.25s ease;
}
.footer-social a:hover { border-color: var(--ox-2); color: var(--ox-2); }
.footer-social a i { font-size: 16px; }

.footer-reviews { margin-top: 20px; display: grid; gap: 8px; }
.footer-reviews a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  letter-spacing: 0.08em;
  padding: 6px 0;
  min-height: var(--tap);
}
.footer-reviews a .badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-bottom {
  max-width: var(--container);
  margin: 32px auto 0;
  padding: 16px var(--gutter) 0;
  border-top: 1px solid var(--line);
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-faint);
}


/* ─── 15. Sticky Book FAB (mobile only) ───────────────────── */
.fab-book {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 55;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  background: var(--ox-2);
  color: #fff;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  box-shadow:
    0 10px 24px -8px rgba(156, 31, 44, 0.55),
    0 2px 0 rgba(0, 0, 0, 0.35);
  transition: background-color 0.25s ease, transform 0.25s ease;
  min-height: var(--tap);
}
.fab-book:hover { background: var(--ox); transform: translateY(-2px); }
@media (min-width: 881px) { .fab-book { display: none; } }


/* ─── 16. Reveal on scroll ────────────────────────────────── */
/* Base fade up (existing) */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.7s cubic-bezier(0.2, 0.7, 0.2, 1),
    transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.reveal.in { opacity: 1; transform: translateY(0); }

/* Slide-in from the sides */
.reveal-left  { opacity: 0; transform: translateX(-44px); transition: opacity .85s cubic-bezier(.2,.7,.2,1), transform .85s cubic-bezier(.2,.7,.2,1); }
.reveal-left.in  { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX( 44px); transition: opacity .85s cubic-bezier(.2,.7,.2,1), transform .85s cubic-bezier(.2,.7,.2,1); }
.reveal-right.in { opacity: 1; transform: translateX(0); }

/* Zoom + lift */
.reveal-scale { opacity: 0; transform: scale(.94) translateY(16px); transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
.reveal-scale.in { opacity: 1; transform: scale(1) translateY(0); }

/* Roll in — rotates while sliding up. Two directions so adjacent rows alternate. */
.reveal-roll  { opacity: 0; transform: translateY(40px) rotate(-6deg); transition: opacity 1s cubic-bezier(.22,.61,.36,1), transform 1s cubic-bezier(.22,.61,.36,1); }
.reveal-roll.in  { opacity: 1; transform: translateY(0) rotate(0); }
.reveal-roll-r{ opacity: 0; transform: translateY(40px) rotate( 6deg); transition: opacity 1s cubic-bezier(.22,.61,.36,1), transform 1s cubic-bezier(.22,.61,.36,1); }
.reveal-roll-r.in{ opacity: 1; transform: translateY(0) rotate(0); }

/* 3D flip from below */
.reveal-flip { opacity: 0; transform: perspective(900px) rotateX(-22deg) translateY(36px); transform-origin: 50% 100%; transition: opacity .95s cubic-bezier(.22,.61,.36,1), transform .95s cubic-bezier(.22,.61,.36,1); }
.reveal-flip.in { opacity: 1; transform: perspective(900px) rotateX(0) translateY(0); }

/* Defocus blur in — sharp clipper-comes-into-focus vibe */
.reveal-blur { opacity: 0; filter: blur(14px); transform: translateY(18px); transition: opacity 1s ease, filter 1s ease, transform 1s ease; }
.reveal-blur.in { opacity: 1; filter: blur(0); transform: translateY(0); }

/* Big slide up — strong vertical entrance for hero-level statements */
.reveal-up-big { opacity: 0; transform: translateY(80px); transition: opacity 1.1s cubic-bezier(.22,.61,.36,1), transform 1.1s cubic-bezier(.22,.61,.36,1); }
.reveal-up-big.in { opacity: 1; transform: translateY(0); }

/* Curtain wipe — clip-path reveal, nice on images */
.reveal-wipe { opacity: 0; clip-path: inset(0 0 100% 0); transition: opacity 1s ease, clip-path 1.1s cubic-bezier(.77,0,.18,1); }
.reveal-wipe.in { opacity: 1; clip-path: inset(0 0 0 0); }

/* Stagger helpers — add .delay-1..6 alongside any reveal class */
.delay-1 { transition-delay: .08s; }
.delay-2 { transition-delay: .18s; }
.delay-3 { transition-delay: .28s; }
.delay-4 { transition-delay: .38s; }
.delay-5 { transition-delay: .48s; }
.delay-6 { transition-delay: .58s; }


/* ─── 16b. Gallery filter tabs + filter-in animation ──────── */
.gal-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  margin: 0 auto 40px;
  border: 1px solid var(--line);
  max-width: 920px;
}
.gal-tab {
  flex: 1 1 auto;
  min-height: var(--tap);
  padding: 14px 22px;
  font-family: 'Bebas Neue', Impact, sans-serif;
  font-size: 16px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-quiet);
  background: none;
  border: none;
  border-right: 1px solid var(--line);
  cursor: pointer;
  transition: background .3s ease, color .3s ease;
  white-space: nowrap;
}
.gal-tab:last-child { border-right: none; }
.gal-tab:hover { color: var(--fg); background: rgba(255,255,255,.03); }
.gal-tab.active { color: #fff; background: var(--ox); }
@media (max-width: 700px) {
  .gal-tab { flex: 1 1 33%; border-bottom: 1px solid var(--line); padding: 12px 10px; font-size: 14px; letter-spacing: .14em; }
}

@keyframes galPop {
  from { opacity: 0; transform: translateY(18px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)   scale(1);  }
}
.gal-slot.gal-pop { animation: galPop .55s cubic-bezier(.22,.61,.36,1) both; }


/* ─── 17. Reduced motion ──────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .reveal,
  .reveal-left, .reveal-right, .reveal-scale,
  .reveal-roll, .reveal-roll-r, .reveal-flip,
  .reveal-blur, .reveal-up-big, .reveal-wipe {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    clip-path: none !important;
  }
}


/* ─── 18. Page-specific helpers ───────────────────────────── */
.text-center { text-align: center; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mt-40 { margin-top: 40px; }
.mb-24 { margin-bottom: 24px; }
.muted { color: var(--fg-quiet); }
.row { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  display: inline-block;
  padding: 6px 12px;
  background: var(--ink-2);
  border: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-mute);
}


/* ─── 19. Map embed ───────────────────────────────────────── */
.map-frame {
  position: relative;
  aspect-ratio: 4 / 3;
  border: 1px solid rgba(255, 255, 255, 0.1);
  overflow: hidden;
}
.map-frame iframe {
  width: 100%; height: 100%;
  border: 0;
  filter: invert(0.92) hue-rotate(180deg) saturate(0.8);
}


/* ─── 20. Mobile compatibility ────────────────────────────────
   Catch-all polish for narrow viewports. Touches:
   - prevent horizontal scroll
   - stack barber portrait+bio rows
   - full-width booking CTAs / footer button
   - responsive iframes (booking widget)
   - wider tap targets on links/buttons
   - long-word/URL wrapping
   - sticky FAB shouldn't cover content
─────────────────────────────────────────────────────────── */
html, body { overflow-x: hidden; max-width: 100%; }
body { word-wrap: break-word; overflow-wrap: anywhere; }

/* Generic interactive tap-target floor (links/buttons inside content) */
.section a.btn, .hero a.btn, .footer-cta a.btn, .btn-cta { min-height: var(--tap); display: inline-flex; align-items: center; }
.btn { min-height: var(--tap); }

/* Make every iframe responsive by default */
iframe { max-width: 100%; }

/* Booking widget embed — flexible height on mobile */
@media (max-width: 720px) {
  .booking-frame { min-height: 420px; padding: 18px; }
  .booking-frame iframe { width: 100%; min-height: 380px; }
}

/* Barber rows: photo + bio sit side-by-side on desktop, stack below 600px */
@media (max-width: 600px) {
  .section [style*="grid-template-columns:auto 1fr"],
  .section [style*="grid-template-columns: auto 1fr"] {
    grid-template-columns: 1fr !important;
    text-align: left;
    gap: 16px !important;
  }
  .barber-card[style*="max-width:220px"] { max-width: 100% !important; margin: 0 auto; }
  .barber-card .photo[style*="max-width:220px"] { max-width: 220px !important; margin: 0 auto; }
}

/* Footer CTA: full-width button on mobile for an easy thumb-tap */
@media (max-width: 720px) {
  .footer-cta-inner { gap: 18px; }
  .footer-cta-inner > div { width: 100%; }
  .footer-cta-inner > a.btn { width: 100%; justify-content: center; }
  .footer-cta h3 { font-size: 1.6rem; line-height: 1.15; }
  .footer-cta p { font-size: 0.9rem; }
}

/* Hero CTA fills the width on small screens so it's never a small hit-target */
@media (max-width: 520px) {
  .hero .cta-block a.btn,
  .section .cta-block a.btn { width: 100%; justify-content: center; }
  h1 { font-size: clamp(2rem, 9vw, 2.6rem); line-height: 1.1; }
  h2 { font-size: clamp(1.6rem, 7vw, 2rem); line-height: 1.15; }
}

/* Gallery filter tabs — make sure 6 tabs wrap nicely on narrow mobile */
@media (max-width: 480px) {
  .gal-tabs { max-width: 100%; }
  .gal-tab { flex: 1 1 50%; font-size: 12px; padding: 12px 8px; letter-spacing: .12em; }
}

/* Footer columns: visit / hours / explore stack with comfortable spacing */
@media (max-width: 720px) {
  .footer-grid { gap: 28px; }
  .footer-col h4 { margin-bottom: 10px; }
}

/* Sticky book FAB: don't fully eclipse content; lift bottom padding */
@media (max-width: 880px) {
  body { padding-bottom: 84px; }
  .fab-book { right: 16px; bottom: 16px; }
}

/* Reviews row in footer: stack badges on phones for clear tappability */
@media (max-width: 720px) {
  .footer-reviews { gap: 4px; }
  .footer-reviews a { padding: 10px 0; min-height: var(--tap); }
}

/* Tables and any inline price grids: never overflow */
@media (max-width: 720px) {
  .price-row, table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* Embedded social links inside .row chips — slightly larger touch area */
@media (max-width: 720px) {
  .chip { padding: 8px 12px; font-size: 12px; }
  .row { gap: 10px; }
}
