html {
  font-family: 'Noto Sans JP', sans-serif;
}

#main {
  color: #333333;
  padding-top: 66px;
}

/* Component pill-button
-------------------------*/
.pill-button {
  width: 100%;
  display: inline-flex;
  justify-content: center;
  color: #333;
  font-size: 14px;
  padding: 14px 1rem;
  background-color: #FFF;
  border: 1px solid #54B0E3;
  border-radius: 60px;
  transition: all .3s;
}
@media (hover: hover) {
  .pill-button:hover {
    color: #FFF;
    background-color: #54B0E3;
  }
}
.pill-button--to-top {
  border: 1px solid #FFF;
}
@media (hover: hover) {
  .pill-button--to-top:hover {
    color: #000;
    border: 1px solid #FFF;
    background-color: #E2E2E2;
  }
}

/* honu-mv
-------------------------*/
.page-mv {
  background-size: cover;
  background-repeat: no-repeat;
}
@media not all and (min-width: 769px) {
  .page-mv {
    background-position: top right;
    background-image: url("../images/campaign/honu/mv_bg_sp_2.jpg");
  }
}
@media screen and (min-width: 769px) {
  .page-mv {
    height: 450px;
    background-position: center;
    background-image: url("../images/campaign/honu/mv_bg_pc_2.jpg");
  }
  .page-mv.bg__wave-bottom::after {
    bottom: -1.5vw;
  }
}

.page-mv__inner {
  display: flex;
  justify-content: space-between;
}
@media not all and (min-width: 769px) {
  .page-mv__inner {
    width: 100%;
    padding: 0 calc((20 / 375) * 100%);
  }
}
@media screen and (min-width: 769px) {
  .page-mv__inner {
    width: auto;
    max-width: 1036px;
    margin: 0 auto;
    padding: 0 20px;
  }
}

.page-heading {
  display: flex;
  flex-direction: column;
  /* margin-left: auto; */
}
@media not all and (min-width: 769px) {
  .page-heading {
    padding-top: 10px;
  }
}
@media screen and (min-width: 769px) {
  .page-heading {
    width: 50%;
    padding-top: 23px;
    padding-left: 20px;
  }
}

@media not all and (min-width: 769px) {
  .page-heading__campaign {
    padding-top: 10px;
    margin-left: -9px;
  }
}
@media screen and (min-width: 769px) {
  .page-heading__campaign {
    padding-top: 30px;
    padding-left: 36px;
  }
}

@media not all and (min-width: 769px) {
  .page-mv__logo {
    padding-top: 24px;
    width: 20%;
  }
}
@media screen and (min-width: 769px) {
  .page-mv__logo {
    padding-top: 23px;
  }
}

/* gohawaii-mv
-------------------------*/

.gohawii_mv {
  position: relative;
  text-align: center;
  background-repeat: no-repeat;
  background-color: #fff;
}
@media not all and (min-width: 769px) {
  .gohawaii_mv {
    aspect-ratio: 375 / 300;
    width: 100%;
    max-height: 300px;
    background-size: cover;
    background-position: bottom 0 center;
    background-image: url("../images/campaign/gohawaii/mv_sp.jpg");
    padding: calc(20 / 375 * 100%);
  }
}
@media screen and (min-width: 769px) {
  .gohawaii_mv {
    aspect-ratio: 1920 / 600;
    width: 100%;
    height: 450px;
    text-align: center;
    background-size: cover;
    background-position: top 0 center;
    background-image: url("../images/campaign/gohawaii/mv_pc.jpg");
    padding-inline: 20px;
  }
  .bg__wave-bottom::after {
    bottom: -1.5vw;
  }
}


.gohawaii_mv__title {
  display: block;
}
@media screen and (min-width: 769px) {
  .gohawaii_mv__title {
    padding-top: 24px;
  }
}

