/* header_style_one.css - FINAL v6 (Includes Search Filter Styles) */
/* (Yeh file header_style.css ki jagah istemaal hogi) */
/* === 1. Basic Setup & Color Variables === */
:root {
    --color-primary: #007bff;     /* Blue */
    --color-primary-dark: #0056b3;
    --color-text: #333;
    --color-text-light: #666;
    --color-bg: #f8f9fa;         /* Light Gray Background */
    --color-card-bg: #ffffff;    /* White cards */
    --color-border: #e9ecef;     /* Light border */
    --color-success: #28a745;
    --color-error: #dc3545;
    --shadow-sm: 0 2px 4px rgba(0,0,0,0.05);
    --shadow-md: 0 4px 10px rgba(0,0,0,0.08);
    --border-radius: 8px;
}

body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; margin: 0; background-color: var(--color-bg); color: var(--color-text); line-height: 1.6; }
ul { list-style: none; margin: 0; padding: 0; }
a { text-decoration: none; color: inherit; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 15px; }

/* === 2. Header (Sticky) === */
.site-header { background-color: var(--color-card-bg); box-shadow: var(--shadow-sm); position: sticky; top: 0; z-index: 1000; width: 100%; }

/* === 3. Top Bar === */
.top-bar { padding: 10px 0; }
.top-bar-content { display: flex; justify-content: space-between; align-items: center; }
.logo-nav { display: flex; align-items: center; }
.logo { font-weight: bold; font-size: 1.5em; margin-right: 25px; color: var(--color-primary); }
.logo img{ max-height: 40px; vertical-align: middle; }

