main .site {
  width: 1080px;
  margin: 0 auto;
}

.mgt110 {
  margin-top: 110px;
}

.btnWrap {
  margin-top: 30px;
}

.btnWrap > a {
  background-color: #886d55;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 19px;
  line-height: 1.68;
  margin: 0 auto;
  max-width: 384px;
  height: 80px;
  transition: opacity 0.3s ease-in-out;
}

.btnWrap > a:hover {
  opacity: 0.8;
}

#fv {
  padding-top: 100px;
  margin-bottom: 110px;
}

#fv .heading {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  margin-bottom: 45px;
}

#fv .heading .txtEn {
  font-family: "Marcellus SC", serif;
  font-weight: normal;
  font-size: 31px;
  line-height: 1.19;
  color: #999999;
  text-transform: uppercase;
}

#fv .heading .txtJa {
  position: relative;
  font-size: 19px;
  font-family: "Noto Serif JP", serif;
  color: #000;
  line-height: 1.578;
}

#fv .img {
  margin-bottom: 76px;
}

#fv .heading-secondary {
  margin: 120px 0 50px;
}
#fv .telbtn {
  display: none;
}
.heading-secondary {
  font-size: 32px;
  line-height: 1.4;
  color: #886d55;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  position: relative;
}

.heading-secondary::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 0;
  background-color: #886d55;
}

.heading-secondary > span {
  padding: 0 10px;
  background-color: #fff;
  display: inline-block;
  position: relative;
  z-index: 1;
}

.txt {
  font-size: 20px;
  line-height: 2.4;
  color: #000;
  text-align: center;
  font-family: "Noto Serif JP", serif;
}

#example {
  position: relative;
  background-color: rgba(136, 109, 85, 0.1);
}

#example .title {
  text-align: center;
}

#example .title-ja {
  font-size: 35px;
  line-height: 1.258;
  color: #000;
  text-align: center;
  display: inline-block;
  font-family: "Noto Serif JP", serif;
  position: relative;
  padding: 10px 5px;
}

#example .site {
  padding: 100px 0;
}

#example .title-ja::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0%);
  z-index: 1;
  background-color: #886d55;
}

#example .boxIn {
  display: flex;
  justify-content: space-between;
  margin-top: 76px;
}

#example .boxIn .pic {
  width: 492px;
}

#example .boxIn .content {
  width: calc(100% - 492px);
  padding-left: 67px;
}
#example .boxIn .content-list {
  margin-bottom: 60px;
}

#example .boxIn .content-list h4,
#example .boxIn .content-list li {
  font-size: 20px;
  line-height: 1.938;
  color: #000;
  letter-spacing: 0.12em;
  font-family: "Noto Serif JP", serif;
  position: relative;
}

#example .boxIn .content-list li {
  padding-left: 20px;
}

#example .boxIn .content-list li::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  border-color: transparent transparent transparent #886d55;
  border-width: 10px;
  border-style: solid;
  z-index: 1;
}

#example .boxIn .content p {
  font-size: 17px;
  line-height: 1.938;
  color: #000;
  text-align: justify;
  letter-spacing: 0.12em;
  font-family: "Noto Serif JP", serif;
}

.titleMed {
  text-align: center;
  font-size: 26px;
  line-height: 1.73;
  color: #000;
  letter-spacing: 0.12em;
  font-family: "Noto Serif JP", serif;
}

#stores .site {
  padding: 100px 0;
}

#stores .list {
  margin-top: 50px;
}

#stores .list figure {
  text-align: center;
}

#flow {
  position: relative;
  background-color: rgba(136, 109, 85, 0.1);
}

#flow .title {
  text-align: center;
}

#flow .title-ja {
  font-size: 32px;
  line-height: 1.258;
  color: #000;
  text-align: center;
  display: inline-block;
  font-family: "Noto Serif JP", serif;
  position: relative;
  padding: 10px 5px;
}

#flow .site {
  padding: 100px 0;
}

#flow .title-ja::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 5px;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0%);
  z-index: 1;
  background-color: #fff;
}

#flow .listStep {
  max-width: 880px;
  margin: 50px auto 0;
}

#flow .listStep-item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 42px;
}

#flow .listStep-item:last-child {
  margin-bottom: 0;
}

#flow .listStep-item_tit {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  margin-right: 28px;
  position: relative;
}

#flow .listStep-item .content {
  width: calc(100% - 88px);
}

