/* 共通（scroll-behavior は付けない：ポインター離脱時にもスクロールが続くのを防ぐ） */
:root {
  --font-family-oswald: "Oswald", "Arial Narrow", "Impact", sans-serif;
  --font-family-noto: "Noto Sans", "Arial Narrow", "Impact", sans-serif;
  --font-family-noto-sans-cjk-jp: "Noto Sans CJK JP", "Noto Sans JP", sans-serif;
  --font-family-roboto-condensed: "Roboto Condensed", sans-serif;
  --color-primary: #E6006D;
  --color-blue: #122341;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
html,
body {
  overflow-x: hidden;
}
body {
  font-family: "Noto Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 16px;
  line-height: 1.5;
  font-weight: normal;
  color: #000;
  background-color: #FFF;
}
.sp_only ,.sp_only_inline{
  display: none!important;
}
.pc_only_flex{
  display: flex!important;
}
.pc_only {
  display: block!important;
}
.pc_only_inline {
  display: inline-block!important;
}
@media screen and (max-width: 767px) {
  .sp_only {
    display: block!important;
  }
  .sp_only_inline{
    display: inline-block!important;
  }
  .pc_only ,.pc_only_flex,.pc_only_inline{
    display: none!important;
  }
}
/* SP: ナビを最初から非表示にし更新時の一瞬表示を防ぐ */
@media (max-width: 750px) {
  #header .header_nav_wrap {
    visibility: hidden !important;
    transform: translateX(-100%);
    pointer-events: none;
  }
  #header.is_menu_open .header_nav_wrap {
    visibility: visible !important;
    pointer-events: auto;
  }
}

#container select:focus {
  border-color: var(--color-primary);
  outline: none; /* デフォルトの青枠消す */
}

#container{
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0;
  font-size: min(16px, 1.0416666666666667vw);
}
#container img {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
  vertical-align: bottom;
}
#container a ,#container .btn{
  opacity: 1;
  transition: opacity 0.4s ease-in-out;
  text-decoration: none;
  color: #000;
}
#container a:hover,#container .btn:hover {
  opacity: 0.7;
}
#wrapper .font_roboto_condensed {
  font-family: var(--font-family-roboto-condensed);
}
#wrapper section {
  padding: min(60px, 4.166666666666667vw) 0;
}
#wrapper .font_primary {
  color: var(--color-primary);
}
#wrapper h2 {
  font-family: var(--font-family-oswald);
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
}
#wrapper p {
  font-weight: 400;
}
#container .btn_wrap,#container .label {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-primary);
  border-radius: min(4px, 0.2777777777777778vw);
}
#container .sup_text,
#wrapper .sup_text {
  font-size: 0.6em!important;
  display: inline-block;
  vertical-align: text-top;
  position: relative;
  top: 0.28em;
}
#wrapper .sup_text02 {
  font-size: 0.6em!important;
  display: inline-block;
  vertical-align: text-top;
  position: relative;
  top: 0.1em;
}
#wrapper .sup_text03 {
  font-size: 0.6em;
  display: inline-block;
  vertical-align: text-bottom;
  position: relative;
  right: 1em;
  bottom: -1em;
}
#container .btn_wrap a {
  display: block;
  color: #fff;
  text-decoration: none;
}
@media (max-width: 750px) {
  #wrapper section{
    padding: min(60px, 8vw) 0;
  }
}

/* ========== Header ========== */
#header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  padding: min(7px, 0.4861111111111111vw) 0;
  background-color: #fff;
  z-index: 100;
  overflow-x: hidden;
}
#header .header_inner {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-inline: auto;
  padding-inline: min(27px, 1.875vw);
  max-width: 1440px;
}
#header .header_nav_wrap {
  display: flex;
  align-items: center;
  margin-left: auto;
  flex-shrink: 1;
}
#header nav {
  flex-shrink: 1;
}
#header nav .header_nav {
  display: flex;
  align-items: center;
  gap: min(30px, 2.0833333333333335vw);
  padding-right: min(60px, 4.166666666666667vw);
}
#header nav .header_nav li a {
  padding: min(10px, 0.7291666666666667vw);
  transition: opacity 0.4s ease-in-out, border-color 0.4s ease-in-out;
  border-bottom: 1px solid transparent;
}
#header nav .header_nav li a:hover {
  border-bottom-color: #000;
}
#header .header_logo {
  width: min(251px,17.430555555555554vw);
}

#header .header_btn {
  width: min(100px, 7.291666666666667vw);
  height: min(34px, 2.3958333333333335vw);
}
#header .header_hamburger {
  display: none;
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  margin-right: min(12px, 1vw);
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  position: relative;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s ease;
}
#header .header_hamburger:hover {
  opacity: 0.8;
}
#header .header_hamburger_line {
  position: absolute;
  left: 50%;
  margin-left: -12px;
  width: min(50px,6.666666666666667vw);
  height: 2px;
  background-color: #000;
  border-radius: 1px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
#header .header_hamburger_line:nth-child(1) { top: 13px; }
#header .header_hamburger_line:nth-child(2) { top: 21px; }
#header .header_hamburger_line:nth-child(3) { top: 29px; }
#header .header_hamburger[aria-expanded="true"] .header_hamburger_line:nth-child(1) {
  top: 21px;
  transform: rotate(45deg);
}
#header .header_hamburger[aria-expanded="true"] .header_hamburger_line:nth-child(2) {
  opacity: 0;
}
#header .header_hamburger[aria-expanded="true"] .header_hamburger_line:nth-child(3) {
  top: 21px;
  transform: rotate(-45deg);
}
#header .header_btn a {
  display: block;
  color: #fff;
  text-decoration: none;
  font-weight: 500;
}

@media (max-width: 750px) {
  #header {
    height: min(90px, 12vw);
    padding: 0;
    display: flex;
    align-items: center;
  }
  #header .header_inner {
    width: 100%;
    padding-inline: min(16px, 4vw);
    position: relative;
  }
  #header .header_hamburger {
    display: flex;
  }
  #header .header_logo {
    width: min(484px, 64.53333333333333vw);
    flex: 1;
    justify-content: center;
    display: flex;
  }
  #header .header_logo a {
    margin: 0 auto;
  }
  #header .header_nav_wrap {
    position: fixed;
    top: min(90px, 12vw);
    left: 0;
    width: 100%;
    max-width: min(654px, 87.2vw);
    height: calc(100vh - min(80px, 10.666666666666666vw));
    background: #fff;
    padding: min(24px, 3.2vw) 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    z-index: 99;
    transform: translateX(-100%);
    transition: transform 0.3s ease, visibility 0s linear 0.3s;
    overflow-y: auto;
    visibility: hidden;
  }
  #header nav {
    margin-left: 0;
  }
  #header nav .header_nav {
    flex-direction: column;
    gap: 0;
    padding-right: 0;
    align-items: stretch;
  }
  #header nav .header_nav li a {
    display: block;
    padding: min(14px, 1.8666666666666667vw) min(24px, 3.2vw);
    border-left: 3px solid transparent;
    color: #000;
    font-size: min(30px, 4vw);
    border-bottom: 2px solid #C1BDBD;
    position: relative;
  }
  #header nav .header_nav li a::after{
    content: '';
    position: absolute;
    right: min(28px, 3.733333333333333vw);
    top: 50%;
    width: min(20px,2.6666666666666665vw);
    height: min(20px,2.6666666666666665vw);
    border-top: 2px solid #000;
    border-right: 2px solid #000;
    transform: translateY(-50%) rotate(45deg);
    pointer-events: none;
  }
  #header nav .header_nav li a:hover {
    border-left-color: #000;
    background: #f5f5f5;
  }
  #header .header_btn {
    width: min(156px,20.8vw);
    height: min(56px,7.466666666666668vw);
    flex-shrink: 0;
    margin-left: auto;
    font-size: min(26px,3.4666666666666663vw);
    border-radius: min(4px, 0.5333333333333333vw);
  }
  #header.is_menu_open .header_nav_wrap {
    visibility: visible !important;
    transform: translateX(0);
    transition: transform 0.3s ease;
  }
  body.has_header_overlay::after {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 98;
    top: min(90px, 12vw);
  }
}

/* ========== Main ========== */
#wrapper {
  margin-top: min(54px, 3.75vw);
  padding: 0;
}
#wrapper .sec_inner, #wrapper .sec_inner_02 {
  width: min(1000px, 70.3125vw);
  margin-inline: auto;
}
#wrapper .flex ,#wrapper .pc_only_flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 750px) {
  #wrapper .sec_inner{
    width: min(645px, 86vw);
  }
  #wrapper .sec_inner_02{
    width: min(660px, 88vw);
    margin-inline: auto;
  }
  #wrapper {
    margin-top: 0;
    overflow-x: hidden;
  }
}

/* ========== FV ========== */
#wrapper .fv {
  position: relative;
  width: 100%;
  max-width: 1440px;
  height: min(644px, 44.72222222222222vw);
  overflow: hidden;
}
#wrapper .fv_poster {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  z-index: 0;
}
#wrapper .fv_video {
  position: absolute;
  top: 0;
  left: 50%;
  width: auto;
  height: auto;
  min-width: 100%;
  transform: translateX(-50%);
  object-fit: contain;
  object-position: top center;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.5s ease-out;
}
#wrapper .fv_video.is_loaded {
  opacity: 1;
}
#wrapper .fv_bg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: min(350px, 24.30555vw);
  z-index: 2;
  background: linear-gradient(to top, #1A4388 0%, #1A4388 55%, transparent 100%);
}
#wrapper .fv_inner {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(532px, 37.39583333333333vw);
  margin-bottom: min(25px, 1.7361111111111112vw);
  z-index: 3;
  color: #fff;
  text-align: center;
  letter-spacing: 0.05em;
  white-space: nowrap;
}
#wrapper .fv_inner .fv_title_sub {
  font-size: min(18px, 1.25vw);
  font-weight: 500;
  text-align: center;
  line-height: 1.35;
  letter-spacing: 0em;
}
#wrapper .fv_inner .fv_title {
  font-family: var(--font-family-oswald);
  font-size: min(78px, 5.520833333333333vw);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.03em;
}
#wrapper .fv_inner .fv_title span{
  color: #ED2483;
}
#wrapper .fv_inner .fv_text_1 {
  font-size: min(20px, 1.4583333333333333vw);
  line-height: 1.8;
  font-weight: 400;
}
#wrapper .fv_inner .fv_text_2 {
  font-size: min(22px, 1.5625vw);
  line-height: 1.8;
  font-weight: 600;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}
#wrapper .fv_inner .fv_text_2 span {
  margin-inline: 1em;
}
#wrapper .fv_inner .fv_text_3 {
  font-size: min(12.8px, 0.90625vw);
  line-height: 1.65;
  letter-spacing: 0.1em;
  padding: min(20px, 1.4583333333333333vw) 0;
}
@media (max-width: 750px) {
  #wrapper .fv {
    margin-top: min(90px, 12vw); /* 固定ヘッダー分の余白 */
    height: min(620px, 82.66666666666667vw);
  }
  #wrapper .fv_video{
    width: 100%;
    height: min(450px, 60vw);
    object-position: top center;
  }
  #wrapper .fv_inner {
    width: 72.1333333333333%;
    margin-bottom: min(40px, 5.333333333333333vw);
  }
  #wrapper .fv_inner .fv_title_sub {
    font-size: min(32px, 4.266666666666667vw);
  }
  #wrapper .fv_inner .fv_title {
    font-size: min(83px, 11.066666666666666vw);
  }
  #wrapper .fv_inner .fv_text_1{
    font-size: min(20px, 2.666666666666667vw);
  }
  #wrapper .fv_inner .fv_text_2{
    font-size: min(22px, 2.933333333333333vw);
  }
  #wrapper .fv_inner .fv_text_3{
    padding-bottom: 0;
    font-size: min(15.7px, 2.093333333333333vw);
    letter-spacing: 0;
  }
  #wrapper .fv_bg{
    height: min(395px, 52.666666666666664vw);
    background: linear-gradient(to top, #1A4388 0%, #1A4388 45%, transparent 100%);
  }
}

/* ========== Section01 ========== */
#wrapper #intro .flex{
  justify-content: space-between;
  align-items: flex-start;
}
#wrapper #intro .intro_item_top{
  margin-bottom: min(16px, 1.1111111111111112vw);
}
#wrapper #intro h2 {
  margin-bottom: min(15px, 1.0416666666666667vw);
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
}
#wrapper #intro .intro_item_left {
  margin-top: min(26px, 1.8055555555555556vw);
  line-height: 1.6;
}
#wrapper #intro .intro_item_left p{
  font-size: min(20px, 1.4583333333333333vw);
  line-height: 1.6;
  letter-spacing: 0;
}
#wrapper #intro .intro_item_right {
  width: min(296px, 20.55555vw);
  text-align: center;
}
#wrapper #intro .intro_item_right p{
  font-size: min(12.8px, 0.90625vw);
  line-height: 1.3;
}
#wrapper #intro .intro_item_icon img{
  width: min(158px, 10.9375vw);
  margin-inline: auto;
}
#wrapper #intro .intro_item_02 {
  gap: min(50px, 3.472222222222222vw);
}
#wrapper #intro .intro_item_02 > div > p{
  padding-top: min(16px, 1.1111111111111112vw);
  font-size: min(18px, 1.25vw);
  line-height: 1.5;
}
#wrapper #intro .intro_item_img{
  position: relative;
  text-align: center;
}
#wrapper #intro .intro_item_img img,
#wrapper #intro .intro_item_img video{
  width: min(300px, 20.833333333333332vw);
  height: auto;
  display: block;
  object-fit: cover;
}
#wrapper #intro .intro_item_img h3{
  position: absolute;
  bottom: 0;
  left: 0;
  align-items: center;
  width: min(300px, 20.833333333333332vw);
  height: min(51px, 3.611111111111111vw);
  margin: 0;
  font-family: var(--font-family-oswald);
  line-height: min(51px, 3.611111111111111vw);
  color: #fff;
  background-color: rgba(0, 0, 0, 0.5);
  font-size: min(24px, 1.6666666666666667vw);
  letter-spacing: 0.1em;
  font-weight: 400;
}
@media (max-width: 750px) {
  #wrapper #intro h2{
    font-size: min(50px, 6.666666666666667vw);
    line-height: 1.1;
    padding-bottom: 0.8em;
  }
  #wrapper #intro .intro_item_right{
    width: min(158px, 21.066666666666666vw);
    margin-top: min(9px, 1.2vw);
    margin-left: min(5px, 0.6666666666666666vw);
  }
  #wrapper #intro .intro_item_icon img{
    width: min(152px, 20.266666666666666vw);
  }
  #wrapper #intro .intro_item_right p{
    font-size: min(12.8px, 1.7066666666666667vw);
    padding-top: min(7px, 0.9333333333333333vw);
    line-height: 1.3;
  }
  #wrapper #intro .intro_item_left{
    margin-top: 0;
  }
  #wrapper #intro .intro_item_left p{
    font-size: min(28px, 3.733333333333333vw);
    line-height: 1.4;
  }
  #wrapper #intro .intro_item_02{
    flex-direction: column;
  }
  #wrapper #intro .intro_item_02 > div{
    display: flex;
  }
  #wrapper #intro .intro_item_img img, #wrapper #intro .intro_item_img video{
    width: min(300px, 40vw);
  }
  #wrapper #intro .intro_item_02 > div > p{
    font-size: min(24px, 3.2vw);
    padding-top: 1em;
    padding-left: min(20px, 2.666666666666667vw);
  }
  #wrapper #intro .intro_item_img h3{
    width: 100%;
    height: min(51px, 6.8vw);
    font-size: min(28px, 3.733333333333333vw);
    line-height: min(51px, 6.8vw);
    letter-spacing: 0.05em;
    font-weight: 400;
  }
  #wrapper #intro .intro_item_top{
    margin-bottom: min(52px, 6.933333333333333vw);
  }
}

/* ========== Section02 ========== */
#wrapper #attractions h2 {
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
}
#wrapper #attractions .flex{
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-bottom: min(24.5px, 1.7361111111111112vw);
}
#wrapper #attractions .attractions_header img{
  width: min(200px, 14.583333333333332vw);
}

#wrapper #attractions .attractions_cards_wrap{
  flex-wrap: wrap;
  gap: min(28px, 1.9444444444444444vw) min(38px, 2.638888888888889vw);
}
#wrapper #attractions .attractions_card{
  position: relative;
  flex: 0 0 calc(50% - min(19px, 1.3194444444444444vw));
  max-width: min(481px, 33.40277777777778vw);
  text-align: center;
  background-color: #122341;
}
#wrapper #attractions .attractions_card .attractions_card_label{
  position: absolute;
  top: min(18px, 1.25vw);
  left: min(22px, 1.5625vw);
  width: min(98px, 6.875vw);
  height: min(33px, 2.34375vw);
  background-color: var(--color-primary);
  color: #fff;
  font-family: var(--font-family-oswald);
  font-size: min(20px, 1.4583333333333333vw);
  line-height: min(33px, 2.34375vw);
  text-align: center;
  font-weight: 200;
  letter-spacing: 0.03em;
  border-radius: min(33px, 2.34375vw);
}
#wrapper #attractions .attractions_card .attractions_card_body{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
}
#wrapper #attractions .attractions_card h3{
  margin-bottom: 1.2em;
  font-family: var(--font-family-oswald);
  color: #fff;
  font-size: min(28px, 1.9444444444444444vw);
  line-height: 1.2;
  letter-spacing: 0.05em;
  font-weight: 300;
}
#wrapper #attractions .attractions_card h3 .font_italic{
  font-family: var(--font-family-roboto-condensed);
  font-style: italic;
  font-weight: 700;
}
#wrapper #attractions .attractions_card p{
  font-weight: 300;
  line-height: 1.95;
  letter-spacing: 0;;
  color: #fff;
}
#wrapper #attractions .attractions_note{
  font-size: min(14px, 1.0416666666666667vw);
}

