/* =========================================
   VARIABILI GLOBALI E SETUP
   ========================================= */
:root {
  --lime-crosstrik: #C6FF00; /* Verde Lime acceso */
  --lime-hover: #AEEA00;     /* Verde Lime leggermente più scuro */
  --nero-crosstrik: #0a0a0a; /* Nero profondissimo per gli sfondi base */
  --grigio-scuro: #181818;   /* Grigio molto scuro per le card */
  --grigio-medio: #2a2a2a;   /* Grigio di transizione per i gradienti */
  --testo-chiaro: #f4f4f4;   /* Bianco sporco per non affaticare la vista */
  --testo-grigio: #aaaaaa;   /* Grigio per i testi secondari/descrizioni */
  --bianco: #ffffff;
}

body {
  font-family: "Roboto", sans-serif;
  background-color: var(--bianco); /* Sfondo generale scuro */
  color: var(--nero-crosstrik);
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6,
.hero-titolo, .titolo-sezione,
.titolo-corso, .nome-coach {
  font-family: "Oswald", sans-serif;
  text-transform: uppercase;
  margin-bottom: 0;
  color: var(--lime-hover);
} 
p{
   color:var(--nero-crosstrik);
}

/* =========================================
   NAVBAR E MENU (Responsive)
   ========================================= */
.navbar-custom {
  background-color: var(--nero-crosstrik) !important;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.8); 
}

.logo-img {
  max-width: 120px;
  height: auto;
  max-height: 150px;
  transition: transform 0.3s ease;
}

.link-item a {
  font-family: "Oswald", sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 1px;
  position: relative;
  transition: color 0.3s ease;
  white-space: nowrap; 
  color: var(--bianco) !important; /* Testo chiaro di base */
}

.link-item a:hover {
  color: var(--lime-hover) !important; /* Lime al passaggio del mouse */
}

.link-evidenziato{
   color:var(--lime-crosstrik)!important;
}

.navbar-toggler:focus {
  box-shadow: none;
  border-color: var(--lime-crosstrik);
}

@media (min-width: 992px) {
  .link-item a::after {
    content: "";
    position: absolute;
    width: 0;
    height: 3px; 
    bottom: -2px;
    left: 50%; 
    transform: translateX(-50%);
    background-color: var(--lime-crosstrik);
    transition: width 0.3s ease;
  }

  .link-item a:hover::after {
    width: 80%; 
  }
}

/* =========================================
   HERO SECTION
   ========================================= */
.hero-custom {
  position: relative;
  height: 80vh; 
  max-height: 600px;
  overflow: hidden;
  color: var(--bianco);
  text-align: center;
  border-radius: 0px 0px 20px 20px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.8);
}

.hero-media {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.hero-media img,
.hero-media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, rgba(10, 10, 10, 0.5), rgba(10, 10, 10, 0.95));
  z-index: 2;
}

.hero-titolo {
  font-size: 4.5rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-shadow: 2px 2px 15px rgba(0, 0, 0, 0.8);
}

.hero-sottotitolo {
  font-size: 1.8rem;
  color: var(--lime-crosstrik);
  font-weight: 700;
  text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.9);
}

.hero-testo {
  font-size: 1.2rem;
  font-weight: 300;
  max-width: 600px;
  margin: 0 auto;
  color: var(--testo-chiaro);
}

/* =========================================
   BOTTONI GLOBALI
   ========================================= */
.bottone,
.btn-leggi {
  background: linear-gradient(135deg, var(--lime-crosstrik), var(--lime-hover));
  color: var(--nero-crosstrik) !important; 
  border: none;
  border-radius: 30px;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 12px 35px;
  text-decoration: none;
  display: inline-block;
  box-shadow: 0 4px 15px rgba(198, 255, 0, 0.2);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  cursor: pointer;
}

.bottone:hover,
.btn-leggi:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(198, 255, 0, 0.4);
  background: linear-gradient(135deg, var(--lime-hover), var(--lime-crosstrik));
}

.btn-leggi {
  font-size: 0.9rem;
  padding: 10px 24px;
  margin-top: 15px;
}

/* =========================================
   SEZIONI GENERICHE E TITOLI
   ========================================= */
