@layer reset, base, components, pages, utilities;

:root {
  --color-main-blue: #0543aa;
  --color-dark-blue: #030a4b;
  --color-middle-blue: #02307d;
  --color-orange: #ff9d00;
  --color-parl-gray: #eff2f6;
  --color-blue-gray: #bacae0;
  --color-dark-gray: #617086;
  --color-blube-black: #2e3c50;
  --color-pale-blue-gray: #e3eaf3;
  --color-accent-blue: #0f5bff;
  --color-red: #f6331a;
  --color-white: #fff;
  --width-contents: 1200px;
  --font-family-notosans: 'Noto Sans JP', sans-serif;
  --font-family-figtree: 'Figtree', sans-serif;
  --border-radius-full: 100vmax;
  --border-radius-button: 44px;
  --transition-hover: 0.3s cubic-bezier(0.13, 0.78, 0.38, 0.98);
  --transition-fade: 0.5s cubic-bezier(0.44, 0.03, 0.14, 0.98);
  --timing-function-arrow-forward: cubic-bezier(0.215, 0.61, 0.355, 1);
  --z-index-header: 100;
  --height-header: 83px;
  --basic-letter-spacing: calc(1em * 0.01);
}

@media (width < 768px) {
  :root {
    --height-header: 72px;
  }
}

@layer reset{

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  text-size-adjust: none;
}

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

ul,
ol {
  padding: 0;
  margin: 0;
  list-style: none;
}

body {
  min-height: 100vh;
  line-height: 1.5;
}

h1,
h2,
h3,
h4,
button,
input,
label {
  line-height: 1.1;
}

a {
  color: currentcolor;
  text-decoration-skip-ink: auto;
}

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

input,
button,
textarea,
select {
  font: inherit;
}

textarea:not([rows]) {
  min-height: 10em;
}

:target {
  scroll-margin-block: 5ex;
}
}

@layer base{

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

:target {
  scroll-margin-top: 83px;
}

body {
  font-family: var(--font-family-notosans);
  font-size: 1.6rem; /* 16px */
  font-weight: normal;
  color: var(--color-blube-black);
  overflow-wrap: break-word;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;

  @media (width < 768px) {
    font-size: 1.5rem;
  }
}

button {
  padding: 0;
  margin: 0;
  appearance: none;
  cursor: pointer;
  background-color: transparent;
  border: none;
}

h1 {
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: calc(40px * 0.06);
}

h2 {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;

  &:not([class]) {
    margin-block: 80px 32px;
  }
}

h3 {
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.4;
  color: var(--color-main-blue);

  &:not([class]) {
    padding-bottom: 1em;
    margin-block: 40px 24px;
    border-bottom: 1px solid var(--color-blue-gray);
  }
}

h4,
h5,
h6 {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.4;

  &:not([class]) {
    margin-block: 24px 16px;
  }
}

p {
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: calc(1em * 0.01);
}

b,
strong {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: calc(1em * 0.01);

  &:not([class]) {
    display: inline-block;
    margin-block: 24px 16px;
    color: var(--color-main-blue);
  }
}

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

  @media (width < 768px) {
    width: 100%;
    max-width: initial;
  }
}

@media (width < 768px) {
  h1 {
    font-size: 2.4rem;
    line-height: 1.5;
  }

  h2 {
    font-size: 2.4rem;
    line-height: 1.5;

    &:not([class]) {
      margin-block: 64px 24px;
    }
  }

  h3 {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.35;

    &:not([class]) {
      margin-block: 32px 24px;
    }
  }

  h4,
  h5,
  h6 {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.5;
  }

  b,
  strong {
    font-size: 1.5rem;

    &:not([class]) {
      margin-block: 16px 8px;
    }
  }
}
}

@layer utilities{
/*
* テキスト配置
*/
.text-align-center {
  text-align: center;
}

.text-align-right {
  text-align: right;
}

/** 角丸画像 */
.image {
  border-radius: 4px;
}

/*
* テキストリンクの下線アニメーション
*/
.link-underline {
  text-decoration: none;

  @media (any-hover: hover) {
    background-image: linear-gradient(currentcolor, currentcolor);
    background-repeat: no-repeat;
    background-position: bottom left 0%;
    background-size: 0 1px;
    transition: var(--transition-hover);

    &:hover {
      text-decoration: none;
      background-position: bottom left 0%;
      background-size: 100% 1px;
    }
  }
}

/** フェードイン表示させる要素 */
.fadein {
  opacity: 0;
  transition: opacity 0.5s ease-in;

  &.fadein--active {
    opacity: 1;
  }
}

/**
* マージン
*/
.mt-0 {
  margin-block-start: 0;
}

.mb-0 {
  margin-block-end: 0;
}

.my-0 {
  margin-block: 0;
}

.mt-16 {
  margin-block-start: 16px;
}

.mb-16 {
  margin-block-end: 16px;
}

.my-16 {
  margin-block: 16px;
}

.mt-24 {
  margin-block-start: 24px;
}

.mb-24 {
  margin-block-end: 24px;
}

.my-24 {
  margin-block: 24px;
}

.mt-32 {
  margin-block-start: 32px;
}

.mb-32 {
  margin-block-end: 32px;
}

.my-32 {
  margin-block: 32px;
}

.mt-40 {
  margin-block-start: 40px;
}

.mb-40 {
  margin-block-end: 40px;
}

.my-40 {
  margin-block: 40px;
}

.mt-80 {
  margin-block-start: 80px;
}

.mb-80 {
  margin-block-end: 80px;
}

.my-80 {
  margin-block: 80px;
}

@media (width < 768px) {
  .mt-0-sp {
    margin-block-start: 0;
  }

  .mb-0-sp {
    margin-block-end: 0;
  }

  .my-0-sp {
    margin-block: 0;
  }

  .mt-16-sp {
    margin-block-start: 16px;
  }

  .mb-16-sp {
    margin-block-end: 16px;
  }

  .my-16-sp {
    margin-block: 16px;
  }

  .mt-24-sp {
    margin-block-start: 24px;
  }

  .mb-24-sp {
    margin-block-end: 24px;
  }

  .my-24-sp {
    margin-block: 24px;
  }

  .mt-32-sp {
    margin-block-start: 32px;
  }

  .mb-32-sp {
    margin-block-end: 32px;
  }

  .my-32-sp {
    margin-block: 32px;
  }

  .mt-40-sp {
    margin-block-start: 40px;
  }

  .mb-40-sp {
    margin-block-end: 40px;
  }

  .my-40-sp {
    margin-block: 40px;
  }

  .mt-80-sp {
    margin-block-start: 80px;
  }

  .mb-80-sp {
    margin-block-end: 80px;
  }

  .my-80-sp {
    margin-block: 80px;
  }
}
}

