@charset "utf-8";

/*============================================================
	乗りほ〜DAY　第二階層
  ============================================================ */
/*
layout.css
color:#222222;
point color2:#00aebb
point color3:#e60020



/*--------------------------------------------------
   SECOND PAGES
 --------------------------------------------------*/  

/* BASIC
 --------------------------------------------------*/ 

/* EACH CONTENT
----------------------------------------------------*/
#info{
width: 100%;
min-height: 600px;
margin:92px auto 0;
padding:0 auto 60px !important;
background-color: #AFDFE4;
}

#facility{
width: 100%;
min-height: 600px;
margin:92px auto 0;
padding:0 auto 60px !important;
background-color: #ffffff;
}

#plan-content{
width: 100%;
min-height: 600px;
margin:92px auto 0;
padding:0 auto 60px !important;
background-color: #ffffff;
}



/*--------------------------------------------------
   INFO
 --------------------------------------------------*/
.info {
max-width: 1000px;
margin: 0 auto;
padding:45px 26px 20px;
background-color: #AFDFE4;
border-radius: 24px;
}

.info-box{
max-width: 1000px;
margin: 0 auto;
padding:45px 50px 40px;
background-color: #ffffff;
border-radius: 20px;
}
.info-box .info-date{
font-size: 1.4rem;
line-height: 1.8;
padding-bottom: 10px;
text-align: right;
}

@media screen and (max-width: 767px) {
.info-box{
margin: 0 auto;
padding:30px 25px 35px;
}
.info-box .info-date{
line-height: 1.6;
}
}	
	
.info .catego{
max-width: 650px;
margin: 0 auto 5px;
	padding-top:20px;
text-align: center;
}	

.info-body{
line-height: 1.8;
padding:15px 5px 20px;
}
@media (max-width: 767px) {
.info-body{ 
line-height: 1.7;
letter-spacing:0.07em;
}
}


@media screen and (max-width: 1024px) {	
.info {
max-width: 96%;
margin: 40px auto 0;
padding:40px 5px 15px;
background-color: #AFDFE4;
border-radius: 24px;
}
}

/* ------ HEADLINE ------ */ 
.info .list_info {
width: 100%;
margin-top:20px;
}
.info .list_info li {
margin: 0 0 15px 0;
}


/* ---------- PAGER ---------- */
.pager .pagination {
text-align: center;
margin-top: 100px;
margin-bottom: 30px;
}

.pager .pagination li {
display: inline-block;
margin: 0 2px;
padding: 0;
background:#ffffff;
width: 40px;
height: 40px;
text-align: center;
position: relative;
border-radius: 10px;
}
.pager .pagination li a{
vertical-align: middle;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
text-align: center;
display:table;
color: #222222;
text-decoration: none;
}
.pager .pagination li a span{
display:table-cell;
vertical-align:middle;
}
.pager .pagination li a:hover,
.pager .pagination li a.active{
color: #2222222;
background: #FAD73E;
border-radius: 10px;
}

@media only screen and (max-width: 767px){
.pager .pagination {
text-align: center;
margin-top: 70px;
margin-bottom: 20px;
}

.pager .pagination li{
display: none;
}
.pager .pagination li.pre,
.pager .pagination li.next{
display: inline-block;
width: 42%;
height: 46px;
text-align: center;
}
.pager .pagination li.pre a,
.pager .pagination li.next a{
width: 100%;
text-align: center;
}

.pager .pagination li.pre span::after{
content: "　前の10件へ";
}
.pager .pagination li.next span::before{
content: "次の10件へ　";
}
}
	

/*--------------------------------------------------
   FACILITY
 --------------------------------------------------*/
/* ------ SERCH ------ */
.serch-facility {
max-width: 1000px;
margin: 40px auto;
padding:40px 26px 40px;
background-color: #CDEBEE;
border-radius: 24px;
}
@media screen and (max-width:1080px){
.serch-facility {
max-width: 95%;	
}	
}		
	