.sezione-custom {
  background-color: transparent;
}

.titolo-sezione {
  font-size: 2.5rem;
  text-align: center;
  position: relative;
  padding-bottom: 15px;
  margin-bottom: 30px;
}

.titolo-sezione::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 4px;
  background: linear-gradient(90deg, transparent, var(--lime-crosstrik), transparent); /* Dettaglio lime sfumato */
  border-radius: 2px;
} 

/* =========================================
   CARDS CONDIVISE (Struttura base)
   ========================================= */
.card-corso,
.card-coach,
.card-prezzo,
.box-orari,
.iframe-box {
  /* Questo è il cuore del nuovo design: un gradiente scuro molto elegante */
  background: linear-gradient(145deg, var(--grigio-medio) 0%, var(--nero-crosstrik) 100%);
  border: 1px solid #333333; /* Bordo sottilissimo per dare profondità */
  border-radius: 15px;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  display: flex;
  flex-direction: column;
}

.card-corso img,
.foto-coach {
  width: 100%;
  height: 250px;
  object-fit: cover;
  border-radius: 14px 14px 0 0; /* Arrotonda solo sopra */
}

/* =========================================
   CARD CORSI
   ========================================= */
.card-corso {
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.5);
}

.card-corso:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 30px rgba(198, 255, 0, 0.05); /* Leggero alone lime */
  border-color: #444;
}

.titolo-corso {
  font-size: 1.8rem;x
  color: var(--testo-chiaro);
}

.descrizione-corso {
  color: var(--testo-grigio);
  font-size: 1rem;
}

/* =========================================
   CARD COACH
   ========================================= */
.card-coach {
  border-bottom: 3px solid #333333;
}

.card-coach:hover {
  border-bottom-color: var(--lime-crosstrik); /* Si accende di lime sotto al passaggio del mouse */
  transform: translateY(-5px);
}

.ruolo-coach {
  color: var(--nero-crosstrik);
  background: linear-gradient(135deg, var(--lime-crosstrik), var(--lime-hover));
  display: inline-block;
  padding: 7px 10px;
  border-radius: 15px;
  font-weight: 700;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px;
  box-shadow: 0 2px 10px rgba(198, 255, 0, 0.2);
}

.bio-coach {
  color: var(--testo-grigio);
  font-size: 1rem;
}

/* =========================================
   TESTO TRONCATO (PER JS)
   ========================================= */
.testo-troncato {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: all 0.3s ease;
}

.testo-espanso {
  -webkit-line-clamp: unset;
}

/* =========================================
   ORARI E IFRAME
   ========================================= */
.box-orari,
.iframe-box {
  padding: 30px;
  height: 100%;
}

.immagine-orari img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 10px;
}

.iframe-box iframe {
  border-radius: 10px;
  opacity: 0.85; /* Abbassa la luminosità della mappa Google per integrarsi nel dark mode */
  transition: opacity 0.3s ease;
}

.iframe-box iframe:hover {
  opacity: 1; /* Si illumina al passaggio del mouse */
}

/*SOCIAL*/
.eapps-instagram-feed-header{
   border-radius-top:30px;
   border-radius-bottom:30px;
}
/* =========================================
   OPZIONE 2: TARIFFE CLEAN MINIMAL (CHIARE)
   ========================================= */
.card-prezzo {
  padding: 40px 30px;
  text-align: center;
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
  /* Sfondo bianco pulito */
  background: #ffffff;
  border: 4px solid var(--lime-crosstrik);
  border-radius: 15px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease;
}

.card-prezzo:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1);
  border-color: #cccccc;
}

.piano-premium {
  /* Sfondo leggermente grigio ghiaccio per staccare */
  background: var(--lime-crosstrik);
  border: 2px solid var(--nero-crosstrik);
  transform: scale(1.05);
   color:var(--nero-crosstrik);
  z-index: 2;
  box-shadow: 0 15px 40px rgba(198, 255, 0, 0.15);
}

.piano-premium:hover {
  transform: scale(1.05) translateY(-10px);
  box-shadow: 0 20px 45px rgba(198, 255, 0, 0.25);
}

