@charset "UTF-8";
/* Google Fonts Noto Serif Japanese、Noto Sans Japaneseを読み込む ******************************************************/
/*
Noto Serif Japanese:
font-weight: 400;
font-weight: 600;
font-weight: 900;

Noto Sans Japanese:
font-weight: 400;
font-weight: 600;
*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;600&family=Noto+Serif+JP:wght@400;600;900&display=swap");

/* リセット ******************************************************/
html {
  scroll-behavior: smooth;
}

.openOuter * {
  box-sizing: border-box;
}

.openOuter *::before,
.openOuter *::after {
  box-sizing: border-box;
}

.openOuter img {
  max-width: 100%;
  height: auto;
  display: block;
}

.openOuter ul,
.openOuter ol {
  padding-left: 0;
}

.openOuter .mt0 {
  margin-top: 0;
}

.openOuter a {
  color: #333;
}

@media only screen and (min-width: 768px) {
  .ec-layoutRole .ec-layoutRole__contents {
    padding-right: 0px !important;
    padding-left: 0px !important;
    max-width: 100% !important;
  }
}

/* 大枠 ******************************************************/
.openOuter {
  margin-top: -20px;
  width: 100%;
  display: block;
  position: relative;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
}

.ly_contentsOuter {
  width: 100%;
}

.ly_centerContentsOuter {
  max-width: 1240px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

.ly_centerContentsOuter.padding0 {
  padding-left: 0;
  padding-right: 0;
}

@media only screen and (max-width: 750px) {
  .ly_centerContentsOuter.sp-padding0 {
    padding-left: 0;
    padding-right: 0;
  }
}

.ly_bgGreen {
  background-color: #00833e;
}

@media only screen and (max-width: 750px) {
  br.pc {
    display: none;
  }
}

br.sp {
  display: none;
}

@media only screen and (max-width: 750px) {
  br.sp {
    display: block;
  }
}

.textFixed {
  display: inline-block;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  text-decoration: inherit;
}

.textAnotation {
  display: inline-block;
  font-weight: 300;
  margin-top: 10px;
  color: inherit;
  text-decoration: inherit;
  font-family: "メイリオ",
    Meiryo,
    "ヒラギノ角ゴ Pro W6",
    "Hiragino Kaku Gothic Pro",
    Osaka,
    "ＭＳ Ｐゴシック",
    "MS PGothic",
    sans-serif;
}

@media only screen and (min-width: 751px) {
  .textAnotation {
    font-size: 18px;
  }
}

.navitopicpath_ {
  padding-top: 40px;
}

@media only screen and (max-width: 750px) {
  .navitopicpath_ {
    display: none;
  }
}

/* ヘッダー見出し ******************************************************/
.header_1 {
  position: relative;
  max-width: 1540px;
  width: 100%;
  text-align: right;
  font-family: "Noto Serif JP", serif;
  color: #00833e;
  font-weight: 400;
  font-size: 70px;
  line-height: 1;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

@media only screen and (max-width: 750px) {
  .header_1 {
    font-size: 40.25px;
    max-width: none;
  }
}

.header_1::after {
  position: absolute;
  content: "";
  display: block;
  width: 60px;
  height: 1px;
  right: 20px;
  bottom: -35px;
  border-bottom: dashed 1px #00833e;
}

.header_1.about {
  padding-top: 100px;
}

@media only screen and (max-width: 750px) {
  .header_1.about {
    padding-top: 60px;
  }
}

.header_1.costPlan {
  margin-top: 60px;
  padding-top: 100px;
}

@media only screen and (max-width: 750px) {
  .header_1.costPlan {
    margin-top: 50px;
    padding-top: 50px;
  }
}

.header_1.flow {
  margin-top: 50px;
  padding-top: 100px;
}

@media only screen and (max-width: 750px) {
  .header_1.flow {
    margin-top: 50px;
    padding-top: 50px;
  }
}

.header_1.introduction {
  color: #004f25;
  margin-top: 55px;
  padding-top: 100px;
}

@media only screen and (max-width: 750px) {
  .header_1.introduction {
    padding-top: 50px;
  }
}

.header_1.faq {
  margin-top: 55px;
  padding-top: 100px;
}

@media only screen and (max-width: 750px) {
  .header_1.faq {
    padding-top: 50px;
  }
}

.header_1 span.ampSmall {
  font-size: 50px;
}

@media only screen and (max-width: 750px) {
  .header_1 span.ampSmall {
    font-size: 43px;
  }
}

@media only screen and (max-width: 750px) {
  .header_2Outer {
    display: block;
    text-align: center;
  }
}

.header_2 {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  font-weight: 600;
}

@media only screen and (max-width: 750px) {
  .header_2 {
    font-size: 19.25px;
    display: inline;
    border-bottom: dashed 1px #00833e;
    text-align: center;
    line-height: 2.4;
    padding-bottom: 10px;
  }
}

.header_2::after {
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  left: 0;
  bottom: -24px;
  border-bottom: dashed 1px #00833e;
}

@media only screen and (max-width: 750px) {
  .header_2::after {
    display: none;
  }
}

.header_3 {
  display: block;
  position: relative;
  font-family: "Noto Serif JP", serif;
  font-size: 44px;
  font-weight: 600;
  color: #333;
}

@media only screen and (max-width: 750px) {
  .header_3 {
    font-size: 24.5px;
  }
}

.header_3::after {
  position: absolute;
  content: "";
  display: block;
  width: 80px;
  height: 1px;
  left: 0;
  bottom: -51px;
  border-bottom: dashed 1px #333;
}

@media only screen and (max-width: 750px) {
  .header_3::after {
    bottom: -25px;
  }
}

.openIntroductionOuter-first .header_3 {
  color: #fff;
}

.openIntroductionOuter-first .header_3::after {
  border-bottom-color: #fff;
}

/* 出店・お問合せボタン ******************************************************/
.openInquiryBtnOuter {
  display: flex;
  justify-content: flex-end;
}

@media only screen and (max-width: 750px) {
  .openInquiryBtnOuter {
    padding-left: 20px;
    padding-right: 20px;
    justify-content: center;
  }
}

.btn_inquiry {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  max-width: 364px;
  /* max-width: 420px; */
  width: 100%;
  height: 100px;
  background-color: #00833e;
  color: #fff !important;
  text-decoration: none;
  margin-right: 10px;
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  transition-duration: 0.3s;
  left: 0;
  top: 0;
}

@media only screen and (max-width: 750px) {
  .btn_inquiry {
    font-size: clamp(19.25px, 4vw, 22.75px);
    text-decoration: none !important;
    height: 80px;
  }
}

.btn_inquiry::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  right: -10px;
  bottom: -10px;
  border-right: solid 1px #00833e;
  border-bottom: solid 1px #00833e;
  transition-duration: 0.3s;
}

@media only screen and (max-width: 750px) {
  .btn_inquiry::before {
    height: 80px;
  }
}

.btn_inquiry[target=_blank] {
  padding-right: 23px;
}

.btn_inquiry[target=_blank]::after {
  position: absolute;
  content: "";
  width: 12px;
  height: 12px;
  top: 0;
  bottom: 0;
  right: 44px;
  margin-top: auto;
  margin-bottom: auto;
  background: url(/html/upload/user_data/fp/open/img/icon_blank.png) no-repeat left top;
}

@media only screen and (max-width: 750px) {
  .btn_inquiry[target=_blank]::after {
    right: 22px;
  }
}

.btn_inquiry:hover {
  background-color: #005c2a;
  left: 6px;
  top: 6px;
  text-decoration: none;
}

.btn_inquiry:hover::before {
  right: -4px;
  bottom: -4px;
}

.btn_inquiry.sizeSmall {
  max-width: 320px;
  width: 100%;
  height: 80px;
  font-size: 24px;
}

.btn_inquiry.sizeSmall::before {
  height: 80px;
}

.openInquiryBtnOuter .btn_inquiry {
  margin-top: 30px;
}

.openMVOuter .btn_inquiry {
  font-size: clamp(16px, 2vw, 23.6px);
  max-height: 100px;
  height: 4em;
  line-height: clamp(16px, 2vw, 34.8px);
  text-align: center;
}

@media only screen and (max-width: 750px) {
  .openMVOuter .btn_inquiry {
    height: 80px;
    max-height: none;
    font-size: 17.5px;
    line-height: 17.5px;
  }
}

.openMVOuter .btn_inquiry::before {
  height: 3em;
}

@media only screen and (max-width: 750px) {
  .openMVOuter .btn_inquiry::before {
    height: 80px;
  }
}

.openMVOuter .btn_inquiry::after {
  right: 10.48%;
}

@media only screen and (max-width: 750px) {
  .openMVOuter .btn_inquiry::after {
    right: 3.57%;
  }
}

.btn_inquiry.btn_bgWhite {
  background-color: #fff;
  color: #333 !important;
}

.btn_inquiry.btn_bgYellow,
.btn_inquiry.btn_bgBlue,
.btn_inquiry.btn_bgLightGreen {
  font-size: clamp(16px, 2vw, 23.6px);
  max-height: 100px;
  line-height: clamp(20px, 2vw, 34.8px);
  text-align: center;
}

@media only screen and (min-width: 751px) {

  .btn_inquiry.btn_bgYellow,
  .btn_inquiry.btn_bgBlue,
  .btn_inquiry.btn_bgLightGreen {
    height: 4em;
  }
}

.btn_inquiry.btn_bgYellow[target=_blank]::after,
.btn_inquiry.btn_bgBlue[target=_blank]::after,
.btn_inquiry.btn_bgLightGreen[target=_blank]::after {
  background: url(/html/upload/user_data/fp/open/img/icon_blank-footer.png) no-repeat left top;
}

.btn_inquiry.btn_bgYellow {
  background-color: #ffed4c;
  color: #333 !important;
}

.btn_inquiry.btn_bgBlue {
  background-color: #bde9ee;
  color: #333 !important;
}

.btn_inquiry.btn_bgLightGreen {
  background-color: #cfe6ae;
  color: #333 !important;
}

.btn_inquiry.btn_bgYellow::before {
  border-right: solid 1px #ffed4c;
  border-bottom: solid 1px #ffed4c;
}

.btn_inquiry.btn_bgBlue::before {
  border-right: solid 1px #bde9ee;
  border-bottom: solid 1px #bde9ee;
}

.btn_inquiry.btn_bgLightGreen::before {
  border-right: solid 1px #cfe6ae;
  border-bottom: solid 1px #cfe6ae;
}

.btn_inquiry.btn_bgWhite[target=_blank]::after {
  background: url(/html/upload/user_data/fp/open/img/icon_blank-footer.png) no-repeat left top;
}



.btn_inquiry.btn_bgWhite::before {
  border-right: solid 1px #fff;
  border-bottom: solid 1px #fff;
}

.btn_inquiry.btn_bgWhite[target=_blank]::after {
  background: url(/html/upload/user_data/fp/open/img/icon_blank-footer.png) no-repeat left top;
}

.btn_inquiry.btn_bgWhite.shopping:hover {
  background-color: #ffed4c;
}

.btn_inquiry.btn_bgWhite.ticket:hover {
  background-color: #bde9ee;
}

.btn_inquiry.btn_bgWhite.order:hover {
  background-color: #cfe6ae;
}

.btn_text_inquiry {
  display: block;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  background: none;
  margin: 0;
  padding: 0;
  cursor: pointer;
  font-size: inherit;
  font-family: "Noto Sans JP", sans-serif;
  color: #00833e !important;
  text-decoration: underline;
  position: relative;
}

@media only screen and (max-width: 750px) {
  .btn_text_inquiry {
    font-size: 14px;
  }
}

.btn_text_inquiry::after {
  display: inline-block;
  content: "";
  width: 12px;
  height: 12px;
  margin-left: 3px;
  margin-right: 5px;
  background: url(/html/upload/user_data/fp/open/img/icon_blank-footer.png) no-repeat left top;
}

/* ナビゲーションメニュー ******************************************************/
.openNav {
  display: block;
  width: 100%;
  min-height: 70px;
}

@media only screen and (max-width: 750px) {
  .openNav {
    height: 60px;
    min-height: 60px;
    margin-bottom: -60px;
  }
}

.openNavOuter {
  /* position: -webkit-sticky;
  position: sticky; */
  position: absolute;
  z-index: 2;
  top: 0;
  width: 100%;
  display: block;
  background-color: rgba(255, 255, 255, 0.9);
  font-weight: 600;
  transition-property: background-color;
  transition-duration: 0.4s;
}

@media only screen and (max-width: 750px) {
  .openNavOuter {
    background: none;
  }
}

.openNavOuter.bgNone {
  background: none;
  width: auto;
  right: 0;
}

@media only screen and (max-width: 750px) {
  .openNavOuter.bgNone {
    width: 100%;
  }
}

.openNavOuter.fixed {
  position: fixed;
}

@media only screen and (max-width: 750px) {
  .openNavOuter.fixed {
    top: 50px;
    background: none;
  }
}

.openNavList {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  min-height: 70px;
  height: 100%;
  margin: 0;
}

@media only screen and (max-width: 750px) {
  .openNavList {
    min-height: 90px;
  }
}

@media only screen and (max-width: 650px) {
  .openNavList {
    min-height: 80px;
  }
}

@media only screen and (max-width: 350px) {
  .openNavList {
    min-height: 70px;
  }
}

.openNavListItem {
  width: auto;
}

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

  .openToppage .openNavListItem:not(:nth-child(6), :nth-child(7), :nth-child(8)) {
    display: none;
  }

  .openNavListItem.mailBtn {
    width: calc(100% / 3);
    box-sizing: border-box;
    /* width: 50%; */
  }
}

