/*
Theme Name: Aurora Theme
Theme URI: https://joshpearson-v3.homepage.studio
Description: Josh Pearson V3 monochrome luxury rebuild
Version: 7.0
Author: HomePage.Studio
*/

@import url('https://fonts.googleapis.com/css2?family=Assistant:wght@300;400;500;600;700&family=Bodoni+Moda:opsz,wght@6..96,400;6..96,500;6..96,600;6..96,700&display=swap');

:root {
  --color-bg: oklch(0.962 0.012 82);
  --color-bg-soft: oklch(0.944 0.014 82);
  --color-panel: oklch(0.985 0.008 82 / 0.92);
  --color-panel-strong: oklch(0.17 0.018 250 / 0.94);
  --color-text: oklch(0.18 0.012 250);
  --color-text-soft: oklch(0.38 0.014 250);
  --color-text-faint: oklch(0.58 0.03 70);
  --color-line: oklch(0.84 0.018 80 / 0.95);
  --color-line-strong: oklch(0.7 0.06 72 / 0.98);
  --color-contrast: oklch(0.98 0.006 82);
  --color-dark: oklch(0.18 0.025 245);
  --color-dark-soft: oklch(0.26 0.02 245);
  --color-accent: oklch(0.72 0.09 75);
  --color-accent-rich: oklch(0.62 0.11 60);
  --color-accent-soft: oklch(0.92 0.03 78);
  --color-accent-olive: oklch(0.5 0.06 145);
  --shadow-soft: 0 20px 60px rgba(24, 20, 12, 0.08);
  --shadow-strong: 0 30px 90px rgba(16, 12, 8, 0.16);
  --radius-lg: 36px;
  --radius-md: 24px;
  --radius-sm: 16px;
  --max: 1380px;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(188, 156, 92, 0.12), transparent 26%),
    linear-gradient(180deg, var(--color-bg) 0%, oklch(0.95 0.012 78) 100%);
  color: var(--color-text);
  font-family: 'Assistant', sans-serif;
  line-height: 1.72;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}
body.nav-open { overflow: hidden; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
input, textarea, select {
  width: 100%;
  border-radius: 0;
  border: 1px solid var(--color-line);
  background: rgba(255,255,255,0.75);
  padding: 16px 18px;
  color: var(--color-text);
}
textarea { min-height: 180px; resize: vertical; }

.site-shell,
.page-shell,
.footer-shell,
.top-bar__inner,
.hero-frame,
.section-shell {
  width: min(calc(100% - 32px), var(--max));
  margin: 0 auto;
}

.display {
  margin: 0;
  font-family: 'Bodoni Moda', serif;
  font-weight: 500;
  line-height: 0.92;
  letter-spacing: -0.04em;
}
.eyebrow {
  display: inline-block;
  margin-bottom: 18px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--color-accent-rich);
}
.lead {
  margin: 0;
  max-width: 58ch;
  font-size: clamp(1.06rem, 1rem + 0.35vw, 1.28rem);
  color: var(--color-text-soft);
}
.section {
  padding: clamp(72px, 7vw, 120px) 0;
}
.section--tight {
  padding-top: clamp(48px, 5vw, 72px);
  padding-bottom: clamp(48px, 5vw, 72px);
}
.section--dark {
  background: var(--color-dark);
  color: var(--color-contrast);
}
.section--dark .eyebrow,
.section--dark .lead,
.section--dark p,
.section--dark .section-note,
.section--dark .stat-value,
.section--dark .stat-label { color: rgba(247,247,247,0.86); }
.section-head {
  display: grid;
  gap: 16px;
  max-width: 760px;
  margin-bottom: clamp(32px, 4vw, 56px);
}
.section-head .display { font-size: clamp(3rem, 7vw, 5.8rem); }

