@charset "UTF-8";
/*------------------------
  Training program
------------------------*/
.resource-about-sect .wrapper {
  background-image: url(../images/training/img-about01.svg), url(../images/training/img-about02.svg);
  background-repeat: no-repeat;
  background-position: left 25% top 0, right 20% top 3%;
  background-size: 75px auto, 125px auto;
  background-size: 6.25vw auto, 10.417vw auto;
}
.resource-about-sect .about-box {
  margin: 5vw 0 0;
}
.resource-about-sect h4.content-title {
  margin: 0 0 0.833vw;
}
.resource-about-sect .about-desc {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.resource-about-sect .about-desc ul li {
  padding-left: 1.5em;
  margin: 0.4em 0;
  position: relative;
}
.resource-about-sect .about-desc ul li::before {
  content: "";
  position: absolute;
  box-sizing: border-box;
  width: 0.8em;
  height: 0.8em;
  border-radius: 50%;
  background-color: #FFA822;
  left: 0;
  top: 0.6em;
}

.resource-about-sect .lead,
.condition-sect .lead {
  max-width: 640px;
  margin: 0 auto 2.5vw;
  font-size: 17px;
  font-size: 1.417vw;
}
.resource-about-sect .lead p,
.condition-sect .lead p {
  line-height: 2.2;
}
.resource-about-sect .lead p + p,
.condition-sect .lead p + p {
  margin-top: 1.2em;
}
.resource-about-sect .lead p a,
.condition-sect .lead p a {
  text-decoration: underline;
  color: #FFA822;
}

@media screen and (min-width: 1366px) {
  .resource-about-sect .wrapper {
    background-size: 75px auto, 125px auto;
  }
  .resource-about-sect .about-box {
    margin: 60px 0 0;
  }
  .resource-about-sect h4.content-title {
    margin: 0 0 10px;
  }
  .resource-about-sect .lead,
  .condition-sect .lead {
    margin: 0 auto 30px;
    font-size: 17px;
  }
}
@media screen and (max-width: 768px) {
  .resource-about-sect .wrapper {
    background-position: left 25% top 0, right 20% top 3%;
    background-size: 50px auto, 90px auto;
  }
  .resource-about-sect .about-box {
    margin: 50px 0 0;
  }
  .resource-about-sect h4.content-title {
    margin: 0 0 5px;
  }
  .resource-about-sect .lead,
  .condition-sect .lead {
    margin: 0 auto 20px;
    font-size: 16px;
  }
}
@media screen and (max-width: 520px) {
  .resource-about-sect .wrapper {
    background-position: left 8% top 0, right 5% top 2%;
    background-size: 40px auto, 70px auto;
  }
}
.condition-sect .content-title {
  margin-bottom: 1.5vw;
}
.condition-sect .area-box {
  padding: 5vw 0 0;
}
.condition-sect .area-box ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
.condition-sect .area-box ul li {
  font-weight: 700;
}
.condition-sect .area-box ul li::after {
  content: "・";
}
.condition-sect .area-box ul li:last-child::after {
  content: none;
}
.condition-sect .area-box ul li:first-child {
  padding-left: 2.5vw;
  background: url(../images/training/icon-marker.svg) no-repeat left center/20px auto;
  background: url(../images/training/icon-marker.svg) no-repeat left center/1.667vw auto;
}
.condition-sect .area-box img {
  display: block;
  margin: 4.167vw auto;
}
.condition-sect .wh-box {
  background-color: #FFF;
  padding: 2.5vw;
  margin-top: 2.5vw;
  border: 1px solid #E6E6E6;
  border-radius: 10px;
}
.condition-sect .wh-box h5 {
  font-size: 18px;
  font-size: 1.5vw;
  text-align: center;
}
.condition-sect .wh-box h5 + img {
  display: block;
  margin: 1.25vw auto;
}
.condition-sect .wh-box .circle {
  text-align: center;
  border: 3px solid #28292B;
  font-weight: 700;
  border-radius: 10px;
}
.condition-sect .wh-box .circle + p {
  font-size: 13px;
  font-size: 1.083vw;
  margin-top: 0.833vw;
}

@media screen and (min-width: 1366px) {
  .condition-sect .content-title {
    margin-bottom: 30px;
  }
  .condition-sect .area-box {
    padding: 60px 0 0;
  }
  .condition-sect .area-box ul li:first-child {
    padding-left: 30px;
    background: url(../images/training/icon-marker.svg) no-repeat left center/20px auto;
  }
  .condition-sect .area-box img {
    margin: 50px auto;
  }
  .condition-sect .wh-box {
    padding: 30px;
    margin-top: 30px;
  }
  .condition-sect .wh-box h5 {
    font-size: 18px;
  }
  .condition-sect .wh-box h5 + img {
    margin: 15px auto;
  }
  .condition-sect .wh-box .circle + p {
    font-size: 13px;
    margin-top: 10px;
  }
}
@media screen and (max-width: 768px) {
  .condition-sect .content-title {
    margin-bottom: 15px;
  }
  .condition-sect .area-box {
    padding: 30px 0 0;
  }
  .condition-sect .area-box ul li {
    font-weight: 700;
  }
  .condition-sect .area-box ul li::after {
    content: "・";
  }
  .condition-sect .area-box ul li:last-child::after {
    content: none;
  }
  .condition-sect .area-box ul li:first-child {
    padding-left: 25px;
    background: url(../images/training/icon-marker.svg) no-repeat left center/18px auto;
  }
  .condition-sect .area-box img {
    width: 240px;
    margin: 20px auto 30px;
  }
  .condition-sect .wh-box {
    padding: 25px 30px 15px;
    margin-top: 30px;
  }
  .condition-sect .wh-box h5 {
    font-size: 18px;
  }
  .condition-sect .wh-box h5 + img {
    margin: 20px auto 0;
    max-width: 120px;
  }
  .condition-sect .wh-box .circle {
    width: 3em;
    margin: 20px auto 0;
  }
  .condition-sect .wh-box .circle + p {
    font-size: 14px;
    margin-top: 10px;
  }
}
.follow-sect .follow-flow {
  justify-content: space-between;
}
.follow-sect .follow-flow .col3 {
  width: calc(33.333% - 3.333vw);
  position: relative;
  padding: 2.5vw 0;
}
.follow-sect .follow-flow .col3::after {
  content: "";
  position: absolute;
  box-sizing: border-box;
  right: -4.9995vw;
  top: 0;
  width: 4.9995vw;
  height: 100%;
  background: url(../images/training/icon-flowarrow.svg) no-repeat center/50% auto;
}
.follow-sect .follow-flow .col3:nth-child(3n)::after {
  content: none;
}
.follow-sect .follow-flow figure {
  aspect-ratio: 29/24;
  overflow: hidden;
}
.follow-sect .follow-flow figure img {
  border-radius: 10px 10px 0 0;
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
}
.follow-sect .follow-flow h4 {
  text-align: center;
  color: #FFF;
  font-size: 18px;
  font-size: 1.5vw;
  padding: 1.25vw 0;
  margin-bottom: 0.833vw;
  background-color: #FFA822;
  border-radius: 0 0 10px 10px;
}
.follow-sect .follow-flow p {
  font-size: 13px;
  font-size: 1.083vw;
}
.follow-sect .item-follow {
  margin: 0 -2.5vw;
  align-items: center;
}
.follow-sect .item-follow:nth-child(odd) {
  flex-direction: row-reverse;
}
.follow-sect .item-follow .col2 {
  padding: 3.333vw 2.5vw;
}
.follow-sect .item-follow h5 {
  font-size: 28px;
  font-size: 2.333vw;
  font-weight: 700;
  color: #FFA822;
  margin-bottom: 1.25vw;
}
.follow-sect .item-follow img {
  display: block;
  margin: 0 auto;
}

@media screen and (min-width: 1366px) {
  .follow-sect .follow-flow .col3 {
    width: calc(33.333% - 40px);
    position: relative;
    padding: 30px 0;
  }
  .follow-sect .follow-flow .col3::after {
    content: "";
    position: absolute;
    box-sizing: border-box;
    right: -60px;
    width: 60px;
  }
  .follow-sect .follow-flow h4 {
    font-size: 18px;
    padding: 15px 0;
    margin-bottom: 10px;
  }
  .follow-sect .follow-flow p {
    font-size: 13px;
  }
  .follow-sect .item-follow {
    margin: 0 -30px;
  }
  .follow-sect .item-follow .col2 {
    padding: 40px 30px;
  }
  .follow-sect .item-follow h5 {
    font-size: 28px;
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 768px) {
  .follow-sect .follow-flow .col3 {
    width: calc(50% - 15px);
    padding: 20px 0;
  }
  .follow-sect .follow-flow .col3::after {
    right: -30px;
    width: 30px;
    background-size: 70% auto;
  }
  .follow-sect .follow-flow .col3:nth-child(3n)::after {
    content: "";
  }
  .follow-sect .follow-flow .col3:nth-child(even)::after, .follow-sect .follow-flow .col3:last-child::after {
    content: none;
  }
  .follow-sect .follow-flow h4 {
    font-size: 16px;
    padding: 5px;
    margin-bottom: 5px;
  }
  .follow-sect .follow-flow p {
    font-size: 13px;
  }
  .follow-sect .item-follow {
    margin: 40px 0;
    align-items: center;
  }
  .follow-sect .item-follow:nth-child(odd) {
    flex-direction: row;
  }
  .follow-sect .item-follow .col2 {
    padding: 10px 0;
  }
  .follow-sect .item-follow h5 {
    font-size: 18px;
    margin-bottom: 10px;
    text-align: center;
  }
  .follow-sect .item-follow img {
    max-width: 180px;
    max-height: 180px;
    object-fit: contain;
  }
}
.jobtype-sect .type-row {
  justify-content: space-between;
}
.jobtype-sect .type-row .item-type {
  width: calc(50% - 1.667vw);
  border-radius: 10px;
  border: 1px solid #E6E6E6;
  padding: 0.833vw 2.5vw 1.667vw;
  margin-top: 3.333vw;
  background-color: #FFF;
}
.jobtype-sect .type-row .item-type figure {
  margin: 0 0 1.25vw;
  aspect-ratio: 16/9;
  border-radius: 10px;
  overflow: hidden;
}
.jobtype-sect .type-row .item-type figure img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  object-position: center;
}
.jobtype-sect .type-row .item-type ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.jobtype-sect .type-row .item-type ul li {
  border-radius: 3px;
  margin: 0.417vw;
  background-color: #52BCDE;
  color: #FFF;
  padding: 0 0.833vw;
}

@media screen and (min-width: 1366px) {
  .jobtype-sect .type-row .item-type {
    width: calc(50% - 20px);
    padding: 10px 30px 20px;
    margin-top: 40px;
  }
  .jobtype-sect .type-row .item-type figure {
    margin: 0 0 15px;
  }
  .jobtype-sect .type-row .item-type ul li {
    margin: 5px;
    padding: 0 10px;
  }
}
@media screen and (max-width: 768px) {
  .jobtype-sect .type-row .item-type {
    width: 100%;
    padding: 15px 15px 25px;
    margin-top: 20px;
  }
  .jobtype-sect .type-row .item-type figure {
    margin: 0 auto 15px;
    max-width: 320px;
    width: 85%;
  }
  .jobtype-sect .type-row .item-type ul li {
    margin: 3px;
    padding: 2px 12px;
    font-size: 14px;
  }
}
.capa-sect .capa-row {
  justify-content: space-between;
  margin-bottom: 5vw;
}
.capa-sect .capa-row .item-capa {
  width: calc(33.333% - 0.333vw);
}
.capa-sect .capa-row .item-capa figure {
  aspect-ratio: 2/0.8;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.capa-sect .capa-row .item-capa figure img {
  display: block;
  margin: 0 auto;
  width: 40%;
}
.capa-sect .capa-row .item-capa h4 {
  text-align: center;
  padding: 0.833vw 1.25vw;
  border-radius: 6px 6px 0 0;
  font-size: 18px;
  font-size: 1.5vw;
  color: #FFF;
}
.capa-sect .capa-row .item-capa .sub-block {
  width: 100%;
  height: 5vw;
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  margin: 0.083vw 0;
  font-weight: 700;
}
.capa-sect .capa-row .item-capa .sub-block:last-child {
  border-radius: 0 0 6px 6px;
}
.capa-sect .capa-row .item-capa:nth-child(1) h4 {
  background-color: #52BCDE;
}
.capa-sect .capa-row .item-capa:nth-child(1) .sub-block {
  background-color: rgba(82, 188, 222, 0.2);
}
.capa-sect .capa-row .item-capa:nth-child(2) h4 {
  background-color: #FFA822;
}
.capa-sect .capa-row .item-capa:nth-child(2) .sub-block {
  background-color: rgba(255, 168, 34, 0.1);
}
.capa-sect .capa-row .item-capa:nth-child(3) h4 {
  background-color: #73c114;
}
.capa-sect .capa-row .item-capa:nth-child(3) .sub-block {
  background-color: rgba(115, 193, 20, 0.1);
}

@media screen and (min-width: 1366px) {
  .capa-sect .capa-row {
    margin-bottom: 60px;
  }
  .capa-sect .capa-row .item-capa {
    width: calc(33.333% - 4px);
  }
  .capa-sect .capa-row .item-capa h4 {
    padding: 10px 15px;
    font-size: 18px;
  }
  .capa-sect .capa-row .item-capa .sub-block {
    height: 60px;
    margin: 1px 0;
  }
}
@media screen and (max-width: 768px) {
  .capa-sect .capa-row {
    margin-bottom: 40px;
  }
  .capa-sect .capa-row .item-capa {
    width: calc(33.333% - 2px);
  }
  .capa-sect .capa-row .item-capa figure {
    aspect-ratio: 2/1;
  }
  .capa-sect .capa-row .item-capa figure img {
    width: 50%;
  }
  .capa-sect .capa-row .item-capa h4 {
    padding: 10px;
    font-size: 15px;
    height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .capa-sect .capa-row .item-capa .sub-block {
    height: 45px;
    margin: 1px 0;
    font-size: 13px;
  }
}