/* Responsive design improvements for mobile and cross-browser compatibility */

/* Base responsive adjustments */
@media (max-width: 768px) {
    /* Enhanced mobile data optimization */
    img {
        image-rendering: optimizeSpeed;
        filter: contrast(0.95) brightness(0.98);
    }
    
    /* Disable expensive animations on slow connections */
    @media (prefers-reduced-data: reduce) {
        .energy-particle,
        .floating-element,
        .cosmic-animation {
            display: none !important;
        }
        
        * {
            animation-duration: 0.1s !important;
            transition-duration: 0.1s !important;
        }
    }
    
    /* Ensure body has proper structure */
    body {
        padding-top: 0 !important;
        min-height: 100vh !important;
        overflow-x: hidden !important;
    }
    
    /* Main content area fixes */
    main, .main-content, #content {
        position: relative !important;
        z-index: 10 !important;
        background: rgba(21, 21, 48, 0.95) !important;
        min-height: 100vh !important;
        padding: 1rem !important;
    }
    
    /* Cosmic background mobile positioning */
    .cosmic-background {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        z-index: 1 !important;
        opacity: 0.7 !important;
    }
    
    /* Energy particles mobile */
    .energy-particle {
        z-index: 1 !important;
        opacity: 0.5 !important;
    }
    
    /* Header fixes */
    .navbar, header {
        position: sticky !important;
        top: 0 !important;
        z-index: 1000 !important;
        background: rgba(21, 21, 48, 0.98) !important;
        backdrop-filter: blur(15px) !important;
        border-bottom: 2px solid rgba(156, 39, 176, 0.3) !important;
        padding: 1rem 0 !important;
    }
    
    /* Mobile navigation improvements */
    .navbar-container {
        padding: 0 1rem !important;
    }
    
    .navbar-brand {
        font-size: 1.8rem !important;
        font-weight: 700 !important;
        color: #fff !important;
        text-shadow: 0 2px 4px rgba(0,0,0,0.5) !important;
    }
    
    .menu-toggle {
        width: 50px !important;
        height: 50px !important;
        background: rgba(156, 39, 176, 0.2) !important;
        border: 2px solid rgba(156, 39, 176, 0.5) !important;
        border-radius: 12px !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 4px !important;
        backdrop-filter: blur(10px) !important;
    }
    
    .menu-toggle span {
        width: 20px !important;
        height: 3px !important;
        background: #fff !important;
        border-radius: 2px !important;
        transition: all 0.3s ease !important;
    }
    
    /* Smaller title on mobile */
    h1, .h1 {
        font-size: 1.8rem !important;
        margin-bottom: 1rem !important;
    }
    
    h2, .h2 {
        font-size: 1.5rem !important;
        margin-bottom: 0.8rem !important;
    }
    
    /* Better padding for mobile */
    .container, .container-fluid {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
        max-width: 100% !important;
    }
    
    /* Card adjustments */
    .card {
        padding: 1rem !important;
        margin: 1rem 0 !important;
        border-radius: 10px !important;
        background: rgba(255, 255, 255, 0.1) !important;
        backdrop-filter: blur(10px) !important;
    }
    
    /* Social sharing buttons mobile positioning */
    .social-share-buttons {
        position: fixed !important;
        bottom: 80px !important;
        right: 10px !important;
        z-index: 999 !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 0.5rem !important;
    }
    
    .social-share-btn {
        width: 50px !important;
        height: 50px !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 1.2rem !important;
        box-shadow: 0 2px 10px rgba(0,0,0,0.3) !important;
    }
    
    /* Navigation menu mobile */
    .navbar-menu {
        position: fixed !important;
        top: 80px !important;
        left: 0 !important;
        right: 0 !important;
        background: rgba(21, 21, 48, 0.98) !important;
        backdrop-filter: blur(20px) !important;
        border-radius: 0 0 20px 20px !important;
        padding: 2rem 1rem !important;
        transform: translateY(-100%) !important;
        opacity: 0 !important;
        transition: all 0.3s ease !important;
        border: 2px solid rgba(156, 39, 176, 0.3) !important;
        border-top: none !important;
        max-height: 80vh !important;
        overflow-y: auto !important;
    }
    
    .navbar-menu.show {
        transform: translateY(0) !important;
        opacity: 1 !important;
    }
    
    .menu-section {
        margin-bottom: 2rem !important;
    }
    
    .menu-heading {
        color: #9c27b0 !important;
        font-size: 1.2rem !important;
        font-weight: 700 !important;
        margin-bottom: 1rem !important;
        text-transform: uppercase !important;
        letter-spacing: 1px !important;
        border-bottom: 2px solid rgba(156, 39, 176, 0.3) !important;
        padding-bottom: 0.5rem !important;
    }
    
    .navbar-menu a {
        display: flex !important;
        align-items: center !important;
        padding: 1rem !important;
        color: #fff !important;
        text-decoration: none !important;
        font-size: 1.1rem !important;
        font-weight: 600 !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border-radius: 12px !important;
        margin-bottom: 0.8rem !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        transition: all 0.3s ease !important;
    }
    
    .navbar-menu a i {
        width: 24px !important;
        margin-right: 1rem !important;
        color: #9c27b0 !important;
        font-size: 1.2rem !important;
    }
    
    .navbar-menu a:hover {
        background: rgba(156, 39, 176, 0.2) !important;
        transform: translateX(5px) !important;
        border-color: rgba(156, 39, 176, 0.5) !important;
    }
    
    .navbar-menu a::after {
        content: '→' !important;
        margin-left: auto !important;
        opacity: 0.5 !important;
        transition: all 0.3s ease !important;
    }
    
    .navbar-menu a:hover::after {
        opacity: 1 !important;
        transform: translateX(5px) !important;
    }
    
    /* Menu item text styling */
    .menu-item-text {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.2rem !important;
    }
    
    .menu-item-text strong {
        font-size: 1.1rem !important;
        font-weight: 700 !important;
        color: #fff !important;
    }
    
    .menu-item-text small {
        font-size: 0.85rem !important;
        color: rgba(255, 255, 255, 0.7) !important;
        font-weight: 400 !important;
        line-height: 1.2 !important;
    }
    
    /* Desktop navigation improvements */
    .navbar-icons {
        display: flex !important;
        gap: 0.5rem !important;
        align-items: center !important;
    }
    
    .nav-icon {
        position: relative !important;
        width: 44px !important;
        height: 44px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: rgba(255, 255, 255, 0.1) !important;
        border-radius: 12px !important;
        color: #fff !important;
        text-decoration: none !important;
        transition: all 0.3s ease !important;
        border: 1px solid rgba(255, 255, 255, 0.2) !important;
        backdrop-filter: blur(10px) !important;
    }
    
    .nav-icon:hover {
        background: rgba(156, 39, 176, 0.3) !important;
        transform: translateY(-2px) !important;
        color: #fff !important;
        border-color: rgba(156, 39, 176, 0.5) !important;
        box-shadow: 0 4px 15px rgba(156, 39, 176, 0.3) !important;
    }
    
    .nav-icon i {
        font-size: 1.1rem !important;
    }
    
    /* Tooltip improvements */
    .nav-icon::after {
        content: attr(title) !important;
        position: absolute !important;
        bottom: -45px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        background: rgba(21, 21, 48, 0.95) !important;
        color: #fff !important;
        padding: 0.5rem 0.8rem !important;
        border-radius: 8px !important;
        font-size: 0.8rem !important;
        white-space: nowrap !important;
        opacity: 0 !important;
        pointer-events: none !important;
        transition: all 0.3s ease !important;
        border: 1px solid rgba(156, 39, 176, 0.3) !important;
        backdrop-filter: blur(10px) !important;
        z-index: 1001 !important;
    }
    
    .nav-icon:hover::after {
        opacity: 1 !important;
        transform: translateX(-50%) translateY(-5px) !important;
    }
    
    /* Welcome content mobile */
    .welcome-content, .hero-section, .hero-sage {
        text-align: center !important;
        padding: 2rem 1rem !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border-radius: 15px !important;
        margin: 1rem 0 !important;
        backdrop-filter: blur(10px) !important;
        position: relative !important;
        z-index: 5 !important;
    }
    
    /* Mobile hero section specific */
    .mobile-hero-section {
        min-height: 100vh !important;
        display: flex !important;
        align-items: center !important;
        padding: 2rem 0 !important;
    }
    
    .mobile-mandala-section {
        margin-bottom: 2rem !important;
    }
    
    .cosmic-mandala-container {
        max-width: 250px !important;
        margin: 0 auto !important;
    }
    
    .hero-content-sage {
        background: rgba(255, 255, 255, 0.1) !important;
        padding: 2rem 1.5rem !important;
        border-radius: 20px !important;
        backdrop-filter: blur(15px) !important;
        margin: 1rem 0 !important;
    }
    
    .hero-content-sage h1 {
        font-size: 2.5rem !important;
        margin-bottom: 1rem !important;
        color: #fff !important;
        text-shadow: 0 2px 4px rgba(0,0,0,0.5) !important;
    }
    
    .hero-content-sage .lead {
        font-size: 1.1rem !important;
        color: rgba(255, 255, 255, 0.9) !important;
        margin-bottom: 1.5rem !important;
    }
    
    /* Footer always visible */
    .footer {
        position: relative !important;
        bottom: auto !important;
        margin-top: 2rem !important;
        background: rgba(21, 21, 48, 0.9) !important;
        backdrop-filter: blur(10px) !important;
    }
    
    /* Hidden desktop-only elements */
    .desktop-only {
        display: none !important;
    }
    
    /* Form adjustments */
    .form-group {
        margin-bottom: 1rem !important;
    }
    
    .form-control {
        font-size: 16px !important; /* Prevents zoom on iOS */
        padding: 0.8rem !important;
        border-radius: 10px !important;
        background: rgba(255, 255, 255, 0.1) !important;
        border: 1px solid rgba(255, 255, 255, 0.2) !important;
        color: white !important;
    }
    
    /* Improved button touch target */
    .btn {
        padding: 0.8rem 1.5rem !important;
        min-height: 48px !important; /* Minimum touch target size */
        border-radius: 25px !important;
        font-size: 1rem !important;
        font-weight: 600 !important;
        box-shadow: 0 4px 15px rgba(0,0,0,0.2) !important;
        backdrop-filter: blur(10px) !important;
    }
    
    .btn-ask-sage-primary {
        background: linear-gradient(135deg, #9c27b0, #673ab7) !important;
        color: white !important;
        border: none !important;
        padding: 1rem 2rem !important;
        font-size: 1.1rem !important;
        font-weight: 700 !important;
        text-decoration: none !important;
        display: inline-block !important;
        border-radius: 30px !important;
        box-shadow: 0 6px 20px rgba(156, 39, 176, 0.4) !important;
        transition: all 0.3s ease !important;
    }
    
    .btn-ask-sage-primary:hover {
        transform: translateY(-2px) !important;
        box-shadow: 0 8px 25px rgba(156, 39, 176, 0.6) !important;
        color: white !important;
    }
    
    /* Feature cards mobile */
    .feature-card {
        background: rgba(255, 255, 255, 0.1) !important;
        border-radius: 15px !important;
        padding: 1rem !important;
        text-decoration: none !important;
        color: white !important;
        display: block !important;
        backdrop-filter: blur(10px) !important;
        border: 1px solid rgba(255, 255, 255, 0.2) !important;
        transition: all 0.3s ease !important;
    }
    
    .feature-card:hover {
        background: rgba(255, 255, 255, 0.15) !important;
        transform: translateY(-2px) !important;
        color: white !important;
    }
    
    /* Grid adjustments */
    .premium-features > div {
        grid-template-columns: 1fr !important; /* Single column on small screens */
    }
    
    /* Better spacing in price comparison */
    .price-comparison {
        flex-direction: column !important;
        align-items: center !important;
    }
    
    .price-card {
        width: 80% !important;
        margin-bottom: 1rem !important;
    }
    
    /* Menu adjustments */
    .navbar-nav {
        padding: 0.5rem 0 !important;
    }
    
    /* Navbar collapse */
    .navbar-collapse {
        background-color: rgba(5, 56, 107, 0.95) !important;
        border-radius: 8px !important;
        padding: 0.5rem !important;
    }
}

