/* ═══════════════════════════════════════════════════════════
   SOSYALBOOST ─ css/components.css
   Cart Drawer · Modals · Search · Toast · Live Feed
   ═══════════════════════════════════════════════════════════ */

/* ── CART OVERLAY ────────────────────────────────── */
.cart-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0);z-index:8000;
  pointer-events:none;transition:background .3s
}
.cart-overlay.open{background:rgba(0,0,0,.5);pointer-events:all}
.cart-drawer{
  position:fixed;top:0;right:-460px;width:460px;height:100vh;
  background:#fff;box-shadow:-10px 0 60px rgba(0,0,0,.15);
  z-index:8001;display:flex;flex-direction:column;
  transition:right .35s cubic-bezier(.4,0,.2,1)
}
.cart-overlay.open .cart-drawer{right:0}
.cart-head{
  padding:22px 24px;border-bottom:1.5px solid var(--border2);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0
}
.cart-head h3{
  font-family:var(--font-head);font-size:20px;font-weight:900;
  display:flex;align-items:center;gap:10px
}
.cart-head h3 span{
  font-size:13px;background:var(--or);color:#fff;
  border-radius:7px;padding:2px 9px;font-weight:800;font-family:var(--font)
}
.cart-head button{
  width:36px;height:36px;border-radius:10px;border:1.5px solid var(--border2);
  background:#fff;font-size:16px;color:var(--tx2);
  display:flex;align-items:center;justify-content:center;transition:all var(--t)
}
.cart-head button:hover{background:var(--or-pale);border-color:var(--or);color:var(--or)}
.cart-body{flex:1;overflow-y:auto;padding:16px 24px}
.cart-empty{text-align:center;padding:60px 20px}
.cart-empty i{font-size:52px;color:var(--border2);margin-bottom:14px;display:block}
.cart-empty p{font-size:15px;color:var(--tx2);font-weight:600}
.cart-item{
  display:flex;gap:14px;padding:14px 0;
  border-bottom:1.5px solid var(--bg2);align-items:flex-start
}
.cart-item:last-child{border-bottom:none}
.ci-icon{
  width:46px;height:46px;border-radius:12px;background:var(--or-pale);
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0
}
.ci-info{flex:1}
.ci-info strong{font-size:13px;font-weight:800;display:block;margin-bottom:2px}
.ci-info span{font-size:11px;color:var(--tx2);font-weight:600}
.ci-meta{display:flex;align-items:center;gap:8px;margin-top:8px}
.ci-price{font-family:var(--font-head);font-size:16px;font-weight:900;color:var(--or)}
.ci-qty{display:flex;align-items:center;gap:6px}
.ci-qty button{
  width:24px;height:24px;border-radius:7px;border:1.5px solid var(--border2);
  background:#fff;font-size:13px;font-weight:800;
  display:flex;align-items:center;justify-content:center;transition:all var(--t)
}
.ci-qty button:hover{background:var(--or);border-color:var(--or);color:#fff}
.ci-qty span{font-size:13px;font-weight:800;min-width:22px;text-align:center}
.ci-del{
  width:28px;height:28px;border-radius:8px;border:1.5px solid #FEE2E2;
  background:#FEF2F2;color:var(--red);font-size:12px;
  display:flex;align-items:center;justify-content:center;transition:all var(--t)
}
.ci-del:hover{background:var(--red);color:#fff}

/* cart coupon */
.cart-coupon{padding:14px 24px;border-top:1.5px solid var(--border2);background:var(--bg)}
.cart-coupon>div{display:flex;gap:8px}
.cart-coupon input{
  flex:1;padding:9px 14px;border-radius:10px;border:1.5px solid var(--border2);
  font-size:13px;font-weight:600;outline:none;transition:border var(--t)
}
.cart-coupon input:focus{border-color:var(--or)}
.cart-coupon button{
  padding:9px 16px;border-radius:10px;border:none;
  background:var(--dark);color:#fff;font-size:13px;font-weight:800;transition:all var(--t)
}
.cart-coupon button:hover{background:#000}
.coupon-msg{font-size:12px;font-weight:700;margin-top:6px;display:none}
.coupon-msg.ok{display:block;color:var(--green)}
.coupon-msg.err{display:block;color:var(--red)}

/* cart footer */
.cart-foot{padding:18px 24px;border-top:1.5px solid var(--border2);background:#fff;flex-shrink:0}
.cart-totals{margin-bottom:16px}
.ct-row{
  display:flex;justify-content:space-between;
  font-size:13px;font-weight:600;color:var(--tx2);padding:5px 0
}
.ct-row.discount strong{color:var(--green)}
.ct-row.total{
  font-size:17px;font-weight:900;color:var(--tx);
  border-top:1.5px solid var(--border2);margin-top:8px;padding-top:12px
}
.ct-row.total strong{color:var(--or);font-family:var(--font-head);font-size:22px}
.btn-checkout{
  width:100%;padding:14px;border-radius:13px;border:none;
  background:linear-gradient(135deg,var(--or),var(--or2));color:#fff;
  font-size:15px;font-weight:800;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:9px;
  box-shadow:0 4px 20px rgba(255,107,0,.35);transition:all .2s
}
.btn-checkout:hover{opacity:.92;transform:translateY(-1px)}

/* ── SEARCH OVERLAY ──────────────────────────────── */
.search-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:8800;
  backdrop-filter:blur(8px);opacity:0;pointer-events:none;
  transition:opacity .2s;display:flex;align-items:flex-start;
  justify-content:center;padding-top:100px
}
.search-overlay.open{opacity:1;pointer-events:all}
.search-box{
  background:#fff;border-radius:20px;padding:20px;
  width:640px;max-width:92vw;
  box-shadow:var(--sh4);
  transform:scale(.94) translateY(-10px);
  transition:transform .22s var(--t2)
}
.search-overlay.open .search-box{transform:scale(1) translateY(0)}
.search-box input{
  width:100%;padding:14px 18px;border-radius:13px;
  border:2px solid var(--border);font-size:16px;font-weight:600;
  outline:none;background:var(--bg);transition:border var(--t)
}
.search-box input:focus{border-color:var(--or);background:#fff}
.search-results{margin-top:14px;display:flex;flex-direction:column;gap:4px}
.sr-item{
  display:flex;align-items:center;gap:12px;padding:11px 14px;
  border-radius:11px;cursor:pointer;transition:background var(--t)
}
.sr-item:hover{background:var(--or-pale)}
.sr-item i{color:var(--or);font-size:15px;width:20px;text-align:center}
.sr-item strong{font-size:13px;font-weight:700;display:block}
.sr-item span{font-size:11px;color:var(--tx2)}

/* ── LIVE FEED ───────────────────────────────────── */
.live-feed{
  position:fixed;bottom:90px;left:20px;z-index:6000;
  display:flex;flex-direction:column;gap:8px;pointer-events:none
}
.feed-item{
  background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  border:1.5px solid var(--border);border-radius:14px;
  padding:10px 16px;display:flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;color:var(--tx);
  box-shadow:0 4px 20px rgba(0,0,0,.1);
  transform:translateX(-120px);opacity:0;
  transition:all .4s cubic-bezier(.34,1.2,.64,1);min-width:260px
}
.feed-item.show{transform:translateX(0);opacity:1}
.feed-item .fi-icon{font-size:18px}
.feed-item .fi-text strong{display:block;font-size:12px}
.feed-item .fi-text span{font-size:10px;color:var(--tx2)}

/* ── STICKY CART BAR ─────────────────────────────── */
.sticky-cart{
  position:fixed;bottom:0;left:0;right:0;z-index:7500;
  background:linear-gradient(135deg,var(--or),var(--or2));
  padding:12px 24px;display:flex;align-items:center;justify-content:space-between;
  transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:0 -4px 24px rgba(255,107,0,.3)
}
.sticky-cart.show{transform:translateY(0)}
.sticky-cart-info{color:#fff;font-weight:700;font-size:14px}
.sticky-cart-info strong{font-family:var(--font-head);font-size:18px}
.sticky-cart button{
  padding:10px 22px;border-radius:10px;border:2px solid rgba(255,255,255,.4);
  background:rgba(255,255,255,.15);backdrop-filter:blur(8px);
  color:#fff;font-size:14px;font-weight:800;cursor:pointer;transition:all var(--t)
}
.sticky-cart button:hover{background:rgba(255,255,255,.25)}

/* ── WHATSAPP BUTTON ─────────────────────────────── */
.whatsapp-btn{
  position:fixed;bottom:88px;right:20px;z-index:7000;
  width:52px;height:52px;border-radius:50%;background:#25D366;
  color:#fff;font-size:26px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.45);transition:all .2s
}
.whatsapp-btn:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.55)}

/* ── TOAST ───────────────────────────────────────── */
.toast-container{
  position:fixed;top:80px;right:20px;z-index:99999;
  display:flex;flex-direction:column;gap:8px
}
.toast{
  background:#fff;border-radius:14px;padding:14px 18px;
  border:1.5px solid var(--border2);box-shadow:0 8px 30px rgba(0,0,0,.12);
  display:flex;align-items:center;gap:12px;font-size:13px;font-weight:700;
  transform:translateX(120px);opacity:0;
  transition:all .3s var(--t2);min-width:280px;max-width:340px
}
.toast.show{transform:translateX(0);opacity:1}
.toast i{font-size:18px}
.toast.success i{color:var(--green)}
.toast.error   i{color:var(--red)}
.toast.info    i{color:var(--blue)}
.toast.warn    i{color:var(--yellow)}

/* ── FLY BALL ────────────────────────────────────── */
.fly-ball{
  width:14px;height:14px;border-radius:50%;background:var(--or);
  position:fixed;z-index:9999;pointer-events:none;opacity:1;
  transition:all .65s cubic-bezier(.2,.8,.2,1)
}
