:root{
  --brand-bg: var(--bg);
  --brand-text: var(--text);
  --brand-accent: var(--primary);
  --brand-success: var(--success);
  --brand-danger: var(--danger);
  --brand-warning: var(--accent);
  --muted: var(--muted);
  --border: var(--border);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;color:var(--brand-text);font-family:var(--font-sans);background:var(--brand-bg)}
h1{font-family:var(--font-sans);margin:var(--space-6) 0 var(--space-4);font-size:var(--font-size-600)}
main.container{width:100%;max-width:1120px;margin:0 auto;padding:0 var(--space-4)}

.site-header,.site-footer{background:var(--surface);border-bottom:1px solid var(--border)}
.site-footer{border-top:1px solid var(--border);border-bottom:0;margin-top:calc(var(--space-6)*2)}
.site-header .container,.site-footer .container{display:flex;align-items:center;justify-content:space-between;height:calc(var(--space-10)*1.5)}
.brand{font-weight:700;text-decoration:none;color:var(--brand-text)}
.brand-mark{display:inline-block;background:var(--brand-accent);color:var(--primary-contrast);border-radius:var(--radius-md);padding:calc(var(--space-1)/2) var(--space-2);margin-right:var(--space-2)}
.nav a{color:var(--brand-text);text-decoration:none;margin-left:var(--space-4);opacity:.85}
.nav a.active,.nav a:hover{opacity:1}

.cart-layout{display:grid;gap:var(--space-6)}
.cart-items{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.cart-head{display:grid;grid-template-columns:minmax(0,1fr) 120px 160px 120px 24px;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);font-weight:600;color:var(--text)}
.cart-rows{display:block}
.row{display:grid;grid-template-columns:minmax(0,1fr) 120px 160px 120px 24px;gap:var(--space-3);align-items:center;padding:var(--space-4);border-bottom:1px solid var(--border)}
.row:last-child{border-bottom:0}
.item{display:flex;gap:var(--space-3);align-items:flex-start}
.thumb{width:64px;height:64px;border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--border);background:var(--surface)}
.info{min-width:0}
.title{font-weight:600;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}
.meta{color:var(--muted);font-size:var(--font-size-100);margin-top:calc(var(--space-1)/2);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}
.price,.line-total{font-weight:600;white-space:nowrap}
.hide-sm{display:block}

.qty{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}
.qty button{all:unset;cursor:pointer;padding:calc(var(--space-3)/2) var(--space-3);line-height:1}
.qty input{width:40px;text-align:center;border:0;border-left:1px solid var(--border);border-right:1px solid var(--border);padding:calc(var(--space-3)/2) 0}
.remove{cursor:pointer;color:var(--muted);font-size:var(--font-size-500)}
.remove:hover{color:var(--text)}

.cart-summary .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);position:sticky;top:var(--space-4)}
.summary-line{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px dashed var(--border)}
.summary-line:last-child{border-bottom:0}
.coupon-block{padding:var(--space-2) 0}
.coupon-row{display:flex;gap:var(--space-2);margin-top:var(--space-2)}
.coupon-row input{flex:1;padding:calc(var(--space-3) - var(--space-1)/2);border:1px solid var(--border);border-radius:var(--radius-md)}
.coupon-msg{font-size:var(--font-size-100);color:var(--muted);margin-top:var(--space-2)}
.grand-total{display:flex;justify-content:space-between;align-items:center;margin:var(--space-3) 0 var(--space-3)}
.grand-amount{font-size:var(--font-size-600);font-weight:700}

.free-ship{margin:var(--space-2) 0 var(--space-4)}
.fs-msg{font-size:var(--font-size-100);color:var(--muted);margin-bottom:var(--space-2)}
.progress{height:var(--space-2);background:var(--border);border-radius:999px;overflow:hidden}
.progress-bar{height:100%;background:var(--brand-success);width:0%}

.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid transparent;padding:var(--space-3) var(--space-4);font-weight:600;cursor:pointer;user-select:none;text-decoration:none}
.btn-primary{background:var(--brand-accent);color:var(--primary-contrast);border-color:var(--brand-accent)}
.btn-primary:hover{filter:brightness(.95)}
.btn-outline{background:var(--bg);border-color:var(--brand-accent);color:var(--brand-accent)}
.btn-lg{padding:calc(var(--space-4) - var(--space-1)/2) var(--space-5);font-size:var(--font-size-300)}
.w-100{width:100%}
.hidden{display:none}

