/* ═══════════════════════════════════════════════════════════════
   PAGINE EDITORIALI/LEGALI — newsletter, cookie, privacy
   Usa i token definiti in homepage.css (caricato prima di questo file).
═══════════════════════════════════════════════════════════════ */

.page-editoriale {
  max-width: var(--col-text);
  margin: 0 auto;
  padding: var(--space-5) var(--margin-page) var(--space-6);
}

.page-editoriale__header {
  margin-bottom: var(--space-4);
}

.page-editoriale__kicker {
  display: block;
  color: var(--color-text-accent);
  margin-bottom: var(--space-2);
}

.page-editoriale__titolo {
  margin-bottom: var(--space-3);
}

.page-editoriale__standfirst {
  max-width: 60ch;
}

.page-editoriale__aggiornato {
  display: block;
  margin-top: var(--space-2);
  color: var(--color-text-tertiary);
}

/* ─── Corpo testo legale ─── */

.legal-body {
  margin-top: var(--space-4);
}

.legal-body h2 {
  font-size: var(--text-lg);
  font-weight: 300;
  margin-top: var(--space-4);
  margin-bottom: var(--space-2);
  padding-top: var(--space-3);
  border-top: 0.5px solid var(--color-border-secondary);
}

.legal-body h3 {
  font-size: var(--text-md);
  font-weight: 400;
  margin-top: var(--space-3);
  margin-bottom: var(--space-1);
}

.legal-body p,
.legal-body li {
  font-size: var(--text-base);
  line-height: var(--leading-body);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}

.legal-body ul {
  list-style: none;
  padding-left: var(--space-3);
}

.legal-body li {
  position: relative;
}

.legal-body li::before {
  content: '—';
  position: absolute;
  left: calc(-1 * var(--space-3));
  color: var(--color-text-tertiary);
}

/* Nota segnaposto per testo da redigere col consulente legale */
.legal-placeholder {
  background-color: var(--color-bg-secondary);
  border-left: 2px solid var(--color-border-accent);
  padding: var(--space-2) var(--space-3);
  margin: var(--space-2) 0;
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
}

/* ─── Tabella cookie ─── */

.legal-table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-3) 0;
  font-size: var(--text-sm);
}

.legal-table th,
.legal-table td {
  text-align: left;
  padding: var(--space-2);
  border-bottom: 0.5px solid var(--color-border-secondary);
  vertical-align: top;
}

.legal-table th {
  font-family: var(--font-body);
  font-weight: 500;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}

.legal-table td {
  color: var(--color-text-secondary);
  line-height: 1.5;
}

/* ─── Box newsletter su pagina dedicata ─── */

.nl-box {
  padding: var(--space-4);
  background-color: var(--color-accent-verde-alpi-light);
  border: 0.5px solid var(--color-border-secondary);
}

.nl-nota {
  margin-top: var(--space-3);
  max-width: 60ch;
}

/* ─── Messaggio di esito ─── */

.nl-esito {
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-3);
  font-size: var(--text-sm);
  line-height: 1.5;
  border-left: 2px solid;
}

.nl-esito--ok {
  background-color: var(--color-accent-verde-alpi-light);
  border-left-color: var(--color-border-accent);
  color: var(--color-text-accent);
}

.nl-esito--err {
  background-color: #F3EAEA;
  border-left-color: var(--color-accent-cordovan);
  color: var(--color-accent-cordovan);
}

/* ─── Form contatti ─── */

.ct-form__field {
  margin-bottom: var(--space-3);
  display: flex;
  flex-direction: column;
}

.ct-form__field .nl-form__input {
  width: 100%;
}

.ct-form__textarea {
  resize: vertical;
  min-height: 8rem;
  font-family: inherit;
}

.ct-form__consenso {
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
  margin: var(--space-3) 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-text-secondary);
}

.ct-form__consenso input {
  margin-top: 0.2em;
  flex-shrink: 0;
}

.ct-form__submit {
  margin-top: var(--space-2);
}
