﻿@charset "UTF-8";
/* ===================================================================
 common.css - 特設ページ共通スタイル
=================================================================== */

/* イントロ（beauty_photo 同等の余白） */
.special .con_intr2.mb-0 {
  margin-bottom: 0 !important;
}
.special .con_intr2 .box_intr2 .txt2.maxwidth_780 {
  max-width: 780px;
}

/* 特設一覧ページ */
.special_list {
  margin-top: 1.5em;
  list-style: none;
  padding: 0;
}
.special_list li {
  margin-bottom: 0.5em;
}
.special_list a {
  color: #2e1d15;
  text-decoration: underline;
}
.special_list a:hover {
  color: #8b6914;
}

/* プラン系レイアウト（firework / mealplan 等）
 * ラッパー余白は beauty_photo と同じ new_content_box02 に任せる */
.con_special_plan {
  color: #242522;
}
.con_special_plan .box_inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 40px;
}
.con_special_plan .box_inner.reverse {
  flex-direction: row-reverse;
}
.con_special_plan .box_inner + .box_inner {
  margin-top: 60px;
}
.con_special_plan .box_photo {
  flex: 0 1 695px;
  max-width: 695px;
  min-width: 280px;
  width: 100%;
}
.con_special_plan .box_det {
  flex: 1 1 260px;
  min-width: 260px;
}
.con_special_plan .box_photo .photo {
  margin: 0;
  line-height: 0;
  overflow: hidden;
}
.con_special_plan .box_photo .photo img {
  width: 100%;
  height: auto;
  display: block;
  vertical-align: top;
  object-fit: cover;
}
.con_special_plan .box_det .title {
  margin-top: 0;
  padding-top: 0;
  font-size: 26px;
  line-height: 1.4230769231;
  color: #c99d57;
  margin-bottom: 20px;
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Yu Mincho", YuMincho, "游明朝", "ＭＳ Ｐ明朝", "MS PMincho", "Times New Roman", Times, Garamond, Georgia, serif;
  font-weight: normal;
}
.con_special_plan .box_det .txt {
  font-size: 16px;
  line-height: 1.6875;
  margin: 0 0 1em;
}
.con_special_plan .plan_price {
  margin: 0 0 1em;
  font-size: 16px;
  color: #2e1d15;
}
.con_special_plan .plan_price .price {
  font-size: 200%;
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Yu Mincho", YuMincho, "游明朝", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  color: #c99d57;
  letter-spacing: 0.05em;
}
.con_special_plan .plan_price .tax {
  font-size: 87.5%;
}
.con_special_plan .plan_course {
  margin: 0 0 0.5em;
  font-size: 16px;
  line-height: 1.6875;
  color: #2e1d15;
}
.con_special_plan .plan_menu,
.con_special_plan .plan_details {
  margin: 0 0 1.5em;
  padding-left: 1.5em;
  list-style: disc;
}
.con_special_plan .plan_menu li,
.con_special_plan .plan_details li {
  margin-bottom: 0.3em;
  font-size: 16px;
  line-height: 1.6875;
}
.con_special_plan .box_btn {
  list-style: none;
  margin: 1em 0 0;
  padding: 0;
  overflow: visible;
}
.con_special_plan .box_btn::after {
  content: "";
  display: block;
  clear: both;
}
.con_special_plan .box_btn li {
  width: 202px;
  float: left;
}
.con_special_plan .box_btn li.btn_ame {
  margin-bottom: 0;
}
.con_special_plan .box_btn li.btn_ame a {
  display: block;
  position: relative;
  text-align: center;
  text-decoration: none;
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Yu Mincho", YuMincho, "游明朝", "ＭＳ Ｐ明朝", "MS PMincho", "Times New Roman", Times, Garamond, Georgia, serif;
  padding: 0.8em 0;
  color: #2e1d15;
  background: #c99d57;
  border: 1px solid #2e1d15;
  box-shadow: 0 0 0 2px #c99d57;
  transition: background 0.8s, color 0.8s;
}
.con_special_plan .box_btn li.btn_ame a::after {
  content: "▷";
  position: absolute;
  top: 50%;
  right: 5%;
  line-height: 1;
  transform: translateY(-50%);
  font-size: 72%;
}
.con_special_plan .box_btn li.btn_ame a:hover {
  opacity: 0.7;
}
.con_special_plan .box_btn li.btn_common {
  width: 202px;
  float: left;
  margin: 0;
}
.con_special_plan .box_btn li.btn_common a {
  display: block;
  position: relative;
  text-align: center;
  text-decoration: none;
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Yu Mincho", YuMincho, "游明朝", "ＭＳ Ｐ明朝", "MS PMincho", "Times New Roman", Times, Garamond, Georgia, serif;
  padding: 0.8em 0;
  color: #2f2f2f;
  background: #d1c0a5;
  border: none;
  box-shadow: 0 0 0 1px #312017, 0 0 0 3px #d1c0a5;
  transition: background 0.8s, color 0.8s;
}
.con_special_plan .box_btn li.btn_common a::after {
  content: "▷";
  position: absolute;
  top: 50%;
  right: 5%;
  line-height: 1;
  transform: translateY(-50%);
  font-size: 72%;
}
.con_special_plan .box_btn li.btn_common a:hover,
.mouse .con_special_plan .box_btn li.btn_common a:hover,
.touch .con_special_plan .box_btn li.btn_common a.touchstart {
  background: #d1c0a5;
  color: #2e1d15;
  opacity: 0.7;
}
@media only screen and (max-width: 767px) {
  .con_special_plan .box_photo,
  .con_special_plan .box_det {
    flex: 1 1 100%;
  }
  .con_special_plan .box_det .title {
    font-size: 20px;
    line-height: 1.45;
  }
  .con_special_plan .box_btn li {
    width: 100%;
    max-width: 370px;
    margin: 0 auto;
    float: none;
  }
  .con_special_plan .box_btn li.btn_ame {
    margin-bottom: 5%;
  }
  .con_special_plan .box_btn li.btn_common {
    width: 100%;
    max-width: 370px;
    margin: 0 auto;
    float: none;
  }
}

