/* ============================================================
   GHOST ZERO — WORK PAGE (🟡 ARCHIVE ROOM)
   Goldenrod on pewter · recolored Systems deployment cards
   (C37/C38) · B51 status chips · G "1997" as small accents only.
   Per DESIGN-CONTRACT.md — instrument, don't cosplay.
   ============================================================ */

.work-page { background: var(--gz-pewter, #2E3034); }

:root {
  /* Archive room (canon in shell/tokens.css) */
  --gz-pewter:    #2E3034;
  --gz-pewter-2:  #4F545C;
  --gz-pewter-3:  #5D616A;
  --gz-gold:      #D4A017;
  --gz-gold-2:    #E6BE3A;
  --gz-arch-line: #646973;
  --gz-arch-text: #E4E6EA;
  --gz-arch-mute: #A0A4AC;
}

/* ---------- hero ---------- */
.work-hero {
  position: relative;
  background: var(--gz-pewter);
  color: var(--gz-arch-text);
  padding: clamp(140px, 18vw, 220px) var(--pad-x) clamp(64px, 8vw, 96px);
  border-bottom: 1px solid var(--gz-arch-line);
  overflow: hidden;
}
.work-hero::before {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 55%;
  height: 100%;
  background: radial-gradient(ellipse at 70% 30%, rgba(212,160,23,0.10) 0%, transparent 60%);
  pointer-events: none;
}
.work-hero-grid {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: end;
  position: relative;
  z-index: 2;
}
@media (max-width: 880px) { .work-hero-grid { grid-template-columns: 1fr; gap: 28px; } }
.work-hero h1 { margin: 22px 0 0; color: var(--gz-arch-text); }
.work-hero h1 em { color: var(--gz-gold-2); font-style: italic; }
.work-hero p { font-size: var(--t-lead); margin: 0 0 8px; max-width: 52ch; color: var(--gz-arch-mute); }
.work-hero .eyebrow { color: var(--gz-gold); }
.work-hero .eyebrow::before { background: var(--gz-gold); }

/* G accent — tiny terminal readout, seasoning only */
.archive-readout {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gz-gold-2);
  border: 1px solid var(--gz-arch-line);
  background: rgba(0,0,0,0.18);
  padding: 10px 14px;
  display: inline-flex;
  gap: 10px;
  align-items: center;
}
.archive-readout::before { content: "►"; color: var(--gz-gold); }

/* ---------- archive section head ---------- */
.sec-head.arch {
  background: #26282C;
  border-color: var(--gz-arch-line);
  color: var(--gz-arch-mute);
}
.sec-head.arch .num { color: var(--gz-gold); }
.sec-head.arch .right { color: var(--gz-arch-text); }

/* ---------- case file cards — C37/C38 recolored gold ---------- */
.files {
  background: var(--gz-pewter);
  padding-bottom: clamp(64px, 9vw, 110px);
}
.files-grid {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: clamp(40px, 6vw, 64px) var(--pad-x) 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
@media (max-width: 1080px) { .files-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px)  { .files-grid { grid-template-columns: 1fr; } }

.file-card {
  position: relative;
  background: var(--gz-pewter-2);
  border: 1px solid var(--gz-arch-line);
  display: flex;
  flex-direction: column;
  transition: transform 200ms ease, border-color 200ms ease;
}
.file-card:hover { transform: translateY(-3px); border-color: var(--gz-gold); }
.file-card:hover .fc-open { color: var(--gz-gold-2); }

.file-card .idtag {
  position: absolute;
  top: 0; left: 0;
  z-index: 4;
  background: var(--gz-gold);
  color: #241C05;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  padding: 4px 9px;
}
.file-card .status {
  position: absolute;
  top: 0; right: 0;
  z-index: 4;
  font-family: var(--font-mono);
  font-size: 8.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 9px;
  background: rgba(0,0,0,0.45);
  color: var(--gz-gold-2);
}
.file-card .fc-photo {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
.file-card .fc-photo .ph { position: absolute; inset: 0; }
.file-card .fc-photo .ph.photo { filter: grayscale(100%) contrast(1.05) brightness(0.8) sepia(0.28); }
.file-card .fc-body {
  padding: 20px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.file-card .fc-vert {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gz-gold);
}
.file-card h3 {
  margin: 0;
  font-family: var(--font-shell);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.005em;
  font-size: 22px;
  line-height: 1.05;
  color: var(--gz-arch-text);
}
.file-card .fc-desc {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--gz-arch-mute);
}
.file-card .fc-specs {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px dashed var(--gz-arch-line);
  display: grid;
  gap: 6px;
}
.file-card .specline {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gz-arch-mute);
}
.file-card .specline .dots { flex: 1; border-bottom: 1px dotted var(--gz-arch-line); transform: translateY(-2px); }
.file-card .specline .val { color: var(--gz-gold-2); }
.file-card .fc-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 18px;
  border-top: 1px solid var(--gz-arch-line);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gz-arch-mute);
}
.file-card .fc-open { color: var(--gz-gold); transition: color 150ms ease; }

