@charset "Shift_JIS";
@import url(ic.css);
@import url('https://fonts.googleapis.com/css?family=Lato:900');
@import url('https://fonts.googleapis.com/icon?family=Material+Icons|Material+Icons+Round');
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@700&family=Noto+Sans+JP:wght@400;700&display=swap');

/*-------------------------------------
  common
-------------------------------------*/
.jtb-nav-breadcrumb { margin-bottom: 25px; }
#page_footer { margin-top: 0; }
h1 { font-size: 18px !important; font-weight: bold !important; line-height 1 !important; margin: 0 auto 25px !important; width: 1120px; }
#cpnArea { font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, sans-serif; line-height: 1.6; width: 100%; }
#cpnArea * { box-sizing: border-box; }
#contentWrap { text-align: center; background: #fcf9f5; }
#contentWrap h2 { background: url(../images/h2-bar.png) no-repeat 50% 100% / 155px auto; padding: 50px 0 20px; position: relative; font-size: 32px; font-weight: bold; margin-bottom: 10px }

#contentWrap #faq h2 br{ display:none; }

#contentWrap h2:after{position: absolute; content:url(../images/icon.png); bottom: 48px; left: 48%; transform: scale(0.5);}

#contentWrap .inner { padding: 30px 42px; margin: 0 auto; width: 1236px; }
#contentWrap .box { padding-top: 100px }
.c-sec {padding: 0.5em 0 !important;}
.inner p.txt{font-size: 1.1em;font-weight: 700;}
#planRanking ul, #planTogether ul { letter-spacing: -0.4em }
#planRanking li, #planTogether li { display: inline-block; letter-spacing: normal; }
#planTheme li a:hover, #bnrSlider a:hover img, #bnrSlider .sp-thumbnail-container img:hover, #items li a:hover, #anchor li a:hover, #planRanking .tab li a:hover, #planTogether .item li:hover img { opacity: 0.8; }
.js-btn-page-top { bottom: 50px; cursor: pointer; display: none; position: fixed; right: 50px; z-index: 100; }
.js-btn-page-top a { display: block; height: 17px; position: relative; width: 35px; }
.js-btn-page-top a::before { color: #000; content: '\e802'; display: inline-block; font-family: 'ic'; font-size: 17px; height: 17px; width: 35px; }
.js-btn-page-top a:hover { opacity: .8; }
#content_area{background:none;}



/*-------------------------------------
  seasonNav
-------------------------------------*/
#headNav { margin: 0 auto; overflow: hidden; width: 1120px; }
#headNav li { float: left; padding: 0 2px; text-align: center; width: 20%; }
#headNav li.sale { float: right }
#headNav li a { background-color: #ebebeb; border: 1px solid #ccc; border-radius: 4px 4px 0 0; color: #333; display: block; padding: 8px 0; text-decoration: none; }
#headNav li a br { display: none }
#headNav li a:hover { background-color: #f2f2f2 }
#headNav li a.active { background-color: #da0a1b; border: 1px solid #da0a1b; color: #fff; }
#headNav li a.active:hover { background-color: #da0a1b }



/*-------------------------------------
  mainVis
-------------------------------------*/
#mainVis { background: url(../images/bg-mv.png) repeat 0 0 / 54px 18px; height: 400px; min-width: 1120px; position: relative; text-align: center; width: 100%; }
#mainVis img { height: 400px; width: auto; }
#mainVis::after { background: url(../images/bg-mv_inner.png) no-repeat 50% 100% / auto 400px; position: absolute; content: ''; width: 100%; height: 100%; top: 0; left: 0; }
/*#mainVis::before { 
background: url(../images/mv_icon.png) no-repeat 50% 100% / auto 250px;
    position: absolute;
    content: '';
    width: 140%;
    height: 48%;
    top: 0;
    left: 0;
      }
*/
/*-------------------------------------
  anchor
-------------------------------------*/
#anchor { text-align: center; background: url(../images/bg-anchor.png) repeat 0 0 / 150px; }
#anchor ul { height: 70px; padding: 10px 0; display: flex; align-items: stretch; justify-content: center; width: 1120px; margin: 0 auto; }
#anchor ul li { width: 265px; height: 100%; display: table; position: relative; }
#anchor ul li + li { margin-left: 20px; }
#anchor ul li span::before, #anchor ul li span::after { position: absolute; content: ""; width: 0; height: 0; border-style: solid; border-width: 10px 10px 0 0; border-color: #decc70 transparent transparent transparent; }
#anchor ul li span:nth-of-type(1)::before { top: 0; left: 0; }
#anchor ul li span:nth-of-type(1)::after { top: 0; right: 0; transform: rotate(90deg); }
#anchor ul li span:nth-of-type(2)::before { bottom: 0; left: 0; transform: rotate(270deg);}
#anchor ul li span:nth-of-type(2)::after { bottom: 0; right: 0; transform: rotate(180deg);}
#anchor ul li a em { display: block; }
#anchor li a { display: block; color: #fff; font-size: 14px; font-weight: bold; text-align: center; display: table-cell; vertical-align: middle; background: url(../images/bg-red.png) repeat 0 0 / 139px; line-height: 1.2; transition: all .3s; position: relative; }
#anchor li a::after { color: #fffb00; content: '\e801'; font-family: 'ic'; font-size: 14px; position: absolute; right: 3px; top: 46%; -webkit-transform: translateY(-50%); transform: translateY(-50%); }
#anchor li a:hover { color: #faf900 !important; text-decoration: none; }
#anchor.fixed { position: fixed; z-index: 10; width: 100%; }

/*-------------------------------------
  calendar
-------------------------------------*/
#calendar { background: url(../images/bg-calendar.png) repeat 0 0 / 320px auto; padding-bottom: 10px; }
#calendar .inner { padding-top: 0; }
#calendar p.txt { text-align: left; font-size: 14px; }
#calendar .calendarWrap { background-color: #cfbea1; padding: 14px 19px; margin-bottom: 40px; }
#calendar ul.date { padding-top: 8px; letter-spacing: -.4em; text-align:left; }
#calendar li { display: inline-block; letter-spacing: normal; width: 11%; padding: 4px 2px; position: relative; text-align: center; vertical-align: bottom; }
#calendar li .week { background-color: #333; color: #fff; font-size: 16px; line-height: 32px; }
#calendar li.sat .week { background-color: #178ee3; }
#calendar li.sun .week { background-color: #ff0000; }
#calendar li .day { background-color: #fff; font-family: 'Lato', sans-serif; font-size: 20px; line-height: 50px; font-weight: bold; }
#calendar li.sat .day { color: #178ee3; }
#calendar li.sun .day { color: #ff0000; }
#calendar li.holiday .day { background: #fcf119; }
#calendar ul.date li:hover { cursor: pointer; }
#calendar ul.date li:hover .floatNavi { opacity: 1; transform: translate(-50%, 88%); visibility: visible; }
#calendar .floatNavi { background-color: rgba(131, 112, 79, .95); border-radius: 4px; bottom: 0; left: 50%; opacity: 0; padding: 10px 12px; position: absolute; transform: translate(-50%, 105%); transition: all .2s ease-in; visibility: hidden; width: 160%; z-index: 10; }
#calendar .floatNavi::before { border: 8px solid transparent; border-bottom: 8px solid rgba(131, 112, 79, .95); content: ""; margin-left: -8px; left: 50%; position: absolute; top: -16px; }
#calendar .floatNavi li { display: block; padding: 1px 0; text-align: left; width: auto; }
#calendar .floatNavi li a { background-color: transparent; color: #fff; display: block; }
#calendar .floatNavi li a::after { color: #fffb00; content: '\e801'; display: inline-block; float: right; font-family: 'ic'; font-size: 11px; }
#calendar .floatNavi li a:hover { color: #fffb00; }

/*-------------------------------------
  items
-------------------------------------*/
#items { padding-bottom: 40px; }
#items h2 { margin-bottom: 0; }

.l-items { display: flex; justify-content: space-between; }
.l-items__col { width: 498px; }
.l-items__col li { display: block; width: 100%; position: relative;}
.l-items__col li + li { margin-top: 20px; }
.l-items__col li a { display: block; color: #fff; font-size: 24px; font-weight: bold; text-align: center; vertical-align: middle; background-size: 139px; line-height: 1.2; padding: 20px 0; transition: all .3s; }
.l-items__col li a::after { color: #fffb00; content: '\e801'; font-family: 'ic'; font-size: 14px; position: absolute; right: 30px; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); }
.l-items__kokunai a { background-image: url(../images/bg-red.png); }
.l-items__kaigai a { background-image: url(../images/bg-deep-red.png); }
.l-items__col li span::before, .l-items__col li span::after { position: absolute; content: ""; width: 0; height: 0; border-style: solid; border-width: 10px 10px 0 0; border-color: #fff transparent transparent transparent; }
.l-items__col li span:nth-of-type(1)::before { top: 0; left: 0; }
.l-items__col li span:nth-of-type(1)::after { top: 0; right: 0; transform: rotate(90deg); }
.l-items__col li span:nth-of-type(2)::before { bottom: 0; left: 0; transform: rotate(270deg);}
.l-items__col li span:nth-of-type(2)::after { bottom: 0; right: 0; transform: rotate(180deg);}
.l-items__col li a:hover { color: #faf900 !important; text-decoration: none; }

/*-------------------------------------
 planRanking
-------------------------------------*/
#planRanking { background: url(../images/bg-recommend.png) repeat 0 0 / 100px; padding-bottom: 80px; }
#planRanking .inner { background: #fff; }
#planRanking .tab { width: 1120px; margin: 0 auto; }
#planRanking .tab li { vertical-align: bottom; width: 50%; }
#planRanking .tab li a { color: #fff; display: block; font-size: 24px; font-weight: bold; padding: 15px 0; text-decoration: none; position: relative; background: url(../images/bg-red.png) repeat 0 0 / 139px; transition: all .3s; }
#planRanking .tab li:nth-of-type(2) a { background-image: url(../images/bg-deep-red.png); }
#planRanking .tab li.active a::after { position: absolute; content: ''; left: 50%; bottom: -12px; width: 0; height: 0; border-style: solid; border-width: 12px 10.5px 0 10.5px; }
#planRanking .tab li:nth-of-type(1).active a::after { border-color: #c3191f transparent transparent transparent; }
#planRanking .tab li:nth-of-type(2).active a::after { border-color: #991315 transparent transparent transparent; }
#planRanking .tab li a span::after { color: #fffb00; content: '\e800'; font-family: 'ic'; font-size: 13px; margin-left: 24px; }
#planRanking .tabBox { margin: 0 auto; padding: 24px 0 40px; width: 900px; }
#planRanking .item { position: relative; margin-bottom: 60px; }
#planRanking .item:last-of-type { margin-bottom: 0; }
#planRanking .item h3 { border: 4px solid #fff; color: #fff; display: table; font-size: 46px; font-weight: bold; left: 50%; line-height: 1; padding: 40px 60px; position: absolute; top: 50%; transform: translate(-50%, -50%); white-space: nowrap; z-index: 1;}
#planRanking #kaigaiTour .item { counter-increment: number-kaigai; }
#planRanking #kokunaiTour .item { counter-increment: number-kokunai; }
#planRanking .item::before { position: absolute; content: ''; width: 80px; height: 80px; top: -20px; left: -20px; background: url(../images/ic-ranking.png) no-repeat 0 0 / 80px; z-index: 1; font-size: 26px; font-weight: bold; color: #c3191e; text-align: center; padding-top: 28px; }
#planRanking #kaigaiTour .item::before { content: counter(number-kaigai); }
#planRanking #kokunaiTour .item::before { content: counter(number-kokunai); }
#planRanking .item-head { height: 360px; position: relative; margin-bottom: 10px; }
#planRanking .item-head::after { background-color: rgba(0, 0, 0, .2); bottom: 0; content: ""; display: block; left: 0; height: 100%; position: absolute; right: 0; top: 0; width: 100%; }
#planRanking .item-head img { width: 100%; height: auto; vertical-align: bottom }
#planRanking .item-head span { color: #fff; bottom: 15px; right: 10px; position: absolute; display: inline-block; padding: 5px 10px; background: rgba(0, 0, 0, 0.5); border-radius: 4px; z-index: 1; }
#planRanking .item-bottom p { font-size: 14px; padding: 0 5px; margin-bottom: 20px; text-align: left; }
#planRanking .item-bottom .btn { display: flex; justify-content: center; }
#planRanking .item-bottom .btn li { padding: 0 5px; width: 27%; }
#planRanking .item-bottom .btn li a { align-items: center; border-radius: 4px; color: #fff; display: flex; flex-wrap: wrap; height: 46px; justify-content: center; line-height: 1.2; position: relative; text-decoration: none; transition: all .3s; }
#planRanking .item-bottom .btn li a span { display: block; }
#planRanking #kokunaiTour .item-bottom .btn li { width: 25%; }
#planRanking #kokunaiTour .item-bottom .btn li a { background: #c3191e; }
#planRanking #kaigaiTour .item-bottom .btn li a { background: #9c1416; }
#planRanking #kokunaiTour .item-bottom .btn li a:hover { background: #ea2026; }
#planRanking #kaigaiTour .item-bottom .btn li a:hover { background: #b52a2c; }
#planRanking .item-bottom .btn li a::after { color: #fffb00; content: '\e801'; font-family: 'ic'; font-size: 12px; position: absolute; right: 1em; top: 50%; transform: translateY(-50%); }
#planRanking h4 { font-size: 20px; font-weight: bold; margin-bottom: 10px; }
#planRanking .item-bottom .tag ul { text-align: left; margin-bottom: 10px; }
#planRanking .item-bottom .tag li { display: inline-block; margin: 0 .3em .3em 0; padding: 0; }
#planRanking .item-bottom .tag li a { display: inline-block; font-size: 13px; height: 30px; line-height: 30px; padding: 0 0.8em; background-color: #fff; border: 1px solid #c3191e; border-radius: 3px; white-space: nowrap; overflow: hidden; color: #c3191e; -webkit-transition: .2s; transition: .2s; }
#planRanking #kaigaiTour .item-bottom .tag li a { border-color: #991315; color: #991315; }
#planRanking .item-bottom .tag li.is-nolink a { border-color: #000 !important; color: #000 !important; pointer-events: none; }
#planRanking .item-bottom .tag li a:hover { background-color: #c3191e; border: 1px solid #c3191e; color: #fff; }
#planRanking #kaigaiTour .item-bottom .tag li a:hover { background-color: #991315; border: 1px solid #991315; color: #fff; }
#planRanking .item-bottom .tag li a span::before { content: '\e803'; font-family: 'ic'; padding-right: 0.5em; }

/*-------------------------------------
  more
-------------------------------------*/
.l-more { border: 1px solid #ccc; margin: 20px auto; width: 900px; }
.l-more__head h3 { background-color: #c3191e; border-bottom: 1px solid #ccc; color: #fff; display: block; font-size: 16px; font-weight: bold; padding: 10px; }
.l-more__bottom { background-color: #fff; padding: 17px 15px }
.l-more__bottom ul { overflow: hidden }
.l-more__bottom ul li { float: left; padding: 3px 10px; }
.l-more__bottom ul li a { color: #0055cc; font-size: 14px; }
.l-more__bottom ul li a:hover { color: #ff984d }

/*-------------------------------------
  Theme
-------------------------------------*/
#planTheme { background: url(../images/bg-check.png) repeat 0 0 / 22px auto; padding-bottom: 40px; }
#planTheme .inner { padding-bottom: 6px; background: #fff; }
#planTheme .item { margin: 0 auto 24px; overflow: hidden; width: 100%; }
#planTheme .item .photo { float: left; position: relative; width: 49%; }
#planTheme .item .photo h3 { background-color: rgba(0,0,0,0.35); color: #fff; font-size: 20px; font-weight: bold; left: 0; padding: 12px 16px; position: absolute; text-align: left; top: 0; width: 100%; }
#planTheme .item .txt { padding-left: 28px; width: 51%; float: right }
#planTheme .item .txt-heading { background-color: #f7f7e6; color: #da0a1b; font-size: 16px; font-weight: bold; height: 36px; line-height: 36px; margin-bottom: 12px; }
#planTheme .item img { width: 100%; }
#planTheme .item p { padding: 1em 0 2em; text-align: left; }
#planTheme .item ul { display: flex; justify-content: space-between; text-align: left; }
#planTheme .item li { width: calc(50% - 5px); }
#planTheme .item li a { border-radius: 4px; color: #fff; display: block; margin: 0 auto; padding: 0.8em 0 0.8em 1em; text-align: center; text-decoration: none; transition: all .3s;}
#planTheme .item li a.kokunai_tour { background: #c3191e; }
#planTheme .item li a.kaigai_tour { background: #9c1416; }
#planTheme .item li a.kokunai_tour:hover { background: #ea2026; }
#planTheme .item li a.kaigai_tour:hover { background: #b52a2c; }
#planTheme .item li a::after { color: #fffc00; content: '\e801'; float: right; font-family: 'ic'; margin-right: 1em; }



/*-------------------------------------
  planTogether
-------------------------------------*/
#planTogether { background: url(../images/bg-planTogether.png) repeat 0 0 / 62px auto; padding-bottom: 80px;}
#planTogether .inner { padding: 30px 30px 5px; overflow: hidden; background: #fff;}
#planTogether .item h3 { background: url(../images/bg-red.png) repeat 0 0 / 139px; color: #fff; font-size: 20px; height: 48px; line-height: 48px; margin-bottom: 12px; text-align: center; }
#planTogether .item { width: 50%; float: left; margin-bottom: 40px;}
#planTogether .item:first-of-type { width: 100% }
#planTogether .item:nth-of-type(even) { padding-right: 10px }
#planTogether .item:nth-of-type(odd) { padding-left: 10px }
#planTogether .item:first-of-type { width: 100%; padding: 0;}
#planTogether .item li { width: 50%; padding: 10px; text-align: left;}
#planTogether .item:first-of-type li { width: 25% }
#planTogether .item li:hover { cursor: pointer;}
#planTogether .item li img { width: 100%; height: auto; margin-bottom: 5px; transition: all .3s;}
#planTogether .item li h4 { margin-bottom: 5px; font-weight: bold; color: #b71417; font-size: 16px; text-align: center;}

/*-------------------------------------
  check
-------------------------------------*/
#check { background: url(../images/bg-check.png) repeat 0 0 / 22px auto; padding-bottom: 120px; }
#check .inner { background-color: #fff; }
#check .sliderBox { overflow-x: hidden; width: 100%; }
#check .sliderAll { width: 660px; margin: 0 auto; height: 340px; position: relative; }
#check .sliderWrap { width: 1980px; position: absolute; left: 50%; margin-left: -990px; }
#check .bnrSlider-main { width: 100% }
#check .bnrSlider-main li { width: 660px }
#check .bnrSlider-main li img { margin: 0 10px; width: 640px; vertical-align: bottom; }
#bnrSlider.box { padding: 0 !important; }
#bnrSlider .bx-wrapper { margin-bottom: 15px }
#bnrSlider .controlWrap { display: block; margin: 0 auto; position: relative; width: 640px; }
#bnrSlider .controlWrap p#icPrev a, #bnrSlider .controlWrap p#icNext a { background-color: #fffb00; border-radius: 50%; height: 30px; margin-top: -15px; position: absolute; top: 50%; width: 30px; }
#bnrSlider .controlWrap p#icPrev a { left: -15px }
#bnrSlider .controlWrap p#icPrev a::before { border-left: 2px solid #ff6b00; border-bottom: 2px solid #ff6b00; content: ""; height: 7px; margin-top: -4px; left: 11px; position: absolute; transform: rotate(45deg); -webkit-transform: rotate(45deg); top: 50%; width: 7px; }
#bnrSlider .controlWrap p#icNext a { right: -15px }
#bnrSlider .controlWrap p#icNext a::before { border-right: 2px solid #ff6b00; border-top: 2px solid #ff6b00; content: ""; height: 7px; margin-top: -4px; right: 11px; position: absolute; transform: rotate(45deg); -webkit-transform: rotate(45deg); top: 50%; width: 7px; }
#bnrSlider .sp-slides-container { margin-bottom: 10px; }

/*-------------------------------------
  FAQ
-------------------------------------*/
#faq { background-color: #fff; padding-bottom: 80px;}
#faq h2 br { display: none;}
#faq .inner { background-color: #fff; padding: 42px; }
.faq__list { border-bottom: 1px solid #d7d7d7; text-align: left; }
.faq__item { border-top: 1px solid #d7d7d7; padding: 0 2em; }
.faq__item--q, .faq__item--a { font-size: 16px; padding-left: 3em; position: relative; }
.faq__item--q { line-height: 1.5; font-weight: bold; padding-bottom: 2em; padding-top: 2em; }
.faq__item--q:hover { cursor: pointer; }
.faq__item--q::before, .faq__item--a::before { font-size: 24px; font-weight: normal; left: 0; line-height: 1; position: absolute;  }
.faq__item--q::before { color: #c0171c; content: "Q." }
.faq__item--q::after { color: #c0171c; content: "\e804"; display: inline-block; font-family: "ic"; font-size: 24px; line-height: 1; position: absolute; right: 2em; transition: all .5s ease; }
.faq__item--q.is-open::after { transform: rotate(-180deg); }
.faq__item--a { display: none; padding-bottom: 2em; }
.faq__item--a::before { color: #c0171c; content: "A." }

/*-------------------------------------
  jtbsite_linklist_wrap
-------------------------------------*/
.jtbsite_linklist_wrap { padding: 40px 0; margin-bottom: 0; }
.jtbsite_linklist_wrap h3, .jtbsite_linklist dt { text-align: left; }

/*-------------------------------------
  sns
-------------------------------------*/
#sns { margin: 0 auto; width: 1120px; }
#sns ul { letter-spacing: -0.4em; margin-bottom: 10px; text-align: right; }
#sns li { display: inline-block; letter-spacing: normal; padding-left: 4px; vertical-align: top; line-height: 1 }


/*-------------------------------------
 close
-------------------------------------*/
.close{
	text-align: center;
    background: #FFFBC7;
    padding: 50px;
    margin-top: 20px;
    }


/*-------------------------------------
 info
-------------------------------------*/
.info{
	text-align: center;
	background: #FFFBC7;
	margin: 30px 200px 0;
	border: solid 3px #bb1419;
	padding-bottom: 40px;
	border-radius: 5px;
    }

.info_ttl{
	text-align: center;
    background: #bb1419;
    color:#fff;
    font-size:170%;
    font-weight:bold;
	padding:10px 0;
    }

.info_link{margin-top:35px;}

.info_link li{
	text-align: center;
	background: #fff;
	border: solid 3px #bb1419;
	padding:10px 30px;
	margin: 0 30px;
	border-radius: 5px;
	display: inline-block;
	}


.info_link a:after {
	color: #bb1419;
	content: '\e801';
	font-family: 'ic';
	font-size: 23px;
	padding-left: 10px;
	vertical-align: middle;
	}

.info br{display:none;}
.info_link a span{font-weight: bold;}


/*-------------------------------------
 連休
-------------------------------------*/
.holidays{
	text-align: center;
	background: url(../images/bg-anchor.png) repeat 0 0 / 150px;
	padding: 15px;
	/* margin-top: 20px; */
	color: #e12323;
	font-size: 150%;
	font-weight: bold;
	}

.holidays span{font-size: 135%; font-weight: bold;}
.holidays br{display:none;}


/*調整*/
.c-item{margin:20px;}
.c-title,.c-item p{text-align: left;}
.c-title a{color: #3498db; font-weight: 700; font-size: 16px;}
.c-btn__block { max-width: 550px !important; display: inline-block; padding: 0 20px;}
.c-bottom__link{margin-top:50px;}
#search .inner{background:#FBDFDF;}
.sec-special .c-item .c-title { background: #c0171c; text-align:center; margin-bottom: 5px; padding: 15px;}
.sec-special .c-item .c-title a {color: #fff !important;}
.JTB-el_btn.-normal-secondary,.JTB-el_btn.-normal-primary{background: #fffa !important; color: #fff !important;}
.l-page a,.c-btn span::after, .c-arrow__rigth::after,.sec-city .c-name span::before {color: #fff; font-weight: bold;}
/*.c-inner .c-btn__wrap .c-btn:first-child { width: 100% !important; }*/
.l-page img{opacity: 1 !important;}
#contents_area {min-width: 950px !important;}
.mystyle-cst_item a{font-size: 90% !important;}
#airhotel .header{margin: 0 auto 30px !important;}
.c-box {border: 1px solid #e5e5e5 !important;}
.c-btn__wrap span,.c-btn__block span{font-weight: unset;}
.c-btn,.c-btn__block a{border: none !important;}
#recommend .inner {padding: 0 42px 30px;}
.mystyle-cst_item figure { height: auto; padding: 0; margin: 0;}


.sec-city .c-city__data .c-catch{border-bottom: 1px solid #ffaba3 !important;}


/*選んでつくる！私だけの旅「ルックJTBMySTYLE」*/
#airhotel span{font-weight: unset;}

#airhotel .header {
  width: 910px;
  margin: 20px auto 30px;
  overflow: hidden;
  background: url(/kaigai/area/images/bg_dynamicjtb_logo.png) 0 34px no-repeat;
}
#airhotel h3 {
  padding: 13px 0 0 170px;
  width: 165px;
  float: left;
  font-family: "メイリオ", Meiryo,"ＭＳ Ｐゴシック", "MS PGothic","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
  font-size: 116%;
  font-weight: bold;
  line-height: 1.7;
}
/* width,marginは各エリアで指定*/
#airhotel hgroup h4 {
  font-family: "メイリオ", Meiryo,"ＭＳ Ｐゴシック", "MS PGothic","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
  text-align: center;
  background: url(/kaigai/area/images/bg_airhotel_feature.gif) center no-repeat;
  font-weight: bold;
  font-size: 13px;
  text-align: center;
  line-height: 1.3;
  float:left;
}
#airhotel .catch_copy {
  font-weight: bold;
  font-size: 116%;
  line-height: 1.7;
  padding: 13px 0 13px 0;
  /*text-align: left;*/
}
#airhotel .detail_link {
  display: none;
}
#airhotel .title:before {
  content: '\e804';
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  *display: inline;
  text-decoration: inherit;
  margin-left: .4em;
  margin-right: .4em;
  text-align: left;
  font-variant: normal;
  text-transform: none;
  line-height: 1em;
  vertical-align: middle;
  font-size: 16px;
  color: #d80b27;
}
#airhotel .feature {
  overflow: hidden;
  width: 745px;
  margin: 0 0 0 170px;
}
#airhotel .feature h4 {
  font-family: "メイリオ", Meiryo,"ＭＳ Ｐゴシック", "MS PGothic","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
  text-align: center;
  background: url(/kaigai/area/images/bg_airhotel_feature.gif) center no-repeat;
  font-weight: bold;
  font-size: 133.33%;
  margin-right: 24px;
  line-height: 1.3;
}
#airhotel .feature h4:before {
  content: '\e804';
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  *display: inline;
  text-decoration: inherit;
  margin-left: .4em;
  margin-right: .4em;
  text-align: left;
  font-variant: normal;
  text-transform: none;
  line-height: 1em;
  vertical-align: middle;
  font-size: 16px;
  color: #d80b27;
}
#airhotel .feature ul {
  overflow: inherit;
  margin-top: 12px;
}
#airhotel .feature li {
  font-family: "メイリオ", Meiryo,"ＭＳ Ｐゴシック", "MS PGothic","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
  font-weight: bold;
  float: left;
  display: block;
  width: 125px;
  height: 60px;
  padding: 15px 0 0 54px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  border-radius: 5px;
  background-color: #ededed;
  position: relative;
  margin-left: 20px;
  line-height: 1.2;
  font-size: 116.6%;
  box-sizing: border-box;
}
#airhotel .feature li:before {
  content: '\e818';
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  *display: inline;
  text-decoration: inherit;
  margin-right: .4em;
  text-align: left;
  font-variant: normal;
  text-transform: none;
  line-height: 1em;
  vertical-align: middle;
  color: #d80b27;
  position: absolute;
}
#airhotel .feature li.air:before {
  content: '\ea01';
  font-size: 33px;
  top: 15px;
  left: 15px;
}
#airhotel .feature li.hotel:before {
  content: '\e805';
  font-size: 33px;
  top: 11px;
  left: 16px;
}
#airhotel .feature li.olioli {
  width: 73px;
  padding: 8px 6px 7px 40px;
  font-size: 100%;
}
#airhotel .feature li.olioli:before {
  content: '\e806';
  font-size: 33px;
  top: 13px;
  left: 13px;
}
#airhotel .feature li.lookjtb {
  width: 172px;
  padding: 15px 0 0 47px;
}
#airhotel .feature li.lookjtb:before {
  content: '\e853';
  font-size: 26px;
  top: 15px;
  left: 10px;
}
#airhotel .feature li:after {
  display: block;
  content: "+";
  font-weight: bold;
  position: absolute;
  top: 0;
  left: -20px;
  width: 20px;
  line-height: 56px;
  text-align: center;
  color: #aaa;
}
#airhotel .feature li:first-child {
  margin-left: 0;
}
#airhotel .feature li:first-child:after {
  content: none;
}
#airhotel .header .feature li.airholink {
  width: 85px;
  padding: 0;
}
#airhotel .header .feature li.airholink a {
    position: absolute;
    left: 0;
    top: -2px;
    display: block;
    color: #fff;
    padding: 20px 0;
    width: 145px;
    height: 62px;
    box-sizing: border-box;
    font-size: 14px;
    line-height: 1.5;
    text-decoration: underline;
    text-align: center;
    border-radius: 8px;
    background: #222;
}
#airhotel .header .feature li.airholink a:after {
    content: "";
    display: inline-block;
    border: 4px solid transparent;
    border-left-color: #fff;
    position: absolute;
    right: 3px;
    top: 50%;
    margin-top: -4px;
}
#airhotel .header .feature li.airholink a:hover {
    background: #cc0000;
    text-decoration: none;
}
#airhotel .header .feature li.airholink:after {
    content: "=";
}
#airhotel .airhotel_tours {
  position: relative;
}

