/* =========================================================
   MATT BAUER  --  Personal Brand Site
   Design language: deep navy blue, amber-gold accent,
   Big Shoulders Display, cinematic grain & reveals.
   Sibling to mattbauersingsgarth.com -- same family,
   broader scope.
   ========================================================= */

:root {
  --ink:        #06111e;
  --ink-2:      #091828;
  --ink-3:      #0d2038;
  --line:       #122030;
  --bone:       #f2ede3;
  --bone-dim:   #afa48f;
  --bone-faint: #6a6050;

  --gold:        #c9971a;
  --gold-bright: #e6b12a;
  --gold-deep:   #9a6f0e;
  --gold-glow:   rgba(201, 151, 26, 0.45);
  --gold-wash:   rgba(201, 151, 26, 0.08);

  --display: 'Big Shoulders Display', 'Arial Narrow', sans-serif;
  --body:    'Archivo', system-ui, -apple-system, sans-serif;
  --mono:    'Spline Sans Mono', ui-monospace, 'SFMono-Regular', monospace;

  --max: 1180px;
  --bleed: clamp(20px, 5.5vw, 80px);
  --ease: cubic-bezier(0.16, 0.84, 0.24, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; background: var(--ink); }

body {
  font-family: var(--body);
  font-size: 17px; line-height: 1.65;
  color: var(--bone); background: var(--ink);
  overflow-x: hidden;
  text-wrap: pretty;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Global grain + vignette */
body::after {
  content: ''; position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(130% 100% at 50% 0%, transparent 55%, rgba(0,0,0,0.6) 100%);
}
body::before {
  content: ''; position: fixed; inset: 0; z-index: 1; pointer-events: none;
  opacity: 0.22; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='150' height='150'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
body > *, main { position: relative; z-index: 2; }

@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

a { color: var(--gold); text-decoration: none; transition: color 0.2s var(--ease); }
a:hover { color: var(--gold-bright); }
img { max-width: 100%; display: block; }
::selection { background: var(--gold); color: var(--ink); }

.skip-link {
  position: absolute; top: -50px; left: 0;
  background: var(--gold); color: var(--ink);
  padding: 10px 16px; z-index: 400;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
}
.skip-link:focus { top: 0; }

/* ---------- Scroll progress ---------- */
.progress { position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 300; pointer-events: none; }
#progress-bar {
  display: block; height: 100%; width: 0;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold), var(--gold-bright));
  box-shadow: 0 0 12px var(--gold-glow);
  transition: width 0.1s linear;
}

/* ---------- Marquee strip ---------- */
.strip { background: var(--gold); color: var(--ink); overflow: hidden; white-space: nowrap; }
.strip-track {
  display: inline-flex; align-items: center;
  padding: 7px 0;
  font-family: var(--mono); font-size: 11.5px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  animation: slide 40s linear infinite;
}
.strip-track span { padding: 0 20px; }
.strip-track i { font-style: normal; opacity: 0.5; font-size: 8px; }
@keyframes slide { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .strip-track { animation: none; } }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  padding: 13px var(--bleed);
  background: rgba(6, 17, 30, 0.85);
  backdrop-filter: saturate(160%) blur(16px);
  -webkit-backdrop-filter: saturate(160%) blur(16px);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: 12px; color: var(--bone); }
.brand:hover { color: var(--bone); }
.brand-mark { color: var(--gold); flex: 0 0 auto; display: inline-flex; }
.badge-arc { fill: currentColor; font-family: var(--mono); font-weight: 600; }
.badge-mono { fill: currentColor; font-family: var(--display); font-weight: 800; letter-spacing: -0.02em; }
.brand-words { display: flex; flex-direction: column; line-height: 1.05; }
.brand-words strong { font-family: var(--display); font-weight: 800; font-size: 20px; letter-spacing: 0.01em; text-transform: uppercase; }
.brand-words em { font-family: var(--mono); font-style: normal; font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--bone-dim); }
.nav-links { display: flex; align-items: center; gap: 24px; }
.nav-links a { font-family: var(--mono); font-size: 12.5px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-dim); }
.nav-links a:hover { color: var(--bone); }
.nav-cta { color: var(--gold) !important; border: 1px solid var(--gold); padding: 7px 16px; border-radius: 100px; }
.nav-cta:hover { background: var(--gold); color: var(--ink) !important; }
@media (max-width: 720px) {
  .brand-words { display: none; }
  .nav-links { gap: 14px; }
  .nav-links a:not(.nav-cta) { display: none; }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 15px 28px; border-radius: 100px;
  border: 1.5px solid transparent; cursor: pointer;
  transition: transform 0.2s var(--ease), background 0.2s var(--ease),
              color 0.2s var(--ease), box-shadow 0.25s var(--ease);
}
.btn span { transition: transform 0.2s var(--ease); }
.btn:hover span { transform: translateX(4px); }
.btn-gold { background: var(--gold); color: var(--ink); }
.btn-gold:hover { background: var(--gold-bright); color: var(--ink); transform: translateY(-2px); box-shadow: 0 12px 36px -8px var(--gold-glow); }
.btn-ghost { background: transparent; color: var(--bone); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-2px); }

