/* ================================================
   THE BARBER CLUB — Main Stylesheet
   thebarberclubfl.com
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400;1,600&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

/* ── Utility ─────────────────────────────────────── */
@media (max-width: 600px) {
  .desktop-only { display: none; }
}

/* ── Reset ──────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  touch-action: manipulation;
}
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background-color: var(--black);
  color: var(--cream);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.6;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
h1, h2, h3 { text-wrap: balance; }

/* Scroll offset for fixed nav */
[id] { scroll-margin-top: 96px; }

/* ── Custom Properties ──────────────────────────── */
:root {
  --black:        #090909;
  --dark:         #111111;
  --card:         #1A1A1A;
  --card2:        #202020;
  --gold:         #C9A55A;
  --gold-dark:    #A8843A;
  --gold-light:   #DFBE7A;
  --cream:        #F0EBE1;
  --off-white:    #C8C3BA;
  --gray:         #787878;
  --border:       #272727;

  --font-display: 'Bebas Neue', sans-serif;
  --font-serif:   'Cormorant Garamond', serif;
  --font-body:    'DM Sans', sans-serif;

  --nav-height:   78px;
  --section-pad:  110px;
  --max-width:    1320px;
}

/* ── Utility ────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 48px;
}
.eyebrow {
  font-family: var(--font-body);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold);
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 5.5vw, 5.5rem);
  line-height: 0.9;
  color: var(--cream);
  letter-spacing: 0.02em;
}
.gold-rule {
  width: 50px;
  height: 2px;
  background: var(--gold);
  margin: 18px 0;
}
.text-gold { color: var(--gold); }

/* Buttons */
.btn-primary {
  display: inline-block;
  background: var(--gold);
  color: var(--black);
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 16px 38px;
  transition: background 0.3s ease, transform 0.2s ease;
}
.btn-primary:hover {
  background: var(--gold-light);
  transform: translateY(-2px);
}
.btn-outline {
  display: inline-block;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 16px 38px;
  transition: background 0.3s ease, color 0.3s ease;
}
.btn-outline:hover {
  background: var(--gold);
  color: var(--black);
}

/* ── Booksy widget — hide generated button, use our own ── */
.booksy-widget-container { display: none !important; }

/* ── Scroll Reveal ──────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.75s ease, transform 0.75s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: 0.10s; }
.reveal-d2 { transition-delay: 0.20s; }
.reveal-d3 { transition-delay: 0.30s; }
.reveal-d4 { transition-delay: 0.40s; }
.reveal-d5 { transition-delay: 0.55s; }

/* ════════════════════════════════════════════════
   NAVIGATION
   ════════════════════════════════════════════════ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-height);
  display: flex;
  align-items: center;
  background: transparent;
  box-shadow: 0 1px 0 transparent;
  transition: box-shadow 0.3s ease, backdrop-filter 0.3s ease, background 0.4s ease;
}
.nav::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(9,9,9,0.82) 0%, rgba(9,9,9,0.3) 80%, transparent 100%);
  opacity: var(--nav-grad-opacity, 1);
  pointer-events: none;
}
.nav.scrolled {
  box-shadow: 0 1px 0 var(--border);
  backdrop-filter: blur(12px);
}

.nav-inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 48px;
}

.nav-logo {
  font-family: var(--font-display);
  font-size: 1.55rem;
  letter-spacing: 0.14em;
  color: #ffffff;
  line-height: 1;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
}
.nav-logo span { color: var(--gold); }

.nav-links {
  display: flex;
  align-items: center;
  gap: 4px;
}
.nav-links a {
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #ffffff;
  padding: 6px 11px;
  transition: color 0.3s ease;
  white-space: nowrap;
  text-shadow: 0 1px 6px rgba(0,0,0,0.6);
}
.nav-links a:hover { color: var(--gold); }
.nav-links a.nav-book {
  background: var(--gold);
  color: var(--black);
  font-weight: 500;
  padding: 8px 20px;
  margin-left: 8px;
  transition: background 0.3s;
  text-shadow: none;
}
.nav-links a.nav-book:hover { background: var(--gold-light); }
.nav-links a.active-page { color: var(--gold); }

/* Dropdown */
.nav-dropdown { position: relative; }
.dropdown-menu {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  background: var(--dark);
  border: 1px solid var(--border);
  border-top: 2px solid var(--gold);
  min-width: 188px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}
.nav-dropdown:hover .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.dropdown-menu a {
  display: block;
  padding: 11px 22px;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  color: var(--off-white);
}
.dropdown-menu a:last-child { border-bottom: none; }
.dropdown-menu a:hover { background: var(--card); color: var(--gold); }

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 8px;
  background: none;
  border: none;
}
.hamburger span {
  display: block;
  width: 26px;
  height: 2px;
  background: var(--cream);
  transition: all 0.3s ease;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Nav */
.mobile-nav {
  position: fixed;
  top: var(--nav-height);
  left: 0; right: 0;
  background: rgba(9,9,9,0.98);
  border-bottom: 1px solid var(--border);
  z-index: 999;
  transform: translateY(-110%);
  opacity: 0;
  transition: transform 0.4s ease, opacity 0.4s ease;
  backdrop-filter: blur(12px);
}
.mobile-nav.open { transform: translateY(0); opacity: 1; }
.mobile-nav a {
  display: block;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--off-white);
  padding: 15px 36px;
  border-bottom: 1px solid var(--border);
  transition: color 0.3s, background 0.3s;
}
.mobile-nav a:hover { color: var(--gold); background: var(--card); }
.mobile-nav a.mobile-book { color: var(--gold); font-weight: 500; }

/* ════════════════════════════════════════════════
   HERO — Split screen with photo
   ════════════════════════════════════════════════ */
.hero {
  display: grid;
  grid-template-columns: 1fr 44%;
  min-height: 100vh;
  background: var(--black);
  overflow: hidden;
}

/* Left: content column */
.hero-content-col {
  position: relative;
  display: flex;
  align-items: center;
  padding: calc(var(--nav-height) + 50px) 60px 80px clamp(48px, 8vw, 130px);
  z-index: 2;
  background: radial-gradient(ellipse at 35% 52%, rgba(210, 148, 18, 0.18) 0%, rgba(180, 110, 10, 0.06) 40%, transparent 62%);
}

/* Gold accent bottom line on content side only */
.hero-content-col::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 80%;
  height: 2px;
  background: linear-gradient(90deg, var(--gold) 0%, transparent 100%);
}

/* Right: photo column */
.hero-photo-col {
  position: relative;
  overflow: hidden;
}
.hero-photo-col img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
/* Dark fade blending photo into content side */
.hero-photo-col::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(9,9,9,0.4) 0%, transparent 30%);
  z-index: 1;
  pointer-events: none;
}
/* Bottom fade on mobile — softens hard edge where photo meets content */
.hero-photo-col::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 0; /* hidden on desktop */
  background: linear-gradient(to top, var(--black) 0%, transparent 100%);
  z-index: 2;
  pointer-events: none;
}

/* Eyebrow tag */
.hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 22px;
  opacity: 0;
  animation: fadeSlideUp 0.8s 0.15s ease forwards;
}
.hero-tag::before {
  content: none;
}

/* Main headline */
.hero-headline {
  font-family: var(--font-display);
  font-size: clamp(5.5rem, 12.5vw, 14rem);
  line-height: 0.84;
  color: var(--cream);
  letter-spacing: 0.01em;
  opacity: 0;
  animation: fadeSlideUp 0.9s 0.3s ease forwards;
}
.hero-headline .the-word {
  display: block;
  font-size: 0.35em;
  color: var(--gold);
  letter-spacing: 0.28em;
  line-height: 1.2;
}

/* Subtitle */
.hero-subtitle {
  font-family: var(--font-serif);
  font-size: clamp(1.05rem, 1.8vw, 1.45rem);
  font-style: italic;
  color: var(--off-white);
  margin-top: 28px;
  margin-bottom: 14px;
  opacity: 0;
  animation: fadeSlideUp 0.9s 0.48s ease forwards;
}

/* Tagline badge */
.hero-tagline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 44px;
  opacity: 0;
  animation: fadeSlideUp 0.9s 0.58s ease forwards;
}
.hero-tagline::before, .hero-tagline::after {
  content: '—';
  color: var(--gold);
}

/* CTA area */
.hero-ctas {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeSlideUp 0.9s 0.7s ease forwards;
}

/* Phone */
.hero-phone {
  margin-top: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  color: var(--gray);
  opacity: 0;
  animation: fadeSlideUp 0.9s 0.85s ease forwards;
}
.hero-phone a {
  color: var(--cream);
  font-weight: 400;
  transition: color 0.3s;
}
.hero-phone a:hover { color: var(--gold); }
.hero-phone-label { font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; }



/* ════════════════════════════════════════════════
   ABOUT / INTRO STRIP
   ════════════════════════════════════════════════ */
.about-intro {
  padding: var(--section-pad) 0;
  background: var(--dark);
}
.about-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 100px;
  align-items: start;
}

.about-intro-left .eyebrow { margin-bottom: 14px; }
.about-intro-left .section-title { margin-bottom: 0; }
.about-intro-left .gold-rule { margin-bottom: 22px; }
.about-intro-left p {
  font-size: 0.95rem;
  color: var(--off-white);
  line-height: 1.85;
  margin-bottom: 14px;
}
.about-intro-left p strong {
  color: var(--cream);
  font-weight: 400;
}
.about-satisfaction {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-top: 28px;
  padding: 22px;
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
}
.about-satisfaction p {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--off-white);
}

.about-stats {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-left: 1px solid var(--border);
  padding-left: 60px;
}
.stat-row {
  padding: 32px 0;
  border-bottom: 1px solid var(--border);
}
.stat-row:first-child { padding-top: 0; }
.stat-row:last-child { border-bottom: none; }
.stat-number {
  font-family: var(--font-display);
  font-size: 4.5rem;
  color: var(--gold);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.stat-label {
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gray);
  margin-top: 6px;
}

/* Team photo in about column */
.about-team-photo {
  margin-bottom: 0;
  overflow: hidden;
}
.about-team-photo img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.6s ease;
}
.about-team-photo:hover img { transform: scale(1.03); }

/* ════════════════════════════════════════════════
   PHOTO SLIDER — Filmstrip multi-image carousel
   ════════════════════════════════════════════════ */
.photo-slider {
  background: var(--dark);
  padding: 48px 0;
  display: flex;
  align-items: center;
  gap: 0;
}

.slider-viewport {
  flex: 1;
  overflow: hidden;
  min-width: 0;
}

.slider-track {
  display: flex;
  gap: 14px;
  will-change: transform;
  /* transition handled by JS crawl — no CSS transition */
}

.slide {
  /* ~3.5 visible at once on desktop */
  min-width: calc(27% - 10px);
  flex-shrink: 0;
  height: 320px;
  overflow: hidden;
}

.slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
  display: block;
  pointer-events: none;
  user-select: none;
  transition: transform 0.5s ease;
}
.slide:hover img { transform: scale(1.04); }

/* ── Lightbox (mobile gallery tap) ──────────── */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(0,0,0,0.95);
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.lightbox.open {
  display: flex;
}
.lightbox-img {
  max-width: 100%;
  max-height: 90vh;
  object-fit: contain;
  border: 1px solid var(--border);
}
.lightbox-close {
  position: absolute;
  top: 16px;
  right: 20px;
  background: none;
  border: none;
  color: var(--cream);
  font-size: 2.4rem;
  line-height: 1;
  cursor: pointer;
  padding: 8px;
  opacity: 0.7;
}
.lightbox-close:hover { opacity: 1; }

