@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap");
/**
 * Swiper 12.1.2
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2026 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: February 18, 2026
 */
:root {
  --swiper-theme-color:#007aff;
}

:host {
  display: block;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 1;
}

.swiper {
  display: block;
  list-style: none;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  padding: 0;
  position: relative;
  z-index: 1;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  box-sizing: initial;
  display: flex;
  height: 100%;
  position: relative;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  width: 100%;
  z-index: 1;
}

.swiper-android .swiper-slide, .swiper-ios .swiper-slide, .swiper-wrapper {
  transform: translateZ(0);
}

.swiper-horizontal {
  touch-action: pan-y;
}

.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  display: block;
  flex-shrink: 0;
  height: 100%;
  position: relative;
  transition-property: transform;
  width: 100%;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-backface-hidden .swiper-slide {
  backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  perspective: 1200px;
  .swiper-cube-shadow, .swiper-slide {
    transform-style: preserve-3d;
  }
}

.swiper-css-mode {
  > .swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    &::-webkit-scrollbar {
      display: none;
    }
  }
  > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: start start;
  }
  &.swiper-horizontal {
    > .swiper-wrapper {
      scroll-snap-type: x mandatory;
    }
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-inline-start: var(--swiper-slides-offset-before);
      scroll-margin-inline-start: var(--swiper-slides-offset-before);
    }
    > .swiper-wrapper > .swiper-slide:last-child {
      margin-inline-end: var(--swiper-slides-offset-after);
    }
  }
  &.swiper-vertical {
    > .swiper-wrapper {
      scroll-snap-type: y mandatory;
    }
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-block-start: var(--swiper-slides-offset-before);
      scroll-margin-block-start: var(--swiper-slides-offset-before);
    }
    > .swiper-wrapper > .swiper-slide:last-child {
      margin-block-end: var(--swiper-slides-offset-after);
    }
  }
  &.swiper-free-mode {
    > .swiper-wrapper {
      scroll-snap-type: none;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: none;
    }
  }
  &.swiper-centered {
    > .swiper-wrapper:before {
      content: "";
      flex-shrink: 0;
      order: 9999;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: center center;
      scroll-snap-stop: always;
    }
  }
  &.swiper-centered.swiper-horizontal {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-inline-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper:before {
      height: 100%;
      min-height: 1px;
      width: var(--swiper-centered-offset-after);
    }
  }
  &.swiper-centered.swiper-vertical {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-block-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper:before {
      height: var(--swiper-centered-offset-after);
      min-width: 1px;
      width: 100%;
    }
  }
}

.swiper-3d {
  .swiper-slide-shadow, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left, .swiper-slide-shadow-right, .swiper-slide-shadow-top {
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 10;
  }
  .swiper-slide-shadow {
    background: rgba(0, 0, 0, 0.1490196078);
  }
  .swiper-slide-shadow-left {
    background-image: linear-gradient(270deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-right {
    background-image: linear-gradient(90deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-top {
    background-image: linear-gradient(0deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-bottom {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, 0.5019607843), rgba(0, 0, 0, 0));
  }
}

.swiper-lazy-preloader {
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top: 4px solid rgba(0, 0, 0, 0);
  box-sizing: border-box;
  height: 42px;
  left: 50%;
  margin-left: -21px;
  margin-top: -21px;
  position: absolute;
  top: 50%;
  transform-origin: 50%;
  width: 42px;
  z-index: 10;
}

.swiper-watch-progress .swiper-slide-visible, .swiper:not(.swiper-watch-progress) {
  .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s linear infinite;
  }
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color:#fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color:#000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(1turn);
  }
}
.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-virtual.swiper-css-mode {
  .swiper-wrapper:after {
    content: "";
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
  }
}

.swiper-virtual.swiper-css-mode.swiper-horizontal {
  .swiper-wrapper:after {
    height: 1px;
    width: var(--swiper-virtual-size);
  }
}

.swiper-virtual.swiper-css-mode.swiper-vertical {
  .swiper-wrapper:after {
    height: var(--swiper-virtual-size);
    width: 1px;
  }
}

:root {
  --swiper-navigation-size:44px;
}

.swiper-button-next, .swiper-button-prev {
  align-items: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
  cursor: pointer;
  display: flex;
  height: var(--swiper-navigation-size);
  justify-content: center;
  position: absolute;
  width: var(--swiper-navigation-size);
  z-index: 10;
  &.swiper-button-disabled {
    cursor: auto;
    opacity: 0.35;
    pointer-events: none;
  }
  &.swiper-button-hidden {
    cursor: auto;
    opacity: 0;
    pointer-events: none;
  }
  .swiper-navigation-disabled & {
    display: none !important;
  }
  svg {
    height: 100%;
    object-fit: contain;
    transform-origin: center;
    width: 100%;
    fill: currentColor;
    pointer-events: none;
  }
}

.swiper-button-lock {
  display: none;
}

.swiper-button-next, .swiper-button-prev {
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  top: var(--swiper-navigation-top-offset, 50%);
}

.swiper-button-prev {
  left: var(--swiper-navigation-sides-offset, 4px);
  right: auto;
  .swiper-navigation-icon {
    transform: rotate(180deg);
  }
}

.swiper-button-next {
  left: auto;
  right: var(--swiper-navigation-sides-offset, 4px);
}

.swiper-horizontal {
  .swiper-button-next, .swiper-button-prev, ~ .swiper-button-next, ~ .swiper-button-prev {
    margin-left: 0;
    margin-top: calc(0px - var(--swiper-navigation-size) / 2);
    top: var(--swiper-navigation-top-offset, 50%);
  }
  &.swiper-rtl .swiper-button-next, &.swiper-rtl ~ .swiper-button-next, & ~ .swiper-button-prev, .swiper-button-prev {
    left: var(--swiper-navigation-sides-offset, 4px);
    right: auto;
  }
  &.swiper-rtl .swiper-button-prev, &.swiper-rtl ~ .swiper-button-prev, & ~ .swiper-button-next, .swiper-button-next {
    left: auto;
    right: var(--swiper-navigation-sides-offset, 4px);
  }
  &.swiper-rtl .swiper-button-next, &.swiper-rtl ~ .swiper-button-next, & ~ .swiper-button-prev, .swiper-button-prev {
    .swiper-navigation-icon {
      transform: rotate(180deg);
    }
  }
  &.swiper-rtl .swiper-button-prev, &.swiper-rtl ~ .swiper-button-prev {
    .swiper-navigation-icon {
      transform: rotate(0deg);
    }
  }
}

.swiper-vertical {
  .swiper-button-next, .swiper-button-prev, ~ .swiper-button-next, ~ .swiper-button-prev {
    left: var(--swiper-navigation-top-offset, 50%);
    margin-left: calc(0px - var(--swiper-navigation-size) / 2);
    margin-top: 0;
    right: auto;
  }
  .swiper-button-prev, ~ .swiper-button-prev {
    bottom: auto;
    top: var(--swiper-navigation-sides-offset, 4px);
    .swiper-navigation-icon {
      transform: rotate(-90deg);
    }
  }
  .swiper-button-next, ~ .swiper-button-next {
    bottom: var(--swiper-navigation-sides-offset, 4px);
    top: auto;
    .swiper-navigation-icon {
      transform: rotate(90deg);
    }
  }
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transform: translateZ(0);
  transition: opacity 0.3s;
  z-index: 10;
  &.swiper-pagination-hidden {
    opacity: 0;
  }
  &.swiper-pagination-disabled, .swiper-pagination-disabled > & {
    display: none !important;
  }
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: var(--swiper-pagination-bottom, 8px);
  left: 0;
  top: var(--swiper-pagination-top, auto);
  width: 100%;
}

.swiper-pagination-bullets-dynamic {
  font-size: 0;
  overflow: hidden;
  .swiper-pagination-bullet {
    position: relative;
    transform: scale(0.33);
  }
  .swiper-pagination-bullet-active, .swiper-pagination-bullet-active-main {
    transform: scale(1);
  }
  .swiper-pagination-bullet-active-prev {
    transform: scale(0.66);
  }
  .swiper-pagination-bullet-active-prev-prev {
    transform: scale(0.33);
  }
  .swiper-pagination-bullet-active-next {
    transform: scale(0.66);
  }
  .swiper-pagination-bullet-active-next-next {
    transform: scale(0.33);
  }
}

.swiper-pagination-bullet {
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
  display: inline-block;
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  button& {
    appearance: none;
    border: none;
    box-shadow: none;
    margin: 0;
    padding: 0;
  }
  .swiper-pagination-clickable & {
    cursor: pointer;
  }
  &:only-child {
    display: none !important;
  }
}

.swiper-pagination-bullet-active {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  opacity: var(--swiper-pagination-bullet-opacity, 1);
}

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
  left: var(--swiper-pagination-left, auto);
  right: var(--swiper-pagination-right, 8px);
  top: 50%;
  transform: translate3d(0, -50%, 0);
  .swiper-pagination-bullet {
    display: block;
    margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  }
  &.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    .swiper-pagination-bullet {
      display: inline-block;
      transition: transform 0.2s, top 0.2s;
    }
  }
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-horizontal.swiper-pagination-bullets {
  .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
  }
  &.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    .swiper-pagination-bullet {
      transition: transform 0.2s, left 0.2s;
    }
  }
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: transform 0.2s, right 0.2s;
}

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit);
}

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.2509803922));
  position: absolute;
  .swiper-pagination-progressbar-fill {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transform: scale(0);
    transform-origin: left top;
    width: 100%;
  }
  .swiper-rtl & .swiper-pagination-progressbar-fill {
    transform-origin: right top;
  }
  &.swiper-pagination-horizontal, &.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-horizontal > &, .swiper-vertical > &.swiper-pagination-progressbar-opposite {
    height: var(--swiper-pagination-progressbar-size, 4px);
    left: 0;
    top: 0;
    width: 100%;
  }
  &.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, &.swiper-pagination-vertical, .swiper-horizontal > &.swiper-pagination-progressbar-opposite, .swiper-vertical > & {
    height: 100%;
    left: 0;
    top: 0;
    width: var(--swiper-pagination-progressbar-size, 4px);
  }
}

