@charset "utf-8";
body,div,dl,dt,dd,ul,ol,li,p,h1,h2,h3,h4,h5,h6,th,td,pre,code,blockquote,form,fieldset,legend,input,textarea,figcaption,figure{margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:normal}li{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal}q:before,q:after{content:''}abbr,acronym{border:0;font-variant:normal}sup{vertical-align:text-top}sub{vertical-align:text-bottom}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit}input,textarea,select{*font-size:100%}legend{color:var(--color-white)}hr{display:none}img{vertical-align:bottom}select,input,button,textarea{font-size:99%}table{font-size:inherit;font:100%;border-collapse:collapse;border-spacing:0}pre,code,kbd,samp,tt{font-family:monospace;*font-size:108%;line-height:100%}.hd{display:block;width:0;height:0;overflow:hidden}.cf:before,.cf:after{content:"";display:table}.cf:after{clear:both}.cf{*zoom:1}article,aside,details,figcaption,figure,footer,header,hgroup,hr,menu,nav,section,main{display:block}*{margin:0;padding:0;box-sizing:border-box;max-height:999999px;outline:none;}*:focus{outline: none;}button{background-color:transparent;border:none;cursor:pointer;outline:none;padding:0;}
/*-----------------------------------------------
 * Bace
 * Common
 * Modal
 * Header
 * Parts
-------------------------------------------------*/
/*-----------------------------------------------
 * Bace
-------------------------------------------------*/
:root{
	/* color */
	--color-black: #000;
	--color-white: #fff;
	--color-grey: #ebebeb;
	--color-grey02: #888888;
	--color-red: #e20000;
	--color-blue: #149dcc;

	/* font */
	--main-font-family: "Noto Sans JP", sans-serif;
	--f-en: "Roboto Condensed", sans-serif;

	/* vw min 計算 => min(calc(数値 / var(--vw-min) * 100vw), 数値); */
	--vw-min: 1200;
}
@media screen and (max-width:768px) {
	:root {
		/* vw min 計算 => min(calc(数値 / var(--vw-min) * 100vw), 数値); */
		--vw-min: 750;
	}
}
body{
	-webkit-text-size-adjust: 100%;
	background-color: var(--color-grey);
	color: var(--color-black);
	font-family: var(--main-font-family);
	font-feature-settings: "palt";
	font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
	font-weight: normal;
	letter-spacing: 0.07em;
	line-height: 1.8;
	word-wrap: break-word;
}
.pc{ display: block; }
.sp{ display: none; }
a{ color: #222; }
a:hover{ text-decoration: none; }
.ah { transition: opacity .3s ease; }
.ah:hover { opacity: .7; }
::selection{
	background: #6ccfee;
	color: var(--color-white);
}
::-moz-selection{
	background: #6ccfee;
	color:var(--color-white);
}
@media screen and (max-width:768px){ 
	html{ 
		font-size: 62.5%;
	}
	body{
		font-size: 10px; 
		font-size: 1rem;
		min-width: 320px;
	}
	.sp{ display: block; }
	.pc{ display: none; }
	.ah:hover { opacity: 1; }
}
/* Adobe font */
.wf-loading {
	opacity: 0;
}
.wf-active {
	opacity: 1;
	transition: opacity 0.3s ease;
}
/*------------------------------------------
* Common
-------------------------------------------*/
/* color */
.c-black {
	color: var(--color-black);
}
.c-white {
	color: var(--color-white);
}
/* font en */
.is-font-en {
    font-family: var(--en-font-family);
}
.is-centerSlide {
	display: inline-block;
	line-height: 1;
	padding: 0 min(calc(8 / var(--vw-min) * 100vw), 8px);
}
@media screen and (max-width:768px){ 
	.is-centerSlide {
		padding: 0 calc(8 / var(--vw-min) * 100vw);
	}
}
/* bg */
#fullWrap {
	position: relative;
	width: 100%;
}

.sub #fullWrap{
	background-color: #eaeced;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
.sub #fullWrap::before{
    display: block;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    -webkit-mask: url(../img/common/deco/bg_dots.png) left top;
    mask: url(../img/common/deco/bg_dots.png) left top;
    mask-size:4px auto;
    background-color: #FFF;
    z-index: 0;
    pointer-events: none;
}
.sub .subContents{
	opacity: 0;
	transition: opacity .4s ease;
}
.sub.--loaded .subContents{
	opacity: 1;
}
.sub .area__contents{
	opacity: 0;
	transform: translateY(40px);
	transition: opacity .6s ease, transform .6s ease;
		transition-delay: .8s;

}
.sub.--loaded .area__contents{
	opacity: 1;
	transform: translateY(0);
	transition-delay: .8s;
}

/*-----------------------------------------
linkBtn
------------------------------------------*/

.linkBtn__link{
    background-color: var(--color-blue);
    color: #FFF;
    font-family: var(--f-en);
    font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
    border-radius: min(calc(20 / var(--vw-min) * 100vw), 20px);
    width: min(calc(200 / var(--vw-min) * 100vw), 200px);
    height: min(calc(40 / var(--vw-min) * 100vw), 40px);
    display: flex;
    text-decoration: none;
    align-items: center;
    justify-content: center;
    position: relative;
	border: 2px solid #149dcc;
	transition: all .4s ease;
}

