﻿/*
========================================================================================
    CSS PAGINA CORSO - NonSoloFitness
========================================================================================
    Richiede: css_2026_Variabili_globali.css (caricato prima di questo file)
========================================================================================
*/

/*
          pulsante iscrizione
                                       */
.div-container-pulsante-iscrizione {
    margin:10px 0 30px 0 !important; background-color: var(--nsf-white); width:100%; text-align:center; padding:5px 0;}    
        
.div-container-pulsante-iscrizione:after {
    display: block; clear: both; content:" "; }   
    
.div-container-pulsante-iscrizione .section-pulsante{
    margin:10px 0; }  
    
.div-container-pulsante-iscrizione p {
    margin-top:5px !important; font-size:14px !important; }    
    
.div-container-pulsante-iscrizione div.iscriviti-subito {
    text-align:center; color: var(--nsf-white); padding:10px 0; width:90%; max-width:400px; 
    margin:0 auto; display:block; font-size:16px; font-weight:500; box-shadow: 0 8px 16px var(--nsf-black-20); 
    background-color: var(--nsf-red); transition: opacity 0.3s ease;}        
    
.div-container-pulsante-iscrizione div.iscriviti-subito span {      
    display: inline-flex; align-items: center; justify-content: center; gap: 5px; }

.div-container-pulsante-iscrizione div:hover {
    opacity:0.75 }
    
.div-container-pulsante-iscrizione div.iscriviti-subito span svg {
    width:22px; height:22px; }
    
    

    
/*
          read more
                                       */
.read-more-container {
  position: relative; margin-top:-15px; }

.read-more-state {
  display: none; }

.read-more-wrap {
  max-height: 250px; overflow: hidden; position: relative; transition: max-height 0.3s ease; margin-bottom:20px; 
  will-change: max-height; }