/* ---------- Section layout ---------- */
.section-inner { max-width: var(--max); margin: 0 auto; padding: clamp(72px, 11vw, 130px) var(--bleed); }
.section-head { margin-bottom: clamp(44px, 6vw, 72px); }
.section-head h2 { margin: 16px 0 0; text-wrap: balance; }
.section-sub { font-size: clamp(17px, 1.5vw, 20px); color: var(--bone-dim); max-width: 52ch; margin: 20px 0 0; }

/* Section headings */
.kicker {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--mono); font-size: 12.5px; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--bone-dim);
}
.kicker .num { color: var(--gold); }
.kicker-gold { color: var(--gold); }
.kicker-gold .num { color: var(--bone-dim); }
h2 {
  font-family: var(--display); font-weight: 800;
  text-transform: uppercase; line-height: 0.88;
  letter-spacing: -0.01em; margin: 0;
  font-size: clamp(38px, 6vw, 88px); color: var(--bone);
  text-wrap: balance;
}

/* ---------- HERO ---------- */
.hero {
  position: relative;
  min-height: calc(100svh - 92px);
  display: flex; flex-direction: column; justify-content: center;
  padding: clamp(64px, 10vh, 140px) var(--bleed) clamp(80px, 12vh, 160px);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.hero-photo {
  position: absolute; inset: 0; z-index: 0;
  background-image: url('/assets/hero.jpg');
  background-size: cover; background-position: center 25%;
}
.hero-scrim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(100deg, rgba(6,17,30,0.97) 0%, rgba(6,17,30,0.84) 35%, rgba(6,17,30,0.38) 65%, rgba(6,17,30,0.58) 100%),
    linear-gradient(0deg, rgba(6,17,30,0.97) 0%, rgba(6,17,30,0.15) 35%, rgba(6,17,30,0) 55%);
}
@media (max-width: 720px) {
  .hero-photo { background-position: 60% center; }
  .hero-scrim {
    background:
      linear-gradient(0deg, rgba(6,17,30,0.98) 10%, rgba(6,17,30,0.55) 50%, rgba(6,17,30,0.72) 100%),
      rgba(6,17,30,0.4);
  }
}
.grain {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  opacity: 0.45; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23g)' opacity='0.5'/></svg>");
}
.hero-inner {
  position: relative; z-index: 5;
  max-width: var(--max); margin: 0 auto; width: 100%;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold);
  margin: 0 0 28px;
}
.dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gold); box-shadow: 0 0 10px var(--gold);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.25} }

.hero-name {
  font-family: var(--display); font-weight: 900;
  text-transform: uppercase; line-height: 0.84;
  letter-spacing: -0.02em;
  font-size: clamp(48px, 17vw, 240px);
  white-space: nowrap;
  color: var(--bone);
  margin: 0 0 32px;
}
.hero-lede {
  font-size: clamp(18px, 1.8vw, 24px);
  line-height: 1.5; color: var(--bone-dim);
  max-width: 54ch; margin: 0 0 30px;
  font-weight: 300; font-style: italic;
}
.hero-lede .br-d { display: none; }
@media (min-width: 860px) { .hero-lede .br-d { display: block; } }

.hero-roles {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 0; margin: 0 0 38px;
}
.role-pill {
  font-family: var(--mono); font-size: 11.5px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--bone); padding: 8px 18px;
  border: 1px solid var(--line); border-radius: 100px;
  margin: 4px;
  transition: border-color 0.2s var(--ease), color 0.2s var(--ease);
}
.role-pill:hover { border-color: var(--gold); color: var(--gold); }
.role-sep { width: 1px; height: 0; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; }

