/* ==========================================================================
   base_components.css
   Externalized component styles formerly inlined in templates/base.html
   (Batch 11 design-system cleanup, 2026-06-05). Two self-contained blocks:
     1. Global toast stack  (Wave 1.8 + 1.9 — used by window.showToast)
     2. NPS survey modal    (authenticated NPS overlay)
   No selectors or values were changed — this is a verbatim move so behavior
   is identical; only the <style> blocks left base.html.
   ========================================================================== */

/* ── 1. Global toast stack ─────────────────────────────────────────────── */
.autevo-toast-stack{position:fixed;top:20px;right:20px;z-index:11000;display:flex;flex-direction:column;gap:8px;
    max-width:min(380px,calc(100vw - 40px));pointer-events:none}
.autevo-toast{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:10px;
    background:#1f2937;color:#fff;box-shadow:0 6px 24px rgba(0,0,0,.25);font-size:.92rem;line-height:1.35;
    opacity:0;transform:translateY(-6px);transition:opacity .18s ease,transform .18s ease;
    border-left:4px solid #6b7280}
.autevo-toast.is-visible{opacity:1;transform:translateY(0)}
.autevo-toast.is-leaving{opacity:0;transform:translateY(-6px)}
.autevo-toast--success{border-left-color:#10b981}
.autevo-toast--error{border-left-color:#ef4444}
.autevo-toast--warning{border-left-color:#f59e0b}
.autevo-toast--info{border-left-color:#3b82f6}
.autevo-toast__icon{flex:0 0 auto;font-size:1.05rem;line-height:1.2;margin-top:1px}
.autevo-toast__body{flex:1 1 auto;min-width:0;word-wrap:break-word}
.autevo-toast__action{flex:0 0 auto;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35);
    border-radius:6px;padding:4px 10px;font-size:.82rem;cursor:pointer}
.autevo-toast__action:hover{background:rgba(255,255,255,.12)}
.autevo-toast__close{flex:0 0 auto;background:transparent;color:rgba(255,255,255,.7);border:0;font-size:1.05rem;
    line-height:1;cursor:pointer;padding:2px 4px;margin-left:2px}
.autevo-toast__close:hover{color:#fff}
@media (prefers-reduced-motion: reduce){
    .autevo-toast{transition:none}
}

/* ── 2. NPS survey modal ───────────────────────────────────────────────── */
.nps-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:11000;display:none;align-items:center;justify-content:center}
.nps-overlay.show{display:flex}
.nps-card{background:#fff;border-radius:16px;padding:32px;width:440px;max-width:92vw;box-shadow:0 12px 48px rgba(0,0,0,.25);text-align:center;animation:nps-pop .25s ease-out}
@keyframes nps-pop{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.nps-title{font-size:1.15rem;font-weight:700;margin-bottom:6px;color:var(--dark-bg-primary)}
.nps-sub{font-size:.88rem;color:#6b7280;margin-bottom:20px}
.nps-scores{display:flex;gap:6px;justify-content:center;margin-bottom:8px;flex-wrap:wrap}
.nps-btn{width:38px;height:38px;border-radius:10px;border:2px solid var(--neutral-200, #e5e7eb);background:#fff;font-weight:700;font-size:.9rem;
    cursor:pointer;transition:all .15s;color:#374151}
.nps-btn:hover{border-color:var(--primary);color:var(--primary);transform:scale(1.08)}
.nps-btn.selected{background:var(--primary);color:#fff;border-color:var(--primary);transform:scale(1.1)}
.nps-labels{display:flex;justify-content:space-between;font-size:.72rem;color:#9ca3af;margin-bottom:18px;padding:0 2px}
.nps-feedback{width:100%;border:1px solid var(--neutral-200, #e5e7eb);border-radius:10px;padding:10px 14px;font-size:.88rem;resize:vertical;
    min-height:60px;max-height:120px;display:none;margin-bottom:14px;font-family:inherit}
.nps-feedback:focus{outline:none;border-color:var(--primary)}
.nps-actions{display:flex;gap:10px;justify-content:center}
.nps-submit{background:var(--primary);color:#fff;border:none;padding:8px 28px;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9rem;transition:background .15s}
.nps-submit:hover{background:#4f46e5}
.nps-submit:disabled{opacity:.5;cursor:not-allowed}
.nps-skip{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:.85rem;padding:8px 16px}
.nps-skip:hover{color:#6b7280}
.nps-thanks{display:none;padding:20px 0}
.nps-thanks .nps-check{font-size:3rem;margin-bottom:12px}
.dark-mode .nps-card{background:var(--dark-bg-secondary);color:var(--dark-text-primary)}
.dark-mode .nps-title{color:var(--border-color)}
.dark-mode .nps-btn{background:var(--dark-bg-primary);border-color:#374151;color:#d1d5db}
.dark-mode .nps-btn:hover{border-color:#818cf8;color:#818cf8}
.dark-mode .nps-btn.selected{background:var(--primary);color:#fff;border-color:var(--primary)}
.dark-mode .nps-feedback{background:var(--dark-bg-primary);border-color:#374151;color:#d1d5db}