/*キーワード*/
.c-keyword__list { /*display: flex;*/ flex-wrap: wrap; margin-top: 1em; }
.c-keyword__list .c-word { align-items: center; background-color: #c0171c; border: 1px solid; border-radius: 100vh; display: inline-flex; height: 3.125em; justify-content: center; margin: .5em .25em; padding: 0 2em; color: #fff;}
.c-keyword__list .c-word span { font-weight: 700; }
.c-keyword__list .c-word span::before { content: "＃" !important; padding-right: .25em; }
.c-keyword__list .c-word:hover { background-color: #faf900 !important; color:#c0171c !important; }


.l-block {margin-top: 4.375em;}
.l-block .c-title{text-align:center;}
.l-block .c-title span { font-size: 1.625em; font-weight: 700; line-height: 1; }


.mouth a {color: #c0171c !important;}
.mouth .c-word:hover { background-color: #c0171c !important; color:#fff !important; }
.season a {color: #007521 !important;}
.season .c-word:hover { background-color: #007521 !important; color:#fff !important; }

.JTB-el_btn.-normal-secondary:after{background: #c0171c !important;}
.c-arrow__rigth a,.c-arrow__rigth::after{color: #323743 !important;}
.c-btn span::after{color: #fff !important;}
.sec-city .c-name span::before{color:#41d8ef !important;}

/*旅行日数から探す*/
.c-sec__head { padding: 2em 0 4em; }
.c-sec__head span { color: #ffe96e; font-family: 'M PLUS Rounded 1c', sans-serif; font-size: 1.25em; letter-spacing: .1em; line-height: 1; }
.c-sec__head span::before { display: block; font-family: "icon"; font-size: 1.375em; margin-bottom: .375em; }
.c-sec__title { color: #fff; font-size: 2em; font-weight: 700; }
.c-col__02 .c-card__item { width: calc(calc(100% - 4.875em) / 2); }
.c-col__02 .c-card__item:nth-child(n + 3) { margin-top: 1em; }
.c-col__02 .c-card__item .c-txt { width: calc(100% - 2.5em); }
.c-col__03 .c-card__item { width: calc(calc(100% - 3.75em) / 3); }
.c-col__03 .c-card__item:nth-child(n + 4) { margin-top: 1em; }
.c-col__04 .c-card__item { width: calc(calc(100% - 6.75em) / 4); }
.c-col__04 .c-card__item:nth-child(n + 5) { margin-top: 1em; }
.c-col__04 .c-card__item .c-card__title { font-size: 1em; }
.c-col__04 .c-card__item p { font-size: .875em; }

.c-sec .c-inner {
    max-width: 1236px !important;
    width: 100%;
}


.c-card__item .c-pic {
    border-radius: 0.5em;
    overflow: hidden;
    position: relative;
    width: 100%;
}

.c-card__item .c-txt {
    margin-left: auto;
    padding: 1.25em 1.5em 3.5em;
    transform: translateY(-2em);
    width: calc(100% - 1.375em);
    background-color: #fbdfdf;
    border-radius: 0.5em;
    display: block;
    position: relative;
    text-align: left;
    z-index: 1;
    color:#c0171c;
}

.l-block .c-title span {
    font-size: 1.625em;
    font-weight: 700;
    line-height: 1;
    position: relative;
}

.sec-area .sp_link, #escort .sp_link, #airhotel .sp_link{width: calc(100% - 3.0em);background: #fbdfdf;margin: 0 auto 10px;padding: 10px;border-radius: 0.5em;    font-size: 1.3125em;}
#escort .sp_link, #airhotel .sp_link {margin-top: 40px; width: 100%;}
.sp_link a:visited,.sec-area .c-card__list a:visited,.sp_link a:link,.sec-area .c-card__list a:link {color: #bd161a !important;} .sec-area .l-block .c-title span::before {left: -2.5em;}
.sec-area .l-block .c-title span::after {right: -2.5em;}

.sec-area .l-block .c-title span::before, 
.sec-area .l-block .c-title span::after {    background-color: #41d8ef;}
.sec-area .l-block .c-title span::before, .sec-area .l-block .c-title span::after {
    content: "";
    display: block;
    height: 3px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 1.75em;
}
.c-card__title{
	color: #bd161a;
	font-size: 1.3125em;
    font-weight: 700;
}
.c-card__item .c-txt p {
    color: #bd161a !important;
    margin-top: 0.75em;
    font-weight: 700;
}
.sec-area .c-card__list {    margin-top: 1.875em;}

.c-card__item a:hover {opacity: 1.0;}


.c-link::before {
    font-family: "icon";
    content: "詳細はこちら \f105";
    padding: 0.5em 0.8em;
    display: block;
    height: 2.5em;
    position: absolute;
    z-index: -1;
    background-color: #fff;
    font-size: 1.0em !important;
}

.c-link2::after {
    border-radius: 50%;
    content: "▲";
    padding: 0.4em 0.7em;
    display: inline-table;
    position: inherit;
    z-index: -1;
    background-color: #fff;
    transform: rotate(90deg);
    font-size: .5em;
    margin-left: 0.3em;
    vertical-align: text-bottom;
}


.sec-area .c-card__item .c-txt::before {
    bottom: 0.5em;
    right: 1.5em;
    top: auto;
    font-size: .8em;
}

.c-coupon__box:hover .c-link::before { animation: 1s circleanime forwards infinite; background-color: #fff; }
.c-link:hover::before { animation: 1s circleanime forwards infinite; }
.c-link:hover::after, .c-coupon__box:hover .c-link::after  { transform: translateX(.25em); }

#special .c-keyword__list .c-word{background-color: #fff;}

/*  アイコン
-----------------------------------------------------------*/
.m-ico{display: inline-flex;align-items: center;font-style: normal;vertical-align: middle;font-weight:normal;}.m-ico:before{font-family:'Material Icons Round';content: attr(data-icon);line-height: 1;font-size: 100%;}


/* 添乗員同行ツアー202211 */
#escort{
	font-family: Helvetica, Arial, Verdana,"メイリオ", Meiryo, "ヒラギノ角ゴPro W3","Hiragino Kaku Gothic Pro",Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	padding-bottom:20px;
}
.escortothers{
	margin: 55px auto 0;
	width: 910px;
}
.escortothers-copy{
	font-size: 14px;
	font-weight: bold;
}
.escortothers-copy br{
	display: none;
}
.escortothers-point{
	margin-top: 30px;
}
.escortothers-point_list{
	display: flex;
	justify-content: center;
	margin-left: -20px;
}
.escortothers-point_item{
	display: flex;
	align-items: center;
	margin-left: 20px;
	padding: 15px 20px;
	width: 400px;
	border-radius: 5px;
	background: #f5f5f5;
}
.escortothers-point_item .m-ico{
	margin-right: 15px;
	font-size: 35px;
	color: #CC0000;
	line-height: 1;
}
.escortothers-point_item p{
	font-size: 14px;
	font-weight: bold;
}
.escort-date{
	text-align: right;
	font-size: 13px;
}
#pickup_tour .escort-wrap{
	margin: 30px auto 0;
	width: 910px;
}
.escort-cas{
	display: flex;
	margin: 10px 0 0 -10px;
}
.escort-cas_item{ 
	margin-left: 10px;
	width: calc(100% / 3 - 10px);
}
.escort-cas_item a{
	display: flex;
	flex-direction: column;
	padding-bottom: 10px;
	height: 100%;
	color: #323743!important;
	font-size: 14px;
	text-decoration: none!important;
	background: #f5f5f5;
	box-shadow: 0 0 0.2em rgb(0 0 0 / 20%);
}
.escort-cas_item-photo{
	order: -2;
}
.escort-cas_item-photo figure{
	margin: 0;
	position: relative;
	padding-top: calc(2.5 / 4 * 100%)!important;
	width: 100%;
	height: 0;
}
.escort-cas_item-photo img{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
    vertical-align: bottom;
}
.escort-cas_item-ttl{
	margin: 10px 10px 0;
	color: #1A5178;
	font-size: 16px;
	font-weight: bold;
	text-align:left;
}
.escort-cas_item-icolist{
	order: -1;
	display: flex;
	flex-wrap: wrap;
	margin: 10px 10px 0 5px;
}
.escort-cas_item-icoitem{
	margin: 5px 0 0 5px;
	padding: 5px 10px;
	line-height: 1;
	font-size: 14px;
	border: solid transparent 1px;
}

.escort-cas_item-icoitem.-dept{
	border-radius: 50vw;
	background: #C6EDFF;
}
.escort-cas_item-icoitem.-es{
	border: solid 1px #ccc;
	background: #fff;
}
.escort-cas_item-icoitem.-icon{
	border: solid 1px #ccc;
	background: #fff;
}

.escort-cas_item-txt{
	margin: 10px 10px 0;
	text-align:left;
}
.escort-cas_item-num{
	margin: 15px 10px 0;
}
.escort-cas_item-price{
	margin: 0 10px;
	color: #CC0000;
	font-weight: bold;
}
.escort-cas_item-price span{
	font-size: 25px;
	font-weight: bold;
}

.escort-cas_item-list{
	margin: 10px 10px 0;
}
.escort-cas_item-item{
	display: flex;
	align-items: flex-start;
	margin-top: 8px;
}
.escort-cas_item-item .m-ico{
	position: relative;
	top: 2px;
	margin-right: 5px;
}
.escort-cas_item-item .fs{
	font-size: 12px;
}

@media screen and (max-width: 999px) {
.escort-cas{
	display: unset;
	margin:0;
}
.escort-cas_item{
    position: relative;
    margin-top: 10px;
    background: #fff;
    box-shadow: 0 0 0.5em rgb(0 0 0 / 20%);
    margin-left: 5px;
    width: calc(100% / 1 - 10px);
}
}

/*特集記事　レイアウト調整*/
#news .c-location { margin-top: .25em; }
#news .c-location::before { color: #c4c4c4; content: "\e803"; display: inline-block; font-family: "icon"; font-size: 1.25em; padding-right: .5em; vertical-align: middle; }
#news .c-txt { display: flex; flex: 1; flex-direction: column; text-align: left; }
#news .c-txt .c-title { font-weight: 500; margin-top: 1em; line-height: 1.4; }

#news .c-pic{
    position: relative;
    overflow: hidden;
    padding-top: 60%;
    margin: 10px 5px;
}

#news .c-pic img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 100%;
    height: 180px;
    object-fit: cover;
}

#news .c-box {
        padding: 40px;
        width: calc(100% / 3);
        margin: 10px;
    }


