@charset "UTF-8";
/* CSS Document */

		
		body {
			font-family: "Noto Sans JP", sans-serif;
			font-optical-sizing: auto;
			font-weight: 200;
			font-style: normal;
			width:100%;
			height: 100vh;
			margin:0;
			padding:0;
			text-align:left;
			font-size:15px;
			line-height:180%;
			letter-spacing: 1px;
			color:#404040;
			background-color:#DEE2E7;}
			
		h1,h2,h3,h4,h5,h6,pre,p,ul,ol,li,dl,dt,dd,th,td,div{
			margin: 0; 
			padding: 0;
			font-weight:normal;
			font-size:100%;}
		
		ul,ol,li,dl,dt,dd{
			list-style-type: none;}
		
		a{color:#404040;
			text-decoration: none; 
			font-family: "Inter", sans-serif;
			font-optical-sizing: auto;
			font-weight: 300;
			font-style: normal;}
	     a:hover{color:#82b8af;}
		
		img {border: none;}
		
		/*
		a:hover img {
		  opacity: 0.9;
		  filter: alpha(opacity=90);
		  -ms-filter: "alpha(opacity=90)";
		}
		
		*/
		
		@media screen and (max-width:640px){
			
			
			
		}
			

		/*
		***********************************
		*margin&padding
		***********************************
		*/
		
		
		.no{margin: 0px;padding: 0px;}
		
		
		/*
		***********************************
		*text&font
		***********************************
		*/
		

h2{margin-bottom: 100px;}

h4{
	font-weight: 600;
	font-size: 17px;
    margin-top: 20px;
    line-height: 200%;}


.title_en{
			font-family: "Inter", sans-serif;
			font-optical-sizing: auto;
			font-weight: 100;
			font-style: normal;
	        text-align: center;
	        font-size: 85px;
	        color: #FFF;
	        margin-bottom: 120px;
	        line-height: 200%;}

.mid_en{
			font-family: "Inter", sans-serif;
			font-optical-sizing: auto;
			font-weight: 100;
			font-style: normal;
	        font-size: 30px;
            letter-spacing: 0;
            margin-right: 20px;}


.copy_JP{
	font-size: 45px;
	font-family: 'Noto Serif JP', sans-serif;
	font-weight: 100;
	line-height: 170%;
	letter-spacing: 2px;
     text-align: center;}




#business .business_list p{
	font-size: 14px;
	line-height: 180%;
	letter-spacing: 0;
}


@media screen and ( max-width:479px ){

	h2{margin-bottom: 40px;}
	.title_en{font-size: 55px;margin-bottom: 40px;}
	
	.copy_JP{font-size: 30px;}
	
		}	

@media screen and (max-width:640px){
						

		}



		
		/*
		***********************************
		*画面サイズ調整
		***********************************
		*/
		
		img{
		max-width: 100%;
		height: auto;
		}
		
		.only_pc{display:block;}
		.only_smt{display:none;}
		
		@media screen and ( max-width:479px ){
		
		.only_pc{display:none;}
		.only_smt{display:block;}	
			
		}
		
		
		/*
		***********************************
		*基本設定_領域
		***********************************
		*/
		
		/* 全体 */

#content{
	width: 100%;}


		/* オープニング */

.opening {
 width: 100vw;
 height: 100vh;
 background-color: #A1A1A1;
 position: fixed;
display: block;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
overflow: hidden;
}
 
.opening p{
	font-size: 80px;
	line-height: 130%;
	margin: 60px;
	font-family: 'Inter', sans-serif;
	font-weight: 100;
	color: #EFEFEF;}

.copy_area{
	position: absolute;
	right: 50%;
	bottom: 50%;
	transform: translate(50%, 50%);
	text-align: center;
	display: block;}

.op_title{
	text-align: left;
	display: inline-block;}


@media screen and ( max-width:479px ){
	
.opening p{font-size: 50px;margin-top:0;}
}

		/* オープニング 文字アニメーション*/


/*========= 流れるテキスト ===============*/

/*全共通*/

.slide-in {
	overflow: hidden;
    display: inline-block;
}

.slide-in_inner {
	display: inline-block;

}

/*左右のアニメーション*/
.leftAnime{
    opacity: 0;/*事前に透過0にして消しておく*/
}

.slideAnimeLeftRight {
	animation-name:slideTextX100;
	animation-duration:0.8s;
	animation-fill-mode:forwards;
    opacity: 0;
}

@keyframes slideTextX100 {
  from {
	transform: translateX(-100%); /*要素を左の枠外に移動*/
        opacity: 0;
  }

  to {
	transform: translateX(0);/*要素を元の位置に移動*/
    opacity: 1;
  }
}

.slideAnimeRightLeft {
	animation-name:slideTextX-100;
	animation-duration:0.8s;
	animation-fill-mode:forwards;
    opacity: 0;
}


@keyframes slideTextX-100 {
  from {
	transform: translateX(100%);/*要素を右の枠外に移動*/
    opacity: 0;
  }

  to {
	transform: translateX(0);/*要素を元の位置に移動*/
    opacity: 1;
  }
}


/*========= 背景動画 ===============*/

#video-area{
    position: fixed;
    z-index: -1;/*最背面に設定*/
    top: 0;
    right:0;
    left:0;
    bottom:0;
    overflow: hidden;
}

