:root {
  --ink: #090a09;
  --ink-2: #10110f;
  --ink-3: #171815;
  --paper: #ece6d8;
  --paper-soft: #cfc6b5;
  --paper-faint: #9f9788;
  --red: #9f4937;
  --amber: #b08a58;
  --blue: #667f8b;
  --line: rgba(236, 230, 216, 0.18);
  --line-strong: rgba(236, 230, 216, 0.34);
  --max: 1440px;
  --measure: 760px;
  --serif: Georgia, "Times New Roman", serif;
  --sans: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  --shadow: 0 30px 90px rgba(0, 0, 0, 0.36);
}

* { box-sizing: border-box; }
html { color-scheme: dark; scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  overflow-x: hidden;
  color: var(--paper);
  background: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 1000;
  pointer-events: none;
  opacity: 0.025;
  background: url("../images/grain.png") repeat;
  mix-blend-mode: screen;
}
img, video { max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { color: inherit; }
::selection { color: var(--ink); background: var(--amber); }
:focus-visible { outline: 2px solid var(--amber); outline-offset: 4px; }

.skip-link {
  position: fixed;
  left: 18px;
  top: -80px;
  z-index: 2000;
  padding: 11px 16px;
  color: var(--ink);
  background: var(--paper);
  font-weight: 700;
  transition: top .2s ease;
}
.skip-link:focus { top: 18px; }

.shell { width: min(calc(100% - 40px), var(--max)); margin-inline: auto; }
.measure { max-width: var(--measure); }
.eyebrow,
.kicker,
.meta-label,
.card-meta,
.archive-filter,
.site-nav a,
.footer-kicker {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.eyebrow, .kicker, .meta-label, .footer-kicker { color: var(--paper-faint); }

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 900;
  background: linear-gradient(to bottom, rgba(7, 8, 7, .92), rgba(7, 8, 7, .68) 70%, transparent);
  transition: background .25s ease, border-color .25s ease;
}
.site-header.is-scrolled {
  background: rgba(9, 10, 9, .94);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
}
.header-inner {
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}
.brand {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  font-size: .76rem;
  white-space: nowrap;
}
.brand small { color: var(--paper-faint); font-size: .58rem; }
.site-nav { display: flex; align-items: center; gap: clamp(15px, 2vw, 32px); }
.site-nav a { position: relative; padding: 8px 0; color: var(--paper-soft); }
.site-nav a[aria-current="page"], .site-nav a:hover { color: var(--paper); }
.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 100%;
  bottom: 2px;
  height: 1px;
  background: currentColor;
  transition: right .2s ease;
}
.site-nav a:hover::after, .site-nav a[aria-current="page"]::after { right: 0; }
.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line-strong);
  background: transparent;
  cursor: pointer;
}
.nav-toggle span,
.nav-toggle::before,
.nav-toggle::after {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  margin: 5px auto;
  background: var(--paper);
  transition: transform .2s ease, opacity .2s ease;
}
.nav-open .nav-toggle span { opacity: 0; }
.nav-open .nav-toggle::before { transform: translateY(6px) rotate(45deg); }
.nav-open .nav-toggle::after { transform: translateY(-6px) rotate(-45deg); }

