/**
 * OEM ASTRA J — UI enhancements
 * Phases 1–6: responsive polish, product cards, search, PDP, cart, animations.
 * Desktop base styles remain in index.html; this file adds production refinements.
 */

/* ── Keyboard focus: subtle gold rings (no browser blue box) ── */
.nav-search,
.mob-search,
.mob-sticky-search,
.catalog-drawer-search,
.catalog-branch-search {
  outline: none;
}

.nav-search input:focus,
.mob-search input:focus,
.mob-sticky-search input:focus,
.catalog-drawer-search input:focus,
.catalog-branch-search input:focus,
.nav-search-filter select:focus,
.mob-search-filter select:focus,
.mob-sticky-search-filter select:focus {
  outline: none;
}

.nav-search input:focus-visible,
.mob-search input:focus-visible,
.mob-sticky-search input:focus-visible,
.catalog-drawer-search input:focus-visible,
.catalog-branch-search input:focus-visible,
.nav-search-filter select:focus-visible,
.mob-search-filter select:focus-visible,
.mob-sticky-search-filter select:focus-visible {
  outline: 2px solid rgba(212, 175, 55, 0.45);
  outline-offset: -2px;
  box-shadow: none;
}

.mob-search:focus-within,
.mob-sticky-search:focus-within {
  border-color: rgba(255, 255, 255, 0.28);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.05);
}

.catalog-drawer-search:focus-within,
.catalog-branch-search:focus-within {
  border-color: #c5c9d0;
  box-shadow: none;
}

.catalog-drawer-search-btn:focus,
.nav-search-btn:focus {
  outline: none;
}

.catalog-drawer-search-btn:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.45);
}

body.catalog-branch-mode .product-card .btn-cart:focus-visible,
body.catalog-branch-mode .product-card .btn-wa-prod:focus-visible,
body.catalog-branch-mode .product-card .btn-view-detail:focus-visible,
body.catalog-branch-mode .product-card .order-qty-btn:focus-visible,
body.catalog-page-open .product-card .btn-cart:focus-visible,
body.catalog-page-open .product-card .btn-wa-prod:focus-visible,
body.catalog-page-open .product-card .btn-view-detail:focus-visible,
body.catalog-page-open .product-card .order-qty-btn:focus-visible {
  outline: 2px solid rgba(212, 175, 55, 0.65);
  outline-offset: 2px;
}

.mob-search-wrap{width:100%;margin-bottom:20px}
.mob-search-filter{display:block;margin-bottom:10px}
.mob-search-filter select{
  width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;
  color:#fff;font-size:13px;font-family:var(--font-ar);padding:10px 12px;
}
.mob-search-wrap .search-dropdown{z-index:2201}
.mob-sticky-search-wrap .search-dropdown{z-index:1106}
.search-drop-hint{font-size:10px;color:var(--gray);font-weight:600;margin-top:2px}
.search-drop-hint em{color:var(--gold-light);font-style:normal;font-weight:800}
.maint-item-link{
  display:inline-block;margin-top:6px;background:transparent;border:none;padding:0;
  font-size:11px;font-weight:700;color:var(--gold-light);cursor:pointer;font-family:var(--font-ar);
  text-decoration:underline;text-underline-offset:2px;
}
.maint-item-link:hover{color:#fff}
@media(max-width:900px){
  .mob-sticky-search .mob-search input{font-size:16px}
}
.search-hl{
  background:rgba(212,175,55,.28);
  color:#fff;
  border-radius:3px;
  padding:0 2px;
  font-weight:800;
}
.live-search-bar .search-query-term{color:var(--gold-light);font-weight:700}

/* ── Catalog pagination (Phase 5) ── */
.catalog-pagination{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-top:28px;padding-top:8px;flex-wrap:wrap;
  direction:ltr;
}
.catalog-pagination-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  min-width:44px;height:44px;padding:0 16px;
  background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);
  color:#fff;font-size:13px;font-weight:700;font-family:var(--font-ar);
  transition:background var(--transition),border-color var(--transition);
}
.catalog-pagination-btn:hover:not(:disabled){
  border-color:var(--gold);background:var(--bg4);color:#fff;
}
.catalog-pagination-btn:disabled{opacity:.35;cursor:default}
.catalog-pagination-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.5}
.catalog-pagination-info{
  font-size:13px;font-weight:700;color:var(--gray);min-width:120px;text-align:center;
}
.catalog-pagination-info em{color:var(--gold-light);font-style:normal;font-weight:800}
@media(max-width:768px){
  .catalog-pagination{gap:8px;margin-top:20px}
  .catalog-pagination-btn{min-width:40px;height:40px;padding:0 12px;font-size:12px}
  .catalog-pagination-info{font-size:12px;min-width:96px}
}

