/*!**************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-4.use[1]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-4.use[2]!./src/scss/style.scss ***!
  \**************************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Roboto:wght@400;700&display=swap);
/*!******************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-4.use[1]!./node_modules/sass-loader/dist/cjs.js??clonedRuleSet-4.use[2]!./src/scss/style.scss (1) ***!
  \******************************************************************************************************************************************************************/
@charset "UTF-8";
/* BASE COLOR
------------------------------------------------------------*/
/* DISPLAY SETTING
------------------------------------------------------------*/
/* OTHER SETTING
------------------------------------------------------------*/
:root {
  font-size: calc(14.5px + 1.5 * (100vw - 1440px) / 480);
  --cx: 0;
  --cy: 0;
  --vw: 100vw;
  --vh: 100vh;
  --screen: 0px;
  --size: 32px;
}
@media screen and (min-width: 1920px) {
  :root {
    font-size: 16px;
  }
}
@media screen and (max-width: 1023px) {
  :root {
    font-size: 14px;
    --size: 16px;
  }
}
@media screen and (max-width: 769px) {
  :root {
    font-size: 13.5px;
    --size: 10px;
  }
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 500;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

main {
  display: block;
}

html {
  overscroll-behavior-y: none;
}

* {
  margin: 0;
  padding: 0;
}

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: none;
}

body {
  color: #221e1d;
  fill: #221e1d;
  background: #efeeed;
  line-height: 1.8;
  font-family: "Roboto", "Noto Sans JP", "Yu Gothic", "游ゴシック", YuGothic, "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", Helvetica, Arial, Verdana, sans-serif;
  font-weight: 400;
  font-size: 1rem;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  letter-spacing: 0.024em;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
}

img {
  -ms-interpolation-mode: bicubic;
  vertical-align: bottom;
  image-rendering: -webkit-optimize-contrast;
}

i, strong {
  font-style: normal;
}

a {
  text-decoration: none;
  outline: none;
  cursor: pointer;
  color: #221e1d;
}

ul, ol {
  list-style: none;
}

input[type=text],
input[type=tel],
input[type=email],
input[type=password],
input[type=submit],
input[type=button],
select,
textarea {
  outline: none;
}
@media screen and (max-width: 1023px) {
  input[type=text],
  input[type=tel],
  input[type=email],
  input[type=password],
  input[type=submit],
  input[type=button],
  select,
  textarea {
    -webkit-appearance: none;
  }
}

/**
 * Swiper 12.1.2
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2026 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: February 18, 2026
 */
:root {
  --swiper-theme-color:#007aff;
}

:host {
  display: block;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 1;
}

.swiper {
  display: block;
  list-style: none;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  padding: 0;
  position: relative;
  z-index: 1;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  box-sizing: initial;
  display: flex;
  height: 100%;
  position: relative;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  width: 100%;
  z-index: 1;
}

.swiper-android .swiper-slide, .swiper-ios .swiper-slide, .swiper-wrapper {
  transform: translateZ(0);
}

.swiper-horizontal {
  touch-action: pan-y;
}

.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  display: block;
  flex-shrink: 0;
  height: 100%;
  position: relative;
  transition-property: transform;
  width: 100%;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-backface-hidden .swiper-slide {
  backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  perspective: 1200px;
  .swiper-cube-shadow, .swiper-slide {
    transform-style: preserve-3d;
  }
}

