
#mm-fab{position:fixed;right:18px;bottom:80px;z-index:9999;width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;font-size:22px;cursor:pointer;
  box-shadow:0 6px 20px rgba(0,0,0,.45)}
#mm-hub{position:fixed;right:18px;bottom:142px;z-index:9999;width:260px;background:#141a2e;border:1px solid #2a3550;
  border-radius:14px;padding:12px;display:none;box-shadow:0 10px 30px rgba(0,0,0,.55)}
#mm-hub h4{margin:2px 0 8px;color:#c8d0e8;font-size:13px}
#mm-hub a{display:block;padding:8px 10px;margin:3px 0;border-radius:8px;background:#1c2540;color:#dbe3f7;
  text-decoration:none;font-size:12.5px}
#mm-hub a:hover{background:#26324f}
#mm-modal{position:fixed;inset:0;z-index:10000;background:rgba(5,8,18,.85);display:none}
#mm-modal .bar{height:42px;display:flex;align-items:center;gap:10px;padding:0 12px;background:#0e1424;color:#dbe3f7}
#mm-modal .bar button{margin-left:auto;background:#26324f;color:#fff;border:none;padding:6px 12px;border-radius:7px;cursor:pointer}
#mm-modal iframe{width:100%;height:calc(100% - 42px);border:0;background:#0b1020}
/* light-theme overrides untuk launcher Menu Utama (FAB) — hanya aktif saat <html data-theme="light"> */
html[data-theme="light"] #mm-hub{background:#ffffff;border:1px solid #e2e8f4;box-shadow:0 10px 30px rgba(20,40,80,.18)}
html[data-theme="light"] #mm-hub h4{color:#1c2640}
html[data-theme="light"] #mm-hub a{background:#f0f3fa;color:#1c2640}
html[data-theme="light"] #mm-hub a:hover{background:#e2e8f4}
html[data-theme="light"] #mm-modal{background:rgba(20,40,80,.45)}
html[data-theme="light"] #mm-modal .bar{background:#eef2f9;color:#1c2640;border-bottom:1px solid #e2e8f4}
html[data-theme="light"] #mm-modal .bar button{background:#0883a8;color:#fff}
html[data-theme="light"] #mm-modal iframe{background:#ffffff}

/* ======= AI Assistant (Jarvis) chat widget — theme-aware ======= */
#ai-fab{position:fixed;right:18px;bottom:18px;z-index:9999;width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#0883a8,#7c3aed);color:#fff;border:none;font-size:24px;cursor:pointer;
  box-shadow:0 6px 20px rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center}
#ai-fab:hover{filter:brightness(1.08)}
/* ---- Baymax-style mascot (replaces 🤖) ---- */
.bx{display:block;overflow:visible}
#ai-fab .bx{width:32px;height:28px;animation:bxfloat 3.6s ease-in-out infinite}
.ai-av .bx{width:20px;height:18px}
.bx-head{fill:#fff;filter:drop-shadow(0 1px 1.5px rgba(0,0,0,.18))}
.bx-bridge,.bx-eyes circle{fill:#16233c}
.bx-eyes{transform-box:fill-box;transform-origin:center;animation:bxblink 4.4s ease-in-out infinite}
@keyframes bxblink{0%,90%,100%{transform:scaleY(1)}95%{transform:scaleY(.1)}}
@keyframes bxfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-2.5px)}}
#ai-fab:hover .bx{animation-duration:1.6s}
/* waving arm (only shown on the header avatar during a greeting) */
.bx-arm{fill:#fff;opacity:0;transform-box:fill-box;transform-origin:bottom center;filter:drop-shadow(0 1px 1.5px rgba(0,0,0,.18))}
.ai-av.greet .bx-arm{animation:bxwave 1.25s ease-in-out 1 forwards}
@keyframes bxwave{0%{opacity:0;transform:rotate(8deg)}12%{opacity:1;transform:rotate(-26deg)}28%{transform:rotate(8deg)}44%{transform:rotate(-26deg)}60%{transform:rotate(6deg)}76%{transform:rotate(-22deg)}90%{opacity:1;transform:rotate(4deg)}100%{opacity:0;transform:rotate(12deg)}}
#ai-panel{position:fixed;right:18px;bottom:142px;z-index:10000;width:370px;max-width:calc(100vw - 36px);
  height:520px;max-height:calc(100vh - 120px);background:#141a2e;border:1px solid #2a3550;border-radius:16px;
  display:none;flex-direction:column;overflow:hidden;box-shadow:0 14px 40px rgba(0,0,0,.6)}
