/* Spirit Sommelier Chat Widget — themed via CSS custom properties */
/* Each site sets --sc-* vars via inline style block in chat.ejs */

.sc-bubble{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--sc-accent,#B87333);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:400px;max-width:calc(100vw - 32px);height:560px;max-height:calc(100vh - 120px);border-radius:16px;background:var(--sc-bg,#0D1F17);border:1px solid var(--sc-border,rgba(184,115,51,.25));box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:9989;display:none;flex-direction:column;overflow:hidden;font-family:'Inter',-apple-system,sans-serif;transition:all .3s ease;color:var(--sc-text,#e5e7eb)}
.sc-panel.open{display:flex}

.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,.6)}

.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,#0A2E1F);color:#fff;font-weight:600;font-size:15px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--sc-border,rgba(184,115,51,.2))}
.sc-header .sc-dot{width:8px;height:8px;border-radius:50%;background:var(--sc-dot,#4ade80);flex-shrink:0}
.sc-title{flex:1}
.sc-maximize{background:none;border:none;color:#fff;cursor:pointer;padding:4px;opacity:.7;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.6;word-wrap:break-word}
.sc-msg.user{align-self:flex-end;background:var(--sc-accent,#B87333);color:#fff;border-bottom-right-radius:4px}
.sc-msg.assistant{align-self:flex-start;background:var(--sc-msg-bg,#142B20);color:var(--sc-text,#e5e7eb);border:1px solid var(--sc-border,rgba(184,115,51,.15));border-bottom-left-radius:4px}
.sc-msg.assistant strong{color:var(--sc-accent-light,#D4975A)}
.sc-msg.assistant code{background:rgba(184,115,51,.12);padding:1px 4px;border-radius:3px;font-size:13px;color:var(--sc-accent-light,#D4975A)}
.sc-msg.assistant a{color:var(--sc-accent-light,#D4975A);text-decoration:underline;text-underline-offset:2px}
.sc-msg.assistant a:hover{color:var(--sc-accent-hover,#E8B87A)}
.sc-msg.system{align-self:center;font-size:12px;color:#6b7a73;padding:4px 12px}

.sc-typing{align-self:flex-start;padding:10px 14px;background:var(--sc-msg-bg,#142B20);border-radius:12px;border-bottom-left-radius:4px;display:none;margin:0 16px}
.sc-typing.show{display:flex;gap:4px;align-items:center}
.sc-typing span{width:6px;height:6px;border-radius:50%;background:#4a6b58;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-quick-start{display:flex;flex-wrap:wrap;gap:6px;padding:8px 16px;border-top:1px solid var(--sc-border,rgba(184,115,51,.1))}
.sc-quick-btn{background:transparent;border:1px solid rgba(184,115,51,.4);color:var(--sc-accent-light,#D4975A);border-radius:20px;padding:6px 14px;font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}
.sc-quick-btn:hover{background:rgba(184,115,51,.15);border-color:var(--sc-accent,#B87333);color:var(--sc-accent-hover,#E8B87A)}

.sc-input-area{padding:12px 16px;border-top:1px solid var(--sc-border,rgba(184,115,51,.15));display:flex;gap:8px;background:var(--sc-bg,#0D1F17)}
.sc-input{flex:1;border:1px solid var(--sc-border,rgba(184,115,51,.25));border-radius:24px;padding:10px 16px;font-size:14px;outline:none;background:var(--sc-input-bg,#0A1A13);color:var(--sc-text,#e5e7eb);font-family:inherit;resize:none;max-height:80px}
.sc-input::placeholder{color:#4a6b58}
.sc-input:focus{border-color:var(--sc-accent,#B87333);box-shadow:0 0 0 2px rgba(184,115,51,.2)}
.sc-send{width:40px;height:40px;border-radius:50%;background:var(--sc-accent,#B87333);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}

.sc-messages::-webkit-scrollbar{width:6px}
.sc-messages::-webkit-scrollbar-track{background:transparent}
.sc-messages::-webkit-scrollbar-thumb{background:var(--sc-scroll,rgba(184,115,51,.3));border-radius:3px}
.sc-messages::-webkit-scrollbar-thumb:hover{background:rgba(184,115,51,.5)}

/* Markdown rendering in assistant messages */
.sc-msg.assistant .sc-h3{font-size:1rem;font-weight:700;color:var(--sc-accent-light,#D4975A);margin:12px 0 6px;padding:0}
.sc-msg.assistant .sc-h4{font-size:0.9rem;font-weight:600;color:var(--sc-accent-light,#D4975A);margin:10px 0 4px;padding:0}
.sc-msg.assistant .sc-hr{border:none;border-top:1px solid var(--sc-border,rgba(184,115,51,.2));margin:10px 0}
.sc-msg.assistant .sc-quote{border-left:3px solid var(--sc-accent,#B87333);padding:4px 10px;margin:6px 0;font-style:italic;opacity:.85;font-size:0.85rem}
.sc-msg.assistant .sc-li{padding-left:12px;position:relative;margin:2px 0;font-size:0.9rem}
.sc-msg.assistant .sc-li::before{content:"•";position:absolute;left:0;color:var(--sc-accent,#B87333)}
.sc-msg.assistant em{font-style:italic;opacity:.9}
.sc-table{width:100%;border-collapse:collapse;font-size:0.8rem;margin:8px 0}
.sc-table th{text-align:left;padding:4px 8px;border-bottom:1px solid var(--sc-border,rgba(184,115,51,.2));color:var(--sc-accent-light,#D4975A);font-weight:600;font-size:0.75rem}
.sc-table td{padding:4px 8px;border-bottom:1px solid rgba(255,255,255,.05);font-size:0.8rem}

@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}
}