.swiper-css-mode {
  > .swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    &::-webkit-scrollbar {
      display: none;
    }
  }
  > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: start start;
  }
  &.swiper-horizontal {
    > .swiper-wrapper {
      scroll-snap-type: x mandatory;
    }
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-inline-start: var(--swiper-slides-offset-before);
      scroll-margin-inline-start: var(--swiper-slides-offset-before);
    }
    > .swiper-wrapper > .swiper-slide:last-child {
      margin-inline-end: var(--swiper-slides-offset-after);
    }
  }
  &.swiper-vertical {
    > .swiper-wrapper {
      scroll-snap-type: y mandatory;
    }
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-block-start: var(--swiper-slides-offset-before);
      scroll-margin-block-start: var(--swiper-slides-offset-before);
    }
    > .swiper-wrapper > .swiper-slide:last-child {
      margin-block-end: var(--swiper-slides-offset-after);
    }
  }
  &.swiper-free-mode {
    > .swiper-wrapper {
      scroll-snap-type: none;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: none;
    }
  }
  &.swiper-centered {
    > .swiper-wrapper:before {
      content: "";
      flex-shrink: 0;
      order: 9999;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: center center;
      scroll-snap-stop: always;
    }
  }
  &.swiper-centered.swiper-horizontal {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-inline-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper:before {
      height: 100%;
      min-height: 1px;
      width: var(--swiper-centered-offset-after);
    }
  }
  &.swiper-centered.swiper-vertical {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-block-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper:before {
      height: var(--swiper-centered-offset-after);
      min-width: 1px;
      width: 100%;
    }
  }
}

