/* ============================================================
   RICH CUTZ BARBERSHOP — styles
   Tortellini Amazing Design System structural tokens
   (spacing, radii, type curves, motion timing, weights)
   re-palletted to the Rich Cutz hallmark: Ink Navy · Bone · Royal Gold
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Bodoni+Moda:ital,opsz,wght@0,6..96,400..900;1,6..96,400..900&family=DM+Serif+Display:ital@0;1&family=Sacramento&family=Allura&display=swap');

:root {
  /* ---- Brand palette — DDR5-warmth pass ----
     Quieter, monastic, library-warm. Navy is preserved on the brand
     crest itself (hallmark — never recolored), but the page surfaces
     shift from cool-blue navy to a warmer carbon-deep with a hint of
     ink-blue underneath. Gold sits one notch more antique.
  */
  --ink:           #0c1322;   /* page bg — warm deep ink, less cool than v1 */
  --ink-2:         #07101d;   /* deepest — hero base, footer */
  --ink-3:         #040a14;   /* near-black warm — overlays */
  --ink-soft:      #161e30;   /* lifted surface */
  --carbon:        #0a0a0a;   /* pure warm carbon — for editorial sections (DDR5 sanctuary) */
  --carbon-2:      #050505;   /* deepest carbon */
  --carbon-soft:   #141311;   /* lifted carbon */

  --bone:          #ece3cb;   /* slightly warmer parchment — DDR5 sanctuary cream */
  --bone-2:        #ddd2b3;   /* darker bone */
  --bone-3:        #c9bd99;   /* tertiary bone (borders on cream) */

  --gold:          #c0985a;   /* antique gold — one notch quieter than v1 */
  --gold-hi:       #ddb87a;   /* hover */
  --gold-deep:     #9a7838;   /* pressed / on-bone display */

  --smoke:         #2a2f3a;
  --smoke-2:       #3a3f4b;

  /* ---- Tortellini structural tokens (unchanged) ---- */
  --font-sans:     'Inter', -apple-system, system-ui, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
  --font-display:  'Bodoni Moda', 'Bodoni 72', 'Didot', 'Playfair Display', Georgia, serif; /* Hagi-style high-contrast modern serif */
  --font-display-huge: 'DM Serif Display', 'Bodoni Moda', Didot, Georgia, serif; /* Giant Hagi POP-UP-style display */
  --font-script:   'Sacramento', 'Allura', 'Pinyon Script', 'Snell Roundhand', cursive; /* Hagi-style flowing signature */
  --font-mono:     ui-monospace, 'SF Mono', Menlo, monospace;
  --font-features: "cv01", "ss03";

  --weight-light:    300;
  --weight-regular:  400;
  --weight-medium:   510;   /* Linear/Tortellini signature */
  --weight-semibold: 590;

  /* Display scale — kept */
  --text-display-xl: 4.50rem;
  --text-display-lg: 4.00rem;
  --text-display:    3.00rem;
  --text-h1:         2.00rem;
  --text-h2:         1.50rem;
  --text-h3:         1.25rem;
  --text-body-lg:    1.125rem;
  --text-body-em:    1.0625rem;
  --text-body:       1.00rem;
  --text-small:      0.9375rem;
  --text-caption-lg: 0.875rem;
  --text-caption:    0.8125rem;
  --text-label:      0.75rem;
  --text-micro:      0.6875rem;

  /* Display compression — kept */
  --tracking-display-xl: -1.584px;
  --tracking-display-lg: -1.408px;
  --tracking-display:    -1.056px;
  --tracking-h1:         -0.704px;
  --tracking-h2:         -0.288px;
  --tracking-h3:         -0.24px;
  --tracking-body-lg:    -0.165px;
  --tracking-caption-lg: -0.182px;
  --tracking-caption:    -0.13px;

  --leading-tight:   1.00;
  --leading-snug:    1.13;
  --leading-heading: 1.33;
  --leading-body:    1.50;
  --leading-relaxed: 1.60;
  --leading-label:   1.40;

  --space-1: 1px;  --space-4: 4px;   --space-7: 7px;   --space-8: 8px;
  --space-11: 11px;--space-12: 12px; --space-16: 16px; --space-19: 19px;
  --space-20: 20px;--space-22: 22px; --space-24: 24px; --space-28: 28px;
  --space-32: 32px;--space-35: 35px; --space-48: 48px; --space-64: 64px;
  --space-80: 80px;

  --radius-micro: 2px;  --radius-sm: 4px;    --radius-md: 6px;
  --radius-card: 8px;   --radius-panel: 12px;--radius-lg: 22px;
  --radius-pill: 9999px;--radius-circle: 50%;

  --max-content-width: 1200px;
  --section-padding-y: var(--space-80);
  --section-padding-x: var(--space-24);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  .marquee__track, .crest-breathe { animation: none !important; }
  .hero__media { transform: none !important; }
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-feature-settings: var(--font-features);
  font-size: var(--text-body);
  font-weight: var(--weight-regular);
  line-height: var(--leading-body);
  color: var(--bone);
  background: var(--ink-2);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-variant-numeric: tabular-nums;  /* tabular nums everywhere by default */
}

img { display: block; max-width: 100%; }

/* Skip link */
.skip {
  position: absolute; top: -100px; left: 8px;
  background: var(--gold); color: var(--ink-2);
  padding: 10px 14px; border-radius: var(--radius-md);
  font-weight: var(--weight-medium); z-index: 1000;
}
.skip:focus { top: 8px; }

/* Focus rings — gold w/ 2px offset, per brief */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ---- Type utilities ---- */
.display-xl, .display-lg, .display, .display-italic {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: var(--leading-tight);
  color: var(--bone);
  font-optical-sizing: auto;
}
.display-xl   { font-size: clamp(2.75rem, 6.5vw, var(--text-display-xl));  letter-spacing: var(--tracking-display-xl); }
.display-lg   { font-size: clamp(2.5rem, 5.5vw, var(--text-display-lg));   letter-spacing: var(--tracking-display-lg); }
.display      { font-size: clamp(2rem, 4vw, var(--text-display));          letter-spacing: var(--tracking-display); }
.display-italic { font-style: italic; font-weight: 400; }

