/* Support Chat Widget — τAI for OddSockets */
/* Themable via CSS custom properties */

.sc-bubble{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--sc-accent,#6366f1);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,#0f0f23);border:1px solid var(--sc-border,#1e1e3f);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,'Inter',system-ui,sans-serif);transition:all .3s ease;color:var(--sc-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,#6366f1));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:20px;width:auto;flex-shrink:0;opacity:.9}
.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}

.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,#6366f1);color:#fff;border-bottom-right-radius:4px}
.sc-msg.assistant{align-self:flex-start;background:var(--sc-card,#1a1a2e);color:var(--sc-text,#e5e7eb);border-bottom-left-radius:4px}
.sc-msg.assistant strong{color:var(--sc-accent-light,#818cf8)}
.sc-msg.assistant code{background:rgba(255,255,255,.08);padding:1px 4px;border-radius:3px;font-size:13px;font-family:'Fira Code','JetBrains Mono',monospace}
.sc-msg.assistant pre.sc-code{background:rgba(0,0,0,.3);border-radius:8px;padding:10px 12px;overflow-x:auto;margin:8px 0;font-size:13px}
.sc-msg.assistant pre.sc-code code{background:none;padding:0;font-family:'Fira Code','JetBrains Mono',monospace}
.sc-msg.assistant .sc-heading{font-weight:700;font-size:15px;margin:12px 0 6px;color:var(--sc-accent-light,#818cf8)}
.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,#818cf8)}
.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,#1e1e3f);font-weight:600;color:var(--sc-accent-light,#818cf8)}
.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,#6b7280);padding:4px 12px}

.sc-typing{align-self:flex-start;padding:10px 14px;background:var(--sc-card,#1a1a2e);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,#6b7280);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}

/* Plan Mode indicator */
.sc-plan-mode{align-self:flex-start;font-size:12px;color:var(--sc-muted,#6b7280);padding:4px 0;display:flex;align-items:center;gap:6px}
.sc-plan-mode strong{color:var(--sc-accent-light,#818cf8)}
.sc-plan-badge{background:rgba(99,102,241,.15);border:1px solid rgba(99,102,241,.3);color:var(--sc-accent-light,#818cf8);border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}

/* E2E test scenarios (collapsible) */
.sc-e2e-tests{align-self:stretch;border:1px solid rgba(34,197,94,.2);border-radius:8px;overflow:hidden;font-size:13px;margin-top:4px}
.sc-e2e-summary{padding:8px 12px;cursor:pointer;color:var(--sc-muted,#6b7280);display:flex;align-items:center;gap:6px;user-select:none}
.sc-e2e-summary:hover{color:var(--sc-text,#e5e7eb)}
.sc-e2e-badge{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3);color:#4ade80;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.sc-e2e-content{padding:10px 12px;border-top:1px solid rgba(34,197,94,.15);color:var(--sc-text,#e5e7eb);line-height:1.6;font-family:'Fira Code','JetBrains Mono',monospace;font-size:12px;max-height:300px;overflow-y:auto}

/* 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,#6366f1);color:var(--sc-accent-light,#818cf8);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,#6366f1);color:#fff}

.sc-input-area{padding:12px 16px;border-top:1px solid var(--sc-border,#1e1e3f);display:flex;gap:8px;background:var(--sc-bg,#0f0f23)}
.sc-input{flex:1;border:1px solid var(--sc-border,#1e1e3f);border-radius:24px;padding:10px 16px;font-size:14px;outline:none;background:var(--sc-input-bg,#16162a);color:var(--sc-text,#e5e7eb);font-family:inherit;resize:none;max-height:80px}
.sc-input::placeholder{color:var(--sc-muted,#6b7280)}
.sc-input:focus{border-color:var(--sc-accent,#6366f1)}
.sc-send{width:40px;height:40px;border-radius:50%;background:var(--sc-accent,#6366f1);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}

/* Mobile */
@media(max-width:480px){
  .sc-panel,.sc-panel.maximized{bottom:0;right:0;width:100%;max-width:100%;height:100vh;max-height:100vh;border-radius:0;transform:none}
  .sc-bubble{bottom:16px;right:16px}
}
