/* Definizioni Variabili Globali */
:root {
  --colore-punti-100: #0d6efd; /* Blu primario Bootstrap */
  --colore-punti-50: #0dcaf0; /* Ciano/Azzurro Bootstrap (info) */
  --colore-punti-vuoti: #6c757d; /* Grigio (Bootstrap secondary) */
}

/* Stili Generali */
body {
  font-family: "Arial", sans-serif;
  margin: 0;
  padding: 0;
  color: #333;
  background-color: #f8f9fa;
}

h1 {
  text-align: center;
  margin-top: 0;
  margin-bottom: 20px;
  color: #0056b3;
  font-size: 1.8em; /* Leggermente ridotto */
}

h2 {
  margin-top: 25px;
  margin-bottom: 15px; /* Aumentato leggermente */
  color: #007bff;
  border-bottom: 1px solid #eee;
  padding-bottom: 5px;
}

/* Stili per la Navigazione */
nav {
  background-color: #e9ecef;
  padding: 10px 20px;
  border-bottom: 1px solid #dee2e6;
  margin-bottom: 20px;
  display: flex;
  align-items: center; /* Aggiunto per allineare verticalmente gli item */
  gap: 10px;
  position: sticky; /* Rende la barra di navigazione appiccicosa */
  top: 0; /* Si attacca alla parte superiore della viewport */
  z-index: 1000; /* Assicura che sia sopra gli altri contenuti */
}

.nav-button {
  padding: 8px 15px;
  cursor: pointer;
  border: 1px solid #ced4da;
  background-color: #f8f9fa;
  color: #333;
  border-radius: 4px;
  font-size: 0.9em;
  font-weight: normal;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  line-height: normal;
  -webkit-appearance: none; /* Reset styling nativo */
  -moz-appearance: none; /* Reset styling nativo */
  appearance: none; /* Reset styling nativo */
  transition: background-color 0.2s ease, border-color 0.2s ease,
    color 0.2s ease, font-weight 0.2s ease;
}

.nav-button.active {
  background-color: #007bff;
  color: white;
  border: 1px solid #007bff;
  font-weight: bold;
}

.nav-button:hover:not(.active) {
  background-color: #dee2e6;
  border-color: #adb5bd;
}

/* Stili per il pulsante Supporta Ko-fi */
.btn-supporta {
  background-color: #eec14b; /* Oro morbido (meno saturo) */
  color: #333; /* Testo scuro per leggibilità */
  padding: 4px 10px;
  border-radius: 20px; /* Bordo arrotondato "a pillola" moderna */
  text-decoration: none;
  font-weight: bold;
  font-family: sans-serif;
  font-size: 0.8em;
  transition: transform 0.2s ease; /* Effetto animato al passaggio del mouse */
  display: inline-flex;
  align-items: center;
  gap: 5px; /* Spazio tra tazzina e testo */
  margin-right: 10px; /* Spazio a destra per staccarlo dal bottone Lingua */
}

.btn-supporta:hover {
  background-color: #f2cf70; /* Oro morbido più chiaro */
  transform: scale(1.05); /* Si ingrandisce leggermente per invitare al click */
  color: #333; /* Mantiene il testo scuro per leggibilità */
}

/* Stili per il placeholder della lingua */
.language-placeholder {
  padding: 8px 15px;
  color: #555; /* Testo grigio scuro */
  background-color: #f0f0f0; /* Sfondo grigio chiaro */
  border: 1px solid #ccc; /* Bordo grigio */
  border-radius: 4px;
  font-size: 0.9em;
  align-self: center; /* Allinea verticalmente con gli altri item della nav */
  font-style: italic; /* Corsivo per indicare "in costruzione" */
}

/* Sposta il selettore della lingua e il badge della versione a destra */
#language-selector {
  margin-left: auto;
}

/* Stili per le Sezioni */
.view-section {
  padding: 20px;
  background-color: #ffffff;
  border: 1px solid #dee2e6;
  margin: 0 20px 10px 20px; /* Ridotto il margin-bottom da 20px a 10px */
  border-radius: 8px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);
  min-height: auto; /* Aggiungiamo questa proprietà */
}

#dashboard-view {
  padding: 0;
  min-height: auto; /* Cambiato da 100vh */
  display: flex;
  flex-direction: column;
  position: relative;
}

/* Modifica il contenitore dello sfondo */
#dashboard-background-content {
  background-image: url("imageVRCompass.png");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  min-height: calc(100vh - 470px); /* Aumentato da 450px a 470px */
  padding: 20px;
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

.version-badge {
  font-size: 0.8em;
  font-weight: bold;
  color: #6c757d;
  background-color: #e9ecef;
  padding: 4px 8px;
  border-radius: 4px;
  /* Il posizionamento a destra è ora gestito da #language-selector */
}

.dashboard-card {
  background-color: rgba(
    238,
    244,
    248,
    0.85
  ); /* Aumentata la trasparenza da 0.95 a 0.85 */
  padding: 8px 15px;
  margin-bottom: 15px;
  min-width: 300px;
  max-width: 550px; /* Aumentato da 450px a 550px */
  margin-left: auto;
  margin-right: auto;
  border-radius: 4px; /* Aggiunto per coerenza visiva */
}

/* Stile per i titoli all'interno delle dashboard-card */
.dashboard-card h3 {
  text-align: center;
  margin-top: 3px;
  margin-bottom: 8px;
  color: #0056b3;
  font-size: 1em;
  font-weight: bold; /* Aggiunto per coerenza */
  padding-bottom: 5px; /* Aggiunto per coerenza */
  white-space: nowrap; /* Forza il testo su una sola riga */
  overflow: hidden; /* Nasconde il testo in eccesso */
  text-overflow: ellipsis; /* Mostra ... se il testo è troppo lungo */
  flex-shrink: 0; /* Impedisce al titolo di restringersi in altezza */
}

/* Stile per la card info/gestione nella dashboard (colonna destra) */
#info-gestione-card {
  max-height: 580px; /* Ridotto da 620px */
  overflow-y: auto; /* Aggiunge la barra di scorrimento verticale se il contenuto eccede */
}

.dashboard-layout {
  display: flex;
  flex-wrap: wrap;
  gap: 15px; /* Ridotto da 20px */
}

.dashboard-column-left {
  flex: 2; /* Occupa una porzione maggiore dello spazio disponibile */
  min-width: 260px; /* Ridotto da 280px */
  display: flex;
  flex-direction: column;
  gap: 20px; /* Spazio tra le card nella colonna sinistra */
}

.dashboard-column-right {
  flex: 1; /* Occupa una porzione minore dello spazio disponibile */
  min-width: 260px; /* Ridotto da 280px */
}

