@charset "UTF-8";

/* ページ設定 */
.snowFesWrap .mainWrap {
    color: #333;
    line-height: 1.5;
    font-size: 17px;
    font-family: "メイリオ", "ＭＳ Ｐゴシック", Arial, sans-serif;
}

.searchBox {
    background: #00a0e9;
    padding: 10px 4%;
}

.searchBox .left {
    color: #fff;
    font-size: 18px;
    padding-right: 15px;
}

.searchBox .right select {
    padding: 5px;
    font-size: 18px;
    width: 208px;
}

.searchBoxWrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

[data-element-id] .snowFesMvImg.show\@sp {
    width: 500px;
}

.snowFesMvImg img {
    width: 100%;
}

.snowFesintro .txt {
    text-align: center;
    margin-bottom: 30px;
}

.snowFesNav {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 1000;
}

.snowFesNav ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    background: #fff;
}

.snowFesNav ul li {
    width: 100%;
    margin: 0 1px;
}

.snowFesNav ul li a {
    position: relative;
    display: block;
    text-align: center;
    background: #0057a0;
    color: #fff;
    padding: 15px 7px 25px;
    line-height: 1.2;
}

.snowFesNav ul li a::after {
    font-family: "Font Awesome 5 Free";
    content: "\f107";
    font-weight: 900;
    position: absolute;
    bottom: 3px;
    left: 0;
    right: 0;
}

.snowFeslead {
  background: #f0f8ff;
  padding: 20px;
}

.snowFeslead .ttl01,
.snowFesMeasure .ttl01 {
    text-align: center;
    font-size: 30px;
    margin: 0 0 40px;
}

.snowFesMeasure.area {
    overflow: hidden;
    background: repeating-linear-gradient(-30deg, #d6f2ff 0, #d6f2ff 10px, #dbf4ff 10px, #dbf4ff 20px);
    background-color: #c3eaff;
    background-image: radial-gradient(#d6f1ff 13%, transparent 0), radial-gradient(#d6f1ff 13%, transparent 0);
    background-position: 0 0, 15px 15px;
    background-size: 30px 30px;
    padding-top: 60px;
}

.snowFesMeasure.area .wrap {
    background: #ffffff66;
    padding: 35px;
    margin: 40px 0;
    border-radius: 10px;
}

.snowFesMeasure.area .wrap:nth-of-type(1) {
    background: none;
    padding: 0 35px;
    border: none;
}

.areaDateWrap {
    background: #fff;
}

.areaDateHead {
    font-size: 24px;
    background: #00a0e9;
    color: #fff;
    text-align: center;
    padding: 7px;
}

.areaDateDetail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
}

.areaDateDetail dl {
    width: 100%;
    margin: 25px 0;
    text-align: center;
}

.areaDateDetail dl:first-of-type {
    border-right: 1px solid #ccc;
}

.areaDateDetail dl dt {
    font-size: 16px;
    display: inline-block;
    background: #c2ecff;
    padding: 7px 10px;
    margin: 0 5px 0 0;
}

.areaDateDetail dl dd {
    margin: 10px 0 0;
    letter-spacing: 0.05em;
}

.areaDateDetail dl dd .fonts {
    font-size: 21px;
}

.areaDateDetail dl dd .fontL {
    font-size: 45px;
}

.areaDateDetail dl dd .fontM {
    font-size: 23px;
}

.areaDateDetail2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    /*color: #fff;*/
    gap: 1rem;
}

.areaDateDetail2 dl {
    width: 100%;
    margin: 25px 0;
    text-align: center;
}

.areaDateDetail2 dl:nth-child(1) {
    background: #7fbfff;
    border-radius: 20px;
    margin-bottom: 10px;
}

.areaDateDetail2 dl:nth-child(2) {
    background: #e697ac;
    border-radius: 20px;
    margin-bottom: 10px;
}

.areaDateDetail2 dl:nth-child(3) {
    background: #ffff99;
    border-radius: 20px;
    margin-bottom: 10px;
}

.areaDateDetail2 dl dt {
    font-size: 28px;
    display: inline-block;
    padding: 7px 10px;
    margin: 0 5px 0 0;
}

