*{
  margin:0;
  padding:0;
  box-sizing:border-box;
  font-family:'Roboto Condensed', 'Spectral', 'Open Sans', sans-serif;
}

body {
  /* Usiamo Open Sans come base per ereditare la leggibilità ovunque */
  font-family: 'Roboto Condensed', 'Spectral', 'Open Sans', sans-serif;
  background: linear-gradient(to bottom, #ffffdd 0%, #ffffcc 100%);
  background-attachment: fixed; /* Mantiene il gradiente fluido */
/* Scuriamo il testo a #222 per dare più "peso" visivo su sfondo giallino */
  color: #222; 
  line-height: 1.6;
  padding: 2px;
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
  border: 0px;
}

/* Titoli del giornale */
/* Applichiamo Lora ai titoli per l'effetto "giornale" */
h1, h2, h3, .title h1 {
  font-family: 'Spectral','Lora', serif;
  font-weight: 700;
  line-height: 1.3;
  color: #111; /* Titoli ancora più scuri per staccare dal fondo */
}

h1 {
  font-size:22px;
  color: #49638b;/* Il tuo blu */
}

h2, h3, h4 {
  font-size: 19px;
  color: #cc0033;
  text-align: center;
  line-height: 1.3; /* Ridotto da 1.5 */
  margin-top: 5px;
  margin-bottom: 5px; /* Ridotto da 15px */
}

/* Corpo del testo */
/* Il testo dei tuoi articoli */
p, .testo1 {
    font-family: 'Roboto Condensed', 'Open Sans', sans-serif;
    font-weight: 500; /* Ora funzionerà perfettamente! */
    font-size: 16px;
    line-height: 1.6;
    color: #222; /* Più scuro per risaltare sullo sfondo giallino */
    margin-bottom: 5px;
    text-align: justify;   /* Giustifica il testo */
}

/* Link e Navigazione */
a, .link-notizia, .menu-item {
    font-family: 'Roboto Condensed', sans-serif;
    text-decoration: none;

    letter-spacing: 0.5px;
}

a, .link-notizia, .menu-item, .link-news {
  font-family: 'Roboto Condensed', sans-serif;
  font-weight: 700;
text-decoration: none;

  letter-spacing: 0.2px;
  color: #0056b3;
}

a, .link-news {
  transition: color 0.3s ease, border-bottom 0.3s ease;
  border-bottom: 1px solid transparent;
}

a:hover, .link-news:hover {
  color: #cc0033; /* Cambia nel rosso dei tuoi titoli h2 */
  border-bottom: 1px solid #cc0033;
}

/* Stile per link già visitati: torna al colore originale */
a:visited, .link-news:visited {
  color: #0056b3; /* colore originale dopo visita */
  border-bottom: 1px solid transparent; /* o puoi lasciare invariato */
}

img{
  max-width:100%;
  height:auto;
  display:block;
}


.container{
  width:95%;
  max-width:1400px;
  margin:auto;
}

/* ================= HEADER ================= */

/* DESKTOP: griglia a 2 colonne — hamburger nascosto, non occupa spazio */
.header {
  display: grid;
  grid-template-columns: 250px 1fr;
  align-items: center;
  border-bottom: 2px solid #ddd;

}

/* hamburger nascosto su desktop — non occupa celle della griglia */
.hamburger {
  display: none;
}

.logo-desktop {
  display: block;
  margin-top: 8px;
}

.logo-mobile {
  display: none;
}

.logo-desktop,
.logo-mobile {
  max-width: 100%;
  height: auto;
}

/* MOBILE ≤ 1023px — allineato al breakpoint del menu */
@media (max-width: 1023px) {

  .logo-desktop { display: none; }
  .logo-mobile  { display: block; margin-top: 5px; }

  /* Header mobile con aree esplicite:
     "logo      hamburger"
     "headeright headeright"            */
  .header {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "logo hamburger"
      "hright hright";
    align-items: center;
    gap: 0;
    padding: 0;
    width: 100%;
    box-sizing: border-box;
  }

  .logo {
    grid-area: logo;
    padding: 4px 0 4px 8px;
  }

  .hamburger {
    grid-area: hamburger;
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 8px;
    flex-shrink: 0;
  }

  .header-right {
    grid-area: hright;
    width: 100%;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
  }

  .intestazione {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    font-size: 20px;
  }

  .intestazione p {
    margin: 0;
    padding: 4px 8px;
  }

  .ticker,
  .ticker .container-ticker {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
  }

}

.header-right{
  padding:2px 5px 3px; /* ridotto da 5px/5px a 2px/3px: risparmio ~5px */
}

.intestazione{
  font-size:20px;        /* ridotto da 28px: testo più compatto */
  line-height:1.2;       /* forza line-height stretto, non eredita 1.6 del body */
  margin:1px 1px 2px;    /* ridotto da 3px/4px */
}

.intestazione p {
  font-weight: bold;     /* Testo in grassetto */
  color: green;          /* Colore verde */
  padding:0px 4px;       /* rimosso padding verticale (era 1px) */
}

.ticker{
  padding:1px;
  font-size:14px;
}

/* ================= TITLE AREA ================= */

.title-area{
  display:grid;
  grid-template-columns:400px 1fr;
  margin-top:1px;   /* ridotto da 4px */
}

.title-box{
  padding:1px 2px;  /* era solo 2px */
}

.text-box{
  padding:2px 5px 2px; /* ridotto da 7px top / 4px bottom: risparmio ~7px */
}

/* ================= SEARCH + BANNER ================= */

.top-section{
  display:grid;
  grid-template-columns:1fr;
  gap:2px 10px;     /* gap verticale ridotto da 5px a 2px */
  margin-top:2px;   /* ridotto da 4px */
}

@media (min-width:1024px){
  .top-section{
    grid-template-columns:300px 1fr;
  }
}

.search-box{
  padding:0px 10px;
}

.search-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap:0px 10px;
  margin-top:5px;
  margin-bottom:0px;
}