/* Extra small devices */
@media (max-width: 576px) {
    /* Even smaller elements */
    .card {
        padding: 0.8rem !important;
        margin: 0.8rem auto !important;
    }
    
    /* Full width inputs */
    .form-control, .btn {
        width: 100% !important;
    }
    
    /* Stack buttons */
    .btn-group {
        flex-direction: column !important;
    }
    
    /* Adjust margins */
    .mt-4, .my-4 {
        margin-top: 1.2rem !important;
    }
    
    /* Better spacing in subscription info */
    .subscription-info {
        padding: 0.8rem !important;
    }
}

/* Microsoft Edge specific fixes */
@supports (-ms-ime-align:auto) {
    /* Fix for footer display on Edge */
    .footer {
        position: relative !important;
        display: block !important;
        width: 100% !important;
        background-color: rgba(5, 56, 107, 0.8) !important;
    }
    
    /* Fix gradient backgrounds in Edge */
    .cosmic-journey-bg {
        background: #05386b !important; /* Fallback solid color */
    }
    
    /* Fix animation issues in Edge */
    .cosmic-particle {
        animation: none !important;
        opacity: 0.4 !important;
    }
}

/* iOS Safari specific fixes */
@supports (-webkit-touch-callout: none) {
    /* Fix for sticky hover states on iOS */
    .btn:hover, a:hover {
        transition: none !important;
    }
    
    /* Fix for input zoom on iOS */
    input, select, textarea {
        font-size: 16px !important; /* Prevents zoom on focus */
    }
    
    /* Better scrolling */
    body {
        -webkit-overflow-scrolling: touch !important;
    }
}

/* Android Chrome specific fixes */
@supports (-webkit-appearance:none) and (not (-ms-ime-align:auto)) and (not (-moz-appearance:none)) {
    /* Better touch interactions */
    .btn, a {
        cursor: pointer !important; 
        -webkit-tap-highlight-color: rgba(0,0,0,0) !important;
    }
}