*{
  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: 18px;
  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 ================= */


.header{
  display:grid;
  grid-template-columns:250px 1fr;
  align-items:center;   /* ← QUESTA È LA CHIAVE */
  background:#ffffcc;
  border-bottom:2px solid #ddd;
}

.logo-desktop{
display:block;
margin-top: 8px;
}

.logo-mobile{
  display:none;
}

.logo-desktop,
.logo-mobile{
  max-width:100%;
  height:auto;
}

/* MOBILE */
@media (max-width:1100px){

  .logo-desktop{
    display:none;
  }

  .logo-mobile{
    display:block;
    margin-top: 5px;
  }

}

.header-right{
  padding:5px 5px 5px;
}

.intestazione{
  font-size:28px;
  margin:5px 1px 5px;
  background:#fff;
}

.intestazione p {
  font-weight: bold;     /* Testo in grassetto */
  color: green;          /* Colore verde */
  padding:1px 5px;
}

.ticker{
  background:#eee;
  padding:1px;
  font-size:14px;
}

/* ================= TITLE AREA ================= */

.title-area{
  display:grid;
  grid-template-columns:400px 1fr;
  background:#fff;
  margin-top:15px;
}

.title-box{
  padding:5px;
  border-right:1px solid #eee;
}

.text-box{
  padding:10px;
}

/* ================= SEARCH + BANNER ================= */

.top-section{
  display:grid;
  grid-template-columns:1fr;
  gap: 2px;0px;
  margin-top:20px;
}

@media (min-width:1024px){
  .top-section{
    grid-template-columns:300px 1fr;
  }
}


.search-box{
  background:#fff;
  padding:10px;
}

.search-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap:10px;
  margin-top:15px;
}

/* SEARCH */

.search-grid div{
  background:#eee;
  padding:5px;
  text-align:center;
}

/* centra SOLO immagini */
.search-grid div img{
  display:block;  /* Trasforma l'immagine in un elemento a blocco */
  margin:0 auto;  /* Centra l'immagine orizzontalmente all'interno del div */
}

/* testo più piccolo solo qui */
.search-box strong{
  font-size:14px;
  color:green
}

.search-grid h2{
  font-size:14px;
}

.search-grid{
  font-size:14px;
}

/* MOBILE */

@media (max-width:1024px){

  .search-grid div img{
    display:none;
  }

}

.banner-top{
  background:#ddd;
  display:flex;
  align-items:center;
  justify-content:center; /* Centrare orizzontalmente */
  font-size:22px;  /* Centrare verticalmente */
}

/* ================= SECTION TITLE ================= */

.section-title{
  margin:20px 0 20px 0;
  background:#fff;
  padding:2px 5px;
  text-align:center;
  font-weight:bold;
  font-size:22px;
}

/* ================= MAIN CONTENT ================= */

.main-content{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
}

.banner-left,
.news,
.sidebar{
  background:#fff;
  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;
  }

  .banner-left{
    grid-column: 1 / -1;
  }

  .sidebar{
    min-width:300px;
  }

}

@media only screen and (min-width:1024px){

  .search-grid{
     grid-template-columns: 1fr 1fr;
  }  /* La griglia con classe 'search-grid' avrà due colonne di larghezza uguale */

  .main-content{
    grid-template-columns: 5fr 3fr;
  }  /* La griglia con classe 'main-content' avrà due colonne: la prima più larga (5 parti),
       la seconda più stretta (3 parti) */

  .banner-left{
    grid-column: 1 / -1;
  }     /* L'elemento 'banner-left' si estende su tutte le colonne disponibili (dalla prima all'ultima) */

}

@media only screen and (min-width:1200px){

  .main-content{
    grid-template-columns: 2fr 6fr 4fr;
  } /* La griglia con classe 'main-content' avrà tre colonne con proporzioni 2:6:4 */

  .banner-left{
    grid-column:auto;
    min-width:160px;
  }   /* L'elemento 'banner-left' avrà una larghezza minima di 160px.
       'grid-column: auto' indica che si posiziona automaticamente secondo la griglia */
  }

  .sidebar{
    min-width:336px;
  }

}

