/* (C) Skeleton Crew Studio 2017 */
@font-face {
  font-family: "SCSMFont";
  src: url("/fonts/SCSM.woff") format('woff'), url("/fonts/SCSM.ttf") format('truetype');
}
@font-face {
  font-family: "SCSMFont";
  src: url("/fonts/SCSMBold.woff") format('woff'), url("/fonts/SCSMBold.ttf") format('truetype');
  font-weight: bold;
}
@font-face {
  font-family: "SCSGlyph";
  src: url("/fonts/SCSGlyph.woff") format('woff'), url("/fonts/SCSGlyph.ttf") format('truetype');
}
html {
  height: 100%;
}
a {
  text-decoration: none;
  color: #748087;
}
a:visited {
  color: #748087;
}
a:hover {
  color: #748087;
}
img {
  padding: 0;
  margin: 0;
}
body {
  background: #ffffff;
  font-family: "SCSMFont";
  height: 100%;
  padding: 0;
  margin: 0;
  color: #748087;
}
#splashvideo {
  position: fixed;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  -ms-transform: translateX(-50%) translateY(-50%);
  -moz-transform: translateX(-50%) translateY(-50%);
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  background: url("/video/splash.jpg") no-repeat;
  background-size: cover;
}
#menu-overlay {
  z-index: 1000;
  overflow: hidden;
  position: fixed;
  display: none;
  top: 0;
  background-image: url("/img/scslogo-menubg.svg");
  background-repeat: no-repeat;
  background-size: 145% auto;
  background-position: center top 70px;
}
#menu-overlay .close {
  position: fixed;
  top: 0;
  right: 0;
  width: 60px;
  height: 60px;
  background: #ffffff;
  cursor: pointer;
  text-align: center;
}
#menu-overlay .close img {
  margin-top: 16px;
  width: 28px;
}
#menu-overlay .link a,
#menu-overlay .link a:visited {
  font-size: 22px;
  color: #ffffff;
  clear: both;
  float: left;
  margin-bottom: 50px;
  border-bottom: 1px solid #ffffff;
}
@media only screen and (max-width: 320px) {
  #menu-overlay .link a,
  #menu-overlay .link a:visited {
    margin-bottom: 35px;
  }
}
#menu-overlay .link.active a {
  font-size: 45px;
  padding-left: 30px;
}
#menu-overlay .link.active.home a {
  color: #ffff9e;
  border-bottom: 1px solid #ffff9e;
}
#menu-overlay .link.active.work a {
  color: #ffc3d7;
  border-bottom: 1px solid #ffc3d7;
}
#menu-overlay .link.active.events a {
  color: #a0e1ef;
  border-bottom: 1px solid #a0e1ef;
}
#menu-overlay .link.active.join-us a {
  color: #d6a9ff;
  border-bottom: 1px solid #d6a9ff;
}
#menu-overlay .link.active.team a {
  color: #64e4d6;
  border-bottom: 1px solid #64e4d6;
}
#menu-overlay .links {
  margin-top: 100px;
  margin-left: 50px;
  float: left;
}
@media only screen and (max-width: 320px) {
  #menu-overlay .links {
    margin-top: 100px;
  }
}
#menu-overlay .social {
  float: left;
  width: 100%;
  display: block;
  margin-left: 25px;
}
#menu-overlay .social .icon {
  margin-left: 0;
  margin: 0 25px;
  width: 25px;
  height: 25px;
  display: inline-block;
}
#menu-overlay .social .icon a {
  width: 100%;
  height: 100%;
  display: inline-block;
}
#menu-overlay .social .icon.facebook,
#menu-overlay .social .icon.twitter,
#menu-overlay .social .icon.instagram {
  background-image: url("/img/sns-logo.svg");
  background-repeat: no-repeat;
  background-size: 74.4px 49.9px;
}
#menu-overlay .social .icon.twitter {
  background-position-x: -49.9px;
}
#menu-overlay .social .icon.twitter:hover {
  background-position-y: -25px;
}
#menu-overlay .social .icon.instagram {
  background-position-x: 1px;
}
#menu-overlay .social .icon.instagram:hover {
  background-position-y: -25px;
}
#menu-overlay .social .icon.facebook {
  background-position-x: -24.5px;
}
#menu-overlay .social .icon.facebook:hover {
  background-position-y: -25px;
}
#menu-overlay .logo {
  position: fixed;
  top: 16px;
  left: 18px;
  width: 25px;
}
.toolbar-logo {
  position: fixed;
  width: 100px;
  float: left;
  height: 100%;
  z-index: 500;
  display: table;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-logo {
    z-index: 500;
    height: 60px;
    width: 60px;
  }
}
.toolbar-logo .tb-cell {
  display: table-cell;
  width: 100px;
  vertical-align: middle;
}
.toolbar-logo .logo {
  height: 40px;
  width: 35px;
  position: absolute;
  left: 32px;
  top: 40px;
  cursor: pointer;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-logo .logo {
    display: none;
  }
}
.toolbar-logo .logo-thick {
  width: 25px;
  position: absolute;
  left: 18px;
  top: 16px;
  display: none;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-logo .logo-thick {
    display: inline-block;
  }
}
.toolbar-logo .logo-name {
  position: absolute;
  width: 14px;
  margin-top: -98.5px;
  z-index: 500;
  margin-left: 39px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-logo .logo-name {
    display: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-logo {
    position: fixed;
  }
}
.toolbar-logo.fixed {
  position: fixed !important;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-logo.mainpage {
    position: absolute;
  }
}
.front-text .wearescs {
  width: 700px;
  position: absolute;
  right: 0;
  bottom: 0;
  margin-right: 100px;
  margin-bottom: 100px;
  display: inline-block;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .front-text .wearescs {
    display: none;
  }
}
.front-text .wearescs-mobile {
  display: none;
  width: 260px;
  margin-left: 50px;
  margin-bottom: 50px;
  position: absolute;
  bottom: 0;
  pointer-events: none;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .front-text .wearescs-mobile {
    display: inline-block;
  }
}
@media only screen and (max-width: 320px) {
  .front-text .wearescs-mobile {
    margin-left: 25px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .front-text {
    text-align: center;
  }
}
.toolbar-lang {
  position: absolute;
  z-index: 75;
  top: 38px;
  right: 110px;
  height: 39px;
  width: 80px;
  background: rgba(0, 0, 0, 0.5);
  -webkit-touch-callout: none;
  /* iOS Safari */

  -webkit-user-select: none;
  /* Safari */

  -khtml-user-select: none;
  /* Konqueror HTML */

  -moz-user-select: none;
  /* Firefox */

  -ms-user-select: none;
  /* Internet Explorer/Edge */

  user-select: none;
  /* Non-prefixed version, currently supported by Chrome and Opera */

  line-height: 42px;
  text-align: center;
  letter-spacing: 2px;
  font-size: 14px;
}
.toolbar-lang span:hover,
.toolbar-lang span.current {
  border-bottom: 1px solid #ffffff;
}
.toolbar-lang .link.active {
  border-bottom: 1px solid #ffffff;
}
.toolbar-lang .link {
  display: inline;
  margin: 0 5px 0 5px;
}
.toolbar-lang a {
  color: #ffffff;
}
.toolbar-lang.light {
  background: rgba(255, 255, 255, 0.5);
}
.toolbar-lang.light a {
  color: #ADADAD;
}
.toolbar-lang.light span:hover,
.toolbar-lang.light span.current {
  border-bottom: 1px solid #000000;
}
.toolbar-lang.light span:hover a,
.toolbar-lang.light span.current a {
  color: #000000;
}
.toolbar-lang.light .link.active {
  border-bottom: 1px solid #000000;
}
.toolbar-lang.light .link.active a {
  color: #000000;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-lang.light {
    background: none;
    top: 8px;
    right: 46px;
    font-size: 12px;
  }
  .toolbar-lang.light a {
    color: #ffffff;
  }
  .toolbar-lang.light span:hover,
  .toolbar-lang.light span.current {
    border-bottom: 1px solid #ffffff;
  }
  .toolbar-lang.light span:hover a,
  .toolbar-lang.light span.current a {
    color: #ffffff;
  }
  .toolbar-lang.light .link.active {
    border-bottom: 1px solid #ffffff;
  }
  .toolbar-lang.light .link.active a {
    color: #ffffff;
  }
}
.toolbar-lang.dark {
  background: rgba(255, 255, 255, 0.5);
}
.toolbar-lang.dark a {
  color: #ADADAD;
}
.toolbar-lang.dark span:hover,
.toolbar-lang.dark span.current {
  border-bottom: 1px solid #000000;
}
.toolbar-lang.dark span:hover a,
.toolbar-lang.dark span.current a {
  color: #000000;
}
.toolbar-lang.dark .link.active {
  border-bottom: 1px solid #000000;
}
.toolbar-lang.dark .link.active a {
  color: #000000;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-lang.dark {
    background: none;
    top: 8px;
    right: 46px;
    font-size: 12px;
  }
  .toolbar-lang.dark a {
    color: #000000;
  }
  .toolbar-lang.dark span:hover,
  .toolbar-lang.dark span.current {
    border-bottom: 1px solid #000000;
  }
  .toolbar-lang.dark span:hover a,
  .toolbar-lang.dark span.current a {
    color: #000000;
  }
  .toolbar-lang.dark .link.active {
    border-bottom: 1px solid #000000;
  }
  .toolbar-lang.dark .link.active a {
    color: #000000;
  }
}
.toolbar-lang.grey {
  background: rgba(255, 255, 255, 0.5);
}
.toolbar-lang.grey a {
  color: #ADADAD;
}
.toolbar-lang.grey span:hover,
.toolbar-lang.grey span.current {
  border-bottom: 1px solid #000000;
}
.toolbar-lang.grey span:hover a,
.toolbar-lang.grey span.current a {
  color: #000000;
}
.toolbar-lang.grey .link.active {
  border-bottom: 1px solid #000000;
}
.toolbar-lang.grey .link.active a {
  color: #000000;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-lang.grey {
    background: none;
    top: 8px;
    right: 46px;
    font-size: 12px;
  }
  .toolbar-lang.grey a {
    color: #748087;
  }
  .toolbar-lang.grey span:hover,
  .toolbar-lang.grey span.current {
    border-bottom: 1px solid #748087;
  }
  .toolbar-lang.grey span:hover a,
  .toolbar-lang.grey span.current a {
    color: #748087;
  }
  .toolbar-lang.grey .link.active {
    border-bottom: 1px solid #748087;
  }
  .toolbar-lang.grey .link.active a {
    color: #748087;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-lang {
    background: none;
    top: 8px;
    right: 46px;
    font-size: 12px;
    z-index: 500;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-lang {
    position: fixed;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-lang {
    right: 40px;
  }
}
.toolbar-lang.fixed {
  position: fixed !important;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-lang.mainpage {
    position: absolute;
  }
}
.toolbar-menu {
  display: none;
  position: absolute;
  right: 13px;
  top: 20px;
}
.toolbar-menu .menu {
  padding: 5px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-menu {
    display: inline-block;
    z-index: 500;
  }
}
.toolbar-menu .menu:hover {
  cursor: pointer;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-menu {
    position: fixed;
  }
}
.toolbar-menu.fixed {
  position: fixed !important;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-menu.mainpage {
    position: absolute;
  }
}
.toolbar-bg {
  display: none;
  position: fixed;
  top: 0;
  width: 100%;
  height: 60px;
  z-index: -50;
  opacity: 0.95;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-bg {
    display: block;
    z-index: 499;
  }
}
.bg-work-main {
  background-image: url("/img/blueangle.svg");
  background-repeat: no-repeat;
  background-size: 70% auto;
  background-position: left center;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .bg-work-main {
    background-position: left center;
    background-size: 93% auto;
  }
}
.bg-events-main {
  background-image: url("/img/pinkskew.svg");
  background-repeat: no-repeat;
  background-size: 35% auto;
  background-position: right bottom 20px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .bg-events-main {
    background-position: right center;
    background-size: 48% auto;
  }
}
.bg-joinus-main {
  background-image: url("/img/greensquare.svg");
  background-repeat: no-repeat;
  background-size: 40% auto;
  background-position: left 40% bottom;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .bg-joinus-main {
    background-size: 60% auto;
    background-position: right 25px bottom 100px;
  }
}
.bg-team-main {
  background-image: url("/img/yellowtriangle.svg");
  background-repeat: no-repeat;
  background-size: 30% auto;
  background-position: left 25% bottom 30%;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .bg-team-main {
    background-size: 60% auto;
    background-position: right 25px bottom 100px;
  }
}
.bg-grey {
  background-color: #748087;
}
.bg-grey .toolbar-bg {
  background-color: #748087;
}
.bg-lightgrey {
  background-color: #f9f9f9;
}
.bg-lightgrey .toolbar-bg {
  background-color: #f9f9f9;
}
.bg-teal {
  background-color: #64e4d6;
}
.bg-teal .toolbar-bg {
  background-color: #64e4d6;
}
.bg-pink {
  background-color: #E4B0C3;
}
.bg-pink .toolbar-bg {
  background-color: #E4B0C3;
}
.bg-white {
  background-color: #ffffff;
}
.bg-white .toolbar-bg {
  background-color: #ffffff;
}
.bg-lightblue {
  background-color: #8FCBD9;
}
.bg-lightblue .toolbar-bg {
  background-color: #8FCBD9;
}
.bg-purple {
  background-color: #BF99E7;
}
.bg-purple .toolbar-bg {
  background-color: #BF99E7;
}
.bg-white {
  background-color: #E4E6E7;
}
.bg-white .toolbar-bg {
  background-color: #E4E6E7;
}
.toolbar-navi {
  position: absolute;
  top: 50px;
  right: 200px;
  z-index: 75;
  -webkit-touch-callout: none;
  /* iOS Safari */

  -webkit-user-select: none;
  /* Safari */

  -khtml-user-select: none;
  /* Konqueror HTML */

  -moz-user-select: none;
  /* Firefox */

  -ms-user-select: none;
  /* Internet Explorer/Edge */

  user-select: none;
  /* Non-prefixed version, currently supported by Chrome and Opera */

}
.toolbar-navi .underline {
  float: left;
  position: relative;
  bottom: -3px;
  width: 97%;
  border-bottom: 2px solid #ffffff;
}
.toolbar-navi.mainpage {
  text-shadow: 1px 1px 2px #000000;
}
.toolbar-navi.mainpage.dark span.dot {
  box-shadow: 1px 1px 2px #000000;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-navi {
    display: none;
    z-index: 500;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-navi {
    right: 130px;
  }
}
.toolbar-navi a {
  float: left;
  display: inline;
  position: relative;
  margin-right: 60px;
  font-size: 14px;
  letter-spacing: 2px;
}
.toolbar-navi span.dot:first-child {
  position: relative;
  float: left;
  left: -10px;
  top: -10px;
  width: 10px;
  height: 10px;
  visibility: hidden;
}
.toolbar-navi.dark span.link.active span.dot:first-child,
.toolbar-navi.light span.link.active span.dot:first-child,
.toolbar-navi.lightalt span.link.active span.dot:first-child,
.toolbar-navi.dark span.link:hover span.dot:first-child,
.toolbar-navi.light span.link:hover span.dot:first-child,
.toolbar-navi.lightalt span.link:hover span.dot:first-child,
.toolbar-navi.dark span.link.current span.dot:first-child,
.toolbar-navi.light span.link.current span.dot:first-child,
.toolbar-navi.lightalt span.link.current span.dot:first-child {
  visibility: visible;
}
.toolbar-navi.dark .home :hover,
.toolbar-navi.light .home :hover,
.toolbar-navi.lightalt .home :hover,
.toolbar-navi.dark .active :hover,
.toolbar-navi.light .active :hover,
.toolbar-navi.lightalt .active :hover {
  color: #ffffff;
}
.toolbar-navi.dark .home span.dot,
.toolbar-navi.light .home span.dot,
.toolbar-navi.lightalt .home span.dot,
.toolbar-navi.dark .active span.dot,
.toolbar-navi.light .active span.dot,
.toolbar-navi.lightalt .active span.dot {
  background: #ffffff;
}
.toolbar-navi.dark .work :hover,
.toolbar-navi.light .work :hover,
.toolbar-navi.lightalt .work :hover {
  color: #ffc3d7;
}
.toolbar-navi.dark .work span.dot,
.toolbar-navi.light .work span.dot,
.toolbar-navi.lightalt .work span.dot {
  background: #ffc3d7;
}
.toolbar-navi.dark .events :hover,
.toolbar-navi.light .events :hover,
.toolbar-navi.lightalt .events :hover {
  color: #a0e1ef;
}
.toolbar-navi.dark .events span.dot,
.toolbar-navi.light .events span.dot,
.toolbar-navi.lightalt .events span.dot {
  background: #a0e1ef;
}
.toolbar-navi.dark .join-us :hover,
.toolbar-navi.light .join-us :hover,
.toolbar-navi.lightalt .join-us :hover {
  color: #d6a9ff;
}
.toolbar-navi.dark .join-us span.dot,
.toolbar-navi.light .join-us span.dot,
.toolbar-navi.lightalt .join-us span.dot {
  background: #d6a9ff;
}
.toolbar-navi.dark .team :hover,
.toolbar-navi.light .team :hover,
.toolbar-navi.lightalt .team :hover {
  color: #64e4d6;
}
.toolbar-navi.dark .team span.dot,
.toolbar-navi.light .team span.dot,
.toolbar-navi.lightalt .team span.dot {
  background: #64e4d6;
}
.toolbar-navi.light a,
.toolbar-navi.light a:visited {
  color: #000000;
}
.toolbar-navi.light .active :hover {
  color: #000000 !important;
}
.toolbar-navi.light .active :hover {
  color: #000000;
}
.toolbar-navi.light .active span.dot {
  background: #000000;
}
.toolbar-navi.lightalt a,
.toolbar-navi.lightalt a:visited {
  color: #000000;
}
.toolbar-navi.lightalt .active :hover {
  color: #000000 !important;
}
.toolbar-navi.lightalt .home :hover,
.toolbar-navi.lightalt .active :hover {
  color: #000000;
}
.toolbar-navi.lightalt .home span.dot,
.toolbar-navi.lightalt .active span.dot {
  background: #000000;
}
.toolbar-navi.dark a,
.toolbar-navi.dark a:visited {
  color: #ffffff;
}
.toolbar-navi.dark .active :hover {
  color: #ffffff !important;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .toolbar-navi {
    position: fixed;
  }
}
.toolbar-navi.fixed {
  position: fixed !important;
}
.panel {
  height: 100%;
  width: 100%;
}
.panel .view {
  z-index: 0;
  width: 100%;
  min-height: 100%;
  position: relative;
  overflow: hidden;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .view {
    min-height: 0;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .view.bottom-padding {
    padding-bottom: 80px;
  }
}
.panel .view.no-min-height {
  min-height: 0;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .view.no-min-height {
    padding-bottom: 60px;
  }
}
.panel .view-header {
  padding: 0 100px 0 100px;
  min-height: 190px;
  width: 100%;
  margin-left: -100px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .panel .view-header {
    min-height: 100px;
    margin: -25px;
    padding: 25px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .view-header {
    min-height: 100px;
    margin: -50px;
    padding: 50px;
  }
}
.panel .content {
  z-index: 2;
  padding: 100px;
}
.panel .content:after {
  content: ".";
  visibility: hidden;
  display: block;
  height: 0;
  clear: both;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .panel .content {
    padding: 25px;
    min-height: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .content {
    padding: 50px;
    min-height: 0;
  }
}
.panel .content.no-padding-top {
  padding-top: 0;
}
@media only screen and (min-width: 1100px) and (max-width: 3000px) {
  .panel .content.extra-padding-bottom {
    padding-bottom: 300px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .content.bottom-padding {
    padding-bottom: 80px;
  }
}
.panel .content.no-min-height {
  min-height: 0;
}
.panel .content.left-padding {
  padding-left: 200px !important;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .panel .content.left-padding {
    padding: 25px !important;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .content.left-padding {
    padding: 50px !important;
  }
}
.panel .view-logobar {
  width: 100px;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
}
.panel .view-logobar a:hover {
  cursor: pointer;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .view-logobar {
    display: none;
  }
}
.panel .view-logobar .logo {
  position: absolute;
  height: 40px;
  width: 35px;
  left: 32px;
  top: 40px;
}
.panel .view-logobar .text {
  position: absolute;
  left: 41px;
  width: 14px;
  top: 400px;
  margin-top: -101px;
}
.panel .colorbar {
  width: 100px;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  z-index: 3;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .panel .colorbar {
    display: none;
  }
}
.table {
  display: table;
  width: 100%;
  height: 100%;
}
.table .column {
  display: table-column;
  vertical-align: middle;
}
.tablecontainer {
  display: table;
  position: absolute;
  height: 100%;
  width: 100%;
}
.tablecontainer .content {
  display: table-cell;
  vertical-align: middle;
}
.flexbox-center {
  text-align: center;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .flexbox-center {
    text-align: left;
    align-items: left;
    justify-content: flex-start;
  }
}
.splash-image {
  width: 54%;
  position: absolute;
  right: 100px;
  bottom: 200px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-image {
    display: none;
  }
}
.splash-image.splash-joinus {
  width: 49%;
}
.splash-image.splash-work {
  width: 52%;
}
@keyframes line-anim-frontpage {
  0% {
    width: 0;
  }
  10% {
    width: 40px;
    left: -199px;
  }
  40% {
    width: 40px;
    left: -91px;
  }
  50% {
    width: 0;
    left: -51px;
  }
  60% {
    width: 40px;
    left: -91px;
  }
  90% {
    width: 40px;
    left: -199px;
  }
  100% {
    width: 0;
  }
}
@keyframes line-anim-subpage {
  0% {
    width: 0;
  }
  10% {
    width: 40px;
    left: -193px;
  }
  40% {
    width: 40px;
    left: -91px;
  }
  50% {
    width: 0;
    left: -51px;
  }
  60% {
    width: 40px;
    left: -91px;
  }
  90% {
    width: 40px;
    left: -193px;
  }
  100% {
    width: 0;
  }
}
.splash-text {
  float: right;
  bottom: 180px;
  right: 85px;
  margin: 0 0 0 25px;
  position: absolute;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text {
    position: relative;
    right: 0;
    bottom: 0;
    display: block;
    margin-bottom: -150px;
    margin-top: 150px;
    float: none;
  }
}
.splash-text.margin-bottom-nullify {
  margin-bottom: 0;
}
@media only screen and (max-width: 320px) {
  .splash-text {
    margin-left: 0;
    margin-right: 0;
  }
}
.splash-text .subtext {
  position: relative;
  display: block;
  font-size: 20px;
  margin-bottom: 12px;
  text-align: right;
  left: -560px;
  letter-spacing: 1px;
  top: 79px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text .subtext {
    font-size: 18px;
    left: 0;
    top: 0;
    letter-spacing: 0;
    text-align: left;
  }
}
.splash-text .line1 {
  position: relative;
  opacity: 0.3;
  display: block;
  border-bottom: 2px solid #ffffff;
  margin-left: 25px;
  width: 142px;
  left: -193px;
  top: 54px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text .line1 {
    opacity: 1;
    left: 0;
    top: 0;
    margin-left: 25px;
    height: 50px;
    border-left: 1px solid #ffffff;
    border-bottom: none;
  }
}
.splash-text .line1-anim {
  position: relative;
  display: block;
  border-bottom: 2px solid #ffffff;
  margin-left: 25px;
  width: 0;
  left: -193px;
  top: 52px;
  animation: line-anim-subpage 4s steps(128) infinite;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text .line1-anim {
    display: none;
  }
}
.splash-text .line2 {
  position: relative;
  display: none;
  border-left: 1px solid #ffffff;
  margin-left: 25px;
  height: 400px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text .line2 {
    display: block;
  }
}
.splash-text .line3 {
  position: relative;
  display: none;
  border-left: 1px solid #ffffff;
  margin-left: 25px;
  height: 240px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text .line3 {
    display: block;
  }
}
.splash-text .title {
  position: relative;
  display: block;
  font-size: 74px;
  color: #ffffff;
  margin: 20px 0 0 0;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text .title {
    font-size: 48px;
  }
}
.splash-text .text {
  position: relative;
  line-height: 32px;
  font-size: 14px;
  letter-spacing: 1px;
  display: block;
  margin: 18px 0 10px 0;
  width: 370px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-text .text {
    max-width: 100%;
    line-height: 28px;
    font-size: 18px;
    letter-spacing: 0;
  }
}
.splash-text.no-bmargin {
  bottom: 0;
}
.splash-front-text {
  float: right;
  bottom: 86px;
  right: 100px;
  letter-spacing: 1px;
  line-height: 72px;
  margin: 0 0 0 25px;
  position: absolute;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-front-text {
    display: none;
  }
}
@media only screen and (max-width: 320px) {
  .splash-front-text {
    margin-left: 0;
    margin-right: 0;
  }
}
.splash-front-text .subtext {
  color: #ffffff;
  position: relative;
  display: block;
  font-size: 20px;
  margin-bottom: 12px;
  text-align: right;
  left: -635px;
  letter-spacing: 1px;
  top: 149px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-front-text .subtext {
    font-size: 18px;
    left: 0;
    top: 0;
    letter-spacing: 0;
    text-align: left;
  }
}
.splash-front-text .line1 {
  position: relative;
  opacity: 0.3;
  display: block;
  border-bottom: 3px solid #ffffff;
  margin-left: 25px;
  width: 147px;
  left: -199px;
  top: 96px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-front-text .line1 {
    opacity: 1;
    left: 0;
    top: 0;
    margin-left: 25px;
    height: 50px;
    border-left: 1px solid #ffffff;
    border-bottom: none;
  }
}
.splash-front-text .line1-anim {
  position: relative;
  display: block;
  border-bottom: 3px solid #ffffff;
  margin-left: 25px;
  width: 0;
  left: -199px;
  top: 93px;
  animation: line-anim-frontpage 4s steps(128) infinite;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-front-text .line1-anim {
    display: none;
  }
}
.splash-front-text .title {
  position: relative;
  display: block;
  font-size: 76px;
  color: #ffffff;
  margin: 20px 0 0 0;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .splash-front-text .title {
    font-size: 48px;
  }
}
.joinus-lookingfor {
  max-width: 1050px;
  max-height: 700px;
  margin: 0 auto;
  display: flex;
  font-size: 32px;
}
@media only screen and (min-width: 816px) and (max-width: 1241px) {
  .joinus-lookingfor {
    max-height: 1200px;
    max-width: 710px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .joinus-lookingfor {
    width: 100%;
    max-width: 100%;
    margin-bottom: 0;
  }
}
@media only screen and (max-width: 320px) {
  .joinus-lookingfor {
    margin: 25px 0;
  }
}
.joinus-lookingfor .text {
  padding: 40px;
  max-width: 50%;
  position: relative;
  margin: 25px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .joinus-lookingfor .text {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0 25px 50px 25px;
  }
}
@media only screen and (min-width: 816px) and (max-width: 1241px) {
  .joinus-lookingfor .text {
    max-width: 100%;
  }
}
:lang(ja) .joinus-lookingfor {
  font-size: 28px;
}
.seeitall-button {
  padding: 50px 0;
  display: block;
  position: relative;
  float: left;
  width: 100%;
  text-align: center;
}
.seeitall-button a img {
  width: 240px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .seeitall-button {
    padding: 25px 0 0 0;
  }
  .seeitall-button a img {
    width: 160px;
  }
}
.game-splash {
  display: block;
  margin: 50px -100px 50px -100px;
}
.game-splash .video-container {
  display: block;
  position: relative;
  width: auto;
  height: 0;
  padding-bottom: 56.25%;
  margin: 0 100px;
}
.game-splash .video-container .video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .game-splash .video-container {
    margin: 0 25px;
  }
}
.game-splash .image-container {
  padding: 0 100px;
  display: block;
  overflow: hidden;
}
.game-splash .image-container img {
  vertical-align: middle;
  width: 100%;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .game-splash .image-container {
    padding: 0;
    margin: 25px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .game-splash {
    margin: 25px -25px;
  }
}
.game-title {
  margin-left: 10%;
  display: block;
}
.game-title .subtext {
  font-size: 22px;
  position: relative;
}
.game-title .line {
  margin: 0 35px;
}
.game-title .line img {
  width: 117px;
  top: -6px;
  position: relative;
}
.game-title .title {
  font-size: 52px;
  position: relative;
  bottom: -10px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .game-title {
    margin-left: 0;
    margin-top: 55px;
  }
  .game-title .subtext {
    font-size: 18px;
  }
  .game-title .line {
    margin: 0 10px;
  }
  .game-title .line img {
    width: 60px;
  }
  .game-title .title {
    font-size: 30px;
    bottom: -4px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .game-title {
    margin-left: 0;
    margin-top: 80px;
  }
  .game-title .subtext {
    font-size: 18px;
  }
  .game-title .line {
    margin: 0 10px;
  }
  .game-title .line img {
    width: 60px;
  }
  .game-title .title {
    font-size: 30px;
    bottom: -4px;
  }
}
.game-text {
  display: block;
  margin: 100px 100px 50px 100px;
}
.game-text h1 {
  text-align: center;
  font-size: 40px;
  font-weight: 100;
}
.game-text h2 {
  text-align: center;
  font-weight: 100;
  font-size: 24px;
}
.game-text p {
  font-size: 18px;
  line-height: 32px;
}
.game-text ul.dashed {
  padding-left: 0;
}
.game-text ul.dashed li {
  line-height: 20px;
  margin-bottom: 10px;
}
.game-text ul.dashed {
  list-style-type: none;
}
.game-text ul.dashed > li {
  text-indent: -5px;
  line-height: 32px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .game-text ul.dashed > li {
    line-height: 24px;
  }
}
.game-text ul.dashed > li:before {
  content: "-";
  text-indent: -5px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .game-text {
    margin: 0;
  }
  .game-text h1 {
    font-size: 28px;
  }
  .game-text h2 {
    font-size: 18px;
  }
  .game-text p {
    line-height: 24px;
  }
}
.game-picture-halfwidth {
  display: block;
  margin: 50px 0;
}
.game-picture-halfwidth img {
  width: 49%;
}
.game-picture-halfwidth img :first-child {
  margin-right: 2%;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .game-picture-halfwidth {
    margin: 0;
  }
  .game-picture-halfwidth img {
    width: 100%;
    margin-bottom: 14px;
  }
}


.shop-icons {
  height: 50px;
  width: 260px;
  display: block;
  margin: auto;
}

.shop-icons a {
  display: inline-block;
  height: 100%;
  margin: 5px;
}

.shop-icons a img {
  display: block;
  height: 100%;
}

.game-picture-big {
  display: block;
  margin: 50px 0;
}
.game-picture-big img {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  display: block;
}
.game-picture-big img :first-child {
  margin-right: 2%;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .game-picture-big {
    margin: 0;
  }
  .game-picture-big img {
    width: 100%;
    margin-bottom: 14px;
  }
}


.game-thomas img {
  width: 120px;
}
.game-thomas.small {
  display: none;
  width: 100%;
  text-align: center;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .game-thomas.small {
    display: block;
    margin-top: 50px;
  }
}
.game-thomas.large {
  margin-left: 25px;
  float: right;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .game-thomas.large {
    display: none;
  }
}
.work-button {
  width: 100%;
  display: none;
  text-align: center;
  margin: 100px 0 25px 0;
}
.work-button img {
  width: 150px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .work-button {
    display: block;
  }
}
.work-cards,
.job-cards,
.team-cards {
  padding-bottom: 100px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .work-cards,
  .job-cards {
    padding-bottom: 0;
    margin: 0;
    display: block;
  }
}
.team-cards {
  flex-direction: row;
}
.team-cards {
  max-width: 1050px;
  /*max-height: 1550px;*/

}
@media only screen and (min-width: 768px) and (max-width: 1170px) {
  .team-cards {
    max-width: 710px;
    /*max-height: 3000px;*/
  
  }
}
.job-cards {
  max-width: 1050px;
  max-height: 700px;
}
@media only screen and (min-width: 816px) and (max-width: 1241px) {
  .job-cards {
    max-width: 710px;
    max-height: 1200px;
  }
}
.work-cards {
  max-width: 1050px;
  max-height: 5200px;
}
@media only screen and (min-width: 768px) and (max-width: 1170px) {
  .work-cards {
    max-width: 710px;
    max-height: 5000px;
  }
}
.job-card {
  max-width: 250px;
  padding: 40px;
  position: relative;
  margin: 25px;
}
.job-card:hover {
  -webkit-box-shadow: 0px 0px 47px -10px rgba(0, 0, 0, 0.55);
  -moz-box-shadow: 0px 0px 47px -10px rgba(0, 0, 0, 0.55);
  box-shadow: 0px 0px 47px -10px rgba(0, 0, 0, 0.55);
  background: white;
}
.job-info
{
	padding: 40px;
  position: relative;
  margin: 25px;
   -webkit-box-shadow: 0px 0px 47px -10px rgba(0, 0, 0, 0.55);
  -moz-box-shadow: 0px 0px 47px -10px rgba(0, 0, 0, 0.55);
  box-shadow: 0px 0px 47px -10px rgba(0, 0, 0, 0.55);
  background: white;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .job-card {
    margin: 12.5px 0;
    max-width: 100%;
    padding: 25px;
    height: auto;
    background: #ffffff;
    float: left;
  }
}
@media only screen and (max-width: 320px) {
  .job-card {
    padding: 25px;
  }
}
.job-card .title {
  font-size: 26px;
  display: block;
  margin-bottom: 20px;
  line-height: 40px;
}
.job-card .title .underline {
  border-bottom: 2px solid #748087;
}
.job-card .text {
  display: block;
  font-size: 14px;
  line-height: 25px;
}
.job-card .text ul {
  padding-left: 20px;
}
:lang(ja) .job-card .title {
  letter-spacing: -1px;
}
:lang(ja) .smaller-spacing {
  letter-spacing: -1px;
}
.team-card {
  max-width: 300px;
  position: relative;
  margin: 25px;
  background: #ffffff;
  /*@media @smallphones, @smartphones, @tablets {
        max-width: 100%;
        margin: 12px 0 12px 0;
        min-height: 0;
        
    }*/

}
.team-card .img img {
  width: 100%;
  height: auto;
}
.team-card .threed {
  display: inline-block;
  width: 300px;
  height: 300px;
  background: black;
  /*@media @smallphones, @smartphones, @tablets {
            display: block;
        }*/

}
.team-card .contents {
  float: left;
  padding: 20px;
  /*@media @smallphones, @smartphones, @tablets {
            margin-bottom: 30px;
        }*/

}
.team-card .contents .name {
  display: block;
  font-size: 26px;
  margin-bottom: 14px;
}
.team-card .contents .title {
  display: block;
  font-size: 18px;
  text-decoration: underline;
  margin-bottom: 10px;
}
.team-card .contents .description {
  display: block;
  font-size: 14px;
  line-height: 25px;
  margin-bottom: 60px;
  /*@media @smallphones, @smartphones, @tablets {
                margin-bottom: 30px;
            }*/

}
.team-card .contents .smaller-padding a {
  padding: 10px 14px;
}
@media only screen and (max-width: 320px) {
  .team-card .contents .smaller-padding a {
    padding: 10px 9px;
  }
}
.work-card {
  max-width: 300px;
  position: relative;
  margin: 25px;
  background: #ffffff;
}
.work-card .img img {
  width: 100%;
  height: auto;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .work-card {
    max-width: 100%;
    margin: 12px 0 12px 0;
    min-height: 0;
    float: left;
  }
}
.work-card .contents {
  float: left;
  padding: 20px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .work-card .contents {
    margin-bottom: 30px;
  }
}
.work-card .contents .date {
  display: block;
  font-size: 13px;
  margin-bottom: 19px;
}
.work-card .contents .title {
  display: block;
  font-size: 26px;
  margin-bottom: 14px;
}
.work-card .contents .subtitle {
  display: block;
  font-size: 18px;
  text-decoration: underline;
  margin-bottom: 10px;
}
.work-card .contents .text {
  display: block;
  font-size: 14px;
  line-height: 25px;
  margin-bottom: 60px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .work-card .contents .text {
    margin-bottom: 30px;
  }
}
.work-card .contents .read-more-container {
  display: block;
  width: 100%;
  position: absolute;
  margin-left: -20px;
  bottom: 5px;
  text-align: center;
}
.work-card .contents .read-more {
  display: inline-block;
  text-align: center;
  margin: 12px auto 24px 0;
}
.work-card .contents .read-more:hover a {
  background: #748087;
  color: #ffffff;
}
.work-card .contents .read-more a {
  font-size: 14px;
  padding: 10px 24px;
  border: 1px solid #748087;
  width: 100%;
  height: 100%;
}
@media only screen and (min-width: 320px) and (max-width: 768px) {
  .work-card .contents .read-more a {
    padding: 10px 18px;
  }
}
.work-card .contents .smaller-padding a {
  padding: 10px 14px;
}
@media only screen and (max-width: 320px) {
  .work-card .contents .smaller-padding a {
    padding: 10px 9px;
  }
}
.panel-line {
  height: 201px;
  position: absolute;
}
.panel-line.weare-line {
  bottom: -100px;
  right: 165px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .panel-line.weare-line {
    height: 100px;
    right: 60px;
    bottom: -90px;
  }
}
.panel-line.work-line {
  top: 0;
  right: 165px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .panel-line.work-line {
    height: 100px;
    right: 60px;
    top: -40px;
  }
}
.panel-line.imb-line {
  bottom: -130px;
  right: 123px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .panel-line.imb-line {
    height: 100px;
    left: 90px;
    bottom: -70px;
  }
}
.panel-line.contact-line {
  top: -70px;
  right: 123px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .panel-line.contact-line {
    height: 100px;
    left: 90px;
    top: -40px;
  }
}
.panel-line.events-header-line {
  display: none;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .panel-line.events-header-line {
    display: inline-block;
    height: 80px;
    left: 81px;
    top: -44px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .panel-line.events-header-line {
    top: -43px;
  }
}
.events-list {
  display: table;
  text-align: center;
  width: 100%;
  margin-bottom: 100px;
}
.events-list:after {
  content: ".";
  visibility: hidden;
  display: block;
  height: 0;
  clear: both;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .events-list {
    display: block;
    margin-bottom: 0;
  }
}
.event-container {
  display: table;
  margin: auto;
  margin-bottom: 50px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .event-container {
    width: 100%;
    display: block;
    margin-bottom: 0;
  }
}
.event-container .event-image {
  display: inline-block;
  width: 600px;
  overflow: hidden;
}
.event-container .event-image img {
  width: 100%;
  vertical-align: middle;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .event-container .event-image {
    width: 100%;
    max-width: 100%;
    margin: 0;
    margin-bottom: 0;
  }
}
.event-container .event-card {
  text-align: left;
  vertical-align: top;
  display: table-cell;
  height: 100%;
  min-width: 237px;
  background: #ffffff;
  padding: 50px 20px 30px 20px;
  width: 350px;
}
.event-container .event-card .date {
  display: block;
  font-size: 13px;
  margin-bottom: 19px;
  display: none;
  margin: 25px 25px 12px 25px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .event-container .event-card {
    margin: 0 0 25px 0;
    display: block;
    width: 100%;
    padding: 7px 0;
  }
  .event-container .event-card .date {
    display: block;
  }
}
.event-container .event-card .title {
  font-size: 26px;
  display: block;
  margin: 0 25px;
  margin-bottom: 15px;
}
.event-container .event-card .subtitle {
  font-size: 18px;
  text-decoration: underline;
  display: block;
  margin-bottom: 15px;
  margin: 0 25px 25px 25px;
}
.event-container .event-card .text {
  font-size: 14px;
  line-height: 25px;
  display: block;
  margin: 25px;
}
.bg-grey {
  background: #748087;
}
.bg-white {
  background: #ffffff;
}
.bg-pink {
  background: #ffc3d7;
}
.bg-lightblue {
  background: #a0e1ef;
}
.bg-purple {
  background: #d7b9f0;
}
.bg-yellow {
  background: #FFFF9E;
}
.footer {
  background-color: #748087;
  min-height: 120px;
  display: block;
  padding: 50px 10px 10px 100px;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer {
    padding: 12px 0;
    min-height: 0;
  }
}
.footer .copyright {
  color: #000000;
  position: absolute;
  left: 200px;
  display: inline-block;
  line-height: 18px;
  font-size: 13px;
  top: 100px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .copyright {
    width: 100%;
    position: static;
    left: 0;
    font-size: 10px;
    bottom: auto;
    text-align: center;
  }
}
.footer .social-links {
  float: right;
}
.footer .social-links .icon {
  width: 32px;
  display: inline-block;
  height: 32px;
  margin-right: 90px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .social-links .icon {
    margin-left: 0;
    margin: 0 25px;
    width: 25px;
    height: 25px;
  }
}
.footer .social-links .icon a {
  width: 100%;
  height: 100%;
  display: inline-block;
}
.footer .social-links .icon.facebook,
.footer .social-links .icon.twitter,
.footer .social-links .icon.instagram {
  background-image: url("/img/sns-logo.svg");
  background-repeat: no-repeat;
  background-size: 95.4px 64px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .social-links .icon.facebook,
  .footer .social-links .icon.twitter,
  .footer .social-links .icon.instagram {
    background-size: 74.4px 49.9px;
  }
}
.footer .social-links .icon.twitter {
  background-position-x: -64px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .social-links .icon.twitter {
    width: 24px;
  }
}
.footer .social-links .icon.twitter:hover {
  background-position-y: -31.5px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .social-links .icon.twitter {
    background-position-x: -49.9px;
  }
  .footer .social-links .icon.twitter:hover {
    background-position-y: -25px;
  }
}
.footer .social-links .icon.instagram {
  background-position-x: 1px;
}
.footer .social-links .icon.instagram:hover {
  background-position-y: -32.4px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .social-links .icon.instagram {
    background-position-x: 1px;
  }
  .footer .social-links .icon.instagram:hover {
    background-position-y: -25px;
  }
}
.footer .social-links .icon.facebook {
  background-position-x: -31.4px;
}
.footer .social-links .icon.facebook:hover {
  background-position-y: -32.4px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .social-links .icon.facebook {
    background-position-x: -24.5px;
  }
  .footer .social-links .icon.facebook:hover {
    background-position-y: -25px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .social-links {
    width: 100%;
    display: block;
    text-align: center;
    margin: 25px 0;
  }
}
.footer .links {
  margin-left: 100px;
  float: left;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer .links {
    display: none;
  }
}
.footer .links .link {
  color: #ffffff;
  margin: 4px 35px 10px 0;
  float: left;
}
.footer .links .link.home:hover {
  color: #ffff9e;
}
.footer .links .link.work:hover {
  color: #ffc3d7;
}
.footer .links .link.events:hover {
  color: #a0e1ef;
}
.footer .links .link.join-us:hover {
  color: #d6a9ff;
}
.footer .links .link.team:hover {
  color: #64e4d6;
}
.footer.relative {
  display: none;
  position: relative;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .footer.relative {
    display: block;
  }
}
:lang(ja) .frontpage-first {
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first {
    margin-left: 25px;
  }
}
:lang(ja) .frontpage-first .title {
  font-size: 28px;
}
:lang(ja) .frontpage-first .title .wa {
  display: inline-block;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first .title {
    width: auto;
  }
}
:lang(ja) .frontpage-first .kanji {
  position: relative;
  font-size: 60px;
  display: block;
}
:lang(ja) .frontpage-first .kanji.wa {
  letter-spacing: -20px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first .kanji {
    font-size: 42px;
  }
}
:lang(ja) .frontpage-first .underbar {
  position: relative;
}
:lang(ja) .frontpage-first .underbar img {
  width: 70px;
}
:lang(ja) .frontpage-first .letter-container {
  display: inline-block;
  width: 120px;
  height: auto;
  padding: 90px 70px 70px 70px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first .letter-container {
    padding: 12px 0;
    display: block;
    width: auto;
    height: auto;
  }
}
:lang(ja) .frontpage-first .explanation {
  display: block;
  font-size: 12px;
  padding-top: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first .explanation {
    padding-top: 6px;
  }
}
:lang(ja) .frontpage-first .explanations-container {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first .explanations-container {
    flex-direction: column;
    align-items: left;
    justify-content: center;
    width: auto;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first .bottom-text .l {
    float: left;
  }
  :lang(ja) .frontpage-first .bottom-text {
    margin-top: 20px;
    margin-bottom: 150px;
    line-height: 24px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  :lang(ja) .frontpage-first .bottom-text {
    max-width: 70%;
  }
}
.m-title {
  color: #ffffff;
}
.m-title.dark {
  color: #ffffff;
}
.m-title.light {
  color: #748087;
}
.m-title.left {
  margin-top: 20%;
  clear: both;
  float: left;
  position: relative;
  font-size: 28px;
  margin-left: 100px;
  max-width: 400px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .m-title.left {
    font-size: 30px;
    max-width: 100%;
    margin-left: 25px;
    margin-right: 25px;
    margin-top: 100px;
  }
}
@media only screen and (max-width: 320px) {
  .m-title.left {
    margin-left: 0;
    margin-right: 0;
    margin-top: 25px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .m-title.left {
    margin-top: 100px;
    font-size: 35px;
  }
}
.m-title.right {
  margin-top: 15%;
  clear: both;
  float: right;
  position: relative;
  font-size: 60px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .m-title.right {
    font-size: 45px;
    margin-top: 50px;
    margin-bottom: 0;
    margin-left: 25px;
    margin-right: 25px;
  }
}
@media only screen and (max-width: 320px) {
  .m-title.right {
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .m-title.right {
    margin-top: 170px;
  }
}
.m-copy {
  line-height: 35px;
  color: #ffffff;
}
.m-copy.light {
  color: #333;
}
.m-copy.left {
  float: left;
  clear: both;
  position: relative;
  font-size: 18px;
  max-width: 500px;
  margin-left: 100px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .m-copy.left {
    max-width: 100%;
    font-size: 18px;
    line-height: 27px;
    margin-left: 25px;
    margin-right: 25px;
    margin-bottom: 100px;
  }
}
@media only screen and (max-width: 320px) {
  .m-copy.left {
    margin-left: 0;
    margin-right: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .m-copy.left {
    margin-bottom: 100px;
  }
}
.m-copy.right {
  float: right;
  clear: both;
  position: relative;
  text-align: right;
  max-width: 500px;
  font-size: 18px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .m-copy.right {
    font-size: 18px;
    line-height: 27px;
    margin-left: 25px;
    margin-right: 25px;
    max-width: 93%;
  }
}
@media only screen and (max-width: 320px) {
  .m-copy.right {
    max-width: 250px;
    margin-left: 0;
    margin-right: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .m-copy.right {
    margin-bottom: 100px;
  }
}
:lang(ja) .m-title.left {
  font-size: 28px;
}
:lang(ja) .m-copy.left {
  font-size: 16px;
}
:lang(ja) .m-copy.right {
  font-size: 16px;
}
.color-pink {
  color: #ffc3d7;
}
.color-lightblue {
  color: #a0e1ef;
}
.color-teal {
  color: #64e4d6;
}
.rotate {
  -webkit-animation: spin 45s infinite linear;
  animation: spin 45s infinite linear;
}
@-webkit-keyframes spin {
  100% {
    -webkit-transform: rotate(-360deg);
  }
}
@-moz-keyframes spin {
  100% {
    -moz-transform: rotate(-360deg);
  }
}
@keyframes spin {
  100% {
    -moz-transform: rotate(-360deg);
    -o-transform: rotate(-360deg);
    transform: rotate(-360deg);
  }
}
.logo-container {
  text-align: center;
  display: block;
  height: 200px;
  margin-top: 100px;
  margin-bottom: 400px;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}
.logo-container .contact-logo-center {
  position: absolute;
  width: 87.4px;
  margin-left: -43px;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .logo-container {
    margin-top: 70px;
    margin-bottom: 350px;
  }
}
@media only screen and (max-width: 320px) {
  .logo-container {
    margin-top: 60px;
    margin-bottom: 350px;
  }
}
.logo-container .contact-spin {
  width: 176px;
  margin-left: -88px;
  margin-top: -36px;
  position: absolute;
}
.logo-container .contact-logo-top {
  position: absolute;
  margin-left: -43px;
  width: 87.4px;
}
.logo-container .contact-logo-bottom {
  position: absolute;
  margin-top: 61.9px;
  margin-left: -43px;
  width: 43.7px;
}
.logo-container .contact-logo-left {
  position: absolute;
  margin-top: 25px;
  margin-left: -43px;
  width: 21.9px;
}
.logo-container .contact-logo-right {
  position: absolute;
  margin-top: 49.7px;
  margin-left: 0.2px;
  width: 43.7px;
}
#contactview {
  min-height: 100%;
}
#contactview .content {
  min-height: 100%;
}
.contact {
  font-size: 70px;
  margin-top: 200px;
  text-align: right;
  display: block;
  position: relative;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .contact {
    font-size: 59px;
    right: 0;
    margin-top: 80px;
    top: 0;
    margin-left: 25px;
    text-align: left;
    width: 100%;
  }
}
@media only screen and (max-width: 320px) {
  .contact {
    font-size: 50px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .contact {
    font-size: 60px;
  }
}
.contact-container {
  display: block;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .contact-container {
    width: 100%;
    margin-top: 40px;
    height: auto;
    bottom: 0;
    right: 0;
    position: relative;
    display: block;
    margin-bottom: 120px;
  }
}
@media only screen and (max-width: 320px) {
  .contact-container {
    margin-top: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-container {
    margin-top: 180px;
    width: 100%;
    height: auto;
    bottom: 0;
    right: 0;
    position: relative;
    float: right;
    display: inline-block;
    margin-bottom: 150px;
  }
}
.contact-info {
  display: flex;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info {
    justify-content: left;
  }
}
.contact-info .box {
  position: absolute;
  bottom: 300px;
  margin: 0 auto;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box {
    bottom: 160px;
    max-width: 400px;
    margin: 0;
  }
}
.contact-info .box .block {
  display: inline-block;
  margin: 0 50px;
}
@media only screen and (min-width: 816px) and (max-width: 1241px) {
  .contact-info .box .block {
    margin: 0 15px;
  }
}
@media only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block {
    margin: 0 12.5px 0 25px;
  }
}
@media only screen and (max-width: 320px) {
  .contact-info .box .block {
    margin: 0 12.5px 0 0;
  }
}
.contact-info .box .block .text {
  position: relative;
  display: inline-block;
}
.contact-info .box .block .icon {
  vertical-align: middle;
  position: relative;
  width: 40px;
  text-align: center;
  overflow: hidden;
  margin-right: 20px;
  display: inline-block;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .contact-info .box .block .icon {
    margin-right: 10px;
    width: 22px;
  }
}
@media only screen and (min-width: 816px) and (max-width: 1241px) {
  .contact-info .box .block .icon {
    margin-right: 5px;
  }
}
.contact-info .box .block.email a:hover {
  color: #ffc3d7;
}
.contact-info .box .block.email .icon img {
  width: 36.3px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.email .icon img {
    width: 22px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.email {
    margin-right: 0;
  }
  .contact-info .box .block.email .icon {
    margin-right: 5px;
  }
}
.contact-info .box .block.phone {
  margin-top: 20px;
}
.contact-info .box .block.phone a:hover {
  color: #a0e1ef;
}
.contact-info .box .block.phone .icon img {
  width: 26.7px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.phone .icon img {
    width: 20px;
  }
}
@media only screen and (max-width: 320px) {
  .contact-info .box .block.phone {
    margin-top: 10px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.phone {
    margin-right: 0;
  }
  .contact-info .box .block.phone .icon {
    margin-right: 5px;
  }
}
.contact-info .box .block.address {
  font-size: 14px;
  line-height: 26px;
}
.contact-info .box .block.address .text {
  position: relative;
  bottom: -22px;
}
.contact-info .box .block.address .text.lower {
  bottom: -50px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.address .text.lower {
    bottom: 0px;
  }
}
.contact-info .box .block.address .icon img {
  width: 32px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.address {
    margin-top: -8px;
  }
  .contact-info .box .block.address .icon img {
    width: 20px;
  }
}
@media only screen and (max-width: 320px) {
  .contact-info .box .block.address {
    margin-top: -12px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.address {
    margin-right: 0;
  }
  .contact-info .box .block.address .icon {
    margin-right: 5px;
  }
}
.contact-info .box .block.address a:hover {
  color: #d6a9ff;
}
.contact-info .box .block.email,
.contact-info .box .block.phone {
  font-size: 24px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .contact-info .box .block.email,
  .contact-info .box .block.phone {
    font-size: 18px;
  }
}
.contact-info .box .block.email .icon img:last-child,
.contact-info .box .block.phone .icon img:last-child,
.contact-info .box .block.address .icon img:last-child {
  display: none;
}
.contact-info .box .block.email .address-glyphs,
.contact-info .box .block.phone .address-glyphs,
.contact-info .box .block.address .address-glyphs {
  font-family: "SCSGlyph";
}
.contact-info .box .block.email.hover a:hover .icon img:first-child,
.contact-info .box .block.phone.hover a:hover .icon img:first-child,
.contact-info .box .block.address.hover a:hover .icon img:first-child {
  display: none;
}
.contact-info .box .block.email.hover a:hover .icon img:last-child,
.contact-info .box .block.phone.hover a:hover .icon img:last-child,
.contact-info .box .block.address.hover a:hover .icon img:last-child {
  display: inline-block;
}
@keyframes weare-anim {
  from {
    top: 0;
  }
  to {
    top: 150px;
    opacity: 1;
  }
}
@keyframes tealtriangle-anim {
  from {
    left: 0;
  }
  to {
    left: 100px;
    opacity: 1;
  }
}
@keyframes pingangle-anim {
  from {
    bottom: 0;
  }
  to {
    bottom: 100px;
    opacity: 1;
  }
}
@keyframes blueskew-anim1 {
  from {
    right: -100px;
    bottom: -80px;
  }
  to {
    right: 0;
    bottom: -180px;
    opacity: 1;
  }
}
@keyframes blueskew-anim2 {
  from {
    right: -100px;
    top: -388px;
  }
  to {
    right: 0;
    top: -288px;
    opacity: 1;
  }
}
@keyframes purplesquare-anim1 {
  from {
    left: 0;
  }
  to {
    left: 100px;
    opacity: 1;
  }
}
@keyframes purplesquare-anim2 {
  from {
    left: 0;
  }
  to {
    left: 100px;
    opacity: 1;
  }
}
.anim-bg {
  overflow: hidden;
  width: 100%;
  height: 100%;
  z-index: 1;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}
.anim-bg.weare img.anim01 {
  opacity: 0;
  position: absolute;
  top: 150px;
  left: 370px;
  width: 900px;
}
.anim-bg.weare img.anim01.animate {
  animation-name: weare-anim;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.weare img.anim01.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.weare img.anim01 {
    opacity: 1;
    left: -225px;
    top: 50px;
    animation-fill-mode: none;
  }
}
.anim-bg.weare img.anim02 {
  opacity: 0;
  position: absolute;
  left: 100px;
  bottom: -118px;
  width: 204px;
}
.anim-bg.weare img.anim02.animate {
  animation-name: tealtriangle-anim;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.weare img.anim02.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.weare img.anim02 {
    opacity: 1;
    width: 170px;
    left: 0;
    bottom: -98px;
  }
}
.anim-bg.work1 img.anim01 {
  opacity: 0;
  position: absolute;
  left: 100px;
  top: -118px;
  width: 204px;
}
.anim-bg.work1 img.anim01.animate {
  animation-name: tealtriangle-anim;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work1 img.anim01.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work1 img.anim01 {
    opacity: 1;
    width: 170px;
    left: 0;
    top: -98px;
  }
}
.anim-bg.work4 img.anim01 {
  opacity: 0;
  position: absolute;
  left: 170px;
  bottom: 100px;
  width: 814px;
}
.anim-bg.work4 img.anim01.animate {
  animation-name: pingangle-anim;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work4 img.anim01.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work4 img.anim01 {
    opacity: 1;
    left: -180px;
    bottom: -200px;
  }
}
.anim-bg.work2 img.anim01 {
  opacity: 0;
  position: absolute;
  right: 0;
  bottom: -180px;
  width: 407px;
}
.anim-bg.work2 img.anim01.animate {
  animation-name: blueskew-anim1;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work2 img.anim01.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work2 img.anim01 {
    opacity: 1;
    right: -230px;
    bottom: -20px;
  }
}
.anim-bg.work3 img.anim01 {
  opacity: 0;
  position: absolute;
  right: 0;
  top: -288px;
  width: 407px;
}
.anim-bg.work3 img.anim01.animate {
  animation-name: blueskew-anim2;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work3 img.anim01.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work3 img.anim01 {
    opacity: 1;
    right: -230px;
    top: -448px;
  }
}
.anim-bg.work3 img.anim02 {
  opacity: 0;
  position: absolute;
  bottom: -100px;
  left: 100px;
  width: 407px;
}
.anim-bg.work3 img.anim02.animate {
  animation-name: purplesquare-anim1;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work3 img.anim02.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.work3 img.anim02 {
    opacity: 1;
    left: -179px;
    bottom: -40px;
  }
}
.anim-bg.cntct img.anim01 {
  opacity: 0;
  position: absolute;
  left: 100px;
  top: -252px;
  width: 407px;
}
.anim-bg.cntct img.anim01.animate {
  animation-name: purplesquare-anim2;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.cntct img.anim01.animate {
    animation: none;
    animation-fill-mode: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .anim-bg.cntct img.anim01 {
    opacity: 1;
    left: -179px;
    top: -312px;
  }
}
.bg-weare {
  background-image: url("/img/happyblock.svg");
  background-repeat: repeat-y;
  background-size: 400px auto;
  background-position: 100px 0;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .bg-weare {
    background-image: none;
  }
}
.boneplayer {
  text-align: center;
  margin: 25px 0 0 0;
  width: 46px;
  height: 36px;
  display: none;
  position: relative;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .boneplayer {
    margin-left: 50px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .boneplayer {
    margin-left: 75px;
  }
}
.boneplayer.right {
  float: right;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .boneplayer.right {
    margin-left: 50px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .boneplayer.right {
    float: left;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .boneplayer.right {
    margin-left: 75px;
  }
}
.boneplayer :hover {
  cursor: pointer;
}
.boneplayer img {
  width: 10px;
  height: 10px;
}
.boneplayer .status-bg {
  width: 46px;
  height: 20px;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url("/img/player-status-bg.png");
  background-size: 46px 20px;
  background-repeat: no-repeat;
}
.boneplayer .status-pb {
  width: 0px;
  height: 20px;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url("/img/player-status-pb.png");
  background-size: 46px 20px;
  background-repeat: no-repeat;
}
.boneplayer .pause,
.boneplayer .play {
  bottom: 0;
  left: 18px;
  display: block;
  position: absolute;
}
.boneplayer .play {
  display: none;
}
:lang(ja) .contact-info .box .block.address {
  letter-spacing: 2px;
}
.frontpage-team {
  margin-bottom: 5px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-team .header {
    margin: 70px 0 0 0;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .frontpage-team .header {
    margin-left: 25px;
  }
}
.frontpage-team .title {
  font-size: 60px;
  float: none;
  position: relative;
  margin-left: 30px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-team .title {
    font-size: 54px;
    margin-left: 0;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-team {
    margin-bottom: 0px;
  }
}
.frontpage-team .title-container {
  margin-bottom: 100px;
  float: none;
}
.frontpage-team .subtext {
  float: none;
  font-size: 18px;
  top: -10px;
  position: relative;
}
.frontpage-team .text {
  display: block;
  width: 100%;
  margin: 35px 0;
  line-height: 30px;
  font-size: 16px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .frontpage-team .text {
    margin: 25px;
    max-width: 97%;
  }
}
.frontpage-team :lang(ja) .text {
  font-size: 14px;
}
.frontpage-team .image {
  display: block;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .frontpage-team .image {
    margin-left: -25px;
    margin-right: -25px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-team .image {
    margin-left: -50px;
    margin-right: -50px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-team .image img {
    margin-bottom: 40px;
  }
}
.frontpage-team .line {
  border-bottom: 2px solid #748087;
  width: 126px;
  display: inline-block;
  position: relative;
  top: -16px;
  margin-left: 30px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-team .line {
    margin-left: 30px;
    margin-top: 15px;
    border-bottom: none;
    height: 50px;
    width: 1px;
    border-left: 1px solid #748087;
    display: block;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-team .button-container {
    margin-bottom: 20px;
  }
}
.frontpage-events {
  color: #ffffff;
  width: 38%;
  position: relative;
  float: left;
  margin-top: 50px;
}
.frontpage-events .title {
  font-size: 28px;
  clear: both;
  float: left;
  margin-bottom: 20px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-events .title {
    font-size: 34px;
    display: block;
    float: none;
    margin: 0 25px;
  }
}
.frontpage-events .text {
  font-size: 18px;
  line-height: 32px;
  clear: both;
  float: left;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-events .text {
    margin: 0 25px 50px 25px;
    display: block;
    font-size: 18px;
    line-height: 32px;
    min-height: 130px;
    float: none;
  }
}
@media only screen and (max-width: 320px) {
  .frontpage-events .text {
    margin-bottom: 25px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-events {
    width: auto;
    position: relative;
    float: left;
    margin: 0;
  }
}
.frontpage-work {
  width: 30%;
  position: relative;
  float: right;
  margin-top: 100px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-work {
    margin-left: 0;
    width: 100%;
    float: none;
    right: 0;
  }
}
.frontpage-work .title {
  font-size: 34px;
  display: block;
  margin-bottom: 20px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-work .title {
    font-size: 30px;
    display: block;
    float: none;
    margin: 0 25px 10px 25px;
  }
}
.frontpage-work .text {
  font-size: 18px;
  display: block;
  line-height: 30px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .frontpage-work .text {
    margin: 0 25px 50px 25px;
    font-size: 18px;
    line-height: 24px;
    min-height: 60px;
    float: none;
  }
}
/* in */
@keyframes arrow-anim-in {
  from {
    height: 111px;
  }
  to {
    height: 70px;
  }
}
@keyframes arrow-anim-white-in {
  from {
    height: 70px;
  }
  to {
    height: 40px;
  }
}
@keyframes arrowhead-anim-in {
  from {
    bottom: -10px;
  }
  to {
    bottom: 27px;
  }
}
@keyframes arrowhead-anim-white-in {
  from {
    bottom: -10px;
  }
  to {
    bottom: 27px;
  }
}
/* out */@keyframes arrow-anim-out {
  from {
    height: 70px;
  }
  to {
    height: 111px;
  }
}
@keyframes arrow-anim-white-out {
  from {
    height: 40px;
  }
  to {
    height: 70px;
  }
}
@keyframes arrowhead-anim-out {
  from {
    bottom: 27px;
  }
  to {
    bottom: -10px;
  }
}
@keyframes arrowhead-anim-white-out {
  from {
    bottom: 27px;
  }
  to {
    bottom: -10px;
  }
}
.slidelink {
  z-index: 10;
  cursor: pointer;
  font-size: 18px;
  height: 101px;
  width: 50px;
  right: 130px;
  text-align: center;
  display: inline-block;
  position: absolute;
  bottom: -10px;
}
.slidelink.white {
  height: 70px;
  right: 99px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.white {
    right: 0;
    left: 90px;
    bottom: -58px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .slidelink.white {
    right: 100px;
  }
}
.slidelink.white a {
  color: #ffffff;
}
.slidelink.white .arrow {
  background: #ffffff;
}
.slidelink.white .arrowhead-left {
  background: #ffffff;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.white .arrowhead-left {
    display: none;
  }
}
.slidelink.white .arrowhead-right {
  background: #ffffff;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.white .arrowhead-right {
    display: none;
  }
}
.slidelink.white.over .arrow {
  animation-name: arrow-anim-white-in;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.white.over .arrowhead-left {
  animation-name: arrowhead-anim-white-in;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.white.over .arrowhead-right {
  animation-name: arrowhead-anim-white-in;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.white.over .arrow {
    animation: none;
  }
  .slidelink.white.over .arrowhead-left {
    animation: none;
  }
  .slidelink.white.over .arrowhead-right {
    animation: none;
  }
}
.slidelink.white.out .arrow {
  animation-name: arrow-anim-white-out;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.white.out .arrowhead-left {
  animation-name: arrowhead-anim-white-out;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.white.out .arrowhead-right {
  animation-name: arrowhead-anim-white-out;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.white.out .arrow {
    animation: none;
  }
  .slidelink.white.out .arrowhead-left {
    animation: none;
  }
  .slidelink.white.out .arrowhead-right {
    animation: none;
  }
}
.slidelink.white .text {
  top: -40px;
  left: -40px;
}
@media only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.white .text {
    left: -65px;
    top: -25px;
  }
}
@media only screen and (max-width: 320px) {
  .slidelink.white .text {
    left: -60px;
    top: -25px;
  }
}
.slidelink.light {
  color: #748087;
}
.slidelink.dark {
  color: #ffffff;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink {
    font-size: 15.6px;
    right: 30px;
    bottom: 15px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .slidelink {
    right: 50px;
  }
}
.slidelink .text {
  position: absolute;
  top: -50px;
  width: 130px;
  left: -50px;
  height: 50px;
  text-align: center;
  display: inline-block;
}
@media only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink .text {
    left: -90px;
    top: -25px;
  }
}
@media only screen and (max-width: 320px) {
  .slidelink .text {
    left: -60px;
    top: -25px;
  }
}
.slidelink.over .arrow {
  animation-name: arrow-anim-in;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.over .arrowhead-left {
  animation-name: arrowhead-anim-in;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.over .arrowhead-right {
  animation-name: arrowhead-anim-in;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.over .arrow {
    animation: none;
  }
  .slidelink.over .arrowhead-left {
    animation: none;
  }
  .slidelink.over .arrowhead-right {
    animation: none;
  }
}
.slidelink.out .arrow {
  animation-name: arrow-anim-out;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.out .arrowhead-left {
  animation-name: arrowhead-anim-out;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
.slidelink.out .arrowhead-right {
  animation-name: arrowhead-anim-out;
  animation-duration: 0.5s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink.out .arrow {
    animation: none;
  }
  .slidelink.out .arrowhead-left {
    animation: none;
  }
  .slidelink.out .arrowhead-right {
    animation: none;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink {
    right: 75px;
    height: 10px;
    width: 1px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .slidelink {
    right: 76px;
  }
}
.slidelink a {
  display: block;
  width: 100%;
  height: 100%;
}
.slidelink .arrow {
  background: #748087;
  display: inline-block;
  position: relative;
  width: 2px;
  height: 111px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink .arrow {
    height: 30px;
    width: 1px;
  }
}
.slidelink .arrowhead-left {
  height: 13px;
  display: inline-block;
  position: absolute;
  width: 2px;
  background-color: #748087;
  left: 20px;
  bottom: -12px;
  -ms-transform: rotate(-45deg);
  /* IE 9 */

  -webkit-transform: rotate(-45deg);
  /* Chrome, Safari, Opera */

  transform: rotate(-45deg);
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink .arrowhead-left {
    display: none;
  }
}
.slidelink .arrowhead-right {
  height: 13px;
  display: inline-block;
  position: absolute;
  width: 2px;
  left: 28px;
  background-color: #748087;
  bottom: -12px;
  -ms-transform: rotate(45deg);
  /* IE 9 */

  -webkit-transform: rotate(45deg);
  /* Chrome, Safari, Opera */

  transform: rotate(45deg);
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .slidelink .arrowhead-right {
    display: none;
  }
}
.work-line {
  width: 2px;
  background: #ffffff;
  height: 21%;
  position: absolute;
  right: 154px;
  top: 0;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .work-line {
    right: 75px;
    max-height: 65px;
    height: 15%;
    width: 1px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .work-line {
    height: 25%;
    right: 100px;
  }
}
.work-line a {
  display: block;
  width: 100%;
  height: 100%;
}
.tab-contact {
  font-size: 21px;
  color: #ffffff;
  position: absolute;
  width: 120px;
  bottom: 90px;
  right: 65px;
  letter-spacing: 2px;
  text-align: center;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .tab-contact {
    font-size: 15.6px;
    letter-spacing: 0px;
    right: 0;
    left: 30px;
    bottom: 45px;
  }
}
.carousel-container {
  overflow: hidden;
  position: relative;
  display: block;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .carousel-container {
    margin-bottom: 25px;
    margin-left: -25px;
    margin-right: -25px;
    margin-top: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .carousel-container {
    margin-bottom: 50px;
    margin-left: -50px;
    margin-right: -50px;
    margin-top: 0;
  }
}
.carousel-container.left {
  float: left;
  margin-left: 25px;
  width: 65%;
  margin-top: 50px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .carousel-container.left {
    max-width: auto;
    margin-left: -25px;
    margin-right: -25px;
    margin-top: 0;
    float: none;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .carousel-container.left {
    max-width: auto;
    margin-left: -50px;
    margin-right: -50px;
    margin-top: 0;
    float: none;
  }
}
.carousel-container.right {
  float: right;
  width: 65%;
  margin-top: 50px;
  margin-right: -75px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px) {
  .carousel-container.right {
    max-width: auto;
    margin-left: -25px;
    margin-right: -25px;
    margin-top: -25px;
    float: none;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .carousel-container.right {
    max-width: auto;
    margin-left: -50px;
    margin-right: -50px;
    margin-top: -50px;
    float: none;
  }
}
.image {
  overflow: hidden;
}
.image img {
  width: 100%;
  vertical-align: top;
}
.events-header-hottopics {
  display: none;
  color: #748087;
  font-size: 18px;
  margin-left: 50px;
  position: absolute;
  bottom: 20px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .events-header-hottopics {
    display: inline-block;
  }
}
.events-header {
  float: left;
  position: relative;
}
.events-header.subtext {
  color: #ffffff;
  font-size: 21px;
  margin-right: 33px;
  top: 120px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .events-header.subtext {
    display: none;
  }
}
.events-header.subtext.dark {
  color: #748087;
}
.events-header.line {
  border-bottom: 2px solid #ffffff;
  width: 140px;
  top: 130px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .events-header.line {
    display: none;
  }
}
.events-header.line.dark {
  border-bottom: 2px solid #748087;
}
.events-header.title {
  top: 108px;
  font-size: 60px;
  color: #ffffff;
  margin-left: 33px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .events-header.title {
    top: 50px;
    left: 25px;
    bottom: 40px;
    position: absolute;
    margin-left: 25px;
    margin-top: 10px;
    font-size: 54px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .events-header.title {
    bottom: 60px;
  }
}
.events-header.title.dark {
  color: #748087;
}
.center {
  text-align: center;
}
.button-container {
  font-size: 18px;
  display: inline-block;
  width: 184px;
  margin-top: 50px;
  background-repeat: no-repeat;
  line-height: 58px;
  height: 55px;
  overflow: hidden;
  clear: both;
  float: left;
  text-align: center;
}
.button-container.work,
.button-container.events,
.button-container.team {
  background-size: 184px 110px;
  background-repeat: no-repeat;
}
.button-container.work:hover,
.button-container.events:hover,
.button-container.team:hover {
  background-position-y: -55px;
}
.button-container.work:hover a,
.button-container.events:hover a,
.button-container.team:hover a {
  color: white;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .button-container.work,
  .button-container.events,
  .button-container.team {
    background-size: 180px auto;
  }
  .button-container.work:hover,
  .button-container.events:hover,
  .button-container.team:hover {
    background-position-y: -54px;
  }
}
.button-container.work a,
.button-container.events a,
.button-container.team a {
  width: 100%;
  height: 100%;
  display: block;
  color: #ffffff;
}
.button-container.events {
  background-image: url("/img/seeitall-events.svg");
}
.button-container.events a {
  color: #748087;
}
.button-container.work {
  background-image: url("/img/seeitall-work.svg");
}
.button-container.team {
  background-image: url("/img/seeitall-team.svg");
  float: none;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .button-container {
    height: 54.6px;
    width: 180px;
    margin: auto;
    display: block;
    text-align: center;
    background-position: center 0;
    background-size: 180px auto;
    font-size: 22px;
    line-height: 58px;
    float: none;
    margin-bottom: 100px;
  }
  .button-container a {
    float: none;
  }
}
.koichi {
  text-align: center;
  margin: 60px 0;
}
.koichi .pic {
  width: 78px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .koichi .pic {
    margin-top: 60px;
  }
}
.koichi .text {
  width: 113px;
  position: absolute;
  margin-top: 28px;
  margin-left: -4px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .koichi .text {
    margin-top: 88px;
  }
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .koichi {
    margin: 0;
    display: block;
  }
}
:lang(ja) .splash-image {
  width: 48%;
}
:lang(ja) .splash-image.splash-joinus {
  width: 43%;
}
:lang(ja) .button-container {
  font-size: 16px;
}
@media only screen and (max-width: 320px), only screen and (min-width: 320px) and (max-width: 768px), only screen and (min-width: 768px) and (max-width: 959px) {
  .hideonmobile {
    display: none !important;
  }
}
.clearfix:after {
  content: ".";
  visibility: hidden;
  display: block;
  height: 0;
  clear: both;
}
#mainpage-left-black {
  opacity: 0;
}
#mainpage-left-white {
  opacity: 1;
}
