/* =======================================================
keyframes
======================================================= */
@keyframes slideAnimeUpDown {
  0% {
    opacity: 0;
    transform: translateY(-100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideAnimeDownUp {
  0% {
    opacity: 0;
    transform: translateY(100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideLeftToRight {
  0% {
    opacity: 0;
    transform: translateX(-150%);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes slideRightToLeft {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-12.5rem);
  }
}
/* =======================================================
common
======================================================= */
.bl-head-logo.--scroll::after {
  width: min(calc(470 / 1680 * 100vw), 470px);
  height: min(calc(470 / 1680 * 100vw), 470px);
}
.bl-head-logo.--scroll .bl-head-logo-link {
  top: min(calc(26 / 1680 * 100vw), 26px);
  left: min(calc(110 / 1680 * 100vw), 110px);
  width: min(calc(78 / 1680 * 100vw), 78px);
}
.bl-head-logo::after {
  position: absolute;
  top: max(calc(-488 / 1680 * 100vw), -488px);
  left: max(calc(-355 / 1680 * 100vw), -355px);
  width: min(calc(975 / 1680 * 100vw), 975px);
  height: min(calc(975 / 1680 * 100vw), 975px);
  content: "";
  background: var(--color-white);
  border-radius: 50%;
  transition: all 0.5s ease;
}
.bl-head-logo-link {
  position: absolute;
  top: min(calc(80 / 1680 * 100vw), 80px);
  left: min(calc(113 / 1680 * 100vw), 113px);
  z-index: 2;
  width: min(calc(242 / 1680 * 100vw), 242px);
  transition: all 0.5s ease;
}

@media screen and (min-width: 751px) {
  .bl-foot.--fixed-news .bl-pagetop {
    bottom: 4rem;
  }
  .bl-head {
    width: calc(100% - min(calc(40 / 1680 * 100vw), 40px) * 2);
    padding: min(calc(26 / 1680 * 100vw), 26px) 0;
  }
  .bl-head-btn {
    padding: min(calc(7 / 1680 * 100vw), 7px) min(calc(16 / 1680 * 100vw), 16px) min(calc(9 / 1680 * 100vw), 9px);
    font-size: min(calc(16 / 1680 * 100vw), 16px);
    border: min(calc(1 / 1680 * 100vw), 1px) solid var(--color-main);
  }
  .bl-head-btn-wrapper {
    gap: min(calc(24 / 1680 * 100vw), 24px);
    margin-bottom: min(calc(16 / 1680 * 100vw), 16px);
  }
  .bl-head-btn.--reservation {
    gap: min(calc(8 / 1680 * 100vw), 8px);
  }
  .bl-head-btn.--reservation::before {
    width: min(calc(22 / 1680 * 100vw), 22px);
    height: min(calc(15 / 1680 * 100vw), 15px);
    margin-top: min(calc(1 / 1680 * 100vw), 1px);
  }
  .bl-head-gnav {
    font-size: min(calc(18 / 1680 * 100vw), 18px);
  }
  .bl-head-gnav-list {
    gap: min(calc(32 / 1680 * 100vw), 32px);
  }
}
@media screen and (width <= 750px) {
  .ly-head.--scroll {
    transition-delay: 0.6s;
  }
  .bl-head-logo {
    position: absolute;
    top: 1.125rem;
    left: 1.875rem;
    z-index: 9999;
  }
  .bl-head-logo.--scroll {
    left: 0.625rem;
  }
  .bl-head-logo.--scroll::after {
    width: 18rem;
    height: 18rem;
  }
  .bl-head-logo.--scroll .bl-head-logo-link {
    top: 0;
    left: 0;
    width: 5.375rem;
  }
  .bl-head-logo::after {
    top: -23.625rem;
    left: -23.875rem;
    width: 45rem;
    height: 45rem;
  }
  .bl-head-logo-link {
    top: 1.5625rem;
    left: -1.25rem;
    width: 12.125rem;
  }
  .bl-foot.--fixed-news .bl-pagetop {
    bottom: 9.5rem;
  }
}
.c-perspective {
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
  transition: background-position 0.1s linear;
}

/* =======================================================
top
======================================================= */
.ly-mv {
  padding-left: 9.375rem;
}

.bl-mv {
  position: relative;
  height: 60rem;
}
.bl-mv-slide {
  width: 100%;
  height: 100%;
}
.bl-mv-slide-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.bl-mv-slide::after {
  position: absolute;
  top: 0;
  left: 0;
  width: calc(100% + 12.5rem);
  height: 100%;
  content: "";
  background: center left/cover no-repeat;
}
.bl-mv-slide.--01::after {
  background-image: url("../images/top/mv-bg01.webp");
}
.bl-mv-slide.--02::after {
  background-image: url("../images/top/mv-bg02.webp");
}
.bl-mv-slide.--03::after {
  background-image: url("../images/top/mv-bg03.webp");
}
.bl-mv-slide.--04::after {
  background-image: url("../images/top/mv-bg04.webp");
}
.bl-mv-slide.--05::after {
  background-image: url("../images/top/mv-bg05.webp");
}
.bl-mv .swiper-slide-active.bl-mv-slide::after,
.bl-mv .swiper-slide-duplicate-active.bl-mv-slide::after,
.bl-mv .swiper-slide-prev.bl-mv-slide::after {
  animation: slideRightToLeft 20s linear 0s normal both;
}
.bl-mv-inner {
  position: relative;
  z-index: 4;
  width: calc(100% - 43.5rem);
  margin: 0 auto;
}
.bl-mv-hgroup {
  position: absolute;
  top: 6.125rem;
  right: 0;
  z-index: 2;
  display: flex;
  flex-direction: row-reverse;
}
.bl-mv-hgroup-txt {
  position: relative;
  width: 3.5rem;
  margin-left: 3rem;
}
.bl-mv-hgroup-txt::before {
  position: absolute;
  top: 0;
  left: -2.25rem;
  width: 1.5rem;
  height: 40.75rem;
  content: "";
  background: url("../images/top/mv-txt-deco.webp") top center/contain no-repeat;
}
.bl-mv-hgroup-ttl {
  display: flex;
  flex-direction: row-reverse;
  align-items: start;
}
.bl-mv-hgroup-ttl-deco {
  display: flex;
  overflow: hidden;
  opacity: 0;
  animation: slideAnimeUpDown 1.5s ease-in forwards;
}
.bl-mv-hgroup-ttl-deco > img {
  animation: slideAnimeDownUp 1.5s ease-in forwards;
}
.bl-mv-hgroup-ttl-deco.--01 {
  width: 6.5rem;
}
.bl-mv-hgroup-ttl-deco.--02 {
  width: 4.5rem;
  animation-delay: 1s;
}
.bl-mv-hgroup-ttl-deco.--02 > img {
  animation-delay: 1s;
}
.bl-mv-btn {
  position: absolute;
  top: 47.0625rem;
  right: 22.875rem;
  z-index: 3;
  grid-template-columns: 1.625rem 1fr;
  gap: 1rem;
  align-items: center;
  width: max-content;
  padding: 1rem 1.3125rem 1.125rem;
  font-size: 1.125rem;
  line-height: 1;
  background: var(--color-white);
  opacity: 0;
  transform: translateX(-300%);
  animation: slideLeftToRight 0.5s ease-in 3s forwards;
}
.bl-mv-btn::before {
  height: 1.625rem;
  content: "";
  background: url("../images/common/btn-arrow--white.svg") top center/contain no-repeat;
}
.bl-mv-line {
  position: absolute;
  bottom: 7.5rem;
  z-index: 3;
  width: 100%;
  height: 9rem;
}
.bl-mv-line .line {
  stroke-dasharray: 4000;
  stroke-dashoffset: -2000;
  animation: flowLine 4s linear infinite;
}
@keyframes flowLine {
  0% {
    opacity: 0;
    stroke-dashoffset: -2000;
  }
  5% {
    opacity: 1;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    stroke-dashoffset: 0;
  }
}
@keyframes flowLineSp {
  0% {
    opacity: 0;
    stroke-dashoffset: -4000;
  }
  5% {
    opacity: 1;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    stroke-dashoffset: 0;
  }
}

@media screen and (width <= 750px) {
  .ly-mv {
    padding-left: 2.5rem;
  }
  .bl-mv {
    height: 68.875rem;
    background: url("../images/top/mv-bg-sp.webp") top right/cover no-repeat;
  }
  .bl-mv-slide.--01::after {
    background-image: url("../images/top/mv-bg01-sp.webp");
  }
  .bl-mv-slide.--02::after {
    background-image: url("../images/top/mv-bg02-sp.webp");
  }
  .bl-mv-slide.--03::after {
    background-image: url("../images/top/mv-bg03-sp.webp");
  }
  .bl-mv-slide.--04::after {
    background-image: url("../images/top/mv-bg04-sp.webp");
  }
  .bl-mv-slide.--05::after {
    background-image: url("../images/top/mv-bg05-sp.webp");
  }
  .bl-mv-inner {
    width: calc(100% - 8rem);
  }
  .bl-mv-hgroup {
    top: 6.3125rem;
  }
  .bl-mv-btn {
    top: 51.375rem;
    right: 4.75rem;
    grid-template-columns: 2.25rem 1fr;
    padding: 1.125rem 1.5rem 1.375rem;
    font-size: 1.75rem;
    font-weight: 700;
  }
  .bl-mv-btn::before {
    height: 2.25rem;
  }
  .bl-mv-line {
    height: 15.4375rem;
  }
  .bl-mv-line .line {
    stroke-dasharray: 4000;
    stroke-dashoffset: 0;
    animation: flowLineSp 5s linear infinite;
  }
  @keyframes flowLineSp {
    0% {
      opacity: 0;
      stroke-dashoffset: 0;
    }
    30% {
      opacity: 1;
    }
    45% {
      opacity: 1;
    }
    100% {
      opacity: 0;
      stroke-dashoffset: -4000;
    }
  }
}
/* =======================================================
modelinfo
======================================================= */
.ly-modelinfo {
  padding: 7.125rem 0 5.25rem;
  background: var(--color-contrast);
}

.bl-modelinfo {
  display: flex;
  gap: 6.5rem;
  width: calc(100% - 12.5rem);
  margin-left: auto;
}
.bl-modelinfo-hgroup {
  display: flex;
  flex-direction: row-reverse;
  gap: 2rem;
  justify-self: start;
}
.bl-modelinfo-hgroup-ttl {
  position: relative;
  width: 6.625rem;
}
.bl-modelinfo-hgroup-ttl::before {
  position: absolute;
  top: 0;
  left: -1.5rem;
  width: 0.0625rem;
  height: 17.5rem;
  content: "";
  background: url("../images/top/modelinfo-ttl-deco.svg") top center/contain no-repeat;
}
.bl-modelinfo-hgroup-txt {
  width: 1rem;
}
.bl-modelinfo-box {
  width: 100%;
  padding-top: 3.0625rem;
  overflow: hidden;
}
.bl-modelinfo-slide {
  width: 30rem;
  height: auto;
  margin-right: 3rem;
  background: var(--color-white);
}
.bl-modelinfo-slide-wrapper {
  margin-bottom: 2.5rem;
}
.bl-modelinfo-slide.--new .bl-modelinfo-slide-link::before {
  position: absolute;
  top: -1rem;
  left: 2.5rem;
  z-index: 2;
  display: grid;
  place-content: center;
  width: 4.875rem;
  height: 4.875rem;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  color: var(--color-white);
  content: "NEW";
  background: var(--color-accent);
  border-radius: 50%;
}
.bl-modelinfo-slide-link {
  position: relative;
  display: block;
}
.bl-modelinfo-slide-link > img {
  position: absolute;
  width: 30rem;
  height: 8.6875rem;
  object-fit: cover;
}
.bl-modelinfo-slide-ttl {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: end;
  min-height: 8.6875rem;
  padding: 0 2.5rem 0.5rem;
  font-size: 2rem;
  font-weight: 400;
  color: var(--color-white);
}
.bl-modelinfo-slide-txt {
  padding: 1.5rem 2.5rem;
  font-weight: 500;
}
.bl-modelinfo-slide-pagination {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 1.5rem;
}
.bl-modelinfo-slide-btn {
  margin: 0 2.5rem 0 auto;
}
.bl-modelinfo-slide-btn-wrapper {
  max-width: 87.875rem;
}
.bl-modelinfo .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.bl-modelinfo .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0;
}
.bl-modelinfo .swiper-pagination-bullet {
  width: 0.75rem;
  height: 0.75rem;
  background: var(--color-white);
  opacity: 1;
}
.bl-modelinfo .swiper-pagination-bullet-active {
  background: var(--color-accent);
}

@media screen and (width <= 750px) {
  .ly-modelinfo {
    padding: 8rem 0;
    background: url("../images/top/modelinfo-bg-sp.webp") top center/cover no-repeat;
  }
  .bl-modelinfo {
    display: block;
    width: calc(100% - 3.75rem);
  }
  .bl-modelinfo-hgroup {
    display: grid;
    gap: 1.5625rem;
  }
  .bl-modelinfo-hgroup-ttl {
    width: 34.875rem;
  }
  .bl-modelinfo-hgroup-ttl::before {
    top: initial;
    bottom: -1rem;
    left: 0;
    width: 19.5625rem;
    height: 0.0625rem;
    background: url("../images/top/modelinfo-ttl-deco-sp.svg") top center/contain no-repeat;
  }
  .bl-modelinfo-hgroup-txt {
    width: 19.5625rem;
  }
  .bl-modelinfo-box {
    padding-top: 4rem;
  }
  .bl-modelinfo-slide {
    width: 28.875rem;
    margin-right: 1.375rem;
  }
  .bl-modelinfo-slide-wrapper {
    margin-bottom: 3.5rem;
  }
  .bl-modelinfo-slide.--new .bl-modelinfo-slide-link::before {
    width: 5.625rem;
    height: 5.625rem;
    font-size: 1.625rem;
  }
  .bl-modelinfo-slide-link > img {
    width: 28.875rem;
    height: 8.625rem;
  }
  .bl-modelinfo-slide-ttl {
    min-height: 8.625rem;
    padding: 0 2.5rem 1rem;
    font-size: 1.75rem;
  }
  .bl-modelinfo-slide-txt {
    padding: 1.125rem 2.5rem;
  }
  .bl-modelinfo-slide-pagination {
    display: none;
  }
  .bl-modelinfo-slide-btn {
    margin: 0 0 0 auto;
  }
  .bl-modelinfo-slide-btn-wrapper {
    max-width: calc(100% - 3.75rem);
    text-align: right;
  }
  .bl-modelinfo .swiper-pagination-bullet {
    width: 1.5rem;
    height: 1.5rem;
  }
}
/* =======================================================
news
======================================================= */
.ly-news {
  padding: 8rem 0;
  background: url("../images/top/news-bg.webp") center center/cover no-repeat;
}

.bl-news-box {
  display: grid;
  grid-template: "container hgroup";
  grid-template-columns: 1fr auto;
  gap: 8rem;
}
.bl-news-hgroup {
  display: flex;
  grid-area: hgroup;
  gap: 2rem;
  justify-self: start;
}
.bl-news-hgroup-ttl {
  position: relative;
  width: 6.625rem;
}
.bl-news-hgroup-ttl::before {
  position: absolute;
  top: 0;
  right: -1.5rem;
  width: 0.0625rem;
  height: 17.5rem;
  content: "";
  background: url("../images/top/modelinfo-ttl-deco.svg") top center/contain no-repeat;
}
.bl-news-hgroup-txt {
  width: 1rem;
}
.bl-news-container {
  grid-area: container;
}
.bl-news-container .c-post-ttl {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: center;
}
.bl-news-container .c-post-ttl::after {
  width: 2.875rem;
  height: 2.875rem;
  content: "";
  background: url("../images/common/circle-arrow.svg") top center/contain no-repeat;
}
.bl-news-btn {
  margin-left: 4rem;
}

@media screen and (width <= 750px) {
  .ly-news {
    padding: 8rem 0 6rem;
    background-image: url("../images/top/news-bg-sp.webp");
  }
  .bl-news-box {
    grid-template: "hgroup" "container";
    grid-template-columns: auto;
    gap: 3.5rem;
  }
  .bl-news-hgroup {
    flex-direction: column;
    gap: 1.5625rem;
    justify-self: end;
    margin-right: 2.25rem;
  }
  .bl-news-hgroup-ttl {
    width: 26.75rem;
  }
  .bl-news-hgroup-ttl::before {
    top: initial;
    right: initial;
    bottom: -1rem;
    left: 0;
    width: 23.875rem;
    height: 0.0625rem;
    background: url("../images/top/news-ttl-deco-sp.svg") top center/contain no-repeat;
  }
  .bl-news-hgroup-txt {
    width: 23.875rem;
  }
  .bl-news-container {
    grid-area: container;
  }
  .bl-news-container .c-post-ttl {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem;
    align-items: center;
  }
  .bl-news-container .c-post-ttl::after {
    width: 2.875rem;
    height: 2.875rem;
    content: "";
    background: url("../images/common/circle-arrow.svg") top center/contain no-repeat;
  }
  .bl-news-btn {
    margin-left: 1.875rem;
  }
}
/* =======================================================
modelhouse
======================================================= */
.ly-modelhouse {
  position: relative;
  padding: 8rem 0;
  background: var(--color-contrast);
}
.ly-modelhouse::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 100%;
  height: 11.625rem;
  content: "";
  background: linear-gradient(-180deg, #f9efeb 0%, white 100%);
  transform: translateX(-50%);
}
.ly-modelhouse .bl-manufacturer-select {
  width: 25rem;
}

.bl-modelhouse {
  position: relative;
  z-index: 2;
  max-width: 113rem;
  padding: 0 2.5rem;
  margin: 0 auto;
}
.bl-modelhouse-new {
  display: grid;
  grid-template-columns: 1fr 416px;
  width: calc((100% - 32px) / 2);
}
.bl-modelhouse-new-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
  width: 80rem;
  margin: 0 auto 6rem;
}
.bl-modelhouse-new .bl-new-box {
  display: grid;
  place-content: center;
  padding: 3rem 1rem;
  background: var(--color-accent03);
}
.bl-modelhouse-new .bl-new-box-imgwrapper {
  display: flex;
  width: 11rem;
  margin: 0 auto 0.75rem;
}
.bl-modelhouse-new .bl-new-box-manufacturer {
  margin-bottom: 0.75rem;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: calc(32/24);
  text-align: center;
}
.bl-modelhouse-new .bl-new-box-txt {
  font-size: 1rem;
  text-align: center;
}
.bl-modelhouse-new .bl-new-imgwrapper > img {
  height: 14.625rem;
  object-fit: cover;
}

@media screen and (width <= 750px) {
  .ly-modelhouse::after {
    height: 17.25rem;
  }
  .ly-modelhouse .bl-manufacturer-select {
    width: 100%;
  }
  .bl-modelhouse {
    padding: 0 1.875rem;
  }
  .bl-modelhouse-new {
    grid-template-columns: auto;
    width: calc((100% - 1.5rem) / 2);
  }
  .bl-modelhouse-new-wrapper {
    gap: 1.5rem;
    width: 100%;
    margin-bottom: 4rem;
  }
  .bl-modelhouse-new .bl-new-box {
    padding: 2.5rem 1rem;
  }
  .bl-modelhouse-new .bl-new-box-imgwrapper {
    margin-bottom: 0.5rem;
  }
  .bl-modelhouse-new .bl-new-box-manufacturer {
    margin-bottom: 0.5rem;
    font-size: 1.625rem;
  }
  .bl-modelhouse-new .bl-new-box-txt {
    font-size: 1.375rem;
  }
  .bl-modelhouse-new .bl-new-imgwrapper > img {
    height: 11.6875rem;
  }
}
/* =======================================================
recommendedevents
======================================================= */
.ly-recommendedevents {
  padding-bottom: 6rem;
  background: url("../images/top/recommendedevents-bg.webp") top center/cover no-repeat;
}
.ly-recommendedevents .c-btn {
  margin: 0 auto;
}
.ly-recommendedevents .c-recommendedevents .swiper-pagination-bullet {
  background: var(--color-white);
}
.ly-recommendedevents .c-recommendedevents .swiper-pagination-bullet-active {
  background: var(--color-accent);
}

@media screen and (width <= 750px) {
  .ly-recommendedevents {
    padding-bottom: 8rem;
    background: url("../images/top/recommendedevents-bg-sp.webp") top center/cover no-repeat;
  }
}
/* =======================================================
guide
======================================================= */
.ly-guide {
  padding: min(calc(96 / 1616 * 100vw), 96px) min(calc(40 / 1616 * 100vw), 40px) min(calc(128 / 1616 * 100vw), 128px);
  background: var(--color-contrast);
}

.bl-guide {
  width: min(calc(1536 / 1616 * 100vw), 1536px);
  padding-left: min(calc(48 / 1616 * 100vw), 48px);
  margin: 0 auto;
}
.bl-guide-box {
  display: grid;
  grid-template: "hgroup frame body";
  grid-template-columns: auto auto 1fr;
}
.bl-guide-hgroup {
  display: flex;
  flex-direction: row-reverse;
  grid-area: hgroup;
  gap: min(calc(32 / 1616 * 100vw), 32px);
  justify-self: start;
}
.bl-guide-hgroup-ttl {
  position: relative;
  width: min(calc(48 / 1616 * 100vw), 48px);
}
.bl-guide-hgroup-ttl::before {
  position: absolute;
  top: 0;
  left: max(calc(-16 / 1616 * 100vw), -16px);
  width: min(calc(1 / 1616 * 100vw), 1px);
  height: min(calc(440 / 1616 * 100vw), 440px);
  content: "";
  background: url("../images/top/guide-ttl-deco.svg") top center/contain no-repeat;
}
.bl-guide-hgroup-txt {
  width: min(calc(20 / 1616 * 100vw), 20px);
}
.bl-guide-frame {
  grid-area: frame;
  width: min(calc(730 / 1616 * 100vw), 730px);
  height: min(calc(444 / 1616 * 100vw), 444px);
  margin: min(calc(32 / 1616 * 100vw), 32px) 0 0 min(calc(104 / 1616 * 100vw), 104px);
  background-image: url("../images/top/guide-img01.webp");
}
.bl-guide-body {
  grid-area: body;
  margin: min(calc(134 / 1616 * 100vw), 134px) 0 0 min(calc(96 / 1616 * 100vw), 96px);
}
.bl-guide-body .bl-body-ttl {
  margin-bottom: min(calc(32 / 1616 * 100vw), 32px);
  font-size: min(calc(28 / 1616 * 100vw), 28px);
  font-weight: 400;
  line-height: calc(42/28);
  letter-spacing: 0.08em;
}
.bl-guide-body .bl-body-txt {
  margin-bottom: min(calc(32 / 1616 * 100vw), 32px);
  font-size: min(calc(17 / 1616 * 100vw), 17px);
  letter-spacing: 0.03em;
}

@media screen and (width <= 750px) {
  .ly-guide {
    padding: 6rem 0 4.5rem;
  }
  .bl-guide {
    width: 100%;
    padding-left: 3.875rem;
  }
  .bl-guide-box {
    display: grid;
    grid-template: "hgroup frame" "body body";
    grid-template-columns: auto 1fr;
  }
  .bl-guide-hgroup {
    gap: 1.375rem;
  }
  .bl-guide-hgroup-ttl {
    width: 2.375rem;
  }
  .bl-guide-hgroup-ttl::before {
    left: -0.875rem;
    width: 0.0625rem;
    height: 30.5rem;
    background: url("../images/top/guide-ttl-deco-sp.svg") top center/contain no-repeat;
  }
  .bl-guide-hgroup-txt {
    width: 1.4375rem;
  }
  .bl-guide-frame {
    width: 35.5rem;
    height: 19.875rem;
    margin: 2rem 0 0 2rem;
    background-image: url("../images/top/guide-img01-sp.webp");
  }
  .bl-guide-body {
    margin: 0;
    transform: translateY(-5rem);
  }
  .bl-guide-body .bl-body-ttl {
    margin: 0 3.75rem 2.5rem 0;
    font-size: 2.25rem;
    text-align: center;
  }
  .bl-guide-body .bl-body-txt {
    padding: 0 6.25rem 0 2.5rem;
    margin-bottom: 3.5rem;
    font-size: 1.75rem;
  }
  .bl-guide-body .bl-body-btn-wrapper {
    margin-right: 3.75rem;
    text-align: right;
  }
}
/* =======================================================
entry
======================================================= */
.ly-entry {
  padding: 8rem 0;
  background: url("../images/top/entry-bg.webp") top center/cover no-repeat;
}

.bl-entry {
  text-align: center;
}
.bl-entry-ttl {
  position: relative;
  display: inline-block;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  font-size: 2.5rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.08em;
}
.bl-entry-ttl::before, .bl-entry-ttl::after {
  position: absolute;
  bottom: 0;
  width: 50%;
  height: 0.0625rem;
  content: "";
}
.bl-entry-ttl::before {
  left: 0;
  background: var(--color-accent);
}
.bl-entry-ttl::after {
  right: 0;
  background: var(--color-main);
}
.bl-entry-txt {
  margin-bottom: 3rem;
}
.bl-entry-btn {
  margin: 0 auto;
}

@media screen and (width <= 750px) {
  .ly-entry {
    background: url("../images/top/entry-bg-sp.webp") top center/cover no-repeat;
  }
  .bl-entry-ttl {
    padding-bottom: 0.5rem;
    margin-bottom: 2rem;
    line-height: calc(47/40);
  }
  .bl-entry-txt {
    margin-bottom: 3.5rem;
  }
  .bl-entry-btn-wrapper {
    text-align: center;
  }
}
/* =======================================================
about
======================================================= */
.ly-about {
  padding: min(calc(128 / 1688 * 100vw), 128px) 0;
  background: var(--color-contrast) url("../images/top/about-bg.webp") bottom center/contain no-repeat;
}

.bl-about {
  max-width: min(calc(1688 / 1688 * 100vw), 1688px);
  padding: 0 min(calc(40 / 1688 * 100vw), 40px);
  margin: 0 auto;
}
.bl-about-box {
  display: grid;
  grid-template: "onlinegallery virtual" "useful useful";
  grid-template-columns: repeat(2, 1fr);
  column-gap: min(calc(56 / 1688 * 100vw), 56px);
}
.bl-about-container.--onlinegallery {
  display: flex;
  grid-area: onlinegallery;
  gap: min(calc(48 / 1688 * 100vw), 48px);
  margin-top: min(calc(128 / 1688 * 100vw), 128px);
}
.bl-about-container.--onlinegallery .bl-container-hgroup {
  flex-direction: row-reverse;
}
.bl-about-container.--onlinegallery .bl-container-hgroup-ttl::before {
  left: max(calc(-14 / 1688 * 100vw), -14px);
  width: min(calc(1 / 1688 * 100vw), 1px);
  height: min(calc(500 / 1688 * 100vw), 500px);
  background: url("../images/top/about-onlinegallery-ttl-deco.svg") top center/contain no-repeat;
}
.bl-about-container.--onlinegallery .bl-container-body {
  background-image: url("../images/top/about-onlinegallery-bg.webp");
}
.bl-about-container.--virtual {
  display: flex;
  flex-direction: row-reverse;
  grid-area: virtual;
  gap: min(calc(48 / 1688 * 100vw), 48px);
}
.bl-about-container.--virtual .bl-container-hgroup-ttl::before {
  right: max(calc(-13 / 1688 * 100vw), -13px);
  width: min(calc(1 / 1688 * 100vw), 1px);
  height: min(calc(396 / 1688 * 100vw), 396px);
  background: url("../images/top/about-virtual-ttl-deco.svg") top center/contain no-repeat;
}
.bl-about-container.--virtual .bl-container-body {
  background-image: url("../images/top/about-virtual-bg.webp");
}
.bl-about-container.--virtual .bl-container-txt {
  color: var(--color-white);
}
.bl-about-container.--useful {
  grid-area: useful;
  padding-left: min(calc(264 / 1688 * 100vw), 264px);
  margin-top: min(calc(176 / 1688 * 100vw), 176px);
}
.bl-about-container .bl-container-hgroup {
  display: flex;
  gap: min(calc(30 / 1688 * 100vw), 30px);
  justify-self: start;
}
.bl-about-container .bl-container-hgroup-ttl {
  position: relative;
  width: min(calc(40 / 1688 * 100vw), 40px);
}
.bl-about-container .bl-container-hgroup-ttl::before {
  position: absolute;
  top: 0;
  content: "";
}
.bl-about-container .bl-container-hgroup-txt {
  width: min(calc(18 / 1688 * 100vw), 18px);
}
.bl-about-container .bl-container-body {
  width: min(calc(640 / 1688 * 100vw), 640px);
  height: min(calc(546 / 1688 * 100vw), 546px);
  padding-top: min(calc(48 / 1688 * 100vw), 48px);
  margin-top: min(calc(48 / 1688 * 100vw), 48px);
}
.bl-about-container .bl-container-txt {
  margin-bottom: min(calc(24 / 1688 * 100vw), 24px);
  font-weight: 700;
  text-align: center;
}
.bl-about-container .bl-container-btn {
  margin: 0 auto;
}
.bl-about-container .bl-container-ttl {
  position: relative;
  display: inline-block;
  padding-bottom: min(calc(16 / 1688 * 100vw), 16px);
  margin-bottom: min(calc(16 / 1688 * 100vw), 16px);
  font-size: min(calc(40 / 1688 * 100vw), 40px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.08em;
}
.bl-about-container .bl-container-ttl::before, .bl-about-container .bl-container-ttl::after {
  position: absolute;
  bottom: 0;
  width: 50%;
  height: min(calc(1 / 1688 * 100vw), 1px);
  content: "";
}
.bl-about-container .bl-container-ttl::before {
  left: 0;
  background: var(--color-accent);
}
.bl-about-container .bl-container-ttl::after {
  right: 0;
  background: var(--color-main);
}
.bl-about-container .bl-container-link {
  display: flex;
  gap: min(calc(32 / 1688 * 100vw), 32px);
  align-items: center;
}
.bl-about-container .bl-container-link::after {
  width: min(calc(46 / 1688 * 100vw), 46px);
  height: min(calc(46 / 1688 * 100vw), 46px);
  content: "";
  background: url("../images/common/circle-arrow.svg") top center/contain no-repeat;
}

@media screen and (width <= 750px) {
  .ly-about {
    padding: 5.3125rem 0 8rem;
    background: var(--color-contrast) url("../images/top/about-bg-sp.webp") bottom center/cover no-repeat;
  }
  .bl-about {
    padding: 0;
  }
  .bl-about-box {
    grid-template: "onlinegallery" "virtual" "useful";
    grid-template-columns: auto;
  }
  .bl-about-container.--onlinegallery {
    gap: 1.5rem;
    margin-top: 0;
    margin-left: 1.875rem;
  }
  .bl-about-container.--onlinegallery .bl-container-hgroup-ttl::before {
    left: -0.875rem;
    width: 0.0625rem;
    height: 27.625rem;
    background: url("../images/top/about-onlinegallery-ttl-deco-sp.svg") top center/contain no-repeat;
  }
  .bl-about-container.--onlinegallery .bl-container-body {
    background: url("../images/top/about-onlinegallery-bg-sp.webp") top center/cover no-repeat;
  }
  .bl-about-container.--onlinegallery .bl-container-btn-wrapper {
    text-align: right;
  }
  .bl-about-container.--virtual {
    gap: 1.5rem;
    margin-top: 4rem;
    margin-right: 1.875rem;
  }
  .bl-about-container.--virtual .bl-container-hgroup-ttl::before {
    right: -0.8125rem;
    width: 0.125rem;
    height: 27.625rem;
    background: url("../images/top/about-virtual-ttl-deco-sp.svg") top center/contain no-repeat;
  }
  .bl-about-container.--virtual .bl-container-body {
    background: url("../images/top/about-virtual-bg-sp.webp") top center/cover no-repeat;
  }
  .bl-about-container.--virtual .bl-container-btn-wrapper {
    text-align: left;
  }
  .bl-about-container.--useful {
    padding-left: 0;
    margin: 8rem 0 0 3.75rem;
  }
  .bl-about-container .bl-container-hgroup {
    gap: 1.4375rem;
  }
  .bl-about-container .bl-container-hgroup-ttl {
    width: 2.375rem;
  }
  .bl-about-container .bl-container-hgroup-txt {
    width: 1.75rem;
  }
  .bl-about-container .bl-container-body {
    width: 37.5rem;
    height: 37.5rem;
    padding-top: 3rem;
    margin-top: 2.6875rem;
  }
  .bl-about-container .bl-container-txt {
    margin-bottom: 2.5rem;
  }
  .bl-about-container .bl-container-btn-wrapper {
    padding: 0 3.75rem;
  }
  .bl-about-container .bl-container-ttl {
    padding-bottom: 0.5rem;
    margin-bottom: 2rem;
    font-size: 2.5rem;
    line-height: calc(48/40);
  }
  .bl-about-container .bl-container-link {
    gap: 2rem;
  }
  .bl-about-container .bl-container-link::after {
    width: 2.875rem;
    height: 2.875rem;
  }
}
/* =======================================================
access
======================================================= */
.ly-access {
  padding: 8rem 0;
  background: var(--color-contrast03);
}

.bl-access-hgroup {
  margin-bottom: 3.5rem;
  line-height: 1;
  text-align: center;
  letter-spacing: 0.08em;
}
.bl-access-hgroup-ttl {
  margin-bottom: 1.5rem;
  font-size: 2.5rem;
  font-weight: 400;
}
.bl-access-hgroup-txt {
  position: relative;
  display: inline-block;
  padding-top: 0.5rem;
  font-size: 1.125rem;
}
.bl-access-hgroup-txt > span {
  position: relative;
}
.bl-access-hgroup-txt > span::before {
  position: absolute;
  top: -0.5rem;
  left: 0;
  width: 100%;
  height: 0.0625rem;
  content: "";
}
.bl-access-hgroup-txt > span.--deco01::before {
  background: var(--color-accent);
}
.bl-access-hgroup-txt > span.--deco02::before {
  background: var(--color-main);
}

@media screen and (width <= 750px) {
  .bl-access {
    padding: 0 3.75rem;
  }
  .bl-access-hgroup {
    margin-bottom: 4rem;
  }
  .bl-access-hgroup-ttl {
    margin-bottom: 1rem;
  }
  .bl-access-hgroup-txt {
    font-size: 1.25rem;
  }
}
/* =======================================================
fixed
======================================================= */
.bl-fixed {
  position: fixed;
  bottom: 0;
  left: 50%;
  z-index: 9000;
  width: 100%;
  max-width: 1024px;
  background: var(--color-white);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.0823529412);
  transform: translateX(-50%);
}
.bl-fixed-close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 9100;
  display: flex;
  width: 24px;
  height: 24px;
  transition: all 0.5s ease;
}
@media (hover: hover) {
  .bl-fixed-close:hover {
    opacity: 0.7;
  }
}
.bl-fixed .el-cat {
  padding: 5px 8px 7px;
  font-weight: 400;
}
.bl-fixed .c-post-link {
  padding: 13px 48px !important;
}
.bl-fixed .c-post-ttl-inner {
  text-decoration: underline;
}

@media screen and (width <= 750px) {
  .bl-fixed {
    bottom: 5rem;
  }
  .bl-fixed-close {
    width: 3.125rem;
    height: 3.125rem;
  }
  .bl-fixed .c-post-link {
    padding: 1.5rem 2rem !important;
  }
  .bl-fixed.--z-index {
    z-index: 1;
  }
}