/* =========================================================================
   page-policy.css — shared styles for all policy/* pages
   Canonical components (.card, .btn, .pill, .container, .section-head,
   .kicker, h2) live in foundation.css, layout.css, and design-system.css.
   This file handles only policy-page-specific patterns.
   ========================================================================= */

/* ── Link colour (policy content area) ──────────────────────────────────── */
main a { color: var(--hvb-teal); text-decoration: none; }
main a:hover { text-decoration: underline; }

/* ── Secondary paragraph ─────────────────────────────────────────────────── */
.sub {
  margin: 6px 0 0;
  color: var(--hvb-slate);
  font-size: 15px;
  line-height: 1.5;
}

/* ── Custom textured hero (NOT site-hero full-bleed) ─────────────────────── */
/* Each page sets its own .hero background via a page-specific override below */
.hero {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(14, 59, 46, 0.10);
}

.hero-inner { padding: 38px 0 18px; }

/* Split hero layout (hero-grid) — EJ, CLCPA */
.hero-inner.hero-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 32px;
  align-items: center;
}

.hero-text {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.hero-figure {
  margin: 0;
  aspect-ratio: 1600 / 1209;
  max-width: 100%;
}

.hero-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-1);
  display: block;
}

.hero-intro {
  margin: 0;
  color: var(--hvb-slate);
  max-width: 72ch;
  line-height: 1.45;
}

/* Quick-tags row */
.kpis {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

/* ── Per-page hero backgrounds ───────────────────────────────────────────── */

/* policy/index.html — circular-flow + topo-hudson-lines */
/* (index uses .site-hero full-bleed; no custom .hero background needed) */

/* policy/funding-grants.html — circular-flow + topo */
.page-policy-funding .hero {
  background:
    radial-gradient(1100px 520px at 15% 10%, rgba(233, 169, 35, 0.14), rgba(233, 169, 35, 0) 62%),
    linear-gradient(180deg, rgba(14, 59, 46, 0.10), rgba(14, 59, 46, 0.02)),
    url("../textures/tx_circular-flow_tile.svg"),
    url("../textures/tx_topo-hudson-lines_tile.svg");
  background-repeat: no-repeat, no-repeat, repeat, repeat;
  background-size: cover, cover, 560px 560px, 520px 520px;
}

/* policy/biosolids-safety.html — circular-flow only */
.page-policy-biosolids .hero {
  background:
    radial-gradient(1100px 520px at 15% 10%, rgba(233, 169, 35, 0.14), rgba(233, 169, 35, 0) 62%),
    linear-gradient(180deg, rgba(14, 59, 46, 0.10), rgba(14, 59, 46, 0.02)),
    url("../textures/tx_circular-flow_tile.svg");
  background-repeat: no-repeat, no-repeat, repeat;
  background-size: cover, cover, 560px 560px;
}

/* policy/environmental-justice.html — water-ripple */
.page-policy-ej .hero {
  background:
    radial-gradient(1100px 520px at 15% 10%, rgba(233, 169, 35, 0.14), rgba(233, 169, 35, 0) 62%),
    linear-gradient(180deg, rgba(14, 59, 46, 0.10), rgba(14, 59, 46, 0.02)),
    url("../textures/tx_water-ripple_tile.svg");
  background-repeat: no-repeat, no-repeat, repeat;
  background-size: cover, cover, 760px 760px;
}

/* policy/clcpa.html — topo-hudson-lines */
.page-policy-clcpa .hero {
  background:
    radial-gradient(1100px 520px at 15% 10%, rgba(233, 169, 35, 0.14), rgba(233, 169, 35, 0) 62%),
    linear-gradient(180deg, rgba(14, 59, 46, 0.10), rgba(14, 59, 46, 0.02)),
    url("../textures/tx_topo-hudson-lines_tile.svg");
  background-repeat: no-repeat, no-repeat, repeat;
  background-size: cover, cover, 760px 760px;
}

/* policy/recommendations.html — topo-hudson-lines (slight intensity variation) */
.page-policy-recommendations .hero {
  background:
    radial-gradient(1100px 520px at 15% 10%, rgba(233, 169, 35, 0.12), rgba(233, 169, 35, 0) 62%),
    linear-gradient(180deg, rgba(14, 59, 46, 0.12), rgba(14, 59, 46, 0.04)),
    url("../textures/tx_topo-hudson-lines_tile.svg");
  background-repeat: no-repeat, no-repeat, repeat;
  background-size: cover, cover, 760px 760px;
}

/* ── Recommendations hero layout (flex split) ────────────────────────────── */
.page-policy-recommendations .hero-inner { padding: 34px 0 16px; }

.hero-layout {
  display: flex;
  gap: 32px;
  align-items: center;
  flex-wrap: wrap;
}

.hero-content { flex: 1 1 320px; }

.hero-media {
  flex: 0 0 320px;
  border-radius: var(--radius-card);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.4);
  box-shadow: var(--shadow-1);
  background: #fff;
}

