/* --- newsletter subscribe — full-bleed dark band with a centered card.
   Rendered as a sibling of `.site-main` inside `<main>`, so it spans
   the viewport naturally without a `100vw` breakout. */
.subscribe {
  margin-top: var(--sp-mega);
  padding: var(--sp-mega) 1.25rem;
  background: var(--color-surface-dark);
  color: var(--color-on-dark-soft);

  & .subscribe__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    max-width: var(--max-w);
    margin-inline: auto;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-bg);
    color: var(--color-fg);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.35);
  }

  & .subscribe__media {
    background: var(--color-bg-soft);

    & img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      aspect-ratio: 16 / 10;
    }
  }

  & .subscribe__form {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--sp-sm);
    padding: var(--sp-giga);
    text-align: center;
  }

  & .subscribe__heading {
    font-family: var(--font-display);
    font-size: var(--fs-giga);
    font-weight: 700;
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
    text-wrap: balance;
  }

  & .subscribe__blurb {
    margin: 0 auto var(--sp-base);
    max-width: 38ch;
    color: var(--color-fg-prose);
    font-size: var(--fs-xs);
    line-height: 1.5;
  }

  & .subscribe__input {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius);
    font: inherit;
    font-size: var(--fs-xs);
    text-align: center;
    outline: none;
    transition: border-color .15s ease, box-shadow .15s ease;

    &:focus {
      border-color: var(--color-fg);
      box-shadow: 0 0 0 4px rgba(15, 23, 42, .06);
    }
  }

  & .subscribe__btn {
    width: 100%;
    padding: 0.75rem 1rem;
    background: var(--color-fg);
    color: var(--color-bg);
    border: 0;
    border-radius: var(--radius);
    font: inherit;
    font-weight: 600;
    font-size: var(--fs-xs);
    cursor: pointer;
    transition: background .15s ease, transform .15s ease;

    &:hover:not(:disabled) { background: var(--color-accent); transform: translateY(-1px); }
    &:disabled             { opacity: 0.7; cursor: progress; }
  }

  /* Honeypot — visually hidden but reachable to screen readers. */
  & .subscribe__honeypot {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }

  & .subscribe__msg {
    margin: 0;
    font-size: var(--fs-xxs);
    line-height: 1.4;
  }
  & .subscribe__msg--error   { color: #BD3F2C; }
  & .subscribe__msg--success { color: #317909; font-weight: 600; }

  @media (max-width: 760px) {
    padding: var(--sp-lg) 1.25rem;

    & .subscribe__inner    { grid-template-columns: 1fr; }
    & .subscribe__form     { padding: var(--sp-md); }
    & .subscribe__media img { aspect-ratio: 16 / 9; }
  }
}