.info-gestione-sezione {
  margin-bottom: 20px; /* Spazio tra le sotto-sezioni nella card di destra */
}

/* Allarga solo la card del grafico andamento VSR */
#grafico-andamento-vsr-card {
  max-width: 750px; /* Aumenta la larghezza massima solo per questa card */
  width: 100%;
  margin-left: 0;
}

/* Stili per la Dashboard */
.dashboard-item {
  margin-top: 5px; /* Piccolo margine superiore */
  margin-bottom: 8px; /* Ridotto il margine inferiore */
  display: flex;
  align-items: baseline; /* Allinea alla baseline per testo e input */
  gap: 10px; /* Aumentato leggermente per più spazio orizzontale */
  width: 100%; /* Assicura che l'item occupi tutta la larghezza disponibile */
}

/* Nuova classe per dashboard-item con elementi distribuiti */
.dashboard-item-flex-space-between {
  display: flex;
  justify-content: space-between;
  align-items: baseline; /* Coerente con .dashboard-item */
}

.dashboard-item label {
  /* width: 120px; */ /* Rimosso: la larghezza sarà flessibile */
  flex-shrink: 0;
  font-weight: bold;
  white-space: nowrap; /* Evita che l'etichetta vada a capo, se possibile */
}
/* Stile per i descrittori nella dashboard che non sono label di input */
.dashboard-descriptor {
  /* width: 180px; */ /* Rimosso: la larghezza sarà flessibile */
  font-weight: bold; /* Mantieni il grassetto */
  flex-shrink: 0; /* Se è ancora in un contesto flex dove questo è rilevante */
  /* Puoi copiare qui altri stili da .dashboard-item label se necessario */
  display: inline-block; /* Per far rispettare la larghezza se non è in un flex container */
}

#classifica-vsr-attuale {
  font-weight: bold;
  color: #007bff;
  font-size: 1.1em;
}

/* Contenitore per i pulsanti di gestione dati per permettere il wrap */
#gestione-dati-pulsanti .pulsanti-wrapper {
  display: flex;
  flex-wrap: wrap; /* Permette ai pulsanti di andare a capo se non c'è spazio */
  gap: 8px; /* Spazio tra i pulsanti */
}

/* Stili per i pulsanti di azione nella Dashboard (Esporta/Importa) */
button.dashboard-action-button,
label.dashboard-action-button {
  /* Applica anche alle label con questa classe */
  padding: 8px 12px; /* Padding ridotto per renderli più compatti */
  cursor: pointer;
  border: 1px solid #007bff; /* Bordo blu primario */
  background-color: #007bff; /* Sfondo blu primario */
  color: white;
  border-radius: 4px;
  font-size: 0.9em; /* Dimensione font ridotta */
  font-weight: normal; /* Rimosso bold per coerenza con nav-button, se preferisci bold rimettilo */
  text-decoration: none;
  display: inline-block;
  text-align: center;
  transition: background-color 0.2s ease, border-color 0.2s ease,
    transform 0.1s ease;
  /* margin-right: 10px; Rimosso, gestito da gap nel wrapper */
}

button.dashboard-action-button:hover,
label.dashboard-action-button:hover {
  /* Applica anche alle label con questa classe */
  background-color: #0056b3; /* Blu più scuro all'hover, coerente con .nav-button.active:hover */
  border-color: #0056b3;
  transform: translateY(-1px); /* Leggero effetto "sollevamento" */
}

/* Stile specifico per il pulsante "DataBase Regate" */
#btn-database-regate {
  background-color: #ffc107; /* Giallo Bootstrap (warning) */
  border-color: #ffc107;
  color: #212529; /* Testo scuro per contrasto con giallo */
  /* margin-right: 0; /* Opzionale: rimuove il margine destro se è l'ultimo elemento e non serve */
}

#btn-database-regate:hover {
  background-color: #e0a800; /* Giallo più scuro per hover */
  border-color: #e0a800;
  color: #212529; /* Mantiene il testo scuro */
}

/* Stile per l'input del nome barca */
#nome-barca {
  /* width: 180px; */ /* Rimosso: la larghezza sarà flessibile */
  flex-grow: 1; /* Permette all'input di espandersi per riempire lo spazio */
  min-width: 150px; /* Larghezza minima per evitare che diventi troppo piccolo */
  padding: 4px 8px;
  height: 28px;
  box-sizing: border-box;
  border: 1px solid #ced4da;
  border-radius: 4px;
  font-size: 0.95em;
}

/* Stili specifici per la Gestione Crediti (#gestione-crediti-view) */
#gestione-crediti-view h1 {
  text-align: left;
}
#gestione-crediti-view h2 {
  font-size: 1.3em;
}

#container-principale-calcolatrice {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 30px;
}

#container-principale-calcolatrice > div:first-child {
  flex: 2;
  min-width: 550px;
}

#istruzioni {
  border: 1px solid #ccc;
  padding: 20px;
  background-color: #f1f3f5;
  border-radius: 5px;
  flex: 1;
  min-width: 350px;
  box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.05);
  overflow-wrap: break-word;
}

#istruzioni h2 {
  margin-top: 0;
  color: #007bff;
  border-bottom: none;
  font-size: 1.1em;
}

#istruzioni p {
  line-height: 1.4;
  color: #495057;
  font-size: 0.9em;
}

/* Stili Tabelle (Generali e Calcolatrice) */
table {
  border-collapse: collapse;
  width: 100%;
  margin-bottom: 25px;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.08);
}

thead th {
  background-color: #007bff;
  color: white;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 10px;
  font-size: 0.9em;
}

th,
td {
  border: 1px solid #ddd;
  padding: 8px 10px;
  text-align: center;
  font-size: 0.9em;
  vertical-align: middle;
}

/* Allinea a sinistra il testo nella colonna "Nome Regata" dello storico (#tabella-classifica-vsr) */
#tabella-classifica-vsr thead th:nth-child(2),
#tabella-classifica-vsr tbody td:nth-child(2) {
  text-align: left;
}

tbody tr:nth-child(even) {
  background-color: #f9f9f9;
}

/* Stili per lo stato dei punti nella tabella storico VSR */
#tabella-classifica-vsr tbody tr.stato-100 {
  background-color: #d4edda; /* Verde chiaro per 100% */
  color: #155724; /* Testo scuro per contrasto */
}

#tabella-classifica-vsr tbody tr.stato-50 {
  background-color: #fff3cd; /* Giallo chiaro per 50% */
  color: #856404; /* Testo scuro per contrasto */
}

#tabella-classifica-vsr tbody tr.stato-scaduta {
  background-color: #e9ecef; /* Grigio chiaro per scadute */
  color: #6c757d; /* Testo grigio scuro */
  /* Potresti anche aggiungere: text-decoration: line-through; per i punti o l'intera riga */
}

