/* ========================================
   MOBILE & iOS FIXES
   ======================================== */

/* Fix per Samsung Mobile - Header che esce dallo schermo */
@media screen and (max-width: 768px) {
    body {
        overflow-x: hidden !important;
        width: 100vw !important;
        max-width: 100vw !important;
    }
    
    .main-nav {
        width: 100vw !important;
        max-width: 100vw !important;
        left: 0 !important;
        right: 0 !important;
        overflow: hidden !important;
    }
    
    .glass-nav {
        width: 100% !important;
        max-width: 100vw !important;
        left: 0 !important;
        right: 0 !important;
        overflow: hidden !important;
    }
    
    /* Fix per contenitori che potrebbero causare overflow */
    .container, .container-fluid {
        max-width: 100vw !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }
    
    /* Fix per elementi che potrebbero estendersi oltre lo schermo */
    .hero-content, .content-card, .feature-card {
        max-width: 100vw !important;
    }
}

/* Fix specifici per iOS Safari */
@supports (-webkit-touch-callout: none) {
    /* iOS Safari Compatibility Fixes */
    body {
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        -webkit-text-size-adjust: 100%;
        -ms-text-size-adjust: 100%;
        /* Fix per iOS Safari viewport */
        width: 100vw;
        max-width: 100vw;
        overflow-x: hidden;
    }
    
    /* Fix per header su iOS */
    .main-nav {
        width: 100vw !important;
        max-width: 100vw !important;
        left: 0 !important;
        right: 0 !important;
        overflow: hidden !important;
        /* Fix per iOS Safari backdrop-filter */
        -webkit-backdrop-filter: blur(20px) saturate(180%);
        backdrop-filter: blur(20px) saturate(180%);
    }
    
    .glass-nav {
        width: 100% !important;
        max-width: 100vw !important;
        left: 0 !important;
        right: 0 !important;
        overflow: hidden !important;
        /* Fix per iOS Safari backdrop-filter */
        -webkit-backdrop-filter: blur(16px);
        backdrop-filter: blur(16px);
    }
    
    /* Fix per contenitori su iOS */
    .container, .container-fluid {
        max-width: 100vw !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
        overflow: hidden !important;
    }
    
    /* Fix per elementi con backdrop-filter su iOS */
    .content-card {
        -webkit-backdrop-filter: blur(12px);
        backdrop-filter: blur(12px);
    }
    
    /* Fix per pulsanti neumorfici su iOS */
    .neumorphic-btn {
        -webkit-backdrop-filter: blur(12px);
        backdrop-filter: blur(12px);
    }
}

/* Fix per dispositivi con schermi molto piccoli */
@media screen and (max-width: 480px) {
    body {
        overflow-x: hidden !important;
        width: 100vw !important;
        max-width: 100vw !important;
    }
    
    .main-nav, .glass-nav {
        width: 100vw !important;
        max-width: 100vw !important;
        left: 0 !important;
        right: 0 !important;
        overflow: hidden !important;
    }
    
    /* Riduci padding per schermi molto piccoli */
    .container, .container-fluid {
        padding-left: 0.5rem !important;
        padding-right: 0.5rem !important;
    }
}

/* Fix per dispositivi con altezza ridotta (landscape mobile) */
@media screen and (max-height: 500px) and (orientation: landscape) {
    .main-nav {
        min-height: 60px !important;
    }
    
    .hero-content {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }
}

/* Fix per dispositivi con pixel ratio alto (retina) */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .main-nav, .glass-nav {
        /* Migliora la qualità del backdrop-filter su schermi retina */
        -webkit-backdrop-filter: blur(20px) saturate(180%);
        backdrop-filter: blur(20px) saturate(180%);
    }
}

/* Fix per dispositivi con supporto touch */
@media (hover: none) and (pointer: coarse) {
    /* Migliora l'esperienza touch */
    .neumorphic-btn {
        min-height: 44px !important; /* Apple HIG recommendation */
        min-width: 44px !important;
    }
    
    .cta-button-main, .cta-button-partners, .cta-button-foundation, .cta-button-launch, .cta-button-blueprint {
        min-height: 44px !important;
        padding: 0.75rem 1.5rem !important;
    }
}

