/* Force Mobile Optimization - Loads Last to Override Everything */

@media (max-width: 768px) {
    /* Nuclear option - force everything to fit */
    html {
        overflow-x: hidden !important;
        width: 100% !important;
    }
    
    body {
        overflow-x: hidden !important;
        width: 100% !important;
        max-width: 100vw !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* Force all elements to respect viewport */
    * {
        max-width: 100vw !important;
        box-sizing: border-box !important;
    }
    
    /* Override any fixed widths */
    .page,
    .container,
    main,
    section,
    div:not(#manual-install-modal-wrapper):not(#ios-install-modal-wrapper):not([id*="pwa"]) {
        max-width: 100% !important;
        width: 100% !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    
    /* Hero sections */
    .hero,
    .intro {
        max-width: 100% !important;
        width: 100% !important;
        padding: 20px 16px !important;
    }
    
    /* Headers and titles */
    h1 {
        font-size: 24px !important;
        line-height: 1.3 !important;
        word-wrap: break-word !important;
        max-width: 100% !important;
    }
    
    h2 {
        font-size: 20px !important;
        line-height: 1.3 !important;
        word-wrap: break-word !important;
    }
    
    h3 {
        font-size: 18px !important;
        line-height: 1.3 !important;
    }
    
    /* Paragraphs and text */
    p, li, span, a {
        font-size: 14px !important;
        line-height: 1.6 !important;
        word-wrap: break-word !important;
        max-width: 100% !important;
    }
    
    /* Lists */
    ul, ol {
        padding-left: 20px !important;
        margin: 12px 0 !important;
        max-width: 100% !important;
    }
    
    /* Grids and flex layouts */
    .grid,
    .benefits-grid,
    .steps-container {
        display: flex !important;
        flex-direction: column !important;
        gap: 16px !important;
        width: 100% !important;
        padding: 16px !important;
    }
    
    /* Cards */
    .pill,
    .contact-box,
    .benefit-card,
    .step-card,
    details {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 12px 0 !important;
        padding: 16px !important;
        box-sizing: border-box !important;
    }
    
    /* Contact boxes should not overflow */
    .contact-box {
        width: 100% !important;
        display: flex !important;
        flex-wrap: wrap !important;
    }
    
    /* Buttons */
    button,
    .btn,
    .button,
    a.button {
        width: 100% !important;
        max-width: 100% !important;
        padding: 12px 16px !important;
        font-size: 14px !important;
    }
    
    /* Navigation */
    nav {
        flex-wrap: wrap !important;
        gap: 8px !important;
        justify-content: center !important;
        width: 100% !important;
    }
    
    nav a {
        font-size: 13px !important;
        padding: 8px 12px !important;
    }
    
    /* Header */
    header,
    .header,
    .head-inner {
        max-width: 100% !important;
        width: 100% !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
    
    /* Tables - make them scroll */
    table {
        display: block !important;
        overflow-x: auto !important;
        white-space: nowrap !important;
        max-width: 100% !important;
    }
    
    /* Images */
    img {
        max-width: 100% !important;
        height: auto !important;
    }
    
    /* Embedded content */
    iframe,
    embed,
    object {
        max-width: 100% !important;
    }
    
    /* Fix inline styles that might cause overflow */
    [style*="width"] {
        width: auto !important;
        max-width: 100% !important;
    }
    
    /* Summary elements in details */
    summary {
        font-size: 14px !important;
        padding: 8px 0 !important;
        word-wrap: break-word !important;
    }
    
    /* Steps and FAQ lists */
    .steps,
    .faq-list {
        padding: 0 !important;
        margin: 12px 0 !important;
        width: 100% !important;
    }
    
    .steps li,
    .faq-list li {
        font-size: 13px !important;
        padding: 12px !important;
        margin-bottom: 8px !important;
        width: 100% !important;
    }
    
    /* Remove any absolute positioning that might cause issues */
    .tight-row {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
        width: 100% !important;
        padding: 0 !important;
    }
    
    /* Footer */
    footer {
        width: 100% !important;
        max-width: 100% !important;
        padding: 16px !important;
    }
    
    /* Prevent text overflow */
    * {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }
}

@media (max-width: 480px) {
    /* Extra small screens */
    h1 {
        font-size: 20px !important;
    }
    
    h2 {
        font-size: 18px !important;
    }
    
    p, li {
        font-size: 13px !important;
    }
    
    .page,
    .container {
        padding: 12px !important;
    }
}
