/*
 * ============================================================
 *  OKU ELECTRONICS — Premium Off-Canvas Cart
 *  Version: 3.0.0
 *  Paste into: Appearance → Customize → Additional CSS
 *  OR enqueue via child theme functions.php
 * ============================================================
 */

/* ── CSS VARIABLES (edit here to reskin) ── */
:root {
  --oku-brand:         #186E70;
  --oku-brand-dark:    #0f4e50;
  --oku-brand-light:   #e8f5f5;
  --oku-accent:        #ffa41c;
  --oku-success:       #16a34a;
  --oku-danger:        #dc2626;
  --oku-text:          #111827;
  --oku-text-muted:    #6b7280;
  --oku-text-faint:    #9ca3af;
  --oku-border:        #e5e7eb;
  --oku-bg-soft:       #f9fafb;
  --oku-white:         #ffffff;
  --oku-shadow-sm:     0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --oku-shadow-md:     0 4px 16px rgba(0,0,0,.10);
  --oku-shadow-lg:     0 12px 40px rgba(0,0,0,.14);
  --oku-radius:        12px;
  --oku-radius-sm:     8px;
  --oku-radius-pill:   100px;
  --oku-font:          'DM Sans', 'Roboto', system-ui, sans-serif;
  --oku-font-mono:     'DM Mono', 'Roboto Mono', monospace;
  --oku-transition:    0.22s cubic-bezier(0.4, 0, 0.2, 1);
  --oku-cart-width:    400px;
}

/* ══════════════════════════════════════════════════════
   OVERLAY
══════════════════════════════════════════════════════ */
.oku-cart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  z-index: 99998;
  display: none;
  transition: background var(--oku-transition);
  backdrop-filter: blur(0px);
}

.oku-cart-overlay.oku-open {
  display: block;
  background: rgba(0, 0, 0, 0.52);
  backdrop-filter: blur(2px);
}

/* ══════════════════════════════════════════════════════
   PANEL
══════════════════════════════════════════════════════ */
#off-canvas-cart-summary,
.oku-cart-panel {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  width: var(--oku-cart-width) !important;
  max-width: 100vw !important;
  height: 100dvh !important;
  height: 100vh !important;
  background: var(--oku-white) !important;
  display: flex !important;
  flex-direction: column !important;
  z-index: 99999 !important;
  overflow: hidden !important;
  font-family: var(--oku-font) !important;
  box-shadow: var(--oku-shadow-lg) !important;
  transform: translateX(100%) !important;
  transition: transform 0.38s cubic-bezier(0.32, 0.72, 0, 1) !important;
  will-change: transform !important;
}

#off-canvas-cart-summary.oku-open,
.off-canvas-cart-active #off-canvas-cart-summary {
  transform: translateX(0) !important;
}

/* ══════════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════════ */
.oku-cart-header,
#off-canvas-cart-summary .off-canvas-cart__header {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 20px !important;
  height: 58px !important;
  border-bottom: 1px solid var(--oku-border) !important;
  background: var(--oku-white) !important;
  position: relative !important;
}

/* Cart title */
#off-canvas-cart-summary .off-canvas-cart__header .section-title,
.oku-cart-title {
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--oku-text) !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

/* Cart count badge in header */
.oku-cart-title-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--oku-brand);
  color: white;
  font-size: 10px;
  font-weight: 700;
  min-width: 20px;
  height: 20px;
  border-radius: var(--oku-radius-pill);
  padding: 0 5px;
}

/* Close button */
#off-canvas-cart-summary .electro-close-icon,
.oku-cart-close {
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: var(--oku-bg-soft) !important;
  border: none !important;
  transition: background var(--oku-transition), transform var(--oku-transition) !important;
  font-size: 0 !important;
  flex-shrink: 0 !important;
  position: relative !important;
}

#off-canvas-cart-summary .electro-close-icon::before,
#off-canvas-cart-summary .electro-close-icon::after {
  content: '' !important;
  position: absolute !important;
  width: 14px !important;
  height: 2px !important;
  background: var(--oku-text-muted) !important;
  border-radius: 2px !important;
  transition: background var(--oku-transition) !important;
}

#off-canvas-cart-summary .electro-close-icon::before { transform: rotate(45deg) !important; }
#off-canvas-cart-summary .electro-close-icon::after  { transform: rotate(-45deg) !important; }

#off-canvas-cart-summary .electro-close-icon:hover {
  background: #fee2e2 !important;
  transform: rotate(90deg) !important;
}