.scroll-cue {
  position: absolute; left: 50%; bottom: 28px;
  transform: translateX(-50%); z-index: 5;
  width: 26px; height: 42px; border: 1.5px solid var(--line);
  border-radius: 100px; display: flex; justify-content: center; padding-top: 8px;
}
.scroll-cue span {
  width: 4px; height: 8px; border-radius: 4px;
  background: var(--gold); animation: drop 1.8s ease-in-out infinite;
}
@keyframes drop { 0%{transform:translateY(0);opacity:1} 70%{transform:translateY(14px);opacity:0} 100%{opacity:0} }

/* ---------- ABOUT ---------- */
.about { border-top: 1px solid var(--line); }
.about-kicker { margin-bottom: clamp(32px, 5vw, 56px); }
.about-grid {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: clamp(40px, 7vw, 100px);
  align-items: start;
}
@media (max-width: 860px) { .about-grid { grid-template-columns: 1fr; gap: 48px; } }

.about-text h2 { margin-bottom: clamp(28px, 3vw, 44px); }
.about-prose .lead-p {
  font-size: clamp(19px, 1.9vw, 24px); line-height: 1.48;
  color: var(--bone); font-weight: 500; margin: 0 0 24px;
}
.about-prose p { color: var(--bone-dim); margin: 0 0 18px; max-width: 58ch; }

.about-stats {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  background: var(--line); border: 1px solid var(--line);
  border-radius: 16px; overflow: hidden;
}
.stat-block {
  display: flex; flex-direction: column; gap: 8px;
  padding: clamp(22px, 3vw, 36px);
  background: var(--ink-2);
  transition: background 0.2s var(--ease);
}
.stat-block:hover { background: var(--ink-3); }
.stat-block-accent { background: linear-gradient(145deg, #091e38, var(--ink-2)); }
.stat-num {
  font-family: var(--display); font-weight: 900;
  font-size: clamp(44px, 5.5vw, 72px); line-height: 0.88;
  color: var(--gold); letter-spacing: -0.02em;
}
.stat-num sup { font-size: 0.45em; vertical-align: top; margin-top: 0.12em; }
.stat-label {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--bone-dim);
}

/* ---------- VIDEO SECTION ---------- */
.video-section { border-top: 1px solid var(--line); }
.video-section .section-inner { padding-bottom: clamp(40px, 6vw, 80px); }
.video-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 2.5vw, 28px);
  margin-bottom: clamp(36px, 5vw, 56px);
}
@media (max-width: 900px) { .video-cards { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .video-cards { grid-template-columns: 1fr; } }

.vcard {
  border: 1px solid var(--line); border-radius: 16px;
  padding: clamp(24px, 3vw, 38px);
  background: linear-gradient(165deg, var(--ink-2), var(--ink));
  display: flex; flex-direction: column; gap: 16px;
  transition: border-color 0.25s var(--ease), transform 0.25s var(--ease);
}
.vcard:hover { border-color: rgba(201, 151, 26, 0.5); transform: translateY(-4px); }
.vcard-feature { border-color: rgba(201, 151, 26, 0.35); }
.vcard-icon {
  width: 44px; height: 44px; color: var(--gold);
  opacity: 0.85;
}
.vcard-tag {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold);
}
.vcard h3 {
  font-family: var(--display); font-weight: 700;
  font-size: clamp(22px, 2.5vw, 30px); text-transform: uppercase;
  letter-spacing: 0.01em; margin: 0; color: var(--bone); line-height: 1.1;
}
.vcard p { margin: 0; font-size: 15.5px; color: var(--bone-dim); line-height: 1.6; flex: 1; }
.video-cta { text-align: center; padding-bottom: clamp(36px, 5vw, 64px); }

/* ---------- MUSIC SECTION ---------- */
.music-section { border-top: 1px solid var(--line); }
.music-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(20px, 3vw, 36px);
}
@media (max-width: 780px) { .music-grid { grid-template-columns: 1fr; } }

