@charset "UTF-8";

@media (orientation: portrait) and (max-width: 767px){

:root {
	--img-loading-bar: url("../img/img-loading-bar.png");
	--img-title-bg-sp: url("../img/bg-desktop-sp.png");
	--img-game-bg-sp: url("../img/bg-desktop-sp.png");
	--img-next-bg-sp: url("../img/bg-desktop-sp.png");
	--img-end-bg-sp: url("../img/bg-desktop-sp.png");
}

* {
	font-family: 'M PLUS Rounded 1c', sans-serif;
}

body {
	overflow: hidden;
	background: #B9E6FA;
}

#container {
	position: relative;
	width:100%;
	height: calc(var(--vh, 1vh) * 100);
	margin:auto;
	overflow: hidden;
}

.page {
	position: absolute;
	width: 100%;
	height: calc(var(--vh, 1vh) * 100);
}

.page-content-wrapper {
	position: absolute;
	top: var(--contents-wrapper-top);
	width: 100%;
	height: var(--contents-wrapper-height);
}

.btn-selected {
	border: 2px groove #F00;
	z-index: 999;
}

/********************************************************************************
* flag
********************************************************************************/

.img-flag-left {
	position: absolute;
	left: -120px;
	top: -20;
	width: 240px;
	z-index: 9999;
}

.img-flag-right {
	position: absolute;
	right: -120px;
	top: -20;
	width: 240px;
	z-index: 9999;
}

/********************************************************************************
* sound button
********************************************************************************/

.btn-sound {
	position: absolute;
	left: -35px;
	top: -50px;
	width: 120px;
	z-index: 10000;
	display: block;
}

/********************************************************************************
* help button
********************************************************************************/

.btn-howto {
	position: absolute;
	right: -35px;
	top: -50px;
	width: 120px;
	z-index: 10000;
	display: none;
}

.btn-howto-close {
	position: absolute;
	right: -35px;
	top: -50px;
	width: 120px;
	z-index: 10000;
	display: none;
}

/********************************************************************************
* character
********************************************************************************/

@keyframes caracter-jump-left {
  0%   { transform: translateY(0px); }
  5%  { transform: translateY(-30px); }
  10%  { transform: translateY(0px); }
  15%  { transform: translateY(-30px); }
  20%  { transform: translateY(0px); }
}

@keyframes caracter-jump-right {
  50%  { transform: translateY(0px); }
  55%  { transform: translateY(-30px); }
  60%  { transform: translateY(0px); }
  65%  { transform: translateY(-30px); }
  70%  { transform: translateY(0px); }
}

.character-left {
	position: absolute;
	left: 0;
	bottom: -5%;
	width: 120px;
	animation-name: caracter-jump-left;
	animation-duration: 5s;
	animation-iteration-count: infinite;
	display: none;
	z-index: 1000;
}

.character-right {
	position: absolute;
	right: 0;
	bottom: -5%;
	width: 120px;
	animation-name: caracter-jump-right;
	animation-duration: 5s;
	animation-iteration-count: infinite;
	display: none;
	z-index: 1000;
}

/********************************************************************************
* title
********************************************************************************/

#page-title {
	background: var(--img-title-bg-sp) no-repeat;
	background-size: 100% calc(var(--vh, 1vh) * 100);
}

#btn-title-start {
	position: absolute;
	left: 50%;
	bottom: 3%;
	width: 35%;
	height: 10%;
	transform: translate(-50%,0);
	opacity: 0;
	transition: 0.5s;
	transition-delay: 0.5s;
}

/********************************************************************************
* slider top
********************************************************************************/

.slider-top{
	margin: 0 auto;
	width: var(--slider-img-width);
  display: none;
}

.slider-top.slick-initialized{
  display: block;
}

.slider-top img{
	width: 100%;
}

.slider-top img.slide-arrow{
	position: absolute;
	top: var(--slider-img-width);
	width: 60px;
	height: auto;
	transform: translate(0,50%);
	z-index: 9999;
}

.slider-top img.prev-arrow{
	left: 5%;
}

.slider-top img.next-arrow{
	right: 5%;
}

#page-title #slider-dots{
	position: absolute;
	top: var(--slider-img-width);
	width: 100%;
	height: 60px;
	transform: translate(0,50%);
	display: flex;
	justify-content: center;
	align-items: center;
	transition: 0.5s;
}

#page-title #slider-dots img{
	width: 35%;
}

/********************************************************************************
* loading
********************************************************************************/

#page-title #loading-bar{
	background: var(--img-loading-bar) no-repeat;
	background-size: 100% 25px;
	position: absolute;
	left: 50%;
	bottom: 3%;
	width: 90%;
	transform: translate(-50%,0);
	transition: 0.5s;
	display: block;
}

