/*
基本設定
-------------------------------------------------------------------*/


*{
 margin : 0px ;
 padding : 0px ;
 font-size : 100% ;
 letter-spacing : 1px ;
 line-height : 130% ;
 }

html{
	height:100%;
	}
body{
	margin:0;
	padding:0;
	color:#000000;
	
	font-family: "メイリオ", "Meiryo", verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;

    font-size: 14px;
	background:#cccccc;
	height:100%;
	overflow: hidden;
	}

a{
	color:#0099FF;
	}

a:hover{
	color:#008cd8;
	text-decoration:underline;
	}




/*
基本レイアウト
-------------------------------------------------------------------*/

#base{
	position: relative;
	height: 100%;
	width:100%;
	box-sizing: border-box;
	padding: 0 0 340px;
	
	transition-property: padding-bottom;
	transition-duration: 200ms;
	transition-timing-function: ease-out;
	}

.scheduler{
	position: relative;
	text-align:left;
	overflow-y: scroll;
	height: 100%;
	}


#bottom_menu{
	margin: 15px 5px 250px 25px;
	list-style: none;
	overflow: hidden;
	}
	 
	#bottom_menu li {
		margin-right: 30px;
		text-align: center;
		float: left;
		}
	 
	#bottom_menu li a {
		text-decoration: none;
		color: #999;
		}
	
#controller{
	position: absolute;
	bottom:0;
	background-color: #dbebc4;
	width: 100%;
	height:340px;
	padding: 0 0 0 750px;
	box-sizing: border-box;
	scrollbar-color: #9fc24d #dbebc4;/*#dbffb7 #dbebc4;*/
	transition-property: height;
	transition-duration: 200ms;
	transition-timing-function: ease-out;
	overflow: hidden;
	}

#controller_toggle{
	position: fixed;
	bottom: 0;
	right: 30px;
	width: 60px;
	height: 30px;
	background-color: #dbebc4;
	padding: 5px;
	box-sizing: border-box;
	cursor: pointer;
	text-align: center;
	transition-property: bottom;
    transition-duration: 200ms;
    transition-timing-function: ease-out;
	}

#controller_inner_left{
	
	position: absolute;
	bottom: 0;
	left: 0;
	overflow-y: scroll;
	height: 340px;
	width: 750px;
	float: left;
	
	}

#controller table{
	margin: 0;
	border-collapse:collapse;
	width: 100%;
	}
	#controller table tr#reserve_list th,
	#controller table tr#reserve_list td{
		padding:2px 2px;
		font-weight:normal;
		white-space:nowrap;
		vertical-align:middle;
		}
	#controller table th,
	#controller table td{
		padding:2px 2px;
		font-weight:normal;
		white-space:nowrap;
		vertical-align:middle;
		}
		
	#controller input[type="text"], #controller input[type="number"], #controller input[type="tel"], #controller textarea, #controller select {
		background-color:#f0f6da;
		font-size: 20px;
		}
		#controller input[type="text"]:disabled, #controller input[type="number"]:disabled, #controller input[type="tel"]:disabled, #controller textarea:disabled, #controller select:disabled {
			background-color:#e0e0e0;
			}

/* new clearfix */  
.container:after {  
 visibility : hidden ;  
 display : block ;  
 font-size : 0 ;  
 content : " " ;  
 clear : both ;  
 height : 0 ;  
 }  
* html .container             { zoom : 1 ; } /* IE6 */  
*:first-child+html .container { zoom : 1 ; } /* IE7 */  



