@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,400;0,500;0,600;1,400;1,500;1,600&display=swap');
/* reset
-------------------------------------------------------*/
body,div,dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
pre,code,form,fieldset,legend,
p,blockquote,table,th,td, figure, section, article {margin: 0; padding: 0;}
body {font:13px/1 'Noto Sans JP', "Yu GothicM", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;}
* html body {font-size: small;}
*:first-child+html body {font-size: small;}
img {border: 0; vertical-align: top;}
h1,h2,h3,h4,h5,h6 {font-size: 100%; font-weight: normal;}
ul,dl,ol {text-indent: 0;}
li {list-style: none;}
address,caption,cite,code,dfn,em,strong,th,var {font-style: normal; font-weight: normal;}
sup {vertical-align: text-top;}
sub {vertical-align: text-bottom;}
input,textarea,select {font-family: inherit; font-size: inherit; font-weight:inherit;}
* html input,* html textarea,* html select {font-size: 100%;}
*:first-child+html+input,*:first-child html+textarea,*:first-child+html select {font-size: 100%;}
table {border-collapse: collapse; border-spacing: 0; font-size: inherit;}
th,td {text-align: left; vertical-align: top;}
caption {text-align: left;}
pre,code,kbd,samp,tt {font-family: monospace;}
* html pre,* html code,* html kbd,* html samp,* html tt {font-size: 100%; line-height: 100%;}
*:first-child+html pre,*:first-child html+code,*:first-child html+kbd,*:first-child+html+samp,*:first-child+html tt {font-size: 108%; line-height: 100%;}
input,select,textarea {font-size: 100%; font-family: Verdana, Helvetica, sans-serif;}
*:focus {outline: none;}

/* base
-------------------------------------------------------*/
*{
	box-sizing:border-box;
}
html { font-size: 62.5%; }
body {
	letter-spacing:0.03em;
}
strong {
	font-weight:bold;
}
a {
	color:#000;
	text-decoration:none;
}
a:hover {
}
.clearfix:after {
	content:"";
	display:block;
	clear:both;
	height:100%;
}
.clear {
	clear:both;
}
.al-center {
	text-align:center;
}
.f-left {
	float:left;
}
.f-right {
	float:right;
}
br.pchide{
  display: none;
}
img{
  max-width: 100%;
  height: auto;
}
img.pc{
  display: inline-block;
}
img.sp{
  display: none;
}
br.pc{
  display: inline;
}
br.sp{
  display: none;
}
.alright{
  text-align: right;
}
.fadein{
  opacity: 0;
  position: relative;
  top: 50px;
  transition: all 1s ease;
}
.fadein.active{
  opacity: 1;
  top: 0;
}
span.ico_blank:after{
	content: "";
	display: inline-block;
	width: 11px;
	height: 11px;
	background: url("../img/ico_blank.svg") no-repeat;
	background-size: contain;
	margin-left: 5px;
}
span.ico_blank.large:after{
	width: 15px;
	height: 15px;
}
span.ico_blank.white:after{
	background-image: url("../img/ico_blank_white.svg");
}
span.ico_blank.green:after{
	background-image: url("../img/ico_blank_green.svg");
}
ul.textnav{
	display: flex;
}

/* header
-----------------------------------------------------*/
body#top{
	padding-top: 0;
}
body{
	padding-top: 70px;
}
header{
	height: 70px;
	background: #fff;
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 20;
}
header #logo{
	font-family: 'Jost', sans-serif;
	display: flex;
	align-items: center;
	padding-left: 30px;
}
header #logo img{
	width: 208px;
	height: auto;
	margin-right: 15px;
}
header nav#global{
	height: 100%;
}
header nav#global > ul{
	display: flex;
	height: 100%;
}
header nav#global > ul > li > a,
header nav#global > ul > li > span{
	display: flex;
	height: 100%;
	align-items: center;
	justify-content: center;
	font-family: 'Jost', sans-serif;
	font-size: 1.5rem;
	padding: 0 18px;
}
header nav#global > ul > li > a:hover{
	color: #3cb3ad;
}
header nav#global > ul > li > span{
	color: #b2b2b2;
}
header nav#global > ul > li.bg{
	width: 110px;
}
header nav#global > ul > li.bg a{
	color: #fff;
}
header nav#global > ul > li.bg.entry{
	background: #3cb3ad;
	margin-left: 125px;
}
header nav#global > ul > li.bg.entry .megamenu{
	background: #3cb3ad;
}
header nav#global > ul > li.bg.entry .megamenu a:hover{
	color: #fff;
}
header nav#global > ul > li.entry span.ico_blank:after{
	background-image: url("../img/ico_blank_white.svg");
}
header nav#global > ul > li.bg.mypage a{
	background: #0b0103;
	transition: background 0.3s ease;
}
header nav#global > ul > li.bg.mypage a:hover{
	background: #666;
}
header nav#global .megamenu{
	position: absolute;
	top: 70px;
	left: 0;
	width: 100%;
	background: rgba(255,255,255,0.9);
	display: flex;
	justify-content: center;
	padding: 30px 0;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
	z-index: 20;
}
header nav#global > ul > li:hover .megamenu{
	opacity: 1;
	visibility: visible;
}
header nav#global .megamenu ul.imgnav{
	display: flex;
}
header nav#global .megamenu ul.imgnav li{
	text-align: center;
}
header nav#global .megamenu ul.imgnav li + li{
	margin-left: 50px;
}
header nav#global .megamenu ul.imgnav li .img {
	display: block;
	margin-bottom: 20px;
}
header nav#global .megamenu ul.imgnav li .img img{
	width: 150px;
}
header nav#global .entry .megamenu ul.imgnav li .img img{
	width: 204px;
}
header nav#global .megamenu dl{
	margin-left: 75px;
}
header nav#global .megamenu dl dt{
	font-size: 1.4rem;
	margin-bottom: 1em;
	font-weight: 500;
}
header nav#global .megamenu dl dd{
	font-size: 1.3rem;
	margin-top: 1.5em;
}
header nav#global .megamenu dl dd:before{
	content: '';
	display: inline-block;
	width: 14px;
	height: 2px;
	background: #000;
	margin-right: 5px;
	vertical-align: middle;
}
header nav#global .megamenu a{
	color: #000;
	transition: color 0.3s ease;
}
header nav#global .megamenu a:hover {
	color: #3cb3ad;
}
.menubtn{
	display: none;
}
header nav#global > ul > li.haschild span.ico{
	display: none;
}
header nav#global .megamenu ul.teamnav{
	display: flex;
}
header nav#global .megamenu ul.teamnav li{
	width: 300px;
}
header nav#global .megamenu ul.teamnav li + li{
	margin-left: 25px;
}
header nav#global .megamenu ul.teamnav li .imgtxt{
	display: flex;
	align-items: center;
}
header nav#global .megamenu ul.teamnav li .imgtxt img{
	width: 129px;
	height: auto;
}
header nav#global .megamenu ul.teamnav li .imgtxt .text{
	padding-left: 20px;
}
header nav#global .megamenu ul.teamnav li .imgtxt .text .jost{
	font-size: 1.6rem;
	font-weight: 500;
	font-style: italic;
}
header nav#global .megamenu ul.teamnav li .imgtxt .text .jost + p{
	font-size: 1.4rem;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	line-height: 1.5em;
	margin-top: 0.5em;
}
header nav#global .megamenu ul.teamnav li .label{
	margin: 15px 0;
	opacity: 1;
	transition: opacity 0.3s ease;
}
header nav#global .megamenu ul.teamnav li a:hover .label{
	opacity: 0.6;
}
header nav#global .megamenu ul.teamnav li .label span:first-child{
	font-size: 2rem;
}
header nav#global .megamenu ul.teamnav li .label{
	font-size: 1.3rem;
}
header nav#global .megamenu ul.teamnav li .label span.en{
	font-size: 1rem;
}
header nav#global .megamenu ul.teamnav li .label + p{
	font-size: 1.2rem;
	text-align: center;
	line-height: 2rem;
	white-space: nowrap;
	letter-spacing: normal;
}
header nav#global .megamenu ul.teamnav li:nth-child(2) .label + p{
	margin-left: -1em;
}
header nav#global .megamenu ul.peoplenav{
	display: flex;
	justify-content: center;
}
header nav#global .megamenu ul.peoplenav li{
	text-align: center;
}
header nav#global .megamenu ul.peoplenav li + li{
	margin-left: 25px;
}
header nav#global .megamenu ul.peoplenav li .img img{
	width: 150px;
	height: auto;
}
header nav#global .megamenu ul.peoplenav li .jost{
	font-size: 2.2rem;
	font-weight: 600;
	font-style: italic;
	margin: 10px 0 8px 0;
}
header nav#global .megamenu ul.peoplenav li .jost img{
	width: 103px;
	height: auto;
	vertical-align: -1px;
	margin: 0 2px 0 4px;
}
header nav#global .megamenu ul.peoplenav li .jost + p{
	font-weight: 500;
	font-size: 1.7rem;
	line-height: 1.5em;
}
header nav#global .megamenu ul.peoplenav li .jost + p small{
	display: block;
	font-size: 1.2rem;
	line-height: 1.4em;
	font-weight: normal;
	margin-bottom: 5px;
}
header nav#global .megamenu ul li a span.imghover{
	position: relative;
	display: inline-block;
	width: 109px;
	height: 17px;
	z-index: 1;
	display: none;
}
header nav#global > ul > li:hover .megamenu ul li a span.imghover{
	display: inline-block;
}
header nav#global .megamenu ul li a span.imghover img:last-child{
	visibility: hidden;
	opacity: 0;
	transition: all 0.3s ease;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
