/* age-gate.css — blocking 18+ modal + compliance-footer-row + RG-block + affiliate banner */

.wh-age-gate {
  position: fixed; inset: 0;
  background: rgba(23, 21, 19, 0.88);
  z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-item);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
.wh-age-gate.is-visible { opacity: 1; pointer-events: auto; }
.wh-age-gate.is-hidden { display: none; }

.wh-age-modal {
  background: var(--c-paper);
  border: 1px solid var(--c-ink);
  border-radius: var(--r-md);
  max-width: 520px; width: 100%;
  max-height: calc(100dvh - 2 * var(--space-item));
  overflow-y: auto;
  padding: 48px;
  font-family: var(--f-body);
  color: var(--c-ink);
}
.wh-age-modal .wh-wordmark {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.04em;
  color: var(--c-accent);
  text-transform: uppercase;
  display: inline-block;
  border-bottom: 0;
}
.wh-age-modal h2 {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 1.25rem;
  margin: var(--space-item) 0 12px;
}
.wh-age-modal p { font-size: 15px; line-height: 1.6; margin: 0 0 16px; max-width: 44ch; }
.wh-age-modal .wh-age-actions {
  display: flex; gap: var(--space-item); align-items: center;
  margin-top: var(--space-item);
}
.wh-age-modal .wh-age-help {
  margin-top: var(--space-item);
  font-size: 13px; color: var(--c-ink-muted);
}
@media (max-width: 520px) {
  .wh-age-modal { padding: 28px; }
}
