@charset "UTF-8";

.mobile {
	display: none;
}

@media screen and (max-width:640px) {
	.mobile {
		display: block;
	}
}

@media screen and (max-width:640px) {
	.desktop {
		display: none;
	}
}

abbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,top_menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video {
	margin: 0;
	padding: 0;
	border: 0;
	background: 0 0;
	box-sizing: border-box;
	font: inherit;
	vertical-align: baseline;
	outline: 0;
	word-break: break-word;
	font-feature-settings: "palt";
}

.android {
	font-family: "Noto Sans Japanese";
}

article,aside,details,figcaption,figure,footer,header,hgroup,top_menu,nav,section {
	display: block;
}

html {
	font-size: 62.5%;
}

body {
	font-family: "游ゴシック",YuGothic,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
	width: 100%;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	color: #000;
	font-size: 14px;
	word-wrap: break-word;
	line-height: 1;
	font-feature-settings: "palt";
}

/*EF利用規約/個人情報の取り扱い部分*/
a {
	background-color: transparent;
	text-decoration: underline;
	color: inherit;
	color: #005ead;
  }

a:hover {
	transform: translateY(2px);
}

ol,ul {
	list-style: none;
}

blockquote,q {
	quotes: none;
}

blockquote:after,blockquote:before,q:after,q:before {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: 700;
}

del {
	text-decoration: line-through;
}

abbr[title],dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #ccc;
	margin: 1em 0;
	padding: 0;
}

input,select {
	vertical-align: middle;
}

.oa {
	overflow: auto;
}

.oh {
	overflow: hidden;
}

.ti {
	text-indent: -9999px;
}

.db {
	display: block;
}

.dib {
	display: inline-block;
}

.dn {
	display: none;
}

.di {
	display: inline;
}

.dt {
	display: table;
	width: 100%;
}

.dtr {
	display: table-row;
}

.dtc {
	display: table-cell;
	vertical-align: top;
}

.flL {
	float: left;
}

.flR {
	float: right;
}

.clr {
	clear: both;
}

.clr_after:after {
	content: "";
	clear: both;
	display: table;
}

.tal {
	text-align: left;
}

.tar {
	text-align: right;
}

.tac {
	text-align: center;
}

.vat {
	vertical-align: top;
}

.vam {
	vertical-align: middle;
}

.vab {
	vertical-align: bottom;
}

.vabl {
	vertical-align: baseline;
}

.fz12 {
	font-size: 12px;
}

.fz16 {
	font-size: 16px;
}

.fz18 {
	font-size: 18px;
}

.fwb {
	font-weight: 700;
}

.m00 {
	margin: 0;
}

.p00 {
	padding: 0;
}

.m05 {
	margin: 5px;
}

.p05 {
	padding: 5px;
}

.m10 {
	margin: 10px;
}

.p10 {
	padding: 10px;
}

.m15 {
	margin: 15px;
}

.p15 {
	padding: 15px;
}

.m20 {
	margin: 20px;
}

.p20 {
	padding: 20px;
}

.m25 {
	margin: 25px;
}

.p25 {
	padding: 25px;
}

.m30 {
	margin: 30px;
}

.p30 {
	padding: 30px;
}

.m35 {
	margin: 35px;
}

.p35 {
	padding: 35px;
}

.m40 {
	margin: 40px;
}

.p40 {
	padding: 40px;
}

.m45 {
	margin: 45px;
}

.p45 {
	padding: 45px;
}

.m50 {
	margin: 50px;
}

.p50 {
	padding: 50px;
}

.m55 {
	margin: 55px;
}

.p55 {
	padding: 55px;
}

.m60 {
	margin: 60px;
}

.p60 {
	padding: 60px;
}

.m65 {
	margin: 65px;
}

.p65 {
	padding: 65px;
}

.m70 {
	margin: 70px;
}

.p70 {
	padding: 70px;
}

.m75 {
	margin: 75px;
}

.p75 {
	padding: 75px;
}

.m80 {
	margin: 80px;
}

.p80 {
	padding: 80px;
}

.m85 {
	margin: 85px;
}

.p85 {
	padding: 85px;
}

.m90 {
	margin: 90px;
}

.p90 {
	padding: 90px;
}

.m95 {
	margin: 95px;
}

.p95 {
	padding: 95px;
}

.m100 {
	margin: 100px;
}

.p100 {
	padding: 100px;
}

.mt00 {
	margin-top: 0;
}

.pt00 {
	padding-top: 0;
}

.mt05 {
	margin-top: 5px;
}

.pt05 {
	padding-top: 5px;
}

.mt10 {
	margin-top: 10px;
}

.pt10 {
	padding-top: 10px;
}

.mt15 {
	margin-top: 15px;
}

.pt15 {
	padding-top: 15px;
}

.mt20 {
	margin-top: 20px;
}

.pt20 {
	padding-top: 20px;
}

.mt25 {
	margin-top: 25px;
}

.pt25 {
	padding-top: 25px;
}

.mt30 {
	margin-top: 30px;
}

.pt30 {
	padding-top: 30px;
}

.mt35 {
	margin-top: 35px;
}

.pt35 {
	padding-top: 35px;
}

.mt40 {
	margin-top: 40px;
}

.pt40 {
	padding-top: 40px;
}

.mt45 {
	margin-top: 45px;
}

.pt45 {
	padding-top: 45px;
}

.mt50 {
	margin-top: 50px;
}

.pt50 {
	padding-top: 50px;
}

.mt55 {
	margin-top: 55px;
}

.pt55 {
	padding-top: 55px;
}

.mt60 {
	margin-top: 60px;
}

.pt60 {
	padding-top: 60px;
}

.mt65 {
	margin-top: 65px;
}

.pt65 {
	padding-top: 65px;
}

.mt70 {
	margin-top: 70px;
}

.pt70 {
	padding-top: 70px;
}

.mt75 {
	margin-top: 75px;
}

.pt75 {
	padding-top: 75px;
}

.mt80 {
	margin-top: 80px;
}

.pt80 {
	padding-top: 80px;
}

.mt85 {
	margin-top: 85px;
}

.pt85 {
	padding-top: 85px;
}

.mt90 {
	margin-top: 90px;
}

.pt90 {
	padding-top: 90px;
}

.mt95 {
	margin-top: 95px;
}

.pt95 {
	padding-top: 95px;
}

.mt100 {
	margin-top: 100px;
}

.pt100 {
	padding-top: 100px;
}

.mb00 {
	margin-bottom: 0;
}

.pb00 {
	padding-bottom: 0;
}

.mb05 {
	margin-bottom: 5px;
}

.pb05 {
	padding-bottom: 5px;
}

.mb10 {
	margin-bottom: 10px;
}

.pb10 {
	padding-bottom: 10px;
}

.mb15 {
	margin-bottom: 15px;
}

.pb15 {
	padding-bottom: 15px;
}

.mb20 {
	margin-bottom: 20px;
}

.pb20 {
	padding-bottom: 20px;
}

.mb25 {
	margin-bottom: 25px;
}

.pb25 {
	padding-bottom: 25px;
}

.mb30 {
	margin-bottom: 30px;
}

.pb30 {
	padding-bottom: 30px;
}

.mb35 {
	margin-bottom: 35px;
}

.pb35 {
	padding-bottom: 35px;
}

