@charset "utf-8";

/*-----------------------------------------------------
共通スタイル
-------------------------------------------------------*/

/*--clearfix--*/
.clearfix {
	zoom: 100%;
}

.clearfix:after {
	content: ".";
	clear: both;
	height: 0;
	font-size: 0;
	line-height: 0;
}

body.scene3 {
	/* background-color: #00B0F0; */
}

/*===========================
* Layout
============================*/

#container {
	margin: 0 auto;
	width: 100%;
	/* padding-bottom: 30px; */
	/* max-width: 640px;
	min-width: 375px;
	width: 90%; */
	/* height: 100dvh; */
	overflow-y: auto;
	position: relative;
}
/* #container .scenes {
	position: absolute;
	top: 0;
	left: 0;
} */

.layoutBase {
	margin: 0 auto;
	max-width: 640px;
	min-width: 375px;
	width: 90%;
}
.layout320 {
	margin: 0 auto;
	width: 320px;
}


.mt_top10 {
	margin-top: 10px;
}
.mt_top20 {
	margin-top: 20px;
}
.mt_top30 {
	margin-top: 30px;
}
.mt_top40 {
	margin-top: 40px;
}
.mt_top50 {
	margin-top: 50px;
}

.m_box_top10 {
	margin: 10px auto 0;
}
.m_box_top20 {
	margin: 20px auto 0;
}
.m_box_top30 {
	margin: 30px auto 0;
}
.m_box_top40 {
	margin: 40px auto 0;
}
.m_box_top50 {
	margin: 50px auto 0;
}

.text_center {
	text-align: center;
	/* font-size: 1.4rem; */
}
.text_left {
	text-align: left;
	/* font-size: 1.4rem; */
}

/*===========================
* Button
============================*/
.btnLarge {
	display: block;
	/* margin: 30px auto 0; */
	width: 320px;
	height: 60px;
	line-height: 60px;
	text-align: center;	
	font-weight: bold;
	border-radius: 50px;
}
.btnLarge.active {
	background-color: #001E50;
	color: #fff;
}
.btnLarge.off {
	background-color: #C2CACF;
	color: #fff;
}
.btnLanguage {
	display: block;
	margin: 20px auto 0;
	width: 320px;
	text-align: center;
}

.answerTrueBtnArea {
	display: flex;
	justify-content: center;
	align-items: center;
}
.btnSmall {
	display: block;
	/* margin: 30px auto 0; */
	width: 150px;
	line-height: 60px;
	text-align: center;	
	font-weight: bold;
	border-radius: 50px;
}
.btnSmall.next {
	background-color: #001E50;
	color: #fff;
}
.btnSmall.stamp {
	background-color: #00B0F0;
	color: #fff;
}



/*===========================
* footer
============================*/
footer {
	margin: 40px 0 0 0;
	width: 100%;
	height: 40px;
	border-top: solid 2px #001E50;
}
footer .footerInner {
	position: relative;
	width: 96%;
	margin: 0 auto;
}
footer .footerLogo{
	display: block;
	position: absolute;
	top: -18px;
	right: 20px;
	background-color: #EAE5DD;
	padding: 0 10px;
}
#scene3 footer .footerLogo{
	/* background-color: #00B0F0; */
}


/*===========================
* scene0
============================*/

#container #scene0 {
	/* display: none; */
	padding-bottom: 30px;
}

#container #scene0 h1 {
	margin: 40px 0 0 0;
	font-size: 2.4rem;
	/* line-height: 1.6;
	margin-bottom: 1.6rem; */
	text-align: center;
}
#container #scene0 .keyvisual {
	display: block;
	margin: 30px auto 0;
}


/*===========================
* scene1
============================*/

#container #scene1 {
	display: none;
}
#container #scene1 .titleArea {
	width: 100%;
	margin: 0 auto;
	background-color: #fff;
	padding: 56px 0 30px 0;
}

