/* =========================================================
   Project Record — "case-file / dossier" page template
   Layers on top of styles.css tokens. Accent-B (oxblood) context.
   ========================================================= */

.proj {
  --rule: var(--ink);
  --paper: var(--bg);
  --record-bg: var(--surface-alt);
  --serif: 'Newsreader', 'EB Garamond', Georgia, serif;
}

/* ----- shared rhythm ----- */
.proj-x { padding-inline: var(--space-page-x); }
.proj-section { padding-block: 13px; }
.proj-section--tight { padding-block: 13px; }
.proj hr.proj-rule { border: 0; border-top: 1px solid var(--hairline); margin: 0; }
.proj hr.proj-rule--ink { border-top: 1px solid var(--ink); }

/* =========================================================
   File header band (the "record" frame)
   ========================================================= */
.proj-filebar {
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
}
.proj-filebar__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: stretch;
  gap: 0;
}
.proj-filebar__cell {
  padding: 11px 0;
  display: flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.proj-filebar__cell--mid {
  justify-content: center;
  padding-inline: 28px;
  border-inline: 1px solid var(--hairline);
  color: var(--accent);
}
.proj-filebar__cell--end { justify-content: flex-end; color: var(--ink-secondary); }
.proj-filebar__dot { width: 6px; height: 6px; background: var(--accent); border-radius: 50%; }

@media (max-width: 720px) {
  .proj-filebar__inner { grid-template-columns: 1fr; }
  .proj-filebar__cell { padding: 9px 0; border: 0 !important; justify-content: flex-start; }
  .proj-filebar__cell--mid { justify-content: flex-start; padding-inline: 0; border-top: 1px solid var(--hairline) !important; border-bottom: 1px solid var(--hairline) !important; }
}

/* =========================================================
   HERO — editorial dossier (default)
   ========================================================= */
.proj-hero { padding-block: clamp(40px, 5vw, 72px) clamp(32px, 4vw, 56px); }

.proj-hero__head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: 24px 32px;
}
.proj-kicker {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
}
.proj-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.05;
  letter-spacing: -0.018em;
  margin-top: 10px;
  max-width: 24ch;
}
.proj-title em { font-style: italic; color: var(--accent); }
.proj-standfirst {
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.5;
  max-width: 56ch;
  margin-top: 18px;
  color: var(--ink);
}

/* Status stamp — tasteful "rubber stamp" tag */
.proj-stamp {
  flex-shrink: 0;
  align-self: start;
  margin-top: 8px;
  min-width: 188px;
  max-width: 220px;
  border: 1px solid var(--ink);
  color: var(--accent);
  padding: 0;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.3;
  text-align: left;
  background: var(--record-bg);
}
.proj-stamp small {
  display: block;
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--ink-secondary);
  padding: 7px 14px;
  border-bottom: 1px solid var(--hairline);
  margin-bottom: 0;
}
.proj-stamp b {
  display: block;
  font-weight: 500;
  padding: 10px 14px 13px;
}

@media (max-width: 560px) {
  .proj-hero__head { grid-template-columns: 1fr; }
  .proj-stamp { justify-self: start; }
}

/* Hero body: lead image + record card side by side (equal height) */
.proj-hero__body {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: clamp(32px, 4vw, 64px);
  margin-top: clamp(28px, 3.5vw, 52px);
  align-items: stretch;
}
.proj-hero__media { display: flex; flex-direction: column; }
.proj-hero__media figure { margin: 0; }

/* Dossier hero: image plate stretches to exactly match the record card height.
   The record drives the row height; the image fills it (object-fit: cover) and
   the caption is taken out of flow so it never adds to the column height. */
.proj[data-hero="dossier"]:not([data-meta="topband"]) .proj-hero__media > figure {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  position: relative;
  min-height: 0;
}
.proj[data-hero="dossier"]:not([data-meta="topband"]) .proj-hero__media .img-real,
.proj[data-hero="dossier"]:not([data-meta="topband"]) .proj-hero__media .img-placeholder {
  flex: 1 1 auto;
  aspect-ratio: auto;
  height: auto;
  min-height: 0;
}
.proj[data-hero="dossier"]:not([data-meta="topband"]) .proj-hero__media .img-caption {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 10px;
}

/* =========================================================
   RECORD CARD (fact sheet / definition list)
   ========================================================= */