.areaDateDetail2 dl dd {
    margin: 10px 0 0;
    letter-spacing: 0.05em;
}

.areaDateDetail2 dl dd .fonts {
    font-size: 21px;
}

.areaDateDetail2 dl dd .fontL {
    font-size: 45px;
}

.areaDateDetail2 dl dd .fontM {
    font-size: 23px;
}

.areaWrap .areaTitle {
  display: flex;
  margin-bottom: 20px;
}

.areaWrap .ttl02 {
    display: inline-block;
    position: relative;
    line-height: 51px;
    text-align: center;
    padding: 5px 0;
    font-size: 28px;
    background: #00a0e9;
    color: #fff;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0 0 10px;
}

.areaWrap .ttl02::after {
    position: absolute;
    content: "";
    z-index: 1;
    top: 0;
    right: 0;
    width: 0px;
    height: 0px;
    border-width: 30.5px 15px 30.5px 0px;
    border-color: transparent #daf4ff transparent transparent;
    border-style: solid;
}

.areaWrap .ttl02 .title {
    margin: 0;
    padding: 8px 40px 8px 15px;
    border-top: dashed 2px #FFF;
    border-bottom: dashed 2px #FFF;
    line-height: 1.5em;
}

.areaWrap .ttl02 .date {
    font-size: 17px;
    color: #fff777;
    margin-left: 15px;
    font-style: italic;
    font-weight: bold;
}

.areaWrap .day {
    font-size: 16px;
    background: rgba(255,255,255,0.7);
    border-radius: 10px;
    margin-left: 100px;
    font-weight: bolder;
    padding: 10px;
    width: 50%;
    text-align: center;
}

.areaWrap .right {
  width: 34%;
}

.areaWrap .right .img img {
  margin-bottom: 10px;
  border-radius: 10px
}

.areaWrap .left {
  width: 64%;
}

.areaWrap .left img {
  margin-bottom: 10px;
  border-radius: 10px
}

.areaWrap .addpic {
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    margin-top: 30px;
}

.areaDetail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    overflow: hidden;
    padding: 0 35px;
    margin-top: 20px;
}

.areaDetail .textBox {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 55%;
    flex: 0 0 55%;
}

.googlemapBox {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 42%;
    flex: 0 0 42%;
    height: 293px;
}

.googlemapBox iframe {
    max-width: 100%;
    height: 100%;
}

.mainTour,
.recommendWrap {
    background: #fff;
    padding: 35px;
    margin: 30px;
    position: relative;
}
.mainTour{
  margin: 30px auto;
}
.swiper-container{
  position: relative;
  overflow: inherit;
}
.swiper-button-prev{
  left: -30px;
}
.swiper-button-next{
  right: -30px;
}
.mainTour .ttl03,
.recommendWrap .ttl03 {
    font-size: 28px;
    border-bottom: 3px dotted #00a0e9;
    padding: 0 0 2px;
    margin: 0 0 12px;
    text-align: center;
    line-height: 1.2;
}

.mainTour .ttl03 .fontSmall,
.recommendWrap .ttl03 .fontSmall {
    display: block;
    font-size: 20px;
}

.mainTour .ttl03 span {
  font-size: 70%;
}

.triangle {
    margin: 0 auto;
    width: 80px;
    height: 0;
    position: relative;
    display: block;
}

.triangle::after {
    border: 40px solid transparent;
    border-bottom-color: #ffffff;
    content: "";
    position: relative;
    top: -80px;
    left: 0;
    right: 0;
}

.recommendDetail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.photoBox {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 40%;
    flex: 0 0 40%;
}

.recommendHotelSlide {
    overflow: hidden;
    /*スライダー入れたら外す*/
    position: relative;
    z-index: 0;
}

.recommendHotelSlide > .uk-slidenav-position {
    position: relative;
}

.recommendHotelSlide > .uk-slidenav-position > .uk-slideshow {
    height: 260px;
}

.recommendHotelSlide > .uk-slidenav-position > .uk-slideshow > li {
    height: 100% !important;
}

.recommendHotelSlide > .uk-slidenav-position > .uk-slideshow > li > div {
    height: 100%;
}

