@charset "UTF-8";
/*
**  ===================================================================
**  foundation CSS ※サイト全体に共通のスタイル
**  ===================================================================
*/
#contentArea {
  background: white;
  width: 1000px;
  margin: 0 auto;
}

#contentArea #contentAreaInner {
  padding: 0;
  margin: 0;
  width: 735px;
  float: left;
}

#contentArea #contentRight {
  width: 235px;
  float: right;
  padding: 0;
  margin: 0;
}

/*
**  ===================================================================
**  キャンペーン概要のスタイル
**  ===================================================================
*/
  *{
    margin: 0;
  }
  .accordion-title{
    position: relative;
    margin: 0;
    cursor: pointer;
  }
  .accordion-title:after{
    content: "";
    background-image: url(../img/accordion_arrow.png);
    background-repeat: no-repeat;
    background-size: 100%;
    height: 5vw;
    width: 6%;
    position: absolute;
    right: 3%;
    top: 50%;
    transition: all 0.2s ease-in-out;
    display: inline-block;
    -webkit-transform: translateY(-50%) rotate(0deg);
    transform: translateY(-50%) rotate(0deg);
  }
  .accordion-title.open:after{
    -webkit-transform: translateY(-50%) rotate(180deg);
    transform: translateY(-50%) rotate(180deg);
  }
  .accordion-content{
    display: none;
  }

/*
**  ===================================================================
**  各種設定：var,reset,base-font,break-point
**  ===================================================================
*/
/*
**  ===================================================================
**  Blocks
**  ===================================================================
*/
/*
**  ===================================================================
**  button CSS ※block { } block__element { } block_modifier { }（key_value）
**  ===================================================================
*/
@media screen and (min-width: 751px) {
  .button__hover{
    transition: .6s;
  }
  .button__hover:hover{
    opacity: .6;
  }
}

@media screen and (min-width: 769px){
  .is-hidden-tablet {
    display: none!important;
  }
}
@media screen and (max-width: 768px){
  .is-hidden-mobile {
    display: none!important;
  }
}


/*
**  ===================================================================
**  site-layout CSS ※block { } block__element { } block_modifier { }（key_value）
**  ===================================================================
*/
/* PC用
-------------------------------------------- */
body {
  font-family: "Noto Sans Japanese", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Verdana", sans-serif;
  font-style: normal;
}
header,footer{
  font-family: 'ヒラギノ角ゴ ProN W3','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic ProN','Hiragino Kaku Gothic Pro',verdana,'メイリオ',Meiryo,'ＭＳ Ｐゴシック', sans-serif;
  font-style: normal;
}