.proj-record {
  background: var(--record-bg);
  border: 1px solid var(--ink);
  padding: 0;
  display: flex;
  flex-direction: column;
}
.proj-record__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
}
.proj-record__head .proj-record__ref { color: var(--accent); }
.proj-record__list { display: flex; flex-direction: column; flex: 1 1 auto; }
.proj-record__list .proj-row { flex: 1 1 auto; }
.proj-row {
  display: grid;
  grid-template-columns: 128px 1fr;
  gap: 18px;
  padding: 14px 22px;
  border-top: 1px solid var(--hairline);
  align-items: baseline;
}
.proj-record__list .proj-row:first-child { border-top: 0; }
.proj-row__key {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-secondary);
  padding-top: 2px;
}
.proj-row__val { font-size: 15px; line-height: 1.5; }
.proj-row__val strong { font-weight: 600; }
.proj-row__val .tagrow { display: flex; flex-wrap: wrap; gap: 8px; }
.proj-tag {
  display: inline-block;
  border: 1px solid var(--hairline);
  padding: 3px 9px;
  font-size: 12px;
  letter-spacing: 0.02em;
  background: var(--paper);
}
.proj-row__val a.proj-extlink {
  display: inline-flex; align-items: center; gap: 6px;
  border-bottom: 1px solid var(--accent);
  color: var(--accent);
  font-weight: 500;
}

/* Status dot in record */
.proj-status { display: inline-flex; align-items: center; gap: 9px; }
.proj-status__dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);
}
.proj-status--live .proj-status__dot { background: #2f7d52; box-shadow: 0 0 0 4px rgba(47,125,82,0.18); }

/* =========================================================
   META LAYOUT VARIANTS (tweakable)
   data-meta = "sidebar" | "topband" | "inline"
   ========================================================= */
/* topband: record becomes a horizontal strip below the title, image full width */
.proj[data-meta="topband"] .proj-hero__body { grid-template-columns: 1fr; }
.proj[data-meta="topband"] .proj-record__list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.proj[data-meta="topband"] .proj-row {
  grid-template-columns: 1fr;
  gap: 8px;
  border-top: 0;
  border-left: 1px solid var(--hairline);
}
.proj[data-meta="topband"] .proj-record__list .proj-row:first-child { border-left: 0; }
.proj[data-meta="topband"] .proj-hero__media { order: 2; margin-top: 8px; }

/* inline: no card chrome — record reads as a tight fact list under standfirst */
.proj[data-meta="inline"] .proj-hero__body { grid-template-columns: 1.4fr 1fr; }
.proj[data-meta="inline"] .proj-record {
  background: transparent;
  border: 0;
  border-top: 1px solid var(--ink);
}
.proj[data-meta="inline"] .proj-record__head { border-bottom: 1px solid var(--hairline); padding-inline: 0; }
.proj[data-meta="inline"] .proj-row { padding-inline: 0; }
.proj[data-meta="inline"] .proj-tag { background: var(--record-bg); }

@media (max-width: 880px) {
  .proj-hero__body,
  .proj[data-meta="inline"] .proj-hero__body { grid-template-columns: 1fr; }
  .proj[data-meta="topband"] .proj-record__list { grid-template-columns: 1fr 1fr; }
  .proj[data-meta="topband"] .proj-row { border-left: 0; border-top: 1px solid var(--hairline); }
}

/* =========================================================
   HERO VARIANTS (tweakable)
   data-hero = "dossier" | "cover" | "text"
   ========================================================= */
/* cover: big full-width image with title stacked above the record */
.proj[data-hero="cover"] .proj-hero__head { display: block; }
.proj[data-hero="cover"] .proj-hero__cover { margin-top: clamp(28px, 3vw, 44px); }
.proj[data-hero="cover"] .proj-hero__cover .img-real { aspect-ratio: 21 / 9; }
.proj[data-hero="cover"] .proj-hero__body { margin-top: clamp(32px, 4vw, 56px); }
.proj-hero__cover { display: none; }
.proj[data-hero="cover"] .proj-hero__cover { display: block; }
.proj[data-hero="cover"] .proj-hero__media { display: none; }
.proj[data-hero="cover"][data-meta="topband"] .proj-hero__media { display: none; }

/* text: no hero image at all; title + standfirst + record only */
.proj[data-hero="text"] .proj-hero__media { display: none; }
.proj[data-hero="text"] .proj-hero__cover { display: none; }
.proj[data-hero="text"] .proj-hero__body { grid-template-columns: 1.1fr 0.9fr; }
.proj[data-hero="text"] .proj-standfirst { max-width: 60ch; font-size: clamp(22px, 2.2vw, 30px); }

@media (max-width: 880px) {
  .proj[data-hero="text"] .proj-hero__body { grid-template-columns: 1fr; }
}

/* =========================================================
   WRITE-UP — numbered dossier blocks
   ========================================================= */
.proj-writeup { margin-top: -2px; }
.proj-block {
  display: grid;
  grid-template-columns: 4fr 8fr;
  gap: clamp(24px, 3vw, 48px);
  padding-block: clamp(26px, 2.6vw, 38px);
  border-top: 1px solid var(--hairline);
  align-items: start;
}
.proj-writeup > .proj-block:first-child { border-top: 0; }
.proj-block__head { display: flex; flex-direction: column; gap: 8px; position: sticky; top: 96px; }
.proj-block__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--accent);
}
.proj-block__title {
  font-family: var(--serif);
  font-size: clamp(20px, 1.9vw, 26px);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.01em;
}
.proj-block__body { font-size: clamp(15px, 1.2vw, 17px); line-height: 1.55; }
.proj-block__body p { margin-bottom: 0.85em; }
.proj-block__body p:last-child { margin-bottom: 0; }
.proj-block__body em { font-style: italic; color: var(--accent); }

