@charset "UTF-8";
/********************************************************/
/* -------------------------------------------
* 【rem単位の設定】
* 16pxを1remとした時の、1px分の計算用ベース
* padding: calc(24 * var(--px)); →24px相当
* font-size: calc(32 * var(--px)); → 32px相当
* ------------------------------------------- */
:root {
  --px: 0.0625rem;
  /* 1px換算 (1rem / 16) */
}

/* -------------------------------------------
 * フォントサイズのroot
 * -------------------------------------------*/
:root {
  /* --- 1 to 10 --- */
  --f1: calc(1 * var(--px));
  --f2: calc(2 * var(--px));
  --f3: calc(3 * var(--px));
  --f4: calc(4 * var(--px));
  --f5: calc(5 * var(--px));
  --f6: calc(6 * var(--px));
  --f7: calc(7 * var(--px));
  --f8: calc(8 * var(--px));
  --f9: calc(9 * var(--px));
  --f10: calc(10 * var(--px));
  /* --- 11 to 20 --- */
  --f11: calc(11 * var(--px));
  --f12: calc(12 * var(--px));
  --f13: calc(13 * var(--px));
  --f14: clamp(13 * var(--px), 100vw * 14 / 1240, 14 * var(--px));
  --f15: clamp(14 * var(--px), 100vw * 15 / 1240, 15 * var(--px));
  --f16: clamp(14 * var(--px), 100vw * 16 / 1240, 16 * var(--px));
  --f17: clamp(14 * var(--px), 100vw * 17 / 1240, 17 * var(--px));
  --f18: clamp(16 * var(--px), 100vw * 18 / 1240, 18 * var(--px));
  --f19: clamp(18 * var(--px), 100vw * 19 / 1240, 19 * var(--px));
  --f20: clamp(18 * var(--px), 100vw * 20 / 1240, 20 * var(--px));
  /* --- 21 to 30 --- */
  --f21: clamp(18 * var(--px), 100vw * 21 / 1240, 21 * var(--px));
  --f22: clamp(18 * var(--px), 100vw * 22 / 1240, 22 * var(--px));
  --f23: clamp(18 * var(--px), 100vw * 23 / 1240, 23 * var(--px));
  --f24: clamp(18 * var(--px), 100vw * 24 / 1240, 24 * var(--px));
  --f25: clamp(18 * var(--px), 100vw * 25 / 1240, 25 * var(--px));
  --f26: clamp(18 * var(--px), 100vw * 26 / 1240, 26 * var(--px));
  --f27: clamp(18 * var(--px), 100vw * 27 / 1240, 27 * var(--px));
  --f28: clamp(18 * var(--px), 100vw * 28 / 1240, 28 * var(--px));
  --f29: clamp(18 * var(--px), 100vw * 29 / 1240, 29 * var(--px));
  --f30: clamp(18 * var(--px), 100vw * 30 / 1240, 30 * var(--px));
  /* --- 31 to 40 --- */
  --f31: clamp(18 * var(--px), 100vw * 31 / 1240, 31 * var(--px));
  --f32: clamp(18 * var(--px), 100vw * 32 / 1240, 32 * var(--px));
  --f33: clamp(20 * var(--px), 100vw * 33 / 1240, 33 * var(--px));
  --f34: clamp(20 * var(--px), 100vw * 34 / 1240, 34 * var(--px));
  --f35: clamp(20 * var(--px), 100vw * 35 / 1240, 35 * var(--px));
  --f36: clamp(20 * var(--px), 100vw * 36 / 1240, 36 * var(--px));
  --f37: clamp(20 * var(--px), 100vw * 37 / 1240, 37 * var(--px));
  --f38: clamp(20 * var(--px), 100vw * 38 / 1240, 38 * var(--px));
  --f39: clamp(20 * var(--px), 100vw * 39 / 1240, 39 * var(--px));
  --f40: clamp(24 * var(--px), 100vw * 40 / 1240, 40 * var(--px));
  /* --- 41 to 50 --- */
  --f41: clamp(24 * var(--px), 100vw * 41 / 1240, 41 * var(--px));
  --f42: clamp(24 * var(--px), 100vw * 42 / 1240, 42 * var(--px));
  --f43: clamp(24 * var(--px), 100vw * 43 / 1240, 43 * var(--px));
  --f44: clamp(24 * var(--px), 100vw * 44 / 1240, 44 * var(--px));
  --f45: clamp(24 * var(--px), 100vw * 45 / 1240, 45 * var(--px));
  --f46: clamp(24 * var(--px), 100vw * 46 / 1240, 46 * var(--px));
  --f47: clamp(24 * var(--px), 100vw * 47 / 1240, 47 * var(--px));
  --f48: clamp(23 * var(--px), 100vw * 48 / 1240, 48 * var(--px));
  --f49: clamp(25 * var(--px), 100vw * 49 / 1240, 49 * var(--px));
  --f50: clamp(30 * var(--px), 100vw * 50 / 1240, 50 * var(--px));
  /* --- 51 to 60 --- */
  --f51: clamp(30 * var(--px), 100vw * 51 / 1240, 51 * var(--px));
  --f52: clamp(30 * var(--px), 100vw * 52 / 1240, 52 * var(--px));
  --f53: clamp(30 * var(--px), 100vw * 53 / 1240, 53 * var(--px));
  --f54: clamp(30 * var(--px), 100vw * 54 / 1240, 54 * var(--px));
  --f55: clamp(30 * var(--px), 100vw * 55 / 1240, 55 * var(--px));
  --f56: clamp(30 * var(--px), 100vw * 56 / 1240, 56 * var(--px));
  --f57: clamp(30 * var(--px), 100vw * 57 / 1240, 57 * var(--px));
  --f58: clamp(30 * var(--px), 100vw * 58 / 1240, 58 * var(--px));
  --f59: clamp(30 * var(--px), 100vw * 59 / 1240, 59 * var(--px));
  --f60: clamp(30 * var(--px), 100vw * 60 / 1240, 60 * var(--px));
  /* --- 61 to 70 --- */
  --f61: clamp(30 * var(--px), 100vw * 61 / 1240, 61 * var(--px));
  --f62: clamp(30 * var(--px), 100vw * 62 / 1240, 62 * var(--px));
  --f63: clamp(30 * var(--px), 100vw * 63 / 1240, 63 * var(--px));
  --f64: clamp(30 * var(--px), 100vw * 64 / 1240, 64 * var(--px));
  --f65: clamp(30 * var(--px), 100vw * 65 / 1240, 65 * var(--px));
  --f66: clamp(30 * var(--px), 100vw * 66 / 1240, 66 * var(--px));
  --f67: clamp(30 * var(--px), 100vw * 67 / 1240, 67 * var(--px));
  --f68: clamp(30 * var(--px), 100vw * 68 / 1240, 68 * var(--px));
  --f69: clamp(30 * var(--px), 100vw * 69 / 1240, 69 * var(--px));
  --f70: clamp(30 * var(--px), 100vw * 70 / 1240, 70 * var(--px));
  /* --- 71 to 80 --- */
  --f71: clamp(30 * var(--px), 100vw * 71 / 1240, 71 * var(--px));
  --f72: clamp(30 * var(--px), 100vw * 72 / 1240, 72 * var(--px));
  --f73: clamp(30 * var(--px), 100vw * 73 / 1240, 73 * var(--px));
  --f74: clamp(30 * var(--px), 100vw * 74 / 1240, 74 * var(--px));
  --f75: clamp(30 * var(--px), 100vw * 75 / 1240, 75 * var(--px));
  --f76: clamp(30 * var(--px), 100vw * 76 / 1240, 76 * var(--px));
  --f77: clamp(30 * var(--px), 100vw * 77 / 1240, 77 * var(--px));
  --f78: clamp(30 * var(--px), 100vw * 78 / 1240, 78 * var(--px));
  --f79: clamp(30 * var(--px), 100vw * 79 / 1240, 79 * var(--px));
  --f80: clamp(30 * var(--px), 100vw * 80 / 1240, 80 * var(--px));
  /* --- 81 to 90 --- */
  --f81: clamp(30 * var(--px), 100vw * 81 / 1240, 81 * var(--px));
  --f82: clamp(30 * var(--px), 100vw * 82 / 1240, 82 * var(--px));
  --f83: clamp(30 * var(--px), 100vw * 83 / 1240, 83 * var(--px));
  --f84: clamp(30 * var(--px), 100vw * 84 / 1240, 84 * var(--px));
  --f85: clamp(30 * var(--px), 100vw * 85 / 1240, 85 * var(--px));
  --f86: clamp(30 * var(--px), 100vw * 86 / 1240, 86 * var(--px));
  --f87: clamp(30 * var(--px), 100vw * 87 / 1240, 87 * var(--px));
  --f88: clamp(30 * var(--px), 100vw * 88 / 1240, 88 * var(--px));
  --f89: clamp(30 * var(--px), 100vw * 89 / 1240, 89 * var(--px));
  --f90: clamp(30 * var(--px), 100vw * 90 / 1240, 90 * var(--px));
  /* --- 91 to 100 --- */
  --f91: clamp(30 * var(--px), 100vw * 91 / 1240, 91 * var(--px));
  --f92: clamp(30 * var(--px), 100vw * 92 / 1240, 92 * var(--px));
  --f93: clamp(30 * var(--px), 100vw * 93 / 1240, 93 * var(--px));
  --f94: clamp(30 * var(--px), 100vw * 94 / 1240, 94 * var(--px));
  --f95: clamp(30 * var(--px), 100vw * 95 / 1240, 95 * var(--px));
  --f96: clamp(30 * var(--px), 100vw * 96 / 1240, 96 * var(--px));
  --f97: clamp(30 * var(--px), 100vw * 97 / 1240, 97 * var(--px));
  --f98: clamp(30 * var(--px), 100vw * 98 / 1240, 98 * var(--px));
  --f99: clamp(30 * var(--px), 100vw * 99 / 1240, 99 * var(--px));
  --f100: clamp(30 * var(--px), 100vw * 100 / 1240, 100 * var(--px));
  /* --- 101 to 110 --- */
  --f101: clamp(30 * var(--px), 100vw * 101 / 1240, 101 * var(--px));
  --f102: clamp(30 * var(--px), 100vw * 102 / 1240, 102 * var(--px));
  --f103: clamp(30 * var(--px), 100vw * 103 / 1240, 103 * var(--px));
  --f104: clamp(30 * var(--px), 100vw * 104 / 1240, 104 * var(--px));
  --f105: clamp(30 * var(--px), 100vw * 105 / 1240, 105 * var(--px));
  --f106: clamp(30 * var(--px), 100vw * 106 / 1240, 106 * var(--px));
  --f107: clamp(30 * var(--px), 100vw * 107 / 1240, 107 * var(--px));
  --f108: clamp(30 * var(--px), 100vw * 108 / 1240, 108 * var(--px));
  --f109: clamp(30 * var(--px), 100vw * 109 / 1240, 109 * var(--px));
  --f110: clamp(30 * var(--px), 100vw * 110 / 1240, 110 * var(--px));
  /* --- 111 to 120 --- */
  --f111: clamp(30 * var(--px), 100vw * 111 / 1240, 111 * var(--px));
  --f112: clamp(30 * var(--px), 100vw * 112 / 1240, 112 * var(--px));
  --f113: clamp(30 * var(--px), 100vw * 113 / 1240, 113 * var(--px));
  --f114: clamp(30 * var(--px), 100vw * 114 / 1240, 114 * var(--px));
  --f115: clamp(30 * var(--px), 100vw * 115 / 1240, 115 * var(--px));
  --f116: clamp(30 * var(--px), 100vw * 116 / 1240, 116 * var(--px));
  --f117: clamp(30 * var(--px), 100vw * 117 / 1240, 117 * var(--px));
  --f118: clamp(30 * var(--px), 100vw * 118 / 1240, 118 * var(--px));
  --f119: clamp(30 * var(--px), 100vw * 119 / 1240, 119 * var(--px));
  --f120: clamp(30 * var(--px), 100vw * 120 / 1240, 120 * var(--px));
}