header nav#global .megamenu ul li a:hover span.imghover img:last-child{
	opacity: 1;
	visibility: visible;
}
header nav#global .megamenu ul li a span.imghover img:first-child{
	transition: all 0.3s ease;
	visibility: visible;
	opacity: 1;
	position: absolute;
	top: 0;
	left: 0;
}
header nav#global .megamenu ul li a:hover span.imghover img:first-child{
	visibility: hidden;
	opacity: 0;
}
header nav#global .megamenu li a img:hover{
	opacity: 1;
}
header nav#global .megamenu li a:hover img{
	opacity: 0.6;
	width: 100px;
}
header #headersns{
  position: absolute;
  top: 23px;
  right: 145px;
	display: flex;
	align-items: center;
}
header #headersns a + a{
	margin-left: 28px;
}
@media only screen and (max-width: 1180px) {
	header #logo{
		display: block;
	}
	header #logo img{
		width: 180px;
	}
	header #logo span{
		display: block;
		margin-top: 7px;
	}
}

/* footer
-----------------------------------------------------*/
footer{
}
footer .copy{
	padding: 100px 0 50px 0;
}
footer .copy p:first-child{
	font-family: 'Jost', sans-serif;
	font-weight: 600;
	font-style: italic;
	text-align: center;
	font-size: 3.2rem;
	margin-bottom: 20px;
}
footer .copy p:last-child{
	font-family: 'Jost', sans-serif;
	font-style: italic;
	text-align: center;
	font-size: 1.9rem;
}
footer nav#row01{
	display: flex;
	justify-content: center;
}
footer nav#row01 dl.disabled{
	color: #b2b2b2;
}
footer nav#row01 dl + dl{
	margin-left: 25px;
}
footer nav#row01 dt{
	font-family: 'Jost', sans-serif;
	font-size: 1.6rem;
	margin-bottom: 0.5em;
}
footer nav#row01 dd{
	line-height: 1.5em;
	text-indent: -6px;
	padding-left: 13px;
}
footer nav#row01 dd:before{
	content: "■";
	display: inline-block;
	width: 6px;
	font-size: 0.5rem;
	vertical-align: middle;
}
footer nav#row01 dd a:hover{
	color: #666;
}
footer #row02{
	background: #f4f3f0;
	text-align: center;
	padding: 30px 0;
	margin-top: 60px;
}
footer #row02 p.links{
	font-size: 1.2rem;
}
footer #row02 p.links a{
	display: inline-block;
	margin: 0 1em;
}
footer #row02 p.links a:hover{
	color: #666;
}
footer #row02 .logo{
	margin: 50px 0 30px 0;
}
footer #row02 .logo img{
	width: 233px;
}
footer #row02 .copyright{
	font-size: 1rem;
}

