/* ============================================================
   bio/styles.css — page styles for the Dossier 2049 bio site
   ============================================================ */

@import url("./colors_and_type.css");

/* ============================================================
   Background atmosphere — amber haze + film grain
   ============================================================ */
.atmosphere {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.atmosphere::before {
  content: "";
  position: absolute;
  inset: -10%;
  background:
    radial-gradient(60% 40% at 80% 0%, var(--amber-glow) 0%, transparent 60%),
    radial-gradient(40% 30% at 10% 30%, rgba(217, 70, 239, 0.10) 0%, transparent 70%),
    radial-gradient(50% 40% at 50% 100%, var(--amber-haze) 0%, transparent 70%);
  filter: blur(20px);
}
.atmosphere::after {
  /* Film grain — SVG noise via data URI */
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.85  0 0 0 0 0.78  0 0 0 0 0.95  0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 200px 200px;
  opacity: 0.5;
  mix-blend-mode: overlay;
}

/* Subtle vertical scan grid in the bg — only visible on dark sections */
.atmosphere .grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(168, 85, 247, 0.04) 1px, transparent 1px);
  background-size: calc(100% / 12) 100%;
  opacity: 0.5;
}

/* ============================================================
   Layout
   ============================================================ */
.shell {
  position: relative;
  z-index: 1;
  min-height: 100vh;
}
.wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
.wrap--narrow { max-width: 60rem; }

/* ============================================================
   Top instrument bar
   ============================================================ */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(10, 8, 7, 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--rule);
}
.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 44px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-mute);
}
.topbar__brand {
  font-family: var(--brand);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--paper);
  font-weight: var(--fw-medium);
}
.topbar__brand .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--amber);
  box-shadow: 0 0 12px var(--amber);
  animation: pulse 2.4s var(--ease-out) infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.55; transform: scale(0.85); }
}
.topbar__meta {
  display: none;
  gap: 28px;
}
@media (min-width: 900px) {
  .topbar__meta { display: flex; }
}
.topbar__meta span::before {
  content: "[ ";
  color: var(--paper-faint);
}
.topbar__meta span::after {
  content: " ]";
  color: var(--paper-faint);
}
.lang {
  display: flex;
  gap: 2px;
  align-items: center;
  border: 1px solid var(--rule);
  padding: 2px;
}
.lang button {
  padding: 4px 8px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  color: var(--paper-mute);
  transition: all var(--t-fast);
}
.lang button:hover { color: var(--paper); }
.lang button[aria-pressed="true"] {
  background: var(--amber);
  color: var(--void);
}

/* ============================================================
   Hero
   ============================================================ */
.hero {
  position: relative;
  padding: clamp(96px, 18vh, 220px) 0 clamp(64px, 12vh, 160px);
  border-bottom: 1px solid var(--rule);
  overflow: hidden;
}
.hero__corners {
  position: absolute;
  inset: var(--gutter);
  pointer-events: none;
  border: 1px solid transparent;
  background:
    /* corner ticks */
    linear-gradient(to right, var(--amber) 0 24px, transparent 24px) top left/24px 1px no-repeat,
    linear-gradient(to bottom, var(--amber) 0 24px, transparent 24px) top left/1px 24px no-repeat,
    linear-gradient(to left, var(--amber) 0 24px, transparent 24px) top right/24px 1px no-repeat,
    linear-gradient(to bottom, var(--amber) 0 24px, transparent 24px) top right/1px 24px no-repeat,
    linear-gradient(to right, var(--amber) 0 24px, transparent 24px) bottom left/24px 1px no-repeat,
    linear-gradient(to top, var(--amber) 0 24px, transparent 24px) bottom left/1px 24px no-repeat,
    linear-gradient(to left, var(--amber) 0 24px, transparent 24px) bottom right/24px 1px no-repeat,
    linear-gradient(to top, var(--amber) 0 24px, transparent 24px) bottom right/1px 24px no-repeat;
}
.hero__head {
  display: flex;
  justify-content: space-between;
  margin-bottom: 64px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-mute);
}
.hero__head-l, .hero__head-r {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hero__head-r { text-align: right; align-items: flex-end; }
.hero__head em { color: var(--amber); font-style: normal; }

/* Hero two-column grid: text left, portrait right (stacks on mobile) */
.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  align-items: start;
}
@media (min-width: 980px) {
  .hero__grid {
    grid-template-columns: minmax(0, 1.5fr) minmax(280px, 1fr);
    gap: 72px;
  }
}
.hero__main { min-width: 0; }