.recommendHotelSlide > .uk-slidenav-position > .uk-slideshow img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    /*IE対策*/
    font-family: "object-fit: cover; object-position: 50% 50%;";
}

.recommendHotelSlide .uk-slider {
    margin-left: -5px;
}

.recommendHotelSlide .uk-slider > li {
    padding-left: 5px;
}

.recommendHotelSlide .uk-slider > li > div {
    height: 85px;
}

.recommendHotelSlide .uk-slider > li > div > img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    font-family: "object-fit: cover; object-position: 50% 50%;";
}

.recommendHotelSlide .uk-slidenav-position {
    margin-top: 5px !important;
}

@media (max-width: 599px){
      .recommendHotelSlide > .uk-slidenav-position > .uk-slideshow li div {
        height: 100%;
    }

    .recommendHotelSlide > .uk-slidenav-position > .uk-slideshow {
        height: 330px;
    }
    
    .recommendHotelSlide .uk-slider {
        min-width: 100% !important;
    }
    
    .recommendHotelSlide .uk-slider > li {
        width: 33.333% !important;
    }
    
    .recommendHotelSlide .uk-slider > li > div {
        height: 80px;
    }
    
    .areaWrap .right {
         width: 98%;
         display: flex;
         margin-bottom: 10px;
    }

    .areaWrap .right img {
        margin-bottom: 10px;
    }
    
    .areaWrap .right .img:first-of-type {
        margin-right: 5px;
    }
    
    .areaWrap .left {
          width: 100%;
    }

    .areaWrap .addpic {
      margin-top: 20px;
    }
    .swiper-button-prev{
      left: -24px;
    }
    .swiper-button-next{
      right: -24px;
    }

}

.textBox {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 58%;
    flex: 0 0 58%;
}

.textBox .txt {
    margin: 10px 0 30px;
}

.textBox dl {
    margin: 0 0 30px;
    font-size: 15px;
}

.textBox dl dt {
    margin: 0 0 7px;
    font-weight: bold;
}

.tourBtn ul li .btnName {
    background: #ff6a86;
    line-height: 1;
    display: block;
    border-radius: 4px;
    margin-bottom: 3px;
    padding: 10px 2px;
    border-bottom: solid 1px #a84457;
    border-right: solid 1px #a84457;
    text-align: center;
    font-size: 18px;
    color: #fff;
    font-weight: 700;
}

.tourBtn ul li .price {
    text-align: center;
    color: #e20303;
    font-weight: bold;
    display: block;
    font-size: 16px;
}

.snowFesMeasure.hotel {
    background: #dff4ff;
    padding: 60px 0 30px;
}

.pageHead {
    max-width: 900px;
    margin: 30px auto 0;
    background: #fff;
    padding: 25px 50px 20px;
    border: 2px solid #19326d;
}

.pageHead dl dd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.pageHead dl dd label {
    display: block;
    width: 20%;
    margin-bottom: 15px;
    font-size: 16px;
}

.pageHead dl dd label:hover {
    cursor: pointer;
}

.courseHit {
    font-size: 20px;
    color: #19326d;
    margin: 10px auto 0;
    text-align: center;
}

.courseHit .courseHit_num {
    font-size: 30px;
    color: #ff4761;
}

.pageBody {
    margin-top: 30px;
}

.pageBody .frame {
    padding: 0 5px;
}

article.is-hide {
    display: none;
}

.optionBody {
    padding: 10px;
    background: #fff;
}

.optionBody .tourBtn ul li {
    padding: 0 1px;
}

.optionBody .tourBtn ul li .btnName {
    font-size: 14px;
    font-weight: 400;
}

.optionBody .tourBtn ul li .price {
    font-size: 12px;
}

.hotelName {
    font-size: 16px;
    font-weight: 900;
    margin: 10px 0 3px;
}

.optionIcon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.optionIcon li {
    display: inline-block;
    background: #00a0e9;
    padding: 3px 4px;
    margin: 0 4px 5px 0;
    font-weight: normal;
    color: #fff;
    font-size: 11px;
}

