/* ==========================================
   MOBILE STRICT FIX
   Force all elements to stay within bounds
   Consistent typography on mobile
   ========================================== */

/* ==========================================
   PREVENT ANY OVERFLOW - CRITICAL
   ========================================== */

* {
    box-sizing: border-box !important;
}

html {
    overflow-x: hidden !important;
    width: 100% !important;
    max-width: 100vw !important;
}

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

/* Force EVERY element to stay within viewport */
section,
div,
header,
footer,
nav,
article,
aside,
main {
    max-width: 100vw !important;
    overflow-x: hidden !important;
}

/* Container strict */
.container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
    margin: 0 auto !important;
    overflow-x: hidden !important;
}

/* ==========================================
   MOBILE TYPOGRAPHY - CONSISTENT SIZES
   ========================================== */

@media (max-width: 767px) {
    /* Headings - Consistent Scale */
    h1, .hero-title {
        font-size: 1.75rem !important; /* 28px */
        line-height: 1.2 !important;
        margin-bottom: 1rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }

    h2, .section-title, .section-title-light {
        font-size: 1.5rem !important; /* 24px */
        line-height: 1.3 !important;
        margin-bottom: 0.75rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }

    h3 {
        font-size: 1.25rem !important; /* 20px */
        line-height: 1.3 !important;
        margin-bottom: 0.5rem !important;
        word-wrap: break-word !important;
    }

    h4 {
        font-size: 1.1rem !important; /* 17.6px */
        line-height: 1.3 !important;
        margin-bottom: 0.5rem !important;
    }

    /* Body text - Consistent */
    p,
    li,
    .section-subtitle {
        font-size: 0.95rem !important; /* 15.2px */
        line-height: 1.6 !important;
        margin-bottom: 0.75rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }

    /* Small text */
    small,
    .stat-label,
    .timer-label,
    .footer-brands p {
        font-size: 0.85rem !important; /* 13.6px */
        line-height: 1.5 !important;
    }

    /* Large text */
    .wow-text {
        font-size: 2rem !important; /* 32px */
        line-height: 1.1 !important;
    }

    .hero-subtitle {
        font-size: 0.9rem !important;
        line-height: 1.5 !important;
    }

    /* Card titles */
    .service-card h3,
    .benefit-card h3 {
        font-size: 1.15rem !important;
        line-height: 1.3 !important;
    }
}

/* ==========================================
   VIDEO SECTIONS - FORCE RESPONSIVE
   ========================================== */

@media (max-width: 767px) {
    /* Video wrappers */
    .video-wrapper,
    .testimonial-video-wrapper,
    .modern-video-card .video-wrapper,
    .video-thumbnail {
        position: relative !important;
        width: 100% !important;
        max-width: 100% !important;
        padding-bottom: 56.25% !important; /* 16:9 */
        height: 0 !important;
        overflow: hidden !important;
    }

    .video-wrapper iframe,
    .testimonial-video-wrapper iframe,
    .modern-video-card .video-wrapper iframe,
    .video-thumbnail iframe {
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        max-width: 100% !important;
        border: 0 !important;
    }

    /* About section video container */
    .modern-video-card {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        overflow: hidden !important;
    }

    /* Testimonials grid */
    .testimonials-modern-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .testimonial-card {
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }
}

/* ==========================================
   IMAGES - FORCE RESPONSIVE
   ========================================== */

@media (max-width: 767px) {
    img {
        max-width: 100% !important;
        height: auto !important;
        display: block !important;
    }

    .hero-image img {
        max-width: 100% !important;
        width: 100% !important;
        height: auto !important;
    }

    /* Logo images */
    .logo-item,
    .brand-logo {
        max-width: 100% !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        font-size: 0.85rem !important;
        padding: 0.5rem !important;
    }
}

/* ==========================================
   TABLES - RESPONSIVE
   ========================================== */