/* Prev / Next buttons */
.slider-btn {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--gray);
  font-size: 1rem;
  cursor: pointer;
  transition: border-color 0.3s, color 0.3s, background 0.3s;
  margin: 0 20px;
}
.slider-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(201,165,90,0.08);
}
.slider-btn:disabled {
  opacity: 0.2;
  cursor: default;
  pointer-events: none;
}

/* ════════════════════════════════════════════════
   SERVICES SECTION
   ════════════════════════════════════════════════ */
.services-section {
  padding: var(--section-pad) 0;
  background: var(--black);
}
.services-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 56px;
}
.services-header-left .eyebrow { margin-bottom: 12px; }
.services-view-all {
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  border-bottom: 1px solid rgba(201,165,90,0.3);
  padding-bottom: 2px;
  transition: border-color 0.3s;
}
.services-view-all:hover { border-color: var(--gold); }

.services-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2px;
}
.service-card {
  background: var(--card);
  padding: 28px 28px 42px;
  position: relative;
  overflow: hidden;
  transition: background 0.35s ease, opacity 0.75s ease, transform 0.75s ease;
}
.service-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0;
  height: 3px;
  background: var(--gold);
  transition: width 0.45s ease;
}
.service-card:hover { background: var(--card2); }
.service-card:hover::after { width: 100%; }

.service-num {
  position: absolute;
  top: 18px; right: 20px;
  font-family: var(--font-display);
  font-size: 3.5rem;
  color: rgba(255,255,255,0.03);
  line-height: 1;
}
.service-icon {
  font-size: 1.8rem;
  margin-bottom: 22px;
  display: block;
  height: 68px;
}
.service-icon svg {
  display: block;
  height: 68px;
  width: auto;
}
.service-name {
  font-family: var(--font-display);
  font-size: 1.65rem;
  color: var(--cream);
  letter-spacing: 0.04em;
  line-height: 1.05;
  margin-bottom: 12px;
}
.service-desc {
  font-size: 0.8rem;
  color: var(--gray);
  line-height: 1.75;
}

/* Wide-card for last item */
.service-card.featured {
  background: var(--card2);
  border: 1px solid var(--border);
}
.service-card.featured .service-name { color: var(--gold); }

/* ════════════════════════════════════════════════
   QUOTE SECTION
   ════════════════════════════════════════════════ */
.quote-section {
  padding: 130px 0;
  background: var(--card);
  position: relative;
  overflow: hidden;
}
.quote-section::before {
  content: '\201C';
  position: absolute;
  top: -80px; left: 30px;
  font-family: var(--font-serif);
  font-size: 34rem;
  color: rgba(201,165,90,0.04);
  line-height: 1;
  pointer-events: none;
}
.quote-inner {
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 1;
}
.quote-text {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4.8vw, 4.8rem);
  color: var(--cream);
  line-height: 1.05;
  letter-spacing: 0.02em;
  margin-bottom: 44px;
}
.quote-text .q-gold { color: var(--gold); }
.quote-sep {
  width: 50px;
  height: 1px;
  background: var(--gold);
  margin: 0 auto 24px;
}
.quote-attr {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--gray);
  letter-spacing: 0.06em;
}
.quote-attr strong {
  font-weight: 400;
  color: var(--off-white);
}

/* ════════════════════════════════════════════════
   HOURS & LOCATION
   ════════════════════════════════════════════════ */
.info-section {
  padding: var(--section-pad) 0;
  background: var(--dark);
}
.info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 70px;
}
.info-col .eyebrow { margin-bottom: 20px; }
.info-col h3 {
  font-family: var(--font-display);
  font-size: 2.6rem;
  color: var(--cream);
  letter-spacing: 0.04em;
  margin-bottom: 26px;
}

.hours-list li {
  display: flex;
  justify-content: space-between;
  font-size: 0.85rem;
  color: var(--off-white);
  padding: 11px 0;
  border-bottom: 1px solid var(--border);
  letter-spacing: 0.04em;
}
.hours-list li:last-child { border-bottom: none; }
.hours-list li .day { color: var(--gray); }
.hours-list li .time { color: var(--gold); }
.hours-list li.closed .time { color: var(--gray); }

.phone-big {
  display: block;
  font-family: var(--font-display);
  font-size: 2.4rem;
  color: var(--gold);
  letter-spacing: 0.04em;
  margin-bottom: 18px;
  transition: color 0.3s;
}
.phone-big:hover { color: var(--gold-light); }

.contact-detail {
  font-size: 0.84rem;
  color: var(--off-white);
  line-height: 1.85;
  margin-bottom: 26px;
}

.icon-links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.icon-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gray);
  border: 1px solid var(--border);
  padding: 9px 18px;
  transition: border-color 0.3s, color 0.3s;
  width: fit-content;
}
.icon-link:hover { border-color: var(--gold); color: var(--gold); }

.area-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 0.88rem;
  color: var(--off-white);
  padding: 13px 0;
  border-bottom: 1px solid var(--border);
  letter-spacing: 0.04em;
}
.area-list li:last-child { border-bottom: none; }
.area-list li::before {
  content: '';
  width: 22px;
  height: 1px;
  background: var(--gold);
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════
   CTA BANNER
   ════════════════════════════════════════════════ */
.cta-banner {
  padding: 110px 0;
  background: var(--black);
  text-align: center;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.cta-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 22px,
    rgba(201,165,90,0.018) 22px,
    rgba(201,165,90,0.018) 23px
  );
}
.cta-banner .eyebrow { margin-bottom: 18px; }
.cta-banner h2 {
  font-family: var(--font-display);
  font-size: clamp(3rem, 7vw, 7.5rem);
  color: var(--cream);
  line-height: 0.88;
  margin-bottom: 48px;
  letter-spacing: 0.02em;
  position: relative;
}
.cta-banner h2 span { color: var(--gold); }
.cta-btns {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
  position: relative;
}

/* ════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════ */
.footer {
  background: var(--dark);
  padding: 70px 0 32px;
  border-top: 1px solid var(--border);
}
.footer-top {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 60px;
  margin-bottom: 60px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--border);
}
.footer-brand .brand-name {
  font-family: var(--font-display);
  font-size: 1.9rem;
  color: var(--cream);
  letter-spacing: 0.1em;
  line-height: 1;
  margin-bottom: 8px;
}
.footer-brand .brand-name span { color: var(--gold); }
.footer-brand .tagline {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--gray);
  font-size: 0.92rem;
  margin-bottom: 6px;
}
.footer-brand .since {
  font-size: 0.62rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 24px;
}
.footer-brand .footer-p {
  font-size: 0.82rem;
  color: var(--gray);
  line-height: 1.8;
  max-width: 280px;
}

.footer-col h4 {
  font-family: var(--font-body);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 22px;
}
.footer-col ul li { margin-bottom: 10px; }
.footer-col ul li a {
  font-size: 0.82rem;
  color: var(--gray);
  letter-spacing: 0.04em;
  transition: color 0.3s;
}
.footer-col ul li a:hover { color: var(--cream); }
.footer-col p {
  font-size: 0.82rem;
  color: var(--gray);
  line-height: 1.85;
}
.footer-col p strong {
  color: var(--off-white);
  font-weight: 400;
  display: block;
  margin-bottom: 4px;
}
.footer-col p strong + br { display: none; }
.footer-col p a {
  color: var(--gray);
  transition: color 0.3s;
}
.footer-col p a:hover { color: var(--gold); }

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.7rem;
  color: var(--gray);
  letter-spacing: 0.08em;
}
.footer-bottom a { color: var(--gray); transition: color 0.3s; }
.footer-bottom a:hover { color: var(--gold); }

/* Footer social icons */
.footer-social {
  display: flex;
  gap: 20px;
  margin-top: 20px;
}
.footer-social a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--gray);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  transition: color 0.25s;
}
.footer-social a:hover { color: var(--gold); }
.footer-social svg { flex-shrink: 0; }

/* ════════════════════════════════════════════════
   REVIEWS / TESTIMONIALS
   ════════════════════════════════════════════════ */
.reviews-section {
  background: var(--dark);
  padding: var(--section-pad) 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.reviews-header {
  margin-bottom: 56px;
}
.reviews-header .section-title span { color: var(--gold); }
.google-badge {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: var(--black);
  border: 1px solid var(--border);
  padding: 14px 20px;
  margin-top: 24px;
}
.google-badge-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.google-badge-stars {
  color: #FBBC05;
  font-size: 0.9rem;
  letter-spacing: 2px;
}
.google-badge-info {
  font-size: 0.75rem;
  color: var(--gray);
  letter-spacing: 0.06em;
}
.google-badge-link {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
  margin-left: 6px;
  transition: color 0.3s;
}
.google-badge-link:hover { color: var(--cream); }
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}
.review-card {
  background: var(--card);
  border-top: 2px solid var(--gold);
  padding: 36px 32px 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: background 0.3s ease, opacity 0.75s ease, transform 0.75s ease;
}
.review-card:hover { background: var(--card2); }
.review-stars {
  color: var(--gold);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
}
.review-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--off-white);
  line-height: 1.75;
  flex: 1;
}
.review-text::before { content: '\201C'; }
.review-text::after  { content: '\201D'; }
.review-footer {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}
.review-name {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--cream);
  letter-spacing: 0.04em;
}
.review-source {
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gray);
}
.reviews-cta {
  text-align: center;
}

/* ════════════════════════════════════════════════
   KEYFRAMES
   ════════════════════════════════════════════════ */
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════ */
@media (max-width: 1200px) {
  .services-grid { grid-template-columns: repeat(3, 1fr); }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
  .info-grid { grid-template-columns: 1fr 1fr; gap: 50px; }
  .about-intro-grid { gap: 60px; }
}