.linkBtn__arrow{
    background: #FFF;
    border-radius: 50%;
    width: min(calc(36 / var(--vw-min) * 100vw), 36px);
    height: min(calc(36 / var(--vw-min) * 100vw), 36px);
    position: absolute;
    right:0;
    top: 0;
    bottom: 0;
    margin: auto;
	transition: all .4s ease;
}
.linkBtn__arrow::after{
    content: "";
    background-color: var(--color-blue);
    -webkit-mask: url(../img/common/icon/ic_arrow.svg) no-repeat center center / contain;
    mask: url(../img/common/icon/ic_arrow.svg) no-repeat center center / contain;
    width: min(calc(16 / var(--vw-min) * 100vw), 16px);
    height: min(calc(17 / var(--vw-min) * 100vw), 17px);
    position: absolute;
    inset: 0;
    margin: auto;
	transition: all .4s ease;
}
.linkBtn__arrow.-btm::after{
    transform: rotate(90deg);
}
.linkBtn__arrow.-prev{
	left: 0;
	right: unset;
    transform: rotate(-180deg);
}

@media screen and (max-width:768px){
	.linkBtn__link{
		width: calc(240 / var(--vw-min) * 100vw);
		height:calc(60 / var(--vw-min) * 100vw);
		border-radius: calc(60 / var(--vw-min) * 100vw);
		font-size: calc(28 / var(--vw-min) * 100vw);
	}
	.linkBtn__arrow{
		width: calc(54 / var(--vw-min) * 100vw);
		height:calc(54 / var(--vw-min) * 100vw);

	}
	.linkBtn__arrow::after{
		width: calc(24 / var(--vw-min) * 100vw);
		height: calc(25 / var(--vw-min) * 100vw);
	}
}

.linkBtn__link:hover{
    background-color: #FFF;
}
.linkBtn__link:hover .linkBtn__txt{
    color: var(--color-blue);
}
.linkBtn__link:hover .linkBtn__arrow{
    background: var(--color-blue);
}
.linkBtn__link:hover .linkBtn__arrow::after{
    background-color: #FFF;
}
.linkBtn__link:hover .linkBtn__arrow::after{
	/*transform: rotate(90deg) translateX(2px);*/
	transform: scale(0.8);
}
.linkBtn__link:hover .linkBtn__arrow.-btm::after{
	/*transform: rotate(90deg) translateX(2px);*/
	transform:rotate(90deg) scale(0.8);
}
.linkBtn__link:hover .linkBtn__arrow.-prev::after{
    transform:scale(0.8);
}
/*-----------------------------------------
sub common
------------------------------------------*/
.areaTtl{
    display: flex;
    align-items: center;
    margin-bottom:min(calc(80 / var(--vw-min) * 100vw), 80px);
}
.areaTtl__circle{
    width: min(calc(32 / var(--vw-min) * 100vw), 32px);
    height: min(calc(32 / var(--vw-min) * 100vw), 32px);
    -webkit-mask: url(../img/common/deco/deco_circle.png) no-repeat center center / contain;
    mask: url(../img/common/deco/deco_circle.png) no-repeat center center / contain;
    background-color: #000;
}
.areaTtl__circle.-w{
    background-color: #FFF;
}
.areaTtl__txt{
    font-size: min(calc(44 / var(--vw-min) * 100vw), 44px);
    color: #149dcc;
    line-height: 1;
    margin-left: min(calc(16 / var(--vw-min) * 100vw), 16px);
    font-family: var(--f-en);
}
.areaTtl__txt.-w{
    color: #FFF;
}


/*-----------------------------------------------
 * Modal
-------------------------------------------------*/
/**
 * modalBox
 * 基盤のモーダル
 */
.modalBox{
	-webkit-overflow-scrolling: touch;
	background: rgba(255,255,255,.9);
	display: none;
	width: 100%;
	height: 100%;
	overflow: auto;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}
.oneModal{
	display: none;
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 1;
}
/* oneModalIn */
.oneModalIn{
	display: flex;
	justify-content: center;
	align-items: center;
	height: auto;
	width: 100%;
	min-height: 100%;
	margin: 0 auto;
	position: relative;
}
.oneModalIn__cont{
	padding: 50px 0;
}
@media screen and (max-width:768px){
	.oneModalIn{
		min-width: 100%;
	}
	.oneModalIn__cont{
		width: 100%;
		padding: 30px 0;
	}
}
/**
 * closeBtn
 */
.closeBtn{
	width: min(calc(60 / var(--vw-min) * 100vw), 60px);
	height:min(calc(60 / var(--vw-min) * 100vw), 60px);
	position: absolute;
	top: min(calc(24 / var(--vw-min) * 100vw), 24px);
	right: min(calc(24 / var(--vw-min) * 100vw), 24px);
	z-index: 2;
}
@media screen and (max-width:768px){
	.closeBtn{
		width: calc(96 / var(--vw-min) * 100vw);
		height: calc(96 / var(--vw-min) * 100vw);
	}
}
.closeBtn a{
	background: var(--color-black);
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
	border-radius: 50%;
}
.closeBtn .line{
	display: block;
	width: min(calc(40 / var(--vw-min) * 100vw), 40px);
	height:min(calc(40 / var(--vw-min) * 100vw), 40px);
	position: relative;
}
.line span{
	display: block;
	height: 2px;
	width: min(calc(40 / var(--vw-min) * 100vw), 40px);
	background-color: #FFF;
	display: block;
	position: absolute;
	top: 50%;
	bottom: 50%;
	transform: rotate(135deg);
}
.line span:nth-child(2) {
        top: 50%;
        bottom: 50%;
        transform: rotate(-135deg);
 }
/**
 * iframe
 */