.hero__portrait { position: relative; }
.portrait__frame {
  position: relative;
  aspect-ratio: 3 / 4;
  border: 1px solid var(--rule-2);
  background: var(--void-2);
  overflow: hidden;
}
.portrait__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(0.6) contrast(1.05) brightness(0.95) sepia(0.18) hue-rotate(230deg) saturate(1.1);
  mix-blend-mode: luminosity;
}
.portrait__frame::after {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 50% at 80% 0%, rgba(168, 85, 247, 0.22) 0%, transparent 65%),
    radial-gradient(50% 40% at 10% 100%, rgba(217, 70, 239, 0.16) 0%, transparent 70%);
  mix-blend-mode: screen;
  pointer-events: none;
}
.portrait__scan {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(
    to bottom,
    transparent 0,
    transparent 3px,
    rgba(168, 85, 247, 0.04) 3px,
    rgba(168, 85, 247, 0.04) 4px
  );
  pointer-events: none;
}
.portrait__corner {
  position: absolute;
  width: 18px; height: 18px;
  border: 1px solid var(--amber);
  pointer-events: none;
}
.portrait__corner--tl { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.portrait__corner--tr { top: -1px; right: -1px; border-left: 0; border-bottom: 0; }
.portrait__corner--bl { bottom: -1px; left: -1px; border-right: 0; border-top: 0; }
.portrait__corner--br { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }
.portrait__meta {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 12px 14px;
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--amber-2);
  background: linear-gradient(to top, rgba(10, 6, 16, 0.92) 0%, rgba(10, 6, 16, 0) 100%);
}

.hero__name {
  font-family: var(--serif);
  font-size: var(--t-display);
  line-height: var(--lh-display);
  letter-spacing: var(--tk-display);
  font-weight: var(--fw-regular);
  color: var(--paper);
  margin: 0;
  text-wrap: balance;
}
.hero__name em {
  font-style: italic;
  color: var(--amber-2);
  font-weight: var(--fw-regular);
}

.hero__tagline {
  margin-top: 28px;
  max-width: 56ch;
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2.6vw, 2.25rem);
  line-height: 1.25;
  font-style: italic;
  color: var(--paper-2);
}
.hero__sub {
  margin-top: 24px;
  max-width: 64ch;
  font-size: var(--t-body-lg);
  line-height: 1.6;
  color: var(--paper-mute);
}
.hero__chips {
  margin-top: 40px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--rule-2);
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-2);
  background: rgba(168, 85, 247, 0.04);
}
.chip::before { content: "["; color: var(--amber); }
.chip::after  { content: "]"; color: var(--amber); }
.hero__ctas {
  margin-top: 48px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  font-family: var(--mono);
  font-size: var(--t-small);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  border: 1px solid var(--rule-2);
  color: var(--paper);
  background: transparent;
  transition: all var(--t-base) var(--ease-out);
}
.btn:hover {
  border-color: var(--amber);
  color: var(--amber);
  background: rgba(168, 85, 247, 0.04);
}
.btn--primary {
  background: var(--amber);
  border-color: var(--amber);
  color: var(--void);
}
.btn--primary:hover {
  background: var(--amber-2);
  border-color: var(--amber-2);
  color: var(--void);
}
.btn .arrow {
  display: inline-block;
  transition: transform var(--t-base) var(--ease-out);
}
.btn:hover .arrow { transform: translateX(4px); }

.hero__scroll {
  margin-top: 80px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-mute);
}
.hero__scroll .line {
  width: 64px;
  height: 1px;
  background: linear-gradient(to right, var(--amber), transparent);
}

