@charset "UTF-8";
body {
  font-family: "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", sans-serif;
  color: #333;
  font-weight: 500;
  font-feature-settings: "palt";
  margin: 0;
  font-size: 18px;
  line-height: 1.8em;
  overflow-x: hidden;
  padding-top: 140px;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 16px;
    line-height: 1.8em;
    padding-top: 70px;
  }
}

img, object, video {
  max-width: 100%;
  height: auto;
}

p {
  margin: 0;
}
p:not(:last-child) {
  margin-bottom: 1em;
}

@media screen and (max-width: 768px) {
  .sp-hide {
    display: none;
  }
}

@media screen and (min-width: 769px) {
  .pc-hide {
    display: none;
  }
}

.header {
  padding: 25px 30px 20px;
  width: 100%;
  box-sizing: border-box;
  left: 0;
  top: 0;
  position: fixed;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  z-index: 9999;
  background: #fff;
  height: 140px;
}
@media screen and (max-width: 768px) {
  .header {
    padding: 15px 15px 9px;
    height: 70px;
  }
}
.header__logo-main {
  font-size: 12px;
  line-height: 1.5em;
  font-weight: normal;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .header__logo-main {
    font-size: 11px;
    line-height: 1.5em;
  }
}
.header__logo-name {
  font-size: 34px;
  line-height: 1.5em;
  font-weight: bold;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .header__logo-name {
    font-size: 20px;
    line-height: 1.5em;
  }
}
.header__logo a:link, .header__logo a:visited {
  text-decoration: none;
  color: #333;
}
.header__logo a:hover, .header__logo a:active {
  text-decoration: none;
  color: #333;
}
.header__contact {
  margin-left: auto;
  margin-right: 25px;
}
@media screen and (max-width: 768px) {
  .header__contact {
    display: none;
  }
}
.header__scsk {
  font-size: 0;
  line-height: 0;
  margin: 6px 0 0;
}
@media screen and (max-width: 768px) {
  .header__scsk {
    width: 53px;
    margin: auto 32px 6px auto;
  }
}
.header__menu {
  width: 30px;
  height: 23px;
  position: relative;
  margin: auto 0 6px;
  cursor: pointer;
  display: none;
}
@media screen and (max-width: 768px) {
  .header__menu {
    display: block;
  }
}
.header__menu.active:after {
  display: none;
}
.header__menu.active span:before {
  top: calc(50% - 2px);
  transform: rotate(45deg);
}
.header__menu.active span:after {
  top: calc(50% - 2px);
  transform: rotate(-45deg);
}
.header__menu:after {
  content: "";
  width: 30px;
  height: 3px;
  background: #0C61B9;
  font-size: 0;
  line-height: 0;
  display: block;
  position: absolute;
  top: calc(50% - 1px);
}
.header__menu span {
  width: 100%;
  height: 100%;
  display: block;
  font-size: 0;
  line-height: 0;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
.header__menu span:before {
  content: "";
  width: 30px;
  height: 3px;
  background: #0C61B9;
  font-size: 0;
  line-height: 0;
  display: block;
  position: absolute;
  top: 1px;
}
.header__menu span:after {
  content: "";
  width: 30px;
  height: 3px;
  background: #0C61B9;
  font-size: 0;
  line-height: 0;
  display: block;
  position: absolute;
  bottom: 0;
}
.header__nav {
  width: 100%;
  display: flex;
  justify-content: flex-end;
}
@media screen and (max-width: 1120px) {
  .header__nav {
    margin-top: 10px;
  }
}
@media screen and (max-width: 768px) {
  .header__nav {
    display: none;
  }
}
.header__nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: flex-start;
}
@media screen and (max-width: 980px) {
  .header__nav ul {
    width: 100%;
    justify-content: space-between;
  }
}
.header__nav ul li {
  font-size: 18px;
  line-height: 1.5em;
  font-weight: 600;
}
@media screen and (max-width: 980px) {
  .header__nav ul li {
    font-size: 16px;
    line-height: 1.5em;
  }
}
.header__nav ul li:not(:last-child) {
  margin-right: 40px;
}
@media screen and (max-width: 980px) {
  .header__nav ul li:not(:last-child) {
    margin-right: 0;
  }
}
.header__nav ul li a:link, .header__nav ul li a:visited {
  text-decoration: none;
  color: #333;
}
.header__nav ul li a:hover, .header__nav ul li a:active {
  text-decoration: none;
  color: #15a38c;
}
.header__nav ul li a.active {
  color: #0c61b9;
}