#video {
    /*天地中央配置*/
    position: fixed;
    z-index: -1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    /*縦横幅指定*/
    width: 177.77777778vh; /* 16:9 の幅→16 ÷ 9＝ 177.77% */
    height: 56.25vw; /* 16:9の幅 → 9 ÷ 16 = 56.25% */
    min-height: 100%;
    min-width: 100%;
}



/*========= ヘッダー表示 =========*/

#js-fixed-header{z-index: 1000000000000000;}



.header {
  width: 100%;
  background: #fff;
}

.header-inner {
  max-width: 1280px;
  width: 80%;
  height: 80px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  align-items: center;
  position: relative;
}

.header-title img{
	width: auto;
	height: 60px;
	object-fit:scale-down;
}

.header-nav {
  margin-left: auto;
	font-size:17px;
}

@media screen and ( max-width:799px ){
		
	.header-nav{display:none;}	
	.header-inner{
		justify-content: center;
		height: 60px;}
	
	.header-title img{height: 40px;}

		}

.header-list {
  display: flex;
}

.header-list__item {
  margin-left: 40px;
}
.header-list__item:first-child {
  margin-left: 0;
}

.fixed-header {
  position: fixed;
  top: -80px;
  left: 0;
  z-index: 1;
  transition: all 0.3s ease-in-out;
  visibility: hidden;
}

.fixed-header.is-show {
  top: 0;
  visibility: visible;
}


/*========= エリア構成 ===============*/

/* ヘッダー */
		
#header2023{
	width: 100%;
	height: 100vh;
	margin: 0 auto;}

#vis_first{
	width: 100%;
	height: 400px;
	background-image:url("../img/2024_new/top/top_img_first.jpg");
	background-size: cover;
	background-position:center;
	background-repeat:no-repeat;
	background-attachment: fixed;
	z-index: 1;
	position:relative;}


#vis_interior{
	width: 100%;
	height: 400px;
	background-image:url("../img/2024_new/top/top_img_interior.jpg");
	background-size: cover;
	background-position:center;
	background-repeat:no-repeat;
	background-attachment: fixed;
	z-index: 1;
	position:relative;}


#vis_interior2{
	width: 100%;
	height: 400px;
	background-image:url("../img/2024_new/top/top_img_interior2.jpg");
	background-size: cover;
	background-position:center;
	background-repeat:no-repeat;
	background-attachment: fixed;
	z-index: 1;
	position:relative;}

.logo_m {
    width:32%;
	max-width: 500px;
	min-width: 350px;
	position: absolute;
	right: 50%;
	bottom: 50%;
	transform: translate(50%, 50%);
    }

	
	
@media screen and ( max-width:479px ){

	#header2023{width: 90%;}
	.logo_m {width:32%;max-width:none;min-width:none;}	
	}
	
@media screen and ( max-width:640px ){	
	
	#vis_first{height: 500px;
	background-size: cover;
	background-attachment: scroll;
	background-image:url("../img/2024_new/top/top_img_first_smt.jpg");}
	
	#vis_interior{height: 500px;
	background-size: cover;
	background-attachment: scroll;
	background-image:url("../img/2024_new/top/top_img_interior_smt.jpg");}
	
	#vis_interior2{height: 500px;
	background-size: cover;
	background-attachment: scroll;
	background-image:url("../img/2024_new/top/top_img_interior2_smt.jpg");}
	
	
	}

/* エリア構成 */

#main_catch{
	width: 80%;
	margin: 0 auto;
	padding: 130px 0 150px 0;
}



#business{
	width: 80%;
	margin: 0 auto;
	padding: 200px 0 150px 0;}

#company{
	width: 70%;
	margin: 0 auto;
	padding: 200px 0 150px 0;}
	
	
@media screen and ( max-width:479px ){
	
	
#business,#company{
	width: 90%;
	padding: 80px 0;}	
	
	}


		
@media screen and (max-width:640px){
			

			
			}
		
/*========= 個別設定 ===============*/


/* ビジネス */

#business ul{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	justify-content:space-between;}

#business li{
	width: 48%; 
    margin-bottom: 60px;}
	
	
	
@media screen and ( max-width:479px ){
	#business ul{justify-content:center;}
	#business li{width: 90%; }
	
		}


/* 会社概要 */
#company dl{display: flex;flex-wrap: wrap;}
#company dt{width: 25%; margin-right: 2%;margin-bottom: 15px; display: flex;}
#company dd{width: 73%; margin-bottom: 15px;}

	
@media screen and ( max-width:479px ){
	
	#company dt{width:100%;margin-right:0; margin-bottom:15px;}
	#company dd{width:100%;margin-bottom:30px;}
	
	}

			
		
		/* フッター*/	
			
		#footer{
			background-color:#898782;}
			
		#footer_in{
			width:100%;
			max-width:1200px;
			margin:0 auto;
			padding:20px 0;
			text-align:center;
			color:#CCC;}
	
			