@charset "utf-8";
@import url("https://fonts.googleapis.com/css?family=M+PLUS+Rounded+1c:400,700&subset=japanese");
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}h1{font-size:2em;margin:.67em 0}mark{background:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{-moz-box-sizing:content-box;box-sizing:content-box;height:0}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}textarea{overflow:auto}optgroup{font-weight:700}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}

/* base */
* {
	margin: 0;
	padding: 0;
}
html {
	height: 100%;
	overflow-y: scroll;
	color: #2d251d;
	background: #685e53;
	/*background-image: url('../images/bg.png');*/
	background-image: url('../images/body_bg.jpg');
	background-position: center center;
	background-repeat: no-repeat;
	background-attachment: fixed;
	background-size: cover;
	font-size: 62.5%;
}
body {
	/*font-family: 'M PLUS 1p', '游ゴシック', YuGothic, 'メイリオ', Meiryo, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', sans-serif;*/
	font-family: 'M PLUS Rounded 1c', '游ゴシック', YuGothic, 'メイリオ', Meiryo, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', sans-serif;
	letter-spacing: 0.05em;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	height: 100%;
	font-size: 1.4rem;
}
ul {
	list-style: none;
	margin-bottom: 1em;
}
h1,h2,h3,h4,h5,p {
	transform: rotate(0.1deg);
}
h1 {
	font-weight: normal;
	/*color: #51b1b0;*/
	text-align: center;
	font-size: 1.8em;
	text-shadow:
		#eae8df 2px 0px,  #eae8df -2px 0px,
		#eae8df 0px -2px, #eae8df 0px 2px,
		#eae8df 2px 2px , #eae8df -2px 2px,
		#eae8df 2px -2px, #eae8df -2px -2px,
		#eae8df 1px 2px,  #eae8df -1px 2px,
		#eae8df 1px -2px, #eae8df -1px -2px,
		#eae8df 2px 1px,  #eae8df -2px 1px,
		#eae8df 2px -1px, #eae8df -2px -1px;
}
h2 {
	font-family: "Yu mincho DemiBold", "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", serif;
	font-size: 1.8em;
	padding-bottom: 0.75em;
}
h3 {
	font-family: "Yu mincho DemiBold", "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", serif;
	font-size: 1.5em;
	padding-bottom: 0.75em;
}
h4 {
	font-family: "Yu mincho DemiBold", "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", serif;
	font-size: 1.3em;
	padding-bottom: 0.25em;
}
p{
	padding-bottom: 1.5em;
}

header {
	min-height: 100vh;
}
footer {
	color: #e1e8e9;
	background-image: url('../images/bg.png');
	text-align: center;
	padding: 3em;
	padding-bottom: 0;
}

/* snsシェアボタン */
#top_sns {
  margin: 0;
  padding: 0;
  text-align: right;
  position: absolute;
  right: 1em;
  bottom: 0;
}
.sns-share-buttons li{
  display: inline-block;
  vertical-align: top;
  line-height: 0;
  margin-right: 1em;
}
.sns-share-buttons li:last-child{
  margin-right: 0;
}
.sns-share-buttons li img {
	width: 60px;
	height: auto;
}
footer .sns-share-buttons{
	position: static;
	text-align: center;
	margin-bottom: 1.2em;
}
footer .sns-share-buttons li img {
	width: 40px;
}

#top_bg {
	width: 100%;
	height: 100vh;
	background-position:center center;
	background-size: cover;
	display: flex;
	align-items: center;
	justify-content: center;
	background-attachment: fixed;
}
#top_outer {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100vh;
	width: 100%;
}
#top_inner {
	width: 100%;
	/*margin-top: 15%;*/
	position: absolute;
	bottom: 0;
}
#top_logo_wrapper {
	text-align: center;
}
#top_logo {
	width: 40%;
	height: auto;
	max-width: 300px;
}
#top_message_area {
	/*color: white;*/
	background-color: rgba(234, 229, 219, 0.7);
	padding: 0.5em;
	font-size: 1.2em;
	letter-spacing: 0.05em;
	text-align: center;
	font-weight: bold;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
