:root {
  --ink: #2c2c2c;
  --paper: #fdf5cc;
  --orange: #e36627;
  --white: #ffffff;
  --gray: #e6e6e6;
  --line: rgba(255, 255, 255, .28);
  --signal: var(--orange);
  --serif: Georgia, "Times New Roman", serif;
  --sans: Arial, Helvetica, sans-serif;
  --header-height: 74px;
  --kpup-rail-width: clamp(92px, 8vw, 126px);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--ink);
  color: var(--white);
  font-family: var(--sans);
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
body.menu-is-open { overflow: hidden; }
.elementor-document-shell { min-height: 60vh; }
.elementor-document-shell > .elementor { width: 100%; }
.elementor-widget-kpup-timeline,
.elementor-widget-kpup-timeline > .elementor-widget-container { overflow: visible; }
.elementor-editor-active .timeline-rail { position: absolute; }
.kpup-elementor-canvas { margin: 0; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
::selection { background: var(--signal); color: var(--white); }

.skip-link {
  position: fixed;
  z-index: 1000;
  top: 10px;
  left: 10px;
  padding: 10px 14px;
  background: var(--white);
  color: var(--ink);
  transform: translateY(-150%);
}
.skip-link:focus { transform: translateY(0); }

.site-header {
  position: fixed;
  z-index: 100;
  inset: 0 0 auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  min-height: var(--header-height);
  padding: 14px clamp(18px, 3vw, 52px);
  color: var(--white);
  transition: background .35s ease, border-color .35s ease;
}
.site-header.is-scrolled {
  background: rgba(44, 44, 44, .86);
  border-bottom: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(16px);
}
.site-brand {
  grid-column: 2;
  display: block;
  max-width: 170px;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: -.03em;
  text-align: center;
}
.site-brand img { max-height: 44px; width: auto; }
.site-brand .custom-logo-link { display: block; }
.site-navigation { grid-column: 1; grid-row: 1; }
.site-navigation ul {
  display: flex;
  align-items: center;
  gap: clamp(18px, 2.5vw, 42px);
  margin: 0;
  padding: 0;
  list-style: none;
}
.site-navigation a {
  position: relative;
  padding: 8px 0;
  font-size: 12px;
  letter-spacing: .09em;
  text-transform: uppercase;
}
.site-navigation a::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 3px;
  left: 0;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .25s ease;
}
.site-navigation a:hover::after,
.site-navigation a:focus-visible::after { transform: scaleX(1); transform-origin: left; }
.menu-toggle { display: none; }

@media (min-width: 901px) {
  body:has([data-timeline]) .site-navigation { margin-left: calc(var(--kpup-rail-width) + 10px); }
}

