 @charset "utf-8";

html, body {
	font-size: 16px;
	font-family: Roboto, Arial, sans-serif;
}

html {
	width: 100%;
	height: 100%;
	padding: 0;
	background-color: #f0f0f0;
}

body {
	-webkit-text-size-adjust: 100%;
	-webkit-touch-callout: none; /* iOS Safari */
	width: 600px;
	min-height: 100%;
	margin: 0 auto !important;
	padding: 0;
	background-color: #fff;
}

body {
/*	padding-top: 40px;*/
	padding-top: 60px;
	padding-bottom: 50px;
}

* {
	box-sizing: border-box;
}

h1 {
	width: 100%;
	height: 40px;
	padding: 5px;
	margin: 0;
	text-align: center;
	font-size: 150%;
	color: #FFF;
	/*background-color: #063a79;*/
	background-color: #7A272D;
}

h2 {
	font-size: 120%;
	font-weight: normal;
	text-align: center;
}
/*
h2 {
	width: 100%;
	height: 40px;
	padding: 5px 10px;
	margin: 0;
	text-align: left;
	font-size: 120%;
	font-weight: normal;
}

h2::before {
	content: "|";
	color: #f00;
	font-weight: bold;
	padding-right: 10px;
}
*/
h3 {
	margin: 0;
	padding: 0;
	font-size: 100%;
	font-weight: normal;
	text-align: center;
}

h4 {
	margin: 0;
	padding: 0;
}

section {
	padding: 0 20px 20px;
}

section h2 {
	color: #333;
	font-size: 100%;
	font-weight: normal;
	padding: 0 20px;
	margin: 0 -20px 10px;
	width: calc(100% + 40px);
	height: 100%;
	border-top: solid 2px #7A272D;
	border-bottom: solid 2px #7A272D;
	background-color: #fee;
}

p {
	margin: 0 !important;
	padding: 0 !important;
}

table {
	width: 100%;
}

table th,
table td {
	font-size: 100%;
	font-weight: normal;
	text-align: left;
}

div.title {
	width: 100%;
	font-size: 100%;
	text-align: center;
	padding: 20px;
}

div.caption {
	position: relative;
	width: 100%;
	font-size: 120%;
	text-align: center;
	padding: 5px;
}

div.caption button {
	position: absolute;
	left: 0;
	top: 5px;
}

div.banner {
	width: 100%;
	height: 60px;
	color: #88f;
	font-size: 300%;
	text-align: center;
	background-color: #eef;
	-webkit-transition: all 2s;
	-moz-transition: all 2s;
	-ms-transition: all 2s;
	-o-transition: all 2s;
	transition: all 2s;
}

div.banner.effect {
	color: #f88;
}

hr {
	border: solid 1px #ccc;
}

button.back {
	width: auto;
	height: auto;
	padding: 0;
	margin: 0;
	font-size: 120%;
	color: #ffc000;
	font-weight: bold;
	border: none;
	background: none;
}

ul {
	scrollbar-width: none;
}

ul::-webkit-scrollbar {
    display: none;
}

/************/
/* ヘッダー */
/************/

header {
	position: fixed;
	/*left: calc(100% - 1240px);*/
	top: 0;
	width: 600px;
	height: 60px;
	padding-top: 0;
	text-align: center;
	color: #fff;
	background-color: #7A272D;
	/*background-color: #fff;*/
	border: solid 1px #ccc;
/*	overflow: hidden;*/
	z-index: 10;
}

header h1 {
	display: inline-block;
	position: relative;
	width: auto;
	padding: 0;
	background: none;
}

header h2 {
	/*
	display: block;
	position: relative;
	width: auto;
	*/
	height: 24px;
	padding: 0;
	margin: 0;
	color: inherit;
	font-size: 120%;
	text-align: center;
	background: none;
	/*background-color: #fee;*/
}

header h3 {
	/*
	display: block;
	position: relative;
	width: auto;
	*/
	padding: 0;
	margin: 0;
	font-size: 100%;
	text-align: center;
	background: none;
	/*background-color: #efe;*/
}

header dl {
	display: inline-block;
	position: relative;
	top: 5px;
	font-size: 80%;
	color: #fff;
	text-align: left;
	padding: 0;
	margin: 0;
	line-height: 120%;
}

header dl dt {
	display: inline-block;
/*	padding: 0;*/
}

header dl dd {
	display: block;
	float: right;
	margin: 0;
}

header img {
/*	max-width: 32px;
	max-height: 32px;*/
	width: 32px;
	height: 32px;
/*	object-fit: contain;*/
	object-fit: cover;
}

footer {
	position: fixed;
	bottom: 0;
	width: 600px;
	height: 56px;
	padding: 0;
	z-index: 999;
	/*background-color: #fee;*/
}

footer menu {
	display: flex;
	width: 100%;
	margin: 0;
	padding: 0;
	background-color: #fefefe;
}

footer menu li {
	list-style: none;
	width: 25%;
	padding-top: 4px;
	text-align: center;
	border: solid 1px #ccc;
	cursor: pointer;
}

footer menu li.selected {
	list-style: none;
	background-color: lightblue;
}

/******************/
/* アカウント登録 */
/******************/

form.profile {
	display: inline-block;
	width: 100%;
	text-align: center;
}