.music-card {
  border: 1px solid var(--line); border-radius: 16px;
  padding: clamp(28px, 3.5vw, 44px);
  background: linear-gradient(165deg, var(--ink-2), var(--ink));
  display: flex; flex-direction: column; gap: 28px;
  transition: border-color 0.25s var(--ease), transform 0.25s var(--ease);
}
.music-card:hover { border-color: rgba(201,151,26,0.45); transform: translateY(-3px); }
.music-card-garth { border-color: rgba(201,151,26,0.3); }
.music-card-top { flex: 1; display: flex; flex-direction: column; gap: 16px; }
.music-tag {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold);
}
.music-card h3 {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(30px, 3.5vw, 48px); text-transform: uppercase;
  letter-spacing: 0.01em; margin: 0; color: var(--bone); line-height: 0.92;
}
.music-card h3 em { font-style: italic; font-weight: 500; font-size: 0.6em; color: var(--gold); display: block; letter-spacing: 0.04em; text-transform: none; margin-top: 6px; }
.music-card > .music-card-top > p { color: var(--bone-dim); font-size: 15.5px; line-height: 1.6; margin: 0; }
.music-formats {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 4px;
}
.music-formats span {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--bone-dim); border: 1px solid var(--line);
  border-radius: 100px; padding: 5px 14px;
}
.music-btn { align-self: flex-start; }

/* Album tracklist */
.album-tracks {
  list-style: none; margin: 0; padding: 0;
  flex: 1; display: flex; flex-direction: column;
}
.album-tracks li {
  display: flex; align-items: baseline; gap: 10px;
  padding: 9px 4px; border-bottom: 1px solid var(--line);
  transition: padding 0.18s var(--ease);
}
.album-tracks li:hover { padding-left: 10px; }
.album-tracks li:hover .t-name { color: var(--gold); }
.album-tracks li:last-child { border-bottom: none; }
.t-num {
  font-family: var(--mono); font-size: 11px; color: var(--bone-faint);
  flex: 0 0 22px;
}
.t-name {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(16px, 1.6vw, 20px); text-transform: uppercase;
  letter-spacing: 0.01em; color: var(--bone); flex: 1;
  transition: color 0.18s var(--ease);
}
.t-len {
  font-family: var(--mono); font-size: 11px; color: var(--bone-faint);
  flex: 0 0 auto;
}

/* ---------- FAMILY SECTION ---------- */
.family-section { border-top: 1px solid var(--line); }
.family-grid {
  display: grid; grid-template-columns: 1fr 1.3fr;
  gap: clamp(40px, 7vw, 96px); align-items: start;
}
@media (max-width: 900px) { .family-grid { grid-template-columns: 1fr; gap: 40px; } }

/* Photo column */
.fam-photo {
  position: sticky; top: calc(56px + 20px);
  aspect-ratio: 4/5;
  border-radius: 16px; overflow: hidden;
  background: linear-gradient(165deg, var(--ink-3), var(--ink-2));
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
}
.fam-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.fam-photo-placeholder {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bone-faint); text-align: center; line-height: 2.2; padding: 32px;
}
.fam-photo-placeholder strong { display: block; color: var(--bone-dim); font-size: 13px; margin-bottom: 8px; }
@media (max-width: 900px) { .fam-photo { position: static; aspect-ratio: 16/9; } }

