@charset "UTF-8";

/* ------------------------------------------------------------------
	BASE
-------------------------------------------------------------------*/
.gradient {
  background: linear-gradient(128deg, #77c9de, #85bcc9, #aec94d);
  background-size: 600% 600%;
  -webkit-animation: AnimationName 9s ease infinite;
  -moz-animation: AnimationName 9s ease infinite;
  animation: AnimationName 9s ease infinite;
  width: 100%;
  height: 100%;
  opacity: 0.3;
}
@-webkit-keyframes AnimationName {
  0% {
    background-position: 0% 87%
  }
  50% {
    background-position: 100% 14%
  }
  100% {
    background-position: 0% 87%
  }
}
@-moz-keyframes AnimationName {
  0% {
    background-position: 0% 87%
  }
  50% {
    background-position: 100% 14%
  }
  100% {
    background-position: 0% 87%
  }
}
@keyframes AnimationName {
  0% {
    background-position: 0% 87%
  }
  50% {
    background-position: 100% 14%
  }
  100% {
    background-position: 0% 87%
  }
}

/* ------------------------------------------------------------------
	keyv
-------------------------------------------------------------------*/
#keyv {
  width: 100%;
  height: 400px;
  position: relative;
  overflow: hidden;
}
#keyv video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  z-index: -1;
  transform: translate(-50%,-50%);
}
#keyv .keyvOverlay {
  width: 100%;
  margin: 0px;
  padding: 0px;
  height: 400px;
  position: relative;
  background-image: url(../../img/common/img-dots.png);
}
#keyv .keyvInner {
  max-width: 100%;
  margin: 0px auto;
  position: relative;
  height: 400px;
}
#keyv .catchcopy {
  position: absolute;
  right: 0px;
  bottom: 20px;
  width: 80%;
}
#keyv .catchcopy img {
  width: 100%;
}
.eff-blur {
  transform: scale(1.1) 0.8s;
  -webkit-animation: catchBlur 4s ease;
  -moz-animation: catchBlur 4s ease;
  animation: catchBlur 4s ease;
}
@-webkit-keyframes catchBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }
  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}
@keyframes catchBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }
  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

/* ------------------------------------------------------------------
	loginCard
-------------------------------------------------------------------*/
#keyv #loginCard {
  display: none;
}

#keyv #presentationCard {
    display: none;
}
.loginCardSp{
	margin: 3px;
    border: 1px #999999 solid;
}

.loginCardSp .panel{
	margin-bottom: 0;
}

.loginCardSp .panel{
	margin-bottom: 0;
}

.loginCardSp .userInput{
	width: 100%;
}

#loginCard  input[type="text"] ,#loginCard  input[type="password"] {
display: inline-block;
font-family: "FontAwesome";
font-style: normal;
font-weight: normal;
line-height: 1;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

/* ------------------------------------------------------------------
	news
-------------------------------------------------------------------*/
#news h2 {
  font-family: "bebas";
  font-size: 3.0rem;
  text-align: center;
  margin-bottom: 20px;
}
#news {
  max-width: 100%;
  margin: 0px auto;
  padding-top: 60px;
}
#news.container {
  padding-bottom: 10px;
}
#news ul {
  height: 216px;
  width: 100%;
}
#news ul li {
  margin-right: 15px;
}
#news ul li a {
  width: 100%;
  padding: 15px 40px 15px 20px;
  line-height: 2em;
  border-bottom: 1px solid #ccc;
  display: inline-block;
  text-decoration: none !important;
  color: #333;
  background-color: #fff;
  position: relative;
}
#news ul li:first-child a {
  border-top: 1px solid #ccc;
}
#news ul li a::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 20px;
  transition: all 0.2s;
  content: "\f105";
  display: block;
  font-family: fontawesome;
}
#news ul li a.external::after {
  content: "\f08e";
}

/* ======= hover ======= */
#news ul li a:hover::after {
  color: #fff;
  right: 20px;
}
#news ul li a:hover {
  background-color: #0d4099;
  color: #fff;
  cursor: pointer;
}
#news ul li dl {
  position: relative;
}
#news ul li dl dt.date {}
#news ul li dl dd.title {}

/* ------------------------------------------------------------------
	deg bg
-------------------------------------------------------------------*/
.fullwidth-deg {
  width: 100%;
  padding: 0px;
  position: relative;
  overflow: hidden;
  min-height: 600px;
  z-index: -1;
}
.degWrap {
  position: absolute;
  padding: 300px 0;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
}
.degWrap:before {
  content: '';
  position: absolute;
  top: 80px;
  left: 0;
  width: 120%;
  height: 50%;
  margin: 3% -10% 0;
  background: #484b56;
  -webkit-transform-origin: left center;
  -ms-transform-origin: left center;
  transform-origin: left center;
  -webkit-transform: rotate(-3deg);
  -ms-transform: rotate(-3deg);
  transform: rotate(-3deg);
  z-index: -1;
}
.degWrap-light {
  position: absolute;
  padding: 300px 0;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  margin-top: -40px;
}
.degWrap-light:before {
  content: '';
  position: absolute;
  top: 50px;
  left: 0;
  width: 120%;
  height: 60%;
  margin: 3% -10% 0;
  background: #b2b2b2;
  -webkit-transform-origin: left center;
  -ms-transform-origin: left center;
  transform-origin: left center;
  -webkit-transform: rotate(3deg);
  -ms-transform: rotate(3deg);
  transform: rotate(3deg);
  z-index: -1;
}
.degWrap + .container {
  position: relative;
}
@media screen and (max-width: 450px) {
  .degWrap-light:before {
    height: 80%;
  }
}

