/* CSS Variables */
:root {
  --cw-accent: #4f46e5;
  --cw-bg-primary: #ffffff;
  --cw-bg-secondary: #f9fafb;
  --cw-text-primary: #0f172a;
  --cw-text-secondary: #6b7280;
  --cw-border: #e5e7eb;
  --cw-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --cw-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --cw-radius: 16px;
  --cw-btn-size: 56px;
  --cw-btn-gap: 12px;
  --cw-z-index: 999999;
}

/* Base Reset */
.chat-widget-container,
.chat-widget-container * { box-sizing: border-box; margin: 0; padding: 0; }

/* Main Container */
.chat-widget-container {
  position: fixed; bottom: 24px; right: 24px; z-index: var(--cw-z-index);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-size: 14px; line-height: 1.5; color: var(--cw-text-primary);
}
.chat-widget-container.position-left { right: auto; left: 24px; }

/* Floating Panel - Buttons */
.chat-widget-panel { display: flex; flex-direction: column-reverse; gap: var(--cw-btn-gap); align-items: center; }
.chat-widget-btn {
  width: var(--cw-btn-size); height: var(--cw-btn-size); min-width: var(--cw-btn-size); min-height: var(--cw-btn-size);
  border-radius: 50%; border: none; background: var(--cw-accent); color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center; box-shadow: var(--cw-shadow);
  transition: transform .2s ease, box-shadow .2s ease; position: relative; overflow: visible;
}
.chat-widget-btn:hover { transform: scale(1.05); box-shadow: var(--cw-shadow-lg); }
.chat-widget-btn:active { transform: scale(0.95); }
.chat-widget-btn:focus { outline: 2px solid var(--cw-accent); outline-offset: 2px; }
.chat-widget-btn svg { width: 24px; height: 24px; fill: currentColor; }

