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

/*--------------------------------------------------------------
 clearFix
----------------------------------------------------------------*/

.clearfix:after { /*floatの解除*/
  display:block;
  clear:both;
  height:0px;
  visibility:hidden;
  content:".";
}

.clearfix {min-height:1px; /*IE6、7対策*/}

* html .clearfix {
  height:1px;　/*¥*//*/ /*MAC IE5.x対策*/
  height:auto;
  overflow:hidden;
  /**/
}

.clear {clear: both;}

/* Clearing floats */
.clear:after,
.wrapper:after,
.format-status .entry-header:after {
  clear:both;
}
.clear:before,
.clear:after,
.wrapper:before,
.wrapper:after,
.format-status .entry-header:before,
.format-status .entry-header:after {
  display:table;
  content:"";
}

/* Main Visual */

#mainvisual {
  display: block;
  max-width: 1100px;
  text-align: center;
  margin: 0 auto;
}
#mainvisual img{
  width: 100%;
}

/* Container */
#container .guide_box {
  width: 1100px;
  margin: 40px auto 40px auto;
}
#container .guide_box .left {
  width: 350px;
  margin: 0;
  padding: 0;
  float: left;
}
#container .guide_box .left .title {
  width: 360px;
  padding: 2px 0 17px 10px;
  color: #333;
  font-size: 26px;
  line-height: 1em;
  font-weight: bold;
  text-align: left;
}
#container .guide_box .left .sidemenu {
  width: 360px;
  border-top: #DDD 1px solid;
}
#container .guide_box .left .sidemenu li {
  position: relative;
  width: 360px;
  margin: 0;
  list-style: none;
  border-bottom: #DDD 1px solid;
  text-align: left;
}
#container .guide_box .left .sidemenu li::after,
#container .guide_box .left .sidemenu li::before {
  display: block;
  content: '';
  position: absolute;
}
#container .guide_box .left .sidemenu li::after {
  top: .35em;
  left: -1.2em;
  width: 14px;
  height: 14px;
  background-color: #FEDB00;
  border-radius: 100%;
  top: 19px;
  left: 10px;
}
#container .guide_box .left .sidemenu li::before {
  z-index: 2;
  top: .625em;
  left: -.975em;
  width: 4px;
  height: 4px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 23px;
  left: 13px;
}
#container .guide_box .left .sidemenu a {
  display: block;
  padding: 15px 0 15px 34px;
  color: #333;
}
#container .guide_box .left .sidemenu a:hover {
  background-color: #F5F5F5;
  color: #333;
}

#container .guide_box .right {
  width: 800px;
  margin: 0;
  padding: 0;
  float: right;
}


#container .guide_box *{
  box-sizing: border-box;
}
#container .cam__fee__wrap h4.cam__fee__title{
  font-size:1.5em;
  background-color:#88D1F5;
  color:#000;
  padding:15px 0;
  text-align:center;
}
#container .cam__fee__wrap h4.cam__fee__staff{
  font-size:1.5em;
  background-color:#88D1F5;
  color:#000;
  padding:15px 0;
  text-align:center;
}


#container .cam__fee__wrap .sale_inactive{
  margin-top: 2em;
  font-size: 1.2em;
  line-height: 2em;
}
#container .right h4.campaign {
  padding: 2px 0 25px 0;
  text-align: center;
  font-size: 1.5em;
}

#container .yokoku {
  position: relative;
}
#container .yokoku img {
  width: 160px;
  position: absolute;
  top:-35px;
  right: 0;
}

.cam__fee__lst li{
  list-style:none;
  text-align:left;
  border-bottom:1px dashed #ccc;
  padding:20px 0;
}
.cam__fee__lst li:nth-child(even){
  background-color:#efefef;
}

#container .cam__fee__wrap .ul__staff{
  border: solid 1px #FF7D00;
}

