/* ═══════════════════════════════════════════════════════════════
   04-animations.css — Keyframes, Transitions & Motion
   ─────────────────────────────────────────────────────────────
   Central library of reusable @keyframes plus the overlay,
   toast, and modal components that depend on them.

   Sections:
     • @keyframes            (backdrop, modal, toast, spinner,
                              search, slide, shake)
     • .zimam-modal-*        (backdrop, container, header, body)
     • .zimam-toast-*        (container, icon, progress bar)
     • .zimam-search-*       (overlay, input, results)
     • .zimam-spinner        (loading indicator)
     • .zimam-confirm-dialog (confirmation overlay)

   Depends on: 01-tokens.css (colours, z-index, radius, shadow).
   Consumers: ConfirmDialog, ToastContainer, SearchOverlay,
              BaseDrawer, ModalBase — via ::deep or global class.
   ═══════════════════════════════════════════════════════════════ */

/* ── Keyframes ── */
@keyframes zimam-backdrop-in  { from { opacity: 0 } to { opacity: 1 } }
@keyframes zimam-backdrop-out { from { opacity: 1 } to { opacity: 0 } }
@keyframes zimam-content-appear {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes zimam-modal-in {
    from { opacity: 0; transform: scale(.92) translateY(10px) }
    to   { opacity: 1; transform: scale(1)  translateY(0) }
}
@keyframes zimam-toast-in {
    from { opacity: 0; transform: translateX(-50%) translateY(-16px) }
    to   { opacity: 1; transform: translateX(-50%) translateY(0) }
}
@keyframes zimam-toast-out {
    from { opacity: 1; transform: translateX(-50%) translateY(0) }
    to   { opacity: 0; transform: translateX(-50%) translateY(-16px) }
}
@keyframes zimam-spin { to { transform: rotate(360deg) } }
@keyframes zimam-logo-pulse {
    0%, 100% { opacity: 0.3 }
    50%      { opacity: 1 }
}
@keyframes zimam-logo-breathe {
    0%, 100% { transform: scale(0.98) }
    50%      { transform: scale(1.02) }
}

/* ── Toast notification ── */
.zimam-toast {
    position: fixed;
    top: 1.25rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: var(--z-toast);
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.75rem 1.25rem;
    border-radius: 0.75rem;
    font-size: var(--text-md);
    font-weight: var(--fw-medium);
    line-height: var(--lh-normal);
    max-width: 90vw;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
    pointer-events: none;
    will-change: opacity, transform;
}
.zimam-toast[data-state="open"]   { animation: zimam-toast-in  var(--duration-slow) var(--ease-out) both; }
.zimam-toast[data-state="closed"] { animation: zimam-toast-out var(--duration-slow) var(--ease-in)  both; }

.zimam-toast--success {
    background: var(--color-success-bg);
    color: var(--color-success-text);
    border: 1px solid var(--color-success-border);
}
.zimam-toast--error {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}
.zimam-toast__icon { flex-shrink: 0; }
.zimam-toast__text { line-height: var(--lh-tight); }

/* ── Modal ── */
.zimam-modal {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.zimam-modal__backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    animation: zimam-backdrop-in var(--duration-normal) var(--ease-out) both;
}
.zimam-modal__card {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 400px;
    background: var(--color-surface);
    border-radius: 1rem;
    border: 1px solid var(--color-border);
    padding: 1.5rem;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
    animation: zimam-modal-in 0.25s var(--ease-out) both;
}
.zimam-modal__body {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.75rem;
}
.zimam-modal__icon {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: #fef2f2;
    display: flex;
    align-items: center;
    justify-content: center;
}
.zimam-modal__title {
    margin: 0;
    font-size: var(--text-xl);
    font-weight: var(--fw-semibold);
    color: var(--color-text-strong);
    line-height: var(--lh-tight);
}
.zimam-modal__message {
    margin: 0;
    font-size: var(--text-base);
    color: var(--color-text-muted);
    line-height: var(--lh-relaxed);
}
.zimam-modal__actions {
    display: flex;
    gap: 0.75rem;
    margin-top: 1.5rem;
}
.zimam-modal__btn {
    flex: 1;
    height: 2.625rem;
    border-radius: 0.625rem;
    font-size: var(--text-md);
    font-weight: var(--fw-medium);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
}
.zimam-modal__btn:disabled { opacity: 0.55; cursor: not-allowed; }
.zimam-modal__btn--cancel {
    background: var(--color-surface);
    color: var(--color-text-secondary);
    border: 1px solid var(--color-border);
}
.zimam-modal__btn--cancel:hover:not(:disabled) { background: var(--color-bg-subtle); }
.zimam-modal__btn--danger {
    background: #dc2626;
    color: #fff;
    border: none;
}
.zimam-modal__btn--danger:hover:not(:disabled) { background: #b91c1c; }
.zimam-modal__btn--primary {
    background: var(--color-primary, #2563eb);
    color: #fff;
    border: none;
}
.zimam-modal__btn--primary:hover:not(:disabled) {
    background: color-mix(in srgb, var(--color-primary, #2563eb) 88%, black);
}

/* ── Z-Logo Spinner ── */
.zimam-logo-spinner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: var(--zimam-spinner-sz, 96px);
    height: var(--zimam-spinner-sz, 96px);
    color: var(--color-text-strong, #0f172a);
}
.zimam-logo-spinner--sm { --zimam-spinner-sz: 64px; }
.zimam-logo-spinner--xs { --zimam-spinner-sz: 44px; }

.zimam-logo-spinner__ring {
    position: absolute;
    inset: 0;
    margin: auto;
    width: 85%;
    height: 85%;
    border-radius: 50%;
    border: 3px solid color-mix(in srgb, currentColor 10%, transparent);
    border-top-color: currentColor;
    animation: zimam-spin 1.5s linear infinite;
    will-change: transform;
}

.zimam-logo-spinner__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40%;
    height: 40%;
    flex-shrink: 0;
}

.zimam-logo-spinner__svg {
    width: 100%;
    height: 100%;
    overflow: visible;
    animation: zimam-logo-breathe 2s ease-in-out infinite;
    filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.06));
}

.zimam-logo-spinner__path--top {
    animation: zimam-logo-pulse 1.5s ease-in-out infinite;
}

.zimam-logo-spinner__path--body {
    animation: zimam-logo-pulse 1.5s ease-in-out infinite;
    animation-delay: 0.2s;
}

@media (prefers-reduced-motion: reduce) {
    .zimam-logo-spinner__ring,
    .zimam-logo-spinner__svg,
    .zimam-logo-spinner__path--top,
    .zimam-logo-spinner__path--body {
        animation: none;
    }

    .zimam-logo-spinner__path--top,
    .zimam-logo-spinner__path--body {
        opacity: 1;
    }
}

/* Light spinner variant (for use on colored buttons) */
.zimam-btn-spinner--light {
    border-color: rgba(255, 255, 255, 0.35);
    border-top-color: #fff;
}

/* ── Spinner ── */
.zimam-btn-spinner {
    display: inline-block;
    width: 16px; height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: zimam-spin 0.5s linear infinite;
    vertical-align: middle;
}

/* Inline row spinner — shown on rows pending a background save. */
.zimam-row-spinner {
    display: inline-block;
    width: 12px; height: 12px;
    margin-inline-start: 0.5rem;
    border: 2px solid var(--color-border, #e2e8f0);
    border-top-color: var(--color-text-strong, #0f172a);
    border-radius: 50%;
    animation: zimam-spin 0.6s linear infinite;
    vertical-align: middle;
    flex-shrink: 0;
}

/* ── Search box ── */
.zimam-search {
    flex: 1;
    min-width: 200px;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    height: 2.125rem;
    padding-inline: 0.75rem;
    border-radius: 0.75rem;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    transition: border-color var(--duration-fast), box-shadow var(--duration-fast);
}
.zimam-search:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-ring);
}
.zimam-search__icon {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
    color: var(--color-text-faint);
}
.zimam-search__input {
    flex: 1;
    min-width: 0;
    background: transparent;
    border: 0;
    color: var(--color-text-strong);
    font-size: 12px;
    line-height: var(--lh-normal);
}
.zimam-search__input::placeholder { color: var(--color-text-faint); }
.zimam-search__input:focus { outline: none; }