.drawer {
  background: #0c61b9;
  width: 100%;
  position: absolute;
  top: 100%;
  left: 0;
  box-sizing: border-box;
  padding: 25px 25px 5px;
  display: none;
}
@media screen and (min-width: 769px) {
  .drawer {
    display: none !important;
  }
}
.drawer__nav {
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: center;
}
.drawer__nav li {
  font-size: 16px;
  line-height: 1.5em;
  font-weight: bold;
  margin-bottom: 20px;
}
.drawer__nav li a:link, .drawer__nav li a:visited {
  text-decoration: none;
  color: #fff;
}
.drawer__nav li a:hover, .drawer__nav li a:active {
  text-decoration: none;
  color: #fff;
}
.drawer__nav li a.active {
  text-decoration: underline;
}
.drawer__contact {
  margin: 0 0 20px;
  text-align: center;
}
.drawer__subnav {
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.drawer__subnav li {
  font-size: 13px;
  line-height: 1.2em;
  border-right: 1px solid #fff;
  margin: 0 0 20px;
}
.drawer__subnav li:first-child {
  border-left: 1px solid #fff;
}
.drawer__subnav li a {
  display: block;
  padding: 0 20px;
}
.drawer__subnav li a:link, .drawer__subnav li a:visited {
  text-decoration: none;
  color: #fff;
}
.drawer__subnav li a:hover, .drawer__subnav li a:active {
  text-decoration: none;
  color: #fff;
}

.btn {
  transition: background 0.3s;
}
.btn:after {
  transition: border-color 0.3s;
}
.btn--header {
  background: #E79248;
  display: inline-block;
  font-size: 16px;
  line-height: 1.5em;
  font-weight: bold;
  text-align: center;
  box-sizing: border-box;
  padding: 10px 45px 10px 20px;
  border-radius: 50px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .btn--header {
    min-width: 275px;
    padding: 10px 20px;
  }
}
.btn--header:link, .btn--header:visited {
  text-decoration: none;
  color: #fff;
}
.btn--header:hover, .btn--header:active {
  text-decoration: none;
  color: #fff;
  background: #E8C3A2;
}
.btn--header:hover:after, .btn--header:active:after {
  border-color: #E8C3A2;
}
.btn--header:before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: block;
  background: #fff;
  position: absolute;
  right: 15px;
  top: calc(50% - 11px);
}
@media screen and (max-width: 768px) {
  .btn--header:before {
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
  }
}
.btn--header:after {
  content: "";
  width: 5px;
  height: 5px;
  display: block;
  position: absolute;
  border-right: 2px solid #E79248;
  border-top: 2px solid #E79248;
  right: 23px;
  top: calc(50% - 3px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .btn--header:after {
    width: 4px;
    height: 4px;
    top: calc(50% - 2px);
    right: 23px;
  }
}
.btn--standard {
  background: #15A38C;
  display: inline-block;
  font-size: 18px;
  line-height: 1.5em;
  font-weight: bold;
  width: 100%;
  max-width: 400px;
  text-align: center;
  box-sizing: border-box;
  padding: 15px;
  border-radius: 50px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .btn--standard {
    font-size: 15px;
    line-height: 1.5em;
  }
}
.btn--standard:link, .btn--standard:visited {
  text-decoration: none;
  color: #fff;
}
.btn--standard:hover, .btn--standard:active {
  text-decoration: none;
  color: #fff;
  background: #a1dad1;
}
.btn--standard:hover:after, .btn--standard:active:after {
  border-color: #a1dad1;
}
.btn--standard:before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: block;
  background: #fff;
  position: absolute;
  right: 20px;
  top: calc(50% - 11px);
}
@media screen and (max-width: 768px) {
  .btn--standard:before {
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
    right: 15px;
  }
}
.btn--standard:after {
  content: "";
  width: 5px;
  height: 5px;
  display: block;
  position: absolute;
  border-right: 2px solid #15A38C;
  border-top: 2px solid #15A38C;
  right: 28px;
  top: calc(50% - 3px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .btn--standard:after {
    width: 4px;
    height: 4px;
    top: calc(50% - 2px);
    right: 23px;
  }
}
.btn--standard-orange {
  background: #e79248;
  display: inline-block;
  font-size: 18px;
  line-height: 1.5em;
  font-weight: bold;
  width: 100%;
  max-width: 400px;
  text-align: center;
  box-sizing: border-box;
  padding: 15px;
  border-radius: 50px;
  position: relative;
}
.btn--standard-orange:link, .btn--standard-orange:visited {
  text-decoration: none;
  color: #fff;
}
.btn--standard-orange:hover, .btn--standard-orange:active {
  text-decoration: none;
  color: #fff;
  background: #E8C3A2;
}
.btn--standard-orange:hover:after, .btn--standard-orange:active:after {
  border-color: #E8C3A2;
}
.btn--standard-orange:before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: block;
  background: #fff;
  position: absolute;
  right: 20px;
  top: calc(50% - 11px);
}
@media screen and (max-width: 768px) {
  .btn--standard-orange:before {
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
    right: 15px;
  }
}
.btn--standard-orange:after {
  content: "";
  width: 5px;
  height: 5px;
  display: block;
  position: absolute;
  border-right: 2px solid #e79248;
  border-top: 2px solid #e79248;
  right: 28px;
  top: calc(50% - 3px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .btn--standard-orange:after {
    width: 4px;
    height: 4px;
    top: calc(50% - 2px);
    right: 23px;
  }
}
.btn--primary {
  background: #15A38C;
  display: inline-block;
  font-size: 28px;
  line-height: 1.5em;
  font-weight: bold;
  width: 100%;
  max-width: 540px;
  text-align: center;
  box-sizing: border-box;
  padding: 30px;
  border-radius: 50px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .btn--primary {
    font-size: 17px;
    line-height: 1.5em;
    padding: 15px;
  }
}
.btn--primary:link, .btn--primary:visited {
  text-decoration: none;
  color: #fff;
}
.btn--primary:hover, .btn--primary:active {
  text-decoration: none;
  color: #fff;
  background: #a1dad1;
}
.btn--primary:hover:after, .btn--primary:active:after {
  border-color: #a1dad1;
}
.btn--primary:before {
  content: "";
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: block;
  background: #fff;
  position: absolute;
  right: 40px;
  top: calc(50% - 14px);
}
@media screen and (max-width: 768px) {
  .btn--primary:before {
    right: 15px;
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
  }
}
.btn--primary:after {
  content: "";
  width: 6px;
  height: 6px;
  display: block;
  position: absolute;
  border-right: 2px solid #15A38C;
  border-top: 2px solid #15A38C;
  right: 51px;
  top: calc(50% - 3px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .btn--primary:after {
    right: 23px;
    width: 4px;
    height: 4px;
    top: calc(50% - 2px);
  }
}
.btn--primary-orange {
  background: #e79248;
  display: inline-block;
  font-size: 28px;
  line-height: 1.5em;
  font-weight: bold;
  width: 100%;
  max-width: 540px;
  text-align: center;
  box-sizing: border-box;
  padding: 30px;
  border-radius: 50px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .btn--primary-orange {
    font-size: 17px;
    line-height: 1.5em;
    padding: 15px;
  }
}
.btn--primary-orange:link, .btn--primary-orange:visited {
  text-decoration: none;
  color: #fff;
}
.btn--primary-orange:hover, .btn--primary-orange:active {
  text-decoration: none;
  color: #fff;
  background: #E8C3A2;
}
.btn--primary-orange:hover:after, .btn--primary-orange:active:after {
  border-color: #E8C3A2;
}
.btn--primary-orange:before {
  content: "";
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: block;
  background: #fff;
  position: absolute;
  right: 40px;
  top: calc(50% - 14px);
}
@media screen and (max-width: 768px) {
  .btn--primary-orange:before {
    right: 15px;
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
  }
}
.btn--primary-orange:after {
  content: "";
  width: 6px;
  height: 6px;
  display: block;
  position: absolute;
  border-right: 2px solid #e79248;
  border-top: 2px solid #e79248;
  right: 51px;
  top: calc(50% - 3px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .btn--primary-orange:after {
    right: 23px;
    width: 4px;
    height: 4px;
    top: calc(50% - 2px);
  }
}

.title {
  text-align: center;
  margin: 0 0 60px;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .title {
    margin-bottom: 30px;
  }
}
.title__main {
  margin: 0;
  font-size: 36px;
  line-height: 1.5em;
}
@media screen and (max-width: 768px) {
  .title__main {
    font-size: 22px;
    line-height: 1.5em;
    margin-bottom: 10px;
    white-space: nowrap;
  }
}
.title__sub {
  font-size: 18px;
  line-height: 1.6em;
  color: #0C61B9;
  font-family: "Alatsi", sans-serif;
}
@media screen and (max-width: 768px) {
  .title__sub {
    font-size: 12px;
    line-height: 1.5em;
  }
}
.title--small {
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .title--small {
    margin-bottom: 25px;
  }
}
.title--small .title__main {
  font-size: 28px;
  line-height: 1.5em;
}
@media screen and (max-width: 768px) {
  .title--small .title__main {
    font-size: 22px;
    line-height: 1.5em;
  }
}
.title--small .title__sub {
  font-size: 16px;
  line-height: 1.5em;
}
@media screen and (max-width: 768px) {
  .title--small .title__sub {
    font-size: 12px;
    line-height: 1.5em;
  }
}

.kv {
  max-width: 1180px;
  height: 418px;
  width: 100%;
  margin: 30px auto 0;
  padding: 0 30px;
  position: relative;
  box-sizing: border-box;
}
@media screen and (max-width: 1120px) {
  .kv {
    height: 300px;
  }
}
@media screen and (max-width: 768px) {
  .kv {
    height: auto;
    padding: 0 15px;
  }
}
.kv__title {
  font-size: 42px;
  line-height: 1.6em;
  font-weight: bold;
  margin: 0;
  position: relative;
  z-index: 4;
}
@media screen and (max-width: 768px) {
  .kv__title {
    font-size: 25px;
    line-height: 1.6em;
    text-align: center;
    margin-bottom: 30px;
    white-space: nowrap;
  }
}
.kv__title strong {
  color: #0C61B9;
}
.kv__img01 {
  font-size: 0;
  line-height: 0;
  position: absolute;
  width: 100vw;
  left: calc(50% - 50vw);
  bottom: 30px;
}
@media screen and (max-width: 1120px) {
  .kv__img01 {
    bottom: 0;
  }
}
@media screen and (max-width: 768px) {
  .kv__img01 {
    bottom: auto;
    top: 50%;
  }
}
@media screen and (max-width: 414px) {
  .kv__img01 {
    top: 60%;
  }
}
.kv__img01 img {
  width: 100%;
  height: auto;
}
.kv__img02 {
  font-size: 0;
  line-height: 0;
  position: absolute;
  width: 54%;
  left: 46%;
  top: 0;
}
@media screen and (max-width: 1120px) {
  .kv__img02 {
    width: 40%;
    left: 54%;
    max-width: 600px;
  }
}
@media screen and (max-width: 768px) {
  .kv__img02 {
    width: 100%;
    position: relative;
    left: auto;
    top: auto;
    margin: 0 auto;
    max-width: 400px;
  }
}
.kv__img03 {
  font-style: 0;
  line-height: 0;
  position: absolute;
  width: calc(51% - 150px);
  left: calc(49% + 65px);
  bottom: 0;
}
@media screen and (max-width: 1120px) {
  .kv__img03 {
    width: 30%;
    left: 60%;
  }
}
@media screen and (max-width: 980px) {
  .kv__img03 {
    width: 38%;
    left: 56%;
  }
}
@media screen and (max-width: 768px) {
  .kv__img03 {
    width: 100%;
    position: relative;
    left: auto;
    top: auto;
    max-width: calc(100% - 100px);
    margin: 0 auto;
  }
}

.home-hero {
  background: #0C61B9;
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  box-sizing: border-box;
  padding: 100px 30px;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 1120px) {
  .home-hero {
    justify-content: space-between;
  }
}
@media screen and (max-width: 768px) {
  .home-hero {
    flex-direction: column;
    padding: 50px 30px;
  }
}
.home-hero__item {
  width: 100%;
  max-width: 530px;
  margin: 0 30px;
  background: #fff;
  box-sizing: border-box;
  padding: 50px 40px;
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1120px) {
  .home-hero__item {
    margin: 0;
    max-width: calc(50% - 15px);
  }
}
@media screen and (max-width: 768px) {
  .home-hero__item {
    max-width: 100%;
    padding: 25px 20px;
    border-radius: 12px;
  }
  .home-hero__item:first-child {
    margin-bottom: 30px;
  }
}
.home-hero__item-image {
  font-size: 0;
  line-height: 0;
  margin-bottom: 40px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-hero__item-image {
    margin-bottom: 20px;
  }
}
.home-hero__item-desc {
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .home-hero__item-desc {
    margin-bottom: 20px;
  }
}
.home-hero__item-link {
  margin-top: auto;
  text-align: center;
}
.home-hero:before {
  content: "";
  width: 1268px;
  height: 427px;
  background: url(../img/common-bgimg-l.webp) no-repeat top center;
  background-size: 100% auto;
  display: block;
  position: absolute;
  right: 10%;
  top: 40px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-hero:before {
    width: 800px;
    right: -10%;
    top: 20px;
  }
}
.home-hero:after {
  content: "";
  width: 1268px;
  height: 427px;
  background: url(../img/common-bgimg-r.webp) no-repeat top center;
  background-size: 100% auto;
  display: block;
  position: absolute;
  left: 10%;
  bottom: 40px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-hero:after {
    width: 800px;
    height: 270px;
    left: -10%;
    bottom: 20px;
  }
}

.home-jobtype {
  width: 100%;
  max-width: 1180px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  box-sizing: border-box;
  margin: -139px auto 0;
  padding: 240px 30px 20px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-jobtype {
    margin-top: -69px;
    padding: 120px 30px 0;
  }
}
.home-jobtype:before {
  content: "";
  width: 100vw;
  height: 50%;
  background: #fff;
  position: absolute;
  left: calc(50% - 50vw);
  bottom: 0;
  z-index: -1;
}
.home-jobtype__item {
  width: calc(50% - 30px);
  margin: 0 0 80px;
  background: #fff;
  box-sizing: border-box;
  border-radius: 14px;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 1120px) {
  .home-jobtype__item {
    width: calc(50% - 15px);
  }
}
@media screen and (max-width: 768px) {
  .home-jobtype__item {
    width: 100%;
    margin-bottom: 50px;
  }
}
.home-jobtype__item-image {
  background: #D0F0EB;
  font-size: 0;
  line-height: 0;
  display: flex;
  justify-content: center;
  align-items: end;
  border-radius: 14px;
  height: 220px;
  margin-bottom: 40px;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .home-jobtype__item-image {
    height: 131px;
    margin-bottom: 25px;
  }
}
.home-jobtype__item-image--center {
  align-items: center;
}
@media screen and (max-width: 768px) {
  .home-jobtype__item-image img {
    max-height: 92%;
    width: auto;
  }
}
.home-jobtype__item-title {
  font-size: 28px;
  line-height: 1.5em;
  text-align: center;
  margin: 0 0 25px;
}
@media screen and (max-width: 768px) {
  .home-jobtype__item-title {
    font-size: 19px;
    line-height: 1.5em;
    margin-bottom: 10px;
  }
}
.home-jobtype__item-title a {
  display: block;
}
.home-jobtype__item-title a:link, .home-jobtype__item-title a:visited {
  text-decoration: none;
  color: #333;
}
.home-jobtype__item-title a:hover, .home-jobtype__item-title a:active {
  text-decoration: none;
  color: #15A38C;
}
.home-jobtype__item-list {
  list-style: none;
  margin: 0 10px 40px;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-jobtype__item-list {
    margin: 0 0 30px;
  }
}
.home-jobtype__item-list > li {
  border-bottom: 1px solid #D5DADE;
}
.home-jobtype__item-list > li > a {
  display: block;
  font-size: 18px;
  line-height: 1.5em;
  font-weight: bold;
  position: relative;
  padding: 15px 0 15px 37px;
}
@media screen and (max-width: 768px) {
  .home-jobtype__item-list > li > a {
    font-size: 15px;
    line-height: 1.5em;
    padding-left: 30px;
  }
}
.home-jobtype__item-list > li > a:link, .home-jobtype__item-list > li > a:visited {
  text-decoration: none;
  color: #333;
}
.home-jobtype__item-list > li > a:hover, .home-jobtype__item-list > li > a:active {
  text-decoration: none;
  color: #15A38C;
}
.home-jobtype__item-list > li > a:before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: block;
  background: #15A38C;
  position: absolute;
  left: 0;
  top: calc(50% - 11px);
}
@media screen and (max-width: 768px) {
  .home-jobtype__item-list > li > a:before {
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
  }
}
.home-jobtype__item-list > li > a:after {
  content: "";
  width: 5px;
  height: 5px;
  display: block;
  position: absolute;
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  left: 6px;
  top: calc(50% - 3px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .home-jobtype__item-list > li > a:after {
    width: 4px;
    height: 4px;
    top: calc(50% - 2px);
    left: 6px;
  }
}
.home-jobtype__item-link {
  margin-top: auto;
  text-align: center;
}

.home-industry {
  width: 100%;
  max-width: 1180px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  box-sizing: border-box;
  position: relative;
  margin: -139px auto 0;
  padding: 240px 30px 40px;
}
@media screen and (max-width: 768px) {
  .home-industry {
    margin-top: -69px;
    padding: 120px 30px 25px;
  }
}
.home-industry:before {
  content: "";
  width: 100vw;
  height: 100%;
  background: #F0F2F3;
  position: absolute;
  left: calc(50% - 50vw);
  top: 0;
  z-index: -1;
}
.home-industry__item {
  width: calc(25% - 45px);
  margin: 0 0 60px;
}
@media screen and (max-width: 1120px) {
  .home-industry__item {
    width: calc(25% - 25px);
  }
}
@media screen and (max-width: 768px) {
  .home-industry__item {
    width: calc(50% - 16px);
    margin-bottom: 25px;
  }
}
.home-industry__item:hover a:link, .home-industry__item:hover a:visited, .home-industry__item:active a:link, .home-industry__item:active a:visited {
  color: #15A38C;
}
.home-industry__item-image {
  width: 100%;
  height: 180px;
  background: #fff;
  border-radius: 14px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 20px;
}
@media screen and (max-width: 768px) {
  .home-industry__item-image {
    margin-bottom: 15px;
    height: 90px;
    border-radius: 12px;
  }
}
@media screen and (max-width: 768px) {
  .home-industry__item-image img {
    max-height: 52%;
    width: auto;
  }
}
.home-industry__item-title {
  font-size: 20px;
  line-height: 1.5em;
  margin: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-industry__item-title {
    font-size: 16px;
    line-height: 1.5em;
  }
}
.home-industry__item-title a:link, .home-industry__item-title a:visited {
  text-decoration: none;
  color: #333;
}
.home-industry__item-title a:hover, .home-industry__item-title a:active {
  text-decoration: none;
  color: #15A38C;
}

.home-cta {
  background: #0C61B9;
  padding: 120px 0;
  text-align: center;
  display: flex;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .home-cta {
    padding: 50px 0;
    flex-direction: column;
  }
}
.home-cta__item {
  width: 100%;
  max-width: 540px;
  margin: 0 20px;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .home-cta__item {
    margin: 0 auto;
    max-width: calc(100% - 60px);
  }
  .home-cta__item:first-child {
    margin-bottom: 15px;
  }
}
.home-cta__image {
  font-size: 0;
  line-height: 0;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
}
.home-cta__image img {
  width: 100%;
  height: auto;
}
.home-cta:before {
  content: "";
  width: 1014px;
  height: 341px;
  background: url(../img/common-bgimg-r.webp) no-repeat top center;
  background-size: 100% auto;
  display: block;
  position: absolute;
  left: 40%;
  bottom: 40%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-cta:before {
    width: 800px;
    height: 280px;
    left: 10%;
    bottom: auto;
    top: -60%;
  }
}

.home-news {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 100px 30px;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-news {
    padding: 50px 30px;
  }
}
.home-news__item {
  width: 100%;
}
.home-news__item-link {
  display: flex;
  justify-content: flex-end;
}
.home-news__item-link a {
  display: block;
  position: relative;
  padding-left: 35px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .home-news__item-link a {
    font-size: 15px;
    line-height: 1.5em;
    padding-left: 25px;
  }
}
.home-news__item-link a:link, .home-news__item-link a:visited {
  text-decoration: none;
  color: #333;
}
.home-news__item-link a:hover, .home-news__item-link a:active {
  text-decoration: none;
  color: #15A38C;
}
.home-news__item-link a:before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: block;
  background: #15A38C;
  position: absolute;
  left: 0;
  top: calc(50% - 11px);
}
@media screen and (max-width: 768px) {
  .home-news__item-link a:before {
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
  }
}
.home-news__item-link a:after {
  content: "";
  width: 5px;
  height: 5px;
  display: block;
  position: absolute;
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  left: 7px;
  top: calc(50% - 3px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .home-news__item-link a:after {
    width: 4;
    height: 4;
    left: 5px;
    top: calc(50% - 3px);
  }
}

.case-title {
  font-size: 30px;
  line-height: 1.5em;
  margin-bottom: 50px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .case-title {
    font-size: 24px;
    line-height: 1.5em;
  }
}

.news-title {
  border-bottom: 1px solid #D5DADE;
  font-size: 30px;
  line-height: 1.5em;
  margin-bottom: 25px;
  padding-bottom: 25px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .news-title {
    font-size: 24px;
    line-height: 1.5em;
  }
}

.news:not(:last-child) {
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .news:not(:last-child) {
    margin-bottom: 25px;
  }
}
.news__item {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  border-bottom: 1px solid #D5DADE;
  margin-bottom: 25px;
  padding-bottom: 25px;
}
@media screen and (max-width: 768px) {
  .news__item {
    justify-content: flex-start;
  }
}
.news__item:last-child {
  margin-bottom: 0;
}
.news__item-date {
  width: 100px;
}
.news__item-cat {
  width: 130px;
}
.news__item-title {
  width: calc(100% - 250px);
  margin: 0 0 0 auto;
  color: #333333;
  font-weight: 500;
  font-size: 18px;
  line-height: 1.8em;
}
@media screen and (max-width: 768px) {
  .news__item-title {
    width: 100%;
    margin-top: 10px;
    font-weight: 500;
    font-size: 16px;
    line-height: 1.8em;
  }
}
.news__item-title a {
  display: block;
  position: relative;
  padding-right: 40px;
}
@media screen and (max-width: 768px) {
  .news__item-title a {
    padding-right: 0;
  }
}
.news__item-title a:link, .news__item-title a:visited {
  text-decoration: none;
  color: #333;
}
.news__item-title a:hover, .news__item-title a:active {
  text-decoration: none;
  color: #15A38C;
}
.news__item-title a:after {
  content: "";
  width: 8px;
  height: 8px;
  display: block;
  position: absolute;
  border-right: 3px solid #15A38C;
  border-top: 3px solid #15A38C;
  right: 0;
  top: calc(50% - 4px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .news__item-title a:after {
    display: none;
  }
}

.date {
  font-size: 16px;
  line-height: 1.5em;
  color: #000;
}

.cat {
  display: block;
  background: #0C61B9;
  font-size: 14px;
  line-height: 1.5em;
  text-align: center;
  box-sizing: border-box;
  padding: 5px;
  border-radius: 4px;
}
.cat:link, .cat:visited {
  text-decoration: none;
  color: #fff;
}
.cat:hover, .cat:active {
  text-decoration: none;
  color: #fff;
}

.cta {
  background: #ffeee0;
  text-align: center;
  padding: 60px 30px;
}
@media screen and (max-width: 768px) {
  .cta {
    padding: 50px 30px;
  }
}
.cta__item {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
}
.cta__item-box {
  background: #fff;
  box-sizing: border-box;
  padding: 40px;
  border-radius: 14px;
}
@media screen and (max-width: 768px) {
  .cta__item-box {
    padding: 25px;
  }
}
.cta__item-title {
  font-size: 36px;
  line-height: 1.5em;
  margin: 0 0 40px;
}
@media screen and (max-width: 768px) {
  .cta__item-title {
    font-size: 21px;
    line-height: 1.5em;
    margin-bottom: 25px;
  }
}
.cta__item-desc {
  margin: 0 0 30px;
}
@media screen and (max-width: 768px) {
  .cta__item-desc {
    margin-bottom: 25px;
    text-align: left;
  }
}

.fixed-nav {
  position: fixed;
  right: 0;
  top: 25vh;
  z-index: 9998;
}
@media screen and (max-width: 768px) {
  .fixed-nav {
    top: auto;
    bottom: 0;
    width: 100%;
  }
}
.fixed-nav a {
  width: 70px;
  height: 290px;
  box-sizing: border-box;
  padding: 20px;
  border-radius: 14px 0 0 14px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  background: #e79248;
  font-weight: bold;
  transition: background 0.3s;
}
@media screen and (max-width: 768px) {
  .fixed-nav a {
    -ms-writing-mode: inherit;
    writing-mode: inherit;
    width: 100%;
    height: auto;
    border-radius: 0;
    font-size: 15px;
    line-height: 1.5em;
    padding: 15px;
    justify-content: center;
  }
}
.fixed-nav a:after {
  transition: border-color 0.3s;
}
.fixed-nav a:link, .fixed-nav a:visited {
  text-decoration: none;
  color: #fff;
}
.fixed-nav a:hover, .fixed-nav a:active {
  text-decoration: none;
  color: #fff;
  background: #E8C3A2;
}
.fixed-nav a:hover:after, .fixed-nav a:active:after {
  border-color: #E8C3A2;
}
.fixed-nav a:before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: block;
  background: #fff;
  position: absolute;
  left: calc(50% - 11px);
  bottom: 20px;
}
@media screen and (max-width: 768px) {
  .fixed-nav a:before {
    width: 17px;
    height: 17px;
    bottom: auto;
    top: calc(50% - 8px);
    left: 75%;
  }
}
.fixed-nav a:after {
  content: "";
  width: 5px;
  height: 5px;
  display: block;
  position: absolute;
  border-right: 2px solid #e79248;
  border-top: 2px solid #e79248;
  left: calc(50% - 4px);
  bottom: 27px;
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .fixed-nav a:after {
    width: 4px;
    height: 4px;
    bottom: auto;
    top: calc(50% - 2px);
    left: calc(75% + 5px);
  }
}

.biggerlink {
  cursor: pointer;
}

.footer {
  position: relative;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 80px 30px;
  box-sizing: border-box;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .footer {
    padding: 50px 30px 80px;
    flex-direction: column;
  }
}
.footer:after {
  content: "";
  width: 100vw;
  height: 100%;
  display: block;
  z-index: -1;
  background: #0c61b9;
  position: absolute;
  left: calc(50% - 50vw);
  top: 0;
}
.footer__nav {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 60%;
  margin-bottom: 40px;
}
@media screen and (max-width: 1120px) {
  .footer__nav {
    width: 100%;
    margin-bottom: 30px;
  }
}
.footer__nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 33.3%;
}
@media screen and (max-width: 768px) {
  .footer__nav ul {
    width: 50%;
  }
  .footer__nav ul:last-child {
    margin-top: 10px;
  }
}
.footer__nav ul li:not(:last-child) {
  margin-bottom: 10px;
}
.footer__nav ul li a {
  font-size: 16px;
  line-height: 1.5em;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .footer__nav ul li a {
    font-size: 15px;
    line-height: 1.5em;
  }
}
.footer__nav ul li a:link, .footer__nav ul li a:visited {
  text-decoration: none;
  color: #fff;
}
.footer__nav ul li a:hover, .footer__nav ul li a:active {
  text-decoration: underline;
  color: #fff;
}
.footer__contact {
  margin: 0 0 0 auto;
  width: 100%;
  max-width: 330px;
}
@media screen and (max-width: 1120px) {
  .footer__contact {
    max-width: 100%;
    text-align: center;
    margin-bottom: 40px;
  }
}
.footer__subnav {
  margin-top: auto;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
@media screen and (max-width: 1120px) {
  .footer__subnav {
    width: 100%;
    margin-bottom: 40px;
    justify-content: center;
    flex-direction: column;
  }
}
.footer__subnav ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: flex-start;
  font-size: 0;
  line-height: 0;
}
@media screen and (max-width: 1120px) {
  .footer__subnav ul {
    justify-content: center;
    margin-bottom: 15px;
  }
}
.footer__subnav ul:last-child {
  border-right: 1px solid #fff;
}
@media screen and (max-width: 1120px) {
  .footer__subnav ul:last-child {
    border-right: none;
    margin-bottom: 0;
  }
}
.footer__subnav ul li {
  border-left: 1px solid #fff;
}
@media screen and (max-width: 1120px) {
  .footer__subnav ul li:last-child {
    border-right: 1px solid #fff;
  }
}
.footer__subnav ul li a {
  font-size: 14px;
  line-height: 1.2em;
  display: inline-block;
  padding: 0 20px;
}
.footer__subnav ul li a:link, .footer__subnav ul li a:visited {
  text-decoration: none;
  color: #fff;
}
.footer__subnav ul li a:hover, .footer__subnav ul li a:active {
  text-decoration: underline;
  color: #fff;
}
.footer__bottom {
  width: 30%;
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  margin-top: auto;
}
@media screen and (max-width: 1120px) {
  .footer__bottom {
    width: 100%;
    flex-direction: column;
  }
}
.footer__scsk {
  font-size: 0;
  line-height: 0;
  margin-bottom: 18px;
}
@media screen and (max-width: 1120px) {
  .footer__scsk {
    width: 100%;
    text-align: center;
  }
  .footer__scsk img {
    width: 67px;
    height: auto;
  }
}
.footer__copyright {
  width: 100%;
  font-size: 14px;
  line-height: 1.5em;
  text-align: right;
}
@media screen and (max-width: 1180px) {
  .footer__copyright {
    font-size: 10px;
    line-height: 1.5em;
    text-align: center;
  }
}

#page-top {
  width: 50px;
  height: 50px;
  position: fixed;
  right: 10px;
  bottom: -50px;
  background: #0c61b9;
  opacity: 0.6;
  border-radius: 50%;
  z-index: 9998;
}
#page-top a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page-top a:before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f106";
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -5px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}

