/* ============================================================
   Cabs Booking Plugin — Frontend Styles
   ============================================================ */

:root {
  --cbp-primary: #F97316;
  --cbp-accent:  #1E3A5F;
  --cbp-bg:      #F8F9FA;
  --cbp-white:   #FFFFFF;
  --cbp-text:    #2D3748;
  --cbp-muted:   #718096;
  --cbp-border:  #E2E8F0;
  --cbp-radius:  14px;
  --cbp-shadow:  0 4px 20px rgba(0,0,0,.10);
  --cbp-shadow-hover: 0 12px 40px rgba(0,0,0,.18);
  --cbp-transition: .25s cubic-bezier(.4,0,.2,1);
}

/* ─── WRAPPER ─────────────────────────────────────── */
.cbp-wrapper { width:100%; }

/* ─── GRID ─────────────────────────────────────────── */
.cbp-grid-wrapper {
  display: grid;
  gap: 28px;
}
.cbp-cols-1 { grid-template-columns: 1fr; }
.cbp-cols-2 { grid-template-columns: repeat(2, 1fr); }
.cbp-cols-3 { grid-template-columns: repeat(3, 1fr); }
.cbp-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width:1024px) {
  .cbp-cols-3, .cbp-cols-4 { grid-template-columns: repeat(2,1fr); }
}
@media (max-width:640px) {
  .cbp-cols-2, .cbp-cols-3, .cbp-cols-4 { grid-template-columns: 1fr; }
}

/* ─── SLIDER ───────────────────────────────────────── */
.cbp-slider-wrapper { position:relative; padding:0; }
.cbp-swiper { overflow:hidden; border-radius: var(--cbp-radius); }
.cbp-swiper .swiper-slide { height:auto; }

.cbp-pagination { bottom:4px !important; }
.cbp-pagination .swiper-pagination-bullet { background:var(--cbp-muted); opacity:.5; }
.cbp-pagination .swiper-pagination-bullet-active { background:var(--cbp-primary); opacity:1; }

.cbp-btn-prev,
.cbp-btn-next {
  color: var(--cbp-primary) !important;
  background: var(--cbp-white);
  width:40px !important; height:40px !important;
  border-radius:50%;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
  top:42% !important;
}
.cbp-btn-prev::after,
.cbp-btn-next::after { font-size:14px !important; font-weight:700; }

/* ─── CARD ─────────────────────────────────────────── */
.cbp-card {
  background: var(--cbp-white);
  border-radius: var(--cbp-radius);
  box-shadow: var(--cbp-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--cbp-transition), box-shadow var(--cbp-transition);
  height: 100%;
}
.cbp-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--cbp-shadow-hover);
}

.cbp-card-image {
  position: relative;
  overflow: hidden;
  height: 210px;
}
.cbp-card-image img {
  width:100%; height:100%;
  object-fit:cover;
  transition: transform .5s ease;
  display:block;
}
.cbp-card:hover .cbp-card-image img {
  transform: scale(1.06);
}
.cbp-img-overlay {
  position:absolute; inset:0;
  background: linear-gradient(180deg,transparent 50%,rgba(0,0,0,.25));
}
.cbp-badge {
  position:absolute; top:14px; left:14px;
  background: var(--cbp-primary);
  color:#fff; font-size:10px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  padding:4px 10px; border-radius:20px;
}

