@charset "UTF-8";

/*================================================

　ボタンデザイン

=================================================*/
.button a {
	display: block;
	position: relative;
	padding: 3.448276% 0;
	color: #00A0E9;
	text-align: center;
	font-size: clamp(1.5rem, (100vw - 1080px) * 2 / 200 + 15px, 1.7rem);
	font-weight: 600;
	line-height: 1;
	background-color: #FFF;
	border: 1px solid #005BAC;
	border-radius: 100vh;
	box-shadow: 2px 2px 2px 0px #000;
}
.button a::after {
	display: block;
	position: absolute;
	top: 50%;
	right: 3%;
	content: '';
	width: 8.3%;
	height: 100%;
	background: url("../images/common/arrow_icon02.svg") center center / 100% auto no-repeat;
	transform: translateY(-50%);
}

@media screen and (max-width: 1080px) {

	.button a {
		font-size: clamp(1.2rem, (100vw - 767px) * 3 / 313 + 12px, 1.5rem);
	}

}

@media screen and (max-width: 767px) {

	.button a {
		font-size: clamp(1.2rem, (100vw - 375px) * 12 / 392 + 12px, 2.4rem);
	}

}

/*================================================

　ボタンデザイン　ボタンキャッチ

=================================================*/
.button-catch {
	position: relative;
	margin: 11.494253% 0 4.081633%;
	padding: 0;
	color: #FFF;
	text-align: center;
	font-size: clamp(1.4rem, (100vw - 1080px) * 2 / 200 + 14px, 1.6rem);
	font-weight: 600;
	line-height: 1;
}
.button-catch::before,
.button-catch::after {
	position: absolute;
	left: 10px;
	bottom: -8px;
	content: '';
	width: 2px;
	height: 180%;
	background-color: #FFF;
	border-radius: 3px;
	transform: rotate(-32deg);
}
.button-catch::after {
	left: auto;
	right: 10px;
	transform: rotate(32deg);
}

@media screen and (max-width: 1080px) {

	.button-catch {
		font-size: clamp(1rem, (100vw - 767px) * 4 / 313 + 10px, 1.4rem);
	}
	.button-catch::before,
	.button-catch::after {
		bottom: -4px;
	}

}

@media screen and (max-width: 767px) {

	.button-catch {
		margin: 9% 0 4.081633%;
		font-size: clamp(1.1rem, (100vw - 375px) * 9 / 392 + 11px, 2rem);
	}
	.button-catch::before,
	.button-catch::after {
		bottom: -8px;
	}

}

@media screen and (max-width: 600px) {

	.button-catch {
		margin: 6% 0 4.081633%;
	}
	.button-catch::before,
	.button-catch::after {
		bottom: -5px;
	}

}


/*================================================

　メインビジュアル

=================================================*/
.mainvisual {
	position: relative;
	overflow: hidden;
	max-height: 515px;
	margin: 0 0 35px;
	background-color: #00a0e9;
	border-radius: 29px;
	z-index: 20;
}
.mainvisual-wrap {
	position: relative;
	max-width: 1280px;
	margin: auto;
	padding: 13px 60px 13px 70px;
}
.mainvisual-text {
	position: absolute;
	top: 50%;
	left: 8.59375%;
	width: 27.1875%;
	padding: 0;
	z-index: 9;
	transform: translateY(-50%);
}
.mainvisual-sp { display: none; }

@media screen and (max-width: 767px) {

	.mainvisual {
		max-height: 100%;
		margin: 0 0 20px;
	}
	.mainvisual-wrap {
		padding: 0;
	}
	.mainvisual-pc { display: none !important; }
	.mainvisual-sp { display: block !important; }

	.mainvisual-text {
		top: 10%;
		left: 50%;
		width: 70%;
		max-width: 384px;
		padding: 0;
		transform: translateX(-50%);
	}

}

@media screen and (max-width: 600px) {

	.mainvisual-text {
		top: 9%;
		width: 60%;
	}

}


/*================================================

　トップタイトル共通設定

=================================================*/
.top-title-box {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 17.818182%;
}
.top-title-box h2 {
	margin: 25px 0;
	color: #00A0E9;
	font-size: clamp(2rem, (100vw - 375px) * 18 / 905 + 20px, 3.8rem);
	font-weight: 600;
}
.top-title-box h2 span {
	display: block;
	padding: 0 0 3px;
	font-size: clamp(1.4rem, (100vw - 375px) * 8 / 905 + 14px, 2.2rem);
}

@media screen and (max-width: 767px) {

	.top-title-box {
		display: flex;
		flex-direction: row;
		justify-content: center;
		width: 100%;
	}
	.top-title-box h2 {
		margin: 0 25px;
		white-space: nowrap;
	}
	.top-title-box figure {
		width: 25%;
	}

}

