@charset "utf-8";

/***************************************

BASE

***************************************/


html {
	height: 100%;
	position: relative;
	background: #cccccc;
	
}

body{
	font-family:  "Inter",  "Noto Sans JP"  sans-serif;
    font-family: "Hiragino Mincho ProN", "Yu Mincho", "MS Mincho", serif;
	/*font-family:  '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',"Helvetica Neue", "Helvetica", "Hiragino Sans", "Arial", "Yu Gothic", "Meiryo", sans-serif;*/
	color: #444444;
	letter-spacing: 0.1rem;
	
	
}




/***************************************

container_top

***************************************/

#container{
	width: 100%;
}

.top_wrap{
	width: 100%;
	text-align: center;
	 margin-top: 5%;
}

.top_main_img{
	max-width: 100%;
   
}
.top_main_text{
	width: 50%;
	margin: 2% auto;
    
}
.top_main_text p{
	font-size: 1.1rem;
	letter-spacing: 0.1rem;
	line-height: 2.5rem;	
	text-align: left;
	font-weight: 400;
	
}

.top_main_banaer{
	margin: 5% auto 15%;
	width: 45%;
}

.top_main_banaer img{
	width: 100%;
}

.top_main_banaer p{
	color: #fff;
	font-size:0.9rem;
}

.marker {
  background:linear-gradient(transparent 50%, rgba(255, 204, 204) 50%);
  display: inline;
  background-repeat: no-repeat;
  background-size: 0% 100%;
  transition:background-size 1.5s;
}
.marker.on {
  background-size: 100% 100%;
}
.under_marker {
  background:linear-gradient(transparent 90%, rgba(10, 10, 10,1.0) 100%);
  display: inline;
  background-repeat: no-repeat;
  background-size: 0% 10%;
  transition:background-size 1.5s;
}
.under_marker.on {
  background-size: 100% 100%;
}










@media screen  and (max-width:1200px){
	
	

.top_wrap{
	width: 100%;
	text-align: center;
    padding-top: 15%;
	
}	
    
.top_main_img{
	max-width: 100%;
   
}    
	
.top_main_text{
	width: 90%;
	margin: 2% auto;
}	
	
.top_main_text p{
	font-size: 0.8rem;
	letter-spacing: 0.1rem;
	line-height: 1.6rem;
	text-align: left;
}	
	

.top_main_banaer{
	margin: 0 auto;
	width: 90%;
}

.top_main_banaer img{
	width: 100%;
}	
	
	
.square_btn{
	display: inline-block;
	width: 90%;

	
}

.square_btn a {
  display: inline-block;
  width: 80%;
  line-height: 50px;

}


	

	
}







/***************************************

Contents 2/14

***************************************/

#header{
	background: #cccccc;
	
}


.main_wrapper{
    width: 100%;
}


.brand_wrapper{
    width: 100%;
    margin: 5% auto;
    text-align: center;
}



.brand_cont_name{
	width: 100%;
	margin: 5% auto 2%;    
	font-size: 5rem;
	font-weight: 600;
	line-height: 3rem;
	
}

.brand_cont_sub{
	width: 100%;
    
	margin: 0 auto 1%;
	font-size: .9rem;
	line-height: 1.5rem;
    font-weight: 600;
	
	
}

.brand_cont_desp{
	width: 60%;
	margin: 0% auto;
	font-size: .95rem;
	line-height: 1.7rem;
	font-weight: 600;
	text-align: left;
}




/* メインエリア */
.column_wrapper {
  display: flex;
  width:99%;
  margin: 0 auto;
  align-items: flex-start;
  letter-spacing: 0.1rem;	
}

/* 左カラム固定 */
.left_column,
.right_column{
  width: 33.3%;
  background: #cccccc;
  box-sizing: border-box;
  overflow: hidden;
  z-index: 10;
  position: sticky;
  top: 0; 
　height: 100vh;    
}



/* 真ん中カラム */
.center_column {  
  width: 33.3%;	    
  background: #cccccc;
 
  
}


