@charset "UTF-8";
/* ******************************
 *
 * RESPONSIVE MIXIN
 *
 * ****************************** */
/* ******************************
 *
 * FONT SETTINGS
 *
 * ****************************** */
/* ******************************
 *
 * FONT SETTINGS
 *
 * ****************************** */
/* ******************************
 *
 * Keyframes
 *
 * ****************************** */
@-webkit-keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
.heroCanvas,
.canvasArea {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100svh;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  -webkit-transition: opacity 400ms ease, visibility 0s linear 400ms;
  transition: opacity 400ms ease, visibility 0s linear 400ms;
  z-index: 0;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  contain: paint;
}
.heroCanvas video,
.canvasArea video {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom;
     object-position: bottom;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}
.heroCanvas.--active,
.canvasArea.--active {
  opacity: 1;
  visibility: visible;
  -webkit-transition: opacity 400ms ease;
  transition: opacity 400ms ease;
}

.heroCanvas {
  position: absolute;
  inset: 0;
  opacity: 1;
  visibility: visible;
  mix-blend-mode: normal;
}

.mainArea {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 320px) {
  .mainArea {
    margin-bottom: 64px;
  }
}
@media screen and (min-width: 600px) {
  .mainArea {
    margin-bottom: 128px;
  }
}

.trHero {
  -webkit-perspective: 1200px;
          perspective: 1200px;
  -webkit-perspective-origin: center;
          perspective-origin: center;
}
.trHero__inner {
  position: relative;
  width: 100%;
  height: 100vh;
  height: 100svh;
}
.trHero__layer {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.trHero__layer.--mv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
}
.trHero__layer.--copy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  overflow: hidden;
}
@media screen and (min-width: 320px) {
  .trHero__layer.--copy {
    padding: 0 5vw 9.4rem;
  }
}
@media screen and (min-width: 600px) {
  .trHero__layer.--copy {
    padding: 0 5vw 2.5vw;
  }
}
@media screen and (min-width: 320px) {
  .trHero__layer.--menu {
    padding: 18.4rem 5vw 0;
  }
}
@media screen and (min-width: 600px) {
  .trHero__layer.--menu {
    padding: 18.4rem 5vw 0;
  }
}
.trHero__mv {
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  will-change: transform;
  -webkit-transform: translateZ(0) rotateX(0deg) rotateY(0deg);
          transform: translateZ(0) rotateX(0deg) rotateY(0deg);
}
@media screen and (min-width: 320px) {
  .trHero__mv {
    width: 64%;
    margin-top: -12rem;
  }
}
@media screen and (min-width: 600px) {
  .trHero__mv {
    width: 30%;
    margin-top: 0;
  }
}
.trHero__mv .imgWrapper {
  padding-bottom: 124%;
  background-color: rgba(var(--color-white)/0.16);
}
.trHero__copyJa {
  font-family: var(--font-unique);
  text-align: right;
}
@media screen and (min-width: 320px) {
  .trHero__copyJa {
    font-size: 2.4rem;
    margin: 0 -2rem 3rem 0;
  }
}
@media screen and (min-width: 600px) {
  .trHero__copyJa {
    font-size: 6.4rem;
    margin: 0;
  }
}
.trHero__copyEn {
  font-family: var(--font-unique);
  line-height: 1.12;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-bottom: 16px;
}
@media screen and (min-width: 320px) {
  .trHero__copyEn {
    font-size: 5.2rem;
  }
}
@media screen and (min-width: 600px) {
  .trHero__copyEn {
    font-size: 15rem;
  }
}
@media screen and (min-width: 320px) {
  .trHero__copyEn span:last-child {
    -webkit-transform: translateX(6rem);
            transform: translateX(6rem);
  }
}
@media screen and (min-width: 600px) {
  .trHero__copyEn span:last-child {
    -webkit-transform: translateX(10rem);
            transform: translateX(10rem);
  }
}
.trHero__copyTitle {
  font-weight: 400;
}
@media screen and (min-width: 320px) {
  .trHero__copyTitle {
    font-size: 2rem;
  }
}
@media screen and (min-width: 600px) {
  .trHero__copyTitle {
    font-size: 4rem;
  }
}
@media screen and (min-width: 320px) {
  .trHero__nav {
    display: none;
  }
}
@media screen and (min-width: 600px) {
  .trHero__nav {
    display: block;
  }
}
@media screen and (min-width: 320px) {
  .trHero__nav ul {
    padding: 0 0 0 1rem;
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 600px) {
  .trHero__nav ul {
    padding: 0 0 0 1rem;
    font-size: 1.8rem;
  }
}
.trHero__nav ul li {
  list-style-type: disc;
  margin-bottom: 4px;
}
.trHero__nav ul a {
  position: relative;
  display: inline-block;
}
.trHero__nav ul a::after {
  content: "";
  display: block;
  position: absolute;
  inset: auto auto 0 0;
  width: 100%;
  height: 1px;
  background: rgb(var(--color-white));
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transform-origin: center right;
          transform-origin: center right;
  -webkit-transition: -webkit-transform 400ms ease;
  transition: -webkit-transform 400ms ease;
  transition: transform 400ms ease;
  transition: transform 400ms ease, -webkit-transform 400ms ease;
}
.trHero__nav ul a:hover::after {
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
  -webkit-transform-origin: center left;
          transform-origin: center left;
}

.trHead__entitle {
  font-family: var(--font-unique);
  font-weight: 400;
  margin-bottom: 24px;
}
@media screen and (min-width: 320px) {
  .trHead__entitle {
    font-size: 2rem;
  }
}
@media screen and (min-width: 600px) {
  .trHead__entitle {
    font-size: 3.2rem;
  }
}
.trHead__entitle span {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
.trHead__entitle span::before {
  content: "(";
}
.trHead__entitle span::after {
  content: ")";
}
.trHead__encopy {
  font-family: var(--font-head);
  font-weight: 400;
}
@media screen and (min-width: 320px) {
  .trHead__encopy {
    font-size: 3.2rem;
  }
}
@media screen and (min-width: 600px) {
  .trHead__encopy {
    font-size: 6.4rem;
  }
}
.trHead__encopy.isJa {
  font-family: var(--font-unique);
}
.trHead__catch {
  font-family: var(--font-unique);
  font-family: 400;
  margin-bottom: 12px;
}
@media screen and (min-width: 320px) {
  .trHead__catch {
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 600px) {
  .trHead__catch {
    font-size: 4.8rem;
  }
}
.trHead__jatitle {
  font-family: var(--font-unique);
  font-family: 400;
}
@media screen and (min-width: 320px) {
  .trHead__jatitle {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 600px) {
  .trHead__jatitle {
    font-size: 2.8rem;
  }
}
.trHead__desc {
  line-height: 1.64;
}
@media screen and (min-width: 320px) {
  .trHead__desc {
    font-size: 1.46rem;
  }
}
@media screen and (min-width: 600px) {
  .trHead__desc {
    font-size: 2rem;
  }
}

@media screen and (min-width: 320px) {
  .trIntro__inner {
    padding: 80px 5vw 0;
  }
}
@media screen and (min-width: 600px) {
  .trIntro__inner {
    padding: 80px 5vw 0;
  }
}
.trIntro__head {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}
.trIntro__wrapper {
  display: grid;
}
@media screen and (min-width: 320px) {
  .trIntro__wrapper {
    grid-template-columns: repeat(1, 1fr);
    margin-top: -8rem;
  }
}
@media screen and (min-width: 600px) {
  .trIntro__wrapper {
    grid-template-columns: repeat(2, 1fr);
    margin-top: -8rem;
  }
}
.trIntro__imgs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (min-width: 320px) {
  .trIntro__imgs {
    gap: 16px;
  }
}
@media screen and (min-width: 600px) {
  .trIntro__imgs {
    gap: 16px;
  }
}
.trIntro__img .imgWrapper {
  padding-bottom: 148%;
  background: rgba(var(--color-white)/0.16);
}
@media screen and (min-width: 320px) {
  .trIntro__img:last-child {
    margin-top: 32px;
  }
}
@media screen and (min-width: 600px) {
  .trIntro__img:last-child {
    margin-top: 32px;
  }
}
.trIntro__copy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (min-width: 320px) {
  .trIntro__copy {
    padding: 0 5vw;
  }
}
@media screen and (min-width: 600px) {
  .trIntro__copy {
    padding: 0 5vw;
  }
}
.trIntro__title {
  font-family: var(--font-unique);
  font-weight: 400;
  margin-bottom: 32px;
}
@media screen and (min-width: 320px) {
  .trIntro__title {
    font-size: 2.4rem;
    text-align: center;
    margin-top: 24px;
  }
}
@media screen and (min-width: 600px) {
  .trIntro__title {
    font-size: 4.8rem;
    text-align: left;
    margin-top: 0;
  }
}
@media screen and (min-width: 320px) {
  .trIntro__desc {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 600px) {
  .trIntro__desc {
    font-size: 1.8rem;
  }
}

@media screen and (min-width: 320px) {
  .trFeature__inner {
    padding: 124px 5vw 0;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__inner {
    padding: 174px 5vw 0;
  }
}
.trFeature__head {
  margin-bottom: 32px;
}
@media screen and (min-width: 320px) {
  .trFeature__head .trHead__catch, .trFeature__head .trHead__jatitle {
    text-align: center;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__head .trHead__catch, .trFeature__head .trHead__jatitle {
    text-align: left;
  }
}
.trFeature__headEn {
  text-align: center;
}
.trFeature__headWrapper {
  display: grid;
}
@media screen and (min-width: 320px) {
  .trFeature__headWrapper {
    grid-template-columns: repeat(1, 1fr);
  }
}
@media screen and (min-width: 600px) {
  .trFeature__headWrapper {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 320px) {
  .trFeature__headBottom {
    padding: 24px 0 0;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__headBottom {
    padding: 0 5vw;
  }
}
.trFeature__card {
  color: rgb(var(--color-text));
}
@media screen and (min-width: 320px) {
  .trFeature__card {
    padding: 8rem 0 0;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__card {
    padding: 16rem 0 0;
  }
}
.trFeature__cardInner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  background: rgb(var(--color-white));
}
.trFeature__cardNum {
  position: absolute;
  font-family: var(--font-unique);
  font-weight: 400;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 8px;
  line-height: 1;
}
@media screen and (min-width: 320px) {
  .trFeature__cardNum {
    inset: 16px auto auto 16px;
    font-size: 2.2rem;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__cardNum {
    inset: 16px auto auto 16px;
    font-size: 4rem;
  }
}
.trFeature__cardNum span:last-child {
  font-size: 50%;
}
.trFeature__cardTitle {
  font-family: var(--font-unique);
  font-weight: 400;
  margin-bottom: 12px;
}
@media screen and (min-width: 320px) {
  .trFeature__cardTitle {
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__cardTitle {
    font-size: 4.2rem;
  }
}
.trFeature__cardDesc {
  line-height: 1.64;
}
@media screen and (min-width: 320px) {
  .trFeature__cardDesc {
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__cardDesc {
    font-size: 2rem;
  }
}
.trFeature__cardCopy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 320px) {
  .trFeature__cardCopy {
    width: 100%;
    padding: 6rem 4vw 0;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__cardCopy {
    width: 68%;
    padding: 0 5vw;
  }
}
@media screen and (min-width: 320px) {
  .trFeature__cardImg {
    width: 100%;
    padding: 8px;
  }
}
@media screen and (min-width: 600px) {
  .trFeature__cardImg {
    width: 32%;
    padding: 8px;
  }
}
.trFeature__cardImg .imgWrapper {
  padding-bottom: 124%;
}

.trFeature {
  position: relative;
}
@media screen and (min-width: 320px) {
  .trFeature .trFeature__head {
    padding: 0 5vw;
  }
}
@media screen and (min-width: 600px) {
  .trFeature .trFeature__head {
    padding: 0;
  }
}
.trFeature__wrapper {
  position: relative;
  height: 100vh;
  height: 100svh;
  overflow: hidden;
}
.trFeature__cards {
  position: relative;
  width: 100%;
  height: 100%;
}
.trFeature__card {
  position: absolute;
  inset: 0;
  width: 100%;
  will-change: transform, filter, opacity;
  -webkit-transform-origin: 50% 85%;
          transform-origin: 50% 85%;
}

@media (prefers-reduced-motion: reduce) {
  .trFeature__wrapper {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }
  .trFeature__cards {
    display: grid !important;
    gap: 2rem;
    position: static !important;
    width: 100% !important;
    height: auto !important;
  }
  .trFeature__card {
    position: relative !important;
    inset: auto !important;
    top: auto !important;
    left: auto !important;
    width: 100% !important;
    opacity: 1 !important;
    -webkit-transform: none !important;
            transform: none !important;
    -webkit-filter: none !important;
            filter: none !important;
    will-change: auto !important;
  }
}
.trSlidertext {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}
.trSlidertext__body {
  overflow: hidden;
}
.trSlidertext__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-animation: loopCl 64000ms linear infinite both;
          animation: loopCl 64000ms linear infinite both;
}
.trSlidertext__item {
  font-family: var(--font-unique);
  font-weight: 400;
  line-height: 1;
}
@media screen and (min-width: 320px) {
  .trSlidertext__item {
    font-size: 16rem;
    width: 160rem;
  }
}
@media screen and (min-width: 600px) {
  .trSlidertext__item {
    font-size: 22rem;
    width: 226rem;
  }
}
.trSlidertext.--reverse {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.trSlidertext.--reverse .trSlidertext__wrapper {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-animation: loopClRv 64000ms linear infinite both;
          animation: loopClRv 64000ms linear infinite both;
}

.trVoice {
  margin-top: 32px;
}
.trVoice__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.trVoice__list {
  background: rgb(var(--color-white));
  color: rgb(var(--color-text));
}
@media screen and (min-width: 320px) {
  .trVoice__listWrapper {
    padding: 64px 5vw 64px 20.5vw;
  }
}
@media screen and (min-width: 600px) {
  .trVoice__listWrapper {
    padding: 64px 5vw 64px 12.5vw;
  }
}
.trVoice__listItem {
  position: relative;
}
@media screen and (min-width: 320px) {
  .trVoice__listItem {
    margin-bottom: 32px;
  }
}
@media screen and (min-width: 600px) {
  .trVoice__listItem {
    margin-bottom: 56px;
  }
}
.trVoice__listNum {
  font-family: var(--font-unique);
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 1;
  gap: 8px;
}
@media screen and (min-width: 320px) {
  .trVoice__listNum {
    font-size: 1.4rem;
    inset: 0.4rem auto auto -15.5vw;
  }
}
@media screen and (min-width: 600px) {
  .trVoice__listNum {
    font-size: 2.4rem;
    inset: 0.4rem auto auto -7.5vw;
  }
}
.trVoice__listNum span:first-child {
  font-size: 64%;
}
.trVoice__listTitle {
  font-family: var(--font-unique);
  font-weight: 400;
}
@media screen and (min-width: 320px) {
  .trVoice__listTitle {
    font-size: 2rem;
    margin-bottom: 8px;
  }
}
@media screen and (min-width: 600px) {
  .trVoice__listTitle {
    font-size: 3.2rem;
    margin-bottom: 16px;
  }
}
@media screen and (min-width: 320px) {
  .trVoice__listContent {
    font-size: 1.3rem;
    margin-bottom: 8px;
  }
}
@media screen and (min-width: 600px) {
  .trVoice__listContent {
    font-size: 1.8rem;
    margin-bottom: 16px;
  }
}
.trVoice__listTgt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (min-width: 320px) {
  .trVoice__listTgt {
    font-size: 1rem;
  }
}
@media screen and (min-width: 600px) {
  .trVoice__listTgt {
    font-size: 1.4rem;
  }
}
.trVoice__listTgt span {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  gap: 4px;
}
.trVoice__listTgt span::before {
  content: "(";
}
.trVoice__listTgt span::after {
  content: ")";
}
.trStats {
  overflow: clip;
}
.trStats__inner {
  padding: 0 5vw;
}
@media screen and (min-width: 320px) {
  .trStats__copy {
    padding: 24rem 10% 0 5vw;
    text-align: center;
  }
}
@media screen and (min-width: 600px) {
  .trStats__copy {
    padding: 24rem 55% 0 5vw;
    text-align: left;
  }
}
@media screen and (min-width: 320px) {
  .trStats__copy.isSmall {
    padding-top: 128px;
  }
}
@media screen and (min-width: 600px) {
  .trStats__copy.isSmall {
    padding-top: 0;
  }
}
@media screen and (min-width: 320px) {
  .trStats__copy .trHead__jatitle {
    margin: 48px 0 24px;
  }
}
@media screen and (min-width: 600px) {
  .trStats__copy .trHead__jatitle {
    margin: 48px 0 24px;
  }
}
.trStats__copy .trHead__desc {
  text-align: left;
}
@media screen and (min-width: 320px) {
  .trStats__cards {
    padding: 64px 0 0 0;
    margin-bottom: 0;
    -webkit-transform: unset;
            transform: unset;
  }
}
@media screen and (min-width: 600px) {
  .trStats__cards {
    padding: 64px 0 0 50%;
    margin-bottom: -22rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
.trStats__cardsWrapper {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (min-width: 320px) {
  .trStats__cardsWrapper {
    gap: 12px;
  }
}
@media screen and (min-width: 600px) {
  .trStats__cardsWrapper {
    gap: 24px;
  }
}
.trStats__cardsItem {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  border: solid 1px rgba(var(--color-white)/0.24);
  backdrop-filter: blur(24px) saturate(140%);
}
@media screen and (min-width: 320px) {
  .trStats__cardsItem {
    border-radius: 8px;
    padding: 32px 0;
  }
}
@media screen and (min-width: 600px) {
  .trStats__cardsItem {
    border-radius: 16px;
    padding: 32px 0;
  }
}
@media screen and (min-width: 320px) {
  .trStats__cardsItem:nth-child(even) {
    -webkit-transform: translateY(24px);
            transform: translateY(24px);
  }
}
@media screen and (min-width: 600px) {
  .trStats__cardsItem:nth-child(even) {
    -webkit-transform: translateY(24px);
            transform: translateY(24px);
  }
}
@media screen and (min-width: 320px) {
  .trStats__cardsTitle {
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 600px) {
  .trStats__cardsTitle {
    font-size: 1.8rem;
  }
}
.trStats__cardsMain {
  font-family: var(--font-head);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 8px;
}
@media screen and (min-width: 320px) {
  .trStats__cardsMain {
    font-size: 3.6rem;
    margin: 40px 0;
  }
}
@media screen and (min-width: 600px) {
  .trStats__cardsMain {
    font-size: 7.2rem;
    margin: 40px 0;
  }
}
.trStats__cardsMain span.unit {
  font-family: var(--font-main);
  font-size: 48%;
}
@media screen and (min-width: 320px) {
  .trStats__cardsSupple {
    font-size: 1.1rem;
  }
}
@media screen and (min-width: 600px) {
  .trStats__cardsSupple {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 320px) {
  .trStats__table {
    padding: 0 5vw;
  }
}
@media screen and (min-width: 600px) {
  .trStats__table {
    padding: 0 5vw;
  }
}

.odometer.odometer-auto-theme, .odometer.odometer-theme-default {
  font-family: var(--font-head) !important;
}

@media screen and (min-width: 320px) {
  .trDoctor {
    margin-top: 128px;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor {
    margin-top: 64px;
  }
}
.trDoctor__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.trDoctor__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 0 5vw;
}
@media screen and (min-width: 320px) {
  .trDoctor__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.trDoctor__msg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 320px) {
  .trDoctor__msg {
    width: 100%;
    padding: 0 5vw 0 0;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__msg {
    width: 35%;
    padding: 0 5vw 0 0;
  }
}
.trDoctor__msgTitle {
  font-family: var(--font-unique);
  margin-bottom: 24px;
}
@media screen and (min-width: 320px) {
  .trDoctor__msgTitle {
    font-size: 2.6rem;
    text-align: center;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__msgTitle {
    font-size: 3.2rem;
    text-align: left;
  }
}
@media screen and (min-width: 320px) {
  .trDoctor__msgMain {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__msgMain {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 320px) {
  .trDoctor__img {
    width: 60%;
    margin: 24px auto;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__img {
    width: 30%;
    margin: 0;
  }
}
.trDoctor__img .img {
  border-radius: 999vw;
}
.trDoctor__img .imgWrapper {
  padding-bottom: 124%;
}
.trDoctor__bio {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (min-width: 320px) {
  .trDoctor__bio {
    width: 100%;
    padding: 0 0 0 5vw;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__bio {
    width: 35%;
    padding: 0 0 0 5vw;
  }
}
.trDoctor__bioHead {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 16px;
}
@media screen and (min-width: 320px) {
  .trDoctor__bioHead {
    font-size: 2.4rem;
    gap: 32px;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__bioHead {
    font-size: 2.4rem;
    gap: 32px;
  }
}
.trDoctor__bioHead span {
  position: relative;
  display: inline-block;
  font-family: var(--font-head);
}
.trDoctor__bioHead span::after {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background: rgb(var(--color-white));
  position: absolute;
  inset: 0 -16px auto auto;
}
.trDoctor__bioHead h3 {
  font-weight: 400;
}
@media screen and (min-width: 320px) {
  .trDoctor__bio p {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 600px) {
  .trDoctor__bio p {
    font-size: 1.8rem;
  }
}

#menuFlowSwiper {
  position: relative;
  overflow: visible;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper {
    padding: 3rem 0 9rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper {
    padding: 12rem 0 0 28.5rem;
  }
}
#menuFlowSwiper .swiper-wrapper:nth-last-child(1) .slideNum::before {
  content: none;
}
#menuFlowSwiper .swiper-slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
#menuFlowSwiper .swiper-slide:nth-last-child(1) .slideTitle::before {
  content: none;
}
#menuFlowSwiper .slideNum {
  color: rgb(var(--color-wh));
  font-family: var(--font-head);
  font-weight: 700;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .slideNum {
    font-size: 3.6rem;
    letter-spacing: 0.3rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .slideNum {
    font-size: 8.2rem;
    letter-spacing: 0.7rem;
  }
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .slideTextWrapper {
    width: 83%;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .slideTextWrapper {
    width: 76%;
  }
}
#menuFlowSwiper .slideTitleWrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#menuFlowSwiper .slideTitle {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-family: var(--font-unique);
  font-weight: 700;
  color: rgb(var(--color-wh));
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .slideTitle {
    font-size: 2rem;
    margin-top: 1rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .slideTitle {
    font-size: 3.6rem;
    margin-top: 3rem;
  }
}
#menuFlowSwiper .slideTitle::before {
  position: absolute;
  content: "";
  border: 1px dashed rgb(var(--color-wh));
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .slideTitle::before {
    top: 1.5rem;
    left: calc(100% + 2rem);
    width: calc(29rem - 100%);
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .slideTitle::before {
    top: 2.8rem;
    left: calc(100% + 3.5rem);
    width: calc(40.5rem - 100%);
  }
}
#menuFlowSwiper .slideDesc {
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .slideDesc {
    font-size: 1.4rem;
    padding: 1.5rem 0 0 0.2rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .slideDesc {
    font-size: 2rem;
    padding: 5rem 0 0 0.5rem;
  }
}
#menuFlowSwiper .slideDesc a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .slideDesc a {
    text-underline-offset: 0.3rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .slideDesc a {
    text-underline-offset: 0.5rem;
  }
}
#menuFlowSwiper .slideImg {
  width: 100%;
  aspect-ratio: 435/241;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .slideImg {
    margin-top: 24px;
    border-radius: 4px;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .slideImg {
    margin-top: 48px;
    border-radius: 8px;
  }
}
#menuFlowSwiper .swiperBtnWrapper {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .swiperBtnWrapper {
    top: unset;
    bottom: 0;
    right: 50%;
    -webkit-transform: translateX(50%);
            transform: translateX(50%);
    gap: 0 2rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .swiperBtnWrapper {
    top: -11.5rem;
    bottom: unset;
    right: 0;
    -webkit-transform: unset;
            transform: unset;
    gap: 0 5rem;
  }
}
#menuFlowSwiper .swiper-button-prev, #menuFlowSwiper .swiper-button-next {
  position: static;
  height: auto;
  color: #FFFFFF;
  margin-top: 0;
  background: #867463;
  font-family: "ShipporiMincho", sans-serif;
  border: none;
  border-radius: 5rem;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .swiper-button-prev, #menuFlowSwiper .swiper-button-next {
    width: 15rem;
    font-size: 1.4rem;
    padding: 0.5rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .swiper-button-prev, #menuFlowSwiper .swiper-button-next {
    width: 30rem;
    font-size: 2.6rem;
    padding: 1rem;
  }
}
#menuFlowSwiper .swiper-button-prev::after, #menuFlowSwiper .swiper-button-next::after {
  content: none;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .swiper-button-prev .btnText {
    margin-left: 20%;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .swiper-button-prev .btnText {
    margin-left: 20%;
  }
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .swiper-button-next .btnText {
    margin-right: 20%;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .swiper-button-next .btnText {
    margin-right: 20%;
  }
}
#menuFlowSwiper .btnIcon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 50%;
  background: #FFFFFF;
  aspect-ratio: 1/1;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .btnIcon {
    width: 30.5%;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .btnIcon {
    width: 30.5%;
  }
}
#menuFlowSwiper .btnIconSvg {
  stroke: #867463;
}
@media screen and (min-width: 320px) {
  #menuFlowSwiper .btnIconSvg {
    width: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  #menuFlowSwiper .btnIconSvg {
    width: 4rem;
  }
}
#menuFlowSwiper .swiper-button-prev {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
#menuFlowSwiper .swiper-button-next {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.agaApproach {
  padding: 0 5vw;
  overflow: hidden;
}
@media screen and (min-width: 320px) {
  .agaApproach .sectionTitleEng {
    font-size: 6.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .agaApproach .sectionTitleEng {
    font-size: 22.2rem;
  }
}

.approachWrapper {
  position: relative;
}
@media screen and (min-width: 320px) {
  .approachWrapper {
    margin: 6rem 0 0;
    padding-bottom: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachWrapper {
    margin: 22.6rem 0 0 11vw;
    padding-bottom: 5rem;
  }
}

.approachNum {
  position: absolute;
  color: rgba(var(--color-wh)/0.16);
  font-family: var(--font-head);
  font-weight: 700;
  z-index: -1;
}
@media screen and (min-width: 320px) {
  .approachNum {
    top: -4rem;
    left: -2rem;
    font-size: 7rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachNum {
    top: -11.5rem;
    left: -11.5rem;
    font-size: 16rem;
  }
}

.approachTitle {
  font-family: var(--font-unique);
  color: #FFFFFF;
  font-weight: 400;
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 320px) {
  .approachTitle {
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachTitle {
    font-size: 3.6rem;
  }
}

.approachDesc {
  color: #FFFFFF;
  font-weight: 400;
  margin: 24px 0;
}
@media screen and (min-width: 320px) {
  .approachDesc {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachDesc {
    font-size: 2rem;
  }
}

.approachSwiper {
  overflow: visible;
}
@media screen and (min-width: 320px) {
  .approachSwiper {
    margin-top: 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper {
    margin-top: 6.5rem;
  }
}
.approachSwiper .swiper-slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: auto;
  border-radius: 24px;
  -webkit-box-shadow: 20px 20px 60px #938477, -20px -20px 60px #c7b2a1;
          box-shadow: 20px 20px 60px #938477, -20px -20px 60px #c7b2a1;
  background: #AD9B8C;
}
@media screen and (min-width: 320px) {
  .approachSwiper .swiper-slide {
    padding: 1rem 1rem 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .swiper-slide {
    padding: 1.4rem 1.4rem 5.5rem;
  }
}
.approachSwiper .swiper-slide .itemImg {
  border-radius: 2rem;
  aspect-ratio: 74/41;
}
.approachSwiper .swiper-slide .title {
  text-align: center;
  font-weight: 600;
  letter-spacing: -0.1rem;
}
@media screen and (min-width: 320px) {
  .approachSwiper .swiper-slide .title {
    font-size: 2rem;
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .swiper-slide .title {
    font-size: 2.7rem;
    margin-top: 5.4rem;
  }
}
.approachSwiper .swiper-slide .desc {
  opacity: 0.8;
  line-height: 1.75;
  letter-spacing: 0.08rem;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media screen and (min-width: 320px) {
  .approachSwiper .swiper-slide .desc {
    font-size: 1.4rem;
    padding: 2rem 2% 0;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .swiper-slide .desc {
    font-size: 1.6rem;
    padding: 3.3rem 0 0 6%;
  }
}
@media screen and (min-width: 320px) {
  .approachSwiper .detail {
    padding: 16px 2% 0;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .detail {
    padding: 24px 6% 0;
  }
}
.approachSwiper .pos {
  margin-bottom: 16px;
}
.approachSwiper .pos span {
  display: inline-block;
  background: rgb(var(--color-wh));
  color: rgb(var(--color-text));
  line-height: 1;
}
@media screen and (min-width: 320px) {
  .approachSwiper .pos span {
    font-size: 1.2rem;
    padding: 4px 8px;
    border-radius: 4px;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .pos span {
    font-size: 1.6rem;
    padding: 6px 12px;
    border-radius: 8px;
  }
}
.approachSwiper .specs dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (min-width: 320px) {
  .approachSwiper .specs dl {
    font-size: 1.2rem;
    margin-bottom: 8px;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .specs dl {
    font-size: 1.6rem;
    margin-bottom: 12px;
  }
}
.approachSwiper .specs dt, .approachSwiper .specs dd {
  position: relative;
}
@media screen and (min-width: 320px) {
  .approachSwiper .specs dt, .approachSwiper .specs dd {
    padding-bottom: 8px;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .specs dt, .approachSwiper .specs dd {
    padding-bottom: 12px;
  }
}
.approachSwiper .specs dt::after, .approachSwiper .specs dd::after {
  content: "";
  position: absolute;
  inset: auto auto 0 0;
  width: 100%;
  height: 1px;
  background: rgb(var(--color-wh));
}
.approachSwiper .specs dt {
  width: 20%;
  font-weight: 700;
}
.approachSwiper .specs dt::after {
  opacity: 0.64;
}
.approachSwiper .specs dd {
  width: 80%;
  opacity: 0.8;
}
.approachSwiper .specs dd::after {
  opacity: 0.32;
}
@media screen and (min-width: 320px) {
  .approachSwiper .content {
    padding: 16px 2% 0;
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .content {
    padding: 24px 6% 0;
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 320px) {
  .approachSwiper .content p {
    margin-bottom: 8px;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .content p {
    margin-bottom: 12px;
  }
}
@media screen and (min-width: 320px) {
  .approachSwiper .content ul {
    padding: 12px 0 0 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachSwiper .content ul {
    padding: 12px 0 0 2rem;
  }
}
.approachSwiper .content li {
  margin-bottom: 8px;
  list-style-type: disc;
}

.approachAbout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 320px) {
  .approachAbout {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 4rem 0;
    padding: 2rem 0 0;
  }
}
@media screen and (min-width: 1025px) {
  .approachAbout {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 0;
    padding: 4rem 0 0 11vw;
  }
}

@media screen and (min-width: 320px) {
  .approachTextWrapper {
    width: 100%;
    padding-top: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachTextWrapper {
    width: 47%;
    padding-top: 8.8rem;
  }
}

.approacCopy {
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (min-width: 320px) {
  .approacCopy {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 1025px) {
  .approacCopy {
    font-size: 2.7rem;
  }
}

.approacText {
  line-height: 1.81;
  opacity: 0.8;
}
@media screen and (min-width: 320px) {
  .approacText {
    font-size: 1.4rem;
    margin-top: 2.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .approacText {
    font-size: 2.1rem;
    margin-top: 4.5rem;
  }
}

@media screen and (min-width: 320px) {
  .approachAboutImg {
    width: 80%;
    border-radius: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .approachAboutImg {
    width: 49%;
    border-radius: 3rem;
  }
}

.fvCv {
  position: absolute;
  bottom: 1rem;
  right: 0.4vw;
}
@media screen and (min-width: 320px) {
  .fvCv {
    display: none;
    width: 18rem;
  }
}
@media screen and (min-width: 1025px) {
  .fvCv {
    display: block;
    width: 43rem;
  }
}

.compareImgWrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (min-width: 320px) {
  .compareImgWrapper {
    padding: 8rem 5vw 0;
    gap: 3rem 0;
  }
}
@media screen and (min-width: 1025px) {
  .compareImgWrapper {
    padding: 20.2rem 21.5rem 0;
    gap: 0;
  }
}

.compareImgItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #e8eeee;
  border-radius: 2rem;
  -webkit-box-shadow: -3.83px -3.214px 10px 0px rgba(255, 255, 255, 0.7), 3.83px 3.214px 10px 0px rgba(169, 189, 199, 0.6);
          box-shadow: -3.83px -3.214px 10px 0px rgba(255, 255, 255, 0.7), 3.83px 3.214px 10px 0px rgba(169, 189, 199, 0.6);
}
@media screen and (min-width: 320px) {
  .compareImgItem {
    width: 100%;
    padding: 2rem 3rem 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .compareImgItem {
    width: 48.6%;
    padding: 5.2rem 9.6rem 6.5rem;
  }
}

.compareImgTitle {
  color: #867463;
  font-weight: 700;
}
@media screen and (min-width: 320px) {
  .compareImgTitle {
    font-size: 2rem;
    letter-spacing: 0.1rem;
  }
}
@media screen and (min-width: 1025px) {
  .compareImgTitle {
    font-size: 3.6rem;
    letter-spacing: 0.16rem;
  }
}

@media screen and (min-width: 320px) {
  .compareImg {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .compareImg {
    margin-top: 5rem;
  }
}

.compareListWrapper {
  overflow: auto;
}
@media screen and (min-width: 320px) {
  .compareListWrapper {
    width: 100vw;
    padding: 5rem 2.5vw 0;
    margin-left: -2.5vw;
  }
}
@media screen and (min-width: 1025px) {
  .compareListWrapper {
    width: auto;
    padding: 8rem 21.5rem 0;
    margin-left: unset;
  }
}

.compareList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  font-family: "ShipporiMincho", sans-serif;
}
@media screen and (min-width: 320px) {
  .compareList {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    gap: 0 1px;
  }
}
@media screen and (min-width: 1025px) {
  .compareList {
    width: 100%;
    gap: 0 2px;
  }
}

.rowHeader {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 320px) {
  .rowHeader {
    width: 19%;
    gap: 1px 0;
  }
}
@media screen and (min-width: 1025px) {
  .rowHeader {
    width: 24%;
    gap: 2px 0;
  }
}
@media screen and (min-width: 320px) {
  .rowHeader .compareListText {
    letter-spacing: 0.05rem;
    padding-left: 10%;
  }
}
@media screen and (min-width: 1025px) {
  .rowHeader .compareListText {
    letter-spacing: 0.1rem;
    padding-left: 16%;
  }
}

.listInsulation {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 320px) {
  .listInsulation {
    width: 40.5%;
    gap: 1px 0;
    border-radius: 1rem 1rem 0 0;
  }
}
@media screen and (min-width: 1025px) {
  .listInsulation {
    width: 38%;
    gap: 2px 0;
    border-radius: 2rem 2rem 0 0;
  }
}
.listInsulation::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (min-width: 320px) {
  .listInsulation::before {
    border: 2px solid #867463;
    border-radius: 1rem 1rem 0 0;
  }
}
@media screen and (min-width: 1025px) {
  .listInsulation::before {
    border: 3px solid #867463;
    border-radius: 2rem 2rem 0 0;
  }
}
.listInsulation .columnHeader {
  color: #FFFFFF;
  background: #867463;
}
@media screen and (min-width: 320px) {
  .listInsulation .columnHeader {
    font-size: 1.8rem;
    letter-spacing: 0.1rem;
    padding: 3rem 1rem 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .listInsulation .columnHeader {
    font-size: 3.6rem;
    letter-spacing: 0.2rem;
    padding: 5rem 4rem 5.7rem;
  }
}
@media screen and (min-width: 320px) {
  .listInsulation .compareListText {
    letter-spacing: 0.05rem;
    padding-left: 6%;
  }
}
@media screen and (min-width: 1025px) {
  .listInsulation .compareListText {
    letter-spacing: 0.1rem;
    padding-left: 8.5%;
  }
}

.listNonInsulated {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #959595;
}
@media screen and (min-width: 320px) {
  .listNonInsulated {
    width: 40.5%;
    gap: 1px 0;
  }
}
@media screen and (min-width: 1025px) {
  .listNonInsulated {
    width: 38%;
    gap: 2px 0;
  }
}
.listNonInsulated .columnHeader {
  background: #f5f7f9;
}
@media screen and (min-width: 320px) {
  .listNonInsulated .columnHeader {
    font-size: 1.4rem;
    letter-spacing: 0.08rem;
    padding: 2rem 1rem 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .listNonInsulated .columnHeader {
    font-size: 3rem;
    letter-spacing: 0.16rem;
    padding: 4.2rem 4rem 3.2rem;
  }
}
.listNonInsulated .compareListText {
  background: #f5f7f9;
  padding-left: 8.5%;
}
@media screen and (min-width: 320px) {
  .listNonInsulated .compareListText {
    letter-spacing: 0.05rem;
    padding-left: 6%;
  }
}
@media screen and (min-width: 1025px) {
  .listNonInsulated .compareListText {
    letter-spacing: 0.1rem;
    padding-left: 8.5%;
  }
}

.compareListText {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-weight: 700;
  background: #FFFFFF;
}
@media screen and (min-width: 320px) {
  .compareListText {
    font-size: 1.2rem;
    height: 5rem;
  }
}
@media screen and (min-width: 1025px) {
  .compareListText {
    font-size: 2.4rem;
    height: 10rem;
  }
}
.compareListText .note {
  letter-spacing: normal;
}
@media screen and (min-width: 320px) {
  .compareListText .note {
    font-size: 73%;
  }
}
@media screen and (min-width: 1025px) {
  .compareListText .note {
    font-size: 80%;
  }
}

.columnHeader {
  font-weight: 700;
}
@media screen and (min-width: 320px) {
  .columnHeader {
    border-radius: 1rem 1rem 0 0;
  }
}
@media screen and (min-width: 1025px) {
  .columnHeader {
    border-radius: 2rem 2rem 0 0;
  }
}

.menuOnline {
  position: relative;
  overflow-x: clip;
}
@media screen and (min-width: 320px) {
  .menuOnline {
    padding: 12rem 2.5vw 64px;
  }
}
@media screen and (min-width: 1025px) {
  .menuOnline {
    padding: 34rem 5vw 128px;
    margin-top: 24rem;
  }
}
@media screen and (min-width: 320px) {
  .menuOnline .commonLinkBtn {
    margin: 3.5rem auto 0;
  }
}
@media screen and (min-width: 1025px) {
  .menuOnline .commonLinkBtn {
    margin: 7rem 1.5rem 0 auto;
  }
}

@media screen and (min-width: 320px) {
  .onlineTextWrapper {
    width: 100%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineTextWrapper {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.onlineTitle {
  font-family: var(--font-unique);
  font-weight: 400;
  color: var(--color-wh);
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 320px) {
  .onlineTitle {
    font-size: 2rem;
    text-align: center;
  }
}
@media screen and (min-width: 1025px) {
  .onlineTitle {
    font-size: 4rem;
    text-align: left;
  }
}

.onlineDesc {
  font-family: "ShipporiMincho", sans-serif;
  opacity: 0.8;
  line-height: 1.7;
  letter-spacing: 0.05rem;
}
@media screen and (min-width: 320px) {
  .onlineDesc {
    font-size: 1.4rem;
    margin-top: 3rem;
    text-align: center;
  }
}
@media screen and (min-width: 1025px) {
  .onlineDesc {
    font-size: 2.1rem;
    margin-top: 6.5rem;
    text-align: left;
  }
}

.onlineImg {
  position: absolute;
}
@media screen and (min-width: 320px) {
  .onlineImg {
    bottom: 3rem;
    right: 5vw;
    width: 18rem;
    border-radius: 1rem;
    aspect-ratio: 49/41;
    -o-object-position: center 40%;
       object-position: center 40%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineImg {
    bottom: unset;
    top: 0;
    right: 13rem;
    width: 38rem;
    border-radius: 2rem;
    aspect-ratio: 38/49;
    -o-object-position: center;
       object-position: center;
  }
}

.onlineAboutWrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap-reverse;
      flex-wrap: wrap-reverse;
}

.onlineAboutImg {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (min-width: 320px) {
  .onlineAboutImg {
    width: 15rem;
    border-radius: 1rem;
    margin: 11rem 0 0 2.5vw;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutImg {
    width: 41.7rem;
    border-radius: 2rem;
    margin: 0 0 4.5rem 10rem;
  }
}

.onlineBgText {
  position: absolute;
  font-family: var(--font-head);
  font-weight: 700;
  color: rgba(var(--color-wh)/0.08);
  line-height: 0.8;
  z-index: -1;
}
@media screen and (min-width: 320px) {
  .onlineBgText {
    top: 8rem;
    left: -0.5rem;
    font-size: 8.4rem;
    letter-spacing: 0.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .onlineBgText {
    top: 15.5rem;
    left: -1rem;
    font-size: 40rem;
    letter-spacing: 1rem;
  }
}
.onlineBgText .small {
  font-size: 82%;
}

.onlineAboutList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (min-width: 320px) {
  .onlineAboutList {
    width: 100%;
    gap: 1rem 2%;
    margin-top: 4rem;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutList {
    width: 46%;
    gap: 2rem 2.75%;
    margin-top: unset;
  }
}

.onlineAboutItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-shadow: 20px 20px 60px #938477, -20px -20px 60px #c7b2a1;
          box-shadow: 20px 20px 60px #938477, -20px -20px 60px #c7b2a1;
  background: #AD9B8C;
  font-family: "ShipporiMincho", sans-serif;
  aspect-ratio: 10/9;
  fill: rgb(var(--color-wh));
}
@media screen and (min-width: 320px) {
  .onlineAboutItem {
    width: 32%;
    border-radius: 1rem;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem {
    width: 31.5%;
    border-radius: 2rem;
  }
}
.onlineAboutItem .itemText {
  opacity: 0.8;
  text-align: center;
}
@media screen and (min-width: 320px) {
  .onlineAboutItem .itemText {
    font-size: 1.2rem;
    margin-bottom: 12%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem .itemText {
    font-size: 1.8rem;
    margin-bottom: 14.5%;
  }
}
.onlineAboutItem .svgWrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 7%;
}
@media screen and (min-width: 320px) {
  .onlineAboutItem .phoneSvg {
    width: 41%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem .phoneSvg {
    width: 41%;
  }
}
.onlineAboutItem .logoSvg {
  position: absolute;
  top: 28%;
  left: 45%;
}
@media screen and (min-width: 320px) {
  .onlineAboutItem .logoSvg {
    width: 10%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem .logoSvg {
    width: 10%;
  }
}
.onlineAboutItem .clockSvg {
  width: 34%;
}
@media screen and (min-width: 320px) {
  .onlineAboutItem .clockSvg {
    margin-bottom: 5%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem .clockSvg {
    margin-bottom: 10%;
  }
}
.onlineAboutItem .medicineSvg {
  width: 35.5%;
  margin-bottom: 10%;
}
.onlineAboutItem .salesSvg {
  width: 35.5%;
}
@media screen and (min-width: 320px) {
  .onlineAboutItem .salesSvg {
    margin-bottom: 5%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem .salesSvg {
    margin-bottom: 10%;
  }
}
.onlineAboutItem .lockSvg {
  width: 31.5%;
}
@media screen and (min-width: 320px) {
  .onlineAboutItem .lockSvg {
    margin-bottom: 5%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem .lockSvg {
    margin-bottom: 10%;
  }
}
.onlineAboutItem .moneySvg {
  width: 39%;
}
@media screen and (min-width: 320px) {
  .onlineAboutItem .moneySvg {
    margin-bottom: 3%;
  }
}
@media screen and (min-width: 1025px) {
  .onlineAboutItem .moneySvg {
    margin-bottom: 6%;
  }
}
.onlineAboutItem .moneySvg .svgElem {
  fill: none;
  stroke: rgb(var(--color-wh));
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2px;
}

.faqList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
}
@media screen and (min-width: 320px) {
  .faqList {
    gap: 2rem;
    margin-top: 4rem;
  }
}
@media screen and (min-width: 1025px) {
  .faqList {
    gap: 3rem;
    margin-top: 25rem;
  }
}

.faqItemWrapper {
  position: relative;
}

.faqItem {
  position: relative;
  cursor: pointer;
  background: rgba(var(--color-text)/0.24);
  backdrop-filter: blur(16px) saturate(140%);
  border: solid 1px rgba(var(--color-wh)/0.24);
}
@media screen and (min-width: 320px) {
  .faqItem {
    border-radius: 1rem;
    padding: 2rem 5rem 2.1rem 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .faqItem {
    border-radius: 2rem;
    padding: 5rem 14rem 5.4rem 5rem;
  }
}
.faqItem[open] ~ .faqIcon {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.faqTitle {
  font-family: "ShipporiMincho", sans-serif;
  font-weight: 700;
  color: rgb(var(--color-wh));
  list-style: none;
  letter-spacing: 0.15rem;
}
@media screen and (min-width: 320px) {
  .faqTitle {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .faqTitle {
    font-size: 3.2rem;
  }
}
.faqTitle::-webkit-details-marker {
  display: none;
}
.faqTitle::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.faqDesc {
  font-family: "ShipporiMincho", sans-serif;
  font-weight: 500;
  opacity: 0.9;
  line-height: 1.8;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 320px) {
  .faqDesc {
    font-size: 1.4rem;
    padding: 2.5rem 0 0 0.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .faqDesc {
    font-size: 2rem;
    padding: 5rem 0 0 0.6rem;
  }
}

.faqIcon {
  position: absolute;
  right: 5%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 6%;
  aspect-ratio: 1/1;
  background: #867463;
  border-radius: 50%;
}
@media screen and (min-width: 320px) {
  .faqIcon {
    top: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .faqIcon {
    top: 4.5rem;
  }
}

.faqSvg {
  width: 50%;
  stroke: #FFFFFF;
}

#trFaq .trStats__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (min-width: 320px) {
  #trFaq .trStats__copy {
    width: 100%;
    padding: 128px 0 0 5vw;
  }
}
@media screen and (min-width: 600px) {
  #trFaq .trStats__copy {
    width: 47.5%;
    padding: 128px 0 0 5vw;
  }
}
#trFaq .trStats__sticky {
  position: sticky;
  top: 22rem;
}
@media screen and (min-width: 320px) {
  #trFaq .trStats__table {
    width: 100%;
  }
}
@media screen and (min-width: 600px) {
  #trFaq .trStats__table {
    width: 50%;
  }
}

:root {
  --s3c-bg: 190 171 154; /* #beab9a */
  --s3c-ink: 30 28 26;
  --s3c-white: 255 255 255;
  --s3c-stroke: 0 0 0 / .10;
}

.s3cDisclosure {
  margin: 18px auto 64px;
}
@media screen and (min-width: 320px) {
  .s3cDisclosure {
    width: 100%;
  }
}
@media screen and (min-width: 600px) {
  .s3cDisclosure {
    width: 50%;
  }
}

.s3cDisclosure__card {
  border: 1px solid rgba(var(--s3c-stroke));
  border-radius: 18px;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.82)), to(rgba(255, 255, 255, 0.68)));
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.68));
  -webkit-box-shadow: 0 16px 46px rgba(0, 0, 0, 0.08), 0 2px 10px rgba(0, 0, 0, 0.06);
          box-shadow: 0 16px 46px rgba(0, 0, 0, 0.08), 0 2px 10px rgba(0, 0, 0, 0.06);
  overflow: clip;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.s3cDisclosure__summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 14px;
}

.s3cDisclosure__summary::-webkit-details-marker {
  display: none;
}

.s3cDisclosure__title {
  font-weight: 600;
  letter-spacing: 0.02em;
  color: rgb(var(--s3c-ink));
  font-size: 13px;
}

.s3cDisclosure__icon {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  position: relative;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  background: rgba(var(--s3c-bg)/0.22);
  border: 1px solid rgba(var(--s3c-bg)/0.35);
  -webkit-box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
          box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

.s3cDisclosure__icon::before,
.s3cDisclosure__icon::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 12px;
  height: 2px;
  background: rgba(var(--s3c-ink)/0.72);
  border-radius: 2px;
}

.s3cDisclosure__icon::after {
  width: 2px;
  height: 12px;
}

.s3cDisclosure__card[open] .s3cDisclosure__icon::after {
  -webkit-transform: scaleY(0);
          transform: scaleY(0);
}

.s3cDisclosure__body {
  padding: 0 16px 14px;
  border-top: 1px solid rgba(var(--s3c-stroke));
}

.s3cDisclosure__body p {
  margin: 12px 0 0;
  line-height: 1.9;
  color: rgba(var(--s3c-ink)/0.84);
  font-size: 13px;
}

.s3cDisclosure__body small {
  display: inline-block;
  margin-top: 6px;
  color: rgba(var(--s3c-ink)/0.62);
  font-size: 12px;
}

/* SP微調整 */
@media (max-width: 720px) {
  .s3cDisclosure__summary {
    padding: 12px 14px;
  }
  .s3cDisclosure__body {
    padding: 0 14px 12px;
  }
}/*# sourceMappingURL=treatments.css.map */