/* SEARCH */

.search-grid div{
  padding:1px 5px;
  text-align:center;
}

/* centra SOLO immagini */
.search-grid div img{
  display:block;
  margin:0 auto;
}

/* testo più piccolo solo qui */
.search-box strong {
  font-size: 14px;
  color: green;
}

.search-grid h2{
  font-size:14px;
  line-height: 0.8;
}

.search-grid{
  font-size:13px;
}

/* MOBILE */

@media (max-width:1024px){

  .search-grid div img{
    display:none;
  }

}

/* --- NUOVO ASSETTO BANNER TOP --- */

.banner-top {
  display: block;
  text-align: center;
  margin: 2px auto;  /* ridotto da 5px: risparmio ~6px */
  width: 100%;
  clear: both;
  min-height: 100px; 
}

@media (min-width: 765px) {
  .banner-top {
    /* Su desktop alziamo il minimo a 280px o 300px per accogliere i banner grandi */
    min-height: 280px; 
  }
}

/* Rimuoviamo eventuali forzature sugli elementi interni di Google */
.banner-top ins.adsbygoogle {
  height: auto !important;
}


/* ================= SECTION TITLE ================= */

.section-title{
  margin:2px 0 0px 0;  /* margin-bottom a 0: lo spazio lo gestisce sb-btns */
  padding:0px 5px;     /* padding verticale azzerato */
  text-align:center;
  font-weight:bold;
  font-size:22px;
}

/* h2 dentro section-title: margini interni minimi */
.section-title h2 {
  margin-top: 2px;
  margin-bottom: 2px;
}

/* ================= /* SEARCH */ ================= */

     .search-grid{
        grid-template-columns: repeat(4, 1fr);
     }

/* ================= MAIN CONTENT ================= */

.main-content{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
}

.banner-left,
.news,
.sidebar{
  padding:10px;
  min-height:400px;
}

@media only screen and (min-width:768px){

     .search-grid{
        grid-template-columns: repeat(4, 1fr);
     }

  .main-content{
    grid-template-columns: 3fr 2fr;
  }

  .search-box{
  padding:0px 10px 10px;
}


  .banner-left{
    grid-column: 1 / -1;
  }

  .sidebar{
    min-width:300px;
  }

}

@media only screen and (min-width:1024px){

  .search-grid{
     grid-template-columns: 1fr 1fr;
  }

  .main-content{
    grid-template-columns: 5fr 3fr;
  }

  .banner-left{
    grid-column: 1 / -1;
  }

}

@media only screen and (min-width:1200px){

  .main-content{
    grid-template-columns: 2fr 6fr 4fr;
  }

  .banner-left{
    grid-column:auto;
    min-width:160px;
  }

  .sidebar{
    min-width:336px;
  }

}

/* ================= 50% ROW ================= */

.row-50{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:20px 0;
}

.row-50 div{
  padding:10px;
}

/* ================= 33% ROW ================= */

.row-33{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-bottom:20px;
}

.row-33 div{
  padding:10px;
}

/* ================= 25% ROW ================= */

.row-25{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-bottom:20px;
}

.row-25 div{
  padding:10px;
}

/* ================= FOOTER ================= */

footer {
  padding: 30px;
  display: flex;
  justify-content: center; /* centra orizzontalmente */
  align-items: center; /* centra verticalmente se necessario */
  flex-direction: column; /* se vuoi mettere tutto in colonna */
}

