﻿article, aside, canvas, details, figcaption, figure, header, footer, main, menu, nav, section, summary {
	display: block;
}
article {
	text-align: left;
	margin: 10px 10px 1em 10px;
	padding-top: 10px;
	padding-bottom: 10px;
}
aside {
	text-align: left;
	margin: 10px;
}
h1, h1 a:link, h1 a:visited, .left_col h2, .right_col h2, .left_col h3, .right_col h3, aside h3 {
	margin-top: 0px;
	padding: 0px;
	line-height: 1.1em;
	clear: both;
	color: black;
}
article h1 {
	font-size: 2em;
}
h2, h3, h4, h5, h6, h2 a:link, h3 a:link, h2 a:visited, h3 a:visited {
	padding: 0px;
	line-height: 1.1em;
	clear: both;
	color: black;
}

body {
	margin: 0;
	padding: 0;
	text-align: center;
	background-color: honeydew;
	color: black;
	font-family: Meiryo, Verdana, Geneva, Tahoma, sans-serif;
	font-size: 1em;
}

a:link {
	text-decoration: none;
	color: blue;
}
a:visited {
	text-decoration: none;
}
a:hover {
	color: blue;
}
a img {
	border-width: 0;
}

header, footer {
	background-color: aquamarine;
	clear: both;
}
*/header h1 {
	margin: 0;
	padding: 0;
	line-height: 0;
	font-size: 1em;
}
header p, footer p {
	margin: 10px 5px 0px 5px;
}
header nav a:hover {
	text-decoration: underline;
}

aside ol {
	margin: 0px 0px 10px 2em;
	padding: 0px;
}
aside ul, ul.list {
	list-style-type: none;
	margin: 0px 0px 1em 0px;
	padding: 0px;
	border-top: dotted 1px;
}
aside ul li, ul.list li {
	padding: 0.5em 0px;
	margin: 0px;
	border-bottom: dotted 1px;
}
aside ol li {
	margin: 0px;
	padding: 5px 0px 5px 0px;
}
aside li a, .list a {
	display: block;
}

.topic_path {
	background-color: whitesmoke;
	clear:both
}
.topic_path, .container {
	padding-left: 10px;
}

.subtitle {
	margin-top: -15px;
}

.lead {
	border: 1px solid #999;
	background-color: lightgray;
	margin: 10px 0;
	padding: 5px;
	clear: both;
}
.lead p {
	margin: 0;
}

.header {
	background-color: greenyellow;
}

.point {
	margin: 1em 0px 1em 0px;
	border: 1px dashed #999;
	padding: 10px;
	clear:both;
}

.col_wrap {
	display: block;
	width: 100%;
	clear: both;
}
.left_col {
	float: left;
	width: 49%;
	margin-bottom: 10px;
	clear: both;
}
.right_col {
	float: right;
	width: 49%;
	margin-bottom: 10px;
}
.left_col ul, .right_col ul {
	padding-top: 0px;
	margin-top: 0px;
}

.container {
	text-align: left;
	position: relative;
	margin: auto;
	max-width: 1085px;
}

#nav {
	background-color: limegreen;
}
#nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	overflow: hidden;
}
#nav li {
	float: left;
	margin: 0;
	padding: 0;
}
#nav li a {
	display: block;
	padding: 0 1em;
	color: saddlebrown;
	font-weight: bold;
}
#page_content {
	background-color: honeydew;
}

#sidebar {
	background-color: wheat;
}

table {
	color: black;
	border-collapse: collapse;
	table-layout: fixed;
	word-break: break-all;
}
th{
	text-align: center;
	border: solid thin;
	border-style: solid;
}
td{
	vertical-align: top;
	border: solid thin;
	border-style: solid;
	padding: 5px 5px 5px 5px;
	table-layout: fixed;
	word-break: break-all;
}

table.autoline {
	display: block;
	border: none;
}
table.autoline tr {
	display: inline;
}
table.autoline td {
	display: inline-block;
	margin-bottom: 8px;
}

td.noneborder {
	border: none;
	padding: 2px 2px 2px 2px;
}

.sitemap ul {
	list-style: none;
}
.sitemap ul li ul {
	margin-top: .5em;
	margin-bottom: .75em;
	margin-left: 10px;
	list-style: none;
}
.sitemap ul li ul li {
	margin-bottom: .25em;
	position: relative;
}
.sitemap ul li ul li::before {
	content: "";
	position: absolute;
	top: -0.5em;
	left: -16px;
	width: 10px;
	height: calc(100% + .75em);
	border-left: 1px solid #000;
}
.sitemap ul li ul li:last-child::before {
	height: calc(1em + .25em);
}
.sitemap ul li ul li::after {
	content: "";
	position: absolute;
	top: .75em;
	left: -16px;
	width: 10px;
	border-bottom: 1px solid #000;
}

