/* ============================================================
   AI-ассистент — глобальный слайд-овер чат
   ============================================================ */
.ai-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 440px; max-width: 92vw;
  background: var(--bg-elev);
  z-index: 140; display: flex; flex-direction: column;
  box-shadow: var(--shadow-lg);
  animation: slideInRight .24s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.ai-scrim { z-index: 135; }

.ai-head { padding: 14px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 11px; }
.ai-mark {
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  background: linear-gradient(140deg, var(--brand), #8b5cf6); color: #fff;
  display: grid; place-items: center; box-shadow: 0 5px 14px -4px rgba(91,91,240,0.6);
}
.ai-head .t { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.ai-head .s { font-size: 11.5px; color: var(--text-muted); display: inline-flex; align-items: center; gap: 5px; }
.ai-head .s .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--ok-fg); }

.ai-msgs { flex: 1; overflow-y: auto; padding: 18px 16px; display: flex; flex-direction: column; gap: 14px; }

.ai-empty { display: flex; flex-direction: column; gap: 14px; padding: 8px 2px; }
.ai-greet { font-size: 14px; color: var(--text-soft); line-height: 1.5; }
.ai-greet b { color: var(--text); font-weight: 600; }
.ai-suggest-h { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); font-weight: 600; }
.ai-suggest { display: flex; flex-direction: column; gap: 7px; }
.ai-suggest button {
  text-align: left; border: 1px solid var(--border); background: var(--bg-elev);
  border-radius: 10px; padding: 10px 12px; font-size: 13px; color: var(--text); cursor: pointer;
  display: flex; align-items: center; gap: 9px; transition: border-color .12s, background .12s;
}
.ai-suggest button:hover { border-color: var(--brand-border); background: var(--brand-soft); }
.ai-suggest button .ic { color: var(--brand); flex-shrink: 0; }

.ai-msg { display: flex; }
.ai-msg.user { justify-content: flex-end; }
.ai-msg.bot { justify-content: flex-start; }
.ai-bubble { max-width: 88%; padding: 11px 13px; border-radius: 13px; font-size: 13.5px; line-height: 1.5; }
.ai-msg.user .ai-bubble { background: var(--accent); color: #fff; border-bottom-right-radius: 4px; }
.ai-msg.bot .ai-bubble { background: var(--bg-muted); border: 1px solid var(--border); border-bottom-left-radius: 4px; color: var(--text); }

.ai-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 11px; }
.ai-card { background: var(--bg-elev); border: 1px solid var(--border); border-radius: 9px; padding: 8px 10px; }
.ai-card .k { font-size: 10.5px; color: var(--text-muted); }
.ai-card .v { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; font-feature-settings: 'tnum'; margin-top: 1px; }
.ai-card.ok .v { color: var(--ok-fg); } .ai-card.warn .v { color: var(--warn-fg); } .ai-card.crit .v { color: var(--crit-fg); }

.ai-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 11px; }
.ai-act {
  display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px; font-weight: 600;
  padding: 6px 11px; border-radius: 999px; cursor: pointer;
  background: var(--bg-elev); border: 1px solid var(--brand-border); color: var(--brand-strong);
  transition: background .12s;
}
.ai-act:hover { background: var(--brand-soft); }

.ai-typing { display: inline-flex; gap: 4px; align-items: center; padding: 3px 2px; }
.ai-typing i { width: 7px; height: 7px; border-radius: 999px; background: var(--text-faint); display: inline-block; animation: aitype 1.2s ease-in-out infinite; }
.ai-typing i:nth-child(2) { animation-delay: .15s; } .ai-typing i:nth-child(3) { animation-delay: .3s; }
@keyframes aitype { 0%,60%,100% { opacity: .3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-3px); } }

.ai-foot { padding: 12px; border-top: 1px solid var(--border); background: var(--bg-muted); }
.ai-inputrow { display: flex; gap: 8px; align-items: flex-end; background: var(--bg-elev); border: 1px solid var(--border-strong); border-radius: 12px; padding: 7px 7px 7px 12px; transition: border-color .12s, box-shadow .12s; }
.ai-inputrow:focus-within { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); }
.ai-input { flex: 1; border: 0; outline: none; background: transparent; resize: none; font-size: 13.5px; line-height: 1.45; max-height: 120px; color: var(--text); padding: 4px 0; }
.ai-send { width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0; border: 0; cursor: pointer; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg, var(--brand), #8b5cf6); transition: filter .12s; }
.ai-send:hover:not(:disabled) { filter: brightness(1.07); }
.ai-send:disabled { opacity: .4; cursor: default; }
.ai-foot-hint { font-size: 11px; color: var(--text-faint); text-align: center; margin-top: 7px; }
