/* =============================================
   PALMTREE SHOPPING - COMPLETE DESIGN SYSTEM
   ============================================= */

:root {
    --primary: #FFD700;
    --primary-light: #FFF8DC;
    --primary-dark: #E6B800;
    --black: #111111;
    --dark: #2d2d2d;
    --gray: #6b6b6b;
    --light-gray: #f6f6f6;
    --border: #ebebeb;
    --white: #ffffff;
    --font: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --shadow-sm: 0 2px 8px rgba(0,0,0,0.05);
    --shadow: 0 4px 20px rgba(0,0,0,0.08);
    --shadow-lg: 0 10px 40px rgba(0,0,0,0.12);
    --radius: 8px;
    --radius-lg: 16px;
    --radius-pill: 50px;
    --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font); font-size: 14px; color: var(--black); background: var(--white); line-height: 1.6; overflow-x: hidden; }
a { text-decoration: none; color: inherit; transition: var(--transition); }
button { cursor: pointer; border: none; outline: none; font-family: var(--font); }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }

/* ---- LOADING SCREEN ---- */
.loading-screen { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 100vh; background: var(--white); gap: 16px; }
.loading-logo { font-size: 56px; animation: loadBounce 1s ease-in-out infinite alternate; }
.loading-spinner { width: 42px; height: 42px; border: 3px solid var(--primary-light); border-top-color: var(--primary); border-radius: 50%; animation: spin 0.8s linear infinite; }
.loading-text { font-size: 18px; font-weight: 700; color: var(--black); letter-spacing: 0.5px; }

@keyframes loadBounce { from { transform: translateY(0) scale(1); } to { transform: translateY(-14px) scale(1.05); } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes float { 0%,100% { transform: translateY(0) rotate(-3deg); } 50% { transform: translateY(-12px) rotate(3deg); } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pulse { 0%,100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.4); opacity: 0.7; } }

/* ---- ANNOUNCEMENT BAR ---- */
.announcement-bar { background: var(--primary); color: var(--black); display: flex; align-items: center; justify-content: space-between; padding: 7px 24px; font-size: 12.5px; font-weight: 500; position: sticky; top: 0; z-index: 1000; }
.announcement-social { display: flex; gap: 12px; align-items: center; }
.announcement-social a { color: var(--black); font-size: 13px; transition: var(--transition); }
.announcement-social a:hover { transform: scale(1.2); }
.announcement-text { text-align: center; flex: 1; padding: 0 16px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.announcement-right a { color: var(--black); font-weight: 600; display: flex; align-items: center; gap: 5px; font-size: 12.5px; }
.announcement-right a:hover { text-decoration: underline; }

/* ---- MAIN HEADER ---- */
.main-header { background: var(--white); border-bottom: 1px solid var(--border); position: sticky; top: 37px; z-index: 999; box-shadow: var(--shadow-sm); }
.header-container { max-width: 1300px; margin: 0 auto; display: flex; align-items: center; padding: 12px 24px; gap: 20px; }
.header-logo a { display: flex; align-items: center; gap: 10px; }
.header-logo .logo-icon { font-size: 34px; line-height: 1; }
.header-logo .logo-text { font-size: 19px; font-weight: 800; color: var(--black); line-height: 1.1; letter-spacing: -0.5px; }
.header-logo .logo-text small { display: block; font-size: 10px; font-weight: 400; color: var(--gray); letter-spacing: 2.5px; text-transform: uppercase; }
.header-logo .logo-img { height: 40px; width: auto; }
.header-search { flex: 1; }
.search-box { display: flex; border: 2px solid var(--border); border-radius: var(--radius-pill); overflow: hidden; transition: var(--transition); }
.search-box:focus-within { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(255,215,0,0.2); }
.search-box input { flex: 1; padding: 10px 18px; border: none; outline: none; font-family: var(--font); font-size: 13.5px; color: var(--black); background: transparent; }
.search-box input::placeholder { color: #bbb; }
.search-btn { background: var(--primary); color: var(--black); border: none; padding: 10px 20px; font-size: 15px; cursor: pointer; transition: var(--transition); }
.search-btn:hover { background: var(--primary-dark); }
.header-actions { display: flex; align-items: center; gap: 10px; }
.header-action-btn { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 6px 12px; color: var(--black); font-size: 10.5px; font-weight: 500; border-radius: var(--radius); transition: var(--transition); }
.header-action-btn i { font-size: 20px; }
.header-action-btn:hover { background: var(--light-gray); }
.header-cart-btn { display: flex; align-items: center; gap: 8px; background: var(--primary); color: var(--black); padding: 10px 18px; border-radius: var(--radius-pill); font-size: 13px; font-weight: 700; transition: var(--transition); }
.header-cart-btn:hover { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(255,215,0,0.45); }
.cart-count { background: var(--black); color: var(--white); font-size: 10px; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }

/* ---- NAVIGATION ---- */
.main-nav { background: var(--white); border-bottom: 2px solid var(--border); position: sticky; top: 97px; z-index: 998; }
.nav-container { max-width: 1300px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; }
.nav-links { display: flex; align-items: center; }
.nav-link { padding: 14px 16px; font-size: 13.5px; font-weight: 500; color: var(--dark); display: flex; align-items: center; gap: 5px; position: relative; transition: var(--transition); white-space: nowrap; }
.nav-link::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 0; height: 2px; background: var(--primary); border-radius: 2px; transition: var(--transition); }
.nav-link:hover::after, .nav-link.active::after { width: 80%; }
.nav-link:hover, .nav-link.active { color: var(--black); }
.nav-dropdown { position: relative; }
.nav-dropdown:hover .dropdown-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.dropdown-menu { position: absolute; top: 100%; left: 0; min-width: 200px; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 8px 0; opacity: 0; visibility: hidden; transform: translateY(-8px); transition: var(--transition); z-index: 999; }
.dropdown-menu a { display: block; padding: 9px 18px; font-size: 13px; color: var(--dark); transition: var(--transition); }
.dropdown-menu a:hover { background: var(--primary-light); color: var(--black); padding-left: 24px; }
.nav-delivery { display: flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 500; color: var(--gray); }
.nav-delivery i { color: var(--primary-dark); font-size: 15px; }

/* ---- MAIN CONTENT ---- */
main { min-height: 50vh; }

/* ---- HERO SLIDER ---- */
.hero-slider { position: relative; overflow: hidden; height: 480px; }
.slide { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; transform: translateX(40px); transition: all 0.6s cubic-bezier(0.4,0,0.2,1); pointer-events: none; }
.slide.active { opacity: 1; transform: translateX(0); pointer-events: all; }
.slide-content { max-width: 1300px; margin: 0 auto; padding: 0 64px; width: 100%; animation: fadeInUp 0.6s ease both; }
.slide-badge { display: inline-block; background: rgba(255,255,255,0.25); backdrop-filter: blur(10px); color: var(--white); padding: 4px 14px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 14px; border: 1px solid rgba(255,255,255,0.35); }
.slide-title { font-size: 52px; font-weight: 900; color: var(--white); line-height: 1.1; margin-bottom: 14px; text-shadow: 0 2px 10px rgba(0,0,0,0.15); }
.slide-subtitle { font-size: 16px; color: rgba(255,255,255,0.88); margin-bottom: 28px; max-width: 450px; line-height: 1.65; }
.slide-btn { display: inline-flex; align-items: center; gap: 8px; background: var(--primary); color: var(--black); padding: 13px 28px; border-radius: var(--radius-pill); font-weight: 700; font-size: 14px; transition: var(--transition); box-shadow: 0 4px 18px rgba(255,215,0,0.45); }
.slide-btn:hover { background: var(--white); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.2); }
.slide-emoji { position: absolute; right: 8%; top: 50%; transform: translateY(-50%); font-size: 200px; opacity: 0.22; animation: float 3.5s ease-in-out infinite; pointer-events: none; }
.slider-controls { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); display: flex; align-items: center; gap: 10px; z-index: 10; }
.slider-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.45); cursor: pointer; transition: var(--transition); border: none; padding: 0; }
.slider-dot.active { width: 26px; border-radius: 4px; background: var(--white); }
.slider-dot:hover { background: rgba(255,255,255,0.75); }
.slider-arrow { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,0.18); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,0.3); color: var(--white); width: 46px; height: 46px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 15px; cursor: pointer; transition: var(--transition); z-index: 10; }
.slider-arrow:hover { background: rgba(255,255,255,0.35); transform: translateY(-50%) scale(1.08); }
.slider-arrow.prev { left: 18px; }
.slider-arrow.next { right: 18px; }