.read-more-wrap::after {
  content: ""; position: absolute; bottom: 0; left: 0; width: 100%; 
  height: 30px; background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #FEFEFE 60%); pointer-events: none; transition: opacity 0.3s ease; }

.read-more-state:checked ~ .read-more-wrap {
  max-height: 2000px; }

.read-more-state:checked ~ .read-more-wrap::after {
  opacity: 0; }

.read-more-trigger {
  cursor: pointer; display: inline-block; }

.read-more-state ~ .read-more-trigger::before {
  content: 'Leggi di più'; color: var(--nsf-red); font-weight:500; font-size:13px; }

.read-more-state:checked ~ .read-more-trigger::before {
  content: 'Leggi meno'; }
  
  
  
  
/*
          headings
                                       */
h3.h3-corso-titolo {
    position: relative; font-size: 22px !important; font-weight:500 !important; padding-bottom: 5px; }

h3.h3-corso-titolo::after {
    content: ""; position: absolute; bottom: 0; left: 0; height: 1px;
    width: 100%; background: linear-gradient( to right, var(--nsf-gray-450) 0%, rgba(204, 204, 204, 0.6) 40%, rgba(204, 204, 204, 0.3) 75%, rgba(204, 204, 204, 0) 100% ); }

h4.h4-corso-titolo {
    font-size: 18px !important; font-weight:500 !important;}

h4.contenitore-programa-orario {
    font-size:16px !important; font-weight:500; }

h5.h5-spiegazione {
    font-size:17px; }
   
h3.h3-corso-titolo.speciale-ricerca {
    position: relative; font-size: 22px !important; font-weight: 500 !important; padding-bottom: 5px; color: var(--nsf-red) !important;
    display: flex; align-items: center; gap: 5px; }

h3.h3-corso-titolo.speciale-ricerca::before {
    content: ""; display: inline-block; width: 20px; height: 20px; background-repeat: no-repeat;
    background-size: contain; background-position: center; flex-shrink: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath fill='%23E2001A' d='M384 208A176 176 0 1 0 32 208a176 176 0 1 0 352 0zM343.3 366C307 397.2 259.7 416 208 416C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208c0 51.7-18.8 99-50 135.3L507.3 484.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L343.3 366z'/%3E%3C/svg%3E"); }
 
h3.h3-corso-titolo.speciale-ricerca::after {
    background: linear-gradient( to right, var(--nsf-red) 0%, rgba(226, 0, 26, 0.6) 40%, rgba(226, 0, 26, 0.3) 75%, rgba(226, 0, 26, 0) 100% ); }
    

    
/*
          calendario
                                       */    
.corsi-in-sede-calendario {
    width: 100%; border-collapse: collapse; font-size: 14px; }

.corsi-in-sede-calendario tr.riga-corso {
    cursor: pointer; }

.corsi-in-sede-calendario th, .corsi-in-sede-calendario td:not(.calendario-diviso-per-mese) {
    padding: 12px; border-bottom: 1px solid var(--nsf-gray-400); }
    
.corsi-in-sede-calendario tfoot td {
    border-bottom:none !important; }   

.corsi-in-sede-calendario:not(.calendario-diviso-per-mese) th:nth-child(1), .corsi-in-sede-calendario:not(.calendario-diviso-per-mese) td:nth-child(1) {
    width: 45%; text-align: left; }

.corsi-in-sede-calendario:not(.calendario-diviso-per-mese) th:nth-child(2), .corsi-in-sede-calendario:not(.calendario-diviso-per-mese) td:nth-child(2) {
    width: 35%; text-align: left; }

.corsi-in-sede-calendario th:nth-child(3), .corsi-in-sede-calendario td:nth-child(3) {
    text-align: center; }

.corsi-in-sede-calendario th:nth-child(4), .corsi-in-sede-calendario td:nth-child(4) {
    width: 25px; text-align: center; }
  
.corsi-in-sede-calendario.calendario-diviso-per-mese th:nth-child(1), .corsi-in-sede-calendario.calendario-diviso-per-mese td:nth-child(1) {
    width: 90%; text-align: left; }

.corsi-in-sede-calendario.calendario-diviso-per-mese th:nth-child(2), .corsi-in-sede-calendario.calendario-diviso-per-mese td:nth-child(2) {
  width: auto; text-align: right; }
  
.corsi-in-sede-calendario td a {
  color: var(--nsf-black-pure); }  

.icona-info i {
  font-size: 24px; cursor: pointer; color: var(--nsf-cta-info); }
  
.icona-info svg {
  height:24px; width:24px; cursor: pointer; fill: var(--nsf-cta-info); margin-top:5px; }  

.corsi-in-sede-calendario tbody tr:nth-child(even) {
  background-color: var(--nsf-gray-250); }

.corsi-in-sede-calendario tbody tr:nth-child(odd) {
  background-color: var(--nsf-white); }

.corsi-in-sede-calendario:not(.calendari-secondari) tbody tr:nth-child(4n - 1) {
  background-color: var(--nsf-gray-250); }

.corsi-in-sede-calendario .riga-corso td {
  vertical-align: middle; }

.riga-dettaglio-box {
  background-color: var(--nsf-highlight-yellow-bg); padding: 16px; position: relative; font-size: 14px; color: var(--nsf-gray-900);
  border-bottom: 2px solid var(--nsf-highlight-yellow) !important; }
  
.chiudi-dettaglio {
  float: right; cursor: pointer; font-weight: bold; color: var(--nsf-cta-info); font-size: 18px; }

.chiudi-dettaglio:hover {
  color: #0a9bbd; }
  
.corsi-in-sede-calendario.filtro-attivo .riga-corso {
    background-color: var(--nsf-white) !important; }

.calendario-card {
    width: 100%; border-collapse: collapse; font-size: 16px; }
    
.calendario-card .spacer  {
    font-size:1px !important; line-height:none !important; height:18px !important; }
    
.calendario-card tbody .spacer hr {
    border: 0; height: 1px; background-color: var(--nsf-gray-250); margin: 0; width: 100%;
    display: block; }  
    
.calendario-card thead th {
    font-size:18px; font-weight:500; letter-spacing:0.5px; padding-bottom:15px; }   
    
.calendario-card thead .spacer hr {
    border: 0; height: 1px; background-color: var(--nsf-gray-400); margin: 0; width: 100%;
    display: block; }         
     
.calendario-card .riga-corso-top .td-corso, .calendario-card .riga-corso-bottom .td-data {
    border-left: 2px solid var(--nsf-red); padding: 5px 10px; }

.calendario-card .riga-corso-top .td-corso {
    padding-bottom: 0; padding-top: 6px; }

.calendario-card .riga-corso-bottom .td-data {
    padding-top: 2px; padding-bottom: 6px; font-size: 15px; }

.calendario-card .td-corso a {
    font-family: 'Poppins', sans-serif; font-weight: 600; color: var(--nsf-black-pure); text-decoration: none; }

.calendario-card .td-corso a:hover {
    color: var(--nsf-red); } 

.calendario-card .td-posti {
    width: 30px; text-align: right; vertical-align: middle; padding-right: 10px;}

.calendario-card .td-icona {
    width: 40px; text-align: right; vertical-align: middle; padding-top:5px; }
    
.calendario-card .td-icona svg {
    width: 30px; height:30px; fill: var(--nsf-red);}    

.calendario-card .td-icona a:hover {
    opacity: 0.7; }
    
.calendario-card tbody tr:nth-child(6n+4) .td-corso {
    border-left-color: #fe2e2e; }

.calendario-card tbody tr:nth-child(6n+5) .td-data {
    border-left-color: #fe2e2e; }
    
.calendario-card tfoot td {
    font-size:13px !important; line-height:2; } 

.calendario-controls {
    display: flex; gap: 10px; background-color: var(--nsf-gray-50); padding: 15px; border-radius: 4px;
    box-shadow: 0 4px 8px var(--nsf-black-30); }

.controlli-colonna-sinistra {
    width: 90%; display: flex; flex-direction: column; gap: 10px; }

.controlli-colonna-destra {
    width: 10%; display: flex; align-items: center; justify-content: center; }

.controlli-riga-1 {
    width: 100%; }

.controlli-riga-2 {
    display: flex; gap: 15px; }

.calendario-controls {
    display: flex; gap: 10px; }

.controlli-colonna-sinistra {
    width: 90%; display: flex; flex-direction: column; gap: 10px; }

.controlli-colonna-destra {
    width: 10%; display: flex; align-items: center; justify-content: center; }

.controlli-riga-1 {
    width: 100%; }

.controlli-riga-2 {
    display: flex; gap: 15px; }

.select-wrapper {
    position: relative; min-width: 200px; border: 1px solid #9b9b9b; border-radius: 4px; background: var(--nsf-white);
    padding: 4px 40px 4px 12px; cursor: pointer; }

.select-wrapper:hover {
    border-color: #6a6a6a; }

.select-wrapper label {
    display: block; font-size: 11px; font-weight: 600; color: #6a6a6a; text-transform: uppercase;
    letter-spacing: 0.5px; margin-bottom: 2px; pointer-events: none; }

.select-wrapper select {
    width: 100%; border: none; background: transparent; font-size: 15px; font-weight: 500; color: #1c1d1f;
    font-family: 'Poppins', sans-serif; cursor: pointer; appearance: none; -webkit-appearance: none; -moz-appearance: none;
    outline: none; padding: 5px !important; }
    
.select-wrapper select:focus {
    outline: none; box-shadow: none; }    

.select-wrapper .select-arrow {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%); width: 14px; height: 14px;
    fill: #6a6a6a; pointer-events: none; }

.btn-ordina {
    display: flex; align-items: center; gap: 8px; background: none; border: none;
    cursor: pointer; padding: 5px; }

.btn-ordina svg {
    width: 40px; height: 40px; fill: var(--nsf-cta-info); }

.btn-ordina span {
    font-size: 11px; color: #1c1d1f; }

.btn-ordina:hover svg {
    opacity: 0.7; }

.btn-ordina:disabled, .btn-ordina.disabled {
    opacity: 0.4; cursor: not-allowed; pointer-events: none; }

.btn-reset {
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px;
    background: none; border: none; cursor: pointer; padding: 5px; visibility: hidden; }

.btn-reset.attivo {
    visibility: visible; }

.btn-reset svg {
    width: 30px; height: 30px; fill: var(--nsf-red); }

.btn-reset span {
    font-size: 11px; color: var(--nsf-red); }

.btn-reset:hover svg {
    opacity: 0.7; }

.calendario-carica-tutti {
    display: flex; justify-content: center; align-items: center; width: 100%; padding: 10px 0; }

.btn-carica-tutti {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 10px 20px;
    background: transparent; border: 2px solid var(--nsf-cta-primary); border-radius: 4px; color: var(--nsf-cta-primary); font-size: 14px; 
    font-weight: 600; cursor: pointer; transition: all 0.2s ease; }

.btn-carica-tutti svg {
    width: 26px; height: 26px; fill: var(--nsf-cta-primary); flex-shrink: 0; transition: transform 0.2s ease; }

.btn-carica-tutti:hover {
    background: var(--nsf-cta-info); color: var(--nsf-white); }

.btn-carica-tutti:hover svg {
    fill: var(--nsf-white); }

.btn-carica-tutti.aperto svg {
    transform: rotate(180deg); }


/* Animazione righe calendario */
.calendario-card .riga-corso-top, .calendario-card .riga-corso-bottom, .calendario-card tr:has(.spacer) {
    transition: opacity 0.3s ease, transform 0.3s ease; }

.calendario-card .riga-animazione-enter {
    opacity: 0; transform: translateY(-10px); }

.calendario-card .riga-animazione-enter-active {
    opacity: 1; transform: translateY(0); }

.calendario-card .riga-animazione-exit {
    opacity: 1; transform: translateY(0); }

.calendario-card .riga-animazione-exit-active {
    opacity: 0; transform: translateY(-10px); }

.calendario-controls-semplice {
    display: flex; justify-content: flex-start; padding: 15px; background-color: var(--nsf-gray-50); border-radius: 4px;
    box-shadow: 0 4px 8px var(--nsf-black-30); margin-bottom: 15px; }

.calendario-controls-semplice .select-wrapper {
    min-width: 250px; }

.corsi-in-sede-calendario .riga-corso, .corsi-in-sede-calendario .riga-dettaglio {
    transition: opacity 0.3s ease, transform 0.3s ease; }

.corsi-in-sede-calendario .riga-animazione-enter {
    opacity: 0; transform: translateY(-10px); }

.corsi-in-sede-calendario .riga-animazione-enter-active {
    opacity: 1; transform: translateY(0); }

.corsi-in-sede-calendario .riga-animazione-exit {
    opacity: 1; transform: translateY(0); }

.corsi-in-sede-calendario .riga-animazione-exit-active {
    opacity: 0; transform: translateY(-10px); }

.corsi-in-sede-calendario.corsi-in-sede-dinamico .sede-corso {
    font-weight: 500; }

.corsi-in-sede-calendario.corsi-in-sede-dinamico .td-data {
    white-space: nowrap; }

/*
          carousel
                                       */ 
.carousel {
    margin-bottom: 10px; }

.carousel-cell {
    width: 280px; height: 280px; margin-right: 10px; border-radius: 5px; display: flex;
    align-items: center; justify-content: center; }
    
.carousel-cell img {
    max-width: 100%; max-height: 100%; object-fit: contain; }
    
.carousel-cell .carousel-cell_div-immagine-spiegazione {
    width: 280px; height: 280px; border: 1px solid var(--nsf-gray-250); display: flex; flex-direction: column; }

.carousel-cell .carousel-cell_div-immagine-spiegazione .div-immagine-spiegazione-image-container {
    flex-grow: 1; display: flex; align-items: center; justify-content: center; border-bottom: 1px solid var(--nsf-gray-400); }
    
.carousel-cell .carousel-cell_div-immagine-spiegazione .div-immagine-spiegazione-image-container img {
    max-width: 200px; max-height: 200px; object-fit: contain; }
            
.carousel-cell .carousel-cell_div-immagine-spiegazione .div-immagine-spiegazione-text-container {
    height: 60px; background-color: var(--nsf-white); display: flex; align-items: center; padding: 5px;
    font-weight: 600; font-size: 14px; }
        
@media (min-width: 450px) {
    .carousel-cell {
        width: 300px; height: 300px; }
        
    .carousel-cell .carousel-cell_div-immagine-spiegazione {
        width: 300px; height: 300px; }
        
    .carousel-cell .carousel-cell_div-immagine-spiegazione .div-immagine-spiegazione-image-container img {
        max-width: 220px; max-height: 220px; }
}


   

/*
          typo
                                       */   
p.evidenzia-concetto {
    border-left: 5px solid var(--nsf-info-cyan); padding-left:10px; }
    
    
ul.iscrizione-comprende {
    list-style-type: none; padding: 0 !important; margin: 0 0 20px 0 !important; }
    
ul.iscrizione-comprende li {
    display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--nsf-gray-250);
    font-size: 15px; line-height: 1.4; }
    
ul.iscrizione-comprende li:last-child {
    border-bottom: none; }
    
ul.iscrizione-comprende li svg {
    flex-shrink: 0; width: 22px; height: 22px; margin-top: 1px; fill: var(--nsf-cta-info); }  
    
div.disponibile-anche-online {
    border: 1px solid var(--nsf-cta-intermediate); padding:10px; width:100%; margin-bottom:50px; display:flow-root; overflow: auto;}    
    
div.disponibile-anche-online:after {
    display:block; clear:both; content:" ";}  
    
div.disponibile-anche-online img:hover {
    opacity:0.75; }      
    
    
        
/*
          orari
                                       */ 
.programma-orario {
    display: flex; flex-direction: column; width: 100%; margin-bottom: 20px; }

.programma-orario-riga {
    display: flex; flex-direction: row; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--nsf-gray-250); }

.programma-orario .programma-orario-riga:nth-child(even) {
    background-color: var(--nsf-info-bg-light); }

.programma-colonna-icona {
    width: 40px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

.programma-colonna-icona svg {
    width: 25px; height: 25px; fill: var(--nsf-cta-info); }

.programma-colonna-ora {
    width: 120px; font-weight: 400; flex-shrink: 0; }

.programma-colonna-attivita {
    flex-grow: 1; text-align: left; padding-left: 10px; font-weight: 500; }

.contenitore-programa-orario .programma-orario:last-of-type {
    margin-bottom: 0; }

.contenitore-programa-orario .programma-orario:last-of-type .programma-orario-riga:last-child {
    border-bottom: none; }



/*
          details
                                       */ 
details.details-pagina-corso summary {
    font-size:18px !important;}
    
details.details-pagina-corso > div, details.details-pagina-corso > p {
    padding: 20px 0 0 0 important; margin:0 !important; }  
    
details.vantaggi p strong {
    line-height:1.6; font-size:15px;}    
    
details.vantaggi p {
    width:100%; display:block; margin-bottom:20px !important; float:left; font-size:14px; line-height:1.4; }

details.vantaggi p img {
    float:left; padding: 0 10px 0 0; width:80px; height:80px; padding:3px; border: 1px solid var(--nsf-gray-250); margin: 0 10px 5px 0; }
    
details.diploma > ul li {
    line-height:1.6; padding-bottom:15px;}   
    
details.diploma > p {
    padding: 0 important; margin-bottom:20px !important; }      
    
.area-box.pagina-corso-specifico {
    border: 1px solid var(--nsf-black-pure); }
          
#details-programma h3 {
    color: var(--nsf-black-pure); font-size:16px; margin-bottom:10px; }   
    
#details-programma h4 {
    color: var(--nsf-gray-950); font-size:22px; margin-bottom:10px;}     
    
#details-programma p {
    margin-bottom:20px !important; }   
    
#details-programma dl {
    margin-bottom:20px !important; }   

#details-programma dl dt:not(:first-of-type) {
  margin-top: 30px; }      
       
#details-programma dt {
    font-weight:500; padding-bottom:5px; margin-bottom:10px; }  
    
