@charset "UTF-8";
/* メディアクエリ
==================================== */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
  display: block;
}

img {
  border: none;
  vertical-align: bottom;
}

a {
  text-decoration: none;
  cursor: pointer;
}

input,
button,
textarea,
select {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* デフォルトスタイルをリセット */
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
  color: inherit;
  font-size: 16px;
  font-family: inherit;
}

label {
  cursor: pointer;
}

/* フォームリセット */
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  border-radius: 0;
  outline: none;
  background: transparent;
  font: inherit;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

main {
  overflow: hidden;
}

html {
  min-height: 100vh;
}

body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 100vh;
  color: #333333;
  font-weight: 400;
  line-height: 1.6;
  font-family: "Noto Sans JP", sans-serif;
}

main {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

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

a {
  color: inherit;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.inner {
  width: 100%;
  max-width: 600px;
  margin-right: auto;
  margin-left: auto;
  padding-right: 15px;
  padding-left: 15px;
}

.btn {
  color: #FFF;
}

.btn a {
  display: grid;
  position: relative;
  place-items: center;
  width: 60%;
  min-height: 5.1rem;
  margin-inline: auto;
  padding: 0.5em 1rem;
  background-image: -webkit-gradient(linear, left top, right top, from(#147BD0), color-stop(51%, #8CB9DE), to(#147BD0));
  background-image: linear-gradient(90deg, #147BD0 0%, #8CB9DE 51%, #147BD0 100%);
  background-size: 200% auto;
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 2.4285714286;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

.btn a::after {
  position: absolute;
  top: 50%;
  right: 1.5rem;
  width: 7px;
  height: 12px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/arrow_btn.webp) no-repeat center center/contain;
  content: "";
}

.pankuz {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 5rem;
  padding: 0.5em 0;
  border-top: 1px solid #CCCCCC;
  color: #06233B;
  text-align: left;
}

.pankuz__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.pankuz a {
  margin-right: 0.5rem;
  font-size: 1.4rem;
}

.post {
  margin-left: 0.5rem;
}

.pankuz .current-item {
  margin-left: 0.5rem;
  font-size: 1.4rem;
}

.pankuz .pankuz__arrow {
  display: inline-block;
  width: 7px;
}

.date-year,
.taxonomy,
.post-works-archive {
  margin-left: 0.5rem;
}

.post-interview-archive {
  margin-left: 0.5rem;
  font-size: 1.4rem;
}

.section {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.section__title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  font-weight: 600;
  text-align: center;
}

.section__en {
  -webkit-transform: rotate(-7.7deg);
          transform: rotate(-7.7deg);
  color: #E7F0F6;
  font-weight: 400;
  font-size: 5rem;
  font-family: "Ephesis", serif;
}

.section__jp {
  margin-top: -2rem;
  color: #06233B;
  font-weight: 700;
  font-size: 3rem;
  font-family: "Shippori Mincho", serif;
}

.section__title-white {
  color: #FFF;
}

.section__sub-jp {
  color: #06233B;
  font-weight: 700;
  font-size: 2.2rem;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.03em;
}

.section__title-left {
  margin-inline: initial;
  padding-left: 1rem;
  text-align: left;
}

.subPage__top {
  padding-top: 2rem;
}

.subPage__title {
  font-size: 2.4rem;
  letter-spacing: 0.03em;
}

.subPage__title-white .subPage__en,
.subPage__title-white .subPage__jp {
  color: #FFF;
}

.subPage__en {
  color: #177DD0;
  font-family: "Ephesis", serif;
  text-align: center;
}

.subPage__en-capitalize {
  text-transform: capitalize;
}

.subPage__jp {
  color: #06233B;
  font-weight: 700;
  font-size: 2.2rem;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.03em;
  text-align: center;
}

.subPage__jp.subPage__jp-white {
  color: #FFF;
}

.subPage__text {
  color: #686868;
  font-size: 1.4rem;
  line-height: 180%;
}

.text {
  font-size: 1.4rem;
  line-height: 1.8;
}

.text__bold {
  font-weight: 700;
}

.text__center {
  text-align: center;
}

.about {
  position: relative;
  padding-top: 5rem;
  padding-top: 5rem;
  background: #06233B;
  letter-spacing: 0.03em;
}

.about::after {
  position: absolute;
  top: 99.8%;
  left: 0;
  width: 100%;
  height: 10rem;
  background: url(../img/bg_about.webp) no-repeat center center/cover;
  content: "";
}

.about__items {
  display: grid;
  gap: 3rem;
}

.about__items:nth-child(2) {
  margin-top: 3rem;
}

.about__item {
  display: grid;
  position: relative;
  padding: 2rem 2rem 3rem;
  gap: 1rem;
  background: #FFF;
  text-align: center;
}

.about__items:nth-child(1) .about__image {
  margin-top: 2rem;
}
.about__items:nth-child(1) .about__item:nth-child(1)::after,
.about__items:nth-child(1) .about__item:nth-child(2)::after {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  content: "※ 2024年度";
  color: #686868;
  font-size: 1.4rem;
}

.about__label {
  color: #06233B;
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.5;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.03em;
}

.about__value {
  margin-top: auto;
  color: #06233B;
  font-weight: 700;
  font-size: 2rem;
  text-align: center;
  white-space: nowrap;
}
.about__value span {
  font-size: 6rem;
}
.about__value .white__label {
  text-shadow: 9px 9px 0 #FFF, -9px -9px 0 #FFF, -9px 9px 0 #FFF, 9px -9px 0 #FFF, 0px 9px 0 #FFF, -9px 0 #FFF, -9px 0 0 #FFF, 9px 0 0 #FFF;
}

.about__value-sales {
  margin-top: -6rem;
  font-size: 4rem;
}
.about__value-sales span {
  margin-right: 2rem;
  font-size: 10rem;
  line-height: 100%;
}

.about__value-client {
  margin-top: -4rem;
}
.about__value-client span {
  margin-right: 1rem;
  font-size: 8rem;
  line-height: 100%;
}

.about__value-center {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10%;
}
.about__value-center span {
  line-height: 110%;
}

.about__value-end span {
  margin-right: 0.5rem;
}

.about__items:nth-child(2) .about__item {
  padding: 2rem;
  gap: 1.9rem;
}
.about__items:nth-child(2) .about__value {
  font-size: 2rem;
}
.about__items:nth-child(2) .about__value span {
  line-height: 120%;
}

.aboutTop {
  padding-bottom: 5rem;
}

.aboutTop__title {
  text-align: center;
}

.aboutTop__text {
  margin-top: 3rem;
  color: #686868;
  font-size: 1.4rem;
  line-height: 180%;
  letter-spacing: 0.03em;
}

.archive__section {
  padding-bottom: 6rem;
  font-weight: 500;
  font-family: "Shippori Mincho", serif;
}

.archive__items {
  display: grid;
  gap: 5rem;
}

.archive__item {
  display: grid;
}

.archive__image {
  aspect-ratio: 540/371;
}
.archive__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.archive__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 5rem;
  padding: 0.5em 1.5rem;
  background: #d5dee4;
  font-weight: 600;
  font-size: 1.8rem;
  font-family: "Roboto", serif;
}

.archive__info {
  margin-top: 1rem;
  padding-left: 2rem;
}

.archive__qualification {
  color: #122A88;
  line-height: 180%;
}

.archive__name {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-top: 1rem;
  gap: 2rem;
  font-size: 2.4rem;
  line-height: 1.125;
}
.archive__name span {
  display: inline-block;
  color: #7D7D7D;
  font-size: 1.4rem;
}

.archive__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 2rem;
  padding-right: 2rem;
}

.archive__btn a {
  width: 18rem;
  min-height: 3.5rem;
  font-family: "Noto Sans JP", sans-serif;
}

.archiveJob__items {
  display: grid;
  gap: 3rem;
}

.archiveJob__item {
  border: 1px solid #62707b;
}

.archiveJob__content {
  padding: 1rem 1.5rem 2rem;
}

.archiveJob__title {
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 180%;
}

.archiveJob__category {
  display: grid;
  place-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 9rem;
  min-height: 3rem;
  padding: 0.3em 0.5em;
  background: #177DD0;
  color: #FFF;
  font-size: 1.2rem;
  line-height: 150%;
}

.archiveJob__text {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin-top: 1rem;
}

.archive__salary {
  color: #122A88;
  font-weight: 700;
  font-size: 1.4rem;
  text-align: right;
}
.archive__salary span {
  font-size: 2.4rem;
}

.archiveJob__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 2rem;
}

.benefits {
  letter-spacing: 0.03em;
}

.benefits__items {
  display: grid;
  margin-top: 3rem;
  gap: 2rem;
}

.benefits__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  padding: 2rem 1.5rem;
  gap: 2rem;
  background: #147bd0;
  color: #FFF;
}

.benefits__title {
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 180%;
  text-align: center;
}

.benefits__item:last-child .benefits__title {
  line-height: 1.25;
}

.benefits__text {
  color: #FFF;
  letter-spacing: 0;
}

.career {
  padding-top: 6rem;
  padding-bottom: 6rem;
  font-family: "Shippori Mincho", serif;
}

.career__title {
  font-weight: 600;
  font-size: 2.4rem;
  font-family: "Roboto", serif;
  text-align: center;
}

.career__text {
  margin-top: 3rem;
}

.career__image {
  margin-top: 2rem;
}

.company {
  position: relative;
  margin-top: 8rem;
  padding-top: 5rem;
  padding-bottom: 8rem;
}

.company__items {
  display: grid;
  padding: 3rem 1rem;
  gap: 2rem;
  color: #686868;
}

.company__item {
  display: grid;
  grid-template-columns: 38% 63%;
  grid-template-columns: 35% 65%;
  padding-right: 0.2em;
  padding-left: 0.2em;
}

.company__item {
  padding-bottom: 2rem;
  border-bottom: 1px solid #ccc;
}

.company__label {
  font-weight: 700;
  font-size: 1.6rem;
}

.company__value {
  font-size: 1.4rem;
  line-height: 180%;
}
.company__value span {
  display: none;
}

.company__text-bold {
  font-weight: 700;
}

.company__map {
  width: 100%;
  height: 20rem;
  margin-top: 3rem;
}

.company__map iframe {
  width: 100%;
  height: 100%;
}

.companyAbout {
  padding-top: 6rem;
  font-family: "Shippori Mincho", serif;
}

.companyAbout__wrapper {
  position: relative;
  margin-top: 4rem;
  padding-top: 7rem;
  padding-bottom: 6rem;
  background: #EBEBEB;
}

.companyAbout__title {
  display: grid;
  position: absolute;
  top: -2.25rem;
  left: 50%;
  place-items: center;
  width: 29rem;
  min-height: 5rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: #D5DEE4;
  font-weight: 700;
  font-size: 2rem;
  text-align: center;
}

.companyAbout__title.fade.is-active {
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.companyAbout__items {
  display: grid;
  gap: 3rem;
}

.companyAbout__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 2rem;
  gap: 2rem;
  background: #FFF;
}

.companyAbout__label {
  font-weight: 700;
  font-size: 2rem;
  text-align: center;
}

.companyAbout__label.companyAbout__label-center {
  text-align: center;
}

.companyAbout__item:nth-child(2) .companyAbout__content {
  display: grid;
  grid-template-columns: 13rem 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4rem;
}
.companyAbout__item:nth-child(3) .companyAbout__content {
  display: grid;
  gap: 4rem;
}
.companyAbout__item:nth-child(4) .companyAbout__content {
  display: grid;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 4rem;
}

.companyAbout__attention {
  margin-left: -2em;
  font-weight: 700;
  font-size: 1.4rem;
}

.companyAbout__number {
  font-weight: 700;
  font-size: 1.8rem;
  text-align: center;
  white-space: nowrap;
}
.companyAbout__number span {
  font-size: 6rem;
}

.companyAbout__value {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
  text-align: center;
}

.companyAbout__text {
  margin-bottom: 2rem;
  color: #999999;
  font-size: 1.4rem;
  line-height: 2.25;
}

.companyPage__head {
  font-weight: 600;
  font-size: 2.4rem;
  line-height: 1.5625;
  font-family: "Roboto", serif;
  text-align: center;
  text-align: center;
}

.contact__heading {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 2.2222222222;
  text-align: left;
}

.contactForm {
  padding-top: 6rem;
  padding-bottom: 10rem;
  letter-spacing: 0.03em;
}

.contactForm__flows {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-top: 2.2rem;
  gap: 0 12.6rem;
  font-weight: 500;
}

.contactForm__flows::before {
  z-index: -2;
  position: absolute;
  top: 1px;
  left: 50%;
  width: 29.5rem;
  height: 4px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: -webkit-gradient(linear, left top, right top, from(#147bd0), to(#61a3d9));
  background: linear-gradient(to right, #147bd0, #61a3d9);
  content: "";
}

.contactForm__flow {
  position: relative;
  color: #686868;
  font-size: 1.4rem;
  -webkit-font-feature-settings: initial;
          font-feature-settings: initial;
  letter-spacing: initial;
  letter-spacing: 0.03em;
}

.contactForm__flow::before {
  position: absolute;
  top: -3.2rem;
  left: 50%;
  width: 2.4rem;
  height: 2.4rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  border-radius: 50%;
  background: #147bd0;
  content: "";
}

.contactForm__flow.is-active {
  color: #06233B;
  font-weight: 700;
}

.contactForm__flow.is-active::before {
  width: 2.4rem;
  height: 2.4rem;
  background: #147bd0;
}

.contactForm__flow.is-active::after {
  z-index: -1;
  position: absolute;
  top: -3.5rem;
  left: 50%;
  width: 3rem;
  height: 3rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  border: 1px solid #147bd0;
  border-radius: 50%;
  background: #FFF;
  content: "";
}

.contactForm__items {
  display: grid;
  margin-top: 5rem;
  gap: 3rem;
}

.contactForm__item {
  display: grid;
  gap: 1rem;
}

.contactForm__labels label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  color: #06233B;
  font-weight: 700;
  font-size: 1.6rem;
}

.contactForm__required {
  color: #FF0404;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
}

.contactForm__answer {
  color: #06233B;
  font-size: 1.6rem;
  line-height: 180%;
}

.contactForm__answer-job {
  position: relative;
}

.contactForm__answer-job::after {
  position: absolute;
  top: 50%;
  right: 1.2rem;
  width: 2rem;
  height: 1.3rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: #62707b;
  content: "";
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
          clip-path: polygon(50% 100%, 0 0, 100% 0);
  pointer-events: none;
}

.contactForm__answer-job:has(.wpcf7-not-valid-tip):after {
  top: 30%;
}

.contactForm__serch {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding-left: 2em;
  gap: 2rem;
}
.contactForm__serch .wpcf7-form-control-wrap {
  width: 15rem;
}

.contactForm__serch::before {
  position: absolute;
  top: 50%;
  left: 0.5em;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "〒";
  font-size: 1.6rem;
}

.contactForm__serch-btn {
  display: grid;
  place-items: center;
  width: 10rem;
  height: 100%;
  padding: 0.5em 1em;
  background: #147bd0;
  color: #FFF;
  font-weight: 400;
  font-size: 1.6rem;
  letter-spacing: 0.03em;
  cursor: pointer;
}

.contactForm__answer-address {
  display: grid;
  gap: 2rem;
}

.contactForm__rule {
  height: 20rem;
  padding: 3rem 1.5rem;
  overflow: scroll;
  border: 1px solid #373737;
  border-radius: 6px;
  color: #686868;
  word-break: break-all;
}

.contactForm__agree {
  margin-top: 3rem;
  color: #686868;
  font-weight: 500;
  font-size: 1.6rem;
  text-align: center;
}
.contactForm__agree a {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.contactForm__btns {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 3rem;
  gap: 2rem;
}

.contactForm__btn {
  margin-top: 6rem;
  text-align: center;
}

.contactForm__btns .contactForm__btn {
  margin-top: initial;
}
.contactForm__btns .contactForm__btn input {
  width: 80%;
}

.contactForm__btn input {
  width: 60%;
  min-height: 5rem;
  background-image: -webkit-gradient(linear, left top, right top, from(#147BD0), color-stop(51%, #8CB9DE), to(#147BD0));
  background-image: linear-gradient(90deg, #147BD0 0%, #8CB9DE 51%, #147BD0 100%);
  background-size: 200% auto;
  color: #FFF;
  font-weight: 700;
  font-size: 1.6rem;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

.contactForm__btn.contactForm__btn-return input {
  border: initial;
  background: #62707b;
  background-image: -webkit-gradient(linear, left top, right top, from(#515151), color-stop(51%, #797979), to(#515151));
  background-image: linear-gradient(90deg, #515151 0%, #797979 51%, #515151 100%);
  background-size: 200% auto;
  color: #FFF;
}

.contactForm__title {
  margin-top: 4rem;
  font-weight: 600;
  font-size: 2rem;
  line-height: 1.3571428571;
  text-align: center;
}

.contacForm__thanks {
  margin-top: 3rem;
  letter-spacing: initial;
  text-align: center;
}

.contacForm__return {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5rem;
}

.contacForm__return.btn a::after {
  display: none;
}

input[type=text],
input[type=email],
input[type=tel],
select,
textarea {
  width: 100%;
  padding: 7px 20px;
  border: 1px solid #147bd0;
  border-radius: 6px;
  background: #e7f0f6;
  color: #333333;
  color: #06233B;
  font-size: 1.6rem;
}

textarea {
  height: 18rem;
}

::-webkit-input-placeholder {
  color: #bbbbbb;
}

::-moz-placeholder {
  color: #bbbbbb;
}

:-ms-input-placeholder {
  color: #bbbbbb;
}

::-ms-input-placeholder {
  color: #bbbbbb;
}

::placeholder {
  color: #bbbbbb;
}

.wpcf7-list-item {
  margin: initial;
}

/* チェックボックスとラジオボタンここから */
.wpcf7-form-control.wpcf7-radio {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 1rem;
}

.wpcf7-list-item-label {
  position: relative;
  padding-left: 1.5em;
  color: #686868;
  font-weight: 700;
  font-size: 1.6rem;
  text-align: center;
}

/* チェック前のradioボタン */
.wpcf7-list-item-label::before {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.8rem;
  height: 1.8rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border: 2px solid #686868;
  border-radius: 100%; /* ラジオボタンっぽく丸くする */
  background: #FFF;
  content: "";
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s; /* 色をじんわり変化させる */
}
/* チェック後のボタン */
input[type=radio]:checked + .wpcf7-list-item-label::before,
input[type=checkbox]:checked + .wpcf7-list-item-label::before {
  background-color: #177DD0; /* チェック後の中心の色 */
  -webkit-box-shadow: inset 0 0 0 3px #fff;
          box-shadow: inset 0 0 0 3px #fff; /* 中心の色のスタイル */
}

div.wpcf7 .wpcf7-spinner {
  display: none !important;
}

.contact__form-thanks {
  margin-top: 5rem;
}

.contact__form-confirm dd {
  width: 100%;
  padding: 10px;
  padding: 2rem;
  border: #dddddd solid 1px;
  background: #fff;
  color: #177DD0;
  font-size: 1.6rem;
}

/* チェック前のcheckbox */
input[type=checkbox] + .wpcf7-list-item-label::before {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.6rem;
  height: 1.6rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border: 1px solid #ccc;
  border-radius: initial; /* ラジオボタンっぽく丸くする */
  background: #fff;
  content: "";
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s; /* 色をじんわり変化させる */
}

/* チェック後のcheckbox */
/* チェックボックスとラジオボタンここまで */
.contactForm__check .contactForm__answer {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 7px 20px;
  border: 1px solid #147bd0;
  border-radius: 6px;
  background: #e7f0f6;
}
.education {
  margin-top: 5rem;
  padding-top: 10rem;
  letter-spacing: 0.03em;
}

.eduaction__wrapper {
  display: grid;
  margin-top: 4rem;
  gap: 4rem;
}

.education__year {
  display: grid;
  place-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-height: 5rem;
  padding: 0.3em 2.5rem;
  background: -webkit-gradient(linear, left top, right top, from(#147bd0), to(#61a3d9));
  background: linear-gradient(to right, #147bd0, #61a3d9);
  color: #FFF;
  font-weight: 700;
  font-size: 1.6rem;
}

.education__inner {
  display: grid;
  grid-template-columns: 1fr 90%;
  margin-top: 3rem;
  gap: 1.5rem;
}

.education__contents {
  display: grid;
  gap: 1.5rem;
}

.education__graph {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
  letter-spacing: 0.3em;
  will-change: height;
}

.education__month:nth-child(1) {
  height: 14.8rem;
}

.education__month:nth-child(2) {
  height: 100%;
}

.education__month {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  font-weight: 500;
  font-size: 1.6rem;
  text-orientation: upright;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
.education__month span {
  margin-left: 0.2rem;
  font-size: 2rem;
  text-align: center;
  text-combine-upright: all;
}

.education__month:nth-child(1) {
  position: relative;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: #5fa2d9;
}

.education__month:nth-child(1)::after {
  position: absolute;
  top: 99.8%;
  left: 0;
  width: 100%;
  height: 1.5rem;
  background: #5fa2d9;
  content: "";
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
          clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.education__month:nth-child(2) {
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding-bottom: 3rem;
  background: -webkit-gradient(linear, left top, left bottom, from(#bdcbd8), to(#314b5f));
  background: linear-gradient(#bdcbd8, #314b5f);
  color: #FFF;
}

.education__start {
  display: grid;
  place-items: center;
  min-height: 5rem;
  background: #5fa2d9;
  color: #06233B;
  font-weight: 500;
  font-size: 1.8rem;
}

.education__second {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 1.3rem;
  gap: 1.3rem;
  font-weight: 500;
  font-size: 1.8rem;
}
.education__second div {
  display: grid;
  place-items: center;
  min-height: 5rem;
  background: #b3d4ef;
  color: #06233B;
}

.education__job {
  padding: 2rem;
  background: #06233B;
  color: #FFF;
}

.education__container {
  display: grid;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
}

.education__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.education__title {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.5;
}

.education__text {
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 180%;
}

.education__label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 2rem;
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0;
  text-align: center;
  text-align: center;
}
.education__label span {
  padding: 0 1.5rem;
}

.education__label::before,
.education__label::after {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin: 0 10px;
  border-top: 1px solid #62707b;
  content: "";
}

.education__items {
  display: grid;
  width: 85%;
  margin-top: 2rem;
  margin-inline: auto;
  gap: 4rem;
}

.education__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: 12rem;
  background: #FFF;
  color: #06233B;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 180%;
  text-align: center;
}
.education__item span {
  display: inline;
  font-size: 1.2rem;
}

.education__item:not(:last-child)::after {
  position: absolute;
  bottom: -3rem;
  left: 50%;
  width: 1.3rem;
  height: 2.4rem;
  -webkit-transform: translateX(-50%) rotate(90deg);
          transform: translateX(-50%) rotate(90deg);
  background: url(../img/arrow_education.webp) no-repeat center center/contain;
  content: "";
}

.education__number {
  position: absolute;
  top: 1rem;
  left: 1rem;
  font-weight: 500;
  font-size: 1.8rem;
}

.education__before {
  width: 90%;
  margin-inline: auto;
  padding: 1rem;
  border: 2px dashed #06233B;
  font-size: 1.4rem;
  line-height: 180%;
}

.education__rules {
  display: grid;
  gap: 5rem;
}

.education__rule {
  position: relative;
  padding: 2rem 1.5rem;
  background: #147bd0;
  color: #FFF;
}
.education__rule h4 {
  font-weight: 700;
  font-size: 2rem;
}

.education__rule::after {
  position: absolute;
  top: 99.9%;
  left: 0;
  width: 100%;
  height: 2.7rem;
  background: #147bd0;
  content: "";
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
          clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.education__rule-items {
  display: grid;
  margin-top: 2rem;
  gap: 2rem;
}

.education__rule-item h5 {
  display: grid;
  place-items: center;
  width: 11.4rem;
  min-height: 3.7rem;
  border: 1px solid #FFF;
  font-size: 1.6rem;
}
.education__rule-item p {
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 1.7142857143;
}

.education__job-middle {
  margin-top: 4rem;
}

.event {
  margin-top: 5rem;
  padding-top: 5rem;
  padding-bottom: 10rem;
  background: #06233B;
}

.event__head {
  text-align: center;
}

.event__items {
  display: grid;
  margin-top: 4rem;
  gap: 2rem;
}

.event__circle {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  aspect-ratio: 1/1;
  width: 80%;
  margin-inline: auto;
  gap: 1.8rem;
  border-radius: 100%;
  background: #FFF;
}

.event__title {
  color: #06233B;
  font-weight: 500;
  font-size: 2rem;
  text-align: center;
}

.event__text {
  margin-top: 2rem;
  color: #FFF;
}

.fade {
  visibility: hidden;
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
  /*追加*/
  opacity: 0;
  -webkit-transition: all 1.5s;
  transition: all 1.5s;
}

.fade.is-active {
  visibility: visible;
  /*元の位置に戻す*/
  -webkit-transform: translateY(0);
          transform: translateY(0);
  /*要素を表示させる*/
  opacity: 1;
}

.flow {
  padding-top: 5rem;
}

.flow__items {
  display: grid;
  margin-top: 3rem;
  gap: 3rem;
}

.flow__item {
  display: grid;
  grid-template-columns: 18% 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
}

.flow__time {
  text-align: center;
}
.flow__time p {
  margin-top: 0.5rem;
  color: #06233B;
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.03em;
}

.flow__container {
  display: grid;
  gap: 1rem;
}

.flow__image {
  aspect-ratio: 200/130;
}
.flow__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.flow__title {
  color: #06233B;
  font-weight: 500;
  font-size: 2rem;
}

.flow__text {
  margin-top: 0.5rem;
}

.footer {
  position: relative;
  padding-top: 6.7rem;
  padding-bottom: 3.6rem;
  background: #06233B;
  color: #FFF;
}

.footer__container {
  display: grid;
  gap: 3rem;
}

.footer__logo {
  width: 8.5rem;
}
.footer__logo a {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 100%;
}

.footer__logo a::after {
  position: absolute;
  top: 50%;
  left: 115%;
  width: 100%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "採用サイト";
  color: #FFF;
  font-weight: 700;
  font-size: 1.2rem;
}

.footer__address {
  margin-top: 2.5rem;
}

.footer__right {
  display: grid;
  gap: 1.5rem;
}

.footer__items {
  display: grid;
  gap: 1.5rem;
}

.footer__item a {
  position: relative;
}

.footer__bottom {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  margin-top: 2rem;
}

.footer__text {
  margin-top: 5rem;
  font-weight: 500;
  font-size: 1.2rem;
  font-family: "Inter", serif;
  text-align: center;
}

.footer__corporate {
  font-size: 1.4rme;
}
.footer__corporate a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.7rem;
}

.fv {
  position: relative;
  width: 100vw;
  margin-top: 6rem;
}

.fv__image {
  position: relative;
}

.fv__image::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.1);
  content: "";
}

.fv img {
  width: 100%;
}

.fv__content {
  z-index: 2;
  position: absolute;
  top: 50%;
  left: 2rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  color: #FFF;
}

.fv__copy {
  position: relative;
  width: 25rem;
}

.fv__copy::after {
  position: absolute;
  top: 100%;
  top: 88%;
  right: 0;
  right: -4.5rem;
  -webkit-transform: rotate(-8deg);
          transform: rotate(-8deg);
  content: "be yourself";
  font-weight: 400;
  font-size: 4rem;
  font-family: "Ephesis", serif;
  letter-spacing: 0.03em;
}

.fv .youtube {
  position: absolute;
  right: 1rem;
  bottom: -2.7rem;
}
.fv .youtube a {
  display: block;
  width: 18rem;
  padding: 1.2rem;
  border-radius: 23px;
  background: #FFF;
  -webkit-box-shadow: 4px 4px 10px rgba(6, 35, 59, 0.15);
          box-shadow: 4px 4px 10px rgba(6, 35, 59, 0.15);
}
.fv .youtube a:hover {
  opacity: 1;
}
.fv .youtube__title {
  font-weight: 700;
  font-size: 1.2rem;
  text-align: center;
}
.fv .youtube__image {
  margin-top: 0.5rem;
}

.fv {
  /* paeination */
  /* 標準のボーダー削除 */
}
.fv .your-class-pagination {
  z-index: 10;
  top: 90%;
  right: initial;
  bottom: initial;
  left: 4rem;
  padding: initial;
  gap: 1rem;
}
.fv .your-class-page {
  width: 12px;
  height: 12px;
  border: 2px solid #FFF;
  background: transparent;
  opacity: 1;
}
.fv .your-class-page.is-active {
  -webkit-transform: initial;
          transform: initial;
  background: #FFF;
  opacity: 1;
}
.fv .splide__track--nav > .splide__list > .splide__slide.is-active,
.fv .splide__track--nav > .splide__list > .splide__slide {
  padding: 0.2rem;
  border: initial;
}

.fvSub {
  position: relative;
}

.fvSub__image {
  position: relative;
  aspect-ratio: 1300/423;
  width: 100%;
  height: 20rem;
}

.fvSub__image img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.fvSub__title {
  display: grid;
  position: absolute;
  bottom: 2rem;
  left: 1rem;
  place-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-height: 6rem;
  padding: 0.3em 0.5em;
  background: -webkit-gradient(linear, left top, right top, from(#147bd0), to(#61a3d9));
  background: linear-gradient(to right, #147bd0, #61a3d9);
  color: #FFF;
  font-weight: 700;
  font-size: 2.6rem;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.03em;
  text-align: center;
  text-transform: capitalize;
}

.group {
  margin-top: 15rem;
  padding-bottom: 10rem;
}

.group__text {
  margin-top: 3rem;
}

.group__items {
  display: grid;
  margin-top: 3rem;
  gap: 2rem;
}

.group__item a {
  display: inline-block;
  position: relative;
}

.group__title {
  position: absolute;
  top: 50%;
  left: 2rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  color: #FFF;
  font-weight: 700;
  font-size: 2.4rem;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.03em;
}

/* ハンバーガーメニュー */
/*==================================================
　5-2-6 3本線が回転して×に
===================================*/
.hamburger {
  z-index: 10000;
  position: relative;
  position: fixed;
  top: 2rem;
  right: 2rem;
  width: 3rem;
  height: 1.8rem;
  cursor: pointer;
}

/*ボタン内側*/
.hamburger span {
  display: inline-block;
  position: absolute;
  right: 0;
  width: 2.5rem;
  height: 2px;
  background: #06233B;
  -webkit-transition: all 0.4s;
  transition: all 0.4s; /*アニメーションの設定*/
}

.hamburger span:nth-of-type(1) {
  top: 35%;
  top: 0;
}

.hamburger span:nth-of-type(2) {
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.hamburger span:nth-of-type(3) {
  bottom: 0;
}

/*activeクラスが付与されると線が回転して×になる*/
.hamburger.active span {
  top: 50%;
  left: 50%;
  width: 20px;
}

.hamburger.active span:nth-of-type(1) {
  -webkit-transform: translate(-50%, -50%) rotate(-135deg);
          transform: translate(-50%, -50%) rotate(-135deg);
}

.hamburger.active span:nth-of-type(2) {
  opacity: 0;
}

.hamburger.active span:nth-of-type(3) {
  -webkit-transform: translate(-50%, -50%) rotate(135deg);
          transform: translate(-50%, -50%) rotate(135deg);
}

.header {
  z-index: 1000;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 6rem;
  background: transparent;
  background: #FFF;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.header__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: inherit;
  padding-left: 1rem;
}

.header__logo {
  z-index: 1000;
  position: relative;
  width: 7rem;
}

.header__logo a {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 100%;
}

.header__logo a::after {
  position: absolute;
  top: 50%;
  left: 115%;
  width: 100%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "採用サイト";
  color: #333333;
  font-weight: 700;
  font-size: 1.2rem;
}

.header__nav {
  display: none;
}

.header__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: inherit;
  gap: 3.9rem;
}

.header__item {
  position: relative;
  height: inherit;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.header__item a,
.header__item p {
  display: grid;
  place-items: center;
  height: inherit;
  font-weight: 700;
  font-size: 1.6rem;
  cursor: pointer;
}

.header__entries {
  display: none;
}

.header__entry a {
  display: grid;
  position: relative;
  place-items: center;
  width: 15rem;
  height: 14rem;
  background: #06233B;
}

.header__entry:nth-child(2) a {
  background: #147BD0;
}

.header__entry span {
  margin-top: -4rem;
}

.header__entry a::after {
  position: absolute;
  top: 65%;
  left: 50%;
  width: 2.1rem;
  height: 2.7rem;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: url(../img/icon_guide.webp) no-repeat center center/contain;
  content: "";
}

.header__entry:nth-child(2) a::after {
  width: 2.7rem;
  height: 2.8rem;
  background: url(../img/icon_entry.webp) no-repeat center center/contain;
}

.header__recruit {
  margin-left: 3rem;
}

.header__recruit a {
  width: 14rem;
  border: 1px solid #FFF;
}

.headerSp {
  visibility: hidden;
  z-index: 120;
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  height: 100%;
  padding-bottom: 10rem;
  overflow: scroll;
  background: #33394b;
  background: #FFF;
  color: #06233B;
  /* これで右に隠す↓↓ */
  opacity: 0;
  -webkit-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
}

.headerSp.is-openSP {
  visibility: visible;
  z-index: 999;
  opacity: 1;
}

.headerSp__nav {
  width: 100%;
  margin-top: 8rem;
  padding-right: 2rem;
  padding-left: 2rem;
}

.headerSp__items {
  display: grid;
  gap: 2rem;
}

.headerSp__item {
  position: relative;
  padding: 0 0.5em;
  border-bottom: 1px solid #dddddd;
}

.headerSp__item {
  width: 100%;
  height: 100%;
  padding-bottom: 2rem;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1;
}

.headerSp__item a {
  display: inline-block;
  width: 100%;
}

.headerSp__btns {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 3rem;
  padding: 0 15px;
  gap: 2rem;
}

.headerSp__btn.btn a {
  width: 100%;
}

.history {
  padding-bottom: 6rem;
}

.history__items {
  display: grid;
  margin-top: 3rem;
  gap: 1.6rem;
  letter-spacing: 0.03em;
}

.history__item {
  display: grid;
  padding: 1rem;
  gap: 0.5rem;
  border: 1px solid #06233b;
  border-radius: 6px;
  font-size: 1.4rem;
  line-height: 180%;
}

.history__year {
  color: #06233b;
  font-weight: 700;
}

.history__content {
  color: #686868;
}

.interview {
  padding-bottom: 10rem;
}

.inerview__lists {
  display: grid;
  gap: 4rem;
}

.interview__top {
  display: grid;
  gap: 1rem;
}

.interview__position {
  color: #686868;
  font-size: 1.4rem;
}

.interview__name {
  margin-top: -0.5rem;
  color: #06233B;
  font-weight: 500;
  font-size: 2.4rem;
}

.interview__items {
  display: grid;
  gap: 1rem;
}

.interview__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  display: grid;
  grid-template-columns: 20% 1fr;
}

.interview__label {
  color: #06233B;
  font-weight: 500;
  font-size: 1.4rem;
}

.interview__value {
  color: #686868;
  font-size: 1.4rem;
}

.interview__image {
  margin-top: 1.5rem;
}

.interviewDetail__items {
  display: grid;
  margin-top: 3rem;
  gap: 3rem;
}

.interviewDetail__title {
  position: relative;
  padding-left: 3.5rem;
  color: #06233B;
  font-weight: 500;
  font-size: 1.6rem;
}

.interviewDetail__title::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 2.5rem;
  height: 1px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: #06233B;
  content: "";
}

.interviewDetail__text {
  margin-top: 1rem;
}

.jobDescription {
  position: relative;
  padding-top: 5rem;
  background: #06233B;
  color: #FFF;
}

.jobDescription::after {
  position: absolute;
  top: 99.8%;
  left: 0;
  width: 100%;
  height: 10rem;
  background: url(../img/bg_about.webp) no-repeat center center/cover;
  content: "";
}

.jobDescription__items {
  display: grid;
  margin-top: 3rem;
  gap: 3rem;
}

.jobDescription__item {
  display: grid;
  gap: 2rem;
}

.jobDescription__content {
  display: grid;
  gap: 1rem;
}

.jobDescription__title {
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.25;
}

.jobDescription__text.subPage__text {
  color: #FFF;
}

.loop__texts {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  z-index: -1;
  position: relative;
  gap: 1.4rem;
  color: #E7F0F6;
  font-weight: 600;
  font-size: 5rem;
  font-family: "Noto Serif", serif;
  white-space: nowrap; /* 改行させない */
  -webkit-animation: scroll-left 10s linear infinite;
          animation: scroll-left 10s linear infinite;
  pointer-events: none;
  /* パフォーマンス向上のため */
  will-change: transform;
}

.loop__text {
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0; /* 要素の幅が縮まらないようにする */
}

/* キーフレームの設定 */
/* ここでは全体幅の半分（テキスト1個分）だけ左に移動する */
@-webkit-keyframes scroll-left {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@keyframes scroll-left {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.megaMenu__btn {
  position: relative;
}

.megaMenu__items {
  visibility: hidden;
  position: absolute;
  top: 100%;
  left: 50%;
  width: 20rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  border: 1px solid #686868;
  background: #FFF;
  opacity: 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.megaMenu__items.is-active {
  visibility: visible;
  opacity: 1;
}

.megaMenu__item:last-child {
  border-top: 1px solid #686868;
}

.megaMenu__item a {
  position: relative;
  place-items: initial;
  padding: 1rem 2rem;
}

.megaMenu__item a::after {
  position: absolute;
  top: 50%;
  right: 2.1rem;
  width: 0.8rem;
  height: 0.8rem;
  -webkit-transform: translateY(-50%) rotate(-45deg);
          transform: translateY(-50%) rotate(-45deg);
  border-right: 2px solid #333333;
  border-bottom: 2px solid #333333;
  content: "";
}

.message {
  padding-bottom: 5rem;
  letter-spacing: 0.03em;
}

.message__top {
  display: grid;
  gap: 1.5rem;
}

.message__title {
  color: #06233B;
  font-weight: 600;
  font-size: 2rem;
  line-height: 1.5;
  font-family: "Shippori Mincho", serif;
}

.messsage__image {
  margin-top: 2.5rem;
}

.message__text {
  margin-top: 1.5rem;
}

.message__company {
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 180%;
  text-align: right;
}

.message__name {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-top: 1rem;
  gap: 1.3rem;
  color: #06233B;
  font-weight: 700;
  font-size: 1.4rem;
  font-family: "Shippori Mincho", serif;
  text-align: right;
}
.message__name span {
  font-size: 2rem;
}

.not-found {
  padding-bottom: 10rem;
}

.not-found__text {
  font-size: 1.8rem;
}

.not-found__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 4rem;
  text-align: center;
}

.other {
  z-index: 5;
  position: relative;
  max-width: 90%;
  margin-top: -8rem;
  margin-inline: auto;
  background: #FFF;
  -webkit-box-shadow: 2px 2px 24px rgba(0, 0, 0, 0.36);
          box-shadow: 2px 2px 24px rgba(0, 0, 0, 0.36); /* 距離: 2px, 角度: 90°, サイズ: 24px, 不透明度: 36% */
  font-family: "Shippori Mincho", serif;
}

.other__wrapper {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.other__items {
  display: grid;
  gap: 3rem;
}

.other__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 22rem;
  padding: 2rem;
  gap: 1.5rem;
  background: #ebebeb;
  text-align: center;
}

.other__title {
  font-weight: 700;
  font-size: 1.8rem;
}

.other__image {
  margin-top: auto;
}

.pagination {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 8rem;
  padding-bottom: 2rem;
  gap: 1.2rem;
  text-align: center;
}

.page-numbers {
  display: grid;
  place-items: center;
  width: 4rem;
  height: 4rem;
  border: 1px solid #177DD0;
  background: #FFF;
  color: #333333;
  font-weight: 400;
  font-size: 1.4rem;
  font-family: "Roboto", serif;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.page-numbers.current {
  background: #177DD0;
  color: #FFF;
  font-weight: 700;
  font-family: "Shippori Mincho", serif;
}

.prev span,
.next span {
  position: relative;
  width: 1.2rem;
  height: 1.2rem;
}

.prev span::after,
.next span::after {
  position: absolute;
  top: 50%;
  left: 35%;
  width: 1.2rem;
  height: 1.2rem;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
  border-right: 2px solid #177DD0;
  border-bottom: 2px solid #177DD0;
  content: "";
}

.prev span::after {
  left: 65%;
  -webkit-transform: translate(-50%, -50%) rotate(135deg);
          transform: translate(-50%, -50%) rotate(135deg);
}

.partner {
  position: relative;
  padding-top: 8rem;
  padding-bottom: 8rem;
}

.parter__container {
  position: relative;
  margin-top: 5rem;
}

.parter__container::after {
  z-index: -2;
  position: absolute;
  top: -15rem;
  left: 30%;
  width: 40rem;
  height: 30rem;
  background: url(../img/partner_blue.png) no-repeat center center/contain;
  content: "";
}

.partner__content {
  position: relative;
  margin-top: 2rem;
}

.partner__image {
  margin-top: 2rem;
}

.partner__title {
  display: grid;
  place-items: center;
  width: 90%;
  min-height: 5.5rem;
  margin-top: 3.5rem;
  margin-inline: auto;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  border-radius: 40px;
  background: #177DD0;
  color: #FFF;
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 0.04em;
  text-align: center;
}

.partner__items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 4rem;
  gap: 1.5rem;
}

.partner__item {
  display: grid;
  gap: 2rem;
}

.philosophy {
  position: relative;
  padding-top: 6rem;
  background: #06233B;
  color: #FFF;
  letter-spacing: 0.03em;
}

.philosophy::after {
  position: absolute;
  top: 99.8%;
  left: 0;
  width: 100%;
  height: 5rem;
  background: url(../img/bg_about.webp) no-repeat center center/cover;
  content: "";
}

.philosophy__items {
  display: grid;
  margin-top: 4rem;
  gap: 3rem;
}

.philosophy__item {
  display: grid;
  padding-bottom: 2rem;
  gap: 1rem;
  border-bottom: 1px solid #576673;
}

.philosophy__label {
  font-size: 2.2rem;
  line-height: 1.3571428571;
  font-family: "Shippori Mincho", serif;
}

.philosophy__value {
  font-size: 1.4rem;
  line-height: 180%;
}

.privacy {
  padding-bottom: 3rem;
}

.privacy__items {
  display: grid;
  margin-top: 4rem;
  gap: 4rem;
}

.privacy__item {
  display: grid;
  gap: 3rem;
}

.privacy__title {
  font-weight: 700;
  font-size: 2rem;
  line-height: 1;
}

.qa {
  padding-top: 5rem;
  padding-bottom: 6rem;
}

.qa__wrapper {
  display: grid;
  gap: 5rem;
}

.qa__items {
  display: grid;
  margin-top: 3rem;
  gap: 1.8rem;
}

.qa__question,
.qa__answer {
  padding: 1.4rem 3rem 1.4rem 1rem;
}

.qa__question {
  position: relative;
  background: #147bd0;
  color: #FFF;
  font-weight: 700;
  font-size: 1.4rem;
}

.qa__answer {
  display: none;
  background: #e7f0f6;
}

.qa__question::before,
.qa__question::after {
  display: block;
  position: absolute;
  top: 50%;
  right: 1rem;
  width: 15px;
  height: 1px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: #FFF;
  content: "";
}

.qa__question::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.qa__question.is-active::after {
  -webkit-transform: rotate(0);
          transform: rotate(0);
}

.qa__flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 1.5rem;
}
.qa__flex span {
  font-weight: 700;
  font-size: 2rem;
  font-family: "Shippori Mincho", serif;
  text-transform: uppercase;
}

.qa__question .qa__flex {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.recommend {
  padding-top: 5rem;
  padding-bottom: 10rem;
}

.recommend__container {
  padding: 3rem 2rem;
  border: 1px solid #dcdcdc;
}

.recommend__title {
  text-align: center;
}

.recommend__items {
  display: grid;
  margin-top: 3rem;
  gap: 2rem;
}

.recommend__item {
  position: relative;
  padding-left: 2.5em;
  color: #686868;
  font-size: 1.4rem;
  line-height: 180%;
  letter-spacing: 0.03em;
}

.recommend__item::after {
  position: absolute;
  top: 50%;
  left: 0;
  width: 2.5rem;
  height: 2.5rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/check_recommend.webp) no-repeat center center/contain;
  content: "";
}

.recruitment {
  position: relative;
  padding-top: 5rem;
  padding-bottom: 8rem;
}

.recruitment__bg {
  background: #e7f0f6;
}

.recruitment__last {
  padding-bottom: 10rem;
}

.recruitment__items {
  display: grid;
  padding: 3rem 1rem;
  gap: 2rem;
  color: #686868;
}

.recruitment__item {
  display: grid;
  grid-template-columns: 38% 63%;
  grid-template-columns: 35% 65%;
  padding-right: 0.2em;
  padding-left: 0.2em;
}

.recruitment__item {
  padding-bottom: 2rem;
  border-bottom: 1px solid #ccc;
}

.recruitment__label {
  font-weight: 700;
  font-size: 1.6rem;
}

.recruitment__value {
  font-size: 1.4rem;
  line-height: 180%;
}
.recruitment__value span {
  display: none;
}

.recruitment__text-bold {
  font-weight: 700;
}

.recruitment__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 3rem;
}

.single {
  font-weight: 500;
  font-family: "Shippori Mincho", serif;
}

.single__head {
  font-weight: 600;
  font-size: 2rem;
  line-height: 1.3157894737;
  font-family: "Roboto", serif;
  text-align: center;
}

.single__image {
  aspect-ratio: 1000/420;
  width: 100%;
  margin-top: 3rem;
}
.single__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.single__info {
  margin-top: 2rem;
}

.single__label {
  display: grid;
  place-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 10.8rem;
  min-height: 3.3rem;
  padding: 0 0.5em;
  background: #177DD0;
  color: #FFF;
  font-size: 1.4rem;
}

.archive__name.single__name {
  margin-top: 1rem;
}

.single__items {
  display: grid;
  margin-top: 3rem;
  padding: 3rem 1.5rem;
  gap: 4rem;
  background: #FFF;
  -webkit-box-shadow: 0px 2px 24px rgba(98, 98, 98, 0.36);
          box-shadow: 0px 2px 24px rgba(98, 98, 98, 0.36);
}

.single__title {
  padding-bottom: 1rem;
  border-bottom: 1px solid #999999;
  font-weight: 600;
  font-size: 2rem;
  line-height: 1.7857142857;
  font-family: "Roboto", serif;
}

.single__text {
  margin-top: 3rem;
}

.single__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5rem;
}

.singleJob {
  font-weight: 500;
  font-family: "Shippori Mincho", serif;
}

.singleJob__items {
  display: grid;
  gap: 4rem;
  background: #FFF;
}

.singleJob__title {
  padding-bottom: 1rem;
  border-bottom: 1px solid #999999;
  font-weight: 600;
  font-size: 2rem;
  line-height: 1.7857142857;
  font-family: "Roboto", serif;
}

.singleJob__text {
  margin-top: 3rem;
}

.singleJob__recruit {
  margin-top: 5rem;
}

.singleJob__lists {
  display: grid;
  margin-top: 2rem;
  gap: 2rem;
}

.singlJob__list {
  display: grid;
  padding-bottom: 2rem;
  gap: 1rem;
  border-bottom: 1px solid #62707b;
}

.singlJob__label {
  font-weight: 700;
  font-size: 1.6rem;
  font-size: 1.8rem;
}

.singleJob__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5rem;
}

.skill {
  position: relative;
  margin-top: 5rem;
  padding-top: 5rem;
  background: #06233B;
  color: #FFF;
}

.skill::after {
  position: absolute;
  top: 99.8%;
  left: 0;
  width: 100%;
  height: 10rem;
  background: url(../img/bg_about.webp) no-repeat center center/cover;
  content: "";
}

.skill__items {
  display: grid;
  margin-top: 3rem;
  gap: 3rem;
}

.skill__content {
  margin-top: 1rem;
}

.skill__title {
  font-weight: 700;
  font-size: 1.8rem;
}

.skill__text {
  margin-top: 1rem;
  color: #FFF;
}

.tab__inner {
  display: grid;
  gap: 2rem;
}

.tab__title {
  color: #06233B;
  font-weight: 500;
  font-size: 2rem;
}

.tab__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1.4rem;
}

@media (max-width: 900px) {
	.tab__items{
	align-content: flex-end;
    flex-wrap: wrap;
 }
}
.tab__item {
  width: 90%;
}

.tab__item a {
  display: grid;
  place-items: center;
  min-width: 16.8rem;
  min-height: 6rem;
  background-image: -webkit-gradient(linear, left top, right top, from(#147BD0), color-stop(51%, #8CB9DE), to(#147BD0));
  background-image: linear-gradient(90deg, #147BD0 0%, #8CB9DE 51%, #147BD0 100%);
  background-size: 200% auto;
  color: #FFF;
  font-weight: 700;
  font-size: 1.6rem;
}

.topActivitie {
  padding-top: 7rem;
  padding-bottom: 10rem;
}
.topActivitie .section__jp {
  position: relative;
}
.topActivitie .section__jp::before {
  position: absolute;
  bottom: 92%;
  left: 43%;
  -webkit-transform: rotate(-7.7deg) translateX(-50%);
          transform: rotate(-7.7deg) translateX(-50%);
  content: "activities";
  color: #E7F0F6;
  font-weight: 400;
  font-size: 5rem;
  font-family: "Ephesis", serif;
}

.topActivitie__container {
  display: grid;
}

.topActivitie__text {
  margin-top: 4rem;
  color: #575656;
}

.topActivitie__items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 2rem;
  gap: 1rem;
}

.topActivitie__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 85%;
  margin-inline: auto;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #B3B3B3;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.65;
}
.topActivitie__title span {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 2.3rem;
  height: 2.3rem;
}

.topInformation__items {
  margin-top: 4rem;
}

.topInformation__item {
  border-top: 1px solid #52687f;
}

.topInformation__item:last-child {
  border-bottom: 1px solid #52687f;
}

.topInformation__item a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 2rem 1.5rem;
  gap: 3rem;
}

.topInformatioin__time {
  font-weight: 700;
  font-size: 1.4rem;
}

.topInformation__title {
  margin-top: 0.5rem;
  font-weight: 400;
  font-size: 1.4rem;
}

.topInformation__arrow {
  width: 1rem;
  margin-left: auto;
}

.topInformation__btn {
  margin-top: 4rem;
}

.topInformation__btn a {
  margin-inline: auto;
}

.topInterview {
  padding-top: 6rem;
}

.topInterview__wrapper {
  position: relative;
  margin-top: -19%;
  padding-bottom: 10rem;
  border-radius: 0 0 250px 0;
  background: #06233B;
}

.topInterview__top {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background: #06233B;
}

.topInterview__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 6.5rem;
}

.topInterview__splide {
  margin-top: 3rem;
  color: #FFF;
}

.topInterview__image {
  position: relative;
  aspect-ratio: 433/310;
  margin-top: -2.2rem;
}
.topInterview__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topInterview__number {
  z-index: 5;
  position: relative;
  margin-left: 1rem;
  color: #FFF;
  font-weight: 500;
  font-size: 4rem;
  line-height: 1;
  font-family: "Roboto", serif;
  letter-spacing: 0.05em;
}

.topInterview__info {
  margin-top: 2rem;
  font-size: 1.4rem;
  line-height: 180%;
}

.topInterview__text {
  margin-top: 1rem;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 180%;
}

.topInterview {
  /* 矢印共通のスタイル */
  /* 前の矢印 */
  /* 次の矢印 */
}
.topInterview .splide__arrows {
  z-index: 5;
  position: relative;
  top: -7rem;
  right: 15px;
  width: 7rem;
  margin-left: auto;
}
.topInterview .splide__arrow--prev {
  left: 0;
}
.topInterview .splide__arrow--next {
  right: 0;
}
.topInterview .button {
  width: 3rem;
  height: 3rem;
  background-color: transparent; /* ボタンの背景を透明にする */
  opacity: 1;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.topInterview .button::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 3rem;
  height: 3rem;
  margin: auto;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  opacity: 1;
}
.topInterview .prev::before {
  background-image: url(../img/arrow_prev.webp);
}
.topInterview .next::before {
  background-image: url(../img/arrow_next.webp);
}

.topKnow {
  position: relative;
  padding-top: 6rem;
  padding-bottom: 6rem;
  background: url(../img/bg_topKnow.webp) no-repeat center center/cover;
  color: #FFF;
}

.topKnow__bg {
  aspect-ratio: 1300/1089;
  width: 100%;
  height: 100%;
}
.topKnow__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topKnow__items {
  display: grid;
  gap: 4rem;
}

.topKnow__item {
  display: grid;
  gap: 4rem;
}

.topKnow__item:not(:last-child) {
  padding-bottom: 4rem;
  border-bottom: 1px solid #B3B3B3;
}

.topKnow__title {
  position: relative;
}

.topKnow__jp {
  font-weight: 700;
  font-size: 2.8rem;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.06em;
}

.topKnow__en {
  position: absolute;
  bottom: -2rem;
  left: 5rem;
  -webkit-transform: rotate(-8deg);
          transform: rotate(-8deg);
  color: #B3B3B3;
  font-weight: 400;
  font-size: 2rem;
  font-family: "Ephesis", serif;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.topKnow__text {
  font-weight: 400;
}

.topKnow__btn {
  margin-top: 3.5rem;
}

.topLink {
  position: relative;
}

.topLink__heading {
  display: grid;
  z-index: 5;
  position: absolute;
  top: -3.5rem;
  left: 50%;
  place-items: center;
  width: 20rem;
  min-height: 7rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: #FFF;
  font-size: 4rem;
}

.topLink__head {
  z-index: 5;
  background: -webkit-gradient(linear, left top, right top, from(#147bd0), to(#61a3d9));
  background: linear-gradient(to right, #147bd0, #61a3d9);
  font-style: italic;
  font-family: "Roboto", serif;
  text-transform: capitalize;
  -webkit-background-clip: text;
  z-index: 5;
  position: relative;
  -webkit-text-fill-color: transparent;
}

.topLink__items {
  display: grid;
}

.topLink__item a {
  display: inline-block;
  position: relative;
}

.topLink__image {
  aspect-ratio: 650/500;
  width: 100%;
}
.topLink__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topLink__title {
  display: grid;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  font-weight: 500;
  text-align: center;
}
.topLink__en {
  color: #FFF;
  font-size: 1.2rem;
  font-family: "Roboto", serif;
  letter-spacing: 0.05em;
}

.topLink__en::first-letter {
  text-transform: capitalize;
}

.topLink__jp {
  color: #FFF;
  font-size: 2.4rem;
  text-align: center;
}

.topLink__arrow {
  margin-top: 1rem;
}

.topMember {
  padding-top: 5rem;
  padding-bottom: 6rem;
}

.topMember__splide {
  margin-top: 3rem;
}
.topMember__splide .splide__slide {
  position: relative;
}
.topMember__splide .splide__slide::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.7);
  content: "";
}
.topMember__splide .splide__slide.is-visible::after {
  display: none;
}
.topMember__splide .splide__arrows {
  z-index: 10;
}
.topMember__splide .splide__arrows {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  margin-inline: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.topMember__splide .splide__arrow {
  background: transparent;
  opacity: 1;
}
.topMember__splide .splide__arrow svg {
  display: none;
}
.topMember__splide .splide__arrow--prev::before,
.topMember__splide .splide__arrow--next::after {
  position: absolute;
  width: 3.5rem;
  height: 7rem;
  background: url(../img/arrow_next.svg) no-repeat center center/contain;
  content: "";
}
.topMember__splide .splide__arrow--prev::before {
  background: url(../img/arrow_prev.svg) no-repeat center center/contain;
}

.topMember__image {
  aspect-ratio: 350/270;
}
.topMember__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topMember__content {
  margin-top: 1rem;
  font-family: "Shippori Mincho", serif;
}

.topMember__title {
  color: #06233B;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.5;
}

.topMember__name {
  font-weight: 700;
  font-size: 2.2rem;
  text-transform: capitalize;
}

.topMember__btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 4rem;
}

.topRecruit__inner {
  max-width: 600px;
  margin-top: 3rem;
  margin-inline: auto;
  padding: 0 15px;
}

.topRecruit__items {
  display: grid;
  gap: 4rem;
}

.topRecruit__item {
  display: grid;
  gap: 1.5rem;
}

.topRecruit__image {
  aspect-ratio: 659/350;
  width: 100%;
}
.topRecruit__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topRecruit__content {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}

.topRecruit__en {
  color: #177DD0;
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 120%;
  font-family: "Ephesis", serif;
}

.topRecruit__jp {
  color: #06233B;
  font-weight: 500;
  font-size: 2.4rem;
  line-height: 150%;
}

.topRecruit__text {
  margin-top: 1rem;
  color: #B3B3B3;
  font-weight: 500;
}

.topRecruit__btn {
  margin-top: 3rem;
}

.topWorks__inner {
  padding-right: 15px;
  padding-left: 15px;
}

.topWorks__items {
  display: grid;
  margin-top: 3.5rem;
  gap: 3rem;
}

.topWorks__item:hover a {
  opacity: 1;
}

.topWorks__image {
  position: relative;
  aspect-ratio: 434/300;
  width: 100%;
}

.topWorks__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.topWorks__image::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  content: "";
  opacity: 0;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  transition: 0.3s;
}

.topWorks__category {
  display: grid;
  z-index: 2;
  position: absolute;
  right: 0;
  bottom: 0;
  place-items: center;
  width: 10rem;
  min-height: 3rem;
  background: #FFF;
  font-weight: 700;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
}

.topWorks__content {
  padding: 2rem 2.5rem;
}

.topWorks__name {
  position: relative;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.8;
}

.topWorks__name::before {
  position: absolute;
  top: 1.4rem;
  left: -2rem;
  width: 1.5rem;
  height: 2px;
  background: #06233B;
  content: "";
}

.topWorks__text {
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 1.8;
}

.topWorks__btn {
  margin-top: 3rem;
}

.topWorks__btn a {
  margin-inline: auto;
}

.workLife {
  margin-top: 10rem;
  padding-top: 5rem;
}

.workLife__top {
  margin-top: 2rem;
}

.workLife__items {
  display: grid;
  margin-top: 3rem;
  gap: 3rem;
}

.workLife__item {
  display: grid;
  gap: 1rem;
}

.workLife__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.workLife__title {
  color: #06233B;
  font-weight: 500;
  font-size: 2rem;
}

.workLife__text {
  margin-top: 1rem;
}

.workLife__bottom {
  margin-top: 3rem;
}

.works {
  padding-top: 6rem;
  padding-bottom: 5rem;
}

.works__btns {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5rem;
}

.works__items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 4rem;
  gap: 1rem;
}

.works__image {
  aspect-ratio: 325/235;
  width: 100%;
}

.works__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.u-desktop {
  display: none;
}

@media (min-width: 768px) and (max-width: 1240px) {
  .header {
    zoom: 0.91;
  }
}

@media screen and (min-width: 768px) {
  html {
    font-size: calc(10 / 1100 * 100vw);
  }
  body {
    font-size: max(1.6rem, 14px);
  }
  .inner {
    max-width: 1040px;
    padding-right: 20px;
    padding-left: 20px;
  }
  .inner__mini {
    max-width: 1040px;
  }
  .btn a {
    width: 28rem;
    min-height: 6rem;
    margin-inline: initial;
  }
  .btn a::after {
    right: 2.6rem;
  }
  .pankuz {
    min-height: 7.1rem;
  }
  .pankuz a {
    margin-right: 1.5rem;
    font-size: 1.6rem;
  }
  .post {
    margin-left: 1.5rem;
  }
  .pankuz .current-item {
    margin-left: 1.5rem;
    font-size: 1.6rem;
  }
  .date-year,
  .taxonomy,
  .post-works-archive {
    margin-left: 1.5rem;
  }
  .post-interview-archive {
    margin-left: 1.5rem;
    font-size: 1.6rem;
  }
  .section {
    padding-top: 22rem;
    padding-bottom: 22rem;
  }
  .section__title {
    margin-inline: initial;
    text-align: initial;
  }
  .section__en {
    margin-left: -5.5rem;
    font-size: 8.2rem;
  }
  .section__jp {
    margin-top: -3.5rem;
    font-size: 4.8rem;
  }
  .section__sub-jp {
    font-size: 3rem;
    line-height: 1.2;
  }
  .section__title-left {
    padding-left: initial;
  }
  .subPage__top {
    padding-top: 10rem;
  }
  .subPage__title {
    font-size: 3rem;
  }
  .subPage__en {
    text-align: initial;
  }
  .subPage__jp {
    font-size: 3rem;
    text-align: initial;
  }
  .subPage__text {
    font-size: 1.6rem;
    line-height: 2.25;
  }
  .text {
    font-size: 1.6rem;
    line-height: 200%;
  }
  .about {
    padding-top: 9.4rem;
  }
  .about::after {
    height: 14%;
  }
  .about__items {
    grid-template-columns: repeat(2, 1fr);
    gap: 4.6rem 3.9rem;
  }
  .about__items:nth-child(2) {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 4.3rem;
    gap: 4rem;
  }
  .about__item {
    aspect-ratio: 1/1;
    padding: 3.6rem;
    gap: 2rem;
  }
  .about__image {
    margin-inline: auto;
  }
  .about__items:nth-child(1) .about__image {
    margin-top: initial;
  }
  .about__items:nth-child(1) .about__item:nth-child(1) .about__image {
    width: 36.9rem;
    margin-top: 4.5rem;
  }
  .about__items:nth-child(1) .about__item:nth-child(2) .about__image {
    width: 23.6rem;
    margin-top: 2rem;
  }
  .about__items:nth-child(1) .about__item:nth-child(3) .about__image {
    width: 36.5rem;
  }
  .about__items:nth-child(1) .about__item:nth-child(4) .about__image {
    width: 32.8rem;
    margin-top: 2rem;
  }
  .about__items:nth-child(1) .about__item:nth-child(1)::after,
  .about__items:nth-child(1) .about__item:nth-child(2)::after {
    bottom: 1.5rem;
    left: 1.5rem;
    font-size: 1.6rem;
  }
  .about__value {
    gap: 1rem;
    font-size: 2.6rem;
  }
  .about__value span {
    font-size: 10rem;
  }
  .about__value-sales {
    margin-top: -12rem;
    gap: 3rem;
    font-size: 6rem;
  }
  .about__value-sales span {
    font-size: 18rem;
  }
  .about__value-client {
    margin-top: -7rem;
  }
  .about__value-client span {
    font-size: 12rem;
  }
  .about__value-center {
    gap: 15%;
    font-size: 2rem;
  }
  .about__value-center span {
    font-size: 6rem;
  }
  .about__items:nth-child(2) .about__item:nth-child(1) .about__image {
    width: 10.5rem;
  }
  .about__items:nth-child(2) .about__item:nth-child(2) .about__image {
    width: 9.8rem;
  }
  .about__items:nth-child(2) .about__item:nth-child(3) .about__image {
    width: 10.7rem;
  }
  .about__items:nth-child(2) .about__value {
    font-size: 3rem;
  }
  .about__items:nth-child(2) .about__value span {
    font-size: 8rem;
    line-height: 90%;
  }
  .aboutTop {
    padding-bottom: 12rem;
  }
  .aboutTop__text {
    margin-top: 4.5rem;
    font-size: 1.6rem;
    line-height: 2.25;
    text-align: center;
  }
  .archive__section {
    padding-bottom: 16.5rem;
  }
  .archive__items {
    gap: 10rem;
  }
  .archive__item {
    grid-template-columns: 54% 1fr;
  }
  .archive__image {
    width: 100%;
  }
  .archive__content {
    margin-top: 1.5rem;
  }
  .archive__title {
    min-height: 9.4rem;
    padding: 0.5em 4rem;
    font-size: 2.2rem;
  }
  .archive__info {
    margin-top: 2rem;
    padding-left: 4rem;
  }
  .archive__name {
    margin-top: 2rem;
    font-size: 3.2rem;
  }
  .archive__btn {
    display: block;
    margin-top: 5rem;
  }
  .archive__btn a {
    width: 25.5rem;
    min-height: 6.4rem;
    font-size: 1.8rem;
  }
  .archiveJob__items {
    grid-template-columns: repeat(2, 1fr);
    gap: 8rem 3.9rem;
  }
  .archiveJob__content {
    padding: 3rem;
  }
  .archiveJob__title {
    font-size: 2rem;
    line-height: 2.5;
  }
  .archiveJob__category {
    min-width: 10.8rem;
    min-height: 3.4rem;
    min-height: 3.4rem;
    font-size: 1.4rem;
  }
  .archiveJob__text {
    margin-top: 2rem;
  }
  .archiveJob__btn {
    margin-top: 3rem;
  }
  .archiveJob__btn a {
    width: 25.5rem;
    min-height: 6.3rem;
    font-size: 1.8rem;
  }
  .benefits__items {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 4rem;
    gap: 5rem;
  }
  .benefits__item {
    aspect-ratio: 1/1;
    max-width: 30rem;
    padding: 3.5rem 2.2rem 4.2rem;
    gap: 4rem;
  }
  .benefits__title {
    font-size: 2rem;
    line-height: 1.8;
  }
  .career {
    padding-top: 22rem;
    padding-bottom: 24rem;
  }
  .career__title {
    font-size: 3.2rem;
  }
  .career__text {
    margin-top: 5.5rem;
  }
  .career__image {
    margin-top: 3rem;
  }
  .company {
    margin-top: 20rem;
    padding-top: 11rem;
    padding-bottom: 12.9rem;
  }
  .company__items {
    margin-top: 9.8rem;
    margin-inline: auto;
    padding: initial;
    gap: 3.2rem;
  }
  .company__item {
    grid-template-columns: 21% 79%;
  }
  .company__item {
    padding-bottom: 3rem;
  }
  .company__label {
    font-size: 1.8rem;
    line-height: 1.6666666667;
  }
  .company__value {
    font-size: 1.6rem;
    line-height: 2.25;
  }
  .company__value span {
    display: inline-block;
  }
  .company__flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    gap: 3.4rem;
  }
  .company__map {
    height: 28rem;
  }
  .companyAbout {
    padding-top: 15rem;
  }
  .companyAbout__wrapper {
    margin-top: 6.6rem;
    padding-top: 12rem;
    padding-bottom: 8rem;
  }
  .companyAbout__title {
    top: -3.75rem;
    width: 64rem;
    min-height: 7.5rem;
    font-size: 2.8rem;
  }
  .companyAbout__items {
    grid-template-columns: repeat(2, 1fr);
    gap: 4.58rem 3.8rem;
  }
  .companyAbout__items > *:nth-child(n+3) {
    grid-column: span 2;
  }
  .companyAbout__item {
    padding: 4.5rem;
    gap: initial;
  }
  .companyAbout__item:nth-child(1),
  .companyAbout__item:nth-child(2) {
    max-height: 29.8rem;
  }
  .companyAbout__label {
    font-size: 2.6rem;
    text-align: left;
  }
  .companyAbout__item:nth-child(2) .companyAbout__content {
    grid-template-columns: 15.7rem 1fr;
    gap: 8rem;
  }
  .companyAbout__item:nth-child(3) {
    padding: 3.9rem 4.5rem 3rem;
  }
  .companyAbout__item:nth-child(3) .companyAbout__content {
    grid-template-columns: 52.4rem 1fr;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 14.4rem;
    line-height: 1;
  }
  .companyAbout__item:nth-child(4) {
    padding: 3.9rem 4.5rem 3rem;
  }
  .companyAbout__item:nth-child(4) .companyAbout__content {
    grid-template-columns: 38rem 1fr;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    margin-top: -1rem;
    padding-left: 4rem;
    gap: 28rem;
    line-height: 1;
  }
  .companyAbout__attention {
    margin-top: auto;
    margin-left: 1em;
    font-size: 1.6rem;
  }
  .companyAbout__number {
    font-size: 2.6rem;
  }
  .companyAbout__number span {
    font-size: 12rem;
  }
  .companyAbout__value {
    text-align: left;
  }
  .companyAbout__text {
    margin-bottom: 4rem;
    padding-left: 1em;
    font-size: 1.6rem;
  }
  .companyPage__head {
    font-size: 3.2rem;
  }
  .contact__heading {
    font-size: 1.8rem;
  }
  .contactForm {
    padding-top: 15.1rem;
    padding-bottom: 19rem;
  }
  .contactForm__flows {
    padding-top: 2.8rem;
  }
  .contactForm__flow {
    font-size: 1.6rem;
  }
  .contactForm__flow::before {
    top: -4.1rem;
    width: 3rem;
    height: 3rem;
  }
  .contactForm__flow.is-active::before {
    width: 3rem;
    height: 3rem;
  }
  .contactForm__flow.is-active::after {
    top: -4.5rem;
    top: -178%;
    width: 3.9rem;
    height: 3.9rem;
  }
  .contactForm__items {
    max-width: 90%;
    margin-top: 8rem;
    margin-inline: auto;
    gap: 5.4rem;
  }
  .contactForm__item {
    gap: 2rem;
  }
  .contactForm__labels label {
    font-size: 1.8rem;
  }
  .contactForm__required {
    font-size: 1.8rem;
  }
  .contactForm__answer {
    line-height: 2.25;
  }
  .contactForm__serch {
    padding-left: 3em;
  }
  .contactForm__serch .wpcf7-form-control-wrap {
    width: 21rem;
  }
  .contactForm__serch::before {
    left: 1em;
  }
  .contactForm__serch-btn {
    width: 11.2rem;
  }
  .contactForm__rule {
    height: 25rem;
    padding: 4.5rem 3.5rem;
    line-height: 2.25;
  }
  .contactForm__agree {
    margin-top: 3.5rem;
  }
  .contactForm__btns {
    max-width: 80%;
    margin-top: 6rem;
    margin-inline: auto;
    gap: 4.8rem;
  }
  .contactForm__btn {
    margin-top: 8.5rem;
  }
  .contactForm__btns .contactForm__btn {
    margin-top: initial;
  }
  .contactForm__btns .contactForm__btn input {
    width: 28rem;
  }
  .contactForm__btn input {
    width: 28rem;
    min-height: 6rem;
    font-size: 1.8rem;
  }
  .contactForm__title {
    margin-top: 10rem;
    font-size: 2.8rem;
  }
  .contacForm__thanks {
    margin-top: 7rem;
  }
  .contacForm__return {
    margin-top: 10rem;
  }
  input[type=text],
  input[type=email],
  input[type=tel],
  select,
  textarea {
    min-height: 5.7rem;
  }
  textarea {
    height: 28rem;
  }
  .wpcf7-form-control.wpcf7-radio {
    gap: 3.5rem 6rem;
  }
  .contact__form-thanks {
    margin-top: 7rem;
  }
  .contactForm__check .contactForm__answer {
    min-height: 5.7rem;
  }
  .education {
    margin-top: 20rem;
    padding-top: 8rem;
  }
  .eduaction__wrapper {
    margin-top: 8rem;
    gap: 13rem;
  }
  .education__year {
    min-height: 6.3rem;
    padding: 0.3em 5.5rem;
    font-size: 2.2rem;
  }
  .education__inner {
    margin-top: 6.7rem;
    gap: 4.8rem;
  }
  .education__contents {
    gap: 3rem;
  }
  .education__graph {
    display: grid;
    grid-template-rows: 25.6rem 1fr;
  }
  .education__month:nth-child(1) {
    height: 100%;
  }
  .education__month {
    font-size: 2rem;
  }
  .education__month span {
    margin-left: -0.6rem;
    font-size: 2rem;
  }
  .education__month:nth-child(1)::after {
    height: 2.7rem;
  }
  .education__start {
    min-height: 10.6rem;
    font-size: 2.8rem;
  }
  .education__second {
    gap: 2.7rem;
    font-size: 2.8rem;
  }
  .education__second div {
    min-height: 10.6rem;
  }
  .education__job {
    padding: 4.3rem 4.5rem;
  }
  .education__container {
    grid-template-columns: 31.0559006211% 1fr;
    gap: 4.8rem;
  }
  .education__content {
    margin-top: 1rem;
  }
  .education__title {
    font-size: 3.2rem;
  }
  .education__text {
    margin-top: 2rem;
    font-size: 1.8rem;
    line-height: 2;
  }
  .education__label {
    margin-top: 3rem;
    font-size: 2rem;
  }
  .education__label span {
    padding: 0 3.5rem;
  }
  .education__items {
    grid-template-columns: repeat(3, 1fr);
    width: 100%;
    margin-top: 4rem;
    padding-right: 2rem;
    padding-left: 2rem;
    gap: 8.5rem;
  }
  .education__item {
    aspect-ratio: 200/200;
    max-width: 20rem;
    min-height: initial;
    font-size: 1.8rem;
    line-height: 1.6666666667;
  }
  .education__item span {
    font-size: 1.4rem;
  }
  .education__item:not(:last-child)::after {
    top: 50%;
    right: -5.3rem;
    bottom: initial;
    left: initial;
    width: 1.8rem;
    height: 2.9rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .education__item:nth-child(3)::after {
    right: -3rem;
  }
  .education__number {
    top: 1.4rem;
    left: 1.4rem;
    font-size: 2.4rem;
  }
  .education__before {
    width: 64.7777777778%;
    padding: 2.9rem;
    font-size: 1.8rem;
    line-height: 2;
    text-align: center;
  }
  .education__rule {
    padding: 2.8rem 4.8rem 3.3rem;
  }
  .education__rule h4 {
    font-size: 2.8rem;
  }
  .education__rule::after {
    top: 99.8%;
    height: 2.7rem;
  }
  .education__rule-items {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 4rem;
    gap: 3.2rem;
  }
  .education__rule-item h5 {
    width: 13.4rem;
    min-height: 3.7rem;
    font-size: 1.8rem;
  }
  .education__rule-item p {
    margin-top: 2rem;
  }
  .event {
    margin-top: 14rem;
    padding-top: 9rem;
    padding-bottom: 20rem;
  }
  .event__items {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 9rem;
  }
  .event__circle {
    width: 100%;
  }
  .event__title {
    font-size: 2.6rem;
  }
  .event__text {
    margin-top: 4rem;
  }
  .flow {
    padding-top: 20rem;
  }
  .flow__items {
    margin-top: 7rem;
    gap: 6.5rem;
  }
  .flow__item {
    grid-template-columns: 15% 1fr;
  }
  .flow__time p {
    font-size: 1.8rem;
  }
  .flow__container {
    grid-template-columns: 24.0963855422% 1fr;
    gap: 3rem;
  }
  .flow__image {
    max-width: 20rem;
  }
  .flow__title {
    font-size: 2.6rem;
  }
  .flow__text {
    margin-top: 1.5rem;
  }
  .footer__inner {
    max-width: 1040px;
  }
  .footer__container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    gap: initial;
  }
  .footer__logo {
    width: 12.5rem;
  }
  .footer__logo a::after {
    font-size: 1.6rem;
  }
  .footer__right {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-top: 13rem;
    margin-left: auto;
    gap: 5.5rem;
  }
  .footer__nav {
    margin-top: initial;
  }
  .footer__items {
    font-size: 1.6rem;
  }
  .footer__bottom {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 13rem;
  }
  .footer__text {
    margin-top: initial;
    font-size: 1.6rem;
    text-align: initial;
  }
  .footer__corporate {
    font-size: 1.6rem;
    line-height: 1.8888888889;
  }
  .fv {
    margin-top: 10rem;
  }
  .fv__image::after {
    display: none;
  }
  .fv__content {
    top: 60%;
    left: 12.8rem;
  }
  .fv__copy {
    width: 45.5rem;
  }
  .fv__copy::after {
    font-size: 6.2rem;
  }
  .fv .youtube {
    right: 4rem;
  }
  .fv .youtube a {
    width: 29.8rem;
    padding: 1.7rem 2.9rem 1.6rem;
  }
  .fv .youtube__title {
    font-size: 2rem;
  }
  .fv .youtube__image {
    margin-top: 1rem;
  }
  .fv .your-class-pagination {
    top: initial;
    bottom: 12.2rem;
    left: 4.6rem;
  }
  .fv .your-class-page {
    width: 15px;
    height: 15px;
  }
  .fv .splide__track--nav > .splide__list > .splide__slide.is-active,
  .fv .splide__track--nav > .splide__list > .splide__slide {
    width: 100% !important;
    padding: initial;
  }
  .fvSub__image {
    height: 100%;
    margin-left: auto;
  }
  .fvSub__title {
    bottom: 7.5rem;
    left: 9.2rem;
    min-height: 9rem;
    padding: 0.3em 8.5rem;
    font-size: 4.6rem;
  }
  .group {
    margin-top: 40rem;
    padding-bottom: 25rem;
  }
  .group__text {
    margin-top: 4rem;
  }
  .group__items {
    margin-top: 5rem;
    gap: 4rem;
  }
  .group__title {
    left: 7.7rem;
    font-size: 3.6rem;
  }
  .hamburger {
    display: none;
  }
  .header {
    height: 10rem;
  }
  .header__inner {
    padding-left: 5rem;
  }
  .header__logo {
    width: 9.6rem;
  }
  .header__logo a::after {
    font-size: 1.6rem;
  }
  .header__nav {
    display: block;
    height: inherit;
    margin-left: auto;
  }
  .header__entries {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    margin-top: 4rem;
    margin-left: 3.5rem;
    color: #FFF;
    font-weight: 700;
    font-size: 1.6rem;
  }
  .history {
    padding-bottom: 20rem;
  }
  .history__items {
    margin-top: 8rem;
  }
  .history__item {
    grid-template-columns: 22% 1fr;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    min-height: 7.9rem;
    padding: 0.3em 4.5rem;
    font-size: 1.6rem;
    line-height: 2.25;
  }
  .interview {
    padding-bottom: 20rem;
  }
  .inerview__lists {
    gap: 12rem;
  }
  .interview__top {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: initial;
  }
  .interview__position {
    font-size: 1.6rem;
  }
  .interview__name {
    margin-top: -1rem;
    font-size: 3.6rem;
  }
  .interview__item {
    grid-template-columns: 8rem 1fr;
    gap: 2.9rem;
  }
  .interview__label {
    font-size: 1.8rem;
    text-align: center;
  }
  .interview__value {
    font-size: 1.6rem;
  }
  .interviewDetail__items {
    margin-top: 7rem;
    gap: 7rem;
  }
  .interviewDetail__title {
    padding-left: 11.7rem;
    font-size: 2.6rem;
  }
  .interviewDetail__title::before {
    width: 9rem;
  }
  .interviewDetail__text {
    margin-top: 3rem;
  }
  .jobDescription {
    padding-top: 8rem;
  }
  .jobDescription::after {
    height: 14%;
  }
  .jobDescription__items {
    margin-top: 8rem;
    gap: 8rem;
  }
  .jobDescription__item {
    grid-template-columns: 1fr 50%;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 3rem;
  }
  .jobDescription__content {
    gap: 4rem;
  }
  .jobDescription__title {
    font-size: 2.4rem;
  }
  .loop__texts {
    font-size: 8.2rem;
  }
  .message {
    padding-bottom: 12.5rem;
  }
  .message__top {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: initial;
  }
  .message__title {
    font-size: 2.4rem;
    line-height: 1.25;
  }
  .messsage__image {
    margin-top: 6rem;
  }
  .message__text {
    margin-top: 3rem;
  }
  .message__company {
    margin-top: 3rem;
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .message__name {
    margin-top: 2rem;
    font-size: 1.8rem;
  }
  .message__name span {
    margin-top: -0.2rem;
    font-size: 2.6rem;
  }
  .not-found {
    padding-bottom: 20rem;
  }
  .not-found__text {
    font-size: 2.6rem;
  }
  .other {
    max-width: 1100px;
    max-width: 84.6153846154%;
    margin-top: -13rem;
  }
  .other__wrapper {
    padding-top: 12.3rem;
    padding-bottom: 9.8rem;
    -webkit-box-shadow: initial;
            box-shadow: initial;
  }
  .other__items {
    grid-template-columns: repeat(2, 1fr);
    gap: 4rem;
  }
  .other__item {
    height: 24rem;
    padding: 3.7rem;
  }
  .other__title {
    font-size: 2.4rem;
  }
  .pagination {
    margin-top: 16rem;
    gap: 1.9rem;
  }
  .page-numbers {
    width: 5rem;
    height: 5rem;
    font-size: 1.8rem;
  }
  .partner {
    padding-top: 26rem;
    padding-bottom: 10rem;
  }
  .parter__container {
    width: 67.7%;
    margin-top: 10.4rem;
  }
  .parter__container::after {
    top: -37rem;
    left: 100%;
    width: 62.3rem;
    height: 82rem;
  }
  .partner__content {
    padding: 4.4rem 4.7rem 4.4rem 0;
    background: #FFF;
  }
  .partner__content::after {
    z-index: -1;
    position: absolute;
    top: 14%;
    left: 75%;
    width: 96rem;
    height: 64rem;
    background: url(../img/partner_image.png) no-repeat;
    background-size: contain;
    content: "";
  }
  .partner__title {
    width: 78.6%;
    min-height: 8rem;
    margin-top: 23.6rem;
    font-size: 2.4rem;
  }
  .partner__items {
    grid-template-columns: repeat(4, 1fr);
    margin-top: 5.5rem;
    gap: 3.2rem;
  }
  .philosophy::after {
    height: 27%;
  }
  .philosophy__items {
    margin-top: 7rem;
    gap: 5rem;
  }
  .philosophy__item {
    grid-template-columns: 23% 1fr;
    padding: 0 1.5em 3rem;
  }
  .philosophy__label {
    font-size: 2.8rem;
  }
  .philosophy__value {
    font-size: 1.6rem;
    line-height: 2.25;
  }
  .privacy__items {
    margin-top: 5rem;
    gap: 6rem;
  }
  .privacy__item {
    gp: 4rem;
  }
  .privacy__title {
    font-size: 2.4rem;
  }
  .qa {
    padding-top: 12rem;
    padding-bottom: 24rem;
  }
  .qa__wrapper {
    gap: 21rem;
  }
  .qa__items {
    margin-top: 6rem;
  }
  .qa__question {
    padding: 1.4rem 6.1rem 1.4rem 3.2rem;
    font-size: 1.8rem;
    line-height: 2.2222222222;
  }
  .qa__answer {
    padding: 3rem 8.1rem 1.4rem 3.2rem;
  }
  .qa__question::before,
  .qa__question::after {
    right: 2.5rem;
    width: 23px;
  }
  .qa__flex {
    gap: 2.5rem;
  }
  .qa__flex span {
    font-size: 3rem;
  }
  .qa__value {
    margin-top: 0.5em;
  }
  .recommend {
    padding-top: 15rem;
    padding-bottom: 20rem;
  }
  .recommend__container {
    padding: 6rem;
  }
  .recommend__items {
    width: 82%;
    margin-top: 5rem;
    margin-inline: auto;
    gap: 3.8rem;
  }
  .recommend__item {
    padding-left: 3em;
    font-size: 2rem;
  }
  .recommend__item::after {
    width: 3.5rem;
    height: 3.5rem;
  }
  .recruitment {
    padding-top: 11rem;
    padding-bottom: 12.9rem;
  }
  .recruitment__items {
    margin-top: 9.8rem;
    margin-inline: auto;
    padding: initial;
    gap: 3.2rem;
  }
  .recruitment__item {
    grid-template-columns: 21% 79%;
  }
  .recruitment__item {
    padding-bottom: 3rem;
  }
  .recruitment__label {
    font-size: 1.8rem;
    line-height: 1.6666666667;
  }
  .recruitment__value {
    font-size: 1.6rem;
    line-height: 2.25;
  }
  .recruitment__value span {
    display: inline-block;
  }
  .recruitment__flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    gap: 3.4rem;
  }
  .recruitment__btn {
    margin-top: 9rem;
  }
  .single__head {
    font-size: 3.8rem;
  }
  .single__image {
    margin-top: 4.5rem;
  }
  .single__info {
    margin-top: 4rem;
  }
  .single__items {
    margin-top: 4rem;
    padding: 6rem 10rem;
    gap: 7rem;
  }
  .single__title {
    font-size: 2.8rem;
  }
  .single__text {
    margin-top: 4.5rem;
  }
  .single__btn {
    margin-top: 10.8rem;
  }
  .singleJob__main {
    max-width: 90%;
    margin-inline: auto;
  }
  .singleJob__items {
    gap: 7rem;
  }
  .singleJob__title {
    font-size: 2.8rem;
  }
  .singleJob__text {
    margin-top: 4.5rem;
  }
  .singleJob__recruit {
    margin-top: 13rem;
  }
  .singleJob__lists {
    margin-top: 4rem;
    gap: 4rem;
  }
  .singlJob__list {
    grid-template-columns: 16% 1fr;
    padding-bottom: 4rem;
    gap: 7.9rem;
  }
  .singleJob__btn {
    margin-top: 10rem;
  }
  .skill {
    margin-top: 11rem;
    padding-top: 8.5rem;
  }
  .skill::after {
    height: 10%;
  }
  .skill__items {
    grid-template-columns: repeat(2, 1fr);
    margin-top: 8rem;
    gap: 6.8rem 4rem;
  }
  .skill__content {
    margin-top: 2.2rem;
  }
  .skill__title {
    font-size: 2.4rem;
  }
  .skill__text {
    margin-top: 1.5rem;
  }
  .tab__inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 3.9rem;
  }
  .tab__title {
    font-size: 2.4rem;
  }
  .tab__item a {
    width: 16.8rem;
    font-size: 1.8rem;
  }
  .topActivitie {
    padding-top: 13rem;
    padding-bottom: 16rem;
  }
  .topActivitie .section__jp::before {
    bottom: 95%;
    left: -3.5rem;
    -webkit-transform: rotate(-7.7deg);
            transform: rotate(-7.7deg);
    font-size: 5.8rem;
  }
  .topActivitie__container {
    grid-template-columns: 33.6% 1fr;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 8.5rem;
  }
  .topActivitie__content {
    margin-top: 4rem;
  }
  .topActivitie__items {
    margin-top: initial;
    gap: 3rem 1.2rem;
  }
  .topActivitie__title {
    font-size: 2rem;
  }
  .topInformation {
    padding-top: initial;
  }
  .topInformation__items {
    margin-top: 6rem;
  }
  .topInformation__item a {
    padding: 2.8rem 3rem;
  }
  .topInformation__label {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .topInformatioin__time {
    font-size: 1.6rem;
  }
  .topInformation__title {
    margin-top: initial;
    margin-left: 7.5rem;
    font-size: 1.6rem;
  }
  .topInformation__btn {
    margin-top: 6rem;
  }
  .topInterview {
    padding-top: 15.6rem;
  }
  .topInterview .section__en {
    font-size: 5.2rem;
  }
  .topInterview .section__jp {
    margin-top: -1.5rem;
  }
  .topInterview__wrapper {
    padding-bottom: 5rem;
    border-radius: 0 0 316px 0;
  }
  .topInterview__top {
    top: -7.1rem;
    width: 81.5384615385%;
    margin-top: -7.1rem;
    padding-left: 15rem;
  }
  .topInterview__splide {
    margin-top: initial;
    margin-right: -10.4rem;
    padding: 0 0 0 4.4rem;
  }
  .topInterview__image {
    margin-top: -3.5rem;
  }
  .topInterview__number {
    margin-left: 1.4rem;
    font-size: 6.4rem;
  }
  .topInterview__text {
    font-size: 2rem;
    line-height: 200%;
  }
  .topInterview .splide__arrows {
    top: -13rem;
    right: 33.5%;
    width: 9rem;
  }
  .topInterview .button {
    width: 4rem;
    height: 4rem;
  }
  .topInterview .button::before {
    width: 4rem;
    height: 4rem;
  }
  .topKnow {
    padding-top: 12rem;
    padding-bottom: 16rem;
  }
  .topKnow__items {
    gap: 7rem;
  }
  .topKnow__item {
    grid-template-columns: 1fr 68%;
  }
  .topKnow__item:not(:last-child) {
    padding-bottom: 7rem;
  }
  .topKnow__jp {
    font-size: 4rem;
  }
  .topKnow__en {
    right: 18rem;
    bottom: initial;
    font-size: 3rem;
  }
  .topKnow__item:nth-child(1) .topKnow__en {
    left: 7rem;
  }
  .topKnow__item:nth-child(2) .topKnow__en {
    left: 8rem;
  }
  .topKnow__item:nth-child(3) .topKnow__en {
    left: 3.5rem;
  }
  .topKnow__text {
    line-height: 2.1875;
  }
  .topLink__heading {
    top: -5rem;
    width: 40rem;
    min-height: 10rem;
    font-size: 6.4rem;
  }
  .topLink__items {
    grid-template-columns: repeat(2, 1fr);
  }
  .topLink__en {
    font-size: 1.4rem;
  }
  .topLink__jp {
    font-size: 3rem;
  }
  .topMember {
    padding-top: 13rem;
    padding-bottom: 15rem;
  }
  .topMember__splide {
    margin-top: 7rem;
  }
  .topMember__splide .splide__arrow--prev {
    left: 4rem;
  }
  .topMember__splide .splide__arrow--next {
    right: 4rem;
  }
  .topMember__splide .splide__arrow--prev::before,
  .topMember__splide .splide__arrow--next::after {
    width: 4.7rem;
    height: 9.3rem;
  }
  .topMember__content {
    margin-top: 2rem;
  }
  .topMember__title {
    font-size: 1.6rem;
  }
  .topMember__name {
    font-size: 3rem;
  }
  .topMember__btn {
    margin-top: 8.5rem;
  }
  .topRecruit__inner {
    max-width: 100%;
    padding: initial;
  }
  .topRecruit__items {
    gap: 9rem;
  }
  .topRecruit__item {
    grid-template-columns: 50.6923076923% 34.3076923077%;
    gap: 4.5rem;
  }
  .topRecruit__item:nth-child(even) {
    grid-template-columns: 34.3076923077% 50.6923076923%;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .topRecruit__item:nth-child(even) .topRecruit__image {
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
        -ms-flex-order: 2;
            order: 2;
  }
  .topRecruit__item:nth-child(even) .topRecruit__content {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
  }
  .topRecruit__en {
    font-size: 2.4rem;
  }
  .topRecruit__jp {
    font-size: 3rem;
  }
  .topRecruit__text {
    margin-top: 3rem;
  }
  .topRecruit__btn {
    margin-top: auto;
  }
  .topWorks__inner {
    padding-right: initial;
    padding-left: initial;
  }
  .topWorks__items {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 4.2rem;
    gap: initial;
  }
  .topWorks__category {
    font-size: 1.6rem;
  }
  .topWorks__content {
    padding: 2rem 5.3rem 2rem 6.1rem;
  }
  .topWorks__name {
    font-size: 2rem;
    line-height: 2;
  }
  .topWorks__name::before {
    top: 2rem;
    left: -5rem;
    width: 4rem;
  }
  .topWorks__text {
    font-size: 1.8rem;
    line-height: 2;
  }
  .topWorks__btn {
    margin-top: 5rem;
  }
  .workLife {
    margin-top: 20rem;
  }
  .workLife__top {
    margin-top: 3rem;
  }
  .workLife__items {
    margin-top: 5rem;
    gap: 6.5rem;
  }
  .workLife__item {
    grid-template-columns: 32% 1fr;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 5rem;
  }
  .workLife__title {
    font-size: 2.6rem;
  }
  .workLife__text {
    margin-top: 1.5rem;
  }
  .workLife__bottom {
    margin-top: 6rem;
  }
  .works {
    padding-top: 12.8rem;
    padding-bottom: initial;
  }
  .works__btns {
    margin-top: 8rem;
  }
  .works__items {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 7.7rem;
  }
  .u-mobile {
    display: none;
  }
  .u-desktop {
    display: block;
  }
}

@media screen and (min-width: 768px) and (min-width: 768px) {
  .recruitment__last {
    padding-bottom: 26.5rem;
  }
}

@media screen and (min-width: 1100px) {
  html {
    font-size: 10px;
  }
}

@media screen and (max-width: 767px) {
  html {
    font-size: 10px;
  }
  body {
    font-size: 1.4rem;
  }
}

@media (1550px <= width) {
  .topKnow {
    margin-right: -100px;
    margin-left: -100px;
    border-bottom-right-radius: 1000px 100px;
    border-bottom-left-radius: 1000px 100px;
  }
}

@media (any-hover: hover) {
  a:hover {
    cursor: pointer;
    opacity: 0.8;
  }
  .btn a:hover {
    background-position: right center; /* change the direction of the change here */
    opacity: 1;
  }
  .contactForm__btn input:hover {
    background-position: right center; /* change the direction of the change here */
    opacity: 1;
  }
  .contactForm__btn.contactForm__btn-return input:hover {
    background-position: right center; /* change the direction of the change here */
    opacity: 1;
  }
  .header__recruit a:hover {
    border: 1px solid #177DD0;
    background: #177DD0;
    opacity: 1;
  }
  .page-numbers:hover {
    background: #177DD0;
    color: #FFF;
    opacity: 1;
  }
  .prev:hover span::after,
  .next:hover span::after {
    border-right: 2px solid #FFF;
    border-bottom: 2px solid #FFF;
  }
  .tab__item a:hover {
    background-position: right center; /* change the direction of the change here */
    opacity: 1;
  }
  .topWorks__item:hover .topWorks__image::after {
    opacity: 1;
  }
}




/*# sourceMappingURL=map/styles.css.map */