/* ================= RESPONSIVE ================= */


@media (max-width:1024px){

  .header{
    grid-template-columns:1fr;
  }

  .title-area{
    grid-template-columns:1fr;
  }

  .top-section{
    grid-template-columns:1fr;
  }

  .main-content{
    grid-template-columns:1fr;
  }

 /* Tablet: 50% rimane in orizzontale con gap ridotto */
  .row-50{
    grid-template-columns: 1fr 1fr;
    gap: 5px;
  }

  /* Tablet: 33% e 25% si incolonnano */
  .row-33,
  .row-25{
    grid-template-columns:1fr;
  }

}

@media (max-width:600px){

  
  body {
    padding: 0;
    margin: 0;
  }

  .container {
    width: 100%;
    padding: 0 4px;
    box-sizing: border-box;
  }

  /* H1 in una sola riga su mobile
     Roboto Condensed è già stretto — con letter-spacing -2px
     e font ~3vw il titolo entra in una riga su 320px.
     overflow:visible + text-overflow:clip = testo sempre completo (SEO ok) */
  h1 {
    font-size: clamp(8px, 3vw, 12px);
     white-space: normal; /* Permette l'andare a capo */
    overflow: visible;
    letter-spacing: -4px;
    text-overflow: clip;
    margin: 0;
    line-height: 1.2;
  }

  
  /* Title area compatta */
  .title-area {
    margin-top: 2px;
    grid-template-columns: 1fr;
  }

  .title-box {
    padding: 2px 4px;
  }

  /* Nasconde testo descrittivo su mobile */
  .text-box {
    display: none;
  }

  /* Section title compatto */
  .section-title {
    margin: 2px 0;
    padding: 1px 4px;
    font-size: 16px;
  }

  /* Top section: gap verticale tra search-box e banner */
  .top-section {
    margin-top: 2px;
    gap: 12px;
  }

  /* Search-box visibile e compatta */
  .search-box {
    display: block;
    padding: 0px 2px 4px;
    background: #fff;
  }

  /* Nasconde i menu a tendina su mobile */
  .search-grid {
    display: none;
  }

  .intestazione {
    font-size: 16px;
    margin: 0;
  }

  /* Banner mobile a 100px fissi */
  .banner-top {
    min-height: 100px;
    max-height: 100px;
    overflow: hidden;
    padding-top: 4px;
  }

   /* Smartphone: tutte le colonne in verticale */
  .row-50,
  .row-33,
  .row-25 {
    grid-template-columns: 1fr;
    gap: 5px;
  }

  /* Padding ridotto — solo verticale, zero laterale */
  .news,
  .sidebar {
    padding: 4px 0;
  }

  /* Riduce gap verticale tra news e sidebar */
  .main-content {
    gap: 8px;
  }

  .news-frame {
    padding: 8px 2px;
    gap: 6px;
  }

  .container-main {
    max-width: 100%;
    margin: 0;
    padding: 0;
  }

  .search-grid {
    gap: 4px;
  }

  .search-grid div {
    padding: 3px;
  }

}

/* ================= 320px — display molto stretti ================= */
@media (max-width: 360px) {

  .container {
    width: 100%;
    padding: 0 2px;
  }

  .news,
  .sidebar {
    padding: 2px 0;
  }

  .news-frame {
    padding: 6px 2px;
    gap: 4px;
  }

  /* Bottoni giornali — griglia più stretta */
  .quotidiani p,
  .periodici p,
  .menu3 p,
  .radio p,
  .btg-lightblue p,
  .btg-orange p,
  .btg-green p {
    grid-template-columns: repeat(auto-fill, minmax(85px, 1fr));
    gap: 3px;
  }

  .quotidiani a,
  .periodici a,
  .menu3 a,
  .radio a,
  .btg-lightblue a,
  .btg-orange a,
  .btg-green a {
    height: 44px;
    font-size: 11px;
    padding: 2px 3px;
  }

}

/* =========================
   fine struttura template
========================= */

/* =========================
   BOTTONI GIORNALI
========================= */

/* =========================
   Sezioni — margin comune
========================= */
.quotidiani,
.periodici,
.giornali,
.menu3,
.btg-lightblue,
.btg-orange {
  margin: 5px 0 10px;
}

/* =========================
   h2 comune
========================= */
.quotidiani h2,
.giornali h2,
.periodici h2,
.menu3 h2,
.pulsante h2,
.btg-lightblue h2,
.btg-orange h2 {
  margin: 3px 10px 7px;
  color: #8b351d;
  text-align: center;
}