#details-programma ul {
    margin-bottom:20px; }       
    
#details-programma dl dd, #details-programma ul li {
    font-size:15px; border-bottom: 1px solid var(--nsf-gray-250); padding:12px 8px; }
    
details.details-pagina-corso-altre-informazioni p {
    margin-bottom:20px !important; }    
    
ul.contatti-fondo-pagina li {
    font-size:15px; padding:8px 0; border-bottom: 1px solid var(--nsf-gray-250); }
    
ul.contatti-fondo-pagina li a {
    color: var(--nsf-black-pure); }    
    
#indice-articolo-container {
    position: -webkit-sticky; position: sticky; top: 5px; z-index: 1100; margin-bottom: 30px; background-color: var(--nsf-index-bg); border-radius:15px;}

#indice-header {
    display: flex; align-items: center; cursor: pointer; user-select: none; font-weight: 500;
    color: var(--nsf-cta-info); padding: 10px 16px; justify-content: center;}

.menu-toggle {
    width: 30px; height: 30px; background-color: var(--nsf-cta-info); border-radius: 50%; display: flex;
    align-items: center; justify-content: center; position: relative; transition: background-color 0.3s ease; margin-right: 15px; }

.menu-toggle .bar {
    width: 16px; height: 2px; background-color: var(--nsf-white); border-radius: 1px; position: absolute;
    left: 7px; right: 7px; transition: transform 0.3s ease, top 0.3s ease, opacity 0.3s ease; }

