/* ============================================================
   Two Minds Solutions FZ LLC
   Editorial dark — single-page site
   ============================================================ */

/* -------- Tokens -------- */
:root {
  --ink:    #0b0b0d;
  --ink-2:  #131317;
  --ink-3:  #1a1a20;
  --paper:  #ece8df;
  --paper-2:#f6f3ec;
  --muted:  #8a857a;
  --muted-2:#5b574f;
  --gold:   #c9a96a;
  --gold-2: #d8be83;
  --ember:  #e76f51;
  --rule:   rgba(236, 232, 223, 0.10);
  --rule-2: rgba(236, 232, 223, 0.18);

  --serif:  "Newsreader", "Iowan Old Style", "Hoefler Text", Georgia, serif;
  --display:"Fraunces", "Newsreader", "Hoefler Text", Georgia, serif;
  --mono:   "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  --max:   1280px;
  --gut:   clamp(20px, 4vw, 56px);

  --ease:  cubic-bezier(0.2, 0.7, 0, 1);
}

/* -------- Reset-ish -------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

html, body {
  margin: 0;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body {
  overflow-x: clip;
  position: relative;
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(201,169,106,0.08), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(231,111,81,0.06), transparent 60%),
    var(--ink);
}

img, svg { display: block; max-width: 100%; }

a { color: inherit; text-decoration: none; }

::selection { background: var(--gold); color: var(--ink); }

/* -------- Global decoration -------- */
.grain {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: overlay;
  opacity: 0.18;
}

.column-rules {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--gut);
  height: 100%;
}
.column-rules span {
  border-left: 1px solid var(--rule);
  height: 100%;
}
.column-rules span:last-child {
  border-right: 1px solid var(--rule);
}
@media (max-width: 720px) {
  .column-rules { display: none; }
}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  background: linear-gradient(to bottom, rgba(11,11,13,0.85), rgba(11,11,13,0.55));
  border-bottom: 1px solid var(--rule);
}

.topbar__inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 14px var(--gut);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
}

.wordmark {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--paper);
}
.wordmark__mark {
  width: 44px;
  height: 22px;
  color: var(--gold);
}
.wordmark__text {
  font-family: var(--display);
  font-weight: 500;
  font-size: 19px;
  letter-spacing: 0.01em;
  font-variation-settings: "opsz" 24, "SOFT" 50;
}
.wordmark__dot {
  color: var(--gold);
  margin: 0 2px;
}

.edition {
  justify-self: center;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.edition__bullet {
  width: 6px; height: 6px;
  background: var(--ember);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(231,111,81,0.18);
  animation: pulse 2.4s ease-in-out infinite;
}
.edition__sep { color: var(--muted-2); }
@media (max-width: 1080px) { .edition { display: none; } }

.nav {
  display: inline-flex;
  align-items: center;
  gap: 22px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--paper);
}
.nav a {
  position: relative;
  padding: 6px 0;
  display: inline-flex;
  gap: 6px;
  align-items: baseline;
  transition: color 0.3s var(--ease);
}
.nav__num {
  color: var(--gold);
  font-size: 10px;
}
.nav a::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.4s var(--ease);
}
.nav a:hover { color: var(--gold-2); }
.nav a:hover::after { transform: scaleX(1); }
@media (max-width: 760px) {
  .nav { display: none; }
}

@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(231,111,81,0.18); }
  50%      { box-shadow: 0 0 0 7px rgba(231,111,81,0.04); }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: clamp(720px, 100vh, 1000px);
  padding: 96px var(--gut) 80px;
  overflow: hidden;
  isolation: isolate;
}

.hero__sky {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.85;
}

.hero__inner {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  grid-template-rows: auto auto auto auto auto;
  column-gap: clamp(24px, 5vw, 80px);
  row-gap: 28px;
  align-items: end;
  position: relative;
}

.hero__kicker {
  grid-column: 1 / -1;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 24px;
}
.kicker__rule {
  display: inline-block;
  width: 56px;
  height: 1px;
  background: var(--gold);
}

