@charset "UTF-8";
.fv{
	position: relative;
}
.fv_01{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	/*FVもとに戻すときコメントアウト外す*/
	/* width: 400px;
	height: 150px; */
	margin: auto;
	
	/*FVもとに戻すときここからコメントアウト*/
	/* min-width: 480px; */
	width: calc(480/1100 * 100vw );
	/* min-height: 356px; */
	height: calc(356/1100 * 100vw );
	/*FVもとに戻すときここまでコメントアウト*/
}
.fv_01 img{
	display: block;
	width: 100%;
}
.fv_02{
	position: absolute;
	top: 16px;
	left: 75%;
	width: 200px;
	height: 200px;
}

/***   ev用   ***/
.top_ev_banner .wrap {
	max-width: 860px;
	margin: 50px auto
}
.top_ev_banner .wrap img {
	height:auto;
}
/****************/

.campaign{
	padding-bottom: 60px;
}
.campaign p:first-child{
	margin-bottom: 40px;
	-webkit-box-shadow: 1px 3px 10px 0 rgba(0,0,0,0.5);
	box-shadow: 1px 3px 10px 0 rgba(0,0,0,0.5);
}
.campaign p.btn_more a{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
	width: 300px;
	height: 60px;
	margin: auto;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	background: linear-gradient(#ffff00, #b4ff17);
	-webkit-border-radius: 12px;
	border-radius: 12px;
	-webkit-box-shadow: 1px 3px 10px 0 rgba(0,0,0,0.5);
	box-shadow: 1px 3px 10px 0 rgba(0,0,0,0.5);
}

.ie11 .campaign p.btn_more a{
	padding-top: 7px;
}

.access{
	padding-bottom: 80px;
	background: url(../img/common/bg01.png);
}
.access .map{
	width: 430px;
	height: 380px;
}
.access .map iframe{
	width: 100%;
	height: 100%;
}
.access .info{
	width: 450px;
}
.access .info h3{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	width: 100%;
	height: 40px;
	padding-left: 12px;
	margin-bottom: 14px;
	font-size: 1.6rem;
	color: #FFF;
	background: #00A5FF;
}
.ie11 .access .info h3{
	padding-top: 7px;
}
.access .info p{
	margin-bottom: 32px;
	font-size: 1.6rem;
}
.access .info p:first-child{
	margin-bottom: 40px;
	font-size: 2rem;
	font-weight: bold;
}
.access .info p a{
	font-size: 1.6rem;
	color: #0064FF;
	font-weight: bold;
}
.access .info p a span{
	color: #00A5FF;
}
.access .blue_box > div{
	width: 72%;
}
.access .blue_box > div + p{
	width: 23%;
}

.news{
	padding-bottom: 60px;
}
.news .wrap{
	max-width: 100%;
	width: 100%;
}

.calendar{
	padding-bottom: 60px;
	background: #00A5FF;
}
.calendar .calendar_block{
	width: 430px;
	/*height: 200px;*/
	padding: 24px 0 0;
	background: #333;
	border-right: 1px solid #333;
}
.calendar .calendar_block .prev a{
	position: relative;
	display: block;
	padding-left: 24px;
	margin-left: 14px;
	font-size: 1.6rem;
	color: #fff;
	font-weight: bold;
} 
.calendar .calendar_block .prev a:before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 18px;
	height: 20px;
	margin: auto;
	background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat bottom left/100% 50%, linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat top right/100% 50%;
}
.calendar .calendar_block .next a{
	position: relative;
	display: block;
	padding-right: 24px;
	margin-right: 14px;
	font-size: 1.6rem;
	color: #fff;
	font-weight: bold;
} 
.calendar .calendar_block .next a:before{
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 18px;
	height: 20px;
	margin: auto;
	background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat top left/100% 50%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat bottom right/100% 50%;
}
.calendar .calendar_block .month{
	font-size: 2rem;
	color: #FFF;
	font-weight: bold;
	text-align: center;
}
.calendar .calendar_block table{
	width: 100%;
	border-collapse: collapse;
	background: #cacaca;
}
.calendar .calendar_block table thead{
	background: #333;
}
.calendar .calendar_block table thead th{
	padding: 18px;
	font-size: 1.6rem;
	color: #fff;
	text-align: center;
}
.calendar .calendar_block table tbody td{
	padding: 18px;
	font-size: 1.6rem;
	color: #333;
	text-align: center;
	border: 1px solid #333;
}
.calendar .calendar_block table tbody td.normal{
	background: #ccedff;
}
.calendar .calendar_block table tbody td.sat{
	background: #a4f098;
}
.calendar .calendar_block table tbody td.sun{
	background: #ffff64;
}
.calendar .calendar_block table tbody td.day_off{
	background: #c5a4cc;
}
.calendar .calendar_block table tbody td.other{
	background: #f5a87c;
}
.calendar .explanation{
	width: 430px;
}
.calendar .explanation p{
	position: relative;
	padding-left: 34px;
	margin-bottom: 28px;
	font-size: 2rem;
	color: #fff;
}
.calendar .explanation p:before{
	content: "";
	position: absolute;
	top: 2px;
	left: 0;
	width: 24px;
	height: 24px;
	border: 1px solid #fff;
}
.calendar .explanation p.normal:before{
	background: #ccedff;
}
.calendar .explanation p.sat:before{
	background: #a4f098;
}
.calendar .explanation p.sun:before{
	background: #ffff64;
}
.calendar .explanation p.day_off:before{
	background: #c5a4cc;
}
.calendar .explanation p.other:before{
	background: #f5a87c;
}
.calendar .explanation p span{
	font-size: 1.6rem;
}
.calendar .small{
	margin-top: 60px;
	font-size: 1.4rem;
	color: #FFF;
	line-height: 1.8;
}
.calendar .explanation p a{
	color: #FFF;
	text-decoration: underline;
}

