[x-cloak] {
	display: none;
}


* {
	margin: 0;
	padding: 0;
	font-size: min(2vw, 1.25rem);
	font-family: "Noto Serif JP","游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
}

*::selection {
	background-color: inherit;
}

img {
	pointer-events: none;
}

/* html {
	width: max-content;
	overflow-x: hidden;
	overflow-y: scroll;
} */


body {
	margin: 0;
	position: relative;
	background-color: white;
	width: 100%;
	height: 100vh;
	height: 100lvh;
	overflow-y: scroll;
	overflow-x: hidden;
	box-sizing: border-box;
}

.sound_check {
	position: fixed;
	width: 100%;
	height: 100%;

	z-index: 99;
	color: white;

	display: flex;
	justify-content: center;
	align-items: center;

}

.sound_check .container {
	align-items: center;
	text-align: center;
}

.sound_check .container .title {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: min(3vw, 1.5rem);
	margin-bottom: 5%;
	letter-spacing: 0.2rem;
}

.sound_check .container .buttons {

	display: flex;
	justify-content: space-around;
	gap: 3rem;
	flex-wrap: wrap;
	padding-top: 5%;

}

.sound_check .container .buttons .button {
	width: 10rem;
	text-align: center;
	border-radius: 2px;
	background-color: #2E595E;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	cursor: pointer;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: min(2vw, 1rem);
	pointer-events: fill;
}

.sound_check .container .buttons .button:hover {
	filter: brightness(1.5);
}

.sound_check .container .buttons .button:active {
	filter: brightness(0.5);
}

.sound_check .container .buttons .button::selection {
	background-color: inherit;
}


.sound_control {

	font-size: min(2vw, 1.25rem);
	width: 2rem;
	height: 2rem;
	position: fixed;
	bottom: 0.5rem;
	right: 0.5rem;
	z-index: 50;
	border-radius: 9999px;
	background-color: #2E595E;
	display: none;
	justify-content: center;
}

.sound_control svg {
	margin: 0.5rem;
	font-size: min(2vw, 1.25rem);
}

.gradient {
	display: block;
	background: linear-gradient(345.37deg, #6DC19F 9.36%, #C9DBC7 92.58%);
	width: 100%;
	height: 100%;
	z-index: 0;
	
	pointer-events: none;
	position: relative;
}

.loading-animation {
	position: absolute;
	width: 100vw;
	object-fit: cover;
	left: -25vw;
}

#mask_flower {
	width: 100%;
	height: 100%;
}
s

.color-snake {
	position: absolute;
	inset: 0 0 0 0;
	margin: auto;
	width: 1200px;
	max-width: 1200px;
	transition: opacity 800ms ease;
}



.loading {
	width: 100dvw;
	height: 100vh;
	height: 100lvh;
	align-items: center;
	text-align: center;
	display: flex;
	justify-content: center;
	pointer-events: none;
}

main {
	width: 100%;
	overflow-x: hidden;
}

.img_container {
	position: relative;
	z-index: 50;
}



.img_scroll {
	height: min(25vmin, 150px);
	position: fixed;
	bottom: 16px;
	left: 24px;
	animation: bounce2 1.5s ease infinite;
}

.loading-video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 5;
}

@keyframes bounce2 {

	0%,
	20%,
	50%,
	80%,
	100% {
		transform: translateY(0);
	}

	40% {
		transform: translateY(-15px);
	}

	60% {
		transform: translateY(-5px);
	}
}

