@charset "UTF-8";
#aboutus {
  overflow: hidden;
  max-width: 1100px;
  margin: 0 auto;
  padding-top: 30px;
}
main h2,
main h3,
main h4 {
  text-align: left;
}
main h3:first-of-type,
main h4 { margin-bottom: 10px; }
main h2 {
  padding: 12px;
  color: #fff;
  background-color: #038de1;
}
main h3 {
  margin-bottom: 28px;
  padding: 12px;
  background-color: #f0f5f9;
}
main h3:nth-of-type(-n+2) { margin-top: 36px; }
main h3 { margin-top: 72px; }
main p {
  margin-bottom: 30px;
  text-align: left;
}
main h3:nth-of-type(1)+ div { text-align: left; }
main h3:nth-of-type(1)+ div p { display: none; }
main h3:nth-of-type(2)+ div {
  overflow: hidden;
  padding: 0 48px;
  font-size: 16px;
}
main h3:nth-of-type(2)+ div p:first-of-type {
  float: right;
  width: 200px;
  line-height: 1.4;
  text-align: center;
}
main h3:nth-of-type(2)+ div p:nth-of-type(2) {
  float: left;
  width: calc(100% - 8% - 200px);
  margin-right: 8%;
  margin-bottom: 0;
}
main h3:nth-of-type(2)+ div p:first-of-type img { margin-bottom: 10px; }
main h3:nth-of-type(3) { clear: both; }
main table,
main tr { width: 100%; }
main table { margin: 0 auto 20px; }
main table:first-of-type { margin-bottom: 6px; }
main tr:first-of-type th,
main tr:first-of-type td { border-top: 1px solid #dce5eb; }
main tr td:first-of-type { border-right: none; }
main th { width: 250px; }
main td {
  overflow: hidden;
  width: calc(100% - 250px);
}
main td p:last-of-type { margin-bottom: 0; }
main dt, main dd { float: left; }
main dt {
  clear: both;
  width: 130px;
  font-weight: bold;
}
main table span { font-weight: bold; }
main td img {
  float: right;
  margin-left: 50px;
}
main table div {
  float: left;
  width: calc(100% - 350px);
}
main table:first-of-type td { position: relative; }
main table:first-of-type tr:nth-of-type(11) img {
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
}
main h3:nth-of-type(5)+p img {
  display: block;
  width: 350px;
  margin-bottom: 24px;
}
main h3:nth-of-type(5)+p span { margin-bottom: 8px; }
main h3+p img+span {
  display: block;
  line-height: 1.4;
  font-weight: bold;
  font-size: 20px;
}
main h3:nth-of-type(6) { margin-bottom: 32px; }
main h4 {
  margin-bottom: 0;
  font-size: 18px;
}
main h4+ p {
  margin-top: -4px;
  margin-bottom: 4px;
  font-size: 18px;
}
main h4+ p+ table { margin-bottom: 30px; }

main ul#recruit{
  text-align: left;
  padding-bottom: 40px;
}
main ul#recruit li{
  max-width:400px;
  margin-right: 30px;
  vertical-align: top;
}

main ul#recruit img {
  margin-bottom: 12px;
}
main ul#recruit h4 {
  margin-bottom: 8px;
  color: #038de1;
  font-size: 18px;
}

main ul#recruit h4+ p {
  font-size: 14px;
  margin-bottom: 12px;
}