@media (max-width: 767px) {
    table {
        width: 100% !important;
        max-width: 100% !important;
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .pricing-table {
        font-size: 0.85rem !important;
    }

    .pricing-table th,
    .pricing-table td {
        padding: 8px 5px !important;
        font-size: 0.8rem !important;
        white-space: normal !important;
        word-wrap: break-word !important;
    }
}

/* ==========================================
   HERO SECTION - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .hero-section {
        padding: 40px 0 !important;
        min-height: auto !important;
        overflow: hidden !important;
    }

    .hero-content {
        display: flex !important;
        flex-direction: column !important;
        gap: 1.5rem !important;
        text-align: center !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .hero-text {
        order: 1 !important;
        width: 100% !important;
    }

    .hero-image {
        order: 2 !important;
        width: 100% !important;
        max-width: 280px !important;
        margin: 0 auto !important;
    }

    .hero-cta-group {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.75rem !important;
        width: 100% !important;
    }

    .cta-primary,
    .cta-secondary {
        width: 100% !important;
        max-width: 100% !important;
        padding: 12px 20px !important;
        font-size: 0.9rem !important;
        justify-content: center !important;
        text-align: center !important;
    }
}

/* ==========================================
   GRIDS - FORCE SINGLE COLUMN
   ========================================== */

@media (max-width: 767px) {
    .services-grid,
    .benefits-grid,
    .testimonials-grid,
    .testimonials-modern-grid,
    .about-layout,
    .booking-content,
    .footer-content,
    .areas-features {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Areas grid - 2 columns max */
    .areas-grid {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.5rem !important;
    }

    .area-item {
        font-size: 0.85rem !important;
        padding: 0.5rem !important;
    }

    /* Brand logos - 2 columns */
    .brand-logos-showcase {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.75rem !important;
        padding: 0 1rem !important;
    }
}

/* ==========================================
   BUTTONS - TOUCH FRIENDLY
   ========================================== */

@media (max-width: 767px) {
    button,
    .cta-primary,
    .cta-secondary,
    .submit-btn,
    .call-btn,
    .book-btn,
    .countdown-cta,
    .call-btn-large {
        min-height: 48px !important; /* Touch target */
        padding: 12px 20px !important;
        font-size: 0.9rem !important;
        width: 100% !important;
        max-width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        white-space: normal !important;
        word-wrap: break-word !important;
    }

    /* Button icons */
    button svg,
    .cta-primary svg,
    .cta-secondary svg {
        width: 18px !important;
        height: 18px !important;
        flex-shrink: 0 !important;
    }
}

/* ==========================================
   COUNTDOWN SECTION - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .countdown-section {
        padding: 30px 0 !important;
        overflow: hidden !important;
        width: 100% !important;
        max-width: 100vw !important;
    }

    .countdown-title {
        font-size: 1.25rem !important;
        line-height: 1.3 !important;
        padding: 0 15px !important;
        margin-bottom: 0.75rem !important;
        text-align: center !important;
    }

    .countdown-label {
        font-size: 0.9rem !important;
        margin-bottom: 1rem !important;
        text-align: center !important;
    }

    .countdown-timer {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 0 15px !important;
        flex-wrap: nowrap !important;
        overflow: visible !important; /* Changed from hidden to visible */
        width: 100% !important;
        max-width: 100% !important;
        margin-bottom: 1.5rem !important;
    }

    .timer-box {
        background: #dc2626 !important;
        color: white !important;
        padding: 15px 12px !important;
        border-radius: 8px !important;
        min-width: 100px !important;
        max-width: 140px !important;
        flex: 1 1 auto !important;
        text-align: center !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        overflow: hidden !important; /* Hide any scroll */
        box-sizing: border-box !important;
    }

    .timer-value {
        font-size: 2rem !important;
        line-height: 1 !important;
        font-weight: 700 !important;
        color: white !important;
        text-align: center !important;
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .timer-label {
        font-size: 0.7rem !important;
        line-height: 1 !important;
        text-transform: uppercase !important;
        color: white !important;
        text-align: center !important;
        display: block !important;
        width: 100% !important;
        margin-top: 5px !important;
        padding: 0 !important;
    }

    .countdown-cta {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 14px 24px !important;
        font-size: 0.9rem !important;
        text-align: center !important;
        margin: 0 auto !important;
        max-width: 90% !important;
    }
}

/* ==========================================
   ABOUT SECTION - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .about-section {
        padding: 40px 0 !important;
    }

    .experience-stats {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 1rem !important;
    }

    .stat-item {
        padding: 1rem !important;
    }

    .stat-value {
        font-size: 1.5rem !important;
    }

    .stat-text {
        font-size: 0.8rem !important;
    }

    .features-list {
        text-align: left !important;
        padding-left: 20px !important;
    }

    .features-list li {
        font-size: 0.9rem !important;
        margin-bottom: 0.5rem !important;
    }
}

/* ==========================================
   BOOKING FORM - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .booking-section {
        padding: 40px 0 !important;
    }

    .booking-form {
        padding: 1.5rem 1rem !important;
    }

    .form-row {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0.75rem !important;
    }

    .booking-form input,
    .booking-form select,
    .booking-form textarea {
        width: 100% !important;
        max-width: 100% !important;
        padding: 12px !important;
        font-size: 0.95rem !important;
    }

    .submit-btn {
        width: 100% !important;
        padding: 14px 20px !important;
        font-size: 0.95rem !important;
    }
}

/* ==========================================
   MAP - RESPONSIVE
   ========================================== */

@media (max-width: 767px) {
    .map-container {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: hidden !important;
    }

    .map-container iframe {
        width: 100% !important;
        max-width: 100% !important;
        height: 300px !important;
    }
}

/* ==========================================
   FAQ SECTION - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .faq-section {
        padding: 40px 0 !important;
    }

    .faq-grid {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
    }

    .faq-item {
        margin-bottom: 0.75rem !important;
    }

    .faq-question {
        padding: 1rem !important;
        font-size: 1rem !important;
    }

    .faq-answer {
        padding: 0 1rem !important;
        font-size: 0.9rem !important;
    }

    .faq-item.active .faq-answer {
        padding: 1rem !important;
    }
}

/* ==========================================
   FOOTER - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .main-footer {
        padding: 2rem 0 1rem !important;
    }

    .footer-content {
        text-align: center !important;
    }

    .footer-column {
        margin-bottom: 1.5rem !important;
    }

    .footer-column h4 {
        font-size: 1.1rem !important;
    }

    .footer-column ul {
        padding: 0 !important;
    }

    .footer-column li {
        font-size: 0.9rem !important;
        margin-bottom: 0.5rem !important;
    }

    .social-links,
    .payment-methods {
        justify-content: center !important;
        flex-wrap: wrap !important;
    }
}

/* ==========================================
   HEADER - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .main-header {
        position: sticky !important;
        top: 0 !important;
        z-index: 1000 !important;
        width: 100% !important;
    }

    .header-content {
        padding: 0.75rem 0 !important;
        width: 100% !important;
    }

    .logo-primary {
        font-size: 1.5rem !important;
    }

    .logo-secondary {
        font-size: 0.9rem !important;
    }
}

/* ==========================================
   BREADCRUMB - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    .breadcrumb {
        padding: 10px 0 !important;
        font-size: 0.85rem !important;
        overflow-x: auto !important;
        white-space: nowrap !important;
    }
}

/* ==========================================
   PREVENT TEXT OVERFLOW EVERYWHERE
   ========================================== */

@media (max-width: 767px) {
    * {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
    }

    /* Prevent long URLs from breaking layout */
    a {
        word-break: break-all !important;
    }
}

/* ==========================================
   SECTION PADDING - CONSISTENT
   ========================================== */

@media (max-width: 767px) {
    section {
        padding: 40px 0 !important;
    }

    .container {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }
}

/* ==========================================
   BACK TO TOP BUTTON - MOBILE FIX
   ========================================== */

@media (max-width: 767px) {
    #backToTop {
        position: fixed !important;
        bottom: 20px !important;
        right: 20px !important;
        z-index: 9999 !important;
        border: none !important;
        outline: none !important;
        background-color: #1e40af !important;
        background: linear-gradient(135deg, #1e40af 0%, #1565C0 100%) !important;
        color: white !important;
        cursor: pointer !important;
        padding: 12px !important;
        border-radius: 50% !important;
        font-size: 16px !important;
        width: 50px !important;
        height: 50px !important;
        box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important;
        transition: all 0.3s ease !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        opacity: 0.9 !important;
    }

    #backToTop:active {
        transform: scale(0.95) !important;
        opacity: 1 !important;
    }

    #backToTop svg {
        width: 24px !important;
        height: 24px !important;
        display: block !important;
        margin: 0 auto !important;
    }

    /* Ensure button doesn't overlap with content */
    #backToTop:hover {
        background: linear-gradient(135deg, #3b82f6 0%, #2196F3 100%) !important;
        transform: scale(1.05) !important;
        box-shadow: 0 6px 16px rgba(0,0,0,0.4) !important;
        opacity: 1 !important;
    }
}