/* -------------------------------------------------------------------
 * プラン詳細ブロック（写真695px + テキスト510px・左右反転対応）
 * class: box_inner special_plan_block [reverse] [special_plan_block--pad-y130]
 * ------------------------------------------------------------------- */
.con_special_plan .box_inner.special_plan_block .box_det {
  flex: 0 0 auto;
  max-width: 510px;
  min-width: 0;
  width: auto;
}

.con_special_plan .box_inner.special_plan_block--pad-y130 {
  margin-top: 130px;
  margin-bottom: 130px;
}

/* タブレット（768px〜1279px）：可変2カラム */
@media only screen and (min-width: 768px) and (max-width: 1279px) {
  .con_special_plan .box_inner.special_plan_block {
    width: 100%;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 24px;
  }

  .con_special_plan .box_inner.special_plan_block .box_photo {
    flex: 1 1 52%;
    max-width: 52%;
    width: auto;
    min-width: 0;
  }

  .con_special_plan .box_inner.special_plan_block .box_det {
    flex: 1 1 42%;
    max-width: 42%;
    width: auto;
    min-width: 0;
  }

  .con_special_plan .box_inner.special_plan_block:not(.reverse) .box_det {
    margin-left: auto;
    margin-right: 0;
  }

  .con_special_plan .box_inner.special_plan_block.reverse .box_det {
    margin-left: 0;
    margin-right: 0;
  }

  .con_special_plan .box_inner.special_plan_block.reverse .box_photo {
    margin-left: auto;
    margin-right: 0;
  }

  .con_special_plan .box_inner.special_plan_block--pad-y130 {
    margin-top: 80px;
    margin-bottom: 80px;
  }

  .con_special_plan .box_inner + .box_inner {
    margin-top: 50px;
  }

  .con_special_plan .box_det .title {
    font-size: 22px;
    line-height: 1.45;
  }

  .special .special_fullbleed_bg {
    padding-top: 40px;
    padding-bottom: 60px;
  }
}