h1, h2, h3 { font-family: var(--font-display); margin: 0; font-optical-sizing: auto; }
h2 { font-size: var(--text-h1); letter-spacing: var(--tracking-h1); line-height: var(--leading-snug); font-weight: 600; }
h3 { font-size: var(--text-h2); letter-spacing: var(--tracking-h2); line-height: var(--leading-heading); font-weight: 600; }

/* Italic accent within display headings — Hagi treatment */
h1 em, h2 em, h3 em, .display em, .display-xl em, .display-lg em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold-hi);
}

p { margin: 0 0 var(--space-16) 0; }
.body-lg { font-size: var(--text-body-lg); line-height: var(--leading-relaxed); letter-spacing: var(--tracking-body-lg); }
.small   { font-size: var(--text-small); }

/* Eyebrow label — mono-style, gold, tracked out */
.eyebrow {
  font-family: var(--font-sans);
  font-size: var(--text-caption);
  font-weight: var(--weight-medium);
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: '';
  width: 22px; height: 1px; background: var(--gold);
}

/* Hairline rule — gold 1px */
.hairline {
  border: 0; border-top: 1px solid var(--gold);
  opacity: 0.45;
  margin: 0;
}
.hairline--smoke { border-top-color: var(--smoke); opacity: 1; }
.hairline--bone  { border-top-color: var(--bone-3); opacity: 1; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-feature-settings: var(--font-features);
  font-size: var(--text-caption-lg);
  font-weight: var(--weight-medium);
  letter-spacing: 0.2px;
  line-height: 1;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease, transform 180ms ease;
  white-space: nowrap;
  text-decoration: none;
  padding: 12px 18px;
  min-height: 44px;
}
.btn--primary {
  background: var(--gold);
  color: var(--ink-2);
  border-color: var(--gold);
}
.btn--primary:hover {
  background: var(--gold-hi);
  border-color: var(--gold-hi);
  color: var(--ink-2);
}
.btn--ghost {
  background: transparent;
  color: var(--bone);
  border-color: rgba(236,227,203,0.28);
}
.btn--ghost:hover {
  background: rgba(236,227,203,0.06);
  border-color: rgba(236,227,203,0.45);
  color: var(--bone);
}
.btn--ghost-dark {
  background: transparent;
  color: var(--ink);
  border-color: rgba(12,19,34,0.25);
}
.btn--ghost-dark:hover {
  background: rgba(12,19,34,0.06);
  border-color: rgba(12,19,34,0.45);
}
.btn--sm {
  padding: 9px 14px;
  font-size: var(--text-label);
  min-height: 36px;
}
.btn .arrow {
  width: 14px; height: 14px;
  transition: transform 180ms ease;
}
.btn:hover .arrow { transform: translateX(2px); }

/* ============================================================
   LAYOUT — container + sections
   ============================================================ */
.container {
  max-width: var(--max-content-width);
  margin: 0 auto;
  padding-left: var(--space-24);
  padding-right: var(--space-24);
}
.container--wide { max-width: 1320px; }

section {
  padding-top: var(--section-padding-y);
  padding-bottom: var(--section-padding-y);
  position: relative;
}
@media (max-width: 720px) {
  section { padding-top: var(--space-48); padding-bottom: var(--space-48); }
}

.section--dark  { background: var(--ink-2); color: var(--bone); }
.section--cream { background: var(--bone); color: var(--ink-2); }
.section--ink   { background: var(--ink); color: var(--bone); }

/* Paper-grain overlay on navy sections @ ~6% */
.grain {
  position: relative;
  isolation: isolate;
}
.grain::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  opacity: 0.06;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.92  0 0 0 0 0.85  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: screen;
  z-index: 0;
}
.grain > * { position: relative; z-index: 1; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-24);
  padding: 18px 24px;
  transition: padding 200ms ease, background 200ms ease, backdrop-filter 200ms ease, border-color 200ms ease;
  border-bottom: 1px solid transparent;
}
.nav.is-scrolled {
  padding: 10px 24px;
  background: rgba(7,16,29,0.78);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom-color: rgba(192,152,90,0.18);
}
.nav__brand {
  display: inline-flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--bone);
}
.nav__brand-mark { width: 36px; height: 36px; }
.nav__brand-text {
  font-family: var(--font-script);
  font-weight: 400;
  font-size: 32px;
  letter-spacing: 0;
  line-height: 1;
  color: var(--bone);
  white-space: nowrap;
  padding-top: 4px;
}
.nav__brand-text .amp { display: none; }
.nav__brand-text-cutz { color: var(--gold-hi); padding-left: 2px; }
.nav__links {
  display: flex; gap: 4px;
  align-items: center;
  list-style: none; margin: 0; padding: 0;
}
.nav__links a {
  display: inline-block;
  padding: 10px 14px;
  font-size: var(--text-caption-lg);
  font-weight: var(--weight-medium);
  color: rgba(236,227,203,0.78);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: color 150ms ease, background 150ms ease;
}
.nav__links a:hover { color: var(--bone); background: rgba(236,227,203,0.05); }
.nav__cta { display: inline-flex; align-items: center; gap: 12px; }
.nav__phone {
  font-size: var(--text-caption-lg);
  color: rgba(236,227,203,0.7);
  text-decoration: none;
  font-variant-numeric: tabular-nums;
}
.nav__phone:hover { color: var(--bone); }

.nav__burger {
  display: none;
  background: transparent;
  border: 1px solid rgba(236,227,203,0.2);
  border-radius: var(--radius-md);
  width: 44px; height: 44px;
  cursor: pointer;
  padding: 0;
  align-items: center; justify-content: center;
  color: var(--bone);
}

