body {
  margin: 0;
  font-family: Arial, sans-serif;
  background: #f4f4f4;
}

header {
  background-color: #3a4d3f;
  color: white;
  padding: 20px;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}

.container,
.container.login-container {
  display: flex;
  justify-content: center;
  align-items: center;
  height: calc(100vh - 80px);
  padding: 20px;
}

.login-box {
  background: #fff;
  padding: 30px;
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
  width: 100%;
  max-width: 500px;
}

.login-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  text-align: center;
  margin-bottom: 20px;
  gap: 10px;
}

.login-header h1 {
  flex-grow: 1;
  font-size: 1.1rem;
  font-weight: bold;
  margin: 0;
}

.logo {
  width: 50px;
  height: auto;
  object-fit: contain;
  pointer-events: none;
  user-select: none;
}

.logo-protector {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 50px;
  background-color: transparent;
  z-index: 10;
}

.left-protector {
  left: 0;
}

.right-protector {
  right: 0;
}

form {
  display: flex;
  flex-direction: column;
}

input[type="text"],
input[type="password"],
input[type="email"] {
  padding: 10px;
  margin-bottom: 15px;
  border: 1px solid #ccc;
  border-radius: 5px;
  width: 100%; /* <--- AGGIUNGI QUESTA RIGA */
  box-sizing: border-box;
}

button[type="submit"],
#chat-form button {
  padding: 10px;
  background-color: #3e5244;
  color: #fff;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  width: 100%; /* <--- AGGIUNGI QUESTA RIGA */
  box-sizing: border-box; /* <--- AGGIUNGI QUESTA RIGA */
}

button[type="submit"]:hover,
#chat-form button:hover {
  background-color: #314135;
}

.error {
  color: red;
  margin-bottom: 10px;
  font-weight: bold;
  text-align: center;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px;
  padding: 40px;
  max-width: 1000px;
  margin: auto;
}

.card {
  background-color: white;
  padding: 30px;
  border-radius: 10px;
  text-align: center;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
  transition: 0.2s ease-in-out;
  cursor: pointer;
  font-weight: bold;
  color: #3a4d3f;
}

.card:hover {
  transform: scale(1.05);
  background-color: #e8eee8;
}

.footer {
  text-align: center;
  margin-top: 20px;
}

.chat-ai-title {
  text-align: center;
  font-size: 22px;
  margin: 0;
  padding-bottom: 10px;
  color: #3d4d3f;
  font-weight: bold;
}

.chat-box {
  background-color: #fff;
  width: 100%;
  max-width: 600px;
  padding: 30px;
  border-radius: 10px;
  box-shadow: 0 0 15px rgba(0,0,0,0.1);
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: stretch;
}

#chat-window {
  height: 300px;
  overflow-y: auto;
  border: 1px solid #ccc;
  padding: 10px;
  border-radius: 5px;
  background-color: #fafafa;
}

#chat-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#chat-form input[type="text"] {
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
}

#salvato {
  position: fixed;
  top: 20px;
  right: 20px;
  background: #4caf50;
  color: white;
  padding: 10px 20px;
  border-radius: 10px;
  font-weight: bold;
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 1000;
}
#salvato.mostra {
  opacity: 1;
}

/* --- Stili per Itinerari.php (Aggiornati per aspetto Card) --- */

/* Wrapper principale per centrare il contenuto delle pagine */
.main-content-wrapper {
  display: flex;
  justify-content: center;
  align-items: flex-start; /* Allinea in alto, non al centro della viewport */
  min-height: calc(100vh - 80px - 60px); /* Altezza minima (header + footer), si adatta al contenuto */
  padding: 20px;
  box-sizing: border-box;
}

/* Contenitore generale per la pagina Itinerari (simile a login-box ma più largo) */
.content-box {
  background: #fff;
  padding: 30px; /* Aumenta il padding se vuoi più spazio interno */
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
  width: 100%;
  max-width: 1000px; /* Larghezza massima aumentata per contenere più card */
  margin-top: 20px;
  margin-bottom: 20px;
}

.section-title {
  text-align: center;
  color: #3d4d3f;
  margin-bottom: 30px; /* Più spazio sotto il titolo */
  font-size: 2rem; /* Rendi il titolo più grande e evidente */
  font-weight: bold;
}

.no-itineraries {
  text-align: center;
  color: #555;
  margin-bottom: 20px;
}

/* Griglia per gli itinerari (molto simile a .grid della dashboard) */
.itinerary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); /* Minimo 200px, si adatta */
  gap: 20px; /* Spazio tra le card */
  padding: 0; /* Rimuovi padding se c'era per allineamento */
  margin-bottom: 30px; /* Spazio sotto la griglia prima del separatore */
}

