/* core/components/confirm_dialog/confirm_dialog.css — 178-2.13Н
   Reusable confirm dialog — native <dialog> с glass-surface консистентным
   detail_modal/home_pres_card visual language. Compact (¬full-screen overlay
   как detail_modal), focused на quick decision.
   Cascade: unlayered (specificity достаточна без @layer). */

.confirm-dialog {
    margin: auto;
    width: min(100% - 32px, 440px);
    padding: var(--space-xl, 24px);
    background: linear-gradient(145deg, rgba(30, 20, 50, 0.92), rgba(10, 5, 20, 0.96));
    border: 1px solid rgba(var(--text-main-rgb, 255 255 255), 0.12);
    border-radius: var(--radius-lg, 16px);
    color: var(--text-main);
    -webkit-backdrop-filter: blur(24px);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    box-shadow:
        0 24px 64px rgba(var(--black-rgb, 0 0 0), 0.6),
        0 0 0 1px rgba(var(--text-main-rgb, 255 255 255), 0.04) inset;
    /* Starting state */
    opacity: 0;
    transform: translateY(20px) scale(0.96);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.confirm-dialog.is-open {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.confirm-dialog::backdrop {
    background: rgba(var(--bg-color-rgb, 5 2 10), 0.7);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    opacity: 0;
    transition: opacity 0.2s ease;
}
.confirm-dialog.is-open::backdrop {
    opacity: 1;
}

.confirm-dialog__title {
    font-family: 'Play', sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.3;
    margin: 0 0 var(--space-sm, 8px);
    color: var(--text-main);
}

.confirm-dialog__message {
    font-size: 0.88rem;
    line-height: 1.5;
    color: rgba(var(--text-main-rgb, 255 255 255), 0.7);
    margin: 0 0 var(--space-lg, 24px);
}

.confirm-dialog__actions {
    display: flex;
    gap: var(--space-sm, 8px);
    justify-content: flex-end;
}

.confirm-dialog__btn {
    /* Mirror .home-action-btn / .home-topbar-search base — peer-level glass */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 96px;
    height: 36px;
    padding: 0 var(--space-md, 16px);
    background: rgba(var(--text-main-rgb, 255 255 255), 0.04);
    color: var(--text-main);
    border: 1px solid rgba(var(--text-main-rgb, 255 255 255), 0.1);
    border-radius: var(--radius-xs, 8px);
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.88rem;
    font-weight: 500;
    line-height: 1;
    transition: background 0.15s, border-color 0.15s, box-shadow 0.15s;
}

.confirm-dialog__btn:hover {
    background: rgba(var(--text-main-rgb, 255 255 255), 0.08);
    border-color: rgba(var(--text-main-rgb, 255 255 255), 0.18);
}

.confirm-dialog__btn:focus-visible,
.confirm-dialog__btn:focus {
    outline: none;
    border-color: var(--accent-secondary);
    box-shadow: 0 0 0 3px rgba(var(--accent-secondary-rgb), 0.18);
}

/* Destructive confirm — accent-primary (Figma Pink) для visual warning;
   единственное место где accent-primary живёт в peer-level UI ∵ destructive
   класс действий требует elevated visibility (≠ regular CTA). */
.confirm-dialog__btn--confirm.is-danger {
    background: rgba(var(--accent-primary-rgb), 0.16);
    border-color: rgba(var(--accent-primary-rgb), 0.45);
    color: var(--text-main);  /* 208-1Н: solid white для контраста на rgba-magenta */
}

.confirm-dialog__btn--confirm.is-danger:hover {
    background: rgba(var(--accent-primary-rgb), 0.24);
    border-color: rgba(var(--accent-primary-rgb), 0.65);
}

.confirm-dialog__btn--confirm.is-danger:focus-visible,
.confirm-dialog__btn--confirm.is-danger:focus {
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px rgba(var(--accent-primary-rgb), 0.25);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .confirm-dialog,
    .confirm-dialog::backdrop {
        transition: none;
    }
}