@media (max-width: 750px) {
  #wrapper #attractions h2{
    font-size: min(50px, 6.666666666666667vw);
    line-height: 1.3;
    letter-spacing: 0.05em;
  }
  #wrapper #attractions .attractions_header img{
    width: min(202px, 26.93333333333333vw);
  }
  #wrapper #attractions .attractions_note{
    padding-top: min(42px, 5.6vw);
    padding-bottom: min(16px, 2.133333333333333vw);
    font-size: min(20px, 2.666666666666667vw);
    line-height: 1.3;
  }
  #wrapper #attractions .attractions_cards_wrap{
    flex-direction: column;
  }
  #wrapper #attractions .attractions_card{
    width: 100%;
    max-width: 100%;
  }
  #wrapper #attractions .attractions_card .attractions_card_label{
    top: min(12.3px, 1.64vw);
    left: min(21.8px, 2.906666666666667vw);
    width: min(119px, 15.866666666666666vw);
    height: min(36px, 4.8vw);
    font-size: min(26.4px, 3.52vw);
    line-height: min(36px, 4.8vw);
  }
  #wrapper #attractions .attractions_card h3{
    margin-bottom: min(51.5px, 6.866666666666667vw);
    font-size: min(44px, 5.866666666666667vw);
    line-height: 1.2;
    letter-spacing: 0.03em;
  }
  #wrapper #attractions .attractions_card p{
    font-size: min(24px, 3.2vw);
    line-height: 1.4;
  }
}

/* ========== Section03 ========== */
#wrapper #all_inclusive,
#wrapper #all_inclusive_02 {
  position: relative;
  background-color: #F8F6F4;
}
#wrapper #all_inclusive:before,
#wrapper #all_inclusive_02:before{
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: min(112.5px, 7.8125vw) solid transparent;
  border-right: min(112.5px, 7.8125vw) solid transparent;
  border-top: min(54px, 3.75vw) solid #F8F6F4;
  z-index: 1;
}
#wrapper #all_inclusive:after,
#wrapper #all_inclusive_02:after{
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #F8F6F4;
  z-index: -1;
}
#wrapper #all_inclusive h2,
#wrapper #all_inclusive_02 h2 {
  margin-bottom: min(30px, 2.0833333333333335vw);
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
  color: var(--color-blue);
}
#wrapper #all_inclusive .all_inclusive_cards_row,
#wrapper #all_inclusive_02 .all_inclusive_cards_row{
  justify-content: center;
  gap: min(10px, 0.7291666666666667vw);
  margin-bottom: min(36.66px, 2.5416666666666665vw);
}
#wrapper #all_inclusive .all_inclusive_card,
#wrapper #all_inclusive_02 .all_inclusive_card{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: min(5px, 0.3645833333333333vw);
  width: min(190px, 13.194444444444444vw);
  height: min(190px, 13.194444444444444vw);
  padding: min(18px, 1.25vw) min(12px, 0.8333333333333334vw);
  background-color: #fff;
  border-radius: min(20px, 1.4583333333333333vw);
  text-align: center;
}
#wrapper #all_inclusive .all_inclusive_cards_row img,
#wrapper #all_inclusive_02 .all_inclusive_cards_row img{
  width: min(162px, 11.388888888888889vw);
  height: min(96px, 6.875vw);
}
#wrapper #all_inclusive .all_inclusive_exclusive,
#wrapper #all_inclusive_02 .all_inclusive_exclusive{
  position: relative;
  width: min(868px, 60.55555555555556vw);
  margin: 0 auto;
  padding: min(20px, 1.4583333333333333vw);
  text-align: center;
  background-color: #FBEDF3;
  border-radius: min(20px, 1.4583333333333333vw);
}
#wrapper #all_inclusive .all_inclusive_exclusive:before,
#wrapper #all_inclusive_02 .all_inclusive_exclusive:before{
  content: '+';
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: min(-20px, -1.3888888888888888vw);
  left: 50%;
  transform: translateX(-50%);
  width: min(44px, 3.0555555555555554vw);
  height: min(44px, 3.0555555555555554vw);
  font-size: min(50px, 3.5714285714285716vw);
  font-weight: 300;
  line-height: 1;
  color: #fff;
  background-color: var(--color-primary);
  border-radius: 50%;
}
#wrapper #all_inclusive .all_inclusive_exclusive h3,
#wrapper #all_inclusive_02 .all_inclusive_exclusive h3{
  padding: min(25px, 1.7361111111111112vw) 0 min(20px, 1.4583333333333333vw);
  font-size: min(28px, 1.9444444444444444vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
}
#wrapper #all_inclusive .all_inclusive_exclusive .flex,
#wrapper #all_inclusive_02 .all_inclusive_exclusive .flex{
  justify-content: center;
  align-items: center;
  gap: min(16px, 1.1111111111111112vw);
}
#wrapper #all_inclusive .all_inclusive_card img,
#wrapper #all_inclusive_02 .all_inclusive_card img{
  width: min(134px, 9.375vw);
  height: min(78px, 5.416666666666667vw);
}
#wrapper #all_inclusive .all_inclusive_card h4,
#wrapper #all_inclusive_02 .all_inclusive_card h4{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: min(66px, 4.638888888888889vw);
  font-weight: 400;
}
#wrapper #all_inclusive .all_inclusive_note,
#wrapper #all_inclusive_02 .all_inclusive_note{
  width: min(868px, 60.55555555555556vw);
  margin: min(30px, 2.0833333333333335vw) auto 0;
  font-size: min(14px, 1.0416666666666667vw);
}

@media (max-width: 750px) {
  #wrapper #all_inclusive h2,
  #wrapper #all_inclusive_02 h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #all_inclusive .all_inclusive_cards_row, #wrapper #all_inclusive .all_inclusive_exclusive .all_inclusive_cards_row02,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row, #wrapper #all_inclusive_02 .all_inclusive_exclusive .all_inclusive_cards_row02{
    width: 100%;
    gap: min(8px, 1.0666666666666667vw);
  }
  #wrapper #all_inclusive .all_inclusive_cards_row,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row{
    margin-bottom: min(29.5px, 3.933333333333333vw);
  }
  #wrapper #all_inclusive .all_inclusive_card,
  #wrapper #all_inclusive_02 .all_inclusive_card{
    width: min(124px, 16.53333333333333vw);
    height: min(220px, 29.333333333333332vw);
    overflow: hidden;
  }
  #wrapper #all_inclusive .all_inclusive_cards_row .all_inclusive_card h4,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row .all_inclusive_card h4{
    margin-top: min(10px, 1.3333333333333333vw);
    line-height: 1.3;
  }
  #wrapper #all_inclusive .all_inclusive_cards_row .all_inclusive_card:nth-child(5) h4,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row .all_inclusive_card:nth-child(5) h4{
    display: block;
    text-align: center;
    height: auto;
    min-height: 3.5em;
    line-height: 1.3;
  }
  #wrapper #all_inclusive .all_inclusive_cards_row  .all_inclusive_card:nth-child(2) h4,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row  .all_inclusive_card:nth-child(2) h4{
    height: 4.5em;
  }
  #wrapper #all_inclusive .all_inclusive_exclusive .all_inclusive_card,
  #wrapper #all_inclusive_02 .all_inclusive_exclusive .all_inclusive_card{
    width: min(148px, 19.733333333333334vw);
    height: min(178px, 23.733333333333334vw);
  }
  #wrapper #all_inclusive .all_inclusive_exclusive,
  #wrapper #all_inclusive_02 .all_inclusive_exclusive{
    width: 100%;
    padding-bottom: min(20px, 2.6666666666666665vw);
  }
  #wrapper #all_inclusive .all_inclusive_card img,
  #wrapper #all_inclusive_02 .all_inclusive_card img{
    width: min(137.7px, 18.36vw);
    height: min(77.6px, 10.346666666666667vw);
  }
  #wrapper #all_inclusive .all_inclusive_cards_row02 .all_inclusive_card img,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row02 .all_inclusive_card img{
    width: min(135px, 18vw);
    height: auto;
    object-fit: contain;
  }
  #wrapper #all_inclusive .all_inclusive_card h4,
  #wrapper #all_inclusive_02 .all_inclusive_card h4{
    font-size: min(18px, 2.4vw);
    line-height: 1;
  }
  #wrapper #all_inclusive .all_inclusive_cards_row02 .all_inclusive_card h4,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row02 .all_inclusive_card h4{
    height: 3em;
    margin-top: min(13px, 1.7333333333333334vw);
    line-height: 1.3;
  }
  #wrapper #all_inclusive .all_inclusive_cards_row02 .all_inclusive_card:first-child h4,
  #wrapper #all_inclusive_02 .all_inclusive_cards_row02 .all_inclusive_card:first-child h4{
    margin-top: min(7px, 0.9333333333333333vw);
    height: 3.5em;
    line-height: 1.1;
  }
  #wrapper #all_inclusive .all_inclusive_exclusive:before,
  #wrapper #all_inclusive_02 .all_inclusive_exclusive:before{
    top: min(-10px, 1.3333333333333335vw);
    width: min(34.5px, 4.6vw);
    height: min(34.5px, 4.6vw);
    font-size: min(30px, 4vw);
    font-weight: 500;
  }
  #wrapper #all_inclusive .all_inclusive_exclusive h3,
  #wrapper #all_inclusive_02 .all_inclusive_exclusive h3{
    font-size: min(28px, 3.733333333333333vw);
  }
  #wrapper #all_inclusive .all_inclusive_note,
  #wrapper #all_inclusive_02 .all_inclusive_note{
    width: 105%;
    font-size: min(20px, 2.6666666666666665vw);
  }
  #wrapper #all_inclusive .all_inclusive_note span,
  #wrapper #all_inclusive_02 .all_inclusive_note span{
    display: inline-block;
    width: 1.2em;
  }
  #wrapper #all_inclusive,
  #wrapper #all_inclusive_02 {
    padding-bottom: min(54px, 7.2vw);
    overflow: visible;
  }
  #wrapper #all_inclusive:before,
  #wrapper #all_inclusive_02:before{
    width: 0;
    height: 0;
    border-left: min(113px, 15.07vw) solid transparent;
    border-right: min(113px, 15.07vw) solid transparent;
    border-top: min(54px, 7.2vw) solid #F8F6F4;
  }
}

/* ========== Registration ========== */
#wrapper #rooms_01 , #wrapper #rooms_02 {
  width: 100%;
  margin: 0 auto ;
  overflow-x: hidden;
}
#wrapper #rooms_01 h2 , #wrapper #rooms_02 h2 {
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
}
#wrapper #rooms_01 .rooms_title_sub , #wrapper #rooms_02 .rooms_title_sub {
  padding: min(10px, 0.7291666666666667vw) 0 min(50px, 3.5714285714285716vw);
  font-size: min(20px, 1.4583333333333333vw);
  line-height: 1.35;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0;
}
#wrapper #rooms_01 .rooms_item , #wrapper #rooms_02 .rooms_item {
  justify-content: flex-start;
  gap: min(30px, 2.0833333333333335vw);
  margin: 0 min(30px, 2.0833333333333335vw);
}
#wrapper #rooms_01 .rooms_item_left , #wrapper #rooms_02 .rooms_item_left {
  display: flex;
  align-items: center;
  gap: min(30px, 2.0833333333333335vw);
}
#wrapper #rooms_01 .rooms_guests_wrap , #wrapper #rooms_02 .rooms_guests_wrap {
  margin-left: auto;
}
#wrapper #rooms_01 .rooms_label , #wrapper #rooms_02 .rooms_label {
  margin-right: min(10px, 0.7291666666666667vw);
  font-family: var(--font-family-oswald);
  width: min(140px, 10vw);
  height: min(28px, 2vw);
  color: #fff;
}
#wrapper #rooms_01 .rooms_icon_wrap, #wrapper #rooms_02 .rooms_icon_wrap{
  margin-left: auto;
  margin-right: 0;
}
#wrapper #rooms_01 .rooms_icon_wrap p, #wrapper #rooms_02 .rooms_icon_wrap p{
  padding-left: min(10px, 0.7291666666666667vw);
  font-size: min(18px, 1.25vw);
}
#wrapper #rooms_01 .rooms_guests_select_wrap, #wrapper #rooms_02 .rooms_guests_select_wrap{
  position: relative;
  display: flex;
  align-items: center;
  min-height: min(40px, 2.8125vw);
  margin-left: min(10px, 0.7291666666666667vw);
  padding: 0 0 0 min(20px, 1.4583333333333333vw);
  padding-right: min(42px, 2.9166666666666665vw);
  background-color: #F2F2F2;
  border-radius: min(4px, 0.2777777777777778vw);
}
#wrapper #rooms_01 .rooms_guests_select_wrap::after, #wrapper #rooms_02 .rooms_guests_select_wrap::after {
  content: '';
  position: absolute;
  right: min(13px, 0.9333333333333333vw);
  top: 40%;
  width: min(12px, 0.8333333333333334vw);
  height: min(12px, 0.8333333333333334vw);
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: translateY(-50%) rotate(135deg);
  pointer-events: none;
}
#wrapper #rooms_01 .rooms_guests_label, #wrapper #rooms_02 .rooms_guests_label {
  display: flex;
  align-items: center;
  padding-right: min(20px, 1.4583333333333333vw);
  font-size: min(20px, 1.4583333333333333vw);
  font-family: inherit;
  color: #000;
  pointer-events: none;
  line-height: 1.4;
  min-height: min(40px, 2.8125vw);
}
#wrapper #rooms_01 .rooms_guests_select, #wrapper #rooms_02 .rooms_guests_select{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  font-size: min(20px, 1.4583333333333333vw);
  font-family: inherit;
  border: none;
  background-color: transparent;
  color: transparent;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}
#wrapper #rooms_01 .rooms_guests_select option, #wrapper #rooms_02 .rooms_guests_select option {
  color: #000;
}
#wrapper #rooms_01 .rooms_icon_wrap img, #wrapper #rooms_02 .rooms_icon_wrap img{
  width: min(24px, 1.7361111111111112vw);
  height: min(24px, 1.7361111111111112vw);
}
#wrapper #rooms_01 .rooms_icon_wrap .rooms_human_icon, #wrapper #rooms_02 .rooms_icon_wrap .rooms_human_icon{
  width: min(33px, 2.3958333333333335vw);
  height: min(33px, 2.3958333333333335vw);
}
#wrapper #rooms_01 .rooms_note, #wrapper #rooms_02 .rooms_note{
  font-size: min(14px, 1.0416666666666667vw);
  text-align: center;
}
#wrapper #rooms_01 .rooms_note a, #wrapper #rooms_02 .rooms_note a{
  text-decoration: underline;
  color: #3366cc;
}
@media (max-width: 750px) {
  #wrapper #rooms_01 , #wrapper #rooms_02 {
    width: 100%;
    margin: 0 auto;
    padding-top: min(88px, 11.733333333333334vw);
  }
  #wrapper #rooms_01 h2, #wrapper #rooms_02 h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #rooms_01 .rooms_title_sub, #wrapper #rooms_02 .rooms_title_sub{
    font-family: var(--font-family-oswald);
    font-size: min(28px, 3.733333333333333vw);
  }
  #wrapper #rooms_01 .rooms_label, #wrapper #rooms_02 .rooms_label{
    font-family: var(--font-family-noto);
    width: min(194px, 25.866666666666667vw);
    height: min(39px, 5.2vw);
    margin: 0 auto min(14px, 1.8666666666666667vw);
    font-size: min(20px, 2.6666666666666665vw);
    border-radius: min(4px, 0.5333333333333333vw);
    text-align: center;
    line-height: min(39px, 5.2vw);
  }
  #wrapper #rooms_01 .rooms_item, #wrapper #rooms_02 .rooms_item,
  #wrapper #rooms_01 .rooms_item_left, #wrapper #rooms_02 .rooms_item_left{
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: min(20px, 2.6666666666666665vw);
  }
  #wrapper #rooms_01 .rooms_item_left .sp_only, #wrapper #rooms_02 .rooms_item_left .sp_only{
    display: flex!important;
    align-items: center;
    gap: min(20px, 2.6666666666666665vw);
  }
  #wrapper #rooms_01 .rooms_icon_wrap, #wrapper #rooms_02 .rooms_icon_wrap{
    margin-inline: auto;
  }
  #wrapper #rooms_01 .rooms_icon_wrap p, #wrapper #rooms_02 .rooms_icon_wrap p{
    font-size: min(21px, 2.8vw);
    padding-left: min(10px, 1.3333333333333333vw);
  }
  #wrapper #rooms_01 .rooms_icon_wrap img, #wrapper #rooms_02 .rooms_icon_wrap img{
    width: min(26px, 3.4666666666666668vw);
    height: min(26px, 3.4666666666666668vw);
  }
  #wrapper #rooms_01 .rooms_icon_wrap .rooms_human_icon, #wrapper #rooms_02 .rooms_icon_wrap .rooms_human_icon{
    width: min(47px, 6.266666666666667vw);
    height: min(47px, 6.266666666666667vw);
  }
  #wrapper #rooms_01 .rooms_guests_select_wrap::after, #wrapper #rooms_02 .rooms_guests_select_wrap::after {
    right: min(12px, 1.6vw);
    width: min(12px, 1.6vw);
    height: min(12px, 1.6vw);
  }
  #wrapper #rooms_01 .rooms_guests_select_wrap, #wrapper #rooms_02 .rooms_guests_select_wrap {
    padding-left: min(28px, 3.733333333333333vw);
  }
  #wrapper #rooms_01 .rooms_guests_label, #wrapper #rooms_02 .rooms_guests_label {
    width: min(148px, 19.733333333333334vw);
    font-size: min(28px, 3.733333333333333vw);
    text-align: center;
  }
  #wrapper #rooms_01 .rooms_guests_select, #wrapper #rooms_02 .rooms_guests_select{
    width: 100%;
    font-size: min(28px, 3.733333333333333vw);
    text-align: center;
    border-radius: min(5.7px, 0.76vw);
  }
}

