@charset "UTF-8";

/*! destyle.css v3.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */

/* Reset box-model and set borders */

/* ============================================ */

*,
::before,
::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-width: 0;
  border-style: solid;
}

/* Document */

/* ============================================ */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */

html {
  line-height: 1.15;
  /* 2 */
  -webkit-tap-highlight-color: transparent;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 3*/
}

/* Sections */

/* ============================================ */

/**
 * Remove the margin in all browsers.
 */

body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main {
  display: block;
}

/* Vertical rhythm */

/* ============================================ */

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */

/* ============================================ */

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
}

/* Lists (enumeration) */

/* ============================================ */

ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}


/* ============================================ */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  /* 1 */
  overflow: visible;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  clear: both;
  /* 1 */
  height: 0;
  margin: 0;
  /* 2 */
  border-top-width: 1px;
  color: inherit;
}


/* ============================================ */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
  background-color: transparent;
  color: inherit;
  text-decoration: none;
}


/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: inherit;
  /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/* ============================================ */

/**
 * Prevent vertical alignment issues.
 */

svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* ============================================ */

/**
1. Correct table border color inheritance in all Chrome and Safari.
*/

/*
 * リセットCSS
 */

html {
  height: 100%;
}

body {
  position: relative;
  color: #333;
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-style: normal;
  line-height: 1.5;
  letter-spacing: .1em;
}

body.is-active {
  overflow: hidden;
}

img {
  max-width: 100%;
  width: 100%;
  height: auto;
}

/*
 * トップページ
 */

/* :root {
  --black: #333;
  --brown: #e7bf92;
  --dark-brown: #574f48;
  --green-grad-90: linear-gradient(90deg,rgba(0, 77, 41, 1) 0%, rgba(49, 175, 83, 1) 45%, rgba(0, 77, 41, 1) 100%);
  --main-grad-180: linear-gradient(180deg,rgba(198, 166, 49, 1) 0%, rgba(245, 232, 187, 1) 45%, rgba(199, 149, 40, 1) 100%);
  --main-grad-90: linear-gradient(90deg, rgba(198, 166, 49, 1) 0%, rgba(245, 232, 187, 1) 45%, rgba(199, 149, 40, 1) 100%);
  --red: #c93939;
  --red-grad-90: linear-gradient(90deg,rgba(142, 26, 26, 1) 0%, rgba(201, 50, 50, 1) 45%, rgba(142, 26, 26, 1) 100%);
  --sp-w: 94.666%;
} */


.loading {
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: #fff;
}

.mv {
  background-image: url(../img/bg_mv.png);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  padding: 5% 0 10%;
}

/* 
.mv::before {
  position: absolute;
  width: 100%;
  background-image: url("../img/mv_christmas_leasing.png");
  background-repeat: repeat-x;
  background-position: center;
  content: "";
} */

.mv__head {
  max-width: 1604px;
  margin: auto;
}

.mv__body {
  margin: auto;
  max-width: 1394px;
  width: 72.604%;
}

.mv-plan-list {
  margin-top: 4.8%;
  margin-right: -.71%;
  margin-left: -.71%;
}

.mv-plan-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

.mv-plan-list li {
  overflow: hidden;
  border-radius: 5px;
}

.mv-plan-list__item {
  display: block;
}

.mv-plan-list li {
  margin-right: .71%;
  margin-left: .71%;
}

.mv-plan-list__item {
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}

.mv-plan-list__item:hover {
  opacity: .7;
}

.mv_txt {
  width: 500px;
  padding: 16px 0;
  font-size: 16px;
  color: #fff;
  backdrop-filter: blur(5px);
  border: #fff 1px solid;
  text-align: center;
  margin: auto;
  margin-top: 3%;
}

.mv_txt p {
  text-align: center;
  margin: auto;
}

