@charset "utf-8";
/* CSS Document */

/*==================================================
下層ページ共通
================================================== */

/* =======================================
	I Placeとは
======================================= */

#about-con01{text-align: center; border-bottom: 1px solid #ccc;}
#about-con01 h3{font-size: 22px; font-weight: 200; line-height: 2.2; color:#013858;}

#about-con02{text-align: center; border-bottom: 1px solid #ccc;}
#about-con02 p{font-size: 16px; margin-bottom: 60px; line-height: 2.2; color:#013858;}
#about-con02 h3{display: block; font-size: 24px; color: #013858; font-weight: 200; margin-bottom: 50px;}
#about-con02 img{margin: 0 30px;}

#about-con03{text-align: center; border-bottom: 1px solid #ccc;}
#about-con03 dl{width: 800px; margin: 0 auto; text-align: left;}
#about-con03 dl dt{font-size: 22px; color:#013858; min-height: 36px; line-height: 36px; font-weight: 200; }
#about-con03 dl dt span {
    display: block;
    float: left;
    width: 27px;
    height: 27px;
    font-size: 20px;
    text-align: center;
    color: #fff;
    background: #013858;
    line-height: 26px;
    border-radius: 18px;
    margin-right: 10px;
    margin-top: 5px;
}

#about-con03 dl dd {
    padding: 0px 0 38px 39px;
    color: #013858;
}


@media (max-width: 767px) {
#about-con01{padding-bottom: 50px !important;}
#about-con01 h3{display: block; width: 85%; margin: 0 auto; font-size: 18px; text-align: left; line-height: 1.8;}

#about-con02{}
#about-con02 p{display: block; width: 85%; margin: 0 auto; font-size: 16px; margin-bottom: 60px; line-height: 1.8; text-align: left;}
#about-con02 h3{display: block; width: 85%; text-align: left; font-size: 20px; line-height: 1.7; color: #013858; font-weight: normal; margin: 0 auto 40px;}
#about-con02 img{width: 26%; margin: 0 10px;}

#about-con03{text-align: center; border-bottom: 1px solid #ccc;}
#about-con03 dl{width: 85%; margin: 0 auto; text-align: left;}
#about-con03 dl dt{}
#about-con03 dl dt p {
    float: left;
    width: 82%;
    font-size: 21px;
    line-height: 32px;
}
#about-con03 dl dt span {
    display: block;
    float: left;
    width: 25px;
    height: 25px;
    font-size: 19px;
    text-align: center;
    color: #fff;
    background: #013858;
    line-height: 23px;
    border-radius: 18px;
    margin-right: 8px;
    margin-top: 3px;
}
#about-con03 dl dd {
    padding: 0px 0 42px 0;
    color: #013858;
}
}

/* =======================================
	ご利用の流れ
======================================= */

#flow-con01{text-align: center; }
#flow-con01 article{width: 996px; margin: 0 auto; border:1px solid #000; position: relative;}
#flow-con01 article i{display: inline-block; width: 44px; height: 44px; line-height: 44px; border:1px solid #000; position: absolute; top:-24px; font-size: 22px; left:474px; background: #fff; font-style: normal; border-radius: 26px;}
#flow-con01 article h3{display: block; padding: 70px 30px 50px; font-size: 24px; font-weight: 200;}
#flow-con01 article p{padding: 0 50px 40px; line-height: 1.7; font-weight: 300;}

@media (max-width: 767px) {
#flow-con01{padding: 130px 0 50px !important;}
#flow-con01 article{width: 94%;}
#flow-con01 article i{left:50%; margin-left: -24px; }
#flow-con01 article h3{padding: 40px 15px 30px; font-size: 18px; }
#flow-con01 article p{padding: 0 10px 30px 10px; font-size: 16px; line-height: 1.7; text-align: left;}
}