.swiper-pagination-lock {
  display: none;
}

.swiper-scrollbar {
  background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, 0.1019607843));
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  position: relative;
  touch-action: none;
  &.swiper-scrollbar-disabled, .swiper-scrollbar-disabled > & {
    display: none !important;
  }
  &.swiper-scrollbar-horizontal, .swiper-horizontal > & {
    bottom: var(--swiper-scrollbar-bottom, 4px);
    height: var(--swiper-scrollbar-size, 4px);
    left: var(--swiper-scrollbar-sides-offset, 1%);
    position: absolute;
    top: var(--swiper-scrollbar-top, auto);
    width: calc(100% - var(--swiper-scrollbar-sides-offset, 1%) * 2);
    z-index: 50;
  }
  &.swiper-scrollbar-vertical, .swiper-vertical > & {
    height: calc(100% - var(--swiper-scrollbar-sides-offset, 1%) * 2);
    left: var(--swiper-scrollbar-left, auto);
    position: absolute;
    right: var(--swiper-scrollbar-right, 4px);
    top: var(--swiper-scrollbar-sides-offset, 1%);
    width: var(--swiper-scrollbar-size, 4px);
    z-index: 50;
  }
}

.swiper-scrollbar-drag {
  background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5019607843));
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  height: 100%;
  left: 0;
  position: relative;
  top: 0;
  width: 100%;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  text-align: center;
  width: 100%;
  > canvas, > img, > svg {
    max-height: 100%;
    max-width: 100%;
    object-fit: contain;
  }
}

.swiper-slide-zoomed {
  cursor: move;
  touch-action: none;
}

.swiper .swiper-notification {
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  margin: 0 auto;
  transition-timing-function: ease-out;
}

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  flex-direction: column;
  flex-wrap: wrap;
}

.swiper-fade {
  &.swiper-free-mode {
    .swiper-slide {
      transition-timing-function: ease-out;
    }
  }
  .swiper-slide {
    pointer-events: none;
    transition-property: opacity;
    .swiper-slide {
      pointer-events: none;
    }
  }
  .swiper-slide-active {
    pointer-events: auto;
    & .swiper-slide-active {
      pointer-events: auto;
    }
  }
}

.swiper.swiper-cube {
  overflow: visible;
}

.swiper-cube {
  .swiper-slide {
    backface-visibility: hidden;
    height: 100%;
    pointer-events: none;
    transform-origin: 0 0;
    visibility: hidden;
    width: 100%;
    z-index: 1;
    .swiper-slide {
      pointer-events: none;
    }
  }
  &.swiper-rtl .swiper-slide {
    transform-origin: 100% 0;
  }
  .swiper-slide-active {
    &, & .swiper-slide-active {
      pointer-events: auto;
    }
  }
  .swiper-slide-active, .swiper-slide-next, .swiper-slide-prev {
    pointer-events: auto;
    visibility: visible;
  }
  .swiper-cube-shadow {
    bottom: 0;
    height: 100%;
    left: 0;
    opacity: 0.6;
    position: absolute;
    width: 100%;
    z-index: 0;
    &:before {
      background: #000;
      bottom: 0;
      content: "";
      filter: blur(50px);
      left: 0;
      position: absolute;
      right: 0;
      top: 0;
    }
  }
}

.swiper-cube {
  .swiper-slide-next + .swiper-slide {
    pointer-events: auto;
    visibility: visible;
  }
}

.swiper-cube {
  .swiper-slide-shadow-cube.swiper-slide-shadow-bottom, .swiper-slide-shadow-cube.swiper-slide-shadow-left, .swiper-slide-shadow-cube.swiper-slide-shadow-right, .swiper-slide-shadow-cube.swiper-slide-shadow-top {
    backface-visibility: hidden;
    z-index: 0;
  }
}

.swiper.swiper-flip {
  overflow: visible;
}

.swiper-flip {
  .swiper-slide {
    backface-visibility: hidden;
    pointer-events: none;
    z-index: 1;
    .swiper-slide {
      pointer-events: none;
    }
  }
  .swiper-slide-active {
    &, & .swiper-slide-active {
      pointer-events: auto;
    }
  }
}

.swiper-flip {
  .swiper-slide-shadow-flip.swiper-slide-shadow-bottom, .swiper-slide-shadow-flip.swiper-slide-shadow-left, .swiper-slide-shadow-flip.swiper-slide-shadow-right, .swiper-slide-shadow-flip.swiper-slide-shadow-top {
    backface-visibility: hidden;
    z-index: 0;
  }
}

.swiper-creative {
  .swiper-slide {
    backface-visibility: hidden;
    overflow: hidden;
    transition-property: transform, opacity, height;
  }
}

.swiper.swiper-cards {
  overflow: visible;
}

.swiper-cards {
  .swiper-slide {
    backface-visibility: hidden;
    overflow: hidden;
    transform-origin: center bottom;
  }
}

* {
  box-sizing: border-box;
}

html {
  width: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: 120px;
}
@media screen and (max-width: 750px) {
  html {
    scroll-padding-top: 60px;
  }
}

body {
  font-size: clamp(15px, 1.1713030747vw, 16px);
  color: #333333;
  line-height: 1.8;
  font-family: "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  text-align: left;
  width: 100%;
  margin: 0px;
  padding: 0px;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}
#wrap {
  text-align: left;
  overflow: hidden;
}

h1, h2, h3, h4, h5, p, ul, ol, li, img, table, th, td, dl, dt, dd {
  margin: 0px;
  padding: 0px;
  font-size: 14px;
}

p {
  text-align: justify;
}

li {
  list-style-type: none;
}