.content {
    background: linear-gradient(345.37deg, #6DC19F 9.36%, #C9DBC7 92.58%);
	z-index: 0;
}

.top {
	position: relative;
	width: 100%;
	height: 10px;
}

.top .bg {
	width: 100vw;
	height: 90vh;
	object-fit: cover;
	object-position: center;
	position: absolute;
	top: 0;
}

.top .kinga_logo {
    position: absolute;
    inset: 8vh 0 0 0;
    margin: 0 auto;

    width: 18%;
	max-width: 400px;
    object-fit: cover;
}

.top .hana_area {
	position: relative;

	width: 100vw;
	height: 100vh;
}


@keyframes rotation-r {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

@keyframes rotation-l {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(-360deg);
	}
}

.top .r-b {
	position: absolute;
	right: 0;
	top: 65vh;

	width: 500px;
	height: 350px;
}

.hana_0 {
	width: 200px;
}


.hana_red {
	width: 130px;
}

.hana_blue {
	width: 100px;
}

.hana_pink {
	width: 100px;
}

.hana_small {
	width: 40px;
}

.top .r-b .hana_0 {
	position: absolute;
	top: 0;
	left: 35%;
}

.top .r-b .hana_blue {
	position: absolute;
	top: 25%;
	left: 45%;
	animation: rotation-r 10s linear infinite;
}

.top .r-b .hana_blue_2 {
	top: unset;
	bottom: 0;
	left: 45%;
	width: 80px;
	transform: rotate(45deg);
	animation: rotation-r 10s linear infinite;
}

.top .r-b .hana_red {
	position: absolute;
	bottom: 0;
	left: 10%;
	animation: rotation-r 10s linear infinite;
}

.top .r-b .hana_red_2 {
	width: 110px;
	bottom: unset;
	top: 35%;
	left: unset;
	right: 15%;
	animation: rotation-l 10s linear infinite;
}

.top .r-b .hana_pink {
	position: absolute;
	top: 50%;
	left: 35%;
	animation: rotation-l 10s linear infinite;
}

.top .r-b .hana_small {
	position: absolute;
	top: 25%;
	left: 25%;
	animation: rotation-l 10s linear infinite;
}
.top .r-b .hana_small_2 {
	position: absolute;
	top: 75%;
	left: 30%;
	animation: rotation-r 10s linear infinite;
}
.top .r-b .hana_small_3 {
	position: absolute;
	top: 25%;
	left: unset;
	right: 40px;
	animation: rotation-l 10s linear infinite;
}

.top .l-t {
	position: absolute;
	left: 0;
	top: 0;

	width: 300px;
	height: 400px;
}

.top .l-t .hana_0 {
	position: absolute;
	top: 0;
	right: 0;
}

.top .l-t .hana_pink {
	position: absolute;
	top: 25%;
	right: 25%;
	animation: rotation-r 10s linear infinite;
}

.top .l-t .hana_red {
	position: absolute;
	top: 45%;
	left: 10%;
	animation: rotation-l 10s linear infinite;
}

.top .l-t .hana_blue {
	position: absolute;
	bottom: 0;
	left: 20%;
	animation: rotation-r 10s linear infinite;
}

.top .l-t .hana_small {
	position: absolute;
	top: 12.5%;
	right: 0;
	animation: rotation-l 10s linear infinite;
}

.top .l-t .hana_small_2 {
	position: absolute;
	top: 25%;
	right: 200px;
	animation: rotation-r 10s linear infinite;
}

.top .l-t .hana_small_3 {
	position: absolute;
	top: 50%;
	right: 40%;
	animation: rotation-l 10s linear infinite;
}

.top .l-t .hana_small_4 {
	position: absolute;
	top: 75%;
	right: 87.5%;
	animation: rotation-r 10s linear infinite;
}

.top .l-t .hana_small_5 {
	position: absolute;
	top: 100%;
	right: 50%;
	animation: rotation-l 10s linear infinite;
}



.top .tsuki {
	position: absolute;
	width: 10vw;
	object-fit: cover;
	object-position: right;
	top: 20vh;
	right: 30vw;
	transition: 1000ms;
}

.top .fuji {
	position: absolute;
	width: 65vw;
	object-fit: cover;
	object-position: right;
	top: 35vh;
	right: -5vmax;
}

.top .yama{
	position: absolute;
	object-fit: cover;
	object-position: center;
	top: 45vh;
	width: 100vw;
	
}

.top .kumo_l {
	position: absolute;
	top: 0;
	left: calc(45vw * 0.3 * -1);
	width: 45vw;
	max-width: 900px;
	object-fit: cover;
	object-position: top left;
	transition: 1000ms;
}

.top .kumo_l_2{
	top: 40vh;
	max-width: 600px;
	width: 28vw;
	left: calc(28vw * 0.3 * -1);
}

.top .kumo_r {
	position: absolute;
	width: 43vw;
	max-width: 800px;
	object-fit: cover;
	object-position: right;
	right: calc(43vw * 0.43 * -1);
	top: 40vh;
	transition: 1000ms;
	transform: translateY(calc(50lvh, 50vh));
}

.top .kumo_r_2 {
	top: 15vh;
	width: 28vw;
	max-width: 600px;
	right: calc(28vw * 0.3 * -1);
}

.top .kawa {
	position: absolute;
	width: 100vw;

	object-fit: cover;
	top: 70vh;
}

.top .top_hebi {
	position: absolute;
	width: 25vw;
	max-width: 650px;
	object-fit: cover;
	top: 45vh;
	left: 15vw;
}


.top .top_header {
	width: 100%;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;

	display: flex;
	justify-content: center;
}


.top .top_header .svg_container {
	max-width: 600px;
    width: 100%;
	position: relative;
}

.top .top_header .svg_container svg {
	position: absolute;
    inset: 0 0 0 0 ;
    margin: auto;
}

.top .top_header .kinga_logo {
    position: absolute;
    inset: 0 0 0 0;
    margin: auto;
}



.gradient-background {
	background: linear-gradient(345.37deg, #6DC19F 9.36%, #F9F0CD 64.26%, #F0ECCB 71.98%, #D9E2C9 84.85%, #C9DBC7 92.58%);

}


.greeting {
	margin-top: 100svh;
	padding: 25vw 0;

	width: 100vw;
	height: 130vh;

	display: flex;
	justify-items: center;
	align-items: center;
	text-align: center;

	line-height: 200%;
	position: relative;
}

.greeting .message {
	width: 1000px;

	aspect-ratio: 1;
	/* background-color: white;
	border-radius: 50%; */

	font-size: 15px;

	position: relative;
	inset: 0 0 0 0;
	margin: auto;

	line-height: 1.6;

	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5%;

	border: 2px solid;
	border-image-source: linear-gradient(180deg, #927E53 0%, #FEFBEE 100%);
	z-index: 4;
}

.greeting .message_frame {
	position: absolute;
	top: 0;
	margin: 0 auto;
	width: 100%;
	height: 100%;
	z-index: 5;
}

.greeting .message_hana {
	position: absolute;
	top: 0;
	left: 80px;
	width: 350px;
}



.greeting  .message_himo {
	width: 40%;
	position: absolute;
	top: 10%;
	margin: 0 auto;
	z-index: 7;
}

.greeting  .logo {
	width: 10%;
	z-index: 7;
}
 
.greeting .message_hebi {
	position: absolute;
	top: calc(50vh + 120px);
	left: calc(50vw + 300px) ;
	width: 25vw;
	max-width: 780px;
	object-fit: cover;
	z-index: 4;
}

.greeting_kirakira {
	position: absolute;
	top: 90vh;
	left: -15vw;
	width: 50vw;
	object-fit: cover;
}

.greeting .kumo_l {
	position: absolute;
	top: 35%;
	left: calc(45vw * 0.45 * -1);
	width: 45vw;
	max-width: 900px;
	object-fit: cover;
	object-position: top left;
}

.greeting .kumo_l_2{
	top: 55%;
	max-width: 600px;
	width: 28vw;
	left: calc(28vw * 0.3 * -1);
	z-index: 1;
}

.greeting .kumo_r {
	position: absolute;
	width: 43vw;
	max-width: 800px;
	object-fit: cover;
	object-position: right;
	right: calc(43vw * 0.43 * -1);
	top: 50%;
}

.greeting .kumo_r_2 {
	top: 35%;
	width: 28vw;
	max-width: 600px;
	right: calc(28vw * 0.3 * -1);
}


.greeting .kawa {
	position: absolute;
	width: 100vw;

	object-fit: cover;
	bottom: -20vw;
	z-index: 1;
}


.message p {
	font-size: 26px;
	font-weight: 500;
	line-height: 2;
	z-index: 8;
}

.omikuji {
	position: relative;
	width: 100%;
	height: auto;
	box-sizing: border-box;
	margin-top: 50vh;
}

.omikuji .omikuji_hebi {
	position: absolute;
	top: -60%;
	left: -10%;
	width: 70vw;
	max-width: 1200px;
	object-fit: cover;
	z-index: 1;
}


.omikuji .img_hex_r {
	position: absolute;
	width: 40vmin;
	object-fit: contain;
	object-position: bottom right;
	bottom: 20%;
	right: 0;
}

.omikuji .container {
	display: flex;
	flex-direction: column;
	justify-content: center;
	max-height: 92vh;
	max-height: 92lvh;
	padding-bottom: 5%;
	position: inherit;
	z-index: 2;
}

.omikuji .container p {
	font-family: "Noto Serif JP","游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
	font-size: 20px;
	text-align: center;
	z-index: 100;
	margin: 2vh;
	color: #595959;
	font-weight: 600;
	letter-spacing: .2rem;
}

.sub_ttl {
	width: 50vmin;
	display: block;
	margin: 0 auto;
	position: relative;
	z-index: 99;
}

.sub_ttl_hana {
	width: 25vmin;
	position: absolute;
	top: 5%;
	left: 50%;
	z-index: 3;
	transform: rotate(18deg);
}

.sub_ttl_hana2 {
	width: 25vmin;
    position: absolute;
    top: 0;
    right: 50%;
    transform: rotate(223deg);
	z-index: 3;
}

.kuji_relative {
	position: relative;
	width: 100%;
	height: 50vmin;
}

.kirakira {
	display: block;
	width: 50vmax;
	min-width: 65vmin;
	height: 700px;

	position: absolute;
	inset: -50vmin 0 0 0;
	margin: auto;
}

.kuji_en1 {
	display: block;
	width: 50vmin;
	aspect-ratio: 1;

	position: absolute;
	inset: 0 0 0 0;
	margin: auto;
}

.kuji_hebi {
	display: block;
	width: 40vmin;
	aspect-ratio: 1;

	position: absolute;
	inset: 0 0 0 0;
	margin: auto;
	transition: opacity 800ms ease;
}

.kuji_atari {
	display: block;
	width: 30vmin;
	aspect-ratio: 1;

	position: absolute;
	inset: 0 0 0 0;
	margin: auto;
}


.kuji_cover {
	display: block;
	width: 28vmin;
	aspect-ratio: 1;
	position: absolute;
	inset: 0 0 0 0;
	margin: auto;
	border-radius: 50%;
	z-index: 4;
}

.scratch_result_image {
	position: absolute;
	z-index: 1;
	display: block;
	width: 28vmin;
	aspect-ratio: 1;

	position: absolute;
	inset: 0 0 0 0;
	margin: auto;
	cursor: pointer;
}

.omikuji .container .kuji {
	width: 100%;
	aspect-ratio: 1;
	padding: 1% 0;
	will-change: transform, animation;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
}

.omikuji .container .kuji #top_circle {
	animation: rotate 20s linear infinite;
	transform-origin: 50% 50%;
}

.omikuji .container .kuji #touch_circle {
	cursor: url('../img/pointer.png'), auto;
}

.omikuji .container .kuji .item {
	filter: drop-shadow(0px 0px 5px #d3d3d3);
	cursor: url('../img/pointer.png'), auto;

}

.omikuji .container .kuji .item:hover {
	filter: brightness(1.5);
}

@keyframes rotate {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}

.footer {
	width: 100dvw;
	color: white;
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: 10vh;
}

.footer .message {
	width: 95%;
	text-align: center;
	position: absolute;
	top: -30px;
	color: #404040;
	font-size: min(2vw, 30px);
	line-height: 1.5em;
	letter-spacing: 0.2em;
}

.footer_mori {
	width: 100%;
	height: 20vw;
	object-fit: cover;
	object-position: top;
}


.footer_img {
	width: 100%;
	max-height: 160px;
	object-fit: cover;
	z-index: 10;
}


.footer>.copyright {

	text-align: center;
	font-size:min(1.5vw, 20px);
	position: absolute;
	bottom: 10%;
	z-index: 15;
	color: #222222;
	font-weight: 400;
	font-family: 'ヒラギノ角ゴ ProN W3', sans-serif;
}

span.selector {
	font-feature-settings: "palt";
	font-size: min(2vw, 30px);
}

span.copyright {
	font-size: min(1.5vw, 20px);
	font-family: 'ヒラギノ角ゴ ProN W3', sans-serif;
}


#particles {
	position: fixed;
	top: 0;
	left: 0;
	width: 100dvw;
	height: 100vh;
	height: 100lvh;
	overflow: hidden;

	z-index: -1;

	pointer-events: none;
}

.overlay {
	position: fixed;
	background: #6dc19f4d;
	z-index: 100;

	top: 0;
	bottom: 0;

	left: 0;
	right: 0;

	display: flex;
	justify-content: center;
	align-items: center;
}

.overlay .loading_item {
	display: flex;
	justify-content: center;
	position: inherit;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	align-items: center;
}

.loading_item img {
	animation: rotate 1s linear infinite;
	width: min-content;
	height: min-content;

}

.overlay .container {
	padding: 16px;
	position: absolute;
	margin: 0 auto;
}

.kuji_image {
	position: absolute;
	top: 0;
	left: 0;

	width: 100%;
	height: 100%;

	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;

	transform: rotateY(180deg);

}

.kuji_image img {
	object-fit: contain;
	width: 100%;
	height: 100%;
}

.omikuji_result {
	height: 100%;
	width: 100%;

	position: relative;
}

.omikuji_result img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.omikuji_close {
	position: absolute;
	width: 20%;
	inset: 50% 0 0 0;
	margin: auto;
	cursor: pointer;
}


/* アニメ用のCSS x-transiton系で使う */
.hebi_show_enter {
	transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
	transition-duration: 1500ms;
}


.item_show_enter {
	transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
	transition-duration: 1000ms;
	transition-delay: 1000ms;
}

.item_show_start {
	opacity: 0;
	translate: -100% 0;
	scale: 0.8;

}

.item_r_show_start {
	opacity: 0;
	translate: 100% 0;
	scale: 0.8;
}

.item_show_end {
	transform: translateX(0);
	opacity: 1;
	scale: 1;

}

.message_hebi_show_end {
	translate: 0 -40%;
}

.message_hebi_show_start {
	opacity: 0;
	translate: 20% -20%;
	transition-duration: 2000s;
	scale: 0.8;
}

.omikuji_hebi_show_start {
	translate: -10% -15%;
	transition-duration: 2000ms;
	transition-delay: 1000ms;
	scale: 0.8;
	/* opacity: 0; */
}

.omikuji_hebi_fadeout { 
    animation: fadeOut 2s ease;
    animation-fill-mode: both; 
}
  
@keyframes fadeOut {
    0% {
        opacity: 1; 
    }
	50% {
        opacity: 1;
    }
	75% {
        opacity: 0.5; 
    }
    100% {
        opacity: 0; 
    }
}

.omikuji_hebi_show_end {
	opacity: 0;
}

.omikuji_show_end {
	transform: translateX(0);
	opacity: 0;
	scale: 1;
}

.tsuki_show_start {
    opacity: 0;
	translate: 0 200%;
	
	scale: 0.8;
}

.omikuji_container_enter {
	transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
	transition-duration: 700ms;
	transition-delay: 1s;
}

.omikuji_show_container_start {
	opacity: 0;
}

.omikuji_show_container_end {
	opacity: 100;
}

.omikuji_show_enter {
	transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
	transition-duration: 500ms;
	transition-delay: 800ms;
}

.omikuji_show_front_start {
	transform: rotateY(0);
}

.omikuji_show_front_end {
	transform: rotateY(180deg);
}

.omikuji_show_back_start {
	transform: rotateY(180deg);
}

.omikuji_show_back_end {
	transform: rotateY(0);
}

.header_item_show {
	transition-duration: 500ms;
	transition-delay: 1800ms;
}

.header_item_show_start {
	opacity: 0;
	scale: 0.95;
}

.header_item_show_end {
	opacity: 1;
	scale: 1;
}

.sp-br {
	display: none;
}

.pc {
	display: block;
}

.sp {
	display: none;
}



@media screen and (max-width: 767px) and (orientation: portrait) {
	* {
		font-size: min(4vw, 1.5em);
	}

	.sp-br {
		display: block;
	}

	.pc {
		display: none;
	}
	
	.sp {
		display: block;
	}
	
	.top .fuji {
        top: calc(100svh - 90vw);
        width: 110vw;
        right: -30vw;
    }
	.top .yama {
		top: calc(100svh - 70vw);
		width: 140vw;
	}

	.top .kawa {
		width: 126vw;
		left: -13vw;
		top: calc(100svh - 38vw);
	}

	.top .top_hebi {
		width: 45vw;
        top: calc(100svh - 80vw);
        left: 5vw;
	}

	.top .kinga_logo {
		inset: 10svh 0 0 0;
		width: 25svh;
	}

	.top .kumo_l {
		top: 2vh;
		left: calc(50vw* 0.2* -1);
		width: 50vw;
	}

	.top .kumo_l_2 {
		top: 15vh;
		left: calc(40vw* 0.4* -1);
        width: 40vw;
	}

	.top .tsuki {
		width: 15vw;
		top: 8svh;
		right: 23vw;
	}

	.top .kumo_r {
		top: 25vh;
		right: calc(48vw* 0.5* -1);
		width: 48vw;
	}

	.top .kumo_r_2 {
		top: 15vh;
        right: calc(40vw* 0.5* -1);
        width: 40vw;
	}

	.top .r-b {
		position: absolute;
		right: -8vw;
		top: 60svh;
	
		width: 50vw;
		height: 35vw;
	}

	.top .l-t {
		position: absolute;
		left: 0;
		top: 0;
	
		width: 30vw;
		height: 40vw;
	}

	.top .r-b .hana_red_2 {
		width: 11vw;
		bottom: unset;
		top: 35%;
		left: unset;
		right: 15%;
		animation: rotation-l 10s linear infinite;
	}

	.top .r-b .hana_blue_2 {
		top: unset;
		bottom: 0;
		left: 35%;
		width: 8vw;
		transform: rotate(45deg);
		animation: rotation-r 10s linear infinite;
	}

	.greeting {
		margin-top: 100svh;
		width: 200vw;
		height: calc(200vw + 20vh);
	}

	.greeting .message {
		width: 175vw;
		aspect-ratio: 1;
		left: -25%;
		top: 28vh;
		/* background-color: rgba(255, 255, 255, 0.7); */
		z-index: 1;
	}

	.greeting .message_himo {
		width: 35%;
	}

	.greeting .message_hana {
		position: absolute;
		top: 0;
		left: 15%;
		width: 25%;
	}

	.message p {
		font-size: min(4vw, 20px);
		font-weight: 550;
	}

	.greeting_kirakira {
        top: 20vh;
        left: 10vw;
        width: 65%;
	}

	.greeting .kumo_r {
		top: 35vh;
		width: 64vw;
		right: calc(64vw * 0.6 * -1 + 100vw);
	}

	.greeting .kumo_r_2 {
		top: 25vh;
		width: 42vw;
		right: calc(42vw * 0.4 * -1 + 100vw);
	}

	.greeting .kumo_l {
		top: 10vh;
		width: 68vw;
		left: calc(68vw * 0.5 * -1);
	}

	.greeting .kumo_l_2 {
		top: 30vh;
		width: 42vw;
		left: calc(42vw * 0.4 * -1);
	}

	.greeting .message_hebi {
		position: absolute;
        left: unset;
        top: 10vh;
        right: 125vw;
        width: 40vw;
        object-fit: cover;
        z-index: 2;
	}

	.greeting .kawa {
		bottom: -65vw;
		width: 126vw;
        left: -13vw;
	}

	.hana_0 {
		width: 20vw;
	}
	
	
	.hana_red {
		width: 13vw;
	}
	
	.hana_blue {
		width: 10vw;
	}
	
	.hana_pink {
		width: 10vw;
	}
	
	.hana_small {
		width: 4vw;
	}

	.omikuji {
		margin-top: 40vw;
	}

	.omikuji .container p {
		font-size: 20px;
		color: #595959;
		font-weight: 550;
		letter-spacing: 0.2rem;
	}

	.omikuji .omikuji_hebi {
		position: absolute;
		top: -30%;
		left: -10%;
		width: 100vw;
		max-width: 1200px;
		object-fit: cover;
		z-index: 3;
	}

	.kuji_relative {
		height: 100vw;
	}


	.sub_ttl {
		width: 45vmax;
		padding-top: 20vh;
		padding-bottom: 5%;
	}

	.sub_ttl_hana {
		position: absolute;
		width: 20vmax;
		top: 20%;
		left: 52%;
		transform: rotate(355deg);
	}

	.sub_ttl_hana2 {
        position: absolute;
        top: 15%;
        width: 20vmax;
        right: 50%;
        transform: rotate(204deg);
    }

	.kirakira {
		width: 200vw;
		height: auto;
		inset: -100% 0 0 -48%;
		margin: auto;
	}

	.kuji_en1 {
		width: 96vw;
	}

	.kuji_hebi {
		width: 80vw;
	}

	.scratch_result_image {
		width: 54vw;
	}

	.kuji_cover {
		width: 54vw;
	}

	.footer {
		width: 100dvw;
		color: white;
		position: relative;
		display: flex;
		flex-direction: column;
		align-items: center;
		margin-top: 50vw;;
	}
	
	.footer .message {
		width: 95%;
		text-align: center;
		position: absolute;
		top: -25vw;
		font-size: 4vw;
		font-weight: 550;
		line-height: 1.75;
		font-feature-settings: "palt";
	}

	.omikuji_close {
		position: absolute;
		width: 40%;
		inset: auto 0 12.5% 0;
		margin: auto;
		cursor: pointer;
	}


	
	.footer_mori {
		width: 100%;
		height: 50vw;
		object-fit: cover;
		object-position: top;
	}
	
	
	.footer_img {
		width: 100%;
		height: 15vw;
		object-fit: cover;
		z-index: 10;
	}
	
	
	.footer>.copyright {
	
		text-align: center;
		font-size: min(3vw, 20px);
		position: absolute;
		bottom: 5vw;
		z-index: 15;
		color: #222222;
	}
	
	span.selector {
		font-feature-settings: "palt";
	}
	
	span.copyright {
		font-size: min(3vw, 20px);
	}

}

/* タブレット */
@media screen and (min-width: 768px)  and (orientation: portrait) {
	* {
		font-size: min(4vw, 1.5em);
	}

	.top .fuji {
        top: calc(100vh - 78vw);
        width: 130vw;
        right: -45vw;
    }
	.top .yama {
		top: calc(100vh - 55vw);
		width: 135vw;
	}

	.top .kawa {
		top: calc(100vh - 35vw / 4* 3);
	}

	.top .kinga_logo {
		inset: 15vh 0 0 0;
		width: 25vh;
	}

	.top .top_hebi {
		width: 40vw;
        top: calc(100vh - 55vw);
        left: 0;
	}

	.top .kumo_l {
		top: 2vh;
		left: calc(50vw* 0.2* -1);
		width: 50vw;
	}

	.top .kumo_l_2 {
		top: 15vh;
		left: calc(40vw* 0.4* -1);
        width: 40vw;
	}

	.top .kumo_r {
		top: 25vh;
		right: calc(48vw* 0.5* -1);
		width: 48vw;
	}

	.top .kumo_r_2 {
		top: 15vh;
        right: calc(40vw* 0.5* -1);
        width: 40vw;
	}

	.top .tsuki {
		width: 18vw;
		top: 8vh;
		right: 23vw;
	}

	.top .r-b {
		right: -8vw;
	}

	.greeting {
		margin-top: 90svh;
		padding: 0;
		height: calc(100vw + 50vh);
	}
	.greeting .message {
		width: 100vw;
		aspect-ratio: 1;
		/* background-color: white; */
		/* border-radius: 50%; */
	
		font-size: 15px;
	
		position: relative;
		top: 25vh;
	}

	.greeting .message_hebi {
		position: absolute;
		left: unset;
		top: 10vh;
		right: 30%;
		width: 25vw;
		object-fit: cover;
	}

	.greeting .kawa {
		bottom: -35vw;
	}

	.greeting_kirakira {
        top: 20vh;
        left: 10vw;
        width: 65%;
	}

	.greeting .kumo_r {
		top: 35vh;
		width: 64vw;
		right: calc(64vw * 0.6 * -1);
	}

	.greeting .kumo_r_2 {
		top: 25vh;
		width: 42vw;
		right: calc(42vw * 0.4 * -1);
	}

	.greeting .kumo_l {
		top: 10vh;
		width: 68vw;
		left: calc(68vw * 0.5 * -1);
	}

	.greeting .kumo_l_2 {
		top: 30vh;
		width: 42vw;
		left: calc(42vw * 0.4 * -1);
	}


	.message p {
		font-size: min(calc(100vw* 0.025), 25px);
	}
	

	.sub_ttl {
		width: 45vmax;
		margin-top: 25vh;
		padding-top: min(10%, 6rem);
		padding-bottom: 5%;
	}

	.sub_ttl_hana {
		position: absolute;
		top: 10%;
		left: 52%;
		transform: rotate(355deg);
	}

	.sub_ttl_hana2 {
        position: absolute;
        top: 0;
        right: 50%;
        transform: rotate(185deg);
    }

	.omikuji {
		margin-top: 40vw;
	}

	.omikuji .omikuji_hebi {
		z-index: 3;
	}
	
}


@media screen and (max-height: 500px)  and (orientation: landscape) {

	.pc {
		display: none;
	}
	
	.sp {
		display: block;
	}
	
	.top .r-b {
		position: absolute;
		right: -8vmin;
		top: 65vh;
	
		width: 50vmin;
		height: 35vmin;
	}

	.top .l-t {
		position: absolute;
		left: 0;
		top: 0;
	
		width: 30vmin;
		height: 40vmin;
	}

	.top .r-b .hana_red_2 {
		width: 11vmin;
		bottom: unset;
		top: 35%;
		left: unset;
		right: 15%;
		animation: rotation-l 10s linear infinite;
	}

	.message p {
		font-size: 18px;
	}

	.top .r-b .hana_blue_2 {
		top: unset;
		bottom: 0;
		left: 35%;
		width: 8vmin;
		transform: rotate(45deg);
		animation: rotation-r 10s linear infinite;
	}
	.hana_0 {
		width: 20vh;
	}
	
	
	.hana_red {
		width: 13vh;
	}
	
	.hana_blue {
		width: 10vh;
	}
	
	.hana_pink {
		width: 10vh;
	}
	
	.hana_small {
		width: 4vh;
	}

	.greeting  {
		height: 200vh;
		padding: 50vh 0;
	}

	.sub_ttl_hana {
        width: 20vh;
    }

	.sub_ttl_hana2 {
        width: 20vh;
    }
}


@media screen and (orientation: portrait) {

	.sound_check .container .buttons {

		padding-left: 10%;
		padding-right: 10%;
	}

	.sound_check .container .buttons .button {
		width: 40dvw;
		font-size: min(5vw, 2rem);
		padding-top: 0.7rem;
		padding-bottom: 0.7rem;
	}


	.sound_check .container .title {
		font-size: min(6vw, 3rem);
		margin-bottom: 5%;
	}
}