.breadcrumbs {
  padding: 0 30px;
  margin: 30px 0 0;
}
@media screen and (max-width: 768px) {
  .breadcrumbs {
    padding: 0 15px;
    margin-top: 15px;
  }
}
.breadcrumbs__inner {
  max-width: 1120px;
  margin: 0 auto;
  list-style: none;
  display: flex;
  justify-content: flex-start;
  color: #333;
  padding: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.breadcrumbs__inner > li {
  font-size: 12px;
  line-height: 1.5em;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media screen and (max-width: 768px) {
  .breadcrumbs__inner > li {
    font-size: 11px;
    line-height: 1.5em;
  }
}
.breadcrumbs__inner > li:not(:last-child):after {
  content: "＞";
  display: inline-block;
  margin: 0 5px;
}
.breadcrumbs__inner > li a:link, .breadcrumbs__inner > li a:visited {
  text-decoration: none;
  color: #333;
}
.breadcrumbs__inner > li a:hover, .breadcrumbs__inner > li a:active {
  text-decoration: underline;
  color: #333;
}

.page__header {
  background: #0c61b9;
  text-align: center;
  width: 100%;
  height: 200px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .page__header {
    height: 120px;
  }
}
.page__header > div,
.page__header > h1 {
  font-size: 40px;
  line-height: 1.5em;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page__header > div,
  .page__header > h1 {
    font-size: 28px;
    line-height: 1.5em;
  }
}
.page__header:before {
  content: "";
  width: 1000px;
  height: 340px;
  background: url(../img/common-bgimg-l.webp) no-repeat top center;
  background-size: 100% auto;
  display: block;
  position: absolute;
  right: 65%;
  top: 5%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .page__header:before {
    width: 100%;
    height: 100%;
    right: 80%;
    top: 15%;
  }
}
.page__header:after {
  content: "";
  width: 1000px;
  height: 340px;
  background: url(../img/common-bgimg-r.webp) no-repeat bottom center;
  background-size: 100% auto;
  display: block;
  position: absolute;
  left: 65%;
  bottom: 5%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .page__header:after {
    width: 100%;
    height: 100%;
    left: 80%;
    bottom: 15%;
  }
}
.page__contents {
  width: 100%;
  max-width: 1180px;
  box-sizing: border-box;
  margin: 80px auto 100px;
  padding: 0 30px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  .page__contents {
    margin: 50px auto;
  }
}
.page__contents-main {
  width: 780px;
}
@media screen and (max-width: 1120px) {
  .page__contents-main {
    width: calc(100% - 300px);
  }
}
@media screen and (max-width: 768px) {
  .page__contents-main {
    width: 100%;
    margin-bottom: 50px;
    order: 1;
  }
}
.page__contents-sub {
  width: 270px;
}
@media screen and (max-width: 768px) {
  .page__contents-sub {
    width: 100%;
    order: 3;
  }
}
.page__contents-footer {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .page__contents-footer {
    order: 2;
  }
}

.contents {
  width: 100%;
}
.contents__header {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin: 0 0 50px;
}
.contents__header-title {
  width: 100%;
  margin: 0 0 30px !important;
}
.contents__header-date {
  width: 100px;
}
.contents__header-cat {
  width: calc(100% - 100px);
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.contents__header-cat .cat {
  margin-bottom: 10px;
}
.contents__header-cat .cat:not(:last-child) {
  margin-right: 10px;
}
.contents .center {
  text-align: center;
}
.contents .center:not(:last-child) {
  margin-bottom: 50px;
}
.contents .mt-be-columns {
  width: 100%;
}
.contents .mt-be-columns:not(:last-child) {
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .contents .mt-be-columns {
    flex-direction: column;
  }
}
.contents .mt-be-columns .mt-be-column:not(:last-child) {
  margin-right: 50px;
}
@media screen and (max-width: 1120px) {
  .contents .mt-be-columns .mt-be-column:not(:last-child) {
    margin-right: 30px;
  }
}
@media screen and (max-width: 768px) {
  .contents .mt-be-columns .mt-be-column:not(:last-child) {
    margin-right: 0;
    margin-bottom: 50px;
  }
}
.contents .mt-be-columns .mt-be-column > * {
  margin: 0;
}
.contents .mt-be-columns .mt-be-column > *:not(:last-child) {
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .contents .mt-be-columns .mt-be-column > *:not(:last-child) {
    margin-bottom: 20px;
  }
}
.contents .column__item-image {
  font-size: 0;
  line-height: 0;
}
.contents .column__item-title {
  font-size: 24px;
  line-height: 1.5em;
  font-weight: bold;
  text-align: center;
  margin-bottom: 25px !important;
}
@media screen and (max-width: 768px) {
  .contents .column__item-title {
    margin-bottom: 15px !important;
    font-size: 22px;
    line-height: 1.5em;
  }
}
.contents .column__item-desc + .center {
  margin-top: auto;
}
.contents .column--two .mt-be-column {
  width: calc(50% - 30px);
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 1120px) {
  .contents .column--two .mt-be-column {
    width: calc(50% - 15px);
  }
}
@media screen and (max-width: 768px) {
  .contents .column--two .mt-be-column {
    width: 100%;
  }
}
.contents .column--two .mt-be-column:not(:last-child) {
  margin-right: 60px;
}
@media screen and (max-width: 1120px) {
  .contents .column--two .mt-be-column:not(:last-child) {
    margin-right: 30px;
  }
}
@media screen and (max-width: 768px) {
  .contents .column--two .mt-be-column:not(:last-child) {
    margin-right: 0;
    margin-bottom: 50px;
  }
}
.contents .column--three .mt-be-column {
  width: calc(50% - 30px);
}
@media screen and (max-width: 1120px) {
  .contents .column--three .mt-be-column {
    width: calc(50% - 15px);
  }
}
@media screen and (max-width: 768px) {
  .contents .column--three .mt-be-column {
    width: 100%;
  }
}
.contents h1 {
  font-size: 36px;
  line-height: 1.5em;
  color: #0c61b9;
  font-weight: bold;
  margin: 0 0 50px;
}
@media screen and (max-width: 768px) {
  .contents h1 {
    font-size: 28px;
    line-height: 1.5em;
  }
}
.contents h2 {
  font-size: 26px;
  line-height: 1.5em;
  background: #f0f2f3;
  border-radius: 14px;
  overflow: hidden;
  padding: 20px 20px 20px 28px;
  position: relative;
  font-weight: bold;
  margin: 0 0 50px;
}
@media screen and (max-width: 768px) {
  .contents h2 {
    border-radius: 12px;
    font-size: 24px;
    line-height: 1.5em;
  }
}
.contents h2:after {
  content: "";
  width: 8px;
  height: 100%;
  display: block;
  background: #0c61b9;
  position: absolute;
  left: 0;
  top: 0;
}
.contents h3 {
  font-size: 24px;
  line-height: 1.5em;
  border-bottom: 1px solid #d5dade;
  padding: 0 0 20px 0;
  font-weight: bold;
  margin: 0 0 50px;
}
@media screen and (max-width: 768px) {
  .contents h3 {
    font-size: 22px;
    line-height: 1.5em;
  }
}
.contents h4 {
  font-size: 22px;
  line-height: 1.5em;
  border-left: 5px solid #0c61b9;
  padding: 0 0 0 20px;
  font-weight: bold;
  margin: 0 0 50px;
}
@media screen and (max-width: 768px) {
  .contents h4 {
    font-size: 20px;
    line-height: 1.5em;
  }
}
.contents h5 {
  font-size: 20px;
  line-height: 1.5em;
  position: relative;
  padding: 0 0 0 20px;
  font-weight: bold;
  margin: 0 0 50px;
}
@media screen and (max-width: 768px) {
  .contents h5 {
    font-size: 18px;
    line-height: 1.5em;
  }
}
.contents h5:after {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #fff;
  border: 4px solid #0c61b9;
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 8px);
}
.contents h6 {
  font-size: 18px;
  line-height: 1.5em;
  font-weight: bold;
  margin: 0 0 50px;
}
@media screen and (max-width: 768px) {
  .contents h6 {
    font-size: 16px;
    line-height: 1.5em;
  }
}
.contents a:not(.btn):not(.cat) {
  color: #15A38C;
}
.contents a:not(.btn):not(.cat):link, .contents a:not(.btn):not(.cat):visited {
  text-decoration: underline;
  color: #15A38C;
}
.contents a:not(.btn):not(.cat):hover, .contents a:not(.btn):not(.cat):active {
  text-decoration: none;
  color: #15A38C;
}
.contents .btn--standard {
  max-width: 340px;
}
.contents .btn--primary {
  max-width: 540px;
  font-size: 24px;
  line-height: 1.5em;
}
.contents img {
  border-radius: 14px;
}
@media screen and (max-width: 768px) {
  .contents img {
    border-radius: 12px;
  }
}
.contents p, .contents ul, .contents ol, .contents dl, .contents table, .contents blockquote, .contents figure {
  margin: 0 0 50px;
}
.contents p:last-child, .contents ul:last-child, .contents ol:last-child, .contents dl:last-child, .contents table:last-child, .contents blockquote:last-child, .contents figure:last-child {
  margin-bottom: 0;
}
.contents blockquote {
  background: #f0f2f3;
  margin: 0 0 50px;
  padding: 20px;
  color: #666;
  font-style: italic;
}
.contents ul {
  list-style: none;
  margin-left: 0;
  padding: 0;
}
.contents ul li {
  position: relative;
  padding-left: 15px;
}
.contents ul li:before {
  content: "";
  width: 4px;
  height: 4px;
  display: block;
  position: absolute;
  left: 0;
  top: 0.8em;
  content: "";
  background: #0C61B9;
}
.contents ol {
  margin-left: 20px;
  padding: 0;
}
.contents dl dt {
  font-weight: bold;
  margin-bottom: 1em;
}
.contents dl dd {
  margin: 0;
  padding: 0 0 0 20px;
  border-left: 1px solid #d5dade;
}
.contents table {
  border-collapse: collapse;
  border-spacing: 0;
  border-bottom: 1px solid #d5dade !important;
}
.contents table caption {
  font-weight: bold;
  text-align: left;
  margin-bottom: 10px;
}
.contents table tr th {
  background: #EBF5FF;
  padding: 30px 20px;
  vertical-align: top;
  border-top: 1px solid #d5dade !important;
  text-align: left;
}
.contents table tr th:not(:first-child) {
  border-left: 1px solid #d5dade !important;
}
@media screen and (max-width: 768px) {
  .contents table tr th {
    white-space: nowrap;
  }
}
.contents table tr td {
  padding: 30px 20px;
  vertical-align: top;
  border-top: 1px solid #d5dade !important;
  text-align: left;
}
.contents table tr td:not(:first-child) {
  border-left: 1px solid #d5dade !important;
}
@media screen and (max-width: 768px) {
  .contents table tr td {
    white-space: nowrap;
  }
}
.contents figure.mt-figure-center {
  text-align: center;
}
.contents figure figcaption {
  font-size: 14px;
  line-height: 1.5em;
  margin-top: 10px;
}

.table-container {
  width: 100%;
  overflow: hidden;
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .table-container {
    overflow-x: auto;
  }
}
.table-container:last-child {
  margin-bottom: 0;
}

.subnav:not(:last-child) {
  margin-bottom: 80px;
}
@media screen and (max-width: 768px) {
  .subnav:not(:last-child) {
    margin-bottom: 50px;
  }
}
.subnav__title {
  color: #fff;
  font-size: 20px;
  line-height: 1.5em;
  text-align: center;
  margin: 0;
}
.subnav__title span {
  display: block;
  padding: 20px;
  background: #0C61B9;
}
.subnav__title a {
  display: block;
  padding: 20px;
  background: #0C61B9;
}
.subnav__title a:link, .subnav__title a:visited {
  text-decoration: none;
  color: #fff;
}
.subnav__title a:hover, .subnav__title a:active {
  text-decoration: none;
  color: #fff;
}
.subnav__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.subnav__list li:not(:last-child) {
  margin-bottom: 1px;
}
.subnav__list li a {
  display: block;
  padding: 20px 20px 20px 12px;
  background: #F0F2F3;
  font-size: 16px;
  line-height: 1.5em;
  position: relative;
}
.subnav__list li a:link, .subnav__list li a:visited {
  text-decoration: none;
  color: #333;
}
.subnav__list li a:hover, .subnav__list li a:active {
  text-decoration: none;
  color: #15a38c;
}
.subnav__list li a:after {
  content: "";
  width: 8px;
  height: 8px;
  display: block;
  position: absolute;
  border-right: 2px solid #15A38C;
  border-top: 2px solid #15A38C;
  right: 15px;
  top: calc(50% - 4px);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .subnav__list li a:after {
    width: 4px;
    height: 4px;
    top: calc(50% - 2px);
    right: 23px;
  }
}

.pager {
  list-style: none;
  margin: 120px 0 0;
  padding: 0;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .pager {
    margin: 0 0 60px;
  }
}
.pager__block a:not(.link__next):not(.link__before) {
  text-decoration: underline;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: block;
  line-height: 40px;
  color: #333;
  box-sizing: border-box;
  border: 1px solid #D5DADE;
  text-align: center;
  margin: 0 10px;
}
.pager__block a:not(.link__next):not(.link__before):link, .pager__block a:not(.link__next):not(.link__before):visited {
  text-decoration: none;
  color: #333;
}
.pager__block a:not(.link__next):not(.link__before):hover, .pager__block a:not(.link__next):not(.link__before):active {
  text-decoration: none;
  color: #fff;
  background: #0C61B9;
  border-color: #0C61B9;
}
.pager__block a.link__next {
  width: 40px;
  height: 40px;
  display: block;
  font-size: 0;
  line-height: 0;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
  margin-left: 20px;
}
.pager__block a.link__next:after {
  content: "";
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  border-top: 3px solid #15A38C;
  border-right: 3px solid #15A38C;
  display: block;
  position: absolute;
  top: calc(50% - 5px);
  left: calc(50% - 5px);
}
.pager__block a.link__next:hover:after, .pager__block a.link__next:active:after {
  border-color: #a1dad1;
}
.pager__block a.link__before {
  width: 40px;
  height: 40px;
  display: block;
  font-size: 0;
  line-height: 0;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
  margin-right: 20px;
}
.pager__block a.link__before:after {
  content: "";
  width: 10px;
  height: 10px;
  transform: rotate(-135deg);
  border-top: 3px solid #15A38C;
  border-right: 3px solid #15A38C;
  display: block;
  position: absolute;
  top: calc(50% - 5px);
  left: calc(50% - 5px);
}
.pager__block a.link__before:hover:after, .pager__block a.link__before:active:after {
  border-color: #a1dad1;
}
.pager__block span {
  display: block;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #0C61B9;
  text-align: center;
  line-height: 40px;
  color: #fff;
  margin: 0 10px;
}

.case {
  border-top: 1px solid #D5DADE;
  padding-top: 50px;
}
.case__item {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.case__item:not(:last-child) {
  margin-bottom: 50px;
}
.case__item-image {
  width: calc(100% - 440px);
  aspect-ratio: 16/9;
  margin-bottom: auto;
  overflow: hidden;
  border-radius: 14px;
  font-size: 0;
  line-height: 0;
  position: relative;
}
@media screen and (max-width: 1120px) {
  .case__item-image {
    width: calc(30% - 30px);
  }
}
@media screen and (max-width: 768px) {
  .case__item-image {
    width: 100%;
    margin-bottom: 20px;
  }
}
.case__item-image a {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: cover !important;
}
.case__item-image img {
  object-fit: cover;
  opacity: 0;
}
.case__item-text {
  width: 390px;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 1120px) {
  .case__item-text {
    width: calc(70% - 0px);
  }
}
@media screen and (max-width: 768px) {
  .case__item-text {
    width: 100%;
  }
}
.case__item-title {
  font-size: 20px;
  line-height: 1.5em;
  font-weight: bold;
  margin: 0 0 20px;
}
.case__item-title a:link, .case__item-title a:visited {
  text-decoration: none;
  color: #333;
}
.case__item-title a:hover, .case__item-title a:active {
  text-decoration: none;
  color: #15A38C;
}
.case__item-todan {
  margin-top: auto;
  line-height: 1.2em;
}
.case__item-todan span {
  display: inline-block;
  padding-right: 10px;
  margin-right: 10px;
  border-right: 1px solid #0C61B9;
}
.case__item-footer {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-bottom: -10px;
}
.case__item-date {
  width: 100px;
}
.case__item-cat {
  width: calc(100% - 100px);
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.case__item-cat .cat {
  margin-bottom: 10px;
}
.case__item-cat .cat:not(:last-child) {
  margin-right: 10px;
}
