@charset "UTF-8";
@media only screen and (max-width: 750px) {
	.pc-only {
		display: none !important;
	}
}

.sp-only {
	display: none !important;
}
@media only screen and (max-width: 750px) {
	.sp-only {
		display: block !important;
	}
}

.sp-only-inline {
	display: none !important;
}
@media only screen and (max-width: 750px) {
	.sp-only-inline {
		display: inline-block !important;
	}
}

html {
	font-size: 100%;
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	background: #fff;
}

img {
	width: 100%;
}

body {
		width: 100%;
		-webkit-text-size-adjust: 100%;
		-ms-text-size-adjust: 100%;
		margin: 0;
		padding: 0;
		border: 0;
		outline: 0;
		font-size: 0.9rem;
		color: #E5004F;
		vertical-align: baseline;
		font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
		font-style: normal;
		line-height: 1.3;
	 /* letter-spacing: 0.1em;*/
		position: relative;
		transition-duration: 500ms;
}

div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video, input, textarea {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	background: transparent;
	line-height: 2rem;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, textarea {
	display: block;
}

nav ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: none;
}

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	color: #333;
	cursor: pointer;
	outline: none;
	z-index:999;
}

input[type=submit] {
	cursor: pointer;
	border: none;
}

textarea {
	resize: vertical;
	overflow: hidden;
}

input, select {
	vertical-align: middle;
	border-radius: 0;
	-moz-border-radius: 0;
	-webkit-border-radius: 0;
	-o-border-radius: 0;
	-ms-border-radius: 0;
	-webkit-appearance: none;
	border: none;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: normal;
}

li {
	list-style: none;
}

address {
	font-style: normal;
}

a {
		cursor: pointer;
		text-decoration: none;
		color: #E5004F;
		font-size:15pt;
		text-decoration:underline;
}
a img {
	outline: none;
}
a:hover, a li:hover, a img:hover {
	opacity: 0.7;
	background: none;
}

/* ----------------------------------------------------------------------------------
 *
 * フッター
 *
 * ---------------------------------------------------------------------------------- */
footer {
	width: 100%;
	text-align: center;
}

footer .wrapper {
	position: relative;
	margin: 0 auto;
	text-align: center;
	width: 100%;
}
@media only screen and (max-width: 750px) {
	footer .wrapper {
		width: 100vw;
	}
}
footer .button-list {
	margin: 0 auto;
	text-align: center;
	margin-bottom: 40px;
}
@media only screen and (max-width: 750px) {
	footer .button-list {
		margin-bottom: 5.3333333333vw;
		margin-left:15vw;
		margin-top:-2vw;
	}
}
footer .button-list .sns {
	margin-bottom: 20px;
}
@media only screen and (max-width: 750px) {
	footer .button-list .sns {
		margin-bottom: 2.4vw;
		margin-left:-2vw;
	}
}
footer .button-list .sns__txt {
	margin: 0 auto;
	text-align: center;
	background: transparent url(../img/common/sns_txt_footer.png) no-repeat 0 0;
	background-size: 100%;
	width: 233px;
	height: 29px;
	margin-bottom: 15px;
}
@media only screen and (max-width: 750px) {
	footer .button-list .sns__txt {
		width: 31.0666666667vw;
		height: 3.8666666667vw;
		margin-bottom: 2vw;
	
	}
}
footer .button-list .sns__icon_block {
	margin: 0 auto;
	text-align: center;
}
footer .button-list .sns__icon_block__twitter {
		display: inline-block;
		background: transparent url(../img/common/sns_twitter.png) no-repeat 0 0;
		background-size: 100%;
		width: 55px;
		height: 55px;
		margin-top: 10px;
		margin-left: 25px;
		margin-right: 5px;
		text-align: center;
}
@media only screen and (max-width: 750px) {
	footer .button-list .sns__icon_block__twitter {
		width: 11.3333333333vw;
		height: 11.3333333333vw;
		margin-right: 1.3333333333vw;
	}
}
footer .button-list .sns__icon_block__line {
		display: inline-block;
		background: transparent url(../img/common/sns_line.png) no-repeat 0 0;
		background-size: 100%;
		margin-top: 10px;
		width: 55px;
		height: 55px;
		margin-left: 5px;
}
@media only screen and (max-width: 750px) {
		footer .button-list .sns__icon_block__line {
				width: 11.3333333333vw;
				height: 11.3333333333vw;
				margin-left:0vw;
				margin-top: 10vw;
		}
}

/*
		.button-list__exercise:hover {
				opacity: 0.7!important;
				display:block;
				background: none;
		}
*/