@media not all and (min-width: 769px) {
  .gohawaii_mv__image {
    display: block;
    width: calc(310 / 335 * 100%);
    max-width: 300px!important;
    margin: 0 auto;
  }
}
@media screen and (min-width: 769px) {
  .gohawaii_mv__image {
    max-width: 717px;
    object-fit: contain;
    margin: 0 auto;
  }
}

.gohawaii-point:before{
    content: url(../images/campaign/gohawaii/icon.svg);
    position:relative;
    top:12px;      /*上からの位置*/
    left:0;  
}

.caution{
  font-size: 0.5em;/*　文字サイズ調整 */
	vertical-align: top;  /* 文字の位置調整 */
}
  



/* answer-mv
-------------------------*/

.answer_mv {
  position: relative;
  text-align: center;
  background-repeat: no-repeat;
  background-color: #fff;
}
@media not all and (min-width: 769px) {
  .answer_mv {
    aspect-ratio: 375 / 300;
    width: 100%;
    max-height: 300px;
    background-size: cover;
    background-position: bottom 0 center;
    background-image: url("../images/campaign/answer/mv_sp.jpg");
    padding: calc(20 / 375 * 100%);
  }
}
@media screen and (min-width: 769px) {
  .answer_mv {
    aspect-ratio: 1920 / 600;
    width: 100%;
    height: 450px;
    text-align: center;
    background-size: cover;
    background-position: top 0 center;
    background-image: url("../images/campaign/answer/mv_pc.jpg");
    padding-inline: 20px;
  }
  .bg__wave-bottom::after {
    bottom: -1.5vw;
  }
}


.answer_mv__title {
  display: block;
}
@media screen and (min-width: 769px) {
  .answer_mv__title {
    padding-top: 24px;
  }
}

@media not all and (min-width: 769px) {
  .answer_mv__image {
    display: block;
    width: calc(310 / 335 * 100%);
    max-width: 300px!important;
    margin: 0 auto;
  }
}
@media screen and (min-width: 769px) {
  .answer_mv__image {
    max-width: 717px;
    object-fit: contain;
    margin: 0 auto;
  }
}



/* section
-------------------------*/
.section {
  width: 100%;
  margin-bottom: 80px;
}
@media not all and (min-width: 769px) {
  .section:not(.section--sp-slider) {
    padding: 0 calc((20 / 375) * 100%);
  }
}
@media screen and (min-width: 769px) {
  .section {
    max-width: 1036px;
    padding: 0 20px;
    margin-right: auto;
    margin-left: auto;
  }
}
.section__heading {
  color: #000000;
  font-weight: bold;
  margin-bottom: 0;
}
@media not all and (min-width: 769px) {
  .section__heading {
    font-size: 24px;
  }
  .section.section--sp-slider .section__heading {
    font-size: 24px;
  }
}
@media screen and (min-width: 769px) {
  .section__heading {
    font-size: 32px;
  }
}
.section__content {
  margin-top: 40px;
}
@media not all and (min-width: 769px) {
  .section.section--sp-slider .section__content {
    margin-top: 9px;
  }
}