.hotelBody {
    font-size: 12px;
    padding: 0 5px 10px 5px;
    line-height: 16px;
    overflow: auto;
    height: 100px;
    margin: 0 0 10px;
}

.snowFesMeasure.info {
    padding: 60px 0;
}

.snowFesMeasure.info .ttl01 {
    margin: 0;
}

.infoWrap {
    margin: 20px 0;
}

.infoWrap dl {
    border-bottom: 1px solid #fff;
}

.infoWrap dl dt {
    background: #c2ecff;
    padding: 15px;
    font-size: 16px;
    display: block;
    cursor: pointer;
    position: relative;
    margin-top: 2px;
    min-height: 0;
    font-weight: 700;
}

.infoWrap dl dt.is-parent .openIcon::after {
    -webkit-transform: rotateZ(90deg);
    transform: rotateZ(90deg);
}

.infoWrap dl dt .openIcon {
    display: block;
    width: 30px;
    height: 30px;
    position: absolute;
    margin: auto 0px;
    top: 0;
    bottom: 0;
    right: 30px;
    background: #00a0e9;
    padding: 5px;
}

.infoWrap dl dt .openIcon::before,
.infoWrap dl dt .openIcon::after {
    content: "";
    display: block;
    background-color: #fff;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
}

.infoWrap dl dt .openIcon::before {
    width: 18px;
    height: 4px;
}

.infoWrap dl dt .openIcon::after {
    width: 4px;
    height: 20px;
}

.infoWrap dl dd {
    display: none;
    padding: 1em 2.2em;
    overflow: auto;
    font-size: 14px;
}

.infoWrap dl dd .answerTtl {
    font-weight: bold;
    margin-bottom: 2px;
}

.infoWrap dl dd .answerTxt {
    line-height: 1.4;
    margin-bottom: 15px;
}

@media (max-width: 1024px) {

    .snowFesWrap .mainWrap .inner,
    .snowFesWrap .mainWrap .inner1200 {
        max-width: 100%;
    }

    .snowFesNav ul li {
        font-size: 15px;
    }

    .mainTour,
    .recommendWrap {
        margin: 30px 0;
    }

    .tourBtn ul li .btnName {
        font-size: 2vw;
    }
    
    .tourBtn ul li .btnName small {
        font-size: 60%;
    }
}