table {
  border-collapse: collapse;
}

a, a:link, a:visited, a:active {
  color: #00AFDD;
  text-decoration: none;
  -webkit-appearance: none;
}

a:hover {
  opacity: 0.8;
}

figure {
  margin: 0;
}

img {
  vertical-align: top;
  max-width: 100%;
  height: auto;
  backface-visibility: hidden;
}

a img {
  vertical-align: bottom;
  backface-visibility: hidden;
}

input,
textarea,
select,
button,
label {
  outline: none;
  -webkit-tap-highlight-color: transparent;
}

:focus {
  outline: 0;
  border-color: orange;
}

summary::-webkit-details-marker {
  display: none;
}

chat {
  display: none;
}

.sp-inline,
.spOnly {
  display: none;
}

@media screen and (max-width: 750px) {
  .spOnly {
    display: block;
  }
  .pcOnly {
    display: none;
  }
  .sp-inline {
    display: inline;
  }
}
.align-center {
  text-align: center;
}

.em {
  font-weight: 700;
}

.nowrap {
  white-space: nowrap;
}

/* レイアウト
-----------------------------------------------*/
.wrapper {
  overflow-x: hidden;
  position: relative;
  z-index: 2;
}

.container {
  margin-inline: auto;
  width: min(1366px, 100%);
  padding-left: clamp(175px, 15.0073206442vw, 205px);
  padding-right: 80px;
}
@media screen and (max-width: 1023px) {
  .container {
    padding: 0 4.2666666667vw;
  }
}

.section {
  padding-top: clamp(70px, 8.78477306vw, 120px);
  padding-bottom: clamp(70px, 8.78477306vw, 120px);
}
.section.virtual-tour {
  padding-top: 0;
}

.side-menu {
  position: absolute;
  top: 0;
  bottom: unset;
  left: 0;
  width: clamp(135px, 11.2737920937vw, 154px);
  padding-top: 20px;
  z-index: 100;
}
@media screen and (min-width: 1367px) {
  .side-menu {
    left: calc(50% - 683px);
  }
}
@media screen and (max-width: 1023px) {
  .side-menu {
    display: none;
  }
}
.side-menu.is-fixed {
  position: fixed;
  top: 120px;
  bottom: unset;
}
.side-menu.is-bottom {
  position: absolute;
  top: unset;
  bottom: 120px;
}
.side-menu__list {
  margin: 0;
  padding: 0;
  border-right: 1px solid #CACCC6;
  padding-left: min(33px, 2.4158125915vw);
}
.side-menu__item {
  font-size: clamp(12px, 0.9516837482vw, 13px);
  font-weight: 700;
  line-height: 1.4;
}
.side-menu__item + .side-menu__item {
  margin-top: clamp(20px, 2.196193265vw, 30px);
}
.side-menu__item a {
  color: #333;
  position: relative;
}
.side-menu__item a:hover, .side-menu__item.is-active a {
  color: #00AFDD;
}
.side-menu__item a:hover::before, .side-menu__item.is-active a::before {
  content: "";
  width: min(28px, 2.0497803807vw);
  height: 1px;
  background-color: #00AFDD;
  position: absolute;
  top: 0.6em;
  left: max(-33px, -2.4158125915vw);
}

/* 共通
-----------------------------------------------*/
.bg-gray {
  background-color: #F4F5F2;
}

.bg-white {
  background-color: #fff;
}

.wrap {
  overflow: none;
}

.ttl__lv1--en {
  font-family: "Oswald", sans-serif;
  font-size: clamp(38px, 4.39238653vw, 60px);
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.0833333333;
  color: #2C373A;
}
.ttl__lv1--jp {
  margin-top: 10px;
  color: #00AFDD;
  font-size: clamp(16px, 1.317715959vw, 18px);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.0888888889;
}

.ttl__lv2--en {
  font-family: "Oswald", sans-serif;
  font-size: clamp(15px, 1.1713030747vw, 16px);
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.1375;
  color: #00AFDD;
  margin-bottom: 20px;
}
.ttl__lv2--en--large {
  font-size: clamp(22px, 2.196193265vw, 30px);
  font-weight: 700;
  margin-right: 10px;
  vertical-align: middle;
}
.ttl__lv2--en--border {
  padding-bottom: 10px;
  position: relative;
}
.ttl__lv2--en--border::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(100%, 1.5em);
  border-bottom: 5px solid #2C373A;
}
.ttl__lv2--jp {
  color: #2C373A;
  font-size: clamp(24px, 2.9282576867vw, 40px);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  margin-bottom: clamp(30px, 2.9282576867vw, 40px);
}
.ttl__lv2--jp--large {
  font-size: clamp(30px, 4.39238653vw, 60px);
}
.ttl__lv2--en + .ttl__lv2--jp {
  margin-top: 40px;
}

.ttl__lv3 {
  font-size: clamp(22px, 2.196193265vw, 30px);
  font-weight: 700;
  line-height: 1.28;
  margin-bottom: clamp(30px, 2.9282576867vw, 40px);
  text-indent: clamp(-36px, -2.635431918vw, -27px);
  padding-left: clamp(27px, 2.635431918vw, 36px);
}
.ttl__lv3 img {
  width: clamp(19px, 1.6837481698vw, 23px);
  vertical-align: middle;
  margin-right: clamp(8px, 0.9516837482vw, 13px);
}

.ttl__lv4 {
  font-size: clamp(19px, 1.756954612vw, 24px);
  font-weight: 700;
  line-height: 1.28;
  margin-bottom: 20px;
  text-align: center;
}
.ttl__lv4--border {
  text-align: left;
  padding: 7px 0 6px clamp(20px, 2.196193265vw, 30px);
  border-left: 2px solid #00AFDD;
}

.text__lead {
  font-weight: 700;
  margin-top: 2.2em;
  margin-bottom: 2.2em;
  font-size: clamp(15px, 1.1713030747vw, 16px);
  line-height: 2.2;
}
* .text__lead:first-of-type {
  margin-top: -0.6em;
}
* .text__lead:last-of-type {
  margin-bottom: -0.6em;
}

.marquee {
  display: flex;
  white-space: nowrap;
  overflow: clip;
}

.marquee__text {
  animation: marquee-scroll 100s linear infinite;
  color: #F4F5F2;
  font-family: "Oswald", sans-serif;
  font-size: max(65px, 7.3206442167vw);
  font-weight: 500;
  line-height: 1;
  margin-top: min(-10px, -1.0248901903vw);
  padding-right: 0.5em; /* テキスト間の余白 */
}

@keyframes marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
/* icon
-----------------------------------------------*/
.icon_arrow_down {
  width: 12px;
  height: 10px;
}

