/* ===========================================================
   Deep Dives pillar — archive + small bits of article chrome.
   Self-contained / additive: this file only adds .dd-* selectors
   (and .pill-deepdive / .cta-ghost helpers used by the renderer).
   Loaded as its own versioned <link> so it never collides with
   collection.css. Uses the site's existing CSS variables.
   =========================================================== */

.dd-archive { max-width: 1100px; margin: 0 auto; padding: clamp(40px, 5vw, 60px) 24px 90px; }

/* ---- 4a. weekly-email banner — full-width dark page headline ---- */
.dd-banner { background: var(--ink); color: var(--paper); padding: clamp(40px, 7vw, 76px) 24px; }
.dd-banner-inner { max-width: 760px; margin: 0 auto; text-align: center; }
.dd-banner-eyebrow {
  display: block; font: 600 12px/1 var(--mono); letter-spacing: .22em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 18px;
}
.dd-banner-head { font: 400 clamp(30px, 5vw, 50px)/1.1 var(--serif); color: var(--paper); margin: 0 0 18px; }
.dd-banner-head .dd-em { color: var(--accent); }
.dd-banner-sub {
  font: 400 clamp(15px, 2.2vw, 18px)/1.6 var(--body-serif);
  color: var(--paper); opacity: .78; margin: 0 auto 28px; max-width: 560px;
}
/* The shared <NewsletterSignup> carries its own copy block; the banner headline
   already says it, so suppress the duplicate and recolour the form for the dark
   ground (light field + accent button). Same handler / `subscribers` write. */
.dd-banner-form { max-width: 460px; margin: 0 auto; }
.dd-banner-form .nl-copy { display: none; }
.dd-banner-form .nl-signup { background: transparent; border: none; box-shadow: none; padding: 0; }
.dd-banner-form .nl-form { display: flex; gap: 8px; }
.dd-banner-form .nl-input {
  flex: 1 1 auto; min-width: 0; background: var(--paper); color: var(--ink);
  border: 1px solid var(--paper); border-radius: 8px; padding: 12px 14px; font: 500 15px/1 var(--sans);
}
.dd-banner-form .nl-input::placeholder { color: var(--ink-mute); }
.dd-banner-form .nl-btn {
  flex: 0 0 auto; background: var(--accent); color: #fff; border: none; border-radius: 8px;
  padding: 12px 22px; font: 700 14px/1 var(--sans); letter-spacing: .02em; cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
}
.dd-banner-form .nl-foot { color: var(--paper); opacity: .6; margin-top: 12px; font: 400 12px/1.4 var(--sans); text-align: center; }
.dd-banner-form .nl-err { color: #ffd9cf; margin-top: 8px; font: 500 13px/1.4 var(--sans); text-align: center; }
.dd-banner-form .nl-done { justify-content: center; gap: 9px; color: var(--paper); }
.dd-banner-form .nl-tick { color: var(--accent); }

/* ---- 4b. featured hero — de-boxed, sits on the cream ---- */
.dd-hero {
  display: grid; grid-template-columns: minmax(0, 300px) 1fr; gap: clamp(22px, 4vw, 44px);
  align-items: center; width: 100%; text-align: left; cursor: pointer;
  background: none; border: 0; border-radius: 0; padding: 0; margin: 0 0 34px;
  font: inherit; color: inherit; -webkit-appearance: none; appearance: none;
}
.dd-hero-cover {
  aspect-ratio: 1; border-radius: 8px; overflow: hidden; background: #0a0a0a;
  box-shadow: 0 22px 46px -28px rgba(23,19,15,.6);
}
.dd-hero-cover img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s ease; }
.dd-hero:hover .dd-hero-cover img { transform: scale(1.03); }
.dd-hero-body { min-width: 0; }
.dd-hero-eyebrow {
  display: block; font: 600 11px/1 var(--mono); letter-spacing: .2em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 12px;
}
.dd-hero-title { font: 400 clamp(28px, 4vw, 42px)/1.08 var(--serif); color: var(--ink); margin: 0 0 8px; }
.dd-hero-meta { font: 600 14px/1 var(--sans); color: var(--ink-2); margin-bottom: 16px; }
.dd-hero-excerpt { font: 400 17px/1.62 var(--body-serif); color: var(--ink-2); margin: 0 0 20px; max-width: 52ch; }
.dd-hero-cta { font: 700 14px/1 var(--sans); color: var(--accent); }
.dd-hero:hover .dd-hero-cta { text-decoration: underline; }