.top-bar {
  position: sticky;
  top: 0;
  z-index: 1000;
  padding: 14px 0 0;
  transition: transform .4s ease, padding .3s ease;
}
.top-bar--hidden { transform: translateY(calc(-100% - 18px)); }
.top-bar__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  min-height: 82px;
  padding: 14px 20px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(14, 16, 20, 0.7);
  backdrop-filter: blur(18px);
}
.top-bar--scrolled .top-bar__inner {
  background: rgba(246,246,246,0.9);
  border-color: rgba(20,20,20,0.08);
  box-shadow: var(--shadow-soft);
}
body:not(.home) .top-bar__inner {
  background: rgba(246,246,246,0.9);
  border-color: rgba(20,20,20,0.08);
  box-shadow: var(--shadow-soft);
}
body.home .top-bar { margin-bottom: -96px; }
.top-bar__brand {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
}
.top-bar__logo {
  width: 96px;
  padding-right: 16px;
  border-right: 1px solid rgba(255,255,255,0.16);
}
.top-bar--scrolled .top-bar__logo,
body:not(.home) .top-bar__logo { border-color: rgba(20,20,20,0.12); }
.top-bar__logo img,
.site-footer__brandmark img,
.brokerage-mark img {
  width: 100%;
  height: auto;
  filter: grayscale(1) contrast(1.06) brightness(1.08);
}
.top-bar__name-lockup {
  display: grid;
  gap: 4px;
}
.top-bar__name,
.top-bar__sub,
.top-bar__nav a,
.mobile-nav a,
.top-bar__cta,
.nav-phone {
  color: rgba(248,248,248,0.92);
}
.top-bar--scrolled .top-bar__name,
.top-bar--scrolled .top-bar__sub,
.top-bar--scrolled .top-bar__nav a,
.top-bar--scrolled .top-bar__cta,
body:not(.home) .top-bar__name,
body:not(.home) .top-bar__sub,
body:not(.home) .top-bar__nav a,
body:not(.home) .top-bar__cta { color: var(--color-text); }
.top-bar__name {
  font-family: 'Bodoni Moda', serif;
  font-size: 1.45rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.top-bar__sub {
  font-size: 0.68rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(248,248,248,0.74);
}
.top-bar__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}
.top-bar__nav a,
.mobile-nav a,
.nav-phone,
.top-bar__cta,
.site-btn,
.form-submit {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.top-bar__nav a {
  position: relative;
}
.top-bar__nav a::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 1px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}
.top-bar__nav a:hover::after { transform: scaleX(1); }
.top-bar__actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.top-bar__cta,
.site-btn,
.form-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border: 1px solid currentColor;
  background: transparent;
  transition: transform .25s ease, background .25s ease, color .25s ease;
  cursor: pointer;
}
.top-bar__cta:hover,
.site-btn:hover,
.form-submit:hover { transform: translateY(-2px); }
body.home .top-bar__cta:hover,
.section--dark .site-btn:hover,
.hero-panel .site-btn:hover,
.cta-block .site-btn:hover {
  background: rgba(255,255,255,0.08);
}
body:not(.home) .top-bar__cta:hover,
.site-btn--filled,
.form-submit:hover {
  background: var(--color-accent-rich);
  border-color: var(--color-accent-rich);
  color: var(--color-contrast);
}
.site-btn--ghost { background: transparent; }
.top-bar__cta,
.form-submit,
.site-btn:not(.site-btn--ghost) {
  background: color-mix(in oklch, var(--color-accent) 18%, transparent);
  border-color: color-mix(in oklch, var(--color-accent-rich) 68%, white 32%);
}
.hamburger {
  display: none;
  width: 48px;
  height: 48px;
  border: 1px solid currentColor;
  background: transparent;
  padding: 0;
  cursor: pointer;
  color: inherit;
}
.hamburger span {
  display: block;
  width: 18px;
  height: 1px;
  margin: 5px auto;
  background: currentColor;
}
.mobile-nav {
  position: fixed;
  inset: 0 0 0 auto;
  width: min(88vw, 380px);
  padding: 120px 28px 32px;
  background: rgba(10, 12, 16, 0.97);
  transform: translateX(100%);
  transition: transform .35s ease;
  z-index: 1100;
  display: grid;
  align-content: start;
  gap: 20px;
}
.mobile-nav.open { transform: translateX(0); }
.mobile-nav__close {
  position: absolute;
  top: 22px;
  right: 22px;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255,255,255,0.18);
  background: transparent;
  color: white;
}
.mobile-nav .nav-phone {
  color: rgba(255,255,255,0.68);
  margin-top: 8px;
}

