/* 共通 */
:root{
    --radius:6px;
    --pdd:10px;
    --left-width:150px;
    --main-color:#0070b3;
}
/* reset */
:focus {
  outline: none;
}
button {
  padding: 0;
  border: none;
  outline: none;
  font: inherit;
  color: inherit;
  background: none
}

.searchBox_wbf{
    width:90%;
    margin:0 auto;
}
.searchBox_wbf.ptn_1 {
    width: 100%;
    margin: 0 auto;
    padding-top: 0;
}

#ovl i{display:none;}
#ovl.air i{
    display:block;
    font-size: 40px;
    color: #fff;
    margin: 5px var(--pdd);
    float: right;
}
#ovl2 {
    height: 100vh;
    background: rgba(0, 0, 0, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 42;
    width: 100%;
}

/* BOX */
.sbw__box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.sbw__box + .sbw__box{margin-top:var(--pdd);}
.sbw__box > *{
    width:calc(100% / 2 - var(--pdd));
}
.sbw__box_col1{margin:var(--pdd) 0;}

.sbw__content{
    cursor:pointer;
    display:block;
    position:relative;
    overflow: hidden;
    background:#fff;
    /* padding:calc(var(--pdd) + 5px) var(--pdd) var(--pdd) var(--pdd); */
    border:1px solid #ccc;
    border-radius:var(--radius);
}
.sbw__content.err{border: 1px solid #df3838;}

/* input、selectのスタイルを一括変更 */
.sbw__content * {
    moz-appearance: none;
    -webkit-appearance: none;/need for safari/
    appearance: none;
    cursor:pointer;
    border: none;
    position: relative;
    width: 100%;
    font-size: 16px;
    background:#fff;
    padding:calc(var(--pdd) + 5px) var(--pdd) var(--pdd) var(--pdd);
    margin-top:var(--pdd);
}
.sbw__box_checkbox {
    display: flex;
    align-items: center;
    cursor: pointer;
}
.sbw__box_checkbox input{
  margin: 0;
  width: 0;
  opacity: 0;
}
.sbw__box_checkbox.rent_dis{
    color: #aaa;
    pointer-events: none;
}
.sbw__box_checkbox input:hover{
  background: rgba(0,0,0,.05) !important;
}
.sbw__box_checkbox input:checked + .sbw__box_checkbox--box{
  background:var(--head-color);
}
.sbw__box_checkbox input:checked + .sbw__box_checkbox--box::before {
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f00c";
    color:#fff;
    font-size: 12px;
}
.sbw__box_checkbox--box {
  position: relative;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border: solid 2px transparent;
  background: rgba(0,0,0, .1);
  border-radius: 40px;
}
.sbw__box_checkbox--txt {
    margin-left: 12px;
    font-size: 14px;
}
/* ボタン */
.sbw__btn,.sbw__btn--dpp {
    background: #ccc;
    border: none;
    width: 100%;
    padding: calc(var(--pdd) * 1.5) 0;
    border-radius: 40px;
    font-weight: bold;
    background: #333;
    color: #fff;
    box-shadow:var(--shadow);
}
.sbw__btn i{margin-right: calc(var(--pdd)/2);}

/* before/after */
.sbw__content::before {
    z-index: 1;
    content: "123";
    position: absolute;
    top:var(--pdd);
    left:var(--pdd);
    font-size: 12px;
    color: #666;
    pointer-events: none;
}

.sbw__content[data-type=dephomen]::before{content: "\51FA\767A\5730";}
.sbw__content[data-type=homeng]::before{content: "\3054\65C5\884C\65B9\9762";}
.sbw__content[data-type=homen]::before{content: "\8A73\7D30\30A8\30EA\30A2";}
.sbw__content[data-type=room]::before{content: "\90E8\5C4B\30BF\30A4\30D7";}
.sbw__content[data-type=toshi]::before{content: "\30A8\30EA\30A2\3092\3055\3089\306B\7D5E\308B";}


.sbw__content[data-type*=tbpndep]::before,.sbw__content[data-type*=tbpndepf]::before{content: "\51FA\767A\5730";}
.sbw__content[data-type*=tbpnarr]::before,.sbw__content[data-type*=tbpnarrf]::before{content: "\5230\7740\5730";}
.sbw__content[data-type=date]::before {content: "\65E5\7A0B";}
.sbw_pax::before {content: "ご旅行人数";}
[data-type=InHotelCode]::before{content: "\5BBF\6CCA\30DB\30C6\30EB";}

/*  目的地（宿泊エリア） */
.sbw__content[data-type=mddArea]::before{content: "\76EE\7684\5730\FF08\5BBF\6CCA\30A8\30EA\30A2\FF09";}
.sbw__content[data-type=smlArea]::before{content: "\5BBF\6CCA\5730\57DF";}


/* ご旅行日程 */
[name=date].sbw__content::before{content:"\3054\65C5\884C\671F\9593";}
/* 宿泊期間 */
[name=sd_date].sbw__content::before{content:"\5BBF\6CCA\65E5";}
/* 宿泊期間 */
[name=checkin].sbw__content::before{content:"\5BBF\6CCA\65E5";}

[name=htlsarea]::before{content: "\76EE\7684\5730\FF08\5BBF\6CCA\30A8\30EA\30A2\FF09";}


/* 空港モーダル */
.sbw_airModal {
    display: none;
    flex-wrap: wrap;
    width: 100%;
    height: 100%;
    border-radius: 20px 20px 0 0;
    overflow: hidden;
    margin: 0 auto;
    position: fixed;
    bottom: 0;
    left:0;
    background: #fff;
    z-index: 50;
}
.am_ttl {
    text-align: center;
    padding: var(--pdd) 0;
    margin:0;
    background:var(--main-color);
    color: #fff;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
}
.am_ttl span{
    background: #fff;
    border-radius: 4px;
    color: #0070b3;
    display: inline-block;
    padding: 0 10px;
    margin-right: 5px;
    font-size: 14px;
}
.am__box{
    display:flex;
    flex-wrap:wrap;
    height:100%;
    justify-content: space-between;
}
.am_selBox--name{
    background: #fff;
    border-radius: 5px;
    color: #333;
    padding: var(--pdd);
    width:100%;
}
.air__left{
    background:#f2f5f7;
    padding:0;
    width:var(--left-width);
}
.air__left li{
    padding:var(--pdd);
    border-bottom:1px solid #a8c1cf;
}
.air__left li.sel {
    position: relative;
    background: #d0e2ec;
    font-weight: bold;
}
.air__left li.sel::after{
	font-family: "Font Awesome 5 Free";
    position:absolute;
	font-weight: 900;
	content: "\f105";
    margin-left:calc(var(--pdd)/ 2);
}

/* 空港 */
.air__right {
    width: calc(100% - var(--left-width));
	  overflow-y:scroll;
    height: 100%;
}
.air__right p{
    padding:var(--pdd);
    margin:0;
    border-bottom:1px solid #ccc;
}
.air__right p:last-of-type{border-bottom:none;}
.depDtl{display:none;padding:0 10px;}
.depDtl.sel{display:block;}

/* 部屋 + 人数 */
.sbw_paxModal {
    display: none;
    width: 100%;
    border-radius: 20px 20px 0 0;
    overflow: hidden;
    margin: 0 auto;
    position: fixed;
    width:100%;
    height:90%;
    bottom:0;
    left:0;
    background: #fff;
    z-index: 50;
    padding-bottom: 40px;
}
.pm__fix {
    display: flex;
    align-items: center;
    background: #333;
    padding: var(--pdd);
    position: fixed;
    bottom: 0;
    width: 100%;
    height:60px;
}
.pm__fix p{
    font-size: 16px;
    color: #fff;
    font-weight: bold;
}
.pm__fix select{
    border: none;
    width: 115px;
    padding: 10px;
    border-radius: 5px;
}
.pm_pax{
    padding:var(--pdd);
    height: 70%;
    overflow-y: scroll;
}
.pm_pax__box {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.pm_pax__box + .pm_pax__box{margin-top:15px;}
.pm_pax__box dt span{
    color: #888;
    font-size: 12px;
}
.pm_pax__box input {
    border: none;
    text-align: center;
    width: 60px;
    font-size: 16px;
}
.pm_pax--plus,.pm_pax--minus{
    display:inline-block;    
    background: #0070b3;
    padding:5px 8px;
    border-radius: 4px;
    font-weight: bold;
    color: #fff;
}
.pm_pax--minus{
    display:inline-block;
    background:var(--main-color);
    padding: 5px 8px;
    border-radius: 4px;
    font-weight: bold;
    color: #fff;
}
.pm_pax--plus.dis,.pm_pax--minus.dis{
    background: #a7adb0;
    color: #e9e9e9;
}
.pm_pax--ttl {
    font-size: 18px;
    font-weight: bold;
    padding: var(--pdd) 0;
    border-bottom: 1px solid #333;
    margin-bottom: var(--pdd);
}
.pm_pax--ttl .fa-check-circle{
    display:none;
}
.pm_pax--ttl.on .fa-check-circle{
    display:inline;
}
.pm_pax--ttl.on .fa-circle{
    display:none;
}
.pm_paxBtn{
    background:var(--main-color);
    width: 100px;
    text-align: center;
    color: #fff;
    padding: 8px;
    border-radius: 30px;
    margin-left: auto;
}
.pm_paxHelpBtn {
    color: #fff;
    padding: 5px 15px;
}
.pax_errBox,.calInfo{
    margin: 10px 10px;
    background: #ffedd6;
    border-radius: 5px;
    font-size: 12px;
    color: #3c0f0a;
    display: block;
    padding:10px;
    position: fixed;
    bottom:70px;
    width: 96%;
    margin: 0;
    left: 50%;
    transform: translateX(-50%);
}
.calInfo {
    bottom: 135px;
}
.pax_errBox_1,.pax_errBox_2,.pax_errBox_3,.pax_errBox_4,.pax_errBox_5{
    padding: 10px;
    font-size:12px;
    color: #681c2d;
    border:1px solid;
    margin:15px 0;
}
.pax_errBox_1 b,.pax_errBox_2 b,.pax_errBox_3 b,.pax_errBox_4 b,.pax_errBox_5 b{
    display:block;
}

/* calendaer */
.stayDate,
.htlsBox{display:none;}
#calenderBox {
    background: #fff;
    position: fixed;
    width: 100%;
    z-index: 51;
    height: 90%;
    bottom: 0;
    border-radius: 10px 10px 00;
    overflow-y: scroll;
}
#calenderBox table{
    width: 90%;
    margin: 15px auto;
}
#calenderBox table th{
    font-size: 20px;
    font-weight: bold;
    padding:10px 0;
}
#calenderBox table td {
    text-align: center;
    padding: 15px 0;
}
#calenderBox table td.is-calSelect{
    background:#0070b363;
    font-weight: bold;
}
#calenderBox table td.is-calSelect2 {
    background: #0070b32b;
}
.weekLine td:first-of-type,#calenderBox table td.holiday{color: #f27979;}
.weekLine td:last-of-type {color: #71b2d6;}
td.is-disabled{color:#aaa;pointer-events:none;}

#calControl{
    position: fixed;
    bottom: 0;
    width: 100%;
    background: #000;
    color: #fff;
    padding:15px;
}
#calBtnBox,#changeHakuBox{
    display:flex;
    flex-wrap:wrap;
    justify-content: space-between;
}
#changeHakuBox{background:#fffffff2;margin-bottom: 10px;border-radius:5px;}
#changeHakuBox p {
    width: calc(100% / 2);
    padding: var(--pdd);
    color: #666;
    font-size: 12px;
    margin:0;
}
#changeHakuBox p:nth-of-type(1){border-right:1px solid #ccc;}
#changeHakuBox p span{
    color:#333;
    font-size:14px;
}
#calBtnBox p {
    width: calc(100% / 2 - var(--pdd));
    text-align: center;
    padding: 10px;
    background: #fff;
    color: #333;
    font-weight: bold;
    border-radius: 40px;
    margin:0;
}
p#dateKettei{
    color:#fff;
    background:var(--main-color);
}
#scrollBox{margin-bottom: 140px;}
.calInfo+#scrollBox{margin-bottom: 180px;}
#calenderBox table td.is-disabled2 {
    color: #aaa;
    cursor: inherit;
    pointer-events:none;
}
#calenderBox[data-flag=cal_nor] table td.is-disabled2 {
      color: #000;
    cursor: pointer;
    pointer-events:inherit;
}
#calenderBox[data-flag=cal_nor] table td.holiday {
    color: #f27979;
}
#calenderBox[data-flag=cal_nor] table td.is-disabled {
    color: #aaa;
    pointer-events: none;
}
.errBox,.errBox2{
  margin-bottom: 10px;
  font-weight: bold;
  color: #c33b3b;
}
.sbw__content.err{border-color:#c33b3b;}

.htlsBox__btn{
    background: #9dd0ef;
    text-align: center;
    font-size: 90%;
    padding: 10px 0;
    border-radius: 8px;
    margin: 15px 0;
}
.htlsBox .sbw__content p{
  margin:0;
  padding:0;
}
.htlsBox .sbw__content{
  padding:10px;
}
.htlsBox .sbw__content::before{
  content:none;
}

/* */
.addHtlsBoxWrap{
    display: none;
    background: #fff;
    position: fixed;
    width: 100%;
    z-index: 50;
    height: 90%;
    bottom: 0;
    border-radius: 10px 10px 00;
    overflow-y: scroll;
}
.addHtlsBoxWrap-head{
    display: flex;
    border-bottom: 1px solid #ccc;
    padding: 10px;
    align-items: center;
    flex-wrap: wrap;
    width: 100%;
}
.addHtlsBoxWrap-head i{
    width: 20px;
    text-align: center;
}
.addHtlsBoxWrap-head--ttl{
    text-align: center;
    width: calc(100% - 40px);
    font-weight: bold;
}
.addHtlsBox{
  padding:15px;
}
.addHtlsBox--ttl{
    font-size: 90%;
    color: #666;
}
.addHtlsBox--date{
/*     display: flex;
flex-wrap: wrap;
justify-content: space-between; */
    border: 1px solid #ccc;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom:10px;
}
.addHtlsBox--date .sbw__content{
  border:none;
  border-radius: 0;
}
.addHtls__area {
    display: none;
    flex-wrap: wrap;
    width: 100%;
    height: 100%;
    border-radius: 20px 20px 0 0;
    overflow: hidden;
    margin: 0 auto;
    position: fixed;
    bottom: 0;
    left: 0;
    background: #f8f8f8;
    z-index: 50;
    padding:20px;
}
.addHtls__area__pref select{
    width: 100%;
    font-size: 16px;
    padding: 10px;
    border: 1px solid #aaa;
    border-radius: 8px;
}
.addHtls__area__pref--ttl{
    font-size: 14px;
    color: #666;
}

.addHtls__area__List ul {
    background: #fff;
    border: 1px solid #aaa;
    border-radius: 8px;
    overflow-y: scroll;
    max-height: 80dvh;
}
.addHtls__area__List{
    margin: 20px 0;
}
.addHtls__area__List--parent{
    border-bottom: 1px solid #ccc;
    padding: 10px;
}
.addHtls__area__List--child {
    /* padding: 0px 0 20px 0; */
}
.addHtls__area__List--child p{
    border-bottom: 1px solid #ccc;
    padding: 10px 10px 10px 30px;
    display: flex;
    align-items: center;
}
.addHtls__area__List--child p label{
  width: 100%;
}
.addHtls__area__Bottom {
    border-top: 1px solid #aaa;
    position: fixed;
    bottom: 0;
    width: 100%;
    left: 0;
    background: #fff;
    padding: 20px;
}
.addHtls__area__Bottom-btn{
    background: var(--main-color);
    color: #fff;
    padding: 10px;
    border-radius: 4px;
    text-align: center;
}

.addHtls__area__List--parent label{
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}
.addHtls__area__List--parent label span{
  display: block;
    width: 80%;
}
.htlsBox .sbw__content .stop_chenge {
    margin: 0;
    padding: 5px;
    font-size: 14px;
    color: #666;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.htlsBox .sbw__content .stop_chenge2 {
    margin: 0;
    padding: 5px;
    font-size: 14px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.stop_chenge i,
.stop_chenge2 i{
    width: 10px;
    padding: 0;
    margin: 0;
    margin-right: 10px;
}
.htls_bottomBtn{
    background: #fff;
    border-top: 1px solid #ccc;
    padding: 15px;
    display: flex;
    position: fixed;
    align-items: center;
    justify-content: right;
    bottom: 0;
    flex-wrap:wrap;
    width: 100%;
    z-index:1;
}
.htls_bottomBtn p{
  margin:0 10px;
  font-size:14px;
}
.htls_scrBox{
    height: 80dvh;
    overflow-y: scroll;
    padding-bottom: 50px;
}
.htls_bottomBtn p.Htls__agBtn{
    width: 100px;
    background: var(--main-color);
    text-align: center;
    color: #fff;
    padding: 5px;
    border-radius: 8px;
    font-size: 16px;
    margin-right: auto;
}
.errBox3 {
    margin-bottom: 10px;
    font-weight: bold;
    color: #c33b3b;
    width: 100%;
    background: #fae8e8;
    padding: 10px;
    border-radius: 6px;
    font-size: 12px;
}
.htlsBox .sbw__content p.htls__pln{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;
    margin-bottom:10px;
}
.htlsBox .sbw__content p.htls__pln:last-of-type{
  margin-bottom:0;
}
.htls__pln span:nth-of-type(1){
  display: block;
    max-width: 2rem;
    text-align: center;
    background: #eee;
    padding: 5px;
    font-size: 12px;
    margin: 0;
  
}
.htls__pln span:nth-of-type(2) {
    width: calc(100% - 3rem);
    padding: 0;
    font-size: 13px;
    margin: 0;
}

@media(min-width: 599px){
    /* 空港 */
    .sbw_airModal{
        top: 50%;
        left: 50%;
        height: 550px !important;
        bottom:inherit;
        max-width: 650px;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        border-radius: 20px;
    }
    .air__left{background: #d0e2ec;}
    .air__left li,.air__right p{cursor: pointer;}
    .air__left li:last-of-type{border:none;}
    .air__left li.sel{background:#fff;}
    #ovl.air i{display: none;}
    
    /* カレンダー */
    #calenderBox {
        max-width: 775px;
        height: 620px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        overflow-y: inherit;
        border-radius: 30px;
    }
    #calenderBox table {
        width: calc(100% / 2 - 15px);
        margin: 15px auto;
    }
    #scrollBox {
        display: flex;
        flex-wrap: wrap;
        padding: 20px;
        margin-bottom: 0;
        height: 475px;
        overflow-y: scroll;
    }
    #calenderBox table td{cursor: pointer;}
    #calControl {position: sticky;padding: 20px 80px;background: #76b4e4;}
    #changeHakuBox p span {font-size: 18px;}  
    #changeHakuBox{margin-bottom:15px;}  
    #calBtnBox p {
        cursor: pointer;
        padding: 14px 0;
        font-size: 18px;
    }
    #calenderBox table td.is-calSelect {background: #76b4e4;}
    #calenderBox table td.is-calSelect2 {background: #1ba5f747;}

    /* 人数 */
    .pm_pax--ttl{font-size:22px;}
    .pm_pax--ttl i{color:var(--main-color);}
    .pm_pax__box dt{font-size: 18px;}
    .sbw_paxModal{
        top: 50%;
        left: 50%;
        height: 580px !important;
        bottom:inherit;
        max-width: 700px;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        border-radius: 20px;
    }
    .pm__fix select {width: 200px;font-size: 18px;}
    .pm_paxBtn {width: 210px;font-size: 18px;padding: 10px;}
    .pm__fix p{font-size:20px;color:#333;}
    .pm__fix{height: 80px;padding: 20px;background: #76b4e4;}
    .pm_pax {
        height: 60%;
        padding: 25px;
    }
  .pax_errBox {
      bottom: 95px;
      font-size: 14px;
      line-height: 1.8;
  }
  .pm_pax--minus,.pm_pax--plus{font-size:18px;cursor:pointer;}
  .calInfo{bottom: 169px;width: calc(775px - 80px);font-size: 15px;}
  
  .sb__flx{display: flex;flex-wrap:wrap;}
  
  /* 1Col */
  .dwWrap__right.col1{
    width: 800px;
    margin: 0 auto;
  }
  .col1__2{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }
  .col1__2 .sbw_mddArea{ width: calc(100% / 2 - 10px);}
  .col1__2 .sbw__box{width: calc(100% / 2 - 10px);}
  .col1 .sbw__return{
    margin-top: 10px;
    width: calc(100% / 2 - 10px);
  }
  .col1__2.day .sbw__box_col1{ width: calc(100% / 2 - 10px);    margin: 0;}
  .col1__2.day .sbw__box_col1.col3__max{margin-top:10px;}
  .col1 .sbw__btn {
      width: 40%;
      margin: 0 auto 35px;
      display: block;
  }
  .searchBox_wbf.col1 {
      width: 100%;
      padding: 0 20px;
  }  
}

/* ABtest */
.abtest .right{
  /* width:40%; */
}
.right__add {
    width: 55%;
    padding: 0 40px;
}
.peach .right__add {
  width: 55%;
  margin-right: -80px;
}
.springsale .right__add {
    width: 55%;
    padding: 0;
}
.right__add img{
    margin: 0 auto;
}
.peach .right__add img {
    margin: 0 auto 20px;
}
.springsale .right__add img{
    margin: 50px auto;
}
.abtest .searchWrap .def__dpp .left {
    width: 45%;
}
.ra__box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.ra__box a {
    background: url(/upload/tenant_1/hatsuyume2024_bg_medama.webp) no-repeat;
    width: calc(100% / 2 - 10px);
    color: #fff;
    font-size: 15px;
    margin-bottom: 20px;
    font-weight: bold;
    /* text-shadow: 1px 1px 4px #463c14; */
    /* background: #ffffff2b; */
    /* box-shadow: 0 0 3px 3px #333; */
    padding: 20px 15px;
    border-radius: 20px;
    /* box-shadow: 0px 0px 10px 0px #3336; */
}
.peach .ra__box a {
    background: #9b308c;
}
.ra__area{
    font-size: 16px;
    display: block;
    text-align: center;
    color:#fff;
    background:#333;
    text-shadow: none;
    margin-bottom: 15px;
    border-radius: 5px;
    padding: 4px 0;
}
.ra__price {
    display: flex;
    font-size: 25px;
    border-top: 1px solid #fff;
    padding-top: 0;
    margin-top: 5px;
    align-items: center;
    justify-content: center;
    color: #fff;
}
.ra__price::after{content:"\5186\301C";}
.ra__price i{font-size:80%;}
.ra__btn{
    background: #333;
    color: #fff;
    text-align: center;
    padding: 20px;
    width: 100%;
    border-radius: 60px;
    display: flex;
    justify-content: center;
        align-items: center;
    font-size: 20px;
    box-shadow: 0px 0px 0px 2px #ffffff94;
    font-weight: bold;
}
.hkd .ra__btn {
  /* margin-top: 80px; */
}

.okasss .ra__btn{
    background: #118bfc;
    color: #fff;
    text-align: center;
    padding: 20px;
    width: 100%;
    border-radius: 60px;
    display: flex;
    justify-content: center;
        align-items: center;
    font-size: 20px;
    box-shadow: 0px 0px 0px 2px #ffffff94;
    font-weight: bold;
    margin-top: 50px;
}
.kyu_jalfamily .ra__btn,
.chu_jalfamily .ra__btn,
.shi_jalfamily .ra__btn,
.tyo_jalfamily .ra__btn,
.osa_jalfamily .ra__btn,
.jalsale .ra__btn,
.oka_jalsale .ra__btn,
.hkd_jalsale .ra__btn,
.kyu_jalsale .ra__btn,
.shi_jalsale .ra__btn,
.chu_jalsale .ra__btn,
.tyo_jalsale .ra__btn,
.osa_jalsale .ra__btn{
    background: #e80010;
    color: #fff;
    text-align: center;
    padding: 20px;
    width: 100%;
    border-radius: 60px;
    display: flex;
    justify-content: center;
        align-items: center;
    font-size: 20px;
    box-shadow: 0px 0px 0px 2px #ffffff94;
    font-weight: bold;
    margin-top: 50px;
}
.anasale .ra__btn{
    background: #00146d;
    color: #fff;
    text-align: center;
    padding: 20px;
    width: 100%;
    border-radius: 60px;
    display: flex;
    justify-content: center;
        align-items: center;
    font-size: 20px;
    box-shadow: 0px 0px 0px 2px #ffffff94;
    font-weight: bold;
    margin-top: 50px;
} 
.springsale .ra__btn{
    background: #2ecf41;
    color: #fff;
    text-align: center;
    padding: 20px;
    width: 100%;
    border-radius: 60px;
    display: flex;
    justify-content: center;
        align-items: center;
    font-size: 20px;
    box-shadow: 0px 0px 0px 2px #ffffff94;
    font-weight: bold;
}
.hkd_summersale .ra__btn{
    background: #16059a;
    color: #fff;
    text-align: center;
    width: 100%;
    border-radius: 60px;
    display: flex;
    justify-content: center;
        align-items: center;
    font-size: 20px;
    box-shadow: 0px 0px 0px 2px #ffffff94;
    font-weight: bold;
    margin-top: 50px;
}
.jal .ra__btn{
    background: #ffff00;
    color: #333;
    text-align: center;
    padding: 15px;
    width: 70%;
    border-radius: 10px;
    display: flex;
    justify-content: center;
        align-items: center;
    font-size: 20px;
    box-shadow: 0px 0px 0px 2px #ffffff94;
    font-weight: bold;
    margin: 20px auto;
}
.abtest .searchWrap{
  /* padding-bottom:100px; */
}

.sd__change {
    width: 100%;
    display: flex;
    margin-bottom: 0;
    margin-top: -80px;
}
.abtest .searchWrap .right{
  margin-top: -7px;
}
.sd__change label {
    display: flex;
    align-items: center;
    gap: 0 0.5em;
    position: relative;
    cursor: pointer;
    font-size: 20px;
    color: #fff;
    font-weight: bold;
    text-shadow: 0 0 5px #333;
    margin-right: 20px;
}

.sd__change label::before,
.sd__change label:has(:checked)::after {
    border-radius: 50%;
    content: '';
}

.sd__change label::before {
    width: 18px;
    height: 18px;
    background-color: #e6edf3;
}

.sd__change label:has(:checked)::after {
    position: absolute;
    top: 50%;
    left: 9px;
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    background-color: #2589d0;
    animation: anim-radio-001 .3s linear;
}

@keyframes anim-radio-001 {
    0% {
        box-shadow: 0 0 0 1px transparent;
    }
    50% {
        box-shadow: 0 0 0 10px #2589d033;
    }
    100% {
        box-shadow: 0 0 0 10px transparent;
    }
}

.sd__change input {
    display: none;
}
.right__add--sp{display: none;}

.abtest #sw__world .docoWrap{
  width: 415px;
}




@media(max-width: 599px){
  .right__add{display: none !important;}
  .sd__change{display: none;}
  .abtest .right{
    width: 100%;
  }
.abtest .searchWrap {
    padding-bottom: 0;
}
.right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(https://www.wbf.co.jp/upload/tenant_1/gtop_hatuyume_bg_sp2.webp) center right;
    background-size: auto 100%;
}
.anasale .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(https://www.wbf.co.jp/upload/tenant_1/anaSP_bg_sp.webp) center right;
    background-size: auto 100%;
}
.hkd .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(https://www.wbf.co.jp/upload/tenant_1/peach-main-hokkaido.webp) center right;
    background-size: auto 100%;
}
.okasss .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/summer2023_bg_top_oka.webp) center right;
    background-size: auto 100%;
}
.jalsale .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/all_bg_summer.webp) right center;
    background-size: auto 100%;
}
.oka_jalsale .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/oka_bg_winter2.webp) center center;
    background-size: auto 100%;
}
.hkd_jalsale .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/hkd_bg_spring.webp) right center;
    background-size: auto 100%;
}
.kyu_jalsale .right__add--sp,
.kyu_jalfamily .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/kyu_bg_spring.webp) left center;
    background-size: auto 100%;
}
.shi_jalsale .right__add--sp,
.shi_jalfamily .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/shi_bg_spring.webp) right center;
    background-size: auto 100%;
}
.chu_jalsale .right__add--sp,
.chu_jalfamily .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/chu_bg_spring.webp) center center;
    background-size: auto 100%;
}
.tyo_jalsale .right__add--sp,
.tyo_jalfamily .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/kanto_bg_winter.webp) center center;
    background-size: auto 100%;
}
.osa_jalsale .right__add--sp,
.osa_jalfamily .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    background: url(/upload/tenant_1/kansai_bg_autumn.webp) left center;
    background-size: auto 100%;
}
.hkd_summersale .right__add--sp {
    padding:25px 15px 55px;
    display: block;
    /*background: url(/upload/tenant_1/summer2023_bg_top_hkd.webp) right center;*/
    background: url(/upload/tenant_1/hk_sayonara_MV_2.webp) right center;
    background-size: auto 100%;
}
.peach .right__add--sp {
    background: url(/import/tenant_1/www.wbf.co.jp/special/peach/img/peach-main.webp) center right no-repeat;
    background-size: auto 100%;
}
.jal .right__add--sp {
    background: url(/upload/tenant_1/jal_family_top_1.webp) center right no-repeat;
    background-size: auto 100%;
}
.area_okinawa.peach .right__add--sp{
    background: url(/upload/tenant_1/ok_peachspecial_mv.webp) center right no-repeat;
    background-size: auto 100%;
}
.area_okinawa-ishigaki.peach .right__add--sp{
    background: url(/upload/tenant_1/ok_peachspecial_mv.webp) center right no-repeat;
    background-size: auto 100%;
}
.area_hokkaido.peach .right__add--sp{
    background: url(/upload/tenant_1/hk_peachspecial_mv.webp) center right no-repeat;
    background-size: auto 100%;
}
.area_sapporo.peach .right__add--sp{
    background: url(/upload/tenant_1/hk_peachspecial_mv.webp) center right no-repeat;
    background-size: auto 100%;
}
.area_kyushu.peach .right__add--sp{
    background: url(/upload/tenant_1/ky_peachspecial_mv.webp) center right no-repeat;
    background-size: auto 100%;
}
.area_hokkaido.springsale .right__add--sp,
.area_sapporo.springsale .right__add--sp{
    background: url(/upload/tenant_1/hk_spksale_mv.webp) center center no-repeat;
    background-size: auto 100%;
}