/* ---- emailed-date eyebrow (mono) — real Wednesday from published_at ---- */
.dd-date {
  display: block; font: 500 11px/1.3 var(--mono); letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-mute); margin: 0 0 10px;
}
.dd-date-sm { margin: 0 0 6px; font-size: 10px; letter-spacing: .12em; }

/* ---- pillar filters ---- */
.dd-filters { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 26px; }
.dd-filter {
  border: 1px solid var(--rule, #d8d0bd); background: transparent; color: var(--ink2, #3a322a);
  border-radius: 30px; padding: 7px 16px; font: 600 13px/1 var(--sans, system-ui), sans-serif; cursor: pointer;
}
.dd-filter.is-active { background: var(--ink, #17130f); color: #fff; border-color: var(--ink, #17130f); }

/* ---- 4c. archive gallery — de-boxed 4-up on the cream ---- */
.dd-archive-sec { border-top: 1px solid var(--rule); padding-top: 30px; }
.dd-sec-eyebrow {
  font: 600 12px/1 var(--mono); letter-spacing: .2em; text-transform: uppercase;
  color: var(--ink-mute); margin: 0 0 24px;
}
.dd-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(18px, 2.6vw, 30px); }
.dd-card {
  display: flex; flex-direction: column; text-align: left; cursor: pointer;
  background: none; border: 0; border-radius: 0; padding: 0;
  font: inherit; color: inherit; -webkit-appearance: none; appearance: none;
}
.dd-card-cover {
  aspect-ratio: 1; background: #0a0a0a; border-radius: 6px; overflow: hidden;
  box-shadow: 0 14px 30px -22px rgba(23,19,15,.5);
}
.dd-card-cover img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s ease; }
.dd-card:hover .dd-card-cover img { transform: scale(1.04); }
.dd-card-body { padding: 13px 2px 0; }
.dd-card-title { font: 400 19px/1.18 var(--serif); color: var(--ink); margin: 3px 0 4px; }
.dd-card-meta { font: 500 12px/1.3 var(--mono); letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mute); }

/* ---- chips ---- */
.dd-chip {
  display: inline-block; font: 700 10px/1 var(--sans, system-ui), sans-serif;
  letter-spacing: .12em; text-transform: uppercase; color: var(--accent, #cf4827);
  border: 1px solid currentColor; border-radius: 20px; padding: 4px 10px; margin-bottom: 12px;
}
.dd-chip-sm { margin-bottom: 8px; padding: 3px 8px; font-size: 9px; }

.dd-more { text-align: center; margin-top: 40px; }

/* ---- helpers reused on the article (rank chrome off) ---- */
.pill-deepdive { background: var(--accent, #cf4827) !important; color: #fff !important; border: none !important; }
.cta-ghost { background: transparent !important; color: var(--ink, #17130f) !important; border: 1px solid var(--rule, #d8d0bd) !important; box-shadow: none !important; }

/* ---- responsive: grid steps down; hero stacks + centres (MOB-05) ---- */
@media (max-width: 900px) {
  .dd-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 680px) {
  .dd-hero { grid-template-columns: 1fr; gap: 22px; justify-items: center; text-align: center; }
  .dd-hero-cover { width: min(78vw, 300px); }
  .dd-hero-body { text-align: center; }
  .dd-hero-excerpt { margin-left: auto; margin-right: auto; }
  .dd-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .dd-banner-form .nl-form { flex-direction: column; }
  .dd-banner-form .nl-btn { justify-content: center; }
}
