/* =========================================================
   alexbogomolov.com — Run 1
   Sits on top of tokens.css. No bold weights anywhere.
   One gold accent per view.
   ========================================================= */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; background: var(--canvas); color: var(--body); }
body {
  font-family: var(--font-serif);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button { cursor: pointer; font: inherit; color: inherit; background: transparent; border: 0; padding: 0; }
a { color: inherit; }

/* Heading reset — brand rule: never weight 700. */
h1, h2, h3, h4, h5, h6 { font-weight: var(--w-display); margin: 0; }

::selection { background: var(--accent); color: var(--canvas); }

/* =========================================================
   TOP NAV — invisible at scroll 0, fades in on scroll
   ========================================================= */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-height);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 0 var(--sp-xl);
  z-index: 50;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity var(--dur-med) var(--ease-out),
              transform var(--dur-med) var(--ease-out);
}
.nav.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.nav__wordmark {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 13px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
}
.nav__links {
  display: flex;
  gap: 36px;
  align-items: center;
}
.nav__link {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 11px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
  position: relative;
  padding: 4px 0;
}
.nav__link:hover { color: var(--ink); }
.nav__link.is-active { color: var(--ink); }
.nav__link.is-active::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  bottom: -2px;
  height: 1px;
  background: var(--ink);
}

/* =========================================================
   SHARED — section rhythm and copy widths
   ========================================================= */
.section {
  padding: var(--sp-section) var(--sp-xxl);
}
.section--narrow {
  max-width: 880px;
  margin: 0 auto;
}
.section--reading {
  max-width: 720px;
  margin: 0 auto;
}
.section--list {
  max-width: var(--max-content);
  margin: 0 auto;
}

/* =========================================================
   SPINNER — used in async form submit buttons to signal in-flight
   ========================================================= */
.spinner {
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spinner-rot 0.7s linear infinite;
  vertical-align: -1px;
  margin-left: 4px;
}
@keyframes spinner-rot {
  to { transform: rotate(360deg); }
}
button[disabled] {
  cursor: wait;
  opacity: 0.7;
}

/* =========================================================
   IN-DEVELOPMENT — slim pipeline list (Tier-2 below the slate)
   ========================================================= */
.dev-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--hairline);
}
.dev-row {
  display: grid;
  grid-template-columns: minmax(220px, 280px) 1fr auto;
  gap: 32px;
  padding: 28px 0;
  border-bottom: 1px solid var(--hairline);
  align-items: start;
}
.dev-row__title-block { display: grid; gap: 6px; }
.dev-row__title {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 22px;
  line-height: 1.2;
  margin: 0;
  color: var(--ink);
  letter-spacing: 0.3px;
}
.dev-row__genre {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.dev-row__logline {
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.55;
  color: var(--body);
  margin: 0;
}
.dev-row__status {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  white-space: nowrap;
  padding-top: 4px;
}
.dev-list__note {
  margin: 32px 0 0;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted);
}
.dev-list__note a {
  color: var(--body-strong);
  text-decoration: none;
  border-bottom: 1px solid var(--hairline-strong);
  padding-bottom: 1px;
  transition: color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
}
.dev-list__note a:hover { color: var(--ink); border-bottom-color: var(--ink); }

@media (max-width: 480px) {
  /* === Phone-specific layout overrides ===================== */
  .section { padding: 80px var(--sp-lg); }
  .featured-in { padding: 36px var(--sp-lg); }
  .featured-in__list { row-gap: 8px; }
  .featured-in__list li + li::before { margin: 0 8px; }
  .footer { padding: 64px var(--sp-lg) 32px; }
  .footer__cols { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer__bottom { flex-direction: column; gap: 12px; align-items: flex-start; }
  .nav { padding: 0 var(--sp-lg); }
  .nav__links { gap: 16px; }
  .nav__link { font-size: 10px; letter-spacing: 1.5px; }
  .nav__wordmark { font-size: 11px; letter-spacing: 3px; }
  /* Page-hero on phones — tighter padding, smaller display title */
  .page-hero { padding: 120px var(--sp-lg) 40px; min-height: auto; }
  .page-hero__title { font-size: clamp(36px, 9vw, 56px); }
  /* Dev-list — already stacks via 720px, this just tightens spacing */
  .dev-row { padding: 22px 0; }
}

@media (max-width: 720px) {
  .dev-row {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 22px 0;
  }
  .dev-row__status { padding-top: 0; }
}

/* =========================================================
   FEATURED-IN — slim press-credibility strip
   ========================================================= */
.featured-in {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 56px var(--sp-xxl);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  text-align: center;
}
.featured-in__label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 20px;
}
.featured-in__list {
  display: flex;
  align-items: center;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
  row-gap: 12px;
}
.featured-in__list li {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.featured-in__list a {
  color: var(--body-strong);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
.featured-in__list a:hover { color: var(--ink); }
.featured-in__list li + li::before {
  content: '·';
  color: var(--muted-soft);
  margin: 0 16px;
}

.eyebrow {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 11px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.eyebrow::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--hairline-strong);
}

.section__heading {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1.1;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--ink);
  margin: 24px 0 0;
}