.swiper-3d {
  .swiper-slide-shadow, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left, .swiper-slide-shadow-right, .swiper-slide-shadow-top {
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 10;
  }
  .swiper-slide-shadow {
    background: rgba(0, 0, 0, 0.1490196078);
  }
  .swiper-slide-shadow-left {
    background-image: linear-gradient(270deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-right {
    background-image: linear-gradient(90deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-top {
    background-image: linear-gradient(0deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-bottom {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
}

.swiper-lazy-preloader {
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top: 4px solid rgba(0, 0, 0, 0);
  box-sizing: border-box;
  height: 42px;
  left: 50%;
  margin-left: -21px;
  margin-top: -21px;
  position: absolute;
  top: 50%;
  transform-origin: 50%;
  width: 42px;
  z-index: 10;
}

.swiper-watch-progress .swiper-slide-visible, .swiper:not(.swiper-watch-progress) {
  .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s linear infinite;
  }
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color:#fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color:#000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(1turn);
  }
}
.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-virtual.swiper-css-mode {
  .swiper-wrapper:after {
    content: "";
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
  }
}

.swiper-virtual.swiper-css-mode.swiper-horizontal {
  .swiper-wrapper:after {
    height: 1px;
    width: var(--swiper-virtual-size);
  }
}

.swiper-virtual.swiper-css-mode.swiper-vertical {
  .swiper-wrapper:after {
    height: var(--swiper-virtual-size);
    width: 1px;
  }
}

:root {
  --swiper-navigation-size:44px;
}

.swiper-button-next, .swiper-button-prev {
  align-items: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
  cursor: pointer;
  display: flex;
  height: var(--swiper-navigation-size);
  justify-content: center;
  position: absolute;
  width: var(--swiper-navigation-size);
  z-index: 10;
  &.swiper-button-disabled {
    cursor: auto;
    opacity: 0.35;
    pointer-events: none;
  }
  &.swiper-button-hidden {
    cursor: auto;
    opacity: 0;
    pointer-events: none;
  }
  .swiper-navigation-disabled & {
    display: none !important;
  }
  svg {
    height: 100%;
    object-fit: contain;
    transform-origin: center;
    width: 100%;
    fill: currentColor;
    pointer-events: none;
  }
}

.swiper-button-lock {
  display: none;
}

.swiper-button-next, .swiper-button-prev {
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  top: var(--swiper-navigation-top-offset, 50%);
}

.swiper-button-prev {
  left: var(--swiper-navigation-sides-offset, 4px);
  right: auto;
  .swiper-navigation-icon {
    transform: rotate(180deg);
  }
}

.swiper-button-next {
  left: auto;
  right: var(--swiper-navigation-sides-offset, 4px);
}

.swiper-horizontal {
  .swiper-button-next, .swiper-button-prev, ~ .swiper-button-next, ~ .swiper-button-prev {
    margin-left: 0;
    margin-top: calc(0px - var(--swiper-navigation-size) / 2);
    top: var(--swiper-navigation-top-offset, 50%);
  }
  &.swiper-rtl .swiper-button-next, &.swiper-rtl ~ .swiper-button-next, & ~ .swiper-button-prev, .swiper-button-prev {
    left: var(--swiper-navigation-sides-offset, 4px);
    right: auto;
  }
  &.swiper-rtl .swiper-button-prev, &.swiper-rtl ~ .swiper-button-prev, & ~ .swiper-button-next, .swiper-button-next {
    left: auto;
    right: var(--swiper-navigation-sides-offset, 4px);
  }
  &.swiper-rtl .swiper-button-next, &.swiper-rtl ~ .swiper-button-next, & ~ .swiper-button-prev, .swiper-button-prev {
    .swiper-navigation-icon {
      transform: rotate(180deg);
    }
  }
  &.swiper-rtl .swiper-button-prev, &.swiper-rtl ~ .swiper-button-prev {
    .swiper-navigation-icon {
      transform: rotate(0deg);
    }
  }
}

.swiper-vertical {
  .swiper-button-next, .swiper-button-prev, ~ .swiper-button-next, ~ .swiper-button-prev {
    left: var(--swiper-navigation-top-offset, 50%);
    margin-left: calc(0px - var(--swiper-navigation-size) / 2);
    margin-top: 0;
    right: auto;
  }
  .swiper-button-prev, ~ .swiper-button-prev {
    bottom: auto;
    top: var(--swiper-navigation-sides-offset, 4px);
    .swiper-navigation-icon {
      transform: rotate(-90deg);
    }
  }
  .swiper-button-next, ~ .swiper-button-next {
    bottom: var(--swiper-navigation-sides-offset, 4px);
    top: auto;
    .swiper-navigation-icon {
      transform: rotate(90deg);
    }
  }
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transform: translateZ(0);
  transition: opacity 0.3s;
  z-index: 10;
  &.swiper-pagination-hidden {
    opacity: 0;
  }
  &.swiper-pagination-disabled, .swiper-pagination-disabled > & {
    display: none !important;
  }
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: var(--swiper-pagination-bottom, 8px);
  left: 0;
  top: var(--swiper-pagination-top, auto);
  width: 100%;
}

.swiper-pagination-bullets-dynamic {
  font-size: 0;
  overflow: hidden;
  .swiper-pagination-bullet {
    position: relative;
    transform: scale(0.33);
  }
  .swiper-pagination-bullet-active, .swiper-pagination-bullet-active-main {
    transform: scale(1);
  }
  .swiper-pagination-bullet-active-prev {
    transform: scale(0.66);
  }
  .swiper-pagination-bullet-active-prev-prev {
    transform: scale(0.33);
  }
  .swiper-pagination-bullet-active-next {
    transform: scale(0.66);
  }
  .swiper-pagination-bullet-active-next-next {
    transform: scale(0.33);
  }
}

.swiper-pagination-bullet {
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
  display: inline-block;
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  button& {
    appearance: none;
    border: none;
    box-shadow: none;
    margin: 0;
    padding: 0;
  }
  .swiper-pagination-clickable & {
    cursor: pointer;
  }
  &:only-child {
    display: none !important;
  }
}

.swiper-pagination-bullet-active {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  opacity: var(--swiper-pagination-bullet-opacity, 1);
}

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
  left: var(--swiper-pagination-left, auto);
  right: var(--swiper-pagination-right, 8px);
  top: 50%;
  transform: translate3d(0, -50%, 0);
  .swiper-pagination-bullet {
    display: block;
    margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  }
  &.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    .swiper-pagination-bullet {
      display: inline-block;
      transition: transform 0.2s, top 0.2s;
    }
  }
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-horizontal.swiper-pagination-bullets {
  .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
  }
  &.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    .swiper-pagination-bullet {
      transition: transform 0.2s, left 0.2s;
    }
  }
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: transform 0.2s, right 0.2s;
}

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit);
}

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.2509803922));
  position: absolute;
  .swiper-pagination-progressbar-fill {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transform: scale(0);
    transform-origin: left top;
    width: 100%;
  }
  .swiper-rtl & .swiper-pagination-progressbar-fill {
    transform-origin: right top;
  }
  &.swiper-pagination-horizontal, &.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-horizontal > &, .swiper-vertical > &.swiper-pagination-progressbar-opposite {
    height: var(--swiper-pagination-progressbar-size, 4px);
    left: 0;
    top: 0;
    width: 100%;
  }
  &.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, &.swiper-pagination-vertical, .swiper-horizontal > &.swiper-pagination-progressbar-opposite, .swiper-vertical > & {
    height: 100%;
    left: 0;
    top: 0;
    width: var(--swiper-pagination-progressbar-size, 4px);
  }
}

