@charset "utf-8";
/*【SP】夏のヨーロッパ 共通css*/
body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: calc(26vw / (750 / 100));
  line-height: calc(38 / 26);
  color: #333;
}
*, *::after, *::before {
  box-sizing: border-box;
}
div:after {
  content: none;
}
.container {
  width: 100%;
  /*overflow-x: hidden;*/
  overflow: hidden;
}
.container .section__container {
  width: 100%;
}
.container seciton {
  display: block;
}
.container figure {
  margin: 0;
}
.container img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.container a {
  color: inherit;
  text-decoration: none;
}
.container .is-pc {
  display: none;
}
.goTop {
  display: none;
  position: fixed;
  bottom: 10px;
  right: 10px;
  transform: translateZ(0);
  z-index: 200;
  cursor: pointer;
}
.goTop img {
  width: calc(100px / 2);
}
.goTop__link {
  display: block;
}
.breadcrumb__contents {
  overflow-x: scroll;
}
.breadcrumb__item, .breadcrumb__item a {
    font-size: .6rem;
}
.banner__wrapper {
  margin-top: calc(60vw / (750 / 100));
}
.banner__wrapper .banner__item + .banner__item {
  margin-top: calc(20vw / (750 / 100));
}
/* head__container
-------------------------------------------------*/
.head__container .logo {
  display: block;
  width: 100%;
  height: 0;
  padding-top: calc((100 / 750) * 100%);
  background: url("../images/sp/nav_top.jpg") no-repeat 0 0;
  background-size: cover;
}
/* main__container
-------------------------------------------------*/
.container [class*="__container"] {
  position: relative;
}
.main__container {
  font-size: calc(28vw / (750 / 100));
  line-height: 1.4;
}
.section__container {
  padding: 0;
}
.section__container.is-item {
  background: #fff;
}
.section__container:not(.is-item) + .section__container.is-item::before, :not[data-page="top"] .main__container::before {
  content: "";
  display: block;
  width: 100vw;
  height: calc(6vw / (750 / 100));
  background: url("../images/sp/line_gray.jpg") repeat-x 0 0;
  background-size: calc(100vw / (750 / 100));
  position: absolute;
  z-index: 1;
}
.section__container.is-item + .section__container.is-item .contents__inner {
  padding-top: 0;
}
.section__container.is-article {
  background: url("../images/sp/event_bg_pale.jpg");
  background-size: calc(100vw / (750 / 100));
}
.section__container.is-article:nth-of-type(even) {
  background-image: url("../images/sp/event_bg_dark.jpg");
}
.section__container .contents__inner {
  width: calc(706vw / (750 / 100));
  margin: auto;
  padding: calc(80vw / (750 / 100)) 0;
}
.section__container .contents__title {
  text-align: center;
}
.section__container [class*="__title--main"] {
  display: block;
  color: #004fa3;
  text-align: center;
  font-size: calc(36vw / (750 / 100));
  font-weight: bold;
  margin-bottom: calc(30vw / (750 / 100));
}
.section__container.is-article .contents__title .section__title--main {
  font-size: calc(32vw / (750 / 100));
  margin: calc(26vw / (750 / 100)) 0 calc(16vw / (750 / 100));
  font-weight: normal;
}
/*通常商品カセット*/
.section__container .contents__item:not(:first-child) {
  margin-top: calc(60vw / (750 / 100));
}
.contents__item--notes {
  margin-top: calc(30vw / (750 / 100));
  font-size: calc(22vw / (750 / 100));
  padding-left: 1em;
  text-indent: -1em;
}
.contents__item--notes + .contents__item--notes {
  margin-top: calc(10vw / (750 / 100));
}
.contents__item .tour_item_box {
  position: relative;
}
.contents__item .tour_item_box + .tour_item_box {
  margin-top: calc(20vw / (750 / 100));
}
.contents__item .tour_item_detail {
  background: #fff;
  padding: calc(14vw / (750 / 100));
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.contents__item .tour_item_detail [class*="item_box_"] {
  display: block;
}
.contents__item .item_box_pic {
  width: calc(200vw / (750 / 100));
}
.contents__item .item_box_bg_pic {
  background: no-repeat right bottom;
  background-size: cover;
  height: calc(133vw / (750 / 100));
}
.contents__item .item_box_info {
  width: calc(460vw / (750 / 100));
  position: relative;
}
.item_box_title {
  font-size: calc(26vw / (750 / 100));
  font-weight: bold;
  margin-bottom: calc(10vw / (750 / 100));
}
.item_box_point, .item_box_days {
  font-size: calc(24vw / (750 / 100));
}
.item_box_price, .item_box_fuel, .item_box_price + .item_box_notes {
  text-align: right;
  color: #f1442c
}
.item_box_price {
  font-size: calc(28vw / (750 / 100));
  font-weight: bold;
  margin-top: calc(10vw / (750 / 100));
}
.item_box_fuel, .item_box_notes {
  font-size: calc(20vw / (750 / 100));
}
.section__container .tour_item_box.LINE .item_box_info::after, .section__container .tour_item_detail[href*="TI-"] .item_box_info::before, .section__container .tour_item_detail[href*="TB-"] .item_box_info::before {
  display: inline-block;
  margin-bottom: calc(10vw / (750 / 100));
  font-size: calc(22vw / (750 / 100));
  line-height: 1;
  padding: calc(8vw / (750 / 100)) calc(34vw / (750 / 100));
  color: #fff;
}
.section__container .tour_item_detail[href*="TI-"] .item_box_info::before {
  content: "添乗員同行";
  background: #00a3d9;
}
.section__container .tour_item_detail[href*="TB-"] .item_box_info::before {
  content: "ビジネスクラス";
  background: #FF8113;
}
.section__container .tour_item_box.LINE .item_box_info::after {
  content: "LINE掲載商品";
  background: #00C300;
  position: absolute;
  top: calc(4vw / (750 / 100));
  left: 0;
}
.section__container .tour_item_box.LINE .tour_item_detail[href*="TI-"] .item_box_info::after {
  left: calc(188vw / (750 / 100));
}
.section__container .tour_item_box.LINE .tour_item_detail[href*="TB-"] .item_box_info::after {
  left: calc(230vw / (750 / 100));
}
.section__container .tour_item_box.LINE .tour_item_detail:not([href*="TI-"]):not([href*="TB-"]) .item_box_info {
  padding-top: calc(50vw / (750 / 100));
}
/*ボタン*/
.section__container .button__wrapper {
  margin-top: calc(60vw / (750 / 100));
}
.section__container .button__wrapper + .button__wrapper {
  margin-top: calc(30vw / (750 / 100));
}
.section__container .button__wrapper:not(.is-input) .button__text {
  display: flex;
  justify-content: center;
  align-items: center;
}
.section__container .button__wrapper .button__text {
  width: calc(680vw / (750 / 100));
  height: calc(80vw / (750 / 100));
  margin: auto;
  padding: calc(10vw / (750 / 100)) calc(30vw / (750 / 100));
  padding-right: calc(60vw / (750 / 100));
  font-size: calc(28vw / (750 / 100));
  line-height: 1.2;
  font-weight: bold;
  color: #fff;
  background-color: #F8A421;
  text-align: center;
}
.section__container .button__wrapper.is-input, .section__container .button__wrapper .button__text {
  position: relative;
}
.section__container .button__wrapper.is-input::after, .section__container .button__wrapper .button__text::after {
  content: "";
  width: calc(30vw / (750 / 100));
  height: calc(30vw / (750 / 100));
  border-radius: 100%;
  background: #fff no-repeat right calc(-1vw / (750 / 100)) center url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2254%22%20height%3D%2254%22%20viewBox%3D%220%200%2054%2054%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.cls-1%20%7B%20fill%3A%20%23F8A421%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Ctitle%3Eicon_arrow_right%3C%2Ftitle%3E%20%3Cg%20id%3D%22%E3%82%AA%E3%83%96%E3%82%B8%E3%82%A7%E3%82%AF%E3%83%88%22%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M20.58579%2C14.27206h0a2%2C2%2C0%2C0%2C0%2C0%2C2.82842L30.48529%2C27l-9.89951%2C9.89951a2%2C2%2C0%2C0%2C0%2C0%2C2.82842h0a2%2C2%2C0%2C0%2C0%2C2.82842%2C0L34.72794%2C28.41421a2%2C2%2C0%2C0%2C0%2C0-2.82842L23.41421%2C14.27206A2%2C2%2C0%2C0%2C0%2C20.58579%2C14.27206Z%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
  background-size: calc(30vw / (750 / 100));
  position: absolute;
  top: 0;
  bottom: 0;
  right: calc(20vw / (750 / 100));
  margin: auto;
}
.section__container .button__wrapper .button__text[target="_blank"]::after {
  width: calc(50vw / (750 / 100));
  height: calc(50vw / (750 / 100));
  border-radius: 0;
  background: url(/cmn/icon/icon_blank_white.svg) no-repeat 0 0;
  background-size: contain;
  right: calc(12vw / (750 / 100));
}
/*お得商品カセット*/
#toku .tour_item_box + .tour_item_box {
  border-top: calc(2vw / (750 / 100)) dashed;
  margin-top: calc(30vw / (750 / 100));
  padding-top: calc(30vw / (750 / 100));
}
#toku .contents__item .tour_item_detail {
  background: none;
}
/*AH商品カセット*/
#airhotel .tour_item_detail {
  padding-top: calc(30vw / (750 / 100));
}
#airhotel .tour_item_box + .tour_item_box {
  margin-top: calc(50vw / (750 / 100));
}
#airhotel .item_box_label {
  background: #000;
  color: #fff;
  display: inline-block;
  font-size: calc(24vw / (750 / 100));
  padding: calc(6vw / (750 / 100)) calc(10vw / (750 / 100));
  position: absolute;
  top: calc(-20vw / (750 / 100));
  left: calc(10vw / (750 / 100));
}
#airhotel .item_box_title {
  width: 100%;
}
#airhotel .item_box_price {
  margin-top: calc(20vw / (750 / 100));
}
/* foot__container
-------------------------------------------------*/
.foot__container {
  background: #f7f4ed;
  padding-bottom: calc(80vw / (750 / 100));
}
.section__container.is-foot + .section__container.is-foot {
  margin-top: calc(60vw / (750 / 100));
}
.section__container.is-foot .section__title {
  background: #cce8f9;
  padding: calc(26vw / (750 / 100)) calc(10vw / (750 / 100));
  margin-bottom: calc(20vw / (750 / 100))
}
.section__container.is-foot [class*="__title--main"] {
  font-size: calc(30vw / (750 / 100));
  line-height: 1;
  margin: 0;
}
.section__container.is-foot .contents__inner {
  padding: 0;
}
.section__container.is-foot .area-navi__wrapper { /*2カラム*/
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.section__container.is-foot .area-navi__wrapper .navi__item {
  width: calc(348vw / (750 / 100));
  height: calc(70vw / (750 / 100));
  display: flex;
  align-items: center;
  background: #fff;
  font-size: calc(22vw / (750 / 100));
  padding: calc(10vw / (750 / 100)) calc(20vw / (750 / 100));
  padding-left: calc(64vw / (750 / 100));
  margin-top: calc(10vw / (750 / 100));
  position: relative;
}
.section__container.is-foot .area-navi__wrapper .navi__item::before {
  content: "";
  display: block;
  width: calc(11vw / (750 / 100));
  height: calc(11vw / (750 / 100));
  background: #004fa3;
  position: absolute;
  top: 0;
  left: calc(33vw / (750 / 100));
  bottom: 0;
  margin: auto;
}

/*おすすめ特集*/
#bottomInfo {
  background: #cce8f9;
}
#bottomInfo #feature {
  width: calc(710vw / 7.5);
  margin: 0 auto;
  padding: calc(45vw / 7.5) 0;
}
.banner__reco {
  background: #fff;
  display: grid;
  padding: calc(30vw / 7.5);
  gap: calc(30vw / 7.5);
  grid-template-columns: repeat(2, 1fr);
}
.banner__reco--inner {
  display: block;
  box-shadow: 0px 0px 0px 4px #fff;
}
.banner__reco--item img {
    max-width: 100%;
}