/* ------ スライド ------ */
#wrapper #rooms_01 .rooms_slider , #wrapper #rooms_02 .rooms_slider {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  box-sizing: border-box;
}
/* プログレスバー（ドラッグ可能・色付き）※両端切れ防止：親に padding を確保 */
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar , #wrapper #rooms_02 .rooms_slider .rooms_slick_bar {
  --slick-progress: 0%;
  --slick-thumb-x: -50%;
  position: relative;
  display: flex;
  width: 50%;
  max-width: min(500px, 34.72vw);
  height: min(10px, 0.6944444444444444vw);
  margin: min(28px, 1.9444444444444444vw) auto 0 !important;
  padding: 0;
  list-style: none;
  background-color: #E6E4E4;
  border-radius: 999px;
  overflow: hidden;
  cursor: pointer;
  user-select: none;
}
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar .rooms_slick_fill , #wrapper #rooms_02 .rooms_slider .rooms_slick_bar .rooms_slick_fill {
  position: absolute;
  left: 0;
  top: 0;
  width: 25%;
  height: 100%;
  max-height: 100%;
  background-color: #C1BDBD;
  border-radius: 999px;
  transition: left 0.1s ease, transform 0.1s;
  z-index: 0;
  pointer-events: none;
  box-sizing: border-box;
}
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar .rooms_slick_thumb, #wrapper #rooms_02 .rooms_slider .rooms_slick_bar .rooms_slick_thumb,
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar .rooms_slick_thumb:active , #wrapper #rooms_02 .rooms_slider .rooms_slick_bar .rooms_slick_thumb:active {
  position: absolute;
  left: var(--slick-progress, 0%);
  top: 0;
  transform: translate(var(--slick-thumb-x, -50%), 0);
  width: 25%;
  height: 100%;
  border-radius: 999px;
  background-color: #C1BDBD;
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
  z-index: 2;
  transition: left 0.1s ease, transform 0.1s;
  pointer-events: auto;
  box-sizing: border-box;
}
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar .rooms_slick_thumb , #wrapper #rooms_02 .rooms_slider .rooms_slick_bar .rooms_slick_thumb { cursor: grab; }
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar .rooms_slick_thumb:active , #wrapper #rooms_02 .rooms_slider .rooms_slick_bar .rooms_slick_thumb:active { cursor: grabbing; }
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar li , #wrapper #rooms_02 .rooms_slider .rooms_slick_bar li {
  display: none !important;
}
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar li button, #wrapper #rooms_02 .rooms_slider .rooms_slick_bar li button,
#wrapper #rooms_01 .rooms_slider .rooms_slick_bar li button::before , #wrapper #rooms_02 .rooms_slider .rooms_slick_bar li button::before {
  display: none !important;
}
#wrapper #rooms_01 .rooms_slider .slick-prev, #wrapper #rooms_02 .rooms_slider .slick-prev,
#wrapper #rooms_01 .rooms_slider .slick-next , #wrapper #rooms_02 .rooms_slider .slick-next {
  display: none !important;
}
/* rooms_01 / rooms_02: ネイティブ横スクロール overflow-x: auto */
#wrapper #rooms_01 .rooms_track,
#wrapper #rooms_02 .rooms_track {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  padding: 0 min(220px, 15.740740740740741vw);
  margin-left: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
#wrapper #rooms_01 .rooms_track::-webkit-scrollbar,
#wrapper #rooms_02 .rooms_track::-webkit-scrollbar {
  display: none;
}
#wrapper #rooms_01 .rooms_track > .rooms_card,
#wrapper #rooms_02 .rooms_track > .rooms_card {
  flex: 0 0 auto;
  margin: min(20px, 1.4583333333333333vw) min(10px, 0.7291666666666667vw);
  padding: min(30px, 2.0833333333333335vw);
  outline: none;
}
#wrapper #rooms_01 .rooms_track > .rooms_card:first-child,
#wrapper #rooms_02 .rooms_track > .rooms_card:first-child {
  margin-left: 0;
}

#wrapper #rooms_01 .rooms_track.slick-initialized .slick-list , #wrapper #rooms_02 .rooms_track.slick-initialized .slick-list {
  width: 100% !important;
  margin-inline: auto;
  padding-left: min(16px, 1.1111111111111112vw);
  overflow: visible;
}
#wrapper #rooms_01 .rooms_track .slick-slide , #wrapper #rooms_02 .rooms_track .slick-slide {
  margin: min(20px, 1.4583333333333333vw) min(10px, 0.7291666666666667vw);
  padding:min(30px, 2.0833333333333335vw);
}
#wrapper #rooms_01 .rooms_track .slick-slide:first-child , #wrapper #rooms_02 .rooms_track .slick-slide:first-child{
  margin-left: min(20px, 1.4583333333333333vw);
}
#wrapper #rooms_01 .rooms_track .slick-slide > div , #wrapper #rooms_02 .rooms_track .slick-slide > div {
  outline: none;
}
#wrapper #rooms_01 .rooms_card , #wrapper #rooms_02 .rooms_card {
  position: relative;
  width: min(480px, 33.333333333333336vw);
  height: min(428px, 30.041666666666668vw);
  padding: min(30px, 2.0833333333333335vw);
  background-color: #F2F2F2;
  border-radius: min(4px, 0.2777777777777778vw);
  box-shadow: 0 0 min(4px, 0.2777777777777778vw) rgba(0, 0, 0, 0.4);
}
#wrapper #rooms_01 .rooms_card .rooms_card_img_wrap , #wrapper #rooms_02 .rooms_card .rooms_card_img_wrap {
  position: relative;
}
#wrapper #rooms_01 .rooms_card .rooms_card_img_wrap img, #wrapper #rooms_02 .rooms_card .rooms_card_img_wrap img,
#wrapper #rooms_01 .rooms_card .rooms_card_img_wrap video , #wrapper #rooms_02 .rooms_card .rooms_card_img_wrap video {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
/* 2枚画像のふんわり切り替え（standard_rooms01） */
#wrapper #rooms_01 .rooms_card .rooms_card_img_wrap .rooms_crossfade,
#wrapper #rooms_02 .rooms_card .rooms_card_img_wrap .rooms_crossfade {
  position: relative;
  display: block;
  overflow: hidden;
}
#wrapper #rooms_01 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img,
#wrapper #rooms_02 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img {
  width: 100%;
  display: block;
  object-fit: cover;
}
#wrapper #rooms_01 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img_back,
#wrapper #rooms_02 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img_back {
  position: relative;
  z-index: 0;
  height: auto;
}
#wrapper #rooms_01 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img_front,
#wrapper #rooms_02 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img_front {
  position: absolute;
  inset: 0;
  height: 100%;
  z-index: 1;
  animation: rooms_crossfade_front 6s ease-in-out infinite;
}
@keyframes rooms_crossfade_front {
  0%, 30% { opacity: 1; }
  50%, 80% { opacity: 0; }
  100% { opacity: 1; }
}
#wrapper #rooms_01 .rooms_card .rooms_card_label , #wrapper #rooms_02 .rooms_card .rooms_card_label {
  position: absolute;
  top: min(8px, 0.59375vw);
  left: min(8px, 0.59375vw);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(133px, 9.375vw);
  height: min(26px, 1.8055555555555556vw);
  font-size: min(14px, 1.0416666666666667vw);
  font-weight: 500;
  color: #fff;
  background-color: var(--color-primary);
  border-radius: min(26px, 1.8055555555555556vw);
}
#wrapper #rooms_01 .rooms_card .rooms_card_date_wrap , #wrapper #rooms_02 .rooms_card .rooms_card_date_wrap {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: min(10px, 0.6944444444444444vw);
  margin: min(18px, 1.25vw) 0;
  text-align: center;
}
#wrapper #rooms_01 .rooms_card .rooms_card_date_title , #wrapper #rooms_02 .rooms_card .rooms_card_date_title {
  display: flex;
  justify-content: center;
  align-items: center;
  flex: 0 0 min(109px, 7.638888888888889vw);
  height: min(40px, 2.8125vw);
  font-size: min(14px, 1.0416666666666667vw);
  line-height: 1.1;
  font-weight: 300;
  background-color: #333333;
  color: #fff;
}
#wrapper #rooms_01 .rooms_card .rooms_card_date , #wrapper #rooms_02 .rooms_card .rooms_card_date {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(16px, 1.1111111111111112vw);
  flex: 1;
  min-width: 0;
  height: min(40px, 2.8125vw);
  padding: 0;
  background-color: #fff;
  font-size: min(24px, 1.7361111111111112vw);
  font-weight: 600;
  line-height: 1.1;
}
#wrapper #rooms_01 .rooms_card .rooms_card_date_icon, #wrapper #rooms_02 .rooms_card .rooms_card_date_icon,
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date_icon , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date_icon {
  width: min(24px, 1.7361111111111112vw);
  height: min(24px, 1.7361111111111112vw);
  margin: 0;
}
#wrapper #rooms_01 .rooms_card .rooms_card_price_wrap , #wrapper #rooms_02 .rooms_card .rooms_card_price_wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: min(16px, 1.1111111111111112vw);
  width: 100%;
}
#wrapper #rooms_01 .rooms_card .rooms_card_room_name , #wrapper #rooms_02 .rooms_card .rooms_card_room_name {
  flex: 0 0 auto;
  font-size: min(24px, 1.7361111111111112vw);
  font-weight: 600;
}
#wrapper #rooms_01 .rooms_card .rooms_card_description , #wrapper #rooms_02 .rooms_card .rooms_card_description {
  font-size: min(15px, 1.0416666666666665vw);
  font-weight: 300;
  line-height: 1.3;
  letter-spacing: 0;
  white-space: nowrap;
}
#wrapper #rooms_01 .rooms_card .rooms_card_price_left p, #wrapper #rooms_02 .rooms_card .rooms_card_price_left p{
  font-size: min(15px, 1.0416666666666665vw);
}
#wrapper #rooms_01 .rooms_card .rooms_card_price_right , #wrapper #rooms_02 .rooms_card .rooms_card_price_right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: min(4px, 0.2777777777777778vw);
  flex-shrink: 0;
}
#wrapper #rooms_01 .rooms_card .rooms_card_price_01, #wrapper #rooms_02 .rooms_card .rooms_card_price_01,
#wrapper #rooms_01 .rooms_card .rooms_card_price_02 , #wrapper #rooms_02 .rooms_card .rooms_card_price_02 {
  font-size: min(18px, 1.25vw);
  text-align: right;
  font-weight: 400;
  white-space: nowrap;
}
#wrapper #rooms_01 .rooms_card .rooms_card_price_01 span, #wrapper #rooms_02 .rooms_card .rooms_card_price_01 span{
  font-family: var(--font-family-oswald);
  font-size: min(27px, 1.9444444444444444vw);
  line-height: 1.2;
  letter-spacing: 0;
}
#wrapper #rooms_01 .rooms_card .rooms_card_price_02 span , #wrapper #rooms_02 .rooms_card .rooms_card_price_02 span {
  font-family: var(--font-family-oswald);
  font-size: min(34px, 2.4305555555555554vw);
  line-height: 1.2;
  letter-spacing: 0;
  color: var(--color-primary);
}
#wrapper #rooms_01 .rooms_card .rooms_card_price_01 .price_unit, #wrapper #rooms_02 .rooms_card .rooms_card_price_01 .price_unit,
#wrapper #rooms_01 .rooms_card .rooms_card_price_02 .price_unit , #wrapper #rooms_02 .rooms_card .rooms_card_price_02 .price_unit {
  font-family: inherit;
  font-size: min(22px, 1.5625vw);
  margin-inline: 0.2em;
}
/* Slickがインラインで指定するため効かない可能性あり。必要ならJSで上書きを検討 */
#wrapper #rooms_01 .slick-list.draggable , #wrapper #rooms_02 .slick-list.draggable {
  padding: 0 !important;
  width: min(1980px, 138.88888888888889vw) !important;
}
/* ドラッグ中のカーソル（つかんでいる手のアイコン） */
.slick-list.draggable:active {
  cursor: grabbing;
}