/* ---- FEATURES BAR ---- */
.features-bar { background: var(--light-gray); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 18px 0; }
.features-grid { max-width: 1300px; margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.feature-item { display: flex; align-items: center; gap: 12px; }
.feature-icon { width: 44px; height: 44px; background: var(--primary-light); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.feature-text strong { display: block; font-size: 13px; font-weight: 700; color: var(--black); }
.feature-text span { font-size: 11.5px; color: var(--gray); }

/* ---- SECTIONS ---- */
.section { padding: 60px 0; }
.section-container { max-width: 1300px; margin: 0 auto; padding: 0 24px; }
.section-header { text-align: center; margin-bottom: 40px; }
.section-badge { display: inline-block; background: var(--primary-light); color: #a07800; padding: 4px 14px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 10px; }
.section-title { font-size: 30px; font-weight: 800; color: var(--black); margin-bottom: 6px; position: relative; display: inline-block; }
.section-title::after { content: ''; position: absolute; bottom: -6px; left: 50%; transform: translateX(-50%); width: 44px; height: 3px; background: var(--primary); border-radius: 2px; }
.section-subtitle { color: var(--gray); font-size: 14.5px; margin-top: 14px; }
.bg-light { background: var(--light-gray); }

/* ---- CATEGORY CARDS ---- */
.categories-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.category-card { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 24px 16px; border-radius: var(--radius-lg); border: 1.5px solid var(--border); cursor: pointer; transition: var(--transition); background: var(--white); text-align: center; }
.category-card:hover { border-color: var(--primary); box-shadow: var(--shadow-lg); transform: translateY(-5px); }
.category-img { width: 96px; height: 96px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 42px; transition: var(--transition); }
.category-card:hover .category-img { transform: scale(1.12) rotate(6deg); }
.category-name { font-size: 13.5px; font-weight: 700; color: var(--black); }
.category-count { font-size: 11.5px; color: var(--gray); }

/* ---- PRODUCT CARDS ---- */
.products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.product-card { border: 1.5px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; background: var(--white); transition: var(--transition); position: relative; }
.product-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-5px); border-color: var(--primary); }
.product-badge { position: absolute; top: 12px; left: 12px; padding: 3px 10px; border-radius: var(--radius-pill); font-size: 10.5px; font-weight: 700; z-index: 2; }
.badge-new { background: var(--primary); color: var(--black); }
.badge-sale { background: #e53e3e; color: white; }
.badge-sold { background: #999; color: white; }
.product-img { height: 200px; display: flex; align-items: center; justify-content: center; font-size: 80px; position: relative; overflow: hidden; transition: var(--transition); }
.product-card:hover .product-img { transform: scale(1.04); }
.product-wishlist { position: absolute; top: 12px; right: 12px; width: 32px; height: 32px; background: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; color: var(--gray); box-shadow: var(--shadow-sm); cursor: pointer; transition: var(--transition); border: none; }
.product-wishlist:hover { color: #e53e3e; transform: scale(1.1); }
.product-info { padding: 14px 16px; }
.product-price { font-size: 12.5px; color: var(--gray); margin-bottom: 3px; }
.product-price strong { color: var(--black); font-size: 15px; font-weight: 700; }
.product-name { font-size: 13.5px; font-weight: 600; color: var(--dark); margin-bottom: 10px; line-height: 1.4; }
.product-rating { display: flex; align-items: center; gap: 4px; margin-bottom: 12px; font-size: 12px; color: var(--gray); }
.stars { color: #f59e0b; }
.product-actions { display: flex; gap: 7px; }
.btn-outline { flex: 1; padding: 9px 12px; border: 1.5px solid var(--black); border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; background: transparent; color: var(--black); cursor: pointer; transition: var(--transition); font-family: var(--font); }
.btn-outline:hover { background: var(--black); color: var(--white); }
.btn-primary-sm { padding: 9px 14px; border: 1.5px solid var(--primary); border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; background: var(--primary); color: var(--black); cursor: pointer; transition: var(--transition); font-family: var(--font); white-space: nowrap; }
.btn-primary-sm:hover { background: var(--primary-dark); border-color: var(--primary-dark); }

/* ---- PROMO BANNERS ---- */
.banners-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.banner-card { border-radius: var(--radius-lg); padding: 32px 28px; display: flex; flex-direction: column; justify-content: flex-end; min-height: 210px; position: relative; overflow: hidden; transition: var(--transition); }
.banner-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.banner-emoji { font-size: 76px; position: absolute; right: 18px; bottom: 18px; opacity: 0.45; transition: var(--transition); }
.banner-card:hover .banner-emoji { transform: scale(1.2) rotate(10deg); opacity: 0.65; }
.banner-tag { font-size: 10.5px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; opacity: 0.65; margin-bottom: 6px; }
.banner-title { font-size: 22px; font-weight: 800; line-height: 1.2; margin-bottom: 18px; }
.banner-btn { display: inline-flex; align-items: center; gap: 6px; padding: 9px 18px; border-radius: var(--radius-pill); font-size: 12.5px; font-weight: 700; cursor: pointer; transition: var(--transition); font-family: var(--font); width: fit-content; }
.banner-btn-dark { background: var(--black); color: var(--white); border: none; }
.banner-btn-dark:hover { background: var(--dark); transform: translateX(3px); }
.banner-btn-outline { background: transparent; color: var(--black); border: 2px solid var(--black); }
.banner-btn-outline:hover { background: var(--black); color: var(--white); }

/* ---- CARE ICONS ---- */
.care-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.care-card { display: flex; flex-direction: column; align-items: center; gap: 12px; cursor: pointer; transition: var(--transition); text-align: center; }
.care-card:hover { transform: translateY(-6px); }
.care-icon { width: 100px; height: 100px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 40px; transition: var(--transition); }
.care-card:hover .care-icon { box-shadow: 0 10px 30px rgba(0,0,0,0.12); transform: scale(1.05); }
.care-name { font-size: 14px; font-weight: 700; color: var(--black); }
.care-desc { font-size: 12px; color: var(--gray); }

/* ---- TESTIMONIALS ---- */
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.testimonial-card { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 24px; transition: var(--transition); }
.testimonial-card:hover { box-shadow: var(--shadow); border-color: var(--primary); }
.testimonial-stars { color: #f59e0b; font-size: 14px; margin-bottom: 12px; }
.testimonial-text { font-size: 13.5px; color: var(--dark); line-height: 1.75; margin-bottom: 16px; font-style: italic; }
.testimonial-author { display: flex; align-items: center; gap: 10px; }
.testimonial-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--primary-light); display: flex; align-items: center; justify-content: center; font-size: 16px; font-weight: 700; color: #a07800; }
.testimonial-name { font-size: 13px; font-weight: 700; color: var(--black); }
.testimonial-location { font-size: 11.5px; color: var(--gray); }

/* ---- NEWSLETTER ---- */
.newsletter-section { background: var(--primary); padding: 56px 0; }
.newsletter-container { max-width: 580px; margin: 0 auto; text-align: center; padding: 0 24px; }
.newsletter-section h2 { font-size: 28px; font-weight: 800; color: var(--black); margin-bottom: 8px; }
.newsletter-section p { font-size: 15px; color: rgba(0,0,0,0.6); margin-bottom: 28px; }
.newsletter-form-inline { display: flex; max-width: 460px; margin: 0 auto; border-radius: var(--radius-pill); overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,0.15); }
.newsletter-form-inline input { flex: 1; padding: 14px 20px; border: none; outline: none; font-family: var(--font); font-size: 13.5px; }
.newsletter-form-inline button { background: var(--black); color: var(--white); padding: 14px 22px; font-family: var(--font); font-size: 13px; font-weight: 700; cursor: pointer; transition: var(--transition); white-space: nowrap; border: none; }
.newsletter-form-inline button:hover { background: var(--dark); }

/* ---- FOOTER ---- */
.site-footer { background: #0f0f0f; color: rgba(255,255,255,0.68); padding-top: 56px; }
.footer-container { max-width: 1300px; margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1.5fr; gap: 40px; }
.footer-brand .footer-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.footer-brand .footer-logo .logo-icon { font-size: 26px; }
.footer-brand .footer-logo .logo-text { font-size: 17px; font-weight: 800; color: var(--white); }
.footer-brand .footer-logo .logo-img { height: 32px; width: auto; }
.footer-desc { font-size: 13px; line-height: 1.7; margin-bottom: 16px; color: rgba(255,255,255,0.55); }
.footer-contact p { font-size: 12.5px; display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.footer-contact i { color: var(--primary); width: 14px; }
.footer-social { display: flex; gap: 8px; margin-top: 16px; }
.footer-social a { width: 34px; height: 34px; background: rgba(255,255,255,0.08); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; color: rgba(255,255,255,0.7); transition: var(--transition); }
.footer-social a:hover { background: var(--primary); color: var(--black); transform: translateY(-3px); }
.footer-col h4 { font-size: 13px; font-weight: 700; color: var(--white); margin-bottom: 18px; text-transform: uppercase; letter-spacing: 1.5px; }
.footer-col ul li { margin-bottom: 9px; }
.footer-col ul li a { font-size: 13px; color: rgba(255,255,255,0.55); transition: var(--transition); }
.footer-col ul li a:hover { color: var(--primary); padding-left: 4px; }
.footer-newsletter h4 { font-size: 13px; font-weight: 700; color: var(--white); margin-bottom: 10px; text-transform: uppercase; letter-spacing: 1.5px; }
.footer-newsletter p { font-size: 12.5px; color: rgba(255,255,255,0.55); margin-bottom: 14px; line-height: 1.6; }
.newsletter-form { display: flex; flex-direction: column; gap: 8px; }
.newsletter-form input { padding: 10px 14px; border: 1px solid rgba(255,255,255,0.12); border-radius: var(--radius); background: rgba(255,255,255,0.07); color: var(--white); font-family: var(--font); font-size: 13px; outline: none; transition: var(--transition); }
.newsletter-form input::placeholder { color: rgba(255,255,255,0.35); }
.newsletter-form input:focus { border-color: var(--primary); background: rgba(255,255,255,0.1); }
.newsletter-form button { padding: 10px; border-radius: var(--radius); background: var(--primary); color: var(--black); font-family: var(--font); font-size: 13px; font-weight: 700; cursor: pointer; transition: var(--transition); border: none; }
.newsletter-form button:hover { background: var(--primary-dark); }
.footer-bottom { max-width: 1300px; margin: 40px auto 0; padding: 20px 24px; border-top: 1px solid rgba(255,255,255,0.07); display: flex; align-items: center; justify-content: space-between; }
.footer-bottom p { font-size: 12.5px; color: rgba(255,255,255,0.4); }
.payment-icons { display: flex; gap: 12px; font-size: 24px; color: rgba(255,255,255,0.4); }

/* ---- VIEW ALL ---- */
.view-all-wrapper { text-align: center; margin-top: 36px; }
.btn-view-all { display: inline-flex; align-items: center; gap: 8px; padding: 13px 32px; border: 2px solid var(--black); border-radius: var(--radius-pill); font-size: 13.5px; font-weight: 700; color: var(--black); background: transparent; cursor: pointer; transition: var(--transition); font-family: var(--font); }
.btn-view-all:hover { background: var(--black); color: var(--white); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,0.18); }

/* ---- CHAT WIDGET ---- */
.chat-widget { position: fixed; bottom: 24px; right: 24px; width: 54px; height: 54px; background: var(--black); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 22px; cursor: pointer; box-shadow: 0 4px 20px rgba(0,0,0,0.3); transition: var(--transition); z-index: 1000; }
.chat-widget:hover { transform: scale(1.1); box-shadow: 0 8px 30px rgba(0,0,0,0.4); }
.chat-badge { position: absolute; top: 5px; right: 5px; width: 10px; height: 10px; background: #ef4444; border-radius: 50%; border: 2px solid var(--black); animation: pulse 2s infinite; }

/* ---- BLAZOR ERROR ---- */
#blazor-error-ui { background: #b32121; bottom: 0; box-shadow: 0 -1px 2px rgba(0,0,0,.2); color: white; display: none; left: 0; padding: 0.6rem 1.25rem 0.7rem; position: fixed; width: 100%; z-index: 10000; }
#blazor-error-ui .dismiss { cursor: pointer; position: absolute; right: 0.75rem; top: 0.5rem; }

/* ---- HAMBURGER BUTTON ---- */
.nav-right-group { display: flex; align-items: center; gap: 12px; }
.hamburger-btn { display: none; flex-direction: column; justify-content: center; align-items: center; gap: 5px; width: 42px; height: 42px; background: transparent; border: 1.5px solid var(--border); border-radius: var(--radius); cursor: pointer; padding: 8px; transition: var(--transition); }
.hamburger-btn:hover { background: var(--primary-light); border-color: var(--primary); }
.ham-line { display: block; width: 20px; height: 2px; background: var(--black); border-radius: 2px; transition: all 0.35s cubic-bezier(0.4,0,0.2,1); transform-origin: center; }
.ham-line.open:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.ham-line.open:nth-child(2) { opacity: 0; transform: scaleX(0); }
.ham-line.open:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---- MOBILE OVERLAY ---- */
.mobile-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 1099; opacity: 0; visibility: hidden; transition: var(--transition); backdrop-filter: blur(2px); }
.mobile-overlay.visible { opacity: 1; visibility: visible; }

/* ---- MOBILE SIDEBAR DRAWER ---- */
.mobile-sidebar { position: fixed; top: 0; left: 0; width: 300px; height: 100vh; background: var(--white); z-index: 1100; transform: translateX(-100%); transition: transform 0.38s cubic-bezier(0.4,0,0.2,1); display: flex; flex-direction: column; overflow: hidden; box-shadow: 4px 0 30px rgba(0,0,0,0.18); }
.mobile-sidebar.open { transform: translateX(0); }

/* Sidebar Header */
.sidebar-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; background: var(--black); flex-shrink: 0; }
.sidebar-logo { display: flex; align-items: center; gap: 9px; font-size: 15px; font-weight: 800; color: var(--white); }
.sidebar-logo span:first-child { font-size: 22px; }
.sidebar-close { width: 34px; height: 34px; background: rgba(255,255,255,0.1); border: none; border-radius: 50%; color: var(--white); font-size: 14px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: var(--transition); }
.sidebar-close:hover { background: rgba(255,255,255,0.25); transform: rotate(90deg); }

/* Sidebar Search */
.sidebar-search { padding: 14px 16px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.sidebar-search .search-box { border-radius: var(--radius); }
.sidebar-search .search-box input { font-size: 13px; padding: 9px 14px; }
.sidebar-search .search-btn { padding: 9px 14px; font-size: 13px; }

/* Sidebar Nav */
.sidebar-nav { flex: 1; overflow-y: auto; padding: 8px 0; }
.sidebar-nav::-webkit-scrollbar { width: 4px; }
.sidebar-nav::-webkit-scrollbar-track { background: transparent; }
.sidebar-nav::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

.sidebar-link { display: flex; align-items: center; gap: 12px; padding: 13px 20px; font-size: 14px; font-weight: 600; color: var(--dark); transition: var(--transition); border-bottom: 1px solid var(--border); }
.sidebar-link i { width: 18px; color: var(--primary-dark); font-size: 15px; }
.sidebar-link:hover, .sidebar-link.active { background: var(--primary-light); color: var(--black); padding-left: 26px; }
.sidebar-link.active { color: var(--black); font-weight: 700; }

/* Sidebar Accordion */
.sidebar-accordion { border-bottom: 1px solid var(--border); }
.sidebar-acc-header { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 13px 20px; font-size: 14px; font-weight: 600; color: var(--dark); background: transparent; border: none; cursor: pointer; transition: var(--transition); font-family: var(--font); }
.sidebar-acc-header span { display: flex; align-items: center; gap: 12px; }
.sidebar-acc-header span i { width: 18px; color: var(--primary-dark); font-size: 15px; }
.sidebar-acc-header:hover { background: var(--primary-light); color: var(--black); }
.acc-icon { font-size: 11px; color: var(--gray); transition: transform 0.3s ease; }
.acc-open .acc-icon { transform: rotate(180deg); }
.sidebar-acc-body { max-height: 0; overflow: hidden; transition: max-height 0.35s cubic-bezier(0.4,0,0.2,1); background: var(--light-gray); }
.acc-open .sidebar-acc-body { max-height: 400px; }
.sidebar-acc-body a { display: block; padding: 11px 20px 11px 54px; font-size: 13px; color: var(--dark); transition: var(--transition); border-bottom: 1px solid var(--border); }
.sidebar-acc-body a:last-child { border-bottom: none; }
.sidebar-acc-body a:hover { color: var(--black); background: var(--primary-light); padding-left: 60px; }

/* Sidebar Footer */
.sidebar-footer { padding: 16px 18px; border-top: 2px solid var(--border); background: var(--light-gray); flex-shrink: 0; }
.sidebar-feature { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--dark); font-weight: 500; margin-bottom: 8px; }
.sidebar-feature i { color: var(--primary-dark); width: 16px; }
.sidebar-social { display: flex; gap: 10px; margin-top: 14px; }
.sidebar-social a { width: 34px; height: 34px; background: var(--black); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; color: var(--white); transition: var(--transition); }
.sidebar-social a:hover { background: var(--primary); color: var(--black); transform: translateY(-2px); }

/* ---- RESPONSIVE ---- */
@media (max-width: 1100px) {
    .categories-grid, .products-grid { grid-template-columns: repeat(3, 1fr); }
    .footer-container { grid-template-columns: repeat(2, 1fr); }
    .slide-title { font-size: 40px; }
    .hero-slider { height: 380px; }
}
@media (max-width: 900px) {
    .nav-links { display: none; }
    .nav-delivery { display: none; }
    .hamburger-btn { display: flex; }
}
@media (max-width: 768px) {
    .announcement-text { display: none; }
    .header-logo .logo-text small { display: none; }
    .categories-grid { grid-template-columns: repeat(4, 1fr); }
    .products-grid { grid-template-columns: repeat(2, 1fr); }
    .banners-grid { grid-template-columns: 1fr; }
    .care-grid { grid-template-columns: repeat(2, 1fr); }
    .testimonials-grid { grid-template-columns: 1fr; }
    .features-grid { grid-template-columns: repeat(2, 1fr); }
    .slide-title { font-size: 26px; }
    .hero-slider { height: 300px; }
    .slide-content { padding: 0 28px; }
    .slide-emoji { font-size: 120px; }
    .footer-container { grid-template-columns: 1fr 1fr; gap: 28px; }
    .section { padding: 40px 0; }
}
@media (max-width: 600px) {
    .categories-grid { grid-template-columns: repeat(2, 1fr); }
    .products-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-container { grid-template-columns: 1fr; }
    .header-action-btn span { display: none; }
    .header-action-btn { padding: 6px 8px; }
}
@media (max-width: 480px) {
    .header-search { display: none; }
    .header-container { gap: 8px; padding: 10px 16px; }
    .slide-title { font-size: 22px; }
    .hero-slider { height: 260px; }
    .slide-btn { padding: 10px 20px; font-size: 13px; }
    .mobile-sidebar { width: 280px; }
    .section-title { font-size: 24px; }
    .features-grid { grid-template-columns: 1fr 1fr; }
}

/* ==============================================
   AUTH PAGES (LOGIN / REGISTER)
   ============================================== */
.auth-page { min-height: calc(100vh - 180px); display: flex; align-items: stretch; background: var(--light-gray); }
.auth-container { display: flex; width: 100%; max-width: 1100px; margin: 0 auto; min-height: 600px; box-shadow: var(--shadow-lg); border-radius: var(--radius-lg); overflow: hidden; }

/* Left branding panel */
.auth-left { width: 380px; flex-shrink: 0; background: linear-gradient(145deg, #111 0%, #2d2d2d 100%); color: var(--white); padding: 50px 40px; display: flex; flex-direction: column; justify-content: center; gap: 40px; }
.auth-brand { text-align: center; }
.auth-logo { font-size: 56px; display: block; margin-bottom: 14px; animation: float 3s ease-in-out infinite; }
.auth-brand h2 { font-size: 22px; font-weight: 800; color: var(--white); margin-bottom: 6px; }
.auth-brand p { font-size: 13px; color: rgba(255,255,255,0.55); }
.auth-features { display: flex; flex-direction: column; gap: 18px; }
.auth-feature-item { display: flex; align-items: center; gap: 14px; background: rgba(255,255,255,0.06); border-radius: var(--radius); padding: 14px 16px; border: 1px solid rgba(255,255,255,0.08); }
.auth-feat-icon { font-size: 24px; flex-shrink: 0; }
.auth-feature-item strong { display: block; font-size: 13px; font-weight: 700; color: var(--white); margin-bottom: 2px; }
.auth-feature-item span { font-size: 11.5px; color: rgba(255,255,255,0.5); }

/* Right form panel */
.auth-right { flex: 1; background: var(--white); display: flex; align-items: center; justify-content: center; padding: 40px 32px; }
.auth-card { width: 100%; max-width: 460px; }
.auth-card-header { margin-bottom: 28px; }
.auth-card-header h1 { font-size: 26px; font-weight: 800; color: var(--black); margin-bottom: 6px; }
.auth-card-header p { font-size: 14px; color: var(--gray); }

/* Form elements */
.form-group { margin-bottom: 18px; }
.form-label { display: block; font-size: 13px; font-weight: 600; color: var(--dark); margin-bottom: 7px; }
.required { color: #ef4444; margin-left: 2px; }
.input-icon-wrap { position: relative; display: flex; align-items: center; }
.input-icon { position: absolute; left: 14px; color: var(--gray); font-size: 14px; pointer-events: none; z-index: 1; }
.input-icon-right { position: absolute; right: 12px; background: none; border: none; color: var(--gray); font-size: 14px; cursor: pointer; padding: 4px; transition: var(--transition); }
.input-icon-right:hover { color: var(--black); }
.form-input { width: 100%; padding: 11px 40px 11px 40px; border: 1.5px solid var(--border); border-radius: var(--radius); font-family: var(--font); font-size: 13.5px; color: var(--black); background: var(--white); outline: none; transition: var(--transition); }
.form-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(255,215,0,0.18); }
.form-input::placeholder { color: #bbb; }
.form-select { padding-left: 40px; cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M5 7l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; background-size: 16px; }
.form-row-between { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.form-row-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.checkbox-label { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: var(--dark); cursor: pointer; }
.checkbox-label input[type="checkbox"] { margin-top: 2px; accent-color: var(--primary); width: 15px; height: 15px; flex-shrink: 0; }
.link-primary { color: var(--primary-dark); font-weight: 600; transition: var(--transition); }
.link-primary:hover { text-decoration: underline; }

/* Alerts */
.form-alert { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-radius: var(--radius); font-size: 13px; font-weight: 500; margin-bottom: 18px; }
.form-alert-error { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }
.form-alert-success { background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0; }

/* Auth buttons */
.btn-auth { width: 100%; padding: 13px; background: var(--primary); color: var(--black); font-family: var(--font); font-size: 14px; font-weight: 700; border: none; border-radius: var(--radius-pill); cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: var(--transition); margin-bottom: 20px; }
.btn-auth:hover:not(:disabled) { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(255,215,0,0.4); }
.btn-auth:disabled { opacity: 0.65; cursor: not-allowed; }
.btn-spinner { width: 16px; height: 16px; border: 2px solid rgba(0,0,0,0.3); border-top-color: var(--black); border-radius: 50%; animation: spin 0.7s linear infinite; flex-shrink: 0; }

/* Divider */
.auth-divider { text-align: center; margin: 4px 0 16px; position: relative; color: var(--gray); font-size: 12.5px; }
.auth-divider::before, .auth-divider::after { content: ''; position: absolute; top: 50%; width: 38%; height: 1px; background: var(--border); }
.auth-divider::before { left: 0; } .auth-divider::after { right: 0; }

/* OAuth */
.oauth-buttons { display: flex; gap: 10px; margin-bottom: 20px; }
.btn-oauth { flex: 1; padding: 10px; border: 1.5px solid var(--border); border-radius: var(--radius); background: var(--white); font-family: var(--font); font-size: 13px; font-weight: 600; color: var(--dark); cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: var(--transition); }
.btn-oauth:hover { border-color: var(--primary); background: var(--primary-light); }
.btn-oauth .fa-google { color: #ea4335; } .btn-oauth .fa-facebook-f { color: #1877f2; }

.auth-switch { text-align: center; font-size: 13px; color: var(--gray); margin-top: 4px; }

/* Password Strength */
.password-strength { height: 4px; background: var(--border); border-radius: 2px; margin-top: 8px; overflow: hidden; }
.strength-bar { height: 100%; border-radius: 2px; transition: var(--transition); }
.strength-weak { background: #ef4444; width: 30%; }
.strength-medium { background: #f59e0b; width: 60%; }
.strength-good { background: #84cc16; width: 80%; }
.strength-strong { background: #22c55e; width: 100%; }

/* ==============================================
   ACCOUNT LAYOUT (SIDEBAR + CONTENT)
   ============================================== */
.account-layout { display: grid; grid-template-columns: 280px 1fr; gap: 24px; max-width: 1300px; margin: 0 auto; padding: 32px 24px; align-items: start; min-height: 70vh; }

/* Account Sidebar */
.account-sidebar { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; position: sticky; top: 160px; }
.account-profile-box { padding: 24px 20px; background: linear-gradient(135deg, #111, #2d2d2d); display: flex; align-items: center; gap: 14px; }
.account-avatar { width: 52px; height: 52px; border-radius: 50%; background: var(--primary); color: var(--black); font-size: 20px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; border: 2px solid rgba(255,215,0,0.4); }
.account-info { flex: 1; min-width: 0; }
.account-name { font-size: 14px; font-weight: 700; color: var(--white); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.account-email { font-size: 11.5px; color: rgba(255,255,255,0.5); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 6px; }
.account-badge { display: inline-block; background: var(--primary); color: var(--black); font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: var(--radius-pill); }
.account-nav { padding: 8px 0; }
.account-nav-link { display: flex; align-items: center; gap: 12px; padding: 13px 20px; font-size: 13.5px; font-weight: 500; color: var(--dark); transition: var(--transition); border-left: 3px solid transparent; }
.account-nav-link i { width: 18px; color: var(--gray); font-size: 14px; transition: var(--transition); }
.account-nav-link:hover { background: var(--primary-light); color: var(--black); border-left-color: var(--primary); }
.account-nav-link:hover i { color: var(--primary-dark); }
.account-nav-link.active { background: var(--primary-light); color: var(--black); font-weight: 700; border-left-color: var(--primary); }
.account-nav-link.active i { color: var(--primary-dark); }
.account-nav-divider { height: 1px; background: var(--border); margin: 8px 0; }
.account-nav-logout { color: #ef4444 !important; }
.account-nav-logout i { color: #ef4444 !important; }
.account-nav-logout:hover { background: #fef2f2 !important; border-left-color: #ef4444 !important; }

/* Account Content Area */
.account-content { min-width: 0; }
.page-title-bar { margin-bottom: 24px; }
.page-title-bar h2 { font-size: 22px; font-weight: 800; color: var(--black); display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.page-title-bar h2 i { color: var(--primary-dark); }
.page-title-bar p { font-size: 13.5px; color: var(--gray); }

/* Dashboard Cards */
.dash-card { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 22px; margin-bottom: 16px; }
.dash-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.dash-card-header h3 { font-size: 15px; font-weight: 700; color: var(--black); display: flex; align-items: center; gap: 8px; }
.dash-card-header h3 i { color: var(--primary-dark); }

/* Welcome Banner */
.dash-welcome { background: linear-gradient(135deg, #111, #2d2d2d); color: var(--white); border-radius: var(--radius-lg); padding: 24px 28px; display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; gap: 16px; }
.dash-welcome h2 { font-size: 20px; font-weight: 800; color: var(--white); margin-bottom: 4px; }
.dash-welcome p { font-size: 13px; color: rgba(255,255,255,0.6); }
.btn-primary-dash { display: inline-flex; align-items: center; gap: 7px; background: var(--primary); color: var(--black); padding: 11px 20px; border-radius: var(--radius-pill); font-size: 13px; font-weight: 700; white-space: nowrap; transition: var(--transition); }
.btn-primary-dash:hover { background: var(--primary-dark); transform: translateY(-1px); }

/* Stat Cards */
.dash-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 20px; }
.dash-stat-card { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 18px; display: flex; align-items: center; gap: 14px; position: relative; overflow: hidden; transition: var(--transition); }
.dash-stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--stat-color, var(--primary)); }
.stat-icon { width: 48px; height: 48px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.stat-number { font-size: 22px; font-weight: 800; color: var(--black); line-height: 1.1; }
.stat-label { font-size: 12px; color: var(--gray); margin-top: 2px; }
.stat-trend { position: absolute; top: 14px; right: 14px; font-size: 11px; }
.stat-trend.up { color: #22c55e; }
.stat-trend.down { color: #ef4444; }

/* Dashboard Grid */
.dash-grid { display: grid; grid-template-columns: 1fr 340px; gap: 16px; }
.dash-right-col { display: flex; flex-direction: column; gap: 16px; }

/* Orders Table */
.orders-table-wrap { overflow-x: auto; }
.orders-table { width: 100%; border-collapse: collapse; }
.orders-table th { text-align: left; font-size: 11.5px; font-weight: 700; color: var(--gray); text-transform: uppercase; letter-spacing: 0.8px; padding: 0 12px 12px; white-space: nowrap; border-bottom: 2px solid var(--border); }
.orders-table td { padding: 13px 12px; font-size: 13px; color: var(--dark); border-bottom: 1px solid var(--border); }
.orders-table tr:last-child td { border-bottom: none; }
.orders-table tr:hover td { background: var(--light-gray); }
.order-status { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 700; }
.status-delivered { background: #d1fae5; color: #065f46; }
.status-shipped { background: #dbeafe; color: #1e40af; }
.status-processing { background: #fef3c7; color: #92400e; }
.status-cancelled { background: #fee2e2; color: #991b1b; }

/* Coupon Card */
.coupon-item { background: linear-gradient(135deg, var(--primary-light), #fffde7); border: 2px dashed var(--primary); border-radius: var(--radius); padding: 16px; text-align: center; }
.coupon-code { font-size: 22px; font-weight: 900; color: var(--black); letter-spacing: 2px; margin-bottom: 4px; font-family: monospace; }
.coupon-desc { font-size: 13px; color: var(--dark); margin-bottom: 6px; }
.coupon-expiry { font-size: 11.5px; color: var(--gray); display: flex; align-items: center; justify-content: center; gap: 5px; margin-bottom: 12px; }
.btn-copy-coupon { background: var(--black); color: var(--white); padding: 8px 18px; border-radius: var(--radius-pill); font-size: 12.5px; font-weight: 700; border: none; cursor: pointer; transition: var(--transition); font-family: var(--font); }
.btn-copy-coupon:hover { background: var(--dark); }

/* Quick Links */
.quick-links { display: flex; flex-direction: column; gap: 2px; }
.quick-link-item { display: flex; align-items: center; gap: 12px; padding: 11px 4px; border-bottom: 1px solid var(--border); font-size: 13.5px; color: var(--dark); font-weight: 500; transition: var(--transition); }
.quick-link-item:last-child { border-bottom: none; }
.quick-link-item:hover { color: var(--black); padding-left: 4px; }
.ql-icon { width: 34px; height: 34px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.quick-link-item .fa-chevron-right { margin-left: auto; font-size: 11px; color: var(--gray); }

/* ==============================================
   EDIT PROFILE
   ============================================== */
.profile-avatar-section { display: flex; align-items: center; gap: 20px; }
.profile-avatar-lg { width: 80px; height: 80px; border-radius: 50%; background: var(--primary); color: var(--black); font-size: 30px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; border: 3px solid var(--primary-light); }
.btn-upload-avatar { display: inline-flex; align-items: center; gap: 6px; background: var(--light-gray); border: 1.5px solid var(--border); color: var(--dark); padding: 7px 14px; border-radius: var(--radius-pill); font-size: 12.5px; font-weight: 600; cursor: pointer; transition: var(--transition); margin-top: 8px; font-family: var(--font); }
.btn-upload-avatar:hover { border-color: var(--primary); background: var(--primary-light); }
.form-actions { display: flex; align-items: center; gap: 12px; margin-top: 20px; flex-wrap: wrap; }
.btn-auth-sm { display: inline-flex; align-items: center; gap: 7px; padding: 11px 22px; border-radius: var(--radius-pill); font-size: 13px; font-weight: 700; cursor: pointer; transition: var(--transition); font-family: var(--font); border: none; }
.btn-save { background: var(--primary); color: var(--black); }
.btn-save:hover:not(:disabled) { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(255,215,0,0.35); }
.btn-save:disabled { opacity: 0.65; cursor: not-allowed; }
.btn-cancel { background: var(--light-gray); color: var(--dark); border: 1.5px solid var(--border) !important; }
.btn-cancel:hover { background: var(--border); }

/* ==============================================
   CHANGE PASSWORD
   ============================================== */
.pwd-card { max-width: 580px; }
.security-tip { display: flex; gap: 14px; align-items: flex-start; background: #eff6ff; border: 1px solid #bfdbfe; border-radius: var(--radius); padding: 14px 16px; margin-bottom: 24px; }
.security-tip .fa-shield-alt { color: #3b82f6; font-size: 18px; margin-top: 2px; }
.security-tip strong { display: block; font-size: 13px; font-weight: 700; color: #1e40af; margin-bottom: 3px; }
.security-tip p { font-size: 12.5px; color: #3b82f6; margin: 0; line-height: 1.5; }
.pwd-strength-wrapper { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.pwd-strength-bar { flex: 1; height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; }
.pwd-strength-fill { height: 100%; border-radius: 3px; transition: var(--transition); }
.pwd-strength-label { font-size: 11.5px; font-weight: 700; min-width: 42px; }
.strength-weak .pwd-strength-fill, .strength-weak { background: #ef4444; color: #ef4444; }
.strength-medium .pwd-strength-fill, .strength-medium { background: #f59e0b; color: #f59e0b; }
.strength-good .pwd-strength-fill, .strength-good { background: #84cc16; color: #84cc16; }
.strength-strong .pwd-strength-fill, .strength-strong { background: #22c55e; color: #22c55e; }
.pwd-requirements { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 10px; }
.pwd-req { font-size: 12px; color: var(--gray); display: flex; align-items: center; gap: 6px; }
.pwd-req i { font-size: 12px; color: var(--border); }
.pwd-req.req-ok { color: #22c55e; }
.pwd-req.req-ok i { color: #22c55e; }

/* ==============================================
   ORDER HISTORY
   ============================================== */
.orders-filter-bar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 14px; margin-bottom: 20px; }
.filter-tabs { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-tab { padding: 8px 16px; border: 1.5px solid var(--border); border-radius: var(--radius-pill); font-size: 12.5px; font-weight: 600; color: var(--gray); background: var(--white); cursor: pointer; transition: var(--transition); font-family: var(--font); }
.filter-tab:hover { border-color: var(--primary); color: var(--black); }
.filter-tab.active { background: var(--primary); border-color: var(--primary); color: var(--black); }
.order-card { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); margin-bottom: 14px; overflow: hidden; transition: var(--transition); }
.order-card:hover { box-shadow: var(--shadow); border-color: var(--primary); }
.order-card-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; border-bottom: 1px solid var(--border); background: var(--light-gray); }
.order-meta { display: flex; align-items: center; gap: 16px; }
.order-id { font-size: 13.5px; font-weight: 700; color: var(--black); }
.order-date { font-size: 12.5px; color: var(--gray); display: flex; align-items: center; gap: 5px; }
.order-card-body { display: flex; align-items: center; gap: 16px; padding: 18px 20px; flex-wrap: wrap; }
.order-product-img { font-size: 50px; flex-shrink: 0; }
.order-product-info { flex: 1; min-width: 200px; }
.order-product-name { font-size: 14.5px; font-weight: 700; color: var(--black); margin-bottom: 5px; }
.order-product-meta { display: flex; gap: 8px; font-size: 12.5px; color: var(--gray); margin-bottom: 6px; }
.order-address { font-size: 12px; color: var(--gray); display: flex; align-items: center; gap: 5px; }
.order-address i { color: var(--primary-dark); }
.order-amount-col { text-align: right; flex-shrink: 0; }
.order-total { font-size: 18px; font-weight: 800; color: var(--black); }
.order-payment { font-size: 11.5px; color: var(--gray); margin-top: 3px; }
.order-card-actions { display: flex; gap: 8px; flex-wrap: wrap; padding: 12px 20px; border-top: 1px solid var(--border); background: var(--light-gray); }
.btn-order-action { display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px; border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; cursor: pointer; transition: var(--transition); font-family: var(--font); border: 1.5px solid var(--border); background: var(--white); color: var(--dark); }
.btn-order-action:hover { transform: translateY(-1px); }
.btn-track { border-color: #3b82f6; color: #3b82f6; } .btn-track:hover { background: #eff6ff; }
.btn-review { border-color: #f59e0b; color: #d97706; } .btn-review:hover { background: #fffbeb; }
.btn-reorder { border-color: #22c55e; color: #16a34a; } .btn-reorder:hover { background: #f0fdf4; }
.btn-cancel-order { border-color: #ef4444; color: #ef4444; } .btn-cancel-order:hover { background: #fef2f2; }
.btn-invoice { border-color: var(--border); color: var(--gray); } .btn-invoice:hover { border-color: var(--dark); color: var(--dark); }

/* Empty State */
.empty-state { text-align: center; padding: 60px 24px; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); }
.empty-icon { font-size: 60px; margin-bottom: 16px; }
.empty-state h3 { font-size: 18px; font-weight: 700; color: var(--black); margin-bottom: 8px; }
.empty-state p { font-size: 14px; color: var(--gray); }

/* ==============================================
   ACCOUNT RESPONSIVE
   ============================================== */
@media (max-width: 1024px) {
    .account-layout { grid-template-columns: 240px 1fr; gap: 16px; }
    .dash-grid { grid-template-columns: 1fr; }
    .dash-right-col { display: grid; grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
    .account-layout { grid-template-columns: 1fr; padding: 16px; }
    .account-sidebar { position: static; }
    .dash-stats { grid-template-columns: 1fr 1fr; }
    .dash-right-col { grid-template-columns: 1fr; }
    .auth-container { flex-direction: column; border-radius: 0; box-shadow: none; }
    .auth-left { width: 100%; padding: 30px 24px; }
    .auth-features { display: none; }
    .auth-right { padding: 28px 20px; }
    .form-row-2col { grid-template-columns: 1fr; }
    .pwd-requirements { grid-template-columns: 1fr; }
    .order-card-body { flex-direction: column; align-items: flex-start; }
    .order-amount-col { text-align: left; }
}
@media (max-width: 480px) {
    .dash-stats { grid-template-columns: 1fr 1fr; }
    .filter-tabs { gap: 4px; }
    .filter-tab { padding: 7px 12px; font-size: 12px; }
    .dash-welcome { flex-direction: column; align-items: flex-start; }
}

/* ==============================================
   CART PAGE
   ============================================== */
.cart-page { min-height: 60vh; }
.cart-page-header { background: var(--white); border-bottom: 1px solid var(--border); padding: 16px 0; margin-bottom: 4px; }
.cart-page-header .section-container { display: flex; align-items: center; justify-content: space-between; }
.cart-page-title { font-size: 22px; font-weight: 800; color: var(--black); display: flex; align-items: center; gap: 10px; margin: 0; }
.cart-page-title i { color: var(--primary-dark); }
.cart-count-badge { background: var(--primary); color: var(--black); font-size: 12px; font-weight: 700; padding: 3px 10px; border-radius: var(--radius-pill); }
.cart-continue-link { display: flex; align-items: center; gap: 6px; font-size: 13.5px; font-weight: 600; color: var(--gray); transition: var(--transition); }
.cart-continue-link:hover { color: var(--black); gap: 8px; }

/* Empty cart */
.cart-empty { text-align: center; padding: 80px 24px; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); }
.cart-empty-icon { font-size: 72px; margin-bottom: 16px; animation: float 3s ease-in-out infinite; }
.cart-empty h2 { font-size: 22px; font-weight: 800; color: var(--black); margin-bottom: 10px; }
.cart-empty p { font-size: 14.5px; color: var(--gray); line-height: 1.7; }

/* Cart layout */
.cart-layout { display: grid; grid-template-columns: 1fr 380px; gap: 24px; align-items: start; }
.cart-items-col { display: flex; flex-direction: column; gap: 0; }

/* Free delivery bar */
.free-delivery-bar { background: linear-gradient(135deg, #f0fdf4, #dcfce7); border: 1.5px solid #bbf7d0; border-radius: var(--radius-lg); padding: 14px 18px; margin-bottom: 14px; }
.free-delivery-bar p { font-size: 13.5px; color: #166534; margin-bottom: 10px; }
.delivery-progress { height: 6px; background: #bbf7d0; border-radius: 3px; overflow: hidden; }
.delivery-progress-fill { height: 100%; background: linear-gradient(90deg, #22c55e, #16a34a); border-radius: 3px; transition: width 0.5s ease; }

/* Cart item card */
.cart-item { display: flex; gap: 16px; align-items: flex-start; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 16px 18px; margin-bottom: 10px; transition: var(--transition); }
.cart-item:hover { border-color: var(--primary); box-shadow: var(--shadow-sm); }
.cart-item-img { width: 90px; height: 90px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; font-size: 42px; flex-shrink: 0; }
.cart-item-info { flex: 1; min-width: 0; }
.cart-item-name { font-size: 14.5px; font-weight: 700; color: var(--black); margin-bottom: 4px; line-height: 1.4; }
.cart-item-meta { font-size: 12.5px; color: var(--gray); margin-bottom: 10px; }
.cart-item-price-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cart-item-price { font-size: 17px; font-weight: 800; color: var(--black); }
.cart-item-original { font-size: 13px; color: var(--gray); text-decoration: line-through; }
.cart-item-saving { font-size: 12px; font-weight: 700; color: #22c55e; background: #f0fdf4; padding: 2px 8px; border-radius: var(--radius-pill); }
.cart-item-actions { display: flex; flex-direction: column; align-items: flex-end; gap: 12px; flex-shrink: 0; }

/* Quantity control */
.qty-control { display: flex; align-items: center; gap: 0; border: 1.5px solid var(--border); border-radius: var(--radius-pill); overflow: hidden; }
.qty-btn { width: 34px; height: 34px; background: var(--light-gray); border: none; color: var(--dark); font-size: 11px; cursor: pointer; transition: var(--transition); display: flex; align-items: center; justify-content: center; }
.qty-btn:hover:not(:disabled) { background: var(--primary); color: var(--black); }
.qty-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.qty-val { min-width: 36px; text-align: center; font-size: 14px; font-weight: 700; color: var(--black); padding: 0 4px; }

/* Cart item icon buttons */
.cart-item-btns { display: flex; gap: 6px; }
.cart-item-wish, .cart-item-remove { width: 34px; height: 34px; border-radius: 50%; border: 1.5px solid var(--border); background: var(--white); font-size: 13px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--transition); }
.cart-item-wish:hover { border-color: #ef4444; color: #ef4444; background: #fef2f2; }
.cart-item-remove:hover { border-color: #ef4444; color: #ef4444; background: #fef2f2; }
.cart-clear-btn { background: none; border: none; color: var(--gray); font-size: 12.5px; font-family: var(--font); cursor: pointer; display: flex; align-items: center; gap: 5px; padding: 4px 0; transition: var(--transition); }
.cart-clear-btn:hover { color: #ef4444; }

/* Cart Summary */
.cart-summary-col { position: sticky; top: 160px; display: flex; flex-direction: column; gap: 14px; }

/* Coupon box */
.cart-coupon-box { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 18px; }
.cart-coupon-header { font-size: 14px; font-weight: 700; color: var(--black); display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.cart-coupon-header i { color: var(--primary-dark); }
.coupon-input-row { display: flex; gap: 0; border: 1.5px solid var(--border); border-radius: var(--radius-pill); overflow: hidden; transition: var(--transition); }
.coupon-input-row:focus-within { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(255,215,0,0.18); }
.coupon-input { border: none !important; border-radius: 0 !important; box-shadow: none !important; padding: 10px 16px !important; font-size: 13px !important; }
.coupon-input:focus { box-shadow: none !important; }
.btn-apply-coupon { background: var(--black); color: var(--white); padding: 10px 18px; border: none; font-family: var(--font); font-size: 13px; font-weight: 700; cursor: pointer; white-space: nowrap; transition: var(--transition); }
.btn-apply-coupon:hover { background: var(--dark); }
.coupon-error { display: block; font-size: 12px; color: #ef4444; margin-top: 8px; display: flex; align-items: center; gap: 5px; }
.available-coupons { margin-top: 12px; font-size: 12px; color: var(--gray); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.coupon-chip { padding: 4px 12px; border: 1.5px dashed var(--primary-dark); border-radius: var(--radius-pill); background: var(--primary-light); color: var(--dark); font-size: 11.5px; font-weight: 700; cursor: pointer; font-family: var(--font); transition: var(--transition); }
.coupon-chip:hover { background: var(--primary); }
.coupon-applied { display: flex; align-items: center; justify-content: space-between; background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: var(--radius); padding: 10px 14px; font-size: 13px; color: #166534; font-weight: 500; }
.coupon-applied button { background: none; border: none; color: #166534; cursor: pointer; font-size: 13px; padding: 2px 4px; }

/* Price breakdown */
.cart-summary-box { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 20px; }
.summary-title { font-size: 15px; font-weight: 800; color: var(--black); margin-bottom: 16px; text-transform: uppercase; letter-spacing: 0.5px; }
.summary-rows { display: flex; flex-direction: column; gap: 0; border-bottom: 1px dashed var(--border); margin-bottom: 14px; }
.summary-row { display: flex; justify-content: space-between; align-items: center; font-size: 13.5px; color: var(--dark); padding: 9px 0; border-bottom: 1px solid var(--border); }
.summary-row:last-child { border-bottom: none; }
.saving-row span:last-child { color: #22c55e; font-weight: 700; }
.free-tag { color: #22c55e; font-weight: 700; font-size: 13px; }
.summary-total { display: flex; justify-content: space-between; align-items: center; font-size: 17px; font-weight: 800; color: var(--black); padding: 14px 0; border-bottom: 1px solid var(--border); margin-bottom: 12px; }
.summary-savings { background: #f0fdf4; color: #166534; font-size: 12.5px; font-weight: 600; padding: 10px 14px; border-radius: var(--radius); margin-bottom: 14px; text-align: center; }
.btn-checkout { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 14px; background: var(--primary); color: var(--black); font-family: var(--font); font-size: 15px; font-weight: 800; border: none; border-radius: var(--radius-pill); cursor: pointer; transition: var(--transition); margin-bottom: 14px; }
.btn-checkout:hover { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(255,215,0,0.4); }
.secure-badges { display: flex; justify-content: center; gap: 14px; margin-bottom: 12px; flex-wrap: wrap; }
.secure-badges span { font-size: 11.5px; color: var(--gray); display: flex; align-items: center; gap: 4px; }
.secure-badges i { color: var(--primary-dark); }
.accepted-payments { display: flex; justify-content: center; gap: 10px; font-size: 24px; color: var(--gray); }

/* ==============================================
   ADDRESS PAGE
   ============================================== */
.btn-add-address { display: inline-flex; align-items: center; gap: 7px; padding: 11px 22px; background: var(--black); color: var(--white); border: none; border-radius: var(--radius-pill); font-family: var(--font); font-size: 13px; font-weight: 700; cursor: pointer; transition: var(--transition); }
.btn-add-address:hover { background: var(--dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.2); }

.address-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.address-card { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 20px; position: relative; transition: var(--transition); }
.address-card:hover { box-shadow: var(--shadow); border-color: var(--primary); }
.address-default { border-color: var(--primary) !important; box-shadow: 0 0 0 2px rgba(255,215,0,0.25); }
.default-badge { position: absolute; top: 14px; right: 14px; display: inline-flex; align-items: center; gap: 4px; background: var(--primary); color: var(--black); font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: var(--radius-pill); }
.address-type-icon { font-size: 28px; margin-bottom: 6px; }
.address-type-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--gray); margin-bottom: 10px; }
.address-name { font-size: 15px; font-weight: 700; color: var(--black); margin-bottom: 4px; }
.address-phone { font-size: 12.5px; color: var(--gray); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.address-phone i { color: var(--primary-dark); font-size: 11px; }
.address-text { font-size: 13px; color: var(--dark); line-height: 1.7; margin-bottom: 16px; }
.address-card-actions { display: flex; gap: 8px; flex-wrap: wrap; padding-top: 14px; border-top: 1px solid var(--border); }
.addr-btn { display: inline-flex; align-items: center; gap: 5px; padding: 6px 12px; border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; cursor: pointer; transition: var(--transition); font-family: var(--font); border: 1.5px solid var(--border); background: var(--white); }
.addr-btn:hover { transform: translateY(-1px); }
.addr-btn-default { border-color: var(--primary-dark); color: var(--primary-dark); }
.addr-btn-default:hover { background: var(--primary-light); }
.addr-btn-edit { border-color: #3b82f6; color: #3b82f6; }
.addr-btn-edit:hover { background: #eff6ff; }
.addr-btn-delete { border-color: #ef4444; color: #ef4444; }
.addr-btn-delete:hover { background: #fef2f2; }

/* Add card button */
.address-add-card { border: 2px dashed var(--border); background: var(--light-gray); display: flex; flex-direction: column; align-items: center; justify-content: center; cursor: pointer; min-height: 200px; transition: var(--transition); }
.address-add-card:hover { border-color: var(--primary); background: var(--primary-light); }

/* Address Modal */
.addr-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 1099; backdrop-filter: blur(3px); }
.addr-modal { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 92%; max-width: 580px; max-height: 90vh; background: var(--white); border-radius: var(--radius-lg); z-index: 1100; box-shadow: 0 20px 60px rgba(0,0,0,0.2); display: flex; flex-direction: column; overflow: hidden; animation: fadeInUp 0.3s ease; }
.addr-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--border); background: var(--white); flex-shrink: 0; }
.addr-modal-header h3 { font-size: 16px; font-weight: 800; color: var(--black); }
.addr-modal-close { width: 32px; height: 32px; background: var(--light-gray); border: none; border-radius: 50%; color: var(--dark); font-size: 13px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--transition); }
.addr-modal-close:hover { background: #fee2e2; color: #ef4444; transform: rotate(90deg); }
.addr-modal-body { padding: 20px 22px; overflow-y: auto; flex: 1; }
.addr-modal-body::-webkit-scrollbar { width: 4px; }
.addr-modal-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.addr-modal-footer { display: flex; gap: 12px; flex-wrap: wrap; padding: 20px 22px; border-top: 1px solid var(--border); margin-top: 0; background: var(--white); justify-content: flex-end; }

/* Address type selector */
.addr-type-selector { display: flex; gap: 8px; flex-wrap: wrap; }
.addr-type-btn { padding: 8px 16px; border: 1.5px solid var(--border); border-radius: var(--radius-pill); background: var(--white); color: var(--dark); font-family: var(--font); font-size: 13px; font-weight: 600; cursor: pointer; display: flex; align-items: center; gap: 6px; transition: var(--transition); }
.addr-type-btn:hover { border-color: var(--primary); background: var(--primary-light); }
.addr-type-btn.selected { border-color: var(--primary); background: var(--primary); color: var(--black); }

/* ==============================================
   CART + ADDRESS RESPONSIVE
   ============================================== */
@media (max-width: 1024px) {
    .cart-layout { grid-template-columns: 1fr 340px; }
}
@media (max-width: 768px) {
    .cart-layout { grid-template-columns: 1fr; }
    .cart-summary-col { position: static; }
    .address-grid { grid-template-columns: 1fr; }
    .cart-item { flex-wrap: wrap; }
    .cart-item-actions { flex-direction: row; align-items: center; width: 100%; justify-content: space-between; }
}
@media (max-width: 480px) {
    .address-grid { grid-template-columns: 1fr; }
    .cart-page-header .section-container { flex-direction: column; align-items: flex-start; gap: 8px; }
    .addr-modal { width: 96%; }
}

/* ==============================================
   PRODUCT LISTING / COLLECTION PAGE
   ============================================== */

/* --- Collection Banner --- */
.collection-banner { position: relative; padding: 48px 0; overflow: hidden; min-height: 200px; display: flex; align-items: center; }
.collection-banner-content { max-width: 1300px; margin: 0 auto; padding: 0 24px; width: 100%; position: relative; z-index: 2; }
.collection-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: rgba(255,255,255,0.65); margin-bottom: 12px; flex-wrap: wrap; }
.collection-breadcrumb a { color: rgba(255,255,255,0.75); transition: var(--transition); }
.collection-breadcrumb a:hover { color: var(--white); }
.collection-breadcrumb i { font-size: 9px; }
.collection-breadcrumb span { color: var(--white); font-weight: 600; }
.collection-title { font-size: 36px; font-weight: 900; color: var(--white); margin-bottom: 8px; line-height: 1.1; text-shadow: 0 2px 8px rgba(0,0,0,0.2); }
.collection-subtitle { font-size: 15px; color: rgba(255,255,255,0.8); margin-bottom: 16px; max-width: 500px; line-height: 1.6; }
.collection-stats { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.collection-stats span { font-size: 13px; color: rgba(255,255,255,0.75); display: flex; align-items: center; gap: 5px; }
.collection-stats strong { color: var(--white); }
.collection-stats i { color: rgba(255,255,255,0.7); }
.collection-banner-emoji { position: absolute; right: 8%; top: 50%; transform: translateY(-50%); font-size: 160px; opacity: 0.15; animation: float 4s ease-in-out infinite; pointer-events: none; z-index: 1; }

/* --- Main Layout --- */
.collection-page { max-width: 1300px; margin: 0 auto; padding: 24px 24px 48px; }
.mobile-filter-bar { display: none; gap: 10px; align-items: center; margin-bottom: 16px; }
.mobile-filter-btn { display: flex; align-items: center; gap: 8px; padding: 10px 18px; border: 1.5px solid var(--border); border-radius: var(--radius-pill); background: var(--white); font-family: var(--font); font-size: 13.5px; font-weight: 600; color: var(--dark); cursor: pointer; transition: var(--transition); }
.mobile-filter-btn:hover { border-color: var(--primary); background: var(--primary-light); }
.filter-badge { background: var(--primary); color: var(--black); font-size: 10px; font-weight: 800; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.sort-select-mobile { flex: 1; padding: 10px 14px; border: 1.5px solid var(--border); border-radius: var(--radius-pill); font-family: var(--font); font-size: 13px; color: var(--dark); background: var(--white); outline: none; cursor: pointer; }
.mobile-sort-wrap { flex: 1; }

.collection-layout { display: grid; grid-template-columns: 260px 1fr; gap: 24px; align-items: start; }

/* --- Filter Sidebar --- */
.filter-sidebar { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; position: sticky; top: 160px; max-height: calc(100vh - 180px); overflow-y: auto; }
.filter-sidebar::-webkit-scrollbar { width: 4px; }
.filter-sidebar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.filter-sidebar-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; border-bottom: 1px solid var(--border); background: var(--white); position: sticky; top: 0; z-index: 5; flex-wrap: wrap; gap: 8px; }
.filter-sidebar-header h3 { font-size: 14px; font-weight: 800; color: var(--black); display: flex; align-items: center; gap: 8px; margin: 0; }
.filter-sidebar-header h3 i { color: var(--primary-dark); }
.clear-filters-btn { font-size: 12px; font-weight: 700; color: #ef4444; background: #fef2f2; border: 1px solid #fecaca; border-radius: var(--radius-pill); padding: 4px 10px; cursor: pointer; font-family: var(--font); transition: var(--transition); }
.clear-filters-btn:hover { background: #fee2e2; }
.filter-close-btn { display: none; width: 28px; height: 28px; background: var(--light-gray); border: none; border-radius: 50%; color: var(--dark); font-size: 12px; cursor: pointer; align-items: center; justify-content: center; transition: var(--transition); }

.filter-group { border-bottom: 1px solid var(--border); }
.filter-group-header { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 13px 18px; font-size: 13.5px; font-weight: 700; color: var(--black); background: transparent; border: none; cursor: pointer; font-family: var(--font); transition: var(--transition); }
.filter-group-header:hover { background: var(--light-gray); }
.filter-group-header .fa-chevron-down { font-size: 10px; color: var(--gray); transition: transform 0.3s ease; }
.filter-group-header .fa-chevron-down.open { transform: rotate(180deg); }
.filter-options { padding: 4px 18px 14px; display: flex; flex-direction: column; gap: 2px; }
.filter-check { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--dark); cursor: pointer; padding: 6px 4px; border-radius: var(--radius); transition: var(--transition); }
.filter-check:hover { background: var(--primary-light); padding-left: 8px; }
.filter-check input[type="checkbox"], .filter-check input[type="radio"] { accent-color: var(--primary); width: 15px; height: 15px; flex-shrink: 0; cursor: pointer; }
.filter-count { margin-left: auto; font-size: 11px; color: var(--gray); background: var(--light-gray); padding: 2px 7px; border-radius: var(--radius-pill); }
.rating-filter-stars { display: flex; align-items: center; gap: 3px; }
.rating-filter-stars span { font-size: 12.5px; color: var(--gray); margin-left: 4px; }
.star-filled { color: #f59e0b; font-size: 12px; }
.star-empty { color: var(--border); font-size: 12px; }
.clear-rating-btn { margin-top: 6px; font-size: 11.5px; color: var(--gray); background: none; border: 1px solid var(--border); border-radius: var(--radius-pill); padding: 4px 10px; cursor: pointer; font-family: var(--font); transition: var(--transition); }
.clear-rating-btn:hover { color: #ef4444; border-color: #ef4444; }
.filter-tags-wrap { padding: 8px 18px 14px; display: flex; flex-wrap: wrap; gap: 6px; }
.filter-tag-chip { padding: 5px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-pill); background: var(--white); color: var(--dark); font-size: 12px; font-weight: 600; cursor: pointer; font-family: var(--font); transition: var(--transition); }
.filter-tag-chip:hover { border-color: var(--primary); background: var(--primary-light); }
.filter-tag-chip.selected { border-color: var(--primary); background: var(--primary); color: var(--black); }
.filter-apply-mobile { display: none; padding: 16px 18px; }

/* --- Toolbar --- */
.collection-content { min-width: 0; }
.collection-toolbar { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 20px; flex-wrap: wrap; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); padding: 14px 18px; }
.toolbar-left { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.result-count { font-size: 13.5px; color: var(--dark); }
.result-count strong { color: var(--black); font-size: 15px; }
.active-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.active-chip { display: inline-flex; align-items: center; gap: 5px; background: var(--primary-light); border: 1px solid var(--primary); color: var(--dark); font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: var(--radius-pill); }
.active-chip button { background: none; border: none; color: var(--dark); font-size: 11px; cursor: pointer; padding: 0 2px; line-height: 1; }
.active-chip button:hover { color: #ef4444; }
.toolbar-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; flex-wrap: wrap; }
.sort-select { padding: 9px 14px; border: 1.5px solid var(--border); border-radius: var(--radius); font-family: var(--font); font-size: 13px; color: var(--dark); background: var(--white); outline: none; cursor: pointer; transition: var(--transition); }
.sort-select:focus { border-color: var(--primary); }
.view-toggle { display: flex; border: 1.5px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.view-btn { width: 36px; height: 36px; background: var(--white); border: none; color: var(--gray); font-size: 13px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--transition); }
.view-btn:hover { background: var(--light-gray); color: var(--dark); }
.view-btn.active { background: var(--primary); color: var(--black); }

/* --- Product Grid --- */
.prod-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.product-category-tag { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--gray); margin-bottom: 4px; }
.product-weight-tag { font-size: 12px; color: var(--gray); margin-bottom: 6px; }
.product-price-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.product-original-price { font-size: 12px; color: var(--gray); text-decoration: line-through; }
.product-discount { background: #fef2f2; color: #dc2626; font-size: 11px; font-weight: 800; padding: 3px 8px; border-radius: var(--radius-pill); white-space: nowrap; }

/* --- List View --- */
.prod-list { display: flex; flex-direction: column; gap: 14px; }
.prod-list-card { display: grid; grid-template-columns: 140px 1fr 160px; gap: 18px; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; transition: var(--transition); }
.prod-list-card:hover { box-shadow: var(--shadow-lg); border-color: var(--primary); transform: translateY(-2px); }
.prod-list-img { height: 100%; min-height: 160px; display: flex; align-items: center; justify-content: center; font-size: 56px; position: relative; }
.prod-list-info { padding: 18px 0; }
.prod-list-name { font-size: 16px; font-weight: 700; color: var(--black); margin-bottom: 6px; line-height: 1.3; }
.prod-list-meta { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--gray); margin-bottom: 10px; flex-wrap: wrap; }
.prod-list-desc { font-size: 13px; color: var(--dark); line-height: 1.6; margin-bottom: 12px; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.prod-list-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.prod-tag { padding: 3px 10px; background: var(--light-gray); border: 1px solid var(--border); border-radius: var(--radius-pill); font-size: 11px; font-weight: 600; color: var(--gray); }
.prod-list-price-col { padding: 18px; border-left: 1px solid var(--border); display: flex; flex-direction: column; justify-content: center; text-align: center; background: var(--light-gray); }
.prod-list-price { font-size: 22px; font-weight: 900; color: var(--black); }
.prod-list-original { font-size: 13px; color: var(--gray); text-decoration: line-through; margin-top: 3px; }
.prod-list-saving { font-size: 12px; font-weight: 700; color: #22c55e; background: #f0fdf4; padding: 3px 8px; border-radius: var(--radius-pill); margin-top: 5px; display: inline-block; }

/* --- Collection Empty --- */
.collection-empty { text-align: center; padding: 60px 24px; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius-lg); }

/* --- Pagination --- */
.pagination-wrap { display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 36px; flex-wrap: wrap; }
.page-btn { width: 40px; height: 40px; border: 1.5px solid var(--border); border-radius: var(--radius); background: var(--white); color: var(--dark); font-size: 13.5px; font-weight: 600; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--transition); font-family: var(--font); }
.page-btn:hover:not(:disabled) { border-color: var(--primary); background: var(--primary-light); color: var(--black); }
.page-btn.active { background: var(--primary); border-color: var(--primary); color: var(--black); font-weight: 800; }
.page-btn:disabled { opacity: 0.35; cursor: not-allowed; }

/* --- Responsive --- */
@media (max-width: 1100px) {
    .collection-layout { grid-template-columns: 220px 1fr; }
    .prod-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
    .collection-layout { grid-template-columns: 1fr; }
    .filter-sidebar { display: none; position: fixed; top: 0; left: 0; width: 300px; height: 100vh; z-index: 1100; border-radius: 0; max-height: 100vh; box-shadow: 4px 0 30px rgba(0,0,0,0.2); }
    .filter-sidebar.filter-open { display: flex; flex-direction: column; }
    .filter-close-btn { display: flex; }
    .filter-apply-mobile { display: block; }
    .mobile-filter-bar { display: flex; }
}
@media (max-width: 768px) {
    .collection-title { font-size: 26px; }
    .collection-banner { padding: 32px 0; }
    .collection-banner-emoji { font-size: 100px; }
    .prod-grid { grid-template-columns: repeat(2, 1fr); }
    .toolbar-right { width: 100%; }
    .collection-toolbar { flex-direction: column; }
    .prod-list-card { grid-template-columns: 110px 1fr; }
    .prod-list-price-col { display: none; }
}
@media (max-width: 480px) {
    .collection-page { padding: 16px 16px 40px; }
    .collection-title { font-size: 22px; }
    .prod-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .prod-list-card { grid-template-columns: 90px 1fr; }
}

/* ==============================================
   PRODUCT DETAIL PAGE (PDP)
   ============================================== */
.product-detail-page { background: var(--light-gray); padding-bottom: 24px; min-height: 80vh; }
.product-detail-page .section-container { max-width: 1200px; margin: 0 auto; padding: 24px; }

/* Breadcrumb */
.pdp-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--gray); margin-bottom: 24px; flex-wrap: wrap; }
.pdp-breadcrumb a { color: var(--dark); font-weight: 500; transition: var(--transition); }
.pdp-breadcrumb a:hover { color: var(--primary-dark); }
.pdp-breadcrumb i { font-size: 9px; }
.pdp-breadcrumb span { color: var(--black); font-weight: 700; }

/* Grid */
.pdp-grid { display: grid; grid-template-columns: 50% 1fr; gap: 40px; background: var(--white); border-radius: var(--radius-lg); padding: 32px; box-shadow: var(--shadow-sm); border: 1.5px solid var(--border); }

/* Left Gallery */
.pdp-gallery { display: flex; flex-direction: column; gap: 16px; }
.pdp-main-img-wrap { position: relative; border-radius: var(--radius-lg); overflow: hidden; height: 500px; border: 1.5px solid var(--border); background: var(--light-gray); }
.pdp-zoom-btn { position: absolute; bottom: 20px; right: 20px; width: 44px; height: 44px; background: var(--white); border: 1.5px solid var(--border); border-radius: 50%; color: var(--dark); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--transition); z-index: 2; box-shadow: var(--shadow-sm); }
.pdp-zoom-btn:hover { color: var(--black); border-color: var(--black); transform: scale(1.05); }
.pdp-main-img { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 140px; }
.pdp-thumb-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: 12px; }
.pdp-thumb { aspect-ratio: 1; border: 2px solid transparent; border-radius: var(--radius); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 28px; transition: var(--transition); background-color: var(--light-gray); }
.pdp-thumb:hover { border-color: var(--gray); }
.pdp-thumb.active { border-color: var(--black); box-shadow: 0 0 0 2px var(--white) inset; }

/* Right Info */
.pdp-vendor { font-size: 13px; font-weight: 600; color: var(--primary-dark); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.pdp-title { font-size: 30px; font-weight: 900; color: var(--black); margin-bottom: 12px; line-height: 1.2; }

/* Rating Row */
.pdp-rating-row { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; flex-wrap: wrap; }
.pdp-stars { color: var(--border); font-size: 13.5px; }
.pdp-stars .filled { color: #f59e0b; }
.pdp-review-count { font-size: 13.5px; color: var(--dark); text-decoration: underline; font-weight: 500; }
.pdp-orders-badge { background: #fee2e2; color: #dc2626; font-size: 11px; font-weight: 700; padding: 4px 10px; border-radius: var(--radius-pill); display: flex; align-items: center; gap: 4px; }

/* Price Box */
.pdp-price-box { margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px dashed var(--border); }
.pdp-price-main { display: flex; align-items: baseline; gap: 12px; margin-bottom: 4px; }
.pdp-current-price { font-size: 32px; font-weight: 900; color: var(--black); }
.pdp-original-price { font-size: 18px; color: var(--gray); text-decoration: line-through; }
.pdp-discount-badge { background: #f0fdf4; border: 1px solid #bbf7d0; color: #16a34a; font-size: 12px; font-weight: 800; padding: 4px 10px; border-radius: var(--radius-pill); }
.pdp-tax-note { font-size: 12.5px; color: var(--gray); }

/* Highlights */
.pdp-highlights { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 26px; }
.pdp-hl-item { display: flex; align-items: center; gap: 8px; font-size: 13.5px; font-weight: 600; color: var(--dark); }
.pdp-hl-item i { font-size: 15px; width: 18px; text-align: center; }

/* Variants */
.pdp-section { margin-bottom: 24px; }
.pdp-section-title { font-size: 14.5px; font-weight: 600; color: var(--dark); margin-bottom: 12px; }
.pdp-section-title strong { color: var(--black); font-weight: 800; }
.pdp-variant-list { display: flex; gap: 12px; flex-wrap: wrap; }
.pdp-variant-btn { border: 1.5px solid var(--border); background: var(--white); border-radius: var(--radius); padding: 10px 16px; cursor: pointer; transition: var(--transition); text-align: left; display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 100px; font-family: var(--font); }
.pdp-variant-btn:hover { border-color: var(--primary); background: var(--primary-light); }
.pdp-variant-btn.active { border-color: var(--black); background: var(--black); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.v-weight { font-size: 14px; font-weight: 700; color: var(--dark); }
.pdp-variant-btn.active .v-weight { color: var(--white); }
.v-price { font-size: 12.5px; color: var(--gray); font-weight: 500; }
.pdp-variant-btn.active .v-price { color: rgba(255,255,255,0.7); }

/* Actions */
.pdp-action-row { display: flex; gap: 14px; margin-bottom: 14px; height: 54px; }
.pdp-qty-wrap { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: var(--radius-pill); background: var(--white); overflow: hidden; width: 130px; }
.pdp-qty-btn { flex: 1; height: 100%; background: none; border: none; cursor: pointer; color: var(--dark); transition: var(--transition); display: flex; align-items: center; justify-content: center; font-size: 12px; }
.pdp-qty-btn:hover { background: var(--light-gray); color: var(--black); }
.pdp-qty-input { width: 44px; border: none; text-align: center; font-size: 15px; font-weight: 700; font-family: var(--font); color: var(--black); padding: 0; outline: none; -moz-appearance: textfield; appearance: textfield; }
.pdp-qty-input::-webkit-outer-spin-button, .pdp-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; appearance: none; margin: 0; }
.pdp-btn-cart { flex: 2; font-size: 15px; padding: 0; display: flex; align-items: center; justify-content: center; gap: 8px; border-radius: var(--radius-pill); border: none; cursor: pointer; font-family: var(--font); transition: var(--transition); font-weight: 800; }
.pdp-btn-wishlist { width: 54px; height: 54px; border: 1.5px solid var(--border); border-radius: 50%; background: var(--white); color: var(--dark); font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--transition); flex-shrink: 0; }
.pdp-btn-wishlist:hover { border-color: var(--primary); background: var(--primary-light); color: var(--black); }
.pdp-btn-wishlist.active { border-color: #ef4444; background: #fef2f2; color: #ef4444; }
.pdp-btn-buy { width: 100%; height: 54px; font-size: 15px; font-weight: 800; border-radius: var(--radius-pill); background: var(--dark); color: var(--white); border: none; cursor: pointer; font-family: var(--font); transition: var(--transition); margin-bottom: 24px; }
.pdp-btn-buy:hover { background: var(--black); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(0,0,0,0.25); }

/* Pincode Check */
.pdp-delivery-check { background: var(--light-gray); border: 1px dashed var(--border); border-radius: var(--radius); padding: 18px; display: flex; gap: 16px; align-items: flex-start; margin-bottom: 24px; }
.icon-truck { font-size: 24px; color: var(--primary-dark); margin-top: 2px; }
.pdp-delivery-check strong { display: block; font-size: 13.5px; font-weight: 700; color: var(--black); margin-bottom: 10px; }
.pdp-pin-input { display: flex; border: 1.5px solid var(--border); border-radius: var(--radius-pill); overflow: hidden; background: var(--white); }
.pdp-pin-input input { border: none; padding: 10px 16px; outline: none; font-size: 13.5px; flex: 1; font-family: var(--font); color: var(--black); }
.pdp-pin-input button { background: none; border: none; border-left: 1px solid var(--border); padding: 0 16px; color: var(--primary-dark); font-weight: 700; font-family: var(--font); cursor: pointer; font-size: 13px; }
.pdp-pin-input button:hover { background: var(--primary-light); }

/* Trust Badges */
.pdp-trust-badges { display: flex; gap: 12px; margin-bottom: 30px; justify-content: space-between; flex-wrap: wrap; }
.trust-badge { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center; font-size: 11px; font-weight: 600; color: var(--dark); flex: 1; min-width: 60px; padding: 12px 8px; border: 1px solid var(--border); border-radius: var(--radius); background: #fafafa; }
.trust-badge i { font-size: 20px; color: var(--gray); }

/* Accordions */
.pdp-accordions { border-top: 1px solid var(--border); }
.pdp-acc-item { border-bottom: 1px solid var(--border); }
.pdp-acc-header { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 18px 0; background: none; border: none; cursor: pointer; font-family: var(--font); font-size: 15px; font-weight: 700; color: var(--black); transition: var(--transition); }
.pdp-acc-header:hover { color: var(--primary-dark); }
.pdp-acc-header span { display: flex; align-items: center; gap: 10px; }
.pdp-acc-header span i { color: var(--gray); font-size: 14px; width: 16px; text-align: center; }
.pdp-acc-header .fa-plus { font-size: 12px; color: var(--gray); transition: transform 0.3s ease; }
.pdp-acc-item.open .fa-plus { transform: rotate(45deg); color: var(--black); }
.pdp-acc-body { max-height: 0; overflow: hidden; padding: 0; font-size: 13.5px; color: var(--dark); line-height: 1.7; transition: all 0.3s ease; opacity: 0; }
.pdp-acc-item.open .pdp-acc-body { max-height: 500px; padding-bottom: 18px; opacity: 1; }
.pdp-acc-body ul { padding-left: 20px; margin-top: 10px; margin-bottom: 0; }
.pdp-acc-body li { margin-bottom: 6px; }

/* Nutrition table */
.nutrition-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.nutrition-table tr:nth-child(even) { background: var(--light-gray); }
.nutrition-table td { padding: 8px 12px; border: 1px solid var(--border); }
.nutrition-table td:first-child { font-weight: 600; }
.nutrition-table td:last-child { text-align: right; }

/* Sticky bottom CTA */
.pdp-sticky-actions { display: none; position: fixed; bottom: 0; left: 0; width: 100%; background: var(--white); padding: 12px 16px; border-top: 1px solid var(--border); box-shadow: 0 -4px 16px rgba(0,0,0,0.08); z-index: 99; align-items: center; gap: 16px; }
.sticky-price { font-size: 18px; font-weight: 800; color: var(--black); white-space: nowrap; }

/* --- Responsive PDP --- */
@media (max-width: 900px) {
    .pdp-grid { grid-template-columns: 1fr; gap: 32px; padding: 24px; }
    .pdp-main-img-wrap { height: 400px; }
}
@media (max-width: 768px) {
    .pdp-gallery { gap: 12px; }
    .pdp-title { font-size: 24px; }
    .pdp-action-row { display: none; } /* Replaced by sticky CTA */
    .pdp-btn-buy { display: none; } /* Replaced by sticky CTA */
    .pdp-sticky-actions { display: flex; }
    .product-detail-page .section-container { padding: 16px; padding-bottom: 80px; }
    .pdp-grid { padding: 16px; border: none; border-radius: 0; box-shadow: none; background: transparent; }
    .pdp-main-img-wrap { border-radius: 12px; height: 320px; }
    .pdp-highlights { grid-template-columns: 1fr; gap: 10px; }
    .pdp-price-box { margin-bottom: 18px; padding-bottom: 16px; }
    .pdp-section { margin-bottom: 18px; }
    .pdp-trust-badges { gap: 8px; margin-bottom: 24px; }
    .trust-badge { padding: 10px 6px; font-size: 10px; }
}

/* ==============================================
   CHECKOUT PAGE (Shopify Style)
   ============================================== */
.checkout-page { min-height: 100vh; background: var(--white); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; }
.checkout-container { display: flex; flex-direction: row-reverse; max-width: 1200px; margin: 0 auto; min-height: 100vh; }

/* Right Sidebar: Order Summary */
.checkout-sidebar { width: 45%; background: var(--light-gray); border-left: 1px solid var(--border); padding: 40px 4%; position: relative; }
.checkout-sidebar::before { /* Desktop background extension */ content: ''; position: absolute; top: 0; bottom: 0; left: 100%; width: 100vw; background: var(--light-gray); }
.checkout-summary-wrap { position: sticky; top: 40px; }

.checkout-items { display: flex; flex-direction: column; gap: 16px; margin-bottom: 24px; padding-bottom: 24px; border-bottom: 1px solid rgba(0,0,0,0.1); }
.checkout-item { display: flex; align-items: center; gap: 14px; }
.ci-img-wrap { position: relative; width: 64px; height: 64px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.1); background: var(--white); display: flex; align-items: center; justify-content: center; font-size: 32px; flex-shrink: 0; }
.ci-qty { position: absolute; top: -8px; right: -8px; background: rgba(114,114,114,0.9); width: 20px; height: 20px; border-radius: 50%; color: var(--white); font-size: 11px; font-weight: 500; display: flex; align-items: center; justify-content: center; z-index: 2; }
.ci-info { flex: 1; min-width: 0; }
.ci-name { font-size: 14px; font-weight: 600; color: #333; margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ci-meta { font-size: 12px; color: #717171; }
.ci-price { font-size: 14px; font-weight: 500; color: #333; }

.checkout-discount { padding-bottom: 24px; border-bottom: 1px solid rgba(0,0,0,0.1); margin-bottom: 24px; }

.checkout-totals { display: flex; flex-direction: column; gap: 10px; padding-bottom: 24px; border-bottom: 1px solid rgba(0,0,0,0.1); margin-bottom: 24px; }
.checkout-totals .summary-row { font-size: 13.5px; color: #535353; font-weight: 400; padding: 0; border: none; }
.checkout-total-final { display: flex; justify-content: space-between; align-items: center; font-size: 16px; color: #333; }
.final-amt { font-size: 24px; font-weight: 600; display: flex; align-items: baseline; gap: 8px; }
.final-amt span { font-size: 12px; color: #717171; font-weight: 400; }

/* Left Main Content: Forms */
.checkout-main { width: 55%; padding: 40px 4% 40px 0; background: var(--white); display: flex; flex-direction: column; gap: 32px; }
.checkout-main-header h2 { font-size: 28px; font-weight: 400; color: #333; margin-bottom: 16px; font-family: var(--font); }
.checkout-breadcrumbs { display: flex; align-items: center; gap: 8px; font-size: 12px; color: #737373; margin-bottom: 16px; flex-wrap: wrap; }
.checkout-breadcrumbs i { font-size: 8px; }
.checkout-breadcrumbs span { cursor: default; }
.checkout-breadcrumbs .active { color: #333; font-weight: 600; }

.checkout-section-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; flex-wrap: wrap; gap: 8px; }
.checkout-section-header h3 { font-size: 17px; font-weight: 400; color: #333; margin: 0; }
.checkout-section-header a { font-size: 13px; color: var(--primary-dark); transition: color 0.2s; }
.checkout-section-header a:hover { color: #000; text-decoration: underline; }

.form-row-2col { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.form-row-3col { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }

/* Custom Inputs Checkout */
.checkout-main .form-group { margin-bottom: 14px; }
.checkout-main .form-input { width: 100%; padding: 13px; border: 1px solid #d9d9d9; border-radius: 5px; font-family: inherit; font-size: 14px; transition: all 0.2s; outline: none; }
.checkout-main .form-input:focus { border-color: var(--primary-dark); box-shadow: 0 0 0 1px var(--primary-dark); }
.checkout-main .form-select { appearance: none; background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23b0bec5%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E"); background-repeat: no-repeat; background-position: right 14px top 50%; background-size: 10px auto; padding-right: 36px; }

.checkout-footer { display: flex; justify-content: space-between; align-items: center; margin-top: 16px; flex-wrap: wrap-reverse; gap: 16px; }
.checkout-back-link { font-size: 13.5px; color: var(--primary-dark); display: flex; align-items: center; gap: 6px; transition: color 0.2s; }
.checkout-back-link:hover { color: #000; }
.btn-checkout-primary { background: var(--black); color: var(--white); padding: 18px 24px; border-radius: 5px; border: none; font-size: 14px; font-weight: 500; font-family: inherit; cursor: pointer; transition: background 0.2s; min-width: 180px; display: flex; justify-content: center; align-items: center; }
.btn-checkout-primary:hover:not(:disabled) { background: #333; }
.btn-checkout-primary:disabled { opacity: 0.7; cursor: not-allowed; }

.checkout-policy-links { margin-top: auto; padding-top: 48px; display: flex; gap: 16px; border-top: 1px solid transparent; flex-wrap: wrap; }
.checkout-policy-links a { font-size: 12px; color: var(--primary-dark); text-decoration: none; }
.checkout-policy-links a:hover { text-decoration: underline; }

/* Mobile Summary Toggle */
.checkout-mobile-summary-toggle { display: none; width: 100%; justify-content: space-between; align-items: center; padding: 20px 16px; background: #fafafa; border: none; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); cursor: pointer; color: var(--primary-dark); font-size: 14px; text-align: left; }
.toggle-left { display: flex; align-items: center; gap: 8px; }
.toggle-right { font-weight: 600; color: #333; font-size: 18px; }

/* --- Checkout Responsive --- */
@media (max-width: 900px) {
    .checkout-container { flex-direction: column; }
    .checkout-sidebar { width: 100%; border-left: none; padding: 0; background: #fafafa; }
    .checkout-sidebar::before { display: none; }
    
    .checkout-mobile-summary-toggle { display: flex; }
    .checkout-sidebar.show-mobile { display: block; border-bottom: 1px solid var(--border); padding: 24px 16px; }
    .checkout-sidebar:not(.show-mobile) .checkout-summary-wrap { display: none; }
    
    .checkout-main { width: 100%; padding: 32px 16px; }
    .checkout-footer { flex-direction: column-reverse; align-items: stretch; gap: 24px; }
    .checkout-back-link { justify-content: center; padding: 14px; }
    .form-row-2col, .form-row-3col { grid-template-columns: 1fr; }
}

/* ==============================================
   STATIC PAGES (About, Contact, Shop Offline)
   ============================================== */

/* Hero Banners */
.page-hero-banner { position: relative; padding: 60px 0; min-height: 250px; display: flex; align-items: center; overflow: hidden; }
.ph-content { position: relative; z-index: 2; max-width: 600px; margin: 0 auto; color: var(--white); }
.ph-content h1 { font-size: 42px; font-weight: 900; margin-bottom: 12px; text-shadow: 0 2px 10px rgba(0,0,0,0.2); }
.ph-content p { font-size: 16px; line-height: 1.6; opacity: 0.9; }
.ph-emoji { position: absolute; right: 10%; top: 50%; transform: translateY(-50%); font-size: 140px; opacity: 0.15; z-index: 1; pointer-events: none; animation: float 4s ease-in-out infinite; }

/* Utilities */
.py-60 { padding-top: 60px; padding-bottom: 60px; }
.mt-20 { margin-top: 20px; }
.mt-30 { margin-top: 30px; }
.mt-60 { margin-top: 60px; }
.mb-10 { margin-bottom: 10px; }
.mb-15 { margin-bottom: 15px; }
.mb-20 { margin-bottom: 20px; }
.mb-30 { margin-bottom: 30px; }
.bg-light { background: var(--light-gray); }
.bg-white { background: var(--white); }
.w-100 { width: 100%; }
.p-15 { padding: 15px; }
.text-gray { color: var(--gray); }

/* About Us Layout */
.about-story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.ab-story-img { width: 100%; border-radius: var(--radius-lg); overflow: hidden; background: var(--light-gray); aspect-ratio: 4/3; }
.img-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 60px; color: var(--border); background: #f0fdf4; border: 2px dashed #bbf7d0; }
.ab-tag { font-size: 12px; font-weight: 700; color: var(--primary-dark); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 10px; display: block; }
.ab-story-text h2 { font-size: 32px; font-weight: 800; color: var(--black); margin-bottom: 20px; line-height: 1.2; }
.ab-story-text p { font-size: 15px; color: var(--dark); line-height: 1.8; margin-bottom: 16px; }

/* About Stats */
.ab-stats { display: flex; gap: 40px; }
.ab-stat-item h3 { font-size: 36px; font-weight: 900; color: var(--primary-dark); margin-bottom: 4px; line-height: 1; }
.ab-stat-item span { font-size: 13px; font-weight: 600; color: var(--gray); text-transform: uppercase; letter-spacing: 0.5px; }

/* About Features */
.ab-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.ab-feature-card { background: var(--white); padding: 40px 30px; border-radius: var(--radius-lg); border: 1.5px solid var(--border); transition: var(--transition); box-shadow: var(--shadow-sm); }
.ab-feature-card:hover { border-color: var(--primary); transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.ab-icon { width: 64px; height: 64px; background: var(--primary-light); color: var(--primary-dark); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 24px; margin: 0 auto 20px; }
.ab-feature-card h4 { font-size: 18px; font-weight: 800; color: var(--black); margin-bottom: 12px; }
.ab-feature-card p { font-size: 14px; color: var(--gray); line-height: 1.6; }

/* Contact Us Layout */
.contact-grid { display: grid; grid-template-columns: 1fr 380px; gap: 40px; align-items: start; }
.contact-form-card { background: var(--white); border-radius: var(--radius-lg); padding: 40px; border: 1.5px solid var(--border); }
.contact-form-card h3 { font-size: 24px; font-weight: 800; color: var(--black); }
.alert-success { background: #f0fdf4; border: 1px solid #bbf7d0; color: #16a34a; padding: 14px 18px; border-radius: var(--radius); font-size: 14px; font-weight: 500; display: flex; align-items: center; gap: 8px; margin-bottom: 24px; }
.form-label { display: block; font-size: 13px; font-weight: 600; color: var(--dark); margin-bottom: 8px; }

.contact-info-wrap { display: flex; flex-direction: column; gap: 24px; }
.c-info-box { display: flex; gap: 16px; background: var(--white); padding: 24px; border-radius: var(--radius-lg); border: 1.5px solid var(--border); box-shadow: var(--shadow-sm); }
.ci-icon { width: 44px; height: 44px; background: var(--primary-light); color: var(--primary-dark); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.c-info-box h4 { font-size: 16px; font-weight: 700; color: var(--black); margin-bottom: 8px; }
.c-info-box p { font-size: 14px; color: var(--gray); line-height: 1.6; margin: 0; }
.c-info-box a { color: var(--primary-dark); text-decoration: none; font-weight: 500; }
.c-info-box a:hover { text-decoration: underline; }

.c-socials h4 { font-size: 18px; font-weight: 800; color: var(--black); }
.social-links-row { display: flex; gap: 12px; }
.social-links-row a { width: 44px; height: 44px; background: var(--white); border: 1.5px solid var(--border); border-radius: 50%; color: var(--dark); display: flex; align-items: center; justify-content: center; font-size: 18px; transition: var(--transition); }
.social-links-row a:hover { background: var(--primary); border-color: var(--primary); color: var(--black); transform: translateY(-3px); }

/* Shop Offline Layout */
.store-grid { display: grid; grid-template-columns: 420px 1fr; gap: 40px; align-items: stretch; }
.store-details-card { background: var(--white); border-radius: var(--radius-lg); padding: 40px; border: 1.5px solid var(--border); }
.sd-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; flex-wrap: wrap; }
.sd-header h2 { font-size: 26px; font-weight: 800; color: var(--black); line-height: 1.2; flex: 1; }
.badge-open { background: #f0fdf4; color: #16a34a; font-size: 12px; font-weight: 700; padding: 6px 14px; border-radius: var(--radius-pill); border: 1px solid #bbf7d0; white-space: nowrap; }

.sd-info-row { display: flex; gap: 16px; margin-bottom: 24px; align-items: flex-start; }
.sd-info-row i { font-size: 22px; color: var(--primary-dark); width: 24px; text-align: center; margin-top: 2px; }
.sd-info-row strong { display: block; font-size: 15px; font-weight: 700; color: var(--black); margin-bottom: 6px; }
.sd-info-row p { font-size: 14.5px; color: var(--gray); line-height: 1.6; margin: 0; }

.store-map-box { border-radius: var(--radius-lg); overflow: hidden; border: 1.5px solid var(--border); min-height: 400px; background: #e5e7eb; position: relative; }
.store-map-box iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }

/* Responsive Adjustments */
@media (max-width: 900px) {
    .about-story-grid { grid-template-columns: 1fr; gap: 40px; }
    .ab-features-grid { grid-template-columns: 1fr; }
    .contact-grid { grid-template-columns: 1fr; }
    .store-grid { grid-template-columns: 1fr; }
    .store-map-box { min-height: 300px; }
}

@media (max-width: 768px) {
    .ph-content h1 { font-size: 32px; }
    .py-60 { padding-top: 40px; padding-bottom: 40px; }
    .contact-form-card { padding: 24px; }
    .store-details-card { padding: 24px; }
}