/* Fix per dispositivi con supporto hover */
@media (hover: hover) and (pointer: fine) {
    /* Mantieni effetti hover solo su dispositivi desktop */
    .neumorphic-btn:hover {
        transform: translateY(-2px);
    }
    
    .cta-button-main:hover, .cta-button-partners:hover, .cta-button-foundation:hover, .cta-button-launch:hover, .cta-button-blueprint:hover {
        transform: translateY(-3px) scale(1.05);
    }
}

/* ========================================
   ADDITIONAL MOBILE OPTIMIZATIONS
   ======================================== */

/* Fix per viewport mobile */
@media screen and (max-width: 768px) {
    html, body {
        /* Forza il viewport corretto su mobile */
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        /* Previene zoom automatico su input */
        -webkit-text-size-adjust: 100%;
        -ms-text-size-adjust: 100%;
    }
    
    /* Fix per elementi che potrebbero causare scroll orizzontale */
    .hero-content, .content-card, .feature-card, .service-widget-item {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }
    
    /* Fix per navigazione mobile */
    .main-nav {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        z-index: 1001 !important;
    }
    
    /* Fix per contenuti che potrebbero estendersi oltre lo schermo */
    .container, .container-fluid, .row, .col, .col-12 {
        max-width: 100% !important;
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }
}

/* Fix specifici per iOS Safari aggiuntivi */
@supports (-webkit-touch-callout: none) {
    /* iOS Safe Area Support */
    .main-nav {
        padding-top: env(safe-area-inset-top) !important;
        padding-left: env(safe-area-inset-left) !important;
        padding-right: env(safe-area-inset-right) !important;
        padding-bottom: env(safe-area-inset-bottom) !important;
    }
    
    /* Fix per iOS Safari scrolling */
    html {
        scroll-behavior: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }
    
    /* Fix per iOS Safari button tap highlight */
    * {
        -webkit-tap-highlight-color: transparent !important;
        -webkit-touch-callout: none !important;
        -webkit-user-select: none !important;
        user-select: none !important;
    }
    
    /* Fix per input e textarea su iOS */
    input, textarea, select {
        -webkit-user-select: text !important;
        user-select: text !important;
        -webkit-appearance: none !important;
        border-radius: 0 !important;
    }
    
    /* Fix per backdrop-filter su iOS Safari */
    .main-nav, .glass-nav, .content-card, .neumorphic-btn {
        /* Fallback per dispositivi iOS che non supportano backdrop-filter */
        background: rgba(15, 23, 42, 0.95) !important;
        /* Mantieni backdrop-filter per dispositivi che lo supportano */
        -webkit-backdrop-filter: blur(20px) saturate(180%);
        backdrop-filter: blur(20px) saturate(180%);
    }
    
    /* Fix per gradient text su iOS Safari */
    .title-color-partners span,
    .title-color-foundation span,
    .title-color-launch span,
    .title-color-blueprint span,
    .text-gradient-main,
    .text-gradient-launch,
    .text-gradient-blueprint {
        /* Fallback per dispositivi iOS che non supportano gradient text */
        background: none !important;
        -webkit-background-clip: unset !important;
        -webkit-text-fill-color: unset !important;
        /* Colori di fallback */
        color: #38bdf8 !important;
    }
    
    /* Fix per hover effects su iOS */
    .cta-button-partners:hover,
    .cta-button-foundation:hover,
    .cta-button-launch:hover,
    .cta-button-blueprint:hover,
    .cta-button-main:hover {
        transform: none !important;
        /* Mantieni solo i cambiamenti di colore */
        background-color: inherit !important;
    }
}

/* Fix per dispositivi Android */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
    /* Fix per Chrome su Android */
    .main-nav, .glass-nav {
        -webkit-backdrop-filter: blur(20px) saturate(180%);
        backdrop-filter: blur(20px) saturate(180%);
    }
}

