@charset "utf-8";
/* CSS Document */
:root{
  --red: #d0505d;
  --blue: #1e9cb5;
  --yellow: #e7df4c;
  --green: #04b58b;
  --purple: #b66999;
  --t_red: rgba(208 80 93 / 80%);
  --line_red: linear-gradient(transparent 85%, #d0505d 85%);
  --line_yel: linear-gradient(transparent 85%, #e7df4c 85%);
  --line_gre: linear-gradient(transparent 85%, #04b58b 85%);
  --border: 5px solid;
  --bg: no-repeat center top;
  --center_cover: no-repeat center center / cover;
  --center_contain: no-repeat center center / contain;
}

.nopc{
  display: none;
}
.main *{
  box-sizing: border-box;
  font-family: 'Noto Sans JP', sans-serif;
}
.inner{
  width: 992px;
  margin: auto;
}
.note-txt{
  font-size: 12px;
  padding-left: 1.0em;
  position: relative
}
.note-txt::before{
  content: "※";
  position: absolute;
  top: 0;
  left: 0
}
.title-wrapper{
  width: 100%;
  height: 540px;
  background: var(--bg);
  background-image: url("../img/bg_mvpc_oka.jpg")
}
.hok .title-wrapper{
  background-image: url("../img/bg_mvpc_hok.jpg")
}
.title-box{
  width: 992px;
  margin: auto;
  padding: 20px 0;
}
.main-title{
  text-align: center;
  margin-bottom: 10px;
}
.lead-copy{
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  color: #FFF;
}
.lead-copy .txt-highlight{
  display: inline;
  background: var(--line_yel);
  font-size: 28px;
  text-align: center;  
}
.lead-copy span:last-child{
  display: block;
}
.select-box{
  display: flex;
  justify-content: center;
  position: relative;
}
.select-box>li{
  width: 240px;
  cursor: pointer;
  position: relative;
}
.select-box>li.is-current{
  bottom: -30px;
  z-index: 10
}
.select-box>li .js-area-select{
  transition: 0.3s;
}
.select-box>li .js-area-select:hover{
  transform: translate(0,20px);
}
.nav-wrapper{
  position: relative;
  z-index: 30;
  box-shadow: 0 2px 10px -12px rgba(0 0 0 / 50%);
  background: var(--red);
}
.hok .nav-wrapper{
  background: var(--green);
}
.nav-wrapper>.inner{
  display: flex;
  justify-content: space-between;
}
.menu-list{
  width: calc(100% - 120px);
  display: flex;
  justify-content: space-between;
  border-right: 1px solid #FFF;
  border-left: 1px solid #FFF;
}
.menu-list>li{
  width: calc(100% / 4);
  border-right: 1px solid #FFF;
  flex-grow: 1
}
.menu-list>li:last-child{
  border-right: none
}
.menu-list>li>a{
  display: block;
  font-weight: 700;
  color: #FFF;
  text-align: center;
  padding: 10px 10px 30px;
  position: relative;
}
.menu-list>li>a::after{
  content: "";
  background: var(--center_contain);
  background-image: url("../img/arrow02.svg");
  width: 15px;
  height: 15px;
  position: absolute;
  right: 0;
  bottom: 10px;
  left: 0;
  margin: auto
}
.menu-list>li>a:hover{
  color: var(--red);
  background: #FFF;
}
.hok .menu-list>li>a:hover{
  color: var(--green)
}
.menu-list>li>a:hover::after{
  background-image: url("../img/arrow01.svg");
}
.hok .menu-list>li>a:hover::after{
  background-image: url("../img/arrow03.svg");
}
.display_selected {
  background: var(--yellow);
  width: 120px;
  height: 82px;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  line-height: 28px;
  position: relative;
  cursor: pointer;
}
.display_selected::before{
  content: "出発地";
  display: block;
  font-size: 12px;
}
.display_selected::after {
  content: "";
  background: url("../img/arrow04.png") var(--center_contain);
  width: 16px;
  height: 12px;
  position: absolute;
  right: 0;
  bottom: 10px;
  left: 0;
  margin: auto
}
.dep-select-zone{
  display: none;
  width: 120px;
  position: absolute;
  z-index: 30;
  border-top: none;
  background: #FFF;
}
.dep-select li {
  cursor: default;
  padding: 2px 10px;
  text-align: center;
}
.dep-select li:hover,
.dep-select li.selected {
  background: var(--yellow);
}
.close-button{
  display: none
}

/*** メインコンテンツ ***/
.content-wrapper{
  background: var(--bg);
  position: relative;
  background-color: #d5f5ff;
  padding: 50px 0;
}
.hok .content-wrapper{
  background-color: #cfdead;
}
.content-wrapper.bbq{
  background-image: url("../img/bg_bbqpc_oka.jpg");
  height: 740px;
  padding: 0
}
.hok .content-wrapper.bbq{
  background-image: url("../img/bg_bbqpc_hok.jpg");
}
.content-wrapper.course{
  background-image: url("../img/bg_oka.png");
  z-index: 30;
  padding-bottom: 0;
  border-bottom: var(--border) var(--red)
}
.hok .content-wrapper.course{
  background-image: url("../img/bg_hok.png");
  border-bottom-color: var(--green)
}
.hok .content-wrapper.area{
  background: url("../img/bg-cont.gif") repeat;
  position: relative;
  z-index: 30
}
.content-wrapper.kerama{
  background-image: url("../img/bg_snorkel.jpg");
}
.head-title{
  text-align: center;
  margin-bottom: 50px;
}
.head-title>span{
  display: inline-block;
  font-size: 54px;
  font-weight: 900;
  color: var(--red);
  text-align: left;
  line-height: 1.2;
  position: relative;
  padding-left: 150px;
}
.hok .head-title>span{
  color: var(--green)
}
.head-title#bbq>span{
  color: var(--blue);
  padding-left: 0;
  text-align: center;
}
.hok .head-title#bbq>span{
  color: var(--purple);
}
.head-title#kerama>span{
  color: var(--yellow);
  padding-left: 265px;
}
.head-title#area{
  margin-bottom: 20px;
}
.head-title#area>span{
  padding-left: 265px;
}
.head-title:not(#bbq)>span::before{
  content: "";
  background: var(--center_contain);
  background-image: url("../img/badge_oka.png");
  width: 140px;
  height: 135px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
.head-title#oka>span::before,
.head-title#isg>span::before{
  background-image: url("../img/badge_oka.png");
}
.head-title#kerama>span::before{
  background-image: url("../img/badge_oka_special.png");
  width: 255px;
}
.head-title#course>span::before{
  background-image: url("../img/badge_hok.png");
}
.head-title#area>span::before{
  background-image: url("../img/badge_hok_special.png");
  width: 255px;
}
.intro-box{
  background: var(--center_cover);
  background-image: url("../img/bg_intro_oka.png");
  width: 860px;
  height: 828px;
  position: absolute;
  top: -40px;
  right: 0;
  left: 0;
  z-index: 10;
  margin: auto;
  padding-top: 80px;
  text-align: center;
}
.hok .intro-box{
  background-image: url("../img/bg_intro_hok.png");
  padding-top: 150px;
}
.intro-txt{
  margin: 30px 180px 20px;
  font-size: 26px;
  font-weight: 900;
}
.txt-line{
  display: inline;
  background: var(--line_red);
}
.hok .txt-line{
  background: var(--line_gre);
}
.txt-em{
  display: block;
  margin: 20px auto 10px;
  color: var(--red);
}
.hok .txt-em{
  color: var(--green);
}
.notice-box{
  width: 360px;
  margin: 20px auto;
  text-align: left
}