/* Content column */
.family-right { display: flex; flex-direction: column; gap: 32px; }
.family-prose .lead-p {
  font-size: clamp(20px, 2vw, 26px); line-height: 1.45;
  color: var(--bone); font-weight: 500; margin: 0 0 22px;
}
.family-prose p { color: var(--bone-dim); margin: 0 0 18px; max-width: 54ch; line-height: 1.65; }
.family-cards { display: flex; flex-direction: column; gap: 12px; }
.fam-card {
  border: 1px solid var(--line); border-radius: 14px;
  padding: clamp(20px, 2.5vw, 30px);
  background: linear-gradient(165deg, var(--ink-2), var(--ink));
  display: flex; flex-direction: column; gap: 6px;
  transition: border-color 0.25s var(--ease), transform 0.25s var(--ease);
  transition-delay: var(--d, 0ms);
}
.fam-card:hover { border-color: rgba(201,151,26,0.4); transform: translateX(6px); }
.fam-card-accent { border-color: rgba(201,151,26,0.3); background: linear-gradient(165deg, #06172e, var(--ink)); }
.fam-name {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(26px, 3vw, 36px); text-transform: uppercase;
  letter-spacing: 0.01em; color: var(--bone); line-height: 1;
}
.fam-age {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 4px;
}
.fam-card p { margin: 0; font-size: 15px; color: var(--bone-dim); line-height: 1.55; }

/* ---------- CONTACT SECTION ---------- */
.contact-section {
  position: relative;
  border-top: 1px solid var(--line);
  overflow: hidden;
  background: radial-gradient(80% 120% at 50% 0%, #0a1f38, var(--ink));
}
.ghost-word {
  position: absolute; right: -4vw; top: 50%;
  transform: translateY(-50%);
  font-family: var(--display); font-weight: 900;
  font-size: clamp(120px, 22vw, 320px); line-height: 0.85;
  letter-spacing: -0.04em; text-transform: uppercase;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(201, 151, 26, 0.07);
  user-select: none; pointer-events: none; z-index: 0;
}
.contact-inner { position: relative; z-index: 2; }
.contact-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(12px, 2vw, 20px);
}
@media (max-width: 600px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-card {
  display: flex; flex-direction: column; gap: 8px;
  border: 1px solid var(--line); border-radius: 14px;
  padding: clamp(22px, 3vw, 34px);
  background: linear-gradient(165deg, var(--ink-2), var(--ink));
  color: var(--bone);
  transition: border-color 0.25s var(--ease), transform 0.25s var(--ease), color 0.2s var(--ease);
  position: relative;
}
.contact-card:hover { border-color: rgba(201,151,26,0.5); transform: translateY(-3px); color: var(--bone); }
.contact-email { border-color: rgba(201,151,26,0.3); }
.contact-mm { grid-column: span 1; }
.contact-icon {
  width: 36px; height: 36px; color: var(--gold);
  margin-bottom: 4px;
}
.contact-label {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold);
}
.contact-val {
  font-family: var(--display); font-weight: 700;
  font-size: clamp(18px, 2vw, 24px); text-transform: uppercase;
  letter-spacing: 0.01em; color: var(--bone); line-height: 1.1;
}
.contact-arrow {
  position: absolute; right: 24px; top: 50%;
  transform: translateY(-50%);
  font-size: 20px; color: var(--gold);
  opacity: 0; transition: opacity 0.2s var(--ease), transform 0.2s var(--ease);
}
.contact-card:hover .contact-arrow { opacity: 1; transform: translateY(-50%) translateX(3px); }

/* ---------- FOOTER ---------- */
.foot { border-top: 1px solid var(--line); background: var(--ink); }
.foot-inner {
  max-width: var(--max); margin: 0 auto;
  padding: clamp(56px, 8vw, 90px) var(--bleed) 48px;
  display: flex; flex-direction: column; align-items: center;
  gap: 20px; text-align: center;
}
.foot-svg { color: var(--gold); }
.foot-name {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(26px, 3.5vw, 42px); text-transform: uppercase;
  letter-spacing: 0.01em; color: var(--bone); margin: 0;
}
.foot-tagline {
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--bone-dim); margin: 0;
}
.foot-links {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 8px 28px; margin-top: 10px;
}
.foot-links a {
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-dim);
  transition: color 0.2s var(--ease);
}
.foot-links a:hover { color: var(--gold); }
.colophon { font-size: 13px; font-style: italic; color: var(--bone-faint); margin: 8px 0 0; }

/* ---------- Hero reveal animations ---------- */
.reveal { opacity: 0; transform: translateY(18px); animation: rise 0.9s var(--ease) forwards; }
.reveal[data-r="1"]{animation-delay:.05s}
.reveal[data-r="2"]{animation-delay:.12s}
.reveal[data-r="3"]{animation-delay:.3s}
.reveal[data-r="4"]{animation-delay:.46s}
.reveal[data-r="5"]{animation-delay:.62s}
.reveal[data-r="6"]{animation-delay:.84s}
@keyframes rise { to { opacity: 1; transform: translateY(0); } }

/* ---------- Scroll reveal ---------- */
.r {
  opacity: 0; transform: translateY(28px);
  transition: opacity 0.72s var(--ease), transform 0.72s var(--ease);
  transition-delay: var(--d, 0ms);
}
.r.is-in { opacity: 1; transform: none; }

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