/* ============================================================
   Section wrappers
   ============================================================ */
.section {
  padding: clamp(80px, 12vh, 160px) 0;
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.section__head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-bottom: 64px;
}
@media (min-width: 900px) {
  .section__head {
    grid-template-columns: 200px 1fr;
    gap: 80px;
    align-items: start;
  }
}
.section__eyebrow {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
  padding-top: 8px;
  position: relative;
}
.section__eyebrow::before {
  content: "";
  display: block;
  width: 32px;
  height: 1px;
  background: var(--amber);
  margin-bottom: 12px;
}
.section__title {
  font-family: var(--serif);
  font-size: var(--t-h1);
  line-height: 1.05;
  letter-spacing: var(--tk-display);
  font-weight: var(--fw-regular);
  color: var(--paper);
  text-wrap: balance;
  margin: 0;
}
.section__title em {
  font-style: italic;
  color: var(--amber-2);
}
.section__sub {
  margin-top: 16px;
  max-width: 56ch;
  font-size: var(--t-body);
  line-height: 1.6;
  color: var(--paper-mute);
}

/* ============================================================
   §01 SIGNAL — paper document panel
   ============================================================ */
.signal {
  position: relative;
}
.signal__panel {
  background:
    linear-gradient(to bottom, rgba(243, 227, 196, 0.02), rgba(243, 227, 196, 0.005));
  border: 1px solid var(--rule);
  padding: clamp(40px, 6vw, 72px);
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 300px);
  column-gap: clamp(40px, 5vw, 80px);
  row-gap: 0;
  align-items: start;
}
@media (max-width: 900px) {
  .signal__panel { grid-template-columns: 1fr; }
}
.signal__lead { grid-column: 1; }
.signal__body { grid-column: 1; }
.signal__panel::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, var(--amber) 0, var(--amber) 96px, var(--rule) 96px);
}
.signal__corner {
  position: absolute;
  top: 12px; right: 16px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  color: var(--paper-faint);
}
.signal__lead {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  line-height: 1.2;
  font-weight: var(--fw-regular);
  color: var(--paper);
  margin: 0 0 32px;
  text-wrap: balance;
}
.signal__lead em { font-style: italic; color: var(--amber-2); }
.signal__body {
  font-family: var(--serif);
  font-size: clamp(1.125rem, 1.4vw, 1.375rem);
  line-height: 1.55;
  color: var(--paper-2);
  max-width: 60ch;
  margin: 0;
  text-wrap: pretty;
  white-space: pre-line;
}
.signal__data {
  grid-column: 2;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding-left: 24px;
  border-left: 1px solid var(--rule);
}
.signal__data dl {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border: 0;
}
.signal__data dt {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
}
.signal__data dd {
  margin: 0;
  font-family: var(--sans);
  font-size: var(--t-body);
  color: var(--paper);
  line-height: 1.4;
}
@media (max-width: 900px) {
  .signal__data {
    grid-column: 1;
    border-left: 0;
    padding-left: 0;
    padding-top: 32px;
    margin-top: 40px;
    border-top: 1px solid var(--rule);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
}

/* ============================================================
   §02 IMPACT — instrumented KPI grid
   ============================================================ */
.filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 40px;
  padding: 16px 20px;
  border: 1px solid var(--rule);
  background: rgba(168, 85, 247, 0.02);
}
.filter__label {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
  margin-right: 8px;
}
.filter__chip {
  padding: 6px 12px;
  border: 1px solid var(--rule-2);
  background: transparent;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-mute);
  cursor: pointer;
  transition: all var(--t-fast);
}
.filter__chip:hover { color: var(--paper); border-color: var(--paper-mute); }
.filter__chip[aria-pressed="true"] {
  background: var(--amber);
  border-color: var(--amber);
  color: var(--void);
}

.kpi-grid {
  display: grid;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  grid-template-columns: 1fr;
}
@media (min-width: 600px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .kpi-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1200px) { .kpi-grid { grid-template-columns: repeat(4, 1fr); } }

