@charset "UTF-8";
/*---------------------------------------------------------------------------------
CSS構成
// 絶対に変更しないCSS
./assets/vendor/**.css

// メインで利用しているCSS
- style.css                 SCSSを集約したCSS

// SCSS構成
- external                  ./assets/vendor/**.cssを上書きする ※基本触らない
- foundation                基本の文字設定やWebフォントの読み込みなど ※基本触らない
- global                    @mixin, @function, 変数など ※基本触らない
- layout                    各ページを構成する大枠のレイアウト ※基本触らない
- object                    パーツやブロック
    ├─component             繰り返し使用される小さな単位のパーツ
    └─project               セクションや大きなブロック
- page                      下層ページ固有のスタイル
---------------------------------------------------------------------------------*/
/* ================================================================
external
================================================================ */
:root {
  --dvw-sm: 575px;
  --dvw-md: 767px;
  --dvw-lg: 991px;
  --dvw-xl: 1199px;
  --dvw-xxl: 1399px;
  --container-max: 1680px;
  --container-pd: max(2dvw, 40px);
}
@media screen and (min-width: 2001px) {
  :root {
    --container-max: calc(1680 / 2000 * 100dvw) ;
  }
}
@media screen and (max-width: 767px) {
  :root {
    --container-pd: max(1.2dvw, 24px);
  }
}
:root {
  --container--md: calc(var(--container-max) / 12 * 10);
  --container--sm: calc(var(--container-max) / 12 * 8);
  --container--xs: calc(var(--container-max) / 12 * 6);
  --br-base: max(.2dvw, .25rem);
  --br: var(--br-base);
}
@media screen and (max-width: 767px) {
  :root {
    --br: calc(var(--br-base) * .5);
  }
}
:root {
  /* hamburger */
  --hamburger--width: 60px;
}
@media screen and (max-width: 1199px) {
  :root {
    --hamburger--width: 52px;
  }
}
@media screen and (max-width: 767px) {
  :root {
    --hamburger--width: 48px;
  }
}
:root {
  /* header-padding */
  --header-padding--vertical: max(1.4dvw, 20px);
  --header-padding--inline: max(1.4dvw, 24px);
}
@media screen and (max-width: 767px) {
  :root {
    --header-padding--vertical: max(calc(20 / 767 * 100dvw), 16px);
    --header-padding--inline: max(calc(20 / 767 * 100dvw), 20px);
  }
}
:root {
  --space-base: max(.2dvw, .25rem);
  --space-section: calc(var(--space-base) * 30);
  --space-content: calc(var(--space-base) * 15);
}
@media screen and (max-width: 1399px) {
  :root {
    --space-content: calc(var(--space-base) * 12);
  }
}
@media screen and (max-width: 1199px) {
  :root {
    --space-content: calc(var(--space-base) * 10);
  }
}
@media screen and (max-width: 991px) {
  :root {
    --space-content: calc(var(--space-base) * 8);
  }
}
@media screen and (max-width: 767px) {
  :root {
    --space-content: calc(var(--space-base) * 6);
  }
}
:root {
  --vertical--60: max(3dvw, 2.75rem);
  --vertical--90: max(4.5dvw, 4.25rem);
  --vertical--120: max(6dvw, 5.75rem);
  /* z-index */
  --z-back-to-top: 1000;
  --z-header: 2000;
  --z-nav: 8000;
  --z-dropdown: 9000;
  --z-hamburger: 9999;
  --z-loading: 99999;
  /* color */
  /* == color-primitive == */
  --base-red-100: #fae9eb;
  --base-red-200: #f0abb3;
  --base-red-400: #e60012;
  --base-gray-100: #f8f8f8;
  --base-gray-150: #edecec;
  --base-gray-200: #e7e7e7;
  --base-gray-300: #a2a2a2;
  --base-gray-400: #8c8c8c;
  --base-gray-700: #595757;
  --base-black-400: #000000;
  --base-white-400: #ffffff;
  --base-yellow-100: #fcf9f3;
  --fc-black-400: #000000;
  --fc-gray-400: #595757;
  --fc-white-400: #ffffff;
  --fc-red-400: #e60012;
  /* == color-semantic == */
  /* bg */
  --bg-body: var(--base-white-400);
  --bg-base: var(--base-white-400);
  --bg-red: var(--base-red-400);
  --bg-red--hover: var(--base-red-100);
  --bg-black: var(--base-black-400);
  --bg-gray--light: var(--base-gray-100);
  --bg-gray--middle: var(--base-gray-200);
  --bg-gray--dark: var(--base-gray-400);
  --bg-yellow: var(--base-yellow-100);
  /* filter */
  --filter-dark: rgba(0, 0, 0, .7);
  /* accent */
  --accent-red: var(--base-red-400);
  /* line */
  --line-black: var(--base-black-400);
  --line-gray--frame: var(--base-gray-700);
  --line-gray--input: var(--base-gray-300);
  --line-gray--separate: var(--base-gray-200);
  --line-red--focus: var(--base-red-200);
  /* button */
  --button-cv: var(--base-red-400);
  --button-others: var(--base-white-400);
  /* scrollbar */
  --scroll-box: var(--base-gray-150);
  /* text */
  --text-dark: var(--fc-black-400);
  --text-light: var(--fc-white-400);
  --text-gray: var(--fc-gray-400);
  --text-link: var(--fc-red-400);
  --title-ja: var(--fc-black-400);
  --title-en: var(--fc-red-400);
  /* font */
  --ff-ja-primary: "Zen Kaku Gothic New";
  --ff-ja-secondary: "Zen Old Mincho";
  --ff-en-primary: "Plus Jakarta Sans";
  --ff-base: "Helvetica Neue",
  Arial,
  "Hiragino Kaku Gothic ProN",
  "Hiragino Sans",
  "Noto Sans JP",
  sans-serif;
  --fs-tel: max(2dvw, 1.5rem);
  --fs-xs: max(.6dvw, .625rem);
  --fs-sm: max(.7dvw, .75rem);
  --fs-md: max(.8dvw, .875rem);
  --fs-lg: max(.9dvw, 1rem);
  --fs-xl: max(1dvw, 1.125rem);
  --fs-copyright: max(.6dvw, .625rem);
  --fs-lg-title--ja: max(2.4dvw, 1.75rem);
  --fs-lg-title--en: max(.6875dvw, .6875rem);
  --fs-md-title: max(1.4dvw, 1.375rem);
  --fs-strong: max(1.2dvw, 1.25rem);
  --ls-min: 0em;
  --ls-narrow: 0.02em;
  --ls-base: 0.05em;
  --ls-wide: 0.1em;
  --ls-en-primary: 0.05em;
  --lh-single: 1;
  --lh-min: 1.2;
  --lh-narrow: 1.4;
  --lh-base: 1.6;
  --lh-wide: 2.0;
  /* animation */
  --animation-button: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  --animation-dropdown: 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  --animation-header: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --animation-banner: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --animation-input: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --animation-fade: 1.6s cubic-bezier(0.4, 0, 0.2, 1);
}

/* 
destyle-custom
---------------------------------------------------------------- */
*,
::before,
::after {
  min-width: initial;
}

/*
bootstrap-custom
---------------------------------------------------------------- */
h1,
h2,
h3,
h4,
h5,
h6 {
  padding: 0;
  margin: 0;
  font-size: initial;
  line-height: 1;
}

p {
  margin: 0;
}

address {
  margin: 0;
}

tbody,
td,
tfoot,
th,
thead,
tr {
  font-weight: 400;
  border: none;
}

a {
  color: #000;
  text-decoration: none;
}

svg,
img,
embed,
object,
iframe form {
  vertical-align: bottom;
}

figure {
  margin: initial;
}

ul,
ol,
dl {
  padding: 0;
  margin: 0;
}

dt,
dd {
  margin: 0;
  font-weight: 400;
}

.shadow {
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}

.card {
  border: none;
}

.icon-link {
  display: initial;
  gap: initial;
  -webkit-box-align: initial;
      -ms-flex-align: initial;
          align-items: initial;
  text-decoration-color: initial;
  text-underline-offset: initial;
  -webkit-backface-visibility: initial;
  backface-visibility: initial;
}

.lead {
  font-size: inherit;
  font-weight: initial;
}

.placeholder {
  display: revert;
  min-height: revert;
  vertical-align: revert;
  cursor: revert;
  background-color: revert;
  opacity: revert;
}

/* 
swiper-custom
---------------------------------------------------------------- */
.swiper-fade .swiper-slide {
  -webkit-transition-property: opacity !important;
  transition-property: opacity !important;
}

/* ================================================================
foundation
================================================================ */
/*
base
---------------------------------------------------------------- */
html {
  font-size: 1rem;
  overflow-x: hidden;
}