.hero {
  position: relative;
  min-height: 100svh;
  padding: 150px 0 40px;
  background: var(--color-dark);
  color: var(--color-contrast);
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 22%, rgba(188, 156, 92, 0.16), transparent 24%),
    linear-gradient(180deg, rgba(8,10,14,0.42) 0%, rgba(14,18,32,0.8) 62%, rgba(10,12,20,0.96) 100%);
  z-index: 1;
}
.hero__media {
  position: absolute;
  inset: 0;
}
.hero__media img,
.mono-photo img,
.area-card img,
.page-hero__media img,
.neighbourhood-card img,
.contact-visual img,
.story-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1) contrast(1.08) brightness(0.88);
}
.hero-frame {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.6fr);
  gap: clamp(28px, 4vw, 56px);
  align-items: end;
}
.hero-copy {
  display: grid;
  gap: 26px;
  align-content: end;
}
.hero-copy .display { font-size: clamp(4rem, 11vw, 9rem); max-width: 9.5ch; }
.hero-copy .lead { color: rgba(248,248,248,0.75); }
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
.hero-meta {
  display: grid;
  gap: 18px;
  align-content: end;
}
.hero-panel,
.quote-panel,
.process-callout,
.value-panel,
.area-panel,
.contact-card,
.page-card,
.cta-block,
.stat-panel,
.story-panel,
.footer-card {
  border: 1px solid color-mix(in oklch, var(--color-accent) 26%, rgba(255,255,255,0.12));
  background: color-mix(in oklch, var(--color-accent) 8%, rgba(255,255,255,0.04));
  padding: clamp(22px, 3vw, 34px);
}
.hero-panel {
  min-height: 100%;
  display: grid;
  gap: 18px;
}
.panel-label,
.stat-label,
.section-note {
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(248,248,248,0.72);
}
.hero-panel p,
.story-panel p,
.cta-block p,
.quote-panel p,
.contact-card p { margin: 0; color: rgba(248,248,248,0.8); }
.hero-panel strong,
.story-panel strong,
.cta-block strong,
.quote-panel strong,
.contact-card strong,
.value-panel strong,
.process-callout strong { font-size: 1.02rem; font-weight: 600; }
.stat-strip {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 32px), var(--max));
  margin: clamp(32px, 4vw, 44px) auto 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: rgba(255,255,255,0.12);
}
.stat-panel {
  background: rgba(255,255,255,0.05);
  border: 0;
  min-height: 132px;
  display: grid;
  align-content: end;
  gap: 8px;
}
.stat-value {
  margin: 0;
  font-family: 'Bodoni Moda', serif;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 0.95;
}

.editorial-grid,
.split,
.page-hero__grid,
.area-hero__grid,
.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.7fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: start;
}
.story-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: stretch;
}
.story-image {
  min-height: 620px;
  overflow: hidden;
}
.story-panel,
.page-copy,
.area-copy {
  display: grid;
  align-content: start;
  gap: 20px;
}
.story-panel,
.page-copy,
.area-copy,
.quote-panel,
.process-callout,
.value-panel,
.page-card,
.contact-card {
  padding: clamp(24px, 3vw, 36px);
  background: linear-gradient(180deg, var(--color-panel) 0%, color-mix(in oklch, var(--color-accent-soft) 46%, var(--color-panel) 54%) 100%);
  border: 1px solid var(--color-line);
  box-shadow: var(--shadow-soft);
}
.story-panel .display,
.page-copy h2,
.area-copy h2,
.quote-panel em,
.process-callout p,
.value-panel p { margin: 0; }
.story-panel .display,
.page-copy h2,
.area-copy h2 { font-size: clamp(2.6rem, 5vw, 4.6rem); font-family: 'Bodoni Moda', serif; font-weight: 500; line-height: 0.96; letter-spacing: -0.04em; }
.page-copy p,
.area-copy p,
.quote-panel p,
.value-panel p,
.process-callout p,
.page-card p,
.contact-card p { color: var(--color-text-soft); margin: 0; }
.quote-panel em {
  font-family: 'Bodoni Moda', serif;
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.15;
  color: var(--color-text);
}
.mono-photo {
  min-height: 620px;
  overflow: hidden;
  background: var(--color-dark);
}

.area-grid,
.process-grid,
.neighbourhood-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}
.area-card,
.process-card,
.neighbourhood-card {
  display: grid;
  gap: 0;
  background: var(--color-panel);
  border: 1px solid var(--color-line);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.area-card__body,
.neighbourhood-card__body,
.process-card__body { padding: 24px; display: grid; gap: 14px; }
.area-card__body span,
.neighbourhood-card__body span,
.process-card__number {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-text-faint);
}
.area-card__body h3,
.neighbourhood-card__body h3,
.process-card h3 { margin: 0; font-family: 'Bodoni Moda', serif; font-weight: 500; font-size: clamp(1.45rem, 2vw, 1.85rem); line-height: 1.05; }
.area-card__body p,
.neighbourhood-card__body p,
.process-card p { margin: 0; color: var(--color-text-soft); }
.area-card img,
.neighbourhood-card img { aspect-ratio: 1 / 1.15; }
.process-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.process-card {
  padding: 28px;
  min-height: 280px;
  align-content: start;
  gap: 18px;
}