/* common
-----------------------------------------------------*/
a img{
  opacity: 1;
  transition: opacity 0.5s ease;
}
a img:hover{
  opacity: 0.6;
}
a.btn{
	background: #0b0103;
	display: inline-block;
	position: relative;
	color: #fff;
	height: 48px;
	line-height: 48px;
}
a.btn span.txt{
	display: inline-block;
	padding: 0 15px;
	position: relative;
	height: 48px;
	overflow: hidden;
}
a.btn span.txt span{
	position: relative;
	z-index: 1;
}
a.btn span.txt:before,
a.btn span.ico:before{
	content: "";
	display: block;
	height: 48px;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	background: #3cb3ad;
	transition: all 0.3s ease;
	transform: translateX(0);
	animation: mouseleave 0.3s forwards;
}
a.btn span.ico:before{
	background: #000;
}
a.btn:hover span.txt:before,
a.btn:hover span.ico:before{
	animation: mouseenter 0.3s forwards;
}
a.btn span.ico{
	display: inline-block;
	width: 48px;
	height: 48px;
	background: #3cb3ad;
	overflow: hidden;
	position: relative;
	text-align: center;
}
a.btn span.ico img{
	position: relative;
	z-index: 1;
	vertical-align: -5px;
}
a.btn span.ico:before{
}
@keyframes mouseenter {
	0% {
		transform: translateX(-100%);
	}
	100% {
		transform: translateX(0);
	}
}
@keyframes mouseleave {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(101%);
	}
}
a.btn02{
	background: #fff;
	display: inline-block;
	padding: 10px 15px;
	color: #3cb3ad;
	font-size: 1.5rem;
	opacity: 1;
	transition: opacity 0.3s ease;
}
a.btn02:hover{
	opacity: 0.6;
}
a.btn02 + a.btn02{
	margin-left: 15px;
}
a.btn.btnreverse{
	background: #3cb3ad;
}
a.btn.btnreverse{
}
a.btn.btnreverse span.txt:before{
	background: #000;
}