@media(max-width:768px){
  .no-results{padding:40px 16px}
  .no-results-actions{flex-direction:column;align-items:stretch}
  .no-results-actions .btn-all-gold{width:100%}
  .catalog-group-row{padding:11px 14px}
  .catalog-group-thumb{width:42px;height:42px}
}

/* ── Product cards — premium automotive (desktop+) ── */
@media(min-width:1025px){
  .product-img-wrap{height:185px}
  body.catalog-branch-mode .product-img-wrap,
  body.catalog-page-open .product-img-wrap{height:178px}
  body.catalog-branch-mode .catalog-view-list .product-img-wrap,
  body.catalog-page-open .catalog-view-list .product-img-wrap{height:auto;min-height:0}
  body:not(.catalog-page-open):not(.catalog-branch-mode) .product-img-wrap img{
    padding:20px;transition:transform .35s ease;
  }
  .product-card:hover .product-img-wrap img{transform:scale(1.06)}
}
.product-card{
  animation:cardFadeIn .45s ease both;
}
@keyframes cardFadeIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
.product-card:hover{
  box-shadow:0 16px 48px rgba(0,0,0,.45),0 0 0 1px rgba(212,175,55,.12);
}
.product-card .product-img-wrap{
  background:linear-gradient(160deg,var(--bg4) 0%,#1e1e22 100%);
}
.product-warranty{
  background:rgba(10,25,70,.35);
  border:1px solid rgba(10,25,70,.5);
  border-radius:6px;
  padding:4px 8px;
  font-size:11px;
}
.product-brand-fallback{
  width:72%;height:72%;object-fit:contain;opacity:.92;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.35));
}

