@charset "UTF-8";

.loading{
width: 100%;
height: 100%;
background-color:#053785;
position: absolute;
top: 0px;
left: 0px;
z-index: 2001;
}

#loader {
width: 30px;
height: 30px;
display: none;
position: fixed;
top: 50%;
left:50%;
margin-top: -15px;
margin-left: -15px;
z-index: 2002;
}


#fade {
width: 100%;
height: 100%;
display: none;
position: absolute;
top: 0;
left: 0;
z-index: 2001;
background-color:#fff;
}


/*----------------------------------------------------------------------------------------------------------------------top slide----------*/

/*.main_imgBox {
    height: 680px;
    overflow: hidden;
    position: relative; }

.main_img {
    z-index:10;
    opacity: 0;
    width: 100%;
    height: 680px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-animation: anime 36s 0s infinite;
    animation: anime 36s 0s infinite; }

.main_img:nth-of-type(2) {
      -webkit-animation-delay: 6s;
      animation-delay: 6s; }

    .main_img:nth-of-type(3) {
      -webkit-animation-delay: 12s;
      animation-delay: 12s; }

    .main_img:nth-of-type(4) {
      -webkit-animation-delay: 18s;
      animation-delay: 18s; }

    .main_img:nth-of-type(5) {
      -webkit-animation-delay: 24s;
      animation-delay: 24s; }

    .main_img:nth-of-type(6) {
      -webkit-animation-delay: 30s;
      animation-delay: 30s; }*/

/*@keyframes anime {
  0% {
        opacity: 0;
    }
    8% {
        opacity: 1;
    }
    17% {
        opacity: 1;
    }
    25% {
        opacity: 0;
        transform: scale(1.2) ;
         z-index:9;
    }
    100% { opacity: 0 }
}
*/

/*----------------------------------------------------------------------------------------------------------------------top video----------*/

.video-wrap {
    position: relative;
    padding-top: 50px;
    height: 100%;
    overflow: hidden;
	background-color: #B3B3B3; 
}
 
.video-wrap iframe,  
.video-wrap object,  
.video-wrap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

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

.video-wrap {
    padding-top: 170px;
	}

}

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

.video-wrap {
    padding-top: 100px;
	}

}

@media screen and (max-width:740px){
	
.video-wrap {
    padding-top: 80px;
	}
}



/*----------------------------------------------------------------------------------------------------------------------#cont----------*/

#cont h2{
font-size:27px;
font-weight: normal;
letter-spacing:3px;
line-height:1.4;
color:#fff;
text-align:center;
position: relative;
margin-bottom: 30px;
}

.border:after{
width:100%;
content: "";
border-bottom: 1px solid #fff;
position: absolute;
top:0;
left: 0;
right: 0;
bottom: -10px;
margin:auto;}

#cont h3{
font-weight:bold;
text-align:left;
color:#5D5D5D;
}

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

#cont h2{ 
font-size:25px;
letter-spacing:3px;
}

}

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

#cont h2{ 
font-size:24px;
margin-bottom: 10px;
}

}

/*----------------------------------------------------------------------------------------------------------------------#banner----------*/

#banner{
padding:100px 30px 0px 30px;
position:relative;
}

#banner .inner{
max-width:1080px;
width:100%;
margin:0 auto;
}

#banner h1{
text-align: center;
}

#banner img{
max-width:700px;
width:100%;
height:auto;
margin-top:20px;
}

#banner .more{
margin:50px auto;	
width:250px;
height:50px;
font-size:14px;
}

#banner .more a {
background-color: #B3B3B3;
border: 1px solid #fff;
color:#fff;
line-height:30px;
width:100%;
border-radius:20px;
}

#banner .more a:hover {
background-color:#B3B3B3;
border: 1px solid #5D5D5D;
color:#5D5D5D;
}

@media(max-width: 740px){

#banner .inner{ width:90%; }

#banner .kerning{ padding-top: 10px; }
	
#banner{
padding:50px 0px 0px 0px;
}
	
}

/*----------------------------------------------------------------------------------------------------------------------#works----------*/

#works{
padding:50px 0 30px;
position:relative;
}

#works .inner{
max-width:1080px;
width:100%;
margin:0 auto;
}

.works-list {
overflow: hidden;
list-style: none;
padding: 0;
}

.works-list li {
float: left;
width: 33.3333333333%;
padding: 10px 30px;
}

.works-list li a{
display: block;
position: relative;
}

.works-list img {
width: 300px;
}

figure img {
  opacity: 1;
  -webkit-transition: .3s ease-in-out;
  transition: .3s ease-in-out;
}

figure:hover img {
  opacity: .5;
}

#works .more{
margin:50px auto;	
width:250px;
height:50px;
font-size:14px;
}

#works .more a {
background-color: #B3B3B3;
border: 1px solid #fff;
color:#fff;
line-height:30px;
width:100%;
border-radius:20px;
}

#works .more a:hover {
background-color:#B3B3B3;
border: 1px solid #5D5D5D;
color:#5D5D5D;
}