.mb40 {
	margin-bottom: 40px;
}

.pb40 {
	padding-bottom: 40px;
}

.mb45 {
	margin-bottom: 45px;
}

.pb45 {
	padding-bottom: 45px;
}

.mb50 {
	margin-bottom: 50px;
}

.pb50 {
	padding-bottom: 50px;
}

.mb55 {
	margin-bottom: 55px;
}

.pb55 {
	padding-bottom: 55px;
}

.mb60 {
	margin-bottom: 60px;
}

.pb60 {
	padding-bottom: 60px;
}

.mb65 {
	margin-bottom: 65px;
}

.pb65 {
	padding-bottom: 65px;
}

.mb70 {
	margin-bottom: 70px;
}

.pb70 {
	padding-bottom: 70px;
}

.mb75 {
	margin-bottom: 75px;
}

.pb75 {
	padding-bottom: 75px;
}

.mb80 {
	margin-bottom: 80px;
}

.pb80 {
	padding-bottom: 80px;
}

.mb85 {
	margin-bottom: 85px;
}

.pb85 {
	padding-bottom: 85px;
}

.mb90 {
	margin-bottom: 90px;
}

.pb90 {
	padding-bottom: 90px;
}

.mb95 {
	margin-bottom: 95px;
}

.pb95 {
	padding-bottom: 95px;
}

.mb100 {
	margin-bottom: 100px;
}

.pb100 {
	padding-bottom: 100px;
}

.ml00 {
	margin-left: 0;
}

.pl00 {
	padding-left: 0;
}

.ml05 {
	margin-left: 5px;
}

.pl05 {
	padding-left: 5px;
}

.ml10 {
	margin-left: 10px;
}

.pl10 {
	padding-left: 10px;
}

.ml15 {
	margin-left: 15px;
}

.pl15 {
	padding-left: 15px;
}

.ml20 {
	margin-left: 20px;
}

.pl20 {
	padding-left: 20px;
}

.ml25 {
	margin-left: 25px;
}

.pl25 {
	padding-left: 25px;
}

.ml30 {
	margin-left: 30px;
}

.pl30 {
	padding-left: 30px;
}

.ml35 {
	margin-left: 35px;
}

.pl35 {
	padding-left: 35px;
}

.ml40 {
	margin-left: 40px;
}

.pl40 {
	padding-left: 40px;
}

.ml45 {
	margin-left: 45px;
}

.pl45 {
	padding-left: 45px;
}

.ml50 {
	margin-left: 50px;
}

.pl50 {
	padding-left: 50px;
}

.ml55 {
	margin-left: 55px;
}

.pl55 {
	padding-left: 55px;
}

.ml60 {
	margin-left: 60px;
}

.pl60 {
	padding-left: 60px;
}

.ml65 {
	margin-left: 65px;
}

.pl65 {
	padding-left: 65px;
}

.ml70 {
	margin-left: 70px;
}

.pl70 {
	padding-left: 70px;
}

.ml75 {
	margin-left: 75px;
}

.pl75 {
	padding-left: 75px;
}

.ml80 {
	margin-left: 80px;
}

.pl80 {
	padding-left: 80px;
}

.ml85 {
	margin-left: 85px;
}

.pl85 {
	padding-left: 85px;
}

.ml90 {
	margin-left: 90px;
}

.pl90 {
	padding-left: 90px;
}

.ml95 {
	margin-left: 95px;
}

.pl95 {
	padding-left: 95px;
}

.ml100 {
	margin-left: 100px;
}

.pl100 {
	padding-left: 100px;
}

.mr00 {
	margin-right: 0;
}

.pr00 {
	padding-right: 0;
}

.mr05 {
	margin-right: 5px;
}

.pr05 {
	padding-right: 5px;
}

.mr10 {
	margin-right: 10px;
}

.pr10 {
	padding-right: 10px;
}

.mr15 {
	margin-right: 15px;
}

.pr15 {
	padding-right: 15px;
}

.mr20 {
	margin-right: 20px;
}

.pr20 {
	padding-right: 20px;
}

.mr25 {
	margin-right: 25px;
}

.pr25 {
	padding-right: 25px;
}

.mr30 {
	margin-right: 30px;
}

.pr30 {
	padding-right: 30px;
}

.mr35 {
	margin-right: 35px;
}

.pr35 {
	padding-right: 35px;
}

.mr40 {
	margin-right: 40px;
}

.pr40 {
	padding-right: 40px;
}

.mr45 {
	margin-right: 45px;
}

.pr45 {
	padding-right: 45px;
}

.mr50 {
	margin-right: 50px;
}

.pr50 {
	padding-right: 50px;
}

.mr55 {
	margin-right: 55px;
}

.pr55 {
	padding-right: 55px;
}

.mr60 {
	margin-right: 60px;
}

.pr60 {
	padding-right: 60px;
}

.mr65 {
	margin-right: 65px;
}

.pr65 {
	padding-right: 65px;
}

.mr70 {
	margin-right: 70px;
}

.pr70 {
	padding-right: 70px;
}

.mr75 {
	margin-right: 75px;
}

.pr75 {
	padding-right: 75px;
}

.mr80 {
	margin-right: 80px;
}

.pr80 {
	padding-right: 80px;
}

.mr85 {
	margin-right: 85px;
}

.pr85 {
	padding-right: 85px;
}

.mr90 {
	margin-right: 90px;
}

.pr90 {
	padding-right: 90px;
}

.mr95 {
	margin-right: 95px;
}

.pr95 {
	padding-right: 95px;
}

.mr100 {
	margin-right: 100px;
}

.pr100 {
	padding-right: 100px;
}

.bdn {
	border: none;
}

.bdtn {
	border-top: none;
}

.bdrn {
	border-right: none;
}

.bdbn {
	border-bottom: none;
}

.bdln {
	border-left: none;
}

.por {
	position: relative;
}

.poa {
	position: absolute;
}

.pof {
	position: fixed;
}

.flex-wrap {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-ms-flex-pack: distribute;
	justify-content: space-around;
}

.flex-row {
	-ms-flex-direction: row;
	flex-direction: row;
}

.font {
	font-family: "Crimson Text",serif;
}

.section {
	position: relative;
	padding: 65px 0 70px;
	overflow: hidden;
}

@media screen and (max-width:640px) {
	.section {
		padding: 30px 0 40px;
	}
}

.seclink {
	position: absolute;
	top: -80px;
}

@media screen and (max-width:640px) {
	.seclink {
		top: -50px;
	}
}

.col-inner {
	display: -ms-flexbox;
	display: flex;
/**
	width: 1000px;
**/
	margin: auto;
}

@media screen and (max-width:640px) {
	.col-inner {
		width: 100%;
		padding-left: 25px;
		padding-right: 25px;
	}
}

.title {
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-direction: column;
	flex-direction: column;
	margin-bottom: 25px;
	font-weight: 700;
	color: #005faf;
}

@media screen and (max-width:640px) {
	.title {
		margin-bottom: 10px;
		text-align: center;
	}
}

.title-en {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 10px;
	font-family: "Crimson Text",serif;
	font-size: 13px;
}

@media screen and (max-width:640px) {
	.title-en {
		margin-bottom: 5px;
		font-size: calc(50% + 1vw);
	}
}