/* Stile per le gare in preavviso di cambio stato */
#tabella-classifica-vsr tbody tr.in-preavviso {
  border-left: 5px solid #dc3545; /* Rosso (colore di danger Bootstrap) */
}

/* Nasconde la colonna "Stato Punti" quando la vista "Mostra Tutte" è attiva */
#tabella-classifica-vsr.vista-tutte-attiva thead th:nth-child(6),
#tabella-classifica-vsr.vista-tutte-attiva tbody td:nth-child(6) {
  display: none;
}

/* Stile per separare i gruppi di livello nella vista "valide" dello storico con uno stacco bianco */
#tabella-classifica-vsr tbody tr.nuovo-gruppo-livello td {
  box-shadow: inset 0 5px 0 0 #ffffff; /* 5px di "spazio bianco" sopra */
}

/* Stile specifico per la riga bonus (Calcolatrice) */
.bonus-row {
  background-color: #e9ecef; /* Grigio chiaro standard header */
  color: #333;
  font-weight: bold;
}
.bonus-row td:first-child {
  /* Evidenzia la label del bonus */
  background-color: #dee2e6;
}

/* Stile per evidenziare categoria e selezione (Calcolatrice) */
th.categoria-cell {
  /* Header categoria cliccabile */
  cursor: pointer;
  transition: background-color 0.2s ease;
}
th.categoria-cell:hover {
  background-color: #0056b3;
}
th.selected-category {
  background-color: #ffc107; /* Giallo */
  color: black;
}
td.highlight-column {
  background-color: #fff3cd; /* Giallo molto chiaro */
}
td.attrezzatura-cell {
  /* Celle attrezzatura cliccabili */
  cursor: pointer;
  transition: background-color 0.2s ease;
}
td.attrezzatura-cell:hover {
  background-color: #f0f0f0;
}
td.attrezzatura-cell.selected {
  background-color: #cfe2ff; /* Azzurrino (Bootstrap info-subtle) */
  font-weight: bold;
  color: #052c65; /* Colore testo scuro per contrasto */
}

/* Nuova classe per il nome dell'attrezzatura selezionata */
td.selected-name {
  background-color: #cfe2ff; /* Azzurrino (Bootstrap info-subtle) */
  font-weight: bold;
  color: #052c65; /* Colore testo scuro per contrasto */
}

/* Nuova classe per le celle con risultati calcolati */
td.calculated-result-cell {
  background-color: #e0f2ff; /* Azzurrino leggermente diverso per distinguerlo */
  font-weight: bold;
  color: #000000; /* Cambiato in nero */
}

/* Stili per input nelle tabelle (Calcolatrice) */
#tabella2 input[type="number"],
#tabella3 input[type="number"],
#tabella3 select {
  width: 90%;
  padding: 6px;
  border: 1px solid #ced4da;
  border-radius: 4px;
  box-sizing: border-box;
  text-align: right;
  font-size: 0.95em;
}
#tabella3 select {
  text-align: left;
}

/* Applica text-align: center specificamente all'input bonus in tabella2 */
#tabella2 tbody tr td:nth-child(2) input[type="number"] {
  /* Seleziona l'input nella seconda cella (Bonus) */
  text-align: center;
}
/* Centra il testo nell'input della classifica finale in Tabella 3 */
#tabella3 tbody td:nth-child(2) input[type="number"] {
  text-align: center; /* Manteniamo il centraggio richiesto in precedenza */
  width: 90%; /* Applichiamo esplicitamente la larghezza come per il bonus */
  /* Questo assicura che l'input tenti di usare il 90% della cella */
  min-width: 60px; /* Aggiungiamo una larghezza minima per garantire spazio */
  /* sufficiente per più cifre, anche se la cella è stretta. */
  /* Puoi aggiustare 60px se necessario. */
}

.calculated-cell {
  background-color: #e8f0fe; /* Azzurro chiaro */
  font-weight: bold;
}
.important-result {
  /* Es. Posizione Recupero */
  color: #dc3545; /* Rosso */
}
.profitto {
  color: #28a745; /* Verde */
  font-weight: bold;
}

/* Stili per risultati calcolati (Calcolatrice) */
.perdita {
  color: #dc3545; /* Rosso */
  font-weight: bold;
}

/* Stili per la sezione Gestione Classifica VSR (#classifica-vsr-view) */
#classifica-vsr-view h2 {
  margin-bottom: 20px;
  font-size: 1.3em;
  border: none;
}
/* Stile per il punteggio VSR attuale nell'intestazione della sezione Gestione Classifica VSR */
#classifica-vsr-attuale-display {
  font-weight: bold;
  color: #007bff;
  font-size: 1.1em; /* Coerente con quello della Dashboard */
  padding: 2px 4px; /* Leggero padding per separarlo visivamente */
  background-color: #e9ecef; /* Sfondo leggero per farlo risaltare */
  border-radius: 3px;
}
#form-aggiungi-gara {
  background-color: #f8f9fa;
  padding: 15px 20px;
  border: 1px solid #dee2e6;
  border-radius: 5px;
  margin-bottom: 25px;
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
  align-items: center;
}

#form-aggiungi-gara label {
  font-weight: bold;
  margin-right: 5px;
  font-size: 0.9em;
}
#form-aggiungi-gara input[type="date"],
#form-aggiungi-gara input[type="number"],
#form-aggiungi-gara select,
#form-aggiungi-gara input[type="text"] {
  /* Unificato lo stile per tutti gli input del form */
  padding: 8px;
  border: 1px solid #ced4da;
  border-radius: 4px;
  font-size: 0.9em;
  box-sizing: border-box; /* Assicura che padding e border non alterino la larghezza totale */
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out; /* Aggiunge transizione per il focus */
}
#form-aggiungi-gara input[type="date"] {
  width: 130px;
}
#form-aggiungi-gara select {
  width: 180px;
}
#form-aggiungi-gara input[type="number"] {
  width: 110px;
  text-align: right;
}
/* Rende il campo Nome Regata flessibile e più grande, come richiesto */
#form-aggiungi-gara input#nome-regata {
  flex-grow: 1; /* Permette al campo di espandersi per riempire lo spazio */
  min-width: 200px; /* Aumenta la larghezza minima per una migliore visibilità */
}
#form-aggiungi-gara input#punteggio-vsr {
  background-color: #e9ecef;
  cursor: not-allowed;
}
#form-aggiungi-gara button {
  padding: 8px 15px;
  background-color: #28a745;
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.2s ease;
  font-size: 0.9em;
  /* margin-left: auto; */ /* Rimosso per un posizionamento flessibile */
}

