/**
 * 
 */
html,body{
	height:100%;
	font-family:'Lucida Grande','Hiragino Kaku Gothic ProN',Meiryo, sans-serif;
	font-size:10pt;
	line-height:140%;
}
html{
	background:#333;
}
body{
	background:url("../images/back_bg.png") repeat-x #333;
}

#loading{
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:999999;
	background: rgba(0,0,0,0.5);
	filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#55000000', endColorstr='#55000000');
	text-align:center;
	display:none;
}
#loading .message{
	display:inline-block;
	position: fixed;
	top:50%;
	left:50%;
	margin-top:-60px;
	background:url("../images/ajax-loader.gif") no-repeat top center;
	padding-top:60px;
	color:#FFF;
}

div#base_frame{
	width:900px;
	margin: 0px auto;
	height:100%;
	display:table;
	min-height:500px;
}
div#header_line{
	height:40px;
	color:#FFF;
	display:table-row;
}
div#navi_line{
	height:30px;
	display:table-row;
}
div#contents_line{
	display:table-row;
}
div#footer_line{
	display:table-row;
	text-align:right;
	color:#888;
	font-size:6pt;
	line-height:15px;
	padding-top:2px;
	height:15px;
}
div#footer_line #copy{
	background:#FFF;
	padding:0px 5px;
}
#header_title{
	float:left;
	font-size:20pt;
	padding-bottom:20px;
	vertical-align:text-bottom;
	line-height:100%;
	background:#FFF;
	width:100%;
}
#header_title img{
	vertical-align:text-bottom;
}

div#login_info{
	float:right;
	font-size:10pt;
	height:20px;
	line-height:20px;
	margin-top:20px;
}
div#login_info #login_name,
div#login_info #logout_btn{
	float:left;
}
a#logout_btn,
a#logout_btn:visited{
	text-decoration:none;
	display:inline-block;
	color:#FFF;
	margin-left:10px;
	font-weight:bold;
}
ul.proc_arrow{
	display:table;
	width:100%;
	padding:0;
	margin:0;
	table-layout:fixed;
	border-top:solid 1px #CCC;
	border-bottom:solid 1px #CCC;
}
ul.proc_arrow li{
	background:#EEE;
	display:table-cell;
	float:none;
	text-align:center;
	padding:0;
	position: relative;
	line-height:30px;
	height:30px;
	font-size:13pt;
}
ul.proc_arrow li:after,
ul.proc_arrow li:before {
	border: solid transparent;
/*
	border: solid #0F0;
*/
	content: ' ';
	height: 0;
	left: 100%;
	position: absolute;
	width: 0;
	z-index:1000;
}
ul.proc_arrow li:after {
	border-width: 14px;
	border-left-color: #EEE;
	top: 1px;
}
ul.proc_arrow li:before {
	border-width: 15px;
	border-left-color: #CCC;
	top: 0;
}
ul.proc_arrow li:first-child{
/*
	border-radius:15px 0 0 0;
*/
}
ul.proc_arrow li:last-child{
/*
	border-radius:0 15px 0 0;
*/
	border:0px;
}
ul.proc_arrow li:last-child:after,
ul.proc_arrow li:last-child:before{
	content: '';
	border:0px;
}
ul.proc_arrow li.now{
	background:#ff9900;
}
ul.proc_arrow li.now:after{
	border-left-color: #ff9900;
}


div#navibar{
/*
	background:url("../images/navibar.png") repeat-x #EEE;
*/
}
/*
div#navibar table{
	width:100%;
	table-layout: fixed;
}
div#navibar table td{
	text-align:center;
	border-right:solid 1px #CCC;
}
div#navibar table td:last-child{
	border-right:none;
}
div#navibar table td > a,
div#navibar table td > a:visited{
	text-decoration:none;
	display:block;
	height:30px;
	line-height:30px;
	vertical-align:middle;
	color:#333;
	padding:0px 7px;
	border-radius:5px;
	margin:0px 5px;
	-webkit-transition: background-color .2s ease-out;  
	transition: background-color .2s ease-out;
}
div#navibar table td > a:hover,
div#navibar table td > a:focus{
	background:#FFBC02;
}
div#navibar table td > a.select{
	background:#FFBC02;
}
*/

