@charset "utf-8";

::-ms-expand{display:none;}
#titleBlock{margin: 0;}
#scheduleBox .title,
#scheduleBox .sec{
	margin:0 auto;
	width:90vw;
	max-width:1000px;
	word-wrap:break-word;
}
#scheduleBox .sec+.sec{margin-top:50px;}
#scheduleBox .title time{
	color: #00405f;
	font-size: 1.222rem;
	font-weight: bold;
	letter-spacing: 0.1rem;
}
#scheduleBox .title .endMsg{
	color: #006def;
	font-size: 1.05rem;
}


/* detail */
/********************/
/* title */
.article #scheduleBox{position: relative;}
#scheduleBox .title {
	border-bottom: 1px solid #e5e5e5;
	position: relative;
	padding-bottom: 20px;
	margin-bottom: 40px;
}
#scheduleBox .title h1 {
	font-size:2.777rem;
	margin: 10px 0 30px;
}
#scheduleBox .title .schedule{width:calc(100% - 96px);}
#scheduleBox .title dt {
	color: #00405f;
	font-weight: normal;
	letter-spacing: 0.1rem;
}
#scheduleBox .title .sns {
	position: absolute;
	right: 0;
	bottom: 22px;
}
#scheduleBox .title .sns dt {
	text-align: right;
	font-weight: bold;
}
#scheduleBox .title .sns dd {
	display: inline-block;
	vertical-align: middle;
	width:24px;
	height:24px;
	margin-top:6px;
}
#scheduleBox .title .sns dd a{display: block;}

/* section */
#scheduleBox .sec h2 {
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
	font-size:1.944rem;
	line-height: 1.6;
	letter-spacing: 0;
	margin-bottom: 25px;
}
#scheduleBox .sec p {
	line-height: 1.8;
	margin-bottom: 2rem;
}
#scheduleBox .sec p.caution {
	position: relative;
	padding-left: 1em;
}
#scheduleBox .sec p.caution:before {
	content: "※";
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	line-height: 1.6;
}
#scheduleBox .sec dl{
	margin-bottom:2rem;
}
#scheduleBox .sec dl *+dt{margin-top:1.2rem;}
#scheduleBox .sec dl.tbl{width: 100%;}
#scheduleBox .sec dl.tbl:after{
	display: block;
	clear: both;
	content: "";
}
#scheduleBox .sec dl.tbl dt,
#scheduleBox .sec dl.tbl dd{display: block;}
#scheduleBox .sec dl.strongTbl dt,
#scheduleBox .sec dl.strongTbl dd{font-weight: bold;}
#scheduleBox .sec table.commonTbl{
	margin-bottom: 36px;
	border-top:1px solid #eee;
	border-bottom:1px solid #eee;
}
#scheduleBox .sec table.commonTbl tr+tr{border-top:1px solid #eee;}
#scheduleBox .sec table.commonTbl th{
	padding:8px 20px;
	font-weight: bold;
}
#scheduleBox .sec table.commonTbl td{padding:8px 20px;}

#scheduleBox .sec a {
	color: #00405f;
	font-weight: bold;
}

/* list */
.sec h3{
	display: block;
	padding:6px;
	margin-bottom:2rem;
	font-size:2.1rem;
	line-height: 1.8;
	border-bottom:1px solid #000;
}
.sec *+h3{margin-top: 4rem;}
.sec h4{
	display: block;
	margin-bottom:2rem;
	font-size:1.8rem;
	line-height: 1.8;
}
.sec *+h4{margin-top:3rem;}
.sec ol.list {counter-reset: item;}
.sec ul.list li,
.sec ol.list li {
	padding:0 0 2.5rem 3.5rem;
	position: relative;
}
.sec ol.list li:before{
	counter-increment: item;
	content:'0' counter(item);
	padding-right:0.5rem;
	color: #233f6d;
	font-size: 1.277rem;
	font-weight: bold;
	position: absolute;
	left: 1px;
	top:1px;
	font-family: "Accurat","Helvetica Neue",sans-serif;
	letter-spacing: 0.1rem;
}
.sec ol.list li:after {
	content: '';
	height: 3px;
	width: 20px;
	display: block;
	background-color: #233f6d;
	position: absolute;
	left: 0;
	top: 1.6rem;
}
.sec ul.list li:before {
	content: '';
	height: 3px;
	width: 20px;
	display: block;
	background-color: #233f6d;
	position: absolute;
	left: 0;
	top:1rem;
}
/* img */
article#scheduleBox figure {
	margin:60px auto;
	width:96%;
	max-width:900px;
	text-align: center;
}
article#scheduleBox section table tr+tr{border-top:1px solid #efefef;}