@media (max-width: 920px) {
  .nav__links, .nav__phone { display: none; }
  .nav__cta .btn--book-desktop { display: none; }
  .nav__burger { display: inline-flex; }
}

/* Mobile sheet */
.sheet {
  position: fixed; inset: 0;
  background: var(--ink-2);
  z-index: 60;
  display: none;
  flex-direction: column;
  padding: 24px;
}
.sheet.is-open { display: flex; }
.sheet__top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 32px; }
.sheet__close {
  width: 44px; height: 44px; border-radius: var(--radius-md);
  background: transparent; border: 1px solid rgba(236,227,203,0.2);
  color: var(--bone); cursor: pointer;
}
.sheet__links { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.sheet__links a {
  display: block;
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 500;
  color: var(--bone);
  padding: 14px 0;
  border-bottom: 1px solid rgba(236,227,203,0.08);
  text-decoration: none;
}
.sheet__links a:hover { color: var(--gold); }
.sheet__footer { margin-top: auto; display: flex; flex-direction: column; gap: 12px; }

/* Mobile sticky bottom CTA bar */
.mobile-cta {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 40;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: rgba(7,16,29,0.92);
  backdrop-filter: saturate(140%) blur(10px);
  border-top: 1px solid rgba(192,152,90,0.2);
}
.mobile-cta .btn { width: 100%; justify-content: center; }
@media (max-width: 720px) {
  .mobile-cta { display: block; }
  body { padding-bottom: 76px; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: min(880px, 100vh);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--ink-3);
  isolation: isolate;
}
.hero__media {
  position: absolute; inset: -8% -2% -2% -2%;
  z-index: 0;
  transition: transform 0.05s linear;
  /* Placeholder photographic background — warm, grainy, navy + gold light.
     CLIENT TO SUPPLY: full-bleed hero photo (clipper / cape / chair). */
  background:
    radial-gradient(ellipse 60% 50% at 70% 30%, rgba(192,152,90,0.32), transparent 60%),
    radial-gradient(ellipse 80% 70% at 30% 80%, rgba(20,30,50,0.65), transparent 70%),
    linear-gradient(135deg, #07101d 0%, #0c1322 45%, #161e30 100%);
}
.hero__media::after {
  content: '';
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='320' height='320'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.85  0 0 0 0 0.55  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23g)'/></svg>");
  opacity: 0.18;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.hero__placeholder-tag {
  position: absolute; bottom: 24px; right: 24px;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1px;
  color: rgba(236,227,203,0.4);
  background: rgba(4,10,20,0.55);
  border: 1px solid rgba(236,227,203,0.12);
  padding: 6px 10px; border-radius: var(--radius-sm);
  z-index: 3;
  text-transform: uppercase;
  pointer-events: none;
}
@media (max-width: 720px) { .hero__placeholder-tag { display: none; } }
.hero__scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(7,16,29,0.0) 30%, rgba(4,10,20,0.78) 100%),
    linear-gradient(90deg, rgba(4,10,20,0.62) 0%, rgba(4,10,20,0.0) 55%);
  z-index: 1;
}
.hero__crest {
  position: absolute;
  top: 88px; right: 56px;
  width: 220px; height: 220px;
  opacity: 0.16;
  z-index: 2;
  animation: crestBreathe 7s ease-in-out infinite;
}
@keyframes crestBreathe {
  0%, 100% { transform: scale(1.000); }
  50%      { transform: scale(1.015); }
}
@media (max-width: 720px) {
  .hero__crest { width: 140px; height: 140px; top: 100px; right: 16px; opacity: 0.12; }
}

.hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 0 var(--space-24) var(--space-64);
  max-width: var(--max-content-width);
  margin: 0 auto;
}
.hero h1 {
  font-family: var(--font-display);
  font-size: clamp(2.75rem, 7.4vw, 6rem);
  font-weight: 600;
  letter-spacing: -1.6px;
  line-height: 0.96;
  color: var(--bone);
  margin: 0;
  max-width: 18ch;
  font-optical-sizing: auto;
}
/* New hero structure: script wordmark over editorial tagline */
.hero__h1 {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 1.4vw, 18px);
  margin: 0;
  max-width: 20ch;
}
.hero__wordmark {
  font-family: 'Sacramento', 'Allura', 'Snell Roundhand', cursive;
  font-weight: 400;
  font-size: clamp(5.5rem, 13vw, 10.5rem);
  line-height: 0.85;
  letter-spacing: -0.005em;
  color: var(--gold-hi);
  text-shadow: 0 1px 0 rgba(0,0,0,0.35), 0 8px 24px rgba(192,152,90,0.18);
  transform: translateX(-0.02em);
}
.hero__tagline {
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 3.4vw, 2.8rem);
  font-weight: 500;
  letter-spacing: -0.6px;
  line-height: 1.05;
  color: var(--bone);
  font-optical-sizing: auto;
  max-width: 16ch;
}
.hero__tagline em {
  color: var(--gold-hi);
  font-weight: 400;
  font-style: italic;
  padding-right: 4px;
}
@media (max-width: 720px) {
  .hero__h1 { max-width: 100%; }
  .hero__wordmark { font-size: clamp(4.5rem, 22vw, 7rem); }
  .hero__tagline { font-size: clamp(1.3rem, 5.6vw, 1.8rem); max-width: 18ch; }
}
.hero h1 em { color: var(--gold-hi); font-weight: 400; font-style: italic; padding-right: 6px; }
.hero__dash {
  color: var(--gold);
  font-style: normal;
  font-weight: 300;
  padding: 0 2px;
  letter-spacing: -0.04em;
}
.hero__line2 { white-space: nowrap; }
@media (max-width: 600px) { .hero__line2 { white-space: normal; } }
.hero h1 .gold-period { color: var(--gold); }
.hero__sub {
  margin-top: 22px;
  font-size: var(--text-body-lg);
  line-height: var(--leading-relaxed);
  color: rgba(236,227,203,0.82);
  max-width: 52ch;
}
.hero__actions {
  margin-top: 36px;
  display: flex; gap: 12px; flex-wrap: wrap;
  align-items: center;
}
.hero__powered {
  margin-top: 16px;
  font-size: var(--text-caption);
  color: rgba(236,227,203,0.5);
  font-family: var(--font-mono);
  letter-spacing: 0.3px;
}
.hero__trust {
  margin-top: 56px;
  padding-top: 22px;
  border-top: 1px solid rgba(192,152,90,0.28);
  display: flex; align-items: center;
  gap: 0;
  flex-wrap: wrap;
}
.hero__trust > * {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: var(--text-caption-lg);
  color: rgba(236,227,203,0.7);
  padding: 0 22px;
  border-right: 1px solid rgba(236,227,203,0.14);
}
.hero__trust > *:first-child { padding-left: 0; }
.hero__trust > *:last-child  { border-right: 0; }
.hero__trust svg { color: var(--gold); flex: none; }
@media (max-width: 720px) {
  .hero__trust { gap: 12px; }
  .hero__trust > * { padding: 0; border-right: 0; }
}