/*
div#navibar ul{
	list-style:none;
	padding:5px 0px;
	display:table-row;
}
div#navibar ul li{
	padding:0px 5px;
	border-right:solid 1px #AAA;
	display:table-cell;
	vertical-align:middle;
}
div#navibar ul li.last{
	border-right:none;
}
div#navibar ul li a,
div#navibar ul li a:visited{
	text-decoration:none;
	display:inline-block;
	height:30px;
	line-height:30px;
	vertical-align:middle;
	color:#333;
	padding:0px 7px;
	border-radius:5px;
}
div#navibar ul li a:hover{
	background:#F00;
	background:url("../images/navi_bg.png") repeat-x #FF9326;
}
*/

#contents_line > table{
	background:#FFF;
	height:100%;
	width:100%;
	border-radius:5px;
}
#contents_line > table #sidebar{
	width:200px;
	padding:0;
}
	

#contents_line > table > tbody > tr > td{
	background:#FF0;
}
div#contents_frame{
	height:100%;
	width:100%;
	background:#FFF;
/*
	border-radius:0 0 15px 15px;
*/
	display:table;
}

#side_frame,
#main_frame{
	display:table-cell;
	height:100%;
/*
	border-radius:0 0 15px 15px;
*/
	padding-bottom:5px;
}
#side_frame{
	width:200px;
	padding:0px;
	border-right:solid 1px #CCC;
}
#side_frame dl{
	display:block;
	clear:both;
	margin:0;
}
#side_frame dl dt,
#side_frame dl dd{
}
#side_frame dl dt{
	padding:5px;
	background:#333;
	color:#FFF;
}
#side_frame dl dt:first-child{
/*
	border-radius:5px 0px 0px 0px;
*/
}
#side_frame dl dd{
	border-bottom:dotted 1px #CCC;
}
#side_frame dl dd > a,
#side_frame dl dd > a:visited{
	padding:5px 20px;
	text-decoration:none;
	display:block;
	color:#333;
	-webkit-transition: background-color .2s ease-out;  
	transition: background-color .2s ease-out;
}
#side_frame dl dd > a:hover,
#side_frame dl dd > a:focus{
	background:#FFBC02;
}
#side_frame dl dd > a.select{
	background:#FFBC02;
}


/*
#side_frame table{
	width:100%;
	border-radius:5px;
}
#side_frame table th,
#side_frame table td{
	border:solid 1px #CCC;
}
#side_frame table th{
	background:#888;
	text-align:left;
	color:#FFF;
	font-weight:normal;
	padding:5px;
}
#side_frame table td a,
#side_frame table td a:visited{
	display:block;
	padding:5px;
}
#side_frame table td a:hover,
#side_frame table td a:focus{
	background:#CCC;
}
*/
#main_frame{
/*
	border-radius:0px 5px 5px 0px;
*/
	padding:10px;
}
/*
#main_pad{
	display:inline-block;
	margin:10px;
	
}
*/



/**
 * アンカーボタン
 */
a.btn_blue,
a.btn_blue:visited{
	display:inline-block;
	padding:3px 10px;
	background:#BEF;
	text-decoration:none;
	color:#555;
	border-radius:3px;
	border:solid 1px #CCC;
}
a.btn_blue:hover,
a.btn_blue:focus{
	border:solid 1px #39F;
	color:#39F;
	background:#9CF;
}
a.btn_glay,
a.btn_glay:visited{
	display:inline-block;
	padding:3px 10px;
	background:#EEE;
	text-decoration:none;
	color:#888;
	border-radius:3px;
	border:solid 1px #CCC;
}
a.btn_glay:hover,
a.btn_glay:focus{
	background:#DDD;
}
/**
 * コンテンツエリア共通
 */