dl.inline,
dl.inline-forced {
/*	margin: 0 0 100px 0;*/
	margin: 0;
}

dl.inline dt,
dl.inline dd,
dl.inline-forced dt,
dl.inline-forced dd {
	margin-top: 20px !important;
	margin-bottom: 20px !important;
}

dl.inline dt,
dl.inline-forced dt {
	display: inline-block;
}

dl.inline dd,
dl.inline-forced dd {
	display: block;
	float: right;
	width: 240px;
	margin-left: 0;
}

dl.low-height dt,
dl.low-height dd {
	margin: 0 !important;
}

form.profile dl {
	text-align: left;
	padding: 20px;
}

form.profile dl dt {
/*	padding: 0;*/
	margin: 5px 0;
}

form.profile dl dd {
	border-bottom: solid 1px #ccc;
}

form.profile dl dd input,
form.profile dl dd input:focus {
	width: 100%;
	font-size: 100%;
	border: none;
	outline: 0;
}

form.profile dl dd.icon {
	position: relative;
	width: 200px;
	height: 100px;
	text-align: center;
	border: none;
}

form.profile dl dd.icon div.control {
	position: absolute;
	left: -30px;
	top: 44px;
	width: auto;
	height: auto;
	border: none;
	text-align: left;
}

form.profile dl dd.icon div.control input[type="image"] {
	width: auto;
	height: auto;
}

form.profile dl dd.icon div.control input[type="image"]:disabled {
	opacity: 0.2;
}

form.profile dl dd.icon img {
	position: absolute;
	left: 0;
	top: 0;
	width: 100px;
	height: 100px;
/*	object-fit: contain;*/
	object-fit: cover;
	background-color: #eee;
}

form.profile dl dd.icon div {
	position: absolute;
	left: 100px;
	top: 0;
	width: 100px;
	height: 100%;
	font-size: 100%;
	line-height: 120%;
	border: solid 1px #ccc;
}

form.profile dl dd.icon input[type="file"] {
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
}

form.profile button {
	width: 100px;
}

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

div.login {
	width: 100%;
	padding: 10px;
}

div.login p {
	white-space: normal;
}

div.login dl {
	margin: 0 0 10px 0;
	background-color: #eef;
}

div.login dl dt {
/*	float: left;
	clear: left;
	width: 100px;*/
	padding: 0 10px;
	font-size: 70%;
}

div.login dl dt.label {
	visibility: hidden;
	position: relative;
	top: +10px;
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
}

div.login dl dt.label.show {
	visibility: visible;
	top: 0;
}

div.login dl dt::before {
	content: "|";
	/*color: #f00;*/
	color: #7A272D;
	font-weight: bold;
	padding-right: 10px;
}

div.login dl dd {
/*	float: left;*/
	margin-left: 0;
}

div.login input[type="text"],
div.login input[type="email"],
div.login input[type="password"] {
	width: 100%;
	padding: 4px 10px;
	font-size: 120%;
	box-sizing: border-box;
	border-radius: 0;
	background: none;
	border: none;
	border-bottom: solid 1px #aaf;
}

div.login input[type="text"].blur,
div.login input[type="email"].blur,
div.login input[type="password"].blur {
	/*border-left: solid 2px #f00;*/
	border-left: solid 2px #7A272D;
}

div.login input[type="text"]:focus,
div.login input[type="email"]:focus,
div.login input[type="password"]:focus {
	outline: none;
	border-bottom: solid 1px #00f;
}
/*
div.login button.sns {
	width: 100%;
	padding: 5px;
	margin: 10px 0;
	color: #fff;
	font-size: 120%;
	border-radius: 5px;
	background: none;
	border: none;
	background-position-x: 10px;
	background-position-y: middle;
	background-repeat: no-repeat;
	background-size: contain;
}

div.login button.facebook {
	background-image: url(img/facebook.png);
	background-color: #385495;
}

div.login button.google {
	background-image: url(img/google.png);
	background-color: #4285f4;
}

div.login button.twitter {
	background-image: url(img/twitter.png);
	background-color: #00aced;
}

div.login button.yahoo {
	background-image: url(img/yahoo.png);
	background-color: #f60e0b;
}

div.login button.instagram {
	background-image: url(img/instagram.png);
	background-color: #3f729b;
}

div.login button.line {
	background-image: url(img/line.png);
	background-position: left center;
	background-repeat: no-repeat;
	background-size: contain;
	background-color: #00c300;
}

div.login div.message {
	line-height: 120%;
}

iframe[name="sns_login"] {
	display: block;
	position: fixed;
	left: 0;
	top: 100%;
	width:100%;
	height: 100%;
	border: none;
	background-color: #fff;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}

div.button-area {
	position: fixed;
	bottom: 10px;
	width: 100%;
	padding-right: 20px;
}

iframe[name="sns_login"].show {
	display: block;
	top: 0;
}
*/
/**********/
/* Header */
/**********/
/*
h2 {
	width: 100%;
	height: 40px;
	padding: 8px 10px 0 55px;
	margin: 0 0 5px 0;
	color: #333;
	font-size: 120%;
	font-weight: bold;
	text-align: left;
	box-sizing: border-box;
	background-color: #fff;
	background-size: contain !important;
	background-repeat: no-repeat !important;
	background-position-x: 10px;
}
*/
/********/
/* HOME */
/********/

