/* Stripe 決済結果ページ（決済完了・決済キャンセル） */

/* ベースレイアウト */
.payment-result,
.payment-result * {
	box-sizing: border-box;
}

.payment-result {
	padding: 100px 20px;
	min-height: 70vh;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f8f9fa;
	/* 薄いグレーの背景でカードを引き立てる */
	width: 100%;
	max-width: 100vw;
	/* 画面幅を超えないように制限 */
	overflow-x: hidden;
	/* 横スクロール防止 */
}

.payment-container {
	width: 100%;
	max-width: 600px;
	/* カード幅を制限 */
	margin: 0 auto;
}

/* カードデザイン */
.payment-card {
	background: #fff;
	border-radius: 20px;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
	padding: 60px 40px;
	text-align: center;
	opacity: 0;
	transform: translateY(20px);
	animation: fadeUp 0.8s ease-out forwards;
}

/* アイコンエリア */
.payment-icon-area {
	margin-bottom: 30px;
}

.payment-status-icon {
	width: 80px;
	height: 80px;
	display: inline-block;
}

/* タイトルエリア */
.payment-title-area {
	margin-bottom: 30px;
}

.payment-page-title {
	font-size: 2.4rem;
	font-weight: 700;
	margin-bottom: 15px;
	color: #333;
	line-height: 1.4;
}

.payment-page-subtitle {
	font-size: 1.1rem;
	color: #888;
	font-weight: 500;
	letter-spacing: 0.05em;
	font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

/* メッセージエリア */
.payment-message {
	font-size: 1.05rem;
	line-height: 1.8;
	color: #555;
	margin-bottom: 40px;
}

.payment-message .sp-only {
	display: none;
}

/* ボタンエリア */
.payment-btn-area {
	margin-top: 40px;
}

.payment-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #111;
	color: #fff;
	text-decoration: none;
	padding: 18px 50px;
	border-radius: 50px;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.payment-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
	background: #333;
	color: #fff;
	opacity: 1;
	/* 親テーマのhover opacityを打ち消し */
}

/* ----------------------------------------------------
   Success Page Styling
---------------------------------------------------- */
.payment-result--success .payment-card {
	border-top: 5px solid #28A745;
}

.payment-result--success .payment-status-icon circle {
	fill: #28A745;
	fill-opacity: 0.1;
}

.payment-result--success .payment-status-icon path {
	stroke: #28A745;
	stroke-dasharray: 50;
	stroke-dashoffset: 50;
	animation: drawCheck 0.6s 0.4s ease-out forwards;
}

/* ----------------------------------------------------
   Cancel Page Styling
---------------------------------------------------- */
.payment-result--cancel .payment-card {
	border-top: 5px solid #CF3141;
}

.payment-result--cancel .payment-status-icon circle {
	fill: #CF3141;
	fill-opacity: 0.1;
}

.payment-result--cancel .payment-status-icon path {
	stroke: #CF3141;
	stroke-dasharray: 50;
	stroke-dashoffset: 50;
	animation: drawCheck 0.6s 0.4s ease-out forwards;
}

/* タイトルのアクセントカラー */
.payment-result--success .payment-page-subtitle {
	color: #28A745;
}

.payment-result--cancel .payment-page-subtitle {
	color: #CF3141;
}

/* ----------------------------------------------------
   Animations
---------------------------------------------------- */
@keyframes fadeUp {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes drawCheck {
	to {
		stroke-dashoffset: 0;
	}
}

/* ----------------------------------------------------
   Responsive
---------------------------------------------------- */
@media screen and (max-width: 768px) {
	.payment-result {
		padding: 60px 16px;
	}

	.payment-card {
		padding: 40px 24px;
	}

	.payment-page-title {
		font-size: 1.6rem;
	}

	.payment-message .sp-only {
		display: inline;
	}

	.payment-message br:not(.sp-only) {
		display: none;
	}

	.payment-btn {
		width: 100%;
		padding: 16px 20px;
	}
}