/* ── Mobile hamburger + drawer ── */
.mob-menu-btn{position:relative;transition:background .2s,border-color .2s}
.mob-menu-btn.is-open{background:var(--red);border-color:var(--red)}
.mob-menu-btn.is-open svg line:nth-child(1){transform:translateY(6px) rotate(45deg)}
.mob-menu-btn.is-open svg line:nth-child(2){opacity:0}
.mob-menu-btn.is-open svg line:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.mob-menu-btn svg line{transform-origin:center;transition:transform .25s ease,opacity .2s}
.mob-drawer-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);
  z-index:997;opacity:0;transition:opacity .28s ease;
  backdrop-filter:blur(2px);
}
.mob-drawer-overlay.open{display:block;opacity:1}
.mob-drawer{
  z-index:998;
  opacity:0;
  visibility:hidden;
  transition:opacity .28s ease,visibility .28s ease;
}
.mob-drawer.open{
  display:block;
  opacity:1;
  visibility:visible;
}
.mob-drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);
}
.mob-drawer-head span{font-size:15px;font-weight:800;color:#fff}
.mob-drawer-close{
  background:var(--bg4);border:1px solid var(--border2);width:36px;height:36px;
  border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;
}
.mob-drawer-close svg{width:16px;height:16px;stroke:var(--gray);fill:none;stroke-width:2.5}
.mob-nav-links li a{
  min-height:48px;display:flex;align-items:center;
  border:1px solid transparent;
}
.mob-nav-links li a:active{background:var(--bg4);border-color:var(--border2)}

/* ── Hero: dual-layer — blurred cover bg + contain fg (full image visible) ── */
.hero-slide{
  position:absolute;inset:0;
  opacity:0;transition:opacity .8s ease;
  pointer-events:none;
  overflow:hidden;
}
.hero-slide.active{opacity:1;}
.hero-slide-bg,
.hero-slide-fg{
  position:absolute;inset:0;width:100%;height:100%;
  display:block;
}
.hero-slide-bg{
  object-fit:cover;object-position:center center;
  transform:scale(1.14);
  filter:blur(14px) brightness(0.48) saturate(1.25);
  z-index:0;
}
.hero-slide-fg{
  object-fit:contain;object-position:center center;
  z-index:1;
}

/* ── Top selling strip + brands banner (mobile marquee) ── */
.top-parts-desktop{display:block}
.top-parts-mobile{display:none}
.brands-slider-wrap--desktop{display:flex}
.brands-banner--mobile{display:none}
@media(max-width:767px){
  .top-parts-desktop{display:none!important}
  .top-parts-mobile{display:block}
  .brands-slider-wrap--desktop{display:none!important}
  .brands-banner--mobile{display:block}
}
.top-parts-viewport{overflow:hidden;touch-action:pan-y pinch-zoom;cursor:grab}
.top-parts-viewport.is-dragging{cursor:grabbing}
#topParts.top-selling-section .section-head{
  scroll-margin-top:calc(var(--nav-total-h) + var(--nav-logo-over) - var(--nav-clearance-trim) + 8px);
}
.top-selling-track{display:flex;gap:14px;align-items:stretch;padding:0 14px}
.top-selling-card{
  flex:0 0 188px;width:188px;
  background:#2a2a2a;border:none;border-radius:12px;
  overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;
  transition:box-shadow .2s ease,transform .2s ease;
  -webkit-tap-highlight-color:transparent;
  box-shadow:0 4px 18px rgba(0,0,0,.32);
}
.top-selling-card:hover{
  box-shadow:0 10px 32px rgba(0,0,0,.45);
  transform:translateY(-2px);
}
.top-selling-img-wrap{
  position:relative;flex-shrink:0;
  background:#000;
  height:130px;min-height:130px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.top-selling-img-wrap img{width:100%;height:100%;object-fit:contain;padding:14px}
.top-selling-img-wrap .product-brand-fallback{
  width:72%;height:72%;object-fit:contain;opacity:.92;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.35));
}
.top-selling-footer{
  padding:10px 12px 12px;display:flex;flex-direction:column;gap:6px;flex:1;min-width:0;
}
.top-selling-title-row{
  display:flex;align-items:flex-start;gap:8px;min-width:0;direction:ltr;
}
.top-selling-name{
  flex:1;min-width:0;
  font-size:10px;font-weight:800;color:#fff;line-height:1.35;
  text-transform:uppercase;letter-spacing:.04em;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
}
.top-selling-brand{
  flex-shrink:0;
  font-size:10px;font-weight:800;color:rgba(255,255,255,.72);
  text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;
}
.top-selling-footer-row{
  display:flex;align-items:flex-end;justify-content:space-between;gap:8px;margin-top:auto;
}
.top-selling-price-row{
  width:100%;min-width:0;margin-top:2px;
}
.top-selling-actions-row{
  display:flex;justify-content:flex-end;margin-top:6px;
}
.top-selling-price-block.product-price-block,
.top-selling-price-row .product-price-block{
  display:inline-flex;flex-direction:row;align-items:center;flex-wrap:nowrap;
  gap:5px 6px;justify-content:flex-start;width:100%;max-width:100%;
}
.top-selling-price-block .product-price-sale{
  font-size:22px;font-weight:400;color:var(--price-final,#93c5fd);font-family:var(--font-en);
  line-height:1;white-space:nowrap;letter-spacing:-.01em;
}
.top-selling-price-block .product-price-sale span{font-size:11px;font-weight:400;color:#555E6B}
.top-selling-price-block .product-price-compare{
  font-size:13px;font-weight:500;color:#fff;font-family:var(--font-en);white-space:nowrap;line-height:1.2;text-decoration:none;
}
.top-selling-price-block .product-price-compare-amt{text-decoration:line-through}
.top-selling-price-block .product-price-compare span{font-size:10px;font-weight:500;color:#fff}
.top-selling-price-block .product-price-badge{
  font-size:15px;font-weight:800;color:#D71920;background:none;white-space:nowrap;
}
.top-selling-price-block .product-price--single{
  font-size:22px;font-weight:400;color:var(--price-final,#93c5fd);font-family:var(--font-en);white-space:nowrap;
}
.top-selling-price-block .product-price--single span{font-size:11px;font-weight:400;color:#555E6B}
.top-parts-grid .top-selling-price-block .product-price-sale{font-size:27px;font-weight:400}
.top-parts-grid .top-selling-price-block .product-price-sale span{font-size:12px;font-weight:400}
.top-parts-grid .top-selling-price-block .product-price-badge{font-size:17px}
.top-parts-grid .top-selling-price-block .product-price-compare{font-size:14px}
.top-parts-grid .top-selling-price-block .product-price--single{font-size:27px;font-weight:400}
.top-selling-cart{
  flex-shrink:0;width:32px;height:32px;min-height:32px;padding:0;
  border:none;border-radius:6px;
  background:#4a4a4a;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s ease,color .2s ease,transform .15s ease;
  position:relative;z-index:3;touch-action:manipulation;
}
.top-selling-cart:hover,.top-selling-cart:focus-visible{
  background:var(--gold,#d4af37);color:#111;
}
.top-selling-cart:active{transform:scale(.94)}
.top-selling-cart svg{width:15px;height:15px;flex-shrink:0;stroke:currentColor;fill:none}
.top-parts-swipe-hint{
  margin:8px 0 0;padding:0 12px;
  font-size:10px;color:rgba(255,255,255,.35);text-align:center;
}
.top-selling-empty{min-width:100%;padding:24px;text-align:center;color:rgba(255,255,255,.4)}
.brands-banner-viewport{overflow:hidden;touch-action:pan-y pinch-zoom;cursor:grab}
.brands-banner-viewport.is-dragging{cursor:grabbing}
.brands-banner-track{
  display:flex;gap:10px;align-items:center;
  width:max-content;padding:0 8px;
  will-change:transform;
}
.brand-banner-item{
  flex:0 0 76px;width:76px;height:76px;
  padding:8px;background:#fff;border:1px solid rgba(0,0,0,.08);
  border-radius:14px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s ease,outline .2s ease;
  -webkit-tap-highlight-color:transparent;
}
.brand-banner-item img{width:100%;height:100%;object-fit:contain}
.brand-banner-item.active{
  border-color:var(--gold);outline:2px solid var(--gold);outline-offset:1px;
}
.brands-track.brands-marquee,
.brands-banner-track.brands-marquee{
  width:max-content;
  will-change:transform;
  transition:none!important;
  animation:brandsMarqueeLtr 12s linear infinite;
  animation-play-state:running;
}
html[dir="rtl"] .brands-track.brands-marquee,
html[dir="rtl"] .brands-banner-track.brands-marquee{
  animation-name:brandsMarqueeRtl;
}
.brands-viewport.is-paused .brands-track.brands-marquee,
.brands-viewport.is-dragging .brands-track.brands-marquee,
.brands-banner-viewport.is-paused .brands-banner-track.brands-marquee,
.brands-banner-viewport.is-dragging .brands-banner-track.brands-marquee{
  animation-play-state:paused;
}
@keyframes brandsMarqueeLtr{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@keyframes brandsMarqueeRtl{
  from{transform:translateX(0)}
  to{transform:translateX(50%)}
}

/* ── Top selling infinite marquee ── */
.top-selling-track.top-selling-marquee{
  width:max-content;
  will-change:transform;
  transition:none !important;
  animation:topSellingMarqueeLtr 28s linear infinite;
  animation-play-state:running;
}
html[dir="rtl"] .top-selling-track.top-selling-marquee{
  animation-name:topSellingMarqueeRtl;
}
.top-parts-viewport.is-paused .top-selling-track.top-selling-marquee,
.top-parts-viewport.is-dragging .top-selling-track.top-selling-marquee{
  animation-play-state:paused;
}
.top-parts-viewport:has(.top-selling-card:hover) .top-selling-track.top-selling-marquee{
  animation-play-state:paused;
}
.top-selling-card:hover{z-index:2}
@keyframes topSellingMarqueeLtr{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@keyframes topSellingMarqueeRtl{
  from{transform:translateX(0)}
  to{transform:translateX(50%)}
}
.top-parts-viewport{touch-action:pan-y pinch-zoom;cursor:grab}
.top-parts-viewport.is-dragging{cursor:grabbing}

/* ── Product detail — related products ── */
.pd-related{margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}
.pd-related-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;
}
.pd-related-card{
  background:var(--bg3);border:1px solid var(--border2);border-radius:12px;
  padding:12px;cursor:pointer;transition:all .22s ease;
}
.pd-related-card:hover{border-color:rgba(212,175,55,.45);transform:translateY(-2px)}
.pd-related-name{font-size:12px;font-weight:700;color:#fff;line-height:1.3;margin-bottom:4px}
.pd-related-brand{font-size:10px;color:var(--gray);font-family:var(--font-en);margin-bottom:6px}
.pd-related-price{font-size:14px;font-weight:900;color:var(--gold-light);font-family:var(--font-en)}
.pd-brand-info{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  background:rgba(10,25,70,.25);border:1px solid rgba(10,25,70,.45);border-radius:10px;
}
.pd-brand-info img{width:36px;height:36px;object-fit:contain;border-radius:50%;background:#fff;padding:4px}
.pd-brand-info-text{font-size:12px;color:var(--gray);line-height:1.5}
.pd-brand-info-text strong{color:#fff;display:block;font-size:13px}

/* ── Cart UX polish ── */
.cart-drawer{will-change:transform}
.cart-item{animation:cartItemIn .32s ease both}
@keyframes cartItemIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.cart-item-removing{animation:cartItemOut .25s ease forwards}
@keyframes cartItemOut{
  to{opacity:0;transform:translateX(20px);max-height:0;padding:0;margin:0;border-width:0}
}
html[dir="ltr"] .cart-item-removing{animation-name:cartItemOutLtr}
@keyframes cartItemOutLtr{to{opacity:0;transform:translateX(-20px);max-height:0;padding:0;margin:0;border-width:0}}
.cart-qty-btn{min-width:32px;min-height:32px}
.nav-cart-btn .cart-badge.bump{animation:badgeBump .45s ease}
@keyframes badgeBump{
  0%,100%{transform:scale(1)}
  40%{transform:scale(1.35)}
}

/* ── Performance: reduce motion preference ── */
@media(prefers-reduced-motion:reduce){
  .product-card,.cart-item,.hero-slide,.pd-modal,.pd-overlay,.pd-main-photo,.pd-thumb,.pd-micro-enter,.pd-price-micro-enter,.pd-description-collapse,.pd-company-link,.pd-actions .btn-cart{animation:none!important;transition:none!important}
  .pd-lightbox.open .pd-lightbox-img{animation:none!important}
  .pd-rating--animate .product-star.is-filled,.pd-rating--animate.is-playing .product-star.is-filled{opacity:1;transform:none;animation:none!important}
  .pd-micro-enter,.pd-price-micro-enter{opacity:1;transform:none}
}

/* ── Lazy image placeholder ── */
img[loading="lazy"]{background:var(--bg4)}

/* ── Hero fallback when images missing ── */
.hero-slide.is-fallback{display:none}
.hero-slider.has-fallback{
  background:linear-gradient(135deg,#0a0a0f 0%,#141824 45%,#1a1020 100%);
}
.hero-slider.has-fallback::after{
  content:'OEM ASTRA J';
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-size:clamp(28px,6vw,56px);font-weight:900;
  letter-spacing:.08em;color:rgba(255,255,255,.08);pointer-events:none;
}

/* ── Product card stock badge ── */
.product-stock-badge{
  position:absolute;top:10px;left:10px;z-index:2;
  background:rgba(37,211,102,.15);border:1px solid rgba(37,211,102,.35);
  color:#6ee7a0;font-size:10px;font-weight:800;padding:3px 8px;border-radius:999px;
  font-family:var(--font-en);letter-spacing:.3px;
}
html[dir="ltr"] .product-stock-badge{left:auto;right:10px}
.product-stock-badge.stock-out{background:rgba(215,25,32,.15);border-color:rgba(215,25,32,.4);color:#ff8a8a}
.product-stock-badge.stock-low{background:rgba(212,175,55,.15);border-color:rgba(212,175,55,.4);color:var(--gold-light,#E2C15A)}

/* ── Brand page (#brand/ID) ── */
#brandPage.catalog-hidden{display:none!important}
#brandPage.top-parts-hidden-companion{display:block}
.brand-page-head{
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border);
}
.brand-page-logo-wrap{
  width:88px;height:88px;border-radius:14px;background:#fff;
  display:flex;align-items:center;justify-content:center;padding:10px;
  border:1px solid var(--border2);flex-shrink:0;
}
.brand-page-logo-wrap img{max-width:100%;max-height:100%;object-fit:contain}
.brand-page-head-text{flex:1;min-width:200px}
.brand-page-head-text .section-label{margin-bottom:6px}
.brand-page-head-text .section-title{margin:0;font-size:clamp(22px,3vw,32px)}
.brand-page-count{color:var(--gray);font-size:14px;margin-top:6px}
.brand-page-table-wrap{overflow-x:auto;margin-bottom:24px}
.brand-page-table{
  width:100%;border-collapse:collapse;font-size:13px;
  background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;
}
.brand-page-table th{
  text-align:start;padding:12px 14px;background:var(--bg3);
  color:var(--gray);font-size:11px;text-transform:uppercase;letter-spacing:.4px;
  border-bottom:1px solid var(--border);
}
.brand-page-table td{
  padding:14px;border-bottom:1px solid var(--border);vertical-align:top;
}
.brand-page-table tr:last-child td{border-bottom:none}
.brand-page-table tr:hover td{background:rgba(255,255,255,.02)}
.brand-page-name{font-weight:700;font-size:14px;margin-bottom:4px;color:#fff}
.brand-page-name-en{font-size:12px;color:var(--gray)}
.brand-page-desc{color:var(--gray);font-size:12px;line-height:1.5;max-width:280px}
.brand-page-price{font-weight:800;color:var(--gold);font-family:var(--font-en);white-space:nowrap}
.brand-stock-pill{
  display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;
  border:1px solid transparent;white-space:nowrap;
}
.brand-stock-pill.stock-in{background:rgba(37,211,102,.12);border-color:rgba(37,211,102,.35);color:#6ee7a0}
.brand-stock-pill.stock-low{background:rgba(212,175,55,.12);border-color:rgba(212,175,55,.35);color:var(--gold-light,#E2C15A)}
.brand-stock-pill.stock-out{background:rgba(215,25,32,.12);border-color:rgba(215,25,32,.35);color:#ff8a8a}
.brand-page-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.brand-page-actions .btn-cart{min-height:36px;padding:0 12px;font-size:12px}
.brand-page-actions .btn-cart:disabled{opacity:.45;cursor:not-allowed}
.brand-page-cards{display:none;flex-direction:column;gap:14px}
.brand-page-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px;
}
.brand-page-card-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px}
.brand-page-card-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0;font-size:12px}
.brand-page-card-meta span{color:var(--gray)}
.brand-page-card-meta strong{color:#fff;font-family:var(--font-en)}
@media(max-width:900px){
  .brand-page-table-wrap{display:none}
  .brand-page-cards{display:flex}
  .brand-page-head{align-items:flex-start}
  .brand-page-logo-wrap{width:72px;height:72px}
}

.search-drop-recent-hdr{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:8px 14px;font-size:11px;color:var(--gray);border-bottom:1px solid var(--border);
  background:var(--bg3);
}
.search-drop-recent-hdr button{
  background:transparent;border:none;color:var(--gold-light);font-size:11px;font-weight:700;cursor:pointer;
}
.search-drop-recent{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:10px 14px;border:none;border-bottom:1px solid var(--border);
  background:transparent;cursor:pointer;text-align:start;color:#fff;
}
.search-drop-recent:hover{background:var(--bg3)}
.search-drop-recent span{font-size:13px;font-weight:600}
.search-drop-recent small{color:var(--gray);font-size:11px}
.search-drop-recent-x{
  background:transparent;border:none;color:var(--gray);font-size:16px;line-height:1;padding:4px 6px;cursor:pointer;
}

/* ── Checkout modal ── */
.checkout-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:2200;
  opacity:0;pointer-events:none;transition:opacity .28s ease;backdrop-filter:blur(4px);
}
.checkout-overlay.open{opacity:1;pointer-events:all}
.checkout-modal{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-46%) scale(.97);
  width:min(480px,94vw);
  max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 24px);
  overflow:hidden;display:flex;flex-direction:column;
  background:var(--bg2);border:1px solid var(--border2);border-radius:18px;z-index:2201;
  opacity:0;pointer-events:none;transition:all .3s ease;box-shadow:0 24px 80px rgba(0,0,0,.75);
}
.checkout-modal.open{opacity:1;pointer-events:all;transform:translate(-50%,-50%) scale(1)}
#checkoutFormView,#checkoutConfirmView{
  flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;
}
.checkout-header{
  display:flex;align-items:center;justify-content:space-between;padding:16px 20px;
  border-bottom:1px solid var(--border);flex-shrink:0;
}
.checkout-header h2{font-size:17px;font-weight:900;color:#fff}
.checkout-close{
  background:var(--bg4);border:1px solid var(--border2);width:34px;height:34px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
}
.checkout-body{
  flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;padding:18px 20px;display:flex;flex-direction:column;gap:12px;
  scrollbar-width:thin;scrollbar-color:rgba(212,175,55,.45) rgba(255,255,255,.06);
}
.checkout-body::-webkit-scrollbar{width:8px}
.checkout-body::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:4px;margin:4px 0}
.checkout-body::-webkit-scrollbar-thumb{background:rgba(212,175,55,.42);border-radius:4px;border:1px solid rgba(0,0,0,.15)}
.checkout-body::-webkit-scrollbar-thumb:hover{background:rgba(196,30,58,.55)}
.checkout-field label{display:block;font-size:12px;font-weight:700;color:var(--gray);margin-bottom:6px}
.checkout-field input,.checkout-field textarea,.checkout-field select{
  width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:9px;
  padding:12px 14px;color:#fff;font-size:14px;font-family:var(--font-ar);outline:none;
}
.checkout-field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23888' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 14px center;padding-left:36px}
html[dir="ltr"] .checkout-field select{background-position:right 14px center;padding-left:14px;padding-right:36px}
.checkout-field textarea{min-height:72px;resize:vertical}
.checkout-field input:focus,.checkout-field textarea:focus,.checkout-field select:focus{border-color:var(--red)}
.checkout-field input.checkout-field-error,.checkout-field textarea.checkout-field-error,.checkout-field select.checkout-field-error{
  border-color:var(--red);box-shadow:0 0 0 2px rgba(215,25,32,.25);
}
.btn-checkout:disabled{opacity:.65;cursor:wait;transform:none}
.checkout-payment{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:12px 14px;
}
.checkout-payment-label{font-size:12px;font-weight:700;color:var(--gray)}
.checkout-payment-badge{
  font-size:12px;font-weight:800;color:var(--gold);background:rgba(212,175,55,.1);
  border:1px solid rgba(212,175,55,.25);padding:6px 10px;border-radius:8px;
}
.checkout-payment-block{
  margin-top:4px;padding:12px 14px;border-radius:12px;
  background:var(--bg3);border:1px solid var(--border2);
}
.checkout-payment-block:has(.checkout-payment-extra:not([hidden])){
  border-color:rgba(212,175,55,.35);
  box-shadow:0 0 0 1px rgba(212,175,55,.12);
}
.checkout-prepaid-fields{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.checkout-prepaid-input{
  width:100%;padding:12px 14px;border-radius:9px;border:1px solid var(--border2);
  background:var(--bg2);color:#fff;font-size:14px;font-family:var(--font-ar);
}
.checkout-prepaid-input.checkout-field-error{border-color:var(--red);box-shadow:0 0 0 2px rgba(215,25,32,.25)}
.checkout-proof-zone{
  margin-top:4px;padding:14px;border-radius:12px;border:2px dashed rgba(212,175,55,.45);
  background:rgba(212,175,55,.06);text-align:center;
}
.checkout-proof-zone.has-proof{border-style:solid;border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.08)}
.checkout-proof-zone.checkout-field-error{border-color:var(--red);box-shadow:0 0 0 2px rgba(215,25,32,.25)}
.checkout-proof-file{
  position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;clip:rect(0,0,0,0);
}
.checkout-proof-btn{
  width:100%;padding:12px 16px;border-radius:10px;border:1px solid rgba(212,175,55,.45);
  background:rgba(212,175,55,.14);color:var(--gold);font-size:14px;font-weight:800;
  font-family:var(--font-ar);cursor:pointer;
}
.checkout-proof-btn:hover{background:rgba(212,175,55,.22)}
.checkout-payment-methods{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.checkout-pay-option{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;
  border:1px solid var(--border2);background:var(--bg3);cursor:pointer;
  transition:border-color .15s ease,background .15s ease,box-shadow .15s ease;
}
.checkout-pay-option.is-selected,.checkout-pay-option:has(input:checked){
  border-color:rgba(212,175,55,.55);background:rgba(212,175,55,.08);
  box-shadow:0 0 0 1px rgba(212,175,55,.18);
}
.checkout-pay-option.is-disabled{opacity:.55;cursor:not-allowed}
.checkout-pay-option input{margin:0;accent-color:var(--gold);flex-shrink:0;width:18px;height:18px}
.checkout-pay-option-icon{
  flex-shrink:0;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.22);color:var(--gold);
}
.checkout-pay-option-icon svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8}
.checkout-pay-option-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.checkout-pay-option-text{font-size:13px;font-weight:700;color:#fff}
.checkout-pay-option-hint{font-size:11px;color:var(--gray)}
.checkout-pay-tel{color:var(--gold);text-decoration:none;font-weight:700}
.checkout-pay-tel:hover{text-decoration:underline}
.checkout-payment-extra{margin-top:10px}
.checkout-payment-extra input[type="text"]{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border2);background:var(--bg2);color:#fff}
.checkout-payment-proof-label{margin-top:10px}
.checkout-payment-proof-input{width:100%;margin-top:6px;font-size:12px;color:var(--gray)}
.checkout-payment-proof-preview img{display:block;max-width:100%;object-fit:contain}
.checkout-field-label{font-size:12px;font-weight:700;color:var(--gray);display:block;margin-bottom:6px}
.checkout-payment-confirm{margin:12px 0;padding:12px;border-radius:10px;background:var(--bg3);border:1px solid var(--border2);text-align:start}
.checkout-pay-confirm-line{font-size:13px;color:var(--gray);margin:6px 0}
.checkout-pay-confirm-line code{color:var(--gold);font-family:var(--font-en)}
.checkout-pay-instructions{font-size:13px;color:var(--gray);line-height:1.6}
.checkout-copy-btn{margin-inline-start:8px;padding:4px 8px;font-size:11px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--gold);cursor:pointer}
.track-modal{max-width:440px}
.track-hint{font-size:13px;margin:0 0 12px;line-height:1.6}
.track-result{margin-top:14px;padding:12px 14px;border-radius:10px;background:var(--bg3);border:1px solid var(--border2)}
.track-summary p{margin:6px 0;font-size:13px}
.track-err{color:#f87171;font-size:13px;margin:0}
.track-ship-block{margin:10px 0;padding:10px;border-radius:8px;background:rgba(212,160,23,.08);border:1px solid rgba(212,160,23,.25)}
.track-carrier-link{display:inline-block;margin-top:8px;font-size:13px;font-weight:700;color:var(--gold)}
.track-wait{font-size:13px;margin:8px 0}
.track-timeline{list-style:none;padding:0;margin:12px 0 0}
.track-timeline li{padding:8px 0 8px 14px;border-inline-start:2px solid var(--border2);margin-inline-start:4px;position:relative}
.track-timeline li.is-done{border-color:var(--gold)}
.track-timeline li strong{display:block;color:#fff;font-size:13px}
.track-timeline time{font-size:11px;color:var(--gray)}
.checkout-confirm-body{text-align:center;padding-top:8px;padding-bottom:24px}
.checkout-confirm-icon{
  width:56px;height:56px;border-radius:50%;margin:0 auto 14px;
  background:rgba(34,197,94,.12);border:2px solid rgba(34,197,94,.35);
  color:#22c55e;font-size:28px;font-weight:900;line-height:52px;
}
.checkout-confirm-title{font-size:18px;font-weight:900;color:#fff;margin-bottom:10px}
.checkout-confirm-id{font-size:14px;color:var(--gray);margin-bottom:8px}
.checkout-confirm-id strong{color:var(--gold);font-family:var(--font-en)}
.checkout-confirm-payref{font-size:13px;color:var(--gold);margin:0 0 10px;line-height:1.5}
.checkout-confirm-msg{font-size:13px;color:var(--gray);line-height:1.6;margin-bottom:16px}
.checkout-wa-secondary{margin-top:4px;font-size:13px;padding:12px}
.checkout-summary{
  background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:12px 14px;
  font-size:13px;color:var(--gray);
}
.checkout-summary strong{color:#fff}
.checkout-items{display:flex;flex-direction:column;gap:0;margin-bottom:10px}
.checkout-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.checkout-item:last-child{border-bottom:none}
.checkout-item-info{flex:1;min-width:0}
.checkout-item-name{font-size:12px;font-weight:700;color:#fff;line-height:1.35;margin-bottom:3px}
.checkout-item-price{font-size:11px;color:var(--gray);font-family:var(--font-en)}
.checkout-total-row{display:flex;align-items:center;justify-content:space-between;font-size:15px;font-weight:900;color:#fff;padding-top:10px;border-top:1px solid var(--border2);margin-top:4px}
.checkout-total-row.sub{font-size:12px;font-weight:700;color:var(--gray);border-top:none;padding-top:6px;margin-top:0}
.checkout-total-row.sub span:last-child{color:rgba(255,255,255,.85);font-weight:700}
.checkout-total-row.discount span:last-child{color:#4ade80}
.checkout-total-row span:last-child{color:var(--price-final,#93c5fd);font-family:var(--font-en);font-size:17px;font-weight:900;letter-spacing:-.02em}
.checkout-totals{margin-top:8px;padding-top:4px;border-top:1px solid var(--border)}
.checkout-promo-input{display:flex;gap:8px;align-items:center}
.checkout-promo-input input{flex:1}
.checkout-promo-btn{
  flex-shrink:0;padding:10px 14px;border-radius:9px;border:1px solid var(--border2);
  background:rgba(212,175,55,.12);color:var(--gold);font-weight:800;font-size:12px;cursor:pointer;
}
.checkout-promo-btn:hover{background:rgba(212,175,55,.22)}
.checkout-promo-msg{display:block;font-size:11px;margin-top:6px;font-weight:700}
.checkout-promo-msg.success{color:#4ade80}
.checkout-promo-msg.error{color:var(--red)}
.order-qty-row--checkout .order-qty-btn{width:40px;height:40px;font-size:16px}
.order-qty-row--checkout .order-qty-val{min-width:24px;font-size:13px}
.checkout-footer{
  flex-shrink:0;position:relative;z-index:2;
  padding:14px 20px calc(18px + env(safe-area-inset-bottom,0px));
  border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;
}
.checkout-toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:#111;border:1px solid rgba(212,175,55,.35);color:#fff;padding:12px 18px;border-radius:10px;
  z-index:2300;opacity:0;pointer-events:none;transition:all .28s ease;font-size:13px;font-weight:700;
  box-shadow:0 12px 40px rgba(0,0,0,.45);
}
.checkout-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.cart-item-img img,.cart-item-img .cart-brand-fallback{
  width:100%;height:100%;object-fit:contain;padding:6px;
}
.cart-brand-fallback{background:#fff;border-radius:8px}
