/* ============================================================
   KS Legal Chatbot — chatbot.css
   All classes prefixed with ksc- to avoid WordPress theme conflicts
   ============================================================ */
:root {
  --ksc-navy:      #1B2A4A;
  --ksc-navy-deep: #101a30;
  --ksc-gold:      #C9A35D;
  --ksc-gold-soft: #E8D5AC;
  --ksc-cream:     #FAF8F4;
  --ksc-slate:     #2D3142;
  --ksc-slate-soft:#6B7280;
  --ksc-line:      #E4DFD4;
  --ksc-success:   #2F6B4F;
  --ksc-danger:    #A4453A;
  --ksc-radius:    14px;
}
/* ── Launcher ───────────────────────────────────────────── */
.ksc-launcher {
  position: fixed;
  bottom: 28px;
  /*right: 28px;*/
  left: 28px;
  right: auto;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  /*background: var(--ksc-navy);*/

  background: linear-gradient(
  135deg,
  #1B2A4A,
  #2F4A7A
  );

  box-shadow:
  0 10px 35px rgba(27,42,74,.35),
  0 0 25px rgba(201,163,93,.35);

  border: 2px solid var(--ksc-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(16,26,48,.35);
  z-index: 999990;
  transition: transform .25s ease;
}
.ksc-launcher:hover { transform: scale(1.06); }
.ksc-launcher svg   { width: 28px; height: 28px; }
.ksc-pulse {
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  border: 2px solid var(--ksc-gold);
  animation: ksc-pulse 2.4s ease-out infinite;
}
@keyframes ksc-pulse {
  0%   { transform: scale(1);    opacity: .7; }
  100% { transform: scale(1.45); opacity: 0;  }
}


.ksc-launcher{
    position:fixed;
    overflow:visible;
}

.ksc-hello-bubble{
    position:absolute;
    left:75px;
    bottom:8px;

    background:#fff;
    color:#1B2A4A;

    padding:10px 14px;
    border-radius:14px;

    font-size:14px;
    font-weight:600;
    line-height:1.4;

    min-width:180px;
    max-width:240px;

    box-shadow:0 8px 25px rgba(0,0,0,.15);

    white-space:normal;
    z-index:999999;

    animation:kscBubbleFloat 3s ease-in-out infinite;
}

.ksc-hello-bubble::after{
    content:"";
    position:absolute;
    left:-8px;
    bottom:18px;

    width:16px;
    height:16px;

    background:#fff;
    transform:rotate(45deg);
}

@keyframes kscBubbleFloat{
    0%,100%{
        transform:translateY(0);
    }
    50%{
        transform:translateY(-4px);
    }
}

.ksc-launcher::after{
    content:"";
    position:absolute;
    top:4px;
    right:4px;
    width:12px;
    height:12px;
    border-radius:50%;
    background:#22c55e;
    border:2px solid white;
}


.ksc-launcher::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:50%;
    background:linear-gradient(
      120deg,
      transparent,
      rgba(255,255,255,.35),
      transparent
    );
    animation: shine 3s infinite;
}

@keyframes shine{
    from{
      transform:translateX(-120%);
    }
    to{
      transform:translateX(120%);
    }
}

@media(max-width:768px){

  .ksc-hello-bubble{
      left:70px;
      min-width:160px;
      max-width:200px;
      font-size:13px;
      padding:8px 12px;
  }

}







