/* Vigilex AI v2 — uses the same semantic operations tokens as the portal. */
.vigilex-ai-root { position: fixed; z-index: 170; right: max(16px, env(safe-area-inset-right)); bottom: max(16px, env(safe-area-inset-bottom)); width: min(390px, calc(100vw - 32px)); color: var(--ui-text); font-family: var(--ui-font); }
.vigilex-ai-root.ai-position-bottom-left { right: auto; left: max(16px, env(safe-area-inset-left)); }
.vigilex-ai-root.ai-position-top-right { top: max(16px, env(safe-area-inset-top)); bottom: auto; }
.vigilex-ai-root.ai-position-top-left { top: max(16px, env(safe-area-inset-top)); right: auto; bottom: auto; left: max(16px, env(safe-area-inset-left)); }
.vigilex-ai-launcher { display: inline-flex; min-height: 48px; align-items: center; gap: 9px; float: right; padding: 7px 13px 7px 8px; border: 1px solid var(--ui-primary); border-radius: 14px; background: var(--ui-primary); box-shadow: var(--ui-shadow-md); color: var(--ui-on-primary); font: inherit; font-size: .83rem; font-weight: 800; }
.ai-position-bottom-left .vigilex-ai-launcher, .ai-position-top-left .vigilex-ai-launcher { float: left; }
.vigilex-ai-launcher:hover { background: var(--ui-primary-hover); border-color: var(--ui-primary-hover); }
.vigilex-ai-launcher-icon { display: grid; width: 32px; height: 32px; place-items: center; border-radius: 10px; background: var(--ui-primary-icon-surface); }
.vigilex-ai-launcher-icon .ui-icon { width: 19px; height: 19px; }
.vigilex-ai-active-dot { display: inline-block; width: 8px; height: 8px; border-radius: 999px; background: var(--ui-success); }
.vigilex-ai-active-dot.is-offline { background: var(--ui-danger); }
.vigilex-ai-launcher-label { white-space: nowrap; }
.vigilex-ai-panel { clear: both; width: 100%; max-height: min(680px, calc(100dvh - 96px)); margin-bottom: 10px; overflow: auto; border: 1px solid var(--ui-border); border-radius: 16px; background: var(--ui-surface); box-shadow: var(--ui-shadow-md); }
.vigilex-ai-panel[hidden] { display: none; }
.ai-position-top-right .vigilex-ai-panel, .ai-position-top-left .vigilex-ai-panel { margin-top: 10px; margin-bottom: 0; }
.vigilex-ai-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px; border-bottom: 1px solid var(--ui-border); background: var(--ui-surface-raised); }
.vigilex-ai-brand { display: flex; min-width: 0; align-items: center; gap: 9px; }
.vigilex-ai-brand > span:last-child { display: grid; min-width: 0; gap: 2px; }
.vigilex-ai-brand strong { overflow: hidden; color: var(--ui-text); font-size: .9rem; text-overflow: ellipsis; white-space: nowrap; }
.vigilex-ai-brand small { display: inline-flex; align-items: center; gap: 5px; color: var(--ui-text-muted); font-size: .72rem; }
.vigilex-ai-avatar { display: grid; width: 34px; height: 34px; place-items: center; overflow: hidden; border: 1px solid var(--ui-border); border-radius: 10px; background: var(--ui-surface-secondary); color: var(--ui-primary); font-size: .8rem; font-weight: 850; object-fit: cover; }
.vigilex-ai-head-actions { display: flex; gap: 5px; }
.vigilex-ai-icon { display: grid; width: 32px; height: 32px; place-items: center; padding: 0; border: 1px solid var(--ui-border); border-radius: 8px; background: var(--ui-surface); color: var(--ui-text); }
.vigilex-ai-icon:hover { background: var(--ui-surface-secondary); color: var(--ui-primary); }
.vigilex-ai-icon .ui-icon { width: 17px; height: 17px; }
.vigilex-ai-impersonation, .vigilex-ai-notice, .vigilex-ai-disclosure { margin: 0; padding: 9px 12px; color: var(--ui-text-muted); font-size: .73rem; line-height: 1.45; }
.vigilex-ai-impersonation { border-bottom: 1px solid var(--ui-border); background: var(--ui-surface-secondary); }
.vigilex-ai-notice { border-bottom: 1px solid var(--ui-border); background: var(--ui-warning-soft); color: var(--ui-text); }
.vigilex-ai-messages { display: grid; min-height: 120px; max-height: 275px; gap: 9px; overflow: auto; padding: 12px; background: var(--ui-surface); }
.vigilex-ai-message { max-width: 88%; padding: 9px 10px; border: 1px solid var(--ui-border); border-radius: 10px; background: var(--ai-agent-bubble-color, var(--ui-surface-raised)); color: var(--ai-agent-text-color, var(--ui-text)); font-size: .84rem; line-height: 1.45; overflow-wrap: anywhere; }
.vigilex-ai-message.user { justify-self: end; border-color: var(--ui-primary-border); background: var(--ai-user-bubble-color, var(--ui-primary-soft)); color: var(--ai-user-text-color, var(--ui-text)); }
.vigilex-ai-message p { margin: 0; }
.vigilex-ai-message a { color: inherit; font-weight: 800; }
.vigilex-ai-message-feedback { display: flex; gap: 4px; padding: 0 2px; }
.vigilex-ai-message-feedback button { min-height: 28px; padding: 4px 7px; border: 1px solid var(--ui-border); border-radius: 7px; background: var(--ui-surface); color: var(--ui-text-muted); font-size: .7rem; font-weight: 700; }
.vigilex-ai-message-feedback button:hover { background: var(--ui-surface-secondary); color: var(--ui-primary); }
.vigilex-ai-message-feedback.is-sent { opacity: .58; }
.vigilex-ai-typing { display: flex; width: fit-content; gap: 4px; padding: 10px 12px; border: 1px solid var(--ui-border); border-radius: 10px; background: var(--ui-surface-raised); }
.vigilex-ai-typing i { display: block; width: 5px; height: 5px; border-radius: 50%; background: var(--ui-text-muted); animation: vigilex-ai-bounce 900ms infinite ease-in-out; }
.vigilex-ai-typing i:nth-child(2) { animation-delay: 120ms; }.vigilex-ai-typing i:nth-child(3) { animation-delay: 240ms; }
@keyframes vigilex-ai-bounce { 0%,60%,100% { transform: translateY(0); } 30% { transform: translateY(-4px); } }
.vigilex-ai-work-panel { display: grid; gap: 8px; margin: 0 12px 10px; padding: 10px; border: 1px solid var(--ui-border); border-radius: 10px; background: var(--ui-surface-raised); }
.vigilex-ai-work-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: .78rem; }
.vigilex-ai-work-head strong { color: var(--ui-text); }.vigilex-ai-work-head a { font-weight: 800; }
.vigilex-ai-work-item { display: grid; gap: 2px; width: 100%; padding: 8px; border: 1px solid var(--ui-border); border-radius: 8px; background: var(--ui-surface); color: var(--ui-text); font-size: .75rem; font-weight: 750; text-align: left; }
.vigilex-ai-work-item:hover { background: var(--ui-surface-secondary); color: var(--ui-primary); }
.vigilex-ai-work-item small { color: var(--ui-text-muted); }
.vigilex-ai-suggestions { display: flex; flex-wrap: wrap; gap: 6px; padding: 0 12px 10px; }
.vigilex-ai-suggestions button { min-height: 30px; padding: 5px 8px; border: 1px solid var(--ui-border); border-radius: 8px; background: var(--ui-surface-raised); color: var(--ui-text); font-size: .72rem; font-weight: 700; text-align: left; }
.vigilex-ai-suggestions button:hover { border-color: var(--ui-accent); color: var(--ui-primary); }
.vigilex-ai-composer { display: grid; grid-template-columns: minmax(0,1fr) 38px; gap: 8px; padding: 10px 12px; border-top: 1px solid var(--ui-border); background: var(--ui-surface); }
.vigilex-ai-composer textarea { min-height: 38px; max-height: 96px; padding: 9px 10px; resize: none; font-size: .83rem; }
.vigilex-ai-composer button { display: grid; width: 38px; height: 38px; place-items: center; padding: 0; border: 1px solid var(--ui-primary); border-radius: 10px; background: var(--ui-primary); color: var(--ui-on-primary); }
.vigilex-ai-composer button:hover { background: var(--ui-primary-hover); border-color: var(--ui-primary-hover); }
.vigilex-ai-composer button:disabled { opacity: .55; cursor: not-allowed; }
.vigilex-ai-composer button .ui-icon { width: 18px; height: 18px; }
.vigilex-ai-disclosure { border-top: 1px solid var(--ui-border); background: var(--ui-surface-raised); }
.vigilex-ai-confirmation, .vigilex-ai-document-card, .vigilex-ai-secure-card { display: grid; gap: 8px; margin: 0 12px 12px; padding: 12px; border: 1px solid var(--ui-border); border-radius: 10px; background: var(--ui-surface-raised); }
.vigilex-ai-confirmation > strong, .vigilex-ai-document-card strong, .vigilex-ai-secure-title strong { color: var(--ui-text); }
.vigilex-ai-confirmation dl { display: grid; gap: 6px; margin: 0; }.vigilex-ai-confirmation dl div { display: grid; grid-template-columns: .7fr 1.3fr; gap: 8px; }.vigilex-ai-confirmation dt { color: var(--ui-text-muted); font-size: .73rem; }.vigilex-ai-confirmation dd { margin: 0; color: var(--ui-text); font-size: .78rem; font-weight: 700; overflow-wrap: anywhere; }
.vigilex-ai-risk { width: fit-content; padding: 4px 7px; border-radius: 999px; background: var(--ui-warning-soft); color: var(--ui-warning); font-size: .68rem; font-weight: 800; text-transform: uppercase; }
.vigilex-ai-card-actions { display: flex; flex-wrap: wrap; gap: 7px; }.vigilex-ai-confirm-button, .vigilex-ai-cancel-button { min-height: 34px; padding: 7px 9px; border-radius: 8px; font-size: .76rem; font-weight: 800; }.vigilex-ai-confirm-button { border: 1px solid var(--ui-primary); background: var(--ui-primary); color: var(--ui-on-primary); }.vigilex-ai-cancel-button { border: 1px solid var(--ui-border); background: var(--ui-surface); color: var(--ui-text); }
.vigilex-ai-confirmation.is-confirmed { border-color: var(--ui-success); }
.vigilex-ai-document-link { width: fit-content; color: var(--ui-primary); font-size: .78rem; font-weight: 800; }
.vigilex-ai-secure-title { display: flex; align-items: center; justify-content: space-between; gap: 8px; }.vigilex-ai-secure-title span { padding: 4px 7px; border-radius: 999px; background: var(--ui-surface-secondary); color: var(--ui-text-muted); font-size: .66rem; font-weight: 800; }.vigilex-ai-secure-card p { margin: 0; color: var(--ui-text-muted); font-size: .75rem; }.vigilex-ai-secure-form { display: grid; gap: 9px; }.vigilex-ai-secure-form label { font-size: .76rem; }.vigilex-ai-secure-status { min-height: 18px; }.vigilex-ai-guest-auth-card input { min-height: 38px; }
@media (max-width: 520px) { .vigilex-ai-root { right: max(10px, env(safe-area-inset-right)); bottom: max(10px, env(safe-area-inset-bottom)); width: min(100% - 20px, 390px); }.vigilex-ai-root.ai-position-bottom-left { left: max(10px, env(safe-area-inset-left)); }.vigilex-ai-panel { max-height: min(610px, calc(100dvh - 84px)); }.vigilex-ai-launcher-label { display: none; }.vigilex-ai-launcher { width: 48px; padding: 7px; justify-content: center; }.vigilex-ai-active-dot { position: absolute; top: 7px; right: 7px; }.vigilex-ai-messages { max-height: 235px; }.vigilex-ai-message { max-width: 93%; } }
@media (prefers-reduced-motion: reduce) { .vigilex-ai-typing i { animation: none; } }
