/* widget.css - Capitara Light v2 (Modern + Animated) */
:root {
  --cap-white: #ffffff;
  --cap-surface: #f6f8fb;
  --cap-border: #e6eef8;
  --cap-text: #123243;
  --cap-muted: #6b7a86;
  --cap-accent: #007bff;
  --cap-radius: 14px;
  --cap-shadow: 0 8px 28px rgba(16, 24, 40, 0.12);
}

/* chat toggle button */
#capitara-chat-btn {
  position: fixed;
  right: 22px;
  bottom: 20px;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  background: linear-gradient(135deg, #2b8cff, #0066ff);
  color: #fff;
  box-shadow: 0 10px 30px rgba(11, 95, 235, 0.25);
  display: grid;
  place-items: center;
  font-size: 26px;
  z-index: 99999;
  border: none;
  cursor: pointer;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
#capitara-chat-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 12px 36px rgba(11, 95, 235, 0.35);
}

/* main window */
#capitara-chat-window {
  position: fixed;
  right: 22px;
  bottom: 96px;
  width: 360px;
  max-width: calc(100% - 40px);
  height: 520px;
  border-radius: var(--cap-radius);
  background: var(--cap-white);
  box-shadow: var(--cap-shadow);
  border: 1px solid var(--cap-border);
  color: var(--cap-text);
  display: none;
  flex-direction: column;
  overflow: hidden;
  z-index: 99998;
  font-family: "Inter", "Roboto", "Arial", sans-serif;
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.3s ease;
}
#capitara-chat-window.show {
  display: flex;
  opacity: 1;
  transform: translateY(0);
}

/* header */
.cap-header {
  padding: 14px;
  border-bottom: 1px solid var(--cap-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.cap-header .title {
  font-weight: 700;
  font-size: 15px;
  color: var(--cap-text);
}
.cap-header .sub {
  font-size: 13px;
  color: var(--cap-muted);
}
.cap-header button {
  background: none;
  border: none;
  color: var(--cap-muted);
  font-size: 18px;
  cursor: pointer;
  transition: color 0.2s ease;
}
.cap-header button:hover {
  color: var(--cap-accent);
}

/* body */
.cap-body {
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* session info */
.cap-session-info {
  padding: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--cap-border);
  font-size: 13px;
  color: var(--cap-muted);
}
.cap-edit {
  background: none;
  border: none;
  color: var(--cap-accent);
  font-weight: 600;
  cursor: pointer;
  font-size: 13px;
}

/* messages */
.cap-messages {
  padding: 12px;
  flex: 1;
  overflow-y: auto;
  background: linear-gradient(180deg, #ffffff, #f9fbff);
  scroll-behavior: smooth;
}
.cap-messages::-webkit-scrollbar {
  width: 6px;
}
.cap-messages::-webkit-scrollbar-thumb {
  background-color: #d6e0ef;
  border-radius: 3px;
}

/* bubbles */
.cap-msg {
  max-width: 78%;
  margin: 8px 0;
  animation: fadeInUp 0.25s ease both;
}
.cap-msg .bubble {
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 14px;
  line-height: 1.4;
  word-break: break-word;
  box-shadow: 0 4px 12px rgba(12, 30, 60, 0.05);
}
.cap-msg .who {
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 4px;
  color: var(--cap-muted);
}
.cap-msg.user {
  margin-left: auto;
}
.cap-msg.user .bubble {
  background: linear-gradient(90deg, #e8f2ff, #d9ebff);
  color: var(--cap-text);
}
.cap-msg.admin .bubble {
  background: #f1f6fb;
  border: 1px solid var(--cap-border);
  color: var(--cap-text);
}

/* pre-chat (name/email) */
.cap-prechat {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cap-prechat input {
  padding: 10px;
  border-radius: 10px;
  border: 1px solid var(--cap-border);
  outline: none;
  font-size: 14px;
  transition: border-color 0.2s ease;
}
.cap-prechat input:focus {
  border-color: var(--cap-accent);
}
.cap-prechat .start-btn {
  padding: 10px;
  border-radius: 10px;
  background: var(--cap-accent);
  color: #fff;
  border: none;
  cursor: pointer;
  font-weight: 700;
  transition: background 0.2s ease;
}
.cap-prechat .start-btn:hover {
  background: #0062e6;
}

/* input area */
.cap-input {
  padding: 10px 12px;
  border-top: 1px solid var(--cap-border);
  display: flex;
  gap: 8px;
  background: var(--cap-white);
}
.cap-input input[type="text"] {
  flex: 1;
  padding: 10px;
  border-radius: 10px;
  border: 1px solid var(--cap-border);
  outline: none;
  font-size: 14px;
  transition: border-color 0.2s ease;
}
.cap-input input:focus {
  border-color: var(--cap-accent);
}
.cap-input button {
  padding: 10px 16px;
  border-radius: 10px;
  border: none;
  background: var(--cap-accent);
  color: white;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s ease;
}
.cap-input button:hover {
  background: #0062e6;
}

/* animation */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* responsive */
@media (max-width: 420px) {
  #capitara-chat-window {
    right: 12px;
    left: 12px;
    width: auto;
    height: 70vh;
    bottom: 82px;
  }
  #capitara-chat-btn {
    right: 16px;
    bottom: 16px;
  }
}