.serch-facility ul{
margin: 0 auto;
}
.serch-facility li{
list-style: none;
margin: 0  5px 0 15px;
line-height: 1.4;
}


input[type="checkbox"],
input[type="radio"] {
margin-right: 0 !important; 
accent-color: #f00;
transform: scale(1.4);
}
@media screen and (max-width: 767px){
input[type="checkbox"],
input[type="radio"] {
margin-right: 5px !important; 
accent-color: #f00;
transform: scale(1.4);
}
}	
	

.freeword{
margin: 30px auto 30px !important;
text-align: center;
}
.freeword-space{
	width: 90%; 
}
@media screen and (max-width: 767px){
.freeword{
margin: 10px auto 0;
text-align: center;
}
.freeword-space{
width: 94%; 
}
}

/* ------ checkbox1 ------ */
.select-business ul li {
list-style: none;
padding: 0 5px 0 15px;
margin: 0 0 10px;
line-height: 1.4;
}

.select-business ul li {
display: block;
width: 100%;
}

@media (min-width: 768px) {
.select-business ul {
display: flex;
flex-wrap: wrap;
}
.select-business ul li {
width: 50%; /* 2列表示にする */
}
}

/* ------ checkbox2 ------ */
.select-date ul li {
list-style: none;
padding: 0 5px 0 15px;
margin: 0 0 10px;
line-height: 1.4;
}

.select-date ul li {
display: block;
width: 100%;
}

@media (max-width: 767px) {
.select-date ul {
display: flex;
flex-wrap: wrap;
}
.select-date ul li {
width: 50%; /* 2列表示にする */
}
}

@media (min-width: 768px) {
.select-date ul {
display: flex;
flex-wrap: wrap;
}
.select-date ul li {
width: 33%; /* 3列表示にする */
}
}

@media (min-width: 1081px) {
.select-date ul {
display: flex;
flex-wrap: wrap;
}
.select-date ul li {
width: 25%; /* 4列表示にする */
}
}

/* ------ RESULT ------ */
.total{
margin:-30px auto 20px;
font-size: 14pt;
text-align: center;
}
.serch-result{
width: 100%;
margin: 60px auto　0;
padding:40px 26px 40px;
background-color: #AFDFE4;
}
.shop-list{
position: relative;
font-size:15px;
word-break:break-all;
width: auto;
margin: 12px 10px;
padding:25px 24px 25px;
background-color: #ffffff;
border-radius: 20px;
}

@media screen and (max-width: 767px){
.serch-result{
margin: 60px auto　0;
padding:30px 16px 30px;
}
.shop-list{
font-size:14px;
margin: 12px 0;
padding:20px 14px 20px;
}
}

/* --- RESULT --- */
.type{
display:inline-block;
margin:0 auto;
color:#e60020;
padding:5px 20px;
text-decoration: none;
font-size:14px;
font-weight: 500;
border: #e60020 1px solid;
letter-spacing: 0.06em;
border-radius: 30px;
}

.site-icon{
margin-bottom:-10px;
padding: 0;
text-align: right;
}
.site-icon img{
margin:0;
width: 30px;
}

/* ------ shop-title ------ */
.shop-title-outer {
	background: #00919C;
	color: #fff;
	margin: 5px 0 12px;
	padding: 7px 7px 7px 12px;
	font-size: 15px;
	font-size: 1.5rem;
	letter-spacing: 0.09em;
 font-weight: 500;
	line-height: 1.4;
}
@media screen and (max-width: 767px) {
	.shop-title-outer{
		margin:5px 0 12px;
		padding: 7px 5px 7px 12px;
		font-size: 15px;
		font-size: 1.5rem;
	}
}

.shop-title-inner {
	display: flex;
	align-items: center;
}

.faci-name {
	flex: 1;
}

.faci-url {
	font-family: "BIZ UDPGothic", sans-serif;
	color: #ffffff;
	font-size: 14px;
	font-size: 1.4rem;
	letter-spacing: 0.09em;
	font-weight: 600;
	line-height: 1.4;
	background: #00919C;
}
@media screen and (max-width: 767px) {
	.faci-url{
		font-size: 14px;
		font-size: 1.4rem;
	}
}	