div.menu-button {
	width: 100%;
	text-align: center;
}

div.menu-button button {
	width: 30%;
	height: 30% !important;
	padding: 10px 0;
	font-size: 120%;
	background-color: #aa0;
	border: solid 1px #ff0;
}

span.small {
	font-size: 60%;
	font-weight: normal;
}

span.middle {
	font-size: 80%;
	font-weight: normal;
}

/**************/
/* マイページ */
/**************/


/************/
/* お知らせ */
/************/


/********/
/* 通知 */
/********/


/********/
/* 設備 */
/********/

table.facility {
	margin: 0 10px;
	width: calc(100% - 20px);
}

table.facility th {
	font-weight: normal;
	text-align: left;
	white-space: nowrap;
	background-color: #eee;
}

table.facility th,
table.facility td {
	padding: 4px;
	font-size: 80%;
	border: solid 1px #ccc;
}

table.facility td.open {
	padding: 0;
}
table.facility td.open th,
table.facility td.open td {
	font-size: 100%;
	padding: 0 5px;
	border: none;
	background-color: #fff;
}

/****************/
/* お知らせ一覧 */
/****************/

table.notification {
	font-size: 90%;
	border-top: solid 2px #ccc;
	border-bottom: solid 2px #ccc;
}

table.notification tr {
	border-bottom: solid 1px #ccc;
}

table.notification tr>* {
	padding-top: 5px; 
	padding-bottom: 5px; 
}

table.notification tr>*:not(:last-child) {
	width: 10px;
	white-space: nowrap;
}

table.notification tr>*:not(:first-child) {
	padding-left: 5px;
}

table.notification tr>*:not(:last-child) {
	padding-right: 5px;
}

table.notification tr {
	cursor: pointer;
}

table.notification div.readed {
	padding: 0 4px;
	border-radius: 10px;
	border: solid 2px lightBlue;
	background-color: lightBlue;
}

table.notification div.readed.important {
	border: solid 2px magenta;
	background-color: pink;
}

table.notification div.unread {
	padding: 0 4px;
	border-radius: 10px;
	border: solid 2px lightBlue;
}

table.notification div.unread.important {
	padding: 0 4px;
	border-radius: 10px;
	border: solid 2px magenta;
}

/************/
/* 予約一覧 */
/************/

table.reservation {
	width: 100%;
	font-size: 90%;
}

table.reservation thead {
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
}

table.reservation tr>* {
	padding: 10px 0;
}

table.reservation.narrow tr>* {
	padding: 5px 0;
}

table.reservation tr>*:not(:last-child) {
	width: 10px;
	white-space: nowrap;
}

table.reservation tr>*:not(:last-child) {
	border-right: solid 1px #ccc;
}

table.reservation tr>*:not(:first-child) {
	padding-left: 5px;
}

table.reservation tr>*:not(:last-child) {
	padding-right: 5px;
}

table.reservation tr {
	cursor: pointer;
}

/********/
/* 予約 */
/********/

ul.facility {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	width: 100%;
	margin: 0;
	padding: 10px;
	text-align: center;
}

ul.facility li {
	width: 100px;
	text-align: center;
	font-size: 60%;
	padding: 10px;
	/*border: solid 1px #ccc;*/
}

ul.facility li img {
	width: 100%;
}

/**************/
/* カレンダー */
/**************/
table.calendar {
	margin: 20px 20px;
	width: calc(100% - 40px);
	border-collapse: collapse;
}

table.calendar th,
table.calendar td {
	font-weight: normal;
	text-align: center;
	padding: 0;
	border: solid 1px #ccc;	
}

table.calendar th {
	width: 14%;
	color: #fff;
}

table.calendar td {
	color: lightgray;
}

table.calendar thead th.w0 {
	background-color: red;
}

table.calendar th.w1,
table.calendar th.w2,
table.calendar th.w3,
table.calendar th.w4,
table.calendar th.w5 {
	background-color: gray;
}

table.calendar th.w6 {
	background-color: blue;
}

table.calendar td.w0 {
	color: red;
}

table.calendar td.w1,
table.calendar td.w2,
table.calendar td.w3,
table.calendar td.w4,
table.calendar td.w5 {
	color: #333;
}

table.calendar td.w6 {
	color: blue;
}

table.calendar td.holiday {
	color: red;
}

table.calendar td.disable {
	background-color: #eee;
}

table.calendar #target a {
	display: inline-block;
	border: solid 1px red;
	border-radius: 50%;
}

table.calendar tfoot tr>* {
	padding: 0 5px;
	text-align: left;
	font-size: 80%;
	border: none;
	color: #333;
}

/****************/
/* タイムライン */
/****************/
table.timeline {
	margin: 20px 20px;
	width: calc(100% - 40px);
}

table.timeline th,
table.timeline td {
	padding: 0;
}

table.timeline th {
	width: 80px;
	font-weight: normal;
	text-align: right;
	padding-right: 10px;
}

table.timeline td {
	text-align: center;
	border-bottom: solid 1px #ccc;
}

table.timeline td.quarter div {
	width: 100%;
	height: 0.75em;
	cursor: pointer;
}

table.timeline td.quarter div:first-child {
	border-bottom: solid 1px #e8e8e8;
}

table.timeline td.quarter div.reserved {
	background-color: #feeeee;
	cursor: default;
}

