.elementor-10693 .elementor-element.elementor-element-2be777c > .elementor-background-overlay{opacity:1;}.elementor-10693 .elementor-element.elementor-element-2be777c{margin-top:3%;margin-bottom:5%;}.elementor-10693 .elementor-element.elementor-element-6e476898 .elementor-heading-title{font-size:120px;line-height:120px;letter-spacing:2px;word-spacing:10px;color:var( --e-global-color-b9e19b2 );}.elementor-10693 .elementor-element.elementor-element-c68f456:not(.elementor-motion-effects-element-type-background), .elementor-10693 .elementor-element.elementor-element-c68f456 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF00;}.elementor-10693 .elementor-element.elementor-element-c68f456 > .elementor-background-overlay{opacity:0.2;transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-10693 .elementor-element.elementor-element-c68f456{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;padding:0% 0% 2% 0%;}.elementor-10693 .elementor-element.elementor-element-c0676f7 > .elementor-element-populated{margin:0px 0px 0px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0% 0% 0% 0%;}.elementor-10693 .elementor-element.elementor-element-5c00613{margin-top:0px;margin-bottom:0px;padding:0px 0px 0px 0px;}.elementor-10693 .elementor-element.elementor-element-e6c3478 > .elementor-element-populated{margin:0px 0px 0px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0% 0% 0% 0%;}.elementor-10693 .elementor-element.elementor-element-7dbead6 > .elementor-widget-container{margin:3% 0% 0% 0%;}.elementor-10693 .elementor-element.elementor-element-7dbead6{z-index:2;}.elementor-10693 .elementor-element.elementor-element-8ce4e2d{margin-top:0%;margin-bottom:3%;}.elementor-10693 .elementor-element.elementor-element-0dd0315 .elementor-icon-box-wrapper{text-align:start;}.elementor-10693 .elementor-element.elementor-element-76e48f9 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}:root{--page-title-display:none;}@media(max-width:1024px) and (min-width:768px){.elementor-10693 .elementor-element.elementor-element-e6c3478{width:100%;}}@media(max-width:1024px){.elementor-10693 .elementor-element.elementor-element-6e476898 .elementor-heading-title{font-size:100px;}.elementor-10693 .elementor-element.elementor-element-c68f456{padding:0% 0% 0% 0%;}.elementor-10693 .elementor-element.elementor-element-e6c3478 > .elementor-element-populated{padding:4% 4% 4% 4%;}.elementor-10693 .elementor-element.elementor-element-7dbead6 > .elementor-widget-container{margin:5% 0% 0% 0%;}.elementor-10693 .elementor-element.elementor-element-8ce4e2d{margin-top:3%;margin-bottom:3%;}}@media(max-width:767px){.elementor-10693 .elementor-element.elementor-element-2be777c{margin-top:2%;margin-bottom:8%;padding:0px 0px 0px 0px;}.elementor-10693 .elementor-element.elementor-element-6e476898{text-align:start;}.elementor-10693 .elementor-element.elementor-element-6e476898 .elementor-heading-title{font-size:60px;line-height:1em;}.elementor-10693 .elementor-element.elementor-element-c68f456{padding:0% 0% 0% 0%;}.elementor-10693 .elementor-element.elementor-element-c0676f7 > .elementor-element-populated{padding:0px 0px 0px 0px;}.elementor-10693 .elementor-element.elementor-element-e6c3478 > .elementor-element-populated{margin:0% 0% 0% 0%;--e-column-margin-right:0%;--e-column-margin-left:0%;padding:5% 5% 5% 5%;}.elementor-10693 .elementor-element.elementor-element-7dbead6 > .elementor-widget-container{margin:5% 0% 0% 0%;}.elementor-10693 .elementor-element.elementor-element-8ce4e2d{margin-top:7%;margin-bottom:7%;}.elementor-10693 .elementor-element.elementor-element-0dd0315 .elementor-icon-box-wrapper{text-align:start;}.elementor-10693 .elementor-element.elementor-element-0dd0315 .elementor-icon-box-title{margin-block-end:0px;}}/* Start custom CSS for html, class: .elementor-element-abf33b4 */<style>
/* --- 1. IL CONTENITORE (LOGICA DI SCORRIMENTO) --- */
.velolake-table-container.table-bici {
    width: 100% !important;
    margin: 20px 0 !important;
    padding: 0 !important;
    display: block !important;
    box-sizing: border-box !important;
    /* Su desktop lo scroll non serve, ma lo prepariamo */
    overflow-x: auto; 
    position: relative;
}

