/**
 * Handfish Dialog Base Styles
 * Generic dialog/modal patterns using native <dialog> element
 */

/* ============================================================================
   Dialog Backdrop
   ============================================================================ */

dialog::backdrop {
    background: var(--hf-backdrop);
    backdrop-filter: var(--hf-glass-blur-sm, blur(4px));
    -webkit-backdrop-filter: var(--hf-glass-blur-sm, blur(4px));
}

/* ============================================================================
   Base Dialog (.hf-dialog)
   ============================================================================ */

.hf-dialog {
    position: fixed;
    padding: 0;
    border: none;
    border-radius: var(--hf-radius-lg, 12px);
    background: color-mix(
        in srgb,
        var(--hf-bg-surface) var(--hf-surface-opacity, 85%),
        transparent var(--hf-surface-transparency, 15%)
    );
    backdrop-filter: var(--hf-glass-blur, blur(16px));
    -webkit-backdrop-filter: var(--hf-glass-blur, blur(16px));
    box-shadow: var(--hf-shadow-xl, 0 20px 60px rgba(0, 0, 0, 0.4));
    color: var(--hf-text-normal);
    max-width: 90vw;
    max-height: 90vh;
    overflow: hidden;
}

.hf-dialog[open] {
    animation: hf-dialog-open 0.2s ease-out;
}

@keyframes hf-dialog-open {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* ============================================================================
   Dialog Title
   ============================================================================ */

.hf-dialog-title {
    font-size: var(--hf-size-lg);
    font-weight: var(--hf-weight-semibold);
    color: var(--hf-text-bright);
    padding: 1.25rem 1.5rem 0;
    margin: 0;
}

/* ============================================================================
   Dialog Body
   ============================================================================ */

.hf-dialog-body {
    padding: 1rem 1.5rem;
    min-width: 320px;
    color: var(--hf-text-normal);
    line-height: 1.5;
}

/* ============================================================================
   Dialog Actions
   ============================================================================ */

.hf-dialog-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 0 1.5rem 1.25rem;
}

/* ============================================================================
   Dialog Close Button (floating)
   ============================================================================ */

.hf-dialog-close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background: transparent;
    border: none;
    color: var(--hf-text-dim);
    cursor: pointer;
    font-size: var(--hf-size-md);
    padding: 0.25em 0.5em;
    line-height: 1;
    opacity: 0.7;
    transition: opacity 0.15s ease;
}

.hf-dialog-close:focus-visible {
    outline: var(--hf-focus-ring-width) solid var(--hf-focus-ring-color);
    outline-offset: var(--hf-focus-ring-offset);
}

.hf-dialog-close:hover {
    opacity: 1;
    color: var(--hf-text-normal);
}
