#cp-chat-fab{position:fixed;right:20px;bottom:20px;width:46px;height:46px;border-radius:50%;background:#f5a623;color:#05070d;display:flex;align-items:center;justify-content:center;font-family:inherit;font-weight:700;font-size:11px;letter-spacing:.08em;cursor:pointer;box-shadow:0 4px 16px rgba(245,166,35,.35),0 0 0 1px rgba(245,166,35,.5);z-index:9999;user-select:none;transition:transform .12s ease,box-shadow .12s ease}
#cp-chat-fab:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(245,166,35,.5),0 0 0 1px #f5a623}
#cp-chat-fab.open{background:#0a0e1a;color:#f5a623;box-shadow:0 0 0 1px #f5a623,0 4px 16px rgba(0,0,0,.5)}
#cp-chat-fab .dot{width:6px;height:6px;border-radius:50%;background:#22c55e;position:absolute;top:6px;right:6px;box-shadow:0 0 6px #22c55e}
#cp-chat-panel{position:fixed;right:20px;bottom:80px;width:380px;max-width:calc(100vw - 40px);height:520px;max-height:calc(100vh - 120px);background:#0a0e1a;border:1px solid #f5a623;border-radius:4px;display:none;flex-direction:column;font-family:inherit;font-size:12px;color:#c9d1d9;z-index:9998;box-shadow:0 12px 32px rgba(0,0,0,.55);overflow:hidden}
#cp-chat-panel.open{display:flex;animation:cpcFadeIn .18s ease-out}
@keyframes cpcFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
#cp-chat-panel .hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#05070d;border-bottom:1px solid #f5a623;letter-spacing:.06em;text-transform:uppercase;font-size:11px}
#cp-chat-panel .hdr .title{color:#f5a623;font-weight:700}
#cp-chat-panel .hdr .sub{color:#6b7280;font-size:10px;margin-left:8px;text-transform:none;letter-spacing:0}
#cp-chat-panel .hdr .x{color:#c9d1d9;background:transparent;border:0;font:inherit;font-size:16px;cursor:pointer;padding:0 4px;line-height:1}
#cp-chat-panel .hdr .x:hover{color:#f5a623}
#cp-chat-body{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:#f5a623 #05070d}
#cp-chat-body::-webkit-scrollbar{width:6px}
#cp-chat-body::-webkit-scrollbar-thumb{background:#f5a623;border-radius:3px}
#cp-chat-body::-webkit-scrollbar-track{background:#05070d}
#cp-chat-body .msg{display:flex;flex-direction:column;gap:4px;max-width:100%}
#cp-chat-body .msg.user{align-items:flex-end}
#cp-chat-body .msg .who{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#6b7280}
#cp-chat-body .msg.user .who{color:#4f9cf9}
#cp-chat-body .msg.asst .who{color:#f5a623}
#cp-chat-body .msg .bubble{padding:8px 10px;border-radius:3px;line-height:1.45;white-space:pre-wrap;word-wrap:break-word;max-width:92%}
#cp-chat-body .msg.user .bubble{background:#1a2233;border:1px solid #2a3344}
#cp-chat-body .msg.asst .bubble{background:#05070d;border:1px solid #2a3344}
#cp-chat-body .msg.asst.streaming .bubble::after{content:"▌";color:#f5a623;animation:cpcBlink 1s infinite}
@keyframes cpcBlink{50%{opacity:0}}
#cp-chat-body .actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
#cp-chat-body .actions .act{background:transparent;border:1px solid #f5a623;color:#f5a623;font:inherit;font-size:10px;padding:4px 8px;cursor:pointer;border-radius:2px;letter-spacing:.05em;text-transform:uppercase}
#cp-chat-body .actions .act:hover{background:#f5a623;color:#05070d}
#cp-chat-body .tool-chip{font-size:9px;color:#6b7280;border-left:2px solid #6b7280;padding-left:6px;letter-spacing:.05em}
#cp-chat-body .tool-chip.done{color:#22c55e;border-color:#22c55e}
#cp-chat-body .err{color:#ef4444;font-size:11px;border:1px solid #ef4444;padding:6px 8px;border-radius:2px}
#cp-chat-footer{border-top:1px solid #2a3344;padding:8px;display:flex;gap:6px;align-items:flex-end}
#cp-chat-input{flex:1;background:#05070d;border:1px solid #2a3344;color:#c9d1d9;font:inherit;font-size:12px;padding:6px 8px;border-radius:2px;resize:none;min-height:32px;max-height:120px;outline:none}
#cp-chat-input:focus{border-color:#f5a623}
#cp-chat-send{background:#f5a623;color:#05070d;border:0;font:inherit;font-weight:700;font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:0 12px;height:32px;cursor:pointer;border-radius:2px}
#cp-chat-send:disabled{background:#6b7280;cursor:not-allowed}
#cp-chat-empty{color:#6b7280;font-size:11px;text-align:center;padding:20px 10px;line-height:1.6}
#cp-chat-empty .suggest{display:block;margin-top:6px;color:#94a3b8;font-size:10px}
/* CHAT WIDGET MOBILE - precisa estar neste <style> pra ter precedencia sobre
   as regras desktop acima (ordem importa em CSS quando especificidade eh igual). */
@media(max-width:480px){
  #cp-chat-fab{right:14px;bottom:14px;width:44px;height:44px;font-size:10px}
  #cp-chat-panel{
    right:0;left:0;bottom:0;
    width:100vw;max-width:100vw;
    height:78vh;max-height:78vh;
    border-radius:6px 6px 0 0;
    border-left:0;border-right:0;border-bottom:0;
  }
  #cp-chat-input{font-size:14px} /* >=14px evita zoom auto do iOS no focus */
}