/* Stile per il focus sugli input del form per evitare il "salto" del layout */
#form-aggiungi-gara input:focus,
#form-aggiungi-gara select:focus {
  border-color: #86b7fe;
  outline: 0; /* Rimuove l'outline di default che causa il salto */
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25); /* Usa box-shadow per l'effetto focus, che non altera le dimensioni */
}
#form-aggiungi-gara button:hover {
  background-color: #218838;
}

/* Stile specifico per il pulsante "Carica da Elenco Regate" per differenziarlo.
   Usiamo l'ID per essere più specifici della regola generica '#form-aggiungi-gara button'. */
#form-aggiungi-gara #btn-apri-modal-elenco-regate {
  background-color: #17a2b8; /* Colore verde acqua/ciano (Bootstrap 'info') */
  border: none; /* Rimuoviamo il bordo per coerenza con l'altro pulsante */
}

/* Stile per l'hover del pulsante "Carica da Elenco Regate" */
#form-aggiungi-gara #btn-apri-modal-elenco-regate:hover {
  background-color: #138496; /* Versione più scura del ciano per l'hover */
}

/* Nuovo stile per lo spacer che spinge il pulsante "Carica" a destra */
.form-spacer {
  flex-grow: 1; /* Questo elemento si espanderà per riempire lo spazio vuoto */
}

/* Stili per il contenitore dell'elenco regate suggerite */
.elenco-regate-suggerite-container {
  margin-top: 20px;
  margin-bottom: 20px;
  padding: 15px;
  background-color: #e7f5ff; /* Azzurrino tenue */
  border: 1px solid #bde0fe; /* Bordo azzurro più scuro */
}

/* Stili per la sezione elenco regate suggerite */
#sezione-elenco-regate-suggerite {
  max-height: 400px; /* Limita l'altezza massima */
  overflow-y: auto; /* Aggiunge la barra di scorrimento verticale se necessario */
  padding-right: 10px; /* Spazio per la scrollbar per non sovrapporre il contenuto */
}

#tabella-gare-salvate th,
#tabella-gare-salvate td {
  font-size: 0.85em;
  padding: 6px 8px;
}
/* Rimosso lo stile per #tabella-gare-salvate button.delete-btn perché non ci sono pulsanti elimina visibili in quella tabella */

/* Stili per i pulsanti di azione nella tabella storico VSR (#tabella-classifica-vsr) */
/* Pulsante Elimina */
#tabella-classifica-vsr button.delete-btn {
  background-color: #f28b82; /* Rosso più tenue */
  color: white;
  border: none;
  padding: 4px 10px;
  border-radius: 3px;
  cursor: pointer;
  font-size: 0.85em;
  margin: 2px; /* Piccolo margine per non toccare i bordi della cella e separare dai pulsanti adiacenti */
  transition: background-color 0.2s ease;
}

#tabella-classifica-vsr button.delete-btn:hover {
  background-color: #e17055; /* Rosso tenue più scuro per hover */
}

/* Pulsante Modifica */
#tabella-classifica-vsr button.edit-btn {
  background-color: #ffd966; /* Giallo più tenue */
  color: #212529; /* Testo scuro per contrasto con giallo */
  border: none;
  padding: 4px 10px;
  border-radius: 3px;
  cursor: pointer;
  font-size: 0.85em;
  margin: 2px;
  transition: background-color 0.2s ease;
}

#tabella-classifica-vsr button.edit-btn:hover {
  background-color: #f9c74f; /* Giallo tenue più scuro per hover */
}

/* Stili per le intestazioni di colonna ordinabili */
.sortable-header {
  cursor: pointer;
  position: relative;
  transition: background-color 0.2s ease; /* Aggiunge transizione per il colore di sfondo */
}

.sortable-header:hover {
  background-color: #0056b3; /* Blu più scuro al passaggio del mouse */
}

.sortable-header::after {
  content: "";
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  border: 4px solid transparent;
  opacity: 0.6; /* Aumentata l'opacità di default per renderlo più visibile */
  transition: opacity 0.2s ease; /* Aggiunge transizione per l'opacità */
}

.sortable-header:hover::after {
  opacity: 1; /* L'indicatore diventa completamente visibile al passaggio del mouse */
}

.sortable-header.sort-asc::after {
  border-bottom-color: currentColor;
  opacity: 1;
}

.sortable-header.sort-desc::after {
  border-top-color: currentColor;
  opacity: 1;
}

/* Stile per il suggerimento di ordinamento nella tabella VSR */
.sort-hint {
  font-size: 0.85em;
  font-style: italic;
  color: #6c757d; /* Grigio secondario Bootstrap */
  text-align: center;
  margin-top: -5px; /* Avvicina il testo ai pulsanti sopra */
  margin-bottom: 15px;
}

/* Layout per la sezione Gestione Classifica VSR */
#container-principale-vsr {
  display: flex;
  gap: 20px;
}

#contenuto-vsr {
  /* Colonna sinistra per form e tabella storico */
  flex: 2;
  min-width: 0;
}

/* Stili per il box istruzioni della Gestione Classifica VSR (colonna destra) */
#istruzioni-vsr-box {
  flex: 1;
  border: 1px solid #ccc;
  padding: 20px;
  background-color: #f1f3f5;
  border-radius: 5px;
  box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.05);
  overflow-wrap: break-word;
  /* Le regole per max-height e overflow-y sono più in basso, specifiche per la scrollabilità */
}

#istruzioni-vsr-box h2 {
  margin-top: 0;
  color: #007bff;
  border-bottom: none;
  font-size: 1.1em;
  margin-bottom: 15px;
}

#istruzioni-vsr-box p,
#istruzioni-vsr-box ul {
  line-height: 1.4;
  color: #495057;
  font-size: 0.9em;
  margin-bottom: 10px;
}

#istruzioni-vsr-box ul {
  padding-left: 20px; /* Indentazione standard per liste */
}
#istruzioni-vsr-box code {
  /* Stile per l'elemento code */
  background-color: #e9ecef;
  padding: 2px 4px;
  border-radius: 3px;
  font-family: monospace;
}

/* Stili per la sezione Analisi e Simulazioni (#analisi-view) */
#analisi-view > h1 + p {
  /* Seleziona il primo paragrafo dopo l'h1 principale della sezione */
  font-style: italic;
  color: #6c757d;
  text-align: center;
  margin-bottom: 25px;
}

.analisi-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.analisi-sezione {
  background-color: #f8f9fa;
  padding: 20px;
  border: 1px solid #e9ecef;
  border-radius: 6px;
}

.analisi-sezione h2 {
  margin-top: 0;
  font-size: 1.2em;
  color: #0056b3;
}
.analisi-sezione p {
  font-style: normal;
  color: #495057;
  font-size: 0.95em;
  line-height: 1.5;
  margin-bottom: 15px;
}
#slot-vsr-container {
  display: grid;
  /* Definisce 4 colonne: la prima è più larga (1.5 volte) delle altre 3 */
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 20px;
  align-items: start; /* Allinea gli elementi all'inizio della loro cella di griglia verticalmente */
}

