@charset "utf-8";
/* *************************************
header
************************************* */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 500;
  background-color: transparent;
  height: var(--header-height-pc);
  transition:
    background-color 0.3s ease-out,
    filter 0.3s ease-out;
  @media (width < 768px) {
    height: var(--header-height-sp);
  }
}

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

.header.is-color {
  background-color: var(--white);
  filter: drop-shadow(0px 5px 10px rgb(0 0 0 / 0.2));
}

.header__inner {
  padding-inline: calc(70 * var(--rem));
  @media (width < 768px) {
    padding-inline: 10px;
  }
}

.header__container {
  display: flex;
  align-items: center;
  gap: calc(24 * var(--rem));
  align-items: center;
  height: var(--header-height-pc);
  @media (width < 768px) {
    height: var(--header-height-sp);
  }
}

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

.header__logo img {
  aspect-ratio: 300 /41;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.header.is-active .header__logo-w,
.header.is-color .header__logo-w,
.header.not-front .header__logo-w {
  display: none;
}

.header__logo-k {
  display: none;
}

.header.is-active .header__logo-k,
.header.is-color .header__logo-k,
.header.not-front .header__logo-k {
  display: block;
}

.header__hamburger {
  display: none;
  @media (width < 768px) {
    display: block;
    margin-inline-start: auto;
  }
}

.header__modal {
  display: contents;
  @media (width < 768px) {
    display: block;
    position: fixed;
    top: var(--header-height-sp);
    left: 0;
    width: 100%;
    height: calc(100vh - var(--header-height-sp));
    background-color: var(--white);
    padding-inline: 10px;
    overflow: auto;
    visibility: hidden;
    opacity: 0;
    transition:
      visibility 0.3s ease-out,
      opacity 0.3s ease-out;
  }
}

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

.header__nav {
  margin-inline-start: auto;
  @media (width < 768px) {
    width: min(100%, calc(600 * var(--rem)));
    margin-inline: auto;
    min-height: calc(550 * var(--rem));
    padding-block-end: calc(40 * var(--rem));
  }
}

.header__list {
  display: flex;
  align-items: center;
  gap: calc(8 * var(--rem));
  height: var(--header-height-pc);
  @media (width < 768px) {
    display: grid;
    margin-block-start: calc(80 * var(--rem));
    gap: calc(16 * var(--rem));
  }
}

.header__link {
  display: inline-block;
  min-width: calc(90 * var(--rem));
  text-align: center;
  padding: calc(4 * var(--rem)) calc(16 * var(--rem));
  font-size: calc(14 * var(--rem));
  font-weight: bold;
  color: var(--white);
  border: 1px solid var(--white);
  transition:
    color 0.3s ease-out,
    border-color 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
    color: var(--text);
    border: none;
    border-bottom: 1px solid var(--blue);
    display: block;
    text-align: left;
    padding-block: calc(10 * var(--rem)) calc(4 * var(--rem));
    padding-inline: calc(4 * var(--rem));
  }
}

@media (any-hover: hover) {
  .header__link:hover {
    opacity: 0.7;
  }
}

.header.is-color .header__link,
.header.not-front .header__link {
  color: var(--text);
  border-color: var(--block);
  @media (width < 768px) {
    border-color: var(--blue);
  }
}

.header__item:has(.header__link[data-item='recruit']) {
  margin-inline-start: calc(7 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(64 * var(--rem));
    width: calc(300 * var(--rem));
    margin-inline: auto;
  }
}

.header__item:has(.header__link[data-item='contact']) {
  margin-inline-start: calc(10 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(16 * var(--rem));
    width: calc(300 * var(--rem));
    margin-inline: auto;
  }
}

.header__link[data-item='recruit'],
.header__link[data-item='contact'] {
  border: none;
  min-width: calc(132 * var(--rem));
  font-size: calc(20 * var(--rem));
  padding: calc(4 * var(--rem));
  border-radius: calc(20 * var(--rem));
  @media (width < 768px) {
    color: var(--white);
    text-align: center;
    padding-block: calc(16 * var(--rem));
  }
}