#off-canvas-cart-summary .electro-close-icon:hover::before,
#off-canvas-cart-summary .electro-close-icon:hover::after {
  background: var(--oku-danger) !important;
}

/* ══════════════════════════════════════════════════════
   FREE DELIVERY PROGRESS BAR
══════════════════════════════════════════════════════ */
.oku-free-delivery-bar {
  flex: 0 0 auto;
  padding: 10px 20px;
  background: var(--oku-brand-light);
  border-bottom: 1px solid rgba(24,110,112,.12);
}

.oku-fdbar-text {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--oku-brand-dark);
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.oku-fdbar-track {
  height: 5px;
  background: rgba(24,110,112,.18);
  border-radius: var(--oku-radius-pill);
  overflow: hidden;
}

.oku-fdbar-fill {
  height: 100%;
  background: var(--oku-brand);
  border-radius: var(--oku-radius-pill);
  transition: width 0.5s ease;
}

/* ══════════════════════════════════════════════════════
   SCROLLABLE BODY
══════════════════════════════════════════════════════ */
#off-canvas-cart-summary .cart-products,
.oku-cart-body {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  min-height: 0 !important;
  scrollbar-width: thin !important;
  scrollbar-color: #d1d5db transparent !important;
}

#off-canvas-cart-summary .cart-products::-webkit-scrollbar { width: 4px !important; }
#off-canvas-cart-summary .cart-products::-webkit-scrollbar-track { background: transparent !important; }
#off-canvas-cart-summary .cart-products::-webkit-scrollbar-thumb {
  background: #d1d5db !important;
  border-radius: 4px !important;
}

/* ══════════════════════════════════════════════════════
   PRODUCT LIST
══════════════════════════════════════════════════════ */
#off-canvas-cart-summary .elementor-menu-cart__products,
#off-canvas-cart-summary .woocommerce-mini-cart {
  display: flex !important;
  flex-direction: column !important;
  padding: 8px 0 !important;
  margin: 0 !important;
  list-style: none !important;
  width: 100% !important;
}

/* ══════════════════════════════════════════════════════
   PRODUCT CARD
══════════════════════════════════════════════════════ */
#off-canvas-cart-summary .elementor-menu-cart__product,
#off-canvas-cart-summary .woocommerce-mini-cart-item {
  display: grid !important;
  grid-template-columns: 80px 1fr 28px !important;
  grid-template-rows: auto auto auto !important;
  column-gap: 12px !important;
  row-gap: 0 !important;
  padding: 14px 18px !important;
  border-bottom: 1px solid var(--oku-border) !important;
  position: relative !important;
  background: var(--oku-white) !important;
  transition: background var(--oku-transition) !important;
  float: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
  align-items: start !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product:last-child {
  border-bottom: none !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product:hover {
  background: #fafbfb !important;
}

/* ── Image ── */
#off-canvas-cart-summary .elementor-menu-cart__product-image,
#off-canvas-cart-summary .product-thumbnail {
  grid-column: 1 !important;
  grid-row: 1 / 4 !important;
  width: 80px !important;
  height: 80px !important;
  border-radius: var(--oku-radius-sm) !important;
  border: 1px solid var(--oku-border) !important;
  background: var(--oku-bg-soft) !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-image img,
#off-canvas-cart-summary .product-thumbnail img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  padding: 5px !important;
  box-sizing: border-box !important;
}

/* ── Name ── */
#off-canvas-cart-summary .elementor-menu-cart__product-name,
#off-canvas-cart-summary .product-name {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-name a,
#off-canvas-cart-summary .product-name a {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--oku-text) !important;
  text-decoration: none !important;
  line-height: 1.45 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  transition: color var(--oku-transition) !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-name a:hover,
#off-canvas-cart-summary .product-name a:hover {
  color: var(--oku-brand) !important;
}

/* ── Variation ── */
#off-canvas-cart-summary dl.variation,
#off-canvas-cart-summary .wc-item-meta {
  margin: 4px 0 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 2px 6px !important;
}

#off-canvas-cart-summary dl.variation dt,
#off-canvas-cart-summary .wc-item-meta dt {
  display: inline !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  color: var(--oku-text-faint) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

#off-canvas-cart-summary dl.variation dd,
#off-canvas-cart-summary .wc-item-meta dd {
  display: inline !important;
  font-size: 10.5px !important;
  color: var(--oku-text-muted) !important;
  margin: 0 !important;
  font-weight: 500 !important;
}