#ai-panel.open{display:flex}
#ai-head{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#0e1424;border-bottom:1px solid #2a3550}
#ai-head .ai-av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#0883a8,#7c3aed);
  display:flex;align-items:center;justify-content:center;font-size:16px}
#ai-head .ai-ttl{color:#dbe3f7;font-size:13.5px;font-weight:600;line-height:1.2}
#ai-head .ai-sub{color:#7e8db3;font-size:10.5px}
#ai-head .ai-x{margin-left:auto;background:#26324f;color:#fff;border:none;width:28px;height:28px;border-radius:8px;cursor:pointer;font-size:13px}
#ai-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.ai-b{max-width:84%;padding:9px 12px;border-radius:13px;font-size:13px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.ai-b.u{align-self:flex-end;background:linear-gradient(135deg,#0883a8,#3b6ed6);color:#fff;border-bottom-right-radius:4px}
.ai-b.a{align-self:flex-start;background:#1c2540;color:#dbe3f7;border:1px solid #2a3550;border-bottom-left-radius:4px}
.ai-b.err{align-self:flex-start;background:#3a1c24;color:#ffc4cf;border:1px solid #5e2733}
.ai-typing{align-self:flex-start;display:flex;gap:4px;padding:11px 14px;background:#1c2540;border:1px solid #2a3550;border-radius:13px}
.ai-typing span{width:7px;height:7px;border-radius:50%;background:#7e8db3;animation:aiblink 1.2s infinite}
.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}
@keyframes aiblink{0%,60%,100%{opacity:.3}30%{opacity:1}}
#ai-sugg{display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 8px}
#ai-sugg button{background:#1c2540;border:1px solid #2a3550;color:#aeb9d8;font-size:11px;padding:5px 10px;border-radius:14px;cursor:pointer}
#ai-sugg button:hover{background:#26324f;color:#fff}
#ai-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid #2a3550;background:#0e1424}
#ai-input textarea{flex:1;resize:none;background:#1c2540;border:1px solid #2a3550;color:#e6ebf7;border-radius:10px;
  padding:9px 11px;font-size:13px;font-family:inherit;max-height:90px;line-height:1.4}
#ai-input textarea:focus{outline:none;border-color:#0883a8}
#ai-input button{background:linear-gradient(135deg,#0883a8,#7c3aed);color:#fff;border:none;border-radius:10px;
  width:42px;font-size:17px;cursor:pointer}
#ai-input button:disabled{opacity:.5;cursor:default}
/* light-theme overrides */
html[data-theme="light"] #ai-panel{background:#ffffff;border:1px solid #e2e8f4;box-shadow:0 14px 40px rgba(20,40,80,.2)}
html[data-theme="light"] #ai-head{background:#f4f7fc;border-bottom:1px solid #e2e8f4}
html[data-theme="light"] #ai-head .ai-ttl{color:#1c2640}
html[data-theme="light"] #ai-head .ai-sub{color:#6b7a9e}
html[data-theme="light"] #ai-head .ai-x{background:#e2e8f4;color:#1c2640}
html[data-theme="light"] .ai-b.a{background:#f0f3fa;color:#1c2640;border:1px solid #e2e8f4}
html[data-theme="light"] .ai-b.err{background:#fdecef;color:#9b1c31;border:1px solid #f5c2cc}
html[data-theme="light"] .ai-typing{background:#f0f3fa;border:1px solid #e2e8f4}
html[data-theme="light"] #ai-sugg button{background:#f0f3fa;border:1px solid #e2e8f4;color:#4a5878}
html[data-theme="light"] #ai-sugg button:hover{background:#e2e8f4;color:#1c2640}
html[data-theme="light"] #ai-input{background:#f4f7fc;border-top:1px solid #e2e8f4}
html[data-theme="light"] #ai-input textarea{background:#ffffff;border:1px solid #dbe2f0;color:#1c2640}
/* ---- proactive briefing: FAB badge + insight cards ---- */
#ai-fab-badge{position:absolute;top:-3px;right:-3px;min-width:19px;height:19px;padding:0 5px;border-radius:10px;
  background:#e0354b;color:#fff;font-size:11px;font-weight:700;line-height:19px;text-align:center;
  box-shadow:0 0 0 2px #141a2e;display:none}
html[data-theme="light"] #ai-fab-badge{box-shadow:0 0 0 2px #ffffff}
#ai-fab.pulse{animation:aifabpulse 1.8s ease-in-out 3}
@keyframes aifabpulse{0%,100%{box-shadow:0 6px 20px rgba(0,0,0,.45)}50%{box-shadow:0 0 0 7px rgba(224,53,75,.25),0 6px 20px rgba(0,0,0,.45)}}
#ai-brief{display:none;flex-direction:column}
#ai-brief.has{display:flex}
/* collapsed summary line: keeps chat unobstructed, expands on tap */
.ai-brief-sum{display:flex;align-items:center;gap:8px;width:100%;border:0;margin:0;cursor:pointer;
  text-align:left;font:inherit;padding:9px 12px;background:transparent;color:#cdd6ee;
  border-bottom:1px solid #232c47}
.ai-brief-sum .ic{font-size:14px;line-height:1}
.ai-brief-sum .tx{font-size:12px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-brief-sum.tahan .tx{color:#ff9fb0}.ai-brief-sum.tinjau .tx{color:#ffd479}.ai-brief-sum.ok .tx{color:#7fe0a6}
.ai-brief-sum .cnt{display:inline-flex;gap:5px}
.ai-brief-sum .cnt b{font-weight:700;padding:1px 7px;border-radius:9px;font-size:10.5px}
.ai-brief-sum .chev{font-size:11px;color:#7e8db3;transition:transform .2s}
#ai-brief.exp .ai-brief-sum .chev{transform:rotate(180deg)}
.ai-brief-cards{max-height:0;overflow:hidden;transition:max-height .25s ease;
  display:flex;flex-direction:column;gap:8px;padding:0 12px}
#ai-brief.exp .ai-brief-cards{max-height:55vh;overflow-y:auto;padding:10px 12px 2px}
.cnt .c-tahan{background:#3a1c24;color:#ff9fb0}.cnt .c-tinjau{background:#3a2f17;color:#ffd479}.cnt .c-ok{background:#15301f;color:#7fe0a6}
.ai-ins{border:1px solid #2a3550;border-left-width:4px;border-radius:11px;background:#1c2540;padding:9px 11px;cursor:pointer;transition:.12s}
.ai-ins:hover{background:#222c4d}
.ai-ins.tahan{border-left-color:#e0354b}.ai-ins.tinjau{border-left-color:#e0a92e}.ai-ins.ok{border-left-color:#28a76a}
.ai-ins .row1{display:flex;align-items:center;gap:8px}
.ai-ins .ic{font-size:15px}
.ai-ins .ttl{font-size:12.5px;font-weight:600;color:#e6ebf7;flex:1;line-height:1.3}
.ai-ins .pill{font-size:9.5px;font-weight:800;letter-spacing:.5px;padding:2px 7px;border-radius:8px;white-space:nowrap}
.ai-ins.tahan .pill{background:#e0354b;color:#fff}.ai-ins.tinjau .pill{background:#e0a92e;color:#23180a}.ai-ins.ok .pill{background:#28a76a;color:#fff}
.ai-ins .dt{font-size:11.5px;color:#aeb9d8;margin-top:5px;line-height:1.45}
.ai-ins .cat{font-size:10px;color:#7e8db3;margin-top:5px}
.ai-ins .cat .go{color:#5aa6ff}
html[data-theme="light"] .ai-brief-sum{color:#46556f;border-bottom-color:#e8edf6}
html[data-theme="light"] .ai-ins{background:#f5f8fd;border-color:#e2e8f4}
html[data-theme="light"] .ai-ins:hover{background:#eef3fb}
html[data-theme="light"] .ai-ins .ttl{color:#1c2640}
html[data-theme="light"] .ai-ins .dt{color:#46556f}
html[data-theme="light"] .ai-ins .cat{color:#7686a4}
html[data-theme="light"] .cnt .c-tahan{background:#fde7ea;color:#c01a33}
html[data-theme="light"] .cnt .c-tinjau{background:#fbf2dc;color:#9a6c08}
html[data-theme="light"] .cnt .c-ok{background:#e3f6ec;color:#177a48}
@media(max-width:480px){#ai-panel{left:10px;right:10px;width:auto;bottom:138px;height:68vh}#ai-fab{right:12px;bottom:12px}}
/* ---- mascot: extra life (thinking, idle wave, concern) ---- */
.bx-body{transform-box:fill-box;transform-origin:center}
/* idle wave: occasional friendly glance when the panel is closed */
#ai-fab .bx-arm{opacity:0}
#ai-fab.idlewave .bx-arm{animation:bxwave 1.3s ease-in-out 1}
#ai-fab.idlewave .bx-body{animation:bxgreetbob 1.3s ease-in-out 1}
@keyframes bxgreetbob{0%,100%{transform:rotate(0)}20%{transform:rotate(-7deg)}50%{transform:rotate(5deg)}80%{transform:rotate(-2deg)}}
/* concerned: small worried tilt while there are TAHAN/TINJAU items */
#ai-fab.concerned .bx-body{animation:bxconcern 2.6s ease-in-out infinite}
@keyframes bxconcern{0%,100%{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}
/* thinking: Jarvis is composing — mascot peers around and nods */
.ai-av.thinking .bx-body{animation:bxnod 1.5s ease-in-out infinite}
@keyframes bxnod{0%,100%{transform:rotate(0)}30%{transform:rotate(-7deg)}70%{transform:rotate(7deg)}}
.ai-av.thinking .bx-eyes{animation:bxlook 1.5s ease-in-out infinite}
@keyframes bxlook{0%,100%{transform:translateX(0)}30%{transform:translateX(-1.5px)}70%{transform:translateX(1.5px)}}
/* ---- mascot mood: "senang" saat semua status OK (mata melengkung ke atas) ---- */
#ai-fab.happy .bx-eyes,.ai-av.happy .bx-eyes,.tb-bx.happy .bx-eyes{animation:bxhappy 3.4s ease-in-out infinite}
@keyframes bxhappy{0%,100%{transform:scaleY(1)}45%,80%{transform:scaleY(.32) translateY(-2.2px)}}
/* ---- login mascot: besar, menyapa sekali saat layar login muncul ---- */
.bxbig .bx{width:60px;height:52px}
.bxbig.greet .bx-arm{animation:bxwave 1.3s ease-in-out 1 .25s forwards}
/* ---- mascot di header topbar: kecil, bisa diklik buka chat ---- */
.tb-bx{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,#0883a8,#7c3aed);cursor:pointer;flex:0 0 auto;margin-right:2px;
  box-shadow:0 3px 10px rgba(0,0,0,.3)}
.tb-bx:hover{filter:brightness(1.08)}
.tb-bx .bx{width:22px;height:19px;animation:bxfloat 3.6s ease-in-out infinite}
.tb-bx:hover .bx{animation-duration:1.6s}
.tb-bx .bx-arm{opacity:0}
.tb-bx.idlewave .bx-arm{animation:bxwave 1.3s ease-in-out 1}
.tb-bx.idlewave .bx-body{animation:bxgreetbob 1.3s ease-in-out 1}
@media(max-width:600px){.tb-bx{width:30px;height:30px}.tb-bx .bx{width:20px;height:18px}}
/* ---- bubble sapaan "Halo Kevin 👋" yang muncul-ilang otomatis ---- */
#ai-greet-bubble{position:fixed;right:84px;bottom:30px;z-index:9998;background:#141a2e;color:#dbe3f7;
  border:1px solid #2a3550;padding:9px 13px;border-radius:14px;border-bottom-right-radius:4px;font-size:13px;
  box-shadow:0 8px 24px rgba(0,0,0,.45);opacity:0;transform:translateY(8px) scale(.96);
  transition:opacity .35s ease,transform .35s ease;pointer-events:none;white-space:nowrap;max-width:62vw}
#ai-greet-bubble.show{opacity:1;transform:translateY(0) scale(1)}
html[data-theme="light"] #ai-greet-bubble{background:#ffffff;color:#1c2640;border-color:#e2e8f4;
  box-shadow:0 8px 24px rgba(20,40,80,.18)}
@media(max-width:480px){#ai-greet-bubble{right:70px;bottom:24px;font-size:12px}}
