@charset "utf-8";

/* ---------------------------------------------------------------------------------------------------- */

.fv {
	position: relative;
	height: 240px;
	padding-bottom: 5%;
	background-image: url(../img/fv_3.png);
	background-position: center;
	background-size: cover;
	overflow: hidden;
}

.fv .section_inner {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 0;
}

.fv .section_container {
	position: relative;
	width: 100%;
	height: 100%;
}

.fv .slider_area {
	width: 100%;
	margin-right: auto;
}

.fv_text {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-end;
	gap: 4px;
	width: max-content;
	padding: 4px;
	background-color: #fff;
	font-size: 2.8rem;
	color: #052A48;
}

.fv_text > * {
	display: block;
	line-height: 1;
}

.fv_text .main {
	font-size: 1em;
	font-weight: 700;
}

.fv_text .main::first-letter {
	color: #33A1F9;
}

.fv_text .sub {
	font-size: 0.3em;
}

@media screen and (min-width: 768px) {
	.fv {
		height: auto;
		padding: 0;
		background-image: none;
	}

	.fv .section_inner {}

	.fv .section_container {}

	.fv .slider_area {
		width: 65%;
		margin-right: auto;
	}

	.fv_text {
		position: relative;
		top: auto;
		left: auto;
		transform: none;
		gap: 8px;
		padding: 8px 4px;
		margin: -4% 18% 0 auto;
	}

	.fv_text > * {}
}

@media screen and (min-width: 1024px) {
	.fv_text {
		margin: -3% 22.5% 0 auto;
	}
}

@media screen and (min-width: 1440px) {
	.fv_text {
		font-size: 4.8rem;
		margin: -3.5% 20% 0 auto;
	}
}

@media screen and (min-width: 1920px) {
	.fv_text {
		margin: -2.5% 23.5% 0 auto;
	}
}

/* ---------------------------------------------------------------------------------------------------- */

.section {
	width: 100%;
	margin: 0;
	padding: 0;
}

.section_inner {
	width: 100%;
	padding: 20% 0;
}

@media screen and (min-width: 768px) {
	.section_inner {
		padding: 10% 0;
	}
}

@media screen and (min-width: 1440px) {
	
}

/* ---------------------------------------------------------------------------------------------------- */

.section {}

.section .section_inner {}

.section .section_container_inner {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 24px;
	width: 90%;
	margin: 0 auto 0;
}

.section .section_content {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 24px;
	width: 100%;
	margin: 0 auto 0;
}

.section .section_content_1 {
	width: 100%; /* 固定幅 */
	overflow-x: auto; /* 横スクロール可能にする */
}

.section table {
	width: 960px; /* テーブル自体を広めにしてはみ出させる */
	margin: 0 auto 0 0;
	border-collapse: collapse;
}

.section table tr {}

.section table th,
.section table td {
	/* display: block; */
	border: 0;
	text-align: center;
	vertical-align: middle;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}

.section table th {
	background-color: #D0E8FB;
}

.section table th:not(:first-child) {
	border-left: 1px #EBEFF3 solid;
}

.section table td {
	border-bottom: 1px #052A48 solid;
	border-right: 1px #052A48 solid;
}

.section table td:first-child {
	border-left: 1px #052A48 solid;
}

.section .download {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 12px;
	width: 100%;
	margin: 0 auto 0;
}

.section .text {
	width: fit-content;
	margin: 0 auto 0;
}

.section .btn {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	width: max-content;
	max-width: 100%;
	margin: 0 auto 0;
	padding: 1em;
	background-color: #33A1F9;
	text-align: center;
	color: #fff;
}

.section .btn > * {
	display: block;
}

.section .btn img {
	width: 10%;
}

@media screen and (min-width: 768px) {
	.section .section_content_1 {}

	.section table {
		width: 100%;
		margin: 0;
	}

	.section table th,
	.section table td {
		padding: 1em;
	}

	.section table th {}

	.section table td {}

	.section table th span {
		margin: 0 auto 0;
	}

	.section .btn {
		flex-direction: row;
		justify-content: space-evenly;
		gap: 12px;
	}
}

@media screen and (min-width: 1024px) {

}

@media screen and (min-width: 1440px) {
	.section .heading_2 {
		width: 90%;
		max-width: 1680px;
	}

	.section .heading_2::before {
		width: 480px;
	}

	.section .section_container_inner {
		gap: 48px;
		width: 90%;
		max-width: 1680px;
	}

	.section .section_content {
		gap: 48px;
	}

	.section table th,
	.section table td {
		font-size: 1.2rem;
	}

	.section .download {
		gap: 24px;
	}

	.section .text {
		font-size: 1.2rem;
	}

	.section .btn {
		font-size: 1.2rem;
	}
}

@media screen and (min-width: 1920px) {
	
}

/* ---------------------------------------------------------------------------------------------------- */

.section_1 table th:nth-of-type(1) {
	width: 40%;
}

.section_1 table th:nth-of-type(2) {
	width: 20%;
}

.section_1 table th:nth-of-type(3) {
	width: 40%;
}

/* ---------------------------------------------------------------------------------------------------- */

.section_2 table th:nth-of-type(1) {
	width: 10%;
}

.section_2 table th:nth-of-type(2) {
	width: 15%;
}

.section_2 table th:nth-of-type(3) {
	width: 15%;
}

.section_2 table th:nth-of-type(4) {
	width: 15%;
}

.section_2 table th:nth-of-type(5) {
	width: 35%;
}

/* ---------------------------------------------------------------------------------------------------- */
