/* ============================================================
 * KAELUM — personal brand site
 * Layout & components on top of kaelum-tokens.css
 * Quiet luxury · obsidian stage · one crimson accent ·
 * a subtle technical/blueprint annotation layer.
 * ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--obsidian);
  color: var(--fg);
  font-family: var(--font-body);
  overflow-x: hidden;
}
::selection { background: var(--crimson); color: var(--porcelain); }

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* density scale — driven by [data-density] on <html> */
:root { --pad-section: 160px; --gap-grid: 64px; --hero-scale: 1; }
html[data-density="compact"]  { --pad-section: 104px; --gap-grid: 40px; --hero-scale: 0.86; }
html[data-density="spacious"] { --pad-section: 220px; --gap-grid: 88px; --hero-scale: 1.12; }

/* ---------- layout primitives ---------- */
.wrap { width: min(1280px, 100% - 96px); margin-inline: auto; }
.wrap--wide { width: min(1480px, 100% - 64px); }
section { position: relative; }

.eyebrow {
  font-family: var(--font-display);
  font-size: var(--t-micro);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--crimson);
  display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow--muted { color: var(--fg-muted); }
.eyebrow .tick { width: 18px; height: 1px; background: currentColor; opacity: .8; }

/* mono technical annotation */
.anno {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--fg-subtle);
  text-transform: uppercase;
}
.anno--accent { color: var(--crimson); }

.k-rule { width: 2px; background: var(--crimson); align-self: stretch; }

/* section index marker, top-left of each section */
.sec-index {
  position: absolute; top: 0; left: 0;
  display: flex; align-items: center; gap: 14px;
  padding: 28px 0;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--fg-subtle); text-transform: uppercase;
}
.sec-index::before { content: ""; width: 40px; height: 1px; background: var(--border-strong); }

/* ============================================================
 * NAV
 * ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  display: flex; justify-content: center;
  padding: 22px 24px;
  pointer-events: none;
  transition: padding var(--dur-base) var(--ease-out);
}
.nav__inner {
  pointer-events: auto;
  display: flex; align-items: center; gap: 40px;
  padding: 12px 14px 12px 26px;
  border-radius: var(--r-pill);
  border: 1px solid var(--border);
  background: rgba(16, 17, 20, 0.55);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  box-shadow: var(--shadow-cinematic);
  transition: all var(--dur-base) var(--ease-out);
}
.nav__brand {
  font-family: var(--font-editorial); font-size: 16px;
  letter-spacing: 0.42em; text-transform: uppercase; color: var(--porcelain);
  padding-right: 0.42em; white-space: nowrap;
}
.nav__links { display: flex; gap: 30px; }
.nav__links a {
  font-family: var(--font-display); font-size: 11px; font-weight: var(--w-semi);
  letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--steel);
  transition: color var(--dur-base) var(--ease-out); white-space: nowrap;
}
.nav__links a:hover { color: var(--porcelain); }
.nav__cta {
  font-family: var(--font-display); font-size: 11px; font-weight: var(--w-semi);
  letter-spacing: var(--ls-eyebrow); text-transform: uppercase;
  color: var(--porcelain); background: var(--crimson);
  padding: 12px 22px; border-radius: var(--r-pill); white-space: nowrap;
  transition: background var(--dur-base) var(--ease-out);
}
.nav__cta:hover { background: var(--crimson-deep); }

/* minimal nav variant */
html[data-nav="minimal"] .nav { padding: 26px 0; }
html[data-nav="minimal"] .nav__inner {
  width: min(1280px, 100% - 96px);
  justify-content: space-between;
  background: transparent; backdrop-filter: none; -webkit-backdrop-filter: none;
  border: 0; box-shadow: none; border-radius: 0;
  padding: 0 0 18px;
  border-bottom: 1px solid var(--border);
}

/* ============================================================
 * HERO — full-bleed cinematic frame, focus point travels the face
 * ============================================================ */
.hero { position: relative; height: 100svh; min-height: 600px; overflow: hidden; display: flex; align-items: flex-end; }