/* Messenger Buttons - Specific Colors */
.chat-widget-btn[data-messenger="telegram"]{ background:#0088cc; }
.chat-widget-btn[data-messenger="whatsapp"]{ background:#25d366; }
.chat-widget-btn[data-messenger="viber"]{ background:#7360f2; }
.chat-widget-btn[data-messenger="messenger"]{ background:#0084ff; }

/* Pulse Animation */
@keyframes pulse { 0%,100%{ transform:scale(1); opacity:1;} 50%{ transform:scale(1.05); opacity:.9;} }
.chat-widget-btn.pulse{ animation:pulse 2s ease-in-out infinite; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .chat-widget-btn.pulse{ animation:none; }
  .chat-widget-btn,.chat-widget-window,.chat-widget-message{ transition:none!important; animation:none!important; }
}

/* Chat Window (animate with visibility/pointer-events, not display) */
.chat-widget-window{
  position: fixed; bottom: 96px; right: 24px; width: 360px; height: 480px;
  background: var(--cw-bg-primary); border-radius: var(--cw-radius); box-shadow: var(--cw-shadow-lg);
  display: flex; flex-direction: column; overflow: hidden;
  opacity: 0; transform: translateY(20px) scale(0.95); transition: opacity .2s ease, transform .2s ease;
  visibility: hidden; pointer-events: none;
}
.chat-widget-container.position-left .chat-widget-window{ right:auto; left:24px; }
.chat-widget-window.visible{ opacity:1; transform:translateY(0) scale(1); visibility:visible; pointer-events:auto; }

/* Header */
.chat-widget-header{
  padding:16px 20px; background:var(--cw-bg-primary); border-bottom:1px solid var(--cw-border);
  display:flex; align-items:center; gap:12px; min-height:64px;
}
.chat-widget-brand-indicator{ width:10px; height:10px; border-radius:50%; background:var(--cw-accent); flex-shrink:0; }
.chat-widget-header-content{ flex:1; min-width:0; }
.chat-widget-header-title{ font-size:16px; font-weight:600; color:var(--cw-text-primary); margin:0 0 2px 0; }
.chat-widget-header-subtitle{ font-size:13px; color:var(--cw-text-secondary); margin:0; }
.chat-widget-close-btn{
  width:32px; height:32px; min-width:32px; border:none; background:transparent; color:var(--cw-text-secondary);
  cursor:pointer; border-radius:8px; display:flex; align-items:center; justify-content:center;
  transition: background .2s ease, color .2s ease; flex-shrink:0;
}
.chat-widget-close-btn:hover{ background:var(--cw-bg-secondary); color:var(--cw-text-primary); }
.chat-widget-close-btn:focus{ outline:2px solid var(--cw-accent); outline-offset:2px; }
.chat-widget-close-btn svg{ width:20px; height:20px; }

/* Body */
.chat-widget-body{
  flex:1; overflow-y:auto; padding:16px; background:var(--cw-bg-secondary);
  display:flex; flex-direction:column; gap:12px;
}
.chat-widget-body::-webkit-scrollbar{ width:6px; }
.chat-widget-body::-webkit-scrollbar-track{ background:transparent; }
.chat-widget-body::-webkit-scrollbar-thumb{ background:var(--cw-border); border-radius:3px; }
.chat-widget-body::-webkit-scrollbar-thumb:hover{ background:var(--cw-text-secondary); }

/* Messages */
.chat-widget-message{ display:flex; gap:8px; animation:slideIn .2s ease; }
@keyframes slideIn{ from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:translateY(0);} }
.chat-widget-message.user{ flex-direction:row-reverse; }
.chat-widget-message-bubble{
  max-width:75%; padding:10px 14px; border-radius:12px; word-wrap:break-word; word-break:break-word;
}
.chat-widget-message-bubble a{ color:inherit; }
.chat-widget-message.operator .chat-widget-message-bubble{ background:var(--cw-bg-primary); color:var(--cw-text-primary); border-bottom-left-radius:4px; }
.chat-widget-message.user .chat-widget-message-bubble{ background:var(--cw-accent); color:#fff; border-bottom-right-radius:4px; }
.chat-widget-message-time{ font-size:11px; color:var(--cw-text-secondary); margin-top:4px; display:block; }

/* Typing Indicator */
.chat-widget-typing{
  display:flex; gap:8px; padding:10px 14px; background:var(--cw-bg-primary);
  border-radius:12px; border-bottom-left-radius:4px; max-width:fit-content;
}
.chat-widget-typing-dot{ width:8px; height:8px; border-radius:50%; background:var(--cw-text-secondary); animation:typingDot 1.4s infinite; }
.chat-widget-typing-dot:nth-child(2){ animation-delay:.2s; }
.chat-widget-typing-dot:nth-child(3){ animation-delay:.4s; }
@keyframes typingDot{ 0%,60%,100%{ transform:translateY(0); opacity:.5;} 30%{ transform:translateY(-8px); opacity:1;} }

/* Quick Replies (chips) */
.chat-widget-suggestions{
  display:flex; flex-wrap:wrap; gap:8px; margin:6px 0 0; padding:0 2px;
}
.chat-widget-suggestion-btn{
  border:0; border-radius:999px; padding:8px 12px; background:var(--cw-accent); color:#fff; cursor:pointer;
  font:inherit; line-height:1; transition:transform .08s ease, background .2s ease, color .2s ease, border-color .2s ease;
  box-shadow: var(--cw-shadow);
}
.chat-widget-suggestion-btn:is(:hover,:focus){ transform:translateY(-1px); }
a.chat-widget-suggestion-btn{ text-decoration:none; display:inline-block; }
a.chat-widget-suggestion-btn:link, a.chat-widget-suggestion-btn:visited{ color:#fff; }
a.chat-widget-suggestion-btn:hover, a.chat-widget-suggestion-btn:focus{ color:#fff; }

/* Error Banner */
.chat-widget-error{
  padding:12px 16px; background:#fee; color:#c00; border-radius:8px; font-size:13px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.chat-widget-error-retry{
  padding:6px 12px; background:#c00; color:#fff; border:none; border-radius:6px; font-size:12px; cursor:pointer; white-space:nowrap;
}

/* Footer */
.chat-widget-footer{
  padding:16px; background:var(--cw-bg-primary); border-top:1px solid var(--cw-border);
  display:flex; gap:12px; align-items:flex-end; position:relative;
}
.chat-widget-input{
  flex:1; padding:10px 14px; border:1px solid var(--cw-border); border-radius:20px;
  font-family:inherit; font-size:14px; line-height:1.5; color:var(--cw-text-primary);
  background:var(--cw-bg-secondary); resize:none; max-height:96px; min-height:40px; outline:none; transition:border-color .2s ease;
}
.chat-widget-input:focus{ border-color:var(--cw-accent); }
.chat-widget-input::placeholder{ color:var(--cw-text-secondary); }
.chat-widget-input.error{ border-color:#c00; }
.chat-widget-send-btn{
  width:40px; height:40px; min-width:40px; border:none; background:var(--cw-accent); color:#fff;
  border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:transform .2s ease, opacity .2s ease;
}
.chat-widget-send-btn:disabled{ opacity:.5; cursor:not-allowed; }
.chat-widget-send-btn:not(:disabled):hover{ transform:scale(1.05); }
.chat-widget-send-btn:not(:disabled):active{ transform:scale(0.95); }
.chat-widget-send-btn:focus{ outline:2px solid var(--cw-accent); outline-offset:2px; }
.chat-widget-send-btn svg{ width:20px; height:20px; }

/* Character Counter */
.chat-widget-char-count{ position:absolute; bottom:4px; right:52px; font-size:11px; color:var(--cw-text-secondary); }
.chat-widget-char-count.over-limit{ color:#c00; font-weight:600; }

/* ---- INLINE CTA BUTTONS ("buttons" payload) ---- */
/* Looks like an operator bubble with pill buttons inside */
.chat-widget-actions{
  align-self:flex-start;
  max-width:75%;
  background: var(--cw-bg-primary);
  color: var(--cw-text-primary);
  border-radius:12px; border-bottom-left-radius:4px;
  padding:10px 12px;
  box-shadow: var(--cw-shadow);
}
.chat-widget-action-list{ display:flex; flex-wrap:wrap; gap:8px; }

/* Solid pill buttons */
.chat-widget-action-btn{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px; border-radius:999px;
  background: var(--cw-accent); color:#fff; border:1px solid transparent;
  font-size:13px; line-height:1; text-decoration:none;
  box-shadow: var(--cw-shadow);
  transition: transform .08s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
}
.chat-widget-action-btn:link, .chat-widget-action-btn:visited{ color:#fff; }
.chat-widget-action-btn:hover{ transform:translateY(-1px); box-shadow: var(--cw-shadow-lg); }
.chat-widget-action-btn:active{ transform:translateY(0); }
.chat-widget-action-btn:focus-visible{ outline:2px solid var(--cw-accent); outline-offset:2px; }

/* Optional outline variant */
.chat-widget-action-btn.is-outline{
  background: transparent; color: var(--cw-text-primary); border-color: var(--cw-border);
}
.chat-widget-action-btn.is-outline:hover{
  background: var(--cw-accent); color:#fff; border-color: var(--cw-accent);
}

/* Mobile */
@media (max-width: 768px){
  .chat-widget-container{ bottom:16px; right:16px; }
  .chat-widget-container.position-left{ left:16px; }
  .chat-widget-btn{ --cw-btn-size:60px; }
  .chat-widget-window{
    position:fixed; bottom:0; right:0; left:0; width:100%; height:65vh; max-height:65vh;
    border-radius: var(--cw-radius) var(--cw-radius) 0 0; transform: translateY(100%);
  }
  .chat-widget-window.visible{ transform: translateY(0); }
  .chat-widget-header{ padding:20px; }
  .chat-widget-footer{ padding:16px; padding-bottom:max(16px, env(safe-area-inset-bottom)); }
}

/* High Contrast */
@media (prefers-contrast: high){ .chat-widget-btn, .chat-widget-window{ border:2px solid currentColor; } }

/* Focus Visible */
.chat-widget-container :focus-visible{ outline:2px solid var(--cw-accent); outline-offset:2px; }

/* SR-only */
.chat-widget-sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border-width:0;
}

/* Hidden */
.chat-widget-hidden{ display:none !important; }
