@charset "UTF-8";@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Poppins:wght@400;500;600;700&display=swap");html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  font-weight: normal;
}

body {
  line-height: 1;
}

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

ul,
ol {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

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

del {
  text-decoration: line-through;
}

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

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

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

input,
select {
  vertical-align: middle;
}

img {
  vertical-align: middle;
}

* {
  box-sizing: border-box;
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

#check_pm {
  display: block;
}
@media screen and (max-width: 1439px) {
  #check_pm {
    display: none;
  }
}

#check_ps {
  display: none;
}
@media screen and (max-width: 1439px) {
  #check_ps {
    display: block;
  }
}
@media screen and (max-width: 1239px) {
  #check_ps {
    display: none;
  }
}

#check_tl {
  display: none;
}
@media screen and (max-width: 1239px) {
  #check_tl {
    display: block;
  }
}
@media screen and (max-width: 1039px) {
  #check_tl {
    display: none;
  }
}

#check_tm {
  display: none;
}
@media screen and (max-width: 1039px) {
  #check_tm {
    display: block;
  }
}
@media screen and (max-width: 839px) {
  #check_tm {
    display: none;
  }
}

#check_ts {
  display: none;
}
@media screen and (max-width: 839px) {
  #check_ts {
    display: block;
  }
}
@media screen and (max-width: 639px) {
  #check_ts {
    display: none;
  }
}

#check_sl {
  display: none;
}
@media screen and (max-width: 639px) {
  #check_sl {
    display: block;
  }
}
@media screen and (max-width: 439px) {
  #check_sl {
    display: none;
  }
}

#check_sm {
  display: none;
}
@media screen and (max-width: 439px) {
  #check_sm {
    display: block;
  }
}
@media screen and (max-width: 339px) {
  #check_sm {
    display: none;
  }
}

#check_ss {
  display: none;
}
@media screen and (max-width: 339px) {
  #check_ss {
    display: block;
  }
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

.fadeO,
.fadeFvO {
  opacity: 0;
}

.fadeB,
.fadeFvB {
  opacity: 0;
  transform: translateY(var(--fadeInLength));
}

.fadeB10,
.fadeFvB10 {
  opacity: 0;
  transform: translateY(10px);
}

.fadeT,
.fadeFvT {
  opacity: 0;
  transform: translateY(calc(-1px * var(--fadeInLength)));
}

.fadeR,
.fadeFvR {
  opacity: 0;
  transform: translateX(var(--fadeInLength));
}

.fadeR10,
.fadeFvR10 {
  opacity: 0;
  transform: translateX(10px);
}

.fadeL,
.fadeFvL {
  opacity: 0;
  transform: translateX(calc(-1px * var(--fadeInLength)));
}
@media screen and (max-width: 839px) {
  .fadeL,
  .fadeFvL {
    transform: translateY(var(--fadeInLength));
  }
}

.fadeO.fadeIn,
.fadeB.fadeIn,
.fadeB10.fadeIn,
.fadeT.fadeIn,
.fadeR.fadeIn,
.fadeR10.fadeIn,
.fadeL.fadeIn,
.fadeFvO.fadeIn,
.fadeFvB.fadeIn,
.fadeFvB10.fadeIn,
.fadeFvT.fadeIn,
.fadeFvR.fadeIn,
.fadeFvR10.fadeIn,
.fadeFvL.fadeIn {
  transition: opacity var(--fadeInOpacityDuration), transform 1s var(--easeOutQuart);
  opacity: 1;
  transform: translateX(0px) translateY(0px);
}

.fadeLine,
.fadeFvLine {
  width: 0px;
}

.fadeLine.fadeIn,
.fadeFvLine.fadeIn {
  transition: width 1s var(--easeOutQuart);
  width: 100%;
}

.fadeLineL::before,
.fadeFvLineL::before {
  right: 100%;
}

.fadeLineL.fadeIn::before,
.fadeFvLineL.fadeIn::before {
  transition: right 1s var(--easeOutQuart);
  right: 0;
}

.fadeLineR::before,
.fadeFvLineR::before {
  left: 100%;
}

.fadeLineR.fadeIn::before,
.fadeFvLineR.fadeIn::before {
  transition: left 1s var(--easeOutQuart);
  left: 0;
}

.fadeBoxL,
.fadeFvBoxL {
  opacity: 0;
  left: 50%;
}

.fadeBoxL.fadeIn,
.fadeFvBoxL.fadeIn {
  transition: opacity var(--fadeInOpacityDuration), left 1s var(--easeOutQuart);
  opacity: 1;
  left: 0%;
}

.fadeBoxR,
.fadeFvBoxR {
  opacity: 0;
  right: 50%;
}

.fadeBoxR.fadeIn,
.fadeFvBoxR.fadeIn {
  transition: opacity var(--fadeInOpacityDuration), right 1s var(--easeOutQuart);
  opacity: 1;
  right: 0%;
}

.fadePhoto,
.fadeFvPhoto {
  overflow: hidden;
}
.fadePhoto .photo_container,
.fadePhoto img,
.fadeFvPhoto .photo_container,
.fadeFvPhoto img {
  opacity: 0;
  transform: scale(1.1);
}

.fadePhoto.fadeIn .photo_container,
.fadePhoto.fadeIn img,
.fadeFvPhoto.fadeIn .photo_container,
.fadeFvPhoto.fadeIn img {
  transition: opacity var(--fadeInOpacityDuration), transform 1s var(--easeOutQuart);
  opacity: 1;
  transform: scale(1);
}