.timeline { --rail-width: var(--kpup-rail-width); position: relative; }
.timeline > :not(.timeline-rail) {
  width: calc(100% - var(--rail-width));
  margin-left: var(--rail-width);
}
.timeline-intro {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  overflow: hidden;
  padding: calc(var(--header-height) + 7vw) clamp(28px, 8vw, 130px) 7vw;
  isolation: isolate;
  text-align: left;
  background:
    linear-gradient(125deg, rgba(227,102,39,.16), transparent 42%),
    var(--ink);
}
.timeline-intro::before,
.timeline-intro::after {
  content: "";
  position: absolute;
  z-index: -1;
}
.timeline-intro::before {
  top: 0;
  right: 8vw;
  width: min(34vw, 520px);
  height: 72vh;
  background: linear-gradient(180deg, var(--signal), color-mix(in srgb, var(--signal) 68%, var(--ink)) 72%, var(--ink));
  opacity: .72;
}
.timeline-intro::after {
  inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
  background-size: 8vw 8vw;
  mask-image: linear-gradient(90deg, #000, transparent 72%);
}
.timeline-intro__noise {
  position: absolute;
  z-index: -1;
  inset: 0;
  opacity: .34;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.16'/%3E%3C/svg%3E");
  mix-blend-mode: screen;
}
.timeline-intro__eyebrow,
.timeline-event__date,
.story-hero__meta,
.archive-header > p {
  margin: 0 0 22px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.timeline-intro h1 {
  position: relative;
  z-index: 1;
  max-width: 9.5ch;
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(4.5rem, 9vw, 9rem);
  font-weight: 400;
  line-height: .82;
  letter-spacing: -.065em;
  text-wrap: balance;
}
.timeline-intro__copy {
  max-width: 520px;
  margin: 42px 0 0 clamp(0px, 15vw, 230px);
  color: rgba(255,255,255,.72);
  font-family: var(--sans);
  font-size: clamp(14px, 1.2vw, 18px);
  line-height: 1.55;
}
.timeline-intro__scroll {
  position: absolute;
  right: clamp(20px, 4vw, 60px);
  bottom: 32px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 10px;
  letter-spacing: .17em;
  text-transform: uppercase;
}
.timeline-intro__scroll i {
  position: relative;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255,255,255,.5);
  border-radius: 50%;
}
.timeline-intro__scroll i::before {
  content: "↓";
  position: absolute;
  inset: 0;
  display: grid;
  place-content: center;
  font-style: normal;
}

.timeline-events { position: relative; }
.timeline-event {
  --event-fg: var(--white);
  --event-bg: var(--ink);
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  display: grid;
  isolation: isolate;
  color: var(--event-fg);
  background: var(--event-bg);
  scroll-margin-top: 0;
}
.timeline-event--light { --event-fg: var(--ink); --event-bg: var(--paper); }
.timeline-event__media,
.timeline-event__wash { position: absolute; z-index: -2; inset: 0; }
.timeline-event__media img { width: 100%; height: 100%; object-fit: cover; }
.timeline-event__wash { z-index: -1; pointer-events: none; }
.timeline-event__content {
  position: relative;
  z-index: 2;
  align-self: end;
  width: min(920px, 82vw);
  margin: clamp(110px, 12vw, 190px) clamp(24px, 6vw, 96px) clamp(60px, 7vw, 105px);
}
.timeline-event__date { display: flex; flex-wrap: wrap; gap: 10px 25px; margin-bottom: 20px; }
.timeline-event__date span::before { content: "•"; margin-right: 25px; }
.timeline-event h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(3.6rem, 8.6vw, 10rem);
  font-weight: 400;
  line-height: .82;
  letter-spacing: -.065em;
  text-wrap: balance;
}
.timeline-event h2 a { text-decoration: none; }
.timeline-event__excerpt {
  max-width: 600px;
  margin: 30px 0 0;
  font-family: var(--serif);
  font-size: clamp(18px, 1.6vw, 24px);
  line-height: 1.35;
}
.timeline-event__cta {
  display: inline-flex;
  align-items: center;
  gap: 36px;
  margin-top: 32px;
  padding-bottom: 9px;
  border-bottom: 1px solid currentColor;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.timeline-event__cta i { font-size: 20px; font-style: normal; transition: transform .2s ease; }
.timeline-event__cta:hover i { transform: translate(4px, -4px); }
.timeline-event__year {
  position: absolute;
  z-index: 0;
  top: 8vh;
  right: -2vw;
  color: var(--event-accent);
  font-family: var(--serif);
  font-size: clamp(8rem, 24vw, 28rem);
  line-height: .8;
  letter-spacing: -.1em;
  opacity: .17;
  pointer-events: none;
}

/* Cinematic: edge-to-edge image and a dramatic, low caption. */
.timeline-event--cinematic .timeline-event__wash {
  background: linear-gradient(90deg, rgba(0,0,0,.76) 0, rgba(0,0,0,.17) 62%), linear-gradient(0deg, rgba(0,0,0,.94), transparent 68%);
}
.timeline-event--cinematic.timeline-event--light .timeline-event__wash {
  background: linear-gradient(90deg, rgba(253,245,204,.9), rgba(253,245,204,.05) 70%), linear-gradient(0deg, rgba(253,245,204,.98), transparent 68%);
}

/* Poster: a vertical artwork floats like a physical object. */
.timeline-event--poster { grid-template-columns: minmax(280px, .85fr) minmax(340px, 1.15fr); }
.timeline-event--poster .timeline-event__media {
  position: relative;
  z-index: 1;
  inset: auto;
  align-self: center;
  justify-self: center;
  width: min(38vw, 570px);
  height: min(74vh, 820px);
  margin: var(--header-height) 0 7vh;
  box-shadow: 0 35px 90px rgba(0,0,0,.42);
  transform: rotate(-2deg);
}
.timeline-event--poster .timeline-event__content {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
  width: min(90%, 760px);
  margin: var(--header-height) 4vw 7vh 2vw;
}
.timeline-event--poster h2 { font-size: clamp(4rem, 8vw, 9rem); }
.timeline-event--poster .timeline-event__year { right: 4vw; top: 50%; transform: translateY(-50%) rotate(90deg); }

/* Editorial: oversized typography with the image treated as a clipping. */
.timeline-event--editorial { background: var(--event-accent); color: var(--ink); }
.timeline-event--editorial .timeline-event__media {
  z-index: 0;
  inset: 17vh 7vw 20vh auto;
  width: 31vw;
  transform: rotate(3deg);
  filter: grayscale(1) contrast(1.1);
  mix-blend-mode: multiply;
}
.timeline-event--editorial .timeline-event__wash { display: none; }
.timeline-event--editorial .timeline-event__content { width: min(1100px, 88vw); }
.timeline-event--editorial h2 { font-size: clamp(5.2rem, 11vw, 13rem); text-transform: uppercase; }
.timeline-event--editorial .timeline-event__year { color: var(--white); opacity: .25; }

/* Split: clear image/text duet. */
.timeline-event--split { grid-template-columns: 52% 48%; }
.timeline-event--split .timeline-event__media { position: relative; z-index: 0; inset: auto; grid-column: 1; height: 100svh; }
.timeline-event--split .timeline-event__content {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
  width: auto;
  margin: calc(var(--header-height) + 30px) 6vw 7vh;
}
.timeline-event--split h2 { font-size: clamp(3.7rem, 6.5vw, 8rem); }

.timeline-empty {
  min-height: 70svh;
  display: grid;
  place-content: center;
  gap: 22px;
  padding: 8vw;
  text-align: center;
}
.timeline-empty p { font: 400 clamp(2rem, 5vw, 5rem)/1 var(--serif); }
.timeline-empty a { text-decoration: underline; text-underline-offset: 6px; }

.timeline-rail {
  position: fixed;
  z-index: 80;
  top: 0;
  bottom: 0;
  left: 0;
  width: var(--rail-width);
  padding: calc(var(--header-height) + 18px) 12px 18px;
  border-right: 1px solid rgba(255,255,255,.2);
  background: rgba(44,44,44,.92);
  color: var(--white);
  backdrop-filter: blur(18px);
  transition: transform .35s ease;
}
.timeline-rail.is-hidden { transform: translateX(-110%); }
.timeline-rail__progress {
  position: absolute;
  top: var(--header-height);
  right: -1px;
  bottom: 0;
  width: 1px;
  background: rgba(255,255,255,.2);
}
.timeline-rail__progress i { display: block; width: 1px; height: 0; background: var(--signal); transition: height .35s ease; }
.timeline-rail__items {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden auto;
  scrollbar-width: none;
}
.timeline-rail__items::-webkit-scrollbar { display: none; }
.timeline-rail__items a {
  position: relative;
  flex: 0 0 clamp(82px, 11vh, 112px);
  min-width: 0;
  display: grid;
  grid-template-columns: 10px 1fr;
  align-content: center;
  gap: 7px 8px;
  border-bottom: 1px solid rgba(255,255,255,.12);
  opacity: .45;
  transition: opacity .25s ease;
}
.timeline-rail__items a.is-active,
.timeline-rail__items a:hover { opacity: 1; }
.timeline-rail__items span { grid-column: 2; font-size: 9px; letter-spacing: .14em; }
.timeline-rail__items i { grid-column: 1; grid-row: 1 / span 2; align-self: center; width: 7px; height: 7px; border: 1px solid currentColor; border-radius: 50%; transition: background .2s ease, transform .2s ease; }
.timeline-rail__items a.is-active i { background: var(--signal); border-color: var(--signal); transform: scale(1.35); }
.timeline-rail__items em {
  grid-column: 2;
  overflow: hidden;
  font-size: 10px;
  font-style: normal;
  line-height: 1.2;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

/* Single story. */
.story { --story-fg: var(--ink); --story-bg: var(--paper); background: var(--story-bg); color: var(--story-fg); }
.story--dark { --story-fg: var(--white); --story-bg: var(--ink); }
.story-hero {
  position: relative;
  min-height: 100svh;
  display: grid;
  grid-template-columns: 52% 48%;
  overflow: hidden;
  isolation: isolate;
  padding-top: var(--header-height);
  background: var(--story-bg);
}
.story-hero__backdrop { position: absolute; z-index: -1; inset: 0; background: radial-gradient(circle at 30% 50%, color-mix(in srgb, var(--event-accent) 36%, transparent), transparent 40%); }
.story-hero__content { align-self: end; padding: 8vw 5vw 7vw; }
.story-hero__back { display: inline-block; margin-bottom: clamp(60px, 12vh, 150px); font-size: 10px; letter-spacing: .15em; text-transform: uppercase; }
.story-hero__meta { display: flex; gap: 22px; }
.story-hero__meta span::after { content: "•"; margin-left: 22px; }
.story-hero h1 { margin: 0; font: 400 clamp(4rem, 8vw, 10rem)/.82 var(--serif); letter-spacing: -.065em; text-wrap: balance; }
.story-hero__dek { max-width: 620px; margin: 34px 0 0; font: 400 clamp(19px, 1.7vw, 26px)/1.35 var(--serif); }
.story-hero__image { min-height: calc(100svh - var(--header-height)); margin: 0; }
.story-hero__image img { width: 100%; height: 100%; object-fit: cover; }
.story-hero__year { position: absolute; z-index: -1; left: -3vw; bottom: -5vw; color: var(--event-accent); font: 400 clamp(10rem, 28vw, 30rem)/.7 var(--serif); letter-spacing: -.1em; opacity: .2; }
.story--poster .story-hero__image { margin: 6vh 6vw 8vh 0; transform: rotate(2deg); box-shadow: 0 25px 70px rgba(0,0,0,.3); }
.story--editorial .story-hero { background: var(--event-accent); color: var(--ink); }
.story--editorial .story-hero__image { filter: grayscale(1) contrast(1.1); mix-blend-mode: multiply; }
.story--cinematic .story-hero { display: block; }
.story--cinematic .story-hero__image { position: absolute; z-index: -2; inset: 0; }
.story--cinematic .story-hero::after { content: ""; position: absolute; z-index: -1; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.9), transparent 80%), linear-gradient(0deg, rgba(0,0,0,.75), transparent 55%); }
.story--cinematic .story-hero__content { width: min(850px, 80vw); min-height: calc(100svh - var(--header-height)); display: flex; flex-direction: column; justify-content: flex-end; color: var(--white); }
.story--cinematic .story-hero__back { margin-bottom: auto; }