.faci-url-inner {
	background: #fff;
	text-align: center;
	background-color: white;
	color: #e60020;
	border-radius: 5px;
	margin: 0 0 0 5px;
	padding: 4px;
}


/*--------------------------------------------------
   FAQ
 --------------------------------------------------*/
#faq {
max-width: 1000px;
margin: 40px auto;
padding:40px 26px 40px;
}
@media screen and (max-width: 767px){
#faq {
padding:40px 15px 40px;
}
}
/* -- 02 -- */ 
.btn-user2{
display: inline-block;
position: absolute;
bottom: 10px;
right: 10px;
color:#ffffff;
background: #D40468;
font-size: 62%;
margin:0 5px 0 10px;
padding: 0.40em 2.0em ;
letter-spacing: 0.03em;
line-height: 1.6; 
font-weight: 400;
border-radius: 5px;
text-align: center;
vertical-align: bottom;
}
.btn-user2-2{
display: inline-block;
color:#ffffff;
background: #D40468;
font-size: 90%;
margin:0px 5px 0 0px !important;
padding: 0.40em 2.0em ;
letter-spacing: 0.03em;
line-height: 1.6; 
font-weight: 400;
border-radius: 5px;
}
/* -- 03 -- */ 
.btn-owner2{
display: inline-block;
position: absolute;
bottom: 10px;
right: 10px;
color:#ffffff;
background: #f3a324;
font-size: 60%;
margin:0 5px 0 10px;
padding: 0.40em 2.0em ;
letter-spacing: 0.03em;
line-height: 1.6; 
font-weight: 400;
border-radius: 5px;
text-align: center;
vertical-align: bottom;
}
.btn-owner2-2{
display: inline-block;
color:#ffffff;
background: #f3a324;
font-size: 90%;
margin:0px 5px 0 0px !important;
padding: 0.40em 2.0em ;
letter-spacing: 0.03em;
line-height: 1.6; 
font-weight: 400;
border-radius: 5px;
}

/* -- link -- */ 
.link-site a:link, .link-site a:visited{
display: inline-block;
font-size: 95%;
color: #2222222 !important;
margin: 10px 0 0;
padding:5px 15px;
letter-spacing: 0.02em;
border: 2px solid #00aebb;
font-weight: 500;
border-radius: 5px;
white-space: nowrap;
}
.link-site a:hover{
color: #FFFFFF !important;
margin: 10px 0 0;
padding:5px 15px;
letter-spacing: 0.02em;
border: 2px solid #00aebb;
background: #00aebb;
font-weight: 500;
border-radius: 5px;
white-space: nowrap;
}



/* ------ ACCODEION関連 ------ */
.accordion {
 width: 100%;
}

/* チェックボックス非表示 */
.accordion-hidden {
 display: none;
}

/* Question部分 */
.accordion-open {
  display: block;
  padding: 10px 80px 10px 50px;
  background: #AFDFE4;
  cursor: pointer;
  margin: 15px 0;
  position: relative;
	 font-size: 16px;
	 line-height: 1.6;
	 font-weight: 500 !important;
}

/* ＋アイコン */
.accordion-open::before,
.accordion-open::after {
  content: '';
  width: 20px;
  height: 3px;
  background: #000;
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translateY(-50%);
}

/* ーアイコン　 */
.accordion-open::after {
  transform: translateY(-50%) rotate(90deg);
  transition: .5s;
}

/* アコーディオンがオープンでーに */
.accordion-hidden:checked+.accordion-open:after {
  transform: translateY(-50%) rotate(0);
}

/* Anser部分 */
.accordion-inner {
  display: block;
  height: 0;
  overflow: hidden;
  padding: 0;
  opacity: 0;
  transition: 0.5s;
  /* 表示速度の設定 */
  cursor: pointer;
}