.openNavListItemLink {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  min-height: 70px;
  height: 100%;
  padding-left: 10px;
  padding-right: 20px;
  font-size: 18px;
  font-family: "Noto Serif JP", serif;
}

@media only screen and (max-width: 1300px) {
  .openNavListItemLink {
    font-size: 13px;
    padding-right: 10px;
  }
}

@media only screen and (min-width: 751px) {
  .openNavListItemLink {
    padding-top: 10px;
    padding-bottom: 10px;
  }
}

.openNavListItemLink .anotation {
  /* font-size: calc((20 / 750)* 100vw); */
  font-size: 10px;
}

@media only screen and (max-width: 350px) {
  .openNavListItemLink .anotation {
    font-size: calc((20 / 750)* 100vw);
  }
}

.openNavListItemLink.inquiry {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  cursor: pointer;
  background-color: #00833e;
  color: #000;
  transition-duration: 0.3s;
  padding-right: 35px;
  position: relative;
  text-align: center;
  font-size: 13.2px;
}

@media only screen and (max-width: 1300px) {
  .openNavListItemLink.inquiry {
    font-size: 12.2px;
    padding-right: 30px;
  }
}

.openNavListItemLink.inquiry.shopping {
  background-color: #ffed4c;
}

.openNavListItemLink.inquiry.ticket {
  background-color: #bde9ee;
}

.openNavListItemLink.inquiry.order {
  background-color: #cfe6ae;
}

.openNavListItemLink.inquiry.shopping,
.openNavListItemLink.inquiry.ticket,
.openNavListItemLink.inquiry.order {
  text-decoration: none !important;
}

@media only screen and (max-width: 750px) {
  .openNavListItemLink.inquiry {
    /* font-size: calc((20 / 750)* 100vw); */
    font-size: clamp(10px, 1vw + 5.6000000000000005px, 13px);
    /* line-height: clamp(10px, 1vw + 11.200000000000001px, 16px); */

    line-height: 1.3;
    padding: 5px 0;
    justify-content: flex-start;
  }
}

@media only screen and (max-width: 350px) {
  .openNavListItemLink.inquiry {
    font-size: calc((20 / 750)* 100vw);
  }
}

.openNavListItemLink.inquiry::after {
  position: absolute;
  content: "";
  width: 12px;
  height: 12px;
  top: 0;
  bottom: 0;
  right: 16px;
  margin-top: auto;
  margin-bottom: auto;
  background: url(/html/upload/user_data/fp/open/img/icon_blank-footer.png) no-repeat left top;
}