#top_message_area h2,
#top_message_area p {
	padding-bottom: 0.25em;
}
#down_arrow_wrapper {
	text-align: center;
	margin-bottom: 1em;
}
#down_arrow {
	width: 15%;
	max-width: 100px;
}

.font-serif {
	font-family: "Yu mincho DemiBold", "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", serif;
}
.content {
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	/*background-color: rgba(234, 229, 219, 1);*/
	background-image: url('../images/system_bg.jpg');
}
.twocolumn_first_inner {
	padding-right: 0.75em;
}
.twocolumn_second_inner {
	padding-left: 0.75em;
}
.content > section {
	padding: 1.5em;
}
section {
	overflow: hidden;
	text-align: center;
}
#schedule {
	width: 50%;
	float: left;
}
#schedule_inner {
	font-size: 1.2em;
	background: #fff;
	border: solid 1px #6b6152;
	/*border-top: none;*/
	min-height: 60vh;
}
#schedule_remark {
	padding: 1em;
	border-top: solid 1px #6b6152;
	text-align: left;
	/*font-weight: bold;*/
	letter-spacing: 0;
}
#twitter_timeline {
	width: 50%;
	float: right;
}

#story_bg {
    background: transparent;
}
#story_bg .content {
	background: transparent;
}
#story {
	font-size: 1.2em;
	line-height: 1.6em;
	min-height: 800px;
	padding: 3em;
}
#story_bg_inner {
	background-image: url('../images/story_char_full.png');
	background-position: center bottom;
	background-repeat: no-repeat;
	min-height: 800px;
}
#story_outer {
	padding: 0 300px 0 0;
}

#story_inner {
	background-color: rgba(234, 229, 219, 0.75);
	padding: 1.5em;
	border: solid 2px #6b6152;
	border-radius: 0.5em;
	color: #6b6152;
}
#story_inner p {
	margin-bottom: 1em;
}
#system {
	font-size: 1.2em;
	line-height: 1.6em;

	background-image:	url('../images/system_bg_top_left.png'),
						url('../images/system_bg_top_right.png'),
						url('../images/system_bg_bottom_left.png'),
						url('../images/system_bg_bottom_right.png'),
						url('../images/system_bg.jpg');
	background-position: left top, right top, left bottom, right bottom, left top;
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat;
	padding: 5em;
	text-align: center;

}
#system p.attention{
	font-family: 'M PLUS Rounded 1c', '游ゴシック', YuGothic, 'メイリオ', Meiryo, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', sans-serif;
	font-size: 1.2em;
	font-weight: bold;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
#menu h2, #access h2, #recruit h2{
	margin-top: 1em;
}
#cast {
}
#cast dd {
	float: left;
	width: 18%;
	padding: 1%;
}
#cast dd img {
	width: 100%;
	height: auto;
}
.image_list {
	display: flex;
	justify-content: center;
	align-items: center;
}
#access .content, #recruit .content {
	position: relative;
	min-height: 640px;
	padding: 0;
}
#access_detail {
	margin-right: 490px;
	padding: 2em;
}
#access_photo {
	text-align: right;
	position: absolute;
	top: 0;
	right: 0;
}
#recruit #recruit_top.content {
	min-height: auto;
}
#recruit_top_inner {
	padding: 2em 2em 0;
}
#recruit_detail {
	margin-left: 490px;
	padding: 0 2em 2em;
}
#recruit_photo {
	text-align: left;
	position: absolute;
	bottom: 0;
	left: 0;
}
#map_outer {
	margin: 0 auto;
	position: relative;
	width: 100%;
	min-height: 50vh;
}
#map_outer iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}
#footer_logo {
	width: 80%;
	height: auto;
	max-width: 300px;
}

#error_page {
	/*min-height: 80%;*/
	text-align: center;
	padding: 5em 0;
}

.contact_form_block {
	
}
.contact_form_block__input,
.contact_form_block__textarea,
.contact_form_block__submit {
	margin-bottom: 0.5em;
}
.contact_form_block__submit {
	margin-top: 1em;
}
.contact_form_block__radio {
	margin-bottom: 1em;
}

