@charset "utf-8";

/*----------------------------------------------------------------------

	TOP

----------------------------------------------------------------------*/
#top {
    background: linear-gradient(rgb(255, 255, 255), rgb(247, 247, 223), rgb(247, 247, 223));
    font-family: var(--font-nb);
}

#logo {
    width: 100%;
    max-width: 1000px;
    margin: clamp(0px, 6vw, 60px) auto clamp(0px, 1vw, 10px);
}

#menu {
    aspect-ratio: 1000 / 800;
    background: url("../img/top/menu_bg.png") no-repeat center center / cover;
    padding-top: clamp(0px, 11.2vw, 112px);
    display: flex;
    flex-direction: column;
    gap: clamp(0px, 4.4vw, 44px);
    position: relative;
}

#menu::before {
    content: "";
    width: clamp(0px, 11.5vw, 115px);
    aspect-ratio: 115 / 65;
    background: url("../img/top/icon_use.svg") no-repeat center center / contain;
    position: absolute;
    top: clamp(0px, 2vw, 20px);
    right: clamp(0px, 11vw, 110px);
}

#menu li {
    margin-left: 11.5%;
    margin-right: 10.5%;
}

#menu li a {
    width: 100%;
    height: clamp(0px, 11.7vw, 117px);
    font-weight: bold;
    color: #fff;
    display: flex;
    align-items: center;
    position: relative;
}

#menu li:nth-child(1) a,
#menu li:nth-child(2) a { font-size: clamp(0px, 6.3vw, 63px); }
#menu li:nth-child(3) a { font-size: clamp(0px, 5.6vw, 56px); } 
#menu li:nth-child(4) a { font-size: clamp(0px, 5.6vw, 56px); letter-spacing: -0.04em; }

#menu .floor {
    width:  clamp(0px, 14.1%, 110px);
    font-size: clamp(0px, 7.2vw, 72px);
    font-weight: 600;
    position: relative;
    top: -0.1em;
}

#menu li a .em {
    font-size: 1.3em;
}

.icon_camera {
    width:  clamp(0px, 10.5vw, 105px);
}

#menu li .icon {
    width: clamp(0px, 12vw, 120px);
    aspect-ratio: 120 / 130;
    position: absolute;
    top: clamp(-17px, -1.7vw, 0px);
    right: 0;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
}
#menu li .icon::before {
    content: "";
    visibility: hidden;
}

#menu li:nth-child(1) a .icon { background-image: url("../img/top/menu_red.png");}
#menu li:nth-child(2) a .icon { background-image: url("../img/top/menu_orange.png");}
#menu li:nth-child(3) a .icon { background-image: url("../img/top/menu_green.png");}
#menu li:nth-child(4) a .icon { background-image: url("../img/top/menu_l_green.png");}

#menu li:nth-child(1) a:active .icon,
#menu li:nth-child(1) .icon::before { background-image: url("../img/top/menu_red_on.png"); }
#menu li:nth-child(2) a:active .icon,
#menu li:nth-child(2) .icon::before { background-image: url("../img/top/menu_orange_on.png"); }
#menu li:nth-child(3) a:active .icon,
#menu li:nth-child(3) .icon::before { background-image: url("../img/top/menu_green_on.png"); }
#menu li:nth-child(4) a:active .icon,
#menu li:nth-child(4) .icon::before { background-image: url("../img/top/menu_l_green_on.png"); }

.spot_link {
    height: clamp(0px, 68vw, 680px);
    position: relative;
    background: url("../img/bg_foot.png") no-repeat center bottom -1px / 100% auto;
}

.spot_link .bg_img {
    width: 100%;
    position: absolute;
    top: clamp(-60px, -6vw, 0px);
    z-index: 0;
}

.spot_link .bg_img img {
    width: 1000px;
    max-width: 100%;
}

.monoshiri_spot {
    width: 25%;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 2;
    top: clamp(0px, 16.5vw, 165px);
    left: 9%;
}

.monoshiri_spot p {
    font-weight: 600;
    text-align: center;
    line-height: 1.1em;
    color: #fff;
}

.monoshiri_spot .text_1 {
    font-size: clamp(0px, 5.2vw, 52px);
    letter-spacing: 0.02em;
}

.monoshiri_spot .text_2 {
    font-size: clamp(0px, 3.7vw, 37px);
    margin-top: 0.1em;
    margin-bottom: 0.5em;
}

.monoshiri_spot a {
    width: clamp(0px, 12vw, 120px);
    aspect-ratio: 120 / 130;
    background-image: url("../img/top/spot_button.png");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    position: relative;
}
.monoshiri_spot a::before {
    content: "";
    visibility: hidden;
}