footer .button-list__event {
	display: block;
	overflow: hidden;
	text-indent: 101%;
	white-space: nowrap;
	margin: 0 auto;
	text-align: center;
	background: transparent url(../img/common/footer_event_btn.png) no-repeat 0 0;
	background-size: 100%;
	width: 400px;
	height: 66px;
}
@media only screen and (max-width: 750px) {
	footer .button-list__event {
		background: transparent url(../img/common/footer_event_btn_sp.png) no-repeat 0 0;
		background-size: 100%;
		width: 400px;
		height: 66px;
		width: 53.3333333333vw;
		height: 8.8vw;
	}
}
footer .logos {
	margin: 0 auto;
	text-align: left;
	margin-left:50px;
	margin-bottom: 20px;
}
@media only screen and (max-width: 750px) {
	footer .logos {
		margin-bottom: 2.6666666667vw;
	}
}
footer .logos__block {
	display: inline-block;
	margin-right: 10px;
}
footer .kikakuarea {
		margin-left: 650px;
}
@media only screen and (max-width: 750px) {
		footer .kikakuarea {
			 /* position: absolute;
				right: 10vw;
				top: 35vw;
				width: 28.1333333333vw;
				height: 20.2666666667vw;*/
		}
}

footer .logos .txt {
		font-size: 13px;
		font-weight: bold;
		color: #fff;
}
@media only screen and (max-width: 750px) {
	footer .logos .txt {
		font-size: 2.6666666667vw;
		text-align:center;
	}
}
footer .logos .txt.shusai {
	vertical-align: middle;
	margin-right: 10px;
}
footer .logos .txt.kikaku {
	vertical-align: middle;
	margin-right: 10px;
}
footer .logos__shusai_logo {
	display: inline-block;
	vertical-align: middle;
	overflow: hidden;
	text-indent: 101%;
	white-space: nowrap;
	margin: 0 auto;
	text-align: center;
	background: transparent url(../img/common/logo.png) no-repeat 0 0;
	background-size: 100%;
	width: 211px;
	height: 77px;
}
@media only screen and (max-width: 750px) {
	footer .logos__shusai_logo {
		top:23vw;
		position:absolute;
		width: 38.1333333333vw;
		height: 20.2666666667vw;
	}
}
footer .logos__nazogeki_logo {
	display: inline-block;
	vertical-align: middle;
	overflow: hidden;
	text-indent: 101%;
	white-space: nowrap;
	margin: 0 auto;
	text-align: center;
	background: transparent url(../img/common/logo_nazogeki.png) no-repeat 0 0;
	background-size: 100%;
	width: 107px;
	height: 45px;
	margin-top:-30px;
}
@media only screen and (max-width: 750px) {
	footer .logos__nazogeki_logo {
		width: 26.2666666667vw;
		height: 16vw;

		/* top: 20vw;
		position: absolute;*/
	}
}
footer .copyright {
	color: #727171 !important;
	font-size: 12pt;

}
@media only screen and (max-width: 750px) {
	footer .copyright {
		font-size: 3.4666666667vw;
	}
}

footer .botomtxt {
	text-align:left;
	padding-left:50px;
	color:rgba(0, 0, 0, 0.5);
}

@media only screen and (max-width: 750px) {
	footer .botomtxt {
		margin-top: 25vw;
		padding-left: 10vw;
		padding-right: 10vw;
		font-size:1vw;
	}
}
.footer_area {
	background: #fff;
	padding: 3% 0;
	margin-top: 3rem;
	position: relative;
	z-index: 0;
	border-top: 1px solid #ddd;
}
.footer_flex {
	display: flex;
	justify-content: flex-start;
	position: relative;
	z-index: 5;
	margin: 0 auto;
	width: 80%;
}
.footer_flex_title {
	text-align:left;
	width:12%;
	font-size:12pt;
	margin-top:10px;
	margin-left:10%;
}
.footer_flex div {
	vertical-align:middle;
	height:60px;
}
.footer_flex_content {
	position: relative;
	width: 72%;
}
.footer_flex_content a {
	display: inline-block;
	margin-right: 2%;
	width: 28%;
}
.footer_flex_content a.img_square {
	width: 12%;
}