/*oparationStatus*/
#oparationStatus h4,
#outService h3+h4{
	margin-top:-1rem;
	text-align: right;
}
#oparationStatus .statusBox{
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#oparationStatus .statusBox dl{
	display: block;
	border: 1px solid #ccc;
	text-align: center;
}
#oparationStatus .statusBox dl dt{
	padding: 8px 0;
	background: #eee;
	font-weight: bold;
	border-bottom: 1px solid #ccc;
}
#oparationStatus .statusBox dl dt span,
#oparationStatus .statusBox dl dt time{display: block;}
#oparationStatus .statusBox dl dt time:before{
	content: "";
	margin-right: 5px;
	display: inline-block;
}
#oparationStatus .statusBox dl dd{padding: 8px 0;}
#oparationStatus .statusBox dl dd ul {
	display:table;
	width: 100%;
}
#oparationStatus .statusBox dl dd ul li{
	display: table-cell;
	vertical-align: middle;
	width: 50%;
}
#oparationStatus .statusBox dl dd ul li:last-child,
#oparationStatus .statusBox dl dd ul li.rent{font-weight: bold;}
#oparationStatus .statusBox dl dd ul li:last-child[data-level="1"]{color:#2f5597;}
#oparationStatus .statusBox dl dd ul li:last-child[data-level="2"]{color:#548335;}
#oparationStatus .statusBox dl dd ul li:last-child[data-level="3"]{color:#c55a11;}
#oparationStatus .statusBox dl dd ul li:last-child[data-level="4"]{color:#c00000;}
#oparationStatus .statusBox dl dd ul li.rent span{
	padding-top:6px;
	padding-bottom:6px;
}
#scheduleBox #oparationStatus .caution{
	display: block;
	position: relative;
	margin-top: 0;
	padding-left:20px;
}
#oparationStatus p.caution:before{
	content: "※";
	position: absolute;
	top: 0;
	left: 0;
}
#outService .locationSelect label{
	display: inline-block;
	margin-right:16px;
}
#outService .locationSelect select{
	display: inline-block;
	border:none;
	padding:5px 40px 5px 10px;
	border-bottom:0.3rem solid #fff;
	margin-bottom:1rem;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: url(/common/img/pink-arrow-down.svg) no-repeat 98% 50% #fff;
	background-size: 12px;
	outline:1px solid #eee;
}
#outService .locationSelect select:focus{
	border-bottom: 0.3rem solid #f35454;
	background-color: #fff4f4;
	background-image: url(/common/img/pink-arrow-up.svg);
	outline: none;
}
#outService .locationGroup{
	margin-top:4rem;
	border:1px solid #cccccc;
}
#outService .locationGroup h4{
	display: block;
	padding:4px 20px;
	margin:0;
	border-bottom:1px solid #cccccc;
	background-color:#eeeeee;
	line-height: 1.8;
}
#outService .locationGroup h4 span.ttl{font-size: 2.1rem;}
#outService .locationGroup h4 time{
	font-weight: normal;
	font-size: 1.4rem;
}
#outService .locationGroup h4 a.more{
	display: inline-block;
	background: #000;
	color: #fff;
	vertical-align: middle;
	padding:2px 12px;
	border-radius:5px;
	font-size:1.3rem;
	transition:all 0.4s;
}
#outService .locationGroup h4 a.more:after{
	display: inline-block;
	vertical-align:1px;
	margin-left:8px;
	font-family: FontAwesome;
	content: "\f105";
	
}
#outService .locationGroup h4 a.more:hover{
	opacity:0.7;
	text-decoration: none;
}
/* #outService .locationGroup table,
#outService .locationGroup > p{margin:12px 20px;}
#outService .locationGroup table td[colspan="3"]{
	padding-top: 16px;
	text-align: left;
} */



