/* =====================================================================
   CART.CSS — Cart Drawer Styles
   ===================================================================== */

   #cart-drawer-overlay {
    transition: opacity 0.4s cubic-bezier(0.32, 0, 0.26, 1),
                visibility 0s linear 0.4s;
    will-change: opacity;
  }
  
  #cart-drawer {
    transition: transform 0.4s cubic-bezier(0.32, 0, 0.26, 1);
    will-change: transform;
  }
  
  /* Khi đóng: visibility ẩn SAU KHI transform xong (delay 0.4s)
     → nội dung vẫn thấy được trong suốt animation trượt ra */
  #cart-drawer.translate-x-full {
    pointer-events: none !important;
    visibility: hidden;
    transition: transform 0.4s cubic-bezier(0.32, 0, 0.26, 1),
                visibility 0s linear 0.4s;
  }
  
  /* Khi mở: visibility hiện NGAY LẬP TỨC, transform bắt đầu slide vào */
  #cart-drawer:not(.translate-x-full) {
    pointer-events: auto;
    visibility: visible;
    transition: transform 0.4s cubic-bezier(0.32, 0, 0.26, 1),
                visibility 0s;
  }
  
  /* Custom Scrollbar for Cart Items */
  .cart-items-scroll::-webkit-scrollbar {
    width: 4px;
  }
  
  .cart-items-scroll::-webkit-scrollbar-track {
    background: transparent;
  }
  
  .cart-items-scroll::-webkit-scrollbar-thumb {
    background: rgba(28, 28, 28, 0.2);
    border-radius: 4px;
  }
  
  .cart-items-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(28, 28, 28, 0.4);
  }
  
  /* Custom Checkbox — specificity cao hơn Tailwind Forms plugin */
  input[type="checkbox"].cart-checkbox {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border: 1px solid rgba(28, 28, 28, 0.3);
    border-radius: 2px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    background-color: transparent;
    transition: all 0.2s;
    flex-shrink: 0;
    /* Reset các property Tailwind Forms hay override */
    color: inherit;
    accent-color: var(--ink, #1C1C1C);
    box-shadow: none;
    padding: 0;
  }
  
  input[type="checkbox"].cart-checkbox:checked {
    background-color: var(--ink, #1C1C1C);
    border-color: var(--ink, #1C1C1C);
  }
  
  input[type="checkbox"].cart-checkbox:checked::after {
    content: '';
    width: 5px;
    height: 10px;
    border: solid var(--cream, #F4EFE6);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    margin-bottom: 2px;
  }
  
  input[type="checkbox"].cart-checkbox:focus-visible {
    outline: 2px solid var(--ink, #1C1C1C);
    outline-offset: 2px;
  }
  
  input[type="checkbox"].cart-checkbox:focus {
    box-shadow: none;
    outline: none;
    border-color: rgba(28, 28, 28, 0.3);
  }
  
  /* Item styling */
  .cart-item {
    transition: opacity 0.3s ease;
  }
  
  .cart-item.removing {
    opacity: 0;
    pointer-events: none;
  }
  
  /* Quantity input hide arrows */
  .cart-qty-input::-webkit-outer-spin-button,
  .cart-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
  }
  
  .cart-qty-input[type=number] {-moz-appearance: textfield;
  }
  /* Khi đóng: delay visibility 0.4s để transition opacity chạy xong */
  #cart-drawer-overlay.opacity-0,
  #checkoutModalOverlay.opacity-0,
  #successModalOverlay.opacity-0,
  #zaloModalOverlay.opacity-0,
  #promo-overlay.opacity-0 {
    visibility: hidden;
    transition: opacity 0.4s cubic-bezier(0.32, 0, 0.26, 1),
                visibility 0s linear 0.4s;
  }
  
  /* Khi mở: visibility ngay lập tức, opacity transition */
  #cart-drawer-overlay:not(.opacity-0),
  #checkoutModalOverlay:not(.opacity-0),
  #successModalOverlay:not(.opacity-0),
  #zaloModalOverlay:not(.opacity-0),
  #promo-overlay:not(.opacity-0) {
    visibility: visible;
    transition: opacity 0.4s cubic-bezier(0.32, 0, 0.26, 1),
                visibility 0s;
  }