/* button
-----------------------------------------------*/
.button {
  color: #fff !important;
  background-color: #00AFDD;
  width: clamp(303px, 26.1346998536vw, 357px);
  height: clamp(70px, 5.8565153734vw, 80px);
  font-size: clamp(17px, 1.4641288433vw, 20px);
  font-weight: 700;
  line-height: 1.4;
  border-radius: 5px;
  padding: 10px clamp(20px, 2.196193265vw, 30px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 22px;
  box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.1);
  cursor: pointer;
}
@media screen and (max-width: 750px) {
  .button {
    width: 100%;
    gap: 10px;
  }
}
.button:hover {
  opacity: 0.8;
}
.button img {
  vertical-align: middle;
}
.button img:nth-of-type(1) {
  width: max(18px, 1.317715959vw);
}
.button img:nth-of-type(2) {
  width: max(14px, 1.0248901903vw);
}
.button span {
  flex-grow: 1;
}
.button--green {
  background-color: #8BAF2E;
}
.button--border {
  border: 1px solid #00AFDD;
  background-color: #fff;
  color: #00AFDD !important;
}
.button .text-s {
  font-size: clamp(15px, 1.1713030747vw, 16px);
}
.button__wrapper {
  display: flex;
  gap: 20px clamp(20px, 2.196193265vw, 30px);
  margin-top: clamp(60px, 6.588579795vw, 90px);
  flex-wrap: wrap;
}
@media screen and (max-width: 750px) {
  .button__wrapper {
    justify-content: center;
    padding: 0 20px;
  }
}
.button__outer {
  position: relative;
}
.button__outer .fukidashi {
  position: absolute;
}
@media screen and (max-width: 750px) {
  .modal .button {
    width: min(303px, 100%);
    margin-inline: auto;
  }
}
.virtual-tour .button {
  width: 100%;
  height: 50px;
  font-size: 18px;
  justify-content: center;
  gap: 8px;
}
.virtual-tour .button span {
  flex-grow: 0;
}
.virtual-tour .button img {
  width: 18px;
}
.simulation .button__wrapper .button img:nth-of-type(1) {
  width: clamp(20px, 1.9033674963vw, 26px);
}
.simulation .button__wrapper .button__outer {
  width: clamp(303px, 26.1346998536vw, 357px);
}
@media screen and (max-width: 750px) {
  .simulation .button__wrapper .button__outer {
    width: min(303px, 100%);
  }
}
.simulation .button__wrapper .fukidashi {
  position: absolute;
  left: -50.5px;
  top: -40px;
}
@media screen and (max-width: 1023px) {
  .simulation .button__wrapper .fukidashi {
    left: -28px;
    top: -50px;
    transform: rotate(7deg);
  }
}
.simulation .slide-item .button {
  width: 100%;
  height: 60px;
  font-size: 16px;
}
.button__wrapper--showroom1 {
  background-color: #F4F5F2;
  padding: 90px 20px 72px;
  position: relative;
  justify-content: center;
  margin-top: 205px;
  gap: 65px clamp(20px, 2.196193265vw, 30px);
}
@media screen and (max-width: 750px) {
  .button__wrapper--showroom1 {
    padding: 98px 20px 30px;
    margin-top: 94px;
  }
}
.button__wrapper--showroom1::before {
  content: "";
  width: 159px;
  height: 199px;
  display: block;
  position: absolute;
  top: -154px;
  left: 47px;
  background-image: url("../img/showroom_illust.png");
  background-size: contain;
}
@media screen and (max-width: 750px) {
  .button__wrapper--showroom1::before {
    width: 100px;
    height: 125px;
    top: -74px;
    left: 50%;
    transform: translateX(-50%);
  }
}
.button__wrapper--showroom1 .fukidashi {
  width: 205px;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 750px) {
  .button__wrapper--showroom1 .fukidashi {
    width: 200px;
    top: -35px;
  }
}
.button__wrapper--showroom1 .button {
  width: 100%;
}
@media screen and (max-width: 750px) {
  .button__wrapper--showroom1 .button {
    height: 80px;
  }
}
.button__wrapper--showroom1 .button img:first-of-type {
  width: min(39px, 2.8550512445vw);
}
@media screen and (max-width: 750px) {
  .button__wrapper--showroom1 .button img:first-of-type {
    width: 25px;
  }
}
.button__wrapper--showroom1 .button__outer {
  width: clamp(303px, 30.7467057101vw, 420px);
}
@media screen and (max-width: 750px) {
  .button__wrapper--showroom1 .button__outer {
    width: min(303px, 100%);
  }
}
.button__wrapper--showroom2 {
  justify-content: center;
  margin: 0;
  gap: 20px clamp(30px, 2.9282576867vw, 40px);
}
.button__wrapper--showroom2 .button {
  width: clamp(303px, 24.1581259151vw, 330px);
  height: 94px;
  line-height: 1.4;
}
.button__wrapper--showroom2 .button:first-child {
  color: #00AFDD !important;
  font-size: clamp(19px, 1.756954612vw, 24px);
}
@media screen and (max-width: 750px) {
  .button__wrapper--showroom2 .button {
    width: min(303px, 100%);
  }
}
.button__wrapper--showroom2 .button .text-s {
  color: #2C373A !important;
}
.button__wrapper--showroom2 .button:last-child {
  color: #2C373A !important;
  font-size: clamp(17px, 1.4641288433vw, 20px);
  cursor: pointer;
}
.button__wrapper--showroom2 .button img:first-of-type {
  width: 30px;
}
.information .button {
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .information .button {
    width: min(303px, 100%);
  }
}
.information .button img:first-of-type {
  width: 23px;
}

@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.fadeout {
  animation: fadeOut 1s;
}

@keyframes moveDown {
  0% {
    transform: translate(-50%, calc(-100% - 100px));
    opacity: 0;
  }
  20% {
    opacity: 1;
  }
  100% {
    transform: translate(-50%, -100%);
  }
}
/* loading */
#loading {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 100;
}

#loading::before,
#loading::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 50%;
  background: #f9f7f4;
  transition: height 0.4s ease-out;
  transition-delay: 0.2s;
}

#loading::before {
  top: 0;
}

#loading::after {
  bottom: 0;
}

#loading.active::before,
#loading.active::after {
  height: 0;
}

#loading .img {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 180px;
  height: 180px;
  transform: translate(-50%, -50%);
  z-index: 2;
  transition: opacity 0.2s ease-out;
}

@keyframes rotation {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
#loading .img .circle {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  animation: 4s linear infinite rotation;
}

#loading.active .img {
  opacity: 0;
}

/* main
-----------------------------------------------*/
.mv-section {
  position: relative;
  z-index: 1;
}

/* movie
-----------------------------------------------*/
.movie {
  position: relative;
  overflow: clip;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 50;
}
@media screen and (max-width: 1366px) {
  .movie {
    height: 612px;
  }
}
@media screen and (max-width: 750px) {
  .movie {
    height: min(612px, 100vh - 124px);
  }
}
.movie::after {
  content: "";
  width: 100%;
  height: 15.6661786237vw;
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0;
  background: linear-gradient(rgba(244, 245, 242, 0) 0%, rgba(244, 245, 242, 0.6) 50%, rgb(244, 245, 242) 100%);
  z-index: 70;
}
@media screen and (max-width: 750px) {
  .movie::after {
    height: 150px;
  }
}
.movie #video {
  width: 100%;
  aspect-ratio: 1366/612;
}
@media screen and (max-width: 1366px) {
  .movie #video {
    width: 1366px;
  }
}
@media screen and (max-width: 750px) {
  .movie #video {
    width: auto;
    height: 100%;
  }
}
.movie iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100vw;
  height: 56.25vw;
}
@media screen and (max-width: 1088px) {
  .movie iframe {
    width: 1088px;
    height: 612px;
  }
}
@media screen and (max-width: 750px) {
  .movie iframe {
    width: min(1088px, (100vh - 124px) / 9 * 16);
    height: min(612px, 100vh - 124px);
  }
}