/* =========================================================
   HERO — homepage. Text-only on pure black, 100vh.
   ========================================================= */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-section) var(--sp-xxl);
  background: var(--canvas);
  overflow: hidden;
}
.hero__inner {
  max-width: 920px;
  text-align: center;
}
.hero__sub {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 56px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.hero__sub::before,
.hero__sub::after {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--hairline-strong);
}
.hero__title {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(32px, 4.4vw, 60px);
  line-height: 1.18;
  letter-spacing: 1.5px;
  text-transform: none; /* keep elegant, not monumental */
  color: var(--ink);
  margin: 0 0 56px;
  text-wrap: balance;
}
.hero__title em {
  font-style: normal;
  color: var(--accent);
}

.hero__cta {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  height: 48px;
  padding: 0 32px;
  border-radius: var(--r-pill);
  border: 1px solid var(--accent);
  color: var(--accent);
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 12px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
}
.hero__cta:hover { color: var(--accent-hover); border-color: var(--accent-hover); }
.hero__cta .arrow {
  font-family: var(--font-mono);
  transition: transform var(--dur-med) var(--ease-out);
}
.hero__cta:hover .arrow { transform: translateY(3px); }

/* The single gold accent on the hero: a small geometric mark bottom-left */
.hero__mark {
  position: absolute;
  left: var(--sp-xxl);
  bottom: var(--sp-xxl);
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: flex-start;
}
.hero__mark-dot {
  width: 6px;
  height: 6px;
  background: var(--accent);
  border-radius: 9999px;
}
.hero__mark-line {
  width: 40px;
  height: 1px;
  background: var(--accent);
  opacity: 0.6;
}
.hero__mark-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--muted-soft);
  margin-top: 4px;
}

/* Wordmark anchor — top-left of the hero, sits behind nav until scroll */
.hero__wordmark {
  position: absolute;
  top: var(--sp-xxl);
  left: var(--sp-xxl);
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 13px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
}
.hero__index {
  position: absolute;
  top: var(--sp-xxl);
  right: var(--sp-xxl);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--muted);
}

/* =========================================================
   MANIFESTO — narrow column of EB Garamond
   ========================================================= */
.manifesto__heading {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(40px, 4.4vw, 56px);
  line-height: 1.1;
  letter-spacing: 2.5px;
  text-transform: none;
  color: var(--ink);
  margin: 0 0 48px;
}
.manifesto__body {
  font-family: var(--font-serif);
  font-weight: var(--w-body);
  font-size: 21px;
  line-height: 1.65;
  color: var(--body-strong);
  margin: 0;
}
.manifesto__body p { margin: 0 0 28px; }
.manifesto__body p:last-child { margin-bottom: 0; }

.soft-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 48px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  padding-bottom: 4px;
  border-bottom: 1px solid transparent;
  transition: color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
}
.soft-link:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.soft-link .arrow {
  transition: transform var(--dur-med) var(--ease-out);
}
.soft-link:hover .arrow { transform: translateX(4px); }

/* =========================================================
   SLATE — 3-column grid of film cards
   ========================================================= */
.slate__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 64px;
  gap: 32px;
}
.slate__title {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 14px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0;
}
.slate__count {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.slate__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-xxl);
}
.film-card {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-top: 32px;
  border-top: 1px solid var(--hairline-strong);
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: border-color var(--dur-med) var(--ease-out);
}
.film-card:hover { border-top-color: var(--ink); }
.film-card__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.film-card__year { color: var(--muted); }
.film-card__sep {
  width: 4px; height: 4px;
  background: var(--muted-soft);
  border-radius: 9999px;
}
.film-card__status { color: var(--ink); }
.film-card__title {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 32px;
  line-height: 1.1;
  letter-spacing: 1px;
  color: var(--ink);
  margin: 0;
  min-height: 80px;
}
.film-card__desc {
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.55;
  color: var(--body);
  margin: 0;
}
.film-card__callout {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.7;
  margin-top: auto;
  padding-top: 12px;
}
.film-card__view {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--muted);
  padding-top: 8px;
  transition: color var(--dur-fast) var(--ease-out);
}
.film-card:hover .film-card__view { color: var(--ink); }
.film-card__view .arrow {
  transition: transform var(--dur-med) var(--ease-out);
}
.film-card:hover .film-card__view .arrow { transform: translateX(4px); }