.title-en:after,.title-en:before {
	content: "";
	display: inline-block;
	width: 2px;
	height: 25px;
	border-radius: 2px;
	background: #327600;
}

@media screen and (max-width:640px) {
	.title-en:after,.title-en:before {
		height: 20px;
	}
}

.title-en:before {
	margin-right: 20px;
	transform: rotate(-45deg);
}

.title-en:after {
	margin-left: 20px;
	transform: rotate(45deg);
}

.title-jp {
	font-size: 40px;
}

@media screen and (max-width:640px) {
	.title-jp {
		font-size: calc(120% + 1.4vw);
		text-align: center;
	}
}

.titlesub {
	-ms-flex-pack: center;
	justify-content: center;
	font-weight: 700;
	font-size: 16px;
	color: #327600;
	text-align: center;
	line-height: 1.5;
}

@media screen and (max-width:640px) {
	.titlesub {
		padding: 0 35px;
		font-size: calc(70% + 1vw);
	}
}

.cv {
	padding: 60px 0;
	border: 1px solid #cf0;
	box-shadow: 10px 10px 0 #fff inset,-10px -10px 0 #fff inset;
	background: #cf0;
}

@media screen and (max-width:640px) {
	.cv {
		padding: 30px 0;
		box-shadow: 5px 5px 0 #fff inset,-5px -5px 0 #fff inset;
	}
}

.cv-btn1,.cv-btn2 {
	position: relative;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	border-radius: 50px;
	font-size: 30px;
	font-weight: 700;
	color: #fff;
}

@media screen and (max-width:640px) {
	.cv-btn1,.cv-btn2 {
		font-size: calc(90% + 1vw);
	}
}