.hero__media { position: absolute; inset: 0; z-index: 0; background: #050608; }
.hero__base, .hero__focus {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: var(--face-x, 50%) var(--face-y, 20%);
}
/* soft, dark, out-of-focus base */
.hero__base { filter: grayscale(.28) contrast(1.02) brightness(.5) blur(2px); transform: scale(1.07); will-change: transform; }
/* sharp, lit focus layer — revealed only inside the travelling lens */
.hero__focus { filter: grayscale(.1) contrast(1.08) brightness(1.05) saturate(1.02); clip-path: circle(0% at 50% 30%); will-change: clip-path; }
body.hero-in .hero__focus { animation: focusTravel 16s var(--ease-in-out) 1.05s infinite; }
body.hero-in .hero__base  { animation: heroKen 28s var(--ease-in-out) infinite alternate; }
@keyframes focusTravel {
  0%,100% { clip-path: circle(20% at 48% 28%); }
  20%     { clip-path: circle(14% at 57% 26%); }
  42%     { clip-path: circle(24% at 53% 39%); }
  64%     { clip-path: circle(13% at 42% 33%); }
  84%     { clip-path: circle(19% at 50% 24%); }
}
@keyframes heroKen { from { transform: scale(1.07) translateY(0); } to { transform: scale(1.15) translateY(-1.5%); } }

.hero__grain { position: absolute; inset: 0; z-index: 2; mix-blend-mode: overlay; opacity: .28; pointer-events: none;
  background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.06) 0 1px, transparent 1px 3px); }
.hero__scrim { position: absolute; inset: 0; z-index: 3; pointer-events: none; background:
  linear-gradient(180deg, rgba(5,6,8,0.62) 0%, transparent 20%, transparent 42%, rgba(5,6,8,0.74) 86%, rgba(5,6,8,0.94) 100%),
  radial-gradient(125% 80% at 52% 30%, transparent 42%, rgba(5,6,8,0.5) 100%); }

/* travelling focus reticle (tracks the lens) */
.hero__reticle { position: absolute; z-index: 4; top: 28%; left: 48%; width: clamp(120px, 18vw, 250px); aspect-ratio: 1;
  transform: translate(-50%, -50%); pointer-events: none; }
body.hero-in .hero__reticle { animation: retTravel 16s var(--ease-in-out) 1.05s infinite; }
@keyframes retTravel {
  0%,100% { top: 28%; left: 48%; width: clamp(120px, 18vw, 250px); }
  20%     { top: 26%; left: 57%; width: clamp(92px, 13vw, 180px); }
  42%     { top: 39%; left: 53%; width: clamp(150px, 22vw, 300px); }
  64%     { top: 33%; left: 42%; width: clamp(86px, 12vw, 165px); }
  84%     { top: 24%; left: 50%; width: clamp(116px, 17vw, 240px); }
}
.hero__reticle b { position: absolute; width: 13px; height: 13px; border: 1px solid rgba(242,239,232,0.72); }
.hero__reticle b.tl { top: 0; left: 0; border-right: 0; border-bottom: 0; }
.hero__reticle b.tr { top: 0; right: 0; border-left: 0; border-bottom: 0; }
.hero__reticle b.bl { bottom: 0; left: 0; border-right: 0; border-top: 0; }
.hero__reticle b.br { bottom: 0; right: 0; border-left: 0; border-top: 0; }
.hero__reticle::after { content: ""; position: absolute; left: 50%; top: 50%; width: 5px; height: 5px; border-radius: 50%;
  background: var(--crimson); transform: translate(-50%, -50%); box-shadow: var(--glow-accent); }

/* corner annotations */
.hero__anno { position: absolute; z-index: 5; display: flex; align-items: center; gap: 10px; }
.hero__anno--tl { top: clamp(96px, 13vh, 132px); left: clamp(24px, 4vw, 64px); }
.hero__anno--tr { top: clamp(96px, 13vh, 132px); right: clamp(24px, 4vw, 64px); }
.hero__anno .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--crimson); box-shadow: var(--glow-accent);
  animation: rec 2.4s steps(1) infinite; }
@keyframes rec { 0%,55% { opacity: 1; } 56%,100% { opacity: .15; } }

