/* Support Chat Widget — themable via CSS custom properties */
/* Defaults to BandSaaS brand colors (dark navy + blue accent) */
/* Tenant band sites override via --theme-* vars from their theme CSS */

.sc-bubble{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--sc-accent,var(--theme-accent,#1e40af));color:#fff;border:none;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.3);z-index:9990;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}
.sc-bubble:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(0,0,0,.4)}
.sc-bubble svg{width:28px;height:28px;fill:currentColor}
.sc-bubble .sc-close{display:none}
.sc-bubble.open .sc-chat-icon{display:none}
.sc-bubble.open .sc-close{display:block}

.sc-panel{position:fixed;bottom:92px;right:24px;width:380px;max-width:calc(100vw - 32px);height:520px;max-height:calc(100vh - 120px);border-radius:16px;background:var(--sc-bg,var(--theme-bg,#121212));border:1px solid var(--sc-border,var(--theme-border,#2d2d2d));box-shadow:0 12px 40px rgba(0,0,0,.4);z-index:9989;display:none;flex-direction:column;overflow:hidden;font-family:var(--sc-font,var(--theme-font,'Inter',sans-serif));transition:all .3s ease;color:var(--sc-text,var(--theme-text,#e5e7eb))}
.sc-panel.open{display:flex}

/* Maximize mode */
.sc-panel.maximized{width:560px;height:80vh;max-height:calc(100vh - 48px);bottom:50%;right:50%;transform:translate(50%,50%);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.5)}

/* Backdrop blur overlay when maximized */
.sc-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9988;opacity:0;pointer-events:none;transition:opacity .3s ease}
.sc-backdrop.show{opacity:1;pointer-events:auto}

.sc-header{padding:16px 20px;background:var(--sc-header,var(--sc-accent,var(--theme-accent,#1e40af)));color:#fff;font-weight:600;font-size:15px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;position:relative}
.sc-header .sc-logo{height:24px;width:auto;flex-shrink:0}
.sc-maximize{background:none;border:none;color:#fff;cursor:pointer;margin-left:auto;padding:4px;opacity:.8;transition:opacity .15s}
.sc-maximize:hover{opacity:1}
.sc-maximize svg{width:16px;height:16px;fill:currentColor}

/* Onboarding progress bar */
.sc-progress{width:100%;height:4px;background:rgba(255,255,255,.2);border-radius:2px;margin-top:8px;overflow:hidden;flex-basis:100%}
.sc-progress-fill{height:100%;background:#4ade80;border-radius:2px;transition:width .4s ease}
.sc-site-url{font-size:11px;font-weight:400;opacity:.8;flex-basis:100%;margin-top:2px}

.sc-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.sc-msg{max-width:85%;padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.5;word-wrap:break-word}
.sc-msg.user{align-self:flex-end;background:var(--sc-accent,var(--theme-accent,#1e40af));color:#fff;border-bottom-right-radius:4px}
.sc-msg.assistant{align-self:flex-start;background:var(--sc-card,var(--theme-card-bg,#1e1e1e));color:var(--sc-text,var(--theme-text,#e5e7eb));border-bottom-left-radius:4px}
.sc-msg.assistant strong{color:var(--sc-accent-light,var(--theme-accent,#3b82f6))}
.sc-msg.assistant code{background:rgba(255,255,255,.08);padding:1px 4px;border-radius:3px;font-size:13px}
.sc-msg.assistant .sc-heading{font-weight:700;font-size:15px;margin:12px 0 6px;color:var(--sc-accent-light,var(--theme-accent,#3b82f6))}
.sc-msg.assistant .sc-heading:first-child{margin-top:0}
.sc-msg.assistant .sc-list-item{padding-left:12px;position:relative;margin:3px 0}
.sc-msg.assistant .sc-list-item::before{content:'•';position:absolute;left:0;color:var(--sc-accent-light,var(--theme-accent,#3b82f6))}
.sc-msg.assistant .sc-table{width:100%;border-collapse:collapse;margin:10px 0;font-size:13px}
.sc-msg.assistant .sc-table th{text-align:left;padding:6px 10px;background:rgba(255,255,255,.06);border-bottom:1px solid var(--sc-border,#2d2d2d);font-weight:600;color:var(--sc-accent-light,#3b82f6)}
.sc-msg.assistant .sc-table td{padding:5px 10px;border-bottom:1px solid rgba(255,255,255,.04)}
.sc-msg.assistant .sc-table tr:last-child td{border-bottom:none}
.sc-msg.assistant s{opacity:.5;text-decoration:line-through}
.sc-msg.system{align-self:center;font-size:12px;color:var(--sc-muted,var(--theme-muted,#6b6b6b));padding:4px 12px}

.sc-typing{align-self:flex-start;padding:10px 14px;background:var(--sc-card,var(--theme-card-bg,#1e1e1e));border-radius:12px;border-bottom-left-radius:4px;display:none}
.sc-typing.show{display:flex;gap:4px;align-items:center}
.sc-typing span{width:6px;height:6px;border-radius:50%;background:var(--sc-muted,var(--theme-muted,#6b6b6b));animation:sc-bounce .6s infinite alternate}
.sc-typing span:nth-child(2){animation-delay:.15s}
.sc-typing span:nth-child(3){animation-delay:.3s}
@keyframes sc-bounce{to{opacity:.3;transform:translateY(-4px)}}

.sc-escalation{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:10px 14px;font-size:13px;color:#fbbf24;margin-top:4px}

/* Review cards */
.sc-review-card{display:flex;gap:12px;padding:12px;border-radius:12px;background:var(--sc-card,var(--theme-card-bg,#1e1e1e));border:1px solid var(--sc-border,var(--theme-border,#2d2d2d));text-decoration:none;color:inherit;transition:border-color .15s,transform .15s;cursor:pointer;max-width:95%}
.sc-review-card:hover{border-color:var(--sc-accent,var(--theme-accent,#1e40af));transform:translateY(-1px)}
.sc-review-art{width:72px;height:72px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--sc-border,#2d2d2d)}
.sc-review-art-placeholder{width:72px;height:72px;border-radius:8px;background:linear-gradient(135deg,var(--sc-accent,#1e40af) 0%,#8b5cf6 100%);flex-shrink:0}
.sc-review-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.sc-review-title{font-weight:600;font-size:14px;color:var(--sc-text,var(--theme-text,#e5e7eb));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-review-meta{font-size:12px;color:var(--sc-muted,var(--theme-muted,#9ca3af));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-review-rating{font-size:13px;color:#fbbf24}
.sc-review-rating span{color:var(--sc-muted,#9ca3af);font-size:11px;margin-left:4px}
.sc-review-editor{font-size:11px;color:var(--sc-accent-light,var(--theme-accent,#3b82f6))}

/* Quick-reply buttons */
.sc-quick-replies{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0}
.sc-quick-btn{background:transparent;border:1px solid var(--sc-accent,var(--theme-accent,#1e40af));color:var(--sc-accent-light,var(--theme-accent,#3b82f6));border-radius:20px;padding:6px 14px;font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit}
.sc-quick-btn:hover{background:var(--sc-accent,var(--theme-accent,#1e40af));color:#fff}

/* Secure password input */
.sc-password-wrap{align-self:stretch;margin-top:4px}
.sc-password-field{width:100%;border:1px solid var(--sc-border,var(--theme-border,#2d2d2d));border-radius:12px;padding:10px 16px;font-size:14px;outline:none;background:var(--sc-input-bg,var(--sc-bg,#1a1a1a));color:var(--sc-text,var(--theme-text,#e5e7eb));font-family:inherit;box-sizing:border-box}
.sc-password-field:focus{border-color:var(--sc-accent,var(--theme-accent,#1e40af));box-shadow:0 0 0 2px rgba(30,64,175,.3)}

.sc-input-area{padding:12px 16px;border-top:1px solid var(--sc-border,var(--theme-border,#2d2d2d));display:flex;gap:8px;background:var(--sc-bg,var(--theme-bg,#121212))}
.sc-input{flex:1;border:1px solid var(--sc-border,var(--theme-border,#2d2d2d));border-radius:24px;padding:10px 16px;font-size:14px;outline:none;background:var(--sc-input-bg,var(--sc-bg,#1a1a1a));color:var(--sc-text,var(--theme-text,#e5e7eb));font-family:inherit;resize:none;max-height:80px}
.sc-input::placeholder{color:var(--sc-muted,var(--theme-muted,#6b6b6b))}
.sc-input:focus{border-color:var(--sc-accent,var(--theme-accent,#1e40af))}
.sc-send{width:40px;height:40px;border-radius:50%;background:var(--sc-accent,var(--theme-accent,#1e40af));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s}
.sc-send:disabled{opacity:.4;cursor:default}
.sc-send svg{width:18px;height:18px;fill:currentColor}

/* ─── Tenant band site theme override ────────────────────────────── */
/* On tenant pages, --theme-* vars are set by the active theme CSS.  */
/* The widget auto-inherits. No extra config needed.                 */

/* ─── Landing page / platform pages (dark BandSaaS brand) ────────── */
/* These pages don't have --theme-* vars, so the defaults above      */
/* use the BandSaaS brand: dark navy bg, blue accents, Inter font.   */

/* Mobile */
@media(max-width:600px){
  .sc-panel,.sc-panel.maximized{bottom:0;right:0;left:0;top:0;width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0;transform:none;box-shadow:none;border:none}
  .sc-panel .sc-header{border-radius:0;padding:12px 16px;position:relative;z-index:2}
  .sc-panel .sc-messages{padding:12px;padding-bottom:80px}
  .sc-panel .sc-input-area{position:fixed;bottom:0;left:0;right:0;padding:10px 12px;background:var(--sc-bg,var(--theme-bg,#121212));border-top:1px solid var(--sc-border,#2d2d2d);z-index:3}
  .sc-panel .sc-input{font-size:16px}
  .sc-bubble{bottom:16px;right:16px;width:48px;height:48px;z-index:9990}
  .sc-bubble.open{bottom:auto;top:12px;right:12px;width:40px;height:40px;z-index:9999;position:fixed}
  .sc-backdrop{display:none}
  .sc-msg{max-width:90%;font-size:15px}
  .sc-review-card{max-width:100%}
  .sc-quick-replies{padding:4px 0}
  .sc-quick-btn{font-size:14px;padding:8px 16px}
}
