@charset "UTF-8";

/* main area */
#mv-area {
	overflow: hidden;
	padding-bottom: 30px;
	position: relative;
}
#mv-area .mv-bg {
	background: #365268;
	height: 100%;
	width: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 0;
}
#mv-area .mv-img {
	margin: 0 auto;
	max-width: 960px;
	width: 95%;
	position: relative;
	z-index: 1;
	animation-delay: 0.75s;
	line-height: 0;
}
@media screen and (min-width: 678px) {
	#mv-area .mv-img .mv-cap {
		bottom: auto;
		top: 30px;
	}
}
#mv-area h2 {
	background: -moz-linear-gradient(left, rgba(82, 127, 95, 0) 0%, rgba(71, 108, 55, 1) 50%, rgba(82, 127, 95, 0) 100%);
	background: -webkit-linear-gradient(left, rgba(82, 127, 95, 0) 0%, rgba(71, 108, 55, 1) 50%, rgba(82, 127, 95, 0) 100%);
	background: linear-gradient(to right, rgba(82, 127, 95, 0) 0%, rgba(71, 108, 55, 0.7) 50%, rgba(82, 127, 95, 0) 100%);
	max-width: 900px;
	margin: 0 auto;
	padding: 7px 100px 7px;
	position: absolute;
	left: 0;
	right: 0;
	top: 50%;
	text-align: center;
	transform: translateY(-50%);
	animation-delay: 1.25s;
}
#mv-area h2 > span {
	color: #fff;
	display: block;
	font-size: 38px;
	letter-spacing: 0.25em;
	line-height: 38px;
	animation-delay: 1.75s;
}
@media screen and (max-width: 900px) {
	#mv-area h2 {
		padding: 5px 10px;
	}
	#mv-area h2 > span {
		font-size: 30px;
		line-height: 30px;
	}
}
@media screen and (max-width: 767px) {
	#mv-area {
		padding-bottom: 10px;
	}
	#mv-area h2 > span {
		font-size: 25px;
		line-height: 25px;
	}
}

/* top area */
.top-area {
	padding:  80px 0 80px;
	position: relative;
}
.top-area .top-imgs .imgL,
.top-area .top-imgs .imgR {
	max-width: 320px;
	position: absolute;
	top: -5vw;
	z-index: 2;
}
.top-area .top-imgs .imgL {
	left: 0;
	width: 30%;
}
.top-area .top-imgs .imgL-sub {
	position: absolute;
	left: 15px;
	top: 80%;
	width: 50%;
	z-index: 2;
}
.top-area .top-imgs .imgR {
	right: 0;
	width: 30%;
}
.frm-ttl-01 {
	text-align: center;
}
.frm-ttl-01 h3 {
	color: #9fa0a0;
	font-size: 31px;
	font-weight: 500;
	letter-spacing: 0.1em;
	margin-bottom: 20px;
	position: relative;
}
.frm-ttl-01 h3::after {
	background: #637f58;
	content: "";
	display: block;
	height: 45px;
	width: 0.6px;
	margin: 0 auto;
	position: absolute;
	top: -58px;
	left: 0;
	right: 0;
}
.frm-ttl-01 p {
	font-size: 22px;
	font-weight: 300;
	letter-spacing: 0.2em;
	line-height: 1.6;
}
@media screen and (max-width: 1200px) {
	.top-area .top-imgs .imgL,
	.top-area .top-imgs .imgR {
		max-width: 25%;
	}
}
@media screen and (max-width: 900px) {
	.top-area .top-imgs .imgL,
	.top-area .top-imgs .imgR {
		top: -7vw;
	}
	.frm-ttl-01 h3 {
		font-size: 25px;
	}
	.frm-ttl-01 p {
		font-size: 18px;
		letter-spacing: 0.1em;
	}
}
@media screen and (max-width: 767px) {
	.top-area {
		padding: 60px 15px 0;
	}
	.top-area .top-imgs .imgL,
	.top-area .top-imgs .imgR {
		display: none;
	}
	.frm-ttl-01 h3 {
		font-size: 20px;
	}
	.frm-ttl-01 p {
		font-size: 16px;
	}
}