.cam__fee__data,.cam__fee__link{
  display:inline-block;
  vertical-align:middle;
}
.cam__fee__data{
  width:69%;
}
.cam__fee__link{
  width:28%;
}
.cam__fee__area,.cam__fee__mdltxt,.cam__fee__kikan,.cam__fee__wari{
  padding-left:10px;
}
.cam__fee__area{
  font-size:26px;
}
.cam__fee__area-m{
  font-size:20px;
  padding-left:15px;
}
.cam__fee__mdltxt{
  font-size:28px;
  color:#DD0000;
  font-weight:bold;
}
.cam__fee__mdltxt-m{
  font-size:14px;
  color:#333;
  font-weight:normal;
}
.cam__fee__mdltxt-m span{
  background-color: #FFE900;
  padding: 0 0.25em;
}
.cam__fee__kikan{
  padding:5px 0;
}
.cam__fee__wari{
  margin-top: 0.25em;
  color:#DD0000;
  font-weight: bold;
}
.cam__fee__attention{
  text-align:left;
  font-size:13px;
  padding-top:20px;
}
.cam__fee__attention span{
  display: block;
  margin-left: 1em;
  text-indent: -1em;
}
.btn__cam__fee{
  display:inline-block;
  width:200px;
  height:54px;
  text-align:center;
  text-decoration:none;
  line-height:54px;
  outline:0;
  cursor:pointer;
  position:relative;
  z-index:2;
  background-color:#FFF34B;
  border:2px solid #FFF34B;
  color:#000;
  line-height:50px;
}
.btn__cam__fee,.btn__cam__fee::before,.btn__cam__fee::after{
  -webkit-box-sizing:border-box;
  -moz-box-sizing:border-box;
  box-sizing:border-box;
  -webkit-transition:all .3s;
  transition:all .3s;
}
.btn__cam__fee::before,.btn__cam__fee::after{
  position:absolute;
  z-index:-1;
  display:block;
  content:'';
  top:0;
  width:50%;
  height:100%;
  background-color:#FFF34B;
}
.btn__cam__fee:hover{
  background-color:#fff;
  border-color:#FFF34B;
  color:#000;
}
.btn__cam__fee::before{
  right:0;
}.btn__cam__fee::after{
  left:0;
}
.btn__cam__fee:hover::before,.btn__cam__fee:hover::after{
  width:0;
  background-color:#FFF34B;
}

.opensaleArea{
  color: #222;
/*  text-align: left;*/
}
.opensaleArea .tokuten{
  background-color: #FFF34B;
  font-size: 1.5em;
  padding: 5px;
  margin-bottom: 20px;
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.1em;
}
.opensaleArea .heading-text{
  margin: 2em auto;
  line-height: 2em;
}
.opensaleArea .mt20{
  margin-top: 20px;
}
.opensaleArea .attention{
  color: #DD0000;
  line-height: 2em;
  margin: 2em auto;
}
.opensaleArea .attention .text__1 {
  font-weight: 700;
}
.opensaleArea .attention .text__2 {
  font-weight: 700;
  color:#000;
}
.opensaleArea .attention .num {
  color: #DD0000;
  font-size:2em;
  padding: 0 3px;
}
.opensaleArea h4.period__ttl {
  margin: 20px 0 0 0;
  font-size: 1.2em;
  text-align: left;
}
.opensaleArea h4.period__ttl span{
  color: #DD0000;
}
.opensaleArea .period {
  display: flex;
  flex-wrap: wrap;
  margin: 20px 0 30px 0;
  width: 100%;
  text-align: left;
  font-weight: bold;
  font-size: 1.2em;
/*  overflow-wrap: break-word;
  min-width: 0;*/
}
.opensaleArea .period dt, .opensaleArea .period dd {
  padding: 10px;
  flex-wrap: wrap;
  box-sizing: border-box;
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc;
  /*overflow-wrap: break-word;
  min-width: 0;*/
}
.opensaleArea .period dt {
  display: flex;
  align-items: center;
  width: 20%;
  background-color: #efefef;
}
.opensaleArea .period dt:last-of-type,
.opensaleArea .period dd:last-of-type {
  border-bottom: 1px solid #ccc;
}
.opensaleArea .period dd {
  display: flex;
  align-items: center;
  width: 80%;
  margin-left: 0;
  border-right: 1px solid #ccc;
  background-color: #fcfcfc;
}
.opensaleArea .period dd span {
  display: inline-flex;
}
.opensaleArea .text_left{
  margin-bottom: 5px;
}
.mt20{
  margin-top: 20px;
}
.btn{
  margin: 3em 0 1em 0;
}
.btn ,.btn a{
  width: 100%;
}
.fs075 {
  font-size: 0.75em;
}
.red {
  color: #DD0000;
}
.w100 {
  width: 100%;
}


