.modal-sheet {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background-color: rgba(0, 0, 0, 0.2);
}

.modal {
	width: calc(128 * var(--spacing));
	padding: calc(4 * var(--spacing));
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	max-height: 90vh;
	overflow-y: scroll;
	z-index: 99;

	@media (width < 40rem) {
		width: 95vw;
		top: initial;
		bottom: 0;
		transform: translate(-50%, 0);
		border-top-left-radius: var(--radius-2xl);
		border-top-right-radius: var(--radius-2xl);
		border-bottom-left-radius: 0;
		border-bottom-right-radius: 0;
	}

	> header {
		margin-bottom: calc(4 * var(--spacing));
		min-height: calc(4 * var(--spacing));
	}

	&.lg {
		width: calc(256 * var(--spacing));
	}
}

.modal-close-btn {
	position: absolute;
	width: calc(4 * var(--spacing));
	height: calc(4 * var(--spacing));
	top: calc(4 * var(--spacing));
	right: calc(4 * var(--spacing));
	padding: 0;
	background-color: transparent;

	svg { color: var(--text-color) }
}