/* =========================================================
   WRITING LIST — publication-style index rows
   ========================================================= */
.writing-list {
  border-top: 1px solid var(--hairline);
}
.writing-row {
  display: grid;
  grid-template-columns: 120px 1fr 160px;
  gap: 32px;
  align-items: baseline;
  padding: 28px 0;
  border-bottom: 1px solid var(--hairline);
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: padding var(--dur-med) var(--ease-out);
}
.writing-row:hover { padding-left: 16px; }
.writing-row__date {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted-soft);
}
.writing-row__main {
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
}
.writing-row__title {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 22px;
  line-height: 1.25;
  letter-spacing: 0.5px;
  color: var(--ink);
  margin: 0;
  position: relative;
  display: inline-block;
  align-self: flex-start;
}
.writing-row__title::after {
  content: '';
  position: absolute;
  left: 0; right: 100%;
  bottom: -4px;
  height: 1px;
  background: var(--accent);
  transition: right var(--dur-med) var(--ease-out);
}
.writing-row:hover .writing-row__title::after { right: 0; }
.writing-row__teaser {
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.55;
  color: var(--muted);
  margin: 0;
  max-width: 540px;
}
.writing-row__tag {
  justify-self: end;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  padding: 6px 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
}

.writing-cta {
  margin-top: 56px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

/* =========================================================
   NEWSLETTER — centered form, accent line on focus
   ========================================================= */
.newsletter {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}
.newsletter__heading {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(32px, 3.6vw, 44px);
  line-height: 1.1;
  letter-spacing: 1.5px;
  text-transform: none;
  color: var(--ink);
  margin: 0 0 24px;
}
.newsletter__body {
  font-family: var(--font-serif);
  font-size: 19px;
  line-height: 1.55;
  color: var(--body-strong);
  margin: 0 0 56px;
}
.newsletter__form {
  display: flex;
  flex-direction: column;
  gap: 32px;
  text-align: left;
}
.newsletter__email {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--hairline-strong);
  border-radius: 0;
  padding: 14px 0;
  height: 48px;
  width: 100%;
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 19px;
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.newsletter__email::placeholder { color: var(--muted-soft); font-style: italic; }
.newsletter__email:focus { border-bottom-color: var(--accent); }

.newsletter__options {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.opt {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 16px;
  cursor: pointer;
  padding: 4px 0;
}
.opt__check {
  position: relative;
  width: 16px;
  height: 16px;
  border: 1px solid var(--hairline-strong);
  margin-top: 3px;
  transition: border-color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.opt input { position: absolute; opacity: 0; pointer-events: none; }
.opt input:checked + .opt__check {
  border-color: var(--accent);
}
.opt input:checked + .opt__check::after {
  content: '';
  position: absolute;
  inset: 3px;
  background: var(--accent);
}
.opt:hover .opt__check { border-color: var(--muted); }
.opt__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 6px;
}
.opt__desc {
  font-family: var(--font-serif);
  font-size: 14px;
  line-height: 1.5;
  color: var(--muted);
  margin: 0;
}

.newsletter__submit {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  height: 48px;
  padding: 0 36px;
  border-radius: var(--r-pill);
  border: 1px solid var(--accent);
  background: transparent;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
}
.newsletter__submit:hover {
  border-color: var(--accent-hover);
  color: var(--accent-hover);
}

/* Single-subscription variant — centered, prominent block button. */
.newsletter__form--single { align-items: stretch; gap: 28px; }
.newsletter__submit--block {
  align-self: stretch;
  justify-content: center;
  padding: 18px 24px;
  font-size: 12px;
}

.newsletter__legal {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted-soft);
  text-align: center;
  margin-top: 16px;
}

/* =========================================================
   FOOTER — 4 columns
   ========================================================= */
.footer {
  border-top: 1px solid var(--hairline);
  padding: 80px var(--sp-xxl) 40px;
}
.footer__inner {
  max-width: var(--max-content);
  margin: 0 auto;
}
.footer__cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 48px;
}
.footer__col-h {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 10px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--hairline);
}
.footer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.footer__link {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--body);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
.footer__link:hover { color: var(--ink); }
.footer__link--static {
  color: var(--muted);
  cursor: default;
}
.footer__link--static:hover { color: var(--muted); }