.kpi {
  position: relative;
  padding: 28px 24px 24px;
  background: var(--void);
  transition: all var(--t-base) var(--ease-out);
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 200px;
}
.kpi:hover {
  background: var(--void-3);
  z-index: 1;
}
.kpi.is-dim { opacity: 0.18; }
.kpi__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
}
.kpi__src { color: var(--amber); }
.kpi__id  { color: var(--paper-faint); }
.kpi__metric {
  font-family: var(--serif);
  font-size: clamp(2.25rem, 3.5vw, 3.25rem);
  line-height: 0.95;
  letter-spacing: var(--tk-display);
  font-weight: var(--fw-regular);
  color: var(--paper);
  font-feature-settings: "tnum" 1;
}
.kpi__metric .unit, .kpi__metric .arrow {
  font-family: var(--mono);
  font-size: 0.4em;
  color: var(--amber);
  letter-spacing: var(--tk-mono);
  vertical-align: middle;
  margin-left: 4px;
}
.kpi__desc {
  margin-top: auto;
  font-size: var(--t-small);
  line-height: 1.5;
  color: var(--paper-mute);
}

/* ============================================================
   §03 TRAJECTORY — instrumented timeline
   ============================================================ */
.tl {
  display: flex;
  flex-direction: column;
}
.tl-item {
  border-top: 1px solid var(--rule);
  position: relative;
}
.tl-item:last-child { border-bottom: 1px solid var(--rule); }
.tl-item__btn {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 24px;
  width: 100%;
  padding: 32px 0;
  align-items: baseline;
  text-align: left;
  cursor: pointer;
  transition: all var(--t-base);
  position: relative;
}
@media (max-width: 700px) {
  .tl-item__btn { grid-template-columns: 1fr; gap: 8px; padding: 24px 0; }
}
.tl-item__btn:hover { background: rgba(168, 85, 247, 0.03); }
.tl-item__btn::before {
  content: "";
  position: absolute;
  left: -8px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px; height: 8px;
  background: var(--rule-2);
  transition: all var(--t-base);
}
.tl-item.is-open .tl-item__btn::before,
.tl-item__btn:hover::before {
  background: var(--amber);
  box-shadow: 0 0 16px var(--amber);
}
.tl-item__id {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  color: var(--paper-faint);
  padding-top: 6px;
}
.tl-item__main {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.tl-item__company {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1.05;
  color: var(--paper);
}
.tl-item.is-open .tl-item__company,
.tl-item__btn:hover .tl-item__company { color: var(--amber-2); }
.tl-item__role {
  font-family: var(--sans);
  font-size: var(--t-body);
  color: var(--paper-mute);
}
.tl-item__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-mute);
  white-space: nowrap;
}
.tl-item__meta span::before { content: "["; color: var(--paper-faint); }
.tl-item__meta span::after  { content: "]"; color: var(--paper-faint); }
.tl-item__caret {
  align-self: center;
  width: 32px; height: 32px;
  border: 1px solid var(--rule-2);
  display: grid;
  place-items: center;
  font-family: var(--mono);
  color: var(--paper-mute);
  transition: all var(--t-base);
}
.tl-item.is-open .tl-item__caret { background: var(--amber); color: var(--void); border-color: var(--amber); transform: rotate(45deg); }

.tl-item__body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--t-slow) var(--ease-out);
}
.tl-item.is-open .tl-item__body { grid-template-rows: 1fr; }
.tl-item__body-inner {
  overflow: hidden;
  min-height: 0;
}
.tl-item__body-pad {
  padding: 0 0 32px;
}

/* Exhibit (image + mono caption) inside an expanded timeline entry */
.tl-exhibit {
  margin: 0 0 32px;
  max-width: 540px;
}
.tl-exhibit__frame {
  position: relative;
  border: 1px solid var(--rule);
  background: var(--void-2);
  overflow: hidden;
}
.tl-exhibit__img {
  display: block;
  width: 100%;
  height: auto;
  filter: saturate(0.8) contrast(1.04);
}
.tl-exhibit__scan {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    rgba(168, 85, 247, 0.04) 0,
    rgba(168, 85, 247, 0.04) 1px,
    transparent 1px,
    transparent 4px
  );
  mix-blend-mode: overlay;
  opacity: 0.6;
}
.tl-exhibit__cap {
  margin-top: 12px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-mute);
}