/* content — anchored bottom-left */
.hero__content { position: relative; z-index: 5; width: 100%; padding-bottom: clamp(52px, 9vh, 116px); }
.hero__content > * { opacity: 0; transform: translateY(24px);
  transition: opacity 1100ms var(--ease-out), transform 1100ms var(--ease-out); }
body.hero-in .hero__content > * { opacity: 1; transform: none; }
body.hero-in .hero__content > *:nth-child(1) { transition-delay: 360ms; }
body.hero-in .hero__content > *:nth-child(2) { transition-delay: 480ms; }
body.hero-in .hero__content > *:nth-child(3) { transition-delay: 620ms; }
body.hero-in .hero__content > *:nth-child(4) { transition-delay: 760ms; }
.hero__eyebrow { margin-bottom: 26px; }
.hero__title {
  font-family: var(--font-display); font-weight: var(--w-bold);
  font-size: calc(clamp(38px, 7.5vw, 122px) * var(--hero-scale));
  line-height: 0.88; letter-spacing: -0.035em; color: var(--porcelain);
  margin: 0; text-wrap: balance; text-shadow: 0 2px 40px rgba(0,0,0,0.45);
}
.hero__title .accent { color: var(--crimson); }
.hero__title .em { font-family: var(--font-editorial); font-style: italic; font-weight: 400; letter-spacing: -0.005em; }
.hero__sub { margin-top: 30px; max-width: 44ch; font-size: 19px; line-height: 1.55; color: var(--smoke); }
.hero__actions { display: flex; align-items: center; gap: 28px; margin-top: 40px; flex-wrap: wrap; }
.hero__btn { text-decoration: none; display: inline-block; }
.hero__micro { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--steel); }
.hero__expr { margin-top: 36px; display: flex; gap: 22px; }
.hero__expr span { font-family: var(--font-display); font-size: 12px; font-weight: var(--w-semi); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--steel); }
.hero__expr span + span::before { content: "·"; margin-right: 22px; color: var(--crimson); }

/* reused by About */
.portrait__tag {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--porcelain); background: rgba(11,12,14,0.55); backdrop-filter: blur(8px);
  border: 1px solid var(--border); padding: 6px 10px; border-radius: var(--r-xs);
}

.scrollcue { position: absolute; z-index: 5; bottom: 28px; right: clamp(24px, 4vw, 64px); display: flex; align-items: center; gap: 12px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--steel); }
.scrollcue__line { width: 56px; height: 1px; background: var(--border-strong); position: relative; overflow: hidden; }
.scrollcue__line::after { content: ""; position: absolute; inset: 0; width: 40%; background: var(--crimson);
  animation: cue 2.6s var(--ease-in-out) infinite; }
@keyframes cue { 0% { transform: translateX(-100%);} 60%,100% { transform: translateX(280%);} }

/* motion variants */
html[data-motion="low"] .hero__focus,
html[data-motion="low"] .hero__reticle { animation-duration: 30s; }
html[data-motion="low"] .hero__base { animation-duration: 46s; }
html[data-motion="off"] .hero__base { animation: none; transform: none; filter: grayscale(.22) contrast(1.02) brightness(.55); }
html[data-motion="off"] .hero__focus { animation: none; clip-path: circle(64% at 50% 28%); }
html[data-motion="off"] .hero__reticle { display: none; }
html[data-motion="off"] .hero__content > * { opacity: 1; transform: none; transition: none; }

/* ============================================================
 * EXPRESSIONS (three columns — SYNDICATE-style media tiles)
 * ============================================================ */
.expr { padding: var(--pad-section) 0; }
.expr__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; margin-bottom: 72px; }
.expr__head h2 {
  font-family: var(--font-display); font-weight: var(--w-bold);
  font-size: clamp(36px, 4.6vw, 68px); line-height: 1.02; letter-spacing: -0.025em; margin: 0; max-width: 18ch;
}
.expr__head p { max-width: 38ch; color: var(--steel); font-size: 17px; line-height: 1.6; margin: 0; }
.expr__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-grid); }
html[data-expr="stacked"] .expr__grid { grid-template-columns: 1fr; gap: 4px; }

