/* Online Store — light retail theme (overrides theme.css tokens) */
:root {
  --bg:        #F6F8FB;
  --bg-2:      #FFFFFF;
  --surface:   #FFFFFF;
  --surface-2: #F1F4F9;
  --steel:     #E4E9F0;
  --steel-2:   #D4DCE7;
  --text:      #15202B;
  --muted:     #647084;
  --accent:    #2563EB;
  --accent-2:  #1D4ED8;
  --forge:     #F2792B;
  --shadow:    0 14px 38px rgba(20,40,80,.10);
  --shadow-sm: 0 4px 16px rgba(20,40,80,.07);
  --gradient-brand: linear-gradient(135deg, #2563EB, #4F46E5);
  --gradient-steel: linear-gradient(160deg, #EEF3FB, #FFFFFF);
}
body { background: var(--bg); }
.topbar { background: rgba(255,255,255,.82); }
.btn-accent { color: #fff; box-shadow: 0 8px 22px rgba(37,99,235,.25); }
.badge { background: rgba(37,99,235,.1); color: var(--accent); border-color: rgba(37,99,235,.2); }

.store-hero { background: linear-gradient(135deg, #2563EB, #4F46E5); color: #fff; border-radius: var(--radius-lg); padding: clamp(30px,5vw,56px); position: relative; overflow: hidden; }
.store-hero::after { content: "🛍️"; position: absolute; inset-block-start: -10px; inset-inline-end: 18px; font-size: 9rem; opacity: .18; }
.store-hero h1 { font-size: clamp(1.8rem,4vw,2.8rem); }
.store-hero p { opacity: .9; max-width: 46ch; margin-top: 10px; }
.store-hero .btn { margin-top: 22px; background: #fff; color: #2563EB; border: none; }

.toolbar-row { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; margin: 26px 0 18px; }
.search-box { position: relative; flex: 1; min-width: 220px; }
.search-box .input { padding-inline-start: 42px; }
.search-box svg { position: absolute; inset-block-start: 50%; inset-inline-start: 14px; transform: translateY(-50%); width: 18px; height: 18px; color: var(--muted); }
.chips-row { display: flex; gap: 9px; flex-wrap: wrap; }

.products { grid-template-columns: repeat(4, 1fr); }
.product { padding: 0; overflow: hidden; display: flex; flex-direction: column; }
.media { position: relative; aspect-ratio: 4/3; background: var(--g, linear-gradient(135deg,#EEF3FB,#DCE6F5)); display: grid; place-items: center; }
.media .emoji { font-size: 3.4rem; }
.media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.media .pbadge { position: absolute; inset-block-start: 10px; inset-inline-start: 10px; }
.product .body { padding: 15px 16px 18px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.product h3 { font-size: 1rem; }
.product .rating { color: #F59E0B; font-size: .85rem; font-weight: 700; }
.product .price-row { display: flex; align-items: baseline; gap: 9px; margin-top: auto; }
.product .price { font-size: 1.15rem; font-weight: 800; color: var(--accent); }
.product .old { color: var(--muted); text-decoration: line-through; font-size: .85rem; }
.product .add { margin-top: 10px; }
.product { cursor: pointer; }
.product .card-qty { display: flex; margin-top: 10px; width: 100%; border-radius: 9px; }
.product .card-qty button { flex: 1; }
.product .card-qty span { flex: 1; }
.sale-chip.active { background: var(--forge); border-color: var(--forge); color: #fff; }

/* Wishlist heart (cards + modal) */
.wish-btn { background: rgba(255,255,255,.85); border: 1px solid var(--steel); color: #9aa6b6; cursor: pointer; border-radius: 50%; width: 34px; height: 34px; display: grid; place-items: center; font-size: 1.05rem; line-height: 1; transition: .15s; }
.wish-btn.on { color: var(--forge); border-color: var(--forge); }
.wish-btn:hover { transform: scale(1.1); }
.card-wish { position: absolute; inset-block-start: 10px; inset-inline-end: 10px; z-index: 2; }
.wish-cnt { background: #9aa6b6; }

/* Product detail modal */
.modal.pm { width: min(760px, 100%); max-height: 90vh; overflow: auto; position: relative; }
.pm-x { position: absolute; inset-block-start: 16px; inset-inline-end: 16px; z-index: 3; }
.pm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; align-items: start; }
.pm-media { position: relative; aspect-ratio: 4/3; border-radius: var(--radius); background: var(--g, linear-gradient(135deg,#EEF3FB,#DCE6F5)); display: grid; place-items: center; overflow: hidden; }
.pm-media .emoji { font-size: 4rem; }
.pm-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.pm-info h2 { font-size: 1.35rem; padding-inline-end: 30px; }
.pm-meta { gap: 12px; margin: 8px 0; }
.pm-pricerow { margin: 6px 0 10px; }
.pm-desc { font-size: .9rem; }
.stock { font-size: .78rem; font-weight: 700; color: var(--good); }
.stock.low { color: var(--forge); }
.pm-vrow { display: flex; align-items: center; gap: 12px; margin-top: 14px; flex-wrap: wrap; }
.pm-vlab { color: var(--muted); font-size: .82rem; min-width: 48px; }
.pm-swatches { display: flex; gap: 8px; }
.pm-sw { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--steel); cursor: pointer; transition: .12s; }
.pm-sw.on { box-shadow: 0 0 0 2px var(--bg), 0 0 0 4px var(--accent); }
.pm-sizes { display: flex; gap: 8px; flex-wrap: wrap; }
.pm-size { min-width: 42px; padding: 7px 10px; border: 1px solid var(--steel); background: var(--surface); border-radius: 9px; cursor: pointer; font-weight: 600; color: var(--text); transition: .12s; }
.pm-size:hover { border-color: var(--accent); }
.pm-size.on { background: var(--accent); color: #fff; border-color: var(--accent); }
.pm-actions { display: flex; align-items: center; gap: 10px; margin-top: 18px; }
.pm-actions #pmAdd { flex: 1; }
.pm-wish { flex: none; }

/* Reviews */
.pm-h { font-size: 1.05rem; margin: 22px 0 12px; padding-top: 18px; border-top: 1px solid var(--steel); }
.rv-grid { display: grid; grid-template-columns: auto 1fr; gap: 24px; align-items: center; margin-bottom: 16px; }
.rv-summary { text-align: center; }
.rv-big { font-size: 2.6rem; font-weight: 800; line-height: 1; }
.rv-bigstars { color: #F59E0B; letter-spacing: 2px; }
.rv-histo { display: flex; flex-direction: column; gap: 5px; }
.hrow { display: flex; align-items: center; gap: 10px; font-size: .8rem; color: var(--muted); }
.hrow span { width: 26px; }
.hbar { flex: 1; height: 8px; background: var(--surface-2); border-radius: 999px; overflow: hidden; }
.hbar i { display: block; height: 100%; background: #F59E0B; border-radius: 999px; }
.rv-list { display: grid; gap: 12px; }
.review { background: var(--surface-2); border-radius: var(--radius-sm); padding: 12px 14px; }
.rv-top { display: flex; justify-content: space-between; align-items: center; }
.rv-stars { color: #F59E0B; }
.rv-date { font-size: .76rem; margin: 2px 0 5px; }
.review p { font-size: .88rem; }

/* Related */
.rel-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }
.rel-card { display: flex; flex-direction: column; align-items: center; gap: 4px; background: var(--surface); border: 1px solid var(--steel); border-radius: var(--radius-sm); padding: 14px 8px; cursor: pointer; transition: .15s; }
.rel-card:hover { transform: translateY(-3px); border-color: var(--accent); }
.rel-em { font-size: 1.8rem; }
.rel-name { font-size: .78rem; text-align: center; color: var(--text); }
.rel-price { font-size: .82rem; font-weight: 800; color: var(--accent); }

/* Wishlist modal */
.wish-body { display: flex; flex-direction: column; gap: 10px; max-height: 60vh; overflow: auto; }
.wish-item { display: flex; align-items: center; gap: 12px; }
.wi-em { width: 48px; height: 48px; border-radius: 11px; background: var(--surface-2); display: grid; place-items: center; font-size: 1.5rem; flex: none; }
.wi-body { flex: 1; }
.wi-act { display: flex; gap: 6px; }

/* Cart drawer */
.cart-toggle { position: relative; }
.cart-count { position: absolute; inset-block-start: -7px; inset-inline-end: -7px; background: var(--forge); color: #fff; min-width: 20px; height: 20px; border-radius: 999px; font-size: .72rem; font-weight: 800; display: grid; place-items: center; padding: 0 5px; }
.drawer { position: fixed; inset-block: 0; inset-inline-end: 0; width: min(420px,100%); background: var(--surface); border-inline-start: 1px solid var(--steel); box-shadow: -20px 0 60px rgba(0,0,0,.18); transform: translateX(100%); transition: transform .32s var(--ease); z-index: 120; display: flex; flex-direction: column; }
html[dir="rtl"] .drawer { transform: translateX(-100%); }
.drawer.open { transform: none !important; }
.drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--steel); }
.drawer-body { flex: 1; overflow: auto; padding: 16px 20px; display: flex; flex-direction: column; gap: 12px; }
.drawer-foot { border-top: 1px solid var(--steel); padding: 18px 20px; }
.cart-item { display: flex; gap: 12px; align-items: center; }
.cart-item .ci-media { width: 56px; height: 56px; border-radius: 11px; background: var(--g,#EEF3FB); display: grid; place-items: center; font-size: 1.6rem; flex: none; }
.cart-item .ci-body { flex: 1; }
.qty { display: inline-flex; align-items: center; border: 1px solid var(--steel); border-radius: 9px; overflow: hidden; }
.qty button { width: 30px; height: 30px; background: var(--surface-2); cursor: pointer; border: none; font-size: 1.1rem; }
.qty span { width: 34px; text-align: center; font-weight: 700; }
.cart-empty { text-align: center; color: var(--muted); padding: 50px 0; }
.sum-row { display: flex; justify-content: space-between; padding: 5px 0; }
.sum-row.total { font-size: 1.15rem; font-weight: 800; border-top: 1px solid var(--steel); margin-top: 8px; padding-top: 12px; }

.backdrop { position: fixed; inset: 0; background: rgba(8,16,30,.4); opacity: 0; pointer-events: none; transition: .3s; z-index: 110; }
.backdrop.show { opacity: 1; pointer-events: auto; }

@media (max-width: 980px) { .products { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 720px) {
  .products { grid-template-columns: repeat(2,1fr); }
  .pm-grid { grid-template-columns: 1fr; }
  .rv-grid { grid-template-columns: 1fr; gap: 14px; }
  .rel-row { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 440px) { .products { grid-template-columns: 1fr; } }