.cbp-card-body {
  padding:18px 20px 20px;
  display:flex; flex-direction:column; flex:1;
}
.cbp-card-meta {
  display:flex; align-items:center; justify-content:space-between;
  font-size:12px; color:var(--cbp-muted);
  margin-bottom:8px;
}
.cbp-duration, .cbp-rating {
  display:flex; align-items:center; gap:4px;
}
.cbp-rating { color:#16A34A; font-weight:600; }
.cbp-reviews { color:var(--cbp-muted); font-weight:400; }

.cbp-card-title {
  font-size:16px; font-weight:700;
  color: var(--cbp-accent);
  margin:0 0 6px; line-height:1.35;
}
.cbp-card-desc {
  font-size:13px; color:var(--cbp-muted);
  margin:0 0 12px; line-height:1.5;
  flex:1;
}

.cbp-card-pricing { margin-bottom:16px; }
.cbp-original-price {
  font-size:13px; color:var(--cbp-muted);
  text-decoration:line-through; margin-right:6px;
}
.cbp-save-badge {
  background:#DCFCE7; color:#16A34A;
  font-size:11px; font-weight:700;
  padding:2px 8px; border-radius:4px;
}
.cbp-sale-price {
  font-size:22px; font-weight:800;
  color: var(--cbp-text); margin-top:4px;
}
.cbp-sale-price span { font-size:13px; font-weight:400; color:var(--cbp-muted); }

/* ─── CARD ACTIONS ─────────────────────────────────── */
.cbp-card-actions { display:flex; gap:10px; align-items:center; margin-top:auto; }

.cbp-phone-btn {
  flex-shrink:0;
  width:44px; height:44px;
  border:2px solid var(--cbp-primary);
  background:var(--cbp-white);
  color:var(--cbp-primary);
  border-radius:10px;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition: background var(--cbp-transition), color var(--cbp-transition);
}
.cbp-phone-btn:hover {
  background: var(--cbp-primary);
  color: #fff;
}

.cbp-callback-btn {
  flex:1;
  background: var(--cbp-primary);
  color:#fff;
  border:none; border-radius:10px;
  padding:12px 18px;
  font-size:14px; font-weight:700;
  cursor:pointer;
  transition: background var(--cbp-transition), transform var(--cbp-transition);
  letter-spacing:.02em;
}
.cbp-callback-btn:hover {
  background: #ea6a0e;
  transform: translateY(-1px);
}

/* ─── POPUP OVERLAY ────────────────────────────────── */
.cbp-popup-overlay {
  display: none !important; /* Force hidden by default */
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  z-index: 99999;
  align-items: center;
  justify-content: center;
  padding: 20px;
  overflow-y: auto;
}
.cbp-popup-overlay.cbp-popup-open {
  display: flex !important; /* Only show when JS adds this class */
}

/* Lock page scroll when popup is open */
body.cbp-no-scroll {
  overflow: hidden;
}

/* ─── STANDALONE FORM SECTION FIX ──────────────────── */
/* Hide any form that renders outside the popup context */
.cbp-popup-overlay:not(.cbp-popup-open) .cbp-popup,
.cbp-popup-overlay:not(.cbp-popup-open) form {
  display: none !important;
  visibility: hidden;
  pointer-events: none;
}

/* ─── POPUP BOX ────────────────────────────────────── */
.cbp-popup {
  background: var(--cbp-white);
  border-radius: 20px;
  box-shadow: 0 30px 80px rgba(0,0,0,.3);
  width: 100%;
  max-width: 540px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 28px 32px 32px;
  position: relative;
  margin: auto;
}

.cbp-popup-close {
  position:absolute; top:16px; right:16px;
  background:#f4f4f4; border:none;
  width:36px; height:36px; border-radius:50%;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--cbp-muted);
  transition: background var(--cbp-transition), color var(--cbp-transition);
}
.cbp-popup-close:hover { background:#e0e0e0; color:var(--cbp-text); }

/* ─── POPUP HEADER ─────────────────────────────────── */
.cbp-popup-header {
  display:flex; align-items:center; gap:16px;
  margin-bottom:24px; padding-bottom:20px;
  border-bottom:1px solid var(--cbp-border);
}
.cbp-popup-pkg-img {
  width:72px; height:56px;
  border-radius:10px; overflow:hidden;
  flex-shrink:0;
}
.cbp-popup-pkg-img img {
  width:100%; height:100%; object-fit:cover;
}
.cbp-popup-pkg-name {
  font-size:17px; font-weight:700; color:var(--cbp-accent);
  margin:0 0 6px; line-height:1.3;
}
.cbp-popup-pkg-price { display:flex; align-items:center; flex-wrap:wrap; gap:6px; }
#cbp-popup-sale-price { font-size:20px; font-weight:800; color:var(--cbp-text); }
#cbp-popup-orig-price { font-size:13px; color:var(--cbp-muted); text-decoration:line-through; }
#cbp-popup-save-badge {
  background:#DCFCE7; color:#16A34A;
  font-size:11px; font-weight:700;
  padding:2px 8px; border-radius:4px;
}