/* map
-----------------------------------------------*/
.map {
  width: 100%;
  aspect-ratio: 1366/612;
  position: relative;
  background-image: url("../img/map/map.png");
  background-size: contain;
}
@media screen and (max-width: 1366px) {
  .map {
    width: 1366px;
  }
}
@media screen and (max-width: 750px) {
  .map {
    width: auto;
    height: 100%;
  }
}
.map::after {
  content: "";
  width: 100%;
  height: 15.6661786237vw;
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0;
  background: linear-gradient(rgba(244, 245, 242, 0) 0%, rgba(244, 245, 242, 0.6) 50%, rgb(244, 245, 242) 100%);
  z-index: 70;
}
@media screen and (max-width: 750px) {
  .map::after {
    height: 150px;
  }
}
.map:active {
  cursor: grabbing;
}
.map img {
  width: 100%;
}
.map__container {
  position: relative;
  scrollbar-width: none;
  overflow-x: auto;
  overflow-y: hidden;
}
@media screen and (max-width: 1366px) {
  .map__container {
    height: 612px;
  }
}
@media screen and (max-width: 750px) {
  .map__container {
    height: min(612px, 100svh - 124px);
  }
}
.map__container.active .pin {
  animation: moveDown 0.8s ease-in-out;
}
.map__scroll {
  display: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 40;
}
@media screen and (max-width: 750px) {
  .map__scroll {
    display: block;
  }
}
.map__list-nav {
  position: absolute;
  top: max(30px, 2.196193265vw);
  left: max(40px, 2.9282576867vw);
  z-index: 40;
}
@media screen and (max-width: 750px) {
  .map__list-nav {
    top: 10px;
    left: 10px;
  }
}
.map__list-nav::before {
  content: "";
  width: calc(100% + 140px);
  height: calc(100% + 156px);
  display: block;
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(rgb(255, 255, 255) 0, rgba(255, 255, 255, 0) 70%);
  top: -78px;
  left: -70px;
  z-index: -1;
}
.map__list-nav__header {
  background-color: #2C373A;
  border-radius: 5px;
  color: #fff;
  font-size: max(14px, 1.0248901903vw);
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-right: max(20px, 1.4641288433vw);
  cursor: pointer;
}
.map__list-nav__button {
  width: max(44px, 3.2210834553vw);
  height: max(50px, 3.6603221083vw);
  display: flex;
  justify-content: center;
  align-items: center;
}
.map__list-nav__button--open {
  display: block;
  width: max(18px, 1.317715959vw);
}
.map__list-nav__button--close {
  display: none;
  width: max(14px, 1.0248901903vw);
}
.map__list-nav[open] {
  z-index: 90;
}
.map__list-nav[open] .map__list-nav__header {
  border-radius: 5px 5px 0 0;
}
.map__list-nav[open] .map__list-nav__button--open {
  display: none;
}
.map__list-nav[open] .map__list-nav__button--close {
  display: block;
}
.map__list {
  background-color: #2C373A;
  color: #00AFDD;
  padding: 3px min(30px, 2.196193265vw) 17px min(44px, 3.2210834553vw);
  overflow-y: auto;
  max-height: calc(100vh - 270px);
}
.map__list li {
  font-size: max(14px, 1.0248901903vw);
  padding: 12.4px 0;
  cursor: pointer;
}
.map__ttl {
  font-family: "Oswald", sans-serif;
  color: #2C373A;
  font-size: max(38px, 4.5387994143vw);
  font-weight: 700;
  text-shadow: 0 0 20px rgb(255, 255, 255);
  letter-spacing: 0.02em;
  padding-left: 3.074670571vw;
  line-height: 1;
}
@media screen and (max-width: 750px) {
  .map__ttl {
    padding-left: 10px;
  }
}
.map__ttl__wrapper {
  position: absolute;
  top: min(100vh - 160px, 93.4640522876%);
  transform: translateY(-100%);
  left: 0;
  width: 100%;
  z-index: 70;
}
@media screen and (max-width: 960px) {
  .map__ttl__wrapper {
    top: min(100vh - 224px, 93.4640522876%);
  }
}
@media screen and (max-width: 750px) {
  .map__ttl__wrapper {
    gap: 0;
    top: unset;
    bottom: 10px;
    transform: none;
  }
}
.map__ttl__wrapper .button {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: clamp(108px, 10.102489019vw, 138px);
  height: clamp(38px, 3.6603221083vw, 50px);
  font-size: clamp(16px, 1.317715959vw, 18px);
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1023px) {
  .map__ttl__wrapper .button {
    left: unset;
    right: 4.2666666667vw;
    transform: none;
  }
}

.pin {
  cursor: pointer;
  position: absolute;
  transform: translate(-50%, -100%);
  z-index: 5;
}
.pin:has(img[alt=はなれ]) {
  z-index: 6;
}
.pin:has(img[alt=ショップ]) {
  z-index: 7;
}
.pin__img {
  display: block;
}
.pin__hover {
  display: none;
}
@media (any-hover: hover) {
  .pin:hover .pin__img {
    display: none;
  }
  .pin:hover .pin__hover {
    display: block;
  }
}

dialog::backdrop {
  background-color: rgba(129, 141, 144, 0.7);
}

body:has(dialog:open) {
  overflow: hidden;
}

.modal {
  width: max(650px, 65.1537335286%);
  max-height: 68.6084142395%;
  border: none;
  padding: 0;
  border-radius: 5px;
  z-index: 10000;
}
@media screen and (max-width: 750px) {
  .modal {
    width: calc(100% - 36px);
    max-height: calc(100% - 30px);
  }
}
.modal__container {
  padding: 5.1244509517vw 5.1244509517vw 5.1244509517vw 3.6603221083vw;
  position: relative;
}
@media screen and (max-width: 750px) {
  .modal__container {
    padding: 47px 20px 30px;
  }
}
.modal__close {
  position: sticky;
  top: 0;
}
.modal__close button {
  cursor: pointer;
  display: block;
  width: max(62px, 4.5387994143vw);
  height: max(62px, 4.5387994143vw);
  margin: -5.1244509517vw -5.1244509517vw 0 auto;
  padding: 0;
  border: none;
  background: none;
}
@media screen and (max-width: 750px) {
  .modal__close button {
    margin: -47px -20px 0 auto;
  }
}
.modal__close img {
  width: max(14px, 1.0248901903vw);
}
.modal__flex {
  display: flex;
  align-items: center;
  gap: 4.39238653vw;
}
@media screen and (max-width: 750px) {
  .modal__flex {
    display: block;
  }
}
.modal__image {
  flex: 23.5724743777vw 0 0;
  text-align: center;
}
@media screen and (max-width: 750px) {
  .modal__image {
    width: 79.9342105263%;
    margin-inline: auto;
  }
}
.modal__image img {
  width: 100%;
}
@media screen and (max-width: 750px) {
  .modal__image img {
    margin-bottom: 20px;
  }
}
.modal__image figcaption {
  margin-top: 15px;
  font-size: clamp(13px, 1.0248901903vw, 14px);
  font-weight: 500;
}
.modal__ttl {
  color: #00AFDD;
  font-weight: 700;
  line-height: 1.4;
}
.modal__ttl--1 {
  font-size: clamp(17px, 1.4641288433vw, 20px);
}
.modal__ttl--2 {
  font-size: clamp(19px, 1.756954612vw, 24px);
}
.modal__content p {
  font-size: clamp(13px, 1.0248901903vw, 14px);
  font-weight: 700;
  margin-top: 20px;
  margin-bottom: clamp(30px, 2.9282576867vw, 40px);
}

/* welcome
-----------------------------------------------*/
.welcome {
  padding-top: clamp(30px, 2.9282576867vw, 40px);
}
.welcome__container {
  padding: clamp(30px, 2.9282576867vw, 40px) 0 0;
  position: relative;
}
.welcome__text {
  width: min(660px, 48.3162518302vw);
}
@media screen and (max-width: 1180px) {
  .welcome__text {
    width: 42.4597364568vw;
  }
}
@media screen and (max-width: 1023px) {
  .welcome__text {
    width: 51.1551155116vw;
  }
}
@media screen and (max-width: 750px) {
  .welcome__text {
    width: 100%;
  }
}
.welcome__img {
  position: absolute;
  top: clamp(40px, 4.39238653vw, 60px);
  right: 0;
  width: min(496px, 36.3103953148vw);
}
@media screen and (max-width: 1180px) {
  .welcome__img {
    width: 29.7218155198vw;
  }
}
@media screen and (max-width: 1023px) {
  .welcome__img {
    width: 37.9537953795vw;
  }
}
@media screen and (max-width: 750px) {
  .welcome__img {
    position: relative;
    top: unset;
    right: unset;
    width: 79.0087463557%;
    margin-inline: auto;
    margin-top: 30px;
  }
}