/* -------------------------------------------
* カラー変数
* -------------------------------------------*/
:root {
  --base-text: #373030;
  --blue-green: #5C9FB1;
  --blue-green-light: #6BA8B7;
  --brown: #6A5C4F;
  --ivory: #F8F6F1;
  --orange: #EE9A75;
  --purple: #6370C4;
  --pink: #DB87CC;
}

/* -------------------------------------------
 * フォントファミリー
 * -------------------------------------------*/
:root {
  --jp: "NotoSansJP", sans-serif;
  --en: "Inter", sans-serif;
  --notoserif: "Noto Serif JP", serif;
}

/********************************************************/
html {
  font-size: 100%;
  -webkit-tap-highlight-color: transparent;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  overflow-x: clip;
  font-size: var(--f16);
  color: var(--base-text);
  background: #fff;
  font-family: var(--jp);
  font-weight: normal;
  height: 100%;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  line-height: 2;
  width: 100%;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-kerning: normal;
          font-kerning: normal;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}

/* -------------------------------------------
 * 共通スタイル
 * -------------------------------------------*/
a[href^="tel:"] {
  pointer-events: none;
}
@media (max-width: 834px) {
  a[href^="tel:"] {
    pointer-events: all;
  }
}

/* -------------------------------------------
 * インナー幅、余白
 * -------------------------------------------*/
