/* ═══════════════════════════════════════════════════════
   LUXE — Mobile Fixes & Overrides
   Target: screens ≤ 767px (phones)
   ═══════════════════════════════════════════════════════ */

/* ── 1. ANNOUNCEMENT BAR: don't cut text on small screens ── */
@media (max-width: 767px) {
  .ann-bar { height: 36px; }
  .ann-track span { font-size: 11px; padding: 0 20px; }
}

/* ── 2. NAV: fix crowding of icons ──────────────────────── */
@media (max-width: 767px) {
  .nav { height: 60px; }
  :root { --nav-h: 60px; }
  .nav-logo { font-size: 22px; letter-spacing: 0.14em; }
  .nav-btn { width: 36px; height: 36px; font-size: 16px; }
  .nav-actions { gap: 2px; }
  .lang-btn { display: none; } /* hide on very small, show in mobile menu */
}

/* ── 3. HERO: fix text too small / buttons stack badly ──── */
@media (max-width: 767px) {
  .hero {
    height: 100svh;
    min-height: 500px;
    max-height: 700px;
  }
  .hero-content {
    padding: 0 0 48px;
  }
  .hero-kicker {
    font-size: 10px;
    letter-spacing: 0.18em;
    margin-bottom: 12px;
  }
  .hero-title {
    font-size: clamp(30px, 8vw, 44px);
    max-width: 100%;
    margin-bottom: 16px;
  }
  .hero-sub {
    font-size: 13px;
    margin-bottom: 24px;
    max-width: 100%;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .hero-btns {
    gap: 10px;
  }
  .hero-btns .btn {
    padding: 12px 20px;
    font-size: 11px;
    flex: 1;
    justify-content: center;
    min-width: 0;
  }
  .hero-btns .btn-outline { display: none; } /* show only CTA on mobile */
  .hero-dots { bottom: 16px; right: 20px; }
  .rtl .hero-dots { right: auto; left: 20px; }
}

/* ── 4. USP BAR: 2-col on mobile (already), improve spacing ─ */
@media (max-width: 767px) {
  .usp-bar { padding: 24px 0; }
  .usp-grid { gap: 16px; }
  .usp-icon { font-size: 22px; margin-bottom: 6px; }
  .usp-title { font-size: 12px; }
  .usp-text { font-size: 11px; }
}

/* ── 5. SECTION HEADERS: better mobile spacing ───────────── */
@media (max-width: 767px) {
  .sec { padding: 48px 0; }
  .sec-lg { padding: 64px 0; }
  .sec-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 28px;
  }
  .sec-title { font-size: clamp(22px, 6vw, 32px); }
  .sec-kicker { font-size: 10px; }
}

/* ── 6. PRODUCT GRID: 2-col readable cards on mobile ──────── */
@media (max-width: 767px) {
  .products-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .pc-info { padding: 10px; }
  .pc-name { font-size: 12px; }
  .pc-brand { font-size: 9px; }
  .pc-price .current { font-size: 13px; }
  .pc-price .original { font-size: 11px; }
  .pc-add { display: none; } /* use product page on mobile, card too small */
  .pc-badges { top: 8px; left: 8px; }
  .badge { font-size: 9px; padding: 2px 7px; }
  .rtl .pc-badges { left: auto; right: 8px; }
}

/* ── 7. CATEGORY GRID: 2-col on mobile ───────────────────── */
@media (max-width: 767px) {
  .cat-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .cat-card { aspect-ratio: 3/4; border-radius: 8px; }
  .cat-card-body { padding: 12px; }
  .cat-card-name { font-size: clamp(14px, 4vw, 18px); }
}

/* ── 8. EDITORIAL BANNER: fix on mobile (padding too big) ─── */
@media (max-width: 767px) {
  .banner-editorial {
    padding: 32px 24px;
    text-align: center;
  }
  .banner-editorial .banner-kicker { justify-content: center; }
  .banner-title { font-size: clamp(22px, 6vw, 32px); max-width: 100%; }
  .banner-text { font-size: 13px; max-width: 100%; margin-bottom: 24px; }
  .banner-img { display: none; } /* hide bg image on mobile */
  .banner-editorial::before { display: none; }
}

/* ── 9. TESTIMONIALS: single col on mobile ───────────────── */
@media (max-width: 639px) {
  .testi-grid { grid-template-columns: 1fr; gap: 12px; }
  .testi-card { padding: 20px; }
  .testi-text { font-size: 13px; }
}

/* ── 10. BRANDS STRIP: smaller on mobile ─────────────────── */
@media (max-width: 767px) {
  .brands-strip { padding: 24px 0; }
  .brand-item { font-size: 14px; letter-spacing: 0.15em; }
  .brands-track { gap: 32px; }
}

/* ── 11. CART DRAWER: full width on mobile ───────────────── */
@media (max-width: 480px) {
  .cart-drawer {
    width: 100vw;
    right: -100vw;
  }
  .cart-drawer.open { right: 0; }
  .rtl .cart-drawer { left: -100vw; }
  .rtl .cart-drawer.open { left: 0; }
  .cart-drawer-head { padding: 16px 18px; }
  .cart-drawer-title { font-size: 17px; }
  .cart-items { padding: 12px; }
  .cart-item-img { width: 64px; height: 76px; }
  .cart-footer { padding: 16px 18px; }
}