/* Nuovo wrapper per la colonna sinistra in Analisi */
.colonna-hc-radar-wrapper {
  display: flex;
  flex-direction: column;
  gap: 20px; /* Spazio tra la card HC e la card del grafico */
}

.slot-categoria {
  padding: 15px;
  border-radius: 4px;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  border: 1px solid #dee2e6;
}
.slot-categoria.slot-debole {
  border-left: 5px solid #ffc107; /* Giallo/Arancione (Bootstrap warning color) */
  background-color: #fff9e6; /* Sfondo giallo molto chiaro per enfatizzare */
}

.slot-categoria.slot-con-opportunita {
  border-left: 5px solid #28a745; /* Verde (Bootstrap success color) */
  background-color: #e9f7ef; /* Sfondo verde molto chiaro */
}

/* Stile per slot con preavviso (non necessariamente debole) */
.slot-categoria.slot-con-preavviso {
  border-left: 5px solid #17a2b8; /* Blu/ciano (Bootstrap info color) */
  background-color: #e8f7f9; /* Sfondo ciano molto chiaro */
}

.info-icon {
  /* Stile per l'icona informativa usata nei preavvisi */
  color: #17a2b8; /* Blu/ciano (Bootstrap info color) */
}

.slot-categoria h3 {
  margin-top: 0;
  font-size: 1.1em;
  color: #007bff;
  border-bottom: 1px solid #eee;
  padding-bottom: 8px;
  margin-bottom: 10px;
}

.progress-bar-container {
  width: 100%;
  background-color: #e9ecef;
  border: 1px solid #ced4da;
  border-radius: 4px;
  height: 14px; /* Ridotta l'altezza */
  margin-top: 5px;
  margin-bottom: 10px;
  overflow: hidden;
}

/* Stile base per l'elemento interno della barra di progresso */
.progress-bar {
  height: 100%;
  width: 0%;
  border-radius: 0.25rem;
  transition: width 0.5s ease-in-out, background-color 0.3s ease;
}

/* Classi per colorare le barre di progresso */
.progress-bar.progress-bar-good {
  background-color: #28a745;
} /* Verde */
.progress-bar.progress-bar-medium {
  background-color: #ffc107;
} /* Giallo */
.progress-bar.progress-bar-low {
  background-color: #dc3545;
} /* Rosso */
.progress-bar.progress-bar-empty {
  background-color: #6c757d;
} /* Grigio */

/* Stili per l'header delle informazioni dello slot (Slot Occupati e Punti Categoria) */
.slot-info-header {
  display: flex;
  justify-content: space-between; /* Allinea gli elementi ai lati opposti */
  align-items: center; /* Allinea verticalmente al centro */
  margin-bottom: 8px; /* Spazio prima della barra di progresso */
}

.slot-occupati-info,
.slot-punti-categoria {
  margin: 0; /* Rimuove il margine predefinito dei paragrafi */
  font-size: 0.9em; /* Coerente con gli altri testi informativi */
}

.slot-punti-categoria span {
  /* Lo span che contiene il numero dei punti */
  font-weight: bold;
  color: #007bff; /* Blu, come altri valori importanti (es. classifica VSR) */
}
.slot-info p,
.gare-slot p,
#lista-suggerimenti-strategici-slot li {
  /* Rimosso #suggerimenti-slot-vsr ul li, #scadenze-container ul li */
  font-size: 0.9em;
  margin-bottom: 5px;
}
.warning-triangle {
  font-size: 1.2em;
  margin-right: 3px;
}

.warning-triangle.calendar-icon {
  font-size: 1.3em;
  color: #007bff;
}

.text-danger {
  color: #c82333 !important;
}

/* Stili per il Monitoraggio Scadenze (ripristinati nel caso siano usati in Strategia o altrove) */
/* Se queste classi non sono usate in Strategia, possiamo rimuoverle di nuovo in seguito */
.scadenza-urgente {
  /* Riferimento generico, non solo #scadenze-container ul li */
  color: #000000;
  background-color: #ffe5b4; /* Sfondo Pesca Chiaro (PeachPuff) */
  font-weight: bold;
  border-left: 5px solid #dc3545;
  padding-left: 10px; /* Assicurati che il padding sia applicato al li se la classe è sul li */
}

/* Stile per le scadenze in preavviso (nei 3 mesi) ma non ancora urgenti (non nell'ultimo mese) */
.scadenza-in-preavviso-non-urgente {
  /* Riferimento generico */
  background-color: #e9f7ef; /* Verdino chiaro (usato per slot con opportunità) */
}

.gare-slot .gara-dettaglio {
  padding: 5px;
  margin-bottom: 5px;
  border-left: 3px solid #007bff;
  background-color: #f8f9fa;
  font-size: 0.85em;
}

/* Stili per il contenitore della lista gare */
.gare-slot {
  flex-grow: 1; /* Per HC, Liv1, Liv2: fa espandere questo box per riempire lo spazio verticale rimanente */
  flex-basis: 0;
  min-height: 0;
}

/* Modificato per mantenere solo #lista-suggerimenti-strategici-slot se ancora usato altrove (es. Strategia) */
#lista-suggerimenti-strategici-slot {
  /* Rimosso #suggerimenti-slot-vsr ul, #scadenze-container ul */
  list-style-type: none;
  padding-left: 0; /* Rimosso max-width: 650px; */
  /* max-width: 650px; */ /* Rimosso per ripristinare la larghezza completa */
}

.gare-slot > ul {
  list-style-type: none;
  padding-left: 0;
  margin-top: 5px;
  margin-bottom: 0;
}

/* Modificato per mantenere solo #lista-suggerimenti-strategici-slot li */
#lista-suggerimenti-strategici-slot li {
  /* Rimosso #suggerimenti-slot-vsr ul li, #scadenze-container ul li */
  padding: 8px;
  /* border-bottom: 1px dashed #e0e0e0; */ /* Rimosso il trattino */
}
#lista-suggerimenti-strategici-slot li:last-child {
  /* Rimosso #suggerimenti-slot-vsr ul li:last-child, #scadenze-container ul li:last-child */
  border-bottom: none;
}

.no-data {
  font-style: italic;
  color: #888;
}

/* Stili per il layout a due colonne nella sezione Strategia */
#strategia-layout-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 20px;
  align-items: stretch; /* Assicura che le colonne abbiano la stessa altezza */
}

#strategia-grafico-box {
  flex: 1;
  min-width: 300px;
  padding: 15px;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  /* display: flex; Rimosso per risolvere il problema di allineamento */
}