.inner--1200 {
  width: min(90%, 1200 * var(--px));
  margin-inline: auto;
}

.inner--1350 {
  width: min(90%, 1350 * var(--px));
  margin-inline: auto;
}

.inner--1600 {
  width: min(90%, 1600 * var(--px));
  margin-inline: auto;
}

/* -------------------------------------------
 * 改行
 * -------------------------------------------*/
.no-scroll {
  overflow: hidden;
  height: 100vh;
}

.br-sp {
  display: none;
}
@media (max-width: 834px) {
  .br-sp {
    display: block;
  }
}

.no-br-sp {
  display: block;
}
@media (max-width: 834px) {
  .no-br-sp {
    display: none;
  }
}

/* -------------------------------------------
 * 見出し
 * -------------------------------------------*/
.section__title-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  line-height: 1.8;
  margin-bottom: calc(40 * var(--px));
}
@media (max-width: 834px) {
  .section__title-wrap {
    margin-bottom: calc(20 * var(--px));
  }
}

.section__title--ja {
  font-size: var(--f24);
}

.section__title--en {
  font-size: var(--f18);
}

.section__title-wrap--left {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.section__title-wrap--center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

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

/* -------------------------------------------
 * ボタン、リンク
 * -------------------------------------------*/
/*  ボタン共通 */
.button {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: calc(3 * var(--px)) calc(16 * var(--px)) calc(3 * var(--px)) calc(20 * var(--px));
  min-width: calc(146 * var(--px));
  border-radius: 100vmax;
  border: solid 1px #222;
  background: #fff;
  color: #222;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: calc(20 * var(--px));
  font-size: var(--f16);
  position: relative;
  -webkit-transition: background 0.3s cubic-bezier(0.08, 0.355, 0.11, 1);
  transition: background 0.3s cubic-bezier(0.08, 0.355, 0.11, 1);
  margin-top: calc(30 * var(--px));
}
.button:hover {
  background: #222;
  color: #fff;
}

.button--center {
  margin-inline: auto;
}

/* -------------------------------------------
 * ヘッダー
 * -------------------------------------------*/
:root {
  --header-height-pc: calc(92 * var(--px));
  --header-height-sp: calc(69 * var(--px));
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--header-height-pc);
  z-index: 1000;
  -webkit-transition: background 0.3s;
  transition: background 0.3s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.header.is-scrolled {
  background: rgba(255, 255, 255, 0.5);
}
@media (max-width: 834px) {
  .header {
    height: var(--header-height-sp);
  }
}

.header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__logo {
  width: calc(200 * var(--px));
  height: auto;
  display: block;
  position: relative;
  z-index: 999;
  margin: 0;
}

.header__logo-link {
  display: block;
  width: 100%;
  height: auto;
}

.header__nav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: calc(30 * var(--px));
}
@media (max-width: 834px) {
  .header__nav-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: calc(20 * var(--px));
  }
}