/* ---------- clients wall — C57 tags, warm ---------- */
.clients {
  background: #26282C;
  border-top: 1px solid var(--gz-arch-line);
  border-bottom: 1px solid var(--gz-arch-line);
  padding: clamp(48px, 7vw, 80px) var(--pad-x);
}
.clients-inner { max-width: var(--max-w); margin: 0 auto; }
.clients h2 { color: var(--gz-arch-text); margin: 14px 0 28px; }
.client-wall {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--gz-arch-line);
  border: 1px solid var(--gz-arch-line);
}
@media (max-width: 880px) { .client-wall { grid-template-columns: repeat(2, 1fr); } }
.client-wall .client {
  background: var(--gz-pewter);
  padding: 26px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.client-wall .client .cname {
  font-family: var(--font-shell);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 15px;
  color: var(--gz-arch-text);
}
.client-wall .client .ctag {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gz-gold);
}

/* ---------- archive closer ---------- */
.arch-closer {
  position: relative;
  background: var(--gz-pewter);
  text-align: center;
  padding: clamp(96px, 13vw, 160px) var(--pad-x);
  overflow: hidden;
}
.arch-closer::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 100%, rgba(212,160,23,0.12) 0%, transparent 60%);
  pointer-events: none;
}
.arch-closer .inner { position: relative; z-index: 2; max-width: 1000px; margin: 0 auto; }
.arch-closer h2 {
  font-family: var(--font-display);
  font-size: var(--t-mega);
  font-style: italic;
  color: var(--gz-arch-text);
  margin: 24px 0 32px;
  line-height: 0.92;
}
.arch-closer h2 em { color: var(--gz-gold-2); }
.arch-closer .btn.gold { background: var(--gz-gold); border-color: var(--gz-gold); color: #241C05; }
.arch-closer .btn.gold:hover { background: var(--gz-gold-2); border-color: var(--gz-gold-2); }


/* ============================================================
   CASE STUDY (Field Report) template + CLIENTS page — Archive room
   ============================================================ */
.csd-head {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(130px, 16vw, 180px) var(--pad-x) clamp(32px, 5vw, 48px);
}
.csd-head .kicker {
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--gz-arch-mute);
}
.csd-head .kicker .idchip { background: var(--gz-gold); color: #241C05; padding: 3px 9px; font-weight: 600; }
.csd-head .kicker .live { color: var(--gz-gold-2); }
.csd-head h1 {
  margin: 18px 0 12px;
  font-family: var(--font-shell); font-weight: 800; text-transform: uppercase;
  letter-spacing: -0.015em; font-size: clamp(38px, 5.5vw, 72px); line-height: 0.96;
  color: var(--gz-arch-text); max-width: 20ch;
}
.csd-head .lede { font-size: var(--t-lead); color: var(--gz-arch-mute); max-width: 56ch; margin: 0; }

.csd-photo {
  max-width: 1100px; margin: 0 auto; padding: 0 var(--pad-x);
}
.csd-photo .ph-holder { position: relative; aspect-ratio: 21/9; overflow: hidden; border: 1px solid var(--gz-arch-line); }
.csd-photo .ph { position: absolute; inset: 0; }
.csd-photo .ph.photo { filter: grayscale(100%) contrast(1.05) brightness(0.8) sepia(0.28); }
.csd-photo .cap {
  display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap;
  padding: 10px 2px; font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--gz-arch-mute);
}

.csd-grid {
  max-width: 1100px; margin: 0 auto;
  padding: clamp(32px, 5vw, 56px) var(--pad-x) clamp(72px, 10vw, 110px);
  display: grid; grid-template-columns: minmax(0, 1fr) 300px;
  gap: clamp(36px, 5vw, 72px); align-items: start;
}
@media (max-width: 880px) { .csd-grid { grid-template-columns: 1fr; } }
.csd-body { font-size: 16.5px; line-height: 1.7; color: var(--gz-arch-mute); }
.csd-body > * + * { margin-top: 20px; }
.csd-body h2 {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--gz-gold);
  display: flex; align-items: center; gap: 10px; margin-top: 38px;
}
.csd-body h2::before { content: ""; width: 24px; height: 1px; background: var(--gz-gold); }
.csd-body strong { color: var(--gz-arch-text); }