#page-title #loading-bar div{
	width: 0%;
	height: 25px;
	overflow: hidden;
	object-fit: none;
	object-position: bottom;
	text-align: left;
}

#page-title #loading-bar div img{
	width: 100%;
	height: 100%;
}

/********************************************************************************
* game
********************************************************************************/

#page-game {
	background: var(--img-game-bg-sp) no-repeat;
	background-size: 100% calc(var(--vh, 1vh) * 100);
	display: none;
}

.div-game-timer {
	position: absolute;
	left: 20%;
	top: 3%;
	width: 60%;
	height: 60px;
	background: rgba(255,255,255,0.6);
	border-radius: 30px;
	text-align: center;
	font-size: 30px;
	font-weight: 900;
	z-index: 9999;
}

.div-game-timer img {
	position: absolute;
	top: 15px;
	left: 40px;
	width: 30px;
}

.div-game-timer span {
	position: absolute;
	top: 8px;
	right: 50px;
	font-size: 30px;
}

.img-panel-frame,
#img-game-bg,
#div-game-panels,
.btn-game-panel {
	position: absolute;
}

.btn-game-panel {
	border-radius: 0;
}

/********************************************************************************
* next
********************************************************************************/

#page-next {
	background: var(--img-next-bg-sp) no-repeat;
	background-size: 100% calc(var(--vh, 1vh) * 100);
	display: none;
}

#img-next-bg {
	position: absolute;
}

@keyframes next-go {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

#btn-next-go {
	position: absolute;
	left: 50%;
	bottom: 3%;
	width: 35%;
	height: 10%;
	transform: translateX(-50%);
	opacity: 0;
	animation-name: next-go;
	animation-duration: 1s;
	animation-delay: 3s;
	animation-fill-mode: forwards;
}

/********************************************************************************
* end
********************************************************************************/

#page-end {
	background: var(--img-end-bg-sp) no-repeat;
	background-size: 100% calc(var(--vh, 1vh) * 100);
	display: none;
}

#page-end .this-score {
	position: absolute;
	left: 50%;
	top: 60px;
	width: 60%;
	height: 60px;
	border-radius: 30px;
	background: rgba(255,255,255,0.3);
	transform: translate(-50%, 0);
	display: flex;
	justify-content: center;
	align-items: center;
}

#page-end .this-score img {
	position: absolute;
	left: 20px;
	width: 30px;
}

#page-end .this-score div {
	position: absolute;
}

#page-end .this-score div.score {
	right: 30px;
	font-size: 40px;
}

#page-end .last-score {
	position: absolute;
	left: 50%;
	width: 90%;
	height: 100px;
	background: rgba(255,255,255,0.8);
	color: black;
	transform: translate(-50%, 0);
	display: flex;
	justify-content: center;
	align-items: center;
}

#page-end .last-score div {
	position: absolute;
}

#page-end .last-score div.star {
	left: 20px;
}

#page-end .last-score div.star img {
	width: 45px;
}

#page-end .last-score div.no {
	left: 25%;
	font-size: 45px;
}

#page-end .last-score div.score {
	right: 15%;
	font-size: 45px;
}

#page-end .score1 {
	top: 150px;
}

#page-end .score2 {
	top: 251px;
}

#page-end .score3 {
	top: 352px;
}

@keyframes end-top {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

#btn-end-top {
	position: absolute;
	left: 50%;
	bottom: 3%;
	width: 35%;
	height: 10%;
	transform: translateX(-50%);
	opacity: 0;
	animation-name: end-top;
	animation-duration: 1s;
	animation-delay: 3s;
	animation-fill-mode: forwards;
}

/********************************************************************************
* howto
********************************************************************************/

#page-howto {
	display: none;
	background:rgb(0 0 0 / 80%);
	z-index: 9999;
}

/********************************************************************************
* slider howto
********************************************************************************/

.slider-howto{
	margin: 0 auto;
	width: var(--slider-img-width);
  display: none;
}

.slider-howto.slick-initialized{
  display: block;
}

.slider-howto img{
	width: 100%;
}

.slider-howto img.slide-arrow{
	position: absolute;
	top: var(--slider-img-width);
	width: 60px;
	height: auto;
	transform: translate(0,50%);
	z-index: 9999;
}

.slider-howto img.prev-arrow{
	left: 5%;
}

.slider-howto img.next-arrow{
	right: 5%;
}

#page-howto  #slider-dots{
	position: absolute;
	top: var(--slider-img-width);
	width: 100%;
	height: 60px;
	transform: translate(0,50%);
	display: flex;
	justify-content: center;
	align-items: center;
	transition: 0.5s;
}

#page-howto #slider-dots img{
	width: 35%;
}

/********************************************************************************
* other
********************************************************************************/

.copyright {
	font-size:12px;
	color:#666;
	text-align:center;
	font-family:Arial, Helvetica, sans-serif;
}
	
}