/* ── 12. SHOP PAGE: fix layout ───────────────────────────── */
@media (max-width: 767px) {
  .shop-hero { padding: 28px 0 20px; }
  .shop-hero h1 { font-size: clamp(22px, 6vw, 32px); }
  .shop-toolbar { flex-wrap: wrap; gap: 10px; }
  .shop-count { order: 3; width: 100%; }
  .shop-sort select { font-size: 12px; padding: 8px 10px; }
}

/* ── 13. PRODUCT DETAIL: fix image & info on mobile ──────── */
@media (max-width: 767px) {
  .product-layout { gap: 24px; padding: 24px 0 60px; }
  .product-title { font-size: clamp(22px, 6vw, 32px); }
  .product-price { margin-bottom: 16px; }
  .price-current { font-size: 26px; }
  .gallery-main { aspect-ratio: 3/4; border-radius: 8px; }
  .gallery-thumb { width: 56px; height: 68px; }
  .add-btns { flex-direction: row; }
  .size-btn { min-width: 40px; height: 40px; }
  .product-desc { font-size: 14px; }
  .tab-btn { padding: 10px 14px; font-size: 11px; }
}

/* ── 14. CHECKOUT / CART PAGE ────────────────────────────── */
@media (max-width: 767px) {
  .cart-page { padding: 24px 0 60px; }
  .cart-product-img { width: 56px; height: 68px; }
  .cart-product-name { font-size: 13px; }
  .cart-summary { padding: 20px; }
  .checkout-page { padding: 24px 0 60px; }
  .form-section { padding: 20px; }
  .checkout-steps { gap: 0; overflow-x: auto; }
  .step-label { font-size: 11px; }
  .step-line { width: 20px; }
}

/* ── 15. AUTH PAGES ──────────────────────────────────────── */
@media (max-width: 480px) {
  .auth-card { padding: 28px 20px; }
  .auth-title { font-size: 20px; }
}

/* ── 16. FOOTER ──────────────────────────────────────────── */
@media (max-width: 639px) {
  .footer { padding-top: 40px; }
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .footer-tagline { max-width: 100%; }
  .footer-newsletter { padding: 24px 0; }
  .newsletter-form {
    flex-direction: column;
    gap: 10px;
  }
  .newsletter-form input { width: 100%; }
  .newsletter-form .btn { width: 100%; }
  .footer-bottom {
    flex-direction: column;
    gap: 14px;
    text-align: center;
  }
  .footer-payments { justify-content: center; }
}

/* ── 17. PROFILE & ORDERS ────────────────────────────────── */
@media (max-width: 767px) {
  .profile-layout { gap: 20px; padding: 24px 0 60px; }
  .profile-sidebar { position: static; }
  .order-card-head { flex-direction: column; gap: 8px; }
}

/* ── 18. PAGINATION ──────────────────────────────────────── */
@media (max-width: 480px) {
  .page-btn { min-width: 34px; height: 34px; font-size: 13px; }
}

/* ── 19. ADMIN ───────────────────────────────────────────── */
@media (max-width: 900px) {
  .admin-body { padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .stat-value { font-size: 22px; }
  .admin-topbar { padding: 0 16px; }
}
@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
}

/* ── 20. GLOBAL TOUCH TARGETS ────────────────────────────── */
@media (max-width: 767px) {
  /* ensure tap targets ≥ 44px */
  .btn { min-height: 44px; }
  .nav-btn { min-width: 40px; min-height: 40px; }
  .size-btn { min-height: 44px; }
  .filter-option { min-height: 36px; }
  
  /* container padding tighter on mobile */
  .container { padding: 0 16px; }
  
  /* back top & whatsapp: don't overlap each other */
  .wa-float { bottom: 16px; right: 16px; width: 46px; height: 46px; font-size: 20px; }
  .back-top { bottom: 74px; right: 16px; }
  .rtl .wa-float { right: auto; left: 16px; }
  .rtl .back-top { right: auto; left: 16px; }
}

/* ── 21. SEARCH OVERLAY ──────────────────────────────────── */
@media (max-width: 767px) {
  .search-overlay { padding-top: 70px; }
  .search-box { padding: 0 16px; }
  .search-box input { font-size: clamp(20px, 6vw, 30px); }
}

/* ── 22. TOAST position on mobile ────────────────────────── */
@media (max-width: 767px) {
  .toast-container {
    bottom: auto;
    top: 70px;
    left: 16px;
    right: 16px;
    transform: none;
    width: auto;
  }
}

/* ── 23. USP GRID 2x2 tighter ───────────────────────────── */
@media (max-width: 380px) {
  .usp-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .usp-item { padding: 0 4px; }
}

/* ── 24. No hover effects on touch (performance) ────────── */
@media (hover: none) {
  .pc:hover { transform: none; box-shadow: none; border-color: transparent; }
  .pc:hover .pc-add { bottom: -44px; }
  .pc:hover .pc-actions { opacity: 0; }
  .pc:hover .pc-img { opacity: 1; }
  .pc:hover .pc-img-alt { opacity: 0; }
  .cat-card:hover img { transform: none; }
  /* Re-enable add button as static on mobile */
  .pc-add {
    display: block;
    bottom: 0;
    position: static;
    padding: 0 10px 10px;
  }
  .pc-act-btn:hover { background: rgba(26,26,26,0.9); color: var(--text); }
}