/* page-overview
-------------------------*/
.page-overview {
  margin-top: calc(40px + 1.5vw);
}
.page-overview__heading {
  color: #00AAAC;
  text-align: center;
  font-weight: bold;
  line-height: 1.3;
}
@media not all and (min-width: 769px) {
  .page-overview__heading {
    font-size: 24px;
  }
  .page-overview__heading span {
    background: repeating-linear-gradient(#FFF, #FFF 18px, #FFF691 14px, #FFF691 31px)
  }
}
@media screen and (min-width: 769px) {
  .page-overview__heading {
    font-size: 32px;
  }
  .page-overview__heading span {
    background: repeating-linear-gradient(#FFF, #FFF 28px, #FFF691 20px, #FFF691 45px);
  }
}

.page-overview__text {
  line-height: 1.75;
}
@media not all and (min-width: 769px) {
  .page-overview__text {
    font-size: 14px;
    margin-top: 28px;
  }
}
@media screen and (min-width: 769px) {
  .page-overview__text {
    font-size: 16px;
    margin-top: 24px;
  }
}

.page-overview__explanation {
  font-size: 14px;
  border: 1px solid #54B0E3;
  padding: 32px 24px;
  margin-top: 16px;
}

/* campaign-overview__item
-------------------------*/
.campaign-overview__item + .campaign-overview__item {
  margin-top: 40px;
}

/* overview-heading
-------------------------*/
.overview-heading {
  font-weight: bold;
  font-size: 16px;
  color: #000000;
}

/* overview-text
-------------------------*/
.overview-text {
  font-size: 14px;
  background-color: #F5F7FA;
  padding: 24px;
  margin-top: 16px;
}
.overview-text__link,
.overview-text--links span {
  color: #3064D5;
}
@media screen and (min-width: 769px) {
  .overview-text__link {
    word-break: keep-all;
  }
}
@media (hover: hover) {
  .overview-text__link:hover {
    color: #140D77;
    opacity: 1;
  }
}

/* cards
-------------------------*/
@media not all and (min-width: 769px) {
  .cards {
    width: auto;
    display: flex;
    overflow-x: scroll;
    padding: 5px calc(( 20 / 375) * 100%);
  }
}
@media screen and (min-width: 769px) {
  .cards {
    display: flex;
    justify-content: space-between;
  }
}
@media not all and (min-width: 769px) {
  .cards__item {
    width: calc(( 320 / 375) * 100%);
    flex-shrink: 0;
  }
  .cards__item + .cards__item {
    margin-left: 16px;
  }
}
@media screen and (min-width: 769px) {
  .cards__item {
    width: calc(( 100% - 32px ) /3);
  }
}

/* merchandise-card
-------------------------*/
.merchandise-card {
  display: block;
  max-width: 320px;
  background-color: #FFF;
  border-radius: 4px;
  box-shadow: 0px 0px 6px rgba(0, 0, 0, .16);
  overflow: hidden;
}
.merchandise-card__img {
  width: 100%;
  height: 160px;
  overflow: hidden;
}
.merchandise-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
.merchandise-card__detail {
  height: calc(100% - 160px);
  display: flex;
  flex-direction: column;
  padding: 16px 16px 20px;
}
.merchandise-card__heading {
  font-size: 16px;
  line-height: 1.2;
  color: #333333;
}
.merchandise-card__text {
  font-size: 12px;
  color: #333333;
  margin: 8px 0;
}
.merchandise-card__price {
  font-size: 16px;
  color: #F01C1C;
  font-weight: bold;
  word-break: break-all;
  margin-top: auto;
}


/* button-container
-------------------------*/
.button-container {
  width: 280px;
}
@media not all and (min-width: 769px) {
  .button-container {
    width: 280px;
    margin: 20px auto 0;
  }
}
@media screen and (min-width: 769px) {
  .button-container {
    width: 280px;
    margin: 45px auto 0;
  }
}

/* page-bottom
-------------------------*/
.page-bottom {
  background-size: cover;
  background-position: top left;
  background-repeat: no-repeat;
  background-color: #FFF;
}
@media not all and (min-width: 769px) {
  .page-bottom {
    background-image: url("../images/souvenir/bg_souvenir_ocean_sp.jpg");
  }
}
@media screen and (min-width: 769px) {
  .page-bottom {
    background-image: url("../images/souvenir/bg_souvenir_ocean_pc.jpg");
  }
}
.page-bottom .button-container {
  margin-top: 0;
  position: relative;
  z-index: 2;
}
@media not all and (min-width: 769px) {
  .page-bottom .button-container {
    padding: 90px 0;
  }
}
@media screen and (min-width: 769px) {
  .page-bottom .button-container {
    padding: 60px 0;
  }
}

/* New styles 20240214 */
.nav__list li{
  width: 20%;
}

.page-overview__text {
  text-align: center;
}
.page-overview__gourmet {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  /* gap: 24px; */
  margin-top: 24px;
  flex-wrap: wrap;
}
.overview-gourmet__card {
  justify-content: flex-start;
  background-color: #ffffff;
  width: calc(100% / 3 - 16px);
}
.overview-gourmet__img {
  width: 100%;
  height: auto;
  flex: 0 0 auto;
  margin-top: 16px;
}
.overview-gourmet__desc {
  margin-left: 24px;
}
.overview-gourmet__heading {
  font-size: 16px;
  font-weight: bold;
  text-indent: -30px;
  padding-left: 29px;
}
.gourmet-heading {
  text-indent: -28px;
  padding-left: 26px;
}
.gourmet-num {
  font-size: 16.5px;
  color: #ffffff;
  font-weight: bold;
  background-color: #54B0E3;
  border-radius: 50%;
  padding: 0px 7.14px;
  margin-right: 4px;
}
.overview-gourmet__text {
  font-size: 16px;
  margin-top: 16px;
}

/* ポイントcol2 */

.page-overview__text {
  text-align: center;
}
.page-overview__point {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  gap: 24px; 
  margin-top: 24px;
  flex-wrap: wrap;
}
.overview-point__card-col2 {
  display: flex;
  justify-content: flex-start;
  background-color: #ffffff;
  max-width: 486px;
  width: calc(100% / 2 - 16px);
}
.overview-point__img {
  width: 164px;
  height: 164px;
  flex: 0 0 auto;
  margin-top: 16px;
}
.overview-point__desc-col2 {
  margin-left: 24px;
}
.overview-point__heading {
  font-size: 16px;
  font-weight: bold;
  text-indent: -30px;
  padding-left: 29px;
}
.point-heading {
  text-indent: -28px;
  padding-left: 26px;
}
.overview-point__text {
  font-size: 16px;
  margin-top: 16px;
}

@media not all and (min-width: 769px) {
  .overview-point__card-col2 {
    width: auto;
  }
  .overview-point__heading {
    grid-column: 1 / span 2;
    grid-row: 1;
  }
  .overview-point__img {
    width: 39%;
    height: auto;
    max-width: 132px;
    margin-top: 8px;
  }
  .overview-point__text {
    grid-column: 2 / 3;
    grid-row: 2;
    margin-left: 16px;
    margin-top: 8px;
  }
  .page-overview__point {
    flex-direction: column;
  }
}


/* ポイントcol2 */



.page-overview__flight {
  margin-top: 24px;
  display: flex;
  justify-content: flex-start;
  gap: 24px;
}
.overview-flight__card {
  max-width: 315px;
  text-align: center;
}
.overview-flight__heading {
  font-size: 16px;
  font-weight: bold;
  display: inline-block;
  border-bottom: 2px solid #54B0E3;
}
.page-overview__video {
  height: fit-content;
}
.page-overview__video video {
  width: 100%;
  max-width: 100%;
  margin-top: 24px;
}
@media not all and (min-width: 769px) {
  .overview-gourmet__card {
    display: grid;
    grid-template-columns: 1fr calc(100% - 132px);
    width: auto;
    max-width: 100%;
  }
  .overview-gourmet__heading {
    grid-column: 1 / span 2;
    grid-row: 1;
  }
  .overview-gourmet__img {
    grid-column: 1 / span 1;
    grid-row: 2/  2;
    height: auto;
    max-width: 132px;
    margin-top: 8px;
  }
  .overview-gourmet__text {
    grid-column: 2 / 3;
    grid-row: 2;
    margin-left: 16px;
    margin-top: 8px;
  }
  .page-overview__gourmet {
    flex-direction: column;
    align-items: center;
    gap: 24px;
  }
  .page-overview__flight {
    width: auto;
    display: flex;
    overflow-x: scroll;
    padding: 5px calc(( 20 / 375) * 100%);
  }
  .overview-flight__card {
    width: calc(( 320 / 364) * 100%);
    flex-shrink: 0;
  }
}

/* hotel移植 */

.gift-section{
  margin-top: 24px;
}
.hotel-section__title {
  font-size: 24px;
  font-family: 'Shippori Mincho', serif;
  text-align: center;
  padding: 30px 0;
  position: relative;
}

.hotel-section__title::before,
.hotel-section__title::after {
  content: '';
  background-color: #54B0E3;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-position: top 0 center;
  -webkit-mask-position: top 0 center;
  mask-size: contain;
  -webkit-mask-size: contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.hotel-section__title::before {
  width: 280px;
  height: 40px;
  mask-image: url("../images/hotel/bg_title_hotel_top.svg");
  -webkit-mask-image: url("../images/hotel/bg_title_hotel_top.svg");
  top: 0;
}
.hotel-section__title::after {
  width: 282px;
  height: 20px;
  mask-image: url("../images/hotel/bg_title_hotel_bottom.svg");
  -webkit-mask-image: url("../images/hotel/bg_title_hotel_bottom.svg");
  bottom: 0;
}

.gift-section__subtitle {
  font-size: 20px;
  font-weight: bold;
  display: block;
  margin-bottom: 4px;
}


@media only screen and (min-width: 768px) {
  .hotel-section__tab li {
    cursor: pointer;
  }
}
.hotel-section__content-wrap {
}
.hotel-section__data-img {
  margin-bottom: 8px;
}
.hotel-section__data-img img {
  width: 100%;
}
.hotel-section__data .section__subtitle {
  text-align: left;
  margin-bottom: 4px;
}


.hotel-section__data-desc {
  padding: 16px;
  background-color: #e7f3fa;
}
@media only screen and (min-width: 768px) {
  .hotel-section__data {
    display: flex;
    padding: 24px;
    background-color: #e7f3fa;
    position: relative;
  }
  .hotel-section__data .tag-ribbon {
    flex-direction: column;
  }
  .hotel-section__data .tag-ribbon small {
    font-size: 10px;
    transform: scale(0.8);
    line-height: 1.3;
  }
  .hotel-section__data .section__subtitle {
    padding-right: 126px;
  }  
  .hotel-section__data-img {
    flex-shrink: 0;
    width: 335px;
    margin-right: 24px;
    margin-bottom: 0;
  }
  .hotel-section__data-desc {
    padding: 0;
  }
}

@media only screen and (min-width: 768px) {
  .hotel-section__content {
    display: flex;
    justify-content: space-between;
  }
}
.hotel-section__heading {
  text-align: center;
}
.hotel-section__heading span {
  font-size: 16px;
  font-weight: bold;
  position: relative;
}
.hotel-section__heading span::before,
.hotel-section__heading span::after {
  content: "";
  display: block;
  width: 1px;
  height: 20px;
  background-color: #9F7442;
  position: absolute;
  top: 5px;
}
.hotel-section__heading span::before {
  left: -20px;
  transform: rotate(-30deg);
}
.hotel-section__heading span::after {
  right: -20px;
  transform: rotate(30deg);
}


/* venue-campaign
-------------------------*/
.venue-campaign {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 32px;
}

.venue-campaign__item {
  width: calc((100% - 16px) / 2);
  color: #333;
  background-image: url('../images/malamaweek/bg_dark.jpg');
  background-position: top;
  background-size: cover;
  text-align: center;
  position: relative;
  z-index: 1;
}
.venue-campaign__item--full {
  width: 100%;
}
.venue-campaign__item::before {
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  background-color: #e7f3fa;
  opacity: .9;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.venue-campaign__item--image {
  height: 173px;
}
.venue-campaign__item--image .gift-section__subtitle {
  margin-top: 24px;
  margin-bottom: 8px;
}
.venue-campaign__item--image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: -1;
}

.venue-campaign__heading {
  font-weight: bold;
}
.venue-campaign__text {
  font-size: 0.875rem;
  margin-top: 8px;
}




@media not all and (min-width: 769px) {
  .venue-campaign__item {
    padding: 24px 8px;
  }
  .venue-campaign__item--full {
    padding: 24px 20px;
  }
  .venue-campaign__item--image {
    padding: 16px 0;
    height: auto;
  }
  .venue-campaign__item--image .section__text-bold {
    font-size: 12px;
  }
  .venue-campaign__item--image .gift-section__subtitle {
    font-size: 18px;
  }
  .venue-campaign__heading {
    font-size: 1rem;
  }
}
@media screen and (min-width: 769px) {
  .venue-campaign__item {
    padding: 24px;
  }
  .venue-campaign__heading {
    font-size: 1.25rem;
  }
}



.sheet-about {
  background-color: #54B0E3;
  padding-bottom: 120px;
  margin-top:32px;
}
.sheet-overview__item {
  text-align: center;
}
.sheet-about__container {
  max-width: 1036px;
  padding: 32px 20px;
  margin-right: auto;
  margin-left: auto;
}
.sheet-flight {
  margin-top: 16px;
}
.sheet-type {
  display: flex;
  justify-content: space-between;
  align-items: center;
  align-items:normal;
  gap: 24px;
  margin: 24px auto 40px;
}
.sheet-type__card {
  background-color: #ffffff;
  padding-bottom: 24px;
  width: 33%;
  display: flex;
  flex-direction: column;
}
.sheet-type__desc {
  padding: 24px;
}
.sheet-type__img {
  align-self: center;
}
.sheet-type__heading {
  font-size: 16px;
  font-weight: bold;
}
.sheet-type__list {
  margin-top: 24px;
}
.sheet-type__li {
  font-size: 16px;
}
.sheet-type__tags {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 24px;
}
.sheet-type__tag {
  color: #fff;
  padding: 2px 8px;
  border-radius: 4px;
}
.sheet-type__tag.tag-blue {
  background-color: #193282;
}
.sheet-type__tag.tag-green {
  background-color: #007336;
}
.sheet-type__link {
  padding: 0 24px;
  margin-top:auto;
}
.sheet-type__link .btn-sheet-type {
  font-size: 16px;
  text-decoration: none;
  color: #333333;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 44px;
  border: 1px solid #333333;
  border-radius: 100px;
}


@media not all and (min-width: 769px) {
  .sheet-type {
    flex-direction: column;
  }
  .sheet-type__card {
    width: 100%;
  }
  .sheet-type__img {
    width: 100%;
  }
  .sheet-type__img img {
    width: 100%;
  }
}

.sheet-services {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 24px;
}
.sheet-services__card {
  display: flex;
  justify-content: flex-start;
  background-color: #ffffff;
  padding: 20px 20px 28px;
  max-width: 488px;
  min-height: 209px; 
}
.sheet-services__img {
  width: 178px;
  height: auto;
  flex: 0 0 auto;
}
.sheet-services__desc {
  margin-left: 16px;
}
.sheet-services__heading {
  font-size: 16px;
  font-weight: bold;
  text-indent: -26px;
  padding-left: 26px;
}
.sheet-services__text {
  font-size: 14px;
  margin-top: 12px;
}

@media not all and (min-width: 769px) {
  .sheet-services {
    flex-direction: column;
  }
  .sheet-services__img {
    width: 41.34%;
    height: auto;
  }
}

.sheet-lounge {
  margin-top: 80px;
}
.sheet-lounge__heading {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
.sheet-lounge__text {
  margin-top: 24px;
  font-size: 16px;
  text-align: center;
}
.sheet-lounge__desc {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 24px;
  margin-top: 16px;
}
.sheet-lounge__card {
  max-width: 484px;
}

.wcpn_bnr{
  margin-top:80px;
  text-align: center;
}

.wcpn_bnr img{
  display: block;
  margin:0 auto;
  width: 100%;
  max-width: 960px !important;
}
