@charset "UTF-8";

.op0{
	opacity: 0;
}

.popup{
  animation: popup 0.6s cubic-bezier(0.22, 1, 0.36, 1) 1 forwards;
}
 
@keyframes popup {
  0% {
    transform: translateY(40px) scale(0.8);
    opacity: 0;
  }
  100% {
    transform: translateY(0) scale(1.0);
  }
  80%, 100% {
    opacity: 1;
  }
}

.fadeup{
  animation: fadeup 0.6s 1 forwards;
}
 
@keyframes fadeup {
  0% {
    transform: translateY(40px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
  }
  80%, 100% {
    opacity: 1;
  }
}

.bg .bg-wrap {
  position: relative;
  display: inline-block;
  margin-top: 5px;
	margin-left: 10px;
}
.bg.is-animated .bg-wrap::before {
  animation: bg 2.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;

  background: #000000;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: left center;
}
.bg .bg-wrap .inn {
  color: #f5ffa5;
  display: inline-block;
  font-size: 18px;
  font-weight: bold;
  padding: 10px 0;
  position: relative;
  z-index: 1;
	letter-spacing: 2px;
}

.bg .bg-wrap .inn span.pt01{
	transform: rotate(-90deg);
	display: inline-block;
	margin-bottom: 3px;
}

.bg .bg-wrap .inn span.pt02{
	color: #94f1e9;
	font-size:24px;
	font-weight: 900;
}
 
@keyframes bg {
  0% {
    opacity: 0;
    transform: scaleX(0) translateX(-5%);
  }
  30% {
    transform: scaleX(1) translateX(0);
  }
  100% {
    transform: scaleX(1) translateX(0);
  }
  30%, 100% {
    opacity: 1;
  }
}
 
.mask-bg {
  color: transparent;
  display: inline-block;
  overflow: hidden;
  position: relative;
  transition: color 0ms 200ms;
}
.mask-bg::after {
  background:#2086FF;
;
  bottom: 0;
  content: '';
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(0, 100%);
}

.mask-bg.is-animated {
  color: #000000;
}
 
.mask-bg.is-animated::after {
  animation: mask-bg 0.5s cubic-bezier(0.8, 0, 0.170, 1);
  clip-path: polygon(11% 0, 100% 0%, 85% 100%, 0% 100%);
}
 
@keyframes mask-bg {
  0% {
    transform: translate(-101%,0) 
  }
  40%, 60% {
    transform: translate(0, 0%)
  }
  100% {
    transform: translate(100%,0)
  }
}

  /*== ボタン共通設定 */
.btn{
    /*アニメーションの起点とするためrelativeを指定*/
    position: relative;
	overflow: hidden;
    /*ボタンの形状*/
	text-decoration: none;
	display: inline-block;
    padding: 10px 30px;
    text-align: center;
    outline: none;
    /*アニメーションの指定*/   
    transition: ease .2s;
}

/*ボタン内spanの形状*/
  .btn{
    background: #000000;
  }
  
.btn span.arrow {
	position: relative;
	z-index: 3;/*z-indexの数値をあげて文字を背景よりも手前に表示*/
	color:#ffffff;
}

.contactBtn span.arrow {
  padding-left: 4em;
}
  
  .btn span.c_text{
    position: absolute;
    font-size: 25px;
    color:#2086FF;
    opacity: 0.5;
    top:calc(50% - 0.75em);
    left: 8px;
    z-index: 2;
  }

.btn:hover span{
	color:#fff;
}
  
  .btnWrap{
    position: relative;
    display: inline-block;
  }
  
  .btnWrap:after{
    content:"";
    width: 50px;
    height: 2px;
    background: #2086FF;
    position: absolute;
    top:calc(50% - 1px);
    left: 25px;
    display: block;
  }  

/*== 背景が流れる（斜め） */
.bgskew::before {
	content: '';
    /*絶対配置で位置を指定*/
	position: absolute;
	top: 0;
	left: -130%;
    /*色や形状*/
	background:#2086FF;
	width:120%;
	height: 100%;
	transform: skewX(-25deg);
}

/*hoverした時のアニメーション*/
.bgskew:hover::before {
	animation: skewanime .5s forwards;/*アニメーションの名前と速度を定義*/
}

@keyframes skewanime {
	100% {
		left:-10%;/*画面の見えていない左から右へ移動する終了地点*/
	}
}

.scrolldown1{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  right: 20px;
  bottom:20px;
    /*全体の高さ*/
  height:180px;
  z-index: 10;
  text-shadow: 0 0 3px #000000,0 0 3px #000000;
}

.scrolldown1 span {
    position: absolute;
    left: -15px;
    top: -15px;
    color: #eee;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  font-size: 19px;
  letter-spacing: 0.2em;
  transform: rotate(-180deg);
}

/* 線の描写 */
.scrolldown1::after{
  content: "";
    /*描画位置*/
  position: absolute;
  top: 40px;
    /*線の形状*/
  width: 1px;
  height: 150px;
  background: #eee;
    /*線の動き1.4秒かけて動く。永遠にループ*/
  animation: pathmove 1.4s ease-in-out infinite;
  opacity:0;
}

/*高さ・位置・透過が変化して線が上から下に動く*/
@keyframes pathmove{
  0%{
    height:0;
    top:40px;
    opacity: 0;
  }
  30%{
    height:100px;
    opacity: 1;
  }
  100%{
    height:0;
    top:150px;
    opacity: 0;
  }
}