@media (max-width: 750px) {
  #wrapper #rooms_01 .rooms_track .slick-slide:first-child , #wrapper #rooms_02 .rooms_track .slick-slide:first-child{
    margin-left: min(50px, 6.666666666666667vw);
  }
  #wrapper #rooms_01 .rooms_track > .rooms_card,
  #wrapper #rooms_02 .rooms_track > .rooms_card {
    width: min(654px, 87.2vw);
    min-width: min(654px, 87.2vw);
    height: min(681px, 90.8vw);
    margin: min(12px, 1.6vw);
    padding: min(32px, 4.266666666666667vw) min(30px, 4vw);
  }
  #wrapper #rooms_01 .rooms_track > .rooms_card:first-child,
  #wrapper #rooms_02 .rooms_track > .rooms_card:first-child {
    margin-left: min(45px, 6vw);
  }
  #wrapper #rooms_01 .rooms_track .slick-slide, #wrapper #rooms_02 .rooms_track .slick-slide{
    width: min(654px, 87.2vw);
    height: min(681px, 90.8vw);
    margin: min(12px, 1.6vw);
    padding: min(32px, 4.266666666666667vw) min(30px, 4vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_img_wrap img, #wrapper #rooms_02 .rooms_card .rooms_card_img_wrap img, #wrapper #rooms_01 .rooms_card .rooms_card_img_wrap video, #wrapper #rooms_02 .rooms_card .rooms_card_img_wrap video,
  #wrapper #rooms_01 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img, #wrapper #rooms_02 .rooms_card .rooms_card_img_wrap .rooms_crossfade .rooms_crossfade_img{
    width: min(594px, 79.2vw);
    height: min(319px, 42.53333333333333vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_label, #wrapper #rooms_02 .rooms_card .rooms_card_label{
    top: min(9px, 1.2vw);
    left: min(9px, 1.2vw);
    width: min(186px, 24.8vw);
    height: min(33px, 4.4vw);
    font-size: min(20px, 2.6666666666666665vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_date_wrap, #wrapper #rooms_02 .rooms_card .rooms_card_date_wrap{
    justify-content: center;
    margin-bottom: min(30px, 4vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_date_title, #wrapper #rooms_02 .rooms_card .rooms_card_date_title{
    flex: 0 0 min(175px, 23.333333333333332vw);
    height: min(40px, 5.333333333333333vw);
    font-size: min(18px, 2.4vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_date, #wrapper #rooms_02 .rooms_card .rooms_card_date{
    flex: 1 1 auto;
    justify-content: center;
    height: min(40px, 5.333333333333333vw);
    margin: 0;
    padding: 0;
    font-size: min(24px, 3.2vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_date_icon, #wrapper #rooms_02 .rooms_card .rooms_card_date_icon, #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date_icon, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date_icon{
    width: min(26px, 3.4666666666666668vw)!important;
    height: min(26px, 3.4666666666666668vw)!important;
    margin-left: min(10px, 1.3333333333333333vw)!important;
    margin-right: 0!important;
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_01, #wrapper #rooms_02 .rooms_card .rooms_card_price_01, #wrapper #rooms_01 .rooms_card .rooms_card_price_02, #wrapper #rooms_02 .rooms_card .rooms_card_price_02{
    font-size: min(27px, 3.6vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_room_name, #wrapper #rooms_02 .rooms_card .rooms_card_room_name{
    font-size: min(30px, 4vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_01 .price_unit, #wrapper #rooms_02 .rooms_card .rooms_card_price_01 .price_unit, #wrapper #rooms_01 .rooms_card .rooms_card_price_02 .price_unit, #wrapper #rooms_02 .rooms_card .rooms_card_price_02 .price_unit{
    font-size: min(34px, 4.533333333333333vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_01 span, #wrapper #rooms_02 .rooms_card .rooms_card_price_01 span{
    font-size: min(42px, 5.6vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_02 span, #wrapper #rooms_02 .rooms_card .rooms_card_price_02 span{
    font-size: min(52px, 6.933333333333333vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_wrap, #wrapper #rooms_02 .rooms_card .rooms_card_price_wrap{
    flex-direction: column;
    align-items: flex-start;
    justify-content: space-between;
    gap: min(58px, 7.733333333333333vw);
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_wrap:has(.rooms_card_price_left),
  #wrapper #rooms_02 .rooms_card .rooms_card_price_wrap:has(.rooms_card_price_left){
    gap: 8px;
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_room_name, #wrapper #rooms_02 .rooms_card .rooms_card_room_name{
    align-self: flex-start;
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_right, #wrapper #rooms_02 .rooms_card .rooms_card_price_right{
    align-self: flex-end;
    margin-top: auto;
  }
  #wrapper #rooms_01 .rooms_card .rooms_card_price_left p, #wrapper #rooms_02 .rooms_card .rooms_card_price_left p{
    font-size: min(20px, 2.6666666666666665vw);
  }
  #wrapper #rooms_01 .rooms_slider .rooms_slick_bar, #wrapper #rooms_02 .rooms_slider .rooms_slick_bar{
    width: min(500px, 66.66666666666666vw);
    max-width: 100%;
    height: min(10px, 1.3333333333333333vw);
    margin-top: min(30px, 4vw)!important;
  }
  #wrapper #rooms_01 .rooms_track, #wrapper #rooms_02 .rooms_track{
    padding-left: 0;
  }
}

/* ========== CTAボタン ========== */
#wrapper #rooms_01 .cta_btn_wrap, #wrapper #rooms_02 .cta_btn_wrap,
#wrapper #yacht_club_01 .cta_btn_wrap , #wrapper #yacht_club_02 .cta_btn_wrap {
  margin: min(35px, 2.5833333333333335vw) auto min(30px, 2.0833333333333335vw);
}
#wrapper #rooms_01 .cta_btn_wrap a, #wrapper #rooms_02 .cta_btn_wrap a,
#wrapper #yacht_club_01 .cta_btn_wrap a , #wrapper #yacht_club_02 .cta_btn_wrap a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(242px, 17.638888888888889vw);
  height: min(65px, 4.791666666666667vw);
  margin-inline: auto;
  background-color: var(--color-primary);
  border-radius: min(65px, 4.791666666666667vw);
  font-size: min(20px, 1.4583333333333333vw);
  font-weight: 500;
  color: #fff;
}

@media (max-width: 750px) {
  #wrapper #rooms_01 .cta_btn_wrap, #wrapper #rooms_02 .cta_btn_wrap, #wrapper #yacht_club_01 .cta_btn_wrap, #wrapper #yacht_club_02 .cta_btn_wrap{
    margin: min(35px, 4.666666666666667vw) 0;
  }
  #wrapper #rooms_01 .cta_btn_wrap a, #wrapper #rooms_02 .cta_btn_wrap a, #wrapper #yacht_club_01 .cta_btn_wrap a, #wrapper #yacht_club_02 .cta_btn_wrap a{
    width: min(380px, 50.666666666666664vw);
    height: min(87px, 11.6vw);
    margin-inline: auto;
    border-radius: min(87px, 11.6vw);
    font-size: min(34px, 4.533333333333333vw);
  }
  #wrapper #rooms_01 .rooms_note, #wrapper #rooms_02 .rooms_note{
    width: min(654px, 87.2vw);
    margin-inline: auto;
    text-align: left;
    font-size: min(20px, 2.6666666666666665vw);
  }
}

/* ========== Yacht Club ========== */
#wrapper #yacht_club_01 , #wrapper #yacht_club_02 {
  background-color: #122341;
  color: #fff;
  overflow-x: hidden;
}
#wrapper #yacht_club_01 .yacht_club_card_date_wrap, #wrapper #yacht_club_02 .yacht_club_card_date_wrap{
  margin-bottom: min(28px, 1.9444444444444444vw);
}
#wrapper #yacht_club_01 .sp_content_wrap, #wrapper #yacht_club_02 .sp_content_wrap{
  gap: min(32px, 2.2222222222222223vw);
}
#wrapper #yacht_club_01 h2 , #wrapper #yacht_club_02 h2 {
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
}
/*
#wrapper #yacht_club_01 .yacht_club_icon , #wrapper #yacht_club_02 .yacht_club_icon {
  width: min(164px, 11.506944444444444vw);
  height: min(137px, 9.583333333333332vw);
}*/
#wrapper #yacht_club_01 .yacht_club_title , #wrapper #yacht_club_02 .yacht_club_title {
  width: min(468px, 32.43055555555555vw);
  height: min(137px, 9.583333333333332vw);
}
#wrapper #yacht_club_01 .yacht_club_list_wrap , #wrapper #yacht_club_02 .yacht_club_list_wrap {
  width: min(466px, 32.43055555555555vw);
  margin-left: auto;
  margin-right: 0;
}
#wrapper #yacht_club_01 .yacht_club_list_wrap h3 , #wrapper #yacht_club_02 .yacht_club_list_wrap h3 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(178px, 12.430555555555557vw);
  height: min(36px, 2.5vw);
  margin-bottom: min(13px, 0.9027777777777778vw);
  padding: 0 min(20px, 1.4583333333333333vw);
  font-size: min(18px, 1.25vw);
  font-weight: 400;
  line-height: 1.35;
  background-color: #1A4388;
  border-radius: min(4px, 0.2777777777777778vw);
}
#wrapper #yacht_club_01 .yacht_club_list_wrap ul , #wrapper #yacht_club_02 .yacht_club_list_wrap ul {
  padding-left: min(20px, 1.4583333333333333vw);
  margin-left: 0;
}
#wrapper #yacht_club_01 .yacht_club_list_wrap ul li , #wrapper #yacht_club_02 .yacht_club_list_wrap ul li {
  margin-left: 0;
  line-height: 1.3;
  letter-spacing: 0;
  list-style: disc;
  list-style-position: outside;
  font-weight: 300;
}
#wrapper #yacht_club_01 .yacht_club_card_description , #wrapper #yacht_club_02 .yacht_club_card_description {
  font-size: min(15px, 1.0416666666666665vw);
  line-height: 1.3;
  letter-spacing: 0;
  color: #000;
}
#wrapper #yacht_club_01 .yacht_club_card , #wrapper #yacht_club_02 .yacht_club_card {
  align-items: flex-start;
  width: min(980px, 68.05555555555556vw);
  height: min(390px, 27.1875vw);
  padding: min(30px, 2.0833333333333335vw) min(37px, 2.5833333333333335vw);
  background-color: #fff;
  border-radius: min(4px, 0.2777777777777778vw);
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_img , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_img {
  width: min(500px, 34.72222222222222vw);
  height: min(330px, 23.229166666666668vw);
  object-fit: cover;
}
/* 2枚画像のふんわり切り替え（DUPLEX SUITE） */
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_crossfade,
#wrapper #yacht_club_02 .yacht_club_card .yacht_club_crossfade {
  position: relative;
  display: block;
  overflow: hidden;
  flex-shrink: 0;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_crossfade .yacht_club_crossfade_img,
#wrapper #yacht_club_02 .yacht_club_card .yacht_club_crossfade .yacht_club_crossfade_img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_crossfade .yacht_club_crossfade_img_back,
#wrapper #yacht_club_02 .yacht_club_card .yacht_club_crossfade .yacht_club_crossfade_img_back {
  z-index: 0;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_crossfade .yacht_club_crossfade_img_front,
#wrapper #yacht_club_02 .yacht_club_card .yacht_club_crossfade .yacht_club_crossfade_img_front {
  z-index: 1;
  animation: yacht_club_crossfade_front 6s ease-in-out infinite;
}
@keyframes yacht_club_crossfade_front {
  0%, 30% { opacity: 1; }
  50%, 80% { opacity: 0; }
  100% { opacity: 1; }
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_right , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_right {
  margin: 0 min(37px, 2.5833333333333335vw) 0 min(30px, 2.1875vw);
  display: flex;
  flex-direction: column;
  height: min(330px, 23.229166666666668vw);
}

#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date_wrap , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date_wrap {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: min(10px, 0.6944444444444444vw);
  text-align: center;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date_title , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date_title {
  display: flex;
  justify-content: center;
  align-items: center;
  flex: 0 0 min(100px, 7.1875vw);
  width: min(100px, 7.1875vw);
  height: min(40px, 2.8125vw);
  font-size: min(14px, 1.0416666666666667vw);
  line-height: 1.1;
  font-weight: 300;
  background-color: #333333;
  color: #fff;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(16px, 1.1111111111111112vw);
  flex: 0 0 min(130px, 9.027777777777778vw);
  width: min(130px, 9.027777777777778vw);
  height: min(40px, 2.8125vw);
  min-width: 0;
  padding: 0;
  background-color: #F3F3F3;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.1;
  color: #000;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date_icon , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date_icon {
  width: min(24px, 1.7361111111111112vw);
  height: min(24px, 1.7361111111111112vw);
}
#wrapper #yacht_club_01 .yacht_club_card_title , #wrapper #yacht_club_02 .yacht_club_card_title {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(179px, 12.430555555555557vw);
  height: min(32px, 2.2222222222222223vw);
  background: url(/shopping/img/special/cruising/2026autumn_us/ca/yacht_club/yacht_club_label_bg.png) no-repeat center center;
  background-size: 100% 100%;
  font-size: min(14px, 1.0416666666666667vw);
  font-weight: 300;
  letter-spacing: 0.03em;
  color: #fff;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_name , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_name {
  margin: min(10px, 0.7291666666666667vw) 0;
  font-size: min(24px, 1.7361111111111112vw);
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #000;
  border-bottom: 1px solid #000;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_wrap , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_wrap {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  margin-top: auto;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_right , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  /*
  gap: min(4px, 0.2777777777777778vw);*/
  color: #000;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_01, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_01,
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02 , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02 {
  font-size: min(18px, 1.25vw);
  text-align: right;
  font-weight: 400;
  white-space: nowrap;
  margin: 0;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_01 span, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_01 span,
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02 span , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02 span {
  font-family: var(--font-family-oswald);
  font-size: min(27px, 1.9444444444444444vw);
  line-height: 1.2;
  letter-spacing: 0;
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02 span , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02 span {
  font-size: min(34px, 2.4305555555555554vw);
  color: var(--color-primary);
}
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_01 .price_unit, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_01 .price_unit,
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02 .price_unit , #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02 .price_unit {
  font-family: inherit;
  font-size: min(22px, 1.5625vw);
  margin-inline: 0.2em;
}
/* 4人選択時：*Maximum occupancy: three guests の $ と値段を黒字 */
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02.yacht_club_max_occupancy .price_unit,
#wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02.yacht_club_max_occupancy .price_unit,
#wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02.yacht_club_max_occupancy span,
#wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02.yacht_club_max_occupancy span {
  color: #000;
}
#wrapper #yacht_club_01 .yacht_club_note , #wrapper #yacht_club_02 .yacht_club_note {
  font-size: min(14px, 1.0416666666666667vw);
  font-weight: 300;
  line-height: 1.3;
  letter-spacing: 0;
  text-align: center;
  opacity: 0.8;
}
  #wrapper #yacht_club_01 .yacht_club_note a, #wrapper #yacht_club_02 .yacht_club_note a{
  text-decoration: underline;
  color: #ffffff;
}

@media (max-width: 750px) {
  #wrapper #yacht_club_01 .yacht_club_icon, #wrapper #yacht_club_02 .yacht_club_icon{
    width: min(136px, 18.133333333333333vw);
    height: min(117px, 15.6vw);
    margin-top: min(-17.5px, -2.3333333333333335vw);
  }
  #wrapper #yacht_club_01 .sp_content_wrap, #wrapper #yacht_club_02 .sp_content_wrap{
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: min(28px, 1.9444444444444444vw);
  }
  #wrapper #yacht_club_01 .flex, #wrapper #yacht_club_02 .flex{
    justify-content: space-between;
    align-items: flex-start;
  }
  #wrapper #yacht_club_01 .flex.sp_content_wrap, #wrapper #yacht_club_02 .flex.sp_content_wrap{
    align-items: flex-start;
  }
  #wrapper #yacht_club_01 .yacht_club_title, #wrapper #yacht_club_02 .yacht_club_title{
    width: min(441px, 58.8vw);
    height: min(40px, 5.333333333333333vw);
    margin-inline: 0;
  }
  #wrapper #yacht_club_01 .yacht_club_list_wrap, #wrapper #yacht_club_02 .yacht_club_list_wrap{
    width: 100%;
    margin-left: 0;
    padding-left: 0;
  }
  #wrapper #yacht_club_01 .yacht_club_list_wrap ul, #wrapper #yacht_club_02 .yacht_club_list_wrap ul{
    padding-left: min(20px, 2.6666666666666665vw);
    margin-left: min(15px, 2vw);
  }
  #wrapper #yacht_club_01 .yacht_club_list_wrap h3, #wrapper #yacht_club_02 .yacht_club_list_wrap h3{
    width: min(178px, 23.733333333333334vw);
    height: min(36px, 4.8vw);
    font-size: min(18px, 2.4vw);
    justify-content: center;
  }
  #wrapper #yacht_club_01 .yacht_club_list_wrap ul li, #wrapper #yacht_club_02 .yacht_club_list_wrap ul li{
    font-size: min(20px, 2.6666666666666665vw);
  }


}

/* ------ Yacht Club スライダー ------ */
#wrapper #yacht_club_01 .yacht_club_slider , #wrapper #yacht_club_02 .yacht_club_slider {
  display: flex;
  flex-direction: column;
  max-width: 100%;
  margin-inline: auto;
}
/* プログレスバー ※両端切れ防止：スライダーに padding-left/right 済み */
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar , #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar {
  --slick-progress: 0%;
  --slick-thumb-x: -50%;
  position: relative;
  display: flex;
  width: 50%;
  max-width: min(500px, 34.72vw);
  height: min(10px, 0.6944444444444444vw);
  margin: min(28px, 1.9444444444444444vw) auto 0 !important;
  list-style: none;
  background-color: #434B60;
  border-radius: 999px;
  overflow: hidden;
  cursor: pointer;
  user-select: none;
}
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_fill , #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_fill {
  position: absolute;
  left: 0;
  top: 0;
  width: 33.333%;
  height: 100%;
  max-height: 100%;
  background-color: #8E8E9D;
  border-radius: 999px;
  transition: left 0.1s ease, transform 0.1s;
  z-index: 0;
  pointer-events: none;
  box-sizing: border-box;
}
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb, #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb,
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb:active , #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb:active {
  position: absolute;
  left: var(--slick-progress, 0%);
  top: 0;
  transform: translate(var(--slick-thumb-x, -50%), 0);
  width: 33.333%;
  height: 100%;
  border-radius: 999px;
  background-color: #8E8E9D;
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
  z-index: 2;
  transition: left 0.1s ease, transform 0.1s;
  pointer-events: auto;
  box-sizing: border-box;
}
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb , #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb { cursor: grab; }
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb:active , #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar .yacht_club_slick_thumb:active { cursor: grabbing; }
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar li , #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar li {
  display: none !important;
}
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar li button, #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar li button,
#wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar li button::before , #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar li button::before {
  display: none !important;
}
#wrapper #yacht_club_01 .yacht_club_slider .slick-prev, #wrapper #yacht_club_02 .yacht_club_slider .slick-prev,
#wrapper #yacht_club_01 .yacht_club_slider .slick-next , #wrapper #yacht_club_02 .yacht_club_slider .slick-next {
  display: none !important;
}
/* Yacht Club: ネイティブ横スクロール */
#wrapper #yacht_club_01 .yacht_club_track,
#wrapper #yacht_club_02 .yacht_club_track {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  margin-left: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 0 min(220px, 15.740740740740741vw);
}
#wrapper #yacht_club_01 .yacht_club_track::-webkit-scrollbar,
#wrapper #yacht_club_02 .yacht_club_track::-webkit-scrollbar {
  display: none;
}
#wrapper #yacht_club_01 .yacht_club_track > .yacht_club_card,
#wrapper #yacht_club_02 .yacht_club_track > .yacht_club_card {
  flex: 0 0 auto;
  min-width: 0;
  margin: min(10px, 0.7142857142857143vw);
  outline: none;
}
#wrapper #yacht_club_01 .yacht_club_track.slick-initialized .slick-list , #wrapper #yacht_club_02 .yacht_club_track.slick-initialized .slick-list {
  width: 100% !important;
  margin-inline: auto;
}
#wrapper #yacht_club_01 .yacht_club_track .slick-slide , #wrapper #yacht_club_02 .yacht_club_track .slick-slide {
  margin: min(20px, 1.4583333333333333vw);
}
#wrapper #yacht_club_01 .yacht_club_track .slick-slide > div , #wrapper #yacht_club_02 .yacht_club_track .slick-slide > div {
  outline: none;
}

