@charset "utf-8";

#newsflash{display: none !important;}
.card-plan-01:hover{
    background: #fff;
}
.card-plan-01{
	min-height: 0!important;}

/* PC <--> SP
-------------------------------------- */
@media all and (max-width: 767px) { .viewpc { display: none !important; } }
@media all and (min-width: 768px) { .viewsp { display: none !important; } }
@media all and (min-width: 992px) { .viewsptab { display: none !important; } }

/* Clearfix
-------------------------------------- */
#restaurantbus-container .cf:after { content: ''; display: block; clear: both; }

/* Margin
-------------------------------------- */
.mt10 { margin-top: 10px; }
.mt15 { margin-top: 15px; }
.mt30 { margin-top: 30px; }
.mt40 { margin-top: 40px; }

/* Padding
-------------------------------------- */
.pb50 { padding-bottom: 50px; }

/* Flexbox [ align-items & justify-content Center ]
-------------------------------------- */
#restaurantbus-container .flex-xy-center { display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }

/* Campaign Banner
-------------------------------------- */
/*#newsflash-campaign{ display: none !important; }*/

/* #restaurantbus-container Common Style
================================================ */
#restaurantbus-container img { width: 100%; }


/* Font */
#restaurantbus-container, #restaurantbus-container .font-go { color: #000; font-size: 14px;font-weight: 500; }
#restaurantbus-container .font-min { font-family: "游明朝体", YuMincho, "游明朝", "Yu Mincho", "Hiragino Mincho ProN", Georgia, "HGS明朝E", "メイリオ", serif; font-weight: normal; }
#restaurantbus-container .color-red { color: #d31f27; }
#restaurantbus-container em { font-style: normal; }
#restaurantbus-container .color-white { color: #fff; }
#restaurantbus-container .font-w-bold { font-weight: bold;}