/*●●トップへ戻る*/
.his-top__button {
  display: block;
  color: #fff !important;
  font-weight: bold;
  line-height: 1;
  padding: calc(30vw/ (750 / 100)) calc(20vw/ (750 / 100));
  background: #0057B8 url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2254%22%20height%3D%2254%22%20viewBox%3D%220%200%2054%2054%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.cls-1%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Ctitle%3Eicon_arrow_right%3C%2Ftitle%3E%20%3Cg%20id%3D%22%E3%82%AA%E3%83%96%E3%82%B8%E3%82%A7%E3%82%AF%E3%83%88%22%3E%20%3Cpath%20class%3D%22cls-1%22%20d%3D%22M20.58579%2C14.27206h0a2%2C2%2C0%2C0%2C0%2C0%2C2.82842L30.48529%2C27l-9.89951%2C9.89951a2%2C2%2C0%2C0%2C0%2C0%2C2.82842h0a2%2C2%2C0%2C0%2C0%2C2.82842%2C0L34.72794%2C28.41421a2%2C2%2C0%2C0%2C0%2C0-2.82842L23.41421%2C14.27206A2%2C2%2C0%2C0%2C0%2C20.58579%2C14.27206Z%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat right calc(10vw/ (750 / 100)) center;
  background-size: calc(48vw/ (750 / 100));
}
