@charset "utf-8";
:root {--main-color: #0177C1;}
:root {--sub-color: #50B5F2;}
:root {--text-color: #333333;}
:root {--text-font: "Zen Kaku Gothic New";}
:root {--sub-font: "Noto Sans JP";}

section{
	width: 100%;
	position: relative;
	overflow: hidden;
}
.inner{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto;
    position: relative;
}
h1,h2,h3,h4,h5,h6{
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
p,a{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.8;
    letter-spacing: 0.1em;
	color: var(--text-color);
}
@media (min-width: 821px) and (max-width: 1280px) {
	p,a{
		font-size: 1.25vw;
	}
}
@media screen and (max-width: 820px) {
	p,a{
		font-size: 15px;
	}
}
/*==================================================================================================*/
/*共通記述*/
.title{
    font-size: 48px;
	margin-bottom: 50px;
}
.title + h3{
    font-size: 24px;
	margin-bottom: 20px;
}
.title + h3 + p{
    margin-bottom: 32px;
}
.more{
	display: flex;
	align-items: center;
	font-size: 15px;
	font-weight: 700;
}
.more::after{
	display: block;
	content: "";
	width: 28px;
	height: 28px;
	background: center / contain no-repeat url("../img/icon-arrow-color.svg");
	margin-left: 13px;
	position: relative;
	left: 0;
	transition: .5s;
}
.more:hover{
	color: var(--main-color);
}
.more:hover::after{
	left: 3px;
}
@media (min-width: 821px) and (max-width: 1280px) {
	.title{
		font-size: 3.75vw;
		margin-bottom: 3.906vw;
	}
	.title + h3{
		font-size: 1.875vw;
		margin-bottom: 1.563vw;
	}
	.title + h3 + p{
		margin-bottom: 2.5vw;
	}
}
@media screen and (max-width: 820px) {
	.title{
		font-size: 34px;
		margin-bottom: 34px;
	}
	.title + h3{
		font-size: 20px;
		margin-bottom: 10px;
	}
	.more{
		font-size: 14px;
	}
}
/*==================================================================================================*/
/*-*/
header{
	width: 100%;
	height: 60px;
	background: #FFF;
	position: fixed;
	top: -60px;
	z-index: 10000;
	transition: .5s;
}
header .inner{
	width: 96%;
	max-width: 96%;
	height: 100%;
}
header .inner h1{
	width: 98px;
	z-index: 1;
}
header .inner h1 a{
	display: flex;
	align-items: center;
}
header .inner nav{
	width: fit-content;
}
.nav{
	width: 620px;
}
.nav li{
	width: fit-content;
}
.nav li a{
	font-family: var(--sub-font);
	font-size: 14px;
	font-weight: 700;
}
header .nav li a:hover{
	color: var(--main-color);
}
.nav li a.btn{
	display: flex;
	align-items: center;
	justify-content: center;
	height: 32px;
	width: 120px;
	font-size: 12px;
	color: #FFF;
	background: var(--main-color);
	border-radius: 3px;
}
.nav li a.btn:hover{
	color: #FFF;
	background: var(--sub-color);
}
header.movement{
	top: 0;
}
.openbtn1{
	display: none;
}
@media screen and (max-width: 820px) {
	header{
		height: 50px;
	}
	header .inner h1{
		width: 80px;
	}
	nav{
		width: 100%;
		height: 100svh;
		background: #FFF;
		position: fixed;
		top: -100svh;
		left: 0;
		transition: .5s;
	}
	.pcNav nav{
		top: 0;
	}
	header .nav{
		width: 100%;
		padding-top: 80px;
	}
	header .nav li{
		width: 100%;
		border-bottom: solid 1px #eee;
	}
	header .nav li:last-child{
		border-bottom: none;
	}
	header .nav li a{
		display: block;
		text-align: center;
		padding: 15px;
	}
	header .nav li a.btn{
		height: 46px;
		width: 90%;
		font-size: 14px;
		margin: 30px auto 0;
	}
	/*ボタン*/
	.openbtn1{
		display: block;
		cursor: pointer;
		width: 50px;
		height: 50px;
		position: absolute;
		top: 0;
		right: -2%;
	}
	.openbtn1 span:nth-of-type(1),
	.openbtn1 span:nth-of-type(2),
	.openbtn1 span:nth-of-type(3){
		display: inline-block;
		transition: all .4s;
		width: 23px;
		height: 1.5px;
		background: var(--main-color);
		position: absolute;
		left: 13px;
	}
	.openbtn1 span:nth-of-type(1) { top:16px;}
	.openbtn1 span:nth-of-type(2) { top:24px;}
	.openbtn1 span:nth-of-type(3) { top:32px;}
	
	.pcNav .openbtn1 span:nth-of-type(1) {
		top: 25px;
		transform: rotate(-45deg);
	}
	.pcNav .openbtn1 span:nth-of-type(2){
		opacity: 0;
	}
	.pcNav .openbtn1 span:nth-of-type(3){
		top: 25px;
		transform: rotate(45deg);
	}
}
/*==================================================================================================*/
/*fv-*/
.fv{
	height: 785px;
	padding: 0;
}
.fv .textBox{
	width: 50%;
	height: 100%;
	background: var(--main-color);
	margin: 0 auto 0 0;
	position: relative;
	z-index: 1;
}
.fv .textBox h2{
	width: max-content;
	font-family: var(--sub-font);
	font-size: 168px;
	letter-spacing: 0.03em;
    line-height: 0.9;
	color: #FFF;
	transform: rotate(90deg);
	position: absolute;
	top: 245px;
    right: -280px;
}
.fv .textBox h2 + p{
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	width: fit-content;
	font-size: 51px;
	font-weight: 700;
	letter-spacing: 0.4em;
    line-height: 1.5;
	position: absolute;
	top: 50px;
	left: 46px;
}
.fv .textBox h2 + p span{
	display: block;
	width: fit-content;
	background: #FFF;
	padding: 30px 0 0;
}
.fv .textBox h2 + p span:nth-child(2){
	margin-right: 30px;
}
.fv .textBox h2 + p + p{
	width: fit-content;
    font-family: var(--sub-font);
    font-size: 10px;
    letter-spacing: 0.15em;
    line-height: 1;
    color: #FFF;
    transform: rotate(90deg);
    position: absolute;
    bottom: 100px;
    left: -60px;
}
.fv .fvSlider{
	width: 50%;
	height: 100%;
	margin: 0;
	position: absolute;
	top: 0;
	right: 0;
}
.fv .fvSlider img{
	display: block;
	height: 100%;
}
.fv a{
	display: block;
	width: 108px;
	position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
	z-index: 10;
	animation: fvscroll 2s ease-out infinite;
}
@keyframes fvscroll {
  0% {
    width: 108px;
  }
  40% {
    width: 105px;
  }
  100% {
    width: 108px;
  }
}
@media (min-width: 769px) and (max-width: 1280px) {
	.fv{
		height: 61.328vw;
	}
	.fv .textBox h2{
		font-size: 13.125vw;
		top: 19.141vw;
		right: -21.875vw;
	}
	.fv .textBox h2 + p{
		font-size: 3.984vw;
		top: 3.906vw;
		left: 3.594vw;
	}
	.fv .textBox h2 + p span{
		padding: 2.344vw 0 0;
	}
	.fv .textBox h2 + p span:nth-child(2){
		margin-right: 2.344vw;
	}
	.fv .textBox h2 + p + p{
		font-size: 0.781vw;
		bottom: 7.813vw;
		left: -4.687vw;
	}
	.fv a{
		bottom: 1.875vw;
	}
	@keyframes fvscroll {
	  0% {
		width: 8.438vw;
	  }
	  40% {
		width: 8.203vw;
	  }
	  100% {
		width: 8.438vw;
	  }
	}
}
@media screen and (max-width: 768px) {
	.fv{
		height: 100svh;
	}
	.fv .textBox{
		width: 100%;
		height: 100%;
		background: none;
	}
	.fv .textBox h2 + p span{
		padding: 24px 0 0;
	}
	.fv .textBox h2 + p span:nth-child(2){
		margin-right: 15px;
	}
	.fv a{
		width: 70px;
	}
	@keyframes fvscroll {
	  0% {
		width: 70px;
	  }
	  40% {
		width: 68px;
	  }
	  100% {
		width: 70px;
	  }
	}
	.fv .fvSlider{
		width: 100%;
	}
	.fv .fvSlider img{
		height: 100svh;
	}
}
@media screen and (max-width: 520px) {
	.fv .textBox h2 {
        font-size: 100px;
        top: 150px;
        right: -168px;
    }
	.fv .textBox h2 + p{
		font-size: 30px;
        top: 20px;
        left: 20px;
	}
}
/*==================================================================================================*/
/*about-*/
.about{
	padding: 220px 0 150px;
}
.about .inner{
	justify-content: center;
}
.about h2{
	width: fit-content;
    font-size: 77px;
	line-height: 1.3;
}
.about h2 + p{
	width: fit-content;
	font-size: 27px;
	font-weight: 700;
	line-height: 2;
}
@media (min-width: 821px) and (max-width: 1280px) {
	.about{
		padding: 17.188vw 0 11.719vw;
	}
	.about h2{
		font-size: 6.016vw;
	}
	.about h2 + p{
		font-size: 2.109vw;
	}
}
@media screen and (max-width: 820px) {
	.about{
		padding: 60px 0;
	}
	.about h2{
		width: 100%;
		font-size: 56px;
	}
	.about h2 + p{
		width: 100%;
		font-size: 22px;
	}
}
@media screen and (max-width: 520px) {
	.about{
		padding: 60px 0 40px;
	}
}
/*==================================================================================================*/
/*news-*/
.news{
	width: 90%;
	max-width: 886px;
	margin: 0 auto 40px;
}
.newsBox{
	width: calc( 100% - 172px );
	height: 41px;
	border-radius: 60px;
	border: solid 1px var(--main-color);
	overflow: hidden;
}
.newsBox h2{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 117px;
	height: 100%;
	font-size: 18px;
	color: #FFF;
	background: var(--main-color);
}
.newsBox a{
	width: calc( 100% - 117px );
	height: 100%;
	padding: 0 30px;
}
.newsBox a p{
	width: 100px;
	font-size: 14px;
	transition: .5s;
}
.newsBox a h3{
	width: calc( 100% - 100px );
	font-size: 14px;
	font-weight: 400;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: .5s;
}
.newsBox a:hover{
	background: rgba(80,181,242,0.20);
}
.newsBox a:hover p,
.newsBox a:hover h3{
	color: #D94800;
}
.newsBox + a{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 161px;
	height: 41px;
	font-size: 15px;
	font-weight: 700;
	color: #FFF;
	background: #D94800;
	border-radius: 60px;
}
.newsBox + a::after{
	display: block;
	content: "";
	width: 24px;
	height: 24px;
	background: center / contain no-repeat url("../img/icon-instagram.svg");
	margin-left: 7px;
}
.newsBox + a:hover{
	opacity: .7;
}
@media (min-width: 821px) and (max-width: 1280px) {
	.news{
		max-width: 69.219vw;
	}
	.newsBox{
		width: calc( 100% - 13.438vw );
		height: 3.203vw;
		border-radius: 4.688vw;
	}
	.newsBox h2{
		width: 9.141vw;
		font-size: 1.406vw;
	}
	.newsBox a{
		width: calc( 100% - 9.141vw );
		padding: 0 2.344vw;
	}
	.newsBox a p{
		width: 7.813vw;
		font-size: 1.094vw;
	}
	.newsBox a h3{
		width: calc( 100% - 7.813vw );
		font-size: 1.094vw;
	}
	.newsBox + a{
		width: 12.578vw;
		height: 3.203vw;
		font-size: 1.172vw;
		border-radius: 4.688vw;
	}
	.newsBox + a::after{
		width: 1.875vw;
		height: 1.875vw;
		margin-left: 0.781vw;
	}
}
@media screen and (max-width: 820px) {
	.newsBox{
		width: 100%;
		margin-bottom: 20px;
	}
}
@media screen and (max-width: 520px) {
	.newsBox{
		height: auto;
		border-radius: 5px;
	}
	.newsBox h2{
		width: 100%;
		height: 44px;
	}
	.newsBox a{
		width: 100%;
		padding: 10px 20px;
	}
	.newsBox a p{
		width: 100%;
		padding-bottom: 3px;
		border-bottom: solid 1px #eee;
	}
	.newsBox a h3{
		width: 100%;
		padding-top: 3px;
	}
	.newsBox + a{
		width: 100%;
	}
}
/*==================================================================================================*/
/*works-*/
.works{
	padding: 100px 0 60px;
	background: center / cover no-repeat url("../img/works-bg.jpg");
}
.works .inner{
	max-width: 1120px;
}
.works .inner div{
	width: 35%;
	max-width: 370px;
}
.works .inner ul{
	width: 65%;
	max-width: 728px;
}
.works ul li{
	width: calc( 50% - 3px );
	max-width: 362px;
	margin-bottom: 26px;
}
.works .inner ul .img{
	width: 100%;
	max-width: 100%;
	box-shadow: 0 4px 4px 0 rgba(0,0,0,0.25);
}
.works ul li p{
	font-size: 14px;
}
@media (min-width: 821px) and (max-width: 1280px) {
	.works{
		padding: 7.813vw 0 4.688vw;
	}
	.works .inner{
		max-width: 87.5vw;
	}
	.works .inner div{
		max-width: 28.906vw;
	}
	.works .inner ul{
		max-width: 56.875vw;
	}
	.works ul li{
		width: calc( 50% - 0.234vw );
		max-width: 28.281vw;
		margin-bottom: 2.031vw;
	}
	.works ul li p{
		font-size: 1.094vw;
	}
}
@media screen and (max-width: 820px) {
	.works{
		padding: 60px 0;
	}
	.works .inner div{
		width: 100%;
		max-width: 100%;
		margin-bottom: 34px;
	}
	.works .title + h3 + p br{
		display: none;
	}
	.works .inner ul{
		width: 100%;
	}
	.works .inner ul .img{
		margin-bottom: 0;
	}
}
@media screen and (max-width: 520px) {
	.works ul li{
		width: 100%;
		max-width: 100%;
	}
	.works ul li:last-child{
		margin-bottom: 0;
	}
}
/*==================================================================================================*/
/*business-*/
.business{
	padding: 120px 0;
}
.business .inner{
	max-width: 1120px;
}
.business .inner .textBox{
	max-width: 583px;
}
.businessSlider{
	width: 880px;
	position: absolute;
    top: 50%;
    left: calc( 583px + 5% );
    transform: translateY(-50%);
}
.businessList{
	height: 440px !important;
	position: relative;
}
.businessList img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.businessList div.flex{
	width: 90%;
	max-width: 402px;
	background: #FFF;
	position: absolute;
	bottom: 35px;
	left: 0;
}
.businessList div img{
	width: 81px;
	height: 81px;
}
.businessList div div{
	width: calc( 100% - 81px );
	padding: 0 15px;
}
.businessList div div h4{
	font-size: 16.5px;
	margin-bottom: 5px;
}
.businessList div div p{
	font-size: 13.5px;
	letter-spacing: 0.05em;
	line-height: 1.2;
}
@media screen and (min-width: 1700px) {
	.businessSlider{
		width: 920px;
	}
}
@media (min-width: 821px) and (max-width: 1280px) {
	.business{
		padding: 9.375vw 0;
	}
	.business .inner{
		max-width: 87.5vw;
	}
	.business .inner .textBox{
		max-width: 45.547vw;
	}
	.businessSlider{
		width: 68.75vw;
		left: calc( 45.547vw + 5% );
	}
	.businessList{
		height: 34.375vw !important;
		position: relative;
	}
	.businessList div.flex{
		max-width: 31.406vw;
		bottom: 2.734vw;
	}
	.businessList div img{
		width: 6.328vw;
		height: 6.328vw;
	}
	.businessList div div{
		width: calc( 100% - 6.328vw );
		padding: 0 1.172vw;
	}
	.businessList div div h4{
		font-size: 1.289vw;
		margin-bottom: 0.391vw;
	}
	.businessList div div p{
		font-size: 1.133vw;
		letter-spacing: 0.05em;
	}
}
@media screen and (max-width: 820px) {
	.business{
		padding: 60px 0;
	}
	.business .inner .textBox{
		max-width: 100%;
		margin-bottom: 34px;
	}
	.businessSlider{
		position: relative;
		top: 0;
		left: 0;
		transform: translateY(0%);
	}
	.businessList div.flex{
		bottom: 15px;
	}
	.businessList div img{
		width: 70px;
		height: 70px;
	}
	.businessList div div{
		width: calc( 100% - 70px );
		padding: 0 10px;
	}
	.businessList div div h4{
		font-size: 14px;
		margin-bottom: 0;
	}
	.businessList div div p{
		font-size: 13px;
	}
}
@media screen and (max-width: 767px) {
	.businessSlider{
		width: 680px;
	}
	.businessList{
		height: 300px !important;
	}
}
/*==================================================================================================*/
/*company-*/
.partition{
	width: 100%;
	aspect-ratio: 16 / 6;
}
.company{
	width: 50%;
}
.company .inner{
	max-width: 460px;
}
@media (min-width: 821px) and (max-width: 1280px) {
	.company .inner{
		max-width: 35.938vw;
	}
}
@media screen and (max-width: 820px) {
	.partition{
		height: 200px;
		aspect-ratio: auto;
	}
	.partition + div{
		display: block;
	}
	.company{
		width: 100%;
		padding: 60px 0;
	}
	.company .inner{
		max-width: 90%;
	}
}
/*==================================================================================================*/
/*recruit-*/
.recruit{
	width: 50%;
	padding: 34px 31px;
	background: var(--main-color);
}
.recruit .inner{
	width: 100%;
	padding: 50px 0 50px;
	border: solid 3px #FFF;
}
.recruit h2{
	display: flex;
	justify-content: center;
	position: relative;
	margin-bottom: 20px;
}
.recruit h2 img{
	width: 126px;
	height: fit-content;
	object-fit: contain;
}
.recruit h2::after{
	display: block;
	content: "";
	width: 115px;
	height: 73px;
	background: center / contain no-repeat url("../img/logo-recruit.svg");
	margin-left: 3px;
	position: relative;
	top: -7px;
}
.recruit h3{
	font-family: "Sawarabi Gothic", sans-serif;
	font-size: 47px;
	font-weight: 400;
	line-height: 1.4;
	letter-spacing: 0;
	text-align: center;
	color: #FFF;
	margin-bottom: 50px;
}
.recruit h3 + img{
	display: block;
	width: 70%;
	max-width: 286px;
	margin: 0 auto;
}
.recruit a{
	width: 90%;
	max-width: 467px;
	height: 88px;
	padding: 0 40px;
	background: #FFF;
	margin: 0 auto;
}
.recruit a p{
	width: fit-content;
	font-size: 24px;
	font-weight: 700;
	transition: .5s;
}
.recruit a:hover p{
	color: #D94800;
}
.recruit a .more{
	transition: .5s;
}
.recruit a:hover .more{
	color: #D94800;
}
.recruit a:hover .more::after{
	left: 3px;
}
@media (min-width: 821px) and (max-width: 1280px) {
	.recruit{
		padding: 2.656vw 2.422vw;
	}
	.recruit .inner{
		padding: 3.906vw 0 3.906vw;
	}
	.recruit h2{
		margin-bottom: 1.563vw;
	}
	.recruit h2 img{
		width: 9.844vw;
	}
	.recruit h2::after{
		width: 8.984vw;
		height: 5.703vw;
		margin-left: 0.234vw;
		top: -0.547vw;
	}
	.recruit h3{
		font-size: 3.672vw;
		margin-bottom: 3.906vw;
	}
	.recruit h3 + img{
		max-width: 22.344vw;
	}
	.recruit a{
		max-width: 36.484vw;
		height: 6.875vw;
		padding: 0 3.125vw;
	}
	.recruit a p{
		font-size: 1.875vw;
	}
}
@media screen and (max-width: 820px) {
	.recruit{
		width: 100%;
		padding: 25px;
	}
	.recruit .inner{
		padding: 25px 0 20px;
	}
	.recruit h2{
		margin-bottom: 10px;
	}
	.recruit h2 img{
		width: 100px;
	}
	.recruit h2::after{
		width: 90px;
		height: 55px;
	}
	.recruit h3{
		font-size: 26px;
		margin-bottom: 20px;
	}
	.recruit a{
		height: 74px;
		padding: 0 20px;
	}
	.recruit a p{
		font-size: 18px;
	}
}
iframe{
	width: 100%;
	aspect-ratio: 16 / 4.2;
	margin-bottom: -7px;
}
@media screen and (max-width: 820px) {
	iframe{
		height: 200px;
		aspect-ratio: auto;
	}
}
/*==================================================================================================*/
/*footer-*/
footer{
	padding: 24px 0 18px;
	background: var(--main-color);
}
footer .inner{
	width: 96%;
	max-width: 96%;
	margin-bottom: 60px;
}
footer .inner div{
	width: fit-content;
}
footer h2{
	width: fit-content;
	margin-bottom: 20px; 
}
footer h2 a{
	display: block;
}
footer h2 a:hover{
	opacity: .7;
}
footer h2 img:nth-child(1){
	width: 127px;
}
footer h2 img:nth-child(2){
	width: 160px;
	margin-left: 8px;
}
footer dl{
	width: 370px;
}
footer dl dt{
	width: 55px;
	font-size: 12px;
	letter-spacing: 0.1em;
	color: #FFF;
	margin-bottom: 5px;
}
footer dl dd{
	width: calc( 100% - 80px );
	font-size: 12px;
	letter-spacing: 0.1em;
	color: #FFF;
	margin-bottom: 5px;
}
footer dl dd::before{
	display: inline-block;
	content: "";
	width: 12px;
	height: 12px;
	background: center / contain no-repeat url("../img/icon-map.svg");
	margin-right: 10px;
}
footer div:nth-child(2){
	width: 676px;
}
footer .nav li a{
	color: #FFF;
}
footer .nav li a:hover{
	opacity: .7;
}
footer .nav li a.btn{
	color: var(--main-color);
	background: #FFF;
}
footer .nav li a.btn:hover{
	opacity: 1;
}
small{
	display: block;
	font-size: 10px;
	text-align: center;
	color: #FFF;
}
@media screen and (max-width: 1120px) {
	footer div:nth-child(2){
		width: 100%;
		margin-top: 20px;
		justify-content:flex-start;
	}
	footer .nav{
		margin-right: 20px;
	}
}
@media screen and (max-width: 820px) {
	footer{
		padding: 24px 0 18px;
	}
	footer .inner{
		width: 90%;
		max-width: 90%;
	}
	footer .inner div{
		width: 100%;
		margin-bottom: 40px;
	}
	footer h2{
		width: 100%;
	}
	footer h2 img:nth-child(1){
		width: 100px;
	}
	footer h2 img:nth-child(2){
		width: 140px;
	}
	footer dl{
		width: 100%;
	}
	footer dl dt{
		font-size: 10px;
	}
	footer dl dd{
		width: calc( 100% - 55px );
		font-size: 10px;
	}
}
@media screen and (max-width: 767px) {
	footer .nav{
		width: 100%;
	}
	footer .nav li{
		width: 100%;
		margin-bottom: 10px;
	}
}