/* top
-----------------------------------------------------*/
html,body{
	height: 100%;
}
#topvisual{
	height: calc(100% - 70px);
	position: relative;
	margin-top: 70px;
}
#topvisual #copy{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	background: #f4f3f0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
	opacity: 1;
	visibility: visible;
	transition: all 0.3s ease;
}
#topvisual #copy.hide{
	opacity: 0;
	visibility: hidden;
}
#topvisual #copy p{
	font-size: 13vw;
	font-family: 'Jost', sans-serif;
	font-weight: 600;
	font-style: italic;
	color: #f4f3f0;
}
#topvisual #copy p span{
	display: inline-block;
	position: relative;
	margin-bottom: 10px;
}
#topvisual #copy p span:after{
	content: "";
	display: block;
	width: 0;
	height: 100%;
	background: #000;
	position: absolute;
	top: 0;
	left: 0;
	transition: width 0.4s ease;
}
#topvisual #copy p.active01 span:after{
	width: 100%;
}
#topvisual #copy p.active02{
	color: #000;
}
#topvisual #copy p.active02 span:after{
	left: auto;
	right: 0;
	width: 0;
}
#topvisual #copy p .span01:after{
	transition-delay: 0;
}
#topvisual #copy p .span02:after{
	transition-delay: 0.3s;
}
#topvisual #copy p .span03:after{
	transition-delay: 0.6s;
}
#topvisual #sliderpro .sp-slide .text{
	position: absolute;
	z-index: 1;
}
#topvisual #sliderpro .sp-slide.slide01 .text{
	top: 50%;
	right: 15vw;
	transform: translate(0, -50%);
}
#topvisual #sliderpro .sp-slide.slide02 .text{
	top: 50%;
	left: 15vw;
	transform: translate(0, -50%);
}
#topvisual #sliderpro .sp-slide.slide03 .text{
	top: 60%;
	right: 15vw;
	transform: translate(0, -50%);
}
#topvisual #sliderpro .sp-slide.slide04 .text{
	top: 45%;
	right: 26vw;
	transform: translate(0, -50%);
}
#topvisual #sliderpro .sp-slide .bg{
	width: 100%;
	height: 100%;
	background: #fff;
	overflow: hidden;
}
#topvisual #sliderpro .sp-slide .bg img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#topvisual #sliderpro .sp-slide .bg img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1);
	transition: transform 13s linear;
}
#topvisual #sliderpro .sp-slide.sp-selected .bg img{
	transform: scale(1.2);
}
#topvisual .scrollbtn{
	position: absolute;
	right: -90px;
	bottom: 110px;
	transform: rotate(90deg);
	transform-origin: top left;
}
#topvisual .scrollbtn a{
	color: #fff;
	font-family: 'Jost', sans-serif;
}
#topvisual .scrollbtn span.line{
	content: "";
	display: inline-block;
	width: 55px;
	height: 1px;
	vertical-align: 4px;
	margin-left: 20px;
	position: relative;
	overflow: hidden;
}
#topvisual .scrollbtn span.line:before{
	content: "";
	display: inline-block;
	background: #fff;
	width: 55px;
	height: 1px;
	position: absolute;
	top: 0;
	left: 0;
	animation: scrollbtn 1.2s infinite;
}
@keyframes scrollbtn {
	0% {
		transform: translateX(0);
	}
	80%,100% {
		transform: translateX(100%);
	}
}
.mincho{
	font-family: 'Noto Serif JP', serif;	
}
.mincho02{
	font-family :"游明朝", YuMincho,"ヒラギノ明朝 Pr6 W6","Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝","MS PMincho", serif !important;
	font-feature-settings: "palt";
	font-weight: 500;
	letter-spacing: 0.05em;
}
.jost{
	font-family: 'Jost', sans-serif;
}
#toplead{
	text-align: center;
	padding: 140px 20px;
}
#toplead .jost{
	font-size: 8rem;
	font-weight: 600;
	font-style: italic;
}
#toplead h1.mincho{
	font-size: 2.7rem;
	font-weight: 500;
	margin-top: 30px;
	margin-bottom: 50px;
}
.personlayout{
	position: relative;
	padding: 80px 0;
	overflow: hidden;
}
.personlayout .bg{
	position: absolute;
	top: 0;
	left: -100%;
	background: #b2e1df;
	width: 85%;
	height: 100%;
	z-index: -1;
	overflow: hidden;
	transition: left 0.5s ease;
}
.personlayout.active .bg{
	left: 0;
}
.personlayout .bg:after{
	content: "";
	display: block;
	width: 500px;
	height: 3000px;
	position: absolute;
	top: -70px;
	right: -250px;
	background: #fff;
	transform: rotate(-345deg);
	transform-origin: top left;
}
.personlayout .inner{
	position: relative;
	padding-left: 100px;
}
.personlayout .inner .text .jost{
	font-weight: 600;
	font-style: italic;
	font-size: 7.5rem;
	margin-top: 4vw;
	margin-top: 10px;
}
.personlayout .inner .img{
	width: 55%;
	float: right;
	background: #fff;
}
.personlayout .inner .text{
	position: relative;
	z-index: 1;
	float: left;
	width: 45%;
}
.personlayout .inner .links{
	float: left;
}
.personlayout .inner .text h2{
	font-size: 3.5rem;
	font-weight: 500;
	white-space: nowrap;
	margin-top: 1em;
	margin-bottom: 0.75em;
	font-feature-settings: "palt";
}
#topbusiness.personlayout .inner .text h2{
	white-space: nowrap;
}
#topmessage.personlayout .inner .text h2{
	/*white-space: normal;*/
}
.personlayout .inner .text h2 + p{
	font-size: 1.5rem;
	line-height: 2em;
}
.personlayout .inner .btn{
	margin-top: 50px;
}
.personlayout .links .btnbox + .btnbox{
	margin-top: 30px;
}
#topteam{
	background: url("../../img/top/team_bg.jpg") no-repeat top 40px center;
	background-size: 100% auto;
	margin: 100px 0;
}
#topteam > .text{
	padding: 0 110px;
}
#topteam .sliderwrap{
	padding: 0 75px;
}
#topteam > .text h2.jost{
	font-size: 7.5rem;
	font-weight: 600;
	font-style: italic;
	text-align: right;
}
#topteam > .text p.mincho{
	text-align: right;
	font-size: 3.5rem;
	margin: 1em 0 0.5em 0;
}
#topteam > .text p.mincho + p{
	text-align: right;
	font-size: 1.5rem;
	line-height: 2;
}
#topteam .row{
	margin-top: 60px;
}
#topteam .row .col{
	padding: 0 35px;
}
#topteam .row .col .img{
	display: block;
	margin-bottom: 15px;
	background: #fff;
	overflow: hidden;
}
#topteam .row .col a:hover .img img{
	opacity: 1;
}
#topteam .row .col a .img img{
	transform: scale(1);
	transition: transform 0.5s linear;
}
#topteam .row .col a:hover .img img{
	transform: scale(1.1);
}
p.label{
	border: 1px solid #32cd32;
	color: #32cd32;
	display: flex;
	align-items: center;
	font-size: 1.6rem;
	line-height: 2em;
	font-weight: 500;
}
p.label span:first-child{
	background: #32cd32;
	color: #fff;
	font-size: 2.5rem;
	font-family: 'Jost', sans-serif;
	width: 50px;
	text-align: center;
	margin-right: 10px;
	font-weight: 400;
}
p.label.orange{
	border-color: #ff8c00;
	color: #ff8c00;
}
p.label.orange span:first-child{
	background: #ff8c00;
}
p.label.blue{
	border-color: #1e90ff;
	color: #1e90ff;
}
p.label.blue span:first-child{
	background: #1e90ff;
}
p.label span.en{
	font-family: 'Jost', sans-serif;
	font-size: 1.1rem;
	margin-left: auto;
	margin-right: 10px;
	font-weight: 400;
}
@media only screen and (max-width: 1330px) {
	p.label span.en{
		display: none;
	}
}
#topteam .row .col p.vol{
	text-align: center;
	color: #363636;
	font-weight: 500;
	font-style: italic;
	font-family: 'Jost', sans-serif;
	font-size: 2.3rem;
	margin: 1em 0;
}
#topteam .row .col h2{
	text-align: center;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 2.2rem;
	line-height: 1.5em;
}
#topteam .row .col h2 + p,
#topteam .row .col h2 + p + p,
#topteam .row .col .setheight p{
	text-align: center;
	line-height: 1.5em;
	font-size: 1.5rem;
	font-weight: 500;
	margin-top: 1em;
}
#topteam.teamnav .setheight{
	font-size: 1.5rem;
	height: 7.2em;
}
#interviewsliderwrap{
	z-index: 10;
	max-width: 900px;
	margin: auto;
}
#topinterview{
	padding: 0 110px;
	background: #f4f3f0;
	padding-bottom: 100px;
	padding-top: 1px;
	margin-top: 120px;
	position: relative;
	width: 100%;
}
#topinterview p.bg{
	font-size: 16vw;
	font-weight: 600;
	font-style: italic;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 0;
	color: #fff;
	overflow: hidden;
}
#topinterview > h2{
	font-weight: 600;
	font-size: 7.5rem;
	font-style: italic;
	margin-top: -38px;
	position: relative;
	z-index: 1;
}
#topinterview > h2 img{
	vertical-align: -4px;
}
#topinterview > h2 .textbox{
	display: inline-block;
	border: 3px solid #000;
	height: 0.75em;
	width: 280px;
	background: #fff;
	transform: skewX(-10deg);
	vertical-align: -4px;
}
#topinterview > h2 + p{
	line-height: 2em;
	font-size: 1.5rem;
	margin: 1em 0 2em 0;
	position: relative;
	z-index: 1;
}
#topinterview #interviewslider{
	position: relative;
	z-index: 1;
	max-width: 1300px;
	margin: auto;
}
#topinterview .col{
	padding: 0 10px;
}
#topinterview .col .img{
	position: relative;
}
@media only screen and (max-width: 1450px) {
	#topinterview .col .img{
		padding-bottom: 4.5vw;
	}
}
@media only screen and (max-width: 1150px) {
	#topinterview .col .img{
		padding-bottom: 5vw;
	}
}
#topinterview .col a:hover .img img{
	opacity: 1;
}
#topinterview .col .img p{
	position: absolute;
	right: 0px;
	bottom: 40px;
	font-size: 2rem;
	font-weight: 500;
}
#topinterview .col .img .hover{
	display: block;
	position: relative;
}
#topinterview .col .img .hover img:nth-child(1){
	opacity: 1;
	transition: opacity 0.5s ease;
}
#topinterview .col .img .hover img:nth-child(2){
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	transition: opacity 0.5s ease;
}
#topinterview .col a:hover .img .hover img:nth-child(1){
	opacity: 0;
}
#topinterview .col a:hover .img .hover img:nth-child(2){
	opacity: 1;
}
#topinterview .col.interview01 .img p{
	right: 0;
}
#topinterview .col.interview02 .img p{
	right: -3%;
}
#topinterview .col.interview03 .img p{
	right: 10%;
}
#topinterview .col.interview04 .img p{
	right: 10%;
}
#topinterview .col .img p small{
	font-size: 1.2rem;
	font-weight: 400;
	line-height: 1.25em;
	display: inline-block;
	margin-bottom: 0.5em;
}
#topinterview .col .jost{
	font-weight: 600;
	font-style: italic;
	font-size: 4rem;
}
#topinterview .col .jost img{
	vertical-align: baseline;
}
#topinterview .col a:hover .jost img{
	opacity: 1;
}
#topmessage{
	margin-top: 100px;
}
.personlayout.reverse .inner{
	padding-left: 0;
}
.personlayout.reverse .bg{
	left: auto;
	right: 0;
	width: 0;
	transition: width 0.3s ease;
}
.personlayout.reverse.active .bg{
	left: auto;
	right: 0;
	width: 100%;
}
.personlayout.reverse .bg:after{
	right: auto;
	left: -300px;
	top: -110px;
	transform: rotate(-15deg);
}
.personlayout.reverse .inner .img{
	float: left;
}
.personlayout.reverse .inner .text{
	float: right;
	padding-left: 50px;
	padding-right: 110px;
}
.personlayout.reverse .inner .text h2{
	line-height: 1.5em;
}
.personlayout.reverse .inner .btn{
	margin-left: 50px;
}
.personlayout .inner h2 + p.name{
	font-size: 2.8rem;
	font-weight: 500;
	line-height: normal;
}
.personlayout .inner .name small{
	font-size: 1.5rem;
	font-weight: 400;
}
section ul.imgnav{
	display: flex;
	justify-content: center;
}
section ul.imgnav li{
	width: 378px;
	font-size: 2.1rem;
	font-family: 'Noto Serif JP', serif;
	text-align: center;
}
section ul.imgnav li + li{
	margin-left: 20px;
}
section ul.imgnav li a span.img{
	display: block;
	overflow: hidden;
	margin-bottom: 20px;
}
section ul.imgnav li a span.img img{
	transform: scale(1);
	transition: transform 0.5s linear;
}
section ul.imgnav li a:hover span.img img{
	opacity: 1;
	transform: scale(1.1);
}
.sectionh3{
	padding: 100px 20px;
}
.sectionh3 h3{
	text-align: center;
	font-size: 4.8rem;
	font-weight: 600;
	font-family: 'Jost', sans-serif;
	font-style: italic;
}
.sectionh3 h3 + p{
	text-align: center;
	font-size: 1.5rem;
	line-height: 2em;
	margin-top: 1em;
	margin-bottom: 3em;
}
ul.bnrnav{
	display: flex;
	justify-content: space-between;
	max-width: 874px;
	flex-wrap: wrap;
	margin: auto;
}
ul.bnrnav li{
	width: 273px;
	text-align: center;
	font-size: 1.5rem;
}
ul.bnrnav li .img{
	display: block;
	margin-bottom: 20px;
}
ul.bnrnav li:last-child{
	margin: auto;
	margin-top: 40px;
}
#topentry{
	background: #f4f3f0;
}
#topentry .btn{
	width: 100%;
	height: 80px;
	line-height: 80px;
}
#topentry a.btn span.txt{
	height: 80px;
	width: 100%;
}
#topentry a.btn span.txt:before,
#topentry a.btn span.ico:before{
	width: 100%;
	height: 80px;
}
#topcsr{
	background: #b2e1df;
	padding: 80px 20px;
}
#topcsr h3{
	text-align: center;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 2.1rem;
	margin-bottom: 40px;
}
ul.textbnrnav{
	display: flex;
	justify-content: center;
}
ul.textbnrnav li{
	width: 273px;
}
ul.textbnrnav li + li{
	margin-left: 25px;
}
ul.textbnrnav li a{
	display: block;
	background: #fff;
	text-align: center;
	padding: 25px 0;
	font-size: 1.5rem;
	opacity: 1;
	transition: opacity 0.5s ease;
}
ul.textbnrnav li a:hover{
	opacity: 0.6;
}
/* message
-----------------------------------------------------*/
#message{
	background: url("../../img/message/bg.jpg") no-repeat bottom center;
	background-size: cover;
	text-align: center;
	padding-top: 100px;
	padding-bottom: 600px;
}
#message h1{
	margin-bottom: 70px;
}
#message h1 .jost{
	font-weight: 600;
	font-style: italic;
	font-size: 3.2rem;
	display: inline-block;
	margin-bottom: 20px;
}
#message h1 .mincho{
	font-size: 1.4rem;
}
#message p.text{
	font-family: 'Noto Serif JP', serif;
	font-size: 1.8rem;
	line-height: 2em;
}
#message p.text + p.text{
	margin-top: 2em;
}
#message > .jost{
	font-weight: 600;
	font-style: italic;
	font-size: 6.3rem;
	margin-top: 1.5em;
}
#message > .jost + p{
	font-family: 'Noto Serif JP', serif;
	font-size: 2.7rem;
	margin: 1em 0 3em 0;
}
#message .logo img{
	mix-blend-mode:multiply;
}
#message .delay{
	transition-delay: 0.5s;
}
/* top message
-----------------------------------------------------*/
.person_title{
	position: relative;
}
.person_title img{
	width: 100%;
}
.person_title h1{
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(0, -50%);
}
.person_title h1 .jost{
	font-size: 7.5rem;
	font-weight: 600;
	font-style: italic;
}
.person_title h1 .mincho{
	font-size: 1.4rem;
	display: inline-block;
	margin-top: 15px;
}
#top_message .content{
	max-width: 1110px;
	margin: auto;
	padding: 0 20px;
}
.content h2.center{
	text-align: center;
	font-family: 'Noto Serif JP', serif;
	font-size: 3.6rem;
	line-height: 1.5em;
	margin-top: 1.75em;
	margin-bottom: 0.5em;
}
.content h2.center + p{
	text-align: center;
	font-size: 3.2rem;
	margin-bottom: 120px;
	font-weight: 500;
}
#top_message .content > h2 + p .position{
	font-size: 1.4rem;
	font-weight: 400;
	display: inline-block;
	margin-bottom: 15px;
}
#top_message .content > h2 + p .en{
	font-size: 1.2rem;
	font-weight: 400;
}
#top_message .content section{
	display: flex;
	margin-top: 110px;
}
#top_message .content section.reverse{
	flex-direction: row-reverse;
}
#top_message .content section .img,
#top_message .content section .text{
	flex-basis: 0;
	flex-grow: 1;
}
#top_message .content section .text{
	margin-left: 40px;
	padding-right: 50px;
	padding-left: 20px;
}
#top_message .content section.reverse .text{
	margin-left: 0;
	margin-right: 40px;
	padding-right: 20px;
	padding-left: 50px;
}
#top_message .content section.reverse .img{
	padding-right: 0;
	padding-left: 0;
}
#top_message .content section .text h3{
	font-family: 'Noto Serif JP', serif;
	font-size: 2.7rem;
	line-height: 1.75em;
	margin-bottom: 0.5em;
}
#top_message .content section .text p{
	font-size: 1.5rem;
	line-height: 2em;
}
#top_message .footerimg img{
	width: 100%;
	margin-top: 170px;
}
/* business
-----------------------------------------------------*/
.img_title{
	position: relative;
}
.img_title img{
	width: 100%;
}
.img_title h1{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	color: #fff;
}
.img_title h1 .jost{
	font-size: 7.5rem;
	font-weight: 600;
	font-style: italic;
}
.img_title h1 .mincho{
	font-size: 1.4rem;
	display: inline-block;
	margin-top: 15px;
}
.sectionA{
	margin-left: auto;
	margin-right: auto;
}
.sectionA + .sectionA{
	margin-top: 100px;
}
.sectionA h2:first-child{
	margin-bottom: 70px;
}
.sectionA h3{
	text-align: center;
	font-family: 'Noto Serif JP', serif;
	font-size: 2.7rem;
	line-height: 1.75em;
	margin: 60px 0 30px 0;
}
.sectionA .img{
	max-width: 1000px;
	text-align: center;
	margin: 70px auto;
}
.sectionA > p{
	font-size: 1.5rem;
	line-height: 2em;
	max-width: 700px;
	margin: auto;
}
.sectionA .img.graph01{
	position: relative;
	max-width: 542px;
}
.graph01 h4{
	color: #00CD08;
	font-weight: bold;
	font-size: 2rem;
	margin-bottom: 10px;
}
.graph01 p.note{
	text-align: left;
	font-weight: bold;
	position: absolute;
	left: calc(100% + 20px);
	bottom: 27px;
	white-space: nowrap;
	line-height: 2em;
}
.graph01 p.note span:before{
	content: "";
	display: inline-block;
	width: 28px;
	height: 14px;
	background: #32cd32;
	margin-right: 10px;
	vertical-align: -2px;
}
.graph01 p.note span:last-child:before{
	background: #c73a2d;
}
.graph01 p.note span:first-child{
	color: #32cd32;
}
.graph01 p.note span:last-child{
	color: #c73a2d;
}
.socialrow{
	display: flex;
	justify-content: center;
	margin-top: 80px;
}
.socialrow .col{
	text-align: center;
}
.socialrow .col + .col{
	margin-left: 30px;
}
.socialrow .col .img{
	margin: 0;
}
.socialrow .col p{
	font-weight: 500;
	line-height: 1.5em;
	margin: 1em 0 2em 0;
}
.socialrow .col ul{
	max-width: 250px;
	margin: auto;
}
.socialrow .col ul li{
	background: #ffe9d1;
	font-size: 1.3rem;
	padding: 10px 0;
	font-weight: 500;
	line-height: 1.5em;
}
.socialrow .col ul li + li{
	margin-top: 10px;
}
#rla > h2:first-child{
	text-align: center;
}
#rla .btnbox{
	text-align: center;
	margin-top: 70px;
}
#rla .btnbox a.btn{
	width: 273px;
	height: 65px;
	line-height: 65px;
	font-size: 1.5rem;
	font-weight: 400;
	position: relative;
}
#rla a.btn span.txt,
#rla a.btn span.txt:before,
#rla a.btn span.ico:before{
	width: 273px;
	height: 65px;
}
.plusico{
	display: inline-block;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 25px;
	right: 5px;
}
.plusico:before,
.plusico:after{
	content: "";
	display: block;
	width: 20px;
	height: 1px;
	background: #3cb3ad;
	position: absolute;
	top: 10px;
	left: 0;
}
.plusico:after{
	transform: rotate(90deg);
	transition: all 0.2s linear;
}
a.active .plusico:after{
	transform: rotate(0deg);
}
#rla{
	padding-left: 20px;
	padding-right: 20px;
}
#rla a.btn span.txt span{
}
#rla a.btn .plusico{
	position: absolute;
	top: 22px;
	right: 17px;
}
#rla a.btn .plusico:before,
#rla a.btn .plusico:after{
	background: #fff;
}
#rla a .white:before{
	content: "READ MORE";
}
#rla a.active .white:before{
	content: "CLOSE";
}
#rlacontent{
	margin-top: 100px;
	display: none;
}
#rlacontent section{
	background: #fff;
	max-width: 960px;
	margin: auto;
}
#rlacontent section + section{
	margin-top: 100px;
}
#rlacontent section picture img{
	width: 100%;
	height: auto;
}
#rlacontent h3{
	text-align: center;
	font-size: 2.7rem;
	font-weight: bold;
	font-family: 'Noto Sans JP', "Yu GothicM", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;;
	margin-bottom: 50px;
}
#rlacontent h3:after{
	content: "";
	display: block;
	width: 85px;
	height: 2px;
	background: #000;
	margin: auto;
	margin-top: 20px;
}
#rlacontent h3 span.logo img{
	vertical-align: -17px;
	margin-right: 20px;
}
#rlacontent .rlasec01{
	padding: 60px 40px 40px 40px;
}
#rlacontent .rlasec02{
	padding: 60px 100px 100px 100px;
}
#rlacontent .rlasec02 img{
}
#rlacontent h4{
	text-align: center;
	font-weight: 600;
	color: #3cb3ad;
	font-size: 2.5rem;
	margin-bottom: 0.75em;
}
#rlacontent h4 + p{
	text-align: center;
	font-weight: bold;
	font-size: 1.7rem;
	line-height: 1.5;
	margin-bottom: 15px;
}
#rlacontent hr{
	display: block;
	width: 85px;
	height: 2px;
	background: #000;
	margin: 80px auto 70px auto;
	border: 0;
}
#rlacontent .magnifybtn{
	display: none;
}
#rlacontent .sp{
	display: none;
}


