/* =====================================================================
 *  モーダル ブロック（フロント共通）
 *  my-snow-monkey/modal ＋ modal-trigger ＋ modal-content
 * ===================================================================== */

.msm-modal-block {
	--msm-modal-overlay: rgba(0, 0, 0, 0.6);
	--msm-modal-bg: #ffffff;
	--msm-modal-color: inherit;
	--msm-modal-radius: 12px;
	--msm-modal-padding: 32px;
	--msm-modal-max-width: 720px;
}

/* ---------- トリガー領域（中に本物のボタンブロックが入る） ---------- */
.msm-modal-block__trigger {
	cursor: pointer;
}

/* ボタンブロックのデフォルト下マージンを打ち消す（単独配置時） */
.msm-modal-block__trigger > .wp-block-buttons:last-child,
.msm-modal-block__trigger > .wp-block-snow-monkey-blocks-buttons:last-child {
	margin-bottom: 0;
}

/* ---------- オーバーレイ & ダイアログ ---------- */
.msm-modal-block__overlay {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 4vw;
	background-color: var(--msm-modal-overlay);
	opacity: 0;
	transition: opacity 0.3s ease;
	overscroll-behavior: contain;
}

.msm-modal-block__overlay[hidden] {
	display: none;
}

.msm-modal-block__overlay.is-open {
	opacity: 1;
}

.msm-modal-block__dialog {
	position: relative;
	max-width: 900px; 
	max-height: 86vh;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	padding: var(--msm-modal-padding);
	background-color: var(--msm-modal-bg);
	color: var(--msm-modal-color);
	border-radius: var(--msm-modal-radius);
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
	transition: transform 0.3s ease, opacity 0.3s ease;
}

.msm-modal-block__dialog:focus {
	outline: none;
}

.msm-modal-block__content > :first-child {
	margin-top: 0;
}

.msm-modal-block__content > :last-child {
	margin-bottom: 0;
}

/* ---------- 閉じるボタン ---------- */
.msm-modal-block__close {
	position: absolute;
	top: 12px;
	right: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	margin: 0;
	padding: 0;
	font-size: 1.5rem;
	line-height: 1;
	color: inherit;
	background-color: rgba(0, 0, 0, 0.06);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	transition: transform 0.15s ease, background-color 0.15s ease, opacity 0.15s ease;
}

.msm-modal-block__close:hover {
	transform: rotate(90deg);
	background-color: rgba(0, 0, 0, 0.12);
}

.msm-modal-block__close:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* 閉じるボタン: プレーン（親クラスで制御） */
.msm-modal--close-plain .msm-modal-block__close {
	background-color: transparent;
	border-radius: 0;
}

/* 閉じるボタン: 非表示（親クラスで制御） */
.msm-modal--no-close .msm-modal-block__close {
	display: none;
}

/* ---------- アニメーション ---------- */
.msm-modal-anim-fade .msm-modal-block__dialog {
	transform: translateY(8px);
	opacity: 0;
}

.msm-modal-anim-fade .msm-modal-block__overlay.is-open .msm-modal-block__dialog {
	transform: translateY(0);
	opacity: 1;
}

.msm-modal-anim-slide .msm-modal-block__dialog {
	transform: translateY(40px);
	opacity: 0;
}

.msm-modal-anim-slide .msm-modal-block__overlay.is-open .msm-modal-block__dialog {
	transform: translateY(0);
	opacity: 1;
}

.msm-modal-anim-zoom .msm-modal-block__dialog {
	transform: scale(0.9);
	opacity: 0;
}

.msm-modal-anim-zoom .msm-modal-block__overlay.is-open .msm-modal-block__dialog {
	transform: scale(1);
	opacity: 1;
}

/* ---------- 本文スクロールロック ---------- */
body.msm-modal-open {
	overflow: hidden;
}

/* ---------- レスポンシブ ---------- */
@media (max-width: 639px) {
	.msm-modal-block__dialog {
		width: 94vw;
		max-height: 88vh;
		padding: clamp(16px, 5vw, var(--msm-modal-padding));
	}
}

/* ---------- モーションを抑える設定への配慮 ---------- */
@media (prefers-reduced-motion: reduce) {
	.msm-modal-block__overlay,
	.msm-modal-block__dialog,
	.msm-modal-block__close {
		transition: none !important;
	}
}
