/* ============================================================
   paragraf.tools - Consent + mailing consent UI
   ============================================================ */

.consent-banner {
  position: fixed;
  left: 20px;
  right: 20px;
  bottom: 20px;
  z-index: 1300;
  max-width: 980px;
  margin: 0 auto;
  transition: opacity .18s ease, transform .18s ease;
}
.consent-banner.is-hidden {
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px);
}
.consent-banner__inner {
  display: grid;
  gap: 18px;
  padding: 20px 22px;
  border-radius: 20px;
  border: 1px solid rgba(45, 27, 78, .14);
  background:
    linear-gradient(180deg, rgba(249, 145, 22, .10) 0%, rgba(255,255,255,.98) 45%),
    linear-gradient(135deg, rgba(112, 71, 176, .08) 0%, rgba(255,255,255,.98) 100%);
  box-shadow: 0 24px 80px rgba(25, 10, 52, .16);
  backdrop-filter: blur(14px);
}
.consent-banner__eyebrow {
  margin: 0 0 6px;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--orange-700);
}
.consent-banner__title {
  margin: 0 0 8px;
  font-family: var(--font-serif);
  font-size: 1.35rem;
  line-height: 1.18;
  color: var(--purple-900);
}
.consent-banner__text,
.consent-banner__legal {
  margin: 0;
  font-size: .92rem;
  line-height: 1.6;
  color: var(--neutral-700);
}
.consent-banner__legal a {
  color: var(--purple-700);
  font-weight: 600;
}
.consent-banner__prefs {
  display: grid;
  gap: 10px;
  margin: 14px 0 12px;
}
.consent-check {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 14px;
  border: 1px solid rgba(112, 71, 176, .12);
  border-radius: 14px;
  background: rgba(255,255,255,.84);
}
.consent-check input {
  margin-top: 3px;
  accent-color: var(--purple-700);
}
.consent-check span {
  display: grid;
  gap: 3px;
}
.consent-check strong {
  font-size: .92rem;
  color: var(--purple-900);
}
.consent-check small {
  font-size: .78rem;
  line-height: 1.5;
  color: var(--neutral-600);
}
.consent-check--locked {
  opacity: .88;
}
.consent-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}
.consent-banner__actions .btn--ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 16px;
  border-radius: 12px;
  border: 1px solid rgba(45, 27, 78, .12);
  background: transparent;
  color: var(--neutral-700);
  cursor: pointer;
}
.consent-banner__actions .btn--ghost:hover {
  border-color: rgba(112, 71, 176, .28);
  color: var(--purple-800);
}

.mailing-form {
  display: grid;
  gap: 12px;
}
.mailing-form__row {
  display: flex;
  gap: 8px;
}
.mailing-form__row > *:first-child {
  flex: 1;
}
.mailing-consent {
  display: grid;
  gap: 8px;
  text-align: left;
}
.mailing-consent__check {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: .86rem;
  line-height: 1.55;
  color: var(--neutral-700);
}
.mailing-consent__check input {
  margin-top: 3px;
  accent-color: var(--purple-700);
}
.mailing-consent__check strong {
  color: var(--purple-900);
}
.mailing-consent__note {
  margin: 0;
  font-size: .78rem;
  line-height: 1.55;
  color: var(--neutral-500);
}
.mailing-consent__note a {
  color: var(--purple-700);
  font-weight: 600;
}
.mailing-consent--compact {
  margin-top: 10px;
}
.mailing-consent--compact .mailing-consent__check,
.mailing-consent--compact .mailing-consent__note {
  font-size: .74rem;
}

.footer__privacy-btn {
  background: transparent;
  border: 0;
  padding: 0;
  font: inherit;
  color: rgba(243,239,250,.6);
  cursor: pointer;
  transition: color .15s ease;
}
.footer__privacy-btn:hover,
.footer__privacy-btn:focus-visible {
  color: rgba(243,239,250,.9);
}

@media (min-width: 960px) {
  .consent-banner {
    left: auto;
    right: 24px;
    max-width: 520px;
    margin: 0;
  }
}

@media (max-width: 640px) {
  .consent-banner {
    left: 12px;
    right: 12px;
    bottom: 12px;
  }
  .consent-banner__inner {
    padding: 16px;
    border-radius: 18px;
  }
  .consent-banner__title {
    font-size: 1.12rem;
  }
  .consent-banner__actions,
  .mailing-form__row {
    flex-direction: column;
  }
  .consent-banner__actions .btn--ghost,
  .consent-banner__actions .btn--secondary,
  .consent-banner__actions .btn--primary,
  .mailing-form__row .btn--primary {
    width: 100%;
    justify-content: center;
  }
}