.swiper-pagination-lock {
  display: none;
}

.swiper-scrollbar {
  background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, 0.1019607843));
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  position: relative;
  touch-action: none;
  &.swiper-scrollbar-disabled, .swiper-scrollbar-disabled > & {
    display: none !important;
  }
  &.swiper-scrollbar-horizontal, .swiper-horizontal > & {
    bottom: var(--swiper-scrollbar-bottom, 4px);
    height: var(--swiper-scrollbar-size, 4px);
    left: var(--swiper-scrollbar-sides-offset, 1%);
    position: absolute;
    top: var(--swiper-scrollbar-top, auto);
    width: calc(100% - var(--swiper-scrollbar-sides-offset, 1%) * 2);
    z-index: 50;
  }
  &.swiper-scrollbar-vertical, .swiper-vertical > & {
    height: calc(100% - var(--swiper-scrollbar-sides-offset, 1%) * 2);
    left: var(--swiper-scrollbar-left, auto);
    position: absolute;
    right: var(--swiper-scrollbar-right, 4px);
    top: var(--swiper-scrollbar-sides-offset, 1%);
    width: var(--swiper-scrollbar-size, 4px);
    z-index: 50;
  }
}

.swiper-scrollbar-drag {
  background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5019607843));
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  height: 100%;
  left: 0;
  position: relative;
  top: 0;
  width: 100%;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  text-align: center;
  width: 100%;
  > canvas, > img, > svg {
    max-height: 100%;
    max-width: 100%;
    object-fit: contain;
  }
}

.swiper-slide-zoomed {
  cursor: move;
  touch-action: none;
}

.swiper .swiper-notification {
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  margin: 0 auto;
  transition-timing-function: ease-out;
}

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  flex-direction: column;
  flex-wrap: wrap;
}

.swiper-fade {
  &.swiper-free-mode {
    .swiper-slide {
      transition-timing-function: ease-out;
    }
  }
  .swiper-slide {
    pointer-events: none;
    transition-property: opacity;
    .swiper-slide {
      pointer-events: none;
    }
  }
  .swiper-slide-active {
    pointer-events: auto;
    & .swiper-slide-active {
      pointer-events: auto;
    }
  }
}

.swiper.swiper-cube {
  overflow: visible;
}

.swiper-cube {
  .swiper-slide {
    backface-visibility: hidden;
    height: 100%;
    pointer-events: none;
    transform-origin: 0 0;
    visibility: hidden;
    width: 100%;
    z-index: 1;
    .swiper-slide {
      pointer-events: none;
    }
  }
  &.swiper-rtl .swiper-slide {
    transform-origin: 100% 0;
  }
  .swiper-slide-active {
    &, & .swiper-slide-active {
      pointer-events: auto;
    }
  }
  .swiper-slide-active, .swiper-slide-next, .swiper-slide-prev {
    pointer-events: auto;
    visibility: visible;
  }
  .swiper-cube-shadow {
    bottom: 0;
    height: 100%;
    left: 0;
    opacity: 0.6;
    position: absolute;
    width: 100%;
    z-index: 0;
    &:before {
      background: #000;
      bottom: 0;
      content: "";
      filter: blur(50px);
      left: 0;
      position: absolute;
      right: 0;
      top: 0;
    }
  }
}

.swiper-cube {
  .swiper-slide-next + .swiper-slide {
    pointer-events: auto;
    visibility: visible;
  }
}

