@charset "utf-8";

body {
	margin: 0;
	background: #f5f7fb;
	color: #333;
	font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
}

#ranking-sp {
	max-width: 640px;
	margin: 0 auto;
	padding: 12px 12px 40px;
}

#ranking-sp img {
	max-width: 100%;
	height: auto;
	display: block;
}

#ranking-sp a {
	color: inherit;
	text-decoration: none;
}

.sp-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 6px 2px 14px;
	color: #666;
	font-size: 12px;
}

.sp-section-title {
	position: relative;
	margin: 0 0 10px;
	padding-left: 14px;
	font-size: 24px;
	line-height: 1.35;
	font-weight: 700;
}

.sp-section-title:before {
	content: "";
	position: absolute;
	left: 0;
	top: 4px;
	width: 5px;
	height: 30px;
	border-radius: 4px;
	background: #2f69c2;
}

.sp-section-intro {
	margin: 0 0 14px;
	color: #5b6470;
	font-size: 13px;
	line-height: 1.8;
}

.sp-hero,
.sp-finder,
.sp-ranking,
.sp-howto,
.sp-faq,
.sp-related {
	margin-bottom: 22px;
}

.sp-hero {
	position: relative;
	padding: 22px 16px 18px;
	border: 2px solid #8fb0dc;
	border-radius: 20px;
	background: linear-gradient(135deg, #fbfdff 0%, #eef5ff 100%);
	box-shadow: 0 10px 24px rgba(30, 66, 125, .08);
}

.sp-hero__eyebrow {
	display: inline-block;
	margin: -36px 0 14px;
	padding: 7px 12px;
	border: 2px solid #8fb0dc;
	border-radius: 999px;
	background: #fff;
	color: #2c5aa0;
	font-size: 13px;
	font-weight: 700;
	box-shadow: 0 4px 10px rgba(44, 90, 160, .12);
}

.sp-hero__title {
	margin: 0 0 12px;
}

.sp-hero__lead {
	margin: 0 0 16px;
	font-size: 15px;
	line-height: 1.9;
	color: #334;
}

.sp-hero__actions {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	margin-bottom: 16px;
}

.sp-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0 16px;
	border-radius: 999px;
	font-size: 16px;
	font-weight: 700;
}

#ranking-sp a.sp-btn--primary,
#ranking-sp a.sp-btn--primary:link,
#ranking-sp a.sp-btn--primary:visited {
	background: #2f69c2;
	color: #fff !important;
	border: 2px solid #2f69c2;
}

#ranking-sp a.sp-btn--secondary,
#ranking-sp a.sp-btn--secondary:link,
#ranking-sp a.sp-btn--secondary:visited {
	background: #fff;
	color: #2f69c2 !important;
	border: 2px solid #2f69c2;
}

.sp-hero__points {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.sp-hero__points li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 13px;
}

.sp-hero__points .icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 10px;
	background: #fff;
	border: 1px solid #d6e4fb;
	color: #2f69c2;
	font-weight: 700;
	flex: 0 0 32px;
}

.sp-finder__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

.sp-finder-card {
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-height: 140px;
	padding: 14px 12px;
	border: 1px solid #dfe7f3;
	border-radius: 18px;
	background: #fff;
	box-shadow: 0 6px 16px rgba(0, 0, 0, .04);
}

.sp-finder-card__thumb {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	border-radius: 14px;
	background: #eef5ff;
	border: 1px solid #d6e4fb;
	overflow: hidden;
}

.sp-finder-card__body strong {
	display: block;
	margin-bottom: 6px;
	color: #213d73;
	font-size: 16px;
	line-height: 1.5;
}

.sp-finder-card__body em {
	display: block;
	font-style: normal;
	color: #666;
	font-size: 12px;
	line-height: 1.7;
}

.sp-top3,
.sp-ranking-list {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.sp-rank-card {
	position: relative;
	border: 1px solid #e0e6f0;
	border-radius: 18px;
	background: #fff;
	overflow: hidden;
	box-shadow: 0 8px 20px rgba(0, 0, 0, .05);
}

.sp-rank-card a {
	display: block;
}

.sp-rank-badge {
	position: absolute;
	left: 12px;
	top: 12px;
	z-index: 2;
	min-width: 72px;
	padding: 8px 12px;
	border-radius: 999px;
	background: #2f69c2;
	color: #fff;
	text-align: center;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
}

.sp-rank-card__image {
	display: block;
	aspect-ratio: 16 / 10;
	background: #f8f8f8;
	overflow: hidden;
}

.sp-rank-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sp-rank-card__body {
	display: block;
	padding: 14px 14px 16px;
}

.sp-rank-card__name {
	display: block;
	margin-bottom: 8px;
	font-size: 17px;
	line-height: 1.65;
}

.sp-rank-card__meta {
	display: block;
	margin-bottom: 8px;
	color: #2f69c2;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.6;
}

.sp-rank-card__desc {
	display: block;
	color: #555;
	font-size: 13px;
	line-height: 1.8;
}

.sp-rank-card--top {
	border-color: #cfdcf6;
	box-shadow: 0 10px 24px rgba(47, 105, 194, .08);
}

.sp-howto__list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.sp-howto-card {
	display: flex;
	gap: 12px;
	padding: 16px 14px;
	border-radius: 18px;
	background: #eef5ff;
}

.sp-howto-card .num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: #2f69c2;
	color: #fff;
	font-size: 17px;
	font-weight: 700;
	flex: 0 0 36px;
}

.sp-howto-card h3 {
	margin: 0 0 8px;
	font-size: 16px;
	line-height: 1.55;
}

.sp-howto-card p {
	margin: 0;
	font-size: 13px;
	line-height: 1.9;
}

.sp-faq__list {
	border-top: 1px solid #d7dde8;
	background: #fff;
	border-radius: 16px;
	overflow: hidden;
}

.sp-faq__item {
	border-bottom: 1px solid #d7dde8;
}

.sp-faq__item:last-child {
	border-bottom: none;
}

.sp-faq__item summary {
	position: relative;
	padding: 16px 48px 16px 14px;
	list-style: none;
	cursor: pointer;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.7;
	background: #fff;
}

.sp-faq__item summary::-webkit-details-marker {
	display: none;
}

.sp-faq__item summary:after {
	content: "＋";
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: #eef5ff;
	border: 1px solid #cfdcf6;
	color: #2f69c2;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 700;
}

.sp-faq__item[open] summary:after {
	content: "－";
}

.sp-faq__answer {
	padding: 0 14px 16px;
}

.sp-faq__answer p {
	margin: 0;
	color: #555;
	font-size: 13px;
	line-height: 1.9;
}

.sp-related__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

.sp-related__link {
	display: flex;
	align-items: center;
	min-height: 58px;
	padding: 12px;
	border: 1px solid #e0e6f0;
	border-radius: 16px;
	background: #fff;
	box-shadow: 0 6px 16px rgba(0, 0, 0, .04);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.6;
}

@media (max-width: 374px) {
	#ranking-sp {
		padding-left: 10px;
		padding-right: 10px;
	}

	.sp-section-title {
		font-size: 22px;
	}

	.sp-finder__grid,
	.sp-related__grid {
		grid-template-columns: 1fr;
	}

	.sp-rank-card__name {
		font-size: 16px;
	}
}