/* ════════════════════════════════════════════════
   URIGOD.GE — Smart Chatbot (Enhanced & Modern UI)
   chatbot.css
   ════════════════════════════════════════════════ */

.cb-trigger {
  position: fixed;
  bottom: 28px; right: 28px; z-index: 8000;
  width: 62px; height: 62px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan) 0%, #00b39e 100%); 
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
  box-shadow: 0 4px 24px rgba(0,229,200,.45), 0 2px 10px rgba(0,0,0,.4), inset 0 -3px 6px rgba(0,0,0,.15);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .25s, filter .3s;
  outline: none;
}
.cb-trigger::before {
  content: ''; position: absolute; inset: -4px; border-radius: 50%;
  border: 1px solid var(--cyan); opacity: 0;
  transition: .3s;
}
.cb-trigger:hover { transform: scale(1.08); box-shadow: 0 8px 32px rgba(0,229,200,.6); }
.cb-trigger:hover::before { opacity: 0.5; transform: scale(1.15); animation: pulseRing 1.5s infinite; }
.cb-trigger.open  { transform: scale(.9) rotate(15deg); filter: brightness(0.8); }

@keyframes pulseRing {
  0% { transform: scale(1); opacity: 0.5; }
  100% { transform: scale(1.3); opacity: 0; }
}

.cb-badge {
  position: absolute; top: -2px; right: -2px;
  width: 22px; height: 22px; background: #ff3d6b;
  border-radius: 50%; border: 3px solid var(--bg);
  font-size: 10px; font-weight: 800; color: #fff;
  display: none; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(255,61,107,.5);
}
.cb-badge.show { display: flex; animation: popIn .4s cubic-bezier(.34,1.56,.64,1); }

@keyframes popIn { 0% {transform:scale(0)} 100% {transform:scale(1)} }

/* Window */
.cb-window {
  position: fixed; bottom: 105px; right: 28px; z-index: 7999;
  width: 390px; max-height: 680px;
  background: var(--bg3); border: 1px solid var(--bdr2);
  border-radius: 24px; display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.6), 0 4px 20px rgba(0,0,0,.35);
  opacity: 0; transform: translateY(20px) scale(.95); pointer-events: none;
  transition: opacity .28s ease, transform .32s cubic-bezier(.34,1.3,.64,1);
}
body.light .cb-window { box-shadow: 0 16px 60px rgba(0,0,0,.15); }
.cb-window.open { opacity: 1; transform: translateY(0) scale(1); pointer-events: all; }

/* Header */
.cb-header {
  padding: 16px 18px 14px; border-bottom: 1px solid rgba(255,255,255,0.05);
  display: flex; align-items: center; gap: 12px; flex-shrink: 0;
  background: rgba(18, 18, 18, 0.85); /* Glass Effect */
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  z-index: 2;
}
body.light .cb-header { background: rgba(255, 255, 255, 0.85); border-bottom: 1px solid var(--bdr); }