/* Fix per dispositivi con supporto touch avanzato */
@media (pointer: coarse) and (hover: none) {
    /* Migliora l'esperienza touch su tutti i dispositivi */
    .neumorphic-btn, .cta-button-main, .cta-button-partners, .cta-button-foundation, .cta-button-launch, .cta-button-blueprint {
        /* Aumenta l'area di touch */
        min-height: 48px !important;
        min-width: 48px !important;
        /* Aggiungi feedback visivo per touch */
        transition: all 0.2s ease !important;
    }
    
    /* Feedback visivo per touch */
    .neumorphic-btn:active, .cta-button-main:active, .cta-button-partners:active, .cta-button-foundation:active, .cta-button-launch:active, .cta-button-blueprint:active {
        transform: scale(0.95) !important;
        opacity: 0.8 !important;
    }
}

/* ========================================
   HEADER PRINCIPALI - RIPRISTINO STILE ORIGINALE
   ======================================== */

/* IMPORTANTE: Non sovrascrivere lo stile originale dell'header */
/* Lo stile è definito in home-style.css e deve rimanere intatto */

/* ========================================
   FIX PER CONTENITORE HEADER CHE ESCE DALLO SCHERMO
   ======================================== */

/* Fix per il contenitore fixed dell'header */
.fixed.top-0.left-0.right-0.z-50.container {
    /* Assicura che il contenitore non esca dallo schermo */
    width: 100vw !important;
    max-width: 100vw !important;
    /* Previene overflow orizzontale */
    /* Assicura che il contenuto si adatti */
    box-sizing: border-box !important;
    /* Centra il contenuto */
    margin: 0 auto !important;
    /* Spacing laterale appropriato */
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}

/* Fix per il contenuto interno dell'header */
.fixed.top-0.left-0.right-0.z-50.container .main-nav {
    /* Assicura che la nav si adatti al contenitore */
    width: 100% !important;
    max-width: 91% !important;
    /* Previene overflow */
}

/* Fix per il contenuto della nav */
.fixed.top-0.left-0.right-0.z-50.container .main-nav .py-3.px-6 {
    /* Assicura che il contenuto interno si adatti */
    width: 100% !important;
    max-width: 100% !important;
    /* Previene overflow */
}

/* ========================================
   COMPORTAMENTO MOBILE VS DESKTOP - DIFFERENZIAZIONE CORRETTA
   ======================================== */

/* ========================================
   MOBILE: HEADER FISSO IN ALTO
   ======================================== */

/* Su mobile: header fisso in alto */
@media screen and (max-width: 768px) {
    .main-nav {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100vw !important;
        max-width: 100vw !important;
        /* Su mobile possiamo forzare overflow hidden */
        overflow: hidden !important;
        /* IMPORTANTE: Non modificare lo stile originale */
        /* Mantieni backdrop-filter, box-shadow, etc. da home-style.css */
    }
    
    /* IMPORTANTE: Su mobile, il menu deve rimanere sempre visibile */
    /* Previeni che -translate-y-full nasconda il menu su mobile */
    .main-nav.-translate-y-full {
        transform: none !important; /* Rimuovi la trasformazione che nasconde il menu */
        top: 0 !important; /* Mantieni sempre in alto */
        position: fixed !important; /* Mantieni sempre fisso */
    }
    
    /* IMPORTANTE: Per le pagine dei servizi, assicura che position: fixed funzioni */
    .main-nav.w-full.fixed.top-0 {
        position: fixed !important; /* Forza position: fixed su mobile */
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        z-index: 1001 !important;
    }
    
    /* Riduci il padding del contenuto principale su mobile */
    main {
        padding-top: 80px !important; /* Solo per il menu principale */
    }
    
    /* Su mobile: nascondi completamente il menu secondario */
    .glass-nav {
        display: none !important;
    }
}

/* ========================================
   DESKTOP: HEADER STICKY CON STILE ORIGINALE
   ======================================== */

