@charset "UTF-8";
.content {
	width: 100%;
	margin: 0 auto;
	padding: 0;
	box-sizing: border-box;
	background-color: #FFF;
}
.inner {
	width: 100%;
	min-width :580px;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
#top {
	background: url(../img/top_bg01.jpg) top center / cover no-repeat;
	margin: 0;
	padding: 0;
	width: 100%;
	height: 400px;
	display: flex;
	flex-direction: column;
}
.top-wrap {
	width: 100%;
	margin: 30px auto 0 auto;
	padding: 0px 0px 0px 0px;
}
.toplogo {
	display: inline-block;
}
h1 {
	margin: 75px auto 0 auto;
	padding: 10px 40px 10px 40px;
	font-size: 64px;
	color: #FFF;
	text-align: center;
	font-weight: 900;
	letter-spacing: 0.18em;
	background-color: rgba(63, 164, 38, 0.6);
}
.section-inner .section2 h3, .section-inner .section3 h3, .section-inner .section4 h3 {
	margin: 0px 0px 40px 0px;
	padding: 0px 0px 6px 0px;
	font-size: 34px;
	font-weight: 900;
	color: #0066CC;
	border-bottom: 3px solid #A4FF00;
	display: flex;
	align-items: center;
	gap: 15px;
}
.triangle-square {
	display: block;
	width: 34px;
	height: 34px;
	background: linear-gradient( 135deg, #A4FF00 50%, #CCFF00 50% );
}
.section1 {
	width: 80%;
	margin: 55px auto 55px auto;
}
.section1 .title-section {
	background-color: #F5FFCC;
	margin: 0px 0px 0px 0px;
	padding: 50px 40px 65px 40px;
}
.section1 .title-section .title-outer {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;   /* ← 追加 */
	gap: 12px;         /* ← アイコンとタイトルの余白（推奨） */
	margin-bottom: 40px;
}
.section1 .title-section .title {
	color: #0066CC;
	text-align: center;
	font-size: 50px;
	margin: 0px 0px 0px 15px;
	padding: 0px;
	font-weight: 900;
	letter-spacing: 0.4rem;
	line-height: 85px;
}
.section1-body {
	font-size: 32px;
	line-height: 1.6;
}
.section-inner {
	margin: 64px 40px 64px 40px;
}
.section-inner .flex-contents {
	margin-bottom: 60px;
}
.section2-inner {
	display: flex;
	margin-right: 5%;
	font-size: 24px;
}
.section2-inner .img01{
	margin-right: 5%;
	width: 50%;
	min-width:200px;
	height: 50%;
}
.section3-inner2 {
	display: flex;
	flex-direction: column;
	align-items: start;
}
.section3-inner {
	display: flex;
	font-size: 24px;
}
.section3-inner .img01 {
	margin-right: 5%;
	width: 50%;
	min-width:200px;
	height: 50%;
}
.section3-inner2 p {
	margin: 0 0 10px 0;
}
.link {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 40px;
}
.link-button {
	width: 45px;
	height: 45px;
	background-color: #A4FF00;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}
.link-button::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 0 10px 18px;
	border-color: transparent transparent transparent #ffffff;
	margin-left: 4px;
}
.section4-inner {
	display: flex;
	font-size: 24px;
	flex-direction: column;
}
.section4-inner p {
	margin-bottom: 60px;
}
.section4 h4 {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 25px 0;
	padding: 0;
}
.section4 h4::before {
	display: inline-block;
	content: "";
	width: 20px;
	height: 20px;
	background-color: #99C2EB;
}
.section4-inner table {
	width: 80%;
	border-collapse: collapse;
	box-sizing: border-box;
	margin: 0 auto 40px auto;
	font-size: 18px;
	border: 1px solid #424140;
}
.section4-inner tr {
	width: 100%;
	border-bottom: 1px solid #424140;
}
.section4-inner th, .section4-inner td {
	padding: 5px;
	margin: 0;
	border: 1px solid #424140;
}
.section4-inner th {
	background-color: #EEF5FC;
	font-weight: normal;
}
.section4-inner td {
	text-align: center;
}
#foot {
	width: 100%;
	margin: 0;
	padding: 0;
}
.foot-top {
	width: 100%;
	height: 80px;
	background: url(../img/obi.png) top center / cover no-repeat;
	margin: 0;
	padding: 0;
}
.foot-inner {
	margin: 20px auto 0px auto;
	padding: 0px 0px 20px 0px;
	display: flex;
	align-items: center;
	justify-content: center;
}
#foot .logo_f a {
	width: 320px;
	height: 75px;
	display: block;
}
#page-top {
	width: 75px;
	height: 75px;
	display: none;
	position: fixed;
	right: 30px;
	bottom: 30px;
}
#page-top p {
	margin: 0;
	padding: 0;
	text-align: center;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	transition: all 0.3s;
}
#move-page-top {
	color: #fff;
	line-height: 75px;
	text-decoration: none;
	display: block;
	cursor: pointer;
}