/* ============================================================
   MARQUEE DIVIDER
   ============================================================ */
.marquee {
  background: var(--ink);
  overflow: hidden;
  border-top: 1px solid rgba(192,152,90,0.22);
  border-bottom: 1px solid rgba(192,152,90,0.22);
  position: relative;
}
.marquee__track {
  display: flex;
  gap: 56px;
  align-items: center;
  padding: 22px 0;
  width: max-content;
  animation: marquee 48s linear infinite;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.5rem, 3.5vw, 2.25rem);
  color: rgba(236,227,203,0.86);
  white-space: nowrap;
}
.marquee__track span { display: inline-flex; align-items: center; gap: 56px; }
.marquee__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold);
  flex: none;
}
@keyframes marquee {
  from { transform: translate3d(0,0,0); }
  to   { transform: translate3d(-50%,0,0); }
}

/* ============================================================
   SERVICES
   ============================================================ */
.services { background: var(--bone); color: var(--ink-2); position: relative; overflow: hidden; }
.services .giant-side { color: transparent; -webkit-text-stroke: 1px rgba(154,120,56,0.25); }
.services .container { max-width: 1080px; }
.services__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 32px; margin-bottom: 56px;
  flex-wrap: wrap;
}
.services__head h2 {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5vw, 4rem);
  font-weight: 600;
  letter-spacing: -1.2px;
  line-height: 1;
  color: var(--ink-2);
  max-width: 14ch;
}
.services__head .eyebrow { color: var(--gold-deep); }
.services__head .eyebrow::before { background: var(--gold-deep); }
.services__head p {
  max-width: 38ch;
  color: rgba(12,19,34,0.7);
  font-size: var(--text-body-lg);
  line-height: var(--leading-relaxed);
}

.svc-group { margin-bottom: 48px; }
.svc-group__label {
  display: flex; align-items: center; gap: 16px;
  font-family: var(--font-sans);
  font-size: var(--text-caption-lg);
  font-weight: var(--weight-medium);
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 20px;
}
.svc-group__label::after {
  content: ''; flex: 1; height: 1px; background: var(--bone-3);
}

.svc-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid var(--bone-3);
  text-decoration: none;
  color: inherit;
  transition: padding 200ms ease, background 200ms ease;
  position: relative;
}
.svc-row:last-child { border-bottom: 0; }
.svc-row:hover {
  padding-left: 12px;
  background: linear-gradient(90deg, rgba(192,152,90,0.08), transparent 60%);
}
.svc-row__name {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  font-weight: 500;
  letter-spacing: -0.4px;
  line-height: 1.15;
  color: var(--ink-2);
  display: flex;
  align-items: baseline;
  gap: 14px;
  flex-wrap: wrap;
}
.svc-row__name .leader {
  flex: 1;
  height: 1px;
  position: relative;
  align-self: center;
  transform: translateY(2px);
  min-width: 40px;
  background-image: radial-gradient(circle, var(--gold) 1px, transparent 1.4px);
  background-size: 7px 2px;
  background-repeat: repeat-x;
  background-position: 0 center;
  opacity: 0.7;
}
.svc-row__desc {
  font-family: var(--font-sans);
  font-size: var(--text-small);
  font-weight: var(--weight-regular);
  color: rgba(12,19,34,0.62);
  margin-top: 6px;
  line-height: var(--leading-relaxed);
  max-width: 56ch;
}
.svc-row__meta {
  font-family: var(--font-sans);
  font-feature-settings: var(--font-features), "tnum";
  font-variant-numeric: tabular-nums;
  font-size: var(--text-body-em);
  font-weight: var(--weight-medium);
  color: var(--ink-2);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.svc-row__meta .sep { color: var(--gold); opacity: 0.7; }
.svc-row__arrow {
  position: absolute;
  right: -2px; top: 50%;
  width: 22px; height: 22px;
  transform: translateY(-50%) translateX(8px);
  opacity: 0;
  color: var(--gold-deep);
  transition: opacity 180ms ease, transform 180ms ease;
}
.svc-row:hover .svc-row__arrow {
  opacity: 1; transform: translateY(-50%) translateX(0);
}

/* Featured row */
.svc-row--featured {
  background: var(--ink-2);
  color: var(--bone);
  margin: 18px -24px;
  padding: 32px 24px;
  border-radius: var(--radius-panel);
  border-top: 1px solid rgba(192,152,90,0.55);
  border-bottom: 1px solid rgba(192,152,90,0.55);
  position: relative;
}
.svc-row--featured:hover {
  background: var(--ink);
  padding-left: 36px;
}
.svc-row--featured .svc-row__name { color: var(--bone); font-size: clamp(1.75rem, 3vw, 2.5rem); font-weight: 500; }
.svc-row--featured .svc-row__meta { color: var(--bone); }
.svc-row--featured .svc-row__desc { color: rgba(236,227,203,0.7); max-width: 54ch; }
.svc-row--featured .leader {
  background-image: radial-gradient(circle, var(--gold-hi) 1px, transparent 1.4px);
  opacity: 0.85;
}
.svc-row--featured .svc-tag {
  position: absolute;
  top: -10px; left: 24px;
  background: var(--gold);
  color: var(--ink-2);
  font-family: var(--font-sans);
  font-size: var(--text-label);
  font-weight: var(--weight-semibold);
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
}

/* Pull quote between groups */
.pullquote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.5rem, 3.6vw, 2.5rem);
  line-height: 1.2;
  letter-spacing: -0.4px;
  color: var(--gold-deep);
  max-width: 22ch;
  margin: 48px auto;
  text-align: center;
  position: relative;
}
.pullquote::before, .pullquote::after {
  content: '';
  display: block;
  margin: 0 auto 22px;
  width: 36px; height: 1px;
  background: var(--gold);
}
.pullquote::after { margin: 22px auto 0; }