.header.is-color .header__link[data-item='recruit'],
.header.is-color .header__link[data-item='contact'],
.header.not-front .header__link[data-item='recruit'],
.header.not-front .header__link[data-item='contact'] {
  color: var(--white);
}

.header__link[data-item='recruit'] {
  background-color: var(--red);
}

.header__link[data-item='contact'] {
  background: linear-gradient(90deg, #009944 0%, #0068b7 100%);
}

/* *************************************
footer
************************************* */
.footer {
  background-color: var(--navy);
  padding-block: calc(60 * var(--rem)) calc(72 * var(--rem));
  margin-block-start: calc(-1 * var(--rem));
}

.footer__inner {
  padding-inline: calc(80 * var(--rem)) calc(44 * var(--rem));
  @media (width < 768px) {
    padding-inline: calc(10 * var(--rem));
  }
}

.footer__container {
  display: flex;
  @media (width < 768px) {
    display: grid;
    width: min(100%, calc(400 * var(--rem)));
    margin-inline: auto;
  }
}

.footer__start {
  @media (width < 768px) {
    display: contents;
  }
}

.footer__logo {
  display: block;
  width: calc(315 * var(--rem));
  @media (width < 768px) {
    margin-inline: auto;
    order: 1;
  }
}

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

.footer__title {
  margin-block-start: calc(17 * var(--rem));
  @media (width < 768px) {
    order: 4;
    margin-block-start: calc(40 * var(--rem));
  }
}

.footer__title-jp {
  font-size: calc(15 * var(--rem));
  color: var(--white);
  font-weight: 500;
  line-height: 1;
  @media (width < 768px) {
    text-align: center;
  }
}

.footer__title-en {
  margin-block-start: calc(10 * var(--rem));
  font-size: calc(15 * var(--rem));
  color: var(--white);
  font-weight: 500;
  line-height: 1;
  @media (width < 768px) {
    text-align: center;
  }
}

.footer__meta {
  margin-block-start: calc(35 * var(--rem));
  @media (width < 768px) {
    order: 5;
  }
}

.footer__address {
  font-size: calc(15 * var(--rem));
  color: var(--white);
  line-height: 1;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  @media (width < 768px) {
    text-align: center;
  }
}

.footer__contact {
  font-size: calc(15 * var(--rem));
  color: var(--white);
  line-height: 1;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-block-start: calc(10 * var(--rem));
  @media (width < 768px) {
    text-align: center;
  }
}

.footer__end {
  margin-inline-start: auto;
  @media (width < 768px) {
    display: contents;
  }
}

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

.footer__item {
}

.footer__link {
  display: block;
  color: var(--white);
  font-size: calc(18 * var(--rem));
  padding: calc(10 * var(--rem)) calc(7 * var(--rem));
  text-align: center;
}

.footer__sublist {
  width: fit-content;
  margin-inline: auto calc(15 * var(--rem));
  @media (width < 768px) {
    order: 3;
    margin-inline: auto;
    margin-block-start: calc(24 * var(--rem));
  }
}

.footer__sublink {
  display: block;
  color: var(--white);
  font-size: calc(11 * var(--rem));
  padding: calc(8 * var(--rem)) calc(10 * var(--rem));
  text-align: right;
  @media (width < 768px) {
    text-align: center;
  }
}

.footer__copy {
  width: fit-content;
  color: var(--white);
  font-size: calc(12 * var(--rem));
  margin-block-start: calc(68 * var(--rem));
  margin-inline: auto calc(30 * var(--rem));
  @media (width < 768px) {
    order: 6;
    margin-inline: auto;
  }
}

/* *************************************
thanks & page-404
************************************* */
.thanks,
.page-404 {
  margin-block-start: calc(80 * var(--rem));
  padding-block-end: calc(80 * 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: 100vh;
  position: relative;
}

.mv__img {
  height: inherit;
}

.mv__img img {
  aspect-ratio: 2401 /1401;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mv__text-block {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  @media (width < 768px) {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
  }
}

.mv__text-start {
  position: relative;
  @media (width < 768px) {
    position: static;
    order: 2;
    padding-inline: calc(10 * var(--rem));
    width: fit-content;
    margin-inline: auto;
  }
}

.mv__text-start-wrap {
  position: absolute;
  top: 50%;
  left: 10%;
  transform: translate(0%, -50%);
  width: 100%;
  @media (width < 768px) {
    display: contents;
  }
}

.mv__text {
  width: 100%;
  display: grid;
  gap: calc(16 * var(--rem));
  /* position: absolute;
  top: 23%;
  left: 10%; */
  @media (width < 768px) {
    position: static;
    gap: calc(10 * var(--rem));
  }
}

.mv__text span {
  display: block;
  width: fit-content;
  line-height: 1;
}

.mv__text span:nth-child(1) {
  color: var(--red);
  font-size: calc(38 * var(--rem));
  font-weight: 900;
  border: calc(2 * var(--rem)) solid var(--red);
  padding: calc(8 * var(--rem)) calc(10 * var(--rem));
  @media (width < 768px) {
    font-size: calc(28 * var(--rem));
  }
}

.mv__text span:nth-child(2),
.mv__text span:nth-child(3) {
  font-size: calc(30 * var(--rem));
  font-weight: 900;
  background-color: var(--red);
  padding: calc(6 * var(--rem)) calc(4 * var(--rem));
  @media (width < 768px) {
    font-size: calc(28 * var(--rem));
  }
}

.mv_subtitle {
  font-size: calc(30 * var(--rem));
  color: var(--white);
  font-feature-settings: 'palt';
  font-kerning: auto;
  /* position: absolute;
  top: 44%;
  left: 10%; */
  @media (width < 768px) {
    position: static;
    margin-block-start: calc(24 * var(--rem));
  }
}

.mv_subtitle span {
  display: block;
  color: var(--red);
  font-size: calc(50 * var(--rem));
  font-weight: 900;
  @media (width < 768px) {
    font-size: calc(32 * var(--rem));
  }
}

.mv__text-end {
  position: relative;
  @media (width < 768px) {
    order: 1;
  }
}

.mv_title {
  /* position: absolute;
  top: 17%;
  left: 22%; */
  position: absolute;
  top: 50%;
  left: 60%;
  transform: translate(-50%, -50%);
  height: 100%;
  display: grid;
  justify-items: center;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: calc(120 * var(--rem));
  font-weight: 900;
  color: var(--red);
  @media (width < 768px) {
    display: block;
    position: static;
    width: fit-content;
    margin-block: auto;
    margin-inline-start: calc(var(--header-height-sp) + calc(20 * var(--rem)));
    font-size: calc(60 * var(--rem));
    transform: translate(0);
    height: auto;
  }
}

/* *************************************
top-about
************************************* */
.top-about {
  position: relative;
}

.top-about__slider {
}

.top-about__wrap {
  position: absolute;
  top: 35%;
  left: 18%;
  transform: translate(-50%, -50%);
  z-index: 100;
  @media (width < 768px) {
    top: 50%;
    left: 50%;
  }
}

.top-about__title {
  font-size: calc(80 * var(--rem));
  font-weight: 900;
  line-height: 1;
  color: var(--green);
  @media (width < 768px) {
    font-size: calc(60 * var(--rem));
  }
}

.top-about__btn {
  margin-block-start: calc(20 * var(--rem));
}

/* *************************************
top-news
************************************* */
.top-news {
  background-color: var(--blue);
  padding-block: calc(50 * var(--rem)) calc(40 * var(--rem));
}

.top-news__inner.inner {
  width: min(100%, calc(1115 * var(--rem)));
}

.top-news__container {
  background-color: var(--white);
  border-radius: calc(20 * var(--rem));
  padding-block: calc(30 * var(--rem)) calc(40 * var(--rem));
  padding-inline: calc(122 * var(--rem));
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(92 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    padding-inline: calc(20 * var(--rem));
    gap: calc(24 * var(--rem));
  }
}

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

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

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

.top-access__inner.inner {
  width: min(100%, calc(1350 * var(--rem)));
}

.top-access__title {
  margin-inline-start: calc(86 * var(--rem));
  @media (width < 768px) {
    margin-inline-start: 0;
    text-align: center;
  }
}

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

.top-access__wrap {
  margin-inline-start: calc(86 * var(--rem));
  @media (width < 768px) {
    margin-inline: 0;
    order: 2;
  }
}

.top-access__subtitle1 {
  font-size: calc(26 * var(--rem));
  font-weight: 500;
  color: var(--blue);
  margin-block-start: calc(38 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(24 * var(--rem));
  }
}

.top-access__list1 {
  margin-block-start: calc(10 * var(--rem));
}

.top-access__subtitle2 {
  font-size: calc(26 * var(--rem));
  font-weight: 500;
  color: var(--blue);
  margin-block-start: calc(18 * var(--rem));
}

.top-access__route {
  color: var(--blue);
}

.top-access__list2 {
  margin-block-start: calc(2 * var(--rem));
}

.top-access__map {
}

.top-access__map iframe {
  aspect-ratio: 579 /325;
  width: 100%;
  height: 100%;
  object-fit: cover;
  @media (width < 768px) {
    aspect-ratio: 1;
  }
}

.top-access__img {
  margin-block-start: calc(38 * var(--rem));
}

.top-access__img img {
  aspect-ratio: 1440 / 551;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
strengths
************************************* */
.strengths {
  margin-block-start: calc(50 * var(--rem));
}

.strengths__container {
  margin-block-start: calc(18 * var(--rem));
  margin-inline-start: calc(18 * var(--rem));
  @media (width < 768px) {
    margin-inline-start: 0;
  }
}

.strengths__content + .strengths__content {
  margin-block-start: calc(22 * var(--rem));
}

.strengths__subtitle {
  font-size: calc(30 * var(--rem));
  font-weight: 500;
  @media (width < 768px) {
    font-size: calc(24 * var(--rem));
  }
}

.strengths__list {
  margin-inline-start: calc(4 * var(--rem));
  margin-block-start: calc(4 * var(--rem));
  display: grid;
  gap: calc(4 * var(--rem));
}

.strengths__item {
  font-size: calc(20 * var(--rem));
  display: inline-grid;
  grid-template-columns: auto 1fr;
  gap: calc(4 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.strengths__item::before {
  content: '';
  display: inline-block;
  width: 0.15lh;
  aspect-ratio: 1;
  background-color: var(--black);
  border-radius: 100vmax;
  margin-block-start: calc(14 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(12 * var(--rem));
  }
}

/* *************************************
introduction
************************************* */
.introduction {
  margin-block-start: calc(60 * var(--rem));
  padding-block-end: calc(55 * var(--rem));
}

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

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

.introduction__content + .introduction__content {
  margin-block-start: calc(30 * var(--rem));
}

.introduction__text {
  margin-block-start: calc(4 * var(--rem));
  font-size: calc(20 * var(--rem));
  letter-spacing: -0.05em;
}

.introduction__img {
  width: 114%;
  margin-block-start: calc(-70 * var(--rem));
  margin-inline-start: calc(-103 * var(--rem));
  position: relative;
  z-index: 1;
  @media (width < 768px) {
    position: static;
    margin: 0;
    width: 80%;
    margin-inline: auto;
    order: 1;
  }
}

.introduction__img img {
  aspect-ratio: 613 /423;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

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

/* *************************************
process-flow
************************************* */
.process-flow {
  margin-block-start: calc(25 * var(--rem));
}

.process-flow__title {
  font-size: calc(50 * var(--rem));
  color: var(--blue);
  font-weight: 500;
  letter-spacing: -0.07em;
  @media (width < 768px) {
    font-size: calc(35 * var(--rem));
  }
}

.process-flow__list {
  margin-block-start: calc(26 * var(--rem));
  padding-inline: calc(55 * var(--rem));
  @media (width < 768px) {
    padding-inline: 0;
  }
}

/* *************************************
manufacturing-flow
************************************* */
.manufacturing-flow {
  margin-block-start: calc(37 * var(--rem));
  padding-bottom: calc(87 * var(--rem));
}

.manufacturing-flow__bg {
  background: url(../../library/images/flow/manufacturing-flow-bg.webp) no-repeat center / contain;
  min-height: calc(1543 * var(--rem));
  padding-block-end: calc(64 * var(--rem));
  @media (width < 768px) {
    background-size: cover;
  }
}

.manufacturing-flow__inner.inner {
  width: min(100%, calc(1245 * var(--rem)));
}

.manufacturing-flow__lead {
  font-size: calc(45 * var(--rem));
  color: var(--blue);
  font-weight: 500;
  line-height: 1.3;
  padding-block-start: calc(19 * var(--rem));
  font-feature-settings: 'palt';
  font-kerning: auto;
  @media (width < 768px) {
    font-size: calc(27 * var(--rem));
  }
}

.manufacturing-flow__title {
  margin-block-start: calc(32 * var(--rem));
}

.manufacturing-flow__title-main {
  font-size: calc(40 * var(--rem));
  @media (width < 768px) {
    font-size: calc(35 * var(--rem));
  }
}

.manufacturing-flow__title-sub {
  font-size: calc(24 * var(--rem));
  font-weight: bold;
  letter-spacing: -0.01em;
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.manufacturing-flow__note {
  font-size: calc(18 * var(--rem));
  font-weight: bold;
  margin-block-start: calc(16 * var(--rem));
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(4 * var(--rem));
  line-height: 1;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.manufacturing-flow__note::before {
  content: '';
  display: inline-block;
  width: 1lh;
  aspect-ratio: 1;
  background-color: var(--text);
  letter-spacing: -0.01em;
  @media (width < 768px) {
    width: 0.7lh;
    margin-block-start: calc(4 * var(--rem));
  }
}

.manufacturing-flow__list {
  margin-block-start: calc(27 * var(--rem));
}

.manufacturing-flow__tables {
  margin-block-start: calc(40 * var(--rem));
  @media (width < 768px) {
    margin-block-start: calc(64 * var(--rem));
  }
}

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

.manufacturing-flow__table-title {
  font-size: calc(26 * var(--rem));
  color: var(--blue);
}

.manufacturing-flow__table-content {
  margin-block-start: calc(22 * var(--rem));
}

/* *************************************
member
************************************* */
.member {
  margin-block-start: calc(86 * var(--rem));
  padding-block-end: calc(46 * var(--rem));
}

/* *************************************
environment-contents
************************************* */
.environment-contents {
  padding-block-start: calc(32 * var(--rem));
}

.environment-contents:last-child {
  padding-block-end: calc(34 * var(--rem));
}

.environment-contents__inner.inner {
  width: min(100%, 1324px);
}

.environment-contents__container {
  border-bottom: 1px solid #231815;
  padding-block-end: calc(38 * var(--rem));
}

.environment-contents:last-child .environment-contents__container {
  border: none;
}

.environment-contents__title {
  font-size: calc(47 * var(--rem));
  font-weight: 500;
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
  }
}

.environment-contents__text {
  margin-block-start: calc(17 * var(--rem));
  font-size: calc(20 * var(--rem));
  line-height: 1.7;
  letter-spacing: 0.04em;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.environment-contents__text[data-spacing='cramped'] {
  letter-spacing: -0.05em;
}

.environment-contents__num-list {
  margin-block-start: calc(15 * var(--rem));
  @media (width < 768px) {
    display: grid;
    gap: calc(8 * var(--rem));
  }
}

.environment-contents__num-item {
  font-size: calc(20 * var(--rem));
  line-height: 1.7;
  letter-spacing: 0em;
  counter-increment: num;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(8 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.environment-contents__num-item::before {
  content: counter(num, decimal-leading) '.';
  display: inline-block;
  font-size: calc(22 * var(--rem));
  margin-block-start: calc(-3 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.environment-contents__wrap {
  display: grid;
  grid-template-columns: 5.8fr 4.2fr;
  gap: calc(40 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
  }
}

.environment-contents__images {
  display: grid;
  grid-template-columns: 5.5fr 4.5fr;
  align-items: center;
  gap: calc(15 * var(--rem));
  @media (width < 768px) {
    justify-items: center;
  }
}

.environment-contents__img1 {
  width: 98%;
}

.environment-contents__img1 img {
  aspect-ratio: 229 /107;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.environment-contents__img2 {
  width: 42%;
}

.environment-contents__img2 img {
  aspect-ratio: 80/109;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.environment-contents__subtitle {
  margin-block-start: calc(50 * var(--rem));
  font-size: calc(30 * var(--rem));
  font-weight: 500;
  padding-left: 1em;
  text-indent: -1em;
  @media (width < 768px) {
    font-size: calc(24 * var(--rem));
    margin-block-start: calc(32 * var(--rem));
  }
}

.environment-contents__wrap2 {
  display: grid;
  grid-template-columns: 7fr 3fr;
  align-items: center;
  gap: calc(24 * var(--rem));
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(40 * var(--rem));
  }
}

.environment-contents__img3 {
  width: 30%;
  @media (width < 768px) {
    margin-inline: auto;
  }
}

.environment-contents__img3 img {
  aspect-ratio: 87/ 175;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* *************************************
message
************************************* */
.message {
  margin-block-start: calc(26 * var(--rem));
}

.message__inner.inner {
  width: min(100%, 1327px);
}

.message__title {
  display: flex;
  gap: calc(7 * var(--rem));
  align-items: flex-end;
  @media (width < 768px) {
    display: grid;
  }
}

.message__title-en {
  font-size: calc(50 * var(--rem));
  font-weight: 500;
  line-height: 1;
  color: var(--blue);
  text-transform: uppercase;
  @media (width < 768px) {
    font-size: calc(40 * var(--rem));
  }
}

.message__title-jp {
  font-size: calc(26 * var(--rem));
  font-weight: 500;
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

.message__container {
  display: grid;
  grid-template-columns: 6.7fr 3.3fr;
  gap: calc(67 * var(--rem));
  align-items: self-start;
  @media (width < 768px) {
    grid-template-columns: 1fr;
    gap: calc(24 * var(--rem));
    margin-block-start: calc(16 * var(--rem));
  }
}

.message__text-block {
  @media (width < 768px) {
    order: 2;
  }
}

.message__text {
  font-size: calc(18 * var(--rem));
  letter-spacing: 0.06em;
  line-height: 1.6;
  margin-block-start: calc(25 * var(--rem));
  @media (width < 768px) {
    margin-block-start: 0;
    font-size: calc(16 * var(--rem));
  }
}

.message__name {
  text-align: right;
  margin-block-start: calc(11 * var(--rem));
  letter-spacing: 0.08em;
}

.message__name span {
  font-size: calc(22 * var(--rem));
}

.message__img {
  margin-block-start: calc(30 * var(--rem));
  width: 97%;
  @media (width < 768px) {
    width: 100%;
    order: 1;
    margin-block-start: 0;
  }
}

.message__img img {
  aspect-ratio: 325 / 269;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* *************************************
corporate-philosophy
************************************* */
.corporate-philosophy {
  margin-block-start: calc(82 * var(--rem));
}

.corporate-philosophy__inner.inner {
  width: min(100%, 1105px);
}

.corporate-philosophy__wrap {
  border: calc(2 * var(--rem)) solid #231815;
  padding-block: calc(28 * var(--rem)) calc(38 * var(--rem));
  padding-inline: calc(24 * var(--rem));
  @media (width < 768px) {
    padding-inline: calc(16 * var(--rem));
  }
}

.corporate-philosophy__title {
  font-size: calc(50 * var(--rem));
  line-height: 1;
  color: var(--blue);
  text-align: center;
  @media (width < 768px) {
    font-size: calc(40 * var(--rem));
  }
}

.corporate-philosophy__text {
  text-align: center;
  margin-block-start: calc(20 * var(--rem));
  font-size: calc(30 * var(--rem));
  font-weight: 500;
  font-family: var(--serif);
  letter-spacing: 0.02em;
  line-height: 1.9;
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

/* *************************************
about-container
************************************* */
.about-container {
  margin-block-start: calc(55 * var(--rem));
  padding-block-end: calc(70 * var(--rem));
}

.about-container__inner.inner {
  width: min(100%, 1283px);
}

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

/* *************************************
overview
************************************* */
.overview {
}

.overview__title {
  font-size: calc(50 * var(--rem));
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(40 * var(--rem));
    text-align: center;
  }
}

.overview__table {
  margin-block-start: calc(29 * var(--rem));
  margin-inline-start: calc(5 * var(--rem));
}

.overview__img {
  margin-block-start: calc(43 * var(--rem));
  width: 93%;
  margin-inline-start: auto;
  @media (width < 768px) {
    width: 100%;
    margin-inline: auto;
  }
}

.overview__img img {
  aspect-ratio: 450 / 253;
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* *************************************
history
************************************* */
.history {
}

.history__title {
  font-size: calc(50 * var(--rem));
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(40 * var(--rem));
    text-align: center;
  }
}

.history__table {
  margin-block-start: calc(29 * var(--rem));
  margin-inline-start: calc(5 * var(--rem));
}

/* *************************************
recruit-lead
************************************* */
.recruit-lead {
  margin-block-start: calc(33 * var(--rem));
}

.recruit-lead__inner.inner {
  width: min(100%, 1310px);
}

.recruit-lead__text {
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.03em;
  line-height: 1.7;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

/* *************************************
recruit
************************************* */
.recruit {
  margin-block-start: calc(50 * var(--rem));
  padding-block-end: calc(80 * var(--rem));
}

.recruit__inner.inner {
  width: min(100%, 1200px);
}

.recruit__title {
  font-size: calc(50 * var(--rem));
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(40 * var(--rem));
    text-align: center;
  }
}

.recruit__table {
  margin-block-start: calc(18 * var(--rem));
  display: grid;
  gap: calc(16 * var(--rem));
}

.recruit__table-item {
  display: grid;
  grid-template-columns: auto 1fr;
}

.recruit__table-item dt,
.recruit__table-item dd {
  font-size: calc(22 * var(--rem));
  font-weight: 500;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.recruit__subtitle {
  margin-block-start: calc(57 * var(--rem));
  font-size: calc(24 * var(--rem));
  font-weight: 500;
}

.recruit__text {
  font-size: calc(22 * var(--rem));
  letter-spacing: 0.03em;
  line-height: 2;
  margin-block-start: calc(8 * var(--rem));
  font-weight: 500;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

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

/* *************************************
contact
************************************* */
.contact {
  margin-block-start: calc(80 * var(--rem));
  padding-block-end: calc(80 * var(--rem));
}

.contact__inner.inner {
  width: min(100%, 1200px);
}

.contact__title {
  font-size: calc(50 * var(--rem));
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
    text-align: center;
  }
}

.contact__lead {
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.03em;
  line-height: 1.7;
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

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

/* *************************************
site-usage
************************************* */
.site-usage {
  margin-block-start: calc(80 * var(--rem));
  padding-block-end: calc(80 * var(--rem));
}

.site-usage__title {
  font-size: calc(50 * var(--rem));
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
    text-align: center;
  }
}

.site-usage__lead {
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.03em;
  line-height: 1.7;
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.site-usage__num-list {
  display: grid;
  gap: calc(32 * var(--rem));
  margin-block-start: calc(40 * var(--rem));
  @media (width < 768px) {
    gap: calc(24 * var(--rem));
  }
}

.site-usage__num-item {
  counter-increment: num;
  padding-left: 1em;
  text-indent: -1em;
  font-size: calc(18 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.site-usage__num-item::before {
  content: counter(num, decimal-leading) '.';
  font-size: calc(20 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.site-usage__text {
  font-size: calc(18 * var(--rem));
  margin-block-start: calc(40 * var(--rem));
  font-weight: bold;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

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

.privacy__title {
  font-size: calc(50 * var(--rem));
  line-height: 1;
  color: var(--blue);
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
    text-align: center;
  }
}

.privacy__lead {
  font-size: calc(20 * var(--rem));
  letter-spacing: 0.03em;
  line-height: 1.7;
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.privacy__top-list {
  display: grid;
  gap: calc(32 * var(--rem));
  margin-block-start: calc(40 * var(--rem));
  @media (width < 768px) {
    gap: calc(24 * var(--rem));
  }
}

.privacy__top-item {
  counter-increment: num;
  padding-left: 1em;
  text-indent: -1em;
  font-size: calc(18 * var(--rem));
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.privacy__top-item::before {
  content: counter(num, decimal-leading) '.';
  font-size: calc(20 * var(--rem));
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.privacy__top-item span {
  display: block;
  font-size: calc(16 * var(--rem));
  margin-block-start: calc(8 * var(--rem));
}

.privacy__subtitle {
  margin-block-start: calc(40 * var(--rem));
  color: var(--blue);
  font-size: calc(26 * var(--rem));
  @media (width < 768px) {
    font-size: calc(22 * var(--rem));
  }
}

.privacy__bottom-list {
  display: grid;
  gap: calc(32 * var(--rem));
  margin-block-start: calc(24 * var(--rem));
  @media (width < 768px) {
    gap: calc(24 * var(--rem));
  }
}

.privacy__bottom-item {
  counter-increment: num;
}

.privacy__bottom-title {
  font-size: calc(18 * var(--rem));
  letter-spacing: 0.03em;
  line-height: 1.7;
}

.privacy__bottom-title::before {
  content: counter(num, decimal-leading) '.';
}

.privacy__bottom-text {
  font-size: calc(18 * var(--rem));
  padding-inline-start: 1em;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

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

.privacy__contact-text,
.privacy__tel,
.privacy__fax {
  font-size: calc(18 * var(--rem));
  letter-spacing: 0.03em;
  line-height: 1.6;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

.privacy__tel {
  display: inline-block;
  margin-block-start: calc(16 * var(--rem));
  padding: calc(5 * var(--rem)) calc(10 * var(--rem));
}

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

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

.news-archive__inner.inner {
  width: min(100%, 1000px);
}

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

.news-archive__pagination {
  margin-block-start: calc(80 * var(--rem));
}

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

.post-single__inner.inner {
  width: min(100%, 1000px);
}

.post-single__time {
  display: block;
  text-align: center;
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  @media (width < 768px) {
    font-size: calc(18 * var(--rem));
  }
}

.post-single__cat {
  display: block;
  width: fit-content;
  min-width: calc(111 * var(--rem));
  margin-inline: auto;
  background-color: var(--blue);
  padding-block: calc(4 * var(--rem));
  padding-inline: calc(8 * var(--rem));
  font-size: calc(14 * var(--rem));
  color: var(--white);
  text-align: center;
  border-radius: calc(6 * var(--rem));
  margin-block-start: calc(8 * var(--rem));
}

.post-single__title {
  border-bottom: calc(2 * var(--rem)) solid var(--blue);
  margin-block-start: calc(16 * var(--rem));
  padding-block-end: calc(8 * var(--rem));
  padding-inline: calc(4 * var(--rem));
  width: fit-content;
  margin-inline: auto;
  @media (width < 768px) {
    font-size: calc(20 * var(--rem));
  }
}

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

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