 .shake {
      -webkit-animation: shake 0.4s 1 linear;
      -moz-animation: shake 0.4s 1 linear;
      -o-animation: shake 0.4s 1 linear;
  }
  @-webkit-keyframes shake {
      0% { -webkit-transform: translate(30px); }
      20% { -webkit-transform: translate(-30px); }
      40% { -webkit-transform: translate(15px); }
      60% { -webkit-transform: translate(-15px); }
      80% { -webkit-transform: translate(8px); }
      100% { -webkit-transform: translate(0px); }
  }
  @-moz-keyframes shake {
      0% { -moz-transform: translate(30px); }
      20% { -moz-transform: translate(-30px); }
      40% { -moz-transform: translate(15px); }
      60% { -moz-transform: translate(-15px); }
      80% { -moz-transform: translate(8px); }
      100% { -moz-transform: translate(0px); }
  }
  @-o-keyframes shake {
      0% { -o-transform: translate(30px); }
      20% { -o-transform: translate(-30px); }
      40% { -o-transform: translate(15px); }
      60% { -o-transform: translate(-15px); }
      80% { -o-transform: translate(8px); }
      100% { -o-origin-transform: translate(0px); }
  }  
.part1 {
      background-image: url(../images/banner-bg.svg);
      background-repeat: no-repeat;
      background-position:bottom center;
      background-size: cover;
      height: 480px;
    }
    .part2{
      background-image: url(../images/lightblue-ribbon.svg);
      background-repeat: no-repeat;
      background-position: top center;
      background-size: cover;
      margin-top:-80px;
    }
    .part3{
      background-image: url(../images/end-bg.svg);
      background-repeat: no-repeat;
      background-position: top center;
      background-size: cover;
      height: 625px;
    }
    .wrapper {
      max-width: 1200px;
      margin: auto;
      position: relative;
    }
    .logo {
      height: 64px
    }

    .btn-border {
      color: white;
      border: 1px solid white;
      padding: 8px 16px;
      float: right;
      margin: 16px 16px 0 0;
      border-radius: 2px;
      text-decoration: none;
    }
    .btn-border:hover{
      background-color: #ef6c00;
      border-color: #ef6c00;
    }
    .banner-img{position: absolute;right:0;top:100px;height: 400px}
    .intro{
      color:white;
      margin: 80px 0 0 48px;
      
    }
    .intro h1,.intro h2{font-weight: normal;font-size: 30px;line-height: 48px}
    .intro p{white-space: pre-wrap;line-height: 28px;margin-top: 16px;font-size: 16px;}
    .h2{color: rgba(0,0,0,0.87);font-weight: normal;
      font-size: 32px
   }
    .intro-p{color:#555;
    font-size: 16px;
    white-space: pre-wrap;
    line-height:32px;
    margin: 16px 0 0 0;}
    /*.l-text{width:50%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center}
    .r-img{width:50%}*/
    .op08{opacity: 0.8}
.cw{color: white;}
  .numCounter {
  display: inline-block;
  height: 36px;
  line-height: 36px;
  color: #f1f1f1;
/*  text-shadow: 0 0 2px #fff;*/
  font-weight: bold;
  white-space: normal;
  font-size: 24px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
    position: relative;
}

.numCounter > b {
  display: inline-block;
  width: 25.71429px;
  height: 100%;
  margin: 0 0.1em;
  border-radius: 4px;
  background: #01579B;
  text-align: center;
  overflow: hidden;
}

.numCounter > b:before {
  content: " 0 1 2 3 4 5 6 7 8 9 ";
  display: block;
  word-break: break-all;
  word-break: break-word;
  -webkit-transition: 0.4s cubic-bezier(0.12, 0.78, 0.52, 1.2);
  transition: 0.4s cubic-bezier(0.12, 0.78, 0.52, 1.2);
}

.numCounter > b.d1:before {
  margin-top: -36px;
}

.numCounter > b.d2:before {
  margin-top: -72px;
}

.numCounter > b.d3:before {
  margin-top: -108px;
}

.numCounter > b.d4:before {
  margin-top: -144px;
}

.numCounter > b.d5:before {
  margin-top: -180px;
}

.numCounter > b.d6:before {
  margin-top: -216px;
}