#works h1{
text-align: center;
}


.new:before {
  border-color: #C30D23 transparent transparent transparent;
  border-style: solid;
  border-width: 60px 60px 0 0;
  content: "";
  height: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  z-index: 2;
}
.new:after {
  color: #fff;
  content: "NEW";
  font-size: 12px;
  position: absolute;
  top: 12px;
  left: 6px;
  transform: rotate(-45deg);
  z-index: 3;
}


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

#works .inner{ width:90%; }


}

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

#works{
padding:0px 0 40px;
position:relative;
}	
	
#works .inner{ width:90%; }
	
#works .more_banner{
font-size:18px;
}

#works .more_banner a {
line-height:30px;
}	
	
}

@media(max-width: 1024px){
.works-list li {
	  float: none;
	  width: 100%;
	  padding: 30px 0px;
	  margin-bottom: 10px;
	}
.works-list li a img{width: 100%;}
}

@media(max-width: 740px){
.works-list li {
	  float: none;
	  width: 100%;
	  padding: 30px 0px;
	  margin-bottom: 10px;
	}
.works-list li a img{width: 100%;}
}

/*----------------------------------------------------------------------------------------------------------------------#news----------*/

#news{
padding:100px 0 30px;
position:relative;
}

#news .inner{
max-width:1080px;
width:100%;
margin:0 auto;
}

#news table{
width:81.5%;
border-bottom:0px dotted #fff;
border-collapse:separate;
border-spacing:0;
margin:0 auto;
}

#news th{
font-weight:bold;
width:20%;
padding:10px 14px 10px 25px;
border-top:1px dotted #fff;
-moz-text-align-last: justify;
  text-align-last: justify;
}


#news td{
width:80%;
padding:10px 14px 10px 50px;
border-top:1px dotted #fff;
}

#news table tr:first-child th,
#news table tr:first-child td{border-top: none;}

#news td a:hover{ text-decoration:none; }

#banner .more{
margin:20px auto;
width:250px;
height:50px;
font-size:14px;
}

#banner .more a {
background-color: #B3B3B3;
border: 1px solid #fff;
color:#fff;
line-height:30px;
width:100%;
border-radius:20px;
}

#banner .more a:hover {
background-color:#B3B3B3;
border: 1px solid #5D5D5D;
color:#5D5D5D;
}

#banner .yoyaku{
margin:20px auto;
padding-bottom: 100px;
width:300px;
height:50px;
font-size:15px;
}

#banner .yoyaku a {
background-color: #5D5D5D;
border: 1px solid #5D5D5D;
color:#fff;
line-height:40px;
width:100%;
}

#banner .yoyaku a:hover {
background-color:#B3B3B3;
border: 1px solid #5D5D5D;
color:#5D5D5D;
}

.info{
text-align: center;
font-weight: bold;
font-size: 18px;
padding-bottom: 100px;
padding-top: 10px;
}

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

#news .inner{ width:90%; }


}

@media screen and (max-width:740px){	
	
#news .inner{ width:90%; }
	
#news th{
-moz-text-align-last: left;
  text-align-last: left;
}
	
#news th, #news td{ 
width:100%;
display:block;
padding:14px 10px;
}
	
#news td{
border-top:none;
padding-top: 5px;
}
	
}


/*----------------------------------------------------------------------------------------------------------------------#instagram----------*/

#instagram{
padding:100px 0 30px;
position:relative;
}

#instagram .inner{
max-width:1080px;
width:100%;
margin:0 auto;
}

#instagram .more{
margin:50px auto;	
width:250px;
height:50px;
font-size:14px;
}

#instagram .more a {
background-color: #B3B3B3;
border: 1px solid #fff;
color:#fff;
line-height:30px;
width:100%;
border-radius:20px;
}

#instagram .more a:hover {
background-color:#B3B3B3;
border: 1px solid #5D5D5D;
color:#5D5D5D;
}


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

#instagram .inner{ width:90%; }


}

@media screen and (max-width:740px){	
	
#instagram .inner{ width:90%; }

#instagram .more{
margin:20px auto;
}

}

/*----------------------------------------------------------------------------------------------------------------------#access----------*/

#access{
padding:65px 0px 50px 0px;
}

#access .inner{
width:90%;
max-width:1080px;
margin:0 auto;
position:relative;
}

.txt_access p{ 
text-align:center;
margin-top:16px;
margin-bottom: 20px;
}


@media screen and (max-width:740px){
	
#access .inner{ width:90%; }

}

/*▽アクセスマップ*/
#map {
width: 100%;
height: 500px;
margin-top: 20px;
}

#access .more{
margin:50px auto;	
width:250px;
height:50px;
font-size:14px;
}

#access .more a {
background-color: #B3B3B3;
border: 1px solid #fff;
color:#fff;
line-height:30px;
width:100%;
border-radius:20px;
}

#access .more a:hover {
background-color:#B3B3B3;
border: 1px solid #5D5D5D;
color:#5D5D5D;
}