.service{
	background: url(../img/common/bg01.png);
}
.service .contents{
	padding-bottom: 80px;
	margin-bottom: 60px;
	border-bottom: 2px solid #00a5ff;
}
.service .contents:last-child{
	margin-bottom: 0;
	border-bottom: none;
}
.service h3{
	margin-bottom: 8px;
	font-size: 4rem;
	font-weight: bold;
	text-align: center;
}
.service h3 + p{
	margin-bottom: 56px;
	text-align: center;
}
.service .flex > div{
	width: 72%;
}
.service .flex > p{
	width: 45%;
	text-align: center;
}
.service .light_blue_box > p{
	width: 23%;
}
.service .flex > div.right{
	width: 45%;
}
.service .blue_fukidashi{
	position: relative;
	padding: 40px;
	margin-bottom: 14px;
	background: #00a5ff;
}
.service .blue_fukidashi:before{
	content: "";
	position: absolute;
	top: 0;
	left: -40px;
	bottom: 0;
	width: 40px;
	height: 40px;
	margin: auto;
	background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat bottom left/100% 50%,linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat top right/100% 50%;
}
.service .blue_fukidashi ul li{
	position: relative;
	padding-left: 18px;
	font-size: 2rem;
	color: #fff;
	font-weight: bold;
	line-height: 1.8;
}
.service .blue_fukidashi ul li:before{
	content: "";
	position: absolute;
	top: 10px;
	left: 0;
	width: 13px;
	height: 18px;
	background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat top left/100% 50%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat bottom right/100% 50%;
}
.service .blue_fukidashi + div{
	margin-bottom: 22px;
}
.service .blue_fukidashi + div + p{
	margin-bottom: 8px;
	font-size: 1.6rem;
}
.service .blue_fukidashi + div + p + ul,
.service .blue_fukidashi + div +  ul{
	margin-bottom: 8px;
}
.service .blue_fukidashi + div + p + ul li,
.service .blue_fukidashi + div + ul li{
	position: relative;
	padding-left: 18px;
	font-size: 1.6rem;
	line-height: 1.8;
}
.service .blue_fukidashi + div + p + ul li span,
.service .blue_fukidashi + div + ul li span{
	display: inline-block;
	width: 9em;
}
.service .blue_fukidashi + div + p + ul li:before,
.service .blue_fukidashi + div + ul li:before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 12px;
	height: 12px;
	margin: auto;
	background: #00a5ff;
}
.service .blue_fukidashi + div + p + ul + p.small,
.service .blue_fukidashi + div + ul + p.small{
	font-size: 1.2rem;
}
.service table{
	margin-top: 60px;
	margin-bottom: 24px;
	width: 100%;
	border-collapse: collapse;
	background: #FFF;
}
.service table thead{
	background: #333;
}
.service table thead th{
	padding: 10px;
    line-height: 1.3;
	font-size: 1.6rem;
	color: #FFF;
	text-align: center;
}
.service table thead th:first-child{
	text-align: left;
}
/*.service table thead th span{
	font-size: 1.2rem;
}*/
.service table tbody{
	border-left: 1px solid #333;
	border-right: 1px solid #333;
}
.service table tbody tr{
	border-bottom: 1px solid #333;
}
.service table tbody td{
	padding: 2px 10px 3px;
	font-size: 1.6rem;
	text-align: center;
    line-height: 1.3;
}
.service table tbody td.status{
    width: 154px;
	padding: 2px 5px 3px;
}