/* Stile per le singole card degli itinerari (ispirato a .card della dashboard) */
.itinerary-card {
  background-color: white; /* Sfondo bianco come la dashboard card */
  padding: 25px; /* Padding interno */
  border-radius: 10px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1); /* Ombreggiatura più pronunciata */
  transition: transform 0.2s ease-in-out, background-color 0.2s ease-in-out;
  cursor: pointer; /* Indice che è cliccabile, anche se i link sono interni */

  display: flex; /* Flexbox per allineare contenuto */
  flex-direction: column; /* Impila titolo e azioni */
  justify-content: space-between; /* Spinge azioni in basso se la card è più alta */
  align-items: center; /* Centra orizzontalmente il contenuto */
  min-height: 120px; /* Altezza minima per le card */
}

.itinerary-card:hover {
  transform: translateY(-5px); /* Leggero sollevamento */
  background-color: #e8eee8; /* Cambia colore al hover */
  box-shadow: 0 5px 15px rgba(0,0,0,0.15); /* Ombreggiatura più forte al hover */
}

.itinerary-card h3 {
  margin-top: 0;
  margin-bottom: 15px; /* Spazio sotto il titolo della card */
  color: #3a4d3f;
  font-size: 1.3rem; /* Dimensione del titolo leggermente più grande */
  font-weight: bold;
  word-break: break-word; /* Rompi parole lunghe se necessario */
}

.itinerary-actions {
  display: flex;
  flex-wrap: wrap; /* Permette ai pulsanti di andare a capo */
  justify-content: center; /* Centra i pulsanti */
  gap: 8px; /* Spazio tra i pulsanti */
  margin-top: auto; /* Spinge il blocco azioni verso il basso nella card flex */
}

/* Stile per i pulsanti all'interno delle card */
.itinerary-actions .btn {
  padding: 8px 12px;
  background-color: #3e5244;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  transition: background-color 0.2s ease, transform 0.1s ease;
  font-size: 0.85rem; /* Riduci leggermente la dimensione del font per i bottoni */
  border: none;
  cursor: pointer;
}

.itinerary-actions .btn:hover {
  background-color: #314135;
  transform: translateY(-1px); /* Piccolo effetto al click/hover */
}

.itinerary-actions .btn-danger {
  background-color: #dc3545; /* Rosso per eliminare */
}

.itinerary-actions .btn-danger:hover {
  background-color: #c82333;
}

/* Separatore */
.section-divider {
  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: 40px 0; /* Spazio sopra e sotto il separatore */
}

/* Form di creazione */
.create-itinerary-form {
  display: flex;
  flex-direction: column;
  align-items: center; /* Centra gli elementi del form */
  gap: 15px;
  padding: 25px;
  border: 1px dashed #cfd8dc; /* Bordo tratteggiato più morbido */
  border-radius: 8px;
  background-color: #fcfdfe; /* Sfondo leggermente più chiaro */
  max-width: 600px; /* Larghezza maggiore per il form */
  margin: 30px auto 0; /* Centra il form e aggiunge margine sopra */
}

.create-itinerary-form label {
  font-weight: bold;
  color: #3a4d3f;
  text-align: center; /* Centra il testo del label */
  width: 100%; /* Occupa tutta la larghezza per centrare bene */
}

.create-itinerary-form input[type="text"] {
  padding: 12px; /* Più padding per l'input */
  border: 1px solid #b0bec5; /* Bordo più scuro */
  border-radius: 5px;
  width: 100%;
  max-width: 350px; /* Larghezza massima dell'input */
  box-sizing: border-box;
  font-size: 1rem;
}

.create-itinerary-form button[type="submit"] {
  padding: 12px 25px; /* Più padding per il bottone */
  background-color: #3e5244;
  color: #fff;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-size: 1rem;
  transition: background-color 0.2s ease, transform 0.1s ease;
}

.create-itinerary-form button[type="submit"]:hover {
  background-color: #314135;
  transform: translateY(-1px);
}

/* Piccoli aggiustamenti per il footer */
.footer {
  text-align: center;
  margin-top: 30px; /* Più spazio dal contenuto */
  padding-bottom: 20px; /* Padding sotto */
}

.footer a {
  color: #3e5244;
  text-decoration: none;
  font-weight: bold;
  transition: color 0.2s ease;
}

.footer a:hover {
  color: #2b3a2f;
}

/* Correggi il container generale se sta ancora causando problemi di altezza/margini */
/* Rimuovi questa regola o modifica se hai un .container che non è main-content-wrapper */
.container,
.container.login-container {
  /* display: flex;  */ /* Potrebbe non servire più con main-content-wrapper */
  /* justify-content: center; */
  /* align-items: center; */
  height: auto; /* Lascia che l'altezza sia determinata dal contenuto */
  /* padding: 20px; */
  margin-top: 0; /* Rimuovi eventuali margini che spingono troppo */
  margin-bottom: 0;
}

