@media only screen and (min-width: 499px) {
  .mainvUnder.mainvUnderMin {
    height: 430px;
    background-image: url(../images/plan/mainv_plan_bg_pc.jpg)
  }

}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .mainvUnder.mainvUnderMin {
    height: 355px;
    background-image: url(../images/plan/mainv_plan_bg_sp.jpg)
  }
}
.planListTop {
   justify-items: center;
}
@media only screen and (max-width: 500px) {
  .planListTop {
    justify-items: initial;
  }
}

.buffetListRibbon {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: center;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon {
    position: absolute;
    background-image: url(../images/plan/ribbon_plan_recommend_pc.png);
    right: -11px;
    top: -71px;
    width: 133px;
    height: 153px;
    padding-top: 90px;
  }
}

@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .buffetListRibbon {
    right: -9px;
    top: -58px;
    width: 110px;
    height: 126px;
    padding-top: 74px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon {
    background-image: url(../images/plan/ribbon_plan_recommend_sp.png);
    width: 18.54165vw;
    height: 18.697875vw;
    margin-left: 53vw;
    margin-bottom: -3vw;
    position: relative;
    z-index: 20;
    padding-top: 10.8888vw;
  }
}
.buffetListRibbon > * {
  color: #aaa08c;
}

.buffetListRibbon .en {
  display: inline-block;
  position: absolute;
  transform: rotate(-7deg) translateX(-50%);
  left: 50%;
  font-family: "Italianno", cursive;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon .en {
    font-size: 68px;
    top: 8px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .buffetListRibbon .en {
    font-size: 56px;
    top: 7px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon .en {
    font-size: 8.9583vw;
    top: 0.75vw;
  }
}
.buffetListRibbon .jp {
  display: inline-block;
  position: relative;
  text-align: center;
  font-weight: bold;
  padding: 0 1em;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon .jp {
    font-size: 16px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .buffetListRibbon .jp {
    font-size: 13px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon .jp {
    font-size: 2.18745vw;
  }
}
.buffetListRibbon .jp:before, .buffetListRibbon .jp:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  content: " ";
  background: #aaa08c;
  height: 1px;
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon .jp:before, .buffetListRibbon .jp:after {
    width: 8px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon .jp:before, .buffetListRibbon .jp:after {
    width: 1.3055vw;
  }
}
.buffetListRibbon .jp:before {
  left: 0;
}
.buffetListRibbon .jp:after {
  right: 0;
}

/* 疑似要素で丸いドットを生成 */
.two-column-lists li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.4em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #b1a28c; /* ドットの色(お好みで) */
}

.vertical-line {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 500px) {
  .vertical-line {
    display: block;
  }
}

.vertical-line .text {
  font-size: 11px;
  margin: 10px;
}

/*  */


/*planList*/
.planList {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planList {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planList {
    margin-bottom: 50px;
  }
}
@media only screen and (max-width: 500px) {
  .planList {
    margin-bottom: 11.0416vw;
  }
}
.planList:last-child {
  margin-bottom: 0;
}

.planListTop {
  position: relative;
  justify-items: center;
}
@media only screen and (max-width: 500px) {
  .planListTop {
    justify-items: initial;
  }
}

.planListRibbon {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: center;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListRibbon {
    position: absolute;
    background-image: url(../images/plan/ribbon_plan_pc.png);
    right: -11px;
    top: -71px;
    width: 133px;
    height: 153px;
    padding-top: 90px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListRibbon {
    right: -9px;
    top: -58px;
    width: 110px;
    height: 126px;
    padding-top: 74px;
  }
}
@media only screen and (max-width: 500px) {
  .planListRibbon {
    background-image: url(../images/plan/ribbon_plan_sp.png);
    width: 18.54165vw;
    height: 18.697875vw;
    margin-left: 53vw;
    margin-bottom: -17vw;
    position: relative;
    z-index: 20;
    padding-top: 10.8888vw;
  }
}
.planListRibbon > * {
  color: #aaa08c;
}
.planListRibbon .en {
  display: inline-block;
  position: absolute;
  transform: rotate(-7deg) translateX(-50%);
  left: 50%;
  font-family: "Italianno", cursive;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListRibbon .en {
    font-size: 68px;
    top: 8px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListRibbon .en {
    font-size: 56px;
    top: 7px;
  }
}
@media only screen and (max-width: 500px) {
  .planListRibbon .en {
    font-size: 8.9583vw;
    top: 0.75vw;
  }
}
.planListRibbon .jp {
  display: inline-block;
  position: relative;
  text-align: center;
  font-weight: bold;
  padding: 0 1em;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListRibbon .jp {
    font-size: 16px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListRibbon .jp {
    font-size: 13px;
  }
}
@media only screen and (max-width: 500px) {
  .planListRibbon .jp {
    font-size: 2.18745vw;
  }
}
.planListRibbon .jp:before, .planListRibbon .jp:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  content: " ";
  background: #aaa08c;
  height: 1px;
}
@media only screen and (min-width: 499px) {
  .planListRibbon .jp:before, .planListRibbon .jp:after {
    width: 8px;
  }
}
@media only screen and (max-width: 500px) {
  .planListRibbon .jp:before, .planListRibbon .jp:after {
    width: 1.3055vw;
  }
}
.planListRibbon .jp:before {
  left: 0;
}
.planListRibbon .jp:after {
  right: 0;
}

.buffetListRibbon {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: center;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon {
    position: absolute;
    background-image: url(../images/plan/ribbon_plan_recommend_pc.png);
    right: -11px;
    top: -71px;
    width: 133px;
    height: 153px;
    padding-top: 90px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .buffetListRibbon {
    right: -9px;
    top: -58px;
    width: 110px;
    height: 126px;
    padding-top: 74px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon {
    background-image: url(../images/plan/ribbon_plan_recommend_sp.png);
    width: 18.54165vw;
    height: 18.697875vw;
    margin-left: 53vw;
    margin-bottom: -3vw;
    position: relative;
    z-index: 20;
    padding-top: 10.8888vw;
  }
}
.buffetListRibbon > * {
  color: #aaa08c;
}
.buffetListRibbon .en {
  display: inline-block;
  position: absolute;
  transform: rotate(-7deg) translateX(-50%);
  left: 50%;
  font-family: "Italianno", cursive;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon .en {
    font-size: 68px;
    top: 8px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .buffetListRibbon .en {
    font-size: 56px;
    top: 7px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon .en {
    font-size: 8.9583vw;
    top: 0.75vw;
  }
}
.buffetListRibbon .jp {
  display: inline-block;
  position: relative;
  text-align: center;
  font-weight: bold;
  padding: 0 1em;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon .jp {
    font-size: 16px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .buffetListRibbon .jp {
    font-size: 13px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon .jp {
    font-size: 2.18745vw;
  }
}
.buffetListRibbon .jp:before, .buffetListRibbon .jp:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  content: " ";
  background: #aaa08c;
  height: 1px;
}
@media only screen and (min-width: 499px) {
  .buffetListRibbon .jp:before, .buffetListRibbon .jp:after {
    width: 8px;
  }
}
@media only screen and (max-width: 500px) {
  .buffetListRibbon .jp:before, .buffetListRibbon .jp:after {
    width: 1.3055vw;
  }
}
.buffetListRibbon .jp:before {
  left: 0;
}
.buffetListRibbon .jp:after {
  right: 0;
}

.courceListRibbon {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: center;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .courceListRibbon {
    position: absolute;
    background-image: url(../images/plan/ribbon_plan_pc.png);
    right: -11px;
    top: -71px;
    width: 133px;
    height: 153px;
    padding-top: 90px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .courceListRibbon {
    right: -9px;
    top: -58px;
    width: 110px;
    height: 126px;
    padding-top: 74px;
  }
}
@media only screen and (max-width: 500px) {
  .courceListRibbon {
    background-image: url(../images/plan/ribbon_plan_sp.png);
    width: 18.54165vw;
    height: 18.697875vw;
    margin-left: 53vw;
    margin-bottom: -3vw;
    position: relative;
    z-index: 20;
    padding-top: 10.8888vw;
  }
}
.courceListRibbon > * {
  color: #aaa08c;
}
.courceListRibbon .en {
  display: inline-block;
  position: absolute;
  transform: rotate(-7deg) translateX(-50%);
  left: 50%;
  font-family: "Italianno", cursive;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .courceListRibbon .en {
    font-size: 68px;
    top: 8px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .courceListRibbon .en {
    font-size: 56px;
    top: 7px;
  }
}
@media only screen and (max-width: 500px) {
  .courceListRibbon .en {
    font-size: 8.9583vw;
    top: 0.75vw;
  }
}
.courceListRibbon .jp {
  display: inline-block;
  position: relative;
  text-align: center;
  font-weight: bold;
  padding: 0 1em;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .courceListRibbon .jp {
    font-size: 16px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .courceListRibbon .jp {
    font-size: 13px;
  }
}
@media only screen and (max-width: 500px) {
  .courceListRibbon .jp {
    font-size: 2.18745vw;
  }
}
.courceListRibbon .jp:before, .courceListRibbon .jp:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  content: " ";
  background: #aaa08c;
  height: 1px;
}
@media only screen and (min-width: 499px) {
  .courceListRibbon .jp:before, .courceListRibbon .jp:after {
    width: 8px;
  }
}
@media only screen and (max-width: 500px) {
  .courceListRibbon .jp:before, .courceListRibbon .jp:after {
    width: 1.3055vw;
  }
}
.courceListRibbon .jp:before {
  left: 0;
}
.courceListRibbon .jp:after {
  right: 0;
}

.planListTopInner {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListTopInner {
    display: flex;
    justify-content: space-between;
  }
}
.partyListTopInner {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .partyListTopInner {
    justify-content: center;
  }
}
@media only screen and (min-width: 499px) {
  .planListTh {
    width: 30.612245%;
  }
}
@media only screen and (max-width: 500px) {
  .planListTh {
    margin-bottom: 6vw;
    position: relative;
    left: -0.8vw;
  }
}
.planListTh figure {
  display: block;
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%;
  height: 0;
  box-sizing: content-box;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListTh figure {
    box-shadow: 15px 15px 0 0 rgba(83, 71, 65, 0.1);
    padding-bottom: 100%;
    background-position: center;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListTh figure {
    box-shadow: 12px 12px 0 0 rgba(83, 71, 65, 0.1);
  }
}
@media only screen and (max-width: 500px) {
  .planListTh figure {
    box-shadow: 1.3888vw 1.3888vw 0 0 rgba(83, 71, 65, 0.1);
    padding-bottom: 56.25%;
    background-position: center;
  }
}

@media only screen and (min-width: 499px) {
  .planListTxt {
    width: 62.040816%;
  }
}
.planListTxt.active {
  border-bottom: 1px dotted #3c5064;
}
@media only screen and (max-width: 500px) {
  .planListTxt.active {
    padding-bottom: 5vw;
  }
}

.partyListTxt.active {
  border-bottom: 1px dotted #3c5064;
}
@media only screen and (max-width: 500px) {
  .partyListTxt.active {
    padding-bottom: 5vw;
  }
}

.planListLead {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListLead {
    font-weight: bold;
    letter-spacing: 0.12em;
    font-size: 16px;
    line-height: 2.0125;
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListLead {
    font-size: 13px;
    margin-bottom: 25px;
  }
}
@media only screen and (max-width: 500px) {
  .planListLead {
    line-height: 1.6666;
    margin-bottom: 3.3333vw;
  }
}

.planName {
  color: #aaa08c;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planName {
    margin-bottom: 15px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planName {
    margin-bottom: 12px;
  }
}
@media only screen and (max-width: 500px) {
  .planName {
    margin-bottom: 3.6111vw;
  }
}
.planName .en {
  letter-spacing: 0.08em;
  font-family: petersburg-web, serif;
  font-weight: 400, 700;
  font-style: normal, italic;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planName .en {
    font-size: 26px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planName .en {
    font-size: 21px;
  }
}
@media only screen and (max-width: 500px) {
  .planName .en {
    font-size: 5.4166vw;
    display: block;
    margin-bottom: 1.8vw;
  }
}
.planName .jp {
  font-weight: bold;
  letter-spacing: 0.12em;
}
@media only screen and (min-width: 499px) {
  .planName .jp {
    display: inline-block;
    margin-left: 0.8em;
  }
}
@media only screen and (max-width: 500px) {
  .planName .jp {
    font-size: 2.9166vw;
    display: block;
  }
}

.partyName {
  color: #aaa08c;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .partyName {
    margin-bottom: 40px;
    justify-self: center;
    border-bottom: solid 1px;
    padding: 10px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .partyName {
    margin-bottom: 12px;
  }
}
@media only screen and (max-width: 500px) {
  .partyName {
    margin-bottom: 3.6111vw;
  }
}
.partyName .en {
  letter-spacing: 0.08em;
  font-family: petersburg-web, serif;
  font-weight: 400, 700;
  font-style: normal, italic;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .partyName .en {
    font-size: 26px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .partyName .en {
    font-size: 21px;
  }
}
@media only screen and (max-width: 500px) {
  .partyName .en {
    font-size: 5.4166vw;
    display: block;
    margin-bottom: 1.8vw;
  }
}
.partyName .jp {
  font-weight: bold;
  letter-spacing: 0.12em;
}
@media only screen and (min-width: 499px) {
  .partyName .jp {
    display: inline-block;
  }
}
@media only screen and (max-width: 500px) {
  .partyName .jp {
    font-size: 2.9166vw;
    display: block;
    padding: 0 5px 5px 6px;
    width: 85px;
    border-bottom: solid 1px;
  }
}

.planNum {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planNum {
    margin-bottom: 5px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planNum {
    margin-bottom: 5px;
  }
}
@media only screen and (max-width: 500px) {
  .planNum {
    margin-bottom: 2.7777vw;
  }
}
.planNum span {
  display: inline-block;
  background: #aaa08c;
  color: #fff;
  font-weight: bold;
  letter-spacing: 0.16em;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planNum span {
    padding: 3px 10px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planNum span {
    padding: 2px 8px;
  }
}
@media only screen and (max-width: 500px) {
  .planNum span {
    font-size: 3.0555vw;
    padding: 0.8333vw 1.6666vw;
  }
}

.planPriceWrap {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planPriceWrap {
    margin-bottom: 14px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planPriceWrap {
    margin-bottom: 11px;
  }
}
@media only screen and (max-width: 500px) {
  .planPriceWrap {
    margin-bottom: 4.4444vw;
  }
}
.planPriceWrap > * {
  display: inline-block;
  letter-spacing: 0.16em;
  font-weight: bold;
}

.planPrice {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planPrice {
    font-size: 20px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planPrice {
    font-size: 16px;
  }
}
@media only screen and (max-width: 500px) {
  .planPrice {
    font-size: 4.1666vw;
  }
}
.planPrice .num {
  font-weight: normal;
  font-family: minion-3, serif;
  font-weight: 400;
  font-style: normal;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planPrice .num {
    font-size: 36px;
    letter-spacing: 0.07em;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planPrice .num {
    font-size: 30px;
  }
}
@media only screen and (max-width: 500px) {
  .planPrice .num {
    font-size: 7.5vw;
  }
}

@media only screen and (max-width: 500px) {
  .planPriceTax {
    font-size: 3.0555vw;
  }
}

.planPriceNum {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planPriceNum {
    font-size: 18px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planPriceNum {
    font-size: 15px;
  }
}
@media only screen and (max-width: 500px) {
  .planPriceNum {
    font-size: 3.6111vw;
  }
}
.planPriceNum span {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planPriceNum span {
    font-size: 14px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planPriceNum span {
    font-size: 12px;
  }
}
@media only screen and (max-width: 500px) {
  .planPriceNum span {
    font-size: 3.0555vw;
  }
}

@media only screen and (min-width: 499px) {
  .planListComment {
    line-height: 1.7;
  }
}
@media only screen and (max-width: 500px) {
  .planListComment {
    line-height: 1.666;
    margin-bottom: 7.5vw;
  }
}

@media only screen and (max-width: 500px) {
  .planBtnOpen button {
    margin-top: 0;
  }
}

.planListContent {
  display: none;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListContent {
    margin-top: 76px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListContent {
    margin-top: 63px;
  }
}
@media only screen and (max-width: 500px) {
  .planListContent {
    margin-top: 5vw;
  }
}

.planConTtl {
  padding-left: 0.5em;
  font-weight: bold;
  letter-spacing: 0.1em;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planConTtl {
    font-size: 21px;
    border-left: 4px solid #3c5064;
    margin-bottom: 20px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planConTtl {
    font-size: 17px;
    border-left: 3px solid #3c5064;
    margin-bottom: 16px;
  }
}
@media only screen and (max-width: 500px) {
  .planConTtl {
    font-size: 4.1666vw;
    border-left: 0.8333vw solid #3c5064;
    margin-bottom: 3.5vw;
  }
}
.planConTtl span {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planConTtl span {
    font-size: 16px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planConTtl span {
    font-size: 13px;
  }
}
@media only screen and (max-width: 500px) {
  .planConTtl span {
    font-size: 3.6111vw;
  }
}

.planListSpecial {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListSpecial {
    margin-bottom: 35px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListSpecial {
    margin-bottom: 29px;
  }
}
@media only screen and (max-width: 500px) {
  .planListSpecial {
    margin-bottom: 7.5vw;
  }
}

@media only screen and (min-width: 499px) {
  .planListSpecialList {
    display: flex;
  }
}
.planListSpecialList ul {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListSpecialList ul {
    margin-right: 40px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListSpecialList ul {
    margin-right: 33px;
  }
}
.planListSpecialList ul li {
  position: relative;
  padding-left: 1.5em;
  letter-spacing: 0.1em;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListSpecialList ul li {
    margin-bottom: 14px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListSpecialList ul li {
    margin-bottom: 11px;
  }
}
@media only screen and (max-width: 500px) {
  .planListSpecialList ul li {
    margin-bottom: 3.3333vw;
  }
}
@media only screen and (min-width: 499px) {
  .planListSpecialList ul li:last-child {
    margin-bottom: 0;
  }
}
.planListSpecialList ul li:before {
  content: "　";
  display: block;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(../images/common/icn_flower.svg);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListSpecialList ul li:before {
    width: 15px;
    height: 15px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListSpecialList ul li:before {
    width: 13px;
    height: 13px;
  }
}
@media only screen and (max-width: 500px) {
  .planListSpecialList ul li:before {
    width: 4.02777vw;
    height: 4.02777vw;
  }
}
@media only screen and (max-width: 500px) {
  .planListSpecialList ul:last-child li:last-child {
    margin-bottom: 0;
  }
}

.planListPeriod {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListPeriod {
    margin-bottom: 50px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListPeriod {
    margin-bottom: 41px;
  }
}
@media only screen and (max-width: 500px) {
  .planListPeriod {
    margin-bottom: 7.5vw;
  }
}

.planListPeriodContent {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListPeriodContent {
    margin-bottom: 20px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListPeriodContent {
    margin-bottom: 16px;
  }
}
@media only screen and (max-width: 500px) {
  .planListPeriodContent {
    margin-bottom: 3.0555vw;
  }
}
.planListPeriodContent:last-child {
  margin-bottom: 0;
}
.planListPeriodContent p {
  line-height: 1.7;
}
@media only screen and (max-width: 500px) {
  .planListPeriodContent p {
    font-size: 3.0555vw;
    letter-spacing: 0.05em;
  }
}
.planListPeriodContent p.notes {
  margin-top: 0.5em;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListPeriodContent p.notes {
    font-size: 13px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListPeriodContent p.notes {
    font-size: 11px;
  }
}
@media only screen and (max-width: 500px) {
  .planListPeriodContent p.notes {
    font-size: 2.9166vw;
    letter-spacing: 0.03em;
  }
}

.planConHead {
  color: #3c5064;
  margin-bottom: 0.5em;
  margin-left: -0.5em;
}

@media only screen and (max-width: 500px) {
  .planListIncludedTable {
    display: block;
  }
}
@media only screen and (max-width: 500px) {
  .planListIncludedTable tbody {
    display: block;
  }
}
.planListIncludedTable th, .planListIncludedTable td {
  border-top: 1px solid #ccc6ba;
  font-weight: normal;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
}
@media only screen and (max-width: 500px) {
  .planListIncludedTable th, .planListIncludedTable td {
    display: block;
  }
}
@media only screen and (max-width: 500px) {
  .planListIncludedTable tr {
    display: flex;
    flex-wrap: wrap;
  }
}
.planListIncludedTable tr:last-child th, .planListIncludedTable tr:last-child td {
  border-bottom: 1px solid #ccc6ba;
}
.planListIncludedTable th {
  text-align: center;
  background: #f3f1ee;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListIncludedTable th {
    padding: 15px 10px;
    width: 15.8%;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListIncludedTable th {
    padding: 12px 8px;
  }
}
@media only screen and (max-width: 500px) {
  .planListIncludedTable th {
    padding: 4vw 0;
    width: 32.6%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1.666;
  }
}
.planListIncludedTable td {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListIncludedTable td {
    padding: 15px 28px 15px 16px;
    width: 34.2%;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListIncludedTable td {
    padding: 12px 23px 12px 21px;
  }
}
@media only screen and (max-width: 500px) {
  .planListIncludedTable td {
    padding: 4.3055vw 0 4.3055vw 3.3333vw;
    width: 67.4%;
  }
}
.planListIncludedTable td > * {
  display: inline-block;
  vertical-align: middle;
}
.planListIncludedTable td .check {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListIncludedTable td .check {
    width: 10.3448%;
  }
}
@media only screen and (max-width: 500px) {
  .planListIncludedTable td .check {
    width: 13.5642%;
    font-size: 3.0555vw;
  }
}
.planListIncludedTable td p {
  line-height: 1.7;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListIncludedTable td p {
    width: 89.6552%;
  }
}
@media only screen and (max-width: 500px) {
  .planListIncludedTable td p {
    width: 86.4358%;
    font-size: 2.9166vw;
  }
}

.planBtnClose button:after {
  background-image: url(../images/common/close.svg);
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planBtnClose button:after {
    width: 11px;
    height: 11px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planBtnClose button:after {
    width: 9px;
    height: 9px;
  }
}
@media only screen and (max-width: 500px) {
  .planBtnClose button:after {
    width: 2.0833vw;
    height: 2.0833vw;
  }
}

.planListRecommend {
  background-image: url(../images/common/bg_noise1.jpg);
  background-size: 200px 200px;
}
@media only screen and (min-width: 499px) {
  .planListRecommend .planListRibbon {
    background-image: url(../images/plan/ribbon_plan_recommend_pc.png);
  }
}
@media only screen and (max-width: 500px) {
  .planListRecommend .planListRibbon {
    background-image: url(../images/plan/ribbon_plan_recommend_sp.png);
  }
  .planListRecommend .planListRibbon .jp {
    padding: 0;
  }
  .planListRecommend .planListRibbon .jp:before, .planListRecommend .planListRibbon .jp:after {
    content: none;
  }
}
.planListRecommend .planListIncludedTable td {
  background: #fff;
}
@media only screen and (max-width: 500px) {
  .planListRecommend .planListIncludedTable td {
    padding-right: 0.5em;
  }
}

.planListRecommend .planListLead, .planListSpecial .planListLead {
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListRecommend .planListLead, .planListSpecial .planListLead {
    min-height: 64px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListRecommend .planListLead, .planListSpecial .planListLead {
    min-height: 52px;
  }
}

.planListRecommend .partyListLead, .planListSpecial .partyListLead {
  justify-self: center;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .planListRecommend .partyListLead, .planListSpecial .partyListLead {
    min-height: 40px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .planListRecommend .partyListLead, .planListSpecial .partyListLead {
    min-height: 52px;
  }
}
@media only screen and (max-width: 500px) {
  .planListRecommend .partyListLead, .planListSpecial .partyListLead {
    margin-bottom: 10px;
    line-height: 1.2rem;
    margin-left: auto;
  }
}

/* 親コンテナを横並びにする */
.two-column-lists {
  display: flex; /* 横並びに */
  gap: 4rem; /* 列間の余白を調整 */
  justify-content: center; /* 必要に応じて調整 */
}
@media only screen and (max-width: 500px) {
  .two-column-lists {
    display: block;
  }
}

/* UL全体の余白調整（必要に応じて） */
.two-column-lists ul {
  list-style: none; /* デフォルトの箇条書きスタイルをリセット */
  padding: 0; /* ブラウザ既定の余白を削除 */
  margin: 0;
}

/* LIに独自のドットを付ける */
.two-column-lists li {
  position: relative;
  margin: 0 0 20px; /* 下方向に少し余白 */
  padding-left: 1.5em; /* ドット分だけ左に余白 */
  line-height: 21px;
}

/* 疑似要素で丸いドットを生成 */
.two-column-lists li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.4em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #b1a28c; /* ドットの色(お好みで) */
}

.vertical-line {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 500px) {
  .vertical-line {
    display: block;
  }
}

.vertical-line .text {
  font-size: 11px;
  margin: 10px;
}

.drinkText {
  justify-items: center;
}

.drinkTtl {
  font-size: 20px;
  font-weight: 800;
  font-family: YuMincho;
  margin-bottom: 40px;
  justify-self: center;
}

.tel {
  font-size: 20px;
  margin-bottom: 5px;
}

.arrow-right {
  position: relative;
  top: -35px;
  left: 100px;
  width: 23px;
}
@media only screen and (max-width: 500px) {
  .arrow-right {
    top: -28px;
    left: 200px;
  }
}

.partyPrice {
  font-size: 20px;
  margin-right: 8px;
}
.secUnder3ContentParty {
  position: relative;
  border-top: 2px solid #dbd7c6;
  border-bottom: 2px solid #dbd7c6;
  background: #fff;
  /*	$num: ($pcViewport + 1px);*/
}
@media only screen and (min-width: 499px) {
  .secUnder3ContentParty {
    padding: 60px 50px;
  }
}
@media only screen and (min-width: 500px) and (max-width: 1366px) {
  .secUnder3ContentParty {
    padding: 50px 41px;
  }
}
@media only screen and (max-width: 500px) {
  .secUnder3ContentParty {
    padding: 0px 20px 10px;
  }
}
.secUnder3ContentParty:before, .secUnder3ContentParty:after {
  content: " ";
  display: block;
  position: absolute;
  height: 2px;
  width: 62.2449%;
  background: #aaa08c;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
}
.secUnder3ContentParty:before {
  top: -2px;
}
.secUnder3ContentParty:after {
  bottom: -2px;
}

#underInquiry {
  background: #fff;
}

.mt-40 {
  margin-top: 40px;
}