.header {
	margin-right: auto;
	margin-left: auto;
	
	height: 125px;

/*角丸（FF/Safari/Chrome）IE無効*/
 border-bottom-left-radius: 20px;    /* 左下 */
 border-bottom-right-radius: 20px; /* 右下 */

-webkit-border-bottom-left-radius: 20px;    /* 左下 */
-webkit-border-bottom-right-radius: 20px; /* 右下 */

-moz-border-radius-bottomleft: 20px;    /* 左下 */
-moz-border-radius-bottomright: 20px; /* 右下 */


/*グラデ*/
/* For WebKit (Safari, Google Chrome etc) */
 background : -webkit-gradient(linear, left top, left bottom, from(#0080bb), to(#008cd8));
/* For Mozilla/Gecko (Firefox etc) */
 background : -moz-linear-gradient(top, #0080bb, #008cd8);
/* For Internet Explorer 5.5 - 7 */
 filter : progid:DXImageTransform.Microsoft.gradient(startColorstr=#0080bb, endColorstr=#008cd8);
/* For Internet Explorer 8 */
 -ms-filter : "progid:DXImageTransform.Microsoft.gradient(startColorstr=#0080bb, endColorstr=#008cd8)";

	}

.header h1{
	height:100px;
	line-height:200px;
	font-size:24px;
	text-align:right;
	color:#fff;
	font-weight:normal;
	text-indent:0px;
	margin-right: 20px;
	}

/*
ログイン
-------------------------------------------------------------------*/

div.login{
	box-sizing: border-box;
	width:360px;
	height:150px;
	margin:-75px 0 0 -180px;
	background : #9cf none ;
	padding: 20px;
	
	text-align:center;
	
	background : #ffffff none ;

	border-top : 1px solid #E9E9E9 ;
	border-right : 2px solid #D7D7D7 ;
	border-left : 1px solid #E9E9E9 ;
	border-bottom : 2px solid #D7D7D7 ;

	/*角丸（FF/Safari/Chrome）IE無効*/
	border-radius: 10px; /* 右上 */
	
	left: 50%;
	position: absolute;
	top: 50%;
	}
	
table.login{
	margin:10px 10px 10px;
	width:360px;
	border:0px none ;
	border-collapse:collapse;
	}

/*
左メニュー
-------------------------------------------------------------------*/

.leftmenu{
	float:left;
	width:100px;
	margin:10px 0 0 0;
	padding : 0 5px ;

background : #f9f9f9 none ;

border-top : 1px solid #E9E9E9 ;
border-left : 1px solid #E9E9E9 ;
border-bottom : 2px solid #D7D7D7 ;


/*角丸（FF/Safari/Chrome）IE無効*/
 border-top-left-radius: 10px;    /* 左上 */
 border-bottom-left-radius: 10px;    /* 左下 */

-webkit-border-top-left-radius: 10px;    /* 左上 */
-webkit-border-bottom-left-radius: 10px;    /* 左下 */

-moz-border-radius-topleft: 10px;    /* 左上 */
-moz-border-radius-bottomleft: 10px;    /* 左下 */


	}

.leftmenu ul{
 width : 96px ;
	margin:20px auto;
	padding: 10px auto;

/*角丸（FF/Safari/Chrome）IE無効*/
 border-top-left-radius: 5px;    /* 左上 */
 border-top-right-radius: 5px; /* 右上 */
 border-bottom-left-radius: 5px;    /* 左下 */
 border-bottom-right-radius: 5px; /* 右下 */

-webkit-border-top-left-radius: 5px;    /* 左上 */
-webkit-border-top-right-radius: 5px; /* 右上 */
-webkit-border-bottom-left-radius: 5px;    /* 左下 */
-webkit-border-bottom-right-radius: 5px; /* 右下 */

-moz-border-radius-topleft: 5px;    /* 左上 */
-moz-border-radius-topright: 5px; /* 右上 */
-moz-border-radius-bottomleft: 5px;    /* 左下 */
-moz-border-radius-bottomright: 5px; /* 右下 */

/*グラデ*/
/* For WebKit (Safari, Google Chrome etc) */
 background : -webkit-gradient(linear, left top, left bottom, from(#0080bb), to(#008cd8));
/* For Mozilla/Gecko (Firefox etc) */
 background : -moz-linear-gradient(top, #0080bb, #008cd8);
/* For Internet Explorer 5.5 - 7 */
 filter : progid:DXImageTransform.Microsoft.gradient(startColorstr=#0080bb, endColorstr=#008cd8);
/* For Internet Explorer 8 */
 -ms-filter : "progid:DXImageTransform.Microsoft.gradient(startColorstr=#0080bb, endColorstr=#008cd8)";

	}

.leftmenu ul img{
	display: block;
	width: 100px;
	height: 25px;
	}

.leftmenu li{
	display:block;
	padding: 10px 5px;
	width:86px;
	background: transparent none;
	font-size: 14px;
	line-height: 110%;
	list-style-type: none;
	border-top : 1px dotted #fff ;
	}

.leftmenu a{
	display:block;
	width:86px;
	background: transparent none;
	font-size: 14px;
	line-height: 110%;
	}

.leftmenu a:link,.leftmenu a:visited{
	color:#fff;
	text-decoration : none ;
	font-weight : bold ;
	}

.leftmenu a:hover{
	color:#ff9;
	text-decoration : none ;
	font-weight : bold ;
	}

/*
メイン
-------------------------------------------------------------------*/
.main{
	margin:10px 5px;
	padding:10px;
	/*width:1046px;*/
	
	/*height: auto !important;
	height: 600px;*/

	background : #ffffff none ;

	border-top : 1px solid #E9E9E9 ;
	border-right : 2px solid #D7D7D7 ;
	border-left : 1px solid #E9E9E9 ;
	border-bottom : 2px solid #D7D7D7 ;

	/*角丸（FF/Safari/Chrome）IE無効*/
	border-radius: 10px;
	overflow: hidden;
	
	position: relative;
	}

h1{
	position: absolute;
	right: 10px;
	top: 10px;
	font-size: 20pt;
	color: #555;
	}

h2{
	margin: 10px 0 5px 0;
	padding: 0px;
	background : #fff none ;
	color:#666;
	font-size: 160%;
	font-weight:normal;
	line-height:100%;
	text-align: center;
	}

h3{
	margin: 20px 0 0 0;
	padding: 0 0 0 5px;
	color:#69f;
	font-size:100%;
	line-height:100%;
	}

h4{
	margin: 1em 0 0.5em 0;
	padding: 0 0 0 5px;
	color:#ff0000;
	font-size:100%;
	line-height:100%;
	}

h5{
	margin: 1em 0 0.5em 0;
	padding: 0 0 0 5px;
	color:#ff6633;
	font-size:120%;
	line-height:100%;
	}

select{
	margin: 1em 0 0.5em 0;
	padding: 0 0 0 5px;	
}

p{
	margin: 0 0 1em 0;
	padding: 0;
	line-decoration:non;	
	}

/*
フォーム
-------------------------------------------------------------------*/

form{
	margin:0;
	padding:0;
	}

select, input, option, checkbox{
	margin:0 ;
	border:1px solid #999999;
	}
	
button, input[type="button"]{
	border: 2px solid #666;
	cursor: pointer;
	background-color:#eeeeee;
	padding : 3px 30px ;
	margin: 0 10px 0 0;
	}

button img{
	display : none ;
	}

textarea {
  overflow: auto;
}

input,textarea, select{
     line-height: 135%;
 font-size : 16px ;
 letter-spacing : 1px ;
     line-height: 135%;
 padding : 5px ;
 vertical-align:middle;
 }

input[type="text"],input[type="number"],input[type="tel"],input[type="password"],input[type="submit"],input[type="file"],textarea,select {
	padding: 1px;
	border : 2px solid #666 ;
	font-size: 16px;
}



input[type="radio"] {
	display:none;
	}

	input[type="radio"]+label {
		display: inline-block;
		padding: 5px 2px;
		cursor: pointer;
		border-left: 2px solid #EEE;
		border-top: 2px solid #EEE;
		border-right: 2px solid #666;
		border-bottom: 2px solid #666;
		}

		input[type="radio"]+label:hover {
			border-left: 2px solid #666;
			border-top: 2px solid #666;
			border-right: 2px solid #EEE;
			border-bottom: 2px solid #EEE;
			}
			
		input[type="radio"]:checked+label {
			border-left: 2px solid #666;
			border-top: 2px solid #666;
			border-right: 2px solid #EEE;
			border-bottom: 2px solid #EEE;
			}



/*

input[type="submit"] {
	margin: 5px 0 0 0;
}
*/

input:focus, textarea:focus, button:focus {
 background-color: #eef9ff;
 border : 2px solid #666 ;
}

select { 
     line-height: 135%;
 vertical-align:middle; 
}
/*
テーブル
-------------------------------------------------------------------*/

.scheduler table#table_schedule{
	margin:10px 0 10px 0;
	border: 1px solid #666;
	border-collapse:collapse;
	}
		
	.scheduler table#table_schedule tr:hover th.hover {
		background-color: #9cbb1c;
		}
		
	.scheduler table#table_schedule tr th.header_place:hover {
		overflow: visible;
		}

	.scheduler th,
	.scheduler td{
		font-weight:normal;
		white-space:nowrap;
		vertical-align:middle;
		}

.scheduler table#table_schedule tr th {
	border: 1px solid #666;
	text-align: center;
	padding: 3px 5px;
	overflow: hidden;
	cursor: default;
	background-color:#bbdbf3;
	font-weight: bold;
	}
	
	.scheduler table#table_schedule tr.date th{
		border-top: 3px double #666;
	    font-size: 14px;
		color:#333;
		font-weight : bold ;
		}
		
	.scheduler table#table_schedule tr.hour th{
		border: 1px solid #666;
	    font-size: 9px;
		color:#333;
		text-align:left;
		font-weight : bold ;
		}
		
		

	.scheduler table#table_schedule tr.summary td{
		border: 1px solid #666;
	    font-size: 9px;
		color:#333;
		text-align:right;
		background-color:#fff
		}
		
	.scheduler table#table_schedule tr td{
		/* border: 1px solid #666; */
		padding: 2px;
		box-sizing: border-box;
		}
		
		.scheduler table#table_schedule tr td {
			border-left: 1px dashed #666;
			}
		.scheduler table#table_schedule tr td.timetable_filled,
		.scheduler table#table_schedule tr td.timetable_form{
			border: 1px solid #666;
			}
		.scheduler table#table_schedule tr td.morning {
			border-left: 1px solid #666;
			}
		.scheduler table#table_schedule tr td.half {
			border-left: 1px dashed #b8b8b8;
			}
		.scheduler table#table_schedule tr td.today {
			background-color:#f3ffb2;
			}
		.scheduler table#table_schedule tr td.holiday {
			background-color:#e4e4e4;
			}
		.scheduler table#table_schedule tr td.sunday {
			background-color:#fce8ef;
			}
		.scheduler table#table_schedule tr td.saturday {
			background-color:#dfeefc;
			}
		.scheduler table#table_schedule tr td.overflowdate {
			background-color:#aaa;
			border-top: 1px solid #666;
			border-left: 1px solid #666;
			}
			