.bar1 {
    top: 8px; }
        
.bar2 {
    top: 14px; }
        
.bar3 {
    top: 20px; }
        
#indice-articolo-container.open {
    background-color: var(--nsf-index-bg-open);}        

#indice-articolo-container.open #indice-header {
        color: var(--nsf-cta-intermediate); border-bottom: 1px solid var(--nsf-cta-intermediate); }
         
#indice-articolo-container.open .menu-toggle {
    background-color: var(--nsf-cta-intermediate); }     

#indice-articolo-container.open .bar1 {
    transform: rotate(45deg); top: 14px; }
    
#indice-articolo-container.open .bar2 {
    opacity: 0; }
      
#indice-articolo-container.open .bar3 {
    transform: rotate(-45deg); top: 14px; }

#indice-body-wrapper {
    max-height: 0; overflow: hidden; opacity: 0; transition: max-height 0.4s ease, opacity 0.4s ease; }
      
#indice-articolo-container.open #indice-body-wrapper {
    max-height: 800px; opacity: 1; }

#indice-lista {
    list-style: none; padding: 10px; margin: 0; }

#indice-lista li {
    list-style: none; margin-bottom: 10px; border-bottom: 1px solid var(--nsf-white); font-size:15px; }

#indice-lista li a {
    display: block; padding: 6px 20px 6px 10px; text-decoration: none; color: var(--nsf-black-pure); transition: opacity 0.5s ease-in-out;
    background-repeat: no-repeat; background-position: right center; background-size: 14px auto; 
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath fill='%236f42c1' d='M267.3 244.7c6.2 6.2 6.2 16.4 0 22.6l-160 160c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L233.4 256 84.7 107.3c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0l160 160z'/%3E%3C/svg%3E"); }