/* 3steps
-----------------------------------------------*/
.steps__row {
  padding-top: clamp(70px, 8.78477306vw, 120px);
  padding-left: min(538px, 39.3850658858vw);
  padding-bottom: clamp(70px, 8.78477306vw, 120px);
  position: relative;
}
@media screen and (max-width: 750px) {
  .steps__row {
    padding-left: 0;
  }
}
.steps__img {
  display: none;
  justify-content: center;
  align-items: center;
  position: absolute;
  width: 100%;
  height: 100%;
}
.steps__img.is-active {
  display: flex;
}
.steps__img img {
  animation: image-appearance 0.6s linear;
  opacity: 1;
  max-width: unset;
}
.steps__img--step1 img {
  width: 83.0357142857%;
}
.steps__img--step2 img {
  width: 88.1696428571%;
}
.steps__img--step3 img {
  width: 145.9821428571%;
}
.steps__img__wrapper {
  width: min(448px, 32.7964860908vw);
  height: min(448px, 32.7964860908vw);
  position: absolute;
  top: 120px;
  left: 0;
}
@media screen and (max-width: 750px) {
  .steps__img__wrapper {
    display: none;
  }
}
.steps__img__wrapper.is-fixed {
  position: fixed;
  top: calc(120px + clamp(70px, 8.78477306vw, 120px));
  left: max(175px, 15.0073206442vw);
}
@media screen and (min-width: 1367px) {
  .steps__img__wrapper.is-fixed {
    left: calc(50% - 478px);
  }
}
@media screen and (max-width: 1023px) {
  .steps__img__wrapper.is-fixed {
    left: 4.2666666667vw;
  }
}
.steps__img__wrapper.is-bottom {
  top: unset;
  bottom: 120px;
}
.steps__img__base {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #fff;
  position: relative;
}
@media screen and (max-width: 750px) {
  .steps__img__base {
    margin: 30px auto;
    width: min(448px, 77.3333333333vw);
    height: min(448px, 77.3333333333vw);
  }
}
.steps__text + .steps__text {
  margin-top: clamp(80px, 10.2489019034vw, 140px);
}
.steps__text:nth-of-type(2) {
  margin-top: clamp(40px, 4.39238653vw, 60px);
}

.ttl__lv1 + .step__text {
  margin-top: clamp(50px, 5.8565153734vw, 80px);
}
.step__ttl {
  font-size: clamp(21px, 2.0497803807vw, 28px);
  margin-bottom: max(13px, 0.9516837482vw);
  font-weight: 700;
}
.step__ttl--num {
  font-family: "Oswald", sans-serif;
  font-size: clamp(34px, 3.6603221083vw, 50px);
  font-weight: 500;
  margin-right: max(15px, 1.0980966325vw);
  color: #00AFDD;
  vertical-align: min(-0.14px, -0.5124450952vw);
}