/* Testi scuri per leggibilità sul fondo chiaro */
.nome-piano { color: var(--nero-crosstrik); font-weight: bold; }
.prezzo-box .prezzo { color: var(--nero-crosstrik); }
.prezzo-box .valuta { color: #111111; } /* Valuta scura */
.prezzo-box .periodo { color: #666666; }
.lista-features li { color: #444444; }

/* Adatta la linea di separazione */
.prezzo-box {
  border-bottom: 1px solid #eeeeee;
  margin-bottom: 25px;
  padding-bottom: 25px;
}
/* =========================================
   FAQ (Sovrascrittura Bootstrap Accordion)
   ========================================= */
.accordion-item {
  background-color: var(--grigio-scuro);
  border: 1px solid #333 !important;
  border-radius: 10px !important;
  overflow: hidden;
  margin-bottom: 10px;
}

.accordion-button {
  background-color: var(--grigio-scuro) !important;
  color: var(--testo-chiaro) !important;
  font-weight: 500;
}

.accordion-button:not(.collapsed) {
  background: linear-gradient(145deg, var(--grigio-medio), var(--nero-crosstrik)) !important;
  color: var(--lime-crosstrik) !important;
  box-shadow: inset 0 -1px 0 rgba(198, 255, 0, 0.2);
}

.accordion-button::after {
  filter: invert(1); /* Fa diventare bianca la freccetta di Bootstrap */
}

.accordion-button:not(.collapsed)::after {
  filter: invert(80%) sepia(80%) saturate(1000%) hue-rotate(30deg) brightness(100%) contrast(100%); /* Trick per colorare la freccetta di lime (approssimativo) */
}

.accordion-body {
  color: var(--testo-grigio);
}

.accordion-button:focus {
  border-color: var(--lime-crosstrik);
  box-shadow: 0 0 0 0.25rem rgba(198, 255, 0, 0.15);
}

/* =========================================
   FOOTER CUSTOM
   ========================================= */
.footer-custom {
  background-color: #050505; /* Uno sfondo ancora più profondo del body per staccare */
  border-top: 3px solid var(--lime-crosstrik);
}

/* Sovrascrivo il colore dei paragrafi per renderli leggibili sul fondo scuro */
.footer-custom p {
  color: var(--testo-grigio);
}

/* Titolo principale del footer */
.footer-titolo {
  color: var(--lime-crosstrik);
  letter-spacing: 2px;
  font-size: 2.2rem;
}

/* Sottotitoli delle colonne */
.titolo-footer-col {
  color: var(--testo-chiaro); /* Manteniamo il bianco per non abusare del lime */
  font-size: 1.4rem;
  letter-spacing: 1px;
}

/* Animazione per la lista dei link */
.footer-links li {
  transition: transform 0.3s ease;
}

.footer-links li:hover {
  transform: translateX(8px); /* Effetto scorrimento laterale al passaggio del mouse */
}

/* Stile per tutti i link del footer (menu, mappa, privacy) */
.footer-links a,
.link-mappa,
.iubenda-white {
  color: var(--testo-chiaro) !important;
  text-decoration: none;
  transition: color 0.3s ease;
  font-family: "Roboto", sans-serif;
}

.footer-links a:hover,
.link-mappa:hover,
.iubenda-white:hover {
  color: var(--lime-crosstrik) !important;
}

/* Indirizzo (sovrascrive il font in corsivo di default del tag <address>) */
.footer-indirizzo {
  font-style: normal;
  line-height: 1.8;
}

/* Bottone Social (Stile Outline che si riempie al passaggio) */
.social-btn {
  background: transparent;
  color: var(--lime-crosstrik);
  border: 2px solid var(--lime-crosstrik);
  border-radius: 30px;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 10px 25px;
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.social-btn:hover {
  background: linear-gradient(135deg, var(--lime-crosstrik), var(--lime-hover));
  color: var(--nero-crosstrik) !important;
  box-shadow: 0 4px 15px rgba(198, 255, 0, 0.4);
  transform: translateY(-3px);
  border-color: transparent;
}

/* Testi secondari e copyright */
.testo-grigio-chiaro {
  color: var(--testo-grigio) !important;
}
