body {
  color: #CCCCCC;
  font-size: 14px;
  background-color: #333;
  overflow: hidden
}
a {
  color: #15e879;
  transition: 0.2s
}
a:hover {
  opacity: 0.7
}
::selection {
  background-color: #15e879;
  color: #222222
}
li {
  list-style: none
}
img {
  width: 100%;
  height: auto
}
#wrapper {
  position: relative
}
.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #333333;
  z-index: 1000;
  background-image: url(/common/images/loading.gif);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 33px 33px
}
.header {
  position: relative;
  padding: 28px 40px 0;
  height: calc( 100px + 28px);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #555
}
@media screen and (max-width: 900px) {
  .header {
    padding: 0 0 0 10px;
    height: 40px
  }
}
.header__logo {
  width: 200px;
  height: auto
}
@media screen and (max-width: 900px) {
  .header__logo {
    width: 100px
  }
}
.header__spBtn {
  display: none
}
@media screen and (max-width: 900px) {
  .header__spBtn {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px
  }
  .header__spBtn img {
    width: 20px;
    height: auto
  }
}
.header__navAreaInner {
  display: flex;
  flex-wrap: wrap
}
@media screen and (max-width: 900px) {
  .header__navAreaInner {
    width: 100%;
    height: 100%;
    flex-direction: column;
    justify-content: center
  }
}
.header__navAreaClose {
  display: none
}
@media screen and (max-width: 900px) {
  .header__navArea {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(34, 34, 34, 0.95);
    z-index: 5;
    padding: 20px
  }
  .header__navAreaClose {
    display: block;
    position: absolute;
    top: 10px;
    right: 10px;
    transform: rotate(45deg)
  }
  .header__navAreaCloseLink {
    display: block;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    position: relative
  }
  .header__navAreaCloseLink::before {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: #555555;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%)
  }
  .header__navAreaCloseLink::after {
    content: "";
    display: block;
    width: 1px;
    height: 100%;
    background-color: #555555;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%)
  }
}
.header__nav {
  display: flex;
  align-items: center;
  font-size: 16px;
  padding: 0 2em 0 0
}
@media screen and (max-width: 1200px) {
  .header__nav {
    font-size: 13px
  }
}
@media screen and (max-width: 900px) {
  .header__nav {
    padding: 0
  }
}
.header__navLists {
  display: flex;
  flex-wrap: wrap
}
@media screen and (max-width: 900px) {
  .header__navLists {
    width: 100%
  }
}
@media screen and (max-width: 900px) {
  .header__navList {
    width: 100%
  }
}
.header__navListLink {
  padding: 1em;
  position: relative;
  color: #CCCCCC
}
.header__navListLink::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0px;
  height: 3px;
  background-color: #15e879;
  transition: 0.2s
}
.header__navListLink:hover {
  opacity: 1
}
.header__navListLink:hover::after {
  width: calc( 100% - 2em)
}
@media screen and (max-width: 900px) {
  .header__navListLink {
    display: block;
    padding: 0.5em;
    text-align: center
  }
}
.header__btn {
  display: flex;
  width: 200px
}
@media screen and (max-width: 1200px) {
  .header__btn {
    width: 150px
  }
}
@media screen and (max-width: 900px) {
  .header__btn {
    width: 100%;
    margin: 1.5em 0 2em
  }
}
.header__btnLink {
  margin: 0 auto;
  border-radius: 3em;
  padding: 0.5em;
  font-size: 16px;
  font-weight: bold;
  color: #222222;
  background-color: #15e879;
  text-align: center;
  width: 100%;
  height: 40px
}
.header__lang {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #111111;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  height: 28px;
  font-size: 10px;
  padding: 0 2em 0 0
}
@media screen and (max-width: 900px) {
  .header__lang {
    position: static;
    height: auto;
    padding: 0 0 0.5em;
    background: none;
    border-bottom: 1px solid #555
  }
}
.header__langHead {
  display: flex;
  align-items: center;
  padding: 0 2em;
  font-weight: bold
}
@media screen and (max-width: 900px) {
  .header__langHead {
    justify-content: center;
    width: 100%;
    position: relative
  }
  .header__langHead::before {
    content: "";
    display: block;
    width: calc( 50% - 5em);
    height: 1px;
    background-color: #555555;
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 0
  }
  .header__langHead::after {
    content: "";
    display: block;
    width: calc( 50% - 5em);
    height: 1px;
    background-color: #555555;
    position: absolute;
    top: 50%;
    right: 0;
    z-index: 0
  }
}
.header__langList {
  border-left: 1px solid #555555
}
@media screen and (max-width: 900px) {
  .header__langList {
    width: 50%;
    border: none
  }
}
.header__langListLink {
  padding: 0 2em;
  border-right: 1px solid #555555;
  opacity: 0.5;
  color: #CCCCCC
}
@media screen and (max-width: 900px) {
  .header__langListLink {
    display: block;
    width: 100%;
    text-align: center;
    padding: 0.5em 0;
    border: none
  }
}
.header__langListLink--current {
  color: #15e879;
  opacity: 1
}
.mv {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 300px;
  width: 100%;
  text-align: center;
  background-image: url(/common/images/mv_bg.jpg);
  background-size: cover
}
@media screen and (max-width: 900px) {
  .mv {
    height: 300px;
    padding: 0 20px
  }
}
.mv__read {
  font-size: 40px;
  margin: 1em 0 1em
}
@media screen and (max-width: 900px) {
  .mv__read {
    font-size: 30px
  }
}
.mv__btnLink {
  margin: 0 auto;
  border-radius: 3em;
  padding: 0.5em;
  font-size: 16px;
  font-weight: bold;
  color: #222222;
  background-color: #15e879;
  text-align: center;
  display: flex;
  justify-content: center;
  max-width: 300px;
}
.project {
  padding: 5% 0;
  border-bottom: 1px solid #555
}
@media screen and (max-width: 900px) {
  .project {
    padding: 10% 0
  }
}
.project__head {
  text-align: center;
  font-size: 36px;
  position: relative;
  margin: 0 0 calc( 5% + 1em)
}
@media screen and (max-width: 900px) {
  .project__head {
    margin: 0 0 calc( 10% + 1em)
  }
}
.project__head::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1em;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 5px;
  background-color: #15e879
}
.project__section {
  display: flex;
  flex-wrap: wrap;
  padding: 50px 0
}
@media screen and (max-width: 900px) {
  .project__section {
    padding: 0
  }
}
.project__section:nth-child(odd) {
  flex-direction: row-reverse
}
.project__pic {
  width: 50%
}
@media screen and (max-width: 900px) {
  .project__pic {
    width: 100%
  }
}
.project__txtArea {
  width: 50%;
  padding: 0 10%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 900px) {
  .project__txtArea {
    width: 100%;
    padding: 10% 0%
  }
}
.project__txtAreaHead {
  font-size: 22px;
  margin: 0 0 1em
}
.features {
  padding: 5% 0;
  border-bottom: 1px solid #555;
  background-color: #dddddd;
  color: #515151
}
@media screen and (max-width: 900px) {
  .features {
    padding: 10% 0
  }
}
.features__head {
  text-align: center;
  font-size: 36px;
  position: relative;
  margin: 0 0 calc( 5% + 1em)
}
@media screen and (max-width: 900px) {
  .features__head {
    margin: 0 0 calc( 10% + 1em)
  }
}
.features__head::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1em;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 5px;
  background-color: #15e879
}
.features__head::after {
  background-color: #11b25d
}
.features__lists {
  display: flex;
  flex-wrap: wrap;
  padding: 0 4%
}
.features__list {
  width: 33.33%;
  padding: 0 4% 8%;
  font-size: 13px;
}
@media screen and (max-width: 1200px) {
  .features__list {
    width: 50%
  }
}
@media screen and (max-width: 900px) {
  .features__list {
    width: 100%;
    padding: 0 6% 12%
  }
}
.features__listHead {
  font-size: 22px
}
.features__listPic {
  margin: 1.5em 0
}
.demo {
  padding: 5% 0;
  border-bottom: 1px solid #555
}
@media screen and (max-width: 900px) {
  .demo {
    padding: 10% 0
  }
}
.demo__head {
  text-align: center;
  font-size: 36px;
  position: relative;
  margin: 0 0 calc( 5% + 1em)
}
@media screen and (max-width: 900px) {
  .demo__head {
    margin: 0 0 calc( 10% + 1em)
  }
}
.demo__head::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1em;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 5px;
  background-color: #15e879
}
.demo__lists {
  display: flex;
  flex-wrap: wrap;
  padding: 0 8%
}
@media screen and (max-width: 1200px) {
  .demo__lists {
    padding: 0 4%
  }
}
.demo__list {
  width: 50%;
  padding: 0 4% 8%
}
@media screen and (max-width: 1200px) {
  .demo__list {
    padding: 0 8% 8%
  }
}
@media screen and (max-width: 900px) {
  .demo__list {
    width: 100%;
    padding: 0 6% 12%
  }
}
.demo__listThumb {
  position: relative;
  background-size: cover
}
.demo__listThumb01 {
  background-image: url(/common/images/demo_thumb01.gif)
}
.demo__listThumb02 {
  background-image: url(/common/images/demo_thumb02.gif)
}
.demo__listThumb03 {
  background-image: url(/common/images/demo_thumb03.gif)
}
.demo__listThumb04 {
  background-image: url(/common/images/demo_thumb04.gif)
}
.demo__listThumb05 {
  background-image: url(/common/images/demo_thumb05.gif)
}
.demo__listThumb06 {
  background-image: url(/common/images/demo_thumb06.gif)
}
.demo__listThumb a {
  position: relative;
  display: block;
  opacity: 1;
  transition: 0.2s;
  z-index: 2
}
.demo__listThumb a:hover {
  opacity: 0
}
.demo__listThumb a::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  background-image: url(/common/images/demo_icon_play.svg);
  background-size: 80px 80px;
  opacity: 0.5;
  z-index: 2
}
.demo__listThumb::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  background-image: url(/common/images/demo_icon_play.svg);
  background-size: 80px 80px;
  opacity: 0.5;
  z-index: 1
}
.demo__listTxtArea {
  position: relative;
  margin: 1.5em 0 0;
  padding: 0 calc( 100px + 1em) 0 0
}
@media screen and (max-width: 1200px) {
  .demo__listTxtArea {
    padding: 0
  }
}
.demo__listHead {
  font-size: 16px
}
.demo__listTxt {
  margin: 1em 0 0;
  font-size: 10px
}
.demo__listBtn {
  position: absolute;
  top: 0;
  right: 0;
  width: 100px
}
@media screen and (max-width: 1200px) {
  .demo__listBtn {
    position: static;
    margin: 1em 0 0
  }
}
.demo__listBtnLink {
  margin: 0 auto;
  border-radius: 3em;
  padding: 0.5em;
  font-size: 16px;
  font-weight: bold;
  color: #222222;
  background-color: #15e879;
  text-align: center;
  display: block;
  font-size: 12px
}
.contact {
  padding: 5% 0;
  border-bottom: 1px solid #555
}
@media screen and (max-width: 900px) {
  .contact {
    padding: 10% 0
  }
}
.contact__head {
  text-align: center;
  font-size: 36px;
  position: relative;
  margin: 0 0 calc( 5% + 1em);
  margin: 0 0 calc( 3% + 1em)
}
@media screen and (max-width: 900px) {
  .contact__head {
    margin: 0 0 calc( 10% + 1em)
  }
}
.contact__head::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1em;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 5px;
  background-color: #15e879
}
.contact__txt {
  max-width: 700px;
  margin: 0 auto;
  padding: 0 20px
}
.contact__btn {
  margin: 50px auto 0;
  padding: 0 20px
}
.contact__btnLink {
  margin: 0 auto;
  border-radius: 3em;
  padding: 0.5em;
  font-size: 16px;
  font-weight: bold;
  color: #222222;
  background-color: #15e879;
  text-align: center;
  display: block;
  max-width: 300px
}
.dlArea {
  text-align: center;
  padding: 50px 20px;
  background-color: #393939
}
.dlArea__read {
  font-size: 24px;
  margin: 0 0 1em
}
.dlArea__btnLink {
  margin: 0 auto;
  border-radius: 3em;
  padding: 0.5em;
  font-size: 16px;
  font-weight: bold;
  color: #222222;
  background-color: #15e879;
  text-align: center;
  display: block;
  max-width: 300px
}
.pagetop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 3
}
.pagetop__link {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 80px;
  height: 80px;
  background-color: #15e879;
  border-radius: 50%;
  color: #222222;
  font-weight: bold;
  box-shadow: 0 0 5px 0 #222222
}
@media screen and (max-width: 900px) {
  .pagetop__link {
    width: 40px;
    height: 40px;
    font-size: 10px
  }
}
address {
  font-style: normal;
  font-size: 10px;
  text-align: center;
  padding: 50px 0
}
.download {
  padding: 5% 0;
  border-bottom: 1px solid #555
}
@media screen and (max-width: 900px) {
  .download {
    padding: 10% 0
  }
}
.download__head {
  text-align: center;
  font-size: 36px;
  position: relative;
  margin: 0 0 calc( 5% + 1em)
}
@media screen and (max-width: 900px) {
  .download__head {
    margin: 0 0 calc( 10% + 1em)
  }
}
.download__head::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1em;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 5px;
  background-color: #15e879
}
.download__contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0 10%
}
.download__picArea {
  width: 45%
}
@media screen and (max-width: 900px) {
  .download__picArea {
    width: 100%;
    padding: 0 0 10%
  }
}
.download__thumb {
  margin: 0 0 2em
}
.download__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 1.5em 0;
  border-bottom: 1px solid #515151
}
@media screen and (max-width: 900px) {
  .download__list {
    font-size: 10px
  }
}
.download__listTxt {
  width: 50%;
  display: flex;
  align-items: center
}
.download__listBtn {
  width: 40%
}
.download__listBtnLink {
  margin: 0 auto;
  border-radius: 3em;
  padding: 0.5em;
  font-size: 16px;
  font-weight: bold;
  color: #222222;
  background-color: #15e879;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px
}
@media screen and (max-width: 900px) {
  .download__listBtnLink {
    font-size: 10px
  }
}
.download__listBtnIcon {
  width: 1em;
  height: auto;
  margin: 0 0.5em 0 0
}
.download__txtArea {
  width: 45%
}
@media screen and (max-width: 900px) {
  .download__txtArea {
    width: 100%
  }
}
.download__txtArea h4 {
  font-size: 22px;
  margin: 1em 0
}
.download__txtArea h4:first-child {
  margin: 0 0 1em
}
.download__txtArea p {
  margin: 1em 0
}
.download__txtArea p:first-child {
  margin: 0 0 1em
}
.download__txtArea a {
  text-decoration: none
}
.download__txtArea table {
  margin: 2em 0;
  font-size: 10px;
  border-top: 1px solid #515151;
  table-layout: fixed;
  width: 100%
}
.download__txtArea table tr {
  border-bottom: 1px solid #515151
}
.download__txtArea table tr th {
  font-weight: bold;
  width: 30%;
  text-align: left;
  padding: 1em
}
.download__txtArea table tr td {
  padding: 1em
}
.download__linebreak {
  display: none
}
@media screen and (max-width: 1300px) {
  .download__linebreak {
    display: inherit
  }
}
@media screen and (max-width: 900px) {
  .download__linebreak {
    display: none
  }
}
.character {
  padding: 5% 0;
  border-bottom: 1px solid #555;
  background-color: #dddddd;
  color: #515151
}
@media screen and (max-width: 900px) {
  .character {
    padding: 10% 0
  }
}
.character a {
  color: #11b25d
}
.character__head {
  text-align: center;
  font-size: 36px;
  position: relative;
  margin: 0 0 calc( 5% + 1em)
}
@media screen and (max-width: 900px) {
  .character__head {
    margin: 0 0 calc( 10% + 1em)
  }
}
.character__head::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1em;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 5px;
  background-color: #15e879
}
.character__head::after {
  background-color: #11b25d
}
.character__contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px
}
@media screen and (max-width: 900px) {
  .character__contents {
    padding: 0 10%
  }
}
.character__picArea {
  width: 50%
}
@media screen and (max-width: 900px) {
  .character__picArea {
    width: 100%;
    padding: 0 0 10%
  }
}
.character__txtArea {
  width: 45%
}
@media screen and (max-width: 900px) {
  .character__txtArea {
    width: 100%
  }
}
.character__txtArea h4 {
  font-size: 22px;
  margin: 1em 0
}
.character__txtArea h4:first-child {
  margin: 0 0 1em
}
.character__txtArea p {
  margin: 1em 0
}
.character__txtArea p:first-child {
  margin: 0 0 1em
}
.character__txtArea li {
  list-style: disc;
  margin: 0.5em 0 0.5em 1.5em
}
.character__picDetail {
  margin: 2em 0 0 !important;
  width: 180px;
  position: relative
}
.character__picDetailIcon {
  display: block;
  position: absolute;
  bottom: 5px;
  right: 5px;
  width: 20px;
  height: 20px;
  background-color: #15e879;
  border-radius: 50%
}
.character__picDetailIcon::before {
  content: "";
  display: block;
  width: 50%;
  height: 2px;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}