@media (max-width: 834px) {
  .header__nav {
    opacity: 0;
    visibility: hidden;
    position: fixed;
    top: 0;
    right: 0;
    height: 100%;
    width: 100%;
    z-index: 99;
    margin: 0;
    padding: min(40vw, 220 * var(--px)) 19% calc(80 * var(--px));
    overflow-y: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    gap: 0;
  }
  .header__nav::before {
    content: "";
    width: 100%;
    inset: 0;
    position: fixed;
    background: #fff;
    z-index: -1;
  }
  .header__nav {
    -webkit-transition: opacity 0.4s ease, visibility 0.4s ease, z-index 0s 0.4s;
    transition: opacity 0.4s ease, visibility 0.4s ease, z-index 0s 0.4s;
  }
}

/* -------------------------------------------
 * ドロワーメニュー（開閉状態）
 * -------------------------------------------*/
[data-drawer-open=true] .header__nav {
  opacity: 1;
  visibility: visible;
  z-index: 99;
  -webkit-transition: opacity 0.4s ease, visibility 0.4s ease, z-index 0s 0s;
  transition: opacity 0.4s ease, visibility 0.4s ease, z-index 0s 0s;
}
[data-drawer-open=true] .header__nav .header__nav-link {
  font-size: var(--f16);
}