/* Project lines inside an expanded timeline entry */
.tl-item__projects {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.proj {
  display: grid;
  grid-template-columns: minmax(180px, 240px) 1fr;
  gap: 24px;
  align-items: baseline;
  padding-left: 24px;
  position: relative;
}
.proj::before {
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--amber);
  font-family: var(--mono);
  font-size: var(--t-meta);
  top: 4px;
}
.proj__name {
  font-family: var(--sans);
  font-weight: var(--fw-semi);
  font-size: var(--t-body);
  color: var(--paper);
  letter-spacing: -0.005em;
}
a.proj__name {
  display: inline-flex;
  align-items: baseline;
  gap: 0;
  width: max-content;
  transition: color var(--t-base);
}
a.proj__name:hover { color: var(--amber-2); }
.proj__link-tag {
  margin-left: 12px;
  padding: 3px 9px;
  border: 1px solid var(--rule-2);
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-mute);
  font-weight: var(--fw-regular);
  white-space: nowrap;
  transition: all var(--t-base);
}
a.proj__name:hover .proj__link-tag {
  border-color: var(--amber);
  color: var(--amber);
  background: rgba(168, 85, 247, 0.08);
}
.proj__impact {
  font-size: var(--t-body);
  line-height: 1.55;
  color: var(--paper-2);
}
@media (max-width: 700px) {
  .proj { grid-template-columns: 1fr; gap: 4px; }
}
.tl-item__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
}
.tag {
  padding: 4px 10px;
  border: 1px solid var(--rule-2);
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-mute);
}
.tl-item__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.tl-item__list li {
  position: relative;
  padding-left: 24px;
  font-size: var(--t-body);
  line-height: 1.55;
  color: var(--paper-2);
}
.tl-item__list li::before {
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--amber);
  font-family: var(--mono);
}

/* ============================================================
   §04 CASE FILES
   ============================================================ */
.cases {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
@media (min-width: 800px) { .cases { grid-template-columns: 1fr 1fr; } }

.case {
  background: var(--void);
  padding: 32px;
  text-align: left;
  cursor: pointer;
  transition: all var(--t-base);
  display: flex;
  flex-direction: column;
  gap: 24px;
  min-height: 320px;
  position: relative;
}
.case:hover { background: var(--void-3); }
.case__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
}
.case__id { color: var(--amber); }
.case__src { color: var(--paper-mute); }
.case__title {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.1;
  letter-spacing: var(--tk-tight);
  color: var(--paper);
  text-wrap: balance;
}
.case__outcome {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px dashed var(--rule);
  font-size: var(--t-small);
  color: var(--paper-mute);
  line-height: 1.5;
}
.case__cta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--amber);
}
.case:hover .case__cta { gap: 14px; }