/* Su desktop: header sticky che rimane fisso */
@media screen and (min-width: 769px) {
    .main-nav {
        /* IMPORTANTE: Rispetta la classe fixed delle pagine dei servizi */
        /* Se ha già position: fixed, non sovrascriverla */
        position: sticky !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        /* IMPORTANTE: Su desktop permette hover effects completi */
        overflow: visible !important;
        /* IMPORTANTE: Non modificare lo stile originale */
        /* Mantieni backdrop-filter, box-shadow, etc. da home-style.css */
        /* Z-index alto per essere sopra tutto */
        z-index: 1001 !important;
        /* Assicura che il menu rimanga fisso durante lo scroll */
        will-change: transform !important;
        /* Transizione fluida per eventuali animazioni */
        transition: transform 0.3s ease-in-out !important;
    }
    
    /* IMPORTANTE: Per le pagine dei servizi, mantieni position: fixed */
    .main-nav.w-full.fixed.top-0 {
        position: relative !important; /* Mantieni fixed per le pagine dei servizi */
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: visible !important;
        z-index: 1001 !important;
    }
    
    /* Assicura che il menu principale rimanga sempre visibile su desktop */
    .main-nav.-translate-y-full {
        /* Anche quando si nasconde, mantieni la posizione corretta */
        top: 0 !important;
        transform: translateY(-100%) !important;
    }
    
    /* Ripristina il padding normale del contenuto */
    main {
        padding-top: 0 !important;
    }
}

/* ========================================
   MENU SECONDARIO - COMPORTAMENTO DESKTOP CORRETTO
   ======================================== */

/* Su desktop: ripristina il comportamento sticky corretto */
@media screen and (min-width: 769px) {
    .glass-nav {
        /* Ripristina il comportamento sticky originale */
        position: relative !important;
        top: 10px !important; /* Posizione iniziale sotto il menu principale */
        z-index: 1000 !important;
        /* Rimuovi tutti i fix mobile */
        left: auto !important;
        right: auto !important;
        width: auto !important;
        max-width: 82% !important;
        margin: auto !important;
        border-radius: 0.75rem !important;
        /* Transizione fluida per il posizionamento */
        transition: top 0.3s ease-in-out !important;
        /* Assicura che il menu secondario rimanga sempre visibile */
        will-change: top !important;
    }
    
    /* Quando il menu principale è nascosto, il secondario rimane fisso al suo posto */
    .main-nav.-translate-y-full ~ .glass-nav {
        top: 95px !important; /* Mantiene la stessa posizione relativa */
    }
    
    /* Assicura che il menu secondario non scompaia mai su desktop */
    .glass-nav.-translate-y-full {
        /* Anche quando si nasconde, mantiene la sua posizione sticky */
        position: sticky !important;
        top: 95px !important;
        transform: translateY(-100%) !important;
    }
}

/* ========================================
   FIX PER BOTTONI TAGLIATI E SPACING MENU
   ======================================== */

/* Fix per bottoni che potrebbero essere tagliati */
.neumorphic-btn,
.cta-button-main,
.cta-button-partners,
.cta-button-foundation,
.cta-button-launch,
.cta-button-blueprint {
    /* Assicura che i bottoni non escano dal loro contenitore */
    max-width: 100% !important;
    /* IMPORTANTE: Non forzare overflow hidden qui per permettere hover effects */
    box-sizing: border-box !important;
    /* Previene che i bottoni si estendano oltre i bordi */
    word-wrap: break-word !important;
    white-space: normal !important;
}

/* Fix per contenitori dei bottoni */
.flex > *,
.grid > * {
    /* Assicura che gli elementi flex/grid non escano */
    max-width: 100% !important;
    /* IMPORTANTE: Non forzare overflow hidden qui per permettere hover effects */
    box-sizing: border-box !important;
}

/* Fix per contenitori che potrebbero causare tagli */
.container,
.container-fluid {
    /* Assicura che i contenitori non causino tagli */
    /* IMPORTANTE: Non forzare overflow visible qui per permettere hover effects */
    word-wrap: break-word !important;
}