@keyframes image-appearance {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  20% {
    opacity: 1;
  }
  30% {
    transform: scale(120%);
  }
  65% {
    transform: scale(90%);
  }
  100% {
    transform: scale(100%);
  }
}
/* swiper
-----------------------------------------------*/
.virtual-tour-swiper,
.simulation-swiper {
  padding-top: 15px;
  padding-bottom: 90px;
  padding-right: 80px;
  margin-right: -80px;
}
@media screen and (min-width: 1367px) {
  .virtual-tour-swiper,
  .simulation-swiper {
    margin-right: calc(603px - 50vw);
  }
}
@media screen and (max-width: 1023px) {
  .virtual-tour-swiper,
  .simulation-swiper {
    margin-right: -4.2666666667vw;
    padding-right: 4.2666666667vw;
  }
}
.virtual-tour-swiper:has(.swiper-button-prev[aria-disabled=true] + .swiper-button-next[aria-disabled=true]),
.simulation-swiper:has(.swiper-button-prev[aria-disabled=true] + .swiper-button-next[aria-disabled=true]) {
  padding-bottom: 0;
}
.virtual-tour-swiper .swiper-button-prev,
.virtual-tour-swiper .swiper-button-next,
.simulation-swiper .swiper-button-prev,
.simulation-swiper .swiper-button-next {
  top: unset;
  bottom: 0;
  width: 60px;
  height: 60px;
  border: 1px solid #00AFDD;
  border-radius: 50%;
}
.virtual-tour-swiper .swiper-button-prev svg,
.virtual-tour-swiper .swiper-button-next svg,
.simulation-swiper .swiper-button-prev svg,
.simulation-swiper .swiper-button-next svg {
  display: none;
}
.virtual-tour-swiper .swiper-button-prev,
.simulation-swiper .swiper-button-prev {
  transform: rotate(180deg);
}
.virtual-tour-swiper .swiper-button-next,
.simulation-swiper .swiper-button-next {
  right: unset;
  left: 75px;
}
.virtual-tour-swiper .swiper-pagination,
.simulation-swiper .swiper-pagination {
  bottom: unset;
  top: calc(100% - 60px);
  left: 145px;
  width: calc(91.4666666667vw - 145px);
  display: flex;
  gap: 8px 0;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.virtual-tour-swiper .swiper-pagination-bullet-active,
.simulation-swiper .swiper-pagination-bullet-active {
  background: #E0472B;
}

/* virtual-tour
-----------------------------------------------*/
@keyframes fuwafuwa {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
.virtual-tour .ttl__lv2 {
  padding-top: clamp(60px, 6.588579795vw, 90px);
}

.virtual-tour-slider .choice {
  font-size: 0;
  margin-top: clamp(50px, 5.1244509517vw, 70px);
}
@media screen and (max-width: 750px) {
  .virtual-tour-slider .choice {
    overflow-x: auto;
    overflow-y: visible;
    margin-right: -4.2666666667vw;
    padding-bottom: 20px;
  }
}
.virtual-tour-slider .choice form {
  width: fit-content;
  display: flex;
  gap: 10px;
  position: relative;
}
@media screen and (max-width: 750px) {
  .virtual-tour-slider .choice form {
    margin-right: 4.2666666667vw;
  }
}
.virtual-tour-slider .choice input {
  display: none;
}
.virtual-tour-slider .choice label {
  font-size: clamp(13px, 1.1713030747vw, 16px);
  font-weight: 700;
  text-align: center;
  padding: 0;
  flex-basis: clamp(115px, 10.6149341142vw, 145px);
  flex-shrink: 0;
  flex-grow: 0;
  height: clamp(133px, 11.420204978vw, 156px);
  cursor: pointer;
  border-radius: 5px;
  position: relative;
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 750px) {
  .virtual-tour-slider .choice label {
    flex-basis: 124px;
  }
}
.virtual-tour-slider .choice label::after {
  content: "";
  width: 12px;
  height: 10px;
  display: block;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #CACCC6;
  position: absolute;
  bottom: -20px;
  left: calc(50% - 6px);
}
.virtual-tour-slider .choice label .virtual-tour-cat-icon {
  position: relative;
  display: block;
  left: 50%;
  transform: translateX(-50%);
}
.virtual-tour-slider .choice label .virtual-tour-cat-icon--img {
  position: relative;
  z-index: 2;
}
.virtual-tour-slider .choice label .virtual-tour-cat-icon--shadow {
  position: absolute;
  bottom: -25px;
  left: 0;
  z-index: 1;
}
.virtual-tour-slider .choice label:nth-of-type(1) {
  flex-basis: clamp(65px, 8.78477306vw, 120px);
  align-items: center;
}
@media screen and (max-width: 750px) {
  .virtual-tour-slider .choice label:nth-of-type(1) {
    flex-basis: 80px;
  }
}
.virtual-tour-slider .choice label:nth-of-type(n+2) {
  align-items: flex-end;
}
.virtual-tour-slider .choice label:nth-of-type(n+2) .virtual-tour-cat-icon {
  position: absolute;
  top: 10px;
}
.virtual-tour-slider .choice label:nth-of-type(2) .virtual-tour-cat-icon {
  width: clamp(84px, 7.2474377745vw, 99px);
}
.virtual-tour-slider .choice label:nth-of-type(2) .virtual-tour-cat-icon--img {
  animation: 4s fuwafuwa infinite;
}
.virtual-tour-slider .choice label:nth-of-type(3) .virtual-tour-cat-icon {
  width: clamp(98px, 8.4187408492vw, 115px);
}
.virtual-tour-slider .choice label:nth-of-type(3) .virtual-tour-cat-icon--img {
  animation: 4s fuwafuwa 2s infinite;
}
.virtual-tour-slider .choice label:nth-of-type(4) .virtual-tour-cat-icon {
  width: clamp(84px, 7.1742313324vw, 98px);
}
.virtual-tour-slider .choice label:nth-of-type(4) .virtual-tour-cat-icon--img {
  animation: 4s fuwafuwa 1.5s infinite;
}
.virtual-tour-slider .choice label:nth-of-type(5) .virtual-tour-cat-icon {
  width: clamp(110px, 8.7115666179vw, 119px);
}
.virtual-tour-slider .choice label:nth-of-type(5) .virtual-tour-cat-icon--img {
  animation: 4s fuwafuwa 1s infinite;
}
.virtual-tour-slider .choice label:nth-of-type(6) .virtual-tour-cat-icon {
  width: clamp(110px, 8.78477306vw, 120px);
}
.virtual-tour-slider .choice label:nth-of-type(6) .virtual-tour-cat-icon--img {
  animation: 4s fuwafuwa 0.5s infinite;
}
.virtual-tour-slider .choice label:hover {
  background: #f4f4f4;
}
.virtual-tour-slider .choice label:hover::after {
  background-color: #8BAF2E;
}
.virtual-tour-slider .choice :checked + label {
  background: #F4F5F2;
}
.virtual-tour-slider .choice :checked + label::after {
  background-color: #8BAF2E;
}
.virtual-tour-slider .slide-item {
  width: 350px;
  background-color: #F0F2ED;
  border: 1px solid #CACCC6;
  border-radius: 5px;
  padding: 30px 30px 20px;
}
@media screen and (max-width: 750px) {
  .virtual-tour-slider .slide-item {
    width: 300px;
    padding: 20px;
  }
}
.virtual-tour-slider .slide-item__img {
  margin-bottom: 20px;
}

.slide-item {
  height: unset;
}
.slide-item__img {
  width: 100%;
  aspect-ratio: 290/163;
  object-fit: cover;
  object-position: center;
}
.slide-item__cat {
  display: inline-block;
  background-color: #fff;
  font-size: clamp(13px, 1.0248901903vw, 14px);
  font-weight: 700;
  color: #8BAF2E;
  padding: 0 5px;
  border-radius: 5px;
  margin-bottom: 10px;
}
.slide-item__title {
  font-size: clamp(17px, 1.4641288433vw, 20px);
  font-weight: 700;
  margin-bottom: 5px;
  line-height: 1.4;
}
.slide-item__text {
  font-size: clamp(12px, 0.9516837482vw, 13px);
  font-weight: 500;
  margin-bottom: 10px;
}
.slide-item__icon {
  margin-bottom: 10px;
}
.slide-item__icon:has(+ .button) {
  margin-bottom: 10px;
}
.slide-item__icon span {
  display: inline-block;
  background-color: #fff;
  font-size: clamp(12px, 0.9516837482vw, 13px);
  font-weight: 500;
  padding: 0 5px;
  border-radius: 5px;
}
.slide-item__icon span + span {
  margin-left: 12px;
}
.slide-item a {
  font-size: clamp(12px, 0.9516837482vw, 13px);
  font-weight: 700;
  color: #00AFDD;
}
.slide-item a.button {
  font-size: 18px;
}
.slide-item__location {
  margin-bottom: 5px;
}
.slide-item__location::before {
  content: "";
  width: 13px;
  height: 15px;
  display: inline-block;
  background-image: url("../img/icon_location.svg");
  background-size: contain;
  margin-right: 8px;
  vertical-align: middle;
}
.slide-item__pdf {
  margin-bottom: 10px;
}
.slide-item__pdf::before {
  content: "";
  width: 11px;
  height: 13px;
  display: inline-block;
  background-image: url("../img/icon_pdf.svg");
  background-size: contain;
  margin-right: 8px;
  vertical-align: middle;
}
.slide-item__simulation {
  margin-top: 15px;
  margin-bottom: 0 !important;
}
.slide-item__simulation::before {
  content: "";
  width: 11px;
  height: 13px;
  display: inline-block;
  background-image: url("../img/icon_simulation_green.svg");
  background-size: contain;
  margin-right: 8px;
  vertical-align: middle;
}

.message {
  margin-top: 25px;
}
.message .result {
  color: #8BAF2E;
  font-weight: 700;
}

/* simulation
-----------------------------------------------*/
.simulation .container {
  position: relative;
  z-index: 2;
}
.simulation .container::before {
  content: "";
  width: min(741px, 54.2459736457vw);
  height: min(428px, 31.3323572474vw);
  display: block;
  position: absolute;
  top: max(-72px, -5.270863836vw);
  right: max(-42px, -3.074670571vw);
  background-image: url("../img/simulation_bg.png");
  background-size: contain;
  z-index: -1;
}
@media screen and (max-width: 750px) {
  .simulation .container::before {
    width: 69.8666666667vw;
    height: 40.2666666667vw;
    top: -10.6666666667vw;
    right: unset;
    left: 37.3333333333vw;
  }
}
.simulation-steps {
  margin-top: 80px;
}
.simulation-steps__title {
  font-size: clamp(17px, 1.4641288433vw, 20px);
  font-weight: 700;
  margin-bottom: clamp(20px, 2.196193265vw, 30px);
}
@media screen and (max-width: 750px) {
  .simulation-steps__title {
    text-align: center;
  }
}
.simulation-step {
  border-right: 4px solid #fff;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  width: 25%;
}
@media screen and (max-width: 750px) {
  .simulation-step {
    border-right: none;
    border-bottom: 4px solid #fff;
    width: min(500px, 100%);
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
.simulation-step:after {
  content: "";
  width: 10px;
  height: 12px;
  display: block;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  background-color: #8BAF2E;
  position: absolute;
  top: calc(50% - 6px);
  right: -10px;
}
@media screen and (max-width: 750px) {
  .simulation-step:after {
    width: 12px;
    height: 10px;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    top: unset;
    bottom: -7px;
    right: unset;
    left: calc(50% - 6px);
  }
}
.simulation-step:last-of-type {
  border: none;
}
.simulation-step:last-of-type::after {
  content: none;
}
.simulation-step__wrapper {
  display: flex;
}
@media screen and (max-width: 750px) {
  .simulation-step__wrapper {
    flex-direction: column;
    align-items: center;
  }
}
.simulation-step__num {
  color: #00AFDD;
  font-family: "Oswald", sans-serif;
  letter-spacing: 0.02em;
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 20px;
}
.simulation-step__text {
  flex-grow: 1;
  font-weight: 500;
}
@media screen and (max-width: 750px) {
  .simulation-step__text {
    text-align: center;
    font-size: 15px;
  }
}
.simulation-step__img {
  width: 138px;
  width: 0 auto;
}
@media screen and (max-width: 750px) {
  .simulation-step__img {
    display: none;
  }
}
.simulation-select {
  margin-top: clamp(50px, 5.8565153734vw, 80px);
}
.simulation-select__dl {
  display: flex;
  gap: 24px;
}
@media screen and (max-width: 750px) {
  .simulation-select__dl {
    display: block;
  }
}
.simulation-select__dl + .simulation-select__dl {
  margin-top: 15px;
}
.simulation-select__dt {
  font-size: clamp(16px, 1.317715959vw, 18px);
  font-weight: 500;
  white-space: nowrap;
}
.simulation-select__button {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 5px;
}
.simulation-select__button input[type=radio] {
  display: none;
}
.simulation-select__button label {
  font-size: clamp(15px, 1.1713030747vw, 16px);
  font-weight: 700;
  padding: 4px 15px 3px;
  background-color: #fff;
  border-radius: 5px;
  color: #00AFDD;
  cursor: pointer;
}
.simulation-select__button label:hover {
  background-color: #00AFDD;
  color: #fff;
}
.simulation-select__button input:checked + label {
  background-color: #00AFDD;
  color: #fff;
}
.simulation-swiper .slide-item {
  width: 330px;
  background-color: #fff;
  border: 1px solid #CACCC6;
  border-radius: 5px;
}
@media screen and (max-width: 750px) {
  .simulation-swiper .slide-item {
    width: 300px;
  }
}
.simulation-swiper .slide-item__img {
  aspect-ratio: 330/221;
  border-radius: 5px 5px 0 0;
}
.simulation-swiper .slide-item__content {
  padding: 18px 30px 30px;
}
@media screen and (max-width: 750px) {
  .simulation-swiper .slide-item__content {
    padding: 20px;
  }
}
.simulation-swiper .slide-item__content .button {
  width: 100%;
}
.simulation-swiper .slide-item__title {
  font-size: clamp(15px, 1.1713030747vw, 16px);
  margin-bottom: 5px;
}
.simulation-swiper .slide-item__icon span {
  background-color: #F0F2ED;
}
.simulation-swiper .slide-item .button {
  text-align: center;
  line-height: 1.4;
}

.simulator_bnr {
  margin: 40px auto 0;
  width: min(303px, 100%);
}

/* showroom
-----------------------------------------------*/
.showroom .container {
  position: relative;
  z-index: 2;
}
.showroom .container::before {
  content: "";
  width: min(1047px, 76.6471449488vw);
  height: min(589px, 43.1185944363vw);
  display: block;
  position: absolute;
  top: max(-150px, -10.980966325vw);
  left: min(552px, 40.4099560761vw);
  background-image: url("../img/showroom_bg.png");
  background-size: contain;
  z-index: -1;
}
@media screen and (max-width: 750px) {
  .showroom .container::before {
    width: 97.7333333333vw;
    height: 54.9333333333vw;
    top: -25.3333333333vw;
    left: 34.6666666667vw;
  }
}
.showroom__contact {
  padding-top: clamp(50px, 5.8565153734vw, 80px);
}

.chat__wrapper {
  width: 100%;
  height: 100%;
  margin-top: 30px;
}
.chat__wrapper iframe {
  width: 100%;
  transition: all 0.5s;
  height: 500px;
}
@media screen and (max-width: 750px) {
  .chat__wrapper iframe {
    height: min(500px, 40vh);
  }
}
.chat__wrapper[aria-hidden=true] iframe {
  height: 0;
}

/* faq
-----------------------------------------------*/
.faq__nav ul {
  display: flex;
  margin: clamp(30px, 2.9282576867vw, 40px) 0 20px;
  gap: 20px;
  justify-content: center;
}
@media screen and (max-width: 750px) {
  .faq__nav ul {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }
}
.faq__nav li {
  color: #00AFDD !important;
  font-weight: 700;
  background-color: #fff;
  position: relative;
}
@media screen and (max-width: 750px) {
  .faq__nav li {
    width: min(303px, 100%);
  }
}
.faq__nav li a {
  display: block;
  padding: 10px 40px 10px 15px;
}
.faq__nav li::after {
  content: "";
  width: 12px;
  height: 10px;
  display: block;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #8BAF2E;
  position: absolute;
  top: calc(50% - 5px);
  right: 15px;
}
.faq__wrapper {
  padding-top: clamp(50px, 5.1244509517vw, 70px);
}
.faq__details {
  background-color: #fff;
  border-radius: 5px;
}
.faq__details + .faq__details {
  margin-top: 20px;
}
.faq__q {
  display: block;
  font-size: clamp(17px, 1.4641288433vw, 20px);
  font-weight: 700;
  line-height: 2;
  position: relative;
  text-indent: calc(-1em - 22px);
  padding: 22px 80px 23px calc(1em + 52px);
  cursor: pointer;
}
@media screen and (max-width: 750px) {
  .faq__q {
    text-indent: calc(-1em - 10px);
    padding: 7px 60px 8px calc(1em + 30px);
  }
}
.faq__q::before {
  content: "Q.";
  font-size: clamp(19px, 1.756954612vw, 24px);
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  margin-right: 22px;
  color: #00AFDD;
}
@media screen and (max-width: 750px) {
  .faq__q::before {
    margin-right: 10px;
  }
}
.faq__q .plus {
  position: absolute;
  width: clamp(20px, 2.196193265vw, 30px);
  height: clamp(20px, 2.196193265vw, 30px);
  right: clamp(20px, 2.196193265vw, 30px);
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
}
.faq__q .plus::before, .faq__q .plus::after {
  content: "";
  display: block;
  background-color: #8BAF2E;
  position: absolute;
}
.faq__q .plus::before {
  width: clamp(20px, 2.196193265vw, 30px);
  height: 3px;
  left: 0;
  top: calc(50% - 1.5px);
}
.faq__q .plus::after {
  content: "";
  width: 3px;
  height: clamp(20px, 2.196193265vw, 30px);
  left: calc(50% - 1.5px);
  top: 0;
  opacity: 1;
  transition: all 0.3s;
}
.faq__a {
  width: calc(100% - 60px);
  margin-inline: 30px;
  padding: 23px 0 22px;
  border-top: 2px solid #E3E3E3;
}
.faq__details[open] .plus::after {
  transform: rotate(90deg);
  opacity: 0;
}

/* information
-----------------------------------------------*/
.information__content {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin: clamp(50px, 5.8565153734vw, 80px) auto;
}
@media screen and (max-width: 750px) {
  .information__content {
    flex-direction: column;
    gap: 60px;
    width: min(500px, 100%);
  }
}
.information__text {
  position: relative;
  padding: clamp(20px, 2.196193265vw, 30px) clamp(30px, 2.9282576867vw, 40px);
  font-size: clamp(17px, 1.4641288433vw, 20px);
  font-weight: 700;
  line-height: 1.6;
  color: #2C373A;
  text-align: center;
}
@media screen and (max-width: 1040px) {
  .information__text {
    padding: clamp(20px, 2.196193265vw, 30px);
  }
}
@media screen and (max-width: 800px) {
  .information__text {
    font-size: 16px;
  }
}
@media screen and (max-width: 750px) {
  .information__text {
    padding: clamp(20px, 2.196193265vw, 30px) clamp(30px, 2.9282576867vw, 40px);
    font-size: clamp(17px, 1.4641288433vw, 20px);
  }
}
.information__text::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  background-color: #F4F5F2;
  border-radius: 5px;
  top: 0;
  left: 0;
  transform: rotate(-6deg);
  z-index: -1;
}
@media screen and (max-width: 750px) {
  .information__text::before {
    transform: rotate(-4deg);
  }
}
.information__text:nth-last-of-type(2)::before {
  transform: rotate(4deg);
}
@media screen and (max-width: 750px) {
  .information__text:nth-last-of-type(2)::before {
    transform: rotate(3deg);
  }
}
@media screen and (max-width: 750px) {
  .information__text:nth-last-of-type(3)::before {
    transform: rotate(-2deg);
  }
}
.information__text::after {
  content: "";
  width: 10px;
  height: 25px;
  position: absolute;
  bottom: -35px;
  left: calc(50% - 5px);
  background-image: url("../img/information_dot.svg");
  background-size: contain;
}

/* PDF行を完全に不可視（高さは維持） */
.slide-item__pdf.is-hidden,
.slide-item__pdf.is-hidden * {
  visibility: hidden !important;
}

/* アイコン(::before)も消す */
.slide-item__pdf.is-hidden::before {
  visibility: hidden !important;
}

/* 念のためクリックも無効化 */
.slide-item__pdf.is-hidden {
  pointer-events: none;
}