/* Modal */
.modal-root[hidden] { display: none; }
.modal-root {
  position: fixed; inset: 0; z-index: 100;
  display: grid; place-items: center;
  padding: var(--gutter);
  animation: fadein var(--t-base) var(--ease-out);
}
@keyframes fadein { from { opacity: 0; } to { opacity: 1; } }
.modal-overlay {
  position: absolute; inset: 0;
  background: rgba(10, 8, 7, 0.75);
  backdrop-filter: blur(8px);
}
.modal {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 720px;
  max-height: 86vh;
  overflow: auto;
  background: var(--void-2);
  border: 1px solid var(--rule-2);
  padding: 40px;
  box-shadow: var(--shadow-2);
}
.modal::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--amber);
}
.modal__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-mute);
  margin-bottom: 24px;
}
.modal__close {
  width: 32px; height: 32px;
  border: 1px solid var(--rule-2);
  display: grid; place-items: center;
  color: var(--paper-mute);
  font-family: var(--mono);
  transition: all var(--t-fast);
}
.modal__close:hover { border-color: var(--amber); color: var(--amber); }
.modal__title {
  font-family: var(--serif);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  line-height: 1.05;
  letter-spacing: var(--tk-tight);
  color: var(--paper);
  margin: 0 0 32px;
}
.modal__grid {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.modal__field {
  border-top: 1px solid var(--rule);
  padding-top: 16px;
}
.modal__field-label {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 12px;
  display: block;
}
.modal__field-body {
  font-size: var(--t-body);
  line-height: 1.6;
  color: var(--paper-2);
}
.modal__field-body--big {
  font-family: var(--serif);
  font-size: clamp(1.125rem, 1.8vw, 1.5rem);
  line-height: 1.3;
  color: var(--paper);
}

/* ============================================================
   §05 CAPABILITIES
   ============================================================ */
.caps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
@media (min-width: 700px)  { .caps { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .caps { grid-template-columns: repeat(5, 1fr); } }

.cap {
  background: var(--void);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.cap__num {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  color: var(--amber);
}
.cap__title {
  font-family: var(--serif);
  font-size: 1.25rem;
  line-height: 1.15;
  color: var(--paper);
}
.cap__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-top: 1px solid var(--rule);
  padding-top: 16px;
}
.cap__list li {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-2);
  position: relative;
  padding-left: 16px;
}
.cap__list li::before {
  content: "—";
  position: absolute; left: 0;
  color: var(--amber);
}

/* ============================================================
   §06 VENTURES
   ============================================================ */
/* ============================================================
   ELSEWHERE — gallery
   ============================================================ */
.gallery {
  columns: 3;
  column-gap: 24px;
}
@media (max-width: 900px) { .gallery { columns: 2; } }
@media (max-width: 600px) { .gallery { columns: 1; } }

.gallery__item {
  break-inside: avoid;
  margin: 0 0 32px;
  display: block;
}
.gallery__frame {
  position: relative;
  border: 1px solid var(--rule);
  background: var(--void-2);
  overflow: hidden;
}
.gallery__img {
  display: block;
  width: 100%;
  height: auto;
  filter: saturate(0.82) contrast(1.04);
  transition: filter var(--t-base);
}
.gallery__item:hover .gallery__img { filter: saturate(1) contrast(1); }
.gallery__scan {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    rgba(168, 85, 247, 0.04) 0,
    rgba(168, 85, 247, 0.04) 1px,
    transparent 1px,
    transparent 4px
  );
  mix-blend-mode: overlay;
  opacity: 0.55;
}
.gallery__cap {
  margin-top: 12px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-mute);
}

/* Bridge between the trajectory section and the ventures section */
.track-bridge {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 0 0 56px;
  margin-top: -32px;
}
.track-bridge__line {
  width: 1px;
  height: 72px;
  background: linear-gradient(to bottom, transparent, var(--amber));
  display: block;
}
.track-bridge__label {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
}
.track-bridge__label::before,
.track-bridge__label::after {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--amber);
  opacity: 0.55;
}

/* Linked venture name (mirrors a.proj__name pattern) */
a.venture__name {
  display: inline-flex;
  align-items: baseline;
  gap: 0;
  width: max-content;
  transition: color var(--t-base);
}
a.venture__name:hover { color: var(--amber-2); }
.venture__link-tag {
  margin-left: 12px;
  padding: 3px 9px;
  border: 1px solid var(--rule-2);
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-mute);
  font-weight: var(--fw-regular);
  white-space: nowrap;
  transition: all var(--t-base);
}
a.venture__name:hover .venture__link-tag {
  border-color: var(--amber);
  color: var(--amber);
  background: rgba(168, 85, 247, 0.08);
}

/* Parallel-to callout at top of each venture card */
.venture__parallel {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 4px;
}

