/* =============================================================================
   ADU Explorer — Affiliate slot
   Tasteful, clearly-labeled. Never confused with editorial.
   ============================================================================= */

.affiliate {
  margin: var(--s-4) 0;
  padding: var(--s-3);
  background: var(--paper);
  border: 1px dashed var(--rule-strong);
  position: relative;
  max-width: 64rem;
}

.affiliate__stamp {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--stamp);
  margin-bottom: var(--s-2);
  padding-bottom: var(--s-1);
  border-bottom: 1px dotted var(--rule);
  display: flex;
  align-items: center;
  gap: var(--s-1);
}
.affiliate__stamp::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  background: var(--stamp);
  border-radius: 50%;
  flex-shrink: 0;
}

.affiliate__list {
  list-style: none;
  padding: 0;
  display: grid;
  gap: 0;
}

.affiliate__item {
  border-bottom: 1px dotted var(--rule);
}
.affiliate__item:last-child { border-bottom: 0; }

.affiliate__link {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: var(--s-2);
  padding: var(--s-2) 0;
  text-decoration: none;
  color: var(--ink);
  transition: color var(--t-fast) var(--ease),
              background var(--t-fast) var(--ease);
}
.affiliate__link:hover {
  background: var(--paper-inset);
  margin-inline: calc(var(--s-2) * -1);
  padding-inline: var(--s-2);
}
.affiliate__link:hover .affiliate__label { color: var(--stamp); }
.affiliate__link:hover .affiliate__arrow { color: var(--stamp); transform: translateX(2px); }

.affiliate__label {
  display: block;
  font-family: var(--font-serif);
  font-size: var(--t-h4);
  font-variation-settings: "opsz" 20, "wght" 460;
  letter-spacing: -0.005em;
  line-height: 1.25;
  transition: color var(--t-fast) var(--ease);
}

.affiliate__desc {
  display: block;
  font-family: var(--font-serif);
  font-size: var(--t-body-sm);
  font-variation-settings: "opsz" 16, "wght" 380;
  color: var(--ink-soft);
  line-height: 1.5;
  margin-top: 2px;
  grid-column: 1;
}

.affiliate__arrow {
  font-family: var(--font-mono);
  font-size: 1.1rem;
  color: var(--ink-soft);
  align-self: center;
  grid-row: 1 / span 2;
  grid-column: 2;
  transition: color var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease);
}

.affiliate__disclosure {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  letter-spacing: 0.06em;
  color: var(--ink-faded);
  line-height: 1.55;
  margin-top: var(--s-2);
  padding-top: var(--s-1);
  border-top: 1px dotted var(--rule);
}
.affiliate__disclosure a {
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 1px solid var(--rule);
}
.affiliate__disclosure a:hover {
  color: var(--stamp);
  border-bottom-color: var(--stamp);
}

/* -----------------------------------------------------------------------------
   Legal / informational pages — long-form prose under the dossier shell.
   ----------------------------------------------------------------------------- */
.legal-prose {
  font-size: var(--t-body);
  line-height: var(--lh-prose);
  max-width: 56rem;
}
.legal-prose h2 {
  font-family: var(--font-serif);
  font-size: var(--t-h3);
  font-variation-settings: "opsz" 28, "wght" 460;
  letter-spacing: -0.008em;
  margin-top: var(--s-5);
  margin-bottom: var(--s-2);
}
.legal-prose h3 {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--stamp);
  margin-top: var(--s-3);
  margin-bottom: var(--s-1);
}
.legal-prose p {
  margin-bottom: var(--s-2);
}
.legal-prose ul {
  padding-left: var(--s-3);
  margin-bottom: var(--s-2);
}
.legal-prose ul li {
  margin-bottom: var(--s-1);
}
.legal-prose strong { font-variation-settings: "opsz" 18, "wght" 600; }
.legal-prose a {
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
  text-decoration: none;
}
.legal-prose a:hover { color: var(--stamp); border-bottom-color: var(--stamp); }
