@charset "utf-8";

/* ヘッダー */
header {
	position: relative;
	margin: 0 auto;
	background-color: #000000;
	padding: 3px 0 5px 0;
	z-index: 300;
}
header h1 {
	position: relative;
	margin: 0 auto;
	width: 30%;
	max-width: 80px;
}

/* nazo */
#nazo  {
	position: relative;
	margin: 0 auto;
	padding: 20px 0 0 0;
}
#nazo.nazoWrap{padding: 30px 0 0 0;}
#nazo::before{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: calc(100% + 24vw);
	content: '';
	display: block;
	background-image: url("../img/bg_red.jpg");
	background-repeat: repeat;
	background-position: 0 0;
	background-size: 250px auto;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 21vw), 0 100%);
	z-index: 90;
}
#nazo::after{
	position: absolute;
	top:-20px;
	left: -30px;
	width: 100%;
	height: 170px;
	background-image: url("../img/nazo/bg.png");
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: contain;
	content: '';
	display: block;
	z-index: 91;
}
#nazo.nazoWrap::after{display: none;}
#nazo h2{
	position: relative;
	margin: 0 auto 10px auto;
	display: block;
	z-index: 99;
}
#nazo h2 img{
	position: relative;
	margin: 0 auto;
}
.chara{
	position: relative;
	margin: 0 auto 20px auto;
	width: calc(100% - 40px);
	max-width: 600px;
	gap: 0 10px;
	z-index: 100;
}
.chara .Img{
	position: relative;
	margin: 0;
	width: 70px;
}
.chara .Txt{
	position: relative;
	margin: 0;
	width: calc(100% - 80px);
}
.chara .Txt .name{
	position: relative;
	margin: 0;
	width: 80px;
}
.chara .Txt .text{
	position: relative;
	margin: 8px 0 0 0;
	width: calc(100% - 20px);
	padding: 10px;
	background-color: #ffffff;
	border-radius: 5px;
	color: #000000;
	line-height: 1.5em;
}

/* list */
#list, #form, #links{
	position: relative;
	margin: 0 auto;
	padding: 100px 0 60px 0;
	background-image: url("../img/bg_catch.png");
	background-repeat: repeat;
	background-position: 50% 50%;
	background-size: 220px auto;
}
#form{padding: 20px 0 50px 0;}
#list::before, #form::before, #links::before{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 150px;
	content: '';
	display: block;
	background: linear-gradient(0deg,rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
}
#list ul{
	position: relative;
	margin:0 auto;
	width: calc(100% - 40px);
	max-width: 500px;
	gap: 10px;
	z-index: 200;
}
#list ul li{
	position: relative;
	margin:0 ;
	width: calc(33.333% - 7px);
}