.footer__contact-line {
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.6;
  color: var(--body);
  margin: 0;
}
.footer__contact-line a {
  color: var(--body);
  text-decoration: none;
  border-bottom: 1px solid var(--hairline-strong);
  transition: color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
}
.footer__contact-line a:hover { color: var(--ink); border-bottom-color: var(--ink); }
.footer__contact-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}
.footer__contact-block + .footer__contact-block { margin-top: 20px; }

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 64px;
  padding-top: 32px;
  border-top: 1px solid var(--hairline);
}
.footer__wordmark {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 12px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--muted);
}
.footer__copy {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--muted);
}

/* =========================================================
   PAGE HERO STRIP (40 / 60vh on inner pages)
   ========================================================= */
.page-hero {
  min-height: 60vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 160px var(--sp-xxl) 80px;
  max-width: var(--max-content);
  margin: 0 auto;
  position: relative;
}
.page-hero--short { min-height: 40vh; }
.page-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 28px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.page-hero__eyebrow::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--hairline-strong);
}
.page-hero__title {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(56px, 8vw, 112px);
  line-height: 0.95;
  letter-spacing: 0.5px;
  color: var(--ink);
  margin: 0 0 24px;
  text-transform: none;
}
.page-hero__sub {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  max-width: 640px;
  line-height: 1.7;
  margin: 0;
}

/* =========================================================
   ABOUT — long-form reading
   ========================================================= */
.about-section {
  padding: var(--sp-section) var(--sp-xxl);
  max-width: 680px;
  margin: 0 auto;
}
.about-section + .about-section {
  padding-top: 0;
}
.about-section__heading {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(28px, 3vw, 36px);
  line-height: 1.15;
  letter-spacing: 1.2px;
  color: var(--ink);
  margin: 0 0 40px;
  text-transform: none;
}
.about-section__body {
  font-family: var(--font-serif);
  font-size: 21px;
  line-height: 1.7;
  color: var(--body-strong);
  margin: 0;
}
.about-section__body p { margin: 0 0 24px; }
.about-section__body p:last-child { margin-bottom: 0; }

.epigraph {
  position: relative;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.5;
  color: var(--body-strong);
  max-width: 540px;
  margin: 0 auto 56px;
  padding: 24px 0 24px 48px;
}
.epigraph::before {
  content: '\201C';
  position: absolute;
  left: 0;
  top: -8px;
  font-family: var(--font-serif);
  font-size: 96px;
  line-height: 1;
  color: var(--accent);
  font-style: normal;
}
.epigraph__source {
  display: block;
  margin-top: 24px;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 10px;
  font-weight: var(--w-body);
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--muted);
}
.epigraph__source a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  transition: color var(--dur-fast) var(--ease-out);
}
.epigraph__source a:hover { color: var(--ink); }

.about-footer-frag {
  max-width: 680px;
  margin: 0 auto;
  padding: 80px var(--sp-xxl) 120px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  border-top: 1px solid var(--hairline);
}
.about-footer-frag__link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
  width: fit-content;
}
.about-footer-frag__link:hover { color: var(--ink); }

/* =========================================================
   WRITING INDEX — filter chips
   ========================================================= */
.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  align-items: center;
  margin: 64px 0 32px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.chip {
  padding: 6px 16px;
  cursor: pointer;
  color: var(--muted);
  transition: color var(--dur-fast) var(--ease-out);
}
.chip:first-child { padding-left: 0; }
.chip:hover { color: var(--ink); }
.chip.is-active { color: var(--accent); }
.chips__sep {
  display: inline-block;
  width: 1px;
  height: 12px;
  background: var(--hairline-strong);
}

.writing-footer {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 80px var(--sp-xxl) 120px;
  max-width: var(--max-content);
  margin: 0 auto;
  border-top: 1px solid var(--hairline);
  margin-top: 80px;
}
.writing-footer__rss,
.writing-footer__subscribe {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
.writing-footer__rss:hover,
.writing-footer__subscribe:hover { color: var(--ink); }

/* =========================================================
   VENTURES
   ========================================================= */
.venture {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 var(--sp-xxl);
  border-top: 1px solid var(--hairline-strong);
  padding-top: 64px;
}
.venture__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 32px;
}
.venture__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.venture__status {
  display: inline-block;
  padding: 6px 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--ink);
}
.venture__title {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(56px, 7vw, 96px);
  line-height: 1;
  letter-spacing: 1px;
  color: var(--ink);
  margin: 0 0 40px;
  text-transform: none;
}
.venture__body {
  font-family: var(--font-serif);
  font-size: 19px;
  line-height: 1.7;
  color: var(--body-strong);
  max-width: 640px;
  margin: 0 0 56px;
}
.venture__body p { margin: 0 0 24px; }
.venture__body p:last-child { margin-bottom: 0; }
.venture__visit {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  height: 48px;
  padding: 0 32px;
  border-radius: var(--r-pill);
  border: 1px solid var(--accent);
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
}
.venture__visit:hover { color: var(--accent-hover); border-color: var(--accent-hover); }
.venture__visit .arrow { transition: transform var(--dur-med) var(--ease-out); }
.venture__visit:hover .arrow { transform: translateX(4px); }

