@font-face {
  font-family: "Inter";
  src: url("../../Inter-Variable.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --green: #2d6a2d;
  --green-dark: #1a4a1a;
  --green-pale: #e8f5e9;
  /* Orange (accent) resta invariato — ma non va mai usato come colore di
     testo o come background con testo bianco: su bianco dà 2.02:1, su bianco
     + testo bianco dà 2.02:1, entrambi sotto WCAG AA. Vedi .update-badge e
     .wa-banner sotto. */
  --orange: #f5a623;
  --text: #212529;
  /* #6c757d su #f1f3f5 dava 4.21:1 — sotto 4.5:1. #495057 dà 7.1:1 e resta
     visivamente "muted" ma rispetta WCAG AA. */
  --text-muted: #495057;
  --gray-100: #f1f3f5;
  --gray-200: #e9ecef;
  --radius: 12px;
}

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: "Inter", sans-serif;
  color: var(--text);
  background: #fff;
}

/* Nav */
.top-bar {
  background: var(--green-dark);
  padding: 0.9rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.top-bar a {
  color: rgba(255, 255, 255, 0.75);
  text-decoration: none;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  transition: color 0.2s;
}
.top-bar a:hover {
  color: #fff;
}
.top-bar .logo {
  color: #fff;
  font-weight: 700;
  font-size: 0.95rem;
  margin-left: auto;
}

/* Hero */
.pp-hero {
  background: linear-gradient(135deg, var(--green-dark), var(--green));
  color: #fff;
  padding: 3rem 1.5rem 2.5rem;
  text-align: center;
}
.pp-hero h1 {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 800;
  margin-bottom: 0.5rem;
}
.pp-hero p {
  font-size: 0.9rem;
  opacity: 0.78;
}

/* Content */
.pp-body {
  max-width: 780px;
  margin: 3rem auto;
  padding: 0 1.5rem 4rem;
}

.pp-section {
  margin-bottom: 2.5rem;
}
.pp-section h2 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--green-dark);
  margin-bottom: 0.85rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--green-pale);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pp-section p,
.pp-section li {
  font-size: 0.92rem;
  line-height: 1.82;
  color: var(--text-muted);
}
.pp-section ul {
  list-style: none;
  padding: 0;
  margin-top: 0.5rem;
}
.pp-section ul li {
  padding: 0.3rem 0;
  padding-left: 1.2rem;
  position: relative;
}
.pp-section ul li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--green);
  font-weight: 700;
}

.info-card {
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
  border-left: 4px solid var(--green);
  border-radius: var(--radius);
  padding: 1.1rem 1.25rem;
  margin-top: 0.75rem;
  font-size: 0.9rem;
  line-height: 1.8;
  color: var(--text-muted);
}
.info-card strong {
  color: var(--text);
}

/* Griglia diritti GDPR (privacy.html) */
.rights-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-top: 0.75rem;
}
.right-item {
  background: var(--green-pale);
  border-radius: var(--radius);
  padding: 0.9rem 1rem;
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--green-dark);
}
.right-item strong {
  display: block;
  margin-bottom: 0.2rem;
  font-weight: 700;
}

.update-badge {
  display: inline-block;
  background: var(--orange);
  /* Testo scuro su arancione: 7.6:1 contro il #fff precedente a 2.02:1. */
  color: var(--text);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.2rem 0.65rem;
  border-radius: 50px;
  margin-bottom: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* WhatsApp banner (termini-e-condizioni.html) */
.wa-banner {
  background: linear-gradient(135deg, #f5a623, #e89b1f);
  /* Testo scuro su arancione: 7.6:1 invece del 2.02:1 del #fff precedente. */
  color: var(--text);
  padding: 1.5rem 1.75rem;
  border-radius: var(--radius);
  text-align: center;
  margin: 2.5rem 0;
  box-shadow: 0 4px 12px rgba(245, 166, 35, 0.2);
}
.wa-banner p {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  color: var(--text);
}
.wa-banner a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--green-dark);
  /* Bianco su verde scuro (#1a4a1a): 13:1. Il vecchio arancione su bianco
     dava 2.02:1 e falliva WCAG AA. */
  color: #fff;
  padding: 0.75rem 1.5rem;
  border-radius: 50px;
  font-weight: 700;
  text-decoration: none;
  transition:
    transform 0.2s,
    box-shadow 0.2s;
}
.wa-banner a:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Back button */
.back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 2rem;
  padding: 0.65rem 1.4rem;
  background: var(--green);
  color: #fff;
  border-radius: 50px;
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
  transition:
    background 0.2s,
    transform 0.2s;
}
.back-btn:hover {
  background: var(--green-dark);
  transform: translateY(-2px);
}

@media (max-width: 480px) {
  .rights-grid {
    grid-template-columns: 1fr;
  }
}