#container #scene1 .quizTitle {
	display: block;
	margin: 0 auto 0;
	font-family: 'vw';
	font-weight: bold;
	text-align: center;
	font-size: 36px;
}
#container #scene1 .quizTitle span {
	font-family: 'vw';
	font-weight: lighter;
}

#container #scene1 .carImage {
	display: block;
	margin: 20px auto 0;
}
#container #scene1 .carName {
	margin: 10px 0 0 0;
	font-family: 'vw';
	font-weight: bold;
	text-align: center;
	font-size: 20px;
}

#container #scene1 p {
}

#container #scene1 .quizList {
	margin: 20px auto 20px;
}
#container #scene1 .quizList li {
	margin-bottom: 2px;
	background-color: #fff;
	width: 100%;
	height: 60px;
	border: 2px solid #fff;
	/* box-sizing: border-box; */
}
#container #scene1 .quizList li.active {
	border: 2px solid #00B0F0;
}
#container #scene1 .quizList li a {
	display: block;
	width: 100%;
	height: 46px;
	padding: 7px 0;
}
#container #scene1 .quizList li a {
}
#container #scene1 .quizList li table {
	width: 100%;
}
#container #scene1 .quizList li table th,
#container #scene1 .quizList li table td{
	vertical-align: middle;
	height: 40px;
	line-height: 1.6em;
}
#container #scene1 .quizList li table th{
	text-align: center;
	width: 40px;
	border-right: solid 1px #DFE4E8;
	font-family: 'vw';
	font-weight: bold;
	font-size: 24px;
	color: #00B0F0;
}
#container #scene1 .quizList li table th img{
	vertical-align: middle;
	line-height: 1em;
}
#container #scene1 .quizList li table td {
	line-height: 1.4em;
	text-align: center;
	font-weight: normal;
	font-size: 16px;
}
#container #scene1 .checkArea {
	width: calc(100% - 20px);
	border: solid 1px #96A3A8;
	border-radius: 6px;
	font-size: 1.3rem;
	line-height: 1.4em;
	padding: 12px 10px 10px 10px;
	position: relative;
}
#container #scene1 .checkIcon {
	position: absolute;
	top: -9px;
	left: 10px;
	background-color: #EAE5DD;
}

#container #scene1 .btnGoStamp {
	position: absolute;
	top: 30px;
	right: 30px;
	width: 40px;
}

/*===========================
* scene2
============================*/

#container #scene2 {
	display: none;
	position: relative;
}
#container #scene2 .titleArea {
	width: 100%;
	height: calc(252px - 56px);
	margin: 0 auto;
	background-color: #fff;
	padding: 56px 0 0 0;
}


#container #scene2 .quizTitle {
	display: block;
	margin: 0 auto 0;
	font-family: 'vw';
	font-weight: bold;
	text-align: center;
	font-size: 24px;
}
#container #scene2 .carImage {
	display: block;
	margin: 30px auto 0;
}
#container #scene2 .answerIcon {
	width: 76px;
	height: 76px;
	position: relative;
	margin: 10px auto 0;
}
#container #scene2 .answerIcon img {
	position: absolute;
	top: 0;
	left: 0;
}

#container #scene2 table.answerTable {
	height: 46px;
	margin: 72px auto 0;
	padding: 7px 0;
	background-color: #fff;
}
#container #scene2 table.answerTable th,
#container #scene2 table.answerTable td{
	vertical-align: middle;
	height: 40px;
}
#container #scene2 table.answerTable th{
	text-align: center;
	width: 50px;
	border-right: solid 1px #DFE4E8;
}
#container #scene2 table.answerTable th{
	vertical-align: top;
	line-height: 1em;
	font-size: 24px;
	font-family: 'vw';
	font-weight: bold;
	color: #6A767D;
}
#container #scene2 table.answerTable th span {
	display: block;
	font-size: 12px;
	font-family: 'NotoSansJP';
	font-weight: normal;
}

#container #scene2 table.answerTable td {
	line-height: 1.4em;
	text-align: center;
	font-weight: bold;
	font-size: 16px;
}