/* recruit
-----------------------------------------------------*/
#recruit{
	margin-bottom: 20px;
}
nav.pagelink{
	text-align: center;
	margin: 40px 0 30px 0;
}
nav.pagelink a{
	color: #3cb3ad;
	font-size: 1.5rem;
	border-bottom: 1px solid #3cb3ad;
	padding-bottom: 10px;
	opacity: 1;
	transition: opacity 0.3s ease;
}
nav.pagelink a:hover{
	opacity: 0.6;
}
nav.pagelink a:after{
  content: "";
  display: inline-block;
  width: 18px;
  height: 8px;
  vertical-align: middle;
  background: url("../img/ico_link_down.svg") no-repeat;
  background-size: contain;
	margin-left: 10px;
}
nav.pagelink a + a{
	margin-left: 2em;
}
.bg_title{
	position: relative;
	background: #a8dcda;
	padding: 60px 0;
}
.bg_title h1{
	text-align: center;
}
.bg_title h1 .jost{
	font-size: 5rem;
	font-weight: 600;
	font-style: italic;
}
.bg_title h1 .mincho{
	font-size: 2.1rem;
	display: inline-block;
	margin-top: 15px;
}
.sectionA hr{
	display: block;
	border: 0;
	background: #000;
	width: 85px;
	height: 2px;
	margin: 70px auto;
}
#recruit .content h3{
	font-size: 2.7rem;
}
.sectionA h3:first-child{
	margin-top: 0;
}
#recruit .sectionA h3.lead{
	font-size: 1.7rem;
	margin-bottom: 1em;
}
.sectionA h3.lead + h3{
	margin-top: 0px;
}
.sectionA.bg{
	padding: 100px 0;
	background: #f4f3f0;
}
.sectionA p + p{
	margin-top: 2em;
}
#recruit .sectionA h3.underline:after{
	content: "";
	display: block;
	border: 0;
	background: #000;
	width: 85px;
	height: 2px;
	margin: 20px auto;
}
#recruit .sectionA.bg figure{
	background: #fff;
	max-width: 960px;
	margin: 70px auto;
	text-align: center;
	padding: 60px 20px;
}
#recruit .row{
	display: flex;
	max-width: 960px;
	padding: 0 20px;
	margin: auto;
}
#recruit .row .col{
	flex-basis: 0;
	flex-grow: 1;
}
#recruit .row .col + .col{
	margin-left: 70px;
}
#recruit .row .col h4{
	color: #3cb3ad;
	font-weight: 600;
	font-size: 2.5rem;
	text-align: center;
}
#recruit .row .col h4:after{
	content: "";
	display: block;
	background: #3cb3ad;
	width: 80px;
	height: 1px;
	margin: 30px auto 35px auto;
}
#recruit .row .col p{
	font-size: 1.5rem;
	line-height: 2em;
}
#recruit .wrap{
	max-width: 900px;
	padding: 0 20px;
	margin: auto;
}
#recruit .wrap h4{
	color: #3cb3ad;
	font-weight: 600;
	font-size: 2.5rem;
	margin-top: 80px;
	margin-bottom: 30px;
}
#recruit table th,
#recruit table td{
	border-top: 1px solid #3cb3ad;
	padding: 20px 20px;
	line-height: 1.5em;
	font-size: 1.6rem;
}
#recruit table th{
	white-space: nowrap;
	background: #f4f3f0;
	font-weight: 600;
	color: #3cb3ad;
}
#recruit table td{
	font-weight: 500;
}
#recruit table td strong{
	font-weight: 500;
	font-size: 1.8rem;
}
#recruit table td small{
	font-size: 1.4rem;
	font-weight: 400;
}
#recruit table{
	border-bottom: 1px solid #3cb3ad;
}
#recruit ol.step li{
	display: flex;
	position: relative;
	background: #f4f3f0;
	line-height: 80px;
	font-size: 2.3rem;
	font-weight: 500;
}
#recruit ol.step li:after{
	bottom: -52px;
	left: 50%;
	border: solid transparent;
	content: "";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(60, 179, 173, 0);
	border-top-color: #3cb3ad;
	border-width: 20px;
	margin-left: -20px;
}
#recruit ol.step li:last-child:after{
	display: none;
}
#recruit ol.step li + li{
	margin-top: 45px;
}
#recruit ol.step li span.num{
	background: #3cb3ad;
	color: #fff;
	text-align: center;
	width: 260px;
}
#recruit ol.step li span.text{
	text-align: center;
	flex-grow: 1;
}
#recruit ol.step li:last-child span.text{
	background: #3cb3ad;
	color: #fff;
	border-left: 4px solid #f4f3f0;
}
#recruit p.note{
	font-size: 1.2rem;
	line-height: 1.5em;
	margin-top: 30px;
}
/* faq
-----------------------------------------------------*/
#faq .content{
	max-width: 900px;
	padding: 0 20px;
	margin: auto;
}
#faq h2{
	font-size: 2.7rem;
	font-weight: 600;
	color: #3cb3ad;
	border-bottom: 1px solid #3cb3ad;
	padding-bottom: 30px;
	margin-top: 80px;
}
#faq dl{
	border-bottom: 1px solid #3cb3ad;
	padding: 15px 0 25px 0;
}
#faq dl dt{
	font-size: 1.8rem;
	font-weight: 500;
	cursor: pointer;
}
#faq dl dt:hover{
	color: #666;
}
#faq dl dt,
#faq dl dd{
	position: relative;
	padding: 15px 0;
	padding-left: 70px;
}
#faq dl dt:before,
#faq dl dd:before{
	content: "Q";
	font-size: 1.4rem;
	display: inline-block;
	background: #3cb3ad;
	width: 30px;
	height: 30px;
	line-height: 30px;
	text-align: center;
	border-radius: 100px;
	color: #fff;
	border: 1px solid #3cb3ad;
	margin-left: -70px;
	margin-right: 38px;
	vertical-align: 10px;
	transform: translateY(10px);
}
#faq dl dd:before{
	content: "A";
	color: #3cb3ad;
	background: #fff;
}
#faq dl dd{
	font-size: 1.6rem;
	font-weight: 500;
	color: #3cb3ad;
	line-height: 1.5em;
}
#faq dl dd a{
	color: #3cb3ad;
}
#faq dl dt .ico{
	display: inline-block;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 25px;
	right: 5px;
}
#faq dl dt .ico:before,
#faq dl dt .ico:after{
	content: "";
	display: block;
	width: 20px;
	height: 1px;
	background: #3cb3ad;
	position: absolute;
	top: 10px;
	left: 0;
}
#faq dl dt .ico:after{
	transform: rotate(90deg);
	transition: all 0.2s linear;
}
#faq dl dt.active .ico:after{
	transform: rotate(0deg);
}
/* team
-----------------------------------------------------*/
#team{
	display: block;
	background: #f4f3f0;
}
#team .content{
	background: #fff;
	max-width: 1050px;
	margin: auto;
	position: relative;
	top: -150px;
}
#team p.label span.en{
	display: block;
}
#team #lead{
	margin: auto;
	padding: 60px 0 30px 0;
}
#team #lead .label{
	max-width: 325px;
	margin: auto;
}
#team #lead .jost{
	font-weight: 600;
	font-style: italic;
	text-align: center;
	font-size: 2.6rem;
	margin: 30px 0;
}
#team #lead h1{
	text-align: center;
	font-size: 4.4rem;
	line-height: 1.25em;
}
#team #lead h1 + p{
	font-size: 1.7rem;
}
#lead h3{
	text-align: center;
	font-size: 1.7rem;
	font-weight: 500;
	margin: 1.75em 0 2em 0;
	line-height: 1.75em;
}
#lead h3.flex{
	display: flex;
	justify-content: center;
}
#lead h3.flex span + span{
	margin-left: 2em;
}
#lead h3 + p{
	font-size: 1.5rem;
	line-height: 2em;
	max-width: 620px;
	margin: auto;
}
#lead ul.profile{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 35px;
}
#lead ul.profile.col3{
	max-width: 620px;
	margin-left: auto;
	margin-right: auto;
}
#lead ul.profile li{
	margin: 0 20px;
	text-align: center;
	color: #363636;
	margin-bottom: 30px;
	display: flex;
	flex-direction: column;
	justify-content: space-around;
}
#lead ul.profile li img{
	width: 140px;
	height: auto;
}
#lead ul.profile li .img + p{
	font-size: 1.2rem;
	line-height: 1.5em;
	margin-top: 20px;
	margin-bottom: 10px;
}
#lead ul.profile li h4{
	font-weight: 500;
	font-size: 2.3rem;
	margin: 10px 0 15px 0;
	margin-top: auto;
}
#lead ul.profile li h4 + p{
	font-size: 1.2rem;
}
#bg{
	background: #9fd9d6;
	padding: 60px 20px;
}
#bg .inner{
	display: flex;
	justify-content: center;
	max-width: 780px;
	margin: auto;
}
#bg .inner .col{
	background: #fff;
	flex-basis: 0;
	flex-grow: 1;
	padding: 30px 20px;
}
#bg .inner .col + .col{
	margin-left: 30px;
}
#bg .inner .col h3{
	text-align: center;
	color: #3cb3ad;
	font-weight: 600;
	font-size: 2.1rem;
}
#bg .inner .col h3:after{
	content: '';
	display: block;
	width: 60px;
	height: 1px;
	background: #3cb3ad;
	margin: 20px auto;
}
#bg .inner .col p{
	font-size: 1.3rem;
	line-height: 1.75em;
}
section.talkcontent{
	padding: 0 130px;
	margin: 90px 0;
}
.talkcontent figure{
	margin-bottom: 55px;
}
.talkcontent h2{
	font-size: 2.8rem;
	font-weight: 600;
	margin: 1em 0;
	position: relative;
	padding-left: 60px;
	line-height: 1.75em;
}
.talkcontent h2:before{
	content: "";
	display: inline-block;
	width: 42px;
	height: 1px;
	background: #000;
	position: absolute;
	top: 25px;
	left: 0;
}
.talkcontent .talk{
	display: flex;
	margin: 20px 0;
}
.talkcontent .talk .img{
	width: 77px;
	height: auto;
	flex-shrink: 0;
	margin-right: 30px;
	text-align: center;
	font-weight: 500;
	font-size: 1.4rem;
}
.talkcontent .talk .img img{
	margin-bottom: 5px;
}
.talkcontent .talk p{
	font-size: 1.5rem;
	line-height: 2em;
}
#topteam.teamnav{
	background-image: none;
	background-color: #f4f3f0;
	padding-top: 1px;
	padding-bottom: 70px;
	margin-top: 130px;
	position: relative;
	margin-bottom: 0;
}
#topteam.teamnav:after{
	content: "";
	display: block;
	height: 330px;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-image: url("../../img/team/otherteam_bg.jpg");
	background-size: cover;
	background-position: center center;
	z-index: 0;
}
#topteam.teamnav > .text h2.jost{
	text-align: center;
	margin-top: -36px;
	position: relative;
	z-index: 1;
}
#topteam.teamnav .sliderwrap{
	max-width: 830px;
	padding: 0;
	margin: auto;
	z-index: 1;
}