#indice-lista li a:hover {
    opacity:0.5; }
        
[id^="h3-corso-titolo-"] {
    scroll-margin-top: 200px; }
    
.wrap-riassunto-corso {
    width: 100%; margin-bottom: 20px; background-color: var(--nsf-white); overflow: hidden; }

.wrap-riassunto-corso .contenitore-riassunto-corso {
    display: flex; align-items: center; padding: 10px 5px; border-bottom: 1px solid var(--nsf-gray-450); width: 100%; }

.wrap-riassunto-corso .contenitore-riassunto-corso:nth-child(1) {
    border-top: 1px solid var(--nsf-gray-450); }

.wrap-riassunto-corso .riassunto-top-colonna-icona {
    flex: 0 0 45px; display: flex; justify-content: center; align-items: center; height:45px; width:45px; }
       
.wrap-riassunto-corso .riassunto-top-colonna-icona svg  {
    width:30px; height:30px; }
    
.wrap-riassunto-corso .riassunto-top-colonna-icona img {
    color: var(--nsf-cta-info); width: 30px; height: 30px; }

.wrap-riassunto-corso .riassunto-top-colonna-spiegazione {
    display: flex; flex-direction: column; justify-content: center; font-weight: 600; }

.wrap-riassunto-corso .riassunto-top-riga-spiegazione-sopra {
    font-size: 13px; color: var(--nsf-gray-750); padding: 5px; padding-bottom: 0; }

.wrap-riassunto-corso .riassunto-top-riga-spiegazione-sotto {
    padding: 5px; padding-top: 0; font-size: 14px; }
     
   
