/**
 * UnitedLGB themed confirm / alert dialogs (replaces native confirm/alert).
 * Uses theme.css variables; no close icon — dismiss only via action buttons.
 */
.ulgb-dialog-overlay {
    display: none;
    position: fixed;
    inset: 0;
    /* Above .homepage-modal-overlay (2147483647); appended to body after open modals so same z-index stacks on top */
    z-index: 2147483647 !important;
    justify-content: center;
    align-items: center;
    padding: 20px;
    box-sizing: border-box;
    background: rgba(8, 7, 6, 0.88);
    /* Clicks on dimmer do nothing — no dismiss */
    pointer-events: auto;
}

.ulgb-dialog-overlay.ulgb-dialog-open {
    display: flex;
}

.ulgb-dialog {
    width: 100%;
    max-width: 400px;
    background: var(--bg-modal-panel);
    border-radius: 16px;
    border: 1px solid var(--border-subtle);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.04) inset,
        0 24px 64px rgba(0, 0, 0, 0.5);
    overflow: hidden;
}

.ulgb-dialog-accent {
    height: 4px;
    width: 100%;
    background: var(--gradient-cta);
}

.ulgb-dialog--danger .ulgb-dialog-accent {
    background: linear-gradient(90deg, #a67c72 0%, #c9a08f 100%);
}

.ulgb-dialog--error .ulgb-dialog-accent {
    background: linear-gradient(90deg, #8f6a62 0%, #b89a82 100%);
}

.ulgb-dialog--success .ulgb-dialog-accent {
    background: linear-gradient(90deg, #8b9d7a 0%, #9aac8a 100%);
}

.ulgb-dialog--info .ulgb-dialog-accent {
    background: var(--gradient-cta);
}

.ulgb-dialog-body {
    padding: 22px 22px 20px;
}

.ulgb-dialog-message {
    margin: 0;
    font-size: 16px;
    line-height: 1.5;
    color: var(--text-primary);
    font-family: inherit;
    white-space: pre-wrap;
    word-break: break-word;
}

.ulgb-dialog-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
    padding: 0 22px 22px;
}

.ulgb-dialog-btn {
    min-height: 44px;
    padding: 10px 18px;
    border-radius: 12px;
    font-size: 15px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background 0.2s, border-color 0.2s, color 0.2s, box-shadow 0.2s;
}

.ulgb-dialog-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--bg-modal-panel), 0 0 0 4px var(--accent);
}

.ulgb-dialog-btn-secondary {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.1);
    color: var(--text-primary);
}

.ulgb-dialog-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.14);
}

.ulgb-dialog-btn-primary {
    background: var(--gradient-button);
    border-color: rgba(255, 255, 255, 0.12);
    color: var(--text-primary);
}

.ulgb-dialog-btn-primary:hover {
    filter: brightness(1.06);
}

.ulgb-dialog--danger .ulgb-dialog-btn-primary {
    background: linear-gradient(135deg, #8f6a62 0%, #a67c72 100%);
    border-color: rgba(201, 160, 143, 0.35);
}

.ulgb-dialog--danger .ulgb-dialog-btn-primary:hover {
    filter: brightness(1.05);
}
