/* =Reset default browser CSS. Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}
:focus {/* remember to define focus styles! */
	outline: 0;
}
body {
	background: #fff;
	line-height: 1;
}
ol, ul {
	list-style: none;
}
table {/* tables still need 'cellspacing="0"' in the markup */
	border-collapse: separate;
	border-spacing: 0;
}
caption, th, td {
	font-weight: normal;
	text-align: left;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: "";
}
blockquote, q {
	quotes: "" "";
}
a img {
	border: 0;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

/* =============================================================================
   Non-Semantic Helper Classes
   ========================================================================== */

.ir { display: block; border: 0; text-indent: -999em; overflow: hidden; background-color: transparent; background-repeat: no-repeat; text-align: left; direction: ltr; *line-height: 0; }
.ir br { display: none; }
.hidden { display: none !important; visibility: hidden; }
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }
.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }
.invisible { visibility: hidden; }
.clearfix:before, .clearfix:after { content: ""; display: table; }
.clearfix:after { clear: both; }
.clearfix { *zoom: 1; }
.clear { clear:both;}
.shadow-box { border:1px solid #aaa; border-top:1px solid #ccc;	box-shadow: 0 10px 15px #aaa;moz-box-shadow: 0 10px 15px #aaa;webkit-box-shadow: 0 10px 15px #aaa;}

/* =Structure
----------------------------------------------- */
body {
	min-width: 11000px;
	background: url("../img/bg_image.jpg") repeat-x;
	background-size: auto;
	background-attachment: fixed;
	font-family: sans-serif;
	font-size: 12px;
	line-height: 1.3em;
	color: #3fa7f3;
}
#op_white {
	position: absolute;
	z-index: 999;
	display: block;
	background: rgba(255,255,255,1);
	height: 100%;
}
::selection {
	color: #000;
	background: #fff;
}
::-moz-selection {
	color: #000;
	background: #fff;
}
strong {
	font-weight: 800;
}
ul#wrapper {
}
li.page {
	position: relative;
	float: left;
	width: 10%;
	height: 550px;
	min-width: 1000px;
}
footer#colophon {
	position: relative;
	width: 100%;
	height: 80px;
	margin-top: 5px;
	background-color: rgba(255,255,255,0.7);
}

li.page header {
	width: 100%;
	height: 100px;
	text-indent: -99999px;
}

li.page article {
	min-width: 800px;
	height: 420px;
	margin: 0 auto;
	padding: 0 50px 30px 50px;
}
.article_wrapper {
	width: 840px;
	margin: 0 auto 10px auto;
	padding: 10px 30px;
	background: rgba(255,255,255,0.3)
}

h2.article_title {
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 1px solid #3fa7f3;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
}
.arrow_right,
.arrow_left {
	position: absolute;
	bottom: 30px;
	display: block;
	height: 28px;
	width: 51px;
	text-indent: -99999px;
}
.arrow_right {
	right: 50px;
	margin: 0 0 0 auto;
	background: url("../img/arrow.png") no-repeat;
	background-position: right;
}
.arrow_left {
	left: 50px;
	margin: 0 auto 0 0;
	background: url("../img/arrow.png") no-repeat;
	background-position: left;
}

#last_margin {
	float: left;
	height: 550px;
	width: 1%;
}
/* top */
li#top article {
	width: 100%;
	min-width: 1000px;
	height: 550px;
	padding: 0;
}

.white_bg {
	background: rgba(255,255,255,0.7);
}

h1#page-title {
	height: 550px;
	width: 100%;
	padding: 0;
	background: url("../img/sarachi_logo.png") no-repeat;
	background-position: center top;
	text-indent: -99999px;
}

.top_info {
	height: 120px;
	text-align: center;
}
.top_info p {
	margin: 0 auto;
	line-height: 1.8em;
	letter-spacing: 0.1em;
}
p.top_date_place {
	font-size: 14px;
	font-weight: 300;
}
p.top_cast_staff {
	font-size: 12px;
	letter-spacing: 0;
}

/* intro */
header#intro_title {
	height: 100px;
	width: 100%;
	background: url("../img/intro_header.png") no-repeat;
	background-position: center center;
	text-indent: -99999px;
}

#intro article {
	width: 100%;
	min-width: 1000px;
	padding: 0;
}

#intro .intro_wrapper {
	min-width: 1000px;
}

p#intro_content {
	min-width: 1000px;
	height: 550px;
	padding: 0;
	text-indent: -99999px;
	background: url("../img/intro.png");
	background-position: center top;
}

/* cast */
li#cast header.cast_title {
	background: url("../img/cast_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}
.cast_profile_wrapper {
	width: 900px;
	margin: 0 auto;
}
.takeda_profile_wrapper,
.okubo_profile_wrapper {
	float: left;
	width: 380px;
	height: 400px;
	margin-right: 10px;
}
.takeda_profile_wrapper img,
.okubo_profile_wrapper img {
	display: block;
	margin: 10px auto;
}

/* staff */

li#staff header.staff_title {
	background: url("../img/staff_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}

#staff article img {
	display: block;
}

#staff article div {
	width: 840px;
	margin: 0 auto 10px auto;
}

#staff article .sugihara_profile_wrapper {
}

#staff article .sugihara_profile_wrapper img {
	display: block;
	float: left;
	margin-right: 10px;
}

