@charset "UTF-8";
@layer foundation, layout, component, project, utility;
/* ====================================================

Foundation

==================================================== */
@layer foundation {
  *,
  *::before,
  *::after {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  html {
    scroll-behavior: smooth;
  }
  body {
    margin: 0;
  }
  img {
    display: block;
    max-width: 100%;
  }
  a {
    color: inherit;
    text-decoration: none;
  }
  h1,
  h2,
  h3,
  h4,
  p,
  figure,
  blockquote,
  dl,
  dd {
    margin: 0;
  }
  ul,
  ol {
    margin: 0;
    padding: 0;
  }
  li {
    list-style: none;
  }
  input,
  button,
  textarea,
  select {
    font: inherit;
  }
  button {
    cursor: pointer;
  }
}
/* ====================================================

Foundation

==================================================== */
@layer foundation {
  :root {
    /* Color */
    --color-primary: #e60012;
    --color-highschool-bg: #fffae6;
    --color-surface-soft: #F8F8F8;
    --color-surface-pink: #fff2f3;
    --color-text: #323232;
    --color-white: #ffffff;
    --color-yellow: #ffff8e;
    --color-yellow-shadow: #fdeeb6;
    --color-orange: #FF6F00;
    --color-blue: #487efe;
    --color-green: #00B95D;
    --color-border-gray: #cfcfcf;
    --color-border-dark: #8f8f8f;
    /* Font Family */
    --font-family-base: "Noto Sans JP", sans-serif;
    --font-family-en: "Jost", sans-serif;
    /* Font Weight */
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-bold: 700;
    --font-weight-extra-bold: 800;
    /* Container */
    --container-padding-inline: 32px;
    --container-padding-inline-lg: 48px;
    /* Radius */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 10px;
    --radius-pill: 999px;
    /* Container */
    --container-width: 600px;
    /* Transition */
    --duration-fast: 0.2s;
    --duration-normal: 0.3s;
  }
  @media screen and (max-width: 600px) {
    :root {
      --container-padding-inline: 16px;
      --container-padding-inline-lg: 24px;
    }
  }
}
/* ====================================================

Foundation

==================================================== */
@layer foundation {
  html,
  body {
    overflow-x: hidden;
    overflow-x: clip;
  }
  body {
    font-family: var(--font-family-base);
    color: var(--color-text);
    background: var(--color-highschool-bg) url("../images/common/body_bg.png") 0 0/874px 519px repeat;
    background-attachment: fixed;
  }
  @media screen and (max-width: 600px) {
    body {
      background-attachment: scroll;
    }
  }
}
/* ====================================================

Layout

==================================================== */
@layer layout {
  .l-page {
    position: relative;
    z-index: 30;
    display: block;
    padding: 0px;
  }
  @media screen and (max-width: 600px) {
    .l-page {
      padding: 0;
    }
  }
  @media screen and (max-width: 376px) {
    .l-page {
      width: 376px;
      -webkit-transform: scale(var(--page-scale, 1));
              transform: scale(var(--page-scale, 1));
      -webkit-transform-origin: top left;
              transform-origin: top left;
    }
    @supports (zoom: 1) {
      .l-page {
        zoom: var(--page-scale, 1);
        -webkit-transform: none;
                transform: none;
      }
    }
    body {
      overflow-x: hidden;
    }
  }
  .l-main {
    width: 100%;
  }
  .l-contents {
    max-width: 600px;
    margin-inline: auto;
  }
  .l-container {
    padding-left: var(--container-padding-inline);
    padding-right: var(--container-padding-inline);
  }
  .l-container--lg {
    padding-left: var(--container-padding-inline-lg);
    padding-right: var(--container-padding-inline-lg);
  }
}
/* ====================================================

Component

==================================================== */
@layer component {
  .c-bg-grid {
    background: #FFFFFF;
    background-repeat: repeat;
    background-size: auto;
    background-position: 0 0;
  }
  .c-bg-grid--pink {
    --bg-grid-border-color: #ffb7c2;
    background-image: url("../images/common/bg_grid02.png");
  }
  .c-bg-grid--yellow {
    --bg-grid-border-color: var(--color-primary);
    background-image: url("../images/common/bg_grid01.png");
  }
  .c-bg-grid--top-border {
    padding-top: clamp(3.5rem, 1.65rem + 7.6vw, 4.5rem);
    border-top: 6px solid var(--bg-grid-border-color);
  }
  .c-bg-grid--halfway {
    position: relative;
    padding-top: clamp(3.5rem, 1.65rem + 7.6vw, 4.5rem);
    border-top: 6px solid var(--color-primary);
  }
  .c-bg-grid--halfway:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 485px;
    background-image: url("../images/common/bg_grid01.png");
    background-repeat: repeat;
    background-size: auto;
    background-position: 0 0;
  }
  .c-bg-grid--halfway__wrap {
    position: relative;
    z-index: 1;
  }
  .c-global-brand {
    position: fixed;
    top: 18px;
    left: 24px;
    z-index: 20;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 10px;
    font-size: 0.78rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
  }
  .c-global-brand img {
    width: 100px;
  }
  .c-mobile-menu-toggle,
  .c-mobile-nav__header {
    display: none;
  }
  .c-mobile-menu-toggle {
    position: fixed;
    top: 18px;
    right: 16px;
    z-index: 200;
    width: 40px;
    height: 40px;
    padding: 0;
    border: 0;
    border-radius: var(--radius-sm);
    background: var(--color-primary);
    cursor: pointer;
  }
  .c-mobile-menu-toggle span {
    position: absolute;
    left: 8px;
    width: 24px;
    height: 2px;
    background: var(--color-white);
    -webkit-transition: opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: transform var(--duration-fast) ease, opacity var(--duration-fast) ease;
    transition: transform var(--duration-fast) ease, opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
  }
  .c-mobile-menu-toggle span:nth-child(1) {
    top: 12px;
  }
  .c-mobile-menu-toggle span:nth-child(2) {
    top: 19px;
  }
  .c-mobile-menu-toggle span:nth-child(3) {
    top: 26px;
  }
  body.is-mobile-nav-open .c-mobile-menu-toggle span:nth-child(1) {
    top: 19px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  body.is-mobile-nav-open .c-mobile-menu-toggle span:nth-child(2) {
    opacity: 0;
  }
  body.is-mobile-nav-open .c-mobile-menu-toggle span:nth-child(3) {
    top: 19px;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
  .c-mobile-nav__header {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
    margin-left: 3px;
  }
  .c-mobile-nav__brand {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 8px;
    color: var(--color-white);
    font-size: 11px;
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
    margin-left: 1px;
  }
  .c-mobile-nav__brand img {
    width: 100px;
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
  .c-mobile-nav__close {
    position: relative;
    width: 28px;
    height: 28px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
  }
  .c-mobile-nav__close span {
    position: absolute;
    top: 13px;
    left: 4px;
    width: 20px;
    height: 2px;
    background: var(--color-white);
  }
  .c-mobile-nav__close span:nth-child(1) {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .c-mobile-nav__close span:nth-child(2) {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
  .c-side-nav {
    position: fixed;
    z-index: 2;
    top: 50%;
    left: max(24px, (100vw - var(--container-width)) / 4 - 145px);
    width: 290px;
    padding: 48px 45px;
    border: 3px solid var(--color-primary);
    border-radius: var(--radius-lg);
    background: var(--color-white);
    -webkit-box-shadow: 7px 7px 0 var(--color-yellow-shadow), inset 0 0 0 2px var(--color-white);
            box-shadow: 7px 7px 0 var(--color-yellow-shadow), inset 0 0 0 2px var(--color-white);
    outline: 1px dashed var(--color-primary);
    outline-offset: -8px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  @media (max-width: 1580px) and (min-width: 1281px) {
    .c-side-nav {
      left: max(24px, (100vw - var(--container-width)) / 4 - 120px);
      width: 220px;
      padding: 40px 28px;
    }
  }
  @media (max-width: 1280px) {
    .c-side-nav {
      position: fixed;
      inset: 0;
      z-index: 290;
      width: auto;
      min-height: 0;
      margin: 0;
      padding: 14px 12px 18px;
      border: 0;
      border-radius: 0;
      background: var(--color-primary);
      -webkit-box-shadow: none;
              box-shadow: none;
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      -webkit-transform: none;
              transform: none;
      -webkit-transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease;
      transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease;
    }
    .c-global-brand {
      position: fixed;
      top: 18px;
      left: 16px;
      z-index: 70;
      gap: 8px;
      font-size: 11px;
      color: var(--color-primary);
    }
    .is-mobile-nav-open .c-side-nav {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
    }
    body.is-mobile-nav-open {
      overflow: hidden;
    }
    .is-mobile-nav-open .c-global-brand {
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
    }
    .c-mobile-menu-toggle {
      display: block;
      top: 9px;
    }
    .c-mobile-nav__header {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
    }
    .c-side-nav__mascot {
      display: none;
    }
  }
  .c-side-nav__mascot {
    position: absolute;
    top: -74px;
    right: 0px;
    width: 85px;
    z-index: 2;
  }
  @media (max-width: 1580px) and (min-width: 1281px) {
    .c-side-nav__mascot {
      top: -58px;
      width: 68px;
    }
  }
  @media (max-width: 1024px) {
    .c-side-nav {
      z-index: 120;
    }
    .c-side-nav__mascot {
      top: -42px;
    }
  }
  @media (max-width: 1280px) {
    .c-side-nav nav {
      position: relative;
      overflow-y: scroll;
      height: calc(100% - 42px);
      padding: 10px 8px 8px;
      border: 3px solid var(--color-white);
      border-radius: 10px;
      -webkit-box-shadow: inset 0 0 0 2px var(--color-white);
              box-shadow: inset 0 0 0 2px var(--color-white);
      outline: 1px dashed var(--color-primary);
      outline-offset: -5px;
      background: var(--color-white);
    }
  }
  .c-side-nav__list {
    display: grid;
    gap: 14px;
  }
  .c-side-nav__list a {
    display: block;
    padding: 8px 18px;
    font-size: 16px;
    font-weight: var(--font-weight-medium);
    line-height: 1;
    color: #1a1a1a;
    white-space: nowrap;
    -webkit-transition: color var(--duration-fast) ease;
    transition: color var(--duration-fast) ease;
  }
  @media (hover: hover) and (pointer: fine) {
    .c-side-nav__list a:hover {
      color: var(--color-primary);
    }
  }
  .c-side-nav__list a.is-active {
    position: relative;
    color: var(--color-primary);
    font-weight: var(--font-weight-bold);
  }
  .c-side-nav__list a.is-active::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 3px;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--color-primary);
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  @media (max-width: 1580px) and (min-width: 1281px) {
    .c-side-nav__list {
      gap: 10px;
    }
    .c-side-nav__list a {
      font-size: 14px;
    }
  }
  @media (max-width: 1280px) {
    .c-side-nav__list {
      height: 100%;
      -ms-flex-line-pack: start;
          align-content: start;
      gap: clamp(0.0625rem, -0.738rem + 3.3vw, 0.5rem);
      padding: clamp(1rem, -0.175rem + 4.8vw, 1.625rem) 0 14px;
      position: relative;
      z-index: 1;
    }
    .c-side-nav__list li:last-child {
      padding-bottom: 24px;
    }
    .c-side-nav__list a {
      padding: 9px 12px;
      font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
      line-height: 1.75;
      text-align: center;
    }
    .c-side-nav__list a.is-active {
      font-weight: var(--font-weight-bold);
    }
    .c-side-nav__list a.is-active::before {
      display: none;
    }
  }
  @media (max-width: 1024px) {
    .c-side-nav__list a.is-active::before {
      display: none;
    }
  }
  @media (max-width: 640px) {
    .c-global-brand {
      position: fixed;
      top: 18px;
      left: 16px;
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      -webkit-transform: translateY(-8px);
              transform: translateY(-8px);
      -webkit-transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
      transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
      transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, transform var(--duration-fast) ease;
      transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, transform var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    }
    .c-mobile-menu-toggle {
      position: fixed;
      top: 9px;
      right: 16px;
      z-index: 200;
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      -webkit-transform: translateY(-8px);
              transform: translateY(-8px);
      -webkit-transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
      transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
      transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, transform var(--duration-fast) ease;
      transition: opacity var(--duration-fast) ease, visibility var(--duration-fast) ease, transform var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    }
    .c-side-nav nav {
      width: 100%;
      overflow-y: scroll;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
    }
    body.is-sp-header-visible .c-mobile-menu-toggle,
    body.is-mobile-nav-open .c-mobile-menu-toggle,
    body.is-page-top .c-global-brand {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    .is-mobile-nav-open .c-global-brand,
    body.is-mobile-nav-open .c-global-brand {
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      -webkit-transform: translateY(-8px);
              transform: translateY(-8px);
    }
  }
  .c-section-heading {
    position: relative;
    z-index: 1;
    margin-bottom: 32px;
    text-align: center;
  }
  .c-section-heading.c-section-heading--inverse .c-section-heading__title,
  .c-section-heading.c-section-heading--inverse .c-section-heading__eng {
    color: var(--color-white);
  }
  .c-section-heading.c-section-heading--inverse .c-section-heading__eng {
    text-shadow: none;
  }
  .c-section-heading.c-section-heading--sm .c-section-heading__title {
    font-size: clamp(0.75rem, 0.625rem + 0.5vw, 0.8125rem);
  }
  .c-section-heading.c-section-heading--sm .c-section-heading__eng {
    font-size: clamp(1.75rem, 0.362rem + 5.7vw, 2.5rem);
  }
  .c-section-heading.c-section-heading--works .c-section-heading__eng {
    margin-top: -80px;
  }
  .c-section-heading__eng {
    font-family: var(--font-family-en);
    font-size: clamp(2.5rem, 0.188rem + 9.5vw, 3.75rem);
    font-weight: 900;
    line-height: 1;
    text-align: center;
    color: var(--color-primary);
    text-shadow: 4px 4px 0 var(--color-yellow);
    letter-spacing: 0.03em;
  }
  .c-section-heading__title {
    margin: 10px 0 0;
    font-size: clamp(0.9375rem, 0.6rem + 1.4vw, 1.125rem);
    font-weight: var(--font-weight-bold);
  }
  .c-section-heading__sub {
    display: inline-block;
    margin: 0 0 16px;
    padding: 0.4em 1em 0.5em;
    font-size: clamp(0.8125rem, 0.225rem + 2.4vw, 1.125rem);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-pill);
    color: var(--color-white);
    background-color: var(--color-primary);
    -webkit-box-shadow: 2px 2px 0 var(--color-yellow);
            box-shadow: 2px 2px 0 var(--color-yellow);
    line-height: 1;
  }
  .c-section-heading--half-circle {
    position: relative;
    width: 100%;
    min-height: clamp(13.75rem, 4.463rem + 38.1vw, 18.75rem);
    padding: clamp(5.625rem, 0.75rem + 20vw, 8.25rem) 0 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    background: transparent;
    overflow: hidden;
    opacity: 1;
  }
  .c-section-heading--half-circle:before {
    content: "";
    position: absolute;
    inset: 0;
    background: -webkit-gradient(linear, left top, left bottom, from(#ffec8e), color-stop(56%, rgba(255, 255, 247, 0.9607843137)), to(var(--color-white)));
    background: linear-gradient(180deg, #ffec8e 0%, rgba(255, 255, 247, 0.9607843137) 56%, var(--color-white) 100%);
    border-radius: 300px 300px 0 0;
    z-index: 0;
  }
  .c-section-heading--half-circle + div {
    position: relative;
    z-index: 100;
    margin-top: -32px;
    background: var(--color-white);
  }
  .c-section-heading--half-circle--2steps + div {
    margin-top: 0px;
  }
  .c-pill-heading {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: clamp(2.5rem, 1.575rem + 3.8vw, 3rem);
    margin-bottom: 24px;
    padding: 10px 0 12px;
    border: 1px solid var(--color-primary);
    border-radius: var(--radius-pill);
    background: var(--color-white);
    -webkit-box-shadow: 3px 3px 0 var(--color-yellow);
            box-shadow: 3px 3px 0 var(--color-yellow);
    font-size: clamp(1rem, 0.663rem + 1.4vw, 1.1875rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
    color: var(--color-primary);
    text-align: center;
  }
  .c-border-heading {
    position: relative;
    margin-top: clamp(2rem, 1.075rem + 3.8vw, 2.5rem);
    margin-bottom: 10px;
    font-size: clamp(0.9375rem, 0.688rem + 1vw, 1.0625rem);
    font-weight: var(--font-weight-medium);
    position: relative;
    padding: 0.4em 1em 0.5em;
    text-align: center;
    background-color: #FFF4F5;
    border-top: 1px dashed #FFBABF;
    border-bottom: 1px dashed #FFBABF;
    color: var(--color-primary);
  }
  .c-lead {
    font-size: clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.6;
    text-align: center;
  }
  .c-lead.c-lead--inverse {
    color: var(--color-white);
  }
  .c-lead__img {
    margin-top: clamp(2rem, 1.075rem + 3.8vw, 2.5rem);
    margin-bottom: clamp(1.5rem, 0.575rem + 3.8vw, 2rem);
  }
  .c-lead__img img {
    border-radius: var(--radius-lg);
  }
  .c-lead__img img + img {
    margin-top: clamp(0.5rem, -0.425rem + 3.8vw, 1rem);
  }
  .c-body {
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    font-weight: var(--font-weight-regular);
    line-height: 2;
    text-align: justify;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    letter-spacing: 0.04em;
    text-wrap: pretty;
  }
  .c-body--center {
    text-align: center;
  }
  .c-link-text {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    gap: 0.35em;
    color: var(--color-primary);
    font-weight: var(--font-weight-regular);
    text-decoration-line: none;
    background-image: -webkit-gradient(linear, left top, left bottom, from(var(--color-yellow)), to(var(--color-yellow)));
    background-image: linear-gradient(var(--color-yellow), var(--color-yellow));
    background-repeat: no-repeat;
    background-position: 0 100%;
    background-size: 100% 0;
    -webkit-transition: background-size var(--duration-fast) ease, text-decoration-color var(--duration-fast) ease;
    transition: background-size var(--duration-fast) ease, text-decoration-color var(--duration-fast) ease;
  }
  .c-link-text::after {
    content: "";
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    width: 0.55em;
    height: 0.55em;
    border-top: 1px solid currentColor;
    border-right: 1px solid currentColor;
    -webkit-transform: translateY(-0.05em) rotate(45deg);
            transform: translateY(-0.05em) rotate(45deg);
    -webkit-transition: -webkit-transform var(--duration-fast) ease;
    transition: -webkit-transform var(--duration-fast) ease;
    transition: transform var(--duration-fast) ease;
    transition: transform var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
  }
  @media (hover: hover) and (pointer: fine) {
    .c-link-text:hover {
      background-size: 100% 0.5em;
      text-decoration-color: transparent;
    }
    .c-link-text:hover::after {
      -webkit-transform: translate(0.18em, -0.05em) rotate(45deg);
              transform: translate(0.18em, -0.05em) rotate(45deg);
    }
  }
  .c-link-text:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 3px;
    border-radius: var(--radius-sm);
  }
  .c-infinite-loop {
    overflow: hidden;
  }
  .c-infinite-loop__track {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    will-change: transform;
  }
  .c-infinite-loop__track.is-ready {
    -webkit-animation-name: infinite-loop;
            animation-name: infinite-loop;
    -webkit-animation-timing-function: linear;
            animation-timing-function: linear;
    -webkit-animation-iteration-count: infinite;
            animation-iteration-count: infinite;
    -webkit-animation-duration: var(--loop-duration);
            animation-duration: var(--loop-duration);
  }
  @-webkit-keyframes infinite-loop {
    from {
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
    to {
      -webkit-transform: translate3d(calc(var(--loop-width) * -1), 0, 0);
              transform: translate3d(calc(var(--loop-width) * -1), 0, 0);
    }
  }
  @keyframes infinite-loop {
    from {
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
    }
    to {
      -webkit-transform: translate3d(calc(var(--loop-width) * -1), 0, 0);
              transform: translate3d(calc(var(--loop-width) * -1), 0, 0);
    }
  }
  .c-toggle-button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
    max-width: 440px;
    margin: 0 auto;
    padding: clamp(0.9375rem, 0.6rem + 1.4vw, 1.125rem) clamp(1.125rem, 0.412rem + 2.9vw, 1.5rem) clamp(0.9375rem, 0.6rem + 1.4vw, 1.125rem) clamp(1.5rem, -1.275rem + 11.4vw, 3rem);
    border: 2px solid transparent;
    border-radius: var(--radius-pill);
    background: var(--color-primary);
    -webkit-box-shadow: 4px 4px 0 var(--color-yellow);
            box-shadow: 4px 4px 0 var(--color-yellow);
    color: var(--color-white);
    text-align: left;
    text-decoration: none;
    cursor: pointer;
    -webkit-transition: background-color 0.28s ease-out, color 0.28s ease-out, border-color 0.28s ease-out, -webkit-transform 0.28s ease-out, -webkit-box-shadow 0.28s ease-out;
    transition: background-color 0.28s ease-out, color 0.28s ease-out, border-color 0.28s ease-out, -webkit-transform 0.28s ease-out, -webkit-box-shadow 0.28s ease-out;
    transition: transform 0.28s ease-out, background-color 0.28s ease-out, color 0.28s ease-out, border-color 0.28s ease-out, box-shadow 0.28s ease-out;
    transition: transform 0.28s ease-out, background-color 0.28s ease-out, color 0.28s ease-out, border-color 0.28s ease-out, box-shadow 0.28s ease-out, -webkit-transform 0.28s ease-out, -webkit-box-shadow 0.28s ease-out;
  }
  @media (hover: hover) and (pointer: fine) {
    .c-toggle-button:hover {
      -webkit-transform: translateY(-2px);
              transform: translateY(-2px);
      background: var(--color-white);
      color: var(--color-primary);
      border-color: var(--color-primary);
      -webkit-box-shadow: 0 0 0 transparent;
              box-shadow: 0 0 0 transparent;
    }
    .c-toggle-button:hover .c-toggle-button__divider {
      color: var(--color-primary);
    }
    .c-toggle-button:hover .c-toggle-button__plus {
      -webkit-transform: rotate(180deg) scale(1.08);
              transform: rotate(180deg) scale(1.08);
      background: var(--color-primary);
    }
    .c-toggle-button:hover .c-toggle-button__plus::before, .c-toggle-button:hover .c-toggle-button__plus::after {
      background: var(--color-white);
    }
  }
  .c-toggle-button:focus-visible {
    outline: 3px solid var(--color-yellow);
    outline-offset: 5px;
  }
  .c-toggle-button__copy {
    display: grid;
    gap: 2px;
    line-height: 1.3;
    font-weight: 600;
  }
  .c-toggle-button__copy span {
    font-size: clamp(0.875rem, 0.413rem + 1.9vw, 1.125rem);
  }
  .c-toggle-button__copy strong {
    font-size: clamp(1.125rem, 0.663rem + 1.9vw, 1.375rem);
  }
  .c-toggle-button__divider {
    width: 2px;
    height: clamp(3rem, 1.487rem + 6.2vw, 3.8125rem);
    margin-left: auto;
    margin-right: 18px;
    border-left: 2px dotted currentColor;
    color: var(--color-white);
    -webkit-transition: color 0.28s ease-out;
    transition: color 0.28s ease-out;
  }
  .c-toggle-button__plus {
    position: relative;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: clamp(1.75rem, 1.288rem + 1.9vw, 2rem);
    height: clamp(1.75rem, 1.288rem + 1.9vw, 2rem);
    border-radius: 50%;
    background: var(--color-white);
    color: transparent;
    font-size: 0;
    line-height: 1;
    -webkit-transition: background-color 0.28s ease-out, -webkit-transform 0.28s ease-out;
    transition: background-color 0.28s ease-out, -webkit-transform 0.28s ease-out;
    transition: transform 0.28s ease-out, background-color 0.28s ease-out;
    transition: transform 0.28s ease-out, background-color 0.28s ease-out, -webkit-transform 0.28s ease-out;
  }
  .c-toggle-button__plus::before, .c-toggle-button__plus::after {
    content: "";
    position: absolute;
    width: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    height: 3px;
    background: var(--color-primary);
    -webkit-transition: background-color 0.28s ease-out;
    transition: background-color 0.28s ease-out;
  }
  .c-toggle-button__plus::after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .c-accordion {
    width: 100%;
    margin: 0 auto;
  }
  .c-accordion.is-open .c-accordion__surface {
    border-radius: 20px;
    background: var(--color-white);
    -webkit-transform: none;
            transform: none;
    -webkit-box-shadow: 4px 4px 0 var(--color-yellow);
            box-shadow: 4px 4px 0 var(--color-yellow);
  }
  .c-accordion.is-open .c-accordion-panel {
    opacity: 1;
  }
  @media (hover: hover) and (pointer: fine) {
    .c-accordion:not(.is-open) .c-accordion__surface:hover {
      -webkit-transform: translateY(-2px);
              transform: translateY(-2px);
      background: var(--color-primary);
      -webkit-box-shadow: 4px 6px 0 var(--color-yellow);
              box-shadow: 4px 6px 0 var(--color-yellow);
    }
    .c-accordion:not(.is-open) .c-accordion-button:hover {
      color: var(--color-white);
    }
    .c-accordion:not(.is-open) .c-accordion-button:hover .c-accordion-button__divider {
      color: var(--color-white);
    }
    .c-accordion:not(.is-open) .c-accordion-button:hover .c-accordion-button__plus {
      -webkit-transform: rotate(180deg) scale(1.08);
              transform: rotate(180deg) scale(1.08);
      background: var(--color-white);
    }
    .c-accordion:not(.is-open) .c-accordion-button:hover .c-accordion-button__plus::before, .c-accordion:not(.is-open) .c-accordion-button:hover .c-accordion-button__plus::after {
      background: var(--color-primary);
    }
  }
  .c-accordion__surface {
    border: 1px solid var(--color-primary);
    border-radius: var(--radius-pill);
    background: var(--color-white);
    -webkit-box-shadow: 4px 4px 0 var(--color-yellow);
            box-shadow: 4px 4px 0 var(--color-yellow);
    overflow: hidden;
    -webkit-transition: background-color 0.22s ease-out, border-radius 0.22s ease-out, -webkit-transform 0.22s ease-out, -webkit-box-shadow 0.22s ease-out;
    transition: background-color 0.22s ease-out, border-radius 0.22s ease-out, -webkit-transform 0.22s ease-out, -webkit-box-shadow 0.22s ease-out;
    transition: transform 0.22s ease-out, background-color 0.22s ease-out, border-radius 0.22s ease-out, box-shadow 0.22s ease-out;
    transition: transform 0.22s ease-out, background-color 0.22s ease-out, border-radius 0.22s ease-out, box-shadow 0.22s ease-out, -webkit-transform 0.22s ease-out, -webkit-box-shadow 0.22s ease-out;
  }
  .c-accordion-button {
    position: relative;
    z-index: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
    margin: 0;
    padding: clamp(0.9375rem, 0.6rem + 1.4vw, 1.125rem) clamp(1.125rem, 0.412rem + 2.9vw, 1.5rem) clamp(0.9375rem, 0.6rem + 1.4vw, 1.125rem) clamp(1.5rem, -1.275rem + 11.4vw, 3rem);
    border: 0;
    border-radius: inherit;
    background: transparent;
    color: var(--color-text);
    text-align: left;
    cursor: pointer;
    -webkit-transition: background-color 0.22s ease-out, color 0.22s ease-out, border-radius 0.22s ease-out;
    transition: background-color 0.22s ease-out, color 0.22s ease-out, border-radius 0.22s ease-out;
  }
  .c-accordion-button[aria-expanded=true] {
    border-radius: 22px 22px 0 0;
    background: transparent;
    color: var(--color-text);
  }
  .c-accordion-button[aria-expanded=true]::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: var(--color-primary);
  }
  .c-accordion-button[aria-expanded=true] .c-accordion-button__divider {
    color: var(--color-primary);
  }
  .c-accordion-button[aria-expanded=true] .c-accordion-button__plus {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
    background: var(--color-primary);
  }
  .c-accordion-button[aria-expanded=true] .c-accordion-button__plus::before, .c-accordion-button[aria-expanded=true] .c-accordion-button__plus::after {
    background: var(--color-white);
  }
  .c-accordion-button[aria-expanded=true] .c-accordion-button__plus::after {
    opacity: 0;
  }
  @media (hover: hover) and (pointer: fine) {
    .c-accordion-button[aria-expanded=true]:hover {
      background: color-mix(in srgb, var(--color-primary) 6%, var(--color-white));
      color: var(--color-text);
    }
    .c-accordion-button[aria-expanded=true]:hover .c-accordion-button__divider {
      color: var(--color-primary);
    }
    .c-accordion-button[aria-expanded=true]:hover .c-accordion-button__plus {
      -webkit-transform: rotate(180deg) scale(0.94);
              transform: rotate(180deg) scale(0.94);
    }
    .c-accordion-button[aria-expanded=true]:hover .c-accordion-button__plus::before {
      width: clamp(0.625rem, 0.375rem + 1vw, 0.75rem);
    }
  }
  .c-accordion-button:focus-visible {
    outline: 3px solid var(--color-yellow);
    outline-offset: -3px;
  }
  .c-accordion-button__copy {
    display: grid;
    gap: 2px;
    line-height: 1.3;
    font-weight: 600;
  }
  .c-accordion-button__copy span {
    font-size: clamp(0.875rem, 0.413rem + 1.9vw, 1.125rem);
  }
  .c-accordion-button__copy strong {
    font-size: clamp(1.0625rem, 0.475rem + 2.4vw, 1.375rem);
  }
  .c-accordion-button__divider {
    width: 2px;
    height: clamp(3rem, 1.487rem + 6.2vw, 3.8125rem);
    margin-left: auto;
    margin-right: 18px;
    border-left: 2px dotted currentColor;
    color: var(--color-primary);
    -webkit-transition: color 0.22s ease-out;
    transition: color 0.22s ease-out;
  }
  .c-accordion-button__plus {
    position: relative;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: clamp(1.75rem, 1.288rem + 1.9vw, 2rem);
    height: clamp(1.75rem, 1.288rem + 1.9vw, 2rem);
    border-radius: 50%;
    background: var(--color-primary);
    color: transparent;
    font-size: 0;
    line-height: 1;
    -webkit-transition: background-color 0.22s ease-out, -webkit-transform 0.22s ease-out;
    transition: background-color 0.22s ease-out, -webkit-transform 0.22s ease-out;
    transition: transform 0.22s ease-out, background-color 0.22s ease-out;
    transition: transform 0.22s ease-out, background-color 0.22s ease-out, -webkit-transform 0.22s ease-out;
  }
  .c-accordion-button__plus::before, .c-accordion-button__plus::after {
    content: "";
    position: absolute;
    width: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    height: 3px;
    background: var(--color-white);
    -webkit-transition: width 0.22s ease-out, background-color 0.22s ease-out, opacity 0.18s ease-out;
    transition: width 0.22s ease-out, background-color 0.22s ease-out, opacity 0.18s ease-out;
  }
  .c-accordion-button__plus::after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .c-accordion-panel {
    height: 0;
    background: var(--color-white);
    color: var(--color-text);
    overflow: hidden;
    opacity: 0;
    -webkit-transition: height 0.32s ease-out, opacity 0.2s ease-out;
    transition: height 0.32s ease-out, opacity 0.2s ease-out;
    will-change: height;
  }
  .c-accordion-panel__inner {
    padding: clamp(1.5rem, -0.35rem + 7.6vw, 2.5rem) clamp(1rem, -0.85rem + 7.6vw, 2rem) clamp(1.5rem, 0.575rem + 3.8vw, 2rem);
  }
  @media (prefers-reduced-motion: reduce) {
    .c-accordion__surface,
    .c-accordion-button,
    .c-accordion-button__divider,
    .c-accordion-button__plus,
    .c-accordion-button__plus::before,
    .c-accordion-button__plus::after,
    .c-accordion-panel {
      -webkit-transition: none;
      transition: none;
    }
  }
  .c-fact-card {
    aspect-ratio: 1/1;
    padding: clamp(1.25rem, -0.138rem + 5.7vw, 2rem) clamp(1rem, 0.075rem + 3.8vw, 1.5rem);
    border-radius: var(--radius-md);
    background: var(--color-surface-pink);
    position: relative;
    overflow: hidden;
  }
  .c-fact-card__number {
    position: absolute;
    top: 0px;
    right: 0px;
    width: clamp(6.25rem, 1.625rem + 19vw, 8.75rem);
    height: clamp(6.25rem, 1.625rem + 19vw, 8.75rem);
    pointer-events: none;
    z-index: 0;
  }
  .c-fact-card__heading,
  .c-fact-card__main,
  .c-fact-card__note,
  .c-fact-card__breakdown {
    position: relative;
    z-index: 1;
  }
  .c-fact-card__heading {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0;
    font-family: var(--font-family-base);
    font-size: clamp(0.875rem, 0.413rem + 1.9vw, 1.125rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
  }
  .c-fact-card__heading::before {
    content: "●";
    font-size: 65%;
    color: var(--color-primary);
    margin-right: 0.5em;
  }
  .c-fact-card__main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 6px;
    margin-top: clamp(2rem, 0.15rem + 7.6vw, 3rem);
  }
  .c-fact-card__value {
    font-family: var(--font-family-en);
    font-size: clamp(1.875rem, -0.688rem + 10.5vw, 3.25rem);
    font-weight: var(--font-weight-extra-bold);
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--color-primary);
  }
  .c-fact-card__value span {
    letter-spacing: -0.2em;
    font-size: 80%;
  }
  .c-fact-card__unit {
    font-size: clamp(0.75rem, -0.175rem + 3.8vw, 1.25rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
    -webkit-transform: translateY(-6px);
            transform: translateY(-6px);
  }
  .c-fact-card__note {
    margin: 12px 0 0;
    font-family: var(--font-family-base);
    font-size: clamp(0.5625rem, 0.438rem + 0.5vw, 0.625rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.5;
    text-align: center;
  }
  .c-fact-card__breakdown {
    margin: clamp(0.75rem, -0.175rem + 3.8vw, 1.25rem) 0 0;
  }
  .c-fact-card__breakdown div {
    display: grid;
    grid-template-columns: 1fr auto;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    gap: 4px;
  }
  .c-fact-card__breakdown div + div {
    margin-top: clamp(0.5rem, -0.3rem + 3.3vw, 0.9375rem);
  }
  .c-fact-card__breakdown dt {
    font-size: clamp(0.75rem, 0.5rem + 1vw, 0.875rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.5;
  }
  .c-fact-card__breakdown dd {
    font-family: var(--font-family-en);
    font-size: clamp(1.125rem, 0.075rem + 4.3vw, 1.6875rem);
    font-weight: var(--font-weight-bold);
    line-height: 1;
    color: var(--color-primary);
  }
  .c-fact-card__breakdown dd span {
    margin-left: 2px;
    font-size: clamp(0.75rem, 0.5rem + 1vw, 0.875rem);
    color: var(--color-text);
  }
  .c-fact-card--ratio .c-fact-card__note {
    margin-top: clamp(0.5rem, -0.425rem + 3.8vw, 1rem);
  }
  .c-work-card {
    position: relative;
    margin-top: clamp(2rem, 0.15rem + 7.6vw, 3rem);
    padding: 40px clamp(1.25rem, -0.138rem + 5.7vw, 2rem) clamp(2.5rem, -0.275rem + 11.4vw, 4rem);
    color: var(--color-white);
    border-radius: clamp(1.25rem, -1.063rem + 9.5vw, 2.5rem);
  }
  .c-work-card--orange {
    background: var(--color-orange);
  }
  .c-work-card--blue {
    background: var(--color-blue);
  }
  .c-work-card--green {
    background: var(--color-green);
  }
  .c-work-card__loop {
    position: absolute;
    left: 0px;
    right: 0px;
    top: clamp(1.75rem, 1.288rem + 1.9vw, 2rem);
    width: 100%;
    font-family: var(--font-family-en);
    font-size: clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
    font-weight: var(--font-weight-bold);
    line-height: 1;
    opacity: 16%;
  }
  .c-work-card__loop__track {
    -webkit-column-gap: 10px;
       -moz-column-gap: 10px;
            column-gap: 10px;
  }
  .c-work-card__title {
    margin: clamp(1.25rem, -1.063rem + 9.5vw, 2.5rem) 0 0;
    font-family: var(--font-family-base);
    font-size: clamp(2.1875rem, 0.675rem + 6.2vw, 3rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
  }
  .c-work-card__number {
    position: absolute;
    top: 8px;
    right: 32px;
    font-family: var(--font-family-en);
    font-size: clamp(4.5rem, 0.55rem + 16.2vw, 6.625rem);
    font-weight: var(--font-weight-regular);
    color: transparent;
    text-align: right;
    -webkit-text-stroke: clamp(0.0625rem, -0.063rem + 0.5vw, 0.125rem) var(--color-white);
    text-stroke: 2px var(--color-white);
  }
  .c-work-card__media {
    position: relative;
    z-index: 1;
    border-radius: var(--radius-lg);
    margin-top: 24px;
    overflow: hidden;
  }
  .c-work-card__tag {
    position: absolute;
    z-index: 2;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    top: -5px;
    left: -5px;
    padding: 8px 16px 16px 0;
    border-radius: 0px 0px var(--radius-lg) 0px;
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    font-weight: var(--font-weight-bold);
    line-height: 1;
    color: var(--color-yellow);
  }
  .c-work-card--orange .c-work-card__tag {
    background: var(--color-orange);
  }
  .c-work-card--blue .c-work-card__tag {
    background: var(--color-blue);
  }
  .c-work-card--green .c-work-card__tag {
    background: var(--color-green);
  }
  .c-work-card__lead {
    margin: clamp(1.25rem, -0.138rem + 5.7vw, 2rem) 0 clamp(1rem, 0.075rem + 3.8vw, 1.5rem);
    font-family: var(--font-family-base);
    font-size: clamp(1.25rem, 0.537rem + 2.9vw, 1.625rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.6;
  }
  .c-work-card__text {
    font-size: clamp(0.9375rem, 0.688rem + 1vw, 1.0625rem);
    font-weight: var(--font-weight-medium);
    line-height: 2;
    text-align: justify;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    letter-spacing: 0.05em;
    text-wrap: pretty;
  }
  .c-work-card__text p + p {
    margin-top: 16px;
  }
  .c-work-card__btn {
    margin-top: 32px;
  }
  .c-work-card__step-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    min-height: clamp(3rem, 1.612rem + 5.7vw, 3.75rem);
    overflow: hidden;
    border: 2px solid var(--color-primary);
    border-radius: clamp(0.25rem, -0.463rem + 2.9vw, 0.625rem);
  }
  .c-work-card__step-label {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: clamp(4rem, 1.9rem + 8.6vw, 5.125rem);
    background: var(--color-primary);
    font-family: var(--font-family-en);
    font-size: clamp(0.8125rem, 0.563rem + 1vw, 0.9375rem);
    font-weight: var(--font-weight-bold);
    line-height: 1;
    color: var(--color-white);
  }
  .c-work-card__step-name {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0 clamp(0.625rem, -0.3rem + 3.8vw, 1.125rem);
    font-family: var(--font-family-base);
    font-size: clamp(0.875rem, 0.162rem + 2.9vw, 1.25rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.5;
    color: var(--color-primary);
  }
  .c-work-card__step-media {
    display: grid;
    gap: 12px;
    margin-top: 20px;
  }
  .c-work-card__step-media img {
    border-radius: clamp(0.25rem, -0.463rem + 2.9vw, 0.625rem);
  }
  .c-work-card__step-text {
    margin: 16px 0 0;
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    line-height: 1.8;
    text-align: justify;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    letter-spacing: 0.04em;
    text-wrap: pretty;
  }
  .c-work-card__feature-step-arrow {
    position: relative;
    margin: 20px auto 20px;
    text-align: center;
  }
  .c-work-card__feature-step-arrow img {
    margin-inline: auto;
  }
  .c-close-button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    min-height: clamp(3rem, 1.15rem + 7.6vw, 4rem);
    margin-top: clamp(1.5rem, -0.35rem + 7.6vw, 2.5rem);
    border: 1px solid var(--color-border-dark);
    border-radius: var(--radius-pill);
    background: var(--color-white);
    font-family: var(--font-family-base);
    font-size: clamp(0.875rem, 0.413rem + 1.9vw, 1.125rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.5;
    color: var(--color-primary);
    cursor: pointer;
    -webkit-transition: color var(--duration-fast) ease, background-color var(--duration-fast) ease, border-color var(--duration-fast) ease;
    transition: color var(--duration-fast) ease, background-color var(--duration-fast) ease, border-color var(--duration-fast) ease;
  }
  @media (hover: hover) and (pointer: fine) {
    .c-close-button:hover {
      background-color: var(--color-primary);
      color: var(--color-white);
      border-color: var(--color-primary);
    }
  }
  .c-interview-card {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: 100%;
    border: clamp(0.125rem, 0rem + 0.5vw, 0.1875rem) solid var(--color-orange);
    border-radius: clamp(0.625rem, -0.55rem + 4.8vw, 1.25rem);
    overflow: hidden;
    background: var(--color-white);
    -webkit-transition: -webkit-transform 0.28s ease-out, -webkit-box-shadow 0.28s ease-out;
    transition: -webkit-transform 0.28s ease-out, -webkit-box-shadow 0.28s ease-out;
    transition: transform 0.28s ease-out, box-shadow 0.28s ease-out;
    transition: transform 0.28s ease-out, box-shadow 0.28s ease-out, -webkit-transform 0.28s ease-out, -webkit-box-shadow 0.28s ease-out;
  }
  .c-interview-card--orange {
    border-color: var(--color-orange);
    background-color: var(--color-orange);
  }
  .c-interview-card--blue {
    border-color: var(--color-blue);
    background-color: var(--color-blue);
  }
  .c-interview-card--green {
    border-color: var(--color-green);
    background-color: var(--color-green);
  }
  .c-interview-card img {
    display: block;
    width: 100%;
    aspect-ratio: 176/179;
    -o-object-fit: cover;
       object-fit: cover;
    overflow: hidden;
    -webkit-transition: -webkit-transform 0.38s ease-out, -webkit-filter 0.38s ease-out;
    transition: -webkit-transform 0.38s ease-out, -webkit-filter 0.38s ease-out;
    transition: transform 0.38s ease-out, filter 0.38s ease-out;
    transition: transform 0.38s ease-out, filter 0.38s ease-out, -webkit-transform 0.38s ease-out, -webkit-filter 0.38s ease-out;
  }
  .c-interview-card .c-interview-card__plus,
  .c-interview-card .c-interview-card__plus::before,
  .c-interview-card .c-interview-card__plus::after {
    -webkit-transition: background-color 0.28s ease-out, -webkit-transform 0.28s ease-out;
    transition: background-color 0.28s ease-out, -webkit-transform 0.28s ease-out;
    transition: transform 0.28s ease-out, background-color 0.28s ease-out;
    transition: transform 0.28s ease-out, background-color 0.28s ease-out, -webkit-transform 0.28s ease-out;
  }
  @media (hover: hover) and (pointer: fine) {
    .c-interview-card:hover {
      -webkit-transform: translateY(-2px);
              transform: translateY(-2px);
      -webkit-box-shadow: clamp(0.1875rem, -0.063rem + 1vw, 0.3125rem) clamp(0.1875rem, -0.063rem + 1vw, 0.3125rem) 0 var(--color-yellow);
              box-shadow: clamp(0.1875rem, -0.063rem + 1vw, 0.3125rem) clamp(0.1875rem, -0.063rem + 1vw, 0.3125rem) 0 var(--color-yellow);
    }
    .c-interview-card:hover img {
      -webkit-transform: scale(1.06);
              transform: scale(1.06);
      -webkit-filter: brightness(1.06) saturate(1.05);
              filter: brightness(1.06) saturate(1.05);
    }
    .c-interview-card:hover .c-interview-card__plus {
      -webkit-transform: rotate(180deg) scale(1.12);
              transform: rotate(180deg) scale(1.12);
    }
    .c-interview-card:hover .c-interview-card__plus::before,
    .c-interview-card:hover .c-interview-card__plus::after {
      background: var(--color-primary);
    }
  }
  .c-interview-card:focus-visible {
    outline: 3px solid var(--color-yellow);
    outline-offset: 5px;
  }
  .c-interview-card__media {
    overflow: hidden;
  }
  .c-interview-card__footer {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    gap: clamp(0.5rem, -0.213rem + 2.9vw, 0.875rem);
    padding: clamp(0.875rem, 0.538rem + 1.4vw, 1.0625rem) clamp(0.5rem, -0.425rem + 3.8vw, 1rem) clamp(0.8125rem, 0.563rem + 1vw, 0.9375rem) clamp(0.625rem, -0.55rem + 4.8vw, 1.25rem);
    background: var(--color-orange);
    color: var(--color-white);
  }
  .c-interview-card--orange .c-interview-card__footer {
    background: var(--color-orange);
  }
  .c-interview-card--blue .c-interview-card__footer {
    background: var(--color-blue);
  }
  .c-interview-card--green .c-interview-card__footer {
    background: var(--color-green);
  }
  .c-interview-card__text {
    display: grid;
    gap: 2px;
    line-height: 1.4;
  }
  .c-interview-card__text span {
    font-size: clamp(0.75rem, 0.625rem + 0.5vw, 0.8125rem);
    font-weight: var(--font-weight-medium);
    letter-spacing: 0.05em;
    color: var(--color-yellow);
  }
  .c-interview-card__text strong {
    font-size: clamp(0.875rem, 0.162rem + 2.9vw, 1.25rem);
    font-weight: var(--font-weight-bold);
    color: var(--color-white);
    letter-spacing: 0.03em;
  }
  .c-interview-card__divider {
    width: 2px;
    height: clamp(2rem, 0.15rem + 7.6vw, 3rem);
    margin-left: auto;
    border-left: 2px dotted var(--color-white);
  }
  .c-interview-card__plus {
    position: relative;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
    height: clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
    border-radius: 50%;
    background: var(--color-white);
    color: transparent;
    font-size: 0;
    line-height: 0;
  }
  .c-interview-card__plus::before,
  .c-interview-card__plus::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: clamp(0.625rem, 0.288rem + 1.4vw, 0.8125rem);
    height: clamp(0.125rem, 0rem + 0.5vw, 0.1875rem);
    background: var(--color-primary);
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  .c-interview-card__plus::after {
    -webkit-transform: translate(-50%, -50%) rotate(90deg);
            transform: translate(-50%, -50%) rotate(90deg);
  }
  .c-tour-flow__img {
    margin-top: 16px;
  }
  .c-benefit-card {
    padding: clamp(1.25rem, -0.138rem + 5.7vw, 2rem);
    border-radius: clamp(0.625rem, -0.55rem + 4.8vw, 1.25rem);
    background: var(--color-white);
    -webkit-box-shadow: 0 0px clamp(0.5rem, 0.25rem + 1vw, 0.625rem) rgba(0, 0, 0, 0.1607843137);
            box-shadow: 0 0px clamp(0.5rem, 0.25rem + 1vw, 0.625rem) rgba(0, 0, 0, 0.1607843137);
    overflow: hidden;
  }
  .c-benefit-card + .c-benefit-card {
    margin-top: clamp(1.25rem, -0.138rem + 5.7vw, 2rem);
  }
  .c-benefit-card img {
    border-radius: clamp(0.5rem, 0.25rem + 1vw, 0.625rem);
  }
  .c-benefit-card img + img {
    margin-top: 10px;
  }
  .c-benefit-card__title {
    margin: 16px 0 0;
    font-size: clamp(1rem, 0.538rem + 1.9vw, 1.25rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.6;
    color: var(--color-primary);
  }
  .c-benefit-card__body {
    margin: 8px 0 0;
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    line-height: 1.8;
  }
  .c-benefit-card--benefits-list .c-benefit-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    -webkit-column-gap: 24px;
       -moz-column-gap: 24px;
            column-gap: 24px;
    row-gap: clamp(0.1875rem, -0.063rem + 1vw, 0.3125rem);
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .c-benefit-card--benefits-list .c-benefit-list li {
    position: relative;
    min-height: 30px;
    padding-left: 18px;
    font-size: clamp(0.875rem, 0.75rem + 0.5vw, 0.9375rem);
    line-height: 1.5;
  }
  .c-benefit-card--benefits-list .c-benefit-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.8em;
    width: clamp(0.5rem, 0.25rem + 1vw, 0.625rem);
    height: clamp(0.5rem, 0.25rem + 1vw, 0.625rem);
    border-radius: 50%;
    background: var(--color-primary);
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .c-training-program {
    display: grid;
    grid-template-columns: 118px 1fr auto;
    -webkit-column-gap: 20px;
       -moz-column-gap: 20px;
            column-gap: 20px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    padding: clamp(1.125rem, 0.2rem + 3.8vw, 1.625rem) clamp(1.25rem, -0.138rem + 5.7vw, 2rem) clamp(1.125rem, 0.412rem + 2.9vw, 1.5rem);
    background: var(--color-surface-soft);
    border-radius: clamp(0.625rem, -0.55rem + 4.8vw, 1.25rem);
  }
  @media screen and (max-width: 600px) {
    .c-training-program {
      grid-template-columns: 1fr;
      row-gap: 10px;
    }
  }
  .c-training-program__title {
    font-size: clamp(1rem, 0.75rem + 1vw, 1.125rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.5;
  }
  .c-training-program--orange .c-training-program__title {
    color: var(--color-orange);
  }
  .c-training-program--blue .c-training-program__title {
    color: var(--color-blue);
  }
  .c-training-program--green .c-training-program__title {
    color: var(--color-green);
  }
  .c-training-program__list li {
    position: relative;
    padding-left: 16px;
    font-size: clamp(0.875rem, 0.75rem + 0.5vw, 0.9375rem);
    line-height: 1.6;
  }
  .c-training-program__list li::before {
    content: "";
    position: absolute;
    top: 0.72em;
    left: 0;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .c-training-program--orange .c-training-program__list li::before {
    background: var(--color-orange);
  }
  .c-training-program--blue .c-training-program__list li::before {
    background: var(--color-blue);
  }
  .c-training-program--green .c-training-program__list li::before {
    background: var(--color-green);
  }
  .c-training-program__list li + li {
    margin-top: 8px;
  }
  .c-training-program__etc {
    -ms-flex-item-align: end;
        align-self: end;
    margin: 0 0 4px;
    font-size: 14px;
    line-height: 1.5;
  }
  @media screen and (max-width: 600px) {
    .c-training-program__etc {
      -ms-flex-item-align: auto;
          align-self: auto;
      margin: 0;
      padding-left: 16px;
    }
  }
  .c-faq-list {
    position: relative;
    z-index: 1;
  }
  .c-faq-list details {
    border-radius: var(--radius-lg);
    background: var(--color-white);
    -webkit-box-shadow: 0 0 5px rgba(230, 0, 18, 0.1607843137);
            box-shadow: 0 0 5px rgba(230, 0, 18, 0.1607843137);
  }
  .c-faq-list details + details {
    margin-top: 12px;
  }
  .c-faq-list summary {
    cursor: pointer;
    color: var(--color-primary);
  }
  .c-faq-list p {
    line-height: 1.8;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    letter-spacing: 0.04em;
    text-wrap: pretty;
  }
  .c-faq-item {
    border-radius: var(--radius-lg);
    -webkit-box-shadow: 0 0 5px rgba(230, 0, 18, 0.1607843137);
            box-shadow: 0 0 5px rgba(230, 0, 18, 0.1607843137);
    -webkit-transition: -webkit-box-shadow var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: -webkit-box-shadow var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: box-shadow var(--duration-fast) ease, transform var(--duration-fast) ease;
    transition: box-shadow var(--duration-fast) ease, transform var(--duration-fast) ease, -webkit-box-shadow var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
  }
  @media screen and (min-width: 1024px) and (hover: hover) and (pointer: fine) {
    .c-faq-item:hover {
      -webkit-box-shadow: 0 2px 7px rgba(230, 0, 18, 0.1607843137);
              box-shadow: 0 2px 7px rgba(230, 0, 18, 0.1607843137);
      -webkit-transform: translateY(-1px);
              transform: translateY(-1px);
    }
  }
  .c-faq-item summary,
  .c-faq-item .c-faq-item__answer p {
    display: grid;
    grid-template-columns: clamp(1.75rem, 1.288rem + 1.9vw, 2rem) 1fr;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
  }
  .c-faq-item summary {
    position: relative;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    padding: clamp(0.75rem, -0.175rem + 3.8vw, 1.25rem) clamp(2.75rem, 1.112rem + 6.7vw, 3.625rem) clamp(1.125rem, 0.875rem + 1vw, 1.25rem) clamp(1.125rem, 0.875rem + 1vw, 1.25rem);
    cursor: pointer;
    list-style: none;
  }
  .c-faq-item summary::-webkit-details-marker {
    display: none;
  }
  .c-faq-item summary::before, .c-faq-item summary::after {
    content: "";
    position: absolute;
    top: 50%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .c-faq-item summary::before {
    right: clamp(1rem, 0.538rem + 1.9vw, 1.25rem);
    width: clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
    height: clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
    border-radius: 50%;
    background: var(--color-primary);
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-transition: background-color var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: background-color var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: background-color var(--duration-fast) ease, transform var(--duration-fast) ease;
    transition: background-color var(--duration-fast) ease, transform var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
  }
  .c-faq-item summary::after {
    right: clamp(1.625rem, 0.7rem + 3.8vw, 2.125rem);
    width: clamp(0.625rem, 0.375rem + 1vw, 0.75rem);
    height: clamp(0.125rem, 0rem + 0.5vw, 0.1875rem);
    background: var(--color-white);
    -webkit-transform: translate(50%, -50%);
            transform: translate(50%, -50%);
    -webkit-transition: opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: opacity var(--duration-fast) ease, transform var(--duration-fast) ease;
    transition: opacity var(--duration-fast) ease, transform var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
  }
  @media screen and (min-width: 1024px) and (hover: hover) and (pointer: fine) {
    .c-faq-item summary:hover::before {
      -webkit-transform: translateY(-50%) scale(1.08);
              transform: translateY(-50%) scale(1.08);
    }
    .c-faq-item summary:hover::after {
      -webkit-transform: translate(50%, -50%) scaleX(1.18);
              transform: translate(50%, -50%) scaleX(1.18);
    }
  }
  .c-faq-item__label {
    color: var(--color-primary);
    font-family: var(--font-family-en);
    font-size: clamp(1.125rem, 0.875rem + 1vw, 1.25rem);
    font-weight: 600;
    line-height: 1.9;
    text-align: left;
  }
  .c-faq-item__question {
    color: var(--color-text);
    font-size: clamp(0.875rem, 0.538rem + 1.4vw, 1.0625rem);
    font-weight: var(--font-weight-medium);
    line-height: 1.6;
  }
  .c-faq-item summary .c-faq-item__question::before {
    content: "";
    position: absolute;
    top: 50%;
    right: clamp(1.625rem, 0.7rem + 3.8vw, 2.125rem);
    width: clamp(0.625rem, 0.375rem + 1vw, 0.75rem);
    height: clamp(0.125rem, 0rem + 0.5vw, 0.1875rem);
    background: var(--color-white);
    -webkit-transform: translate(50%, -50%) rotate(90deg);
            transform: translate(50%, -50%) rotate(90deg);
    -webkit-transition: opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: transform var(--duration-fast) ease, opacity var(--duration-fast) ease;
    transition: transform var(--duration-fast) ease, opacity var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
  }
  .c-faq-item.is-open summary .c-faq-item__question::before,
  .c-faq-item[open] summary .c-faq-item__question::before {
    opacity: 0;
    -webkit-transform: translate(50%, -50%) rotate(0deg);
            transform: translate(50%, -50%) rotate(0deg);
  }
  @media screen and (min-width: 1024px) and (hover: hover) and (pointer: fine) {
    .c-faq-item summary:hover .c-faq-item__question::before {
      -webkit-transform: translate(50%, -50%) rotate(90deg) scaleX(1.18);
              transform: translate(50%, -50%) rotate(90deg) scaleX(1.18);
    }
    .c-faq-item.is-open summary:hover .c-faq-item__question::before,
    .c-faq-item[open] summary:hover .c-faq-item__question::before {
      -webkit-transform: translate(50%, -50%) rotate(0deg);
              transform: translate(50%, -50%) rotate(0deg);
    }
  }
  .c-faq-item__answer {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    overflow: hidden;
    padding: 0;
    -webkit-transition: height var(--duration-normal) ease, opacity var(--duration-fast) ease;
    transition: height var(--duration-normal) ease, opacity var(--duration-fast) ease;
    will-change: height;
  }
  .c-faq-item__answer p {
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    padding: 0 22px 29px;
    font-size: clamp(0.875rem, 0.538rem + 1.4vw, 1.0625rem);
    line-height: 1.75;
  }
  @media (prefers-reduced-motion: reduce) {
    .c-faq-item,
    .c-faq-item__answer,
    .c-faq-item summary::before,
    .c-faq-item summary::after,
    .c-faq-item summary .c-faq-item__question::before {
      -webkit-transition: none;
      transition: none;
    }
  }
  body.is-modal-open {
    overflow: hidden;
  }
  .c-modal {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: none;
    height: 100vh;
    height: 100dvh;
    background: rgba(40, 35, 28, 0.72);
  }
  .c-modal[aria-hidden=false] {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    overflow-y: auto;
    min-height: 100%;
    padding: 24px 0;
    -webkit-animation: modal-fade-in var(--duration-normal) ease both;
            animation: modal-fade-in var(--duration-normal) ease both;
  }
  .c-modal[aria-hidden=false] .c-modal__dialog {
    -webkit-animation: modal-dialog-in var(--duration-normal) ease both;
            animation: modal-dialog-in var(--duration-normal) ease both;
  }
  .c-modal[aria-hidden=false].is-closing {
    pointer-events: none;
    -webkit-animation: modal-fade-out var(--duration-normal) ease both;
            animation: modal-fade-out var(--duration-normal) ease both;
  }
  .c-modal[aria-hidden=false].is-closing .c-modal__dialog {
    -webkit-animation: modal-dialog-out var(--duration-normal) ease both;
            animation: modal-dialog-out var(--duration-normal) ease both;
  }
  .c-modal__backdrop {
    position: absolute;
    inset: 0;
    background: transparent;
  }
  .c-modal__dialog {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: min(100% - 48px, var(--container-width));
    max-height: 90vh;
    margin: 0 auto;
    background: var(--color-white);
    overflow: visible;
    -webkit-box-shadow: 0 24px 48px rgba(0, 0, 0, 0.25);
            box-shadow: 0 24px 48px rgba(0, 0, 0, 0.25);
    -ms-scroll-chaining: none;
        overscroll-behavior: contain;
    border-radius: 8px;
  }
  .c-modal__dialog::before {
    content: none;
  }
  @media (max-width: 1024px) {
    .c-modal__dialog {
      width: min(100% - 32px, var(--container-width));
    }
  }
  @media (max-width: 640px) {
    .c-modal {
      top: var(--modal-viewport-offset-top, 0px);
      bottom: auto;
      height: var(--modal-viewport-height, 100dvh);
    }
    .c-modal[aria-hidden=false] {
      -webkit-box-align: start;
          -ms-flex-align: start;
              align-items: flex-start;
      padding: max(32px, env(safe-area-inset-top)) 0 max(24px, env(safe-area-inset-bottom));
    }
    .c-modal__dialog {
      width: min(100% - 24px, var(--container-width));
      max-height: calc(var(--modal-viewport-height, 100dvh) - 56px);
    }
    .c-modal__close {
      top: 8px;
      right: 8px;
    }
  }
  @-webkit-keyframes modal-fade-in {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  @keyframes modal-fade-in {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  @-webkit-keyframes modal-dialog-in {
    from {
      opacity: 0;
      -webkit-transform: translateY(16px);
              transform: translateY(16px);
    }
    to {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes modal-dialog-in {
    from {
      opacity: 0;
      -webkit-transform: translateY(16px);
              transform: translateY(16px);
    }
    to {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @-webkit-keyframes modal-fade-out {
    from {
      opacity: 1;
    }
    to {
      opacity: 0;
    }
  }
  @keyframes modal-fade-out {
    from {
      opacity: 1;
    }
    to {
      opacity: 0;
    }
  }
  @-webkit-keyframes modal-dialog-out {
    from {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    to {
      opacity: 0;
      -webkit-transform: translateY(16px);
              transform: translateY(16px);
    }
  }
  @keyframes modal-dialog-out {
    from {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    to {
      opacity: 0;
      -webkit-transform: translateY(16px);
              transform: translateY(16px);
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .c-modal[aria-hidden=false],
    .c-modal[aria-hidden=false] .c-modal__dialog,
    .c-modal[aria-hidden=false].is-closing,
    .c-modal[aria-hidden=false].is-closing .c-modal__dialog {
      -webkit-animation: none;
              animation: none;
    }
  }
  .c-modal__close {
    position: absolute;
    top: clamp(-0.75rem, -0.037rem + -2.9vw, -1.125rem);
    right: clamp(-0.5rem, 0.675rem + -4.8vw, -1.125rem);
    width: clamp(2rem, 0.15rem + 7.6vw, 3rem);
    height: clamp(2rem, 0.15rem + 7.6vw, 3rem);
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: var(--color-white);
    cursor: pointer;
    -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
            box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
    z-index: 10;
    -webkit-transition: background-color var(--duration-fast) ease, -webkit-box-shadow var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: background-color var(--duration-fast) ease, -webkit-box-shadow var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
    transition: background-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease, transform var(--duration-fast) ease;
    transition: background-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease, transform var(--duration-fast) ease, -webkit-box-shadow var(--duration-fast) ease, -webkit-transform var(--duration-fast) ease;
  }
  .c-modal__close:focus-visible {
    background-color: var(--color-white);
    -webkit-box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
            box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
    -webkit-transform: scale(1.08);
            transform: scale(1.08);
  }
  @media (hover: hover) and (pointer: fine) {
    .c-modal__close:hover {
      background-color: var(--color-white);
      -webkit-box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
              box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
      -webkit-transform: scale(1.08);
              transform: scale(1.08);
    }
  }
  .c-modal__close-icon {
    position: relative;
    display: block;
    width: clamp(1rem, 0.287rem + 2.9vw, 1.375rem);
    height: clamp(1rem, 0.287rem + 2.9vw, 1.375rem);
    margin: 0 auto;
  }
  .c-modal__close-icon::before,
  .c-modal__close-icon::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: clamp(1rem, 0.287rem + 2.9vw, 1.375rem);
    height: clamp(0.125rem, 0rem + 0.5vw, 0.1875rem);
    background: var(--color-primary);
    -webkit-transform-origin: center;
            transform-origin: center;
    -webkit-transition: background-color var(--duration-fast) ease;
    transition: background-color var(--duration-fast) ease;
  }
  @media (prefers-reduced-motion: reduce) {
    .c-modal__close {
      -webkit-transition: background-color var(--duration-fast) ease, -webkit-box-shadow var(--duration-fast) ease;
      transition: background-color var(--duration-fast) ease, -webkit-box-shadow var(--duration-fast) ease;
      transition: background-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;
      transition: background-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease, -webkit-box-shadow var(--duration-fast) ease;
    }
    .c-modal__close:focus-visible {
      -webkit-transform: scale(1.03);
              transform: scale(1.03);
    }
  }
  @media (prefers-reduced-motion: reduce) and (hover: hover) and (pointer: fine) {
    .c-modal__close:hover {
      -webkit-transform: scale(1.03);
              transform: scale(1.03);
    }
  }
  .c-modal__close-icon::before {
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
            transform: translate(-50%, -50%) rotate(45deg);
  }
  .c-modal__close-icon::after {
    -webkit-transform: translate(-50%, -50%) rotate(-45deg);
            transform: translate(-50%, -50%) rotate(-45deg);
  }
  .c-modal__header {
    padding: clamp(1rem, 0.538rem + 1.9vw, 1.25rem) 24px clamp(1rem, 0.538rem + 1.9vw, 1.25rem);
    background: var(--color-primary);
    border-radius: 8px 8px 0 0;
  }
  .c-modal__header h2 {
    font-size: clamp(1.125rem, 0.2rem + 3.8vw, 1.625rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
    color: var(--color-white);
    text-align: center;
  }
  .c-modal__body {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 0 24px clamp(2rem, -0.775rem + 11.4vw, 3.5rem);
    background: var(--color-white);
    -ms-scroll-chaining: none;
        overscroll-behavior: contain;
    border-radius: 0 0 8px 8px;
  }
  .c-modal__body,
  .c-interview-modal {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.2) transparent;
  }
  .c-modal__body::-webkit-scrollbar,
  .c-interview-modal::-webkit-scrollbar {
    width: 6px;
  }
  .c-modal__body::-webkit-scrollbar-track,
  .c-interview-modal::-webkit-scrollbar-track {
    background: transparent;
  }
  .c-modal__body::-webkit-scrollbar-thumb,
  .c-interview-modal::-webkit-scrollbar-thumb {
    border-radius: var(--radius-pill);
    background-color: rgba(230, 0, 18, 0.24);
  }
  @media (hover: hover) and (pointer: fine) {
    .c-modal__body::-webkit-scrollbar-thumb:hover,
    .c-interview-modal::-webkit-scrollbar-thumb:hover {
      background-color: rgba(230, 0, 18, 0.38);
    }
  }
  .c-modal__visual {
    padding: 0;
  }
  .c-modal__visual-image {
    display: block;
    width: 100%;
    max-width: 100%;
    margin: clamp(1.25rem, -1.063rem + 9.5vw, 2.5rem) auto;
    -webkit-transform: translateY(8px);
            transform: translateY(8px);
  }
  .c-modal__content {
    margin-top: 40px;
    padding-left: 64px;
    padding-right: 64px;
    background: var(--color-white);
  }
  .c-modal__content--padding-sm {
    padding-left: 24px;
    padding-right: 24px;
  }
  @media screen and (max-width: 600px) {
    .c-modal__content {
      padding-left: 0;
      padding-right: 0;
    }
  }
  .c-modal__content h3 {
    margin: 0;
    font-family: var(--font-family-base);
    font-size: clamp(1.25rem, 0.075rem + 4.8vw, 1.875rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.55;
    color: var(--color-primary);
  }
  .c-modal__text {
    margin-top: 24px;
  }
  .c-modal__text p {
    margin: 0;
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.75;
    text-align: justify;
  }
  .c-modal__text p + p {
    margin-top: 4px;
  }
  .c-modal__text-accent {
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
  }
  .c-modal--interview[aria-hidden=false] {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .c-interview-modal {
    --interview-modal-theme-color: var(--color-orange);
    position: relative;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0;
    background: var(--color-white);
    border-radius: 8px;
    -ms-scroll-chaining: none;
        overscroll-behavior: contain;
  }
  .c-interview-modal--blue {
    --interview-modal-theme-color: var(--color-blue);
  }
  .c-interview-modal--green {
    --interview-modal-theme-color: var(--color-green);
  }
  .c-interview-modal__hero {
    position: relative;
    z-index: 2;
    padding: clamp(1.5rem, -0.35rem + 7.6vw, 2.5rem) clamp(1.5rem, -0.35rem + 7.6vw, 2.5rem) 0;
    background: var(--interview-modal-theme-color);
  }
  .c-interview-modal__hero::before {
    content: "";
    position: absolute;
    width: 102%;
    height: 600px;
    border-radius: var(--radius-pill);
    left: -1%;
    bottom: clamp(-23.875rem, -29.675rem + 23.8vw, -20.75rem);
    background-color: var(--color-white);
    z-index: 0;
  }
  .c-interview-thumb {
    position: relative;
  }
  .c-interview-modal__label {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    padding: clamp(0.25rem, -0.463rem + 2.9vw, 0.625rem) clamp(1.25rem, -0.138rem + 5.7vw, 2rem) clamp(0.875rem, 0.413rem + 1.9vw, 1.125rem) clamp(0.875rem, 0.413rem + 1.9vw, 1.125rem);
    background: var(--interview-modal-theme-color);
    border-radius: 0 0 10px 0;
  }
  .c-interview-modal__occupation {
    font-size: clamp(0.8125rem, 0.475rem + 1.4vw, 1rem);
    font-weight: var(--font-weight-medium);
    letter-spacing: 0;
    color: var(--color-yellow);
  }
  .c-interview-modal__name {
    font-size: clamp(1.125rem, 0.325rem + 3.3vw, 1.5625rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.35;
    letter-spacing: 0.05em;
    color: var(--color-white);
  }
  .c-interview-modal__image {
    border-radius: var(--radius-md);
  }
  .c-interview-modal__body {
    position: relative;
    z-index: 3;
    background-color: var(--color-white);
    margin-top: clamp(1.5rem, -1.275rem + 11.4vw, 3rem);
    padding: 0 clamp(1.5rem, -3.125rem + 19vw, 4rem) clamp(1.5rem, -2.2rem + 15.2vw, 3.5rem);
  }
  .c-interview-modal__lead {
    font-size: clamp(1.125rem, -0.263rem + 5.7vw, 1.875rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.6;
    color: var(--interview-modal-theme-color);
  }
  .c-interview-modal__text {
    margin-top: clamp(1.25rem, 0.788rem + 1.9vw, 1.5rem);
  }
  .c-interview-modal__text:first-of-type {
    margin-top: clamp(1.25rem, -0.138rem + 5.7vw, 2rem);
  }
  .c-interview-modal__text p {
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    font-weight: var(--font-weight-regular);
    line-height: 2;
    text-align: justify;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    letter-spacing: 0.03em;
    text-wrap: pretty;
  }
  .c-interview-modal__gallery {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 0.287rem + 2.9vw, 1.375rem);
    margin-top: clamp(1.25rem, 0.788rem + 1.9vw, 1.5rem);
  }
  .c-interview-modal__gallery img {
    border-radius: var(--radius-md);
  }
  .c-interview-modal__schedule {
    margin-top: clamp(2rem, 1.075rem + 3.8vw, 2.5rem);
    border: 1px solid var(--color-primary);
    border-radius: 8px;
  }
  .c-interview-modal__schedule h3 {
    padding: clamp(0.75rem, 0.5rem + 1vw, 0.875rem) clamp(1rem, 0.538rem + 1.9vw, 1.25rem);
    background: var(--color-primary);
    border-radius: 6px 6px 0 0;
    font-size: clamp(1rem, 0.75rem + 1vw, 1.125rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.4;
    color: var(--color-white);
  }
  .c-interview-modal__schedule-list {
    padding: 16px clamp(1rem, 0.287rem + 2.9vw, 1.375rem) 16px;
    position: relative;
  }
  .c-interview-modal__schedule-list::before {
    content: "";
    position: absolute;
    top: 30px;
    bottom: 30px;
    left: clamp(1.1875rem, 0.262rem + 3.8vw, 1.6875rem);
    width: 1px;
    background: #aaaaaa;
  }
  .c-interview-modal__schedule-list li {
    display: grid;
    grid-template-columns: 45px 1fr;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    gap: clamp(0.375rem, -0.088rem + 1.9vw, 0.625rem);
    position: relative;
    padding-left: clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
  }
  .c-interview-modal__schedule-list li + li {
    margin-top: 12px;
  }
  .c-interview-modal__schedule-list li::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 0;
    width: clamp(0.5rem, 0.162rem + 1.4vw, 0.6875rem);
    height: clamp(0.5rem, 0.162rem + 1.4vw, 0.6875rem);
    border-radius: 50%;
    background: var(--color-primary);
  }
  .c-interview-modal__schedule-time {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-family: var(--font-family-en);
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    font-weight: var(--font-weight-medium);
    line-height: 1.8;
  }
  .c-interview-modal__schedule-text {
    display: block;
    font-size: clamp(0.875rem, 0.538rem + 1.4vw, 1.0625rem);
    line-height: 1.6;
  }
  .c-interview-modal__message {
    position: relative;
    margin-top: clamp(2rem, 1.075rem + 3.8vw, 2.5rem);
    padding: clamp(1.25rem, -0.138rem + 5.7vw, 2rem) clamp(1.25rem, -0.138rem + 5.7vw, 2rem) clamp(1.25rem, 0.325rem + 3.8vw, 1.75rem);
    border-radius: 8px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    overflow: hidden;
    background: var(--interview-modal-theme-color);
    color: var(--color-white);
  }
  .c-interview-modal__message h3 {
    font-size: clamp(1rem, 0.538rem + 1.9vw, 1.25rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.5;
  }
  .c-interview-modal__message p {
    margin-top: 12px;
    font-size: clamp(0.875rem, 0.75rem + 0.5vw, 0.9375rem);
    font-weight: var(--font-weight-medium);
    line-height: 1.95;
    text-align: justify;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    text-wrap: pretty;
  }
  .c-interview-modal__message p + p {
    margin-top: 4px;
  }
  .c-info-table {
    margin: 0;
  }
  .c-info-table__row {
    display: grid;
    grid-template-columns: clamp(4rem, -1.338rem + 21.9vw, 6.875rem) 1fr;
    gap: clamp(0.625rem, -0.3rem + 3.8vw, 1.125rem);
    padding: clamp(1rem, 0.538rem + 1.9vw, 1.25rem) 0;
    border-bottom: 1px dashed var(--color-border-gray);
  }
  .c-info-table__row:first-child {
    padding-top: 0;
  }
  .c-info-table__row dt,
  .c-info-table__row dd {
    font-size: clamp(0.8125rem, 0.475rem + 1.4vw, 1rem);
    line-height: 1.6;
  }
  .c-info-table__row dt {
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
  }
  .c-info-table__note {
    font-size: clamp(0.5625rem, 0.1rem + 1.9vw, 0.8125rem);
  }
}
/* ====================================================

Project

==================================================== */
@layer project {
  .p-contents {
    position: relative;
    background-color: var(--color-white);
    -webkit-box-shadow: -10px 0 16px rgba(253, 238, 182, 0.3), 10px 0 16px rgba(253, 238, 182, 0.3);
            box-shadow: -10px 0 16px rgba(253, 238, 182, 0.3), 10px 0 16px rgba(253, 238, 182, 0.3);
  }
  /* ----------------------------------------------------

    FV　ファーストビュー

  ---------------------------------------------------- */
  .p-hero {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 100vh;
    min-height: 100svh;
    padding: 54px 0;
    text-align: center;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .p-hero__visual {
    position: relative;
    z-index: 1;
    width: min(811px, 100% - 48px, 100svh - 108px);
    aspect-ratio: 1/1;
    margin: 0 auto;
  }
  .p-hero__layer {
    position: absolute;
    inset: 0;
    display: block;
    pointer-events: none;
  }
  .p-hero__layer img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
  .p-hero__layer--foods-01 {
    z-index: 10;
  }
  .p-hero__layer--foods-02 {
    z-index: 9;
  }
  .p-hero__layer--text {
    z-index: 8;
  }
  .p-hero__layer--logo {
    z-index: 7;
  }
  .p-hero__layer--mascot {
    z-index: 6;
  }
  .p-hero__layer--title {
    z-index: 5;
  }
  .p-hero__layer--person {
    z-index: 4;
  }
  .p-hero__layer--circle {
    z-index: 3;
  }
  .p-hero__layer--circle-shadow {
    z-index: 2;
  }
  .p-hero__layer--bg {
    z-index: 1;
  }
  .p-hero__photos {
    display: none;
  }
  .p-hero__photo {
    position: absolute;
    display: block;
    pointer-events: none;
    -webkit-transform-origin: center;
            transform-origin: center;
  }
  @media (min-width: 1281px) {
    .p-hero__photos {
      position: fixed;
      top: 50%;
      left: calc(75% + 150px);
      z-index: 2;
      display: block;
      width: clamp(340px, 39vw - 234px, 540px);
      aspect-ratio: 52/76;
      overflow: visible;
      pointer-events: none;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%);
      -webkit-transition: opacity 0.42s ease, visibility 0.42s ease;
      transition: opacity 0.42s ease, visibility 0.42s ease;
    }
    .p-hero__photo--01 {
      top: -4%;
      right: 0;
      width: 100%;
    }
    .p-hero__photo--02 {
      top: 72%;
      right: 4%;
      width: 60%;
      z-index: 1;
    }
    .p-hero__photo--03 {
      top: 45%;
      right: 24%;
      width: 69%;
    }
  }
  @media (max-width: 640px) {
    .p-hero {
      padding: 64px 0 34px;
    }
    .p-hero__visual {
      position: relative;
      width: calc(100% - 16px);
      height: calc(100svh - 98px);
      margin: 0 auto;
      aspect-ratio: auto;
    }
  }
  /* ----------------------------------------------------

    ABOUT US　サンデリカについて

  ---------------------------------------------------- */
  .p-section--about {
    padding: clamp(5rem, -0.588rem + 22.9vw, 8rem) 0 0;
  }
  .p-about__statement {
    margin-top: clamp(2.5rem, -3.088rem + 22.9vw, 5.5rem);
    text-align: center;
  }
  .p-about__statement p {
    font-size: clamp(1.5rem, 0.575rem + 3.8vw, 2rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.6;
  }
  .p-about__statement span {
    color: var(--color-primary);
  }
  .p-about__photos {
    margin-top: clamp(2.5rem, -0.275rem + 11.4vw, 4rem);
  }
  .p-about__photos-track {
    -webkit-column-gap: 14px;
       -moz-column-gap: 14px;
            column-gap: 14px;
  }
  .p-about__photo {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    width: clamp(180px, 45vw, 270px);
    height: clamp(180px, 45vw, 270px);
  }
  .p-about__photo:nth-child(odd) {
    margin-top: clamp(32px, 8vw, 50px);
  }
  .p-about__photo img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    border-radius: var(--radius-sm);
  }
  .p-about__description {
    width: 70%;
    margin-inline: auto;
    margin-top: clamp(2.5rem, -0.275rem + 11.4vw, 4rem);
  }
  .p-about__description p {
    margin: 0;
    font-family: var(--font-family-base);
    font-size: clamp(1rem, 0.538rem + 1.9vw, 1.25rem);
    font-weight: var(--font-weight-bold);
    line-height: 2.4;
    text-align: justify;
  }
  .p-about__description p + p {
    margin-top: clamp(0.625rem, -1.013rem + 6.7vw, 1.5rem);
  }
  @media screen and (max-width: 600px) {
    .p-about__description {
      width: 100%;
      padding-left: 32px;
      padding-right: 32px;
    }
  }
  .p-about__facts {
    margin-top: clamp(3.5rem, -1.625rem + 21vw, 6.25rem);
  }
  .p-about__facts-grid {
    display: grid;
    grid-template-columns: repeat(2, 48%);
    -webkit-column-gap: clamp(0.5rem, -1.35rem + 7.6vw, 1.5rem);
       -moz-column-gap: clamp(0.5rem, -1.35rem + 7.6vw, 1.5rem);
            column-gap: clamp(0.5rem, -1.35rem + 7.6vw, 1.5rem);
    row-gap: clamp(0.5rem, -1.35rem + 7.6vw, 1.5rem);
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p-about__works-intro {
    margin-top: clamp(2rem, -0.775rem + 11.4vw, 3.5rem);
  }
  /* ----------------------------------------------------

    WORKS　仕事を知る

  ---------------------------------------------------- */
  .p-section--works {
    padding: clamp(1.25rem, -1.063rem + 9.5vw, 2.5rem) 0 clamp(5rem, 0.375rem + 19vw, 7.5rem);
  }
  /* ----------------------------------------------------

    INTERVIEW　先輩を知る

  ---------------------------------------------------- */
  .p-section--interview {
    padding-bottom: clamp(4rem, -2.513rem + 26.7vw, 7.5rem);
  }
  .p-interview-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, -0.85rem + 7.6vw, 2rem) clamp(0.5rem, -1.35rem + 7.6vw, 1.5rem);
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
  /* ----------------------------------------------------

    BENEFITS　福利厚生

  ---------------------------------------------------- */
  .p-section-benefits {
    margin-top: -1px;
    margin-bottom: clamp(3.5rem, 0.725rem + 11.4vw, 5rem);
  }
  /* ----------------------------------------------------

    TRAINING　研修制度

  ---------------------------------------------------- */
  .p-section-training {
    padding-bottom: clamp(3.5rem, 0.725rem + 11.4vw, 5rem);
  }
  .p-training-programs__cards {
    display: grid;
    gap: clamp(0.625rem, -0.3rem + 3.8vw, 1.125rem);
  }
  /* ----------------------------------------------------

    FACTORY TOUR　工場見学

  ---------------------------------------------------- */
  .p-section--tour {
    margin-bottom: clamp(3.5rem, 0.725rem + 11.4vw, 5rem);
  }
  .p-tour-flow {
    margin-top: clamp(1.25rem, -0.138rem + 5.7vw, 2rem);
  }
  /* ----------------------------------------------------

    Q&A　よくある質問

  ---------------------------------------------------- */
  .p-section-faq {
    position: relative;
    padding-bottom: clamp(3.5rem, 0.725rem + 11.4vw, 5rem);
  }
  .p-faq__img {
    position: absolute;
    right: clamp(1.25rem, -1.988rem + 13.3vw, 3rem);
    top: -10px;
    width: clamp(6.25rem, 1.375rem + 20vw, 8.875rem);
    z-index: 0;
  }
  /* ----------------------------------------------------

    ENTRY　応募方法・募集要項

  ---------------------------------------------------- */
  .p-entry__cta {
    margin-top: 40px;
    scroll-margin-top: 40px;
  }
  .p-section-entry {
    margin-bottom: clamp(3.5rem, 0.725rem + 11.4vw, 5rem);
  }
  .p-entry-flow__list {
    display: grid;
    gap: clamp(0.5rem, 0.037rem + 1.9vw, 0.75rem);
    margin: 0;
    padding: 0;
    list-style: none;
    counter-reset: entry-flow;
  }
  .p-entry-flow__list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 12px;
    padding: clamp(0.625rem, -0.088rem + 2.9vw, 1rem) clamp(1rem, 0.075rem + 3.8vw, 1.5rem);
    border-radius: 10px;
    background: var(--color-surface-soft);
    font-size: clamp(0.875rem, 0.625rem + 1vw, 1rem);
    line-height: 1.7;
    counter-increment: entry-flow;
  }
  .p-entry-flow__list li::before {
    content: counter(entry-flow) ".";
    color: var(--color-primary);
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-medium);
    font-size: 20px;
    line-height: 1.7;
  }
  /* ----------------------------------------------------

    MESSAGE　私たちからのメッセージ

  ---------------------------------------------------- */
  .p-section--message {
    position: relative;
    padding: clamp(3.5rem, 0.725rem + 11.4vw, 5rem) 0 clamp(3.5rem, 0.725rem + 11.4vw, 5rem);
    background: var(--color-primary);
  }
  .p-section--message__text {
    font-size: clamp(0.9375rem, 0.688rem + 1vw, 1.0625rem);
    font-weight: var(--font-weight-medium);
    line-height: 2;
    text-align: justify;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    letter-spacing: 0.04em;
    text-wrap: pretty;
    color: var(--color-white);
  }
  .p-section--message__text strong {
    font-size: clamp(1rem, 0.75rem + 1vw, 1.125rem);
  }
  .p-message__mascot {
    position: absolute;
    right: clamp(1.25rem, -1.988rem + 13.3vw, 3rem);
    top: clamp(6.25rem, 0.45rem + 23.8vw, 9.375rem);
    width: clamp(4.25rem, 1.475rem + 11.4vw, 5.75rem);
  }
  /* ----------------------------------------------------

    CONTACT　お問い合わせ

  ---------------------------------------------------- */
  .p-section-contact {
    padding-top: clamp(3rem, 1.15rem + 7.6vw, 4rem);
    padding-bottom: clamp(3rem, 1.15rem + 7.6vw, 4rem);
  }
  .p-contact__card {
    margin-top: clamp(1.5rem, 0.575rem + 3.8vw, 2rem);
    padding: 24px 0;
    border-radius: 20px;
    background: var(--color-white);
    -webkit-box-shadow: 0 0 10px rgba(230, 0, 18, 0.1607843137);
            box-shadow: 0 0 10px rgba(230, 0, 18, 0.1607843137);
    text-align: center;
  }
  .p-contact__department {
    font-size: 16px;
    font-weight: var(--font-weight-bold);
    line-height: 1.6;
  }
  .p-contact__body {
    margin-top: 8px;
  }
  .p-contact__body p {
    font-size: 14px;
    line-height: 1.8;
  }
  /* ----------------------------------------------------

    フッタ

  ---------------------------------------------------- */
  .p-section-footer {
    padding: 40px 0;
    padding-bottom: calc(40px + env(safe-area-inset-bottom));
    text-align: center;
    background-color: var(--color-white);
  }
  .p-footer__logo img {
    width: clamp(7.5rem, 4.6rem + 11.9vw, 9.0625rem);
    margin-inline: auto;
  }
  .p-footer__link {
    position: relative;
    display: inline-block;
    margin-top: 32px;
    font-size: 14px;
  }
  .p-footer__link::after {
    content: "";
    position: absolute;
    right: -19px;
    top: 50%;
    width: 16px;
    height: 16px;
    background: url("../images/common/icon_newwindow.svg") center/contain no-repeat;
    -webkit-transform: translateY(-45%);
            transform: translateY(-45%);
  }
  .p-footer__link {
    -webkit-transition: opacity var(--duration-fast) ease;
    transition: opacity var(--duration-fast) ease;
  }
  @media (hover: hover) and (pointer: fine) {
    .p-footer__link:hover {
      opacity: 0.7;
    }
  }
  .p-footer__copy {
    margin-top: 40px;
    font-size: clamp(0.625rem, 0.375rem + 1vw, 0.75rem);
    font-family: var(--font-family-en);
  }
}
/* ====================================================

Project Animation

==================================================== */
@layer project {
  /* ----------------------------------------------------

    FV Animation

  ---------------------------------------------------- */
  @media (min-width: 1281px) {
    .is-fv-animation-pending .c-side-nav {
      opacity: 0;
      visibility: hidden;
    }
    .c-side-nav {
      -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
      transition: opacity 0.5s ease, visibility 0.5s ease;
    }
    .is-fv-animation-complete .c-side-nav {
      opacity: 1;
      visibility: visible;
    }
    .is-fv-animation-complete .c-side-nav {
      -webkit-animation: side-nav-cheer-in 0.68s ease-out both;
              animation: side-nav-cheer-in 0.68s ease-out both;
    }
    .is-fv-animation-complete .c-side-nav__mascot {
      -webkit-transform-origin: center bottom;
              transform-origin: center bottom;
      -webkit-animation: side-nav-mascot-hop 8.5s ease-in-out 1.4s infinite;
              animation: side-nav-mascot-hop 8.5s ease-in-out 1.4s infinite;
    }
  }
  .is-fv-animation-pending .an-fv-animation__layer {
    opacity: 0;
  }
  .is-fv-animation-pending .an-fv-animation__photo {
    opacity: 0;
  }
  .is-fv-photos-hidden .an-fv-animation__photos {
    opacity: 0;
    visibility: hidden;
  }
  .is-fv-animation-ready .an-fv-animation__layer--circle,
  .is-fv-animation-ready .an-fv-animation__layer--circle-shadow,
  .is-fv-animation-ready .an-fv-animation__layer--person {
    -webkit-animation: fv-bound-in 0.88s ease-out both;
            animation: fv-bound-in 0.88s ease-out both;
  }
  .is-fv-animation-ready .an-fv-animation__layer--logo,
  .is-fv-animation-ready .an-fv-animation__layer--text {
    -webkit-animation: fv-cheer-in 0.72s ease-out 0.72s both;
            animation: fv-cheer-in 0.72s ease-out 0.72s both;
  }
  .is-fv-animation-ready .an-fv-animation__layer--title {
    -webkit-animation: fv-mask-reveal 0.54s ease 1.12s both;
            animation: fv-mask-reveal 0.54s ease 1.12s both;
  }
  .is-fv-animation-ready .an-fv-animation__layer--mascot {
    -webkit-animation: fv-drop-bound-in 0.58s cubic-bezier(0.18, 1.08, 0.36, 1) 1.42s both;
            animation: fv-drop-bound-in 0.58s cubic-bezier(0.18, 1.08, 0.36, 1) 1.42s both;
  }
  .is-fv-animation-ready .an-fv-animation__layer--foods-01 {
    -webkit-animation: fv-fade-in 0.62s ease 1.78s both, fv-float 3.2s ease-in-out 2.46s infinite;
            animation: fv-fade-in 0.62s ease 1.78s both, fv-float 3.2s ease-in-out 2.46s infinite;
  }
  .is-fv-animation-ready .an-fv-animation__layer--foods-02 {
    -webkit-animation: fv-fade-in 0.62s ease 1.92s both, fv-float-alt 3.4s ease-in-out 2.64s infinite;
            animation: fv-fade-in 0.62s ease 1.92s both, fv-float-alt 3.4s ease-in-out 2.64s infinite;
  }
  .is-fv-animation-ready .an-fv-animation__layer--bg {
    -webkit-animation: fv-fade-in 0.7s ease 2.28s both, fv-bg-pulse 5.6s ease-in-out 3s infinite;
            animation: fv-fade-in 0.7s ease 2.28s both, fv-bg-pulse 5.6s ease-in-out 3s infinite;
  }
  @media (min-width: 1281px) {
    .is-fv-animation-ready .an-fv-animation__photo--01 {
      -webkit-animation: fv-photo-in 0.58s cubic-bezier(0.18, 1.08, 0.36, 1) 1.58s both, fv-photo-float 5.8s ease-in-out 2.26s infinite;
              animation: fv-photo-in 0.58s cubic-bezier(0.18, 1.08, 0.36, 1) 1.58s both, fv-photo-float 5.8s ease-in-out 2.26s infinite;
    }
    .is-fv-animation-ready .an-fv-animation__photo--02 {
      -webkit-animation: fv-photo-in 0.54s cubic-bezier(0.18, 1.08, 0.36, 1) 1.72s both, fv-photo-float-alt 5.4s ease-in-out 2.36s infinite;
              animation: fv-photo-in 0.54s cubic-bezier(0.18, 1.08, 0.36, 1) 1.72s both, fv-photo-float-alt 5.4s ease-in-out 2.36s infinite;
    }
    .is-fv-animation-ready .an-fv-animation__photo--03 {
      -webkit-animation: fv-photo-in 0.54s cubic-bezier(0.18, 1.08, 0.36, 1) 1.86s both, fv-photo-float 5.2s ease-in-out 2.5s infinite;
              animation: fv-photo-in 0.54s cubic-bezier(0.18, 1.08, 0.36, 1) 1.86s both, fv-photo-float 5.2s ease-in-out 2.5s infinite;
    }
  }
  @-webkit-keyframes fv-bound-in {
    0% {
      opacity: 0;
      -webkit-transform: scale(0.68);
              transform: scale(0.68);
    }
    58% {
      opacity: 1;
      -webkit-transform: scale(1.055);
              transform: scale(1.055);
    }
    76% {
      opacity: 1;
      -webkit-transform: scale(0.985);
              transform: scale(0.985);
    }
    90% {
      opacity: 1;
      -webkit-transform: scale(1.012);
              transform: scale(1.012);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @keyframes fv-bound-in {
    0% {
      opacity: 0;
      -webkit-transform: scale(0.68);
              transform: scale(0.68);
    }
    58% {
      opacity: 1;
      -webkit-transform: scale(1.055);
              transform: scale(1.055);
    }
    76% {
      opacity: 1;
      -webkit-transform: scale(0.985);
              transform: scale(0.985);
    }
    90% {
      opacity: 1;
      -webkit-transform: scale(1.012);
              transform: scale(1.012);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @-webkit-keyframes fv-person-in {
    0% {
      opacity: 0;
      -webkit-transform: scale(0.98);
              transform: scale(0.98);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @keyframes fv-person-in {
    0% {
      opacity: 0;
      -webkit-transform: scale(0.98);
              transform: scale(0.98);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @-webkit-keyframes fv-mask-reveal {
    0% {
      opacity: 1;
      clip-path: inset(0 100% 0 0);
    }
    100% {
      opacity: 1;
      clip-path: inset(0);
    }
  }
  @keyframes fv-mask-reveal {
    0% {
      opacity: 1;
      clip-path: inset(0 100% 0 0);
    }
    100% {
      opacity: 1;
      clip-path: inset(0);
    }
  }
  @-webkit-keyframes fv-drop-bound-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(-38px) scale(0.98);
              transform: translateY(-38px) scale(0.98);
    }
    72% {
      opacity: 1;
      -webkit-transform: translateY(5px) scale(1.01);
              transform: translateY(5px) scale(1.01);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }
  @keyframes fv-drop-bound-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(-38px) scale(0.98);
              transform: translateY(-38px) scale(0.98);
    }
    72% {
      opacity: 1;
      -webkit-transform: translateY(5px) scale(1.01);
              transform: translateY(5px) scale(1.01);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }
  @-webkit-keyframes fv-fade-in {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  @keyframes fv-fade-in {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  @-webkit-keyframes fv-cheer-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(10px) scale(0.96) rotate(-1.5deg);
              transform: translateY(10px) scale(0.96) rotate(-1.5deg);
    }
    52% {
      opacity: 1;
      -webkit-transform: translateY(-7px) scale(1.035) rotate(1deg);
              transform: translateY(-7px) scale(1.035) rotate(1deg);
    }
    74% {
      opacity: 1;
      -webkit-transform: translateY(3px) scale(0.992) rotate(-0.4deg);
              transform: translateY(3px) scale(0.992) rotate(-0.4deg);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1) rotate(0deg);
              transform: translateY(0) scale(1) rotate(0deg);
    }
  }
  @keyframes fv-cheer-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(10px) scale(0.96) rotate(-1.5deg);
              transform: translateY(10px) scale(0.96) rotate(-1.5deg);
    }
    52% {
      opacity: 1;
      -webkit-transform: translateY(-7px) scale(1.035) rotate(1deg);
              transform: translateY(-7px) scale(1.035) rotate(1deg);
    }
    74% {
      opacity: 1;
      -webkit-transform: translateY(3px) scale(0.992) rotate(-0.4deg);
              transform: translateY(3px) scale(0.992) rotate(-0.4deg);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1) rotate(0deg);
              transform: translateY(0) scale(1) rotate(0deg);
    }
  }
  @-webkit-keyframes fv-float {
    0% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translateY(-8px);
              transform: translateY(-8px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes fv-float {
    0% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translateY(-8px);
              transform: translateY(-8px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @-webkit-keyframes fv-float-alt {
    0% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translateY(7px);
              transform: translateY(7px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes fv-float-alt {
    0% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translateY(7px);
              transform: translateY(7px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @-webkit-keyframes fv-bg-pulse {
    0% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    50% {
      opacity: 1;
      -webkit-transform: scale(1.025);
              transform: scale(1.025);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @keyframes fv-bg-pulse {
    0% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    50% {
      opacity: 1;
      -webkit-transform: scale(1.025);
              transform: scale(1.025);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @-webkit-keyframes fv-photo-in {
    0% {
      opacity: 0;
      -webkit-transform: translate(38px, -12px) scale(0.96);
              transform: translate(38px, -12px) scale(0.96);
    }
    68% {
      opacity: 1;
      -webkit-transform: translate(-4px, 3px) scale(1.012);
              transform: translate(-4px, 3px) scale(1.012);
    }
    100% {
      opacity: 1;
      -webkit-transform: translate(0) scale(1);
              transform: translate(0) scale(1);
    }
  }
  @keyframes fv-photo-in {
    0% {
      opacity: 0;
      -webkit-transform: translate(38px, -12px) scale(0.96);
              transform: translate(38px, -12px) scale(0.96);
    }
    68% {
      opacity: 1;
      -webkit-transform: translate(-4px, 3px) scale(1.012);
              transform: translate(-4px, 3px) scale(1.012);
    }
    100% {
      opacity: 1;
      -webkit-transform: translate(0) scale(1);
              transform: translate(0) scale(1);
    }
  }
  @-webkit-keyframes fv-photo-float {
    0% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translateY(-8px);
              transform: translateY(-8px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
  }
  @keyframes fv-photo-float {
    0% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translateY(-8px);
              transform: translateY(-8px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
  }
  @-webkit-keyframes fv-photo-float-alt {
    0% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translate(5px, 7px);
              transform: translate(5px, 7px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
  }
  @keyframes fv-photo-float-alt {
    0% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
    50% {
      opacity: 1;
      -webkit-transform: translate(5px, 7px);
              transform: translate(5px, 7px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translate(0);
              transform: translate(0);
    }
  }
  @-webkit-keyframes side-nav-cheer-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(calc(-50% + 28px));
              transform: translateY(calc(-50% + 28px));
    }
    72% {
      opacity: 1;
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%);
    }
  }
  @keyframes side-nav-cheer-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(calc(-50% + 28px));
              transform: translateY(calc(-50% + 28px));
    }
    72% {
      opacity: 1;
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%);
    }
  }
  @-webkit-keyframes side-nav-mascot-hop {
    0%, 82%, 100% {
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
    86% {
      -webkit-transform: translateY(-12px) scale(1.03, 0.97);
              transform: translateY(-12px) scale(1.03, 0.97);
    }
    90% {
      -webkit-transform: translateY(0) scale(0.98, 1.02);
              transform: translateY(0) scale(0.98, 1.02);
    }
    94% {
      -webkit-transform: translateY(-5px) scale(1.01, 0.99);
              transform: translateY(-5px) scale(1.01, 0.99);
    }
    98% {
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }
  @keyframes side-nav-mascot-hop {
    0%, 82%, 100% {
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
    86% {
      -webkit-transform: translateY(-12px) scale(1.03, 0.97);
              transform: translateY(-12px) scale(1.03, 0.97);
    }
    90% {
      -webkit-transform: translateY(0) scale(0.98, 1.02);
              transform: translateY(0) scale(0.98, 1.02);
    }
    94% {
      -webkit-transform: translateY(-5px) scale(1.01, 0.99);
              transform: translateY(-5px) scale(1.01, 0.99);
    }
    98% {
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .is-fv-animation-ready .an-fv-animation__layer {
      -webkit-animation: none;
              animation: none;
      opacity: 1;
      clip-path: none;
      -webkit-transform: none;
              transform: none;
    }
    .is-fv-animation-ready .an-fv-animation__photo {
      -webkit-animation: none;
              animation: none;
      opacity: 1;
      -webkit-transform: none;
              transform: none;
    }
    .is-fv-animation-complete .c-side-nav,
    .is-fv-animation-complete .c-side-nav__mascot {
      -webkit-animation: none;
              animation: none;
    }
  }
  /* ----------------------------------------------------

    Scroll Animation

  ---------------------------------------------------- */
  .an-scroll-section:not(.is-scroll-visible) .an-scroll-item {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
  }
  .an-contents-slide:not(.is-scroll-visible) {
    opacity: 0;
    -webkit-transform: translateY(72px);
            transform: translateY(72px);
    will-change: opacity, transform;
  }
  .an-contents-slide.is-scroll-visible {
    -webkit-animation: contents-slide-in 0.86s ease-out both;
            animation: contents-slide-in 0.86s ease-out both;
  }
  .an-scroll-section.is-scroll-visible .an-scroll-item {
    -webkit-animation: scroll-rise-in 0.72s ease-out both;
            animation: scroll-rise-in 0.72s ease-out both;
  }
  .an-scroll-section.is-scroll-visible > .an-scroll-item:nth-child(1) {
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .an-scroll-section.is-scroll-visible > .an-scroll-item:nth-child(2) {
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .an-scroll-section.is-scroll-visible > .an-scroll-item:nth-child(3) {
    -webkit-animation-delay: 0.34s;
            animation-delay: 0.34s;
  }
  .an-scroll-section.is-scroll-visible > .an-scroll-item:nth-child(4) {
    -webkit-animation-delay: 0.46s;
            animation-delay: 0.46s;
  }
  .an-scroll-section.is-scroll-visible > .an-scroll-item:nth-child(5) {
    -webkit-animation-delay: 0.58s;
            animation-delay: 0.58s;
  }
  .an-text-bounce {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    overflow: visible;
  }
  .an-scroll-section:not(.is-scroll-visible) .an-text-bounce__char {
    display: inline-block;
    opacity: 0;
    -webkit-transform: translateY(0.55em) scale(0.82);
            transform: translateY(0.55em) scale(0.82);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
  .an-text-bounce__char {
    display: inline-block;
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
  .an-scroll-section.is-scroll-visible .an-text-bounce__char {
    -webkit-animation: text-bounce-in 0.58s cubic-bezier(0.2, 1.4, 0.38, 1) both;
            animation: text-bounce-in 0.58s cubic-bezier(0.2, 1.4, 0.38, 1) both;
    -webkit-animation-delay: calc(0.08s + var(--char-index) * 0.055s);
            animation-delay: calc(0.08s + var(--char-index) * 0.055s);
  }
  .an-scroll-fade-list:not(.is-scroll-visible) > * {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  .an-scroll-fade:not(.is-scroll-visible) {
    opacity: 0;
    -webkit-transform: translateY(24px);
            transform: translateY(24px);
  }
  .an-scroll-fade.is-scroll-visible {
    -webkit-animation: scroll-fade-in 0.64s ease-out both;
            animation: scroll-fade-in 0.64s ease-out both;
  }
  .an-scroll-bound:not(.is-scroll-visible) {
    opacity: 0;
    -webkit-transform: scale(0.96);
            transform: scale(0.96);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
  .an-scroll-bound {
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
  }
  .an-scroll-bound.is-scroll-visible {
    -webkit-animation: scroll-bound-in 0.78s ease both;
            animation: scroll-bound-in 0.78s ease both;
  }
  .an-scroll-fade-list.is-scroll-visible > * {
    -webkit-animation: scroll-fade-in 0.58s ease-out both;
            animation: scroll-fade-in 0.58s ease-out both;
  }
  .an-scroll-fade-list.is-scroll-visible > *:nth-child(1) {
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .an-scroll-fade-list.is-scroll-visible > *:nth-child(2) {
    -webkit-animation-delay: 0.1s;
            animation-delay: 0.1s;
  }
  .an-scroll-fade-list.is-scroll-visible > *:nth-child(3) {
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .an-scroll-fade-list.is-scroll-visible > *:nth-child(4) {
    -webkit-animation-delay: 0.3s;
            animation-delay: 0.3s;
  }
  .an-scroll-fade-list.is-scroll-visible > *:nth-child(5) {
    -webkit-animation-delay: 0.4s;
            animation-delay: 0.4s;
  }
  .an-scroll-fade-list.is-scroll-visible > *:nth-child(6) {
    -webkit-animation-delay: 0.5s;
            animation-delay: 0.5s;
  }
  .an-scroll-fade-list.is-scroll-visible > *:nth-child(n+7) {
    -webkit-animation-delay: 0.6s;
            animation-delay: 0.6s;
  }
  .an-scroll-section.is-scroll-animation-finished .an-scroll-item,
  .an-scroll-section.is-scroll-animation-finished .an-text-bounce__char,
  .an-contents-slide.is-scroll-animation-finished,
  .an-scroll-fade.is-scroll-animation-finished,
  .an-scroll-bound.is-scroll-animation-finished,
  .an-scroll-fade-list.is-scroll-animation-finished > * {
    -webkit-animation: none;
            animation: none;
    opacity: 1;
    will-change: auto;
  }
  @-webkit-keyframes scroll-rise-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(30px);
              transform: translateY(30px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes scroll-rise-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(30px);
              transform: translateY(30px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @-webkit-keyframes contents-slide-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(72px);
              transform: translateY(72px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes contents-slide-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(72px);
              transform: translateY(72px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @-webkit-keyframes scroll-fade-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(20px);
              transform: translateY(20px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes scroll-fade-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(20px);
              transform: translateY(20px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @-webkit-keyframes scroll-bound-in {
    0% {
      opacity: 0;
      -webkit-transform: scale(0.96);
              transform: scale(0.96);
    }
    58% {
      opacity: 1;
      -webkit-transform: scale(1.015);
              transform: scale(1.015);
    }
    78% {
      opacity: 1;
      -webkit-transform: scale(0.995);
              transform: scale(0.995);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @keyframes scroll-bound-in {
    0% {
      opacity: 0;
      -webkit-transform: scale(0.96);
              transform: scale(0.96);
    }
    58% {
      opacity: 1;
      -webkit-transform: scale(1.015);
              transform: scale(1.015);
    }
    78% {
      opacity: 1;
      -webkit-transform: scale(0.995);
              transform: scale(0.995);
    }
    100% {
      opacity: 1;
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @-webkit-keyframes text-bounce-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(0.55em) scale(0.82);
              transform: translateY(0.55em) scale(0.82);
    }
    58% {
      opacity: 1;
      -webkit-transform: translateY(-0.18em) scale(1.08);
              transform: translateY(-0.18em) scale(1.08);
    }
    78% {
      opacity: 1;
      -webkit-transform: translateY(0.05em) scale(0.98);
              transform: translateY(0.05em) scale(0.98);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }
  @keyframes text-bounce-in {
    0% {
      opacity: 0;
      -webkit-transform: translateY(0.55em) scale(0.82);
              transform: translateY(0.55em) scale(0.82);
    }
    58% {
      opacity: 1;
      -webkit-transform: translateY(-0.18em) scale(1.08);
              transform: translateY(-0.18em) scale(1.08);
    }
    78% {
      opacity: 1;
      -webkit-transform: translateY(0.05em) scale(0.98);
              transform: translateY(0.05em) scale(0.98);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .an-scroll-section .an-scroll-item,
    .an-scroll-section .an-text-bounce__char,
    .an-contents-slide,
    .an-scroll-fade,
    .an-scroll-bound,
    .an-scroll-fade-list > * {
      -webkit-animation: none;
              animation: none;
      opacity: 1;
    }
  }
}
/* ====================================================

Utility

==================================================== */
@layer utility {
  .u-color-yellow {
    color: var(--color-yellow);
  }
  .u-visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .u-br-pc {
    display: inline;
  }
  @media screen and (max-width: 600px) {
    .u-br-pc {
      display: none;
    }
  }
  .u-br-sp {
    display: none;
  }
  @media screen and (max-width: 600px) {
    .u-br-sp {
      display: inline;
    }
  }
}