/* ============================================================
   ABOUT
   ============================================================ */
.about { background: var(--ink); color: var(--bone); position: relative; overflow: hidden; }
.about .signature { display: inline-block; margin: 10px 0 8px; }
.about__grid {
  display: grid;
  grid-template-columns: 5fr 6fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 920px) {
  .about__grid { grid-template-columns: 1fr; gap: 32px; }
}
.about__portrait {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-panel);
  overflow: hidden;
  background: var(--ink-3);
  border: 1px solid rgba(192,152,90,0.25);
}
.about__portrait img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 28%;
  display: block;
  transition: transform 1200ms cubic-bezier(.2,.8,.2,1);
}
.about__portrait:hover img {
  transform: scale(1.03);
}
/* Subtle warm grade — film-grain feel without destroying skin tones */
.about__portrait::after {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 30%, transparent 40%, rgba(4,10,20,0.35) 100%),
    linear-gradient(180deg, rgba(192,152,90,0.06) 0%, transparent 30%, rgba(4,10,20,0.18) 100%);
  pointer-events: none;
  mix-blend-mode: multiply;
}
.about__portrait::before {
  content: '';
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='1.1' numOctaves='1' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.78  0 0 0 0 0.64  0 0 0 0 0.36  0 0 0 0.4 0'/></filter><rect width='100%' height='100%' filter='url(%23g)'/></svg>");
  opacity: 0.18;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 1;
}

.about__body { padding-top: 8px; }
.about__body h2 {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
  font-weight: 600;
  letter-spacing: -1px;
  line-height: 1.04;
  color: var(--bone);
  margin: 22px 0 0;
  max-width: 18ch;
}
.about__body .pulled {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.5rem, 2.8vw, 2rem);
  color: var(--gold-hi);
  font-weight: 400;
  margin: 28px 0 18px;
  padding-left: 18px;
  border-left: 2px solid var(--gold);
  line-height: 1.25;
  max-width: 28ch;
}
.about__body p {
  color: rgba(236,227,203,0.78);
  font-size: var(--text-body-lg);
  line-height: var(--leading-relaxed);
  max-width: 60ch;
}
.about__placeholder {
  font-family: var(--font-mono);
  color: rgba(236,227,203,0.45);
  font-size: 12px;
  letter-spacing: 0.4px;
  border: 1px dashed rgba(236,227,203,0.2);
  padding: 14px 16px;
  border-radius: var(--radius-card);
  background: rgba(236,227,203,0.02);
  margin-bottom: 16px;
}
.about__creds {
  display: flex; gap: 0;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid rgba(192,152,90,0.24);
  flex-wrap: wrap;
}
.about__creds dt {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: rgba(236,227,203,0.45);
  margin-bottom: 6px;
}
.about__creds dd {
  font-family: var(--font-display);
  font-size: var(--text-h2);
  font-weight: 500;
  color: var(--bone);
  margin: 0;
}
.about__cred {
  padding: 0 28px;
  border-right: 1px solid rgba(236,227,203,0.12);
}
.about__cred:first-child { padding-left: 0; }
.about__cred:last-child  { border-right: 0; }
@media (max-width: 600px) {
  .about__cred { padding: 0; border-right: 0; flex-basis: 50%; margin-bottom: 16px; }
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery { background: var(--bone); color: var(--ink-2); }
.gallery__head { margin-bottom: 40px; }
.gallery__head h2 {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
  font-weight: 600;
  letter-spacing: -1px;
  line-height: 1.04;
  color: var(--ink-2);
  margin: 14px 0 0;
}
.gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.gallery__cell {
  border-radius: var(--radius-card);
  overflow: hidden;
  position: relative;
  background: var(--ink);
  cursor: zoom-in;
  transition: transform 320ms cubic-bezier(.2,.8,.2,1), box-shadow 320ms ease;
  border: 1px solid rgba(12,19,34,0.08);
  padding: 0;
  font-family: inherit;
  aspect-ratio: 1 / 1;          /* every cell is a perfect square */
}
.gallery__cell:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 50px -22px rgba(12,19,34,0.5);
}
.gallery__cell img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 700ms cubic-bezier(.2,.8,.2,1), filter 320ms ease;
  filter: saturate(0.92) contrast(1.04);
}
.gallery__cell:hover img {
  transform: scale(1.05);
  filter: saturate(1) contrast(1.06);
}

/* Per-cell focal points — push subject into frame after object-fit cover crop */
.gallery__cell--1 img { object-position: 50% 42%; }  /* LV V-design — big hero */
.gallery__cell--2 img { object-position: 50% 32%; }  /* Versace gold cape */
.gallery__cell--3 img { object-position: 50% 38%; }  /* Bald fade + beard */
.gallery__cell--4 img { object-position: 50% 38%; }  /* Pompadour */
.gallery__cell--5 img { object-position: 50% 50%; }  /* 360 waves */
.gallery__cell--6 img { object-position: 50% 42%; }  /* Smile */

