@charset "UTF-8";
/*
	opening
-----------------------------------------------------------------------------------------------*/
#opening{
	align-items: center;
	animation: opening 1.3s ease-out 3.0s forwards;
	background: url("../images/bg_paper02.png") repeat #fefef6;
	display: flex;
	height: 100%;
	justify-content: center;
	position: fixed;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 999;
}
.opening__img{
	animation: opFade 0.8s ease .8s forwards;
	margin: 0 0 0 30px;
	opacity: 0;
	width: 200px;
}
.opening__txt{
	animation: opFade 1.2s ease 1.5s forwards;
	color: var(--red);
	font-size: 3.0rem;
	font-weight: var(--bold);
	letter-spacing: .5rem;
	line-height: 1.3;
	margin: 15px 0 0 0;
	opacity: 0;
	text-align: center;
}
#opening.is-active{
	opacity: 0;
	visibility: hidden;
}
/*
	animation
-----------------------------------------------------------------------------------------------*/
.intaview__item:nth-child(2).anmFadeUp.jsAnmStart{
	animation: anmFadeUp 1s ease .7s forwards;
}
/*
	common
-----------------------------------------------------------------------------------------------*/
.ctsArea{
	padding: 95px 30px;
}
/* リード文
============================== */
.corner__inner{
	background: rgba(233, 233, 218, .2);
	font-size: 2.0rem;
	padding: 40px 20px;
}
.corner__inner::before, .corner__inner::after, .corner__box::before, .corner__box::after{
	background: url(../images/deco_corner02.png) no-repeat top center/ cover;
}
/* h4
============================== */
.top-head{
	position: absolute;
	z-index: 1;
}
.top-head__inner{
	padding: 0 25px 0 0;
	position: relative;
}
.top-head__title{
	color: transparent;
	text-indent: -9999px;
	width: 85px;
	z-index: 1;
}
.top-head__sub{
	color: #c99300;
	font-size: 1.2rem;
	font-weight: var(--bold);
	left: 100%;
	letter-spacing: .5rem;
	margin-top: -7px;
	position: absolute;
	top: 0;
	transform: rotate(90deg);
	transform-origin: left;
	width: max-content;
}
/* work */
#work .top-head{
	position: static;
}
#work .top-head__title{
	background: url("../images/head_work01.png") no-repeat top left/ cover;
	height: 348px;
}
/* people */
#people .top-head{
	left: 30px;
	top: -40px;
}
#people .top-head__title{
	background: url("../images/head_people01.png") no-repeat top left/ cover;
	height: 278px;
}
/* environ */
#environ .top-head{
	left: -40px;
	top: -42px;
}
#environ .top-head__title{
	background: url("../images/head_environ01.png") no-repeat top left/ cover;
	height: 288px;
}
/* company */
#company .top-head{
	position: static;
}
#company .top-head__title{
	background: url("../images/head_company01.png") no-repeat top left/ cover;
	height: 340px;
}
/* recruit */
#recruit .top-head{
	left: 0;
	top: -40px;
}
#recruit .top-head__title{
	background: url("../images/head_recruit01.png") no-repeat top left/ cover;
	height: 282px;
}
/*
	kv
-----------------------------------------------------------------------------------------------*/
#kv{
	position: relative;
}
.slick__list{
	border-radius: 0 0 0 60px;
	height: 40vw;
	margin: 0 0 0 auto;
	max-height: calc(100vh - 260px);
	max-width: 1800px;
	min-height: 500px;
	min-width: 700px;
	overflow: hidden;
	position: relative;
	width: calc(100vw - 470px);
	z-index: 1;
}
.slick__item{
	display: inline-block;
	width: calc(25% - 8px);
}
.slick-slide img{
	z-index: -1;
}
/* progress bar */
.slider-dots{
	bottom: 20px;
	display: flex;
	justify-content: center;
	list-style: none;
	margin: 0;
	padding: 0;
	position: absolute;
	text-align: center;
	width: 100%;
}
.slider-dots button{
	background-color: rgba(255, 255, 255, .6);
	border: 0;
	font-size: 0;
	height: 3px;
	margin: 0 7px;
	position: relative;
	width: 180px;
}
.slider-dots button::after{
	content: '';
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 0%;
}
.slick-active button::after{
	background: #FFF;
}
.kv__copy{
	left: 80px;
	opacity: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
}
.top-kv__head{
	font-size: 6.8rem;
	font-weight: var(--black);
	letter-spacing: .3rem;
	line-height: 1.5;
}
.top-kv__sub{
	align-items: center;
	background: var(--red);
	border-radius: 20px;
	color: #FFF;
	display: inline-flex;
	font-size: 2.1rem;
	font-weight: var(--bold);
	height: 41px;
	justify-content: center;
	margin: 60px 0 0 0;
	width: 350px;
}
.top-kv__txt{
	line-height: .9;
	letter-spacing: .2rem;
}
/*
	catch
-----------------------------------------------------------------------------------------------*/
#catch{
	background: url("../images/top_catch_bg01_pc.png") no-repeat center center/ cover;
	margin: 95px 0 0 0;
	overflow: hidden;
	padding: 100px 20px;
	position: relative;
	width: 100%;
}
.catch__inner{
	color: #FFF;
	position: relative;
	text-align: center;
	z-index: 1;
}
.catch__head{
	font-size: 5.0rem;
	letter-spacing: .2rem;
	margin: 0 0 30px;
}
.catch__txt{
	font-size: 1.9rem;
	line-height: 2.4;
	opacity: .85;
}
/*
	work
-----------------------------------------------------------------------------------------------*/
#work{
	display: flex;
	flex-direction: row-reverse;
	justify-content: start;
	padding: 95px 0 160px 0;
	position: relative;
}
.work__header{
	align-items: flex-start;
	display: flex;
	flex-direction: row-reverse;
}
#work .corner__inner{
	height: 585px;
	margin: 120px 60px 0 0;
	min-width: 125px;
	writing-mode: vertical-rl;
}
.work__inner{
	width: 70%;
}
a.work__button--hit,
a.work__button--project{
	align-items: flex-end;
	background-size: 100%;
	display: flex;
	height: 25vw;
	justify-content: flex-end;
	min-height: 330px;
	min-width: 680px;
	padding: 30px 20px;
	position: relative;
	width: 85%;
}
.work__button--hit{
	background: url("../images/top_work_img01.png") no-repeat center center/ cover;
	border-radius: 0 60px 10px 0;
}
.work__button--inner{
	padding: 0 60px 0 0;
	position: relative;
}
.work__button--inner .ico-circle__red{
	bottom: 5px;
}
.work__button--txt{
	color: #FFF;
	font-size: 2.5rem;
	font-weight: var(--bold);
}
.work__button--project{
	background: url("../images/top_work_img02.png") no-repeat center center/ cover;
	border-radius: var(--bdrs-bl);
	display: inline-block;
	margin: 60px 0 0 60px;
}
/* hover */
a[class^="work__button--"]:hover{
	background-size: 105%;
	box-shadow: 0 0 13px rgba(0, 0, 0, .3);
}
/*
	people
-----------------------------------------------------------------------------------------------*/
#people{
	background: url("../images/top_bg01.png") repeat;
	border-radius: 0 0 60px 0;
	position: relative;
}
.intaview{
	align-items: center;
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1260px;
	padding: 0 30px 55px;
	position: relative;
}
.intaview__header{
	display: block;
	width: 100vw;
}
.intaview__title{
	font-size: 3.2rem;
	font-weight: var(--bold);
	line-height: 1.2;
	margin: 0 0 37px 0;
	padding: 0 0 17px 32%;
	position: relative;
}
.intaview__title::before{
	background-image: 
			linear-gradient(125deg, rgba(237, 191, 51, 1) 6%,
			rgba(237, 191, 51, 0.5) 28%,
			rgba(237, 191, 51, 1) 43%);
	bottom: 0;
	content: '';
	height: 1px;
	left: 50%;
	position: absolute;
	transform: translate(-50%, 0);
	width: 200vw;
}
.intaview__txt{
	font-size: 1.6rem;
	margin-left: 32%;
}
.intaview__list{
	display: flex;
	gap: 20px;
	margin: -55px 0 0 30px;
}
.intaview__item{
	width: 370px;
}
a[class^="intaview__button--"]{
	align-items: flex-end;
	border-radius: var(--bdrs-br);
	display: inline-flex;
	height: 485px;
	overflow: hidden;
	padding: 35px;
	position: relative;
	width: 100%;
}
a[class^="intaview__button--"]::before {
	background-image: linear-gradient(0deg, rgba(0, 24, 41, .3), rgba(255, 255, 255, 0) 100%);
	bottom: 0;
	content: '';
	height: 80px;
	left: 0;
	position: absolute;
	width: 100%;
}
a.intaview__button--01{
	background: url("../images/top_people_img01.png") no-repeat center top/ cover, url("../images/top_people_img01_hover.png");
}
a.intaview__button--02{
	background: url("../images/top_people_img02.png") no-repeat center top/ cover, url("../images/top_people_img02_hover.png");
}
.intaview__dept{
	background: #FFF;
	color: var(--red);
	display: inline-block;
	font-size: 1.3rem;
	line-height: 1;
	margin: 0 0 0 3px;
	padding: 4px 7px;
}
.intaview__name{
	color: #FFF;
	display: block;
	font-size: 3.5rem;
	font-weight: var(--light);
	line-height: 1;
	margin: 15px 0;
}
.intaview__en{
	color: #FFF;
	display: block;
	font-size: 1.0rem;
	font-weight: var(--light);
	letter-spacing: .8rem;
	margin: 0 0 0 3px;
}
.intaview__item .ico-circle__red{
	bottom: 38px;
	right: 36px;
}
/* hover */
a.intaview__button--01,
a.intaview__button--02{
	transition: background .3s;
}
a.intaview__button--01:hover{
	background: url("../images/top_people_img01_hover.png") no-repeat center top/ cover;
}
a.intaview__button--02:hover{
	background: url("../images/top_people_img02_hover.png") no-repeat center top/ cover;
}
a[class^="intaview__button"]:hover .ico-circle__red{
	right: 30px;
}
.crosstalk{
	align-items: flex-start;
	box-shadow: 0 7px 12px rgba(0, 0, 0, .4);
	border-radius: 0 0 60px 0;
	display: flex;
	height: 420px;
	overflow: hidden;
	position: relative;
}
.crosstalk__inner{
	align-items: center;
	background: url("../images/top_people_bg02.png") repeat;
	color: #FFF;
	display: flex;
	height: 420px;
	width: 33%;
}
.crosstalk__box{
	width: 100%;
}
.crosstalk__img{
	min-width: 910px;
	overflow: hidden;
	width: 67%;
}
.crosstalk__title{
	border-bottom: 1px solid #FFF;
	display: block;
	font-size: 3.2rem;
	margin: 0 0 25px 0;
	padding: 0 60px 17px;
}
.crosstalk__txt{
	display: block;
	font-size: 1.6rem;
	line-height: 2.2;
	padding: 0 60px;
	width: 100%;
}
.crosstalk__inner .ico-circle__red{
	bottom: 38px;
	right: 38px;
}
/* hover */
.crosstalk__inner,
.crosstalk .crosstalk__img img,
.crosstalk .ico-circle__red{
	transition: .3s;
}
.crosstalk:hover .crosstalk__inner{
	background: url("../images/top_people_bg02_hover.png") repeat;
}
.crosstalk:hover .crosstalk__img img{
	transform: scale(1.05);
}
.crosstalk:hover .ico-circle__red{
	right: 30px;
}
/*
	break
-----------------------------------------------------------------------------------------------*/
#break{
	height: 530px;
	margin: -55px 0 0 0;
	overflow: hidden;
	position: relative;
	z-index: -1;
}
.break__video video{
	min-width: 1400px;
	opacity: .6;
	width: 100%;
}
.break__video::before{
	background: rgba(0, 64, 129, .6);
	content: '';
	height: 530px;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 1;
}
/*
	environ
-----------------------------------------------------------------------------------------------*/
#environ{
	background: url("../images/top_bg01.png") repeat;
	border-top: 1px solid var(--red);
	padding-top: 140px;
}
.environ__inner{
	background: rgba(255, 255, 255, .65);
	border-radius: 60px 0 0 0;
	display: flex;
	margin: 0 0 0 auto;
	min-width: 1080px;
	padding: 75px 30px 75px 145px;
	position: relative;
	width: 80%;
}
.environ__button{
	display: inline-block;
}
.environ__button + .environ__button{
	margin: 0 0 0 45px;
}
.environ__img{
	border-radius: var(--bdrs-br);
	display: block;
	height: 288px;
	overflow: hidden;
	position: relative;
	width: 415px;
	z-index: 1;
}
.environ__img img{
	z-index: -1;
}
.environ__txt{
	display: inline-block;
	font-size: 2.5rem;
	font-weight: var(--bold);
	margin: 15px 0 0 0;
	padding: 0 35px 0 0;
	position: relative;
}
.environ__txt .ico-circle__red{
	bottom: 5px;
	right: 0;
}
/* hover */
.environ__img,
.environ__img img{
	transition: .3s;
}
.environ__button:hover .environ__img{
	box-shadow: 0 0 13px rgba(0, 0, 0, .3);
	z-index: 1;
}
.environ__button:hover .environ__img img{
	transform: scale(1.05);
	z-index: -1;
}
/*
	company
-----------------------------------------------------------------------------------------------*/
#company{
	position: relative;
}
#company::before{
	background-image: 
			linear-gradient(125deg, rgba(237, 191, 51, 1) 6%,
			rgba(237, 191, 51, 0.5) 28%,
			rgba(237, 191, 51, 1) 43%);
	content: '';
	height: 1px;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}