.hero__title {
  grid-column: 1 / 2;
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(56px, 9.5vw, 156px);
  line-height: 0.92;
  letter-spacing: -0.025em;
  margin: 0;
  font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 0;
}
.hero__line {
  display: block;
  color: var(--paper);
}
.hero__line--em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold);
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
  padding-left: 0.6em;
}

.hero__lede {
  grid-column: 1 / 2;
  max-width: 56ch;
  font-size: clamp(17px, 1.5vw, 21px);
  line-height: 1.55;
  color: rgba(236,232,223,0.82);
  margin: 8px 0 0;
}
.hero__lede em {
  font-style: italic;
  color: var(--gold);
}

.hero__meta {
  grid-column: 1 / 2;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 32px;
  padding-top: 22px;
  border-top: 1px solid var(--rule-2);
}
.meta__cell {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.meta__label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}
.meta__value {
  font-family: var(--display);
  font-size: 15px;
  color: var(--paper);
  font-style: italic;
  font-variation-settings: "opsz" 24;
}

.hero__mark {
  grid-column: 2 / 3;
  grid-row: 2 / 5;
  align-self: center;
  justify-self: end;
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  position: relative;
}
.mark {
  width: clamp(220px, 32vw, 380px);
  height: auto;
  color: var(--paper);
  filter: drop-shadow(0 24px 60px rgba(201,169,106,0.18));
  animation: floatSlow 9s ease-in-out infinite;
}
@keyframes floatSlow {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-8px) rotate(-0.4deg); }
}

.mark__pair { transform-origin: 160px 160px; }
.mark__circle {
  stroke-dasharray: 500;
  stroke-dashoffset: 500;
  animation: drawCircle 2.4s var(--ease) 0.6s forwards;
}
.mark__circle--b { animation-delay: 0.9s; }
.mark__vesica {
  stroke-dasharray: 500;
  stroke-dashoffset: 500;
  animation: drawCircle 2s var(--ease) 1.6s forwards;
}
.mark__center {
  opacity: 0;
  transform-origin: 160px 160px;
  transform: scale(0.6);
  animation: popIn 0.6s var(--ease) 2.4s forwards;
}
@keyframes drawCircle {
  to { stroke-dashoffset: 0; }
}
@keyframes popIn {
  to { opacity: 1; transform: scale(1); }
}
.hero__mark:hover .mark__pair {
  animation: spin 12s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}