@media screen and (max-width: 767px) {
  #aboutus { padding: 30px 12px 0; }
  main #aboutus h3:nth-of-type(2)+ div p { width: 100%;}
  main h3:nth-of-type(2)+ div { padding: 0 20px; }
  main #aboutus h3:nth-of-type(2)+ div p:nth-of-type(2) {
    margin-right: 0;
    margin-bottom: 36px;
  }
  main h3:nth-of-type(2)+ div p:first-of-type { margin-bottom: 24px; }
  main h3:nth-of-type(2)+ div p:first-of-type img,
  main h3:nth-of-type(2)+ div p:first-of-type span {
    display: inline-block;
    vertical-align: middle;
  }
  main h3:nth-of-type(2)+ div p:first-of-type img {
    margin-bottom: 0;
    padding: 10px;
  }
  main h3:nth-of-type(3) { margin-top: 56px; }
  main h3:nth-of-type(n+4) { margin-top: 72px; }
  main h3:nth-of-type(6) { margin-top: 56px; }
  main h4,
  main h4+ p { font-size: 16px; }
  main th, main td { padding: 20px 16px 19px; }
  main th { width: 22%; }

  main ul#recruit{
    padding-bottom: 40px;
  }
  main ul#recruit li{
    max-width:46%;
    margin-right: 4%;
  }

}


@media screen and (max-width: 719px) {
  main h3:nth-of-type(2)+ div { padding: 0; }
  main table:first-of-type th,
  main table:first-of-type td {
    display: block;
    width: 100%;
  }
  main table:first-of-type tr:nth-of-type(n+6) th { display: none; }
  main table:first-of-type th {
    text-align: left;
    background: transparent;
  }
  main table:first-of-type th { padding: 12px 12px 0px }
  main table:first-of-type td { padding: 12px; }
  main table:first-of-type th { border-top: 1px solid #dce5eb; }
  main table:first-of-type td { border-top: none; }
  main table:first-of-type tr:nth-of-type(n+6) td { border-top: 1px solid #dce5eb; }
  main td img,
  main td div { float: none; }
  main td img {
    display: block;
    width: 100%;
    margin: 0 auto 12px;
  }
  main table:first-of-type tr:nth-of-type(n+12) td { text-align: left; }
  main table:first-of-type tr:nth-of-type(n+12) td img {
    float: right;
    width: auto;
  }
  main table:first-of-type tr:nth-of-type(n+12) td div { width: calc(100% - 160px); }
  main table div {
    display: inline-block;
    width: auto;
    text-align: left;
  }
  main table:first-of-type tr:nth-of-type(11) img {
    position: static;
    top: auto;
    right: auto;
    transform: translateY(0);
  }
}


@media screen and (max-width: 583px) {
  main h3:first-of-type { margin-bottom: 20px; }
  main h4+ p { margin-bottom: 6px; }
  main h4+ p+ table:not(:last-of-type) { margin-bottom: 68px; }
  main h4:nth-of-type(3) + p+ table tr:first-of-type th { display: none; }
  main h4:nth-of-type(3) + p+ table tr:first-of-type td { border-top: 1px solid #dce5eb; }
  main table th {
    text-align: left;
    background: transparent;
  }
  main table th { padding: 12px 12px 0px }
  main table td { padding: 12px; }
  main table th { border-top: 1px solid #dce5eb; }
  main table td,
  main tr:first-of-type td { border-top: none; }
  main tr:hover td { background: transparent; }
  main th,
  main td,
  main table:first-of-type tr:nth-of-type(n+12) td img,
  main table:first-of-type tr:nth-of-type(n+12) td div {
    display: block;
    width: 100%;
  }
  main th { text-align: left; }
  main table:first-of-type tr:nth-of-type(n+12) td img { float: none; }

  main ul#recruit{
    padding-bottom: 0;
  }
  main ul#recruit li{
    max-width:100%;
    margin-right: 0;
    padding-bottom: 30px;
  }
  main ul#recruit h4+ p {
    margin-bottom: 0;
  }
  main ul#recruit h4+ p br {
    display: none;
  }

}


@media screen and (max-width: 479px) {
  main h3+ div img { display: none; }
  main h3:nth-of-type(1) { margin-bottom: 28px; }
  main h3:nth-of-type(1)+ div p {
    display: block;
    line-height: 1.4;
    font-weight: bold;
    font-size: 16px;
  }
  main h3:nth-of-type(3) { margin-top: 50px; }
}