/* ==========================================================================
   AFRIKAN ACCENT ADVENTURES — BOOKING CART
   Floating cart button + slide-in drawer. Uses --aaa-* design tokens and the
   shared .aaa-btn pill buttons so it inherits the brand. Stacks ABOVE the
   floating WhatsApp button (.aaa-wa) so the two never collide.
   ========================================================================== */

/* ── Floating cart button (FAB) ──────────────────────────────────────────── */
/* .aaa-wa sits at right:24px / bottom:24px and is ~60px tall, so place the cart
   one notch higher (bottom:100px). On mobile .aaa-wa moves to bottom:84px, so
   the cart moves to bottom:160px (still clear of the sticky mobile bar). */
.aaa-cart-fab{
  position:fixed;right:24px;bottom:100px;z-index:9001;
  width:60px;height:60px;border:none;border-radius:50%;cursor:pointer;
  background:var(--aaa-navy);color:#fff;
  display:grid;place-items:center;
  box-shadow:0 14px 30px -10px rgba(7,32,63,.6);
  transition:transform .25s ease,filter .25s ease,background .25s ease;
}
.aaa-cart-fab:hover{transform:translateY(-2px) scale(1.05);background:var(--aaa-navy-2)}
.aaa-cart-fab:active{transform:scale(.98)}
.aaa-cart-fab.has-items{background:var(--aaa-blue)}
.aaa-cart-fab.has-items:hover{background:var(--aaa-blue-deep)}
.aaa-cart-fab__ic{font-size:1.55rem;line-height:1}
.aaa-cart-fab__count{
  position:absolute;top:-4px;right:-4px;min-width:22px;height:22px;padding:0 6px;
  border-radius:50px;background:var(--aaa-gold);color:var(--aaa-navy);
  font-family:var(--aaa-sans);font-weight:800;font-size:.74rem;
  display:grid;place-items:center;box-shadow:0 2px 8px rgba(7,32,63,.35);
}

/* ── Backdrop + drawer ───────────────────────────────────────────────────── */
.aaa-cart-backdrop{
  position:fixed;inset:0;z-index:9098;background:rgba(7,18,38,.5);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
}
.aaa-cart-backdrop.is-on{opacity:1;visibility:visible}
body.aaa-cart-lock{overflow:hidden}

.aaa-cart-drawer{
  position:fixed;top:0;right:0;z-index:9099;height:100%;
  width:min(440px,100%);background:var(--aaa-paper);color:var(--aaa-ink);
  display:flex;flex-direction:column;
  box-shadow:-24px 0 60px -20px rgba(7,32,63,.5);
  transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  font-family:var(--aaa-sans);
}
.aaa-cart-drawer.is-open{transform:translateX(0)}

/* ── Header ──────────────────────────────────────────────────────────────── */
.aaa-cart-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 22px;background:var(--aaa-navy);color:#fff;flex-shrink:0;
}
.aaa-cart-head h3{margin:0;color:#fff;font-family:var(--aaa-serif);font-size:1.3rem}
.aaa-cart-close{
  width:38px;height:38px;border:none;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.12);color:#fff;font-size:1.4rem;line-height:1;transition:.2s;
}
.aaa-cart-close:hover{background:rgba(255,255,255,.25)}

/* ── Body (scrolls) ──────────────────────────────────────────────────────── */
.aaa-cart-body{flex:1;overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column;gap:24px}

/* items */
.aaa-cart-empty{
  text-align:center;color:var(--aaa-ink-soft);font-size:.94rem;
  padding:26px 16px;background:var(--aaa-mist);border-radius:var(--aaa-radius);
}
.aaa-cart-line{
  border:1px solid var(--aaa-line);border-radius:14px;padding:14px 16px;
  display:flex;flex-direction:column;gap:10px;background:var(--aaa-paper);
}
.aaa-cart-line + .aaa-cart-line{margin-top:12px}
.aaa-cart-line__main b{display:block;font-family:var(--aaa-serif);font-size:1.02rem;line-height:1.2}
.aaa-cart-line__main small{display:block;color:var(--aaa-ink-soft);font-size:.82rem;margin-top:3px}
.aaa-cart-line__price{display:inline-block;margin-top:6px;font-weight:700;color:var(--aaa-blue)}
.aaa-cart-line__price em{font-style:normal;color:var(--aaa-ink-soft);font-weight:500;font-size:.82rem}
.aaa-cart-line__ctrl{display:flex;align-items:center;justify-content:space-between;gap:12px}
.aaa-cart-line__ctrl label{font-size:.78rem;color:var(--aaa-ink-soft);font-weight:700;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:8px}
.aaa-cart-line__ctrl input{
  width:60px;padding:7px 9px;border:1.5px solid var(--aaa-line);border-radius:9px;
  font-family:var(--aaa-sans);font-size:.92rem;text-align:center;
}
.aaa-cart-line__ctrl input:focus{outline:none;border-color:var(--aaa-blue)}
.aaa-cart-rm{
  background:none;border:none;cursor:pointer;color:var(--aaa-gold-deep);
  font-weight:700;font-size:.82rem;text-decoration:underline;padding:4px;
}
.aaa-cart-rm:hover{color:var(--aaa-blue)}