#off-canvas-cart-summary dl.variation dd p { display: inline !important; margin: 0 !important; }

/* ── In Stock badge ── */
#off-canvas-cart-summary .oku-stock-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  color: var(--oku-success) !important;
  margin-top: 4px !important;
}

#off-canvas-cart-summary .oku-stock-badge::before {
  content: '' !important;
  display: inline-block !important;
  width: 5px !important;
  height: 5px !important;
  border-radius: 50% !important;
  background: var(--oku-success) !important;
  flex-shrink: 0 !important;
}

/* ── Hide pi-edd ── */
#off-canvas-cart-summary .pi-edd,
#off-canvas-cart-summary [id^="pi-estimate-"] {
  display: none !important;
}

/* ── PRICE + QTY ROW ── */
#off-canvas-cart-summary .elementor-menu-cart__product-price,
#off-canvas-cart-summary .product-price {
  grid-column: 2 !important;
  grid-row: 2 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin-top: 10px !important;
}

/* Price */
#off-canvas-cart-summary .elementor-menu-cart__product-price .woocommerce-Price-amount,
#off-canvas-cart-summary .product-price .amount {
  font-size: 15px !important;
  font-weight: 800 !important;
  color: var(--oku-brand) !important;
  letter-spacing: -0.01em !important;
  font-family: var(--oku-font-mono) !important;
}

/* Hide old qty text */
#off-canvas-cart-summary .product-quantity {
  display: none !important;
}

/* ══════════════════════════════════════════════════════
   QTY SELECTOR PILL
══════════════════════════════════════════════════════ */
#off-canvas-cart-summary .oku-minicart-qty {
  display: inline-flex !important;
  align-items: center !important;
  border: 1.5px solid var(--oku-border) !important;
  border-radius: var(--oku-radius-pill) !important;
  overflow: hidden !important;
  background: var(--oku-white) !important;
  height: 32px !important;
  flex-shrink: 0 !important;
  box-shadow: var(--oku-shadow-sm) !important;
}

#off-canvas-cart-summary .oku-minicart-qty__btn {
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 17px !important;
  font-weight: 400 !important;
  color: var(--oku-text-muted) !important;
  transition: background var(--oku-transition), color var(--oku-transition) !important;
  padding: 0 !important;
  line-height: 1 !important;
  user-select: none !important;
}

#off-canvas-cart-summary .oku-minicart-qty__btn:hover {
  background: var(--oku-brand) !important;
  color: var(--oku-white) !important;
}

#off-canvas-cart-summary .oku-minicart-qty__btn:active {
  transform: scale(0.9) !important;
}

#off-canvas-cart-summary .oku-minicart-qty__val {
  width: 32px !important;
  text-align: center !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--oku-text) !important;
  border: none !important;
  border-left: 1px solid var(--oku-border) !important;
  border-right: 1px solid var(--oku-border) !important;
  background: var(--oku-bg-soft) !important;
  padding: 0 !important;
  height: 30px !important;
  -moz-appearance: textfield !important;
}

#off-canvas-cart-summary .oku-minicart-qty__val::-webkit-inner-spin-button,
#off-canvas-cart-summary .oku-minicart-qty__val::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
}

/* ── Updating state ── */
#off-canvas-cart-summary .oku-minicart-qty.oku-updating {
  opacity: 0.5 !important;
  pointer-events: none !important;
}

/* ══════════════════════════════════════════════════════
   REMOVE BUTTON
══════════════════════════════════════════════════════ */
#off-canvas-cart-summary .elementor-menu-cart__product-remove,
#off-canvas-cart-summary .product-remove {
  grid-column: 3 !important;
  grid-row: 1 !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  padding-top: 1px !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-remove a,
#off-canvas-cart-summary .product-remove a,
#off-canvas-cart-summary a.elementor_remove_from_cart_button,
#off-canvas-cart-summary a.remove_from_cart_button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 26px !important;
  height: 26px !important;
  border-radius: 50% !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  font-size: 0 !important;
  color: transparent !important;
  text-decoration: none !important;
  transition: all var(--oku-transition) !important;
  position: relative !important;
  cursor: pointer !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-remove a::before,