.brand_img{
    width: 100%;
    margin: 0 auto 5%;
}


.left_column img,
.right_column img {
  width: 100vw;
  height: 100vh;
  object-fit: cover;
}

.center_column .brand_img{
    width: 95%;
    
    
}

.center_column .brand_img p{
    font-size: .8rem;
	line-height: 1.5rem;
	font-weight: 600;
	text-align: left;
    
}


.item_wrapper{
    width: 80%;
    margin: 0 auto;
    
}




.btn{
    width:50%;
    padding: 5% 0 0 0;
    margin: 0 auto;
    
}
.btn a{
    display:block;
    width:100%;
    background:#444444;
    text-align:center;
    color:#FFFFFF;
    font-size:1.0rem;
    padding: 3% 0;
}
.btn a:hover{
    background:#8A8A8A;
    color:#FFFFFF;
    margin-left:0px;
    margin-top:0px;
    box-shadow:none;
}




@media screen  and (max-width:1200px){
    
    



.brand_cont_name{ 
	font-size: 3rem;	
}

.brand_cont_sub{	
	margin: 0 auto 2%;	
	line-height: 1.6rem;	
}

.brand_cont_desp{
	width: 95%;
	margin: 0% auto;
	font-size: .8rem;
	line-height: 1.6rem;
	
}




/* メインエリア */
.column_wrapper {
  display: block;
  width:99%;
  margin: 0 auto;
  letter-spacing: 0.1rem;	
      
}

/* 左カラム固定 */
.left_column,
.right_column{
  width: 100%;
  background: #cccccc;
  position: relative;
     
}



/* 真ん中カラム */
.center_column {  
  width: 100%;	    
  background: #cccccc;
 
  
}


.brand_img{
    width: 100%;
    margin: 0 auto 5%;
}


.left_column img,
.right_column img {
  width: 100vw;
  height: 100vh;
  object-fit: cover;
}

.center_column .brand_img{
    width: 95%;
    
    
}

.center_column .brand_img p{
    font-size: .8rem;
	line-height: 1.5rem;
	font-weight: 600;
	text-align: left;
    
}


.item_wrapper{
    width: 80%;
    margin: 0 auto;
    
}




.btn{
    width:90%;
    padding: 5% 0 0 0;
    margin: 0 auto;
    
}
.btn a{
    display:block;
    width:100%;
    background:#444444;
    text-align:center;
    color:#FFFFFF;
    font-size:0.9rem;
    padding: 5% 0;
}
.btn a:hover{
    background:#8A8A8A;
    color:#FFFFFF;
    margin-left:0px;
    margin-top:0px;
    box-shadow:none;
}
    
    
}


/***************************************

underline

***************************************/


.underline-Area {
	  width: 50%;
	  min-width: 200px;
	  height: auto;
	  margin: 0;
	  padding: 20px;
	  border: 1px solid #333;
}

.underline-Area p {
	  margin: 60px auto;
}

.underline-before {

	background: linear-gradient(black, black) 0 100%/0 2px no-repeat;
	transition: background 3s;
	text-decoration: none;

}

.underline-after {
	background-size: 100% 2px;
  
}

	


/***************************************

fadeUp

***************************************/


.fadeUp{
animation-name:fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}


/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
 
.fadeUpTrigger{
    opacity: 0;
}



/***************************************

delay

***************************************/

.delay{
	
	 opacity: 0;
   	 animation: fadein 6s ease forwards;
}


@keyframes fadein  {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

.delay_1 {animation-delay: 0.5s}
.delay_2 {animation-delay: 1.2s}
.delay_3 {animation-delay: 1.9s}
.delay_4 {animation-delay: 2.6s}
.delay_5 {animation-delay: 3.3s}
.delay_6 {animation-delay: 4.0s}


/***************************************

PC/SP

***************************************/


@media screen and (min-width: 1200px) {
  .sp {
    display: none;
  }
}
@media screen and (max-width: 1200px) {
  .pc {
    display: none;
  }
}



