.p-photo, .p-photo2 {
  background: no-repeat top;
  background-size: 100% auto;
  position: relative;
}

.p-flow {
  background: #ebf6fd;
}

.p-flow__body {
  background: #fff;
  position: relative;
}

.p-flow__title {
  -webkit-align-items: flex-start;
  align-items: flex-start;
  background: url(/recruit/assets/images/workstyle/tri.svg) no-repeat;
  background-size: auto 100%;
  -webkit-box-align: start;
  -webkit-box-pack: center;
  color: #0075c1;
  font-weight: 700;
  -webkit-justify-content: center;
  justify-content: center;
  letter-spacing: 0.1em;
  line-height: 1;
}

.p-flow__title, .p-flow__year {
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
}

.p-flow__year {
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-align: center;
  -webkit-box-pack: start;
  color: #fff;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}

.p-flow__year:first-child {
  background: rgba(0, 117, 193, 0.4);
}

.p-flow__year:nth-child(2) {
  background-color: rgba(0, 117, 193, 0.55);
}

.p-flow__year:nth-child(3) {
  background-color: rgba(0, 117, 193, 0.7);
}

.p-flow__year:nth-child(4) {
  background-color: rgba(0, 117, 193, 0.85);
}

.p-flow__year:nth-child(5) {
  background-color: rgba(0, 117, 193, 0.9);
}

.p-flow__year:nth-child(6) {
  background-color: #0075c1;
  height: 12.5rem;
}
.p-flow__year:nth-child(6) dt {
  white-space: nowrap;
}
.p-flow__year:nth-child(6) dd p {
  line-height: 1.5;
}
.p-flow__year:nth-child(6) dd p br {
  display: block;
}
.p-flow__year:nth-child(6) dd p:last-child {
  font-size: 80%;
}

.p-flow__year dt {
  font-weight: 700;
}

.p-flow__year dd p {
  font-weight: 700;
  letter-spacing: 0.05em;
}

.p-flow__point {
  border-bottom: 1px solid #008ae2;
}

.p-flow__point-number {
  -webkit-align-items: flex-end;
  align-items: flex-end;
  -webkit-box-align: end;
  -webkit-box-pack: center;
  color: #0075c1;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  line-height: 1;
}

.p-flow__point-number:after, .p-flow__point-number:before {
  border-top: 1px solid #008ae2;
  -webkit-box-flex: 1;
  content: "";
  display: block;
  -webkit-flex-grow: 1;
  flex-grow: 1;
  margin-bottom: 0.2em;
}

.p-flow__point-number:before {
  margin-right: 0.5em;
}

.p-flow__point-number:after {
  margin-left: 0.5em;
}

.p-flow__point-title {
  color: #0075c1;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
}

.p-flow__point-text {
  letter-spacing: 0.05em;
  line-height: 2;
  text-align: justify;
}

.p-training__header {
  background: #65aede;
  position: relative;
}

.p-training__header .c-section__lead, .p-training__header .c-section__subtitle {
  color: #fff;
}

.p-training {
  background: #ebf6fd;
}

.p-training__body {
  position: relative;
}

.p-training__section {
  background: #fff;
}

.p-training__title {
  color: #0075c1;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
}

.p-training__text {
  letter-spacing: 0.05em;
  line-height: 2;
  text-align: justify;
}

.p-job > li {
  background: #0075c1;
  color: #fff;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  font-weight: 700;
  letter-spacing: 0.1em;
}

.p-job > li:nth-child(2n) {
  background: #0084d9;
}

@media only screen and (min-width: 768px), print {
  .p-workstyle__lead {
    white-space: nowrap;
  }
  .p-photo {
    width: 100%;
    height: 0;
    padding-top: 63.4%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
  }
  .p-photo2 {
    height: 27.375rem;
    margin: -3.65rem auto 0;
    max-width: 72.5rem;
  }
  .p-flow {
    margin-bottom: 6.25rem;
    padding-bottom: 6.25rem;
    padding-top: 6.25rem;
  }
  .p-flow__body {
    margin: 0 auto;
    padding: 3.75rem 3.75rem 5rem;
    width: 62.5rem;
  }
  .p-flow__title {
    background-position: right 17.8125rem bottom;
    font-size: 1.5rem;
    height: 5.1875rem;
    padding-top: 1.25rem;
  }
  .p-flow__years {
    -webkit-align-items: stretch;
    align-items: stretch;
    -webkit-box-align: stretch;
    -webkit-box-pack: stretch;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    -webkit-justify-content: stretch;
    justify-content: stretch;
    margin-bottom: 3rem;
  }
  .p-flow__year {
    background: url(/recruit/assets/images/workstyle/arrow.svg) no-repeat 0;
    -webkit-box-direction: normal;
    -webkit-box-orient: vertical;
    -webkit-flex-basis: 33%;
    flex-basis: 33%;
    -webkit-flex-direction: column;
    flex-direction: column;
    padding: 0.75rem 0 1.3125rem;
    width: 33%;
    height: 12.5rem !important;
  }
  .p-flow__year dd {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-top: -2rem;
  }
  .p-flow__year dt {
    font-size: 0.875rem;
    margin-bottom: 0.8125rem;
  }
  .p-flow__year dt b {
    font-size: 1.75rem;
  }
  .p-flow__year dd p {
    font-size: 0.8125rem;
    line-height: 1.3846153846;
    text-align: center;
  }
  .p-flow__year dd p + p {
    margin-top: 0.5rem;
  }
  .p-flow__year dd small {
    font-size: 0.75rem;
  }
  .p-flow__points {
    -webkit-align-items: stretch;
    align-items: stretch;
    -webkit-box-align: stretch;
    -webkit-box-pack: justify;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .p-flow__point {
    -webkit-flex-basis: 17.5rem;
    flex-basis: 17.5rem;
    width: 17.5rem;
  }
  .p-flow__point-number {
    font-size: 2.5rem;
    margin-bottom: 2rem;
  }
  .p-flow__point-title {
    -webkit-align-items: center;
    align-items: center;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    font-size: 1.25rem;
    height: 4rem;
    -webkit-justify-content: center;
    justify-content: center;
    line-height: 1.6;
    margin-bottom: 1.25rem;
  }
  .p-flow__point-text {
    font-size: 0.875rem;
    margin: 0 0.9375rem 1.625rem;
  }
  .p-workstyle__training {
    margin-top: 4.375rem;
  }
  .p-workstyle__training > .c-section__lead {
    margin-bottom: 2.875rem;
  }
  .p-training__header {
    padding: 3.375rem 0 8.75rem;
  }
  .p-training {
    padding-bottom: 3.125rem;
  }
  .p-training__body {
    -webkit-align-items: stretch;
    align-items: stretch;
    -webkit-box-align: stretch;
    -webkit-box-pack: justify;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin: -6.25rem auto 0;
    width: 62.25rem;
  }
  .p-training__section {
    box-shadow: 0.625rem 0.625rem #0075c1;
    -webkit-flex-basis: 19.5rem;
    flex-basis: 19.5rem;
    margin-bottom: 1.875rem;
    max-width: 19.5rem;
    padding: 3.625rem 1.875rem 1.875rem;
    width: 19.5rem;
  }
  .p-training__title {
    -webkit-align-items: center;
    align-items: center;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    font-size: 1rem;
    height: 3.25rem;
    -webkit-justify-content: center;
    justify-content: center;
    line-height: 1.625;
    margin-bottom: 1rem;
  }
  .p-training__text {
    font-size: 0.875rem;
  }
  .p-training__image {
    margin-top: 1.6875rem;
  }
  .p-job {
    -webkit-align-items: center;
    align-items: center;
    -webkit-box-align: center;
    -webkit-box-pack: justify;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin: 0 auto 1.875rem;
  }
  .p-job > li {
    -webkit-align-items: flex-start;
    align-items: flex-start;
    -webkit-box-align: start;
    -webkit-box-pack: center;
    -webkit-flex-basis: 5rem;
    flex-basis: 5rem;
    font-size: pc-rem(16);
    height: 15rem;
    -webkit-justify-content: center;
    justify-content: center;
    margin: 0 2px;
    padding-top: 1rem;
    width: 5rem;
  }
  .p-job > li:last-child {
    border: 0;
  }
  .p-job > li span {
    white-space: nowrap;
    -webkit-writing-mode: vertical-lr;
    -ms-writing-mode: tb-lr;
    writing-mode: vertical-lr;
  }
}
@media only screen and (max-width: 767.9px) {
  .sp_only_bg {
    background: url("../images/workstyle/sp_photo_2.png");
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    width: 100%;
    height: 26.5rem;
    margin: -3.75rem 0 3.75rem;
  }
  .p-photo {
    display: none;
    height: 23.08333rem;
    margin: -1.41667rem 0 0;
  }
  .p-photo2 {
    height: 16.08333rem;
    margin: -2.41667rem 0 0;
  }
  .p-flow {
    margin-bottom: 4.16667rem;
    padding-top: 4.16667rem;
    padding-bottom: 4.16667rem;
  }
  .p-flow__body {
    margin: 0 2.08333rem 0;
    padding: 2.08333rem 2.08333rem 1.66667rem;
  }
  .p-flow__title {
    background-position: right 3.95833rem bottom;
    font-size: 1.16667rem;
    height: 4.16667rem;
    padding-top: 1.25rem;
  }
  .p-flow__years {
    margin-bottom: 3.33333rem;
  }
  .p-flow__year {
    background: url(/recruit/assets/images/workstyle/sp_arrow.svg) no-repeat top;
    background-size: 1.125rem auto;
    height: 6.66667rem;
    padding: 0 0 0 1.45833rem;
  }
  .p-flow__year dt {
    font-size: 1rem;
    margin-right: 2.33333rem;
  }
  .p-flow__year dt b {
    font-size: 1.66667rem;
  }
  .p-flow__year dd p {
    font-size: 1rem;
    line-height: 1.3333333333;
  }
  .p-flow__year dd p + p {
    margin-top: 0.75rem;
  }
  .p-flow__year dd small {
    font-size: 0.91667rem;
  }
  .p-flow__year dd br {
    display: none;
  }
  .p-flow__point {
    margin-bottom: 1.66667rem;
    padding-bottom: 2.08333rem;
  }
  .p-flow__point-number {
    font-size: 2.5rem;
    margin-bottom: 2.16667rem;
  }
  .p-flow__point-title {
    font-size: 1.16667rem;
    line-height: 1.7142857143;
    margin-bottom: 1rem;
  }
  .p-flow__point-text {
    font-size: 1rem;
  }
  .p-workstyle__training {
    margin-top: 4.16667rem;
  }
  .p-workstyle__training > .c-section__lead {
    margin-bottom: 1.54167rem;
  }
  .p-training__header {
    padding: 3rem 0 6.58333rem;
  }
  .p-training {
    padding-bottom: 2.5rem;
  }
  .p-training__body {
    margin: -5rem 4.16667rem 0;
  }
  .p-training__section {
    box-shadow: 0.625rem 0.625rem #0075c1;
    margin-bottom: 1.66667rem;
    padding: 2.16667rem 2.08333rem 2.08333rem;
  }
  .p-training__title {
    font-size: 1.08333rem;
    line-height: 1.3846153846;
    margin-bottom: 1.125rem;
  }
  .p-training__text {
    font-size: 1rem;
  }
  .p-training__image {
    margin-top: 1.125rem;
  }
  .p-job {
    margin-bottom: 2.5rem;
  }
  .p-job > li {
    -webkit-align-items: center;
    align-items: center;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    font-size: 1.08333rem;
    height: 4.16667rem;
    -webkit-justify-content: center;
    justify-content: center;
    border-bottom: 2px solid #fff;
  }
}
.saitama {
  margin: 11rem 4.16667rem 0;
}
@media only screen and (min-width: 768px), print {
  .saitama {
    margin: 3rem 4.16667rem 0;
  }
}
.saitama .frame {
  -webkit-animation: effect 0.5s ease forwards;
  animation: effect 0.5s ease forwards;
  background: #fff;
  box-shadow: 0.625rem 0.625rem #0075c1;
  margin-bottom: 1.66667rem;
  padding: 2.16667rem 2.08333rem 2.08333rem;
}
@media only screen and (min-width: 768px), print {
  .saitama .frame {
    display: flex;
    justify-content: space-between;
    max-width: 780px;
    margin: 0 auto;
    padding: 0;
  }
}
.saitama .frame .img {
  margin-top: -10rem;
}
@media only screen and (min-width: 768px), print {
  .saitama .frame .img {
    margin-top: 0;
    width: 440px;
  }
}
@media only screen and (min-width: 768px), print {
  .saitama .frame .txt_area {
    padding: 3.16667rem 3.08333rem 3.08333rem;
  }
}
.saitama .frame .txt_area h3 {
  font-size: 1.08333rem;
  line-height: 1.3846153846;
  margin-top: 1.125rem;
  margin-bottom: 1.125rem;
  color: #0075c1;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
}
@media only screen and (min-width: 768px), print {
  .saitama .frame .txt_area h3 {
    font-size: 1rem;
    line-height: 1.625;
    margin-bottom: 1rem;
    text-align: left;
  }
}
.saitama .frame .txt_area p {
  font-size: 1rem;
  letter-spacing: 0.05em;
  line-height: 2;
  text-align: justify;
}
@media only screen and (min-width: 768px), print {
  .saitama .frame .txt_area p {
    font-size: 0.875rem;
  }
}
.saitama .frame .txt_area a {
  display: inline-block;
  margin-top: 0.5625rem;
  color: #0075c1;
  text-decoration: none;
  background-size: auto 0.83333rem;
  font-size: 1rem;
  padding-right: 1rem;
  background: url(/recruit/assets/images/common/external-3.svg) no-repeat 100%;
  letter-spacing: 0.05em;
}
@media only screen and (min-width: 768px), print {
  .saitama .frame .txt_area a {
    font-size: 0.875rem;
  }
}

@media only screen and (min-width: 768px), print {
  .c-section__lead p.center {
    text-align: center;
  }
}

.c-section__supplement {
  font-size: 1rem;
  margin: 3rem 4.16666rem 0;
  letter-spacing: 0.05em;
  line-height: 2;
}
@media only screen and (min-width: 768px), print {
  .c-section__supplement {
    font-size: 0.875rem;
    margin: 1rem auto 0;
    width: 32.5rem;
  }
}

@media only screen and (min-width: 768px), print {
  .p-training__section.various {
    width: 100%;
    max-width: 100%;
    flex-basis: 100%;
    display: flex;
    justify-content: space-between;
  }
  .p-training__section.various .p-training__title {
    text-align: left;
    width: 15rem;
    justify-content: flex-start;
  }
  .p-training__section.various .p-training__text {
    width: 40rem;
  }
}
.p-training__section.various ul {
  margin-top: 0.5rem;
}
.p-training__section.various ul li {
  text-indent: -0.5rem;
  padding-left: 0.5em;
}
@media only screen and (min-width: 768px), print {
  .p-training__section.various ul li {
    text-indent: 0;
    padding-left: 0;
    display: flex;
  }
}
.p-training__section.various ul li .tit {
  display: inline;
}
@media only screen and (min-width: 768px), print {
  .p-training__section.various ul li .tit {
    width: 150px;
  }
}
.p-training__section.various ul li .txt {
  display: inline;
}
@media only screen and (min-width: 768px), print {
  .p-training__section.various ul li .txt {
    float: 1;
  }
}

.sp_only {
  display: block;
}
@media only screen and (min-width: 768px), print {
  .sp_only {
    display: none;
  }
}

.pc_only {
  display: none;
}
@media only screen and (min-width: 768px), print {
  .pc_only {
    display: block;
  }
}