@media screen and (min-width:1081px){
	/*article*/
	article#scheduleBox {margin:80px 10px 70px;}
	#oparationStatus div.statusBox[data-int="2"]:after,
	#oparationStatus div.statusBox[data-int="5"]:after,
	#oparationStatus div.statusBox[data-int="8"]:after,
	#oparationStatus div.statusBox[data-int="11"]:after,
	#oparationStatus div.statusBox[data-int="14"]:after,
	#oparationStatus div.statusBox[data-int="17"]:after,
	#oparationStatus div.statusBox[data-int="20"]:after,
	#oparationStatus div.statusBox[data-int="23"]:after{
		display: block;
		width:31%;
		height: 1px;
		content: "";
	}
	#oparationStatus .statusBox dl{width:31%;}
}
@media screen and (min-width:769px) and (max-width:1080px){
	/*article*/
	article#scheduleBox{margin: 8vw 1vw 7vw;}
	#oparationStatus .statusBox dl{width:48%;}
}
@media screen and (min-width:769px){
	section.mv h3{font-size: 3.8rem;}
	#scheduleBox .title .endMsg{
		display: inline-block;
		margin-left: 16px;
	}
	#scheduleBox .sec dl.tbl dt{
		width:90px;
		margin:0 0 5px;
		float: left;
	}
	#scheduleBox .sec dl.tbl dd{margin: 0 0 5px 95px;}
	#oparationStatus h4,
	#outService h3+h4{font-size:1.3rem;}
	#scheduleBox #oparationStatus .lead{margin-bottom:40px;}
	#oparationStatus .statusBox dl dt time{
		margin-top:2px;
		font-size:1.2rem;
	}
	#oparationStatus .statusBox dl dt time:before{content: "利用可能時間:";}
	html[lang="en"] #oparationStatus .statusBox dl dt time:before{content: "Available time:";}
	#oparationStatus .statusBox dl ul li{padding:0 20px;}
	#oparationStatus .statusBox dl ul li:last-child{font-size:1.8rem;}
	#outService h4+form[name="search_form"]{margin-top:-40px;}
	/* #outService .locationGroup h4 a.more{vertical-align:4px;}
	#outService .locationGroup table td{
		padding: 8px 16px;
		vertical-align: top;
	}
	#outService .locationGroup table td:nth-child(1){
		min-width:124px;
		text-align:right;
	}
	#outService .locationGroup table td:nth-child(2){
		min-width:132px;
		text-align:center;
	} */
}
@media screen and (max-width:768px) {
	section.mv h3{font-size: 3.2rem;}

	
	/*article*/
	article#scheduleBox{padding: 7vw 0;}

	#scheduleBox .sec .relatedLinks dt,
	#scheduleBox .sec .relatedLinks dd{width:auto;}
	#scheduleBox .title h1{font-size: 2.4rem;}
	#scheduleBox .title .endMsg{display:block;}
	#scheduleBox .sec dl.tbl dt{margin:0 0 5px;}
	#scheduleBox .sec dl.tbl dd{margin: 0 0 12px 30px;}
	#scheduleBox .sec table.commonTbl,
	#scheduleBox .sec table.commonTbl *{
		display: block;
		width: 100%;
	}
	#scheduleBox .sec table.commonTbl th,
	#scheduleBox .sec table.commonTbl td{
		padding-left: 10px;
		padding-right: 10px;
	}
	#scheduleBox .sec table.commonTbl * + th,
	#scheduleBox .sec table.commonTbl * + td{padding-top:0;}

	#oparationStatus h4,
	#outService h3+h4{font-size:1.2rem;}
	#scheduleBox #oparationStatus .lead{margin-bottom:4vw;}
	#oparationStatus .statusBox dl dt time{
		margin-top:3px;
		font-size:11px;
	}
	#oparationStatus .statusBox dl dt time:before{
		content: "";
		width:16px;
		height:16px;
		background: url(../img/time-ico.svg) no-repeat left top;
		background-size: contain;
		vertical-align: -4px;
	}
	#oparationStatus .statusBox dl ul li{
		padding:0 10px;
		font-size:1.3rem;
	}
	#oparationStatus .statusBox dl ul li:last-child{font-size:1.5rem;}
	/* #outService .locationGroup h4 time{display: block;}
	#outService .locationGroup table tr{display: block;}
	#outService .locationGroup table tr+tr{
		margin-top:12px;
		padding-top: 12px;
	}
	#outService .locationGroup table td{
		padding-right:12px;
		text-align: left;
	}
	#outService .locationGroup table td:nth-child(n-2){display:inline-block;}
	#outService .locationGroup table td:last-child{
		display: block;
		width:100%;
		margin-top:8px;
	} */
}
@media screen and (min-width:481px) and (max-width:768px){
	#oparationStatus .statusBox dl{width:48%;}
}
@media screen and (max-width:480px){
	#titleBlock.subBefore h2 .enName{font-size: 3.6rem;}
	#titleBlock.subBefore h2 .jpName{font-size: 1.6rem;}
	#scheduleBox .title h1{font-size: 2.1rem;}
	#oparationStatus .statusBox dl{width:100%;}
}