:root{
  --bg:#f5f2ec;              /* fondo crema caldo */
  --card:#ffffff;            /* box bianchi */
  --muted:#6b6f76;           /* testo secondario */
  --text:#1e2430;            /* testo principale */
  --line:#e6e1d8;            /* linee sottili */

  --accent:#1f3557;          /* blu istituzionale */
  --accent2:#2e4a78;
  --good:#3f8f6a;
  --warn:#b58b3c;

  --radius: 12px;
  --shadow: 0 8px 24px rgba(0,0,0,.06);
  --max: 1120px;
}


    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family:var(--font);
      background: var(--bg);
      color:var(--text);
      line-height:1.55;
    }
    a{color:inherit}
    .wrap{max-width:var(--max); margin:0 auto; padding:0 20px}
	/* HERO layout desktop/tablet: testo a sinistra, riepilogo a destra */
.hero-grid{
  display: grid;
  margin-top: 24px;
  grid-template-columns: minmax(0,1fr) 460px; /* prova 420/440/460 */
  gap: 18px;
  align-items: start;
}


    .nav{
    background: #ffffff;
    border-bottom:1px solid var(--line);
    }

    .nav-inner{
      display:flex; align-items:center; justify-content:space-between;
      padding:14px 0;
      gap:16px;
    }
    .brand{display:flex; align-items:center; gap:12px; min-width: 260px;}
    .logo{
      width:38px; height:38px; border-radius:12px;
      background: linear-gradient(135deg, var(--accent), var(--accent2));
      box-shadow: 0 12px 30px rgba(124,92,255,.25);
    }
    .brand h1{font-size:14px; margin:0; letter-spacing:.2px}
    .brand .sub{display:block; color:var(--muted); font-size:12px; margin-top:2px}
    .nav-links{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end}
    .nav-links a{
      text-decoration:none; color:var(--muted);
      font-size:13px; padding:8px 10px; border-radius:12px;
    }
    .nav-links a:hover{color:var(--text); background:rgba(255,255,255,.06)}
.btn:hover{
  background:var(--accent);
  color:#ffffff;
}
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:10px;
  text-decoration:none;
  border:2px solid #1f3557;
  font-weight:600;
  transition:.2s ease;
}

.btn.primary{
  background:#1f3557;
  border:2px solid #1f3557;
  color:#ffffff;
}

.btn.primary:hover{
  background:#162844;
  color:#ffffff;
}

    .kicker{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:8px 12px;
      border-radius:999px;
      background: rgba(255,255,255,.06);
      border:1px solid var(--line);
      color:var(--muted);
      font-size:13px;
      width:fit-content;
    }
    .dot{
      width:8px; height:8px; border-radius:99px;
      background: var(--good);
      box-shadow: 0 0 0 6px rgba(36,209,139,.15);
    }
    .hero h2{
      margin:14px 0 10px;
      font-size: clamp(30px, 3.4vw, 52px);
      line-height:1.08;
      letter-spacing:-.5px;
    }
    .hero p{
      margin: 0 0 18px;
      color: var(--muted);
      font-size: 16px;
      max-width: 60ch;
    }
    .cta-row{display:flex; gap:12px; flex-wrap:wrap; align-items:center}
    .mini{color: var(--muted); font-size: 13px; margin-top: 12px;}
    .card{
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    }

    .hero-card{padding:18px}
    .hero-card h3{margin:0 0 10px; font-size:14px; color: var(--muted); font-weight:600}
    .stat{
      display:flex; justify-content:space-between; align-items:baseline;
      padding:12px 0;
      border-top:1px solid var(--line);
      gap:14px;
    }
    .stat:first-of-type{border-top:0}
    .stat b{font-size:16px; text-align:right}
    .stat span{color:var(--muted); font-size:13px}
    .pill{
      display:inline-flex; align-items:center; gap:8px;
      padding:7px 10px; border-radius:999px;
      border:1px solid var(--line);
      color: var(--muted);
      font-size:12px;
      background: rgba(255,255,255,.04);
    }
    .pill strong{color:var(--text); font-weight:700}
    .section{padding: 22px 0}
    .section h3{margin:0 0 10px; font-size: 22px; letter-spacing:-.2px;}
    .section p{margin:0 0 16px; color:var(--muted)}
    .grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
    .grid-2{display:grid; grid-template-columns: repeat(2, 1fr); gap:14px;}
    .panel{padding:16px}
    .panel h4{margin:0 0 8px; font-size:15px}
    .panel ul{margin:0; padding-left:18px; color:var(--muted)}
    .panel li{margin:8px 0}
    .tag{
      display:inline-flex; align-items:center;
      padding:6px 10px; border-radius:12px;
      border:1px solid var(--line);
      background: rgba(255,255,255,.04);
      color: var(--muted);
      font-size:12px;
      margin-right:8px;
      margin-bottom:8px;
    }
.notice{
  padding:14px 16px;
  border-radius:12px;
  border:1px solid #e7d9b8;
  background:#fff8e8;
  color:#8a6a2f;
  font-weight:500;
}