@media (max-width: 599px) {
    .snowFesWrap .mainWrap {
        font-size: 13px;
    }

    .searchBox .inner {
        width: 100%;
    }

    .searchBox .left {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 164px;
        flex: 0 0 164px;
        font-size: 14px;
        padding-right: 10px;
    }

    .searchBox .right {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 135px;
        flex: 0 0 135px;
    }

    .searchBox .right select {
        font-size: 14px;
        width: 100%;
    }

    .snowFesintro .txt {
        text-align: left;
    }

    .snowFesNav {
        position: static;
    }

    .snowFesNav ul li {
        font-size: 13px;
    }

    .snowFesNav ul li a {
        padding: 10px 2px 17px;
        font-size: .8em;
    }

    .snowFesMeasure .ttl01 {
        font-size: 5.5vw;
        margin: 0 0 25px;
    }

    .snowFesMeasure.area {
        padding-top: 30px;
    }

    .snowFesMeasure.area .wrap {
        padding: 13px 10px;
        margin: 30px 0;
    }

    .snowFesMeasure.area .wrap:nth-of-type(1) {
        margin: 0 auto;
        padding: 0;
        width: 100%;
    }

    .areaDateHead {
        font-size: 16px;
    }

    .areaDateDetail {
        display: block;
    }

    .areaDateDetail dl {
        margin: 0;
        padding: 17px 0 15px;
    }

    .areaDateDetail dl:first-of-type {
        border-right: none;
    }

    .areaDateDetail dl dt {
        font-size: 13px;
    }

    .areaDateDetail dl dd {
        margin: 7px 0 0;
    }

    .areaDateDetail dl dd .fonts {
        font-size: 4vw;
    }

    .areaDateDetail dl dd .fontL {
        font-size: 8vw;
    }

    .areaDateDetail dl dd .fontM {
        font-size: 5vw;
    }
    
    .areaDateDetail2 {
        display: block;
    }

    .areaDateDetail2 dl {
        margin: 0;
        padding: 17px 0 15px;
    }

    .areaDateDetail2 dl:first-of-type {
        border-right: none;
    }

    .areaDateDetail2 dl dt {
        font-size: 13px;
    }

    .areaDateDetail2 dl dd {
        margin: 7px 0 0;
    }

    .areaDateDetail2 dl dd .fonts {
        font-size: 4vw;
    }

    .areaDateDetail2 dl dd .fontL {
        font-size: 8vw;
    }

    .areaDateDetail2 dl dd .fontM {
        font-size: 5vw;
    }
    
    .areaWrap .areaTitle {
      display: block;
    }

    .areaWrap .ttl02 {
        font-size: 20px;
        line-height: 39px;
    }
    
    .areaWrap .day {
        width: 100%;
        margin-left: 0;
        margin-bottom: 10px;
    }

    .areaWrap .ttl02::after {
        border-width: 24.5px 15px 24.5px 0px;
    }

    .areaWrap .ttl02 .date {
        margin-left: 10px;
        font-size: 12px;
    }

    .areaImg {
        /* display: none; */
    }

    .areaDetail {
        display: block;
        padding: 0;
    }

    .mainTour,
    .recommendWrap {
        padding: 10px;
        margin: 30px 0 10px;
    }

    .mainTour .ttl03,
    .recommendWrap .ttl03 {
        font-size: 18px;
        padding: 7px 0 3px;
    }

    .mainTour .ttl03 .fontSmall,
    .recommendWrap .ttl03 .fontSmall {
        font-size: 13px;
    }

    .triangle {
        width: 40px;
    }

    .triangle::after {
        border: 20px solid transparent;
        border-bottom-color: #ffffff;
        top: -40px;
    }

    .recommendDetail {
        display: block;
    }

    .textBox .txt {
        margin: 0 0 10px;
    }

    .textBox dl {
        margin: 0 0 15px;
        font-size: 12px;
    }

    .textBox dl dt {
        margin: 0 0 3px;
    }

    .tourBtn ul li .btnName {
        font-size: 3.5vw;
        font-weight: 400;
    }

    .tourBtn ul li .price {
        font-size: 3vw;
    }

    .snowFesMeasure.hotel {
        padding: 30px 0;
    }

    .pageHead {
        margin: 15px auto 0;
        padding: 20px 0 15px;
    }

    .pageHead dl dd {
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .pageHead dl dd label {
        width: 48%;
        margin-bottom: 10px;
        padding-left: 5%;
        font-size: 4vw;
    }

    .courseHit {
        font-size: 16px;
        margin: 0 auto;
    }

    .courseHit .courseHit_num {
        font-size: 26px;
    }

    .pageBody {
        margin-top: 20px;
    }

    .hotelName {
        font-size: 14px;
    }

    .hotelBody {
        height: auto;
    }

    .snowFesMeasure.info {
        padding: 30px 0;
    }

    .snowFesMeasure.info .inner,
    .snowFesMeasure.info .inner1200 {
        width: 100%;
    }
}


.snowFesSearch .searchBox {
    background: #fff;
    padding: 10px 4%;
}

.snowFesSearch .ttl01 {
    text-align: center;
    font-size: 30px;
    margin: 0 0 40px;
}

.snowFesSearch .ttl02 {
    padding: 8px;
    background: #206D9D;
    color: #fff;
    font-size: 24px;
    font-weight: bold;
    text-align: center;
}

.snowFesSearch .searchBox .body {
    padding: 20px;
    background: #EFF6FA;
    font-size: 18px;
}

.snowFesSearch .searchBox .button label {
    display: block;
    position: relative;
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
}

.snowFesSearch .searchBox .button input {
    width: 100%;
    padding: 10px 5px;
    background: #E8560D;
    border: none;
    border-radius: 8px;
    color: #fff;
    font-weight: bold;
    line-height: 1;
    font-size: 20px;
    cursor: pointer;
}

@media (max-width: 599px) {
  .snowFesSearch .ttl02 {
    font-size: 20px;
  }
  
  .snowFesSearch .searchBox .body {
    font-size: 16px;
  }
}

.getdpprice {
  margin: 0 auto;
}

.getdpprice .pri {
    color: #ff2b06;
    font-weight: bold;
    font-size: 30px;
    font-style: italic;
}

.getdpprice .yen {
    color: #ff2b06;
    font-weight: bold;
    font-size: 20px;
}
form[name=tbpnSearch] label{border:none;padding:0;height:auto;}
.selWrap input{padding:0;}
#pax p{
  border: 1px solid #aaa;
  background: #fff;
  padding: 0 1rem;
  margin: 0 1rem;
}
#tbpnSearch > div.sw{width:800px;margin: 0.5rem auto;display:flex;flex-wrap:wrap;}
#tbpnSearch dl{
  display:flex;
  flex-wrap:wrap;
  align-items: center;
  width:calc(100% / 2 - 1rem);
}
#tbpnSearch .paxTable dl.fx{width:auto;}
form[name=tbpnSearch] dl.pax{border:none;height:auto;}
form[name=tbpnSearch] dl.pax dt {
    font-size: inherit;
    color: inherit;
    position: initial;
    width: auto;
    display: inherit;
}
.pax_sel{font-size:.8rem;}
form[name=tbpnSearch] dl.pax dd{padding:0;width:auto;height:auto;}
#pax p {
    border: 1px solid #333;
    padding: 0 0.5rem;
    margin: 0;
    font-size: inherit;
}
.wbfCalender {
    width: 100%;
    padding: 0 0.5rem;
    font-size: initial;
    border: 1px solid #333;
    border-radius: 0;
}
form[name=tbpnSearch] label[name=date]::before{content:"";}
form[name=tbpnSearch] label[name=tbpn_adt]::before {content: "";}
form[name=tbpnSearch] label[name=tbpndep]::before {
    content: "";
}
#tbpnSearch dl.pax{width:100%;}
#tbpnSearch dt{width: 6rem;}
#tbpnSearch > div dd{width:calc(100% - 7rem);}
#calendar table{display:none;}
#calendar table#cal_2026_2{display:table;width:100%;height: 350px;}
#calenderBox{width:40%;left: 30%;}
.searchBtn{
  width: 240px;
  margin: 1rem auto 0;
}
.searchBtn button{
    width: 100%;
    padding: 10px 5px;
    background: #E8560D;
    border: none;
    border-radius: 8px;
    color: #fff;
    font-weight: bold;
    line-height: 1;
    font-size: 20px;
    cursor: pointer;
}