.footer_flex_content .sns_icons a {
	width: auto;
	margin-right: 0;
}
.footer_area .txt_jtb {
	font-size: 0.9em;
	color: #000;
	font-family: serif;
	width: 80%;
	margin: 0 auto 1%;
	padding-left: 28%;
	line-height: 1.4em;
}
.footer_area .txt_jtb a {
	color: #000;
	text-decoration: none;
	font-size: 0.9em;
}
.footer_area .txt_jtb a:hover {
	text-decoration: underline;
}
@media only screen and (max-width: 750px) {
	.footer_flex {
		width: 94%;
	}
	.footer_flex_content {
		width: 100%;
	}
	.footer_flex_content a {
		width: 28%;
	}
	.footer_flex_content a.img_square {
		width: 14%;
	}
	.footer_flex_content a.nazoxnazo {
		margin-top: 1em;
		display: block;
		width: 30%;
	}
	.sp_footer1 {
		font-size: 0.7em;
	}
	.footer_flex_title {
		margin-left: 10px;
	}
	.chiyoda_logo {
		width: 46%;
	}
	.footer_area .txt_jtb {
		padding-left: 13%;
	}
	.footer_flex div.sponser {
		height: 30px;
	}
}
.footer_flex	img {
	vertical-align: middle;
}
.footer_area .img_kumo10 {
	position: absolute;
	z-index: 2;
	width: 360px;
	right: 8%;
	top: -30%;
}

/* ----------------------------------------------------------------------------------
 *
 * トップページ
 *
 * ---------------------------------------------------------------------------------- */

main {
	width: 100vw;
}
.top_area {
	width: 100%;
	position: relative;
}
.top_area p {
	width: 100%;
	position: relative;
	text-align: center;
	font-weight: 700;
}
.txt_attention {
	width: 88%;
	margin: 2em auto 3em;
	background: #e0f1f1;
	padding: 3%;
	text-align: center;
	position: relative;
	font-size: 0.6rem;
	line-height: 1.2rem;
}
.img_hanabira {
	position: absolute;
	left: 4%;
	bottom: 19%;
	width: 6vw;
}
.img_sakura01 {
	position: absolute;
	left: 4%;
	top: -14%;
	width: 8vw;
	z-index: 98;
}
.inputarea {
	width: 80%;
	margin: 0 auto;
	position: relative;
	text-align: center;
}
.txt_error {
	display: none;
	text-align: center;
	position: absolute;
	top: -50%;
	width: 100%;
}
.img_good {
	width: 36px;
	position: absolute;
	right: -12%;
	top: calc(50% - 18px);
	display: none;
}
.formarea {
	display: flex;
}
.formarea input {
	width: calc( 100% - 100px);
	height: 100%;
	height: 60px;
	padding-left: 2vw;
	border: 2px solid #e5004f;
}
.keyword {
	background-color: white;
}
.btn_submit {
	width: 90px;
	cursor:pointer;
}
.msg_kaitou {
	width: 100%;
	padding: 1em 0 3em;
	text-align: center;
	margin: 2em auto 0;
	background: #e0f1f1;
}
.img_girl {
	width: 100%;
	margin-top: 2em;
}
.txt_msg {
	font-family: serif;
	margin-top: 1em;
}
.img_sakura02 {
	width: 8%;
	margin: 1em auto;
}
h3 {
	background: #e9546b;
	position: relative;
	width: 86%;
	padding: 2%;
	margin: 0 auto 0.6em;
	color: #fff;
	cursor: pointer;
}
h3:after {
	content: "";
	display: block;
	position: absolute;
	width: 20px;
	height: 20px;
	background: url("../img/icon_arrow01_off.png") no-repeat;
	background-size: 100%;
	right: 2%;
	top: calc(50% - 10px);
}
h3.on:after {
	content: "";
	display: block;
	position: absolute;
	width: 20px;
	height: 20px;
	background: url("../img/icon_arrow01_on.png") no-repeat;
	background-size: 100%;
	right: 2%;
	top: calc(50% - 10px);
}
h3.on {
	margin: 0 auto;
}
h3.lightpink {
	background: #ef858c;
}
h3.darkpink {
	background: #e5004f;
}
h3.green {
	background: #009e96;
}
.hint_sakura {
	display: none;
}
.hint_final {
	display: none;
}
.ttl_hint {
	margin: 1em 0;
}
.hint_box_area {
	display: none;
}
.hint_box {
	display: block;
	width: 86%;
	padding: 2%;
	background: #eeebe9;
	color: #542400;
	margin: 0 auto 0.4em;
}
.next_hint_box {
	display: none;
	width: 86%;
	padding: 2%;
	background: #eeebe9;
	color: #542400;
	margin: 0 auto 0.4em;
}
button.next_hint {
	display: block;
	background: #ef858c;
	color: #fff;
	padding: 2%;
	width: 50%;
	margin: 2em auto 0;
	border: 0;
}
.goto_book {
	width: 80%;
	margin: -1em auto 0;
	background: #e5004f;
	padding: 0.4em;
	border-radius: 50px;
	text-align: center;
	color: #fff;
}
.goto_book img {
	vertical-align: middle;
	width: 10%;
	margin-right: 8px;
}
.ttl_howto {
	margin: 1em 0;
	position: relative;
}
.img_tree {
	width: 30vw;
	position: absolute;
	left: 35%;
	top: 2%;
	z-index: 99;
}
.img_tree_shine {
	width: 30vw;
	position: absolute;
	left: 35%;
	top: 2%;
	z-index: 99;
	display: none;
}
.example01 {
	width: 80%;
	margin: 1em auto;
}
.msg_kaitou {
	display: none;
}
.howto_area {
	text-align: center;
	display: none;
}
.final_area {
	margin: 3em 0 0;
	padding: 1em 0 2em;
	background: #e0f1f1;
	display: none;
}
.img_final {
	width: 90%;
	margin: 1em auto 0;
}
.btn_present {
	width: 86%;
	margin: 0 auto;
	padding: 2%;
	color: #fff100;
	background: #e5004f;
	text-align: center;
	text-decoration: none;
	display: block;
	position: relative;
	font-weight: 700;
	font-size: 1rem;
}
.btn_present:hover {
	background: #e5004f;
	opacity: 0.7;
}
.btn_present:after {
	content: "";
	display: block;
	position: absolute;
	width: 20px;
	height: 20px;
	background: url("../img/icon_arrow02.png") no-repeat;
	background-size: 100%;
	right: 2%;
	top: calc(50% - 10px);
}
.epirogue_area {
	background: #deefef;
	text-align: center;
}
.letter_area {
	line-height: 0;
}
.ttl_epirogue {
	margin-bottom: 1em;
}

