/* ============================================================================
   MOBILE-FIRST OPTIMIZATION — Teknik Uzmanım
   Version: 1.0
   Description: Comprehensive mobile UX overhaul
   ============================================================================ */

/* ==========================================================================
   1. CSS CUSTOM PROPERTIES (Mobile Overrides)
   ========================================================================== */
:root {
    --mobile-header-h: 56px;
    --mobile-dock-h: 64px;
    --mobile-touch-min: 44px;
    --mobile-radius: 12px;
    --mobile-gap: 8px;
    --m-primary: #16a34a;
    --m-primary-dark: #15803d;
    --m-success: #16a34a;
    --m-danger: #dc2626;
    --m-warning: #f59e0b;
    --m-text: #1e293b;
    --m-text-muted: #64748b;
    --m-bg: #f8fafc;
    --m-border: #e2e8f0;
    --m-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    --m-shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.12);
}

/* ==========================================================================
   2. MOBILE STICKY HEADER — Refined
   ========================================================================== */
@media (max-width: 1024px) {

    /* Top bar stays but is more compact on mobile */
    .top-bar {
        padding: 2px 0 !important;
        font-size: 10px !important;
    }

    .top-bar .top-bar-content {
        flex-wrap: nowrap !important;
        overflow: hidden !important;
    }

    .top-bar .top-bar-right {
        display: none !important;  /* Hide legal links on mobile top bar */
    }

    .top-bar .top-bar-left {
        width: 100% !important;
    }

    .top-bar .top-bar-left > a:not(.highlight) {
        display: none !important;  /* Hide phone/email, keep promo */
    }

    .top-bar .marquee-wrapper {
        width: 100% !important;
        flex: 1 !important;
    }

    /* Header wrapper refinement */
    #sticky-header-wrapper {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        z-index: 2147483647 !important;
        background: rgba(255, 255, 255, 0.97) !important;
        backdrop-filter: blur(20px) saturate(180%) !important;
        -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
        box-shadow: 0 1px 12px rgba(0, 0, 0, 0.06) !important;
        border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
    }

    /* Main header compact */
    .main-header {
        padding: 6px 0 !important;
    }

    .header-content {
        padding: 0 12px !important;
        gap: 8px !important;
    }

    /* Logo compact */
    .header-logo .logo-link {
        display: flex !important;
        align-items: center !important;
        gap: 6px !important;
    }

    .header-logo .logo-link img.logo-img {
        height: 28px !important;
        width: auto !important;
        max-width: 42px !important;
    }

    .logo-text {
        font-size: 11px !important;
        font-weight: 800 !important;
        letter-spacing: -0.01em !important;
    }

    .logo-text-sub {
        font-size: 7px !important;
        opacity: 0.7 !important;
    }

    /* Desktop elements hidden */
    .desktop-only,
    .header-search,
    .header-actions {
        display: none !important;
    }

    /* Mobile header actions */
    .mobile-header-actions {
        display: flex !important;
        align-items: center !important;
        gap: 2px !important;
        flex-shrink: 0 !important;
    }

    .mobile-action-btn,
    .mobile-search-toggle {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 40px !important;
        height: 40px !important;
        border-radius: 10px !important;
        background: transparent !important;
        color: var(--m-text) !important;
        transition: background 0.2s, transform 0.15s !important;
        border: none !important;
        cursor: pointer !important;
    }

    .mobile-action-btn:active,
    .mobile-search-toggle:active {
        transform: scale(0.92) !important;
        background: rgba(0, 0, 0, 0.04) !important;
    }

    /* Cart badge on mobile header */
    .mobile-filter-active-dot {
        position: absolute;
        top: 8px;
        right: 8px;
        width: 8px;
        height: 8px;
        background: #facc15;
        border-radius: 50%;
        border: 2px solid white;
    }

    .mobile-header-actions .cart-count {
        position: absolute !important;
        top: 2px !important;
        right: 0 !important;
        background: var(--m-danger) !important;
        color: white !important;
        font-size: 9px !important;
        font-weight: 800 !important;
        min-width: 16px !important;
        height: 16px !important;
        line-height: 16px !important;
        text-align: center !important;
        border-radius: 99px !important;
        padding: 0 4px !important;
        border: 2px solid white !important;
        box-shadow: 0 2px 6px rgba(220, 38, 38, 0.3) !important;
    }

    /* Navigation bar hidden on mobile */
    .main-nav {
        display: none !important;
    }

    /* Body padding for fixed header */
    body {
        padding-top: 80px !important;
        padding-bottom: calc(var(--mobile-dock-h) + 12px + env(safe-area-inset-bottom)) !important;
    }

    /* Mobile search expandable */
    .mobile-search-expandable {
        display: none;
        padding: 6px 12px 10px !important;
        background: white !important;
        border-top: 1px solid rgba(0, 0, 0, 0.04) !important;
    }

    .mobile-search-expandable.active {
        display: block !important;
        animation: mobileSlideDown 0.25s ease !important;
    }

    .mobile-search-expandable .search-form {
        display: flex !important;
        gap: 8px !important;
    }

    .mobile-search-expandable .search-input {
        flex: 1 !important;
        height: 42px !important;
        border-radius: 10px !important;
        border: 1.5px solid var(--m-border) !important;
        padding: 0 14px !important;
        font-size: 14px !important;
        background: var(--m-bg) !important;
        transition: border-color 0.2s !important;
    }

    .mobile-search-expandable .search-input:focus {
        border-color: var(--m-primary) !important;
        background: white !important;
        outline: none !important;
        box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
    }

    .mobile-search-expandable .search-btn {
        width: 42px !important;
        height: 42px !important;
        border-radius: 10px !important;
        border: none !important;
        background: var(--m-primary) !important;
        color: white !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-shrink: 0 !important;
    }
}