/* the features-deployed ledger — the features x clients engine */
.deployed {
  border: 1px solid var(--gz-arch-line); background: rgba(0,0,0,0.18);
}
.deployed .d-head {
  padding: 12px 16px; border-bottom: 1px solid var(--gz-arch-line);
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--gz-gold);
}
.deployed a.d-row {
  display: grid; grid-template-columns: 76px 1fr auto;
  gap: 14px; align-items: baseline;
  padding: 13px 16px; border-bottom: 1px dashed var(--gz-arch-line);
  transition: background 150ms ease;
}
.deployed a.d-row:last-child { border-bottom: none; }
.deployed a.d-row:hover { background: rgba(212,160,23,0.07); }
.deployed .d-id { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.12em; color: var(--gz-gold); }
.deployed .d-name { color: var(--gz-arch-text); font-weight: 500; font-size: 14.5px; }
.deployed .d-metric { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gz-gold-2); text-align: right; }

/* results spec rail */
.csd-rail { position: sticky; top: 110px; display: flex; flex-direction: column; gap: 18px; }
@media (max-width: 880px) { .csd-rail { position: static; } }
.csd-rail .r-card { border: 1px solid var(--gz-arch-line); background: var(--gz-pewter-2); padding: 16px; display: grid; gap: 9px; }
.csd-rail .r-card .rc-cap { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gz-gold); margin-bottom: 4px; }
.csd-rail .specline { display: flex; align-items: baseline; gap: 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gz-arch-mute); }
.csd-rail .specline .dots { flex: 1; border-bottom: 1px dotted var(--gz-arch-line); transform: translateY(-2px); }
.csd-rail .specline .val { color: var(--gz-arch-text); }
.csd-rail .bignum { font-family: var(--font-display); font-size: 52px; line-height: 0.9; color: var(--gz-gold-2); }
.csd-rail .bignum small { display: block; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em; color: var(--gz-arch-mute); margin-top: 8px; text-transform: uppercase; }

/* next/prev case nav */
.case-nav {
  border-top: 1px solid var(--gz-arch-line);
  background: #26282C;
  display: grid; grid-template-columns: 1fr 1fr;
}
.case-nav a {
  padding: 26px var(--pad-x);
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--gz-arch-mute);
  display: flex; flex-direction: column; gap: 6px;
  transition: background 150ms ease;
}
.case-nav a:hover { background: var(--gz-pewter); }
.case-nav a .t { font-family: var(--gz-font-shell, var(--font-shell)); font-weight: 700; font-size: 17px; color: var(--gz-arch-text); text-transform: uppercase; letter-spacing: 0; }
.case-nav a.next { text-align: right; align-items: flex-end; border-left: 1px solid var(--gz-arch-line); }

/* clients page — roster cards */
.roster-grid {
  max-width: var(--max-w); margin: 0 auto;
  padding: clamp(40px, 6vw, 64px) var(--pad-x) clamp(72px, 10vw, 110px);
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px;
}
@media (max-width: 1020px) { .roster-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .roster-grid { grid-template-columns: 1fr; } }
.roster-card {
  position: relative; border: 1px solid var(--gz-arch-line); background: var(--gz-pewter-2);
  padding: 22px 18px 16px; display: flex; flex-direction: column; gap: 8px;
  transition: transform 180ms ease, border-color 180ms ease;
}
.roster-card:hover { transform: translateY(-2px); border-color: var(--gz-gold); }
.roster-card .rc-sector { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gz-gold); }
.roster-card h3 { margin: 0; font-family: var(--font-shell); font-weight: 800; text-transform: uppercase; font-size: 19px; letter-spacing: 0; color: var(--gz-arch-text); line-height: 1.1; }
.roster-card .rc-services { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gz-arch-mute); line-height: 1.9; }
.roster-card .rc-foot {
  margin-top: auto; padding-top: 12px; border-top: 1px dashed var(--gz-arch-line);
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gz-arch-mute);
}
.roster-card .rc-foot .go { color: var(--gz-gold); }
.roster-card .status-chip { position: absolute; top: 0; right: 0; font-family: var(--font-mono); font-size: 8.5px; letter-spacing: 0.12em; padding: 4px 9px; background: rgba(0,0,0,0.45); color: var(--gz-gold-2); text-transform: uppercase; }