.hotel-list{
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 30;
}
.hotel-list>li{
  width: calc(98% / 6);
  min-height: 60px;
  margin-right: 0.4%;
  border: var(--border) var(--red);
  border-bottom: none;
  padding: 0 10px;
  font-weight: 700;
  color: #FFF;
  background: var(--red);
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex-grow: 1;
}
.hotel-list>li.is-active,
.hotel-list>li:hover{
  background: #FFF;
  color: var(--red);
  position: relative
}
.hotel-list>li.is-active::after{
  content: "";
  width: 100%;
  height: 5px;
  background: #FFF;
  position: absolute;
  bottom: -5px;
  left: 0;
}
.hok .hotel-list>li{
  border-color: var(--green);
  background: var(--green);
}
.hok .hotel-list>li.is-active,
.hok .hotel-list>li:hover{
  background: #FFF;
  color: var(--green)
}
.js-hotel-button{
  display: none
}
.item-wrap{
  background: url("../img/bg-cont.gif") repeat;
  border-top: var(--border) var(--red);
  padding: 50px 0;
  position: relative;
  z-index: 10
}
.hok .item-wrap{
  border-color: var(--green)
}
.item-content{
  display: none;
  width: 992px;
  margin: auto;
}
.item-content.is-active{
  display: block
}
.item-box{
  display: flex;
  justify-content: space-between;
}
.in-box{
  width: calc(96% / 2);
}
.sub-title{
  background: url("../img/bg_ttl_oka.jpg") left top;
  min-height: 120px;
  position: relative;
  padding: 20px 5px;
  font-size: 34px;
  font-weight: 900;
  color: #FFF;
  padding-left: 125px;
  margin-bottom: 20px;
  line-height: 1.2;
  display: flex;
  flex-direction: column;
  justify-content: center
}
.hok .sub-title{
  background: url("../img/bg_ttl_hok.jpg") left top;
}
.sub-title>small{
  font-size: 22px;
  display: block;
  margin-bottom: 5px;
}
.course-label{
  width: 95px;
  height: 100px;
  border-radius: 0 0 20px 20px;
  background: var(--yellow);
  padding: 0 10px;
  font-size: 22px;
  font-weight: 900;
  color: var(--blue);
  text-align: center;
  position: absolute;
  top: 0;
  left: 20px;
  line-height: 100px;
}
.hok .course-label{
  height: 120px;
  color: var(--purple);
  line-height: 120px;
}
.item-txt{
  font-weight: 900
}
.item-ph{
  width: 100%;
  height: 360px;
  position: relative;
  margin-top: 80px;
}
.item-ph>img{
  width: 100%;
  height: 100%;
  object-fit: none;
  object-position: center;
  border-radius: 20px;
}
.item-ph::before{
  content: "";
  background: var(--center_contain);
  background-image: url("../img/ill_htl_oka.png");
  width: 370px;
  height: 117px;
  position: absolute;
  top: -30px;
  left: 0;
}
.hok .item-ph::before{
  background-image: url("../img/ill_htl_hok.png");
}
.ph-caption{
  display: block;
  font-weight: 700;
  color: var(--blue);
  margin-top: 5px;
}
.hok .ph-caption{
  color: var(--purple)
}