.ok{
  padding:14px 16px;
  border-radius:12px;
  border:1px solid #cde5db;
  background:#edf7f2;
  color:#2f6f59;
  font-weight:500;
}

    .steps{
      counter-reset: step;
      display:grid;
      gap:10px;
      margin: 0;
      padding: 0;
      list-style: none;
    }
    .steps li{
      display:flex; gap:12px; align-items:flex-start;
      padding: 12px 12px;
      border-radius: 14px;
      border: 1px solid var(--line);
      background: rgba(255,255,255,.04);
    }
    .steps li::before{
      counter-increment: step;
      content: counter(step);
      width: 28px; height: 28px;
      display:flex; align-items:center; justify-content:center;
      border-radius: 10px;
      background: rgba(124,92,255,.18);
      border:1px solid rgba(124,92,255,.22);
      font-weight:800;
      flex: 0 0 auto;
    }
    .faq{display:grid; gap:10px;}
    details{
      border: 1px solid var(--line);
      background: rgba(255,255,255,.04);
      border-radius: 14px;
      padding: 12px 12px;
    }
    summary{cursor:pointer; font-weight:650}
    details p{margin:10px 0 0; color:var(--muted)}
    footer{
      padding: 34px 0 46px;
      border-top: 1px solid var(--line);
      margin-top: 22px;
      color: var(--muted);
    }
/* FOOTER responsive */
.footer-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px; /* desktop */
  gap: 18px;
  align-items: start;
}

/* importantissimo: evita overflow per testi lunghi/URL */
.footer-grid a,
.footer-grid p,
.footer-grid div{
  overflow-wrap: anywhere;
  word-break: break-word;
}
    .fineprint{font-size:12px; color: rgba(159,176,199,.9)}
    .contact{display:grid; gap:8px; padding: 14px;}
    .contact a{color: var(--text); text-decoration:none}
    .contact a:hover{text-decoration:underline}
    .split{display:flex; flex-wrap:wrap; gap:10px; align-items:center;}
    .hr{height:1px; background: var(--line); margin: 10px 0 0;}

    /* Tabelle */
    .table{
      width:100%;
      border-collapse: separate;
      border-spacing: 0;
      overflow:hidden;
      border:1px solid var(--line);
      border-radius: 14px;
      background: rgba(255,255,255,.03);
    }
    .table th, .table td{
      padding: 10px 12px;
      text-align:left;
      border-bottom:1px solid var(--line);
      color: var(--muted);
      font-size: 13px;
      vertical-align: top;
    }
    .table th{color: var(--text); font-weight:700; background: rgba(255,255,255,.04);}
    .table tr:last-child td{border-bottom:0}
    .table td b{color: var(--text);}
    .badge{
      display:inline-flex;
      padding: 4px 8px;
      border-radius: 999px;
      border:1px solid var(--line);
      background: rgba(255,255,255,.04);
      color: var(--muted);
      font-size:12px;
      white-space:nowrap;
    }

    /* Commissione */
    .people{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
    .person{padding:16px;}
    .person h4{margin:0 0 6px; font-size:15px}
    .person .role{color: var(--muted); font-size:12px; margin-bottom:10px}
    .person p{margin:0; color:var(--muted); font-size:13px}

    /* Articoli */
    .articles-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
    .article-card{padding:16px; cursor:pointer;}
    .article-card h4{margin:0 0 8px; font-size:15px}
    .article-card .meta{color:var(--muted); font-size:12px; margin-bottom:10px}
    .article-card p{margin:0; color:var(--muted); font-size:13px}
    .article-card:hover{border-color: rgba(255,255,255,.22); background: rgba(255,255,255,.06)}
    .article-view{padding:16px;}
    .article-view h3{margin-top:0}
    .article-view .meta{color:var(--muted); font-size:13px; margin-bottom:12px}
    .article-view .content{color: var(--muted)}
    .article-view .content h4{color: var(--text)}
.article-view .content a:not(.btn){
  color: var(--text);
  text-decoration: underline;
}

    .article-toolbar{display:flex; gap:10px; flex-wrap:wrap; align-items:center; justify-content:space-between; margin-bottom:10px}
    .search{
      display:flex; gap:10px; align-items:center;
      padding: 10px 12px;
      border-radius: 14px;
      border:1px solid var(--line);
      background: rgba(255,255,255,.04);
      width: min(520px, 100%);
    }
    .search input{
      flex:1;
      border:0;
      outline:0;
      background: transparent;
      color: var(--text);
      font-size: 13px;
    }
    .search input::placeholder{color: rgba(159,176,199,.7)}
    .logo-img{
        width:38px;
        height:38px;
        object-fit:contain;
        border-radius:8px;
        }

    /* Mobile */
    @media (max-width: 980px){
      .hero-grid{grid-template-columns: 1fr; }
      .grid-3{grid-template-columns: 1fr; }
      .grid-2{grid-template-columns: 1fr; }
      .people{grid-template-columns: 1fr; }
      .articles-grid{grid-template-columns: 1fr; }
      .brand{min-width:auto}
      .nav-links{display:none}
  .footer-grid{
    grid-template-columns: 1fr;
  }
  .footer-grid .contact{
    width: 100%;
  }
    }