@media (min-width: 769px) {
    .wrap-riassunto-corso-qualifica-desktop {
        visibility:visible; display:inline; }
        
    .wrap-riassunto-corso-qualifica-mobile {
        visibility:hidden; display:none; }        
}     

@media (max-width: 768px) {
    .wrap-riassunto-corso-qualifica-desktop {
        visibility:hidden; display:none; }
        
    .wrap-riassunto-corso-qualifica-mobile {
        visibility:visible; display:inline; }        
}  


@media (min-width: 769px) {
    .wrap-riassunto-corso .contenitore-riassunto-corso {
        width: 50%; float: left; }

     .wrap-riassunto-corso .contenitore-riassunto-corso-100{
        width: 100%; }

    .wrap-riassunto-corso .contenitore-riassunto-corso:nth-child(1), .wrap-riassunto-corso .contenitore-riassunto-corso:nth-child(2) {
        border-top: 1px solid var(--nsf-gray-450); }

    .wrap-riassunto-corso .contenitore-riassunto-corso:nth-child(7) {
        border-bottom: 1px solid var(--nsf-gray-450); }
}


.wrap-riassunto-corso .contenitore-riassunto-corso {
    opacity: 0; transform: translateY(15px); transition: opacity 0.25s ease-out, transform 0.25s ease-out; }
    
.wrap-riassunto-corso .contenitore-riassunto-corso.visible {
    opacity: 1; transform: translateY(0); }


.container-immagine-principale {
    position: relative; display: inline-block; overflow: hidden; line-height: 0; }

.container-immagine-principale .banda {
    position: absolute; width: 200px; height: 35px; background-color: rgba(0, 123, 255, 0.85); color: var(--nsf-white);
    text-align: center; line-height: 35px; font-weight: 500; font-size: 15px; text-transform: uppercase;
    left: 0; top: 60%; box-shadow: 0 4px 6px var(--nsf-black-20); z-index: 1; }

@media (max-width: 480px) {
    .container-immagine-principale .banda {
        width: 150px; height: 28px; font-size: 13px; line-height: 28px; top: 50%;}
}


dl.corso-dettagli {
  margin: 0 0 20px 0; padding: 0; }

.corso-dettagli dt {
  display: flex; align-items: center; font-weight: 500; margin-top: 15px; margin-bottom:10px; }

.corso-dettagli dt svg {
  margin-right:10px; fill: var(--nsf-cta-info); width:25px; height:25px; }

.corso-dettagli dd {
  padding: 0 0 12px 0; line-height: 1.5; border-bottom: 1px solid var(--nsf-gray-250); margin-bottom:20px; }    
  
.pagina-corsi-lista {
    display:none; }  
    
.sticky-footer {
    display: none; }    
    
    
.live-users-box {
    width: 100%; margin: 20px auto; display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--nsf-cta-info); box-shadow: 0 5px 10px var(--nsf-black-15); font-weight: 500; background-color: var(--nsf-white); padding: 0 20px;
    box-sizing: border-box; }

.live-users-icon {
    width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; }

.live-users-icon svg {
    width: 35px; height: 35px; fill: var(--nsf-cta-info); }

.live-users-text {
    padding-left: 10px; color: var(--nsf-gray-900); display: flex; align-items: center; }

.numero-utenti {
    color: var(--nsf-cta-info); font-weight: 500; padding-right:5px; }
    
    
.section-container-pulsante-iscrizione {
    margin:30px 0 30px 0 !important; background-color: var(--nsf-gray-50); width:100%; text-align:center; padding:10px 0;}    
        
.section-container-pulsante-iscrizione:after {
    display: block; clear: both; content:" "; }   
    
.section-container-pulsante-iscrizione .section-pulsante{
    margin:20px 0; }    
    
.section-container-pulsante-iscrizione div.iscriviti-subito {
    text-align:center; color: var(--nsf-white); padding:10px 0; max-width:300px; margin:0 auto; display:block; font-size:16px; border-radius: 3px; 
    font-weight:500; box-shadow: 0 4px 8px var(--nsf-black-20); }                                                           

.section-container-pulsante-iscrizione div.iscriviti-subito.online {
    background-color: var(--nsf-udemy-purple); }
    
.section-container-pulsante-iscrizione div.iscriviti-subito.sede {
    background-color: var(--nsf-red); }    

.section-container-pulsante-iscrizione div:hover {
    opacity:0.8 }

.centered-text {
    display: flex; align-items: center; justify-content: center; width: 100%; font-size: 14px;
    position: relative; color: var(--nsf-gray-800); margin: 15px 0; padding: 0 10px; box-sizing: border-box; }

.centered-text::before, .centered-text::after {
    content: ""; flex: 1; border-bottom: 1px solid var(--nsf-gray-600); margin: 0 10px; }
    

.section-cosa-imparerai h2 {
    text-align: center; font-size: 40px; margin-bottom: 50px; color: var(--nsf-black); }