/*==================================================
オフィスガイド（一覧）
================================================== */
#guide-list{text-align: center;}
.link-guide{width: 996px; margin: 0 auto 30px; border:1px solid #333333; text-align: left; position: relative;}
.guide-list-img{width: 140px; height: 140px; margin: 20px 30px 20px 20px; float: left;}
.guide-list-img img{width: 140px; height: 140px; object-fit: cover;}
.guide-list-basicinfo, .guide-list-price, .guide-list-equip{width: 600px; float: left;}
.guide-list-basicinfo{margin: 20px 0 0;}
.office-station{margin-bottom: 10px; font-size: 18px; font-weight: 300;}
a.guide-map{display: inline-block; background: #013858; border:1px solid #013858; color: #fff; text-decoration: none; padding: 3px 10px; line-height: 1; margin-left: 20px; font-size: 13px; border-radius: 4px;}
a.guide-map i{padding-right: 5px;}
a.guide-map:hover{background:#fff; color:#013858; }
.guide-time {
    display: inline-block;
    background: #f5f5f5;
    /* border: 1px solid #013858; */
    color: #000;
    text-decoration: none;
    padding: 8px 10px;
    line-height: 1;
    margin-left: 0px;
    font-size: 13px;
    /* border-radius: 4px; */
    line-height: 21px;
}
.guide-time i{padding-right: 5px;}
.office-name{font-weight: 300; font-size: 18px; line-height: 1.7;}
.guide-list-price{margin: 10px 0; font-size: 24px; font-weight: 300;}
.guide-list-price span{font-size: 16px;}
.guide-list-equip{margin-bottom: 20px;}
.guide-list-equip span{display: inline-block; border-radius: 2px; background: #c20b18; color: #fff; font-size: 12px; margin: 0 5px 0 0; padding: 0 5px;}
a.btn-office-list{display: inline-block; width: 75px; color: #fff; font-size: 12px; background:#013858; position: absolute; top: 0; right: 0; vertical-align: middle; text-align: center; text-decoration: none; height: 100%;}
a.btn-office-list span{position: absolute; top: 45%; left: 30px;}
a.btn-office-list:hover{background: #c20b18;}



@media (max-width: 767px) {
.link-guide{width: 90%; margin: 0 auto 25px; }
.guide-list-img{width: 100px; height: 100px; margin: 15px 20px 15px 15px; float: left;}
.guide-list-img img{width: 100px; height: 100px; object-fit: cover;}
.guide-list-basicinfo{width: 55%; float: left;}
.guide-list-basicinfo{margin: 15px 0 0;}
.office-station{margin-bottom: 10px; font-size: 14px;}
a.guide-map{display: block; width: 50%; margin-top: 5px; text-align: center; padding: 3px 0; line-height: 1; margin-left: 0; font-size: 12px; }
a.guide-map i{padding-right: 5px;}
a.guide-map:hover{background:#fff; color:#013858; }
.office-name{font-size: 15px; line-height: 1.6;}
.guide-list-price{margin: 10px 15px; font-size: 24px;width: 100%;}
.guide-list-price span{font-size: 14px;}
.guide-list-equip{margin:0 15px 15px; width: 100%;}
.guide-list-equip span{display: inline-block; border-radius: 2px; background: #c20b18; color: #fff; font-size: 12px; margin: 0 5px 0 0; padding: 0 5px;}
a.spbtn-office-list{display: block; clear: left; width: 100%; box-sizing: border-box; color: #fff; font-size: 16px; background:#013858; text-align: center; text-decoration: none; padding:15px 0; }
a.spbtn-office-list i{display: inline-block; border:1px solid #fff; width: 16px; height: 16px; line-height: 16px; border-radius: 8px; text-align: center; font-size: 10px; margin-left: 7px; font-style: normal; vertical-align: middle; }

a.spbtn-office-list:hover {
  background-color: #c20b18;
}
}

/*==================================================
オフィスガイド（詳細）
================================================== */

#guide-detail{padding: 0 0 60px;}
.topic-path{background: #f0f0f0; text-align: left !important;}
.topic-path ul{width: 1000px; margin: 0 auto; list-style: none; font-size: 12px; padding: 5px 0;}
.topic-path ul li{display: inline-block;}
.topic-path ul li a{color: inherit;}
.topic-path ul li a:hover{color: #999;}

.guide-detail-name{display: block; margin: 50px 0; font-size: 24px; font-weight: 200; line-height: 1.6;}

.guide-left{width: 640px; float: left;}
.guide-right{width: 330px; float: right;}

.guide-detail-visual img{width: 100%;}

.guide-detail-txt{margin: 30px 0;}
.guide-detail-equip span{display: inline-block; border-radius: 2px; background: #c20b18; color: #fff; font-size: 12px; margin: 0 5px 0 0; padding: 0 5px;}
.guide-detail-basicinfo{margin: 30px 0;}
.guide-detail-basicinfo table{width: 100%; box-sizing: border-box; border-top:1px solid #333; border-bottom:1px solid #333; border-collapse: collapse;}
.guide-detail-basicinfo th{width: 180px; padding: 25px 0; text-align: left; vertical-align: middle; border-bottom:1px dashed #ccc; font-weight: normal;}
.guide-detail-basicinfo td{padding: 25px 0; text-align: left; vertical-align: middle; border-bottom:1px dashed #ccc;}

.ul-riyou{margin: 0 0 0 20px;}

.guide-detail-access{margin: 30px 0; padding-bottom: 30px; border-bottom: 1px solid #333;}
.guide-detail-access h4{display: block; font-size: 18px; margin-bottom: 30px; font-weight: 300;}
.google-map iframe{width: 100%; height: 320px; margin: 25px 0 0;}

.guide-detail-attention{margin: 30px 0; padding-bottom: 30px; border-bottom: 1px solid #333;}
.guide-detail-cancel h4{display: block; font-size: 16px; font-weight: 300;}
.guide-detail-cancel ul{margin-bottom: 20px;}

/*サイドカラム*/
.guide-detail-price{border:1px solid #013858; padding: 20px; border-radius: 8px; margin-bottom: 30px;}
.price-info{font-size: 32px; font-weight: 300; }
.price-info span{display: block; font-size: 14px; padding-left: 5px;}
.kibou-form table{border-collapse: collapse; width: 100%; box-sizing: border-box; margin-bottom: 15px;}
.kibou-form table td{width: 50% !important; padding-bottom: 10px; text-align: left; vertical-align: middle;}
.kibou-form table td h3{display: block; font-size: 14px; font-weight: 300;}
.kibou-form table td input{height: 24px; background: #fff; width: 60%;}
.kibou-form p{text-align: center; border-radius: 4px; padding: 6px 0; background: #f0f0f0; }

.price{text-align: center; font-size: 36px; margin: 0;}
.price span{font-size: 14px;}

a.btn-yoyaku{display: block; text-decoration: none; font-size: 18px; color: #fff; border-radius: 6px; background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #001d5e), color-stop(0.00, #3098c8));
background: -webkit-linear-gradient(#3098c8, #001d5e);
background: -moz-linear-gradient(#3098c8, #001d5e);
background: -o-linear-gradient(#3098c8, #001d5e);
background: -ms-linear-gradient(#3098c8, #001d5e);
background: linear-gradient(#3098c8, #001d5e); text-align: center;
padding: 12px 0;
font-weight: 300;}
a.btn-yoyaku:hover{background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #000), color-stop(0.00, #3098c8));
background: -webkit-linear-gradient(#3098c8, #000);
background: -moz-linear-gradient(#3098c8, #000);
background: -o-linear-gradient(#3098c8, #000);
background: -ms-linear-gradient(#3098c8, #000);
background: linear-gradient(#3098c8, #000);}

.guide-detail-calendar{border:1px solid #013858; border-radius: 8px; margin: 25px 0;}
.guide-detail-calendar h3{display: block; text-align: center; font-size: 16px; color: #fff; padding: 10px 0; border-top-left-radius: 8px;
border-top-right-radius: 8px; background:#013858; font-weight: 300;}
.calendar{padding: 15px 15px 20px;}
.calendar h4{display: block; text-align: center; font-size: 15px; font-weight: 400; margin-bottom: 15px;}
.calendar table{width: 100%; box-sizing: border-box; border-collapse: collapse; border:1px solid #ccc;}
.calendar table thead th{font-weight: 300; text-align: center; width: 14.28%; padding: 8px 0; font-size: 12px; border:1px solid #ccc; background: #d9eaf3;}
.calendar table tbody td{font-weight: 300; text-align: center; font-size: 12px; border:1px solid #ccc;}
.calendar table tbody td a{display: block; padding: 7px 0; color: inherit;}
.calendar table tbody td a:hover{background: #c20b18; text-decoration: none; color: #fff;}
.calendar table tbody td span.past-day{display: block; padding: 7px 0; color: #999;}
.calendar table tbody td span.full-day{display: block; padding: 7px 0; color: #999; background: #f0f0f0;}

a.btn-favorite-on{display: block; border-radius: 6px; border:1px solid #c20b18; color: #c20b18; text-align: center; font-size: 15px; text-decoration: none; padding: 15px 0;}
a.btn-favorite-off{display: block; border-radius: 6px; border:1px solid #c20b18; color: #fff; background:#c20b18; text-align: center; font-size: 15px; text-decoration: none; padding: 15px 0;}
.favorite-num{display:block; text-align:center; padding-top:10px;}

@media (max-width: 767px) {
#guide-detail{padding: 0 0 60px;}
#guide-detail .contents-area{width: 100%;}
#guide-detail.sp-page{padding-top:15px !important;}
.topic-path{display: none;}

.guide-detail-name{display: block; background: #013858; color: #fff; margin: 50px 0 0; font-size: 18px; line-height: 1.6; padding: 20px 15px; text-align: left;}

.guide-left{width: 100%; float: none;}
.guide-right{display: none;}

.guide-detail-txt{width: 85%; margin: 30px auto;}
.guide-detail-equip{width: 85%; margin: 0 auto;}

.sp-contents{width: 85%; margin: 0 auto;}

.guide-detail-basicinfo{border-top:1px solid #333; border-bottom:1px solid #333;}
.guide-detail-basicinfo table{width: 85%; box-sizing: border-box;  border-collapse: collapse; border-top:none; border-bottom:none; margin: 0 auto 20px;}
.guide-detail-basicinfo th{width: 25%; }
.guide-detail-basicinfo td{}

.sp-btn-yoyaku{background-color:rgba(212,212,212,0.8); padding: 10px; position: fixed; bottom:0; z-index: 999; width: 100%; box-sizing: border-box;}
.sp-btn-yoyaku a{display: block; text-decoration: none; font-size: 18px; color: #fff; border-radius: 6px; background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #001d5e), color-stop(0.00, #3098c8));
background: -webkit-linear-gradient(#3098c8, #001d5e);
background: -moz-linear-gradient(#3098c8, #001d5e);
background: -o-linear-gradient(#3098c8, #001d5e);
background: -ms-linear-gradient(#3098c8, #001d5e);
background: linear-gradient(#3098c8, #001d5e); text-align: center;
padding: 12px 0;}

.guide-detail-calendar{margin: 0 auto 40px; width: 90%; box-sizing: border-box;}
.guide-detail-calendar h3{display: block; text-align: center; font-size: 16px; color: #fff; padding: 10px 0; border-top-left-radius: 8px;
border-top-right-radius: 8px; background:#013858; font-weight: 300;}
.calendar{padding: 15px 15px 20px;}
.calendar h4{display: block; text-align: center; font-size: 15px; font-weight: 400; margin-bottom: 15px;}
.calendar table{width: 100%; box-sizing: border-box; border-collapse: collapse; border:1px solid #ccc;}
.calendar table thead th{font-weight: 300; text-align: center; width: 14.28%; padding: 8px 0; font-size: 12px; border:1px solid #ccc; background: #d9eaf3;}
.calendar table tbody td{font-weight: 300; text-align: center; font-size: 12px; border:1px solid #ccc;}
.calendar table tbody td a{display: block; padding: 7px 0; color: inherit;}
.calendar table tbody td a:hover{background: #c20b18; text-decoration: none; color: #fff;}
.calendar table tbody td span.past-day{display: block; padding: 7px 0; color: #999;}
.calendar table tbody td span.full-day{display: block; padding: 7px 0; color: #999; background: #f0f0f0;}

.sp-btn-area{text-align: center; padding: 0 0 25px ; text-align: center; border-bottom: 1px solid #333; padding-bottom: 15px;}
.sp-btn-area a{display: inline-block !important; width: 43.5%; margin: 15px 5px 0; border:1px solid; text-decoration: none; padding: 12px 0; box-sizing: border-box; border-radius: 4px;}
.sp-btn-area a.spbtn-guide-calendar{border-color: #053957; color: #053957;}
.sp-btn-area a.spbtn-guide-favorite{border-color: #c20b18; color: #c20b18;}
.sp-btn-area a i{padding-right: 5px;}

.guide-detail-attention{margin: 20px 0; }

}

/*==================================================
カレンダーTOP
================================================== */
#calendar-top{padding: 0 0 60px !important;}
#calendar-top section.contents-area{margin-top: 50px;}
#calendar-top .guide-detail-calendar{border:none; border-radius: 0; margin: 0;}
#calendar-top .title-month{position: relative; height: 30px; line-height: 30px; margin-bottom: 15px;}
.title-month a{position: absolute; font-size: 20px; color: inherit; top:0;}
.next-cal{right: 0;}
#calendar-top .calendar{padding: 0;}
#calendar-top .calendar h4{margin-bottom: 0;}
#calendar-top .calendar table thead th{padding: 15px 0; font-size: 14px;}
#calendar-top .calendar table tbody td{font-size: 14px; }
#calendar-top .calendar table tbody td a{padding: 15px 0; height: 74px;}
#calendar-top .calendar table tbody td a:hover{background: #c20b18; text-decoration: none; color: #fff;}
#calendar-top .calendar table tbody td span.past-day{padding: 15px 0; height: 74px;}
#calendar-top .calendar table tbody td span.full-day{padding: 15px 0; height: 74px;}
.calendar table tbody td a.active{background: #c20b18; text-decoration: none; color: #fff;}

.calendar-day{width: 100%; box-sizing: border-box; border-collapse: collapse; border:1px solid #ccc;}
.calendar-day td{font-weight: 300; text-align: center; font-size: 14px; border:1px solid #ccc; text-align: right;}
.calendar-day td a{display: block; padding: 0px 5px; color: inherit; position: relative; text-decoration: none;}
.calendar-day td a:hover{background: #c20b18; text-decoration: none; color: #fff;}
.calendar-day td a span{display: block;}
.calendar-day td a i{position: absolute; left: 10px; top:45%; color:#c20b18 }
.calendar-day td a:hover i{color: #fff;}
.calendar-day td p{margin: 0 !important;}
.calendar-day td.check-time a{color: #fff; background: #c20b18; text-decoration: none; color: #fff;}
.calendar-day td.check-time a i{color: #fff;}

.calendar-day td.reserved a{background: #f0f0f0; color: #999 !important;}
.calendar-day td.reserved a i{color: #999;}

.box-calendar-day{margin: 30px 0;}
.box-calendar-day h3{display: block; text-align: center; padding: 10px 0; font-size: 16px; font-weight: 300; color: #fff; background: #c20b18;}

.box-calendar-day2{margin: 30px 0;}
.box-calendar-day2 h3{display: block; text-align: center; padding: 10px 0; font-size: 16px; font-weight: 300; color: #fff; background: #013758;}

.side-l{border-left: 1px solid #ccc; padding-left: 20px; font-size: 13px;}
.side-l h3{display: block; background:#f0f0f0; padding: 10px 0; text-align: center; font-weight: 300; font-size: 15px; margin: 20px 0;}
.calendar-side-office img{width: 80px; height: 80px; object-fit: cover; float: left; margin-right: 15px;}
.calendar-side-office h4{font-size: 13px; font-weight: 300;}
.calendar-side-date table{width: 100%; box-sizing: border-box; border-collapse: collapse;}
.calendar-side-date th{width: 90px; font-weight: normal; vertical-align: top; padding: 8px 2px; border-bottom: 1px dashed #ccc; text-align: left;}
.calendar-side-date td{vertical-align: top; padding: 8px 2px; border-bottom: 1px dashed #ccc; text-align: left;}
.side-l a.btn{margin: 25px 0; font-size: 14px; border-color:#c20b18; color: #fff !important; background: #c20b18; }
.side-l a.btn:hover{background: #fff; border-color:#000; color: #000 !important;}
.side-l a.btn-submit{margin: 25px 0; font-size: 14px; border-color:#000; color: #000 !important; background: #fff; }

@media (max-width: 767px) {
#calendar-top{padding: 50px 0  !important;}
#calendar-top .calendar table thead th{padding: 12px 0; font-size: 13px;}
#calendar-top .calendar table tbody td{font-size: 13px; }
#calendar-top .calendar table tbody td a{padding: 10px 0; height: 54px;}
#calendar-top .calendar table tbody td span.past-day{padding: 10px 0; height: 54px;}
#calendar-top .calendar table tbody td span.full-day{padding: 10px 0; height: 54px;}

.calendar-day td{font-size: 13px;}
.calendar-day td a{display: block; padding: 0px 5px;}
.calendar-day td a i{left: 5px;}

.box-calendar-day{margin: 10px 0;}
.box-calendar-day h3{font-size: 15px;}

#calendar-top .guide-right{display: block; float: none; width: 100%;}

.side-l{border-left: none; padding-left: 0; font-size: 13px; padding-top: 0;}
.side-l h3{margin: 15px 0;}

}


 
/*==================================================
ご予約内容の確認
================================================== */
#reserve-confirm{text-align: center; padding: 0 0 60px 0;}
#reserve-confirm .title-contents{margin-top: 60px;}
.reserve-confirm-table{width: 100%; box-sizing: border-box; border-collapse: collapse;}
.reserve-confirm-table th{width: 120px; font-weight: normal; vertical-align: top; padding: 12px 2px; border-bottom: 1px dashed #ccc; text-align: left;}
.reserve-confirm-table td{vertical-align: top; padding: 12px 2px; border-bottom: 1px dashed #ccc; text-align: left;}

#reserve-confirm .side-l{border: none;}
#reserve-confirm .side-l a.btn{margin: 0;}

@media (max-width: 767px) {
#reserve-confirm{padding: 50px 0  !important;}
#reserve-confirm .guide-right{display: block; float: none; width: 100%; margin-top: 20px;}
}

/*==================================================
決済方法選択
================================================== */
#pay-select{padding: 0 0 60px !important;}
#pay-select section.contents-area{margin-top: 50px;}
#pay-select section.contents-area p{text-align: center; margin: 0 0 50px; font-size: 23px;color:#013858;font-weight:300;}
#pay-select section.contents-area article {
    position: relative;
    width: 303px;
    height: 477px;
    float: left;
    border: solid 1px #013758;
    padding: 7px;
    background-color: #fcfeff;
    line-height: 24px;
    /* margin: 0 auto; */
}


#pay-select section.contents-area article.pay-method02{margin: 0 20px;}
.pay-method-ex{text-align: center; margin: 7px 0;}
.pay-method-ex h3{display: block; font-size: 15px; font-weight: 300; margin-bottom: 12px;border-bottom:solid 1px #013758;}
.pay-method-ex ul{text-align: left; margin: 23px 20px ;}
.pay-method-ex li {
    margin-bottom: 10px;
    }

@media screen and (max-width: 767px) {
#pay-select{padding: 50px 0  !important;}
#pay-select section.contents-area p{text-align: center; margin: 0 0 30px; font-size: 16px;color:#013858;font-weight:300;}
#pay-select section.contents-area article {
    width: 94%;
    float: none;
    margin: 0 auto;
    height: 58vh;
}

#pay-select section.contents-area article.pay-method02{margin: 50px auto !important;}
.pay-method-ex{text-align: center; margin: 20px 0;}
.pay-method-ex h3{font-size: 18px; font-weight: 300; margin-bottom: 10px;border-bottom:solid 1px #013758;}
.pay-method-ex ul{text-align: left; margin: 20px 30px ;}
}

@media screen and (max-width:360px){
	
#pay-select section.contents-area article {
    height: 79vh;
}
}

/*==================================================
会員情報
================================================== */
#member-select{padding: 0 0 60px !important;}
#member-select section.contents-area{margin-top: 50px;}
#member-select section.contents-area p{text-align: center; margin: 0 0 50px; font-size: 23px;color:#013858;font-weight:300;}
#member-select section.contents-area article {
    width: 290px;
    float: left;
    border: solid 1px #013758;
    padding: 7px;
    background-color: #fcfeff;
    line-height: 25px;
}

#member-select section.contents-area article.member-method02{margin: 0 40px;}
.member-method-ex{text-align: center; margin: 7px 0;}
.member-method-ex h3{display: block; font-size: 15px; font-weight: 300; margin-bottom: 12px;border-bottom:solid 1px #013758;}
.member-method-ex ul{text-align: left; margin: 23px 20px ;}

@media (max-width: 767px) {
#member-select{padding: 50px 0  !important;}
#member-select section.contents-area p{text-align: center; margin: 0 0 30px; font-size: 16px;color:#013858;font-weight:300;}
#member-select section.contents-area article {
    width: 94%;
    float: none;
    margin: 0 auto;
}
#member-select section.contents-area article.member-method02{margin: 50px auto !important;}
.member-method-ex{text-align: center; margin: 20px 0;}
.member-method-ex h3{font-size: 18px; font-weight: 300; margin-bottom: 10px;border-bottom:solid 1px #013758;}
.member-method-ex ul{text-align: left; margin: 20px 30px ;}
}


.midashi {
  position: relative;
  padding: 0.25em 1em;
  border-top: solid 1px #013858;
  border-bottom: solid 1px #013858;
}
.midashi:before, .midashi:after {
  content: '';
  position: absolute;
  top: -7px;
  width: 1px;
  height: -webkit-calc(100% + 14px);
  height: calc(100% + 14px);
  background-color: #013858;
}
.midashi:before {
  left: 7px;
}
.midashi:after {
  right: 7px;
}

#pay-select section.contents-area article.pay-method02{margin: 0 20px;}
.pay-method-ex{text-align: center; margin: 7px 0;}
.pay-method-ex h3{display: block; font-size: 15px; font-weight: 300; margin-bottom: 12px;border-bottom:solid 1px #013758;}
.pay-method-ex ul{text-align: left; margin: 23px 20px ;}
.pay-method-ex li {
    margin-bottom: 10px;
    }

@media (max-width: 767px) {
#pay-select{padding: 50px 0  !important;}
#pay-select section.contents-area p{text-align: center; margin: 0 0 30px; font-size: 16px;color:#013858;font-weight:300;}
#pay-select section.contents-area article {
    width: 94%;
    float: none;
    margin: 0 auto;
    height: 64vh;
}
#pay-select section.contents-area article.pay-method02{margin: 50px auto !important;}
.pay-method-ex{text-align: center; margin: 20px 0;}
.pay-method-ex h3{font-size: 18px; font-weight: 300; margin-bottom: 10px;border-bottom:solid 1px #013758;}
.pay-method-ex ul{text-align: left; margin: 20px 30px ;}
}


@media screen and (max-width:360px){
	
#pay-select section.contents-area article {
    height: 79vh;
}
}

/*==================================================
請求書払い
================================================== */
#seikyusho{padding: 0 0 60px !important;}
#seikyusho section.contents-area{margin-top: 50px;}
#seikyusho section.contents-area .title-contents{margin-bottom: 30px;}
#seikyusho section.contents-area h4{display: block; font-size: 18px; font-weight: 300; margin: 30px 0;}
#seikyusho section.contents-area p{}
.seikyusho-att{padding: 30px 50px; border-radius: 6px; background: #f0f0f0;}
.seikyusho-att h3{display: block; margin: 0 0 25px; font-size: 15px; font-weight: 300;}
.seikyusho-att ul{margin: 0 20px ;}
.seikyu-list{border-top: 1px solid #ccc; padding-top: 30px; margin-top: 30px;}
.seikyu-list h4{margin-top: 0 !important;}
.seikyu-list table{width: 100%; box-sizing: border-box; border:1px solid #ccc; border-collapse: collapse;}
.seikyu-list thead th{background: #f0f0f0; text-align: center; vertical-align: middle; padding: 15px 10px; font-weight: normal; border:1px solid #ccc; box-sizing: border-box;}
.seikyu-list td{text-align: center; vertical-align: middle; padding: 15px 10px; border:1px solid #ccc; box-sizing: border-box;}
.seikyu-list td a.btn{border-radius: 0; padding: 5px 0;}

@media (max-width: 767px) {
#seikyusho{padding: 50px 0  !important;}
.seikyusho-att{padding: 20px 30px; }
.box-seikyu-list{width: 100%; overflow-x: auto; padding-bottom: 10px; -webkit-overflow-scrolling: touch;}
.seikyu-list table{width: 920px;}
}

/*==================================================
請求先登録
================================================== */
#seikyu-touroku{text-align: center; padding-bottom: 60px;}
#seikyu-touroku input[type="number"], #regi-form input[type="date"]{width: 20%;}
@media (max-width: 767px) {
#seikyu-touroku{text-align: center; padding-bottom: 60px !important;}
}

/*==================================================
お客様情報入力
================================================== */
#customer-info{padding: 0 0 60px !important;}
#customer-info section.contents-area{margin-top: 50px;}
#customer-info section.contents-area .title-contents{margin-bottom: 30px;}
#customer-info section.contents-area h4{display: block; font-size: 18px; font-weight: 300; margin: 30px 0;}
.reserve-pic{width: 100px; float: left;}
.reserve-pic img{width: 100px; height: 100px; object-fit: cover;}
.reserve-txt{width: 850px; float: right; margin-bottom: 30px;}
.reserve-txt h4{margin-top: 0 !important;}
.confirm-price{width: 100%; box-sizing: border-box; border:1px solid #ccc; border-collapse: collapse;}

.reserve-txt2{margin-bottom: 30px;}
.confirm-price thead th{background: #f0f0f0; text-align: center; vertical-align: middle; padding: 15px 10px; font-weight: normal; border:1px solid #ccc; box-sizing: border-box;}
.confirm-price td{text-align: center; vertical-align: middle; padding: 15px 10px; border:1px solid #ccc; box-sizing: border-box;}
#customer-info h3{display: block; border-bottom: 1px solid #ccc; font-size: 18px; padding: 5px 10px; font-weight: 300; margin-bottom: 30px;}
.goukei{background: #f0f0f0; padding: 12px 15px; text-align: right; margin: 25px 0 40px;}
#customer-info .form-basic{width: 960px; margin: 50px auto 0;}

@media (max-width: 767px) {
#customer-info{padding: 50px 0  !important;}
.reserve-pic{width: 80px; float: left; margin-right: 15px;}
.reserve-pic img{width: 80px; height: 80px;}
.reserve-txt{width: 100%; float: none; margin-bottom: 30px;}
#customer-info .form-basic{width: 100%; margin: 30px auto 0;}
}

/*==================================================
最終確認画面
================================================== */
#confirm{padding: 0 0 30px !important; text-align: left;}
#confirm section.contents-area{margin-top: 50px;}
#confirm section.contents-area .title-contents{margin-bottom: 30px;}
#confirm section.contents-area h4{display: block; font-size: 18px; font-weight: 300; margin: 30px 0;}
#confirm h3{display: block; font-size: 18px; padding: 5px 10px; font-weight: 300; margin-bottom: 30px;margin-top: 20px;}
#confirm-att{border-radius: 6px; background: #f0f0f0; padding: 20px 25px; margin: 0 auto 30px;}
#confirm-att .title-type01{border-bottom: none; border-left: 10px solid #052a4b; padding: 3px 7px; }
#confirm-att .guide-detail-attention{border-bottom: none;}
#confirm-att .guide-detail-cancel h4{font-size: 15px !important;}
#confirm-check {
    text-align: center;
    /* float: left; */
    margin: 0px auto;
    width: 50%;
}

#confirm-check .btn{display: block; margin: 0px auto; font-size: 14px; border:1px solid #c20b18; color: #fff !important; background: #c20b18; }
#confirm-check .btn2{display: block; margin: 25px auto; font-size: 14px; border:1px solid #013758; color: #fff !important; background: #013758; }
#confirm-check .btn:hover{background: #fff; border-color:#000; color: #000 !important;}

#confirm-check2{
	
    text-align: center;
    margin: 0px 5px;
}
#confirm-check2 .btn{display: block; margin: 25px auto; font-size: 14px; border:1px solid #c20b18; color: #fff !important; background: #c20b18; }
#confirm-check2 .btn2{display: block; margin: 25px auto; font-size: 14px; border:1px solid #013758; color: #fff !important; background: #013758; }
#confirm-check2 .btn:hover{background: #fff; border-color:#000; color: #000 !important;}
#confirm-check3 {
    text-align: center;
    /* float: left; */
    margin: 0px auto;
    width: 30%;
	padding: 20px 0;
}

#confirm-check3 .btn{display: block; margin: 0px auto; font-size: 14px; border:1px solid #c20b18; color: #fff !important; background: #c20b18; }
#confirm-check3 .btn2{display: block; margin: 25px auto; font-size: 14px; border:1px solid #013758; color: #fff !important; background: #013758; }
#confirm-check3 .btn:hover{background: #fff; border-color:#000; color: #000 !important;}

@media (max-width: 767px) {
#confirm{padding: 15px 0  !important;}
#confirm-att{padding: 10px; margin: 0 auto 20px;}
	#confirm-att .sp-contents{width: 90%;}
#confirm-att .guide-detail-cancel h4{font-size: 15px !important; }
#confirm-check{

	font-size: 13px;
    float: inherit;
    margin: auto;
	width: 80%;
}
#confirm-check .btn{width: 100%; padding: 15px 0;}
	
	
#confirm-check2{

	font-size: 13px;
    float: inherit;
    margin: auto;
}
#confirm-check2 .btn{width: 100%; padding: 15px 0;}	
	
#confirm-check3{

	font-size: 13px;
    float: inherit;
    margin: auto;
	width: 80%;
	padding: 20px 0;
}
#confirm-check3 .btn{width: 100%; padding: 15px 0;}

}





/*==================================================
予約完了
================================================== */
#reserve-fin{padding: 0 0 60px !important;}
#reserve-fin section.contents-area{margin-top: 50px;}
#reserve-fin section.contents-area .title-contents{margin-bottom: 30px;}
#reserve-fin section.contents-area h4{display: block; font-size: 18px; font-weight: 300; margin: 30px 0;}
#reserve-fin h3{display: block; border-bottom: 1px solid #ccc; font-size: 18px; padding: 5px 10px; font-weight: 300; margin-bottom: 30px;}

@media (max-width: 767px) {
#reserve-fin{padding: 50px 0  !important;}
}
/*==================================================
お知らせ一覧
================================================== */

#info-list{text-align: center !important;}
#info-list #con-topics{padding: 0;}

/*==================================================
お知らせ詳細
================================================== */

#info-detail{padding: 0 0 60px;}
.info-entry{text-align: left !important; width: 800px !important; margin: 0 auto !important;}
.info-entry i{margin-left: 10px !important;}
.entry-date{margin-bottom: 15px;}
.entry-title{font-weight: 200 !important;}
.entry-link{border-top: 1px solid #ccc; padding: 0; margin-top: 60px; position: relative;}
.entry-link a{position: absolute; top: 30px; color: inherit; text-decoration: none; font-size: 13px; }
.entry-link a:hover{text-decoration: underline;}
.entry-link-prev{left: 0;}
.entry-link-next{right: 0;}

@media (max-width: 767px) {
.info-entry{width: 85% !important;}
.entry-link{border-top: 1px solid #ccc; padding: 0; margin-top: 50px; position: relative; min-height: 60px;}
.entry-link a{position: absolute; top: 20px; color: inherit; text-decoration: none; font-size: 12px; }
.entry-link a:hover{text-decoration: underline;}
.entry-link-prev{left: 0;}
.entry-link-next{right: 0;}
}

/*==================================================
お問い合わせ
================================================== */

#contact-con01{text-align: center;}
.form-basic{width: 800px; margin: 0 auto 50px; text-align: left;}
.form-basic dt{border-left: 10px solid #052a4b; padding: 3px 7px;}
.form-basic dt span{display: inline-block; border-radius: 4px; padding: 2px 5px; font-size: 12px; color: #fff; background: #c20b18; margin-left: 12px;}
.form-basic dd{margin: 20px 0 30px;}
.form-basic dd span{display: inline-block; margin-left: 15px; font-size: 12px;}


@media (max-width: 767px) {
#contact-con01{padding-bottom: 50px !important;}
.form-basic{width: 85%; text-align: left;}
.form-basic dt{line-height: 1.7;}
.form-basic dd p{display: block; width: 95%; margin-left: 0; margin-top: 10px;}
}

/*==================================================
新規会員登録
================================================== */
#regi-form{text-align: center; padding-bottom: 60px;}
#regi-form input[type="number"],
#regi-form input[type="date"]{width: 20%;}
#regi-form .half, #regi-form input[type="date"]{width: 20%;}

@media (max-width: 767px) {
#regi-form input[type="date"]{width: 90% }
#regi-form .half, #regi-form input[type="date"]{width: 40%;}
}

/* 入力エラーのスタイル */
input[type=text]:required,
input[type=email]:required,
input[type=email]:invalid,
input[type=tel]:required,
textarea:required {
	color: #630015;
	border-color: #c20c33;
	background-color: #ffd9e1;
}

/* 入力値が正常な時のスタイル */
input[type=text]:valid,
input[type=email]:valid,
input[type=tel]:valid,
textarea:valid {
	color: #333;
	border-color: #ccc;
	background: #fff;
}

/*==================================================
会員ログイン
================================================== */
#login .contents-area{width: 900px;}
.login-left{width: 560px; float: left;}
.login-right{width: 250px; float: right; border-radius: 6px; padding: 25px; background: #f0f0f0;}
#login .form-basic{width: 100%;}
#login input[type="email"]{width: 70%;}
#login input[type="password"]{width: 50%;}
.login-remember{margin-bottom: 20px;}
.login-right h3{display: block; font-weight: 300; font-size: 16px; border-left: 5px solid #333; padding: 0 0 0 5px; line-height: 1.2; }
.login-right a{display: block; margin: 10px 10px 20px; color: #015c91; font-size: 13px; text-decoration: none;}
.login-right a:hover{color: #c20b18; text-decoration: underline;}
.login-right a:before{content: "▶︎"; font-size: 10px; padding-right: 0;}

@media (max-width: 767px) {
#login .contents-area{width: 85%;}
#login .title-contents{text-align: center;}
.login-left{width: 100%; float: none;}
.login-right{width: 100%; float: none; padding: 20px 20px 10px; box-sizing: border-box; margin: 40px 0;}
#login .form-basic{width: 100%;}
#login input[type="email"]{width: 95%;}
#login input[type="password"]{width: 50%;}
#login input[type="submit"]{width: 100%;}
.login-remember{margin-bottom: 30px;}
.login-right h3{font-size: 15px;}
}

/*==================================================
プライバシーポリシー
================================================== */
#privacy{text-align: center; padding-bottom: 60px; font-size: 14px;}
#privacy .contents-area{width: 800px; text-align: left;}
#privacy h3{display: block; font-size: 15px; font-weight: 300;}
#privacy p{margin:0 0 30px; line-height: 1.8;}
#privacy ol{margin: 0 30px 30px;}
.txt-privacy{text-align: right;}

@media (max-width: 767px) {
#privacy{font-size: 13px;}
#privacy .contents-area{width: 90%; }
#privacy ol{margin: 0 0 30px 20px;}
}

/*==================================================
マイページ
================================================== */
#mypage{padding: 50px 0;}
#mypage .title-contents{margin-bottom: 40px;}

#mypage .title-contents2 {
    display: block;
    margin-bottom: 60px;
    font-size: 28px;
    font-weight: 200;
    position: relative;
    color: #013858;
	text-align: center;
}
.mypage-header {
    height: 79px;
    padding: 10px 0;
    background: #013858;
}
#mypage .title-contents2 span {
    display: block;
    font-size: 12px;
    margin-top: 0;
    font-weight: 400;
    color: #013858;
}

.mypage-header h1{display: block; width: 122px; height: 67px; float: left;}
.login-info {
    width: 12%;
    float: left;
    text-align: center;
    font-size: 13px;
    padding-top: 19px;
    color: #fff;
}
.logo-maypage{
	 width: 8%;
    float: left;
    padding: 0px 25px 0px 0px;
}
.mypage-header-btn{width: 560px; height: 67px; float: right; text-align: right;}
.mypage-header-btn a {
    display: inline-block;
    border-radius: 4px;
    width: 75px;
    height: 55px;
    padding-top: 12px;
    margin: 0 5px;
    text-decoration: none;
    text-align: center;
    border: 1px solid #fff;
    font-size: 10px;
    color: #fff;
}
.mypage-header-btn a:hover{background: #c20b18; color: #fff;}
.mypage-header-btn a i{display: block; font-size: 28px;}

#mypage-top-history{margin-top: 60px;}

.mypage-list-btn {
    /* float: right; */
    margin-top: 0px;
    margin-bottom: 16px;
}

.mypage-list-btn a {
    position: relative;
    display: block;
    color: #013858;
    border-radius: 4px;
    border: 1px solid #013858;
    padding: 6px 33px;
    /* margin-right: 10px; */
    text-decoration: none;
    font-size: 12px;
    margin: 12px 11px -2px 797px;
    text-align: center;
    width: 12%;
    /* height: 17px; */
}


.mypage-list-btn a:hover{background:#013858; color: #fff; }

#mypage .form-basic{width: 100%;}


#mypage .form-basic2 {
    width: 100%;
    margin: 0 auto 50px;
    text-align: center;
}

#mypage-account input[type="number"]{width: 20%;}
#mypage-account .half{width: 20%;}

#mypage #top-con01{padding: 20px 0 30px; background: #f5f4f4; margin-bottom: 50px;}

@media (max-width: 767px) {
#mypage{padding-top: 30px !important; margin-bottom: 100px;}
#mypage .contents-area{width: 85%;}
#mypage .link-guide{width: 100%;}
.sp-mypage-header {
    position: relative;
    /* border-bottom: 1px solid #000; */
    height: 65px;
    background: #005d91;
}
.sp-mypage-header h1 img{height: 50px; margin-top: 10px; margin-left: 10px;}
a.sp-mypage-contact{display: inline-block; border-radius: 4px; width: 50px; height: 43px; padding-top: 7px; text-decoration: none; text-align: center; border:1px solid #000 ; font-size: 10px; color: #000; position: absolute; top:9px; right:10px;}
a.sp-mypage-contact i{display: block; font-size: 20px;}
.login-info.login-info {
    height: 50px;
    width: auto;
    float: none;
    padding-top: 0;
    position: absolute;
    top: 10px;
    right: 4%;
}
.sp-mypage-menu {
    position: fixed;
    bottom: 0;
    width: 100%;
    background: #ffffff;
    text-align: center;
    z-index: 99;
}

.sp-mypage-menu li{display: inline-block;}
.sp-mypage-menu li a {
    display: inline-block;
    line-height: 1.1;
    margin: 10px 5px;
    border-radius: 4px;
    width: 56px;
    height: 43px;
    padding-top: 7px;
    text-decoration: none;
    text-align: center;
    border: 1px solid #052a4b;
    font-size: 10px;
    color: #052a4b;
}
.sp-mypage-menu li a i{display: block; font-size: 18px;}
.mypage-list-btn{float: none; text-align: center; border-top: 1px dashed #ccc; margin: 15px 0; padding-top: 15px; clear: left;}
.mypage-list-btn a {
    width: 81%;
    padding: 5px 20px;
    margin: 10px auto;
}
#mypage-account a.btn-detail, #mypage-top-history a.btn-detail{display: block; text-align: center; width: 80%; margin: 0 auto; padding: 0px 0;}
#mypage-account input[type="submit"]{width: 100%;}
#mypage-top-history{margin-top: 30px;}
#mypage #top-con01{padding: 15px 0 20px; margin-bottom: 30px;}
#mypage-account .half{width: 40%;}
	
	

#mypage .title-contents2 {
    display: block;
    margin-bottom: 40px;
    font-size: 24px;
}

}

.sticky {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
}

/*==================================================
ご利用時間
================================================== */



.cp_ipselect {
	overflow: hidden;
	width: 90%;
	margin: 0 auto;
	text-align: center;
}
.cp_ipselect select {
	width: 100%;
	padding-right: 1em;
	cursor: pointer;
	text-indent: 0.01px;
	text-overflow: ellipsis;
	border: none;
	outline: none;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
}
.cp_ipselect select::-ms-expand {
    display: none;
}
.cp_ipselect.cp_sl03 {
	position: relative;
	border-radius: 2px;
	border: 2px solid #013758;
	background: #ffffff;
}
.cp_ipselect.cp_sl03::before {
	position: absolute;
	top: 1.4em;
	right: 0.8em;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #013758;
	pointer-events: none;
}
.cp_ipselect.cp_sl03 select {
	padding: 8px 38px 8px 8px;
	color: #013758;
}	
/*==================================================
スクロール
================================================== */
div.example {
  width: 100%;
  height: 400px;
  background-color:#fff;
  overflow: scroll;
	}

div.example2 {
  width: 100%;
  height: 300px;
  background-color:#fff;
  overflow: scroll;
	}


.tyuigaki{
	
	color: #BA1D20;
	font-size: 12px;
	margin: 8px 0 0px
}

span.guide-taime {
    display: inline-block;
    background: #efefef;
    /* border: 1px solid #013858; */
    color: #000;
    text-decoration: none;
    padding: 3px 10px;
    line-height: 1;
    margin-left: 20px;
    font-size: 13px;
    /* border-radius: 4px; */
}
.idea{
    max-width: 217px;
    margin: 0 auto;
    text-align: left;
    font-size: 22px;
    line-height: 3rem;
    color: #033857;
}



@media (max-width: 767px){
span.guide-taime {
    display: block;
    width: 86%;
    margin-top: 12px;
    text-align: center;
    padding: 3px 0;
    line-height: 1;
    margin-left: 0;
    font-size: 12px;
    line-height: 18px;
}
	
.idea {
    max-width: 100%;
    margin: 0px 29px;
    text-align: left;
    font-size: 18px;
    line-height: 2.5rem;
    color: #033857;
}
}
.btn_pg{
	
	padding: 15px 0;
	
}