.hero-media img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ── Table of contents sidebar ───────────────────────────────────────────── */
.toc {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.toc a {
  display: block;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(14, 59, 46, 0.10);
  background: rgba(255, 255, 255, 0.55);
  text-decoration: none;
  color: var(--hvb-black);
  margin-top: 8px;
}

.toc a:hover { background: rgba(31, 111, 98, 0.08); }

.toc a.active {
  background: rgba(14, 59, 46, 0.10);
  border-color: rgba(14, 59, 46, 0.18);
  font-weight: 900;
  color: var(--hvb-green);
}

/* ── Amber callout block ─────────────────────────────────────────────────── */
.callout {
  border-left: 4px solid rgba(233, 169, 35, 0.75);
  background: #fff;
  border-radius: 14px;
  padding: 14px;
  border-top: 1px solid rgba(14, 59, 46, 0.10);
  border-right: 1px solid rgba(14, 59, 46, 0.10);
  border-bottom: 1px solid rgba(14, 59, 46, 0.10);
  margin-top: 12px;
  color: var(--hvb-slate);
}

.callout strong { color: var(--hvb-black); }

/* ── Link row ────────────────────────────────────────────────────────────── */
.linkrow {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

/* ── Policy summary grid (EJ, CLCPA, invasive species) ──────────────────── */
.policy-summary-grid { margin: 32px 0; }

.policy-summary-grid__cards {
  display: grid;
  gap: 18px;
}

@media (min-width: 960px) {
  .policy-summary-grid__cards {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  }
}

.policy-summary-card {
  background: var(--hvb-paper);
  border: 1px solid rgba(14, 59, 46, 0.10);
  border-radius: var(--radius-card);
  padding: 18px;
  box-shadow: var(--shadow-1);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.policy-summary-card h2 {
  margin: 0;
  font-size: 18px;
  font-family: var(--font-head);
}

.policy-summary-card p { margin: 0; color: var(--hvb-slate); }

.policy-summary-card ul {
  margin: 0;
  padding-left: 18px;
  color: var(--hvb-slate);
}

.policy-summary-card.related-links { margin-top: 24px; }

/* CLCPA uses .container directly as the grid wrapper (no __cards div) */
.page-policy-clcpa .policy-summary-grid .container {
  display: grid;
  gap: 18px;
}

@media (min-width: 960px) {
  .page-policy-clcpa .policy-summary-grid .container {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  }
}

/* ── Two-column main+aside grid ──────────────────────────────────────────── */
.policy-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 14px;
  align-items: start;
}

@media (max-width: 980px) {
  .policy-grid { grid-template-columns: 1fr; }
}

/* Biosolids variant (slightly wider main) */
.page-policy-biosolids .policy-grid {
  grid-template-columns: 1.15fr 0.85fr;
}

/* ── Badge pill (policy/index.html doc cards) ────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--hvb-green);
  background: rgba(14, 59, 46, 0.10);
  border: 1px solid rgba(14, 59, 46, 0.14);
  padding: 6px 10px;
  border-radius: 999px;
  white-space: nowrap;
}

/* ── Doc card list (policy/index.html) ───────────────────────────────────── */
.doclist { display: grid; gap: 12px; }

.doc {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  background:
    linear-gradient(180deg, rgba(31, 111, 98, 0.06), rgba(31, 111, 98, 0.02)),
    url("../textures/tx_recycled-paper_tile.png");
  background-repeat: no-repeat, repeat;
  background-size: cover, 640px 640px;
}

.dochead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.meta {
  margin: 0;
  color: var(--hvb-slate);
  font-size: 13.5px;
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}

/* ── Funding columns (policy/index.html) ─────────────────────────────────── */
.funding-section { max-width: 1200px; margin-inline: auto; }

.funding-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.funding-column {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

@media (max-width: 1100px) {
  .funding-columns { grid-template-columns: 1fr; }
}

/* ── Checklist (funding-grants.html) ─────────────────────────────────────── */
.checklist {
  padding-left: 18px;
  margin: 10px 0 0;
  color: var(--hvb-slate);
}

/* ── Warning block (environmental-justice.html) ──────────────────────────── */
.warning {
  border-left: 4px solid rgba(233, 60, 35, 0.55);
  background: rgba(233, 60, 35, 0.08);
  padding: 12px;
  border-radius: 12px;
  margin-top: 12px;
  color: var(--hvb-slate);
}

/* ── Recommendations-specific ────────────────────────────────────────────── */
.intro {
  margin-top: 24px;
  padding: 18px;
  border-radius: var(--radius-card);
  background: white;
  border: 1px solid rgba(14, 59, 46, 0.08);
  box-shadow: var(--shadow-1);
}

.intro p { margin: 0; color: var(--hvb-slate); }

.theme-grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 980px) {
  .theme-grid { grid-template-columns: 1fr; }
}

.theme-card {
  background: var(--hvb-paper);
  border: 1px solid rgba(14, 59, 46, 0.12);
  border-radius: var(--radius-card);
  padding: 22px;
  box-shadow: var(--shadow-1);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.theme-card h2 {
  margin: 0;
  font-family: var(--font-head);
  font-size: 20px;
  letter-spacing: -0.02em;
}

.theme-card ul {
  margin: 0;
  padding-left: 16px;
  color: var(--hvb-slate);
}

.theme-card li { margin: 6px 0; }

.theme-letter {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--hvb-green);
}

.card-summary { margin: 0; color: var(--hvb-slate); }

.who-for {
  margin: 0;
  font-weight: 600;
  color: var(--hvb-black);
}

.cta-band {
  margin-top: 32px;
  padding: 22px;
  border-radius: var(--radius-card);
  background: var(--hvb-green);
  color: #fff;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.cta-band p { margin: 0; max-width: 72ch; }
.cta-band .btn { border-color: rgba(255, 255, 255, 0.4); }

/* ── Biosolids stacked layout ────────────────────────────────────────────── */
/* Section cards within the main container get top spacing */
.page-policy-biosolids main .container > section.card { margin-top: 24px; }