/* ── Panel ──────────────────────────────────────────────── */
.ksc-panel {
  position: fixed;
  bottom: 28px;
  left: 28px;
  width: 390px;
  max-width: calc(100vw - 24px);
  height: 640px;
  max-height: calc(100vh - 48px);
  background: var(--ksc-cream);
  border-radius: var(--ksc-radius);
  box-shadow: 0 24px 60px rgba(16,26,48,.28);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 999991;
  border: 1px solid var(--ksc-line);
  transform: translateY(16px) scale(.97);
  opacity: 0;
  pointer-events: none;
  transition: all .28s cubic-bezier(.2,.8,.2,1);
}
.ksc-panel.ksc-open {
  transform: translateY(0) scale(1);
  opacity: 1;
  pointer-events: auto;
}
/* ── Header ─────────────────────────────────────────────── */
.ksc-header {
  background: linear-gradient(135deg, var(--ksc-navy) 0%, var(--ksc-navy-deep) 100%);
  color: #fff;
  padding: 16px 16px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.ksc-back-btn {
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,.7); padding: 4px; line-height: 0;
  flex-shrink: 0; display: none;
}
.ksc-back-btn.ksc-show { display: flex; }
.ksc-back-btn:hover { color: #fff; }
.ksc-header-seal {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--ksc-gold);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ksc-header-seal svg { width: 20px; height: 20px; }
.ksc-header-info { flex: 1; min-width: 0; }
.ksc-header-title {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 1rem; font-weight: 700;
  margin: 0; line-height: 1.2; color: #fff;
}
.ksc-header-sub {
  margin: 2px 0 0;
  font-size: .72rem;
  color: rgba(255,255,255,.7);
  display: flex; align-items: center; gap: 5px;
  font-family: Arial, sans-serif;
}
.ksc-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #4ADE80; flex-shrink: 0; display: inline-block;
}
.ksc-close-btn {
  margin-left: auto;
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,.65); padding: 4px; line-height: 0;
}
.ksc-close-btn:hover { color: #fff; }
/* ── Progress ───────────────────────────────────────────── */
.ksc-progress-track {
  display: flex; gap: 6px;
  padding: 10px 18px;
  background: rgba(27,42,74,0.04);
  flex-shrink: 0;
  border-bottom: 1px solid var(--ksc-line);
}
.ksc-progress-track:empty { display: none; }
.ksc-progress-step {
  flex: 1; height: 4px; border-radius: 2px;
  background: var(--ksc-line); overflow: hidden; position: relative;
}
.ksc-progress-step.ksc-done,
.ksc-progress-step.ksc-active { background: var(--ksc-gold-soft); }
.ksc-progress-fill {
  position: absolute; inset: 0;
  background: var(--ksc-gold); width: 0%;
  transition: width .4s ease;
}
.ksc-progress-step.ksc-done  .ksc-progress-fill { width: 100%; }
.ksc-progress-step.ksc-active .ksc-progress-fill { width: 55%; }
/* ── Chat body ───────────────────────────────────────────── */
.ksc-body {
  flex: 1; overflow-y: auto;
  padding: 18px;
  display: flex; flex-direction: column;
  gap: 14px; scroll-behavior: smooth;
}
.ksc-body::-webkit-scrollbar { width: 6px; }
.ksc-body::-webkit-scrollbar-thumb { background: var(--ksc-line); border-radius: 3px; }
/* ── Messages ───────────────────────────────────────────── */
.ksc-row { display: flex; gap: 8px; max-width: 100%; animation: ksc-rise .3s ease; }
@keyframes ksc-rise {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.ksc-row.ksc-bot  { align-self: flex-start; }
.ksc-row.ksc-user { align-self: flex-end; flex-direction: row-reverse; }
.ksc-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--ksc-navy); color: var(--ksc-gold);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-family: Georgia, serif; font-weight: 700; font-size: .72rem;
}
.ksc-bubble {
  padding: 10px 14px; border-radius: 12px;
  font-size: .87rem; line-height: 1.45;
  max-width: 255px; font-family: Arial, sans-serif;
}
.ksc-row.ksc-bot  .ksc-bubble {
  background: #fff; border: 1px solid var(--ksc-line);
  color: var(--ksc-slate); border-top-left-radius: 4px;
}
.ksc-row.ksc-user .ksc-bubble {
  background: var(--ksc-navy); color: #fff;
  border-top-right-radius: 4px;
}
.ksc-typing {
  display: flex; gap: 4px;
  padding: 12px 14px;
  background: #fff; border: 1px solid var(--ksc-line);
  border-radius: 12px; border-top-left-radius: 4px;
  width: fit-content;
}
.ksc-typing span {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ksc-slate-soft);
  animation: ksc-blink 1.2s infinite ease-in-out;
}
.ksc-typing span:nth-child(2) { animation-delay: .2s; }
.ksc-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes ksc-blink { 0%,80%,100%{opacity:.25;} 40%{opacity:1;} }
/* ── Form cards ──────────────────────────────────────────── */
.ksc-card {
  background: #fff; border: 1px solid var(--ksc-line);
  border-radius: 12px; padding: 16px;
  display: flex; flex-direction: column; gap: 10px;
  align-self: stretch; animation: ksc-rise .3s ease;
}
.ksc-card label {
  font-size: .72rem; font-weight: 700; font-family: Arial, sans-serif;
  color: var(--ksc-slate-soft); text-transform: uppercase; letter-spacing: .04em;
}
.ksc-card input,
.ksc-card textarea,
.ksc-card select {
  width: 100%; padding: 10px 12px;
  border: 1px solid var(--ksc-line); border-radius: 8px;
  font-family: Arial, sans-serif; font-size: .88rem;
  color: var(--ksc-slate); background: var(--ksc-cream);
  outline: none; transition: border-color .15s ease;
  box-sizing: border-box;
}
.ksc-card input:focus,
.ksc-card textarea:focus,
.ksc-card select:focus {
  border-color: var(--ksc-gold); background: #fff;
}
.ksc-field-error {
  font-size: .72rem; color: var(--ksc-danger);
  display: none; font-family: Arial, sans-serif;
}
.ksc-field-error.ksc-show { display: block; }
/* ── Back link inside card ───────────────────────────────── */
.ksc-back-link {
  display: flex; align-items: center; gap: 5px;
  font-size: .74rem; color: var(--ksc-slate-soft);
  cursor: pointer; align-self: flex-start;
  font-family: Arial, sans-serif;
  background: none; border: none; padding: 0;
}
.ksc-back-link:hover { color: var(--ksc-navy); }
.ksc-back-link svg { width: 13px; height: 13px; }
/* ── Main menu ───────────────────────────────────────────── */
.ksc-menu-grid {
  display: flex; flex-direction: column; gap: 8px;
  align-self: stretch; animation: ksc-rise .3s ease;
}
.ksc-menu-btn {
  display: flex; align-items: center; gap: 12px;
  background: #fff; border: 1px solid var(--ksc-line);
  border-radius: 10px; padding: 13px 14px;
  cursor: pointer; text-align: left;
  font-family: Arial, sans-serif; transition: all .15s ease;
}
.ksc-menu-btn:hover { border-color: var(--ksc-gold); background: #fdf9ef; }
.ksc-menu-icon {
  width: 36px; height: 36px; border-radius: 8px; flex-shrink: 0;
  background: var(--ksc-cream); display: flex; align-items: center; justify-content: center;
}
.ksc-menu-icon svg { width: 18px; height: 18px; color: var(--ksc-navy); }
.ksc-menu-text strong { display: block; font-size: .86rem; color: var(--ksc-slate); }
.ksc-menu-text span   { display: block; font-size: .74rem; color: var(--ksc-slate-soft); margin-top: 1px; }
.ksc-menu-arrow { margin-left: auto; color: var(--ksc-slate-soft); flex-shrink: 0; font-size: 1.2rem; }
/* ── Practice areas ──────────────────────────────────────── */
.ksc-area-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.ksc-area-btn {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 14px 8px; border: 1.5px solid var(--ksc-line);
  border-radius: 10px; background: var(--ksc-cream);
  cursor: pointer; font-family: Arial, sans-serif;
  transition: all .15s ease; text-align: center;
}
.ksc-area-btn:hover { border-color: var(--ksc-gold-soft); background: #fdf9ef; }
.ksc-area-btn svg   { width: 20px; height: 20px; color: var(--ksc-navy); }
.ksc-area-btn span  { font-size: .78rem; font-weight: 700; color: var(--ksc-slate); }
/* ── FAQ ─────────────────────────────────────────────────── */
.ksc-faq-grid { display: flex; flex-direction: column; gap: 8px; align-self: stretch; }
.ksc-faq-btn {
  background: #fff; border: 1px solid var(--ksc-line);
  border-radius: 10px; padding: 11px 14px;
  text-align: left; cursor: pointer;
  font-size: .83rem; font-weight: 600;
  color: var(--ksc-slate); font-family: Arial, sans-serif;
  transition: all .15s ease;
}
.ksc-faq-btn:hover { border-color: var(--ksc-gold); background: #fdf9ef; }
/* ── Quick chips ─────────────────────────────────────────── */
.ksc-quick-row { display: flex; gap: 8px; flex-wrap: wrap; align-self: stretch; }
.ksc-quick-btn {
  background: #fff; border: 1px solid var(--ksc-line);
  border-radius: 20px; padding: 7px 13px;
  font-size: .78rem; cursor: pointer; color: var(--ksc-navy);
  font-family: Arial, sans-serif; font-weight: 600;
}
.ksc-quick-btn:hover { border-color: var(--ksc-gold); }
/* ── Slot picker ─────────────────────────────────────────── */
.ksc-slot-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ksc-slot-btn {
  padding: 9px 8px; border: 1px solid var(--ksc-line);
  border-radius: 8px; background: var(--ksc-cream);
  font-size: .8rem; cursor: pointer; text-align: center;
  transition: all .15s ease; font-family: Arial, sans-serif;
}
.ksc-slot-btn:hover { border-color: var(--ksc-gold); }
.ksc-slot-btn.ksc-selected { background: var(--ksc-navy); color: #fff; border-color: var(--ksc-navy); }
.ksc-slot-btn.ksc-taken    { opacity: .4; cursor: not-allowed; text-decoration: line-through; }
/* ── Channel choice ──────────────────────────────────────── */
.ksc-channel-choice { display: flex; gap: 10px; }
.ksc-channel-card {
  flex: 1; border: 1.5px solid var(--ksc-line);
  border-radius: 10px; padding: 14px 10px;
  text-align: center; cursor: pointer;
  transition: all .15s ease; background: var(--ksc-cream);
}
.ksc-channel-card:hover    { border-color: var(--ksc-gold-soft); }
.ksc-channel-card.ksc-sel  { border-color: var(--ksc-gold); background: #fdf9ef; }
.ksc-channel-card svg      { width: 22px; height: 22px; margin-bottom: 6px; }
.ksc-channel-card .ksc-wa-icon svg { color: #2F6B4F; }
.ksc-channel-card .ksc-em-icon svg { color: var(--ksc-navy); }
.ksc-channel-card span  { display: block; font-size: .78rem; font-weight: 700; margin-top: 4px; font-family: Arial, sans-serif; }
.ksc-channel-card small { display: block; font-size: .68rem; color: var(--ksc-slate-soft); margin-top: 2px; font-family: Arial, sans-serif; }
/* ── Buttons ─────────────────────────────────────────────── */
.ksc-btn-primary {
  background: var(--ksc-navy); color: #fff; border: none;
  border-radius: 8px; padding: 11px 16px;
  font-family: Arial, sans-serif; font-weight: 700; font-size: .86rem;
  cursor: pointer; transition: background .15s ease; width: 100%;
}
.ksc-btn-primary:hover    { background: var(--ksc-navy-deep); }
.ksc-btn-primary:disabled { background: #C9C4B6; cursor: not-allowed; }
.ksc-btn-secondary {
  background: none; border: 1px solid var(--ksc-line);
  color: var(--ksc-slate-soft); border-radius: 8px; padding: 9px 14px;
  font-size: .8rem; cursor: pointer; font-family: Arial, sans-serif;
}
.ksc-btn-row { display: flex; gap: 8px; }
.ksc-btn-row .ksc-btn-primary { flex: 1; }
/* ── File upload zone ────────────────────────────────────── */
.ksc-upload-zone {
  border: 1.5px dashed var(--ksc-line); border-radius: 10px;
  padding: 18px 12px; text-align: center; cursor: pointer;
  background: var(--ksc-cream); transition: all .15s ease;
}
.ksc-upload-zone:hover, .ksc-upload-zone.ksc-drag { border-color: var(--ksc-gold); background: #fdf9ef; }
.ksc-upload-zone svg { width: 22px; height: 22px; color: var(--ksc-slate-soft); margin-bottom: 6px; }
.ksc-upload-zone p   { margin: 0; font-size: .8rem; color: var(--ksc-slate-soft); font-family: Arial, sans-serif; }
.ksc-upload-zone p.ksc-main { color: var(--ksc-slate); font-weight: 600; margin-bottom: 2px; }
.ksc-file-list { display: flex; flex-direction: column; gap: 6px; }
.ksc-file-chip {
  display: flex; align-items: center; gap: 8px;
  background: var(--ksc-cream); border: 1px solid var(--ksc-line);
  border-radius: 8px; padding: 7px 10px; font-size: .78rem;
  font-family: Arial, sans-serif;
}
.ksc-file-chip .ksc-chip-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ksc-chip-remove {
  cursor: pointer; color: var(--ksc-danger); border: none;
  background: none; font-size: .95rem; padding: 2px;
}
/* ── Confirm card ────────────────────────────────────────── */
.ksc-confirm-card {
  background: #fff; border: 1px solid var(--ksc-line);
  border-radius: 12px; padding: 22px 18px;
  text-align: center; align-self: stretch; animation: ksc-rise .35s ease;
}
.ksc-confirm-seal {
  width: 64px; height: 64px; margin: 0 auto 12px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--ksc-gold-soft), var(--ksc-gold));
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--ksc-navy);
}
.ksc-confirm-seal svg { width: 28px; height: 28px; color: var(--ksc-navy); }
.ksc-confirm-card h2 {
  font-family: Georgia, serif; font-size: 1.05rem;
  color: var(--ksc-navy); margin: 0 0 6px;
}
.ksc-confirm-card p {
  font-size: .82rem; color: var(--ksc-slate-soft);
  margin: 0 0 14px; line-height: 1.5; font-family: Arial, sans-serif;
}
.ksc-booking-id-box {
  background: var(--ksc-navy); color: var(--ksc-gold-soft);
  border-radius: 8px; padding: 10px;
  font-family: Georgia, serif; font-weight: 700;
  letter-spacing: .06em; font-size: 1rem; margin-bottom: 14px;
}
.ksc-confirm-summary {
  text-align: left; background: var(--ksc-cream);
  border: 1px solid var(--ksc-line); border-radius: 8px;
  padding: 10px 12px; font-size: .78rem; color: var(--ksc-slate);
  margin-bottom: 14px; display: flex; flex-direction: column; gap: 4px;
  font-family: Arial, sans-serif;
}
.ksc-confirm-summary div { display: flex; justify-content: space-between; gap: 8px; }
.ksc-confirm-summary .ksc-lbl { color: var(--ksc-slate-soft); }
.ksc-sent-tags { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; margin-bottom: 14px; }
.ksc-sent-tag  {
  font-size: .72rem; font-weight: 700; padding: 4px 9px; border-radius: 20px;
  display: flex; align-items: center; gap: 4px; text-decoration: none;
  font-family: Arial, sans-serif;
}
.ksc-sent-tag.ksc-wa { background: #E7F2EC; color: var(--ksc-success); }
.ksc-sent-tag.ksc-em { background: #EAF0FB; color: var(--ksc-navy); }
.ksc-sent-tag svg { width: 11px; height: 11px; }
.ksc-advocate-note {
  display: flex; align-items: center; gap: 10px;
  background: var(--ksc-cream); border: 1px solid var(--ksc-gold-soft);
  border-radius: 10px; padding: 12px; text-align: left;
}
.ksc-advocate-note .ksc-av {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--ksc-navy); color: var(--ksc-gold);
  display: flex; align-items: center; justify-content: center;
  font-family: Georgia, serif; font-weight: 700; font-size: .85rem; flex-shrink: 0;
}
.ksc-advocate-note p { margin: 0; font-size: .8rem; color: var(--ksc-slate); line-height: 1.4; font-family: Arial, sans-serif; }
.ksc-advocate-note strong { color: var(--ksc-navy); }
/* ── Status result ───────────────────────────────────────── */
.ksc-status-result {
  background: #fff; border: 1px solid var(--ksc-line);
  border-radius: 10px; padding: 14px;
  align-self: stretch; animation: ksc-rise .3s ease;
}
.ksc-srow {
  display: flex; justify-content: space-between;
  font-size: .82rem; padding: 6px 0;
  border-bottom: 1px solid var(--ksc-line);
  font-family: Arial, sans-serif;
}
.ksc-srow:last-child { border-bottom: none; }
.ksc-srow .ksc-lbl  { color: var(--ksc-slate-soft); }
.ksc-status-pill {
  font-size: .7rem; font-weight: 700;
  padding: 3px 10px; border-radius: 20px;
  text-transform: uppercase; font-family: Arial, sans-serif;
}
.ksc-status-pill.ksc-pending  { background: #F7E6E3; color: var(--ksc-danger); }
.ksc-status-pill.ksc-review   { background: #F6EFDC; color: #9A7B22; }
.ksc-status-pill.ksc-approved { background: #E7F2EC; color: var(--ksc-success); }
.ksc-status-pill.ksc-rejected { background: #EDEAE4; color: var(--ksc-slate-soft); }
/* ── Spinner ──────────────────────────────────────────────── */
.ksc-spinner {
  width: 20px; height: 20px; border-radius: 50%;
  border: 2px solid var(--ksc-line);
  border-top-color: var(--ksc-navy);
  animation: ksc-spin .7s linear infinite;
  margin: 8px auto;
}
@keyframes ksc-spin { to { transform: rotate(360deg); } }
/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 480px) {
  .ksc-panel {
    bottom: 0; right: 0; left: 0;
    width: 100%; height: 100%; max-height: 100%;
    border-radius: 0;
  }
  .ksc-launcher {
    left: 18px;
    right: auto;
  }
}


/* Chatbot */
.ksc-launcher{
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 99999;
}

/* WhatsApp + Call Buttons */
.advocate-float-btns{
    position: fixed;
    right: 20px;
    bottom: 95px; /* chatbot ke upar */
    z-index: 99998;
    display:flex;
    flex-direction:column;
    gap:12px;
}


.float-call{
    background: linear-gradient(135deg,#C9A35D,#A67C2D);
}

/* Mobile */
@media(max-width:576px){

    .ksc-launcher{
        right:15px;
        bottom:15px;
    }

    .advocate-float-btns{
        right:15px;
        bottom:85px;
        gap:10px;
    }
}

.ksc-launcher{
   left:28px !important;
   right:auto !important;
}