@charset "UTF-8";

/* =========================================================================
 * RedotPay Child - components.css
 * 共通UIコンポーネント (BEMライク命名)
 *
 * 目次:
 *   1. .rdp-conclusion-box   結論ボックス (AIO最重要)
 *   2. .rdp-cta-button       CTAボタン
 *   3. .rdp-card             汎用カード
 *   4. .rdp-faq              FAQアコーディオン
 *   5. .rdp-author-box       著者BOX
 *   6. .rdp-breadcrumb       パンくず
 *   7. .rdp-table-compare    比較テーブル
 *   8. .rdp-language-switcher 言語スイッチャー
 *   9. .rdp-toc              目次
 * ========================================================================= */

/* -------------------------------------------------------------------------
 * 1. 結論ボックス(全記事冒頭・150-200字推奨)
 * ------------------------------------------------------------------------- */
.rdp-conclusion-box {
	margin: var(--rdp-sp-5) 0 var(--rdp-sp-6);
	padding: var(--rdp-sp-5) var(--rdp-sp-6);
	background: var(--rdp-red-light);
	border: 2px solid var(--rdp-red);
	border-radius: var(--rdp-radius-md);
	box-shadow: var(--rdp-shadow-sm);
	position: relative;
}

.rdp-conclusion-box__title {
	display: inline-flex;
	align-items: center;
	gap: var(--rdp-sp-2);
	margin: 0 0 var(--rdp-sp-3);
	color: var(--rdp-red-dark);
	font-size: 18px;
	font-weight: 900;
	letter-spacing: 0.04em;
}

.rdp-conclusion-box__title::before {
	content: "💡";
	font-size: 22px;
}

.rdp-conclusion-box__list {
	margin: 0;
	padding-left: 1.4em;
	font-weight: 500;
}

.rdp-conclusion-box__list li {
	margin-bottom: var(--rdp-sp-2);
	color: var(--rdp-gray-900);
}

.rdp-conclusion-box__list li:last-child { margin-bottom: 0; }

@media (max-width: 768px) {
	.rdp-conclusion-box {
		padding: var(--rdp-sp-4);
		margin: var(--rdp-sp-4) 0;
	}
}

/* -------------------------------------------------------------------------
 * 2. CTAボタン
 * ------------------------------------------------------------------------- */
.rdp-cta-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--rdp-sp-2);
	min-height: 48px;
	padding: var(--rdp-sp-3) var(--rdp-sp-6);
	font-size: 16px;
	font-weight: 700;
	color: var(--rdp-white);
	background: var(--rdp-red);
	border: 2px solid var(--rdp-red);
	border-radius: var(--rdp-radius-pill);
	box-shadow: var(--rdp-shadow-md);
	cursor: pointer;
	text-decoration: none;
	transition:
		background var(--rdp-dur-base) var(--rdp-ease),
		transform   var(--rdp-dur-fast) var(--rdp-ease),
		box-shadow  var(--rdp-dur-base) var(--rdp-ease);
}
.rdp-cta-button:hover {
	background: var(--rdp-red-dark);
	border-color: var(--rdp-red-dark);
	color: var(--rdp-white);
	text-decoration: none;
	transform: translateY(-1px);
	box-shadow: var(--rdp-shadow-lg);
}
.rdp-cta-button--ghost {
	background: transparent;
	color: var(--rdp-red);
}
.rdp-cta-button--ghost:hover {
	background: var(--rdp-red-light);
	color: var(--rdp-red-dark);
}
.rdp-cta-button--xl {
	font-size: 18px;
	min-height: 56px;
	padding: var(--rdp-sp-4) var(--rdp-sp-7);
}

/* -------------------------------------------------------------------------
 * 3. 汎用カード
 * ------------------------------------------------------------------------- */
.rdp-card {
	background: var(--rdp-white);
	border: 1px solid var(--rdp-gray-200);
	border-radius: var(--rdp-radius-lg);
	box-shadow: var(--rdp-shadow-md);
	overflow: hidden;
	transition: transform var(--rdp-dur-base) var(--rdp-ease),
	            box-shadow var(--rdp-dur-base) var(--rdp-ease);
}
.rdp-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--rdp-shadow-lg);
}
.rdp-card__media img { width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; }
.rdp-card__body { padding: var(--rdp-sp-5); }
.rdp-card__title { margin: 0 0 var(--rdp-sp-2); font-size: 18px; font-weight: 700; color: var(--rdp-black); }
.rdp-card__excerpt { margin: 0; color: var(--rdp-gray-700); font-size: 15px; }

/* -------------------------------------------------------------------------
 * 4. FAQ アコーディオン
 * ------------------------------------------------------------------------- */