#flow .listStep-item .content > .tit {
  min-width: 165px;
  height: 30px;
  padding: 0 15px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  color: #886d55;
  font-size: 14px;
  border: 1px solid #886d55;
  font-weight: 500;
}

#flow .listStep-item .content > .tit.active {
  background-color: #886d55;
  color: #fff;
}

#flow .listStep-item .content .txt > a {
  position: relative;
  display: inline-block;
  padding-left: 30px;
}
#flow .listStep-item .content .txt.telbtn {
  display: none;
}
#flow .listStep-item .content .txt > a:hover {
  opacity: 0.8;
}

#flow .listStep-item .content .txt > a::before {
  content: "";
  position: absolute;
  width: calc(100% - 30px);
  left: 30px;
  bottom: 0;
  height: 1px;
  background-color: #886d55;
  z-index: 1;
}

#flow .listStep-item .content .txt > a::after {
  content: "";
  position: absolute;
  left: 2px;
  top: 12px;
  border: solid #886d55;
  border-width: 0 2px 2px 0;
  display: inline-block;
  padding: 3px 3px 10px 10px;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}

#flow .listStep-item:last-child .listStep-item_tit::before {
  content: none;
}

#flow .listStep-item_tit::before {
  content: "";
  position: absolute;
  width: 19px;
  height: 9px;
  left: 50%;
  bottom: -15px;
  background-image: url(../../assets/images/gift/icon_arrow.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: translateX(-50%);
  z-index: 1;
}

#flow .listStep-item_tit span {
  display: inline-block;
  color: #886d55;
  font-family: Futura, YuGothic, "ProN W3", "Hiragino Kaku Gothic ProN",
    "Yu Gothic", Meiryo, sans-serif;
}

#flow .listStep-item_tit .txt {
  font-size: 12px;
  text-transform: uppercase;
}

#flow .listStep-item_tit .num {
  font-size: 37px;
}

#flow .listStep-item .txt {
  text-align: left;
  line-height: 1.79;
}

#notes {
  position: relative;
  padding: 100px 0;
}

#notes .list {
  width: 890px;
  margin: 30px auto 0;
}

#notes .list .txt {
  text-align: left;
  text-indent: -20px;
  padding-left: 20px;
}

.onlySP {
  display: none !important;
}

.onlyPC {
  display: block !important;
}

/* SP */
@media (max-width: 768px) {
  .sp-mgt45 {
    margin-top: 45px !important;
  }
  main .site {
    width: 100%;
    padding: 0 20px;
  }

  .onlySP {
    display: block !important;
  }

  .onlyPC {
    display: none !important;
  }

  #fv {
    padding-top: 80px;
    margin-bottom: 80px;
  }
  #fv .telbtn {
    display: block;
  }
  #fv .telbtn > a {
    font-size: 16px;
    font-family: "Marcellus SC", serif;
  }
  .btnWrap > a {
    height: 70px;
  }

  .heading-secondary {
    font-size: 22px;
  }

  #fv .heading {
    margin-bottom: 35px;
  }

  #fv .heading .txtEn {
    font-size: 30px;
    text-align: center;
  }

  #fv .heading-secondary {
    margin: 50px 0 30px;
  }

  #fv .heading .txtJa {
    font-size: 16px;
    text-align: center;
  }

  #fv .img {
    margin-left: -20px;
    margin-right: -20px;
    margin-bottom: 40px;
  }

  .heading-secondary::before {
    content: none;
  }

  .heading-secondary > span {
    border-bottom: 1px solid #886d55;
  }

  .txt {
    font-size: 12px;
  }

  #flow .listStep-item_tit {
    width: 60px;
    height: 60px;
    margin-right: 20px;
  }

  #flow .listStep-item .content {
    width: calc(100% - 60px);
  }

  #flow .listStep-item .content .txt > a::after {
    left: 7px;
    top: 8px;
    padding: 3px 3px 5px 5px;
  }
  #flow .listStep-item .content .txt.telbtn > a::after {
    top: 12px;
  }
  #flow .listStep-item .content .txt.telbtn {
    display: block;
  }
  #flow .listStep-item .content .txt.telbtn > a {
    margin-top: 11px;
    font-size: 18px;
    font-family: "Marcellus SC", serif;
  }
  #flow .listStep-item .content > .tit {
    font-size: 12px;
    min-width: 140px;
  }

  #example .title-ja {
    font-size: 25px;
  }

  #example .site {
    padding: 40px 20px 80px;
  }

  #example .boxIn .content-list {
    margin-bottom: 35px;
  }

  #example .boxIn .content-list li {
    padding-left: 18px;
  }

  #example .boxIn .content-list li::before {
    top: 5px;
    left: 2px;
    border-width: 8px;
  }

  #example .boxIn .content-list h4,
  #example .boxIn .content-list li {
    font-size: 14px;
  }

  #example .boxIn .content p {
    font-size: 12px;
  }

  #example .boxIn {
    display: block;
    width: 100%;
    margin-top: 55px;
  }

  #example .boxIn .pic {
    width: 100%;
  }

  #example .boxIn .content {
    width: 100%;
    padding-left: 0;
  }

  #example .boxIn .content-tit {
    display: block;
    text-align: center;
    margin: 30px 0;
  }

  #stores .site {
    padding: 50px 20px 80px;
  }

  #stores .list {
    margin-top: 35px;
  }

  #flow .site {
    padding: 40px 20px 80px;
  }

  #flow .title-ja {
    font-size: 25px;
  }

  #flow .listStep-item_tit .txt {
    font-size: 10px;
  }

  #flow .listStep-item > .txt {
    font-size: 23px;
  }

  #flow .listStep-item_tit .num {
    font-size: 24px;
  }

  #notes {
    padding: 40px 0 100px;
  }

  #notes .site {
    padding: 0 20px;
  }

  #notes .list {
    width: 100%;
  }

  #notes .list .txt {
    font-size: 12px;
    text-indent: -15px;
    padding-left: 15px;
  }

  .titleMed {
    font-size: 20px;
  }
}