.cb-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan-d) 0%, var(--bg3) 100%); 
  border: 2px solid var(--cyan);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; flex-shrink: 0; position: relative;
  box-shadow: 0 0 12px rgba(0,229,200,.3);
}
.cb-avatar::after {
  content: ''; position: absolute; bottom: -2px; right: -2px;
  width: 13px; height: 13px; background: #22c55e;
  border-radius: 50%; border: 3px solid var(--bg3);
}
.cb-hinfo { flex: 1; min-width: 0; }
.cb-hname { font-family: var(--font-serif,'Playfair Display',serif); font-size: 16px; font-weight: 800; margin-bottom: 2px; }
.cb-hstatus { font-size: 11px; color: var(--t2); font-weight: 500; }
.cb-hclose {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--glass); border: 1px solid var(--bdr);
  display: flex; align-items: center; justify-content: center;
  color: var(--t2); font-size: 14px; cursor: pointer; flex-shrink: 0;
  transition: all .2s;
}
.cb-hclose:hover { background: rgba(255,61,107,.15); color: #ff3d6b; border-color: rgba(255,61,107,.3); transform: rotate(90deg); }

/* Messages */
.cb-messages {
  flex: 1; overflow-y: auto; padding: 16px 16px;
  display: flex; flex-direction: column; gap: 12px;
  scroll-behavior: smooth;
  scrollbar-width: thin; scrollbar-color: var(--bdr2) transparent;
}
.cb-messages::-webkit-scrollbar { width: 4px; }
.cb-messages::-webkit-scrollbar-thumb { background: var(--bdr2); border-radius: 2px; }

.cb-msg { display: flex; gap: 10px; animation: cbIn .35s cubic-bezier(.34,1.3,.64,1) both; }
@keyframes cbIn { from { opacity:0; transform:translateY(12px) scale(.97); } to { opacity:1; transform:none; } }
.cb-msg.user { flex-direction: row-reverse; }

.cb-avi {
  width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0; margin-top: 4px;
}
.cb-msg.bot  .cb-avi { background: var(--cyan-d);  border: 1px solid var(--bdr-cyan); }
.cb-msg.user .cb-avi { background: var(--glass2);  border: 1px solid var(--bdr2); }

.cb-bubble {
  max-width: 82%; padding: 12px 16px;
  font-size: 13.5px; line-height: 1.55; border-radius: 20px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}
.cb-msg.bot  .cb-bubble { 
  background: var(--bg2); border: 1px solid var(--bdr); 
  border-bottom-left-radius: 4px; color: var(--t1); 
}
.cb-msg.user .cb-bubble { 
  background: linear-gradient(135deg, var(--cyan) 0%, #00b39e 100%); 
  color: #080808; font-weight: 600; border-bottom-right-radius: 4px; 
}

/* Typing dots */
.cb-dots { display: flex; gap: 5px; padding: 4px 2px; align-items: center; }
.cb-dots span { width: 7px; height: 7px; background: var(--t3); border-radius: 50%; animation: cbDot 1.1s ease infinite; }
.cb-dots span:nth-child(2) { animation-delay: .18s; }
.cb-dots span:nth-child(3) { animation-delay: .36s; }
@keyframes cbDot { 0%,60%,100%{transform:translateY(0);opacity:.4} 30%{transform:translateY(-6px);opacity:1} }

/* Result card */
.cb-card {
  background: var(--bg3); border: 1px solid var(--bdr);
  border-radius: 16px; overflow: hidden; margin-top: 4px;
  transition: all .3s; box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.cb-card:hover { border-color: var(--cyan); box-shadow: 0 6px 20px rgba(0,229,200,.15); transform: translateY(-2px); }
.cb-card-img { width: 100%; height: 80px; object-fit: cover; display: block; border-bottom: 1px solid var(--bdr); }
.cb-card-no-img { height: 60px; background: var(--bg2); display: flex; align-items: center; justify-content: center; font-size: 32px; }
.cb-card-body { padding: 12px 14px; }
.cb-card-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.cb-card-name { font-weight: 800; font-size: 15px; }
.cb-card-rating { font-size: 12px; font-weight: 800; color: #ffc107; background: rgba(255,193,7,.1); padding: 2px 8px; border-radius: 10px;}
.cb-card-meta { font-size: 12.5px; color: var(--t2); margin-bottom: 10px; line-height: 1.5; }
.cb-card-actions { display: flex; gap: 8px; }
.cb-card-btn {
  flex: 1; padding: 8px 10px; border-radius: 12px; font-size: 12.5px; font-weight: 700;
  cursor: pointer; text-align: center; text-decoration: none; border: none;
  font-family: inherit; display: flex; align-items: center; justify-content: center;
  gap: 6px; transition: all .2s;
}
.cb-card-btn.p { background: var(--cyan); color: #080808; }
.cb-card-btn.p:hover { filter: brightness(1.15); transform: translateY(-1px); }
.cb-card-btn.g { background: var(--glass); border: 1px solid var(--bdr); color: var(--t2); }
.cb-card-btn.g:hover { color: var(--t1); background: var(--glass2); border-color: var(--t3); }

/* Quick replies */
.cb-qrs { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.cb-qr {
  padding: 6px 14px; border-radius: 100px; font-size: 12.5px; font-weight: 600;
  background: rgba(255,255,255,0.03); border: 1px solid var(--bdr); color: var(--t2);
  cursor: pointer; transition: all .2s; backdrop-filter: blur(4px);
}
body.light .cb-qr { background: rgba(0,0,0,0.03); }
.cb-qr:hover { background: var(--cyan-d); border-color: var(--cyan); color: var(--cyan); transform: translateY(-1px); }

/* ── Form panel ──────────────────────────────── */
.cb-form-panel {
  border-top: 1px solid var(--bdr); background: var(--bg2);
  flex-shrink: 0; overflow-y: auto; max-height: 320px;
  scrollbar-width: thin; scrollbar-color: var(--bdr2) transparent;
}
.cb-form-inner { padding: 16px 18px 6px; display: flex; flex-direction: column; gap: 14px; }

.cb-fl { display: flex; flex-direction: column; gap: 6px; }
.cb-fl-lbl { font-size: 11.5px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; color: var(--t3); }

.cb-ti {
  width: 100%; background: var(--bg3); border: 1px solid var(--bdr);
  border-radius: 12px; padding: 10px 14px; font-size: 13.5px; font-weight: 500;
  color: var(--t1); outline: none; font-family: inherit;
  transition: all .25s;
}
.cb-ti:focus { border-color: var(--cyan); box-shadow: 0 0 0 4px rgba(0,229,200,.15); background: var(--bg); }
.cb-ti::placeholder { color: var(--t3); font-weight: 400; }

/* Budget */
.cb-budget { display: flex; gap: 10px; align-items: center; }
.cb-budget .cb-ti { flex: 1; }
.cb-budget-lari { font-size: 16px; color: var(--cyan); font-weight: 800; flex-shrink: 0; }

/* Tags */
.cb-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.cb-tag {
  padding: 6px 14px; border-radius: 100px; font-size: 12.5px; font-weight: 600;
  background: var(--glass); border: 1px solid var(--bdr); color: var(--t2);
  cursor: pointer; transition: all .2s; user-select: none;
}
.cb-tag.sel { background: var(--cyan-d); border-color: var(--cyan); color: var(--cyan); box-shadow: 0 2px 8px rgba(0,229,200,.2); }
.cb-tag:hover:not(.sel) { background: var(--glass2); color: var(--t1); }

/* Checkboxes */
.cb-checks { display: flex; flex-wrap: wrap; gap: 10px 16px; margin-top: 4px; }
.cb-chk {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 500; color: var(--t2); cursor: pointer; transition: color .2s;
}
.cb-chk:hover { color: var(--t1); }
.cb-chk input { width: 16px; height: 16px; accent-color: var(--cyan); cursor: pointer; }

/* People */
.cb-people { display: flex; gap: 8px; flex-wrap: wrap; }
.cb-pnum {
  min-width: 40px; height: 40px; border-radius: 50%; 
  background: var(--glass); border: 1px solid var(--bdr);
  font-size: 14px; font-weight: 700; color: var(--t2);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .2s; user-select: none;
}
.cb-pnum.sel { background: var(--cyan-d); border-color: var(--cyan); color: var(--cyan); transform: scale(1.05); box-shadow: 0 4px 10px rgba(0,229,200,.2); }
.cb-pnum:hover:not(.sel) { background: var(--glass2); color: var(--t1); }

/* Submit */
.cb-form-foot { padding: 12px 18px 16px; }
.cb-submit {
  width: 100%; padding: 14px; border-radius: 14px;
  background: linear-gradient(135deg, var(--cyan) 0%, #00b39e 100%);
  color: #080808; font-size: 15px; font-weight: 800; border: none;
  cursor: pointer; font-family: inherit;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: all .2s; box-shadow: 0 4px 16px rgba(0,229,200,.3);
}
.cb-submit:hover { filter: brightness(1.15); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,229,200,.4); }
.cb-submit:active { transform: scale(.97); box-shadow: none; }

/* Free chat row */
.cb-free {
  display: flex; gap: 10px; padding: 14px 18px; flex-shrink: 0;
  border-top: 1px solid var(--bdr); background: var(--bg2);
}
.cb-free-in {
  flex: 1; background: var(--bg3); border: 1px solid var(--bdr);
  border-radius: 100px; padding: 12px 18px; font-size: 14px; font-weight: 500;
  color: var(--t1); outline: none; font-family: inherit;
  transition: all .2s;
}
.cb-free-in:focus { border-color: var(--cyan); box-shadow: 0 0 0 4px rgba(0,229,200,.15); }
.cb-free-in::placeholder { color: var(--t3); font-weight: 400; }
.cb-free-btn {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan) 0%, #00b39e 100%); 
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: #080808; flex-shrink: 0;
  transition: all .25s cubic-bezier(.34,1.56,.64,1);
  box-shadow: 0 4px 12px rgba(0,229,200,.3);
}
.cb-free-btn:hover { filter: brightness(1.15); transform: scale(1.1) rotate(-10deg); }
.cb-free-btn:active { transform: scale(.92); }

@media (max-width: 440px) {
  .cb-window { width: calc(100vw - 32px); right: 16px; bottom: 96px; border-radius: 20px; }
  .cb-trigger { right: 16px; bottom: 16px; width: 56px; height: 56px; font-size: 24px; }
}