.character__picDetailIcon::after {
  content: "";
  display: block;
  width: 2px;
  height: 50%;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}
.character_download__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.character_download__listBtn {
  width: 32%
}
.character_download__listBtnLink {
  margin: 0 auto;
  border-radius: 3em;
  padding: 0.5em;
  font-size: 16px;
  font-weight: bold;
  color: #333333 !important;
  background-color: #15e879;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px
}
.overlay1 {
  display: none;
  background-color: rgba(34, 34, 34, 0.5);
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  padding: 50px 20px;
  z-index: 100
}
.overlay2 {
  display: none;
  background-color: rgba(34, 34, 34, 0.5);
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  padding: 50px 20px;
  z-index: 100
}
.overlay3 {
  display: none;
  background-color: rgba(34, 34, 34, 0.5);
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  padding: 50px 20px;
  z-index: 100
}
.overlay__pic1 {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  background-image: url(/common/images/character_aiko_pic_detail.png);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain
}
.overlay__pic2 {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  background-image: url(/common/images/character_eleanor_pic_detail.png);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain
}
.overlay__pic3 {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  background-image: url(/common/images/character_genbu_pic_detail.png);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain
}
.overlay__close {
  position: absolute;
  top: 10px;
  right: 10px;
  display: block;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  transform: rotate(45deg)
}
.overlay__close::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #555555;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%)
}
.overlay__close::after {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: #555555;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%)
}
.register__download__listBtn {
  width: 75%;
}
.register__formLabel {
  width: 25%;
  font-size: 13px;
}
.register__formText {
  width: 75%;
}
.register__formTextBox {
  width: 75%;
  outline: none;
  border: none;
  border-bottom: 2px solid gray;
  font-size: 13px;
  padding: 4px 8px;
}
.register__formSelector {
  width: 75%;
  outline: none;
  border: none;
  border-bottom: 2px solid gray;
  background-color: #444444;
  font-size: 13px;
  padding: 4px 8px;
}
.register__form {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 600px;
  margin: 0 auto;
}
@media screen and (max-width: 900px) {
  .register__form {
    max-width: 80%;
  }
}
.register__formList {
  width: 100%;
}
.register__formRow {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 2em 0;
}
.joinus__frame {
  display: flex;
  flex-wrap: wrap;
  flex-flow: row wrap-reverse;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0 10%;
  max-width: 1600px
}
.joinus__ull {
  width: 40%;
  margin: 1em auto
}
.joinus__ulr {
  width: 55%;
}
@media screen and (max-width: 900px) {
  .joinus__ull {
    width: 100%;
    margin: 1em auto;
    display: flex;
    flex-direction: column-reverse
  }
  .joinus__ulr {
    width: 100%
  }
  .joinus__ull ul {
    flex: 0 0 auto
  }
}
.joinus__frame p {
  margin: 0.7em 0 0.7em 0
}
.joinus__frame h3 {
  margin: 0.5em 0 0.5em 0
}
.joinus__bulletlist li {
  list-style: disc;
  margin: 0.2em 0 0.2em 2.5em
}

