/* mediareinformati.it — stile editoriale-giuridico, v2 */
:root{
  --carta:#fbfaf7;
  --carta-scura:#f3f1ea;
  --inchiostro:#1b1b1f;
  --grigio:#5d594f;
  --grigio-chiaro:#8b8578;
  --blu:#1f3a5f;
  --blu-vivo:#2c5282;
  --blu-scuro:#152a46;
  --oro:#b08d3e;
  --filo:#ddd8cc;
  --filo-chiaro:#eae6db;
  --serif:Georgia,"Times New Roman",serif;
  --sans:-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--carta);color:var(--inchiostro);font-family:var(--sans);font-size:16.5px;line-height:1.65}
::selection{background:var(--blu);color:#fff}

/* ---------- intestazione ---------- */
header.sito{background:var(--carta);border-bottom:1px solid var(--filo)}
.testata{max-width:1100px;margin:0 auto;padding:34px 24px 6px;text-align:center}
.testata h1{font-family:var(--serif);font-size:2.1em;margin:0;letter-spacing:.005em;font-weight:normal}
.testata h1 a{color:var(--inchiostro);text-decoration:none}
.testata h1 a::first-letter{color:var(--blu)}
.testata .motto{color:var(--grigio);margin:8px 0 0;font-size:.86em;font-family:var(--sans);
  text-transform:uppercase;letter-spacing:.22em}
.testata .motto::before,.testata .motto::after{content:"—";color:var(--oro);margin:0 12px}
nav.principale{max-width:1100px;margin:18px auto 0;padding:0 24px;display:flex;flex-wrap:wrap;
  justify-content:center;gap:0 4px;font-size:.9em;border-top:1px solid var(--filo-chiaro)}
nav.principale a{color:var(--blu);text-decoration:none;padding:12px 11px 10px;
  border-bottom:2px solid transparent;white-space:nowrap;letter-spacing:.01em;transition:color .15s,border-color .15s}
nav.principale a:hover{color:var(--blu-scuro);border-bottom-color:var(--filo)}
nav.principale a.attivo{border-bottom-color:var(--oro);font-weight:600;color:var(--blu-scuro)}

/* ---------- struttura ---------- */
main{max-width:1100px;margin:0 auto;padding:44px 24px 72px}
h2.pagina{font-family:var(--serif);font-size:1.9em;margin:0 0 6px;color:var(--blu-scuro);font-weight:normal;letter-spacing:.005em}
p.sottotitolo{margin:0 0 20px;color:var(--grigio);font-size:1.04em;font-family:var(--serif);font-style:italic}
.intro-motore{border-left:3px solid var(--oro);background:var(--carta-scura);padding:16px 22px;margin:0 0 30px;font-size:.96em;border-radius:0 3px 3px 0}
.intro-motore p{margin:0;color:#33302a}
a{color:var(--blu-vivo)}
a:hover{color:var(--blu-scuro)}

/* ---------- ricerca e filtri ---------- */
.strumenti{border:1px solid var(--filo);background:#fff;padding:18px 20px;margin-bottom:10px;border-radius:4px;box-shadow:0 1px 2px rgba(27,27,31,.04)}
.strumenti .riga{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}
.campo{display:flex;flex-direction:column;gap:5px;min-width:150px;flex:1}
.campo.largo{flex:3;min-width:250px}
.campo label{font-size:.72em;text-transform:uppercase;letter-spacing:.1em;color:var(--grigio);font-weight:600}
.campo input[type=search],.campo select,.campo textarea{padding:9px 12px;border:1px solid var(--filo);background:var(--carta);
  font:inherit;color:var(--inchiostro);width:100%;border-radius:3px;transition:border-color .15s,box-shadow .15s}
.campo input:focus,.campo select:focus,.campo textarea:focus{outline:none;border-color:var(--blu-vivo);box-shadow:0 0 0 3px rgba(44,82,130,.12)}
button.azzeramento{background:none;border:1px solid var(--filo);padding:9px 16px;font:inherit;font-size:.86em;
  color:var(--grigio);cursor:pointer;border-radius:3px;transition:all .15s}
button.azzeramento:hover{border-color:var(--blu-vivo);color:var(--blu-vivo)}
.conteggio{font-size:.86em;color:var(--grigio);margin:12px 2px 20px;font-style:italic}

/* ---------- risultati ---------- */
ul.risultati{list-style:none;margin:0;padding:0}
ul.risultati>li{border-bottom:1px solid var(--filo-chiaro);padding:17px 6px;transition:background .15s}
ul.risultati>li:hover{background:rgba(243,241,234,.5)}
ul.risultati>li:first-child{border-top:2px solid var(--blu-scuro)}
.r-titolo{font-family:var(--serif);font-size:1.12em;margin:0 0 4px;line-height:1.45}
.r-titolo a{color:var(--blu-scuro);text-decoration:none}
.r-titolo a:hover{text-decoration:underline;text-underline-offset:3px}
.r-meta{font-size:.8em;color:var(--grigio);margin:0 0 4px;letter-spacing:.01em}
.r-meta .sep{margin:0 7px;color:var(--filo)}
.etichetta{display:inline-block;border:1px solid var(--filo);background:var(--carta-scura);padding:1px 9px;
  font-size:.92em;border-radius:20px;margin-right:5px;color:#4a463d}
.r-testo{margin:5px 0 0;font-size:.93em;color:#3c3933;line-height:1.6}
.r-dettaglio{display:none;margin-top:12px;border-left:3px solid var(--oro);padding:10px 16px;font-size:.89em;background:var(--carta-scura);border-radius:0 3px 3px 0}
li.aperto .r-dettaglio{display:block}
.r-dettaglio dt{font-weight:600;color:var(--grigio);font-size:.82em;text-transform:uppercase;letter-spacing:.07em;margin-top:8px}
.r-dettaglio dd{margin:1px 0 3px}
.apri-dettaglio{background:none;border:none;color:var(--blu-vivo);cursor:pointer;font-size:.83em;padding:2px 0;
  text-decoration:underline;text-underline-offset:2px}
.apri-dettaglio:hover{color:var(--blu-scuro)}
.carica-altri{display:block;margin:30px auto 0;background:var(--blu);color:#fff;border:none;padding:11px 32px;
  font:inherit;font-size:.9em;cursor:pointer;border-radius:3px;letter-spacing:.03em;transition:background .15s}
.carica-altri:hover{background:var(--blu-scuro)}
.nessun-risultato{padding:34px 6px;color:var(--grigio);font-style:italic;font-family:var(--serif)}

/* ---------- home ---------- */
.manifesto{max-width:780px;margin:0 auto;font-family:var(--serif);font-size:1.16em;line-height:1.8;text-align:center}
.manifesto p:first-child{margin-top:8px}
.manifesto p:first-child::first-letter{font-size:1.6em;color:var(--blu);font-weight:bold}
.numeri-archivio{display:flex;flex-wrap:wrap;justify-content:center;gap:0;
  border-top:1px solid var(--filo);border-bottom:1px solid var(--filo);margin:38px 0;padding:26px 0}
.numeri-archivio div{flex:1;min-width:150px;padding:4px 22px;text-align:center;border-right:1px solid var(--filo-chiaro)}
.numeri-archivio div:last-child{border-right:none}
.numeri-archivio b{display:block;font-family:var(--serif);font-size:2.1em;color:var(--blu-scuro);font-weight:normal;line-height:1.15}
.numeri-archivio span{font-size:.72em;color:var(--grigio);text-transform:uppercase;letter-spacing:.1em}
h2.sezione-home{font-family:var(--serif);font-size:1.45em;margin:46px 0 0;color:var(--blu-scuro);font-weight:normal;text-align:center}
h2.sezione-home::after{content:"";display:block;width:56px;height:2px;background:var(--oro);margin:12px auto 0}
.motori-elenco{margin:30px 0 0}
.motore-voce{display:block;border-bottom:1px solid var(--filo-chiaro);padding:19px 14px;color:inherit;text-decoration:none;
  border-left:3px solid transparent;transition:border-color .15s,background .15s}
.motore-voce:first-child{border-top:1px solid var(--filo)}
.motore-voce:hover{background:rgba(243,241,234,.6);border-left-color:var(--oro)}
.motore-voce h3{font-family:var(--serif);margin:0 0 5px;font-size:1.22em;color:var(--blu-scuro);font-weight:normal}
.motore-voce p{margin:0;font-size:.92em;color:var(--grigio);line-height:1.55}
.motore-voce .dot{color:var(--oro);margin-right:10px;font-size:.8em}

/* ---------- sistemi: schede paese ---------- */
.griglia-paesi{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 26px}
.griglia-paesi button{border:1px solid var(--filo);background:#fff;padding:8px 15px;font:inherit;font-size:.88em;
  cursor:pointer;color:var(--blu-scuro);border-radius:20px;transition:all .15s}
.griglia-paesi button:hover{border-color:var(--blu-vivo);color:var(--blu-vivo)}
.griglia-paesi button.selezionato{background:var(--blu);color:#fff;border-color:var(--blu)}
.scheda-paese{border:1px solid var(--filo);background:#fff;padding:30px 36px;margin-top:10px;border-radius:4px;box-shadow:0 1px 3px rgba(27,27,31,.05)}
.scheda-paese h3.nome-paese{font-family:var(--serif);font-size:1.6em;margin:0;color:var(--blu-scuro);
  border-bottom:2px solid var(--filo);padding-bottom:10px;font-weight:normal}
.scheda-paese .agg{color:var(--grigio);font-size:.84em;font-style:italic;margin:8px 0 0}
.scheda-paese h3:not(.nome-paese){font-family:var(--serif);font-size:1.08em;color:var(--blu-scuro);margin-top:26px;font-weight:600}
.scheda-paese .lnk{background:var(--carta-scura);border-left:3px solid var(--oro);padding:9px 18px;margin:14px 0;font-size:.9em;border-radius:0 3px 3px 0}
.scheda-paese .src{font-size:.8em;color:var(--grigio);margin-top:18px;font-style:italic}
.avviso-provvisorio{border:1px dashed var(--filo);background:var(--carta-scura);padding:14px 20px;font-size:.9em;
  color:var(--grigio);margin:14px 0;border-radius:3px}

/* ---------- statistiche ---------- */
table.dati{border-collapse:collapse;width:100%;font-size:.89em;background:#fff;border:1px solid var(--filo)}
table.dati th,table.dati td{border-bottom:1px solid var(--filo-chiaro);padding:8px 12px;text-align:right}
table.dati th{background:var(--blu-scuro);color:#fff;font-weight:600;letter-spacing:.02em;font-size:.92em}
table.dati tr:nth-child(even) td{background:rgba(243,241,234,.45)}
table.dati td:first-child,table.dati th:first-child{text-align:left}
.barra{display:inline-block;height:8px;background:linear-gradient(90deg,var(--blu),var(--blu-vivo));vertical-align:middle;margin-right:7px;border-radius:2px}
.nota-fonte{font-size:.82em;color:var(--grigio);margin-top:12px;font-style:italic}

/* ---------- assistente ---------- */
.assistente-domanda{display:flex;gap:12px;flex-wrap:wrap}
.assistente-domanda input{flex:1;min-width:260px;padding:13px 16px;font:inherit;font-size:1.05em;
  border:1px solid var(--filo);border-radius:3px;background:#fff}
.assistente-domanda input:focus{outline:none;border-color:var(--blu-vivo);box-shadow:0 0 0 3px rgba(44,82,130,.12)}
.bottone-primario{background:var(--blu);color:#fff;border:none;padding:12px 28px;font:inherit;font-size:.95em;
  cursor:pointer;border-radius:3px;letter-spacing:.02em;transition:background .15s}
.bottone-primario:hover{background:var(--blu-scuro)}
.bottone-secondario{background:#fff;color:var(--blu-scuro);border:1px solid var(--filo);padding:10px 20px;font:inherit;
  font-size:.88em;cursor:pointer;border-radius:3px;transition:all .15s}
.bottone-secondario:hover{border-color:var(--blu-vivo);color:var(--blu-vivo)}
.suggerimenti-domande{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 0}
.suggerimenti-domande button{border:1px solid var(--filo);background:var(--carta-scura);padding:6px 14px;font:inherit;
  font-size:.83em;cursor:pointer;color:#4a463d;border-radius:20px;transition:all .15s}
.suggerimenti-domande button:hover{border-color:var(--oro);color:var(--blu-scuro)}
.risposta{border:1px solid var(--filo);background:#fff;padding:34px 40px;margin-top:28px;border-radius:4px;box-shadow:0 1px 3px rgba(27,27,31,.05)}
.risposta h3.titolo-risposta{font-family:var(--serif);font-size:1.5em;margin:0 0 4px;color:var(--blu-scuro);font-weight:normal}
.risposta .fonti-conteggio{color:var(--grigio);font-size:.85em;font-style:italic;margin:0 0 18px}
.risposta h4{font-family:var(--serif);font-size:1.1em;color:var(--blu-scuro);margin:24px 0 8px;
  border-bottom:1px solid var(--filo-chiaro);padding-bottom:5px;font-weight:600}
.risposta ul{margin:6px 0;padding-left:22px}
.risposta li{margin:5px 0;font-size:.94em;line-height:1.55}
.risposta .cit{color:var(--grigio);font-size:.86em}
.barra-export{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px;padding-top:18px;border-top:1px solid var(--filo-chiaro)}

/* ---------- progetto ---------- */
.prosa{max-width:780px;font-size:1.03em;line-height:1.75}
.prosa h3{font-family:var(--serif);color:var(--blu-scuro);margin-top:34px;font-size:1.25em;font-weight:600}
.prosa h3::after{content:"";display:block;width:36px;height:2px;background:var(--oro);margin-top:8px}

/* ---------- piè di pagina ---------- */
footer.sito{border-top:1px solid var(--filo);margin-top:48px;background:var(--carta-scura)}
footer.sito .interno{max-width:1100px;margin:0 auto;padding:26px 24px;font-size:.82em;color:var(--grigio);
  display:flex;flex-wrap:wrap;gap:8px 30px;justify-content:space-between}

@media (max-width:640px){
  body{font-size:15.5px}
  .testata{padding:24px 16px 4px}
  .testata h1{font-size:1.6em}
  .testata .motto{letter-spacing:.12em;font-size:.78em}
  .testata .motto::before,.testata .motto::after{margin:0 6px}
  nav.principale{gap:0;font-size:.84em;justify-content:flex-start}
  nav.principale a{padding:10px 8px}
  main{padding:28px 16px 56px}
  .strumenti .riga{flex-direction:column;align-items:stretch}
  .campo{min-width:0}
  .scheda-paese{padding:20px 18px}
  .risposta{padding:22px 18px}
  .numeri-archivio div{min-width:110px;padding:4px 10px}
  .numeri-archivio b{font-size:1.6em}
}
@media print{
  header.sito nav,.strumenti,.carica-altri,.barra-export,footer.sito{display:none}
  body{background:#fff}
}

.fonti-titolo{font-family:Georgia,serif;color:var(--blu);font-size:1.05rem;font-weight:bold;cursor:pointer;margin:18px 0 6px;border-top:1px solid var(--filo);padding-top:14px}
details>.fonti-titolo::marker{color:var(--oro)}