@media only screen and (max-width: 750px) {
  .openNavListItemLink.inquiry::after {
    width: 10px;
    height: 10px;
    background: url(/html/upload/user_data/fp/open/img/icon_blank-footer.png) no-repeat center bottom / contain;
    top: auto;
    bottom: 8px;
    left: 0;
    right: 0;
    margin: auto;
  }
}


.openNavListItemLink.inquiry.shopping:hover {
  background-color: #fff;
  color: #000;
}

.openNavListItemLink.inquiry.ticket:hover {
  background-color: #fff;
  color: #000;
}

.openNavListItemLink.inquiry.order:hover {
  background-color: #fff;
  color: #000;
}

.openNavListItemLink:hover {
  color: inherit;
  text-decoration: none;
}

.openNavListItemLink span {
  position: relative;
}

.openNavListItemLink:hover span::after {
  position: absolute;
  content: "";
  display: block;
  bottom: -10px;
  left: 0;
  width: 100%;
  height: 1px;
  border-bottom: dashed 1px #333;
}

@media only screen and (max-width: 750px) {
  .openNavListItemLink:hover span::after {
    display: none;
  }
}

/* メインビジュアル ******************************************************/
.openMVOuter {
  background: url(/html/upload/user_data/fp/open/img/mv_pc.jpg) no-repeat center center;
  background-size: cover;
  min-height: 600px;
  position: relative;
  margin-top: -20px;
}

@media only screen and (max-width: 750px) {
  .openMVOuter {
    background: url(/html/upload/user_data/fp/open/img/mv_sp.jpg) no-repeat top center;
    background-size: cover;
    min-height: 380px;
    padding-top: 100px;
    padding-bottom: 60px;
  }
}

.openMVHeader {
  position: absolute;
  display: block;
  max-width: 549px;
  width: 40.19%;
  z-index: 1;
  left: 83px;
  top: 45.1%;
}