/* Desktop Main Nav */
/* RESTORED: Styles for .main-nav */
.main-nav { display: flex !important; }
.main-nav ul { display: flex !important; align-items: center !important; }
.main-nav li { margin-right: 20px; }
.main-nav a { color: var(--color-text-light); font-weight: 500; padding-bottom: 5px; border-bottom: 3px solid transparent; transition: color 0.2s, border-bottom-color 0.2s; white-space: nowrap; }
.main-nav a:hover, .main-nav a.active { color: #ff6f61; border-bottom-color: #ff6f61; }
.badge { background-color: #ff6f61; color: #fff; font-size: 0.7em; padding: 2px 5px; border-radius: 3px; margin-left: 5px; vertical-align: middle; }


/* Desktop User Actions */
.user-actions { display: flex !important; align-items: center !important; gap: 15px !important; font-size: 0.9em; color: var(--color-text-light); }
.user-actions a { color: var(--color-text-light); transition: color 0.2s; }
.user-actions a:not(.btn-secondary):hover { color: #ff6f61; }
/* NEW: Mobile user actions (Hidden on desktop by default) */
/* .user-actions.mobile-only { display: none !important; } */
/* UPDATED: !important hataya gaya taaki mobile view isey override kar sake */
/* .user-actions.mobile-only { display: none; } */

/* LATEST FIX: Desktop par mobile buttons ko force-hide karne ke liye !important waapas add kiya gaya */
.user-actions.mobile-only { display: none !important; }


/* === 4. Buttons (Header Specific) === */
.btn-secondary { background-color: #ff6f61 !important; color: white !important; padding: 8px 16px; border-radius: 5px; text-decoration: none; font-size: 0.9rem; font-weight: 600; border: none; cursor: pointer; transition: background-color 0.2s ease, box-shadow 0.2s ease; white-space: nowrap; }
.btn-secondary:hover { background-color: #e65a50 !important; box-shadow: var(--shadow-sm); }
.cart-button { position: relative; margin-left: 10px; min-width: 90px; text-align: center; }
#cart-item-count { position: absolute; top: -8px; right: -8px; background-color: var(--color-primary); color: white; border-radius: 50%; padding: 2px 6px; font-size: 0.75em; font-weight: bold; min-width: 18px; text-align: center; line-height: 1.1; border: 1px solid white; }
#cart-item-count:empty { display: none; }

/* === 5. Search Area === */
.search-area { background-color: var(--color-bg); padding: 15px 0; border-top: 1px solid var(--color-border); position: relative; z-index: 1001; overflow: visible !important; }
.search-area-content { display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.location-search { display: flex; align-items: center; flex-grow: 1; background-color: var(--color-card-bg); border: 1px solid var(--color-border); border-radius: var(--border-radius); overflow: visible !important; /* Allow suggestions to overflow */ }
.location-selector { display: flex; align-items: center; padding: 10px 15px; border-right: 1px solid var(--color-border); cursor: pointer; white-space: nowrap; color: var(--color-text-light); }
.location-selector i { margin-right: 8px; } .location-selector span { font-weight: 500; color: var(--color-text); } .location-selector .fa-caret-down { margin-left: 8px; margin-right: 0; }

/* === Search Suggestions Styles === */
.search-bar-container { position: relative; flex-grow: 1; overflow: visible !important; /* Allow suggestions to overflow */ }
.search-bar { display: flex; flex-grow: 1; }
.search-bar input { flex-grow: 1; border: none; padding: 10px 15px; font-size: 1em; outline: none; }
.search-bar button { background: none; border: none; padding: 0 15px; cursor: pointer; color: var(--color-text-light); font-size: 1.1em; }
.search-suggestions { display: none; position: absolute; left: 0; width: 100%; top: 100%; background-color: #fff; border: 1px solid var(--color-border); border-top: none; border-radius: 0 0 var(--border-radius) var(--border-radius); box-shadow: var(--shadow-md); z-index: 9999; max-height: 250px; overflow-y: auto; box-sizing: border-box; }
.suggestion-item { padding: 10px 15px; cursor: pointer; font-size: 0.9em; border-bottom: 1px solid var(--color-border); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.suggestion-item:last-child { border-bottom: none; }
.suggestion-item:hover { background-color: #f8f9fa; }
.suggestion-item strong { font-weight: 700; color: var(--color-primary); }
/* === END Search Suggestions Styles === */

.quick-actions { display: flex; align-items: center; gap: 15px; flex-shrink: 0; }
.offer-text { font-size: 0.9em; color: var(--color-text-light); white-space: nowrap; }
.offer-text i { color: #ff6f61; margin-right: 5px; }

/* === 6. Category Nav === */
.category-nav { background-color: var(--color-card-bg); border-top: 1px solid var(--color-border); padding: 8px 0; overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; position: relative; z-index: 1000; }
.category-nav ul { display: flex; padding: 0 15px; }
/* NEW: Hide mobile list by default */
/* .category-nav ul.mobile-only { display: none; } */
/* UPDATED: !important lagaya gaya taaki yeh desktop par hamesha hide rahe */
.category-nav ul.mobile-only { display: none !important; }
.category-nav li { margin-right: 25px; }
.category-nav a { color: var(--color-text-light); font-size: 0.9em; font-weight: 500; transition: color 0.2s; padding: 5px 0; }
.category-nav a:hover { color: #ff6f61; }
.category-nav i { font-size: 0.8em; margin-left: 3px; }

/* === 7. Mobile Menu Toggle (FORCE HIDE) === */
.mobile-menu-toggle {
    display: none !important; /* Force hide */
}

/* === 8. Mobile Nav Container (FORCE HIDE) === */
.mobile-nav-container {
    display: none !important; /* Force hide */
}
.mobile-nav-container.active {
    display: none !important; /* Force hide */
}
/* .user-actions-mobile { ... } */

/* === NEW STYLES for Search Filtering === */
.product-card.hidden-by-search {
    display: none !important; /* Hide the card when filtered */
}

#showAllProductsBtn {
    display: none; /* Hidden by default, shown by JS */
    margin: 1.5rem 0 0.5rem 0; /* Space above/below */
    padding: 10px 20px;
    cursor: pointer;
    background-color: var(--color-primary);
    color: white;
    border: none;
    border-radius: 5px;
    font-weight: 600;
    transition: background-color 0.2s ease;
}
#showAllProductsBtn:hover {
    background-color: var(--color-primary-dark);
}
/* === END NEW STYLES === */

/* === 9. Mobile Responsiveness === */
@media (max-width: 1024px) {
    .desktop-only { display: none !important; }
    /* .mobile-only { display: flex !important; } /* SHOW mobile user actions */
    /* UPDATED: Rule ko zyada specific banaya gaya hai */
    .user-actions.mobile-only { display: flex !important; } /* SHOW mobile user actions (FIXED SPECIFICITY) */
    /* NEW: Show mobile category list and hide desktop list (redundant but safe) */
    .category-nav ul.desktop-only { display: none !important; }
    .category-nav ul.mobile-only { display: flex !important; }
    
    /* REMOVED toggle/nav container styles */
    /* .mobile-menu-toggle { display: block; } */
    /* .mobile-nav-container:not(.active) { display: none !important; } */
    /* .mobile-nav-container.active { display: block !important; } */

    .logo-nav{ flex-grow: 0; }
    .search-area-content { flex-direction: column; align-items: stretch; }
    .location-search { margin-bottom: 10px; }
    .quick-actions { justify-content: flex-end; }
    .top-bar { border-bottom: none; }
}

@media (max-width: 768px) {
    .logo { margin-right: 15px; font-size: 1.3em; }
    .location-search { flex-direction: column; border: none; background: none; }
    .location-selector { width: 100%; border: 1px solid var(--color-border); border-radius: var(--border-radius); margin-bottom: 10px; justify-content: center; background-color: var(--color-card-bg); }
    .search-bar-container { width: 100%; }
    .search-bar { width: 100%; border: 1px solid var(--color-border); border-radius: var(--border-radius); background-color: var(--color-card-bg); }
    .quick-actions { flex-direction: row; justify-content: space-between; width: 100%; }
    .offer-text { flex-grow: 1; }
    .cart-button { margin-left: 0; }
    .category-nav li { margin-right: 15px; } /* Slightly reduce spacing for mobile */
    .btn-secondary { padding: 6px 12px; font-size: 0.85rem; }
    #showAllProductsBtn { width: 100%; text-align: center; } /* Make button full width on mobile */

    /* Adjust mobile user action buttons padding */
    .user-actions.mobile-only .btn-secondary {
        padding: 6px 10px;
        font-size: 0.8rem;
    }
}