.swiper-cube {
  .swiper-slide-shadow-cube.swiper-slide-shadow-bottom, .swiper-slide-shadow-cube.swiper-slide-shadow-left, .swiper-slide-shadow-cube.swiper-slide-shadow-right, .swiper-slide-shadow-cube.swiper-slide-shadow-top {
    backface-visibility: hidden;
    z-index: 0;
  }
}

.swiper.swiper-flip {
  overflow: visible;
}

.swiper-flip {
  .swiper-slide {
    backface-visibility: hidden;
    pointer-events: none;
    z-index: 1;
    .swiper-slide {
      pointer-events: none;
    }
  }
  .swiper-slide-active {
    &, & .swiper-slide-active {
      pointer-events: auto;
    }
  }
}

.swiper-flip {
  .swiper-slide-shadow-flip.swiper-slide-shadow-bottom, .swiper-slide-shadow-flip.swiper-slide-shadow-left, .swiper-slide-shadow-flip.swiper-slide-shadow-right, .swiper-slide-shadow-flip.swiper-slide-shadow-top {
    backface-visibility: hidden;
    z-index: 0;
  }
}

.swiper-creative {
  .swiper-slide {
    backface-visibility: hidden;
    overflow: hidden;
    transition-property: transform, opacity, height;
  }
}

.swiper.swiper-cards {
  overflow: visible;
}

.swiper-cards {
  .swiper-slide {
    backface-visibility: hidden;
    overflow: hidden;
    transform-origin: center bottom;
  }
}

#viewport {
  position: fixed;
  inset: 0;
  overflow: hidden;
  will-change: transform;
}

#container {
  min-height: 100%;
  will-change: transform;
}

.site-main {
  background: url(../../images/common/texture_bg.webp) repeat;
  padding: var(--head) 0 0;
  position: relative;
}

.in-module .max {
  max-width: 1200px;
  margin: 0 auto;
}
@media screen and (max-width: 1023px) {
  .in-module .max {
    min-width: 1px;
    max-width: 100%;
  }
}
.in-module.wrap {
  padding: calc(10vmin + 4rem) calc(var(--size) + 2vw);
}
.in-module.wrap.mid {
  padding-top: calc(5vmin + 4rem);
  padding-bottom: calc(5vmin + 4rem);
}
.in-module.wrap.no-top {
  padding-top: 0;
}
.in-module.wrap.no-bottom {
  padding-bottom: 0;
}
.in-module.white {
  background: #fffefd;
}
.in-module.darken {
  background: rgba(34, 30, 29, 0.064);
}
.in-module .c-title {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  margin: 0 0 1.6rem;
  background: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJf44Os44Kk44Ok44O8XzIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgdmlld0JveD0iMCAwIDQwLjI1IDguODEiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDojYjk4ZTFkO30uY2xzLTJ7ZmlsbDojYjYxOTIwO308L3N0eWxlPjwvZGVmcz48ZyBpZD0iX+ODrOOCpOODpOODvF8xLTIiPjxjaXJjbGUgY2xhc3M9ImNscy0xIiBjeD0iNC40IiBjeT0iNC40IiByPSI0LjQiLz48Y2lyY2xlIGNsYXNzPSJjbHMtMiIgY3g9IjIwLjEzIiBjeT0iNC40IiByPSI0LjQiLz48Y2lyY2xlIGNsYXNzPSJjbHMtMSIgY3g9IjM1Ljg1IiBjeT0iNC40IiByPSI0LjQiLz48L2c+PC9zdmc+") no-repeat center top/2.4rem;
  padding: 1.6rem 0 0;
}
.in-module .t-center {
  text-align: center;
}
.in-module .t-start {
  text-align: start;
}
.in-module .t-end {
  text-align: end;
}
.in-module .btnarea {
  margin: 2.4rem 0 0;
}
.in-module .btnarea.center {
  text-align: center;
}
.in-module .btnarea a.btn {
  color: #fffefd;
  border: #221e1d 1px solid;
  font-size: 1.08rem;
  line-height: 1.5;
  padding: 0.8rem 3.2rem;
  border-radius: 999rem;
  overflow: hidden;
  position: relative;
  display: inline-block;
  z-index: 1;
  transition: color 320ms cubic-bezier(0.65, 0, 0.35, 1);
}
.in-module .btnarea a.btn:before {
  content: "";
  background: #221e1d;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transition: width 320ms cubic-bezier(0.65, 0, 0.35, 1);
}
.in-module .btnarea a.btn:hover {
  color: #221e1d;
}
.in-module .btnarea a.btn:hover:before {
  left: auto;
  right: 0;
  width: 0;
}