/* text & title */
.c-txt01 {
	line-height: 2.5;
	letter-spacing: 0.01em;
}
.c-ttl00 {
	font-size: 38px;
	line-height: 1.6;
	letter-spacing: 0.01em;
	margin-bottom: 25px;
}
.c-ttl00 .large {
	font-size: 128%;
}
.c-ttl01 {
	font-size: 24px;
	line-height: 1.6;
	letter-spacing: 0.01em;
	margin-bottom: 25px;
}
.color_aqua {
	color: #002e54;
}
@media screen and (max-width: 900px) {
	.c-ttl01 {
		font-size: 20px;
		line-height: 1.5;
	}
	.c-txt01 {
		font-size: 14px;
	}
}
@media screen and (max-width: 767px) {
	.c-ttl00 {
		font-size: 24px;	
	}
	.c-ttl01 {
		font-size: 20px;
		line-height: 1.5;
		margin-bottom: 15px;
	}
	.c-txt01 {
		font-size: 14px;
		line-height: 1.8;
		text-align: left!important;
	}
}
.ta_c {
  text-align: center;
}
.inner {
	margin: 0 auto;
	max-width: 1200px;
	width: 92%;
}
.inner1000 {
	margin: 0 auto;
	max-width: 1000px;
	width: 92%;
}
@media screen and (max-width: 900px) {
	.vpc900 {
		display: none
	}
}
@media not screen, screen and (min-width: 901px) {
	.vsp900 {
		display: none
	}
}

.top-area {
	background-image: url(../imgs/environment/top-area-bg.svg);
	background-repeat: no-repeat;
	background-size: 46%;
	background-position: 50% -9vw;
}
/* sections */
.sec-environment {
	padding: 100px 0;
}
.sec-environment .info-ttl {
	font-size: 24px;
	margin-bottom: 20px;
	position: relative;
}
.sec-environment .info-ttl > span {
	border-top: solid 0.3px #637f58;
	border-bottom: solid 0.3px #637f58;
	display: block;
	padding: 10px;
}
.sec-environment .caplist {
	width: 100%;
}
.environment-subttl {
	font-size: 20px;
	line-height: 1;
	position: relative;
}
.environment-subttl span span {
	padding: 0 1em;
	background-color: #fff;
	position: relative;
	z-index: 10;
}
.environment-subttl::after {
	content: "";
	width: 100%;
	height: 1px;
	background-color: #383839;
	position: absolute;
	top: 50%;
	left: 0;
	z-index: 0;
}
.pt-0 {
	padding-top: 0 !important;
}
.pb-0 {
	padding-bottom: 0 !important;
}
@media screen and (max-width: 900px) {
	.sec-environment {
		padding: 60px 0;
	}
	.sec-environment .info-ttl {
		font-size: 15px;
	}
}
@media screen and (max-width: 767px) {
	.top-area {
		background-size: 80%;
	}
	.com-photo-copy .ttl {
		font-size: 15px;
	}
	.col-6 {
		padding: 0 8px;
	}
}
.frm-border03 {
	border: 0.3px solid #aaa;
	padding: 60px;
	position: relative;
}
.frm-border03:before,
.frm-border03:after {
	background: #fff;
	content: "";
	height: 2px;
	max-width: 80%;
	width: calc(100% - 140px);
	margin: 0 auto;
	position: absolute;
	left: 0;
	right: 0;
	z-index: 1;
}
.frm-border03:before {
	top: -2px;
}
.frm-border03:after {
	bottom: -2px;
}
@media screen and (max-width: 900px) {
	.frm-border03 {
		padding: 40px 20px;
	}
}

.top-area .top-imgs .imgR {
	width: 21%;
	max-width: 100%;
	max-height: 276px;
	text-align: right;
}
.top-area .top-imgs .imgR figure,
.top-area .top-imgs .imgR img {
	max-height: 276px;
}
.sec2 .frm-box {
	border: none;
	background-color: #c1ccbc;
}
.sec2 .frm-box .frm-ttl-02 h4:after {
	content: none;
}
.sec3 {
	padding: 0 0 20px;
}
.sec3 .ttl.bg_aqua {
	background-color: #002e54;
}
.sec4 figure {
	display: block;
}
.sec4 .environment-img figure {
	width: 100%;
}
.bg_aqua_light {
  background-color: rgba(134,149,163,0.13);
}
.com-photo-copy .ttl {
	color: #fff;
	font-size: 20px;
	letter-spacing: 0.05em;
	margin-bottom: 15px;
	text-align: center;
}
.com-photo-copy .name {
	letter-spacing: 0.2em;
	margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
	.com-photo-copy .name {
		font-size: 14px;
		letter-spacing: 0.1em;
	}
}

.mb50 {
	margin-bottom: 50px !important
}
.mb60 {
	margin-bottom: 60px !important
}
@media screen and (max-width: 900px) {
	.mb10_sp {
		margin-bottom: 10px !important
	}
	.mb20_sp {
		margin-bottom: 20px !important
	}
	.mb30_sp {
		margin-bottom: 30px !important
	}
	.mb40_sp {
		margin-bottom: 40px !important
	}
}

figure figcaption {
  color: #333;
  font-size: 10px;
  position: absolute;
  bottom: 0;
  right: 0;
  line-height: 1.5;
  padding: 3px 5px;
  text-align: right;
  z-index: 4;
}
figure figcaption.white {
  color: #ffffff;
	text-shadow: 0 0 3px rgba(0,0,0,1), 0 0 5px rgba(0,0,0,1), 0 0 5px rgba(0,0,0,1); 
}
