/* projects.css — archive page styling */

.proj-header {
  padding: 104px 0;
  border-bottom: 1px solid var(--rule);
}
.proj-title {
  font-size: var(--fs-d1);
  margin: 16px 0 40px;
}
.proj-sub {
  display: grid; grid-template-columns: minmax(320px, 1.4fr) minmax(280px, 1fr); gap: 32px; align-items: end;
  border-top: 1px solid var(--rule-strong);
  padding-top: 24px;
}
@media (max-width: 1100px) {
  .proj-sub { grid-template-columns: 1fr; }
}
.filters { display: flex; gap: 8px; flex-wrap: wrap; }
.filters button {
  padding: 8px 14px;
  border: 1px solid var(--rule-strong);
  font-size: var(--fs-label); letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 180ms;
}
.filters button:hover { color: var(--accent); border-color: var(--accent); }
.filters button.on { background: var(--ink); color: var(--bg); border-color: var(--ink); }

/* Index table */
.proj-index { padding: 80px 0; }
.proj-table { border-top: 2px solid var(--ink); margin-top: 16px; }
.proj-row {
  display: grid;
  grid-template-columns: 60px 1.4fr 1.6fr 100px 60px;
  align-items: baseline;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule);
  gap: 16px;
  transition: padding 240ms cubic-bezier(.2,.8,.2,1), color 240ms;
}
.proj-row:not(.proj-row-head):hover { padding-left: 16px; color: var(--accent); }
.proj-row-head { font-size: var(--fs-tiny); letter-spacing: var(--ls-eyebrow); color: var(--ink-faint); padding: 14px 0; }
.proj-row .num { font-size: var(--fs-sm); color: var(--ink-faint); }
.proj-row .name { font-size: var(--fs-d3); }
.proj-row .scope { font-size: var(--fs-sm); color: var(--ink-soft); }
.proj-row .year { font-size: var(--fs-label); color: var(--ink-faint); letter-spacing: var(--ls-label); }
.proj-row .jump { font-size: var(--fs-sm); text-align: right; color: var(--ink-faint); }
.proj-row:not(.proj-row-head):hover .num,
.proj-row:not(.proj-row-head):hover .scope,
.proj-row:not(.proj-row-head):hover .year,
.proj-row:not(.proj-row-head):hover .jump { color: var(--accent); }

/* Spreads */
.spread {
  padding: 104px 0;
  border-bottom: 1px solid var(--rule);
}
.spread.alt { background: var(--surface); }
.spread.featured { background: var(--surface-2); }
.spread-head { margin-bottom: 32px; font-size: var(--fs-label); letter-spacing: var(--ls-label); color: var(--ink-faint); }
.spread-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 56px;
  align-items: start;
}
.spread.alt .spread-grid { grid-template-columns: 1fr 1.2fr; }
.spread-media > .placeholder { width: 100%; aspect-ratio: 5/4; transition: transform 480ms cubic-bezier(.2,.8,.2,1); }
.spread-media:hover .placeholder { transform: translateY(-4px); }
.spread-thumbs {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
  margin-top: 12px;
}
.spread-thumbs.four { grid-template-columns: repeat(4, 1fr); }
.spread-thumbs .placeholder { width: 100%; aspect-ratio: 7/5; }

.spread-body { padding-top: 8px; }
.spread-title { font-size: var(--fs-d2); margin: 0 0 24px; }
.spread-facts {
  margin: 32px 0 0; padding: 0;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--rule);
}
.spread-facts > div {
  display: grid; grid-template-columns: 120px 1fr;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule);
  gap: 16px;
}
.spread-facts dt { font-size: var(--fs-label); letter-spacing: var(--ls-label); color: var(--ink-faint); }
.spread-facts dd { margin: 0; font-size: var(--fs-body); color: var(--ink); }

/* GALLERY */
.gallery { background: var(--surface); }
.gallery-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: end;
  margin-bottom: 40px;
}
.gallery-head .lead { max-width: 44ch; }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.gallery-tile { display: flex; flex-direction: column; gap: 12px; }
.gallery-tile .placeholder { width: 100%; aspect-ratio: 3/2; transition: transform 480ms cubic-bezier(.2,.8,.2,1); }
.gallery-tile:hover .placeholder { transform: translateY(-4px); }
.tile-meta {
  display: flex; justify-content: space-between;
  font-size: var(--fs-label); letter-spacing: var(--ls-label); color: var(--ink-soft);
  padding-bottom: 8px; border-bottom: 1px solid var(--rule);
}
.gallery-tile:hover .tile-meta { color: var(--accent); border-color: var(--accent); }
.gallery-more {
  margin-top: 48px; padding-top: 24px;
  border-top: 1px solid var(--rule);
  display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
  font-size: var(--fs-label); letter-spacing: var(--ls-label); color: var(--ink-faint);
}
.gallery-more a { color: var(--ink); border-bottom: 1px solid var(--rule-strong); padding-bottom: 2px; }
.gallery-more a:hover { color: var(--accent); border-color: var(--accent); }
@media (max-width: 900px) {
  .gallery-head { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
}

/* End */
.proj-end { padding: 104px 0; text-align: center; }
.proj-end-wrap { max-width: 800px; margin: 0 auto; }
.proj-end h2 { font-size: var(--fs-d2); margin: 0 0 24px; }
.proj-end .lead { margin: 0 auto 32px; }
.proj-end-ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

@media (max-width: 900px) {
  .spread-grid, .spread.alt .spread-grid, .proj-sub { grid-template-columns: 1fr !important; gap: 32px !important; }
  .proj-row { grid-template-columns: 40px 1fr 60px; }
  .proj-row .scope, .proj-row .year { display: none; }
}