.section {
  padding: 5% 0;
}
@media screen and (max-width: 900px) {
  .section {
    padding: 10% 0
  }
}

.section.bright {
  background-color: #dddddd;
  color: #515151
}

.section.border {
  border-bottom: 1px solid gray
}

.section.bright a {
  color: #11b25d
}

.section__head {
  text-align: center;
  font-size: 36px;
  position: relative;
  margin: 0 0 calc( 5% + 1em);
  margin: 0 0 calc( 3% + 1em)
}
@media screen and (max-width: 900px) {
  .section__head {
    margin: 0 0 calc( 10% + 1em)
  }
}
@media screen and (max-width: 600px) {
  .section__head {
    font-size: 28px;
  }
}

.section__head::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1em;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 5px;
  background-color: #11b25d
}

.section__contents {
  max-width: 80%;
  margin: 0 auto;
  padding: 0 20px
}
@media screen and (max-width: 900px) {
  .section__contents {
    max-width: 95%;
  }
}

.websynthv__subheading {
  text-align: center;
  font-size: 24px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 600px) {
  .websynthv__subheading {
    font-size: 20px;
  }
}

.websynthv__subheading.qa {
  margin-top: 2em;
  margin-bottom: 0.5em;
}

.websynthv__subheading.credits {
  display: flex;
  align-items: center;
  justify-content: center;
}