@media screen and (max-width: 767px) {
  .mv {
  background-image: url(../img/bg_mv_sp.png);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  padding: 8% 0 10%;
  }
.mv__head{
    width: 90%;
    filter: drop-shadow(0px 0px 5px #000);
}

.mv_txt {
  width: 336px;
  padding: 12px 0;
  font-size: 16px;
  margin-top: 3%;
}

  .mv-plan-list {
    /* margin-right: 2%;
    margin-left: 2%; */
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .mv-plan-list li {
    margin-top: 1.4%;
    margin-right: 0.5%;
    margin-left: 0.5%;
    -ms-flex-preferred-size: 48.6%;
    flex-basis: 48.6%;
  }

}

/*/////////////////////////// クルーズ詳細 ///////////////////////////*/

/* 共通 */

.section {
  background-repeat: no-repeat, no-repeat, repeat-x;
  background-position: left center, right center, center top;
  background-size: contain, contain, 100.5% auto;
  position: relative;
  z-index: 1;
}

.section-inner {
  max-width: 1200px;
  text-align: center;
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 1250px) {
  .section-inner {
    width: 90%;
  }
}

.section h2 {
  width: 65%;
  text-align: center;
  margin: auto;
}

.btn-reservation {
  display: inline-block;
  margin-top: 30px;
  width: 510px;
}

@media screen and (max-width: 1250px) {
  .btn-reservation {
    width: 95%;
  }
}

.btn-reservation__content:hover {
  opacity: .7;
}

/* スライダー */
.plan-col__slider {
  display: none;
  position: relative;
  z-index: 1;
}

.plan-col__slider.slick-initialized {
  display: block;
}

.plan-col__slider .slick-dots li {
  margin: 0;
}

.plan-col__slider .slick-dots li button:before {
  opacity: 1;
  color: #d0d0d0;
}

.plan-col__slider .slick-dots li.slick-active button:before {
  opacity: 1;
  color: #e7bf92;
}

.plan-col__slider::before {
  color: #fff;
  position: absolute;
  right: 0;
  bottom: -2em;
  font-size: clamp(.625rem, .581rem + .19vw, .75rem);
  content: "※イメージ";
}

.plan-col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: space-between;
}

.plan-col__item {
  max-width: 43.965%;
  -ms-flex-preferred-size: 43.965%;
  flex-basis: 43.965%;
}

.plan-col__item.is-left {
  margin-right: 3.0175%;
}

.plan-col__item.is-right {
  margin-left: 3.0175%;
}

.plan-col__item-head {
  margin-top: 13.5%;
}

.plan-col__item-body {
  margin-top: 40px;
}

.plan-col__slider .slick-dots li button:before {
  font-size: 10px;
}

.plan-col__btn {
  margin-top: 35px;
}

.plan {
  padding-top: 5.8%;
}

.hr {
  padding-top: 5.8%;
}

.sp-item {
  display: none;
}

@media screen and (max-width: 1250px) {
  .plan-col__item.is-left {
    margin-right: 0;
  }

  .plan-col__item.is-right {
    margin-left: 0;
  }

  .plan-col__item {
    max-width: 48%;
  }
}

@media screen and (max-width: 767px) {
  .pc-item {
    display: none;
  }

  .sp-item {
    display: block;
  }

  .section h2 {
    width: 100%;
  }

  .plan {
    padding-top: 15%;
  }

  .plan-col__item {
    margin-top: 0;
    max-width: 100%;
    text-align: center;
    margin: auto;
  }

  .plan-col__item-head {
    margin-top: 8.5%;
  }

  .btn-reservation {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {

}

/* 共通ここまで */
/* クルーズ１ */
.cruise1 {
  padding: 8% 0;
  background-image: url("../img/bg_cruise1.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}

.cruise1 h3 {
  width: 278px;
  text-align: center;
  margin: auto;
}

.cruise1_1-2 {
  background-image: url("../img/bg_cruise1_2.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  margin-top: 50px;
  padding: 0 5.1% 6.7%;
}

@media screen and (max-width: 1250px) {
  .cruise1_1-2 {
    padding: 0px 4.1% 3.8%;
    height: 40.4vw;
  }
}

.cruise1_2 h3 {
  width: 434px;
}

.cruise1_1-2 .plan-col__slider::before {
  color: #333333;
}

.cruise1_1-2 .plan-col__slider .slick-dots li.slick-active button:before {
  color: #004488;
  opacity: 0;
}

.plan2 .plan-col {
  flex-direction: row-reverse;
}

.plan2 .plan-col__item.is-left {
  margin-right: 0;
  margin-left: 3.0175%;
}

.plan2 .plan-col__item.is-right {
  margin-left: 0;
  margin-right: 3.0175%;
}

.plan2 .plan-col {
  justify-content: center;
}

.cruise1_1-2 h3 {
  width: 434px;
}

@media screen and (max-width: 767px) {
  .cruise1 {
    padding: 19% 0;
    background-image: url("../img/bg_cruise1_sp.png");
  }

  .cruise1 h3 {
    width: 60%;
  }

  .cruise1_2 h3 {
    width: 100%;
  }

  .plan-col {
    display: block;
  }

  .cruise1_1-2 {
    background-image: url("../img/bg_cruise1_2_sp.png");
    padding: 7.5% 8% 21.4%;
    margin-top: 50px;
    margin-bottom: 15%;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    height: 158.8vw;
  }

  .plan2 .plan-col .plan-col__item.is-left {
    margin-left: 0;
  }

  .plan2 .plan-col .plan-col__item.is-right {
    margin-right: 0;
  }
}

/* クルーズ２ */
.cruise2 {
  padding: 8% 0;
  background-image: url("../img/bg_cruise2.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}

.cruise2 h3 {
  width: 680px;
  text-align: center;
  margin: auto;
}

.cruise2_1 .plan-col {
  position: relative;
}


.cruise2_1 .gentei {
  position: absolute;
  left: -5%;
  top: 0;
}

.cruise2_1-2 {
  background-image: url("../img/bg_cruise2_2.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  margin-top: 70px;
  padding: 0 5.1% 7%;
}

.cruise2_1-2 .plan-col {
  flex-direction: row-reverse;
}

.cruise2_1-2 .plan-col__item.is-left {
  margin-right: 0;
  margin-left: 3.0175%;
}

.cruise2_1-2 .plan-col__item.is-right {
  margin-left: 0;
  margin-right: 3.0175%;
}

.cruise2_1-2 .plan-col {
  justify-content: center;
}

.cruise2 .plan-col__slider::before {
  color: #333333;
}

.cruise2 .plan .plan-col__slider .slick-dots li button:before {
  color: #fff;
}

.cruise2 .plan-col__slider .slick-dots li.slick-active button:before {
  color: #DB2504;
}
.cruise2 .plan-col__slider.__heroica .slick-dots li.slick-active button:before {
  color: #DB2504;
  opacity: 0;
}

.cruise2_2 h3 {
  width: 434px;
}

@media screen and (max-width: 1250px) {
  .cruise2_1-2 {
    width: 100%;
    height: 40.7vw;
  }
}

@media screen and (max-width: 767px) {
  .cruise2 {
    padding: 19% 0;
    background-image: url("../img/bg_cruise2_sp.png");
  }

  .cruise2_1-2 {
    background-image: url("../img/bg_cruise2_2_sp.png");
    padding: 4.5% 6% 19.4%;
    margin-top: 50px;
    margin-bottom: 15%;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    height: 168.7vw;
  }

  .cruise2 h3 {
    width: 100%;
  }

  .cruise2_1-2 .plan-col__item-head {
    margin-top: 14%;
  }

  .cruise2_1 .gentei {
    width: 100px;
    left: -5%;
    top: -5%;
  }
}


/* クルーズ 3 */
.cruise3 {
  padding: 8% 0;
  background-image: url("../img/bg_cruise3.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}

.cruise3 h2 {
  width: 90%;
}

.cruise3 h3 {
  width: 80%;
  text-align: center;
  margin: auto;
}

.cruise3_1 {
  position: relative;
}

.cruise3 .kendama {
  position: absolute;
  width: 150px;
  top: 5%;
  left: -3%;
}

.cruise3 .plan-col__slider::before {
  color: #333333;
}

.cruise3 .plan .plan-col__slider .slick-dots li button:before {
  color: #AFAFAF;
}

.cruise3 .plan-col__slider .slick-dots li.slick-active button:before {
  color: #0491DB;
}

.cruise3_2 .plan-col {
  flex-direction: row-reverse;
}

.cruise3_2 .plan-col__item.is-left {
  margin-right: 0;
  margin-left: 3.0175%;
}

.cruise3_2.plan-col__item.is-right {
  margin-left: 0;
  margin-right: 3.0175%;
}

.cruise3 .btn-reservation {
  text-align: center;
  margin: 30px auto 6%;
}

@media screen and (max-width: 1250px) {
  .cruise3 .btn-reservation {
    width: 50%;
  }
}

.cruise3 .section-inner {
  position: relative;
  padding-bottom: 5%;
}

.cruise3 .gasho {
  position: absolute;
  width: 200px;
  left: 0;
  bottom: 0;
}

@media screen and (max-width: 767px) {
  .cruise3 {
    padding: 19% 0;
    background-image: url("../img/bg_cruise3_sp.png");
  }

  .cruise3 h2 {
    width: 100%;
  }

  .cruise3 h3 {
    width: 100%;
  }

  .cruise3 .section-inner {
    padding-bottom: 30%;
  }

  .cruise3 .gasho {
    width: 40%;
    left: 0;
    bottom: 0;
  }

  .cruise3 .btn-reservation {
    width: 95%;
  }
}

/* クルーズ 4 */
.cruise4 {
  padding: 8% 0;
  background-image: url("../img/bg_cruise4.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}

.cruise4 .section-inner {
  max-width: 1372px;
}

.cruise4_cont {
  position: relative;
}

.cruise4 h2 {
  width: 100%;

}

.cruise4_1 .plan-col {
  position: absolute;
  bottom: 5%;
  left: 0;
  right: 0;
  width: 73%;
  text-align: center;
  margin: auto;
}

.cruise4_1 .plan-col__item-head {
  margin: 0;
}

.cruise4_1 .plan-col__item.is-right {
  max-width: 36% !important;
  margin: 0;
}

.cruise4_1 .plan-col__item.is-left {
  max-width: 53% !important;
  margin: 0;
}

.cruise4 .btn-reservation {
  width: 50%;
  text-align: center;
  margin: 2.5% auto;
}

.cruise4 .plan-col__slider::before {
  color: #333333;
}

.cruise4 .plan-col__slider .slick-dots li.slick-active button:before {
  color: #DB2504;
}

@media screen and (max-width: 1400px) {
  .cruise4 .section-inner {
    width: 95%;
  }
}

@media screen and (max-width: 767px) {
  .cruise4_1 .plan-col {
    bottom: 5%;
    left: 0;
    right: 0;
    width: 89%;
    text-align: center;
    margin: auto;
  }

  .cruise4_1 .plan-col__item.is-right {
    max-width: 100% !important;
    margin: 0;
  }

  .cruise4_1 .plan-col__item.is-left {
    max-width: 100% !important;
    margin: 0 0 3%;
  }

  .cruise4 .btn-reservation {
    width: 100%;
    text-align: center;
    margin: 6% auto;
  }
}


footer {
  background: linear-gradient(to right, #382600, #835A02);
  color: #fff;
  text-align: center;
  margin: auto;
  padding: 23px 0;
  font-size: 22px;
}

@media screen and (max-width: 767px) {
  footer {
    font-size: 12px;
  }
}