#container #scene2 table.answerTable td.true {
	color: #EA4F5F;
}
#container #scene2 table.answerTable td.false {
	color: #6A767D;
}
#container #scene2 .answerImage {
	display: block;
	margin: 20px auto 20px;
}

#container #scene2 .answerTrueArea {
	/* display: none; */
}
#container #scene2 .answerTrueArea table.answerTable th{
	color: #EA4F5F;
}
#container #scene2 .answerFalseArea {
	display: none;
}
#container #scene2 .answerFalseArea table.answerTable td{
	color: #6A767D;
}

/*===========================
* scene3 stamp
============================*/
#container #scene3 {
	display: none;
	position: relative;
	/* color: #fff; */
}
#container .stampTitle {
	font-family: 'vw';
	font-weight: bold;
	font-size: 36px;
	margin: 56px 0 0 0;
	line-height: 1em;;
}
#container .stampArea {
	margin: 20px auto 0;
	width: 285px;
	height: 413px;
	position: relative;
}

#container .stampArea ul.stampList li {
	width: 85px;
	height: 85px;
	position: absolute;
	background-color: #fff;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
}
#container .stampArea ul.stampList li .ticket_white {
	display: block;
}
#container .stampArea ul.stampList li .ticket_blue {
	display: none;
}

#container .stampArea ul.stampList li.layout9:nth-child(1) {
	top: 0;
	left: 100px;
}
#container .stampArea ul.stampList li.layout9:nth-child(2) {
	top: 82px;
	left: 50px;
}
#container .stampArea ul.stampList li.layout9:nth-child(3) {
	top: 82px;
	left: 150px;
}
#container .stampArea ul.stampList li.layout9:nth-child(4) {
	top: 164px;
	left: 100px;
}
#container .stampArea ul.stampList li.layout9:nth-child(5) {
	top: 164px;
	left: 0;
}
#container .stampArea ul.stampList li.layout9:nth-child(6) {
	top: 246px;
	left: 50px;
}
#container .stampArea ul.stampList li.layout9:nth-child(7) {
	top: 328px;
	left: 100px;
}
#container .stampArea ul.stampList li.layout9:nth-child(8) {
	top: 246px;
	left: 150px;
}
#container .stampArea ul.stampList li.layout9:nth-child(9) {
	top: 164px;
	left: 200px;
}


#container .stampArea ul.stampList li .ticket {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#container .stampArea ul.stampList li img {
	/* display: block; */
}
#container .stampArea ul.stampList li p {
	/* display: block; */
	color: #001E50;
	font-size: 10px;
	font-family: 'vw';
	font-weight: bold;
	line-height: 1.4em;
}

#container .stampArea ul.stampList li:nth-child(-n+3){
	background-color: #A9E3FF;
}
#container .stampArea ul.stampList li:nth-child(-n+3) div{
	opacity: 0.2;
}
#container .stampArea ul.stampList li:nth-child(-n+2).active{
	background-color: #fff;
}
#container .stampArea ul.stampList li:nth-child(-n+2).active div{
	opacity: 1;
}

#container .stampArea ul.stampList li:nth-child(3).active{
	background-color: #001E50;
	color: #fff;
}
#container .stampArea ul.stampList li:nth-child(3).active div{
	opacity: 1;
}
#container .stampArea ul.stampList li:nth-child(3).active div p{
	color: #fff;
}
#container .stampArea ul.stampList li:nth-child(3).active .ticket_white {
	display: none;
}
#container .stampArea ul.stampList li:nth-child(3).active .ticket_blue {
	display: block;
}


#container .stampArea ul.stampList li.layout9:nth-child(n+4){
	background-color: #C2CACF;
}
#container .stampArea ul.stampList li.layout9:nth-child(n+4) div{
	opacity: 0.2;
}