.empty{padding:var(--space-6);text-align:center}

@media (min-width:992px){
  .cart-layout{grid-template-columns:2fr 1fr;align-items:flex-start}
  .cart-items{max-height:70vh;overflow-y:auto}
}

@media (max-width:991px){
  .cart-head{grid-template-columns:minmax(0,1fr) 100px 140px 100px 24px}
  .row{grid-template-columns:minmax(0,1fr) 100px 140px 100px 24px}
  .hide-sm{display:none}
}
@media (max-width:575px){
  .cart-head{display:none}
  .row{grid-template-columns:minmax(0,1fr) 80px 120px 80px 24px;padding:var(--space-3)}
  .thumb{width:48px;height:48px}
  .qty button{padding:calc(var(--space-3)/2) var(--space-2)}
  .qty input{width:32px}
}

.cart{ display:grid; gap:var(--space-6); grid-template-columns:1fr; }
.cart > *{ width:100%; }
@media(min-width:992px){ .cart{ grid-template-columns: 2fr 1fr; } }

.cart-line{ display:grid; grid-template-columns: 88px 1fr auto; gap:12px; padding:12px; border:1px solid var(--border);
  border-radius: var(--radius); background:#fff; align-items:center; }
.cart-line + .cart-line{ margin-top:12px; }
.cart-line__img img{ width:72px; height:72px; object-fit:cover; border-radius:10px; border:1px solid var(--border); }
.cart-line__title{ font-weight:600; margin:0; }
.cart-line__meta{ color:var(--muted); font-size:13px; }
.cart-line__qty{ display:flex; align-items:center; gap:8px; }
.cart-line__qty input{ width:56px; text-align:center; }
.cart-line__total{ font-weight:700; }

.cart-summary{ position:sticky; top:80px; border:1px solid var(--border); border-radius:var(--radius); padding:16px; background:#fff; }
.cart-summary .row{ display:flex; justify-content:space-between; margin:6px 0; }
.cart-summary .row.total{ font-weight:700; }
.cart-empty{ text-align:center; padding:40px 0; color:var(--muted); }

/* === UX fixes appended === */

/* Cart lines layout */
.cart-lines{ display:flex; flex-direction:column; gap: var(--space-3); }
.cart-line{ display:grid; grid-template-columns: 88px 1fr auto; gap: var(--space-3); align-items:center; padding: var(--space-3); background: var(--surface); border:1px solid var(--border); border-radius:12px; }
.cart-line__img img{ width:88px; height:88px; border-radius:10px; object-fit:cover; }
.cart-line__title{ margin:0 0 2px; font-weight:600; color: var(--text); }
.cart-line__meta{ margin:0 0 8px; color: var(--muted); font-size: var(--font-size-100); }
.cart-line__qty{ display:flex; align-items:center; gap: 6px; }
.cart-line__qty input[type="number"]{ width:72px; text-align:center; }
.cart-line__total{ font-weight:700; font-size: var(--font-size-400); }

.cart-empty{ padding: var(--space-4); background: var(--surface); border:1px solid var(--border); border-radius:12px; }

/* Summary card polish */
.cart-summary .card{ border-radius:12px; border:1px solid var(--border); background: var(--surface); }
.summary-line{ display:flex; justify-content:space-between; align-items:center; padding: 8px 0; }
.grand-total{ border-top:1px solid var(--border); padding-top: var(--space-3); }

/* Responsive */
@media (max-width: 768px){
  .cart-line{ grid-template-columns: 64px 1fr; }
  .cart-line__total{ justify-self:end; grid-column: 2; }
}


/* === CART REDESIGN (opinionated) === */
.cart-wrap{ display:grid; grid-template-columns: 1fr 360px; gap: var(--space-6); align-items:start; }
@media (max-width: 980px){ .cart-wrap{ grid-template-columns: 1fr; } }

.cart-lines{ display:flex; flex-direction:column; gap: var(--space-3); }

.cart-line{
  display:grid;
  grid-template-columns: 96px 1fr auto;
  gap: var(--space-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: var(--space-3);
  align-items:center;
}
.cart-line__img img{ width:96px; height:96px; border-radius: 10px; object-fit: cover; display:block; }
.cart-line__title{ margin:0 0 4px; font-weight:700; color: var(--text); }
.cart-line__meta{ margin:0 0 8px; color: var(--muted); font-size: var(--font-size-100); }
.cart-line__qty{ display:flex; align-items:center; gap: 8px; }
.cart-line__qty .btn{ min-width:34px; height:34px; padding:0; }
.cart-line__qty input[type="number"]{ width:72px; text-align:center; height:34px; }
.cart-line__total{ font-weight:700; font-size: 18px; }

.cart-empty{ padding: var(--space-5); text-align:center; background: var(--surface); border:1px solid var(--border); border-radius: 14px; }

.cart-summary .card{
  background: var(--surface);
  border:1px solid var(--border);
  border-radius: 14px;
  padding: var(--space-4);
  position: sticky;
  top: var(--space-6);
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
}

.summary-title{ font-size:16px; font-weight:700; margin-bottom: var(--space-2); }
.summary-line{ display:flex; justify-content:space-between; padding: 8px 0; color: var(--text); }
.summary-line small{ color: var(--muted); }
.grand-total{ border-top:1px dashed var(--border); margin-top: 10px; padding-top: 10px; display:flex; justify-content:space-between; align-items:center; }
.grand-amount{ font-size: 20px; font-weight:800; }

.coupon-row input{ border-radius: 10px; }
.coupon-row .btn{ min-height:40px; }

.checkout-block .btn-primary{ background: var(--primary); border-color: var(--primary); }
.checkout-block .btn-primary:hover{ filter: brightness(.95); }
.checkout-notes{ padding-top: 8px; font-size: 13px; color: var(--muted); }

/* Mobile collapse */
@media (max-width: 768px){
  .cart-line{ grid-template-columns: 64px 1fr; }
  .cart-line__total{ grid-column: 2; justify-self:end; }
}


/* === Fix: stop global sticky cards causing overlap === */
.card{ position: static !important; top: auto !important; }
.cart-summary .card{ position: sticky !important; top: var(--space-6) !important; }


/* Only the summary card is sticky */
.cart-summary .summary-card{ position: sticky; top: var(--space-6); }
.cart-summary .pm-section.card{ position: static; }


/* === FINAL STICKY SCOPE PATCH === */
.cart-summary .pm-section.card{ position: static !important; top:auto !important; }
.cart-summary .summary-card{ position: sticky !important; top: var(--space-6) !important;  }
/* On narrow screens, disable sticky entirely */
@media (max-width: 900px){
  .cart-summary .summary-card{ position: static !important; top:auto !important; }
}



/* Ensure spacing between blocks in the aside column */
.cart-summary > * + *{ margin-top: var(--space-4); }


/* === Cart Page UI/UX Refinements === */

/* Header separation */
.annc{ margin-bottom: 4px; }
.bnz-header{ border-bottom:1px solid var(--border); }

/* Cart item card layout */
.cart-line, .cart-item, .cart-product{
  display:grid;
  grid-template-columns: 80px 1fr auto;
  gap: var(--space-3);
  align-items:center;
}
.cart-line img{ max-width:72px; border-radius:8px; }
.cart-line .product-name{ font-weight:500; margin-bottom:4px; }
.cart-line .qty-controls{ display:flex; align-items:center; gap:6px; }
.cart-line .remove-link{ display:block; font-size:13px; color:var(--danger); margin-top:4px; }
.cart-line .price{ font-weight:600; text-align:right; }

/* Prevent middle column from stretching the drawer */
.cart-line__info{ min-width:0; }

/* Summary card readability */
.summary-card .row{ margin:10px 0; }
.summary-card .row span:last-child{ font-weight:600; }
.summary-card .total span{ font-size:18px; font-weight:700; }

/* WhatsApp button spacing */
.whatsapp-float, .whatsapp-button{
  bottom:80px !important;
}

.cart-title{ font-weight:600; margin-bottom:4px; }

.cart-controls{ display:flex; align-items:center; gap:8px; }

.cart-remove{ color:var(--danger); text-decoration:none; font-size:14px; }
.cart-remove:hover{ text-decoration:underline; }

.cart-price{ font-weight:700; align-self:center; justify-self:end; }

@media (max-width: 480px){ .cart-line{ grid-template-columns:72px 1fr; } .cart-price{ grid-column:2; justify-self:start; margin-top:6px; } .cart-remove{ display:inline-block; margin-top:6px; } }

.cart-summary .row{ justify-content:space-between; gap:12px; margin:8px 0; }
.cart-summary .row.total{ font-weight:700; font-size:var(--font-size-500); }
