/* src/styles/top.scss */
.top-floating-menu__banner-close-alt,
.top-news__close-text {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}
.top-first-visit {
  padding-top: 20px;
}
.top-first-visit__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 5px;
  line-height: 1;
}
.top-first-visit__title-text {
  font-size: 2rem;
  color: var(--COLOR_PRIMARY);
}
.top-first-visit__text {
  margin-top: var(--SPACING);
  text-align: center;
}
.top-first-visit__text-highlight {
  background: linear-gradient(transparent 60%, rgba(226, 174, 122, 0.3) 40%);
  font-weight: var(--FONT_WEIGHT_BOLD);
}
.top-first-visit__image {
  margin-top: var(--SPACING);
  text-align: center;
}
@media (width >= 768px) {
  .top-hero {
    position: relative;
    height: 640px;
    background: url(/assets/images/pages/top/hero-background-pc.jpg) no-repeat center/cover;
  }
}
@media (width >= 1280px) {
  .top-hero {
    height: auto;
    aspect-ratio: 2/1;
    background-size: contain;
  }
}
.top-hero__nav {
  display: none;
}
.top-hero__animation {
  position: absolute;
}
.top-hero__animation--car {
  top: 290px;
  left: 390px;
}
.top-news {
  position: fixed;
  top: var(--HEIGHT_HEADER);
  left: 0;
  z-index: var(--Z_INDEX_DRAWER_MENU);
  display: flex;
  flex-direction: column;
  width: 100%;
  height: calc(100% - var(--HEIGHT_HEADER));
  padding: 20px;
  background-color: var(--COLOR_BASE);
}
@media (width < 768px) {
  .top-news {
    translate: 0 100%;
    visibility: hidden;
    transition: translate var(--TRANSITION), visibility var(--TRANSITION);
  }
  .top-news.is-shown {
    translate: 0 0;
    visibility: visible;
  }
}
@media (width >= 768px) {
  .top-news {
    position: static;
    height: 560px;
    box-shadow: 0 -6px 14px rgba(0, 0, 0, 0.25);
  }
}
@media (width >= 1000px) {
  .top-news {
    position: absolute;
    inset: auto 10px 0 auto;
    width: 375px;
    height: 400px;
    padding-bottom: 0;
    border-radius: 10px 10px 0 0;
    visibility: hidden;
    opacity: 0;
    transition: opacity var(--TRANSITION), visibility var(--DURATION);
  }
  .top-news.is-shown {
    visibility: visible;
    opacity: 1;
  }
}
.top-news__heading {
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 10px;
  color: var(--COLOR_PRIMARY);
  font-size: 2rem;
}
.top-news__heading::before {
  content: "";
  width: 21px;
  height: 21px;
  background: url(/assets/images/common/icon-bell.svg) no-repeat center/contain;
}
.top-news__close {
  position: absolute;
  top: 5px;
  right: 5px;
  width: 44px;
  height: 44px;
}
.top-news__close::before,
.top-news__close::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 28px;
  height: 2px;
  background-color: var(--COLOR_PRIMARY);
  border-radius: 2px;
}
.top-news__close::before {
  rotate: 45deg;
}
.top-news__close::after {
  rotate: -45deg;
}
@media (width >= 768px) {
  .top-news__close {
    display: none;
  }
}
@media (width >= 1000px) {
  .top-news__close {
    display: block;
  }
}
.top-news__tabs {
  flex-grow: 1;
  flex-basis: 0;
  display: flex;
  flex-direction: column;
  row-gap: 20px;
  margin-top: 20px;
  overflow: hidden;
}
.top-news__tabs-list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
.top-news__tabs-tab {
  padding: 8px;
  background-color: var(--COLOR_BACKGROUND);
  border-radius: 5px;
  font-size: 1.2rem;
  color: var(--COLOR_PRIMARY);
}
.top-news__tabs-tab[aria-selected=true] {
  background-color: var(--COLOR_PRIMARY);
  color: var(--COLOR_BASE);
}
.top-news__tabs-content {
  flex: 1;
  overflow: auto;
}
.top-news__item {
  padding-block: 15px;
  border-bottom: 1px solid var(--COLOR_PRIMARY);
}
.top-news__item:first-child {
  padding-block-start: 0;
}
.top-news__link {
  position: relative;
  display: grid;
  align-items: center;
  padding-inline: 36px 21px;
  grid-template-columns: auto 1fr;
  column-gap: 5px;
  background-repeat: no-repeat;
  background-position: 0 center;
}
.top-news__link::after {
  content: "";
  position: absolute;
  inset: 0 0 0 auto;
  width: 15px;
  height: 15px;
  margin: auto;
  background-color: var(--COLOR_PRIMARY);
  mask: url(/assets/images/common/icon-chevron.svg) no-repeat center/contain;
  transition: background-color var(--TRANSITION);
}
.top-news__item[data-category=news] .top-news__link {
  background-image: url(/assets/images/pages/top/icon-news-1.svg);
}
.top-news__item[data-category=notice] .top-news__link {
  background-image: url(/assets/images/pages/top/icon-news-2.svg);
}
.top-news__item[data-latest] .top-news__link {
  font-weight: var(--FONT_WEIGHT_BOLD);
}
.top-news__category {
  grid-area: 1/1/2/2;
  padding: 3px 5px;
  background-color: var(--COLOR_BACKGROUND);
  border-radius: 5px;
  color: var(--COLOR_PRIMARY);
  font-size: 1.2rem;
  font-weight: var(--FONT_WEIGHT_BOLD);
}
.top-news__date {
  grid-area: 1/2/2/3;
  font-size: 1.2rem;
}
.top-news__text {
  grid-area: 2/1/3/3;
}
@keyframes floating {
  0% {
    transform: translateY(0);
  }
  25% {
    transform: translateY(3px);
  }
  75% {
    transform: translateY(-3px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.top-park {
  position: relative;
  margin-bottom: -15px;
  animation: 1.2s var(--EASING) forwards fade-in;
}
@media (width >= 768px) {
  .top-park {
    height: 640px;
    aspect-ratio: auto;
    margin-bottom: 0;
    overflow: hidden;
  }
}
@media (width >= 1000px) {
  .top-park {
    margin-bottom: -15px;
  }
}
@media (width >= 1280px) {
  .top-park {
    height: auto;
    aspect-ratio: 2/1;
  }
}
.top-park__nav-item {
  --color: none;
  --top: auto;
  --right: auto;
  --left: auto;
  --width: 220px;
  --delay: 0s;
  position: absolute;
  top: var(--top);
  right: var(--right);
  left: var(--left);
  width: var(--width);
  margin: auto;
  animation: 5s floating var(--delay) ease-in-out infinite;
}
.top-park__nav-item--variant-0 {
  --color: var(--COLOR_PRIMARY);
  --width: 210px;
  --top: 1.0685663402%;
  --left: 0;
  --right: 0;
}
@media (width >= 768px) {
  .top-park__nav-item--variant-0 {
    --top: 157px;
  }
}
@media (width >= 1280px) {
  .top-park__nav-item--variant-0 {
    --top: 24.53125%;
  }
}
@media (width >= 1920px) {
  .top-park__nav-item--variant-0 {
    --top: 31.25%;
  }
}
.top-park__nav-item--variant-1 {
  --color: var(--COLOR_ZONE_1_FOREGROUND);
  --top: 15.3606411398%;
  --left: 3.7333333333%;
  --delay: .2s;
}
@media (width >= 768px) {
  .top-park__nav-item--variant-1 {
    --top: 28px;
    --left: 57.2916666667%;
    --right: 0;
  }
}
@media (width >= 1280px) {
  .top-park__nav-item--variant-1 {
    --top: 4.375%;
    --left: 46.875%;
  }
}
@media (width >= 1920px) {
  .top-park__nav-item--variant-1 {
    --top: 8.3333333333%;
  }
}
.top-park__nav-item--variant-2 {
  --color: var(--COLOR_ZONE_2_FOREGROUND);
  --top: 30.5877114871%;
  --right: 3.7333333333%;
  --delay: .4s;
}
@media (width >= 768px) {
  .top-park__nav-item--variant-2 {
    --top: 282px;
    --left: 0;
    --right: 49.4791666667%;
  }
}
@media (width >= 1280px) {
  .top-park__nav-item--variant-2 {
    --top: 44.0625%;
    --right: 61.71875%;
  }
}
@media (width >= 1920px) {
  .top-park__nav-item--variant-2 {
    --top: 47.9166666667%;
  }
}
.top-park__nav-item--variant-3 {
  --color: var(--COLOR_ZONE_3_FOREGROUND);
  --top: 43.8557435441%;
  --left: 3.7333333333%;
  --delay: .6s;
}
@media (width >= 768px) {
  .top-park__nav-item--variant-3 {
    --top: 38px;
    --left: 0;
    --right: 24.7395833333%;
  }
}
@media (width >= 1280px) {
  .top-park__nav-item--variant-3 {
    --top: 5.9375%;
    --right: 34.375%;
  }
}
@media (width >= 1920px) {
  .top-park__nav-item--variant-3 {
    --top: 9.375%;
  }
}
.top-park__nav-item--variant-4 {
  --color: var(--COLOR_ZONE_4_FOREGROUND);
  --top: 57.7471059662%;
  --right: 3.7333333333%;
  --delay: .8s;
}
@media (width >= 768px) {
  .top-park__nav-item--variant-4 {
    --top: 320px;
    --left: 52.0833333333%;
    --right: 0;
  }
}
@media (width >= 1280px) {
  .top-park__nav-item--variant-4 {
    --top: 50%;
    --left: 40.625%;
  }
}
@media (width >= 1920px) {
  .top-park__nav-item--variant-4 {
    --top: 56.25%;
  }
}
.top-park__nav-item--variant-5 {
  --color: var(--COLOR_ZONE_5_FOREGROUND);
  --top: 71.4158504007%;
  --left: 3.7333333333%;
  --delay: 1s;
}
@media (width >= 768px) {
  .top-park__nav-item--variant-5 {
    --top: 181px;
    --left: 69.0104166667%;
    --right: 0;
  }
}
@media (width >= 1280px) {
  .top-park__nav-item--variant-5 {
    --top: 28.28125%;
    --left: 57.8125%;
  }
}
@media (width >= 1920px) {
  .top-park__nav-item--variant-5 {
    --top: 33.3333333333%;
  }
}
.top-park__nav-item--variant-6 {
  --color: var(--COLOR_ZONE_6_FOREGROUND);
  --width: 244px;
  --top: 86.5093499555%;
  --right: 3.7333333333%;
  --delay: 1.2s;
}
@media (width >= 768px) {
  .top-park__nav-item--variant-6 {
    --top: 418px;
    --left: 0;
    --right: 0;
  }
}
@media (width >= 1280px) {
  .top-park__nav-item--variant-6 {
    --top: 65.3125%;
  }
}
@media (width >= 1920px) {
  .top-park__nav-item--variant-6 {
    --top: 69.7916666667%;
  }
}
@media (width < 768px) {
  .top-park__nav-item {
    transition: scale var(--TRANSITION);
  }
  .top-park__nav-item.is-animating {
    scale: 1.1;
  }
}
@media (hover: hover) and (width >= 768px) {
  .top-park__nav-item {
    transition: scale var(--TRANSITION);
  }
  .top-park__nav-item:has(.top-park__nav-link:hover) {
    scale: 1.1;
  }
}
.top-park__nav-link {
  --border: 3px solid var(--color);
  display: block;
  border: var(--border);
  border-radius: 10px;
  text-align: center;
  overflow: hidden;
}
.top-park__nav-link::before {
  content: "";
  position: absolute;
  inset: auto 0 -4px 0;
  width: 32px;
  height: 32px;
  margin: auto;
  background-color: var(--COLOR_BASE);
  border: var(--border);
  border-radius: 2px;
  transform: rotate(45deg) skew(5deg, 5deg);
}
.top-park__nav-content {
  position: relative;
  display: flex;
  flex-direction: column;
  row-gap: 5px;
  background-color: var(--COLOR_BASE);
  padding: 12px 4px;
}
.top-park__nav-label {
  position: absolute;
  top: -22px;
  right: -13px;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 2px;
  width: 43px;
  height: 43px;
  background-color: var(--COLOR_PRIMARY);
  border: 2px solid var(--COLOR_BASE);
  border-radius: 50%;
  font-size: 1rem;
  font-weight: var(--FONT_WEIGHT_BOLD);
  color: var(--COLOR_BASE);
}
.top-park__nav-label::before,
.top-park__nav-label::after {
  content: "";
  width: 1px;
  height: 7px;
  background-color: var(--COLOR_BASE);
  border-radius: 1px;
}
.top-park__nav-label::before {
  rotate: -15deg;
}
.top-park__nav-label::after {
  rotate: 15deg;
}
.top-park__nav-title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 4px;
  width: fit-content;
  margin-inline: auto;
  color: var(--color);
  font-size: 1.6rem;
}
.top-park__nav-title::after {
  content: "";
  width: 10px;
  height: 10px;
  background-color: var(--color);
  mask: url(/assets/images/common/icon-chevron.svg) no-repeat center/contain;
}
.top-park__nav-text {
  color: #515151;
  font-size: 1rem;
}
@media (width < 768px) {
  .top-park-pc {
    display: none;
  }
}
@media (width >= 768px) {
  .top-park-pc {
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    aspect-ratio: 2/1;
    transform: translate(-50%, -50%);
    background: var(--background-park-pc) no-repeat center/cover;
  }
}
@media (width >= 768px) {
  .top-park-pc__objects {
    position: absolute;
    width: 100%;
  }
}
@media (width >= 768px) {
  .top-park-pc__object {
    position: relative;
  }
}
@media (width >= 768px) {
  .top-park-pc__sprite {
    background: var(--image-url) 0 0 no-repeat;
    width: var(--width);
    height: var(--height);
  }
}
@media (width < 768px) {
  .top-park-sp {
    position: relative;
    aspect-ratio: 750/4492;
  }
}
@media (width >= 768px) {
  .top-park-sp {
    display: none;
  }
}
@media (width < 768px) {
  .top-park-sp__object {
    position: absolute;
    top: 0;
    left: 0;
  }
}
@media (width < 768px) {
  .top-park-sp__sprite {
    background: var(--image-url) 0 0 no-repeat;
    width: var(--width);
    height: var(--height);
    background-position: 0 0;
  }
}
@media (width < 768px) {
  .top-park-sp__scroll-icon {
    position: absolute;
    top: calc(var(--initial-vh) - 325px);
    left: 15px;
    width: fit-content;
    padding-bottom: 16px;
    color: var(--COLOR_PRIMARY);
    font-weight: var(--FONT_WEIGHT_BOLD);
    background: url(/assets/images/common/icon-chevron-double.svg) no-repeat center bottom/14px;
    text-transform: lowercase;
  }
  html:has(.top-floating-menu__inner.is-banner-hidden) .top-park-sp__scroll-icon {
    top: calc(var(--initial-vh) - 157px);
  }
}
@keyframes fade-into-top {
  from {
    opacity: 0;
    translate: 0 80px;
  }
  to {
    opacity: 1;
    translate: 0 0;
  }
}
@keyframes fade-into-right {
  from {
    opacity: 0;
    translate: -80px 0;
  }
  to {
    opacity: 1;
    translate: 0 0;
  }
}
@media (width < 768px) {
  .top-floating-menu {
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: var(--Z_INDEX_FLOATING_AREA);
    width: 100%;
    transition: opacity var(--TRANSITION), visibility var(--TRANSITION);
    pointer-events: none;
  }
  .top-floating-menu button,
  .top-floating-menu a {
    pointer-events: auto;
  }
  body.footer-in-view .top-floating-menu {
    opacity: 0;
    visibility: hidden;
  }
}
@media (width >= 768px) {
  .top-floating-menu {
    display: contents;
  }
}
@media (width < 768px) {
  .top-floating-menu__inner {
    display: flex;
    flex-direction: column;
    opacity: 0;
    animation: 0.8s var(--EASING) 0.5s forwards fade-into-top;
    transition: transform var(--TRANSITION);
  }
  .top-floating-menu__inner.is-banner-hidden {
    transform: translateY(var(--banner-height));
  }
}
@media (width >= 768px) {
  .top-floating-menu__inner {
    display: contents;
  }
}
.top-floating-menu__trigger {
  position: relative;
  width: 66px;
  height: 66px;
  margin-inline: auto 20px;
  background-color: var(--COLOR_PRIMARY);
  border-radius: 50%;
  filter: drop-shadow(0 3px 6px var(--COLOR_SHADOW));
  color: var(--COLOR_BASE);
  font-weight: var(--FONT_WEIGHT_BOLD);
  font-size: 1.2rem;
}
.top-floating-menu__trigger + .top-floating-menu__trigger {
  margin-block-start: 20px;
}
.top-floating-menu__trigger--news {
  padding-top: 4px;
}
.top-floating-menu__trigger--news::before {
  content: "";
  position: absolute;
  inset: 7px 0 auto 0;
  width: 15px;
  height: 15px;
  margin: auto;
  mask: url(/assets/images/common/icon-bell.svg) no-repeat center/contain;
  background-color: var(--COLOR_BASE);
}
.top-floating-menu__trigger--asobiglico {
  padding: 20px 10px 0;
  transition: opacity var(--TRANSITION), visibility var(--TRANSITION);
}
.top-floating-menu__trigger--asobiglico::before {
  content: "";
  position: absolute;
  inset: 5px 0 auto 0;
  width: 12px;
  height: 20px;
  margin: auto;
  background: url(/assets/images/pages/top/icon-asobiglico.svg) no-repeat center/contain;
}
.top-floating-menu__inner:not(.is-banner-hidden) .top-floating-menu__trigger--asobiglico {
  display: none;
}
@media (width >= 768px) {
  .top-floating-menu__trigger {
    box-shadow: var(--SHADOW_BUTTON);
    filter: none;
  }
  .top-floating-menu__trigger + .top-floating-menu__trigger {
    margin-block-start: 0;
  }
  .top-floating-menu__trigger--news {
    display: none;
  }
  .top-floating-menu__trigger--asobiglico {
    position: absolute;
    top: calc(min(100%, 100vh - var(--HEIGHT_HEADER)) - 66px - 20px);
    left: 20px;
    margin: 0;
  }
}
@media (width >= 1000px) {
  .top-floating-menu__trigger--news {
    position: absolute;
    top: calc(min(100%, 100vh - var(--HEIGHT_HEADER)) - 66px - 20px);
    right: 20px;
    display: block;
    margin: 0;
  }
}
.top-floating-menu__banner {
  position: relative;
  margin-top: 30px;
  padding: 20px 20px 40px;
  background-color: var(--COLOR_PRIMARY);
  border-radius: 20px 20px 0 0;
  transition: opacity var(--TRANSITION);
}
.top-floating-menu__inner.is-banner-hidden .top-floating-menu__banner {
  visibility: hidden;
  opacity: 0;
}
@media (width >= 768px) {
  .top-floating-menu__banner {
    position: absolute;
    top: calc(min(100%, 100vh - var(--HEIGHT_HEADER)) - 128px - 10px);
    left: 10px;
    z-index: var(--Z_INDEX_FLOATING_AREA);
    width: 230px;
    margin-top: 0;
    padding: 16px;
    border-radius: 10px;
    box-shadow: var(--SHADOW_BUTTON);
  }
  .top-floating-menu__inner:not(.is-banner-hidden) .top-floating-menu__banner {
    animation: 0.8s var(--EASING) 0.5s forwards fade-into-right;
  }
  .top-floating-menu__inner:not(.is-banner-hidden) .top-floating-menu__banner.no-delay {
    animation-delay: 0s;
  }
}
.top-floating-menu__banner-title {
  position: relative;
  width: fit-content;
  margin-inline: auto;
  padding-inline: 36px;
}
.top-floating-menu__banner-title::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 25px;
  height: 42px;
  margin: auto;
  background-image: url(/assets/images/pages/top/icon-asobiglico.svg);
  rotate: -6deg;
}
@media (width >= 768px) {
  .top-floating-menu__banner-title {
    width: auto;
    padding-inline-end: 20px;
  }
}
.top-floating-menu__banner-title-text {
  position: relative;
  display: block;
  padding-block: 10px;
  color: var(--COLOR_BASE);
  font-size: 2rem;
  font-weight: var(--FONT_WEIGHT_BOLD);
}
.top-floating-menu__banner-title-text::before,
.top-floating-menu__banner-title-text::after {
  content: "";
  position: absolute;
  left: -1px;
  width: 28px;
  height: 2px;
  background-color: var(--COLOR_BASE);
  border-radius: 2px;
}
.top-floating-menu__banner-title-text::before {
  top: 0;
  rotate: -15deg;
}
.top-floating-menu__banner-title-text::after {
  bottom: 0;
  rotate: 15deg;
}
@media (width >= 768px) {
  .top-floating-menu__banner-title-text {
    font-size: 1.4rem;
  }
}
.top-floating-menu__banner-button {
  position: relative;
  display: block;
  width: min(100%, 360px);
  border: 2px solid var(--COLOR_PRIMARY);
  border-radius: 100vmax;
  margin: 20px auto 0;
  padding: 10px 50px;
  background-color: var(--COLOR_BASE);
  color: var(--COLOR_PRIMARY);
  font-weight: var(--FONT_WEIGHT_BOLD);
  text-align: center;
  box-shadow: var(--SHADOW_BUTTON);
}
.top-floating-menu__banner-button::after {
  content: "";
  position: absolute;
  inset: 0 30px 0 auto;
  width: 15px;
  height: 15px;
  margin: auto;
  background-color: currentColor;
  mask: url(/assets/images/common/icon-chevron.svg) no-repeat center/contain;
  transition: background-color var(--TRANSITION);
}
@media (width >= 768px) {
  .top-floating-menu__banner-button {
    margin-top: 10px;
    padding-inline: 20px 40px;
  }
}
.top-floating-menu__banner-close {
  position: absolute;
  top: 5px;
  right: 5px;
  width: 44px;
  height: 44px;
}
.top-floating-menu__banner-close::before,
.top-floating-menu__banner-close::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 24px;
  height: 2px;
  background-color: var(--COLOR_BASE);
  border-radius: 2px;
}
.top-floating-menu__banner-close::before {
  rotate: 45deg;
}
.top-floating-menu__banner-close::after {
  rotate: -45deg;
}
@media (width >= 768px) {
  .top-floating-menu__banner-close {
    top: 0;
    right: 0;
  }
}
:root[data-park-theme=day] {
  --background-park-pc: url(/assets/images/pages/top/pc/background_day.avif);
}
:root[data-park-theme=night] {
  --background-park-pc: url(/assets/images/pages/top/pc/background_night.avif);
}
.l-footer {
  flex: 1;
}
.l-footer__body {
  flex: 1;
}