.ra__price{font-size:18px;}
.ra__box a{font-size:13px;}.ra__area{font-size:15px;}
.ra__btn,
.jal .ra__btn {
    padding: 10px;
    font-size: 18px;
    width: 100%;
    margin: 20px auto 0;
}
.abtest .mainImgBlock {
    padding-top: 0;
}
.abtest .searchWrap .inner {
    width: 100%;
    padding: 0;
}
.abtest .docoWrap.top{box-shadow: none;}
.abtest .mainImg{display:none;}
.abtest .docoTtl{display: none;}
.popupBanner.gtop{bottom:20px;}

.abtest .searchWrap .def__dpp .left {
    width: 100%;
}

.right__add--sp img{margin:20px 0 0;}
.abtest .searchWrap .def__dpp .right{display: block;}
}



 /*	this is my short cut clear fix.
	with note "display:flex" */
.courseSection .cfx:before,.courseSection .cfx:after {
  content:"";
  display: table;
}
.courseSection .cfx:after { clear:both; }
.courseSection .cfx { *zoom:1; }

.courseSection .cf:before,.courseSection .cf:after {
  content:"";
  display: table;
}
.courseSection .cf:after { clear:both; }
.courseSection .cf { *zoom:1; }


/* unnuber list is clear fix */
.courseSection ul:before,.courseSection ul:after {
content:"";
display: table;
}
.courseSection ul:after { clear:both; }
.courseSection ul { *zoom:1; }

/* data list is clear fix */
.courseSection dl:before,.courseSection dl:after {
content:"";
display: table;
}
.courseSection dl:after { clear:both; }
.courseSection dl { *zoom:1; }
.courseSection li { list-style:none; }

.addHtls__area__pref{padding-top:10px;}
.area_hs{
    background: #d94c4c;
    color: #f8f8f8;
    padding: 1px 4px;
    border-radius: 4px;
    display: inline-block;
    margin-right: 5px;
    margin-bottom: 5px;
}

@media(min-width: 599px){
    .addHtlsBoxWrap {
        max-width: 555px;
        height: 620px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        overflow: hidden;
        border-radius: 30px;
    }
    .addHtls__area{
        max-width: 555px;
        height: 620px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        overflow: hidden;
        border-radius: 30px;      
    }
    .addHtls__area__List ul {
        max-height: 45dvh;
    }
    .htls_scrBox{
        height: 80%;
        overflow-y: scroll;
        padding-bottom: 40px;
    }
    
    .htls_scrBox::-webkit-scrollbar {
        background: #eee;
    }
    .htls_scrBox::-webkit-scrollbar-thumb {
        background: #0070b3;
        border-radius: 15px;
    }

    
}