@media (max-width: 750px) {
  #wrapper #yacht_club_01 .yacht_club_track,
  #wrapper #yacht_club_02 .yacht_club_track {
    margin-top: min(30px, 4vw);
    padding: 0 min(40px, 5.333333333333333vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card_title, #wrapper #yacht_club_02 .yacht_club_card_title{
    width: min(212px, 28.266666666666666vw);
    height: min(39px, 5.2vw);
    font-size: min(18px, 2.4vw);
    font-weight: 400;
  }
  #wrapper #yacht_club_01 .yacht_club_card_sp_wrap, #wrapper #yacht_club_02 .yacht_club_card_sp_wrap{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: min(30px, 4vw);
    padding-bottom: min(15px, 2vw);
    border-bottom: 1px solid #000;
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_name, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_name{
    width: min(306px, 40.8vw);
    margin: 0;
    font-size: min(30px, 4vw);
    border-bottom: none;
  }
  #wrapper #yacht_club_01 .yacht_club_card_description, #wrapper #yacht_club_02 .yacht_club_card_description{
    margin-top: min(16px, 2.1333333333333333vw);
    font-size: min(20px, 2.6666666666666665vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_wrap, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_wrap{
    margin-top: min(16px, 2.1333333333333333vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_wrap.yacht_club_max_occupancy, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_wrap.yacht_club_max_occupancy{
    margin-top: min(89px, 11.866666666666667vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_01, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_01, #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02{
    font-size: min(27px, 3.6vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_01 .price_unit, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_01 .price_unit, #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02 .price_unit, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02 .price_unit{
    font-size: min(34px, 4.533333333333333vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_01 span, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_01 span{
    font-size: min(42px, 5.6vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_price_02 span, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_price_02 span{
    font-size: min(52px, 6.933333333333333vw);
  }
  #wrapper #yacht_club_01 .yacht_club_note, #wrapper #yacht_club_02 .yacht_club_note{
    width: min(654px, 87.2vw);
    margin-inline: auto;
    padding-top: min(20px, 2.6666666666666665vw);
    font-size: min(20px, 2.6666666666666665vw);
    text-align: left;
  }
  #wrapper #yacht_club_01 .yacht_club_card, #wrapper #yacht_club_02 .yacht_club_card{
    width: min(654px, 87.2vw);
    height: min(760px, 101.33333333333333vw);
    padding: min(37px, 5vw) min(30px, 4vw);
  }
  #wrapper #yacht_club_01 .yacht_club_track .slick-slide, #wrapper #yacht_club_02 .yacht_club_track .slick-slide{
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
  }
  #wrapper #yacht_club_01 .yacht_club_track > .yacht_club_card,
  #wrapper #yacht_club_02 .yacht_club_track > .yacht_club_card {
    flex-direction: column;
    width: min(654px, 87.2vw);
    margin: 0 min(12px, 1.6vw);

  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_img, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_img{
    width: 100%;
    height: min(320px, 42.666666666666664vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_right, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_right{
    width: 100%;
    height: auto;
    margin: min(8px, 1.0666666666666667vw) 0 0 0;
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date_wrap, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date_wrap{
    width: 100%;
    min-width: 0;
    justify-content: center;
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date_title, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date_title{
    flex: 0 0 min(175px, 23.333333333333332vw);
    min-width: 0;
    width: auto;
    height: min(40px, 5.333333333333333vw);
    font-size: min(18px, 2.4vw);
  }
  #wrapper #yacht_club_01 .yacht_club_card .yacht_club_card_date, #wrapper #yacht_club_02 .yacht_club_card .yacht_club_card_date{
    flex: 1 1 auto;
    min-width: 0;
    width: auto;
    justify-content: center;
    height: min(40px, 5.333333333333333vw);
    font-size: min(24px, 3.2vw);
  }
  #wrapper #yacht_club_01 .yacht_club_slider .yacht_club_slick_bar, #wrapper #yacht_club_02 .yacht_club_slider .yacht_club_slick_bar{
    width: min(500px, 66.66666666666667vw);
    max-width: 100%;
    height: min(10px, 1.3333333333333333vw);
    margin-top: min(30px, 4vw)!important;
  }
}

/* ========== Section04 Itinerary ========== */
#wrapper #itinerary {
  overflow-x: hidden;
}
#wrapper #itinerary h2 {
  margin-bottom: min(32px, 2.2222222222222223vw);
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
}
#wrapper #itinerary h3{
  font-family: var(--font-family-oswald);
  font-weight: 600;
  text-align: center;
  line-height: 1.35;
  letter-spacing: 0.05em;
}
#wrapper #itinerary h3.itinerary_subtitle {
  font-size: min(34px, 2.361111111111111vw);
  color: #000;
}
#wrapper #itinerary .itinerary_sub_title {
  margin-bottom: min(34px, 2.361111111111111vw);
  font-size: min(18px, 1.25vw);
  font-weight: 300;
  text-align: center;
  line-height: 1.35;
  letter-spacing: 0;
}
#wrapper #itinerary .itinerary_card {
  justify-content: center;
  width: min(466px, 32.43055555555555vw);
  width: 100%;
  margin-bottom: min(74px, 5.138888888888889vw);
  padding: 0;
}
#wrapper #itinerary .itinerary_card_text01,
#wrapper #itinerary .itinerary_card_text02 {
  width: min(362px, 25.13888888888889vw);
  font-size: min(18px, 1.25vw);
  font-weight: 300;
  line-height: 1.5;
  letter-spacing: 0;
}
#wrapper #itinerary .itinerary_card_text01 {
  width: min(282px, 19.6875vw);
}
#wrapper #itinerary .itinerary_card img {
  width: min(63px, 4.375vw);
  height: min(58px, 4.0625vw);
  margin-left: 0;
  margin-right: min(25px, 1.7361111111111112vw);
}
#wrapper #itinerary .itinerary_card img:nth-of-type(2) {
  margin-left: min(58px, 4.0625vw);
}
#wrapper #itinerary .itinerary_note_wrap {
  width: min(1000px, 71.875vw);
  margin-inline: auto;
  text-align: center;
}
#wrapper #itinerary .itinerary_note {
  padding-left: 0;
  margin-left: 0;
  list-style: none;
  font-size: min(14px, 1.0416666666666667vw);
  font-weight: 300;
  line-height: 1.3;
  letter-spacing: 0.03em;
  text-align: left;
}
#wrapper #itinerary .itinerary_note li {
  position: relative;
  padding-left: 0.6em;
}
#wrapper #itinerary .itinerary_note li::before {
  content: '* ';
  position: absolute;
  left: 0;
}

@media (max-width: 750px) {
  #wrapper #itinerary h2 {
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #itinerary h3.itinerary_subtitle{
    margin-bottom: min(16px, 2.1333333333333333vw);
    font-size: min(38px, 5.066666666666667vw);
    line-height: 1.2;
  }
  #wrapper #itinerary .itinerary_sub_title{
    font-size: min(24px, 3.2vw);
    margin-bottom: min(33.5px, 4.466666666666667vw);
  }
  #wrapper #itinerary .itinerary_card{
    flex-direction: column;
    align-items: flex-start;
    width: min(567px, 75.6vw);
  }
  #wrapper #itinerary .itinerary_card .flex{
    gap: min(20px, 2.6666666666666665vw);
  }
  #wrapper #itinerary .itinerary_card img{
    width: min(102px, 13.6vw);
    height: min(100.3px, 13.375vw);
  }
  #wrapper #itinerary .itinerary_card_text01, #wrapper #itinerary .itinerary_card_text02{
    width: min(500px, 66.66666666666667vw);
    font-size: min(24px, 3.2vw);
    font-weight: 500;
  }
  #wrapper #itinerary .itinerary_note_wrap{
    width: min(654px, 87.2vw);
    margin-inline: auto;
  }
  #wrapper #itinerary .itinerary_note{
    font-size: min(20px, 2.6666666666666665vw);
    font-weight: 400;
    letter-spacing: 0;
  }
}

/* ----map navigation----*/
#wrapper #itinerary .itinerary_map_nav {
  width: min(1000px, 71.875vw);
  margin: min(75px, 5.208333333333333vw) auto min(50px, 3.59375vw);
  text-align: center;
}
#wrapper #itinerary .itinerary_map_nav ul {
  list-style: none;
}
#wrapper #itinerary .itinerary_map_nav ul li {
  position: relative;
}
#wrapper #itinerary .itinerary_map_nav ul li a {
  display: flex;
  justify-content: center;
  flex-flow: column;
  width: min(114px, 8.125vw);
  min-height: min(60px, 4.166666666666667vw);
  margin-inline: auto;
  padding-bottom: min(15px, 1.0416666666666667vw);
  color: var(--color-primary);
  text-decoration: none;
  font-size: min(25px, 1.7361111111111112vw);
  font-weight: 500;
  font-style: italic;
  line-height: 1.35;
  letter-spacing: 0;
  text-align: center;
  white-space: nowrap;
  border-bottom: 3px solid var(--color-primary);
}
#wrapper #itinerary .itinerary_map_nav ul li a.kagoshima_link{
  font-size: min(22px, 1.5625vw);
}
#wrapper #itinerary .itinerary_map_nav ul li a.jeju_link,
#wrapper #itinerary .itinerary_map_nav ul li a.kanazawa_link,
#wrapper #itinerary .itinerary_map_nav ul li a.kagoshima_link{
  letter-spacing:-0.05em;
}
#wrapper #itinerary .itinerary_map_nav ul li::after {
  content: '';
  position: absolute;
  right: min(-22px, -1.5625vw);
  top: 50%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
  border-top: min(6px, 0.4166666666666667vw) solid transparent;
  border-bottom: min(6px, 0.4166666666666667vw) solid transparent;
  border-left: min(10px, 0.6944444444444444vw) solid rgba(230, 0, 109, 0.2);
  pointer-events: none;
}
#wrapper #itinerary .itinerary_map_nav ul li:last-child::after {
  display: none;
}
#wrapper #itinerary .itinerary_map_nav ul li a span{
  font-size: min(16px, 1.1111111111111112vw);
  letter-spacing: 0;
}

/* ----map wrap----*/
#wrapper #itinerary .itinerary_map_wrap {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  width: min(1000px, 71.875vw);
  height: min(580px, 40.27777777777778vw);
  background: url(/shopping/img/special/cruising/2026autumn_us/ca/itinerary/map_bg_pc.jpg) no-repeat center center;
  background-size: 100% auto;
}
#wrapper #itinerary .itinerary_map_card{
  position: absolute;
  width: min(900px, 64.58333333333333vw);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: min(10px, 1.3333333333333333vw);
  grid-template-areas:
  ". a b c"
  "d . . ."
  "e . . f";
  text-align: center;
}
#wrapper #itinerary .itinerary_map_card #kanazawa{
  grid-area: a;
  transform: translateX(min(-25px, -1.7361111111111112vw)) translateY(min(5px, 0.3541666666666667vw));
}
#wrapper #itinerary .itinerary_map_card #sakata{
  grid-area: b;
  transform: translateX(min(-25px, -1.7361111111111112vw)) translateY(min(5px, 0.3541666666666667vw));
}
#wrapper #itinerary .itinerary_map_card #hakodate {
  grid-area: c;
  transform: translateX(min(20px, 1.4583333333333333vw)) translateY(min(5px, 0.3541666666666667vw));
}
#wrapper #itinerary .itinerary_map_card #jeju{
  grid-area: d;
  transform: translateY(min(-10px, -0.6944444444444444vw));
}
#wrapper #itinerary .itinerary_map_card #kagoshima{
  grid-area: e;
  transform: translateY(min(-10px, -0.6944444444444444vw));
}
#wrapper #itinerary .itinerary_map_card #tokyo {
  grid-area: f;
  transform: translateX(min(20px, 1.4583333333333333vw)) translateY(min(-10px, -0.6944444444444444vw));
}
#wrapper #itinerary .itinerary_map_city_btn_wrap{
  position: relative;
  width: min(212px, 15.138888888888889vw);
  height: min(172px, 12.291666666666667vw);
}
#wrapper #itinerary .itinerary_map_city_btn_wrap > a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
/* #container img の height:auto 等を避け、枠内で横・縦とも中央に「かぶせ」表示 */
#wrapper #itinerary .itinerary_map_city_btn_wrap img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  max-width: none;
  object-fit: cover;
  object-position: center center;
  display: block;
}
#wrapper #itinerary .itinerary_map_city_title{
  position: absolute;
  z-index: 2;
  top: min(10px, 0.7291666666666667vw);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(188px, 13.125vw);
  height: min(30px, 2.1875vw);
  padding: 0;
  background-color: #fff;
  border-radius: min(30px, 2.1875vw);
  font-size: min(22px, 1.5625vw);
  text-align: center;
  color: var(--color-primary);
  font-weight: 300;
  font-style: italic;
  line-height: 1;
  box-shadow: 0 min(2px, 0.1388888888888889vw) min(6px, 0.4166666666666667vw) rgba(0,0,0,0.2);
}
#wrapper #itinerary .itinerary_map_city_title span{
  font-size: min(12px, 0.8333333333333334vw);
  letter-spacing: 0;
  padding-right: min(8px, 0.5555555555555556vw);
}
#wrapper #itinerary .itinerary_map_city_title span.sp_only_flex{
  display: none;
}
#wrapper #itinerary .itinerary_map_city_description{
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  position: absolute;
  z-index: 2;
  bottom: min(12px,0.8333333333333334vw);
  left: 50%;
  width: min(146px, 19.466666666666665vw);
  transform: translateX(-50%);
  font-size: min(10px, 1.3333333333333335vw);
  line-height: 1.2;
  letter-spacing: 0;
  text-align: left;
  font-weight: 300;
  color: #EDEDED;
  text-shadow: 0 0 min(4px, 0.2777777777777778vw) rgba(0,0,0,0.45);
}

@media (max-width: 750px) {
  #wrapper #itinerary{
    overflow-x: hidden;
  }
  #wrapper #itinerary .itinerary_map_nav{
    width: 100%;
  }
  #wrapper #itinerary .itinerary_map_nav ul{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: min(22px, 2.933333333333333vw);
  }
  #wrapper #itinerary .itinerary_map_nav ul li a,#wrapper #itinerary .itinerary_map_nav ul li a.kagoshima_link{
    width: min(140px, 18.666666666666668vw);
    min-height: min(70px, 9.333333333333334vw);
    font-size: min(28px, 3.733333333333333vw);
  }
  #wrapper #itinerary .itinerary_map_nav ul li a span{
    font-size: min(16px, 2.1333333333333333vw);
  }
  #wrapper #itinerary .itinerary_map_wrap {
    width: 100vw;
    max-width: 100vw;
    height: min(648px, 86.4vw);
    position: relative;
    left: 50%;
    margin-left: -50vw;
    transform: none;
    background: url(/shopping/img/special/cruising/2026autumn_us/ca/itinerary/map_bg_sp.jpg) no-repeat center center;
    background-size: 100% auto;
  }
  #wrapper #itinerary .itinerary_map_city_btn_wrap{
    width: min(212px, 28.266666666666666vw);
    height: min(172px, 22.933333333333334vw);
  }
  #wrapper #itinerary .itinerary_map_card{
    width: min(672px, 90vw);
    grid-template-columns: repeat(3, 1fr);
    grid-template-areas:
    "a b c"
    ". . ."
    "d e f";
    height: min(605px, 80.66666666666667vw);
    gap: min(15px, 2vw);
  }
  #wrapper #itinerary .itinerary_map_card #kanazawa{
    transform: translateX(0);
  }
  #wrapper #itinerary .itinerary_map_card #sakata{
    transform: translateX(0);
  }
  #wrapper #itinerary .itinerary_map_card #hakodate {
    transform: translateX(0);
  }
  #wrapper #itinerary .itinerary_map_card #tokyo {
    transform: translateX(0);
  }
  #wrapper #itinerary .itinerary_map_card #jeju{
    transform: translateY(0);
  }
  #wrapper #itinerary .itinerary_map_card #kagoshima{
    transform: translateY(0);
  }
  #wrapper #itinerary .itinerary_map_card #tokyo {
    transform: translateY(0);
  }
  #wrapper #itinerary .itinerary_map_card #kanazawa,#wrapper #itinerary .itinerary_map_card #sakata,#wrapper #itinerary .itinerary_map_card #hakodate {
    align-self: start;
  }
  #wrapper #itinerary .itinerary_map_card #jeju, #wrapper #itinerary .itinerary_map_card #kagoshima,#wrapper #itinerary .itinerary_map_card #tokyo {
    align-self: end;
  }
  #wrapper #itinerary .itinerary_map_city_title{
    gap: min(8px, 1.0666666666666667vw);
    top: min(10px, 1.3333333333333333vw);
    width: min(188px, 25.066666666666666vw);
    height: min(30px, 4vw);
    font-family: var(--font-family-noto);
    font-size: min(22px, 2.933333333333333vw);
    line-height: 1;
    letter-spacing: 0;
    box-shadow: 0 min(2px, 0.26666666666666666vw) min(6px, 0.8vw) rgba(0,0,0,0.2);
  }
  #wrapper #itinerary .itinerary_map_city_title span{
    font-size: min(16px, 2.1333333333333333vw);
  }
  #wrapper #itinerary .itinerary_map_city_title span.sp_only_flex{
    display: inline-flex;
    align-items: center;
    flex-wrap: nowrap;
  }
  #wrapper #itinerary .itinerary_map_city_title span.sp_only{
    display: inline;
    letter-spacing: -0.2em;
  }
  #wrapper #itinerary .itinerary_map_city_description{
    bottom: min(15px, 2vw);
    font-size: min(10px, 1.3333333333333335vw);
    text-align: center;
  }
}

/* ----city detail----*/
#wrapper #itinerary .itinerary_city_detail_wrap {
  margin: min(30px, 2.1875vw) auto min(37px, 2.6041666666666667vw);
}
#wrapper #itinerary .itinerary_city_detail_wrap .itinerary_city_detail_content{
  align-items: flex-end;
}
#wrapper #itinerary .itinerary_city_detail {
  width: min(1000px, 71.875vw);
  height: min(800px, 57.8125vw);
  margin: 0 auto;
  padding: min(50px, 3.59375vw) min(70px, 4.930555555555555vw);
  background-color: #F8F6F4;
  border-radius: min(20px, 1.4583333333333333vw);
  box-shadow: min(2px, 0.1388888888888889vw) min(4px, 0.2777777777777778vw) min(8px, 0.5555555555555556vw) rgba(0,0,0,0.2);
}
#wrapper #itinerary h3.itinerary_city_detail_title {
  margin-bottom: min(20px, 1.4583333333333333vw);
  font-size: min(38px, 2.638888888888889vw);
  text-align: center;
  color: var(--color-primary);
  font-weight: 500;
}
#wrapper #itinerary h3.itinerary_city_detail_title span{
  padding-left: 0.5em;
}
#wrapper #itinerary .itinerary_day1_item01 {
  flex: 0 0 auto;
  width: min(256px, 17.916666666666668vw);
  margin-left: auto;
  margin-right: 0;
  text-align: center;
}
#wrapper #itinerary .itinerary_day1_img02 {
  width: min(174px, 12.1875vw);
  margin-right: 0;
  margin-left: auto;
  padding-bottom: min(15px, 1.0416666666666667vw);
}
#wrapper #itinerary .itinerary_day1_item01 p span,
#wrapper #itinerary .itinerary_day1_item02 p span,
#wrapper #itinerary .itinerary_day2_pc_item02 p span {
  display: block;
  font-size: min(14px, 1.0416666666666667vw);
  letter-spacing: 0;
  padding-top: 0.5em;
  text-align: left;
}
#wrapper #itinerary .itinerary_day1_img03 {
  width: min(292px, 20.138888888888889vw);
  margin: 0 min(16px, 1.1111111111111112vw) 0 min(50px, 3.59375vw);
}
#wrapper #itinerary h4 {
  font-family: var(--font-family-oswald);
  font-size: min(20px, 1.4583333333333333vw);
  line-height: 1.35;
  letter-spacing: 0.03em;
  font-weight: 600;
  padding: min(7px, 0.5208333333333334vw) 0 min(16.5px, 1.1574074074074074vw);
}
#wrapper #itinerary .itinerary_day1_item02 h5 {
  padding-bottom: min(10px, 0.7291666666666667vw);
  font-family: var(--font-family-oswald);
  font-size: min(20px, 1.4583333333333333vw);
}