/* --- Stili Editor.php --- */

/* Wrapper principale per l'intera area dell'editor */
.editor-main-wrapper {
  display: flex;
  flex-direction: column; /* Il titolo va sopra il contenitore delle colonne */
  align-items: center; /* Centra il contenuto orizzontalmente */
  padding: 20px;
  max-width: 1400px; /* Larghezza massima dell'editor */
  margin: 20px auto; /* Centra il wrapper nella pagina */
  background-color: #fff;
  border-radius: 10px;
  box-shadow: 0 0 15px rgba(0,0,0,0.1);
  min-height: calc(100vh - 120px); /* Assicura un'altezza minima per il contenuto */
  box-sizing: border-box;
}

.editor-title {
  text-align: center;
  color: #3d4d3f;
  margin-bottom: 30px;
  font-size: 2.2rem;
  font-weight: bold;
  width: 100%; /* Occupa tutta la larghezza per centrare */
}

/* Contenitore per le due colonne (sidebar + contenuto) */
.editor-container {
  display: flex;
  width: 100%;
  gap: 25px; /* Spazio tra sidebar e contenuto */
  min-height: 600px; /* Altezza minima del contenitore dell'editor */
}

/* Sidebar di sinistra */
.editor-sidebar {
  flex: 0 0 250px; /* Larghezza fissa di 250px, non cresce, non si restringe */
  background-color: #f8f8f8;
  padding: 20px;
  border-radius: 8px;
  box-shadow: inset 0 0 8px rgba(0,0,0,0.05); /* Leggera ombreggiatura interna */
  display: flex;
  flex-direction: column; /* Organizza le sezioni in colonna */
  gap: 25px; /* Spazio tra le sezioni della sidebar */
}

.sidebar-section h3 {
  color: #3a4d3f;
  margin-top: 0;
  margin-bottom: 15px;
  font-size: 1.2rem;
  text-align: center;
}

.sidebar-divider {
  border: 0;
  height: 1px;
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0));
  margin: 10px 0;
}

/* Controlli Pagine */
.page-controls {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center; /* Centra gli elementi */
}

.page-controls .custom-select {
  width: 100%;
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
  background-color: #fff;
  font-size: 1rem;
  box-sizing: border-box; /* Include padding nel width */
}

.page-action-buttons {
  display: flex;
  gap: 10px; /* Spazio tra "Nuova Pagina" e "Elimina" */
  width: 100%;
  justify-content: center; /* Centra i bottoni orizzontalmente */
}

/* Bottoni generali nell'editor */
.btn {
  padding: 10px 15px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-size: 0.95rem;
  transition: background-color 0.2s ease, transform 0.1s ease;
  white-space: nowrap; /* Evita che il testo vada a capo nei bottoni */
}

.btn-sm {
  padding: 8px 12px; /* Pulsanti più piccoli */
  font-size: 0.85rem;
}

.btn-sidebar {
  display: block; /* Ogni bottone sulla sua riga */
  width: 100%;
  background-color: #4CAF50; /* Un verde per l'aggiunta */
  color: white;
  text-align: center;
  margin-bottom: 10px;
}
.btn-sidebar:hover {
  background-color: #45a049;
  transform: translateY(-1px);
}

.btn-danger {
  background-color: #dc3545;
  color: white;
}
.btn-danger:hover {
  background-color: #c82333;
  transform: translateY(-1px);
}

.btn-success {
  background-color: #28a745;
  color: white;
}
.btn-success:hover {
  background-color: #218838;
  transform: translateY(-1px);
}

.btn-block {
  display: block;
  width: 100%;
}


/* Area di contenuto principale (dove si editano i blocchi) */
.editor-content-area {
  flex-grow: 1; /* Occupa tutto lo spazio rimanente */
  background-color: #fff; /* Bianco per l'area di testo */
  padding: 25px;
  border-radius: 8px;
  box-shadow: 0 0 8px rgba(0,0,0,0.08); /* Leggera ombra */
  overflow-y: auto; /* Permette lo scroll se il contenuto è lungo */
}

.blocks-container {
  /* Questo è il div che contiene tutti i blocchi */
  min-height: 500px; /* Assicura un'altezza minima per la visualizzazione */
  border: 1px dashed #e0e0e0; /* Bordo visivo per l'area di lavoro */
  padding: 15px;
  background-color: #fafafa; /* Leggero sfondo per l'area di lavoro */
}