.sidebyside p{
	display: inline-block;
	vertical-align: top;
	padding-left: 0.5em;
	word-break: break-all;
}

.fssml {
	font-size: 0.8em;
}
.fsmid {
	font-size: 1.2em;
}
.fsbig {
	font-size: 1.5em;
}
.fsbold {
	font-weight: bold;
}
.fsred {
	color: red;
}
.fsgreen {
	color: forestgreen;
}
.fsbrown {
	color: saddlebrown;
}

.width4em {
	width: 4em;
}
.width5em {
	width: 5em;
}
.width6em {
	width: 6em;
}
.width7em {
	width: 7em;
}
.width8em {
	width: 8em;
}
.width9em {
	width: 9em;
}
.width13em {
	width: 13em;
}
.width15em {
	width: 15em;
}
.width100pc {
	width: 100%;
}
.rowmargin1em {
	margin-bottom: 1em;
}
.rowmargin2em {
	margin-bottom: 2em;
}
.rowmargin3em {
	margin-bottom: 3em;
}

.leftmargin1em {
	margin-left: 1em;
}
.leftmargin2em {
	margin-left: 2em;
}
.rightmargin1em {
	margin-right: 1em;
}

.alignleft {
	text-align: left; !important
}
.alignright {
	text-align: right;
}
.aligncenter {
	text-align: center;
}

.indent {
	text-indent: 1em;
}
.indentrow2 {
	padding-left: 1em;
	text-indent: -1em;
}

.textblock {
	display: inline-block;
}

.fs1 {
	margin: 10px 5px 0px 5px;
	display: inline-block;
	vertical-align: top;
	font-size: 3em;
	font-weight: bold;
	color: saddlebrown;
}
.fs2 {
	margin: 5px 5px 5px 5px;
	display: inline-block;
	vertical-align: top;
	font-weight: bold;
	color: saddlebrown;
}

.sidebyside {
	margin: 10px 0px 0px 15px;
	display: inline-block;
	vertical-align: top;
}

.side {
	overflow: hidden;
	_zoom: 1;	/*IE6バグ対策*/
}
.side .img {
	padding-right: 10px;
	float: left;
}
.side .txt {
	overflow: hidden;
	_zoom: 1;	/*IE6バグ対策*/
}

.linkbox1 {
	display: inline-block;
	margin: 5px 5px 5px 5px;
	padding: 0px;
	width: 300px;
	height: 75px;
	vertical-align: middle;
	text-align: center;
	background-color: lavenderblush;
}
.linkbox2 {
	display: inline-block;
	margin: 5px 5px 5px 5px;
	padding: 0px;
	width: 300px;
	height: 100px;
	vertical-align: middle;
	text-align: center;
	background-color: lavenderblush;
}
.linkbox3 {
	display: inline-block;
	margin: 5px 5px 5px 5px;
	padding: 0px;
	width: 300px;
	height: 75px;
	text-align: center;
	vertical-align: middle;
	background-color: paleturquoise;
}

.btnLeft {
	text-align: left;
	float: left;
}
.btnRight {
	text-align: right;
}

/* ボタン */
.button {
	display: block;
	max-width: 180px;
	padding: 10px;
	/* テキスト */
	font-size: 13px;
	text-align: center;
	text-decoration: none;

/*	text-shadow: 0 -1px 3px rgba(0, 0, 0, .3);
*/
	/* 角丸 */
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	/* ドロップシャドウ */
	box-shadow: 0 3px 5px 0 rgba(0, 0, 0, .3);
	-webkit-box-shadow: 0 3px 5px 0 rgba(0, 0, 0, .3);
	-moz-box-shadow: 0 3px 5px 0 rgba(0, 0, 0, .3);
}
/* ボタンの色を指定 */
.blue {
/*
	color: #CCC;
*/
	background-color: aquamarine;
	border: solid 1px gray;
	/* グラデーション */
/*
	background: -webkit-gradient(linear, left top, left bottom, from(#00adee), to(#0078a5));
	background: -moz-linear-gradient(top, #00adee, #0078a5);
*/
}

.rsvbtn:hover {
	background-color: greenyellow;
}

@media only screen {
	img {
		max-width: 100%;
		height: auto;
	}
	.wrapper {
		font-size: 14px
	}
}

@media(max-width: 480px) {
	#snav{
		display: none
	}
}