#wrapper #itinerary .itinerary_city_title_wrap,
#wrapper #itinerary .itinerary_city_title_wrap02 {
  align-items: center;
}
#wrapper #itinerary .itinerary_city_title_wrap h3{
  width: min(666px, 46.45833333333333vw);
}
#wrapper #itinerary .itinerary_city_title_wrap02 h3{
  width: min(546px, 38.28125vw);
}
#wrapper #itinerary .itinerary_city_title_wrap p,
#wrapper #itinerary .itinerary_city_title_wrap02 p{
  margin-left: auto;
  margin-right: 0;
  font-size: min(18px, 1.25vw);
  line-height: 1.35;
  letter-spacing: 0;
  font-weight: 400;
  text-align: right;
  will-change: nowrap;
}
#wrapper #itinerary .itinerary_city_title_wrap p .itinerary_icon03,
#wrapper #itinerary .itinerary_city_title_wrap02 p .itinerary_icon03{
  display: inline-block;
  width: min(21px, 1.4583333333333333vw);
  height: min(25px, 1.7361111111111112vw);
}
#wrapper #itinerary .itinerary_day2_content_wrap{
  align-items: flex-start;
}
#wrapper #itinerary .itinerary_day2_item01 p{
  width: min(402px, 28.020833333333332vw);
}
/* Day2の2カラム内画像：幅を縮められるようにする */
#wrapper #itinerary .itinerary_city_detail_2column {
  align-items: flex-start;
  gap: min(39px, 2.7083333333333335vw);
  min-width: 0;
}
#wrapper #itinerary .itinerary_city_detail_2column .day2 h4{
  padding: min(7px, 0.5208333333333334vw) 0 min(33px, 2.361111111111111vw);
}
#wrapper #itinerary .itinerary_city_detail_2column h4.p_small{
  padding: min(7px, 0.5208333333333334vw) 0;
}
#wrapper #itinerary .itinerary_city_detail_2column h4{
  padding: min(7px, 0.5208333333333334vw) 0 0.8em;
}
#wrapper #itinerary .itinerary_city_detail_2column p{
  padding-bottom: min(20px, 1.4583333333333333vw);
  line-height: 1.4;
  letter-spacing: 0;
}

#wrapper #itinerary .itinerary_day_item01 img.itinerary_left_img{
  width: 100%;
  min-width: min(570px, 40.05208333333333vw);
}
#wrapper #itinerary .itinerary_day_item02 img.itinerary_right_img{
  width: min(250px, 17.36111111111111vw);
}
#wrapper #itinerary .itinerary_day2_img04{
  width: min(222px, 15.416666666666668vw);
  margin: 0 min(16px, 1.1111111111111112vw) 0 min(50px, 3.59375vw);
}
#wrapper #itinerary .itinerary_city_detail_1column h4{
  padding-top: min(14px, 1.0416666666666667vw);
}
#wrapper #itinerary .note_wrap_bottom{
  margin-top: min(30px, 2.1875vw);
}

/* ----sec04 city スライダー（Embla・矢印・ドット）---- */
#wrapper #itinerary .itinerary_city_slider {
  position: relative;
  width: min(1100px, 76.38888888888889vw);
  margin: 0 auto;
  overflow: visible;
}
/* Embla viewport：1枚ずつ表示・余白はスライド内 padding で確保 */
#wrapper #itinerary .itinerary_city_track.embla {
  overflow: hidden;
  padding: 0;
  box-sizing: border-box;
}
#wrapper #itinerary .itinerary_city_track .embla__container {
  display: flex;
  touch-action: pan-y pinch-zoom;
}
#wrapper #itinerary .itinerary_city_track .embla__slide {
  flex: 0 0 100%;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: min(15px, 1.0416666666666667vw) min(20px, 1.388888888888889vw) min(25px, 1.7361111111111112vw);
}
/* 影が切れないようスライド周りに余白（影分を含める） */
#wrapper #itinerary .itinerary_city_slider .slick-list {
  margin: 0 min(-20px, -1.388888888888889vw);
  padding: min(15px, 1.0416666666666667vw) min(20px, 1.388888888888889vw) min(25px, 1.7361111111111112vw);
}
#wrapper #itinerary .itinerary_city_slider .slick-slide {
  padding: 0;
  height: auto;
}
#wrapper #itinerary .itinerary_city_slider .slick-slide > div {
  height: 100%;
}
#wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow {
  position: absolute;
  z-index: 2;
  top: 50%;
  transform: translateY(-50%);
  width: min(50px, 3.59375vw);
  height: min(50px, 3.59375vw);
  border: none;
  border-radius: 50%;
  background: rgba(171, 171, 171, 0.6);
  color: #fff;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s;
  backface-visibility: hidden;
  contain: layout style;
}
#wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow:hover {
  background: rgba(171, 171, 171, 0.75);
}
#wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow_prev {
  left: min(20px, 1.388888888888889vw);
}
#wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow_next {
  right: min(20px, 1.388888888888889vw);
}
/* 前: ‹ / 次: › を span で表示 */
#wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow_icon {
  line-height: 1;
  font-weight: 300;
  display: inline-block;
  width: min(15px, 1.0416666666666667vw);
  height: min(15px, 1.0416666666666667vw);
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
#wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow_prev .itinerary_city_arrow_icon {
  margin-left: 0.5em;
  transform: rotate(-135deg);
}
#wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow_next .itinerary_city_arrow_icon {
  margin-right: 0.5em;
  transform: rotate(45deg);
}
#wrapper #itinerary .itinerary_city_slider .slick-dots {
  position: relative;
  bottom: 0;
  margin-top: min(-13px, -0.9259259259259259vw);
}
#wrapper #itinerary .itinerary_city_slider .slick-dots li button {
  position: relative;
  width: 10px;
  height: 10px;
  padding: 0;
  border-radius: 50%;
}
#wrapper #itinerary .itinerary_city_slider .slick-dots li button::before {
  position: absolute;
  width: 10px;
  height: 10px;
  font-size: 0;
  line-height: 0;
  content: '';
  border-radius: 50%;
  background: currentColor;
  opacity: 0.25;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #C1BDBD;
}
#wrapper #itinerary .itinerary_city_slider .slick-dots li.slick-active button::before {
  opacity: 1;
}
#wrapper #itinerary .itinerary_city_slider .itinerary_city_detail_wrap {
  margin-left: 0;
  margin-right: 0;
}

@media (max-width: 750px) {
  #wrapper #itinerary h3.itinerary_city_detail_title{
    font-size: min(38px, 5.066666666666667vw);
    text-align: left;
  }
  #wrapper #itinerary .itinerary_city_slider{
    width: 100%;
    padding-left: min(15px, 1.3333333333333333vw);
    padding-right: min(10px, 1.3333333333333333vw);
    box-sizing: border-box;
  }
  #wrapper #itinerary .itinerary_city_slider .slick-list{
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }
  #wrapper #itinerary .itinerary_city_detail{
    width: 100%;
    max-width: min(700px, 93.33333333333333vw);
    height: min(870px, 116vw);
    margin-inline: auto;
    padding: min(30px, 4vw) min(40px, 5.333333333333333vw);
    box-shadow: min(2px, 0.26666666666666666vw) min(4px, 0.5333333333333333vw) min(12px, 1.6vw) rgba(0, 0, 0, 0.2);
  }
  #wrapper #itinerary .itinerary_city_slider .slick-slide > div{
    margin-top: min(30px, 4vw);
    height: min(870px, 116vw);
  }
  #wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow{
    width: min(50px, 6.666666666666667vw);
    height: min(50px, 6.666666666666667vw);
  }
  #wrapper #itinerary .itinerary_city_slider .itinerary_city_arrow_icon{
    width: min(15px, 2vw);
    height: min(15px, 2vw);
  }
  #wrapper #itinerary h4{
    padding-top: min(10px, 1.3333333333333333vw);
    font-size: min(24px, 3.2vw);
  }
  #wrapper #itinerary .itinerary_city_detail_wrap .itinerary_city_detail_content{
    flex-direction: column;
    align-items: flex-start;
  }
  #wrapper #itinerary .itinerary_day1_item01{
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    width: 100%;
    padding: 0;
  }
  #wrapper #itinerary .itinerary_day1_img02{
    width: min(195px, 26vw);
    padding-bottom: 0;
  }
  #wrapper #itinerary .itinerary_day1_item01 p{
    padding-top: min(20px, 2.6666666666666665vw);
    font-size: min(18px, 2.4vw);
  }
  #wrapper #itinerary .itinerary_day1_item02 p,
  #wrapper #itinerary .itinerary_day2_pc_item02 p{
    font-size: min(18px, 2.4vw);
    letter-spacing: 0;
  }
  #wrapper #itinerary .itinerary_day2_item02 p{
    margin-top: min(17px, 2.2666666666666666vw);
  }
  #wrapper #itinerary .itinerary_day1_item01 p span,
  #wrapper #itinerary .itinerary_day1_item02 p span,
  #wrapper #itinerary .itinerary_day2_pc_item02 p span{
    font-size: min(16px, 2.1333333333333333vw);
  }
  #wrapper #itinerary .itinerary_day1_item02 h5{
    font-size: min(24px, 3.2vw);
  }
  #wrapper #itinerary .itinerary_day1_item02_sp {
    width: 100%;
    margin-top: min(30px, 4vw);
    flex-direction: row-reverse;
    align-items: flex-start;
  }
  #wrapper #itinerary .itinerary_day1_img03{
    width: min(280px, 37.33333333333333vw);
    margin: auto;
  }
  #wrapper #itinerary .itinerary_city_detail_2column{
    flex-direction: column;
    align-items: flex-start;
    justify-content: space-between;
    gap: min(11px, 1.4666666666666666vw);
    min-width: 0;
  }
  #wrapper #itinerary .itinerary_day_item01 img.itinerary_left_img{
    width: 100%;
  }
  #wrapper #itinerary .itinerary_day_item02{
    display: flex;
    gap: min(30px, 4vw);
  }
  #wrapper #itinerary .itinerary_day_item02 img.itinerary_right_img{
    width: min(294px, 39.2vw);
    margin-inline: auto;
    padding: 0;
  }
  #wrapper #itinerary .sp_only .itinerary_day2_content_wrap{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: min(40px, 5.333333333333333vw);
  }
  #wrapper #itinerary .itinerary_day2_img04{
    width: min(294px, 39.2vw);
    margin-inline: 0;
    padding: 0;
  }
  #wrapper #itinerary .itinerary_day2_item01{
    flex: 0 0 auto;
    width: min(285px, 38vw);
  }
  #wrapper #itinerary .itinerary_day2_item02{
    flex: 0 0 auto;
    width: min(294px, 39.2vw);
  }
  #wrapper #itinerary .itinerary_city_detail_2column p{
    width: 100%;
    padding-top: 0;
    font-size: min(18px, 2.4vw);
  }
  #wrapper #itinerary .itinerary_city_detail_2column h4{
    padding: min(10px, 1.3333333333333333vw) 0 ;
  }
  #wrapper #itinerary .itinerary_city_title_wrap p .itinerary_icon03, #wrapper #itinerary .itinerary_city_title_wrap02 p .itinerary_icon03{
    width: min(21px, 2.8vw);
    height: min(25px, 3.3333333333333335vw);
  }
  #wrapper #itinerary .itinerary_city_title_wrap p, #wrapper #itinerary .itinerary_city_title_wrap02 p{
    font-size: min(20px, 2.6666666666666665vw);
    line-height: 1.1;
  }
  #wrapper #itinerary .itinerary_city_title_wrap p, #wrapper #itinerary .itinerary_city_title_wrap02 p{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: min(8px, 1.0666666666666667vw);
    text-align: left;
  }
  #wrapper #itinerary .itinerary_day_item01 .day11_note{
    font-size: min(18px, 2.4vw);
  }
  #wrapper #itinerary .itinerary_city_slider .slick-dots {
    margin-top: 0;
  }
}

/* ========== Section05 Special cruise ship MSC Bellissima ========== */
#wrapper #ship .sec_inner h2{
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
}
#wrapper #ship .sec_inner h2 span.font_italic{
  font-family: var(--font-family-roboto-condensed);
  font-style: italic;
  font-weight: 700;
}
#wrapper #ship .ship_cards_wrap{
  margin-top: min(30px, 2.1875vw);
  margin-bottom: min(30px, 2.1875vw);
}
#wrapper #ship .ship_card01,
#wrapper #ship .ship_card02{
  align-items: center;
}
#wrapper #ship .ship_card01{
  margin-bottom: min(8px, 0.5555555555555556vw);
}
#wrapper #ship .ship_card01 p,
#wrapper #ship .ship_card02 p{
  font-size: min(18px, 1.25vw);
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 400;
}
#wrapper #ship .ship_card01 .ship_card01_text_wrap,
#wrapper #ship .ship_card02 .ship_card02_text_wrap{
  width: min(344px, 24.020833333333332vw);
  flex-shrink: 0;
  margin-right: 0;
  text-align: center;
}
#wrapper #ship .ship_card01 h3{
  padding-bottom: min(20px, 1.4583333333333333vw);
  font-family: var(--font-family-oswald);
  font-weight: 300;
  font-size: min(34px, 2.361111111111111vw);
  letter-spacing: 0.01em;
  line-height: 1.35;
}
/* sec05 動画：左揃え・中央は残り幅がgap・動画サイズそのまま */
#wrapper #ship .ship_card01_video_wrap {
  position: relative;
  width: min(635px, 44.19444444444444vw);
  flex-shrink: 0;
  margin-left: auto;
}
#wrapper #ship .ship_card01_video_wrap .ship_card01_video {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
#wrapper #ship .ship_card01_video_wrap .ship_card01_fallback {
  position: absolute;
  left: 0;
  top: 0;
  display: none;
}
#wrapper #ship .ship_card01_video_wrap.is-fallback .ship_card01_video {
  display: none;
}
#wrapper #ship .ship_card01_video_wrap.is-fallback .ship_card01_fallback {
  display: block;
  position: static;
}
#wrapper #ship .ship_card02_imgs_wrap{
  display: flex;
  flex-wrap: wrap;
  gap: min(8px, 0.5555555555555556vw);
  width: min(635px, 44.19444444444444vw);
  flex-shrink: 0;
  margin-left: auto;
}
#wrapper #ship .ship_card02_imgs_wrap img{
  width: calc(50% - min(4px, 0.2777777777777778vw));
  height: auto;
  object-fit: cover;
}

@media (max-width: 750px) {
  #wrapper #ship .ship_card01{
    flex-direction: column;
    margin-bottom: min(8px, 1.0666666666666667vw);
  }
  #wrapper #ship .ship_card01 .ship_card01_text_wrap, #wrapper #ship .ship_card02 .ship_card02_text_wrap, #wrapper #ship .ship_card01_video_wrap, #wrapper #ship .ship_card02_imgs_wrap{
    gap: min(8px, 1.0666666666666667vw);
    width: 100%;
  }
  #wrapper #ship .sec_inner h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #ship .ship_card01 h3{
    font-size: min(38px, 5.066666666666667vw);
    padding-bottom: min(45px, 6vw);
  }
  #wrapper #ship .ship_card01_text_wrap p{
    text-align: left;
    font-size: min(24px, 3.2vw);
    padding-bottom: min(40px, 5.333333333333333vw);
    line-height: 1.6;
    letter-spacing: -0.01em;
  }
  #wrapper #ship .ship_card02{
    gap: min(8px, 1.0666666666666667vw);
  }
  #wrapper #ship .ship_card02_imgs_wrap img{
    width: calc(50% - min(4px, 0.5333333333333333vw));
  }
}

/*---sec05 ship 横スクロール---*/
#wrapper #ship .ship_slider {
  margin-top: min(60px, 4.236111111111111vw);
  max-width: 100%;
  margin-inline: auto;
  overflow: visible;
}
#wrapper #ship .ship_track {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  margin: 0;
  box-sizing: border-box;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