#off-canvas-cart-summary .product-remove a::before,
#off-canvas-cart-summary a.elementor_remove_from_cart_button::before,
#off-canvas-cart-summary a.remove_from_cart_button::before,
#off-canvas-cart-summary .elementor-menu-cart__product-remove a::after,
#off-canvas-cart-summary .product-remove a::after,
#off-canvas-cart-summary a.elementor_remove_from_cart_button::after,
#off-canvas-cart-summary a.remove_from_cart_button::after {
  content: '' !important;
  position: absolute !important;
  width: 10px !important;
  height: 1.5px !important;
  background: var(--oku-text-faint) !important;
  border-radius: 2px !important;
  transition: background var(--oku-transition) !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-remove a::before,
#off-canvas-cart-summary .product-remove a::before,
#off-canvas-cart-summary a.elementor_remove_from_cart_button::before,
#off-canvas-cart-summary a.remove_from_cart_button::before {
  transform: rotate(45deg) !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-remove a::after,
#off-canvas-cart-summary .product-remove a::after,
#off-canvas-cart-summary a.elementor_remove_from_cart_button::after,
#off-canvas-cart-summary a.remove_from_cart_button::after {
  transform: rotate(-45deg) !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-remove a:hover,
#off-canvas-cart-summary .product-remove a:hover,
#off-canvas-cart-summary a.elementor_remove_from_cart_button:hover,
#off-canvas-cart-summary a.remove_from_cart_button:hover {
  background: #fef2f2 !important;
  border-color: #fca5a5 !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product-remove a:hover::before,
#off-canvas-cart-summary .elementor-menu-cart__product-remove a:hover::after,
#off-canvas-cart-summary .product-remove a:hover::before,
#off-canvas-cart-summary .product-remove a:hover::after,
#off-canvas-cart-summary a.elementor_remove_from_cart_button:hover::before,
#off-canvas-cart-summary a.elementor_remove_from_cart_button:hover::after,
#off-canvas-cart-summary a.remove_from_cart_button:hover::before,
#off-canvas-cart-summary a.remove_from_cart_button:hover::after {
  background: var(--oku-danger) !important;
}

/* ══════════════════════════════════════════════════════
   EMPTY CART STATE
══════════════════════════════════════════════════════ */
.oku-empty-cart {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  text-align: center;
  height: 100%;
}

.oku-empty-cart-icon {
  width: 80px;
  height: 80px;
  background: var(--oku-bg-soft);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}

.oku-empty-cart-icon svg {
  width: 36px;
  height: 36px;
  stroke: var(--oku-text-faint);
}

.oku-empty-cart h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--oku-text);
  margin: 0 0 8px;
}

.oku-empty-cart p {
  font-size: 13px;
  color: var(--oku-text-muted);
  margin: 0 0 24px;
  line-height: 1.6;
}

.oku-empty-cart a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--oku-brand);
  color: var(--oku-white);
  padding: 11px 24px;
  border-radius: var(--oku-radius-sm);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: background var(--oku-transition);
}

.oku-empty-cart a:hover { background: var(--oku-brand-dark); }

/* ══════════════════════════════════════════════════════
   CART FOOTER — STICKY
══════════════════════════════════════════════════════ */
.oku-cart-footer {
  flex: 0 0 auto;
  background: var(--oku-white);
  border-top: 1px solid var(--oku-border);
}

/* Subtotal */
#off-canvas-cart-summary .elementor-menu-cart__subtotal,
.oku-subtotal-row {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 14px 20px !important;
  background: var(--oku-bg-soft) !important;
  border-top: 1px solid var(--oku-border) !important;
  border-bottom: 1px solid var(--oku-border) !important;
}

#off-canvas-cart-summary .elementor-menu-cart__subtotal strong {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--oku-text-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
}

#off-canvas-cart-summary .elementor-menu-cart__subtotal .woocommerce-Price-amount,
#off-canvas-cart-summary .elementor-menu-cart__subtotal .amount {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--oku-text) !important;
  letter-spacing: -0.02em !important;
  font-family: var(--oku-font-mono) !important;
}

/* Delivery note */
.oku-delivery-note {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 20px;
  font-size: 11.5px;
  color: var(--oku-success);
  font-weight: 500;
  background: #f0fdf4;
  border-bottom: 1px solid #d1fae5;
}

.oku-delivery-note svg {
  width: 14px;
  height: 14px;
  stroke: var(--oku-success);
  flex-shrink: 0;
}

/* Trust badges */
.oku-trust-badges {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 8px 20px;
  border-bottom: 1px solid var(--oku-border);
}