.monoshiri_spot a:active,
.monoshiri_spot a::before {
    background-image: url("../img/top/spot_button_on.png");
}

.spot_link .language {
    width: clamp(0px, 14vw, 140px);
    aspect-ratio: 140 / 180;
    background: url("../img/top/lang_button.png") no-repeat top center / contain;
    position: absolute;
    top: clamp(0px, 44.5vw, 445px);
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 2;
}
.spot_link .language::before {
    content: "";
    visibility: hidden;
}
.spot_link .language:active,
.spot_link .language::before {
    background: url("../img/top/lang_button_on.png") no-repeat top center / contain;
}

.spot_link .note {
    font-size: clamp(0px, 2.7vw, 27px);
    font-weight: 800;
    line-height: 1.5em;
    position: absolute;
    top: clamp(0px, 56vw, 560px);
    right: 2em;
}


/*-----------------------------------
	言語選択
-----------------------------------*/
.lang_overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(33,33,33,0.2);
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.lang_overlay.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.lang_menu {
    width: clamp(0px, 70.5vw, 705px);
    aspect-ratio: 705 / 515;
    background: url("../img/top/lang_bg.svg") no-repeat center center / contain;
    position: absolute;
    top: clamp(0px, 92.5vw, 925px);
    left: 0;
    right: 0;
    margin: auto;
    opacity: 0;
    transform: translateY(10px);
    pointer-events: none;
    transition: all 0.3s ease;
    z-index: 1001;
}

.lang_menu.active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.lang_menu_text {
    font-size: clamp(0px, 4.9vw, 49px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
    margin-top: clamp(0px, 14.5vw, 145px);
}

.lang_menu_list {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0 clamp(0px, 3vw, 30px);
}

.lang_option {
    width: clamp(0px, 27.5vw, 275px);
    display: block;
    background: url("../img/top/lang_menu_bg.svg") no-repeat center center / contain;
    border: none;
    cursor: pointer;
    margin-top: clamp(0px, 11vw, 110px);
    padding: 0;
    position: relative;
}
.lang_option::before {
    content: "";
    visibility: hidden;
}

.lang_option::before,
.lang_option:active {
    background-image: url("../img/top/lang_menu_bg_on.svg");
}


/*----------------------------------------------------------------------

	PAGE

----------------------------------------------------------------------*/
#page {
    background-color: #f7f7df;
    padding-top: clamp(0px, 11vw, 110px);
    padding-bottom: clamp(0px, 20vw, 200px);
    position: relative;
    z-index: 1;
}

#page::after {
    content: "";
    width: 100%;
    aspect-ratio: 1000 / 200;
    background: url("../img/page/bg_foot.png") no-repeat center bottom / cover;
    position: absolute;
    bottom: -1px;
    left: 0;
    z-index: 1;
}


/*-----------------------------------
	header
-----------------------------------*/
#header {
    width: 100%;
    max-width: 1000px;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 1000;
}

#header .button_top {
    width: clamp(0px, 10vw, 100px);
    aspect-ratio: 1 / 1;
    background: url("../img/button_top.png") no-repeat center center / contain;
    position: absolute;
    top: 3vw;
    right: 1vw;
}

#header .button_top::before {
    content: "";
    visibility: hidden;
}

#header .button_top::before,
#header .button_top:active {
    background-image: url("../img/button_top_on.png");
}


/*-----------------------------------
	footer
-----------------------------------*/
#footer {
    width: 100%;
    display: flex;
    justify-content: center;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 900;
}

.foot_img {
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    pointer-events: none;
}

.footer_nav {
    width: clamp(0px, 87.5%, 875px);
    padding-bottom: clamp(0px, 3vw, 30px);
    display: flex;
    justify-content: space-between;
}

.footer_nav span {
    visibility: hidden;
}

.button_nav {
    width: clamp(0px, 34vw, 340px);
    aspect-ratio: 340 / 112;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    position: relative;
    margin-top: clamp(0px, 3vw, 30px);
}
.button_nav::before {
    content: "";
    visibility: hidden;
}

.button_nav.back { background-image: url("../img/footer/back.png"); }
.button_nav.back::before,
.button_nav.back:active { background-image: url("../img/footer/back_on.png"); }
.button_nav.next { background-image: url("../img/footer/next.png"); }
.button_nav.next::before,
.button_nav.next:active { background-image: url("../img/footer/next_on.png"); }

