@charset "UTF-8";
:root {
  --design-width-pc: 1400;
  --design-width-sp: 375;
}
:root {
  --color-white: #eee.c-logo.-type2 .c-logo__txt {
    width: 11.5rem;
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
    margin-left: 0.8rem;
  }
  --color-transp: #00000000;
  --color-main: #3c8;
  --color-main2: #0bf;
  --color-main-white: #f5f6f4;
  --color-main-gray: #eee;
  --color-accent: #f46;
  --color-accent2: #fc3;
  --color-bg: var(--color-gradation);
  --color-bg2: var(--color-main-white);
  --color-bg3: #d5d6d3;
  --color-bg4: #ffffff;
  --color-bg5: #e8ebe8;
  --color-bg6: #cacdd0;
  --color-bg7: #f2f2f1;
  --color-bg8: rgba(0, 0, 0, 0.3);
  --color-txt: var(--color-main-gray);
  --color-txt2: var(--color-main);
  --color-txt3: #000;
  --color-txt4: #21a2af;
  --color-txt5: #333;
  --color-txt6: #f4b700;
  --color-gradation: linear-gradient(
    90deg,
    var(--color-main2),
    var(--color-main)
  );
  --color-gradation2: linear-gradient(
    90deg,
    var(--color-accent2),
    var(--color-accent)
  );
  --color-gradation2-0deg: linear-gradient(
    0deg,
    var(--color-accent2),
    var(--color-accent)
  );
  --color-gradation3: linear-gradient(
    90deg,
    var(--color-main) 20%,
    var(--color-main2) 80%
  );
  --color-hover-gradation: linear-gradient(
    90deg,
    var(--color-transp) 8.1173%,
    rgba(158, 217, 172, 0.6) 57.9481%,
    #004514 93.5544%
  );
  --color-hover-gradation2: linear-gradient(
    90deg,
    var(--color-transp) 7.4798%,
    rgba(64, 179, 243, 0.6) 57.4286%,
    #001d4d 93.5811%
  );
  --color-hover-gradation3: linear-gradient(
    90deg,
    var(--color-transp) 6.534%,
    rgba(242, 181, 0, 0.6) 57.2947%,
    #d5007a 93.8602%
  );
  --color-hover-gradation4: linear-gradient(
    90deg,
    var(--color-transp) 6.534%,
    rgba(242, 181, 0, 0.8) 44.3212%,
    #d5007a 82.8448%
  );
  --color-blend: #000c1e;
  --color-shadow-gradation: linear-gradient(
    90deg,
    #011341,
    var(--color-transp) 84%
  );
  --color-shadow-gradation2: linear-gradient(
    90deg,
    #3d5d90,
    var(--color-transp) 84%
  );
  --color-line: #b7b9b5;
  --color-accordion-bg: var(--color-main-gray);
  --color-accordion-txt: var(--color-main);
  --color-scrollbar-bg: var(--color-main);
  --color-scrollbar-track: var(--color-main);
  --color-form-bg: var(--color-white);
  --color-form-bg-hover: var(--color-main-white);
  --color-form-caption: #6c8ea1;
  --color-form-scrollbar: var(--color-main);
  --color-ui-required: #d70578;
  --color-modal-bg: rgba(0, 31, 65, 0.6);
  --color-modal-txt: #ffffff;
}
.theme-gradation {
  --theme-color: var(--color-gradation);
}
.theme-gradation2 {
  --theme-color: var(--color-gradation2);
}
.theme-white {
  background: var(--color-bg4) !important;
  color: var(--color-txt2);
  --color-accordion-bg: var(--color-main);
  --color-accordion-txt: var(--color-txt);
}
:root {
  --easeInSine: cubic-bezier(0.47, 0, 0.745, 0.715);
  --easeOutSine: cubic-bezier(0.39, 0.575, 0.565, 1);
  --easeInOutSine: cubic-bezier(0.445, 0.05, 0.55, 0.95);
  --easeInQuad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --easeOutQuad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --easeInOutQuad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --easeInCubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --easeOutCubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --easeInOutCubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --easeInQuart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
  --easeOutQuart: cubic-bezier(0.165, 0.84, 0.44, 1);
  --easeInOutQuart: cubic-bezier(0.77, 0, 0.175, 1);
  --easeInQuint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  --easeOutQuint: cubic-bezier(0.23, 1, 0.32, 1);
  --easeInOutQuint: cubic-bezier(0.86, 0, 0.07, 1);
  --easeInExpo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
  --easeOutExpo: cubic-bezier(0.19, 1, 0.22, 1);
  --easeInOutExpo: cubic-bezier(1, 0, 0, 1);
  --easeInCirc: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --easeOutCirc: cubic-bezier(0.075, 0.82, 0.165, 1);
  --easeInOutCirc: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --easeInBack: cubic-bezier(0.6, -0.28, 0.735, 0.045);
  --easeOutBack: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  --easeInOutBack: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
:root {
  --font-sans-serif: IBM Plex Sans Condensed, sans-serif;
  --font-gothic: Noto Sans JP, sans-serif;
  --font-mix: Outfit, Noto Sans JP, sans-serif;
}
:root {
  --font-size10: 10px;
  --font-size11: 11px;
  --font-size12: max(1.2rem, 11px);
  --font-size13: max(1.3rem, 12px);
  --font-size14: max(1.4rem, 12px);
  --font-size15: max(1.5rem, 13px);
  --font-size16: max(1.6rem, 14px);
  --font-size17: max(1.7rem, 15px);
  --font-size18: max(1.8rem, 15px);
  --font-size19: max(1.9rem, 16px);
  --font-size20: max(2rem, 16px);
  --font-size22: max(2.2rem, 18px);
  --font-size24: max(2.4rem, 20px);
  --font-size26: max(2.6rem, 25px);
  --font-size27: max(2.7rem, 24px);
  --font-size28: max(2.8rem, 24px);
  --font-size30: max(3rem, 24px);
  --font-size31: max(3.1rem, 28px);
  --font-size32: max(3.2rem, 28px);
  --font-size34: max(3.4rem, 30px);
  --font-size35: max(3.5rem, 30px);
  --font-size36: max(3.6rem, 30px);
  --font-size38: max(3.8rem, 32px);
  --font-size40: max(4rem, 36px);
  --font-size42: max(4.2rem, 36px);
  --font-size44: max(4.4rem, 38px);
  --font-size45: max(4.5rem, 38px);
  --font-size48: max(4.8rem, 40px);
  --font-size50: max(5rem, 40px);
  --font-size52: max(5.2rem, 42px);
  --font-size56: max(5.6rem, 46px);
  --font-size58: max(5.8rem, 46px);
  --font-size60: max(6rem, 50px);
  --font-size70: 7rem;
  --font-size71: 7.1rem;
  --font-size74: 7.4rem;
  --font-size75: 7.5rem;
  --font-size76: 7.6rem;
  --font-size84: 8.4rem;
  --font-size94: 9.4rem;
  --font-size183: 18.3rem;
  --font-size186: 18.6rem;
  --font-en-top: -0.14em;
  --font-en-bottom: -0.13em;
}
body:not(.use-max) {
  --font-size12: 12px;
  --font-size13: 13px;
  --font-size14: 14px;
  --font-size15: 1.5rem;
  --font-size16: 1.6rem;
  --font-size17: 1.7rem;
  --font-size18: 1.8rem;
  --font-size19: 1.9rem;
  --font-size20: 2rem;
  --font-size22: 2.2rem;
  --font-size24: 2.4rem;
  --font-size26: 2.6rem;
  --font-size27: 2.7rem;
  --font-size28: 2.8rem;
  --font-size30: 3rem;
  --font-size31: 3.1rem;
  --font-size32: 3.2rem;
  --font-size34: 3.4rem;
  --font-size35: 3.5rem;
  --font-size36: 3.6rem;
  --font-size38: 3.8rem;
  --font-size40: 4rem;
  --font-size42: 4.2rem;
  --font-size44: 4.4rem;
  --font-size45: 4.5rem;
  --font-size50: 5rem;
  --font-size52: 5.2rem;
  --font-size56: 5.6rem;
  --font-size58: 5.8rem;
  --font-size60: 6rem;
}
:root {
  --radius-size5: 0.5rem;
  --radius-size7: 0.7rem;
  --radius-size10: 1rem;
  --radius-size13: 1.3rem;
  --radius-size15: 1.5rem;
  --radius-size15-2: 1.5rem;
  --radius-size16: 1.6rem;
  --radius-size20: 2rem;
  --radius-size20-2: 2rem;
  --radius-size30: 3rem;
  --radius-size40: 4rem;
  --radius-size45: 4.5rem;
  --radius-size45-2: 4.5rem;
  --radius-size50: 5rem;
  --radius-size70: 7rem;
  --radius-size70-2: 7rem;
  --radius-size70-3: 7rem;
  --radius-size70-4: 7rem;
  --radius-size100: 10rem;
  --radius-size100-2: 10rem;
  --radius-size150: 15rem;
}
@media screen and (max-width: 1023px) {
  :root {
    --radius-size7: 0.5rem;
    --radius-size13: 1.1rem;
    --radius-size15: 1rem;
    --radius-size16: 1rem;
    --radius-size20: 1.5rem;
    --radius-size20-2: 1rem;
    --radius-size30: 2rem;
    --radius-size40: 1.5rem;
    --radius-size45-2: 3rem;
    --radius-size50: 3rem;
    --radius-size70: 2rem;
    --radius-size70-2: 4rem;
    --radius-size70-3: 5rem;
    --radius-size70-4: 3rem;
    --radius-size100: 1.5rem;
    --radius-size100-2: 5rem;
    --radius-size150: 10rem;
  }
}
:root {
  --shadow: 0 0 4rem rgba(0, 0, 0, 0.3);
  --shadow-sticky: 0 0 0 0 rgba(0, 0, 0, 0);
  --shadow-sticky--sticky: 0 0 3em 0 rgba(0, 0, 0, 0.25);
}
:root {
  --contents-pct: calc((339 / var(--design-width-sp)) * 100%);
  --contents-outside-vw: calc(18 / var(--design-width-sp) * 100vw);
}
:root {
  --slope-angle: 7.5;
  --slope-tan: 0.1316524976;
  --slope: skewY(-7.5deg);
  --slope--positive: skewY(7.5deg);
  --slope-height: calc(100vw * var(--slope-tan));
}
:root {
  --ease-level1: var(--easeOutQuart);
  --ease-level2: var(--easeOutQuint);
  --ease-heavy1: var(--easeInOutQuart);
  --ease-heavy2: var(--easeInOutQuint);
  --ease-heavy3: var(--easeOutBack);
  --transition-delay: var(--ease-level1);
  --transition-hover: 400ms var(--ease-level1);
  --transition-hover-slow: 800ms var(--ease-level1);
  --transition-hover-slow2: 1200ms var(--ease-heavy2);
  --transition-down-fade: 2800ms var(--ease-heavy1);
  --transition-modal: 1000ms var(--ease-level2);
  --transition-modal-opacity: 800ms var(--ease-level1);
  --transition-sticky: 300ms var(--ease-level1);
  --transition-accordion: 500ms var(--ease-level1);
  --transition-stalker: 600ms var(--ease-level1);
  --transition-loopslider-track: 200ms ease;
  --transition-slider-basic: 1600ms var(--ease-level1);
  --transition-slider: 2000ms var(--ease-heavy1);
  --transition-slider-gradation: 2700ms linear;
  --transition-carousel-change: 400ms ease;
  --transition-fade: 1500ms var(--ease-level2);
  --transition-fadeup: 1500ms var(--ease-level2);
  --transition-fadeup-slow: 2400ms var(--ease-level2);
  --transition-scale: 4000ms var(--ease-level2);
  --transition-scale2: 800ms var(--ease-heavy3);
  --transition-split: 1200ms var(--ease-level2);
  --transition-shadow: 1200ms var(--ease-level2);
  --transition-and: 1800ms var(--ease-heavy2);
  --transition-and-delay-dot: 2450ms;
  --transition-and-delay-title: 3000ms;
  --transition-loopslider-horizontal: 10000ms;
  --transition-loopslider-vertical-slope: 100000ms;
  --transition-loopslider-vertical-slope: 10000ms;
}
:root {
  --z-index-: -1;
  --z-index-l-main: 0;
  --z-index-l-footer: 10;
  --z-index-l-contact: 100;
  --z-index-: -1;
  --z-index-l-header: 10000;
  --z-index-c-overlay: 100000;
  --z-index-js-modal: 1000000;
  --z-index-l-sitemap: 10000000;
}
abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: 0 0;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section {
  display: block;
}
body {
  line-height: 1;
}
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  font-weight: 400;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote::after,
blockquote::before,
q::after,
q::before {
  content: "";
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
img,
picture {
  max-width: 100%;
}
picture {
  display: block;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  padding: 0;
}
a img {
  border: none;
}
a {
  background: 0 0;
  vertical-align: baseline;
  font-size: 100%;
  text-decoration: none;
  cursor: pointer;
}
a:hover,
a:hover img {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
a,
button,
small,
span,
time {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}
template {
  display: none;
}
button,
input,
select,
textarea {
  margin: 0;
  padding: 0;
  background: 0 0;
  border: none;
  border-radius: 0;
  outline: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  box-sizing: border-box;
  cursor: pointer;
}
textarea {
  resize: vertical;
  overflow: auto;
}
[type="file"] {
  line-height: 1 !important;
}
select::-ms-expand {
  display: none;
}
select::-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #fff;
}
input:-webkit-autofill,
option:-webkit-autofill,
select:-webkit-autofill {
  -webkit-text-fill-color: #000 !important;
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
}
*,
::after,
::before {
  box-sizing: border-box;
}
html {
  height: 100vh;
  font-size: 62.5%;
}
@media screen and (max-width: 1280px) and (min-width: 1024px) {
  html {
    font-size: 0.78125vw;
  }
}
@media screen and (max-width: 767px) and (min-width: 561px) {
  html {
    font-size: 1.30378vw;
  }
}
@media screen and (max-width: 375px) {
  html {
    font-size: 2.66667vw;
  }
}
body {
  width: 100%;
  background: var(--color-bg);
  color: var(--color-txt);
  font-family: "Antonio", sans-serif;
  font-family: "Noto Sans JP", sans-serif;
  font-family: var(--font-gothic);
  font-weight: 500;
  font-size: 1rem;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  text-rendering: geometricPrecision;
  text-decoration-thickness: 1px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.2);
  -webkit-overflow-scrolling: touch;
  overflow-x: hidden;
  overflow-y: scroll;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 500;
}
address,
dd,
dt,
li,
td,
th {
  font-size: inherit;
  line-height: inherit;
}
ol,
ul {
  list-style-position: inside;
}
a,
button,
input,
select,
textarea {
  transition: all var(--transition-hover);
}
button,
input,
select,
textarea {
  font-family: inherit;
}
svg {
  fill: currentColor;
  transition: fill var(--transition-hover);
}
body.ua-chrome img {
  image-rendering: -webkit-optimize-contrast;
}
[id^="area-"] {
  margin-top: -8rem;
  padding-top: 8rem;
}
@-webkit-keyframes down-fade {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -200%, 0);
    transform: translate3d(0, -200%, 0);
  }
  20% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: translate3d(0, 500%, 0);
    transform: translate3d(0, 500%, 0);
  }
}
@keyframes down-fade {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -200%, 0);
    transform: translate3d(0, -200%, 0);
  }
  20% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: translate3d(0, 500%, 0);
    transform: translate3d(0, 500%, 0);
  }
}
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}
.slick-slider:not(.slick-initialized) {
  height: 0;
  overflow: hidden;
}
.slick-list {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: 0;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}
.slick-slider .slick-list,
.slick-slider .slick-track {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: flex-start;
  transition-timing-function: var(--ease-level2) !important;
}
[dir="rtl"] {
  flex-direction: row-reverse;
}
.slick-track:after,
.slick-track:before {
  display: table;
  content: "";
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}
.slick-slide {
  min-height: 1px;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
  display: none;
}
.c-and {
  position: relative;
  display: block;
  fill: var(--color-txt);
  pointer-events: none;
}
body.ua-firefox .c-and,
body.ua-safari .c-and.-type2 {
  opacity: 0;
  -webkit-transform: translate3d(0, 2rem, 0) rotate(0.001deg);
  transform: translate3d(0, 2rem, 0) rotate(0.001deg);
}
body.ua-firefox .c-and :not(span),
body.ua-safari .c-and.-type2 :not(span) {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
}
body.ua-firefox .c-and .c-and__4,
body.ua-safari .c-and.-type2 .c-and__4 {
  display: none;
}
body.ua-firefox .c-and image,
body.ua-safari .c-and.-type2 image {
  -webkit-mask: none;
  mask: none;
}
body.ua-firefox .c-and.is-shown,
body.ua-firefox .is-shown .c-and,
body.ua-safari .c-and.is-shown.-type2,
body.ua-safari .is-shown .c-and.-type2 {
  opacity: 1 !important;
  -webkit-transform: translate3d(0, 0, 0) rotate(0.001deg) !important;
  transform: translate3d(0, 0, 0) rotate(0.001deg) !important;
  transition: var(--transition-fadeup);
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  transition-delay: 0.6s;
}
.c-and image {
  width: 100%;
  height: 100%;
  -webkit-mask: url(#c-and__clip-mask);
  mask: url(#c-and__clip-mask);
}
.c-and.is-shown .c-and__1,
.c-and.is-shown .c-and__2,
.is-shown .c-and .c-and__1,
.is-shown .c-and .c-and__2 {
  stroke-dashoffset: 0;
}
.c-and.is-shown .c-and__3,
.c-and.is-shown .c-and__4 path,
.c-and.is-shown .c-and__txt,
.is-shown .c-and .c-and__3,
.is-shown .c-and .c-and__4 path,
.is-shown .c-and .c-and__txt {
  opacity: 1;
}
.c-and__1,
.c-and__2 {
  fill: none;
  stroke: var(--color-white);
  stroke-miterlimit: 10;
  stroke-width: 16px;
  stroke-opacity: 1;
  transition: var(--transition-and);
}
.c-and__1 {
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
}
.c-and__2 {
  stroke-dasharray: 460;
  stroke-dashoffset: 460;
  transition-delay: 0.8s;
}
.c-and__3 {
  opacity: 0;
  transition: opacity var(--transition-fadeup);
  transition-delay: var(--transition-and-delay-dot);
}
div.c-and__3 {
  position: absolute;
  bottom: calc((2 / 408) * 100%);
  padding-left: 10rem;
  pointer-events: auto;
}
@media screen and (min-width: 1024px) {
  div.c-and__3 {
    right: calc((-40 / 335) * 100%);
  }
}
@media screen and (max-width: 1023px) {
  div.c-and__3 {
    right: calc((-44 / 335) * 100%);
  }
}
.c-and__4 {
  --transition-delay: var(--transition-and-delay-title);
}
.c-and__4 path {
  display: block;
}
.c-and__txt {
  white-space: nowrap;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity var(--transition-fadeup);
  transition-delay: var(--transition-and-delay-title);
  margin-left: 0.3rem;
}
@media screen and (min-width: 1024px) {
  .c-and__txt {
    margin-top: 2.1rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-and__txt {
    margin-top: 1.7rem;
  }
}
.c-and__txt span {
  display: block;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(140 / 1000 * 1em);
}
.c-and__txt span::after,
.c-and__txt span::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.c-and__txt span::before {
  margin-top: var(--font-en-top);
}
.c-and__txt span::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .c-and__txt span {
    font-size: var(--font-size12);
    letter-spacing: calc(110 / 1000 * 1em);
  }
}
@media screen and (max-width: 1023px) {
  .c-and__txt span {
    font-size: var(--font-size10);
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    -webkit-transform-origin: 0 100%;
    transform-origin: 0 100%;
    letter-spacing: calc(140 / 1000 * 1em);
  }
}
.c-column {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 768px) {
  .c-column.-col-2-md {
    -ms-grid-columns: (1fr) [2];
    grid-template-columns: repeat(2, 1fr);
  }
  .c-column.-col-2-md.-stage > :nth-of-type(2n-1) {
    margin-top: calc(var(--width) * var(--slope-tan));
  }
  .c-column.-col-2-md.-stage > :nth-of-type(2n + 3) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-2-md.-stage > :nth-of-type(2n + 4) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
  .c-column.-col-2-md.-stage-left > :nth-of-type(2n-1) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-2-md.-stage-left > :nth-of-type(2n) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
}
@media screen and (max-width: 767px) {
  .c-column.-col-2-md {
    -ms-grid-columns: (1fr) [1];
    grid-template-columns: repeat(1, 1fr);
  }
  .c-column.-col-2-md.-stage > * + * {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-2-md.-stage-left > * {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
}
@media screen and (min-width: 561px) {
  .c-column.-col-2-sm {
    -ms-grid-columns: (1fr) [2];
    grid-template-columns: repeat(2, 1fr);
  }
  .c-column.-col-2-sm.-stage > :nth-of-type(2n-1) {
    margin-top: calc(var(--width) * var(--slope-tan));
  }
  .c-column.-col-2-sm.-stage > :nth-of-type(2n + 3) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-2-sm.-stage > :nth-of-type(2n + 4) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
  .c-column.-col-2-sm.-stage-left > :nth-of-type(2n-1) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-2-sm.-stage-left > :nth-of-type(2n) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
}
@media screen and (max-width: 560px) {
  .c-column.-col-2-sm {
    -ms-grid-columns: (1fr) [1];
    grid-template-columns: repeat(1, 1fr);
  }
  .c-column.-col-2-sm.-stage > * + * {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-2-sm.-stage-left > * {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
}
@media screen and (min-width: 768px) {
  .c-column.-col-3-md {
    -ms-grid-columns: (1fr) [3];
    grid-template-columns: repeat(3, 1fr);
  }
  .c-column.-col-3-md.-stage > :nth-of-type(3n-2) {
    margin-top: calc(var(--width) * var(--slope-tan) * 2);
  }
  .c-column.-col-3-md.-stage > :nth-of-type(3n-1) {
    margin-top: calc(var(--width) * var(--slope-tan) * 1);
  }
  .c-column.-col-3-md.-stage > :nth-of-type(3n + 4) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-3-md.-stage > :nth-of-type(3n + 5) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
  .c-column.-col-3-md.-stage > :nth-of-type(3n + 6) {
    margin-top: calc(var(--width) * var(--slope-tan) * -3);
  }
  .c-column.-col-3-md.-stage-left > :nth-of-type(3n-2) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-3-md.-stage-left > :nth-of-type(3n-1) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
  .c-column.-col-3-md.-stage-left > :nth-of-type(3n) {
    margin-top: calc(var(--width) * var(--slope-tan) * -3);
  }
}
@media screen and (max-width: 767px) {
  .c-column.-col-3-md {
    -ms-grid-columns: (1fr) [1];
    grid-template-columns: repeat(1, 1fr);
  }
  .c-column.-col-3-md.-stage > * + * {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-3-md.-stage-left > * {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
}
@media screen and (min-width: 768px) {
  .c-column.-col-3-md-2 {
    -ms-grid-columns: (1fr) [3];
    grid-template-columns: repeat(3, 1fr);
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(3n-2) {
    margin-top: calc(var(--width) * var(--slope-tan) * 2);
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(3n-1) {
    margin-top: calc(var(--width) * var(--slope-tan) * 1);
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(3n + 4) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(3n + 5) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(3n + 6) {
    margin-top: calc(var(--width) * var(--slope-tan) * -3);
  }
  .c-column.-col-3-md-2.-stage-left > :nth-of-type(3n-2) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-3-md-2.-stage-left > :nth-of-type(3n-1) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
  .c-column.-col-3-md-2.-stage-left > :nth-of-type(3n) {
    margin-top: calc(var(--width) * var(--slope-tan) * -3);
  }
}
@media screen and (max-width: 767px) {
  .c-column.-col-3-md-2 {
    -ms-grid-columns: (1fr) [2];
    grid-template-columns: repeat(2, 1fr);
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(2n-1) {
    margin-top: calc(var(--width) * var(--slope-tan));
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(2n + 3) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-3-md-2.-stage > :nth-of-type(2n + 4) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
  .c-column.-col-3-md-2.-stage-left > :nth-of-type(2n-1) {
    margin-top: calc(var(--width) * var(--slope-tan) * -1);
  }
  .c-column.-col-3-md-2.-stage-left > :nth-of-type(2n) {
    margin-top: calc(var(--width) * var(--slope-tan) * -2);
  }
}
.c-column.-gap-c-7 {
  -webkit-column-gap: 0.7rem;
  -moz-column-gap: 0.7rem;
  column-gap: 0.7rem;
}
@media screen and (min-width: 1024px) {
  .c-column.-gap-c-23 {
    -webkit-column-gap: 2.3rem;
    -moz-column-gap: 2.3rem;
    column-gap: 2.3rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-column.-gap-c-23 {
    -webkit-column-gap: 1.1rem;
    -moz-column-gap: 1.1rem;
    column-gap: 1.1rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-column.-gap-c-32 {
    -webkit-column-gap: 3.2rem;
    -moz-column-gap: 3.2rem;
    column-gap: 3.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-column.-gap-c-32 {
    -webkit-column-gap: 1.5rem;
    -moz-column-gap: 1.5rem;
    column-gap: 1.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-column.-gap-c-65 {
    -webkit-column-gap: 6.5rem;
    -moz-column-gap: 6.5rem;
    column-gap: 6.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-column.-gap-c-65 {
    -webkit-column-gap: 4rem;
    -moz-column-gap: 4rem;
    column-gap: 4rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-column.-gap-c-73 {
    -webkit-column-gap: 7.3rem;
    -moz-column-gap: 7.3rem;
    column-gap: 7.3rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-column.-gap-c-73 {
    -webkit-column-gap: 2rem;
    -moz-column-gap: 2rem;
    column-gap: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-column.-gap-c-91 {
    -webkit-column-gap: 9.1rem;
    -moz-column-gap: 9.1rem;
    column-gap: 9.1rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-column.-gap-c-91 {
    -webkit-column-gap: 6rem;
    -moz-column-gap: 6rem;
    column-gap: 6rem;
  }
}
.c-column.-gap-r-5 {
  row-gap: 0.5rem;
}
.c-column.-gap-r-15 {
  row-gap: 1.5rem;
}
@media screen and (min-width: 1024px) {
  .c-column.-gap-r-47 {
    row-gap: 4.7rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-column.-gap-r-47 {
    row-gap: 1.5rem;
  }
}
.c-column.-gap-r-60 {
  row-gap: 6rem;
}
.c-column.-gap-r-62 {
  row-gap: 6.2rem;
}
.c-column.-gap-r-74 {
  row-gap: 7.4rem;
}
.c-dots {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.c-dots li {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 561px) {
  .c-dots li {
    margin-left: 2rem;
  }
}
@media screen and (max-width: 560px) {
  .c-dots li {
    margin-left: 1.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-dots li:last-of-type {
    margin-right: 2.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-dots li:last-of-type {
    margin-right: 0.6rem;
  }
}
.c-dots li.is-active button,
.c-dots li.slick-active button {
  -webkit-transform: scale(1.81818, 1.81818);
  transform: scale(1.81818, 1.81818);
}
.c-dots button {
  border-radius: 100px;
  background-color: currentColor;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
  text-align: left;
}
@media screen and (min-width: 561px) {
  .c-dots button {
    width: 1.1rem;
    height: 1.1rem;
  }
}
@media screen and (max-width: 560px) {
  .c-dots button {
    width: 0.7rem;
    height: 0.7rem;
  }
}
.c-dots2 li + li {
  margin-top: 1.3rem;
}
.c-dots2 li.slick-active button {
  -webkit-transform: scale(200%);
  transform: scale(200%);
}
.c-dots2 button {
  --dots-size: 0.7rem;
  width: var(--dots-size);
  height: var(--dots-size);
  border-radius: 100px;
  background-color: currentColor;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
  text-align: left;
}
.c-gradation {
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.c-gradation.is-hover:hover::before {
  -webkit-transform: translate3d(100%, 0, 0);
  transform: translate3d(100%, 0, 0);
}
.c-gradation.is-hover:hover::after {
  -webkit-transform: translate3d(0, 0, 0) scale(-1, 1);
  transform: translate3d(0, 0, 0) scale(-1, 1);
}
.c-gradation::after,
.c-gradation::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: var(--theme-color);
  transition: -webkit-transform var(--transition-hover-slow);
  transition: transform var(--transition-hover-slow);
  transition: transform var(--transition-hover-slow),
    -webkit-transform var(--transition-hover-slow);
  z-index: -1;
  pointer-events: none;
}
.c-gradation::before {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.c-gradation::after {
  -webkit-transform: translate3d(-99%, 0, 0) scale(-1, 1);
  transform: translate3d(-99%, 0, 0) scale(-1, 1);
}
.c-gradation-hover {
  position: relative;
}
.c-gradation-hover.-type2::before {
  z-index: 0;
}
.c-gradation-hover::before {
  content: "";
  display: block;
  width: var(--gradation-hover-width);
  height: 100%;
  position: absolute;
  top: 0;
  right: var(--gradation-hover-right, 0);
  z-index: 10;
  background: var(--gradation-hover-bg);
  opacity: 0;
  transition: opacity var(--transition-hover-slow);
}
.c-gradation-hover.is-hover:hover::before,
.is-hover:hover .c-gradation-hover::before {
  opacity: 1;
}
.c-gradation-txt {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: var(--color-accent);
  background: var(--color-gradation2);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-transform: uppercase;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
}
.c-gradation-txt::after,
.c-gradation-txt::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.c-gradation-txt::before {
  margin-top: var(--font-en-top);
}
.c-gradation-txt::after {
  margin-bottom: var(--font-en-bottom);
}
.c-inner-large,
.c-inner-medium,
.c-inner-medium2,
.c-inner-medium3,
.c-inner-medium4,
.c-inner-medium5,
.c-inner-small,
.c-inner-small2,
.c-inner-small3,
.c-inner-small4,
.c-inner-small5,
.c-inner-xsmall,
.c-inner-xxsmall {
  width: var(--contents-pct);
  margin: 0 auto;
}
.c-inner-large2,
.c-inner-large3 {
  margin: 0 auto;
}
@media screen and (min-width: 1024px) {
  .c-inner-large2,
  .c-inner-large3 {
    width: 95%;
  }
}
@media screen and (max-width: 1023px) {
  .c-inner-large2,
  .c-inner-large3 {
    width: var(--contents-pct);
  }
}
.c-inner-xxsmall {
  max-width: 93rem;
}
.c-inner-xsmall {
  max-width: 99.8rem;
}
.c-inner-small {
  max-width: 106.6rem;
}
.c-inner-small2 {
  max-width: 110rem;
}
.c-inner-small3 {
  max-width: 100rem;
}
.c-inner-small4 {
  max-width: 100.7rem;
}
.c-inner-small5 {
  max-width: 101rem;
}
.c-inner-medium {
  max-width: 114rem;
}
.c-inner-medium2 {
  max-width: 117rem;
}
.c-inner-medium3 {
  max-width: 118rem;
}
.c-inner-medium4 {
  max-width: 112rem;
}
.c-inner-medium5 {
  max-width: 116.2rem;
}
.c-inner-large {
  max-width: 122.4rem;
}
.c-inner-large2 {
  max-width: 132.3rem;
}
.c-inner-large3 {
  max-width: 130rem;
}
.c-inner-full {
  width: 100%;
  max-width: calc(var(--design-width-pc) * 0.1rem);
  margin: 0 auto;
}
.c-inner-full-large {
  width: 100%;
  max-width: 192rem;
  margin: 0 auto;
}
[class*="c-jaggy"]:not([class*="c-jaggy__"]) {
  position: relative;
}
[class*="c-jaggy"]:not([class*="c-jaggy__"])
  + [class*="c-jaggy"]:not([class*="c-jaggy__"]) {
  margin-top: calc(var(--slope-height) * -0.5);
}
[class*="c-jaggy"]:not([class*="c-jaggy__"]).-top .c-jaggy__cell.-top {
  display: block;
}
[class*="c-jaggy"]:not([class*="c-jaggy__"]).-bottom .c-jaggy__cell.-bottom {
  display: block;
}
.c-jaggy .c-jaggy__inner {
  -webkit-clip-path: polygon(
    0 var(--slope-height),
    100% 0,
    100% calc(100% - var(--slope-height)),
    0 100%
  ) !important;
  clip-path: polygon(
    0 var(--slope-height),
    100% 0,
    100% calc(100% - var(--slope-height)),
    0 100%
  ) !important;
  padding-top: calc(var(--slope-height) * 0.5);
  padding-bottom: calc(var(--slope-height) * 0.5);
}
.c-jaggy-top .c-jaggy__inner {
  -webkit-clip-path: polygon(
    0 var(--slope-height),
    100% 0,
    100% 100%,
    0 100%
  ) !important;
  clip-path: polygon(
    0 var(--slope-height),
    100% 0,
    100% 100%,
    0 100%
  ) !important;
  padding-top: calc(var(--slope-height) * 0.5);
}
.c-jaggy__inner {
  position: relative;
  width: 100%;
  height: 100%;
}
.c-jaggy__cell {
  display: none;
  height: 3.7rem;
  position: absolute;
  left: 0;
  width: 100%;
  z-index: 1000000;
  pointer-events: none;
}
.c-jaggy__cell.-top {
  bottom: 100%;
  -webkit-transform: var(--slope);
  transform: var(--slope);
  -webkit-transform-origin: 100%;
  transform-origin: 100%;
}
.c-jaggy__cell.-top div::after,
.c-jaggy__cell.-top div::before,
.c-jaggy__cell.-top::after,
.c-jaggy__cell.-top::before {
  background: var(--jaggy-color-top, #f5f6f4);
}
.c-jaggy__cell.-bottom {
  top: 100%;
  -webkit-transform: var(--slope) scale(1, -1);
  transform: var(--slope) scale(1, -1);
  -webkit-transform-origin: 0;
  transform-origin: 0;
}
.c-jaggy__cell.-bottom div::after,
.c-jaggy__cell.-bottom div::before,
.c-jaggy__cell.-bottom::after,
.c-jaggy__cell.-bottom::before {
  background: var(--jaggy-color-bottom, #f5f6f4);
}
.c-jaggy__cell div::after,
.c-jaggy__cell div::before,
.c-jaggy__cell::after,
.c-jaggy__cell::before {
  content: "";
  display: block;
  width: 100%;
  position: absolute;
  left: 0;
}
.c-jaggy__cell::before {
  height: 0.1rem;
  top: 0;
}
.c-jaggy__cell::after {
  height: 0.2rem;
  top: 1rem;
}
.c-jaggy__cell div::before {
  height: 0.5rem;
  top: 1.9rem;
}
.c-jaggy__cell div::after {
  height: 0.8rem;
  top: 2.8rem;
}
.c-list-disc > li {
  display: flex;
  align-items: baseline;
}
@media screen and (min-width: 1024px) {
  .c-list-disc > li + li {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-list-disc > li + li {
    margin-top: 1.6rem;
  }
}
.c-list-disc > li::before {
  content: "";
  display: block;
  background-color: var(--color-text-level1);
  border-radius: 50%;
  font-size: inherit;
  line-height: inherit;
  position: relative;
  top: -0.4em;
  -webkit-transform: translateY(50%);
  transform: translateY(50%);
}
@media screen and (min-width: 1024px) {
  .c-list-disc > li::before {
    width: 0.7rem;
    height: 0.7rem;
    margin-right: 1.2rem;
    margin-left: 0.1rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-list-disc > li::before {
    width: 0.5rem;
    height: 0.5rem;
    margin-right: 0.6rem;
  }
}
.c-list-disc > li > span {
  flex: 1;
  align-self: baseline;
}
.c-list-disc.-accent li::before {
  background-color: var(--color-accent);
}
.c-list-decimal {
  counter-reset: item;
}
.c-list-decimal > li {
  display: flex;
  align-items: baseline;
}
@media screen and (min-width: 1024px) {
  .c-list-decimal > li + li {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-list-decimal > li + li {
    margin-top: 1.6rem;
  }
}
.c-list-decimal > li::before {
  counter-increment: item;
  content: counter(item) ".";
  text-align: right;
  font-family: var(--font-sans-serif);
}
@media screen and (min-width: 1024px) {
  .c-list-decimal > li::before {
    width: 1.2rem;
    font-size: var(--font-size14);
    margin-right: 1.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-list-decimal > li::before {
    width: 1.1rem;
    font-size: var(--font-size12);
    margin-right: 0.9rem;
  }
}
.c-list-decimal.-accent > li::before {
  color: var(--color-accent);
}
.c-objectfit.-cover {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}
.c-objectfit.-contain {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  position: absolute;
  top: 0;
  left: 0;
}
.c-object {
  position: absolute;
  pointer-events: none;
}
@media screen and (min-width: 1024px) {
  .c-object-mqUp-lg {
    position: absolute;
    pointer-events: none;
  }
}
.c-overlay {
  position: fixed;
  top: 0;
  right: 0;
  z-index: var(--z-index-c-overlay);
  width: 100%;
  height: 100%;
  background-color: var(--color-modal-bg);
  opacity: 0;
  visibility: hidden;
  transition: var(--transition-modal);
  transition-property: opacity, visibility;
}
.c-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}
.c-shadow {
  position: relative;
}
.c-shadow::before {
  content: "";
  display: block;
  width: var(--shadow-width);
  height: 50%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  border-radius: var(--shadow-radius);
  background: var(--color-shadow-gradation);
  -webkit-transform-origin: 0;
  transform-origin: 0;
  -webkit-transform: var(--slope) translate3d(0, 0, 0);
  transform: var(--slope) translate3d(0, 0, 0);
  opacity: 0;
  transition: var(--transition-shadow);
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  transition-delay: var(--shadow-delay, 1000ms);
}
.c-shadow.-zindex0::before {
  z-index: 0;
}
.c-shadow.-color2::before {
  background: var(--color-shadow-gradation2);
}
@media screen and (max-width: 1023px) {
  .c-shadow.-right-mqDown-md::before {
    left: auto;
    right: 0;
  }
}
.c-shadow.is-shown::before,
.is-shown .c-shadow::before {
  opacity: 1;
  -webkit-transform: var(--slope)
    translate3d(var(--shadow-left), var(--shadow-top), 0);
  transform: var(--slope) translate3d(var(--shadow-left), var(--shadow-top), 0);
}
.c-slider {
  position: relative;
  width: 100%;
  height: 100%;
}
.c-slider__content {
  width: 100%;
  height: 100%;
  position: relative;
  background-color: var(--color-main);
}
.c-slider__content li {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition-slider-basic);
  transition-property: opacity, visibility;
}
.c-slider__content li.is-active {
  opacity: 1;
  visibility: visible;
}
.c-slope-txt {
  -webkit-transform: var(--slope);
  transform: var(--slope);
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
}
.c-slope-txt span {
  display: inline-block;
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
  -webkit-transform: var(--slope--positive);
  transform: var(--slope--positive);
  letter-spacing: calc(100 / 1000 * 1em);
}
.c-slope {
  padding-bottom: calc(var(--width) * var(--slope-tan));
}
.c-slope.-type2 {
  padding-bottom: 0;
}
.c-slope.-type3 .c-slope__slope {
  height: auto;
}
.c-slope__slope {
  position: relative;
  z-index: 0;
  overflow: hidden;
  display: block;
  height: calc(var(--height) - var(--width) * var(--slope-tan));
  border-radius: var(--slope-radius, 0);
  -webkit-transform-origin: 100% 0;
  transform-origin: 100% 0;
  -webkit-transform: var(--slope);
  transform: var(--slope);
}
.c-slope__inner {
  display: block;
  -webkit-transform-origin: 100% 0;
  transform-origin: 100% 0;
  -webkit-transform: var(--slope--positive);
  transform: var(--slope--positive);
}
.c-slope2 {
  padding-bottom: calc(var(--width) * var(--slope-tan));
}
.c-slope2__slope {
  position: relative;
  z-index: 0;
  overflow: hidden;
  display: block;
  height: calc(var(--height) - var(--width) * var(--slope-tan));
  border-radius: var(--slope-radius, 0);
  -webkit-transform-origin: 100% 0;
  transform-origin: 100% 0;
  -webkit-transform: var(--slope);
  transform: var(--slope);
}
.c-slope3 {
  -webkit-transform: var(--slope);
  transform: var(--slope);
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
}
.c-youtube {
  position: relative;
}
.c-youtube::after {
  content: "";
  display: block;
  padding-top: 56.25%;
}
.c-youtube > iframe {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.c-arrow {
  --arrow-border: var(--color-main-gray);
  --arrow-bg: var(--color-main-gray);
  --arrow-icon: var(--color-main);
  --arrow-hover-border: var(--color-white);
  --arrow-hover-bg: var(--color-transp);
  --arrow-hover-icon: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--circle-size);
  height: var(--circle-size);
  border-radius: 50%;
  border: solid 1px var(--arrow-border);
  background-color: var(--arrow-bg);
  transition: var(--transition-hover);
  transition-property: background-color, border-color;
}
.c-arrow::before {
  content: "";
  display: block;
  width: var(--arrow-size);
  height: var(--arrow-size);
  border-top: solid 1px var(--arrow-icon);
  border-right: solid 1px var(--arrow-icon);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: border-color var(--transition-hover);
}
.is-hover:hover .c-arrow {
  background-color: var(--arrow-hover-bg);
  border-color: var(--arrow-hover-border);
}
.is-hover:hover .c-arrow::before {
  border-color: var(--arrow-hover-icon);
}
@media screen and (min-width: 1024px) {
  .c-arrow.-xsmall {
    --circle-size: 1.9rem;
    --arrow-size: 0.5rem;
    padding-right: 0.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-arrow.-xsmall {
    --circle-size: 1.6rem;
    --arrow-size: 0.4rem;
    padding-right: 0.1rem;
  }
}
.c-arrow.-small {
  --circle-size: 2.2rem;
  --arrow-size: 0.5rem;
  padding-right: 0.2rem;
}
@media screen and (min-width: 1024px) {
  .c-arrow.-small2 {
    --circle-size: 2.3rem;
    --arrow-size: 0.5rem;
    padding-right: 0.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-arrow.-small2 {
    --circle-size: 1.8rem;
    --arrow-size: 0.4rem;
    padding-right: 0.1rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-arrow.-small3 {
    --circle-size: 2.6rem;
    --arrow-size: 0.6rem;
    padding-right: 0.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-arrow.-small3 {
    --circle-size: 1.6rem;
    --arrow-size: 0.4rem;
    padding-right: 0.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-arrow.-medium {
    --circle-size: 4rem;
    --arrow-size: 0.9rem;
    padding-right: 0.3rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-arrow.-medium {
    --circle-size: 2.6rem;
    --arrow-size: 0.6rem;
    padding-right: 0.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-arrow.-medium2 {
    --circle-size: 4rem;
    --arrow-size: 0.9rem;
    padding-right: 0.3rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-arrow.-medium2 {
    --circle-size: 2.2rem;
    --arrow-size: 0.5rem;
    padding-right: 0.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-arrow.-large {
    --circle-size: 6.4rem;
    --arrow-size: 1.5rem;
    padding-right: 0.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-arrow.-large {
    --circle-size: 4.3rem;
    --arrow-size: 1rem;
    padding-right: 0.6rem;
  }
}
.c-arrow.-type2 {
  --arrow-bg: var(--color-white);
  --arrow-icon: var(--color-accent);
}
.c-arrow.-main {
  --arrow-border: var(--color-main);
  --arrow-bg: var(--color-main);
  --arrow-icon: var(--color-white);
  --arrow-hover-border: var(--color-main);
  --arrow-hover-icon: var(--color-main);
}
.c-arrow.-main-border-white {
  --arrow-border: var(--color-main);
  --arrow-bg: var(--color-main);
  --arrow-icon: var(--color-white);
  --arrow-hover-border: var(--color-white);
  --arrow-hover-icon: var(--color-white);
}
.c-arrow.-border-white {
  --arrow-border: var(--color-white);
  --arrow-bg: var(--color-transp);
  --arrow-icon: var(--color-white);
  --arrow-hover-bg: var(--color-white);
  --arrow-hover-icon: var(--color-main);
}
.c-arrow.-border-main {
  --arrow-border: var(--color-main);
  --arrow-bg: var(--color-transp);
  --arrow-icon: var(--color-main);
  --arrow-hover-border: var(--color-main);
  --arrow-hover-bg: var(--color-main);
  --arrow-hover-icon: var(--color-white);
}
.c-arrow2 {
  width: var(--box-width);
  height: calc(var(--box-width) * 2);
  transition: -webkit-transform var(--transition-hover);
  transition: transform var(--transition-hover);
  transition: transform var(--transition-hover),
    -webkit-transform var(--transition-hover);
}
.is-hover:hover .c-arrow2 {
  -webkit-transform: translate3d(0.6rem, 0, 0);
  transform: translate3d(0.6rem, 0, 0);
}
.c-arrow2::before {
  content: "";
  display: block;
  width: calc(var(--box-width) * 1.41421356237);
  height: calc(var(--box-width) * 1.41421356237);
  border-top: solid 1px currentColor;
  border-right: solid 1px currentColor;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transform-origin: 0 0;
  transform-origin: 0 0;
  transition: border-color var(--transition-hover);
}
.c-arrow2.-small {
  --box-width: 0.4rem;
}
.c-blank svg {
  width: 0.8rem;
  height: 0.8rem;
}
.c-blank svg g {
  stroke: currentColor;
}
.c-icon {
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0;
  line-height: 0;
}
.c-instagram {
  position: relative;
}
@media screen and (min-width: 1024px) {
  .c-instagram {
    margin-right: 0.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-instagram {
    margin-right: 0.7rem;
  }
}
.c-instagram::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-image: url(../img/common/icon/sns_instagram.svg);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  transition: var(--transition-hover);
}
.c-instagram svg {
  width: 1.8rem;
  height: 1.8rem;
  opacity: 0;
}
@media screen and (max-width: 1023px) {
  .c-instagram.-type2 svg {
    width: 1.4rem;
    height: 1.4rem;
  }
}
.c-contact {
  color: var(--color-txt);
}
.c-contact a {
  display: block;
  width: 100%;
  transition: none;
}
.c-contact .c-arrow {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: var(--slope--positive) translateY(-50%);
  transform: var(--slope--positive) translateY(-50%);
}
.c-contact.-small {
  --slope-radius: var(--radius-size7);
}
@media screen and (min-width: 1024px) {
  .c-contact.-small .c-arrow {
    right: 4.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-small .c-arrow {
    right: 1.4rem;
  }
}
.c-contact.-small .c-contact__inner {
  padding-top: calc(var(--width) * var(--slope-tan));
}
@media screen and (min-width: 1024px) {
  .c-contact.-small .c-contact__inner {
    height: calc(var(--width) * var(--slope-tan) + 9.2rem);
    padding-left: 6rem;
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-small .c-contact__inner {
    height: calc(var(--width) * var(--slope-tan) + 7.6rem);
    padding-left: 2.8rem;
    padding-bottom: 1rem;
  }
}
.c-contact.-small .c-contact__title {
  display: flex;
}
@media screen and (min-width: 1024px) {
  .c-contact.-small .c-contact__title__en {
    font-size: var(--font-size20);
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-small .c-contact__title__en {
    font-size: var(--font-size16);
  }
}
.c-contact.-small .c-contact__title__ja {
  margin-left: 0.7rem;
}
@media screen and (min-width: 1024px) {
  .c-contact.-small .c-contact__title__ja {
    font-size: var(--font-size12);
    margin-top: 0.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-small .c-contact__title__ja {
    font-size: var(--font-size11);
    margin-top: 0.1rem;
  }
}
@media screen and (max-width: 767px) and (min-width: 561px) {
  .c-contact.-small .c-contact__title__ja {
    margin-top: 0;
  }
}
.c-contact.-large {
  --slope-radius: var(--radius-size20);
}
@media screen and (min-width: 1024px) {
  .c-contact.-large .c-arrow {
    right: 5.4rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-large .c-arrow {
    right: 3rem;
  }
}
.c-contact.-large .c-contact__inner {
  padding-top: calc(var(--width) * var(--slope-tan));
}
@media screen and (min-width: 1024px) {
  .c-contact.-large .c-contact__inner {
    height: 32.5rem;
    padding-left: 8.2rem;
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-large .c-contact__inner {
    padding-left: 3.2rem;
    padding-bottom: 0.8rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .c-contact.-large .c-contact__inner {
    height: 22rem;
  }
}
@media screen and (max-width: 560px) {
  .c-contact.-large .c-contact__inner {
    height: 18.8rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-contact.-large .c-contact__title__en {
    font-size: var(--font-size27);
    font-weight: bold;
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-large .c-contact__title__en {
    font-size: var(--font-size22);
    font-weight: bold;
  }
}
@media screen and (min-width: 1024px) {
  .c-contact.-large .c-contact__title__ja {
    font-size: var(--font-size14);
    margin-top: 1.9rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-contact.-large .c-contact__title__ja {
    font-size: var(--font-size11);
    margin-top: 1.4rem;
  }
}
.c-contact__inner {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.c-contact__title__en {
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
}
.c-contact__title__en::after,
.c-contact__title__en::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.c-contact__title__en::before {
  margin-top: var(--font-en-top);
}
.c-contact__title__en::after {
  margin-bottom: var(--font-en-bottom);
}
.c-count {
  counter-reset: item;
}
.c-count .c-count__target::before {
  counter-increment: item;
  content: counter(item, decimal-leading-zero);
  font-family: var(--font-sans-serif);
}
.c-crop {
  line-height: calc(var(--line-height) * 1em);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
}
.c-crop::after,
.c-crop::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.c-crop::before {
  margin-top: calc((1 - var(--line-height)) * 0.5em);
}
.c-crop::after {
  margin-bottom: calc((1 - var(--line-height)) * 0.5em);
}
.c-crop-vertical {
  line-height: calc(var(--line-height) * 1em);
  padding-right: 0.01px;
  padding-left: 0.01px;
}
.c-crop-vertical::after,
.c-crop-vertical::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.c-crop-vertical::before {
  margin-right: calc((1 - var(--line-height)) * 0.5em);
}
.c-crop-vertical::after {
  margin-left: calc((1 - var(--line-height)) * 0.5em);
}
.c-crop-vertical-horizontal-lg {
  line-height: calc(var(--line-height) * 1em);
}
@media screen and (min-width: 1024px) {
  .c-crop-vertical-horizontal-lg {
    padding-right: 0.01px;
    padding-left: 0.01px;
  }
  .c-crop-vertical-horizontal-lg::after,
  .c-crop-vertical-horizontal-lg::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  .c-crop-vertical-horizontal-lg::before {
    margin-right: calc((1 - var(--line-height)) * 0.5em);
  }
  .c-crop-vertical-horizontal-lg::after {
    margin-left: calc((1 - var(--line-height)) * 0.5em);
  }
}
@media screen and (max-width: 1023px) {
  .c-crop-vertical-horizontal-lg {
    padding-top: 0.01px;
    padding-bottom: 0.01px;
  }
  .c-crop-vertical-horizontal-lg::after,
  .c-crop-vertical-horizontal-lg::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  .c-crop-vertical-horizontal-lg::before {
    margin-top: calc((1 - var(--line-height)) * 0.5em);
  }
  .c-crop-vertical-horizontal-lg::after {
    margin-bottom: calc((1 - var(--line-height)) * 0.5em);
  }
}
.c-logo {
  display: flex;
}
.c-logo a {
  display: flex;
  align-items: center;
}
.c-logo a.is-hover:hover {
  opacity: 0.5;
}
@media screen and (max-width: 560px) {
  .c-logo.-type2 .c-logo__txt {
    width: 11.5rem;
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
    margin-left: 0.8rem;
  }
}
.c-logo.-color .c-logo__logo::before {
  content: "";
  display: block;
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/common/logo.svg);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.c-logo.-color img {
  opacity: 0;
}
.is-sticky .c-logo.-color .c-logo__logo::before {
  opacity: 0;
}
.is-sticky .c-logo.-color img {
  opacity: 1;
}
.c-logo__logo {
  position: relative;
  display: block;
  width: var(--logo-width);
}
.c-logo__txt {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100px;
  border: solid 1px;
}
@media screen and (min-width: 1024px) {
  .c-logo__txt {
    width: 13rem;
    height: 2.4rem;
    font-size: var(--font-size12);
    padding-bottom: 0.1rem;
    margin-left: 1.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-logo__txt {
    width: 7.2rem;
    height: 2rem;
    font-size: var(--font-size10);
    margin-left: 1rem;
  }
}
@media screen and (min-width: 561px) {
  .c-logo2 {
    display: flex;
    align-items: center;
  }
}
.c-logo2 span {
  display: block;
}
@media screen and (min-width: 1024px) {
  .c-logo2__logo {
    width: 9.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-logo2__logo {
    width: 7.7rem;
  }
}
@media screen and (min-width: 561px) {
  .c-logo2__txt {
    font-size: var(--font-size12);
    margin-left: 1.4rem;
  }
}
@media screen and (max-width: 560px) {
  .c-logo2__txt {
    font-size: var(--font-size10);
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    -webkit-transform-origin: 0 100%;
    transform-origin: 0 100%;
    margin-top: 0.6rem;
  }
}
.c-title {
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
}
.c-title::after,
.c-title::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.c-title::before {
  margin-top: var(--font-en-top);
}
.c-title::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .c-title {
    font-size: var(--font-size50);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .c-title {
    font-size: var(--font-size38);
  }
}
@media screen and (max-width: 560px) {
  .c-title {
    font-size: var(--font-size32);
  }
}
@media screen and (min-width: 1024px) {
  .c-title2 {
    padding-left: 0.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-title2 {
    padding: 0 0.5rem;
  }
}
.c-title2__en {
  opacity: 0.5;
  text-transform: uppercase;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
}
.c-title2__en::after,
.c-title2__en::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.c-title2__en::before {
  margin-top: var(--font-en-top);
}
.c-title2__en::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .c-title2__en {
    font-size: var(--font-size18);
    padding-left: 0.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-title2__en {
    font-size: var(--font-size14);
    padding-left: 0.3rem;
  }
}
.c-title2__ja {
  font-weight: 700;
  letter-spacing: calc(100 / 1000 * 1em);
}
@media screen and (min-width: 1024px) {
  .c-title2__ja {
    font-size: var(--font-size26);
    margin-top: 2.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .c-title2__ja {
    font-size: var(--font-size22);
    margin-top: 2rem;
  }
}
.c-title3 {
  text-align: center;
}
.c-title3__ja {
  letter-spacing: calc(100 / 1000 * 1em);
}
@media screen and (min-width: 1024px) {
  .c-title3__ja {
    font-size: var(--font-size24);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .c-title3__ja {
    font-size: var(--font-size22);
  }
}
@media screen and (max-width: 560px) {
  .c-title3__ja {
    font-size: var(--font-size18);
  }
}
@media screen and (min-width: 1024px) {
  .c-title3__en {
    margin-top: 2.2rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .c-title3__en {
    margin-top: 1.6rem;
  }
}
@media screen and (max-width: 560px) {
  .c-title3__en {
    margin-top: 1.2rem;
  }
}
.c-title3__en span {
  display: block;
  opacity: 0.5;
  text-transform: uppercase;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  font-size: var(--font-size10);
  letter-spacing: calc(100 / 1000 * 1em);
}
.c-title3__en span::after,
.c-title3__en span::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.c-title3__en span::before {
  margin-top: var(--font-en-top);
}
.c-title3__en span::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (max-width: 560px) {
  .c-title3__en span {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    -webkit-transform-origin: 50% 100%;
    transform-origin: 50% 100%;
  }
}
.c-title4 {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 100px;
  background-color: var(--color-bg5);
  color: var(--color-txt2);
  font-weight: 700;
}
@media screen and (min-width: 561px) {
  .c-title4 {
    font-size: var(--font-size14);
    padding: 0.8rem 2.2rem;
  }
}
@media screen and (max-width: 560px) {
  .c-title4 {
    font-size: var(--font-size12);
    padding: 0.7rem 1.7rem;
  }
}
@media screen and (min-width: 1024px) {
  .c-title4.-large {
    font-size: var(--font-size16);
    padding: 0.7rem 1.6rem;
  }
}
.c-txts > :not(:last-child)::after {
  content: "\A\A";
  display: inline;
  white-space: pre;
}
@media screen and (min-width: 561px) {
  .c-txt-xsmall {
    font-size: var(--font-size12);
    --line-height: calc(25.75 / 12);
  }
}
@media screen and (max-width: 560px) {
  .c-txt-xsmall {
    font-size: var(--font-size11);
    --line-height: calc(22 / 11);
  }
}
@media screen and (min-width: 561px) {
  .c-txt-xsmall2 {
    font-size: var(--font-size12);
    --line-height: calc(20 / 12);
  }
}
@media screen and (max-width: 560px) {
  .c-txt-xsmall2 {
    font-size: var(--font-size10);
    --line-height: calc(18 / 10);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-medium {
    font-size: var(--font-size14);
    --line-height: calc(29.75 / 14);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-medium {
    font-size: var(--font-size12);
    --line-height: calc(25.75 / 12);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-medium2 {
    font-size: var(--font-size14);
    --line-height: calc(33.75 / 14);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-medium2 {
    font-size: var(--font-size12);
    --line-height: calc(27.75 / 12);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-medium3 {
    font-size: var(--font-size14);
    --line-height: calc(32 / 14);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-medium3 {
    font-size: var(--font-size12);
    --line-height: calc(28 / 12);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-medium4 {
    font-size: var(--font-size14);
    --line-height: calc(22 / 14);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-medium4 {
    --line-height: calc(18 / 10);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .c-txt-medium4 {
    font-size: var(--font-size12);
  }
}
@media screen and (max-width: 560px) {
  .c-txt-medium4 {
    font-size: var(--font-size10);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-xlarge {
    font-size: var(--font-size16);
    --line-height: calc(36 / 16);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xlarge {
    font-size: var(--font-size14);
    --line-height: calc(30 / 14);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-xlarge2 {
    font-size: var(--font-size16);
    --line-height: calc(39.75 / 16);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xlarge2 {
    font-size: var(--font-size14);
    --line-height: calc(30 / 14);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-xlarge3 {
    font-size: var(--font-size16);
    --line-height: calc(36 / 16);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xlarge3 {
    font-size: var(--font-size12);
    --line-height: calc(28 / 12);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-xlarge4 {
    font-size: var(--font-size16);
    --line-height: calc(24 / 16);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xlarge4 {
    font-size: var(--font-size14);
    --line-height: calc(17 / 12);
  }
}
.c-txt-xlarge4__small {
  display: block;
}
@media screen and (min-width: 1024px) {
  .c-txt-xlarge4__small {
    font-size: var(--font-size12);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xlarge4__small {
    font-size: var(--font-size10);
    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
    letter-spacing: calc(100 / 1000 * 1em);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-xxlarge {
    font-size: var(--font-size18);
    --line-height: calc(65.75 / 18);
    letter-spacing: calc(120 / 1000 * 1em);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xxlarge {
    font-size: var(--font-size14);
    --line-height: calc(30.67 / 14);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-xxlarge2 {
    font-size: var(--font-size18);
    --line-height: calc(43.75 / 18);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xxlarge2 {
    font-size: var(--font-size14);
    --line-height: calc(30.47 / 14);
  }
}
@media screen and (min-width: 1024px) {
  .c-txt-xxxlarge {
    font-size: var(--font-size20);
    --line-height: calc(83 / 20);
    letter-spacing: calc(90 / 1000 * 1em);
  }
}
@media screen and (max-width: 1023px) {
  .c-txt-xxxlarge {
    font-size: var(--font-size16);
    --line-height: calc(54.55 / 16);
  }
}
@media screen and (max-width: 767px) {
  .js-accordion-mqUp-md__panel {
    height: 0;
    overflow: hidden;
    transition: height var(--transition-accordion);
  }
}
.js-delay-1 {
  transition-delay: 0.1s !important;
}
.js-delay-2 {
  transition-delay: 0.2s !important;
}
.js-delay-3 {
  transition-delay: 0.3s !important;
}
.js-delay-4 {
  transition-delay: 0.4s !important;
}
.js-delay-5 {
  transition-delay: 0.5s !important;
}
.js-delay-6 {
  transition-delay: 0.6s !important;
}
.js-delay-7 {
  transition-delay: 0.7s !important;
}
.js-delay-8 {
  transition-delay: 0.8s !important;
}
.js-delay-9 {
  transition-delay: 0.9s !important;
}
.js-delay-10 {
  transition-delay: 1s !important;
}
.js-delay-11 {
  transition-delay: 1.1s !important;
}
.js-delay-12 {
  transition-delay: 1.2s !important;
}
.js-delay-13 {
  transition-delay: 1.3s !important;
}
.js-delay-14 {
  transition-delay: 1.4s !important;
}
.js-delay-15 {
  transition-delay: 1.5s !important;
}
.js-delay-16 {
  transition-delay: 1.6s !important;
}
.js-delay-17 {
  transition-delay: 1.7s !important;
}
.js-delay-18 {
  transition-delay: 1.8s !important;
}
.js-delay-19 {
  transition-delay: 1.9s !important;
}
.js-delay-20 {
  transition-delay: 2s !important;
}
.js-delay-21 {
  transition-delay: 2.1s !important;
}
.js-delay-22 {
  transition-delay: 2.2s !important;
}
.js-delay-23 {
  transition-delay: 2.3s !important;
}
.js-delay-24 {
  transition-delay: 2.4s !important;
}
.js-delay-25 {
  transition-delay: 2.5s !important;
}
.js-delay-26 {
  transition-delay: 2.6s !important;
}
.js-delay-27 {
  transition-delay: 2.7s !important;
}
.js-delay-28 {
  transition-delay: 2.8s !important;
}
.js-delay-29 {
  transition-delay: 2.9s !important;
}
.js-delay-30 {
  transition-delay: 3s !important;
}
@-webkit-keyframes loopSlider_horizontal {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  100% {
    -webkit-transform: translate3d(calc(var(--original-size) * -1), 0, 0);
    transform: translate3d(calc(var(--original-size) * -1), 0, 0);
  }
}
@keyframes loopSlider_horizontal {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  100% {
    -webkit-transform: translate3d(calc(var(--original-size) * -1), 0, 0);
    transform: translate3d(calc(var(--original-size) * -1), 0, 0);
  }
}
@-webkit-keyframes loopSlider_horizontal_track {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
  0.5%,
  99.5% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}
@keyframes loopSlider_horizontal_track {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
  0.5%,
  99.5% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}
.js-loopslider.-horizontal {
  overflow: visible;
  width: 100vw;
}
.js-loopslider.-horizontal .js-loopslider__content {
  width: var(--all-size);
  margin-top: 8px;
}
.js-loopslider.-horizontal .js-loopslider__content::after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  line-height: 0;
  visibility: hidden;
}
.js-loopslider.-horizontal
  .js-loopslider__content
  + .js-loopslider__content
  li {
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (min-width: 1681px) {
  .js-loopslider.-horizontal .js-loopslider__content li {
    -webkit-transform: rotate(200deg);
    transform: rotate(200deg);
  }
  .js-loopslider.-horizontal .js-loopslider__content img {
    -webkit-transform: rotate(160deg);
    transform: rotate(160deg);
  }
}
.js-loopslider.-vertical-slope {
  overflow: visible;
}
body:not(.is-load) .js-loopslider__content {
  height: 0;
  opacity: 0;
}
.js-modal {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--z-index-js-modal);
  opacity: 0;
  visibility: hidden;
  transition: var(--transition-modal);
  transition-property: opacity, visibility;
}
.js-modal.is-loading,
.js-modal.is-visible {
  opacity: 1;
  visibility: visible;
}
.js-modal.is-loading {
  pointer-events: none;
}
.js-modal.is-loading::after {
  opacity: 1;
}
.js-modal::after {
  content: "";
  display: block;
  background-image: url(../img/common/icon/apng-loading.png);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(0.00001deg);
  transform: translate(-50%, -50%) rotate(0.00001deg);
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  transition: opacity 350ms 0.1s ease;
}
@media screen and (min-width: 1024px) {
  .js-modal::after {
    width: 6rem;
    height: 6rem;
  }
}
.js-modal .c-overlay {
  z-index: 0;
}
.js-modal__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 4% 9.33333%;
  padding: var(--contents-outside-vw);
  padding: calc(var(--contents-outside-vw) * 2);
}
.js-modal__youtube {
  position: relative;
  z-index: 100;
  max-width: 120rem;
  width: 100%;
  max-height: 100%;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition-modal);
  transition-property: opacity, visibility;
}
.js-modal__youtube.is-visible {
  opacity: 1;
  visibility: visible;
}
.js-modal__youtube::after {
  content: "";
  display: block;
  padding-top: 56.25%;
}
.js-modal__youtube__iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.js-modal__youtube__caption {
  display: none;
}
.js-modal__close {
  position: absolute;
  z-index: 100;
}
@media screen and (min-width: 1024px) {
  .js-modal__close {
    width: 8rem;
    height: 8rem;
    top: 4rem;
    right: 4rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .js-modal__close {
    width: 6rem;
    height: 6rem;
    top: 3rem;
    right: 3rem;
  }
}
@media screen and (max-width: 560px) {
  .js-modal__close {
    width: 5rem;
    height: 5rem;
    top: 2rem;
    right: 2rem;
  }
}
.js-modal__close button {
  display: block;
  width: 100%;
  height: 100%;
}
.js-modal__close button.is-hover:hover {
  opacity: 0.5;
}
.js-modal__close span {
  display: block;
  width: 80%;
  height: 1px;
  background-color: var(--color-modal-txt);
  margin: auto;
  transition: width var(--transition-hover);
}
.js-modal__close span:nth-of-type(1) {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.js-modal__close span:nth-of-type(2) {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
svg.js-svg {
  width: 100%;
}
img.js-svg {
  opacity: 0;
}
.js-fade {
  opacity: 0;
  transition: var(--transition-fade);
  transition-property: opacity;
  transition-delay: 0.2s;
}
.is-shown .js-fade,
.js-fade.is-shown {
  opacity: 1;
}
.js-fades {
  --transition-delay: 50ms;
}
.js-fades > * {
  opacity: 0;
  transition: var(--transition-fade);
  transition-property: opacity;
  transition-delay: 0.2s;
}
.js-fades > :nth-child(1) {
  transition-delay: calc(var(--transition-delay) + 120ms);
}
.js-fades > :nth-child(2) {
  transition-delay: calc(var(--transition-delay) + 240ms);
}
.js-fades > :nth-child(3) {
  transition-delay: calc(var(--transition-delay) + 360ms);
}
.js-fades > :nth-child(4) {
  transition-delay: calc(var(--transition-delay) + 480ms);
}
.js-fades > :nth-child(5) {
  transition-delay: calc(var(--transition-delay) + 600ms);
}
.js-fades > :nth-child(6) {
  transition-delay: calc(var(--transition-delay) + 720ms);
}
.js-fades > :nth-child(7) {
  transition-delay: calc(var(--transition-delay) + 840ms);
}
.js-fades > :nth-child(8) {
  transition-delay: calc(var(--transition-delay) + 960ms);
}
.js-fades > :nth-child(9) {
  transition-delay: calc(var(--transition-delay) + 1080ms);
}
.js-fades > :nth-child(10) {
  transition-delay: calc(var(--transition-delay) + 1200ms);
}
.js-fades > :nth-child(11) {
  transition-delay: calc(var(--transition-delay) + 1320ms);
}
.js-fades > :nth-child(12) {
  transition-delay: calc(var(--transition-delay) + 1440ms);
}
.js-fades > :nth-child(13) {
  transition-delay: calc(var(--transition-delay) + 1560ms);
}
.js-fades > :nth-child(14) {
  transition-delay: calc(var(--transition-delay) + 1680ms);
}
.js-fades > :nth-child(15) {
  transition-delay: calc(var(--transition-delay) + 1800ms);
}
.js-fades > :nth-child(16) {
  transition-delay: calc(var(--transition-delay) + 1920ms);
}
.js-fades > :nth-child(17) {
  transition-delay: calc(var(--transition-delay) + 2040ms);
}
.js-fades > :nth-child(18) {
  transition-delay: calc(var(--transition-delay) + 2160ms);
}
.js-fades > :nth-child(19) {
  transition-delay: calc(var(--transition-delay) + 2280ms);
}
.js-fades > :nth-child(20) {
  transition-delay: calc(var(--transition-delay) + 2400ms);
}
.is-shown .js-fades > *,
.js-fades.is-shown > * {
  opacity: 1;
}
.js-fadeup {
  opacity: 0;
  -webkit-transform: translate3d(0, 2rem, 0) rotate(0.001deg);
  transform: translate3d(0, 2rem, 0) rotate(0.001deg);
  transition: var(--transition-fadeup);
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  transition-delay: var(--transition-delay);
  --transition-delay: 200ms;
}
.js-fadeup.-slow {
  transition: var(--transition-fadeup-slow);
  --transition-delay: 400ms;
}
.is-shown .js-fadeup,
.js-fadeup.is-shown {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0) rotate(0.001deg);
  transform: translate3d(0, 0, 0) rotate(0.001deg);
}
.js-fadeups,
.js-fadeups2 {
  --transition-delay: 50ms;
}
.js-fadeups.-slow,
.js-fadeups2.-slow {
  --transition-delay: 200ms;
}
.js-fadeups.-slow > *,
.js-fadeups2.-slow > * {
  transition: var(--transition-fadeup-slow);
}
.js-fadeups2 > *,
.js-fadeups > * {
  opacity: 0;
  transition: var(--transition-fadeup);
  transition-property: opacity, -webkit-transform !important;
  transition-property: opacity, transform !important;
  transition-property: opacity, transform, -webkit-transform !important;
  transition-delay: 0s;
}
.js-fadeups2 > :nth-child(1),
.js-fadeups > :nth-child(1) {
  transition-delay: calc(var(--transition-delay) + 180ms);
}
.js-fadeups2 > :nth-child(2),
.js-fadeups > :nth-child(2) {
  transition-delay: calc(var(--transition-delay) + 360ms);
}
.js-fadeups2 > :nth-child(3),
.js-fadeups > :nth-child(3) {
  transition-delay: calc(var(--transition-delay) + 540ms);
}
.js-fadeups2 > :nth-child(4),
.js-fadeups > :nth-child(4) {
  transition-delay: calc(var(--transition-delay) + 720ms);
}
.js-fadeups2 > :nth-child(5),
.js-fadeups > :nth-child(5) {
  transition-delay: calc(var(--transition-delay) + 900ms);
}
.js-fadeups2 > :nth-child(6),
.js-fadeups > :nth-child(6) {
  transition-delay: calc(var(--transition-delay) + 1080ms);
}
.js-fadeups2 > :nth-child(7),
.js-fadeups > :nth-child(7) {
  transition-delay: calc(var(--transition-delay) + 1260ms);
}
.js-fadeups2 > :nth-child(8),
.js-fadeups > :nth-child(8) {
  transition-delay: calc(var(--transition-delay) + 1440ms);
}
.js-fadeups2 > :nth-child(9),
.js-fadeups > :nth-child(9) {
  transition-delay: calc(var(--transition-delay) + 1620ms);
}
.js-fadeups2 > :nth-child(10),
.js-fadeups > :nth-child(10) {
  transition-delay: calc(var(--transition-delay) + 1800ms);
}
.js-fadeups2 > :nth-child(11),
.js-fadeups > :nth-child(11) {
  transition-delay: calc(var(--transition-delay) + 1980ms);
}
.js-fadeups2 > :nth-child(12),
.js-fadeups > :nth-child(12) {
  transition-delay: calc(var(--transition-delay) + 2160ms);
}
.js-fadeups2 > :nth-child(13),
.js-fadeups > :nth-child(13) {
  transition-delay: calc(var(--transition-delay) + 2340ms);
}
.js-fadeups2 > :nth-child(14),
.js-fadeups > :nth-child(14) {
  transition-delay: calc(var(--transition-delay) + 2520ms);
}
.js-fadeups2 > :nth-child(15),
.js-fadeups > :nth-child(15) {
  transition-delay: calc(var(--transition-delay) + 2700ms);
}
.js-fadeups2 > :nth-child(16),
.js-fadeups > :nth-child(16) {
  transition-delay: calc(var(--transition-delay) + 2880ms);
}
.js-fadeups2 > :nth-child(17),
.js-fadeups > :nth-child(17) {
  transition-delay: calc(var(--transition-delay) + 3060ms);
}
.js-fadeups2 > :nth-child(18),
.js-fadeups > :nth-child(18) {
  transition-delay: calc(var(--transition-delay) + 3240ms);
}
.js-fadeups2 > :nth-child(19),
.js-fadeups > :nth-child(19) {
  transition-delay: calc(var(--transition-delay) + 3420ms);
}
.js-fadeups2 > :nth-child(20),
.js-fadeups > :nth-child(20) {
  transition-delay: calc(var(--transition-delay) + 3600ms);
}
.is-shown .js-fadeups2 > *,
.is-shown .js-fadeups > *,
.js-fadeups.is-shown > *,
.js-fadeups2.is-shown > * {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0) rotate(0.001deg);
  transform: translate3d(0, 0, 0) rotate(0.001deg);
}
.js-fadeups > * {
  -webkit-transform: translate3d(0, 2rem, 0) rotate(0.001deg);
  transform: translate3d(0, 2rem, 0) rotate(0.001deg);
}
.js-fadeups2 > * {
  -webkit-transform: translate3d(0, 1rem, 0) rotate(0.001deg);
  transform: translate3d(0, 1rem, 0) rotate(0.001deg);
}
.js-scale,
.js-scale2 {
  opacity: 0;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
}
.is-shown .js-scale,
.is-shown .js-scale2,
.js-scale.is-shown,
.js-scale2.is-shown {
  opacity: 1;
  -webkit-transform: scale(1) rotate(0.00001deg);
  transform: scale(1) rotate(0.00001deg);
}
.js-scale {
  -webkit-transform: scale(0.85) rotate(0.00001deg);
  transform: scale(0.85) rotate(0.00001deg);
  transition: var(--transition-scale);
  transition-delay: 0.2s;
}
.js-scale2 {
  -webkit-transform: scale(0.7) rotate(0.00001deg);
  transform: scale(0.7) rotate(0.00001deg);
  transition: var(--transition-scale2);
  transition-delay: 0.5s;
}
.js-splitrow {
  opacity: 0;
}
.js-splitrow.is-split {
  opacity: 1;
}
.is-shown .js-splitrow .js-splitrow__txt,
.js-splitrow.is-shown .js-splitrow__txt {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.js-splitrow__row {
  display: block;
  position: relative;
}
.js-splitrow__row:nth-of-type(1) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 100ms) !important;
}
.js-splitrow__row:nth-of-type(2) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 200ms) !important;
}
.js-splitrow__row:nth-of-type(3) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 300ms) !important;
}
.js-splitrow__row:nth-of-type(4) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 400ms) !important;
}
.js-splitrow__row:nth-of-type(5) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 500ms) !important;
}
.js-splitrow__row:nth-of-type(6) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 600ms) !important;
}
.js-splitrow__row:nth-of-type(7) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 700ms) !important;
}
.js-splitrow__row:nth-of-type(8) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 800ms) !important;
}
.js-splitrow__row:nth-of-type(9) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 900ms) !important;
}
.js-splitrow__row:nth-of-type(10) .js-splitrow__txt {
  transition-delay: calc(var(--transition-delay) + 1000ms) !important;
}
.js-splitrow__txt {
  display: inline-block;
  -webkit-transform: translate3d(0, 40%, 0);
  transform: translate3d(0, 40%, 0);
  opacity: 0;
  transition: var(--transition-split);
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  --transition-delay: 0ms;
}
.p-button {
  --button-bg: var(--color-main-white);
  --button-txt: var(--color-main);
  --button-hover-bg: var(--color-main);
  --button-hover-txt: var(--color-main-white);
  width: 100%;
}
@media screen and (min-width: 561px) {
  .p-button.-small {
    max-width: 16.8rem;
    height: 3.4rem;
  }
}
@media screen and (max-width: 560px) {
  .p-button.-small {
    max-width: 13rem;
    height: 3rem;
  }
}
@media screen and (min-width: 1024px) {
  .p-button.-small .p-button__inner {
    padding-left: 0.5rem;
  }
}
@media screen and (max-width: 560px) {
  .p-button.-small .p-button__txt {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    -webkit-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
    margin-left: -1.2rem;
  }
}
.p-button.-medium {
  height: 5rem;
}
@media screen and (min-width: 561px) {
  .p-button.-medium {
    max-width: 14.2rem;
  }
}
@media screen and (max-width: 560px) {
  .p-button.-medium {
    max-width: 13.7rem;
  }
}
@media screen and (max-width: 560px) {
  .p-button.-medium .p-button__txt {
    margin-left: 0.9rem;
  }
}
.p-button.-hover2 {
  --button-hover-bg: var(--color-transp);
}
.p-button.-hover2 .p-button__inner {
  border: solid 1px var(--button-bg);
}
.p-button__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 100px;
  background: var(--button-bg);
  color: var(--button-txt);
  transition: var(--transition-hover);
}
.is-hover:hover .p-button__inner,
.p-button__inner.is-hover:hover {
  background: var(--button-hover-bg);
  color: var(--button-hover-txt);
}
.p-button__inner .c-blank {
  margin-left: 0.7rem;
}
.p-button__txt {
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-size: var(--font-size10);
  letter-spacing: calc(60 / 1000 * 1em);
}
.p-button__txt::after,
.p-button__txt::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-button__txt::before {
  margin-top: var(--font-en-top);
}
.p-button__txt::after {
  margin-bottom: var(--font-en-bottom);
}
.p-button2 {
  --button-txt: var(--color-main);
  --button-hover-bg: var(--color-main);
  --button-hover-txt: var(--color-main-white);
  width: 100%;
}
@media screen and (min-width: 561px) {
  .p-button2 {
    max-width: 18.2rem;
    height: 5.8rem;
  }
}
@media screen and (max-width: 560px) {
  .p-button2 {
    max-width: 16.4rem;
    height: 4.6rem;
  }
}
.p-button2__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border: solid 1px var(--button-txt);
  border-radius: var(--radius-size5);
  color: var(--button-txt);
  transition: var(--transition-hover);
}
.is-hover:hover .p-button2__inner,
.p-button2__inner.is-hover:hover {
  background: var(--button-hover-bg);
  color: var(--button-hover-txt);
}
.is-hover:hover .p-button2__inner .c-instagram::before,
.p-button2__inner.is-hover:hover .c-instagram::before {
  opacity: 0;
}
.is-hover:hover .p-button2__inner .c-instagram svg,
.p-button2__inner.is-hover:hover .c-instagram svg {
  opacity: 1;
}
.p-button2__inner .c-blank {
  margin-left: 0.4rem;
}
.p-button2__txt {
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-size: var(--font-size10);
  letter-spacing: calc(60 / 1000 * 1em);
}
.p-button2__txt::after,
.p-button2__txt::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-button2__txt::before {
  margin-top: var(--font-en-top);
}
.p-button2__txt::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (max-width: 1023px) {
  .p-button2__txt {
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
  }
}
.p-button3 {
  --button-bg: var(--color-gradation);
  --button-txt: var(--color-white);
  --button-hover-bg: var(--color-white);
  --button-hover-txt: var(--color-main);
}
@media screen and (min-width: 561px) {
  .p-button3.-small {
    width: 15.3rem;
    height: 5rem;
  }
}
@media screen and (max-width: 560px) {
  .p-button3.-small {
    width: 11.1rem;
    height: 4rem;
  }
}
.p-button3.-small .p-button3__inner {
  font-family: var(--font-sans-serif);
  letter-spacing: calc(80 / 1000 * 1em);
}
@media screen and (min-width: 1024px) {
  .p-button3.-small .p-button3__inner {
    font-size: var(--font-size18);
  }
}
@media screen and (max-width: 1023px) {
  .p-button3.-small .p-button3__inner {
    font-size: var(--font-size14);
  }
}
.p-button3__inner {
  width: 100%;
  height: 100%;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 0;
  overflow: hidden;
  border-radius: 100px;
  background: var(--button-bg);
  color: var(--button-txt);
}
.p-button3__inner::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  border-radius: inherit;
  background: var(--button-hover-bg);
  opacity: 0;
  transition: opacity var(--transition-hover);
}
.is-hover:hover .p-button3__inner,
.p-button3__inner.is-hover:hover {
  color: var(--button-hover-txt);
}
.is-hover:hover .p-button3__inner::before,
.p-button3__inner.is-hover:hover::before {
  opacity: 1;
}
.p-daliy__title {
  text-align: center;
  text-transform: uppercase;
  color: var(--color-bg6);
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  letter-spacing: calc(80 / 1000 * 1em);
  margin-bottom: -0.2rem;
}
.p-daliy__title::after,
.p-daliy__title::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-daliy__title::before {
  margin-top: var(--font-en-top);
}
.p-daliy__title::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .p-daliy__title {
    font-size: var(--font-size70);
  }
}
@media screen and (max-width: 1023px) {
  .p-daliy__title {
    font-size: var(--font-size45);
  }
}
@media screen and (max-width: 560px) {
  .p-daliy__title.-type2 {
    font-size: var(--font-size30);
  }
}
.p-daliy__main {
  border-radius: var(--radius-size50);
  background-color: var(--color-bg6);
  color: var(--color-txt2);
}
.p-hero {
  z-index: 10;
}
.p-hero__absolute {
  position: absolute;
  left: 0;
  z-index: 100;
  z-index: 1000;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .p-hero__absolute {
    top: 16rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .p-hero__absolute {
    top: 10rem;
  }
}
@media screen and (max-width: 560px) {
  .p-hero__absolute {
    top: 9.3rem;
  }
}
.p-hero__title {
  position: absolute;
  top: 0;
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (min-width: 1024px) {
  .p-hero__title {
    right: 3.2rem;
    right: calc((32 / 1400) * 100%);
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__title {
    right: calc((15 / 375) * 100%);
  }
}
.p-hero__title__en {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
}
.p-hero__title__en::after,
.p-hero__title__en::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-hero__title__en::before {
  margin-left: var(--font-en-top);
}
.p-hero__title__en::after {
  margin-right: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .p-hero__title__en {
    font-size: var(--font-size60);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .p-hero__title__en {
    font-size: var(--font-size42);
  }
}
@media screen and (max-width: 560px) {
  .p-hero__title__en {
    font-size: var(--font-size36);
  }
}
.p-hero__title__ja {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  text-orientation: upright;
  letter-spacing: calc(130 / 1000 * 1em);
}
@media screen and (min-width: 1024px) {
  .p-hero__title__ja {
    font-size: var(--font-size18);
    margin-right: 2.5rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .p-hero__title__ja {
    font-size: var(--font-size16);
    margin-right: 2rem;
  }
}
@media screen and (max-width: 560px) {
  .p-hero__title__ja {
    font-size: var(--font-size14);
    margin-right: 1.6rem;
  }
}
.p-hero__breadcrumb {
  position: absolute;
  top: 0;
  z-index: 100;
  z-index: 1000;
}
@media screen and (min-width: 1024px) {
  .p-hero__breadcrumb {
    left: calc((32 / 1400) * 100%);
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__breadcrumb {
    left: calc((15 / 375) * 100%);
  }
}
.p-hero__breadcrumb li:last-of-type a {
  opacity: 0.5;
}
.p-hero__breadcrumb li:not(:last-of-type)::after {
  content: "";
  display: block;
  background-color: currentColor;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  margin: 0 auto;
}
@media screen and (min-width: 1024px) {
  .p-hero__breadcrumb li:not(:last-of-type)::after {
    width: 0.6rem;
    height: 0.4rem;
    margin-top: 1.6rem;
    margin-bottom: 1.3rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__breadcrumb li:not(:last-of-type)::after {
    width: 0.5rem;
    height: 0.3rem;
    margin-top: 1rem;
    margin-bottom: 0.8rem;
  }
}
.p-hero__breadcrumb a {
  display: block;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-size: var(--font-size12);
  font-weight: 500;
  letter-spacing: calc(30 / 1000 * 1em);
  padding: 0 0.5rem;
  margin: 0 -0.5rem;
}
.p-hero__breadcrumb a::after,
.p-hero__breadcrumb a::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-hero__breadcrumb a::before {
  margin-left: var(--font-en-top);
}
.p-hero__breadcrumb a::after {
  margin-right: var(--font-en-bottom);
}
.p-hero__title2 {
  text-align: center;
}
@media screen and (min-width: 1024px) {
  .p-hero__title2 {
    margin-top: 16.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__title2 {
    margin-top: 23rem;
  }
}
.p-hero__title2__ja {
  letter-spacing: calc(100 / 1000 * 1em);
}
@media screen and (min-width: 1024px) {
  .p-hero__title2__ja {
    font-size: var(--font-size30);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .p-hero__title2__ja {
    font-size: var(--font-size26);
  }
}
@media screen and (max-width: 560px) {
  .p-hero__title2__ja {
    font-size: var(--font-size20);
  }
}
.p-hero__title2__en {
  margin: 0 auto;
}
@media screen and (min-width: 1024px) {
  .p-hero__title2__en {
    font-size: var(--font-size42);
    margin-top: 2.6rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .p-hero__title2__en {
    font-size: var(--font-size36);
    margin-top: 2.2rem;
  }
}
@media screen and (max-width: 560px) {
  .p-hero__title2__en {
    font-size: var(--font-size28);
    margin-top: 1.7rem;
  }
}
.p-hero__and {
  position: relative;
  z-index: 10;
  pointer-events: none;
}
@media screen and (min-width: 561px) {
  .p-hero__and {
    display: flex;
    align-items: flex-start;
  }
}
@media screen and (min-width: 1024px) {
  .p-hero__and {
    margin-top: 13rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__and {
    margin-top: 10rem;
    padding: 0 var(--contents-outside-vw);
  }
}
@media screen and (max-width: 560px) {
  .p-hero__and {
    margin-top: 8.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .p-hero__and.-absolute {
    position: absolute;
    top: 0;
    left: calc((110 / 1400) * 100%);
  }
}
@media screen and (min-width: 1024px) {
  .p-hero__and__and {
    width: 298px;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__and__and {
    width: 19.8rem;
    margin-left: 0.8rem;
  }
}
.p-hero__and__and svg {
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 1024px) {
  .p-hero__and__txt {
    margin-top: 7rem;
    margin-left: -0.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__and__txt {
    margin-top: 5.5rem;
  }
}
.p-hero__and__num {
  position: relative;
  display: flex;
  align-items: flex-start;
}
@media screen and (min-width: 1024px) {
  .p-hero__and__num {
    font-size: var(--font-size38);
    margin-top: 3rem;
    margin-left: -6.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__and__num {
    font-size: var(--font-size24);
    margin-top: 2.1rem;
    margin-left: 1.8rem;
  }
}
.p-hero__and__num::before {
  content: "";
  display: block;
  width: 1px;
  background-color: currentColor;
  position: absolute;
  bottom: -0.1rem;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
}
@media screen and (min-width: 1024px) {
  .p-hero__and__num::before {
    height: 7.6rem;
    left: 2.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__and__num::before {
    height: 4.8rem;
    left: 1.7rem;
  }
}
.p-hero__and__num span {
  display: inline-block;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
}
.p-hero__and__num span::after,
.p-hero__and__num span::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-hero__and__num span::before {
  margin-top: var(--font-en-top);
}
.p-hero__and__num span::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .p-hero__and__num span:nth-of-type(2) {
    margin-top: 2.5rem;
    margin-left: 1.4rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__and__num span:nth-of-type(2) {
    margin-top: 1.6rem;
    margin-left: 0.8rem;
  }
}
@media screen and (min-width: 1024px) {
  .p-hero__txt {
    padding-top: 20rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__txt {
    padding: 24rem calc(var(--contents-outside-vw) * 3) 0
      var(--contents-outside-vw);
  }
}
.p-hero__img {
  position: relative;
  margin-bottom: calc(var(--slope-height) * -0.5);
}
@media screen and (min-width: 1024px) {
  .p-hero__img {
    width: calc((1250 / 1400) * 100%);
    margin-top: 15.8rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .p-hero__img {
    margin-top: 12rem;
  }
}
@media screen and (max-width: 560px) {
  .p-hero__img {
    margin-top: 4.9rem;
  }
}
.p-hero__img__catch {
  position: absolute;
  z-index: 10;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  text-orientation: upright;
  -webkit-font-feature-settings: "vpal" 1;
  font-feature-settings: "vpal" 1;
  font-weight: 500;
}
@media screen and (min-width: 1024px) {
  .p-hero__img__catch {
    font-size: var(--font-size24);
    --line-height: calc(51.5122 / 24);
    top: 23.2rem;
    right: calc((95 / 1250) * 100%);
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__img__catch {
    --line-height: calc(29.0137 / 14);
    letter-spacing: calc(20 / 1000 * 1em);
    top: -3rem;
    right: calc((42 / 375) * 100%);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .p-hero__img__catch {
    font-size: var(--font-size20);
  }
}
@media screen and (max-width: 560px) {
  .p-hero__img__catch {
    font-size: var(--font-size14);
  }
}
.p-hero__img__figure {
  --shadow-radius: var(--radius-size40);
}
@media screen and (min-width: 1024px) {
  .p-hero__img__figure {
    --slope-radius: 0 var(--radius-size40) var(--radius-size40) 0;
    --shadow-width: calc((1180 / 1250) * 100%);
    --shadow-top: 5.2rem;
    --shadow-left: 7.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__img__figure {
    --shadow-width: calc((406 / 375) * 100%);
    --shadow-top: 3.7rem;
    --shadow-left: 3.4rem;
  }
}
.p-hero__img__figure__inner {
  position: relative;
}
@media screen and (min-width: 1024px) {
  .p-hero__img__figure__inner {
    max-height: 120rem;
    min-height: 85rem;
  }
}
@media screen and (max-width: 560px) {
  .p-hero__img__figure__inner {
    min-height: 34.2rem;
  }
}
.p-hero__img__figure__inner::after {
  content: "";
  display: block;
}
@media screen and (min-width: 768px) {
  .p-hero__img__figure__inner::after {
    padding-top: calc((850 / 1250) * 100%);
  }
}
@media screen and (max-width: 767px) {
  .p-hero__img__figure__inner::after {
    padding-top: calc((342 / 375) * 100%);
  }
}
@media screen and (min-width: 1024px) {
  .p-hero__carousel {
    margin-top: 13.4rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__carousel {
    margin-top: 17rem;
  }
}
.p-hero__carousel .slick-track::before {
  content: "";
  display: block;
  width: 100%;
  background: var(--color-bg);
  position: absolute;
  left: 0;
  bottom: 0;
}
.p-hero__carousel__content {
  -webkit-transform: var(--slope);
  transform: var(--slope);
}
.p-hero__carousel__content:not(.slick-initialized) {
  height: 0;
  overflow: hidden;
}
.p-hero__carousel__cell {
  -webkit-transform: translate3d(0, 0, 0) var(--slope--positive);
  transform: translate3d(0, 0, 0) var(--slope--positive);
  --shadow-radius: var(--radius-size40);
}
@media screen and (min-width: 1024px) {
  .p-hero__carousel__cell {
    width: 78rem;
    margin: 0 1.2rem;
    --shadow-width: calc((284 / 318) * 100%);
    --shadow-top: 5.6rem;
    --shadow-left: 4.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__carousel__cell {
    width: calc(285 / 375 * 100vw);
    margin: 0 calc(7 / 375 * 100vw);
    --shadow-width: calc((255 / 285) * 100%);
    --shadow-top: 2.7rem;
    --shadow-left: 3rem;
  }
}
.p-hero__carousel__cell::before {
  z-index: -1;
}
.p-hero__carousel__cell div {
  display: block;
  position: relative;
  z-index: 100;
  -webkit-clip-path: url(#svg-p-hero-carousel);
  clip-path: url(#svg-p-hero-carousel);
}
@media screen and (min-width: 1024px) {
  .p-hero__carousel__dots {
    position: absolute;
    top: 50%;
    left: calc((30 / 1400) * 100%);
    -webkit-transform: var(--slope--positive) translateY(-50%);
    transform: var(--slope--positive) translateY(-50%);
    z-index: 10;
  }
}
@media screen and (max-width: 1023px) {
  .p-hero__carousel__dots {
    display: none !important;
  }
}
.p-nav a {
  display: inline-flex;
  align-items: center;
  vertical-align: top;
  width: 100%;
}
.p-nav a::before {
  content: "";
  display: block;
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  background-color: var(--color-accent);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  transition: -webkit-transform var(--transition-hover);
  transition: transform var(--transition-hover);
  transition: transform var(--transition-hover),
    -webkit-transform var(--transition-hover);
}
@media screen and (min-width: 561px) {
  .p-nav a::before {
    width: 0.4rem;
    height: 0.6rem;
    margin-right: 1.8rem;
  }
}
@media screen and (max-width: 560px) {
  .p-nav a::before {
    width: 0.3rem;
    height: 0.5rem;
    margin-right: 1.3rem;
  }
}
.p-nav a.is-hover:hover::before {
  -webkit-transform: translate3d(0.5rem, 0, 0);
  transform: translate3d(0.5rem, 0, 0);
}
@media screen and (min-width: 1024px) {
  .p-nav .c-blank {
    margin-left: 0.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-nav .c-blank {
    margin-left: 0.7rem;
  }
}
.p-nav.-type1 li {
  border-bottom: solid 1px;
}
@media screen and (min-width: 1024px) {
  .p-nav.-type1 a {
    height: 6.6rem;
    padding: 0 0 0 0.4rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-nav.-type1 a {
    height: 4.4rem;
    padding: 0 0.8rem;
  }
}
@media screen and (min-width: 1024px) {
  .p-nav.-type1 .p-nav__en .p-nav__txt {
    font-size: var(--font-size20);
  }
}
@media screen and (max-width: 1023px) {
  .p-nav.-type1 .p-nav__en .p-nav__txt {
    font-size: var(--font-size16);
  }
}
@media screen and (min-width: 1024px) {
  .p-nav.-type1 .p-nav__en__large {
    font-size: var(--font-size30);
  }
}
@media screen and (min-width: 1024px) {
  .p-nav.-type1 .p-nav__ja .p-nav__txt {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-nav.-type1 .p-nav__ja .p-nav__txt {
    font-size: var(--font-size13);
  }
}
@media screen and (min-width: 768px) {
  .p-nav.-type2 {
    display: flex;
  }
}
@media screen and (max-width: 767px) {
  .p-nav.-type2 ul {
    width: 22rem;
  }
}
@media screen and (max-width: 560px) {
  .p-nav.-type2 ul {
    width: 16.8rem;
  }
}
@media screen and (min-width: 768px) {
  .p-nav.-type2 ul + ul {
    margin-left: 5.3rem;
  }
}
@media screen and (max-width: 767px) {
  .p-nav.-type2 ul + ul {
    border-top: solid 1px var(--color-line);
    margin-top: 2.5rem;
    padding-top: 2.3rem;
  }
}
@media screen and (min-width: 1024px) {
  .p-nav.-type2 li + li {
    margin-top: 2.7rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-nav.-type2 li + li {
    margin-top: 1.7rem;
  }
}
.p-nav.-type2 a {
  padding: 0.5rem 0;
  margin: -0.5rem 0;
}
@media screen and (min-width: 1024px) {
  .p-nav.-type2 .p-nav__en .p-nav__txt {
    font-size: var(--font-size18);
  }
}
@media screen and (max-width: 1023px) {
  .p-nav.-type2 .p-nav__en .p-nav__txt {
    font-size: var(--font-size15);
  }
}
@media screen and (min-width: 1024px) {
  .p-nav.-type2 .p-nav__en__large {
    font-size: var(--font-size28);
  }
}
@media screen and (min-width: 1024px) {
  .p-nav.-type2 .p-nav__ja .p-nav__txt {
    font-size: var(--font-size14);
  }
}
@media screen and (max-width: 1023px) {
  .p-nav.-type2 .p-nav__ja .p-nav__txt {
    font-size: var(--font-size12);
  }
}
@media screen and (min-width: 561px) {
  .p-nav__num {
    width: 1.4rem;
    margin-right: 1.2rem;
    margin-bottom: -0.2rem;
  }
}
@media screen and (max-width: 560px) {
  .p-nav__num {
    width: 1.1rem;
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    margin-right: 0.6rem;
    margin-bottom: -0.1rem;
  }
}
.p-nav__num::before {
  font-weight: 400;
  font-size: var(--font-size10);
  letter-spacing: calc(80 / 1000 * 1em);
}
.p-nav__en .p-nav__txt {
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 400;
  letter-spacing: calc(80 / 1000 * 1em);
}
.p-nav__en .p-nav__txt::after,
.p-nav__en .p-nav__txt::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-nav__en .p-nav__txt::before {
  margin-top: var(--font-en-top);
}
.p-nav__en .p-nav__txt::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (max-width: 1023px) {
  .p-nav__en__large {
    font-size: var(--font-size24);
  }
}
.p-nav__en__large {
  display: inline-block;
  margin-top: -1rem;
}
.p-nav__ja .p-nav__txt {
  font-weight: 500;
  letter-spacing: calc(100 / 1000 * 1em);
}
.p-nav__accordion {
  position: relative;
}
.p-nav__accordion.is-open .p-nav__switch span:nth-of-type(2) {
  height: 0;
}
@media screen and (min-width: 768px) {
  .p-nav__switch {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .p-nav__switch {
    position: absolute;
    top: 0;
    right: 0;
    width: 4rem;
    height: 4.4rem;
  }
}
.p-nav__switch i {
  position: relative;
  display: block;
  width: 1.6rem;
  height: 1.6rem;
  margin: 0 auto;
}
.p-nav__switch span {
  display: block;
  background-color: var(--color-txt2);
}
.p-nav__switch span:nth-of-type(1) {
  width: 100%;
  height: 1px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(0.00001deg);
  transform: translate(-50%, -50%) rotate(0.00001deg);
}
.p-nav__switch span:nth-of-type(2) {
  width: 1px;
  height: 100%;
  margin: 0 auto;
  transition: height var(--transition-accordion);
}
.p-nav__panel ul {
  border-top: solid 1px;
}
.p-nav__panel li:last-of-type {
  border-bottom: none;
}
.p-pagination {
  width: 100%;
}
@media screen and (min-width: 561px) {
  .p-pagination {
    max-width: 44rem;
  }
}
@media screen and (max-width: 560px) {
  .p-pagination {
    max-width: 25.4rem;
  }
}
.p-pagination ul {
  border-top: solid 1px;
  border-bottom: solid 1px;
}
@media screen and (min-width: 1024px) {
  .p-pagination ul {
    padding-top: 6.2rem;
    padding-bottom: 6.3rem;
    padding-left: 0.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .p-pagination ul {
    padding-top: 4rem;
    padding-bottom: 4.2rem;
    padding-left: 0.1rem;
  }
}
.p-pagination li + li {
  margin-top: 2.9rem;
}
.p-pagination a {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 1024px) {
  .p-pagination a {
    padding-left: 0.2rem;
  }
}
.p-pagination .c-arrow {
  -webkit-transform: var(--slope--positive);
  transform: var(--slope--positive);
}
.p-pagination__num {
  opacity: 0.5;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
}
.p-pagination__num::after,
.p-pagination__num::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-pagination__num::before {
  margin-top: var(--font-en-top);
}
.p-pagination__num::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .p-pagination__num {
    width: 7rem;
    padding-left: 3rem;
    font-size: var(--font-size14);
  }
}
@media screen and (max-width: 1023px) {
  .p-pagination__num {
    width: 4.7rem;
    padding-left: 1.7rem;
    font-size: var(--font-size11);
  }
}
.p-pagination__title {
  flex: 1;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  letter-spacing: calc(50 / 1000 * 1em);
}
.p-pagination__title::after,
.p-pagination__title::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.p-pagination__title::before {
  margin-top: var(--font-en-top);
}
.p-pagination__title::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .p-pagination__title {
    font-size: var(--font-size22);
  }
}
@media screen and (max-width: 1023px) {
  .p-pagination__title {
    font-size: var(--font-size16);
  }
}
.l-contact {
  position: relative;
  z-index: var(--z-index-l-contact);
  margin-top: calc(var(--slope-height) * -0.5);
  margin-bottom: -1px;
  --jaggy-color-top: var(--color-bg3);
  --jaggy-color-bottom: var(--color-bg3);
}
.l-contact .c-jaggy {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100% - var(--bottom));
  margin-top: 0;
  padding-top: 0;
  padding-bottom: 0;
  z-index: 100;
}
@media screen and (min-width: 1024px) {
  .l-contact .c-jaggy {
    bottom: 12rem;
  }
}
@media screen and (min-width: 1681px) {
  .l-contact .c-jaggy {
    --bottom: 20%;
  }
}
@media screen and (min-width: 1921px) {
  .l-contact .c-jaggy {
    --bottom: 15%;
  }
}
@media screen and (min-width: 2561px) {
  .l-contact .c-jaggy {
    --bottom: 10%;
  }
}
@media screen and (max-width: 1023px) {
  .l-contact .c-jaggy {
    --bottom: 20%;
  }
}
.l-contact .c-jaggy__inner {
  background-color: var(--color-bg3);
}
.l-contact__bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-bg2);
  -webkit-clip-path: polygon(0 var(--slope-height), 100% 0, 100% 100%, 0 100%);
  clip-path: polygon(0 var(--slope-height), 100% 0, 100% 100%, 0 100%);
}
.l-contact__body {
  position: relative;
  z-index: 1000;
}
@media screen and (min-width: 1024px) {
  .l-contact__body {
    padding-top: calc(var(--slope-height) * 0.5);
  }
}
@media screen and (max-width: 1023px) {
  .l-contact__body {
    padding-top: calc(var(--slope-height) * 0.5 + 6.6rem);
  }
}
.l-footer {
  position: relative;
  background-color: var(--color-bg2);
}
@media screen and (min-width: 1024px) {
  .l-footer {
    padding-top: 17.7rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer {
    padding-top: 8.5rem;
  }
}
.l-footer__inner {
  position: relative;
  color: var(--color-txt2);
}
@media screen and (min-width: 1024px) {
  .l-footer__inner {
    --logo-width: 17.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__inner {
    --logo-width: 12rem;
    padding: 0 var(--contents-outside-vw);
  }
}
.l-footer__inner .c-inner-medium {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1024px) {
  .l-footer__inner .c-inner-medium {
    padding: 0 1.3rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__inner .c-inner-medium {
    padding: 0 0.3rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-footer__inner .c-logo {
    margin-left: 0.2rem;
  }
}
.l-footer__en {
  position: absolute;
  right: 0;
  color: var(--color-txt3);
  text-align: right;
  z-index: 0;
  pointer-events: none;
}
@media screen and (min-width: 1024px) {
  .l-footer__en {
    bottom: -17.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__en {
    bottom: -5.5rem;
  }
}
.l-footer__en span {
  display: block;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  letter-spacing: calc(40 / 1000 * 1em);
}
.l-footer__en span::after,
.l-footer__en span::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.l-footer__en span::before {
  margin-top: var(--font-en-top);
}
.l-footer__en span::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .l-footer__en span {
    font-size: var(--font-size186);
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__en span {
    font-size: var(--font-size74);
  }
}
@media screen and (min-width: 1024px) {
  .l-footer__en span + span {
    margin-top: 5rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__en span + span {
    margin-top: 3.3rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-footer__nav {
    margin-top: 6.5rem;
    margin-left: 0.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__nav {
    margin-top: 4.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-footer__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 5.1rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__bottom {
    margin-top: 3.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-footer__bottom .p-button2 {
    margin-top: 0.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-footer__other {
    margin-top: 0.2rem;
    margin-right: -1rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__other {
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-end;
    justify-content: space-between;
    margin-top: 2.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__pagetop {
    margin-bottom: 0.4rem;
  }
}
.l-footer__pagetop a {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.l-footer__pagetop a.is-hover:hover .l-footer__pagetop__icon::before {
  -webkit-transform: translate3d(0, -0.5rem, 0);
  transform: translate3d(0, -0.5rem, 0);
}
.l-footer__pagetop__txt {
  text-transform: uppercase;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 400;
  letter-spacing: calc(80 / 1000 * 1em);
}
.l-footer__pagetop__txt::after,
.l-footer__pagetop__txt::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.l-footer__pagetop__txt::before {
  margin-top: var(--font-en-top);
}
.l-footer__pagetop__txt::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .l-footer__pagetop__txt {
    font-size: var(--font-size18);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .l-footer__pagetop__txt {
    font-size: var(--font-size16);
  }
}
@media screen and (max-width: 560px) {
  .l-footer__pagetop__txt {
    font-size: var(--font-size13);
  }
}
.l-footer__pagetop__icon {
  display: block;
  border-bottom: solid 1px;
}
@media screen and (min-width: 561px) {
  .l-footer__pagetop__icon {
    width: 1.5rem;
    margin-left: 1.2rem;
  }
}
@media screen and (max-width: 560px) {
  .l-footer__pagetop__icon {
    width: 1rem;
    margin-left: 0.8rem;
  }
}
.l-footer__pagetop__icon::before {
  content: "";
  display: block;
  background-image: url(../img/common/icon/up.svg);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  transition: -webkit-transform var(--transition-hover);
  transition: transform var(--transition-hover);
  transition: transform var(--transition-hover),
    -webkit-transform var(--transition-hover);
}
@media screen and (min-width: 561px) {
  .l-footer__pagetop__icon::before {
    width: 1.5rem;
    height: 0.8rem;
    margin-bottom: 0.5rem;
  }
}
@media screen and (max-width: 560px) {
  .l-footer__pagetop__icon::before {
    width: 1rem;
    height: 0.6rem;
    margin-bottom: 0.4rem;
  }
}
.l-footer__copyright {
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 400;
  font-size: var(--font-size8);
  --line-height: calc(15 / 7);
  letter-spacing: calc(100 / 1000 * 1em);
}
.l-footer__copyright::after,
.l-footer__copyright::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.l-footer__copyright::before {
  margin-top: var(--font-en-top);
}
.l-footer__copyright::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (min-width: 1024px) {
  .l-footer__copyright {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
    margin-top: 3rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__copyright {
    -webkit-transform: scale(0.7);
    transform: scale(0.7);
    -webkit-transform-origin: 0 100%;
    transform-origin: 0 100%;
  }
}
.l-footer__corporate {
  margin: 0 0 0 auto;
}
@media screen and (min-width: 1024px) {
  .l-footer__corporate {
    width: calc(100% - 5.6rem);
    height: 20.8rem;
    margin-top: 16.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__corporate {
    width: calc(100vw - var(--scrollbar-width) - var(--contents-outside-vw));
    height: 17rem;
    margin-top: 5.7rem;
  }
}
.l-footer__corporate a {
  position: relative;
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-size150) 0 0 0;
  color: var(--color-txt);
  overflow: hidden;
}
@media screen and (min-width: 1024px) {
  .l-footer__corporate a {
    padding: 0.9rem 8rem 0 8.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer__corporate a {
    padding: 0 3.6rem 0 6rem;
  }
}
@media screen and (max-width: 560px) {
  .l-footer__corporate .p-button {
    margin-top: 0.8rem;
  }
}
.l-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--z-index-l-header);
  width: 100%;
  background: 0 0 !important;
}
@media screen and (min-width: 1024px) {
  .l-header {
    --logo-width: 17rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .l-header {
    --logo-width: 14rem;
  }
}
@media screen and (max-width: 560px) {
  .l-header {
    --logo-width: 12rem;
  }
}
@media screen and (max-width: 560px) {
  .l-header.is-sticky {
    --logo-width: 11rem;
  }
}
.l-header.is-sticky .l-header__inner {
  background: var(--color-bg);
  box-shadow: var(--shadow-sticky--sticky);
  color: var(--color-txt);
}
@media screen and (min-width: 1024px) {
  .l-header.is-sticky .l-header__inner {
    padding: 1.2rem 2rem 1rem 2.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-header.is-sticky .l-header__inner {
    padding: 0.5rem 0.8rem 0.5rem 1.6rem;
  }
}
@media screen and (max-width: 560px) {
  .l-header.is-sticky .l-header__entry {
    width: 8rem;
    height: 2.6rem;
  }
}
.l-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: var(--shadow-sticky);
  transition: var(--transition-sticky);
  transition-property: padding, box-shadow, background-color;
}
@media screen and (min-width: 1024px) {
  .l-header__inner {
    padding: 2.2rem 3.2rem 2.2rem 3rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-header__inner {
    padding: 1rem 1.3rem 1rem 1.5rem;
  }
}
.l-header__inner .c-logo {
  position: relative;
  z-index: 10;
}
.l-header__inner .c-logo__logo {
  transition: var(--transition-sticky);
  transition-property: width;
}
.l-header__nav {
  position: absolute;
  width: 100%;
  left: 0;
  padding-left: 2.1rem;
}
@media screen and (max-width: 1023px) {
  .l-header__nav {
    display: none;
  }
}
.l-header__nav__list {
  display: flex;
  align-items: center;
  justify-content: center;
}
.l-header__nav__accordion {
  display: flex;
  align-items: center;
  margin-right: 2rem;
}
.l-header__nav__accordion__txt {
  display: block;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 500;
  font-size: var(--font-size14);
}
.l-header__nav__accordion__txt::after,
.l-header__nav__accordion__txt::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.l-header__nav__accordion__txt::before {
  margin-top: var(--font-en-top);
}
.l-header__nav__accordion__txt::after {
  margin-bottom: var(--font-en-bottom);
}
.l-header__nav__accordion__main {
  position: relative;
  --height: 100%;
  color: var(--color-accordion-txt);
  font-family: var(--font-sans-serif);
  font-weight: 500;
  font-size: var(--font-size14);
  margin-left: 1.2rem;
}
.l-header__nav__accordion__main.is-open .l-header__nav__accordion__body {
  opacity: 1;
  pointer-events: auto;
}
.l-header__nav__accordion__main::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--height);
  border-radius: var(--radius-size10);
  background-color: var(--color-accordion-bg);
  transition: height var(--transition-accordion);
}
.l-header__nav__accordion__switch {
  position: relative;
  display: flex;
  align-items: center;
  width: 11.3rem;
  height: 4rem;
  border-radius: var(--radius-size10);
  padding: 0 2rem;
}
.l-header__nav__accordion__switch::before {
  content: "";
  display: block;
  width: 6px;
  height: 3px;
  -webkit-clip-path: polygon(100% 0, 0 0, 50% 100%);
  clip-path: polygon(100% 0, 0 0, 50% 100%);
  background-color: var(--color-accordion-txt);
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.l-header__nav__accordion__body {
  position: absolute;
  width: 100%;
  opacity: 0;
  transition: opacity var(--transition-accordion);
  pointer-events: none;
}
.l-header__nav__accordion__body ul {
  padding: 0 0 2rem;
}
.l-header__nav__accordion__body li + li {
  margin-top: 1.2rem;
}
.l-header__nav__accordion__body li.is-hidden {
  display: none;
}
.l-header__nav__accordion__body a {
  display: block;
  padding: 0.3rem 2rem;
}
.l-header__nav__accordion__body a.is-hover:hover {
  opacity: 0.5;
}
.l-header__nav__bacic a {
  position: relative;
  display: block;
  border-radius: 100px;
  font-family: var(--font-mix);
  font-weight: 500;
  font-size: var(--font-size14);
  padding: 0.5rem 1.7rem;
}
.l-header__nav__stalker {
  position: absolute;
  display: block;
  border-radius: 100px;
  background-color: var(--color-txt);
  opacity: 0;
  transition: var(--transition-stalker);
  pointer-events: none;
}
.l-header__nav__stalker.is-move {
  opacity: 0.1;
}
.l-header__buttons {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 561px) {
  .l-header__entry {
    width: 12rem;
    height: 4rem;
  }
}
@media screen and (max-width: 560px) {
  .l-header__entry {
    width: 8rem;
    height: 2.9rem;
  }
}
.l-header__entry a {
  position: relative;
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 100px;
  color: var(--color-txt3);
  text-transform: uppercase;
  font-family: var(--font-sans-serif);
  font-weight: 500;
  overflow: hidden;
}
@media screen and (min-width: 561px) {
  .l-header__entry a {
    font-size: var(--font-size14);
  }
}
@media screen and (max-width: 560px) {
  .l-header__entry a {
    font-weight: 600;
    font-size: var(--font-size10);
  }
}
.l-header__button {
  position: relative;
  z-index: 0;
  border-radius: 50%;
  overflow: hidden;
}
@media screen and (min-width: 561px) {
  .l-header__button {
    width: 4.1rem;
    height: 4.1rem;
    margin-left: 1rem;
  }
}
@media screen and (max-width: 560px) {
  .l-header__button {
    width: 3rem;
    height: 3rem;
    margin-left: 0.7rem;
  }
}
.l-header__button.is-hover:hover {
  background-color: var(--color-txt);
}
.l-header__button.is-hover:hover span {
  background-color: var(--color-main);
}
.l-header__button span {
  display: block;
  height: 1px;
  margin: 0 auto;
  background-color: currentColor;
  transition: background-color var(--transition-hover);
}
@media screen and (min-width: 1024px) {
  .l-header__button span {
    width: 1.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-header__button span {
    width: 0.8rem;
  }
}
@media screen and (min-width: 561px) {
  .l-header__button span:nth-of-type(2) {
    margin-top: 0.4rem;
    margin-bottom: 0.4rem;
  }
}
@media screen and (max-width: 560px) {
  .l-header__button span:nth-of-type(2) {
    margin-top: 0.3rem;
    margin-bottom: 0.3rem;
  }
}
.l-header__button svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 96%;
}
.l-header__button path {
  stroke: currentColor;
}
@media screen and (max-width: 560px) {
  .l-header__button path {
    stroke-width: 2px;
  }
}
.l-main {
  position: relative;
  z-index: var(--z-index-l-main);
  padding-top: 0.1px;
}
.l-sitemap {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--z-index-l-sitemap);
  width: 100%;
  height: calc(var(--vh) * 100);
  overflow: auto;
  pointer-events: none;
}
@media screen and (min-width: 1024px) {
  .l-sitemap {
    --logo-width: 17.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap {
    --logo-width: 9.8rem;
  }
}
.l-sitemap.is-open {
  pointer-events: auto;
}
.l-sitemap.is-open .l-sitemap__body {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.l-sitemap.is-open .l-sitemap__inner {
  opacity: 1;
  transition-delay: 0.7s;
}
.l-sitemap__body {
  position: absolute;
  top: 0;
  left: 0;
  z-index: var(--z-index-l-sitemap);
  width: 100%;
  background-color: var(--color-bg4);
  color: var(--color-txt2);
  -webkit-clip-path: polygon(
    0 0,
    100% 0,
    100% calc(100% - var(--slope-height)),
    0 100%
  );
  clip-path: polygon(
    0 0,
    100% 0,
    100% calc(100% - var(--slope-height)),
    0 100%
  );
  -webkit-transform: translate3d(0, -100%, 0);
  transform: translate3d(0, -100%, 0);
  transition: -webkit-transform var(--transition-modal);
  transition: transform var(--transition-modal);
  transition: transform var(--transition-modal),
    -webkit-transform var(--transition-modal);
}
@media screen and (min-width: 1024px) {
  .l-sitemap__body {
    padding: 11rem calc((110 / 1400) * 100%)
      calc(var(--slope-height) / 2 + 0.3rem);
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .l-sitemap__body {
    padding: 5rem var(--contents-outside-vw)
      calc(var(--slope-height) / 2 + 4rem);
  }
}
@media screen and (max-width: 560px) {
  .l-sitemap__body {
    padding: 3.6rem calc(var(--contents-outside-vw) * 2)
      calc(var(--slope-height) / 2 + 4rem);
  }
}
.l-sitemap__inner {
  opacity: 0;
  transition: opacity var(--transition-modal-opacity);
}
@media screen and (min-width: 1024px) {
  .l-sitemap__inner {
    min-width: 85.8rem;
    width: calc((858 / 1180) * 100%);
  }
}
@media screen and (min-width: 1024px) {
  .l-sitemap__header {
    padding-left: 1.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__header {
    padding-left: 1rem;
  }
}
.l-sitemap__button {
  position: fixed;
}
@media screen and (min-width: 1024px) {
  .l-sitemap__button {
    width: 4.4rem;
    height: 4.4rem;
    top: 11.3rem;
    right: 11.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__button {
    width: 3.4rem;
    height: 3.4rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 561px) {
  .l-sitemap__button {
    top: 5rem;
    right: var(--contents-outside-vw);
  }
}
@media screen and (max-width: 560px) {
  .l-sitemap__button {
    top: 3.5rem;
    right: calc(var(--contents-outside-vw) * 2);
  }
}
.l-sitemap__button span {
  display: block;
  height: 1px;
  background-color: var(--color-txt2);
  position: absolute;
  top: 50%;
  left: 50%;
}
@media screen and (min-width: 1024px) {
  .l-sitemap__button span {
    width: 6rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__button span {
    width: 4.7rem;
  }
}
.l-sitemap__button span:nth-of-type(1) {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
  transform: translate(-50%, -50%) rotate(45deg);
}
.l-sitemap__button span:nth-of-type(2) {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  transform: translate(-50%, -50%) rotate(-45deg);
}
@media screen and (min-width: 561px) {
  .l-sitemap__main {
    margin-top: 4.6rem;
  }
}
@media screen and (max-width: 560px) {
  .l-sitemap__main {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-sitemap__main > :not(.l-sitemap__contact) {
    margin-left: 1.3rem;
  }
}
.l-sitemap__blank {
  display: flex;
}
@media screen and (min-width: 1024px) {
  .l-sitemap__blank {
    margin-top: 3.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__blank {
    margin-top: 1.5rem;
  }
}
.l-sitemap__blank li {
  border-bottom: solid 1px;
  align-self: flex-end;
}
@media screen and (min-width: 1024px) {
  .l-sitemap__blank li + li {
    margin-left: 4.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__blank li + li {
    margin-left: 2.3rem;
  }
}
.l-sitemap__blank a {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 1024px) {
  .l-sitemap__blank a {
    padding: 1.3rem 0.6rem 1.3rem 0.3rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__blank a {
    padding: 1rem 0.2rem 1rem 0.3rem;
  }
}
.l-sitemap__blank span {
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-size: var(--font-size10);
  letter-spacing: calc(60 / 1000 * 1em);
}
.l-sitemap__blank span::after,
.l-sitemap__blank span::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.l-sitemap__blank span::before {
  margin-top: var(--font-en-top);
}
.l-sitemap__blank span::after {
  margin-bottom: var(--font-en-bottom);
}
@media screen and (max-width: 560px) {
  .l-sitemap__blank span {
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
  }
}
@media screen and (min-width: 561px) {
  .l-sitemap__blank .c-blank {
    margin-left: 0.7rem;
  }
}
@media screen and (max-width: 560px) {
  .l-sitemap__blank .c-blank {
    margin-left: -0.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-sitemap__blank .c-instagram {
    margin-top: -0.7rem;
    margin-bottom: -0.7rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__blank .c-instagram {
    margin-top: -0.5rem;
    margin-bottom: -0.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-sitemap__contact {
    margin-top: 0.4rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__contact {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-sitemap__footer {
    margin-top: 5.2rem;
  }
}
@media screen and (max-width: 1023px) {
  .l-sitemap__footer {
    margin-top: 3.2rem;
  }
}
.l-sitemap__copyright {
  -webkit-transform: scale(0.8);
  transform: scale(0.8);
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  white-space: nowrap;
}
.l-sitemap__copyright small {
  display: block;
  font-family: var(--font-sans-serif);
  padding-top: 0.01px;
  padding-bottom: 0.01px;
  font-weight: 400;
  font-size: var(--font-size10);
}
.l-sitemap__copyright small::after,
.l-sitemap__copyright small::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  font-size: inherit;
}
.l-sitemap__copyright small::before {
  margin-top: var(--font-en-top);
}
.l-sitemap__copyright small::after {
  margin-bottom: var(--font-en-bottom);
}
.l-sitemap__copyright span {
  letter-spacing: calc(170 / 1000 * 1em);
}
.l-svg {
  position: fixed;
  z-index: -10000000;
  width: 0;
  height: 0;
}
.l-wrapper {
  background: var(--color-bg);
  overflow: hidden;
}
.u-ib {
  display: inline-block;
}
.u-inline {
  display: inline;
}
.u-block {
  display: block;
}
.u-n {
  display: none;
}
@media screen and (min-width: 1281px) {
  .u-n-mqUp-xl {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .u-n-mqUp-lg {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .u-n-mqUp-md {
    display: none;
  }
}
@media screen and (min-width: 561px) {
  .u-n-mqUp-sm {
    display: none;
  }
}
@media screen and (min-width: 415px) {
  .u-n-mqUp-xs {
    display: none;
  }
}
@media screen and (min-width: 376px) {
  .u-n-mqUp-xxs {
    display: none;
  }
}
@media screen and (max-width: 1280px) {
  .u-n-mqDown-xl {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  .u-n-mqDown-lg {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .u-n-mqDown-md {
    display: none;
  }
}
@media screen and (max-width: 560px) {
  .u-n-mqDown-sm {
    display: none;
  }
}
@media screen and (max-width: 414px) {
  .u-n-mqDown-xs {
    display: none;
  }
}
@media screen and (max-width: 375px) {
  .u-n-mqDown-xxs {
    display: none;
  }
}
.u-font-white {
  color: var(--color-white) !important;
}
.u-kerning {
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt" 1;
}
.u-pointerevent-none {
  pointer-events: none;
}
.u-relative {
  position: relative;
}
.u-reverse {
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
}
.u-ls-_001 {
  letter-spacing: -0.01em;
}