@media (max-width: 599px) {
  .getdpprice .pri {
    font-size: 20px;
  }
  .getdpprice .yen {
    font-size: 15px;
  }
  #tbpnSearch > div.sw{width:100%;margin:0 auto;}
#tbpnSearch dl {
    width: 100%;
    margin-bottom: 0.5rem;
}
  #tbpnSearch select {
      width: 100%;
      padding: 0.2rem 0.5rem;
      border-radius: 0;
  }
  #tbpnSearch input {
    padding: 0 0 0 0.5rem;
  }
  #calenderBox {
      width: 90%;
      left: 0;
  }
  
}
.bnrImg img {
  margin: 0 auto;
}

/* 2022.12.15 */
.searchbox {
    width: 90%;
    padding: 40px;
    margin: 2rem auto;
    background: #fff;
    border-radius: 4px;
}
.sfd_air select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: block;
    cursor: pointer;
    margin: 0;
    border: 0;
    background: transparent;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    font-size: 14px;
    color: #333;
    padding: 25px 30px 6px 10px;
}
.searchboxWrap {
    background: #c3eaff;
    margin: 4rem 0;
    padding: 2rem 0;
}
.searchboxWrap .ttl01 {
    text-align: center;
    font-size: 30px;
    margin: 0 0 40px;
}
@media (max-width: 599px) {
  .searchboxWrap .ttl01 {
      font-size: 22px;
      margin: 0;
  }
  .searchbox{padding:20px;}
  .searchBtn {width: 100%;}
}


/* すらいどつあー　*/
/* ================================
mainTour
================================== */