.section-cosa-imparerai dl {
    counter-reset: learning-counter; display: flex; flex-direction: column; gap: 0; overflow: hidden; }
    
.section-cosa-imparerai dt {
    counter-increment: learning-counter; position: relative; padding-left: 80px; padding-top: 30px; font-size: 20px;
    font-weight: 600; color: var(--nsf-black); line-height: 1.4; border-top: 1px solid var(--nsf-gray-350); opacity: 0;
    transform: translateY(20px); transition: opacity 0.25s ease-out, transform 0.25s ease-out; }
    
.section-cosa-imparerai dt:first-of-type {
    border-top: none; }
    
.section-cosa-imparerai dt::before {
    content: counter(learning-counter, decimal-leading-zero); position: absolute; left: 0; top: 30px; font-size: 32px;
    font-weight: 300; color: var(--nsf-red); line-height: 1; width: 60px; }
    
.section-cosa-imparerai dd {
    padding-left: 80px; padding-bottom: 30px; margin: 0; margin-top: 8px; font-size: 16px;
    line-height: 1.7; color: var(--nsf-gray-800); opacity: 0; transform: translateY(20px); transition: opacity 0.25s ease-out, transform 0.25s ease-out; }
    
.section-cosa-imparerai dt.visible, .section-cosa-imparerai dd.visible {
    opacity: 1; transform: translateY(0); }
    
@media (max-width: 600px) {
    
    .section-cosa-imparerai h2 {
        font-size: 28px; margin-bottom: 30px; }
    
    .section-cosa-imparerai dt {
        padding-left: 55px; padding-top: 25px; font-size: 18px; }
    
    .section-cosa-imparerai dt::before {
        font-size: 24px; top: 25px; width: 45px; }
    
    .section-cosa-imparerai dd {
        padding-left: 55px; padding-bottom: 25px; font-size: 15px; }
        
}




/* 
________________________________________________________________________________________________________________________________________________________
    LISTE ANIMATE - Pagine corso
--------------------------------------------------------------------------------------------------------------------------------------------------------
    Liste con marker SVG freccia e animazioni di ingresso alternate (dall'alto/dal basso)
________________________________________________________________________________________________________________________________________________________
*/

.nsf-lista-animata {
    list-style: none; margin: 0 0 24px 0; padding: 0; }

.nsf-lista-animata li {
    position: relative; padding: 12px 0 12px 32px; border-bottom: 1px solid var(--nsf-gray-200);
    opacity: 0; transition: opacity 0.5s ease-out, transform 0.5s ease-out, background 0.3s ease, padding 0.3s ease; }

.nsf-lista-animata li:last-child {
    border-bottom: none; }

.nsf-lista-animata li:nth-child(odd) {
    transform: translateY(-30px); }

.nsf-lista-animata li:nth-child(even) {
    transform: translateY(30px); }

.nsf-lista-animata li.visible {
    opacity: 1; transform: translateY(0); }

.nsf-lista-animata li::before {
    content: ''; position: absolute; left: 0; top: 18px; width: 20px; 
    height: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 640 640'%3E%3Cpath fill='%23e63946' d='M427.3 308.7C433.5 314.9 433.5 325.1 427.3 331.3L267.3 491.3C261.1 497.5 250.9 497.5 244.7 491.3C238.5 485.1 238.5 474.9 244.7 468.7L393.4 320L244.7 171.3C238.5 165.1 238.5 154.9 244.7 148.7C250.9 142.5 261.1 142.5 267.3 148.7L427.3 308.7z'/%3E%3C/svg%3E");
    background-size: contain; background-repeat: no-repeat; transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); }

.nsf-lista-animata.su-sfondo-nero li {
    border-bottom-color: var(--nsf-white-10); color: var(--nsf-white-warm); }

.nsf-lista-animata.su-sfondo-nero li:hover {
    background: var(--nsf-white-05); }

.nsf-lista-animata.su-sfondo-nero li::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 640 640'%3E%3Cpath fill='%23e63946' d='M427.3 308.7C433.5 314.9 433.5 325.1 427.3 331.3L267.3 491.3C261.1 497.5 250.9 497.5 244.7 491.3C238.5 485.1 238.5 474.9 244.7 468.7L393.4 320L244.7 171.3C238.5 165.1 238.5 154.9 244.7 148.7C250.9 142.5 261.1 142.5 267.3 148.7L427.3 308.7z'/%3E%3C/svg%3E"); }

@media (prefers-reduced-motion: reduce) {
    
    .nsf-lista-animata li {
        opacity: 1; transform: none; transition: background 0.3s ease, padding 0.3s ease; }
        
}





/* 
________________________________________________________________________________________________________________________________________________________
    DL ANIMATA
--------------------------------------------------------------------------------------------------------------------------------------------------------
    DT con SVG
________________________________________________________________________________________________________________________________________________________
*/
.nsf-dl-animata {
    margin: 0 0 24px 0; padding: 0; }
    