@media (max-width: 960px) {
  :root { --section-pad: 80px; }
  .reviews-grid { grid-template-columns: 1fr; gap: 20px; }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  /* Stack hero: photo on top, content below */
  .hero {
    grid-template-columns: 1fr;
    grid-template-rows: 50vh auto;
  }
  .hero-photo-col { order: -1; }
  /* Activate bottom fade on mobile */
  .hero-photo-col::after { height: 120px; }
  .hero-content-col {
    padding: 48px 36px 64px 36px;
    align-items: flex-start;
  }
  .about-intro-grid {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  .about-stats {
    border-left: none;
    padding-left: 0;
    border-top: 1px solid var(--border);
    padding-top: 40px;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .about-team-photo { width: 100%; flex-shrink: 0; }
  .about-team-photo img { height: 220px; object-position: center center; }
  .stat-row { flex: 1; min-width: 140px; padding: 20px 0; border-bottom: none; text-align: center; }
  .photo-slider { height: 360px; }
  .slider-btn { width: 40px; height: 40px; font-size: 0.9rem; }
  .slider-prev { left: 16px; }
  .slider-next { right: 16px; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .services-header { flex-direction: column; align-items: flex-start; gap: 16px; }
}

@media (max-width: 600px) {
  .reviews-section { padding: 44px 0; }
}

@media (max-width: 720px) {
  :root { --section-pad: 65px; }
  .container { padding: 0 28px; }
  .nav-inner { padding: 0 28px; }
  .hero-content-col { padding: 36px 28px 56px 28px; }
  .hero-headline { font-size: clamp(4.5rem, 20vw, 6rem); }
  .photo-slider { height: auto; padding: 32px 0; }
  .slider-btn { display: none; }
  .slide {
    min-width: unset;
    width: auto;
    height: 360px;
  }
  .slide img {
    width: auto;
    height: 100%;
    object-fit: unset;
  }
  .services-grid { grid-template-columns: 1fr; }
  .info-grid { grid-template-columns: 1fr; gap: 50px; }
  .footer-top { grid-template-columns: 1fr; gap: 40px; }
  .footer-bottom { flex-direction: column; gap: 10px; text-align: center; }
  .cta-btns { flex-direction: column; align-items: center; }
  .btn-primary, .btn-outline { text-align: center; min-width: 240px; }
}

/* ════════════════════════════════════════════════
   PAGE: blog.html
   ════════════════════════════════════════════════ */
/* ── Blog Page ───────────────────────────────── */

    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'BLOG';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(10rem, 24vw, 30rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 560px;
      margin-top: 10px;
    }

    /* ── Featured Post ───────────────────────────── */
    .blog-featured {
      background: var(--dark);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .featured-post {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0;
      border: 1px solid var(--border);
      overflow: hidden;
    }
    .featured-post-image {
      position: relative;
      background: var(--black);
      min-height: 400px;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
    }
    .featured-post-image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      display: block;
      position: absolute;
      inset: 0;
    }
    .featured-post-image-bg {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.15) 0%, transparent 60%);
    }
    .featured-post-image::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.55) 100%);
      pointer-events: none;
    }
    .featured-post-image-text {
      position: relative;
      z-index: 1;
      text-align: center;
      padding: 40px;
    }
    .featured-post-image-text .big-num {
      font-family: var(--font-display);
      font-size: clamp(6rem, 14vw, 12rem);
      color: var(--gold);
      opacity: 0.25;
      line-height: 1;
      display: block;
    }
    .featured-post-image-text .scissors {
      font-size: 4rem;
      display: block;
      margin-bottom: 12px;
    }
    .featured-post-body {
      padding: 52px 48px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 20px;
      background: var(--black);
    }
    .post-meta {
      display: flex;
      align-items: center;
      gap: 16px;
      flex-wrap: wrap;
    }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date {
      font-size: 0.8rem;
      color: var(--gray);
      letter-spacing: 0.05em;
    }
    .post-author {
      font-size: 0.8rem;
      color: var(--gray);
    }
    .post-title {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3.2rem);
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: 0.02em;
    }
    .post-excerpt {
      font-family: var(--font-serif);
      font-size: 1.05rem;
      font-style: italic;
      color: var(--off-white);
      line-height: 1.7;
    }
    .post-rule {
      width: 40px;
      height: 2px;
      background: var(--gold);
    }
    .featured-badge {
      font-size: 0.68rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--black);
      background: var(--gold);
      padding: 4px 10px;
      align-self: flex-start;
    }

    /* ── Posts Grid ──────────────────────────────── */
    .blog-grid-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .blog-grid-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 48px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 24px;
    }
    .blog-grid-header h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
    }
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .blog-card {
      background: var(--dark);
      display: flex;
      flex-direction: column;
      gap: 0;
      border: 1px solid var(--border);
      transition: border-color 0.3s, opacity 0.75s ease, transform 0.75s ease;
      cursor: pointer;
    }
    .blog-card.reveal {
      opacity: 0;
      transform: translateY(28px);
    }
    .blog-card.reveal.visible {
      opacity: 1;
      transform: translateY(0);
    }
    .blog-card:hover { border-color: rgba(191,150,71,0.4); }
    .blog-card-image {
      height: 200px;
      background: var(--black);
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    .blog-card-image-icon {
      font-size: 3.5rem;
      opacity: 0.4;
    }
    .blog-card-image img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
    }
    .blog-card-image-gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.08) 0%, transparent 70%);
    }
    .blog-card-image::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.55) 100%);
      pointer-events: none;
    }
    .blog-card-body {
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      flex: 1;
    }
    .blog-card .post-title {
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
    }
    .blog-card .post-excerpt {
      font-size: 0.92rem;
      flex: 1;
    }
    .read-more {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      align-self: flex-start;
      transition: border-color 0.3s;
      margin-top: 4px;
    }
    .read-more:hover { border-color: var(--gold); }

    /* ── Coming Soon Strip ───────────────────────── */
    .blog-coming-soon {
      background: var(--dark);
      padding: 100px 0;
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      text-align: center;
    }
    .coming-soon-inner {
      max-width: 560px;
      margin: 0 auto;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 18px;
    }
    .coming-soon-rule-group {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-bottom: 4px;
    }
    .coming-soon-line {
      display: block;
      width: 48px;
      height: 1px;
      background: var(--gold);
      opacity: 0.5;
    }
    .coming-soon-diamond {
      display: block;
      width: 7px;
      height: 7px;
      background: var(--gold);
      transform: rotate(45deg);
    }
    .coming-soon-inner h3 {
      font-family: var(--font-display);
      font-size: clamp(2.4rem, 4vw, 3.6rem);
      color: var(--cream);
      letter-spacing: 0.04em;
      line-height: 1;
    }
    .coming-soon-inner > p {
      color: var(--gray);
      font-size: 0.95rem;
      line-height: 1.75;
      max-width: 420px;
    }

    /* ── Mobile ──────────────────────────────────── */
    @media (max-width: 960px) {
      .featured-post {
        grid-template-columns: 1fr;
      }
      .featured-post-image { min-height: 240px; }
      .featured-post-body { padding: 36px 32px; }
      .blog-grid { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .blog-featured { padding: 44px 0; }
      .blog-grid-section { padding: 44px 0; }
      .blog-grid { grid-template-columns: 1fr; }
      .featured-post-body { padding: 28px 24px; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: celebrating-10-years-of-style-and-service.html
   ════════════════════════════════════════════════ */
/* ── Blog Post Page ──────────────────────────── */

    .post-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 70px;
      position: relative;
      overflow: hidden;
      border-bottom: 1px solid var(--border);
    }
    .post-hero::before {
      content: '10+';
      position: absolute;
      right: -10px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(10rem, 24vw, 28rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.02em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .post-hero-meta {
      display: flex;
      align-items: center;
      gap: 16px;
      flex-wrap: wrap;
      margin-bottom: 24px;
    }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date {
      font-size: 0.82rem;
      color: var(--gray);
      letter-spacing: 0.05em;
    }
    .post-author {
      font-size: 0.82rem;
      color: var(--gray);
    }
    .post-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.2rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
      max-width: 900px;
    }
    .post-hero h1 span { color: var(--gold); }
    .post-hero-rule {
      width: 48px;
      height: 2px;
      background: var(--gold);
      margin-top: 32px;
    }

    /* ── Post Photo ──────────────────────────────── */
    .post-photo-strip {
      background: var(--black);
      border-bottom: 1px solid var(--border);
      position: relative;
    }
    .post-photo-strip::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.55) 100%);
      pointer-events: none;
    }
    .post-photo-strip img {
      width: 100%;
      height: 480px;
      object-fit: cover;
      object-position: center 30%;
      display: block;
    }

    /* ── Post Body ───────────────────────────────── */
    .post-body-section {
      background: var(--dark);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .post-body-inner {
      max-width: 760px;
    }
    .post-body-inner h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
      margin-bottom: 24px;
      margin-top: 48px;
      line-height: 1;
    }
    .post-body-inner h2:first-child { margin-top: 0; }
    .post-body-inner p {
      color: var(--off-white);
      font-size: 1.05rem;
      line-height: 1.85;
      margin-bottom: 24px;
    }
    .post-body-inner p:last-child { margin-bottom: 0; }
    .post-pull-quote {
      border-left: 3px solid var(--gold);
      padding: 24px 32px;
      margin: 40px 0;
      background: rgba(255,255,255,0.02);
    }
    .post-pull-quote p {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.3rem !important;
      color: var(--cream) !important;
      line-height: 1.6 !important;
      margin: 0 !important;
    }
    .post-sign-off {
      margin-top: 48px;
      padding-top: 32px;
      border-top: 1px solid var(--border);
    }
    .post-sign-off p {
      font-size: 0.95rem !important;
      color: var(--gray) !important;
    }
    .post-sign-off strong {
      color: var(--cream);
      font-family: var(--font-display);
      letter-spacing: 0.05em;
      font-size: 1.1rem;
    }

    /* ── Post Nav ────────────────────────────────── */
    .post-nav {
      background: var(--black);
      padding: 48px 0;
      border-bottom: 1px solid var(--border);
    }
    .post-nav-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }
    .post-nav-next {
      display: flex;
      flex-direction: column;
      gap: 6px;
      text-decoration: none;
      max-width: 400px;
    }
    .post-nav-label {
      font-size: 0.72rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gray);
    }
    .post-nav-title {
      font-family: var(--font-display);
      font-size: 1.4rem;
      color: var(--cream);
      letter-spacing: 0.03em;
      transition: color 0.3s;
      line-height: 1.1;
    }
    .post-nav-next:hover .post-nav-title { color: var(--gold); }
    .post-nav-arrow {
      font-size: 1.6rem;
      color: var(--gold);
      flex-shrink: 0;
    }

    /* ── Mobile ──────────────────────────────────── */
    @media (max-width: 600px) {
      .post-hero { padding: calc(var(--nav-height) + 36px) 0 44px; }
      .post-photo-strip img { height: 260px; }
      .post-body-section { padding: 44px 0; }
      .post-nav-inner { flex-direction: column; align-items: flex-start; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: did-you-know-some-facts-about-barbers.html
   ════════════════════════════════════════════════ */
/* ── Blog Post Page ──────────────────────────── */

    .post-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 70px;
      position: relative;
      overflow: hidden;
      border-bottom: 1px solid var(--border);
    }
    .post-hero::before {
      content: 'BARBA';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(8rem, 20vw, 24rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.08em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .post-hero-meta {
      display: flex;
      align-items: center;
      gap: 16px;
      flex-wrap: wrap;
      margin-bottom: 24px;
    }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date {
      font-size: 0.82rem;
      color: var(--gray);
      letter-spacing: 0.05em;
    }
    .post-author {
      font-size: 0.82rem;
      color: var(--gray);
    }
    .post-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.2rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
      max-width: 900px;
    }
    .post-hero h1 span { color: var(--gold); }
    .post-hero-rule {
      width: 48px;
      height: 2px;
      background: var(--gold);
      margin-top: 32px;
    }

    /* ── Photo ───────────────────────────────────── */
    .post-photo-strip {
      background: var(--black);
      border-bottom: 1px solid var(--border);
      position: relative;
    }
    .post-photo-strip::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.55) 100%);
      pointer-events: none;
    }
    .post-photo-strip img {
      width: 100%;
      height: 480px;
      object-fit: cover;
      object-position: center calc(60% + 20px);
      display: block;
    }

    /* ── Post Body ───────────────────────────────── */
    .post-body-section {
      background: var(--dark);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .post-body-inner {
      max-width: 760px;
    }
    .post-body-inner h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
      margin-bottom: 20px;
      margin-top: 52px;
      line-height: 1;
    }
    .post-body-inner h2:first-child { margin-top: 0; }
    .post-body-inner p {
      color: var(--off-white);
      font-size: 1.05rem;
      line-height: 1.85;
      margin-bottom: 24px;
    }
    .post-body-inner p:last-child { margin-bottom: 0; }
    .post-pull-quote {
      border-left: 3px solid var(--gold);
      padding: 24px 32px;
      margin: 40px 0;
      background: rgba(255,255,255,0.02);
    }
    .post-pull-quote p {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.3rem !important;
      color: var(--cream) !important;
      line-height: 1.6 !important;
      margin: 0 !important;
    }

    /* Fact cards */
    .fact-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2px;
      margin: 40px 0;
    }
    .fact-card {
      background: rgba(255,255,255,0.03);
      border: 1px solid var(--border);
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }
    .fact-card .fact-icon {
      font-size: 1.8rem;
      line-height: 1;
    }
    .fact-card .fact-label {
      font-size: 0.72rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gold);
    }
    .fact-card .fact-text {
      font-size: 0.95rem !important;
      color: var(--off-white) !important;
      line-height: 1.65 !important;
      margin: 0 !important;
    }

    /* ── Post Nav ────────────────────────────────── */
    .post-nav {
      background: var(--black);
      padding: 48px 0;
      border-bottom: 1px solid var(--border);
    }
    .post-nav-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }
    .post-nav-prev {
      display: flex;
      flex-direction: column;
      gap: 6px;
      text-decoration: none;
      max-width: 400px;
    }
    .post-nav-label {
      font-size: 0.72rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gray);
    }
    .post-nav-title {
      font-family: var(--font-display);
      font-size: 1.4rem;
      color: var(--cream);
      letter-spacing: 0.03em;
      transition: color 0.3s;
      line-height: 1.1;
    }
    .post-nav-prev:hover .post-nav-title { color: var(--gold); }
    .post-nav-arrow {
      font-size: 1.6rem;
      color: var(--gold);
      flex-shrink: 0;
    }

    /* ── Mobile ──────────────────────────────────── */
    @media (max-width: 720px) {
      .fact-grid { grid-template-columns: 1fr; }
    }
    @media (max-width: 600px) {
      .post-hero { padding: calc(var(--nav-height) + 36px) 0 44px; }
      .post-photo-strip img { height: 260px; }
      .post-body-section { padding: 44px 0; }
      .post-nav-inner { flex-direction: column; align-items: flex-start; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: hairstyles.html
   ════════════════════════════════════════════════ */
/* ── Hairstyles Page ─────────────────────────── */

    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'STYLES';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(8rem, 18vw, 22rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner {
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 540px;
      margin-top: 10px;
    }

    /* ── Intro ───────────────────────────────────── */
    .hairstyles-intro {
      background: var(--dark);
      padding: 60px 0;
      border-bottom: 1px solid var(--border);
    }
    .hairstyles-intro-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 60px;
    }
    .hairstyles-intro-text {
      max-width: 600px;
    }
    .hairstyles-intro-text h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 3.5vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.04em;
      margin-bottom: 14px;
    }
    .hairstyles-intro-text p {
      font-size: 0.95rem;
      color: var(--off-white);
      line-height: 1.85;
    }
    .hairstyles-intro-stat {
      text-align: right;
      flex-shrink: 0;
    }
    .hairstyles-intro-stat .stat-big {
      font-family: var(--font-display);
      font-size: 5rem;
      color: var(--gold);
      line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .hairstyles-intro-stat .stat-label {
      font-size: 0.68rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--gray);
      margin-top: 6px;
    }

    /* ── Gallery section ─────────────────────────── */
    .gallery-section {
      background: var(--black);
      padding: var(--section-pad) 0;
    }
    .gallery-section + .gallery-section {
      background: var(--dark);
      border-top: 1px solid var(--border);
    }
    .gallery-section + .gallery-section + .gallery-section {
      background: var(--black);
      border-top: 1px solid var(--border);
    }

    .gallery-header {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      margin-bottom: 36px;
      gap: 20px;
    }
    .gallery-header-left .eyebrow { margin-bottom: 8px; }
    .gallery-header-left h2 {
      font-family: var(--font-display);
      font-size: clamp(2.5rem, 5vw, 5rem);
      color: var(--cream);
      letter-spacing: 0.03em;
      line-height: 0.9;
    }
    .gallery-count {
      font-family: var(--font-display);
      font-size: 3.5rem;
      color: rgba(201,165,90,0.2);
      line-height: 1;
      flex-shrink: 0;
    }

    /* Photo grid */
    .photo-grid {
      display: grid;
      gap: 10px;
    }
    .photo-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
    .photo-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
    .photo-grid.cols-5 { grid-template-columns: repeat(5, 1fr); }

    .photo-card {
      position: relative;
      overflow: hidden;
      background: var(--card);
      aspect-ratio: 3/4;
    }
    .photo-card.wide { aspect-ratio: 4/3; }
    .photo-card.square { aspect-ratio: 1/1; }

    .photo-card img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      display: block;
      transition: transform 0.6s ease;
      will-change: transform;
    }
    .photo-card:hover img { transform: scale(1.06); }

    .photo-label {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      padding: 36px 14px 12px;
      background: linear-gradient(to top, rgba(9,9,9,0.88) 0%, transparent 100%);
      font-family: var(--font-body);
      font-size: 0.72rem;
      font-weight: 400;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--cream);
      opacity: 0;
      transition: opacity 0.3s ease;
    }
    .photo-card:hover .photo-label { opacity: 1; }

    /* Always-visible label variant */
    .photo-label.always-on { opacity: 1; }

    /* Feature row: one wide + two tall */
    .feature-row {
      display: grid;
      grid-template-columns: 1.6fr 1fr 1fr;
      gap: 10px;
      margin-bottom: 10px;
    }
    .feature-row .photo-card { aspect-ratio: unset; height: 420px; }

    /* ── Responsive ──────────────────────────────── */
    @media (max-width: 1100px) {
      .photo-grid.cols-5 { grid-template-columns: repeat(3, 1fr); }
      .photo-grid.cols-4 { grid-template-columns: repeat(3, 1fr); }
    }
    @media (max-width: 900px) {
      .hairstyles-intro-inner { flex-direction: column; align-items: flex-start; gap: 28px; }
      .hairstyles-intro-stat { text-align: left; }
      .photo-grid.cols-4,
      .photo-grid.cols-3,
      .photo-grid.cols-5 { grid-template-columns: repeat(2, 1fr); }
      .feature-row { grid-template-columns: 1fr 1fr; }
      .feature-row .photo-card:last-child { display: none; }
      .feature-row .photo-card { height: 300px; }
      .gallery-header { flex-direction: column; align-items: flex-start; gap: 0; }
      .gallery-count { display: none; }
      .photo-label { opacity: 1; }
    }
    @media (max-width: 600px) {
      /* Mobile spacing per brand standard */
      .page-hero { padding-top: calc(var(--nav-height) + 36px); padding-bottom: 24px; }
      .page-hero h1 { font-size: clamp(4rem, 18vw, 6rem); }
      .hairstyles-intro { padding: 36px 0; }
      .gallery-section { padding: 44px 0; }
      .gallery-header { margin-bottom: 24px; }
      .photo-grid.cols-4,
      .photo-grid.cols-3,
      .photo-grid.cols-5 { grid-template-columns: repeat(2, 1fr); }
      .feature-row { grid-template-columns: 1fr; }
      .feature-row .photo-card { height: 260px; }
      .feature-row .photo-card:not(:first-child) { display: none; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: barbers.html
   ════════════════════════════════════════════════ */
/* ── Barbers Page ────────────────────────────── */

    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'TEAM';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(10rem, 22vw, 28rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 560px;
      margin-top: 10px;
    }

    /* ── Team photo strip ────────────────────────── */
    .team-photo-strip {
      background: var(--black);
      padding: 0;
      line-height: 0;
      position: relative;
    }
    .team-photo-strip img {
      width: 100%;
      height: 600px;
      object-fit: cover;
      object-position: center 10%;
      display: block;
    }
    .team-photo-strip::after {
      content: '';
      position: absolute;
      bottom: 0; left: 0; right: 0;
      height: 200px;
      background: linear-gradient(to top, var(--dark) 0%, transparent 100%);
      pointer-events: none;
    }

    /* ── Intro ───────────────────────────────────── */
    .barbers-intro {
      background: var(--dark);
      padding: 60px 0 70px;
      border-bottom: 1px solid var(--border);
    }
    .barbers-intro-inner {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }
    .barbers-intro h2 {
      font-family: var(--font-display);
      font-size: clamp(2.2rem, 4vw, 3.8rem);
      color: var(--cream);
      letter-spacing: 0.04em;
      line-height: 1;
      margin-bottom: 20px;
    }
    .barbers-intro h2 span { color: var(--gold); }
    .barbers-intro p {
      font-size: 0.95rem;
      color: var(--off-white);
      line-height: 1.85;
    }
    .barbers-stat-row {
      display: flex;
      gap: 48px;
    }
    .barbers-stat { text-align: center; }
    .barbers-stat .num {
      font-family: var(--font-display);
      font-size: 4rem;
      color: var(--gold);
      line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .barbers-stat .lbl {
      font-size: 0.68rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--gray);
      margin-top: 6px;
    }

    /* ── Barber cards grid ───────────────────────── */
    .barbers-section {
      background: var(--black);
      padding: var(--section-pad) 0;
    }
    .barbers-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 0;
      background: transparent;
    }

    .barber-card {
      background: var(--dark);
      padding: 44px 36px;
      position: relative;
      overflow: hidden;
      outline: 1px solid var(--border);
      transition: background-color 0.3s, opacity 0.75s ease, transform 0.75s ease;
      display: flex;
      flex-direction: row;
      align-items: flex-start;
      gap: 28px;
    }
    .barber-card:hover { background: var(--card2); }

    /* Large background number */
    .barber-card::before {
      content: attr(data-num);
      position: absolute;
      right: -10px;
      bottom: -20px;
      font-family: var(--font-display);
      font-size: 9rem;
      color: rgba(201,165,90,0.05);
      line-height: 1;
      pointer-events: none;
      transition: color 0.3s;
    }
    .barber-card:hover::before { color: rgba(201,165,90,0.08); }

    .barber-origin {
      font-size: 0.62rem;
      letter-spacing: 0.28em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 10px;
    }
    .barber-name {
      font-family: var(--font-display);
      font-size: 3.2rem;
      color: var(--cream);
      letter-spacing: 0.06em;
      line-height: 1;
      margin-bottom: 20px;
    }
    .barber-rule {
      width: 40px;
      height: 2px;
      background: var(--gold);
      margin-bottom: 20px;
    }
    .barber-bio {
      font-size: 0.88rem;
      color: var(--off-white);
      line-height: 1.85;
      margin-bottom: 24px;
    }
    .barber-specialties {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .barber-tag {
      font-size: 0.62rem;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--off-white);
      border: 1px solid rgba(255,255,255,0.12);
      background: rgba(255,255,255,0.04);
      padding: 5px 10px;
      transition: border-color 0.3s, color 0.3s;
    }
    .barber-card:hover .barber-tag {
      border-color: rgba(201,165,90,0.3);
      color: var(--off-white);
    }

    /* Photo slot — hidden until photo is added */
    .barber-photo-slot {
      width: 120px;
      height: 120px;
      border-radius: 50%;
      background: var(--card2);
      border: 2px solid var(--border);
      flex-shrink: 0;
      margin-bottom: 14px;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .barber-card-left {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      flex-shrink: 0;
      width: 160px;
    }
    .barber-card-right {
      flex: 1;
      min-width: 0;
    }
    .barber-photo-slot img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
    }
    .barber-photo-slot .initials {
      font-family: var(--font-display);
      font-size: 1.6rem;
      color: var(--gold);
      opacity: 0.4;
    }

    /* ── Responsive ──────────────────────────────── */
    /* Already 2-col on desktop, go single on mobile */
    @media (max-width: 900px) {
      .barbers-intro-inner { grid-template-columns: 1fr; gap: 40px; }
      .team-photo-strip img { height: 380px; }
    }
    @media (max-width: 600px) {
      /* Mobile spacing */
      .page-hero { padding-top: calc(var(--nav-height) + 36px); padding-bottom: 24px; }
      .page-hero h1 { font-size: clamp(4rem, 18vw, 6rem); }
      .barbers-intro { padding: 40px 0 48px; }
      .barbers-section { padding: 44px 0; }
      .barbers-grid { grid-template-columns: 1fr; }
      .barber-card { padding: 32px 24px; flex-direction: column; align-items: flex-start; gap: 0; }
      .barber-card-left { flex-direction: column; align-items: flex-start; text-align: left; width: 100%; }
      .barber-card-right { width: 100%; }
      .barber-card::before { font-size: 7rem; }
      .barber-name { font-size: 2.6rem; margin-bottom: 0; }
      .barber-rule { margin-top: 16px; margin-bottom: 16px; }
      .team-photo-strip img { height: 280px; }
      .barbers-stat-row { gap: 32px; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: 404.html
   ════════════════════════════════════════════════ */
.error-page {
      background: var(--black);
      min-height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      overflow: hidden;
    }
    .error-page::before {
      content: '404';
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
      font-family: var(--font-display);
      font-size: clamp(20rem, 55vw, 56rem);
      color: rgba(255,255,255,0.06);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .error-inner {
      position: relative;
      z-index: 1;
      text-align: center;
      padding: 40px 24px;
      max-width: 560px;
    }
    .error-eyebrow {
      font-size: 0.78rem;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 20px;
      display: block;
    }
    .error-heading {
      font-family: var(--font-display);
      font-size: clamp(4rem, 10vw, 9rem);
      color: var(--cream);
      line-height: 0.88;
      letter-spacing: 0.02em;
      margin-bottom: 24px;
    }
    .error-heading span { color: var(--gold); }
    .error-rule {
      width: 40px;
      height: 2px;
      background: var(--gold);
      margin: 0 auto 28px;
    }
    .error-message {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.1rem;
      color: var(--off-white);
      line-height: 1.7;
      margin-bottom: 40px;
    }
    .error-links {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      justify-content: center;
    }

/* ════════════════════════════════════════════════
   PAGE: contact-us.html
   ════════════════════════════════════════════════ */
/* ── Contact Page Specific ───────────────────── */

    /* Page hero — tight, typographic, no photo */
    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'CONTACT';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(8rem, 18vw, 22rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner {
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 480px;
      margin-top: 10px;
    }

    /* ── Main contact layout ─────────────────────── */
    .contact-section {
      background: var(--dark);
      padding: var(--section-pad) 0;
    }
    .contact-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: start;
    }

    /* Left — info column */
    .contact-info { display: flex; flex-direction: column; gap: 48px; }

    .contact-block h3 {
      font-family: var(--font-display);
      font-size: 1.6rem;
      letter-spacing: 0.08em;
      color: var(--cream);
      margin-bottom: 16px;
    }
    .contact-block .eyebrow { margin-bottom: 8px; }

    .contact-phone {
      font-family: var(--font-display);
      font-size: 3rem;
      color: var(--gold);
      letter-spacing: 0.06em;
      line-height: 1;
      transition: color 0.3s;
    }
    .contact-phone:hover { color: var(--gold-light); }

    .contact-address {
      font-size: 0.92rem;
      color: var(--off-white);
      line-height: 1.9;
    }

    /* Hours table */
    .hours-table {
      width: 100%;
      border-collapse: collapse;
    }
    .hours-table tr {
      border-bottom: 1px solid var(--border);
    }
    .hours-table tr:last-child { border-bottom: none; }
    .hours-table td {
      padding: 11px 0;
      font-size: 0.88rem;
      color: var(--off-white);
    }
    .hours-table td:first-child {
      color: var(--gray);
      font-size: 0.72rem;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      width: 50%;
    }
    .hours-table .closed { color: var(--gray); }
    .hours-open { color: var(--gold) !important; font-weight: 500; }

    /* Quick links */
    .contact-links { display: flex; flex-direction: column; gap: 10px; }
    .contact-link-btn {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 14px 20px;
      border: 1px solid var(--border);
      font-size: 0.78rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--off-white);
      transition: border-color 0.3s, color 0.3s, background-color 0.3s;
    }
    .contact-link-btn:hover {
      border-color: var(--gold);
      color: var(--gold);
      background: rgba(201,165,90,0.05);
    }
    .contact-link-btn.primary {
      background: var(--gold);
      border-color: var(--gold);
      color: var(--black);
      font-weight: 500;
    }
    .contact-link-btn.primary:hover {
      background: var(--gold-light);
      border-color: var(--gold-light);
      color: var(--black);
    }
    .contact-link-icon { font-size: 1.1rem; }

    /* Right — form column */
    .contact-form-wrap {}
    .contact-form-wrap h2 {
      font-family: var(--font-display);
      font-size: 2rem;
      letter-spacing: 0.08em;
      color: var(--cream);
      margin-bottom: 8px;
    }
    .contact-form-wrap .form-sub {
      font-size: 0.88rem;
      color: var(--gray);
      margin-bottom: 36px;
      line-height: 1.7;
    }

    .contact-form { display: flex; flex-direction: column; gap: 18px; }

    .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

    .form-group { display: flex; flex-direction: column; gap: 7px; }
    .form-group label {
      font-size: 0.66rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--gray);
    }
    .form-group input,
    .form-group textarea {
      background: #252525;
      border: 1px solid #3a3a3a;
      color: var(--cream);
      font-family: var(--font-body);
      font-size: 0.9rem;
      padding: 14px 18px;
      outline: none;
      transition: border-color 0.3s;
      width: 100%;
    }
    .form-group input:focus,
    .form-group textarea:focus {
      border-color: var(--gold);
    }
    .form-group input::placeholder,
    .form-group textarea::placeholder {
      color: var(--gray);
      opacity: 0.6;
    }
    .form-group textarea {
      resize: vertical;
      min-height: 130px;
    }
    .form-submit {
      background: var(--gold);
      color: var(--black);
      border: none;
      font-family: var(--font-display);
      font-size: 1.05rem;
      letter-spacing: 0.18em;
      padding: 18px 40px;
      cursor: pointer;
      transition: background-color 0.3s;
      align-self: flex-start;
    }
    .form-submit:hover { background: var(--gold-light); }

    /* ── Map strip ───────────────────────────────── */
    .map-strip {
      background: var(--black);
      padding: 0;
      line-height: 0;
    }
    .map-strip iframe {
      width: 100%;
      height: 380px;
      border: none;
      display: block;
      filter: grayscale(100%) invert(90%) contrast(85%);
      opacity: 0.7;
    }

    /* ── Responsive ──────────────────────────────── */
    @media (max-width: 900px) {
      .contact-grid { grid-template-columns: 1fr; gap: 60px; }
      .form-row { grid-template-columns: 1fr; }
    }
    @media (max-width: 600px) {
      .page-hero { padding-bottom: 30px; }
      .contact-section { padding-top: 50px; }
      .page-hero h1 { font-size: clamp(4rem, 18vw, 6rem); }
      .contact-phone { font-size: 2.2rem; }
      .form-submit { width: 100%; text-align: center; }
      .cta-banner { padding: 60px 0; }
    }

/* ── Style Help Section ──────────────────────── */
.style-help-section {
  background: var(--dark);
  padding: var(--section-pad) 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.style-help-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.style-help-text h2 {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 4.5vw, 4.2rem);
  color: var(--cream);
  letter-spacing: 0.02em;
  line-height: 0.95;
  margin-top: 14px;
}
.style-help-text p {
  color: var(--off-white);
  font-size: 0.97rem;
  line-height: 1.75;
  margin-bottom: 16px;
}
.style-help-btns {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 32px;
}
.style-help-photo {
  position: relative;
  overflow: hidden;
}
.style-help-photo img {
  width: 100%;
  height: 560px;
  object-fit: cover;
  object-position: center;
  display: block;
}
.style-help-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.45) 100%);
  pointer-events: none;
}
@media (max-width: 768px) {
  .style-help-inner { grid-template-columns: 1fr; gap: 36px; }
  .style-help-photo { order: -1; }
  .style-help-photo img { height: 300px; }
  .style-help-section { padding: 60px 0; }
  .style-help-btns { justify-content: center; }
}