#strategia-contenuto-box {
  flex: 2;
  min-width: 300px;
  display: flex; /* Aggiunto per risolvere il conflitto di layout */
  flex-direction: column; /* Impila gli elementi interni verticalmente */
}

/* Stili per la sezione "Cosa è Cambiato?" */
.strategia-header-con-pulsante {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px; /* Spazio prima del contenuto sottostante */
}

.strategia-header-con-pulsante h2 {
  margin-bottom: 0; /* Rimuove il margine dal titolo h2 */
}

.toggle-summary-btn {
  padding: 6px 12px;
  font-size: 0.85em;
  background-color: #6c757d; /* Grigio (Bootstrap 'secondary') */
  color: white;
  border: 1px solid #6c757d;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.toggle-summary-btn:hover {
  background-color: #5a6268; /* Grigio più scuro */
}

/* ----- INIZIO MODIFICHE PER GRAFICO TORTA STRATEGIA E SPIEGAZIONE ----- */
#grafico-torta-container h2 {
  text-align: center;
  margin-top: 5px;
  margin-bottom: 8px;
  font-size: 1.3em;
  color: #007bff;
  flex-shrink: 0;
  padding-bottom: 5px;
  border-bottom: 1px solid #eee;
}

#grafico-torta-container {
  max-width: 100%;
  position: relative;
  /* height: 750px; */ /* Rimosso per permettere al contenitore di adattarsi */
}

.canvas-wrapper-strategia {
  position: relative;
  height: 280px;
  width: 100%;
  flex-shrink: 0;
}

.canvas-wrapper-strategia canvas {
  display: block;
}

#grafico-torta-container .spiegazione-grafico {
  font-size: 0.85em;
  color: #555;
  margin-top: 10px;
  padding: 10px;
  background-color: #f8f9fa;
  border-radius: 4px;
  border: 1px solid #e9ecef;
  overflow-y: auto;
  /* flex-grow: 1; */ /* Rimosso per risolvere il problema di allineamento */
  flex-shrink: 1;
  min-height: 0;
}

/* Stile per il contenitore del riepilogo eventi passati */
.summary-content {
  background-color: #f0f8ff; /* AliceBlue, un azzurrino molto chiaro */
  border: 1px solid #d6eaf8; /* Bordo azzurro leggermente più scuro */
  border-radius: 5px;
  padding: 15px;
  margin-bottom: 20px; /* Spazio prima del monitoraggio scadenze future */
}

.summary-content ul {
  list-style-type: none;
  padding-left: 0;
}
/* ----- FINE MODIFICHE PER GRAFICO TORTA STRATEGIA E SPIEGAZIONE ----- */

/* MEDIA QUERY */
@media (max-width: 1200px) {
  .view-section {
    margin: 0 15px 15px 15px;
    padding: 15px;
  }
  nav {
    padding: 8px 15px;
  }
  h1 {
    font-size: 1.6em;
  }
  h2 {
    font-size: 1.2em;
  }

  #container-principale-calcolatrice {
    gap: 20px;
  }
  #container-principale-calcolatrice > div:first-child {
    min-width: 450px;
  }
  #istruzioni {
    min-width: 300px;
    padding: 15px;
  }

  th,
  td {
    padding: 6px 8px;
    font-size: 0.85em;
  }
  #tabella2 input,
  #tabella3 input,
  #tabella3 select {
    padding: 5px;
    font-size: 0.9em;
  }

  #form-aggiungi-gara {
    gap: 10px 15px;
    padding: 10px 15px;
  }
  #form-aggiungi-gara input,
  #form-aggiungi-gara select {
    padding: 6px;
    font-size: 0.85em;
  }
  #form-aggiungi-gara select {
    width: 160px;
  }
  #form-aggiungi-gara input[type="number"] {
    width: 80px;
  }
}

@media (max-width: 992px) {
  nav {
    flex-wrap: wrap;
  }
  .dashboard-item {
    flex-direction: column;
    align-items: flex-start;
  }
  .dashboard-item label {
    width: auto;
    margin-bottom: 5px;
  }

  #container-principale-calcolatrice {
    flex-direction: column;
  }
  #container-principale-calcolatrice > div:first-child,
  #istruzioni {
    min-width: 100%;
  }

  #container-principale-vsr {
    flex-direction: column;
  }
  #contenuto-vsr,
  #istruzioni-vsr-box {
    min-width: 100%;
  }

  #strategia-layout-container {
    flex-direction: column;
  }
  .dashboard-layout {
    flex-direction: column; /* Colonne impilate su schermi più piccoli */
  }
  .dashboard-column-left,
  .dashboard-column-right {
    flex-basis: 100%; /* Ogni colonna occupa tutta la larghezza */
  }
  #strategia-grafico-box,
  #strategia-contenuto-box {
    min-width: 100%;
  }

  #form-aggiungi-gara {
    flex-direction: column;
    align-items: stretch;
  }
  #form-aggiungi-gara label {
    margin-bottom: 3px;
  }
  #form-aggiungi-gara input,
  #form-aggiungi-gara select,
  #form-aggiungi-gara button {
    width: 100%;
    box-sizing: border-box;
  }
  #form-aggiungi-gara button {
    margin-left: 0;
    margin-top: 10px;
  }
}

@media (max-width: 768px) {
  .view-section {
    margin: 0 10px 10px 10px;
    padding: 10px;
  }
  nav {
    padding: 8px 10px;
  }
  .nav-button {
    font-size: 0.8em;
    padding: 6px 10px;
  }
  h1 {
    font-size: 1.4em;
    margin-bottom: 15px;
  }
  h2 {
    font-size: 1.1em;
    margin-bottom: 10px;
  }

  th,
  td {
    padding: 4px 6px;
    font-size: 0.8em;
  }
  #tabella2 input,
  #tabella3 input,
  #tabella3 select {
    padding: 4px;
    font-size: 0.85em;
  }

  #istruzioni p {
    font-size: 0.85em;
    line-height: 1.3;
  }

  #form-aggiungi-gara {
    padding: 10px;
  }
  #form-aggiungi-gara label {
    font-size: 0.85em;
  }
  #form-aggiungi-gara input,
  #form-aggiungi-gara select {
    padding: 5px;
    font-size: 0.85em;
  }
  #tabella-gare-salvate th,
  #tabella-gare-salvate td {
    font-size: 0.75em;
    padding: 4px;
  }
  #tabella-gare-salvate button.delete-btn {
    padding: 2px 6px;
    font-size: 0.8em;
  }
}

.autore-credits {
  text-align: right;
  margin-top: 5px; /* Margine superiore ridotto notevolmente */
  font-size: 0.8em;
  color: #6c757d;
}