.hero {
  position: relative;
  min-height: min(980px, 100svh);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  isolation: isolate;
}
.hero-media,
.hero-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-media { z-index: -3; object-fit: cover; object-position: 50% 52%; transform: scale(1.015); }
.hero-shade {
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(5, 6, 5, .93) 0, rgba(5, 6, 5, .68) 38%, rgba(5, 6, 5, .15) 72%),
    linear-gradient(0deg, rgba(5, 6, 5, .96) 0, rgba(5, 6, 5, .14) 56%, rgba(5, 6, 5, .55) 100%);
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(circle at 70% 44%, transparent 0 20%, rgba(4, 5, 4, .18) 58%, rgba(4, 5, 4, .5) 100%);
}
.hero-inner { padding: 150px 0 84px; }
.hero h1 {
  max-width: 1050px;
  margin: 15px 0 24px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(4.2rem, 10vw, 10.5rem);
  line-height: .82;
  letter-spacing: -.055em;
}
.hero-deck { max-width: 770px; margin: 0; color: var(--paper-soft); font-size: clamp(1.08rem, 2vw, 1.42rem); line-height: 1.52; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 18px;
  border: 1px solid var(--line-strong);
  background: transparent;
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.button:hover { color: var(--ink); background: var(--paper); border-color: var(--paper); }
.button-primary { color: var(--ink); background: var(--paper); border-color: var(--paper); }
.button-primary:hover { color: var(--paper); background: var(--red); border-color: var(--red); }

.section { padding: clamp(84px, 10vw, 150px) 0; border-top: 1px solid var(--line); }
.section-dark { background: var(--ink-2); }
.section-grid { display: grid; grid-template-columns: minmax(0, .78fr) minmax(0, 1.22fr); gap: clamp(48px, 8vw, 130px); }
.section h2,
.page-hero h1,
.project-title,
.archive-title,
.feature-title {
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -.035em;
}
.section h2 { margin: 12px 0 0; font-size: clamp(2.8rem, 5.4vw, 5.6rem); line-height: .98; }
.section-copy { color: var(--paper-soft); font-size: 1.05rem; }
.section-copy p:first-child { margin-top: 0; }
.section-copy p:last-child { margin-bottom: 0; }
.lead { color: var(--paper); font-family: var(--serif); font-size: clamp(1.35rem, 2.6vw, 2.1rem); line-height: 1.35; }

.selected-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 18px;
  margin-top: 54px;
}
.project-card {
  grid-column: span 6;
  position: relative;
  min-height: 520px;
  overflow: hidden;
  background: var(--ink-3);
  border: 1px solid var(--line);
  isolation: isolate;
}
.project-card:nth-child(1), .project-card:nth-child(4) { grid-column: span 7; }
.project-card:nth-child(2), .project-card:nth-child(3) { grid-column: span 5; }
.card-image, .card-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.card-image { z-index: -2; object-fit: cover; transition: transform .7s cubic-bezier(.2,.7,.2,1), filter .4s ease; }
.card-shade { z-index: -1; background: linear-gradient(0deg, rgba(4,5,4,.96), rgba(4,5,4,.12) 72%); }
.project-card:hover .card-image { transform: scale(1.035); filter: saturate(.82) contrast(1.05); }
.card-copy { position: absolute; inset: auto 0 0; padding: 28px; }
.card-copy h3 { margin: 8px 0 10px; font-family: var(--serif); font-size: clamp(2rem, 3.2vw, 3.7rem); font-weight: 400; line-height: 1; }
.card-copy p { max-width: 650px; margin: 0; color: var(--paper-soft); }
.card-meta { color: var(--paper-faint); }
.card-arrow { display: inline-flex; margin-top: 18px; font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.card-arrow::after { content: "→"; margin-left: 10px; transition: transform .2s ease; }
.project-card:hover .card-arrow::after { transform: translateX(5px); }

.activity-list { display: grid; gap: 0; border-top: 1px solid var(--line); }
.activity-item { display: grid; grid-template-columns: 110px minmax(0, .7fr) minmax(0, 1.3fr); gap: 24px; padding: 24px 0; border-bottom: 1px solid var(--line); }
.activity-item strong { font-family: var(--serif); font-size: 1.32rem; font-weight: 400; }
.activity-item span:last-child { color: var(--paper-soft); }

.quote-band { padding: clamp(70px, 9vw, 130px) 0; background: #c8b28f; color: #16140f; }
.quote-band blockquote { max-width: 1100px; margin: 0; font-family: var(--serif); font-size: clamp(2.2rem, 5vw, 5.1rem); line-height: 1.04; letter-spacing: -.035em; }
.quote-band cite { display: block; margin-top: 24px; font-family: var(--sans); font-size: .72rem; font-style: normal; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }

.page-hero { padding: 175px 0 80px; border-bottom: 1px solid var(--line); background: radial-gradient(circle at 80% 10%, rgba(176,138,88,.12), transparent 35%); }
.page-hero h1 { max-width: 980px; margin: 14px 0 20px; font-size: clamp(4rem, 9vw, 9rem); line-height: .88; }
.page-hero p { max-width: 780px; color: var(--paper-soft); font-size: 1.16rem; }
.page-hero .lead { color: var(--paper); }

.archive-toolbar { position: sticky; top: 78px; z-index: 30; padding: 14px 0; border-bottom: 1px solid var(--line); background: rgba(9,10,9,.94); backdrop-filter: blur(16px); }
.archive-filters { display: flex; gap: 9px; overflow-x: auto; scrollbar-width: none; }
.archive-filters::-webkit-scrollbar { display: none; }
.archive-filter { flex: 0 0 auto; padding: 9px 12px; border: 1px solid var(--line); color: var(--paper-soft); background: transparent; cursor: pointer; }
.archive-filter:hover, .archive-filter.is-active { color: var(--ink); border-color: var(--paper); background: var(--paper); }
.archive-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; padding: 52px 0 110px; }
.archive-card { grid-column: span 4; min-width: 0; border: 1px solid var(--line); background: var(--ink-2); transition: transform .25s ease, border-color .25s ease; }
.archive-card:hover { transform: translateY(-4px); border-color: var(--line-strong); }
.archive-card[hidden] { display: none; }
.archive-image-wrap { aspect-ratio: 4 / 3; overflow: hidden; background: linear-gradient(135deg, #26221c, #0f1110); }
.archive-image { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.archive-card:hover .archive-image { transform: scale(1.025); }
.archive-placeholder { height: 100%; display: flex; align-items: flex-end; padding: 24px; background: radial-gradient(circle at 75% 20%, rgba(176,138,88,.22), transparent 35%), repeating-linear-gradient(0deg, transparent 0 23px, rgba(236,230,216,.04) 24px 25px); }
.archive-placeholder span { font-family: var(--serif); font-size: clamp(2rem, 4vw, 4.2rem); line-height: .95; }
.archive-copy { padding: 22px; }
.archive-copy h2 { margin: 8px 0 9px; font-family: var(--serif); font-size: 2rem; font-weight: 400; line-height: 1.05; }
.archive-copy p { margin: 0; color: var(--paper-soft); }
.archive-copy .card-arrow { margin-top: 15px; }

.project-hero { position: relative; min-height: 82svh; display: flex; align-items: flex-end; overflow: hidden; isolation: isolate; }
.project-hero-image, .project-hero-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.project-hero-image { z-index: -2; object-fit: cover; }
.project-hero-shade { z-index: -1; background: linear-gradient(0deg, rgba(5,6,5,.97), rgba(5,6,5,.18) 62%, rgba(5,6,5,.58)); }
.project-hero-inner { padding: 170px 0 70px; }
.project-title { max-width: 1050px; margin: 14px 0 22px; font-size: clamp(3.7rem, 9vw, 9.4rem); line-height: .86; }
.project-meta { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; max-width: 980px; margin-top: 34px; padding-top: 18px; border-top: 1px solid var(--line-strong); }
.project-meta div { color: var(--paper-soft); }
.project-meta span { display: block; margin-bottom: 5px; color: var(--paper-faint); font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }

.text-only-project { padding-top: 175px; background: radial-gradient(circle at 72% 12%, rgba(102,127,139,.18), transparent 30%), linear-gradient(135deg, #161713, #080908 70%); }
.text-only-project .project-hero-inner { padding-top: 80px; }

.project-body { padding: 92px 0 130px; }
.project-intro { display: grid; grid-template-columns: .75fr 1.25fr; gap: clamp(40px, 8vw, 120px); padding-bottom: 90px; border-bottom: 1px solid var(--line); }
.project-intro .lead { margin-top: 0; }
.project-section { display: grid; grid-template-columns: .7fr 1.3fr; gap: clamp(40px, 8vw, 120px); padding: 72px 0; border-bottom: 1px solid var(--line); }
.project-section h2 { margin: 0; font-family: var(--serif); font-size: clamp(2.2rem, 4vw, 4.2rem); font-weight: 400; line-height: 1; }
.project-section-copy { max-width: 780px; color: var(--paper-soft); }
.project-section-copy p:first-child { margin-top: 0; }
.project-gallery { padding: 90px 0 10px; }
.gallery-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; margin-top: 36px; }
.gallery-item { grid-column: span 6; margin: 0; }
.gallery-item:nth-child(3n+1) { grid-column: span 12; }
.gallery-button { width: 100%; padding: 0; border: 0; background: transparent; cursor: zoom-in; }
.gallery-button img { display: block; width: 100%; max-height: 820px; object-fit: cover; }
.gallery-item figcaption { display: flex; justify-content: space-between; gap: 20px; padding-top: 10px; color: var(--paper-faint); font-size: .78rem; }
.project-credits { margin-top: 76px; padding: 28px; border: 1px solid var(--line); background: var(--ink-2); }
.project-credits h2 { margin: 0 0 10px; font-family: var(--serif); font-weight: 400; }
.project-credits ul { margin: 0; padding-left: 18px; color: var(--paper-soft); }
.project-pagination { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); }
.project-pagination a { padding: 32px 4vw; border-right: 1px solid var(--line); transition: background .2s ease; }
.project-pagination a:last-child { border-right: 0; text-align: right; }
.project-pagination a:hover { background: var(--ink-2); }
.project-pagination span { display: block; color: var(--paper-faint); font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.project-pagination strong { display: block; margin-top: 6px; font-family: var(--serif); font-size: 1.5rem; font-weight: 400; }

.timeline { position: relative; margin-top: 42px; border-top: 1px solid var(--line); }
.timeline-item { display: grid; grid-template-columns: 160px minmax(0, 1fr); gap: 32px; padding: 28px 0; border-bottom: 1px solid var(--line); }
.timeline-year { color: var(--amber); font-family: var(--mono); font-size: .88rem; }
.timeline-item h3 { margin: 0 0 6px; font-family: var(--serif); font-size: 1.55rem; font-weight: 400; }
.timeline-item p { margin: 0; color: var(--paper-soft); }

.research-cards, .lab-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; margin-top: 42px; }
.research-card, .lab-card { grid-column: span 6; min-height: 330px; padding: 30px; border: 1px solid var(--line); background: var(--ink-2); }
.research-card h3, .lab-card h3 { margin: 10px 0 12px; font-family: var(--serif); font-size: 2rem; font-weight: 400; }
.research-card p, .lab-card p { color: var(--paper-soft); }
.lab-card { position: relative; overflow: hidden; }
.lab-card::after { content: attr(data-index); position: absolute; right: 18px; bottom: -30px; color: rgba(236,230,216,.035); font-family: var(--serif); font-size: 10rem; line-height: 1; }
.status { display: inline-flex; padding: 6px 8px; border: 1px solid var(--line-strong); color: var(--paper-faint); font-size: .67rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }

.cv-nav { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.cv-nav a { padding: 8px 10px; border: 1px solid var(--line); color: var(--paper-soft); font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.cv-section { padding: 56px 0; border-top: 1px solid var(--line); scroll-margin-top: 100px; }
.cv-section h2 { margin: 0 0 26px; font-family: var(--serif); font-size: clamp(2.2rem, 4vw, 4rem); font-weight: 400; }
.cv-list { margin: 0; padding: 0; list-style: none; }
.cv-list li { display: grid; grid-template-columns: 130px minmax(0, 1fr); gap: 24px; padding: 13px 0; border-top: 1px solid rgba(236,230,216,.08); }
.cv-list time { color: var(--paper-faint); font-family: var(--mono); font-size: .83rem; }
.cv-list span { color: var(--paper-soft); }

.contact-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(50px, 9vw, 140px); }
.contact-links { padding-top: 20px; }
.contact-links a { display: block; padding: 14px 0; border-top: 1px solid var(--line); font-family: var(--serif); font-size: 1.35rem; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: grid; gap: 7px; }
.field-full { grid-column: 1 / -1; }
.field label { color: var(--paper-soft); font-size: .76rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.field input, .field textarea, .field select {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: 0;
  padding: 13px 14px;
  color: var(--paper);
  background: var(--ink-2);
}
.field textarea { min-height: 180px; resize: vertical; }
.honeypot { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.form-note { color: var(--paper-faint); font-size: .82rem; }
.form-message { margin-bottom: 22px; padding: 14px 16px; border: 1px solid var(--line-strong); }
.form-message.success { border-color: #708b6c; }
.form-message.error { border-color: var(--red); }

.privacy-copy h2 { margin-top: 50px; font-family: var(--serif); font-size: 2rem; font-weight: 400; }
.privacy-copy p, .privacy-copy li { color: var(--paper-soft); }

.lightbox[hidden] { display: none; }
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 1500;
  display: grid;
  place-items: center;
  padding: 28px;
  background: rgba(3,4,3,.94);
}
.lightbox-inner { position: relative; width: min(1180px, 100%); max-height: 92svh; }
.lightbox img { display: block; width: 100%; max-height: 82svh; object-fit: contain; }
.lightbox-caption { margin: 10px 58px 0 0; color: var(--paper-soft); font-size: .82rem; }
.lightbox-close { position: absolute; top: -12px; right: -12px; width: 46px; height: 46px; border: 1px solid var(--line-strong); background: var(--ink); cursor: pointer; }

.site-footer { padding: 70px 0 34px; border-top: 1px solid var(--line); background: var(--ink-2); }
.footer-grid { display: grid; grid-template-columns: 1.3fr .7fr .7fr; gap: 42px; }
.footer-title { max-width: 620px; margin: 10px 0 0; font-family: var(--serif); font-size: clamp(2.3rem, 4.4vw, 4.6rem); font-weight: 400; line-height: 1; }
.footer-links { display: grid; align-content: start; gap: 8px; }
.footer-links a { color: var(--paper-soft); }
.footer-links a:hover { color: var(--paper); }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; margin-top: 60px; padding-top: 20px; border-top: 1px solid var(--line); color: var(--paper-faint); font-size: .76rem; }

.reveal { opacity: 1; transform: none; }
.js .reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
.js .reveal.visible { opacity: 1; transform: none; }

@media (max-width: 1050px) {
  .archive-card { grid-column: span 6; }
  .project-card, .project-card:nth-child(n) { grid-column: span 6; }
  .activity-item { grid-template-columns: 88px 1fr; }
  .activity-item span:last-child { grid-column: 2; }
}

@media (max-width: 820px) {
  .shell { width: min(calc(100% - 28px), var(--max)); }
  .header-inner { min-height: 68px; }
  .nav-toggle { display: block; }
  .site-nav {
    position: fixed;
    inset: 68px 0 auto;
    display: grid;
    gap: 0;
    max-height: 0;
    overflow: hidden;
    background: rgba(9,10,9,.98);
    border-bottom: 1px solid transparent;
    transition: max-height .25s ease, border-color .25s ease;
  }
  .nav-open .site-nav { max-height: 520px; border-color: var(--line); }
  .site-nav a { padding: 15px 22px; border-top: 1px solid var(--line); }
  .site-nav a::after { display: none; }
  .hero { min-height: 860px; }
  .hero-inner { padding-bottom: 56px; }
  .hero h1 { font-size: clamp(4rem, 18vw, 7.7rem); }
  .section-grid, .project-intro, .project-section, .contact-grid { grid-template-columns: 1fr; }
  .section-grid, .project-intro, .project-section { gap: 30px; }
  .project-meta { grid-template-columns: 1fr; gap: 12px; }
  .project-card, .project-card:nth-child(n) { grid-column: span 12; min-height: 470px; }
  .research-card, .lab-card { grid-column: span 12; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid > :first-child { grid-column: 1 / -1; }
  .project-pagination { grid-template-columns: 1fr; }
  .project-pagination a { border-right: 0; border-bottom: 1px solid var(--line); }
  .project-pagination a:last-child { text-align: left; border-bottom: 0; }
}

@media (max-width: 620px) {
  .archive-filters { flex-wrap: wrap; overflow-x: visible; }
  .archive-filter { padding: 8px 10px; font-size: .7rem; }
  .hero { min-height: 800px; }
  .hero h1 { font-size: clamp(3.5rem, 20vw, 6.5rem); }
  .hero-deck { font-size: 1rem; }
  .selected-grid, .archive-grid { display: block; }
  .project-card, .archive-card { margin-bottom: 16px; }
  .archive-card { width: 100%; }
  .archive-image-wrap { aspect-ratio: 5 / 4; }
  .card-copy { padding: 21px; }
  .page-hero { padding-top: 135px; }
  .page-hero h1, .project-title { font-size: clamp(3.3rem, 18vw, 6.2rem); }
  .timeline-item, .cv-list li { grid-template-columns: 1fr; gap: 7px; }
  .gallery-grid { display: block; }
  .gallery-item { margin-bottom: 28px; }
  .gallery-item figcaption { display: block; }
  .form-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-grid > :first-child { grid-column: auto; }
  .footer-bottom { display: block; }
  .footer-bottom span { display: block; margin-top: 6px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .js .reveal { opacity: 1; transform: none; }
}
.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.nav-toggle .visually-hidden { display: block; width: 1px !important; height: 1px !important; margin: -1px !important; background: transparent !important; }

/* v2.0 broad-practice homepage and flat-file release */
.hero-broad{min-height:94svh;position:relative;overflow:hidden;background:#090a09}
.hero-mosaic{position:absolute;inset:0;display:grid;grid-template-columns:1.25fr .75fr;grid-template-rows:1fr 1fr;gap:2px;background:#171817}
.hero-mosaic-image{width:100%;height:100%;object-fit:cover;filter:saturate(.68) contrast(1.04);opacity:.82}
.hero-mosaic-image:first-child{grid-row:1 / span 2}
.hero-broad .hero-shade{background:linear-gradient(90deg,rgba(4,5,4,.94) 0%,rgba(4,5,4,.72) 36%,rgba(4,5,4,.22) 72%,rgba(4,5,4,.42) 100%),linear-gradient(0deg,rgba(4,5,4,.72),transparent 55%)}
.hero-subdeck{max-width:700px;margin:.9rem 0 0;color:var(--muted);font-size:clamp(1rem,1.4vw,1.22rem);line-height:1.65}
.practice-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;margin-top:2.5rem;background:var(--line)}
.practice-card{background:var(--black);padding:clamp(1.4rem,2.4vw,2.2rem);min-height:280px}
.practice-card>span,.placeholder-index{display:block;color:var(--accent);font-family:var(--sans);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:2rem}
.practice-card h3{font-size:clamp(1.25rem,2vw,1.8rem);margin:0 0 1rem}
.practice-card p{color:var(--muted);margin:0;line-height:1.65}
.archive-heading{display:flex;justify-content:space-between;gap:2rem;align-items:end;margin-bottom:2.2rem}
.archive-placeholder,.project-placeholder{display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;gap:.5rem;padding:1.4rem;background:radial-gradient(circle at 76% 20%,rgba(159,73,55,.22),transparent 28%),linear-gradient(145deg,#151714,#080908);color:var(--ivory);min-height:100%}
.archive-placeholder strong,.project-placeholder strong{font-family:var(--serif);font-size:clamp(1.3rem,2vw,2rem);line-height:1.06}
.archive-placeholder small,.project-placeholder small{font-family:var(--sans);font-size:.68rem;letter-spacing:.11em;text-transform:uppercase;color:var(--muted)}
.project-placeholder{position:absolute;inset:0;padding:clamp(2rem,7vw,7rem);justify-content:center;opacity:.78}
.text-only-project .project-hero-inner{position:relative;z-index:2}
.lab-card .card-arrow{display:inline-block;margin-top:1.2rem}
@media(max-width:980px){.practice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-mosaic{grid-template-columns:1fr 1fr}.hero-mosaic-image:first-child{grid-row:auto}.hero-broad .hero-shade{background:linear-gradient(90deg,rgba(4,5,4,.92),rgba(4,5,4,.56)),linear-gradient(0deg,rgba(4,5,4,.76),transparent 58%)}}
@media(max-width:680px){.hero-broad{min-height:90svh}.hero-mosaic{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.hero-mosaic-image{opacity:.52}.hero-broad .hero-shade{background:linear-gradient(0deg,rgba(4,5,4,.96) 0%,rgba(4,5,4,.68) 68%,rgba(4,5,4,.52) 100%)}.practice-grid{grid-template-columns:1fr}.practice-card{min-height:0}.archive-heading{display:block}.archive-heading .button{margin-top:1rem}.hero-actions .button{margin-bottom:.45rem}}
/* v2.0.1 hero stacking correction */
.hero-mosaic{z-index:-3;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
.hero-mosaic-image:first-child{grid-row:auto}
.hero-inner{position:relative;z-index:1}

/* v2.1 refinement pass: single-image homepage, project-first archive, varied about page */
:root{--muted:var(--paper-soft);--black:var(--ink);--accent:var(--amber);--ivory:var(--paper)}
.hero-single .hero-media{opacity:.86;filter:saturate(.62) contrast(1.06) brightness(.82);object-position:50% 48%}
.hero-single .hero-shade{background:linear-gradient(90deg,rgba(4,5,4,.96) 0%,rgba(4,5,4,.78) 38%,rgba(4,5,4,.34) 68%,rgba(4,5,4,.22) 100%),linear-gradient(0deg,rgba(4,5,4,.90) 0%,rgba(4,5,4,.22) 58%,rgba(4,5,4,.62) 100%)}
.hero-single::after{background:radial-gradient(circle at 68% 46%,transparent 0 20%,rgba(4,5,4,.16) 56%,rgba(4,5,4,.58) 100%)}
.hero-single .hero-inner{max-width:var(--max)}
.about-split{display:grid;grid-template-columns:minmax(280px,.82fr) minmax(0,1.18fr);gap:clamp(34px,6vw,90px);align-items:center}
.about-image{margin:0;border:1px solid var(--line);background:var(--ink);box-shadow:var(--shadow)}
.about-image img{display:block;width:100%;aspect-ratio:1/1;object-fit:cover;filter:saturate(.72) contrast(1.04)}
.about-image figcaption{padding:12px 14px;color:var(--paper-faint);font-size:.75rem;letter-spacing:.04em;border-top:1px solid var(--line)}
.about-panel{padding:clamp(24px,4vw,54px);border:1px solid var(--line);background:linear-gradient(145deg,rgba(23,24,21,.72),rgba(9,10,9,.5))}
.about-panel h2{margin:12px 0 28px;font-family:var(--serif);font-size:clamp(2.6rem,5vw,5rem);font-weight:400;line-height:.98;letter-spacing:-.035em}
.mode-list{display:grid;gap:0;border-top:1px solid var(--line)}
.mode-list article{display:grid;grid-template-columns:130px minmax(0,1fr);gap:22px;padding:20px 0;border-bottom:1px solid var(--line)}
.mode-list span{color:var(--amber);font-family:var(--mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em}
.mode-list p{margin:0;color:var(--paper-soft)}
.cv-item{display:grid;grid-template-columns:130px minmax(0,1fr);gap:24px;padding:13px 0;border-top:1px solid rgba(236,230,216,.08)}
.cv-item span{color:var(--paper-faint);font-family:var(--mono);font-size:.83rem}.cv-item p{margin:0;color:var(--paper-soft)}
@media(max-width:820px){.about-split{grid-template-columns:1fr}.about-panel{padding:24px}.mode-list article{grid-template-columns:1fr;gap:6px}.hero-single .hero-media{opacity:.5}.hero-single .hero-shade{background:linear-gradient(0deg,rgba(4,5,4,.96) 0%,rgba(4,5,4,.76) 62%,rgba(4,5,4,.66) 100%)}}


/* v2.2 refinements: broader landing image, highlights, mobile filter select, desktop project back button */
.home-hero-focus{object-position:56% 54%}
.highlights-section{padding-top:clamp(58px,7vw,96px);padding-bottom:clamp(58px,7vw,96px);background:linear-gradient(180deg,rgba(16,17,15,.96),rgba(9,10,9,1));}
.highlight-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:var(--line);border:1px solid var(--line);}
.highlight-card{background:var(--ink-2);min-height:260px;transition:background .2s ease, transform .2s ease;}
.highlight-card a{display:flex;min-height:260px;flex-direction:column;justify-content:flex-end;padding:clamp(22px,3vw,34px);}
.highlight-card:hover{background:#181914;transform:translateY(-2px)}
.highlight-card h3{margin:.55rem 0 .7rem;font-family:var(--serif);font-size:clamp(1.7rem,2.4vw,2.7rem);font-weight:400;line-height:1.02;}
.highlight-card p{margin:0;color:var(--paper-soft);}
.archive-filter-shell{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.filter-select-label{display:block;color:var(--paper-faint);font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;}
.archive-filter-select{display:block;min-height:44px;width:min(100%,360px);border:1px solid var(--line-strong);background:var(--ink);color:var(--paper);padding:8px 12px;border-radius:0;}
.desktop-back{position:fixed;top:96px;left:clamp(20px,3vw,52px);z-index:700;display:inline-flex;align-items:center;min-height:40px;padding:8px 12px;border:1px solid var(--line-strong);background:rgba(9,10,9,.66);backdrop-filter:blur(12px);color:var(--paper-soft);font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:background .2s ease,color .2s ease,border-color .2s ease;}
.desktop-back:hover{color:var(--ink);background:var(--paper);border-color:var(--paper);}
.focus-deities{object-position:82% 48%;}
.project-hero-image.focus-deities{object-position:76% 50%;}
.archive-image[src*="cybernauts-panel"]{filter:saturate(.82) contrast(1.06);}
@media(max-width:820px){
  .highlight-grid{grid-template-columns:1fr;}
  .highlight-card,.highlight-card a{min-height:190px;}
  .desktop-back{display:none;}
  .archive-toolbar{top:68px;padding:10px 0;}
  .archive-filter-shell{display:grid;grid-template-columns:auto minmax(0,1fr);gap:9px 12px;align-items:center;}
  .filter-select-label,.archive-filter-select{display:block;}
  .archive-filter-select{width:100%;}
  .archive-filters{display:none;}
}
@media(max-width:620px){.archive-toolbar{padding:8px 0}.archive-grid{padding-top:30px}.page-hero p{font-size:1.02rem}.home-hero-focus{object-position:58% 50%}}


/* v2.3: dropdown-only Work filter; hide legacy button block if cached markup remains. */
@media(max-width:820px){.archive-filters{display:none!important;}}