/* Form */
@import url("https://fonts.googleapis.com/css2?family=Marcellus+SC&display=swap");

.contentForm {
  max-width: 1024px;
  margin: 100px auto 0;
  padding-bottom: 100px;
  position: relative;
  z-index: 1;
}

.contentForm .frm__group {
  padding: 60px 70px 60px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid #999999;
}

.contentForm .frm__tit {
  display: flex;
  align-items: center;
  flex-direction: column;
}

.contentForm .frm__tit > .en {
  font-size: 22px;
  color: #999999;
  letter-spacing: 0.1em;
  font-family: "Marcellus SC", serif;
  font-weight: normal;
  margin-bottom: 10px;
  text-align: center;
  line-height: 1.5;
}

.contentForm .txt-Med {
  font-size: 18px;
  line-height: 1.8;
  color: #000;
  font-family: "Noto Serif JP", serif;
}

.contentForm .frm__tit > .ja {
  font-size: 17px;
  color: #000;
  letter-spacing: 0.1em;
  font-family: "Noto Serif JP", serif;
  font-weight: normal;
  line-height: 1.5;
}

.contentForm .frm-control > span {
  display: block;
  margin-bottom: 20px;
}

.contentForm .frm-control > span:last-child {
  margin-bottom: 0;
}

.contentForm .frm__tit {
  width: 230px;
}

.contentForm .frm_cnt {
  width: 728px;
}

.contentForm .frm-control input {
  font-family: "Noto Serif JP", serif;
  padding: 20px;
  width: 100%;
  border: 1px solid #999999;
  outline: none;
  color: #0f0f0f;
  font-size: 20px;
  background-color: #fff;
  letter-spacing: 0.1em;
  line-height: 1.6;
  display: block;
  max-width: 725px;
}

.contentForm .frm-control textarea {
  font-family: "Noto Serif JP", serif;
  padding: 20px;
  width: 100%;
  border: 1px solid #999999;
  outline: none;
  color: #0f0f0f;
  font-size: 20px;
  background-color: #fff;
  letter-spacing: 0.1em;
  line-height: 1.6;
  display: block;
  max-width: 725px;
}

.contentForm .frm__group.constraint {
  flex-direction: column;
}

.contentForm .frm__group.constraint .agreement-tit_txt {
  font-size: 24px;
  color: #000;
  letter-spacing: 0.1em;
  font-family: "Noto Serif JP", serif;
  font-weight: normal;
  text-align: center;
}

.contentForm .frm__group.constraint .agreement-content_desc {
  line-height: 2.25;
  margin-top: 40px;
}

.contentForm .frm__group.constraint .agreement-content_desc > a {
  position: relative;
  padding-right: 20px;
}

.contentForm .frm__group.constraint .agreement-content_desc > a:hover {
  opacity: 0.8;
}

.contentForm .frm__group.constraint .agreement-content_desc > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 8px;
  right: 8px;
  width: 18px;
  height: 18px;
  background-image: url(../images/contact/target.svg);
  background-repeat: no-repeat;
  background-size: cover;
}