.service table tbody td.type{
	width: 6em;
}

.service table tbody td.number{
	width: 6em;
}

.service table tbody td.type{
	text-align: left;
}
.service table tbody td.fee{
	font-weight: bold;
}
.service table tbody td.status,
.service table tbody td.linkBtn{
	background: rgba(50,130,50,0.1);
}
.service table tbody td.status p,
.service table tbody td.linkBtn p{
	color: #328232;
	font-weight: bold;
    text-align: center;
}

.service table tbody td.status.remain .status_label,
.service table tbody td.status.little .status_label{
	color:#328232;
}

.service table tbody td.status.full .status_label{
	color:#DC4646;
}



.service table tbody td.linkBtn{
	width: 204px;
	padding: 8px 15px 8px 0;
	text-align: right;
}
.service table tbody td.linkBtn a{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	        justify-content: center;
	width: 189px;
	height: 32px;
	margin: auto;
	font-size: 1.6rem;
	color: #333;
	font-weight: bold;
	text-align: center;
	background: linear-gradient(#ffff00, #b4ff17);
	-webkit-border-radius: 6px;
	        border-radius: 6px;
	-webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.5);
	        box-shadow: 0 1px 0 0 rgba(0,0,0,0.5);
}
.ie11 .service table tbody td.linkBtn a{
	padding-top: 7px;
}
.service table tbody td.linkBtn a+a{ margin-top: 5px !important;}

.service table tbody td.linkBtn a.btn_sim{
    background: #e4e4e4 !important;
    color: #333333 !important;
    font-weight: 400 !important;
}

.service table tbody td.full.status,
.service table tbody td.full + td{
	background: rgba(220,70,70,0.1);
}
.service table tbody td.full.status p,
.service table tbody td.full + td p{ color: #DC4646;}

.service table tbody td p.scheduled_date{
    text-align: center;
    font-size: 1.6rem;
    font-weight: 400;
    color: #333333 !important;
}

.service table tbody td.full + td a,
.service table.add_room_no tbody td.full + td a,
.service table:not(.add_room_no) tbody td.full + td a{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	        justify-content: center;
	width: 189px;
	height: 36px;
	margin: auto;
	font-size: 1.6rem;
	color: #fff;
	font-weight: bold;
	text-align: center;
	background: linear-gradient(#ff9b9b, #ff629d);
	-webkit-border-radius: 6px;
	        border-radius: 6px;
	-webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.5);
	        box-shadow: 0 1px 0 0 rgba(0,0,0,0.5);
}
.ie11 .service table tbody td.full + td a,
.ie11 .service table.add_room_no tbody td.full + td a,
.ie11 .service table:not(.add_room_no) tbody td.full + td a{
	padding-top: 7px;
}
.service table tbody td.full + td a br,
.service table.add_room_no tbody td.full + td a br,
.service table:not(.add_room_no) tbody td.full + td a br{
	display: none;
}
.service table tbody td span.strikethrough{
	text-decoration: line-through;
}
.service table tbody td span.red_font{
	color: #DC4646;
}

.sp_room_num{ display: none;}

.service table + ul{
	margin-bottom: 36px;
}
.service table + ul li{
	position: relative;
	padding-left: 22px;
	font-size: 1.6rem;
	line-height: 1.8;
}
.service table + ul li a{
	color: #0064ff;
}
.service table + ul li:before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 12px;
	height: 12px;
	margin: auto;
}
.service table + ul li.blue:before{
	background: #00a5ff;
}
.service table + ul li.red:before{
	background: #dc4646;
}
.service .light_blue_box{
	padding: 40px;
	margin-bottom: 40px;
	background: #CCEDFF;
}
.service .light_blue_box p{
	font-size: 1.6rem;
	line-height: 1.8;
}
.service .light_blue_box p.fsl{
	font-size: 2rem;
	font-weight: bold;
}
.service .blue_box .youtube{
	width: 23%;
}
.service .blue_box .youtube iframe{
	width: 100%;
}