.story-content { padding: clamp(80px, 12vw, 180px) max(24px, calc((100vw - 720px) / 2)); font: 400 clamp(18px, 1.45vw, 22px)/1.72 var(--serif); }
.story-content > * { margin-top: 0; margin-bottom: 1.55em; }
.story-content > :is(h2,h3,h4) { margin-top: 1.6em; margin-bottom: .55em; font-weight: 400; line-height: .98; letter-spacing: -.035em; }
.story-content h2 { font-size: clamp(2.8rem, 5vw, 5.4rem); }
.story-content h3 { font-size: clamp(2rem, 3.6vw, 3.8rem); }
.story-content a { text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 4px; }
.story-content > .alignwide { width: min(1240px, calc(100vw - 48px)); max-width: none; margin-left: 50%; transform: translateX(-50%); }
.story-content > .alignfull { width: 100vw; max-width: none; margin-left: 50%; transform: translateX(-50%); }
.story-content blockquote { margin: clamp(60px, 9vw, 130px) 0; padding-left: clamp(24px, 4vw, 60px); border-left: 4px solid var(--event-accent); font-size: clamp(2rem, 4.8vw, 5rem); line-height: 1.02; }
.story-content blockquote cite { display: block; margin-top: 24px; font: 700 10px/1.4 var(--sans); letter-spacing: .15em; text-transform: uppercase; }
.story-content .wp-block-image figcaption { margin-top: 10px; font: 400 11px/1.4 var(--sans); letter-spacing: .08em; text-transform: uppercase; }
.story-content .is-style-kpup-manifesto { padding: clamp(90px, 14vw, 220px) 6vw; background: var(--event-accent); color: var(--ink); }
.story-content .is-style-kpup-manifesto h2 { max-width: 1100px; margin-inline: auto; }
.story-content .is-style-kpup-note { gap: clamp(28px, 5vw, 90px); margin-block: clamp(70px, 10vw, 140px); }
.story-next { display: grid; gap: 18px; padding: clamp(60px, 8vw, 120px) 6vw; border-top: 1px solid color-mix(in srgb, currentColor 22%, transparent); }
.story-next span { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; }
.story-next a { max-width: 1000px; font: 400 clamp(2.8rem, 6vw, 7rem)/.98 var(--serif); }

