@charset "UTF-8";

/*　共通設定--------------------------------　*/

html, body, header, section, article, nav, footer,
div, span, p, h1, h2, h3, h4, ul, ol, li, dl, dt, dd,
table, tr, th, td, tbody, thead, tfoot {
	margin: 0;
	padding: 0;}

img { border: 0; vertical-align:bottom }

body {
	width: 100%;
	background-color: #fff;
/*	font: 14px/1.231 'ヒラギノ角ゴ pro W3', "Hiragino KaKu Gothic Pro", Osaka, sans-serif; */
	font-size: 15px;
	line-height: 2em;
	-webkit-text-size-adjust: 100%;
	}
.sp-only{
	display: block;
}

/*　ヘッダー・スライドバー--------------------------------　*/

/* slimmenu.js内の .menu-collapseに上書き */
.menu-collapser {
	height:70px;
	text-align:left; /* ロゴの位置 */
	background-color:#fff;
}
/* menu内のロゴ画像設定 */
.menu-collapser img#spHeadLogo{
	margin:5px 20px 0 auto;
	max-height:55px;
	width: auto;
}


#head {
	display:none;
}




/*　ビジュアル--------------------------------　*/

#visual {
	width:100% ;
	height:auto;
	padding: 0 0 0 0;
}




table td {
	line-height:1.8em }

table td hr {
	margin:0 0 1em 0;
    border: 0;
    height: 1px;
    background: url(../img/hr.gif) repeat-x ;
}

body.index .theme-default .nivoSlider {
    margin-bottom: 0 !important;
}


/*　ナビ表示--------------------------------　*/

/*　背景　*/
.sb-slidebar {
	border-left:1px solid #999;/* 左側にborder */
	background:#fff !important; /* slideber.cssの設定を上書き */
	}

#navi-box {
	width:100%;
	height:70px;/* naviの高さ */
	position:relative;
	z-index:2 ;
	}

#navi {
	text-decoration: none;
	width: 100%;
	height:70px;
	margin: 0 0 0px 0;
	background:none;
	z-index:2 ;
	}

#navi h1 {
	display:none;}

#navi ul {
	width: 100%;
	height:auto;
	background:none;
	border-bottom: 1px solid #999;
	margin: 0 auto 10px;
	} /* ナビ下のborder */

#navi li {
	float:none;
	list-style: none;
	text-align: left;
	width: 100%;
	max-width: inherit;
}

#navi li a {
	text-decoration: none;
	padding: 5px;
	height:auto;
	width:100%;
	display: block;
	font-weight: normal;
	border-top: solid 1px #999;/* li上のborder */
	color: #333 !important;/* 文字色 */
	background:#fff;/* リンク背景 */
}

#navi li a span{
	display:none;
	}


/* スマホ用ナビを表示 */
#navi li.spnavi {
	display:inline;
}

/* hover時の設定 */
#navi li a:hover ,
body.index li a#navi-index ,
body.teacher li a#navi-teacher ,
body.lesson li a#navi-lesson ,
/* スマホ用ナビ */
body.contact li a#navi-contact {
	background:none;
	color:#fff !important;
	background-color:#cebb90;
}

li a#navi-index {
	margin-left:0px;
}

/*　スクロール時のナビ固定　jquery連動*/
.fixed {
	position: fixed;
	top: 0px;}






/*　パンくずリスト--------------------------------　*/
#bread {
	width:96%;
	}





/*　コンテンツ　メインカラム--------------------------------　*/

#contents-main{
	width:96%;
	padding: 30px 0 30px 0;
	margin:0px auto 0px auto;
}

#contents-main h2 {
	margin: 0 auto 30px;
	font-size: 130%;
	background-size: 150px;
}

#contents-main h3 {
	font-size:100% ;
	padding:0 0 0.3em 0;
}
#contents-sub h2 {
	margin: 0 auto 30px;
	font-size: 130%;
}

/* 行間設定 */
#contents-main p {
	line-height:1.9em;
}

#contents-main p img {
	width:100%;
	height:auto;
	margin:0 0 1em 0;
	}


/* ページトップ（非表示にする設定） */
#footer p.pagetop {
	display: none;
}
#footer p.pagetop a {
	display: none;
}

/* アクセス（前頁共通）--------------------------------　*/

#contents-sub .access{
	padding: 30px 1%;
}
#contents-sub .access h2{
	margin-bottom: 15px;
}

#contents-sub .access img{
	width: 100%;
}

#contents-sub .access img.map{
	margin-right: 0;
	width: 100%;
	max-width: inherit;
	float: none;
	margin-bottom: 2em;
}
#contents-sub .access .fl-right{
	float: none;
	width: 100%;
	max-width: inherit;
}






/* ★トップページのみ--------------------------------　*/