.hero__mark-caption {
  display: flex;
  gap: 10px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.hero__mark-caption span:first-child { color: var(--gold); }

.hero__scroll {
  grid-column: 1 / -1;
  margin-top: 56px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  width: fit-content;
}
.hero__scroll svg { width: 18px; height: 30px; color: var(--paper); }
.hero__scroll-dot {
  animation: scrollDot 2s ease-in-out infinite;
}
@keyframes scrollDot {
  0%   { transform: translateY(0);   opacity: 1; }
  60%  { transform: translateY(14px); opacity: 0; }
  100% { transform: translateY(0);   opacity: 1; }
}

@media (max-width: 760px) {
  .hero__inner {
    grid-template-columns: 1fr;
  }
  .hero__title, .hero__lede, .hero__meta { grid-column: 1 / -1; }
  .hero__mark {
    grid-column: 1 / -1;
    grid-row: auto;
    justify-self: center;
    margin-top: 24px;
  }
  .hero__meta { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee {
  border-top: 1px solid var(--rule-2);
  border-bottom: 1px solid var(--rule-2);
  background: var(--ink-2);
  overflow: hidden;
  padding: 22px 0;
}
.marquee__track {
  display: inline-flex;
  white-space: nowrap;
  align-items: center;
  gap: 28px;
  font-family: var(--display);
  font-style: italic;
  font-size: clamp(28px, 4vw, 56px);
  font-variation-settings: "opsz" 144, "SOFT" 70;
  font-weight: 300;
  color: var(--paper);
  animation: marquee 40s linear infinite;
  padding-left: 28px;
}
.marquee__track .m-dot { color: var(--gold); font-size: 0.5em; }
@keyframes marquee {
  to { transform: translateX(-50%); }
}

/* ============================================================
   SECTION SHARED
   ============================================================ */
section {
  position: relative;
  padding: clamp(80px, 10vw, 140px) var(--gut);
  max-width: var(--max);
  margin: 0 auto;
}

.section-head {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: end;
  gap: 18px;
  margin-bottom: clamp(36px, 5vw, 64px);
}
.section-head__num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
  padding-bottom: 6px;
}
.section-head__title {
  margin: 0;
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(40px, 6vw, 84px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 96, "SOFT" 40;
  font-style: italic;
  color: var(--paper);
}
.section-head__rule {
  height: 1px;
  background: linear-gradient(to right, var(--rule-2), transparent);
  align-self: end;
  margin-bottom: 18px;
}

.section-lede {
  max-width: 56ch;
  font-size: clamp(17px, 1.4vw, 20px);
  color: rgba(236,232,223,0.78);
  margin: 0 0 clamp(48px, 6vw, 80px);
}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: start;
}
.manifesto__lead {
  font-family: var(--display);
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.35;
  color: var(--paper);
  font-variation-settings: "opsz" 72, "SOFT" 60;
  margin: 0;
  grid-column: 1 / 2;
}
.dropcap {
  float: left;
  font-family: var(--display);
  font-style: normal;
  font-weight: 700;
  font-size: 4.4em;
  line-height: 0.85;
  padding: 6px 14px 0 0;
  color: var(--gold);
  font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 1;
}

.pullquote {
  position: relative;
  grid-column: 2 / 3;
  padding: 28px 28px 28px 56px;
  border-left: 1px solid var(--gold);
  background: linear-gradient(to right, rgba(201,169,106,0.05), transparent 80%);
  color: var(--gold);
}
.pullquote__mark {
  position: absolute;
  top: 18px;
  left: 14px;
  width: 32px;
  height: 32px;
  color: var(--gold);
  opacity: 0.7;
}
.pullquote blockquote {
  margin: 0;
  font-family: var(--display);
  font-style: italic;
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.4;
  color: var(--gold-2);
  font-variation-settings: "opsz" 60, "SOFT" 60;
}

.manifesto__body {
  grid-column: 1 / -1;
  margin-top: 32px;
  columns: 2;
  column-gap: clamp(28px, 4vw, 64px);
  color: rgba(236,232,223,0.82);
  font-size: 17px;
  line-height: 1.65;
}
.manifesto__body p { margin: 0 0 1em; break-inside: avoid; }

.ornament {
  display: block;
  margin: 64px auto 0;
  width: min(420px, 60%);
  color: var(--muted-2);
}

@media (max-width: 800px) {
  .manifesto__grid { grid-template-columns: 1fr; }
  .pullquote { grid-column: 1; }
  .manifesto__body { columns: 1; }
}

/* ============================================================
   PRACTICE / CARDS
   ============================================================ */
.cards {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(20px, 2.5vw, 36px);
}
.card {
  position: relative;
  padding: 36px 32px 32px;
  background: var(--ink-2);
  border: 1px solid var(--rule-2);
  color: var(--paper);
  overflow: hidden;
  transition: transform 0.5s var(--ease), border-color 0.5s var(--ease), background 0.5s var(--ease);
}
.card:nth-child(1) { grid-column: span 7; }
.card:nth-child(2) { grid-column: span 5; }
.card:nth-child(3) { grid-column: span 5; }
.card:nth-child(4) { grid-column: span 7; }

.card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(360px 220px at var(--mx, 80%) var(--my, 0%),
      rgba(201,169,106,0.12), transparent 60%);
  opacity: 0;
  transition: opacity 0.6s var(--ease);
  pointer-events: none;
}
.card:hover {
  transform: translateY(-4px);
  border-color: rgba(201,169,106,0.45);
  background: var(--ink-3);
}
.card:hover::before { opacity: 1; }

.card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 24px;
}
.card__num { color: var(--gold); font-style: italic; }

.card__icon {
  width: 96px;
  height: 96px;
  color: var(--paper);
  margin-bottom: 28px;
  transition: transform 0.6s var(--ease);
}
.card:hover .card__icon { transform: rotate(-3deg) scale(1.04); }
.card__orbit { transform-origin: 60px 60px; transition: transform 1.2s var(--ease); }
.card:hover .card__orbit { transform: rotate(20deg); }
.card__layer { transition: transform 0.6s var(--ease); }
.card:hover .card__layer { transform: translate(-4px, -4px); }