/* --- 2. LA TABELLA (LOGICA DESKTOP: 100%) --- */
.table-bici .velolake-pricing-table {
    width: 100% !important; /* Larghezza piena su computer */
    border-collapse: collapse;
    font-family: 'Inter', sans-serif;
    background: #ffffff;
    margin: 0 !important;
    table-layout: auto; /* Permette alla tabella di adattarsi su schermi grandi */
}

/* --- 3. FIX SPECIFICO PER MOBILE (Sotto i 768px) --- */
@media (max-width: 767px) {
    .velolake-table-container.table-bici {
        max-width: 100% !important; /* Usa 100% invece di 100vw per evitare bug di scroll */
        overflow-x: auto !important; 
        -webkit-overflow-scrolling: touch !important; 
        
        /* MODIFICA FONDAMENTALE: auto permette sia lo swipe della tabella che lo scroll della pagina */
        touch-action: auto !important; 
        
        /* Evita che il tocco rimanga "intrappolato" nella tabella */
        position: relative;
        z-index: 1;
    }

    .table-bici .velolake-pricing-table {
        width: 850px !important; 
        min-width: 850px !important;
        table-layout: fixed !important;
        
        /* Assicura che il tocco sulla tabella non blocchi lo scroll genitore */
        pointer-events: auto; 
    }
}

/* --- 4. STILE ESTETICO (UGUALE PER TUTTI) --- */
.table-bici .velolake-pricing-table th {
    padding: 15px;
    font-size: 13px;
    text-transform: uppercase;
    text-align: center;
    border-bottom: 2px solid #222 !important;
    background: #ffffff;
    color: #222;
}
.table-bici .velolake-pricing-table th:first-child { text-align: left; }

.table-bici .velolake-pricing-table td {
    padding: 12px 15px;
    border-bottom: 1px solid #f2f2f2 !important;
    text-align: center;
    font-size: 14px;
    vertical-align: middle;
}

/* Colonna Segmento e Magenta */
.table-bici .velolake-pricing-table td:first-child {
    text-align: left;
    color: #444;
}
.table-bici .velolake-pricing-table td strong {
    color: #f20769 !important; /* Magenta Velolake */
    font-weight: 700;
    display: block;
    line-height: 1.2;
}
.table-bici .velolake-pricing-table td small {
    display: block;
    color: #777;
    font-size: 11px;
    margin-top: 2px;
}

/* Badge Sconto Verde */
.table-bici .discount-badge {
    display: inline-block;
    font-size: 11px;
    color: #27ae60 !important;
    font-weight: bold;
    margin-left: 8px;
    background: #e9f7ef !important;
    padding: 2px 6px;
    border-radius: 4px;
}