#staff article .otashogo_profile_wrapper {
}

#staff article .otashogo_profile_wrapper img {
	float: right;
	margin: 0 10px;
}

p.sarachi_staff {
	margin: 30px 0;
	text-align: center;
}

#staff2 article {
	padding-top: 50px;
}
/* story */
#story header.story_title {
	background: url("../img/story_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}
.story_wrapper {
}
#story p {
	margin-bottom: 15px;
	font-size: 18px;
	text-align: center;
	line-height: 1.5em;
}
.story1 {
	font-size: 24px;
}
.story_strong {
	width: auto;
	border-bottom: 1px solid #3fa7f3;
	font-size: 24px;
	font-weight: 800;
	line-height: 1.5em;
}
/* note */
#note header.note_title {
	background: url("../img/note_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}
.note_img_wrapper {
	float: left;
	width: 250px;
	margin-right: 10px;
}
.note_img_wrapper img {
}
.note_content_wrapper {
	float: left;
	width: 550px;
}
.sarachi_note2 {
	float: left;
	width: 550px;
	margin-top: 30px;
}



/* schedule ticket */
#schedule_ticket header.schedule_ticket_title {
	background: url("../img/schedule_ticket_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}

.schedule_table {
	float: left;
	width: 370px;
	margin-right: 30px;
}

table.ticket_reserved {
	width: 100%;
}

table.ticket_reserved td {
	padding-top: 5px;
	border-bottom: 1px solid #3fa7f3;
}

table.ticket_reserved caption {
	margin-bottom: 10px;
	text-align: center;
	font-size: 14px;
	font-weight: 700;
}

span.table_description {
	font-size: 12px;
	text-align: right;
}

.schedule_description {
	float: left;
	width: 440px;
}
.schedule_description li {
	list-style: circle;
}

.ticket_left {
	float: left;
	width: 390px;
	margin-right: 10px;
}
.ticket_right {
	float: left;
	width: 440px;
}

/* info */
#info header.info_title {
	background: url("../img/info_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}

.info_wrapper {
	width: 900px;
	margin: 0 auto;
}

.map_wrapper {
	float: left;
	width: 450px;
	height: 400px;
	margin: 0;
}
.place_wrapper  {
	width: 270px;
	margin: 0 auto 0 116px;
	padding: 5px 10px;
	border: 1px solid #999;
	border-bottom: none;
	background: #fff;
}

.contact_wrapper {
	float: left;
	width: 330px;
	height: 400px;
	margin: 0;
}

/* news */
#news header.news_title {
	background: url("../img/news_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}

/* special */
#special header.special_title {
	background: url("../img/special_header.png");
	background-repeat: no-repeat;
	background-position: center top;
}

.sarachi_post_title {
}

#special h3.special_heading {
	font-weight: bold
}

/* footer */
nav#menu {
	position: absolute;
	width: 10%;
	color: #aedd04;
	font-size: 18px;
	font-weight: 700;
}
ul#menu_wrapper {
	width: 800px;
	margin: 0 auto;
	padding-top: 10px;
}
li.menu_container {
	float: left;
	margin: 0 10px 5px 0;
}
#menu a {
	display: block;
	height: 24px;
	padding: 3px 10px;
	color: #3fa7f3;
	text-align: center;
	text-decoration: none;
}
#menu a:hover {
	color: #fff;  /* Fallback: assume this color ON TOP of image */
}



/* blog */
body#sarachi_blog {
	width: 100%;
	min-width: 100%;
}
#sarachi_blog #primary {
	width: 900px;
	margin: 0 auto;
}
#sarachi_blog h1#page_title {
	width: 900px;
	height: 300px;
	background: url("../img/blog_header.png");
	background-repeat: no-repeat;
	position: top center;
	text-indent: -99999px;
}

#sarachi_blog #content {
	padding: 0 100px 50px 100px;
}

#sarachi_blog article {
	margin-bottom: 100px;
}
#sarachi_blog header.entry-header {
	margin-bottom: 30px;
	padding-bottom: 5px;
	border-bottom: 1px solid #3fa7f3;
}
#sarachi_blog h3.entry-title {
	padding-bottom: 12px;
	font-size: 18px;
	font-weight: 700;
}
#sarachi_blog p.date {
}
#sarachi_blog .entry-content {
}

/* special page */
body#sarachi_special {
	width: 100%;
	min-width: 100%;
}
#sarachi_special #primary {
	width: 900px;
	margin: 0 auto;
}
#sarachi_special h1#page_title {
	width: 900px;
	height: 300px;
	background: url("../img/specialpage_header.png");
	background-repeat: no-repeat;
	position: top center;
	text-indent: -99999px;
}

#sarachi_special #content {
	padding: 0 100px 50px 100px;
}

#sarachi_special article {
	margin-bottom: 100px;
}
#sarachi_special header.entry-header {
	margin-bottom: 30px;
	padding-bottom: 5px;
	border-bottom: 1px solid #3fa7f3;
}
#sarachi_special h3.entry-title {
	padding-bottom: 12px;
	font-size: 18px;
	font-weight: 700;
}
#sarachi_special p.date {
}
#sarachi_special .entry-content {
	padding-bottom: 30px;
	border-bottom: 1px solid #3fa7f3;
}
#sarachi_special footer.entry-meta {
	border: none;
	font-size: 10px;
	text-align: right;
}