/* Anserを表示 */
.accordion-hidden:checked+.accordion-open+.accordion-inner {
  height: auto;
  opacity: 1;
  padding: 10px;
}

/* Q&A */
.accordion .Q,
.accordion .A {
  position: relative;
}

.accordion .Q::before{
  font-size: 2.4rem;
  display: block;
  position: absolute;
  top: -.5em;
  left: -1.2em;
	 right: 16em;
}
.accordion .A::before {
  font-size: 2.4rem;
	 color:#00aebb !important;
	 font-weight: 600;
  display: block;
  position: absolute;
  top: -.5em;
  left: -1.2em;
	 right: 5em;
}

.accordion .Q::before {
  content: 'Q.';
}

.accordion .A::before {
  content: 'A.';
}

.accordion .accordion-open {
  padding-left: 2.5em;
}

.accordion .accordion-hidden:checked+.accordion-open+.accordion-inner {
  height: auto;
  opacity: 1;
  padding: 10px 10px 20px 4.5em;
		font-size: 16px;
	 font-weight: normal;
	 line-height: 1.5;
}
.accordion .accordion-hidden:checked+.accordion-open+.accordion-inner img{
	max-width: 20%;
	padding-top:15px;
	}
@media (min-width: 768px) {
	.accordion .accordion-hidden:checked+.accordion-open+.accordion-inner {
  height: auto;
  opacity: 1;
  padding: 10px 10px 20px 4.0em;
}
}	
@media screen and (max-width: 767px) {
.accordion .accordion-hidden:checked+.accordion-open+.accordion-inner img{
	max-width: 50%;
	padding-top:15px;
	}	
}	
	
	
/* MOVING BUS backカラー修正
----------------------------------------------------*/ 
.moving-bus-stage2{
position: relative;
width: 100%;
height: 80px;
top: 0px;
display: block;
background-color: #ffffff;
border-bottom: solid #777 1px;
}
/*---- MOBILE ------*/
@media screen and (max-width: 767px) {
.moving-bus-stage2{
height: 66px;
}	
}	


/*--------------------------------------------------
   BUS PLAN CONTENT
 --------------------------------------------------*/

.planpage-nav{
display: inline-block;
padding: 20px 16px 55px; 
}
@media (max-width: 767px){
.planpage-nav{
display: inline-block;
padding: 0 4px 40px; 
}	
}		
	
/* PLAN01
----------------------------------------------------*/ 
#bus-plan01, #bus-plan02{
width: 100%;
margin:90px auto 0px;
text-align: center;
overflow: hidden;
}

.bus-plan01, .bus-plan02{
position: relative;
width: 100%;
height: auto;
margin: 0 auto;
padding:50px 40px 5px;
background-color: #0bb2bf;
overflow: hidden;
}
/*---- TAB ------*/
@media screen and (max-width: 1080px) {
.bus-plan01, .bus-plan02{
margin-bottom: -1px;
padding:50px 0 5px;
}
}
/*---- MOBILE ------*/
@media screen and (max-width: 767px) {
.bus-plan01, .bus-plan02{
margin-bottom:-2px;
padding:50px 0 5px;
}
}
/*---- MOBILE ------*/
@media screen and (max-width: 480px) {
.bus-plan01, .bus-plan02{
margin-bottom:-7px;
padding:50px 0 5px;
}
}
.wave{
width: 100%;
magin: 0;
padding:0;
}
/*---- MOBILE ------*/
@media screen and (max-width: 767px) {
.wave img{
width: 120% !important;
height: 140%;
}
}

.plan-intro{
width: 66%;
margin: 40px auto 20px;
text-align: left;
}
/*---- MOBILE ------*/
@media screen and (max-width: 767px) {
.wave img{
width: 80%;
}
.plan-intro{
width: 90%;
font-size: 98%;
margin: 40px auto 5px;
}
}


/* ------ TIME SCHEDULE ------ */
.schedule-wrap{
width: 100%;
max-width: 1460px;
position: relative; 
margin-right: auto; 
margin-left: auto; 
height: 100vh;
padding:0 20px;
text-align: center;
}

