/* Mobile Responsive CSS - Common File for All Pages */

/* ============================================
   Prevent Horizontal Scrolling & Fix Vertical Scrolling
   ============================================ */
html {
    overflow-x: hidden !important;
    max-width: 100vw !important;
    position: relative;
    -webkit-overflow-scrolling: touch !important;
    height: 100% !important;
}

body {
    overflow-x: hidden !important;
    max-width: 100vw !important;
    position: relative;
    -webkit-overflow-scrolling: touch !important;
    height: auto !important;
    min-height: 100vh !important;
    overflow-y: auto !important;
}

* {
    max-width: 100%;
    box-sizing: border-box;
}

/* Smooth scrolling for mobile - Fix Blink Issue */
@media (max-width: 767.98px) {
    html {
        scroll-behavior: smooth !important;
        -webkit-overflow-scrolling: touch !important;
        height: 100% !important;
    }

    body {
        -webkit-overflow-scrolling: touch !important;
        overscroll-behavior-y: contain !important;
        height: auto !important;
        min-height: 100vh !important;
        min-height: -webkit-fill-available !important; /* iOS Safari fix */
        /* Fix blink issue - disable GPU acceleration on scroll */
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        backface-visibility: hidden !important;
        -webkit-backface-visibility: hidden !important;
        perspective: 1000px !important;
        -webkit-perspective: 1000px !important;
    }

    /* Fix viewport height for mobile browsers */
    @supports (-webkit-touch-callout: none) {
        body {
            min-height: -webkit-fill-available !important;
        }
    }

    /* Prevent scroll chaining */
    .header,
    .main-nav {
        overscroll-behavior: contain !important;
    }

    /* Fix blink on buttons and interactive elements */
    .btn,
    .btn-outline,
    button,
    a.btn {
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        backface-visibility: hidden !important;
        -webkit-backface-visibility: hidden !important;
    }

    /* Section footer button - Fix blink */
    .section-footer {
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }

    .section-footer .btn,
    .section-footer .btn-outline {
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        transition: background-color 0.2s ease, color 0.2s ease !important;
        /* Remove transform transitions that cause blink */
        transition-property: background-color, color, border-color !important;
    }

    /* Disable hover transforms on mobile */
    .btn:hover,
    .btn-outline:hover,
    button:hover {
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }
}

/* ============================================
   Mobile First Approach - Media Queries
   ============================================ */

