html, body {
  font-family: 'Open Sans', sans-serif;
  font-family: 'Raleway', sans-serif;
  overflow-x: hidden !important;
  max-width: 100% !important;
  color: #22262D; }

#loading_div {
  background-color: #DDEBF2;
  text-align: center;
  padding-top: calc(50vh - 150px);
  padding-bottom: calc(50vh - 150px); }

.fw-section {
  background: transparent;
  background-attachment: scroll;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  padding-left: calc(50vw - 250px);
  padding-right: calc(50vw - 250px); }
  .fw-section#intro {
    background-image: url(/assets/img/intro_bg.png); }
  .fw-section#process {
    background-image: url(/assets/img/process_bg.png); }
  .fw-section#service {
    background-image: url(/assets/img/service_bg.png); }
  .fw-section#works {
    background-image: url(/assets/img/works_bg.png); }
  .fw-section#contact {
    background-image: url(/assets/img/contact_bg.png); }
  .fw-section#w_intro {
    background-image: url(/assets/img/w_intro_bg.png); }
  .fw-section#w_challenge {
    background-image: url(/assets/img/w_challenge_bg.png); }
  .fw-section .col-lg-5 {
    z-index: 1; }
  .fw-section .fw-container {
    height: 100%; }
    .fw-section .fw-container .fw-logo {
      z-index: 1000;
      position: absolute;
      height: 36px;
      margin: 30px 20px; }
    .fw-section .fw-container .section-title {
      width: 147px;
      font-size: 16px;
      border-bottom: solid #1CECFC 1px;
      margin: 25px auto;
      text-align: center;
      padding-bottom: 6px;
      color: #253660; }
      .fw-section .fw-container .section-title.white-text {
        color: white; }
  @media (min-width: 992px) {
    .fw-section {
      padding-left: 0px;
      padding-right: 0px; }
      .fw-section .col-lg-1, .fw-section .col-lg-5, .fw-section .col-lg-6 {
        height: 100vh;
        min-height: 800px; }
      .fw-section .fw-container {
        max-width: 1920px;
        margin: 0 auto; }
        .fw-section .fw-container .fw-logo {
          height: 55px;
          margin: 66px 55px; }
        .fw-section .fw-container .section-title {
          width: 222px;
          font-size: 25px;
          margin: 50vh -40px;
          transform: rotate(-90deg);
          top: 50vh;
          width: 222px; } }

#intro .fw-name {
  font-weight: 700;
  font-size: 48px;
  line-height: 60px;
  color: white;
  margin-top: 50px;
  margin-left: 50px; }

#intro .fw-slogan {
  font-weight: 500;
  font-size: 30px;
  line-height: 55px;
  color: white;
  margin-left: 50px;
  margin-top: 20px; }

#intro .fw-planet {
  width: 256px;
  top: 10px;
  position: relative; }

#intro .fw-whale {
  position: relative;
  width: 400px;
  top: -200px;
  right: -20px; }

@media (min-width: 992px) {
  #intro .fw-name {
    font-size: 72px;
    margin-top: calc((100vh - 150px)/2);
    width: 555px; }
  #intro .fw-slogan {
    font-size: 48px;
    margin-top: 40px;
    width: 555px; }
  #intro .fw-planet {
    left: -200px;
    width: 512px; }
  #intro .fw-whale {
    width: 1000px;
    top: -400px;
    right: 200px; } }

#process .circle-col {
  padding: 0px; }

#process .fw-process {
  font-weight: 700;
  font-size: 25px;
  color: white;
  margin-top: 50px;
  margin-left: 50px;
  width: 400px; }

#process .fw-circle {
  width: 500px;
  height: 500px;
  background-image: url("/assets/img/circle.png");
  background-size: cover;
  margin-left: -30px;
  margin-top: -50px; }
  #process .fw-circle .rev-rotation {
    position: relative;
    cursor: pointer; }
  #process .fw-circle .unicorn {
    height: 40%;
    margin-top: 30%;
    margin-left: 35%; }
  #process .fw-circle .idea {
    width: 200px;
    top: -200px;
    left: -100px; }
  #process .fw-circle .analyze {
    width: 200px;
    top: -410px;
    left: -170px; }
  #process .fw-circle .design {
    width: 200px;
    top: -575px;
    right: -305px; }
  #process .fw-circle .implement {
    width: 200px;
    top: -330px;
    left: 170px; }
  #process .fw-circle .testing {
    width: 200px;
    top: -360px;
    left: 190px; }
  #process .fw-circle .maintain {
    width: 200px;
    top: -425px;
    left: -225px; }