.company__body{
	margin: 60px 70px 0 0;
	text-align: right;
}
.company__inner{
	display: flex;
	flex-direction: row-reverse;
}
#company .corner__inner{
	height: 122px;
	margin: 0 0 75px 0;
	padding: 40px;
}
.company__box{
	text-align: left;
}
.company__button-wide{
	display: block;
	line-height: 1;
	padding: 0 150px 0 0;
	position: relative;
}
.company__button-wide--img{
	border-radius: var(--bdrs-tl);
	display: inline-block;
	height: 330px;
	overflow: hidden;
	position: relative;
	width: 795px;
	z-index: 1;
}
.company__button-wide--inner{
	background: rgba(255, 255, 255, .93);
	border-radius: var(--bdrs);
	box-shadow: var(--shadow);
	display: inline-block;
	height: 200px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translate(0, -50%);
	width: 345px;
	z-index: 2;
}
.company__button-wide--txt{
	display: block;
	font-size: 2.5rem;
	font-weight: var(--bold);
	line-height: 1.4;
	padding: 33px 30px;
	position: relative;
}
.company__button-wide--txt::before{
	background-image: 
			linear-gradient(125deg, rgba(237, 191, 51, 1) 6%,
			rgba(237, 191, 51, 0.5) 28%,
			rgba(237, 191, 51, 1) 43%);
	bottom: 0;
	content: '';
	height: 1px;
	left: 0;
	position: absolute;
	width: 100%;
}
/* 社長メッセージ */
.top-message{
	padding: 0 0 0 227px;
}
.top-message .company__button-wide--img{
	border-radius: var(--bdrs-br);
	width: 718px;
}
.top-message .company__button-wide--inner{
	height: 270px;
	left: 0;
	padding: 20px 0;
	width: 400px;
}
.top-message .company__button-wide--txt{
	padding: 17px 30px;
}
.company__button--message{
	font-size: 2.7rem;
	font-weight: var(--light);
	line-height: 1.6;
}
.company__button--message{
	display: block;
	padding: 35px 30px;
}
.company__flex{
	display: flex;
	gap: 20px;
	margin: 13px 0;
}
a.company__button--01,
a.company__button--02,
a.company__button--03{
	align-items: flex-end;
	border-radius: var(--bdrs);
	color: #FFF;
	display: flex;
	height: 400px;
	overflow: hidden;
	padding: 20px;
	position: relative;
	width: calc((100% - 40px)/3);
	z-index: 1;
}
a[class^="company__button--"]::before {
	background-image: linear-gradient(0deg, rgba(0, 24, 41, .6), rgba(255, 255, 255, 0) 100%);
	bottom: 0;
	content: '';
	height: 80px;
	left: 0;
	position: absolute;
	width: 100%;
}
.company__button--01{
	background: url("../images/top_company_img02.png") no-repeat center center/ cover;
}
.company__button--02{
	background: url("../images/top_company_img03.png") no-repeat center center/ cover;
}
.company__button--03{
	background: url("../images/top_company_img04.png") no-repeat center center/ cover;
}
.company__button--inner{
	position: relative;
	width: 100%;
}
.company__button--inner .ico-circle__red{
	bottom: 0;
	right: 0;
}
.company__button--txt{
	font-size: 1.8rem;
	font-weight: var(--bold);
	line-height: 1.3;
}
.link{
	padding: 0 20px 0 0;
	position: relative;
}
.link::before{
	background: url("../images/link_icon02.svg") no-repeat center center/ cover;
	content: '';
	height: 11px;
	position: absolute;
	right: 0;
	top: 9px;
	width: 11px;
}
.company__button--sub{
	display: block;
	font-size: 1.2rem;
}
/* hover */
a[class^="company__button"],
a[class^="company__button"] img,
a[class^="company__button"] .ico-circle__red{
	transition: .3s;
}
a[class^="company__button"]{
	background-size: 100%;
}
a[class^="company__button"]:hover{
	background-size: 105%;
}
a[class^="company__button"]:hover img{
	transform: scale(1.05);
}
a[class^="company__button--"]:hover .ico-circle__red{
	right: -5px;
}
.company__button-wide:hover .ico-circle__red{
	right: 15px;
}
/*
	recruit
-----------------------------------------------------------------------------------------------*/
#recruit{
	background: url("../images/top_recruit_bg01.png") no-repeat center center/ cover;
	border-radius: 0 0 60px;
	padding-bottom: 75px;
	text-align: center;
}
a.recruit__button{
	align-items: center;
	background: rgba(255, 255, 255, .9);
	border-radius: var(--bdrs);
	display: inline-flex;
	height: 220px;
	justify-content: center;
	margin: 0 auto;
	min-width: 900px;
	position: relative;
}
.recruit__head{
	color: var(--red);
	display: block;
	font-size: 3.7rem;
	font-weight: var(--bold);
}
.recruit__txt{
	color: #3d4b60;
	display: inline-block;
	font-size: 1.5rem;
	line-height: 1.7;
	margin: 15px 0 0 0;
}
#recruit + #footer{
	margin-top: 0;
}
/* hover */
.ico-circle__red{
	transition: .3s;
}
.recruit__button:hover{
	background: #FFF;
	box-shadow: 0 0 15px rgb(0, 0, 0, .25);
}
.recruit__button:hover .ico-circle__red{
	right: 15px;
}
/*
	footer
-----------------------------------------------------------------------------------------------*/
a.footer-entry__button,
.footer-entry__button{
	height: 220px;
	max-width: 900px;
	/* position: relative; */
	top: -125px;
}
.footer-entry__txt{
	width: 100%;
}
@media screen and (max-width:1024px){
	/*
		break
	-----------------------------------------------------------------------------------------------*/
	#break{
		height: auto;
		line-height: 1;
		margin: -55px 0 0;
	}
	.break__video video{
		min-width: auto;
		width: 100%;
	}
	.break__video::before{
		height: 100%;
	}
	/*
		environ
	-----------------------------------------------------------------------------------------------*/
	/* hover */
	.environ__button:hover .environ__img{
		border-radius: var(--bdrs-br);
		overflow: hidden;
		z-index: 1;
	}
	.environ__button:hover .environ__img img{
		z-index: -1;
	}
}
@media screen and (max-width:812px){
	/*
		common
	-----------------------------------------------------------------------------------------------*/
	.ctsArea{
		padding: 55px 15px 70px;
	}
	/* リード文
	============================== */
	.corner__inner{
		font-size: 1.3rem;
		padding: 12px;
	}
	/* h4
	============================== */
	.top-head__inner{
		padding: 0 13px 0 0;
	}
	.top-head__title{
		width: 45px;
	}
	.top-head__sub{
		font-size: 1.0rem;
		letter-spacing: .3rem;
		margin-top: -7px;
		opacity: .7;
	}
	/* work */
	#work .top-head__title{
		height: 185px;
	}
	/* people */
	#people .top-head{
		left: 6%;
		top: -67px;
	}
	#people .top-head__title{
		height: 147px;
	}
	/* environ */
	#environ .top-head{
		left: 15px;
		top: 50px;
	}
	#environ .top-head__title{
		height: 153px;
	}
	/* company */
	#company .top-head{
		position: absolute;
		top: -20px;
	}
	#company .top-head__title{
		height: 177px;
	}
	/* recruit */
	#recruit .top-head{
		left: 15px;
		top: -40px;
	}
	#recruit .top-head__title{
		height: 150px;
		left: 15px;
	}
	/*
		opening
	-----------------------------------------------------------------------------------------------*/
	.opening__img{
		margin: 0 0 0 30px;
		opacity: 0;
		width: 120px;
	}
	.opening__txt{
		font-size: 2.0rem;
		letter-spacing: .3rem;
		line-height: 1.3;
		margin: 10px 0 0 0;
	}
	/*
		kv
	-----------------------------------------------------------------------------------------------*/
	/* swiper */
	.slick__list{
		border-radius: 0 0 0 30px;
		height: fit-content;
		max-height: fit-content;
		max-width: 500px;
		min-height: fit-content;
		min-width: 80%;
		overflow: hidden;
		width: 100%;
	}
	.slick__list{
		z-index: -1;
	}
	.slick__list img{
		transform: scale(1.1);
	}
	/* progress bar */
	.slider-dots{
		bottom: 13px;
		display: flex;
		justify-content: center;
		list-style: none;
		margin: 0;
		padding: 0;
		position: absolute;
		text-align: center;
		width: 100%;
	}
	.slick__item{
		display: inline-block;
		width: calc(25% - 8px);
	}
	.slider-dots button{
		height: 2px;
		margin: 0 4px;
		width: 90px;
	}
	.kv__copy{
		left: auto;
		margin: 47px 0 0;
		position: static;
		text-align: center;
		top: auto;
		transform: none;
	}
	.top-kv__head{
		font-size: 4.2rem;
		letter-spacing: .3rem;
		line-height: 1.4;
		text-align: center;
	}
	.top-kv__sub{
		border-radius: 20px;
		display: inline-flex;
		font-size: 1.7rem;
		height: 32px;
		line-height: 1;
		margin: 23px 0 0 0;
		padding: 0 30px;
		width: auto;
	}
	.top-kv__txt{
		line-height: .9;
		letter-spacing: .2rem;
	}
	/*
		catch
	-----------------------------------------------------------------------------------------------*/
	#catch{
		background: url("../images/top_catch_bg01_sp.png") no-repeat center bottom/ cover;
		margin: 75px 0 0 0;
		padding: 60px 15px;
	}
	.catch__head{
		font-size: 3.5rem;
		letter-spacing: 0;
		margin: 0 0 25px;
	}
	.catch__txt{
		font-size: 1.6rem;
		line-height: 2.0;
		text-align: left;
	}
	/*
		break
	-----------------------------------------------------------------------------------------------*/
	#break{
		margin: -10px 0 0;
	}
	/*
		work
	-----------------------------------------------------------------------------------------------*/
	#work{
		display: block;
		flex-direction: row-reverse;
		justify-content: start;
		padding: 20px 0 70px;
	}
	.work__header{
		justify-content: space-between;
		margin: 0;
		padding: 0 25px;
		position: relative;
		z-index: 1;
	}
	#work .corner__inner{
		height: auto;
		margin: 43px 0 0;
		min-width: auto;
		writing-mode: inherit;
		width: 70%;
	}
	.work__inner{
		margin: -25px 0 0 0;
		width: 100%;
	}
	a.work__button--hit,
	a.work__button--project{
		background-size: 125%;
		height: 200px;
		max-width: 500px;
		min-height: auto;
		min-width: auto;
		padding: 17px 30px;
		width: 90%;
	}
	a.work__button--hit img{
		height: 100%;
	}
	.work__button--hit{
		border-radius: 0 40px 10px 0;
	}
	.work__button--inner{
		padding: 0 27px 0 0;
	}
	.work__button--inner .ico-circle__red{
		bottom: auto;
		right: 0;
		top: 50%;
		transform: translate(0, -50%);
	}
	.work__button--txt{
		font-size: 1.8rem;
		line-height: 1.3;
	}
	.work__button--project{
		margin: 15px 0 0 15px;
	}
	/* hover */
	a[class^="work__button--"]:hover{
		background-size: 125%;
		box-shadow: 0 0 13px rgba(0, 0, 0, .3);
		transition: .3s;
	}
	/*
		people
	-----------------------------------------------------------------------------------------------*/
	#people{
		background-size: 100px;
		border-radius: 0 0 15px 0;
		padding: 53px 0 0;
	}
	.intaview{
		display: block;
		margin: 0 auto;
		max-width: 1200px;
		padding: 0 15px 53px;
	}
	.intaview__header{
		display: block;
		width: 100%;
	}
	.intaview__title{
		font-size: 2.0rem;
		line-height: 1.2;
		margin: 0 0 15px;
		padding: 0 0 15px 25%;
	}
	.intaview__title::before{
		width: 100vw;
	}
	.intaview__txt{
		font-size: 1.4rem;
		margin-left: 25%;
	}
	.intaview__list{
		gap: 10px;
		justify-content: center;
		margin: 25px 0 0;
	}
	.intaview__item{
		max-width: 190px;
		width: calc((100% - 10px)/2);
	}
	a[class^="intaview__button--"]{
		height: 250px;
		padding: 15px;
		width: 100%;
	}
	.intaview__dept{
		font-size: 1.0rem;
		margin: 0 0 0 2px;
		padding: 2px 6px;
	}
	.intaview__name{
		font-size: 2.3rem;
		margin: 7px 0;
	}
	.intaview__en{
		letter-spacing: .4rem;
	}
	.intaview__item .ico-circle__red{
		bottom: 18px;
		right: 18px;
	}
	/* hover */
	a[class^="intaview__button"]:hover .ico-circle__red{
		right: 18px;
	}
	.crosstalk{
		box-shadow: 0 7px 12px rgba(0, 0, 0, .4);
		border-radius: 0 0 13px 0;
		display: block;
		height: auto;
		width: 100%;
	}
	.crosstalk__inner{
		background: url("../images/top_people_bg02.png") repeat;
		display: block;
		height: auto;
		padding: 20px 0;
		width: 100%;
	}
	.crosstalk__img{
		display: flex;
		line-height: 1;
		min-width: auto;
		width: 100%;
	}
	.crosstalk__title{
		font-size: 2.3rem;
		margin: 0 0 20px 0;
		padding: 0 15px 14px;
	}
	.crosstalk__txt{
		display: block;
		font-size: 1.5rem;
		line-height: 1.6;
		padding: 0 15px 20px;
		width: 100%;
	}
	.crosstalk .ico-circle__red{
		bottom: 22px;
		right: 23px;
	}
	/* hover */
	.crosstalk:hover .ico-circle__red{
		right: 23px;
	}
	/*
		environ
	-----------------------------------------------------------------------------------------------*/
	#environ{
		background-size: 100px;
		padding-top: 70px;
		position: relative;
	}
	.environ__inner{
		border-radius: 35px 0 0 0;
		display: block;
		min-width: auto;
		padding: 40px 15px 70px 60px;
		position: static;
		width: 87%;
	}
	.environ__button{
		display: block;
	}
	.environ__button + .environ__button{
		margin: 25px 0 0 0;
	}
	.environ__img{
		display: block;
		height: 150px;
		max-width: 320px;
		position: relative;
		width: 100%;
	}
	.gallery img{
		bottom: 0;
		left: 50%;
		position: absolute;
		transform: translate(-50%, 0);
	}
	.environ__txt{
		display: inline-block;
		font-size: 1.8rem;
		margin: 7px 0 0 0;
		padding: 0 22px 0 0;
	}
	.environ__txt .ico-circle__red{
		bottom: 3px;
		right: 0;
	}
	/* hover */
	.environ__img,
	.environ__img img{
		transition: .3s;
		z-index: -1;
	}
	.environ__button:hover .environ__img{
		box-shadow: 0 0 13px rgba(0, 0, 0, .3);
		transition: .3s;
	}
	.gallery.environ__button:hover .environ__img img{
		transform: translate(-50%, 0) scale(1.05);
		transition: .3s;
	}
	.environ__button:hover .environ__img img{
		transform: scale(1.05);
		transition: .3s;
	}
	/*
		company
	-----------------------------------------------------------------------------------------------*/
	.company__body{
		margin:  0 0;
		text-align: left;
	}
	.company__inner{
		display: flex;
		flex-direction: row-reverse;
	}
	#company .corner__inner{
		height: auto;
		margin: 0 auto 45px 10px;
		min-width: 70%;
		padding: 12px;
		width: 70%;
	}
	.company__box{
		text-align: left;
	}
	.company__button-wide{
		display: block;
		line-height: 1;
		padding: 0 0 60px;
	}
	.company__button-wide--img{
		height: auto;
		width: 95%;
	}
	.company__button-wide--inner{
		bottom: 0;
		height: 115px;
		max-width: 300px;
		top: auto;
		transform: none;
		width: 70%;
	}
	.company__button-wide--txt{
		font-size: 1.8rem;
		line-height: 1.4;
		padding: 15px;
	}
	[class^="company__button"] .ico-circle__red{
		bottom: 10px;
		right: 10px;
	}
	/* 社長メッセージ */
	.top-message{
		padding: 0 0 90px;
	}
	.top-message .company__button-wide--img{
		width: 95%;
	}
	.top-message .company__button-wide--inner{
		height: auto;
		padding: 0;
		width: 70%;
	}
	.top-message .company__button-wide--txt{
		padding: 15px;
	}
	.company__button--message{
		font-size: 1.8rem;
		line-height: 1.4;
	}
	.company__button--message{
		display: block;
		padding: 15px;
	}
	.company__flex{
		display: flex;
		flex-wrap: wrap;
		gap: 10px;
		margin: 20px 0 10px;
		width: 95%;
	}
	a.company__button--01,
	a.company__button--02,
	a.company__button--03{
		height: 200px;
		padding: 10px 23px 10px 10px;
		width: calc((100% - 10px)/2);
	}
	.company__button--01{
		background: url("../images/top_company_img02.png") no-repeat center center/ cover;
		height: 180px!important;
		width: 100%!important;
	}
	.company__button--02{
		background: url("../images/top_company_img03.png") no-repeat center center/ cover;
	}
	.company__button--03{
		background: url("../images/top_company_img04.png") no-repeat center center/ cover;
	}
	.company__button--inner{
		position: relative;
		width: 100%;
	}
	.company__button--inner .ico-circle__red{
		bottom: 0;
		right: -12px;
	}
	.company__button--txt{
		display: inline-block;
		font-size: 1.5rem;
	}
	.link{
		padding: 0 20px 0 0;
		position: relative;
	}
	.link::before{
		background: url("../images/link_icon02.svg") no-repeat center center/ cover;
		content: '';
		height: 11px;
		position: absolute;
		right: 0;
		top: 9px;
		width: 11px;
	}
	.company__button--sub{
		display: block;
		font-size: 1.2rem;
	}
	/* hover */
	a[class^="company__button"],
	a[class^="company__button"] img,
	a[class^="company__button"] .ico-circle__red{
		transition: .3s;
	}
	a[class^="company__button"]{
		background-size: 100%;
	}
	a[class^="company__button"]:hover{
		background-size: 105%;
		transition: .3s;
	}
	a[class^="company__button"]:hover img{
		transform: scale(1.05);
		transition: .3s;
	}
	a[class^="company__button--"]:hover .ico-circle__red{
		right: -12px;
		transition: .3s;
	}
	.company__button-wide:hover .ico-circle__red{
		right: -12px;
		transition: .3s;
	}
	/*
		recruit
	-----------------------------------------------------------------------------------------------*/
	#recruit{
		border-radius: 0 0 35px;
		padding-bottom: 20px;
	}
	a.recruit__button{
		height: 150px;
		min-width: 80%;
	}
	.recruit__head{
		font-size: 2.5rem;
	}
	.recruit__txt{
		font-size: 1.4rem;
		line-height: 1.4;
		margin: 8px 0 0 0;
	}
	/* hover */
	.recruit__button:hover{
		box-shadow: 0 0 10px rgb(0, 0, 0, .25);
	}
	.recruit__button:hover .ico-circle__red{
		right: 20px;
	}
	/*
		footer
	-----------------------------------------------------------------------------------------------*/
	a.footer-entry__button,
	.footer-entry__button{
		height: 130px;
		max-width: 83%;
		position: absolute;
		top: -68px;
		width: 74%;
	}
	.footer-entry__txt{
		width: 100%;
	}
}