.card {
  display: flex; flex-direction: column; gap: 22px;
  border-top: 1px solid var(--border-strong); padding-top: 26px;
}
html[data-expr="stacked"] .card {
  flex-direction: row; align-items: center; gap: 48px; padding: 40px 0; border-top: 1px solid var(--border);
}
.card__num { font-family: var(--font-mono); font-size: 11px; color: var(--crimson); letter-spacing: 0.06em; }
.card__media {
  position: relative; aspect-ratio: 4/5; border: 1px solid var(--border); border-radius: var(--r-sm);
  overflow: hidden; background: #0d0e11;
}
html[data-expr="stacked"] .card__media { width: 300px; flex: none; aspect-ratio: 4/3; }
.card__media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.2) contrast(1.05);
  transition: transform var(--dur-slow) var(--ease-out), filter var(--dur-slow) var(--ease-out); }
.card:hover .card__media img { transform: scale(1.04); filter: grayscale(0) contrast(1.05); }
.card__icon {
  position: absolute; top: 14px; left: 14px; z-index: 2; width: 40px; height: 40px;
  display: grid; place-items: center; border: 1px solid var(--border-strong); border-radius: var(--r-pill);
  background: rgba(11,12,14,0.6); backdrop-filter: blur(8px); color: var(--porcelain);
}
.card__icon svg { width: 18px; height: 18px; stroke-width: 1.25; }
.card__media .anno { position: absolute; bottom: 12px; left: 14px; z-index: 2; color: var(--steel); }
.card__body { display: flex; flex-direction: column; gap: 12px; }
html[data-expr="stacked"] .card__body { flex: 1; }
.card__role { font-family: var(--font-display); font-size: 12px; font-weight: var(--w-bold); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--crimson); }
.card__title { font-family: var(--font-display); font-size: 26px; font-weight: var(--w-bold); letter-spacing: -0.02em; line-height: 1.05; margin: 0; }
.card__desc { font-size: 16px; line-height: 1.6; color: var(--steel); margin: 0; max-width: 40ch; }

/* ============================================================
 * MANIFESTO
 * ============================================================ */
.manifesto { padding: var(--pad-section) 0; }
.manifesto__inner { display: flex; gap: 40px; align-items: stretch; max-width: 1080px; }
.manifesto blockquote {
  margin: 0; font-family: var(--font-editorial); font-style: italic;
  font-size: clamp(34px, 5vw, 76px); line-height: 1.12; color: var(--porcelain); text-wrap: pretty;
}
.manifesto blockquote .hl { color: var(--crimson); }
.manifesto__sign { margin-top: 40px; display: flex; align-items: center; gap: 16px; }
.manifesto__sign .anno { color: var(--fg-muted); }

/* ============================================================
 * WORK
 * ============================================================ */
.work { padding: var(--pad-section) 0; }
.work__head { margin-bottom: 64px; }
.work__head h2 { font-family: var(--font-display); font-weight: var(--w-bold); font-size: clamp(36px, 4.6vw, 68px); letter-spacing: -0.025em; margin: 18px 0 0; }
.work__grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 4px; }
.tile { position: relative; overflow: hidden; border: 1px solid var(--border); background: var(--charcoal); cursor: pointer; }
.tile img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.25) contrast(1.05); transition: transform var(--dur-slow) var(--ease-out), filter var(--dur-slow) var(--ease-out); }
.tile:hover img { transform: scale(1.04); filter: grayscale(0); }
.tile__ov { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 20px;
  background: linear-gradient(180deg, rgba(5,6,8,.1) 0%, transparent 35%, rgba(5,6,8,.75) 100%); }
.tile__series { align-self: flex-start; font-family: var(--font-display); font-size: 9px; font-weight: var(--w-bold); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--crimson);
  background: rgba(11,12,14,0.6); backdrop-filter: blur(8px); padding: 6px 10px; border-radius: var(--r-xs); border: 1px solid var(--border); }
.tile__cap { font-family: var(--font-display); font-size: 16px; font-weight: var(--w-semi); line-height: 1.25; color: var(--porcelain); }
.tile--a { grid-column: span 7; aspect-ratio: 16/10; }
.tile--b { grid-column: span 5; aspect-ratio: 16/10; }
.tile--c { grid-column: span 4; aspect-ratio: 4/5; }
.tile--d { grid-column: span 4; aspect-ratio: 4/5; }
.tile--e { grid-column: span 4; aspect-ratio: 4/5; }