.band {
  position: relative;
  background: var(--color-dark);
  color: var(--color-contrast);
  min-height: 82svh;
  display: grid;
  align-items: end;
}
.band__media,
.band::before {
  position: absolute;
  inset: 0;
}
.band__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1) contrast(1.06) brightness(0.56);
}
.band::before {
  content: '';
  background: linear-gradient(180deg, rgba(8,10,14,0.14) 0%, rgba(8,10,14,0.82) 100%);
  z-index: 1;
}
.band__inner {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 32px), var(--max));
  margin: 0 auto;
  padding: clamp(80px, 8vw, 140px) 0;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.55fr);
  gap: clamp(28px, 4vw, 56px);
  align-items: end;
}
.band__inner .display { font-size: clamp(3.4rem, 7vw, 6.8rem); max-width: 10ch; }
.band__inner p { margin: 0; max-width: 58ch; color: rgba(248,248,248,0.78); }
.band__aside { display: grid; gap: 1px; background: rgba(255,255,255,0.14); }
.band__aside > div { padding: 24px; background: rgba(255,255,255,0.06); display: grid; gap: 8px; }
.band__aside span { font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(248,248,248,0.62); }
.band__aside strong { font-family: 'Bodoni Moda', serif; font-size: 1.55rem; font-weight: 500; }

.page-hero,
.area-hero {
  padding: 180px 0 54px;
}
.page-hero__copy,
.area-hero__copy { display: grid; gap: 22px; align-content: center; }
.page-hero .display,
.area-hero .display { font-size: clamp(3.4rem, 8vw, 7rem); max-width: 10ch; }
.page-hero__media,
.area-hero__media,
.contact-visual,
.story-image {
  position: relative;
  background: var(--color-dark);
  min-height: 540px;
  aspect-ratio: 4 / 5;
  overflow: hidden;
}
.page-hero__media img,
.area-hero__media img,
.contact-visual img,
.story-image img {
  position: absolute;
  inset: 0;
}
.page-content,
.area-content { padding: 0 0 clamp(72px, 8vw, 120px); }
.area-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.7fr);
  gap: clamp(28px, 4vw, 48px);
}
.area-list { display: grid; gap: 18px; }
.area-link {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 0;
  background: var(--color-panel);
  border: 1px solid var(--color-line);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.area-link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1) contrast(1.08) brightness(0.9);
}
.area-link > div { padding: 24px; display: grid; gap: 12px; }
.area-link span { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-text-faint); }
.area-link h3 { margin: 0; font-family: 'Bodoni Moda', serif; font-size: clamp(1.6rem, 2.2vw, 2.2rem); font-weight: 500; line-height: 1.05; }
.area-link p { margin: 0; color: var(--color-text-soft); }
.area-panel {
  background: linear-gradient(180deg, color-mix(in oklch, var(--color-accent-olive) 18%, var(--color-dark) 82%) 0%, var(--color-dark) 100%);
  color: var(--color-contrast);
  border-color: color-mix(in oklch, var(--color-accent) 32%, rgba(255,255,255,0.12));
  box-shadow: none;
  display: grid;
  align-content: end;
  gap: 18px;
  min-height: 100%;
}
.area-panel .display { font-size: clamp(2.8rem, 5vw, 4.2rem); }
.area-panel p { margin: 0; color: rgba(248,248,248,0.74); }

.contact-layout {
  align-items: stretch;
}
.page-card {
  padding: clamp(28px, 4vw, 42px);
  display: grid;
  gap: 22px;
}
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.form-label {
  display: grid;
  gap: 10px;
}
.form-label span {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-text-faint);
}
.form-label.full { grid-column: 1 / -1; }
.contact-card {
  padding: clamp(28px, 4vw, 42px);
  display: grid;
  align-content: end;
  gap: 18px;
}
.contact-card a { text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 0.18em; }