@media only screen and (max-width: 750px) {
  .openMVHeader {
    position: static;
    min-width: auto;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
}

.openMVHeader img {
  width: 100%;
  height: auto;
}

.openMVInquiryBtnOuter {
  margin-top: 60px;
  display: flex;
  justify-content: flex-end;
}

.openMVOuter .openMVInquiryBtnOuter {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 25px;
  margin-top: auto;
  max-width: 420px;
  width: 30.75%;
  right: 81px;
  top: 57%;
  transform: translateY(-50%);
}

@media only screen and (max-width: 900px) {
  .openMVOuter .openMVInquiryBtnOuter {
    top: 62%;
  }
}

@media only screen and (max-width: 750px) {
  .openMVOuter .openMVInquiryBtnOuter {
    position: static;
    max-width: none;
    width: 80%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 52px;
    transform: none;
    align-items: center;
  }
}

/* リード文 ******************************************************/
.openLeadOuter {
  width: 100%;
  padding-left: calc((100% - 1200px) / 2);
  margin-top: 23px;
}

@media only screen and (max-width: 750px) {
  .openLeadOuter {
    margin-top: 63px;
    padding-left: 0;
  }
}

.openLeadWrapper {
  width: 100%;
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
}

@media only screen and (max-width: 750px) {
  .openLeadWrapper {
    display: block;
  }
}

.openLeadTextOuter {
  width: 70%;
  margin-left: 20px;
}

@media only screen and (max-width: 750px) {
  .openLeadTextOuter {
    width: 100%;
    margin-left: 0;
  }
}

.openLeadText {
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  font-weight: 600;
  line-height: 2.15;
  letter-spacing: 0.05em;
}

@media only screen and (max-width: 750px) {
  .openLeadText {
    padding-left: 15px;
    padding-right: 15px;
    font-size: 15.75px;
  }
}

.openLeadText span {
  position: relative;
  color: #00833e;
}

.openLeadText span::after {
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  left: 0;
  bottom: -2px;
  border-bottom: dashed 1px #00833e;
}

.openLeadSubText {
  width: 94%;
  font-size: 18px;
  line-height: 2.78;
  margin-top: 32px;
}

@media only screen and (max-width: 750px) {
  .openLeadSubText {
    width: 100%;
    font-size: 12.25px;
    padding-left: 15px;
    padding-right: 15px;
    line-height: 2.3;
  }
}

.openLeadImgOuter {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  width: 41.3%;
  margin-top: 75px;
}

@media only screen and (max-width: 750px) {
  .openLeadImgOuter {
    width: 100%;
    margin-top: 20px;
  }
}

.openLeadImgWrapper {
  display: block;
  width: 100%;
}

.openLeadImgWrapper img {
  width: 100%;
  height: auto;
}

/* JRE POINT経済圏をベースとした顧客戦略 ******************************************************/
.openJREPointOuter {
  margin-top: 180px;
}

@media only screen and (max-width: 750px) {
  .openJREPointOuter {
    margin-top: 64px;
  }
}

.openJREPointList {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 90px;
}

@media only screen and (max-width: 750px) {
  .openJREPointList {
    display: block;
    margin-top: 60px;
  }
}

.openJREPointListItem {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-align: center;
  margin-top: 56px;
  padding-top: 95px;
}

.openJREPointListItem:nth-of-type(1) {
  width: 40%;
  background: url(/html/upload/user_data/fp/open/img/jrepoint_client_icon_01.png) no-repeat top center;
  background-size: 81px 75px;
  margin-top: 0;
}

@media only screen and (max-width: 750px) {
  .openJREPointListItem:nth-of-type(1) {
    width: 100%;
  }
}

.openJREPointListItem:nth-of-type(2) {
  width: 40%;
  background: url(/html/upload/user_data/fp/open/img/jrepoint_client_icon_02.png) no-repeat top center;
  background-size: 81px 75px;
  margin-top: 0;
}

@media only screen and (max-width: 750px) {
  .openJREPointListItem:nth-of-type(2) {
    width: 100%;
    margin-top: 56px;
  }
}

.openJREPointListItem:nth-of-type(3) {
  width: 40%;
  background: url(/html/upload/user_data/fp/open/img/jrepoint_client_icon_03.png) no-repeat top center;
  background-size: 81px 75px;
}

@media only screen and (max-width: 750px) {
  .openJREPointListItem:nth-of-type(3) {
    width: 100%;
  }
}

.openJREPointListItem:nth-of-type(4) {
  width: 40%;
  background: url(/html/upload/user_data/fp/open/img/jrepoint_client_icon_05.png) no-repeat top center;
  background-size: 81px 75px;
}

@media only screen and (max-width: 750px) {
  .openJREPointListItem:nth-of-type(4) {
    width: 100%;
  }
}

.openJREPointListItem span.openJREPointListItem-lyout {
  display: block;
  font-size: 18px;
}

@media only screen and (max-width: 750px) {
  .openJREPointListItem span.openJREPointListItem-lyout {
    font-size: 14px;
  }
}

.openJREPointListItem span.openJREPointListItem-lyout:first-of-type {
  min-height: 48px;
}

@media only screen and (max-width: 750px) {
  .openJREPointListItem span.openJREPointListItem-lyout:first-of-type {
    min-height: 28px;
  }
}

.openJREPointListItem span.openJREPointListItem-strong {
  display: inline;
  font-size: 24px;
  font-weight: bold;
  color: #00833e;
}

@media only screen and (max-width: 750px) {
  .openJREPointListItem span.openJREPointListItem-strong {
    font-size: 17.5px;
  }
}

/* 出店サポート ******************************************************/
.openSupportOuter {
  max-width: 1120px;
  width: 100%;
  margin-top: 160px;
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (max-width: 750px) {
  .openSupportOuter {
    margin-top: 100px;
  }
}

.openSupportList {
  display: grid;
  grid-template-columns: calc(50% - 15px) calc(50% - 15px);
  grid-template-rows: auto auto;
  gap: 30px;
  margin-top: 80px;
}

@media only screen and (max-width: 750px) {
  .openSupportList {
    display: block;
    margin-top: 30px;
  }
}

.openSupportListItem {
  border: solid 1px #7fc19e;
  padding: 10px 10px 16px 10px;
}

@media only screen and (max-width: 750px) {
  .openSupportListItem {
    margin-bottom: 20px;
  }
}

.openSupportListItem:nth-of-type(1) {
  grid-column: 1/2;
  grid-row: 1/3;
}

.openSupportListItem:nth-of-type(2) {
  grid-column: 2/3;
  grid-row: 1/2;
}

.openSupportListItem:nth-of-type(3) {
  grid-column: 2/3;
  grid-row: 2/3;
}

@media only screen and (max-width: 750px) {
  .openSupportListItem:nth-of-type(3) {
    margin-bottom: 0;
  }
}

.openSupportListItemHeader {
  background-color: #00833e;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  padding: 20px;
}

@media only screen and (max-width: 750px) {
  .openSupportListItemHeader {
    font-size: 15.75px;
  }
}

.openSupportListItem:nth-of-type(1) .openSupportListItemHeader {
  background-color: #005c2a;
}

.openSupportMeritList {
  margin-top: 17px;
}

.openSupportMeritListItem {
  position: relative;
  font-size: 18px;
  padding-left: 40px;
  padding-right: 20px;
  line-height: 1.7;
  margin-top: 14px;
}

@media only screen and (max-width: 750px) {
  .openSupportMeritListItem {
    font-size: 12.25px;
  }
}

.openSupportMeritListItem:first-of-type {
  margin-top: 0;
}

.openSupportMeritListItem::before {
  position: absolute;
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  top: 0.75em;
  left: 23px;
  background-color: #333;
  border-radius: 3px;
}

/* 費用・プラン ******************************************************/
.openCostPlanOuter {
  margin-top: 26px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanOuter {
    margin-top: 50px;
  }
}

.openCostPlanLeadOuter {
  margin-top: 69px;
}

.openCostPlanLeadText {
  font-size: 18px;
  line-height: 3;
}

@media only screen and (max-width: 750px) {
  .openCostPlanLeadText {
    font-size: 12.25px;
    line-height: 1.8;
  }
}


.openCostPlanTableOuter {
  margin-top: 43px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableOuter {
    margin-top: 30px;
  }
}

.openCostPlanTableInner {
  border: solid 2px #00833e;
  padding: 60px 40px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableInner {
    padding: 20px 15px;
  }
}

.openCostPlanTableTitle {
  font-family: "Noto Serif JP",
    serif;
  display: inline-block;
  background: #000;
  color: #fff;
  padding: 30px;
  font-size: 28px;
  margin-bottom: 10px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableTitle {
    padding: 15px 20px;
    font-size: 22px;
  }
}

.openCostPlanTableTitle.shopping {
  background: #ffed4c;
  color: #000;
}

.openCostPlanTableTitle.ticket {
  background: #bde9ee;
  color: #000;
}

.openCostPlanTableTitle.order {
  background-color: #cfe6ae;
  color: #000;
}


.openCostPlanTable {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTable {
    display: block;
  }
}

.openCostPlanTableTerm {
  width: 230px;
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  font-weight: 600;
  letter-spacing: -0.1em;
  position: relative;
  text-align: center;
  padding-bottom: 19px;
  border-bottom: dashed 1px #333;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableTerm {
    width: 100%;
    font-size: 19.25px;
    padding-bottom: 10px;
  }
}

.openCostPlanTableTerm::after {
  position: absolute;
  display: block;
  width: 100%;
  height: 1px;
  left: 0;
  bottom: -19px;
  border-bottom: dashed 1px #333;
}

.openCostPlanTableTerm:nth-of-type(2) {
  padding-top: 56px;
}

.openCostPlanTableDescription {
  width: calc(100% - 230px);
  padding-left: 50px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableDescription {
    width: 100%;
    padding-left: 0;
  }
}

.openCostPlanTableDescription .initialCost {
  display: flex;
  align-items: baseline;
  width: 100%;
  height: 100%;
  font-size: 24px;
  font-weight: bold;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableDescription .initialCost {
    margin-top: 20px;
    font-size: 15.75px;
    justify-content: center;
  }
}

.openCostPlanTableDescription .initialCost span {
  font-size: 40px;
  padding-left: 0.3em;
  padding-right: 0.2em;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableDescription .initialCost span {
    font-size: 24.5px;
  }
}

.openCostPlanTableDescription:nth-of-type(2) {
  padding-top: 56px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanTableDescription:nth-of-type(2) {
    padding-top: 20px;
  }
}

.openCostPlanRCList {
  display: grid;
  grid-template-columns: 29.9% 5.14% 29.9% 5.14% 29.9%;
  grid-template-rows: auto;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCList {
    display: block;
  }
}

.openCostPlanRCListItem {
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  padding: 20px 10px 13px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCListItem {
    padding-top: 15px;
  }
}

.openCostPlanRCListItem:nth-of-type(1),
.openCostPlanRCListItem:nth-of-type(3) {
  width: 100%;
  background-color: #005c2a;
  color: #fff;
}

.openCostPlanRCListItem:nth-of-type(2),
.openCostPlanRCListItem:nth-of-type(4) {
  width: 100%;
  grid-template-rows: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
}

.openCostPlanRCListItem:nth-of-type(5) {
  width: 100%;
  background-color: #00833e;
  color: #fff;
  grid-template-rows: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: bold;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCListItem:nth-of-type(5) {
    min-height: 84px;
  }
}

.openCostPlanRCListItem .RCheader {
  display: block;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  border-bottom: dashed 1px #fff;
  line-height: 1;
  padding-bottom: 16px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCListItem .RCheader {
    font-size: 19.25px;
  }
}

.openCostPlanRCListItem .RCheader span {
  font-size: 20px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCListItem .RCheader span {
    font-size: 14px;
  }
}

.openCostPlanRCListItem .RCDesc {
  display: block;
  font-size: 40px;
  text-align: center;
  margin-top: 14px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCListItem .RCDesc {
    font-size: 31.5px;
  }
}

.openCostPlanRCListItem .RCDesc span.RCfontBold {
  font-weight: bold;
  padding-right: 0.1em;
  font-size: inherit;
}

.openCostPlanRCListItem .RCDesc span.RCfontSmall {
  font-size: 24px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCListItem .RCDesc span.RCfontSmall {
    font-size: 14px;
  }
}

.openCostPlanRCListItem .RCDesc span.RCattention {
  display: block;
  font-size: 15px;
  margin-top: 12px;
}

@media only screen and (max-width: 750px) {
  .openCostPlanRCListItem .RCDesc span.RCattention {
    font-size: 12.25px;
    margin-top: 3px;
  }
}

/* 出店までの流れ ******************************************************/
.openFlowOuter {
  margin-top: 31px;
}

@media only screen and (max-width: 750px) {
  .openFlowOuter {
    margin-top: 50px;
  }
}

.openFlowListOuter {
  margin-top: 100px;
  padding-bottom: 155px;
}

@media only screen and (max-width: 750px) {
  .openFlowListOuter {
    margin-top: 70px;
    padding-bottom: 100px;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    flex-direction: row-reverse;
  }
}

.openFlowPeriod {
  background: linear-gradient(to right, #00833e, #005c2a);
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  padding: 9px 28px 11px;
  -webkit-clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 50%, calc(100% - 16px) 100%, 0 100%);
  clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 50%, calc(100% - 16px) 100%, 0 100%);
}

@media only screen and (max-width: 750px) {
  .openFlowPeriod {
    background: linear-gradient(to bottom, #00833e, #005c2a);
    font-size: 14px;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    -webkit-text-orientation: upright;
    text-orientation: upright;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% calc(100% - 16px), 50% 100%, 0 calc(100% - 16px));
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 16px), 50% 100%, 0 calc(100% - 16px));
    padding: 10px 3px;
  }
}

.openFlowList {
  display: grid;
  grid-template-columns: 20.83% 20.83% 20.83% 20.83% 16.67%;
  grid-template-rows: auto;
  margin-top: 30px;
}

@media only screen and (max-width: 750px) {
  .openFlowList {
    display: block;
    margin-top: 0;
    margin-right: 15px;
  }
}

.openFlowListItem {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  margin: 0;
  padding: 0 50px 0 0;
  position: relative;
}

@media only screen and (max-width: 750px) {
  .openFlowListItem {
    display: block;
    padding: 0 0 50px 0;
  }
}