.cv-btn1 {
	position: relative;
	width: 600px;
	height: 85px;
	margin: auto;
	background-image: linear-gradient(to bottom,#b10026 50%,#9c0020 50%);
	box-shadow: 0 3px 0 rgba(0,0,0,.3);
	color: #fff;
}

@media screen and (max-width:640px) {
	.cv-btn1 {
		width: 100%;
		height: auto;
		padding: 20px 0 20px 10%;
	}
}

.cv-btn1-icon {
	margin: -20px 20px 0 -110px;
}

@media screen and (max-width:640px) {
	.cv-btn1-icon {
		position: absolute;
		top: -10px;
		left: 5px;
		max-width: 60px;
		width: 18%;
		margin: 0;
	}
}

.cv-btn1:hover {
	box-shadow: none;
}

.cv-btn2 {
	width: 257px;
	height: 50px;
	background-image: linear-gradient(to bottom,#b10026 50%,#9c0020 50%);
	box-shadow: 0 3px 0 rgba(0,0,0,.3);
	color: #fff;
	font-size: 15px;
	text-align: center;
}

.cv-btn2-icon {
	margin: -10px 5px 0 -20px;
}

.cv-btn2:hover {
	box-shadow: none;
}

.cv-area-fixed {
	position: fixed;
	bottom: 0px;
	z-index: 9999;
	width: 100%;
	padding: 15px 0;
	background: #327600;
}

.cv-area-fixed .cv-btn2 {
	width: 330px;
	height: 50px;
	margin: auto;
	box-shadow: 0 3px 0 rgba(0,0,0,.2);
	font-size: 18px;
}

@media screen and (max-width:640px) {
	.cv-area-fixed .cv-btn2 {
		width: 100%;
		height: auto;
		padding: 15px 0 15px 10%;
		font-size: calc(80% + 1vw);
	}
}

@media screen and (max-width:640px) {
	.cv-area-fixed .cv-btn2-icon {
		position: absolute;
		top: -10px;
		left: 5px;
		max-width: 50px;
		width: 15%;
		margin: 0;
	}
}

.slick-next,.slick-prev {
	z-index: 100;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #cf0;
	transition: all .4s linear;
}

.slick-next:hover,.slick-prev:hover {
	opacity: .8;
	background: #cf0;
}

.slick-next:before,.slick-prev:before {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	width: 40px;
	height: 40px;
	font-size: 25px;
	color: #435400;
}

.slick-prev {
	left: -5px;
}

@media screen and (max-width:640px) {
	.slick-prev {
		left: 10px;
	}
}

.slick-prev:before {
	content: "\f104";
	font-family: FontAwesome;
}

.slick-next {
	right: -5px;
}

@media screen and (max-width:640px) {
	.slick-next {
		right: 10px;
	}
}

.slick-next:before {
	content: "\f105";
	font-family: FontAwesome;
}

.header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 65px;
	z-index: 1000;
	background-color: #fff;
}

@media screen and (max-width:640px) {
	.header {
		height: 50px;
		padding-top: 0px;
	}
}

.header .col-inner {
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-align: center;
	align-items: center;
        width: 1750px;
}

@media screen and (max-width:640px) {
	.header .col-inner {
		padding: 0 15px;
		position: relative;
		-ms-flex-align: center;
		align-items: center;
	}
}

.header .page_ttl {
	width: 290px;
	height: 26px;
        margin-left: 70px;
        margin-top: 10px;
}

@media screen and (max-width:640px) {
	.header .page_ttl {
		max-width: 210px;
		width: 90%;
		height: auto;
		margin-top: 7px;
		margin-left: -18px;
	}
}

.header .page_ttl img {
	width: 100%;
}

@media only screen and (max-width:960px) {
	.gnav {
		display: none;
	}
}

.gnav ul {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-pack: justify;
	justify-content: space-between;
	height: 85px;
}

.gnav li a {
	padding: 0 13px;
	font-size: 14px;
	font-weight: 700;
	transition: all .3s;
}

.gnav li a:hover {
	opacity: .6;
}

.gnav li .cv-btn2 {
	margin-left: 10px;
}

.top_menu {
	overflow-y: auto;
	position: absolute;
	visibility: hidden;
	opacity: 0;
	top: 0;
	right: 0;
	width: 512px;
	height: 100vh;
	max-height: 100vh;
	background: #072040;
	z-index: 9000;
	padding: 13.6% 0;
	transform: translateX(100%);
	transition: .3s ease-in-out;
}

.top_menu ul {
	width: 100%;
	margin: auto;
	border-bottom: 1px solid #666;
}

.top_menu ul li {
	border-top: 1px solid #666;
}

.top_menu ul li a {
	display: block;
	width: 100%;
	text-align: left;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.6;
	padding: .75em 1.5em;
	color: #fff;
	white-space: nowrap;
	letter-spacing: .1em;
	opacity: 1;
	transition: all .2s linear;
}

.top_menu ul li a:hover {
	opacity: .6;
}

.opened .top_menu {
	width: 80%;
	transform: translateX(0);
	visibility: visible;
	opacity: 1;
}

.overlay {
	position: fixed;
	top: 0;
	left: 0;
	opacity: 0;
	visibility: hidden;
	width: 100vw;
	height: 100vh;
	background: rgba(0,0,0,.4);
	z-index: 1001;
	transition: all .2s;
}

.opened .overlay {
	opacity: 1;
	visibility: visible;
}

.menu-trigger {
	color: #000;
	width: 50px;
	height: auto;
	padding-top: 20px;
	margin-top: 32px;
	display: none;
	position: relative;
	right: 25px;
	z-index: 9999;
	transition: all .3s linear;
}

.menu-trigger:hover {
	opacity: .7;
}

.menu-trigger span {
	transition: all .3s linear;
}

.menu-trigger span:nth-of-type(1),.menu-trigger span:nth-of-type(2),.menu-trigger span:nth-of-type(3) {
	display: block;
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	opacity: 1;
	background-color: #115fad;
}

.menu-trigger span:nth-of-type(1) {
	top: 0;
}

.menu-trigger span:nth-of-type(2) {
	top: 50%;
	transform: translateY(-1px);
}

.menu-trigger span:nth-of-type(3) {
	top: 100%;
	transform: translateY(-2px);
}

.menu-trigger span:nth-of-type(4) {
	text-align: center;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	font-size: calc(100vw * 10 / 320);
	font-weight: 500;
	color: #000;
	white-space: nowrap;
	opacity: 1;
	visibility: visible;
}

.opened .menu-trigger span {
	background-color: #fff;
}

.opened .menu-trigger span:nth-of-type(1) {
	transform: translateY(-1px) rotate(-45deg);
	top: 50%;
}

.opened .menu-trigger span:nth-of-type(2) {
	left: 50%;
	opacity: 0;
	animation: active-menu-bar02 .5s forwards;
}

@keyframes active-menu-bar02 {
	100% {
		height: 0;
	}
}

.opened .menu-trigger span:nth-of-type(3) {
	transform: translateY(-1px) rotate(45deg);
	top: 50%;
}

.opened .menu-trigger span:nth-of-type(4) {
	background-color: transparent;
	opacity: 0;
	visibility: hidden;
}

@media only screen and (max-width:960px) {
	.menu-trigger {
		display: block;
	}
}

@media only screen and (max-width:640px) {
	.top_menu {
		width: 0;
	}

	.top_menu ul li a {
		font-size: calc(100vw * 12 / 320);
	}

	.menu-trigger {
		width: 25px;
		padding-top: 18px;
		margin-top: 1px;
		right: -22px;
	}
}

.keyvisual {
	position: relative;
	height: 500px;
	margin-top: -40px;
	background: url(../images/keyvisual_2-2.png) center center no-repeat;
}

@media screen and (max-width:640px) {
	.keyvisual {
		display: -ms-flexbox;
		display: flex;
		-ms-flex-direction: column;
		flex-direction: column;
		height: auto;
		background: url(../images/keyvisual_2-2_sp.png) center center/cover no-repeat;
		margin-top: 0px;
		position: relative;
		height: 300px;
	}
}

.keyvisual-copy {
	color: #fff;
}

@media screen and (max-width:640px) {
	.keyvisual-copy {
		-ms-flex-order: 1;
		order: 1;
		padding: 10px 0;
	}
}

.keyvisual-copy .col-inner {
	-ms-flex-pack: end;
	justify-content: flex-end;
}

@media screen and (max-width:640px) {
	.keyvisual-copy .col-inner {
		-ms-flex-pack: left;
		justify-content: left;
		padding: 0 13px;
	}
}

.keyvisual-copy__wrap {
	position: relative;
	padding: 30px 0 0;
}

@media screen and (max-width:640px) {
	.keyvisual-copy__wrap {
		display: -ms-flexbox;
		display: flex;
		-ms-flex-pack: center;
		justify-content: center;
		-ms-flex-align: center;
		align-items: center;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		padding: 0;
	}
}

.keyvisual-copy1 {
	width: 620px;
	margin-left: 14%;
	margin-bottom: -2px;
}
.keyvisual-copy1 .desktop {
    color: #001647;
	font-size: 81px;
	line-height: 83px;
    font-family: serif;
}
@media screen and (max-width:640px) {
	.keyvisual-copy1 {
		display: inline-block;
		width: 100%;
		text-align: center;
		margin-bottom: -1px;
		color: #001647;
    font-size: 81px;
    line-height: 83px;
	}
}

.keyvisual-copy1 img {
	margin-left: -0px;
}

@media screen and (max-width: 640px) {
	.keyvisual-copy1 img {
		margin-left: 2px;
	}
}

.keyvisual-copy_list {
	position: absolute;
	left: 23px;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	width: 470px;
}

@media screen and (max-width:640px) {
	.keyvisual-copy_list {
		position: static;
		width: 100%;
		padding: 0;
	}
}

.keyvisual-copy_list li {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	width: 150px;
	height: 30px;
	margin-bottom: 6px;
	border-radius: 40px;
	background: #e9ebe8;
	font-family: "游明朝",YuMincho,"ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","ＭＳ Ｐ明朝","ＭＳ 明朝",serif;
	font-size: 13px;
	font-weight: 700;
	color: #327600;
}

@media screen and (max-width:640px) {
	.keyvisual-copy_list li {
		width: 32%;
		height: auto;
		margin: 0 1px 5px;
		padding: 1.5% 5px;
		font-size: 2.6vw;
	}
}

.keyvisual-copy_list li span {
	font-size: 8px;
	letter-spacing: -1px;
}

@media screen and (max-width:640px) {
	.keyvisual-copy_list li span {
		font-size: 1.6vw;
	}
}

.keyvisual-copy_list li:nth-child(4),.keyvisual-copy_list li:nth-child(5),.keyvisual-copy_list li:nth-child(6) {
	margin-bottom: 0;
}

.keyvisual-copy2 {
	font-size: 30px;
	font-weight: 700;
	color: #327600;
	text-align: center;
	text-shadow: 0 0 8px #fff,0 0 8px #fff,0 0 8px #fff,0 0 8px #fff;
	line-height: 1.5;
}

@media screen and (max-width:640px) {
	.keyvisual-copy2 {
		display: inline-block;
		margin-bottom: 10px;
		font-size: 2.9vw;
		text-shadow: none;
		color: #fff;
		line-height: 1.2;
	}
}

.keyvisual-points {
	position: absolute;
	bottom: 20px;
	left: 0;
	width: 100%;
	padding: 25px 0;
}

@media screen and (max-width:640px) {
	.keyvisual-points {
		-ms-flex-order: 3;
		order: 3;
		position: static;
		width: auto;
		padding: 10px 0 5px;
		background: 0 0;
	}
}

.keyvisual-points .points-inner {
	-ms-flex-pack: end;
	justify-content: flex-end;
}

@media screen and (max-width:640px) {
	.keyvisual-points .points-inner {
		padding: 0 10px;
	}
}

.keyvisual-pointsbox {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: row;
	flex-direction: row;
	-ms-flex-pack: justify;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 510px;
}

@media screen and (max-width:640px) {
	.keyvisual-pointsbox {
		width: 42%;
	}
}

.keyvisual-pointseach {
    text-align: center;
	width: 115px;
	height: 115px;
	padding: 21px 0;
	border-radius: 115px;
	opacity: 0.6;
	background: #005eab;
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	line-height: 1.5;
}

@media screen and (max-width:640px) {
	.keyvisual-pointseach {
		width: auto;
		min-height: 60px;
		height: auto;
		margin-bottom: 7px;
		padding: 13px 0;
		border-radius: 5px;
		font-size: 24px;
		line-height: 1.3;
		opacity: 1;
	}
}

.keyvisual-pointseach dt {
	position: absolute;
	top: 10px;
	right: 15px;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	-ms-flex-align: center;
	align-items: center;
	font-family: "Crimson Text",serif;
}

@media screen and (max-width:640px) {
	.keyvisual-pointseach dt {
		top: 7%;
		right: 3px;
	}
}

.keyvisual-pointseach dt span:first-child {
	transform: rotate(90deg);
	display: block;
	margin: 15px 0 20px;
	font-size: 11px;
}

@media screen and (max-width:640px) {
	.keyvisual-pointseach dt span:first-child {
		margin: 50% 0 10px;
		font-size: 1.6vw;
	}
}

.keyvisual-pointseach dt span:last-child {
	font-size: 25px;
}

@media screen and (max-width:640px) {
	.keyvisual-pointseach dt span:last-child {
		font-size: 3vw;
	}
}

@media screen and (max-width:640px) {
	.keyvisual-pointseach dd br {
		display: none;
	}
}

.sec1 {
	padding: 60px 0 80px;
	background: url(../images/sec1-bg.png) center 0 no-repeat;
}

@media screen and (max-width:640px) {
	.sec1 {
		padding: 30px 0;
		background-size: cover;
	}
}

.sec1 .titlesub {
	margin-bottom: 60px;
}

@media screen and (max-width:640px) {
	.sec1 .titlesub {
		margin-bottom: 40px;
	}
}

.voice {
	width: 990px;
	margin: auto;
}

@media screen and (max-width:640px) {
	.voice {
		width: 100%;
	}
}

.voice .slick-list {
	overflow: visible;
}

.voice-box {
	display: -ms-flexbox!important;
	display: flex!important;
	width: 990px;
	padding: 0 15px;
}

@media screen and (max-width:640px) {
	.voice-box {
		-ms-flex-direction: column;
		flex-direction: column;
		width: 100%;
	}
}

.voice-img {
	width: 480px;
}

@media screen and (max-width:640px) {
	.voice-img {
		-ms-flex-order: 2;
		order: 2;
		width: 100%;
	}
}

.voice-img img {
	width: 100%;
}

.voice-summary {
	position: relative;
	width: 480px;
	padding: 40px 170px 0 40px;
	background: #fff;
}

@media screen and (max-width:640px) {
	.voice-summary {
		-ms-flex-order: 1;
		order: 1;
		width: 100%;
		min-height: 125vw;
		padding: 20px 30% 20px 20px;
	}
}

.voice-title {
	position: absolute;
	top: -15px;
	right: 20px;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-size: 38px;
	font-weight: 700;
	color: #fff;
}

@media screen and (max-width:640px) {
	.voice-title {
		right: 10px;
		font-size: calc(100% + 2vw);
	}
}

.voice-title>span {
	display: block;
	margin-right: 1px;
}

.voice-title>span span {
	display: inline-block;
	padding: 10px 6px;
	background: #327600;
}

@media screen and (max-width:640px) {
	.voice-inner {
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
}

.voice-inner-num {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-bottom: 15px;
	font-family: "Crimson Text",serif;
	font-weight: 700;
}

@media screen and (max-width:640px) {
	.voice-inner-num {
		-ms-flex-direction: column;
		flex-direction: column;
		-ms-flex-pack: center;
		justify-content: center;
		width: 45%;
		margin-bottom: 0;
	}
}

.voice-inner-num dt {
	font-size: 15px;
}

@media screen and (max-width:640px) {
	.voice-inner-num dt {
		margin-bottom: 5px;
		font-size: calc(70% + 1vw);
	}
}

.voice-inner-num dd {
	font-size: 18px;
}

@media screen and (max-width:640px) {
	.voice-inner-num dd {
		font-size: calc(90% + 1vw);
	}
}

.voice-inner-point {
	margin-bottom: 15px;
	padding: 25px 25px 30px;
	background: #f3f3f3;
	text-align: center;
}

@media screen and (max-width:640px) {
	.voice-inner-point {
		width: 55%;
		margin-bottom: 0;
		padding: 10px 0;
	}
}

.voice-inner-point h4 {
	margin-bottom: 5px;
	font-size: 18px;
	font-weight: 700;
}

@media screen and (max-width:640px) {
	.voice-inner-point h4 {
		font-size: calc(60% + 1vw);
	}
}

.voice-inner-point ul {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
}

@media screen and (max-width:640px) {
	.voice-inner-point ul li {
		width: 12%;
	}
}

@media screen and (max-width:640px) {
	.voice-inner-point ul li img {
		width: 100%;
	}
}

.voice-inner p {
	font-size: 15px;
	font-weight: 700;
	line-height: 1.8;
}

@media screen and (max-width:640px) {
	.voice-inner p {
		padding-top: 15px;
		font-size: calc(80% + 1vw);
	}
}

.sec2 {
	background: url(../images/sec1-bg.png) center center/cover no-repeat;
}

.sec2 .title-en:after,.sec2 .title-en:before {
	background: #005faf;
}

.sec2 .titlesub {
	margin-bottom: 60px;
	color: #005faf;
}

@media screen and (max-width:640px) {
	.sec2 .titlesub {
		margin-bottom: 40px;
	}
}

.sec2 .slick-list {
	overflow: visible;
}

.sample {
	width: 990px;
	margin: auto;
}

@media screen and (max-width:640px) {
	.sample {
		width: 100%;
	}
}

.sample-box {
	padding: 0 10px;
}

.sample-inner {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	height: 410px;
	background: #fff;
}

@media screen and (max-width:640px) {
	.sample-inner {
		height: auto;
		min-height: 90vw;
	}
}

.sample-title {
	height: 120px;
	background: #327600;
	font-size: 19px;
	color: #fff;
	text-align: center;
	line-height: 1.3;
}

@media screen and (max-width:640px) {
	.sample-title {
		height: auto;
		min-height: 110px;
		font-size: calc(80% + 1vw);
	}
}

.sample-title span {
	font-weight: 700;
}

.sample-title span:first-child {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	width: 160px;
	height: 35px;
	margin: -20px auto 20px;
	border-radius: 20px;
	background: #fff;
	font-family: "Crimson Text",serif;
	font-size: 14px;
	color: #327600;
}

@media screen and (max-width:640px) {
	.sample-title span:first-child {
		width: 60%;
		height: auto;
		margin-top: -10px;
		padding: 7px 0;
		border-radius: 8px;
		font-size: calc(50% + 1vw);
	}
}

.sample-img {
	position: absolute;
	top: -65px;
	left: 50%;
	transform: translateX(-50%);
}

@media screen and (max-width:640px) {
	.sample-img {
		max-width: 125px;
		width: 50%;
	}
}

.sample-summary {
	position: relative;
	padding: 30px 35px 0;
}

@media screen and (max-width:640px) {
	.sample-summary {
		padding: 30px 25px 30px;
	}
}

.sample-summary-p {
	height: 110px;
	font-size: 14px;
	line-height: 1.6;
}

@media screen and (max-width:640px) {
	.sample-summary-p {
		height: auto;
		min-height: 28vw;
		font-size: calc(60% + 1vw);
	}
}

.sample-summary-income {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 15px;
	font-weight: 700;
	color: #b10026;
}

.sample-summary-income span:first-child {
	font-size: 42px;
	font-family: "Crimson Text",serif;
}

@media screen and (max-width:640px) {
	.sample-summary-income span:first-child {
		font-size: calc(220% + 1vw);
	}
}

.sample-summary-income span:last-child {
	margin: 2px 0 0 5px;
	font-size: 16px;
	line-height: 1;
}

@media screen and (max-width:640px) {
	.sample-summary-income span:last-child {
		font-size: calc(70% + 1vw);
	}
}

.sample-summary-place {
	padding: 8px 0;
	border-radius: 20px;
	background: #ebebeb;
	font-weight: 700;
	text-align: center;
}

@media screen and (max-width:640px) {
	.sample-summary-place {
		border-radius: 5px;
		font-size: calc(55% + 1vw);
	}
}

.logos {
	padding: 60px 0 70px;
}

@media screen and (max-width:640px) {
	.logos {
		padding: 20px 0 0;
	}
}

.sec3 {
	background: url(../images/sec3-bg.png) center center/cover no-repeat;
}

.sec3 .title {
	margin-bottom: 40px;
}

.case {
	display: -ms-flexbox;
	display: flex;
	max-width: 1800px;
	min-width: 1024px;
	width: 100%;
	margin: 0 auto;
}

@media screen and (max-width:640px) {
	.case {
		-ms-flex-direction: column;
		flex-direction: column;
		min-width: 100px;
		padding-right: 25px;
		padding-left: 25px;
	}
}

.case-img {
	position: relative;
	z-index: 1;
	max-width: 1015px;
	width: 100%;
}

@media screen and (max-width:640px) {
	.case-img {
		-ms-flex-order: 1;
		order: 1;
	}
}

.case-img img {
	display: block;
	width: 100%;
}

.case-img p {
	position: absolute;
	top: 60px;
	transform: rotate(90deg);
	font-size: 18px;
	font-weight: 700;
	font-family: "Crimson Text",serif;
	color: #fff;
}

@media screen and (max-width:640px) {
	.case-img p {
		display: none;
	}
}

.case-summary {
	position: relative;
	z-index: 5;
	max-width: 1015px;
	min-width: 940px;
	width: 100%;
	padding: 70px;
	background: #fff;
}

@media screen and (max-width:640px) {
	.case-summary {
		-ms-flex-order: 2;
		order: 2;
		min-width: 100px;
		padding: 25px;
	}
}

.case-summary-age {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 20px;
	font-size: 15px;
	font-weight: 700;
	color: #327600;
}

@media screen and (max-width:640px) {
	.case-summary-age {
		margin-bottom: 10px;
		font-size: calc(70% + 1vw);
		font-weight: 700;
	}
}

.case-summary-age:before {
	content: "";
	width: 82px;
	height: 2px;
	display: block;
	margin-right: 10px;
	background: #327600;
}

@media screen and (max-width:640px) {
	.case-summary-age:before {
		width: 60px;
	}
}

.case-summary-title {
	margin-bottom: 30px;
	font-size: 36px;
	font-weight: 700;
	color: #327600;
	line-height: 1.2;
}

@media screen and (max-width:640px) {
	.case-summary-title {
		margin-bottom: 30px;
		font-size: calc(100% + 1vw);
		font-weight: 700;
		line-height: 1.4;
	}
}

.case1 {
	margin-bottom: 100px;
}

@media screen and (max-width:640px) {
	.case1 {
		margin-bottom: 20px;
	}
}

.case1 .case-img p {
	left: 0;
}

.case1 .case-summary {
	margin: 50px 0 -50px -15%;
}

@media screen and (max-width:640px) {
	.case1 .case-summary {
		margin: 0;
	}
}

.case2 {
	margin-bottom: 50px;
}

.case2 .case-img p {
	right: 0;
}

.case2 .case-summary {
	margin: 50px -15% -50px 0;
}

@media screen and (max-width:640px) {
	.case2 .case-summary {
		margin: 0;
	}
}

.case-sub {
	margin-bottom: 10px;
	font-size: 16px;
	font-weight: 700;
}

@media screen and (max-width:640px) {
	.case-sub {
		font-size: calc(90% + 1vw);
		font-weight: 700;
		line-height: 1.4;
	}
}

.case-paraph {
	font-size: 16px;
	line-height: 1.6;
}

@media screen and (max-width:640px) {
	.case-paraph {
		font-size: calc(80% + 1vw);
	}
}

.ba {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-align: center;
	align-items: center;
	margin-bottom: 30px;
}

@media screen and (max-width:640px) {
	.ba {
		-ms-flex-direction: column;
		flex-direction: column;
		margin-bottom: 20px;
	}
}

.ba dl {
	position: relative;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-direction: column;
	flex-direction: column;
	width: 47%;
	height: 110px;
	border: 4px solid #dcdcdc;
}

@media screen and (max-width:640px) {
	.ba dl {
		width: 100%;
		height: auto;
		padding: 20px 0 10px;
		border-width: 2px;
	}
}

.ba dt {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	width: 75%;
	height: 35px;
	margin: -25px 0 10px;
	background: #dcdcdc;
	font-family: "Crimson Text",serif;
	font-size: 15px;
	font-weight: 700;
	color: #fff;
}

@media screen and (max-width:640px) {
	.ba dt {
		position: absolute;
		top: -10px;
		left: 50%;
		transform: translateX(-50%);
		height: auto;
		margin: 0;
		padding: 7px 0;
		font-size: calc(50% + 1vw);
	}
}

.ba-paraph {
	font-size: 16px;
	margin-bottom: 8px;
}

@media screen and (max-width:640px) {
	.ba-paraph {
		margin-bottom: 5px;
		font-size: calc(60% + 1vw);
		font-weight: 700;
	}
}

.ba-income {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	font-weight: 700;
	color: #dcdcdc;
}

.ba-income span:first-child {
	font-size: 42px;
	font-family: "Crimson Text",serif;
}

@media screen and (max-width:640px) {
	.ba-income span:first-child {
		font-size: calc(220% + 1vw);
	}
}

.ba-income span:last-child {
	margin: 2px 0 0 5px;
	font-size: 16px;
	line-height: 1;
}

@media screen and (max-width:640px) {
	.ba-income span:last-child {
		font-size: calc(70% + 1vw);
	}
}

.ba-after {
	border-color: #be002d!important;
}

.ba-after dt {
	background: #be002d;
}

.ba-after .ba-income {
	color: #be002d;
}

.ba i {
	margin: 0 20px;
	font-size: 24px;
	color: #dcdcdc;
}

@media screen and (max-width:640px) {
	.ba i {
		transform: rotate(90deg);
		margin: 10px 0 15px;
		font-size: 18px;
	}
}

.sec4 {
	background: url(../images/sec4-bg.png) center center/cover no-repeat;
}

@media screen and (max-width:640px) {
	.sec4 {
		padding: 25px 0 0;
	}
}

.sec4 .title {
	margin-bottom: 60px;
	color: #fff;
}

@media screen and (max-width:640px) {
	.sec4 .title {
		margin-bottom: 30px;
	}
}

.sec4 .title-en:after,.sec4 .title-en:before {
	background: #fff;
}

.sec4 .titlesub {
	margin-bottom: 60px;
	color: #fff;
}

.sec4 .col-inner {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-ms-flex-pack: center;
	justify-content: center;
}

.sec4-each {
	position: relative;
	width: 216px;
	margin: 0 15px 20px;
	color: #fff;
}

@media screen and (max-width:640px) {
	.sec4-each {
		clear: both;
		width: 100%;
	}
}

.sec4-each:nth-child(1) {
	margin-left: 0;
}

.sec4-each:nth-child(4) {
	margin-right: 0;
}

.sec4-img {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin-bottom: 15px;
}

@media screen and (max-width:640px) {
	.sec4-img {
		float: left;
		max-width: 180px;
		width: 40%;
		margin-right: 10px;
	}
}

@media screen and (max-width:640px) {
	.sec4-img img {
		width: 100%;
	}
}

.sec4-icon {
	position: absolute;
	top: -10px;
	left: -10px;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-direction: column;
	flex-direction: column;
	width: 70px;
	height: 70px;
	border-radius: 50%;
	background: #327600;
	font-family: "Crimson Text",serif;
	font-weight: 700;
}

@media screen and (max-width:640px) {
	.sec4-icon {
		width: 35px;
		height: 35px;
	}
}

.sec4-icon span:first-child {
	font-size: 12px;
}

@media screen and (max-width:640px) {
	.sec4-icon span:first-child {
		font-size: 7px;
	}
}

.sec4-icon span:last-child {
	font-size: 30px;
}

@media screen and (max-width:640px) {
	.sec4-icon span:last-child {
		font-size: 14px;
	}
}

.sec4-title {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	height: 2em;
	margin-bottom: 10px;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
	line-height: 1.4;
}

@media screen and (max-width:640px) {
	.sec4-title {
		-ms-flex-pack: start;
		justify-content: flex-start;
		height: auto;
		margin-bottom: 6px;
		font-size: calc(100% + 1vw);
		text-align: left;
	}
}

.sec4-paraph {
	font-size: 15px;
	font-weight: 700;
	line-height: 1.4;
}

@media screen and (max-width:640px) {
	.sec4-paraph {
		font-size: calc(70% + 1vw);
		font-weight: 400;
	}
}

.footer {
	padding: 7px 0;
	background: #2673bf;
}

.footer .col-inner {
	-ms-flex-pack: center;
	justify-content: center;
}

.footer-small {
	font-size: 12px;
	color: #2673bf;
}



.searchIndex-loopImage {
	overflow: hidden;
	height: 72px;
    position: relative;
}
@keyframes loopImage {
	0% {
			transform: translateX(0)
	}

	100% {
			transform: translateX(50%)
	}
}
.searchIndex-loopImage > ul {
	position: absolute;
	top: 0;
	right: 0;
	display: flex;
	flex-direction: row-reverse;
	will-change: transform;
}
.searchIndex-loopImage > ul.isLoop {
	animation: loopImage 60s linear infinite;
}
.searchIndex-loopImage > ul > li {
	flex: 0 0 150px;
	padding: 5px;
	text-align: center;
	margin: 0 2px;
	background: #fff;
}
.searchIndex-loopImage > ul > li img {
	max-width: 100%;
	width: auto;
}
.company__logo {
    height: auto;
    padding: 5px 0;
}
.searchIndex .isLoop{
	display: flex;
	width: fit-content;
	margin: auto;
	flex-wrap: wrap;
	height: auto;
	justify-content: center;
}
.keyvisual-points--first {
	bottom:142px;
	width: auto;
	margin-left: 48.5%;
}
.keyvisual-points--second {
	width: auto;
	bottom:0px;
}


@media screen and (max-width:640px) {
	.isLoop li {
		width: 25%;
	}
	.pointseach__box--sp {
		display: flex;
		justify-content: flex-end;
	}
	.keyvisual-pointseach {
		margin-top: 5px;
		width: 66px;
		height: 66px;
		font-size: 16px;
		border-radius: 66px;
	}
	.keyvisual-pointsbox {
		width: 100%;
	}
	.keyvisual-copy1 {
		margin-left: 0px;
	}
	.company__logo {
			padding: 0px 0;
	}
	.keyvisual-points--first {
		margin-left: 0;
		position: absolute;
		bottom: 0px;
		width: 84%;
		margin: 0 8%;
	}
}
.gnav {
	width: fit-content;
	margin-left: 3%;
}
.cv__box {
	position: absolute;
	bottom: 9%;
	width: 500px;
	left: 49%;
	display: flex;
}









.companylogo_pc img {
    display:block;
     padding-left: 485px;
     padding-top: 15px;
}

@media screen and (max-width: 640px){
.companylogo_pc img {
    display: none;
}}






.consult_pc {
	-ms-flex-pack: center;
	font-weight: 600;
	font-size: 19px;
	color: #000;
	line-height: 1.5;
	letter-spacing: 1px;
	padding-top: 20px;
	bottom: 66px;
	width: fit-content;
        padding-right: 10px;
}

@media screen and (max-width: 640px)
{.consult_pc {
    display: none;
}}
.consult_sp {
    display: none;
}
@media screen and (max-width: 640px)
{.consult_sp {
    color: #000;
    font-size: 3.3vw;
    display: inherit;
    line-height: 1.4;
    margin-top: 10px;
    font-weight: 600;
    text-align: left;
}}

.web_pc {
	-ms-flex-pack: center;
	font-weight: 600;
	font-size: 28px;
	color: #000;
	line-height: 1.5;
	bottom: 66px;
	width: fit-content;
        line-height: 1.3;
    text-decoration: underline;
    text-decoration-color: #FF0000;
    margin-left: 4.4%;
}

@media screen and (max-width: 640px)
{.web_pc {
    display: none;
}}
.web_sp {
    display: none;
}
@media screen and (max-width: 640px)
{.web_sp {
		color: #000;
		order: 2;
    font-size: 5.4vw;
    display: inherit;
    line-height: 1.6;
    font-weight: 700;
		text-align: left;
		margin-left: 13px;
    text-decoration: underline;
    text-decoration-color: #FF0000;
    padding-top: 10px;
}}






@media screen and (max-width: 640px)
{.keyvisual-main strong {
    color: #dcfc52;
    
}}



.companylogo_sp img {
    display: none;
}

@media screen and (max-width: 640px) {
.companylogo_sp img {
    display:block;
}}


.companylogo_pc {
    display: -ms-flexbox;
    display: flex;
    width: 1100px;
    margin: auto;
}


.keyvisual-undercopy {
    position: absolute;
    -ms-flex-pack: center;
    font-weight: 700;
    font-size: 18px;
    color: #001647;
    line-height: 1.5;
    letter-spacing: 1px;
    width: 600px;
    left: -70px;
    text-shadow: 0 0 20px #fff;
    text-align: center;
}
@media screen and (max-width: 640px)
{.keyvisual-undercopy {
    display: none;
}}

.title_sub {
    display: none;
}
@media screen and (max-width: 640px)
{.title_sub {
    font-size: 3.1vw;
    display: inherit;
   line-height: 1.3;
}}

.keyvisual-main {
    display: none;
}

@media screen and (max-width: 640px)
{.keyvisual-main {
    font-weight: 700;
    display: inherit;
    text-align: left;
    line-height: 1.2;
    font-size: 9.5vw;
		font-family: serif;
		text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF,-1px 1px 0 #FFF, 1px -1px 0 #FFF,0px 1px 0 #FFF, 0-1px 0 #FFF,-1px 0 0 #FFF, 1px 0 0 #FFF;
}}

p.company_logo{
text-align: center;
}

@media (max-width: 640px) {
  .logo_pc {
    display: none;
}}


@media (min-width: 641px) {
  .logo_sp {
     display: none;
  }
}



.address {
    letter-spacing: .03em;
    line-height: 1.5;
    color: #fff;
}
@media screen and (max-width: 640px)
{.address {
    display: none;
    color: #fff;
}}

.copy {
    letter-spacing: .03em;
    margin-top: 7px;
    text-align: center;
    color: #fff;
}


.address_sp {
    display: none;
    color: #fff;
}

@media screen and (max-width: 640px)
{.address_sp {
   letter-spacing: .03em;
    line-height: 1.5;
    display: inherit;
}}




/* 2019.03.25 スライド式EF追加 */
.main {
	padding-top: 60px;
}
.stepHide.is-show {
	animation: none;
}
#lp_entryForm {
    background: #f0f0f0;
    min-height: 100%;
    padding-bottom: 80px;
}
#lp_entryForm h2 {
    padding: 0px 0 25px;
    text-align:center;
}
.ent_stepWrap, #ent_contentWrap, .ent_stepWrap p {
    background:#f0f0f0;
}
#lp_entryForm #ef-container {
	background-color:#f0f0f0;
}
#lp_entryForm .ent_stepWrap h2{
    background:url(../../common/images/contents/agnet_entry_title01.webp) no-repeat center 25px;
    margin:0 auto;
    padding:25px 0;
    width:413px;
    height:151px;
    display:block;
}
.spOnly {
    display:none;
}
@media screen and (max-width: 640px) {
.main {
	padding-top: 0px;
}
.keyvisual {
	margin-top: 50px;
}
.stepHide.is-show {
	animation: none;
}
#lp_entryForm {
	margin-bottom: 10px;
	padding-bottom: 0px;
        margin-top: -20px;
       
}
#lp_entryForm .ent_stepWrap h2{
	padding: 0;
	margin: 0;
	display: none;
}
.spOnly {
    display:block;
}
#lp_entryForm .ent_stepWrap .incHeader {
background-image: none;
background-color: #2673bf;
padding: 10px 0;
margin: 20px 0 0;
font-size:1.2em;
font-weight: bold;
color: #fff !important;
text-align: center;
}
.footer {
	margin: 0;
}
}