.rdp-faq {
	margin: var(--rdp-sp-7) 0;
	border-top: 1px solid var(--rdp-gray-200);
}
.rdp-faq__item {
	border-bottom: 1px solid var(--rdp-gray-200);
}
.rdp-faq__question {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--rdp-sp-3);
	padding: var(--rdp-sp-4) 0;
	font-size: 17px;
	font-weight: 700;
	color: var(--rdp-black);
	background: transparent;
	border: 0;
	cursor: pointer;
	text-align: left;
}
.rdp-faq__question::before {
	content: "Q.";
	color: var(--rdp-red);
	font-weight: 900;
	margin-right: 6px;
}
.rdp-faq__icon {
	flex: 0 0 auto;
	width: 24px;
	height: 24px;
	transition: transform var(--rdp-dur-base) var(--rdp-ease);
}
.rdp-faq__item[open] .rdp-faq__icon { transform: rotate(45deg); }
.rdp-faq__answer {
	padding: 0 0 var(--rdp-sp-4);
	color: var(--rdp-gray-900);
}
.rdp-faq__answer::before {
	content: "A.";
	color: var(--rdp-red);
	font-weight: 900;
	margin-right: 6px;
}

/* -------------------------------------------------------------------------
 * 5. 著者BOX (E-E-A-T シグナル)
 * ------------------------------------------------------------------------- */
.rdp-author-box {
	display: grid;
	grid-template-columns: 96px 1fr;
	gap: var(--rdp-sp-5);
	padding: var(--rdp-sp-5);
	margin: var(--rdp-sp-6) 0;
	background: var(--rdp-gray-100);
	border-radius: var(--rdp-radius-lg);
	border-left: 4px solid var(--rdp-red);
}
.rdp-author-box__avatar img {
	width: 96px;
	height: 96px;
	border-radius: 50%;
	object-fit: cover;
}
.rdp-author-box__name {
	margin: 0 0 var(--rdp-sp-1);
	font-size: 18px;
	font-weight: 700;
}
.rdp-author-box__role {
	margin: 0 0 var(--rdp-sp-2);
	color: var(--rdp-red);
	font-size: 14px;
	font-weight: 700;
}
.rdp-author-box__bio { margin: 0 0 var(--rdp-sp-2); color: var(--rdp-gray-700); font-size: 14px; line-height: 1.7; }
.rdp-author-box__sns a { margin-right: var(--rdp-sp-3); color: var(--rdp-gray-700); font-size: 14px; }

@media (max-width: 600px) {
	.rdp-author-box { grid-template-columns: 64px 1fr; gap: var(--rdp-sp-3); }
	.rdp-author-box__avatar img { width: 64px; height: 64px; }
}

/* -------------------------------------------------------------------------
 * 6. パンくず
 * ------------------------------------------------------------------------- */
.rdp-breadcrumb {
	margin: var(--rdp-sp-3) 0 var(--rdp-sp-5);
	font-size: 13px;
	color: var(--rdp-gray-700);
}
.rdp-breadcrumb ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 4px 8px; }
.rdp-breadcrumb li::after { content: "›"; margin-left: 8px; color: var(--rdp-gray-300); }
.rdp-breadcrumb li:last-child::after { content: ""; }
.rdp-breadcrumb a { color: var(--rdp-gray-700); }
.rdp-breadcrumb a:hover { color: var(--rdp-red); }

/* -------------------------------------------------------------------------
 * 7. 比較テーブル
 * ------------------------------------------------------------------------- */
.rdp-table-compare {
	width: 100%;
	border-collapse: collapse;
	margin: var(--rdp-sp-5) 0;
	font-size: 15px;
}
.rdp-table-compare th,
.rdp-table-compare td {
	padding: var(--rdp-sp-3) var(--rdp-sp-4);
	border: 1px solid var(--rdp-gray-200);
	text-align: left;
	vertical-align: middle;
}
.rdp-table-compare thead th {
	background: var(--rdp-charcoal);
	color: var(--rdp-white);
	font-weight: 700;
}
.rdp-table-compare tbody tr:nth-child(even) { background: var(--rdp-gray-100); }
.rdp-table-compare__highlight {
	background: var(--rdp-red-light) !important;
	font-weight: 700;
}

/* -------------------------------------------------------------------------
 * 8. 言語スイッチャー
 * ------------------------------------------------------------------------- */
.rdp-language-switcher {
	display: inline-flex;
	align-items: center;
	gap: var(--rdp-sp-1);
	padding: 4px 8px;
	border: 1px solid var(--rdp-gray-300);
	border-radius: var(--rdp-radius-pill);
	background: var(--rdp-white);
	font-size: 13px;
}
.rdp-language-switcher select {
	border: 0;
	background: transparent;
	font-size: 13px;
	font-weight: 500;
	color: var(--rdp-black);
	cursor: pointer;
	padding: 4px 8px;
}

/* -------------------------------------------------------------------------
 * 9. 目次
 * ------------------------------------------------------------------------- */
.rdp-toc {
	background: var(--rdp-gray-100);
	border-left: 4px solid var(--rdp-red);
	padding: var(--rdp-sp-5);
	margin: var(--rdp-sp-5) 0;
	border-radius: 0 var(--rdp-radius-md) var(--rdp-radius-md) 0;
}
.rdp-toc__title {
	margin: 0 0 var(--rdp-sp-3);
	font-size: 16px;
	font-weight: 700;
	color: var(--rdp-black);
}
.rdp-toc ol { margin: 0; padding-left: 1.4em; counter-reset: rdptoc; }
.rdp-toc ol li { list-style: decimal; margin: var(--rdp-sp-1) 0; }
.rdp-toc a { color: var(--rdp-gray-900); }
.rdp-toc a:hover { color: var(--rdp-red); }