.contentForm .frm__group.constraint .agreement-content_desc > a::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: #999999;
  bottom: -1px;
  z-index: 1;
  left: 0;
}

.contentForm .frm__group.constraint .your-consent {
  margin-top: 40px;
}

.contentForm .ckbPrivacy input {
  position: absolute;
  opacity: 0;
  left: 0;
  top: 0;
  cursor: pointer;
}

.contentForm .wpcf7-list-item-label {
  height: 24px;
  width: 24px;
  border: 1px solid #707070;
  display: block;
  position: relative;
  margin-right: 10px;
  background-color: #fff;
  cursor: pointer;
  overflow: hidden;
}

.contentForm #agree_check {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.contentForm .wpcf7-list-item-label:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  background-color: #f8f6f4;
  width: 100%;
  height: 100%;
  z-index: 1;
  transition: width 0.3s ease-in-out;
}

.contentForm .ckbPrivacy input:checked ~ .wpcf7-list-item-label:before {
  width: 0;
  left: auto;
  right: 0;
}

.contentForm .wpcf7-list-item-label::after {
  content: "";
  display: block;
  position: absolute;
  top: 5px;
  left: 5px;
  width: 14px;
  height: 11px;
  background-image: url(../images/contact/ico_check.svg);
  background-repeat: no-repeat;
  background-size: cover;
}

.contentForm .frmBtn {
  padding-bottom: 30px;
}

.contentForm .frmBtn .btn-link {
  width: 450px;
  height: 90px;
  margin: 0 auto !important;
  cursor: pointer;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 22px;
  line-height: 1.923;
  font-weight: 500;
  letter-spacing: 0.1em;
  background-color: #666666;
  color: #fff;
  transition: opacity 0.3s ease-in-out;
  font-family: "Noto Serif JP", serif;
}

.contentForm .frmBtn .btn-link:hover {
  opacity: 0.8;
}

.wpcf7 form .wpcf7-response-output {
  /* display: none !important; */
  font-size: 16px !important;
  margin: 0 auto !important;
  padding: 1em 1em !important;
  max-width: 600px;
  width: 100%;
}

/* SP */
@media (max-width: 768px) {
  .wpcf7 form .wpcf7-response-output {
    max-width: auto;
  }
  .contentForm {
    max-width: 100%;
    margin: 50px auto 0;
  }

  .contentForm .frm__group {
    padding: 20px 0 30px;
    flex-direction: column;
    align-items: flex-start;
  }

  .contentForm .frm__tit {
    width: 100%;
  }

  .contentForm .frm__tit {
    display: flex;
    flex-direction: row;
    margin-bottom: 10px;
  }

  .contentForm .frm__tit > .en {
    font-size: 16px;
    margin-bottom: 0;
  }

  .contentForm .frm__tit > .ja {
    font-size: 12px;
    margin-left: 10px;
  }

  .contentForm .frm_cnt {
    width: 100%;
  }

  .contentForm .frm-control > span {
    margin-bottom: 10px;
  }

  .contentForm .frm-control input {
    padding: 10px;
    font-size: 12px;
    max-width: 100%;
  }

  .contentForm .txt-Med {
    font-size: 12px;
  }

  .contentForm .frm__group.constraint {
    padding: 30px 0 30px;
  }

  .contentForm .frm__group.constraint .agreement-tit {
    text-align: center;
    width: 100%;
  }

  .contentForm .frm__group.constraint .agreement-tit_txt {
    font-size: 18px;
  }

  .contentForm .frm__group.constraint .agreement-content_desc {
    margin-top: 30px;
  }

  .contentForm .frm__group.constraint .agreement-content_desc > a::before {
    top: 3px;
    right: 6px;
    width: 12px;
    height: 12px;
  }

  .contentForm .wpcf7-list-item-label {
    height: 20px;
    width: 20px;
  }

  .contentForm .frm__group.constraint .your-consent {
    margin-top: 25px;
    width: 100%;
  }

  .contentForm .frmBtn .btn-link {
    width: 100%;
    height: 70px;
    font-size: 18px;
  }

  .contentForm .frmBtn {
    padding-bottom: 100px;
  }
}
.contentForm .wpcf7-not-valid-tip {
  font-size: 16px;
  transform: translateY(5px);
}
.ex-mgt45 {
  margin-top: 45px;
  display: inline-block;
}
.lh-cs {
  line-height: 3.4;
}