table.timeline td.quarter div.myreserved {
	background-color: #eeeefe;
}

table.timeline td.quarter div.out_of_range {
	background-color: #f8f8f8;
	cursor: default;
}

table.timeline td.none {
	border: none;
}

/************/
/* ポイント */
/************/

div.point {
	
}

div.point h3 {
	margin: 0;
	padding: 0;
	font-size: 120%;
	line-height: 100%;
	text-align: center;
}

div.point h4 {
	margin: 0;
	padding: 0;
	font-size: 250%;
	line-height: 100%;
	text-align: center;
}

div.point h5 {
	margin: 5px 0;
	padding: 0;
	font-size: 100%;
	line-height: 100%;
	text-align: center;
	font-weight: normal;
}

div.point table th,
div.point table td {
	padding: 5px 10px;
	border: solid 1px #ccc;
}

div.point table tr.soon {
	color: red;;
}

div.point table th {
	text-align: center;
}

table.history {
	font-size: 90%;
}

table.history tr>* {
	padding: 2px 5px !important;
}

table.history thead tr {
	background-color: rgb(222, 246, 254);
}

table.account {
	margin-bottom: 10px;
	input {
		width: 100%;
		padding: 10px;
		border: none;
	}
	input:disabled {
		background-color: #fff;
	}
	tfoot {
		td {
			border: none;
			padding: 0;
			a {
				color: blue;
			}
		}
	}
}

table.account.disabled {
	opacity: 0.5;
}

/********************/
/* 左側が見出しの表 */
/********************/

table.left_header th {
	width: 10px;
	white-space: nowrap;
	background-color: #eee;
}

table.left_header tr>* {
	padding: 5px 10px;
	border: solid 1px #ccc;
}

/**************************************/
/* テーブルの行の背景を交互に変更する */
/**************************************/

table.stripe tr:not(thead tr) {
	background: #f8f8f8;
	cursor: pointer;
}

table.stripe tr:not(thead tr):nth-child(odd) {
	background: #fff;
}

td.amount {
	text-align: right;
}

td.amount::after {
	content: " 円";
}

td.person {
	text-align: right;
}

td.person::after {
	content: " 人";
}

@media screen and (max-width: 768px) {
	html {
		background-color: #fff;
	}
	body {
		width: 100%;
		font-size: 20px;
	}
	header {
		width: 100%;
	}
	footer {
		width: 100%;
	}
	/*
	div#-popup iframe {
		width: 90% !important;
		left: 5% !important;
	}
		*/
}

@media only screen and (max-width:360px) {
	dl.inline dt,
	dl.inline dd {
		clear: both;
	}
	
	dl.inline dt {
		display: block;
		margin-top: 0 !important;
		margin-bottom: 0 !important;
	}

	dl.inline dd {
		margin: 2px 0 16px !important;
	}
}

@media only screen and (width:320px) {

	div.step-box h2 {
		font-size: 105%;
		padding-top: 7px;
	}
/*
	div#-popup iframe {
		height: 340px !important;
	}
*/
	span.small.point {
		position: relative;
		top: -5px;
	}

	div.prediction table td {
		font-size: 75%;
	}

	dl.inline dt,
	dl.inline dd {
		clear: both;
	}
	
	dl.inline dt {
		display: block;
		margin-top: 0 !important;
		margin-bottom: 0 !important;
	}

	dl.inline dd {
		margin: 2px 0 16px !important;
	}

	tr.entrant img {
		margin-top: 4px;
	}
	
	p.full-name {
		display: none;
	}
	
	p.short-name {
		display: inline-block;
	}

	th.full-name,
	td.full-name {
		font-size: 110% !important;
	}

	table.confirmed td.date,
	table.confirmed td.like,
	table.confirmed td.page-view {
	/*	line-height: 80% !important;*/
		background-size: auto 20px !important;
		background-position: 10px 0 !important;
	}
	/*
	dl.point-total {
		font-size: 100%;
	}
	*/
}

@media only screen and (width:375px) {
	/*
	div#-popup iframe {
		height: 340px !important;
	}
*/
	div.prediction table td {
		font-size: 90%;
	}

	dl.inline dt,
	dl.inline dd {
		clear: both;
	}
	
	dl.inline dt {
		display: block;
		margin-top: 0 !important;
		margin-bottom: 0 !important;
	}

	dl.inline dd {
		margin: 2px 0 20px !important;
	}
/*
	p.full-name {
		display: none;
	}
	
	p.short-name {
		display: inline-block;
	}*/

	th.full-name,
	td.full-name {
		font-size: 120% !important;
	}
}
/*
.full-screen {
	position: fixed;
	visibility: hidden;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: none;
	transition: background-color 0.3s linear;
}

.full-screen.show {
	visibility: visible;
	background-color: rgba( 0, 0, 0, 0.2 );
}
*/
div#--uploading {
	position: fixed;
	visibility: hidden;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-image: url('img/loading.gif');
	background-position: center bottom 5px;
	background-repeat: no-repeat;
	background-color: none;
	transition: background-color 0.3s linear;
}

div#--uploading.show {
	visibility: visible;
	background-color: RGBA( 0, 0, 0, 0.2 );
}

/************/
/*  Option  */
/************/

body.option {
	padding: 0;
}

body.inner-pane {
	padding: 0;
}

/***********/
/* Profile */
/***********/