.tokuten-content>li+li{
  margin-top: 30px;
}
.tokuten-ph{
  margin: 0 auto 30px;
  width: 330px;
  height: 240px;
  position: relative;
}
.tokuten-ph>img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 20px;
  border: var(--border) var(--red);
}
.hok .tokuten-ph>img{
  border-color: var(--green);
}
.tokuten-ph::after{
  content: "";
  background: var(--center_contain);
  width: 146px;
  height: 150px;
  position: absolute;
  right: -70px;
  bottom: -30px;
}
.tokuten-ph.bbq::after{
  background-image: url("../img/ico_bbq_oka.png")
}
.tokuten-ph.bbq.manza::after{
  background-image: url("../img/ico_bbq_oka_ana.png");
  height: 234px;
}
.tokuten-ph.active::after{
  background-image: url("../img/ico_activity_oka.png")
}
.hok .tokuten-ph.bbq::after{
  background-image: url("../img/ico_bbq_hok.png")
}
.hok .tokuten-ph.active::after{
  background-image: url("../img/ico_activity_hok.png")
} 
.tokuten-midashi{
  font-size: 22px;
  font-weight: 900;
  color: var(--red);
  text-align: center;
  line-height: 1.2
}
.tokuten-midashi.manza{
  color: var(--blue);
}
.hok .tokuten-midashi{
  color: var(--green)
}
.tokuten-midashi small{
  font-size: 14px;
  color: #000;
}
.tokuten-data>li{
  font-weight: 500;
}
.tokuten-data.dot>li{
  position: relative;
  padding-left: 1.0em
}
.tokuten-data.dot>li::before{
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
.tokuten-txt{
  font-size: 16px;
  font-weight: 900;
  margin: 10px auto;
}
.tokuten-txt>span{
  color: var(--red);
}
.tokuten-list{
  margin-top: 10px;
}
.tokuten-list>li{
  position: relative;
  padding-left: 1.2em;
  font-weight: 500;
}
.tokuten-list>li>span{
  font-size: 16px;
  font-weight: 900;
}
.tokuten-list>li::before{
  content: "●";
  position: absolute;
  top: 4px;
  left: 0;
  color: var(--red);
  font-size: 10px;
}

/*** 沖縄 慶良間***/
.special-wrap{
  background: rgba(255 255 255 / 90%);
  padding: 20px;
}
.special-title{
  font-size: 24px;
  font-weight: 900;
  color: var(--red);
  text-align: center;
  margin-bottom: 10px;
}
.specia-copy{
  font-size: 18px;
  font-weight: 900;
  margin-bottom: 50px;
}
.special-list{
  display: flex;
  justify-content: space-between;
}
.special-list>li{
  width: calc((100% - 40px) / 3);
}
.special-ph{
  margin-bottom: 5px;
  width: 300px;
  height: 220px;
  position: relative;
}
.special-ph>img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 20px;
  border: var(--border) var(--blue);
}
.special-list.active>li .special-ph::before{
  content: "";
  background: var(--center_contain);
  width: 189px;
  height: 80px;
  position: absolute;
  top: -40px;
  left: 0;
}
.special-list.active>li:first-child .special-ph::before{
  background-image: url("../img/ico_a.png")
}
.special-list.active>li:nth-child(2) .special-ph::before{
  background-image: url("../img/ico_b.png")
}
.special-midashi{
  font-size: 22px;
  font-weight: 900;
  color: var(--blue);
  text-align: center;
  margin-bottom: 5px;
}
.special-txt{
  font-size: 16px;
  font-weight: 900;
}
.special-txt small{
  font-size: 12px;
  display: block
}
.special-shedule{
  font-size: 24px;
  font-weight: 900;
  color: var(--red);
}
.special-shedule>small{
  font-size: 14px;
  color: #000;
}
.schedule-list>li{
  font-weight: 700;
}
.schedule-list>li>small{
  font-size: 12px;
  display: block;
}
.schedule-midashi{
  font-size: 18px;
  font-weight: 900;
  color: var(--blue);
}
.schedule-list>li+.schedule-midashi{
  margin-top: 10px;
}
.special-list.food{
  margin-top: 20px;
  padding: 20px;
  background: var(--red);
  border-radius: 20px;
}
.special-list.food .special-ph{
  height: 180px;
}
.special-list.food .special-ph>img{
  border: none
}
.special-list.food .special-midashi{
  color: var(--yellow);
}
.special-midashi.badge{
  padding-left: 130px;
  position: relative;
  text-align: left;
  margin-bottom: 20px;
}
.special-midashi.badge>small{
  font-size: 14px;
  display: block;
}
.special-midashi.badge::before{
  content: "";
  background: url("../img/ico_bbq_oka.png") var(--center_contain);
  width: 117px;
  height: 120px;
  position: absolute;
  top: 0;
  left: 0;
}
.special-list.food .special-txt{
  color: #FFF;
}
.special-data{
  color: #FFF;
}