/* ════════════════════════════════════════════════
   PAGE: careers.html
   ════════════════════════════════════════════════ */
/* ── Careers Page ────────────────────────────── */

    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'HIRING';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(8rem, 18vw, 24rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 520px;
      margin-top: 10px;
    }

    /* ── Why Join Section ────────────────────────── */
    .why-join {
      background: var(--dark);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .why-split {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }
    .why-text { display: flex; flex-direction: column; gap: 24px; }
    .why-text h2 {
      font-family: var(--font-display);
      font-size: clamp(2.8rem, 6vw, 5.5rem);
      color: var(--cream);
      line-height: 0.92;
      letter-spacing: 0.02em;
    }
    .why-text h2 span { color: var(--gold); }
    .why-text p {
      color: var(--off-white);
      line-height: 1.8;
      font-size: 1.02rem;
    }
    .perks-list {
      display: flex;
      flex-direction: column;
      gap: 0;
      border-top: 1px solid var(--border);
      margin-top: 8px;
    }
    .perk-item {
      display: flex;
      align-items: flex-start;
      gap: 16px;
      padding: 18px 0;
      border-bottom: 1px solid var(--border);
    }
    .perk-icon { font-size: 1.3rem; flex-shrink: 0; margin-top: 2px; }
    .perk-text {
      font-size: 0.92rem;
      color: var(--off-white);
      line-height: 1.6;
    }
    .perk-text strong {
      display: block;
      color: var(--cream);
      font-size: 0.82rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      margin-bottom: 3px;
    }
    .why-photo {
      position: relative;
    }
    .why-photo img {
      width: 100%;
      height: 560px;
      object-fit: cover;
      object-position: center 15%;
      display: block;
    }
    .why-photo-label {
      position: absolute;
      bottom: 24px;
      left: 24px;
      background: var(--black);
      color: var(--gold);
      font-family: var(--font-display);
      font-size: 0.85rem;
      letter-spacing: 0.12em;
      padding: 6px 14px;
    }

    /* ── Application Form ────────────────────────── */
    .apply-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .apply-grid {
      display: grid;
      grid-template-columns: 340px 1fr;
      gap: 80px;
      align-items: start;
    }
    .apply-info { padding-top: 6px; }
    .apply-info h2 {
      font-family: var(--font-display);
      font-size: clamp(2.5rem, 5vw, 4rem);
      color: var(--cream);
      line-height: 0.95;
      letter-spacing: 0.02em;
      margin-top: 10px;
      margin-bottom: 24px;
    }
    .apply-info h2 span { color: var(--gold); }
    .apply-info p {
      color: var(--off-white);
      line-height: 1.8;
      font-size: 0.95rem;
      margin-bottom: 16px;
    }
    .apply-info p:last-child { margin-bottom: 0; }
    .apply-rule {
      width: 40px;
      height: 2px;
      background: var(--gold);
      margin-bottom: 24px;
    }
    .apply-contact-line {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 0.82rem;
      color: var(--gray);
      margin-top: 32px;
      padding-top: 28px;
      border-top: 1px solid var(--border);
    }
    .apply-contact-line a {
      color: var(--gold);
      text-decoration: none;
      font-family: var(--font-display);
      font-size: 1.2rem;
      letter-spacing: 0.06em;
    }
    .apply-contact-line a:hover { color: var(--gold-light); }

    /* Form */
    .apply-form-wrap {}
    .apply-form { display: flex; flex-direction: column; gap: 18px; }
    .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
    .form-group { display: flex; flex-direction: column; gap: 7px; }
    .form-group label {
      font-size: 0.66rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--gray);
    }
    .form-group input,
    .form-group textarea,
    .form-group select {
      background: #252525;
      border: 1px solid #3a3a3a;
      color: var(--cream);
      font-family: var(--font-body);
      font-size: 0.9rem;
      padding: 14px 18px;
      outline: none;
      transition: border-color 0.3s;
      width: 100%;
      appearance: none;
    }
    .form-group select {
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 16px center;
      padding-right: 40px;
    }
    .form-group select option { background: #252525; }
    .form-group input:focus,
    .form-group textarea:focus,
    .form-group select:focus { border-color: var(--gold); }
    .form-group input::placeholder,
    .form-group textarea::placeholder { color: var(--gray); opacity: 0.6; }
    .form-group textarea { resize: vertical; min-height: 150px; }
    .form-submit {
      background: var(--gold);
      color: var(--black);
      border: none;
      font-family: var(--font-display);
      font-size: 1rem;
      letter-spacing: 0.14em;
      padding: 18px 40px;
      cursor: pointer;
      transition: background-color 0.3s;
      align-self: flex-start;
      margin-top: 6px;
    }
    .form-submit:hover { background: var(--gold-light); }

    /* ── Mobile ──────────────────────────────────── */
    @media (max-width: 960px) {
      .why-split { grid-template-columns: 1fr; gap: 48px; }
      .why-photo img { height: 400px; }
      .apply-grid { grid-template-columns: 1fr; gap: 48px; }
      .form-row { grid-template-columns: 1fr; }
    }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .why-join { padding: 44px 0; }
      .why-photo img { height: 300px; }
      .apply-section { padding: 44px 0; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: meet-the-owner.html
   ════════════════════════════════════════════════ */
/* ── Meet the Owner Page ─────────────────────── */

    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'OWNER';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(8rem, 18vw, 24rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 560px;
      margin-top: 10px;
    }

    /* ── Owner Spotlight ─────────────────────────── */
    .owner-spotlight {
      background: var(--dark);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .owner-split {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: start;
    }
    .owner-photo-col {
      position: relative;
    }
    .owner-photo-col img {
      width: 100%;
      height: 580px;
      object-fit: cover;
      object-position: center 40%;
      display: block;
    }
    .owner-photo-label {
      position: absolute;
      bottom: 24px;
      left: 24px;
      background: var(--gold);
      color: var(--black);
      font-family: var(--font-display);
      font-size: 0.85rem;
      letter-spacing: 0.12em;
      padding: 6px 14px;
    }
    .owner-info-col {
      display: flex;
      flex-direction: column;
      gap: 28px;
      padding-top: 8px;
    }
    .owner-title {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1rem;
      color: var(--gold);
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }
    .owner-name {
      font-family: var(--font-display);
      font-size: clamp(4rem, 8vw, 7rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .owner-rule {
      width: 48px;
      height: 2px;
      background: var(--gold);
    }
    .owner-bio p {
      color: var(--off-white);
      line-height: 1.8;
      margin-bottom: 16px;
    }
    .owner-bio p:last-child { margin-bottom: 0; }
    .owner-stats {
      display: flex;
      gap: 40px;
      border-top: 1px solid var(--border);
      padding-top: 28px;
    }
    .owner-stat .num {
      font-family: var(--font-display);
      font-size: 2.8rem;
      color: var(--gold);
      line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .owner-stat .lbl {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      margin-top: 4px;
    }

    /* ── Content Blocks ──────────────────────────── */
    .content-block {
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .content-block:nth-child(even) { background: var(--dark); }
    .content-block-inner {
      display: grid;
      grid-template-columns: 300px 1fr;
      gap: 80px;
      align-items: start;
    }
    .content-block-label {
      padding-top: 6px;
    }
    .content-block-label h3 {
      font-family: var(--font-display);
      font-size: clamp(2.2rem, 4.5vw, 3.8rem);
      color: var(--cream);
      line-height: 1;
      margin-top: 8px;
    }
    .content-block-body p {
      color: var(--off-white);
      line-height: 1.8;
      margin-bottom: 16px;
    }
    .content-block-body p:last-child { margin-bottom: 0; }

    /* Advisor card */
    .advisor-card {
      display: flex;
      align-items: flex-start;
      gap: 20px;
      background: rgba(255,255,255,0.03);
      border: 1px solid var(--border);
      padding: 28px;
      margin-top: 28px;
    }
    .advisor-icon {
      flex-shrink: 0;
      line-height: 1;
      margin-top: 2px;
      color: var(--gold);
    }
    .advisor-icon svg {
      display: block;
    }
    .advisor-info h4 {
      font-family: var(--font-display);
      font-size: 1.5rem;
      color: var(--cream);
      letter-spacing: 0.04em;
      margin-bottom: 4px;
    }
    .advisor-info p {
      color: var(--gray) !important;
      font-size: 0.88rem !important;
      line-height: 1.7 !important;
      margin-bottom: 10px !important;
    }
    .advisor-info a {
      font-size: 0.8rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      transition: border-color 0.3s;
      text-decoration: none;
    }
    .advisor-info a:hover { border-color: var(--gold); }

    /* ── Info Strip ──────────────────────────────── */
    .owner-info-strip {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .info-strip-grid {
      display: grid;
      grid-template-columns: 1fr 1px 1fr 1px 1fr;
      gap: 0;
      align-items: start;
    }
    .info-strip-divider {
      background: var(--border);
      height: 100%;
      min-height: 120px;
    }
    .info-strip-block {
      padding: 0 48px;
    }
    .info-strip-block:first-child { padding-left: 0; }
    .info-strip-block:last-child { padding-right: 0; }
    .info-strip-block h4 {
      font-family: var(--font-display);
      font-size: 0.9rem;
      letter-spacing: 0.15em;
      color: var(--gold);
      margin-bottom: 16px;
    }
    .info-strip-block p,
    .info-strip-block a:not(.btn-primary) {
      font-size: 0.9rem;
      color: var(--gray);
      line-height: 1.9;
      text-decoration: none;
      display: block;
    }
    .info-strip-block a:not(.btn-primary):hover { color: var(--gold); }
    .info-strip-block .hours-row {
      display: flex;
      justify-content: space-between;
      gap: 16px;
      font-size: 0.88rem;
      color: var(--gray);
      line-height: 2;
    }
    .info-strip-block .hours-row .day { color: var(--off-white); }
    .hours-closed { color: var(--gray) !important; font-style: italic; }

    /* ── Mobile ──────────────────────────────────── */
    @media (max-width: 960px) {
      .owner-split {
        grid-template-columns: 1fr;
        gap: 40px;
      }
      .owner-photo-col img { height: 420px; }
      .info-strip-grid {
        grid-template-columns: 1fr;
        gap: 40px;
      }
      .info-strip-divider { display: none; }
      .info-strip-block { padding: 0; }
      .content-block-inner {
        grid-template-columns: 1fr;
        gap: 28px;
      }
    }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .owner-spotlight { padding: 44px 0; }
      .owner-photo-col img { height: 340px; }
      .owner-stats { gap: 24px; flex-wrap: wrap; }
      .content-block { padding: 44px 0; }
      .owner-info-strip { padding: 44px 0; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: about-us.html
   ════════════════════════════════════════════════ */
/* ── About Page ──────────────────────────────── */

    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'ABOUT';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(9rem, 20vw, 26rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 560px;
      margin-top: 10px;
    }

    /* ── Intro — split layout ────────────────────── */
    .about-intro-section {
      background: var(--dark);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .about-split {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }
    .about-split-text h2 {
      font-family: var(--font-display);
      font-size: clamp(2.5rem, 4.5vw, 4.5rem);
      color: var(--cream);
      letter-spacing: 0.03em;
      line-height: 0.92;
      margin-bottom: 28px;
    }
    .about-split-text h2 span { color: var(--gold); }
    .about-split-text p {
      font-size: 0.95rem;
      color: var(--off-white);
      line-height: 1.9;
      margin-bottom: 16px;
    }
    .about-split-text p:last-child { margin-bottom: 0; }
    .about-split-photo {
      position: relative;
      overflow: hidden;
    }
    .about-split-photo img {
      width: 100%;
      height: 520px;
      object-fit: cover;
      object-position: center 20%;
      display: block;
      transition: transform 0.6s ease;
      will-change: transform;
    }
    .about-split-photo:hover img { transform: scale(1.03); }
    .about-split-photo::after {
      content: 'EST. 2013';
      position: absolute;
      bottom: 24px;
      right: 24px;
      font-family: var(--font-display);
      font-size: 0.75rem;
      letter-spacing: 0.28em;
      color: var(--gold);
      background: rgba(9,9,9,0.75);
      padding: 8px 14px;
    }

    /* ── Content blocks ──────────────────────────── */
    .content-block {
      padding: var(--section-pad) 0;
    }
    .content-block:nth-child(odd) { background: var(--black); }
    .content-block:nth-child(even) { background: var(--dark); }
    .content-block + .content-block { border-top: 1px solid var(--border); }

    .content-block-inner {
      display: grid;
      grid-template-columns: 340px 1fr;
      gap: 80px;
      align-items: start;
    }
    .content-block-label h3 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 3.5vw, 3.2rem);
      color: var(--cream);
      letter-spacing: 0.04em;
      line-height: 1;
      margin-top: 10px;
    }
    .content-block-label .eyebrow { margin-bottom: 10px; }

    .content-block-body p {
      font-size: 0.95rem;
      color: var(--off-white);
      line-height: 1.9;
      margin-bottom: 16px;
    }
    .content-block-body p:last-child { margin-bottom: 0; }

    /* Team card link */
    .team-link-card {
      display: flex;
      align-items: center;
      gap: 20px;
      margin-top: 32px;
      padding: 22px 24px;
      border: 1px solid var(--border);
      border-left: 3px solid var(--gold);
      transition: background-color 0.3s;
    }
    .team-link-card:hover { background: rgba(201,165,90,0.05); }
    .team-link-card img {
      width: 72px;
      height: 72px;
      object-fit: cover;
      object-position: center 20%;
      flex-shrink: 0;
    }
    .team-link-card-text .label {
      font-size: 0.66rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 4px;
    }
    .team-link-card-text .name {
      font-family: var(--font-display);
      font-size: 1.3rem;
      color: var(--cream);
      letter-spacing: 0.06em;
    }
    .team-link-card-text .sub {
      font-size: 0.8rem;
      color: var(--gray);
      margin-top: 2px;
    }
    .team-link-card .arrow {
      margin-left: auto;
      font-size: 1.2rem;
      color: var(--gold);
      flex-shrink: 0;
    }

    /* Cleanliness icon list */
    .clean-list {
      display: flex;
      flex-direction: column;
      gap: 0;
      margin-top: 28px;
    }
    .clean-item {
      display: flex;
      align-items: flex-start;
      gap: 16px;
      padding: 16px 0;
      border-bottom: 1px solid var(--border);
    }
    .clean-item:first-child { border-top: 1px solid var(--border); }
    .clean-icon {
      font-size: 1.1rem;
      flex-shrink: 0;
      margin-top: 2px;
    }
    .clean-text {
      font-size: 0.88rem;
      color: var(--off-white);
      line-height: 1.7;
    }

    /* ── Photo accent row ────────────────────────── */
    .photo-accent-row {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
      margin-top: 48px;
    }
    .photo-accent-row .accent-photo {
      height: 240px;
      overflow: hidden;
    }
    .photo-accent-row .accent-photo img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      display: block;
      transition: transform 0.6s ease;
      will-change: transform;
    }
    .photo-accent-row .accent-photo:hover img { transform: scale(1.05); }

    /* ── Responsive ──────────────────────────────── */
    @media (max-width: 960px) {
      .about-split { grid-template-columns: 1fr; gap: 48px; }
      .about-split-photo { order: -1; }
      .about-split-photo img { height: 340px; }
      .content-block-inner { grid-template-columns: 1fr; gap: 32px; }
      .photo-accent-row { grid-template-columns: repeat(2, 1fr); }
      .photo-accent-row .accent-photo:last-child { display: none; }
    }
    @media (max-width: 600px) {
      .page-hero { padding-top: calc(var(--nav-height) + 36px); padding-bottom: 24px; }
      .page-hero h1 { font-size: clamp(4rem, 18vw, 6rem); }
      .about-intro-section { padding: 44px 0; }
      .content-block { padding: 44px 0; }
      .about-split-photo img { height: 260px; }
      .photo-accent-row { grid-template-columns: 1fr; }
      .photo-accent-row .accent-photo:not(:first-child) { display: none; }
      .photo-accent-row .accent-photo { height: 200px; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: services.html
   ════════════════════════════════════════════════ */
/* ── Services Page Specific ──────────────────── */

    .page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      position: relative;
      overflow: hidden;
    }
    .page-hero::before {
      content: 'SERVICES';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--font-display);
      font-size: clamp(7rem, 16vw, 20rem);
      color: rgba(255,255,255,0.03);
      letter-spacing: 0.05em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
    }
    .page-hero-inner {
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(5rem, 11vw, 11rem);
      line-height: 0.88;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .page-hero-sub {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      max-width: 560px;
      margin-top: 10px;
    }

    /* ── Intro strip ─────────────────────────────── */
    .services-intro {
      background: var(--dark);
      padding: 70px 0;
      border-bottom: 1px solid var(--border);
    }
    .services-intro-inner {
      display: grid;
      grid-template-columns: 1fr;
      max-width: 700px;
    }
    .services-intro-text h2 {
      font-family: var(--font-display);
      font-size: clamp(2.2rem, 4vw, 3.8rem);
      color: var(--cream);
      letter-spacing: 0.04em;
      line-height: 1;
      margin-bottom: 20px;
    }
    .services-intro-text h2 span { color: var(--gold); }
    .services-intro-text p {
      font-size: 0.95rem;
      color: var(--off-white);
      line-height: 1.85;
    }
    .services-intro-quote {
      border-left: 3px solid var(--gold);
      padding-left: 28px;
    }
    .services-intro-quote blockquote {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.35rem;
      color: var(--cream);
      line-height: 1.6;
    }
    .services-intro-quote cite {
      display: block;
      margin-top: 16px;
      font-size: 0.68rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--gold);
      font-style: normal;
    }

    /* ── Services sections ───────────────────────── */
    .services-block {
      padding: var(--section-pad) 0;
    }
    .services-block + .services-block {
      border-top: 1px solid var(--border);
    }
    .services-block:nth-child(odd) { background: var(--black); }
    .services-block:nth-child(even) { background: var(--dark); }

    .services-block-header {
      margin-bottom: 56px;
    }
    .services-block-header .eyebrow { margin-bottom: 10px; }
    .services-block-header h2 {
      font-family: var(--font-display);
      font-size: clamp(3rem, 6vw, 6rem);
      color: var(--cream);
      letter-spacing: 0.03em;
      line-height: 0.9;
    }
    .services-block-header p {
      font-size: 0.95rem;
      color: var(--off-white);
      line-height: 1.8;
      max-width: 600px;
      margin-top: 18px;
    }

    /* Haircut grid */
    .haircut-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1px;
      background: var(--border);
      border: 1px solid var(--border);
    }
    .haircut-item {
      background: var(--card);
      padding: 28px 24px;
      display: flex;
      align-items: flex-start;
      gap: 16px;
      transition: background-color 0.3s;
    }
    .haircut-item:hover { background-color: var(--card2); }
    .haircut-item:last-child { grid-column: 1 / -1; }
    .haircut-num {
      font-family: var(--font-display);
      font-size: 1.1rem;
      color: var(--gold);
      opacity: 0.5;
      line-height: 1;
      flex-shrink: 0;
      margin-top: 2px;
    }
    .haircut-name {
      font-family: var(--font-body);
      font-size: 0.88rem;
      font-weight: 400;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--cream);
      line-height: 1.4;
    }

    /* Hairstyle photo grid */
    .hairstyle-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 10px;
    }
    .hairstyle-card {
      position: relative;
      overflow: hidden;
      aspect-ratio: 3/4;
      background: var(--card);
    }
    .hairstyle-card img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      display: block;
      transition: transform 0.6s ease;
    }
    .hairstyle-card:hover img { transform: scale(1.06); }
    .hairstyle-card-label {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      padding: 32px 16px 14px;
      background: linear-gradient(to top, rgba(9,9,9,0.85) 0%, transparent 100%);
      font-family: var(--font-display);
      font-size: 1rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--cream);
    }

    /* Grooming list */
    .grooming-layout {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: start;
    }
    .grooming-list {
      display: flex;
      flex-direction: column;
    }
    .grooming-item {
      display: flex;
      align-items: center;
      gap: 20px;
      padding: 20px 0;
      border-bottom: 1px solid var(--border);
    }
    .grooming-item:first-child { border-top: 1px solid var(--border); }
    .grooming-item-num {
      font-family: var(--font-display);
      font-size: 0.85rem;
      color: var(--gold);
      opacity: 0.5;
      flex-shrink: 0;
      width: 28px;
    }
    .grooming-item-name {
      font-size: 0.92rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--cream);
    }

    /* Hot shave feature card */
    .shave-feature {
      background: var(--card2);
      border: 1px solid var(--border);
      border-left: 3px solid var(--gold);
      padding: 40px;
    }
    .shave-feature .eyebrow { margin-bottom: 14px; }
    .shave-feature h3 {
      font-family: var(--font-display);
      font-size: 2rem;
      letter-spacing: 0.06em;
      color: var(--cream);
      margin-bottom: 16px;
      line-height: 1;
    }
    .shave-feature p {
      font-size: 0.92rem;
      color: var(--off-white);
      line-height: 1.85;
      margin-bottom: 24px;
    }
    .shave-feature .btn-primary {
      display: inline-block;
    }

    /* ── Responsive ──────────────────────────────── */
    @media (max-width: 1100px) {
      .hairstyle-grid { grid-template-columns: repeat(3, 1fr); }
    }
    @media (max-width: 900px) {
      .services-intro-inner { grid-template-columns: 1fr; gap: 40px; }
      .haircut-grid { grid-template-columns: repeat(2, 1fr); }
      .grooming-layout { grid-template-columns: 1fr; gap: 48px; }
      .hairstyle-grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (max-width: 600px) {
      /* Tighten all vertical breathing room on mobile */
      .page-hero { padding-top: calc(var(--nav-height) + 36px); padding-bottom: 24px; }
      .page-hero h1 { font-size: clamp(4rem, 18vw, 6rem); }
      .services-intro { padding: 40px 0; }
      .services-intro-inner { gap: 28px; }
      .services-block { padding: 44px 0; }
      .services-block-header { margin-bottom: 32px; }
      .grooming-layout { gap: 32px; }
      .haircut-grid { grid-template-columns: 1fr; }
      .hairstyle-grid { grid-template-columns: repeat(2, 1fr); }
      .shave-feature { padding: 24px 20px; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: thank-you.html
   ════════════════════════════════════════════════ */
/* ── Thank You Page ──────────────────────────── */

    .thankyou-page {
      background: var(--black);
      min-height: 100vh;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      position: relative;
      overflow: hidden;
      padding: calc(var(--nav-height) + 48px) 24px 80px;
    }

    /* Ghost background word */
    .thankyou-page::before {
      content: 'SHARP';
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
      font-family: var(--font-display);
      font-size: clamp(16rem, 40vw, 46rem);
      color: rgba(255,255,255,0.025);
      letter-spacing: 0.06em;
      line-height: 1;
      pointer-events: none;
      white-space: nowrap;
      user-select: none;
    }

    .thankyou-inner {
      position: relative;
      z-index: 1;
      text-align: center;
      max-width: 640px;
      width: 100%;
      opacity: 0;
      transform: translateY(20px);
      animation: ty-rise 0.6s ease-out 0.1s forwards;
    }

    @keyframes ty-rise {
      to { opacity: 1; transform: translateY(0); }
    }

    /* Check mark */
    .ty-check {
      width: 56px;
      height: 56px;
      border: 2px solid var(--gold);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 32px;
      opacity: 0;
      transform: scale(0.7);
      animation: ty-check-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) 0.5s forwards;
    }

    @keyframes ty-check-in {
      to { opacity: 1; transform: scale(1); }
    }

    .ty-check svg {
      width: 22px;
      height: 22px;
      stroke: var(--gold);
      stroke-width: 2;
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    /* Checkmark draw animation */
    .ty-check svg path {
      stroke-dasharray: 30;
      stroke-dashoffset: 30;
      animation: ty-draw 0.4s ease-out 0.9s forwards;
    }

    @keyframes ty-draw {
      to { stroke-dashoffset: 0; }
    }

    .ty-eyebrow {
      font-size: 0.72rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 20px;
    }

    .ty-heading {
      font-family: var(--font-display);
      font-size: clamp(4rem, 10vw, 9rem);
      color: var(--cream);
      line-height: 0.88;
      letter-spacing: 0.02em;
      margin-bottom: 12px;
    }

    .ty-heading span { color: var(--gold); }

    .ty-rule {
      width: 40px;
      height: 2px;
      background: var(--gold);
      margin: 28px auto;
    }

    .ty-message {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.15rem;
      color: var(--off-white);
      line-height: 1.7;
      margin-bottom: 12px;
      max-width: 500px;
      margin-left: auto;
      margin-right: auto;
    }

    .ty-detail {
      font-size: 0.88rem;
      color: var(--gray);
      line-height: 1.7;
      margin-bottom: 48px;
    }

    /* Next steps */
    .ty-steps {
      display: flex;
      gap: 2px;
      justify-content: center;
      margin-bottom: 48px;
      text-align: left;
    }

    .ty-step {
      background: var(--dark);
      border: 1px solid var(--border);
      padding: 20px 22px;
      flex: 1;
      max-width: 180px;
    }

    .ty-step-num {
      font-family: var(--font-display);
      font-size: 2rem;
      color: rgba(201,165,90,0.25);
      line-height: 1;
      margin-bottom: 10px;
    }

    .ty-step-label {
      font-size: 0.68rem;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--gray);
      line-height: 1.5;
    }

    /* CTAs */
    .ty-links {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      justify-content: center;
    }

    /* ── Responsive ──────────────────────────────── */
    @media (max-width: 600px) {
      .thankyou-page { padding: calc(var(--nav-height) + 32px) 20px 60px; }
      .ty-steps { flex-direction: column; align-items: center; }
      .ty-step { max-width: 100%; width: 100%; }
      .ty-heading { font-size: clamp(3.5rem, 18vw, 5.5rem); }
    }

/* ════════════════════════════════════════════════
   PAGE: blog/category/did-you-know/index.html
   ════════════════════════════════════════════════ */
.page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      border-bottom: 1px solid var(--border);
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.5rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .filter-label {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 0.78rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 5px 14px;
      margin-top: 16px;
      align-self: flex-start;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .blog-grid-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .blog-grid-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 48px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 24px;
    }
    .blog-grid-header h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
    }
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .blog-card {
      background: var(--dark);
      display: flex;
      flex-direction: column;
      border: 1px solid var(--border);
      transition: border-color 0.3s;
    }
    .blog-card:hover { border-color: rgba(191,150,71,0.4); }
    .blog-card-image {
      height: 200px;
      background: var(--black);
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    .blog-card-image-icon { font-size: 3.5rem; opacity: 0.4; }
    .blog-card-image-gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.08) 0%, transparent 70%);
    }
    .blog-card-body {
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      flex: 1;
    }
    .post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date { font-size: 0.8rem; color: var(--gray); }
    .post-title {
      font-family: var(--font-display);
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: 0.02em;
    }
    .post-excerpt {
      font-family: var(--font-serif);
      font-size: 0.92rem;
      font-style: italic;
      color: var(--off-white);
      line-height: 1.7;
      flex: 1;
    }
    .read-more {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      align-self: flex-start;
      transition: border-color 0.3s;
      margin-top: 4px;
    }
    @media (max-width: 960px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .blog-grid-section { padding: 44px 0; }
      .blog-grid { grid-template-columns: 1fr; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: blog/category/barbers/index.html
   ════════════════════════════════════════════════ */
.page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      border-bottom: 1px solid var(--border);
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.5rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .filter-label {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 0.78rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 5px 14px;
      margin-top: 16px;
      align-self: flex-start;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .blog-grid-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .blog-grid-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 48px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 24px;
    }
    .blog-grid-header h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
    }
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .blog-card {
      background: var(--dark);
      display: flex;
      flex-direction: column;
      border: 1px solid var(--border);
      transition: border-color 0.3s;
    }
    .blog-card:hover { border-color: rgba(191,150,71,0.4); }
    .blog-card-image {
      height: 200px;
      background: var(--black);
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    .blog-card-image-icon { font-size: 3.5rem; opacity: 0.4; }
    .blog-card-image-gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.08) 0%, transparent 70%);
    }
    .blog-card-body {
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      flex: 1;
    }
    .post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date { font-size: 0.8rem; color: var(--gray); }
    .post-title {
      font-family: var(--font-display);
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: 0.02em;
    }
    .post-excerpt {
      font-family: var(--font-serif);
      font-size: 0.92rem;
      font-style: italic;
      color: var(--off-white);
      line-height: 1.7;
      flex: 1;
    }
    .read-more {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      align-self: flex-start;
      transition: border-color 0.3s;
      margin-top: 4px;
    }
    @media (max-width: 960px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .blog-grid-section { padding: 44px 0; }
      .blog-grid { grid-template-columns: 1fr; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: blog/category/all/index.html
   ════════════════════════════════════════════════ */
.page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      border-bottom: 1px solid var(--border);
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.5rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .filter-label {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 0.78rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 5px 14px;
      margin-top: 16px;
      align-self: flex-start;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .blog-grid-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .blog-grid-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 48px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 24px;
    }
    .blog-grid-header h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
    }
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .blog-card {
      background: var(--dark);
      display: flex;
      flex-direction: column;
      border: 1px solid var(--border);
      transition: border-color 0.3s;
    }
    .blog-card:hover { border-color: rgba(191,150,71,0.4); }
    .blog-card-image {
      height: 200px;
      background: var(--black);
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    .blog-card-image-icon { font-size: 3.5rem; opacity: 0.4; }
    .blog-card-image-gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.08) 0%, transparent 70%);
    }
    .blog-card-body {
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      flex: 1;
    }
    .post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date { font-size: 0.8rem; color: var(--gray); }
    .post-title {
      font-family: var(--font-display);
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: 0.02em;
    }
    .post-excerpt {
      font-family: var(--font-serif);
      font-size: 0.92rem;
      font-style: italic;
      color: var(--off-white);
      line-height: 1.7;
      flex: 1;
    }
    .read-more {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      align-self: flex-start;
      transition: border-color 0.3s;
      margin-top: 4px;
    }
    @media (max-width: 960px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .blog-grid-section { padding: 44px 0; }
      .blog-grid { grid-template-columns: 1fr; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: blog/category/community/index.html
   ════════════════════════════════════════════════ */
.page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      border-bottom: 1px solid var(--border);
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.5rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .filter-label {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 0.78rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 5px 14px;
      margin-top: 16px;
      align-self: flex-start;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .blog-grid-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .blog-grid-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 48px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 24px;
    }
    .blog-grid-header h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
    }
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .blog-card {
      background: var(--dark);
      display: flex;
      flex-direction: column;
      border: 1px solid var(--border);
      transition: border-color 0.3s;
    }
    .blog-card:hover { border-color: rgba(191,150,71,0.4); }
    .blog-card-image {
      height: 200px;
      background: var(--black);
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    .blog-card-image-icon { font-size: 3.5rem; opacity: 0.4; }
    .blog-card-image-gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.08) 0%, transparent 70%);
    }
    .blog-card-body {
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      flex: 1;
    }
    .post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date { font-size: 0.8rem; color: var(--gray); }
    .post-title {
      font-family: var(--font-display);
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: 0.02em;
    }
    .post-excerpt {
      font-family: var(--font-serif);
      font-size: 0.92rem;
      font-style: italic;
      color: var(--off-white);
      line-height: 1.7;
      flex: 1;
    }
    .read-more {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      align-self: flex-start;
      transition: border-color 0.3s;
      margin-top: 4px;
    }
    @media (max-width: 960px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .blog-grid-section { padding: 44px 0; }
      .blog-grid { grid-template-columns: 1fr; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: blog/archives/09-2024/index.html
   ════════════════════════════════════════════════ */
.page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      border-bottom: 1px solid var(--border);
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.5rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .filter-label {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 0.78rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 5px 14px;
      margin-top: 16px;
      align-self: flex-start;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .blog-grid-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .blog-grid-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 48px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 24px;
    }
    .blog-grid-header h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
    }
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .blog-card {
      background: var(--dark);
      display: flex;
      flex-direction: column;
      border: 1px solid var(--border);
      transition: border-color 0.3s;
    }
    .blog-card:hover { border-color: rgba(191,150,71,0.4); }
    .blog-card-image {
      height: 200px;
      background: var(--black);
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    .blog-card-image-icon { font-size: 3.5rem; opacity: 0.4; }
    .blog-card-image-gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.08) 0%, transparent 70%);
    }
    .blog-card-body {
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      flex: 1;
    }
    .post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date { font-size: 0.8rem; color: var(--gray); }
    .post-title {
      font-family: var(--font-display);
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: 0.02em;
    }
    .post-excerpt {
      font-family: var(--font-serif);
      font-size: 0.92rem;
      font-style: italic;
      color: var(--off-white);
      line-height: 1.7;
      flex: 1;
    }
    .read-more {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      align-self: flex-start;
      transition: border-color 0.3s;
      margin-top: 4px;
    }
    @media (max-width: 960px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .blog-grid-section { padding: 44px 0; }
      .blog-grid { grid-template-columns: 1fr; }
      .cta-banner { padding: 60px 0; }
    }