/* add-ons */
.aaa-cart-addons h4,.aaa-cart-checkout h4{
  font-family:var(--aaa-serif);font-size:1.12rem;margin:0 0 4px;
}
.aaa-cart-addons__sub{margin:0 0 12px;color:var(--aaa-ink-soft);font-size:.85rem}
.aaa-cart-addon{
  display:flex;align-items:center;gap:12px;justify-content:space-between;
  border:1px solid var(--aaa-line);border-radius:12px;padding:12px 14px;
}
.aaa-cart-addon + .aaa-cart-addon{margin-top:10px}
.aaa-cart-addon.is-on{border-color:var(--aaa-blue);background:var(--aaa-sky)}
.aaa-cart-addon__info{display:flex;flex-direction:column;gap:2px;min-width:0}
.aaa-cart-addon__info b{font-size:.94rem;font-family:var(--aaa-sans);font-weight:700}
.aaa-cart-addon__info small{color:var(--aaa-ink-soft);font-size:.79rem;line-height:1.35}
.aaa-cart-addon__price{font-weight:700;color:var(--aaa-blue);font-size:.88rem;margin-top:3px}
.aaa-cart-addon__price em{font-style:normal;color:var(--aaa-ink-soft);font-weight:500;font-size:.78rem}
.aaa-cart-addon__btn{
  flex-shrink:0;border:1.5px solid var(--aaa-blue);background:transparent;color:var(--aaa-blue);
  border-radius:50px;padding:8px 16px;font-weight:700;font-size:.82rem;cursor:pointer;
  font-family:var(--aaa-sans);transition:.2s;white-space:nowrap;
}
.aaa-cart-addon__btn:hover{background:var(--aaa-blue);color:#fff}
.aaa-cart-addon.is-on .aaa-cart-addon__btn{background:var(--aaa-blue);color:#fff}

/* checkout form */
.aaa-cart-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.aaa-cart-grid label{
  display:flex;flex-direction:column;gap:5px;
  font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--aaa-blue);font-weight:700;
}
.aaa-cart-grid label.full{grid-column:1 / -1}
.aaa-cart-grid input,.aaa-cart-grid textarea{
  padding:11px 13px;border:1.5px solid var(--aaa-line);border-radius:10px;
  font-family:var(--aaa-sans);font-size:.94rem;color:var(--aaa-ink);font-weight:500;
  letter-spacing:normal;text-transform:none;width:100%;
}
.aaa-cart-grid input:focus,.aaa-cart-grid textarea:focus{outline:none;border-color:var(--aaa-blue)}
.aaa-cart-submit{width:100%;justify-content:center}
.aaa-cart-msg{font-size:.88rem;text-align:center;margin-top:10px;display:none}
.aaa-cart-msg.is-ok{display:block;color:var(--aaa-green)}
.aaa-cart-msg.is-err{display:block;color:var(--aaa-gold-deep)}

/* success state */
.aaa-cart-success{text-align:center;padding:14px 6px}
.aaa-cart-success__ic{
  width:56px;height:56px;border-radius:50%;background:var(--aaa-green);color:#fff;
  display:grid;place-items:center;font-size:1.7rem;font-weight:800;margin:0 auto 14px;
}
.aaa-cart-success h4{font-family:var(--aaa-serif);font-size:1.25rem;margin:0 0 8px}
.aaa-cart-success p{color:var(--aaa-ink-soft);font-size:.92rem;line-height:1.6;margin:0 0 14px}
.aaa-cart-success__pay{
  background:var(--aaa-sand);border-radius:12px;padding:14px 16px;
  color:var(--aaa-ink) !important;font-weight:600;font-size:.88rem !important;
}

/* ── Footer (sticky subtotal) ────────────────────────────────────────────── */
.aaa-cart-foot{
  flex-shrink:0;border-top:1px solid var(--aaa-line);
  padding:16px 22px 18px;background:var(--aaa-paper);
}
.aaa-cart-subtotal{display:flex;align-items:baseline;justify-content:space-between}
.aaa-cart-subtotal span{color:var(--aaa-ink-soft);font-size:.92rem;font-weight:600}
.aaa-cart-subtotal__val{font-family:var(--aaa-serif);font-size:1.7rem;color:var(--aaa-ink);font-weight:700}
.aaa-cart-foot__note{display:block;margin-top:8px;color:var(--aaa-ink-soft);font-size:.74rem;line-height:1.45}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media(max-width:680px){
  .aaa-cart-fab{bottom:160px;right:18px}
  .aaa-cart-grid{grid-template-columns:1fr}
}
/* When the nav drawer is locked open, hide the floating cart (matches .aaa-wa). */
body.aaa-nav-locked .aaa-cart-fab{display:none !important}
