@charset "utf-8";
/* *************************************
header
************************************* */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background-color: var(--main);
  height: calc(80 * var(--rem));
  transition: box-shadow 0.3s ease, background-color 0.3s ease;
}

.header.is-active {
  box-shadow: 0px 10px 20px 0px rgb(0 0 0 / 0.2);
  background-color: var(--white);
}

.header.not-front {
  background-color: var(--white);
}

.header__inner {
  padding-inline: 56px;
  height: inherit;
  @media (width < 768px) {
    padding-inline: 10px;
  }
}

.header__container {
  display: flex;
  align-items: center;
  height: inherit;
}

.header__logo {
  width: calc(380 * var(--rem));
  @media (width < 768px) {
    width: calc(260 * var(--rem));
  }
}

.header__logo img.header__img-w {
  aspect-ratio: 300/94;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.header.is-active img.header__img-w,
.header.not-front img.header__img-w {
  display: none;
}

.header__logo img.header__img-k {
  display: none;
}

.header.is-active img.header__img-k,
.header.not-front img.header__img-k {
  display: block;
}

.header__hamburger {
  display: none;
  @media (width < 768px) {
    display: block;
    margin-inline-start: auto;
    background-color: transparent;
    position: relative;
    z-index: 100;
  }
}

.header__modal {
  display: contents;
  height: inherit;
  @media (width < 768px) {
    display: block;
    position: fixed;
    inset: 0;
    height: 100svh;
    background-color: var(--white);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    overflow-y: scroll;
    padding: 0 calc(10 * var(--rem)) calc(24 * var(--rem));
  }
}

.header__modal.is-open {
  opacity: 1;
  visibility: visible;
}

.header__modal-logo {
  display: none;
  @media (width < 768px) {
    display: block;
    width: calc(260 * var(--rem));
  }
}

.header__modal-logo img {
  aspect-ratio: 300 / 94;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.header__nav {
  height: inherit;
  margin-inline-start: auto;
  @media (width < 768px) {
    height: revert;
    min-height: 500px;
    margin-block-start: calc(40 * var(--rem));
  }
}

.header__list {
  height: inherit;
  display: grid;
  grid-template-columns: repeat(5, auto);
  gap: calc(16 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

.header__list li {
  height: inherit;
  display: grid;
  align-items: center;
}

.header__list li a {
  display: grid;
  place-content: center;
  text-align: center;
  padding: calc(10 * var(--rem));
  font-size: calc(18 * var(--rem));
  color: var(--white);
  transition: color 0.3s ease;
  @media (width < 768px) {
    grid-template-columns: repeat(2, auto);
    align-items: center;
    gap: 0 calc(16 * var(--rem));
    padding-block: calc(16 * var(--rem));
    place-content: start;
    color: var(--text);
    border-bottom: 2px dashed var(--green);
  }
}

.header.is-active .header__list li:not(:last-child) a,
.header.not-front .header__list li:not(:last-child) a {
  color: var(--black);
}

.header__list li:last-child a {
  background-color: var(--green);
  padding: calc(10 * var(--rem)) calc(25 * var(--rem));
  min-width: calc(158 * var(--rem));
  transition: opacity 0.3s ease;
  @media (width < 768px) {
    color: var(--white);
    place-content: center;
    margin-block-start: calc(40 * var(--rem));
    padding-block: calc(24 * var(--rem));
  }
}

/* *************************************
footer
************************************* */
.footer {
  background-color: var(--white);
  padding-block: calc(24 * var(--rem)) calc(33 * var(--rem));
}

.footer__inner {
  padding-inline: calc(50 * var(--rem));
  @media (width < 768px) {
    padding-inline: 16px;
    max-width: calc(500 * var(--rem));
    margin-inline: auto;
  }
}

.footer__container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: self-start;
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(32 * var(--rem));
  }
}

.footer__left {
  @media (width < 768px) {
    order: 2;
  }
}

.footer__logo {
  width: calc(328 * var(--rem));
  margin-block-start: calc(18 * var(--rem));
  @media (width < 768px) {
    width: 100%;
  }
}

.footer__logo img {
  aspect-ratio: 300/ 32;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.footer__left-list {
  margin-block-start: calc(30 * var(--rem));
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: calc(640 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(24 * var(--rem));
    width: fit-content;
    margin-inline: auto;
  }
}

.footer__left-residence,
.footer__left-tel {
  margin-block-start: calc(-10 * var(--rem));
  letter-spacing: 0.01em;
}

.footer__right {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: calc(525 * var(--rem));
  margin-inline-start: auto;
  @media (width < 768px) {
    grid-template-columns: 1.5fr 1fr;
    width: 100%;
    order: 1;
  }
}

.footer__nav {
  position: relative;
  padding-block: calc(8 * var(--rem));
}

.footer__nav::before {
  content: '';
  display: block;
  width: 1px;
  height: 100%;
  background-color: var(--black);
  position: absolute;
  top: calc(15 * var(--rem));
  left: calc(-20 * var(--rem));
  @media (width < 768px) {
    display: none;
  }
}

.footer__nav-item + .footer__nav-item {
  margin-block-start: calc(4 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(16 * var(--rem));
  }
}

.footer__nav-item a {
  padding: calc(5 * var(--rem)) calc(10 * var(--rem));
}

.footer__nav-item.footer__nav-item--s a {
  font-size: calc(14 * var(--rem));
  padding: calc(5 * var(--rem)) calc(10 * var(--rem));
}

.footer__wrap {
  display: grid;
  grid-template-columns: repeat(2, auto);
  align-items: flex-end;
  margin-block-start: calc(43 * var(--rem));
  padding-inline-end: calc(24 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(16 * var(--rem));
    padding-inline-end: 0;
  }
}

.footer__copy {
  font-size: calc(10 * var(--rem));
  @media (width < 768px) {
    order: 2;
    text-align: center;
  }
}

.footer__link-list {
  display: grid;
  grid-template-columns: repeat(2, auto);
  width: fit-content;
  gap: calc(16 * var(--rem));
  margin-inline-start: auto;
  @media (width < 768px) {
    margin-inline: auto;
  }
}

.footer__link {
  display: block;
  margin-inline-start: auto;
  @media (width < 768px) {
    order: 1;
    margin-inline-start: 0;
  }
}

.footer__sns {
  width: calc(45 * var(--rem));
}

.footer__sns img {
  aspect-ratio: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* *************************************
contact-section
************************************* */
.contact-section {
  background-color: var(--gray);
  padding-block: calc(67 * var(--rem)) calc(45 * var(--rem));
}

.contact-section__inner.inner {
  width: min(100%, calc(1125 * var(--rem)));
}

.contact-section__title {
  text-align: center;
}

.contact-section__text {
  text-align: center;
  margin-block-start: calc(20 * var(--rem));
  font-size: calc(20 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.contact-section__content {
  margin-block-start: calc(40 * var(--rem));
}

/* *************************************
contact
************************************* */
.contact {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.contact__inner.inner {
  width: min(100%, calc(900 * var(--rem)));
}

.contact__tel {
  text-align: center;
  background-color: #9cc48d30;
  padding: calc(24 * var(--rem));
}

.contact__tel-title {
  font-size: calc(26 * var(--rem));
  @media (width < 768px) {
    font-size: calc(22 * var(--rem));
  }
}

.contact__tel a {
  margin-block-start: calc(8 * var(--rem));
  font-size: calc(40 * var(--rem));
  font-weight: bold;
  letter-spacing: 0.1em;
  display: grid;
  grid-template-columns: repeat(2, auto);
  align-items: center;
  width: fit-content;
  margin-inline: auto;
  @media (width < 768px) {
    font-size: calc(28 * var(--rem));
  }
}

.contact__tel a::before {
  content: '';
  display: block;
  width: calc(40 * var(--rem));
  aspect-ratio: 1;
  background: url(../../library/images/common/icon_tel.svg) no-repeat center / contain;
  @media (width < 768px) {
    width: calc(30 * var(--rem));
  }
}

.contact__tel-text {
  font-size: calc(20 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.contact__form {
  margin-block-start: calc(40 * var(--rem));
}

/* *************************************
thanks & page-404
************************************* */
.thanks,
.page-404 {
  margin-block-start: calc(40 * var(--rem));
}

.thanks__title,
.page-404__title {
  font-size: calc(30 * var(--rem));
  text-align: center;
  @media (width < 768px) {
    font-size: calc(26 * var(--rem));
  }
}

.thanks__text,
.page-404__text {
  font-size: calc(18 * var(--rem));
  margin-block-start: calc(40 * var(--rem));
  text-align: center;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.thanks__btn,
.page-404__btn {
  margin-block-start: calc(40 * var(--rem));
  text-align: center;
}

/* *************************************
mv
************************************* */
.mv {
  height: 100svh;
  position: relative;
}

.mv__img {
  height: inherit;
}

.mv__img img {
  aspect-ratio: 1440 / 772;
  width: 100%;
  height: 100%;
  object-fit: cover;
  @media (width < 768px) {
    aspect-ratio: 2/3;
    object-position: 91% 50%;
  }
}

.mv__text-block {
  position: absolute;
  top: 45%;
  left: 29%;
  transform: translate(-50%, -50%);
  text-shadow: 0 0 5px #0d1523, 0 0 15px #0d1523, 0 0 25px #0d1523, 0 0 40px #0d1523;
  @media (width < 768px) {
    top: 50%;
    left: 50%;
    width: 90%;
  }
}

.mv__title {
  color: var(--white);
  font-family: var(--font-sub);
  font-size: calc(70 * var(--rem));
  font-weight: 400;
  letter-spacing: -0.001em;
  @media (width < 768px) {
    font-size: calc(35 * var(--rem));
  }
}

.mv__lead {
  color: var(--white);
  font-size: calc(26 * var(--rem));
  margin-block-start: calc(24 * var(--rem));
  margin-inline-start: calc(16 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
    margin-inline-start: 0;
  }
}

.mv__scroll {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translate(-50%, -1053%);
}

/* *************************************
site-lead
************************************* */
.site-lead {
  margin-block-start: calc(97 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
  }
}

.site-lead__container {
  display: flex;
  @media (width < 768px) {
    display: grid;
    grid-template-columns: 1fr;
    gap: calc(40 * var(--rem));
  }
}

.site-lead__wrap {
  padding-inline-start: calc(113 * var(--rem));
  width: 53%;
  @media (width < 768px) {
    padding-inline: 20px;
    width: 100%;
  }
}

.site-lead__text {
  margin-block-start: calc(35 * var(--rem));
  font-size: calc(20 * var(--rem));
  line-height: 2;
  letter-spacing: 0.04em;
  padding-inline-end: 11%;
  @media (width < 768px) {
    width: 100%;
    padding-inline-end: 0;
    font-size: calc(16 * var(--rem));
  }
}

.site-lead__img {
  width: 47%;
  height: calc(525 * var(--rem));
  margin-inline-start: auto;
  @media (width < 768px) {
    width: 100%;
    height: 100%;
  }
}

.site-lead__img img {
  aspect-ratio: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
top-flow
************************************* */
.top-flow {
  margin-block-start: calc(80 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
  }
}

.top-flow__btn {
  text-align: center;
  margin-block-start: calc(40 * var(--rem));
}

/* *************************************
top-about
************************************* */
.top-about {
  margin-block-start: calc(115 * var(--rem));
  position: relative;
  padding-block-end: calc(120 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
    padding-block-end: calc(180 * var(--rem));
  }
}

.top-about__img {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: min(56%, calc(1050 * var(--rem)));
  @media (width < 768px) {
    width: 100%;
  }
}

.top-about__img img {
  aspect-ratio: 1302 / 699;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-about__wrap {
  background-color: var(--gray);
  width: 54%;
  margin-inline-start: auto;
  padding-block: calc(64 * var(--rem));
  padding-inline: calc(107 * var(--rem)) calc(112 * var(--rem));
  @media (width < 768px) {
    padding-inline: calc(20 * var(--rem));
    margin-inline-start: 0;
    width: 100%;
  }
}

.top-about__title {
  @media (width < 768px) {
    text-align: center;
  }
}

.top-about__text {
  margin-block-start: calc(33 * var(--rem));
  font-size: calc(20 * var(--rem));
  line-height: 2;
  @media (width < 768px) {
    margin-block-start: calc(24 * var(--rem));
    font-size: calc(16 * var(--rem));
  }
}

.top-about__btn {
  text-align: center;
  margin-block-start: calc(50 * var(--rem));

  @media (width < 768px) {
    margin-inline: 0;
  }
}

/* *************************************
top-recruit
************************************* */
.top-recruit {
  background: url(../../library/images/top/top-recruit-bg.webp) no-repeat center / cover;
  position: relative;
  padding: calc(116 * var(--rem)) 0 calc(105 * var(--rem)) calc(90 * var(--rem));
  @media (width < 768px) {
    padding-inline: 20px;
  }
}

.top-recruit::before {
  content: '';
  display: block;
  position: absolute;
  inset: 0;
  background-color: #00930070;
}

.top-recruit__container {
  position: relative;
  z-index: 1;
  display: flex;
  gap: calc(80 * var(--rem));
  align-items: center;
  @media (width < 768px) {
    display: grid;
    grid-template-columns: 1fr;
    gap: calc(24 * var(--rem));
  }
}

.top-recruit__wrap {
  width: 34%;
  @media (width < 768px) {
    display: contents;
  }
}

.top-recruit__title {
  margin-block-start: calc(-8 * var(--rem));
  @media (width < 768px) {
    text-align: center;
    order: 1;
  }
}

.top-recruit__subtitle {
  font-size: calc(45 * var(--rem));
  color: var(--white);
  margin-block-start: calc(47 * var(--rem));
  line-height: 1.2;
  @media (width < 768px) {
    font-size: calc(32 * var(--rem));
    order: 3;
    margin-block-start: 0;
  }
}

.top-recruit__text {
  font-size: calc(20 * var(--rem));
  line-height: 2;
  color: var(--white);
  margin-block-start: calc(27 * var(--rem));
  letter-spacing: 0.06em;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
    order: 4;
    margin-block-start: 0;
  }
}

.top-recruit__btn {
  margin-block-start: calc(60 * var(--rem));
  text-align: center;
  @media (width < 768px) {
    order: 5;
    margin-block-start: 0;
  }
}

.top-recruit__images {
  width: 60%;
  margin-inline-start: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, auto);
  gap: calc(20 * var(--rem));
  @media (width < 768px) {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
    gap: calc(8 * var(--rem));
    order: 2;
  }
}

.top-recruit__img:nth-child(1) {
  grid-column: span 2;
  grid-row: span 1;
}

.top-recruit__img:nth-child(1) img {
  aspect-ratio: 1214/ 597;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-recruit__img:nth-child(2) {
  grid-column: span 1;
  grid-row: 2/3;
}

.top-recruit__img:nth-child(3) {
  grid-column: 2/3;
  grid-row: 2/3;
}

.top-recruit__img:nth-child(2) img,
.top-recruit__img:nth-child(3) img {
  aspect-ratio: 594/ 368;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
top-news
************************************* */
.top-news {
  margin-block-start: calc(90 * var(--rem));
}

.top-news__title {
  text-align: center;
}

.top-news__list {
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    padding-inline: 10px;
  }
}

.top-news__link {
  margin-block-start: calc(8 * var(--rem));
  text-align: right;
  margin-inline-end: calc(10 * var(--rem));
}

/* *************************************
top-track-animation
************************************* */
.top-track-animation {
  margin-block-start: calc(103 * var(--rem));
  padding-bottom: calc(50 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
  }
}

/* *************************************
to-top-btn
************************************* */
.to-top-btn {
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  background-color: var(--white);
}

.to-top-btn.is-active {
  visibility: visible;
  opacity: 1;
}

/* *************************************
business-overview
************************************* */
.business-overview {
  padding-block-start: calc(80 * var(--rem));
  background: linear-gradient(180deg, var(--gray) 0%, var(--gray) 50%, transparent 50%, transparent 100%);
  @media (width < 768px) {
    padding-block-start: calc(40 * var(--rem));
  }
}

.business-overview__inner.inner {
  width: min(100%, calc(1000 * var(--rem)));
}

.business-overview__text {
  border-left: 1px solid var(--green);
  padding-inline-start: calc(24 * var(--rem));
  padding-block: calc(16 * var(--rem));
  margin-block-start: calc(24 * var(--rem));
}

.business-overview__text p {
  margin-block-end: 1em;
}

.business-overview__img {
  box-shadow: 0px 10px 20px 0px rgb(0 0 0 / 0.2);
  width: min(100%, calc(630 * var(--rem)));
  margin-inline: auto;
}

.business-overview__img img {
  aspect-ratio: 1280 / 853;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
business-flow
************************************* */
.business-flow {
  margin-block-start: calc(80 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
  }
}

.business-btn {
  margin-block-start: calc(80 * var(--rem));
  text-align: center;
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
  }
}

/* *************************************
gallery
************************************* */
.gallery {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.gallery__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  @media (width < 768px) {
    grid-template-columns: repeat(2, 1fr);
  }
}

.gallery__img img {
  aspect-ratio: 1440 /960;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
corporate-philosophy
************************************* */
.corporate-philosophy {
  margin-block-start: calc(104 * var(--rem));
  position: relative;
  padding-block: calc(80 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
    padding-block: calc(40 * var(--rem));
  }
}

.corporate-philosophy::before,
.corporate-philosophy::after {
  content: '';
  display: block;
  position: absolute;
  inset: 0;
  background-color: var(--gray);
  z-index: 1;
}

.corporate-philosophy::before {
  clip-path: polygon(100% 0, 100% 100%, 26% 100%);
}

.corporate-philosophy::after {
  clip-path: polygon(0 100%, 0 0, 74% 0);
}

.corporate-philosophy__title {
  text-align: center;
  position: relative;
  z-index: 2;
}

.corporate-philosophy__container {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  align-items: center;
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(24 * var(--rem));
  }
}

.corporate-philosophy__img {
}

.corporate-philosophy__img img {
  aspect-ratio: 1280 /853;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.corporate-philosophy__text {
  padding: calc(32 * var(--rem));
  margin-inline-start: calc(-40 * var(--rem));
  background-color: #ffffffb0;
  box-shadow: 0px 10px 20px 0px rgb(0 0 0 / 0.2);
  @media (width < 768px) {
    margin-inline: 0;
    padding: 0;
    box-shadow: none;
    background-color: transparent;
  }
}

.corporate-philosophy__text p {
  margin-block-end: 1em;
}

/* *************************************
greetings
************************************* */
.greetings {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.greetings__title {
  text-align: center;
}

.greetings__container {
  margin-block-start: calc(24 * var(--rem));
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(32 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
  }
}

.greetings__text {
  @media (width < 768px) {
    order: 2;
  }
}

.greetings__text p {
  margin-block-end: 1em;
}

.greetings__img {
  width: 70%;
  margin-inline: auto;
  @media (width < 768px) {
    width: 100%;
    order: 1;
  }
}

.greetings__img img {
  aspect-ratio: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  @media (width < 768px) {
  }
}

/* *************************************
about
************************************* */
.about {
  margin-block-start: calc(104 * var(--rem));
  background: url(../../library/images/top/top-recruit-bg.webp) no-repeat center / cover;
  position: relative;
  padding-block: calc(80 * var(--rem));
  padding-inline-end: calc(80 * var(--rem));
  @media (width < 768px) {
    padding-inline: 10px;
    margin-block-start: calc(80 * var(--rem));
  }
}

.about::before {
  content: '';
  display: block;
  position: absolute;
  inset: 0;
  background-color: #00930070;
}

.about__container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  gap: calc(24 * var(--rem));
  position: relative;
  z-index: 1;
  @media (width < 768px) {
    grid-template-columns: 1fr;
    width: 100%;
  }
}

.about__images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, auto);
}

.about__img:nth-child(1) {
  grid-column: span 2;
  grid-row: span 1;
}

.about__img:nth-child(2) {
  grid-column: 1/2;
  grid-row: 2/3;
}

.about__img:nth-child(3) {
  grid-column: 2/3;
  grid-row: 2/3;
}

.about__img img {
  aspect-ratio: 1280/853;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about__wrap {
  background-color: var(--white);
  padding: calc(40 * var(--rem));
  width: min(100%, calc(660 * var(--rem)));
  @media (width < 768px) {
    padding-inline: calc(24 * var(--rem));
  }
}

.about__title {
  text-align: center;
}

.about__text {
  margin-block-start: calc(24 * var(--rem));
}

/* *************************************
qualification-holder
************************************* */
.qualification-holder {
  padding-block: calc(104 * var(--rem));
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
  background-size: 16px 16px;
  background-repeat: repeat;
  background-position: center center;
  overflow-x: hidden;
  scroll-behavior: smooth;
  @media (width < 768px) {
    padding-block: calc(80 * var(--rem));
  }
}

.qualification-holder__title {
  text-align: center;
}

.qualification-holder__container {
  margin-block-start: calc(24 * var(--rem));
  margin-inline: auto;
  width: min(100%, calc(1000 * var(--rem)));
}

/* *************************************
access
************************************* */
.access {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.access__inner.inner {
  width: min(100%, calc(1000 * var(--rem)));
  margin-inline: auto;
}

.access__title {
  text-align: center;
}

.access__map-title {
  color: var(--green);
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.1em;
  @media (width < 768px) {
    margin-block-start: calc(24 * var(--rem));
  }
}

.access__map {
  margin-block-start: calc(16 * var(--rem));
}

.access__map iframe {
  aspect-ratio: 16 /9;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
recruit
************************************* */
.recruit {
  margin-block-start: calc(104 * var(--rem));
  padding-block: calc(80 * var(--rem)) calc(200 * var(--rem));
  background-color: #9cc48d30;
  @media (width < 768px) {
    padding-block: calc(40 * var(--rem));
    margin-block-start: calc(80 * var(--rem));
  }
}

.recruit__title {
  text-align: center;
}

.recruit__container {
  margin-block-start: calc(90 * var(--rem));
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: calc(32 * var(--rem));
  align-items: center;
  padding-inline-start: calc(40 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(56 * var(--rem));
    padding-inline: 0;
  }
}

.recruit__wrap {
  width: min(100%, calc(800 * var(--rem)));
  margin-inline-start: auto;
  @media (width < 768px) {
    order: 2;
  }
}

.recruit__sub-title {
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
    padding-inline: 20px;
  }
}

.recruit__text {
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    padding-inline: 20px;
  }
}

.recruit__text p {
  margin-block-end: 1em;
}

.recruit__text span {
  color: var(--green);
}

.recruit__btn {
  margin-block-start: calc(80 * var(--rem));
  text-align: center;
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
  }
}

.recruit__list {
  position: relative;
  display: grid;
  place-content: center;
  @media (width < 768px) {
    order: 1;
  }
}

.recruit__item:nth-child(1) {
  width: 65%;
  margin-inline: auto;
  @media (width < 768px) {
    width: 90%;
  }
}

.recruit__item:nth-child(1) .recruit__img img {
  aspect-ratio: 1440 / 1920;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.recruit__item:nth-child(2) {
  width: 45%;
  position: absolute;
  top: 0%;
  right: 0%;
  transform: translateY(-50%);
  @media (width < 768px) {
    width: min(55%, calc(210 * var(--rem)));
  }
}

.recruit__item:nth-child(2) .recruit__img {
}

.recruit__item:nth-child(3) {
  width: 45%;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translateY(50%);
  @media (width < 768px) {
    width: min(45%, calc(178 * var(--rem)));
  }
}

.recruit__item:nth-child(3) .recruit__img {
}

.recruit__item:nth-child(2) .recruit__img img,
.recruit__item:nth-child(3) .recruit__img img {
  aspect-ratio: 1440 /960;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
message
************************************* */
.message {
  margin-block-start: calc(104 * var(--rem));
  padding-block: calc(104 * var(--rem));
  background: url(../../library/images/recruit/message.webp) no-repeat center / cover;
  position: relative;
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.message::before {
  content: '';
  display: block;
  position: absolute;
  inset: 0;
  background-color: #00000070;
}

.message__title {
  position: relative;
  z-index: 1;
}

.message__wrap {
  width: min(100%, calc(900 * var(--rem)));
  margin-inline: auto;
  margin-block-start: calc(32 * var(--rem));
  position: relative;
  z-index: 1;
}

.message__sub__title {
  text-align: center;
  line-height: 2;
  color: var(--white);
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.message__text {
  margin-block-start: calc(24 * var(--rem));
  text-align: center;
}

.message__text p {
  margin-block-end: 1em;
  color: var(--white);
}

/* *************************************
recruit-info
************************************* */
.recruit-info {
  padding-block: calc(104 * var(--rem));
  background-color: var(--white);
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
  background-size: 16px 16px;
  background-repeat: repeat;
  background-position: center center;
  overflow-x: hidden;
  scroll-behavior: smooth;
}

.recruit-info__table {
  width: min(100%, calc(1000 * var(--rem)));
  margin-inline: auto;
  margin-block-start: calc(32 * var(--rem));
}

/* *************************************
selection-process
************************************* */
.selection-process {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.selection-process__inner.inner {
  width: min(100%, calc(1000 * var(--rem)));
}

.selection-process__list {
}

.selection-process__text {
  border: 1px solid var(--green);
  padding: calc(24 * var(--rem));
  text-align: center;
}

/* *************************************
introduction
************************************* */
.introduction {
  margin-block-start: calc(80 * var(--rem));
  padding-block: calc(104 * var(--rem));
  background-color: #9cc48d30;
}

.introduction__list {
  margin-block-start: calc(40 * var(--rem));
}

.introduction__btn {
  margin-block-start: calc(40 * var(--rem));
  text-align: center;
}

/* *************************************
staff-interview-head
************************************* */
.staff-interview-head {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.staff-interview-head__container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  @media (width < 768px) {
    grid-template-columns: 1fr;
  }
}

.staff-interview-head__wrap {
  @media (width < 768px) {
    order: 2;
  }
}

.staff-interview-head__title-block {
  background: linear-gradient(89deg, rgba(236, 244, 234, 1) 0%, rgba(88, 191, 88, 1) 100%);
  padding: calc(40 * var(--rem)) calc(20 * var(--rem));
  @media (width < 768px) {
    padding: calc(20 * var(--rem));
  }
}

.staff-interview-head__mate {
  display: inline-grid;
  grid-template-columns: repeat(2, auto);
  gap: calc(24 * var(--rem));
  align-items: center;
}

.staff-interview-head__position {
  border: 1px solid var(--green);
  padding: calc(2 * var(--rem)) calc(8 * var(--rem));
  background-color: var(--green);
  color: var(--white);
}

.staff-interview-head__position,
.staff-interview-head__years {
  font-size: calc(20 * var(--rem));
  font-weight: 400;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.staff-interview-head__name {
  font-size: calc(40 * var(--rem));
  margin-block-start: calc(8 * var(--rem));
  line-height: 1;
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
  }
}

.staff-interview-head__text {
  margin-block-start: calc(40 * var(--rem));
  padding-inline: calc(20 * var(--rem));
  line-height: 2;
  @media (width < 768px) {
    margin-block-start: calc(24 * var(--rem));
  }
}

.staff-interview-head__img {
  @media (width < 768px) {
    order: 1;
  }
}

.staff-interview-head__img img {
  aspect-ratio: 2560 / 1707;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.staff-interview-head__img img.noimage {
  width: 90%;
  object-fit: contain;
  margin-inline: auto;
}

/* *************************************
faq
************************************* */
.faq {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

/* *************************************
senior-message
************************************* */
.senior-message {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.senior-message__container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(24 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
  }
}

.senior-message__img img {
  aspect-ratio: 1400/960;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.senior-message__img img.noimage {
  width: 90%;
  object-fit: contain;
  margin-inline: auto;
}

.senior-message__wrap {
}

.senior-message__text {
  margin-block-start: calc(40 * var(--rem));
  padding-block: calc(16 * var(--rem));
  padding-inline-start: calc(16 * var(--rem));
  border-left: 2px solid var(--green);
  @media (width < 768px) {
    margin-block-start: calc(24 * var(--rem));
  }
}

.senior-message__text p {
  margin-block-end: 1en;
}

.senior-message__btn {
  margin-block-start: calc(40 * var(--rem));
  text-align: center;
  @media (width < 768px) {
  }
}

/* *************************************
staff-interview-archive
************************************* */
.staff-interview-archive {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.staff-interview-archive__pagination {
  margin-block-start: calc(40 * var(--rem));
}

/* *************************************
columns
************************************* */
.columns {
  margin-block-start: calc(104 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(80 * var(--rem));
  }
}

.columns__inner.inner {
  width: min(100%, calc(1000 * var(--rem)));
}

.columns__time {
  font-size: calc(18 * var(--rem));
}

.columns__cat {
  width: fit-content;
  margin-inline: auto;
  margin-block-start: calc(8 * var(--rem));
  background-color: var(--green);
  padding: calc(4 * var(--rem)) calc(8 * var(--rem));
  color: var(--white);
  text-transform: uppercase;
}

.columns__title {
  margin-block-start: calc(24 * var(--rem));
  margin-inline: auto;
  width: fit-content;
  padding-inline: calc(8 * var(--rem));
  padding-block-end: calc(4 * var(--rem));
  border-bottom: 1px solid var(--green);
}

.columns__content {
  margin-block-start: calc(40 * var(--rem));
}

.columns__btn {
  margin-block-start: calc(80 * var(--rem));
  text-align: center;
}

/* *************************************
the-content
************************************* */
.the-content {
  img.alignright {
    display: block;
    margin: 0 0 0 auto;
  }
  img.alignleft {
    display: block;
    margin: 0 auto 0 0;
  }
  img.aligncenter {
    display: block;
    margin: 0 auto;
  }

  p {
    margin-block-end: 1em;
  }
}

/* *************************************
privacy-policy
************************************* */
.privacy-policy {
  margin-block-start: calc(80 * var(--rem));
}

body.privacy-policy {
  margin: 0;
}

.privacy-policy__inner.inner {
  width: min(100%, calc(1000 * var(--rem)));
}

.privacy-policy__wrap {
  margin-block-start: calc(80 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(40 * var(--rem));
  }
}

.privacy-policy__contents {
  h3 {
    margin-block-end: calc(8 * var(--rem));
  }

  p.center {
    text-align: center;
  }

  p {
    margin-block-end: 1em;
  }

  ul {
    margin-block-end: calc(16 * var(--rem));
    display: grid;
    gap: calc(8 * var(--rem));
  }

  ul > li {
    position: relative;
    padding-inline-start: calc(10 * var(--rem));
  }

  ul > li::before {
    content: '';
    display: block;
    width: calc(4 * var(--rem));
    aspect-ratio: 1;
    background-color: var(--green);
    border-radius: 100vmax;
    position: absolute;
    top: calc(12 * var(--rem));
    left: 0;
  }

  ol {
    margin-block-end: calc(16 * var(--rem));
    display: grid;
    gap: calc(8 * var(--rem));
  }

  ol > li {
    display: grid;
    grid-template-columns: calc(20 * var(--rem)) 1fr;
    gap: calc(8 * var(--rem));
    counter-increment: num;
  }

  ol > li::before {
    content: counter(num, decimal-leading) '.';
  }

  dl {
    div {
      display: grid;
      grid-template-columns: auto 1fr;
      gap: calc(8 * var(--rem));
    }
  }
}