.header__nav-link {
  font-size: var(--f18);
  line-height: 1.4;
}

.header__nav-item {
  text-align: center;
}

/* -------------------------------------------
 * ハンバーガーボタン
 * -------------------------------------------*/
:root {
  --bars-width: min(calc(56 / var(--vw-min-sp) * 100vw), calc(56 * var(--px)));
  --bars-height: min(calc(32 / var(--vw-min-sp) * 100vw), calc(32 * var(--px)));
  --bar-height: min(calc(1 / var(--vw-min-sp) * 100vw), calc(1 * var(--px)));
  --bars-y-translate: calc((var(--bars-height) - var(--bar-height)) / 2);
  --bars-rotate: 45deg;
}

.nav-button {
  width: calc(56 * var(--px));
  height: calc(33 * var(--px));
  text-align: center;
  position: relative;
  z-index: 100;
  border: none;
  display: none;
  cursor: pointer;
  pointer-events: auto;
}
@media (max-width: 834px) {
  .nav-button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

/* -------------------------------------------
 * ハンバーガーボタン（開閉状態）
 * -------------------------------------------*/
[data-drawer-open=true] .nav-button__bars > span:nth-of-type(1) {
  -webkit-transform: translateY(var(--bars-y-translate)) rotate(calc(-1 * var(--bars-rotate)));
          transform: translateY(var(--bars-y-translate)) rotate(calc(-1 * var(--bars-rotate)));
}
[data-drawer-open=true] .nav-button__bars > span:nth-of-type(2) {
  display: none;
}
[data-drawer-open=true] .nav-button__bars > span:nth-of-type(3) {
  -webkit-transform: translateY(calc(var(--bars-y-translate) * -1)) rotate(var(--bars-rotate));
          transform: translateY(calc(var(--bars-y-translate) * -1)) rotate(var(--bars-rotate));
}

.nav-button__bars,
.nav-button__bars span {
  display: inline-block;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

.nav-button__bars {
  position: relative;
  width: var(--bars-width);
  height: var(--bars-height);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.nav-button__bars span {
  width: 100%;
  height: var(--bar-height);
  background: var(--base-text);
}

.nav-button__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

/* -------------------------------------------
 * フッター
 * -------------------------------------------*/
.footer {
  padding-block: calc(67 * var(--px)) calc(39 * var(--px));
  background-color: #ddd;
  color: #000;
  z-index: 10;
  margin-top: calc(120 * var(--px));
}
@media (max-width: 834px) {
  .footer {
    padding-block: calc(30 * var(--px)) 0;
    margin-top: calc(60 * var(--px));
  }
}

.footer__top {
  display: grid;
  grid-template-columns: auto 50%;
  gap: calc(30 * var(--px)) calc(2 * var(--px));
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: calc(365 * var(--px));
}
@media (max-width: 834px) {
  .footer__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (max-width: 834px) {
  .footer__top {
    -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;
    margin-bottom: calc(80 * var(--px));
  }
}

.footer__logo {
  width: calc(228 * var(--px));
  -webkit-transition: opacity ease-in-out 0.3s;
  transition: opacity ease-in-out 0.3s;
}
.footer__logo:hover {
  opacity: 0.7;
}
@media (max-width: 499px) {
  .footer__logo {
    margin-bottom: calc(30 * var(--px));
    width: calc(180 * var(--px));
  }
}

.footer__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-column-gap: 10%;
     -moz-column-gap: 10%;
          column-gap: 10%;
}
@media (max-width: 834px) {
  .footer__nav {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
  }
}
@media (max-width: 499px) {
  .footer__nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.footer__nav-item {
  text-align: center;
}

.footer-nav__item-link {
  font-size: var(--f18);
  line-height: 1.4;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: calc(5 * var(--px));
  text-align: center;
}

.footer__nav-item {
  font-size: var(--f18);
  font-weight: 600;
}

.footer__nav-item + .footer__nav-item {
  margin-top: calc(10 * var(--px));
}

.footer__nav-child {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: calc(10 * var(--px));
  margin-block: calc(10 * var(--px)) calc(20 * var(--px));
}

.footer__nav-child-item {
  font-size: var(--f16);
  font-weight: normal;
  line-height: 1.4;
  padding-left: calc(16 * var(--px));
  position: relative;
}
.footer__nav-child-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.6em;
  width: calc(8 * var(--px));
  height: calc(1 * var(--px));
  background-color: #000;
  border-radius: 100vmax;
}

@media (max-width: 834px) {
  .footer__nav-col + .footer__nav-col {
    margin-top: calc(10 * var(--px));
  }
}

.footer__list-heading {
  line-height: 1.2;
  margin-bottom: calc(10 * var(--px));
}

.footer__copy {
  font-size: var(--f13);
}

/* -------------------------------------------
 * 下層
 * -------------------------------------------*/
body.under {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  min-height: 100vh;
}

.under-main {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding-top: calc(200 * var(--px));
}
@media (max-width: 834px) {
  .under-main {
    padding-top: calc(120 * var(--px));
  }
}

/* -------------------------------------------
 * 下層ページ見出し
 * -------------------------------------------*/
.under-fv {
  margin-bottom: calc(60 * var(--px));
}
@media (max-width: 834px) {
  .under-fv {
    margin-bottom: calc(30 * var(--px));
  }
}

.under-fv__title-wrap {
  line-height: 1.3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: calc(10 * var(--px));
  margin-bottom: calc(20 * var(--px));
}

.under-fv__title--en {
  font-size: var(--f60);
}

.under-fv__title--ja {
  font-size: var(--f20);
}

.under-fv__img {
  width: min(90%, 1350 * var(--px));
  margin-inline: auto;
}
@media (max-width: 834px) {
  .under-fv__img {
    width: 100%;
  }
}

/* -------------------------------------------
 * パンくずリスト
 * -------------------------------------------*/
.breadcrumbs-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-bottom: calc(20 * var(--px));
}

.breadcrumbs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: calc(10 * var(--px));
}
@media (max-width: 834px) {
  .breadcrumbs {
    gap: calc(6 * var(--px));
  }
}
.breadcrumbs li {
  display: inline-block;
}
.breadcrumbs li:not(:last-child)::after {
  content: "›";
  padding-inline: calc(14 * var(--px));
  font-size: var(--f20);
  line-height: 1;
}
@media (max-width: 834px) {
  .breadcrumbs li:not(:last-child)::after {
    padding-inline: calc(12 * var(--px));
    font-size: calc(15 * var(--px));
  }
}

.breadcrumbs__item-link {
  line-height: 1;
}

/* -------------------------------------------
 * 404ページ
 * -------------------------------------------*/
.error-404__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.error-404__text {
  text-align: center;
  margin-block: calc(30 * var(--px));
}
@media (max-width: 834px) {
  .error-404__text {
    text-align: left;
  }
}

/* -------------------------------------------
 * カスタム投稿タイプcolumn共通
 * -------------------------------------------*/
.column__date {
  font-size: var(--f16);
}

.column__title {
  font-size: var(--f24);
  font-weight: bold;
}

.column__category {
  border-radius: 100vmax;
  border: 1px solid #000;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.5em 1em;
  font-size: var(--f13);
  margin-bottom: calc(20 * var(--px));
}

.column__tag {
  border-radius: 100vmax;
  border: 1px solid #000;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.5em 1em;
  font-size: var(--f13);
  margin-bottom: calc(20 * var(--px));
}

.column__thumbnail img {
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  width: 100%;
  height: auto;
}

.column__text {
  font-size: var(--f16);
}

/* -------------------------------------------
 * アニメーション / フェードアップ
 * -------------------------------------------*/
.js-fadeup {
  opacity: 0;
  -webkit-transform: translateY(calc(10 * var(--px)));
          transform: translateY(calc(10 * var(--px)));
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transition-duration: 1000ms;
          transition-duration: 1000ms;
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
  -webkit-transition-delay: calc(200ms + var(--fade-in-delay, 0s));
          transition-delay: calc(200ms + var(--fade-in-delay, 0s));
}

.js-fadeup.is-visible {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/* -------------------------------------------
 * アニメーション / フェードイン
 * -------------------------------------------*/
.js-fadein {
  opacity: 0;
  -webkit-transition-property: opacity;
  transition-property: opacity;
  -webkit-transition-duration: 1000ms;
          transition-duration: 1000ms;
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
  -webkit-transition-delay: calc(200ms + var(--fade-in-delay, 0s));
          transition-delay: calc(200ms + var(--fade-in-delay, 0s));
}

.js-fadein.is-visible {
  opacity: 1;
}/*# sourceMappingURL=style.css.map */