/* ================= 50% ROW ================= */

.row-50{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;  /* Lo spazio tra le celle della griglia sarà di 20 pixel sia in orizzontale che in verticale */
  margin:20px 0;
}

.row-50 div{
  background:#fff;
  padding:10px;
}

/* ================= 33% ROW ================= */

.row-33{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-bottom:20px;
}

.row-33 div{
  background:#fff;
  padding:10px;
}

/* ================= 25% ROW ================= */

.row-25{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-bottom:20px;
}

.row-25 div{
  background:#fff;
  padding:10px;
}

/* ================= FOOTER ================= */

footer{
  background:#eee;
  color:#000;
  padding:30px;
  text-align:center;
}

/* ================= 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;
  }

  .row-50,
  .row-33,
  .row-25{
    grid-template-columns:1fr;
  }

}

@media (max-width:600px){

  body:{
 margin: 1px 2px;
}

  h1 {
  font-size:12px;
}

  .intestazione{
    font-size:22px;
     margin: 1px 1px;
  }

  .banner-top{
    min-height:150px;
  }

}

/* =========================
   fine telaio template
========================= */

/* =========================
   MOTORE RICERCA
========================= */

.search-container {
    min-width: 70px;
    max-width: 600px;
    margin: 10px auto;
    padding: 10px;
    background: #f8f9fa;
    border-radius: 4px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

.search-form {
    display: flex;
    gap: 10px;
    flex-wrap: nowrap; /* Impedisce che vada a capo */
    flex-direction: row; /* Disposizione in riga */
    align-items: center; /* Allinea verticalmente */
}

/* Input di testo */
.search-input {
    flex: 1;
    min-width: 90px;
    padding: 7px 16px;
    border: 2px solid #ddd;
    border-radius: 7px;
    font-size: 17px;
    outline: none;
    box-sizing: border-box;
}

/* Bottone di ricerca */
.search-btn {
    width: 80px;
    padding: 8px 12px;
    background: linear-gradient(to bottom, #F1EFD3, #dcd798);
    border: 1px solid #C5BD5C;
    color: #004a94;
    border-radius: 7px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s;
}

/* Hover bottone */

.search-btn:hover {
    transform: translateY(+1px);
     background: linear-gradient(to bottom, #dcd798, #F1EFD3);
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

/* Responsive per schermi piccoli */
@media (max-width: 480px) {
    .search-form {
        flex-direction: row; /* Rimane in riga anche su schermi piccoli */
        flex-wrap: nowrap; /* Impedisce il wrapping */
    }
    .search-input {
        min-width: 90px; /* puoi anche togliere questa riga se vuoi che si adatti */
        flex: 1;
    }
}

/* =========================
   FINE MOTORE RICERCA
========================= */

/* =========================
   TUTTI I BOTTONI 
========================= */

/* =========================
   Sezioni
========================= */
.quotidiani,
.periodici,
.giornali,
.menu3 {
  margin: 5px 0 10px;
}

.giornali{
 background:#ffffee;
  border:1px solid #b8962e;
  border-radius:8px;
  padding:10px;
}

.quotidiani h2,
.giornali h2,
.periodici h2,
.menu3 h2,
.pulsante h2 {
  margin-bottom: 10px;
  color: #8b351d;
  text-align: center;
}

/* =========================
   Contenitori bottoni DESKTOP
========================= */
.quotidiani p,
.periodici p,
.radio p,
.menu3 p {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 5px;
  align-items: stretch;
  margin-bottom: 5px;
}

/* Contenitore pulsante: text-align justify distribuisce i bottoni */
.pulsante {
  text-align: justify;
}
.pulsante p {
  text-align: justify;
  margin-bottom: 5px;
  font-size: 0; /* elimina lo spazio bianco tra inline-block */
}

/* =========================
   Bottoni generali
========================= */
.quotidiani a,
.giornali a,
.periodici a,
.radio a,
.menu3 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;

  background: linear-gradient(to bottom, #FEFEF2, #ecead6);
  border: 1px solid #d6d6d6;
  color: #444;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  overflow: hidden;
}

/* Colore testo pulsante */
.pulsante a { color: #1a1a1a; }

/* Bottoni pulsante: inline-block si adatta al testo/immagine */
.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 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: #444;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

/* Colori specifici */
.quotidiani a,
.giornali a,
.menu3 a { color: #1a1a1a; }
.periodici a,
.radio a { color: #cc0033; }

/* =========================
   Immagini nei bottoni
========================= */
.quotidiani a img,
.giornali a img,
.periodici a img,
.radio a img,
.menu3 a img,
.pulsante a img {
  max-width: 100%;
  max-height: 40px;
}

/* =========================
   Hover & Active
========================= */
.quotidiani a:hover,
.periodici a:hover,
.radio a:hover,
.pulsante a:hover {
  background: linear-gradient(to bottom, #ecead6, #FEFEF2);
  color: #ff0c00;
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}

.quotidiani a:active,
.giornali a:active,
.periodici a:active,
.radio a:active,
.pulsante a:active {
  background: linear-gradient(to bottom, #ecead6, #FEFEF2);
  transform: translateY(1px);
  box-shadow: none;
  color: #1a1a1a;
}

/* =========================
   Stile speciale menu3
========================= */
.menu3 a {
  background: linear-gradient(to bottom, #F1EFD3, #dcd798);
  border: 1px solid #b9b9b9;
  color: #004a94;
}
.menu3 a:hover {
  background: linear-gradient(to bottom, #dcd798, #F1EFD3);
  color: #ff0c00;
}
.menu3 a:active {
  color: #004a94;
}

/* =========================
   Stile speciale giornali hover
========================= */
.giornali a:hover {
  background: linear-gradient(to bottom, #ecead6, #FEFEF2);
  color: #ff0c00;
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}

/* =========================
   Giornali: griglia 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;
}

/* Elemento senza testo */
.giornali div.righe p {
  display: contents;
  margin: 0;
}

/* Bottone tutta cella */
.giornali div.righe p a {
  width: 100%;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* NUOVA VERSIONE: con classe con-testo */
.giornali div.righe p.con-testo {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 8px;
  grid-column: 1 / -1;
}

.giornali div.righe p.con-testo a {
  flex-shrink: 0;
  width: 100px;
}

.giornali div.righe 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;
}

/* Retrocompatibilità: <p> senza .righe */
.giornali > p {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 8px;
}
.giornali > p a {
  flex-shrink: 0;
  width: 100px;
}
.giornali > p .testo {
  flex: 1 1 0;
  min-width: 0;
  font-size: 13px;
  line-height: 1.4;
  color: #444;
  word-wrap: break-word;
  text-align: justify;
}

/* =========================
   Sezioni btg-lightblue e btg-orange
========================= */
.btg-lightblue,
.btg-orange {
  margin: 5px 0 10px;
}

.btg-lightblue h2,
.btg-orange h2 {
  margin-bottom: 15px;
  color: #8b351d;
  text-align: center;
}

.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;
}

.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;
}

.btg-lightblue a img,
.btg-orange a img {
  max-width: 100%;
  max-height: 40px;
}

/* btg-lightblue */
.btg-lightblue a {
  color: #252525;
  background: linear-gradient(to bottom, #EDF3F8, #c8dae8);
}
.btg-lightblue a:hover {
  background: linear-gradient(to bottom, #c8dae8, #EDF3F8);
  color: #ff0c00;
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}
.btg-lightblue a:active {
  background: linear-gradient(to bottom, #c8dae8, #EDF3F8);
  transform: translateY(1px);
  box-shadow: none;
  color: #252525;
}

/* btg-orange */
.btg-orange a {
  color: #252525;
  background: linear-gradient(to bottom, #FFE88C, #FFCC00);
}
.btg-orange a:hover {
  background: linear-gradient(to bottom, #FFCC00, #FFE88C);
  color: #ff0c00;
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}
.btg-orange a:active {
  background: linear-gradient(to bottom, #FFCC00, #FFE88C);
  transform: translateY(1px);
  box-shadow: none;
  color: #252525;
}

/* =========================
   Responsive smartphone (≤ 600px)
========================= */
@media (max-width: 600px) {
  .giornali div.righe p.con-testo {
    flex-direction: column;
    align-items: stretch;
  }
  .giornali div.righe p.con-testo a {
    width: 100%;
  }
  .giornali > p {
    flex-direction: column;
    align-items: stretch;
  }
  .giornali > p 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 SERVIZI
========================= */

/* =========================
   NOTIZIE
========================= */

 /* IL TUO CSS PERSONALIZZATO ADATTATO */
        .container-ticker { width: 100%; margin: 0 auto 0px auto; }
        .container-main { max-width: 850px; 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; 
            padding: 1px 4px 1px 7px; 
            border: 1px solid rgba(194, 186, 75, 0.2);
            border-radius: 7px;
            min-height: 50px; 
            box-shadow: 0 4px 10px rgba(0,0,0,0.2);
        }
        .tikernewsclass a { font-family: Roboto+Condensed; color: #ffeb3b !important; text-decoration: none; font-weight: bold; 
        }

         .tikernewsclass data { font-family: Roboto+Condensed; color: #fff !important; text-decoration: none; font-weight: bold; 
        }

        /* 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%); transition: all 0.6s ease; display: block; }
        .news-frame:hover .news-thumb { filter: grayscale(0%) sepia(70%) 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(#ffffdd, #ffffcc);
  border-bottom: 2px solid #cc0033;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  position: relative;
}

/* Checkbox nascosta */
#menu-toggle {
  display: none;
}

/* ================= DESKTOP ================= */

.menu-level-1 {
  list-style: none;
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 10px 5px 7px;
}

.menu-level-1 > li {
    background:  #ffffee;
  position: relative;
}

.menu-level-1 > li > a {
  text-decoration: none;
  font-weight: 900;
  font-size: 18px;
  letter-spacing: 0.5px;
  color: #3792ff;
  padding: 6px 0;
  transition: 0.3s ease;

}

.menu-level-1 > li > a.active {
  color: #cc0033; /* Il rosso che usi per gli h2 */
  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: 4px;
}

.menu-level-1 > li > a:hover::after {
  width: 100%;
}

/* ================= SUBMENU DESKTOP ================= */

.menu-level-2 {
  list-style: none;
  position: absolute;
  top: 100%;
  left: 50%;
  background: #ffffff;
  padding: 15px 5px;
  display: none;
  gap: 2px;
  border-radius: 6px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
  white-space: nowrap; /* Evita che i link vadano a capo */
}

.menu-level-2 {
  /* ... altre proprietà ... */
  max-width: 95vw; /* Impedisce al menu di uscire dallo schermo */
  overflow-x: auto; /* Permette lo scroll se le voci sono troppe */
  flex-wrap: wrap;  /* In alternativa, le voci vanno a capo su due righe */
  justify-content: center;
}

.menu-level-2 a {
  text-decoration: none;
  font-family: 'Open Sans', sans-serif;
  font-weight: 600;
  font-size: 14px;
  /* CAMBIO: stesso blu del menu principale */
  color: #3792ff; 
  padding: 8px 12px;
  text-transform: uppercase; /* Se vuoi mantenere lo stile "Condensed" del menu */
  letter-spacing: 0.5px;
  transition: all 0.2s ease;
}

.menu-level-2 a:hover {
  /* Al passaggio del mouse possiamo scurirlo o usare il rosso dei titoli per contrasto */
  color: #1a6cd1; 
  background: #f0f7ff; /* Un leggero tocco azzurrato sullo sfondo */
  border-radius: 4px;
}

.menu-level-2::after {
  content: '';
  position: absolute;
  top: -6px; /* Lo posiziona sul bordo superiore */
  left: 50%;
  transform: translateX(-50%);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid #ffffff; /* Colore uguale allo sfondo del sottomenu */
}

.menu-level-2 li {
  display: inline-block;
}

.menu-level-2 a {
  text-decoration: none;
  font-weight: 700;
  padding: 6px 10px;
  transition: 0.2s;
}

.menu-level-2 a:hover {
  color: #cc0033;
}

.has-sub:hover .menu-level-2 {
  display: flex;
  animation: fadeDown 0.25s ease forwards;
}

@keyframes fadeDown {
  from { opacity: 0; transform: translateY(-5px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ================= HAMBURGER ================= */

.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 15px;
  margin-left: auto;      /* SPINGE A DESTRA */
}

.hamburger span {
  width: 25px;
  height: 3px;
  background: #1a1a1a;
  transition: 0.3s;
}

/* Animazione hamburger */
#menu-toggle:checked + .hamburger span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

#menu-toggle:checked + .hamburger span:nth-child(2) {
  opacity: 0;
}

#menu-toggle:checked + .hamburger span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

/* ================= MOBILE (a 1100px) ================= */

/* ================= MOBILE (Versione Ultra-Stabile) ================= */
@media (max-width: 1023px) {

  /* 1. Forza la barra principale a non scoppiare */
  .main-nav {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 60px;
    position: relative;
  }

  .hamburger { display: flex; }

  /* 2. Il Pannello del Menu (si apre sotto la barra) */
  .menu-level-1 {
    display: none; /* Nascosto di base */
    flex-direction: column;
    position: absolute;
    top: 60px;
    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 */
  #menu-toggle:checked ~ .menu-level-1 {
    display: block; /* Usiamo block per evitare conflitti flex */
  }

  /* 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; /* Chiuso */
    position: static !important; /* IMPORTANTE: sposta i link sotto */
    width: 100% !important;
    transform: none !important;  /* Rimuove centraggio desktop */
    left: 0 !important;
    background: #f4f4f4 !important; /* Grigio per distinguerlo */
    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:active .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 2026
===================================== */

/* =========================
   BTN COLOR — sb-btns
   Griglia bottoni multicolore autonoma.
   Non dipende da nessun'altra classe.
   Usare ovunque: sidebar, main, footer.
   HTML: <div class="sb-btns"> <a class="oro">...</a> </div>
   Classi colore: .oro .arancio .celeste .verde (senza = crema)
========================= */

.sb-btns {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 5px;
  margin: 5px 0 10px;
}

.sb-btns 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;
  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;
  /* reset esplicito da regole globali template */
  letter-spacing: normal;
  border-bottom: 1px solid #d6d6d6;
  line-height: 1.1;
}

.sb-btns a:hover {
  filter: brightness(0.93);
  color: #ff0c00;
  border-bottom: 1px solid #d6d6d6;
}

.sb-btns a:active {
  transform: translateY(1px);
  box-shadow: none;
}

.sb-btns a img {
  max-width: 100%;
  max-height: 40px;
  display: inline;
}

/* Varianti colore */
.sb-btns a.oro {
  background: linear-gradient(to bottom, #F1EFD3, #dcd798);
  border-color: #b9b9b9;
  color: #004a94;
}

.sb-btns a.arancio {
  background: linear-gradient(to bottom, #FFE88C, #FFCC00);
  border-color: #e0b800;
  color: #252525;
}

.sb-btns a.celeste {
  background: linear-gradient(to bottom, #EDF3F8, #c8dae8);
  border-color: #a8c4d8;
  color: #1a1a1a;
}

.sb-btns a.verde {
  background: linear-gradient(to bottom, #e8f5e2, #b8dba8);
  border-color: #a8c8a0;
  color: #1a3a1a;
}

/* =========================
   fine BTN COLOR
========================= */
