/* ══ CART.CSS — Rokola DJ App ══ */

/* ── CART DRAWER ──────────────────────────────────────── */
#cartDrawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: 360px; max-width: 95vw;
  background: var(--bg2); border-left: 1px solid var(--border);
  z-index: 250; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.28s cubic-bezier(0.32,0.72,0,1);
  box-shadow: -8px 0 32px rgba(0,0,0,0.5);
}
#cartDrawer.open { transform: translateX(0); }

/* Cart overlay (mobile tap-to-close backdrop) */
#cartOverlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,0.6); z-index: 249;
  backdrop-filter: blur(3px); opacity: 0;
  transition: opacity 0.28s ease; pointer-events: none;
}
#cartOverlay.open { opacity: 1; pointer-events: all; }

#cartHandle { display: none; } /* shown only mobile */
#cartHeader { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.1rem; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.cart-title { font-size: 0.9rem; font-weight: 600; color: var(--text-hi); }
.cart-close-btn {
  background: rgba(255,255,255,0.06); border: 1px solid var(--border);
  border-radius: 50%; color: var(--text-dim); cursor: pointer;
  width: 40px; height: 40px; font-size: 1.15rem;
  display: flex; align-items: center; justify-content: center;
  padding: 0; transition: all 0.12s; flex-shrink: 0;
}
.cart-close-btn:hover { border-color: var(--red); color: var(--red); background: rgba(220,60,60,0.08); }
#cartItems { flex: 1; overflow-y: auto; padding: 0.4rem 0; }
.cart-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; gap: 0.6rem; color: var(--text-dim); }
.cart-empty-icon { font-size: 2.2rem; opacity: 0.18; }
.cart-empty-txt { font-family: var(--mono); font-size: 0.72rem; }
.cart-item { display: flex; align-items: center; gap: 0.6rem; padding: 0.5rem 1.1rem; border-bottom: 1px solid var(--border2); transition: background 0.1s; animation: rowIn 0.15s ease; }
.cart-item:hover { background: var(--bg3); }
.cart-item-thumb { width: 40px; height: 40px; border-radius: 5px; overflow: hidden; background: var(--bg3); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 0.9rem; }
.cart-item-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cart-item-info { flex: 1; min-width: 0; }
.cart-item-title { font-size: 0.76rem; font-weight: 500; color: var(--text-hi); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cart-item-sub { font-family: var(--mono); font-size: 0.62rem; color: var(--amber); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cart-item-ext { font-family: var(--mono); font-size: 0.58rem; color: var(--text-dim); margin-top: 0.08rem; }
.cart-remove { background: none; border: none; color: var(--text-dim); cursor: pointer; font-size: 1rem; padding: 0.4rem; border-radius: 50%; transition: all 0.12s; flex-shrink: 0; min-width: 36px; min-height: 36px; display: flex; align-items: center; justify-content: center; }
.cart-remove:hover, .cart-remove:active { color: var(--red); background: rgba(240,80,80,0.12); }
#cartFooter { border-top: 1px solid var(--border); padding: 0.85rem 1.1rem; flex-shrink: 0; display: flex; flex-direction: column; gap: 0.55rem; padding-bottom: calc(0.85rem + env(safe-area-inset-bottom, 0px)); }
.cart-summary { font-family: var(--mono); font-size: 0.68rem; color: var(--text-dim); }
.cart-summary b { color: var(--text-hi); }
.cart-actions { display: flex; gap: 0.4rem; }
.cart-action-btn { flex: 1; padding: 0.5rem; border-radius: 8px; font-family: var(--mono); font-size: 0.68rem; font-weight: 500; cursor: pointer; transition: all 0.12s; border: 1px solid var(--border); text-align: center; }
.cart-action-btn.primary { background: var(--green); border-color: var(--green); color: #0c0c0e; }
.cart-action-btn.primary:hover { opacity: 0.88; }
.cart-action-btn.secondary { background: none; color: var(--text-dim); }
.cart-action-btn.secondary:hover { border-color: var(--text-dim); color: var(--text); }
.cart-action-btn.danger { background: none; color: var(--red); border-color: rgba(240,80,80,0.28); }
.cart-action-btn.danger:hover, .cart-action-btn.danger:active { background: rgba(240,80,80,0.1); }

/* ── CART: MOBILE BOTTOM SHEET ─────────────────────────── */
@media (max-width: 767px) {
  #cartDrawer {
    top: auto; left: 0; right: 0; bottom: 0;
    width: 100%; max-width: 100%; max-height: 88vh;
    border-left: none; border-top: 1px solid var(--border);
    border-radius: 16px 16px 0 0;
    transform: translateY(100%);
    box-shadow: 0 -8px 40px rgba(0,0,0,0.5);
  }
  #cartDrawer.open { transform: translateY(0); }
  #cartHandle {
    display: block; width: 36px; height: 4px; background: var(--border);
    border-radius: 2px; margin: 0.65rem auto 0; flex-shrink: 0;
  }
  #cartHeader { padding: 0.65rem 1rem 0.65rem; }
  .cart-title { font-size: 1rem; }
  .cart-close-btn { width: 44px; height: 44px; font-size: 1.25rem; }
  .cart-item { padding: 0.65rem 1rem; }
  .cart-item-title { font-size: 0.88rem; }
  .cart-item-sub   { font-size: 0.72rem; }
  #cartFooter { padding: 0.9rem 1rem calc(0.9rem + env(safe-area-inset-bottom, 0px)); }
  .cart-action-btn { padding: 0.7rem 0.5rem; font-size: 0.78rem; min-height: 44px; }
}