/* -- left -- */
.collage01{
text-align:center;
}
.collage01 img{
magin: -5px 0 0;	
max-width: 90%;
height: auto;
}
@media (max-width: 1080px) { 
.collage01 img{
max-width: 110%;
}
}		
	
#time-schedule {
max-width: 540px;
margin: 40px auto 25px;
padding:30px 20px 18px;
background-image:
	url("../img/plan/01/back_line.jpg");
background-repeat:repeat;
background-size: 120%;
background-position:top 0px left 0px;
}
.time-wrap {
font-size: 90%;
counter-reset: count;
margin: 1.2em auto 0.5em;
padding-left: 20px;
position: relative;
text-align: left;
}
.time-content {
padding: 0 0 0.3em 2.5em;
margin: 0;
position: relative;
text-align: left;
}

/*---- TABLET ------*/
@media screen and (max-width: 1280px) {
#time-schedule {
margin: 20px auto;
padding:20px 12px 5px;
}
.time-wrap {
font-size: 86%;
counter-reset: count;
margin: 0em auto 0.3em;
padding-left: 10px;
position: relative;
}
.time-content {
padding: 0 0 0.2em 2.0em;
}	
}
/*---- TABLET ------*/
@media screen and (max-width: 1080px) {
#time-schedule {
margin: 15px auto;
padding:20px 11px 5px;
}
#time-schedule img {
width: 90%;
}
.time-wrap {
font-size: 78%;
counter-reset: count;
margin: 0em auto 0.3em;
padding-left: 5px;
position: relative;
}
.time-content {
padding: 0 0 0.2em 1.9em;
}	
}	
	
/*---- MOBILE ------*/
@media screen and (max-width: 767px) {
#time-schedule {
padding:30px 15px 18px;
}
.time-wrap {
font-size: 96%;
padding:0 10px;
}
.time-content {
padding: 0 0 0.5em 2.0em;
}
}	
/*----------*/


.time-content::before {
content: "";
display: block;
width: 12px;
height: 12px;
background: #D20320;
border: solid 2px #ffffff;
border-radius: 50%;
position: absolute;
top: 3px;
left: 5px;
box-shadow: 0 0 0 1px #D20320;
}

.time-content::after {
content: "";
display: block;
height: calc(100% - 35px);
border-left: dotted 3px #90A3A3;
position: absolute;
top: 28px;
left: 11px;
}

.time-busstop {
font-size: 110%;
font-weight: normal;
}

.time-note {
margin-top: 0.4em;
padding: 0 0 1em;
line-height: 1.4;
}

.time-wrap > :last-of-type::after {
display: none;
}

/* ------ SPOT------ */
.spots{
margin: 25px 15px;
}
.spots p{
text-align: left;
}
/*---- TABLET ------*/
@media screen and (max-width: 1299px) {
.spots p{
text-align: left;
font-size: 92%;
line-height: 1.6;
}
}
.spot-outline{
padding-right: 15px;
}
@media screen and (max-width: 767px) {
.spots p{
text-align: left;
font-size: 98%;
line-height: 1.6;
}
.spot-outline{
padding: 5px 2px 20px !important;
}
}	
.benefits{
margin: 7px 5px 5px;
padding: 12px;
font-size: 98%;
color:#ffffff;
background: rgba(205,5,8,1.00);
border:double 1px rgba(205,5,8,1.00);
border-radius: 10px;
line-height: 1.5;
letter-spacing: 0.06em;
text-align: center;
}
@media screen and (max-width: 767px) {
.benefits{
margin: 18px 6px 10px;
font-size: 95%;
}
}
.border-line{
width: 100%;
padding: 25px 0 40px;
}



/* ------ PLAN INFO ------ */
.plan01-info{
width: 100%;
margin: 0px 0 0;
padding:20px 20px 18px;
overflow: hidden;
}