/* Subtle warm grade overlay — Hagi cinematic feel */
.gallery__cell::after {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 30%, transparent 50%, rgba(4,10,20,0.18) 100%),
    linear-gradient(180deg, transparent 60%, rgba(4,10,20,0.32) 100%);
  pointer-events: none;
  mix-blend-mode: multiply;
  opacity: 0.55;
  transition: opacity 320ms ease;
  z-index: 2;
}
.gallery__cell:hover::after { opacity: 0.25; }

/* Film grain on top */
.gallery__cell::before {
  content: '';
  position: absolute; inset: 0;
  z-index: 3;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='1.0' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.85  0 0 0 0 0.55  0 0 0 0.3 0'/></filter><rect width='100%' height='100%' filter='url(%23g)'/></svg>");
  opacity: 0.14;
  mix-blend-mode: overlay;
  pointer-events: none;
}

/* Layout: one big square hero (2×2) + 5 matching tiles (1×1).
   3-col × 3-row mosaic. Every cell is the same aspect ratio. */
.gallery__cell--1 { grid-column: span 2; grid-row: span 2; }
.gallery__cell--2 { grid-column: span 1; grid-row: span 1; }
.gallery__cell--3 { grid-column: span 1; grid-row: span 1; }
.gallery__cell--4 { grid-column: span 1; grid-row: span 1; }
.gallery__cell--5 { grid-column: span 1; grid-row: span 1; }
.gallery__cell--6 { grid-column: span 1; grid-row: span 1; }

@media (max-width: 720px) {
  .gallery__grid { grid-template-columns: repeat(2, 1fr); }
  .gallery__cell--1 { grid-column: span 2; grid-row: span 2; }
  .gallery__cell--2,
  .gallery__cell--3,
  .gallery__cell--4,
  .gallery__cell--5,
  .gallery__cell--6 { grid-column: span 1; grid-row: span 1; }
}

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 80;
  background: rgba(4,10,20,0.94);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.lightbox.is-open { display: flex; }
.lightbox__inner {
  max-width: 1100px; width: 100%;
  aspect-ratio: 3 / 2;
  border-radius: var(--radius-panel);
  position: relative;
  border: 1px solid rgba(236,227,203,0.18);
  overflow: hidden;
}
.lightbox__close {
  position: absolute; top: 16px; right: 16px;
  z-index: 1;
  width: 44px; height: 44px; border-radius: var(--radius-md);
  background: rgba(7,16,29,0.7);
  border: 1px solid rgba(236,227,203,0.2);
  color: var(--bone); cursor: pointer;
}

/* ============================================================
   HOURS + VISIT
   ============================================================ */
.visit { background: var(--ink-2); color: var(--bone); }
.visit__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: flex-start;
}
@media (max-width: 920px) {
  .visit__grid { grid-template-columns: 1fr; gap: 32px; }
}
.visit__head h2 {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
  font-weight: 600;
  letter-spacing: -1px;
  line-height: 1.04;
  color: var(--bone);
  margin: 14px 0 0;
}

.hours {
  margin-top: 16px;
  border-top: 1px solid rgba(236,227,203,0.1);
}
.hours__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  border-bottom: 1px solid rgba(236,227,203,0.08);
  font-size: var(--text-body-em);
}
.hours__day {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.25rem;
  color: var(--bone);
  letter-spacing: -0.2px;
}
.hours__time {
  font-family: var(--font-sans);
  font-feature-settings: var(--font-features), "tnum";
  font-variant-numeric: tabular-nums;
  color: rgba(236,227,203,0.78);
  font-size: var(--text-body);
}
.hours__row--today {
  position: relative;
  padding-left: 16px;
  background: linear-gradient(90deg, rgba(192,152,90,0.10), transparent 70%);
  border-radius: var(--radius-sm);
  margin: 0 -16px;
  padding-right: 16px;
}
.hours__row--today::before {
  content: '';
  position: absolute; left: 0; top: 50%;
  transform: translateY(-50%);
  width: 3px; height: 60%;
  background: var(--gold);
  border-radius: 2px;
}
.hours__row--today .hours__day { color: var(--gold-hi); }
.hours__row--today .hours__time { color: var(--gold-hi); }
.hours__row--today .hours__badge {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--ink-2);
  background: var(--gold);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  margin-left: 10px;
}

.visit-card {
  background: rgba(236,227,203,0.04);
  border: 1px solid rgba(192,152,90,0.32);
  border-radius: var(--radius-panel);
  padding: 32px;
}
.visit-card__name {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--bone);
  letter-spacing: -0.4px;
  margin-bottom: 6px;
}
.visit-card__row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 0;
  border-top: 1px solid rgba(236,227,203,0.08);
}
.visit-card__row:first-of-type { border-top: 0; padding-top: 0; }
.visit-card__row svg {
  width: 18px; height: 18px;
  color: var(--gold);
  flex: none;
  margin-top: 2px;
}
.visit-card__row a, .visit-card__row span {
  color: rgba(236,227,203,0.82);
  text-decoration: none;
  font-size: var(--text-body);
  font-feature-settings: var(--font-features), "tnum";
}
.visit-card__row a:hover { color: var(--gold-hi); }
.visit-card__row .label {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1.2px;
  text-transform: uppercase;
  color: rgba(236,227,203,0.5);
  display: block;
  margin-bottom: 2px;
}