input[type=radio] {
	margin-right: 0.2em;
}
label {
	padding: 0 0.5em;
}
input[type=text] {
	width: 100%;
	height: 40px;
	padding: 0 5px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	outline: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-box-shadow: none;
	box-shadow: none;
	border-radius: 0;
	border: 1px solid #c5c5c5;
/*
	-webkit-transition-property: all;
	-o-transition-property: all;
	transition-property: all;
	-webkit-transition: .3s linear;
	-o-transition: .3s linear;
	transition: .3s linear;
*/
}
textarea {
	width: 100%;
	padding: 0 5px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	outline: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-box-shadow: none;
	box-shadow: none;
	border-radius: 0;
	border: 1px solid #c5c5c5;
/*
	-webkit-transition-property: all;
	-o-transition-property: all;
	transition-property: all;
	-webkit-transition: .3s linear;
	-o-transition: .3s linear;
	transition: .3s linear;
*/
}
button {
	font-size: 1.1em;
	letter-spacing: 0.05em;
	color: #eae8df;
	background-color: #55b1af;
	width: 100%;
	max-width: 400px;
	height: 40px;
	padding: 0 5px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	outline: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-box-shadow: none;
	box-shadow: none;
	border-radius: 0;
	border: 1px solid #eae8df;
}
.contact_form_block__back button {
	color: #55b1af;
	background-color: #eae8df;
	border: 1px solid #55b1af;
}

#contact {
	margin: 1.5em 0;
}
#contact_detail {
	padding: 2em;
}

.contact_form_block_button_wrapper .contact_form_block__submit{
	display: inline-block;
	width: calc(100% / 2 - 3em);
}
.contact_form_block_button_wrapper .contact_form_block__back{
	display: inline-block;
	width: calc(100% / 2 - 3em);
}
.form_error {
	display: block;
	color: #ff7777;
	text-align: left;
	font-weight: bold;
	margin-left: 0.5em;
	font-size: 0.8em;
}
.error_item {
	background: #ffff99;
}
#contact dt {
	font-weight: bold;
	border-bottom: solid 1px #55b1af; /*** #2d251d ***/
	margin-bottom: 0.5em;
}
#contact dd {
	font-size: 1.2em;
	margin-bottom: 1em;
}

.contact_complete_remark {
	margin: 3em 0;
}

.fade-in {
	visibility: hidden;
}
.fade-in-animation {
	-webkit-animation-fill-mode:both;
	-ms-animation-fill-mode:both;
	animation-fill-mode:both;
	-webkit-animation-duration:1.5s;
	-ms-animation-duration:1.5s;
	animation-duration:1.5s;
	-webkit-animation-name: fade-in-animation;
	-ms-animation-name: fade-in-animation;
	animation-name: fade-in-animation;
	visibility: visible !important;
}
@-webkit-keyframes fade-in-animation {
	0% { opacity: 0; -webkit-transform: translateY(-20px); }
	100% { opacity: 1; -webkit-transform: translateY(0); }
}
@keyframes fade-in-animation {
	0% { opacity: 0; -webkit-transform: translateY(-20px); -ms-transform: translateY(-20px); transform: translateY(-20px); }
	100% { opacity: 1; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); }
}

#test_overlay {
	position: fixed;
	width: 100%;
	top: 0;
	padding: 2em 0;
	text-align: center;
	background-color: rgba(255, 255, 0, 0.5);
	color: red;
	font-size: 2em;
	font-weight: bold;

}

