/* ================================================================
   BELI SAHAJA — Public CSS
   Guna selector kuat + !important untuk override tema WordPress
   ================================================================ */

/* ── Variables ── */
:root {
  --bs-primary:   #f05a28;
  --bs-primary-d: #d04010;
  --bs-primary-l: #fff3ef;
  --bs-bg:        #f7f8fa;
  --bs-white:     #ffffff;
  --bs-border:    #e2e8f0;
  --bs-muted:     #718096;
  --bs-text:      #2d3748;
  --bs-green:     #10b981;
  --bs-red:       #ef4444;
  --bs-radius:    12px;
  --bs-radius-sm: 8px;
  --bs-shadow:    0 1px 4px rgba(0,0,0,.07),0 4px 14px rgba(0,0,0,.07);
  --bs-shadow-lg: 0 8px 30px rgba(0,0,0,.13);
  --bs-font:      -apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

/* ── Box sizing ── */
.bs-shop *,.bs-product-single *,.bs-checkout-page *,
.bs-cart-drawer *,.bs-cart-drawer-overlay,.bs-thankyou-page * {
  box-sizing:border-box;
}

/* ================================================================
   BUTTONS
   ================================================================ */
.bs-btn {
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:4px;
  padding:10px 14px;
  font-size:13px;
  font-weight:600;
  font-family:var(--bs-font);
  line-height:1.2;
  border-radius:var(--bs-radius-sm);
  border:2px solid var(--bs-border);
  background:var(--bs-white);
  color:var(--bs-text);
  cursor:pointer;
  text-decoration:none !important;
  transition:all .15s;
  -webkit-tap-highlight-color:transparent;
  white-space:nowrap;
  -webkit-appearance:none;
  appearance:none;
}
.bs-btn:hover,.bs-btn:focus { border-color:var(--bs-primary); color:var(--bs-primary); outline:none; text-decoration:none !important; }
.bs-btn-primary { background:var(--bs-primary) !important; color:#fff !important; border-color:var(--bs-primary) !important; }
.bs-btn-primary:hover { background:var(--bs-primary-d) !important; border-color:var(--bs-primary-d) !important; color:#fff !important; }
/* Override tema — paksa semua teks dalam butang primary jadi putih */
.bs-btn-primary, .bs-btn-primary *,
.bs-btn-primary:visited, .bs-btn-primary:visited *,
button.bs-btn-primary, button.bs-btn-primary *,
a.bs-btn-primary, a.bs-btn-primary * { color:#fff !important; }
.bs-btn-outline { background:transparent !important; color:var(--bs-primary) !important; border-color:var(--bs-primary) !important; }
.bs-btn-outline:hover { background:var(--bs-primary) !important; color:#fff !important; }
.bs-btn-sm  { padding:6px 12px !important; font-size:12px !important; }
.bs-btn-lg  { padding:13px 20px !important; font-size:15px !important; }
.bs-btn[disabled],.bs-btn-disabled { opacity:.4 !important; cursor:not-allowed !important; pointer-events:none !important; }

/* ================================================================
   SHOP
   ================================================================ */
.bs-shop {
  font-family:var(--bs-font);
  color:var(--bs-text);
  font-size:14px;
  padding:14px 16px;
  max-width:1200px;
  margin:0 auto;
}

/* Cart bar */
.bs-cart-bar {
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:var(--bs-primary);
  color:#fff;
  padding:9px 12px;
  border-radius:var(--bs-radius);
  margin-bottom:12px;
  font-size:13px;
  font-weight:500;
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 2px 10px rgba(240,90,40,.3);
}
.bs-cart-bar .bs-btn { background:rgba(255,255,255,.2) !important; color:#fff !important; border-color:rgba(255,255,255,.4) !important; padding:5px 11px !important; font-size:12px !important; }

/* Search */
.bs-shop-header { margin-bottom:10px; }
.bs-search-form  { display:flex; gap:8px; align-items:center; }
.bs-search-input {
  flex:1; min-width:0; padding:9px 12px;
  border:2px solid var(--bs-border); border-radius:var(--bs-radius-sm);
  font-size:14px; font-family:var(--bs-font); color:var(--bs-text);
  background:var(--bs-white); outline:none; -webkit-appearance:none;
}
.bs-search-input:focus { border-color:var(--bs-primary); }

/* Category tabs */
.bs-category-tabs {
  display:flex; gap:7px; overflow-x:auto;
  -webkit-overflow-scrolling:touch; padding-bottom:10px;
  margin-bottom:12px; border-bottom:1px solid var(--bs-border);
  scrollbar-width:none;
}
.bs-category-tabs::-webkit-scrollbar { display:none; }
.bs-cat-tab {
  display:inline-flex; align-items:center; gap:4px;
  padding:6px 12px; border-radius:999px; font-size:13px; font-weight:600;
  white-space:nowrap; flex-shrink:0; color:var(--bs-muted);
  text-decoration:none !important; background:var(--bs-white);
  border:2px solid var(--bs-border); transition:all .15s;
}
.bs-cat-tab:hover  { color:var(--bs-primary); border-color:var(--bs-primary); text-decoration:none !important; }
.bs-cat-tab.active { background:var(--bs-primary) !important; color:#fff !important; border-color:var(--bs-primary) !important; }
.bs-cat-tab-img { width:16px; height:16px; border-radius:50%; object-fit:cover; }

/* Product grid — ikut setting admin (CSS var di-inject dari PHP) */
.bs-product-grid {
  display:grid !important;
  grid-template-columns:repeat(var(--bs-cols-mob,2),1fr) !important;
  gap:8px;
}
@media screen and (min-width:640px) {
  .bs-product-grid { grid-template-columns:repeat(var(--bs-cols-desk,3),1fr) !important; gap:12px; }
}

/* Product Card */
/* Ikon butang guna CSS — lebih reliable dari emoji */
.bs-btn-buy::before    { content: ''; margin-right:4px; }
.bs-btn-cart::before   { content: ''; margin-right:4px; }
.bs-actions-row .bs-btn-primary { font-weight:700; letter-spacing:.2px; }
.bs-actions-row .bs-btn-outline { font-weight:700; letter-spacing:.2px; }

/* Gambar dan title boleh klik ke detail */
.bs-product-media-link { display:block; text-decoration:none !important; }
.bs-product-name-link  { display:block; text-decoration:none !important; color:inherit !important; }
.bs-product-name-link:hover .bs-product-name { color:var(--bs-primary) !important; }
.bs-media-slider { cursor:grab; user-select:none; }
.bs-media-slider:active { cursor:grabbing; }

.bs-product-card {
  background:var(--bs-white); border-radius:var(--bs-radius);
  overflow:hidden; border:1px solid var(--bs-border);
  box-shadow:var(--bs-shadow); display:flex; flex-direction:column;
}

/* Media */
.bs-product-media { position:relative; aspect-ratio:1/1; overflow:hidden; background:#f0f0f0; flex-shrink:0; }
.bs-product-media img,.bs-product-main-img { width:100%; height:100%; object-fit:cover; display:block; }
.bs-media-slider { position:relative; width:100%; height:100%; }
.bs-slide { display:none; width:100%; height:100%; }
.bs-slide.active { display:block; }
.bs-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.bs-slide-dots { position:absolute; bottom:5px; left:0; right:0; display:flex; justify-content:center; gap:4px; }
.bs-dot { width:5px; height:5px; border-radius:50%; background:rgba(255,255,255,.5); cursor:pointer; transition:all .2s; }
.bs-dot.active { background:#fff; transform:scale(1.3); }
.bs-video-wrapper { width:100%; height:100%; }
.bs-video-wrapper iframe { width:100%; height:100%; border:none; }
.bs-video-thumb { display:flex; align-items:center; justify-content:center; height:100%; font-size:28px; background:#111; color:#fff; }
.bs-badge-sale { position:absolute; top:5px; left:5px; background:var(--bs-red); color:#fff; font-size:8px; font-weight:800; padding:2px 6px; border-radius:4px; text-transform:uppercase; }
.bs-badge-featured { position:absolute; top:5px; right:5px; font-size:14px; }
.bs-sold-out-overlay { position:absolute; inset:0; background:rgba(0,0,0,.45); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:12px; }

/* Card info */
.bs-product-info { padding:8px 8px 4px; flex:1; }
.bs-product-name { font-size:12px; font-weight:700; margin-bottom:4px; line-height:1.4; color:var(--bs-text); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.bs-product-short-desc { display:none; }
@media screen and (min-width:640px) {
  .bs-product-name { font-size:13px; }
  .bs-product-short-desc { display:-webkit-box; font-size:11px; color:var(--bs-muted); margin-bottom:4px; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; line-height:1.4; }
}
.bs-original-price { font-size:10px; color:var(--bs-muted); text-decoration:line-through; display:block; margin-bottom:1px; }
.bs-current-price { font-size:14px; font-weight:800; color:var(--bs-primary); line-height:1.2; }
@media screen and (min-width:640px) { .bs-current-price { font-size:15px; } }
.bs-type-badge { display:inline-block; font-size:9px; background:var(--bs-primary-l); color:var(--bs-primary); padding:2px 6px; border-radius:4px; font-weight:600; margin-top:3px; }

/* Card actions */
.bs-product-actions { padding:5px 7px 8px; display:flex; flex-direction:column; gap:4px; }
.bs-actions-row { display:flex; gap:4px; }
.bs-actions-row .bs-btn { flex:1; padding:8px 4px !important; font-size:11px !important; justify-content:center; }
.bs-btn-detail { width:100%; justify-content:center; padding:6px 8px !important; font-size:11px !important; color:var(--bs-muted) !important; border-color:var(--bs-border) !important; }
.bs-btn-detail:hover { color:var(--bs-primary) !important; border-color:var(--bs-primary) !important; }

.bs-empty-products { grid-column:1/-1; text-align:center; padding:40px 16px; color:var(--bs-muted); font-size:14px; }
.bs-pagination { display:flex; gap:8px; justify-content:center; margin-top:20px; flex-wrap:wrap; }
.bs-page-btn { display:inline-flex !important; align-items:center !important; justify-content:center !important; width:34px; height:34px; border-radius:var(--bs-radius-sm); border:2px solid var(--bs-border) !important; text-decoration:none !important; color:var(--bs-text) !important; font-size:13px; font-weight:600; background:var(--bs-white) !important; }
.bs-page-btn.active,.bs-page-btn:hover { background:var(--bs-primary) !important; border-color:var(--bs-primary) !important; color:#fff !important; }
.bs-cart-icon-link { position:relative; display:inline-flex; align-items:center; text-decoration:none !important; font-size:22px; }
.bs-cart-badge { position:absolute; top:-6px; right:-10px; background:var(--bs-primary); color:#fff; font-size:10px; font-weight:800; min-width:18px; height:18px; border-radius:9px; display:flex; align-items:center; justify-content:center; padding:0 4px; }

/* ================================================================
   CART DRAWER
   ================================================================ */
body.bs-cart-open { overflow:hidden !important; }
.bs-cart-drawer-overlay { position:fixed; top:0; left:0; width:100vw; height:100vh; background:rgba(0,0,0,.5); z-index:9990; opacity:0; pointer-events:none; transition:opacity .25s; }
.bs-cart-drawer-overlay.open { opacity:1; pointer-events:all; }
.bs-cart-drawer { position:fixed; top:0; right:0; bottom:0; width:340px; max-width:93vw; background:var(--bs-white); z-index:9991; display:flex; flex-direction:column; box-shadow:-4px 0 24px rgba(0,0,0,.14); transform:translateX(100%); transition:transform .26s cubic-bezier(.4,0,.2,1); }
.bs-cart-drawer.open { transform:translateX(0); }
.bs-cart-drawer-header { flex:0 0 auto; display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--bs-border); }
.bs-cart-drawer-header h3 { font-size:15px; font-weight:700; color:var(--bs-text); margin:0; font-family:var(--bs-font); }
.bs-cart-close { width:30px; height:30px; border-radius:50%; border:none; background:var(--bs-bg); color:var(--bs-muted); font-size:17px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.bs-cart-close:hover { background:var(--bs-border); }
.bs-cart-drawer-body { flex:1 1 auto; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:10px 14px; min-height:0; }
.bs-cart-drawer-footer { flex:0 0 auto; padding:12px 16px 20px; border-top:2px solid var(--bs-border); background:var(--bs-white); display:flex; flex-direction:column; gap:7px; }
.bs-cart-total-row { display:flex; justify-content:space-between; align-items:center; font-size:13px; padding-bottom:10px; border-bottom:1px solid var(--bs-border); font-family:var(--bs-font); }
.bs-cart-total-row strong { font-size:17px; color:var(--bs-primary); }
#bs-go-checkout { padding:13px; font-size:14px; font-weight:700; border-radius:var(--bs-radius); }
#bs-continue-shopping { padding:9px; font-size:13px; background:var(--bs-bg) !important; border-color:var(--bs-border) !important; color:var(--bs-text) !important; }
.bs-cart-items { display:flex; flex-direction:column; }
.bs-cart-row { display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid var(--bs-border); }
.bs-cart-row:last-child { border-bottom:none; }
.bs-cart-item-img { width:56px; height:56px; flex-shrink:0; object-fit:cover; border-radius:var(--bs-radius-sm); border:1px solid var(--bs-border); }
.bs-cart-item-info { flex:1; min-width:0; }
.bs-cart-item-name  { font-size:12px; font-weight:600; margin-bottom:2px; line-height:1.3; color:var(--bs-text); }
.bs-cart-item-price { font-size:12px; font-weight:700; color:var(--bs-primary); margin-bottom:5px; }
.bs-cart-qty-ctrl { display:flex; align-items:center; gap:5px; }
.bs-cart-qty-minus,.bs-cart-qty-plus { width:24px; height:24px; border-radius:50%; border:1.5px solid var(--bs-border); background:var(--bs-white); cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; transition:all .15s; }
.bs-cart-qty-minus:hover,.bs-cart-qty-plus:hover { background:var(--bs-primary); border-color:var(--bs-primary); color:#fff; }
.bs-cart-qty-val { font-size:13px; font-weight:700; min-width:18px; text-align:center; }
.bs-cart-remove { background:none; border:none; color:var(--bs-muted); cursor:pointer; font-size:16px; width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all .15s; flex-shrink:0; }
.bs-cart-remove:hover { background:#fee2e2; color:var(--bs-red); }
.bs-cart-empty { text-align:center; padding:40px 16px; color:var(--bs-muted); font-size:14px; font-family:var(--bs-font); }
.bs-loading { text-align:center; padding:28px; color:var(--bs-muted); font-size:13px; }

/* ================================================================
   PRODUCT SINGLE — Mobile satu kolum, Desktop dua kolum
   ================================================================ */
.bs-product-single { background:var(--bs-bg); font-family:var(--bs-font); }
.bs-breadcrumb { padding:9px 14px; font-size:12px; color:var(--bs-muted); background:var(--bs-white); border-bottom:1px solid var(--bs-border); }
.bs-breadcrumb a { color:var(--bs-primary); text-decoration:none !important; }

/* MOBILE — paksa block satu kolum */
div.bs-product-single-grid { display:block !important; float:none !important; }
div.bs-product-gallery { display:block !important; width:100% !important; float:none !important; }
div.bs-product-details { display:block !important; width:100% !important; float:none !important; }

.bs-gallery-main { width:100% !important; aspect-ratio:1/1; overflow:hidden; background:#f0f0f0; display:block !important; }
.bs-gallery-main img,.bs-main-img { width:100% !important; height:100% !important; object-fit:cover; display:block !important; }
.bs-gallery-main .bs-video-embed { width:100%; height:100%; display:block; }
.bs-gallery-main .bs-video-embed iframe { width:100%; height:100%; border:none; display:block; }
.bs-gallery-thumbs { display:flex !important; gap:8px; padding:8px 14px; overflow-x:auto; background:var(--bs-white); border-bottom:1px solid var(--bs-border); scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.bs-gallery-thumbs::-webkit-scrollbar { display:none; }
.bs-thumb-item { width:52px; height:52px; flex-shrink:0; border-radius:var(--bs-radius-sm); overflow:hidden; cursor:pointer; border:2px solid transparent; transition:border-color .15s; }
.bs-thumb-item.active,.bs-thumb-item:hover { border-color:var(--bs-primary); }
.bs-thumb-item img { width:100%; height:100%; object-fit:cover; }
.bs-video-thumb-sm { width:100%; height:100%; background:#1a1a2e; color:#fff; display:flex; align-items:center; justify-content:center; font-size:18px; }

div.bs-product-details { background:var(--bs-white) !important; padding:16px 14px !important; padding-bottom:90px !important; }
.bs-product-cat-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:var(--bs-primary); margin-bottom:4px; }
.bs-product-title { font-size:19px; font-weight:800; line-height:1.3; color:var(--bs-text); margin-bottom:8px; font-family:var(--bs-font); }
.bs-price-original { font-size:12px; color:var(--bs-muted); text-decoration:line-through; display:block; margin-bottom:1px; }
.bs-price-main { font-size:26px; font-weight:900; color:var(--bs-primary); line-height:1; margin-bottom:10px; }
.bs-stock-status { display:inline-block; font-size:12px; font-weight:700; padding:4px 10px; border-radius:5px; margin-bottom:12px; }
.bs-stock-status.in-stock    { color:#065f46; background:#d1fae5; }
.bs-stock-status.out-of-stock { color:#991b1b; background:#fee2e2; }
.bs-product-short-desc { font-size:14px; line-height:1.7; color:var(--bs-muted); margin-bottom:14px; padding-bottom:12px; border-bottom:1px solid var(--bs-border); }
.bs-qty-section { display:flex !important; align-items:center; gap:10px; margin-bottom:12px; }
.bs-qty-section label { font-size:13px; font-weight:600; color:var(--bs-text); white-space:nowrap; font-family:var(--bs-font); }
.bs-qty-input { display:flex !important; align-items:center; border:2px solid var(--bs-border); border-radius:var(--bs-radius-sm); overflow:hidden; }
.bs-qty-minus,.bs-qty-plus { width:40px; height:40px; border:none; background:var(--bs-bg); cursor:pointer; font-size:20px; color:var(--bs-text); display:flex !important; align-items:center; justify-content:center; transition:background .15s; flex-shrink:0; }
.bs-qty-minus:hover,.bs-qty-plus:hover { background:var(--bs-primary); color:#fff; }
#bs-qty { width:46px; text-align:center; border:none; border-left:1px solid var(--bs-border); border-right:1px solid var(--bs-border); font-size:15px; font-weight:700; padding:8px 4px; font-family:var(--bs-font); -moz-appearance:textfield; }
#bs-qty::-webkit-outer-spin-button,#bs-qty::-webkit-inner-spin-button { -webkit-appearance:none; }

/* Sticky CTA — MOBILE sahaja */
div.bs-product-cta-sticky {
  position:fixed !important;
  bottom:0 !important; left:0 !important; right:0 !important;
  z-index:500; background:var(--bs-white);
  border-top:1px solid var(--bs-border);
  box-shadow:0 -3px 12px rgba(0,0,0,.1);
  padding:10px 12px;
  display:flex !important; gap:8px;
}
div.bs-product-cta-sticky .bs-btn { flex:1; padding:13px 8px !important; font-size:13px !important; justify-content:center; }
div.bs-product-cta-desktop { display:none !important; }

.bs-product-meta { display:flex; gap:7px; flex-wrap:wrap; font-size:12px; color:var(--bs-muted); border-top:1px solid var(--bs-border); padding-top:10px; margin-top:8px; }
.bs-product-meta span { background:var(--bs-bg); padding:3px 8px; border-radius:4px; }
.bs-product-description { background:var(--bs-white); margin-top:8px; padding:16px 14px; border-top:6px solid var(--bs-bg); }
.bs-product-description h2 { font-size:15px; font-weight:700; margin-bottom:10px; font-family:var(--bs-font); color:var(--bs-text) !important; }
.bs-product-description { color:var(--bs-text) !important; }
.bs-desc-content { font-size:14px; line-height:1.8; font-family:var(--bs-font); color:var(--bs-text) !important; }
/* Paksa warna teks dalam description — override tema WordPress */
.bs-desc-content *,
.bs-desc-content p,
.bs-desc-content li,
.bs-desc-content span,
.bs-desc-content strong,
.bs-desc-content em,
.bs-desc-content h1,
.bs-desc-content h2,
.bs-desc-content h3,
.bs-desc-content h4 { color:var(--bs-text) !important; }
.bs-desc-content a { color:var(--bs-primary) !important; }
/* Penerangan ringkas juga */
.bs-product-short-desc,
.bs-product-short-desc * { color:var(--bs-muted) !important; }
/* Product details panel — paksa background putih & teks gelap */
div.bs-product-details,
div.bs-product-details p,
div.bs-product-details span,
div.bs-product-details li { color:var(--bs-text) !important; }
div.bs-product-details .bs-price-main { color:var(--bs-primary) !important; }
div.bs-product-details .bs-price-original { color:var(--bs-muted) !important; }
div.bs-product-details .bs-product-cat-label { color:var(--bs-primary) !important; }

/* Desktop 768+ */
@media screen and (min-width:768px) {
  .bs-product-single { padding:20px 16px; }
  div.bs-product-single-grid { display:flex !important; gap:24px; align-items:flex-start; max-width:1080px; margin:0 auto; }
  div.bs-product-gallery { width:46% !important; flex-shrink:0 !important; position:sticky; top:20px; background:var(--bs-white); border:1px solid var(--bs-border); border-radius:var(--bs-radius); overflow:hidden; box-shadow:var(--bs-shadow); }
  .bs-gallery-main { border-radius:var(--bs-radius) var(--bs-radius) 0 0 !important; }
  .bs-gallery-thumbs { border-bottom:none; }
  div.bs-product-details { flex:1 !important; min-width:0 !important; padding:22px !important; padding-bottom:22px !important; background:var(--bs-white) !important; border:1px solid var(--bs-border); border-radius:var(--bs-radius); box-shadow:var(--bs-shadow); }
  .bs-product-title { font-size:23px; }
  .bs-price-main { font-size:30px; }
  div.bs-product-cta-sticky  { display:none !important; }
  div.bs-product-cta-desktop { display:flex !important; gap:10px; margin-bottom:14px; }
  div.bs-product-cta-desktop .bs-btn { flex:1; }
  .bs-product-description { max-width:1080px; margin:16px auto 0; border-radius:var(--bs-radius); border:1px solid var(--bs-border); box-shadow:var(--bs-shadow); padding:22px; }
  .bs-breadcrumb { padding:10px 0; background:transparent !important; border:none !important; max-width:1080px; margin:0 auto; }
}

/* ================================================================
   CHECKOUT — Mobile: ringkasan atas, form bawah, bayar sticky
   Desktop: form kiri, ringkasan kanan
   ================================================================ */
div.bs-checkout-page {
  background:var(--bs-bg) !important;
  min-height:100vh !important;
  font-family:var(--bs-font) !important;
  display:block !important;
}
div.bs-checkout-container {
  max-width:940px !important;
  margin:0 auto !important;
  padding:0 !important;
  width:100% !important;
  display:block !important;
}
div.bs-checkout-page h1.bs-checkout-title {
  display:block !important;
  font-size:22px !important; font-weight:800 !important;
  padding:24px 0 8px 0 !important; margin:0 0 16px 0 !important;
  background:transparent !important;
  border:none !important;
  color:var(--bs-text) !important; font-family:var(--bs-font) !important;
}

/* MOBILE: flex kolum, ringkasan dulu (order:1), form kemudian (order:2) */
div.bs-checkout-grid {
  display:flex !important;
  flex-direction:column !important;
  width:100% !important;
  max-width:100% !important;
  float:none !important;
  gap:0 !important;
}
div.bs-order-summary {
  order:1 !important;
  width:100% !important;
  max-width:100% !important;
  float:none !important;
  flex:none !important;
  position:static !important;
}
div.bs-checkout-form {
  order:2 !important;
  width:100% !important;
  max-width:100% !important;
  float:none !important;
  flex:none !important;
  position:static !important;
}

div.bs-checkout-page div.bs-card {
  display:block !important;
  background:var(--bs-white) !important;
  padding:16px 14px !important;
  margin:0 0 6px 0 !important;
  border:none !important;
  border-bottom:1px solid var(--bs-border) !important;
  border-radius:0 !important;
  box-shadow:none !important;
  width:100% !important;
  float:none !important;
}
div.bs-checkout-page div.bs-card h2 {
  display:block !important;
  font-size:13px !important; font-weight:700 !important;
  margin:0 0 14px 0 !important; padding:0 !important;
  color:var(--bs-text) !important; font-family:var(--bs-font) !important;
  line-height:1.3 !important;
}
div.bs-checkout-page .bs-field { margin-bottom:12px !important; display:block !important; }
div.bs-checkout-page .bs-field label {
  display:block !important;
  font-size:13px !important; font-weight:600 !important;
  margin:0 0 6px 0 !important; padding:0 !important;
  color:var(--bs-text) !important; font-family:var(--bs-font) !important;
  text-transform:none !important; letter-spacing:0 !important;
  line-height:1.3 !important;
}
div.bs-checkout-page .bs-field small { display:block !important; font-size:11px !important; color:var(--bs-muted) !important; margin-top:3px !important; }
div.bs-checkout-page input.bs-input-full,
div.bs-checkout-page select.bs-input-full,
div.bs-checkout-page textarea.bs-input-full {
  display:block !important;
  width:100% !important; padding:11px 12px !important;
  border:1.5px solid var(--bs-border) !important;
  border-radius:var(--bs-radius-sm) !important;
  font-size:15px !important; font-family:var(--bs-font) !important;
  color:var(--bs-text) !important; background:var(--bs-white) !important;
  outline:none !important; -webkit-appearance:none !important;
  appearance:none !important; box-sizing:border-box !important; margin:0 !important;
}
div.bs-checkout-page input.bs-input-full:focus,
div.bs-checkout-page select.bs-input-full:focus,
div.bs-checkout-page textarea.bs-input-full:focus { border-color:var(--bs-primary) !important; }
div.bs-checkout-page textarea.bs-input-full { resize:vertical !important; min-height:68px !important; }
div.bs-checkout-page .bs-field-row { display:grid !important; grid-template-columns:1fr 1fr !important; gap:10px !important; }

/* Shipping */
.bs-shipping-calc { padding-top:12px; margin-top:12px; border-top:1px dashed var(--bs-border); }
#bs-calc-shipping { width:100%; padding:11px; }
.bs-shipping-result { margin-top:10px; background:#f0fdf4; border:1px solid #bbf7d0; border-radius:var(--bs-radius-sm); padding:11px; }
.bs-shipping-detail { font-size:12px; margin-bottom:7px; font-family:var(--bs-font); }
.bs-fee-row { display:flex; justify-content:space-between; font-size:12px; padding:2px 0; }
.bs-fee-total { border-top:1px solid #bbf7d0; padding-top:5px; margin-top:4px; font-weight:700; }
.bs-error-msg { color:var(--bs-red); font-size:13px; margin-top:8px; padding:8px 12px; background:#fee2e2; border-radius:var(--bs-radius-sm); }

/* Bayar button */

#bs-place-order { padding:14px !important; font-size:15px !important; font-weight:800 !important; border-radius:var(--bs-radius) !important; font-family:var(--bs-font) !important; }
.bs-secure-note { text-align:center; font-size:11px; color:var(--bs-muted); margin-top:6px; font-family:var(--bs-font); }

/* Order summary items */
.bs-order-items { margin-bottom:12px; display:block !important; }
.bs-order-item { display:flex !important; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--bs-border); }
.bs-order-item:last-child { border-bottom:none; }
.bs-order-item-img { width:46px; height:46px; flex-shrink:0; object-fit:cover; border-radius:var(--bs-radius-sm); border:1px solid var(--bs-border); }
.bs-order-item-info { flex:1; min-width:0; }
.bs-order-item-name  { font-size:12px; font-weight:600; line-height:1.3; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; color:var(--bs-text); }
.bs-order-item-qty   { font-size:11px; color:var(--bs-muted); display:block; }
.bs-order-item-price { font-size:13px; font-weight:700; color:var(--bs-primary); flex-shrink:0; }
.bs-order-totals { border-top:2px solid var(--bs-border); padding-top:10px; margin-bottom:12px; }
#bs-shipping-row { display:none; } /* hidden until user checks shipping */
.bs-total-row { display:flex !important; justify-content:space-between; font-size:13px; padding:3px 0; font-family:var(--bs-font); }
.bs-grand-total { font-size:16px; border-top:2px solid var(--bs-border); padding-top:8px; margin-top:4px; }

/* Desktop checkout extra overrides */
@media screen and (min-width:768px) {
  div.bs-checkout-page { padding:24px 24px !important; }
  div.bs-checkout-page h1.bs-checkout-title { padding:0 0 8px 0 !important; margin:0 0 20px 0 !important; }
  div.bs-checkout-page div.bs-card { border-radius:var(--bs-radius) !important; border:1px solid var(--bs-border) !important; margin-bottom:14px !important; padding:22px 24px !important; }

  /* Desktop: sorok sepenuhnya pay bar mobile */
  .bs-checkout-pay-bar { display:none !important; }
  .bs-secure-note { text-align:left !important; margin-top:8px !important; }
  div.bs-checkout-grid {
    flex-direction:row !important;
    gap:20px !important;
    align-items:flex-start !important;
  }
  div.bs-order-summary {
    order:2 !important;
    width:320px !important;
    max-width:320px !important;
    flex-shrink:0 !important;
    position:sticky !important;
    top:20px !important;
  }
  div.bs-checkout-form {
    order:1 !important;
    flex:1 !important;
    width:auto !important;
    max-width:none !important;
  }
}

/* Desktop inline place order button */
.bs-place-order-desktop { display:none; margin-top:4px; }
@media screen and (min-width:768px) {
  .bs-place-order-desktop { display:block !important; }
  .bs-place-order-desktop .bs-btn { padding:15px !important; font-size:15px !important; font-weight:800 !important; border-radius:var(--bs-radius) !important; }
}

/* ================================================================
   THANK YOU
   ================================================================ */
.bs-thankyou-page { min-height:100vh; background:var(--bs-bg); display:flex; align-items:center; justify-content:center; padding:24px 16px; font-family:var(--bs-font); }
.bs-thankyou-container { max-width:500px; width:100%; }
.bs-thankyou-success,.bs-thankyou-pending,.bs-thankyou-error { background:var(--bs-white); border-radius:var(--bs-radius); padding:30px 20px; text-align:center; box-shadow:var(--bs-shadow-lg); border:1px solid var(--bs-border); }
.bs-thankyou-icon { font-size:50px; margin-bottom:10px; }
.bs-thankyou-success h1 { color:var(--bs-green); font-size:20px; margin-bottom:6px; font-family:var(--bs-font); }
.bs-thankyou-pending h1 { color:#d97706; font-size:20px; margin-bottom:6px; font-family:var(--bs-font); }
.bs-thankyou-error h1   { color:var(--bs-red); font-size:20px; margin-bottom:6px; font-family:var(--bs-font); }
.bs-thankyou-msg { font-size:14px; color:var(--bs-muted); margin-bottom:16px; }
.bs-order-confirm-box { background:var(--bs-bg); border-radius:var(--bs-radius-sm); padding:14px; margin:14px 0; text-align:left; }
.bs-order-confirm-box h3 { font-size:13px; font-weight:700; margin-bottom:8px; font-family:var(--bs-font); }
.bs-order-confirm-detail { display:flex; flex-direction:column; gap:6px; }
.bs-order-confirm-detail div { display:flex; justify-content:space-between; font-size:13px; gap:8px; }
.bs-order-confirm-detail div strong { text-align:right; word-break:break-all; }
.bs-email-notice { font-size:13px; color:var(--bs-muted); margin:12px 0; }

/* ── Checkout: satu butang dalam form, mobile total bar ── */

/* Wrap butang dalam form */
.bs-pay-wrap {
  padding:14px 14px 24px;
  background:var(--bs-white);
}
@media screen and (min-width:768px) {
  .bs-pay-wrap { padding:0; background:transparent; margin-top:8px; }
}

/* Butang bayar */
.bs-btn-pay {
  padding:15px !important;
  font-size:15px !important;
  font-weight:800 !important;
  border-radius:var(--bs-radius) !important;
  font-family:var(--bs-font) !important;
  letter-spacing:.2px;
}

.bs-secure-note {
  text-align:center;
  font-size:11px;
  color:var(--bs-muted);
  margin-top:6px;
  font-family:var(--bs-font);
}

/* Mobile total bar — tunjuk jumlah, push butang ke atas */
.bs-mobile-total-bar {
  display:none;
}
@media screen and (max-width:767px) {
  /* Beri ruang bawah supaya butang tidak tersembunyi */
  .bs-checkout-container { padding-bottom:90px !important; }
  .bs-pay-wrap {
    position:fixed !important;
    bottom:0 !important; left:0 !important; right:0 !important;
    width:100% !important;
    z-index:300;
    padding:12px 16px 16px !important;
    border-top:2px solid var(--bs-border) !important;
    box-shadow:0 -4px 16px rgba(0,0,0,.1) !important;
    background:var(--bs-white) !important;
    box-sizing:border-box !important;
  }
  .bs-pay-wrap .bs-btn-pay {
    width:100% !important;
    display:flex !important;
    justify-content:center !important;
  }
}
/* Extra bottom padding on page to prevent content hidden behind pay bar */
div.bs-checkout-page div.bs-checkout-container {
  padding-bottom:140px !important;
}

/* Desktop — pay bar jadi inline dalam form */
@media screen and (min-width:768px) {
  .bs-checkout-pay-bar {
    position:static !important;
    border:none !important;
    box-shadow:none !important;
    background:transparent !important;
    padding:0 !important;
    margin-top:8px;
  }
  .bs-checkout-pay-total { display:none !important; } /* desktop ada dalam summary */
  div.bs-checkout-page div.bs-checkout-container { padding-bottom:0 !important; }
  div.bs-checkout-grid {
    flex-direction:row !important;
    gap:16px !important;
    align-items:flex-start !important;
  }
  div.bs-order-summary {
    order:2 !important;
    width:300px !important;
    max-width:300px !important;
    flex-shrink:0 !important;
    position:sticky !important;
    top:16px !important;
  }
  div.bs-checkout-form {
    order:1 !important;
    flex:1 !important;
    width:auto !important;
    max-width:none !important;
  }
}

/* ================================================================
   TOAST
   ================================================================ */
.bs-toast { position:fixed; bottom:-70px; left:50%; transform:translateX(-50%); background:#1a202c; color:#fff; padding:10px 20px; border-radius:999px; font-size:13px; font-weight:600; z-index:99999; transition:bottom .26s ease; white-space:nowrap; box-shadow:var(--bs-shadow-lg); max-width:calc(100vw - 32px); text-align:center; font-family:var(--bs-font); }
.bs-toast.show { bottom:20px; }
.bs-toast.bs-toast-success { background:var(--bs-green); }
.bs-toast.bs-toast-error   { background:var(--bs-red); }