th.header3{
	border: 1px solid #666;
    font-size: 14px;
	color:#333;
	font-weight : bold ;
	}
th.header4{
	border: 1px solid #666;
    font-size: 14px;
	color:#333;
	font-weight : bold ;
	}
th.header5{
	border: 1px solid #666;
    font-size: 14px;
	color:#333;
	font-weight : bold ;
	width:250px;
	}
td.detail1{
	background : #fff none ;
    font-size: 14px;
	white-space:normal;
	}
td.detail2{
    font-size: 14px;
	white-space:normal;
	text-align:right;
	}
td.detail3{
    font-size: 14px;
	white-space:normal;
	text-align:center;
	}
td.detail4{
    font-size: 14px;
	white-space:normal;
	vertical-align:middle;
	text-align:left;
	}
td.detail5{
    font-size: 14px;
	white-space:normal;
	width:660px;
	}
.scheduler table#table_schedule tr th.timetable_filled,
.scheduler table#table_schedule tr td.timetable_filled{
    font-size: 14px;
	vertical-align:middle;
	padding: 2px;
	overflow: hidden;
	cursor: pointer;
	background-repeat: no-repeat;
	background-position: center center;
	}
	.scheduler table#table_schedule tr th.timetable_filled:hover,
	.scheduler table#table_schedule tr td.timetable_filled:hover {
		overflow: visible;
		/*text-shadow:1px 1px 0 #fff,-1px 1px 0 #fff,1px -1px 0 #fff,-1px -1px 0 #fff;*/
		/*text-shadow:0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff,0 0 3px #fff;*/
		}
		
td.timetable_form{
    font-size: 14px;
	vertical-align:middle;
	padding: 2px;
	overflow: hidden;
	cursor: pointer;
	background-color:#9fc24d;
	}
/*
フッター
-------------------------------------------------------------------*/

.footer{
 width :  1200px ;
	clear:both;
	margin : 20px auto ;
	border-top : 1px solid #999 ;
	}

.copy{
	text-align:center;
	color:#999999;
	font-size: 11px;
	padding:2px;
	margin : 5px auto ;
	}


@media screen and (max-width: 900px){
	#controller{
		padding-left: 50%;
		}
	#controller_inner_left{
		width: 50%;
		}
	}