#main_frame{
	font-size:12pt;
	font-weight:normal;
	color:#333;
}
.full_w{
	width:100%;
}
#main_frame ul.hbox{
	width:100%;
	display:table;
	table-layout: fixed;
	border-collapse:collapse;
	border-spacing:0px;
}
#main_frame ul.hbox > li{
	display:table-cell;
}
#main_frame ul.hbox > li.space{
	width:10px;
}
#main_frame ul.vbox{
	width:100%;
	display:block;
}
#main_frame ul.vbox > li{
	display:block;
}
#main_frame ul.vbox > li.space{
	height:10px;
}

#main_frame h1,
#main_frame h2{
	font-size:14pt;
	font-weight:bold;
	margin-bottom:10px;
}
table th,
table td{
	border:solid 1px #CCC;
	font-weight:normal;
	padding:3px;
}
table th{
	background:#EEE;
}

#main_frame ul.btns{
	text-align:center;
}
#main_frame ul.btns li{
	display:inline-block;
	margin:0px 20px;
}

/**
 *
 */
ul.error_message{
	border:solid 1px #F00;
	border-radius:5px;
	display:block;
	float:none;
	background:#FEE;
	list-style:disc outside;
	
	margin:0;
	margin-bottom:20px;
	padding:10px 10px 5px 30px;
}
ul.error_message li{
	float:none;
	text-align:left;
	color:#F00;
	margin-bottom:5px;
}
/**
 * 完了メッセージ
 */
ul.success_message{
	border:solid 1px #00F;
	border-radius:5px;
	display:block;
	float:none;
	background:#EEF;
	list-style:none;
	
	margin:0;
	margin-bottom:20px;
	padding:10px 10px 5px 10px;
}
ul.success_message li{
	float:none;
	text-align:left;
	color:#00F;
	margin-bottom:5px;
}

div.page_detail{
	padding-bottom:20px;
	width:100%;
	clear:both;
}
div.page_detail .text{
	line-height:30px;
	display:inline-block;
}

/**
 * 日付入力
 */
#flipsnap_calendar{
	width: 880px;
	overflow: hidden;
	margin: 0 auto;
}
#flipsnap_calendar_frame{
	width: 880px;
	display: block;
}
#flipsnap_calendar_frame .flipsnap_calendar_item{
	float:left;
	width:880px;
	white-space: nowrap;
	clear:none;
}

input{
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;	
}
input.reserve_no,
input.reserve_email,
input.reserve_authcode,
input.email,
input.tel,
input.datepicker,
input.date{
	ime-mode:disabled;
}

div.page_footer_information{
	font-size:10pt;
}
.txt_center{
	text-align:center;
}
.accept_domain{
	
}
.accept_domain dt{
	font-weight:bold;
}
.accept_domain dd{
	font-weight:bold;
}


/**
 *
 */
div.modal_bg{
	position:fixed;
	width:100%;
	height:100%;
	background:rgba(0,0,0,0.5);
	z-index:99999;
	display:flex; 
	align-items: center;
}
div.modal_bg > div.modal_frame{
	width:800px;
	background:#FFF;
	margin:0px auto;
	padding:20px;
	border-radius:10px;
	font-size:110%;
	line-height:120%;
	position:relative;
}
div.modal_bg > div.modal_frame b{
	font-size:120%;
	padding-right:30px;
}
div.modal_bg > div.modal_frame a.modal_close{
	position: relative;
	width: 30px;
	height: 30px;
	border: 3px solid #39a9d6;
	border-radius: 100%;
	display:inline-block;
	font-size:1px;
	position:absolute;
	right:10px;
	top:10px;
}
/* 左 */
div.modal_bg > div.modal_frame a.modal_close::before {
	position: absolute;
	top: 1px;
	left: 10px;
	width: 4px;
	height: 22px;
	content: "";
	background-color: #39a9d6;
	transform: rotate(45deg);
}
/* 右 */
div.modal_bg > div.modal_frame a.modal_close::after {
	position: absolute;
	top: 1px;
	left: 10px;
	width: 4px;
	height: 22px;
	content: "";
	background-color: #39a9d6;
	transform: rotate(135deg);
}
div.modal_bg > div.modal_frame a.modal_close:hover{
	border-color:#F90;
}
div.modal_bg > div.modal_frame a.modal_close:hover::before,
div.modal_bg > div.modal_frame a.modal_close:hover::after {
	background-color: #F90;
}