.card__title {
  margin: 0 0 12px;
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(28px, 2.8vw, 38px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--paper);
  font-variation-settings: "opsz" 96, "SOFT" 60;
}
.card--accent .card__title { color: var(--gold-2); }

.card__body {
  font-size: 16px;
  line-height: 1.6;
  color: rgba(236,232,223,0.78);
  margin: 0 0 24px;
  max-width: 48ch;
}

.card__chips {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.card__chips li {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  border: 1px solid var(--rule-2);
  padding: 5px 10px;
  border-radius: 999px;
}

@media (max-width: 760px) {
  .card,
  .card:nth-child(1),
  .card:nth-child(2),
  .card:nth-child(3),
  .card:nth-child(4) {
    grid-column: 1 / -1;
  }
}

/* ============================================================
   PROCESS
   ============================================================ */
.process__figure {
  margin: 0;
}
.process__svg {
  width: 100%;
  height: auto;
  margin-bottom: 56px;
  display: block;
}
.process__path {
  stroke-dasharray: 1800;
  stroke-dashoffset: 1800;
  transition: stroke-dashoffset 2.4s var(--ease);
}
@media (max-width: 760px) {
  .process__svg { display: none; }
}
.process__figure.in .process__path,
.reveal.in .process__path {
  stroke-dashoffset: 0;
}
.process__nodes g { opacity: 1; }

.process__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: clamp(16px, 2vw, 28px);
  border-top: 1px solid var(--rule-2);
  padding-top: 28px;
}
.process__list h4 {
  margin: 0 0 10px;
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  color: var(--paper);
  font-variation-settings: "opsz" 60, "SOFT" 50;
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.process__list h4 span {
  font-family: var(--mono);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--gold);
}
.process__list p {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.55;
  color: rgba(236,232,223,0.74);
}
@media (max-width: 900px) {
  .process__list { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .process__list { grid-template-columns: 1fr; }
}

/* ============================================================
   CAPABILITIES MATRIX
   ============================================================ */
.caps__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(40px, 5vw, 80px) clamp(40px, 6vw, 96px);
}
@media (min-width: 1080px) {
  .caps__grid { grid-template-columns: repeat(4, 1fr); }
}

.caps__heading {
  margin: 0 0 20px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule-2);
}
.caps__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.caps__list li {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 10px 0;
  font-family: var(--display);
  font-size: 18px;
  color: var(--paper);
  font-variation-settings: "opsz" 24;
  transition: color 0.3s var(--ease), padding-left 0.4s var(--ease);
}
.caps__list li:hover {
  color: var(--gold-2);
  padding-left: 6px;
}
.caps__list li > span:last-child {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
}
.leader {
  flex: 1;
  border-bottom: 1px dotted var(--muted-2);
  margin-bottom: 4px;
}

/* ============================================================
   INDUSTRIES
   ============================================================ */
.industries__list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--rule-2);
}
.industries__list li {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  align-items: baseline;
  gap: 20px;
  padding: 28px 0;
  border-bottom: 1px solid var(--rule);
  cursor: default;
  transition: padding-left 0.5s var(--ease), background 0.5s var(--ease);
  position: relative;
  overflow: hidden;
}
.industries__list li::before {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 0;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.6s var(--ease);
}
.industries__list li:hover::before { transform: scaleX(1); }
.industries__list li:hover {
  padding-left: 16px;
  background: linear-gradient(to right, rgba(201,169,106,0.06), transparent 60%);
}

.industries__num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
}
.industries__name {
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(32px, 5vw, 64px);
  font-style: italic;
  letter-spacing: -0.015em;
  line-height: 1;
  color: var(--paper);
  font-variation-settings: "opsz" 144, "SOFT" 50, "WONK" 1;
  transition: color 0.4s var(--ease);
}
.industries__list li:hover .industries__name { color: var(--gold-2); }
.industries__note {
  font-family: var(--serif);
  font-style: italic;
  color: var(--muted);
  font-size: 14px;
  text-align: right;
  max-width: 24ch;
}
@media (max-width: 720px) {
  .industries__list li {
    grid-template-columns: 30px 1fr;
  }
  .industries__note {
    grid-column: 2;
    text-align: left;
    margin-top: 6px;
  }
}

