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

.l-wrapper {
  background-color: #1e1e1e;
  position: relative;
  z-index: 0;
}

.l-content-main {
  color: #ccc;
}

.m-tbl tbody, .m-tbl-list-data {
  color: #333 !important;
}

.m-tbl-list-data {
  background-color: #fff;
}

.m-hdg-lv2, .m-hdg-lv3 {
  color: #f2f2f2 !important;
}

.m-nav-breadcrumb a {
  color: #ccc !important;
}

.m-hdg-lv2 .m-hdg {
  border-left: 3px solid #f2f2f2 !important;
}

/* 時刻表矢印 */
@media screen and (min-width: 768px) {
  #timetable tbody th, #timetable tbody td {
    position:relative;
  }

  #timetable tbody th + th::before, #timetable tbody td + td::before {
    content:'→';
    position:absolute;
    left:-5px;
  }
}

/* 国際線就航コンテンツ PC */

.m-img-hdg {
  margin: 25px 0 35px;
}

.m-box-panels {
  margin: 0 auto 60px;
}
.m-box-panels-inner {
  margin: 0 auto 60px;
  display: flex;
  justify-content: space-around;
}
.m-box-panels-inner li {
  position: relative;
}
.m-box-panels-inner li .active {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s;
}
.m-box-panels-inner li:hover .active {
  opacity: 1;
}

.m-box-feature {
    margin: 0 0 40px;
}
.m-box-feature__ttl {
  text-align: center;
  margin: 0 0 25px;
}
.m-box-feature__cap {
  margin: 0 0 27px;  
  font-size: 150%;
  font-weight: normal;
  letter-spacing: .2em;
  text-align: center;
}

.m-box-dictioany {
  margin: 0 0 50px;
}

.m-box-shop {
  margin: 0 0 25px;
}
.m-box-shop__ttl {
  text-align: center;
  margin: 0 0 12.5px;
}
.m-box-shop__cap {
  margin: 0 0 25px;  
  font-weight: normal;
  letter-spacing: .2em;
  text-align: center;
}
.m-box-shop-list-inner {
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap:wrap;
}
.m-box-shop-list-inner li {
  margin: 0 0 2.5%;
  padding: .5% 1.5%;
  width: 48.5%;
  background: #eeece1;
  position: relative;
  height: calc(735px - 4rem);
}

.m-box-shop-list-shop-name {
  padding: 10px 0;
  text-align: center;
  border-bottom: 1px solid #000000;
}
.m-box-shop-list-shop-name span {
  color: #000000;
  font-size: 130%;
}
.m-box-shop-list-shop-intro {
  color: #000000;
}
.m-box-shop-list-shop-detail {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  padding: 1.5%;
  color: #000000;
  border: 10px solid #ded6c3;
  background: #ffffff;
  position: absolute;
  bottom: 15px;
  left: 15px;
  right: 15px;
}
.m-box-shop-list-shop-detail dt{
  width: 30%;
}
.m-box-shop-list-shop-detail dd {
  width: 70%;
}
.m-box-shop-list-shop-detail dd::before {
  content: ": ";
}
.m-box-shop-list-shop-detail a {
  text-decoration: underline;
}

@media screen and (max-width: 1164px){
  .m-box-shop-list-shop-intro {
    font-size: 1.4vw;
    line-height: 1.7;
  }
  .m-box-shop-list-shop-detail {
    font-size: 1.38vw;
    letter-spacing: .2em;
  }
  .m-box-shop-list-inner li {
    height: 70vw;
  }
  .m-box-shop-list-inner li:nth-child(5), .m-box-shop-list-inner li:nth-child(6) {
      height: 74vw;
  }
}

.m-box-coupon__ttl {
  text-align: center;
  margin: 0 0 25px;
}

.m-m-box-coupon__image {
  position: relative;
}

.m-m-box-coupon__btn {
  position: absolute;
  bottom: 3.8vw;
  left: 5%;
  width: 90%;
  text-align: center;
}

.m-box-shinfuro-bar {
  max-width: 1000px;
  margin: 50px auto 50px;
  padding-top: 40px !important;
  padding-bottom: 45px !important;
  position: relative;
  color: #fff !important;
  text-shadow: 0px 0px 7px #000000;
  height: 74px;
}
.m-box-shinfuro-bar::after {
  width: 100%;
  height: 100%;
  margin: 0 -100%;
  padding: 0 100%;
  position: absolute;
  top: 0;
  z-index: 0;
  background:#1e1e1e url(/int_tw/campaign/2018/beppu_bus/img/shinfuro_ttl.png) no-repeat center center;
	background-size:auto;
	content: '';
}
.m-box-shinfuro-inner {
    margin: 0 auto;
    display: flex;
    justify-content: space-around;
    width: 94%;
}
.m-box-shinfuro-inner dl {
    width: 45%;
}
.m-box-shinfuro__movie dd {
  position:relative;
  padding-top:56.25%;
}
.m-box-shinfuro__movie dd iframe {
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}

.m-box-shinfuro__movie dt {
  text-align: center;
}

.m-box-closing {
  max-width: 1000px;
  margin: 50px auto 50px;
  padding-top: 40px !important;
  padding-bottom: 45px !important;
  position: relative;
  color: #fff !important;
  text-shadow: 0px 0px 7px #000000;
  height: 486px;
}
.m-box-closing::after {
  width: 100%;
  height: 100%;
  margin: 0 -100%;
  padding: 0 100%;
  position: absolute;
  top: 0;
  z-index: -1;
  background:#1e1e1e url(/int_tw/campaign/2018/beppu_bus/img/bnr_closing.png) no-repeat center center;
	background-size:auto;
	content: '';
}