/***********************************************/
/* contents幅以下の場合のレイアウト            */
/***********************************************/
@media screen and (max-width: 1440px) {
	#story_bg_inner {
		background-image: url('../images/story_char.png');
		background-position: right bottom;
		background-repeat: no-repeat;
	}
	.content {
		margin: 0;
	}
}
/***********************************************/
/* タブレット向けレイアウト                    */
/***********************************************/
@media screen and (max-width: 768px) {

	#schedule {
		width: 100%;
		float: none;
	}
	#twitter_timeline {
		width: 100%;
		float: none;
	}
	.twocolumn_first_inner {
		padding: 0;
	}
	.twocolumn_second_inner {
		padding: 0;
		padding-top: 1.5em;
	}
	#story_bg_inner {
		background-image: url('../images/tw_story_char.png');
	}
	#story_outer {
		padding: 0 200px 0 0;
	}
	#system {
		background-image:	url('../images/tb_system_bg_top_left.png'),
							url('../images/tb_system_bg_top_right.png'),
							url('../images/tb_system_bg_bottom_left.png'),
							url('../images/tb_system_bg_bottom_right.png'),
							url('../images/system_bg.jpg');
	}
	#cast dd {
		width: 23%;
	}
	#access .content, #recruit .content {
		position: static;
		min-height: auto;
	}
	#access_detail, #recruit_detail {
		margin: 0;
	}
	#access_photo, #recruit_photo {
		text-align: center;
		position: static;
		padding-bottom: 2em;
	}

	
	input,textarea,label,button {
		font-size: 17px;
	}
	#contact dt {
	}
	#contact dd {
		font-size: 17px;
	}

}
/***********************************************/
/* スマホ向けレイアウト                        */
/***********************************************/
@media screen and (max-width: 640px) {

	html {
		/*background-image: url('../images/sp_body_bg.jpg');*/
		background-image: url('../images/bg.png');
		background-repeat: repeat;
	}
	body {
		font-size: 1rem;
	}
	h1 {
		font-size: 1em;
		text-shadow:
			#eae8df 1px 1px 0, #eae8df -1px -1px 0,/*右下、左上*/
			#eae8df -1px 1px 0, #eae8df 1px -1px 0,/*右上、左下*/
			#eae8df 0px 1px 0, #eae8df  0-1px 0,/*右、左*/
			#eae8df -1px 0 0, #eae8df 1px 0 0;/*上、下*/
	}
	.sns-share-buttons li img {
		width: 40px;
	}
	.nosp {
		display: none;
	}
	.content > section {
		padding: 1em;
	}
	#top_bg {
		width: 100%;
		/*height: 58vh;*/
		/*margin-bottom: 42vh;*/
	}
	#top_inner {
		/*bottom: 5vh;*/
	}
	#top_logo {
		width: 30%;
	}
	#top_message_area {
		margin: 0;
	}
	#top_message_area p {
	    padding-bottom: 0.5em;
	    line-height: 1.1em;
	}
	#news {
		padding: 1.5em 1.5em 1em;
	}
	#schedule_remark {
		font-size: 0.8em;
		letter-spacing: 0;
	}
	#story {
		font-size: 1em;
	}
	#story_bg .content > section {
		padding: 3em 0;
		min-height: auto;
	}
	#story_bg_inner {
		background-image: url('../images/sp_story_char.png');
		min-height: auto;
	}
	#story_outer {
		padding: 0 20% 0 1.5em;
	}
	#story_inner {
		padding: 1em 0.5em 0;
		letter-spacing: 0;
	}
	#story_inner p {
		padding-bottom: 0.2em;
		line-height: 1.5em;
	}
	#system {
		background-image:	url('../images/sp_system_bg_top_left.png'),
							url('../images/sp_system_bg_top_right.png'),
							url('../images/sp_system_bg_bottom_left.png'),
							url('../images/sp_system_bg_bottom_right.png'),
							url('../images/system_bg.jpg');
		padding: 3em 1.5em;
	}
	#cast dd {
		width: 48%;
	}
	#access, #recruit {
		background-image: url('../images/sp_body_bg.jpg');
	}
	#access_photo, #recruit_photo{
		padding-bottom: 0;
	}
	#access_photo img, #recruit_photo img{
		width: 100%;
		height: auto;
	}
	#contact h2{
		color: #e1e8e9;
	}
	.contact_form_block_button_wrapper .contact_form_block__submit,
	.contact_form_block_button_wrapper .contact_form_block__back{
		display: block;
		width: 100%;
	}
	.contact_complete_remark {
		margin: 0;
	}

}