/* --- Stili per i singoli blocchi (esistenti, da migliorare se necessario) --- */
.text-block,
.heading-block,
.image-block {
  position: relative;
  margin-bottom: 15px; /* Spazio tra i blocchi */
  padding: 10px 15px; /* Padding interno */
  background-color: #ffffff;
  border: 1px solid #e0e0e0;
  border-radius: 5px;
  min-height: 40px; /* Altezza minima per i blocchi editabili */
  outline: none; /* Rimuove l'outline predefinito al focus */
}

/* Stile per i blocchi quando in modalità focus/editing */
.text-block.editing,
.heading-block.editing {
  border-color: #3e5244; /* Bordo evidenziato quando in editing */
  box-shadow: 0 0 0 2px rgba(62, 82, 68, 0.2);
}

/* Controlli dei blocchi (Up/Down/Delete) */
.block-controls {
  position: absolute;
  top: 5px; /* Posiziona in alto a destra */
  right: 5px;
  z-index: 10;
  display: flex;
  gap: 5px; /* Spazio tra i pulsanti di controllo */
  opacity: 0; /* Nascosti di default */
  transition: opacity 0.2s ease;
}

.block-item:hover .block-controls,
.block-item.active .block-controls { /* Mostra i controlli quando il blocco è hovered o attivo */
  opacity: 1;
}

.block-controls button {
  background-color: #555;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 4px 8px;
  font-size: 0.8rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.block-controls button:hover {
  background-color: #333;
}

.block-controls .delete-block-btn {
  background-color: #dc3545;
}

.block-controls .delete-block-btn:hover {
  background-color: #c82333;
}


/* Menu opzioni blocco (quello che appare al click sull'icona delle opzioni) */
#blockOptionsMenu {
  position: absolute; /* Sarà posizionato dinamicamente da JS */
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 5px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.15);
  z-index: 1000;
  padding: 10px;
  display: none; /* Nascosto di default */
  flex-direction: column; /* Bottoni in colonna */
  gap: 5px;
  min-width: 150px;
}

#blockOptionsMenu button {
  background: none;
  border: none;
  padding: 8px 12px;
  text-align: left;
  cursor: pointer;
  font-size: 0.9rem;
  color: #333;
  transition: background-color 0.1s ease;
}

#blockOptionsMenu button:hover {
  background-color: #f0f0f0;
}

#blockOptionsMenu .btn-danger {
  background-color: #dc3545;
  color: white;
  margin-top: 5px;
}

#blockOptionsMenu .btn-danger:hover {
  background-color: #c82333;
}


/* Toolbar di formattazione (quella che appare sopra il testo selezionato) */
#formatToolbar {
    display: flex; /* Rendi i bottoni in riga */
    flex-wrap: wrap; /* Vai a capo se non c'è spazio */
    justify-content: center; /* Centra i bottoni */
    gap: 5px; /* Spazio tra i bottoni */
    margin-bottom: 20px;
    padding: 10px;
    background-color: #eee;
    border-radius: 5px;
    border: 1px solid #ccc;
}

.btn-toolbar {
    padding: 6px 10px;
    background-color: #666; /* Colore più neutro per la toolbar */
    color: white;
    font-size: 0.85rem;
}

.btn-toolbar:hover {
    background-color: #555;
}

/* Stili per l'upload di immagini */
.image-upload-area {
  margin-top: 15px;
  padding: 15px;
  border: 2px dashed #a0a0a0;
  border-radius: 8px;
  text-align: center;
  background-color: #f5f5f5;
  cursor: pointer;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.image-upload-area:hover {
  border-color: #3e5244;
  background-color: #e8eee8;
}

.image-upload-area p {
  margin: 0;
  color: #666;
  font-size: 0.95rem;
}

.image-upload-preview img {
    max-width: 100%;
    height: auto;
    border-radius: 5px;
    margin-top: 10px;
    display: block; /* Per rimuovere spazio sotto l'immagine */
    margin-left: auto;
    margin-right: auto;
}

.image-list-dropdown {
    width: 100%;
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    margin-top: 10px;
}

/* Per i pulsanti specifici dell'immagine (upload, seleziona esistente, rimuovi) */
.image-block .image-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin-top: 10px;
}

.image-block .image-buttons .btn {
    flex-grow: 1; /* Permette ai bottoni di espandersi */
    max-width: 180px; /* Limita la larghezza massima */
}

/* Media Queries per rendere il layout responsive su schermi piccoli */
@media (max-width: 768px) {
  .editor-container {
    flex-direction: column; /* Impila sidebar e contenuto su schermi piccoli */
    gap: 20px;
  }

  .editor-sidebar {
    flex: none; /* Rimuovi larghezza fissa */
    width: 100%; /* Occupano tutta la larghezza */
  }

  .editor-main-wrapper {
      padding: 10px;
      margin: 10px auto;
  }

  .editor-title {
      font-size: 1.8rem;
      margin-bottom: 20px;
  }

  .content-box {
      padding: 20px;
  }
}