.oku-trust-badge {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  color: var(--oku-text-faint);
}

.oku-trust-badge svg {
  width: 13px;
  height: 13px;
  stroke: var(--oku-text-faint);
}

/* Buttons */
#off-canvas-cart-summary .elementor-menu-cart__footer-buttons {
  display: grid !important;
  grid-template-columns: 1fr 1.6fr !important;
  gap: 10px !important;
  padding: 14px 18px 16px !important;
  background: var(--oku-white) !important;
}

#off-canvas-cart-summary .elementor-button--view-cart {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 46px !important;
  background: var(--oku-white) !important;
  color: var(--oku-text) !important;
  border: 1.5px solid var(--oku-border) !important;
  border-radius: var(--oku-radius-sm) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: all var(--oku-transition) !important;
  letter-spacing: 0.01em !important;
}

#off-canvas-cart-summary .elementor-button--view-cart:hover {
  border-color: var(--oku-brand) !important;
  color: var(--oku-brand) !important;
  background: var(--oku-brand-light) !important;
}

#off-canvas-cart-summary .elementor-button--checkout {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  height: 46px !important;
  background: var(--oku-brand) !important;
  color: var(--oku-white) !important;
  border: none !important;
  border-radius: var(--oku-radius-sm) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: all var(--oku-transition) !important;
  letter-spacing: 0.02em !important;
  box-shadow: 0 4px 14px rgba(24,110,112,.35) !important;
  position: relative !important;
  overflow: hidden !important;
}

#off-canvas-cart-summary .elementor-button--checkout::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: rgba(255,255,255,0) !important;
  transition: background var(--oku-transition) !important;
}

#off-canvas-cart-summary .elementor-button--checkout:hover {
  background: var(--oku-brand-dark) !important;
  color: var(--oku-white) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(24,110,112,.42) !important;
}

#off-canvas-cart-summary .elementor-button--checkout:active {
  transform: translateY(0) !important;
}

/* Arrow on checkout */
#off-canvas-cart-summary .elementor-button--checkout .elementor-button-text::after {
  content: ' →' !important;
}

/* ══════════════════════════════════════════════════════
   LOADING SPINNER
══════════════════════════════════════════════════════ */
.oku-cart-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  flex-direction: column;
  gap: 12px;
}

.oku-spinner {
  width: 28px;
  height: 28px;
  border: 2.5px solid var(--oku-border);
  border-top-color: var(--oku-brand);
  border-radius: 50%;
  animation: okuSpin 0.7s linear infinite;
}

@keyframes okuSpin {
  to { transform: rotate(360deg); }
}

/* ══════════════════════════════════════════════════════
   PRODUCT ENTER ANIMATION
══════════════════════════════════════════════════════ */
#off-canvas-cart-summary .elementor-menu-cart__product {
  animation: okuFadeSlide 0.3s ease both !important;
}

#off-canvas-cart-summary .elementor-menu-cart__product:nth-child(1) { animation-delay: 0.00s !important; }
#off-canvas-cart-summary .elementor-menu-cart__product:nth-child(2) { animation-delay: 0.04s !important; }
#off-canvas-cart-summary .elementor-menu-cart__product:nth-child(3) { animation-delay: 0.08s !important; }
#off-canvas-cart-summary .elementor-menu-cart__product:nth-child(4) { animation-delay: 0.12s !important; }
#off-canvas-cart-summary .elementor-menu-cart__product:nth-child(5) { animation-delay: 0.16s !important; }

@keyframes okuFadeSlide {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ══════════════════════════════════════════════════════
   HIDE XOOTIX
══════════════════════════════════════════════════════ */
.xoo-wsc-sc-cont,
.xoo-wsc-cart-trigger,
.xoo-wsc-basket {
  display: none !important;
}

/* ══════════════════════════════════════════════════════
   MOBILE
══════════════════════════════════════════════════════ */
@media (max-width: 480px) {
  :root { --oku-cart-width: 100vw; }

  #off-canvas-cart-summary .elementor-menu-cart__footer-buttons {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    padding: 12px 14px 14px !important;
  }

  #off-canvas-cart-summary .elementor-menu-cart__product {
    grid-template-columns: 68px 1fr 24px !important;
    padding: 12px 14px !important;
  }

  #off-canvas-cart-summary .elementor-menu-cart__product-image,
  #off-canvas-cart-summary .product-thumbnail {
    width: 68px !important;
    height: 68px !important;
  }
}