/* ------------------------------------------------------------------
	serviceGuide
-------------------------------------------------------------------*/
#serviceGuide {
  margin-top: -460px;
  z-index: 1;
}
#serviceGuide h2 + p {
  color: #fff;
  width: 100%;
  margin: 0px auto;
  padding: 0 10px;
}
#serviceGuide ul {
  margin-top: 80px;
  margin-bottom: 40px;
}
#serviceGuide ul li {
  width: 50%;
  float: left;
  padding: 10px;
}
#serviceGuide ul li a {
  display: block;
  padding: 30px 20px;
  background: #fff;
  border: 1px solid #e6e6e6;
  box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  opacity: 0;
}
#serviceGuide ul li a:hover {
  background: #0d4099;
  color: #fff;
}
#serviceGuide ul li a dl dd.title {
  font-size: 18px;
  text-align: center;
  font-weight: bold;
  margin-bottom: 20px;
}
#serviceGuide ul li a dl dt {
  margin-bottom: 30px;
  text-align: center;
  font-size: 60px;
  line-height: 1;
}
#serviceGuide ul li a dl dd {
  padding: 10px;
  line-height: 22px;
  text-align: justify;
}
#serviceGuide ul li:first-child a {
}
#serviceGuide ul li:nth-child(3) a {
  margin-top: -40px;
}
#serviceGuide ul li:nth-child(3) a {
  margin-top: 0 !important;
}
@media screen and (max-width: 450px) {
  #serviceGuide ul li {
    width: 100%;
    float: none;
  }
  #serviceGuide ul li:first-child a {
    margin-top: -60px;
  }
}

/* ------keyvAnimation --------*/
#serviceGuide .isPlay {
  animation-name: play;
  animation-duration: .5s;
  animation-fill-mode: forwards;
  animation-timing-function: cubic-bezier(.8, 0, .5, 1);
  position: relative;
  opacity: 1 !important;
}
#serviceGuide .isPlay:before {
  animation-name: maskOut;
  animation-duration: .5s;
  animation-delay: .5s;
  animation-fill-mode: forwards;
  animation-timing-function: cubic-bezier(.8, 0, .5, 1);
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  background-color: #0d4099;
}
#serviceGuide ul li:nth-child(2) .isPlay:before {
  animation-delay: 0.6s;
}
#serviceGuide ul li:nth-child(3) .isPlay:before {
  animation-delay: 0.7s;
}
#serviceGuide ul li:nth-child(4) .isPlay:before {
  animation-delay: 0.8s;
}

/* ------------------------------------------------------------------
	membership
-------------------------------------------------------------------*/
#membership {
  margin-top: -520px;
  margin-bottom: 60px;
  z-index: 1;
}
#membership .content-inner-fix {
  display: flex;
}
@media screen and (max-width: 450px) {
  #membership .content-inner-fix {
    flex-direction: column;
  }
  #membership .imgBox {
    width: 100% !important;
    margin-top: 30px !important;
  }
  #membership .textBox {
    width: 100% !important;
    padding-right: 0px !important;
  }

}
#membership .imgBox {
  width: 50%;
  position: relative;
  z-index: 1;
  order: 1;
  margin-top: 50px;
}
#membership .imgBox .imgBoxInner {
  border: 2px solid #fff;
  margin: 10px;
  width: calc(100% - 20px);
  z-index: 2;
  position: absolute;
  top: 0px;
  left: 0px;
  margin-right: 60px;
  height: calc(100% - 20px);
}
#membership .textBox {
  width: 50%;
  color: #fff;
  padding-right: 30px;
}
#membership .textBox h2 {
  font-family: "Montserrat", sans-serif;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
}
#membership .textBox p {
  margin-bottom: 20px;
}
#membership ul.memberBtn li {
  width: 100%;
  margin-bottom: 10px;
}
#membership ul.memberBtn li a {
  display: block;
  padding: 12px;
  background: #ed6479;
  border: 1px solid #de4159;
  box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.1);
  border-radius: 3px;
  color: #fff;
  text-align: center;
  font-size: 16px;
}
#membership ul.memberBtn li:last-child a {
  display: block;
  padding: 12px;
  background: #ffffff;
  border: 1px solid #de4159;
  box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.1);
  border-radius: 3px;
  color: #de4159;
  text-align: center;
  font-size: 16px;
}
#membership ul.memberBtn li a i {
  padding-left: 10px;
}
#membership ul.memberBtn li a:hover {
  background: #0d4099;
  border: 1px solid #0d4099;
  color: #fff;
}



/* ---------------------------------------------------------------------- */
/* ---------------------------------------------------------------------- */
/* ---------------------------------------------------------------------- */
/*  bootstrap Overwrite
/* ---------------------------------------------------------------------- */
/* ---------------------------------------------------------------------- */
/* ---------------------------------------------------------------------- */
.input-group-addon {
  background-color: #6bc7f1 !important;
  color: #FFF !important;
  border: 1px solid #ccc;
  border-right: none !important;
}
.panel {
  margin-bottom: 20px;
  background-color: #fff;
  border: 1px solid transparent;
  border-radius: 4px;
  -webkit-box-shadow: 0 0px 20px rgba(0, 0, 0, .1);
  box-shadow: 0 0px 20px rgba(0, 0, 0, .1);
}
.panel-heading img {
  width: 160px;
}