/* Fix per elementi che potrebbero essere tagliati */
.hero-content,
.content-card,
.feature-card,
.service-widget-item {
    /* Assicura che il contenuto non sia tagliato */
    /* IMPORTANTE: Non forzare overflow visible qui per permettere hover effects */
    word-wrap: break-word !important;
    white-space: normal !important;
}

/* ========================================
   FIX SPECIFICI PER INDEX - PERMETTE HOVER EFFECTS
   ======================================== */

/* Fix specifici per l'index - permette ai bottoni di espandersi durante hover */
@media screen and (min-width: 769px) {
    /* Su desktop, permetti ai bottoni di espandersi durante hover */
    .main-nav .neumorphic-btn:hover {
        /* Permetti al bottone di espandersi oltre i bordi del contenitore */
        z-index: 1002 !important; /* Sopra tutto */
        /* Assicura che l'effetto hover sia visibile */
        overflow: visible !important;
        /* IMPORTANTE: Non sovrascrivere gli effetti hover dell'index */
        /* Gli effetti hover sono definiti in home-style.css */
    }
    
    /* Assicura che il container del menu non tagli i bottoni durante hover */
    .main-nav .container,
    .main-nav .container-fluid {
        /* Su desktop, non forzare overflow hidden per permettere hover effects */
        overflow: visible !important;
    }
    
    /* Assicura che il menu principale non tagli i bottoni durante hover */
    .main-nav {
        /* Su desktop, non forzare overflow hidden per permettere hover effects */
        overflow: visible !important;
    }
    
    /* IMPORTANTE: Ripristina gli hover effects originali dell'index */
    .main-nav .neumorphic-btn {
        /* Ripristina le proprietà originali per permettere hover effects */
        position: relative !important;
        overflow: hidden !important; /* Importante per l'effetto scia */
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }
    
    /* Ripristina l'effetto scia bianca */
    .main-nav .neumorphic-btn::before {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        left: -20% !important;
        width: 100% !important;
        height: 100% !important;
        background: linear-gradient(
            90deg,
            transparent,
            rgba(255, 255, 255, 0.1),
            transparent
        ) !important;
        transition: left 0.5s !important;
        z-index: 1 !important;
    }
    
    /* Ripristina l'effetto hover della scia */
    .main-nav .neumorphic-btn:hover::before {
        left: 20% !important;
    }
    
    /* Ripristina gli effetti hover delle icone */
    .main-nav .neumorphic-btn:hover .icon-foundation,
    .main-nav .neumorphic-btn:hover .icon-launch,
    .main-nav .neumorphic-btn:hover .icon-blueprint,
    .main-nav .neumorphic-btn:hover .icon-partners {
        transform: scale(1.1) !important;
        transition: all 0.3s ease !important;
    }
}

/* Fix per mobile - mantieni overflow hidden per evitare problemi */
@media screen and (max-width: 768px) {
    .main-nav,
    .main-nav .container,
    .main-nav .container-fluid {
        /* Su mobile, mantieni overflow hidden per evitare problemi */
        overflow: hidden !important;
    }
    
    /* Su mobile, disabilita hover effects per performance */
    .main-nav .neumorphic-btn:hover {
        transform: none !important;
    }
    
    .main-nav .neumorphic-btn:hover::before {
        display: none !important;
    }
}

@media screen and (max-width: 768px) {
    .main-nav .md\:hidden a {
        color: #c9d1d9 !important; /* Colore grigio chiaro visibile */
        background: none !important;
        -webkit-background-clip: unset !important;
        -webkit-text-fill-color: unset !important;
    }

    /* Migliora il colore al passaggio del mouse */
    .main-nav .md\:hidden a:hover {
        color: #ffffff !important;
    }
    
        .main-nav button.md\:hidden {
        position: relative; /* Necessario perché z-index funzioni */
        z-index: 9999 !important; /* Un valore altissimo per garanzia */
    }

}

.mobile-menu-open .md\:hidden {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    padding-bottom: 25px;
}