@media (max-width: 768px) {
    /* Banner voli: button accanto al titolo e niente spazi inutili */
    .flight-deals-banner {
        padding: 1rem 0 !important;
    }
    .flight-deals-banner .banner-content-simple {
        display: flex;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 0.5rem !important;
        padding: 0 !important;
        flex-wrap: wrap !important; /* consenti al bottone di andare sotto quando serve */
    }
    .flight-deals-banner .banner-text-simple {
        margin: 0 !important;
        text-align: left !important;
        display: flex;
        align-items: center;
        gap: 0.5rem;
        min-width: 0; /* consente al testo di restringersi senza andare a capo inutilmente */
    }
    .flight-deals-banner .banner-text-simple h3 {
        margin: 0 !important;
        font-size: 1.1rem !important;
        line-height: 1.2 !important;
        white-space: normal; /* consenti di andare a capo su schermi piccoli */
    }
    .flight-deals-banner .banner-text-simple p {
        display: none; /* nascondi il sottotitolo su mobile per lasciare spazio al bottone */
    }
    .flight-deals-banner .banner-btn-simple {
        margin: 0.4rem 0 0 0 !important; /* va sotto al titolo quando wrap */
        white-space: nowrap;
        flex-shrink: 0;
        align-self: flex-start; /* allinea a sinistra sotto al titolo */
        padding: 0.5rem 0.75rem !important;
        font-size: 0.9rem !important;
    }

    /* Footer più compatto */
    footer {
        padding: 1.5rem 0 0.5rem 0 !important;
    }
    .footer-content {
        gap: 1rem !important;
        padding: 0 !important;
    }
    .footer-section {
        padding: 0.5rem 0 !important;
        margin: 0 !important;
    }
    .footer-section h3, .footer-section h4 {
        margin-bottom: 0.5rem !important;
        font-size: 1rem !important;
    }
    .footer-section p {
        margin: 0.3rem 0 !important;
        font-size: 0.9rem !important;
        line-height: 1.4 !important;
    }
    .footer-section ul {
        margin: 0 !important;
        padding: 0 !important;
    }
    .footer-section li {
        margin: 0.2rem 0 !important;
        font-size: 0.9rem !important;
    }
    .footer-bottom {
        padding: 0.8rem 0 !important;
        margin-top: 0.5rem !important;
        font-size: 0.8rem !important;
    }
}

/* Mantieni inline su mobile medio (481-768px) per un aspetto più compatto */
@media (min-width: 481px) and (max-width: 768px) {
    .flight-deals-banner .banner-content-simple {
        flex-wrap: nowrap !important;
    }
    .flight-deals-banner .banner-text-simple h3 {
        white-space: nowrap; /* su schermi medi resta in linea */
        font-size: 1.1rem !important;
    }
    .flight-deals-banner .banner-btn-simple {
        margin-top: 0 !important;
        align-self: center;
    }
}

/* Allinea la seconda riga del titolo sotto la parola "Occasioni" (emoji a margine) */
@media (max-width: 480px) {
    .flight-deals-banner .banner-text-simple {
        display: block !important;
    }
    .flight-deals-banner .banner-text-simple h3 {
        /* Hanging indent: l'emoji "sporge" a sinistra, le righe successive partono allineate al testo */
        padding-left: 1.6em;
        text-indent: -1.6em;
    }
}
@media (max-width: 768px) {
    .hero {
        padding: 4rem 1rem; /* Ridotto padding verticale */
        min-height: auto; /* Rimuovo altezza minima */
    }

    .hero-content h1 {
        font-size: 2.5rem; /* Titolo più piccolo */
    }

    .section-header {
        padding: 2rem 0; /* Padding ridotto per header sezioni */
    }

    .container {
        padding: 0 1rem; /* Padding laterale ridotto */
    }

    .featured-flights,
    .featured-destinations,
    .hot-deals,
    .flight-deals-banner {
        padding: 2rem 0; /* Padding sezioni ridotto */
    }

    .footer-content {
        grid-template-columns: 1fr; /* Footer a colonna singola */
        text-align: center;
        gap: 1.5rem;
    }

    .footer-section ul {
        padding-left: 0;
    }
}