.openFlowListItem::before {
  position: absolute;
  content: "";
  display: block;
  width: 31px;
  height: 31px;
  top: 60px;
  right: 11px;
  background: url(/html/upload/user_data/fp/open/img/flow_icon_arrow.png) no-repeat left top;
  background-size: 31px 31px;
}

@media only screen and (max-width: 750px) {
  .openFlowListItem::before {
    top: auto;
    bottom: 10px;
    right: 0;
    left: 0;
    margin-left: auto;
    margin-right: auto;
    transform: rotate(90deg);
  }
}

.openFlowListItem:last-of-type {
  padding-right: 0;
}

@media only screen and (max-width: 750px) {
  .openFlowListItem:last-of-type {
    padding-bottom: 0;
  }
}

.openFlowListItem:last-of-type::before {
  display: none;
}

.openFlowListItem .openFlowStepOuter {
  display: block;
}

.openFlowListItem:nth-of-type(1) .openFlowStepOuter,
.openFlowListItem:nth-of-type(5) .openFlowStepOuter {
  color: #fff;
  grid-template-rows: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
}

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

  .openFlowListItem:nth-of-type(1) .openFlowStepOuter,
  .openFlowListItem:nth-of-type(5) .openFlowStepOuter {
    padding-top: 25px;
    padding-bottom: 25px;
    font-size: 17.5px;
  }
}

.openFlowListItem:nth-of-type(1) .openFlowStepOuter {
  background-color: #00833e;
}

.openFlowListItem:nth-of-type(5) .openFlowStepOuter {
  background-color: #005c2a;
}

.openFlowListItem:nth-of-type(2) .openFlowStepOuter,
.openFlowListItem:nth-of-type(3) .openFlowStepOuter,
.openFlowListItem:nth-of-type(4) .openFlowStepOuter {
  display: flex;
  flex-direction: column;
  border: solid 1px #333;
  padding: 17px 20px 9px;
}

.openFlowListItem:nth-of-type(2) .openFlowStepNumber,
.openFlowListItem:nth-of-type(3) .openFlowStepNumber,
.openFlowListItem:nth-of-type(4) .openFlowStepNumber {
  font-family: "Noto Serif JP", serif;
  color: #00833e;
  font-size: 24px;
  font-weight: 600;
  text-align: center;
  border-bottom: dashed 1px #00833e;
  padding-bottom: 13px;
}

.openFlowListItem:nth-of-type(2) .openFlowStepNumber span,
.openFlowListItem:nth-of-type(3) .openFlowStepNumber span,
.openFlowListItem:nth-of-type(4) .openFlowStepNumber span {
  font-style: italic;
  font-size: 30px;
}

.openFlowListItem:nth-of-type(2) .openFlowStepText,
.openFlowListItem:nth-of-type(3) .openFlowStepText,
.openFlowListItem:nth-of-type(4) .openFlowStepText {
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: center;
  font-family: "Noto Serif JP", serif;
  font-size: 22px;
  text-align: center;
  line-height: 1.8;
  margin-top: 4px;
}

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

  .openFlowListItem:nth-of-type(2) .openFlowStepText,
  .openFlowListItem:nth-of-type(3) .openFlowStepText,
  .openFlowListItem:nth-of-type(4) .openFlowStepText {
    font-size: 15.75px;
    margin-top: 15px;
  }
}

.openFlowStepLeadTextOuter {
  margin-top: 18px;
}

.openFlowStepLeadText {
  font-size: 18px;
  line-height: 1.8;
}

@media only screen and (max-width: 750px) {
  .openFlowStepLeadText {
    font-size: 12.25px;
  }
}

/* 加盟店紹介 ******************************************************/
.openIntroductionOuter-first {
  margin-top: 26px;
}

.openIntroductionOuter-second {
  padding-bottom: 160px;
}

@media only screen and (max-width: 750px) {
  .openIntroductionOuter-second {
    padding-bottom: 100px;
  }
}

.openIntroductionLeadOuter {
  width: 100%;
  margin-top: 71px;
}

@media only screen and (max-width: 750px) {
  .openIntroductionLeadOuter {
    width: 100%;
  }
}

.openIntroductionLeadText {
  font-size: 18px;
  color: #fff;
  line-height: 2.6;
}

@media only screen and (max-width: 750px) {
  .openIntroductionLeadText {
    font-size: 14px;
    line-height: 1.8;
  }
}

.openIntroductionListOuter {
  margin-top: 40px;
  padding-top: 10px !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
}