/*** 北海道エリア ***/
.spot-wrap{
  background: url("../img/map_hok.png") no-repeat 4% top;
  background-size: calc(((96% / 3) *2)) auto;
  padding-top: 80px;
}
.spot-list{
  display: flex;
  flex-wrap: wrap;
  position: relative;
}
.spot-list::before{
  content: "";
  display: block;
  width: calc(((96% / 3) *2) + 4%);
}
.spot-list>li{
  width: calc(96% / 3);
}
.spot-list>li:nth-child(n+2):nth-child(-n+3){
  margin-right: 2%;
}
.spot-list>li:nth-child(n+2){
  margin-top: 80px;
}
.spot-ph{
  position: relative
}
.spot-ph>img:not(.spot-kazari){
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 20px;
  border: var(--border);
}
.furano .spot-ph>img:not(.spot-kazari){
  border-color: var(--purple);
}
.niseko .spot-ph>img:not(.spot-kazari){
  border-color: #437fb3
}
.tokachi .spot-ph>img:not(.spot-kazari){
  border-color: #de8733
}
.tomamu .spot-ph>img:not(.spot-kazari){
  border-color: var(--green);
}
.spot-kazari{
  position: absolute;
  top: -40px;
  left: 0;
}
.spot-name{
  font-size: 22px;
  font-weight: 900;
  margin: 5px auto;
}
.furano .spot-name{
  color: var(--purple);
}
.niseko .spot-name{
  color: #437fb3
}
.tokachi .spot-name{
  color: #de8733
}
.tomamu .spot-name{
  color: var(--green);
}
.spot-catch{
  font-size: 16px;
  font-weight: 900;
}

