/* ============================================================================
   MODAL
   Polished override of Bootstrap modals — softer chrome, tighter typography,
   refined header/footer treatment.
   ============================================================================ */

.modal-content {
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-hard);
    background: var(--surface-1);
}

.modal-header {
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--surface-1);
    border-bottom: 1px solid var(--border-light);
    align-items: center;
}

.modal-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--text-strong);
    letter-spacing: var(--letter-spacing-tight);
    line-height: var(--line-height-snug);
    margin: 0;
}

.modal-body {
    padding: var(--spacing-lg);
    color: var(--text-default);
    font-size: var(--font-size-md);
    line-height: var(--line-height-normal);
}

.modal-footer {
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--surface-2);
    border-top: 1px solid var(--border-light);
    gap: var(--spacing-sm);
}

.modal-footer > * { margin: 0; }

.modal-backdrop.show { opacity: 0.55; }
.modal-backdrop { background: var(--bg-dark); }

.btn-close {
    opacity: 0.6;
    transition: var(--transition-fast);
    border-radius: var(--border-radius-sm);
    padding: 0.5rem;
}
.btn-close:hover { opacity: 1; }
.btn-close:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring);
    opacity: 1;
}

/* Offcanvas polish (Bootstrap) — shares the modal look */
.offcanvas {
    background: var(--surface-1);
    border: 0;
    border-left: 1px solid var(--border-color);
    box-shadow: var(--shadow-hard);
}

.offcanvas-header {
    border-bottom: 1px solid var(--border-light);
    padding: var(--spacing-md) var(--spacing-lg);
}

.offcanvas-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--text-strong);
}

.offcanvas-body { padding: var(--spacing-lg); }