/* ─── FORM ─────────────────────────────────────────── */
.cbp-form-row { margin-bottom:14px; }
.cbp-form-group { position:relative; }

/* Hide Message textarea */
.cbp-form-group textarea,
.cbp-form-row:has(textarea) {
  display: none !important;
}

.cbp-form-group input,
.cbp-form-group select {
  width:100%; box-sizing:border-box;
  border:1.5px solid var(--cbp-border);
  border-radius:10px;
  padding:13px 16px;
  font-size:14px; color:var(--cbp-text);
  background:var(--cbp-white);
  outline:none;
  transition: border-color var(--cbp-transition), box-shadow var(--cbp-transition);
  font-family:inherit;
}
.cbp-form-group input:focus,
.cbp-form-group select:focus {
  border-color:var(--cbp-primary);
  box-shadow:0 0 0 3px rgba(249,115,22,.12);
}

.cbp-phone-row { display:flex; gap:12px; }
.cbp-phone-code { flex:0 0 120px; }
.cbp-phone-num  { flex:1; }

.cbp-two-col { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:480px){ .cbp-two-col{ grid-template-columns:1fr; } }

/* ─── FORM ACTIONS ─────────────────────────────────── */
.cbp-form-actions { display:flex; gap:12px; margin-top:20px; }

.cbp-submit-btn {
  flex:1;
  background:var(--cbp-primary); color:#fff;
  border:none; border-radius:12px;
  padding:14px 24px;
  font-size:15px; font-weight:700;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition: background var(--cbp-transition), transform var(--cbp-transition);
}
.cbp-submit-btn:hover { background:#ea6a0e; transform:translateY(-1px); }
.cbp-submit-btn:disabled { opacity:.7; cursor:not-allowed; }

.cbp-whatsapp-btn {
  flex-shrink:0;
  background:#25D366; color:#fff;
  border:none; border-radius:12px;
  padding:14px 18px;
  font-size:14px; font-weight:700;
  cursor:pointer;
  display:flex; align-items:center; gap:8px;
  transition: background var(--cbp-transition);
}
.cbp-whatsapp-btn:hover { background:#1ebe5d; }

/* ─── FORM MESSAGE ─────────────────────────────────── */
.cbp-form-message {
  padding:12px 16px; border-radius:10px;
  margin-bottom:16px; font-size:14px; font-weight:600;
}
.cbp-form-message.cbp-success { background:#DCFCE7; color:#15803D; }
.cbp-form-message.cbp-error   { background:#FEE2E2; color:#B91C1C; }

/* ─── SPIN ANIMATION ───────────────────────────────── */
@keyframes cbp-spin { to { transform:rotate(360deg); } }
.cbp-spin { animation:cbp-spin .7s linear infinite; }

/* ─── NO PACKAGES ──────────────────────────────────── */
.cbp-no-packages {
  text-align:center; color:var(--cbp-muted);
  padding:40px; background:var(--cbp-bg);
  border-radius:var(--cbp-radius);
}

/* ─── SCROLLBAR IN POPUP ───────────────────────────── */
.cbp-popup::-webkit-scrollbar { width:5px; }
.cbp-popup::-webkit-scrollbar-thumb { background:var(--cbp-border); border-radius:4px; }
.cbp-pagination { display:none !important; }
/* ─── SCROLLBAR IN POPUP ───────────────────────────── */
.cbp-popup::-webkit-scrollbar { width:5px; }
.cbp-popup::-webkit-scrollbar-thumb { background:var(--cbp-border); border-radius:4px; }
.cbp-pagination { display:none !important; }

/* ─── CRITICAL: Prevent popup bleeding ─────────────── */
.cbp-popup-overlay:not(.cbp-popup-open) {
  display: none !important;
  pointer-events: none !important;
  visibility: hidden !important;
}