@media only screen and (max-width: 750px) {
  .openIntroductionListOuter {
    margin-top: 40px;
    padding-top: 0 !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

.openIntroductionList {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-bottom: 10px;
}

@media only screen and (max-width: 750px) {
  .openIntroductionList {
    flex-wrap: inherit;
    justify-content: inherit;
    /* flex-direction: column; */
  }
}

.openIntroductionListItem {
  display: block;
  max-width: 360px;
  width: 30%;
  margin-right: 5%;
  margin-top: 60px;
}

@media only screen and (max-width: 750px) {
  .openIntroductionListItem {
    max-width: none;
    width: 100%;
    margin-right: 0;
    margin-top: 0;
    padding-bottom: 10px;
  }
}

.openIntroductionListItem:nth-of-type(3n),
.openIntroductionListItem:last-of-type {
  margin-right: 0;
}

.openIntroductionListItem:nth-of-type(1),
.openIntroductionListItem:nth-of-type(2),
.openIntroductionListItem:nth-of-type(3) {
  margin-top: 0;
}

.openIntroductionListItemLink {
  display: block;
  height: 100%;
  background-color: #fff;
  border-top-right-radius: 30px;
  border-bottom-left-radius: 30px;
  position: relative;
  text-decoration: none;
  transition-duration: 0.3s;
  top: 0;
  left: 0;
}
.openIntroductionListItemBox {
  display: block;
  height: 100%;
  background-color: #fff;
  border-top-right-radius: 30px;
  border-bottom-left-radius: 30px;
  position: relative;
}

@media only screen and (max-width: 750px) {
  .openIntroductionListItemLink {
    text-decoration: none !important;
  }
}

.openIntroductionListItemLink::after,
.openIntroductionListItemBox::after {
  position: absolute;
  content: "";
  display: block;
  width: 15px;
  height: 15px;
  right: -10px;
  bottom: -10px;
  border-right: solid 1px #fff;
  border-bottom: solid 1px #fff;
}

.openIntroductionListItemLink:hover {
  top: -10px;
  left: -10px;
  text-decoration: none;
  color: inherit;
}

@media only screen and (max-width: 750px) {
  .openIntroductionListItemLink:hover {
    top: 0;
    left: 0;
  }
}

.openIntroductionListItemImgOuter {
  overflow: hidden;
  border-top-right-radius: 30px;
  height: auto;
}

.openIntroductionListItemImgOuter img {
  transition-duration: 0.3s;
  width: auto;
  max-height: 260px;
  margin-left: auto;
  margin-right: auto;
}

.openIntroductionListItemLink:hover .openIntroductionListItemImgOuter img {
  transform: scale(1.08);
}

.openIntroductionListItemShopName {
  font-size: 24px;
  font-weight: bold;
  margin-top: 28px;
  padding-left: 30px;
  padding-right: 30px;
}

@media only screen and (max-width: 750px) {
  .openIntroductionListItemShopName {
    font-size: 17.5px;
    margin-top: 20px;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.openIntroductionListItemShopText {
  font-size: 18px;
  margin-top: 8px;
  padding-left: 30px;
  padding-right: 30px;
  padding-bottom: 21px;
  line-height: 1.8;
}

@media only screen and (max-width: 750px) {
  .openIntroductionListItemShopText {
    font-size: 12.25px;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.openIntroductionListItem.comingsoon {
  max-width: 100%;
  width: 70%;
}

@media only screen and (max-width: 750px) {
  .openIntroductionListItem.comingsoon {
    width: 100%;
  }
}

.openIntroductionListItem.comingsoon .openIntroductionListItemLink {
  padding: 30px;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  pointer-events: none;
}

.openIntroductionListItem.comingsoon .openIntroductionListItemLink:hover {}

.swiper-slide {
  width: 30%;
}

@media only screen and (max-width: 750px) {
  .swiper-pagination {
    position: static !important;
    margin-top: 10px;
  }
}

@media only screen and (max-width: 750px) {
  .swiper-pagination-bullet {
    width: 12px !important;
    height: 12px !important;
    margin-left: 5px !important;
    margin-right: 5px !important;
    background-color: #fff !important;
  }
}

.btn_text_open_shioplist {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  background: none;
  margin: 0;
  padding: 0;
  cursor: pointer;
  font-size: 18px;
  font-family: "Noto Sans JP", sans-serif;
  color: #fff !important;
  text-decoration: underline;
  position: relative;
  display: block;
}

@media only screen and (max-width: 750px) {
  .btn_text_open_shioplist {
    font-size: 14px;
  }
}

/* よくあるご質問 ******************************************************/
.openFaqOuter {
  margin-top: 33px;
}

@media only screen and (max-width: 750px) {
  .openFaqOuter {
    margin-top: 50px;
  }
}

.openFaqListOuter {
  margin-top: 78px;
}

.openFaqList {
  max-width: 900px;
  width: 100%;
  margin-top: 60px;
  margin-left: auto;
  margin-right: auto;
  border-bottom: dashed 1px #333;
}

.openFaqList.openVoiceQAList {
  max-width: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  border: none;
}

@media only screen and (max-width: 750px) {
  .openFaqList.openVoiceQAList {
    display: block;
  }
}

.openFaqListTerm {
  background-color: #00833e;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.8;
  padding: 24px 20px 22px 108px;
  position: relative;
}

@media only screen and (max-width: 750px) {
  .openFaqListTerm {
    font-size: 14px;
    padding: 16px 10px 16px 55px;
  }
}

.openFaqListTerm::before {
  position: absolute;
  content: "Q";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  left: 32px;
  top: 20px;
  line-height: 1;
  background-color: #fff;
  color: #005c2a;
  border-radius: 20px;
  font-size: 21px;
  font-weight: normal;
  padding-bottom: 4px;
}

@media only screen and (max-width: 750px) {
  .openFaqListTerm::before {
    width: 30px;
    height: 30px;
    left: 12px;
    top: 17px;
    border-radius: 15px;
    font-size: 14px;
  }
}

.openVoiceQAList .openFaqListTerm {
  max-width: 570px;
  width: 100%;
  padding: 22px 20px 20px 68px;
  display: flex;
  align-items: center;
}

@media only screen and (min-width: 751px) {
  .openVoiceQAList .openFaqListTerm {
    min-height: 114px;
  }
}

@media only screen and (max-width: 750px) {
  .openVoiceQAList .openFaqListTerm {
    max-width: none;
    padding: 12px 20px 14px 68px;
  }
}

.openVoiceQAList .openFaqListTerm::before {
  display: none;
}

.openVoiceQAList .openFaqListTerm p {
  display: block;
  position: relative;
}

.openVoiceQAList .openFaqListTerm p::before {
  position: absolute;
  content: "Q";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  left: -47px;
  top: 2px;
  line-height: 1;
  background-color: #fff;
  color: #005c2a;
  border-radius: 20px;
  font-size: 21px;
  font-weight: normal;
  padding-bottom: 4px;
}

@media only screen and (max-width: 750px) {
  .openVoiceQAList .openFaqListTerm p::before {
    top: 0;
  }
}

.openFaqListDescription {
  font-size: 18px;
  line-height: 1.8;
  padding: 19px 20px 22px 108px;
  position: relative;
}

@media only screen and (max-width: 750px) {
  .openFaqListDescription {
    font-size: 12.25px;
    padding: 16px 10px 16px 55px;
  }
}

.openFaqListDescription::before {
  position: absolute;
  content: "A";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  left: 32px;
  top: 15px;
  line-height: 1;
  background-color: #005c2a;
  color: #fff;
  border-radius: 20px;
  font-size: 21px;
  font-weight: normal;
  padding-bottom: 2px;
}

@media only screen and (max-width: 750px) {
  .openFaqListDescription::before {
    width: 30px;
    height: 30px;
    left: 12px;
    top: 13px;
    border-radius: 15px;
    font-size: 14px;
  }
}

.openVoiceQAList .openFaqListDescription {
  max-width: 570px;
  width: 100%;
  border-bottom: none;
  padding: 22px 20px 50px 68px;
}

@media only screen and (max-width: 750px) {
  .openVoiceQAList .openFaqListDescription {
    max-width: none;
  }
}

.openVoiceQAList .openFaqListDescription::before {
  width: 32px;
  height: 32px;
  left: 21px;
  top: 24px;
  border-radius: 16px;
  font-size: 18px;
  font-weight: normal;
  padding-bottom: 4px;
}

@media only screen and (max-width: 750px) {
  .openVoiceQAList .openFaqListDescription::before {
    top: 18px;
  }
}

.openFaqListDescriptionText {
  margin-bottom: 1em;
}

.openFaqListDescriptionText:last-of-type {
  margin-bottom: 0;
}

.openFaqMoreBtnOuter {
  display: flex;
  justify-content: center;
  margin-top: 60px;
}

/* 加盟店紹介ページ ******************************************************/
.openVoiceMVOuter {
  width: calc(100% - 20px);
  padding-left: calc((100% - 1200px) / 2 - 20px);
  display: block;
  margin-top: 70px;
  margin-left: 20px;
}

@media only screen and (max-width: 750px) {
  .openVoiceMVOuter {
    margin-top: 0;
    padding-top: 90px;
  }
}

.openVoiceMVWrapper {
  width: 100%;
  margin-top: 70px;
  position: relative;
  padding-right: 20px;
}

.openVoiceHeaderText {
  position: absolute;
  right: 0;
  top: -51px;
}

@media only screen and (max-width: 750px) {
  .openVoiceHeaderText::after {
    bottom: -15px;
  }
}

@media only screen and (max-width: 750px) {
  .openVoiceHeaderText {
    top: -66px;
  }
}

.openVoiceMVInner {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  max-width: 1200px;
  width: 100%;
}

@media only screen and (max-width: 750px) {
  .openVoiceMVInner {
    flex-wrap: wrap;
    flex-direction: column;
  }
}

.openVoiceMVTextOuter {
  max-width: 600px;
  width: 100%;
  display: flex;
  justify-content: flex-end;
  flex-direction: column;
}

@media only screen and (max-width: 750px) {
  .openVoiceMVTextOuter {
    max-width: none;
    order: 2;
    margin-top: 20px;
  }
}

.openVoiceMVCompanyOuter {
  width: 100%;
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  margin-bottom: 44px;
}

@media only screen and (max-width: 750px) {
  .openVoiceMVCompanyOuter {
    margin-bottom: 20px;
  }
}

.openVoiceMVCompanyLogoOuter {
  width: 94px;
}

.openVoiceMVCompanyNameOuter {
  width: calc(100% - 119px);
}

@media only screen and (max-width: 750px) {
  .openVoiceMVCompanyNameOuter {
    width: calc(100% - 109px);
  }
}

.openVoiceMVCompanyName-company {
  font-size: 22.75px;
  font-weight: bold;
  margin-bottom: 18px;
}

@media only screen and (max-width: 750px) {
  .openVoiceMVCompanyName-company {
    margin-bottom: 10px;
  }
}

.openVoiceMVCompanyName-name {
  font-size: 20px;
}

.openVoiceMVCompanyLeadText {
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  line-height: 2;
  font-weight: 600;
}

@media only screen and (max-width: 750px) {
  .openVoiceMVCompanyLeadText {
    font-size: 19.25px;
    line-height: 1.8;
  }
}

.openVoiceMVImageOuter {
  max-width: 570px;
  width: 100%;
}

@media only screen and (max-width: 750px) {
  .openVoiceMVImageOuter {
    max-width: none;
    order: 1;
  }
}

.openVoiceMVImageWrapper {
  width: 100%;
  height: auto;
  display: flex;
  justify-content: center;
}

.openVoiceMVImageWrapper img {
  border-top-right-radius: 50px;
  border-bottom-left-radius: 50px;
}

.openVoiceLeadOuter {
  margin-top: 41px;
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
}

@media only screen and (max-width: 750px) {
  .openVoiceLeadOuter {
    display: block;
  }
}

.openVoiceLeadTextOuter {
  width: calc(100% - 350px);
  display: block;
}

@media only screen and (max-width: 750px) {
  .openVoiceLeadTextOuter {
    width: 100%;
  }
}

.openVoiceLeadText {
  font-size: 18px;
  line-height: 2.8;
}

@media only screen and (max-width: 750px) {
  .openVoiceLeadText {
    font-size: 15.5px;
    line-height: 1.8;
  }
}

.openVoiceLeadShopBtnOuter {
  width: 320px;
  margin-top: 19px;
}

@media only screen and (max-width: 750px) {
  .openVoiceLeadShopBtnOuter {
    display: flex;
    justify-content: center;
    width: 100%;
  }
}

.openVoiceQAOuter {
  margin-top: 100px;
}

@media only screen and (max-width: 750px) {
  .openVoiceQAOuter {
    margin-top: 70px;
  }
}

.openVoiceQAList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 50px;
}

@media only screen and (max-width: 750px) {
  .openVoiceQAList {
    display: block;
  }
}

.openVoiceQAListItem {
  max-width: 570px;
  width: 47.5%;
}

@media only screen and (max-width: 750px) {
  .openVoiceQAListItem {
    max-width: none;
    width: 100%;
  }
}

.openFaqListDescriptionSubOuter {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
}

@media only screen and (max-width: 750px) {
  .openFaqListDescriptionSubOuter {
    display: block;
  }
}

.openFaqListDescriptionSubTextOuter {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

@media only screen and (max-width: 750px) {
  .openFaqListDescriptionSubTextOuter {
    width: 100%;
  }
}

@media only screen and (max-width: 750px) {
  .openFaqListDescriptionSubText {
    font-size: 12.25px;
  }
}

.openFaqListDescriptionSubImageOuter {
  display: block;
  width: 155px;
  margin-left: 10px;
}

@media only screen and (max-width: 750px) {
  .openFaqListDescriptionSubImageOuter {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-left: 0;
    margin-top: 10px;
  }
}

.openFaqListDescriptionSubImageOuter:empty {
  display: none;
  margin-left: 0;
}

.openFaqListDescriptionSubImage {
  margin-top: 15px;
}

@media only screen and (max-width: 750px) {
  .openFaqListDescriptionSubImage {
    margin-top: 0;
  }
}

.openFaqListDescriptionSubImage:first-of-type {
  margin-top: 0;
}

@media only screen and (max-width: 750px) {
  .openFaqListDescriptionSubImage {
    max-width: 100px !important;
    width: 100%;
    height: auto;
  }
}

.openVoiceOtherShopOuter {
  margin-top: 50px;
}

.openIntroductionTitle {
  font-family: "Noto Serif JP", serif;
  display: inline-block;
  background: #000;
  color: #fff;
  padding: 20px;
  font-size: 20px;
  margin-bottom: 10px;
  margin-top: 30px;
}

.openIntroductionTitle.shopping {
  background: #ffed4c;
  color: #000;
}

.openIntroductionTitle.ticket {
  background: #bde9ee;
  color: #000;
}

.openIntroductionTitle.order {
  background: #cfe6ae;
  color: #000;
}

.openVoiceOtherShopListOuter {
  margin-top: 90px;
  background: linear-gradient(to bottom, #fff 0px, #fff 120px, #00833e 120px);
  padding-bottom: 70px !important;
  padding-top: 10px !important;
}

@media only screen and (max-width: 750px) {
  .openVoiceOtherShopListOuter {
    margin-top: 70px;
    padding-top: 0 !important;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.openVoiceFooterOuter {
  width: 100%;
  height: auto;
  background: url(/html/upload/user_data/fp/open/img/footer_bg.jpg) no-repeat bottom center;
  background-size: cover;
  padding-top: 80px;
  padding-bottom: 90px;
}

@media only screen and (max-width: 750px) {
  .openVoiceFooterOuter {
    padding-top: 100px;
    padding-left: 25px;
    padding-right: 25px;
  }
}

.openVoiceFooterBtnOuter {
  display: flex;
  justify-content: center;
}

/* よくあるご質問ページ ******************************************************/
.openFaqNavOuter {
  margin-top: 20px;
}

#fp_nav {
  margin-bottom: 0;
}

#fp_nav ul {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 30px;
  flex-wrap: nowrap;
}

@media only screen and (max-width: 750px) {
  #fp_nav ul {
    flex-wrap: wrap;
  }
}

#fp_nav ul li {
  flex-grow: 1;
  flex-shrink: 1;
  border-left: 1px solid rgb(218, 218, 218);
  padding-right: 2px;
  padding-left: 2px;
  height: auto;
  margin-bottom: 3px;
}

@media only screen and (max-width: 750px) {
  #fp_nav ul li {
    flex-grow: initial;
    flex-shrink: initial;
    width: 50%;
    display: block;
    border-left: none;
    border-right: 1px solid rgb(218, 218, 218);
  }
}

@media only screen and (max-width: 750px) {
  #fp_nav ul li:nth-of-type(odd) {
    border-left: 1px solid rgb(218, 218, 218);
  }
}

#fp_nav ul li:last-of-type {
  border-right: 1px solid rgb(218, 218, 218);
  /* width: calc(((100% - 1px) / 4) - 1px); */
}

@media only screen and (max-width: 750px) {
  #fp_nav ul li:last-of-type {
    width: 50%;
  }
}

#fp_nav ul li a {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 4px;
  width: 100%;
  height: 100%;
  text-align: center;
  text-decoration: none;
  font-size: 16px;
  font-weight: bold;
  color: rgb(0, 131, 63);
  padding-top: 8px;
  padding-bottom: 25px;
  background-image: url("/fp/img/ico_arrow_b_grn.png");
  background-repeat: no-repeat;
  background-position: 50% 90%;
  font-family: "Noto Serif JP", serif;
}