#container .stampArea ul.stampList li.layout9:nth-child(n+4).active{
	background-color: #fff;
}
#container .stampArea ul.stampList li.layout9:nth-child(n+4).active div{
	opacity: 1.0;
}
#container .stampArea ul.stampList li.layout9:nth-child(9).active{
	background-color: #001E50;
	color: #fff;
}
#container .stampArea ul.stampList li.layout9:nth-child(9).active div{
	opacity: 1;
}
#container .stampArea ul.stampList li.layout9:nth-child(9).active div p{
	color: #fff;
}
#container .stampArea ul.stampList li.layout9:nth-child(9).active .ticket_white {
	display: none;
}
#container .stampArea ul.stampList li.layout9:nth-child(9).active .ticket_blue {
	display: block;
}

/*============= stamp line =============*/
#container .stampArea ul.stampLine li {
	position: absolute;
	width: 105px;
	height: 0px;
	border-top: solid 2px #fff;
}
#container .stampArea ul.stampLine li.blue {
	border-color: #A9E3FF;
}
#container .stampArea ul.stampLine li.gray {
	border-color: #C2CACF;
}
#container .stampArea ul.stampLine li:nth-child(1) {
	top: 81px;
	left: 65px;
	transform: rotate(-60deg);
}
#container .stampArea ul.stampLine li:nth-child(2) {
	top: 120px;
	left: 80px;
	/* transform: rotate(120deg); */
}

#container .stampArea ul.stampLine li:nth-child(3) {
	top: 205px;
	left: 20px;
	/* transform: rotate(60deg); */
}
#container .stampArea ul.stampLine li:nth-child(4) {
	top: 270px;
	left: 22px;
	transform: rotate(60deg);
}
#container .stampArea ul.stampLine li:nth-child(5) {
	top: 350px;
	left: 72px;
	transform: rotate(60deg);
}
#container .stampArea ul.stampLine li:nth-child(6) {
	top: 300px;
	left: 135px;
	transform: rotate(120deg);
}
#container .stampArea ul.stampLine li:nth-child(7) {
	top: 270px;
	left: 150px;
	transform: rotate(120deg);
}

/*============= stamp line =============*/
#container #scene3 .tickeBtnArea0 {
	position: relative;
	margin: 30px auto 0;
	width: 320px;
}
#container #scene3 .tickeBtnArea1 {
	position: relative;
	margin: 10px auto 0;
	width: 320px;
}

#container #scene3 .ticketBtn {
	display: table-cell;
	vertical-align: middle;
	line-height: 1.4em;
}
#container #scene3 .ticketBtn span {
	display: block;
	font-size: 13px;
	font-weight:normal;
}

#container #scene3 .off a.ticketBtn {
	background-color: #C2CACF;
}

#container #scene3 .checkedArea {
	position: absolute;
	top: 0;
	left: 0;
	display: none;
	/* margin: 30px auto 0; */
}
#container #scene3 .checkedArea > div {
	display: table-cell;
	vertical-align: middle;
	width: 320px;
	height: 60px;
	text-align: center;	
	font-weight: bold;
	border-radius: 50px;
	color: #001E50;
	background-color: rgba(0, 0, 0, 0.0);
	font-size: 13px;
}

#container #scene3 .done a.ticketBtn {
	background-color: #A9E3FF;
}
#container #scene3 .done .checkedArea {
	display: block;
}

#container #scene3 .white a.ticketBtn {
	background-color: #fff;
	color: #001E50;
	font-weight: normal;
}