.step{
	background: #00a5ff;
}
.step .title_area{
	margin-bottom: 0;
}
.step .contents{
	padding: 58px 0;
	border-top: 2px solid #fff;
}
.step .title_area + .contents{
	border-top: none;
}
.step .contents .left{
	position: relative;
	padding-left: 50px;
}
.step .contents .left:before{
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100px;
	height: 100px;
	margin: auto;
}
.step .contents .left.first:before{
	background: url(../img/index/img_step01.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.step .contents .left.second:before{
	background: url(../img/index/img_step02.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.step .contents .left.third:before{
	background: url(../img/index/img_step03.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.step .contents .left.fourth:before{
	background: url(../img/index/img_step04.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.step .contents .left.fifth:before{
	background: url(../img/index/img_step05.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.step .contents .right{
	width: 60%;
}
.step .contents .right h3{
	margin-bottom: 16px;
	font-size: 4rem;
	color: #FFF;
	font-weight: bold;
}
.step .contents .right p{
	font-size: 1.6rem;
	color: #FFF;
	line-height: 1.8;
}
.step .contents .right ul{
	margin-top: 24px;
}
.step .contents .right ul li{
	font-size: 1.4rem;
	color: #FFF;
	line-height: 1.8;
	padding-left: 1em;
	position: relative;
}
.step .contents .right ul li:before{
	content: '※';
	position: absolute;
	left:0;
	top:0;
}

.reason{
	padding-bottom: 80px;
	background: url(../img/common/bg01.png);
}
.reason .title_area{
	margin-bottom: 0;
}
.reason .content_top01,
.reason .content_top02{
	border-bottom: 2px solid #00a5ff;
}
.reason .content_top01 .contents,
.reason .content_top02 .contents{
	width: 50%;
}
.reason .content_top01 .contents:first-child,
.reason .content_top02 .contents:first-child{
	border-right: 2px solid #00a5ff;
}
.reason .content_top01 .contents:first-child,
.reason .content_top02 .contents:first-child{
	padding: 90px 60px 60px 0;
}
.reason .content_top01 .contents:nth-child(2),
.reason .content_top02 .contents:nth-child(2){
	padding: 90px 0 60px 60px;
}
.reason .contents p:first-child{
	position: relative;
}
.reason .contents p:first-child:before{
	content: "";
	position: absolute;
	top: -60px;
	left: 0;
	right: 0;
	width: 120px;
	height: 121px;
	margin: auto;
}
.reason .content_top01 .contents:first-child p:first-child:before{
	background: url(../img/index/bg_img21.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.reason .content_top01 .contents:nth-child(2) p:first-child:before{
	background: url(../img/index/bg_img22.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.reason .content_top02 .contents:first-child p:first-child:before{
	background: url(../img/index/bg_img23.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.reason .content_top02 .contents:nth-child(2) p:first-child:before{
	background: url(../img/index/bg_img24.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.reason .content_top01 .contents p,
.reason .content_top02 .contents p{
	font-size: 1.6rem;
	line-height: 1.8;
}
.reason .content_top01 .contents p:first-child,
.reason .content_top02 .contents p:first-child{
	margin-bottom: 36px;
	line-height: 1;
}
.reason .content_top01 .contents h3,
.reason .content_top02 .contents h3{
	margin-bottom: 24px;
	font-size: 3rem;
	color: #00A5FF;
	font-weight: bold;
	text-align: center;
}
.reason .content_bottom{
	margin-top: 60px;
}
.reason .content_bottom .contents{
	margin-bottom: 30px;
}
.reason .content_bottom .contents p{
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
}
.reason .content_bottom .contents p:first-child{
	margin-bottom: 8px;
}
.reason .content_bottom .contents p span{
	font-size: 1.6rem;
}
.reason .blue_box{
	margin-top: 40px;
}
.reason .blue_box h3{
	margin-bottom: 8px;
	font-size: 3rem;
	font-weight: bold;
	text-align: center;
}
.reason .blue_box table{
	width: 100%;
	border-collapse: collapse;
}
.reason .blue_box table thead{
	background: #333;
}
.reason .blue_box table thead th{
	padding: 10px;
	font-size: 1.6rem;
	color: #FFF;
	text-align: center;
	border-bottom: 1px solid #333;
}
.reason .blue_box table thead th:first-child{
	text-align: left;
}
.reason .blue_box table thead th:last-child{
	color: #333;
	background: linear-gradient(#ffff00, #b4ff17);
}
.reason .blue_box table{
	border-top: 1px solid #333;
	border-left: 1px solid #333;
	border-right: 1px solid #333;
}
.reason .blue_box table tbody tr{
	border-bottom: 1px solid #333;
}
.reason .blue_box table tbody td{
	padding: 10px;
	font-size: 1.6rem;
	text-align: center;
	line-height: 1.6;
}
.reason .blue_box table tbody td:first-child{
	text-align: left;
}
.reason .blue_box table tbody td:last-child{
	color: #F00;
	font-weight: bold;
	background: rgba(255, 0, 0, 0.1);
}

.voice{
	padding-bottom: 80px;
	background: #00a5ff;
}
.voice .title_area p{
	font-size: 2rem;
	color: #333;
}
.voice .left,
.voice .right{
	width: 45%;
}
.voice .content_top{
	margin-bottom: 56px;
}
.voice .woman,
.voice .man{
	position: relative;
	padding-left: 70px;
}
.voice .woman + div,
.voice .man + div{
	margin-top: 48px;
}
.voice .woman:before,
.voice .man:before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 39px;
	height: 81px;
	margin: auto;
}
.voice .woman:before{
	background: url(../img/index/icon_woman.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.voice .man:before{
	background: url(../img/index/icon_man.png) no-repeat center center;
	-webkit-background-size: cover;
	     -o-background-size: cover;
	        background-size: cover;
}
.voice p{
	font-size: 1.6rem;
	color: #FFF;
	line-height: 1.8;
}

.qa{
	padding-bottom: 60px;
}
.qa .acmenu{
	padding: 0;
	border-bottom: none;
}
.qa dt{
	width: 100%;
	max-width: 100%;
	border-bottom: 2px solid #00a5ff;
}
.qa dt:first-child{
	border-top: 2px solid #00a5ff;
}
.qa .acmenu dt:after{
	width: 0;
	height: 0;
	background: none;
}
.qa dt .wrap{
	position: relative;
	padding: 18px 0;
}
.qa .acmenu dt .wrap:before{
	content: "Q";
	display: inline;
	padding: 18px 0;
	margin-right: 8px;
	font-size: 2rem;
	color: #00A5FF;
	font-weight: bold;
}
.qa .acmenu dt .wrap:after{
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 20px;
	height: 18px;
	margin: auto;
	background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat top left/50% 100%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat top right/50% 100%;
}
.qa .acmenu dt.active .wrap:after{
	background: linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat top left/50% 100%, linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat top right/50% 100%;
}
.qa dt.active{
	margin-bottom: 0;
	border-bottom: none;
}
.qa dd{
	width: 100%;
	border-bottom: 2px solid #00a5ff;
}
.qa .acmenu dd .wrap{
	padding: 0 0 18px 1.6em;
	text-indent: -1.6em;
}
.qa .acmenu dd .wrap:before{
	content: "A";
	display: inline;
	padding: 18px 0;
	margin-right: 8px;
	font-size: 2rem;
	color: #00A5FF;
	font-weight: bold;
}
.qa .acmenu dd .wrap span{
	font-weight: bold;
}

div.listmark {
	position: relative;
	text-indent: 0;
	padding-left: 1em;
}
div.listmark:before {
	content: '※';
	position: absolute;
	left:0;
	top:0;
}

@media screen and (max-width: 760px){
	.fv_01{
		position: inherit;
		width: 100%;
		height: auto;

		/*FVもとに戻すときここからコメントアウト*/
		max-width: none;
		max-height: none;
		min-width: auto;
		min-height: auto;

		padding-top: 2%;
		width: 44%;
		height: 50%;
		position: absolute;
		margin-top: 0;
		/*FVもとに戻すときここまでコメントアウト*/
	}
	.fv_02{
		top: auto;
		left: 0;
		right: 0;
		bottom: 4%;
		width: 92%;
		height: auto;
		margin: auto;
	}

	/***   ev用   ***/
	.top_ev_banner .wrap {
		margin: 6% auto
	}
	/****************/

	.campaign{
		padding-bottom: 10%;
	}
	.campaign p:first-child{
		margin-bottom: 5%;
	}
	.campaign p.btn_more a{
		width: 250px;
		height: 50px;
		font-size: 1.6rem;
	}

	.access{
		padding-bottom: 5%;
	}
	.access .wrap .flex{
		display: block;
	}
	.access .map{
		width: 100%;
		height: 280px;
		margin: 0 auto 5%;
	}
	.access .info{
		width: 100%;
	}
	.access .info h3{
		height: 25px;
		padding-left: 2%;
		margin-bottom: 1%;
		font-size: 1.4rem;
	}
	.access .info p{
		margin-bottom: 2%;
		font-size: 1.4rem;
	}
	.access .info p:first-child{
		margin-bottom: 3%;
		font-size: 1.4rem;
	}
	.access .info p a{
		font-size: 1.4rem;
	}
	.access .blue_box > div{
		width: 100%;
	}

	.news{
		padding-bottom: 5%;
	}

	.calendar{
		padding-bottom: 5%;
	}
	.calendar > .wrap > .flex{
		display: block;
	}
	.calendar .calendar_block{
		width: 100%;
		height: auto;
		padding: 5% 0 0;
		margin-bottom: 5%;
		border-right: none;
	}
	.calendar .calendar_block .prev a{
		padding-left: 20px;
		margin-left: 14px;
		font-size: 1.2rem;
	} 
	.calendar .calendar_block .prev a:before{
		width: 14px;
		height: 16px;
	}
	.calendar .calendar_block .next a{
		padding-right: 20px;
		margin-right: 14px;
		font-size: 1.2rem;
	} 
	.calendar .calendar_block .next a:before{
		width: 14px;
		height: 16px;
	}
	.calendar .calendar_block .month{
		font-size: 1.6rem;
	}
	.calendar .calendar_block table thead th{
		padding: 3%;
		font-size: 1.2rem;
		background: none;
	}
	.calendar .calendar_block table tbody td{
		padding: 4%;
		font-size: 1.2rem;
	}
	.calendar .explanation{
		width: 100%;
	}
	.calendar .explanation p{
		padding-left: 20px;
		margin-bottom: 3%;
		font-size: 1.4rem;
	}
	.calendar .explanation p:before{
		width: 12px;
		height: 12px;
	}
	.calendar .explanation p span{
		font-size: 1.4rem;
		letter-spacing: -1px;
	}
	.calendar .small{
		margin-top: 3%;
		font-size: 1.2rem;
	}

	.service .contents{
		padding-bottom: 5%;
		margin-bottom: 5%;
		border-bottom: 1px solid #00a5ff;
	}
	.service h2{
		width: 128px;
	}
	.service h3{
		margin-bottom: 3%;
		font-size: 2rem;
	}
	.service h3 + p{
		margin-bottom: 3%;
	}
	.service h3 + p + .flex{
		display: block;
	}
	.service .flex > p{
		width: 60%;
		margin: auto;
	}
	.service h3 + p + .flex > p:first-child{
		margin-bottom: 10%;
	}
	.service .flex > div.right{
		width: 100%;
	}
	.service .blue_fukidashi{
		padding: 4%;
		margin-bottom: 3%;
	}
	.service .blue_fukidashi:before{
		top: -20px;
		left: 0;
		right: 0;
		bottom: auto;
		width: 20px;
		height: 20px;
		background: linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat top left/50% 100%, linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #00a5ff 50.5%) no-repeat top right/50% 100%;
	}
	.service .blue_fukidashi ul li{
		padding-left: 1em;
		font-size: 1.4rem;
	}
	.service .blue_fukidashi ul li:before{
		top: 6px;
		width: 0.6em;
		height: 1em;
	}
	.service .blue_fukidashi + div{
		margin-bottom: 3%;
	}
	.service .blue_fukidashi + div > p{
		width: 32%;
	}
	.service .blue_fukidashi + div + p{
		margin-bottom: 2%;
		font-size: 1.2rem;
	}
	.service .blue_fukidashi + div + p + ul,
	.service .blue_fukidashi + div +  ul{
		margin-bottom: 2%;
	}
	.service .blue_fukidashi + div + p + ul li,
	.service .blue_fukidashi + div + ul li{
		padding-left: 1.2em;
		font-size: 1.2rem;
	}
	.service .blue_fukidashi + div + p + ul li:before,
	.service .blue_fukidashi + div + ul li:before{
		width: 0.8em;
		height: 0.8em;
	}
	.service .blue_fukidashi + div + p + ul + p.small,
	.service .blue_fukidashi + div + ul + p.small{
		font-size: 1.2rem;
	}
	.service table{
		margin-top: 5%;
		margin-bottom: 3%;
	}
	.service table thead th{
		padding: 2% 0;
		font-size: 0.8rem;
		line-height: 1.6;
	}
	.service table thead th span{
		font-size: 0.8rem;
	}
	.service table tbody td{
		padding: 2% 1%;
		font-size: 0.8rem;
		line-height: 1.6;
        letter-spacing: -0.05rem;
	}
    .service table thead th.type{ padding-left: 2%;}
    .service table thead th.number,
    .service table tbody td.number{ display: none;}
	.service table tbody td.type{
		padding: 2% 0 2% 1%;
        width: auto;
	}

	.service table tbody td.size{
		width: 11em;
		padding: 2% 0;
	}

	.service table tbody td.status{
		width: 9em;
		padding: 2% 0;
	}
	.service table tbody td.status p{
		font-size: 0.8rem;
	}
    .service table tbody td p.scheduled_date {
		font-size: 0.8rem;
        letter-spacing: -0.08rem;
    }
	.service table tbody td.linkBtn{
		width: 12em;
		padding: 2% 1% 2% 0;
	}

	.service table tbody td.linkBtn a,
	.service table tbody td.full + td a,
    .service table.add_room_no tbody td.full + td a,
    .service table:not(.add_room_no) tbody td.full + td a{
		display: block;
		width: 98%;
		height: auto;
		padding: 4%;
		margin: auto;
		font-size: 0.8rem;
		line-height: 1.4;
		-webkit-border-radius: 3px;
		        border-radius: 3px;
	}

	.service table tbody td.full + td a br{
		display: block;
	}

    .sp_room_num{ display: block;}

	.service table + ul{
		margin-bottom: 3%;
	}
	.service table + ul li{
		padding-left: 1em;
		font-size: 1.2rem;
	}
	.service table + ul li:before{
		top: 6px;
		bottom: auto;
		width: 0.8em;
		height: 0.8em;
	}
	.service .flex > div{
		width: 100%;
	}
	.service .light_blue_box{
		display: block;
		padding: 4%;
		margin-bottom: 4%;
	}
	.service .light_blue_box p{
		font-size: 1.4rem;
	}
	.service .light_blue_box p.sp{
		margin-bottom: 3%;
	}
	.service .light_blue_box p.fsl{
		margin-bottom: 3%;
		font-size: 1.8rem;
	}
	.service .light_blue_box p.fsl + p{
		margin-bottom: 3%;
	}
	.service .light_blue_box div + p{
		margin-left: 40px;
	}
	.service .light_blue_box p img{
		width: 100%;
	}
	.service .blue_box .youtube{
		width: 100%;
		margin-left: 0;
		margin-bottom: 3%;
	}
	.service .blue_box .youtube iframe{
		width: 100%;
		height: 100%;
	}

	.step .contents{
		padding: 5% 0;
		border-top: 1px solid #fff;
	}
	.step .contents .wrap{
		display: block;
	}
	.step .contents .left{
		padding-top: 40px;
		padding-left: 0;
		margin-bottom: 3%;
	}
	.step .contents .left img{
		width: 100%;
	}
	.step .contents .left:before{
		top: 0;
		left: 0;
		right: 0;
		bottom: auto;
		width: 75px;
		height: 75px;
	}
	.step .contents .right{
		width: 100%;
	}
	.step .contents .right h3{
		margin-bottom: 3%;
		font-size: 2rem;
		text-align: center;
	}
	.step .contents .right p{
		font-size: 1.4rem;
	}
	.step .contents .right ul{
		margin-top: 1em;
	}
	.step .contents .right ul li{
		font-size: 1.2rem;
	}

	.reason{
		padding-bottom: 5%;
	}
	.reason .content_top01 .wrap,
	.reason .content_top02 .wrap{
		display: block;
		width: 100%;
	}
	.reason .content_top01,
	.reason .content_top02{
		border-bottom: none;
	}
	.reason .content_top01 .contents,
	.reason .content_top02 .contents{
		width: 100%;
	}
	.reason .content_top01 .contents:first-child,
	.reason .content_top02 .contents:first-child{
		border-right: none;
	}
	.reason .content_top01 .contents:first-child,
	.reason .content_top02 .contents:first-child,
	.reason .content_top01 .contents:nth-child(2),
	.reason .content_top02 .contents:nth-child(2){
		padding: 50px 2.5% 2.5%;
		border-bottom: 1px solid #00a5ff;
	}
	.reason .contents p:first-child:before{
		top: -35px;
		width: 75px;
		height: 75px;
	}
	.reason .content_top01 .contents p,
	.reason .content_top02 .contents p{
		font-size: 1.4rem;
	}
	.reason .content_top01 .contents p:first-child,
	.reason .content_top02 .contents p:first-child{
		margin-bottom: 3%;
		text-align: center;
		
	}
	.reason .content_top01 .contents h3,
	.reason .content_top02 .contents h3{
		margin-bottom: 3%;
		font-size: 2rem;
	}
	.reason .content_bottom{
		margin-top: 5%;
	}
	.reason .content_bottom .contents{
		width: 48%;
		margin-bottom: 3%;
	}
	.reason .content_bottom .contents p{
		font-size: 1.4rem;
	}
	.reason .content_bottom .contents p:first-child{
		margin-bottom: 3%;
	}
	.reason .content_bottom .contents p span{
		font-size: 1.4rem;
	}
	.reason .blue_box{
		margin-top: 3%;
	}
	.reason .blue_box h3{
		margin-bottom: 3%;
		font-size: 1.4rem;
	}
	.reason .blue_box table thead th{
		padding: 2%;
		font-size: 0.9rem;
	}
	.reason .blue_box table tbody td{
		padding: 2% 1%;
		font-size: 0.8rem;
	}
	.reason .blue_box table tbody td:first-child{
		width: 7em;
	}
	.reason .blue_box table tbody td:nth-child(2),
	.reason .blue_box table tbody td:nth-child(3){
		width: 7em;
	}

	.voice{
		padding-bottom: 5%;
	}
	.voice .title_area p{
		font-size: 1rem;
	}
	.voice .content_top,
	.voice .content_bottom{
		display: block;
	}
	.voice .content_top + p{
		margin-bottom: 5%;
	}
	.voice .left,
	.voice .right{
		width: 100%;
	}
	.voice .content_top{
		margin-bottom: 0;
	}
	.voice .woman,
	.voice .man{
		position: relative;
		padding-left: 50px;
		margin-bottom: 5%;
	}
	.voice .woman + div,
	.voice .man + div{
		margin-top: 0;
	}
	.voice .woman:before,
	.voice .man:before{
		width: 36px;
		height: 75px;
	}
	.voice p{
		font-size: 1.4rem;
	}

	.qa{
		padding-bottom: 5%;
	}
	.qa dt{
		border-bottom: 1px solid #00a5ff;
	}
	.qa dt:first-child{
		border-top: 1px solid #00a5ff;
	}
	.qa dt .wrap{
		padding: 2% 0;
	}
	.qa .acmenu dt .wrap:before,
	.qa .acmenu dd .wrap:before{
		font-size: 1.4rem;
	}
	.qa dd{
		border-bottom: 1px solid #00a5ff;
	}
	.qa .acmenu dd .wrap{
		padding: 0 0 18px 1.4em;
		text-indent: -1.4em;
	}
	.qa .acmenu dt .wrap:after {
		width: 16px;
		height: 14px;
	}
}


.calendar_relative {
	position: relative;
}
#calendar_body .progress {
	position: absolute;
	width:100%;
	height: 100%;
	top: 0;
	left: 0;
	/*background-color: #fff;*/
	/*opacity: 0.5;*/
	z-index: 9999;
}
#calendar_body .progress img {
	position: absolute;
	top: 60%;
	left: 50%;
	transform: translate(-50%,-50%);
}

#calendar_body td.reserve {
	cursor: pointer;
}

#calendar_body td.reserve:hover {
	text-decoration: underline;
}