#process .fw-process-detail {
  background-color: rgba(255, 255, 255, 0.1);
  color: white;
  font-size: 18px;
  width: 100%;
  margin-left: 50px;
  margin-top: -50px;
  max-width: 700px;
  width: 90%;
  padding: 20px;
  font-weight: 400; }

@media (min-width: 992px) {
  #process .fw-process {
    font-weight: 700;
    font-size: 48px;
    margin-top: calc((100vh - 170px)/2);
    width: 600px; }
  #process .fw-circle {
    margin-top: calc(50vh - 300px);
    margin-left: 50px; }
  #process .fw-process-detail {
    margin-top: 50px;
    margin-left: -50px;
    font-size: 24px; } }

#service .fw-service-planet {
  width: 150px;
  margin: -25px auto -25px;
  text-align: center; }
  #service .fw-service-planet .planet {
    width: 100%; }
  #service .fw-service-planet .http {
    width: 50px;
    position: relative;
    top: -100px; }

#service .fw-service-whale {
  width: 245px;
  margin: 0 auto;
  text-align: center; }
  #service .fw-service-whale .whale-head {
    width: 115px;
    margin-top: -20px; }
  #service .fw-service-whale .service-cloud {
    width: 100%;
    position: relative;
    top: -75px; }

#service .service-content {
  color: #253660; }
  #service .service-content .content-title {
    font-size: 25px;
    font-weight: 700;
    padding-left: 25px;
    cursor: pointer; }
    #service .service-content .content-title .indicator {
      float: left;
      width: 20px;
      height: 20px;
      border-radius: 20px;
      background-color: #05C9C8;
      margin-top: 9px;
      margin-right: 15px; }
    #service .service-content .content-title.active .indicator {
      margin-left: -5px;
      border: 5px solid #b2e4da;
      width: 30px;
      height: 30px;
      border-radius: 30px;
      margin-top: 3px; }
  #service .service-content .content-detail {
    margin-left: 35px;
    padding: 15px;
    font-size: 18px;
    font-weight: 400;
    overflow: hidden; }
    #service .service-content .content-detail:not(:last-child) {
      border-left: 1px solid #05A5C9; }
  #service .service-content .fake-content-detail {
    margin-left: 35px;
    height: 20px;
    border-left: 1px solid #05A5C9; }

@media (min-width: 992px) {
  #service .fw-service-planet {
    transform: scale(2);
    margin-top: 150px; }
  #service .fw-service-whale {
    transform: scale(2);
    margin-top: 200px; }
  #service .service-content {
    margin-top: 120px;
    margin-right: 80px; }
    #service .service-content .content-title {
      font-size: 36px; }
      #service .service-content .content-title .indicator {
        width: 30px;
        height: 30px;
        border-radius: 30px;
        margin-top: 13px;
        margin-left: -5px; }
      #service .service-content .content-title.active .indicator {
        width: 40px;
        height: 40px;
        border-radius: 40px;
        margin-top: 6px;
        margin-left: -10px; }
    #service .service-content .content-detail {
      font-size: 23px;
      padding: 25px; } }

#works .fp-controlArrow {
  width: 50px !important;
  height: 50px !important;
  background-image: url("/assets/img/arrow.svg");
  background-size: cover;
  border: none !important;
  margin-top: -150px; }
  @media (min-width: 992px) {
    #works .fp-controlArrow {
      margin-top: 0px; } }
  #works .fp-controlArrow.fp-next {
    margin-right: 0px;
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg); }
  @media (min-width: 992px) {
    #works .fp-controlArrow.fp-next {
      margin-right: 100px; } }

#works .slide {
  padding-left: 70px;
  padding-right: 70px; }
  @media (min-width: 992px) {
    #works .slide {
      padding-left: 100px;
      padding-right: 200px; } }