@media (max-width: 880px) {
  .proj-block { grid-template-columns: 1fr; gap: 20px; }
  .proj-block__head { position: static; }
}

/* =========================================================
   SECTION HEADER (reused for partners / people / gallery / links)
   ========================================================= */
.proj-shead {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px 24px;
  flex-wrap: wrap;
  padding-bottom: 11px;
  margin-bottom: 26px;
  border-bottom: 1px solid var(--ink);
}
.proj-shead__label { display: flex; align-items: baseline; gap: 12px; min-width: 0; }
.proj-shead__num { flex-shrink: 0; white-space: nowrap; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--accent); }
.proj-shead__title {
  white-space: nowrap;
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
  line-height: 1.3;
}
.proj-shead__index { flex-shrink: 0; white-space: nowrap; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-secondary); text-align: right; }

/* =========================================================
   RECORD FRAME — reusable bordered "report area"
   (participants, community mandate, etc.)
   ========================================================= */
.proj-recframe { border: 1px solid var(--ink); background: var(--record-bg); }
.proj-recframe__bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px 16px;
  flex-wrap: wrap;
  padding: 12px 22px;
  border-bottom: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
}
.proj-recframe__ref { color: var(--accent); flex-shrink: 0; white-space: nowrap; }
.proj-recframe__body { display: flex; flex-direction: column; }
.proj-recrow {
  display: grid;
  grid-template-columns: 156px 1fr;
  gap: 24px;
  padding: 15px 22px;
  border-top: 1px solid var(--hairline);
  align-items: baseline;
}
.proj-recframe__body .proj-recrow:first-child { border-top: 0; }
.proj-recrow__key {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  padding-top: 2px;
}
.proj-recrow__main { display: flex; flex-direction: column; gap: 4px; }
.proj-recrow__name { font-size: 17px; font-weight: 600; letter-spacing: -0.01em; }
.proj-recrow__desc { font-size: 15px; line-height: 1.55; color: var(--ink); }
.proj-recrow__desc strong { font-weight: 600; }
.proj-recrow__desc p { margin: 0 0 0.75em; }
.proj-recrow__desc p:last-child { margin-bottom: 0; }
.proj-recrow__desc em { font-style: italic; color: var(--accent); }
.proj-recrow--mandate { align-items: start; }

/* Link rows inside a record frame (Elsewhere) */
.proj-recrow--link {
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  color: inherit;
  transition: color .15s ease, background .15s ease;
}
a.proj-recrow--link:hover { color: var(--accent); background: color-mix(in srgb, var(--accent) 5%, transparent); }
a.proj-recrow--link:hover .proj-recrow__arrow { transform: translateX(5px); }
.proj-recrow__idx { font-family: var(--font-mono); font-size: 12px; color: var(--ink-secondary); }
.proj-recrow--link .proj-recrow__name { font-size: clamp(16px, 1.4vw, 19px); font-weight: 500; }
.proj-recrow__url { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--ink-secondary); margin-top: 3px; }
.proj-recrow__arrow { font-size: 18px; transition: transform .2s ease; flex-shrink: 0; }
@media (max-width: 680px) {
  .proj-recrow { grid-template-columns: 1fr; gap: 6px; }
}