/* Extra Small Devices (phones, 320px and up) */
@media (max-width: 575.98px) {
    /* Container adjustments - Prevent overflow & Equal margins */
    .container {
        margin: 0 10px !important;
        padding: 0 10px !important;
        max-width: 100% !important;
        width: calc(100% - 20px) !important;
        box-sizing: border-box !important;
    }

    /* Header Mobile Styles */
    .header {
        padding: 8px 0 !important;
        width: 100% !important;
        overflow: hidden !important;
    }

    .header .container {
        margin: 0 15px !important;
        padding: 0 15px !important;
        max-width: 100% !important;
        width: calc(100% - 30px) !important;
        box-sizing: border-box !important;
    }

    .header-content {
        flex-direction: column !important;
        gap: 10px !important;
        align-items: stretch !important;
        width: 100% !important;
        flex-wrap: wrap !important;
    }

    /* Logo - Perfect Responsive */
    .logo {
        font-size: 16px !important;
        text-align: center !important;
        width: 100% !important;
        justify-content: center !important;
        flex-shrink: 0 !important;
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        padding: 5px 0 !important;
        order: 0 !important;
    }

    .logo span {
        font-size: 16px !important;
        font-weight: 700 !important;
    }

    .logo-icon {
        font-size: 22px !important;
        flex-shrink: 0 !important;
    }

    /* Logo hover effects disabled on mobile */
    .logo:hover {
        transform: none !important;
    }

    /* Offer Banner - Make Responsive */
    .offer-banner {
        width: 100% !important;
        max-width: 100% !important;
        padding: 6px 10px !important;
        font-size: 11px !important;
        margin: 0 !important;
        position: relative !important;
        left: auto !important;
        transform: none !important;
        order: 1;
        white-space: normal !important;
        word-wrap: break-word;
        text-align: center;
    }

    .offer-banner .banner-text {
        white-space: normal !important;
        display: block;
        line-height: 1.4;
    }

    /* Header Actions - Perfect Responsive */
    .header-actions {
        justify-content: space-around !important;
        gap: 5px !important;
        order: 2 !important;
        width: 100% !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        padding: 5px 0 !important;
    }

    .header-actions a {
        font-size: 11px !important;
        padding: 8px 6px !important;
        white-space: nowrap !important;
        flex: 1 1 0 !important;
        min-width: 0 !important;
        text-align: center !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 2px !important;
        border-radius: 6px !important;
        transition: background 0.2s ease !important;
    }

    .header-actions a:active {
        background: rgba(150, 111, 84, 0.1) !important;
    }

    .header-actions a span:not(.cart-count):not(.wishlist-count) {
        display: none !important; /* Hide text labels on very small screens */
    }

    /* Cart, Wishlist, Account Links */
    .cart-link, .wishlist-link, .account-link {
        font-size: 11px !important;
        gap: 2px !important;
        position: relative !important;
    }

    .cart-link i, .wishlist-link i, .account-link i {
        font-size: 18px !important;
        color: #FFFFFF !important;
    }

    .cart-count, .wishlist-count {
        font-size: 9px !important;
        padding: 2px 5px !important;
        min-width: 18px !important;
        height: 18px !important;
        border-radius: 9px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        position: absolute !important;
        top: -5px !important;
        right: -5px !important;
        background: #e74c3c !important;
        color: white !important;
        font-weight: bold !important;
    }

    /* User Account Dropdown Mobile */
    .user-account-section {
        display: flex !important;
        align-items: center !important;
        gap: 5px !important;
        flex: 1 1 0 !important;
        justify-content: center !important;
    }

    .user-dropdown {
        position: relative !important;
        display: inline-block !important;
    }

    .dropdown-toggle {
        background: rgba(255, 255, 255, 0.2) !important;
        border: 1px solid rgba(255, 255, 255, 0.3) !important;
        color: white !important;
        padding: 4px 6px !important;
        border-radius: 4px !important;
        font-size: 10px !important;
        width: auto !important;
        height: auto !important;
    }

    .user-dropdown-content {
        position: absolute !important;
        top: 100% !important;
        right: 0 !important;
        background: white !important;
        min-width: 180px !important;
        box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
        border-radius: 8px !important;
        margin-top: 5px !important;
        z-index: 10004 !important;
        display: none !important;
        padding: 8px 0 !important;
    }

    .user-dropdown.show .user-dropdown-content {
        display: block !important;
    }

    .user-dropdown-content a {
        display: block !important;
        padding: 10px 15px !important;
        color: #333 !important;
        text-decoration: none !important;
        font-size: 14px !important;
        transition: background 0.2s ease !important;
    }

    .user-dropdown-content a:hover {
        background: #f8f9fa !important;
        color: #966F54 !important;
    }

    .user-dropdown-content a i {
        margin-right: 8px !important;
        width: 18px !important;
        text-align: center !important;
    }

    /* Navigation Mobile - Perfect Hamburger Menu like Login/Register */
    .main-nav {
        width: 100% !important;
        overflow: hidden !important;
        position: relative !important;
    }

    .main-nav .container {
        margin: 0 10px !important;
        padding: 0 10px !important;
        max-width: 100% !important;
        width: calc(100% - 20px) !important;
        box-sizing: border-box !important;
    }

    .nav-content {
        flex-direction: column !important;
        padding: 0 !important;
        width: 100% !important;
    }

    /* Mobile Menu Toggle Button - Perfect styling */
    .mobile-menu-toggle {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: #966F54 !important;
        color: white !important;
        border: none !important;
        padding: 12px 15px !important;
        font-size: 15px !important;
        cursor: pointer !important;
        width: auto !important;
        min-width: auto !important;
        text-align: center !important;
        margin: 0 !important;
        border-radius: 8px !important;
        font-weight: 600 !important;
        transition: background 0.3s ease !important;
        position: fixed !important;
        top: 10px !important;
        left: 10px !important;
        z-index: 99999 !important;
        pointer-events: auto !important;
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: rgba(160, 122, 92, 0.3) !important;
        box-shadow: 0 2px 10px rgba(0,0,0,0.4) !important;
        isolation: isolate !important;
        transform: translateZ(0) !important;
    }
    
    /* Ensure banner doesn't interfere with menu button */
    .banner-slider {
        position: relative !important;
        z-index: 1 !important;
    }

    .mobile-menu-toggle:hover {
        background: #8B5A3C !important;
    }

    .mobile-menu-toggle i {
        margin-right: 8px !important;
        font-size: 16px !important;
    }

    /* Hide desktop nav links */
    .nav-links {
        display: none !important;
        width: 100% !important;
    }

    /* Show mobile nav when active */
    .nav-links.mobile-active {
        display: flex !important;
        flex-direction: column !important;
        list-style: none;
        margin: 0 !important;
        padding: 0 !important;
        gap: 0 !important;
        width: 100% !important;
        background: white;
        border-top: 1px solid #e0e0e0;
    }

    .nav-links.mobile-active li {
        width: 100% !important;
        border-bottom: 1px solid #f0f0f0;
    }

    .nav-links.mobile-active li a {
        display: block;
        padding: 15px 20px !important;
        color: #333 !important;
        text-decoration: none;
        font-size: 15px !important;
        width: 100% !important;
        border: none !important;
    }

    .nav-links.mobile-active li a:hover {
        background: #f8f9fa;
        color: #966F54 !important;
    }

    /* Dropdown in mobile menu - Perfect Responsive */
    .nav-links.mobile-active .dropdown {
        position: static !important;
        display: none !important;
        background: #f8f9fa !important;
        box-shadow: none !important;
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        width: 100% !important;
        min-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        border-top: 1px solid #e0e0e0 !important;
        max-height: 0 !important;
        overflow: hidden !important;
        transition: max-height 0.3s ease, padding 0.3s ease !important;
    }

    .nav-links.mobile-active li.active .dropdown,
    .nav-links.mobile-active li.menu-open .dropdown {
        display: block !important;
        max-height: 500px !important;
        padding: 5px 0 !important;
    }

    .nav-links.mobile-active .dropdown a {
        padding: 12px 35px !important;
        font-size: 14px !important;
        border-bottom: 1px solid #e8e8e8 !important;
        color: #555 !important;
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        transition: background 0.2s ease, color 0.2s ease !important;
    }

    .nav-links.mobile-active .dropdown a:hover {
        background: #e9ecef !important;
        color: #966F54 !important;
    }

    .nav-links.mobile-active .dropdown a i {
        font-size: 14px !important;
        width: 18px !important;
        text-align: center !important;
        color: #966F54 !important;
    }

    /* Menu items with dropdown - Add arrow indicator */
    .nav-links.mobile-active li > a {
        position: relative !important;
    }

    .nav-links.mobile-active li > a .fa-chevron-down {
        position: absolute !important;
        right: 20px !important;
        transition: transform 0.3s ease !important;
    }

    .nav-links.mobile-active li.active > a .fa-chevron-down,
    .nav-links.mobile-active li.menu-open > a .fa-chevron-down {
        transform: rotate(180deg) !important;
    }

    /* Search box in nav - Small & Compact for Mobile */
    .search-box {
        width: 100% !important;
        margin: 8px 0 !important;
        padding: 0 10px !important;
        order: 3;
        position: relative;
    }

    .search-box i {
        position: absolute;
        left: 15px;
        top: 50%;
        transform: translateY(-50%);
        color: #666;
        z-index: 1;
        font-size: 14px !important;
    }

    .search-box input {
        width: 100% !important;
        padding: 8px 12px 8px 38px !important;
        font-size: 14px !important;
        border: 2px solid #e9ecef !important;
        border-radius: 6px !important;
        box-sizing: border-box !important;
        height: 38px !important;
        line-height: 1.4 !important;
    }

    .search-box input:focus {
        border-color: #966F54 !important;
        outline: none !important;
    }

    .search-box input::placeholder {
        font-size: 13px !important;
    }

    /* Banner Slider Mobile - Perfect like Login/Register */
    .banner-slider {
        height: 280px !important;
        width: 100% !important;
        overflow: hidden !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .slider-container {
        width: 100% !important;
        height: 100% !important;
    }

    .slides-container {
        width: 100% !important;
        height: 100% !important;
    }

    .slide {
        min-width: 100% !important;
        width: 100% !important;
        height: 100% !important;
    }

    .slide-bg {
        width: 100% !important;
        height: 100% !important;
        background-size: cover !important;
        background-position: center !important;
    }

    .slide-content {
        padding: 15px !important;
        width: 100% !important;
    }

    .slide-content .container {
        margin: 0 10px !important;
        padding: 0 10px !important;
        max-width: 100% !important;
        width: calc(100% - 20px) !important;
        box-sizing: border-box !important;
    }

    .slide-text {
        width: 100% !important;
    }

    .slide-text h1 {
        font-size: 1.5rem !important;
        margin-bottom: 8px !important;
        line-height: 1.3 !important;
        padding: 0 10px !important;
    }

    .slide-text p {
        font-size: 0.85rem !important;
        margin-bottom: 12px !important;
        padding: 0 10px !important;
        line-height: 1.4 !important;
    }

    .slide-buttons {
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
        padding: 0 10px !important;
        align-items: center !important;
    }

    .slide-buttons .btn {
        width: 100% !important;
        max-width: 200px !important;
        padding: 10px 15px !important;
        font-size: 13px !important;
        margin: 0 !important;
    }

    /* Slider Dots Mobile */
    .slider-dots {
        bottom: 10px !important;
        gap: 6px !important;
    }

    .slider-dot {
        width: 8px !important;
        height: 8px !important;
    }

    /* Home page specific mobile styles - Perfect like Login/Register */
    body.home-page {
        padding-top: 0 !important;
        overflow-x: hidden !important;
    }

    .home-page {
        margin-top: 0 !important;
        padding-top: 0 !important;
        width: 100% !important;
        overflow-x: hidden !important;
    }

    .home-page .container {
        margin: 0 10px !important;
        padding: 0 10px !important;
        max-width: 100% !important;
        width: calc(100% - 20px) !important;
        box-sizing: border-box !important;
    }

    /* Features section mobile */
    .features-section {
        padding: 30px 0 !important;
    }

    .features-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }

    .feature-card {
        padding: 20px 15px !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .feature-icon {
        width: 45px !important;
        height: 45px !important;
        font-size: 1.1rem !important;
    }

    .feature-card h3 {
        font-size: 1rem !important;
        margin-bottom: 8px !important;
    }

    .feature-card p {
        font-size: 0.85rem !important;
        line-height: 1.5 !important;
    }

    /* Categories section mobile */
    .categories-section {
        padding: 30px 0 !important;
    }

    .categories-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }

    .category-card {
        height: auto !important;
        min-height: 200px !important;
        padding: 15px !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .category-image {
        height: 120px !important;
        margin-bottom: 10px !important;
    }

    .category-label .category-title {
        font-size: 1.1rem !important;
    }

    .category-label .category-link {
        font-size: 0.8rem !important;
    }

    /* Products section mobile */
    .products-section {
        padding: 30px 0 !important;
    }

    .products-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }

    .product-card {
        width: 100% !important;
        max-width: 100% !important;
        margin-bottom: 15px !important;
    }

    .product-buttons {
        flex-direction: column !important;
        gap: 8px !important;
    }

    .product-buttons .add-to-cart,
    .product-buttons .view-more {
        width: 100% !important;
        padding: 10px !important;
        font-size: 0.85rem !important;
    }

    /* Newsletter section mobile */
    .newsletter-section {
        padding: 30px 0 !important;
    }

    .newsletter-content {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        padding: 0 10px !important;
        text-align: center !important;
    }

    /* Hero content mobile */
    .hero-content {
        grid-template-columns: 1fr !important;
        gap: 25px !important;
        text-align: center !important;
        padding: 20px 10px !important;
    }

    .hero-title {
        font-size: 1.8rem !important;
        line-height: 1.3 !important;
    }

    .hero-stats {
        justify-content: center !important;
        flex-wrap: wrap !important;
        gap: 15px !important;
    }

    .hero-buttons {
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
        align-items: center !important;
    }

    .hero-buttons .btn {
        width: 100% !important;
        max-width: 250px !important;
        padding: 12px 20px !important;
        font-size: 14px !important;
    }

    /* Hero Section Mobile */
    .hero {
        padding: 30px 0 !important;
    }

    .hero h1 {
        font-size: 24px !important;
        margin-bottom: 12px !important;
        padding: 0 10px !important;
    }

    .hero p {
        font-size: 14px !important;
        margin-bottom: 20px !important;
        padding: 0 10px !important;
    }

    .cta-button {
        padding: 12px 20px !important;
        font-size: 14px !important;
        width: auto !important;
        max-width: 90%;
    }

    /* Banner Grid Mobile */
    .banner-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }

    .banner {
        padding: 20px !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .banner i {
        font-size: 32px !important;
    }

    .banner h3 {
        font-size: 18px !important;
    }

    .banner p {
        font-size: 13px !important;
    }

    /* Categories Mobile */
    .categories-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }

    .category-card {
        margin-bottom: 15px;
        width: 100% !important;
        max-width: 100% !important;
    }

    .category-image {
        height: 150px !important;
    }

    .category-content {
        padding: 15px !important;
    }

    .category-content h3 {
        font-size: 16px !important;
    }

    /* Features Mobile */
    .features {
        padding: 30px 0 !important;
    }

    .features-grid {
        grid-template-columns: 1fr !important;
        gap: 25px !important;
        padding: 0 10px !important;
    }

    .feature i {
        font-size: 32px !important;
    }

    .feature h3 {
        font-size: 18px !important;
    }

    /* Footer Mobile - Fix Scrolling Issue */
    .footer {
        padding: 30px 0 20px !important;
        margin-top: 40px !important;
        position: relative !important;
        width: 100% !important;
        overflow: visible !important;
    }

    .footer .container {
        margin: 0 10px !important;
        padding: 0 10px !important;
        max-width: 100% !important;
        width: calc(100% - 20px) !important;
        box-sizing: border-box !important;
    }

    .footer-content {
        grid-template-columns: 1fr !important;
        gap: 25px !important;
        padding: 0 !important;
        margin-bottom: 25px !important;
    }

    .footer-section {
        text-align: center;
        width: 100% !important;
    }

    .footer-bottom {
        padding-top: 20px !important;
        margin-top: 20px !important;
    }

    /* Ensure main content allows scrolling to footer */
    main {
        min-height: auto !important;
        padding-bottom: 20px !important;
    }

    /* Section Titles Mobile */
    .section-title {
        font-size: 22px !important;
        margin-bottom: 25px !important;
        padding: 0 10px !important;
    }

    /* Products Grid Mobile */
    .products-grid,
    .product-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }

    .product-card {
        margin-bottom: 15px;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Cart Mobile */
    .cart-item {
        flex-direction: column !important;
        gap: 15px !important;
        width: 100% !important;
    }

    .cart-item-image {
        width: 100% !important;
        max-width: 100% !important;
    }

    .cart-item-details {
        width: 100% !important;
    }

    /* Forms Mobile */
    .form-group {
        margin-bottom: 15px;
        width: 100% !important;
    }

    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    textarea,
    select {
        width: 100% !important;
        max-width: 100% !important;
        padding: 12px !important;
        font-size: 16px !important; /* Prevents zoom on iOS */
        box-sizing: border-box !important;
    }

    /* Buttons Mobile - Prevent Overflow & Fix Blink */
    .btn,
    button,
    input[type="submit"],
    .cta-button,
    .btn-outline {
        width: 100% !important;
        max-width: 100% !important;
        padding: 12px 15px !important;
        font-size: 15px !important;
        margin-bottom: 10px;
        box-sizing: border-box !important;
        white-space: normal !important;
        word-wrap: break-word;
        /* Fix blink issue */
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        backface-visibility: hidden !important;
        -webkit-backface-visibility: hidden !important;
        /* Optimize transitions */
        transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
        transition-property: background-color, color, border-color !important;
    }

    /* Section footer specific - Fix blink on scroll */
    .section-footer {
        position: relative !important;
        z-index: 1 !important;
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        padding: 20px 10px !important;
    }

    .section-footer .btn,
    .section-footer .btn-outline {
        position: relative !important;
        z-index: 1 !important;
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }

    /* Disable any animations on scroll */
    .section-footer * {
        animation: none !important;
        -webkit-animation: none !important;
    }

    /* Fix all product cards and sections that cause blink */
    .product-card,
    .feature-card,
    .category-card {
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        backface-visibility: hidden !important;
        -webkit-backface-visibility: hidden !important;
    }

    /* Disable hover transforms on mobile that cause blink */
    .product-card:hover,
    .feature-card:hover,
    .category-card:hover {
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }

    /* Fix sections that might cause blink */
    section {
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }

    /* Optimize scrolling performance */
    * {
        -webkit-font-smoothing: antialiased !important;
        -moz-osx-font-smoothing: grayscale !important;
    }

    /* Disable GPU acceleration on scroll for better performance */
    main,
    .home-page,
    .products-page {
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }

    /* Tables Mobile */
    table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Admin Panel Mobile */
    .admin-sidebar {
        width: 100% !important;
        position: fixed !important;
        height: 100vh !important;
        transform: translateX(-100%);
        transition: transform 0.3s ease;
        z-index: 10000;
    }

    .admin-sidebar.mobile-open {
        transform: translateX(0);
    }

    .admin-main {
        margin-left: 0 !important;
        width: 100% !important;
    }

    .admin-header {
        padding: 1rem !important;
        flex-direction: column !important;
        gap: 15px !important;
    }

    .admin-content {
        padding: 1rem !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .admin-mobile-menu-toggle {
        display: block !important;
        background: #8B4513;
        color: white;
        border: none;
        padding: 10px 15px;
        font-size: 18px;
        cursor: pointer;
        margin-bottom: 15px;
        width: 100% !important;
    }
}

/* Small Devices (landscape phones, 576px and up) */
@media (min-width: 576px) and (max-width: 767.98px) {
    .container {
        margin: 0 10px !important;
        padding: 0 10px !important;
        max-width: 100% !important;
        width: calc(100% - 20px) !important;
        box-sizing: border-box !important;
    }

    .header .container {
        margin: 0 10px !important;
        padding: 0 10px !important;
        max-width: 100% !important;
        width: calc(100% - 20px) !important;
        box-sizing: border-box !important;
    }

    .header-content {
        flex-wrap: wrap;
        gap: 12px;
    }

    .offer-banner {
        width: 100% !important;
        max-width: 100% !important;
        font-size: 12px !important;
        padding: 6px 12px !important;
        white-space: normal !important;
    }

    .search-bar {
        order: 3;
        width: 100%;
        margin: 0 !important;
    }

    .banner-slider {
        height: 400px !important;
    }

    .slide-text h1 {
        font-size: 2.2rem !important;
    }

    .slide-text p {
        font-size: 1rem !important;
    }

    .banner-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .categories-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .products-grid,
    .product-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Navigation still uses mobile menu */
    .mobile-menu-toggle {
        display: block !important;
    }

    .nav-links {
        display: none !important;
    }

    .nav-links.mobile-active {
        display: flex !important;
        flex-direction: column !important;
    }
}

/* Medium Devices (tablets, 768px and up) */
@media (min-width: 768px) and (max-width: 991.98px) {
    .container {
        margin: 0 20px !important;
        padding: 0 20px !important;
        max-width: 100% !important;
    }

    .header .container {
        margin: 0 20px !important;
        padding: 0 20px !important;
    }

    /* Header Responsive for Tablets */
    .header-content {
        flex-wrap: wrap !important;
        gap: 15px !important;
    }

    .logo {
        font-size: 20px !important;
        flex: 0 0 auto !important;
    }

    .logo-icon {
        font-size: 28px !important;
    }

    .offer-banner {
        width: auto !important;
        max-width: 100% !important;
        font-size: 13px !important;
        padding: 8px 15px !important;
        order: 1 !important;
        flex: 1 1 auto !important;
    }

    .header-actions {
        flex: 1 1 100% !important;
        order: 2 !important;
        justify-content: flex-end !important;
        gap: 15px !important;
    }

    .header-actions a span:not(.cart-count):not(.wishlist-count) {
        display: inline !important;
    }

    .header-actions a {
        flex-direction: row !important;
        font-size: 13px !important;
        padding: 8px 12px !important;
    }

    .search-bar {
        order: 3;
        width: 100%;
        max-width: 100% !important;
        margin: 15px 0 0 0 !important;
    }

    .banner-slider {
        height: 500px !important;
    }

    .banner-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .categories-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    .products-grid,
    .product-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    /* Show desktop nav on tablets */
    .mobile-menu-toggle {
        display: none !important;
    }

    .nav-links {
        display: flex !important;
        flex-direction: row !important;
        gap: 20px !important;
    }

    .nav-links li a {
        font-size: 14px !important;
        padding: 12px 15px !important;
    }

    /* Dropdown for tablets */
    .nav-links .dropdown {
        min-width: 200px !important;
    }

    .admin-sidebar {
        width: 200px !important;
    }

    .admin-main {
        margin-left: 200px !important;
    }
}

/* Large Devices (desktops, 992px and up) */
@media (min-width: 992px) and (max-width: 1199.98px) {
    .container {
        margin: 0 30px !important;
        padding: 0 20px !important;
    }

    .banner-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    .categories-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }

    .products-grid,
    .product-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* Extra Large Devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {
    /* Desktop styles - already defined in main CSS */
}

/* ============================================
   Common Mobile Utilities
   ============================================ */

/* Hide on mobile */
@media (max-width: 767.98px) {
    .desktop-only {
        display: none !important;
    }

    .mobile-hidden {
        display: none !important;
    }

    .mobile-menu-toggle {
        display: block !important;
    }
}

/* Show only on mobile */
@media (min-width: 768px) {
    .mobile-only {
        display: none !important;
    }

    .mobile-menu-toggle {
        display: none !important;
    }
}

/* Touch-friendly buttons and links */
@media (max-width: 767.98px) {
    a, button, .btn {
        min-height: 44px; /* iOS recommended touch target */
        min-width: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
}

/* Image responsiveness */
@media (max-width: 767.98px) {
    img {
        max-width: 100% !important;
        height: auto !important;
        display: block;
    }
}

/* Modal and Popup Mobile */
@media (max-width: 767.98px) {
    .modal-dialog {
        margin: 10px !important;
        max-width: calc(100% - 20px) !important;
        width: calc(100% - 20px) !important;
    }

    .modal-content {
        padding: 20px !important;
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* Product Detail Mobile */
@media (max-width: 767.98px) {
    .product-detail {
        flex-direction: column !important;
        width: 100% !important;
    }

    .product-detail-image {
        width: 100% !important;
        max-width: 100% !important;
        margin-bottom: 20px;
    }

    .product-detail-info {
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* Checkout Mobile */
@media (max-width: 767.98px) {
    .checkout-container {
        flex-direction: column !important;
        width: 100% !important;
    }

    .checkout-form,
    .checkout-summary {
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* User Dashboard Mobile */
@media (max-width: 767.98px) {
    .user-dashboard {
        flex-direction: column !important;
        width: 100% !important;
    }

    .user-sidebar {
        width: 100% !important;
        margin-bottom: 20px;
    }

    .user-content {
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* Text adjustments for mobile */
@media (max-width: 767.98px) {
    h1 {
        font-size: 22px !important;
    }

    h2 {
        font-size: 20px !important;
    }

    h3 {
        font-size: 18px !important;
    }

    h4 {
        font-size: 16px !important;
    }

    p {
        font-size: 14px !important;
        line-height: 1.6;
    }
}

/* Spacing adjustments for mobile */
@media (max-width: 767.98px) {
    .section {
        padding: 25px 0 !important;
    }

    .section-padding {
        padding: 15px 0 !important;
    }
}

/* Card adjustments for mobile */
@media (max-width: 767.98px) {
    .card {
        margin-bottom: 15px;
        width: 100% !important;
        max-width: 100% !important;
    }

    .card-body {
        padding: 15px !important;
    }
}

/* Prevent any element from causing horizontal scroll */
@media (max-width: 767.98px) {
    * {
        max-width: 100vw !important;
    }

    body > * {
        overflow-x: hidden !important;
    }

    /* Fix scrolling issues - Allow vertical scroll, prevent horizontal */
    html {
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        height: 100% !important;
    }

    body {
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        height: auto !important;
        min-height: 100vh !important;
        position: relative !important;
    }

    /* Fix iOS Safari scrolling bounce */
    @supports (-webkit-touch-callout: none) {
        body {
            position: relative !important;
            min-height: -webkit-fill-available !important;
        }
    }

    /* Ensure footer is reachable */
    .footer {
        position: relative !important;
        bottom: auto !important;
        margin-bottom: 0 !important;
    }

    /* Fix for sticky elements that might block scrolling */
    .header,
    .main-nav {
        position: sticky !important;
        top: 0 !important;
        z-index: 1000 !important;
    }
}

/* ============================================
   Additional Pages Mobile Styles - Perfect like Login/Register
   ============================================ */

/* Products Page Mobile */
@media (max-width: 767.98px) {
    .products-page {
        padding: 20px 0 !important;
    }

    .page-header {
        padding: 30px 15px !important;
        text-align: center !important;
    }

    .page-title {
        font-size: 1.8rem !important;
        margin-bottom: 10px !important;
    }

    .page-subtitle {
        font-size: 0.9rem !important;
    }

    .filters-sidebar {
        width: 100% !important;
        margin-bottom: 20px !important;
        padding: 15px !important;
    }

    .filter-group {
        margin-bottom: 20px !important;
    }

    .filter-group label {
        font-size: 14px !important;
    }

    .main-content {
        flex-direction: column !important;
    }

    .products-container {
        width: 100% !important;
    }
}

/* Cart Page Mobile */
@media (max-width: 767.98px) {
    .cart-page {
        padding: 20px 0 !important;
    }

    .cart-content,
    .cart-summary {
        padding: 20px 15px !important;
        margin-bottom: 20px !important;
    }

    .cart-item {
        padding: 15px !important;
        margin-bottom: 15px !important;
    }

    .cart-item-image img {
        width: 100% !important;
        height: auto !important;
    }

    .cart-summary {
        position: static !important;
        width: 100% !important;
    }
}

/* Checkout Page Mobile */
@media (max-width: 767.98px) {
    .checkout-page {
        padding: 20px 0 !important;
    }

    .checkout-form {
        padding: 20px 15px !important;
    }

    .checkout-summary {
        padding: 20px 15px !important;
        margin-top: 20px !important;
    }

    .payment-methods {
        flex-direction: column !important;
        gap: 10px !important;
    }
}

/* Product Detail Page Mobile */
@media (max-width: 767.98px) {
    .product-detail-page {
        padding: 20px 0 !important;
    }

    .product-detail-container {
        flex-direction: column !important;
        gap: 20px !important;
    }

    .product-images {
        width: 100% !important;
    }

    .product-info {
        width: 100% !important;
        padding: 0 10px !important;
    }

    .product-title {
        font-size: 1.5rem !important;
    }

    .product-price {
        font-size: 1.3rem !important;
    }

    .quantity-selector {
        width: 100% !important;
        justify-content: center !important;
    }
}

/* Contact Page Mobile */
@media (max-width: 767.98px) {
    .contact-page {
        padding: 20px 0 !important;
    }

    .contact-form {
        padding: 20px 15px !important;
    }

    .contact-info {
        margin-top: 30px !important;
        padding: 0 15px !important;
    }
}

/* About Page Mobile */
@media (max-width: 767.98px) {
    .about-page {
        padding: 20px 0 !important;
    }

    .about-content {
        padding: 0 15px !important;
    }

    .about-section {
        margin-bottom: 30px !important;
    }
}

/* User Dashboard Mobile - Fix Screen Shaking */
@media (max-width: 767.98px) {
    .user-dashboard-page,
    .user-dashboard {
        padding: 20px 0 !important;
        overflow-x: hidden !important;
        position: relative !important;
        /* Fix screen shaking */
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        backface-visibility: hidden !important;
        -webkit-backface-visibility: hidden !important;
        perspective: 1000px !important;
        -webkit-perspective: 1000px !important;
    }

    .dashboard-content {
        padding: 0 10px !important;
        /* Fix shaking */
        will-change: auto !important;
        transform: translateZ(0) !important;
    }

    .dashboard-cards {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        /* Fix shaking */
        will-change: auto !important;
    }

    /* User dashboard sidebar and main content */
    .user-dashboard .sidebar,
    .user-dashboard .main-content,
    .user-dashboard .dashboard-container {
        /* Fix screen shaking */
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
        backface-visibility: hidden !important;
        -webkit-backface-visibility: hidden !important;
    }

    /* User profile specific */
    .user-profile,
    .profile-form,
    .user-info,
    .sidebar-nav {
        /* Fix shaking */
        will-change: auto !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }

    /* Disable hover transforms that cause shake */
    .user-dashboard *:hover,
    .user-dashboard-page *:hover {
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
    }
}

/* All Pages Common Mobile Styles */
@media (max-width: 767.98px) {
    /* Page containers - Fix scrolling */
    main {
        padding: 0 !important;
        width: 100% !important;
        overflow-x: hidden !important;
        overflow-y: visible !important;
        min-height: auto !important;
        position: relative !important;
        padding-bottom: 20px !important;
    }

    /* Section spacing */
    section {
        padding: 25px 0 !important;
    }

    /* Cards */
    .card,
    .content-card {
        padding: 15px !important;
        margin-bottom: 15px !important;
    }

    /* Buttons in forms */
    .form-actions {
        flex-direction: column !important;
        gap: 10px !important;
    }

    .form-actions .btn {
        width: 100% !important;
    }

    /* Tables - make scrollable */
    .table-responsive {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    table {
        min-width: 600px !important;
    }

    /* Modals */
    .modal {
        padding: 10px !important;
    }

    .modal-header,
    .modal-body,
    .modal-footer {
        padding: 15px !important;
    }

    /* Help Form Modal - Mobile Top Position - Perfect */
    #helpFormModal {
        align-items: flex-start !important;
        justify-content: center !important;
        padding-top: 10px !important;
        padding-bottom: 10px !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        display: flex !important;
    }

    #helpFormModal > div {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
        margin-left: 10px !important;
        margin-right: 10px !important;
        max-height: calc(100vh - 20px) !important;
        width: calc(100% - 20px) !important;
        max-width: 100% !important;
        border-radius: 15px !important;
        overflow: hidden !important;
    }

    /* Modal header mobile */
    #helpFormModal > div > div:first-child {
        padding: 15px 20px !important;
    }

    #helpFormModal > div > div:first-child h2 {
        font-size: 20px !important;
        margin-bottom: 5px !important;
    }

    #helpFormModal > div > div:first-child p {
        font-size: 12px !important;
    }

    /* Modal content mobile */
    #helpFormModal > div > div:nth-child(2) {
        padding: 15px 12px !important;
        max-height: calc(100vh - 180px) !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    /* Close button mobile - Perfect & Always Visible - Only for close button */
    #closeHelpModalBtn {
        position: fixed !important;
        top: 15px !important;
        right: 15px !important;
        z-index: 10005 !important;
        width: 40px !important;
        height: 40px !important;
        font-size: 24px !important;
        background: rgba(255, 255, 255, 1) !important;
        color: #333 !important;
        border: 2px solid rgba(0, 0, 0, 0.25) !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3) !important;
        line-height: 1 !important;
        padding: 0 !important;
        margin: 0 !important;
        pointer-events: auto !important;
        -webkit-tap-highlight-color: transparent !important;
        touch-action: manipulation !important;
        user-select: none !important;
        -webkit-user-select: none !important;
    }

    #closeHelpModalBtn:hover {
        background: rgba(255, 255, 255, 1) !important;
        transform: scale(1.1) !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
    }

    #closeHelpModalBtn:active {
        transform: scale(0.9) !important;
        background: rgba(240, 240, 240, 1) !important;
    }

    /* Form fields mobile - Proper styling */
    #helpFormModal input[type="text"],
    #helpFormModal input[type="email"],
    #helpFormModal input[type="tel"],
    #helpFormModal textarea,
    #helpFormModal select {
        width: 100% !important;
        padding: 10px 12px !important;
        font-size: 15px !important;
        border: 2px solid #e9ecef !important;
        border-radius: 8px !important;
        box-sizing: border-box !important;
        margin: 0 !important;
        margin-top: 0 !important;
        line-height: 1.5 !important;
    }

    /* Form grid mobile - Single column - Name and Email */
    #helpFormModal form > div[style*="display: grid"] {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }

    /* Form group mobile */
    #helpFormModal .form-group-enhanced {
        margin-bottom: 15px !important;
    }

    #helpFormModal .form-group-enhanced label {
        font-size: 14px !important;
        margin-bottom: 5px !important;
        display: block !important;
        line-height: 1.4 !important;
    }

    /* Label icon spacing */
    #helpFormModal .form-group-enhanced label i {
        margin-right: 6px !important;
    }

    /* Radio buttons mobile - Stack vertically */
    #helpFormModal label[style*="display: flex"][style*="align-items: center"][style*="cursor: pointer"] {
        flex-direction: row !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 10px 12px !important;
        margin-bottom: 8px !important;
        width: 100% !important;
        justify-content: flex-start !important;
    }

    /* Radio button input mobile */
    #helpFormModal label[style*="cursor: pointer"] input[type="radio"] {
        margin: 0 !important;
        width: 18px !important;
        height: 18px !important;
        flex-shrink: 0 !important;
    }

    /* Radio button container mobile - Fast Acting Relief */
    #helpFormModal .form-group-enhanced > div[style*="display: flex"][style*="gap: 30px"] {
        flex-direction: column !important;
        gap: 8px !important;
        margin-top: 8px !important;
    }

    /* Submit button mobile - Proper position */
    #helpFormModal button[type="submit"] {
        width: 100% !important;
        padding: 14px 20px !important;
        font-size: 16px !important;
        border-radius: 10px !important;
        margin: 0 !important;
        position: relative !important;
        min-width: auto !important;
        text-align: center !important;
        display: block !important;
    }

    /* Submit button container mobile */
    #helpFormModal div[style*="text-align: center"][style*="margin-top: 25px"] {
        padding: 15px 10px !important;
        margin-top: 20px !important;
        border-radius: 12px !important;
    }

    /* Form gap mobile */
    #helpFormModal form {
        gap: 12px !important;
    }

    /* Select dropdown mobile */
    #helpFormModal select {
        padding-right: 40px !important;
        background-position: right 12px center !important;
    }

    /* Textarea mobile */
    #helpFormModal textarea {
        min-height: 100px !important;
        resize: vertical !important;
    }
}