/* Container */
#restaurantbus-container .container-fluid { padding: 0; }
#restaurantbus-container .row-12 { margin-left: -6px; margin-right: -6px; }
@media all and (min-width: 1200px) { #rest.details-menu-titleaurantbus-container .container { max-width: 1220px; }
    #restaurantbus-container .container.container-1000 { max-width: 1000px; } }
@media all and (min-width: 768px) { #restaurantbus-container .container { padding: 0; } 
    #restaurantbus-container .row-md-20 { margin-left: -10px; margin-right: -10px; } }
@media all and (min-width: 992px) { #restaurantbus-container .row-lg-60 { margin-left: -30px; margin-right: -30px; } }

/* links */
#restaurantbus-container a { color: #000; }
#restaurantbus-container a:hover { text-decoration: none; }
#restaurantbus-container .txtlink { padding: 10px 10px 7px; border-bottom: solid 1px #000; font-size: 12px; line-height: 2.6; }
#restaurantbus-container .txtlink:hover { color: #000; opacity: .7; }
#restaurantbus-container .txtlink:active, #restaurantbus-container .txtlink:focus { text-decoration: none; }
@media all and (min-width: 768px) { #restaurantbus-container .txtlink { font-size: 14px; } }

/* Buttons */
#restaurantbus-container .btn { width: 100%; color: #fff; }
#restaurantbus-container .btn-primary { display: block; margin: 0 auto; background: #d31f27; border: none; border-radius: 50rem; font-weight: bold; font-size: 14px;}
#restaurantbus-container .btn-primary.btn-stop { background: #666;}

#restaurantbus-container .btn-primary.btn-waku { background: #fff;border: solid 3px #d31f27;color: #d31f27;}
#restaurantbus-container .btn-primary.btn-gold { background: #fff;border: solid 3px #a58a2f;color: #a58a2f;}
#restaurantbus-container .btn-primary:hover { opacity: .7; }
#restaurantbus-container .card .btn-primary:hover { opacity: 1; }
#restaurantbus-container .btn-primary:active, #restaurantbus-container .btn-primary:focus { border: none; box-shadow: none; outline:none;}
#restaurantbus-container .btn-secondary { display: block; max-width: 300px; margin: 0 auto; background: #000; border: none; border-radius: 50rem; font-weight: bold; font-size: 14px;}
#restaurantbus-container .btn-secondary:hover { background: #222;}
#restaurantbus-container .btn-secondary:active, #restaurantbus-container .btn-secondary:focus { border: none; box-shadow: none; outline:none;}
#restaurantbus-container .btn-secondary.btn-restaurantbus-pagetop { padding: 22px 15px; max-width: 300px; border-radius: 0; box-sizing: border-box; line-height: 1;}
#restaurantbus-container .btn-secondary.btn-restaurantbus-pagetop img.btn-logo-restaurantbus { display: inline-block; margin-right: 20px; width: 162px; border-radius: 0; }
.btn-primary.btn-stop-gray { background: #999!important;pointer-events: none!important;color: #FFF!important;text-align: center!important;}
.link-stop{pointer-events: none!important;}
@media all and (min-width: 768px) { #restaurantbus-container .btn-primary { font-size: 16px; }
    #restaurantbus-container .btn-secondary.btn-restaurantbus-pagetop { font-size: 16px; } }

/* Card */
#restaurantbus-container .card dt{position: relative;}
#restaurantbus-container .card dt .img-over-txt{
    position: absolute;
    bottom:0;
    left: 0;
    width: 100%;
    background:rgba(89,123,55,0.7);
    color: #fff;
    padding: 3px 8px;
    font-weight: normal;
    text-align: right;
}
#restaurantbus-container .card-box { padding: 0 6px; }
#restaurantbus-container .card { position: relative; margin-bottom: 45px; border: none; border-radius: 0; background: #000; color: #fff; box-shadow: 0px 0px 6px 0px rgba(0,0,0,.16); }
#restaurantbus-container .card:hover { background: #222; }
#restaurantbus-container .card img { border-radius: 0; }
#restaurantbus-container .card .card-body { padding: 10px 10px 20px 10px; }
@media all and (min-width: 768px) { #restaurantbus-container .card-box { padding: 0 15px; }
    #restaurantbus-container .card { margin-bottom: 60px; }}
@media all and (min-width: 992px) { #restaurantbus-container .card .card-body { padding: 14px 20px 20px 20px; } }

/* Card (Plan) */
#restaurantbus-container .plan-card .btn-primary { margin-top: 15px; }
#restaurantbus-container .plan-card::before, #restaurantbus-container .plan-card::after {   position: absolute;z-index: 2; top: -5px; left: 50%; padding: 1px 18px; border-radius: 0 0 4px 4px; color: #fff; font-weight: bold; font-size: 12px; text-align: center; line-height: 2; -webkit-transform: translate(-50%); -moz-transform: translate(-50%); -ms-transform: translate(-50%); -o-transform: translate(-50%); transform: translate(-50%); }
#restaurantbus-container .plan-card.ico-card-tokyo::before { content: "TOKYO"; }
#restaurantbus-container .plan-card.ico-card-kyoto::before { content: "KYOTO"; }
#restaurantbus-container .plan-card.ico-experience::after { top: -32px; right: -22px; left: auto; width: 26.15%; height: 28.46%; background: url("/restaurantbus/img/ui2019/ico-experience.png") top center/contain no-repeat; content: ""; }
#restaurantbus-container .plan-card .tag-genre { margin: 0 -2px 20px -2px; font-size: 9px;  text-align: center; }
#restaurantbus-container .plan-card .tag-genre li { padding: 0 2px; }
#restaurantbus-container .plan-card .tag-genre li span { display: block; width: 100%; border: 1px solid #ccc; opacity: .6; }
#restaurantbus-container .plan-card .tag-genre li .badge-active { opacity: 1; }
#restaurantbus-container .plan-card .card-title { font-weight: bold; font-size: 14px;line-height: 1.6; }
#restaurantbus-container .plan-card .card-title strong { font-size: 20px; line-height: 1.6; }
#restaurantbus-container .plan-card .card-title small { font-weight: bold; }
#restaurantbus-container .plan-card .card-text { font-size: 12px; }
#restaurantbus-container .plan-card .card-plan-price { margin-top: 15px; width: 100%;}
#restaurantbus-container .plan-card .plan-price { float: right;margin-top: 5px;text-align: center;width: 100%;}
#restaurantbus-container .col-12 .plan-card .plan-price { width: auto;}
#restaurantbus-container .plan-card .plan-price .plan-price-sub { margin-right: 0px; font-size: 20px; text-decoration: line-through;display: block;}
.plan-price-sub { margin-left:5px;text-decoration: line-through;}
#restaurantbus-container .plan-card .plan-price span { margin-left: 0; font-size: 30px; color: #fff; line-height: 1.8; }
#restaurantbus-container .plan-card .plan-price span:before { content: none; }
#restaurantbus-container .plan-card .plan-price span.num:after { font-size: 14px; content: "円"; }
#restaurantbus-container .plan-card .plan-price span.min:after { font-size: 14px; content: "円～"; }
#restaurantbus-container .plan-card .plan-time { position: relative; float: left; display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center;  width: 36px;  height: 36px;  font-weight: bold;  font-size: 12px;  text-align: center; }
#restaurantbus-container .plan-card .plan-time::after { position: absolute; top: 0; left: 0; width: 36px; height: 36px; border: 2px solid #000; border-radius: 50%; text-align: center; content: "";}
#restaurantbus-container .plan-card .circle-day::after { border-color: orange;}
#restaurantbus-container .plan-card .circle-night::after { border-color: green; }
@media all and (max-width: 320px){
#restaurantbus-container .plan-card .tag-genre { margin-left: -4px; margin-right: -4px; }
}
@media all and (min-width: 768px) {  #restaurantbus-container .plan-card .btn-primary { margin-top: 10px; padding: 10px; }
    #restaurantbus-container .plan-card .tag-genre { margin: 0 -10px 24px; font-weight: bold; font-size: 12px; }
    #restaurantbus-container .plan-card .tag-genre li { padding: 0 10px; }
    #restaurantbus-container .plan-card .card-title { font-size: 16px; }
    #restaurantbus-container .plan-card .card-title strong { font-size: 26px; }
    #restaurantbus-container .plan-card .card-text { font-size: 14px; }
    #restaurantbus-container .plan-card .card-plan-price { margin-top: 6px; }
    #restaurantbus-container .plan-card .plan-price {width: auto;text-align: right;}
    #restaurantbus-container .plan-card .plan-price span { font-size: 20px; line-height: 1.2; }
    #restaurantbus-container .plan-card .plan-price span:after { margin-left: 2px; font-size: 16px; } }

/* __Color - Lunch */
#restaurantbus-container .plan-card .tag-genre li span.tag-genre-lunch, #restaurantbus-container .plan-card .circle-day::after{ border-color: #d37705; }
/* __Color - Dinner */
#restaurantbus-container .plan-card .tag-genre li span.tag-genre-dinner, #restaurantbus-container .plan-card .circle-night::after{ border-color: #048F95; }
/* __Color - Experience */
#restaurantbus-container .plan-card .tag-genre li span.tag-genre-experience { border-color: #ba1079; }

/*  Gallery */
#restaurantbus-container .restaurantbus-gallery { background: #000; }
#restaurantbus-container .restaurantbus-gallery-inner li { padding: 0;}

/* Modal */
#restaurantbus-container .modal-section { margin-bottom: 1em; }
#restaurantbus-container .modal-section img { width: 100%; }
#restaurantbus-container .modal-section ul { margin-left: 1em; list-style-type: disc; }
#restaurantbus-container .modal-content { margin-left: 1px; }
#restaurantbus-container .modal-header { border-radius: 5px 5px 0 0 / 5px 5px 0 0; background: #000; color: #fff; }
#restaurantbus-container .modal-header .close { margin: -5px -5px -10px auto; padding: 0; border-radius: 6px;  background: #fff; color: #000; font-size: 2em; opacity: 1; }
#restaurantbus-container .modal-header .modal-title { text-align: left; font-weight: bold; font-size: 16px; line-height: 1.2; }
#restaurantbus-container .modal-menu-title-sub { font-weight: bold; font-size: 16px; }
#restaurantbus-container .modal-body { text-align: left; }
#restaurantbus-container .modal-body p { margin-bottom: 15px; font-size: 14px; }
@media all and (min-width: 768px) { #restaurantbus-container .modal-content { margin-left: 0; } }

/* Table (.details-table) */
#restaurantbus-container .details-table { display: table; border-collapse: separate; border-spacing: 0px 2px; width: 100%; margin-bottom: 24px; line-height: 1.6; }
#restaurantbus-container .details-table dl { display: table-row; }
#restaurantbus-container .details-table dt { display: table-cell; width: 40.5%; padding: 8px 16px; background: #F0ecec; font-weight: normal;}
#restaurantbus-container .details-table dd { display: table-cell; padding: 14px 0 14px 16px; }
#restaurantbus-container .details-table dd .txtlink { padding-left: 0; padding-right: 0; }
#restaurantbus-container .details-table-side { margin: 0; }
#restaurantbus-container .details-table-side dt { padding: 8px 16px; background: #F0ecec; font-weight: normal; text-align: center; }
#restaurantbus-container .details-table-side dd { text-align: center; }
@media all and (max-width: 767px) { #restaurantbus-container .details-table.break-table-sp,
    #restaurantbus-container .details-table.break-table-sp dl,
    #restaurantbus-container .details-table.break-table-sp dt,
    #restaurantbus-container .details-table.break-table-sp dd { display: block; width: 100%; }
    #restaurantbus-container .details-table-side { display: table; border-collapse: separate; border-spacing: 0px 2px; width: 100%; margin-bottom: 24px; line-height: 1.6; }
    #restaurantbus-container .details-table-side dl { display: table-row; padding: 0; }
    #restaurantbus-container .details-table-side dt { display: table-cell; width: 210px; text-align: left; }
    #restaurantbus-container .details-table-side dd { display: table-cell; text-align: right; } }
@media all and (min-width: 768px) {
    #restaurantbus-container .details-table { border-collapse: separate; border-spacing: 0px 3px; }
    #restaurantbus-container .details-table dt, #restaurantbus-container .details-table dd { font-size: 16px; }
    #restaurantbus-container .details-table dt { display: table-cell; width: 150px; }
    #restaurantbus-container .details-table.dt-long dt { width: 235px; vertical-align: middle; }
    #restaurantbus-container .details-table-side dl { padding: 1px; }
    #restaurantbus-container .details-table-side dd { padding: 15px 5px 0; } }

/* Google Map */
#restaurantbus-container .googlemap, .googlemap iframe { width: 100%; height: 300px; margin: 10px auto; }

/* Movie */
#restaurantbus-container .movie { position: relative; width: 100%; margin: 0 auto; padding-bottom: 56.28%; height: 0; overflow: hidden; }
#restaurantbus-container .movie iframe { position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px; width: 100%; height: 100%; border: none; }
@media all and (min-width: 992px) { #restaurantbus-container .movie { width: 49.18%; padding-bottom: 27.62%; } }

/* Area Key Colors */
/* __ [ TOKYO ]  */ 
/* FontColor  */ #restaurantbus-container.color-tokyo .color-primary { color: #3f4a90; }
/* Background */ #restaurantbus-container.color-tokyo, #restaurantbus-container.color-tokyo .color-primary-bg { background: #3f4a90; }
/* Card icon */  #restaurantbus-container .ico-card-tokyo::before {  background: #3f4a90; }
/* [.details-schedule-list] */ #restaurantbus-container.color-tokyo .details-schedule-list li::before, #restaurantbus-container.color-tokyo .details-schedule-list li::after {  background: #3f4a90; }
#restaurantbus-container.color-tokyo .details-schedule-list li { border: 4px solid rgba( 63, 74, 144, .7 ); } /* #3f4a90 opacity 70% */

/* __ [ KYOTO ]  */
/* FontColor  */ #restaurantbus-container.color-kyoto .color-primary { color: #597b37; }
/* Background */ #restaurantbus-container.color-kyoto, #restaurantbus-container.color-kyoto .color-primary-bg {  background: #597b37; }
/* Card icon */  #restaurantbus-container .ico-card-kyoto::before { background: #597b37; }
/* [.details-schedule-list] */ #restaurantbus-container.color-kyoto .details-schedule-list li::before, #restaurantbus-container.color-kyoto .details-schedule-list li::after { background: #597b37; }
#restaurantbus-container.color-kyoto .details-schedule-list li { border: 2px solid rgba( 89, 123, 55, .7 ); } /* #597b37 opacity 70% */

/* ///////////////////////////////////////////// */

/*  [ Top Page ] #restaurantbus-navber
================================================ */
#restaurantbus-navber { position: relative; background: #000; }
#restaurantbus-navber .container { padding: 0 5px 0 0; }
#restaurantbus-navber, #restaurantbus-navber .restaurantbus-nav-list { min-height: 50px; }
#restaurantbus-navber a { display: block; }
#restaurantbus-navber .restaurantbus-nav-brand { position: absolute; width: 22.66%; height: 100%; padding: 10px; background: #c61921; color: #000; z-index: 2; }
#restaurantbus-navber .restaurantbus-nav-list { display: table; vertical-align: middle; width: 78%; float: right; text-align: center; }
#restaurantbus-navber .restaurantbus-nav-list li { display: table-cell; vertical-align: middle; }
#restaurantbus-navber .restaurantbus-nav-list li a { padding: 15px 0; color: #fff; font-size: 13px; }
@media all and (max-width: 320px) { #restaurantbus-navber .restaurantbus-nav-list li a { font-size: 11px; } }
@media all and (max-width: 768px) { #restaurantbus-navber .container { max-width: 100%; } }
@media all and (min-width: 768px) { #restaurantbus-navber .container { padding: 0; }
    #restaurantbus-navber, #restaurantbus-navber .restaurantbus-nav-list { min-height: 120px; }
    #restaurantbus-navber .restaurantbus-nav-brand { width: 240px; }
    #restaurantbus-navber .restaurantbus-nav-list { border-collapse: separate; border-spacing: 60px 0; width: auto; }
    #restaurantbus-navber .restaurantbus-nav-list li a { padding: 30px 0; font-weight: bold; font-size: 16px; } }
@media all and (min-width: 992px) { #restaurantbus-navber .restaurantbus-nav-list { margin-right: -40px; } }

/*  [ Top Page ] #restaurantbus-intro
================================================ */
#restaurantbus-intro { position: relative; padding: 30px 0 20px; background: #720b0f; background: linear-gradient(#720b0f, #b11920); color: #fff; }
#restaurantbus-intro .intro-head-title, #restaurantbus-intro .badge-keyword, #restaurantbus-intro .intro-txt { display: block; width: 100%; max-width: 780px; margin: 0 auto; }
#restaurantbus-intro .intro-head-title { max-width: 780px; }
#restaurantbus-intro .intro-head-title img { display: block; }
#restaurantbus-intro .intro-head-title .intro-head-title-logo { display: block; margin: 20px auto 30px auto; }
#restaurantbus-intro .badge-keyword { display: block; font-size: 12px; text-align: center; }
#restaurantbus-intro .badge-keyword li { display: inline-block; margin: 0 2px 4px 2px; padding: 0 10px; border: 1px solid #fc8b8b; border-radius: 6px; font-weight: bold; }
#restaurantbus-intro .intro-body { z-index: 0; background: url("/restaurantbus/img/ui2019/bg-japanmap-dots.png") center 40px /contain no-repeat; }
#restaurantbus-intro .intro-body-title { padding-top: 30px; font-size: 24px; letter-spacing: .1em; }
#restaurantbus-intro .intro-img-wrap { position: relative; margin-bottom: 40px; text-align: center; }
#restaurantbus-intro .intro-body-img { width: 24.9122%; min-width: 211px; max-width: 284px; padding: 30px 0; }
#restaurantbus-intro .intro-txt { line-height: 1.8; }

/* Movie */
#restaurantbus-intro .movie {  margin: 30px auto; }

@media all and (max-width: 320px) { #restaurantbus-intro .intro-body-title { letter-spacing: 0; } }
@media all and (min-width: 768px) { #restaurantbus-intro .intro-head-title { width: 64%; }
    #restaurantbus-intro .intro-head-title .intro-head-title-logo { margin: 26px auto 25px auto; }
    #restaurantbus-intro .intro-body { margin-top: -10px; padding-top: 40px; background-position: top; background-size: 522px; }
    #restaurantbus-intro .intro-body-title { padding-top: 0; font-size: 32px; line-height: 1.6; }
    #restaurantbus-intro .intro-body-img { padding: 40px 0;}
    #restaurantbus-intro .intro-img-wrap { margin-bottom: 25px; }
    #restaurantbus-intro .intro-img-wrap::before { position: absolute; top: 90px; left: 0; width: 21.92%; max-width: 503px; height: 100%; background: url("/restaurantbus/img/ui2019/intro-img-food-left.png") no-repeat; background-size: contain; content: ""; }
    #restaurantbus-intro .intro-img-wrap::after { position: absolute; top: 90px; right: 0; width: 27.98%; max-width: 319px; height: 100%; background: url("/restaurantbus/img/ui2019/intro-img-food-right.png") no-repeat; background-size: contain; content: ""; } }
@media all and (min-width: 992px) {
    #restaurantbus-intro { padding: 96px 0 80px; }
    #restaurantbus-intro .badge-keyword { display: table; border-collapse: separate; border-spacing: 4px 0; }
    #restaurantbus-intro .badge-keyword li { display: table-cell; }
    #restaurantbus-intro .intro-img-wrap::before { top: 0; width: 21.92%; }
    #restaurantbus-intro .intro-img-wrap::after { top: 0; right: 0; }
    /* Movie */
    #restaurantbus-intro .movie { margin-bottom: 0; } }

/*  [ Top Page ] #restaurantbus-plan
================================================ */
#restaurantbus-plan { position: relative; z-index: 0; }

/* Background */
#restaurantbus-plan.bg-fill { background: linear-gradient(#b11920, #b21920); }
#restaurantbus-plan.bg-dots::before { position: absolute; z-index: -1; top: 10px; left: 10px; width: calc(100% - 10px); height: calc(100% - 20px); background: url("/restaurantbus/img/ui2019/bg-pattern-dots.png"); background-size: 15px; content: ""; }

/* Background Object */
#restaurantbus-plan .bg-object-fork::after, #restaurantbus-plan .bg-object-chopsticks::before, #restaurantbus-plan .bg-object-knife::after { position: absolute; z-index: -1; content: ""; }
#restaurantbus-plan .bg-object-fork::after { top: 326px; right: 0; width: 49.6vw; height: 49.6vw; background: url("/restaurantbus/img/ui2019/bg-object-fork.png") 0 100% / 200% no-repeat; }
#restaurantbus-plan .bg-object-chopsticks::before { bottom: -45px; left: 0; width: 40vw; height: 60vw; background: url("/restaurantbus/img/ui2019/bg-object-chopsticks.png") 100% 100% / 200% no-repeat; }
/*#restaurantbus-plan .bg-object-knife::after { bottom: 420px; right: 0; width: 34vw; height: 57.6vw; background: url("/restaurantbus/img/ui2019/bg-object-knife.png") 0 0 / 200% no-repeat; }*/

/* Title */
#restaurantbus-plan .plan-area-head { position: relative; }
#restaurantbus-plan .plan-area-head::before { position: absolute; z-index: -2; top: 0; left: 0; width: 100%; height: 100%; background: #fff; content: ""; }
#restaurantbus-plan .plan-area-head .plan-link { position: absolute; bottom: 15px; right: 4.39vw; }
#restaurantbus-plan .plan-area-head .plan-title { padding: 22px 0; text-align: center; }
#restaurantbus-plan .plan-area-head .plan-title img { max-width: 106px; }

/* Title(Sub) */
#restaurantbus-plan .specialplan-head .plan-sub-title { position: relative; display: inline-block; padding: 20px 10px 38px 14px; font-weight: normal; font-weight: bold; font-size: 20px; letter-spacing: .2em; }
#restaurantbus-plan .specialplan-head .plan-sub-title::after { position: absolute; left: 0; bottom: 0; width: 146px; height: 34px; background: url("/restaurantbus/img/ui2019/title-section-underline-curve.png") center/contain no-repeat; content: ""; }
#restaurantbus-plan .specialplan-head .title-head-logo::before { position: absolute; left: 14px; top: 0; width: 122px; height: 10px; background: url("/restaurantbus/img/ui2019/logo-restaurantbus.svg") top/contain no-repeat; content: ""; }

/* Area Link */
#restaurantbus-plan .plan-area-body { background: #fff; }
#restaurantbus-plan .plan-area-body li { position: relative; height: 80vw; padding: 0; }
#restaurantbus-plan .plan-area-body li:last-child{display: none;}
#restaurantbus-plan .plan-area-inner { width: 180px; height: 180px; padding: 10px 10px 20px 10px; background: #fff; box-shadow: 0px 0px 6px 0px rgba(0,0,0,.3); text-align: center; }
#restaurantbus-plan .bg-feature .plan-area-inner { width: 180px; height: auto; padding: 10px 10px 10px 10px;}
#restaurantbus-plan a .plan-area-inner:hover { background: #f5f5f5; }
#restaurantbus-plan .btn-plan-area { position: relative; overflow: hidden; padding: 5px; height: calc(30% + 10px); background: #000; color: #fff; }
#restaurantbus-plan .btn-plan-area::before { position: absolute; top: -25px; right: 0; width: 40px; height: 40px; border-top: 20px solid transparent; border-bottom: 20px solid transparent; border-left: 20px solid #fff; content: ""; }
#restaurantbus-plan .bg-photo { position: relative; overflow: hidden; z-index: 0; }
#restaurantbus-plan .bg-photo-img { position: absolute; top: 0; right: 0; z-index: -1; }
#restaurantbus-plan .bg-feature .bg-photo-img { position: absolute; top: 50%; right: 0; z-index: -1; transform: translate(0, -50%); }
#restaurantbus-plan li.bg-feature .bg-photo-img{width: 150%;}

/* Plan List */
#restaurantbus-plan .restaurantbus-plan-food { position: relative; padding: 45px 0 0 0; }

/* specialplan */
#restaurantbus-plan .restaurantbus-specialplan { position: relative; margin-top: 60px; padding-bottom: 60px; }
#restaurantbus-plan .specialplan-head { padding-top: 15px; color: #fff; text-align: center; }
#restaurantbus-plan .specialplan-body { margin: 0 auto; max-width: 1115px; }
#restaurantbus-plan .specialplan-map { padding: 40px 0 50px 0; box-sizing: border-box; text-align: center; }
#restaurantbus-plan .specialplan-list li { padding: 0 6px; }
#restaurantbus-plan .specialplan-list .note { display: block; color: #fff; text-align: center; }
#restaurantbus-plan .specialplan-card { margin-bottom: 16px; text-align: center; background: #fff; color: #000; }
#restaurantbus-plan .specialplan-card:hover { background: #fff; }
#restaurantbus-plan a .specialplan-card:hover { background: #ffde94; }
#restaurantbus-plan .specialplan-card::before { display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; position: absolute; top: 0; left: 0; width: 44px; height: 44px; background: #ffde94; color: #000; font-weight: bold; font-size: 12px; content: "開催中"; }
#restaurantbus-plan .specialplan-card.ico-card-end { box-shadow: none; }
#restaurantbus-plan .specialplan-card.ico-card-end::before { background: #000; color: #fff; content: "終了"; }
#restaurantbus-plan .specialplan-card .card-body { padding: 10px; }
#restaurantbus-plan .specialplan-card .card-body .card-title { font-weight: bold; font-size: 14px;}
#restaurantbus-plan .specialplan-card .card-body .card-text { font-size: 10px; }
#restaurantbus-plan .specialplan-more { padding-bottom: 1em; text-align: right; }
#restaurantbus-plan .specialplan-more .txtlink { color: #fff; border-bottom-color: #fff; }

/* Voice */
#restaurantbus-plan .plan-voice { margin: 56px auto 0 auto; padding: 20px; background: #fff; border-radius: 12px; }
#restaurantbus-plan .plan-voice-title { padding: 7px 0 0 0; color: #b21920; font-weight: bold; font-size: 16px; text-align: center; }
#restaurantbus-plan .plan-voice-list { margin-bottom: 18px; }
#restaurantbus-plan .plan-voice-list li { position: relative; display: block; padding: 30px 0 30px 55px; min-height: 36px; border-bottom: 1px dashed #d31f27; }
#restaurantbus-plan .plan-voice-list li::before { position: absolute; display: block; top: 30px; left: 0; width: 36px; height: 36px; background: url("/restaurantbus/img/ui2019/ico-balloon.png") top / 100% no-repeat; content: "";}
#restaurantbus-plan .plan-voice-list li .voice-plof { display: block; margin-top: 7px; margin-left: -55px; color: #666; font-size: 12px; text-align: right;}
#restaurantbus-plan .plan-voice-more { text-align: right; }
#restaurantbus-container .plan-voice-more .txtlink { border-bottom-color: #d31f27; }

@media all and (min-width: 768px) { 
    /* Background */
    #restaurantbus-plan.bg-dots::before { top: 20px; background-size: 36px; }
    /* Background Object */
    #restaurantbus-plan .bg-object-fork::after { top: 316px; width: 320px; height: 100%; background-position: center right; background-size: contain; }
    #restaurantbus-plan .bg-object-chopsticks::before { top: 930px; width: 245px; height: 100%; background-position: center left; background-size: contain; }
    /*#restaurantbus-plan .bg-object-knife::after { top: 956px; bottom: auto; width: 345px; height: 400px; background-position: center right; background-size: contain; }*/
    /* Title */
    #restaurantbus-plan .plan-area-head .plan-link { bottom: 35px; }
    #restaurantbus-plan .plan-area-head .plan-title img { max-width: 190px; }
    /* Title(Sub) */
    #restaurantbus-plan .specialplan-head .plan-sub-title { font-size: 30px; font-weight: normal; font-weight: 100; padding: 30px 6px 34px 14px; }
    #restaurantbus-plan .specialplan-head .title-head-logo::before { width: 173px; height: 28px; }
    /* Area Link */
    #restaurantbus-plan .plan-area-body li { height: 43vw; max-height: 600px; }
	#restaurantbus-plan .plan-area-body li:last-child{display: flex;}
    #restaurantbus-plan .plan-area-body li.bg-feature { height: auto;padding: 24px 0; }
    #restaurantbus-plan li.bg-feature .bg-photo-img{width: 100%;}
    /* specialplan */
    #restaurantbus-plan .restaurantbus-specialplan { position: relative; margin-top: 30px; }
    #restaurantbus-plan .specialplan-head { padding-top: 30px; }
    #restaurantbus-plan .specialplan-map { padding: 50px 0; }
    #restaurantbus-plan .specialplan-map img { padding-right: 38px; max-width: 563px; }
    #restaurantbus-plan .specialplan-list { margin: 0 -10px 0; }
    #restaurantbus-plan .specialplan-list li { padding: 0 10px; }
    #restaurantbus-plan .specialplan-list .note { margin: -5px 20px 5px; text-align: right; }
    #restaurantbus-plan .specialplan-card { margin-bottom: 20px; }
    #restaurantbus-plan .specialplan-card::before { width: 60px; height: 60px; font-size: 12px; }
    #restaurantbus-plan .specialplan-card.ico-card-end::before { font-weight: normal; }
    /* Voice */
    #restaurantbus-plan .plan-voice { margin: 40px auto; padding: 25px 60px 30px; }
    #restaurantbus-plan .plan-voice-title { padding-bottom: 20px; }
    #restaurantbus-plan .plan-voice-list li { padding: 20px 0 20px 64px; min-height: 60px; }
    #restaurantbus-plan .plan-voice-list li::before { top: 10px; left: 0; width: 46px; height: 46px; background: url("/restaurantbus/img/ui2019/ico-balloon.png") top / 100% no-repeat; }
    #restaurantbus-plan .plan-voice-list li .voice-plof { margin-left: 0; text-align: left;} }
@media all and (min-width: 992px) {
    /* Area Link */
    #restaurantbus-plan .plan-area-inner { width: 280px; height: 280px; padding: 1.46vw; }
    #restaurantbus-plan .bg-feature .plan-area-inner { width: 280px; height: 260px; padding: 1.46vw; }
    /* Voice */
    #restaurantbus-plan .plan-voice { width: 65.57%; } }

/*  [ Top Page ] #restaurantbus-sns
================================================ */
#restaurantbus-sns { padding: 57px 0 10px 0; background: #fafafa; border-top: solid 7px #b21920; }
#restaurantbus-sns .sns-inner-list { margin: 0 auto; }
#restaurantbus-sns .sns-inner-list .sns-inner-list-inner { padding: 0; text-align: center; }
#restaurantbus-sns .sns-inner-list .sns-inner-list-inner .sns-inner-txt {  display: block; padding-bottom: 38px; font-size: 16px; text-align: center; }
#restaurantbus-sns .sns-inner-list .sns-inner-list-inner .sns-inner-link { display: block; min-width: 216px; margin: 0 auto; padding-bottom: 20px; color: #d31f27; font-weight: bold; }
#restaurantbus-sns .sns-inner-list .sns-inner-list-inner .sns-inner-link:hover { opacity: .7; }
#restaurantbus-sns .ico-sns { width: 58px; height: 58px; margin-right: 1em;}
@media all and (min-width: 768px) { #restaurantbus-sns { padding: 60px 0 0 0; text-align: center; }
    #restaurantbus-sns .sns-inner-list { display: table; vertical-align: middle; width: 76.72%; text-align: left;}
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner { display: table-cell; }
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner:first-child { display: table-caption; }
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner .sns-inner-txt { text-align: left; }
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner:first-child .sns-inner-txt { text-align: center; }
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner .sns-inner-link { display: inline-block;} }
@media all and (min-width: 992px) { #restaurantbus-sns .sns-inner-list { padding-left: 8%; }
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner { text-align: left; }
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner:first-child { display: table-cell; /*width: 35.29%;*/ width: 50%; }
    #restaurantbus-sns .sns-inner-list .sns-inner-list-inner .sns-inner-link { display: inline-block; width: 57.6%; } }

/*  [ Top Page ] #restaurantbus-pr-contact
================================================ */
#restaurantbus-pr-contact { padding: 40px 0 60px 0; background: #fafafa; }

/* PR */
#restaurantbus-pr-contact .restaurantbus-pr { background: #fff; border-top: 1px solid #b21920; }
#restaurantbus-pr-contact .pr-head { text-align: center; }
#restaurantbus-pr-contact .pr-head img { width: 122px; }
#restaurantbus-pr-contact .restaurantbus-pr-title { margin: 15px 0 36px 0; font-weight: normal; font-size: 16px; }
#restaurantbus-pr-contact .restaurantbus-pr-inner { width: 100%; padding: 40px 0 50px 0; }
#restaurantbus-pr-contact .pr-body { margin: 0 24px; font-size: 14px; }
#restaurantbus-pr-contact .pr-list-date { padding-right: 1em; box-sizing: border-box; font-weight: normal; }
#restaurantbus-pr-contact .pr-list-txt { padding: 4px 0; font-weight: bold; }

/* Contact */
#restaurantbus-pr-contact .restaurantbus-contact { padding: 50px 24px; background: #b21920; background: linear-gradient(to bottom, #b21920 0%,#a0161d 30%,#620e12 90%,#690f13 100%); color: #fff; text-align: center; }
#restaurantbus-pr-contact .restaurantbus-contact-inner p { font-size: 16px; }
#restaurantbus-pr-contact .link-contact { margin-top: 30px; }
#restaurantbus-pr-contact .link-contact .txtlink { color: #fff; border-bottom-color: #d31f27;}
#restaurantbus-pr-contact .restaurantbus-contact .btn {  margin: 40px auto 0 auto; padding: 20px 15px; }

@media all and (min-width: 768px) { #restaurantbus-pr-contact { padding: 30px 0; }
    /* PR */
    #restaurantbus-pr-contact .restaurantbus-pr,
    #restaurantbus-pr-contact .restaurantbus-contact{ margin: 0 2.2%; }
    #restaurantbus-pr-contact .restaurantbus-pr-inner { padding-bottom: 56px; }
    #restaurantbus-pr-contact .restaurantbus-pr-list { display: table-row; }
    #restaurantbus-pr-contact .pr-list-date { display: table-cell; width: 130px; padding-right: 1em; box-sizing: border-box; font-weight: normal; }
    #restaurantbus-pr-contact .pr-list-txt { display: table-cell; padding: 4px 0; font-weight: bold; }
    /* Contact */
    #restaurantbus-pr-contact .restaurantbus-contact { padding: 47px 0 57px; }
    #restaurantbus-pr-contact .link-contact { margin-top: 27px; }
    #restaurantbus-pr-contact .link-contact .txtlink { color: #fff; border-bottom-color: #d31f27; }
    #restaurantbus-pr-contact .restaurantbus-contact .btn {  width: 240px; margin: 30px auto 0 auto; padding: 24px 15px; } }
@media all and (min-width: 992px) { 
    /* PR */
    #restaurantbus-pr-contact .pr-body { display: table; margin: 0 auto; width: 55.57%; } }

/* ///////////////////////////////////////////// */

/*  [ Sub( PlanTop & Details ) Page ] Common Style
================================================ */
/* plan-details-list-block  */
#restaurantbus-container ul.plan-details-list-block { margin-left: 0; padding: 15px; background: #f0ecec; list-style-type: none; }
#restaurantbus-container ul.plan-details-list-block li { position: relative; margin-bottom: .8em; padding-left: 2em; font-size: 12px; line-height: 1.6em;}
#restaurantbus-container ul.plan-details-list-block li::before { position: absolute; display: inline-block; top: .3em; left: 0; width: 14px; height: 14px; background: #b21920; border-radius: 50%; content: "";}
#restaurantbus-container ul.plan-details-list-block li .txtlink { display: inline-block; margin: 30px 0 10px -24px; line-height: 1; }
@media all and (min-width: 768px) { #restaurantbus-container ul.plan-details-list-block { padding: 30px 40px; }
    #restaurantbus-container ul.plan-details-list-block li {font-size: 14px;}
    #restaurantbus-container ul.plan-details-list-block li .txtlink { margin: 15px 0 10px -2em; } }

/* #restaurantbus-header-s */
#restaurantbus-header-s { padding: 13px 0; background: #d31f27; text-align: center; }
#restaurantbus-header-s .restaurantbus-nav-brand img { display: inline-block; width: 120px; }
@media all and (min-width: 768px) { #restaurantbus-header-s .restaurantbus-nav-brand img { width: 162px; } }

/* #restaurantbus-area-mv */
#restaurantbus-area-mv { position: relative; overflow: hidden; height: 220px; z-index: 0; }
#restaurantbus-area-mv.area-mv-s { height: 130px; }
#restaurantbus-area-mv.area-mv-s .restaurantbus-area-title { width: 130px; height: 100%; padding: 15px; }
#restaurantbus-area-mv .restaurantbus-area-title { position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%,-50%); -moz-transform: translate(-50%,-50%); -ms-transform: translate(-50%,-50%); -o-transform: translate(-50%,-50%); transform: translate(-50%,-50%); width: 180px; height: 180px; padding: 20px; box-sizing: border-box; }
#restaurantbus-area-mv .restaurantbus-area-title-inner { height: 100%; margin: 0; color: #fff; font-size: 14px; text-align: center; }
#restaurantbus-area-mv .restaurantbus-area-title-bg { position: absolute; top: 0; left: 50%; z-index: -1; -webkit-transform: translateX(-50%); -moz-transform: translateX(-50%); -ms-transform: translateX(-50%); -o-transform: translateX(-50%); transform: translateX(-50%); min-width: 100%; max-width: 100%; min-height: 100%; }

/* __Kyoto Only */
#restaurantbus-area-mv.area-mv-s .restaurantbus-area-title-bg.viewsp.position-kyoto { top: auto; bottom: -30px; }
@media all and (max-width: 767px) { #restaurantbus-area-mv.area-mv-s .restaurantbus-area-title { transform: none; top: 0; left: 10.6%; } }
@media all and (min-width: 768px) { #restaurantbus-area-mv { height: 360px; }
    #restaurantbus-area-mv.area-mv-s { height: 172px; }
    #restaurantbus-area-mv.area-mv-s .restaurantbus-area-title { width: 172px; }
    #restaurantbus-area-mv .restaurantbus-area-title { width: 244px; height: 244px; }
    #restaurantbus-area-mv .restaurantbus-area-title-bg { top: -40px; width: 100%; min-width: 1366px; height: auto; }
    /* __Kyoto Only */
    #restaurantbus-area-mv.area-mv-s .restaurantbus-area-title-bg.viewpc.position-kyoto { top: auto;bottom: -100px; } }
@media all and (min-width: 992px) {
    /* __Kyoto Only */
    #restaurantbus-area-mv.area-mv-s .restaurantbus-area-title-bg.viewpc.position-kyoto { top: auto;bottom: -140px; } }

/*  [ Sub( PlanTop ) Page ] Common Style
================================================ */
/* #restaurantbus-area-intro */
#restaurantbus-area-intro { position: relative; overflow: hidden; z-index: 0; }
#restaurantbus-area-intro::before { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba( 0, 0, 0, .7); content: ""; }
#restaurantbus-area-intro .container { position: relative; padding: 0; }
/*#restaurantbus-area-intro .restaurantbus-area-intro-bg { min-width: 100%; max-width: 100%; min-height: 100%; }*/
#restaurantbus-area-intro .restaurantbus-area-intro-bg {  position: absolute; z-index: -1; top: 0; left: -20%; width: 140%; }
#restaurantbus-area-intro .area-intro-content { position: relative; padding: 65px 9%; }
#restaurantbus-area-intro .restaurantbus-area-intro-inner { text-align: center; }
#restaurantbus-area-intro .restaurantbus-area-intro-inner p { font-size: 16px; line-height: 1.6; }
#restaurantbus-area-intro .restaurantbus-area-intro-bus { width: auto; max-height: 73px; }
#restaurantbus-area-intro .area-intro-inner { position: relative; color: #fff; text-align: left; }
#restaurantbus-area-intro .area-intro-title { margin: 15px 0 35px; font-size: 28px; text-align: center; }
/* PLan */
#restaurantbus-plan-plantop { padding: 50px 0; }
/* --- [ .restaurantbus-plan-food ] <= All Common Style / [ #restaurantbus-plan-plantop ] <= PlanTop Style */
#restaurantbus-plan-plantop .restaurantbus-plan-food { padding-bottom: 5px;}
#restaurantbus-plan-plantop .restaurantbus-plan-food .plan-food-head { margin-bottom: 50px; color: #fff; text-align: center;}
#restaurantbus-plan-plantop .restaurantbus-plan-food .plan-food-head-img { margin-bottom: 30px; }
#restaurantbus-plan-plantop .restaurantbus-plan-food .plan-food-head p { line-height: 2; }
@media all and (min-width: 768px) { 
    /* #restaurantbus-area-intro */
    #restaurantbus-area-intro { display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; min-height: 687px; }
    #restaurantbus-area-intro::before { content: none; }
    #restaurantbus-area-intro .restaurantbus-area-intro-bg { left: 50%; -webkit-transform: translateX(-50%); -moz-transform: translateX(-50%); -ms-transform: translateX(-50%); -o-transform: translateX(-50%); transform: translateX(-50%); width: 100%; min-width: 1366px; height: auto; }
    #restaurantbus-area-intro .area-intro-content { padding: 0; }
    #restaurantbus-area-intro .restaurantbus-area-intro-inner { position: relative; z-index: 0; float: right; width: 100%; max-width: 560px; padding: 100px 0; }
    #restaurantbus-area-intro .restaurantbus-area-intro-bus { max-height: 100px; margin-bottom: -20px; }
    #restaurantbus-area-intro .area-intro-inner { z-index: -1; padding: 50px 40px; background: rgba(0,0,0,.7); }
    #restaurantbus-area-intro .area-intro-title { margin: 0 -20px 40px; font-size: 36px; }
    /* PLan */
    /* --- [ .restaurantbus-plan-food ] <= All Common Style / [ #restaurantbus-plan-plantop ] <= PlanTop Style    */
    #restaurantbus-plan-plantop .restaurantbus-plan-food .plan-food-head-img { max-width: 400px; } }

/* ///////////////////////////////////////////// */

/*  [ Sub(Details) Page ] Common Style
================================================ */
/* Title */
#restaurantbus-container .plan-details-title { color: #fff; font-size: 24px; text-align: center; }
#restaurantbus-container .container-block .plan-details-title-sub { margin-bottom: 1px; padding: 1em 5px;  background: #fff; font-weight: bold; font-size: 18px; text-align: center; }
@media all and (min-width: 768px) {  #restaurantbus-container .plan-details-title { font-size: 30px; letter-spacing: .1em;}
    #restaurantbus-container .container-block .plan-details-title-sub { padding: 16px; font-size: 20px; } }

/* .container-block */
#restaurantbus-container .container-block { margin-top: 30px; margin-bottom: 40px; padding: 0; }
#restaurantbus-container .container-block:first-child { margin-top: 0;}
#restaurantbus-container .container-block .plan-details-body { background: #fff; }
#restaurantbus-container .container .container-block .plan-details-body { padding: 24px; }
#restaurantbus-container .container-block .btn-secondary { margin-top: 50px; padding: 10px; font-size: 16px; line-height: 1; }
#restaurantbus-container .container-block .txtlink { font-size: 14px; border-bottom-color: #d31f27; }
@media all and (min-width: 768px) {  #restaurantbus-container .container .container-block .plan-details-body { padding: 80px; }
    #restaurantbus-container .container-block .txtlink { font-size: 16px; } }

/* .restaurantbus-plan-book  */
#restaurantbus-container .container-block .plan-book-block-inner { padding: 15px 15px 30px; }
#restaurantbus-container .container.container-block .plan-details-body { width: 100%; padding-top: 0; }
#restaurantbus-container .container.container-block .plan-book-block { padding-top: 15px; }
#restaurantbus-container .container.container-block .plan-book-block-inner { padding: 0; }
#restaurantbus-container .container.container-block .plan-book-photo { margin: 0 -24px; }
#restaurantbus-container .plan-book-block .btn-primary { max-width: 260px; margin: 0 auto; padding: 20px; }
#restaurantbus-container .plan-book-name { margin-top: 0; margin-bottom: 0; font-weight: bold; font-size: 20px; line-height: 1.4; }
#restaurantbus-container .plan-book-name-sub { display: block; font-weight: normal; font-size: 14px;margin-bottom: 10px; }
#restaurantbus-container .plan-book-block p { line-height: 1.6; }
#restaurantbus-container .plan-book-block .note { margin-top: 10px; font-weight: bold; font-size: 14px; text-align: center; line-height: 1.4; }
#restaurantbus-container .plan-book-price { margin-top: 0; font-weight: bold; text-align: center; }
#restaurantbus-container .plan-book-price small { padding-right: 5px; font-weight: bold; font-size: 18px; }
#restaurantbus-container .plan-book-price span { font-size: 24px; line-height: 1.6; }
#restaurantbus-container .btn-pagebottom { padding-top: 10px; }
@media all and (min-width: 768px) {
    /* .container-block */
    #restaurantbus-container .container-block { margin-top: 30px; margin-bottom: 30px; }
    /* .restaurantbus-plan-book  */
    #restaurantbus-container .container-block .plan-book-block-inner { padding: 0 5.25%; }
    #restaurantbus-container .restaurantbus-plan-book .plan-details-body { display: table; min-height: 407px; }
    #restaurantbus-container .container.container-block .plan-details-body { padding: 0; }
    #restaurantbus-container .container.container-block .plan-book-block { padding: 20px 20px; }
    #restaurantbus-container .plan-book-photo { position: relative; display: table-cell; overflow: hidden; width: 50vw; }
    /*#restaurantbus-container .plan-details-body-02 .plan-book-photo { position: relative; display: block; overflow: hidden; width: 100%;height: 500px; }*/
    #kyotoarea #restaurantbus-container .plan-book-photo { background:#597b37; }
    #tokyoarea #restaurantbus-container .plan-book-photo { background:#3f4a90; }
    #restaurantbus-container .book-photo-img { position: absolute; top: 50%; left: 50%; width: auto; min-height: 100%; -webkit-transform: translate(-50%,-50%); -moz-transform: translate(-50%,-50%); -ms-transform: translate(-50%,-50%); -o-transform: translate(-50%,-50%); transform: translate(-50%,-50%); }
    /*#restaurantbus-container .plan-details-body-02 .book-photo-img { position: relative; top: auto; left: auto; width: auto; height: auto; -webkit-transform: none; -moz-transform: none; -ms-transform: none; -o-transform: none; transform: none; }*/
    #restaurantbus-container .container.container-block .plan-book-photo { width: 340px; }
    #restaurantbus-container .container.container-block .book-photo-img { left: 50%; width: auto; height: 100%; }
    #restaurantbus-container .plan-book-block { display: table-cell; vertical-align: middle; width: 50vw; padding: 20px; }
    /*#restaurantbus-container .plan-details-body-02 .plan-book-block { position: absolute; bottom: 0;left: 0;display: block; vertical-align: middle; width: 100%; padding: 20px; }*/
    #restaurantbus-container .plan-book-name { margin-bottom: 15px; font-size: 24px; }
    #restaurantbus-container .plan-book-name-sub { font-size: 18px; line-height: 1; }
    #restaurantbus-container .plan-book-block p { line-height: 1.6; }
    #restaurantbus-container .plan-book-price { margin-top: 30px; font-size: 24px; }
    #restaurantbus-container .plan-book-block .btn-primary { margin: 20px auto 0 auto; }
    #restaurantbus-container .btn-pagebottom { padding-top: 30px; padding-bottom: 25px; } }
@media all and (min-width: 1480px) {
    #restaurantbus-container .book-photo-img { width: 180%; height: auto; } }

/* Icons Foodpict */
#restaurantbus-container .food-pict-wrap { margin: 0 -5px 15px; }
#restaurantbus-container .food-pict-wrap .food-pict { margin-bottom: 0; padding: 0 5px 5px; color: #7F2317; font-size: 11px; text-align: center;}
#restaurantbus-container .food-pict-wrap .food-pict dt { margin-bottom: 2px; }
@media all and (max-width: 320px) {
    #restaurantbus-container .food-pict-wrap { margin-left: -15px; margin-right: -15px;}
    #restaurantbus-container .food-pict-wrap .food-pict { font-size: 12px; padding-left: 2px; } }

/*  [ Sub(Details) Page ] #restaurantbus-plan-points
================================================ */
#restaurantbus-plan-points { padding-top: 10px; }
#restaurantbus-container #restaurantbus-plan-points .plan-details-body {padding-top: 0; }
#restaurantbus-plan-points .plan-details-body .ico-bookmark { position: relative; display: inline-block; width: 30px; height: 50px; margin: -1px 0 0 0; }
#restaurantbus-plan-points .plan-details-body .ico-bookmark::after { position: absolute; bottom: -1px; left: 0; width: 30px; height: 24px; background: url("/restaurantbus/img/ui2019/parts-ribbon.png") bottom / 100% no-repeat; content: ""; }
#restaurantbus-plan-points .plan-points-title { font-weight: bold; font-size: 18px; text-align: center; }
#restaurantbus-plan-points .plan-points-list { padding: 0; }
#restaurantbus-plan-points .plan-points-list li { display: block; padding: 15px 0; line-height: 2; }
#restaurantbus-plan-points .plan-points-list .ico-list-check { position: relative; padding-left: 57px; }
#restaurantbus-plan-points .plan-points-list .ico-list-check::before { position: absolute; top: 30px; left: 0; width: 41px; height: 100%; background: url("/restaurantbus/img/ui2019/ico-check.png") top center / contain no-repeat; content: ""; }
@media all and (min-width: 768px) {
    #restaurantbus-container #restaurantbus-plan-points .plan-details-body { padding: 0 6% 60px 7%;  }
    #restaurantbus-plan-points .plan-details-body .ico-bookmark { width: 30px; height: 50px; }
    #restaurantbus-plan-points .plan-points-title { margin-top: 10px; }
    #restaurantbus-plan-points .plan-points-list { padding: 15px 0 25px; }
    #restaurantbus-plan-points .plan-points-list li { font-size: 18px; }
    #restaurantbus-plan-points .plan-points-list li { padding: 20px 0; }
    #restaurantbus-plan-points .plan-points-list .ico-list-check::before { top: 0;background-position: center; } }

/*  [ Sub(Details) Page ] #restaurantbus-plan-details
================================================ */
/*  [ Sub(Details) Page ] __.restaurantbus-plan-details-food
================================================ */
#restaurantbus-container .restaurantbus-plan-details-menu .plan-details-body { padding-top: 24px;  padding-bottom: 50px; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .plan-details-body .txtlink { margin-top: 30px; }

/* Menu */
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-badge span { width: 60px; height: 60px; margin: 20px auto; padding: 0 2px; border-radius: 50%; color: #fff; text-align: center; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-content { font-size: 12px; line-height: 2; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-title { position: relative; padding-bottom: 24px; overflow: hidden; font-weight: bold; font-size: 20px; line-height: 1.6; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .menu-kcal { display: inline-block; padding: 5px 15px; border: 3px solid #000; font-weight: normal; font-size: 16px; line-height: 1; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-lead { margin-bottom: 24px; font-size: 16px; line-height: 1.6; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .note { font-size: 12px; }

/* Slide */
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-slide { display: block; width: 100%; max-width: 572px; margin: 40px auto 55px; font-size: 12px; line-height: 1.2; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-slide li { position: relative; z-index: 0; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-slide li .caption { display: block; padding: 5px; background: rgba( 0, 0, 0, 0.7); color: #fff; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slick-slide img { max-width: 100%; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-arrow,
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-arrow:hover { background:rgba(134,126,126,1); z-index:9; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-prev { left: 0; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-next { right: 0; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-prev:before{ content:"\f104"; font-family: "Font Awesome 5 Free";font-weight: bold; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-next:before{ content:"\f105"; font-family: "Font Awesome 5 Free";font-weight: bold; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots{ bottom:-15px; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slick-dots li,
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots li,
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots li button,
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots li button:before{ width:7px; height:7px; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots li button:before{ content:''; background:#a8a4a4; opacity: 1; border-radius:50%; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slick-dots li.slick-active button:before { opacity: 1; background:#555252; }
@media all and (min-width: 768px) {
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-slide li .caption { position: absolute; bottom: 0; width: 100%; z-index: 1;}}

/* Menu-list */
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-list { margin-bottom: 40px; text-align: left; line-height: 1.6; }
#restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-list dd {  margin-bottom: 15px;}

@media all and (min-width: 768px) { #restaurantbus-container #restaurantbus-plan-details .restaurantbus-plan-details-menu .plan-details-body { padding: 16px 100px 70px; }
    /* Menu */
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu { display: table; margin-top: 10px; padding-right: 4em;}
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-badge { display: table-cell; }
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-badge span { width: 100px; height: 100px; margin-right: 24px; padding: 0 9px 0 7px;}
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-content { display: table-cell; vertical-align: top;}
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-content p { font-size: 14px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-title { margin-top: 20px; padding-bottom: 0; font-size: 20px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .note { font-size: 14px; }
    /* Slide */
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-slide { margin: 0 auto 76px;; }
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots{ bottom:-25px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .slick-dots li { margin: 0 10px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .slick-dots li,
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots li,
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots li button,
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-dots li button:before{ width:14px; height:14px; }
    /* Menu-list */
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-list { font-size: 16px; text-align: center; } }
@media all and (min-width: 992px) { #restaurantbus-plan-details .restaurantbus-plan-details-menu .details-menu-title-inner { padding-right: 7em; }
    #restaurantbus-plan-details .restaurantbus-plan-details-menu .menu-kcal { display: inline-block; position: absolute; top: 0; right: 0; } }

/*  [ Sub(Details) Page ] __.restaurantbus-plan-details-schedule
================================================ */
/* Schedule */
#restaurantbus-container#restaurantbus-plan-details .restaurantbus-plan-details-schedule .plan-details-body { padding: 24px 13px 50px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-wrap { position: relative;margin-bottom: 20px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .schedule-time { position: absolute; display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 60px; height: 60px; border-radius: 50%; color: #fff; font-weight: bold; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .schedule-time-start { float: left; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .schedule-time-end { position: absolute; top: -10px; right: -70px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list { padding: 18px 0 0 0; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li { display: inline-block; float: left; position: relative; margin-right: 30px; margin-bottom: 1em; padding: 10px; border-radius: 6px; font-size: 12px; text-align: center; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.ico-left-dots-sp { margin-left: 30px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li::after, #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.ico-left-dots-sp::before { display: inline-block; position: absolute; top: 1em; width: 20px; height: 15px; -webkit-mask-image: url("/restaurantbus/img/ui2019/dots.svg"); mask-image: url("/restaurantbus/img/ui2019/dots.svg"); content: ""; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li::after { right: -30px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.ico-left-dots-sp::before { left: -30px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:first-child { width: 46vw; margin-left: 70px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child { display: block; float: right; width: 48vw; margin-right: 65px; margin-left: calc(1vw + 71px); }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:first-child::after, #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::after { width: 20px; right: -74px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::after { width: 12px; left: -64px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:first-child::before, #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::before { display: block; position: absolute; right: calc(-45px - 4px); width: 38px; height: 18px; background: url("/restaurantbus/img/ui2019/ico-bus.png") center / contain no-repeat; content: ""; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::before { left: calc(-45px - 4px); }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li em { display: inline-block; position: absolute; top: 100%; left: 50%; z-index: 1; width: 82%; padding: 3px; border-radius: 100px; background: #d31f27; color: #fff; font-weight: bold; font-size: 9px; text-align: center; line-height: 1; -webkit-transform: translate(-50%,-50%); -moz-transform: translate(-50%,-50%); -ms-transform: translate(-50%,-50%); -o-transform: translate(-50%,-50%); transform: translate(-50%,-50%); }

/* Spot */
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-spot-wrap { position: relative; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos { margin: 15px auto 0; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos-block { text-align: center; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos-block .spot-photos-block-inner { position: relative; width: 50%; padding: 0 8px 8px; float: left; font-size: 9px; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos-map-img { position: relative; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photosnum { display: block; position: absolute; top: 8px; left: 8px; width: 1.6em; height: 1.6em; padding-top: .25em; border-radius: 50%; border: 1px solid #707070; background: #fff; box-shadow: 0px 3px 6px rgba(0,0,0,0.16); font-style: normal; text-align: center; line-height: 1; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos-block-inner em { position: absolute; bottom: 8px; left: 0; width: calc(100% - 20px); margin: 0 10px; border-radius: 100px; background: #d31f27; color: #fff; text-align: center; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .note { display: inline-block; margin-top: 30px; text-align: left; }

@media all and (max-width: 320px) {#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-wrap { margin: 0 -14px 20px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule  .details-schedule-list li { padding: 10px 5px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule  .details-schedule-list li:first-child, #restaurantbus-plan-details .restaurantbus-plan-details-schedule  .details-schedule-list li:last-child { width: 42vw; } }
@media all and (min-width: 768px) { 
    /* Schedule */
    #restaurantbus-container#restaurantbus-plan-details .restaurantbus-plan-details-schedule .plan-details-body { padding: 67px 80px 80px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule  .schedule-time { position: static; display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 78px; height: 78px; font-size: 18px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule  .schedule-time-end { position: absolute; right: -90px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule  .details-schedule-list { padding: 10px 0 15px 90px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li { margin-right: 50px; padding: 14px 18px; font-size: 16px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.ico-left-dots-sp { margin-left: 0; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li::after { top: 1.2em; right: -45px; width: 30px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.ico-left-dots-sp::before { content: none; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:first-child { width: calc(100% - 140px); margin-left: 0; margin-right: 140px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child { width: calc(100% - 230px); margin-right: 90px; margin-left: 140px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:first-child::after, #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::after { width: 70px; right: -140px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::after { left: -140px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:first-child::before, #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::before { right: -62px; width: 47px; height: 22px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li:last-child::before { left: -62px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li em { font-size: 12px; }
    /* Spot */
	#restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos{width: 80%;}
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos-block { width: 45%; padding: 0; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-spot-wrap.no-map .spot-photos { padding-right: 20px; padding-left: 20px; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-spot-wrap.no-map .spot-photos-block { width: auto; margin: 0 -40px; padding: 0; float: none;}
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photos-block .spot-photos-block-inner { width: 100%; padding: 7px 0 14px 0; font-size: 12px; }#restaurantbus-plan-details .restaurantbus-plan-details-schedule .photos-right { padding-left: 8px; float: right; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-spot-wrap.no-map .spot-photos-block .spot-photos-block-inner { width: 50%; padding: 0 40px; box-sizing: border-box; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .photos-left { padding-right: 8px; float: left; }
    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .spot-photosnum { top: 10px; left: 10px; }

    #restaurantbus-plan-details .restaurantbus-plan-details-schedule .note { font-size: 14px; } }

@media all and (max-width: 768px) {
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.icon-width-100 { margin:0;width:100%;display: block;position: relative; }
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.icon-width-100 + li{
    margin-top: 10px;
}
#restaurantbus-plan-details .restaurantbus-plan-details-schedule .details-schedule-list li.icon-width-100::after { display: none; }
} 

/*  [ Sub(Details) Page ] __#restaurantbus-plan-details-seat
================================================ */
#restaurantbus-container #restaurantbus-plan-details-seat .plan-details-body { padding-top: 24px;  padding-bottom: 50px; }
#restaurantbus-plan-details-seat .details-seat-photos { margin: 0 -3px; }
#restaurantbus-plan-details-seat .details-seat-photos::before { content: none; }
#restaurantbus-plan-details-seat .details-seat-photos-inner { text-align: center; padding: 0 3px 20px; }
#restaurantbus-plan-details-seat .seat-photos-txt { margin-top: 8px; }

/* ico-balloon */
#restaurantbus-plan-details-seat .ico-balloon { position: relative; display: inline-block; width: 14px; height: 14px; margin-right: 10px; background: #666; border-radius: 50%; }
#restaurantbus-plan-details-seat .ico-balloon::before { position: absolute; top: calc(.5em - 4px); right: -4px; width: 0; height: 0; border-radius: 2px; border-top: 4px solid transparent; border-bottom: 4px solid transparent; border-left: 8px solid #666; content: ""; }

/* __ico-balloon Colors */
#restaurantbus-plan-details-seat .ico-balloon-color1 { background: #d3817b; } #restaurantbus-plan-details-seat .ico-balloon-color1::before { border-left-color: #d3817b; }
#restaurantbus-plan-details-seat .ico-balloon-color2 { background: #bD86ad; } #restaurantbus-plan-details-seat .ico-balloon-color2::before { border-left-color: #bD86ad; }
#restaurantbus-plan-details-seat .ico-balloon-color3 { background: #64a2c0; } #restaurantbus-plan-details-seat .ico-balloon-color3::before { border-left-color: #64a2c0; }
#restaurantbus-plan-details-seat .ico-balloon-color4 { background: #889b78; } #restaurantbus-plan-details-seat .ico-balloon-color4::before { border-left-color: #889b78; }

/* seat-perth-img */
#restaurantbus-plan-details-seat .details-seat-perth { margin-top: 30px; }
#restaurantbus-plan-details-seat .seat-bus-img,
#restaurantbus-plan-details-seat .seat-perth-img { margin-top: 20px; }
#restaurantbus-plan-details-seat .seat-perth-img .note { margin-top: 10px; color: #474645; font-size: 11px; }

/* details-seat-book */
#restaurantbus-plan-details-seat .details-seat-book { margin-top: 50px; }
#restaurantbus-plan-details-seat .seat-book-tel { font-weight: bold; color: #b21920; }
#restaurantbus-plan-details-seat .seat-book-tel small { font-weight: bold; font-size: unset; }
#restaurantbus-plan-details-seat .details-seat-notes { margin-top: 50px; }
#restaurantbus-plan-details-seat .persons-emphasis { display: block; border: 1px solid #b21920; padding: 1em; }

@media all and (min-width: 768px) { #restaurantbus-container #restaurantbus-plan-details-seat .plan-details-body { padding: 60px 100px 90px 100px; }
    #restaurantbus-plan-details-seat .details-seat-photos-inner { padding: 0 23px 30px; }
    #restaurantbus-plan-details-seat .details-seat-photos { margin: 0 -23px; }
    #restaurantbus-plan-details-seat .seat-photos-txt { font-size: 14px; line-height: 1.6; }
    #restaurantbus-plan-details-seat .seat-bus-img { max-width: 500px; margin: 50px auto 0; }
    #restaurantbus-plan-details-seat .seat-perth-img { max-width: 537px; margin: 50px auto 0; }
    #restaurantbus-plan-details-seat .details-seat-book { margin-top: 70px; }
    #restaurantbus-plan-details-seat .seat-book-tel { font-size: 18px; }
    #restaurantbus-plan-details-seat .seat-book-tel small { font-size: 14px; } }

/*   [ Sub(Details) Page ] __.restaurantbus-plan-details-conditions
================================================ */
#restaurantbus-container .restaurantbus-plan-details-conditions .plan-details-body { padding-top: 24px;  padding-bottom: 22px; }
.restaurantbus-plan-details-conditions .conditions-inner-title { margin-bottom: 10px; font-weight: bold; font-size: 14px; }
@media all and (min-width: 768px) {  #restaurantbus-container .restaurantbus-plan-details-conditions .plan-details-body { padding: 60px 90px 80px; }
    .restaurantbus-plan-details-conditions .conditions-left { width: 42.5%; float: left;}
    .restaurantbus-plan-details-conditions .conditions-right { width: 52%; float: right; } }

/*  [ Sub(Details) Page ] __#restaurantbus-plan-details-information
================================================ */
#restaurantbus-container #restaurantbus-plan-details-information .plan-details-body { padding-top: 26px;  padding-bottom: 26px; }
@media all and (min-width: 768px) { #restaurantbus-container #restaurantbus-plan-details-information .plan-details-body { padding: 55px 100px 90px ;} }


.acc-box .card-header{
    padding:6px;
    background: #feebf2;
    border-bottom:none;
}
.acc-box .card-header h3{
    font-weight: bold;
    margin:0;
}
.acc-box .card-header h3 button{
    background: none;
    text-align: left;
    color: #dc3545;
    padding:0 30px 0 0;
    position: relative;
    line-height: 1.4;
    display: block;
    width: 100%;
    font-weight: bold;
    font-size: 14px;
}
.acc-box .card-header h3 button .badge{
    line-height: 1;
    font-weight: normal;
    position: relative;
    top: -2px;
    padding: 3px 4px 2px;
    color: #fff;
    background-color: #dc3545;
    border-radius: 2px;
    font-size: 12px;
}
.acc-box .card-header:first-child{
    border-radius: 0;
}
.acc-box .card{
    border-radius: 0;
    border: 2px solid #d9534f;
}
.acc-box .card-body{
    padding:0 10px 10px;
    background: #feebf2;
}
.acc-box .card-body p{
    font-size: 13px;
    margin-bottom: 0;
}
.acc-box .card-header button:after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 0px;
    content: "\f077";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    color: #d9534f;
}
.acc-box .card-header button.collapsed:after {
    content: "\f078";
}


.acc-01,.acc-02,.acc-02,.acc-03{
    display: none;
}

#kyotoarea  .acc-02{
    display: none;
}
#tokyoarea .acc-04,
#toparea .acc-04,
#kyotoarea  .acc-04{
    display: none;
}
@media all and (max-width: 768px) {
.acc-box .card-header h3 button{
    font-size: 13px;
}
.acc-box .card-body p{
    font-size: 13px;
}
}


.restaurantbus-campaignwrap{
    background: url(/restaurantbus/img/ui2019/bg-blue.gif) top left;
    color: #fff;
    font-size: 18px;
    font-weight: bold;
    border-top:3px solid #ffff66;
    padding: 12px;
    line-height: 2em;
}
.restaurantbus-campaignwrap strong{
    font-size: 110%;
    border-bottom: 3px solid #ffff66;
}
.restaurantbus-campaignwrap a{
    color: #fff !important;
    text-decoration: underline;
}
.restaurantbus-campaignwrap a:hover{
    text-decoration: none;
}
.plan-area-head .restaurantbus-campaignwrap{
    background: url(/restaurantbus/img/ui2019/bg-blue.gif) top left;
    border-top:none;
    padding: 12px 12px;
}
#toparea .restaurantbus-campaignwrap,
#kyotoarea .restaurantbus-campaignwrap{
    background: url(/static/img/restaurantbus/bnr/bnr_kyoto2.jpg) center top repeat-x;
    background-size: 600px;
    color: #fff;
    border-top:3px solid #c61921;
    border-bottom:none;
    padding: 0;
    line-height: 1;
    text-align: center;
}
#toparea .restaurantbus-campaignwrap a,
#kyotoarea .restaurantbus-campaignwrap a{
    display: block;
    width: 100%;
}
.restaurantbus-campaignwrap img{
    width: 600px !important;
    height: auto;
}
@media all and (max-width: 768px) {
.restaurantbus-campaignwrap,.plan-area-head .restaurantbus-campaignwrap{
    font-size: 13px;
    padding: 10px 0 10px;
}
.restaurantbus-campaignwrap img{
    width: 100%;
}
}

.label-sale{
    background: url(/restaurantbus/img/ui2019/bg-blue.gif) top left;
    color: #fff;
    font-size: 10px !important;
    padding: 2px 3px 1px;
    border-radius: 2px;
    position: relative;
    font-weight: normal !important;
    top: -3px;
    margin-right: 5px;
}
#restaurantbus-container .plan-card .plan-price span.label-sale:after{
    display: none;
}
.price-before{
    text-decoration: line-through;
}

.Bnr-wedding{
	margin-bottom: 40px;
}
@media (min-width: 992px){
.Bnr-wedding{
	width:40%;
}
}
/*  GOTO アイコン対応
--------------------------------------------------------- */

.Bnr-wedding{
  position:relative;
}
.img-gotoicon{
  position: absolute;
  top: 5px;
  left: 5px;
  zoom:0.5;
}

#restaurantbus-container img.img-gotoicon{
	width: auto;	
}
@media (max-width: 767px){
.img-gotoicon{
  zoom:0.25;
}
	}
/*  もっとTOKYO プラン追加
--------------------------------------------------------- */
.motto-tokyo p{}	
.motto-tokyo span{
		color:#ffff66;
		font-size: 130%;
	font-weight:bold;
		
	}	
.motto-tokyo-ex{text-align:right;font-size: 130%;}
.motto-tokyo-off{text-decoration: line-through;margin-left:10px;}
.motto-tokyo-price{font-size: 130%;font-weight:bold;margin-left:10px;}
.motto-tokyo-menu{text-align:center;margin-top:10px;color:#d31f27;font-size: 120%;
	font-weight:bold;}
.motto-tokyo-text{text-align:center;margin-top:40px;color:#333;font-size: 120%;
}
	

#restaurantbus-container .plan-card .plan-price .motto-tokyo-price { margin-right: 10px!important; display:inline!important;}

.motto-tokyo-btn{
	margin-top:5px!important;
	width: 95%!important;
}
.motto-tokyo-btn a{
	display:block;
	color: #FFF!important;
}
.motto-tokyo-btn a:hover{opacity: 0.5!important;}

.special-box{
	background: #f4f6ff;
	padding: 20px;	
}

.txt-special{
	font-size: 20px;
	font-weight: bold;
	line-height: 1.4em!important;
	color: #3f4a90;
}		

#restaurantbus-container .special-box .plan-book-price {
    margin-top: 10px;
}
ul.motto-tokyo-point{
}
ul.motto-tokyo-point li{
	line-height: 200%;
	font-size: 140%;
	
}
ul.motto-tokyo-point li i{
	color: #a58a2f;
	margin-right: 10px;
}

.motto-tokyo-corse{
	text-align: center;
	font-size: 0.9em;
}
@media (max-width: 767px){
	.special-box{
	padding: 10px;	
}
	.txt-special{
	font-size: 16px;
}
	.motto-tokyo-text{
		font-size: 13px;
		text-align: left;
}
	ul.motto-tokyo-point li{
	line-height: 150%;
	font-size: 13px;
		text-align: left;
}
	ul.motto-tokyo-point li:first-child{
		margin-bottom: 10px;
	}
	.txt-european{
		color: #3f4a90!important;
	}	
}
/*--------------------
20201120 Instagram 
--------------------*/
#restaurantbus-sns #post_more {
    display: none;
}

		
		
/*--------------------
予約ボタン非活性
--------------------*/

#restaurantbus-container .comingsoon  {opacity: 0.6!important;transition-property: all!important;transition: 0.3s linear!important;pointer-events: none!important;}
#restaurantbus-container .card-box.comingsoon {opacity: 0.5!important;transition-property: all!important;transition: 0.3s linear!important;pointer-events: none!important;}
#restaurantbus-container .comingsoon .btn-primary {font-size: 0;}
#restaurantbus-container .comingsoon .btn-primary:before {content: "販売停止中";    font-size: 14px;}

#restaurantbus-container .kanbai  {pointer-events: none!important;position: relative;}
#restaurantbus-container .kanbai:before{content: "";position: absolute;top: 0;left: 0;background: rgba(0, 0, 0, 0.7);width: 100%;height: 100%;z-index: 2;}
#restaurantbus-container .kanbai:after {content: "完売しました"; font-size: 18px;font-weight: bold;color: #fff;position: absolute;top: 0;left: 0;z-index: 3;display: block;width: 100%;text-align: center;background: red;padding: 12px 6px;}
#restaurantbus-container .kanbai .plan-card.ico-card-kyoto::before{display: none;}

#restaurantbus-container .hanbaiend  {pointer-events: none!important;position: relative;}
#restaurantbus-container .hanbaiend:before{content: "";position: absolute;top: 0;left: 0;background: rgba(0, 0, 0, 0.7);width: 100%;height: 100%;z-index: 2;}
#restaurantbus-container .hanbaiend:after {content: "販売終了しました"; font-size: 18px;font-weight: bold;color: #fff;position: absolute;top: 0;left: 0;z-index: 3;display: block;width: 100%;text-align: center;background: red;padding: 12px 6px;}
#restaurantbus-container .hanbaiend .plan-card.ico-card-kyoto::before{display: none;}

.plan-sakura-head{
    text-align: center;
    color: #fff;
    margin-bottom: 24px;
    font-size: 18px;
    font-weight: bold;
    font-family: "游明朝体", YuMincho, "游明朝", "Yu Mincho", "Hiragino Mincho ProN", Georgia, "HGS明朝E", "メイリオ", serif;
    line-height: 1.4;
}
.plan-pickup-title{
    text-align: center;
    color: #fff;
    margin-top: 48px;
    margin-bottom: 24px;
    font-size: 20px;
    font-weight: bold;
    font-family: "游明朝体", YuMincho, "游明朝", "Yu Mincho", "Hiragino Mincho ProN", Georgia, "HGS明朝E", "メイリオ", serif;
    line-height: 1.4;
}
.label-pickup-kyoto{
    background: #597b37;
    color: #fff;
    display: inline-block;
    padding: 3px 5px;
    font-size: 80%;
    border-radius: 2px;
    margin-right: 10px;
    position: relative;
    top: -2px;
}
.label-pickup-tokyo{
    background: #3f4a90;
    color: #fff;
    display: inline-block;
    padding: 3px 5px;
    font-size: 80%;
    border-radius: 2px;
    margin-right: 10px;
    position: relative;
    top: -2px;
}
.label-sakura-day{
    display: block;
    font-size: 30px;
    font-weight: bold;
    border-bottom: 1px dotted #fff;
    margin:6px auto 12px;
    padding-bottom: 6px;
    width: 66.66666%;
    text-align: center;
}
.card-plan-campprice{
    border-top:dotted 1px #fff;
    border-bottom:dotted 1px #fff;
    padding: 10px 12px 8px;
    margin-top: 12px;
}
.card-plan-campprice p{
    text-align: center;
    font-size: 14px;
}
#restaurantbus-container .card-plan-campprice p .plan-price span{
    line-height: 1;
    font-size: 24px;
}
#restaurantbus-container .card-plan-campprice p .plan-price{
    float: none;
}

.sakura-modal .modal-header{
    background: #597b37;
    color: #fff;
}
#tokyoarea .sakura-modal .modal-header{
    background: #3f4a90;
}
.btn-sakuraselect{
    display: block;
    margin: 0 auto;
    border: 2px solid #d31f27;
    background: #fff;
    color: #333 !important;
    border-radius: 50rem;
    font-size: 16px;
}
.btn-sakuraselect span{
    display: block;
    color: #d31f27 !important;
    font-size: 110%;
}
.btn-sakuraselect strong{
    font-size: 120%;
    font-weight: bold;
    color: #d31f27 !important;
}
.btn-sakuraselect:hover{
    background: #d31f27;
    color: #fff !important;
    border: 2px solid #d31f27;
}
.btn-sakuraselect:hover strong,
.btn-sakuraselect:hover span{
    color: #fff !important;
}
@media (max-width: 767px){
.label-sakura-day{
    width: 96%;
    font-size: 24px;
}
.btn-sakuraselect{
    font-size: 14px;
}
}
@media (max-width: 320px){
.label-sakura-day{
    width: 100%;

}
}

.plan-sakura-lead{
    text-align: center;
    margin-bottom: 24px;
    font-size: 14px;
    color: #fff;
}
.plan-sakura-lead span{
    font-size: 24px;
    font-weight: bold;
}
.plan-sakura-lead span:before{
    content: "＼";
    margin-right: 3px;
}
.plan-sakura-lead span:after{
    content: "／";
    margin-right: 3px;
}
.list-sakuranav{
    margin:0 auto 72px;
}
.list-sakuranav .link-sakuranav{
    padding: 0;
    margin:0;
    width: 33.33%;
    float: left;
}
.list-sakuranav .link-sakuranav a{
    display: block;
    text-align: center;
    color: #fff !important;
    border:solid 1px #fff;
    font-size: 13px;
    padding:12px 6px;
    position: relative;
}
.list-sakuranav .link-sakuranav a:after {
    content: "\f0dd";
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    left: 12px;
    transform: translate(0, -50%);
    font-size: 13px;
}
.list-sakuranav .link-sakuranav + .link-sakuranav a{
    border-left: none;
}
.list-sakuranav .link-sakuranav a:hover{
    color: #597b37 !important;
    text-decoration:none;
    background:#fff;
}
.list-sakuranav .link-sakuranav a span{
    display: block;
    font-size: 24px;
    font-weight: bold;
}


.list-oshinagaki{
    width:50%;
    margin:0 auto 36px;
}
.list-oshinagaki .link-oshinagaki{
    padding: 0 12px;
    margin:0;
    width: 50%;
    float: left;
    text-align: center;
}
.list-oshinagaki .link-oshinagaki a{
    display:block;
    text-align: center;
    border:2px solid #d31f27;
    background:#fff;
    color: #d31f27 !important;
    font-size: 13px;
    padding:6px 6px;
    position: relative;
    border-radius: 50rem;
}
/*.list-oshinagaki .link-oshinagaki + .link-oshinagaki{
    border-left: dotted 1px #fff;
}*/
.list-oshinagaki .link-oshinagaki a:hover{
    background:#d31f27;
    color: #fff !important;
}
.list-oshinagaki .link-oshinagaki a small{
    display: block;
}
.list-oshinagaki .link-oshinagaki a small:before {
    content: "\f2e7";
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    margin-right: 6px;
    font-size: 13px;
}
.card-oshinagaki-box{
    width: 33.333%;
    margin:0 auto 36px;
}
#restaurantbus-container .card-oshinagaki-box .btn-primary{
    border:2px solid #d31f27;
    background:#fff;
    color: #d31f27;
}
@media (max-width: 767px){
.plan-sakura-lead{
    margin-bottom: 12px;
}
.plan-sakura-lead br{
    display: none;
}
.plan-sakura-lead span{
    display: block;
    position: relative;
    margin-bottom: 6px;
}
.plan-sakura-lead span:before{
    content: "＼";
    position: absolute;
    top:50%;
    left: 5%;
    transform: translate(0, -50%);
}
.plan-sakura-lead span:after{
    content: "／";
    position: absolute;
    top:50%;
    right: 5%;
    transform: translate(0, -50%);
}
.list-oshinagaki{
    width:100%;
    margin:0 auto 24px;
}
.list-oshinagaki .link-oshinagaki{
    padding: 0 3px;
}
.list-sakuranav .link-sakuranav a{
    font-size: 12px;
    padding:12px 3px 24px 3px;
}
.list-sakuranav .link-sakuranav a:after {
    top: auto;
    bottom:6px;
    left: 50%;
    transform: translate(-50%, 0);
}
.list-sakuranav .link-sakuranav a span{
    font-size: 16px;
}
}
@media (max-width: 320px){
.list-sakuranav .link-sakuranav{
    width: 100%;
    float: none;
}
.list-sakuranav .link-sakuranav + .link-sakuranav a{
    border-left:solid 1px #fff;
    border-top: none;
}
.list-sakuranav .link-sakuranav a{
    text-align: left;
    padding: 12px 12px 12px 36px;
}
.list-sakuranav .link-sakuranav a span{
    display: inline;
    font-size: 120%;
    font-weight: bold;
    margin-right: 6px;
}
.list-sakuranav .link-sakuranav a br{
    display: none !important;
}
.list-sakuranav .link-sakuranav a:after {
    top: 50%;
    bottom:auto;
    left: 12px;
    transform: translate(0, -50%);
}
}


.row-kazokuwari{
    margin-top: 24px;
}
.wrap-kazokuwari{
    border:solid 2px #ff0000;
    padding: 6px;
    border-radius: 10px;
    background:#feebf2;
}
.wrap-nomalwari{
    border:solid 2px #fff;
    padding: 6px;
    border-radius: 10px;
}
.lead-kazokuwari{
    text-align: center;
    font-weight: bold;
    margin-bottom: 6px;
    font-size: 13px;
    color: #ff0000;
    line-height: 1.2 !important;
}
#restaurantbus-container .row-kazokuwari .plan-book-price{
    margin-top: 0;
}
#restaurantbus-container .plan-book-block .row-kazokuwari .btn-primary{
    margin-top: 0;
}
#restaurantbus-container .row-kazokuwari .plan-book-price small{
    font-size: 14px;
}
#restaurantbus-container .row-kazokuwari .plan-book-price span{
    font-size: 20px;
}

.row-event .card-title{
    position: relative;
    margin-bottom: 24px;
    padding-bottom: 12px;
}
.row-event .card-title:after{
    content: "";
    width: 100%;
    height: 3px;
    background: #fff;
    display: block;
    position: absolute;
    bottom: 0;
}
.row-event .card-title:before{
    content: "";
    width: 25%;
    height: 3px;
    background: #d31f27;
    display: block;
    position: absolute;
    bottom: 0;
    z-index: 1;
}

.wrap-tokuten{
    background: #fefdeb;
    padding: 12px;
    border-radius: 3px;
    margin-bottom: 24px;
}
.wrap-tokuten p{
    margin: 0;
    color: #4a4a00;
    padding-left: 72px;
    position: relative;
    font-weight: bold;
}
.wrap-tokuten p:before{
    content: "特典";
    position: absolute;
    background: #f3f34f;
    color: #333;
    display: inline-block;
    border-radius: 3px;
    padding: 3px 12px;
    font-size: 80%;
    left: 0;
}



/* 商品ボックスのレイアウトを変更。テキストが多くなってきたので黒背景だとわかりにく */
.card-plan-01{
    position: relative;
    overflow: hidden;
}
.card-plan-01 dt{
    margin-bottom: 12px;
}
.card-plan-01 dd{
    padding: 0;
}
.card-plan-01.card-kyoto dt.toriming{
    /* 一時的なクラス、/campaign/でしか使用していない */
    padding: 48px 12px;
    background: url(/restaurantbus/img/ui2019/plan-area-bg-kyoto.jpg) no-repeat center center;
    background-size: cover;
    text-align: center;
}
.card-plan-01.card-tokyo dt.toriming{
    /* 一時的なクラス、/campaign/でしか使用していない */
    padding: 48px 12px;
    background: url(/restaurantbus/img/ui2019/plan-area-bg-tokyo.jpg) no-repeat center center;
    background-size: cover;
    text-align: center;
}
.card-plan-01 dt.toriming img{
    width: auto !important;
    zoom: 0.3;
    background: #fff;
    padding: 12px;
}
.card-plan-01 dd + dd{
    margin-top: 12px;
}
#toparea .card-kyoto:before{
    content: "KYOTO";
    background: #597b37;
    color: #fff;
    display: block;
    width:calc(100% + 24px);
    margin: -12px -12px 12px;
    text-align: center;
    font-size: 13px;
    padding: 6px 3px;
    line-height: 1;
}
#toparea .card-tokyo:before{
    content: "TOKYO";
    background: #3f4a90;
    color: #fff;
    display: block;
    width:calc(100% + 24px);
    margin: -12px -12px 12px;
    text-align: center;
    font-size: 13px;
    padding: 6px 3px;
    line-height: 1;
}
.list-tag{}
.list-tag li{float: left;margin: 0 3px 3px 0;}
.list-tag li span{
    display: inline-block;
    color: #fff;
    border-radius: 2px;
    padding: 4px 6px 3px;
    line-height: 1;
}
.tag-lunch{
    background: #048F95;
}
.tag-dinner{
    background: #d37705;
}
.tag-experience{
    background: #ba1079;
}
.tag-time{
    background: #ba1079;
}
.card-plan-01 dd.course-title{
    font-size: 16px;
    font-weight: bold;
}
.course-title strong{
    font-size: 22px;
    display: block;
}
.card-kyoto .course-title{
    border-bottom: solid 1px #597b37;
    padding: 0 6px 6px 6px;
}
.card-kyoto .course-title{
    color: #597b37;
}
.card-tokyo .course-title{
    border-bottom: solid 1px #3f4a90;
    padding: 0 6px 6px 6px;
}
.card-tokyo .course-title{
    color: #3f4a90;
}
.card-plan-01 dd.course-price{
    border-top: solid 1px #ccc;
    padding: 6px 6px 0;
}
.course-price.plan-detail-price{
/*  border-top: solid 1px #ccc;*/
    padding: 6px 6px 0;
    margin-top: 10px;
}
.course-price-defo p{
    font-size: 14px;
    font-weight: bold;
}
.card-kyoto .course-price-defo p{
    color: #597b37;
}
.card-tokyo .course-price-defo p{
    color: #3f4a90;
}
.list-price{
    margin-top: 6px;
}
.list-price > li{
    text-align: right;
    font-weight: normal;
}
.list-price > li + li{
    margin-top: 6px;
}
.list-price .plan-price{
    font-weight: normal;
    font-size: 12px;
    line-height: 1.1;
}
.list-price .plan-price .num{
    color: #d31f27;
    font-size: 22px;
    font-weight: bold;
}
.list-price .plan-price .num:after{
    content: "円～";
    font-size: 12px;
}
.list-price .plan-price .num.only:after{
    content: "円";
}
.course-pickup{
    margin-top: 12px;
}
.box-pickup{
    background: #fefdeb;
    padding: 12px;
    border-radius: 3px;
}
.box-pickup.change-borderpink{
    border: dotted 1px #ef857f;
    background: #fff6f6;
}
.box-pickup p{
    color: #4a4a00;
    font-size: 14px;
}
.box-pickup p + p{
    margin-top: 6px;
    margin-bottom: 0;
}
.plan-detail-price .box-pickup p{
    font-size: 16px;
}
.text-red{
    color: #d31f27;
}
.text-blue{
    color: #1f5fd3;
}
.text-link{
    color: #007bff;
    text-decoration: underline;
}
.text-link:hover{
    text-decoration: none;
}
@media (max-width: 767px){
#toparea .card-kyoto:before,
#toparea .card-tokyo:before{
    width:calc(100% + 10px);
    margin: -5px -5px 12px;
}
}


.title-pricereserve{
    margin-top: 12px;
    font-size: 18px;
}
#kyotoarea .title-pricereserve{
    color: #597b37;
}
.detail-pricetable{
    margin-top: 12px;
}
.pickup-pricetable{
    background:#fff6e2;
    padding: 15px 20px;
}
.dl-pricetable{
    display: flex;
}
.dl-pricetable + .dl-pricetable{
    border-top: 1px dotted #ccc;
}
.dl-pricetable dt,
.dl-pricetable dd{
    padding: 3px 0;
}

.price-table-title,.price-table-title-6{
    width: 43%;
}
.txt-120{
	font-size: 120%;
}
.price-table-price,.price-table-price-4{
    width: 32%;
}
.price-table-btn{
    width: 25%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.price-table-price .plan-price .num,.price-table-price-4 .plan-price .num{
    color: #d31f27;
    font-size: 22px;
    font-weight: bold;
}
.price-table-price .plan-price .num:after,.price-table-price-4 .plan-price .num:after{
    content: "～";
    font-size: 12px;
}
.price-table-price .plan-price .num.min:after,.price-table-price-4 .plan-price .num.min:after{
    content: "円～";
    font-size: 12px;
}
.price-table-price .plan-price .num.only:after,.price-table-price-4 .plan-price .num.only:after{
    content: "円";
}
.price-table-price .plan-price .num.max:after,.price-table-price-4 .plan-price .num.max:after{
    content: "円";
}
#restaurantbus-container .price-table-btn .btn-primary{
    margin: 0;
    padding: 6px;
    font-size: 14px;
}

@media (max-width: 991px){
.pickup-pricetable{
    padding: 10px 10px;
    margin-left: -10px;
    margin-right: -10px;
}
.title-pricereserve{
    font-size: 16px;
}
.dl-pricetable{
    display: flex;
    flex-wrap: wrap;
}
.price-table-title{
    width: 50%;
}
.price-table-price{
    width: 50%;
}
.price-table-title-6{
    width: 60%;
}
.price-table-price-4{
    width: 40%;
	}
	
.price-table-btn{
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.price-table-price li{
    text-align: right;
}
	.price-table-price-4 li{
    text-align: right;
}
}


.modal-body .plan-details-body { padding: 0; }
.modal-body .details-schedule-wrap { position: relative; display: flex; }
.modal-body .schedule-time { position: absolute; display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 60px; height: 60px; border-radius: 50%; color: #fff; font-weight: bold; }
.modal-body .schedule-time-start { float: left;font-size: 12px; }
.modal-body .schedule-time-end { position: absolute; top: -10px; right: -70px; }
.modal-body .details-schedule-list { padding: 18px 0 0 0;display: flex; flex-wrap: wrap;width: 100%;}
.modal-body .details-schedule-list li { display: inline-block; float: left; position: relative; margin-right: 30px; margin-bottom: 1em; padding: 10px; border-radius: 6px; font-size: 12px; text-align: center; }
.modal-body .details-schedule-list li.ico-left-dots-sp { margin-left: 30px; }
.modal-body .details-schedule-list li::after, .modal-body .details-schedule-list li.ico-left-dots-sp::before { display: inline-block; position: absolute; top: 1em; width: 20px; height: 15px; -webkit-mask-image: url("/restaurantbus/img/ui2019/dots.svg"); mask-image: url("/restaurantbus/img/ui2019/dots.svg"); content: ""; }
.modal-body .details-schedule-list li::after { right: -30px; }
.modal-body .details-schedule-list li.ico-left-dots-sp::before { left: -30px; }
.modal-body .details-schedule-list li:first-child { margin-left: 70px;}
.modal-body .details-schedule-list li:last-child::after { display: none; }
/*.modal-body .details-schedule-list li:first-child { width: 46vw; margin-left: 70px; }
.modal-body .details-schedule-list li:last-child { display: block; float: right; width: 46vw; margin-right: 65px; margin-left: calc(1vw + 71px); }
.modal-body .details-schedule-list li:first-child::after, .modal-body .details-schedule-list li:last-child::after { width: 20px; right: -74px; }
.modal-body .details-schedule-list li:first-child::before, .modal-body .details-schedule-list li:last-child::before { display: block; position: absolute; right: calc(-45px - 4px); width: 38px; height: 18px; background: url("/restaurantbus/img/ui2019/ico-bus.png") center / contain no-repeat; content: ""; }
.modal-body .details-schedule-list li:last-child::before { left: calc(-45px - 4px); }*/
.modal-body .details-schedule-list li em { display: block;padding: 3px 6px; border-radius: 100px; background: #d31f27; color: #fff; font-weight: bold; font-size: 10px; text-align: center; line-height: 1.2; }
.schedule-time-em{
	position: absolute;
    left:0;
    top: 65px;
    font-size: 11px;
	text-align: center;
	color: #b21920;
}
.schedule-time-em-end{
	position: absolute;
    right:-75px;
    bottom: -30px;
    font-size: 11px;
	text-align: center;
	color: #b21920;	
}

@media all and (max-width: 320px) {.modal-body .details-schedule-wrap { margin: 0 -14px; }
    .modal-body  .details-schedule-list li { padding: 10px 5px; }
    .modal-body  .details-schedule-list li:first-child, .modal-body  .details-schedule-list li:last-child { width: 42vw; }
	.schedule-time-em-end{
	position: absolute;
    right:-75px;
    bottom: -10px;
    font-size: 11px;
	text-align: center;
}
}
@media all and (min-width: 768px) { 
    /* Schedule */
    #restaurantbus-container.modal-body .plan-details-body { padding: 67px 80px 80px; }
    .modal-body .schedule-time { display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 68px; height: 68px; font-size: 18px; }
    .modal-body .schedule-time-end { position: absolute; right: -90px; }
    .modal-body .details-schedule-list { padding: 18px 0 0 0;display: flex; flex-wrap: wrap;width: 100%;}
    .modal-body .details-schedule-list li { margin-right: 50px; padding: 14px 18px; font-size: 13px; }
    .modal-body .details-schedule-list li.ico-left-dots-sp { margin-left: 0; }
    .modal-body .details-schedule-list li::after { top: 1.2em; right: -45px; width: 30px; }
    .modal-body .details-schedule-list li.ico-left-dots-sp::before { content: none; }
    /*.modal-body .details-schedule-list li:first-child { width: calc(100% - 140px); margin-left: 0; margin-right: 140px; }
    .modal-body .details-schedule-list li:last-child { width: calc(100% - 230px); margin-right: 90px; margin-left: 140px; }
    .modal-body .details-schedule-list li:first-child::after, .modal-body .details-schedule-list li:last-child::after { width: 70px; right: -140px; }
    .modal-body .details-schedule-list li:last-child::after { left: -140px; }
    .modal-body .details-schedule-list li:first-child::before, .modal-body .details-schedule-list li:last-child::before { right: -62px; width: 47px; height: 22px; }
    .modal-body .details-schedule-list li:last-child::before { left: -62px; }*/
    .modal-body .details-schedule-list li:first-child { margin-left: 90px;}
    .modal-body .details-schedule-list li:last-child::after { display: none; }
    .modal-body .details-schedule-list li em { font-size: 12px; }
.schedule-time-em{
	position: absolute;
    left: -15px;
    top: 85px;
    font-size: 12px;
}
.schedule-time-em-end{
	position: absolute;
    right:-90px;
    bottom: -40px;
    font-size: 12px;
	text-align: center;

}
	
}
.modal-body .details-schedule-list li::before, .modal-body .details-schedule-list li::after { background: #597b37; }
.modal-body .details-schedule-list li { border: 2px solid rgba( 89, 123, 55, .7 ); } /* #597b37 opacity 70% */
.modal-body .details-schedule-list li.spot-momiji { border: 2px solid #ee7b00;background: #fff6ed;position: relative; } /* #597b37 opacity 70% */
.modal-body .details-schedule-list li.spot-momiji:before {
    content: "";
    width: 32px;
    height: 26px;
    background: url(/restaurantbus/kyoto/img/2021autumn/icon-momiji.png) no-repeat;
    background-size: cover;
    position: absolute;
    top: -14px;
    left: -10px;
} 
.modal-body .color-primary-bg {
    background: #597b37;
}
.modal-body .btn-primary { display: block; margin: 0 auto; background: #d31f27; border: none; border-radius: 50rem; font-weight: bold; font-size: 14px;outline:none;color: #FFF; }
.modal-body .btn-primary:hover { opacity: .7; }

.modal-body .r-btn .btn-primary:active,.modal-body .r-btn .btn-primary:focus,.modal-body .r-btn .btn-primary:link { border: none!important;  box-shadow: none!important;  background: #d31f27; outline:none!important; }

.tbl-menu{
    border-top: 1px solid #eee;
    border-right: 1px solid #eee;
    width: 100%;
    margin-bottom: 60px;
}
.tbl-menu th,
.tbl-menu td{
    border-bottom: 1px solid #eee;
    border-left: 1px solid #eee;
    background: #fff;
    width: 25%;
}
#tokyoarea .tbl-menu th,
.wrap-tokyo .tbl-menu th,
.wrap-normal-two .tbl-menu th{
    width: 25%;
}
#tokyoarea .tbl-menu td,
.wrap-tokyo .tbl-menu td,
.wrap-normal-two .tbl-menu td{
    width: 37.5%;
}
.tbl-menu thead th{
    text-align: center;
    padding: 5px;
}
.tbl-menu thead th.th-plantitle{
    border-bottom: none;
    background: #ffeae7;
    color: #fff;
    font-size: 18px;
    position: relative;
    padding: 0;
    overflow: hidden;
}
.tbl-menu thead th.th-kyotodep{
    background: url(/restaurantbus/kyoto/img/2022spring/restaurant_bus_sakura.jpg) no-repeat bottom center;
    background-size: cover;
}
#tokyoarea .tbl-menu thead th.th-kyotodep,
.wrap-tokyo .tbl-menu thead th.th-kyotodep{
    background: url(/restaurantbus/tokyo/img/ui2019/restaurant_bus_thum.jpg) no-repeat bottom center;
    background-size: cover;
}
.tbl-menu thead th.th-plantitle b{
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
    background: rgba(223, 134, 126, 0.6);
    text-align: center;
    width: 100%;
}
.tbl-menu thead th.th-plantitle b span{
    margin-left: 3px;
}
.tbl-menu thead th.th-kyotodep b{
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
    background: rgba(89, 123, 55, 0.5);
    text-align: center;
    height: 100%;
    width: 100%;
    display: flex;
    padding: 0;
    align-items: end;
    justify-content: center;
    font-size: 18px;
}
#tokyoarea .tbl-menu thead th.th-kyotodep b,
.wrap-tokyo .tbl-menu thead th.th-kyotodep b{
    background: rgba(63, 74, 144, 0.5);
}
.tbl-menu thead th.th-plantitle img{
    position: relative;
}
.tbl-menu thead th.th-plantime{
    font-size: 13px;
    padding: 0;
    border-bottom: none;
    background: #fafafa;
}
.list-dep{
    text-align: left;
    margin-bottom: 5px;
    padding: 0 5px 2px;
}
.list-dep li{
    font-size: 16px;
    font-weight: bold;
    border-bottom: dotted 1px #ccc;
    color: #597b37;
}
#tokyoarea .list-dep li,
.wrap-tokyo .list-dep li{
    color: #3f4a90;
}
.tbl-menu tbody th{
    padding: 15px 10px;
    background: #ebf4e3;
    border-bottom: dotted 1px #afcd91;
}
#tokyoarea .tbl-menu tbody th,
.wrap-tokyo .tbl-menu tbody th{
    background: #f0f2ff;
    border-bottom: dotted 1px #8c96d0;
}
.tbl-menu tbody td{
    vertical-align: middle;
}
.tbl-menu td.td-kazokuwari{
    text-align: center;
    padding: 4px 10px 2px;
    background: #fff6e2;
    color: #9b7c36;
    border-bottom: none !important;
    font-weight: bold;
}
.th-kikan{
    text-align: center;
    font-weight: normal;
}
.btn-detail-stop .th-kikan{
    background: #eee !important;
}
.text-fromto{
    display: block;
    font-weight: bold;
    font-size: 20px;
    color: #597b37;
}
#tokyoarea .text-fromto,
.wrap-tokyo .text-fromto{
    color: #3f4a90;
}
.btn-detail-stop .text-fromto{
    color: #666 !important;
}
.tbl-planlink{
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    padding: 15px 10px;
    text-align: center;
}
.tbl-planlink:hover{
    background: #fafafa;
}
.btn-detail{
    background: #597b37;
    color: #fff;
    position: relative;
    display: inline-block;
    border-radius: 100px;
    font-size: 13px;
    padding: 4px 8px 3px;
    line-height: 1;
    margin-top: 10px;
    border: solid 1px #597b37;
}
.btn-detail:after{
    content: "\f35a";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    margin-left: 5px;
}
.btn-detail-stop .btn-detail:after{
    display: none;
}
.btn-detail-stop .btn-detail{
    background: #ccc !important;
    color: #666 !important;
    border: solid 1px #597b37 !important;
}
#tokyoarea .btn-detail,
.wrap-tokyo .btn-detail{
    background: #3f4a90;
	border: solid 1px #2c3678 !important;
}
.tbl-planlink:hover .btn-detail{
    background: #fff;
    color: #597b37;
}
#tokyoarea .tbl-planlink:hover .btn-detail,
.wrap-tokyo .tbl-planlink:hover .btn-detail{
    background: #fff;
    color: #3f4a90;
}
.label-lightup{
    position: absolute;
    top: -45px;
    left:50%;
    background: #df867e;
    z-index: 1;
    text-align: center;
    display: inline-block;
    font-size: 12px;
    color: #fff;
    padding: 4px 6px 4px;
    line-height: 1.1;
    width: 70%;
    transform: translate(-50%, 0);
}
.label-lightup:before {
    border: 16px solid transparent;
    border-top: 16px solid #df867e;
    left: 50%;
    content: "";
    display: block;
    bottom: -30px;
    position: absolute;
    z-index: -1;
    transform: translate(-50%, 0);
}
.tbl-price{
    display: flex;
    align-items: flex-start;
}
.tbl-price + .tbl-price{
    margin-top: 5px;
}
.tbl-waribiki{
    background: #fff6e2;
    padding: 5px;
}
.tbl-price li{
    width: 50%;
    font-size: 10px;
    text-align: center;
    align-items: flex-start;
}
.tbl-price li small{
    font-size: 13px;
}
.text-price{
    font-size: 22px;
    color: #d31f27;
    font-weight: bold;
}

.bnr-plan img{
	border: 1px solid #5a1b1e;
}
.bg-furupo{
	background: url("/restaurantbus/tokyo/img/bg-furupo.png") ;
	background-size: cover;
    background-position: center;
	padding: 20px 0 0;
	border: 2px solid #f8f6e8;
}


.txt-nouzei {
  position: relative;
  padding: 0 1rem;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  color: #eaad52;
  width: 220px;
  margin: 0 auto;
}
.txt-nouzei::before, .txt-nouzei::after {
  position: absolute;
  top: 2px;
  height: 20px;
  content: '';
}
.txt-nouzei::before {
  border-left: solid 4px;
  border-radius: 80px;
  left: 0;
  transform: rotate(-30deg);
}
.txt-nouzei::after {
  border-right: solid 4px;
  border-radius: 80px;
  right: 0;
  transform: rotate(30deg);
}





#restaurantbus-container .btn-furupolink{
	padding: 14px 5px;
	border-radius: 60px;
	background: #FFBF60;
	width: 98%;
	max-width: 300px!important;
	margin: 5px auto;
	display: block;
	font-weight: bold;
	color: #000;
	text-align: center;
	border: 2px solid #FFF;

}
#restaurantbus-container .btn-furupolink:hover{
	opacity:0.7;
}




#restaurantbus-container .btn-furupo{
	padding: 10px;
	border-radius: 60px;
	background: linear-gradient(62deg, #cb1b45, #df5c34);
	width: 90%;
	max-width: 600px!important;
	margin: 10px auto;
	display: block;
	font-weight: bold;
	color: #FFF;
	text-align: center;

}
#restaurantbus-container .btn-furupo:hover{
	opacity:0.7;
}
.ti-furupo{
	padding: 0 20px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 3px;
}
.txt-center{
	text-align: center;
}

.mv-tokyo{
	padding-top:110px!important;
}


@media (max-width: 992px){
.tbl-price{
    display: block;
}
.tbl-price li{
    width: 100%;
}
	
}

@media (max-width: 768px){
#tokyoarea .tbl-menu th,
.wrap-tokyo .tbl-menu th{
    width: 25%;
}
#tokyoarea .tbl-menu td,
.wrap-tokyo .tbl-menu td{
    width: 37.5%;
}
.th-plandep ul{
    display: block;
}
.list-dep li{
    font-size: 12px;
    margin-bottom: 3px;
}
.tbl-menu thead th.th-plantitle{
    font-size: 12px;
    padding-top: 5px;
    vertical-align: top;
	background:#fefce5;
}
.tbl-menu thead th.th-plantitle b{
    position: relative;
    bottom: 0;
    left: 0;
    z-index: 1;
    background: none;
    text-align: center;
    width: 100%;
    color: #efc25c;
    display: block;
    margin-bottom: 3px;
}
.tbl-menu thead th.th-plantitle b span{
    display: block;
    line-height: 1;
}
.tbl-menu thead th.th-kyotodep b{
    position: absolute;
    bottom: auto;
    top: 0;
    left: 0;
    z-index: 1;
    background: rgba(89, 123, 55, 0.5);
    text-align: center;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-end;
    padding: 0;
    justify-content: center;
    font-size: 12px;
    color: #fff;
}
.tbl-menu tbody th{
    padding: 15px 0px;
}
.tbl-menu tbody td{
    vertical-align: top;
}
.tbl-menu td.td-kazokuwari{
    font-size: 13px;
}
.th-kikan{
    font-size: 12px;
}
.text-fromto{
    font-size: 13px;
}
.tbl-planlink{
    padding: 10px 1px 10px;
}
.label-lightup{
    position: absolute;
    top: -55px;
    width: 80%;
    padding: 4px 3px 4px;
}
.btn-detail{
    font-size: 12px;
    padding: 3px 6px 2px;
}
.btn-detail span{
    display: none;
}
.tbl-price{
    display: block;
}
.tbl-price li{
    width: 100%;
    font-size: 10px;
}
.tbl-price li + li{
    margin-top: 5px;
}
.tbl-price li small{
    font-size: 11px;
}
.text-price{
    font-size: 15px !important;
    letter-spacing:-0.5px;
}
.list-kazokuwari span{
    font-size: 12px;
}
.txt-sp-center{
		text-align: center;
		
	}
	
.mv-tokyo{
	padding-top:30px!important;
}	
}



.img-iconyake{
    width: 40px;
    height: 40px;
    border-radius: 100px;
    position: absolute;
    top: -15px;
    left: -20px;
    border: 1px solid #faf6c1;
    background: #111;
    color:#faf6c1;
    font-size: 11px;
    line-height: 1.2;
    display: flex;
    justify-content: center;
    align-items: center;
}
@media (max-width: 991px){
.text-gion{
	margin-top:50px;
}
}
/*花見コース*/

.tbl-menu.tbl-hanami tbody th.th-hanami{
	 background: #fdf5ef!important;
	 border-bottom: dotted 1px #f2caad!important;
}
.th-hanami .text-fromto{
	color:#df6554!important;
}
.tbl-hanami .list-dep li{
	color:#df6554!important;
}
.tbl-hanami .btn-detail{
	background:#df6554!important;
	border: solid 1px #dc6a5b!important;
}

#tokyoarea .tbl-hanami .btn-detail{
	background:#df6554!important;
	border: solid 1px #dc6a5b!important;
}

.tbl-hanami .tbl-planlink:hover .btn-detail{
    background: #fff!important;
    color: #df6554!important;
}
.txt-hanami{
	font-size: 0.9em!important;
	background: #FFF!important;
    padding: 5px!important;
    width: 95%!important;
    margin: 5px auto!important;
	max-width: 550px!important;
}
.txt-hanami li span{
	color:#df867e!important; 
	font-weight: bold!important;
}
.txt-hanami li i{
	color: #df6554!important;
	margin-right: 3px!important;
}
.th-hanami .btn-route{
	background: #df6554!important
}



@media(max-width:767px) {
	
}


/*花見コース　end*/

/*和食コース*/

.tbl-menu.tbl-japanese tbody th.th-japanese{
	 background: #f3fdef!important;
	 border-bottom: dotted 1px #a5c997!important;
}
.th-japanese .text-fromto{
	color:#41742e!important;
}
.tbl-japanese .list-dep li{
	color:#41742e!important;
}
.tbl-japanese .btn-detail{
	background:#dc6a5b!important;
	border: solid 1px #dc6a5b!important;
}

.tbl-japanese .btn-detail{
	background:#41742e!important;
	border: solid 1px #41742e!important;
}

.tbl-japanese .tbl-planlink:hover .btn-detail{
    background: #fff!important;
    color: #41742e!important;
}
.txt-japanese{
	font-size: 0.9em!important;
	background: #FFF!important;
    padding: 5px!important;
    width: 95%!important;
    margin: 5px auto!important;
	max-width: 550px!important;
}
.txt-japanese li span{
	color:#df867e!important; 
	font-weight: bold!important;
}
.txt-japanese li i{
	color: #41742e!important;
	margin-right: 3px!important;
}

.th-japanese .btn-route{
	background: #41742e!important
}


/*和食コース end*/


.text-green{
	color: rgb(23 157 168)!important;
}

.tab-seat{
	margin-bottom: 20px;
}

.nav-tabs.tab-seat{
	border-bottom: 2px solid #EEE;
}

.nav-tabs.tab-seat .nav-item {
    margin-bottom: -2px;
}

.nav-tabs.tab-seat .nav-item.show .nav-link, .nav-tabs.tab-seat .nav-link.active {
    color: #495057;
    background-color: #fff;
    border-color: #EEE #EEE #fff;
	background:#fff;
}

.nav-tabs.tab-seat .nav-link {
    border: 2px solid transparent;
    border-top-left-radius: 0.25rem;
    border-top-right-radius: 0.25rem;
	background:rgba(252,233,233,1.00);
}
.nav-tabs.tab-seat .nav-link::before{
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    content: "\f0da";
    font-family: "Font Awesome 5 Free";
 
}
.nav-tabs.tab-seat .nav-link.active::before{
    content: '\f0d7';
    font-family: "Font Awesome 5 Free";
    position: absolute;
    right: 50%;
    transform: translate(50%, 50%);
}


.nav-tabs.tab-seat .nav-link.a:hover{
	text-decoration: underline;
}
.txt-priod{
	margin: 0 0 10px;
	color: #b21920;
	font-weight: bold;
	width: 220px;
}

.txt-ryokosien{
	color: #b21920;
	font-weight: bold;
	font-size: 1.2em;
}

.bg-green{
	background: #ebf4e3;
	padding: 10px;
}
.bg-green .txt-priod{
	color: #597b37;
	font-size: 1.2em;
	width: 100%;
}
.bg-pink{
	background: #fdf5ef!important;
	padding: 10px;
}
.bg-pink .txt-priod{
	color: #df6554!important;
	font-size: 1.2em;
		width: 100%;
}
.link-plan {
	width:98%;
	justify-content: center;
	align-content:  center;
	margin: 10px auto 0;
	align-items:  stretch;
}
.link-plan li {
	justify-content: center;
	
}
.link-plan li a{
	font-size: 13px;
	line-height: 16px;
	display: inline-block;
	background: #FFF;
	border-radius: 100px;
	margin: 0 6px;
	padding: 10px 20px 10px 10px;
	position: relative;
	align-items:center;
	text-align: center;
}


.link-plan li .plan-end{
	pointer-events: none;
	position: relative;
}

.link-plan li .plan-end:before{content: "";position: absolute;top: 0;left: 0;background: rgba(0, 0, 0, 0.7);width: 100%;height: 100%;z-index: 2;border-radius: 100px;}

.link-plan li .plan-end:after {content: "販売終了"; font-size: 16px;font-weight: bold;color:#d31f27;position: absolute;top:50%;left: 0;z-index: 3;display: block;width: 100%;text-align: center;padding: 12px 6px;}




.link-plan li a span{
	background: #F14482;
	display: inline-block;
	color: #FFF;
	padding: 2px;
	margin-right: 3px;
	font-size: 0.8em;
	font-weight: normal;
}

.link-plan li a:after{
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translate(0, -50%);
    content: "\f078";
    font-size: 11px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
	color: #3f4a90;
}
.link-plan li a:hover{
	opacity: 0.7;
}
.txt-small-pc{
	font-size: 11px!important;
}

.box-special{
	padding-top: 10px!important;
	background:#F2F2FD;
	border: 2px solid #3f4a90!important;
	padding: 10px 0 10px 4px;

	
}
.box-special .btn-primary{
	margin: 5px auto 0!important;
}
.box-special dd:last-child{
	display: flex;
	align-items: center;
}
.details-spot-map{
		text-align: center;
}
.details-spot-map img{
	width: 80%;
	max-width: 400px;

}
.details-spot-map.g-map{
width: 100%;
  position: relative;
  padding-top: 56.25%;
	}	


.details-spot-map.g-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


@media (max-width: 992px){
.link-plan li a{
	justify-content: center;
	align-content:  center;	
	height: 80px;
	display: flex;
	flex-direction: column;
	border-radius: 20px;
	

}
		.txt-center-sm{
		text-align: center;
	}
.txt-small-pc{
	font-size: 14px!important;
}
	
}

@media (max-width: 767px){
	
.link-plan{
	flex-wrap: wrap; /*--折り返しの指定--*/
	width: 98%;
	}
	
.link-plan li{
			width: 50%;
	padding: 0 3px;
	

	}	
.link-plan li a{
	font-size: 11px;
	line-height: 14px;
	width: 100%;
	margin: 0 2px;
	padding: 0 10px 0 5px;
	justify-content: center;
	align-content:  center;	
	margin-bottom: 10px;
	height: 50px;
	display: flex;
	border-radius: 100px;
}	
	
	.link-plan li a span{
		display: none;
	}	

.details-spot-map.g-map{
width: 96%;
	height: 260px;
	}		
	
}
/* ルートモーダル用CSS　*/
.btn-route{
	display: block;
	color: #FFF!important;
	font-weight: bold;
	padding: 8px 0 8px 10px;
	max-width: 140px;
	background: #3f4a90;
	border-radius: 60px;
	position: relative;
	margin: 10px auto;
	text-align: center;
}


.btn-route::before{
  font-family: 'Font Awesome 5 Free';
  position: absolute;
  font-weight: 900;
  content: "\f3c5";
  left: 16px;	
}
.btn-route:hover{
	opacity: 0.7;
}

.modal-body.modal-route .details-schedule-list li{
	border: 4px solid rgba( 63, 74, 144, .7 );
}
.modal-body.modal-route .color-primary-bg{
	background: #3f4a90;
}
.modal-body.modal-route .details-schedule-list li::before, .modal-body .details-schedule-list li::after {
    background: #3f4a90;
}

.modal-footer.footer-route .btn-close{
	padding: 8px 12px;
}


.tab-route.nav-tabs{
	width: 100%;
	justify-content: space-between;
	border-bottom: none;
	align-items: stretch;

}
.tab-route.nav-tabs .nav-link{
	padding: 12px;
	border-radius: 8px;
	border: 2px solid #3f4a90;
	color: #3f4a90;
	height: 100%;
	font-weight: bold;
}
.tab-route.nav-tabs .nav-link span{
	font-size: 14px;
}
.tab-route.nav-tabs .nav-link:hover{
	background: #3f4a90;
	color: #FFF;

}
.tab-route.nav-tabs .nav-link.active {
	background: #3f4a90;
	color: #FFF;
	border: 2px solid #e2c56f;
}
.tab-route li{
	width: 24%;
}
.tit-route{
	padding: 30px 0 10px;
    font-size: 20px;
	color: #3f4a90;
	font-weight: bold;
	text-align: center;
}	
.color-red{
	color:#d31f27 ;
}


.modal .details-schedule-list{
	max-width:680px;
	padding: 10px 0 15px 10px!important;
}


@media (max-width: 992px){
	.tab-route.nav-tabs .nav-link{
	padding: 8px;
}

	.modal .details-schedule-list{
	max-width:380px;
}

	.modal 	.spot-photos-block-inner em{
		font-size: 0.8em!important;
	}
}

@media (max-width: 767px){
	.btn-route{
		font-size: 11px;
		width: 95%;
		padding: 6px 0 6px 10px;
	}

.btn-route::before{
  left: 8px;	
}	
	
	.modal-body.modal-route{
		padding: 20px 0;
	}	
	
	.modal-body.modal-route .schedule-time-start{
		left: 20px;
	}
	
	.modal-body.modal-route .details-schedule-wrap{
		padding: 0 20px;
	}
	
	.details-spot-map{
		margin:0 auto 16px;
		width: 95%;
	}	
	
	.modal-body.modal-route .plan-details-body .note{
		padding: 0 20px;
	}
.tab-route li{
	width: 49%;
	margin-bottom: 10px!important;
}	
.tab-route.nav-tabs .nav-link{
	padding: 8px;
	font-weight: bold;
}
.tab-route.nav-tabs .nav-link span{
	font-size: 12px;
	line-height: 16px;
	display: inline-block;
}	
	
	
}
	
/* ルートモーダル用CSSここまで　*/


/*プランレイアウト調整　ここから*/

.box-plan {
	display: flex;
	align-items: flex-start;
}

.box-plan-left {
	width: 60%;
}

.box-plan-right {
	width:40%;
	margin-left: 2%;
}

@media (max-width: 1200px) {

	.box-plan-left {
		width: 46%;
	}

	.box-plan-right {
		width: 54%;
	}
	
}
@media (max-width: 1023px) {
	.box-plan {
		flex-wrap: wrap;
	}

	.box-plan-left {
		width: 100%;
	}

	.box-plan-right {
		width: 100%;
		margin-left: 0;
	}
	
}

@media (max-width: 767px) {
	.sp-flexReverse {
		display: flex;
		flex-wrap: wrap;
		flex-direction: column-reverse;
	}
}

/*プランレイアウト調整　ここまで*/

/*テレビ放送対応*/
.pickup-info{
	background: #c61921;
	color: #fff;
	padding: 10px 0;
	width: 100%;
	text-align: center;
}

.color-tokyo .pickup-info{
	background:#3f4a90;
}


#restaurantbus-container .pickup-info a{
	color: #fff;
	text-decoration: underline;
}
a.link-down{
	position: relative;
	display: block;
	margin: 0 auto;
	width: 180px;
}
a.link-down::after{
	position: absolute;
    top: 50%;
	right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "\f107";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 20px;
}

.ico-tv{
	position: relative;
}

.ico-tv::after{
	 content: ''; /*何も入れない*/
	position: absolute;	
	z-index: 3;
  width:200px; /*画像の幅*/
  height: 80px; /*画像の高さ*/
  background: url(/restaurantbus/img/icon_tv.svg) no-repeat;
  background-size: contain;
  vertical-align: middle;	
	left: 10px;
	top:10px;
}

@media (max-width: 767px) {
	.pickup-info p{
		font-size: 12px;
	}
	a.link-down{
        width: 150px;
        font-size: 13px;
    }
    .ico-tv::after{
        width: 98%; /*画像の幅*/
        height: ; /*画像の高さ*/
        left: 0;
        top:3px;
    }	
}
/*テレビ放送対応　ここまで*/



/*アレルギー表記テーブル ここから*/
.allergy-table th {white-space: nowrap; text-align: center;}
.allergy-table .table1 thead td,.allergy-table .table1 thead th {background-color:#e7e7e7;text-align:center;font-weight:bold;}
.allergy-table .table1 th,.allergy-table .table1 td{border: 1px solid #cccccc;border-collapse: collapse;padding:14px;text-align: center;}
.allergy-table .table1 td{background-color:#ffffff;    line-height: 1.5;}
.allergy-table .table1 th{background-color:#e7e7e7;font-weight: bold;}
.allergy-table .table1 th:nth-child(1){width: 120px;}
.allergy-table .table1 {width: 100%;}

@media(max-width:767px){
	.tbl-wrap{width: 100%; overflow-x: auto;}
    .allergy-table .table1 {
       overflow-x: scroll;
       white-space: nowrap;
       -webkit-overflow-scrolling: touch;
    }
}
.allergy-table .table1 td:nth-child(1){
  text-align: left;
}
/*アレルギー表記テーブル ここまで*/




.menu-color-box {
    padding: 20px;
    background-color: #EEE;
}

/*クリスマスメニュー ここから*/
.xmas-menu-box {
    padding: 136px 20px 20px 30px;
    background-color: #fffaf0;
    border-top: 6px solid #19311d;
    border-left: 6px solid #87212d;
    border-right: 6px solid #87212d;
    border-bottom: 6px solid #19311d;
    position: relative;
}

.xmas-menu-box::before{
    content: '';
    position: absolute;
    z-index: 1;
    display: block;
    left: 50%;
    top: 5px;
    transform: translateX(-50%);
    width: 80%;
    height: 135px;
    background: url("../../tokyo/img/christmas/img-xmas-menu-head-pc.svg") no-repeat center center/ 100%;
}

/*スライダー*/
#restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-arrow, #restaurantbus-plan-details .restaurantbus-plan-details-menu .slide-wrap .slick-arrow:hover {
    background: #19311d;
}

#restaurantbus-plan-details .xmas-menu-box .details-slide .slick-dots li.slick-active button:before {
    background: #87212d;
}


@media(max-width:767px) {
   .xmas-menu-box {
        padding: 100px 16px 30px;
    }
    .xmas-menu-box::before{
        top: 10px;
        width: 84%;
        height: 76px;
        background: url("../../tokyo/img/christmas/img-xmas-menu-head-sp.svg") no-repeat center center/ 100%;
    }
}

/*クリスマスメニュー ここまで*/

/*ふきだしタイトル*/

.balloon1 {
  position: relative;
  display: inline-block;
  margin: 0 auto 1.5em;
  padding: 16px 20px;
  min-width: 120px;
  width: 100%;
	max-width:780px;
  font-size: 16px;
  background: #FFF;
  outline: 5px solid #fdf5ef!important;
	text-align: center;
}

.balloon1:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 15px solid #FFF;
}

.balloon1 p {
  margin: 0;
  padding: 0;
}
.balloon1 dl dt{
	color: #b21920;
	margin-bottom: 8px;
	text-align: center;
}

.balloon1 dl dd{
	font-size: 14px;
	padding-left: 28px;
	position: relative;
	max-width: 350px;
	margin: 0 auto 8px;
}

.balloon1 dl dd::before{
	  content: '';
  width: 20px;
  height:20px;
  background-repeat: no-repeat;
  background-size: contain;
  transform: translate(-50%, 0);
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);	
  top: 0;
  left: 1%;
  position: absolute;
	 background-image: url(/restaurantbus/tokyo/img/2024spring/ico-sakura.png);
	
}
.txt-attention{
	font-size: 0.8em;
	color: #b21920;
}
.balloon1 .txtlink{
	padding: 0!important;
	color: #007bff!important;
	border-bottom: solid 1px #007bff!important;
	line-height: 1.6!important;
	
}

@media(max-width:767px) {
	.balloon1 {
		padding: 16px;
		text-align: left;
	}	
	.balloon1 dl dt{
		font-size: 17px;
}
	.balloon1 dl dd{
	font-size: 13px;
		padding-left: 18px;
}
	
}



/*ふきだしタイトル　ここまで*/



.txt-end{
	position: relative;
	
	
}

.txt-end::after{
	position: absolute;
	content: "運行終了しました";
	color:#fff;
	font-weight: bold;
	font-size: 2em;
	padding-top: 17vw;
	text-align: center;
	height: 43vw;
    max-height: 600px;
	background-color: rgba(0,0,0,0.7);
	width: 100%;
}


@media(max-width:767px) {
	.txt-end::after{
		height: 80vw;
	padding-top: 35vw;		
	}
}



/*20240521追記*/
/*【ランチ限定】お子様連れ家族プラン*/
.familyplan .campaign-text{
	background:#fff6e2;
    padding: 0.5em 1em;
    background: repeating-linear-gradient(-45deg, #fff, #fff6e2 3px, #fff6e2 3px, #fff6e2 7px);
    border-left: solid 10px #d31f27;
	box-shadow: 0 3px 4px rgba(0, 0, 0, 0.1);/*影*/
}

.familyplan dd {
    display: flex;
    align-items: center;
    /*justify-content: center;*/
}

/*隣接する直前のdl*/
.dl-pricetable:has(+ .familyplan){
	border-bottom: 1px dotted #ccc;
	padding-bottom: 1rem !important;
}

/*隣接する直後のdl*/
.familyplan + dl{
	border-top: 1px dotted #ccc;
	margin-top: 1rem !important;
}

@media(min-width:768px){
	.familyplan .familyplan-br{
		margin-left: 1em;
	}
}


@media(max-width:767px) {
	
	.familyplan dd.price-table-price-4{
		justify-content: flex-end;
	}
	
	.familyplan .price-table-btn{
		padding-top: 1rem !important;
	}
	
	.familyplan small{
		font-size: 75%;
	}
}


/***** 202406 期間限定 ビアガーデンプラン */
.w-100 {
    width: 100%;
}

/* link */
.link-inline {
    text-decoration: underline;
}

/* button */
#restaurantbus-container .price-table-btn .btn-primary.btn-pickup {
    background: #eed00c;
    box-shadow: 2px 2px 2px rgba(0,0,0,0.3);
}

.plan-pickup {
    border: 1px dashed #777;
    padding: 16px 10px;
    background: #fcf2ea;
}

.plan-pickup .price-table-btn {
    width: 31%;
}

#restaurantbus-container .plan-beergarden .bg-yellow {
     background: #fefce5;
}

#restaurantbus-container .plan-beergarden .color-yellow {
     color: #e8aa02;
}

#restaurantbus-container .plan-beergarden .tbl-planlink .btn-detail {
    background: #e8aa02;
    border: 1px solid #e8aa02 !important;
}

#restaurantbus-container .plan-beergarden .th-kikan .btn-route {
    background: #e8aa02;
}

#restaurantbus-container .plan-beergarden .tbl-planlink:hover .btn-detail {
    color: #e8aa02;
    background: #fff;
}

#restaurantbus-container .plan-beergarden .tbl-planlink .btn-detail:hover {
    color: #e8aa02;
}

#restaurantbus-container .plan-beergarden .tbl-planlink {
    padding: 10px 6px;
}

#restaurantbus-container .plan-beergarden .mt-sp-28 {
    margin-top: 24px;
}

 #restaurantbus-container .plan-beergarden-title {
    font-weight: bold;
}


@media (max-width: 961px) {
  .plan-pickup .price-table-btn {
        width: 100%;
    }
    
    .plan-beergarden-title {
        font-size: 18px;
    }
    
    .title-small {
        font-size: 13px;
    }
    
    #restaurantbus-container .list-dep {
        padding: 0 0 2px;
    }
    
    #restaurantbus-container .plan-beergarden .mt-sp-28 {
        margin-top: 28px;
    }
}
/*202406 期間限定 ビアガーデンプラン ****/



/***** 202410 期間限定 クリスマスプラン */
/*装飾*/
.plan-christmas {
    padding: 10px 10px;
    background: repeating-linear-gradient(315deg, #ae0000, #ae0000 20px, #003b14 0, #003b14 40px);
	text-align: center;
}

.plan-christmas-inner {
    background: #FFF5DC;
    border: double 3px #c18914;
	padding: 10px;
}

/*テキスト*/
.plan-christmas-title{
    font-size: 120%;
}
.plan-christmas-title span{
	border-bottom: solid 1px #c18914;
}

/* button */
.plan-christmas .btn-christmas {
    background: #c18914!important;
    box-shadow: 2px 2px 2px rgba(0,0,0,0.3);
}
.plan-christmas .price-table-btn {
    width: 33%;
}

@media (max-width: 991px) {
 	.plan-christmas .price-table-btn {
        width: 100%;
		margin: auto;
    }
    
    .title-small {
        font-size: 13px;
    }

}
/*202406 期間限定 ビアガーデンプラン ****/

/***** 202502 期間限定 桜花見プラン */
/*装飾*/
.plan-sakura {
    padding: 4px 3px;
/*    background: repeating-linear-gradient(-64deg, #fff, #fff 2px, #eda1e0 2px, #eda1e0 6px);*/
	text-align: center;
/*    background: #eda1e0;*/
    border: dotted 2px #eda1e0;
    position: relative;
}

.plan-sakura::before {
    content: '';
    position: absolute;
    top: -26px;
    transform: rotate(-22deg);
    left: 32px;
    width: 60px;
    height: 64px;
    display: inline-block;
    background: url(/restaurantbus/tokyo/img/2025spring/icon-sakura.svg) no-repeat center center / 100%;
}
.plan-sakura-inner {
    background: #ffeded;
	padding: 10px;
}
.plan-modal.sakura .modal-header{
    background: #ffeded;
    font-weight: bold;
}


/*テキスト*/
.plan-sakura-title {
    font-size: 120%;
}
.plan-sakura-title span {
	border-bottom: dotted 1px #AE9841;
}
 
.plan-sakura .btn-sakura {
    background: #AE9841!important;
    box-shadow: 2px 2px 2px rgba(0,0,0,0.3);
}
.plan-sakura .price-table-btn {
    width: 33%;
}

@media (max-width: 1100px) {
    .plan-sakura::before {
        top: -20px;
        left: 3%;
        width: 46px;
        height: 48px;
    }
}

@media (max-width: 991px) {
 	.plan-sakura .price-table-btn {
        width: 100%;
		margin: auto;
    }
    .title-small {
        font-size: 13px;
    }
    .plan-sakura::before {
        top: -20px;
        left: -2px;
        width: 50px;
        height: 54px;
    }
}

/*プラン モーダル*/
.plan-modal-sakura .card-plan-title {
   font-size: 16px; 
}
.plan-modal-sakura .card-plan-cate {
   font-size: 14px; 
}
.plan-modal-sakura .card-plan-01:hover {
    background: inherit;
}

.plan-modal-sakura .card-plan-01 {
    box-shadow: none;
    border: 1px solid #ccc;
    font-size: 14px;
}

.plan-modal-sakura .card-plan-heading {
  font-size: 18px;
  font-weight: bold;
}

.plan-modal-sakura .card-plan-title {
  font-size: 16px;
  font-weight: bold;
  padding-bottom: 10px;
  border-bottom: 1px solid #ccc;
}

.plan-modal-sakura .card-plan-cate {
  font-size: 14px;
  font-weight: 400;
}

.plan-modal-sakura .btn{
    color: #fff;
    width: 100%;
    margin-left: auto;
    background: #AE9841;
    border: none;
    text-align: center;
}

.plan-modal-sakura .btn::after{
    right: 10px;
}

@media (max-width: 767px) {
   .plan-modal-sakura .card-plan-01 {
        font-size: 13px;
    }
    .plan-modal-sakura .card-plan-title {
      padding: 6px;
      font-size: 16px;
    }
    
    .plan-modal-sakura .card-plan-title {
      font-size: 14px;
    }
    
    .plan-modal-sakura .card-plan-cate {
      font-size: 12px;
    }
}

/** 202502 期間限定 桜花見プラン **/

/** 202505 メニュー切り替えタブ **/
.menu-tabs {
    margin-top: 16px;
    border-bottom: none;
}
.menu-tabs .nav-item {
    width: 50%;
}
.menu-tabs .nav-item .nav-link {
    font-size: 16px;
    font-weight: bold;
    padding: 12px 20px;
    text-align: center;
    background-color: #efefef;
    border-bottom: 1px solid #dee2e6;
    position: relative;
}
.menu-tabs .nav-item .nav-link::after {
    content: '\f0d7';
    position: absolute;
    top: 50%;
    right: 10px;
    font-size: 14px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    transform: translateY(-50%);
}
#restaurantbus-container .menu-tabs .nav-item a.nav-link {
    color: #888;
}
#restaurantbus-container .menu-tabs .nav-item a.nav-link.active {
    border-bottom: none;
    background-color: #fff;
    color: #000;
}

.tab-content .title-pricereserve {
    padding-top: 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid #bbb;
}

#restaurantbus-container .price-table-btn .btn-primary.type-02 {
    background: #fff;
    color: #d31f27;
    border: 1px solid #d31f27;
}

/*プラン用のモーダル設定*/
#restaurantbus-container .plan-main .modal-header {
    background: #3f4a90;
}
#restaurantbus-container .plan-main .modal-header h3 {
    font-size: 18px;
}
#restaurantbus-container .plan-main .modal-header .close {
    background: transparent;
    color: #fff;
    text-shadow: none;
}
#restaurantbus-container .plan-main .modal-footer {
    justify-content: center;
}
/*
@media(max-width: 560px) {
     #restaurantbus-container .plan-main .price-table-title-6{
         width: 34%;
         font-size: 16px;
    }
    #restaurantbus-container .plan-main .price-table-price-4 .plan-price .num {
        font-size: 18px;
        margin-right: 3%;
    }
    #restaurantbus-container .plan-main .price-table-btn {
        width: 28%;
    }
}
*/