.visit-card__map {
  display: block;
  width: 100%;
  margin-top: 22px;
  border-radius: var(--radius-card);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  position: relative;
  background: var(--ink);
  border: 1px solid rgba(192,152,90,0.2);
}
.visit-card__map iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.visit-card__map-link {
  position: absolute;
  bottom: 12px; left: 12px;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--bone);
  background: rgba(4,10,20,0.82);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(192,152,90,0.4);
  padding: 7px 11px;
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease;
}
.visit-card__map-link:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--ink-2);
}
.visit-card__map-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(0deg, rgba(236,227,203,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(236,227,203,0.05) 1px, transparent 1px);
  background-size: 36px 36px;
}
.visit-card__map-pin {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -100%);
  color: var(--gold);
}
.visit-card__map-pulse {
  position: absolute;
  left: 50%; top: 50%;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--gold);
  opacity: 0.3;
  transform: translate(-50%, -50%);
  animation: mapPulse 2.6s ease-out infinite;
}
@keyframes mapPulse {
  0%   { width: 8px; height: 8px; opacity: 0.55; }
  100% { width: 80px; height: 80px; opacity: 0; }
}
.visit-card__map-label {
  position: absolute;
  bottom: 12px; left: 12px;
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(236,227,203,0.65);
  background: rgba(4,10,20,0.65);
  border: 1px solid rgba(236,227,203,0.15);
  padding: 5px 9px; border-radius: var(--radius-sm);
}

.visit__cta {
  margin-top: 48px;
  display: flex; gap: 16px; flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  padding: 28px 32px;
  background: linear-gradient(90deg, rgba(192,152,90,0.12), rgba(192,152,90,0.02));
  border: 1px solid rgba(192,152,90,0.3);
  border-radius: var(--radius-panel);
}
.visit__cta-text {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.2vw, 1.75rem);
  color: var(--bone);
  font-weight: 600;
  letter-spacing: -0.4px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: var(--ink-3);
  color: rgba(236,227,203,0.7);
  padding: 88px var(--space-24) 56px;
  text-align: center;
  border-top: 1px solid rgba(192,152,90,0.2);
}
.footer__crest {
  width: 140px; height: 140px;
  margin: 0 auto 28px;
  opacity: 0.92;
}
.footer__name {
  font-family: var(--font-script);
  font-size: clamp(3rem, 6.5vw, 5rem);
  font-weight: 400;
  letter-spacing: 0;
  color: var(--bone);
  margin: 0 0 16px;
  line-height: 1;
}
.footer__name-cutz { color: var(--gold-hi); }
.footer__contact {
  font-size: var(--text-body);
  margin-bottom: 6px;
  font-feature-settings: var(--font-features), "tnum";
}
.footer__contact a { color: rgba(236,227,203,0.78); text-decoration: none; }
.footer__contact a:hover { color: var(--gold-hi); }
.footer__hours {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  letter-spacing: 0.4px;
  color: var(--gold);
  margin-top: 18px;
  text-transform: uppercase;
}
.footer__ig {
  margin-top: 20px;
}
.footer__ig a {
  display: inline-flex; align-items: center; gap: 8px;
  color: rgba(236,227,203,0.7);
  font-size: var(--text-caption-lg);
  border: 1px solid rgba(236,227,203,0.2);
  padding: 8px 14px;
  border-radius: var(--radius-pill);
  text-decoration: none;
}
.footer__ig a:hover { color: var(--bone); border-color: rgba(192,152,90,0.5); }
.footer__rule {
  border: 0;
  border-top: 1px solid rgba(192,152,90,0.2);
  margin: 40px auto;
  max-width: 320px;
}
.footer__legal {
  font-size: var(--text-caption);
  color: rgba(236,227,203,0.45);
}
.footer__legal-line { margin: 4px 0; }
.footer__cta { margin-top: 32px; display: inline-flex; }

/* ============================================================
   FLOURISH ORNAMENTS
   ============================================================ */
.flourish {
  display: flex; align-items: center; justify-content: center;
  gap: 16px;
  color: var(--gold);
  margin: 56px 0 32px;
  opacity: 0.7;
}
.flourish__line { width: 80px; height: 1px; background: currentColor; }
.flourish svg { width: 24px; height: 24px; }

/* ============================================================
   SHOP / GOODS
   ============================================================ */