/*================================================

　top-service

=================================================*/
.top-service {
	position: relative;
	max-width: 1280px;
	margin: -100px auto 0;
	padding: 100px 3.515625% 0;
	z-index: 10;
}
.top-service-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0;
	padding: 25px 4.545455%;
	border: 10px solid #00a0e9;
	border-radius: 29px;
}
.top-service-solution {
	width: 77%;
}
.top-service-solution ul li a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 12px 0;
}
.top-service-solution-text {
	width: 80.131579%;
}
.top-service-solution-text h3 {
	margin: 0 0 5px;
	font-size: clamp(1.4rem, (100vw - 375px) * 7 / 905 + 14px, 2.1rem);
	font-weight: 600;
	line-height: 1.2;
}
.top-service-solution-text h3 span {
	display: block;
	color: #919191;
	font-size: clamp(1rem, (100vw - 375px) * 2 / 905 + 10px, 1.2rem);
}
.top-service-solution-text p {
	padding: 3px 0 0;
	font-size: clamp(1.2rem, (100vw - 375px) * 4 / 905 + 12px, 1.6rem);
	line-height: 1.4;
	border-top: 1px dotted #000;
}
.top-service-solution-icon {
	width: 16.842105%;
}

@media screen and (max-width: 1080px) {

}

@media screen and (max-width: 767px) {

	.top-service-inner {
		display: block;
		margin: 0;
		border: 6px solid #00a0e9;
	}
	.top-service-solution {
		width: 100%;
	}
	.top-service-solution ul li {
		margin: 12px 0;
	}
	.top-service-solution-text {
		width: 80.131579%;
	}
	.top-service-solution-icon {
		width: 16.842105%;
	}

}

/*================================================

　top-news

=================================================*/
.top-news {
	position: relative;
	max-width: 1280px;
	margin: -100px auto 0;
	padding: 100px 3.515625% 0;
	z-index: 9;
}
.top-news-inner {
	display: flex;
	justify-content: space-between;
	margin: 35px 0;
	padding: 35px 4.545455%;
	border: 10px solid #00a0e9;
	border-radius: 29px;
}
.top-news-box {
	width: 77%;
}
.top-news-box h3 {
	padding: 2.857143% 0 2.857143% 15px;
	font-size: clamp(1.2rem, (100vw - 375px) * 7 / 905 + 12px, 1.9rem);
	font-weight: 600;
	background: #EAEAEAED url("../images/top/news-icon01.svg") right 12px center / auto 84.615385% no-repeat;
	border-left: 8px solid #00A0E9;
}
.top-news-box-content {
	display: flex;
	margin: 0;
	padding: 3.246753% 3.896104%;
	font-weight: 600;
}
.top-news-box-content h4 {
	white-space: nowrap;
	font-size: clamp(2rem, (100vw - 375px) * 10 / 905 + 20px, 3rem);
}
.top-news-box-content ul {
	padding: 0 0 0 15px;
	font-size: clamp(1.2rem, (100vw - 375px) * 6 / 905 + 12px, 1.8rem);
	line-height: 1.5;
}

@media screen and (max-width: 1080px) {

}

@media screen and (max-width: 767px) {

	.top-news-inner {
		display: block;
		margin: 20px 0;
		padding: 25px 4.545455%;
		border: 6px solid #00a0e9;
	}
	.top-news-box {
		width: 100%;
	}
	.top-news-box h3 {
		margin: 20px 0 0;
	}

}

/*================================================

　profile

=================================================*/
.profile {
	position: relative;
	max-width: 1280px;
	margin: -100px auto 0;
	padding: 100px 3.515625% 0;
	z-index: 9;
}
.profile-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0;
	padding: 35px 4.545455%;
	border: 10px solid #00a0e9;
	border-radius: 29px;
}
.profile-box {
	width: 78.9%;
}
.profile-box ul li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 12px 0;
}
.profile-box-text {
	width: 77.186312%;
}
.profile-box-text h3 {
	margin: 0 0 5px;
	font-size: clamp(1.4rem, (100vw - 375px) * 7 / 905 + 14px, 2.1rem);
	font-weight: 600;
	line-height: 1.2;
}
.profile-box-text p {
	padding: 3px 0 0;
	font-size: clamp(1.2rem, (100vw - 375px) * 4 / 905 + 12px, 1.6rem);
	line-height: 1.4;
	border-top: 1px dotted #000;
}
.profile-box-icon {
	width: 20.405577%;
}

@media screen and (max-width: 1080px) {

}

@media screen and (max-width: 767px) {

	.profile-inner {
		display: block;
		margin: 0;
		padding: 25px 4.545455%;
		border: 6px solid #00a0e9;
	}
	.profile-box {
		width: 100%;
	}
	.profile-box ul li {
		align-items: flex-start;
	}
	.profile-box-text {
		width: 77.186312%;
	}
	.profile-box-text h3 {
		margin: 0 0 5px;
	}
	.profile-box-text p {
		padding: 3px 0 0;
	}
	.profile-box-icon {
		width: 20.405577%;
	}

}