@media(max-width: 639px) {
	body{
		-webkit-text-size-adjust: 100%;
	}
	nav#gnav {
		display: none
	}
	.left_col, .right_col,footer .left_col, footer .right_col {
		float: left;
		width: 100%;
		margin: 0!important;
	}
	.left_col ul.list {
		margin-bottom: 0!important;
	}
	.right_col ul.list {
		margin-top: -1px;
		margin-bottom: 1.5em
	}
	.right_col h3, .right_col h4 {
		margin-top: 1.1em!important;
	}
	#page_content, #sidebar {
		margin: auto 0px;
		border-radius: 0px;
	}
	.leftimg, .rightimg {
		float: none;
		padding: 0;
		text-align: center
	}
	img.rightimg {
		display: block;
		margin: auto
	}
}

@media(min-width: 768px) {
	.search{
		position: absolute;
		top: 1.5em;
		right: 0px;
		width: 300px;
	}
}

@media(min-width: 1008px) {
	.container {
		width: 975px
	}
	.wrapper {
		display: inline-block;
		*display: inline;
		*zoom: 1;
		width: 985px;
		margin-bottom: 10px;
		margin-top: 10px;
	}
	#page_content {
		margin: auto 0px;
		width: 750px;
		float: left;
	}
	#sidebar {
		float: right;
		width: 220px;
		margin: auto 0px 10px 0px;
	}
	#page_content, #sidebar {
		border-radius: 7px;
	}
	article, aside {
		padding-top: -10px;
		margin-top: 0;
		margin-bottom:0;
	}
}

@media only screen and (min-width: 1110px) {
	.container {
		width:1075px;
	}
	.wrapper {
		width: 1085px;
	}
	#page_content {
		width: 750px;
	}
	#sidebar {
		width: 320px;
	}
}

/* ** */
.tb-cell {
	display: table;
	width: 100%;
	margin: 20px auto 40px auto;
	text-align: left;
}
.tb-cell .row {
	display: table-row;
}
.tb-cell .row .cell {
	display: table-cell;
	border: 1px solid honeydew;
	padding: 10px;
	vertical-align: middle;
	color: black;
}
.tb-cell .row .cell:first-child {
	width: 6em;
	text-align: center;
}
.tb-cell .row .cell:last-child {
	width: 44em;
}
.mail-form .row .cell {
	padding: 5px;
}
.mail-form .row .cell:nth-child(1) {
	background: aquamarine;
}
.mail-form .row .cell:nth-child(2) {
	background: wheat;
}
input[type=text], input[type=email], input[type=password] {
	height: 30px;
	font-size: 16px;
	padding: 0px 3px 0px 3px;
}
input[type=date] {
	width: 3em;
	font-size: 16px;
	padding: 0px 3px 0px 3px;
}
textarea {
	width: 99%;
	height: 100px;
	font-size: 16px;
}
button {
	color: black;
	border: none;
	padding: 10px;
	font-size: 16px;
	cursor: pointer;
}
button[type=button] {
	margin-left: 10px;
}
button[type=button], button[type=submit] {
	background: limegreen;
}
button[type=reset] {
	background: none;
}
button[type=button]:hover, button[type=submit]:hover {
	background: greenyellow;
}
button[type=reset]:hover {
	text-decoration: underline;
}

.cell_2 {
	display: table-cell;
	border: 1px solid lavenderblush;
	padding: 10px;
	vertical-align: middle;
	color: black;
	background: paleturquoise;
}
.input_num {
	width: 4em;
	text-align: center;
}
.input_name {
	width: 12em;
}
.input_tel {
	width: 8em;
	text-align: center;
}
.input_full {
	width: 98%;
}

/* ↓予約カレンダー用 */
@charset "utf-8";

/*土曜の文字色*/
.youbi_6 {
	color: royalblue !important;
}
/*祝日と日曜の文字色*/
.youbi_0, .shukujitu {
	color: red !important;
}
/*本日の背景色　※ただし設定ファイルでの設定が優先されます*/
.today {
	background: greenyellow;
}
/*休業日設定した日の背景色　※ただし設定ファイルでの設定が優先されます*/
.holiday {
	background: pink;
}
/*定休日設定した日の背景色　※ただし設定ファイルでの設定が優先されます*/
.closed {
	background: pink;
}
.hidden {
	display: none;
}
/*休業日テキスト部の左側の四角*/
.holidayCube {
	display: inline-block;
	width: 13px;
	height: 13px;
	margin: 3px 3px 0 3px;
	position: relative;
	top: 2px;
}
/*定休日テキスト部の左側の四角*/
.closedCube {
	display: inline-block;
	width: 13px;
	height: 13px;
	margin: 3px 3px 0 3px;
	position: relative;
	top: 2px;
}
/*---------------------------------
			index.php
---------------------------------*/