.fadePhotoB,
.fadeFvPhotoB {
  transform: translateY(20px);
  overflow: hidden;
}
.fadePhotoB .photo_container,
.fadePhotoB img,
.fadeFvPhotoB .photo_container,
.fadeFvPhotoB img {
  opacity: 0;
  transform: scale(1.1);
}
.fadePhotoB::before,
.fadeFvPhotoB::before {
  opacity: 0;
  transform: scale(1.1);
}
.fadePhotoB a::before,
.fadeFvPhotoB a::before {
  opacity: 0;
  transform: scale(1.1);
}

.fadePhotoB30,
.fadeFvPhotoB30 {
  transform: translateY(30px);
  overflow: hidden;
}
.fadePhotoB30 .photo_container,
.fadePhotoB30 img,
.fadeFvPhotoB30 .photo_container,
.fadeFvPhotoB30 img {
  opacity: 0;
  transform: scale(1.1);
}
.fadePhotoB30::before,
.fadeFvPhotoB30::before {
  opacity: 0;
  transform: scale(1.1);
}
.fadePhotoB30 a::before,
.fadeFvPhotoB30 a::before {
  opacity: 0;
  transform: scale(1.1);
}

.fadePhotoB.fadeIn,
.fadeFvPhotoB.fadeIn,
.fadePhotoB30.fadeIn,
.fadeFvPhotoB30.fadeIn {
  transition: transform 1s var(--easeOutQuart);
  transform: translateY(0);
}
.fadePhotoB.fadeIn .photo_container,
.fadePhotoB.fadeIn img,
.fadeFvPhotoB.fadeIn .photo_container,
.fadeFvPhotoB.fadeIn img,
.fadePhotoB30.fadeIn .photo_container,
.fadePhotoB30.fadeIn img,
.fadeFvPhotoB30.fadeIn .photo_container,
.fadeFvPhotoB30.fadeIn img {
  transition: opacity var(--fadeInOpacityDuration), transform 1s var(--easeOutQuart);
  opacity: 1;
  transform: scale(1);
}
.fadePhotoB.fadeIn::before,
.fadeFvPhotoB.fadeIn::before,
.fadePhotoB30.fadeIn::before,
.fadeFvPhotoB30.fadeIn::before {
  transition: opacity var(--fadeInOpacityDuration), transform 1s var(--easeOutQuart);
  opacity: 1;
  transform: scale(1);
}
.fadePhotoB.fadeIn a::before,
.fadeFvPhotoB.fadeIn a::before,
.fadePhotoB30.fadeIn a::before,
.fadeFvPhotoB30.fadeIn a::before {
  transition: opacity var(--fadeInOpacityDuration), transform 1s var(--easeOutQuart);
  opacity: 1;
  transform: scale(1);
}