body {
  font-family: YakuHanJP, var(--ff-ja-primary), var(--ff-base);
  font-size: var(--fs-md);
  letter-spacing: var(--ls-base);
  color: var(--text-dark);
  font-feature-settings: "palt";
  -webkit-font-feature-settings: "palt";
  background-color: var(--bg-body);
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

.is-nav-open {
  overflow: hidden;
  -ms-touch-action: none;
      touch-action: none;
}

div {
  line-height: var(--lh-single);
}

p {
  line-height: var(--lh-base);
}

a {
  display: inline-block;
  color: var(--text-dark);
}

img,
picture {
  display: inline-block;
  width: 100%;
  height: auto;
}

svg {
  display: inline-block;
}

use {
  display: inline-block;
  width: 100%;
  height: auto;
}

@media (any-hover: hover) {
  a:has(span[data-action=call]) {
    pointer-events: none;
    cursor: text;
  }
}

/* === paragraph-custom === */
.note {
  padding-left: 1em;
  font-size: 0.875em;
  line-height: var(--lh-narrow);
  text-indent: -1em;
}

.small {
  margin-right: 0.5em;
  font-size: 0.75em;
}

.marker {
  position: relative;
}
.marker::before {
  content: "";
  display: block;
  width: 100%;
  height: 0.2em;
  background-color: var(--marker-bg);
}

/*
br
---------------------------------------------------------------- */
.br-sm {
  display: none;
}
@media screen and (max-width: 575px) {
  .br-sm {
    display: block;
  }
}

.br-md {
  display: none;
}
@media screen and (max-width: 767px) {
  .br-md {
    display: block;
  }
}

.br-lg {
  display: none;
}
@media screen and (max-width: 991px) {
  .br-lg {
    display: block;
  }
}

.br-xl {
  display: none;
}
@media screen and (max-width: 1199px) {
  .br-xl {
    display: block;
  }
}

.br-xxl {
  display: none;
}
@media screen and (max-width: 1399px) {
  .br-xxl {
    display: block;
  }
}

/*
animation
---------------------------------------------------------------- */
/* .js-transparentAppear */
.js-transparentAppear {
  opacity: 0;
  visibility: hidden;
  -webkit-animation: transparentDisappear var(--animation-button) forwards;
          animation: transparentDisappear var(--animation-button) forwards;
}
@-webkit-keyframes transparentDisappear {
  0% {
    opacity: 1;
    visibility: visible;
  }
  100% {
    opacity: 0;
    visibility: hidden;
  }
}
@keyframes transparentDisappear {
  0% {
    opacity: 1;
    visibility: visible;
  }
  100% {
    opacity: 0;
    visibility: hidden;
  }
}
.js-transparentAppear.is-animated {
  -webkit-animation: transparentAppear var(--animation-button) forwards;
          animation: transparentAppear var(--animation-button) forwards;
}
@-webkit-keyframes transparentAppear {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  100% {
    opacity: 1;
    visibility: visible;
  }
}
@keyframes transparentAppear {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  100% {
    opacity: 1;
    visibility: visible;
  }
}

/* .js-fadeUp */
.js-fadeUp {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(12px);
          transform: translateY(12px);
}
.js-fadeUp.is-animated {
  -webkit-animation-name: fadeUp;
          animation-name: fadeUp;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-timing-function: ease;
          animation-timing-function: ease;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@-webkit-keyframes fadeUp {
  0% {
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translateY(12px);
            transform: translateY(12px);
  }
  80% {
    opacity: 1;
    visibility: visible;
  }
  100% {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes fadeUp {
  0% {
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translateY(12px);
            transform: translateY(12px);
  }
  80% {
    opacity: 1;
    visibility: visible;
  }
  100% {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

/* .js-fadeIn */
.js-fadeIn {
  opacity: 0;
  visibility: hidden;
}
.js-fadeIn.is-animated {
  -webkit-animation-name: fadeIn;
          animation-name: fadeIn;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  100% {
    opacity: 1;
    visibility: visible;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  100% {
    opacity: 1;
    visibility: visible;
  }
}

/* .js-bgExtend */
.js-bgLRExtend {
  -webkit-animation-name: bgExtendAnimeBase;
          animation-name: bgExtendAnimeBase;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  opacity: 0;
}
@-webkit-keyframes bgExtendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes bgExtendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.js-bgLRExtend.is-animated::before {
  content: "";
  width: 100%;
  height: 1em;
  background-color: var(--bg-black);
  position: absolute;
  top: calc(50% - 0.5em);
  left: 0;
  -webkit-animation-name: bgLRExtendAnime;
          animation-name: bgLRExtendAnime;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@-webkit-keyframes bgLRExtendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}
@keyframes bgLRExtendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}

.js-textAppear {
  opacity: 0;
}
.js-textAppear.is-animated {
  -webkit-animation-name: bgExtendAnimeSecond;
          animation-name: bgExtendAnimeSecond;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
  -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@-webkit-keyframes bgExtendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes bgExtendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.js-bgLRExtend-pic {
  -webkit-animation-name: bgExtendAnimeBase;
          animation-name: bgExtendAnimeBase;
  -webkit-animation-duration: 1.6s;
          animation-duration: 1.6s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  opacity: 0;
}
@keyframes bgExtendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.js-bgLRExtend-pic.is-animated::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--bg-black);
  position: absolute;
  top: 0;
  left: 0;
  -webkit-animation-name: bgLRExtendAnime;
          animation-name: bgLRExtendAnime;
  -webkit-animation-duration: 1.4s;
          animation-duration: 1.4s;
  -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@keyframes bgLRExtendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}

.js-textAppear-pic {
  height: 100%;
  opacity: 0;
}
.js-textAppear-pic.is-animated {
  -webkit-animation-name: bgExtendAnimeSecond;
          animation-name: bgExtendAnimeSecond;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
  -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@keyframes bgExtendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* === animation-custom === */
/* delay */
@media screen and (min-width: 768px) {
  .animation-delay-1 {
    -webkit-animation-delay: 0.1s;
            animation-delay: 0.1s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-2 {
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-3 {
    -webkit-animation-delay: 0.3s;
            animation-delay: 0.3s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-4 {
    -webkit-animation-delay: 0.4s;
            animation-delay: 0.4s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-5 {
    -webkit-animation-delay: 0.5s;
            animation-delay: 0.5s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-6 {
    -webkit-animation-delay: 0.6s;
            animation-delay: 0.6s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-7 {
    -webkit-animation-delay: 0.7s;
            animation-delay: 0.7s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-8 {
    -webkit-animation-delay: 0.8s;
            animation-delay: 0.8s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-9 {
    -webkit-animation-delay: 0.9s;
            animation-delay: 0.9s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-10 {
    -webkit-animation-delay: 1s;
            animation-delay: 1s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-11 {
    -webkit-animation-delay: 1.1s;
            animation-delay: 1.1s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-12 {
    -webkit-animation-delay: 1.2s;
            animation-delay: 1.2s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-13 {
    -webkit-animation-delay: 1.3s;
            animation-delay: 1.3s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-14 {
    -webkit-animation-delay: 1.4s;
            animation-delay: 1.4s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-15 {
    -webkit-animation-delay: 1.5s;
            animation-delay: 1.5s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-16 {
    -webkit-animation-delay: 1.6s;
            animation-delay: 1.6s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-17 {
    -webkit-animation-delay: 1.7s;
            animation-delay: 1.7s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-18 {
    -webkit-animation-delay: 1.8s;
            animation-delay: 1.8s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-19 {
    -webkit-animation-delay: 1.9s;
            animation-delay: 1.9s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-20 {
    -webkit-animation-delay: 2s;
            animation-delay: 2s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-21 {
    -webkit-animation-delay: 2.1s;
            animation-delay: 2.1s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-22 {
    -webkit-animation-delay: 2.2s;
            animation-delay: 2.2s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-23 {
    -webkit-animation-delay: 2.3s;
            animation-delay: 2.3s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-24 {
    -webkit-animation-delay: 2.4s;
            animation-delay: 2.4s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-25 {
    -webkit-animation-delay: 2.5s;
            animation-delay: 2.5s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-26 {
    -webkit-animation-delay: 2.6s;
            animation-delay: 2.6s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-27 {
    -webkit-animation-delay: 2.7s;
            animation-delay: 2.7s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-28 {
    -webkit-animation-delay: 2.8s;
            animation-delay: 2.8s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-29 {
    -webkit-animation-delay: 2.9s;
            animation-delay: 2.9s;
  }
}
@media screen and (min-width: 768px) {
  .animation-delay-30 {
    -webkit-animation-delay: 3s;
            animation-delay: 3s;
  }
}
/* duration */
.is-animated.animation-duration-1 {
  -webkit-animation-duration: 0.1s;
          animation-duration: 0.1s;
}

.is-animated.animation-duration-2 {
  -webkit-animation-duration: 0.2s;
          animation-duration: 0.2s;
}

.is-animated.animation-duration-3 {
  -webkit-animation-duration: 0.3s;
          animation-duration: 0.3s;
}

.is-animated.animation-duration-4 {
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
}

.is-animated.animation-duration-5 {
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
}

.is-animated.animation-duration-6 {
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
}

.is-animated.animation-duration-7 {
  -webkit-animation-duration: 0.7s;
          animation-duration: 0.7s;
}

.is-animated.animation-duration-8 {
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
}

.is-animated.animation-duration-9 {
  -webkit-animation-duration: 0.9s;
          animation-duration: 0.9s;
}

.is-animated.animation-duration-10 {
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
}

.is-animated.animation-duration-11 {
  -webkit-animation-duration: 1.1s;
          animation-duration: 1.1s;
}

.is-animated.animation-duration-12 {
  -webkit-animation-duration: 1.2s;
          animation-duration: 1.2s;
}

.is-animated.animation-duration-13 {
  -webkit-animation-duration: 1.3s;
          animation-duration: 1.3s;
}

.is-animated.animation-duration-14 {
  -webkit-animation-duration: 1.4s;
          animation-duration: 1.4s;
}

.is-animated.animation-duration-15 {
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
}

.is-animated.animation-duration-16 {
  -webkit-animation-duration: 1.6s;
          animation-duration: 1.6s;
}

.is-animated.animation-duration-17 {
  -webkit-animation-duration: 1.7s;
          animation-duration: 1.7s;
}

.is-animated.animation-duration-18 {
  -webkit-animation-duration: 1.8s;
          animation-duration: 1.8s;
}

.is-animated.animation-duration-19 {
  -webkit-animation-duration: 1.9s;
          animation-duration: 1.9s;
}

.is-animated.animation-duration-20 {
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
}

.is-animated.animation-duration-21 {
  -webkit-animation-duration: 2.1s;
          animation-duration: 2.1s;
}

.is-animated.animation-duration-22 {
  -webkit-animation-duration: 2.2s;
          animation-duration: 2.2s;
}

.is-animated.animation-duration-23 {
  -webkit-animation-duration: 2.3s;
          animation-duration: 2.3s;
}

.is-animated.animation-duration-24 {
  -webkit-animation-duration: 2.4s;
          animation-duration: 2.4s;
}

.is-animated.animation-duration-25 {
  -webkit-animation-duration: 2.5s;
          animation-duration: 2.5s;
}

.is-animated.animation-duration-26 {
  -webkit-animation-duration: 2.6s;
          animation-duration: 2.6s;
}

.is-animated.animation-duration-27 {
  -webkit-animation-duration: 2.7s;
          animation-duration: 2.7s;
}

.is-animated.animation-duration-28 {
  -webkit-animation-duration: 2.8s;
          animation-duration: 2.8s;
}

.is-animated.animation-duration-29 {
  -webkit-animation-duration: 2.9s;
          animation-duration: 2.9s;
}

.is-animated.animation-duration-30 {
  -webkit-animation-duration: 3s;
          animation-duration: 3s;
}

/* 
.svg-sprites
---------------------------------------------------------------- */
.svg-sprites {
  display: block;
  width: 0;
  height: 0;
}

/* ================================================================
layout
================================================================ */
/* .l-wrapper */
.l-wrapper {
  min-height: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

/* .l-header */
.l-header {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: var(--z-header);
}

/* .l-main */
.l-main {
  /* l-main内の要素が存在しない場合、
     親要素のサイズをl-mainに割り当てる */
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

/* .l-container */
.l-container {
  max-width: calc(var(--container-max) + var(--container-pd) * 2);
  padding-inline: var(--container-pd);
  margin-inline: auto;
}
.l-container--full {
  width: 100%;
  max-width: calc(88dvw + var(--container-pd) * 2);
  padding-inline: var(--container-pd);
  margin-inline: auto;
}

/* .l-footer */
.l-footer {
  /* 1ページ内のコンテンツ高さが100vhに満たない場合
     p-footerを画面最下部に寄せる */
  justify-self: end;
}

/* ================================================================
object
================================================================ */
/*
.c-button
---------------------------------------------------------------- */
.c-button {
  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: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 4.25em;
     -moz-column-gap: 4.25em;
          column-gap: 4.25em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding: 1.25em 2em 1.25em 0;
  border: 1px solid var(--accent-red);
  border-radius: 1000px;
  font-size: max(0.8dvw, 1rem);
  font-weight: 500;
  overflow: hidden;
  position: relative;
  -webkit-transition: background-color var(--animation-button), color var(--animation-button);
  transition: background-color var(--animation-button), color var(--animation-button);
}
.c-button[type=submit] {
  border-radius: calc(var(--br-base) * 2);
}
.c-button {
  /* .button-arrow */
}
.c-button .button-arrow {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 1.25em;
  aspect-ratio: 24/14;
  -webkit-mask-image: url(../assets/images/common/icon-arrow.svg);
          mask-image: url(../assets/images/common/icon-arrow.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  opacity: 0;
  -webkit-transform: translateX(-1.25em);
          transform: translateX(-1.25em);
  -webkit-transition: all var(--animation-button);
  transition: all var(--animation-button);
  position: absolute;
  left: 2em;
}
.c-button {
  /* .button-text */
}
.c-button .button-text {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-left: 2em;
  position: relative;
  z-index: 2;
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}
.c-button {
  /* .button-circle */
}
.c-button .button-circle {
  width: 0.75em;
  height: 0.75em;
  border-radius: 50%;
  -webkit-transition: opacity var(--animation-button), -webkit-transform var(--animation-button);
  transition: opacity var(--animation-button), -webkit-transform var(--animation-button);
  transition: transform var(--animation-button), opacity var(--animation-button);
  transition: transform var(--animation-button), opacity var(--animation-button), -webkit-transform var(--animation-button);
}
.c-button {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .c-button:hover .button-arrow {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  .c-button:hover .button-text {
    -webkit-transform: translateX(2.5em);
            transform: translateX(2.5em);
  }
  .c-button:hover .button-circle {
    opacity: 1;
    -webkit-transform: scale(0);
            transform: scale(0);
  }
}

@media screen and (max-width: 575px) {
  .c-button {
    min-width: 80dvw;
  }
  .c-button[type=submit]:not(:first-child) {
    margin-top: 1em;
  }
}
/* === .bg-base === */
.c-button.bg-base {
  background-color: var(--bg-base);
  color: var(--accent-red);
  /* .button-arrow */
}
.c-button.bg-base .button-arrow {
  background-color: var(--accent-red);
}
.c-button.bg-base {
  /* .button-circle */
}
.c-button.bg-base .button-circle {
  background-color: var(--accent-red);
}
.c-button.bg-base {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .c-button.bg-base:hover {
    background-color: var(--accent-red);
    color: var(--text-light);
  }
  .c-button.bg-base:hover .button-arrow {
    background-color: var(--text-light);
  }
}

/* === .bg-red === */
.c-button.bg-red {
  background-color: var(--accent-red);
  color: var(--text-light);
  /* .button-arrow */
}
.c-button.bg-red .button-arrow {
  background-color: var(--text-light);
}
.c-button.bg-red {
  /* .button-circle */
}
.c-button.bg-red .button-circle {
  background-color: var(--text-light);
}
.c-button.bg-red {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .c-button.bg-red:hover {
    background-color: var(--bg-base);
    color: var(--accent-red);
  }
  .c-button.bg-red:hover .button-arrow {
    background-color: var(--accent-red);
  }
}

/* === .at-nav === */
.c-button.at-nav {
  -webkit-column-gap: 0.5rem;
     -moz-column-gap: 0.5rem;
          column-gap: 0.5rem;
  width: 100%;
  padding: 1.5em 2em 1.5em 0;
  border-radius: calc(var(--br-base) * 2);
}
.c-button.at-nav .button-circle {
  width: 1em;
  height: 1em;
  border-radius: 0;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.c-button.at-nav--contact .button-circle {
  -webkit-mask-image: url(../assets/images/common/icon-mail.svg);
          mask-image: url(../assets/images/common/icon-mail.svg);
}
.c-button.at-nav--quotation .button-circle {
  -webkit-mask-image: url(../assets/images/common/icon-calculator.svg);
          mask-image: url(../assets/images/common/icon-calculator.svg);
}

@media screen and (min-width: 1340px) {
  .c-button.at-nav {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: max(1.2dvw, 1em) max(1.6dvw, 1.25em);
    padding-left: 0;
  }
  .c-button.at-nav .button-text {
    margin-inline: 1.75em 0.75em;
  }
  .c-button.at-nav .button-arrow {
    left: 1.75em;
  }
  .c-button.at-nav {
    /* --- hover --- */
  }
}
@media screen and (min-width: 1340px) and (any-hover: hover) {
  .c-button.at-nav:hover .button-text {
    -webkit-transform: translateX(1.75em);
            transform: translateX(1.75em);
  }
}
/* === .c-button.role-back === */
.c-button.role-back {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  padding-inline: 2em 0;
  border-color: var(--line-black);
  font-family: var(--ff-en-primary);
}
.c-button.role-back .button-arrow {
  background-color: var(--bg-black);
  -webkit-transform: translateX(-1.25em);
          transform: translateX(-1.25em);
  scale: -1 1;
  left: initial;
  right: 2em;
}
.c-button.role-back .button-text {
  margin-inline: 0 2em;
}
.c-button.role-back .button-circle {
  background-color: var(--bg-black);
}
.c-button.role-back {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .c-button.role-back:hover {
    background-color: var(--bg-black);
  }
  .c-button.role-back:hover .button-arrow {
    background-color: var(--text-light);
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  .c-button.role-back:hover .button-text {
    color: var(--text-light);
    -webkit-transform: translateX(-1.75em);
            transform: translateX(-1.75em);
  }
}

/*
.c-banner
---------------------------------------------------------------- */
.c-banner {
  display: grid;
  place-items: center start;
  width: 100%;
  border: 1px solid var(--line-black);
  font-weight: 700;
  -webkit-transition: top var(--animation-banner), background-color var(--animation-banner), -webkit-box-shadow var(--animation-banner);
  transition: top var(--animation-banner), background-color var(--animation-banner), -webkit-box-shadow var(--animation-banner);
  transition: top var(--animation-banner), box-shadow var(--animation-banner), background-color var(--animation-banner);
  transition: top var(--animation-banner), box-shadow var(--animation-banner), background-color var(--animation-banner), -webkit-box-shadow var(--animation-banner);
  position: relative;
  top: 0;
}
.c-banner .banner-tag {
  grid-column: 1/2;
  grid-row: 1/2;
}
.c-banner .banner-text {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  line-height: var(--lh-single);
}
.c-banner .banner-icon {
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* --- hover --- */
@media (any-hover: hover) {
  .c-banner:hover {
    top: -1px;
    -webkit-box-shadow: 1px 1px 0px 0px var(--line-black);
            box-shadow: 1px 1px 0px 0px var(--line-black);
    background-color: var(--bg-red--hover);
  }
}
/* === .c-banner.href-web === */
.c-banner.href-web {
  grid-template-columns: -webkit-max-content auto;
  grid-template-columns: max-content auto;
  gap: 0.6666666667em 1em;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: max(1.4dvw, 1rem) max(2dvw, 1rem);
}
.c-banner.href-web .banner-tag {
  font-size: var(--fs-sm);
}
.c-banner.href-web .banner-text {
  grid-column: 1/2;
  grid-row: 2/3;
}
.c-banner.href-web .banner-icon {
  grid-column: 2/3;
  grid-row: 2/3;
  width: 0.6666666667em;
  background-image: url(../assets/images/common/icon-link.svg);
}

/* === .c-banner.href-file === */
.c-banner.href-file {
  grid-template-columns: -webkit-max-content minmax(0, 1fr) auto;
  grid-template-columns: max-content minmax(0, 1fr) auto;
  gap: 0.6666666667em 0.5em;
  padding: max(0.8dvw, 0.75em) max(1.2dvw, 1em);
  font-weight: 500;
}
.c-banner.href-file .banner-tag {
  font-size: var(--fs-xs);
}
.c-banner.href-file .banner-icon {
  width: 0.8333333333em;
  margin-left: 0.5em;
  background-image: url(../assets/images/common/icon-file.svg);
}

/*
.c-desc
---------------------------------------------------------------- */
.c-desc {
  line-height: var(--lh-base);
  text-align: justify;
  -moz-text-align-last: left;
       text-align-last: left;
}
.c-desc p:not(:first-of-type) {
  margin-top: 0.75em;
}

/*
.c-band
---------------------------------------------------------------- */
.c-band {
  display: block;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  height: -webkit-max-content;
  height: -moz-max-content;
  height: max-content;
  padding: 0.3625em 0.725em;
  font-weight: 500;
  color: var(--text-light);
}

/* === .bg-red === */
.c-band.bg-red {
  background-color: var(--bg-red);
}

/* === .bg-gray === */
.c-band.bg-gray--dark {
  background-color: var(--bg-gray--dark);
}

/* === .bg-lightgray === */
.c-band.bg-gray--middle {
  background-color: var(--bg-gray--middle);
  color: var(--text-gray);
}

/* === .role-cat === */
.c-band.role-cat {
  background-color: var(--bg-black);
}

/* === .role-tag === */
.c-band.role-tag {
  color: var(--text-gray);
  border-radius: 62.5rem;
  border: 1px solid var(--line-gray--frame);
}

/*
.c-num
---------------------------------------------------------------- */
.c-num {
  font-family: var(--ff-en-primary);
  color: var(--accent-red);
  position: relative;
}
.c-num::before {
  position: absolute;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  font-size: 0.5em;
  color: var(--text-red);
  bottom: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

/* === .c-num.at-case === */
.c-num.at-case::before {
  content: "case";
}

/* === .c-num.at-flow === */
.c-num.at-flow::before {
  content: "step";
}

/*
.c-bullet
---------------------------------------------------------------- */
.c-bullet {
  padding-left: 1.2em;
  line-height: var(--lh-narrow);
  position: relative;
}
.c-bullet::before {
  content: "";
  display: inline-block;
  width: 0.25em;
  aspect-ratio: 1/1;
  margin-right: 0.5714285714em;
  border-radius: calc(var(--br) * 0.2);
  background-color: var(--bg-black);
  position: absolute;
  top: calc(1em * var(--lh-narrow) / 2 - 0.125em);
  left: 0.375em;
}

/*
.c-order
---------------------------------------------------------------- */
.c-order {
  padding-left: 1.75em;
  line-height: var(--lh-narrow);
  position: relative;
  counter-increment: num-count;
}
.c-order::before {
  content: "(" counter(num-count, number) ")";
  display: inline-block;
  font-family: var(--ff-en-primary);
  font-size: 1.0625em;
  color: var(--accent-red);
  position: absolute;
  left: 0;
}
.c-order .order-list.in-order-list > .c-order {
  padding-left: 1.75em;
  counter-increment: alpha-count;
}
.c-order .order-list.in-order-list > .c-order::before {
  content: "(" counter(alpha-count, lower-alpha) ")";
  font-size: 0.9375em;
  color: var(--text-black);
}

/*
.c-note
---------------------------------------------------------------- */
/*
.c-tel
---------------------------------------------------------------- */
.c-tel {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.c-tel .tel-num {
  display: inline-block;
  font-family: var(--ff-en-primary);
  font-weight: 700;
  white-space: nowrap;
}
.c-tel .tel-num .icon {
  font-size: 0.6em;
  margin-right: 0.4em;
}
.c-tel .tel-num span {
  display: inline-block;
}
.c-tel .tel-num a {
  color: inherit;
}
@media (any-hover: hover) {
  .c-tel .tel-num a:hover {
    pointer-events: none;
  }
}
.c-tel .tel-info {
  margin-top: 1.4285714286em;
  font-size: max(0.35em, 0.625rem);
}
.c-tel .tel-info-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 0.4285714286em;
  font-weight: 500;
}
.c-tel .tel-info-item dt::before {
  content: "(";
  display: inline-block;
  margin-right: 0.4285714286em;
}
.c-tel .tel-info-item dd::after {
  content: ")";
  display: inline-block;
  margin-left: 0.4285714286em;
}

/*
.c-lg-title
---------------------------------------------------------------- */
.c-lg-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  font-size: var(--fs-lg-title--ja);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.c-lg-title .en {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5818181818em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 1.7454545455em;
  font-family: var(--ff-en-primary);
  font-size: var(--fs-lg-title--en);
  font-weight: 700;
  color: var(--accent-red);
}
.c-lg-title .en::before {
  content: "";
  display: inline-block;
  width: 0.5818181818em;
  aspect-ratio: 1/1;
  border-radius: calc(var(--br) * 0.5);
  background-color: var(--accent-red);
}
.c-lg-title .ja {
  font-weight: 500;
}
@media screen and (max-width: 575px) {
  .c-lg-title .ja.text-long {
    line-height: var(--lh-narrow);
  }
}

/* --- .c-lg-title.is-light --- */
.c-lg-title.is-light .en,
.c-lg-title.is-light .ja {
  color: var(--text-light);
}
.c-lg-title.is-light .en::before {
  background-color: var(--bg-base);
}

/* --- .c-lg-title.text-topics --- */
.c-lg-title.text-topics .ja {
  margin-left: -0.25em;
  letter-spacing: var(--ls-min);
}

/* --- .c-lg-title.text-tour --- */
.c-lg-title.text-tour .ja {
  letter-spacing: -0.025em;
}

/*
.c-md-title
---------------------------------------------------------------- */
.c-md-title {
  font-size: var(--fs-md-title);
  font-weight: 500;
  color: var(--text-gray);
  position: relative;
}

/*
.c-logo-set
---------------------------------------------------------------- */
.c-logo-set a {
  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;
  height: 100%;
  -webkit-transition: opacity var(--animation-button);
  transition: opacity var(--animation-button);
}
.c-logo-set {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .c-logo-set a:hover {
    opacity: 0.7;
  }
}
.c-logo-set .logo-main {
  width: 75.7%;
}
.c-logo-set .logo-anniversary {
  width: 17.9%;
}

/*
.c-card
---------------------------------------------------------------- */
/* ---------- screen ~992px, 575px~ ---------- */
.c-card {
  display: grid;
  height: 100%;
  padding: var(--vertical--60) 0;
  position: relative;
  -webkit-transition: background-color var(--animation-button);
  transition: background-color var(--animation-button);
  container: c-card/inline-size;
}
.c-card::before {
  content: "";
  display: block;
  max-width: calc(var(--container-max) / 2);
  width: calc(100% - var(--container-pd));
  height: 1px;
  background-color: var(--line-black);
  position: absolute;
  bottom: 0;
}
.c-card::after {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: var(--line-black);
  position: absolute;
  top: 0;
  right: 0;
}
.c-card:has(> a) {
  padding: 0;
}
.c-card:has(> a) > a {
  padding: var(--vertical--60) 0;
}
.c-card .card-inner {
  width: max(38dvw + var(--container-pd) * 2, 760px + var(--container-pd) * 2);
  height: 100%;
  margin-inline: auto;
  padding-inline: var(--container-pd);
  position: relative;
}
@media screen and (max-width: 1839px) {
  .c-card .card-inner {
    width: 100%;
  }
}
.c-card {
  /* .card-decoration */
}
.c-card .card-decoration {
  display: none;
}
.c-card .pic {
  width: 100%;
  overflow: hidden;
  aspect-ratio: 3/2;
}
.c-card .pic img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}
.c-card {
  /* .card-text */
}
.c-card .card-text {
  display: grid;
}
.c-card .title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: max(1dvw, 0.4em);
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  font-size: max(1.8dvw, 1.375rem);
  line-height: var(--lh-min);
}
.c-card .name {
  font-weight: 700;
}
.c-card .desc {
  font-weight: 500;
}

/* === .c-card.role-link === */
.c-card.role-link:nth-child(2n-1)::before {
  right: 0;
}
.c-card.role-link:nth-child(2n-1) .card-inner {
  margin-left: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
}
@media screen and (min-width: 2001px) {
  .c-card.role-link:nth-child(2n-1) .card-inner {
    margin-right: 2dvw;
  }
}
@media screen and (max-width: 1839px) {
  .c-card.role-link:nth-child(2n-1) .card-inner {
    margin-right: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
  }
}
@media screen and (max-width: 1759px) {
  .c-card.role-link:nth-child(2n-1) .card-inner {
    margin-left: 0;
    margin-right: 0;
    margin-inline: 0;
  }
}
.c-card.role-link:nth-child(2n)::before {
  left: 0;
}
.c-card.role-link:nth-child(2n)::after {
  display: none;
}
.c-card.role-link:nth-child(2n) .card-inner {
  margin-right: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
}
@media screen and (min-width: 2001px) {
  .c-card.role-link:nth-child(2n) .card-inner {
    margin-left: 2dvw;
  }
}
@media screen and (max-width: 1839px) {
  .c-card.role-link:nth-child(2n) .card-inner {
    margin-left: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
  }
}
@media screen and (max-width: 1759px) {
  .c-card.role-link:nth-child(2n) .card-inner {
    margin-inline: 0;
  }
}
.c-card.role-link .card-decoration {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-family: var(--ff-en-primary);
  font-size: var(--fs-sm);
  font-weight: 500;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  color: var(--accent-red);
  position: absolute;
  top: 1.875rem;
}
.c-card.role-link:nth-child(2n-1) .card-decoration {
  left: 3%;
}
.c-card.role-link:nth-child(2n) .card-decoration {
  right: 3%;
}
.c-card.role-link .subtitle {
  font-size: max(1.2dvw, 1rem);
}
.c-card.role-link {
  /* .card-text */
}
.c-card.role-link .card-text {
  grid-template-columns: minmax(0, 1fr) max(2.6dvw, 1.75rem);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0 1.25rem;
}
.c-card.role-link .title {
  grid-column: 1/2;
  grid-row: 1/2;
  margin: 1.1111111111em 0 1em;
  margin: 0.8em 0 1em;
}
.c-card.role-link .desc {
  grid-column: 1/2;
  grid-row: 2/3;
}
.c-card.role-link .arrow {
  grid-column: 2/3;
  grid-row: 1/3;
  align-self: center;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}
@container c-card (max-width: 599.5px) {
  .c-card.role-link .card-text {
    grid-template-columns: 100%;
  }
  .c-card.role-link .arrow {
    width: max(2.6dvw, 1.5rem);
    position: absolute;
    top: 100%;
    right: var(--container-pd);
  }
}

/* === .c-card.at-event === */
.c-card.at-event:nth-child(3n-2)::before {
  right: 0;
}
.c-card.at-event:nth-child(3n-2) .card-inner {
  margin-left: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
}
@media screen and (min-width: 2001px) {
  .c-card.at-event:nth-child(3n-2) .card-inner {
    margin-right: 2dvw;
  }
}
@media screen and (max-width: 1839px) {
  .c-card.at-event:nth-child(3n-2) .card-inner {
    margin-right: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
  }
}
@media screen and (max-width: 1759px) {
  .c-card.at-event:nth-child(3n-2) .card-inner {
    margin-inline: 0;
  }
}
.c-card.at-event:nth-child(3n-1)::after, .c-card.at-event:nth-child(3n)::after {
  display: none;
}
.c-card.at-event:nth-child(3n-1) .card-inner, .c-card.at-event:nth-child(3n) .card-inner {
  margin-right: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
}
@media screen and (min-width: 2001px) {
  .c-card.at-event:nth-child(3n-1) .card-inner, .c-card.at-event:nth-child(3n) .card-inner {
    margin-left: 2dvw;
  }
}
@media screen and (max-width: 1839px) {
  .c-card.at-event:nth-child(3n-1) .card-inner, .c-card.at-event:nth-child(3n) .card-inner {
    margin-left: calc((100dvw - (var(--container-max) + var(--container-pd) * 2)) / 2);
  }
}
@media screen and (max-width: 1759px) {
  .c-card.at-event:nth-child(3n-1) .card-inner, .c-card.at-event:nth-child(3n) .card-inner {
    margin-inline: 0;
  }
}
.c-card.at-event {
  /* .card-text */
}
.c-card.at-event .card-text {
  margin-top: 1.5em;
}
.c-card.at-event .title {
  margin: 0.5em 0 0.75em;
}
.c-card.at-event .detail-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  margin-top: 1em;
}
.c-card.at-event .detail-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5em;
}
.c-card.at-event .detail-item dd {
  color: var(--text-gray);
  font-weight: 500;
}

.c-card.at-event.column-2 .card-inner {
  display: grid;
  grid-template-columns: 40% minmax(0, 1fr);
  grid-template-rows: -webkit-max-content auto minmax(0, 1fr);
  grid-template-rows: max-content auto minmax(0, 1fr);
  -webkit-column-gap: max(1.5dvw, 1.25rem);
     -moz-column-gap: max(1.5dvw, 1.25rem);
          column-gap: max(1.5dvw, 1.25rem);
}
.c-card.at-event.column-2 .pic {
  grid-column: 1/2;
  grid-row: 1/3;
  aspect-ratio: 1/1;
}
.c-card.at-event.column-2 {
  /* .card-text */
}
.c-card.at-event.column-2 .card-text {
  grid-column: 2/3;
  height: -webkit-min-content;
  height: -moz-min-content;
  height: min-content;
  margin-top: 0;
}
.c-card.at-event.column-2 .title {
  font-size: max(1.4dvw, 1.25rem);
}
.c-card.at-event.column-2 {
  /* .br-control */
}
.c-card.at-event.column-2 .br-control {
  display: none;
}

/* ---------- screen ~1150px ---------- */
@media screen and (max-width: 1150px) {
  /* === .c-card.at-event === */
  .c-card.at-event::before {
    max-width: 100%;
    width: calc(100% - var(--container-pd) * 2);
  }
  .c-card.at-event::after {
    display: none;
  }
  .c-card.at-event:nth-child(3n-2)::before, .c-card.at-event:nth-child(3n-1)::before {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    right: initial;
    left: 50%;
  }
  .c-card.at-event:nth-child(3n)::before {
    display: none;
  }
}
/* ---------- screen ~991px ---------- */
@media screen and (max-width: 991px) {
  .c-card::before {
    max-width: 100%;
    width: calc(100% - var(--container-pd) * 2);
  }
  .c-card::after {
    display: none;
  }
  /* === .c-card.role-link === */
  .c-card.role-link:nth-child(2n-1)::before, .c-card.role-link:nth-child(2n)::before {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    right: initial;
    left: 50%;
  }
}
/* ---------- screen 576~1150px ---------- */
@media screen and (max-width: 1150px) and (min-width: 576px) {
  /* === .c-card.at-event === */
  .c-card.at-event .card-inner,
  .c-card.at-event.column-2 .card-inner {
    display: grid;
    grid-template-columns: 40% minmax(0, 1fr);
    -webkit-column-gap: max(2.8254288597dvw, 1.25rem);
       -moz-column-gap: max(2.8254288597dvw, 1.25rem);
            column-gap: max(2.8254288597dvw, 1.25rem);
    width: 100%;
  }
  .c-card.at-event .pic,
  .c-card.at-event.column-2 .pic {
    grid-column: 1/2;
    grid-row: 1/3;
    aspect-ratio: 3/2;
  }
  .c-card.at-event,
  .c-card.at-event.column-2 {
    /* .card-text */
  }
  .c-card.at-event .card-text,
  .c-card.at-event.column-2 .card-text {
    grid-column: 2/3;
    height: -webkit-min-content;
    height: -moz-min-content;
    height: min-content;
    margin-top: 0;
  }
  .c-card.at-event .title,
  .c-card.at-event.column-2 .title {
    font-size: 1.75rem;
  }
  .c-card.at-event,
  .c-card.at-event.column-2 {
    /* .br-control */
  }
  .c-card.at-event .br-control,
  .c-card.at-event.column-2 .br-control {
    display: none;
  }
  @container c-card (max-width: 991px) {
    .c-card.at-event .pic,
    .c-card.at-event.column-2 .pic {
      aspect-ratio: 1/1;
    }
    .c-card.at-event .title,
    .c-card.at-event.column-2 .title {
      font-size: max(2.8254288597dvw, 1.25rem);
    }
  }
}
/* ---------- screen 576~991px ---------- */
@media screen and (max-width: 991px) and (min-width: 576px) {
  .c-card {
    padding: var(--vertical--60) 0;
  }
  /* === .c-card.role-link === */
  .c-card.role-link .card-decoration {
    top: var(--vertical--60);
  }
  .c-card.role-link:nth-child(2n-1) .card-decoration, .c-card.role-link:nth-child(2n) .card-decoration {
    left: 0.1%;
  }
  .c-card.role-link .card-inner {
    display: grid;
    grid-template-columns: 40% minmax(0, 1fr);
    grid-template-rows: -webkit-max-content minmax(0, 1fr);
    grid-template-rows: max-content minmax(0, 1fr);
    -webkit-column-gap: max(2.8254288597dvw, 1.5rem);
       -moz-column-gap: max(2.8254288597dvw, 1.5rem);
            column-gap: max(2.8254288597dvw, 1.5rem);
  }
  .c-card.role-link .br-lg-md {
    display: block;
  }
  .c-card.role-link .subtitle {
    grid-column: 2/3;
    grid-row: 1/2;
    font-size: max(1.8163471241dvw, 1rem);
  }
  .c-card.role-link .pic {
    grid-column: 1/2;
    grid-row: 1/3;
    aspect-ratio: 1/1;
    margin-top: 0;
  }
  .c-card.role-link {
    /* .card-text */
  }
  .c-card.role-link .card-text {
    grid-template-columns: auto;
    grid-template-rows: -webkit-max-content minmax(0, 1fr);
    grid-template-rows: max-content minmax(0, 1fr);
    grid-column: 2/3;
    grid-row: 2/3;
    height: 100%;
    position: relative;
  }
  .c-card.role-link .title {
    font-size: max(2.8254288597dvw, 1.25rem);
  }
  .c-card.role-link .arrow {
    width: max(3.6326942482dvw, 1.5rem);
    position: absolute;
    top: calc(100% - max(3.6326942482dvw, 1.5rem) * 14 / 24);
    right: 0;
  }
  .c-card.role-link {
    /* .br-control */
  }
  .c-card.role-link .br-control {
    display: none;
  }
  @container c-card (max-width: 767px) {
    .c-card.role-link .card-inner {
      width: 100%;
    }
  }
}
/* ---------- screen ~576px ---------- */
@media screen and (max-width: 575px) {
  .c-card .subtitle,
  .c-card.role-link .subtitle,
  .c-card.at-event .subtitle,
  .c-card.at-event.column-2 .subtitle {
    font-size: max(2.7826086957dvw, 0.875rem);
  }
  .c-card .title,
  .c-card.role-link .title,
  .c-card.at-event .title,
  .c-card.at-event.column-2 .title {
    font-size: max(4.8695652174dvw, 1.125rem);
  }
  .c-card .br-control,
  .c-card.role-link .br-control,
  .c-card.at-event .br-control,
  .c-card.at-event.column-2 .br-control {
    display: none;
  }
  /* === .c-card.role-link === */
  .c-card.role-link:has(> a) > a {
    padding-bottom: calc(var(--vertical--60) * 1.5);
  }
  .c-card.role-link .card-decoration {
    top: var(--vertical--60);
  }
  .c-card.role-link:nth-child(2n-1) .card-decoration {
    left: 0;
  }
  .c-card.role-link:nth-child(2n) .card-decoration {
    right: 0;
  }
  .c-card.role-link .arrow {
    width: max(2.6dvw, 1.5rem);
    position: absolute;
    top: calc(100% + 1rem);
    right: var(--container-pd);
  }
  /* === .c-card.at-event === */
  .c-card.at-event:nth-child(3n-1)::before {
    width: calc(100% - var(--container-pd) * 2);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    left: 50%;
  }
  /* === .c-card.at-event.column-2 === */
  .c-card.at-event.column-2 {
    display: grid;
    height: 100%;
    padding: var(--vertical--60) 0;
  }
  .c-card.at-event.column-2 .card-inner {
    grid-template-columns: 100%;
  }
  .c-card.at-event.column-2 .pic {
    grid-row: 1/2;
    aspect-ratio: 3/2;
  }
  .c-card.at-event.column-2 .card-text {
    grid-column: 1/2;
    grid-row: 2/3;
    margin-top: 1.5em;
  }
}
/* --- hover --- */
@media (any-hover: hover) {
  .c-card:has(a):hover {
    background-color: var(--bg-red--hover);
  }
  .c-card:has(a):hover .pic img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .c-card:has(a):hover .arrow {
    -webkit-transform: translateX(4px);
            transform: translateX(4px);
  }
}
/* --- .card-decoration --- */
.card-item:nth-child(n) .c-card .card-decoration {
  top: 1.875rem;
}

.card-item:nth-child(n-1) .c-card .card-decoration {
  left: 1.875rem;
}

.card-item:nth-child(2n) .c-card .card-decoration {
  left: initial;
  right: 1.875rem;
}

/*
.c-tags
---------------------------------------------------------------- */
.c-tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5rem 0.25rem;
}

/*
.c-text-link
---------------------------------------------------------------- */
.c-text-link {
  position: relative;
}
.c-text-link::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--line-black);
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transform-origin: left;
          transform-origin: left;
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
  position: absolute;
  bottom: -1px;
  left: 0;
}
.c-text-link {
  /* --- hover ---*/
}
@media (any-hover: hover) {
  .c-text-link:hover::before {
    -webkit-transform: scale(0);
            transform: scale(0);
    -webkit-transform-origin: right;
            transform-origin: right;
  }
}

/*
.c-paging
---------------------------------------------------------------- */
.c-paging {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.75em;
  font-family: var(--ff-en-primary);
  font-size: max(1.2dvw, 1.125rem);
  font-weight: 200;
}
.c-paging .paging-text {
  position: relative;
}
.c-paging .paging-text::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--line-black);
  -webkit-transform: scale(0);
          transform: scale(0);
  -webkit-transform-origin: right;
          transform-origin: right;
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
  position: absolute;
  bottom: -2px;
  left: 0;
}
@media (any-hover: hover) {
  .c-paging .paging-text:has(.num) {
    cursor: pointer;
  }
  .c-paging .paging-text:has(.num):hover::before {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: left;
            transform-origin: left;
  }
}
.c-paging .paging-text.current::before {
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transform-origin: left;
          transform-origin: left;
}
.c-paging .paging-arrow .arrow {
  width: 1.75em;
}

/*
section.c-separate-line
---------------------------------------------------------------- */
section.c-separate-line {
  position: relative;
}
section.c-separate-line::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--line-black);
  position: absolute;
  top: 0;
  left: 0;
}

/*
.c-indicator-arrow
---------------------------------------------------------------- */
.c-indicator-arrow .arrow {
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: var(--bg-gray--middle);
  background-image: url(../assets/images/common/icon-indicator-arrow.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 13.3928571429%;
  -webkit-transition: background-color var(--animation-button), -webkit-transform var(--animation-button);
  transition: background-color var(--animation-button), -webkit-transform var(--animation-button);
  transition: background-color var(--animation-button), transform var(--animation-button);
  transition: background-color var(--animation-button), transform var(--animation-button), -webkit-transform var(--animation-button);
  cursor: pointer;
}
.c-indicator-arrow .arrow.prev {
  scale: -1 1;
}
@media (any-hover: hover) {
  .c-indicator-arrow .arrow:hover {
    background-color: var(--bg-red);
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
}

/*
.c-back-to-top
---------------------------------------------------------------- */
.c-back-to-top {
  width: 40px;
  aspect-ratio: 1/1;
  border-radius: var(--br-base);
  background-color: var(--bg-gray--dark);
  -webkit-transition: background-color var(--animation-button);
  transition: background-color var(--animation-button);
  opacity: 0;
  visibility: hidden;
  position: fixed;
  z-index: var(--z-back-to-top);
  bottom: 20px;
  right: max(3dvw, 20px);
}
.c-back-to-top > .arrow {
  width: 20%;
  position: absolute;
  rotate: -90deg;
  top: calc(32.5% - 1px);
  left: 40%;
}
@media (any-hover: hover) {
  .c-back-to-top:hover {
    background-color: var(--accent-red);
  }
}
.c-back-to-top.is-fixed {
  -webkit-animation: BtTAppear var(--animation-button) forwards;
          animation: BtTAppear var(--animation-button) forwards;
}
@-webkit-keyframes BtTAppear {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  100% {
    opacity: 1;
    visibility: visible;
  }
}
@keyframes BtTAppear {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  100% {
    opacity: 1;
    visibility: visible;
  }
}

/*
.c-scroll-box
---------------------------------------------------------------- */
.c-scroll-box {
  padding: max(2dvw, 1.5rem) max(1.5dvw, 1rem);
  border-radius: calc(var(--br-base) * 5);
  background-color: var(--bg-gray--light);
}
.c-scroll-box:has(> .inner) {
  padding-right: max(0.6dvw, 0.5rem);
}
.c-scroll-box > .inner {
  height: 100%;
  min-height: 0;
  padding-right: 20px;
  overflow-y: auto;
}
.c-scroll-box > .inner::-webkit-scrollbar {
  width: 16px;
}
.c-scroll-box > .inner::-webkit-scrollbar-thumb {
  border-radius: 9999px;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  background-color: var(--accent-red);
  background-clip: padding-box;
}
.c-scroll-box > .inner::-webkit-scrollbar-track {
  background-color: var(--scroll-box);
}

@media screen and (max-width: 767px) {
  .c-scroll-box > .inner {
    padding-right: 12px;
  }
  .c-scroll-box > .inner::-webkit-scrollbar {
    width: 8px;
  }
  .c-scroll-box > .inner::-webkit-scrollbar-thumb {
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 2px solid transparent;
    border-right: 2px solid transparent;
  }
}
/*
.c-table
---------------------------------------------------------------- */
.c-table {
  width: 100%;
  line-height: var(--lh-narrow);
  table-layout: auto;
  border-collapse: separate;
  border-spacing: 0.75em 0;
  font-size: var(--fs-md);
}
.c-table thead th.table-title {
  padding: 1em;
  background-color: var(--bg-black);
  color: var(--text-light);
  text-align: center;
}
.c-table th,
.c-table td {
  padding: 1.5em 1em;
  vertical-align: middle;
}
.c-table th {
  width: 0;
  font-weight: 500;
  white-space: nowrap;
}

@media screen and (max-width: 575px) {
  .c-table {
    border-spacing: 0;
  }
  .c-table th,
  .c-table td {
    display: block;
    width: 100%;
  }
  .c-table td {
    padding-top: 1.25em;
  }
}
/* === .c-table.role-table === */
.c-table.role-table td {
  border-bottom: 1px solid var(--line-gray--separate);
}

@media screen and (max-width: 575px) {
  .c-table.role-table th {
    padding-bottom: 0;
    border: none;
    position: relative;
  }
}
/* === .c-table.role-form === */
.c-table.role-form {
  max-width: var(--container--md);
  margin-inline: auto;
  border-spacing: 0.75em 0.25em;
  font-size: max(0.8dvw, 1rem);
}
.c-table.role-form th {
  background-color: var(--bg-gray--middle);
}
.c-table.role-form .need::after {
  content: "*";
  color: var(--accent-red);
}
.c-table.role-form .note {
  display: block;
  margin-top: 0.5em;
  font-size: 0.75em;
  font-weight: 400;
}
.c-table.role-form label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  cursor: pointer;
  position: relative;
}
.c-table.role-form input:not([type=file]),
.c-table.role-form textarea,
.c-table.role-form select {
  display: inline-block;
  padding: 0.25em 0.5em;
  border: 1px solid var(--line-gray--input);
  border-radius: var(--br-base);
  -webkit-transition: background-color var(--animation-input), border var(--animation-input);
  transition: background-color var(--animation-input), border var(--animation-input);
  cursor: pointer;
}
.c-table.role-form {
  /* input[type="file"] */
}
.c-table.role-form input[type=file]::-webkit-file-upload-button {
  padding: 0.25em 0.5em;
  border: 1px solid var(--line-gray--input);
  border-radius: var(--br-base);
  background-color: var(--bg-gray--light);
  -webkit-transition: background-color var(--animation-input), border var(--animation-input);
  transition: background-color var(--animation-input), border var(--animation-input);
  cursor: pointer;
}
.c-table.role-form input[type=file]::file-selector-button {
  padding: 0.25em 0.5em;
  border: 1px solid var(--line-gray--input);
  border-radius: var(--br-base);
  background-color: var(--bg-gray--light);
  -webkit-transition: background-color var(--animation-input), border var(--animation-input);
  transition: background-color var(--animation-input), border var(--animation-input);
  cursor: pointer;
}
.c-table.role-form {
  /* input[type="date"] */
}
.c-table.role-form input[type=date] {
  position: relative;
  min-width: 10em;
  min-height: 2em;
  padding-right: 2em;
  color: var(--text-dark);
  vertical-align: middle;
}
.c-table.role-form input[type=date].is-blank::before {
  content: attr(placeholder);
  display: block;
  width: calc(100% - 2em);
  font-size: var(--fs-sm);
  line-height: 2;
  color: var(--text-gray);
  white-space: nowrap;
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 0.5em;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.c-table.role-form input[type=date]:not(.is-blank)::before {
  content: none;
}
.c-table.role-form input[type=date]::-webkit-datetime-edit-fields-wrapper {
  display: -webkit-inline-box;
  display: inline-flex;
  -webkit-box-pack: start;
          justify-content: flex-start;
}
.c-table.role-form input[type=date]::-webkit-date-and-time-value {
  text-align: left;
}
.c-table.role-form input[type=date].is-blank::-webkit-datetime-edit {
  display: none;
}
.c-table.role-form input[type=date]:not(.is-blank)::-webkit-datetime-edit {
  color: var(--text-dark);
}
.c-table.role-form input[type=date]::-webkit-calendar-picker-indicator {
  width: 100%;
  height: 100%;
  position: absolute;
  opacity: 0;
  top: 0;
  left: 0;
  cursor: pointer;
}
.c-table.role-form input[type=date]::after {
  content: "";
  display: inline-block;
  width: 0.8em;
  aspect-ratio: 1/1;
  background-image: url(../assets/images/quotation/icon-calendar.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: 50%;
  right: 0.5em;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  pointer-events: none;
}
.c-table.role-form input[type=date]:focus-within {
  background-color: var(--bg-red--hover);
  border: 1px solid var(--line-red--focus);
}
.c-table.role-form {
  /* Firefox */
}
@-moz-document url-prefix() {
  .c-table.role-form input[type=date]::after {
    content: "";
    display: inline-block;
    width: 0.8em;
    aspect-ratio: 1/1;
    background-image: url(../assets/images/quotation/icon-calendar.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    position: absolute;
    top: 50%;
    right: 0.5em;
    transform: translateY(-50%);
    pointer-events: none;
  }
}
.c-table.role-form {
  /* input[type="file"] */
}
.c-table.role-form input:not([type=file]):focus,
.c-table.role-form textarea:focus {
  outline: none;
  background-color: var(--bg-red--hover);
  border: 1px solid var(--line-red--focus);
}
@media (any-hover: hover) {
  .c-table.role-form input:not([type=file]):hover,
  .c-table.role-form textarea:hover,
  .c-table.role-form select:hover {
    outline: none;
    background-color: var(--bg-red--hover);
    border: 1px solid var(--line-red--focus);
  }
  .c-table.role-form input[type=file]:hover::-webkit-file-upload-button {
    background-color: var(--bg-red--hover);
    border: 1px solid var(--line-red--focus);
  }
  .c-table.role-form input[type=file]:hover::file-selector-button {
    background-color: var(--bg-red--hover);
    border: 1px solid var(--line-red--focus);
  }
}
.c-table.role-form .label-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.75em 1.5em;
}
.c-table.role-form .label-container.for-vertical {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}
.c-table.role-form .label-container:has(> .date-label) {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}
.c-table.role-form .radio-choice,
.c-table.role-form .checkbox-choice {
  display: block;
  position: relative;
  padding-left: 1.5em;
  white-space: nowrap;
  line-height: var(--lh-single);
}
.c-table.role-form {
  /* checkbox */
}
.c-table.role-form input[type=checkbox] {
  opacity: 0;
  width: 100%;
  height: 100%;
  position: absolute;
}
.c-table.role-form .checkbox-choice::before {
  content: "";
  display: block;
  width: 1em;
  aspect-ratio: 1/1;
  background-color: var(--bg-base);
  border: 1px solid var(--line-gray--input);
  -webkit-transition: background-color var(--animation-input), border var(--animation-input);
  transition: background-color var(--animation-input), border var(--animation-input);
  position: absolute;
  left: 0;
}
.c-table.role-form .checkbox-choice::after {
  content: "";
  display: block;
  width: 0.75em;
  aspect-ratio: 1.75/1;
  border-left: 0.15em solid var(--accent-red);
  border-bottom: 0.15em solid var(--accent-red);
  rotate: -45deg;
  opacity: 0;
  -webkit-transition: opacity var(--animation-input);
  transition: opacity var(--animation-input);
  position: absolute;
  top: 0.2em;
  left: 0.125em;
}
.c-table.role-form {
  /* radio */
}
.c-table.role-form input[type=radio] {
  opacity: 0;
  width: 100%;
  height: 100%;
  position: absolute;
}
.c-table.role-form .radio-choice::before {
  content: "";
  width: 1em;
  aspect-ratio: 1/1;
  background-color: var(--bg-base);
  border: 1px solid var(--line-gray--input);
  border-radius: 50%;
  -webkit-transition: background-color var(--animation-input), border var(--animation-input);
  transition: background-color var(--animation-input), border var(--animation-input);
  position: absolute;
  top: 0.125em;
  left: 0;
}
.c-table.role-form .radio-choice::after {
  content: "";
  width: 0.6em;
  aspect-ratio: 1/1;
  background-color: var(--accent-red);
  border-radius: 50%;
  opacity: 0;
  -webkit-transition: opacity var(--animation-input);
  transition: opacity var(--animation-input);
  position: absolute;
  top: 0.325em;
  left: 0.2em;
}
.c-table.role-form {
  /* --- input[type="radio, checkbox"]:hover --- */
}
@media (any-hover: hover) {
  .c-table.role-form input[type=radio]:hover + .radio-choice::before,
  .c-table.role-form input[type=radio]:hover + .checkbox-choice::before,
  .c-table.role-form input[type=checkbox]:hover + .radio-choice::before,
  .c-table.role-form input[type=checkbox]:hover + .checkbox-choice::before {
    background-color: var(--bg-red--hover);
    border: 1px solid var(--line-red--focus);
  }
}
.c-table.role-form {
  /* --- input[type="radio, checkbox"]:checked --- */
}
.c-table.role-form input[type=radio]:checked + .radio-choice::before,
.c-table.role-form input[type=checkbox]:checked + .checkbox-choice::before {
  border: 1px solid var(--accent-red);
}
.c-table.role-form input[type=radio]:checked + .radio-choice::after,
.c-table.role-form input[type=checkbox]:checked + .checkbox-choice::after {
  opacity: 1;
}
.c-table.role-form {
  /* input[type="text, tel, email"] */
}
.c-table.role-form input[type=text],
.c-table.role-form input[type=tel],
.c-table.role-form input[type=email] {
  width: 15em;
}
.c-table.role-form {
  /* input[type="number"] */
}
.c-table.role-form input[type=number] {
  width: 6em;
}
.c-table.role-form {
  /* textarea */
}
.c-table.role-form textarea {
  width: 100%;
  height: calc(10em * var(--lh-base));
  padding: 0.5em;
}
@media screen and (max-width: 991px) {
  .c-table.role-form textarea {
    height: calc(15em * var(--lh-base));
  }
}
.c-table.role-form .textarea {
  position: relative;
  z-index: 10;
}
.c-table.role-form .placeholder {
  width: 100%;
  height: 100%;
  opacity: 0.7;
  position: absolute;
  z-index: -10;
  top: 0;
  left: 0;
  color: var(--text-gray);
  padding: 2em 1.75em;
}
.c-table.role-form .placeholder > .inner {
  height: 100%;
  overflow: hidden;
}
.c-table.role-form .placeholder.is-hidden {
  display: none;
}
.c-table.role-form .example-list {
  margin-top: 0.5em;
  line-height: var(--lh-narrow);
}
.c-table.role-form .example-list .example-item {
  padding-left: 1em;
  text-indent: -1em;
}
.c-table.role-form .example-list .example-item:not(:first-child) {
  margin-top: 0.5em;
}
.c-table.role-form {
  /* select */
}
.c-table.role-form select {
  -webkit-appearance: base-select;
     -moz-appearance: base-select;
          appearance: base-select;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5em;
}
.c-table.role-form select:open {
  background-color: var(--bg-red--hover);
  border: 1px solid var(--line-red--focus);
}
.c-table.role-form select::picker-icon {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 0.4em solid transparent;
  border-left: 0.4em solid transparent;
  border-top: 0.5em solid var(--line-gray--frame);
  border-bottom: 0 solid transparent;
  border-radius: var(--br-base);
}
.c-table.role-form ::picker(select) {
  -webkit-appearance: base-select;
     -moz-appearance: base-select;
          appearance: base-select;
  padding: 0.5em;
  background-color: var(--bg-base);
  border: 1px solid var(--line-black);
}

@media screen and (max-width: 575px) {
  .c-table.role-form {
    border-spacing: 0 0.25em;
  }
  .c-table.role-form td {
    padding-inline: 0;
  }
  .c-table.role-form input[type=text],
  .c-table.role-form input[type=tel],
  .c-table.role-form input[type=email] {
    width: 100%;
  }
}
/*
.c-lead-area
---------------------------------------------------------------- */
.c-lead-area {
  margin-inline: calc(50% - 50dvw);
  padding: var(--vertical--120) calc(50dvw - 50%);
  background-color: var(--bg-yellow);
}

/*
.c-anchor-list
---------------------------------------------------------------- */
.c-anchor-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.c-anchor-list .anchor-item > a {
  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;
  -webkit-column-gap: 0.4em;
     -moz-column-gap: 0.4em;
          column-gap: 0.4em;
  width: 100%;
  height: 100%;
  padding: 0.75em 1em;
  font-weight: 500;
  -webkit-transition: background-color var(--animation-button);
  transition: background-color var(--animation-button);
}
.c-anchor-list .text {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.c-anchor-list .icon {
  display: grid;
  place-content: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 0.6em;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}
.c-anchor-list .icon img {
  margin-top: 0.1em;
}
.c-anchor-list {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .c-anchor-list .anchor-item > a:hover {
    background-color: var(--bg-red--hover);
  }
  .c-anchor-list .anchor-item > a:hover .icon {
    -webkit-transform: translateY(2px);
            transform: translateY(2px);
  }
}

@media screen and (max-width: 767px) {
  .c-anchor-list {
    grid-template-columns: repeat(auto-fit, minmax(46dvw, 1fr));
  }
}
/*
.c-dropdown
---------------------------------------------------------------- */
.c-dropdown {
  display: grid;
  grid-template-rows: minmax(0, 0fr);
  overflow: hidden;
  font-size: var(--fs-sm);
  -webkit-transition: grid-template-rows var(--animation-dropdown);
  transition: grid-template-rows var(--animation-dropdown);
  transition: grid-template-rows var(--animation-dropdown), -ms-grid-rows var(--animation-dropdown);
}
.c-dropdown > .inner {
  padding-top: var(--header-padding--vertical);
}
.c-dropdown .dropdown-list {
  padding: 1.5em;
  border: 1px solid var(--line-black);
  background-color: var(--bg-base);
}
.c-dropdown .dropdown-item {
  border-bottom: 1px solid var(--line-gray--separate);
}
.c-dropdown .dropdown-item:last-child {
  border-bottom: none;
}
.c-dropdown .dropdown-item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 0.75em;
     -moz-column-gap: 0.75em;
          column-gap: 0.75em;
  width: 100%;
  padding: 1.25em 0.5em;
  -webkit-transition: background-color var(--animation-button);
  transition: background-color var(--animation-button);
}
.c-dropdown .dropdown-item a::before {
  content: "";
  display: inline-block;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 0.4em;
  height: 1px;
  background-color: var(--line-black);
}
.c-dropdown .dropdown-item a > .text {
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}

/* --- .dropdown.is-active */
.dropdown.is-active {
  grid-template-rows: minmax(0, 1fr);
}

/* --- hover --- */
@media (any-hover: hover) {
  .dropdown-item a:hover {
    background-color: var(--bg-red--hover);
  }
  .dropdown-item a:hover > .text {
    -webkit-transform: translateX(0.15em);
            transform: translateX(0.15em);
  }
}
@media screen and (max-width: 1339px) {
  .c-dropdown > .inner {
    padding-top: 0;
    font-size: var(--fs-md);
  }
  .c-dropdown .dropdown-list {
    border: none;
    padding: 0.5em 0;
    background-color: transparent;
  }
}
/*
.c-topics-info
---------------------------------------------------------------- */
.c-topics-info {
  display: grid;
  grid-template-columns: -webkit-max-content auto minmax(0, 1fr);
  grid-template-columns: max-content auto minmax(0, 1fr);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-topics-info .date {
  font-weight: 700;
  color: var(--text-gray);
}
.c-topics-info .category {
  margin-left: 1.4285714286em;
}
.c-topics-info .new {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-left: 0.8571428571em;
  font-weight: 700;
  color: var(--accent-red);
}

/*
.c-history-item
---------------------------------------------------------------- */
.c-history-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  row-gap: var(--space-content);
}
.c-history-item > * {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.c-history-item > .content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: max(2.0181634712dvw, 0.75rem) max(3dvw, 2rem);
}
.c-history-item > .content > .text {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding-left: calc(var(--vertical--90) * 1.5 / 2);
}
.c-history-item .date {
  font-family: var(--ff-en-primary);
  font-size: max(2.4dvw, 2.25rem);
  color: var(--accent-red);
  position: relative;
}
.c-history-item .date::before {
  content: "";
  display: block;
  width: 0.25em;
  aspect-ratio: 1/1;
  background-color: var(--accent-red);
  border-radius: calc(var(--br-base) * 0.5);
  position: absolute;
  top: 0.15em;
  left: calc(var(--vertical--90) * 1.5 / 2 * -1 - 0.125em);
}
.c-history-item .month {
  margin-top: 0.5em;
  font-size: max(0.4166666667em, 0.75rem);
}
.c-history-item .desc {
  margin-top: 1.5em;
  font-weight: 500;
}
.c-history-item .pic {
  display: grid;
  place-content: center;
  position: relative;
  width: 100%;
}
.c-history-item .pic img {
  width: 100%;
  aspect-ratio: 4/3;
  position: absolute;
  left: 0;
}
.c-history-item .pic.pic-logo img {
  width: max(12dvw, 11.25rem);
  aspect-ratio: initial;
  left: calc(max(6dvw, 7rem) * -1);
}
.c-history-item .pic.pic-anniversary img {
  width: max(6.5dvw, 6.25rem);
  aspect-ratio: initial;
  bottom: -25%;
}

@media screen and (max-width: 991px) {
  .c-history-item .content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .c-history-item .pic {
    place-content: start;
    padding-left: calc(var(--vertical--90) * 1.5 / 2);
  }
  .c-history-item .pic img {
    position: static;
  }
  .c-history-item .pic.pic-logo img {
    width: 11.25rem;
  }
}
@media screen and (max-width: 575px) {
  .c-history-item .empty {
    display: none;
  }
  .c-history-item .pic.pic-logo,
  .c-history-item .pic.pic-anniversary {
    place-content: start;
  }
  .c-history-item .pic.pic-logo img {
    width: 50dvw;
  }
  .c-history-item .pic.pic.pic-anniversary img {
    width: 30dvw;
    margin-top: 0.5em;
  }
}
/*
.c-conversion-link
---------------------------------------------------------------- */
.c-conversion-link {
  display: grid;
  place-items: center;
  height: 100%;
  padding: var(--vertical--90) 0;
  color: var(--text-light);
  overflow: hidden;
  -webkit-transition: opacity var(--animation-button);
  transition: opacity var(--animation-button);
  position: relative;
  container: c-conversion-link/inline-size;
}
.c-conversion-link > .inner {
  width: calc(76% + var(--container-pd) * 2);
  padding-inline: var(--container-pd);
}
@container c-conversion-link (max-width: 575px) {
  .c-conversion-link > .inner {
    width: 100%;
  }
}
.c-conversion-link .title {
  margin-bottom: 0.8333333333em;
  position: relative;
  z-index: 10;
}
.c-conversion-link .desc {
  font-size: var(--fs-sm);
  font-weight: 500;
  position: relative;
  z-index: 10;
}
.c-conversion-link .image {
  position: absolute;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all var(--animation-button);
  transition: all var(--animation-button);
}
.c-conversion-link .arrow {
  width: max(4%, 1.75rem);
  aspect-ratio: 40/24;
  background-color: var(--bg-base);
  -webkit-mask-image: url(../assets/images/common/icon-arrow.svg);
          mask-image: url(../assets/images/common/icon-arrow.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  position: absolute;
  bottom: max(8.6%, 1.75rem);
  right: max(6%, 2.25rem);
  -webkit-transition: all var(--animation-button);
  transition: all var(--animation-button);
}
@media screen and (max-width: 767px) {
  .c-conversion-link .arrow {
    bottom: max(8.6%, 1.5rem);
  }
}
.c-conversion-link {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .c-conversion-link:hover {
    opacity: 0.9;
  }
  .c-conversion-link:hover .image {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .c-conversion-link:hover .arrow {
    -webkit-transform: translateX(1rem);
            transform: translateX(1rem);
  }
}

/* --- .c-conversion-link.is-form --- */
.c-conversion-link.is-form {
  background-color: var(--accent-red);
}
.c-conversion-link.is-form .image {
  width: max(26.6%, 8rem);
  top: 25%;
  right: 15.7%;
}
@media screen and (max-width: 991px) {
  .c-conversion-link.is-form .image {
    width: max(38%, 8.125rem);
    top: 7%;
    right: 4%;
  }
}

/* --- .c-conversion-link.is-quotation --- */
.c-conversion-link.is-quotation .image {
  width: 100%;
  height: 100%;
  z-index: -10;
  top: 0;
  left: 0;
}
.c-conversion-link.is-quotation .image img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-conversion-link.is-quotation .image::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--filter-dark);
  position: absolute;
}

/* --- .c-conversion-link.is-tel --- */
.c-conversion-link.is-tel {
  padding: var(--vertical--90) 0;
  background-color: var(--accent-red);
  font-size: var(--fs-tel);
  color: var(--text-light);
}
@media screen and (max-width: 374px) {
  .c-conversion-link.is-tel {
    font-size: 8.56dvw;
  }
}

/*
.c-parallax-area
---------------------------------------------------------------- */
.c-parallax-area {
  height: 80dvh;
  position: relative;
}
.c-parallax-area > .inner {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  clip-path: inset(0);
}
.c-parallax-area .pic {
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: fixed;
  z-index: -1;
  top: 0;
  left: 0;
}

/* === .parallax-area.at-top === */
.parallax-area.at-top .pic {
  background-image: url(../assets/images/top/parallax.jpg);
}

/* === .parallax-area.at-tour === */
.parallax-area.at-tour .pic {
  background-image: url(../assets/images/tour/parallax.jpg);
  background-position: top;
}

/* === .parallax-area.at-event === */
.parallax-area.at-event .pic {
  background-image: url(../assets/images/event/parallax.jpg);
}

/* === .parallax-area.at-company === */
.parallax-area.at-company .pic {
  background-image: url(../assets/images/company/parallax.jpg);
}

/*
.c-title-desc
---------------------------------------------------------------- */
.c-title-desc {
  padding: var(--vertical--90) 0 var(--vertical--60);
  margin-inline: auto;
  position: relative;
}
.c-title-desc::before {
  content: "";
  display: block;
  max-width: var(--container-max);
  width: 100%;
  height: 1px;
  background-color: var(--line-black);
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.c-title-desc > .inner {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 1.875rem;
}
.c-title-desc .section-title {
  grid-column: 1/2;
  grid-row: 1/2;
}
.c-title-desc .desc {
  grid-column: 2/3;
  grid-row: 2/3;
  font-weight: 500;
}
.c-title-desc .desc-title {
  font-size: var(--fs-strong);
  font-weight: 500;
  line-height: var(--lh-narrow);
}
.c-title-desc .button {
  grid-column: 2/3;
  grid-row: 3/4;
  margin-top: var(--space-content);
}

@media screen and (max-width: 767px) {
  .c-title-desc > .inner {
    grid-template-columns: auto;
  }
  .c-title-desc .desc {
    grid-column: 1/2;
    margin-top: calc(var(--space-content) * 2);
  }
  .c-title-desc .button {
    grid-column: 1/2;
  }
}
@media screen and (max-width: 575px) {
  .c-title-desc {
    width: 100%;
  }
  .c-title-desc .button {
    justify-self: center;
  }
}
/*
.c-flow-item
---------------------------------------------------------------- */
.c-flow-item {
  padding: max(3dvw, 2.5rem) max(3dvw, 1.25rem);
  border-radius: calc(var(--br-base) * 5);
  background-color: var(--bg-gray--light);
}
.c-flow-item:nth-child(2) .list-title {
  letter-spacing: 0;
}
.c-flow-item .flow-title {
  padding-left: calc(var(--fs-md-title) * 2.5);
  font-size: var(--fs-md-title);
  position: relative;
}
.c-flow-item .flow-title .num {
  position: absolute;
  left: 0;
}
.c-flow-item .flow-content {
  margin-top: max(1.6dvw, 1.25rem);
  padding-left: calc(var(--fs-md-title) * 2.5);
}
.c-flow-item:not(:last-child) .flow-content {
  position: relative;
}
.c-flow-item:not(:last-child) .flow-content::before {
  content: "";
  display: block;
  width: 1px;
  height: calc(max(1.6dvw, 1.25rem) * 0.35 + 100% + max(3dvw, 2.5rem) + max(3dvw, 1.5rem) + max(3dvw, 2.5rem) * 0.5);
  background-color: var(--line-black);
  -webkit-transform-origin: top;
          transform-origin: top;
  -webkit-transition: -webkit-transform var(--animation-line);
  transition: -webkit-transform var(--animation-line);
  transition: transform var(--animation-line);
  transition: transform var(--animation-line), -webkit-transform var(--animation-line);
  position: absolute;
  top: calc(max(1.6dvw, 1.25rem) * 0.35 * -1);
  left: calc(var(--fs-md-title) * 0.9);
}
.c-flow-item .flow-content.is-showed::before {
  -webkit-transform: scaleY(1);
          transform: scaleY(1);
}
.c-flow-item .detail {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) 25%;
  gap: max(4.3438914027%, 1.75rem);
}
.c-flow-item .illust {
  width: max(11dvw, 11.25rem);
  aspect-ratio: 4/3;
}
.c-flow-item .illust img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-flow-item:nth-child(6) .desc {
  grid-column: 2/4;
}
.c-flow-item .list {
  height: -webkit-max-content;
  height: -moz-max-content;
  height: max-content;
  padding: 1.25em;
  padding-bottom: max(1.4dvw, 1.25rem);
  border-radius: calc(var(--br-base) * 2.5);
  background-color: var(--bg-gray--middle);
}
.c-flow-item .list-title {
  width: 100%;
  background-color: var(--bg-black);
  font-size: var(--fs-md);
  font-weight: 500;
  text-align: center;
}
.c-flow-item .check-list {
  margin-top: 1em;
}
.c-flow-item .check-item:not(:first-child) {
  margin-top: 0.75em;
}
.c-flow-item .conversion {
  margin-top: max(1.6dvw, 1.25rem);
  display: grid;
  grid-template-columns: -webkit-max-content 1fr;
  grid-template-columns: max-content 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: max(3.6199095023%, 1.25rem);
}
.c-flow-item .tel {
  font-size: var(--fs-tel);
  color: var(--accent-red);
  text-align: center;
}
.c-flow-item .tel a {
  color: var(--accent-red);
}
.c-flow-item .tel .tel-info {
  margin-top: 1em;
}
.c-flow-item .form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.75rem;
}
.c-flow-item .button {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-width: 11.25rem;
}

@media screen and (max-width: 991px) {
  .c-flow-item .illust {
    width: 18.1634712412dvw;
  }
  .c-flow-item .desc {
    grid-column: 2/4;
  }
  .c-flow-item .list {
    grid-column: 1/4;
  }
}
@media screen and (max-width: 575px) {
  .c-flow-item .detail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .c-flow-item .illust {
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
  }
  .c-flow-item .conversion {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
/*
.c-loop-text
---------------------------------------------------------------- */
.c-loop-text {
  margin-inline: calc(50% - 50dvw);
  padding-bottom: calc(var(--vertical--60) * 0.5);
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.c-loop-text .swiper-slide {
  margin-right: max(2.8dvw, 1.1666666667rem);
}
.c-loop-text .text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: max(0.8dvw, 0.3333333333rem);
     -moz-column-gap: max(0.8dvw, 0.3333333333rem);
          column-gap: max(0.8dvw, 0.3333333333rem);
  font-size: max(8dvw, 3.75rem);
  font-weight: 500;
  letter-spacing: 0.2em;
  color: var(--bg-red--hover);
}

/*
.c-swiper-fade
---------------------------------------------------------------- */
.c-swiper-fade .slide,
.c-swiper-fade .swiper,
.c-swiper-fade .swiper-wrapper,
.c-swiper-fade .swiper-slide {
  height: 100%;
}
.c-swiper-fade .swiper-wrapper {
  -webkit-transition-timing-function: linear !important;
          transition-timing-function: linear !important;
}

.c-swiper-gallery .gallery-main {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  /* slide */
}
.c-swiper-gallery .gallery-main .slide {
  height: 100%;
}
.c-swiper-gallery .gallery-main .slide .swiper,
.c-swiper-gallery .gallery-main .slide .swiper-wrapper,
.c-swiper-gallery .gallery-main .slide .swiper-slide {
  height: 100%;
}
.c-swiper-gallery .gallery-main .slide .media {
  height: 100%;
}
.c-swiper-gallery .gallery-main .slide .media img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: 7s 1s ease-out;
  transition: 7s 1s ease-out;
}
.c-swiper-gallery .gallery-main .slide.swiper-slide[class*=-active] .slide__media img {
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}
.c-swiper-gallery .gallery-main {
  /* navigation */
}
.c-swiper-gallery .gallery-main .navigation {
  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%;
  position: absolute;
  top: calc(50% - 1.875rem);
  right: 0;
  z-index: 10;
}
.c-swiper-gallery .gallery-main .navigation .arrow {
  width: clamp(2.5rem, 1.721rem + 1.623dvw, 3.75rem);
  aspect-ratio: 1/1;
  border: 1px solid var(--accent-blue);
  position: relative;
}
.c-swiper-gallery .gallery-main .navigation .arrow-box::before, .c-swiper-gallery .gallery-main .navigation .arrow-box::after {
  background-color: var(--accent-blue);
}
.c-swiper-gallery .gallery-main .navigation .arrow--prev .arrow-box::before, .c-swiper-gallery .gallery-main .navigation .arrow--prev .arrow-box::after {
  scale: -1 1;
}
.c-swiper-gallery .gallery-thumb {
  margin-top: 10px;
  /* slide */
}
.c-swiper-gallery .gallery-thumb .slide {
  height: 100%;
}
.c-swiper-gallery .gallery-thumb .slide .swiper,
.c-swiper-gallery .gallery-thumb .slide .swiper-wrapper,
.c-swiper-gallery .gallery-thumb .slide .swiper-slide {
  height: 100%;
}
.c-swiper-gallery .gallery-thumb .slide .media {
  height: 100%;
}
.c-swiper-gallery .gallery-thumb .slide .media img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-swiper-gallery .gallery-thumb .slide .swiper-slide {
  aspect-ratio: 4/3;
  overflow: hidden;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  cursor: pointer;
}
.c-swiper-gallery .gallery-thumb .slide .swiper-slide .thumb-media {
  width: 100%;
  height: 100%;
}
.c-swiper-gallery .gallery-thumb .slide .swiper-slide .thumb-media img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media (any-hover: hover) {
  .c-swiper-gallery .gallery-thumb .slide .swiper-slide:hover {
    opacity: 0.8;
    -webkit-transform: scale(0.96);
            transform: scale(0.96);
  }
  .c-swiper-gallery .gallery-thumb .slide .swiper-slide:hover img {
    -webkit-transform: scale(1.04);
            transform: scale(1.04);
  }
}
.c-swiper-gallery .gallery-thumb .slide .swiper-slide[class*=-thumb-active] {
  opacity: 0.8;
  -webkit-transform: scale(0.96);
          transform: scale(0.96);
}
.c-swiper-gallery .gallery-thumb .slide .swiper-slide[class*=-thumb-active] img {
  -webkit-transform: scale(1.04);
          transform: scale(1.04);
}
.c-swiper-gallery .gallery-thumb {
  /* scrollbar */
}
.c-swiper-gallery .gallery-thumb .scrollbar {
  height: 8px;
  margin-top: 10px;
}
.c-swiper-gallery .gallery-thumb .scrollbar .swiper-scrollbar-drag {
  height: 100%;
  background-color: var(--accent-blue);
  border-radius: 1000px;
}

.c-swiper-loop .slide {
  overflow: hidden;
}
.c-swiper-loop .slide .swiper {
  overflow: visible;
}
.c-swiper-loop .slide .swiper-wrapper {
  -webkit-transition-timing-function: linear !important;
          transition-timing-function: linear !important;
}
.c-swiper-loop .slide .swiper-slide {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}

/*
.p-header
---------------------------------------------------------------- */
.p-header {
  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;
  padding: var(--header-padding--vertical) var(--header-padding--inline);
  border-bottom: 1px solid var(--line-black);
  background-color: var(--bg-base);
  font-size: var(--fs-md);
  container: p-header/inline-size;
  -webkit-animation: headerAbsolute var(--animation-header) forwards;
          animation: headerAbsolute var(--animation-header) forwards;
}
@-webkit-keyframes headerAbsolute {
  0% {
    opacity: 1;
    visibility: visible;
    position: fixed;
  }
  99% {
    opacity: 0;
    visibility: hidden;
    position: fixed;
  }
  100% {
    position: absolute;
  }
}
@keyframes headerAbsolute {
  0% {
    opacity: 1;
    visibility: visible;
    position: fixed;
  }
  99% {
    opacity: 0;
    visibility: hidden;
    position: fixed;
  }
  100% {
    position: absolute;
  }
}
.p-header {
  /* .header-logo */
}
.p-header .header-logo {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: max(14dvw, 12.5rem);
  position: relative;
  z-index: -10;
}
.p-header {
  /* .hamburger */
}
.p-header .hamburger {
  display: none;
}

/* .p-header.is-fixed */
.p-header.is-fixed {
  -webkit-animation: headerFixed var(--animation-header) forwards;
          animation: headerFixed var(--animation-header) forwards;
}
@-webkit-keyframes headerFixed {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  .1% {
    position: fixed;
    opacity: 0;
    visibility: hidden;
  }
  100% {
    position: fixed;
    opacity: 1;
    visibility: visible;
  }
}
@keyframes headerFixed {
  0% {
    opacity: 0;
    visibility: hidden;
  }
  .1% {
    position: fixed;
    opacity: 0;
    visibility: hidden;
  }
  100% {
    position: fixed;
    opacity: 1;
    visibility: visible;
  }
}

@media screen and (max-width: 1339px) {
  .p-header {
    /* .hamburger */
  }
  .p-header .hamburger {
    display: block;
    width: var(--hamburger--width);
    aspect-ratio: 1/1;
    border-radius: calc(var(--br) * 2);
    background-color: var(--accent-red);
    cursor: pointer;
    opacity: 1;
    -webkit-transition: opacity var(--animation-button);
    transition: opacity var(--animation-button);
    position: relative;
    z-index: var(--z-hamburger);
  }
  .p-header .hamburger > span {
    display: block;
    width: 42.5%;
    height: 1px;
    border-radius: 62.5rem;
    background-color: var(--bg-base);
    -webkit-transition: all var(--animation-button);
    transition: all var(--animation-button);
    position: absolute;
    left: 28.75%;
  }
  .p-header .hamburger > span:nth-child(1) {
    top: 34.6%;
  }
  .p-header .hamburger > span:nth-child(2) {
    top: calc(50% - 0.5px);
  }
  .p-header .hamburger > span:nth-child(3) {
    bottom: 33%;
  }
  .p-header .hamburger {
    /* --- hover --- */
  }
  .p-header {
    /* --- .hamburger.is-active --- */
  }
}
@media screen and (max-width: 1339px) and (any-hover: hover) {
  .p-header .hamburger:hover {
    opacity: 0.8;
  }
}
@media screen and (max-width: 1339px) {
  .p-header .hamburger.is-active span:nth-child(1) {
    top: 50%;
    -webkit-transform: rotate(-30deg);
            transform: rotate(-30deg);
  }
  .p-header .hamburger.is-active span:nth-child(2) {
    opacity: 0;
  }
  .p-header .hamburger.is-active span:nth-child(3) {
    bottom: 48.5%;
    -webkit-transform: rotate(30deg);
            transform: rotate(30deg);
  }
}
/*
.p-nav
---------------------------------------------------------------- */
.p-nav {
  position: static;
  z-index: var(--z-nav);
  top: var(--header-padding--vertical);
  right: var(--header-padding--inline);
}
.p-nav .nav-bg {
  display: none;
}
.p-nav {
  /* .nav-main */
}
.p-nav .nav-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: max(1.8dvw, 1.5em);
  padding-inline: 0;
  font-size: var(--fs-md);
  font-weight: 500;
}
.p-nav {
  /* .nav-list */
}
.p-nav .nav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  gap: max(1.6dvw, 1.25em);
}
.p-nav {
  /* .nav-item */
}
.p-nav .nav-item {
  position: relative;
}
@media screen and (min-width: 1340px) and (any-hover: hover) {
  .p-nav .nav-item:hover .nav-a > .text::before {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: left;
            transform-origin: left;
  }
}
.p-nav .nav-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 0.4em;
     -moz-column-gap: 0.4em;
          column-gap: 0.4em;
  height: 100%;
}
.p-nav .nav-a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  height: 100%;
  position: relative;
}
.p-nav .nav-a > .text {
  position: relative;
}
.p-nav .nav-a > .text::before {
  content: "";
  width: 100%;
  height: 1px;
  background-color: var(--line-black);
  position: absolute;
  bottom: -2px;
  left: 0;
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transform-origin: right;
          transform-origin: right;
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}
.p-nav {
  /* --- .nav-item.is-current --- */
}
.p-nav .nav-a.is-current > .text::before {
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
  -webkit-transform-origin: left;
          transform-origin: left;
}
.p-nav {
  /* .nav-button-list */
}
.p-nav .nav-button-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.625em;
}
.p-nav {
  /* .dropdown */
}
.p-nav .dropdown {
  position: absolute;
  z-index: var(--z-dropdown);
}
.p-nav .dropdown-icon {
  display: grid;
  place-content: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 0.6em;
}
.p-nav .dropdown-icon img {
  margin-top: 0.1em;
}

@media screen and (max-width: 1339px) {
  .p-nav .nav-bg {
    display: block;
    width: 100%;
    height: 100%;
    background-color: var(--filter-dark);
    position: fixed;
    z-index: -10;
    top: 0;
    left: 0;
  }
  .p-nav .nav-decoration {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    font-family: var(--ff-en-primary);
    font-size: 7.4682598954dvw;
    font-weight: 500;
    letter-spacing: 0.15em;
    color: var(--bg-red--hover);
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    white-space: nowrap;
    position: fixed;
    top: 0;
    left: 0;
  }
  .p-nav {
    /* .nav-main */
  }
  .p-nav .nav-main {
    width: max(50dvw, 480px);
    height: 100dvh;
    padding: var(--vertical--120) 0;
    background-color: var(--bg-base);
    -webkit-transition: -webkit-transform var(--animation-dropdown);
    transition: -webkit-transform var(--animation-dropdown);
    transition: transform var(--animation-dropdown);
    transition: transform var(--animation-dropdown), -webkit-transform var(--animation-dropdown);
    position: fixed;
    top: 0;
    right: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    overflow-y: auto;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .p-nav .nav-main::-webkit-scrollbar {
    display: none;
  }
  .p-nav .nav-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    font-size: var(--fs-lg);
  }
  .p-nav {
    /* .nav-list */
  }
  .p-nav .nav-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    gap: 1.25em;
  }
  .p-nav {
    /* .nav-item */
  }
  .p-nav .nav-item {
    width: 100%;
  }
  .p-nav .nav-link {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .p-nav .nav-a {
    padding: 0.5em 0;
    /* --- hover --- */
  }
  .p-nav {
    /* .nav-button-list */
    /* .dropdown */
    /* --- .dropdown-icon.is-active --- */
  }
}
@media screen and (max-width: 1339px) and (any-hover: hover) {
  .p-nav .nav-a:hover > .text::before {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: left;
            transform-origin: left;
  }
}
@media screen and (max-width: 1339px) {
  .p-nav .nav-button-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p-nav .dropdown {
    position: static;
  }
  .p-nav .dropdown-icon {
    width: 2em;
    aspect-ratio: 1/1;
    background-color: var(--bg-gray--middle);
    border-radius: var(--br-base);
    -webkit-transition: background-color var(--animation-button);
    transition: background-color var(--animation-button);
    cursor: pointer;
  }
  .p-nav .dropdown-icon img {
    width: 0.65em;
    -webkit-transition: -webkit-transform var(--animation-button);
    transition: -webkit-transform var(--animation-button);
    transition: transform var(--animation-button);
    transition: transform var(--animation-button), -webkit-transform var(--animation-button);
  }
  .p-nav .dropdown-icon {
    /* --- hover --- */
  }
}
@media screen and (max-width: 1339px) and (any-hover: hover) {
  .p-nav .dropdown-icon:hover {
    background-color: var(--bg-red--hover);
  }
}
@media screen and (max-width: 1339px) {
  .p-nav .dropdown-icon.is-active img {
    -webkit-transform: rotate(-180deg);
            transform: rotate(-180deg);
  }
}
@media screen and (max-width: 1339px) {
  /* === .p-nav.is-active === */
  .p-nav.is-active {
    /* .nav-main */
  }
  .p-nav.is-active .nav-main {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@media screen and (max-width: 575px) {
  .p-nav {
    /* .nav-main */
  }
  .p-nav .nav-main {
    width: 100dvw;
  }
}
/*
.p-footer
---------------------------------------------------------------- */
.p-footer {
  /* --- footer-main --- */
}
.p-footer .footer-main {
  padding: var(--vertical--120) 0;
}
.p-footer .footer-main > .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-footer {
  /* .company */
}
.p-footer .logo {
  width: max(16.4dvw, 16.25rem);
}
.p-footer .info {
  margin-top: 3.4285714286em;
  font-size: var(--fs-sm);
}
.p-footer .num-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 0.6em;
}
.p-footer .num-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.4285714286em;
}
.p-footer .num-item:not(:first-child)::before {
  content: "/";
  display: inline-block;
  margin-left: 0.4285714286em;
}
.p-footer {
  /* .fnav */
}
.p-footer .fnav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: max(4dvw, 1.75rem);
  font-size: max(0.8dvw, 0.8125rem);
}
.p-footer .fnav-list a {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  -webkit-transition: color var(--animation-button);
  transition: color var(--animation-button);
}
.p-footer {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .p-footer .fnav-list a:hover {
    color: var(--accent-red);
  }
}
.p-footer .anchor-list {
  margin-top: 1.5em;
}
.p-footer .anchor-item:not(:first-child),
.p-footer .lower-title:not(:first-child) {
  margin-top: 1.1em;
}
.p-footer .lower-title {
  font-weight: 500;
}
.p-footer {
  /* --- .footer-end --- */
}
.p-footer .footer-end {
  padding-bottom: max(1.6dvw, 2rem);
  border-top: 1px solid var(--line-black);
}
.p-footer {
  /* .top */
}
.p-footer .top {
  padding: var(--vertical--90) 0;
}
.p-footer .copy {
  height: max(2dvw, 2rem);
  text-align: center;
}
.p-footer .copy img {
  width: auto;
  height: 100%;
}
@media screen and (max-width: 575px) {
  .p-footer .copy {
    height: 5.5652173913dvw;
  }
}
.p-footer {
  /* .bottom */
}
.p-footer .bottom {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  place-items: center;
}
.p-footer .bottom::before {
  content: "";
}
.p-footer .copyright {
  font-size: var(--fs-sm);
  color: var(--text-gray);
}
.p-footer .policy-link {
  justify-self: end;
}

@media screen and (max-width: 1199px) {
  .p-footer {
    /* --- footer-main --- */
  }
  .p-footer .footer-main > .inner {
    -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;
    gap: max(var(--space-content) * 1.5, 3.75rem);
  }
  .p-footer {
    /* .company */
  }
  .p-footer .logo {
    width: max(16.4dvw, 16.25rem);
  }
  .p-footer .info {
    margin-top: 2em;
    text-align: center;
  }
  .p-footer .num-list {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p-footer {
    /* .fnav */
  }
  .p-footer .fnav-list {
    gap: clamp(1.75rem, -1.814rem + 7.425dvw, 3.75rem);
  }
}
@media screen and (max-width: 767px) {
  .p-footer .fnav-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 3rem 1.75rem;
    font-size: var(--fs-md);
  }
}
@media screen and (max-width: 575px) {
  .p-footer {
    /* --- footer-main --- */
  }
  .p-footer .fnav {
    width: 100%;
  }
  .p-footer .fnav-list {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .p-footer .anchor-item a {
    width: 100%;
    position: relative;
  }
  .p-footer .anchor-item a::before {
    content: "";
    display: block;
    width: 0.4em;
    aspect-ratio: 1/1;
    border-top: 1px solid var(--line-gray--frame);
    border-right: 1px solid var(--line-gray--frame);
    position: absolute;
    top: calc(50% - 0.2em);
    right: 0;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .p-footer {
    /* --- .footer-end --- */
  }
  .p-footer .bottom {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    row-gap: 1em;
  }
  .p-footer .bottom::before {
    display: none;
  }
  .p-footer .copyright {
    grid-row: 2/3;
  }
  .p-footer .policy-link {
    grid-row: 1/2;
    justify-self: center;
  }
}
/*
.p-conversion
---------------------------------------------------------------- */
.p-conversion {
  display: grid;
  grid-template-columns: repeat(2, 50%);
  gap: 1px 0;
}
.p-conversion .conversion-tel {
  grid-column: 1/3;
}

@media screen and (max-width: 767px) {
  .p-conversion {
    gap: 0;
  }
  .p-conversion .conversion-form {
    grid-column: 1/3;
  }
  .p-conversion .conversion-quotation {
    grid-column: 1/3;
  }
}
/*
.p-lower-header
---------------------------------------------------------------- */
.p-lower-header {
  display: grid;
  grid-template-columns: 65dvw minmax(0, 1fr);
  height: 100dvh;
}
.p-lower-header > * {
  min-width: 0;
  min-height: 0;
}
.p-lower-header > .pic img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-lower-header > .text {
  padding: calc(var(--vertical--60) * 0.5) 0;
}
.p-lower-header > .text > .inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) -webkit-max-content;
  grid-template-rows: minmax(0, 1fr) max-content;
  place-content: center;
  height: 100%;
  padding-inline: var(--container-pd);
}
.p-lower-header .lower-title {
  place-self: center;
  font-size: max(2.4dvw, 2rem);
}
.p-lower-header {
  /* .breadcrumbs */
}
.p-lower-header .breadcrumbs {
  justify-self: end;
  font-size: var(--fs-xs);
}
.p-lower-header .breadcrumbs-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-lower-header .breadcrumbs-item:not(:first-child) > a {
  margin-left: 0.4285714286em;
}
.p-lower-header .breadcrumbs-item:not(:first-child)::before {
  content: "/";
  display: inline-block;
  margin-left: 0.4285714286em;
  color: var(--bg-gray--dark);
}
.p-lower-header {
  /* === .breadcrumbs-item.page-current === */
}
.p-lower-header .breadcrumbs-item.page-current > a {
  pointer-events: none;
  color: var(--bg-gray--dark);
}

@media screen and (max-width: 1199px) {
  .p-lower-header {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: 35dvh minmax(0, 1fr);
  }
  .p-lower-header > .pic {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .p-lower-header > .text {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .p-lower-header .lower-title {
    justify-self: start;
  }
}
/* === .p-lower-header.size-half === */
.p-lower-header.size-half {
  grid-template-columns: minmax(0, 1fr);
  border-bottom: 1px solid var(--line-black);
  height: auto;
  aspect-ratio: 3.3028/1;
}
.p-lower-header.size-half .text > .inner {
  max-width: calc(var(--container--md) + var(--container-pd) * 2);
  margin-inline: auto;
}
.p-lower-header.size-half .lower-title {
  place-self: center start;
}

@media screen and (max-width: 1199px) {
  .p-lower-header.size-half {
    grid-template-rows: minmax(0, 1fr);
  }
}
@media screen and (max-width: 991px) {
  .p-lower-header.size-half {
    aspect-ratio: 2/1;
  }
}
@media screen and (max-width: 576px) {
  .p-lower-header.size-half {
    aspect-ratio: 1/1;
  }
}
/* === .p-lower-header.at-topics === */
.p-lower-header.at-topics .breadcrumbs-item.page-current > a,
.p-lower-header.at-tour .breadcrumbs-item.page-current > a {
  margin-left: -0.25em;
  letter-spacing: var(--ls-min);
}

/* === .p-lower-header.at-tour === */
.p-lower-header.at-tour .lower-title {
  white-space: nowrap;
}
.p-lower-header.at-tour img {
  -o-object-position: bottom;
     object-position: bottom;
}
@media screen and (max-width: 374px) {
  .p-lower-header.at-tour .lower-title .ja {
    font-size: max(8.5561497326dvw, 1.75rem);
  }
}

/* === .p-lower-header.at-event === */
.p-lower-header.at-event .lower-title .ja {
  line-height: var(--lh-narrow);
}
.p-lower-header.at-event > .pic img {
  -o-object-position: 10% 50%;
     object-position: 10% 50%;
}
@media screen and (max-width: 1199px) and (min-width: 576px) {
  .p-lower-header.at-event .br-control {
    display: none;
  }
}

/* 
.p-section
---------------------------------------------------------------- */
/*
.p-policy
---------------------------------------------------------------- */
.p-policy {
  max-width: var(--container--md);
  margin-inline: auto;
  padding: var(--vertical--120) 0;
}
.p-policy .section-title {
  margin-inline: auto;
  font-size: var(--fs-md-title);
  text-align: center;
}
.p-policy .section-title .en {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-policy .section-title .small {
  margin-top: 1em;
  font-size: 0.5em;
  color: var(--text-gray);
}
.p-policy .text-link {
  display: inline;
  color: var(--accent-red);
}
.p-policy .text-link::before {
  background-color: var(--accent-red);
  bottom: 0.25em;
}
.p-policy .policy-container {
  margin-top: var(--space-content);
  padding: max(2dvw, 1.5rem);
  font-size: var(--fs-md);
  word-break: break-all;
}
.p-policy .policy-container > .inner {
  padding: 0;
}
.p-policy .lead .note {
  line-height: var(--lh-base);
}
.p-policy .policy-detail {
  margin-top: calc(var(--space-content) * 1.25);
}
.p-policy .section-block:not(:first-child) {
  margin-top: max(var(--space-content), 4em);
}
.p-policy .section-block > .desc {
  margin-top: 1em;
}
.p-policy .section-block > .desc:not(:first-child) {
  margin-top: 1.75em;
}
.p-policy .policy-title {
  padding-left: 0.75em;
  font-size: 1.25em;
  font-weight: 500;
  line-height: var(--lh-narrow);
  position: relative;
}
.p-policy .policy-title::before {
  content: "";
  display: inline-block;
  width: 0.15em;
  height: 100%;
  background-color: var(--accent-red);
  position: absolute;
  left: 0;
}
.p-policy .list-title {
  display: inline-block;
}
.p-policy .order-list {
  margin-top: 1.5em;
}
.p-policy .order-list.in-order-list {
  margin-top: 0.5em;
}
.p-policy .order-item {
  line-height: var(--lh-narrow);
}
.p-policy .order-item:not(:first-child) {
  margin-top: 1em;
}
.p-policy .order-list.in-order-list > .order-item:not(:first-child) {
  margin-top: 0.75em;
}
.p-policy .info-list {
  margin-top: 1em;
}
.p-policy .info-list .info-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.25em;
  line-height: var(--lh-min);
}
.p-policy .info-list .info-item dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.p-policy .info-list .info-item:not(:first-child) {
  margin-top: 0.5em;
}
.p-policy .info-list dd {
  padding-left: 0.75em;
  position: relative;
}
.p-policy .info-list dd::before {
  content: "：";
  display: inline-block;
  position: absolute;
  left: 0;
}
.p-policy .agree-box {
  margin-top: 2em;
}
.p-policy .agree-box label {
  margin-inline: auto;
  font-size: var(--fs-lg);
  font-weight: 500;
}
.p-policy .button-container {
  max-width: var(--container--md);
  margin-inline: auto;
  margin-top: var(--space-content);
  text-align: center;
}

/*
.p-card-list
---------------------------------------------------------------- */
.p-card-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-inline: calc(50% - 50dvw);
}

/* === .p-card-list.item-double === */
@media screen and (max-width: 991px) {
  .p-card-list.item-double {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .p-card-list.item-double .animation-delay-4 {
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
}
/* === .p-card-list.item-triple === */
.p-card-list.item-triple {
  position: relative;
}
.p-card-list.item-triple > li:nth-child(1) {
  grid-column: 1/2;
  grid-row: 1/3;
}
.p-card-list.item-triple > li:nth-child(2) {
  grid-column: 2/3;
  grid-row: 1/2;
}
.p-card-list.item-triple > li:nth-child(3) {
  grid-column: 2/3;
  grid-row: 2/3;
}
.p-card-list.item-triple.last::before {
  display: none;
}

@media screen and (max-width: 1150px) {
  .p-card-list.item-triple {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .p-card-list.item-triple > li:nth-child(n) {
    grid-column: 1/2;
    grid-row: initial;
  }
  .p-card-list.item-triple .animation-delay-2 {
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
}
@media screen and (max-width: 575px) {
  .p-card-list.item-triple::before {
    display: none;
  }
}
/* 
.p-topics-box
---------------------------------------------------------------- */
.p-topics-box {
  padding: max(2dvw, 1.5rem) max(1.5dvw, 1rem);
  border-radius: calc(var(--br-base) * 5);
  background-color: var(--bg-gray--light);
}
.p-topics-box .topics-item {
  border-top: 1px solid var(--line-gray--separate);
}
.p-topics-box .topics-item:last-child {
  border-bottom: 1px solid var(--line-gray--separate);
}
.p-topics-box .topics-item a {
  -webkit-transition: background-color var(--animation-button);
  transition: background-color var(--animation-button);
  width: 100%;
}
.p-topics-box .topics-item article {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: max(2.4dvw, 1rem);
     -moz-column-gap: max(2.4dvw, 1rem);
          column-gap: max(2.4dvw, 1rem);
  padding: max(1.2dvw, 1.5rem) max(0.5dvw, 0.25rem);
}
.p-topics-box .topics-item article * {
  min-width: 0;
}
.p-topics-box .topics-item .topics-info {
  grid-column: 1/2;
}
.p-topics-box .topics-item .title {
  grid-column: 1/2;
  width: 100%;
  margin-top: 0.75em;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.p-topics-box .topics-item .desc {
  grid-column: 1/2;
  margin-top: 1em;
  text-align: start;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  max-height: calc(1em * var(--lh-base) * 3);
}
.p-topics-box .topics-item .tag-list {
  grid-column: 1/2;
  margin-top: 1em;
}
.p-topics-box .topics-item .topics-arrow {
  grid-column: 2/3;
  grid-row: 1/5;
  width: 1.5rem;
  width: max(1.2dvw, 1.25rem);
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}
.p-topics-box {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .p-topics-box .topics-item:hover a {
    background-color: var(--bg-red--hover);
  }
  .p-topics-box .topics-item:hover .topics-arrow {
    -webkit-transform: translateX(4px);
            transform: translateX(4px);
  }
}

/*
.p-topics-slider
---------------------------------------------------------------- */
.p-topics-slider {
  position: relative;
}
.p-topics-slider > .inner {
  margin-top: -0.9375rem;
  margin-left: calc(max(0.75dvw, 0.5rem) * -1);
}
.p-topics-slider .topics-list {
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
.p-topics-slider .topics-slide {
  width: max(18.75dvw, 16.25rem);
  height: auto;
  padding: 0.9375rem max(0.75dvw, 0.5rem);
  -webkit-transition: background-color var(--animation-button);
  transition: background-color var(--animation-button);
}
.p-topics-slider .topics-slide > a {
  width: 100%;
}
.p-topics-slider .pic {
  aspect-ratio: 3/4;
  overflow: hidden;
}
.p-topics-slider .pic img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
}
.p-topics-slider .text {
  margin-top: 1.5em;
}
.p-topics-slider .title {
  font-size: var(--fs-lg);
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.p-topics-slider .topics-info {
  margin-top: 1em;
  font-size: var(--fs-sm);
}
.p-topics-slider .desc {
  margin-top: 1em;
  display: -webkit-box;
  overflow: hidden;
  text-align: start;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.p-topics-slider .tag-list {
  margin-top: 1em;
  font-size: var(--fs-sm);
}
.p-topics-slider {
  /* --- hover --- */
}
@media (any-hover: hover) {
  .p-topics-slider .topics-slide:has(a):hover {
    background-color: var(--bg-red--hover);
  }
  .p-topics-slider .topics-slide:has(a):hover .pic img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.p-topics-slider {
  /* .navigation */
}
.p-topics-slider .navigation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 91dvw;
  position: absolute;
  z-index: 10;
  top: calc(max(18.75dvw, 16.25rem) * 4 / 3 * 0.5 - max(5.6dvw, 60px) / 2);
  left: calc(50% - 45.5dvw);
}
.p-topics-slider .navigation .arrow {
  width: max(4dvw, 48px);
  position: absolute;
}
.p-topics-slider .navigation .arrow.prev {
  left: 0;
}
.p-topics-slider .navigation .arrow.next {
  right: 0;
}

/* 
.p-file-list
---------------------------------------------------------------- */
.p-file-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: max(0.8dvw, 0.5rem);
}
.p-file-list .file-item {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

/* 
.p-history-timeline
---------------------------------------------------------------- */
.p-history-timeline {
  position: relative;
}
.p-history-timeline::before {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: var(--line-black);
  position: absolute;
  top: 0;
  left: calc(50% - 0.5px);
}
.p-history-timeline .history-item:nth-child(2n-1) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.p-history-timeline .history-item:nth-child(2n) {
  text-align: end;
}
.p-history-timeline .history-item:nth-child(2n) > .content {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.p-history-timeline .history-item:nth-child(2n) > .content > .text {
  padding-left: 0;
  padding-right: calc(var(--vertical--90) * 1.5 / 2);
}
.p-history-timeline .history-item:nth-child(2n) > .content .year {
  margin-inline: auto 0;
}
.p-history-timeline .history-item:nth-child(2n) .pic img {
  left: initial;
  right: 0;
}
.p-history-timeline .history-item:nth-child(2n) .date::before {
  left: initial;
  right: calc(var(--vertical--90) * 1.5 / 2 * -1 - 0.125em);
}
.p-history-timeline .history-item:not(:first-child) {
  margin-top: var(--vertical--90);
}

@media screen and (max-width: 991px) {
  .p-history-timeline .history-item:nth-child(2n) > .content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p-history-timeline .history-item:nth-child(2n) .pic {
    place-items: end;
    place-content: end;
    padding-right: calc(var(--vertical--90) * 1.5 / 2);
  }
}
@media screen and (max-width: 575px) {
  .p-history-timeline::before {
    left: 0;
  }
  .p-history-timeline .history-item:nth-child(2n) {
    text-align: start;
  }
  .p-history-timeline .history-item:nth-child(2n) > .content > .text {
    padding-right: 0;
    padding-left: calc(var(--vertical--90) * 1.5 / 2);
  }
  .p-history-timeline .history-item:nth-child(2n) .date::before {
    right: initial;
    left: calc(var(--vertical--90) * 1.5 / 2 * -1 - 0.125em);
  }
  .p-history-timeline .history-item:nth-child(2n) .pic {
    place-items: start;
    place-content: start;
    padding-right: 0;
  }
  .p-history-timeline .history-item:not(:first-child) {
    margin-top: var(--vertical--60);
  }
}
/*
.p-section-report
---------------------------------------------------------------- */
.p-section-report > .inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: var(--vertical--120) 0;
}
.p-section-report .text-area .section-title {
  margin-bottom: 0.8333333333em;
}
.p-section-report .button {
  grid-column: 2/3;
  grid-row: 1/2;
  align-self: end;
}
.p-section-report .topics-slider {
  grid-column: 1/3;
  grid-row: 2/3;
  margin-top: var(--space-content);
}
.p-section-report .topics-slider > .inner {
  margin-right: calc(50% - 50dvw);
}

@media screen and (max-width: 767px) {
  .p-section-report .button {
    grid-column: 1/3;
    grid-row: 3/4;
    justify-self: center;
    margin-top: var(--space-content);
  }
}
/*
.p-section-cases
---------------------------------------------------------------- */
.p-section-cases {
  margin-inline: calc(50% - 50dvw);
  padding-inline: calc(50dvw - 50%);
}
.p-section-cases:not(:first-child) {
  margin-top: var(--vertical--60);
}
.p-section-cases .title-desc {
  width: 100%;
}

/* === .p-section-cases#meeting === */
.p-section-cases#meeting .section-title .ja {
  line-height: var(--lh-min);
}

/*
.p-page-form
---------------------------------------------------------------- */
/* === .page-desc === */
.page-desc {
  margin-inline: calc(50% - 50dvw);
  padding: var(--vertical--90) calc(50dvw - 50%);
  background-color: var(--bg-yellow);
  font-weight: 500;
}
.page-desc > .inner {
  max-width: var(--container--md);
  margin-inline: auto;
}
.page-desc .red {
  color: var(--accent-red);
}

/* === .form-container === */
.form-container {
  padding-top: var(--vertical--90);
}
.form-container .form-block:not(:first-of-type) {
  margin-top: var(--space-content);
}

/* === form-item switch === */
.form-block.requirement:has(.radio-trip_others:checked) .only_bus {
  display: none;
}
.form-block.requirement:has(.radio-only_bus:checked) .trip_others {
  display: none;
}

/* === .section-policy === */
.section-policy {
  padding: var(--vertical--90) 0 var(--vertical--120);
}
.section-policy .policy-container {
  height: 30rem;
  padding-right: max(0.6dvw, 0.5rem);
}
.section-policy .policy-container > .inner {
  padding-right: 12px;
}

/* 
.p-splash
---------------------------------------------------------------- */
/*========= LoadingのためのCSS ===============*/
/* Loading背景画面設定 */
#splash {
  /*fixedで全面に固定*/
  position: fixed;
  z-index: var(--z-loading);
  width: 100%;
  height: 100%;
  background: var(--bg-body);
  text-align: center;
  color: var(--text-dark);
}

/* Loadingバー中央配置 */
#splash_text {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: var(--z-loading);
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  color: var(--text-dark);
}

/* ================================================================
page
================================================================ */
/*
top
---------------------------------------------------------------- */
/* === .mv === */
.mv {
  display: grid;
  grid-template-columns: 65dvw minmax(0, 1fr);
  height: 100dvh;
}
.mv > * {
  min-width: 0;
  min-height: 0;
}
.mv .mv-slider {
  position: relative;
}
.mv {
  /* .slider */
}
.mv .slider {
  height: 100%;
}
.mv .slider * {
  height: inherit;
}
.mv .media img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.mv {
  /* .text */
}
.mv .text {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  color: var(--text-light);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  position: absolute;
  z-index: 10;
  top: 51%;
  left: 0;
  right: 0;
}
.mv .text > .inner {
  padding-inline: var(--container-pd);
}
.mv .copy {
  font-size: max(2dvw, 2.25rem);
  text-align: center;
}
.mv .copy .ja {
  height: max(2dvw, 2.25rem);
}
.mv .copy .en {
  font-size: 0.5em;
  margin-top: 0.75em;
}
.mv .copy span {
  display: block;
}
.mv .copy img {
  width: auto;
  height: 100%;
}
.mv .desc {
  margin-top: 1.5em;
  font-size: var(--fs-sm);
  font-weight: 500;
}
.mv .desc p {
  text-align: center;
  -moz-text-align-last: center;
       text-align-last: center;
}

@media screen and (max-width: 1399px) {
  .mv {
    grid-template-columns: auto;
    height: auto;
    min-height: 0;
    padding-top: 0 !important;
  }
  .mv .mv-slider {
    height: 80dvh;
  }
}
@media screen and (max-width: 767px) {
  .mv .text {
    width: 100%;
    max-width: initial;
  }
}
@media screen and (max-width: 575px) {
  .mv .copy {
    font-size: max(6.2608695652dvw, 1.5rem);
  }
  .mv .copy .ja {
    height: max(6.2608695652dvw, 1.5rem);
  }
}
/* === .section-topics === */
.section-topics {
  padding: var(--vertical--60) 0;
  container: section-topics/inline-size;
}
.section-topics > .inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-rows: auto minmax(0, 1fr);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: calc(var(--space-content) * 0.5) 1em;
  width: 94.2857142857%;
  height: 100%;
  margin-inline: auto;
  padding-inline: var(--container-pd);
}
.section-topics .section-title {
  font-size: 1.75rem;
}
.section-topics .button {
  -ms-flex-item-align: center;
      align-self: center;
}
.section-topics .topics-box {
  grid-column: 1/3;
  min-height: 0;
  padding-right: max(0.6dvw, 0.5rem);
}
.section-topics .topics-box .topics-info {
  font-size: var(--fs-sm);
}
.section-topics .topics-box .title {
  font-size: var(--fs-md);
}
@container section-topics (max-width: 575px) {
  .section-topics > .inner {
    width: 100%;
  }
}

@media screen and (max-width: 1399px) and (min-width: 1200px) {
  .section-topics .button {
    min-width: 10.5rem;
  }
}
@media screen and (max-width: 1399px) {
  .section-topics {
    padding-block: var(--vertical--90);
  }
  .section-topics > .inner {
    width: 100%;
    row-gap: var(--space-content);
  }
  .section-topics .section-title {
    font-size: var(--fs-lg-title--ja);
  }
  .section-topics .topics-list {
    max-height: 50dvh;
  }
}
@media screen and (max-width: 575px) {
  .section-topics .button {
    grid-column: 1/3;
    grid-row: 3/4;
    justify-self: center;
  }
}
/* === .section-search === */
.section-search {
  padding: var(--vertical--120) 0;
}
.section-search .title-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
.section-search .section-title {
  margin-right: 0.6666666667em;
}
.section-search .search-banner-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
  gap: max(1.5dvw, 0.5rem);
  margin-top: var(--space-content);
}
.section-search .search-banner-list .banner-item {
  font-size: clamp(1.125rem, 0.891rem + 0.487dvw, 1.5rem);
}

@media screen and (max-width: 767px) {
  .section-search .search-banner-list {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}
@media screen and (max-width: 575px) {
  .section-search .title-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    gap: 1em;
  }
}
/*
topics
---------------------------------------------------------------- */
/* === .topics-wrapper === */
.topics-wrapper {
  max-width: var(--container--md);
  margin-inline: auto;
  padding: var(--vertical--120) 0;
}

/* === .topics-categories === */
.topics-categories {
  font-size: max(0.7dvw, 0.875rem);
}
.topics-categories > .inner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  -webkit-column-gap: 1.5em;
     -moz-column-gap: 1.5em;
          column-gap: 1.5em;
}
.topics-categories .categories-icon {
  width: 1.75em;
  aspect-ratio: 1/1;
  line-height: var(--lh-base);
}
.topics-categories .categories-icon img {
  vertical-align: middle;
}
.topics-categories .category-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.375rem 0.625rem;
}
.topics-categories .category-item > a {
  border: 0.1em solid var(--line-black);
  color: var(--text-dark);
  -webkit-transition: background-color var(--animation-button), color var(--animation-button);
  transition: background-color var(--animation-button), color var(--animation-button);
}
@media (any-hover: hover) {
  .topics-categories .category-item > a:hover {
    background-color: var(--bg-black);
    color: var(--text-light);
  }
}
.topics-categories .category-item.is-active > a {
  background-color: var(--bg-black);
  color: var(--text-light);
}

/* === .topics-container === */
.topics-container {
  margin-top: calc(var(--space-content));
}
.topics-container .topics-box .topics-info {
  font-size: var(--fs-sm);
}
.topics-container .topics-box .title {
  font-size: var(--fs-lg);
}
.topics-container .topics-box .desc {
  font-size: var(--fs-sm);
}
.topics-container .topics-box .tag-list {
  font-size: var(--fs-sm);
}

/* === .topics-container === */
.topics-paging {
  margin-top: var(--space-content);
}
.topics-paging .paging {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

/*
news-detail
---------------------------------------------------------------- */
/* === .article-wrapper === */
.article-wrapper {
  max-width: var(--container--md);
  margin-inline: auto;
  padding: var(--vertical--120) 0;
}

/* === .detail-info === */
.detail-info .topics-info {
  font-size: var(--fs-md);
}
.detail-info .title {
  margin-top: 0.75em;
  font-size: var(--fs-xl);
  line-height: var(--lh-narrow);
}
.detail-info .tag-list {
  margin-top: 1.5em;
  font-size: var(--fs-sm);
}

/* === .detail-file === */
.detail-file {
  margin-top: 2.5em;
}

/* === .main-text === */
.main-text {
  margin-top: var(--vertical--90);
}
.main-text > *:not(:first-child) {
  margin-top: calc(var(--space-content));
}
.main-text .image-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-column-gap: max(1.5dvw, 1rem);
     -moz-column-gap: max(1.5dvw, 1rem);
          column-gap: max(1.5dvw, 1rem);
}
.main-text .detail-image {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  max-width: 50%;
}
.main-text .detail-image > .pic {
  aspect-ratio: 4/3;
  background-color: var(--bg-gray--middle);
  overflow: hidden;
}
.main-text .detail-image img {
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.main-text .detail-image > .desc {
  margin-top: 0.75em;
  font-size: var(--fs-md);
  font-weight: 500;
  text-align: center;
  line-height: var(--lh-narrow);
}
.main-text .text-block {
  text-align: start;
}

/* === .button-back === */
.button-back {
  margin-top: var(--vertical--120);
  text-align: center;
}

/*
tour
---------------------------------------------------------------- */
/* === .section-can_we_do === */
.section-can_we_do {
  padding-top: var(--vertical--120);
}
.section-can_we_do .card-item.role-link .pic {
  margin-top: 0;
}
.section-can_we_do .report-banner {
  width: 100dvw;
  margin-inline: calc(50% - 50dvw);
  padding-inline: calc(50dvw - 50%);
  padding-block: var(--vertical--120);
  text-align: center;
  -webkit-transition: background-color var(--animation-button);
  transition: background-color var(--animation-button);
  position: relative;
}
.section-can_we_do .report-banner > .inner {
  display: grid;
  place-content: center;
  position: relative;
}
.section-can_we_do .report-banner .report-title {
  font-size: max(1.8dvw, 1.375rem);
}
.section-can_we_do .report-banner .report-title .name {
  font-weight: 700;
}
.section-can_we_do .report-banner .report-desc {
  margin-top: 1em;
  font-weight: 500;
}
.section-can_we_do .report-banner .report-desc p {
  text-align: center;
}
.section-can_we_do .report-banner .report-arrow {
  width: max(2.6dvw, 1.5rem);
  height: -webkit-max-content;
  height: -moz-max-content;
  height: max-content;
  margin: auto;
  -webkit-transition: -webkit-transform var(--animation-button);
  transition: -webkit-transform var(--animation-button);
  transition: transform var(--animation-button);
  transition: transform var(--animation-button), -webkit-transform var(--animation-button);
  position: absolute;
  inset: 0;
  left: auto;
  right: 0;
}
@media (any-hover: hover) {
  .section-can_we_do .report-banner:hover {
    background-color: var(--bg-red--hover);
  }
  .section-can_we_do .report-banner:hover .report-arrow {
    -webkit-transform: translateX(4px);
            transform: translateX(4px);
  }
}

@media screen and (max-width: 991px) and (min-width: 576px) {
  .section-can_we_do .card-item.role-link .title {
    margin-top: 0;
  }
  .section-can_we_do .report-banner .report-title {
    font-size: max(2.8254288597dvw, 1.25rem);
  }
}
@media screen and (max-width: 575px) {
  .section-can_we_do .report-banner {
    padding-bottom: calc(var(--vertical--90) * 1.25);
  }
  .section-can_we_do .report-banner .report-title {
    font-size: max(4.8695652174dvw, 1.25rem);
  }
  .section-can_we_do .report-banner .report-title > .name {
    display: block;
    margin-top: 0.5em;
  }
  .section-can_we_do .report-banner .report-arrow {
    top: calc(100% + 1.5rem);
    bottom: auto;
  }
}
/* === .section-flow === */
.section-flow {
  margin-inline: auto;
  padding: var(--vertical--120) 0;
}
.section-flow .flow-wrapper {
  margin-top: var(--space-content);
}
.section-flow .flow-item:not(:first-child) {
  margin-top: max(3dvw, 1.5rem);
}

/*
event
---------------------------------------------------------------- */
/* === .anchor-container === */
.anchor-container {
  margin-inline: calc(50% - 50dvw);
  padding-inline: calc(50dvw - 50%);
  background-color: var(--bg-gray--light);
}
.anchor-container > .inner {
  padding: 0.5rem 0;
}
.anchor-container .anchor-list {
  font-size: max(0.7dvw, 0.875rem);
}

/*
company
---------------------------------------------------------------- */
/* === .section-message === */
.section-message .title-desc {
  padding: 0;
}
.section-message .title-desc::before {
  display: none;
}
.section-message .title-desc > .inner {
  grid-template-columns: -webkit-max-content minmax(0, 1fr);
  grid-template-columns: max-content minmax(0, 1fr);
  -webkit-column-gap: 3.75rem;
     -moz-column-gap: 3.75rem;
          column-gap: 3.75rem;
}
.section-message .desc {
  justify-self: end;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-family: var(--ff-ja-secondary);
}
.section-message .desc .desc-title {
  font-weight: 700;
}
.section-message .desc p {
  font-weight: 500;
  line-height: var(--lh-wide);
  text-align: justify;
  -moz-text-align-last: start;
       text-align-last: start;
}
.section-message .desc p:not(:first-child) {
  margin-top: 1.5em;
}
.section-message .desc p.signature {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 3em;
  margin-inline: auto 0;
}

@media screen and (max-width: 991px) {
  .section-message .title-desc > .inner {
    grid-template-columns: auto;
  }
  .section-message .title-desc .desc {
    justify-self: start;
    grid-column: 1/2;
    margin-top: calc(var(--space-content) * 2);
  }
}
/* === .section-history === */
.section-history {
  padding: var(--vertical--120) 0;
}
.section-history .history-content {
  margin-top: var(--space-content);
}

/* === .section-outline === */
.section-outline {
  max-width: var(--container--xs);
  margin-inline: auto;
  padding: var(--vertical--90) 0;
}
.section-outline .outline-table {
  margin-top: var(--space-content);
}
.section-outline .business-item:not(:first-child) {
  margin-top: 0.75em;
}
.section-outline .partnership-block:not(:first-child) {
  margin-top: 2em;
}
.section-outline .partnership-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5em 0.25em;
}
.section-outline .partnership-item:not(:last-child)::after {
  content: "/";
  display: inline-block;
  margin-left: 0.25em;
}
.section-outline .note {
  margin-top: 0.5em;
}

/* === .section-access === */
.section-access {
  max-width: var(--container--xs);
  margin-inline: auto;
  padding: var(--vertical--90) 0;
}
.section-access .access-content {
  margin-top: var(--space-content);
}
.section-access .map > iframe {
  width: 100%;
  aspect-ratio: 2.4142/1;
}
.section-access .access-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5em;
  margin-top: 1.5em;
  font-size: var(--fs-md);
  line-height: var(--lh-min);
}
.section-access .access-info dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

@media screen and (max-width: 767px) {
  .section-access .map > iframe {
    aspect-ratio: 4/3;
  }
}
/* === .section-registration === */
.section-registration {
  max-width: var(--container--xs);
  margin-inline: auto;
  padding: var(--vertical--90) 0;
}
.section-registration .registration-table {
  margin-top: var(--space-content);
}

/* === .section-others === */
.section-others {
  max-width: var(--container--xs);
  margin-inline: auto;
  padding: var(--vertical--90) 0;
}
.section-others .others-content {
  margin-top: var(--space-content);
}
.section-others .file-block {
  margin-top: calc(var(--space-content) * 0.75);
}
.section-others .block-title {
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--text-gray);
}
.section-others .file-list {
  margin-top: 1em;
  font-size: var(--fs-sm);
}

/*
privacy-policy
---------------------------------------------------------------- */
/* ===  === */
/* 
@media print
---------------------------------------------------------------- */
@media print {
  *::before,
  *::after {
    -webkit-print-color-adjust: exact !important;
            print-color-adjust: exact !important;
    background-image: block !important;
    -webkit-box-shadow: none !important;
            box-shadow: none !important;
  }
  .l-wrapper {
    -webkit-print-color-adjust: exact !important;
            print-color-adjust: exact !important;
    background-attachment: scroll;
  }
  body {
    min-width: 992px;
  }
  .l-container,
  section {
    page-break-before: avoid;
  }
  section + section.new-none:not(:root) {
    page-break-before: avoid;
  }
  .new-page {
    page-break-before: always;
  }
  /* swiper */
  /* animation */
  [class^=js-],
  [class*=" js-"] {
    opacity: initial;
    visibility: visible;
  }
  .p-header,
  .p-header.is-fixed {
    position: absolute;
  }
  .js-dropdown {
    display: none;
  }
  .c-button {
    -webkit-column-gap: 1rem;
       -moz-column-gap: 1rem;
            column-gap: 1rem;
  }
  .mv {
    height: auto;
    aspect-ratio: 2000/1200;
  }
  .c-parallax-area {
    height: auto;
    aspect-ratio: 2000/1200;
  }
  .c-parallax-area .pic {
    position: static;
  }
  .p-lower-header {
    height: auto;
    aspect-ratio: 2000/1200;
  }
  .section-can_we_do {
    page-break-before: always;
  }
}/*# sourceMappingURL=style.css.map */