/* SNS */
.share_area {
	width: 100%;
}
.share_area p {
	text-align: center;
	margin-top: 2em;
	font-size: 1.5rem;
	color: #5a3819;
	font-weight: 700;
}
.sns_area_wrap {
	margin: 2em auto 0;
}
.sns_area {
	width: 46%;
	margin: 0 auto;
}
.sns_area li {
	display: inline-block;
	width: 25%;
	margin-left: 6%;
	font-size: 0;
}
.watch_area {
	display: none;
}
#wrapper {
	display: flex;
	flex-direction: column;
	height: 250px;
	transition-duration: 500ms;
	position: absolute;
	width: 250px;
	bottom: 18%;
	left: 12%;
	/*background: rgba(0,0,230,0.5);*/
}

#output {
	background-color: #3B3B3B;
	width: 100%;
	display: block;
	min-height: 30px;
	padding: 10px;
	font-size: 0.8em;
	color: white;
	display: none;
}

#rotate-container{
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	color: white;
}

#rotatable {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: #fff;
	width: 60px;
	height: 60px;
	font-size: 2rem;
	background: transparent;
	/*background: rgba(200,0,0,0.2);*/
	left: 41%;
	position: absolute;
	bottom: 40%;
	z-index: 97;
}
#interaction {
	position: fixed;
	bottom: 12%;
	height: 250px;
	width: 250px;
	left: 12%;
	bottom: 18%;
	z-index: 100;
	position: absolute;
	/*background: rgba(0,240,0,0.2);*/
}
.text {
	font-size: 2rem;
	color: #000;
	text-align: center;
}
.bg-gray01 {
	background: #ccc;
}
.bg-gray02 {
	background: #999;
}
.bg-gray03 {
	background: #333;
}
.txt_center {
	text-align: center;
}
.mgb2em {
	margin-bottom: 2em;
}
.opacity_dark {
	opacity: 0.3;
}
.txt_black {
	color: #595757;
}
.txt_pink {
	color: #e5004f;
}
.txt_bold {
	font-weight: 700;
}

@media only screen and (min-width: 750px) {
	/*
	main {
		margin: 0 atuo;
		width: 1000px;
	}
	.top_area {
		margin: 0 auto;
		width: 1000px;
		position: relative;
	}
	*/
	.img_good {
		right: -10%;
	}
	#wrapper {
		width: 50%;
		height: 21%;
		bottom: 15%;
		left: 18%;
	}
	#rotatable {
		left: 46%;
		bottom: 43%;
	}
	#interaction {
		width: 50%;
		height: 21%;
		left: 18%;
		bottom: 15%;
	}
	h3:after {
		top: calc(50% - 10px);
	}
	h3.on:after {
		top: calc(50% - 10px);
	}
	.btn_present:after {
		top: calc(50% - 10px);
	}
}