.mainTour{
  width: 100%;
}
.mainTour h4{
  text-align: center;
  margin: 10px;
  font-size: 25px;
}
.depWrap .depItem.active a{
  border:none;
  margin: 0 0 30px 0;
}
.mainTour .depWrap .depItem a {
    border: 1px solid #a9a9a9;
    border-radius: 15px;
    width: 25%;
    /*margin: 0 10px;*/
}
.mainTour .tabWrap {
  overflow-x: inherit;
}
.mainTour .tabBody {
  overflow-x: inherit;
}
.mainTour .depItem {
  width: 100%;
}
.mainTour .depItem .pic img {
  border-radius: 15px 15px 0 0 ;
}
.mainTour .depItem .center .areaList {
  font-size: 14px;
  background: #0057a0;
  color: #fff;
  padding: 5px 10px;
  width: 50%;
  text-align: center;
}
.mainTour .depItem .center .tit {
  font-size: 20px;
  font-weight: bold;
}
.mainTour .depItem .center .alt {
  font-size: 20px;
  font-weight: bold;
  padding: 8px 15px;
  border-bottom: 3px dotted #020724;
}
.mainTour .depItem .center .text {
  font-size: 18px;
  display: block;
}
.mainTour .depItem .bottom {
  padding: 15px;
}
.mainTour .getdpprice .pri {
  color: #ed5629;
  font-size: 30px;
  font-weight: bold;
}
.mainTour .getdpprice .pri .yen {
  font-size: 80%;
}
.mainTour .getdpprice + .getdpprice_info {
    font-size: 14px;
    color: #555;
    display: block;
}
.block-type-02 .center .sub {
    margin-top: 30px;
    padding: 0 20px;
    text-align: center;
    font-size: 80%;
}
.snowFesWrap .block-type-02 .bottom .getdpprice {
  width: 100%;
  margin: 0;
}

.snowFesWrap .reader-clamp-2 {
  max-height: 3em;
  display: block;
  overflow: visible;
}
.swiper-button-next, .swiper-button-prev {
      top: 70%;
}

@media (max-width: 767px) {
  .depWrap .depItem.active a{
    margin: 0;
    width: 100%;
  }
  .mainTour h4 {
    font-size: 18px;
  }
  .block-type-02 .up {
      width: 100%;
    }
  .block-type-02 .center {
      width: 100%;
    }
  .mainTour .depItem .center .tit {
      margin: 10px;
      padding: 0;
      font-size: 18px;
    }
  .block-type-02 .center .sub {
      font-size: 14px;
    }
  .mainTour .depItem .center .areaList {
      width: 90%;
      margin: 10px auto;
    }
  .block-type-02 .bottom .getdpprice, .getdpprice_info {
      text-align: center;
      margin-bottom: 10px;
    }
}

.swiper-button-prev:before {
  content: '';
  color: #fff;
  background: url(/upload/tenant_1/fukuokaHotel_arrow02.png);
  display: inline-block;
  width: 26px;
  height: 51px;
}
.swiper-button-next:after{
  content: '';
  color: #fff;
  background: url(/upload/tenant_1/fukuokaHotel_arrow01.png);
  display: inline-block;
  width: 26px;
  height: 51px;
}

@media (max-width: 820px){
    .swiper-button-prev:before, .swiper-button-next:after{
    width: 13px;
    height: 25px;
    background-size: 100%;
  }
}

.fesimage {
  display: flex;
}

.fesimage img {
  border-radius: 10px;
  width: calc(100% / 3 - 5px);
  margin: 0 auto;
}

.addpic span {
  font-size: 22px;
}

@media (max-width: 767px){
  .fesimage {
  }
  .fesimage img {
    width: 30%;
    margin-bottom: 10px;
  }
  .line {
    margin-bottom: 10px;
  }
  .addpic span {
    font-size: 18px;
  }
}

.article {
  background: #dff4ff;
    padding: 60px 0 30px;
}

.article .ttl01 {
  text-align: center;
    font-size: 30px;
    margin: 0 0 40px;
}

.article ul li img {
  margin-bottom: 10px;
    overflow: hidden;
}

.article h4 {
  font-weight: 700;
}

@media (max-width: 767px) {
  .article .ttl01 {
    font-size: 16px;
  }
}