/* ════════════════════════════════════════════════
   PAGE: blog/archives/03-2018/index.html
   ════════════════════════════════════════════════ */
.page-hero {
      background: var(--black);
      padding: calc(var(--nav-height) + 70px) 0 60px;
      border-bottom: 1px solid var(--border);
    }
    .page-hero-inner { display: flex; flex-direction: column; gap: 14px; }
    .page-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(3.5rem, 8vw, 8rem);
      line-height: 0.9;
      color: var(--cream);
      letter-spacing: 0.02em;
    }
    .page-hero h1 span { color: var(--gold); }
    .filter-label {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 0.78rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 5px 14px;
      margin-top: 16px;
      align-self: flex-start;
    }
    .back-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gray);
      text-decoration: none;
      margin-bottom: 36px;
      transition: color 0.3s;
    }
    .back-link:hover { color: var(--gold); }
    .back-link::before { content: '←'; }
    .blog-grid-section {
      background: var(--black);
      padding: var(--section-pad) 0;
      border-bottom: 1px solid var(--border);
    }
    .blog-grid-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      margin-bottom: 48px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 24px;
    }
    .blog-grid-header h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3rem);
      color: var(--cream);
      letter-spacing: 0.03em;
    }
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .blog-card {
      background: var(--dark);
      display: flex;
      flex-direction: column;
      border: 1px solid var(--border);
      transition: border-color 0.3s;
    }
    .blog-card:hover { border-color: rgba(191,150,71,0.4); }
    .blog-card-image {
      height: 200px;
      background: var(--black);
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1px solid var(--border);
      position: relative;
      overflow: hidden;
    }
    .blog-card-image-icon { font-size: 3.5rem; opacity: 0.4; }
    .blog-card-image-gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(191,150,71,0.08) 0%, transparent 70%);
    }
    .blog-card-body {
      padding: 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
      flex: 1;
    }
    .post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
    .post-category {
      font-size: 0.72rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--gold);
      border: 1px solid rgba(191,150,71,0.35);
      padding: 4px 10px;
    }
    .post-date { font-size: 0.8rem; color: var(--gray); }
    .post-title {
      font-family: var(--font-display);
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: 0.02em;
    }
    .post-excerpt {
      font-family: var(--font-serif);
      font-size: 0.92rem;
      font-style: italic;
      color: var(--off-white);
      line-height: 1.7;
      flex: 1;
    }
    .read-more {
      font-size: 0.78rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      border-bottom: 1px solid rgba(191,150,71,0.3);
      padding-bottom: 2px;
      align-self: flex-start;
      transition: border-color 0.3s;
      margin-top: 4px;
    }
    @media (max-width: 960px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 600px) {
      .page-hero { padding: calc(var(--nav-height) + 36px) 0 40px; }
      .blog-grid-section { padding: 44px 0; }
      .blog-grid { grid-template-columns: 1fr; }
      .cta-banner { padding: 60px 0; }
    }