/* 狭いタブレット（768px〜1023px）：縦積み */
@media only screen and (min-width: 768px) and (max-width: 1023px) {
  .con_special_plan .box_inner.special_plan_block,
  .con_special_plan .box_inner.special_plan_block.reverse {
    flex-direction: column;
    gap: 28px;
  }

  .con_special_plan .box_inner.special_plan_block .box_photo,
  .con_special_plan .box_inner.special_plan_block .box_det {
    flex: 1 1 100%;
    max-width: 100%;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

/* PC（1280px〜）：デザイン固定幅 */
@media only screen and (min-width: 1280px) {
  .con_special_plan .box_inner.special_plan_block {
    width: 100%;
    justify-content: flex-start;
    gap: 40px;
  }

  .con_special_plan .box_inner.special_plan_block .box_photo {
    flex: 0 0 695px;
    max-width: 695px;
    width: 695px;
  }

  .con_special_plan .box_inner.special_plan_block .box_det {
    flex: 0 0 510px;
    width: 510px;
    max-width: 510px;
  }

  .con_special_plan .box_inner.special_plan_block:not(.reverse) .box_det {
    margin-left: auto;
    margin-right: 0;
  }

  .con_special_plan .box_inner.special_plan_block.reverse .box_det {
    margin-left: 0;
    margin-right: 0;
  }

  .con_special_plan .box_inner.special_plan_block.reverse .box_photo {
    margin-left: auto;
    margin-right: 0;
  }
}

.special_plan_block .box_photo {
  position: relative;
}

.special_plan_block .box_slide_wrap {
  position: relative;
  width: 100%;
}

.special_plan_block .box_slide {
  width: 100%;
  margin: auto;
}

.special_plan_block .box_slide .photo {
  margin: 0;
  line-height: 0;
}

.special_plan_block .box_slide .photo img,
.special_plan_block .box_slide .slick-slide img {
  width: 100%;
  height: auto;
  display: block;
  vertical-align: top;
  border: none;
}

.special_plan_block .box_slide.slick-dotted.slick-slider {
  margin-bottom: 0;
}

.special_plan_block .box_slide .slick-dots {
  bottom: 5%;
  z-index: 3;
}

.special_plan_block .box_slide .slick-dots li {
  width: 12px;
  height: 12px;
  margin: 0 0.5em;
}

.special_plan_block .box_slide .slick-dots li button {
  width: 100%;
  height: 100%;
}

.special_plan_block .box_slide .slick-dots li button::before {
  content: "";
  width: 100%;
  height: 100%;
  border: 1px solid #fff;
  box-sizing: border-box;
  background: none;
  opacity: 1;
  transition: background 0.8s;
}

.special_plan_block .box_slide .slick-dots li.slick-active button::before {
  background: #fff;
}

.special_plan_block .photo_note {
  position: absolute;
  left: 0;
  bottom: 0;
  margin: 0;
  padding: 10px 14px;
  color: #fff;
  font-size: 12px;
  line-height: 1.4;
  letter-spacing: 0.05em;
  z-index: 2;
  pointer-events: none;
}

/* 料金・お料理内容（破線テーブル） */
.special_plan_block .box_plan_spec {
  margin: 28px 0 24px;
}

.special_plan_block table.tbl_plan {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
}

.special_plan_block table.tbl_plan tr:first-child {
  border-top: 1px dashed #242522;
}

.special_plan_block table.tbl_plan tr {
  border-bottom: 1px dashed #242522;
}

.special_plan_block table.tbl_plan th {
  width: 26.862745098%;
  padding: 14px 12px 14px 0;
  font-weight: normal;
  font-size: 16px;
  line-height: 1.6875;
  color: #2e1d15;
  text-align: left;
  vertical-align: top;
  box-sizing: border-box;
}

.special_plan_block table.tbl_plan td {
  padding: 14px 0 14px 12px;
  font-size: 16px;
  line-height: 1.6875;
  color: #2e1d15;
  text-align: left;
  vertical-align: top;
  box-sizing: border-box;
}

.special_plan_block table.tbl_plan td:before {
  content: none;
}

.special_plan_block table.tbl_plan td .course {
  margin: 0 0 0.35em;
}

.special_plan_block table.tbl_plan td .menu {
  margin: 0;
}

/* プラン内容（表内・中点付き箇条書き） */
.special_plan_block table.tbl_plan td .plan_details {
  margin: 0;
  padding: 0;
  list-style: none;
}

.special_plan_block table.tbl_plan td .plan_details li {
  position: relative;
  padding-left: 1em;
  margin-bottom: 0.35em;
  font-size: 16px;
  line-height: 1.6875;
  color: #2e1d15;
}

.special_plan_block table.tbl_plan td .plan_details li:last-child {
  margin-bottom: 0;
}

.special_plan_block table.tbl_plan td .plan_details li::before {
  content: "・";
  position: absolute;
  left: 0;
}

.special_plan_block .box_det .txt:last-of-type {
  margin-bottom: 0;
}

@media only screen and (max-width: 767px) {
  .con_special_plan .box_inner.special_plan_block .box_photo {
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    margin-left: 0;
  }

  .con_special_plan .box_inner.special_plan_block .box_det {
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    margin-left: 0;
  }

  .special_plan_block .photo_note {
    font-size: 11px;
    padding: 8px 10px;
  }

  .special_plan_block table.tbl_plan th,
  .special_plan_block table.tbl_plan td {
    display: block;
    width: 100%;
    padding: 10px 0;
  }

  .special_plan_block table.tbl_plan th {
    padding-bottom: 4px;
  }

  .special_plan_block table.tbl_plan td {
    padding-top: 0;
    padding-bottom: 12px;
  }
}

/* -------------------------------------------------------------------
 * 全幅背景セクション（コンテンツ幅は new_content_box02 のまま）
 * class: special_fullbleed_bg [special_fullbleed_bg--beige 等]
 * ------------------------------------------------------------------- */
.special .special_fullbleed_bg {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);
  padding-top: 50px;
  padding-bottom: 100px;
  box-sizing: border-box;
}

.special .special_fullbleed_bg > .new_content_box02 {
  margin-top: 0;
  margin-bottom: 0;
}

.special .special_fullbleed_bg .box_btn {
  margin-top: 3em;
}

.special .special_fullbleed_bg--beige {
  background: #ebe8e2;
}