/* ============================================================
   project detail page styles
   ============================================================ */

.proj-page { padding-top: 88px; }

/* HEADER */
.proj-head {
  padding: clamp(48px, 7vw, 80px) var(--gutter) clamp(32px, 5vw, 56px);
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}
.proj-crumb {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 16px;
}
.proj-crumb a { color: var(--ink-soft); }
.proj-crumb a:hover { color: var(--ink); }

.proj-titleblock {
  display: grid;
  grid-template-columns: 1fr 5fr 2fr;
  gap: clamp(24px, 4vw, 48px);
  align-items: end;
  padding: 24px 0;
}
.proj-num {
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  color: var(--timber);
  align-self: start;
  padding-top: 14px;
}
.proj-title {
  font-family: var(--sans);
  font-weight: 300;
  font-size: clamp(48px, 8vw, 120px);
  line-height: 0.95;
  letter-spacing: -0.035em;
  text-wrap: balance;
}
.proj-tagline {
  font-family: var(--sans);
  font-style: normal;
  font-weight: 300;
  color: var(--ink-soft);
  font-size: clamp(18px, 1.6vw, 24px);
  line-height: 1.3;
  text-wrap: pretty;
}

.proj-facts {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 18px 0;
  margin-top: 8px;
}
.fact-label { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 4px; }
.fact-value { font-family: var(--sans); font-size: 1rem; }

/* COVER — image-driven, no forced aspect ratio.
   The hero image of the project sets its own height at full width. */
.proj-cover {
  margin: 0 var(--gutter) clamp(48px, 6vw, 80px);
  background: var(--paper-deep);
}
.proj-cover img {
  display: block;
  width: 100%;
  height: auto;
  /* No object-fit. The image IS the cover. */
}

/* BODY */
.proj-body {
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1fr 7fr 4fr;
  gap: clamp(32px, 5vw, 56px);
  margin-bottom: clamp(56px, 8vw, 96px);
}
.proj-body-eyebrow { padding-top: 8px; }
.proj-summary {
  font-family: var(--sans);
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: 300;
  line-height: 1.3;
  letter-spacing: -0.005em;
  color: var(--ink);
  max-width: 32ch;
  text-wrap: pretty;
  margin: 0 0 24px;
}
.proj-paras p {
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 0 0 14px;
  max-width: 56ch;
}

@media (max-width: 1000px) {
  .proj-titleblock { grid-template-columns: 1fr; gap: 16px; }
  .proj-facts { grid-template-columns: repeat(2, 1fr); }
  .proj-body { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 520px) {
  .proj-facts { grid-template-columns: 1fr; gap: 12px; padding: 14px 0; }
  .proj-crumb { flex-wrap: wrap; gap: 6px; }
}

/* GALLERY — mixed aspect ratios coexist gracefully.
   Each figure occupies the space its image dictates; no aspect-ratio
   frame, no object-fit. Width modifiers control how wide a piece
   reads on the page (full / 70% left / 70% right / 50/50 spread). */
.proj-gallery {
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
  gap: clamp(48px, 8vw, 96px);
  margin-bottom: clamp(56px, 7vw, 80px);
}
.gimg { display: block; width: 100%; margin: 0; }
.gimg-frame {
  background: var(--paper-deep);
  position: relative;
  overflow: hidden;
}
.gimg-frame img {
  display: block;
  width: 100%;
  height: auto;
  /* No object-fit. The image IS the frame. */
}
.gimg-cap {
  margin-top: 12px;
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex;
  justify-content: space-between;
  border-top: 1px solid var(--rule);
  padding-top: 10px;
}
.gimg.alignL { width: 70%; margin-right: auto; }
.gimg.alignR { width: 70%; margin-left: auto; }
.gimg.alignFull { width: 100%; }
.gimg.alignSpread {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  width: 100%;
  align-items: start;
}
.gimg.alignSpread .gimg-frame { width: 100%; }
@media (max-width: 800px) {
  .gimg.alignL, .gimg.alignR { width: 100%; }
  .gimg.alignSpread { grid-template-columns: 1fr; }
}

/* PAGINATION */
.proj-pager {
  margin: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--rule);
}
.pager-cell {
  padding: 32px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  cursor: pointer;
  transition: background 200ms, padding 200ms;
}
.pager-cell:hover { background: var(--paper-deep); padding-left: 14px; padding-right: 14px; }
.pager-cell:hover .pager-dir, .pager-cell:hover .pager-name { color: var(--timber-deep); }
.pager-cell.right { text-align: right; align-items: flex-end; border-left: 1px solid var(--rule); }
.pager-cell.right:hover { padding-right: 14px; padding-left: 14px; }
.pager-dir { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.pager-name {
  font-family: var(--sans);
  font-weight: 300;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.02em;
}