@media screen and (max-width:740px){
  #mainvisual{
    height: inherit;
  }
  #container .guide_box {
    width: 90%;
    padding: 5%;
    margin: 0 0 5% 0;
  }
  #container .guide_box .left {
    width: 100%;
    margin: 0;
    padding: 0;
  }
  #container .guide_box .right {
    width: 100%;
    margin: 0 0 30px;
    padding: 0;
  }
  #container .right h4.campaign{
    font-size: 1.2em;
  }

  #container .yokoku {
    position: relative;
  }
  #container .yokoku img {
    width: 130px;
    position: absolute;
    top:-55px;
    right: -20px;
  }

  #container .cam__fee__wrap h4.cam__fee__title{
    line-height: 1.5em;
  }
  #container .cam__fee__wrap h4.cam__fee__staff{
    line-height: 1.5em;
  }
  .opensaleArea .tokuten{
    font-size: 1.2em;
  }
  .opensaleArea .heading-text{
    margin: 2em auto;
    font-size: 0.85em;
    width: 100%;
  }
  .opensaleArea .heading-text .app__ul li{
    margin-left: 1em;
  }
  .opensaleArea .period{
    display: block;
  }
  .opensaleArea .period dt,.opensaleArea .period dd {
    display: block;
    width: 100%;
    border-right: 1px solid #ccc;
    border-bottom: none;
  }
  .opensaleArea .period dt:last-of-type {
    border-bottom: none;
  }
  .cam__fee__data,.cam__fee__link{
    display:block;
    vertical-align:top;
  }
  .cam__fee__data{
    width:100%;
  }
  .cam__fee__link{
    padding-top: 20px;
    width:100%;
    text-align: center;
  }
  .cam__fee__link a {
    width: 90%;
  }
  .cam__fee__mdltxt-m{
    display:block;
  }
  .cam__fee__kikan{
    font-size:13px;
  }
}

@media screen and (max-width:380px){
  .opensaleArea .heading-text .app__ul{
    width: 100%;
  }
}


/** box26 **/
.box26 {
  position: relative;
  margin: 2em 0;
  padding: 0.5em 1em 0 1em;
  border: solid 3px #64A70B;
  border-radius: 8px;
}
.box26 .app__ttl{
  position: absolute;
  display: inline-block;
  margin: 0;
  top: -15px;
  left: 10px;
  padding: 0 10px;
  background-color: #fff;
  text-align: left;
  font-size: 1.2em;
  font-weight: bold;
}
.box26 .app__ttl i {
  color: #64A70B;
  margin-right: 0.5em;
  font-size: 1.2em;
}
.box26 .app__ul{
/*  width: 420px;*/
  list-style: none;
  margin: 20px auto 1em auto;
}
.box26 .app__ul li{
  margin-left: 2em;
  text-indent: -1em;
  text-align: left;
}

/** info campaign **/
.info__cp {
  margin: 1em 0;
  font-size: 0.9em;
  text-align: left;
}
.info__cp .info__text{
  margin: 0.5em 0 0.5em 3em;
}
.info__cp .info__text .kikan {
  font-weight: bold;
}
@media screen and (max-width:740px) {
  .info__cp .info__text {
    margin: 0.5em 0;
  }
  .info__cp .info__text .kikan {
    display: block;
  }
  .box26 {
    padding: 0.5em 0.25em 0 0.25em;
  }
  .box26 .app__ul li{
    margin-left: 1.5em;
  }
  .box26 .app__ul{
    font-size: 0.85em;
  }
}

.coupon-btn {
  display: flex;
  align-items: center;
  background-color: #ffed00;
  border-radius: 30px;
  padding: 20px 30px;
  font-family: sans-serif;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
  width: fit-content;     /* ← コンテンツサイズに応じた幅 */
  margin: 20px auto;
}
.coupon-btn .left-text {
  color: #9b4d9b;
  font-size: 20px;
  margin-right: 20px;
}
.coupon-btn .divider {
  width: 2px;
  height: 60px;
  background-color: #9b4d9b;
  margin-right: 20px;
}
.coupon-btn .code-area {
  display: flex;
  flex-direction: column;
}
.coupon-btn .code {
  font-size: 32px;
  font-weight: bold;
  color: #9b4d9b;
}
.coupon-btn .note {
  font-size: 14px;
  color: #ff0000;
  margin-top: 4px;
}

@media (max-width: 600px) {
  .coupon-btn {
    flex-direction: column;
    text-align: center;
    padding: 20px;
  }
  .coupon-btn .divider {
    display: none;
  }
  .coupon-btn .left-text {
    margin-right: 0;
    margin-bottom: 10px;
  }
}



/* Search Box */
#container .form_search{
  display: block;
}