@keyframes mobileSlideDown {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   3. HAMBURGER MENU — Accordion Style (Left Side)
   ========================================================================== */
@media (max-width: 1024px) {

    .mobile-menu {
        position: fixed !important;
        inset: 0 !important;
        z-index: 2147483647 !important;
        display: none !important;
    }

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

    .mobile-menu-overlay {
        position: absolute !important;
        inset: 0 !important;
        background: rgba(15, 23, 42, 0.5) !important;
        backdrop-filter: blur(4px) !important;
        -webkit-backdrop-filter: blur(4px) !important;
        animation: fadeIn 0.3s ease !important;
    }

    .mobile-menu-content {
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        width: 85% !important;
        max-width: 340px !important;
        background: white !important;
        overflow-y: auto !important;
        overscroll-behavior: contain !important;
        -webkit-overflow-scrolling: touch !important;
        animation: menuSlideIn 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
        box-shadow: 8px 0 30px rgba(0, 0, 0, 0.15) !important;
    }

    /* Menu header */
    .mobile-menu-header {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 20px 16px !important;
        background: linear-gradient(135deg, #1e293b 0%, #334155 100%) !important;
        color: white !important;
    }

    .mobile-user-info {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
    }

    .user-avatar {
        width: 44px !important;
        height: 44px !important;
        border-radius: 12px !important;
        background: rgba(255, 255, 255, 0.15) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .user-avatar i {
        width: 22px !important;
        height: 22px !important;
        color: white !important;
    }

    .user-name {
        font-weight: 700 !important;
        font-size: 15px !important;
        color: white !important;
    }

    .user-role {
        font-size: 11px !important;
        color: rgba(255, 255, 255, 0.6) !important;
        font-weight: 600 !important;
    }

    .mobile-menu-close {
        width: 36px !important;
        height: 36px !important;
        border-radius: 10px !important;
        background: rgba(255, 255, 255, 0.1) !important;
        border: none !important;
        color: white !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
    }

    /* Nav sections */
    .mobile-nav-sections {
        padding: 8px 0 !important;
    }

    .mobile-nav-section {
        padding: 0 !important;
        border-bottom: 1px solid #f1f5f9 !important;
    }

    .mobile-nav-section h4 {
        padding: 14px 16px 6px !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.08em !important;
        color: #94a3b8 !important;
        margin: 0 !important;
    }

    .mobile-nav-list {
        list-style: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .mobile-nav-list li {
        border: none !important;
    }

    .mobile-nav-list li > a {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        padding: 13px 16px !important;
        color: var(--m-text) !important;
        text-decoration: none !important;
        font-size: 14px !important;
        font-weight: 600 !important;
        transition: background 0.15s !important;
        min-height: var(--mobile-touch-min) !important;
    }

    .mobile-nav-list li > a:active {
        background: #f1f5f9 !important;
    }

    .mobile-nav-list li > a i {
        width: 20px !important;
        height: 20px !important;
        color: var(--m-primary) !important;
        flex-shrink: 0 !important;
    }

    /* Accordion categories - Refined for Dual Action (Link + Toggle) */
    .mobile-accordion-item {
        border-bottom: 1px solid #f1f5f9;
    }

    .mobile-accordion-header {
        display: flex !important;
        align-items: stretch !important;
        width: 100% !important;
    }

    .mobile-accordion-header.active {
        color: #16a34a !important;
        background: #f0fdf4 !important;
    }

    .mobile-cat-link-main,
    .mobile-cat-link-single {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        padding: 13px 16px !important;
        color: var(--m-text) !important;
        text-decoration: none !important;
        font-size: 14px !important;
        font-weight: 600 !important;
        flex: 1 !important;
        transition: background 0.15s !important;
    }

    .mobile-cat-link-main:active,
    .mobile-cat-link-single:active {
        background: #f1f5f9 !important;
    }

    .mobile-accordion-toggle {
        width: 54px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border: none !important;
        background: none !important;
        border-left: 1px solid #f1f5f9 !important;
        cursor: pointer !important;
        transition: background 0.15s !important;
    }

    .mobile-accordion-toggle:active {
        background: #eff6ff !important;
    }

    .mobile-accordion-toggle .accordion-icon {
        width: 20px !important;
        height: 20px !important;
        color: #94a3b8 !important;
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
        flex-shrink: 0 !important;
    }

    .mobile-accordion-toggle.open .accordion-icon {
        transform: rotate(180deg) !important;
        color: var(--m-primary) !important;
    }

    .mobile-accordion-toggle.open {
        color: var(--m-primary) !important;
        background: #eff6ff !important;
    }

    .mobile-accordion-children {
        max-height: 0 !important;
        overflow: hidden !important;
        transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
        background: #fafbfc !important;
    }

    .mobile-accordion-children.open {
        max-height: 800px !important;
    }

    .mobile-accordion-children a {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 11px 16px 11px 44px !important;
        color: #475569 !important;
        text-decoration: none !important;
        font-size: 13px !important;
        font-weight: 500 !important;
        transition: background 0.15s, color 0.15s !important;
        min-height: 40px !important;
        border-left: 3px solid transparent !important;
    }

    .mobile-accordion-children a:active {
        background: #eff6ff !important;
        color: var(--m-primary) !important;
        border-left-color: var(--m-primary) !important;
    }

    /* Contact info */
    .mobile-contact-info {
        padding: 4px 8px 12px !important;
    }

    .mobile-contact-info .contact-item {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 10px 8px !important;
        color: var(--m-text) !important;
        font-size: 13px !important;
        font-weight: 600 !important;
        text-decoration: none !important;
        min-height: var(--mobile-touch-min) !important;
    }

    .mobile-contact-info .contact-item i {
        width: 18px !important;
        color: var(--m-primary) !important;
    }
}

@keyframes menuSlideIn {
    from { transform: translateX(-100%); }
    to { transform: translateX(0); }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* ==========================================================================
   4. MOBILE BOTTOM DOCK — 4 Items, Modern Design
   ========================================================================== */
@media (max-width: 900px) {

    .mobile-bottom-nav {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        background: rgba(255, 255, 255, 0.92) !important;
        backdrop-filter: blur(24px) saturate(180%) !important;
        -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
        border-top: 1px solid rgba(0, 0, 0, 0.04) !important;
        z-index: 2147483646 !important;
        padding: 6px 0 !important;
        padding-bottom: calc(6px + env(safe-area-inset-bottom)) !important;
        box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.06) !important;
        border-radius: 0 !important;
    }

    .mobile-bottom-nav .nav-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 3px !important;
        color: #94a3b8 !important;
        text-decoration: none !important;
        font-size: 10px !important;
        font-weight: 700 !important;
        transition: color 0.2s !important;
        position: relative !important;
        padding: 4px 0 !important;
        -webkit-tap-highlight-color: transparent !important;
    }

    .mobile-bottom-nav .nav-item i {
        width: 22px !important;
        height: 22px !important;
        stroke-width: 2 !important;
        transition: all 0.2s !important;
    }

    .mobile-bottom-nav .dock-link.active {
        color: #16a34a !important;
    }

    .dock-link.active i {
        color: #16a34a !important;
        transform: translateY(-4px) scale(1.1);
    }

    .mobile-bottom-nav .nav-item.active::before {
        content: '' !important;
        position: absolute !important;
        top: -6px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 24px !important;
        height: 3px !important;
        background: var(--m-primary) !important;
        border-radius: 0 0 3px 3px !important;
    }

    /* Cart badge in dock */
    .mobile-bottom-nav .nav-badge {
        position: absolute !important;
        top: -2px !important;
        right: -8px !important;
        background: var(--m-danger) !important;
        color: white !important;
        font-size: 9px !important;
        font-weight: 800 !important;
        min-width: 16px !important;
        height: 16px !important;
        line-height: 16px !important;
        text-align: center !important;
        border-radius: 99px !important;
        padding: 0 4px !important;
        border: 2px solid white !important;
        box-shadow: 0 2px 8px rgba(239, 68, 68, 0.35) !important;
        animation: badgePop 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
    }

    @keyframes badgePop {
        0% { transform: scale(0); }
        100% { transform: scale(1); }
    }
}

/* ==========================================================================
   5. PRODUCT GRID — Mobile Optimized 2-Column
   ========================================================================== */
@media (max-width: 1024px) {

    .product-grid {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: var(--mobile-gap) !important;
        padding: 4px !important;
    }

    .product-card {
        border-radius: 10px !important;
        border: 1px solid #f1f5f9 !important;
        overflow: hidden !important;
        background: white !important;
        transition: transform 0.2s, box-shadow 0.2s !important;
        display: flex !important;
        flex-direction: column !important;
        padding: 0 !important;
    }

    .product-card:active {
        transform: scale(0.98) !important;
    }

    .product-img-wrapper {
        aspect-ratio: 1 / 1 !important;
        overflow: hidden !important;
        padding: 0 !important;
        margin: 0 !important;
        background: #fafbfc !important;
        position: relative !important;
    }

    .product-img {
        width: 100% !important;
        height: 100% !important;
        object-fit: contain !important;
        object-position: center !important;
        display: block !important;
        padding: 8px !important;
    }

    /* Badge positioning */
    .product-badges {
        position: absolute !important;
        top: 6px !important;
        left: 6px !important;
        z-index: 2 !important;
    }

    .product-badges .badge {
        font-size: 8px !important;
        padding: 2px 6px !important;
        border-radius: 4px !important;
    }

    .fav-btn {
        position: absolute !important;
        top: 6px !important;
        right: 6px !important;
        z-index: 3 !important;
        width: 32px !important;
        height: 32px !important;
        border-radius: 8px !important;
        background: rgba(255, 255, 255, 0.85) !important;
        backdrop-filter: blur(4px) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border: none !important;
        cursor: pointer !important;
    }

    .fav-btn i {
        width: 16px !important;
        height: 16px !important;
    }

    .product-info {
        padding: 8px 10px 6px !important;
        flex: 1 !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 4px !important;
    }

    .product-rating {
        display: none !important;
    }

    .product-name {
        font-size: 12px !important;
        font-weight: 600 !important;
        line-height: 1.25 !important;
        color: #334155 !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
        height: auto !important;
        min-height: 30px !important;
    }

    .product-price-wrapper {
        margin-top: auto !important;
    }

    .old-price {
        font-size: 10px !important;
        color: #94a3b8 !important;
        text-decoration: line-through !important;
    }

    .current-price {
        font-size: 15px !important;
        font-weight: 800 !important;
        color: var(--m-primary) !important;
    }

    .product-actions {
        padding: 6px 10px 10px !important;
    }

    .product-actions .btn-add-cart {
        width: 100% !important;
        padding: 8px 0 !important;
        font-size: 11px !important;
        font-weight: 800 !important;
        border-radius: 8px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 6px !important;
        min-height: 38px !important;
        border: none !important;
        cursor: pointer !important;
        transition: transform 0.15s !important;
    }

    .product-actions .btn-add-cart:active {
        transform: scale(0.96) !important;
    }

    .product-actions .btn-out-of-stock {
        width: 100% !important;
        padding: 8px 0 !important;
        font-size: 11px !important;
        font-weight: 700 !important;
        border-radius: 8px !important;
        text-align: center !important;
        color: #94a3b8 !important;
        background: #f1f5f9 !important;
    }
}

/* ==========================================================================
   6. CATEGORY PAGE — Sticky Filter/Sort & Touch-Friendly
   ========================================================================== */
@media (max-width: 1024px) {

    /* Category layout */
    .category-layout {
        padding: 0 8px !important;
        margin-top: 8px !important;
    }

    /* Sticky filter/sort toolbar */
    .mobile-filter-toolbar {
        position: sticky !important;
        top: 80px !important; /* Below header */
        z-index: 100 !important;
        background: rgba(255, 255, 255, 0.95) !important;
        backdrop-filter: blur(12px) !important;
        -webkit-backdrop-filter: blur(12px) !important;
        padding: 8px 4px !important;
        margin: 0 -8px 8px !important;
        border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
        display: flex !important;
        gap: 8px !important;
        align-items: center !important;
    }

    .mobile-filter-btn {
        flex: 1 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        min-height: 46px !important;
        background: white !important;
        border: 1.5px solid var(--m-border) !important;
        border-radius: 12px !important;
        font-size: 13px !important;
        font-weight: 700 !important;
        color: var(--m-text) !important;
        cursor: pointer !important;
        transition: all 0.2s !important;
        padding: 10px 14px !important;
        -webkit-tap-highlight-color: transparent !important;
    }

    .mobile-filter-btn:active {
        transform: scale(0.97) !important;
        background: #f8fafc !important;
    }

    .mobile-filter-btn i {
        width: 18px !important;
        height: 18px !important;
        color: var(--m-primary) !important;
    }

    .mobile-filter-btn .filter-active-dot {
        width: 8px !important;
        height: 8px !important;
        background: var(--m-primary) !important;
        border-radius: 50% !important;
        display: inline-block !important;
        margin-left: 4px !important;
    }

    /* Category title */
    .category-layout h1 {
        font-size: 20px !important;
        margin-bottom: 4px !important;
    }

    .category-layout h1 + p {
        font-size: 12px !important;
        margin-bottom: 8px !important;
    }
}

/* ==========================================================================
   7. PRODUCT DETAIL PAGE — Floating CTA, Touch Qty, Trust Badges
   ========================================================================== */
@media (max-width: 900px) {

    /* Floating Add to Cart Bar */
    .mobile-floating-cta {
        position: fixed !important;
        bottom: calc(var(--mobile-dock-h) + env(safe-area-inset-bottom)) !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 10000 !important;
        background: rgba(255, 255, 255, 0.97) !important;
        backdrop-filter: blur(20px) saturate(180%) !important;
        -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
        padding: 10px 16px !important;
        box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.1) !important;
        border-top: 1px solid rgba(0, 0, 0, 0.05) !important;
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        transform: translateY(100%) !important;
        transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
    }

    .mobile-floating-cta.visible {
        transform: translateY(0) !important;
    }

    .mobile-floating-cta .cta-price {
        flex-shrink: 0 !important;
    }

    .mobile-floating-cta .cta-price-value {
        font-size: 18px !important;
        font-weight: 800 !important;
        color: var(--m-text) !important;
        line-height: 1.2 !important;
    }

    .mobile-floating-cta .cta-price-label {
        font-size: 10px !important;
        color: var(--m-text-muted) !important;
        font-weight: 600 !important;
    }

    .mobile-floating-cta .cta-btn {
        flex: 1 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        background: var(--m-primary) !important;
        color: white !important;
        border: none !important;
        padding: 14px 20px !important;
        border-radius: 14px !important;
        font-size: 15px !important;
        font-weight: 800 !important;
        cursor: pointer !important;
        transition: transform 0.15s, box-shadow 0.2s !important;
        min-height: 50px !important;
    }

    .mobile-floating-cta .cta-btn:active {
        transform: scale(0.97) !important;
    }

    .mobile-floating-cta .cta-btn:disabled {
        background: #94a3b8 !important;
        cursor: not-allowed !important;
    }

    .mobile-floating-cta .cta-btn i {
        width: 20px !important;
        height: 20px !important;
    }

    /* Touch-friendly Quantity Selector */
    .qty-input {
        display: flex !important;
        border: 2px solid var(--m-border) !important;
        border-radius: 14px !important;
        overflow: hidden !important;
        width: 100% !important;
    }

    .qty-btn {
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
        font-size: 22px !important;
        font-weight: 800 !important;
        background: white !important;
        border: none !important;
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: background 0.15s !important;
        color: var(--m-text) !important;
        -webkit-tap-highlight-color: transparent !important;
    }

    .qty-btn:active {
        background: #f1f5f9 !important;
    }

    .qty-val {
        flex: 1 !important;
        text-align: center !important;
        font-size: 18px !important;
        font-weight: 800 !important;
        border: none !important;
        border-left: 2px solid var(--m-border) !important;
        border-right: 2px solid var(--m-border) !important;
        color: var(--m-text) !important;
        background: #fafbfc !important;
    }

    /* Trust Badges — Compact Row */
    .mobile-trust-badges {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 8px !important;
        margin: 12px 0 !important;
    }

    .mobile-trust-badge {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        gap: 6px !important;
        padding: 12px 6px !important;
        background: #f8fafc !important;
        border: 1px solid #f1f5f9 !important;
        border-radius: 12px !important;
    }

    .mobile-trust-badge-icon {
        width: 36px !important;
        height: 36px !important;
        border-radius: 10px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .mobile-trust-badge-icon i {
        width: 20px !important;
        height: 20px !important;
    }

    .mobile-trust-badge-text {
        font-size: 10px !important;
        font-weight: 700 !important;
        color: var(--m-text) !important;
        line-height: 1.3 !important;
    }

    /* Product detail page fixes */
    .product-detail-container {
        padding: 0 10px !important;
        margin: 0 auto !important;
    }

    .product-detail-grid {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .gallery-column {
        position: static !important;
    }

    .main-image-wrapper {
        border-radius: 14px !important;
        padding: 10px !important;
        border: 1px solid #f1f5f9 !important;
        max-height: 350px !important;
    }

    .product-title {
        font-size: 16px !important;
        line-height: 1.35 !important;
        margin-top: 4px !important;
    }

    .price-box {
        padding: 16px !important;
        border-radius: 14px !important;
    }

    .price-box .current-price {
        font-size: 28px !important;
    }

    /* Features list compact */
    .features-list {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }

    .feature-badge {
        padding: 10px !important;
        border-radius: 10px !important;
        font-size: 11px !important;
        gap: 6px !important;
    }

    .feature-badge i {
        width: 18px !important;
        height: 18px !important;
    }

    /* Tabs mobile */
    .product-tabs {
        border-radius: 14px !important;
        overflow: hidden !important;
    }

    .tab-header {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
    }

    .tab-header::-webkit-scrollbar {
        display: none !important;
    }

    .tab-btn {
        padding: 12px 14px !important;
        font-size: 12px !important;
        white-space: nowrap !important;
        min-height: var(--mobile-touch-min) !important;
    }

    .tab-content {
        padding: 14px !important;
    }

    /* Hide action buttons text on mobile */
    .action-buttons .btn-icon span {
        display: none !important;
    }

    .action-buttons .btn-icon {
        width: 48px !important;
        height: 48px !important;
        padding: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 12px !important;
    }

    /* Product body needs extra padding for floating CTA */
    .product-detail-container {
        padding-bottom: 80px !important;
    }
}

/* ==========================================================================
   8. CHECKOUT — Minimalist Mobile
   ========================================================================== */
@media (max-width: 900px) {

    .checkout-container {
        padding: 0 10px !important;
        padding-bottom: 140px !important;
    }

    .checkout-grid {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .checkout-section {
        padding: 16px !important;
        border-radius: 14px !important;
        margin-bottom: 12px !important;
    }

    .section-title {
        font-size: 15px !important;
    }

    .section-header {
        margin-bottom: 12px !important;
        padding-bottom: 10px !important;
    }

    /* Address cards single column */
    .address-grid {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    .address-card {
        padding: 14px !important;
        border-radius: 12px !important;
    }

    /* Form inputs mobile-optimized */
    .form-input {
        font-size: 16px !important; /* Prevents iOS zoom */
        padding: 12px 14px !important;
        border-radius: 10px !important;
        min-height: 48px !important;
    }

    .form-row {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    /* Payment options */
    .payment-option {
        padding: 14px !important;
        border-radius: 12px !important;
        min-height: var(--mobile-touch-min) !important;
    }

    /* Summary card mobile */
    .summary-card {
        border-radius: 14px !important;
        padding: 16px !important;
        position: static !important;
    }

    /* Mobile checkout sticky action */
    .mobile-sticky-action {
        display: flex !important;
        position: fixed !important;
        bottom: calc(var(--mobile-dock-h) + env(safe-area-inset-bottom)) !important;
        left: 0 !important;
        right: 0 !important;
        background: rgba(255, 255, 255, 0.97) !important;
        backdrop-filter: blur(20px) !important;
        -webkit-backdrop-filter: blur(20px) !important;
        padding: 12px 16px !important;
        box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.1) !important;
        z-index: 10001 !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 12px !important;
        border-top: 1px solid rgba(0, 0, 0, 0.05) !important;
    }

    /* Step indicator compact */
    .checkout-steps {
        margin-bottom: 16px !important;
        padding: 0 !important;
    }

    .step-circle {
        width: 30px !important;
        height: 30px !important;
        font-size: 12px !important;
    }

    .step-label {
        font-size: 9px !important;
    }

    .checkout-steps::before {
        top: 15px !important;
    }
}

/* ==========================================================================
   9. HOME PAGE — Mobile Slider & Hero
   ========================================================================== */
@media (max-width: 1024px) {

    .hero-section {
        margin-bottom: 16px !important;
        border-radius: 14px !important;
        overflow: hidden !important;
    }

    .slider-container .product-card {
        flex: 0 0 calc(50% - 4px) !important;
        min-width: 150px !important;
    }

    .slider-container {
        gap: 8px !important;
        padding-left: 8px !important;
        padding-right: 8px !important;
    }
}

/* ==========================================================================
   10. CART PAGE — Mobile Optimized
   ========================================================================== */
@media (max-width: 900px) {

    .cart-item-grid {
        grid-template-columns: 1fr !important;
    }

    .cart-item {
        padding: 12px !important;
        border-radius: 12px !important;
        gap: 10px !important;
    }

    .cart-item-image {
        width: 80px !important;
        height: 80px !important;
    }
}

/* ==========================================================================
   11. GLOBAL MOBILE UTILITIES
   ========================================================================== */
@media (max-width: 1024px) {

    /* Containers full width */
    .container,
    .container-wide {
        padding-left: 0 !important;
        padding-right: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Smooth scrolling */
    html {
        scroll-behavior: smooth !important;
        -webkit-text-size-adjust: 100% !important;
    }

    /* Prevent horizontal overflow */
    body {
        overflow-x: hidden !important;
    }

    /* Tap highlight removal */
    * {
        -webkit-tap-highlight-color: transparent;
    }

    /* Search results dropdown mobile */
    .search-results-dropdown {
        border-radius: 0 0 12px 12px !important;
        max-height: 60vh !important;
    }

    .search-result-item {
        padding: 10px 12px !important;
        gap: 10px !important;
    }

    /* Image optimization hints */
    img {
        content-visibility: auto;
    }

    /* Footer mobile adjustments */
    footer {
        padding: 2rem 1rem 1rem !important;
        margin-top: 2rem !important;
    }

    footer .container {
        gap: 2rem !important;
    }

    /* Cookie banner position adjustment for dock */
    #cookie-banner {
        bottom: calc(var(--mobile-dock-h) + 16px + env(safe-area-inset-bottom)) !important;
        left: 12px !important;
        right: 12px !important;
        border-radius: 14px !important;
    }
}

/* ==========================================================================
   12. WEBP IMAGE SUPPORT
   ========================================================================== */
.webp-container picture {
    display: block;
    width: 100%;
    height: 100%;
}

.webp-container picture img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* ==========================================================================
   13. ANIMATIONS
   ========================================================================== */
@keyframes slideUp {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

@keyframes slideDown {
    from { transform: translateY(-10px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

/* Product card entrance animation */
@media (max-width: 1024px) {
    .product-card.animate-fadeIn {
        animation: cardFadeIn 0.4s ease both !important;
    }

    @keyframes cardFadeIn {
        from { opacity: 0; transform: translateY(12px); }
        to { opacity: 1; transform: translateY(0); }
    }
}