form[name="profile"] textarea,
form[name="profile"] input[type="text"],
form[name="profile"] input[type="date"] {
	display: block;
	width: 100%;
	margin: 0;
	padding: 10px 5px;
	padding-bottom: 0;
	background-color: #fff;
	border: none;
}

form[name="profile"] label {
	display: block;
	width: 100%;
	height: 28px;
	margin: 0;
	padding: 0 5px;
	color: #333;
	font-weight: bold;
	background-color: #f5f8fa;
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
}

form[name="profile"] textarea,
form[name="profile"] input[type="text"],
form[name="profile"] input[type="date"] {
	font-size: 100%;
	padding-bottom: 10px;
	border-radius: 0;
	-webkit-appearance: none;
/*	border-bottom: solid 2px #7c8c99;*/
}

form[name="profile"] div.birthday {
	position: relative;
	background-color: #ff8;
}

form[name="profile"] p.placeholder {
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	margin: 0;
	padding: 10px 5px;
	width: 100%;
	height: 43px;
	color: #666;
	background-color: #fff;
	pointer-events: none;
}

form[name="profile"] input[type="date"] {
	height: 44px;
	text-align: center;
	border-bottom: solid 1px #ccc;
}

form[name="profile"] textarea {
	height: 100px;
}

form[name="profile"] div.icon {
	position: relative;
	margin: 10px;
}

form[name="profile"] div.icon img.add-icon {
	position: absolute;
	left: 0;
	top: 0;
	width: 60px;
	width: 60px;
	padding: 22px 22px;
	background-color: RGBA( 0, 0, 0, 0.1 );
}

form[name="profile"] div.icon button {
	position: absolute;
	left: 70px;
	top: 20px;
	width: 100px;
	height: 30px;
	white-space: nowrap;
}

form[name="profile"] div.icon input[type="file"] {
	position: absolute;
/*	left: 0;
	top: 0;
	width: 60px;
	height: 60px;*/
	left: 70px;
	top: 20px;
	width: 100px;
	height: 30px;
	opacity: 0;
	background-color: #f00;
}

form[name="profile"] p.limit {
	display: block;
	float: right;
	margin: 0;
	padding: 2px 0;
	font-weight: normal;
}


/**********************/
/* ハンバーガメニュー */
/**********************/

a#menu,
a#-return {
/*a#-return,*/
	position: absolute;
	left: 4px;
	top: 8px;
	width: 30px;
	height: 24px;
	margin: 0;
/*	z-index: 10;*/
}
a#menu,
a#menu span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
a#menu span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #fff;
	border-radius: 4px;
}
a#menu span:nth-of-type(1) {
	top: 0;
}
a#menu span:nth-of-type(2) {
	top: 10px;
}
a#menu span:nth-of-type(3) {
	bottom: 0;
}

a#menu.active {
	-webkit-transform: rotate(360deg);
	transform: rotate(360deg);
}
a#menu.active span:nth-of-type(1) {
	-webkit-transform: translateY(10px) rotate(-45deg);
	transform: translateY(10px) rotate(-45deg);
}
a#menu.active span:nth-of-type(2) {
	-webkit-transform: translateY(0) rotate(45deg);
	transform: translateY(0) rotate(45deg);
}
a#menu.active span:nth-of-type(3) {
	opacity: 0;
}

a#-return {
	top: 6px;
	color: #fff;
	font-size: 20px;
/*	font-size: 24px;*/
	font-weight: bold;
}

a#-right-button {
	/*
	top: 10px;
	left: auto;
	right: 6px !important;
	width: auto;
	*/
	color: #fff;
	font-size: 16px;
}

a#icon {
	position: absolute;
	right: 4px;
	top: 4px;
/*	z-index: 10;*/
}

/**********************/
/* プルダウンメニュー */
/**********************/

div#mask {
	position: fixed;
	display: block;
	visibility: hidden;
	left: 0;
	top: 50px;
	width: 100%;
	height: 100%;
	background-color: #000;
	opacity: 0;
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
/*	z-index: 10;*/
}

div#mask.show {
	visibility: visible;
	opacity: 0.2;
/*	z-index: 10;*/
}

ul.pulldown-menu {
	display: block;
	position: absolute;
	visibility: hidden;
	left: 0;
	top: 50px;
/*	width: 100px;*/
	width: auto;
	height: 0;
	margin: 0;
	padding: 0;
	overflow: hidden;
	color: #333;
	text-align: left;
	list-style-type: none;
	background-color: #fff;
	border: solid 1px #ccc;
	border-top: none;
/*	box-shadow: 4px 4px 10px RGBA(0,0,0,0.6);*/
/*	z-index: 11;*/
}

ul.pulldown-menu a {
	color: #333;
}

ul.pulldown-menu.active {
	visibility: visible;
	height: auto;
/*	max-height: 100%;*//* JavaScript で設定する */
	overflow-y: scroll;
/*	z-index: 11;*/
}

ul.pulldown-menu li {
	display: block;
	width: auto;
	height: 0;
	padding: 20px 10px 20px 60px !important;
	overflow: hidden;
	box-sizing: border-box;
	transition: .2s;
}

ul.pulldown-menu li:not(:first-child) {
	border-top: solid 1px #ccc;
}