body.index #contents-main {
	width:96%;
	padding:30px 0 20px 0;
	}

body.index #contents-main #top-blog {
	width:100%;
}
/*トップページ　文章*/
body.index #contents-main .aboutshuku h2 {
	background: none;
	margin-bottom: 20px;
}

body.index #contents-main .aboutshuku p {
	text-align: left;
	line-height:2;
}



/* ★ブログページのみ--------------------------------　*/

body #contents-main .entry p img{
	width:100%;
	margin:0 0 1em 0;
	height:auto;
}





/* ★公式ブログページ　個別設定-------------------------------- */

/* 一覧・詳細　共通設定　-----*/
body.blog #contents {
	width:96%;
	}
body.blog #contents-main {
	width:100%;
	float:none;
	padding-top:0px;
	}

/* 記事件名 */
body.blog #contents-main h2{
	font-size:14px;
	margin-bottom:1em;
}
body.blog #contents-main .entry {
	margin-bottom:1em;
	}

/* ブログ・カテゴリタイトル表示用 */
body.blog #contents-main .category-ti {
	font-size:16px;
	margin:0 auto 1em auto  ;
	}
body.detail #contents-main .category-ti {
	margin:0 auto 1em auto  ;
}

/* サイドメニュー */
body.blog #contents-banner {
	width:100%;
	float:none;
	padding-top:0px;
	}
body.blog #contents-banner .banner-box {
	margin-bottom:2em;
	}

body.blog #contents-banner h2 {
	font-size:13px;
	margin-bottom:1em;
	}
body.blog #contents-banner ul {
	font-size:13px;
	}
body.blog #contents-banner ul li{
	margin-left:20px;
	}





/* ブログ　一覧ページ　-----*/

/* 記事ブロック */
body.list #contents-main .entry {
	width:100%;
	float:none;
	margin:0px;
	padding:0;
	}

/* サムネイル画像 */
body.list #contents-main .entry p.thumb img {
	width:100% ;
}

/* 記事件名 */
body.list #contents-main h2 {
	font-size:14px;
	margin-bottom:0.5em;
	background:url(../img/top_info_li.jpg) no-repeat 0 6px ;
	}





/* ★お問い合わせ-------------------------------- */

/* お問い合わせ　テーブル設定 */
body #contents-main table#inquiry_form  th {
	width:auto;
	display: block;
	margin-top: 10px;
	padding: 2px 6px;
	}

/* nest table用 */
body #contents-main table#inquiry_form table{
	width:30%;
}

/* テキストボックスなどの長さ */

body #contents-main table#inquiry_form  tr.require{
	display: block;
}
body #contents-main table#inquiry_form td {
	display: block;
	padding: 1em 10px;
}

body #contents-main table#inquiry_form  td input.name{
	width:100%;
	display: block;
}
body #contents-main table#inquiry_form  td input.mail{
	width:100%;
	display: block;
}
body #contents-main table#inquiry_form  td input.tel{
	width:100%;
	display: block;
}
body #contents-main table#inquiry_form  td text {
	width:100%;
	display: block;}


/* ★リンク集-------------------------------- */

body.links #contents-main ul > li{
	list-style: none;
	float: none;
	margin: 0 auto 3em;
}
body.links #contents-main ul > li img{
	width: 96%;
	height: auto;
	margin: 0 auto;
}
body.links #contents-main ul > li p{
	font-size: 15px;
	margin-bottom: 5px;
}




/* ★出演者のみ--------------------------------　*/

body.index #contents-main #performer-navi, body.performers #contents-main #performer-navi  {
	margin-bottom:40px;
	}


body.index #contents-main #performer-navi p, body.performers #contents-main #performer-navi p {
	width: 43%;
	margin:10px 10px;
	padding:0 ;
	float:left;
	}


body.index #contents-main #performer-navi p img, body.performers #contents-main #performer-navi p img {
	margin-bottom:0;
	}




/* ★タイムテーブル--------------------------------　*/

body.timetable #contents-main table{
	border:0;
	margin:50px 0 50px -5px;
	border-collapse:separate; width: 100%;

}

body.timetable #contents-main table td{
	width:25%;
	vertical-align:top;
	text-align:center;
	padding:1px 0 5px 0;
	line-height:1.5em;
}


body.timetable #contents-main table td img{
	margin:0;
	width:140px
}


body.timetable #contents-main table th{
	background-color:#eee;
}

/* ★archive--------------------------------　*/

#contents-main .archive-list_item {
    width: 50%;
    padding: 0 10px;
    margin-bottom: 30px;
    box-sizing: border-box;
}
#contents-main .archive-list_item em {
    margin-bottom: 6px;
}
#contents-main .archive-list_item .overview {
    line-height: 1.4;
    display: inline-block;
	font-size: 90%;
}