.venture-placeholder {
  max-width: 880px;
  margin: 0 auto;
  padding: 120px var(--sp-xxl) 160px;
  border-top: 1px dashed var(--hairline);
  margin-top: 120px;
}
.venture-placeholder__note {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted-soft);
  margin: 0;
}

/* =========================================================
   PRESS
   ========================================================= */
.press-section {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 var(--sp-xxl);
}
.press-section + .press-section {
  margin-top: 96px;
}
.press-section__label {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 10px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 32px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--hairline);
}
.press-bio {
  font-family: var(--font-serif);
  font-size: 19px;
  line-height: 1.7;
  color: var(--body-strong);
  margin: 0;
  max-width: 640px;
}
.press-bio p { margin: 0 0 20px; }
.press-bio p:last-child { margin-bottom: 0; }

.press-table {
  width: 100%;
  border-collapse: collapse;
}
.press-table th,
.press-table td {
  text-align: left;
  padding: 24px 0;
  border-bottom: 1px solid var(--hairline);
  vertical-align: baseline;
}
.press-table th {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--w-body);
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  padding-bottom: 12px;
}
.press-table td:nth-child(1) {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 22px;
  letter-spacing: 0.5px;
  color: var(--ink);
  width: 40%;
}
.press-table td:nth-child(2) {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted);
  width: 30%;
}
.press-table td:nth-child(3) {
  text-align: right;
  width: 30%;
}
.press-table__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--hairline-strong);
  transition: border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
}
.press-table__link:hover { color: var(--accent); border-bottom-color: var(--accent); }

.press-contact__email {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: clamp(28px, 3.4vw, 40px);
  letter-spacing: 0.5px;
  color: var(--ink);
  text-decoration: none;
  display: inline-block;
  border-bottom: 1px solid var(--hairline-strong);
  padding-bottom: 6px;
  margin-bottom: 24px;
  transition: color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
}
.press-contact__email:hover { color: var(--accent); border-bottom-color: var(--accent); }
.press-contact__note {
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.6;
  color: var(--muted);
  margin: 0;
  max-width: 480px;
}

.headshot {
  display: block;
  width: 320px;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center top;
  background: #0a0a0a;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
}
.headshot-caption {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--muted);
}
.headshot-caption a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--hairline-strong);
  padding-bottom: 2px;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.headshot-caption a:hover { border-bottom-color: var(--ink); }

/* =========================================================
   ENTRY ANIMATION — fade up
   ========================================================= */
.fade-in {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity var(--dur-slow) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
}
.fade-in.is-in {
  opacity: 1;
  transform: translateY(0);
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 920px) {
  .nav { padding: 0 var(--sp-lg); }
  .nav__links { gap: 20px; }
  .nav__link { font-size: 10px; letter-spacing: 1.8px; }
  .section { padding: 80px var(--sp-lg); }
  .hero { padding: 80px var(--sp-lg); }
  .hero__wordmark, .hero__index { top: var(--sp-lg); }
  .hero__wordmark { left: var(--sp-lg); }
  .hero__index { right: var(--sp-lg); }
  .hero__mark { left: var(--sp-lg); bottom: var(--sp-lg); }
  .slate__grid { grid-template-columns: 1fr; gap: var(--sp-xl); }
  .film-card__title { min-height: auto; }
  .writing-row { grid-template-columns: 1fr; gap: 8px; }
  .writing-row__tag { justify-self: start; margin-top: 12px; }
  .footer { padding: 56px var(--sp-lg) 32px; }
  .footer__cols { grid-template-columns: 1fr 1fr; gap: 40px; }
  .footer__bottom { flex-direction: column; gap: 16px; align-items: flex-start; }
  .page-hero { padding: 140px var(--sp-lg) 56px; }
  .about-section { padding: 80px var(--sp-lg); }
  .venture, .press-section { padding: 0 var(--sp-lg); }
  .venture-placeholder { padding: 80px var(--sp-lg) 120px; }
  .writing-footer { padding: 56px var(--sp-lg) 80px; flex-direction: column; gap: 24px; align-items: flex-start; }
  .epigraph { padding-left: 32px; }
  .epigraph::before { font-size: 72px; }
}
