/**
 * Standard app modals (confirmations, pickers, forms in dialog).
 * Loaded on app pages after app-theme.css. Excludes PDF customization-modal.
 */

.modal.fade:not(.customization-modal) .modal-dialog {
	margin: 1.25rem auto;
	max-width: min(32rem, calc(100% - 2rem));
}

.modal.fade:not(.customization-modal) .modal-dialog.modal-lg {
	max-width: min(48rem, calc(100% - 2rem));
}

.modal.fade:not(.customization-modal) .modal-dialog.modal-sm {
	max-width: min(24rem, calc(100% - 2rem));
}

.modal.fade:not(.customization-modal) .modal-content {
	border: none;
	border-radius: 20px;
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	background: var(--surface);
}

.modal.fade:not(.customization-modal) .modal-header {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 1.125rem 1.25rem;
	border-bottom: 1px solid var(--border);
	background: var(--surface);
}

.modal.fade:not(.customization-modal) .modal-header.bg-success,
.modal.fade:not(.customization-modal) .modal-header.bg-primary,
.modal.fade:not(.customization-modal) .modal-header.bg-danger,
.modal.fade:not(.customization-modal) .modal-header.bg-dark {
	background: var(--surface) !important;
	border-bottom: 1px solid var(--border);
}

.modal.fade:not(.customization-modal) .modal-title {
	flex: 1 1 auto;
	min-width: 0;
	margin: 0;
	font-family: var(--font-family);
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--text-dark);
}

.modal.fade:not(.customization-modal) .modal-header .modal-title.text-white {
	color: var(--text-dark) !important;
}

.modal.fade:not(.customization-modal) .modal-body {
	padding: 1.25rem 1.25rem 1.35rem;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--text-mid);
}

.modal.fade:not(.customization-modal) .modal-body p:last-child {
	margin-bottom: 0;
}

.modal.fade:not(.customization-modal):not(.live-signature-modal) .modal-footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.625rem;
	padding: 0.875rem 1.25rem;
	border-top: 1px solid var(--border);
	background: var(--bg);
}

.modal.fade:not(.customization-modal):not(.live-signature-modal) .modal-footer .btn {
	min-height: var(--btn-min-height);
	padding: var(--btn-padding-y) var(--btn-padding-x);
	font-size: var(--btn-font-size);
	font-weight: var(--btn-font-weight);
	border-radius: var(--btn-border-radius);
	border-width: var(--btn-border-width);
}

.modal.fade:not(.customization-modal) .modal-footer .btn-outline-secondary,
.modal.fade:not(.customization-modal) .modal-footer .btn.btn-outline-secondary {
	background-color: transparent !important;
	border-color: var(--border) !important;
	color: var(--text-mid) !important;
	box-shadow: none !important;
}

.modal.fade:not(.customization-modal) .modal-footer .btn-outline-secondary:hover,
.modal.fade:not(.customization-modal) .modal-footer .btn.btn-outline-secondary:hover {
	background-color: var(--primary-ghost) !important;
	border-color: var(--primary-mid) !important;
	color: var(--primary-mid) !important;
}

.modal.fade:not(.customization-modal) .modal-footer .btn-outline-danger,
.modal.fade:not(.customization-modal) .modal-footer .btn.btn-outline-danger {
	background-color: transparent !important;
	border-color: rgba(229, 62, 62, 0.45) !important;
	color: var(--danger) !important;
	box-shadow: none !important;
}

.modal.fade:not(.customization-modal) .modal-footer .btn-outline-danger:hover,
.modal.fade:not(.customization-modal) .modal-footer .btn.btn-outline-danger:hover,
.modal.fade:not(.customization-modal) .modal-footer .btn-outline-danger:focus,
.modal.fade:not(.customization-modal) .modal-footer .btn.btn-outline-danger:focus {
	background-color: var(--danger) !important;
	border-color: var(--danger) !important;
	color: #fff !important;
}

.modal.fade:not(.customization-modal) .modal-footer .btn-outline-primary,
.modal.fade:not(.customization-modal) .modal-footer .btn.btn-outline-primary {
	box-shadow: none;
}

.modal.fade:not(.customization-modal) .modal-header .btn-close {
	flex-shrink: 0;
	width: 2rem;
	height: 2rem;
	margin: 0;
	padding: 0;
	border-radius: var(--radius-xs);
	border: 1px solid var(--border);
	background-color: var(--surface);
	opacity: 1;
}

.modal.fade:not(.customization-modal) .modal-header .btn-close:hover {
	border-color: var(--primary-mid);
	background-color: var(--primary-ghost);
}

.modal.fade:not(.customization-modal) .modal-header .btn-close.btn-close-white {
	filter: none;
	background-color: var(--surface);
	border-color: var(--border);
}

