/* TripsBox AI Concierge v2.0 — Widget Styles */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700;900&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root{
  --p:#0B6E4F;--a:#F5A623;--bg:#F7F9FC;--surface:#FFFFFF;
  --border:#E4EAF2;--text:#1A2638;--text2:#6B7C93;--text3:#A0AEC0;
  --radius:20px;--shadow:0 4px 24px rgba(0,0,0,.09);
  --font-ar:'Cairo',sans-serif;--font-en:'Plus Jakarta Sans',sans-serif;
  --h:560px;
}

#tba-widget{
  --p:var(--p);--a:var(--a);
  font-family:var(--font-ar);font-size:14.5px;color:var(--text);
  background:var(--surface);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  height:var(--h,560px);max-height:90vh;position:relative;
  box-shadow:var(--shadow);border:1px solid var(--border);
}
[dir="ltr"] #tba-widget{font-family:var(--font-en);}

/* ── Header ────────────────────────────────────────────────────────── */
.tba-header{
  background:linear-gradient(135deg,var(--p) 0%,color-mix(in srgb,var(--p) 80%,#000) 100%);
  color:#fff;padding:13px 16px;display:flex;align-items:center;
  justify-content:space-between;flex-shrink:0;
}
.tba-header-left{display:flex;align-items:center;gap:10px;}
.tba-avatar{
  width:42px;height:42px;background:rgba(255,255,255,.18);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.tba-bot-name{font-weight:700;font-size:15px;line-height:1.2;}
.tba-bot-status{display:flex;align-items:center;gap:5px;font-size:11.5px;opacity:.85;margin-top:2px;}
.tba-online-dot{width:7px;height:7px;background:#4ade80;border-radius:50%;animation:tba-pulse 2s infinite;}
@keyframes tba-pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.6;transform:scale(.85);}}
.tba-header-right{display:flex;align-items:center;gap:6px;}
.tba-lang-switch{display:flex;background:rgba(255,255,255,.12);border-radius:8px;overflow:hidden;}
.tba-lang-btn{background:none;border:none;color:rgba(255,255,255,.7);width:30px;height:26px;cursor:pointer;font-size:12px;font-weight:700;transition:all .2s;}
.tba-lang-btn.tba-active,.tba-lang-btn:hover{background:rgba(255,255,255,.25);color:#fff;}
.tba-header-btn{background:rgba(255,255,255,.15);border:none;color:#fff;width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.tba-header-btn:hover{background:rgba(255,255,255,.28);}

/* ── Weather strip ─────────────────────────────────────────────────── */
.tba-weather{
  background:linear-gradient(90deg,#0369A1 0%,#0284C7 100%);
  color:#fff;padding:8px 14px;display:flex;align-items:center;
  gap:10px;font-size:12.5px;flex-shrink:0;flex-wrap:wrap;
}
.tba-w-temp{font-weight:700;font-size:16px;}
.tba-w-detail{opacity:.85;}

/* ── Map ───────────────────────────────────────────────────────────── */
.tba-map{height:180px;flex-shrink:0;border-bottom:1px solid var(--border);}

/* ── Quest banner ──────────────────────────────────────────────────── */
.tba-quest-banner{
  background:linear-gradient(90deg,var(--a) 0%,#E8890A 100%);
  color:#fff;padding:9px 14px;display:flex;align-items:center;
  gap:8px;flex-shrink:0;
}
.tba-quest-emo{font-size:22px;flex-shrink:0;}
.tba-quest-text{flex:1;min-width:0;}
.tba-quest-text b{display:block;font-size:13px;font-weight:700;}
.tba-quest-text span{font-size:11.5px;opacity:.9;}
.tba-quest-btn{background:#fff;color:var(--a);border:none;border-radius:20px;padding:5px 14px;font-weight:700;font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0;font-family:inherit;}
.tba-quest-btn:hover{transform:scale(1.04);}
.tba-quest-close{background:none;border:none;color:rgba(255,255,255,.7);font-size:16px;cursor:pointer;padding:0 4px;flex-shrink:0;}

/* ── Messages ──────────────────────────────────────────────────────── */
.tba-messages{
  flex:1;overflow-y:auto;padding:14px 14px 6px;
  display:flex;flex-direction:column;gap:10px;background:var(--bg);
}
.tba-messages::-webkit-scrollbar{width:4px;}
.tba-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}

.tba-msg{display:flex;align-items:flex-end;gap:7px;max-width:88%;}
.tba-msg-bot{align-self:flex-start;}
.tba-msg-user{align-self:flex-end;flex-direction:row-reverse;}
[dir="rtl"] .tba-msg-user{flex-direction:row;}
[dir="rtl"] .tba-msg-bot{flex-direction:row-reverse;}

.tba-msg-av{width:28px;height:28px;background:var(--p);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.tba-bubble{
  background:var(--surface);border-radius:16px 16px 16px 4px;
  padding:9px 13px;box-shadow:0 1px 4px rgba(0,0,0,.07);
  font-size:13.5px;line-height:1.6;max-width:100%;word-break:break-word;
}
.tba-msg-user .tba-bubble{background:var(--p);color:#fff;border-radius:16px 16px 4px 16px;}
[dir="rtl"] .tba-bubble{border-radius:16px 16px 4px 16px;}
[dir="rtl"] .tba-msg-user .tba-bubble{border-radius:16px 16px 16px 4px;}

.tba-typing span{display:inline-block;width:6px;height:6px;background:var(--text3);border-radius:50%;margin:0 2px;animation:tba-bounce .9s infinite;}
.tba-typing span:nth-child(2){animation-delay:.15s;}
.tba-typing span:nth-child(3){animation-delay:.3s;}
@keyframes tba-bounce{0%,80%,100%{transform:translateY(0);}40%{transform:translateY(-6px);}}

/* ── Hotel card ────────────────────────────────────────────────────── */
.tba-hotel-card{
  background:var(--surface);border-radius:14px;
  box-shadow:0 2px 14px rgba(0,0,0,.10);overflow:hidden;
  width:100%;max-width:310px;align-self:flex-start;
}
[dir="rtl"] .tba-hotel-card{align-self:flex-end;}
.tba-card-img{width:100%;height:120px;object-fit:cover;display:block;}
.tba-card-img-ph{width:100%;height:80px;background:linear-gradient(135deg,var(--p),#0E9F7E);display:flex;align-items:center;justify-content:center;font-size:36px;}
.tba-card-body{padding:10px 12px;}
.tba-card-top{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:5px;}
.tba-card-name{font-weight:700;font-size:13.5px;flex:1;min-width:0;}
.tba-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;white-space:nowrap;}
.tba-badge-local{background:#DCFCE7;color:#166534;}
.tba-badge-ext{background:#FEF3C7;color:#92400E;}
.tba-card-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:11.5px;color:var(--text2);margin-bottom:5px;}
.tba-card-highlight{background:#F0FDF4;color:#166534;font-size:11.5px;padding:5px 8px;border-radius:8px;margin-bottom:6px;}
.tba-card-price{font-size:12.5px;color:var(--text2);margin-bottom:8px;}
.tba-card-price strong{color:var(--p);font-size:14px;}
.tba-card-actions{display:flex;gap:7px;flex-wrap:wrap;}
.tba-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:10px;font-size:12px;font-weight:600;text-decoration:none;border:none;cursor:pointer;font-family:inherit;transition:all .15s;}
.tba-btn-view{background:var(--p);color:#fff;}
.tba-btn-view:hover{background:color-mix(in srgb,var(--p) 85%,#000);color:#fff;}
.tba-btn-wa{background:#25D366;color:#fff;}
.tba-btn-wa:hover{background:#1da851;}

/* ── External suggestions ──────────────────────────────────────────── */
.tba-suggestions{background:var(--surface);border-radius:12px;padding:10px 12px;box-shadow:0 1px 6px rgba(0,0,0,.07);max-width:310px;width:100%;align-self:flex-start;}
[dir="rtl"] .tba-suggestions{align-self:flex-end;}
.tba-sugg-title{font-weight:700;font-size:12.5px;margin-bottom:7px;color:var(--text2);}
.tba-sugg-link{display:flex;flex-direction:column;text-decoration:none;padding:7px 8px;border-radius:8px;transition:background .15s;color:var(--text);}
.tba-sugg-link:hover{background:var(--bg);}
.tba-sugg-src{font-size:10.5px;color:var(--text3);margin-top:2px;}
.tba-sugg-note{font-size:11px;color:var(--a);margin-top:1px;}

/* ── WhatsApp CTA ──────────────────────────────────────────────────── */
.tba-wa-bubble{background:linear-gradient(135deg,#075E54,#128C7E) !important;color:#fff !important;padding:14px !important;}
.tba-wa-title{font-weight:700;font-size:15px;margin-bottom:4px;}
.tba-wa-sub{font-size:12px;opacity:.85;margin-bottom:12px;}
.tba-wa-btn{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:#fff;text-decoration:none;padding:10px 18px;border-radius:30px;font-weight:700;font-size:13px;transition:transform .15s;}
.tba-wa-btn:hover{transform:scale(1.04);color:#fff;}

/* ── Input area ────────────────────────────────────────────────────── */
.tba-input-wrap{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;}
.tba-chips{display:flex;gap:5px;padding:8px 12px 4px;overflow-x:auto;scrollbar-width:none;}
.tba-chips::-webkit-scrollbar{display:none;}
.tba-chip{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:12px;cursor:pointer;white-space:nowrap;font-family:inherit;transition:all .15s;}
.tba-chip:hover{background:var(--p);color:#fff;border-color:var(--p);}
.tba-input-row{display:flex;align-items:flex-end;padding:7px 12px 8px;gap:8px;}
.tba-input{flex:1;border:1.5px solid var(--border);border-radius:22px;padding:8px 15px;font-size:13.5px;resize:none;outline:none;font-family:inherit;line-height:1.45;max-height:110px;background:var(--bg);color:var(--text);transition:border-color .2s;}
.tba-input:focus{border-color:var(--p);background:#fff;}
.tba-send-btn{width:38px;height:38px;border-radius:50%;background:var(--p);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;}
.tba-send-btn:hover{transform:scale(1.06);background:color-mix(in srgb,var(--p) 85%,#000);}
.tba-provider-badge{text-align:center;padding:0 12px 5px;font-size:10px;color:var(--text3);}

/* ── Quest Modal ───────────────────────────────────────────────────── */
.tba-quest-modal{
  position:absolute;inset:0;background:rgba(15,20,35,.55);
  display:flex;align-items:center;justify-content:center;
  z-index:100;border-radius:var(--radius);backdrop-filter:blur(4px);
}
.tba-quest-card{background:#fff;border-radius:18px;width:calc(100% - 40px);max-width:320px;padding:22px;box-shadow:0 12px 40px rgba(0,0,0,.25);}
.tba-quest-progress{display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.tba-qstep{width:30px;height:30px;border-radius:50%;background:var(--bg);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text2);transition:all .3s;flex-shrink:0;}
.tba-qstep.active{background:var(--p);border-color:var(--p);color:#fff;}
.tba-qstep.done{background:#22C55E;border-color:#22C55E;color:#fff;}
.tba-qline{flex:1;height:2px;background:var(--border);max-width:36px;}
.tba-quest-q{font-size:15px;font-weight:700;margin-bottom:14px;text-align:center;line-height:1.4;}
.tba-quest-opts{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;}
.tba-quest-opt{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:9px 14px;font-size:12.5px;cursor:pointer;transition:all .15s;font-family:inherit;}
.tba-quest-opt:hover{background:var(--p);color:#fff;border-color:var(--p);}
.tba-quest-win{text-align:center;padding:10px 0;}
.tba-quest-trophy{font-size:50px;animation:tba-trophy .5s ease;}
@keyframes tba-trophy{0%{transform:scale(0);}60%{transform:scale(1.2);}100%{transform:scale(1);}}
.tba-quest-win-title{font-size:18px;font-weight:800;color:var(--p);margin:8px 0;}
.tba-quest-prize{font-size:13px;color:var(--text2);margin-bottom:16px;line-height:1.5;}
.tba-quest-go{background:var(--p);color:#fff;border:none;border-radius:26px;padding:11px 26px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:transform .15s;}
.tba-quest-go:hover{transform:scale(1.04);}

/* ── Travel Card Panel ─────────────────────────────────────────────── */
.tba-card-panel{
  position:absolute;inset:0;background:rgba(15,20,35,.55);
  display:flex;align-items:flex-end;justify-content:center;
  z-index:99;border-radius:var(--radius);backdrop-filter:blur(3px);
}
.tba-card-panel-inner{background:#fff;border-radius:18px 18px 0 0;width:100%;padding:20px;position:relative;max-height:90%;overflow-y:auto;}
.tba-panel-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:20px;cursor:pointer;color:var(--text2);}
[dir="rtl"] .tba-panel-close{right:auto;left:14px;}
.tba-cp-title{font-size:17px;font-weight:800;margin-bottom:5px;}
.tba-cp-sub{font-size:12.5px;color:var(--text2);margin-bottom:14px;}
.tba-cp-input{width:100%;box-sizing:border-box;border:1.5px solid var(--border);border-radius:10px;padding:9px 13px;font-size:13px;font-family:inherit;margin-bottom:9px;outline:none;}
.tba-cp-input:focus{border-color:var(--p);}
.tba-cp-btn{width:100%;background:var(--p);color:#fff;border:none;border-radius:12px;padding:11px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;}
.tba-cp-btn:hover{opacity:.9;}
.tba-cp-msg{font-size:12px;margin-top:7px;min-height:16px;}
.tba-cp-actions{display:flex;gap:8px;margin-top:12px;}
.tba-cp-btn-sm{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:9px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;color:var(--text);transition:all .15s;}
.tba-cp-btn-sm:hover{background:var(--p);color:#fff;border-color:var(--p);}
.tba-cp-btn-wa{background:#25D366 !important;color:#fff !important;border-color:#25D366 !important;}

/* ── Travel Card Visual ────────────────────────────────────────────── */
.tba-travel-card{
  background:linear-gradient(135deg,var(--p) 0%,color-mix(in srgb,var(--p) 60%,#000) 100%);
  border-radius:16px;padding:18px;color:#fff;position:relative;overflow:hidden;margin-bottom:4px;
}
.tba-travel-card::before{content:'';position:absolute;top:-40px;right:-40px;width:130px;height:130px;background:rgba(255,255,255,.08);border-radius:50%;}
.tba-travel-card::after{content:'';position:absolute;bottom:-30px;left:-20px;width:100px;height:100px;background:rgba(255,255,255,.05);border-radius:50%;}
.tba-tc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.tba-tc-logo{font-weight:900;font-size:14px;}
.tba-tc-tier{background:var(--tier-color,#6B7280);padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.tba-tc-name{font-size:16px;font-weight:700;margin-bottom:4px;}
.tba-tc-code{font-size:12px;opacity:.75;letter-spacing:.06em;margin-bottom:10px;font-family:monospace;}
.tba-tc-pts{font-size:22px;font-weight:900;}
.tba-tc-pts span{font-size:13px;font-weight:400;opacity:.8;}
.tba-tc-bar{height:5px;background:rgba(255,255,255,.2);border-radius:3px;margin:5px 0 3px;}
.tba-tc-bar-fill{height:100%;background:var(--a);border-radius:3px;transition:width .4s;}
.tba-tc-next{font-size:10.5px;opacity:.7;margin-bottom:8px;}
.tba-tc-bookings{font-size:11.5px;opacity:.7;}
.tba-cp-disc{background:rgba(255,255,255,.15);border-radius:8px;padding:6px 10px;font-size:12px;margin-bottom:6px;}

/* ── Leaflet override ──────────────────────────────────────────────── */
.leaflet-container{font-family:inherit;}

/* ── Responsive ────────────────────────────────────────────────────── */
@media(max-width:480px){
  #tba-widget{border-radius:0;height:100vh;max-height:100vh;}
  .tba-hotel-card,.tba-suggestions{max-width:100%;}
}