/* Calender style */
#calenderTable {
	width: 100%;
	font-family: Meiryo, Verdana, Geneva, Tahoma, sans-serif;
	border-collapse: collapse;
}
#calenderTable th {
	padding: 5px;
	font-size: 12px;
	border: 1px solid silver;
	color: black;
	background: aquamarine;
}
#calenderTable td {
	padding: 5px;
	text-align: right;
	font-size: 12px;
	border: 1px solid silver;
	color: dimgray;
	width: 14%;
	vertical-align: top;
}
#calenderTable .calenderHeader a {
	color: #dimgray;
	text-decoration: none;
}
#calenderTable td .scheduleComment {
	text-align: left;
	color: black;
	font-size: 12px;
	padding-left: 0.5em;
}
#calenderTable td .schedulePulldownList {
	text-align: left;
	color: black;
	font-size: 10px;
	padding: 0px 0 3px;
/*
	border-bottom: 1px dotted silver;
*/
}
#calenderTable .borderless {
	border: 0 !important
}
.countNum {
	font-size: 110%;
}
p.holidayText {
	font-size: 12px !important;
	color: dimgray;
	margin: 0;
	padding: 0 0 5px;
}

/* if ListStyle */
ul#calenderList {
	list-style: none;
	margin: 0;
	padding: 0;
	font-family: Meiryo, Verdana, Geneva, Tahoma, sans-serif;
}
#calenderList li {
	border-bottom: 1px solid gray;
	padding: 5px;
}
#calenderList li.first-child {
	border-top: 1px solid gray;
}
#calenderList .scheduleComment {
	text-align: left;
	color: royalblue;
	font-size: 12px;
}
#calenderList .schedulePulldownList {
	text-align: left;
	color: dimgray;
	font-size: 10px;
	padding: 0px 0 3px;
//	border-bottom: 1px dotted darkgray;
}
table.navNextPrev{
	width: 100%;
}
table.navNextPrev .dspPrev {
	text-align: left;
	padding: 10px;
}
table.navNextPrev .dspNext {
	text-align: right;
	padding: 10px;
}
h2#headerYm {
	background: dimgray;
	color: white;
	text-align: center;
	padding: 5px ;
	font-size: 110%;
	font-family: Meiryo, Verdana, Geneva, Tahoma, sans-serif;
}
/* /if ListStyle */

/* Reserv Btn styl*/
.reservForm {
	display: inline;
}
.reservForm input {
	font-size: 12px;
	cursor: pointer;
	font-family: Meiryo, Verdana, Geneva, Tahoma, sans-serif;
	padding: 1px 2px;
}
/* /Reserv Btn styl*/

/* ReservForm Style */
#formWrap {
	width: 650px;
	margin: 10px auto;
	color: dimgray;
	line-height: 120%;
	font-size: 90%;
	font-family: Meiryo, Verdana, Geneva, Tahoma, sans-serif;
}
#formWrap h2 {
	font-weight: normal;
	font-size: 14px;
	color: dimgray;
	margin: 0 0 10px;
	background: whitesmoke;
	padding: 5px 8px 3px;
	border-radius: 3px;
	border: 1px solid silver;
}
#formWrap p {
	margin: 0 0 5px;
	padding: 0;
	font-size: 13px;
}

table.formTable {
	width: 100%;
	margin: 15px auto;
	border-collapse: collapse;
}
table.formTable td, table.formTable th {
	border: 1px solid silver;
	padding: 10px;
	font-size: 90%;
}
table.formTable th {
	width: 30%;
	font-weight: normal;
	background: whitesmoke;
	text-align: left;
}
/*---------------------------------
		/index.php style
---------------------------------*/
/* ↑予約カレンダー用 */

body#auth #login_form {
	width: 500px;
	margin: 25px auto;
	border: 1px solid silver;
	border-radius: 10px;
	box-shadow: 0 0px 7px darkgray;
	font-weight: normal;
	padding: 16px 16px 20px;
	color: dimgray;
	line-height: 1.3;
	font-size: 90%;
}
body#auth form .input {
	font-size: 20px;
	margin: 2px 6px 10px 0;
	padding: 3px;
	width: 97%;
}
body#auth input[type=text], body#auth input[type=password], body#auth input[type=file], body#auth input[type=button], body#auth input[type=submit], body#auth input[type=reset] {
	background-color: white;
	border: 1px solid gray;
}
body#auth .button-primary {
	border: 1px solid black;
	border-radius: 11px;
	cursor: pointer;
	font-size: 18px;
	padding: 3px 10px;
	width: 450px;
	height: 38px;
}