.toAnimation {
  transform: translateY(2rem);
  opacity: 0;
}
.toAnimation.active {
  transform: translateX(0);
  opacity: 1;
  transition: all 600ms ease-in-out;
  transition-property: transform, opacity;
}
.toAnimation.active.delay-1 {
  transition-delay: 200ms;
}
.toAnimation.active.delay-2 {
  transition-delay: 400ms;
}
.toAnimation.active.delay-3 {
  transition-delay: 600ms;
}
.toAnimation.active.delay-4 {
  transition-delay: 800ms;
}
.toAnimation.active.delay-5 {
  transition-delay: 1000ms;
}
.toAnimation.active.delay-6 {
  transition-delay: 1200ms;
}
.toAnimation.active.delay-7 {
  transition-delay: 1400ms;
}
.toAnimation.active.delay-8 {
  transition-delay: 1600ms;
}
.toAnimation.active.delay-9 {
  transition-delay: 1800ms;
}
.toAnimation.active.delay-10 {
  transition-delay: 2000ms;
}

.toAnimationAll > * {
  transform: translateY(2rem);
  opacity: 0;
}
.toAnimationAll.active > * {
  transform: translateY(0);
  opacity: 1;
  transition: all 600ms ease-in-out;
  transition-property: transform, opacity;
}
.toAnimationAll.active > *:nth-child(1) {
  transition-delay: 80ms;
}
.toAnimationAll.active > *:nth-child(2) {
  transition-delay: 160ms;
}
.toAnimationAll.active > *:nth-child(3) {
  transition-delay: 240ms;
}
.toAnimationAll.active > *:nth-child(4) {
  transition-delay: 320ms;
}
.toAnimationAll.active > *:nth-child(5) {
  transition-delay: 400ms;
}
.toAnimationAll.active > *:nth-child(6) {
  transition-delay: 480ms;
}
.toAnimationAll.active > *:nth-child(7) {
  transition-delay: 560ms;
}
.toAnimationAll.active > *:nth-child(8) {
  transition-delay: 640ms;
}
.toAnimationAll.active > *:nth-child(9) {
  transition-delay: 720ms;
}
.toAnimationAll.active > *:nth-child(10) {
  transition-delay: 800ms;
}
.toAnimationAll.active > *:nth-child(11) {
  transition-delay: 880ms;
}
.toAnimationAll.active > *:nth-child(12) {
  transition-delay: 960ms;
}
.toAnimationAll.active > *:nth-child(13) {
  transition-delay: 1040ms;
}
.toAnimationAll.active > *:nth-child(14) {
  transition-delay: 1120ms;
}
.toAnimationAll.active > *:nth-child(15) {
  transition-delay: 1200ms;
}
.toAnimationAll.active > *:nth-child(16) {
  transition-delay: 1280ms;
}
.toAnimationAll.active > *:nth-child(17) {
  transition-delay: 1360ms;
}
.toAnimationAll.active > *:nth-child(18) {
  transition-delay: 1440ms;
}
.toAnimationAll.active > *:nth-child(19) {
  transition-delay: 1520ms;
}
.toAnimationAll.active > *:nth-child(20) {
  transition-delay: 1600ms;
}
.toAnimationAll.active > *:nth-child(21) {
  transition-delay: 1680ms;
}
.toAnimationAll.active > *:nth-child(22) {
  transition-delay: 1760ms;
}
.toAnimationAll.active > *:nth-child(23) {
  transition-delay: 1840ms;
}
.toAnimationAll.active > *:nth-child(24) {
  transition-delay: 1920ms;
}
.toAnimationAll.active > *:nth-child(25) {
  transition-delay: 2000ms;
}
.toAnimationAll.active > *:nth-child(26) {
  transition-delay: 2080ms;
}
.toAnimationAll.active > *:nth-child(27) {
  transition-delay: 2160ms;
}
.toAnimationAll.active > *:nth-child(28) {
  transition-delay: 2240ms;
}
.toAnimationAll.active > *:nth-child(29) {
  transition-delay: 2320ms;
}
.toAnimationAll.active > *:nth-child(30) {
  transition-delay: 2400ms;
}

