@layer page {
  :root {
    --pc-top: 5rem;
    --pc-frame-height: 7.625rem;
    --sp-top: calc(65/900*100svh);
    --sp-frame-height: calc(110/900*100svh);
  }
  @media (orientation: landscape) {
    :root {
      --sp-top: calc(90/900*100svh);
      --sp-frame-height: calc(145/900*100svh);
    }
  }
  html, body {
    margin: 0;
    height: 100vh;
    overflow: hidden;
  }
  .p-home-scroller {
    height: 100vh;
    overflow: auto;
    overscroll-behavior: contain;
  }
  .p-home-link {
    display: block;
    width: 25.5555555556svh;
    position: absolute;
    bottom: 0;
    z-index: 25;
    transition: 0.25s opacity;
    font-size: 10px;
  }
  @media (hover: hover) {
    .p-home-link:hover {
      opacity: 0.8;
    }
  }
  .p-home-link#link-hontenbiru {
    bottom: 53.4%;
    left: 30%;
  }
  .p-home-link#link-shop {
    bottom: 15.4%;
    left: 40.3%;
  }
  .p-home-link#link-museum {
    bottom: 78.8%;
    left: 62.4%;
  }
  .p-home-link#link-torakichike {
    bottom: 36%;
    left: 78.2%;
  }
  .p-home-hontenbiru-anim {
    position: absolute;
    bottom: 49.6014171833%;
    left: 25.185%;
    aspect-ratio: 506/536;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    height: 44.995571302%;
    background-image: url("../../../img/page/home/honsha_sprite.png");
  }
  .p-home-hontenbiru-anim-on {
    position: absolute;
    bottom: 48.4%;
    left: 19.68%;
    aspect-ratio: 1390/560;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    height: 45%;
    background-image: url("../../../img/page/home/honsha_sprite_on.png");
  }
  .p-home-shop-anim {
    position: absolute;
    bottom: -1%;
    left: 44.5%;
    aspect-ratio: 730/282;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    width: 55.5555555556svh;
    background-image: url("../../../img/page/home/shop_sprite.png");
  }
  .p-home-shop-anim-on {
    position: absolute;
    bottom: -1%;
    left: 44.7%;
    aspect-ratio: 755/840;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    width: 55.5555555556svh;
    background-image: url("../../../img/page/home/shop_sprite_on.png");
  }
  .p-home-museum-anim {
    position: absolute;
    bottom: 50.8%;
    left: 62.4%;
    aspect-ratio: 250/265;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    height: 23%;
    background-image: url("../../../img/page/home/museum_sprite.png");
  }
  .p-home-museum-anim-on {
    position: absolute;
    bottom: 45.2%;
    left: 55.3%;
    aspect-ratio: 820/390;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    height: 34%;
    background-image: url("../../../img/page/home/museum_sprite_on.png");
  }
  .p-home-torakichike-anim {
    position: absolute;
    bottom: 24.6%;
    left: 83%;
    aspect-ratio: 410/250;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    height: 23%;
    background-image: url("../../../img/page/home/torakichike_sprite.png");
  }
  .p-home-torakichike-anim-on {
    position: absolute;
    bottom: 16%;
    left: 76.51%;
    aspect-ratio: 200/660;
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
    height: 51%;
    background-image: url("../../../img/page/home/torakichike_sprite_on.png");
  }
  .torakichike-house {
    aspect-ratio: 812/454;
    position: absolute;
    bottom: 15.45%;
    left: 74.8%;
    height: 41.0983170948%;
  }
  .point {
    width: 10px;
    height: 10px;
    background: #000;
    position: absolute;
    bottom: 0;
    z-index: 1000;
    opacity: 0;
  }
  .point#point-0 {
    top: 80.4%;
    left: 24.5%;
  }
  .point#point-1 {
    top: 52.4%;
    left: 28.5%;
  }
  .point#point-2 {
    top: 38%;
    left: 48.5%;
  }
  .point#point-3 {
    top: 34%;
    left: 58.5%;
  }
  .point#point-4 {
    top: 34%;
    left: 64%;
  }
  .point#point-5 {
    top: 35.4%;
    left: 72%;
  }
  .point#point-6 {
    top: 41.5%;
    left: 82%;
  }
  .point#point-7 {
    top: 45.5%;
    left: 88%;
  }
  .point#point-8 {
    top: 45.5%;
    left: 92%;
  }
  .point#point-9 {
    top: 48%;
    left: 100%;
  }
  #point-over {
    width: 10px;
    height: 10px;
    background: #000;
    position: absolute;
    bottom: 0;
    z-index: 100;
    opacity: 0;
    top: 32.5%;
    left: 90%;
  }
  .p-home-wrapper {
    position: fixed;
    display: flex;
    height: 100svh;
    top: var(--pc-top);
    pointer-events: none;
  }
  @media screen and (max-width: 767px) {
    .p-home-wrapper {
      top: var(--sp-top);
    }
  }
  .p-home-start,
  .p-home-end {
    width: 100vw;
    height: 100svh;
    flex-shrink: 0;
    position: relative;
  }
  .p-home-start div,
  .p-home-end div {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
  }
  .p-home-main {
    position: relative;
    height: 100svh;
  }
  .p-home-row {
    position: absolute;
    left: 0;
    top: 0;
    aspect-ratio: 8000/1129;
    height: calc(100svh - var(--pc-frame-height));
    z-index: 1;
    pointer-events: none;
  }
  @media screen and (max-width: 767px) {
    .p-home-row {
      height: calc(100svh - var(--sp-frame-height));
    }
  }
  .p-home-row a {
    pointer-events: fill;
  }
  .p-home-row img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: left bottom;
  }
  .p-home-indicator {
    pointer-events: none;
    position: fixed;
    z-index: 1200;
    bottom: calc(1% + 3.75rem);
    right: 1%;
    padding-top: 1.3333333333svh;
    padding-bottom: 1.3333333333svh;
    width: 47.8888888889svh;
    border-radius: 0.5rem;
    background: rgba(103, 52, 33, 0.6) url("../../../img/page/home/indicator.webp") 0 0/100% auto no-repeat;
  }
  @media (orientation: landscape) {
    .p-home-indicator {
      padding-top: 1.3333333333svh;
      padding-bottom: 1.3333333333svh;
    }
  }
  @media screen and (max-width: 767px) and (orientation: landscape) {
    .p-home-indicator {
      padding-top: 0;
      bottom: 8vh;
      font-size: 16px;
      border-radius: 1.0666666667vh;
    }
  }
  .p-home-indicator img {
    width: 100%;
  }
  .p-home-indicator__btn-wrap {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0 2svh;
    padding: 0 2svh 0 1.8888888889svh;
  }
  .p-home-indicator a {
    display: block;
    width: 7svh;
    pointer-events: fill;
    transition: 0.25s filter;
  }
  .p-home-indicator a[href="#link-shop"] img {
    max-width: none;
    width: 8svh;
    transform: translate(-3%, 2%);
  }
  @media (hover: hover) {
    .p-home-indicator a:hover {
      filter: hue-rotate(-40deg) saturate(200%) brightness(95%);
    }
  }
  .p-home-indicator__torakichi {
    position: absolute;
    width: 5.1111111111svh;
    left: 0;
    top: -40%;
    transform: translateX(2.8888888889svh);
  }
  .p-home-indicator__step {
    width: 0.5vw;
    height: 0.5vw;
    background: #000;
    position: absolute;
    left: 10.2%;
    top: 0;
    opacity: 0;
  }
  .p-home-indicator__step.is-1 {
    left: 29.2%;
  }
  .p-home-indicator__step.is-2 {
    left: 48.1%;
  }
  .p-home-indicator__step.is-3 {
    left: 67.1%;
  }
  .p-home-indicator__step.is-4 {
    left: 85.7%;
  }
  .is-rev-dist .p-home-torakichhi-walker {
    scale: -1 1;
  }
  .p-home-torakichhi-walker {
    aspect-ratio: 354/390;
    background-image: url("../../../img/page/home/walk_sprite.png");
    background-repeat: no-repeat;
    background-size: auto 100%;
    width: 26.6666666667svh;
    position: relative;
    top: -3.5555555556svh;
    translate: 0% 0;
    transition: 0.8s translate;
  }
  .p-home-torakichhi-walker.u-hidden {
    translate: -40% 0;
  }
  .p-home-torakichhi-end {
    position: absolute;
    left: 0;
    top: 0;
    aspect-ratio: 1/1;
    background-image: url("../../../img/page/home/walk_end_sprite.png");
    background-repeat: no-repeat;
    background-size: auto 100%;
    width: 34.4444444444svh;
    top: -10.2222222222svh;
    translate: -50% -4%;
    transition: 0.8s translate;
  }
  .p-home-torakichhi-end.u-hidden {
    translate: -25% -4%;
  }
  .p-home-torakichhi {
    pointer-events: none;
    position: fixed;
    z-index: 110;
    bottom: 18.3333333333svh;
    left: 50%;
    width: 33.3333333333svh;
    transform: translateX(-50%);
  }
  .p-home-torakichhi.is-over {
    z-index: 2000;
  }
  .p-home-torakichhi__box {
    position: relative;
    left: 0;
    top: 0;
  }
  .p-home-torakichhi .p-home-comment {
    position: absolute;
    top: 0;
    left: 0;
    width: 35.4444444444svh;
    transform: translate(-60%, -89%);
    scale: 0;
    transition: 0.4s scale;
    transition: bottom right;
  }
  @media screen and (max-width: 767px) and (orientation: portrait) {
    .p-home-torakichhi .p-home-comment {
      width: 27.7777777778svh;
      transform: translate(-40%, -108%);
    }
  }
  .p-home-torakichhi.is-link-hontenbiru .is-hontenbiru {
    scale: 1;
  }
  .p-home-torakichhi.is-link-shop .is-shop {
    scale: 1;
  }
  .p-home-torakichhi.is-link-museum .is-museum {
    scale: 1;
  }
  .p-home-torakichhi.is-link-torakichike .is-torakichike {
    scale: 1;
  }
  .p-home-sora {
    position: relative;
  }
  .p-home-front {
    z-index: 111;
  }
  .p-home-door {
    z-index: 150;
  }
  .p-home-door .p-home-start-cont,
  .p-home-door .p-home-end-cont {
    width: 110vw;
    height: 100svh;
    position: absolute;
    top: 0;
  }
  .p-home-door .p-home-start-cont a,
  .p-home-door .p-home-end-cont a {
    pointer-events: fill;
  }
  .p-home-door .p-home-start-cont {
    left: 0;
    background: url("../../../img/page/home/bg.png") 0 0/auto 22.2222222222svh repeat;
    transform: translateX(-100vw);
    z-index: 2000;
  }
  .p-home-door .p-home-start-img-wrap {
    position: relative;
    aspect-ratio: 2082/1304;
    transform: translate(5%, -2.5rem);
  }
  @media screen and (max-width: 767px) and (orientation: landscape) {
    .p-home-door .p-home-start-img-wrap {
      transform: translate(5%, -2.6666666667vh);
    }
  }
  .p-home-door .p-home-start-img {
    width: 100svh;
  }
  .p-home-door .p-home-start-anim {
    position: absolute;
    left: 20.8%;
    top: -5.9%;
    width: 44%;
    margin: 0 auto;
    aspect-ratio: 610/205;
    background-image: url("../../../img/page/home/start_sprite.png");
    background-position: 0 50%;
    background-repeat: no-repeat;
    background-size: auto 100%;
  }
  .p-home-door .p-home-start-scroll {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-60%, -50%);
    width: 33.3333333333svh;
    height: 33.3333333333svh;
    transition: 1s opacity;
    opacity: 0;
  }
  .p-home-door .p-home-start-scroll.is-show {
    opacity: 1;
  }
  .p-home-door .p-home-end-cont {
    width: 120vw;
    right: 0;
    z-index: 2;
    background: url("../../../img/page/home/bg.png") 100% 0/auto 22.2222222222svh repeat;
    transform: translateX(100vw);
    display: flex;
    justify-content: flex-end;
  }
  @media screen and (max-width: 767px) and (orientation: portrait) {
    .p-home-door .p-home-end-cont {
      width: 180vw;
    }
  }
  .p-home-door .p-home-end-cont__btn {
    --wrap-height: calc(100svh - var(--header-height) - var(--footer-height));
    display: block;
    position: absolute;
    left: 50%;
    top: calc(var(--wrap-height) / 2);
    height: var(--wrap-height);
    transform: translate(-40%, -4.4444444444svh);
  }
  @media (hover: hover) {
    .p-home-door .p-home-end-cont__btn {
      transform: translate(-40%, 0svh);
    }
  }
  @media screen and (max-width: 767px) and (orientation: portrait) {
    .p-home-door .p-home-end-cont__btn {
      transform: translate(-70%, -4.4444444444svh);
    }
  }
  .p-home-door .p-home-end-cont__btn a {
    width: 33.3333333333svh;
    display: block;
    transition: 0.25s opacity;
    font-size: 10px;
  }
  @media screen and (max-width: 767px) and (orientation: portrait) {
    .p-home-door .p-home-end-cont__btn a {
      width: 24.4444444444svh;
    }
  }
  .p-home-door .p-home-end-cont__btn a.is-hp {
    width: 42.2222222222svh;
  }
  @media screen and (max-width: 767px) and (orientation: portrait) {
    .p-home-door .p-home-end-cont__btn a.is-hp {
      width: 31.1111111111svh;
    }
  }
  @media (hover: hover) {
    .p-home-door .p-home-end-cont__btn a:hover {
      opacity: 0.8;
    }
  }
  .p-home-door .p-home-end-img {
    max-width: 80vw;
    max-height: 71.2222222222svh;
    transform: translate(-5%, -2.5rem);
  }
  .is-scrolled .p-home-start-scroll {
    opacity: 0;
  }
  .p-home-box {
    position: relative;
    width: 100vw;
    height: 100svh;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .l-header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    width: 100vw;
  }
  .l-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 100;
    width: 100vw;
  }
}