.fadePhotoPop,
.fadeFvPhotoPop {
  opacity: 0;
  transform: scale(0.5);
  overflow: hidden;
}
.fadePhotoPop.fadeIn,
.fadeFvPhotoPop.fadeIn {
  animation: fadePhotoPop_01 0.4s var(--easeOutCubic) both, fadePhotoPop_02 0.28s var(--easeInCubic) 0.4s forwards;
}
@keyframes fadePhotoPop_01 {
  0% {
    opacity: 0;
    transform: scale(0.5);
  }
  100% {
    opacity: 1;
    transform: scale(1.08);
  }
}
@keyframes fadePhotoPop_02 {
  0% {
    transform: scale(1.08);
  }
  100% {
    transform: scale(1);
  }
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

.span_pc {
  display: inline-block;
}
@media screen and (max-width: 1239px) {
  .span_pc {
    display: none;
  }
}

.span_tb {
  display: none;
}
@media screen and (max-width: 1239px) {
  .span_tb {
    display: inline-block;
  }
}
@media screen and (max-width: 639px) {
  .span_tb {
    display: none;
  }
}

.span_sp {
  display: none;
}
@media screen and (max-width: 639px) {
  .span_sp {
    display: inline-block;
  }
}

.span_pl_tl {
  display: inline-block;
}
@media screen and (max-width: 1039px) {
  .span_pl_tl {
    display: none;
  }
}

.span_tm_ts {
  display: none;
}
@media screen and (max-width: 1039px) {
  .span_tm_ts {
    display: inline-block;
  }
}
@media screen and (max-width: 639px) {
  .span_tm_ts {
    display: none;
  }
}

.span_sl_ss {
  display: none;
}
@media screen and (max-width: 639px) {
  .span_sl_ss {
    display: inline-block;
  }
}

:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}
body {
  font-family: "Poppins", "游ゴシック体", "YuGothic", "游ゴシック", "Yu Gothic", "Noto Sans JP", sans-serif;
  font-style: normal;
  font-size: 15px;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.05em;
  color: var(--c-text);
  font-feature-settings: "palt";
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}
a,
a:hover {
  color: var(--c-text);
}
a:link,
a:visited,
a:hover {
  text-decoration: none;
}
svg {
  overflow: visible;
}
.t_hide {
  width: 0px;
  height: 0px;
  text-indent: -9999px;
  position: absolute;
  left: 0px;
  top: 0px;
}
.keisen_long {
  margin-right: 0.4em;
  letter-spacing: -0.3em;
}
.block,
.b {
  display: inline-block;
}
.t_dummy {
  color: #f0f;
}
span.dash_line {
  letter-spacing: -0.2em;
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

.br_pc {
  display: block;
}
@media screen and (max-width: 1239px) {
  .br_pc {
    display: none;
  }
}

.br_tb {
  display: none;
}
@media screen and (max-width: 1239px) {
  .br_tb {
    display: block;
  }
}
@media screen and (max-width: 639px) {
  .br_tb {
    display: none;
  }
}

.br_sp {
  display: none;
}
@media screen and (max-width: 639px) {
  .br_sp {
    display: block;
  }
}

.br_pl_ps {
  display: block;
}
@media screen and (max-width: 1239px) {
  .br_pl_ps {
    display: none;
  }
}

.br_pl_tl {
  display: block;
}
@media screen and (max-width: 1039px) {
  .br_pl_tl {
    display: none;
  }
}

.br_tm_tm {
  display: none;
}
@media screen and (max-width: 1039px) {
  .br_tm_tm {
    display: block;
  }
}
@media screen and (max-width: 839px) {
  .br_tm_tm {
    display: none;
  }
}

.br_tm_ts {
  display: none;
}
@media screen and (max-width: 1039px) {
  .br_tm_ts {
    display: block;
  }
}
@media screen and (max-width: 639px) {
  .br_tm_ts {
    display: none;
  }
}

.br_sl_ss {
  display: none;
}
@media screen and (max-width: 639px) {
  .br_sl_ss {
    display: block;
  }
}

.br_tl {
  display: none;
}
@media screen and (max-width: 1239px) {
  .br_tl {
    display: block;
  }
}

.br_ts {
  display: none;
}
@media screen and (max-width: 839px) {
  .br_ts {
    display: block;
  }
}

.br_ts_sl {
  display: none;
}
@media screen and (max-width: 839px) {
  .br_ts_sl {
    display: block;
  }
}
@media screen and (max-width: 639px) {
  .br_ts_sl {
    display: none;
  }
}

.br_tm {
  display: none;
}
@media screen and (max-width: 1039px) {
  .br_tm {
    display: block;
  }
}

.br_ts {
  display: none;
}
@media screen and (max-width: 839px) {
  .br_ts {
    display: block;
  }
}

.br_sl {
  display: none;
}
@media screen and (max-width: 639px) {
  .br_sl {
    display: block;
  }
}

.br_sm {
  display: none;
}
@media screen and (max-width: 439px) {
  .br_sm {
    display: block;
  }
}

.br_ss {
  display: none;
}
@media screen and (max-width: 339px) {
  .br_ss {
    display: block;
  }
}

@media screen and (max-width: 839px) {
  .br_pl_tm {
    display: none;
  }
}

@media screen and (max-width: 639px) {
  .br_pl_ts {
    display: none;
  }
}

@media screen and (max-width: 439px) {
  .br_pl_sl {
    display: none;
  }
}

.br_tl_tm {
  display: none;
}
@media screen and (max-width: 1239px) {
  .br_tl_tm {
    display: block;
  }
}
@media screen and (max-width: 839px) {
  .br_tl_tm {
    display: none;
  }
}

.br_tl_ts {
  display: none;
}
@media screen and (max-width: 1239px) {
  .br_tl_ts {
    display: block;
  }
}
@media screen and (max-width: 639px) {
  .br_tl_ts {
    display: none;
  }
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

.maru {
  letter-spacing: -0.6em;
}

.ten {
  letter-spacing: -0.3em;
}

.ten_03 {
  letter-spacing: 0em;
}

.nakaguro {
  margin-left: -0.1em;
  letter-spacing: -0.1em;
}

.ls6m {
  letter-spacing: -0.6em;
}

.ls55m {
  letter-spacing: -0.55em;
}

.ls5m {
  letter-spacing: -0.5em;
}

.ls45m {
  letter-spacing: -0.45em;
}

.ls4m {
  letter-spacing: -0.4em;
}

.ls35m {
  letter-spacing: -0.35em;
}

.ls3m {
  letter-spacing: -0.3em;
}

.ls275m {
  letter-spacing: -0.275em;
}

.ls25m {
  letter-spacing: -0.25em;
}

.ls225m {
  letter-spacing: -0.225em;
}

.ls215m {
  letter-spacing: -0.215em;
}

.ls2m {
  letter-spacing: -0.2em;
}

.ls19m {
  letter-spacing: -0.19em;
}

.ls175m {
  letter-spacing: -0.175em;
}

.ls165m {
  letter-spacing: -0.165em;
}

.ls15m {
  letter-spacing: -0.15em;
}

.ls14m {
  letter-spacing: -0.14em;
}

.ls125m {
  letter-spacing: -0.125em;
}

.ls1m {
  letter-spacing: -0.1em;
}

.ls09m {
  letter-spacing: -0.09em;
}

.ls075m {
  letter-spacing: -0.075em;
}

.ls065m {
  letter-spacing: -0.065em;
}

.ls05m {
  letter-spacing: -0.05em;
}

.ls04m {
  letter-spacing: -0.04em;
}

.ls025m {
  letter-spacing: -0.025em;
}

.ls015m {
  letter-spacing: -0.015em;
}

.ls0 {
  letter-spacing: 0em;
}

.ls01 {
  letter-spacing: 0.01em;
}

.ls025 {
  letter-spacing: 0.025em;
}

.ls035 {
  letter-spacing: 0.035em;
}

.ls05 {
  letter-spacing: 0.05em;
}

.ls06 {
  letter-spacing: 0.06em;
}

.ls075 {
  letter-spacing: 0.075em;
}

.ls1 {
  letter-spacing: 0.1em;
}

.ls11 {
  letter-spacing: 0.11em;
}

.ls125 {
  letter-spacing: 0.125em;
}

.ls135 {
  letter-spacing: 0.135em;
}

.ls15 {
  letter-spacing: 0.15em;
}

.ls16 {
  letter-spacing: 0.16em;
}

.ls175 {
  letter-spacing: 0.175em;
}

.ls2 {
  letter-spacing: 0.2em;
}

.ls215 {
  letter-spacing: 0.215em;
}

.ls225 {
  letter-spacing: 0.225em;
}

.ls25 {
  letter-spacing: 0.25em;
}

.ls3 {
  letter-spacing: 0.3em;
}

.ls35 {
  letter-spacing: 0.35em;
}

.ls4 {
  letter-spacing: 0.4em;
}

.ls45 {
  letter-spacing: 0.45em;
}

.ls5 {
  letter-spacing: 0.5em;
}

.ls55 {
  letter-spacing: 0.55em;
}

.ls6 {
  letter-spacing: 0.6em;
}

.ls65 {
  letter-spacing: 0.65em;
}

.ls7 {
  letter-spacing: 0.7em;
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

.ml6m {
  margin-left: -0.6em;
}

.ml55m {
  margin-left: -0.55em;
}

.ml5m {
  margin-left: -0.5em;
}

.ml45m {
  margin-left: -0.45em;
}

.ml4m {
  margin-left: -0.4em;
}

.ml35m {
  margin-left: -0.35em;
}

.ml3m {
  margin-left: -0.3em;
}

.ml25m {
  margin-left: -0.25em;
}

.ml2m {
  margin-left: -0.2em;
}

.ml15m {
  margin-left: -0.15em;
}

.ml1m {
  margin-left: -0.1em;
}

.ml05m {
  margin-left: -0.05em;
}

.ml0 {
  margin-left: 0em;
}

.ml05 {
  margin-left: 0.05em;
}

.ml1 {
  margin-left: 0.1em;
}

.ml15 {
  margin-left: 0.15em;
}

.ml2 {
  margin-left: 0.2em;
}

.ml25 {
  margin-left: 0.25em;
}

.ml3 {
  margin-left: 0.3em;
}

.ml35 {
  margin-left: 0.35em;
}

.ml4 {
  margin-left: 0.4em;
}

.ml45 {
  margin-left: 0.45em;
}

.ml5 {
  margin-left: 0.5em;
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

.mt7m {
  margin-top: -0.7em;
}

.mt65m {
  margin-top: -0.65em;
}

.mt6m {
  margin-top: -0.6em;
}

.mt55m {
  margin-top: -0.55em;
}

.mt5m {
  margin-top: -0.5em;
}

.mt45m {
  margin-top: -0.45em;
}

.mt4m {
  margin-top: -0.4em;
}

.mt35m {
  margin-top: -0.35em;
}

.mt3m {
  margin-top: -0.3em;
}

.mt25m {
  margin-top: -0.25em;
}

.mt2m {
  margin-top: -0.2em;
}

.mt15m {
  margin-top: -0.15em;
}

.mt1m {
  margin-top: -0.1em;
}

.mt05m {
  margin-top: -0.05em;
}

.mt0 {
  margin-top: 0em;
}

.mt05 {
  margin-top: 0.05em;
}

.mt1 {
  margin-top: 0.1em;
}

.mt15 {
  margin-top: 0.15em;
}

.mt2 {
  margin-top: 0.2em;
}

.mt25 {
  margin-top: 0.25em;
}

.mt3 {
  margin-top: 0.3em;
}

.mt35 {
  margin-top: 0.35em;
}

.mt4 {
  margin-top: 0.4em;
}

.mt45 {
  margin-top: 0.45em;
}

.mt5 {
  margin-top: 0.5em;
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

#wrapper #bg {
  position: fixed;
  inset: 0;
}
#wrapper #bg #bg_gray {
  background-color: var(--c-grayBg);
  position: absolute;
  inset: 0;
}
#wrapper #bg #bg_noise {
  background-image: url("../../_assets/img/_common/bg_noise.jpg");
  background-size: 1440px 900px;
  mix-blend-mode: color-dodge;
  opacity: 0.4;
  position: absolute;
  inset: 0;
}
#wrapper #bg #bg_line {
  background-image: url("../../_assets/img/_common/bg_line.svg");
  position: absolute;
  inset: 0;
}
#wrapper main {
  width: 100vw;
  max-width: 100vw;
  overflow: hidden;
  padding-bottom: 100px;
  position: relative;
}
@media screen and (max-width: 1239px) {
  #wrapper main {
    padding-bottom: 80px;
  }
}
@media screen and (max-width: 639px) {
  #wrapper main {
    padding-bottom: 60px;
  }
}
#wrapper main .fv .main .page_title .content .head {
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-feature-settings: initial;
}
#wrapper main .fv .main .page_title .content .head h1 {
  margin-top: 15px;
  font-size: 34px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 600;
}
#wrapper main .fv .main .page_title .content .head h1 span {
  font-weight: 600;
}
#wrapper main .fv .main .page_title .content .head h1 {
  color: var(--c-ThkRed);
  position: relative;
}
#wrapper main .fv .main .page_title .content .head h1 span.en {
  display: inline-block;
  letter-spacing: 0em;
  font-weight: 500;
}
#wrapper main .fv .main .page_title .content .head h1 span.en span {
  font-weight: 500;
}
#wrapper main .fv .main .page_title .content .head h1 span.en {
  translate: 0.04em 0;
}
#wrapper #bg_red {
  transition: background-color 0.5s;
  background-color: transparent;
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 201;
}

