/* ============================================================
   DAF — SHORT CASE template (secondary / idea-first cases)
   Inherits tokens + chrome from styles.css / layout.css / case.css
   Visual-first: typographic opening, one stat, the work itself.
   ============================================================ */

/* ---------------- opening — typographic, no hero band ---------------- */
.sc-open { border-bottom: 1px solid var(--line); }
.sc-open .sc-in {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(56px, 6.5vw, 110px) var(--pad) clamp(48px, 5vw, 84px);
}
.sc-meta {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 20px; flex-wrap: wrap; margin-bottom: clamp(34px, 3.6vw, 60px);
}
.sc-kicker {
  font-family: var(--mono); font-weight: 400; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--blue);
}
.sc-meta .eyebrow { margin-bottom: 0; }
.sc-q {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(44px, 6.2vw, 118px); line-height: 0.98;
  letter-spacing: -0.022em; font-optical-sizing: auto; text-wrap: balance;
  max-width: 14ch;
}
.sc-q em { font-style: italic; color: var(--blue); }
.sc-standfirst {
  display: grid; grid-template-columns: 1fr minmax(300px, 0.62fr);
  gap: clamp(30px, 4vw, 80px); align-items: end;
  margin-top: clamp(36px, 4vw, 64px);
}
.sc-standfirst .dek { margin-bottom: 0; max-width: 46ch; }
.sc-standfirst .sc-scope {
  font-family: var(--grotesk); font-weight: 600; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted);
  text-align: right;
}

/* ---------------- full-width visuals ---------------- */
.sc-bleed { width: 100%; line-height: 0; background: var(--ink); border-bottom: 1px solid var(--line); position: relative; }
.sc-bleed image-slot { display: block; width: 100% !important; height: auto !important; aspect-ratio: 2.4; }
.sc-bleed--board image-slot { aspect-ratio: 1.9; }
.sc-bleed .sc-cap {
  position: absolute; left: var(--pad); bottom: clamp(16px, 1.8vw, 28px); z-index: 2;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: rgba(242,239,233,.85); line-height: 1.5;
}

/* ---------------- the idea — stat + copy ---------------- */
.sc-idea {
  display: grid; grid-template-columns: minmax(260px, 0.7fr) 1.3fr;
  gap: clamp(34px, 4.5vw, 90px); align-items: center;
}
.sc-stat { min-width: 0; }
.sc-stat .n {
  font-family: var(--serif); font-weight: 400; line-height: 0.9;
  font-size: clamp(72px, 8.2vw, 150px); letter-spacing: -0.03em; color: var(--ink);
  white-space: nowrap;
}
.sc-stat .n em { font-style: italic; color: var(--blue); font-size: 0.5em; letter-spacing: -0.01em; }
.sc-stat .l {
  font-family: var(--grotesk); font-weight: 600; font-size: 10.5px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted);
  margin-top: 18px; line-height: 1.6;
}
.sc-idea .body-text { max-width: 56ch; }
.sc-idea .body-text + .body-text { margin-top: 16px; }

/* ---------------- payoff band ---------------- */
.sc-payoff { background: var(--ink); color: var(--paper); border-bottom: 1px solid var(--line); }
.case-hourz .sc-payoff { background: #E40521; }
.case-hourz .sc-payoff .sc-kicker { color: rgba(242, 239, 233, 0.75); }
.case-hourz .sc-payoff p em { color: var(--paper); }
.sc-payoff .sc-in {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(64px, 7.5vw, 130px) var(--pad);
  text-align: center;
}
.sc-payoff p {
  font-family: var(--serif); font-weight: 400; margin: 0 auto;
  font-size: clamp(30px, 3.8vw, 64px); line-height: 1.08;
  letter-spacing: -0.018em; max-width: 22ch; text-wrap: balance;
}
.sc-payoff p em { font-style: italic; color: var(--blue-soft); }
.sc-payoff .sc-kicker { display: block; margin-bottom: clamp(22px, 2.4vw, 36px); color: var(--blue-soft); }

/* ---------------- the work ---------------- */
.sc-work-head { margin-bottom: clamp(28px, 3vw, 46px); }
.sc-grid3 {
  display: grid; grid-template-columns: 1fr;
  gap: clamp(28px, 3vw, 48px);
}
.sc-grid3 figure { margin: 0; min-width: 0; }
.sc-grid3 image-slot { display: block; width: 100% !important; height: auto !important; aspect-ratio: 2500 / 1773; }
.sc-grid3 figcaption {
  display: flex; justify-content: space-between; align-items: baseline; gap: 12px;
  margin-top: 12px;
}
.sc-grid3 figcaption .t {
  font-family: var(--grotesk); font-weight: 700; font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink);
}
.sc-grid3 figcaption .d {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; color: var(--muted);
}
.sc-duo {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: clamp(14px, 1.6vw, 24px); margin-top: clamp(14px, 1.6vw, 24px);
}
.sc-duo image-slot { display: block; width: 100% !important; height: auto !important; aspect-ratio: 4 / 3; }

/* ---------------- gallery — 1 vertical left, 2 horizontals stacked right ---------------- */
.sc-gallery {
  display: grid; grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: clamp(14px, 1.6vw, 24px);
}
.sc-gallery .g-left { grid-row: 1 / 3; min-width: 0; }
.sc-gallery .g-left image-slot { display: block; width: 100% !important; height: 100% !important; }
.sc-gallery .g-right { min-width: 0; }
.sc-gallery .g-right image-slot { display: block; width: 100% !important; height: auto !important; aspect-ratio: 3 / 2; }
.sc-allmedia { margin-top: clamp(14px, 1.6vw, 24px); line-height: 0; }

/* ---------------- related / back ---------------- */
.sc-foot {
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; flex-wrap: wrap;
}
.sc-rel {
  display: inline-flex; align-items: baseline; gap: 10px;
  font-family: var(--grotesk); font-weight: 600; font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted);
  text-decoration: none;
}
.sc-rel .v { color: var(--blue); }
.sc-rel:hover .v { text-decoration: underline; }

/* ---------------- data strips — more air around the hairline ---------------- */
.case .cs .statline {
  margin-top: clamp(48px, 5vw, 80px);      /* space between content above and the line */
  padding-top: clamp(28px, 2.6vw, 40px);   /* space between the line and the numbers */
}
.case .cs .statline .l { margin-top: 12px; }
.case .cs .statline .s { padding-left: clamp(20px, 2vw, 32px); padding-right: clamp(20px, 2vw, 32px); }
.case .cs .statline .s:first-child { padding-left: 0; }

/* ---------------- responsive ---------------- */
@media (max-width: 940px) {
  .sc-standfirst { grid-template-columns: 1fr; align-items: start; }
  .sc-standfirst .sc-scope { text-align: left; }
  .sc-idea { grid-template-columns: 1fr; gap: 34px; }
  .sc-duo { grid-template-columns: 1fr; }
  .sc-gallery { grid-template-columns: 1fr; }
  .sc-gallery .g-left { grid-row: auto; }
  .sc-gallery .g-left image-slot { height: auto !important; aspect-ratio: 4 / 5; }
}
