/* =========================================================
   AquariumLesson – Cart Panel "Woo-lite" (scoped)
   Works with Woo mini-cart markup inside #al-cart-panel
   ========================================================= */

:root{
  /* fallback tokens (use your existing if already defined) */
  --al-ink: #1f2a24;
  --al-muted: rgba(31,42,36,.72);
  --al-line: rgba(31,42,36,.12);
  --al-card: #ffffff;
  --al-soft: #f4f8f6;
  --al-shadow: 0 10px 30px rgba(0,0,0,.10);
  --al-radius: 14px;
  --al-radius-sm: 10px;

  --al-green: #2c6b4a;
  --al-green-2: #5CA892;
}

/* overlay */
#al-cart-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(2px);
  z-index: 9998;
}

/* drawer panel */
#al-cart-panel{
  position: fixed;
  top: 0;
  right: 0;
  height: 100dvh;
  width: min(420px, 92vw);
  background: var(--al-card);
  color: var(--al-ink);
  box-shadow: var(--al-shadow);
  z-index: 9999;

  display: flex;
  flex-direction: column;

  border-left: 1px solid var(--al-line);
}

/* mobile sheet */
@media (max-width: 767px){
  #al-cart-panel{
    top: auto;
    bottom: 0;
    right: 0;
    left: 0;
    width: auto;
    height: min(82dvh, 680px);
    border-left: 0;
    border-top: 1px solid var(--al-line);
    border-radius: 18px 18px 0 0;
  }
}

/* grip */
#al-cart-panel .al-sheet-grip{
  width: 46px;
  height: 5px;
  border-radius: 999px;
  background: rgba(31,42,36,.18);
  margin: 10px auto 0;
}

/* header */
#al-cart-panel .al-cart-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--al-line);
}

#al-cart-panel .al-cart-head h2{
  font-size: 16px;
  line-height: 1.2;
  margin: 0;
  font-weight: 700;
  letter-spacing: .2px;
}

#al-cart-panel .al-cart-close{
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid var(--al-line);
  background: #fff;
  color: var(--al-ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  line-height: 1;
}
#al-cart-panel .al-cart-close:hover{ background: var(--al-soft); }
#al-cart-panel .al-cart-close:active{ transform: translateY(1px); }

/* body */
#al-cart-panel .al-cart-body{
  padding: 14px 16px 16px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  flex: 1 1 auto;
}

/* empty state */
#al-cart-panel .al-cart-empty{
  padding: 16px;
  background: var(--al-soft);
  border: 1px solid var(--al-line);
  border-radius: var(--al-radius);
}
#al-cart-panel .al-cart-empty p{
  margin: 0 0 12px;
  color: var(--al-muted);
  font-size: 14px;
}

/* generic AL button inside panel (for your fallback HTML) */
#al-cart-panel .al-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  height: 42px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(44,107,74,.18);
  background: rgba(44,107,74,.10);
  color: var(--al-green);
  font-weight: 700;
  text-decoration: none;
}
#al-cart-panel .al-btn:hover{ background: rgba(44,107,74,.14); }

/* ---------------------------------------------------------
   Woo mini-cart core (scoped)
   --------------------------------------------------------- */

#al-cart-panel .woocommerce-mini-cart{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

#al-cart-panel .woocommerce-mini-cart-item{
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: 10px;
  align-items: center;

  padding: 10px;
  border: 1px solid var(--al-line);
  border-radius: var(--al-radius);
  background: #fff;
}

#al-cart-panel .woocommerce-mini-cart-item a{
  color: var(--al-ink);
  text-decoration: none;
}

/* thumb */
#al-cart-panel .woocommerce-mini-cart-item a img{
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--al-line);
  background: var(--al-soft);
}

/* product title link (Woo often puts title as an <a> without image too) */
#al-cart-panel .woocommerce-mini-cart-item a:not(:has(img)){
  font-weight: 700;
  font-size: 13.5px;
  line-height: 1.25;
}

/* meta: qty/price */
#al-cart-panel .woocommerce-mini-cart-item .quantity,
#al-cart-panel .woocommerce-mini-cart-item .amount{
  font-size: 12.5px;
  color: var(--al-muted);
}
#al-cart-panel .woocommerce-mini-cart-item .quantity{
  display: inline-flex;
  gap: 6px;
  align-items: baseline;
}

/* remove button */
#al-cart-panel .woocommerce-mini-cart-item .remove{
  width: 30px;
  height: 30px;
  border-radius: 10px;
  border: 1px solid var(--al-line);
  background: #fff;
  color: var(--al-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 18px;
  line-height: 1;
}
#al-cart-panel .woocommerce-mini-cart-item .remove:hover{
  background: var(--al-soft);
  color: var(--al-ink);
}

/* subtotal */
#al-cart-panel .woocommerce-mini-cart__total{
  display: flex;
  justify-content: space-between;
  align-items: center;

  margin: 14px 0 10px;
  padding: 12px 12px;
  border: 1px solid var(--al-line);
  border-radius: var(--al-radius);
  background: var(--al-soft);
}
#al-cart-panel .woocommerce-mini-cart__total strong{
  font-size: 13px;
}
#al-cart-panel .woocommerce-mini-cart__total .amount{
  font-weight: 800;
  color: var(--al-ink);
}

/* buttons row */
#al-cart-panel .woocommerce-mini-cart__buttons{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 0;
}

#al-cart-panel .woocommerce-mini-cart__buttons a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  padding: 0 14px;
  border-radius: 14px;
  font-weight: 800;
  text-decoration: none;
  border: 1px solid transparent;
  transition: transform .08s ease, background .12s ease, border-color .12s ease;
}

#al-cart-panel .woocommerce-mini-cart__buttons a:active{
  transform: translateY(1px);
}

/* View cart = secondary */
#al-cart-panel .woocommerce-mini-cart__buttons a.button.wc-forward:not(.checkout){
  background: #fff;
  color: var(--al-ink);
  border-color: var(--al-line);
}
#al-cart-panel .woocommerce-mini-cart__buttons a.button.wc-forward:not(.checkout):hover{
  background: var(--al-soft);
}

/* Checkout = primary */
#al-cart-panel .woocommerce-mini-cart__buttons a.checkout{
  background: var(--al-green);
  color: #fff;
  border-color: rgba(0,0,0,0);
}
#al-cart-panel .woocommerce-mini-cart__buttons a.checkout:hover{
  background: #255a3e; /* slightly darker green */
}

/* small details */
#al-cart-panel .woocommerce-mini-cart-item dl,
#al-cart-panel .woocommerce-mini-cart-item .variation{
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--al-muted);
}
#al-cart-panel .woocommerce-mini-cart-item dt{
  font-weight: 700;
  color: rgba(31,42,36,.70);
}
#al-cart-panel .woocommerce-mini-cart-item dd{
  margin: 0 0 4px;
}

/* make sure Woo default floats don't break */
#al-cart-panel .woocommerce-mini-cart-item:after{
  content: "";
  display: block;
  clear: both;
}