/* =========================================================
   PARTNERS / COLLABORATORS
   ========================================================= */
.proj-partners {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1px;
  background: var(--hairline);
  border: 1px solid var(--hairline);
}
.proj-partner {
  background: var(--paper);
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 220px;
}
.proj-partner__logo {
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.proj-partner__logo img { max-height: 60px; max-width: 160px; width: auto; object-fit: contain; }
.proj-partner__logo--ph {
  width: 100%;
  border: 1px dashed var(--hairline);
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-secondary);
}
.proj-partner__name { font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
.proj-partner__role { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--ink-secondary); text-transform: uppercase; margin-top: -10px; }
.proj-partner__desc { font-size: 14px; line-height: 1.5; color: var(--ink); }
.proj-partner__link { margin-top: auto; }

@media (max-width: 880px) { .proj-partners { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .proj-partners { grid-template-columns: 1fr; } }

/* =========================================================
   PARTICIPANTS / PEOPLE
   ========================================================= */
.proj-people { display: flex; flex-direction: column; }
.proj-person {
  display: grid;
  grid-template-columns: 220px 1fr auto;
  gap: 32px;
  padding: 20px 0;
  border-top: 1px solid var(--hairline);
  align-items: baseline;
}
.proj-people .proj-person:first-child { border-top: 0; }
.proj-person__name { font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
.proj-person__role { font-size: 15px; color: var(--ink); }
.proj-person__meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-secondary); }
@media (max-width: 720px) {
  .proj-person { grid-template-columns: 1fr; gap: 4px; }
  .proj-person__meta { margin-top: 4px; }
}

/* =========================================================
   GALLERY (tweakable columns)
   ========================================================= */
.proj-gallery {
  display: grid;
  grid-template-columns: repeat(var(--gallery-cols, 3), 1fr);
  gap: clamp(14px, 1.4vw, 22px);
}
.proj-gallery figure { margin: 0; }
.proj-gallery .img-real, .proj-gallery .img-placeholder { aspect-ratio: 4 / 5; }
@media (max-width: 880px) { .proj-gallery { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .proj-gallery { grid-template-columns: 1fr; } }

/* =========================================================
   EXTERNAL LINKS / RESOURCES
   ========================================================= */
.proj-links { display: flex; flex-direction: column; border-top: 1px solid var(--hairline); }
.proj-linkrow {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: 24px;
  align-items: baseline;
  padding: 22px 0;
  border-bottom: 1px solid var(--hairline);
  transition: color .15s ease;
}
.proj-linkrow:hover { color: var(--accent); }
.proj-linkrow:hover .proj-linkrow__arrow { transform: translateX(6px); }
.proj-linkrow__idx { font-family: var(--font-mono); font-size: 12px; color: var(--ink-secondary); }
.proj-linkrow__main { display: flex; flex-direction: column; gap: 5px; }
.proj-linkrow__label { font-size: clamp(18px, 1.8vw, 24px); font-weight: 500; letter-spacing: -0.01em; }
.proj-linkrow__url { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--ink-secondary); }
.proj-linkrow__arrow { font-size: 20px; transition: transform .2s ease; }

/* =========================================================
   LOCATION
   ========================================================= */
.proj-location {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}
.proj-location__card { background: var(--record-bg); border: 1px solid var(--ink); padding: 28px; }
.proj-location__name { font-family: var(--serif); font-size: clamp(22px, 2.4vw, 30px); font-weight: 400; }
.proj-location__addr { font-size: 16px; line-height: 1.6; color: var(--ink); margin-top: 10px; }
.proj-location__note { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-secondary); margin-top: 18px; }
@media (max-width: 720px) { .proj-location { grid-template-columns: 1fr; } }

/* =========================================================
   BACK / footer nav within page
   ========================================================= */
.proj-backbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; flex-wrap: wrap;
  padding-block: 28px;
  border-top: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase;
}
.proj-backbar a:hover { color: var(--accent); }