/* ============================================================
 * SIGNATURE SERIES — editorial index / tracklist
 * ============================================================ */
.series { padding: var(--pad-section) 0; }
.series__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; margin-bottom: 48px; }
.series__head h2 { font-family: var(--font-display); font-weight: var(--w-bold); font-size: clamp(36px, 4.6vw, 68px); letter-spacing: -0.025em; margin: 16px 0 0; max-width: 16ch; }
.series__list { border-top: 1px solid var(--border-strong); }
.series__row {
  display: grid; grid-template-columns: 64px 1fr auto; align-items: center; gap: 28px;
  padding: 30px 8px; border-bottom: 1px solid var(--border);
  transition: background var(--dur-base) var(--ease-out), padding var(--dur-base) var(--ease-out);
}
.series__row:hover { background: rgba(255,255,255,0.018); padding-left: 20px; }
.series__row .n { font-family: var(--font-mono); font-size: 12px; color: var(--crimson); }
.series__row .name { font-family: var(--font-display); font-size: clamp(22px, 2.6vw, 34px); font-weight: var(--w-semi); letter-spacing: -0.02em; }
.series__row:hover .name { color: var(--porcelain); }
.series__row .desc { font-size: 14px; color: var(--fg-muted); text-align: right; max-width: 32ch; }

/* ============================================================
 * ABOUT (warm portrait)
 * ============================================================ */
.about { padding: var(--pad-section) 0; }
.about__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: var(--gap-grid); align-items: center; }
.about__portrait { position: relative; aspect-ratio: 4/5; border: 1px solid var(--border-strong); border-radius: var(--r-sm); overflow: hidden; background: #0d0e11; box-shadow: var(--shadow-cinematic); }
.about__portrait img { width: 100%; height: 100%; object-fit: cover; object-position: 40% 30%; }
.about__portrait .portrait__tag { }
.about__body { display: flex; flex-direction: column; }
.about__body h2 { font-family: var(--font-display); font-weight: var(--w-bold); font-size: clamp(30px, 3.6vw, 52px); letter-spacing: -0.025em; line-height: 1.08; margin: 22px 0 0; text-wrap: balance; }
.about__body p { font-size: 18px; line-height: 1.65; color: var(--steel); margin: 28px 0 0; max-width: 52ch; }
.about__body p .lead-first { color: var(--porcelain); }
.about__stats { display: flex; gap: 56px; margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--border); }
.about__stat .num { font-family: var(--font-display); font-weight: var(--w-bold); font-size: 30px; letter-spacing: -0.02em; }
.about__stat .lbl { font-family: var(--font-display); font-size: 11px; font-weight: var(--w-semi); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--steel); margin-top: 6px; }

/* ============================================================
 * JOIN THE FIELD (primary CTA)
 * ============================================================ */