#fp_nav ul li a:hover {
  background-color: rgb(230, 245, 236);
}

.openFaqHeaderOuter {
  margin-top: 60px;
  padding-top: 20px;
}

.openFaqLowerOuter {
  width: calc(100% - 20px);
  padding-left: calc((100% - 1200px) / 2 - 20px);
  display: block;
  margin-top: 70px;
  margin-left: 20px;
}

@media only screen and (max-width: 750px) {
  .openFaqLowerOuter {
    margin-top: 0;
    padding-top: 90px;
  }
}

.openFaqLowerWrapper {
  width: 100%;
  margin-top: 70px;
  position: relative;
  padding-right: 20px;
}

.openFaqLowerHeaderText {
  position: absolute;
  right: 0;
  top: -51px;
}

@media only screen and (max-width: 750px) {
  .openFaqLowerHeaderText::after {
    bottom: -15px;
  }
}

@media only screen and (max-width: 750px) {
  .openFaqLowerHeaderText {
    top: -66px;
  }
}

.openFaqLowerInner {
  display: block;
  max-width: 1200px;
  width: 100%;
  padding-top: 70px;
  padding-bottom: 120px;
}

@media only screen and (max-width: 750px) {
  .openFaqLowerInner {
    padding-top: 0;
  }
}

/* フッター ******************************************************/
.openFooterOuter {
  width: 100%;
  height: auto;
  margin-top: 170px;
  background: url(/html/upload/user_data/fp/open/img/footer_bg.jpg) no-repeat center center;
  background-size: cover;
  padding-top: 160px;
  padding-bottom: 160px;
}

@media only screen and (max-width: 750px) {
  .openFooterOuter {
    padding-top: 100px;
    padding-left: 25px;
    padding-right: 25px;
    padding-bottom: 100px;
  }
}

.openFooterImgOuter {
  display: flex;
  justify-content: center;
  line-height: 1;
}

.openFooterBtnOuter {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 60px;
  margin-right: 40px;
  margin-left: 40px;
  margin-bottom: 100px;
  gap: 40px;
}

@media only screen and (max-width: 750px) {
  .openFooterBtnOuter {
    margin-bottom: 50px;
  }
}

.openFooterBtnOuter .btn_inquiry {
  font-size: clamp(16px, 2vw, 23.6px);
  max-height: 100px;
  height: 4em;
  line-height: clamp(20px, 2vw, 34.8px);
  /* line-height: clamp(16px, 2vw, 34.8px); */
  text-align: center;
}