#works .slide-row {
  height: 100%; }
  #works .slide-row .works-image {
    background-size: cover;
    height: 100%;
    width: cacl(200%);
    margin: 100px -50px 0px -50px;
    -webkit-box-shadow: 0px 7px 20px 3px rgba(5, 165, 201, 0.3);
    -moz-box-shadow: 0px 7px 20px 3px rgba(5, 165, 201, 0.3);
    box-shadow: 0px 7px 20px 3px rgba(5, 165, 201, 0.3); }
    #works .slide-row .works-image.entera {
      background-image: url("/assets/img/works/work-entera.png"); }
    #works .slide-row .works-image.reset {
      background-image: url("/assets/img/works/work-reset.png"); }
    #works .slide-row .works-image.pillarcare {
      background-image: url("/assets/img/works/work-pillarcare.png"); }
    #works .slide-row .works-image.rohan {
      background-image: url("/assets/img/works/work-rohan.png"); }
    #works .slide-row .works-image.soulartist {
      background-image: url("/assets/img/works/work-soulartist.jpg"); }
    @media (min-width: 992px) {
      #works .slide-row .works-image {
        margin: 0px;
        margin-top: 50%;
        height: 50%;
        width: 100%; } }
  #works .slide-row .works-info {
    margin: 0px -50px; }
    @media (min-width: 992px) {
      #works .slide-row .works-info {
        margin: 0px;
        margin-top: 50%;
        padding: 0px 25px; } }
    #works .slide-row .works-info .works-name {
      margin-top: 125px;
      font-size: 28px;
      color: #344A93;
      text-align: left;
      font-weight: bold; }
      @media (min-width: 992px) {
        #works .slide-row .works-info .works-name {
          font-size: 48px;
          margin-top: 0px; } }
    #works .slide-row .works-info .works-link {
      margin-top: 125px;
      text-align: right;
      font-size: 14px;
      line-height: 40px; }
      #works .slide-row .works-info .works-link img {
        width: 20px;
        margin-top: -1px; }
      #works .slide-row .works-info .works-link a {
        color: #22262D; }
      @media (min-width: 992px) {
        #works .slide-row .works-info .works-link {
          font-size: 18px;
          margin-top: 0px;
          line-height: 80px; } }
    #works .slide-row .works-info .works-detail {
      font-size: 16px;
      color: #22262D; }
      @media (min-width: 992px) {
        #works .slide-row .works-info .works-detail {
          font-size: 24px; } }

#contact .ready {
  font-weight: 700;
  font-size: 28px;
  color: #344A93;
  margin-left: 45px;
  margin-top: 0px;
  margin-bottom: 20px;
  text-align: center; }

#contact form {
  padding: 0px 45px; }
  #contact form input, #contact form textarea {
    margin-bottom: 13px;
    background: none; }
    #contact form input:focus, #contact form textarea:focus {
      border-color: #344A93; }
  #contact form input[type="submit"] {
    background-color: #344A93;
    color: white;
    font-weight: 700; }
    #contact form input[type="submit"]:hover {
      background-color: #3758c7; }
  #contact form .more {
    font-weight: 400;
    font-size: 15px;
    color: #22262D;
    margin-bottom: 10px; }
    #contact form .more strong {
      color: #344A93; }

#contact .contact-whale {
  text-align: center; }
  #contact .contact-whale img {
    width: 200px; }

#contact .contact-info {
  line-height: 30px;
  padding: 0px 45px; }
  #contact .contact-info img {
    width: 18px; }

#contact .contact-sns {
  text-align: center;
  margin-bottom: 20px; }
  #contact .contact-sns img {
    width: 50px;
    margin: 10px; }

#contact .fw-static-link {
  color: #253660;
  font-size: 14px;
  text-decoration: underline; }

@media (min-width: 992px) {
  #contact .ready {
    font-size: 48px;
    margin-top: 50px;
    margin-bottom: 100px; }
  #contact form {
    padding: 0px 45px; }
    #contact form input, #contact form textarea {
      margin-bottom: 25px;
      font-size: 20px;
      padding: 20px; }
    #contact form input[type="submit"] {
      line-height: 0px;
      height: 50px; }
  #contact .contact-whale {
    text-align: center;
    margin-bottom: 25px;
    margin-top: 25px; }
    #contact .contact-whale img {
      width: 50%; }
  #contact .contact-info {
    line-height: 40px;
    padding: 0px 45px;
    font-size: 22px; }
    #contact .contact-info img {
      width: 18px; }
  #contact .contact-sns {
    margin-top: 25px; }
    #contact .contact-sns img {
      width: 50px;
      margin: 10px; }
  #contact .fw-static-link {
    font-size: 18px; } }
