/* Mobile Floating Elements Fix */
/* This file ensures draggable back button and floating navigation work on mobile */

/* Override the responsive CSS that hides floating elements on mobile */
@media (max-width: 768px) {
    /* Ensure draggable back button is visible on mobile */
    .draggable-back-button {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        z-index: 9999 !important;
        position: fixed !important;
        /* Ensure it's not hidden by other rules */
        transform: none !important;
        animation: none !important;
    }
    
    /* Ensure floating navigation toggle is visible on mobile */
    #floating-nav-toggle {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        z-index: 99999 !important;
        position: fixed !important;
        /* Ensure it's not hidden by other rules */
        transform: none !important;
        animation: none !important;
    }
    
    /* Ensure floating navigation menu is visible when open */
    .floating-nav-menu {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        z-index: 99999 !important;
        position: fixed !important;
        /* Ensure it's not hidden by other rules */
        transform: none !important;
        animation: none !important;
    }
    
    /* Override the general floating-elements hide rule for our specific elements */
    .draggable-back-button,
    #floating-nav-toggle,
    .floating-nav-menu {
        display: flex !important;
    }
    
    /* Override the floating-elements display: none rule */
    .floating-elements {
        display: block !important;
    }
    
    /* Ensure our specific floating elements are not affected by the general rule */
    .floating-elements .draggable-back-button,
    .floating-elements #floating-nav-toggle,
    .floating-elements .floating-nav-menu {
        display: flex !important;
    }
}

@media (max-width: 480px) {
    /* Ensure draggable back button is visible on small mobile */
    .draggable-back-button {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        z-index: 9999 !important;
        position: fixed !important;
        /* Adjust size for small screens */
        padding: 8px 16px !important;
        font-size: 11px !important;
        min-width: 120px !important;
        min-height: 36px !important;
        /* Ensure it's not hidden by other rules */
        transform: none !important;
        animation: none !important;
    }
    
    /* Ensure floating navigation toggle is visible on small mobile */
    #floating-nav-toggle {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        z-index: 99999 !important;
        position: fixed !important;
        /* Adjust size for small screens */
        width: 50px !important;
        height: 50px !important;
        /* Ensure it's not hidden by other rules */
        transform: none !important;
        animation: none !important;
    }
    
    /* Ensure floating navigation menu is visible when open on small mobile */
    .floating-nav-menu {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        z-index: 99999 !important;
        position: fixed !important;
        /* Adjust size for small screens */
        min-width: 160px !important;
        max-width: 200px !important;
        padding: 0.4rem !important;
        /* Ensure it's not hidden by other rules */
        transform: none !important;
        animation: none !important;
    }
    
    /* Override the general floating-elements hide rule for our specific elements */
    .draggable-back-button,
    #floating-nav-toggle,
    .floating-nav-menu {
        display: flex !important;
    }
    
    /* Override the floating-elements display: none rule */
    .floating-elements {
        display: block !important;
    }
    
    /* Ensure our specific floating elements are not affected by the general rule */
    .floating-elements .draggable-back-button,
    .floating-elements #floating-nav-toggle,
    .floating-elements .floating-nav-menu {
        display: flex !important;
    }
}

/* Touch-friendly improvements for mobile */
@media (max-width: 768px) {
    /* Increase touch target size for draggable back button */
    .draggable-back-button {
        min-height: 44px !important; /* Minimum touch target size */
        min-width: 140px !important;
        /* Ensure it's not too close to screen edges */
        margin: 10px !important;
        /* Improve touch interaction */
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: transparent !important;
    }
    
    /* Increase touch target size for floating nav toggle */
    #floating-nav-toggle {
        min-width: 44px !important;
        min-height: 44px !important;
        /* Ensure it's not too close to screen edges */
        margin: 10px !important;
        /* Improve touch interaction */
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: transparent !important;
    }
    
    /* Improve touch targets in floating menu */
    .floating-nav-item {
        min-height: 44px !important;
        padding: 0.6rem 0.8rem !important;
        /* Improve touch interaction */
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: transparent !important;
    }
}

/* Ensure proper positioning on mobile */
@media (max-width: 768px) {
    /* Default positions for mobile */
    .draggable-back-button {
        top: 20px !important;
        left: 20px !important;
        right: auto !important;
        bottom: auto !important;
    }
    
    #floating-nav-toggle {
        top: 20px !important;
        right: 20px !important;
        left: auto !important;
        bottom: auto !important;
    }
}

/* Prevent conflicts with other mobile styles */
@media (max-width: 768px) {
    /* Override any display: none rules that might affect our floating elements */
    .draggable-back-button,
    #floating-nav-toggle,
    .floating-nav-menu {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }
    
    /* Ensure proper stacking context */
    .draggable-back-button {
        z-index: 9999 !important;
    }
    
    #floating-nav-toggle,
    .floating-nav-menu {
        z-index: 99999 !important;
    }
    
    /* Override any transform or animation that might hide elements */
    .draggable-back-button,
    #floating-nav-toggle,
    .floating-nav-menu {
        transform: none !important;
        animation: none !important;
    }
}

/* Dark mode support for mobile */
@media (max-width: 768px) {
    body.dark-mode .draggable-back-button {
        background: linear-gradient(135deg, #1e40af, #1e3a8a) !important;
        color: #f8fafc !important;
        box-shadow: 0 4px 15px rgba(30, 64, 175, 0.4) !important;
    }
    
    body.dark-mode #floating-nav-toggle {
        background: linear-gradient(135deg, #1e293b, #334155) !important;
        border: 2px solid rgba(255, 255, 255, 0.2) !important;
    }
    
    body.dark-mode .floating-nav-menu {
        background: rgba(30, 41, 59, 0.95) !important;
        border: 2px solid rgba(255, 255, 255, 0.1) !important;
    }
}

/* High contrast mode support for mobile */
@media (max-width: 768px) and (prefers-contrast: high) {
    .draggable-back-button {
        border: 3px solid white !important;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5) !important;
    }
    
    #floating-nav-toggle {
        border: 3px solid white !important;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5) !important;
    }
}

/* Landscape orientation adjustments */
@media (max-width: 768px) and (orientation: landscape) {
    /* Adjust positions for landscape mode */
    .draggable-back-button {
        top: 10px !important;
        left: 10px !important;
    }
    
    #floating-nav-toggle {
        top: 10px !important;
        right: 10px !important;
    }
    
    /* Reduce sizes slightly for landscape */
    .draggable-back-button {
        padding: 6px 12px !important;
        font-size: 10px !important;
        min-width: 100px !important;
        min-height: 32px !important;
    }
    
    #floating-nav-toggle {
        width: 45px !important;
        height: 45px !important;
    }
}

/* Force override for any conflicting styles */
@media (max-width: 768px) {
    /* Use higher specificity to override any conflicting rules */
    body .draggable-back-button,
    body #floating-nav-toggle,
    body .floating-nav-menu {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        position: fixed !important;
        z-index: 99999 !important;
    }
    
    /* Override the specific floating-elements rule */
    body .floating-elements .draggable-back-button,
    body .floating-elements #floating-nav-toggle,
    body .floating-elements .floating-nav-menu {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }
}
