@charset "UTF-8";
.lato {
	font-family: "Lato", sans-serif;
}
.roboto_con {
	font-family: "Roboto Condensed", sans-serif;
}
p {
	color: #000;
}
#a01,
#a02,
#a03 {
	margin-top: -100px;
	padding-top: 100px;
}
.subpage {
	padding-top: 0;
}
.head-line01 {
	margin-bottom: 40px;
	text-align: center;
}
.head-line01 .en {
	margin-bottom: 11px;
	padding-bottom: 2px;
	position: relative;
	display: block;
	color: #0071BC;
	font-size: 52px;
	font-weight: 400;
	font-family: "Lato", sans-serif;
	text-align: center;
}
.head-line01 .en::before {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 25px;
	height: 1px;
	background-color: #80B8DD;
	content: '';
}
.head-line01 .jp {
	color: #000;
	font-size: 14px;
	font-weight: 500;
}
.main-visual {
	margin-bottom: 50px;
	padding: 94px 0 20px;
	aspect-ratio: 1280 / 836;
	background: url(../img/bg01.png) no-repeat center top 1px / cover;
	position: relative;
}
.main-visual .inner {
	margin: 0 auto;
	padding: 0 20px;
	max-width: 1100px;
	width: 100%;
	box-sizing: border-box;
	position: relative;
	z-index: 5;
}
.main-visual .list-inner {
	margin: 0 auto;
	padding: 0 20px;
	max-width: 1100px;
    position: absolute;
    bottom: 15vw;
    right: 0;
    left: 0;
}
.main-visual .inner .text-box {
	margin-bottom: 241px;
}
.main-visual .inner .text-box h1 {
	margin-bottom: 13px;
	color: #0071BC;
	font-size: 85px;
	font-weight: 700;
	line-height: 1.06;
	font-family: "Roboto Condensed", sans-serif;
}
.main-visual .inner .text-box .text {
	color: #000;
	font-size: 24px;
	font-weight: 700;
}
.main-visual .link-list {
	position: relative;
	z-index: 1;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.main-visual .link-list::before {
	position: absolute;
	top: 0;
	left: 7px;
	right: 7px;
	height: 100%;
	background-color: #FFF;
	transform: skewX(-27deg);
	content: '';
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
	z-index: -1;
}
.main-visual .link-list {
	gap: 9px;
}
.main-visual .link-list li {
	width: calc((100% - 18px) / 3);
	position: relative;
}
.main-visual .link-list li::before {
	position: absolute;
	top: 17%;
	right: -9px;
	bottom: 16%;
	width: 1px;
	height: auto;
	background-color: rgba(0, 113, 188, 0.43);
	content: '';
	transform: skew(-31deg);
}
.main-visual .link-list li:first-child::before {
	right: 6px;
}
.main-visual .link-list li:nth-child(3)::before {
	display: none;
}
.main-visual .link-list li a {
	padding: 21px 10px 23px;
	display: block;
	text-align: center;
	box-sizing: border-box;
}
.main-visual .link-list li .en {
	margin-bottom: -4px;
	display: block;
	color: #0071BC;
	font-size: 22px;
	font-family: "Lato", sans-serif;
}
.main-visual .link-list li .txt {
	color: #000;
	font-size: 20px;
	font-weight: 500;
}
.c-subpage-inner {
	margin: 0 auto;
	padding: 0 20px;
	max-width: 1140px;
	position: relative;
	z-index: 5;
}
.message {
	margin-bottom: 68px;
}
.message .photo-box {
	margin-bottom: 39px;
	position: relative;
}
.message .photo-box .photo {
	border-radius: 10px;
	overflow: hidden;
}
.message .photo-box .text {
	position: absolute;
	bottom: 37px;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 562px;
	color: #000;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.48;
}
.message .photo-box .text .big {
	margin-left: 4px;
	font-size: 18px;
}
.message .text-box {
	margin: 0 auto;
	padding: 0 20px;
	max-width: 880px;
}
.message .text-box .text {
	margin-bottom: 27px;
	color: #000;
	font-size: 16px;
	line-height: 1.69;
}
.message .text-box .text:last-child {
	margin-bottom: 0;
}
.company {
	margin-bottom: 93px;
	padding-top: 57px;
	position: relative;
}
.company::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 632px;
	background: linear-gradient(#efefef 0%, #f5f5f5 87.19%, #fff 100%);
	content: '';
}
.company .head-line01 {
	margin-bottom: 58px;
}
.company .img-box {
	margin-bottom: 78px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.company .img-box .text-box {
	width: calc(100% - 360px);
}
.company .img-box .text-box .title {
	margin-bottom: 14px;
	color: #FFF;
	font-size: 26px;
	font-weight: 500;
	line-height: 1.95;
}
.company .img-box .text-box .title .bg-txt {
	padding: 2px 12px;
	background: -webkit-linear-gradient(#0071BC,#0071BC) repeat-x center center / 100% 100%;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}
.company .img-box .text-box .text {
	line-height: 1.69;
}
.company .img-box .photo-box {
	margin-top: 1px;
	width: 334px;
}
.company .img-box .photo-box .photo {
	margin-bottom: 12px;
	border-radius: 10px;
	overflow: hidden;
}
.company .img-box .photo-box .name {
	font-size: 18px;
	font-weight: 500;
}
.company .img-box .photo-box .name .sml {
	margin-bottom: -1px;
	display: block;
	font-size: 14px;
	font-weight: 500;
}
.company .inner {
	margin: 0 auto;
	padding: 0 20px;
	max-width: 880px;
	box-sizing: border-box;
}
.company .inner .sub-inner:not(:last-child) {
	margin-bottom: 46px;
}
.company .inner .title-box {
	margin-bottom: 17px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}
.company .inner .title-box .num {
	margin-top: 3px;
	padding: 1px 5px 2px;
	width: 48px;
	color: #FFF;
	font-weight: 700;
	font-family: "Lato", sans-serif;
	line-height: 1.2;
	text-align: center;
	box-sizing: border-box;
	background: linear-gradient(90deg,#0071bc 0%, #b2d4eb 100%);
}
.company .inner .title-box .txt {
	width: calc(100% - 58px);
	color: #0071BC;
	font-size: 18px;
	font-weight: 500;
}
.company .inner .title {
	margin-bottom: 17px;
	font-size: 26px;
	font-weight: 500;
	line-height: 1.54;
}
.company .inner .text-area {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.company .inner .text-area .text {
	line-height: 1.69;
	width: calc(100% - 250px);
}
.company .inner .text-area .photo {
	margin-top: -3px;
	width: 230px;
	text-align: center;
}
.company .inner .text-area .photo img {
	margin: 0 auto;
	width: 137px;
}
.company .inner .text-area .photo .txt {
	margin-top: 11px;
	display: block;
	color: #000;
	font-size: 13px;
	letter-spacing: 0.08em;
	line-height: 1.85;
}
.company .inner .img-area {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}
.company .inner .img-area .photo {
	margin-top: 4px;
	width: 235px;
	border-radius: 10px;
	overflow: hidden;
}
.company .inner .img-area .text {
	width: calc(100% - 260px);
	line-height: 1.69;
}
.company .inner .inn-text {
	line-height: 1.69;
}
.company .inner .inn-photo {
	margin: 18px auto 0;
	max-width: 300px;
}
.company .inner .inn-photo.mb01 {
	margin-bottom: 18px;
}
.company .inner .inn-photo img {
	border-radius: 10px;
	overflow: hidden;
}
.company .inner .inn-photo .txt {
	margin-top: 7px;
	color: #000;
	display: block;
	font-size: 11px;
}
.company .inner .out-box {
	margin: 0 auto 18px;
	padding: 0 20px;
	max-width: 720px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.topics {
	padding: 88px 0 61px;
	position: relative;
}
.topics::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../img/topics_bg01.png) no-repeat left top / 100% 100%;
	content: '';
}
.topics .head-line01 {
	margin-bottom: 14px;
}
.topics .photo-area {
	margin: 0 auto -3px;
	max-width: 984px;
	position: relative;
}
.topics .photo-area.is-spec {
	margin-bottom: 4px;
}
.topics .photo-area .text-box {
	position: absolute;
	top: 38px;
    left: 72px;
}
.topics .photo-area.is-spec .text-box {
	top: auto;
	bottom: 16px;
} 
.topics .photo-area .text-box .en {
	margin-bottom: 10px;
}
.topics .photo-area.is-spec .text-box .en {
	letter-spacing: 0.02em;
}
.topics .photo-area .text-box .text {
	color: #FFF;
	font-size: 20px;
	font-weight: 700;
}
.topics .text-area {
	margin: 0 auto 46px;
	padding: 0 20px;
	max-width: 880px;
}
.topics .inn-text {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.69;
}
.topics .p-link p {
	padding: 2px 15px 0 28px;
	width: fit-content;
	display: block;
	color: #000;
	font-weight: 500;
	background: #FFF url(../img/link_icon01.png) no-repeat left 15px center / 8px;
}
.topics .p-link.is-spec {
	margin: 13px 0 9px;
}
@media screen and (min-width: 1080px) {
	.main-visual .link-list li a:hover {
		opacity: 0.7;
	}
}
@media screen and (min-width: 768px) and (max-width: 1140px) {
	.main-visual .link-list::before {
		left: 15px;
		right: 15px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1079px) {
	#a01,
	#a02,
	#a03 {
		margin-top: -60px;
		padding-top: 60px;
	}
	.main-visual .link-list li .en {
		font-size: 1.6vw;
	}
	.main-visual .link-list li .txt {
		font-size: 1.5vw;
	}
	.topics .photo-area .text-box {
		top: 3.5vw;
		left: 6.67vw;
	}
	.topics .photo-area.is-spec .text-box {
		top: auto;
		bottom: 1.48vw;
	}
	.topics .photo-area .text-box .en {
	}
	.topics .photo-area .text-box .text {
		font-size: 1.8vw;
	}
}
@media screen and (min-width: 768px) and (max-width: 1000px) {
	.company .img-box .text-box {
		width: calc(100% - 310px);
	}
	.company .img-box .text-box .title {
		font-size: 2vw;
	}
	.company .inner .title {
		font-size: 2.5vw;
	}
	.company .img-box .photo-box {
		width: 280px;
	}
	.company .inner .inn-photo {
		max-width: 260px;
	}
}
@media screen and (max-width: 767px) {
	#a01,
	#a02,
	#a03 {
		margin-top: -60px;
		padding-top: 60px;
	}
	.head-line01 {
		margin-bottom: 18px;
	}
	.head-line01 .en {
		margin-bottom: 7px;
		padding-bottom: 5px;
		font-size: 32px;
	}
	.main-visual {
		margin-bottom: 32px;
		padding: 16px 0 47px;
		aspect-ratio: 375 / 555;
		background: url(../img/bg01_sp.png) no-repeat center top 106px / 100%;
	}
	.main-visual .inner {
		margin: 0;
		padding: 0 15px;
		max-width: inherit;
		height: 100%;
		display: flex;
		flex-wrap: wrap;
		flex-direction: column;
		justify-content: space-between;
	}
	.main-visual .inner .text-box {
		margin-bottom: 30px;
	}
	.main-visual .inner .text-box h1 {
		margin: 0 -10px 7px 0;
		font-size: 50px;
		
	}
	.main-visual .inner .text-box .text {
		font-size: 14px;
	}
	.main-visual .link-list {
		display: block;
	}
	.main-visual .link-list::before {
		left: 14px;
		right: 14px;
		transform: skewX(-4deg);
	}
	.main-visual .link-list {
		padding-bottom: 8px;
		display: block;
	}
	.main-visual .link-list li {
		margin-bottom: 5px;
		padding: 0 40px;
		width: auto;
		position: relative;
	}
	.main-visual .link-list li:last-child {
		margin-bottom: 0;
	}
	.main-visual .link-list li::before {
		display: none;
	}
	.main-visual .link-list li a {
		padding: 11px 10px 18px;
		border-bottom: 1px solid rgba(0, 113, 188, 0.43);
	}
	.main-visual .link-list li:last-child a {
		border-bottom: 0;
	}
	.main-visual .link-list li .en {
		margin-bottom: -4px;
		font-size: 20px;
	}
	.main-visual .link-list li .txt {
		font-size: 16px;
	}
	.c-subpage-inner {
		margin: 0;
		padding: 0 20px;
		max-width: inherit;
		width: auto;
	}
	.message {
		margin-bottom: 36px;
	}
	.message .photo-box {
		margin-bottom: 19px;
	}
	.message .photo-box .photo {
		margin-bottom: 12px;
	}
	.message .photo-box .text {
		position: static;
		transform: none;
		max-width: inherit;
	}
	.message .text-box {
		margin: 0;
		padding: 0;
		max-width: inherit;
	}
	.company {
		margin-bottom: 40px;
		padding-top: 33px;
	}
	.company::before {
		height: 883px;
	}
	.company .head-line01 {
		margin-bottom: 26px;
	}
	.company .img-box {
		margin-bottom: 33px;
		display: block;
	}
	.company .img-box .text-box {
		margin-bottom: 18px;
		width: auto;
	}
	.company .img-box .text-box .title {
		margin-bottom: 14px;
		font-size: 20px;
		line-height: 2;
	}
	.company .img-box .photo-box {
		margin-top: 1px;
		width: auto;
	}
	.company .img-box .photo-box img {
		width: 100%;
	}
	.company .img-box .photo-box .photo img {
		width: 100%;
	}
	.company .img-box .photo-box .name .sml {
		margin-bottom: -2px;
	}
	.company .inner {
		margin: 0;
		padding: 0;
		max-width: inherit;
	}
	.company .inner .title-box {
		margin-bottom: 17px;
	}
	.company .inner .title-box .num {
		margin-top: 5px;
	}
	.company .inner .title-box .txt {
		width: calc(100% - 58px);
		line-height: 1.67;
	}
	.company .inner .title {
		margin-bottom: 18px;
		font-size: 20px;
		line-height: 1.5;
	}
	.company .inner .text-area {
		display: block;
	}
	.company .inner .text-area .text {
		line-height: 1.69;
		width: auto;
	}
	.company .inner .text-area .photo {
		margin-top: 28px;
		width: auto;
	}
	.company .inner .img-area {
		display: block;
	}
	.company .inner .img-area .photo {
		margin: 0 0 19px;
		width: auto;
	}
	.company .inner .img-area .text {
		width: auto;
	}
	.company .inner .inn-photo {
		max-width: inherit;
	}
	.company .inner .inn-photo .txt {
		margin-top: 3px;
	}
	.company .inner .out-box {
		margin: 18px 0 9px;
		padding: 0;
		max-width: inherit;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.company .inner .out-box .inn-photo {
		margin: 0 0 8px;
		width: calc((100% - 9px) / 2);
	}
	.topics {
		padding: 52px 0 65px;
	}
	.topics::before {
		background: url(../img/topics_bg01_sp.png) no-repeat left top / 100% 100%;
	}
	.topics .head-line01 {
		margin-bottom: -1px;
	}
	.topics .photo-area {
		margin: 0 auto -3px;
		max-width: inherit;
	}
	.topics .photo-area .text-box {
		margin-bottom: -13px;
		position: static !important;
	}
	.topics .photo-area.is-spec .text-box {
		margin-bottom: -15px;
	}
	.topics .photo-area .text-box .en {
		margin-top: 40px;
	}
	.topics .photo-area .text-box .en img {
		width: 70%;
	}
	.topics .photo-area.is-spec .text-box .en {
		letter-spacing: 0.07em;
	}
	.topics .photo-area .text-box .text {
		font-size: 16px;
	}
	.topics .photo-area .photo {
		margin: 0 -20px 10px;
	}
	.topics .photo-area.is-spec .photo {
		margin-bottom: -10px;
	}
	.topics .photo-area .photo img {
		width: 100%;
	}
	.topics .text-area {
		margin: 0 0 11px;
		padding: 0;
		max-width: inherit;
	}
	.topics .p-link p {
		padding: 1px 15px 0 28px;
		line-height: 1.69;
		background: #FFF url(../img/link_icon01.png) no-repeat left 15px top 10px / 8px;
	}
	.topics .p-link.is-spec {
		margin: 23px 0 9px;
	}
}
@media screen and (max-width: 370px) {
	.company .inner .title {
		font-size: 5.4vw;
	}
	.main-visual .inner .text-box h1 {
		font-size: 13.2vw;
	}
}
@media screen and (max-width: 359px) {
	.main-visual .link-list li .txt {
		font-size: 4.4vw;
	}
	.topics .p-link p {
		font-size: 4.4vw;
	}
}