ul.pulldown-menu li.header {
	color: #fff;
	padding: 5px 0 !important;
	text-align: center;
	max-height: 2em;
	background-color: #00b0f0;
}

ul.pulldown-menu li.division {
	color: #333;
	padding: 5px 0 !important;
	text-align: center;
	max-height: 2em;
	background-color: #eef;
}

ul.pulldown-menu li.top,
ul.pulldown-menu li.about,
ul.pulldown-menu li.accepting,
ul.pulldown-menu li.chat,
ul.pulldown-menu li.ranking,
ul.pulldown-menu li.notice,
ul.pulldown-menu li.mypage,
ul.pulldown-menu li.notification,
ul.pulldown-menu li.config,
ul.pulldown-menu li.logout {
	background-position: 10px center;
	background-repeat: no-repeat;
	background-size: 40px auto;
}

ul.pulldown-menu li.top {
	background-image: url(img/top.png);
}

ul.pulldown-menu li.about {
	background-image: url(img/about.png);
}

ul.pulldown-menu li.accepting {
	background-image: url(img/accepting.png);
}

ul.pulldown-menu li.chat {
	background-image: url(img/chat.png);
}

ul.pulldown-menu li.notice {
	background-image: url(img/notice.png);
}

ul.pulldown-menu li.ranking {
	background-image: url(img/ranking.png);
}

ul.pulldown-menu li.mypage {
	background-image: url(img/mypage.png);
}

ul.pulldown-menu li.notification {
	background-image: url(img/notification.png);
}

ul.pulldown-menu li.config {
	background-image: url(img/config.png);
}

ul.pulldown-menu li.logout {
	background-image: url(img/logout.png);
}

ul.pulldown-menu.active li {
	height: 3.7em;
	overflow: visible;
}

ul.pulldown-menu.hierarchy li::after {
	display: inline-block;
	content: " ";
	width: 18px;
}

ul.pulldown-menu li.hierarchy::after {
	/*content: "\025B6";*/	/* > */
	content: "\025BC";	/* V */
	color: #00b0f0;
	-webkit-transform: rotate(-90deg);
	-moz-transform: rotate(-90deg);
	-ms-transform: rotate(-90deg);
	-o-transform: rotate(-90deg);
	transform: rotate(-90deg);
	transition: all 0.2s;
}

ul.pulldown-menu li.hierarchy.active::after {
	/*content: "\025BC";*/	/* V */
	-webkit-transform: rotate(0);
	-moz-transform: rotate(0);
	-ms-transform: rotate(0);
	-o-transform: rotate(0);
	transform: rotate(0);
}

ul.pulldown-menu li.sub {
	height: 0;
	padding: 0 10px 0 20px !important;
	overflow: hidden;
	border: none;
}

ul.pulldown-menu li.sub.active {
	height: 2.5em;
	padding: 10px 10px 10px 20px !important;
	overflow: visible;
	border-top: solid 1px #ccc;
}

ul#user-menu {
	left: auto;
	right: 0;
/*	left: 200px;*/
	width: 190px;
}

/****************/
/* ポップアップ */
/****************/

body.fixed {
    position: fixed;
    /*width: 100%;*/
    height: 100%;
    left: 0;
}

body.popup {
	padding: 40px 0;
}

body.popup h1 {
	position: fixed;
	left: 0;
	top: 0;
	font-size: 120%;
	padding-left: 0;
	padding-right: 0;
	z-index: 1;
}

body.popup h2 {
	margin-bottom: 0;
	/*padding: 10px 0;*/
	padding: 0;
	font-size: 100%;
	font-weight: normal;
	text-align: center;
}

body.popup h3 {
	margin: 0;
	padding: 0;
	font-size: 100%;
	font-weight: normal;
	text-align: center;
}

body.popup p {
	margin: 0;
	padding: 0;
}

body.popup div.scrolling {
	margin: 0 20px;
	padding: 10px;
	width: calc(100% - 40px);
	height: 260px;
	border: solid 1px #ccc;
}

body.popup footer {
	position: fixed;
	bottom: 0;
	width: 100%;
	padding: 10px;
	text-align: center;
	background-color: #fff;
}

body.popup #alert {
	display: none;
}
/*
div#-popup {
	z-index: 10;
}

div#-popup iframe {
	position: fixed;
	left: calc((100% - 600px) / 2);
	top: 100%;
	width: 600px;
	height: 400px;
	background: #fff;
	border: none;
	box-shadow: 0 0 10px #000;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}

div#-popup.show iframe {
	top: 20%;
}

div#-zoom {
	top: 100%;
	background-image: url('img/loading.gif');
	background-position: center center;
	background-repeat: no-repeat;
	background-size: auto;
	transition: top 0.2s ease-out;
	z-index: 10;
}

div#-zoom.show {
	visibility: visible;
	top: 0;
	background-color: rgba( 0, 0, 0, 0.9 );
}

div#-zoom div.close {
	position: absolute;
	top: 0;
	right: 0;
	width: 30px;
	height: 30px;
	color: #fff;
	font-size: 40px;
	line-height: 30px;
	text-align: center;
	border-radius: 50%;
	background-color: #000;
	opacity: 0.5;
}

div#-alert {
	z-index: 10;
}

div#-alert section {
	display: block;
	position: relative;
	top: 15%;
	width: 250px;
	height: 130px;
	margin: 100px auto;
	padding-top: 10px;
	text-align: center;
	border: solid 2px #ccc;
	background-color: #fff;
	border-radius: 10px;
	box-shadow: 0 0 10px #000;
	opacity: 0;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}

div#-alert.show section {
	opacity: 1;
}

div#-alert section p#-title,
div#-alert section p#-message {
	font-size: 120%;
	margin: 10px 0;
	white-space: pre-wrap;
}

div#-alert section p#-title {
	font-weight: bold;
}

div#-alert section div {
	position: absolute;
	bottom: 10px;
	width: 100%;
}

div#-alert section button {
	margin: 5px 10px;
}

div#-slidein {
	display: none;
	position: fixed;
	left: 100%;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 20;
	transition: left 0.2s ease-out;
	background-color: #fff;
}

div#-slidein.show {
	left: 0;
}

div#-slidein iframe {
	width: 100%;
	height: 100%;
	margin-top: -40px;
	padding-top: 40px;
	box-sizing: border-box;
	border: none;
	overflow-y: scroll;
}
*/
/******************/
/* フルスクリーン */
/******************/