/* --- Touch Target Size (min 44x44px) --- */
button, .nav-link, .cta-button, .deal-btn, .offer-cta, .hero-service-button, .hamburger {
  min-width: 44px;
  min-height: 44px;
  display: inline-flex; /* Aggiunto per centrare il testo */
  align-items: center; /* Aggiunto per centrare il testo */
  justify-content: center; /* Aggiunto per centrare il testo */
  padding: 0.5rem 1rem;
  font-size: 1rem;
  line-height: 1.2;
}/* --- Spacing tra link menu mobile --- */
@media (max-width: 800px) {
    .nav-menu {
        gap: 0.5rem;
    }
    .nav-link {
        display: block;
        margin-bottom: 0.5rem;
        padding: 0.75rem 1.5rem;
    }
}

/* --- Pull-to-refresh gesture fix --- */
html, body {
    overscroll-behavior-y: contain;
}

/* --- Viewport units moderni (dvh) --- */
@supports (height: 100dvh) {
    /* Usa dvh solo dove serve, non sul banner per evitare spazi enormi */
    .hero, .main, .section {
        min-height: 100dvh;
        height: auto;
    }
}

/* Salvaguardia extra: su mobile annulla qualunque min-height sul banner */
@media (max-width: 768px) {
    .banner-content-simple {
        min-height: auto !important;
        height: auto !important;
    }
}
/* Mobile Optimization CSS - Ottimizzazioni specifiche per dispositivi mobili */