/* 問題 */
#nazo .nazoImg{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 40px);
	max-width: 800px;
	z-index: 105;
}
#form::after, #links::after{
	position: absolute;
	bottom:20px;
	left: 0;
	width: 100%;
	height: 170px;
	background-image: url("../img/nazo/bg.png");
	background-repeat: no-repeat;
	background-position: calc(100% + 20px) 0;
	background-size: contain;
	content: '';
	display: block;
	z-index: 91;
}
#form #err{
	position: relative;
	margin: 0 auto;
	z-index: 106;
}
#form #err p{
	position: relative;
	margin: 0 auto;
	padding: 5px 10px;
	color: #FFE700;
	text-align: center;
}
#form .hintWrap{
	position: relative;
	margin: 20px auto 0 auto;
	z-index: 507;
}
#form .hintInWrap{
	position: relative;
	margin: 0 auto 10px auto;
	width: calc(100% - 40px);
	max-width: 560px;
	border: solid 1px #dbbc2b;
	background-color: #dbbc2b;
}
#form .hintWrap .Btnhint{
	position: relative;
	margin: 0 auto;
	padding: 3px 20px;
	text-align: center;
	color: #000000;
	cursor: pointer;
	font-size: .13rem;
	transition: all .3s ease-out;
}
#form .hintWrap .Btnhint:hover{background-color: #dbbc2b;color: #000000;}
#form .hintWrap .hintTxt{
	position: relative;
	margin:0 auto;
	padding: 10px;
	font-size: .13rem;
	display: none;
	background-color: #ffffff;
	color: #000000;
}
#form .inputArea{
	margin:30px auto 0 auto;
	padding-bottom: 10px;
	width: calc(100% - 40px);
	max-width: 560px;
}
/* form */
.inputArea .inputTxt{
	position: relative;
    display: block;
	margin:  0 auto 20px auto !important;
	padding: 0 8px;
	border: solid 1px #757d92;
	background-color: #fefff3;
	width: calc(100% - 16px);
	max-width: 686px;
	border-radius: 5px;
	height: 2.5em;
	line-height: 3em;
	font-size: .16rem;
	z-index: 500;
}
.inputArea .inputTxt.disabled{background-color: #B0CFD7; color: #708392;pointer-events : none;}
::placeholder {color: #cecece;}
input::-webkit-contacts-auto-fill-button, 
input::-webkit-credentials-auto-fill-button {
  visibility: hidden;
  pointer-events: none;
  position: absolute;
  right: 0;
}

.button{
	position: relative;
	margin: 0 auto;
	display: block;
	width: 10em;
	max-width: 480px;
	padding: 5px 0;
	border-radius: 5px;
	background: #000000;
	border: solid 1px #898989;
	color: #ffffff !important;
	text-align: center;
	transition: all .3s ease-out;
	cursor: pointer;
	z-index: 501;
}
.button::after{display: none;}
.button:hover{background-color: #ffffff;color: #000000 !important;}
button.button{margin: 10px auto 0 auto;max-width: 16em;}
.button:disabled, .button:disabled:hover{background-color: #B0CFD7; color: #8B999F !important;border: solid 1px #B0CFD7; pointer-events : none;}

/* クリア */
#nazo .clearImg{
	position: relative;
	margin: 0 auto 30px auto;
	width: calc(100% - 40px);
	max-width: 800px;
	z-index: 105;
}
#links .pagelinks{
	position: relative;
	margin: 0 auto;
	width: calc(100% - 40px);
	max-width: 800px;
	z-index: 600;
}
#links .pagelinks li{
	position: relative;
	margin: 0 auto 20px auto;
	text-align: center;
	background-color: #000000;
	transition: all .3s ease-out;
}
#links .pagelinks li:hover{background-color: #ffffff;}
#links .pagelinks li a{
	display: block;
	padding: 5px 10px;
	color: #ffffff;
	transition: all .3s ease-out;
}
#links .pagelinks li:hover a{color: #000000;}
#links .snsshare{
	position: relative;
	margin: 50px auto 0 auto;
	width: calc(100% - 40px);
	max-width: 800px;
	z-index: 601;
}
#links .snsshare h4{
	position: relative;
	margin: 0 auto 10px auto;
	text-align: center;
	font-weight: bold;
	line-height: 1.2em;
	padding: 5px 0;
	border-top: solid 2px #dbbc2b;
	border-bottom: solid 2px #dbbc2b;
	color: #ffffff;
}
#links .snsshare img{
	position: relative;
	margin: 0 auto;
	width: 50px;
	transition: all .3s ease-out;
}
#links .snsshare img:hover{transform: scale(1.04, 1.04);}


/* ----- pc ----- */
@media screen and (min-width: 641px) {
	
	/* ヘッダー */
	header {padding: 5px 0 8px 0;}
	header h1 {max-width: 110px;}
	
	/* nazo */
	#nazo  {padding: 40px 0 0 0;}
	#nazo.nazoWrap{padding: 60px 0 0 0;}
	#nazo::before{
		height: calc(100% + 16vw);
		background-size: 500px auto;
		clip-path: polygon(0 0, 100% 0, 100% calc(100% - 16vw), 0 100%);
	}
	#nazo::after{
		top:-20px;
		left: 0;
		height: 310px;
		background-position: calc(50% - 250px) 0;
	}
	#nazo h2{margin: 0 auto 30px auto;}
	.chara{margin: 0 auto 40px auto;gap: 20px;}
	.chara .Img{width: 100px;}
	.chara .Txt{width: calc(100% - 120px);}
	.chara .Txt .name{width: 100px;}
	.chara .Txt .text{
		margin: 8px 0 0 0;
		width: calc(100% - 40px);
		padding: 15px 20px;
	}

	/* list */
	#list, #form, #links  {
		padding: 150px 0 80px 0;
		background-size: 400px auto;
	}
	#list::before{
		height: 250px;
		background: linear-gradient(0deg,rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
	}
	#list ul{gap: 40px;}
	#list ul li{width: calc(33.333% - 27px);}
	#list ul li:hover{transform: scale(1.04, 1.04);transition: all .3s ease-out;}
	
	.button{
		padding: 10px 0;
		font-size: .18rem;
		line-height: 1em;
	}
	
	#form{padding: 20px 0 80px 0;}
	#form::after, #links::after{
		bottom:20px;
		height: 240px;
	}
	#links .pagelinks li a{padding: 10px 20px;}
	#links .snsshare{margin: 80px auto 0 auto;}
	#links .snsshare h4{
		margin: 0 auto 20px auto;
		padding: 10px 0;
	}
	#links .snsshare img{width: 60px;}

}
