@charset "utf-8";
/* CSS Document */

.visHid0 {visibility: hidden!important; width: 0!important; height: 0!important; margin: 0!important; padding: 0!important; position: fixed!important;}
body.is-fixed {position: fixed; width: 100%;}
/*--btn*/
.reservationModuleWrap .btn {display: inline-block; position: relative; width: 100%;}
.btn__inner {display: flex; justify-content: center; align-items: center;}
.btnTxtWrap {line-height: 1.2; width: 100%;}
.btnTxtWrap > span {display: block;}
.btn__txt--gr {color: #696969; font-size: 0.97rem;}
.btn__txt--gd {color: #A46A00;}
.btn__txt--ellipsis {display: block; width: 100%; margin: auto; text-overflow: ellipsis; white-space: nowrap; overflow: hidden; font-weight: normal;}
.btn--flying .btn__txt.text-eyebrow-s, .btn--date .btn__txt.text-eyebrow-s {font-size: 1.17rem;}

/*--errorTxt*/
.errorTxt {width: 100%;padding-top: 4px; color: #DC2A2A; font-size: 0.97rem;}
.reservationModuleWrap .errorTxt > p + p, .reservationModuleWrap .roomTravelers__error > p + p {margin-top: 0;}
.roomTravelers__error {position: relative; padding: 6px 14px 0; line-height: 1.5; color: #3e3e3e;font-size: 1.17rem; font-weight: bold; font-family: 'Montserrat', sans-serif;}

/*--formPulldown*/
.formPulldown {position: relative; border-bottom: 1px solid #9c6d16; cursor: pointer;}
.formPulldown::after {position: absolute; bottom: 8px; right: 10px; content: ''; display: inline-block; width: 24px; height: 24px; background: url(/content/dam/jal/wwwjalcojp/world/common/images/icons/icon_arrow_gr.svg) no-repeat 0 0; transition: all 0.5s ease; transform: rotate(180deg);}
.formPulldown.is-active::after {transform: rotate(0);}
.formPulldown__select {padding: 0 34px 9px 14px;}
.formPulldown__optionWrap {display: none; position: absolute; width: 100%; top: 36px; left: 0; background: #fff; box-shadow: 2px 2px 5px 0px rgba(0, 0, 0, 0.3); border-radius: 0 0 4px 4px; z-index: 2;}
.formPulldown__option {padding: 7px 10px; display: block; text-decoration: none; transition: all 0.6s ease 0s;width: 100%;}
.formPulldown__option:hover {background-color: #9C6D16; color: #fff;}


/*--modal*/
.reservationModal {display: none; position: fixed; left: 0; top: 0; width: 100%; height: 100%; opacity: 0;transition: .3s; z-index: 10000;}
.reservationModal.is-active {display: block; opacity: 1;}
.modal__inner {display: flex; align-items: center; justify-content: center; width: 100%; height: 100%;}
.modalPanel {position: relative; display: inline-block; width: 100%; height: 100%; max-width: 1000px;}
.modalPanel__inner {display: flex; flex-direction: column; width: 100%; height: 100%; background: #fff; overflow: auto;}
.modalPanel__content {margin-top: 48px;  padding: 24px 10px 0; background: #fff;}
.reservationModal .modalPanel__bottom {position: sticky; position: -webkit-sticky; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; left: 0; margin-top: auto; right: 0; bottom: 0; padding: 16px 24px; background: #fff; box-shadow: 0px -1px 2px 0px #0000001A; z-index: 100;}
.modalPanel__bottom .button-primary {width: 100%;}
.roomTravelersBtn--primary, .calendarBtn--primary {width: 100%;}

/*--modal_roomTravelers*/
.reservationModal--roomTravelers .modalPanel__content {padding: 24px 10px 60px;}
.roomTravelers_title {font-size: 1.17rem; font-weight: bold;text-transform: uppercase; font-family: 'Montserrat', sans-serif;}
.roomTravelers_reset {margin-top: 4px;}
.roomTravelers_reset .btn.btn--reset {font-size: 1.17rem;}
.roomTravelers_reset .btn.btn--reset .icon-reset {margin-left: 2px;}
.roomPeopleWrap {margin-top: 24px;}
.roomPeople {border-bottom: 1px solid #BFBFBF; padding:0 14px 20px;}
.roomPeople + .roomPeople {display: none; padding: 20px 14px;}
.roomPeople.is-active {display: block;}
.roomPeople__title {font-size: 1.17rem; font-weight: bold;text-transform: uppercase; font-family: 'Montserrat', sans-serif;}
.roomPeople__inner {margin-top: 20px;}
.roomPeople__item {display: flex; justify-content: space-between; flex-wrap: wrap; position: relative; width: 100%; padding: 0; box-sizing: border-box;}
.roomPeople__item + .roomPeople__item {padding-top: 20px;}
.roomPeople__label {width: 50%;}
.roomPeople__item .roomPeople__label p + p {margin-top: 0;}
.roomPeople__btnSet {width: 50%; text-align: right;}
.roomPeople__btn {display: inline-block; width: 26px; height: 26px; border: 1px solid #757575; border-radius: 50%; line-height: 24px; font-size: 1.4rem; font-family: 'Lato', sans-serif; color: #757575;}
.roomPeople__btn:hover {border-color: #9c6d16; color: #fff; background-color: #9c6d16;}
.roomPeople__changeNum {display: inline-block; padding: 0 8px;}
.childrenAgeWrap {width: 100%;}
.childrenAge__title {padding: 0 6px;}
.childrenAgeList {display: none; position: relative; text-align: left; margin: 20px 0 0 auto;}
.childrenAgeList.is-active {display: block;}
.childrenAgeList:nth-of-type(1) {z-index: 9;}
.childrenAgeList:nth-of-type(2) {z-index: 8;}
.childrenAgeList:nth-of-type(3) {z-index: 7;}
.childrenAgeList:nth-of-type(4) {z-index: 6;}
.childrenAgeList:nth-of-type(5) {z-index: 5;}
.childrenAgeList:nth-of-type(6) {z-index: 4;}
.childrenAgeList:nth-of-type(7) {z-index: 3;}
.childrenAgeList:nth-of-type(8) {z-index: 2;}
.childrenAgeList:nth-of-type(9) {z-index: 1;}
.childrenAge {position: relative;}
.childrenAge__inner {margin-top: 20px;}
.childrenAgeWrap .formPulldown__optionWrap {height: 142px; overflow: auto;}
.btn.btn--add {width: auto; margin: 20px 6px; padding: 0 16px 0 0; color: #856514; font-size: 1.68rem; font-weight: bold;}
.btn.btn--add::after {content: ''; position: absolute; top: 5px; right: 0; width: 16px; height: 16px; background: url(/content/dam/guide-to-japan/icons/icon_plus_gd.svg);}
.btnWrap--remove {display: flex; align-items: center; justify-content: end; flex-wrap: wrap; margin-top: 18px;}
.btn.btn--remove {position: relative; width: auto; text-align: right; padding:0 16px 0 0; color: #856514; font-size: 1.4rem; font-weight: bold;}
.btn.btn--remove::after {content: ''; position: absolute; bottom: 2px; right: 0; width: 16px; height: 16px; background: url(/content/dam/guide-to-japan/icons/icon_remove_gd.svg);}

/*--calendar modal*/
.reservationModal--calendar .modalPanel__inner {overflow: initial;}
.renew-jal-overwritte .reservationModal--calendar .switch-unit .switch-button .label-l, .renew-jal-overwritte .reservationModal--calendar .switch-unit .switch-button .label-r {padding: 0;}
.calendarBtnWrap {border-bottom: 1px solid #bfbfbf; padding-bottom: 8px; }
.calendarTable__inner {position: relative;}
    .calendarTable__arrow {position: absolute; top: 20px;}
    .calendarTable__arrow.calendarTable__arrow--prev {left: 0;}
    .calendarTable__arrow.calendarTable__arrow--prev svg {transform: rotate(180deg);}
    .calendarTable__arrow.calendarTable__arrow--next {right: 0;}
.btn.btn--reset {width: auto; text-align: left; padding: 0; margin-top: 8px; font-family: 'Montserrat', sans-serif; font-weight: bold; font-size: 1.68rem; color: #82621f;}
.btn.btn--reset:hover {color: #82621f;}
.btn.btn--reset .icon-reset {vertical-align: middle; margin-left: 5px;}
.modal_body_title {font-weight: bold;}
.reservationModal--calendar .calendar-table .body-cell td button {color: #000;}
.reservationModal--calendar .calendar-table .body-cell .dep-day, .reservationModal--calendar .calendar-table .body-cell .arr-day, .reservationModal--calendar .calendar-table .body-cell .in-day, .reservationModal--calendar .calendar-table .body-cell .out-day {color: #fff;}
.reservationModal--calendar .calendar-table .body-cell td button:hover {background-color: #b59457;color: #000;z-index: 100;}

/*--flyingFromTo modal*/
.flyingFromToWrap {position: relative;}
.flyingFromTo__inner {display: flex; justify-content: space-between; padding: 20px 8px 9px; border-bottom: 1px solid #a46a00;}
.reservationModal--flyingFromTo .flyingFromTo__title--to {display: none;}
.reservationModal--flyingFromTo.is-flyingTo .flyingFromTo__title--from {display: none;}
.reservationModal--flyingFromTo.is-flyingTo .flyingFromTo__title--to {display: block;}

.flyingFromTo__input {width: 100%; padding: 3px 0 3px 5px; margin-right: 8px; font-size: 1.68rem;}
.flyingSuggest {width: 100%; background: #fff; box-shadow: 0px 8px 16px 0px #00000014; border-radius: 0 0 4px 4px; z-index: 2; max-height: calc(100vh - 200px); max-height: calc(100svh - 200px); overflow: auto;}
.flyingSuggest_list {cursor: pointer;}
.flyingSuggest_list_item:first-child {margin-top: 16px; padding: 0;/*後消す*/}
.flyingSuggest_list_item:last-child {padding-bottom: 8px;}
.flyingSuggest .btn--flyingSuggest {display: table; width: 100%; color: #282828;}
.flyingSuggest .btn--flyingSuggest:hover {background-color: rgb(156, 109, 22); color: #fff;}
.flyingSuggest .btn--flyingSuggest .itemCol {display: table-cell; width: 100%; vertical-align: top; text-align: left; padding: 8px 24px 12px; font-size: 1.68rem;}
.flyingSuggest .btn--flyingSuggest .itemCol span {display: block;}
.flyingSuggest .btn--flyingSuggest .itemCol span.text-fineprint {font-weight: normal;}
.flyingSuggest .no-result {color: #757575;font-size: 1.6rem; padding-left: 24px;}
.flyingSuggest .btn--flyingSuggest:hover .no-result {color: #fff;}

.reservationModuleWrap {margin-top: 48px; padding: 32px 24px; background-color: #F2F1EF;}
.reservationModule {max-width: 900px; margin: 0 auto;}
.reservationModule__title {font-family: Montserrat; font-size: 2.02rem; font-weight: bold;}
.reservationModule__inner {margin-top: 20px;}
.classRoomWrap {display: flex;}
.classRoom__item {width: 100%; font-size: 1.4rem;}
.classRoom__item + .classRoom__item {margin-left: 15px;}
.btn.btn--roomTravelers {line-height: 1.2; text-align: left; padding:0; border-bottom: 1px solid #9c6d16; font-size: 1.4rem; min-height: 40px; height: 40px;}
.btn.btn--roomTravelers::after {position: absolute; top: 12px; right: 4px; content: ''; display: inline-block; width: 16px; height: 16px; background: url(/content/dam/guide-to-japan/icons/icon_dialog.svg) no-repeat 0 0; background-size: contain; transform: rotate(0deg);/*後消す*/}
.btn.btn--roomTravelers.is-active::after {transform: rotate(0);}
.btn.btn--roomTravelers .btn__inner {justify-content: space-between;}
.classRoomWrap .formPulldown {height: 40px; display: flex; align-items: center;}
.classRoomWrap .formPulldown:after {top: 12px; right: 4px; width: 16px; height: 16px; background-size: contain;}
.classRoomWrap .formPulldown__optionWrap {top: 44px;}
.formPulldown--class .formPulldown__optionWrap {padding-top: 16px;}
.classRoomWrap .formPulldown__option[aria-selected='true'] {color: #A46A00; font-weight: bold;}
.classRoomWrap .formPulldown__option[aria-selected='true']:hover {color: #fff;}
.classRoomWrap .formPulldown__select {line-height: 1.2;  padding: 0 16px 0 0;}

.flyingDateWrap {position: relative; margin-top: 20px;}
.flyingWrap {display: flex; align-items: center; position: relative;}
.flying__item {width: calc((100% - 55px) / 2); position: relative;}
.reservationModuleWrap .btn.btn--flying, .reservationModuleWrap .btn.btn--date { padding:0 5px; border: 1px solid #D5D5D5;border-radius: 4px;background-color: #fff; min-height: 64px;}
.reservationModuleWrap .btn.btn--flying.is-error, .reservationModuleWrap .btn.btn--date.is-error {border: 1px solid #DC2A2A;}
.btn--flying .btn__txt {font-size: 1.68rem; font-weight: bold;}
.btn__txt--flyingTop {white-space: nowrap; position: absolute; top: 10px; left: 50%; transform: translateX(-50%); -webkit-transform: translateX(-50%); z-index: 1;}

.dateWrap {display: flex; margin-top: 20px;}
.date__item {width: calc((100% - 15px) / 2); }
.date__item + .date__item {margin-left: 15px;}
.date__item .text-technical {margin-top: 6px;}
.btn--date .btn__txt {font-size: 1.4rem; font-weight: bold;}
.btn--date .btn__txt--gd {font-size: 1.68rem;}
.flyingIcon {padding: 0 15px;}

.reservationModuleBtn--primary {margin-top: 20px;}

@media screen and (max-width: 739px){
    .renew-jal-overwritte .reservationModuleWrap .pc-disnon {display: block!important;}
    .renew-jal-overwritte .reservationModuleWrap .sp-disnon {display: none!important;}
    .modalClose {position: absolute; top: 0; left: 0; right: 0; width: 100vw; height: 48px; background: rgba(40, 40, 40, 0.96); z-index: 11;}
    .modalClose .remodalClose__btn {position: absolute; display: block; width: 32px; height: 32px; padding: 0; top: 8px; right: 16px; left: auto; z-index: 12;}

    .calendarTableTitle {min-height: auto; height: calc(100vh - 236px); height: calc(100svh - 236px); overflow-y: scroll; padding: 25px 0;}
}

@media screen and (min-width: 740px){
    .renew-jal-overwritte .reservationModuleWrap .sp-disnon {display: block!important;}
    .renew-jal-overwritte .reservationModuleWrap .pc-disnon {display: none!important;}

    .btn--flying .btn__txt.btn__txt--gd {display: flex; align-items: baseline;}

    .btn__txt--ellipsis {margin: 0 0 0 4px;}

    .reservationModule {width: 900px;}
    .reservationModule__title {font-size: 2.42rem;}
    .reservationModule__inner {position: relative;}
    .classRoom__item {position: relative; width: 241px;}
    .btn.btn--roomTravelers::after {background: url(/content/dam/jal/wwwjalcojp/world/common/images/icons/icon_arrow_gr.svg) no-repeat 0 0; background-size: contain; transition: all 0.5s ease; transform: rotate(180deg);}

    .reservationModal {position:absolute;}
    .modalPanel__inner {border-radius: 4px; box-shadow: 0px 8px 16px 0px #00000014;}
    .reservationModal .modalPanel__bottom {position: static; padding: 16px 10px;}
    .reservationModal.reservationModal--roomTravelers {top: 42px; width: 241px; height: 482px;}
    .reservationModal--roomTravelers .modalPanel__content {overflow-y: auto; overflow-x: hidden; margin-top: 0; padding: 24px 10px 0;}
    .roomPeople {padding: 0 0 20px;}
    .roomPeople + .roomPeople {padding: 20px 0;}
    .reservationModuleBtn--primary {margin: 0 0 0 auto;}
    .reservationModuleBtn--primary .button-primary {width: 120px; min-width: initial; height: 56px; padding: 20px 0;}
    .reservationModal.reservationModal--calendar {top: initial; width: 900px; height: auto; min-height: 500px;}
    .reservationModal--calendar .modalPanel__content {margin-top: 0; padding: 24px 30px 32px;}
    .modalPanel__top {display: flex; justify-content: space-between;padding-bottom: 24px; margin-bottom: 24px; border-bottom: 1px solid #BFBFBF;}
    .renew-jal-overwritte .reservationModal--calendar .switch-unit {width: auto;}
    .renew-jal-overwritte .reservationModal--calendar .switch-unit .switch-button label {width: 225px;}
    .reservationModal--calendar .modal_body_title {font-weight: normal;}
    .renew-jal-overwritte .reservationModal--calendar .switch-unit .switch-button .label-l, .renew-jal-overwritte .reservationModal--calendar .switch-unit .switch-button .label-r {padding: 4px 10px;}
    .btn.btn--reset {margin: 0;}
    .calendarBtn--primary .button-primary {min-width: 194px; height: 48px;}
    .calendarBtnWrap {margin: 0 218px 0 0; padding: 8px 0 0; border-bottom:none;}
    .calendarTable__arrow {top: 24px;}
    .calendarTable .month {display: flex;}
    .renew-jal-overwritte .reservationModal--calendar .calendar-table-unit {width: 332px; padding: 0px 42px;height: 322px;}
    .renew-jal-overwritte .reservationModal--calendar .calendar-table .head-cell th {padding: 10px 8px;}
    .renew-jal-overwritte .reservationModal--calendar .calendar-table .body-cell td button {padding: 10px 14px;}
    .reservationModal.reservationModal--calendar .modalPanel__bottom {position: absolute;
box-shadow: none; width: 194px; height: 48px; padding: 0; top: 24px; right: 30px; left: initial; background: transparent; margin: 0;}
    .reservationModal.reservationModal--flyingFromTo {width: 460px; top: initial;}
    .reservationModal.reservationModal--flyingFromTo.is-flyingTo {left: 216px;}
    .flyingFromTo__title {padding: 0 8px;}
    .reservationModal.reservationModal--flyingFromTo .modalPanel__inner {height: auto;}
    .reservationModal.reservationModal--flyingFromTo .modalPanel__content {padding: 16px 0 0; margin-top: 0;}
    .flyingSuggest {max-height: calc(100vh - 320px); max-height: calc(100svh - 320px); padding-bottom: 16px;}
    .flyingSuggest_list_item:last-child {padding-bottom: 0;}
    .formPulldown__optionWrap::-webkit-scrollbar, .flyingSuggest::-webkit-scrollbar {display: none;}
    .formPulldown__optionWrap:hover::-webkit-scrollbar, .flyingSuggest:hover::-webkit-scrollbar {display: block; width: 4px;}
    .formPulldown__optionWrap::-webkit-scrollbar-track, .flyingSuggest::-webkit-scrollbar-track {background-color: transparent;}
    .formPulldown__optionWrap::-webkit-scrollbar-thumb, .flyingSuggest::-webkit-scrollbar-thumb {background-color: rgba(0,0,0,.5);border-radius: 16px;}

    .flyingDateWrap {display: flex;}
    .flyingWrap {align-items: flex-start;}
    .flying__item {width: 172px;}
    .btn__txt--flyingTop {position: static; transform: none; -webkit-transform: none;}
    .reservationModuleWrap .btn.btn--flying, .reservationModuleWrap .btn.btn--date {text-align: left; min-height: 56px; padding:0 5px 0 52px;}
    .reservationModuleWrap .btn.btn--flying::after {position: absolute; top: 50%; left: 10px; content: ''; display: inline-block; width: 32px; height: 32px; background: url(/content/dam/guide-to-japan/icons/icon_pin_gd.svg) no-repeat 0 0; transform: translateY(-50%); -webkit-transform: translateY(-50%);}
    .flyingIcon {padding: 16px 2px;}
    .dateWrap {margin: 0 0 0 5px;}
    .date__item {width: 194px;}
    .date__item + .date__item {margin-left: 5px;}
    .reservationModuleWrap .btn.btn--date::after {position: absolute; top: 50%; left: 10px; content: ''; display: inline-block; width: 32px; height: 32px; background: url(/content/dam/guide-to-japan/icons/icon_calendar_gd.svg) no-repeat 0 0; transform: translateY(-50%); -webkit-transform: translateY(-50%);}
}

/*------
Guide to Japan - Vacations L3 Page
-----*/
.renew-jal-overwritte .modal-inr-cont .reservationModuleWrap {
  padding: 0;
}
.renew-jal-overwritte .mdl-booking-search-module .reservationModal.is-active {
  display: block !important;
  opacity: 1 !important;
}

@media screen and (max-width: 1004px) {
  .renew-jal-overwritte .mdl-booking-search-module .reservationModuleWrap .pc-disnon {
    display: block !important;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModuleWrap .sp-disnon {
    display: none !important;
  }
  .mdl-booking-search-module .modalClose {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100vw;
    height: 48px;
    background: rgba(40, 40, 40, 0.9607843137);
    z-index: 11;
  }
  .mdl-booking-search-module .modalClose .remodalClose__btn {
    position: absolute;
    display: block;
    width: 32px;
    height: 32px;
    padding: 0;
    top: 8px;
    right: 16px;
    left: auto;
    z-index: 12;
  }
  .mdl-booking-search-module .btn__txt--ellipsis {
    display: block;
    width: 100%;
    margin: auto;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    font-weight: normal;
  }
  .mdl-booking-search-module .reservationModule {
    max-width: none;
    margin: 0 auto;
    width: 100%;
  }
  .mdl-booking-search-module .reservationModule__title {
    font-family: Montserrat;
    font-size: 2.02rem;
    font-weight: bold;
  }
  .mdl-booking-search-module .reservationModule__inner {
    margin-top: 20px;
  }
  .mdl-booking-search-module .classRoom__item {
    width: 100%;
    font-size: 1.4rem;
    position: inherit;
  }
  .mdl-booking-search-module .btn.btn--roomTravelers::after {
    position: absolute;
    top: 12px;
    right: 4px;
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    background: url(/content/dam/guide-to-japan/icons/icon_dialog.svg) no-repeat 0 0;
    background-size: contain;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); /*後消す*/
  }
  .mdl-booking-search-module .reservationModal {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    z-index: 10000;
  }
  .mdl-booking-search-module .modalPanel__inner {
    border-radius: 0;
    -webkit-box-shadow: none;
            box-shadow: none;
    height: 100%;
  }
  .mdl-booking-search-module .reservationModal .modalPanel__bottom {
    position: sticky;
    padding: 16px 24px;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--roomTravelers {
    top: 0;
    width: 100%;
    height: 100%;
  }
  .mdl-booking-search-module .reservationModal--roomTravelers .modalPanel__content {
    overflow-y: auto;
    overflow-x: hidden;
    margin-top: 48px;
    padding: 24px 10px 60px;
  }
  .mdl-booking-search-module .roomPeople {
    padding: 0 14px 20px;
  }
  .mdl-booking-search-module .roomPeople + .roomPeople {
    padding: 20px 14px;
  }
  .mdl-booking-search-module .reservationModuleBtn--primary {
    margin-top: 20px;
  }
  .mdl-booking-search-module .reservationModuleBtn--primary .button-primary {
    width: 100%;
    min-width: initial;
    height: auto;
    padding: 13px 24px;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--calendar {
    top: 0;
    width: 100%;
    height: 100%;
    min-height: auto;
  }
  .mdl-booking-search-module .reservationModal--calendar .modalPanel__content {
    margin-top: 48px;
    padding: 24px 10px 0;
  }
  .mdl-booking-search-module .modalPanel__top {
    display: block;
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: 0px;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit {
    width: auto;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit .switch-button label {
    width: auto;
  }
  .mdl-booking-search-module .reservationModal--calendar .modal_body_title {
    font-weight: bold;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit .switch-button .label-l, .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit .switch-button .label-r {
    padding: 0;
  }
  .mdl-booking-search-module .btn.btn--reset {
    margin-top: 8px;
  }
  .mdl-booking-search-module .calendarBtn--primary .button-primary {
    min-width: auto;
    height: auto;
  }
  .renew-jal-overwritte .switch-unit .switch-button{
    height:auto;
    min-height:41px;
  }
  .mdl-booking-search-module .calendarBtnWrap {
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #bfbfbf;
    padding-bottom: 8px;
  }
  .mdl-booking-search-module .calendarTable__arrow {
    top: 20px;
  }
  .mdl-booking-search-module .calendarTable .month {
    display: block;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .calendar-table-unit {
    width: 100%;
    height: 334px;
    display: inline-block;
    padding: 0;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .calendar-table .head-cell th {
    padding: 10px 8px;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .calendar-table .body-cell td button {
    padding: 10px 14px;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--calendar .modalPanel__bottom {
    width: auto;
    height: auto;
    top: 0;
    position: sticky;
    left: 0;
    margin-top: auto;
    right: 0;
    bottom: 0;
    padding: 16px 24px;
    background: #fff;
    -webkit-box-shadow: 0px -1px 2px 0px rgba(0, 0, 0, 0.1019607843);
            box-shadow: 0px -1px 2px 0px rgba(0, 0, 0, 0.1019607843);
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo {
    width: 100%;
    top: 0;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo.is-flyingTo {
    left: 0;
  }
  .mdl-booking-search-module .flyingFromTo__title {
    padding: 0;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo .modalPanel__inner {
    height: 100%;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo .modalPanel__content {
    margin-top: 48px;
    padding: 24px 10px 0;
  }
  .mdl-booking-search-module .flyingSuggest {
    max-height: calc(100vh - 200px);
    max-height: calc(100svh - 200px);
    padding-bottom: 0;
  }
  .mdl-booking-search-module .flyingSuggest_list_item:last-child {
    padding-bottom: 8px;
  }
  .mdl-booking-search-module .formPulldown__optionWrap::-webkit-scrollbar, .flyingSuggest::-webkit-scrollbar {
    display: none;
  }
  .mdl-booking-search-module .formPulldown__optionWrap:hover::-webkit-scrollbar, .mdl-booking-search-module .flyingSuggest:hover::-webkit-scrollbar {
    display: none;
  }
  .mdl-booking-search-module .flyingDateWrap {
    display: block;
  }
  .mdl-booking-search-module .flyingWrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .mdl-booking-search-module .flying__item {
    width: calc((100% - 55px) / 2);
  }
  .mdl-booking-search-module .btn__txt--flyingTop {
    position: absolute;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .mdl-booking-search-module .btn--flying .btn__txt {
    display: block;
  }
  .mdl-booking-search-module .reservationModuleWrap .btn.btn--flying, .mdl-booking-search-module .reservationModuleWrap .btn.btn--date {
    text-align: center;
    padding: 0 5px;
    min-height: 64px;
  }
  .mdl-booking-search-module .reservationModuleWrap .btn.btn--flying::after {
    display: none;
  }
  .mdl-booking-search-module .flyingIcon {
    padding: 0 15px;
  }
  .mdl-booking-search-module .dateWrap {
    margin: 20px 0 0 0;
  }
  .mdl-booking-search-module .date__item {
    width: calc((100% - 15px) / 2);
  }
  .mdl-booking-search-module .date__item + .date__item {
    margin-left: 15px;
  }
  .mdl-booking-search-module .reservationModuleWrap .btn.btn--date::after {
    display: none;
  }
  .mdl-booking-search-module .calendarTableTitle {
    min-height: auto;
    height: calc(100vh - 236px);
    height: calc(100svh - 236px);
    overflow-y: scroll;
    padding: 25px 0;
  }
}
@media screen and (min-width: 1005px) {
  .renew-jal-overwritte .mdl-booking-search-module .reservationModuleWrap .sp-disnon {
    display: block !important;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModuleWrap .pc-disnon {
    display: none !important;
  }
  .mdl-booking-search-module .btn--flying .btn__txt.btn__txt--gd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
  .mdl-booking-search-module .btn__txt--ellipsis {
    margin: 0 0 0 4px;
  }
  .mdl-booking-search-module .reservationModule {
    width: 900px;
  }
  .mdl-booking-search-module .reservationModule__title {
    font-size: 2.42rem;
  }
  .mdl-booking-search-module .reservationModule__inner {
    position: relative;
  }
  .mdl-booking-search-module .classRoom__item {
    position: relative;
    width: 241px;
  }
  .mdl-booking-search-module .btn.btn--roomTravelers::after {
    background: url(/content/dam/jal/wwwjalcojp/world/common/images/icons/icon_arrow_gr.svg) no-repeat 0 0;
    background-size: contain;
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .mdl-booking-search-module .reservationModal {
    position: absolute;
  }
  .mdl-booking-search-module .modalPanel__inner {
    border-radius: 4px;
    -webkit-box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.0784313725);
            box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.0784313725);
  }
  .mdl-booking-search-module .reservationModal .modalPanel__bottom {
    position: static;
    padding: 16px 10px;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--roomTravelers {
    top: 42px;
    width: 241px;
    height: 482px;
  }
  .mdl-booking-search-module .reservationModal--roomTravelers .modalPanel__content {
    overflow-y: auto;
    overflow-x: hidden;
    margin-top: 0;
    padding: 24px 10px 0;
  }
  .mdl-booking-search-module .roomPeople {
    padding: 0 0 20px;
  }
  .mdl-booking-search-module .roomPeople + .roomPeople {
    padding: 20px 0;
  }
  .mdl-booking-search-module .reservationModuleBtn--primary {
    margin: 0 0 0 auto;
  }
  .mdl-booking-search-module .reservationModuleBtn--primary .button-primary {
    width: 120px;
    min-width: initial;
    height: 56px;
    padding: 20px 0;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--calendar {
    top: initial;
    width: 900px;
    height: auto;
    min-height: 500px;
  }
  .mdl-booking-search-module .reservationModal--calendar .modalPanel__content {
    margin-top: 0;
    padding: 24px 30px 32px;
  }
  .mdl-booking-search-module .modalPanel__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-bottom: 24px;
    margin-bottom: 24px;
    border-bottom: 1px solid #BFBFBF;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit {
    width: auto;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit .switch-button label {
    width: 225px;
  }
  .mdl-booking-search-module .reservationModal--calendar .modal_body_title {
    font-weight: normal;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit .switch-button .label-l, .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .switch-unit .switch-button .label-r {
    padding: 4px 10px;
  }
  .mdl-booking-search-module .btn.btn--reset {
    margin: 0;
  }
  .mdl-booking-search-module .calendarBtn--primary .button-primary {
    min-width: 194px;
    height: 48px;
  }
  .mdl-booking-search-module .calendarBtnWrap {
    margin: 0 218px 0 0;
    padding: 8px 0 0;
    border-bottom: none;
  }
  .mdl-booking-search-module .calendarTable__arrow {
    top: 24px;
  }
  .mdl-booking-search-module .calendarTable .month {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .calendar-table-unit {
    width: 332px;
    padding: 0px 42px;
    height: 322px;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .calendar-table .head-cell th {
    padding: 10px 8px;
  }
  .renew-jal-overwritte .mdl-booking-search-module .reservationModal--calendar .calendar-table .body-cell td button {
    padding: 10px 14px;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--calendar .modalPanel__bottom {
    position: absolute;
    -webkit-box-shadow: none;
            box-shadow: none;
    width: 194px;
    height: 48px;
    padding: 0;
    top: 24px;
    right: 30px;
    left: initial;
    background: transparent;
    margin: 0;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo {
    width: 460px;
    top: initial;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo.is-flyingTo {
    left: 216px;
  }
  .mdl-booking-search-module .flyingFromTo__title {
    padding: 0 8px;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo .modalPanel__inner {
    height: auto;
  }
  .mdl-booking-search-module .reservationModal.reservationModal--flyingFromTo .modalPanel__content {
    padding: 16px 0 0;
    margin-top: 0;
  }
  .mdl-booking-search-module .flyingSuggest {
    max-height: calc(100vh - 320px);
    max-height: calc(100svh - 320px);
    padding-bottom: 16px;
  }
  .mdl-booking-search-module .flyingSuggest_list_item:last-child {
    padding-bottom: 0;
  }
  .mdl-booking-search-module .formPulldown__optionWrap::-webkit-scrollbar, .flyingSuggest::-webkit-scrollbar {
    display: none;
  }
  .mdl-booking-search-module .formPulldown__optionWrap:hover::-webkit-scrollbar, .mdl-booking-search-module .flyingSuggest:hover::-webkit-scrollbar {
    display: block;
    width: 4px;
  }
  .mdl-booking-search-module .formPulldown__optionWrap::-webkit-scrollbar-track, .mdl-booking-search-module .flyingSuggest::-webkit-scrollbar-track {
    background-color: transparent;
  }
  .mdl-booking-search-module .formPulldown__optionWrap::-webkit-scrollbar-thumb, .mdl-booking-search-module .flyingSuggest::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.5);
    border-radius: 16px;
  }
  .mdl-booking-search-module .flyingDateWrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .mdl-booking-search-module .flyingWrap {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .mdl-booking-search-module .flying__item {
    width: 172px;
  }
  .mdl-booking-search-module .btn__txt--flyingTop {
    position: static;
    -webkit-transform: none;
            transform: none;
  }
  .mdl-booking-search-module .reservationModuleWrap .btn.btn--flying, .mdl-booking-search-module .reservationModuleWrap .btn.btn--date {
    text-align: left;
    min-height: 56px;
    padding: 0 5px 0 52px;
  }
  .mdl-booking-search-module .reservationModuleWrap .btn.btn--flying::after {
    position: absolute;
    top: 50%;
    left: 10px;
    content: "";
    display: inline-block;
    width: 32px;
    height: 32px;
    background: url(/content/dam/guide-to-japan/icons/icon_pin_gd.svg) no-repeat 0 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .mdl-booking-search-module .flyingIcon {
    padding: 16px 2px;
  }
  .mdl-booking-search-module .dateWrap {
    margin: 0 0 0 5px;
  }
  .mdl-booking-search-module .date__item {
    width: 194px;
  }
  .mdl-booking-search-module .date__item + .date__item {
    margin-left: 5px;
  }
  .mdl-booking-search-module .reservationModuleWrap .btn.btn--date::after {
    position: absolute;
    top: 50%;
    left: 10px;
    content: "";
    display: inline-block;
    width: 32px;
    height: 32px;
    background: url(/content/dam/guide-to-japan/icons/icon_calendar_gd.svg) no-repeat 0 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
