/* ============================================================
   PAGE: Case study (detail) — shared layout for /work/*.html
   ============================================================ */

.cs-hero {
  padding-top: clamp(8rem, 16vh, 13rem);
  padding-bottom: var(--space-5);
}
.cs-hero__eyebrow { margin-bottom: var(--space-3); }
.cs-hero__title { max-width: 16ch; }
.cs-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
  color: var(--color-text-mute);
  font-size: var(--fs-sm);
}
.cs-hero__meta dt { text-transform: uppercase; letter-spacing: var(--tracking-label); font-size: var(--fs-label); }
.cs-hero__meta dd { color: var(--color-text); margin-top: 0.25rem; }
.cs-hero__tags { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: var(--space-4); }
.cs-hero__live { margin-top: var(--space-4); }

.cs-cover {
  margin-top: var(--space-4);
  max-width: 960px;              /* keep mockups at native-ish size — avoids upscaling/pixelation */
  margin-inline: auto;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-bg-soft);
}
.cs-cover img,
.cs-cover video { width: 100%; height: auto; display: block; }

/* Branding case: stacked artboard gallery */
.cs-gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 1040px;
  margin-inline: auto;
  margin-top: var(--space-4);
}
.cs-gallery figure {
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--color-bg-soft);
}
.cs-gallery img { width: 100%; height: auto; display: block; }

.cs-body {
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  gap: var(--space-5);
  padding-block: var(--section-y);
}
.cs-body__lead { font-size: var(--fs-lead); color: var(--color-text); max-width: 60ch; }
.cs-body__lead + .cs-body__lead { margin-top: var(--space-3); color: var(--color-text-dim); }

.cs-next {
  border-top: 1px solid var(--color-line);
  padding-block: var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}
.cs-next__label { color: var(--color-text-mute); font-size: var(--fs-sm); }
.cs-next__title { font-size: var(--fs-h2); font-weight: 500; letter-spacing: var(--tracking-tight); }

@media (max-width: 760px) {
  .cs-body { grid-template-columns: 1fr; gap: var(--space-3); }
  .cs-next { flex-direction: column; align-items: flex-start; }
}