.m-box-foot {
  max-width: 1000px;
  margin: 50px auto 50px;
  padding-top: 40px !important;
  padding-bottom: 45px !important;
  position: relative;
  color: #fff !important;
  text-shadow: 0px 0px 7px #000000;
  height: 246px;
}
.m-box-foot::after {
  width: 100%;
  height: 100%;
  margin: 0 -100%;
  padding: 0 100%;
  position: absolute;
  top: 80px;
  z-index: -1;
  background:#1e1e1e url(/int_tw/campaign/2018/beppu_bus/img/bnr_foot.png) no-repeat center center;
	background-size:auto;
	content: '';
}

.l-content-related__hdg_s {
  font-size: 80%;
}

@media screen and (min-width: 768px) {
  .sp-only {
    display: none !important;
  }
}

/* 別府背景 */
.m-box-bg-beppu {
  max-width: 1000px;
  margin: 50px auto 0;
  padding-top: 40px !important;
  padding-bottom: 45px !important;
  position: relative;
  color: #fff !important;
  text-shadow: 0px 0px 7px #000000;
  height: 300px;
}

.m-box-bg-beppu::after {
  width: 100%;
  height: 100%;
  margin: 0 -100%;
  padding: 0 100%;
  position: absolute;
  top: 0;
  z-index: -1;
  background:#1e1e1e url(/int_tw/campaign/2018/beppu_bus/img/bg_main.png) no-repeat center center;
	background-size:auto;
	content: '';
}

.m-box-bg-beppu__hdg--lv3 {
  font-size: 2.8rem;
}

.m-box-bg-beppu__hdg--lv3 + * {
  margin-top: 35px !important;
}

.m-box-bg-beppu__hdg--lv4 {
  margin-top: 80px;
  font-size: 1.8rem;
  font-weight: bold;
}

.m-box-bg-beppu__hdg--lv4 + * {
  margin-top: 20px !important;
}

@media screen and (max-width: 767px) {
  .m-box-bg-beppu {
    padding-top: 27px !important;
    padding-bottom: 27px !important;
    height: 150px;
  }
  .m-box-bg-beppu__hdg--lv3 {
    font-size: 1.8rem;
  }
  .m-box-bg-beppu__hdg--lv3 + * {
    margin-top: 25px !important;
  }
  .m-box-bg-beppu__hdg--lv4 {
    margin-top: 50px;
    font-size: 1.5rem;
  }
  .m-box-bg-beppu__hdg--lv4 + * {
    margin-top: 25px !important;
  }
  .pc-only {
  	display: none !important;
  }
	.l-header-content-sp-bg {
		position: relative !important;
	}
}

/* 国際線就航コンテンツ PC */

.m-box-bg-beppu::after {
  background:#1e1e1e url(/int_tw/campaign/2018/beppu_bus/img/bg_main2.png) no-repeat center center;
}

@media screen and (max-width: 767px) {

.m-img-hdg {
    margin: 25px 0 0;
}

.m-box-panels {
    margin: 0px auto 5.8vw;
}

.m-box-feature {
    margin: 0 0 3.2vw;
}
.m-box-feature__ttl {
    margin: 0 0 2.4vw;
}
.m-box-feature__cap {
    font-size: 2.6vw;
    margin: 3vw;
}

.m-box-shop__ttl {
    margin: 0 0 2.4vw;
}
.m-box-shop__cap {
    font-size: 2.6vw;
    margin: 3vw;
}
.m-box-shop-list-inner {
    display: block;
}
.m-box-shop-list-inner li {
    height: 74vw;
}
.m-box-shop-list-inner li {
  padding: 2.5%;
  width: 100%;
  height: auto;
}
.m-box-shop-list-inner li:nth-child(5),
.m-box-shop-list-inner li:nth-child(6) {
  height: auto;
}
.m-box-shop-list-shop-img {
  margin: 0;
}
.m-box-shop-list-shop-intro {
  font-size: 3vw;
  line-height: 1.4;
  margin: 1.5vw 0;
}
.m-box-shop-list-shop-detail {
  padding: 1vw 2.4vw;
  position: relative;
  bottom: 0;
  left: 0;
  right: 0;
  border: 1.4vw solid #ded6c3;
  font-size: 2.8vw;
  letter-spacing: .2em;
}

.m-box-coupon__ttl {
    margin: 0 0 3vw;
}

.m-box-shinfuro-bar {
  margin: 0 auto;
  height: 14vw;
  padding-top: 3vw !important;
}
.m-box-shinfuro-inner {
  display: block;
}
.m-box-shinfuro-inner {
  width: 99%;
}
.m-box-shinfuro-inner dl {
  width: 100%;
  background: #000000;
}
.m-box-shinfuro__movie dt {
  padding: 3vw 0;
  font-size: 4vw;
}
.m-box-shinfuro-bar::after {
  display:none;
}

.m-box-closing {
  position: relative;
  top:0;
  margin: 0 auto 5vw;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  height: auto;
}
.m-box-closing::after {
  display:none;
}

.m-box-foot {
  margin: 0;
  height: 36vw;
}
.m-box-foot::after {
  margin: 6vw -100%;
  padding: 3vw 60vw;
  top:0;
  background-size: contain;
}

.l-content-related {
  padding: 8vw 10px 40px;
}

}