/* ============================================================
   FIGURES / FIELD NOTES
   ============================================================ */
.figures__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 48px);
}
.figure {
  margin: 0;
  padding: 36px 28px 32px;
  border: 1px solid var(--rule-2);
  background: var(--ink-2);
  position: relative;
  overflow: hidden;
}
.figure::after {
  content: "";
  position: absolute;
  right: -40px;
  top: -40px;
  width: 160px;
  height: 160px;
  border: 1px solid var(--rule);
  border-radius: 50%;
  transition: transform 0.8s var(--ease);
}
.figure:hover::after { transform: rotate(45deg) scale(1.05); }

.figure__num {
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(72px, 10vw, 140px);
  line-height: 0.9;
  color: var(--paper);
  letter-spacing: -0.04em;
  font-variation-settings: "opsz" 144, "SOFT" 30;
  margin-bottom: 24px;
}
.figure--em .figure__num {
  color: var(--gold);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
}
.figure figcaption {
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.55;
  color: rgba(236,232,223,0.78);
}
.figure figcaption strong {
  display: block;
  font-family: var(--display);
  font-style: italic;
  font-weight: 500;
  font-size: 18px;
  color: var(--paper);
  margin-bottom: 6px;
  font-variation-settings: "opsz" 36;
}

@media (max-width: 800px) {
  .figures__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   CLOSING
   ============================================================ */
.closing {
  text-align: center;
  padding-top: clamp(120px, 14vw, 200px);
  padding-bottom: clamp(120px, 14vw, 200px);
}
.closing__filigree {
  width: min(640px, 80%);
  margin: 0 auto 48px;
  color: var(--muted);
}
.filigree__path {
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  transition: stroke-dashoffset 2s var(--ease);
}
.closing__filigree.in .filigree__path { stroke-dashoffset: 0; }

.closing__title {
  margin: 0 0 28px;
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(40px, 6.5vw, 96px);
  line-height: 1;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
.closing__title span { display: block; }
.closing__title--em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
}
.closing__sub {
  font-family: var(--display);
  font-style: italic;
  font-size: clamp(16px, 1.4vw, 20px);
  color: var(--muted);
  margin: 0;
}
.closing__sub em { color: var(--gold); font-style: italic; }

/* ============================================================
   COLOPHON / FOOTER
   ============================================================ */
.colophon {
  border-top: 1px solid var(--rule-2);
  background: var(--ink-2);
  padding: 56px var(--gut);
  text-align: center;
}
.colophon__inner {
  max-width: var(--max);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.colophon__mark { color: var(--gold); }
.colophon__mark svg { width: 56px; height: 28px; }
.colophon__line {
  margin: 0;
  font-family: var(--display);
  font-style: italic;
  font-size: 15px;
  color: var(--paper);
  font-variation-settings: "opsz" 24;
}
.colophon__line strong {
  font-style: normal;
  font-weight: 500;
  color: var(--gold-2);
  letter-spacing: 0.005em;
}
.colophon__sep { color: var(--muted-2); margin: 0 10px; }
.colophon__year {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  color: var(--muted);
  font-style: normal;
}
.colophon__set {
  margin: 0;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.colophon__set em {
  font-family: var(--display);
  text-transform: none;
  font-style: italic;
  color: var(--gold);
  letter-spacing: 0;
}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 0.9s var(--ease),
    transform 0.9s var(--ease);
  transition-delay: calc(var(--i, 0) * 90ms);
  will-change: transform, opacity;
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  html { scroll-behavior: auto; }
  .marquee__track { animation: none; transform: none; }
  .mark { animation: none; }
  .reveal { opacity: 1; transform: none; }
  .mark__circle, .mark__vesica, .mark__center, .process__path, .filigree__path {
    stroke-dashoffset: 0 !important;
    opacity: 1 !important;
    transform: none !important;
  }
}