/* people
-----------------------------------------------------*/
.people_title img{
	width: 100%;
}
#people .bg{
	background: #f4f3f0;
	padding: 130px 0;
}
#people .title{
	background: #fff;
	max-width: 960px;
	margin: auto;
	margin-top: -130px;
	position: relative;
	z-index: 1;
	text-align: center;
	padding: 50px 20px 70px 20px;
}
#people .title .jost{
	font-size: 7.4rem;
	font-weight: 600;
	font-style: italic;
	margin-bottom: 45px;
}
#people .title .jost img{
	height: 54px;
	width: auto;
	vertical-align: -1px;
	margin: 0 15px;
}
#people .title .job{
	font-size: 1.4rem;
	line-height: 1.75em;
}
#people .title .name{
	font-size: 3.2rem;
	font-weight: 500;
	margin: 20px 0;
}
#people .title .name_en{
	font-size: 1.2rem;
	margin: 0.8em 0 1.2em 0;
}
#people .title .date{
	font-size: 1.3rem;
}
#people .title .text{
	font-size: 1.5rem;
	line-height: 2em;
	margin-top: 3em;
}
#people .content{
	max-width: 1110px;
	margin: auto;
	padding: 0 20px;
}
#people .content section{
	display: flex;
	margin-top: 110px;
}
#people .content section:first-child{
	margin-top: 0;
}
#people .content section.reverse{
	flex-direction: row-reverse;
}
#people .content section .img,
#people .content section .text{
	flex-basis: 0;
	flex-grow: 1;
}
#people .content section .text{
	margin-left: 40px;
	padding-right: 50px;
	padding-left: 20px;
}
#people .content section.reverse .text{
	margin-left: 0;
	margin-right: 40px;
	padding-right: 20px;
	padding-left: 50px;
}
#people .content section.reverse .img{
	padding-right: 0;
	padding-left: 0;
}
#people .content section .text h3{
	font-weight: 600;
	font-size: 3rem;
	line-height: 1.5em;
	margin-bottom: 0.75em;
}
#people .content section .text p{
	font-size: 1.5rem;
	line-height: 2em;
}
#people .footerimg img{
	width: 100%;
	margin-top: 170px;
}
#people .footerimg.mt img{
	margin-top: 140px;
}
#people #holiday{
	max-width: 1000px;
	padding: 0 20px;
	margin: auto;
	margin-top: 100px;
	color: #363636;
}
#people #holiday .jost{
	font-size: 4.5rem;
	font-weight: 600;
	font-style: italic;
	text-align: center;
}
#people #holiday .jost + p{
	text-align: center;
	font-size: 1.5rem;
	margin: 1.5em 0 70px 0;
}
#people #holiday .flex{
	display: flex;
}
#people #holiday .flex figure{
	background: #f4f3f0;
	padding: 20px 10px 40px 10px;
	width: 514px;
	flex-shrink: 0;
	margin-right: 60px;
}
#people #holiday .flex h4{
	font-size: 2rem;
	line-height: 1.75em;
	font-weight: 500;
}
#people #holiday .flex h4:after{
	content: "";
	display: block;
	height: 1px;
	background: #363636;
	margin: 20px 0;
}
#people #holiday .flex p{
	font-size: 1.5rem;
	line-height: 2em;
}
#people #holiday .flex.reverse{
	flex-direction: row-reverse;
}
#people #holiday .flex.reverse figure{
	margin-right: 0;
	margin-left: 60px;
}
#people #holiday .flex.vertical{
	max-width: 740px;
	margin: auto;
}
#people #holiday .flex.vertical figure{
	width: 360px;
}
#topinterview.peoplenav{
	margin-top: 165px;
}
#topinterview.peoplenav > .jost:first-child{
	margin-bottom: 40px;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}
#topinterview.peoplenav #interviewsliderwrap{
	max-width: 600px;
}