.websynthv__subheading.credits div {
  width: 300px;
  max-width: 50%;
  padding: 0 20px;
  margin-top: 20px;
  margin-bottom: 20px;
}

.websynthv__subheading.credits p {
  /* width: 150px; */
  max-width: 100%;
}

.websynthv__tips {
  text-align: center;
  font-size: 13px
}

.section__contents.websynthvdemo {
  height: 600px;
  width: 80%;
  max-width: 1024px;
  margin: 0 auto;
  margin-bottom: 1em;
  display: flex;
  align-items: center;
  justify-content: center;
}

.section__contents.websynthvdemo #websynthv-status {
  line-height: 50px;
  min-width: 200px;
  text-align: center;
}

.section__contents.websynthvdemo #websynthv-notice {
  line-height: 50px;
  text-align: center;
  font-size: 13px;
}

.section__contents.websynthvdemo #websynthv-progress {
  min-width: 200px;
  width: 100%;
}

.section__contents.websynthv p {
  text-align: center;
  line-height: 35px;
  font-size: 14px;
  margin: 0 auto;
}
@media screen and (max-width: 800px) {
  .section__contents.websynthv p {
    text-align: left;
    font-size: 13px;
  }
}

.section__contents.text {
  font-size: 16px;
  line-height: 2em;
}
@media screen and (max-width: 600px) {
  .section__contents.text {
    font-size: 13px;
  }
}

.section__contents.text p {
  width: 800px;
  max-width: 90%;
  margin: 0 auto;
}

.section__contents.joblisting p {
  font-size: 18px;
  padding-top: 20px;
  text-align: center;
}

.section__contents.joblisting table {
  margin-top: 50px;
  margin-left: auto;
  margin-right: auto;
}

.section__contents.joblisting tr {
  width: 200px;
  height: 50px;
}

.section__contents.joblisting tr:first-child {
  border-bottom: 1px solid gray;
}

.section__contents.joblisting th {
  text-align: left;
  min-width: 100px;
  padding-left: 20px;
}

.section__contents.joblisting td {
  text-align: left;
  padding-left: 20px;
  padding-right: 20px;
}