/* Archives and utility pages. */
.archive-shell { min-height: 100vh; padding: calc(var(--header-height) + 8vw) 5vw 10vw; background: var(--paper); color: var(--ink); }
.archive-header { display: grid; gap: 8px; margin-bottom: 7vw; }
.archive-header h1 { margin: 0; font: 400 clamp(4rem, 10vw, 11rem)/.82 var(--serif); letter-spacing: -.07em; }
.archive-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 6vw 2vw; }
.archive-card__image { display: block; aspect-ratio: 4 / 3; overflow: hidden; background: var(--gray); }
.archive-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.archive-card:hover .archive-card__image img { transform: scale(1.025); }
.archive-card time { display: block; margin-top: 16px; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; }
.archive-card h2 { margin: 10px 0 0; font: 400 clamp(1.8rem, 3vw, 3.3rem)/1 var(--serif); letter-spacing: -.035em; }
.navigation.pagination { margin-top: 90px; }
.nav-links { display: flex; gap: 18px; }
.not-found { min-height: 100svh; display: grid; place-content: center; padding: 10vw; text-align: center; background: var(--signal); color: var(--ink); }
.not-found p { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; }
.not-found h1 { max-width: 1000px; margin: 20px auto 50px; font: 400 clamp(4rem, 10vw, 11rem)/.82 var(--serif); letter-spacing: -.07em; }
.not-found a { justify-self: center; padding-bottom: 5px; border-bottom: 1px solid; }
.site-footer { display: grid; grid-template-columns: 1fr auto; gap: 35px 7vw; padding: 7vw 5vw 4vw; border-top: 1px solid rgba(255,255,255,.18); background: var(--ink); color: var(--white); }
.site-footer__name { grid-column: 1 / -1; margin: 0; font: 400 clamp(4rem, 11vw, 12rem)/.8 var(--serif); letter-spacing: -.075em; }
.site-footer ul { display: flex; gap: 24px; margin: 0; padding: 0; list-style: none; font-size: 11px; text-transform: uppercase; }
.site-footer__meta { margin: 0; color: rgba(255,255,255,.55); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; }