.shop {
  background: var(--ink-2);
  color: var(--bone);
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(192,152,90,0.18);
}
.shop__grid {
  display: grid;
  grid-template-columns: 5fr 6fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 920px) {
  .shop__grid { grid-template-columns: 1fr; gap: 32px; }
}
.shop__copy h2 {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
  font-weight: 600;
  letter-spacing: -1px;
  line-height: 1.04;
  color: var(--bone);
  margin: 14px 0 18px;
  max-width: 14ch;
}
.shop__copy p {
  color: rgba(236,227,203,0.72);
  font-size: var(--text-body-lg);
  line-height: var(--leading-relaxed);
  max-width: 48ch;
}
.shop__signup {
  display: flex;
  gap: 8px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.shop__email {
  flex: 1;
  min-width: 240px;
  background: rgba(236,227,203,0.05);
  border: 1px solid rgba(236,227,203,0.18);
  color: var(--bone);
  padding: 14px 16px;
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
}
.shop__email::placeholder { color: rgba(236,227,203,0.4); }
.shop__email:focus {
  border-color: var(--gold);
  outline: none;
}
.shop__legal {
  display: block;
  margin-top: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.3px;
  color: rgba(236,227,203,0.4);
}

.shop__lookbook {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 14px;
  aspect-ratio: 1 / 1;
}
.shop__tile {
  position: relative;
  border-radius: var(--radius-card);
  overflow: hidden;
  border: 1px solid rgba(192,152,90,0.15);
  transition: transform 320ms cubic-bezier(.2,.8,.2,1);
}
.shop__tile:hover { transform: translateY(-4px); }
.shop__tile::after {
  content: '';
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='1.0' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.9  0 0 0 0 0.78  0 0 0 0 0.5  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23g)'/></svg>");
  opacity: 0.2; mix-blend-mode: overlay; pointer-events: none;
}
.shop__tile-tag {
  position: absolute;
  bottom: 10px; left: 10px;
  font-family: var(--font-mono);
  font-size: 9.5px; letter-spacing: 0.9px;
  color: rgba(236,227,203,0.72);
  background: rgba(4,10,20,0.6);
  border: 1px solid rgba(236,227,203,0.18);
  padding: 4px 8px; border-radius: var(--radius-sm);
  text-transform: uppercase;
}
.shop__tile--1 { background: radial-gradient(ellipse 70% 70% at 30% 40%, rgba(192,152,90,0.45), transparent 65%), linear-gradient(160deg, #1a1108, #050505); }
.shop__tile--2 { background: radial-gradient(ellipse 65% 55% at 60% 50%, rgba(154,120,56,0.4), transparent 65%), linear-gradient(135deg, #0c1322, #040a14); }
.shop__tile--3 { background: radial-gradient(ellipse 55% 70% at 50% 35%, rgba(236,227,203,0.16), transparent 60%), linear-gradient(160deg, #161e30, #07101d); }
.shop__tile--4 { background: radial-gradient(ellipse 70% 50% at 70% 60%, rgba(221,184,122,0.3), transparent 65%), linear-gradient(200deg, #0a0a0a, #050505); }

/* ============================================================
   GIANT SIDEWAYS TYPE — Hagi POP-UP STORE move
   Uses writing-mode for reliable orientation across browsers.
   ============================================================ */
.giant-side {
  position: absolute;
  top: 50%;
  font-family: var(--font-display);
  font-weight: 500;
  font-style: normal;
  font-optical-sizing: auto;
  font-size: clamp(7rem, 22vw, 20rem);
  line-height: 0.82;
  letter-spacing: -0.03em;
  color: var(--bone);
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
.giant-side--right {
  right: -0.05em;
  transform: translateY(-50%);
}
.giant-side--left {
  left: -0.05em;
  transform: translateY(-50%) rotate(180deg);
}
.giant-side--ghost { color: transparent; -webkit-text-stroke: 1px rgba(236,227,203,0.22); }
.giant-side--gold  { color: var(--gold); opacity: 0.18; }
@media (max-width: 720px) {
  .giant-side { display: none; }  /* too crowded on mobile */
}

/* Inline giant marker that sits above a heading (Hagi treatment) */
.bigmark {
  font-family: var(--font-display-huge);
  font-weight: 400;
  font-size: clamp(5rem, 14vw, 14rem);
  line-height: 0.82;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: var(--bone);
  margin: 0;
}
.bigmark em { font-style: italic; color: var(--gold-hi); font-weight: 400; }
.bigmark--ghost { color: transparent; -webkit-text-stroke: 1px rgba(236,227,203,0.28); }

/* ============================================================
   SCRIPT SIGNATURE — RichKelz personal mark
   ============================================================ */
.signature {
  font-family: var(--font-script);
  font-weight: 400;
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: 1;
  color: var(--gold-hi);
  display: inline-block;
  transform: rotate(-2deg);
}
.signature--sm {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
}

/* ============================================================
   GSAP REVEAL HOOKS — JS sets initial state when ScrollTrigger
   is available. CSS no longer pre-hides — content stays visible
   if JS is disabled, fails, or runs late.
   ============================================================ */
[data-anim] { will-change: transform, opacity; }

/* Magnetic CTA — small affordance via CSS, GSAP layers on top */
.btn--magnetic { transition: transform 280ms cubic-bezier(0.2, 0.8, 0.2, 1), background 180ms ease, color 180ms ease, border-color 180ms ease; }

/* Cursor (subtle dot) — fully optional, off on touch */
.cursor {
  position: fixed;
  top: 0; left: 0;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--gold);
  pointer-events: none;
  z-index: 90;
  mix-blend-mode: screen;
  transition: width 220ms ease, height 220ms ease, opacity 220ms ease;
  opacity: 0;
}
.cursor.is-visible { opacity: 0.9; }
.cursor.is-hover { width: 36px; height: 36px; background: rgba(192,152,90,0.35); }
@media (hover: none) { .cursor { display: none; } }

/* ============================================================
   MOBILE POLISH
   Targeted refinements so the phone experience matches the
   desktop pacing. Keeps every desktop rule above untouched.
   ============================================================ */
@media (max-width: 720px) {
  /* Visit card: trim the padding, give the map a taller aspect that
     reads better in portrait, and let the section CTA stack cleanly. */
  .visit-card { padding: 24px 20px; }
  .visit-card__map { aspect-ratio: 4 / 3; margin-top: 18px; }

  .visit__cta {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
    padding: 22px;
    gap: 14px;
  }
  .visit__cta .btn { width: 100%; justify-content: center; }

  /* Services rows: keep meta tight next to the name on narrow viewports. */
  .svc-row { gap: 12px; padding: 16px 0; }
  .svc-row__meta { font-size: var(--text-caption-lg); white-space: nowrap; }
  .svc-row--featured { margin: 12px -12px; padding: 24px 18px; }
  .svc-row--featured .svc-tag { left: 16px; }

  /* About: tighter signature + portrait inset so the dark scrim breathes. */
  .about__portrait { border-radius: var(--radius-card); }

  /* Gallery: a touch more space between cells looks calmer on a phone. */
  .gallery__grid { gap: 12px; }
  .gallery__head { margin-bottom: 28px; }

  /* Lightbox: use full viewport on a phone instead of a fixed aspect ratio. */
  .lightbox { padding: 12px; }
  .lightbox__inner { aspect-ratio: auto; height: 100%; }
  .lightbox__close { top: 12px; right: 12px; }

  /* Footer: give the script wordmark room and shrink the crest a touch. */
  .footer { padding: 64px var(--space-24) 48px; }
  .footer__crest { width: 110px; height: 110px; margin-bottom: 20px; }

  /* Mobile sheet links — full-width tap target, less crowded. */
  .sheet__links a { font-size: 28px; padding: 12px 0; }
}

/* Extra-narrow phones (iPhone SE, etc.) */
@media (max-width: 380px) {
  .hero__wordmark { font-size: clamp(3.6rem, 20vw, 5.5rem); }
  .visit-card { padding: 20px 16px; }
  .nav { padding: 14px 16px; }
  .nav.is-scrolled { padding: 8px 16px; }
  .nav__brand-text { font-size: 26px; }
}