#wrapper.bgRed #bg_red {
  background-color: var(--c-ThkRed);
  pointer-events: auto;
}
@media screen and (max-width: 1039px) {
  #wrapper.bgRed #bg_red {
    background-color: transparent;
    pointer-events: none;
  }
}

_::-webkit-full-page-media,
_:future,
:root #wrapper main .fv .main .page_title .content .head h1 {
  translate: -0.07em 0;
}

_::-webkit-full-page-media,
_:future,
:root #wrapper main .fv .main .page_title .content .head h1 span.en {
  translate: 0.08em 0;
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

:root {
  --delayLine: 0.3s;
  --delayText: calc(var(--delayLine) + 0.1s);
  --delayTextSpan: 0.05s;
}

header {
  transition: translate 0.5s var(--easeInOutQuart);
  display: grid;
  grid-template-columns: auto 1fr auto;
  height: 76px;
  pointer-events: none;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 101;
}
@media screen and (max-width: 1239px) {
  header {
    height: 68px;
  }
}
@media screen and (max-width: 1039px) {
  header {
    grid-template-columns: auto 1fr;
    z-index: 501;
  }
}
@media screen and (max-width: 639px) {
  header {
    height: 60px;
  }
}
header .nav_wrap {
  transition: height 0.5s var(--easeInOutCubic);
  height: 0;
  overflow: hidden;
  pointer-events: auto;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
}
@media screen and (max-width: 1039px) {
  header .nav_wrap {
    top: 68px;
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap {
    top: 60px;
  }
}
header .nav_wrap .nav_bg {
  background-color: var(--c-ThkRed);
  position: absolute;
  inset: 0;
}
header .nav_wrap .nav_scroll_wrap {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  width: 100vw;
  height: 100vh;
  height: 100dvh;
  overflow-y: scroll;
  overscroll-behavior-y: contain;
  position: relative;
}
@media screen and (max-width: 1039px) {
  header .nav_wrap .nav_scroll_wrap {
    height: calc(100vh - 68px);
    height: calc(100dvh - 68px);
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap .nav_scroll_wrap {
    height: calc(100vh - 60px);
    height: calc(100dvh - 60px);
  }
}
header .nav_wrap .nav_scroll_wrap .close_bg {
  position: absolute;
  inset: 0;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container {
  align-self: center;
  padding: 100px 0;
  position: relative;
}
@media screen and (max-width: 1239px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container {
    padding: 75px 0;
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container {
    padding: 50px 0;
  }
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav {
  margin-inline: auto;
  width: 1100px;
}
@media screen and (max-width: 1239px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav {
    width: 980px;
  }
}
@media screen and (max-width: 1039px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav {
    width: 400px;
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav {
    width: 290px;
  }
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul {
  display: grid;
  grid-template-columns: 40fr 130fr 130fr 230fr 160fr 160fr;
  column-gap: 50px;
}
@media screen and (max-width: 1239px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul {
    column-gap: 35px;
  }
}
@media screen and (max-width: 1039px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul {
    grid-template-columns: 1fr;
    row-gap: 45px;
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul {
    row-gap: 40px;
  }
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title .text {
  transition: opacity 0s 0.5s, translate 0s 0.5s;
  opacity: 0;
  translate: 15px 0;
  font-size: 18px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title .text span {
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title .text {
  color: var(--c-white);
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title a {
  transition: opacity 0s 0.5s, translate 0s 0.5s, color 0.3s;
  opacity: 0;
  translate: 15px 0;
  display: inline-block;
  font-size: 18px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title a span {
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title a {
  color: var(--c-white);
}
@media screen and (min-width: 1239px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title a:hover {
    color: var(--c-ThkRed40);
  }
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title::after {
  transition: clip-path 0s 0.5s;
  clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
  content: "";
  display: inline-block;
  margin-top: 10px;
  width: 100%;
  height: 1px;
  background-color: var(--c-white);
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title.gray a {
  color: var(--c-ThkRed40);
  pointer-events: none;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 20px;
  margin-top: 20px;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li {
  transition: opacity 0s 0.5s, translate 0s 0.5s;
  opacity: 0;
  translate: 15px 0;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li a {
  transition: color 0.3s;
  display: inline-block;
  font-size: 16px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 400;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li a span {
  font-weight: 400;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li a {
  color: var(--c-white);
}
@media screen and (max-width: 1239px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li a {
    font-size: 15px;
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li a {
    font-size: 14px;
  }
}
@media screen and (min-width: 1239px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li a:hover {
    color: var(--c-ThkRed40);
  }
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li.gray a {
  color: var(--c-ThkRed40);
  pointer-events: none;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul li.li_top .title::after {
  display: none;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb {
  display: none;
}
@media screen and (max-width: 1039px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb {
    display: block;
    margin-top: 80px;
    margin-inline: auto;
    width: 400px;
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb {
    width: 290px;
  }
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .corporate {
  transition: opacity 0s 0.5s, translate 0s 0.5s;
  opacity: 0;
  translate: 15px 0;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .corporate a {
  font-size: 14px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .corporate a span {
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .corporate a {
  color: var(--c-white);
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .copyright {
  transition: opacity 0s 0.5s, translate 0s 0.5s;
  opacity: 0;
  translate: 15px 0;
  padding-top: 20px;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .copyright .text {
  font-size: 11px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .copyright .text span {
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .copyright .text {
  color: var(--c-white);
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb {
  display: none;
}
@media screen and (max-width: 1039px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb {
    transition: translate 0.4s var(--easeInOutQuart);
    translate: 0 0;
    display: block;
    position: fixed;
    left: 100%;
    top: 118px;
  }
}
@media screen and (max-width: 639px) {
  header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb {
    top: 100px;
  }
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 120px;
  height: 40px;
  border-radius: 5px 0 0 5px;
  position: relative;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb a::before {
  transition: background-color 0.5s, border 0.5s;
  content: "";
  display: inline-block;
  background-color: var(--c-white);
  border-radius: inherit;
  position: absolute;
  inset: 0;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb a .text {
  transition: color 0.5s;
  font-size: 13px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb a .text span {
  font-weight: 500;
}
header .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb a .text {
  color: var(--c-ThkRed);
  position: relative;
}
header .header_bg {
  display: none;
}
@media screen and (max-width: 1039px) {
  header .header_bg {
    display: block;
    width: 100%;
    height: 100%;
    background-color: var(--c-white);
    position: absolute;
    left: 0;
    top: 0;
  }
}
header .logo_wrap {
  justify-self: start;
  align-self: center;
  margin-left: 26px;
  pointer-events: auto;
  position: relative;
}
@media screen and (max-width: 1239px) {
  header .logo_wrap {
    margin-left: 23px;
  }
}
@media screen and (max-width: 639px) {
  header .logo_wrap {
    margin-left: 18px;
  }
}
header .logo_wrap a {
  display: flex;
  align-items: center;
  column-gap: 18px;
}
header .logo_wrap a .logo {
  line-height: 0;
}
header .logo_wrap a .logo svg {
  transition: fill 0.5s;
  width: auto;
  height: 24px;
  fill: var(--c-ThkRed);
}
@media screen and (max-width: 1239px) {
  header .logo_wrap a .logo svg {
    height: 22px;
  }
}
@media screen and (max-width: 639px) {
  header .logo_wrap a .logo svg {
    height: 20px;
  }
}
header .logo_wrap a .line {
  transition: background-color 0.5s;
  width: 1px;
  height: 24px;
  background-color: var(--c-black);
}
@media screen and (max-width: 1239px) {
  header .logo_wrap a .line {
    height: 22px;
  }
}
@media screen and (max-width: 639px) {
  header .logo_wrap a .line {
    height: 20px;
  }
}
header .logo_wrap a .sub {
  transition: color 0.5s;
  font-size: 12px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
header .logo_wrap a .sub span {
  font-weight: 500;
}
header .entry {
  justify-self: end;
  margin-right: 22px;
  pointer-events: auto;
}
@media screen and (max-width: 1039px) {
  header .entry {
    display: none;
  }
}
header .entry a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 110px;
  height: 40px;
  border-radius: 0 0 5px 5px;
  position: relative;
}
header .entry a::before {
  transition: background-color 0.5s, border 0.5s;
  content: "";
  display: inline-block;
  background-color: var(--c-ThkRed);
  border-left: 1px solid var(--c-ThkRed);
  border-right: 1px solid var(--c-ThkRed);
  border-bottom: 1px solid var(--c-ThkRed);
  border-radius: inherit;
  position: absolute;
  inset: 0;
}
header .entry a .text {
  transition: color 0.5s;
  padding-top: 6px;
  font-size: 12px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
header .entry a .text span {
  font-weight: 500;
}
header .entry a .text {
  color: var(--c-white);
  position: relative;
}
@media screen and (min-width: 1239px) {
  header .entry a:hover::before {
    background-color: var(--c-white);
  }
}
@media screen and (min-width: 1239px) {
  header .entry a:hover .text {
    color: var(--c-ThkRed);
  }
}
header .nav_switch {
  justify-self: end;
  align-self: center;
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 6px;
  align-content: center;
  margin-right: 22px;
  width: 40px;
  height: 35px;
  pointer-events: auto;
  cursor: pointer;
  position: relative;
}
@media screen and (max-width: 1039px) {
  header .nav_switch {
    row-gap: 7px;
    margin-right: 21px;
  }
}
@media screen and (max-width: 639px) {
  header .nav_switch {
    margin-right: 15px;
  }
}
header .nav_switch span {
  transition: background-color 0.3s, translate 0.5s var(--easeInOutQuart), rotate 0.5s var(--easeInOutQuart), clip-path 0.5s var(--easeInOutQuart);
  justify-self: center;
  content: "";
  display: block;
  width: 24px;
  height: 1px;
  background-color: var(--c-black);
}
@media screen and (max-width: 1039px) {
  header .nav_switch span {
    width: 30px;
  }
}
header .nav_switch span:nth-of-type(2) {
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
@media screen and (min-width: 1239px) {
  header .nav_switch:hover span {
    background-color: var(--c-ThkRed);
  }
}

header.hide {
  translate: 0 -100%;
}

header.open .nav_wrap {
  height: 100vh;
  height: 100dvh;
}
@media screen and (max-width: 1039px) {
  header.open .nav_wrap {
    height: calc(100vh - 68px);
    height: calc(100dvh - 68px);
  }
}
@media screen and (max-width: 639px) {
  header.open .nav_wrap {
    height: calc(100vh - 60px);
    height: calc(100dvh - 60px);
  }
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title .text {
  transition: opacity 0.6s var(--delayText), translate 0.8s var(--easeOutQuart) var(--delayText), color 0.3s;
  opacity: 1;
  translate: 0 0;
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title a {
  transition: opacity 0.6s var(--delayText), translate 0.8s var(--easeOutQuart) var(--delayText), color 0.3s;
  opacity: 1;
  translate: 0 0;
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .title::after {
  transition: clip-path 0.6s var(--easeOutCubic) var(--delayLine);
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li {
  transition: opacity 0.6s, translate 0.8s var(--easeOutQuart);
  opacity: 1;
  translate: 0 0;
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(1) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 1);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(2) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 2);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(3) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 3);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(4) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 4);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(5) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 5);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(6) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 6);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(7) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 7);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(8) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 8);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(9) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 9);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container nav .nav_ul > li .sub_ul li:nth-of-type(10) {
  transition-delay: calc(var(--delayText) + var(--delayTextSpan) * 10);
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .corporate {
  transition: opacity 0.6s var(--delayText), translate 0.8s var(--easeOutQuart) var(--delayText);
  opacity: 1;
  translate: 0 0;
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container .nav_mb .copyright {
  transition: opacity 0.6s var(--delayText), translate 0.8s var(--easeOutQuart) var(--delayText);
  opacity: 1;
  translate: 0 0;
}
header.open .nav_wrap .nav_scroll_wrap .nav_scroll_container .entry_mb {
  transition: translate 0.6s var(--easeInOutQuart);
  translate: -100% 0;
}
header.open .logo_wrap a .logo svg {
  fill: var(--c-white);
}
@media screen and (max-width: 1039px) {
  header.open .logo_wrap a .logo svg {
    fill: var(--c-ThkRed);
  }
}
header.open .logo_wrap a .line {
  background-color: var(--c-white);
}
@media screen and (max-width: 1039px) {
  header.open .logo_wrap a .line {
    background-color: var(--c-black);
  }
}
header.open .logo_wrap a .sub {
  color: var(--c-white);
}
@media screen and (max-width: 1039px) {
  header.open .logo_wrap a .sub {
    color: var(--c-black);
  }
}
header.open .entry a::before {
  background-color: var(--c-white);
  border-left: 1px solid var(--c-white);
  border-right: 1px solid var(--c-white);
  border-bottom: 1px solid var(--c-white);
}
header.open .entry a .text {
  color: var(--c-ThkRed);
}
@media screen and (min-width: 1239px) {
  header.open .entry a:hover::before {
    background-color: var(--c-ThkRed);
  }
}
@media screen and (min-width: 1239px) {
  header.open .entry a:hover .text {
    color: var(--c-white);
  }
}
header.open .nav_switch span {
  background-color: var(--c-white);
}
@media screen and (max-width: 1039px) {
  header.open .nav_switch span {
    background-color: var(--c-black);
  }
}
header.open .nav_switch span:nth-of-type(1) {
  translate: 0 7px;
  rotate: -45deg;
}
@media screen and (max-width: 1039px) {
  header.open .nav_switch span:nth-of-type(1) {
    translate: 0 8px;
  }
}
header.open .nav_switch span:nth-of-type(2) {
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 100% 100%);
}
header.open .nav_switch span:nth-of-type(3) {
  translate: 0 -7px;
  rotate: 45deg;
}
@media screen and (max-width: 1039px) {
  header.open .nav_switch span:nth-of-type(3) {
    translate: 0 -8px;
  }
}
@media screen and (min-width: 1239px) {
  header.open .nav_switch:hover span {
    background-color: var(--c-ThkRed40);
  }
}:root {
  --c-ThkRed: hsl(356 88.6% 44.7%);
  --c-ThkRed80: hsl(356 71.7% 55.7%);
  --c-ThkRed60: hsl(357 71.6% 66.9%);
  --c-ThkRed40: hsl(356 71.7% 77.8%);
  --c-ThkRed20: hsl(357 71.4% 89%);
  --c-ThkGraphRed: hsl(356 88.6% 44.7%);
  --c-ThkGraphRed70: hsl(357 71.6% 61.4%);
  --c-ThkGraphRed40: hsl(356 71.7% 77.8%);
  --c-ThkGraphRed15: hsl(358 71.4% 91.8%);
  --c-ThkGraphGray45: hsl(0 0% 54.9%);
  --c-ThkGraphGray25: hsl(0 0% 74.9%);
  --c-grayBg: hsl(0 0% 90.2%);
  --c-gray11: hsl(0 0% 6.7%);
  --c-grayDC: hsl(0 0% 86.3%);
  --c-grayC2: hsl(0 0% 76.1%);
  --c-Black: hsl(220 0% 0%);
  --c-black: hsl(220 0% 10%);
  --c-blackHover: hsl(220 0% 50%);
  --c-White: hsl(220 0% 100%);
  --c-white: hsl(220 0% 100%);
  --c-dummy: hsl(0 0% 47.1%);
  --c-bg: hsl(220 10% 90%);
  --c-text: hsl(220 10% 10%);
  --c-textHover: hsl(220 10% 50%);
  --fadeInLength: 20px;
  --fadeInOpacityDuration: 0.8s;
  --lmContentsDelay: 0.3s;
  --easeOutQuad: cubic-bezier(0.5, 1, 0.89, 1);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutQuart: cubic-bezier(0.25, 1, 0.5, 1);
  --easeOutQuint: cubic-bezier(0.22, 1, 0.36, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic: cubic-bezier(0.65, 0, 0.35, 1);
  --easeInOutQuart: cubic-bezier(0.76, 0, 0.24, 1);
  --easeInOutQuint: cubic-bezier(0.83, 0, 0.17, 1);
  --easeInOutExpo: cubic-bezier(0.87, 0, 0.13, 1);
  --easeInQuad: cubic-bezier(0.11, 0, 0.5, 0);
  --easeInCubic: cubic-bezier(0.32, 0, 0.67, 0);
  --easeInQuart: cubic-bezier(0.5, 0, 0.75, 0);
  --easeInQuint: cubic-bezier(0.64, 0, 0.78, 0);
  --easeInExpo: cubic-bezier(0.7, 0, 0.84, 0);
}

footer {
  margin-top: 100px;
  padding-top: 0px;
  padding-bottom: 100px;
  width: 100vw;
  max-width: 100vw;
  overflow: hidden;
  position: relative;
  z-index: 301;
}
@media screen and (max-width: 1239px) {
  footer {
    margin-top: 70px;
  }
}
@media screen and (max-width: 1039px) {
  footer {
    padding-bottom: 45px;
    background-color: var(--c-ThkRed);
  }
}
@media screen and (max-width: 639px) {
  footer {
    margin-top: 40px;
  }
}
footer .footer_nav {
  margin-inline: auto;
  width: 1100px;
}
@media screen and (max-width: 1239px) {
  footer .footer_nav {
    width: 980px;
  }
}
@media screen and (max-width: 1039px) {
  footer .footer_nav {
    display: none;
  }
}
footer .footer_nav .footer_nav_ul {
  display: grid;
  grid-template-columns: 34fr 120fr 120fr 220fr 150fr 150fr;
  column-gap: 60px;
}
footer .footer_nav .footer_nav_ul li .title .text {
  font-size: 18px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
footer .footer_nav .footer_nav_ul li .title .text span {
  font-weight: 500;
}
footer .footer_nav .footer_nav_ul li .title .text {
  color: var(--c-white);
}
footer .footer_nav .footer_nav_ul li .title a {
  transition: color 0.3s;
  display: inline-block;
  font-size: 16px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
footer .footer_nav .footer_nav_ul li .title a span {
  font-weight: 500;
}
footer .footer_nav .footer_nav_ul li .title a {
  color: var(--c-white);
}
@media screen and (max-width: 1239px) {
  footer .footer_nav .footer_nav_ul li .title a {
    font-size: 15px;
  }
}
@media screen and (min-width: 1239px) {
  footer .footer_nav .footer_nav_ul li .title a:hover {
    color: var(--c-ThkRed40);
  }
}
footer .footer_nav .footer_nav_ul li .title::after {
  content: "";
  display: inline-block;
  margin-top: 10px;
  width: 100%;
  height: 1px;
  background-color: var(--c-white);
}
footer .footer_nav .footer_nav_ul li .title.gray a {
  color: var(--c-ThkRed40);
  pointer-events: none;
}
footer .footer_nav .footer_nav_ul li .sub_ul {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 20px;
  margin-top: 20px;
}
footer .footer_nav .footer_nav_ul li .sub_ul li a {
  transition: color 0.3s;
  display: inline-block;
  font-size: 14px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 400;
}
footer .footer_nav .footer_nav_ul li .sub_ul li a span {
  font-weight: 400;
}
footer .footer_nav .footer_nav_ul li .sub_ul li a {
  color: var(--c-white);
}
@media screen and (max-width: 1239px) {
  footer .footer_nav .footer_nav_ul li .sub_ul li a {
    font-size: 13px;
  }
}
@media screen and (min-width: 1239px) {
  footer .footer_nav .footer_nav_ul li .sub_ul li a:hover {
    color: var(--c-ThkRed40);
  }
}
footer .footer_nav .footer_nav_ul li .sub_ul li.gray a {
  color: var(--c-ThkRed40);
  pointer-events: none;
}
footer .footer_nav .footer_nav_ul li.li_top .title::after {
  display: none;
}
footer .footer_bottom {
  display: grid;
  grid-template-columns: auto 1fr;
  row-gap: 20px;
  margin-top: 70px;
  margin-inline: auto;
  width: 1100px;
}
@media screen and (max-width: 1239px) {
  footer .footer_bottom {
    margin-top: 50px;
    width: 980px;
  }
}
@media screen and (max-width: 1039px) {
  footer .footer_bottom {
    grid-template-columns: 1fr;
    row-gap: 30px;
    margin-top: 30px;
    width: 100%;
  }
}
footer .footer_bottom .pagetop {
  grid-column: 1/3;
  justify-self: end;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  cursor: pointer;
  position: relative;
}
@media screen and (max-width: 1239px) {
  footer .footer_bottom .pagetop {
    width: 31px;
    height: 31px;
  }
}
@media screen and (max-width: 1039px) {
  footer .footer_bottom .pagetop {
    grid-column: auto;
    justify-self: center;
  }
}
@media screen and (max-width: 639px) {
  footer .footer_bottom .pagetop {
    width: 28px;
    height: 28px;
  }
}
footer .footer_bottom .pagetop::before {
  transition: background-color 0.3s;
  content: "";
  display: inline-block;
  background-color: transparent;
  border: 1px solid var(--c-white);
  border-radius: inherit;
  position: absolute;
  inset: 0;
}
footer .footer_bottom .pagetop .arrow {
  line-height: 0;
  position: relative;
}
footer .footer_bottom .pagetop .arrow svg {
  transition: stroke 0.3s;
  fill: none;
  stroke: var(--c-white);
  stroke-width: 1px;
}
@media screen and (max-width: 839px) {
  footer .footer_bottom .pagetop .arrow svg.svg_pc {
    display: none;
  }
}
footer .footer_bottom .pagetop .arrow svg.svg_mb {
  display: none;
}
@media screen and (max-width: 839px) {
  footer .footer_bottom .pagetop .arrow svg.svg_mb {
    display: block;
  }
}
@media screen and (min-width: 1239px) {
  footer .footer_bottom .pagetop:hover::before {
    background-color: var(--c-white);
  }
}
@media screen and (min-width: 1239px) {
  footer .footer_bottom .pagetop:hover .arrow svg {
    stroke: var(--c-ThkRed);
  }
}
footer .footer_bottom .line {
  grid-column: 1/3;
  width: 100%;
  height: 1px;
  background-color: var(--c-white);
}
@media screen and (max-width: 1039px) {
  footer .footer_bottom .line {
    display: none;
  }
}
@media screen and (max-width: 1039px) {
  footer .footer_bottom .corporate {
    display: none;
  }
}
footer .footer_bottom .corporate a {
  transition: color 0.3s;
  display: inline-block;
  font-size: 15px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
footer .footer_bottom .corporate a span {
  font-weight: 500;
}
footer .footer_bottom .corporate a {
  color: var(--c-white);
}
@media screen and (min-width: 1239px) {
  footer .footer_bottom .corporate a:hover {
    color: var(--c-ThkRed40);
  }
}
footer .footer_bottom .copyright {
  justify-self: end;
}
@media screen and (max-width: 1039px) {
  footer .footer_bottom .copyright {
    justify-self: center;
  }
}
footer .footer_bottom .copyright .text {
  margin-right: -0.1em;
  font-size: 11px;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
footer .footer_bottom .copyright .text span {
  font-weight: 500;
}
footer .footer_bottom .copyright .text {
  color: var(--c-white);
}