.modal.fade:not(.customization-modal) .modal-backdrop.show {
	opacity: 0.45;
}

@media (max-width: 575.98px) {
	.modal.fade:not(.customization-modal) .modal-dialog {
		margin: 0.75rem auto;
	}

	.modal.fade:not(.customization-modal):not(.live-signature-modal) .modal-footer {
		flex-direction: row;
	}

	.modal.fade:not(.customization-modal):not(.live-signature-modal) .modal-footer .btn {
		flex: 0 1 auto;
	}
}

/*
 * Modals portaled from the dashboard iframe — centered on the parent app viewport.
 */
.osinv-parent-portal-modal,
#osinv-dynamic-confirm-modal {
	z-index: 1060;
}

body:has(.osinv-parent-portal-modal.show) .modal-backdrop,
body:has(#osinv-dynamic-confirm-modal.show) .modal-backdrop {
	z-index: 1055;
}

.osinv-parent-portal-modal .modal-dialog.modal-dialog-centered,
#osinv-dynamic-confirm-modal .modal-dialog.modal-dialog-centered {
	min-height: calc(100% - 3rem);
}

.osinv-parent-portal-modal .modal-content,
#osinv-dynamic-confirm-modal .modal-content {
	max-height: calc(100vh - 3rem);
	max-height: calc(100dvh - 3rem);
}

.osinv-parent-portal-modal .modal-body,
#osinv-dynamic-confirm-modal .modal-body {
	overflow-y: auto;
}

/*
 * Compact flash alert + confirm — content-sized (not viewport-stretched).
 * Portaled to the dashboard parent; Bootstrap modal-body defaults to flex: 1 1 auto.
 */
#osinv-dynamic-alert-modal .modal-content,
#osinv-dynamic-confirm-modal .modal-content {
	flex: 0 0 auto;
	align-self: center;
	height: auto;
	max-height: min(24rem, calc(100dvh - 3rem));
}

#osinv-dynamic-alert-modal .modal-body,
#osinv-dynamic-confirm-modal .modal-body {
	flex: 0 1 auto;
	overflow-y: visible;
	min-height: 0;
}

#osinv-dynamic-alert-modal .modal-footer,
#osinv-dynamic-confirm-modal .modal-footer {
	flex-shrink: 0;
}

/* Share modal portaled to dashboard parent — explicit button colors (iframe CSS may not apply) */
.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__action-btn,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn.btn-outline-primary {
	background-color: transparent !important;
	border-color: var(--primary-mid) !important;
	color: var(--primary-mid) !important;
	box-shadow: none !important;
}

.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn i,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn span,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__action-btn i,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__action-btn span,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn i,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn span,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn .osinv-wa-icon {
	color: inherit !important;
}

.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn:hover,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn:focus,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn:focus-visible,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn:active,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__action-btn:hover,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__action-btn:focus,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__action-btn:focus-visible,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__action-btn:active,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn.btn-outline-primary:hover,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn.btn-outline-primary:focus,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn.btn-outline-primary:focus-visible,
.osinv-parent-portal-modal.document-share-modal .document-share-modal__actions .btn.btn-outline-primary:active {
	background-color: var(--primary-mid) !important;
	border-color: var(--primary-mid) !important;
	color: #fff !important;
}

.osinv-parent-portal-modal.document-share-modal .document-share-modal__copy-btn.is-copied {
	background: #edf7f0 !important;
	border-color: var(--success, #198754) !important;
	color: var(--success, #198754) !important;
}

html.osinv-in-iframe .modal-backdrop.show {
	z-index: 1050;
}

/*
 * Bulk PDF ZIP download — parent viewport overlay (iframe posts osinvBulkPdfOverlay).
 */
.osinv-bulk-pdf-overlay {
	position: fixed;
	inset: 0;
	z-index: 1080;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	background: rgba(15, 23, 42, 0.48);
}

.osinv-bulk-pdf-overlay[hidden] {
	display: none !important;
}

.osinv-bulk-pdf-overlay__card {
	min-width: 260px;
	max-width: 380px;
	padding: 1.5rem 2rem;
	text-align: center;
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 18px 48px rgba(15, 23, 42, 0.2);
}

.osinv-bulk-pdf-overlay__title {
	margin-bottom: 0.25rem;
	font-weight: 600;
	color: #0f172a;
}

.osinv-bulk-pdf-overlay .osinv-bulk-pdf-hourglass {
	display: block;
	margin: 0 auto 1rem;
	font-family: 'Material Symbols Outlined';
	font-size: 3rem;
	font-weight: normal;
	font-style: normal;
	line-height: 1;
	letter-spacing: normal;
	text-transform: none;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 48;
	color: var(--primary-mid, var(--primary-mid));
}