/* =========================
   Contenitori p — griglia comune
========================= */
.quotidiani p,
.periodici p,
.radio p,
.menu3 p,
.btg-lightblue p,
.btg-orange p {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 5px;
  align-items: stretch;
  margin-bottom: 5px;
}

/* =========================
   Stile speciale .giornali
========================= */
.giornali {
  background: #ffffee;
  border: 1px solid #b8962e;
  border-radius: 8px;
  padding: 10px;
}

/* griglia diretta su <p> dentro .giornali */
.giornali p {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 5px;
  align-items: stretch;
  margin-bottom: 5px;
}

/* taglia il testo che deborda nei bottoni .giornali */
.giornali p a {
  overflow: hidden;
  min-width: 0;
}

/* =========================
   Bottoni — stile base comune a tutti
========================= */
.quotidiani a,
.giornali a,
.periodici a,
.radio a,
.menu3 a,
.btg-lightblue a,
.btg-orange a {
  width: 100%;
  height: 52px;
  padding: 4px 6px;
  line-height: 1.1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 4px;
  font-weight: 800;
  font-size: clamp(13px, 1.2vw, 14px);
  text-decoration: none;
  transition: all 0.2s ease;
  border: 1px solid #d6d6d6;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  overflow: hidden;
  text-overflow: clip;
  background: linear-gradient(to bottom, #FEFEF2, #ecead6);
  color: #444;
}



/* =========================
   Colori testo per gruppo
========================= */
.quotidiani a,
.giornali a,
.menu3 a { color: #1a1a1a; }

.periodici a,
.radio a { color: #cc0033; }

/* =========================
   Immagini nei bottoni — comune a tutti
========================= */
.quotidiani a img,
.giornali a img,
.periodici a img,
.radio a img,
.menu3 a img,
.pulsante a img,
.btg-lightblue a img,
.btg-orange a img {
  max-width: 100%;
  max-height: 40px;
}

/* =========================
   Hover — comune (background invertito + rosso)
========================= */
.quotidiani a:hover,
.giornali a:hover,
.periodici a:hover,
.radio a:hover,
.pulsante a:hover,
.btg-lightblue a:hover,
.btg-orange a:hover {
  color: #ff0c00;
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}

/* hover background invertito per i gruppi crema */
.quotidiani a:hover,
.giornali a:hover,
.periodici a:hover,
.radio a:hover,
.pulsante a:hover {
  background: linear-gradient(to bottom, #ecead6, #FEFEF2);
}

/* =========================
   Active — comune a tutti
========================= */
.quotidiani a:active,
.giornali a:active,
.periodici a:active,
.radio a:active,
.pulsante a:active,
.btg-lightblue a:active,
.btg-orange a:active {
  transform: translateY(1px);
  box-shadow: none;
}

/* =========================
   Stile speciale .menu3
========================= */
.menu3 a {
  background: linear-gradient(to bottom, #F1EFD3, #dcd798);
  border-color: #b9b9b9;
  color: #004a94;
}
.menu3 a:hover {
  background: linear-gradient(to bottom, #dcd798, #F1EFD3);
  color: #ff0c00;
}
.menu3 a:active { color: #004a94; }

/* =========================
   .btg-lightblue
========================= */
.btg-lightblue a {
  background: linear-gradient(to bottom, #EDF3F8, #c8dae8);
  color: #252525;
}
.btg-lightblue a:hover {
  background: linear-gradient(to bottom, #c8dae8, #EDF3F8);
}
.btg-lightblue a:active { color: #252525; }

/* =========================
   .btg-orange
========================= */
.btg-orange a {
  background: linear-gradient(to bottom, #FFE88C, #FFCC00);
  color: #252525;
}
.btg-orange a:hover {
  background: linear-gradient(to bottom, #FFCC00, #FFE88C);
}
.btg-orange a:active { color: #252525; }

/* =========================
   .pulsante
========================= */
.pulsante {
  text-align: justify;
}
.pulsante p {
  text-align: justify;
  margin-bottom: 5px;
  font-size: 0;
}
.pulsante a {
  display: inline-block;
  vertical-align: middle;
  width: auto;
  height: auto;
  min-height: 48px;
  padding: 14px 12px;
  line-height: 1.2;
  text-align: center;
  margin: 2px;
  border-radius: 4px;
  font-weight: 900;
  font-size: clamp(13px, 1.2vw, 14px);
  text-decoration: none;
  cursor: pointer;
  transition: all 0.2s ease;
  background: linear-gradient(to bottom, #FEFEF2, #ecead6);
  border: 1px solid #d6d6d6;
  color: #1a1a1a;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

/* =========================
   .giornali — griglia righe con testo opzionale
========================= */
.giornali div.righe {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 5px;
  align-items: stretch;
  margin-bottom: 5px;
}

.giornali div.righe p {
  display: contents;
  margin: 0;
}

.giornali div.righe p a {
  width: 100%;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  min-width: 0;
}

/* =========================
   Solo p.con-testo va in flex row
   NON tutti i <p> dentro .giornali
========================= */
.giornali div.righe p.con-testo,
.giornali > p.con-testo {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 8px;
}

.giornali div.righe p.con-testo {
  grid-column: 1 / -1;
}

.giornali div.righe p.con-testo a,
.giornali > p.con-testo a {
  flex-shrink: 0;
  width: 100px;
}

.giornali div.righe p.con-testo .testo,
.giornali > p.con-testo .testo {
  flex: 1 1 0;
  min-width: 0;
  font-size: 13px;
  line-height: 1.4;
  color: #444;
  word-wrap: break-word;
  text-align: justify;
}

/* =========================
   Responsive smartphone (≤ 600px)
========================= */
@media (max-width: 600px) {

  .giornali div.righe p.con-testo,
  .giornali > p.con-testo {
    flex-direction: column;
    align-items: stretch;
  }

  .giornali div.righe p.con-testo a,
  .giornali > p.con-testo a {
    width: 100%;
  }

  .pulsante {
    text-align: left;
  }
  .pulsante p {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 5px;
    align-items: stretch;
    text-align: center;
    font-size: initial;
  }
  .pulsante a {
    display: flex;
    width: 100%;
    height: 52px;
    margin: 0;
    font-size: clamp(13px, 1.2vw, 14px);
    align-items: center;
    justify-content: center;
    padding: 4px 6px;
  }
}

/* =========================
   fine TUTTI BOTTONI GIORNALI
========================= */



/* =========================
   NOTIZIE
========================= */

 /* IL TUO CSS PERSONALIZZATO ADATTATO */
        .container-ticker { width: 100%; margin: 0 auto 0px auto; }
        .container-main { max-width: 100%; margin: 0 auto; }
        .sezione-titolo { text-align: center; color: #6b642e; text-transform: uppercase; letter-spacing: 3px; font-weight: 800; margin: 5px 0; font-size: 1.2em; }

        /* Stile Ticker Flash */
  

.tikernewsclass { 
    background: linear-gradient(90deg, #030e3f 0%, #3d5ce6 100%);
    color: #fff; 
    border: 1px solid rgba(194, 186, 75, 0.2);
    border-radius: 7px;
    height: 45px; /* Altezza fissa per desktop */
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
    overflow: hidden;
    display: flex;
    align-items: center;
    padding: 0 10px;
}

/* Stile per il link (Titolo) */
.tikernewsclass a { 
    font-family: 'Roboto Condensed', sans-serif; 
    color: #ffeb3b !important; 
    text-decoration: none; 
    font-weight: bold; 
    white-space: nowrap; /* Su desktop resta su una riga */
}

/* Stile per la data e la fonte (Testo piccolo) */
.tikernewsclass div, .tikernewsclass span { 
    font-family: 'Roboto Condensed', sans-serif; 
}

/* Regola specifica per MOBILE */
@media screen and (max-width: 768px) {
    .tikernewsclass {
        height: auto !important; /* Diventa elastico */
        min-height: 55px;
        padding: 8px 10px !important; /* Più spazio interno per non toccare i bordi */
        display: flex;
        align-items: center; /* Centra l'immagine rispetto al blocco testo */
    }

    .tikernewsclass a {
        white-space: normal !important; /* La notizia può andare a capo */
        font-size: 13px !important;
        line-height: 1.2 !important;
        display: block;
        margin-bottom: 4px; /* Sposta il titolo lontano dalla fonte */
    }

    /* Protezione per Fonte e Data */
    .tikernewsclass div span {
        font-size: 10px !important;
        display: inline-block; /* Aiuta a mantenere la riga integra */
        vertical-align: middle;
    }
}

        /* REGOLE PER LE SCHEDE NOTIZIE (MAIN.PHP) */
        .news-frame {
            background-color: #ffffee; padding: 18px; margin-bottom: 15px;
            border-radius: 4px; display: flex; gap: 20px;
             border:1px solid #e2dea9;
            transition: all 0.4s ease; cursor: pointer; align-items: flex-start;
        }
        .news-frame:hover { background-color: #fff; box-shadow: 0 4px 15px rgba(107, 100, 46, 0.1); border-color: rgba(107, 100, 46, 0.4); }

        .thumb-wrapper { flex-shrink: 0; overflow: hidden; border-radius: 7px; }
        
        /* Effetto Black & White / Sepia */
        .news-thumb { width: 170px; height: 110px; object-fit: cover; filter: grayscale(100%); display: block; }
        .news-frame:hover .news-thumb { filter:  sepia(30%) contrast(1.1) brightness(1.05); }

        .news-content { flex-grow: 1; display: flex; flex-direction: column; }
        .meta-data { font-family: 'Roboto Condensed', sans-serif; font-size: 13px; color: #555; text-transform: uppercase; display: flex; /* Usiamo flex per allineare tutto perfettamente */ align-items: center; gap: 10px; /* Questo imposta la stessa identica distanza tra ogni elemento */ }
        .separator { color: #555; font-weight: bold; }
        
        .source-name { color: #2d5a27; font-weight: 700; margin-right: 10px; }
        .news-title-link { color: #111 !important; text-decoration: none; font-size: 19px; font-weight: 600; line-height: 1.2; margin-bottom: 8px; display: block; }
        .news-description { color: #333; font-size: 14px; margin: 0; line-height: 1.5; text-align: justify; }

        #timer-container { text-align: center; font-size: 12px; margin-bottom: 5px; color: #6b642e; }
        #countdown { font-weight: bold; color: #d9534f; }

        .btn-refresh { background-color: #e2dea9; color: #111; border: 1px solid #d0ca77; margin-left: 10px; padding: 6px 12px; border-radius: 4px; cursor: pointer; font-family: 'Roboto Condensed', sans-serif; font-weight: bold; font-size: 12px; text-transform: uppercase;}
        .btn-refresh:hover { background-color: #d0ca77; /* colore più scuro al passaggio del mouse */}
        .sezione-titolo { border-left: 5px solid #cc0000; padding-left: 10px; margin-bottom: 20px; font-size: 18px; text-transform: uppercase; font-weight: 900; }

        @media (max-width: 600px) {
            h1 { font-size: 1.3em; letter-spacing: 1px; margin: 3px 0; }
            .news-frame { flex-direction: column; text-align: justify; }
            .thumb-wrapper { margin: 0 auto 10px auto; }
            .news-thumb { width: 100%; height: auto; max-height: 200px; }
        }

/* =========================
   fine NOTIZIE
========================= */


/* =====================================
   PREMIUM NEWS MENU 2026
===================================== */

.menu {
  grid-column: 1 / -1;
  position: sticky;
  top: 0;
  z-index: 999;
}

.main-nav {
  background: linear-gradient(to bottom, #ffffdd 0%, #ffffcc 100%);
  border-bottom: 2px solid #cc0033;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  position: relative;
  /* overflow visible è il default — il submenu absolute esce fuori */
}

/* Checkbox nascosta */
#menu-toggle {
  display: none;
}

/* ================= DESKTOP ================= */

.menu-level-1 {
  list-style: none;
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 5px 5px 4px;
}

/* Il <li> è static: il submenu si ancora al .main-nav */
.menu-level-1 > li {
  background: #ffffee;
  position: static;
}

.menu-level-1 > li > a {
  text-decoration: none;
  font-weight: 900;
  font-size: 18px;
  letter-spacing: 0.3px;
  color: #3792ff;
  padding: 0px 0;
  display: inline-block;
  transition: 0.3s ease;
}

.menu-level-1 > li > a.active {
  color: #cc0033;
  border-bottom: 2px solid #cc0033;
}

.menu-level-1 > li > a:hover {
  color: #1a6cd1;
}

/* Linea animata sotto */
.menu-level-1 > li > a::after {
  content: "";
  display: block;
  height: 2px;
  width: 0%;
  background: #cc0033;
  transition: 0.3s;
  margin-top: 2px;
}

.menu-level-1 > li > a:hover::after {
  width: 100%;
}

/* ================= SUBMENU DESKTOP — isola orizzontale ================= */

/* Ancorato a .main-nav, larghezza piena, tocca il bordo rosso */
.menu-level-2 {
  list-style: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  margin-top: -6px; /* si sovrappone al bordo del main-nav: zero gap */

  background: #fffff5;
  border-top: 3px solid #cc0033;
  border-bottom: 2px solid #cc0033;
  box-shadow: 0 6px 18px rgba(0,0,0,0.10);

  /* Nascosto con visibility — transizione ritardata in uscita */
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 4px 0;
  padding: 7px 20px;
  white-space: normal;
  z-index: 998;
  box-sizing: border-box;

  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  /* scompare dopo 600ms — abbastanza per raggiungere il submenu */
  transition: opacity 0.15s ease,
              visibility 0s linear 0.6s;
}

/* Si apre al hover sul li O quando il mouse è già dentro il submenu */
.has-sub:hover .menu-level-2,
.menu-level-2:hover {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transition: opacity 0.15s ease,
              visibility 0s linear 0s;
}

.menu-level-2::after { display: none; }

.menu-level-2 li {
  display: inline-block;
}

.menu-level-2 a {
  display: inline-block;
  text-decoration: none;
  font-family: 'Roboto Condensed', sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: #3792ff;
  padding: 6px 14px;
  border-radius: 4px;
  transition: all 0.2s ease;
  border-bottom: none;
}

.menu-level-2 a:hover {
  color: #cc0033;
  background: #fff0f0;
  border-bottom: none;
}

@keyframes fadeDown {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ================= HAMBURGER ================= */

/* Solo le barre — display e posizione gestiti nell'header media query */
.hamburger span {
  width: 25px;
  height: 3px;
  background: #1a1a1a;
  transition: 0.3s;
}

/* Animazione apertura */
#menu-toggle:checked ~ .header .hamburger span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}
#menu-toggle:checked ~ .header .hamburger span:nth-child(2) {
  opacity: 0;
}
#menu-toggle:checked ~ .header .hamburger span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

/* ================= MOBILE menu (a 1023px) ================= */
@media (max-width: 1023px) {

  /* La barra menu è solo contenitore del pannello */
  .main-nav {
    display: block;
    position: relative;
    height: auto;
  }

  /* 2. Il Pannello del Menu (si apre sotto la barra) */
  .menu-level-1 {
    display: none; /* Nascosto di base */
    flex-direction: column;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background: #ffffff;
    height: auto;
    max-height: 80vh;
    overflow-y: auto;
    padding: 0;
    margin: 0;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    z-index: 1000;
  }

  /* Apertura con Checkbox — il toggle è primo figlio di .container */
  #menu-toggle:checked ~ .fluid .menu-level-1 {
    display: block;
  }

  /* 3. Voci principali: DEVONO essere blocchi che occupano spazio */
  .menu-level-1 > li {
    display: block;
    width: 100%;
    position: relative;
    border-bottom: 1px solid #eee;
  }

  .menu-level-1 > li > a {
    display: block;
    padding: 15px 20px;
    color: #3792ff;
    font-weight: bold;
  }

  /* 4. IL SOTTOMENU MOBILE: Deve "allungare" la voce padre */
  .menu-level-2 {
    display: none !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transition: none !important;
    position: static !important;
    width: 100% !important;
    transform: none !important;
    left: 0 !important;
    background: #f4f4f4 !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
  }
    
.menu-level-2 {
    /* ... le altre proprietà che abbiamo già messo ... */
    border-radius: 0 0 12px 12px; /* Arrotonda solo i due angoli in basso */
    margin: 0 10px 10px 10px;    /* Aggiunge un po' di distacco dai bordi laterali */
    overflow: hidden;            /* Fondamentale: "taglia" i link interni seguendo la curva */
    border: 1px solid #eee;      /* Opzionale: un sottile bordo per definire meglio la forma */
}

  /* Quando l'utente tocca/passa sopra, il sottomenu si inserisce tra i link */
  .has-sub:hover .menu-level-2,
  .has-sub.sub-open .menu-level-2 {
    display: block !important;
  }
    
.menu-level-2 {
    box-shadow: inset 0 2px 5px rgba(0,0,0,0.05) !important;
}

  .menu-level-2 li {
    display: block;
    width: 100%;
    border-bottom: 1px solid #ddd;
  }
    
.menu-level-2 li:last-child {
    border-bottom: none !important;
}

  .menu-level-2 a {
    display: block;
    padding: 12px 40px !important; /* Rientro per gerarchia */
    color: #444 !important;
    font-size: 15px;
    text-transform: none;
  }

  /* Rimuove la freccetta bianca del desktop che copre tutto */
  .menu-level-2::after { display: none !important; }
}

/* =====================================
   FINE PREMIUM NEWS MENU 
===================================== */


/* =========================
   BTN COLOR — sb-btns / btns-large / btns-half
   Pulsantiera multicolore autonoma.
   Usare ovunque: sidebar, main, footer.

   GRIGLIA (bottoni compatti, auto-fill):
     <div class="sb-btns"> <a class="oro">...</a> </div>

   COLONNA (bottoni a larghezza piena, uno per riga):
     <div class="btns-large"> <a class="oro">...</a> </div>

   DOPPIA COLONNA (due bottoni affiancati 50%+50%):
     <div class="btns-half"> <a class="oro">...</a> <a class="celeste">...</a> </div>

   Classi colore: .oro .arancio .celeste .verde (senza = crema)
========================= */

/* --- Layout contenitori --- */

.sb-btns {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 5px;
  margin: 2px 0 8px; /* margin-top da 5px a 2px */
}

.btns-large {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin: 5px 0 10px;
}

.btns-half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
  margin: 5px 0 10px;
}

/* --- Stile comune ai link di tutte le pulsantiere --- */

.sb-btns a,
.btns-large a,
.btns-half a {
  display: flex;
  width: 100%;
  height: 52px;
  padding: 4px 6px;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 4px;
  font-family: 'Roboto Condensed', sans-serif;
  font-weight: 800;
  font-size: clamp(13px, 1.2vw, 14px);
  text-decoration: none;
  border: 1px solid #d6d6d6;
  border-bottom: 1px solid #d6d6d6;
  background: linear-gradient(to bottom, #FEFEF2, #ecead6);
  color: #1a1a1a;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  overflow: hidden;
  box-sizing: border-box;
  transition: filter 0.2s ease;
  letter-spacing: normal;
  line-height: 1.1;
}

/* btns-large e btns-half: font e padding leggermente più grandi */
.btns-large a,
.btns-half a {
  padding: 4px 16px;
  font-size: clamp(14px, 1.5vw, 16px);
}

/* --- Hover e active condivisi --- */

.sb-btns a:hover,
.btns-large a:hover,
.btns-half a:hover {
  filter: brightness(0.93);
  color: #ff0c00;
  border-bottom: 1px solid #d6d6d6;
}

.sb-btns a:active,
.btns-large a:active,
.btns-half a:active {
  transform: translateY(1px);
  box-shadow: none;
}

.sb-btns a img,
.btns-large a img,
.btns-half a img {
  max-width: 100%;
  max-height: 40px;
  display: inline;
}

/* --- Varianti colore condivise --- */

.sb-btns a.oro,
.btns-large a.oro,
.btns-half a.oro {
  background: linear-gradient(to bottom, #F1EFD3, #dcd798);
  border-color: #b9b9b9;
  color: #004a94;
}

.sb-btns a.arancio,
.btns-large a.arancio,
.btns-half a.arancio {
  background: linear-gradient(to bottom, #FFE88C, #FFCC00);
  border-color: #e0b800;
  color: #252525;
}

.sb-btns a.celeste,
.btns-large a.celeste,
.btns-half a.celeste {
  background: linear-gradient(to bottom, #EDF3F8, #c8dae8);
  border-color: #a8c4d8;
  color: #1a1a1a;
}

.sb-btns a.verde,
.btns-large a.verde,
.btns-half a.verde {
  background: linear-gradient(to bottom, #e8f5e2, #b8dba8);
  border-color: #a8c8a0;
  color: #1a3a1a;
}

/* =========================
   fine BTN COLOR
========================= */

/* =========================
   MOTORE RICERCA
========================= */

.search-form {
  display: flex;
  align-items: stretch;
  width: 100%;
  max-width: 600px;
}

.search-input {
  flex: 1;
  padding: 4px 7px;
  font-size: 16px;
  border: 1px solid #ccc;
  border-right: none;
  border-radius: 4px 0 0 4px;
  outline: none;
  box-sizing: border-box;
}

.search-input:focus {
  border: 2px solid #ddd;
}

.search-btn {
  padding: 5px 10px;
  font-size: 17px;
  border: 1px solid #ccc;
  border-radius: 0 4px 4px 0;
 background: linear-gradient(to bottom, #F1EFD3, #dcd798);
 border: 1px solid #C5BD5C;
  cursor: pointer;
  white-space: nowrap;
}

.search-btn:hover {
      background: linear-gradient(to bottom, #dcd798, #F1EFD3);
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

.search-box{
  padding:0px 10px;
  background: transparent;
}

@media (max-width: 480px) {
  .search-input {
    border-right: 1px solid #ccc;
    border-bottom: none;
    border-radius: 4px 4px 0 0;
  }

  .search-btn {
    border-top: none;
    border-radius: 0 0 4px 4px;
    width: 100%;
  }

}

/* =========================
   FINE MOTORE RICERCA
========================= */

/* =========================
   MOTORE Ricerca Telefoni
========================= */

.cercanumeritelefonici {
    width: 96%;
    margin: 3px 1px 4px;
    padding: 4px 4px;
    text-align: left;
    font-weight: 700;
    font-size: 65%;
    background-color: #45aefc;
    font-family: "Verdana", "Arial", "Times", "Times New Roman", sans-serif;
    border: 1px solid #eee;
    color: #fff;
    border-radius: 2px;
    box-shadow: 0 1px 3px #aaa;
    /* Per vecchi browser */
    -moz-border-radius: 2px;
    -webkit-border-radius: 2px;
    -moz-box-shadow: 0 2px 4px #aaa;
    -webkit-box-shadow: 0 2px 4px #aaa;
}

/* =========================
   FINE MOT.Ricerca TeLefoni
========================= */