#wrapper #ship .ship_track::-webkit-scrollbar {
  display: none;
}
#wrapper #ship .ship_track .ship_slider_item{
  flex: 0 0 auto;
  min-width: 0;
  margin-right: min(16px, 2.1333333333333333vw);
}
#wrapper #ship .ship_slider_item{
  position: relative;
  width: min(310px, 21.694444444444443vw);
  flex-shrink: 0;
}
#wrapper #ship .ship_slider_item:last-child{
  margin-right: 0;
}
#wrapper #ship .ship_slider_item p{
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  margin: 0;
  padding: min(12px, 0.8333333333333334vw) 0;
  background-color: rgba(255, 255, 255, 0.6);
  font-size: min(18px, 1.25vw);
  line-height: 1.35;
  letter-spacing: 0;
  font-weight: 400;
  text-align: center;
}
/* sec05 スライドバー（Registration / rooms と同じ色） */
#wrapper #ship .ship_slider .ship_slick_bar {
  --slick-progress: 0%;
  --slick-thumb-x: -50%;
  position: relative;
  display: flex;
  width: 50%;
  max-width: min(500px, 34.72vw);
  height: min(10px, 0.6944444444444444vw);
  margin: min(28px, 1.9444444444444444vw) auto 0 !important;
  padding: 0;
  list-style: none;
  background-color: #E6E4E4;
  border-radius: 999px;
  overflow: hidden;
  cursor: grab;
  user-select: none;
}
#wrapper #ship .ship_slider .ship_slick_bar:active {
  cursor: grabbing;
}
#wrapper #ship .ship_slider .ship_slick_bar .ship_slick_thumb,
#wrapper #ship .ship_slider .ship_slick_bar .ship_slick_thumb:active {
  position: absolute;
  left: var(--slick-progress, 0%);
  top: 0;
  transform: translate(var(--slick-thumb-x, -50%), 0);
  width: 40%;
  height: 100%;
  border-radius: 999px;
  background-color: #C1BDBD;
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
  z-index: 1;
  transition: left 0.1s ease, transform 0.1s;
  pointer-events: auto;
  cursor: grab;
  box-sizing: border-box;
}
#wrapper #ship .ship_slider .ship_slick_bar .ship_slick_thumb:active {
  cursor: grabbing;
}
#wrapper #ship .ship_slider .ship_slick_bar li {
  display: none !important;
}
#wrapper #ship .ship_slider .ship_slick_bar li button,
#wrapper #ship .ship_slider .ship_slick_bar li button::before {
  display: none !important;
}

@media (max-width: 750px) {
  #wrapper #ship .ship_slider_item{
    width: min(250px, 33.33333333333333vw);
    height: min(238px, 31.733333333333334vw);
  }
  #wrapper #ship .ship_slider_item p{
    padding: min(7px, 0.9333333333333333vw) 0;
    font-size: min(18px, 2.4vw);
    font-weight: 600;
  }
  #wrapper #ship .ship_slider .ship_slick_bar{
    width: min(500px, 66.66666666666666vw);
    max-width: 100%;
    height: min(10px, 1.3333333333333335vw);
    margin-top: min(30px, 4vw)!important;
  }
}

/* ========== Section06 Dining ========== */
#wrapper #dining .sec_inner h2{
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
}
#wrapper #dining .flex{
  align-items: flex-start;
  width: min(1000px, 70.3125vw);
  margin: min(30px, 2.1875vw) 0;
  gap: min(20px, 1.3888888888888888vw);
}
#wrapper #dining .dining_card01,
#wrapper #dining .dining_card02 {
  flex: 1;
  min-width: 0;
  max-width: min(490px, 34.166666666666664vw);
}
#wrapper #dining .dining_card01 h3,
#wrapper #dining .dining_card02 h3{
  padding-bottom: min(20px, 1.4583333333333333vw);
  font-family: var(--font-family-oswald);
  font-size: min(34px, 2.361111111111111vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  font-weight: 500;
  text-align: center;
}
#wrapper #dining .dining_card01 h4,
#wrapper #dining .dining_card02 h4{
  padding: min(37px, 2.5416666666666665vw) 0 min(16.5px, 1.1574074074074074vw);
  font-family: var(--font-family-oswald);
  font-size: min(24px, 1.6666666666666667vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  font-weight: 500;
  text-align: center;
}
#wrapper #dining .dining_card01 h4 span,
#wrapper #dining .dining_card02 h4 span{
  font-size: min(18px, 1.25vw);
  font-weight: 400;
}
#wrapper #dining .dining_note_list li{
  font-weight: 400;
}
#wrapper #dining .dining_note_list li span{
  font-size: min(14px,0.9722222222222222vw);
}

#wrapper #dining .dining_note_wrap{
  display: flex;
  justify-content: center;
  align-items: center;
}
#wrapper #dining .dining_note{
  font-size: min(18px, 1.25vw);
  font-weight: 400;
  text-align: left;
  line-height: 1.35;
  letter-spacing: 0;
}

#wrapper #dining .dining_card03_wrap{
  justify-content: center;
  align-items: flex-start;
  gap: min(16px, 1.1111111111111112vw);
  text-align: center;
}
#wrapper #dining .dining_card03{
  width: min(238px, 16.597222222222222vw);
}
#wrapper #dining .dining_card03 p{
  padding-top: min(16px, 1.1111111111111112vw);
  font-size: min(18px, 1.25vw);
  line-height: 1.3;
}

/* sec06 スライダー：Embla・矢印なし・ドットは画像内の下・幅500px制御 */
#wrapper #dining .dining_slider_wrap {
  position: relative;
  width: min(500px, 34.72vw);
  max-width: 100%;
  margin: 0 auto;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  box-sizing: border-box;
}
#wrapper #dining .dining_left_slider.embla {
  overflow: hidden;
  width: 100% !important;
  margin-inline: auto;
  height: 100% !important;
  box-sizing: border-box;
}
#wrapper #dining .dining_left_slider .embla__container {
  display: flex;
  touch-action: pan-y pinch-zoom;
  height: 100%;
}
#wrapper #dining .dining_left_slider .embla__slide {
  flex: 0 0 100%;
  min-width: 0;
  height: 100%;
}
#wrapper #dining .dining_left_slider .embla__slide img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
#wrapper #dining .dining_left_slider .slick-list {
  width: 100% !important;
  height: 100% !important;
  overflow: hidden;
}
#wrapper #dining .dining_left_slider .slick-track {
  height: 100% !important;
}
#wrapper #dining .dining_left_slider .slick-slide {
  width: min(500px, 34.72vw) !important;
  max-width: 100% !important;
  height: 100% !important;
}
#wrapper #dining .dining_left_slider .slick-slide > div {
  height: 100%;
}
#wrapper #dining .dining_left_slider .slick-slide img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
#wrapper #dining .dining_slider_wrap .slick-dots {
  position: absolute;
  bottom: min(2px, 0.1388888888888889vw);
  left: 0;
  right: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: center;
  z-index: 2;
}
#wrapper #dining .dining_slider_wrap .slick-dots li {
  display: inline-block;
  margin: 0 min(4px, 0.2777777777777778vw);
  vertical-align: middle;
}
#wrapper #dining .dining_slider_wrap .slick-dots li button {
  font-size: 0;
  line-height: 0;
  width: 10px;
  height: 10px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: #C1BDBD;
  cursor: pointer;
}
#wrapper #dining .dining_slider_wrap .slick-dots li button::before {
  content: none;
}
#wrapper #dining .dining_slider_wrap .slick-dots li.slick-active button {
  background: #fff;
}
#wrapper #dining .dining_card01 ul,
#wrapper #dining .dining_card02 ul{
  margin: 0 auto;
  list-style-type: disc;
  list-style-position: outside;
  padding-left: min(22px, 1.5277777777777777vw);
  font-size: min(18px, 1.25vw);
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 300;
  text-align: left;
}
#wrapper #dining .dining_card01 ul li::marker,
#wrapper #dining .dining_card02 ul li::marker {
  font-size: 0.6em;
}


@media (max-width: 750px) {
  #wrapper #dining{
    overflow-x: hidden;
  }
  #wrapper #dining .sec_inner h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #dining .dining_cards_wrap_top{
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }
  #wrapper #dining .dining_card01,
  #wrapper #dining .dining_card02{
    width: 100%;
    max-width: 100%;
  }
  #wrapper #dining .dining_slider_wrap{
    width: min(660px, 88vw)!important;
    max-width: 100%!important;
    height: min(360px, 48vw)!important;
    margin-left: auto!important;
    margin-right: auto!important;
    overflow: hidden;
  }
  #wrapper #dining .dining_left_slider{
    width: 100%!important;
    height: 100%!important;
  }
  #wrapper #dining .dining_left_slider .slick-list,
  #wrapper #dining .dining_left_slider .slick-track{
    height: 100%!important;
  }
  #wrapper #dining .dining_left_slider .slick-slide{
    display: flex;
    justify-content: center;
    align-items: center;
    width: min(660px, 88vw)!important;
    height: min(360px, 48vw)!important;
  }
  #wrapper #dining .dining_left_slider .slick-slide > div{
    height: 100%;
    overflow: hidden;
  }
  #wrapper #dining .flex.dining_card03{
    display: flex!important;
  }
  #wrapper #dining .dining_slider_wrap .slick-dots li button{
    width: min(10px, 1.3333333333333335vw);
    height: min(10px, 1.3333333333333335vw);
  }
  #wrapper #dining .dining_card01 ul, #wrapper #dining .dining_card02 ul{
    font-size: min(24px, 3.2vw);
  }
  #wrapper #dining .dining_card02 ul{
    padding-bottom: min(60px, 8vw);
  }
  #wrapper #dining .dining_card01 h4, #wrapper #dining .dining_card02 h4{
    font-size: min(34px, 4.533333333333333vw);
  }
  #wrapper #dining .dining_note_list_wrap{
    width: min(571px, 76.13333333333333vw);
    margin-inline: auto;
    text-align: center;
    padding-bottom: min(60px, 8vw);
  }
  #wrapper #dining .dining_card01 h3, #wrapper #dining .dining_card02 h3{
    font-size: min(38px, 5.066666666666667vw);
  }
  #wrapper #dining .dining_note_list li{
    margin-left: min(10px, 1.3333333333333335vw);
  }
  #wrapper #dining .dining_note_list li span{
    font-size: min(18px, 2.4vw);
  }
  #wrapper #dining .dining_note{
    font-size: min(18px, 2.4vw);
    margin-bottom: min(60px, 8vw);
  }
  #wrapper #dining .dining_note_last{
    margin-top: min(60px, 8vw);
    margin-bottom: 0;
  }
  #wrapper #dining .dining_card03_wrap{
    width: 100%;
    justify-content: space-between;
  }
  #wrapper #dining .dining_card03{
    width: min(150px, 20vw);
    gap: min(18px, 2.4vw);
  }
  #wrapper #dining .dining_card03 p{
    font-size: min(20px, 2.6666666666666665vw);
    white-space: nowrap;
    text-align: center;
  }
}

/* ========== Section07 Special Experience ========== */
#wrapper #excursion{
  padding-bottom: 0;
  margin-bottom: min(60px, 4.236111111111111vw);
}
#wrapper #excursion h2{
  margin-bottom: min(10px, 0.7142857142857143vw);
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  font-weight: 300;
  line-height: 1.5;
  text-align: center;
}
#wrapper #excursion .sec_inner h2 span{
  padding-left: min(20px, 1.4583333333333333vw);
  font-family: var(--font-family-noto);
  font-size: min(14px, 0.9722222222222222vw);
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1.35;
  color: #000
}
#wrapper #excursion .excursion_note{
  font-size: min(18px, 1.25vw);
  line-height: 1.35;
  letter-spacing: 0;
  font-weight: 400;
  text-align: center;
}
#wrapper #excursion .excursion_cards_wrap{
  align-items: flex-start;
  gap: min(20px, 1.4583333333333333vw);
  margin-top: min(40px, 2.8125vw);
}
#wrapper #excursion .excursion_card{
  width: min(319px, 22.01388888888889vw);
}
#wrapper #excursion .excursion_card h3{
  font-family: var(--font-family-oswald);
  padding: min(37px, 2.5416666666666665vw) 0 min(10px, 0.7291666666666667vw);
  font-size: min(24px, 1.6666666666666667vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  font-weight: 600;
  text-align: center;
}
#wrapper #excursion .excursion_card p{
  font-size: min(18px, 1.25vw);
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 400;
}
@media screen and (max-width: 750px) {
  #wrapper #excursion .sec_inner h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #excursion .sec_inner h2 span{
    display: block;
    padding-bottom: min(12px, 1.6vw);
    font-size: min(20px, 2.6666666666666665vw);
  } 
  #wrapper #excursion .excursion_note{
    padding-bottom: min(42px, 5.6vw);
    font-size: min(24px, 3.2vw);
    text-align: left;
  }
  #wrapper #excursion .excursion_cards_wrap{
    flex-direction: column;
    gap: min(30px, 4vw);
    margin-top: 0;
  }
  #wrapper #excursion .excursion_card img{
    width: min(320px, 42.666666666666664vw);
    height: min(320px, 42.666666666666664vw);
  }
  #wrapper #excursion .excursion_card{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: min(20px, 2.6666666666666665vw);
    width: 100%;
  }
  #wrapper #excursion .excursion_card h3{
    padding-top: 0;
    font-size: min(34px, 4.533333333333333vw);
    text-align: left;
    font-weight: 400;
  }
  #wrapper #excursion .excursion_card p{
    font-size: min(24px, 3.2vw);
    line-height: 1.5;
    letter-spacing: 0;
  }
  #wrapper #excursion .sec_inner{
    padding-bottom: min(60px, 8vw);
  }
}

/* ========== Section08 Travel with Peace of Mind ========== */
#wrapper #support{
  position: relative;
  padding-top: min(175px, 12.5vw);
  background-color: #ECF5F9;
}
#wrapper #support::before{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: min(113px, 7.8125vw);
  background: url("/shopping/img/special/cruising/2026autumn_us/ca/support/bg_top_pc.png") no-repeat bottom center / 100% auto;
  z-index: 0;
}
#wrapper #support .support_cards_wrap,
#wrapper #support .support_cards_wrap_inner{
  gap: min(37px, 2.638888888888889vw);
}
#wrapper #support .support_card{
  width: min(319px, 22.01388888888889vw);
}
#wrapper #support .support_card h2{
  font-family: var(--font-family-oswald);
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.05em;
  line-height: 1.35;
}
#wrapper #support .support_card p{
  padding-top: min(10px, 0.7291666666666667vw);
  font-size: min(18px, 1.25vw);
  line-height: 1.35;
  letter-spacing: 0.05em;
  font-weight: 400;
}
#wrapper #support .support_card h3{
  padding-top: min(37px, 2.638888888888889vw);
  font-family: var(--font-family-oswald);
  font-size: min(24px, 3.2vw);
  letter-spacing: 0.05em;
  line-height: 1.35;
  font-weight: 500;
}
#wrapper #support .support_card .card_top{
  padding: 0 0 min(10px, 0.7291666666666667vw);
}
#wrapper #support .support_card01{
  align-self: center;
}
#wrapper #support .support_card02{
  align-self: flex-start;
  width: min(348px, 24.166666666666668vw);
  text-align: center;
}

@media screen and (max-width: 750px) {
  #wrapper #support{
    position: relative;
    margin-top: 0;
    padding: min(125px, 16.666666666666668vw) 0 min(60px, 8vw);
  }
  #wrapper #support .support_cards_wrap{
    flex-direction: column;
    gap: min(44px, 6.222222222222222vw);
  }
  #wrapper #support .support_card .card_top{
    font-size: min(28px, 3.733333333333333vw);
  }
  #wrapper #support .support_card{
    width: 100%;
    text-align: center;
  }
  #wrapper #support .support_cards_wrap_inner{
    gap: min(37px, 5vw);
  }
  #wrapper #support .support_card h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #support::before{
    top: 0;
    left: 0;
    width: 100%;
    height: min(75px, 10vw);
    background: url("/shopping/img/special/cruising/2026autumn_us/ca/support/bg_top_sp.png") no-repeat bottom center / 100% auto;
  }
  #wrapper #support .support_card02 h3{
    padding-top: min(30px, 4vw);
    font-family: var(--font-family-oswald);
    font-weight: 500;
    font-size: min(34px, 4.533333333333333vw);
    line-height: 1;
  }
  #wrapper #support .support_card p{
    font-size: min(24px, 3.2vw);
    line-height: 1.5;
    letter-spacing: 0;
  }
}

/* ========== Section09 Customer Reviews ========== */
#wrapper #reviews{
  padding-top: min(80px, 5.787037037037037vw);
}
#wrapper #reviews .reviews_title_wrap{
  position: relative;
  padding-bottom: min(50px, 3.5714285714285716vw);
}
#wrapper #reviews .reviews_title_wrap::before{
  content: '';
  position: absolute;
  top: min(-22px, -1.5740740740740742vw);
  right: min(17px, 1.25vw);
  width: min(202px, 14.0625vw);
  height: min(120px, 8.680555555555555vw);
  background: url("/shopping/img/special/cruising/2026autumn_us/ca/common/satisfaction_icon.png") no-repeat top right / 100% auto;
}
#wrapper #reviews .sec_inner h2{
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  font-weight: 300;
  line-height: 1.35;
}
#wrapper #reviews .sec_inner h3{
  font-family: var(--font-family-oswald);
  font-size: min(24px, 1.6666666666666667vw);
  letter-spacing: 0.03em;
  font-weight: 400;
  line-height: 1.35;
}
#wrapper #reviews .card_last_title{
  grid-column: 1 / -1;
  text-align: left;
  white-space: nowrap;
}
#wrapper #reviews .reviews_cards_wrap{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(47px, 3.333333333333333vw) min(37px, 2.638888888888889vw);
  width: 100%;
}
#wrapper #reviews .reviews_card{
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: min(23px, 1.6145833333333333vw);
  width: min(481.5px, 33.57142857142857vw);
  height: min(360px, 25.416666666666668vw);
  padding: min(60px, 4.236111111111111vw) min(32px, 2.2916666666666665vw) 0;
  background-color: #F8F6F4;
  font-size: min(18px, 1.25vw);
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 400;
}
#wrapper #reviews .reviews_card.card_last{
  grid-column: 1 / -1;
  width: 100%;
  padding-bottom: min(66px, 4.583333333333333vw);
}
#wrapper #reviews .reviews_card.card_last .reviews_card_content{
  height: 100%;
  padding-right: min(20px, 1.4583333333333333vw);
  overflow-y: auto;
}
#wrapper #reviews .reviews_card::before{
  content: '';
  position: absolute;
  top: min(-20px, -1.4583333333333333vw);
  left: min(28px, 1.994047619047619vw);
  width: min(65px, 4.583333333333333vw);
  height: min(65px, 4.583333333333333vw);
  background: url("/shopping/img/special/cruising/2026autumn_us/ca/reviews/icon.png") no-repeat top center / 100% auto;
}
#wrapper #reviews .reviews_note{ 
  margin-top: min(30px, 2.142857142857143vw);
  font-size: min(14px, 1.0416666666666667vw);
  font-weight: 400;
  line-height: 1.35;
  letter-spacing: 0;
}
#wrapper #reviews .reviews_note span{
  padding-left: 0.5em;
}