@media screen and (min-width: 650px){	
  .br-pc { display:block; }
  .br-sp { display:none; }
}
@media screen and (max-width: 650px){	
  .br-pc { display:none; }
  .br-sp { display:block; }
}

.fulltime > h2 { font-size: 20px; font-size: 30px; color: #fff; width: 100%; position: relative; background: #2b762d; padding: 10px 10px 10px 10px; position: relative; text-align: center; }
@media screen and (max-width: 640px)
{.fulltime > h2 {
    padding: 10px 0;
    font-size: calc(80% + 2.5vw);
    
}}


.bdrBox {
    overflow: hidden;
    position: relative;
    width: 1200px;
    padding: 20px 0 0;
    margin-right: auto;
    margin-bottom: 0px;
    margin-left: auto;
    background: #fff;
    margin-bottom: 3px;
    margin-top: 20px;
}
@media screen and (max-width: 640px)
{.bdrBox {
    width: 345px;
   padding-top: 5px;
  margin-bottom: 25px;
}}


.leftright {
    width: 100%;
}


.vlist ul.left {
    width: 570px;
    margin-left: 19px;
}
@media screen and (max-width: 640px)
{.vlist ul.left {
    width: 400px;
   margin-left: -1px;
}}


@media screen and (max-width: 640px)
vlist ul.left > li > div {
    width: 55px;
    font-size: calc(80% + 1vw);
    
}

ul {
    list-style: none;
}

.fulltime .vlist ul > li {
    border-bottom: 2px dotted #68b2d9;
}

.vlist ul > li {
    position: relative;
    overflow: hidden;
    border-bottom: 2px dotted #68b2d9;
    padding-bottom: 10px;
    margin-bottom: 10px;
}

.vlist ul.left > li > div {
    width: 70px;
}

.sec2 section ul > li > div {
    color: #68b2d9;
}

.vlist ul > li > div {
    font-size: 48px;
    font-size: 5.1rem;
    float: left;
    text-align: center;
    padding-top: 12px;
    color: #68b2d9;
   }
@media screen and (max-width: 640px)
{.vlist ul > li > div {
    font-size: calc(80% + 8vw);
    padding: 15px 0 4px 5px;
}}

.vlist ul.left > li > p {
    width: 500px;
}
@media screen and (max-width: 640px)
{.vlist ul.left > li > p {
    font-size: 13px;
    line-height: 1.4em;
    width: 260px;
    padding: 5px 0 0 3px;
}}


.vlist ul > li > p {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.75;
    float: left;
    padding-top: 4px;
}

.vlist ul > li > p span {
    background: #fffb95;
}

.vlist ul > li > p strong {
    font-weight: bold;
    font-size: 1.5rem;
}
@media screen and (max-width: 640px)
.vlist ul > li > p strong {
    font-weight: bold;
    font-size: 1.3rem;
}

.vlist ul.right {
    width: 570px;
   margin-left: 22px;
}
@media screen and (max-width: 640px)
{.vlist ul.right {
    width: 400px;
   margin: auto;
   padding-top: 0;
}}

.vlist ul {
    float: left;
   padding-top: 25px;
    position: relative;
}
@media screen and (max-width: 640px)
{.vlist ul {
    padding-top: 15px;
}}

.vlist ul > li {
    position: relative;
    overflow: hidden;
    border-bottom: 2px dotted #68b2d9;
    padding-bottom: 10px;
    margin-bottom: 10px;
}
@media screen and (max-width: 640px)
{.vlist ul > li {
    padding-bottom: 5px;
    margin-bottom: 5px;
}}



.vlist ul.right > li > div {
    width: 70px;
}

.vlist ul.right > li > p {
    width: 500px;
}
@media screen and (max-width: 640px)
{.vlist ul.right > li > p {
    font-size: 13px;
    line-height: 1.4em;
    width: 260px;
}}

.vlist ul > li > p {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.75;
    float: left;
    padding-top: 4px;
}

.fulltime .vlist ul > li {
    border-bottom: 2px dotted #68b2d9;
}

.attention {
    float: left;
    width: 100%;
    padding-top: 25px;
    padding-bottom: 25px;
}


.sec2 section .attention p.bgRadius {
    background: #2b762d;
}

.attention p.bgRadius {
    color: #fff;
    font-weight: normal;
    line-height: 49px;
    width: 660px;
    height: 49px;
    margin: 0 auto;
    text-align: center;
    letter-spacing: 1px;
    background: #005faf;
}

@media screen and (max-width: 640px)
{.attention p.bgRadius {
    width: 350px;
    line-height: 25px;
　　height: 55px;
}}

.attention p {
    color: #ff4f1c;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: bold;
    text-align: center;
    margin-top: 25px;
}
@media screen and (max-width: 479px) {
	.attention p { font-size: 1.6rem; }
}

.attention p br {
    display: none;
}
@media screen and (max-width: 640px) {
.attention p br { display: inline;}


.sec2 {
    padding: 30px 0 0;
}