.cta-block {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: end;
  padding: clamp(28px, 4vw, 42px);
  background: linear-gradient(135deg, color-mix(in oklch, var(--color-accent-rich) 28%, var(--color-dark) 72%) 0%, var(--color-dark) 100%);
  color: var(--color-contrast);
  border-color: color-mix(in oklch, var(--color-accent) 32%, rgba(255,255,255,0.12));
}
.cta-block .display { font-size: clamp(2.8rem, 5vw, 4.6rem); max-width: 11ch; }
.cta-actions { display: flex; flex-wrap: wrap; gap: 14px; }

.site-footer {
  background: linear-gradient(180deg, color-mix(in oklch, var(--color-accent-olive) 12%, var(--color-dark) 88%) 0%, var(--color-dark) 100%);
  color: var(--color-contrast);
  padding: 0 0 28px;
}
.site-footer__panel {
  padding-top: clamp(64px, 7vw, 110px);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) repeat(2, minmax(180px, 0.5fr)) minmax(220px, 0.75fr);
  gap: 24px;
}
.footer-card {
  min-height: 100%;
}
.site-footer__brand {
  display: grid;
  gap: 18px;
}
.site-footer__brandmark { width: 130px; }
.site-footer h4 {
  margin: 0 0 18px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(248,248,248,0.56);
}
.site-footer__nav,
.site-footer__contact { display: grid; gap: 12px; }
.footer-copy,
.site-footer__bottom,
.site-footer__bottom a,
.brokerage-mark p { color: rgba(248,248,248,0.68); }
.site-footer__bottom {
  margin-top: 18px;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  font-size: 0.8rem;
}
.brokerage-mark { display: grid; gap: 16px; }
.brokerage-mark__image { width: 150px; }

.reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .7s cubic-bezier(.19,1,.22,1), transform .7s cubic-bezier(.19,1,.22,1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1180px) {
  .top-bar__nav { display: none; }
  .hamburger { display: inline-block; }
  .hero-frame,
  .editorial-grid,
  .split,
  .story-grid,
  .page-hero__grid,
  .area-hero__grid,
  .area-layout,
  .contact-layout,
  .band__inner,
  .cta-block,
  .site-footer__grid { grid-template-columns: 1fr; }
  .hero-meta { grid-template-columns: 1fr 1fr; align-items: stretch; }
  .site-footer__grid > * { min-height: auto; }
}

@media (max-width: 900px) {
  .stat-strip,
  .area-grid,
  .process-grid,
  .neighbourhood-grid,
  .form-grid,
  .hero-meta { grid-template-columns: 1fr; }
  .hero-frame,
  .hero-copy,
  .hero-meta,
  .hero-panel,
  .stat-strip,
  .stat-panel { min-width: 0; width: 100%; }
  .hero-copy .display,
  .hero-copy .lead,
  .hero-panel strong,
  .hero-panel p { overflow-wrap: anywhere; }
  .area-link { grid-template-columns: 1fr; }
  .page-hero__media,
  .area-hero__media,
  .contact-visual,
  .story-image,
  .mono-photo { min-height: 340px; }
  .top-bar__inner {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
  }
  .top-bar__brand { min-width: 0; max-width: calc(100% - 56px); }
  .top-bar__name-lockup { min-width: 0; }
  .top-bar__name { font-size: 1.1rem; }
  .top-bar__sub { font-size: 0.58rem; }
  .top-bar__cta { display: none; }
}

@media (max-width: 640px) {
  body.home .top-bar { margin-bottom: -88px; }
  .top-bar__inner { min-height: 74px; padding: 10px 12px; }
  .top-bar__logo { width: 64px; padding-right: 10px; }
  .top-bar__name { font-size: 0.82rem; letter-spacing: 0.1em; }
  .top-bar__sub { display: none; }
  .hero { min-height: auto; padding-top: 132px; padding-bottom: 24px; }
  .hero-copy { gap: 20px; }
  .hero-actions { display: grid; }
  .hero-panel { padding: 20px; }
  .stat-strip { margin-top: 24px; }
  .page-hero__media,
  .area-hero__media,
  .contact-visual,
  .story-image,
  .mono-photo { min-height: 280px; }
  .hero-copy .display,
  .page-hero .display,
  .area-hero .display,
  .section-head .display,
  .band__inner .display,
  .cta-block .display,
  .story-panel .display,
  .page-copy h2,
  .area-copy h2,
  .area-panel .display { line-height: 0.98; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
}