.kanko .kankoWrap {
  display: flex;
}

.kanko .kankoWrap .card {
  width: 45%;
  background: #ffffff66;
  border-radius: 10px;
  padding: 20px;
  margin: 0 auto 10px;
}

.kanko .kankoWrap .card img {
  margin-bottom: 10px;
  border-radius: 10px;
}

.kanko .kankoWrap .card h3 {
  font-weight: bold;
  text-align: center;
  font-size: 1.4rem;
}

.kanko .kankoWrap .card .text {
  text-align: center;
  margin-bottom: 10px;
}

.kanko .kankoWrap .card .detail {
  text-align: center;
}

.kanko .kankoWrap .card a {
  padding: 5px 10px;
  border: 3px solid #0057a0;
  border-radius: 30px;
  background: #fff;
}


@media (max-width: 767px){
  .kanko .kankoWrap {
  display: block;
}
  .kanko .kankoWrap .card {
    width: 95%;
  }
}


.optionBody .cmsn .tourBtn ul li .cmsnWrap{position:relative;}
.optionBody .cmsn .tourBtn ul li .cmsnWrap::before {
  content: "";
  background: #696969c9;
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.optionBody .cmsn .tourBtn ul li .cmsnWrap::after {
    content: "Coming Soon!";
    position: absolute;
    top: 50%;
    left: 20%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    display: block;
    color: #fff;
    font-size: 180%;
    z-index: 4;
    font-weight: bold;
    transform: rotate(-8deg);
    text-align: center;
}

.optionBody.cmsn{
  position:relative;
}
.optionBody.cmsn::before {
    content: "";
    background: #333c;
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    z-index: 1;
    left: 0;
    top: 0;
}
.optionBody.cmsn::after {
    content: "coming\a0soon";
    color: #fff;
    z-index: 3;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    font-size: 25px;
    width: 100%;
    text-align: center;
    text-shadow: 0 0 10px #333;
}

/* 地図追加 */

.map_new .yukimatsuriMap{
  border: solid 10px #FFF;
  margin-bottom: 30px;
}
.map_new .directions{
  margin-bottom: 30px;
}
.map_new .directions ul{
  background-color: #FFF;
  padding: 20px;
  display: flex;
  text-align: center;
  align-items: center;
  justify-content: space-between;
  font-weight: bold;
}
.map_new .directions ul li{
  width: 23%;
}
.map_new .directions ul li:first-child{
  padding: 10px;
  border: dotted 2px #bad3f4;
}
.map_new .directions ul li span{
  display: block;
  background: #32b1e8;
  border-radius: 6px;
  margin-bottom: 5px;
  color: #FFF;
  padding: 5px;
}
.map_new .directions ul li:nth-child(3) span{
  background: #922690;
}
.map_new .directions ul li:last-child span{
  background: #13b2a6;
}
.map_new .overview{
  background-color: #FFF;
  padding: 20px;
}
.map_new .overview p{
  border: dotted 2px #bad3f4;
  padding: 20px;
}
@media (max-width: 599px){
  .map_new .yukimatsuriMap{
    margin-bottom: 15px;
    overflow-x: scroll;
  }
  .map_new .yukimatsuriMap img{
      width: 600px;
      max-width: max-content;
  }
  .map_new .directions{
      margin-bottom: 15px;
  }
  .map_new .directions ul{
  display: block;
  }
  .map_new .directions ul li{
  width: 100%;
      margin-bottom: 10px;
  }
  .map_new .directions ul li:last-child {
  margin-bottom: 0px;
  }
  .map_new .overview{
  padding: 15px;
  }
  .map_new .overview p{
  padding: 15px;
  }
}


.campImg {
  max-width: 90%;
  margin: 0 auto;
}

.snowFesend .endtxt {
    border: 3px solid #1D7DBE;
    border-radius: 5px;
    text-align: center;
    padding: 10px;
    line-height: 1.5em;
    margin: 10px auto;
    width: 90%;
    font-weight: bold;
}

@media (max-width: 599px){
  .snowFesend .endtxt{
    margin-top: 60px;
    background-color: #fff;
  }
}