@media (max-width: 900px) {
  :root { --header-height: 64px; --kpup-rail-width: 64px; }
  .site-header { grid-template-columns: 1fr auto; padding-inline: 18px; }
  .site-brand { grid-column: 1; justify-self: start; }
  body:has([data-timeline]) .site-brand { margin-left: var(--kpup-rail-width); }
  .menu-toggle { grid-column: 2; display: flex; align-items: center; gap: 12px; border: 0; padding: 9px 0; background: transparent; color: inherit; font-size: 10px; letter-spacing: .13em; text-transform: uppercase; }
  .menu-toggle i, .menu-toggle i::after { display: block; width: 22px; height: 1px; background: currentColor; transition: transform .25s ease; }
  .menu-toggle i { position: relative; }
  .menu-toggle i::after { content: ""; position: absolute; top: 6px; }
  .menu-toggle[aria-expanded="true"] i { transform: rotate(45deg); }
  .menu-toggle[aria-expanded="true"] i::after { top: 0; transform: rotate(90deg); }
  .site-navigation { position: fixed; inset: 0; z-index: -1; display: grid; place-content: center; background: var(--ink); opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease; }
  .site-navigation.is-open { opacity: 1; visibility: visible; }
  .site-navigation ul { flex-direction: column; gap: 12px; }
  .site-navigation a { font: 400 clamp(2.8rem, 12vw, 5rem)/1 var(--serif); letter-spacing: -.04em; text-transform: none; }
  .timeline-intro { padding-inline: 24px; }
  .timeline-intro::before { top: 0; right: 0; left: auto; width: 46vw; height: 56vh; }
  .timeline-intro::after { inset: 0; width: auto; height: auto; }
  .timeline-intro h1 { max-width: 7ch; font-size: clamp(3.5rem, 18vw, 7rem); line-height: .82; }
  .timeline-intro__copy { margin-left: 0; }
  .timeline-intro__scroll { right: 18px; bottom: 22px; }
  .timeline-event__content { width: auto; margin-inline: 24px; }
  .timeline-event h2 { font-size: clamp(3.5rem, 14vw, 7rem); }
  .timeline-event__year { top: 13vh; font-size: 42vw; }
  .timeline-event--poster,
  .timeline-event--split { display: block; }
  .timeline-event--poster .timeline-event__media,
  .timeline-event--split .timeline-event__media { position: absolute; z-index: -2; inset: 0; width: 100%; height: 100%; margin: 0; transform: none; }
  .timeline-event--poster .timeline-event__wash,
  .timeline-event--split .timeline-event__wash { display: block; background: linear-gradient(0deg, rgba(0,0,0,.95), rgba(0,0,0,.08) 80%); }
  .timeline-event--poster .timeline-event__content,
  .timeline-event--split .timeline-event__content { position: absolute; right: 0; bottom: 0; left: 0; width: auto; margin: 90px 24px 55px; color: var(--white); }
  .timeline-event--editorial .timeline-event__media { inset: 17vh 7vw auto auto; width: 58vw; height: 45vh; }
  .timeline-event--editorial h2 { font-size: clamp(4.2rem, 17vw, 8rem); }
  .timeline-event__excerpt { display: none; }
  .timeline-rail { padding: calc(var(--header-height) + 12px) 7px 12px; }
  .timeline-rail__items a { flex-basis: 76px; grid-template-columns: 8px 1fr; gap: 5px 4px; }
  .timeline-rail__items em { display: none; }
  .story-hero { display: block; padding-top: var(--header-height); }
  .story-hero__content { position: relative; z-index: 2; min-height: 72svh; display: flex; flex-direction: column; justify-content: flex-end; padding: 12vh 24px 55px; }
  .story-hero__back { margin-bottom: auto; }
  .story-hero__image { min-height: 62svh; }
  .story--poster .story-hero__image { margin: 0; transform: none; }
  .story--cinematic .story-hero__content { width: auto; min-height: calc(100svh - var(--header-height)); }
  .story-hero h1 { font-size: clamp(4rem, 16vw, 8rem); }
  .archive-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .site-footer { grid-template-columns: 1fr; padding: 90px 24px 40px; }
  .site-footer__name { grid-column: 1; }
}

@media (max-width: 560px) {
  .timeline-intro__copy { font-size: 17px; }
  .timeline-event__date span::before { display: none; }
  .timeline-event__date span { width: 100%; }
  .timeline-event__cta { margin-top: 24px; }
  .archive-grid { grid-template-columns: 1fr; gap: 70px; }
  .site-footer ul { flex-wrap: wrap; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