.button_go {
    width: clamp(0px, 13vw, 130px);
    aspect-ratio: 130 / 140;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    position: relative;
}
.button_go::before {
    content: "";
    visibility: hidden;
}
.button_go.red { background-image: url("../img/footer/go_red.png"); }
.button_go.red::before,
.button_go.red:active { background-image: url("../img/footer/go_red_on.png"); }
.button_go.orange { background-image: url("../img/footer/go_orange.png"); }
.button_go.orange::before,
.button_go.orange:active { background-image: url("../img/footer/go_orange_on.png"); }
.button_go.green { background-image: url("../img/footer/go_green.png"); }
.button_go.green::before,
.button_go.green:active { background-image: url("../img/footer/go_green_on.png"); }
.button_go.l_green { background-image: url("../img/footer/go_l_green.png"); }
.button_go.l_green::before,
.button_go.l_green:active { background-image: url("../img/footer/go_l_green_on.png"); }

.go_comment {
    position: absolute;
    top: clamp(-80px, -8vw, 0px);
    left: 0;
    right: 0;
    margin: auto;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
}
.go_comment.red { width: clamp(0px, 31vw, 310px);}
.go_comment.l_green { width: clamp(0px, 37.5vw, 375px);}
.go_comment.green { width: clamp(0px, 22vw, 220px);}
.go_comment.orange { width: clamp(0px, 26vw, 260px);}
.go_comment.monoshiri { width: clamp(0px, 32.5vw, 325px);}


/*-----------------------------------
	title
-----------------------------------*/
#page_title {
    font-size: clamp(0px, 6.1vw, 61px);
    font-weight: 700;
    line-height: 1;
    font-family: var(--font-nb);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0 clamp(0px, 3vw, 30px);
    padding: clamp(0px, 2vw, 20px) 0 0;
    position: relative;
}

#page_title.red { color: var(--color-pink); }
#page_title.orange { color: var(--color-orange); }
#page_title.green { color: var(--color-green); }
#page_title.l_green { color: var(--color-l-green); }

#page_title .icon {
    font-size: clamp(0px, 7.8vw, 78px);
    font-weight: 600;
    position: relative;
    top: -0.1em;
}

#page_title .icon .em {
    font-size: 1.3em;
}

#page_title.l_green {
    gap: 0 clamp(0px, 1vw,10px);
}
#page_title.l_green .icon img {
    width: clamp(0px, 10.5vw, 105px);
}

#page_title.monoshiri {
    gap: 0 clamp(0px, 2vw, 20px);
}
#page_title.monoshiri .icon img {
    width: clamp(0px, 7vw, 70px);
}

.title_line {
    width: clamp(0px, 100vw, 1000px);
    aspect-ratio: 1000 / 8;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}

/*-----------------------------------
	main
-----------------------------------*/
.main_cont {
    width: 100%;
    position: relative;
}

.img_area {
    width: 100%;
    position: relative;
    z-index: 1;
}

.text_area {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}

.text_area p {
    line-height: 1.6em;
    font-weight: 500;
    position: absolute;
}

.text_area.floor_5 p { color: var(--color-red); }
.text_area.floor_5 .text_1 { font-size: clamp(0px, 3.8vw, 38px); top: 10%; left: 37%; }
.text_area.floor_5 .text_2 { font-size: clamp(0px, 3.6vw, 36px); top: 28.5%; left: 10%; }
.text_area.floor_5 .text_3 { font-size: clamp(0px, 3.6vw, 36px); top: 42.5%; left: 22.5%; }
.text_area.floor_5 .mark {
    background: var(--color-red);
    height: calc(tan(60deg) * 0.8em / 2);
    width: 1em;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    display: inline-block;
    margin: 0 0.2em;
}

.text_area.floor_3 p { color: var(--color-brown); font-size: clamp(0px, 4.2vw, 42px); line-height: 1.4em; }
.text_area.floor_3 .text_1 { top: 4%; left: 24%; }

.text_area.floor_1 p { color: var(--color-green2); font-size: clamp(0px, 3.8vw, 38px); }
.text_area.floor_1 .text_1 { top: 10.5%; left: 3.5%; }
.text_area.floor_1 .text_2 { font-size: clamp(0px, 3.6vw, 36px); top: 66.7%; left: 19%; line-height: 1.5em; }

.text_area.photo_spot p { color: var(--color-green2); font-size: clamp(0px, 4.1vw, 41px); }
.text_area.photo_spot .text_1 { top: 3%; left: 16%; line-height: 1.5em; }
.text_area.photo_spot .text_2 { top: 24%; left: 28%; }
.text_area.photo_spot .text_3 { top: 28.5%; left: 33.5%; }
.text_area.photo_spot .text_4 { top: 33%; left: 35.5%; }

.text_area.monoshiri p { color: var(--color-brown); font-size: clamp(0px, 3.8vw, 38px); }
.text_area.monoshiri .text_1 { top: 7%; left: 16%; }