.join { padding: var(--pad-section) 0; }
.join__panel {
  position: relative; border: 1px solid var(--border-strong); border-radius: var(--r-md);
  background: linear-gradient(160deg, #15171b 0%, #0a0b0d 70%);
  padding: clamp(48px, 7vw, 110px); overflow: hidden;
}
.join__panel::before { content: ""; position: absolute; inset: 0; opacity: .5; pointer-events: none;
  background-image: linear-gradient(to right, rgba(168,178,190,0.04) 1px, transparent 1px), linear-gradient(to bottom, rgba(168,178,190,0.04) 1px, transparent 1px);
  background-size: 64px 64px; -webkit-mask-image: radial-gradient(80% 120% at 100% 0%, #000, transparent 70%); mask-image: radial-gradient(80% 120% at 100% 0%, #000, transparent 70%); }
.join__inner { position: relative; max-width: 720px; }
.join__panel h2 { font-family: var(--font-display); font-weight: var(--w-bold); font-size: clamp(40px, 5.2vw, 84px); letter-spacing: -0.03em; line-height: 0.98; margin: 24px 0 0; text-wrap: balance; }
.join__panel h2 .em { font-family: var(--font-editorial); font-style: italic; font-weight: 400; color: var(--crimson); }
.join__panel p { font-size: 18px; line-height: 1.6; color: var(--steel); margin: 28px 0 0; max-width: 48ch; }
.join__form { display: flex; gap: 16px; margin-top: 44px; max-width: 540px; flex-wrap: wrap; }
.join__field { flex: 1; min-width: 240px; display: flex; flex-direction: column; gap: 8px; }
.join__field label { font-family: var(--font-display); font-size: 10px; font-weight: var(--w-bold); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--steel); }
.join__field input { font-family: var(--font-body); font-size: 16px; color: var(--porcelain); background: transparent; border: 0; border-bottom: 1px solid var(--border-strong); padding: 12px 0; outline: none; transition: border-color var(--dur-base) var(--ease-out); }
.join__field input::placeholder { color: var(--fg-subtle); }
.join__field input:focus { border-color: var(--crimson); }
.btn {
  font-family: var(--font-display); font-size: 12px; font-weight: var(--w-semi); letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase; padding: 18px 32px; border-radius: var(--r-xs); border: 1px solid transparent;
  background: var(--crimson); color: var(--porcelain); cursor: pointer; line-height: 1; align-self: flex-end;
  transition: background var(--dur-base) var(--ease-out); white-space: nowrap;
}
.btn:hover { background: var(--crimson-deep); }
.btn:active { opacity: .85; }
.join__note { margin-top: 22px; font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.04em; }
.join__confirm { display: none; }
.join.is-joined .join__form { display: none; }
.join.is-joined .join__confirm { display: block; }
.join__confirm .q { font-family: var(--font-editorial); font-style: italic; font-size: clamp(26px, 3vw, 40px); color: var(--crimson); line-height: 1.25; margin: 28px 0 0; max-width: 22ch; }
.join__confirm .b { font-size: 16px; color: var(--steel); margin-top: 18px; }

/* ============================================================
 * FOOTER
 * ============================================================ */
.foot { padding: 96px 0 56px; border-top: 1px solid var(--border); margin-top: 40px; }
.foot__top { display: flex; justify-content: space-between; align-items: flex-start; gap: 48px; flex-wrap: wrap; }
.foot__brand { font-family: var(--font-editorial); font-size: clamp(48px, 9vw, 140px); letter-spacing: 0.06em; text-transform: uppercase; color: var(--porcelain); line-height: .9; }
.foot__cols { display: flex; gap: 72px; flex-wrap: wrap; }
.foot__col { display: flex; flex-direction: column; gap: 14px; }
.foot__col .h { font-family: var(--font-display); font-size: 10px; font-weight: var(--w-bold); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--fg-subtle); margin-bottom: 4px; }
.foot__col a { font-size: 15px; color: var(--steel); transition: color var(--dur-base) var(--ease-out); }
.foot__col a:hover { color: var(--porcelain); }
.foot__meta { display: flex; justify-content: space-between; align-items: center; gap: 24px; margin-top: 80px; padding-top: 28px; border-top: 1px solid var(--border); flex-wrap: wrap; }
.foot__meta span { font-family: var(--font-display); font-size: 11px; font-weight: var(--w-semi); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--fg-subtle); }

/* ============================================================
 * REVEAL ANIMATION (motion driven by [data-motion])
 * ============================================================ */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity var(--dur-cine) var(--ease-out), transform var(--dur-cine) var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }
html[data-motion="low"] .reveal { transform: translateY(14px); transition-duration: var(--dur-base); }
html[data-motion="off"] .reveal { opacity: 1; transform: none; transition: none; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; }
  .scrollcue__line::after { animation: none; }
  .hero__base { animation: none !important; transform: none !important; filter: grayscale(.22) contrast(1.02) brightness(.55); }
  .hero__focus { animation: none !important; clip-path: circle(64% at 50% 28%) !important; }
  .hero__reticle { display: none; }
  .hero__content > * { opacity: 1 !important; transform: none !important; }
  html { scroll-behavior: auto; }
  .belief { opacity: 1 !important; transform: none !important; }
}