/* common */
.commonIframe{
	width: 100%;
	height: 100%;
	display: block;
}
/* youtube */
.youtubeIframeWrap {
	width: 70%;
	max-width: 159.993vh;
	position: relative;
}
@media screen and (max-width:768px){
	.youtubeIframeWrap {
		width: 100%;
		max-width: 100%;
	}
}
.youtubeIframeWrap:before{
	content: "";
	display: block;
	padding-top: 56.25%;
	z-index: 0;
}
.youtubeIframe{
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
/*-----------------------------------------------
 * Header
-------------------------------------------------*/
.header {
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 999;
}
@media screen and (max-width:768px){
	.header {
		top: 0;
		bottom: auto;
	}
}
.headerNavLists {
	display: flex;
    flex-wrap: wrap;
}
@media screen and (max-width:768px){
	.headerNavLists {
		width: 100%;
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		margin-top: calc(180 / var(--vw-min) * 100vw);
	}
}
.headerNavItem a {
	font-family: var(--f-en);
	font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
	color: #FFF;
	text-decoration: none;
	margin: 0 min(calc(12 / var(--vw-min) * 100vw), 12px);
}
.is-works .headerNavItem a,
.is-news .headerNavItem a {
	color: #000;
}
/* sub */
.sub .headerNavItem a {
	color: #000;
}
@media screen and (max-width:768px){
	.headerNavItem {
		line-height: 1;
		text-align: center;
		margin-bottom: calc(60 / var(--vw-min) * 100vw);
	}
	.headerNavItem a {
		font-size: calc(32 / var(--vw-min) * 100vw);
		color: var(--color-black);
		margin: 0;
	}
}
.header-logo{
	opacity: 0;
	transition: opacity .4s ease;
}
.header.is-scrolled .header-logo{
	opacity: 1;
}
.header-logo a {
	display: block;
	width: min(calc(121 / var(--vw-min) * 100vw), 121px);
	height: min(calc(50 / var(--vw-min) * 100vw), 50px);
	-webkit-mask: url(../img/common/logo/logo_mark.svg)no-repeat center/contain;
	mask: url(../img/common/logo/logo_mark.svg)no-repeat center/contain;
	background-color: #000;
	transition: all .4s ease;
}
.is-fv .header-logo a,
.is-portfolio .header-logo a,
.is-mission .header-logo a {
	background-color: #fff;
}
@media screen and (max-width:768px){
	.is-active .header-logo{
		position: absolute;
		opacity: 1;
		left: 0;
		right: 0;
		top: calc(40 / var(--vw-min) * 100vw);
		width: calc(180 / var(--vw-min) * 100vw);
        height: calc(69 / var(--vw-min) * 100vw);
		margin: auto;
	}
	.header-logo a {
		width: 100%;
		height: 100%;
		-webkit-mask: url(../img/common/logo/logo_mark.svg)no-repeat center/contain;
		mask: url(../img/common/logo/logo_mark.svg)no-repeat center/contain;
		background-color: #000;
		transition: all .4s ease;
	}
}
@media screen and (max-width:768px){
	.subPagelogo{
		position: fixed;
		opacity: 1;
		left: 0;
		right: 0;
		top: calc(40 / var(--vw-min) * 100vw);
		width: calc(180 / var(--vw-min) * 100vw);
		height: calc(69 / var(--vw-min) * 100vw);
		margin: auto;
		z-index: 10;
	}
	.subPagelogo a {
		display: block;
		width: 100%;
		height: 100%;
		-webkit-mask: url(../img/common/logo/logo_mark.svg)no-repeat center/contain;
		mask: url(../img/common/logo/logo_mark.svg)no-repeat center/contain;
		background-color: #000;
		transition: all .4s ease;
	}
}
/* sub */
.sub .header-logo {
	opacity: 1;
}

.header__snsLink {
	position: relative;
	display: flex;
    align-items: center;
}
@media screen and (max-width:768px){ 
	.header__snsLink {
		margin: calc(224 / var(--vw-min) * 100vw) auto 0;
	}
}
.header__snsLink a {
	font-family: var(--en-font-family);
	font-size: min(calc(14 / var(--vw-min) * 100vw), 14px);
	color: var(--color-black);
	font-weight: 700;
	text-decoration: none;
	display: block;
	padding-right: min(calc(30 / var(--vw-min) * 100vw), 30px);

}
@media screen and (max-width:768px){ 
	.header__snsLink a {
		font-size: calc(28 / var(--vw-min) * 100vw);
		padding-right: calc(60 / var(--vw-min) * 100vw);
	}
}
.header__snsLink.is-tw a::before {
	content: "";
	width: min(calc(20 / var(--vw-min) * 100vw), 20px);
	height: min(calc(20 / var(--vw-min) * 100vw), 20px);
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto;
	-webkit-mask: url(../img/common/sns/icon_tw.svg)no-repeat center/ contain;
	mask: url(../img/common/sns/icon_tw.svg)no-repeat center/ contain;
	background-color: var(--color-black);
}
@media screen and (max-width:768px){ 
	.header__snsLink.is-tw a::before {
		width: calc(40 / var(--vw-min) * 100vw);
		height: calc(40 / var(--vw-min) * 100vw);
	}
}
/* inner */
@media screen and (max-width:768px){
	.header__inner {
		width: 100%;
		min-height: 100vh;
		min-height: 100dvh;
		position: absolute;	
		padding: 0;
		display: block;
		pointer-events: none;
		overflow: auto;
		overscroll-behavior: contain;
		top: 0;
		left: 0;
		bottom: 0;
		opacity: 0;
		transition: opacity .5s ease-in-out;
	}
	.header.is-active .header__inner {
		opacity: 1;
		pointer-events: auto;
	}
	.header__inner:before {
		content: "";
		background: rgba(255,255,255,.9);
		position: fixed;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		z-index: 0;
	}
}
/**
 * headerNav
 */
 .headerNav {
	display: flex;
	align-items: center;
	padding: 0 min(calc(24 / var(--vw-min) * 100vw), 24px);
	height: min(calc(80 / var(--vw-min) * 100vw), 80px);
	justify-content: space-between;
 }
 body.top .headerNav {
	background-color: unset;
 }

@media screen and (max-width:768px){
	.headerNav {
		position: relative;
		z-index: 1;
		flex-direction: column;
		padding: calc(50 / var(--vw-min) * 100vw) calc(48 / var(--vw-min) * 100vw) calc(96 / var(--vw-min) * 100vw);
		height: unset;
	}
}
/**
 * navBtn
 */
@media screen and (max-width:768px){
	.header__navBtnWrap {
		background-color: var(--color-black);
		width: calc(96 / var(--vw-min) * 100vw);
		height: calc(96 / var(--vw-min) * 100vw);
		position: absolute;
		top: calc(24 / var(--vw-min) * 100vw);
		right: calc(24 / var(--vw-min) * 100vw);
		z-index: 2;
		border-radius: 50%;
	}
	.header__navBtn {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 100%;
		position: relative;
		transition: .4s ease;
	}
	.header__navBtn__lineWrap {
		width: calc(48 / var(--vw-min) * 100vw);
		height: calc(16 / var(--vw-min) * 100vw);
		position: relative;
	}
	.header__navBtn--line {
		background-color: var(--color-white);
		display: block;
		width: 100%;
		height: calc(2 / var(--vw-min) * 100vw);
		margin: auto;
		position: absolute;
		transition: .4s ease;
	}
	.header__navBtn--line:nth-child(1) {
		top: 0;
	}
	.header__navBtn--line:nth-child(2) {
		bottom: 0;
	}
	.header__navBtn.is-active .header__navBtn__lineWrap {
		transform: rotateX(360deg);
	}
	.header__navBtn.is-active .header__navBtn--line {
		background-color: var(--color-black);
	}
	.header__navBtn.is-active .header__navBtn--line:nth-child(1) {
		top: 50%;
		bottom: 50%;
		transform: rotate(135deg);
	}
	.header__navBtn.is-active .header__navBtn--line:nth-child(2) {
		top: 50%;
		bottom: 50%;
		transform: rotate(-135deg);
	}
}
@media screen and (min-width:767px){
	body.top .header-logo a.is-active {
		opacity: 1;
		pointer-events: auto;
	}
}
/* SNS */
.header__snsListsWrap{
	margin-left: min(calc(20 / var(--vw-min) * 100vw), 20px);
	height: min(calc(40 / var(--vw-min) * 100vw), 40px);
	display: flex;
	align-items: center;
	z-index: 10;
	/*position: absolute;
	right: min(calc(40 / var(--vw-min) * 100vw), 40px);
	top: min(calc(20 / var(--vw-min) * 100vw), 20px);*/
}
.snsLists__ttl{
	font-family: var(--f-en);
	font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
	line-height: 1;
	letter-spacing: min(calc(0.16 / var(--vw-min) * 100vw), 0.16px);
	color: #aaaaaa;
	margin-right:min(calc(20 / var(--vw-min) * 100vw), 20px);
}
.snsLists{
	display: flex;
	gap: min(calc(16 / var(--vw-min) * 100vw), 16px);
}
@media screen and (max-width:768px){
	.header__snsListsWrap{
		position: relative;
		right: unset;
		margin-left: unset;
		height:unset;
		flex-direction: column;
	}
	.header__snsListsWrap .snsLists__ttl{
		font-size: calc(24 / var(--vw-min) * 100vw);
		margin-bottom: calc(24/ var(--vw-min) * 100vw);
		margin-right:unset;
	}
	.header__snsListsWrap .snsLists{
		gap:calc(32 / var(--vw-min) * 100vw);
	}
}

.snsItem{
	border-radius: min(calc(100 / var(--vw-min) * 100vw), 100px);
}
.snsItem__link{
	display: flex;
    align-items: center;
    justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
}
.snsItem__link::before{
	display: block;
	content: "";
	background-color: #FFF;
	mask-size: contain;
	mask-repeat: no-repeat;
	mask-position: center center;
	transition: all .4s ease;
}
.sub .snsItem__link::before,
.is-works .snsItem__link::before,
.is-news .snsItem__link::before {
	background-color: #000;
}
.snsItem__link:hover::before{
	background-color: #149dcc;
}


/* 各SNSパーツ */
.snsItem.is-tw .snsItem__link:before {
	width: min(calc(19 / var(--vw-min) * 100vw), 19px);
	height: min(calc(20 / var(--vw-min) * 100vw), 20px);
	-webkit-mask-image: url(../img/common/sns/icon_x.svg);
	mask-image: url(../img/common/sns/icon_x.svg);
}
.snsItem.is-fb .snsItem__link:before  {
	width: min(calc(20 / var(--vw-min) * 100vw), 20px);
	height: min(calc(19 / var(--vw-min) * 100vw), 19px);
	-webkit-mask-image: url(../img/common/sns/icon_fb.svg);
	mask-image: url(../img/common/sns/icon_fb.svg);
}
.snsItem.is-ig .snsItem__link:before {
	width:  min(calc(19 / var(--vw-min) * 100vw), 19px);
	height: min(calc(19 / var(--vw-min) * 100vw), 19px);
	-webkit-mask-image: url(../img/common/sns/icon_ig.svg);
	mask-image: url(../img/common/sns/icon_ig.svg);
}
/*
.snsItem.is-yt .snsItem__link:before {
	width:  min(calc(26 / var(--vw-min) * 100vw), 26px);
	height: min(calc(18 / var(--vw-min) * 100vw), 18px);
	-webkit-mask-image: url(../img/common/sns/icon_yt.svg);
	mask-image: url(../img/common/sns/icon_yt.svg);
}
.snsItem.is-tiktok .snsItem__link:before {
	width:  min(calc(19 / var(--vw-min) * 100vw), 19px);
	height: min(calc(22 / var(--vw-min) * 100vw), 22px);
	-webkit-mask-image: url(../img/common/sns/icon_tiktok.svg);
	mask-image: url(../img/common/sns/icon_tiktok.svg);
}
*/

@media screen and (max-width:767px){
	.header__snsListsWrap .snsItem__link::before{
		background-color: #000;
	}
	.header__snsListsWrap .snsItem.is-tw .snsItem__link:before {
		width: calc(48 / var(--vw-min) * 100vw);
		height: calc(48 / var(--vw-min) * 100vw);
	}
	.header__snsListsWrap .snsItem.is-fb .snsItem__link:before  {
		width: calc(48 / var(--vw-min) * 100vw);
		height: calc(48 / var(--vw-min) * 100vw);
	}
	.header__snsListsWrap .snsItem.is-ig .snsItem__link:before {
		width: calc(48 / var(--vw-min) * 100vw);
		height: calc(48 / var(--vw-min) * 100vw);
	}
}

/*------------------------------------------
* contact
-------------------------------------------*/
.contact {
    padding: min(calc(160 / var(--vw-min) * 100vw), 160px) 0;
    background-color: var(--color-black);
    position: relative;
}
@media screen and (max-width:768px){ 
	.contact {
		padding: calc(145 / var(--vw-min) * 100vw) 0 calc(96 / var(--vw-min) * 100vw);
	}
}
.contact .slider-tit {
    width: 100%;
    height: min(calc(161 / var(--vw-min)* 100vw), 161px);
    position: absolute;
    top: min(calc(80 / var(--vw-min) * 100vw), 80px);
    right: 0;
    left: 0;
    -webkit-mask: url(../img/top/slider-tit/slider-tit_contact.svg) repeat-x 0 center / min(calc(873 / var(--vw-min)* 100vw), 873px) min(calc(161 / var(--vw-min)* 100vw), 161px);
    mask: url(../img/top/slider-tit/slider-tit_contact.svg) repeat-x 0 center / min(calc(873 / var(--vw-min)* 100vw), 873px) min(calc(161 / var(--vw-min)* 100vw), 161px);
    background: var(--color-white);
    animation: contactSliderTit 30s linear reverse infinite;
}
@media screen and (max-width:768px){ 
	.contact .slider-tit {
		height: calc(145 / var(--vw-min)* 100vw);
		top: calc(96 / var(--vw-min) * 100vw);
		-webkit-mask: url(../img/top/slider-tit/slider-tit_contact.svg) repeat-x 0 center / calc(788.2 / var(--vw-min)* 100vw) calc(145 / var(--vw-min)* 100vw);
		mask: url(../img/top/slider-tit/slider-tit_contact.svg) repeat-x 0 center /calc(788.2 / var(--vw-min)* 100vw) calc(145 / var(--vw-min)* 100vw);
	}
}
.contact .slider-tit::before {
    content: "";
    width: 100%;
    height: min(calc(90 / var(--vw-min) * 100vw), 90px);
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(0deg, var(--color-black) 0%, transparent 100%);
}
@media screen and (max-width:768px){ 
	.contact .slider-tit::before {
		height: calc(96 / var(--vw-min) * 100vw);
	}
}
@keyframes contactSliderTit{
	0%{
		mask-position:0 center;
		-webkit-mask-position:0 center;
	}
	100%{
		mask-position:min(calc(873 / var(--vw-min) * 100vw), 873px) center;
		-webkit-mask-position:min(calc(873 / var(--vw-min) * 100vw), 873px) center;
	}
}
@media screen and (max-width:768px){ 
	@keyframes contactSliderTit{
		0%{
			mask-position:0 center;
			-webkit-mask-position:0 center;
		}
		100%{
			mask-position: calc(788.2 / var(--vw-min) * 100vw) center;
			-webkit-mask-position: calc(788.2 / var(--vw-min) * 100vw) center;
		}
	}
}
/*-----------------------------------------------
 * Footer
-------------------------------------------------*/
.footer {
	padding: min(calc(80 / var(--vw-min) * 100vw), 40px) 0 min(calc(80 / var(--vw-min) * 100vw), 80px);
	background-color: var(--color-black);
	position: relative;
	overflow: hidden;
	margin-top: auto;
}
@media screen and (max-width:768px){ 
	.footer {
		padding: calc(60 / var(--vw-min) * 100vw) 0 calc(48 / var(--vw-min) * 100vw);
	}
}
.footerWrap {
	display: flex;
    justify-content: flex-start;
	padding: 0 min(calc(40 / var(--vw-min) * 100vw), 40px);
}
@media screen and (max-width:768px){ 
	.footerWrap {
		flex-direction: column;
		padding: 0 calc(48 / var(--vw-min) * 100vw);
	}
	.footer__navWrap {
	}
}
.footer__navLists {
	width: min(calc(560 / var(--vw-min) * 100vw), 560px);
	display: flex;
	flex-wrap: wrap;
	margin-top: min(calc(40 / var(--vw-min) * 100vw), 40px);
}
@media screen and (max-width:768px){ 
	.footer__navLists {
		width: calc(583 / var(--vw-min) * 100vw);
		justify-content: center;
		margin-top: calc(96 / var(--vw-min) * 100vw);
	}
}
.footer__navItem a {
	font-family: var(--en-font-family);
	font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
	color: var(--color-white);
	font-weight: 700;
	text-decoration: none;
	margin: 0 min(calc(12 / var(--vw-min) * 100vw), 12px);
}
@media screen and (max-width:768px){ 
	.footer__navItem {
		margin-top: calc(22 / var(--vw-min) * 100vw);
	}
	.footer__navItem:nth-child(-n+3) {
		margin-top: 0;
	}
	.footer__navItem a {
		font-size: calc(24 / var(--vw-min) * 100vw);
		margin: 0 calc(44 / var(--vw-min) * 100vw);
	}
}

.footer__navWrap{
	display: flex;
    flex-direction: column;
}
/* FOOTER > NAV */
.footerNavLists{
	display: flex;
	width:min(calc(200 / var(--vw-min) * 100vw), 200px);
	height:min(calc(105 / var(--vw-min) * 100vw), 105px);
	flex-direction: column;
	flex-wrap: wrap;
}
.footerNavItem a{
	font-size:min(calc(16 / var(--vw-min) * 100vw), 16px);
	color: #FFF;
	font-family: var(--f-en);
	text-decoration: none;
	line-height: 1;
}


@media screen and (max-width:768px){ 
	.footerNavLists{
		width:70%;
		height:auto;
		flex-wrap: wrap;
        flex-direction: row;
		margin-bottom: calc(48 / var(--vw-min) * 100vw);
	}
	.footerNavItem{
		width: 50%;
		margin-bottom: calc(16 / var(--vw-min) * 100vw);
	}
	.footerNavItem a{
		font-size:calc(28 / var(--vw-min) * 100vw);
	}
	.footerNavLists .ic_blank{
		-webkit-mask: url(../img/common/icon/ic_blank.svg) no-repeat center center / calc(14 / var(--vw-min) * 100vw) auto;
		mask: url(../img/common/icon/ic_blank.svg) no-repeat center center / calc(14 / var(--vw-min) * 100vw) auto;
		width: calc(20 / var(--vw-min) * 100vw);
		height:calc(20 / var(--vw-min) * 100vw);
	}
}
/* FOOTER > SNS */
.footer__snsListsWrap{
	display: flex;
    align-items: center;
}
.footer__snsListsWrap .snsItem__link::before {
	background-color: #FFF;
}
.footer__snsListsWrap .snsItem__link:hover::before {
	background-color: #149dcc;
}


@media screen and (max-width:768px){ 
	.footer__snsListsWrap  .snsLists__ttl{
		font-size: calc(24 / var(--vw-min) * 100vw);
	}
	.footer__snsListsWrap .snsLists{
		gap:calc(32 / var(--vw-min) * 100vw);
	}
    .footer__snsListsWrap .snsItem.is-tw .snsItem__link:before {
        width: calc(48 / var(--vw-min) * 100vw);
        height: calc(48 / var(--vw-min) * 100vw);
    }
	.footer__snsListsWrap .snsItem.is-ig .snsItem__link:before {
        width: calc(48 / var(--vw-min) * 100vw);
        height: calc(48 / var(--vw-min) * 100vw);
    }
	.footer__snsListsWrap .snsItem.is-fb .snsItem__link:before {
        width: calc(48 / var(--vw-min) * 100vw);
        height: calc(48 / var(--vw-min) * 100vw);
    }
}
/* LOGO */
.footer__logo{
	margin-right: min(calc(80 / var(--vw-min) * 100vw), 80px);
}
.footer__logo a {
	width: min(calc(163 / var(--vw-min) * 100vw), 163px);
	height:	min(calc(87 / var(--vw-min) * 100vw), 87px);
	display: block;
	-webkit-mask: url(../img/common/logo/logo.svg)no-repeat center/contain;
	mask: url(../img/common/logo/logo.svg)no-repeat center/contain;
	background-color: var(--color-white);
}
@media screen and (max-width:768px){ 
	.footer__logo{
		margin-right:unset;
		margin-bottom: calc(96 / var(--vw-min) * 100vw);
	}
	.footer__logo a {
		width: calc(236 / var(--vw-min) * 100vw);
        height: calc(120 / var(--vw-min) * 100vw);
	}
}
/* footer scroll top */

/*
.footer__scTop a {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid rgba(255,255,255,.4);
	display: block;
	position: relative;
	pointer-events: auto;
	background-color: #000;
}*/
@media screen and (max-width:768px){ 
	.footer__scTop {
		position: absolute;
		top: 0;
		right: calc(60 / var(--vw-min) * 100vw);
		padding-top: calc(120 / var(--vw-min) * 100vw);
	}
	.footer__scTop a{
		width: calc(80 / var(--vw-min) * 100vw);
		height: calc(80 / var(--vw-min) * 100vw);
	}
}
/*
.footer__scTop a::before {
	content: "";
	width: 1px;
	height: 40px;
	background-color: var(--color-white);
	position: absolute;
	bottom: 20px;
	right: 0;
	left: 0;
	margin: auto;
	pointer-events: none;
}
.footer__scTop a::after {
	content: "";
	width: 1px;
	height: 80px;
	background-color: var(--color-white);
	opacity: 0.4;
	position: absolute;
	top: -60px;
	right: 0;
	left: 0;
	margin: auto;
	pointer-events: none;
}
@media screen and (max-width:768px){ 
	.footer__scTop a::before {
		height: calc(80 / var(--vw-min) * 100vw);
		bottom: calc(40 / var(--vw-min) * 100vw);
	}
	.footer__scTop a::after {
		height: calc(158 / var(--vw-min) * 100vw);
		top: calc(-120 / var(--vw-min) * 100vw);
	}
}
@media (hover: hover) and (pointer: fine) {
    .footer__scTop a:hover::before {
		height: 80px;
		transition: all .4s ease;
    }
}
*/






/* scroll top */
.footer__scTop{
	position: absolute;
	right: min(calc(60 / var(--vw-min) * 100vw), 60px);
	top: 0;
	padding-top:min(calc(60 / var(--vw-min) * 100vw), 60px);
	width:min(calc(40 / var(--vw-min) * 100vw), 40px);
}
@media screen and (max-width:768px){ 
	.footer__scTop {
		position: absolute;
		top: 0;
		right: calc(120 / var(--vw-min) * 100vw);
		padding-top: calc(120 / var(--vw-min) * 100vw);
	}
}

.scLink{
    position: relative;
    z-index: 10;
    display: block;
    width: 100%;
    height: 100%;
}

/* circle */
.sc__circle{
	width: min(calc(40 / var(--vw-min) * 100vw), 40px);
	height: min(calc(40 / var(--vw-min) * 100vw), 40px);
	border-radius: 50%;
	border: 1px solid rgba(255,255,255,.4);
	display: block;
	position: relative;
	pointer-events: auto;
	background-color: rgba(0, 0, 0,0.6);
}
.footer__scTop .scLink .sc__circle::before {
	content: "";
	width: 1px;
	height: min(calc(40 / var(--vw-min) * 100vw), 40px);
	background-color: var(--color-white);
	position: absolute;
	bottom: min(calc(20 / var(--vw-min) * 100vw), 20px);
	right: 0;
	left: 0;
	margin: auto;
	pointer-events: none;
	transition: all .4s ease;
}
.footer__scTop .scLink .sc__circle::after {
	content: "";
	width: 1px;
	height: min(calc(79 / var(--vw-min) * 100vw), 79px);
	background-color: var(--color-white);
	opacity: 0.4;
	position: absolute;
	top: max(calc(-60/ var(--vw-min) * 100vw), -60px);
	right: 0;
	left: 0;
	margin: auto;
	pointer-events: none;
}
@media screen and (max-width:768px){ 
	.sc__circle{
        width: calc(80 / var(--vw-min) * 100vw);
        height: calc(80 / var(--vw-min) * 100vw);
    }
    .footer__scTop .scLink .sc__circle::before {
        height: calc(80 / var(--vw-min) * 100vw);
        bottom: calc(40 / var(--vw-min) * 100vw);
    }
	.footer__scTop .scLink .sc__circle::after {
		height: calc(158 / var(--vw-min) * 100vw);
		top: calc(-120 / var(--vw-min) * 100vw);
	}
}

/* light */
.deco_light{
    position: absolute;
    display: block;
    top: max(calc(-22 / var(--vw-min) * 100vw), -22px);
    left: max(calc(-22 / var(--vw-min) * 100vw), -22px);
    margin: auto;
    width: min(calc(82 / var(--vw-min) * 100vw), 82px);
    height: min(calc(82 / var(--vw-min) * 100vw), 82px);
    transition: all .4s ease;
}
.deco_light::before{
    content: "";
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    margin: auto;
    background: url(../img/common/deco/c_light.png) no-repeat center center / 100% auto;
    width: min(calc(82 / var(--vw-min) * 100vw), 82px);
    height: min(calc(82 / var(--vw-min) * 100vw), 82px);
    opacity: 1;
    transition: all .4s ease;
}
.deco_light::after{
    content: "";
    position: absolute;
    display: block;
    top: 0;
    left: max(calc(-21 / var(--vw-min) * 100vw), -21px);
	right: 0;
	bottom: 0;
    margin: auto;
    background: url(../img/common/deco/c_light_over.png) no-repeat center center / 100% auto;
    width: min(calc(124 / var(--vw-min) * 100vw), 124px);
    height: min(calc(124 / var(--vw-min) * 100vw), 124px);
    opacity: 0;
    transition: all .4s ease;
}
@media screen and (max-width:768px){ 
    .deco_light{
        top: calc(-44 / var(--vw-min) * 100vw);
        left: calc(-44 / var(--vw-min) * 100vw);
        width: calc(164 / var(--vw-min) * 100vw);
        height: calc(164 / var(--vw-min) * 100vw);
    }

    .deco_light::before{
        width: calc(164 / var(--vw-min) * 100vw);
        height: calc(164 / var(--vw-min) * 100vw);
    }
    .deco_light::after{
        left: calc(-42 / var(--vw-min) * 100vw);
        width: calc(248 / var(--vw-min) * 100vw);
        height: calc(248 / var(--vw-min) * 100vw);
    }
}



@media (hover: hover) and (pointer: fine) {
    .scLink:hover .deco_light::before{
       opacity: 0.4;
    }
	.scLink:hover .deco_light::after{
        opacity: 1;
    }
    .scLink:hover .sc__circle::before {
		height: calc(80 / var(--vw-min) * 100vw);
    }
}




















.footer__copyright {
	font-family: var(--f-en);
	font-size: min(calc(12 / var(--vw-min) * 100vw), 12px);
	color: var(--color-grey02);
	text-align: right;
	position: absolute;
	right: min(calc(40 / var(--vw-min) * 100vw), 40px);
	bottom: min(calc(40 / var(--vw-min) * 100vw), 40px);
}
@media screen and (max-width:768px){ 
	.footer__copyright {
		position: relative;
		text-align: center;
		font-size:calc(16 / var(--vw-min) * 100vw);
		left: 0;
		right: 0;
		bottom: unset;
		margin: auto;
		margin-top: calc(40 / var(--vw-min) * 100vw);
	}
}
/*-----------------------------------------------
 * Parts
-------------------------------------------------*/
/*----------------------------
* アニメーション
-----------------------------*/

/** transition **/
.is-t4,
.recruit-contItem__icon::before,
.recruit-contItem__icon::after,
.scroll-down a::before,
.footer__scTop a::before {
	transition: .4s ease;
}
/* font slider */
.is-centerSlide {
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 0% 100%;
	background-image: linear-gradient(var(--color-blue), var(--color-blue));
	transition: background-size .6s ease;
}
.is-rightSlide {
	background-repeat: no-repeat;
	background-position: left bottom;
	background-size: 0% 100%;
	background-image: linear-gradient(var(--color-blue), var(--color-blue));
	transition: background-size .6s ease;
}
.is-whiteSlider {
	background-image: linear-gradient(var(--color-white), var(--color-white));
}

/** active **/
.headerNavItem a .headerNavItem__txt {
	background-repeat: no-repeat;
	background-position: left bottom;
	background-size: 0% 100%;
	background-image: linear-gradient(var(--color-blue), var(--color-blue));
	transition: background-size .6s ease;
}
.headerNavItem a.is-active .headerNavItem__txt {
	background-size: 100% 100%;
}
/** active **/
.headerNavItem a.is-active .is-centerSlide,
.footerNavItem a.is-active .is-centerSlide,
.js-header.is-active .header__navBtnWrap {
	background-position: center bottom;
	background-size: 100% 100%;
}
.js-header.is-active .header__navBtnWrap {
	border: calc(2 / var(--vw-min) * 100vw) solid var(--color-black);
	background-color: #FFF;
}
.headerNavItem a.is-active {
	color: var(--color-white);
}
.footer__navItem a.is-active {
	color: var(--color-black);
}
.recruit-contItemBtn.is-active,
.recruit-contItem-textWrap.is-active {
	background-color: var(--color-white);
}
.recruit-contItem__icon.is-active {
	background-color: var(--color-black);
}
.recruit-contItem__icon.is-active::before {
	background-color: var(--color-white);
}
.recruit-contItem__icon.is-active::after {
	opacity: 0;
}
/* 
* hover
*/
@media (hover: hover) and (pointer: fine) {
	/* header footer */
	.headerNavItem a:hover .is-centerSlide,
	.footer__navItem a:hover .is-centerSlide {
		background-position: center bottom;
		background-size: 100% 100%;
	}
	.headerNavItem a:hover .headerNavItem__txt {
		background-size: 100% 100%;
	}
	.headerNavItem a:hover {
		color: var(--color-white);
	}
	.footer__navItem a:hover {
		color: var(--color-black);
	}
	.header-logo:hover,
	.header__snsLink a:hover,
	.footer__logo a:hover,
	.footer__snsLink a:hover  {
		opacity: .7;
	}
	/* news works */
	.news__contItem a:hover {
		background-color: var(--color-white);
		color: var(--color-white);
	}
	.news__contItem a:hover .news__arrow {
		transform:translateX(5px)
	}  
	.works__swiperItem a:hover,
	.works__contItem a:hover {
		color: var(--color-white);
	}
	.works__swiperItem a:hover .works__swiperItem-img img,
	.works__contItem a:hover .works__contItem-img img {
	  transform: scale(1.1);
	}
	.pagerBtn.is-next:hover {
		transform: translateX(5px);
	}
	.worksSwiper-pagerBtnWrap .pagerBtn.is-prev:hover {
		transform: scale(-1, 1) translateX(5px);
	}
	.news__contItem a:hover .is-rightSlide,
	.works__swiperItem a:hover .is-rightSlide,
	.works__contItem a:hover .is-rightSlide {
		background-position: left bottom;
		background-size: 100% 100%;
	}
	/* recruit */
	.recruit-contItem:hover {
		background-color: var(--color-white);
	}
	.recruit-contItem:hover .recruit-contItem__icon::after {
		transform: translateY(10px);
		opacity: 0;
	}
	/* Link Btn */
	.linkBtn a:hover {
		color: var(--color-white);
	}
	.linkBtn.is-w-LinkBtn a:hover {
		color: var(--color-black);
	}
	.linkBtn a:hover::before {
		transform: scale(1);
		opacity: 1;
	}
	.scroll-down a:hover::before {
		transform: translateY(10px);
	}

}

/* ICON */
.ic_blank{
	display: inline-block;
	margin-left:5px;
	-webkit-mask: url(../img/common/icon/ic_blank.svg) no-repeat center center / min(calc(8 / var(--vw-min) * 100vw), 8px) auto;
	mask: url(../img/common/icon/ic_blank.svg) no-repeat center center / min(calc(8 / var(--vw-min) * 100vw), 8px) auto;
    width: min(calc(12 / var(--vw-min) * 100vw), 12px);
    height: min(calc(12 / var(--vw-min) * 100vw), 12px);
	background-color: #888888;
}
/*-------------------------------------
* sub fadein
--------------------------------------*/
.subLoading{
    display: none;
}
body.--loaded .subLoading{
    display: block;
    position:fixed;
	z-index: 10000;
    width: 100%;
    height: 100vh;
    top: 0;
	left: 0;
    transform: scaleX(0);
    background-color: var(--color-black);
	animation: subload 1.2s ease forwards;
}




.area__inner{
	opacity: 0;
	transition: opacity .4s ease;
	transition-delay: .4s;
}
.area__inner.is-ani {
	opacity: 1;
}
.area__contents{
	opacity: 0;
	transform: translateY(20px);
	transition: opacity .4s ease, transform .4s ease;
	transition-delay: .8s;
}
.is-ani .area__contents{
	opacity: 1;
	transform: translateY(0);
}

.js-scrani .areaTtl__txt{
	display: block;
	transform: translate3d(0,100%,0) skewY(12deg);
	transform-origin: left;
	transition: .6s ease-in-out;
}
.is-ani .areaTtl__txt {
	transform: translate3d(0,0,0) skewY(0);
}
@media screen and (max-width:768px){ 
	.area__contents{
		transform: translateY(3vw);
	}
}