.numCounter > b.d7:before {
  margin-top: -252px;
}

.numCounter > b.d8:before {
  margin-top: -288px;
}

.numCounter > b.d9:before {
  margin-top: -324px;
}

.numCounter > span {
  display: inline-block;
  font-size: 1.1em;
  opacity: 0.7;
  line-height: 1.8;
  padding: 0;
  vertical-align: top;
  text-shadow: none;
}

.numCounter {
  overflow: hidden;
  width: 152px;
  height: 36px;
  margin: 0 0 -16px 0;
  padding: 8px 0;
  text-align: center;
  background: #222;
  background: -webkit-gradient(linear, left top, left bottom, to(#0277BD));
  background: linear-gradient(to bottom, #0277BD 100%);
  border-radius: 8px;
}

.numCounter:before {
  content: "";
  position: absolute;
  left: -10%;
  right: -10%;
  top: -50%;
  bottom: 50%;
  background: #fff;
  opacity: 0.04;
  z-index: 1;
  -webkit-transform: rotatez(-5deg);
          transform: rotatez(-5deg);
}
  .login-wrapper{
    width:360px;
    margin:-200px auto 0 auto;
    background-color: white;
    padding: 24px 48px 32px 48px;
  }
@media screen and (max-width:640px) {
    .login-wrapper {
	padding: 12px 32px 24px 32px;
    width: 320px;  
}
  }
  .waves-bg{
    height:360px;background-image: url(../images/bg-bluewaves.svg);background-size: cover;background-repeat: no-repeat;background-position:bottom center;
  }

    .ct-logo {
      width: 200px;
      margin: 0;
    }

    @media screen and (max-width:400px) {
      .ct-logo {
        width: 160px;
        margin: 8px 0 0 8px;
      }
      header .btn-border {
        font-size: 14px;
        padding: 4px 8px;
      }
    }

    .slogan {
      width: 100%;
      max-width: 400px;
    }

    .banner-toon {
      width: 100%;
      max-width: 588px;
    }

    .banner-container {
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flex;
      display: -o-flex;
      display: flex;
      color: white;
      margin: auto;
      max-width: 1200px;
      flex-wrap: wrap;
    }

    .header-container {
      max-width: 1200px;
      margin: auto;
    }

    .banner-pic,
    .banner-text {
      width: 100%;
    }

    .feature-text {
      font-size: 18px;
    }

    .btn-register {
      display: block;
      width:100%;
    }

    .r-text,
    .l-text {
      margin-top: -72px;
    }

    .feature-sec {
	margin: auto;
      max-width: 1200px;
}
.l-img,.r-img{width: 100%}
    @media screen and (min-width:800px) {
      .ct-logo {
        width: 228px;
      }
      .banner-pic,
      .banner-text {
        width: 50%;
        margin-top: 32px;
      }
      .banner-toon {
        margin-top: 40px;
        margin-bottom: -32px;
      }
      .banner-pic p {
        margin-bottom: -96px;
        margin-top: 32px;
      }
      .banner-text ul {
        line-height: 28px;
      }
      .feature-text {
        font-size: 20px;
      }
      .l-img,
      .r-img {
        width: 54%;
      }
      .r-text,
      .l-text {
        width: 46%;
        
      }
      .r-text {
        text-align: left;
        padding-right: 8%;
      }
      .l-text {
	order:1;
        text-align: right;
        padding-left: 10%;
}
      .r-img{
        order:2
      }
      .btn-register {
        display: inline-block;
      }
      @media screen and (min-width:800px) {
        .btn-register {
	width: 160px;
}
      }
      .r-text,.l-text{
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        align-items: center;
      }
      .r-text .f24,.l-text .f24 {
	font-size: 32px !important;
}
      .r-text .c2,.l-text .c2 {
	font-size: 16px !important;
        line-height: 32px;
}
      .l-text .left-align {
	text-align: right;
}
      .customer-sec{
        height: 480px;
      }
      .customer-sec .r-text {
	padding-top: 180px;
}
      .customer-sec .lh24 {
	font-size: 16px !important;
}
      
    }

    @media screen and (min-width: 1024px) {
      .banner-text {
        padding: 40px 0 0 48px;
      }
      .feature-sec{
        margin-top: -64px
      }
    }