/* Alternanza colori righe */
.table-bici .velolake-pricing-table tr:nth-child(odd) td:first-child { background-color: #fafafa !important; }
.table-bici .velolake-pricing-table tr:nth-child(even) td:first-child { background-color: #ffffff !important; }
.table-bici .velolake-pricing-table tr:hover { background-color: #fcfcfc !important; }

/* Reset bordi laterali */
.table-bici .velolake-pricing-table td, 
.table-bici .velolake-pricing-table th {
    border-left: none !important;
    border-right: none !important;
}
</style>/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-f8e857b */<style>
/* --- 1. IL CONTENITORE (LOGICA DI SCORRIMENTO) --- */
.velolake-table-container.table-accessori {
    width: 100% !important;
    margin: 20px 0 !important;
    padding: 0 !important;
    display: block !important;
    box-sizing: border-box !important;
    overflow-x: auto; /* Predispone lo scorrimento */
    position: relative;
}

/* --- 2. LA TABELLA (LOGICA DESKTOP: 100%) --- */
.table-accessori .velolake-pricing-table {
    width: 100% !important; /* Occupa tutto lo spazio su Desktop */
    border-collapse: collapse;
    font-family: 'Inter', sans-serif;
    background: #ffffff;
    margin: 0 !important;
    table-layout: auto;
}

/* --- 3. FIX SPECIFICO PER MOBILE (Sotto i 768px) --- */
@media (max-width: 767px) {
    .velolake-table-container.table-accessori {
        max-width: 100% !important; /* Cambiato da 100vw a 100% per stabilità */
        overflow-x: auto !important; 
        -webkit-overflow-scrolling: touch !important; 
        
        /* FIX: 'auto' permette sia lo swipe orizzontale della tabella che lo scroll verticale della pagina */
        touch-action: auto !important; 
        position: relative;
    }

    .table-accessori .velolake-pricing-table {
        /* Manteniamo la larghezza fissa per non schiacciare i testi */
        width: 600px !important; 
        min-width: 600px !important;
        table-layout: fixed !important;
    }
}

/* --- 4. STILE ESTETICO (ISOLATO PER .table-accessori) --- */
.table-accessori .velolake-pricing-table th {
    padding: 20px 15px;
    font-size: 14px;
    text-transform: uppercase;
    text-align: center;
    border-bottom: 2px solid #222 !important;
    color: #222;
    background: #ffffff;
}
.table-accessori .velolake-pricing-table th:first-child { text-align: left; }

.table-accessori .velolake-pricing-table td {
    padding: 12px 15px;
    border-bottom: 1px solid #f2f2f2 !important;
    text-align: center;
    font-size: 14px;
    vertical-align: middle;
    color: #333;
}

/* Titolo Accessorio (Magenta) */
.table-accessori .velolake-pricing-table td:first-child {
    text-align: left;
    color: #444;
}
.table-accessori .velolake-pricing-table td strong {
    color: #f20769 !important; /* Magenta Velolake */
    font-weight: 700;
    display: block;
    line-height: 1.2;
}

/* Descrizione piccola */
.table-accessori .velolake-pricing-table td small {
    display: block;
    color: #777;
    font-size: 11px;
    margin-top: 2px;
}

/* Badge Unità (Day, Call, ecc.) */
.table-accessori .discount-badge {
    display: inline-block;
    font-size: 10px;
    color: #666 !important;
    font-weight: bold;
    margin-left: 6px;
    background: #eeeeee !important;
    padding: 2px 5px;
    border-radius: 4px;
}

/* Zebra Styling (Alternanza colori prima colonna) */
.table-accessori .velolake-pricing-table tr:nth-child(odd) td:first-child {
    background-color: #fafafa !important;
}
.table-accessori .velolake-pricing-table tr:nth-child(even) td:first-child {
    background-color: #ffffff !important;
}

/* Hover riga */
.table-accessori .velolake-pricing-table tr:hover {
    background-color: #fcfcfc !important;
}

/* Reset bordi laterali */
.table-accessori .velolake-pricing-table td, 
.table-accessori .velolake-pricing-table th {
    border-left: none !important;
    border-right: none !important;
}
</style>/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-76e48f9 */<style>
.velolake-top-routes-clean { 
    max-width: 1250px; 
    margin: 20px auto; 
    padding: 0 15px; 
    box-sizing: border-box;
}

.routes-grid { 
    display: grid; 
    grid-template-columns: repeat(3, 1fr); 
    gap: 25px; 
}

.route-card { 
    height: 450px; 
    border-radius: 20px; 
    background-size: cover; 
    background-position: center; 
    overflow: hidden; 
    position: relative; 
    transition: transform 0.3s ease, box-shadow 0.3s ease; 
    cursor: pointer; 
}

.route-card:hover { transform: translateY(-5px); box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15); }

.route-overlay { 
    position: absolute; 
    top: 0; left: 0; 
    width: 100%; height: 100%; 
    background: linear-gradient(0deg, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.15) 70%); 
    display: flex; 
    align-items: flex-end; 
    padding: 40px 30px; 
    box-sizing: border-box; 
    text-decoration: none !important; 
}

.route-content { 
    color: #ffffff; 
    text-align: left; 
    width: 100%; 
}

/* --- TITOLI UNIFORMATI (Usa .elementor-heading-title nell'HTML) --- */
.route-content .elementor-heading-title { 
    color: #ffffff !important; 
    margin: 0 0 10px 0 !important; 
    padding: 0 !important;
    font-size: 1.8rem !important; 
    font-weight: 700 !important; 
    text-transform: uppercase;
    line-height: 1.1 !important;
}

.route-content p { 
    color: #e0e0e0; 
    margin: 0 0 25px 0 !important; 
    font-size: 1.2rem !important; 
    line-height: 1.6;
    max-width: 90%;
}

/* STILE PULSANTE UNIFORMATO */
.route-btn-elementor { 
    display: inline-block; 
    background-color: #F20769; 
    color: #ffffff; 
    padding: 14px 28px; 
    border-radius: 10px; 
    font-weight: 600; 
    text-transform: uppercase; 
    font-size: 13px; 
    transition: all 0.3s ease; 
    border: none;
}

.route-card:hover .route-btn-elementor { 
    background-color: #ffffff; 
    color: #F20769; 
}

@media (max-width: 992px) { .routes-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { 
    .routes-grid { grid-template-columns: 1fr; } 
    .route-card { height: 380px; } 
    .route-content .elementor-heading-title { font-size: 1.5rem !important; }
}
</style>/* End custom CSS */