/*===========================
* scene4
============================*/
#container #scene4 {
	display: none;
}
#container #scene4 .ticketCompleteImage {
	display: block;
	margin: 0px auto 0;
	width: 360px;
}
#container #scene4 .ticketGetArea {
	width: 360px;
	height: 200px;
	margin: 10px auto 10px;
	background-color: #001E50;
	border-radius: 10px;
	position: relative;
	background-image: url("../images/ticketGet_Bg.png");
	background-repeat: no-repeat;
}
#container #scene4 .checkSlideArea {
	display: none;
	width: 300px;
	height: 70px;
	text-align: center;	
	font-weight: bold;
	border-radius: 50px;
	background-color: #fff;
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -50px;
	margin-left: -150px;
	border: solid 3px #fff;
	box-sizing: border-box;
}
#container #scene4 .checkSlideArea p {
	float: right;
	margin: 10px 36px 0 0;
	text-align: center;
	font-weight: normal;
	line-height: 1.2em;
	font-size: 17px;
}
#container #scene4 .checkSlideArea p strong {
	font-size: 22px;
}
#container #scene4 .checkSlideArea p span {
	font-size: 13px;
}
#container #scene4 .checkSlideArea .checkSlideBtn {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 80px;
	height: 62px;
	background-color: #00B0F0;
	border-radius: 50px;
	position: absolute;
	top: 0;
	left: 0;
	
}


#container #scene4 .checkUsedArea {
	/* display: none; */
}
#container #scene4 .checkUsedIcon {
	width: 300px;
	height: 70px;
	text-align: center;	
	font-weight: bold;
	border-radius: 50px;
	background-color: #00B0F0;
	position: absolute;
	top: 50px;
	left: 50%;
	margin-left: -150px;
	border: solid 3px #fff;
	box-sizing: border-box;
}
#container #scene4 .checkUsedIcon .checkedIcon {
	position: absolute;
	top: 20px;
	left: 30px;
}
#container #scene4 .checkUsedIcon p {
	float: right;
	margin: 10px 20px 0 0;
	text-align: center;
	font-weight: normal;
	line-height: 1.2em;
	font-size: 17px;
	color: #fff;
}
#container #scene4 .checkUsedIcon p strong {
	font-size: 22px;
}
#container #scene4 .checkUsedIcon p span {
	font-size: 13px;
}

#container #scene4 .btnBack {
	display: block;
	/* margin: 30px auto 0; */
	width: 300px;
	height: 64px;
	line-height: 64px;
	text-align: center;	
	font-weight: bold;
	border-radius: 50px;
	margin: 30px auto 0;
	background-color: #fff;
	font-weight: normal;
	font-weight: bold;
}


#container #scene4 .exclamationText {
	position: absolute;
	bottom: 25px;
	left: 50%;
	width: calc(300px - 36px);
	line-height: 1.4em;
	margin-left: -150px;
	color: #fff;
	font-size: 13px;
	background-image: url("../images/icon_exclamation.png");
	background-size: 24px 24px;
	background-repeat: no-repeat;
	background-position: 0 center;
	padding-left: 36px;
}

/*===========================
* loading
============================*/
.loadingArea {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #fff;
	z-index: 1000;
}
.loadingArea .loadingLogo {
	position: absolute;
	top: 50%;
	left: 50%;
	margin: -120px 0 0 -105px;
}
.loadingArea .loadingText {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	margin: -50px 0 0 0;
	text-align: center;
	font-size: 24px;
	font-weight: bold;
	color: #001E50;
	font-family: 'vw';
	line-height: 1em;
}
/* HTML: <div class="loader"></div> */
.loadingArea .loader {
	position: absolute;
	top: 50%;
	left: 50%;
	margin: 0px 0 0 -25px;
  width: 50px;
	height: 50px;
  padding: 8px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: #001E50;
  --_m: 
    conic-gradient(#0000 10%,#000),
    linear-gradient(#000 0 0) content-box;
  -webkit-mask: var(--_m);
          mask: var(--_m);
  -webkit-mask-composite: source-out;
          mask-composite: subtract;
  animation: l3 1s infinite linear;
}
@keyframes l3 {to{transform: rotate(1turn)}}


.resetBtn {
	display: block;
	width: 10px;
	height: 10px;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 1000;
	/* background-color: blue; */
}

.alertArea {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.8);
	z-index: 1001;
}

.alertArea .alertInner {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 320px;
	height: 200px;
	margin-top: -100px;
	margin-left: -160px;
	background-color: #fff;
	border-radius: 10px;
	padding: 20px;
	box-sizing: border-box;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
}