body.fullscreen {
	padding: 0;
	/*text-align: center;*/
	border: solid 10px #7A272D;
}

body.fullscreen h1 {
	height: 50px;
}

body.fullscreen h2 {
	margin: 0;
	padding: 0;
	color: rgb(10, 158, 216);
	font-size: 160%;
	text-align: center;
}

body.fullscreen h3 {
	padding: 0;
	/*margin: 10px 0 0;*/
	margin: 0;
	font-size: 120%;
	font-weight: normal;
	text-align: center;
	line-height: 100%;
}

body.fullscreen select {
	font-size: 30px;
	color: #333;
}

/******************/
/* 送迎バス時刻表 */
/******************/

table.timetable {
	font-size: 80%;
	margin: 0 auto 20px;
	width: calc(100% - 40px);
}

table.timetable a {
	color: blue;
}

table.timetable thead th {
	text-align: center;
	vertical-align: top;
	background-color: cornsilk;
}

table.timetable thead span {
	display: inline-block;
	white-space: pre;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	/*text-orientation: upright;*/
}

table.timetable thead span span.latin {
	text-orientation: upright;
	letter-spacing: -0.4em; /* マイナスで詰める */
	padding-bottom: 4px;
}

table.timetable tr>* {
	padding: 10px 5px;
	border: solid 1px #ccc;
}

table.timetable tbody tr>* {
	text-align: center;
}

/*table.timetable.low tbody tr td {*/
table.timetable.low tbody tr>* {
	background-color: rgb(201, 187, 64);
}

table.timetable.low tr.out_of_service td {
	text-decoration: line-through;
}

table.timetable.low tbody tr.reservation>* {
/*table.timetable tr.reservation td {*/
	background-color: #fff !important;
}

/********************/
/* メタリックボタン */
/********************/

/*背景*/
.btn-wrap {
	display: inline-block;
	width: 100px;
	height: 100px;
	margin: 20px 20px;
}

.btn,
a.btn,
button.btn {
  font-size: 60px;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  /*padding: 1rem 4rem;*/
  width: 100%;
  height: 100%;
  /*padding: 1rem 1rem;*/
  padding: 5px 0;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  /*border-radius: 0.5rem;*/
}