#input-bonus-totale {
  width: 90%;
  text-align: center;
}
.riga-in-modifica td {
  background-color: #e6e0f8 !important;
  font-weight: bold;
}

.separatore-analisi {
  border: 0;
  height: 1px;
  background-image: linear-gradient(
    to right,
    rgba(0, 0, 0, 0),
    rgba(0, 0, 0, 0.25),
    rgba(0, 0, 0, 0)
  );
  margin: 30px 0;
}

/* Stile per il separatore orizzontale all'interno delle card di analisi */
.hr-card-separator {
  border: 0;
  height: 1px;
  background-color: #dee2e6; /* Un grigio chiaro, coerente con i bordi */
  margin: 15px 0; /* Spazio sopra e sotto la linea */
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

#istruzioni-vsr-box {
  max-height: 682px;
  overflow-y: auto;
  padding-right: 10px;
}

/* === Modifiche specifiche per la sezione Analisi === */

/* Nasconde la linea separatrice specifica dopo la panoramica slot VSR nella pagina Analisi */
#analisi-view
  .analisi-container
  > #panoramica-slot-vsr
  + hr.separatore-analisi {
  display: none;
}

/* Stile specifico per la card del grafico radar nella sezione Analisi.
   Usa la classe .slot-categoria per la larghezza corretta, ma sovrascrive
   lo stile per ripristinare l'aspetto della .dashboard-card e renderla quadrata. */
#grafico-radar-card-analisi {
  background-color: rgba(
    238,
    244,
    248,
    0.85
  ); /* Ripristina lo sfondo semi-trasparente */
  padding: 8px 15px; /* Ripristina il padding originale */
  aspect-ratio: 1 / 1; /* Forza il contenitore ad essere un quadrato (altezza = larghezza) */
  display: flex;
  flex-direction: column;
}

/* Ripristina lo stile del titolo per la card del grafico radar */
#grafico-radar-card-analisi h3 {
  text-align: center; /* Centra il titolo */
  color: #0056b3; /* Ripristina il colore blu */
  border-bottom: none; /* Rimuove il bordo che eredita da .slot-categoria h3 */
  padding-bottom: 0;
}

/* Fa in modo che il contenitore del canvas si espanda per riempire lo spazio disponibile */
#grafico-radar-container-analisi {
  position: relative;
  flex-grow: 1; /* Occupa tutto lo spazio verticale rimanente */
}

/* Contenitore per descrizione e legenda nella sezione Analisi */
.descrizione-e-legenda-container {
  display: flex;
  justify-content: space-between; /* Spinge la descrizione a sinistra e la legenda a destra */
  align-items: center; /* Allinea verticalmente gli elementi */
  margin-bottom: 15px; /* Spazio prima del contenuto degli slot */
}

/* Stili per la Legenda nella Sezione Analisi */
.legenda-analisi {
  /* float: right; Rimosso perché ora è gestito da flexbox del genitore */
  /* max-width: 320px; Rimosso o aumentato per permettere una singola riga */
  background-color: #f8f9fa;
  border: 1px solid #dee2e6;
  border-radius: 0.25rem;
  padding: 0.4rem 0.6rem; /* Padding ridotto per compattezza */
  margin-left: 1rem; /* Spazio dalla descrizione */
  /* margin-bottom: 1rem; Rimosso, gestito dal contenitore genitore */
  font-size: 0.7em; /* Testo più piccolo */
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  display: flex; /* Abilita flexbox per gli item interni */
  flex-wrap: nowrap; /* Forza gli item su una singola riga */
  /* justify-content: flex-end; Non più necessario se flex-wrap è nowrap e il box si adatta */
  gap: 0.6rem; /* Spazio tra gli item (sia orizzontale che verticale se vanno a capo) */
  white-space: nowrap; /* Assicura che il testo interno non vada a capo */
  align-self: center; /* Allinea la legenda verticalmente al centro del suo contenitore flex */
}

/* Rimuoviamo gli stili per h4 e legenda-sottosezione che non esistono più */
/* .legenda-analisi h4 { ... } */
/* .legenda-sottosezione:not(:last-child) { ... } */

.legenda-item {
  display: flex;
  align-items: center;
  color: #495057;
  /* margin-bottom e margin-right non sono più necessari grazie a 'gap' sul parent */
}

.legenda-item .colore-campione {
  display: inline-block;
  width: 10px; /* Campione di colore più piccolo */
  height: 10px; /* Campione di colore più piccolo */
  margin-right: 0.3rem; /* Spazio ridotto tra campione e testo */
  border: 1px solid #adb5bd;
  flex-shrink: 0;
}

/* Avvicina la scritta autore al contenuto precedente specificamente nella pagina Analisi */
#analisi-view > p#autore-analisi.autore-credits {
  margin-top: 10px;
}

/* Stili per la nuova barra dei punti VSR per fascia */
.stacked-bar-label {
  font-size: 0.85em;
  color: #495057;
  margin-top: 12px; /* Spazio sopra l'etichetta */
  margin-bottom: 4px; /* Spazio tra etichetta e barra */
}

.stacked-points-bar-container {
  width: 100%;
  height: 14px; /* Ridotta l'altezza, uguale alla barra di progresso slot */
  background-color: #e9ecef; /* Sfondo base per la parte non riempita */
  border: 1px solid #ced4da;
  border-radius: 4px;
  display: flex; /* Per allineare i segmenti orizzontalmente */
  overflow: hidden; /* Per i bordi arrotondati */
  margin-bottom: 10px; /* Spazio sotto la barra */
}

.points-bar-segment {
  height: 100%;
  transition: width 0.5s ease-in-out;
  display: flex; /* Per centrare eventuale testo (non usato ora) */
  align-items: center;
  justify-content: center;
  font-size: 0.7em;
  color: white;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
}

.points-bar-100 {
  background-color: var(--colore-punti-100);
}
.points-bar-50 {
  background-color: var(--colore-punti-50);
}
.points-bar-empty {
  background-color: var(--colore-punti-vuoti);
}
/* .points-bar-empty non necessita di un colore di sfondo specifico,
   perché il background del container (.stacked-points-bar-container) farà da sfondo per la parte vuota.
   Se si volesse un colore diverso per la parte vuota, si potrebbe aggiungere qui. */

/* Stili per le note a piè di pagina nella Dashboard */
#dashboard-footer-notes {
  position: relative; /* Cambiato da fixed a relative */
  bottom: auto; /* Rimosso il posizionamento bottom */
  left: auto; /* Rimosso il posizionamento left */
  transform: none; /* Rimossa la trasformazione */
  padding: 4px 12px;
  margin: 10px auto; /* Aggiunto margine automatico */
  font-size: 0.7em; /* Ridotto ulteriormente */
  color: #6c757d;
  text-align: center;
  background-color: rgba(255, 255, 255, 0.95);
  border: 1px solid #e9ecef;
  border-radius: 4px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
  z-index: 1; /* Ridotto z-index */
  max-width: 95%; /* Aumentato da 80% a 95% */
  width: auto;
  white-space: normal; /* Permette il wrapping del testo */
}