@keyframes arrow-forward {
  0% {
    transform: translate(0);
  }

  25% {
    opacity: 0;
    transform: translate(100%);
  }

  25.1% {
    opacity: 0;
    transform: translate(-100%);
  }

  100% {
    opacity: 1;
    transform: translate(0);
  }
}
@layer components {
    .footer-organization {
      display: flex;
      flex-direction: column;
      row-gap: 12px;
    }

    .footer-organization__address {
      font-size: 1.2rem;
      line-height: calc(21 / 12);
    }

    .footer-organization__address-title {
      font-weight: 700;
    }

    @media (width < 1280px) {
      .footer-organization__logo {
        width: 154px;
        height: 67px;
      }
    }
    @media (width < 1024px) {
      .footer-organization {
        align-items: center;
      }
      .footer-organization__address {
        text-align: center;
      }
    }
  }@layer components {
    .navigation-inquiry {
      display: flex;
      flex-direction: column;
      align-items: center;
      row-gap: 40px;
    }

    .navigation-inquiry__text {
      font-size: 2.4rem;
      font-weight: 500;
      line-height: calc(23 / 14);
      letter-spacing: 0.16em;
      text-align: center;
    }

    .navigation-inquiry__button {
      width: 100%;
      height: 77px;
      font-size: 1.6rem;
      letter-spacing: 0.05em;
      font-weight: 700;
      display: flex;
      justify-content: center;
      align-items: center;
      text-decoration: none;
      border-radius: 4px;
      background-color: var(--color-orange);
    }

    @media (width < 1024px) {
      .navigation-inquiry__button {
        width: calc(100% - 72px);
        min-width: 260px;
      }
    }
  }@layer components {
    .footer-menu {
      font-size: 1.4rem;
    }

    .footer-menu__title {
      font-size: 1.6rem;
      font-weight: 700;
      line-height: 1.28;
      color: var(--color-white);
    }

    .footer-menu__list {
      margin-top: 16px;
      display: flex;
      flex-direction: column;
      row-gap: 8px;
    }
  }@layer components {
    .footer-local-menu {
      display: flex;
      flex-direction: column;
      row-gap: 24px;
    }

    .footer-local-menu__header {
      width: fit-content;
      display: grid;
      grid-template-columns: repeat(2, auto);
      column-gap: 32px;
      align-items: center;
      text-decoration: none;
    }
    .footer-local-menu__title {
      font-size: 3.2rem;
      font-weight: 700;
    }

    .footer-local-menu__list {
      display: grid;
      column-gap: 60px;
      row-gap: 40px;
      grid-template-columns: repeat(4, 1fr);
    }

    .footer-local-menu__item {
      padding-bottom: 10px;
      border-bottom: 1px solid var(--color-main-blue);
    }

    .footer-local-menu__link {
      font-weight: 700;
    }

    .footer-local-menu__category {
      font-weight: 700;
      font-size: 1.2rem;
      color: var(--color-blue-gray);
    }

    .footer-local-menu__children {
      padding-block: 16px 0;
      display: flex;
      flex-direction: column;
      row-gap: 14px;
    }

    .footer-local-menu__children-link {
      font-weight: 500;
      font-size: 1.4rem;
    }

    @media (width < 1280px) {
      .footer-local-menu__list {
        column-gap: 32px;
      }
    }
  }@layer components {
    .footer-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      grid-template-rows: auto;
      column-gap: 60px;
    }

    .footer-grid__column {
      display: flex;
      flex-direction: column;
      row-gap: 40px;
    }

    .footer__local__column {
      margin-top: 40px;
      grid-column: 1 / -1;
    }

    @media (width < 1280px) {
      .footer-grid {
        column-gap: 32px;
      }
    }

    @media (width < 1024px) {
      .footer-grid {
        display: none;
      }
    }
  }@layer base {
    .plus {
      display: flex;
      width: 100%;
      height: 100%;
      position: relative;

      &::before,
      &::after {
        position: absolute;
        content: '';
        display: block;
        width: 16px;
        height: 2px;
        inset: 0;
        margin: auto;
        background-color: var(--plus-icon-border-color, var(--color-main-blue));
      }

      &::after {
        rotate: 90deg;
        transition: scale 0.2s ease;
      }
    }
  }

  *:is([aria-expanded='true']) .plus::after {
    scale: 0;
  }@layer components {
    .accordion-menu {
      width: 100%;
    }
    .accordion-menu__title {
      border-bottom: 1px solid var(--accordion-menu-border-color, var(--color-blue-gray));
      width: 100%;
      display: grid;
      grid-template-columns: 1fr 24px;
      font-weight: var(--accordion-menu-font-wegiht, 700);
      column-gap: 16px;
      text-decoration: none;
      padding-block: 10px;
      text-align: left;
      color: inherit;
      font-size: 1.5rem;
      line-height: 1.6;

      &[href] {
        color: var(--accordion-menu-link-color, var(--color-main-blue));
      }
    }

    .accordion-menu__children {
      overflow: hidden;
      height: 0;
    }

    .accordion-menu__children-link {
      border-bottom: 1px solid var(--accordion-menu-border-color, var(--color-blue-gray));
      display: grid;
      grid-template-columns: 1fr 24px;
      column-gap: 16px;
      padding-block: 10px;
      font-size: 1.4rem;
      line-height: calc(21 / 14);
      text-decoration: none;
      font-weight: var(--accordion-menu-font-wegiht, 400);
      align-items: center;
    }

    .accordion-menu__children-arrow {
      width: 1em;
      height: 1em;
      font-size: 2.4rem;
    }

    .accordion-menu__category {
      padding-block: 10px;
      font-size: 1.2rem;
      line-height: calc(21 / 14);
      font-weight: var(--accordion-menu-font-wegiht, 400);
      color: var(--accordion-menu-category-color, var(--color-main-blue));
      border-bottom: 1px solid var(--accordion-menu-border-color, var(--color-blue-gray));
    }

    .accordion-menu__children-link--sub {
      margin-inline-start: 16px;
      font-size: 1.4rem;
    }

    .accordion-menu--white {
      /** アコーディオンメニュー要素のカラー設定 */
      --accordion-menu-link-color: var(--color-white);
      --accordion-menu-category-color: var(--color-blue-gray);
      --plus-icon-border-color: var(--color-white);
      --accordion-menu-border-color: var(--color-dark-gray);
    }
  }@layer components {
    .footer-accordion {
      display: none;

      @media (width < 1024px) {
        display: block;
      }
    }
  }@layer components {
    .global-footer {
      color: var(--color-white);
    }

    .global-footer__top {
      background-color: var(--color-dark-blue);
      padding: 100px 30px 76px 30px;
    }
    .global-footer__left {
      flex: none;
    }

    .global-footer__nav {
      padding-inline: 0;
      flex-grow: 1;
      align-self: stretch;
    }

    .global-footer__info {
      display: flex;
      justify-content: space-between;
      margin-top: 100px;
    }

    .global-footer__right {
      align-self: center;
      width: 470px;
      justify-content: flex-start;
    }

    .navigation-inquiry__text {
      text-align: left;
      width: 100%;
    }

    .global-footer__bottom {
      min-height: 40px;
      padding: 0 30px;
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin: 0 auto;
      background-color: #000532;
      font-size: 1.2rem;
    }

    .global-footer__lists {
      display: flex;
      gap: 18px;
    }

    @media (width < 1280px) {
      .global-footer__top {
        padding-inline: 20px;
      }

      .global-footer__right {
        padding-left: 20px;
      }
    }

    @media (width < 1024px) {
      .global-footer__top {
        display: grid;
        grid-template-areas: 
          "inquiry"
          "nav"
          "organization";
        gap: 40px;
        padding: 0 20px 45px;
      }

      .global-footer__nav {
        grid-area: nav;
      }

      .global-footer__info {
        display: contents; /* 親要素を無効化 */
      }

      /* FooterOrganizationを最上部に配置 */
      .global-footer__left {
        grid-area: organization;
      }

      /* NavigationInquiryを中央に配置 */
      .global-footer__right {
        grid-area: inquiry;
        width: 100%;
        padding-left: 0;
        padding-block: 0; /* 既存のpaddingを削除 */
        position: static; /* 既存のpositionをリセット */
        margin-top: 32px;
      }

      .navigation-inquiry {
        row-gap: 16px;
      }

      .navigation-inquiry__text {
        text-align: center;
        font-size: 1.4rem;
      }

      .navigation-inquiry__button {
        width: 260px;
        height: 56px;
      }

      .global-footer__bottom {
        background-color: none;
        flex-wrap: wrap;
        padding-inline: 0;
        min-height: initial;
        width: 100%;
        flex-direction: column-reverse;
      }

      .global-footer__copyright {
        width: 100%;
        background-color: #000532;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        height: 44px;
      }

      .global-footer__lists {
        width: 100%;
        display: block;
        background-color: var(--color-dark-blue);
        padding: 10px 20px;
        justify-content: flex-end;
      }

      .global-footer__list a {
        height: 30px;
        display: block;
        text-decoration: none;
      }
      
    }


  }@layer components {
    .drawer-menu {
      width: 100%;
      padding-inline: 20px;
      padding-bottom: 40px;
    }
  }@layer components {
    .header-overlay {
      position: absolute;
      width: 100%;
      height: 100dvh;
      top: var(--height-header);
      left: 0;
      background-color: rgba(5, 67, 170, 0.6);
      pointer-events: none;
      transition: opacity var(--transition-fade);
      opacity: 0;

      &[aria-hidden='false'] {
        opacity: 1;
        pointer-events: auto;
        cursor: pointer;
      }
    }
  }@layer components {
    .switch-language {
      align-self: center;
      display: grid;
      grid-template-areas:
        'en ja'
        'toggle toggle';
      gap: 6px 16px;
      color: var(--color-main-blue);
    }

    .switch-language__ja {
      grid-area: ja;
    }

    .switch-language__en {
      grid-area: en;
    }

    .switch-language__button {
      display: flex;
      justify-content: center;
      align-items: center;
      text-decoration: none;
      font-size: 1.2rem;
      width: 18px;
      height: 18px;
      font-family: var(--font-family-figtree);
      opacity: 0.5;

      &[data-current-language='true'] {
        font-weight: 700;
        opacity: 1;
      }
    }

    .switch-language__toggle {
      grid-area: toggle;
      width: 33px;
      height: 3px;
      margin-inline: auto;
      position: relative;

      &::after {
        content: '';
        display: block;
        width: 6px;
        height: 6px;
        background-color: var(--color-main-blue);
        border-radius: var(--border-radius-full);
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
      }

      &::before {
        content: '';
        display: block;
        background-color: #a7c3e7;
        width: 100%;
        height: 2px;
        position: absolute;
        inset: 0;
        margin: auto;
        border-radius: 1px;
      }
    }

    /* 日本語言語が選択されている場合 */
    .switch-language:has(.switch-language__ja[data-current-language='true']) {
      .switch-language__toggle::after {
        left: calc(100% - 3px);
      }
    }

    /* 英言語が選択されている場合 */
    .switch-language:has(.switch-language__en[data-current-language='true']) {
      .switch-language__toggle::after {
        left: -3px;
      }
    }

    @media (any-hover: hover) {
      .switch-language__button:hover {
        font-weight: 700;
        opacity: 1;
      }

      .switch-language__toggle::after {
        transition: 0.3s ease-out;
        transition-property: left;
      }

      .switch-language:has(.switch-language__en:hover) {
        .switch-language__toggle::after {
          left: -3px;
        }
      }

      .switch-language:has(.switch-language__ja:hover) {
        .switch-language__toggle::after {
          left: calc(100% - 3px);
        }
      }
    }
  }@layer components {
    .header-drawer-menu__bar {
      display: flex;
      height: 100%;
      justify-content: flex-end;
      align-items: center;
      column-gap: 20px;
    }

    .header-drawer-menu__trigger {
      width: 40px;
      height: 40px;
      border-radius: 4px;
      background-color: var(--color-orange);
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-direction: column;
      padding: 13px 12px;
      position: relative;

      span {
        position: absolute;
        display: block;
        width: 16px;
        height: 2px;
        background-color: var(--color-white);
        inset: 0;
        margin: auto;
        transition: all 0.3s ease;

        &:nth-child(1) {
          transform: translateY(-6px);
        }

        &:nth-child(3) {
          transform: translateY(6px);
        }
      }

      &[aria-expanded='true'] {
        span:nth-child(1) {
          transform: translateY(0) rotate(45deg);
        }
        span:nth-child(2) {
          opacity: 0;
        }
        span:nth-child(3) {
          transform: translateY(0) rotate(-45deg);
        }
      }
    }

    .header-drawer-menu__navigation {
      position: absolute;
      top: var(--height-header);
      left: 0;
      width: 100%;
      background-color: var(--color-white);
      overflow: auto;
      max-block-size: calc(100dvh - var(--height-header));

      &[aria-hidden='true'] {
        height: 0;
      }
    }

    .header-drawer-menu__inquiry {
      background-color: var(--color-dark-blue);
      padding: 41px 20px 50px;
      color: var(--color-white);
    }
  }@layer components {
    .local-menu {
      display: flex;
      flex-direction: column;
      row-gap: 40px;
    }

    .local-menu__header {
      width: fit-content;
      display: grid;
      grid-template-columns: repeat(2, auto);
      column-gap: 32px;
      align-items: center;
      text-decoration: none;
    }
    .local-menu__title {
      font-size: 3.2rem;
      font-weight: 700;
    }

    .local-menu__list {
      display: grid;
      gap: 16px;
      grid-template-columns: repeat(3, 1fr);
    }

    .local-menu__item {
      padding-bottom: 10px;
      border-bottom: 1px solid var(--color-blue-gray);
    }

    .local-menu__link {
      font-weight: 700;
    }

    .local-menu__category {
      font-weight: 700;
    }

    .local-menu__children {
      padding-block: 16px calc(40px - 16px);
      display: flex;
      flex-direction: column;
      row-gap: 14px;
    }

    .local-menu__children-link {
      font-weight: 500;
    }
  }@layer components {
    .header-navigation {
      display: flex;
      column-gap: 32px;
      margin-left: auto;
      align-items: center;

      @media (width < 1360px) {
        column-gap: 24px;
      }
    }

    .header-navigation__button {
      font-size: 1.6rem;
      font-weight: 500;
      display: flex;
      align-items: center;
      text-decoration: none;
      color: var(--color-dark-blue);

      @media (any-hover: hover) {
        transition: color var(--transition-hover);
        &:hover {
          color: var(--color-main-blue);
        }
      }

      &[aria-expanded='true'] {
        color: var(--color-main-blue);
        font-weight: 700;

        .header-navigation__button-arrow {
          rotate: 180deg;
        }
      }
    }

    .header-navigation__button-icon {
      color: var(--color-main-blue);
      width: 24px;
      height: 24px;
      flex: none;
      display: flex;
      justify-content: center;
      align-items: center;
    }

    .header-navigation__button-arrow {
      transition: rotate var(--transition-hover);
    }

    .header-navigation__menu {
      position: absolute;
      left: 0;
      top: var(--height-header);
      width: 100%;
      background-color: var(--color-white);
      overflow: hidden;
      &[aria-hidden='true'] {
        height: 0;
      }
    }
    .header-navigation__local {
      width: 100%;
      max-width: calc(var(--width-contents) + 40px);
      margin-inline: auto;
      padding: 40px 20px 80px;
      max-block-size: calc(100dvh - var(--height-header));
      overflow-y: auto;
    }
  }@layer componets {
    .global-header {
      display: grid;
      grid-template-columns: auto 1fr;
      width: 100%;
      position: fixed;
      top: 0;
      left: 0;
      z-index: var(--z-index-header);
      background-color: var(--color-white);
      height: var(--height-header);

      @media (width < 1024px) {
        padding-inline: 20px;
      }
    }

    .global-header__brand {
      margin-inline: 24px;
      display: flex;
      align-items: center;
      @media (width < 1024px) {
        margin-inline: 0;
      }
    }

    .global-header__logo {
      width: 154px;

      @media (width < 768px) {
        width: 125px;
      }
    }

    .global-header__navigation {
      display: grid;
      grid-template-columns: 1fr auto 159px;

      @media (width < 1360px) {
        grid-template-columns: 1fr 159px;
        grid-template-areas:
          'language inquiry'
          'navigation navigation';
      }

      @media (width < 1024px) {
        display: none;
      }
    }

    .global-header__menu {
      @media (width < 1360px) {
        padding-inline-end: 20px;
        grid-area: navigation;
      }
    }

    .global-header__language {
      padding-inline: 80px 40px;

      @media (width < 1360px) {
        grid-area: language;
        padding-inline: 32px;
        justify-self: flex-end;
      }
    }

    .global-header__inquiry {
      text-decoration: none;
      display: flex;
      justify-content: center;
      align-items: center;
      font-size: 1.6rem;
      font-weight: 700;
      color: var(--color-white);
      background-color: var(--color-orange);

      @media (any-hover: hover) {
        transition: opacity var(--transition-hover);

        &:hover {
          opacity: 0.7;
        }
      }

      @media (width < 1360px) {
        grid-area: inquiry;
      }
    }

    .global-header__drawer-menu {
      display: none;

      @media (width < 1024px) {
        display: block;
      }
    }
  }@layer components {
    .main {
      padding-top: var(--height-header);
      overflow-x: hidden;
    }
  }@layer components {
    .heading-tertiary {
      display: flex;
      align-items: center;
      padding: 1em 50px;
      min-height: 178px;
      border-bottom: 3px solid var(--color-main-blue);

      @media (width < 1024px) {
        padding-inline: 20px;
      }

      @media (width < 768px) {
        padding: 1em 16px;
        min-height: 116px;
      }
    }
  }@layer components {
    .breadcrumb {
      display: flex;
      flex-wrap: nowrap;
      gap: 8px;
      width: 100%;
      padding: 12px 30px;
      margin-inline: auto;
      list-style: none;
    }

    .breadcrumb__item {
      flex: none;
      font-size: 1.2rem;
      font-style: normal;
      font-weight: 400;
      line-height: 100%;

      &:not(:last-child)::after {
        margin-left: 8px;
        content: '>';
      }

      &:last-child {
        color: var(--color-main-blue);
      }
    }

    .breadcrumb__item a {
      text-decoration: none;
      color: var(--color-dark-gray);
      transition: color var(--transition-hover);
    }

    /* パンくずのラッパークラス */
    .breadcrumb-scroller {
      width: 100%;
      overflow-x: auto;
      scrollbar-width: none;
    }

    @media (any-hover: hover) {
      .breadcrumb__item a:hover {
        color: var(--color-main-blue);
      }
    }

    @media (width < 768px) {
      .breadcrumb {
        padding-inline: 16px;
      }
      /* 画面右端にスクロールした時に右に余白を持たせる */
      .breadcrumb__item:last-child {
        padding-inline-end: 16px;
      }
    }
  }@layer components {
    .article {
      width: 100%;
      max-width: calc(var(--width-contents) + 40px);
      margin-inline: auto;
      margin-block-end: 120px;
      padding-inline: 20px;

      @media (width < 768px) {
        padding-inline: 16px;
        margin-block-end: 60px;
      }
    }
  }@layer base {
    .arrow {
      display: flex;
      width: 100%;
      height: 100%;
      justify-content: center;
      align-items: center;
      border-radius: var(--border-radius-full);
      background-color: var(--color-main-blue);
      color: var(--color-white);
      overflow: hidden;
      border: 1px solid var(--color-main-blue);
      position: relative;
    }

    .arrow--invert {
      background-color: var(--color-white);
      color: var(--color-main-blue);
      border: none;
    }

    .arrow__icon {
      position: relative;
      width: 25%;
    }
    @media (any-hover: hover) {
      .arrow:not(.arrow--inline) {
        transition: 0.2s var(--timing-function-arrow-forward);
        transition-property: color;
      }

      .arrow:not(.arrow--inline)::before {
        position: absolute;
        inset: 0;
        margin: auto;
        content: '';
        display: block;
        width: 100%;
        height: 100%;
        background-color: var(--color-white);
        transform: scale(0);
        opacity: 0;
        transition: 0.2s var(--timing-function-arrow-forward);
        transition-property: transform, opacity;
        border-radius: var(--border-radius-full);
      }

      .arrow--invert:not(.arrow--inline)::before {
        background-color: var(--color-main-blue);
      }

      /* 親要素a, buttonのホバーでアローアニメーションを実行 */
      *:is(a, button):hover {
        /* ボタン要素内では背景色・カラーをアニメーションさせる */
        .arrow:not(.arrow--inline) {
          color: var(--color-main-blue);
        }
        .arrow--invert:not(.arrow--inline) {
          color: var(--color-white);
        }

        .arrow:not(.arrow--inline)::before {
          opacity: 1;
          transform: scale(1);
        }

        .arrow__icon {
          animation: arrow-forward 0.6s var(--timing-function-arrow-forward) forwards;
        }
      }
    }
  }@layer components {
    .arrow-link {
      display: grid;
      grid-template-columns: 24px auto;
      column-gap: 8px;
      align-items: flex-start;
      text-decoration: none;

      @media (any-hover: hover) {
        transition: color var(--transition-hover);

        &:hover {
          color: var(--color-main-blue);
        }
      }
    }

    .arrow-link__arrow {
      width: 1em;
      height: 1em;
      font-size: 2.4rem;
    }
  }@layer components {
    .view-more {
      display: grid;
      grid-template-columns: auto 72px;
      column-gap: 16px;
      align-items: center;
      text-decoration: none;
      color: var(--color-main-blue);
    }

    .view-more--white {
      color: var(--color-white);

      .view-more__arrow {
        background-color: var(--color-white);
        color: var(--color-main-blue);
      }
    }

    .view-more__text {
      font-family: var(--font-family-figtree);
      font-weight: 600;
    }

    .view-more__arrow {
      width: 72px;
      height: 72px;
    }
  }@layer components {
    .grid {
      display: grid;
      gap: 24px;
    }

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

    .grid--columns-3 {
      grid-template-columns: repeat(3, 1fr);
    }

    .grid--columns-4 {
      grid-template-columns: repeat(4, 1fr);
    }

    @media (width < 768px) {
      .grid,
      .grid--columns-2,
      .grid--columns-3,
      .grid--columns-4 {
        grid-template-columns: 1fr;
      }
    }
  }@layer base {
    .window {
      display: flex;
      width: 100%;
      height: 100%;
      justify-content: center;
      align-items: center;
      border-radius: var(--border-radius-full);
      background-color: var(--color-main-blue);
      color: var(--color-white);
      overflow: hidden;
      border: 1px solid var(--color-main-blue);
      position: relative;
    }

    .window__icon {
      position: relative;
      width: 11px;
    }

    @media (any-hover: hover) {
      .window {
        transition: 0.2s var(--timing-function-arrow-forward);
        transition-property: color;
      }

      .window::before {
        position: absolute;
        inset: 0;
        margin: auto;
        content: '';
        display: block;
        width: 100%;
        height: 100%;
        background-color: var(--color-white);
        transform: scale(0);
        opacity: 0;
        transition: 0.2s var(--timing-function-arrow-forward);
        transition-property: transform, opacity;
        border-radius: var(--border-radius-full);
      }

      /* 親要素a, buttonのホバーアニメーションを実行 */
      *:is(a, button):hover {
        .window {
          color: var(--color-main-blue);
        }

        .window::before {
          opacity: 1;
          transform: scale(1);
        }
      }
    }
  }@layer base {
    .pdf {
      display: flex;
      width: 100%;
      height: 100%;
      justify-content: center;
      align-items: center;
      background-color: transparent;
      color: var(--color-red);
      overflow: hidden;
    }

    .pdf__icon {
      position: relative;
      width: 16px;
      height: 15px;
    }

    @media (any-hover: hover) {
      .pdf {
        transition: 0.2s var(--timing-function-arrow-forward);
        transition-property: color;
      }

      /* 親要素a, buttonのホバーアニメーションを実行 */
      *:is(a, button):hover {
        .pdf {
          color: var(--color-white);
        }
      }
    }
  }@layer components {
    .button {
      text-decoration: none;
      display: flex;
      align-items: center;
      justify-content: space-between;
      column-gap: 8px;
      width: 100%;
      border-radius: var(--border-radius-button);
      min-height: 44px;
      border: 1px solid var(--color-main-blue);
      color: var(--color-main-blue);
      font-weight: 700;
      background-color: var(--color-white);
      padding-inline: 32px 16px;
      padding-block: 8px;
    }

    .button__icon {
      flex: 0 0 24px;
      width: 24px;
      height: 24px;
    }

    @media (any-hover: hover) {
      .button {
        transition: 0.2s var(--timing-function-arrow-forward);
        transition-property: background-color, color;

        &:hover {
          color: var(--color-white);
          background-color: var(--color-main-blue);
        }
      }
    }
  }@layer pages {
    .agreement-main {
      margin-block: 80px 120px;
    }

    .agreement-main__grid {
      grid-auto-rows: minmax(56px, auto);
    }

    .agreement-notice {
      margin-block-start: 16px;
      font-size: 1.4rem;
      color: var(--dark-gray);
      font-weight: 400;
    }

    @media (width < 768px) {
      .agreement-main {
        margin-block: 64px 80px;
      }

      .agreement-notice {
        margin-block-start: 24px;
        font-size: 1.3rem;
      }
    }
  }@layer components {
    .column-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 24px 40px;
    }

    .column-grid--left {
      grid-template-columns: 1fr 2fr;
    }

    .column-grid--right {
      grid-template-columns: 2fr 1fr;
    }

    @media (width < 768px) {
      .column-grid,
      .column-grid--left,
      .column-grid--right {
        grid-template-columns: 1fr;
      }
    }
  }@layer pages {
    .introduction-main__text {
      display: flex;
      flex-direction: column;
      row-gap: calc(1em * 1.6);
    }

    .introduction-main__signsignature {
      margin-top: 34px;

      @media (width < 768px) {
        margin-top: 30px;
      }
    }
  }@layer components {
    .arrow-anchor {
      display: flex;
      width: 100%;
      height: 100%;
      justify-content: center;
      align-items: center;
      border-radius: var(--border-radius-full);
      background-color: var(--color-middle-blue);
      color: var(--color-white);
      overflow: hidden;
      border: 1px solid var(--color-middle-blue);
      position: relative;
      transform: rotate(90deg);
    }

    .arrow-anchor--invert {
      background-color: var(--color-white);
      color: var(--color-middle-blue);
      border: none;
    }

    .arrow-anchor__icon {
      position: relative;
      width: 25%;
      transition: transform var(--transition-hover);
    }
    @media (any-hover: hover) {
      /* 親要素a, buttonのホバーでアローアニメーションを実行 */
      *:is(a, button):hover {
        .arrow-anchor__icon {
          transform: translateX(2px);
        }
      }
    }
  }@layer components {
    .arrow-anchor-link {
      display: grid;
      grid-template-columns: 24px auto;
      column-gap: 8px;
      align-items: flex-start;
      text-decoration: none;
      color: var(--color-white);
      align-items: center;
    }

    .arrow-anchor-link__arrow {
      width: 1em;
      height: 1em;
      font-size: 2.4rem;
    }

    .arrow-anchor-link__text {
      font-weight: 500;
    }
  }@layer components {
    .basic-table-col__wrapper {
      overflow-x: auto;
      -webkit-text-size-adjust: 100%;
    }

    .basic-table-col,
    .basic-table-col__body {
      display: table;
      width: 100%;
      border-spacing: 0;
    }

    .basic-table-col {
      min-width: 767px;
    }

    .basic-table-col {
      position: relative;
      margin-block: 24px;
      overflow: hidden;
    }

    .basic-table-col::before {
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      width: 100%;
      height: 100%;
      pointer-events: none;
      content: '';
      border: solid 1px var(--color-blue-gray);
    }

    @media (width > 1023px) {
      .basic-table-col__body {
        display: table-row-group;
      }
    }
  }@layer components {
    .basic-table-col__data {
      display: table-cell;
      padding-block: 16px;
      padding-inline: 16px;
      text-align: left;
      background-color: #ffffff;
    }

    .basic-table-col__data:first-child {
      width: 23.66%;
    }

    .basic-table-col__data:not(:first-child) {
      border-left: 1px solid var(--color-blue-gray);
    }

    .basic-table-col__row:not(:first-child) .basic-table-col__data {
      border-top: 1px solid var(--color-blue-gray);
      vertical-align: top;
    }

    .basic-table-col--sub-table .basic-table-col__data,
    .basic-table-col--sub-table .basic-table-col__row:not(:first-child) .basic-table-col__data {
      border-color: var(--color-blue-gray);
    }

    .basic-table-col__data--header {
      font-size: 1.5rem;
      background: var(--color-parl-gray);
    }

    .basic-table-col--sub-table .basic-table-col__data--header {
      background: var(--color-parl-gray);
    }

    .basic-table-col__data > *:first-child {
      margin-block-start: 0;
    }

    .basic-table-col__data > *:last-child {
      margin-block-end: 0;
    }

    .basic-table-col--sub-table .basic-table-col__data--header .note-text {
      font-weight: normal;
    }

    @media (width > 1023px) {
      .basic-table-col__data {
        padding-block: 24px;
        padding-inline: 24px;
      }

      .basic-table-col__data--header {
        font-size: 1.6rem;
      }
    }
  }@layer components {
    .basic-table-col__row {
      display: table-row;
    }

    .basic-table-col__row:not(:first-child) {
      border-top: 1px solid var(--color-blue-gray);
    }

    .basic-table-col--sub-table .basic-table-col__row:not(:first-child) {
      border-color: var(--color-blue-gray);
    }
  }@layer pages {
    .network-anchor {
      background-color: var(--color-main-blue);
      margin-block-start: 24px;
    }

    .network-anchor__list {
      padding-block: 40px;
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      grid-auto-rows: minmax(34px, auto);
      gap: 16px;
      max-width: calc(var(--width-contents) + 40px);
      margin-inline: auto;
      padding-inline: 20px;
    }

    .network-anchor__item {
      border-bottom: 1px solid var(--color-middle-blue);
      padding-block-end: 8px;
    }

    .network-main__table--text:not(:first-child) {
      margin-block-start: 20px;
    }

    .network-main__table--text-sub {
      display: block;
      font-weight: 400;
      padding-inline-start: 16px;
    }

    .network-main__table--address {
      font-weight: 400;
      margin-block-end: 10px;
      line-height: 1.3;
    }

    .network-main__table-btn {
      color: var(--color-main-blue);
    }

    @media (width < 1024px) {
      .network-anchor__list {
        padding-block: 32px;
        grid-template-columns: repeat(1, 1fr);
        gap: 8px;
      }

      .network-main__table--text-sub {
        padding-inline-start: 8px;
      }

      .network-main__table--address {
        margin-block-end: 8px;
      }

      .network-anchor__item {
        border-bottom: none;
        padding-block-end: 0;
      }

      .network-main__table--text:not(:first-child) {
        margin-block-start: 16px;
      }
    }
  }@layer components {
    .text-link {
      display: inline-grid;
      grid-template-columns: 24px auto;
      column-gap: 8px;
      align-items: flex-start;
      text-decoration: none;

      @media (any-hover: hover) {
        transition: color var(--transition-hover);

        &:hover {
          color: var(--color-main-blue);

          .text-link__icon--pdf {
            color: currentColor;
          }
        }
      }
    }

    .text-link__icon {
      width: 24px;
      height: 24px;
      display: flex;
      justify-content: center;
      align-items: center;
    }

    .text-link__blue{
      color: var(--color-main-blue);
    }

    .text-link__icon--blue{
      color: var(--color-main-blue);
    }

    .text-link__icon--pdf {
      color: var(--color-red);
    }
  }@layer pages {
    .article {
      margin-block-end: 80px;
    }

    .article.origin-history__table {
      margin-block-end: 0;
    }

    .origin-name-item__body {
      display: grid;
      grid-template-columns: calc(700 / 1200 * 100%) 1fr;
    }

    .origin-name__item__slogan {
      background-color: var(--color-pale-blue-gray);
      padding: 40px;
      margin-bottom: 24px;
    }

    .origin-name__item__slogan__imagearea .image {
      max-width: 100%;
      width: 200px;
      height: auto;
    }

    .origin-history {
      width: 100vw;
      margin: 0 calc(50% - 50vw);
      background-color: var(--color-parl-gray);
    }

    .origin-history__inner {
      padding: 40px 0 120px; 
    }

    .origin-history__item {
      display: grid;
      grid-template-columns: calc(284 / 1200 * 100%) 1fr;
      background-color: var(--color-white);
      margin-bottom: 16px;
    }

    .origin-history__item:last-child {
      margin-bottom: 0;
    }
    
    .origin-history__item dt {
      display: flex;
      align-items: center;
      padding: 24px;
      font-weight: bold;
      color: var(--color-middle-blue);

    }

    .origin-history__item dd {
      padding: 24px;

    }

    @media (width < 768px) {

      .origin-history__inner {
        padding-bottom: 60px; 
      }

      .origin-name-item__body {
        display: block;
      }

      .origin-name-item__body__logo {
        width: 66.47%;
        margin: auto;
        margin-top: 9.41%;
      }

      .origin-history__item {
        display: flex;
      }

      .origin-history__item dt {
        align-items: flex-start;
        width: 110px;
        font-size: 1.4rem;
        padding: 16px 10px 16px 16px;
      }

      .origin-history__item dd {
        width: calc(100% - 110px);
        font-size: 1.4rem;
        padding: 16px 32px 16px 0;
      }
    }
  }@layer components {
    .basic-list {
      display: grid;
      row-gap: 8px;
      margin-block: 16px;
      font-size: 1.6rem;
      font-weight: 500;
    }

    .basic-list--ol {
      counter-reset: basicListCounter;
    }

    @media (width < 768px) {
      .basic-list {
        display: grid;
        row-gap: 8px;
        margin-block: 16px;
        font-size: 1.5rem;
      }
    }
  }@layer components {
    .basic-list__item {
      position: relative;
    }

    .basic-list--ul > .basic-list__item {
      position: relative;
      margin-left: 1.1em;
    }

    .basic-list--ul > .basic-list__item::before {
      position: absolute;
      width: 6px;
      height: 6px;
      margin-inline: 0.25em;
      content: '';
      background: var(--color-main-blue);
      border-radius: 50%;
      top: 0.6em;
      left: -1.1em;
    }
    .basic-list--ol > .basic-list__item {
      text-indent: -2em;
      padding-left: 2em;
      counter-increment: basicListCounter;
    }

    .basic-list--ol > .basic-list__item::before {
      font-weight: 500;
      margin-inline: 0.25em;
      content: '(' counter(basicListCounter) ') ';
    }

    .basic-list--notice > .basic-list__item::before {
      width: auto;
      height: auto;
      content: '※';
      background: none;
    }

    .number-list--ol{
      list-style: none;
      counter-reset: number;
    }
    .number-list--ol > .basic-list__item {
      counter-increment: number;
      position: relative;
      margin-left: 1.5em;
    }

    .number-list--ol > .basic-list__item::before {
      content: counter(number) ". ";
      position: absolute;
      margin-inline: 0.25em;
      top: 0;
      left: -1.5em;
    }

  }@layer pages {
    .privacy-main {
      margin-block: 80px 113px;
    }

    .privacy-main__inner {
      padding-inline: 16px 0;
    }

    .privacy-main__btn--list {
      border: 1px solid var(--color-middle-blue);
      padding-block: 32px;
      padding-inline: 40px;
      margin-block-start: 40px;
    }

    .privacy-main__btn--text {
      color: var(--color-main-blue);
    }

    .privacy-main__btn--title {
      font-size: 1.4rem;
      margin-block-end: 8px;
    }

    .privacy-main__btn--item {
      display: flex;
      flex-wrap: nowrap;
      column-gap: 40px;
    }

    .privacy-main__btn--title:not(:first-child) {
      margin-block-start: 16px;
    }

    .privacy-main__head {
      margin-block-start: 40px;
      margin-block-end: 8px;
      font-size: 1.6rem;
      font-weight: 500;
    }

    .privacy-main .basic-table {
      margin-block-start: 20px;
    }

    .privacy-main__ol {
      text-indent: -2em;
      padding-left: 2em;
      counter-increment: basicListCounter;
      margin-block-end: 8px;
    }

    .privacy-main__ol::before {
      font-weight: 500;
      margin-inline: 0 0.25em;
      content: '(' counter(basicListCounter) ') ';
    }

    .privacy-main__text--level1 {
      padding-inline: 8px 0;
    }

    .privacy-main__contact-text {
      text-indent: -3.6em;
      padding-left: 3.6em;
    }
    .privacy-main__contact-text-en {
      text-indent: -10.4em;
      padding-left: 10.4em;
    }

    @media (width < 768px) {
      .privacy-main {
        margin-block: 60px 80px;
      }

      .privacy-main__inner {
        padding-inline: 8px;
      }

      .privacy-main__head {
        margin-block-start: 22px;
        margin-block-end: 6px;
        font-size: 1.5rem;
      }

      .privacy-main__btn--list {
        margin-block-start: 22px;
        padding-block: 16px;
        padding-inline: 20px;
      }

      .privacy-main__btn--title {
        font-size: 1.3rem;
      }

      .privacy-main__btn--item {
        flex-wrap: wrap;
        row-gap: 8px;
        column-gap: 20px;
      }

      .privacy-main__btn--title:not(:first-child) {
        margin-block-start: 8px;
      }
    }
  }@layer components {
    .basic-table,
    .basic-table__body {
      display: block;
    }

    .basic-table {
      position: relative;
      margin-block: 24px;
      overflow: hidden;
    }

    .basic-table::before {
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      width: 100%;
      height: 100%;
      pointer-events: none;
      content: '';
      border-top: solid 1px var(--color-blue-gray);
      border-bottom: solid 1px var(--color-blue-gray);
    }

    .basic-table--full-width {
      width: 100%;
    }

    @media (width > 1023px) {
      .basic-table {
        display: table;
        border-spacing: 0;
      }

      .basic-table__body {
        display: table-row-group;
      }
    }
  }@layer components {
    .basic-table__row {
      display: block;
    }

    .basic-table__row:not(:first-child) {
      border-top: 1px solid var(--color-blue-gray);
    }

    @media (width > 1023px) {
      .basic-table__row {
        display: table-row;
      }
    }
  }@layer components {
    .basic-table__data {
      display: block;
      padding-block: 16px;
      padding-inline: 16px;
      text-align: left;
      background-color: #ffffff;
    }

    .basic-table__data--header {
      font-size: 1.5rem;
      background: var(--color-parl-gray);
    }

    .basic-table__data:not(:first-child) {
      border-top: 1px solid var(--color-blue-gray);
    }

    .basic-table__data > *:first-child {
      margin-block-start: 0;
    }

    .basic-table__data > *:last-child {
      margin-block-end: 0;
    }

    @media (width > 1023px) {
      .basic-table__data {
        display: table-cell;
        padding-block: 24px;
        padding-inline: 24px;
      }

      .basic-table__data:first-child {
        width: 23.66%;
      }

      .basic-table__data:not(:first-child) {
        border-top: none;
      }

      .basic-table__row:not(:first-child) .basic-table__data {
        border-top: 1px solid var(--color-blue-gray);
      }

      .basic-table__data--header {
        font-size: 1.6rem;
      }
    }
  }@layer pages {
    .profile-main {
      margin-block: 80px 120px;
    }

    .network-main__table-text {
      font-weight: 400;
    }

    .profile-main__map {
      position: relative;
      padding-block: 80px;
      margin-block-start: 80px;
    }

    .profile-main__map:before {
      content: '';
      position: absolute;
      display: block;
      top: 0;
      left: 0;
      right: 0;
      width: 100vw;
      height: 100%;
      margin-inline: calc(50% - 50vw);
      background-color: var(--color-parl-gray);
      z-index: -1;
    }

    .profile-main__map--grid {
      grid-template-columns: 65fr 51fr;
    }

    .profile-main__map--grid:not(:nth-of-type(1)) {
      margin-block-start: 42px;
    }

    .profile-main__map--iframe {
      aspect-ratio: 510 / 383;
      width: 100%;
      height: auto;
    }

    .profile-main__map--header {
      font-size: 3.2rem;
      font-weight: 700;
      line-height: 1.5;
      margin-block: 0 32px;
    }

    .profile-main__map--title {
      padding-bottom: 0.7em;
      margin-block: 0 16px;
      border-bottom: 1px solid var(--color-blue-gray);
    }

    @media (width < 768px) {
      .profile-main {
        margin-block: 64px 80px;
      }

      .profile-main__map--grid {
        grid-template-columns: 1fr;
      }

      .profile-main__map {
        padding-block: 64px;
        margin-block-start: 64px;
      }

      .profile-main__map--grid:not(:nth-of-type(1)) {
        margin-block-start: 16px;
      }

      .profile-main__map--header {
        font-size: 2.4rem;
        line-height: 1.5;
        margin-block: 0 24px;
      }
    }
  }@layer components {
    .heading-primary {
      position: relative;
    }

    .heading-primary__picture {
      display: block;
      width: 100%;
      aspect-ratio: 1440 / 370;
      max-height: 370px;

      > img {
        width: 100%;
        height: 100%;
        object-fit: cover;
      }

      @media (width < 768px) {
        aspect-ratio: 375 / 240;
        max-height: 240px;
      }
    }

    .heading-primary__text {
      position: absolute;
      inset: 0;
      margin: auto;
      width: 100%;
      height: 100%;
      max-width: calc(var(--width-contents) + 40px);
      padding-inline: 20px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      color: var(--color-white);
      row-gap: 8px;

      > p {
        font-family: var(--font-family-figtree);
        letter-spacing: 0.64px;
        font-size: 1.6rem;
        font-weight: 600;
      }

      > h1 {
        font-size: 5rem;
        font-weight: 700;
        line-height: 1.25;
        letter-spacing: 3px;

        @media (width < 768px) {
          font-size: 3.8rem;
        }
      }
    }
  }@layer components {
    .card-grid {
      display: grid;
      column-gap: 24px;
      row-gap: 60px;
    }

    .card-grid--columns-2 {
      grid-template-columns: repeat(2, 1fr);
    }

    .card-grid--columns-3 {
      grid-template-columns: repeat(3, 1fr);
    }

    @media (width < 768px) {
      .card-grid,
      .card-grid--columns-2,
      .card-grid--columns-3 {
        grid-template-columns: 1fr;
        row-gap: 30px;
      }
    }
  }@layer components {
    .card-link {
      display: grid;
      grid-template-rows: auto 1fr max-content;
      height: 100%;
      overflow: hidden;
      text-decoration: none;

      @media (any-hover: hover) {
        transition: var(--transition-hover);

        .card-link__image {
          transition: var(--transition-hover);
        }

        &:hover {
          color: var(--color-main-blue);

          .card-link__image {
            scale: 1.2;
          }
        }
      }
    }

    .card-link__head {
      overflow: hidden;
      border-radius: 5px;
    }

    .card-link__image {
      display: block;
      width: 100%;
      margin-inline: auto;
      border-radius: 4px;
    }

    .card-link__title {
      font-weight: 500;
      font-size: 1.8rem;
      margin-block-start: 16px;

      @media (width < 768px) {
        font-size: 1.6rem;
      }
    }

    .card-link__description {
      font-size: 1.4rem;
      margin-block-start: 8px;
      color: var(--color-dark-gray);
      line-height: calc(19.6 / 14);
    }

    .card-link__btn {
      margin-block-start: 16px;
      font-weight: 500;
    }
  }@layer components {
    .page-banner__inner {
      display: grid;
      grid-template-columns: repeat(2, 1fr);

      @media (width < 768px) {
        grid-template-columns: 1fr;
      }
    }

    .page-banner__item {
      position: relative;
    }

    .page-banner__link {
      display: grid;
      grid-template-columns: auto 72px;
      column-gap: 8px;
      align-items: center;
      text-decoration: none;
      height: 100%;
      aspect-ratio: 720 / 384;
      padding-inline: 49px;

      @media (any-hover: hover) {
        &:hover .page-banner__image {
          scale: 1.2;
        }
      }

      @media (width < 768px) {
        aspect-ratio: 375 / 200;
        padding-inline: 16px;
      }
    }

    .page-banner__text {
      font-size: 4rem;
      font-weight: 700;
      color: var(--color-white);

      @media (width < 1024px) {
        font-size: 2.4rem;
      }
    }

    .page-banner__arrow {
      width: 72px;
      height: 72px;

      @media (width < 1024px) {
        width: 56px;
        height: 56px;
      }
    }

    .page-banner__picture {
      overflow: hidden;
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      right: 0;
      left: 0;
      margin-inline: auto;
      z-index: -2;
    }

    .page-banner__picture::before {
      content: '';
      display: block;
      overflow: hidden;
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      right: 0;
      left: 0;
      margin-inline: auto;
      z-index: 1;
      background-color: rgba(5, 67, 170, 0.6);
    }

    .page-banner__image {
      transition: var(--transition-hover);
      width: 100%;
    }
  }@layer pages {
    .corporate-main {
      margin-block-start: 80px;

      @media (width < 768px) {
        margin-block-start: 40px;
      }
    }
  }@layer components {
    .image-caption {
      display: flex;
      flex-direction: column;
      row-gap: 16px;

      > figcaption {
        text-align: center;
        font-size: 1.4rem;
        line-height: 1.4;
        color: var(--color-dark-gray);
        letter-spacing: var(--basic-letter-spacing);
      }
    }

    @media (width < 768px) {
      .image-caption {
        row-gap: 8px;

        > figcaption {
          font-size: 1.2rem;
        }
      }
    }
  }@layer pages {
    .index-hero {
      width: 100%;
      height: calc(100vh - var(--height-header));
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding-inline: 86px;
      color: var(--color-white);
      background-color: rgba(3, 72, 148, 0.3);

      .clip-path {
        display: inline-block;
        clip-path: inset(0 100% 0 0);
      }
    }
    .index-hero__title {
      font-size: 5.3rem;
      font-weight: 700;
      line-height: calc(80 / 53);
    }

    .index-hero__lead {
      font-size: 3.2rem;
      font-family: var(--font-family-figtree);
    }

    .index-hero__title-bar {
      display: block;
      width: 79px;
      height: 1px;
      background-color: var(--color-white);
      margin-block: 40px 38px;
    }

    @media (width < 1024px) {
      .index-hero {
        padding-inline: 20px;
      }
      .index-hero__title {
        font-size: 3.2rem;
      }
      .index-hero__lead {
        font-size: 2.8rem;
      }
    }

    @media (width < 768px) {
      .index-hero {
        padding-inline: 16px;
      }
      .index-hero__title {
        font-size: 2.8rem;
      }
      .index-hero__lead {
        font-size: 1.8rem;
      }
    }

    .index-hero.loaded {
      .clip-path {
        animation: text-clip-path 1.2s cubic-bezier(0.86, 0, 0.07, 1) 0.7s forwards;
      }
    }

    @keyframes text-clip-path {
      0% {
        clip-path: inset(0 100% 0 0);
      }

      100% {
        clip-path: inset(0);
      }
    }
  }@layer pages {
    .index-section-header {
      color: var(--color-main-blue);
    }

    .index-section-header--white {
      color: var(--color-white);
    }
    .index-section-header__english {
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .index-section-header__title {
      font-size: 8rem;
      font-weight: 600;
      font-family: var(--font-family-figtree);
      letter-spacing: calc(1em * 0.04);
      line-height: calc(96 / 80);
    }

    .index-section-header__japanese {
      font-size: 2.4rem;
      letter-spacing: calc(1em * 0.16);
      display: grid;
      grid-template-columns: 8px 1fr;
      column-gap: 8px;
      align-items: center;

      &::before {
        width: 8px;
        height: 8px;
        content: '';
        display: block;
        border-radius: var(--border-radius-full);
        background-color: currentColor;
      }
    }

    @media (width < 1280px) {
      .index-section-header__title {
        font-size: 4.8rem;
      }
      .index-section-header__japanese {
        font-size: 1.8rem;
      }
    }

    @media (width < 768px) {
      .index-section-header {
        .view-more {
          grid-template-columns: 1fr 56px;
          column-gap: 12px;
        }
        .view-more__arrow {
          width: 56px;
          height: 56px;
        }
      }

      .index-section-header__title {
        font-size: 3.2rem;
      }
      .index-section-header__japanese {
        font-size: 1.4rem;
        column-gap: 4px;

        &::before {
          width: 6px;
          height: 6px;
        }
      }
    }
  }@layer pages {
    .index-about {
      color: var(--color-white);
      background-color: var(--color-index-blue);
      width: 100%;
      min-height: 633px;
      display: grid;
      grid-template-columns: calc(886 / 1536 * 100%) 1fr;
    }

    .index-about__right {
      overflow: hidden;
    }

    .index-about__image {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
      background: url(/img/index/img-about_1.jpg) no-repeat center center / cover;
    }

    .index-about__picture {
      display: block;
    }

    .index-about__left {
      width: 100%;
      display: flex;
      padding: 40px 126px;
      flex-direction: column;
      justify-content: center;
      row-gap: 40px;

      @media (width < 1480px) {
        padding-inline: 40px;
      }
    }

    @media (width < 1024px) {
      .index-about {
        grid-template-columns: 1fr;
        min-height: inherit;
      }

      .index-about__image {
        width: 100%;
        aspect-ratio: 376 / 220;
        max-height: 220px;
      }

      .index-about__left {
        padding: 70px 16px;
      }
    }
  }@layer pages {
    .index-background-video {
      width: 100%;
      height: 100vh;
      position: fixed;
      inset: 0;
      margin: auto;
      z-index: -1;
      object-fit: cover;
    }
  }@layer pages {
    .headline-information {
      background-color: var(--color-white);
      padding: 32px 20px;
    }

    .headline-information__link {
      max-width: calc(var(--width-index-contents) + 40px);
      width: 100%;
      display: flex;
      align-items: center;
      margin-inline: auto;
      text-decoration: none;
      column-gap: 32px;
    }

    .headline-information__header {
      display: flex;
      align-items: center;
      column-gap: 8px;
    }

    .headline-information__time {
      font-size: 1.2rem;
      letter-spacing: calc(1em * 0.04);
      color: var(--color-dark-gray);
      font-weight: 500;
    }
    .headline-information__label {
      display: inline-flex;
      padding-inline: 6px;
      font-size: 1.2rem;
      align-items: center;
      justify-content: center;
      border-radius: 4px;
      color: var(--color-white);
      background-color: var(--color-orange);
      height: 20px;
    }

    .headline-information__text {
      font-weight: 400;
    }
    @media (width < 768px) {
      .headline-information {
        padding-block: 24px;
      }
      .headline-information__link {
        max-width: initial;
        flex-direction: column;
        align-items: flex-start;
        row-gap: 8px;
      }
    }
  }@layer pages {
    .feature-scroll {
      display: grid;
      grid-template-columns: repeat(2, 246px);
      column-gap: 16px;

      @media (width < 1380px) {
        grid-template-columns: repeat(2, auto);
      }

      @media (width < 1024px) {
        display: flex;
        flex-direction: column;
        row-gap: 8px;
      }
    }

    .feature-scroll__left,
    .feature-scroll__right {
      @media (width < 1024px) {
        display: flex;
        width: max-content;
      }
    }

    .feature-scroll__images {
      width: 246px;
      display: flex;
      flex-direction: column;

      @media (width < 1024px) {
        flex: none;
        width: fit-content;
        flex-direction: row;
      }
    }

    .feature-scroll__image {
      width: 100%;
      border-radius: 4px;
      margin-bottom: 16px;

      @media (width < 1024px) {
        width: 180px;
        height: 120px;
        margin-bottom: 0;
        margin-right: 8px;
        object-fit: cover;
      }
    }

    .feature-scroll__left {
      animation: scroll-to-lower 50s linear infinite;
      @media (width < 1024px) {
        animation: scroll-to-left 50s linear infinite;
      }
    }

    .feature-scroll__right {
      animation: scroll-to-upper 50s linear infinite;
      @media (width < 1024px) {
        animation: scroll-to-right 50s linear infinite;
      }
    }

    /** 下から上に無限スクロールする  */
    @keyframes scroll-to-upper {
      0% {
        transform: translateY(0);
      }
      to {
        transform: translateY(-50%);
      }
    }

    /** 上から下に無限スクロールする  */
    @keyframes scroll-to-lower {
      0% {
        transform: translateY(-50%);
      }
      to {
        transform: translateY(0);
      }
    }

    /** 右から左に無限スクロールする */
    @keyframes scroll-to-left {
      0% {
        transform: translateX(0);
      }
      to {
        transform: translateX(-50%);
      }
    }

    /** 左から右に無限スクロールする */
    @keyframes scroll-to-right {
      0% {
        transform: translateX(-50%);
      }
      to {
        transform: translateX(0);
      }
    }
  }@layer pages {
    .index-feature {
      display: grid;
      height: 650px;
      grid-template-columns: calc(638 / 1536 * 100%) 1fr;
      background-color: var(--color-white);

      @media (width < 1480px) {
        grid-template-columns: auto 1fr;
      }
      @media (width < 1024px) {
        height: auto;
        padding-bottom: 80px;
      }
    }
    .index-feature__left {
      overflow: hidden;
      padding-inline: 60px;

      @media (width < 1480px) {
        padding-inline: 0;
      }
    }
    .index-feature__right {
      width: 100%;
      display: flex;
      padding: 40px 126px;
      flex-direction: column;
      justify-content: center;
      row-gap: 40px;
      color: var(--color-main-blue);

      > p {
        color: var(--color-blube-black);
      }
    }
    @media (width < 1480px) {
      .index-feature__right {
        padding-inline: 40px;
      }
    }
    @media (width < 1024px) {
      .index-feature {
        display: flex;
        flex-direction: column-reverse;
        min-height: initial;
      }

      .index-feature__right {
        padding: 80px 16px 40px;
      }

      .index-feature__left {
        width: 100%;
        aspect-ratio: 375 / 248;
        max-height: 248px;
      }
    }
  }@layer pages {
    .index-logistics {
      width: 100%;
      background-color: var(--color-main-blue);
      padding: 120px 20px;
    }

    .index-logistics__inner {
      width: 100%;
      max-width: var(--width-index-contents);
      margin-inline: auto;
    }

    .index-logistics__title {
      color: var(--color-white);
    }

    .index-logistics__grid {
      margin-top: 80px;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }

    .index-logistics__button {
      width: 100%;
      height: 100%;
      padding: 32px 16px;
      display: grid;
      grid-template-columns: 64px auto 24px;
      align-items: center;
      text-decoration: none;
      border: 1px solid var(--color-white);
      border-radius: 4px;
      background-color: var(--color-white);
    }

    .index-logistics__button-body {
      padding-inline: 16px 20px;
    }

    .index-logistics__button-title {
      font-size: 1.6rem;
    }
    .index-logistics__button-text {
      font-size: 1.2rem;
      line-height: calc(20 / 12);
      letter-spacing: calc(1em * 0.04);
      margin-top: 8px;
    }

    .index-logistics__button-arrow {
      display: flex;
      width: 24px;
      height: 24px;
    }

    @media (width < 1024px) {
      .index-logistics {
        padding: 64px 16px;
      }
      .index-logistics__grid {
        grid-template-columns: repeat(2, 1fr);
        margin-top: 40px;
      }
    }
    @media (width < 768px) {
      .index-logistics__grid {
        grid-template-columns: 1fr;
        row-gap: 8px;
      }

      .index-logistics__button {
        padding: 16px;
      }
    }

    @media (any-hover: hover) {
      .index-logistics__button {
        transition: var(--transition-hover);
        transition-property: color, background-color;

        &:hover {
          background-color: var(--color-main-blue);
          color: var(--color-white);

          .index-logistics__button-title {
            color: inherit;
          }
        }
      }
    }
  }@layer pages {
    .index-recruit {
      background-color: var(--color-white);
      width: 100%;
      padding-block: 182px 200px;

      @media (width < 1280px) {
        padding-block: 120px;
      }

      @media (width < 1024px) {
        padding-block: 80px;
      }
    }

    .index-recruit__wrapper {
      display: grid;
      grid-template-columns: calc(283 / 1536 * 100%) 1fr;

      @media (width < 1024px) {
        grid-template-columns: 1fr;
        gap: 33px 0;
        position: relative;
      }
    }
    .index-recruit__header {
      color: var(--color-main-blue);
      padding-right: 38px;
      background-color: var(--color-white);
      writing-mode: vertical-rl;

      @media (width < 1024px) {
        padding-block: 16px;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
      }
    }

    .index-recruit__title {
      font-size: 8rem;
      font-weight: 600;
      font-family: var(--font-family-figtree);
      letter-spacing: calc(1em * 0.04);
      line-height: calc(96 / 80);

      @media (width < 1280px) {
        font-size: 4.8rem;
      }

      @media (width < 1024px) {
        font-size: 4rem;
      }
    }

    .index-recruit__japanese {
      font-size: 2.4rem;
      letter-spacing: calc(1em * 0.16);
      display: grid;
      grid-template-columns: 8px 1fr;
      column-gap: 8px;
      align-items: center;

      &::before {
        width: 8px;
        height: 8px;
        content: '';
        display: block;
        border-radius: var(--border-radius-full);
        background-color: currentColor;
      }
      @media (width < 1024px) {
        font-size: 1.4rem;

        &::before {
          width: 6px;
          height: 6px;
        }
      }
    }

    .index-recruit__body {
      background: linear-gradient(-90deg, #00389e 0%, #015aff 100%);
      padding: 62px 127px 76px calc(56 / 1536 * 100vw);
      display: grid;
      grid-template-columns: 1fr 500px;
      column-gap: calc(62 / 1536 * 100vw);

      @media (width < 1380px) {
        padding-inline: 40px;
      }

      @media (width < 1280px) {
        padding: 48px 32px;
        column-gap: 32px;
        grid-template-columns: 1fr 380px;
      }
      @media (width < 1024px) {
        grid-template-columns: 1fr;
        background: linear-gradient(180deg, #00389e 0%, #015aff 100%);
        padding: 136px 16px 80px;
      }
    }
    .index-recruit__picture {
      position: relative;
      @media (width < 1024px) {
        display: contents;
      }
    }
    .index-recruit__image {
      position: absolute;
      right: 0;
      top: 50%;
      translate: 0 -50%;

      @media (width < 1280px) {
        width: 380px;
        height: 328px;
      }

      @media (width < 1024px) {
        width: 300px;
        height: 259px;
        translate: 0 0;
        top: 0;
      }
    }

    .index-recruit__text {
      color: var(--color-white);
      margin-bottom: 60px;

      @media (width < 1280px) {
        margin-bottom: 24px;
      }
    }
  }@layer pages {
    .index-sustainability {
      width: 100%;
      background-color: var(--color-white);
      padding-block-end: 200px;
      @media (width < 768px) {
        padding-block-end: 80px;
      }
    }
    .index-sustainability__wrapper {
      background: url(/img/index/bg-sustainability.jpg) no-repeat 0 0;
      background-size: cover;
      padding-inline: 20px;

      @media (width < 1024px) {
        padding-inline-end: 0;
      }
      @media (width < 768px) {
        background: none;
        padding-inline: 0;
      }
    }

    .index-sustainability__inner {
      width: 100%;
      max-width: var(--width-index-contents);
      margin-inline: auto;
    }
    .index-sustainability__body {
      background-color: var(--color-white);
      margin-left: auto;
      width: calc(727 / 1296 * 100%);
      padding: 44px 72px 40px;

      @media (width < 1024px) {
        padding-inline: 40px;
      }
      @media (width < 768px) {
        width: 100%;
        padding-inline: 16px;
        padding-block: 0;

        &::before {
          content: '';
          display: block;
          width: 100%;
          aspect-ratio: 343 / 167;
          max-height: 167px;
          background: url(/img/index/bg-sustainability.jpg) no-repeat 0 0;
          background-size: cover;
          border-radius: 4px;
          margin-bottom: 30px;
        }
      }
    }
    .index-sustainability__text {
      margin-block: 40px;
      @media (width < 768px) {
        margin-block: 24px;
      }
    }
    .index-sustainability__buttons {
      display: grid;
      grid-template-columns: 1fr;
      grid-template-rows: repeat(3, 56px);
      row-gap: 16px;
    }
  }@layer components {
    .topics-list-item {
      border-bottom: 1px solid var(--color-blue-gray);
    }

    .topics-list-item__link {
      display: grid;
      grid-template-columns: 1fr 24px;
      align-items: center;
      padding-block: 10px 16px;
      text-decoration: none;
      column-gap: 16px;

      @media (width < 768px) {
        padding-block: 12px;
      }
    }

    .topics-list-item__time {
      font-size: 1.2rem;
      font-weight: 500;
      color: var(--color-dark-gray);
    }

    .topics-list-item__inner {
      display: flex;
      flex-direction: column;
      row-gap: 4px;
    }

    .topics-list-item__label {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: var(--color-main-blue);
      font-size: 1.2rem;
      background-color: var(--color-pale-blue-gray);
      width: fit-content;
      padding-inline: 6px;
      height: 18px;
      border-radius: 4px;
      margin-left: 8px;
    }

    .topics-list-item__icon--pdf {
      color: var(--color-red);
    }

    @media (any-hover: hover) {
      .topics-list-item__link {
        transition: background-color var(--transition-hover);
      }
      .topics-list-item__link:hover {
        background-color: var(--color-parl-gray);
      }
    }

    @media (width < 768px) {
      .topics-list-item:first-child {
        .topics-list-item__link {
          padding-block-start: 0;
        }
      }
    }
  }@layer pages {
    .index-topics {
      width: 100%;
      background-color: rgba(5, 67, 170, 0.6);
      padding: 120px 20px 110px;

      @media (width < 768px) {
        padding: 80px 16px;
      }
    }

    .index-topics__inner {
      width: 100%;
      max-width: var(--width-index-contents);
      margin-inline: auto;
    }

    .index-topics__list {
      width: 100%;
      padding: 56px;
      background: var(--color-white);
      border-radius: 4px;
      margin-top: 40px;

      @media (width < 768px) {
        padding: 32px 24px;
      }
    }
  }@layer pages {
    .page-index {
      --color-index-blue: #0543aa;
      --width-index-contents: 1296px;
    }
  }