.nsf-dl-animata dt, .nsf-dl-animata dd {
    opacity: 0; transition: opacity 0.5s ease-out, transform 0.5s ease-out, background 0.3s ease; }
    
.nsf-dl-animata dt {
    display: flex; align-items: center; gap: 12px; padding: 16px 0 8px 0; margin: 0; 
    font-weight: 600; color: var(--nsf-black); transform: translateY(-30px); font-size:18px; }

.nsf-dl-animata dt svg {
    flex-shrink: 0; width: 28px; height: 28px; fill: var(--nsf-red); }
    
.nsf-dl-animata dd {
    padding: 0 0 16px 40px; margin: 0; border-bottom: 1px solid var(--nsf-gray-200);  color: var(--nsf-black-soft); transform: translateY(30px); }
    
.nsf-dl-animata dd:last-of-type {
    border-bottom: none; }
    
.nsf-dl-animata dt.visible, .nsf-dl-animata dd.visible {
    opacity: 1; transform: translateY(0); }
    
.nsf-dl-animata.su-sfondo-nero dt {
    color: var(--nsf-white); }
    
.nsf-dl-animata.su-sfondo-nero dt svg {
    fill: var(--nsf-red); }
    
.nsf-dl-animata.su-sfondo-nero dd {
    border-bottom-color: var(--nsf-white-10); color: var(--nsf-white-warm); }
    
@media (prefers-reduced-motion: reduce) {
    .nsf-dl-animata dt, .nsf-dl-animata dd {
        opacity: 1; transform: none; transition: background 0.3s ease; }
}


.segmented-control {
    display: flex; position: relative; background: var(--nsf-gray-400); border-radius: 8px; padding: 4px;
    max-width: 500px; margin: 0 auto 30px auto; }
    
.segmented-control input[type="radio"] {
    display: none; }
    
.segmented-control label {
    flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 20px;
    font-size: 15px; font-weight: 600; color: var(--nsf-gray-600); cursor: pointer; transition: color 0.3s ease;
    position: relative; z-index: 2; border-radius: 6px; }
    
.segmented-control label svg {
    width: 20px; height: 20px; fill: currentColor; }
    
.segmented-control input[type="radio"]:checked + label {
    color: var(--nsf-white); }
    
.segmented-control .slider {
    position: absolute; top: 4px; bottom: 4px; width: calc(50% - 4px); background: var(--nsf-red);
    border-radius: 6px; transition: transform 0.3s ease; z-index: 1; }
    
.segmented-control input#tab-online:checked ~ .slider {
    transform: translateX(100%); }

.tab-content {
    display: none; opacity: 0; transform: translateY(10px); transition: opacity 0.3s ease, transform 0.3s ease; }
    
.tab-content.active {
    display: block; opacity: 1; transform: translateY(0); }
    
    


/* ============================================
   How To Steps (con numeri circolari)
   ============================================ */
.how-to-steps {
    list-style: none; padding: 0; margin: 0 0 10px 0; counter-reset: step-counter; }

.how-to-steps li {
    display: flex; align-items: flex-start; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--nsf-gray-250);
    opacity: 0; transform: translateX(-20px); transition: opacity 0.4s ease, transform 0.4s ease; }

.how-to-steps li.visible {
    opacity: 1; transform: translateX(0); }

.how-to-steps li:last-child {
    border-bottom: none; }

.how-to-steps li::before {
    counter-increment: step-counter; content: counter(step-counter); flex-shrink: 0; display: flex; align-items: center;
    justify-content: center; width: 36px; height: 36px; background: var(--nsf-cta-info); color: var(--nsf-white);
    font-size: 16px; font-weight: 700; border-radius: 6px; box-shadow: 0 4px 8px rgba(0, 123, 255, 0.35); }

.how-to-steps li span {
    padding-top: 6px; line-height: 1.5; }


/* ============================================
   Riassunto Corso
   ============================================ */
.contenitore-riassunto-corso {
    opacity: 0; transform: translateY(15px); transition: opacity 0.3s ease, transform 0.3s ease; }

.contenitore-riassunto-corso.visible {
    opacity: 1; transform: translateY(0); }


/* ============================================
   Corso Dettagli (dt da sopra, dd da sotto, svg pulse)
   ============================================ */
dl.corso-dettagli dt {
    opacity: 0; transform: translateY(-20px); transition: opacity 0.4s ease, transform 0.4s ease; }

dl.corso-dettagli dd {
    opacity: 0; transform: translateY(20px); transition: opacity 0.4s ease, transform 0.4s ease; }

dl.corso-dettagli dt.visible,
dl.corso-dettagli dd.visible {
    opacity: 1; transform: translateY(0); }

dl.corso-dettagli dt svg {
    opacity: 0; transform: scale(0); }

dl.corso-dettagli dt.visible svg {
    animation: svgPulse 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
    animation-delay: 0.25s; }

@keyframes svgPulse {
    0% { opacity: 0; transform: scale(0); }
    50% { opacity: 1; transform: scale(1.3); }
    100% { opacity: 1; transform: scale(1); }
}