.site-index .firstview {
  padding: 3.2rem calc(var(--size) + 2vw);
  position: relative;
}
.site-index .firstview__pic {
  max-width: 1200px;
  margin: 0 auto 4rem;
  position: relative;
  z-index: 2;
}
.site-index .firstview__pic img {
  width: 100%;
  border-radius: 0.8rem;
}
.site-index .firstview__bg {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  mix-blend-mode: multiply;
}
.site-index .firstview__bg img {
  height: 60%;
  opacity: 0.12;
}
.site-index .firstview__context {
  background: #fffefd;
  padding: 2.4rem;
  border-radius: 0.8rem;
  text-align: center;
  position: relative;
}
.site-index .firstview__context:before, .site-index .firstview__context:after {
  content: "";
  width: 8rem;
  height: 5rem;
  background: url(../../images/index/f_context_efe.webp) no-repeat 0 0/contain;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-15%, -15%);
}
.site-index .firstview__context:after {
  left: auto;
  right: 0;
  transform: translate(15%, -15%) rotateY(180deg);
}
.site-index .r-bg {
  height: 6.4rem;
  background: url(../../images/index/r_bg_b.webp) repeat-x 0 1px/41.1rem 6.4rem;
  position: relative;
  animation: movebg 8000ms infinite linear;
}
.site-index .r-bg:before {
  content: "";
  width: 100%;
  height: 100%;
  background: url(../../images/index/r_bg_a.webp) repeat-x 0 1px/41.1rem 6.4rem;
  position: absolute;
  inset: 0;
  animation: movebg 20000ms infinite reverse linear;
}
@keyframes movebg {
  0% {
    background-position: 0 1px;
  }
  100% {
    background-position: -41.1rem 1px;
  }
}
.site-index .news__grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 5.6rem;
}
.site-index .news__grid > * {
  align-self: flex-start;
}
.site-index .news__grid h2 {
  color: #b61920;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-end;
  gap: 0.8rem;
}
.site-index .news__grid h2:before {
  content: attr(data-eng);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
}
.site-index .news__grid ul {
  margin: 0.56rem 0 0;
}
.site-index .news__grid ul li {
  display: grid;
  grid-template-columns: 12rem 1fr;
  gap: 2.4rem;
}
.site-index .news__grid ul li h3 {
  font-size: 1.12rem;
}
.site-index .news__grid ul li a {
  color: #b61920;
  font-weight: 700;
  text-decoration: underline;
  display: inline-block;
}
.site-index .guide {
  position: relative;
  border: #efeeed 0.6rem solid;
  padding: 2.4rem;
  padding-top: 4.8rem;
  border-radius: 0.8rem;
}
.site-index .guide__title {
  font-size: 1.2rem;
  line-height: 1;
  text-align: center;
  padding: 0 2.4rem;
  background: #fffefd;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}
.site-index .guide__title:before {
  content: attr(data-eng);
  color: #b98e1d;
  display: block;
  font-size: 2.4rem;
  margin: 0 0 0.72rem;
}
.site-index .guide__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.8rem;
}
.site-index .guide__list li a {
  display: block;
  text-align: center;
  font-size: 1.04rem;
}
.site-index .flyer {
  position: relative;
}
.site-index .flyer:before {
  content: "";
  background: rgba(34, 30, 29, 0.064);
  position: absolute;
  width: 100%;
  height: 10rem;
  left: 0;
  bottom: 0;
}
.site-index .flyer__wave {
  height: 4rem;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  fill: #fffefd;
}
.site-index .flyer__icon {
  width: 5.6rem;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
.site-index .flyer__icon img {
  width: 100%;
}
.site-index .flyer__title {
  width: 40rem;
  margin: 0 auto 2.4rem;
}
.site-index .flyer__title img {
  width: 100%;
}
.site-index .flyer__list__item {
  margin: 3.2rem 0 0;
  background: #fffefd;
  padding: 2.4rem;
  border-radius: 0.8rem;
  box-shadow: 0 0 3.2rem rgba(34, 30, 29, 0.06);
  position: relative;
}
.site-index .flyer__list__item:before, .site-index .flyer__list__item:after {
  content: "";
  width: 8rem;
  height: 5rem;
  background: url(../../images/index/f_context_efe.webp) no-repeat 0 0/contain;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-15%, -15%);
}
.site-index .flyer__list__item:after {
  left: auto;
  right: 0;
  transform: translate(15%, -15%) rotateY(180deg);
}
.site-index .flyer__list__item img {
  max-width: 100%;
}
.site-index .flyer__list__item__title {
  text-align: center;
  font-size: 2.4rem;
  margin: 0 0 1.6rem;
}
.site-index .flyer__list__item__main {
  text-align: center;
}
.site-index .flyer__list__item__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.2rem;
}
.site-index .flyer__list__item__grid > * {
  align-self: center;
}
.site-index .flyer__list__item__grid__pic img {
  width: 100%;
  border-radius: 0.64rem;
}
.site-index .flyer__list__item__grid__data .btn {
  margin: 1.6rem 0 0;
}
.site-index .listable {
  margin: 2.4rem 0 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.6rem;
}
.site-index .listable li {
  background: #fffefd;
  border-radius: 0.64rem;
  overflow: hidden;
}
.site-index .listable li figure img {
  width: 100%;
  aspect-ratio: 16/10;
}
.site-index .listable li dl {
  padding: 1.4rem;
  font-size: 0.92rem;
}
.site-index .listable li dl dt {
  font-size: 1.08rem;
  font-weight: 700;
  text-align: center;
}
.site-index .listable li dl dd.act {
  margin: 0.64rem 0 1rem 0.48rem;
  background: #b98e1d;
  text-align: center;
  color: #FFF;
}
.site-index .listable li dl dd.act.disabled {
  background: #ebeae8;
  color: rgb(91.8971428571, 81.0857142857, 78.3828571429);
}
.site-index .listable li dl dd a {
  color: #b61920;
  text-decoration: underline;
  line-height: 1.5;
  display: inline-block;
}
.site-index .volunteer, .site-index .companies {
  background: #fffefd;
  border-radius: 0.8rem;
  padding: 2.4rem;
}
.site-index .volunteer .btnarea, .site-index .companies .btnarea {
  margin-top: 1.6rem;
}
.site-index .companies {
  margin: 3.2rem 0 0;
}
.site-index .companies__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin: 1.6rem 0 3.2rem;
  gap: 1.6rem;
}
.site-index .companies__list li a {
  display: block;
  height: 100%;
}
.site-index .companies__list li img {
  width: 100%;
  background: #efeeed;
  object-fit: contain;
  aspect-ratio: 1/1;
}
.site-index .companies__texts {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: 0.72rem;
  margin: 1.6rem 4rem 0;
  font-size: 0.96rem;
}
.site-index .companies__texts.l {
  font-size: 1.24rem;
}
.site-index .companies__texts.m {
  font-size: 1.08rem;
}
.site-index .companies__texts li a {
  color: #b61920;
  text-decoration: underline;
}
.site-index .companies__texts li:after {
  content: "/";
  opacity: 0.24;
  display: inline-block;
  margin: 0 0 0 0.72rem;
}
.site-index .companies__texts li:last-child:after {
  display: none;
}
.site-index .bnr {
  margin: 3.2rem 0 0;
}
.site-index .bnr a {
  color: #b61920;
  text-decoration: underline;
}
.site-index .bnr figure {
  margin: 0 0 0.8rem;
}
.site-index .bnr figure img {
  max-width: 60%;
  background: #fffefd;
  border-radius: 0.8rem;
  padding: 1.6rem;
}

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