@media screen and (max-width: 750px) {
  #wrapper #reviews .sec_inner h2 {
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #reviews .sec_inner h3{
    padding-bottom: min(50px, 6.666666666666667vw);
    font-size: min(24px, 3.2vw);
  }
  #wrapper #reviews .reviews_title_wrap::before{
    top: 0;
    right: 0;
    width: min(202px, 26.93333333333333vw);
    height: min(120px, 16vw);
  }
  #wrapper #reviews .reviews_cards_wrap{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: min(40px, 5.333333333333333vw);
  }
  #wrapper #reviews .reviews_card{
    gap: 2em;
    width: 100%;
    height: min(520px, 69.33333333333333vw);
    padding: min(60px, 8vw) min(32px, 4.266666666666667vw) 0;
    font-size: min(24px, 3.2vw);
  }
  #wrapper #reviews .reviews_card p{
    font-size: min(24px, 3.2vw);
    letter-spacing: 0.05em;
    line-height: 1.6;
  }
  #wrapper #reviews .reviews_card.card_last{
    width: 100%;
    max-width: 100%;
    height: min(520px, 69.33333333333333vw);
    padding-bottom: min(55px, 7.333333333333333vw);
  }
  #wrapper #reviews .reviews_card.card_last .reviews_card_content p{
    font-size: min(24px, 3.2vw);
    padding-bottom: min(53px, 7.06vw);
  }
  #wrapper #reviews .reviews_card::before{
    left: min(27.5px, 3.6666666666666665vw);
    width: min(63px, 8.4vw);
    height: min(66px, 8.799999999999999vw);
  }
  #wrapper #reviews .reviews_note{
    margin-top: min(30px, 4vw);
    font-size: min(20px, 2.6666666666666665vw);
  }
  #wrapper #reviews .reviews_cards_wrap .card_last_title{
    align-self: flex-start;
    text-align: left;
    width: 100%;
    white-space: normal;
  }
}

/* ========== Section10 From Registration to Embarkation ========== */
#wrapper #guide h2{
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
}
#wrapper #guide .guide_title_sub{
  font-size: min(22px, 1.5625vw);
  line-height: 1.35;
  letter-spacing: 0;
  font-weight: 400;
  text-align: center;
}
#wrapper #guide .guide_cards_wrap{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  justify-content: center;
  gap: min(18px, 1.25vw);
  padding-top: min(30px, 2.142857142857143vw);
  overflow: visible;
}
#wrapper #guide .guide_card{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(235px, 16.388888888888888vw);
  height: min(235px, 16.388888888888888vw);
  padding: min(39px, 2.7083333333333335vw) 0 0;
  background-color: #F8F6F4;
  text-align: center;
  border-radius: min(20px, 1.4583333333333333vw);
}
#wrapper #guide .guide_card::before{
  position: absolute;
  top: min(10px, 0.7291666666666667vw);
  left: min(13px, 0.9259259259259259vw);
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(70px, 4.94047619047619vw);
  height: min(24px, 1.6666666666666667vw);
  font-family: var(--font-family-oswald);
  font-weight: 300;
  background-color: var(--color-primary);
  color: #fff;
  border-radius: min(24px, 1.7361111111111112vw);
  z-index: 1;
}
#wrapper #guide .guide_card.step01::before{
  content: 'STEP 1';
}
#wrapper #guide .guide_card.step02::before{
  content: 'STEP 2';
}
#wrapper #guide .guide_card.step03::before{
  content: 'STEP 3';
}
#wrapper #guide .guide_card.step04::before{
  content: 'STEP 4';
}
#wrapper #guide .guide_card.step05::before{
  content: 'STEP 5';
}
#wrapper #guide .guide_card.step06::before{
  content: 'STEP 6';
}
  #wrapper #guide .guide_card.step07::before{
  content: 'STEP 7';
}
#wrapper #guide .guide_card.step08::before{
  content: 'STEP 8';
}
#wrapper #guide .guide_card::after{
  content: '';
  position: absolute;
  top: 50%;
  right: min(-20px, -1.4583333333333333vw);
  transform: translateY(-50%);
  width: min(29px, 2.013888888888889vw);
  height: min(25px, 1.7361111111111112vw);
  background: url("/shopping/img/special/cruising/2026autumn_us/ca/guide/arrow.png") no-repeat center / 100% auto;
  z-index: 2;
}

#wrapper #guide .guide_card.step04::after,
#wrapper #guide .guide_card.step08::after{
  display: none;
}
#wrapper #guide .guide_card.step05::after{
  left: min(-23px, -1.6vw);
  right: min(-20px, -1.4583333333333333vw);
  width: auto;
  background-image: url("/shopping/img/special/cruising/2026autumn_us/ca/guide/arrow.png"), url("/shopping/img/special/cruising/2026autumn_us/ca/guide/arrow.png");
  background-repeat: no-repeat, no-repeat;
  background-position: left center, right center;
  background-size: min(29px, 2.013888888888889vw) min(25px, 1.7361111111111112vw);
}
#wrapper #guide .guide_card img{
  flex-shrink: 0;
  width: min(162px, 11.388888888888889vw);
  padding-bottom: min(9px, 0.6458333333333334vw);
}
#wrapper #guide .guide_card h3{
  font-family: var(--font-family-noto-sans-cjk-jp);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 2.6em;
  text-align: center;
  font-size: min(22px, 1.5625vw);
  letter-spacing: 0;
  line-height: 1.3;
  font-weight: 500;
}

@media screen and (max-width: 750px) {
  #wrapper #guide .guide_title_sub{
    font-size: min(28px, 3.733333333333333vw);
  }
  #wrapper #guide h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #guide .guide_cards_wrap{
    gap: min(6px, 0.8vw);
  }
  #wrapper #guide .guide_card{
    padding-top: min(65px, 8.666666666666666vw);
    width: min(158px, 21.066666666666666vw);
    height: min(240px, 32vw);
  }
  #wrapper #guide .guide_card::before{
    top: min(10px, 1.3333333333333333vw);
    left: 50%;
    transform: translateX(-50%);
    width: min(90px, 12vw);
    height: min(29px, 3.8666666666666667vw);
    font-size: min(24px, 3.2vw);
    font-weight: 300;
    line-height: 1.2;
  }
  #wrapper #guide .guide_card img{
    width: min(140px, 18.666666666666668vw);
    padding-bottom: min(15px, 2vw);
  }
  #wrapper #guide .guide_card h3{
    font-size: min(18px, 2.4vw);
    font-weight: 500;
    letter-spacing: 0;
  }
  #wrapper #guide .guide_card::after{
    right: min(-10px, -1.3333333333333333vw);
    width: min(30px, 4vw);
    height: min(25px, 3.3333333333333335vw);
  }
  #wrapper #guide .guide_card.step05::after{
    left: min(-10px, -1.3333333333333333vw);
    background-size: min(30px, 4vw) min(25px, 3.3333333333333335vw);
  }
  #wrapper #guide .guide_card.step02,
  #wrapper #guide .guide_card.step04{
    padding-top: min(50px, 6.666666666666667vw);
  }
  #wrapper #guide .guide_card.step02 h3,
  #wrapper #guide .guide_card.step04 h3{
    height: 5em;
    font-size: min(17px, 2.2666666666666666vw);
  }
  #wrapper #guide .guide_card.step02 h3{
    white-space: nowrap;
  }
}

/* ========== Section11 Frequently Asked Questions ========== */
#wrapper #faq{
  background-color: #ECF5F9;
}
#wrapper #faq h2{
  font-size: min(38px, 2.638888888888889vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  text-align: center;
  color: #000;
}
#wrapper #faq .faq_title_sub{
  font-size: min(22px, 1.5625vw);
  line-height: 1.35;
  letter-spacing: 0;
  font-weight: 400;
  text-align: center;
}
#wrapper #faq .faq_cards_wrap{
  flex-direction: column;
  gap: min(16px, 1.1111111111111112vw);
  margin-top: min(30px, 2.142857142857143vw);
}
#wrapper #faq .faq_card{
  width: 100%;
  padding: min(25px, 1.7361111111111112vw) min(40px, 2.8125vw);
  background-color: #fff;
  border-radius: min(16px, 1.1111111111111112vw);
}
#wrapper #faq .faq_card_question{
  position: relative;
  padding-left: min(46px, 3.2291666666666665vw);
  padding-right: min(36px, 2.5vw);
  font-size: min(24px, 1.7361111111111112vw);
  letter-spacing: 0.03em;
  line-height: 1.35;
  font-weight: 400;
  cursor: pointer;
  user-select: none;
}
#wrapper #faq .faq_card_question::after{
  content: '';
  position: absolute;
  right: min(12px, 0.8333333333333334vw);
  top: 50%;
  width: min(15px, 1.0416666666666667vw);
  height: min(15px, 1.0416666666666667vw);
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: translateY(-50%) rotate(-45deg);
  transition: transform 0.4s ease;
}
#wrapper #faq .faq_card.faq_card_open .faq_card_question::after{
  transform: translateY(-50%) rotate(135deg);
}
#wrapper #faq .faq_card_answer_wrap{
  overflow: hidden;
  transition: height 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
#wrapper #faq .faq_card_answer_wrap.is_closed{
  height: 0;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
#wrapper #faq .faq_more_wrap{
  display: flex;
  flex-direction: column;
  gap: min(16px, 1.1111111111111112vw);
  min-height: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}
#wrapper #faq .faq_cards_wrap.faq_show_more .faq_more_wrap{
  max-height: 5000px;
}
#wrapper #faq .faq_faq_btn.collapse_all{
  background-color: #AEAFB2;
}
#wrapper #faq .faq_card_question::before{
  content: 'Q';
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(30px, 2.142857142857143vw);
  height: min(30px, 2.142857142857143vw);
  color: #fff;
  font-family: var(--font-family-noto-sans-cjk-jp);
  font-size: min(20px, 1.4583333333333333vw);
  font-weight: 300;
  background: var(--color-primary);
  border-radius: 50%;
  z-index: 1;
}
#wrapper #faq .faq_card_answer{
  margin-top: min(16px, 1.1111111111111112vw);
  padding: min(16px, 1.1111111111111112vw) min(45px, 3.125vw) 0;
  font-size: min(18px, 1.25vw);
  line-height: 1.35;
  letter-spacing: 0;
  font-weight: 400;
  border-top: 1.5px solid #000;
}
#wrapper #faq .faq_card_answer_list{
  list-style: disc;
  list-style-position: outside;
  padding-left: calc(min(45px, 3.125vw) - 0.6em);
  margin-left: min(16px, 1.1111111111111112vw);
  line-height: 1.5;
}
#wrapper #faq .faq_card_answer_list li{
  padding-left: 0.2em;
}
#wrapper #faq .faq_card_answer_list li::marker{
  font-size: 0.55em;
}
#wrapper #faq .faq_card_answer_text{
  display: block;
  margin-top: 2em;
  margin-bottom: 2em;
  font-size: min(18px, 1.25vw);
  line-height: 1.35;
  letter-spacing: 0;
  font-weight: 400;
}
#wrapper #faq ul .faq_card_answer_text{
  list-style: none;
  margin-left: min(-16px, -1.1111111111111112vw);
}
#wrapper #faq .faq_faq_btn_wrap{
  text-align: center;
  margin-top: min(30px, 2.142857142857143vw);
}
#wrapper #faq .faq_faq_btn{
  width: min(242px, 17.638888888888889vw);
  height: min(65px, 4.791666666666667vw);
  margin-inline: auto;
  font-size: min(18px, 1.25vw);
  letter-spacing: 0;
  background-color: #1A4388;
  border-radius: min(65px, 4.791666666666667vw);
  color: #fff;
  text-decoration: none;
  text-align: center;
  line-height: min(65px, 4.791666666666667vw);
  font-weight: 500;
  transition: background-color 0.4s ease-in-out;
  cursor: pointer;
}

@media screen and (max-width: 750px) {
  #wrapper #faq .faq_title_sub{
    font-size: min(28px, 3.733333333333333vw);
  }
  #wrapper #faq h2{
    font-size: min(50px, 6.666666666666667vw);
  }
  #wrapper #faq .faq_cards_wrap{
    gap: min(16px, 2.1333333333333333vw);
  }
  #wrapper #faq .faq_more_wrap{
    gap: min(16px, 2.1333333333333333vw);
  }
  #wrapper #faq .faq_card{
    padding: min(26px, 3.466666666666667vw) min(40px, 5.333333333333333vw) min(26px, 3.466666666666667vw) min(40px, 5.333333333333333vw);
  }
  #wrapper #faq .faq_card_question::before{
    top: 50%;
    transform: translateY(-50%);
    width: min(30px, 4vw);
    height: min(30px, 4vw);
    font-size: min(20px, 2.6666666666666665vw);
  }
  #wrapper #faq .faq_card_question{
    padding-left: min(46px, 6.133333333333333vw);
    font-size: min(24px, 3.2vw);
    line-height: 1.3;
    letter-spacing: 0.05em;
  }
  #wrapper #faq .faq_card_question::after{
    width: min(18px, 2.4vw);
    height: min(18px, 2.4vw);
  }
  #wrapper #faq .faq_card_answer{
    margin-top: min(24px, 3.2vw);
    padding-top: min(24px, 3.2vw);
    font-size: min(18px, 2.4vw);
    line-height: 1.5;
    letter-spacing: 0.03em;
  }
  #wrapper #faq ul .faq_card_answer_text{
    font-size: min(18px, 2.4vw);
    line-height: 1.6;
    letter-spacing: 0.05em;
  }
  #wrapper #faq .faq_card_answer_text{
    font-size: min(18px, 2.4vw);
  }
  #wrapper #faq .faq_faq_btn{
    width: min(242px, 32.266666666666666vw);
    height: min(65px, 8.666666666666666vw);
    margin-top: min(30px, 4vw);
    font-size: min(24px, 3.2vw);
    line-height: min(65px, 8.666666666666666vw);
  }
}

/* ========== Footer ========== */
#wrapper #footer_note{
  width: 100%;
  padding: min(12px, 0.8333333333333334vw) 0 min(32px, 2.2222222222222223vw);
  text-align: center;
  font-size: min(14px, 1.0416666666666667vw);
  line-height: 1.3;
  letter-spacing: 0.03em;
  font-weight: 300;
}

#wrapper #footer{
  font-family: "Inter", sans-serif;
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
  height: min(482px, 33.75vw);
  background: url(/shopping/img/special/cruising/2026autumn_us/ca/common/footer_bg_pc.jpg) no-repeat center center;
  color: #fff;
}
#wrapper #footer .footer_inner{
  padding: min(30px, 2.142857142857143vw) min(40px, 2.8125vw);
  color: #fff;
}
#wrapper #footer .footer_inner ul{
  margin-top: min(125px, 8.680555555555556vw);
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}
#wrapper #footer .footer_inner ul li a{
  color: #fff;
  font-size: min(18px, 1.25vw);
  font-weight: 300;
  line-height: 2.1;
  letter-spacing: 0.03em;
  text-decoration: none;
}
#wrapper #footer .footer_inner ul li a:hover{
  padding-bottom: min(3px, 0.20833333333333334vw);
  border-bottom: 1px solid #fff;
  transition: padding-bottom 0.1s ease-in-out;
}
#wrapper #footer .footer_inner .footer_copyright{
  margin-top: min(140px, 9.92063492063492vw);
  font-size: min(20px, 1.4583333333333333vw);
  line-height: 1.3;
  letter-spacing: 0.03em;
  font-weight: 300;
  text-align: center;
}

@media screen and (max-width: 750px) {
  #wrapper #footer{
    height: min(380px, 50.66666666666667vw);
    background: url(/shopping/img/special/cruising/2026autumn_us/ca/common/footer_bg_sp.jpg) no-repeat center center;
  }
  #wrapper #footer_note{
    width: min(654px, 87.2vw);
    margin-inline: auto;
    padding: min(10px, 1.3333333333333333vw) 0 min(30px, 4vw);
    font-size: min(20px, 2.6666666666666665vw);
    text-align: left;
    letter-spacing: 0;
  }
  #wrapper #footer .footer_inner ul{
    margin-top: min(95px, 12.666666666666666vw);

  }
  #wrapper #footer .footer_inner ul li a{
    font-size: min(18px, 2.4vw);
    text-decoration: underline;
  }
  #wrapper #footer .footer_inner .footer_copyright{
    font-size: min(20px, 2.6666666666666665vw);
  }
}