.btn-switch {
  color: #333;
  border: 1px solid #ddd;
  /*border-radius: 100vh;*/
  background: #fbfbfc;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#fbfbfc),
    to(#dcddde)
  );
  background: -webkit-linear-gradient(top, #fbfbfc 0%, #dcddde 100%);
  background: linear-gradient(180deg, #fbfbfc 0%, #dcddde 100%);
  -webkit-box-shadow: -1px -5px 6px rgba(0, 0, 0, 0.2), 3px 3px 5px white,
    0 10px 10px rgba(0, 0, 0, 0.1), inset 0 -4px 5px rgba(0, 0, 0, 0.1);
  box-shadow: -1px -5px 6px rgba(0, 0, 0, 0.2), 3px 3px 5px white,
    0 10px 10px rgba(0, 0, 0, 0.1), inset 0 -4px 5px rgba(0, 0, 0, 0.1);
}

.btn-switch span {
  display: inline-block;

  -webkit-transition: all 0.3s;

  transition: all 0.3s;
}

.btn-switch:hover {
  -webkit-box-shadow: -1px -5px 6px rgba(0, 0, 0, 0.2), 3px 3px 5px white,
    0 10px 10px rgba(0, 0, 0, 0.1), inset 0 -4px 5px rgba(0, 0, 0, 0.1),
    inset 0 3px 3px rgba(0, 0, 0, 0.18);
  box-shadow: -1px -5px 6px rgba(0, 0, 0, 0.2), 3px 3px 5px white,
    0 10px 10px rgba(0, 0, 0, 0.1), inset 0 -4px 5px rgba(0, 0, 0, 0.1),
    inset 0 3px 3px rgba(0, 0, 0, 0.18);
}

.btn-switch:hover span {
  -webkit-transform: scale(0.96);
  transform: scale(0.96);
}

button.btn-switch {
	width: 80px;
	height: 50px;
	font-size: 20px;
}

/* 旧来の iPhone（例：16:9 や 3:2） */
/*@media screen and (max-width: 768px) and (max-aspect-ratio: 9/16) {*/
/* 旧来の iPhone（高さが小さい） */
@media screen and (max-width: 768px) and (max-height: 736px) {
	.btn-wrap {
		margin: 5px 20px;
	}
}

/* XperiaV（SO-52E）で駐車券のボタンが縦になってしまう現象の対策 */
@media screen and (width: 1080px) {
	body.login section {
		zoom: 80%;
	}
}

/********/
/* 共通 */
/********/

.document {
	white-space: pre-wrap;
}

.shadow {
	box-shadow: 0 0 10px #000;
}

.wbr span {
	display: inline-block;
/*	white-space: nowrap;*/
}

p.message {
	color: #f00;
	margin: 0;
	padding: 0;
	line-height: 110%;
}

table.center {
	width: 100%;
}

table.center th {
	width: 10%;
}

table.center td {
	width: 45%;
}

table.center th.center,
table.center td.center {
	text-align: center;
}

table.center th.right,
table.center td.right {
	text-align: right;
}

button.center {
	display: block;
	margin: 0 auto;
}

button.bottom {
	position: fixed;
	bottom: -5px;
	left: 50%;
	transform: translate(-50%, -50%);
}

div.scrolling {
	position: absolute;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	overflow-x: hidden;
	overflow-y: auto;
}

table.simple {
	width: 100%;
	background-color: #fff;
}

table.simple th,
table.simple td {
	padding: 5px;
	font-size: 100%;
	border: none;
}

table.simple th {
	text-align: center;
	font-weight: bold;
}

table.simple td {
	text-align: left;
}

table.no-border {
	background-color: #fff;
}

table.no-border th,
table.no-border td {
	padding: 10px !important;
	text-align: left;
	vertical-align: top;
	box-sizing: border-box;
	border: none !important;
}

button.large {
	width: 90%;
	padding: 10px;
	margin: 4px 5% 0;
	float: center;
	color: #000;
	font-weight: bold;
	background-color: #eaeaea;
	border: solid 1px #ccc;
}

button.large:disabled {
	color: #fff;
	background-color: #ddd;
}

button.more::after {
	content: "〉";
	color: #333;font-size: 120%;
	font-weight: bold;
	float: right;
}

button.yellow {
	color: #fff;
	background-color: #ffc000;
}

button.blue {
	color: #fff;
	background-color: #00b0f0;
}

img.icon {
	width: 32px;
	height: 32px;
/*	object-fit: contain;*/
	object-fit: cover;
}

img.icon-small {
	width: 24px;
	height: 24px;
/*	object-fit: contain;*/
	object-fit: cover;
}

img.icon-middle {
	width: 40px;
	height: 40px;
	object-fit: cover;
}

img.icon-medium {
	width: 50px;
	height: 50px;
	object-fit: cover;
}

img.icon-large {
	width: 60px;
	height: 60px;
	object-fit: cover;
}

img.circle {
	border-radius: 50%;
	background-color: #4f4;
}

img.notice {
	max-width: 90px;
	max-height: 60px;
	object-fit: contain;
}

div.icon {
	display: inline-block;
	width: 32px;
	height: 32px;
}

div.icon-small {
	display: inline-block;
	width: 24px;
	height: 24px;
}
/*
div#-inner-pane {
	display: none;
	position: fixed;
	left: 0;
	top: 100%;
	width: 100%;
	height: 100%;
	border-top: solid 1px #000;
	background-color: #fff;
	transition: all 0.3s ease-out;
}

div#-inner-pane.show {
	border-top: solid 1px #fff;
	top: 0;
}
*/
footer section {
	display: block;
	width: calc(100% - 20px);
	margin: 10px auto;
	padding: 10px;
	border: solid 1px #ccc;
}

footer section h4 {
	color: #00f;
	font-weight: bold;
}

footer div.goto_top {
	color: #fff;
	padding: 10px;
	text-align: center;
	background-color: #2f5597;
}

footer div.link {
	padding: 10px 0;
	text-align: center;
	background-color: #f2f2f2;
}

footer div.copyright {
	color: #fff;
	padding: 10px;
	font-weight: bold;
	text-align: center;
	background-color: #00b050;
}

div#-inner-pane iframe {
	width: 100%;
	height: 100%;
	border: none;
}

.nobr {
	white-space: nowrap;
}

.bold {
	font-weight: bold;
}

.red {
	color: #f00;
}

.ellipsis {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

.odds {
	white-space: nowrap;
	text-align: right !important;
}

.odds.red {
	color: #f00;
}

.odds.blue {
	color: #33f;
}

div.spc2 {
	height: 2px;
	line-height: 2px;
}

div.spc5 {
	height: 5px;
	line-height: 5px;
}

div.spc10 {
	height: 10px;
	line-height: 10px;
}

div.spc20 {
	height: 20px;
	line-height: 20px;
}

div.nothing {
	text-align: center;
	font-weight: bold;
	padding: 30px 0;
	border-top: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
}
/*
#toast {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	padding: 10px;
	color: #fff;
	opacity: 0;
	white-space: nowrap;
	border-radius: 10px;
	background-color: rgba( 0, 0, 0, 0.6 );
	filter: drop-shadow(0 0 10px #000);
	pointer-events: none;
	transition: opacity 0.3s;
}

#toast.show {
	opacity: 1;
}
*/