Lumi/plugins/lumi_ai/public/assistant.css
2026-06-11 06:35:43 +02:00

30 lines
3.5 KiB
CSS

.lumi-ai-shell { width: 100%; min-width: 0; }
.lumi-ai-pill { width: 100%; min-height: 42px; display: flex; align-items: center; gap: 9px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 7px; background: var(--surface-2); color: var(--ink); cursor: pointer; }
.lumi-ai-pill:hover { border-color: var(--sea); background: var(--surface-3); }
.lumi-ai-mark { display: grid; place-items: center; width: 26px; height: 26px; border-radius: 6px; background: var(--sea); color: white; font-size: 10px; font-weight: 800; }
.lumi-ai-pill-label { flex: 1; text-align: left; font-weight: 700; }
.lumi-ai-state { width: 8px; height: 8px; border-radius: 50%; background: #8b949e; box-shadow: 0 0 0 3px color-mix(in srgb, #8b949e 18%, transparent); }
.lumi-ai-state.ready { background: #2ea043; box-shadow: 0 0 0 3px color-mix(in srgb, #2ea043 18%, transparent); }
.lumi-ai-state.error { background: #d73a49; box-shadow: 0 0 0 3px color-mix(in srgb, #d73a49 18%, transparent); }
.lumi-ai-panel { position: fixed; z-index: 80; left: calc(var(--sidebar-width, 260px) + 14px); right: 14px; top: var(--lumi-ai-top, calc(100vh - 16.666vh - 14px)); height: max(180px, 16.666vh); max-height: calc(100vh - 16px); display: grid; grid-template-rows: auto 1fr auto; overflow: hidden; border: 1px solid var(--border); border-radius: 8px; background: var(--card); box-shadow: 0 18px 55px rgba(0,0,0,.22); opacity: 0; transform: translateY(100%); pointer-events: none; transition: transform 0.5s ease-in-out, height 0.5s ease-in-out, opacity 0.5s ease-in-out; }
.lumi-ai-panel.open { opacity: 1; transform: translateY(0); pointer-events: auto; }
.lumi-ai-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; border-bottom: 1px solid var(--border); background: var(--surface-2); }
.lumi-ai-header div { display: flex; align-items: baseline; gap: 10px; }
.lumi-ai-header span { color: var(--ink-soft); font-size: 12px; }
.lumi-ai-close { border: 0; background: transparent; color: var(--ink-soft); font-size: 22px; cursor: pointer; }
.lumi-ai-messages { min-height: 0; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 8px; }
.lumi-ai-message { max-width: min(760px, 86%); padding: 8px 10px; border-radius: 7px; white-space: pre-wrap; overflow-wrap: anywhere; line-height: 1.4; }
.lumi-ai-message.assistant { align-self: flex-start; background: var(--surface-2); border: 1px solid var(--border); }
.lumi-ai-message.user { align-self: flex-end; background: var(--sea); color: white; }
.lumi-ai-message.error { border-color: var(--rose); color: var(--rose); }
.lumi-ai-confirm { display: flex; gap: 8px; margin-top: 8px; }
.lumi-ai-confirm button { padding: 5px 9px; border-radius: 5px; border: 1px solid var(--border); cursor: pointer; }
.lumi-ai-compose { display: grid; grid-template-columns: 1fr 40px; gap: 8px; padding: 10px 12px; border-top: 1px solid var(--border); }
.lumi-ai-compose textarea { width: 100%; min-height: 40px; max-height: 96px; resize: vertical; border: 1px solid var(--border); border-radius: 6px; background: var(--surface-2); color: var(--ink); padding: 8px; }
.lumi-ai-compose button { display: grid; place-items: center; border: 0; border-radius: 6px; background: var(--sea); color: white; cursor: pointer; }
.lumi-ai-compose svg { width: 19px; height: 19px; }
@media (max-width: 800px) { .lumi-ai-panel { left: 10px; right: 10px; } }
body.sidebar-collapsed .lumi-ai-pill { justify-content: center; padding: 8px; }
body.sidebar-collapsed .lumi-ai-pill-label,
body.sidebar-collapsed .lumi-ai-state { display: none; }