/* SP用
-------------------------------------------- */

  #wrapper{
    background: #fff;
  }
  div#wrapper-content {
    /* background-image: url(../img/main-image.png);*/
  }
  div#wrapper-content img {
    width: 100%;
    vertical-align: top;
  }
  div .hidden-xs {
    display: none !important;
  }
  .jtb-container {
    background: #ffffff;
    margin: auto;
  }
  .jtb-container p,
  .jtb-container li{
    line-height: inherit;
  }
  .contents {
    margin: 0 5%;
    text-align: center;
  }

  .contents-block{
    margin-bottom: 14%;
  }
  .contents-block:last-child{
    margin-bottom: 0;
  }
  .contents-title__area{
    text-align: center;
    display: flex;
  }
  .contents-title__img{
    width: 81px;
    margin-right: 6%;
  }
  .contents-title__text{
    width: 70%;
    font-size: 100%;
    font-weight: 300;
    text-align: left;
  }
  .contents-nav__area{
    margin-bottom: 6%;
  }
  .contents-nav__list{
    display: flex;
    justify-content: space-between;
    position: relative;
  }
  .contents-nav__item{
    width: calc((100% / 3) - 5px);
    position: relative;
    background-image: url(../img/nav_border.png);
    background-repeat: repeat-y;
    background-position: 18px 0;
    background-size: 1%;
    font-size: 90%;
    line-height: 1.3;
    color: #fff;
    font-weight: bold;
  }
  .contents-nav__item:nth-child(1){
    background-color: #C00812;
  }
  .contents-nav__item:nth-child(2){
    background-color: #006BB6;
  }
  .contents-nav__item:nth-child(3){
    background-color: #4C9132;
  }
  .contents-nav__item .contents-nav__inner{
    display: block;
    padding: 5% 2% 5% 20%;
  }
  .contents-nav__item a{
    box-sizing: border-box;
    padding: 5% 2% 5% 20%;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    width: 100%;
    font-size: 90%;
    line-height: 1.3;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
  }
  .contents-nav__item a:active,
  .contents-nav__item a:hover{
    color: #fff;
  }
  .contents-nav__item a:before{
    content: "";
    width: 10px;
    height: 6px;
    background-image: url(../img/nav_arrow.png);
    background-size: 100%;
    background-repeat: no-repeat;
    position: absolute;
    left: 4%;
  }
  .contents-nav__small{
    font-size: 70%;
  }

  .contents-block__title{
    text-align: left;
    font-size: 127%;
    font-weight: bold;
    color: #000000;
    line-height: 1;
    padding-bottom: 3%;
    border-bottom: 2px solid;
  }
  .contents-block__title.typeA{
    border-color: #C00812;
    font-size: 123%;
  }
  .contents-block__title.typeB{
    border-color: #006BB6;
  }
  .contents-block__title.typeC{
    border-color: #4C9132;
  }
  
  .contents-block__bg{
    background:repeating-linear-gradient(-45deg,#FFEFD1,#FFEFD1 8px,#FEF4E0 0,#FEF4E0 16px);
  }
  .contents-block__inner{
    padding: 6% 3% 4%;
  }

  .contents-ticket-title__area{
    align-items: center;
    margin-bottom: 6%;
  }
  .contents-ticket-title__logo{
    margin: 0 auto 5%;
    width: 80%;
    background: #fff;
  }
  .contents-ticket-title__img{
    margin: 0 auto;
    width: 52%;
  }
  .contents-ticket-title__text{
    text-align: left;
    font-size: 107%;
    font-weight: 300;
  }

  .contents-ticket-block{
    margin-bottom: 6%;
  }
  .contents-ticket-block.typeA{
    margin-bottom: 4%;
  }
  .contents-ticket-block:last-child{
    margin-bottom: 0;
  }
  .contents-ticket-block__title{
    text-align: center;
    background: #C00812;
    border-radius: 5px;
    font-size: 110%;
    color: #fff;
    line-height: 1.4;
    padding: 3% 10% 3% 20%;
  }
  .contents-ticket-block__title.typeA{
    background: #4C9132;
    position: relative;
    padding: 0;
  }
  .contents-ticket-block__title.typeA a{
    color: #fff;
    display: block;
    padding: 3% 20% 3% 20%;
    text-decoration: none;
  }
  .contents-ticket-block__title.typeB{
    padding: 3% 18% 3% 20%;
  }
  .contents-ticket-block__title.open{
    border-radius: 5px 5px 0 0;
  }
  .contents-ticket-block__icon{
    position: relative;
  }
  .contents-ticket-block__icon:before{
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -40%;
    background: url(../img/ticket_icon01.png) no-repeat;
    width: 34%;
    height: 100%;
    background-size: contain;
  }
  .contents-ticket-block__icon.typeA:before{
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -83%;
    background: url(../img/ticket_icon02.png) no-repeat;
    width: 68%;
    height: 100%;
    background-size: contain;
  }
  .contents-ticket-block__icon.typeB:before{
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -62%;
    background: url(../img/ticket_icon01.png) no-repeat;
    width: 59%;
    height: 100%;
    background-size: contain;
  }
  .contents-ticket-block__icon.typeC:before{
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -78%;
    background: url(../img/ticket_icon01.png) no-repeat;
    width: 70%;
    height: 100%;
    background-size: contain;
  }
  .contents-ticket-block__title.typeA:after{
    content: "";
    position: absolute;
    right: 4%;
    top: 50%;
    background: url(../img/ticket_link_icon.png) no-repeat;
    background-size: 100%;
    width: 6%;
    height: 5vw;
    display: block;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .contents-ticket-block__body{
    background: #fff;
    border: 1px solid #C00812;
  }

  .contents-ticket-block__inner{
    padding: 5% 4%;
  }
  .contents-ticket-step__list{
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 4%;
  }
  .contents-ticket-step__item{
    width: 38%;
    padding-right: 9%;
    margin-right: 5%;
    position: relative;
    margin-bottom: 6%;
  }
  .contents-ticket-step__item:after{
    content: "";
    background: url(../img/contents_ticket01_arrow.png) no-repeat;
    background-size: 100%;
    width: 10%;
    height: 30%;
    position: absolute;
    top: 10%;
    right: 0;
  }
  .contents-ticket-step__item:nth-child(2n){
    margin-right: 0;
  }
  .contents-ticket-step__item:nth-last-child(-n+2){
    margin-bottom: 0;
  }
  .contents-ticket-step__item:last-child:after{
    background: transparent;
    margin-right: 0;
  }

  .contents-ticket-step__img{
    margin: 0 8% 8%;
  }
  .contents-ticket-step__text{
    text-align: left;
    font-size: 80%;
    font-weight: 300;
    color: #000;
    display: flex;
    align-items: start;
  }
  .contents-ticket-step__number{
    font-family: noto-sans, sans-serif;
    font-weight: 500;
    display: inline-block;
    background: #BD0411;
    border-radius: 100px;
    padding: 0px 5%;
    vertical-align: middle;
    font-size: 100%;
    color: #FFCD00;
    margin-right: 5%;
    line-height: 18px;
  }
  .contents-ticket-step__number.typeA{
    padding: 0 2% 0 1%;
  }
  .contents-ticket-step__caution{
    font-size: 70%;
    font-weight: 300;
    text-align: right;
    color: #000;
  }

  .contents-price{
    margin: 4% auto 4%;
    background: #FDF3DE;
  }
  .contents-price__area{
    padding: 3% 6% 3%;
  }
  .contents-price__list{
    display: flex;
    justify-content: center;
    margin-bottom: 4%;
  }

  .contents-price-block{
    padding-top: 2%;
    padding-right: 7%;
    padding-bottom: 2%;
    margin-right: 7%;
    border-right: 2px dotted #666666;
    width: 100%;
  }
  .contents-price-block:last-child{
    margin-right: 0;
    padding-right: 0;
    border-right: none;
  }
  .contents-price-block__title{
    font-size: 90%;
    color: #006BB6;
    line-height: 1;
    margin-bottom: 30%;
  }
  .contents-price-block__item{
    width: 100%;
    font-family: noto-sans, sans-serif;
    font-weight: bold;
    font-style: normal;
    line-height: 1;
    font-size: 115%;
    margin-bottom: 10%;
  }
  .contents-price-block__item:last-child{
    margin-bottom: 0;
  }
  .contents-price-block__small{
    font-size: 80%;
    font-weight: 500;
    margin-left: 3%;
  }
  .contents-price__date{
    text-align: right;
    font-size: 70%;
    font-weight: 300;
    color: #000;
  }

  .contents-ticket-block__subtitle{
    font-size: 100%;
    line-height: 1;
    background: #FFC3C8;
    text-align: left;
    padding: 3% 4%;
    color: #000;
    margin-bottom: 4%;
  }
  .contents-ticket-block__text{
    text-align: left;
    font-size: 100%;
    font-weight: 300;
    color: #000;
  }
  .contents-ticket-block__link{
    color: #006BB6;
    text-decoration: underline;
    position: relative;
  }
  .contents-ticket-block__link:after{
    content: "";
    display: inline-block;
    background-image: url(../img/contents_link_icon.png);
    background-repeat: no-repeat;
    background-size: 100%;
    width: 8px;
    height: 12px;
    padding-left: 1%;
  }

  .contents-price__caution{
    font-size: 70%;
    text-align: left;
    font-weight: 300;
    color: #000;
  }

  .contents-pause__bg{
    margin-top: 5%;
    background: #DCEAF8;
  }
  .contents-pause__inner{
    padding: 3% 4%;
  }
  .contents-pause__text{
    font-size: 95%;
    font-weight: 300;
    line-height: 1.6;
    text-align: left;
    color: #1C5EA6;
  }

  .contents-leisure__block{
    margin-bottom: 6%;
  }
  .contents-leisure__title{
    text-align: center;
    font-size: 100%;
    margin-bottom: 3%;
    font-weight: bold;
    color: #4C9132;
  }
  .contents-leisure__text{
    text-align: left;
    font-size: 100%;
    font-weight: 300;
    color: #000;
  }



/* Common
------------------------------------------------------------- */
.wf-hannari {
  font-family: "Hannari";
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

.color-red {
  color: #e60012;
}

.tl-center {
  text-align: center;
}

/*
**  ===================================================================
**  site-header CSS ※block { } block__element { } block_modifier { }（key_value）
**  ===================================================================
*/



  .main__area{
    background: #006BB6;
    margin: auto;
  }
  .main__title{
    text-align: center;
    margin-bottom: 6%;
    color: #ffffff;
    font-size: 130%;
    font-weight: bold;
    display: block;
    padding: 7% 7% 5%;
    text-decoration: none;
    line-height: 28px;
  }
  .main__title a{
    color: #ffffff;
    font-size: 130%;
    font-weight: bold;
    display: block;
    padding: 7% 7% 5%;
    text-decoration: none;
  }


/*
**  ===================================================================
**  site-footer CSS ※block { } block__element { } block_modifier { }（key_value）
**  ===================================================================
*/
  .l-contact {
    padding: 6% 3% 2%;
    text-align: center;
  }
  .l-contact img {
    margin: auto;
  }
  .snslist {
    text-align: center;
    letter-spacing: -.4em;
    margin: 10% 0;
  }
  .snslist__item {
    vertical-align: top;
    display: inline-block;
    letter-spacing: normal;
    margin: 0 3px;
  }
  .l-bnr {
    margin: 5% 4%;
  }
  .l-bnr__item {
    line-height: 0;
  }
  .l-bnr__item a {
    display: block;
  }
  .inquiry__item {
    width: 90%;
  }


.icon {
  display: inline;
}

/*
**  ===================================================================
**  site-navigation CSS ※block { } block__element { } block_modifier { }（key_value）
**  ===================================================================
*/

  .l-nav__list {
    padding: 4% 3%;
    text-align: center;
  }
  .l-nav__item {
    margin-bottom: 3%;
  }
  .l-nav__item:last-child {
    margin-bottom: 0;
  }