.plan01-info-box{
max-width: 980px;
margin: 0px auto 35px;
padding:40px 45px 25px;
border-radius: 20px;
background-color: #CDEBEE;
overflow: hidden;
}
.plan01-info-box p{
text-align: left;
}
@media screen and (max-width: 767px) {
.plan01-info{
margin-top: -20px;
padding:0 20px 20px;
}
.plan01-info-box{
margin: 0px auto 30px;
padding:20px 25px 15px;
overflow: hidden;
}
}	
	
/* -- Q&A -- */
.plan01-info dl{
margin: 30px auto;
}
.plan01-info dt{
padding-left:17px;
font-size: 1.7rem;
font-weight: 500;
color:#00A0C0;
letter-spacing: 0.08em; 
margin-bottom: 20px;
line-height: 1.6;
text-align: left;
}

.plan01-info dd{
padding: 10px 5px 4px 50px;
font-size: 1.7rem;
letter-spacing: 0.06em; 
line-height: 1.7;
border-left: none;
text-align: left;
}
.plan01-info dd a:link{
	text-decoration: underline !important;
}
.plan01-info dd a:visited { 
	text-decoration: underline !important;
}

@media screen and (max-width: 767px) {
.plan01-info dt{
padding-left:10px;
font-size: 1.6rem;
font-weight: 500;
letter-spacing: 0.08em; 
margin-bottom: 20px;
line-height: 1.6;
text-align: left;
}
.plan01-info dd{
padding: 5px 5px 4px 10px;
font-size: 1.6rem;
letter-spacing: 0.06em; 
line-height: 1.7;
border-left: none;
text-align: left;
}
}		
	
	
.chara-q{
font-family: "ＭＳ 明朝",平成明朝,serif;
display: inline-block;
width: 44px;
height: 44px;
border-radius: 50%;
font-size: 2.8rem;
color: #ffffff;
background: #00A0C0;
text-align:center !important;
line-height: 1.5;
vertical-align: bottom;
}
.chara-a{
font-family: "ＭＳ 明朝",平成明朝,serif;
display: inline-block;
width: 44px;
height: 44px;
border-radius: 50%;
font-size: 2.8rem;
color: #ffffff;
background: #E68F02;
text-align:center !important;
line-height: 1.5;
vertical-align: bottom;
}

/* PLAN02
----------------------------------------------------*/ 
/* -- left -- */
.north-map{
text-align: center;
}
.north-map img{
magin: -5px 0 0;	
max-width: 94%;
height: auto;
}
@media (max-width: 1080px) { 
.north-map img{
max-width: 105%;
}
}	
.plan-headword{
margin:24px auto -10px;
text-align: center !important;
}

.pl-attention{
	margin-top:-10px;
	margin-left:15px !important;
	margin-bottom: 20px;
	padding-left:5px !important;
 color:#DD0321 !important;
	line-height: 1.3;
	text-align: left !important;
	}
@media (max-width: 1080px) { 
.pl-attention{
	margin-top:-10px;
	margin-left:5px !important;
	padding-left:5px !important;
 color:#DD0321 !important;
	text-align: left !important;
	}
	}
@media screen and (max-width: 767px) {
.pl-attention{
	margin:0px 0 30px !important;
	padding-left:0 !important;
	color:#DD0321 !important;
	text-align: center !important;
	}
}
	
.hed-highschool img{
max-width: 800px;
margin-top:-30px;
}
@media (max-width: 1080px) { 
.hed-highschool img{
width: 100%;
}
}	

.hedomisaki img{
padding-top:5px;
}
	
	
.hedona-shops{
max-width: 940px;
margin-top:25px;
margin-left:auto !important; 
margin-right:auto!important; 
text-align: center !important;
}

/* PLAN03
----------------------------------------------------*/ 
/* -- left -- */
.chubu-map{
text-align: center;
}
.chubu-map img{
margin: 24px 0 0;	
max-width: 98%;
height: auto;
}
@media (max-width: 1080px) { 
.chubu-map img{
margin: 20px 0 0;	
max-width: 100%;
}
}	