/* JIS AI Chatbot Public Widget — v1.0.0 */
:root { --jisai-w-primary:#6366f1; --jisai-w-bot-bubble:#6366f1; --jisai-w-agent-bubble:#0ea5e9; --jisai-w-user-bubble:#e8e8f0; --jisai-w-text:#1a1a2e; --jisai-w-radius:16px; }
#jisai-widget-wrap{position:fixed;z-index:2147483647;bottom:0;right:8px;font-family:-apple-system,'Segoe UI',sans-serif;}
#jisai-fab-wrap{margin-left:auto;margin-bottom:var(--jisai-fab-offset,8px);display:inline-block;position:relative;}
#jisai-fab{width:56px;height:56px;border-radius:50%;background:var(--jisai-w-primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.3);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .2s;position:relative;z-index:1;overflow:hidden;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
#jisai-fab-unread{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;line-height:18px;text-align:center;padding:0 4px;z-index:2;pointer-events:none;display:none;}
#jisai-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(0,0,0,.4);}
.jisai-fab-default-icon{pointer-events:none;transition:opacity .25s ease,transform .3s cubic-bezier(.4,0,.2,1);opacity:1;transform:scale(1) rotate(0deg);}
.jisai-fab-close-icon{pointer-events:none;}
#jisai-fab.is-open .jisai-fab-default-icon{opacity:0 !important;transform:scale(0.4) rotate(90deg) !important;}
#jisai-fab.is-open .jisai-fab-close-icon{opacity:1 !important;transform:scale(1) rotate(0deg) !important;}
#jisai-widget-wrap.position-bottom-left{right:auto;left:8px;}

/* ── Side-right: tab sticks to right edge ── */
#jisai-widget-wrap.position-side-right{right:0;top:auto;bottom:var(--jisai-side-offset,50%);transform:translateY(50%);display:flex;flex-direction:row;align-items:center;}
#jisai-widget-wrap.position-side-right #jisai-fab-wrap{order:2;margin-left:0;margin-bottom:0;}
#jisai-widget-wrap.position-side-right #jisai-fab{border-radius:8px 0 0 8px;width:40px;height:auto;min-height:110px;padding:12px 8px;transform:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.04em;white-space:nowrap;overflow:hidden;}
#jisai-widget-wrap.position-side-right #jisai-fab:hover{transform:none;opacity:.9;}
#jisai-widget-wrap.position-side-right #jisai-fab-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
#jisai-widget-wrap.position-side-right #jisai-fab-icon img{width:100%;height:100%;object-fit:contain;}
#jisai-widget-wrap.position-side-right #jisai-fab-label{writing-mode:vertical-rl;text-orientation:mixed;transform:none;line-height:1.2;}
#jisai-widget-wrap.position-side-right #jisai-window{position:relative;bottom:auto;right:auto;top:auto;left:auto;transform-origin:right center;order:1;margin-right:0;}
#jisai-widget-wrap.position-side-right #jisai-window.open{transform:scale(1) translateX(0);opacity:1;pointer-events:all;}
#jisai-widget-wrap.position-side-right #jisai-window{transform:scale(.9) translateX(20px);opacity:0;pointer-events:none;}

/* ── Side-left: tab sticks to left edge ── */
#jisai-widget-wrap.position-side-left{left:0;right:auto;top:auto;bottom:var(--jisai-side-offset,50%);transform:translateY(50%);display:flex;flex-direction:row;align-items:center;}
#jisai-widget-wrap.position-side-left #jisai-fab-wrap{order:1;margin-left:0;margin-bottom:0;}
#jisai-widget-wrap.position-side-left #jisai-fab{border-radius:0 8px 8px 0;width:40px;height:auto;min-height:110px;padding:12px 8px;transform:none;display:flex;flex-direction:column-reverse;align-items:center;justify-content:center;gap:8px;order:1;font-size:12px;font-weight:600;letter-spacing:.04em;white-space:nowrap;overflow:hidden;}
#jisai-widget-wrap.position-side-left #jisai-fab:hover{opacity:.9;}
#jisai-widget-wrap.position-side-left #jisai-fab-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
#jisai-widget-wrap.position-side-left #jisai-fab-icon img{width:100%;height:100%;object-fit:contain;}
#jisai-widget-wrap.position-side-left #jisai-fab-label{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);line-height:1.2;}
#jisai-widget-wrap.position-side-left #jisai-window{position:relative;bottom:auto;right:auto;top:auto;left:auto;transform-origin:left center;order:2;margin-left:0;}
#jisai-widget-wrap.position-side-left #jisai-window.open{transform:scale(1) translateX(0);opacity:1;pointer-events:all;}
#jisai-widget-wrap.position-side-left #jisai-window{transform:scale(.9) translateX(-20px);opacity:0;pointer-events:none;}
#jisai-window{position:absolute;bottom:var(--jisai-chat-offset,90px);right:0;width:360px;height:520px;background:#fff;border-radius:var(--jisai-w-radius);box-shadow:0 8px 40px rgba(0,0,0,.25);display:flex;flex-direction:column;overflow:hidden;transform:scale(.85) translateY(24px);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .25s ease;transform-origin:bottom right;}
#jisai-window.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all;}
.position-bottom-left #jisai-window{right:auto;left:0;transform-origin:bottom left;}
#jisai-header{background:var(--jisai-w-primary);color:#fff;padding:12px 14px;display:flex;align-items:center;gap:10px;}
#jisai-header-left{display:flex;align-items:center;gap:9px;flex:1;min-width:0;}
#jisai-header-info{display:flex;flex-direction:column;gap:2px;min-width:0;}
#jisai-header-avatar{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.22);border:1.5px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;font-size:16px;overflow:hidden;color:#fff;flex-shrink:0;}
#jisai-header-avatar img{width:82%;height:82%;object-fit:contain;}
#jisai-header-avatar.has-logo img{width:82%;height:82%;object-fit:contain;}
#jisai-header-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
#jisai-header-status{display:flex;align-items:center;gap:5px;font-size:.68rem;opacity:.85;}
#jisai-header-controls{display:flex;align-items:center;gap:4px;flex-shrink:0;}
#jisai-header-close{background:none;border:none;color:rgba(255,255,255,.8);cursor:pointer;font-size:18px;padding:0;line-height:1;}
#jisai-header-close:hover{color:#fff;}
#jisai-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#f8f9fa;}
#jisai-prechat{background:#f8f9fa;}
#jisai-messages::-webkit-scrollbar{width:4px;}
#jisai-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px;}
.jisai-msg{display:flex;flex-direction:column;gap:4px;max-width:82%;}
.jisai-msg.bot{align-self:flex-start;align-items:flex-start;}
.jisai-msg.user{align-self:flex-end;align-items:flex-end;}
.jisai-bubble{padding:10px 14px;border-radius:var(--jisai-w-radius);font-size:14px;line-height:1.55;word-break:break-word;}
.jisai-msg.bot .jisai-bubble{background:var(--jisai-w-bot-bubble);color:var(--jisai-w-bot-text,#fff);box-shadow:0 1px 3px rgba(0,0,0,.08);border-bottom-left-radius:4px;}
.jisai-msg.agent{align-self:flex-start;align-items:flex-start;}
.jisai-msg.agent .jisai-bubble{background:var(--jisai-w-agent-bubble);color:var(--jisai-w-agent-text,#fff);box-shadow:0 1px 3px rgba(0,0,0,.08);border-bottom-left-radius:4px;}
.jisai-msg.user .jisai-bubble{background:var(--jisai-w-user-bubble);color:var(--jisai-w-user-text,#1a1a2e);border-bottom-right-radius:4px;}
.jisai-msg-time{font-size:10px;color:#9ca3af;display:flex;align-items:center;gap:3px;}
.jisai-msg.user .jisai-msg-time{justify-content:flex-end;}
.jisai-msg-tick{font-size:11px;line-height:1;}
.jisai-tick-sent{color:#9ca3af;}
.jisai-tick-read{color:#3b82f6;}
.jisai-typing .jisai-bubble{display:flex;gap:5px;align-items:center;}
.jisai-dot{width:7px;height:7px;border-radius:50%;background:#9ca3af;animation:sbaiDot 1.2s infinite;}
.jisai-dot:nth-child(2){animation-delay:.2s;}
.jisai-dot:nth-child(3){animation-delay:.4s;}
@keyframes sbaiDot{0%,80%,100%{transform:scale(1);opacity:.5}40%{transform:scale(1.25);opacity:1}}
#jisai-input-area{padding:12px;border-top:1px solid #e5e7eb;background:#fff;display:flex;align-items:flex-end;gap:8px;}
#jisai-input{flex:1;border:1px solid #e5e7eb;border-radius:10px;padding:10px 14px;font-size:14px;font-family:inherit;resize:none;min-height:42px;max-height:120px;outline:none;transition:border-color .15s;color:#1a1a2e;}
#jisai-input:focus{border-color:var(--jisai-w-primary);}
#jisai-send{width:38px;height:38px;border-radius:10px;background:var(--jisai-w-primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;flex-shrink:0;transition:.15s;}
#jisai-send:hover{opacity:.9;}
#jisai-send:disabled{opacity:.5;cursor:not-allowed;}
#jisai-branding{text-align:center;padding:6px 8px;font-size:10px;color:#9ca3af;background:#fff;border-top:1px solid #f3f4f6;display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap;}
#jisai-branding a{color:#9ca3af;text-decoration:none;}
.jisai-e2e-badge{color:#059669;font-weight:600;font-size:10px;white-space:nowrap;}
/* ── Scroll-to-bottom button (widget) ── */
#jisai-scroll-btn{position:absolute;bottom:92px;right:14px;width:30px;height:30px;border-radius:50%;background:var(--jisai-w-primary);color:#fff;border:none;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:15px;box-shadow:0 2px 10px rgba(0,0,0,.3);z-index:20;transition:opacity .15s,transform .15s;line-height:1;}
#jisai-scroll-btn.jisai-visible{display:flex;}
#jisai-scroll-btn:hover{transform:scale(1.1);}
/* ── List rendering inside bot bubbles ── */
.jisai-bubble ol,.jisai-bubble ul{padding-left:20px !important;margin:6px 0 !important;list-style:revert !important;}
.jisai-bubble ol{list-style-type:decimal !important;}
.jisai-bubble ul{list-style-type:disc !important;}
.jisai-bubble li{display:list-item !important;margin:3px 0 !important;line-height:1.55 !important;}
/* ── Quick action chips ── */
#jisai-quick-actions{display:flex;flex-wrap:wrap;gap:7px;padding:8px 14px 6px;border-top:1px solid rgba(0,0,0,.06);flex-shrink:0;}
.jisai-qa-chip{padding:6px 13px;border-radius:20px;border:1.5px solid var(--jisai-w-primary,#6366f1);background:rgba(99,102,241,.08);color:var(--jisai-w-primary,#6366f1);font-size:.74rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;}
.jisai-qa-chip:hover{background:var(--jisai-w-primary,#6366f1);color:#fff;}
/* ── Popup bubble above widget ── */
@keyframes jisai-popup-in{from{opacity:0;transform:translateY(8px) scale(.96);}to{opacity:1;transform:translateY(0) scale(1);}}
#jisai-popup-bubble{animation:jisai-popup-in .35s cubic-bezier(.4,0,.2,1);}
/* ── Mobile: full-screen chat window ── */
@media(max-width:480px){
  #jisai-window{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100%!important;height:100%!important;border-radius:0!important;transform:translateY(100%)!important;transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .25s ease!important;}
  #jisai-window.open{transform:translateY(0)!important;opacity:1!important;}
}