#container .serchbox {
  text-align: left;
  padding: 5px 20px 15px 20px;
  margin: 0 auto 40px auto;
  background-color: rgba(243,238,245,1.00);
  -moz-border-radius: 4px;
  -webkit-border-radius: 4px;
  border-radius: 4px;
}
#container .serchbox h4 {
  font-size: 16px;
  /*line-height: 1em;*/
  margin-bottom: -10px;
  padding: 10px;
  font-weight: bold;
}
#container .serchbox h4 i {
  color: #88D1F5;
  font-size: 1.2em;
}

#container .serchbox .areaselect {
  width: 100%;
}

#container .serchbox .areaselect .midashi {
  display: inline;
  padding: 8px 12px;
  width: 50px;
  height: 38px;
  margin: 0 5px 0 0;
  font-size: 12px;
  line-height: 40px;
  text-align: center;
  color: #FFFFFF;
  background-color: #666;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
}

#container .serchbox .date {
  display: inline;
  width: 100%;
  margin: 0 20px 0 0;
  /*float: left;*/
  text-align: left;
}
#container .serchbox .date .date__departure {
  display: inline;
  margin-right: 10px;
}
#container .serchbox .date .date__return {
  display: inline;
  margin-right: 10px;
}


#container .serchbox .date .midashi {
  display: inline;
  padding: 8px 18px;
  width: 50px;
  height: 38px;
  margin: 0 5px 0 0;
  font-size: 12px;
  line-height: 40px;
  text-align: center;
  color: #FFFFFF;
  background-color: #666;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
  /*float: left;*/
}

#container .serchbox .date input,#container .serchbox .date select {
  display: inline;
}

#container .serchbox .date input[type="text"],
#container .serchbox .date input[type="date"]{
  width: 135px;
  height: 38px;
  font-size: 14px;
  border: 1px solid #DDD;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
  background-image: url(../img/icon_calendar.png);
  background-repeat: no-repeat;
  background-position: 10px 8px;
  padding: 0 8px 0 40px;
  margin: 0 5px 0 0;
}
#container .serchbox .date input[type="text"]:focus,
#container .serchbox .date input[type="date"]:focus {
  border: 1px solid #999;
  outline: 0;
}
#container .serchbox .date select {
  width: 70px;
  height: 38px;
  font-size: 14px;
  border: 1px solid #DDD;
  border-radius: 3px;
  padding: 0 8px 0 8px;
  background-image: url(../img/icon_arrow.png);
  background-repeat: no-repeat;
  background-position: right 10px top 16px;
  /*float: left;*/
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: '';
}

#container .serchbox .date select::-ms-expand {
  display: none;
}
#container .serchbox .date select:focus {
  border: 1px solid #999;
  outline: 0;
}
#container .serchbox .areaselect select {
  display: inline;
  height: 38px;
  font-size: 14px;
  border: 1px solid #DDD;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
  padding: 0 8px 0 8px;
  margin: 0;
}
#container .serchbox .areaselect select::-ms-expand {
  display: none;
}
#container .serchbox .areaselect select:focus {
  border: 1px solid #999;
  outline: 0;
}
#container .serchbox .areaselect select.from_pref {
  width: 100px;
  background-image: url(../img/icon_arrow.png);
  background-repeat: no-repeat;
  background-position: right 10px top 16px;
}
#container .serchbox .areaselect select.from_area {
  width: 115px;
  background-image: url(../img/icon_arrow.png);
  background-repeat: no-repeat;
  background-position: right 10px top 16px;
}

#container .serchbox .button {
  display: inline-block;
  width: 135px;
  height: 35px;
  font-size: 18px;
  margin: 0 0 3px 0;
  text-align: center;
  text-decoration: none;
  outline: none;
  position: relative;
  background-color: #5dc2d0;
  border-radius: 4px;
  border: none;
  color: #fff;
  line-height: 40px;
  -webkit-transition: none;
  transition: none;
  box-shadow: 0 3px 0 #5a96aa;
  text-shadow: 0 1px 1px rgba(0, 0, 0, .3);
  /*float: left;*/
}
#container .serchbox .button:hover {
    box-shadow: none;
    transform: translate3d(0, 3px, 0);
}

.btn__code{
  padding: 1em 3em;
  background-color: #9B2E8D;
}


@media screen and (max-width:740px) {
  #container .serchbox .button {
    margin-top: 0.25em;
    width: 100%;
  }
}