@media only screen and (max-width: 750px) {
  .openFooterBtnOuter .btn_inquiry {
    height: 80px;
    max-height: none;
    font-size: 17.5px;
    line-height: 21.5px;
    /* line-height: 17.5px; */
  }
}

@media only screen and (max-width: 750px) {
  .openFooterBtnOuter .btn_inquiry::before {
    height: 80px;
  }
}

@media only screen and (max-width: 750px) {
  .openFooterBtnOuter {
    align-items: center;
    flex-direction: column;
  }
}

/* グローバルフッターを上書き ******************************************************/
#footer {
  margin-top: 0;
}





.c-carousel__activator-main {
  display: none;
}

@media only screen and (min-width: 751px) {
  .c-carousel__main-control {
    display: none;
  }
}

@media only screen and (max-width: 750px) {
  .c-carousel {
    position: relative;
    width: 100%;
    margin: 0 auto;
  }

  .c-carousel__activator-main {
    position: absolute;
    z-index: -1;
    opacity: 0;
  }

  .c-carousel__main {
    overflow: hidden;
    position: relative;
  }

  .c-carousel__main-track {
    display: flex;
    transition: transform 0.3s ease-out;
    margin-left: 20px;
  }

  /* .c-carousel__main-item:first-child {
    margin-left: 0;
  } */

  .c-carousel__main-item {
    flex-shrink: 0;
    width: calc(100% - 20px);
    margin-right: 20px;
  }

  .c-carousel__main-image {
    display: block;
    width: 100%;
  }

  .c-carousel__main-control-item {
    display: none;
  }

  .c-carousel__btn-prev-main,
  .c-carousel__btn-next-main {
    position: absolute;
    top: 50%;
    right: 16px;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    transform: translateY(-50%);
    background-color: #000;
    border-radius: 50%;
    transition: opacity 0.3s;
    cursor: pointer;
  }

  .c-carousel__btn-prev-main {
    right: auto;
    left: 16px;
  }

  .c-carousel__activator-main:nth-child(1):checked~.c-carousel__main .c-carousel__main-control-item:nth-child(1) {
    display: block;
  }

  .c-carousel__activator-main:nth-child(2):checked~.c-carousel__main .c-carousel__main-control-item:nth-child(2) {
    display: block;
  }

  .c-carousel__activator-main:nth-child(3):checked~.c-carousel__main .c-carousel__main-control-item:nth-child(3) {
    display: block;
  }


  .c-carousel__activator-main:nth-child(1):checked~.c-carousel__main .c-carousel__main-track {
    transform: translateX(calc(-100% * 0));
  }

  .c-carousel__activator-main:nth-child(2):checked~.c-carousel__main .c-carousel__main-track {
    transform: translateX(calc(-100% * 1));
  }

  .c-carousel__activator-main:nth-child(3):checked~.c-carousel__main .c-carousel__main-track {
    transform: translateX(calc(-100% * 2));
  }

  .c-image-arrow.prev {
    position: absolute;
    width: 10px;
    height: 10px;
    border-bottom: 2px solid #fff;
    border-left: 2px solid #fff;
    top: 57%;
    right: 30%;
    transform: rotate(45deg) translate(-50%, -50%);
  }

  .c-image-arrow.next {
    position: absolute;
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    top: 57%;
    left: 30%;
    transform: rotate(45deg) translate(-50%, -50%);
  }

  .move_controler {
    position: absolute;
    bottom: -20px;
    width: 100%;
    text-align: center;
  }

  .openVoiceOtherShopOuter .move_controler {
    bottom: 50px;
  }

  .button_move {
    display: inline-block;
    height: 12px;
    width: 12px;
    margin: 0 2px;
    border-radius: 100%;
    cursor: pointer;
    opacity: 0.2;
    z-index: 2;
  }

  .button_move:hover {
    opacity: 1;
  }

  .button_move {
    background-color: #fff;
  }

  .c-carousel__activator-main:nth-of-type(1):checked~.c-carousel__main-item:nth-of-type(1) {
    opacity: 1;
  }

  .c-carousel__activator-main:nth-of-type(1):checked~.move_controler .button_move:nth-of-type(1) {
    opacity: 1;
  }

  .c-carousel__activator-main:nth-of-type(2):checked~.c-carousel__main-item:nth-of-type(2) {
    opacity: 1;
  }

  .c-carousel__activator-main:nth-of-type(2):checked~.move_controler .button_move:nth-of-type(2) {
    opacity: 1;
  }

  .c-carousel__activator-main:nth-of-type(3):checked~.c-carousel__main-item:nth-of-type(3) {
    opacity: 1;
  }

  .c-carousel__activator-main:nth-of-type(3):checked~.move_controler .button_move:nth-of-type(3) {
    opacity: 1;
  }
}

/*追記241015*/
.btn_inquiry .anotation {
  font-size: 10px;
  line-height: 1;
  margin-top: 5px;
}

.openInquiryBtnOuter {
  flex-direction: column;
  align-items: flex-end;
}

@media only screen and (max-width: 750px) {
  .openInquiryBtnOuter {
    align-items: center;
  }
}

.openMVInquiryBtnOuter .textlink {
  text-align: left;
  text-decoration: underline;
  color: #fff;
  font-size: 18px;
  text-indent: -18px;
  padding-left: 18px;
}

@media only screen and (max-width: 750px) {
  .btn_inquiry .textlink {
    font-size: 14px;
    text-indent: -14px;
    padding-left: 14px;
  }
}


.openInquiryBtnOuter .textlink {
  margin-top: 30px;
  text-align: left;
  text-decoration: underline;
  color: #000;
  font-size: 18px;
  text-indent: -18px;
  padding-left: 18px;
}

@media only screen and (max-width: 750px) {
  .openInquiryBtnOuter .textlink {
    font-size: 14px;
    text-indent: -14px;
    padding-left: 14px;
    margin-left: -20px;
    margin-right: -20px;
  }
}


.btn_inquiry.js_mailTo::after {
  background: url(/html/upload/user_data/fp/open/img/icon_mailopen.png) no-repeat left top !important;
  width: 20px !important;
  height: 20px !important;
}

@media only screen and (max-width: 750px) {
  .btn_inquiry.js_mailTo::after {
    right: 5.57%;
  }
}


.mailissue {
  border: 2px solid #fff;
  color: #fff;
  max-width: 900px;
  margin-right: auto;
  margin-left: auto;
  padding: 50px;
}

@media only screen and (max-width: 750px) {
  .mailissue {
    padding: 20px;
  }
}


.mailissue__title {
  text-align: center;
  margin: 0 auto 20px;
}

@media only screen and (max-width: 750px) {
  .mailissue__title {
    font-size: 16px;
  }
}


.mailissue__readtext {
  font-size: 18px;
  line-height: 1.8;
  margin-bottom: 20px;
}

@media only screen and (max-width: 750px) {
  .mailissue__readtext {
    font-size: 12.25px;
  }
}


.mailissue__detailtext {
  font-size: 18px;
  line-height: 1.8;
  margin-bottom: 20px;
}

@media only screen and (max-width: 750px) {
  .mailissue__detailtext {
    font-size: 12.25px;
    padding-left: 12.25px;
    text-indent: -12.25px;
    margin-bottom: 10px;
  }
}


.mailissue__detailtext__inner {
  padding-left: 18px;
  display: block;
}

@media only screen and (max-width: 750px) {
  .mailissue__detailtext__inner {
    padding-left: 12.25px;
    display: contents;
  }
}


.mailissue__detailtext__inner .anotation {
  padding-left: 18px;
  text-indent: -18px;
}

@media only screen and (max-width: 750px) {
  .mailissue__detailtext__inner .anotation {
    font-size: 10px;
    padding-left: 10px;
    text-indent: -10px;
  }
}


.openFaqListDescriptionText .textlink {
  text-decoration: underline;
}



/* スクロール位置の調整 ******************************************************/
.c-contents__scrolltarget {
  margin-top: -130px;
  padding-top: 130px;
}

@media only screen and (max-width: 767px) {
  .c-contents__scrolltarget {
    margin-top: -210px;
    padding-top: 210px;
  }
}