@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes scroll-line {
  0% {
    height: 0;
  }
  100% {
    height: 100%;
  }
}
.top-content {
  opacity: 0;
}

.top-opening {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 400;
}

.top-opening_first {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.top-opening_first:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../../img/top-opening-first-before.jpg);
  background-size: cover;
  background-position: 50% 0%;
}
.top-opening_first--window {
  width: 18.1551976574vw;
  max-height: 47.5260416667vh;
  aspect-ratio: 248/365;
  background-image: url(../../img/top-opening-first-window.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media (max-width: 767px) {
  .top-opening_first--window {
    width: 66.1333333333vw;
    max-height: auto;
  }
}

.top-opening_second {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.top-opening_second:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../../img/top-opening-second-before.jpg);
  background-size: cover;
  background-position: 50% 0%;
}
.top-opening_second--deco {
  width: 36.5300146413vw;
  max-height: 68.4895833333vh;
  aspect-ratio: 499/526;
  background-position: 50% 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media (max-width: 767px) {
  .top-opening_second--deco {
    width: 63.7333333333vw;
    max-height: auto;
  }
}
.top-opening_second--tree {
  width: 100%;
  height: 100%;
  background-image: url(../../img/top-opening-second-tree.svg);
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  transform-origin: center;
}
.top-opening_second--lip {
  width: 36.5300146413vw;
  height: auto;
  max-height: 68.4895833333vh;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-47deg);
  transform-origin: center;
}
@media (max-width: 767px) {
  .top-opening_second--lip {
    width: 63.7333333333vw;
    max-height: auto;
  }
}
.top-opening_second--lip > g {
  display: block;
  transform-origin: center;
}

.top-opening_third {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: 100% auto;
  background-repeat: repeat-y;
  background-position: 0% 0%;
  background-image: url(../../img/cmn-main-top.jpg);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 767px) {
  .top-opening_third {
    background-size: 364.2666666667vw auto;
  }
}
.top-opening_third--img {
  display: block;
  width: 4.831625183vw;
  max-height: 49.21875vh;
  object-fit: contain;
}
@media (max-width: 767px) {
  .top-opening_third--img {
    width: 13.0666666667vw;
    max-height: auto;
  }
}

.top-mv {
  height: 100vh;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  position: relative;
}
@media (max-width: 767px) {
  .top-mv {
    display: block;
    height: auto;
  }
}
.top-mv--wrapper {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 56.2225475842vw;
  display: flex;
  overflow: hidden;
  cursor: grab;
}
.top-mv--wrapper.is_dragging {
  cursor: grabbing;
}
@media (max-width: 767px) {
  .top-mv--wrapper {
    position: static;
    transform: none;
    height: auto;
    display: block;
  }
}
.is_mv_height_over .top-mv--wrapper {
  height: 100vh;
}
.top-mv--inner {
  display: flex;
  align-items: flex-start;
  width: 446.5592972182vw;
  box-sizing: border-box;
  padding-left: 18.6676427526vw;
  transform: translateX(0);
  will-change: transform;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}
@media (max-width: 767px) {
  .top-mv--inner {
    display: block;
    width: 100%;
    padding-left: 0;
    animation: none;
  }
}
.is_mv_height_over .top-mv--inner {
  width: calc(609.375vh + 100vw);
  padding-left: 33.203125vh;
}
@media (max-width: 767px) {
  .top-mv--inner:last-of-type {
    display: none;
  }
}
.top-mv--img {
  display: block;
  pointer-events: none;
}
.top-mv--img-01 {
  width: 43.9238653001vw;
  margin-top: 6.8814055637vw;
}
@media (max-width: 767px) {
  .top-mv--img-01 {
    width: 90.6666666667vw;
    margin-top: 22.6666666667vw;
  }
}
.is_mv_height_over .top-mv--img-01 {
  width: 78.125vh;
  margin-top: 12.2395833333vh;
}
.top-mv--img-02 {
  width: 23.2796486091vw;
  margin-left: 8.2723279649vw;
  margin-top: 19.3997071742vw;
}
@media (max-width: 767px) {
  .top-mv--img-02 {
    width: 64.2666666667vw;
    margin-left: 0;
    margin-top: 30.6666666667vw;
  }
}
.is_mv_height_over .top-mv--img-02 {
  width: 41.40625vh;
  margin-left: 14.7135416667vh;
  margin-top: 34.5052083333vh;
}
.top-mv--img-03 {
  width: 29.0629575403vw;
  margin-left: -3.1478770132vw;
  margin-top: 6.8814055637vw;
}
@media (max-width: 767px) {
  .top-mv--img-03 {
    width: 80vw;
    margin-left: auto;
    margin-top: 30.6666666667vw;
  }
}
.is_mv_height_over .top-mv--img-03 {
  width: 51.6927083333vh;
  margin-left: -5.5989583333vh;
  margin-top: 12.2395833333vh;
}
.top-mv--img-04 {
  width: 42.972181552vw;
  margin-left: -26.5007320644vw;
  margin-top: 24.8169838946vw;
}
@media (max-width: 767px) {
  .top-mv--img-04 {
    width: 100%;
    margin-left: 0;
    margin-top: 40.2666666667vw;
  }
}
.is_mv_height_over .top-mv--img-04 {
  width: 76.4322916667vh;
  margin-left: -47.1354166667vh;
  margin-top: 44.140625vh;
}
.top-mv--img-05 {
  width: 23.5724743777vw;
  margin-left: -11.1273792094vw;
}
@media (max-width: 767px) {
  .top-mv--img-05 {
    width: 64.5333333333vw;
    margin-left: 0;
    margin-top: 48.8vw;
  }
}
.is_mv_height_over .top-mv--img-05 {
  width: 41.9270833333vh;
  margin-left: -19.7916666667vh;
}
.top-mv--img-06 {
  width: 29.0629575403vw;
  margin-top: 24.8169838946vw;
}
@media (max-width: 767px) {
  .top-mv--img-06 {
    width: 80vw;
    margin-left: auto;
    margin-top: 44.8vw;
  }
}
.is_mv_height_over .top-mv--img-06 {
  width: 51.6927083333vh;
  margin-top: 44.140625vh;
}
.top-mv--desc {
  font-size: 1.317715959vw;
  letter-spacing: 0.05em;
  line-height: 3.3333333333;
  text-align: center;
  pointer-events: none;
}
@media (max-width: 767px) {
  .top-mv--desc {
    font-size: 4vw;
    line-height: 2.6666666667;
  }
}
.is_mv_height_over .top-mv--desc {
  font-size: 2.34375vh;
}
.top-mv--desc-01 {
  font-size: 1.4641288433vw;
  letter-spacing: 0.2em;
  line-height: 2;
  margin-top: 21.0834553441vw;
  margin-left: -19.7657393851vw;
}
@media (max-width: 767px) {
  .top-mv--desc-01 {
    font-size: 4vw;
    line-height: 2.6666666667;
    margin-top: 113.8666666667vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.is_mv_height_over .top-mv--desc-01 {
  font-size: 2.6041666667vh;
  margin-top: 37.5vh;
  margin-left: -35.15625vh;
}
.top-mv--desc-02 {
  margin-top: 36.6032210835vw;
  margin-left: 8.5651537335vw;
}
@media (max-width: 767px) {
  .top-mv--desc-02 {
    margin-top: 36vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.is_mv_height_over .top-mv--desc-02 {
  margin-top: 65.1041666667vh;
  margin-left: 15.234375vh;
}
.top-mv--desc-03 {
  margin-top: 9.663250366vw;
  margin-left: 9.4436310395vw;
}
@media (max-width: 767px) {
  .top-mv--desc-03 {
    margin-top: 37.3333333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.is_mv_height_over .top-mv--desc-03 {
  margin-top: 17.1875vh;
  margin-left: 16.796875vh;
}
.top-mv--desc-04 {
  margin-top: 35.7247437775vw;
  margin-left: 10.8345534407vw;
}
@media (max-width: 767px) {
  .top-mv--desc-04 {
    margin-top: 42.9333333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.is_mv_height_over .top-mv--desc-04 {
  margin-top: 63.5416666667vh;
  margin-left: 19.2708333333vh;
}
.top-mv--desc-05 {
  margin-top: 12.9575402635vw;
  margin-left: 12.737920937vw;
}
@media (max-width: 767px) {
  .top-mv--desc-05 {
    margin-top: 43.2vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.is_mv_height_over .top-mv--desc-05 {
  margin-top: 23.046875vh;
  margin-left: 22.65625vh;
}
.top-mv--desc-06 {
  margin-top: 27.5256222548vw;
  margin-left: 41.5812591508vw;
}
@media (max-width: 767px) {
  .top-mv--desc-06 {
    margin-top: 70.1333333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.is_mv_height_over .top-mv--desc-06 {
  margin-top: 48.9583333333vh;
  margin-left: 0;
  width: 100vw;
}
.top-mv--scroll {
  display: flex;
  align-items: flex-start;
  position: absolute;
  bottom: 0;
  right: 2.635431918vw;
  height: 5.8565153734vw;
}
@media (max-width: 767px) {
  .top-mv--scroll {
    display: none;
  }
}
.top-mv--scroll:before {
  content: "";
  display: block;
  background-color: #868484;
  width: 0.0732064422vw;
  height: 0;
  margin-right: 0.5124450952vw;
  animation: scroll-line 1.2s ease-in-out infinite;
}
.top-mv--scroll_txt {
  writing-mode: vertical-rl;
  font-family: "Marcellus", serif;
  font-size: 1.0248901903vw;
  color: #707070;
  line-height: 1.2857142857;
}

.top-mv_ttl {
  margin-top: 28.2576866764vw;
  margin-left: -11.3469985359vw;
  position: relative;
  width: 36.4568081991vw;
  aspect-ratio: 498/226;
  pointer-events: none;
}
@media (max-width: 767px) {
  .top-mv_ttl {
    margin-top: -5.0666666667vw;
    margin-left: 8.5333333333vw;
    width: 88.2666666667vw;
  }
}
.is_mv_height_over .top-mv_ttl {
  margin-top: 50.2604166667vh;
  margin-left: -20.1822916667vh;
  width: 64.84375vh;
}
.top-mv_ttl--img {
  display: block;
  width: 100%;
}
.top-mv_ttl--img_deco {
  display: block;
  width: 5.0512445095vw;
  aspect-ratio: 69/39;
  background-image: url(../../img/lip.svg);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: contain;
  position: absolute;
  right: 0;
  bottom: 7.6134699854vw;
}
@media (max-width: 767px) {
  .top-mv_ttl--img_deco {
    width: 12.2666666667vw;
    right: 1.0666666667vw;
    bottom: 18.4vw;
  }
}
.is_mv_height_over .top-mv_ttl--img_deco {
  width: 8.984375vh;
  bottom: 13.5416666667vh;
}

.top-mv_letter {
  position: absolute;
  bottom: 2.1229868228vw;
  left: 15.1537335286vw;
  width: 15.8125915081vw;
}
@media (max-width: 767px) {
  .top-mv_letter {
    bottom: auto;
    top: 139.2vw;
    left: -1.3333333333vw;
    width: 41.3333333333vw;
  }
}
.is_mv_height_over .top-mv_letter {
  bottom: 3.7760416667vh;
  left: 26.953125vh;
  width: 28.125vh;
}
.top-mv_letter--inner {
  position: relative;
}
.top-mv_letter--inner .swiper-button-prev {
  width: auto;
  height: auto;
  top: auto;
  left: 5.6368960469vw;
  bottom: 1.1713030747vw;
  transition: 0.3s;
}
@media (max-width: 767px) {
  .top-mv_letter--inner .swiper-button-prev {
    left: 15.7333333333vw;
    bottom: 3.7333333333vw;
  }
}
.is_mv_height_over .top-mv_letter--inner .swiper-button-prev {
  left: 10.0260416667vh;
  bottom: 2.0833333333vh;
}
.top-mv_letter--inner .swiper-button-prev:after {
  color: #707070;
  font-size: 1.4641288433vw;
  padding: 0 0.7320644217vw;
}
@media (max-width: 767px) {
  .top-mv_letter--inner .swiper-button-prev:after {
    font-size: 2.6666666667vw;
    padding: 0 1.3333333333vw;
  }
}
.is_mv_height_over .top-mv_letter--inner .swiper-button-prev:after {
  font-size: 2.6041666667vh;
  padding: 0 1.3020833333vh;
}
.top-mv_letter--inner .swiper-button-prev:hover {
  transform: translateX(-0.2196193265vw);
}
@media (max-width: 767px) {
  .top-mv_letter--inner .swiper-button-prev:hover {
    transform: none;
  }
}
.is_mv_height_over .top-mv_letter--inner .swiper-button-prev:hover {
  transform: translateX(-0.390625vh);
}
.top-mv_letter--inner .swiper-button-next {
  width: auto;
  height: auto;
  top: auto;
  right: 5.6368960469vw;
  bottom: 1.1713030747vw;
  transition: 0.3s;
}
@media (max-width: 767px) {
  .top-mv_letter--inner .swiper-button-next {
    right: 15.7333333333vw;
    bottom: 3.7333333333vw;
  }
}
.is_mv_height_over .top-mv_letter--inner .swiper-button-next {
  right: 10.0260416667vh;
  bottom: 2.0833333333vh;
}
.top-mv_letter--inner .swiper-button-next:after {
  color: #707070;
  font-size: 1.4641288433vw;
  padding: 0 0.7320644217vw;
}
@media (max-width: 767px) {
  .top-mv_letter--inner .swiper-button-next:after {
    font-size: 2.6666666667vw;
    padding: 0 1.3333333333vw;
  }
}
.is_mv_height_over .top-mv_letter--inner .swiper-button-next:after {
  font-size: 2.6041666667vh;
  padding: 0 1.3020833333vh;
}
.top-mv_letter--inner .swiper-button-next:hover {
  transform: translateX(0.2196193265vw);
}
@media (max-width: 767px) {
  .top-mv_letter--inner .swiper-button-next:hover {
    transform: none;
  }
}
.is_mv_height_over .top-mv_letter--inner .swiper-button-next:hover {
  transform: translateX(0.390625vh);
}
.top-mv_letter--item {
  background-color: #fff;
  border-radius: 50%;
  overflow: hidden;
}
.top-mv_letter--link {
  display: block;
  width: 100%;
  aspect-ratio: 216/216;
  box-sizing: border-box;
  padding-top: 2.3426061493vw;
  position: relative;
  transition: opacity 0.3s;
}
@media (max-width: 767px) {
  .top-mv_letter--link {
    padding-top: 6.4vw;
  }
}
.is_mv_height_over .top-mv_letter--link {
  padding-top: 4.1666666667vh;
}
.top-mv_letter--link-brown {
  background-color: #CEC6C6;
}
.top-mv_letter--link-green {
  background-color: #C1DBBB;
}
.top-mv_letter--link-blue {
  background-color: #BCDFF0;
}
.top-mv_letter--link-yellow {
  background-color: #F7EDA9;
}
.top-mv_letter--link-yellow_green {
  background-color: #D6E3A0;
}
.top-mv_letter--link-pink {
  background-color: #F8D5CC;
}
.top-mv_letter--link:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../../img/top-mv-letter-item-before.png);
  background-position: 50% 50%;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  mix-blend-mode: soft-light;
  pointer-events: none;
}
.top-mv_letter--link:after {
  content: "";
  display: block;
  width: 10.9077598829vw;
  aspect-ratio: 149/42;
  background-image: url(../../img/top-mv-letter-item-after.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  position: absolute;
  top: 0.7320644217vw;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  .top-mv_letter--link:after {
    width: 28.5333333333vw;
    top: 2.1333333333vw;
  }
}
.is_mv_height_over .top-mv_letter--link:after {
  width: 19.4010416667vh;
  top: 1.3020833333vh;
}
.top-mv_letter--link:hover {
  opacity: 0.9;
}
@media (max-width: 767px) {
  .top-mv_letter--link:hover {
    opacity: 1;
  }
}
.top-mv_letter--cat {
  font-family: "Marcellus", serif;
  font-size: 1.0248901903vw;
  line-height: 1.2857142857;
  text-align: center;
  color: #707070;
  height: 3.074670571vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (max-width: 767px) {
  .top-mv_letter--cat {
    font-size: 2.9333333333vw;
    line-height: 1.2727272727;
    height: 9.0666666667vw;
  }
}
.is_mv_height_over .top-mv_letter--cat {
  font-size: 1.8229166667vh;
  height: 5.46875vh;
}
.top-mv_letter--ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.0248901903vw;
  letter-spacing: 0.1em;
  line-height: 1.5714285714;
  text-align: center;
}
@media (max-width: 767px) {
  .top-mv_letter--ttl {
    font-size: 2.9333333333vw;
    line-height: 1.4545454545;
  }
}
.is_mv_height_over .top-mv_letter--ttl {
  font-size: 1.8229166667vh;
}

.top-article {
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
@media (max-width: 767px) {
  .top-article {
    display: block;
  }
}
.top-article:nth-of-type(2n) {
  flex-direction: row-reverse;
}
.top-article:nth-of-type(2n) .top-article--wrap-more {
  width: 36.0907759883vw;
}
@media (max-width: 767px) {
  .top-article:nth-of-type(2n) .top-article--wrap-more {
    width: 100%;
  }
}
.top-article:nth-of-type(2n) .top-article_more {
  margin-right: 6.3689604685vw;
}
@media (max-width: 767px) {
  .top-article:nth-of-type(2n) .top-article_more {
    margin-right: auto;
  }
}
.top-article:nth-of-type(2n) .top-article--wrap-content {
  width: 63.9092240117vw;
  padding-left: 14.6412884334vw;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .top-article:nth-of-type(2n) .top-article--wrap-content {
    width: 100%;
    padding-left: 0;
  }
}
.top-article-column {
  padding-top: 17.2035139092vw;
}
@media (max-width: 767px) {
  .top-article-column {
    padding-top: 57.6vw;
  }
}
.top-article-exercise {
  padding-top: 22.9868228404vw;
}
@media (max-width: 767px) {
  .top-article-exercise {
    padding-top: 74.6666666667vw;
  }
}
.top-article-qa {
  padding-top: 17.8623718887vw;
}
@media (max-width: 767px) {
  .top-article-qa {
    padding-top: 50.1333333333vw;
  }
}
.top-article--wrap {
  width: 50%;
}
@media (max-width: 767px) {
  .top-article--wrap {
    width: 100%;
  }
}
.top-article--wrap-content {
  margin-top: auto;
}
@media (max-width: 767px) {
  .top-article--wrap-content {
    margin-top: 17.6vw;
  }
}
.top-article--desc {
  font-size: 1.1713030747vw;
  line-height: 2.5em;
}
@media (max-width: 767px) {
  .top-article--desc {
    font-size: 3.7333333333vw;
    line-height: 2.1428571429em;
    text-align: center;
  }
}
@media (max-width: 767px) {
  .top-article--list_wrap {
    padding-left: 12vw;
    padding-right: 12vw;
  }
}

.top-article_more {
  width: 20.2049780381vw;
  aspect-ratio: 276/408;
  margin-left: auto;
  margin-right: 10.102489019vw;
  position: relative;
}
@media (max-width: 767px) {
  .top-article_more {
    width: 73.6vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.top-article_more:before {
  content: "";
  display: block;
  width: auto;
  height: 101%;
  aspect-ratio: 138/407;
  background-image: url(../../img/top-article-more-left.svg);
  background-size: contain;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  position: absolute;
  left: -4%;
  bottom: -0.5%;
  z-index: 100;
  transition: 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transform-origin: left;
}
@media (max-width: 767px) {
  .top-article_more:before {
    height: 100.5%;
  }
}
.top-article_more:after {
  content: "";
  display: block;
  width: auto;
  height: 101%;
  aspect-ratio: 138/407;
  background-image: url(../../img/top-article-more-right.svg);
  background-size: contain;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  position: absolute;
  right: -4%;
  bottom: -0.5%;
  z-index: 100;
  transition: 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transform-origin: right;
}
@media (max-width: 767px) {
  .top-article_more:after {
    height: 100.5%;
  }
}
.top-article_more.is_show:before {
  left: 0;
  transform: rotateY(180deg);
  z-index: 102;
}
.top-article_more.is_show:after {
  right: 0;
  transform: rotateY(180deg);
  z-index: 102;
}
.top-article_more--link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  position: relative;
  background-position: 50% 100%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.top-article_more--link:before {
  content: "";
  width: 21.6691068814vw;
  aspect-ratio: 592/816;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  background-image: url(../../img/top-article-more-link.png);
  background-size: contain;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  mix-blend-mode: soft-light;
  z-index: 101;
  transition: 1.5s;
}
@media (max-width: 767px) {
  .top-article_more--link:before {
    width: 78.9333333333vw;
  }
}
.top-article_more--link:after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: contain;
  z-index: 102;
}
.top-article_more--link:hover .top-article_more--txt {
  transform: scale(1.05);
}
@media (max-width: 767px) {
  .top-article_more--link:hover .top-article_more--txt {
    transform: none;
  }
}
.top-article_more--link-column {
  background-image: url(../../img/top-article-more-link-column-bg.svg);
}
.top-article_more--link-column:after {
  width: 30.8931185944vw;
  aspect-ratio: 422/209;
  background-image: url(../../img/top-article-more-link-column-txt.svg);
  top: -12.9575402635vw;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  .top-article_more--link-column:after {
    width: 88.2666666667vw;
    top: -37.6vw;
  }
}
.top-article_more--link-exercise {
  background-image: url(../../img/top-article-more-link-exercise-bg.svg);
}
.top-article_more--link-exercise:after {
  width: 32.2840409956vw;
  aspect-ratio: 441/232;
  background-image: url(../../img/top-article-more-link-exercise-txt.svg);
  top: -11.420204978vw;
  left: -12.4450951684vw;
}
@media (max-width: 767px) {
  .top-article_more--link-exercise:after {
    width: 89.0666666667vw;
    top: -35.7333333333vw;
    left: -5.3333333333vw;
  }
}
.top-article_more--link-qa {
  background-image: url(../../img/top-article-more-link-qa-bg.svg);
}
.top-article_more--link-qa:after {
  width: 29.7950219619vw;
  aspect-ratio: 407/221;
  background-image: url(../../img/top-article-more-link-qa-txt.svg);
  top: -9.4436310395vw;
  left: -8.345534407vw;
}
@media (max-width: 767px) {
  .top-article_more--link-qa:after {
    width: 84.2666666667vw;
    top: -35.2vw;
    left: -8.5333333333vw;
  }
}
.top-article_more--txt {
  writing-mode: vertical-rl;
  text-orientation: upright;
  color: #455D74;
  font-size: 1.317715959vw;
  letter-spacing: 0.24em;
  font-weight: 700;
  transition: 0.3s;
  opacity: 0;
}
@media (max-width: 767px) {
  .top-article_more--txt {
    font-size: 4.8vw;
  }
}
.is_show .top-article_more--txt {
  opacity: 1;
}
.top-article_more--en {
  font-weight: 600;
  color: #fff;
  font-size: 1.1713030747vw;
  letter-spacing: 0.1em;
  line-height: 1.875em;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 2.1229868228vw;
  transition: 0.3s;
  opacity: 0;
}
@media (max-width: 767px) {
  .top-article_more--en {
    font-size: 4.2666666667vw;
    bottom: 7.7333333333vw;
  }
}
.is_show .top-article_more--en {
  opacity: 1;
}

.top-article_list {
  margin-top: 4.1727672035vw;
  width: 100%;
}
@media (max-width: 767px) {
  .top-article_list {
    margin-top: 11.4666666667vw;
  }
}
.top-article_list.swiper {
  padding-top: 0.3660322108vw;
  padding-left: 0.5856515373vw;
  margin-left: -0.5856515373vw;
}
@media (max-width: 767px) {
  .top-article_list.swiper {
    padding-top: 0;
    padding-left: 0;
    margin-left: 0;
    overflow: visible;
  }
}
.top-article_list .swiper-slide {
  width: 20.4978038067vw;
  margin-right: 2.3426061493vw;
  position: relative;
}
@media (max-width: 767px) {
  .top-article_list .swiper-slide {
    width: 74.6666666667vw;
    margin-right: 8.5333333333vw;
  }
}
.top-article_list--item {
  box-sizing: border-box;
}
.top-article_list--item.empty {
  aspect-ratio: 280/242;
  border: 0.0732064422vw solid #fff;
  background-image: url(../../img/empty.jpg);
  background-position: 50% 50%;
  background-size: cover;
  border-radius: 1.4641288433vw;
}
@media (max-width: 767px) {
  .top-article_list--item.empty {
    border-width: 0.2666666667vw;
    border-radius: 5.3333333333vw;
  }
}
.top-article_list--new {
  background-color: #EB6D9A;
  border-radius: 0.2196193265vw;
  width: 4.4655929722vw;
  line-height: 2.196193265vw;
  color: #fff;
  font-family: "Marcellus", serif;
  font-size: 1.1713030747vw;
  position: absolute;
  top: -0.3660322108vw;
  left: -0.5856515373vw;
  z-index: 100;
  text-align: center;
  padding-top: 0.05em;
  pointer-events: none;
}
@media (max-width: 767px) {
  .top-article_list--new {
    border-radius: 0.8vw;
    width: 16.2666666667vw;
    line-height: 8vw;
    font-size: 4.2666666667vw;
    top: -1.3333333333vw;
    left: -2.1333333333vw;
  }
}
.top-article_list--new:before {
  content: "";
  display: block;
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  width: 0.7320644217vw;
  aspect-ratio: 10/8;
  background-color: #EB6D9A;
  position: absolute;
  bottom: -0.5124450952vw;
  right: 0.8052708638vw;
}
@media (max-width: 767px) {
  .top-article_list--new:before {
    width: 2.6666666667vw;
    bottom: -1.8666666667vw;
    right: 2.9333333333vw;
  }
}
.top-article_list--link {
  display: block;
  width: 100%;
  background-color: #fff;
  aspect-ratio: 280/242;
  border-radius: 1.4641288433vw;
  overflow: hidden;
}
@media (max-width: 767px) {
  .top-article_list--link {
    border-radius: 5.3333333333vw;
  }
}
.top-article_list--link:hover .top-article_list--img {
  transform: scale(1.1);
}
@media (max-width: 767px) {
  .top-article_list--link:hover .top-article_list--img {
    transform: none;
  }
}
.top-article_list--img_wrap {
  width: 100%;
  aspect-ratio: 280/177;
  overflow: hidden;
}
.top-article_list--img {
  display: block;
  width: 100%;
  transition: 0.3s;
}
.top-article_list--txt {
  padding: 0.7320644217vw 1.6837481698vw 1.0248901903vw;
  height: calc(100% - 12.9575402635vw);
  box-sizing: border-box;
  display: flex;
  align-items: center;
}
@media (max-width: 767px) {
  .top-article_list--txt {
    padding: 2.6666666667vw 6.1333333333vw 3.7333333333vw;
    height: calc(100% - 47.2vw);
  }
}
.top-article_list--txt_inner {
  font-size: 1.0248901903vw;
  color: #404040;
  line-height: 1.4285714286;
}
@media (max-width: 767px) {
  .top-article_list--txt_inner {
    font-size: 3.7333333333vw;
    line-height: 1.4285714286;
  }
}

.top-comming {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  margin-top: 19.4729136164vw;
}
@media (max-width: 767px) {
  .top-comming {
    display: block;
    margin-top: 39.2vw;
  }
}

.top-comming_more {
  width: 20.2049780381vw;
  aspect-ratio: 276/408;
  position: relative;
  margin-right: 17.5695461201vw;
}
@media (max-width: 767px) {
  .top-comming_more {
    width: 73.6vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.top-comming_more:last-of-type {
  margin-right: 0;
}
@media (max-width: 767px) {
  .top-comming_more:last-of-type {
    margin-right: auto;
    margin-top: 32.8vw;
  }
}
.top-comming_more:before {
  content: "";
  display: block;
  width: auto;
  height: 101%;
  aspect-ratio: 138/407;
  background-image: url(../../img/top-article-more-left.svg);
  background-size: contain;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  position: absolute;
  left: -4%;
  bottom: -0.5%;
  z-index: 100;
  transition: 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transform-origin: left;
}
@media (max-width: 767px) {
  .top-comming_more:before {
    height: 100.5%;
  }
}
.top-comming_more:after {
  content: "";
  display: block;
  width: auto;
  height: 101%;
  aspect-ratio: 138/407;
  background-image: url(../../img/top-article-more-right.svg);
  background-size: contain;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  position: absolute;
  right: -4%;
  bottom: -0.5%;
  z-index: 100;
  transition: 1.2s cubic-bezier(0.33, 1, 0.68, 1);
  transform-origin: right;
}
@media (max-width: 767px) {
  .top-comming_more:after {
    height: 100.5%;
  }
}
.top-comming_more:hover:before {
  left: 0;
  transform: rotateY(180deg);
  z-index: 102;
}
.top-comming_more:hover:after {
  right: 0;
  transform: rotateY(180deg);
  z-index: 102;
}
.top-comming_more:hover .top-comming_more--txt,
.top-comming_more:hover .top-comming_more--en {
  opacity: 1;
}
.top-comming_more--link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  position: relative;
  background-position: 50% 100%;
  background-repeat: no-repeat;
  background-size: 100% auto;
  pointer-events: none;
}
.top-comming_more--link:before {
  content: "";
  width: 21.6691068814vw;
  aspect-ratio: 592/816;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  background-image: url(../../img/top-article-more-link.png);
  background-size: contain;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  mix-blend-mode: soft-light;
  z-index: 101;
  transition: 1.5s;
}
@media (max-width: 767px) {
  .top-comming_more--link:before {
    width: 78.9333333333vw;
  }
}
.top-comming_more--link:after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: contain;
  z-index: 102;
}
.top-comming_more--link-talk {
  background-image: url(../../img/top-article-more-link-talk-bg.svg);
}
.top-comming_more--link-talk:after {
  width: 9.4436310395vw;
  aspect-ratio: 129/90;
  background-image: url(../../img/top-article-more-link-talk-txt.svg);
  top: -4.0263543192vw;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  .top-comming_more--link-talk:after {
    width: 30.1333333333vw;
    top: -12vw;
  }
}
.top-comming_more--link-interview {
  background-image: url(../../img/top-article-more-link-interview-bg.svg);
}
.top-comming_more--link-interview:after {
  width: 19.2532942899vw;
  aspect-ratio: 263/134;
  background-image: url(../../img/top-article-more-link-interview-txt.svg);
  top: -6.2225475842vw;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  .top-comming_more--link-interview:after {
    width: 61.3333333333vw;
    top: -19.2vw;
  }
}
.top-comming_more--txt {
  writing-mode: vertical-rl;
  text-orientation: upright;
  color: #455D74;
  font-size: 1.317715959vw;
  letter-spacing: 0.24em;
  font-weight: 700;
  transition: 0.3s;
  opacity: 0;
}
@media (max-width: 767px) {
  .top-comming_more--txt {
    font-size: 4.8vw;
  }
}
.top-comming_more--en {
  font-weight: 600;
  color: #fff;
  font-size: 1.1713030747vw;
  letter-spacing: 0.1em;
  line-height: 1.875em;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 2.1229868228vw;
  transition: 0.3s;
  opacity: 0;
}
@media (max-width: 767px) {
  .top-comming_more--en {
    font-size: 4.2666666667vw;
    bottom: 7.7333333333vw;
  }
}

.top-method {
  margin-top: 17.1303074671vw;
  margin-left: auto;
  width: 85.3587115666vw;
  padding-top: 14.055636896vw;
  padding-bottom: 14.5680819912vw;
  background-color: #fff;
  position: relative;
  padding-left: 11.7130307467vw;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 767px) {
  .top-method {
    margin-top: 79.4666666667vw;
    margin-left: 0;
    margin-right: 0;
    width: 100%;
    padding-top: 22.1333333333vw;
    padding-bottom: 27.2vw;
    padding-left: 0;
    display: block;
  }
}
.top-method--video_wrap {
  width: 56.8081991215vw;
  position: relative;
}
@media (max-width: 767px) {
  .top-method--video_wrap {
    margin-top: 12vw;
    width: 100%;
  }
}
.top-method--video {
  width: 100%;
}
.top-method--video_img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.3s;
}
.is_playing .top-method--video_img {
  opacity: 0;
}

.top-method_ttl {
  width: 42.4597364568vw;
  aspect-ratio: 580/211;
  position: absolute;
  right: 7.1742313324vw;
  top: -9.3704245974vw;
}
@media (max-width: 767px) {
  .top-method_ttl {
    width: 90.6666666667vw;
    aspect-ratio: 340/178;
    right: 50%;
    transform: translateX(50%);
    top: -30.9333333333vw;
  }
}
.top-method_ttl--img {
  width: 100%;
}

.top-method_desc {
  font-size: 1.4641288433vw;
  writing-mode: vertical-rl;
  letter-spacing: 0.32em;
  line-height: 1.6;
  text-align: center;
}
@media (max-width: 767px) {
  .top-method_desc {
    font-size: 5.3333333333vw;
    text-align: left;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}
.top-method_desc--txt {
  display: inline-block;
  margin-left: 2.3426061493vw;
}
@media (max-width: 767px) {
  .top-method_desc--txt {
    display: block;
    margin-left: 8.5333333333vw;
  }
}
@media (max-width: 767px) {
  .top-method_desc--txt:nth-of-type(2) {
    margin-top: 1.5em;
    height: 9.24em;
  }
}
.top-method_desc--txt:last-of-type {
  margin-left: 0;
  display: block;
}
@media (max-width: 767px) {
  .top-method_desc--txt:last-of-type {
    margin-top: 3em;
    height: 9.24em;
  }
}

.top-product {
  padding-top: 11.7130307467vw;
  position: relative;
}
@media (max-width: 767px) {
  .top-product {
    padding-top: 21.0666666667vw;
  }
}
.top-product:before {
  content: "";
  display: block;
  width: 18.0819912152vw;
  aspect-ratio: 247/119;
  background-image: url(../../img/top-gooditem.svg);
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 7.5402635432vw;
  left: 18.0819912152vw;
  z-index: 100;
}
@media (max-width: 767px) {
  .top-product:before {
    width: 54.9333333333vw;
    top: 8.5333333333vw;
    left: 8.8vw;
  }
}
.top-product .swiper-pagination {
  position: static;
  margin-top: 2.5622254758vw;
}
@media (max-width: 767px) {
  .top-product .swiper-pagination {
    margin-top: 7.7333333333vw;
  }
}
.top-product .swiper-pagination .swiper-pagination-bullet {
  width: 1.0248901903vw;
  height: auto;
  aspect-ratio: 1/1;
  border: 0.0732064422vw solid #CEC6C6;
  background-color: transparent;
  opacity: 1;
  margin-left: 0.439238653vw !important;
  margin-right: 0.439238653vw !important;
}
@media (max-width: 767px) {
  .top-product .swiper-pagination .swiper-pagination-bullet {
    width: 3.7333333333vw;
    border-width: 0.2666666667vw;
    margin-left: 1.6vw !important;
    margin-right: 1.6vw !important;
  }
}
.top-product .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: #CEC6C6;
}

.top-product_list--link {
  display: flex;
  width: 65.6661786237vw;
  margin: auto;
  aspect-ratio: 897/277;
  border-radius: 2.196193265vw;
  background-color: #fff;
  position: relative;
}
@media (max-width: 767px) {
  .top-product_list--link {
    border-radius: 5.3333333333vw;
    display: block;
    width: 84vw;
  }
}
.top-product_list--link:after {
  content: "More";
  display: block;
  font-family: "Marcellus", serif;
  font-size: 1.0248901903vw;
  line-height: 1.2142857143;
  color: #958383;
  position: absolute;
  right: 2.9282576867vw;
  bottom: 2.1229868228vw;
}
@media (max-width: 767px) {
  .top-product_list--link:after {
    font-size: 3.4666666667vw;
    line-height: 1.1538461538;
    right: 6.1333333333vw;
    bottom: 5.8666666667vw;
  }
}
.top-product_list--img {
  width: 29.9414348463vw;
  border-radius: 2.196193265vw 0 0 2.196193265vw;
}
@media (max-width: 767px) {
  .top-product_list--img {
    width: 100%;
    border-radius: 5.3333333333vw 5.3333333333vw 0 0;
  }
}
.top-product_list--txt {
  width: 35.7247437775vw;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: 4.39238653vw;
}
@media (max-width: 767px) {
  .top-product_list--txt {
    display: block;
    width: 70.4vw;
    padding-top: 12.8vw;
    height: 63.4666666667vw;
    box-sizing: border-box;
    padding-left: 0;
    margin-left: auto;
    margin-right: auto;
  }
}
.top-product_list--desc {
  font-size: 1.1713030747vw;
  letter-spacing: 0.1em;
  line-height: 1.875;
  margin-top: 1.4641288433vw;
}
@media (max-width: 767px) {
  .top-product_list--desc {
    font-size: 3.7333333333vw;
    margin-top: 4.2666666667vw;
  }
}

.top-product_ttl {
  display: flex;
  align-items: center;
}
.top-product_ttl-rupika {
  width: 15.2269399707vw;
}
@media (max-width: 767px) {
  .top-product_ttl-rupika {
    width: 42.9333333333vw;
  }
}
.top-product_ttl-lupetto {
  width: 16.7642752562vw;
}
@media (max-width: 767px) {
  .top-product_ttl-lupetto {
    width: 47.2vw;
  }
}
.top-product_ttl--img {
  width: 100%;
}

.top-happy {
  margin-top: 19.1800878477vw;
  background-color: #fff;
  width: 85.3587115666vw;
  padding: 8.8579795022vw 0 7.5402635432vw 14.6412884334vw;
  box-sizing: border-box;
  position: relative;
}
@media (max-width: 767px) {
  .top-happy {
    margin-top: 35.4666666667vw;
    width: 100%;
    padding: 29.3333333333vw 0 93.8666666667vw;
  }
}
.top-happy:before {
  content: "";
  display: block;
  width: 33.6749633968vw;
  aspect-ratio: 920/920;
  background-image: url(../../img/top-happy.jpg);
  background-size: cover;
  background-position: 50% 50%;
  position: absolute;
  top: -5.1976573939vw;
  right: -27.2327964861vw;
}
@media (max-width: 767px) {
  .top-happy:before {
    width: 103.2vw;
    top: auto;
    right: auto;
    bottom: -33.8666666667vw;
    left: 16vw;
  }
}
.top-happy--desc {
  font-size: 1.1713030747vw;
  text-align: center;
  line-height: 2.5;
}
@media (max-width: 767px) {
  .top-happy--desc {
    font-size: 3.7333333333vw;
    line-height: 2.1428571429;
  }
}
.top-happy .swiper-pagination {
  position: static;
  margin-top: 4.6120058565vw;
}
@media (max-width: 767px) {
  .top-happy .swiper-pagination {
    margin-top: 15.4666666667vw;
  }
}
.top-happy .swiper-pagination .swiper-pagination-bullet {
  width: 1.0248901903vw;
  height: auto;
  aspect-ratio: 1/1;
  border: 0.0732064422vw solid #CEC6C6;
  background-color: transparent;
  opacity: 1;
  margin-left: 0.439238653vw !important;
  margin-right: 0.439238653vw !important;
}
@media (max-width: 767px) {
  .top-happy .swiper-pagination .swiper-pagination-bullet {
    width: 3.7333333333vw;
    border-width: 0.2666666667vw;
    margin-left: 1.6vw !important;
    margin-right: 1.6vw !important;
  }
}
.top-happy .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: #CEC6C6;
}

.top-happy_ttl {
  width: 37.3352855051vw;
  aspect-ratio: 510/254;
  position: absolute;
  right: 17.4963396779vw;
  top: -6.2225475842vw;
}
@media (max-width: 767px) {
  .top-happy_ttl {
    width: 86.9333333333vw;
    aspect-ratio: 326/155;
    right: 50%;
    transform: translateX(50%);
    top: -18.4vw;
  }
}
.top-happy_ttl--img {
  width: 100%;
}

.top-happy_list {
  margin-top: 2.7818448023vw;
  margin-left: auto;
  margin-right: auto;
  width: 54.5387994143vw;
}
@media (max-width: 767px) {
  .top-happy_list {
    margin-top: 8.5333333333vw;
    width: 100%;
  }
}
.top-happy_list--item {
  width: 100%;
  aspect-ratio: 745/374;
}
@media (max-width: 767px) {
  .top-happy_list--item {
    aspect-ratio: 373/471;
  }
}
.top-happy_list--inner {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .top-happy_list--inner {
    display: block;
  }
}
.top-happy_list--img {
  display: block;
  width: 25.6222547584vw;
  aspect-ratio: 350/350;
  margin-right: 6.0029282577vw;
  object-fit: contain;
}
@media (max-width: 767px) {
  .top-happy_list--img {
    width: 85.3333333333vw;
    margin-right: 0;
    margin-top: 2.6666666667vw;
    margin-left: 5.3333333333vw;
  }
}
.top-happy_list--txt {
  width: 16.1054172767vw;
}
@media (max-width: 767px) {
  .top-happy_list--txt {
    width: 58.6666666667vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.top-happy_list--ttl {
  font-size: 1.317715959vw;
  font-weight: 700;
  line-height: 1.6666666667;
  color: #7E93A8;
  text-align: center;
}
@media (max-width: 767px) {
  .top-happy_list--ttl {
    font-size: 4.2666666667vw;
    line-height: 1.875;
    margin-top: 3.2vw;
  }
}
.top-happy_list--desc {
  font-size: 1.0980966325vw;
  line-height: 2;
  margin-top: 1.4641288433vw;
}
@media (max-width: 767px) {
  .top-happy_list--desc {
    font-size: 3.7333333333vw;
    margin-top: 5.3333333333vw;
  }
}

.top-post {
  margin-top: 17.5695461201vw;
  background-color: #fff;
  padding-top: 14.6412884334vw;
  padding-bottom: 11.7130307467vw;
}
@media (max-width: 767px) {
  .top-post {
    margin-top: 64vw;
    padding-top: 26.6666666667vw;
    padding-bottom: 0;
  }
}
.top-post--ttl {
  margin-top: 3.8067349927vw;
  font-size: 1.756954612vw;
  text-align: center;
  color: #958383;
  line-height: 1.5;
  font-weight: 400;
}
@media (max-width: 767px) {
  .top-post--ttl {
    margin-top: 16.2666666667vw;
    font-size: 4.2666666667vw;
    line-height: 1.5;
  }
}
.top-post--ttl:first-of-type {
  margin-top: 0;
}

.top-post_list {
  width: 45.2415812592vw;
  margin-top: 4.5387994143vw;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .top-post_list {
    width: 89.3333333333vw;
    margin-top: 11.4666666667vw;
  }
}
.top-post_list--item {
  transition: 0.3s;
}
.top-post_list--item:first-of-type .top-post_list--txt {
  padding-top: 0;
}
.top-post_list--txt {
  display: flex;
  align-items: flex-start;
  padding-top: 2.1229868228vw;
}
@media (max-width: 767px) {
  .top-post_list--txt {
    flex-wrap: wrap;
    padding-top: 7.2vw;
  }
}
.top-post_list--date {
  font-size: 1.0248901903vw;
  line-height: 1.5;
  width: 6.149341142vw;
}
@media (max-width: 767px) {
  .top-post_list--date {
    font-size: 3.7333333333vw;
    width: 22.4vw;
  }
}
.top-post_list--tag {
  width: 8.1259150805vw;
  display: block;
  text-align: center;
  color: #fff;
  font-family: "Marcellus", serif;
  font-size: 0.878477306vw;
  padding-top: 0.1464128843vw;
  padding-bottom: 0.1464128843vw;
  line-height: 1.3333333333;
  margin-right: 1.6837481698vw;
}
@media (max-width: 767px) {
  .top-post_list--tag {
    width: 29.6vw;
    font-size: 3.2vw;
    padding-top: 0.5333333333vw;
    padding-bottom: 0.5333333333vw;
    margin-right: 0;
  }
}
.top-post_list--tag-purple {
  background-color: #D38FC3;
}
.top-post_list--tag-green {
  background-color: #76BDC3;
}
.top-post_list--tag-blue {
  background-color: #87A9CB;
}
.top-post_list--tag-orange {
  background-color: #D5AE87;
}
.top-post_list--desc {
  font-size: 1.0248901903vw;
  line-height: 1.5;
  width: calc(100% - 15.9590043924vw);
}
@media (max-width: 767px) {
  .top-post_list--desc {
    margin-top: 2.9333333333vw;
    font-size: 3.7333333333vw;
    width: 100%;
  }
}
.top-post_list--link:hover {
  opacity: 0.7;
}
@media (max-width: 767px) {
  .top-post_list--link:hover {
    opacity: 1;
  }
}

.top-post_more {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 6.5153733529vw;
  aspect-ratio: 89/44;
  margin-top: 4.6120058565vw;
  margin-left: auto;
  margin-right: 25.5490483163vw;
  transition: 0.3s;
}
@media (max-width: 767px) {
  .top-post_more {
    width: 23.7333333333vw;
    margin-top: 4vw;
    margin-left: auto;
    margin-right: 6.1333333333vw;
  }
}
.top-post_more:after {
  content: "";
  display: block;
  width: auto;
  height: 100%;
  aspect-ratio: 44/44;
  border-radius: 50%;
  border: 0.0732064422vw solid #958383;
  box-sizing: border-box;
  background-image: url(../../img/icon/icon-arrow-brown.svg);
  background-size: 1.1713030747vw auto;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  transition: 0.3s;
}
@media (max-width: 767px) {
  .top-post_more:after {
    border-width: 0.2666666667vw;
    background-size: 4.2666666667vw auto;
  }
}
.top-post_more--txt {
  font-family: "Marcellus", serif;
  color: #958383;
  font-size: 1.0248901903vw;
}
@media (max-width: 767px) {
  .top-post_more--txt {
    font-size: 3.7333333333vw;
  }
}
.top-post_more:hover:after {
  background-color: #958383;
}
@media (max-width: 767px) {
  .top-post_more:hover:after {
    background-color: transparent;
  }
}
.top-post_more:hover:after {
  background-image: url(../../img/icon/icon-arrow-white.svg);
}
@media (max-width: 767px) {
  .top-post_more:hover:after {
    background-image: url(../../img/icon/icon-arrow-brown.svg);
  }
}

.top-profile {
  padding-bottom: 16.9106881406vw;
  background-color: #fff;
  position: relative;
}
@media (max-width: 767px) {
  .top-profile {
    padding-top: 14.4vw;
    padding-bottom: 39.4666666667vw;
    margin-top: -0.2666666667vw;
  }
}
.top-profile--img {
  display: block;
  width: 48.9019033675vw;
  aspect-ratio: 1336/982;
  position: absolute;
  top: 18.3016105417vw;
  left: 17.5695461201vw;
}
@media (max-width: 767px) {
  .top-profile--img {
    position: static;
    width: 100%;
    aspect-ratio: auto;
    margin-top: 9.0666666667vw;
  }
}

.top-profile_ttl--img {
  display: block;
  width: 19.0336749634vw;
  aspect-ratio: 260/174;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .top-profile_ttl--img {
    width: 44.5333333333vw;
  }
}
.top-profile_ttl--txt {
  font-size: 1.317715959vw;
  margin-top: -0.878477306vw;
  font-weight: 400;
  display: block;
  text-align: center;
}
@media (max-width: 767px) {
  .top-profile_ttl--txt {
    font-size: 4.2666666667vw;
    margin-top: -4vw;
  }
}

.top-profile_txt {
  width: 35.3587115666vw;
  box-sizing: border-box;
  padding: 4.39238653vw 3.7335285505vw 5.8565153734vw 4.2459736457vw;
  margin-top: 14.7144948755vw;
  margin-left: 50vw;
  background-color: #fff;
  position: relative;
}
@media (max-width: 767px) {
  .top-profile_txt {
    width: 89.3333333333vw;
    padding: 11.7333333333vw 4.5333333333vw 3.4666666667vw 6.1333333333vw;
    margin-top: -16.8vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.top-profile_txt--img {
  display: block;
  width: 7.1010248902vw;
  aspect-ratio: 97/28;
}
@media (max-width: 767px) {
  .top-profile_txt--img {
    width: 18.4vw;
  }
}
.top-profile_txt--desc {
  font-size: 1.0248901903vw;
  line-height: 2.1428571429;
  margin-top: 2.5622254758vw;
}
@media (max-width: 767px) {
  .top-profile_txt--desc {
    font-size: 3.7333333333vw;
    margin-top: 9.3333333333vw;
  }
}

.top-profile_name {
  margin-top: 2.4890190337vw;
  display: flex;
  align-items: center;
}
@media (max-width: 767px) {
  .top-profile_name {
    margin-top: 9.6vw;
  }
}
.top-profile_name--post {
  font-size: 1.1713030747vw;
  line-height: 1.5;
  margin-right: 1.4641288433vw;
}
@media (max-width: 767px) {
  .top-profile_name--post {
    font-size: 3.7333333333vw;
    line-height: 1.5;
    margin-right: 5.3333333333vw;
  }
}
.top-profile_name--txt {
  font-size: 1.4641288433vw;
  line-height: 1.45;
}
@media (max-width: 767px) {
  .top-profile_name--txt {
    font-size: 5.3333333333vw;
  }
}

.top-profile_book {
  margin-top: 3.4407027818vw;
  border-top: 0.0732064422vw solid #E2E9F0;
  border-bottom: 0.0732064422vw solid #E2E9F0;
  width: 43.1918008785vw;
  margin-left: auto;
  margin-right: auto;
  padding-top: 3.3674963397vw;
  padding-bottom: 3.3674963397vw;
  padding-left: 14.6412884334vw;
  position: relative;
  box-sizing: border-box;
}
@media (max-width: 767px) {
  .top-profile_book {
    margin-top: 77.8666666667vw;
    border-width: 0.2666666667vw;
    width: 89.3333333333vw;
    padding-top: 12.2666666667vw;
    padding-bottom: 12.2666666667vw;
    padding-left: 16vw;
  }
}
.top-profile_book--img {
  display: block;
  width: 14.2752562225vw;
  aspect-ratio: 390/520;
  position: absolute;
  top: -5.9297218155vw;
  left: -2.8550512445vw;
}
@media (max-width: 767px) {
  .top-profile_book--img {
    width: 52vw;
    top: -63.4666666667vw;
    left: 50%;
    transform: translateX(-50%);
  }
}
.top-profile_book--ttl {
  font-weight: 500;
  font-size: 1.1713030747vw;
  line-height: 1.5;
  color: #434343;
}
@media (max-width: 767px) {
  .top-profile_book--ttl {
    font-size: 4.2666666667vw;
  }
}
.top-profile_book--desc {
  font-size: 1.0248901903vw;
  line-height: 1.8571428571;
  color: #434343;
  margin-top: 1.5373352855vw;
}
@media (max-width: 767px) {
  .top-profile_book--desc {
    font-size: 3.7333333333vw;
    margin-top: 5.6vw;
  }
}
.top-profile_book--company {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.9516837482vw;
  line-height: 1.4615384615;
  color: #393939;
  margin-top: 1.6105417277vw;
}
@media (max-width: 767px) {
  .top-profile_book--company {
    font-size: 3.4666666667vw;
    margin-top: 5.8666666667vw;
  }
}

.top-contact {
  padding-bottom: 9.5168374817vw;
}
@media (max-width: 767px) {
  .top-contact {
    padding-bottom: 20.8vw;
  }
}
.top-contact:before {
  content: "";
  display: block;
  width: 100vw;
  aspect-ratio: 2732/758;
  background-image: url(../../img/top-contact.jpg);
  background-size: cover;
  background-position: 50% 50%;
}
@media (max-width: 767px) {
  .top-contact:before {
    width: 100%;
    aspect-ratio: 750/758;
    background-image: url(../../img/top-contact-sp.jpg);
  }
}
.top-contact--ttl {
  font-size: 1.317715959vw;
  line-height: 1.4444444444;
  text-align: center;
  margin-top: 5.8565153734vw;
  font-weight: 400;
  position: relative;
}
@media (max-width: 767px) {
  .top-contact--ttl {
    font-size: 4.2666666667vw;
    line-height: 1.5;
    margin-top: 13.8666666667vw;
  }
}
.top-contact--ttl:before {
  content: "";
  display: block;
  width: 21.3030746706vw;
  aspect-ratio: 291/149;
  background-image: url(../../img/top-contact-ttl.svg);
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: -12.5915080527vw;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  .top-contact--ttl:before {
    width: 52.2666666667vw;
    top: -28.5333333333vw;
  }
}
.top-contact--desc {
  font-size: 1.1713030747vw;
  text-align: center;
  margin-top: 3.3674963397vw;
  line-height: 2.5;
}
@media (max-width: 767px) {
  .top-contact--desc {
    font-size: 3.7333333333vw;
    margin-top: 8.5333333333vw;
    line-height: 2.1428571429;
  }
}

.top-contact_flow {
  padding-top: 5.7833089312vw;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 767px) {
  .top-contact_flow {
    padding-top: 18.4vw;
  }
}
.top-contact_flow--item {
  background-color: #CEC6C6;
  width: 11.7130307467vw;
  text-align: center;
  color: #fff;
  font-weight: 700;
  font-size: 1.1713030747vw;
  line-height: 1.5;
  padding-top: 0.5856515373vw;
  padding-bottom: 0.5856515373vw;
  margin-right: 3.6603221083vw;
  position: relative;
}
@media (max-width: 767px) {
  .top-contact_flow--item {
    width: 21.3333333333vw;
    font-size: 3.7333333333vw;
    line-height: 1.5;
    padding-top: 2.6666666667vw;
    padding-bottom: 2.6666666667vw;
    margin-right: 10.6666666667vw;
  }
}
.top-contact_flow--item:after {
  content: "";
  display: block;
  width: 1.0980966325vw;
  aspect-ratio: 15/21;
  background-image: url(../../img/icon/icon-arrow-brown2.svg);
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: -2.4890190337vw;
  transform: translateY(-50%);
}
@media (max-width: 767px) {
  .top-contact_flow--item:after {
    width: 3.7333333333vw;
    right: -7.2vw;
  }
}
.top-contact_flow--item:last-of-type {
  margin-right: 0;
}
.top-contact_flow--item:last-of-type:after {
  content: none;
}
.top-contact_flow--item.input {
  background-color: #958383;
}
.is_form_confirm .top-contact_flow--item.input {
  background-color: #CEC6C6;
}
.is_form_thanks .top-contact_flow--item.input {
  background-color: #CEC6C6;
}
.top-contact_flow--item.confirm {
  background-color: #958383;
}
.is_form_input .top-contact_flow--item.confirm {
  background-color: #CEC6C6;
}
.is_form_thanks .top-contact_flow--item.confirm {
  background-color: #CEC6C6;
}
.top-contact_flow--item.thanks {
  background-color: #958383;
}
.is_form_input .top-contact_flow--item.thanks {
  background-color: #CEC6C6;
}
.is_form_confirm .top-contact_flow--item.thanks {
  background-color: #CEC6C6;
}

/*# sourceMappingURL=top.css.map */