.ventures {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
.venture {
  border: 1px solid var(--rule);
  padding: 32px;
  background: var(--void-2);
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  transition: border-color var(--t-base);
}
@media (min-width: 800px) {
  .venture { grid-template-columns: 1fr 2fr; gap: 40px; }
}
.venture:hover { border-color: var(--rule-amber); }
.venture::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 32px; height: 2px;
  background: var(--amber);
}
.venture__l { display: flex; flex-direction: column; gap: 12px; }
.venture__name {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2.2vw, 1.875rem);
  line-height: 1.05;
  color: var(--paper);
}
.venture__role {
  font-family: var(--sans);
  font-size: var(--t-small);
  color: var(--paper-mute);
}
.venture__period {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-mono);
  text-transform: uppercase;
  color: var(--paper-faint);
  margin-top: 8px;
}
.venture__stamps {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.stamp {
  padding: 4px 10px;
  border: 1px dashed var(--amber);
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
  background: rgba(168, 85, 247, 0.04);
}
.venture__bullets {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-self: center;
}
.venture__bullets li {
  position: relative;
  padding-left: 24px;
  font-size: var(--t-body);
  line-height: 1.55;
  color: var(--paper-2);
}
.venture__bullets li::before {
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--amber);
  font-family: var(--mono);
}

/* ============================================================
   §07 TRANSMISSION
   ============================================================ */
.transmission {
  background: var(--void);
}
.tx {
  border: 1px solid var(--rule);
  padding: clamp(40px, 6vw, 72px);
  position: relative;
  background:
    repeating-linear-gradient(
      0deg,
      transparent 0,
      transparent 23px,
      rgba(168, 85, 247, 0.03) 23px,
      rgba(168, 85, 247, 0.03) 24px
    );
}
.tx::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, var(--amber), transparent);
}
.tx__head {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-faint);
  margin-bottom: 32px;
}
.tx__title {
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 1.05;
  letter-spacing: var(--tk-display);
  color: var(--paper);
  margin: 0 0 16px;
}
.tx__title em { font-style: italic; color: var(--amber-2); }
.tx__sub {
  max-width: 50ch;
  font-size: var(--t-body-lg);
  line-height: 1.55;
  color: var(--paper-mute);
  margin: 0 0 48px;
}
.tx__lines {
  display: grid;
  gap: 16px;
  margin-bottom: 48px;
}
.tx__line {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 24px;
  align-items: baseline;
  padding: 16px 0;
  border-bottom: 1px solid var(--rule);
}
@media (max-width: 600px) {
  .tx__line { grid-template-columns: 1fr; gap: 4px; }
}
.tx__line dt {
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--amber);
}
.tx__line dd {
  margin: 0;
  font-family: var(--mono);
  font-size: var(--t-body);
  color: var(--paper);
  letter-spacing: var(--tk-mono);
}
.tx__line dd a { color: var(--paper); border-bottom: 1px solid var(--rule-2); transition: all var(--t-fast); }
.tx__line dd a:hover { color: var(--amber); border-bottom-color: var(--amber); }
.tx__signoff {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.5rem;
  color: var(--amber-2);
}

/* ============================================================
   Footer
   ============================================================ */
.footer {
  padding: 32px 0;
  border-top: 1px solid var(--rule);
  background: var(--void);
}
.footer__inner {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-faint);
}
.footer__l, .footer__r {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
}

/* ============================================================
   Visually-hidden
   ============================================================ */
.sr {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ============================================================
   Right-side section rail (scrollspy)
   ============================================================ */
.rail {
  position: fixed;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 40;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 16px;
  background: var(--void);
  border: 1px solid var(--rule);
}
.rail__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  font-family: var(--mono);
  font-size: var(--t-meta);
  letter-spacing: var(--tk-meta);
  text-transform: uppercase;
  color: var(--paper-mute);
  cursor: pointer;
  transition: color var(--t-base);
  white-space: nowrap;
}
.rail__dot {
  width: 6px;
  height: 6px;
  border: 1px solid var(--paper-mute);
  background: transparent;
  flex-shrink: 0;
  transition: all var(--t-base);
}
.rail__item:hover { color: var(--paper); }
.rail__item:hover .rail__dot { border-color: var(--paper); }
.rail__item.is-active { color: var(--amber); }
.rail__item.is-active .rail__dot {
  background: var(--amber);
  border-color: var(--amber);
  box-shadow: 0 0 12px var(--amber);
}
@media (max-width: 900px) { .rail { display: none; } }