/* ============================================================
 * RECOGNITION — full-bleed warm portrait (ember mode)
 * ============================================================ */
.recognition {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--obsidian);
}
.recognition__media { position: absolute; inset: 0; z-index: 0; }
.recognition__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 28%;
  filter: contrast(1.05) saturate(1.15) brightness(0.92);
  transform-origin: center center;
  will-change: transform;
}
.recognition__scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(11,12,14,0.91) 0%, rgba(11,12,14,0.78) 28%, rgba(11,12,14,0.32) 52%, rgba(11,12,14,0.0) 72%),
    linear-gradient(180deg, rgba(11,12,14,0.38) 0%, transparent 15%, transparent 75%, rgba(11,12,14,0.6) 100%);
}
.recognition .wrap { position: relative; z-index: 2; padding: var(--pad-section) 0; }
.recognition__content { max-width: 62ch; }
.recognition__eyebrow { margin-bottom: 40px; }
.recognition h2 {
  font-family: var(--font-display);
  font-weight: var(--w-bold);
  font-size: clamp(32px, 5vw, 78px);
  letter-spacing: -0.03em; line-height: 1.02;
  margin: 0 0 52px; text-wrap: balance; color: var(--porcelain);
}
.recognition__body { display: flex; flex-direction: column; gap: 22px; }
.recognition__body p { font-size: 19px; line-height: 1.68; color: var(--smoke); margin: 0; max-width: 54ch; }
.recognition__body em { font-style: italic; color: var(--porcelain); }
.recognition__body strong { color: var(--porcelain); font-weight: var(--w-semi); }
.recognition__sacred { margin-top: 80px; padding-top: 56px; border-top: 1px solid rgba(210,116,90,0.32); }
.recognition__sacred p {
  font-family: var(--font-editorial);
  font-size: clamp(30px, 4.5vw, 68px);
  font-style: italic; line-height: 1.1;
  color: var(--ember); margin: 0;
  text-shadow: 0 2px 28px rgba(210,116,90,0.28);
}

/* ============================================================
 * WORLDVIEW — stacked beliefs
 * ============================================================ */
.worldview { padding: var(--pad-section) 0; }
.worldview__head { display: flex; align-items: stretch; gap: 32px; margin-bottom: 80px; }
.worldview__head h2 {
  font-family: var(--font-display); font-weight: var(--w-bold);
  font-size: clamp(26px, 3.2vw, 48px);
  letter-spacing: -0.025em; line-height: 1.08; margin: 0;
}
.worldview__beliefs { border-top: 1px solid var(--border-strong); }
.belief {
  display: grid; grid-template-columns: 56px 1fr;
  gap: 32px; padding: 56px 0;
  border-bottom: 1px solid var(--border);
  align-items: start;
  opacity: 0; transform: translateY(18px);
  transition: opacity var(--dur-cine) var(--ease-out), transform var(--dur-cine) var(--ease-out);
}
.belief.in { opacity: 1; transform: none; }
.belief__n {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; color: var(--crimson);
  padding-top: 8px; line-height: 1;
}
.belief__text {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.5vw, 36px);
  font-weight: var(--w-regular);
  line-height: 1.32; letter-spacing: -0.02em;
  color: var(--porcelain); margin: 0;
}
.belief__accent { color: var(--crimson); }

/* ============================================================
 * THE UNDEFINED — movement section
 * ============================================================ */