/* Stili per la Finestra Modale Elenco Regate */
.modal {
  display: none; /* Nascosto di default */
  position: fixed; /* Rimane fisso durante lo scroll */
  z-index: 1050; /* Sopra la maggior parte degli altri elementi, ma sotto eventuali altri modali di sistema se necessario */
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto; /* Abilita lo scroll se il contenuto della modale è più grande della viewport */
  background-color: rgba(0, 0, 0, 0.5); /* Sfondo semi-trasparente */
}
/* Stili per la nuova finestra modale di notifica VSR */
#vsr-change-modal.modal {
  display: flex; /* Usa flexbox per centrare il contenuto */
  align-items: center; /* Centra verticalmente */
  justify-content: center; /* Centra orizzontalmente */
}

#vsr-change-modal .modal-content {
  background-color: #fefefe; /* Bianco puro per la modale di avviso */
  margin: auto; /* Centra automaticamente */
  padding: 30px; /* Più padding per un aspetto più spazioso */
  border: 1px solid #888;
  width: 90%; /* Larghezza della modale */
  max-width: 500px; /* Larghezza massima per non essere troppo grande su schermi ampi */
  border-radius: 8px;
  box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
  animation-name: animatetop;
  animation-duration: 0.4s;
  text-align: center; /* Centra il testo all'interno della modale */
  position: relative; /* Per posizionare il pulsante di chiusura */
}

/* Animazione per la modale */
@keyframes animatetop {
  from {
    top: -300px;
    opacity: 0;
  }
  to {
    top: 0;
    opacity: 1;
  }
}

#vsr-change-modal .modal-content h2 {
  color: #dc3545; /* Rosso per il titolo di attenzione */
  margin-top: 0;
  margin-bottom: 15px;
  font-size: 1.5em;
  border-bottom: none; /* Rimuovi il bordo inferiore */
  padding-bottom: 0;
}

#vsr-change-modal .modal-content p {
  font-size: 1.1em;
  line-height: 1.5;
  margin-bottom: 10px;
  color: #333;
}

#vsr-change-modal .modal-content p strong {
  color: #007bff; /* Blu per i punteggi in grassetto */
}

#vsr-change-modal .modal-footer {
  margin-top: 20px;
  display: flex;
  justify-content: center; /* Centra i pulsanti */
  gap: 15px; /* Spazio tra i pulsanti */
}

#vsr-change-modal .modal-footer button {
  padding: 10px 20px;
  font-size: 1em;
  cursor: pointer;
  border-radius: 5px;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

/* Stili per il pulsante di chiusura della modale (la 'x' in alto a destra) */

.modal-content {
  background-color: #eef4f8; /* Sfondo azzurrino molto chiaro */
  margin: 10% auto; /* 10% dall'alto e centrato orizzontalmente */
  padding: 25px;
  border: 1px solid #b8cdda; /* Bordo leggermente più scuro dell'azzurrino */
  border-top: 5px solid #007bff; /* Bordo superiore blu per un accento di colore */
  width: 80%; /* Larghezza della modale */
  max-width: 750px; /* Leggermente aumentata la larghezza massima */
  border-radius: 8px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
  position: relative;
  display: flex;
  flex-direction: column;
}

.modal-content h2 {
  margin-top: 0;
  margin-bottom: 15px;
  color: #0056b3; /* Blu più scuro per il titolo, per maggiore contrasto */
  border-bottom: 1px solid #eee;
  padding-bottom: 10px;
}

.close-button {
  color: #aaa;
  position: absolute;
  top: 10px;
  right: 20px;
  font-size: 28px;
  font-weight: bold;
  line-height: 1;
}

.close-button:hover,
.close-button:focus {
  color: black;
  text-decoration: none;
  cursor: pointer;
}

.modal-table-container {
  max-height: 400px; /* Altezza massima per la tabella, poi scroll */
  overflow-y: auto; /* Scroll verticale se la tabella eccede */
  margin-top: 10px;
}

/* Stili per la sezione Strategia - Monitoraggio Scadenze per compattare il testo */
#strategia-view #monitoraggio-scadenze h4 {
  font-size: 1.05em; /* Riduce la dimensione del titolo h4, rendendolo più vicino a un paragrafo normale */
  margin-top: 0.8em; /* Leggera riduzione del margine superiore se necessario */
  margin-bottom: 0.4em; /* Riduce lo spazio sotto il titolo h4 */
}

#strategia-view #monitoraggio-scadenze ul li,
#strategia-view #monitoraggio-scadenze ul li.no-data {
  font-size: 0.9em; /* Riduce la dimensione del testo degli elementi della lista */
  line-height: 1.4; /* Mantiene una buona leggibilità con il font ridotto */
  margin-bottom: 0.3em; /* Leggero spazio tra gli elementi della lista */
  padding-left: 5px; /* Leggero padding se gli elementi della lista sembrano troppo attaccati al bordo */
}

#strategia-view #monitoraggio-scadenze .scadenze-categoria {
  margin-bottom: 0.5em; /* Riduce lo spazio tra le categorie di scadenze */
}

/* Stile per la dicitura "Non contribuisce al VSR attuale" */
.non-contributing-suffix {
  color: #212529; /* Testo nero per massimo contrasto su sfondo chiaro */
  font-weight: bold; /* Grassetto per evidenziare */
  font-size: 0.9em; /* Leggermente più piccolo del testo principale dell'elemento li */
  margin-left: 3px; /* Piccolo spazio dal testo precedente */
  background-color: #e9ecef; /* Sfondo grigio chiaro (simile a Bootstrap 'light') */
  padding: 2px 5px; /* Padding per dare respiro allo sfondo */
  border-radius: 3px; /* Bordi arrotondati per effetto etichetta */
  border: 1px solid #ced4da; /* Bordo sottile per definire meglio l'etichetta */
}

/* Stile per evidenziare l'obiettivo di classifica nella sezione Analisi */
.target-rank-highlight {
  background-color: #cfe2ff; /* Azzurrino (Bootstrap 'info-subtle') */
  color: #052c65; /* Testo blu scuro per contrasto */
  font-weight: bold;
  padding: 2px 6px;
  border-radius: 4px;
  display: inline-block; /* Necessario per applicare padding e background correttamente */
  margin-left: 5px; /* Piccolo spazio dall'etichetta a sinistra */
  font-style: normal; /* Assicura che non sia in corsivo se ereditato */
}