/* Miglioramenti per touch devices */
@media (hover: none) and (pointer: coarse) {
    /* Aumenta le aree di touch per una migliore usabilità */
    .nav-link,
    .cta-button,
    .deal-btn,
    .hero-service-button,
    .read-more {
        min-height: 44px;
        min-width: 44px;
        padding: 12px 16px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    /* Rimuove effetti hover su dispositivi touch */
    .offer-card:hover,
    .deal-card:hover,
    .guide-card:hover {
        transform: none;
        box-shadow: inherit;
    }
    
    /* Migliora la responsività dei tap */
    .offer-card:active,
    .deal-card:active,
    .guide-card:active {
        transform: scale(0.98);
        transition: transform 0.1s ease;
    }
}

/* Ottimizzazioni per schermi molto piccoli (< 375px) */
@media (max-width: 374px) {
    .container {
        padding: 0 0.75rem;
    }
    
    .nav-logo h1 {
        font-size: 1.5rem;
    }
    
    .nav-logo span {
        font-size: 0.65rem;
    }
    
    .hero h1 {
        font-size: 1.8rem;
        line-height: 1.2;
    }
    
    .hero-subtitle {
        font-size: 0.9rem;
    }
    
    .section-subtitle {
        font-size: 0.9rem;
    }
    
    /* Grid ultra-compatto per schermi piccoli */
    .hero-services-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    .flights-grid,
    .destinations-grid,
    .deals-grid-2 {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    /* Card più compatte */
    .deal-card,
    .guide-card,
    .offer-card {
        padding: 0.75rem;
        margin-bottom: 1rem;
    }
    
    .deal-route,
    .guide-card h3 {
        font-size: 0.9rem;
    }
    
    .deal-price {
        font-size: 1.1rem;
    }
}

/* Ottimizzazioni per landscape su mobile */
@media (max-height: 500px) and (orientation: landscape) {
    .hero {
        padding: 2rem 0 1rem;
    }
    
    .hero h1 {
        font-size: 1.8rem;
        margin-bottom: 0.5rem;
    }
    
    .hero-subtitle {
        font-size: 0.9rem;
        margin-bottom: 1rem;
    }
    
    .hero-services-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 1rem;
    }
    
    .hero-service-image {
        height: 80px;
    }
    
    .hero-service-content {
        padding: 0.75rem;
    }
    
    .navbar {
        padding: 0.5rem 0;
    }
    
    .nav-container {
        padding: 0.5rem 1.5rem;
    }
}

/* Hide hamburger menu on desktop */
@media (min-width: 769px) {
    .hamburger {
        display: none !important;
    }
}

/* Miglioramenti per la navigazione mobile */
@media (max-width: 768px) {
    /* Hamburger menu più accessibile */
    .hamburger {
        width: 30px;
        height: 30px;
        padding: 5px;
        cursor: pointer;
        transition: all 0.3s ease;
        border-radius: 4px;
    }
    
    .hamburger:hover {
        background-color: rgba(99, 102, 241, 0.1);
    }
    
    .hamburger.active .bar:nth-child(1) {
        transform: rotate(45deg) translate(5px, 5px);
    }
    
    .hamburger.active .bar:nth-child(2) {
        opacity: 0;
    }
    
    .hamburger.active .bar:nth-child(3) {
        transform: rotate(-45deg) translate(7px, -6px);
    }
    
    /* Menu mobile migliorato */
    .nav-menu {
        background: rgba(255, 255, 255, 0.98);
        backdrop-filter: blur(20px);
        border-top: 1px solid var(--gray-200);
    }
    
    .nav-menu.active {
        animation: slideDown 0.3s ease-out;
    }
    
    @keyframes slideDown {
        from {
            opacity: 0;
            transform: translateY(-20px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
    
    /* Link del menu più grandi per touch */
    .nav-menu .nav-link {
        padding: 1rem 2rem;
        font-size: 1.1rem;
        border-bottom: 1px solid var(--gray-100);
        transition: all 0.3s ease;
    }
    
    .nav-menu .nav-link:hover,
    .nav-menu .nav-link.active {
        background-color: var(--gray-50);
        color: var(--primary-color);
    }
}

/* Ottimizzazioni per form e input su mobile */
@media (max-width: 768px) {
    input[type="text"],
    input[type="email"],
    input[type="tel"],
    select,
    textarea {
        font-size: 16px; /* Previene lo zoom su iOS */
        padding: 12px 16px;
        border-radius: 8px;
        border: 2px solid var(--gray-300);
        transition: border-color 0.3s ease;
    }
    
    input:focus,
    select:focus,
    textarea:focus {
        border-color: var(--primary-color);
        outline: none;
        box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
    }
    
    /* Bottoni più grandi su mobile */
    .cta-button,
    .deal-btn,
    button[type="submit"] {
        min-height: 48px;
        padding: 12px 24px;
        font-size: 1rem;
        font-weight: 600;
        border-radius: 8px;
        transition: all 0.3s ease;
    }
}

/* Ottimizzazioni per le immagini su mobile */
@media (max-width: 768px) {
    img {
        max-width: 100%;
        height: auto;
        border-radius: 8px;
    }
    
    .hero-service-image img,
    .guide-card img {
        object-fit: cover;
        width: 100%;
        height: 100%;
    }
    
    /* Lazy loading placeholder */
    img[loading="lazy"] {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
    
    @keyframes loading {
        0% { background-position: 200% 0; }
        100% { background-position: -200% 0; }
    }
}

/* Miglioramenti per la tipografia mobile */
@media (max-width: 768px) {
    /* Dimensioni font ottimizzate per mobile */
    h1 { font-size: clamp(1.8rem, 5vw, 2.5rem); }
    h2 { font-size: clamp(1.5rem, 4vw, 2rem); }
    h3 { font-size: clamp(1.2rem, 3vw, 1.5rem); }
    h4 { font-size: clamp(1rem, 2.5vw, 1.25rem); }
    
    /* Miglior leggibilità */
    body {
        line-height: 1.6;
        font-size: 16px;
    }
    
    p {
        margin-bottom: 1rem;
        line-height: 1.6;
    }
    
    /* Spaziatura ottimizzata */
    .section-header h2 {
        margin-bottom: 1rem;
    }
    
    .section-subtitle {
        margin-bottom: 2rem;
    }
}

/* Ottimizzazioni per le performance su mobile */
@media (max-width: 768px) {
    /* Riduce le animazioni per migliorare le performance */
    * {
        animation-duration: 0.3s !important;
        transition-duration: 0.3s !important;
    }
    
    /* Ottimizza il rendering */
    .offer-card,
    .deal-card,
    .guide-card {
        will-change: auto;
        contain: layout style paint;
    }
    
    /* Riduce la complessità delle ombre */
    .offer-card,
    .deal-card,
    .guide-card {
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    }
    
    .offer-card:hover,
    .deal-card:hover,
    .guide-card:hover {
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    }
}

/* Miglioramenti per l'accessibilità mobile */
@media (max-width: 768px) {
    /* Focus visibile migliorato */
    *:focus {
        outline: 2px solid var(--primary-color);
        outline-offset: 2px;
    }
    
    /* Contrasto migliorato per testi piccoli */
    .offer-details,
    .deal-airline,
    .guide-meta {
        color: var(--gray-700);
        font-weight: 500;
    }
    
    /* Skip link per navigazione da tastiera */
    .skip-link {
        position: absolute;
        top: -40px;
        left: 6px;
        background: var(--primary-color);
        color: white;
        padding: 8px;
        text-decoration: none;
        border-radius: 4px;
        z-index: 1000;
    }
    
    .skip-link:focus {
        top: 6px;
    }
}

/* Ottimizzazioni per dispositivi con notch (iPhone X+) */
@supports (padding: max(0px)) {
    .navbar {
        padding-left: max(1.5rem, env(safe-area-inset-left));
        padding-right: max(1.5rem, env(safe-area-inset-right));
    }
    
    .container {
        padding-left: max(1.5rem, env(safe-area-inset-left));
        padding-right: max(1.5rem, env(safe-area-inset-right));
    }
    
    .nav-menu {
        padding-left: max(0px, env(safe-area-inset-left));
        padding-right: max(0px, env(safe-area-inset-right));
    }
}

/* Ottimizzazioni per PWA e modalità fullscreen */
@media (display-mode: standalone) {
    .navbar {
        padding-top: max(1rem, env(safe-area-inset-top));
    }
    
    body {
        padding-bottom: max(0px, env(safe-area-inset-bottom));
    }
}

/* Miglioramenti per la velocità di scroll su mobile */
@media (max-width: 768px) {
    html {
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
    }
    
    /* Ottimizza lo scrolling per iOS */
    body {
        -webkit-overflow-scrolling: touch;
    }
    
    /* Previene il bounce su iOS */
    .nav-menu {
        overscroll-behavior: contain;
    }
}

/* Supporto per dark mode su mobile */
@media (prefers-color-scheme: dark) and (max-width: 768px) {
    .nav-menu {
        background: rgba(30, 41, 59, 0.98);
        color: #f1f5f9;
    }
    
    .nav-menu .nav-link {
        color: #cbd5e1;
        border-bottom-color: rgba(255, 255, 255, 0.1);
    }
    
    .nav-menu .nav-link:hover,
    .nav-menu .nav-link.active {
        background-color: rgba(99, 102, 241, 0.2);
        color: #a5b4fc;
    }
}

/* Ottimizzazioni per connessioni lente */
@media (prefers-reduced-data: reduce) {
    /* Disabilita animazioni non essenziali */
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    /* Riduce la qualità delle immagini di sfondo */
    .hero,
    .hot-deals {
        background-image: none;
        background-color: var(--light-color);
    }
}

/* Miglioramenti per la stampa da mobile */
@media print {
    .hamburger,
    .nav-menu,
    .cta-button,
    .deal-btn {
        display: none !important;
    }
    
    .container {
        max-width: none;
        padding: 0;
    }
    
    .offer-card,
    .deal-card,
    .guide-card {
        break-inside: avoid;
        margin-bottom: 1rem;
        box-shadow: none;
        border: 1px solid #ccc;
    }
}

/* Footer mobile: About in alto, poi 2 colonne (Destinazioni + Servizi), poi Contatti centrato */
@media (max-width: 768px) {
    .footer-content {
        display: flex !important;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: stretch; /* colonne stessa altezza */
        gap: 0.75rem !important;
        text-align: initial;
    }
    /* Struttura base: ogni sezione occupa la riga intera di default */
    .footer-content > .footer-section {
        flex: 1 1 100%;
        max-width: 100%;
    }
    /* About (1°) per primo, a tutta larghezza */
    .footer-content > .footer-section:nth-child(1) {
        order: 1;
        text-align: center;
    }
    /* Seconda riga: Destinazioni (2°) a sinistra e Servizi (3°) a destra */
    .footer-content > .footer-section:nth-child(2),
    .footer-content > .footer-section:nth-child(3) {
        order: 2;
        flex: 0 0 calc(50% - 0.5rem);
        max-width: calc(50% - 0.5rem);
        text-align: left;
    }
    /* Terza riga: Contatti centrato a tutta larghezza */
    .footer-content > .footer-section:nth-child(4) {
        order: 3;
        text-align: center;
    }
    .footer-content > .footer-section:nth-child(1) p {
        margin: 0.4rem 0 !important;
        font-size: 0.95rem !important;
        line-height: 1.5 !important;
    }
}

/* --- Mobile fixes: hero height, oversized cards, guides grid --- */
@media (max-width: 768px) {
    /* Prevent any accidental horizontal scroll */
    html, body { max-width: 100%; overflow-x: hidden; }

    /* Trim the blue hero sections across pages */
    .hero {
        padding: 1.2rem 0 0.8rem !important;
        min-height: auto !important;
    }
    .hero .hero-content { display: block !important; gap: 0.75rem !important; }
    /* Align full-bleed hero with mobile container padding */
    .container .hero { margin-left: -1rem !important; margin-right: -1rem !important; margin-bottom: 0.75rem !important; }

    /* Offers & Tips landing cards: avoid overflow from minmax(400px, 1fr) */
    main > div[style*="grid-template-columns"][style*="minmax(400px"],
    .container > div[style*="grid-template-columns"][style*="minmax(400px"] {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    main > div[style*="grid-template-columns"][style*="minmax(400px"] > div,
    .container > div[style*="grid-template-columns"][style*="minmax(400px"] > div {
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
        padding: 1.25rem 1rem !important;
    }
    main > div[style*="grid-template-columns"][style*="minmax(400px"] a,
    .container > div[style*="grid-template-columns"][style*="minmax(400px"] a {
        padding: 0.7rem 1.25rem !important;
        font-size: 0.95rem !important;
        border-width: 1.5px !important;
    }

    /* Guides page: 2 cards per row and shorter cards */
    .guides-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 0.75rem !important; max-width: 100% !important; padding: 0 0.25rem; }
    .guides-grid .guide-card { min-width: 0 !important; max-width: 100% !important; }
    .guides-grid .guide-card img { height: 120px !important; }
    .guides-grid .guide-content { padding: 0.75rem !important; gap: 0.5rem !important; }
    .guides-grid .guide-content h3 { font-size: 1rem !important; margin-bottom: 0.4rem !important; line-height: 1.2 !important; }
    .guides-grid .guide-content p { font-size: 0.9rem !important; line-height: 1.45 !important; margin-bottom: 0.75rem !important; }
    .guides-grid .guide-meta { gap: 0.5rem !important; }
}
