/* Mobile Viewport Fix - Finale Lösung mit clip-path */

/* HTML und Body Fix */
html {
    width: 100%;
    overflow-x: hidden !important;
    margin: 0;
    padding: 0;
}

body {
    width: 100%;
    overflow-x: hidden !important;
    margin: 0;
    padding: 0;
    position: relative;
}

/* Verhindere horizontales Scrollen global */
* {
    max-width: 100vw !important;
}

/* Hero Section Fix */
.hero {
    overflow-x: hidden;
    box-sizing: border-box;
}

/* Alle Hauptsektionen */
.features,
.parks,
.premium,
.download,
.footer {
    overflow-x: hidden !important;
    overflow-y: visible !important;
    box-sizing: border-box;
}

/* Premium-Sektion spezifisch - kein separates Scrolling */
.premium {
    overflow: hidden !important;
    overflow-x: hidden !important;
    overflow-y: visible !important; /* Erlaubt Badges oben */
    -webkit-overflow-scrolling: touch !important;
    height: auto !important;
    max-height: none !important;
    min-height: auto !important;
}

/* Pricing Cards Fix für Mobile */
@media (max-width: 768px) {
    .premium .pricing-cards {
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
    }
    
    .premium .pricing-card {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
}

/* Mobile spezifisch */
@media (max-width: 768px) {
    /* Hero Title Fix - FINALE LÖSUNG */
    .hero-title {
        font-size: 26px !important;
        line-height: 1.25 !important;
        white-space: normal !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 0 15px 0 !important;
        position: relative !important;
        z-index: 1 !important;
    }
    
    /* Fix Mehr erfahren button */
    .hero-secondary {
        position: relative !important;
        z-index: 10 !important;
    }
    
    .hero-secondary .btn {
        position: relative !important;
        z-index: 10 !important;
        pointer-events: auto !important;
    }
    
    .hero-subtitle {
        font-size: 14px !important;
        line-height: 1.4 !important;
        white-space: normal !important;
        word-wrap: break-word !important;
        display: block !important;
        width: 100% !important;
        padding: 0 !important;
    }
    
    .hero-text {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 10px !important;
        box-sizing: border-box !important;
    }
    
    .hero-content {
        padding: 0 !important;
        width: 100% !important;
    }
    
    .hero {
        padding: 110px 20px 40px !important;
        margin-top: 0 !important;
        position: relative !important;
    }
    /* Verhindere horizontales Scrollen */
    html, body {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden !important;
        position: relative;
        margin: 0;
        padding: 0;
    }
    
    /* ENTFERNT: clip-path verursacht Text-Abschneidung auf Mobile
    body {
        clip-path: inset(0 0 0 0);
    } */
    
    /* Container bleiben flexibel */
    .container {
        max-width: 100%;
        padding: 0 20px;
        box-sizing: border-box;
    }
    
    /* Hero Content */
    .hero-content {
        max-width: 100%;
        box-sizing: border-box;
    }
    
    /* Device Mockups */
    .hero-image {
        overflow: hidden;
        max-width: 100%;
    }
    
    /* Navbar bleibt normal */
    .navbar {
        width: 100%;
        left: 0;
        right: 0;
        margin: 0;
    }
    
    /* Nav-Toggle bleibt klickbar */
    .nav-toggle {
        cursor: pointer;
        z-index: 1001;
        display: flex;
    }
    
    /* Mobile Menu Styles - überschreibt styles.css */
    .nav-menu,
    ul.nav-menu,
    #navMenu,
    ul#navMenu {
        position: fixed !important;
        left: 20px !important;
        top: 70px !important;
        right: 20px !important;
        width: auto !important;
        height: auto !important;
        max-height: calc(100vh - 100px) !important;
        background: rgba(255, 255, 255, 0.98) !important;
        backdrop-filter: blur(25px) saturate(200%) !important;
        -webkit-backdrop-filter: blur(25px) saturate(200%) !important;
        z-index: 999 !important;
        transition: opacity 0.3s ease, visibility 0.3s ease !important;
        overflow-y: auto !important;
        flex-direction: column !important;
        text-align: left !important;
        padding: 20px !important;
        box-shadow: 
            0 8px 32px rgba(0, 0, 0, 0.12),
            0 1px 0 rgba(255, 255, 255, 0.5) inset !important;
        border: 1px solid rgba(255, 255, 255, 0.3) !important;
        border-radius: 24px !important;
        visibility: hidden;
        opacity: 0;
        display: none;
        margin: 0 !important;
        margin-left: 0 !important;
        box-sizing: border-box !important;
        list-style: none !important;
        gap: 0 !important;
        align-items: stretch !important;
    }
    
    /* Aktives Menü */
    .nav-menu.active,
    ul.nav-menu.active,
    #navMenu.active,
    ul#navMenu.active {
        visibility: visible !important;
        opacity: 1 !important;
        display: flex !important;
    }
    
    /* Mobile Navigation Items */
    .nav-menu > li,
    ul.nav-menu > li {
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
    }
    
    /* Keep settings and auth visible but restructure them */
    .nav-menu .user-auth.compact {
        width: 100% !important;
        margin: 15px 0 0 0 !important;
        padding: 15px 0 0 0 !important;
        border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
        display: block !important;
    }
    
    .nav-menu .settings-dropdown {
        width: 100% !important;
        margin: 10px 0 0 0 !important;
        padding: 0 !important;
        display: block !important;
    }
    
    /* Style auth button for mobile */
    .nav-menu .auth-dropdown-toggle {
        background: transparent !important;
        border: 2px solid var(--primary-color) !important;
        border-radius: 12px !important;
        padding: 12px 20px !important;
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 10px !important;
        font-size: 15px !important;
        color: var(--primary-color) !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
        font-weight: 600 !important;
    }
    
    .nav-menu .auth-dropdown-toggle:after {
        content: 'Account';
    }
    
    .nav-menu .auth-dropdown-toggle:hover {
        background: var(--primary-color) !important;
        color: white !important;
    }
    
    /* Style settings button for mobile */
    .nav-menu .settings-toggle {
        background: transparent !important;
        border: 2px solid #666 !important;
        border-radius: 12px !important;
        padding: 12px 20px !important;
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 10px !important;
        font-size: 15px !important;
        color: var(--text-primary) !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
        font-weight: 600 !important;
    }
    
    .nav-menu .settings-toggle:after {
        content: 'Einstellungen';
    }
    
    .nav-menu .settings-toggle:hover {
        background: #666 !important;
        color: white !important;
    }
    
    /* Hide dropdown arrows on mobile */
    .nav-menu .dropdown-arrow-small {
        display: none !important;
    }
    
    /* Mobile dropdown menus */
    .nav-menu .auth-dropdown-menu,
    .nav-menu .settings-menu {
        position: static !important;
        display: none !important;
        width: 100% !important;
        margin-top: 10px !important;
        background: rgba(0, 0, 0, 0.05) !important;
        border-radius: 12px !important;
        padding: 10px !important;
        box-shadow: none !important;
        border: none !important;
        backdrop-filter: none !important;
        transform: none !important;
        opacity: 1 !important;
    }
    
    .nav-menu .user-auth.active .auth-dropdown-menu,
    .nav-menu .settings-dropdown.active .settings-menu {
        display: block !important;
    }
    
    /* Style dropdown items */
    .nav-menu .auth-option,
    .nav-menu .theme-option-compact,
    .nav-menu .lang-option-compact {
        display: flex !important;
        align-items: center !important;
        padding: 10px 15px !important;
        margin: 5px 0 !important;
        background: white !important;
        border-radius: 8px !important;
        text-decoration: none !important;
        color: var(--text-primary) !important;
        transition: all 0.2s ease !important;
    }
    
    .nav-menu .auth-option:hover,
    .nav-menu .theme-option-compact:hover,
    .nav-menu .lang-option-compact:hover {
        background: var(--primary-color) !important;
        color: white !important;
    }
    
    /* Mobile Nav Links */
    .nav-menu .nav-link {
        display: block !important;
        padding: 12px 16px !important;
        width: 100% !important;
        text-align: left !important;
        border-radius: 12px !important;
        margin: 4px 0 !important;
    }
    
    /* Mobile Dropdown */
    .nav-menu .nav-dropdown {
        position: relative !important;
        width: 100% !important;
    }
    
    /* Mobile Dropdown Menu - als Accordion */
    .nav-menu .nav-dropdown-menu {
        position: static !important;
        display: none !important;
        width: 100% !important;
        background: transparent !important;
        box-shadow: none !important;
        border: none !important;
        padding: 0 !important;
        margin: 0 !important;
        backdrop-filter: none !important;
        transform: none !important;
        opacity: 1 !important;
    }
    
    /* Wenn Dropdown aktiv ist */
    .nav-menu .nav-dropdown.active .nav-dropdown-menu {
        display: block !important;
    }
    
    /* Mobile Dropdown Items */
    .nav-menu .nav-dropdown-menu li {
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    .nav-menu .nav-dropdown-menu a {
        display: block !important;
        padding: 10px 16px 10px 32px !important;
        width: 100% !important;
        text-align: left !important;
        border-radius: 8px !important;
        margin: 2px 0 !important;
        background: rgba(0, 122, 255, 0.05) !important;
        font-size: 14px !important;
    }
    
    /* Dark mode mobile menu */
    [data-theme="dark"] .nav-menu,
    [data-theme="dark"] ul.nav-menu,
    [data-theme="dark"] #navMenu,
    [data-theme="dark"] ul#navMenu {
        background: rgba(28, 28, 30, 0.6) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        box-shadow: 
            0 8px 32px rgba(0, 0, 0, 0.4),
            0 1px 0 rgba(255, 255, 255, 0.08) inset !important;
    }
    
    /* Stelle sicher dass die li Elemente richtig formatiert sind */
    .nav-menu li {
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* Extra Sicherheit - stelle sicher, dass das Menü wirklich versteckt ist */
    body:not(.menu-open) .nav-menu:not(.active),
    body:not(.menu-open) ul.nav-menu:not(.active),
    body:not(.menu-open) #navMenu:not(.active) {
        left: -200% !important;
        visibility: hidden !important;
        opacity: 0 !important;
        pointer-events: none !important;
        display: flex !important; /* Behalte display flex, aber verstecke es */
    }
}
/* Extra kleine Bildschirme (iPhone SE, etc.) */
@media (max-width: 400px) {
    .hero-title {
        font-size: 20px !important;
        line-height: 1.3 !important;
    }
    
    .hero-subtitle {
        font-size: 13px !important;
    }
    
    .hero {
        padding: 80px 15px 25px !important;
    }
    
    .stat-number {
        font-size: 24px !important;
    }
    
    .stat-label {
        font-size: 11px !important;
    }
    
    .hero-stats {
        gap: 15px !important;
        margin-top: 15px !important;
    }
}