.undefined-section {
  padding: var(--pad-section) 0;
  background: var(--charcoal);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.undefined__inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--gap-grid); align-items: start;
}
.undefined__left { position: sticky; top: 140px; }
.undefined__left .eyebrow { margin-bottom: 36px; }
.undefined__name {
  font-family: var(--font-editorial); font-style: italic;
  font-size: clamp(52px, 8.5vw, 132px);
  line-height: 0.92; letter-spacing: -0.02em;
  margin: 0; color: var(--porcelain);
}
.undefined__right { display: flex; flex-direction: column; gap: 28px; padding-top: 4px; }
.undefined__right p { font-size: 19px; line-height: 1.68; color: var(--steel); margin: 0; }
.undefined__right strong { color: var(--porcelain); }
.undefined__toomuch {
  display: flex; flex-direction: column; gap: 4px;
  padding: 28px 32px;
  border-left: 2px solid var(--crimson);
  margin: 4px 0;
}
.undefined__toomuch span {
  font-family: var(--font-display);
  font-size: clamp(15px, 1.5vw, 22px);
  line-height: 1.6; color: var(--smoke); letter-spacing: -0.01em;
}
.undefined__rally {
  margin-top: 16px; padding-top: 40px;
  border-top: 1px solid var(--border-strong);
  display: flex; flex-direction: column; gap: 6px;
}
.undefined__rally span {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.8vw, 26px);
  font-weight: var(--w-regular); letter-spacing: -0.02em; color: var(--steel);
}
.undefined__rally strong {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.8vw, 42px);
  font-weight: var(--w-bold); letter-spacing: -0.025em; color: var(--porcelain);
}

/* ============================================================
 * ABOUT — additional copy styles
 * ============================================================ */
.about__honest { color: var(--steel) !important; }
.fg-strong { color: var(--porcelain); font-weight: var(--w-semi); }
.about__cta { margin-top: 44px; }
.about__cta .btn { text-decoration: none; display: inline-block; }

/* ============================================================
 * RESPONSIVE — new sections
 * ============================================================ */
@media (max-width: 1080px) {
  .undefined__inner { grid-template-columns: 1fr; }
  .undefined__left { position: static; }
  .undefined__name { font-size: clamp(52px, 12vw, 96px); }
  .recognition__body p { font-size: 17px; }
}
@media (max-width: 720px) {
  .recognition h2 { font-size: clamp(26px, 8vw, 48px); }
  .recognition__sacred p { font-size: clamp(24px, 7vw, 46px); }
  .belief { grid-template-columns: 36px 1fr; gap: 16px; padding: 36px 0; }
  .undefined__toomuch { padding: 20px; }
}

/* ============================================================
 * RESPONSIVE
 * ============================================================ */
@media (max-width: 1080px) {
  .expr__grid { grid-template-columns: 1fr; gap: 4px; }
  html:not([data-expr="stacked"]) .card { flex-direction: row; align-items: center; gap: 32px; padding: 32px 0; border-top: 1px solid var(--border); }
  html:not([data-expr="stacked"]) .card__media { width: 220px; flex: none; aspect-ratio: 4/3; }
  .about__grid { grid-template-columns: 1fr; }
  .work__grid { grid-template-columns: repeat(6, 1fr); }
  .tile--a, .tile--b { grid-column: span 6; }
  .tile--c, .tile--d, .tile--e { grid-column: span 3; }
}
@media (max-width: 720px) {
  .wrap, .wrap--wide { width: calc(100% - 40px); }
  .nav__links { display: none; }
  html[data-nav="minimal"] .nav__inner { padding-bottom: 14px; }
  .hero__title { font-size: calc(clamp(32px, 11vw, 80px) * var(--hero-scale)); }
  .hero__actions { flex-direction: column; align-items: flex-start; gap: 16px; }
  .hero__anno--tr { display: none; }
  .scrollcue { display: none; }
  .series__row { grid-template-columns: 40px 1fr; }
  .series__row .desc { display: none; }
  .work__grid { grid-template-columns: 1fr; }
  .tile { grid-column: span 1 !important; }
  .card { flex-direction: column !important; align-items: stretch !important; }
  .card__media { width: 100% !important; aspect-ratio: 4/3 !important; }
  .foot__top { flex-direction: column; }
}

/* ── Footer subscribe block ── */
.foot__subscribe {
  border-bottom: 0.5px solid var(--border);
  padding: 80px 0 72px;
  text-align: center;
}
.foot__subscribe-inner {
  max-width: 560px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.foot__subscribe-title {
  font-family: var(--f-display);
  font-size: clamp(24px, 4vw, 36px);
  font-weight: 500;
  color: var(--off-white);
  line-height: 1.2;
  margin: 0;
}
.foot__subscribe-sub {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.7;
  margin: 0;
}
@media (max-width: 720px) {
  .foot__subscribe { padding: 56px 0 48px; }
}