/*** 注意事項 ***/
.notice-wrapper{
  background: #FFF;
  padding-bottom: 20px;
}
.notice-title{
  background: var(--blue);
  font-size: 24px;
  font-weight: 900;
  color: #FFF;
  text-align: center;
  padding: 10px;
  margin-bottom: 20px;
}
.hok .notice-title{
  background: var(--purple);
}
.tour-notice{
  padding: 0 20px;
  margin-bottom: 20px;
}
.tour-notice:last-child{
  margin-bottom: 0
}
.tour-notice:nth-child(n+5):nth-child(-n+6) .tour-notice__s_midashi.activity{
  display: none
}
.tour-notice>li{
  font-size: 12px
}
.tour-notice>li.tour-notice__midashi{
  font-size: 16px;
  font-weight: 900;
  margin-bottom: 5px;
}
.tour-notice__s_midashi{
  font-size: 14px;
  color: var(--blue);
  font-weight: 700;
}
.hok .tour-notice__s_midashi{
  color: var(--purple)
}
.tour-notice>li.asta{
  padding-left: 1.0em;
  position: relative;
}
.tour-notice>li.asta::before{
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}

/*** 商品部分 ***/
.area00{
  display: none;
  width: 992px;
  margin: auto;
}
.area00.is-display{
  display: block;
}
.sub-title__tour{
  font-size: 24px;
  font-weight: 900;
  color: var(--blue);
  text-align: center;
  margin: 60px auto 20px;
}
.hok .sub-title__tour{
  color: var(--purple)
}
.more-link{
  width: 800px;
  margin: 30px auto 0;
}
.more-link>a{
  display: block;
  background: var(--red);
  border: var(--border) var(--red);
  border-radius: 30px;
  font-size: 16px;
  font-weight: 700;
  color: #FFF;
  text-align: center;
  padding: 12px;
  transition: 0.3s;
  position: relative
}
.more-link>a::after{
  content: "";
  background: var(--center_contain);
  background-image: url("../img/arrow09.svg");
  width: 14px;
  height: 14px;
  position: absolute;
  top: 0;
  right: 3%;
  bottom: 0;
  margin: auto;
}
.kerama .more-link>a::after{
  background-image: url("../img/arrow06.svg");
}
.more-link>a:hover{
  border: var(--border);
  background: #FFF;
  color: var(--red);
}
.more-link>a:hover::after{
  background-image: url("../img/arrow07.svg");
}
.hok .more-link>a:hover::after{
  background-image: url("../img/arrow08.svg");
}
.kerama .more-link>a:hover::after{
  background-image: url("../img/arrow05.svg");
}
.hok .more-link>a{
  background: var(--green);
  border-color: var(--green);
}
.hok .more-link>a:hover{
  background: #FFF;
  color: var(--green);
}

/*** 0626追加 ANAインターコンチネンタル万座 駄菓子ランド ***/
.add-content-wrapper{
  background: var(--red);
  border-radius: 20px;
  margin: 30px auto;
  padding: 20px;
}
.add-content__title{
  font-size: 30px;
  font-weight: 900;
  color: var(--yellow);
  position: relative;
  padding: 20px 0 20px 130px;
}
.add-content__title span{
  font-size: 70%;
  display: block;
}
.add-content__title::before{
  content: "";
  background: url("../img/ico_htl_oka.png") var(--center_contain);
  width: 120px;
  height: 124px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
}
.add-content__flexbox{
  display: flex;
  gap: 20px;
  margin-top: 10px;
}
.add-content__copy{
  width: calc((100% -  (20px * 2)) / 3);
}
.copy-txt{
  font-size: 22px;
  font-weight: 700;
  color: #FFF;
}
.add-content_note{
  margin-top: 10px;
}
.add-content_note>li{
  font-size: 12px;
  font-weight: 500;
  color: #FFF;
  position: relative;
  padding-left: 1.0em
}
.add-content_note>li::before{
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.add-content__img{
  flex: 1
}
.add-content__ph{
  display: flex;
  gap: 20px;
}
.add-content__ph>li{
  width: 100%;
  height: 180px;
  overflow: hidden;
  border-radius: 20px;
}
.add-content__ph img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 20px;
}