@charset "UTF-8";
.mv-wrap {
  position: relative;
  width: 97.9166666667vw;
  height: 37.5vw;
  margin: auto;
  margin-bottom: 80px;
}
.mv-wrap .msk-wrap {
  -webkit-mask-image: url(../images/top/mv-msk.svg);
  mask-image: url(../images/top/mv-msk.svg);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-position: center;
  mask-size: contain;
  -webkit-mask-size: contain;
  padding: 0;
  margin: 0;
}
.mv-wrap .msk-wrap img {
  width: 97.9166666667vw;
  height: 37.5vw;
  -o-object-fit: cover;
     object-fit: cover;
}
/* 250225 slick.jsで作成したスライダー読み込み時のレイアウトずれ対策 */
.mv-wrap .msk-wrap > img:not(:first-child) {
  display: none;
}
/* /250225 */

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .mv-wrap {
    height: auto;
    margin-bottom: 54px;
    width: 100vw;
  }
  .mv-wrap .msk-wrap {
    -webkit-mask: none;
            mask: none;
  }
  .mv-wrap .msk-wrap img {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.mv-wrap .ibj-banner {
  position: absolute;
  left: 30px;
  bottom: 60px;
}
@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .mv-wrap .ibj-banner {
    left: 0;
    bottom: 0;
    width: 60px;
    display: none;
  }
}

/*240313*/
.marriage-agency h1 {
  font-size: 30px;
  font-family: "Noto Serif JP";
  text-align: center;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
.marriage-agency h1{
  font-size: 20px;
  margin-bottom: 20px;
  } 
}
/*/240313*/



.counseling {
  margin-bottom: 100px;
}
.counseling .main {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  margin-bottom: 46px;
}
.counseling > ul {
  width: 807px;
  margin: auto;
  margin-bottom: 66px;
}
.counseling > ul li {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 28px;
  letter-spacing: 0.05em;
  line-height: 1.5;
  text-align: left;
  color: #222;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.counseling > ul li::before {
  content: "";
  display: inline-block;
  width: 34px;
  height: 34px;
  background: url(../images/top/check-icon.svg) no-repeat center/contain;
  margin-right: 8px;
}
.counseling > ul li:last-of-type {
  margin-bottom: 86px;
}
.counseling .zoom-btn {
  margin-bottom: 120px;
}
.counseling .zoom-btn small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-size: 22px;
  text-align: center;
  color: #24abe8;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 8px;
}
.counseling .zoom-btn small::before, .counseling .zoom-btn small::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 18px;
}
.counseling .zoom-btn small::before {
  background: url(../images/top/zoom-counseling-before.svg) no-repeat center/contain;
  margin-right: 10px;
}
.counseling .zoom-btn small::after {
  background: url(../images/top/zoom-counseling-after.svg) no-repeat center/contain;
  margin-left: 10px;
}
.counseling .zoom-btn a {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 26px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 28px 0;
  text-align: center;
  color: #fcfcfc;
  display: block;
  background: #24ABE8;
  width: 520px;
  margin: auto;
  border-radius: 10px;
}
.counseling .zoom-btn a:hover {
  background: #56BFEE;
  box-shadow: 0 5px 0 rgba(126, 197, 229, 0.46);
  opacity: 1;
}
.counseling .area {
  border: 1px solid #C2A33C;
  position: relative;
  padding: 50px 0 40px;
  width: 850px;
  margin: 0 auto 40px;
}
.counseling .area .item {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #FFF;
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 28px;
  letter-spacing: 0.1em;
  line-height: 42px;
  text-align: center;
  color: #222;
  padding: 0 30PX;
}
.counseling .area ul {
  display: flex;
  justify-content: center;
  align-items: center;
}
.counseling .area ul li {
  margin: 0 10px;
}
.counseling .area ul li a {
  display: block;
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 0.2em;
  text-align: center;
  color: #222;
  border: 2px solid #EEEEEE;
  background: #FFF;
  border-radius: 100px;
  padding: 14px 25px 10px;
  text-align: center;
}
.counseling .area ul li a:hover {
  background: #EEEEEE;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .counseling {
    padding: 0 10px;
    margin-bottom: 40px;
  }
  .counseling .main {
    font-size: 24px;
    margin-bottom: 36px;
  }
  .counseling > ul {
    width: 100%;
    margin-bottom: 46px;
    justify-content: center;
  }
  .counseling > ul li {
    font-size: 20px;
    margin-bottom: 20px;
    align-items: flex-start;
  }
  .counseling > ul li::before {
    width: 15px;
    min-width: 15px;
    height: 15px;
    margin-right: 10px !important;
    margin-top: 8px;
  }
  .counseling .zoom-btn {
    margin-bottom: 60px;
  }
  .counseling .zoom-btn small {
    font-size: 22px;
    margin-bottom: 8px;
  }
  .counseling .zoom-btn small::before, .counseling .zoom-btn small::after {
    width: 14px;
    height: 18px;
  }
  .counseling .zoom-btn small::before {
    margin-right: 10px;
  }
  .counseling .zoom-btn small::after {
    margin-left: 10px;
  }
  .counseling .zoom-btn a {
    font-size: 26px;
    padding: 28px 0;
    width: 100%;
    border-radius: 10px;
  }
  .counseling .area {
    padding: 30px 10px 10px;
    width: 100%;
  }
  .counseling .area .item {
    font-size: 22px;
    padding: 0 20PX;
    width: 90%;
  }
  .counseling .area ul {
    flex-wrap: wrap;
    padding: 0;
  }
  .counseling .area ul li {
    font-size: 20px;
    letter-spacing: 0.2em;
    border-radius: 100px;
    margin: 0 5px;
    margin-bottom: 10px;
    padding: 0;
    width: 30%;
  }
  .counseling .area ul li a {
    padding: 14px 0 10px;
  }
}

.is_tablet .counseling > ul {
  width: 670px;
}
.is_tablet .counseling > ul li {
  font-size: 22px;
}

.reason {
  padding: 9.375vw 0 9.375vw;
  margin: auto;
  background: url(../images/top/reason-bg.jpg) no-repeat center/cover;
  position: relative;
  z-index: 1;
}
.reason .tit1 {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 2.0833333333vw;
  letter-spacing: 0.1em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  margin-bottom: 1.3020833333vw;
}
.reason p.tit-sub {
  margin-bottom: 1.5625vw;
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 1.4583333333vw;
}
.reason ul {
  display: flex;
  justify-content: center;
  margin-bottom: 2.25vw;
}
.reason ul li {
  width: 19.7916666667vw;
  padding: 7.2916666667vw 1.0416666667vw 1.3020833333vw;
  margin-right: 1.0416666667vw;
  padding-right: 1.0416666667vw;
  border-right: 1px solid #E8DDBA;
  position: relative;
}
.reason ul li:last-of-type {
  border-right: none;
  margin-right: 0;
}
.reason ul li:nth-of-type(1)::before {
  content: "";
  display: inline-block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0.441667vw;
  width: 6.9270833333vw;
  height: 5.2083333333vw;
  background: url(https://high-test.ec-access.com/themes/hga2023/images/top/reason-img-1.svg) no-repeat center/contain;
}
.reason ul li:nth-of-type(2)::before {
  content: "";
  display: inline-block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 1.0416666667vw;
  width: 7.96875vw;
  height: 5.2083333333vw;
  background: url(https://high-test.ec-access.com/themes/hga2023/images/top/reason-img-2.svg) no-repeat center/contain;
}
.reason ul li:nth-of-type(3)::before {
  content: "";
  display: inline-block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0.9375vw;
  width: 9.4270833333vw;
  height: 5.2083333333vw;
  background: url(https://high-test.ec-access.com/themes/hga2023/images/top/reason-img-3.svg) no-repeat center/contain;
}
.reason ul li .item {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 1.25vw;
  line-height: 1.4;
  text-align: center;
  color: #EC427C;
  margin-bottom: 1.0416666667vw;
  min-height: 69px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.reason ul li p {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 0.8854166667vw;
  line-height: 1.6;
  text-align: left;
  color: #222;
  margin-bottom: 0;
}
.reason .tit2 {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 1.4583333333vw;
  letter-spacing: 0.1em;
  line-height: 1.4;
  text-align: center;
  color: #EC427C;
  margin-bottom: 20px;
}
.reason p {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 0.8854166667vw;
  line-height: 1.6;
  text-align: center;
  color: #222;
  margin-bottom: 1.0416666667vw;
}
.reason .banner-tit {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 1.1458333333vw;
  letter-spacing: 0.05em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  margin-bottom: 10px;
}
.reason .banner-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 1.0416666667vw;
}
.reason .banner-wrap .item {
  display: inline-block;
  margin: 0 0.5208333333vw;
}
.reason .buttons {
  margin-top: 2.0833333333vw;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 40px;
}
.reason .buttons .item {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 1.0416666667vw;
  letter-spacing: 0.05em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  display: inline-block;
  border-radius: 100px;
  background: #FFF;
  padding: 0.8333333333vw 4.1666666667vw 0.78125vw;
  margin: 0 1.0416666667vw;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
}
.reason .buttons .item:hover {
  background-color: #F6F6F6;
  opacity: 1;
}
.reason .movie {
  text-align: center;
  margin-top: 6rem;
}
.reason .movie iframe {
  width: 72rem;
  height: 40.5rem;
}
/* 230707 */
.reason .tv-interview {
  text-align: center;
  margin: 80px 0 40px;
}
.reason .tv-interview .tv-interview-caption {
  margin: 10px 0 0;
  text-align: center;
}
/* /230707 */
/* 231106 */
.reason ul li .reason-img-photo {
  margin-bottom: 1.0416666667vw;
  text-align: center;
}
/* /231106 */
@media screen and (max-width: 1280px) {
  .reason .banner-tit{
    font-size: 19px;
  }
  .reason .tit1 {
    font-size: 24px;
    margin-bottom: 15px;
  }
  .reason ul {
    margin-bottom: 1.5625vw;
  }
  .reason ul li {
    width: 33.333%;
  }
  .reason ul li .item {
    font-size: 1.5625vw;
  }
  .reason ul li p {
    font-size: 1.25vw;
  }
  .reason .tit2 {
    font-size: 24px;
  }
  .reason p {
    font-size: 1.25vw;
  }
  .reason .item .banner-tit {
    font-size: 19px;
  }
}
@media screen and (max-width: 767px) {
  .reason {
    background: #F8F4E7;
    width: 100%;
  }
  .reason .tit1 {
    font-size: 24px;
    margin-bottom: 15px;
  }
  .reason p.tit-sub {
    margin-bottom: 20px;
    font-size: 18px;
    text-align: center;
  }
  .reason ul {
    flex-direction: column;
    justify-content: center;
    margin-bottom: 30px;
  }
  .reason ul li {
    width: 100%;
    padding: 130px 10px 0;
    margin-right: 0;
    margin-bottom: 30px;
  }
  .reason ul li:last-of-type {
    margin-bottom: 0;
  }
  .reason ul li:nth-of-type(1)::before {
    width: 151px;
    height: 118px;
  }
  .reason ul li:nth-of-type(2)::before {
    width: 172px;
    height: 119px;
  }
  .reason ul li:nth-of-type(3)::before {
    width: 199px;
    height: 118px;
  }
  .reason ul li .item {
    font-size: 22px;
    margin-bottom: 20px;
    justify-content: center;
    min-height: 0;
  }
  /* 231106 */
  .reason ul li .reason-img-photo {
    margin-bottom: 20px;
  }
  /* /231106 */
  .reason ul li p {
    font-size: 16px;
    margin-bottom: 0;
  }
  .reason .tit2 {
    font-size: 24px;
  }
  .reason p {
    font-size: 18px;
    text-align: left;
    margin-bottom: 20px;
    padding: 0 10px;
    font-feature-settings: "palt";
  }
  .reason .item .banner-tit {
    font-size: 19px;
  }
  .reason .banner-wrap {
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 0 10px;
  }
  .reason .banner-wrap .item {
    width: 49%;
    margin: 0;
    margin-bottom: 10px;
  }
  .reason .buttons {
    display: block;
    padding: 0 10px;
  }
  .reason .buttons .item {
    width: 100%;
    font-size: 18px;
    margin: 0;
    margin-bottom: 20px;
    padding: 16px 0 15px;
  }
  .reason .movie iframe {
    width: 360px;
    height: 203px;
  }
}
@media screen and (max-width: 896px) and (orientation: landscape) {
  .reason .tit2 {
    font-size: 18px;
  }
  .reason ul li {
    padding-top: 50px;
  }
  .reason ul li::before {
    top: 5px;
  }
  .reason ul li .item {
    min-height: 40px;
  }
  .reason .banner-wrap .item {
    width: 24%;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) {
  .reason ul li {
    padding-top: 140px;
  }
}

.price {
  padding: 80px 0;
  position: relative;
}
.price::before {
  content: "";
  display: block;
  position: absolute;
  top: -3%;
  left: 50%;
  width: 1px;
  height: 660px;
  z-index: -64;
/*  background-color: #EEE;*/
}
.price .main , .embedsocial .main {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  color: #222;
  margin-bottom: 30px;
  position: relative;
  z-index: 2;
}
.price .main small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  color: #222;
  margin-top: 20px;
  display: block;
  letter-spacing: 0;
}
.price .main::before {
  position: absolute;
  top: -76px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Price";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.embedsocial .main::before {
  position: absolute;
  top: -76px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Reviews";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.price .item {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 28px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  text-align: center;
  color: #222;
  margin-bottom: 0;
}
.price .table-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 73px;
}
.price .table-wrap > div {
  margin: 0 21px;
}
.price .table-wrap > div .wo {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 26px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  margin-bottom: 10px;
  color: #ec427c;
}
.price .table-wrap > div table {
  border-collapse: collapse;
}
.price .table-wrap > div table tr th {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 1;
  text-align: center;
  color: #fff;
  padding: 10px 0 7px;
  width: 136px;
  background: #EC427C;
  border-right: 1px solid #FFF;
}
.price .table-wrap > div table tr td {
  font-family: Arial;
  font-weight: normal;
  font-size: 25px;
  line-height: 1;
  text-align: center;
  color: #222;
  vertical-align: middle;
  padding: 6px 0 10px;
  border-right: 1px solid #DDD;
}
.price .table-wrap > div table tr td:last-of-type {
  border-right: none;
}
.price .table-wrap > div table tr td small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 18px;
  line-height: 1;
  text-align: center;
  color: #222;
}
.price .table-wrap > div table tr .discount .before {
  font-family: Arial;
  font-weight: normal;
  font-size: 14px;
  line-height: 1;
  text-align: center;
  color: #999;
  text-decoration: line-through;
}
.price .table-wrap > div table tr .discount .before small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 10px;
  line-height: 1;
  text-align: center;
  color: #999;
  text-decoration: none;
}
.price .table-wrap > div table tr .discount .after {
  font-family: Arial;
  font-weight: bold;
  font-size: 25px;
  line-height: 1;
  text-align: center;
  color: #ec427c;
}
.price .table-wrap > div table tr .discount .after small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 18px;
  line-height: 1;
  text-align: center;
  color: #ec427c;
}
.price .table-wrap > div table tr .compleat-out .before {
  font-family: Arial;
  font-weight: normal;
  font-size: 14px;
  line-height: 1;
  text-align: center;
  color: #999;
}
.price .table-wrap > div table tr .compleat-out .before small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 10px;
  line-height: 1;
  text-align: center;
  color: #999;
  text-decoration: none;
}
.price .table-wrap > div table tr .compleat-out .after {
  font-family: Arial;
  font-weight: normal;
  font-size: 25px;
  line-height: 1;
  text-align: center;
}
.price .table-wrap > div table tr .compleat-out .after small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 18px;
  line-height: 1;
  text-align: center;
}
.price .table-wrap > div.man .ma {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 26px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  margin-bottom: 10px;
  color: #24ABE8;
}
.price .table-wrap > div.man table tr th {
  background: #24ABE8;
}
.price .table-wrap > div.man table tr .discount .after {
  color: #24ABE8;
}
.price .table-wrap > div.man table tr .discount .after small {
  color: #24ABE8;
}
.price .more-btn {
  width: 348px;
  margin: auto;
  text-align: center;
}
.price .more-btn a {
  display: block;
  width: 100%;
  padding: 16px 0 15px;
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  background: #FFF;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
}
.price .more-btn a:hover {
  background-color: #F6F6F6;
  opacity: 1;
}
/* 230706 */
#top .price .course_price-heading {
  margin-bottom: 20px;
}
#top .price .course_price-heading strong {
  display: block;
  font-size: 22px;
  text-align: center;
  line-height: 1.8;
}
#top .price .course_price-heading strong .large-price {
  font-size: 1.5em;
  color: #F00;
  margin: 0 5px;
}
#top .price .course_price-heading strong .under_Line-double {
  border-bottom: 6px double;
  color: #F00;
}

.price .course .komi {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 20px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  color: #222;
}

.price .course {
  text-align: center;
  margin-bottom: 50px;
}
.price .course .komi p {
  display: inline-block;
  text-align: left;
}

.price .course .course-container {
  margin-bottom: 30px;
}
.price .course .course-container:last-of-type {
  margin-bottom: 0;
}

.price .course p {
  font-size: 15px;
  line-height: normal;
}


/* /230706 */
@media screen and (max-width: 1366px) {
  .price {
    padding: 4.39238653vw 0 11.7130307467vw;
  }
  .price .main,.embedsocial .main {
    font-size: 2.9282576867vw;
    margin-bottom: 2.196193265vw;
  }
  .embedsocial .main {
    margin-top: 70px;
  }
  .price .main small {
    font-size: 1.2445095168vw;
    margin-top: 1.4641288433vw;
  }
  .price .item {
     font-size: 22px;
     margin-bottom: 20px;
  }
  .price .table-wrap {
    margin-bottom: 5.3440702782vw;
  }
  .price .table-wrap > div {
    margin: 0 1.5373352855vw;
  }
   .price .table-wrap > div .wo {
    font-size: 1.9033674963vw;
  }
  .price .table-wrap > div .ma {
    font-size: 1.9033674963vw;
  }
  .price .table-wrap > div table tr th {
    font-size: 1.317715959vw;
    padding: 0.7320644217vw 0 0.5124450952vw;
    width: 8.4919472914vw;
  }
  .price .table-wrap > div table tr td {
    font-size: 1.8301610542vw;
    padding: 0.439238653vw 0 0.7320644217vw;
  }
  .price .table-wrap > div table tr td small {
    font-size: 1.317715959vw;
  }
  .price .table-wrap > div table tr .discount .before {
    font-size: 1.0248901903vw;
  }
  .price .table-wrap > div table tr .discount .before small {
    font-size: 0.7320644217vw;
  }
  .price .table-wrap > div table tr .discount .after {
    font-size: 1.8301610542vw;
  }
  .price .table-wrap > div table tr .discount .after small {
    font-size: 1.317715959vw;
  }
  .price .more-btn {
    width: 25.4758418741vw;
  }
  .price .more-btn a {
    padding: 1.1713030747vw 0 1.0980966325vw;
    font-size: 1.4641288433vw;
    border-radius: 7.3206442167vw;
    box-shadow: 0 0.2196193265vw 0.439238653vw rgba(0, 0, 0, 0.25);
  }
  
  .price .course {padding: 0 15px;}
  
  .price .course p {text-align: left;}
  
  .price .course .komi {text-align: left;}
}
@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .price {
    padding: 80px 0 20px;
  }
  .price::before {
    display: none;
  }
  .price .main,.embedsocial .main {
    font-size: 24px;
    text-align: center;
    margin-bottom: 30px;
  }
  .price .main small {
    font-size: 17px;
    margin-top: 13px;
  }
  .price .komi {
    font-size: 22px;
    margin-bottom: 20px;
  }
  .price .table-wrap {
    display: block;
    margin-bottom: 50px;
  }
  .price .table-wrap .woman {
    margin-bottom: 20px;
  }
  .price .table-wrap > div .wo {
    font-size: 26px;
    margin-bottom: 10px;
  }
    .price .table-wrap > div .ma {
    font-size: 26px;
    margin-bottom: 10px;
  }
  .price .table-wrap > div .sp-table-scroll {
    width: 100%;
    overflow-x: scroll;
  }
  .price .table-wrap > div .sp-table-scroll th, .price .table-wrap > div .sp-table-scroll td {
    white-space: nowrap;
    padding: 5px 20px;
  }
  .price .table-wrap > div table {
    width: 100%;
  }
  .price .table-wrap > div table tr th {
    font-size: 18px;
    letter-spacing: 0.05em;
    padding: 10px 0 7px;
    display: none;
  }
  .price .table-wrap > div table tr td {
    font-size: 25px;
    padding: 6px 0 10px;
    border-right: 1px solid #DDD;
    display: block;
    width: 100%;
  }
  .price .table-wrap > div table tr td::before {
    content: attr(data-label);
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.05em;
    line-height: 1;
    color: #fff;
    padding: 10px 0 7px;
    background: #EC427C;
    display: block;
    width: 100%;
    margin-bottom: 10px;
  }
  .price .table-wrap > div.man table tr td::before {
    background: #24ABE8;
  }
  .price .table-wrap > div table tr td:last-of-type {
    border-right: none;
  }
  .price .table-wrap > div table tr td small {
    font-size: 18px;
  }
  .price .table-wrap > div table tr .discount .before {
    font-size: 14px;
  }
  .price .table-wrap > div table tr .discount .before small {
    font-size: 10px;
  }
  .price .table-wrap > div table tr .discount .after {
    font-size: 25px;
  }
  .price .table-wrap > div table tr .discount .after small {
    font-size: 18px;
  }
  .price .more-btn {
    width: 100%;
    padding: 0 10px;
  }
  .price .more-btn a {
    width: 100%;
    padding: 16px 0 15px;
    font-size: 20px;
    letter-spacing: 0.05em;
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
  }
  /* 230706 */
  #top .price .course_price-heading strong {
    font-size: 18px;
  }
  /* /230706 */
}

.flow {
  background: #F0F9FD;
  padding: 160px 0 60px;
  margin: 20px 0 100px;
}
.flow h2 {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
  color: #222;
  margin-bottom: 47px;
  position: relative;
}
.flow h2 span {
  position: relative;
  z-index: 2;
}
.flow h2 small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  color: #222;
  margin-top: 20px;
  display: block;
}
.flow h2::before {
  position: absolute;
  top: -94px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Flow";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #FFFFFF;
  opacity: 1;
}
.flow ol {
  max-width: 1200px;
  margin: auto;
  /*margin-bottom: 70px;*/
  position: relative;
}
.flow ol::before {
  content: "";
  display: inline-block;
  width: 3px;
  height: 100%;
  opacity: 0.15;
  position: absolute;
  top: 0;
  left: 170px;
  background: #24ABE8;
}
.flow ol li {
  display: flex;
  align-items: center;
  margin-bottom: 40px;
}
.flow ol li .img-wrap {
  position: relative;
  width: 355px;
  margin-right: 76px;
}
.flow ol li .img-wrap img {
  display: inline-block;
  width: 100%;
}
.flow ol li .img-wrap p {
  position: absolute;
  top: 0;
  right: -50px;
  font-family: Lora;
  font-weight: normal;
  font-style: italic;
  font-size: 24px;
  line-height: 1;
  text-align: right;
  color: #24abe8;
  text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
.flow ol li .img-wrap p span {
  font-family: Lora;
  font-weight: normal;
  font-style: italic;
  font-size: 65px;
  line-height: 1;
  text-align: right;
  color: #24abe8;
  text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
.flow ol li .txt-wrap {
  width: 769px;
}
.flow ol li .txt-wrap .item {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 24px;
  line-height: 1.4;
  text-align: left;
  color: #222;
  margin-bottom: 10px;
}
.flow ol li .txt-wrap p {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  line-height: 1.6;
  text-align: left;
  color: #222;
}
.flow ol li .txt-wrap p.red {
  color: #EC427C;
  font-weight: 700;
}

/*
.flow .more-btn {
    width: 348px;
    margin: auto;
    text-align: center;
    margin-bottom: 10px;
    margin-top: 50px;
}

.flow .more-btn a {
   display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #222;
    background: #FFF;
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
}
*/

.flow .more-btn_spe {
    width: 348px;
    margin: auto;
    text-align: center;
    margin-bottom: 10px;
    margin-top: 50px;
}

.flow .more-btn_spe a {
    display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #fff;
    background: linear-gradient(135deg, #C2A33C, #e6cc63);
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease-in-out;
    opacity: 1;
}

.flow .more-btn_spe a::before {
    content: '';
    position: absolute;
    top: 0;
    left: -75%;
    width: 50%;
    height: 100%;
    background: linear-gradient(
        120deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.6) 50%,
        rgba(255, 255, 255, 0) 100%
    );
    transform: skewX(-25deg);
}

.flow .more-btn_spe a:hover::before {
    animation: shine 1s forwards;
}

@keyframes shine {
    0% {
        left: -75%;
    }
    100% {
        left: 125%;
    }
}

@media screen and (max-width: 1366px) {
  .flow {
    padding: 11.7130307467vw 0;
  }
  .flow h2 {
    font-size: 2.9282576867vw;
    margin-bottom: 3.4407027818vw;
  }
  .flow h2 small {
    font-size: 1.2445095168vw;
    margin-top: 1.4641288433vw;
  }
  .flow h2::before {
    top: -6.8814055637vw;
    z-index: 1;
    font-size: 7.3206442167vw;
  }
  .flow ol {
    max-width: 87.8477306003vw;
  }
  .flow ol::before {
    left: 12.4450951684vw;
  }
  .flow ol li {
    margin-bottom: 2.9282576867vw;
  }
  .flow ol li .img-wrap {
    width: 25.9150805271vw;
    margin-right: 5.5636896047vw;
  }
  .flow ol li .img-wrap p {
    font-size: 1.756954612vw;
    text-shadow: 0px 0.2196193265vw 0.439238653vw rgba(0, 0, 0, 0.16);
  }
  .flow ol li .img-wrap p span {
    font-size: 4.7584187408vw;
    text-shadow: 0px 0.2196193265vw 0.439238653vw rgba(0, 0, 0, 0.16);
  }
  .flow ol li .txt-wrap {
    width: 56.3689604685vw;
  }
  .flow ol li .txt-wrap .item {
    font-size: 1.756954612vw;
    margin-bottom: 0.7320644217vw;
  }
  .flow ol li .txt-wrap p {
    font-size: 1.2445095168vw;
  }
  .flow .more-btn {
    width: 320px;
    margin: auto;
    text-align: center;
    margin-top: 20px;}
  
}
@media screen and (max-width: 767px) {
  .flow {
    padding: 120px 10px 60px;
    margin: 50px 0;
  }
  .flow h2 {
    font-size: 24px;
    margin-bottom: 47px;
  }
  .flow h2 small {
    font-size: 17px;
    margin-top: 20px;
  }
  .flow h2::before {
    top: -94px;
    font-size: 100px;
  }
  .flow ol {
    max-width: 1200px;
  }
  .flow ol::before {
    content: none;
  }
  .flow ol li {
    margin-bottom: 40px;
    display: block;
  }
  .flow ol li .img-wrap {
    width: 100%;
    margin-right: 0;
    margin-bottom: 10px;
  }
  .flow ol li .img-wrap p {
    font-size: 24px;
    text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    right: 10px !important;
  }
  .flow ol li .img-wrap p span {
    font-size: 65px;
    text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  }
  .flow ol li .txt-wrap {
    width: 100%;
  }
  .flow ol li .txt-wrap .item {
    font-size: 22px;
    margin-bottom: 10px;
    text-align: center;
  }
  .flow ol li .txt-wrap p {
    font-size: 17px;
  }
}
@media screen and (max-width: 896px) and (orientation: landscape) {
  .flow ol li .img-wrap img.pc-block {
    display: block !important;
  }
  .flow ol li .img-wrap img.sp-block {
    display: none !important;
  }
  .flow ol li .img-wrap p {
    right: -30px;
  }
}
@media screen and (max-width: 668px) and (orientation: landscape) {
  .flow ol li .img-wrap img.pc-block {
    display: none !important;
  }
  .flow ol li .img-wrap img.sp-block {
    display: block !important;
    width: auto;
    margin: auto;
  }
  .flow ol li .img-wrap p {
    right: 20%;
  }
}

/*
.supporter {
  padding: 8.3333333333vw 0;
  padding-bottom: 100px;
}
*/

.supporter {
  padding: 8.3333333333vw 0;
  padding-bottom: 100px;
}

.supporter .main {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 2.0833333333vw;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  color: #222;
  margin-bottom: 2.4479166667vw;
  position: relative;
  z-index: 2;
  margin-top: -50px;
}
.supporter .main small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 0.8854166667vw;
  text-align: center;
  color: #222;
  margin-top: 1.0416666667vw;
  display: block;
}
.supporter .main::before {
  position: absolute;
  top: -100px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Adviser";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #C2A33C;
  opacity: 0.07;
}
.supporter .img-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
  padding: 0 1.0416666667vw;
  /*margin-bottom: 8.3333333333vw;*/
}
.supporter .img-wrap img {
  display: inline-block;
  margin: 0 1.0416666667vw;
  width: 17.1875vw;
}
@media screen and (max-width: 767px) {
  .supporter {
    padding: 60px 0 20px;
  }
  .supporter .main {
    font-size: 24px;
    padding-top: 40px;
    line-height: 30px;
  }
  
.supporter .main::before {
    top: -7.479167vw;
    font-size: 70px;
}
  
  .supporter .img-wrap {
    justify-content: space-between;
    width: 100%;
    padding: 0 20px;
    margin-bottom: 50px;
    flex-wrap: wrap;
  }
  .supporter .img-wrap img {
    display: inline-block;
    margin: 0;
    width: 50%;
  }
}
@media screen and (max-width: 896px) and (orientation: landscape) {
  .supporter {
    padding-bottom: 120px;
  }
}

.supporter-link {
  padding: 0 0 100px;
}
.supporter-link ul {
  display: flex;
  justify-content: center;
}
.supporter-link ul li {
  width: 24.4791666667vw;
  height: 20.8333333333vw;
  transition: 0.4s;
  position: relative;
}
.supporter-link ul li.fade-in-delay:nth-of-type(1) {
  background: url("../images/top/supporter2-img1.png") no-repeat center/cover;
}
.supporter-link ul li.fade-in-delay:nth-of-type(2) {
  background: url("../images/top/supporter2-img2.png") no-repeat center/cover;
}
.supporter-link ul li.fade-in-delay:nth-of-type(3) {
  background: url("../images/top/supporter2-img3.png") no-repeat center/cover;
}
.supporter-link ul li.fade-in-delay:nth-of-type(4) {
  background: url("../images/top/supporter2-img4.png") no-repeat center/cover;
}
.supporter-link ul li::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(36, 171, 232, 0.26);
  z-index: 1;
  transition: 0.4s;
}
.supporter-link ul li a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
}
.supporter-link ul li a:hover {
  opacity: 1;
}
.supporter-link ul li .item {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 1.3541666667vw;
  line-height: 1.4;
  text-align: center;
  color: #fff;
  transition: 0.4s;
}
.supporter-link ul li p {
  font-family: "Noto Sans JP";
  font-weight: normal;
  font-size: 0.8854166667vw;
  line-height: 1.6;
  text-align: left;
  color: #222;
  opacity: 0;
  position: absolute;
  width: 17.7083333333vw;
  top: 13.5416666667vw;
  left: 50%;
  transform: translateX(-50%);
  transition: 0.4s;
}
.supporter-link ul li:hover {
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
}
.supporter-link ul li:hover::before {
  background: rgba(36, 171, 232, 0.1);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
}
.supporter-link ul li:hover .item {
  top: 6.3541666667vw;
  color: #222;
  transform: translateX(-50%);
}
.supporter-link ul li:hover p {
  opacity: 1;
  top: 9.375vw;
}

.supporter-link ul li.twolines:hover .item {
  top: 6vw;
  color: #222;
  transform: translateX(-50%);
}
.supporter-link ul li.twolines:hover p {
  opacity: 1;
  top: 10.775vw;
}
@media screen and (max-width: 767px) {
  .supporter-link {
    padding: 0 0 50px;
  }
  .supporter-link ul {
    flex-wrap: wrap;
  }
  .supporter-link ul li {
    width: 100%;
    height: 260px;
  }
  .supporter-link ul li .item {
    font-size: 22px;
    top: 30%;
  }
  .supporter-link ul li p {
    font-size: 17px;
    width: 100%;
    opacity: 1;
    width: 100%;
    padding: 0 10px;
    height: auto;
    top: 45%;
    color: #FFF;
  }
  .supporter-link ul li::before {
    background: rgba(36, 171, 232, 0.5);
  }
  .supporter-link ul li:hover {
    -webkit-backdrop-filter: blur(0);
            backdrop-filter: blur(0);
  }
  .supporter-link ul li:hover::before {
    background: rgba(36, 171, 232, 0.5);
    -webkit-backdrop-filter: blur(0);
            backdrop-filter: blur(0);
  }
  .supporter-link ul li:hover .item {
    top: 30%;
    color: #FFF;
    transform: translate(-50%, -50%);
  }
  .supporter-link ul li:hover p {
    opacity: 1;
    top: 45%;
  }
}
.is_tablet .supporter-link ul li {
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
}
.is_tablet .supporter-link ul li::before {
  background: rgba(36, 171, 232, 0.5);
}
.is_tablet .supporter-link ul li h2 {
  top: 6.3541666667vw;
  color: #FFF;
  transform: translateX(-50%);
  font-size: 20px;
}
.is_tablet .supporter-link ul li p {
  opacity: 1;
  top: 9.375vw;
  color: #FFF;
  font-size: 16px;
}

/*231027Q&A追加*/

.qa-list dl {
    position: relative;
    margin: 0;
    padding: 28px 80px 28px 30px;
    cursor: pointer;
    border-bottom: 1px solid #000;
}
.qa-list dl:first-child {
    border-top: 1px solid #000;
}
.qa-list dl::before {
    position: absolute;
    top: 35px;
    right: 35px;
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    transform: rotate(135deg);
    border-top: 2px solid #000;
    border-right: 2px solid #000;
}
.qa-list .open::before {
    transform: rotate(-45deg);
}
.qa-list dl dt {
    position: relative;
    margin: 0;
    padding: 0 0 0 50px;
    font-weight: bold;
    font-size: 20px;
}
.qa-list dl dt::before {
    font-size: 22px;
    line-height: 1;
    position: absolute;
    top: 3px;
    left: 0;
    display: block;
    content: 'Q.';
    color: #3285bf;
}
.qa-list dl dd::before {
    font-size: 22px;
    line-height: 1;
    position: absolute;
    top: 3px;
    left: 2px;
    display: block;
    content: 'A.';
    font-weight: bold;
    color: #3285bf;
}
.qa-list dl dd {
    position: relative;
    display: none;
    height: auto;
    margin: 20px 0 0;
    padding: 0 0 0 50px;
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}

@media screen and (max-width: 767px) {
.qa-list dl {
    position: relative;
    padding: 15px 40px 15px 10px;
}
.qa-list dl::before {
    top: 20px;
    right: 20px;
    width: 7px;
    height: 7px;
}
.qa-list dl dt {
    padding: 0 0 0 30px;
    font-size: 14px;
}
.qa-list dl dt::before {
    font-size: 14px;
    top: 3px;
    left: 5px;
    content: 'Q.';
}
.qa-list dl dd::before {
    font-size: 14px;
    top: 5px;
    left: 5px;
    content: 'A.';
}
.qa-list dl dd {
    margin: 10px 0 0;
    padding: 0 0 0 30px;
    font-size: 14px;
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}
}
/*231027ここまでQ&A追加*/

.voice {
  margin-bottom: 11.208333333333vw;
  padding-top: 160px;
}
.voice .container {
  max-width: 100%;
  padding: 3.5416666667vw 0 2.9166666667vw;
  border-top: 1px solid #C2A33C;
  border-bottom: 1px solid #C2A33C;
  position: relative;
}
.voice .container::after {
  content: "";
  width: 12.5vw;
  height: 9.375vw;
  background: url(../images/top/wedding-illust.jpg) no-repeat center/contain;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 50%);
}
.voice .container h2 {
  display: inline;
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 2.0833333333vw;
  letter-spacing: 0.1em;
  text-align: center;
  color: #222;
  position: relative;
  z-index: 2;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  background: #FFF;
  padding: 0 1.5625vw;
  line-height: 1.3;
}
.voice .container h2 small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 0.8854166667vw;
  text-align: center;
  color: #222;
  margin-top: 1.0416666667vw;
  display: block;
}
.voice .container h2::before {
  position: absolute;
  top: -5.5208333333vw;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Voice";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 5.2083333333vw;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.voice .container .slide-wrap {
  padding-bottom: 0;
  margin-bottom: 2.6041666667vw;
}
.voice .container .slide-wrap .slick-list::before {
  content: none !important;
}
.voice .container .slide-wrap .item {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 0.8854166667vw;
  line-height: 1.6;
  text-align: left;
  color: #222;
  background: #FFF;
  padding: 1.5625vw;
  border-radius: 1.5625vw;
  position: relative;
  width: 19.2708333333vw;
  min-height: 11.1458333333vw;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  margin: 0 0.78125vw;
  margin-bottom: 1.3020833333vw;
  cursor: default;
}
.voice .container .slide-wrap .item::after {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 100%);
  width: 1.3020833333vw;
  height: 1.3020833333vw;
  background: url(../images/top/voice-parts.png) no-repeat center/contain;
}
.voice .more-btn {
  width: 380px;
  margin: auto;
  margin-top: 5.2916666667vw;
  text-align: center;
}
.voice .more-btn a {
  display: block;
  width: 100%;
  padding: 16px 0 15px;
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  background: #FFF;
  border-radius: 100px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
}
.voice .more-btn a:hover {
  background-color: #F6F6F6;
  opacity: 1;
}
@media screen and (max-width: 1580px) {
  .voice {
    margin-bottom: 10.1265822785vw;
  }
  .voice .container {
    padding: 4.3037974684vw 0 6.0759493671vw;
  }
  .voice .container::after {
    width: 15.1898734177vw;
    height: 11.3924050633vw;
  }
  .voice .container h2 {
    font-size: 2.5316455696vw;
    padding: 0 1.8987341772vw;
  }
  .voice .container h2 small {
    font-size: 1.0759493671vw;
    margin-top: 1.2658227848vw;
    margin-bottom: 0.5vw;
  }
  .voice .container h2::before {
    top: -4.8101265823vw;
    font-size: 6.3291139241vw;
  }
  .voice .container .slide-wrap .item {
    font-size: 1.0759493671vw;
    padding: 1.8987341772vw;
    border-radius: 1.8987341772vw;
    width: 23.417721519vw;
    margin: 0 0.9493670886vw;
    margin-bottom: 1.582278481vw;
  }
  .voice .container .slide-wrap .item::after {
    width: 1.582278481vw;
    height: 1.582278481vw;
  }
  .voice .more-btn {
    width: 29.2825768668vw;
  }
  .voice .more-btn a {
    padding: 1.1713030747vw 0 1.0980966325vw;
    font-size: 1.4641288433vw;
    border-radius: 7.3206442167vw;
    box-shadow: 0 0.2196193265vw 0.439238653vw rgba(0, 0, 0, 0.25);
  }
}
@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .voice {
    /*margin-bottom: 60px;*/
    margin-bottom: 60px;
    padding-top: 100px;
  }
  .voice .container {
    padding: 40px 0 80px;
  }
  .voice .container::after {
    width: 240px;
    height: 180px;
    font-size: 26px;
    white-space: nowrap;
  }
  .voice .container h2 {
    font-size: 24px;
    padding: 0 10px;
    white-space: nowrap;
  }
  .voice .container h2 small {
    font-size: 17px;
    margin-top: 20px;
  }
  .voice .container h2::before {
    top: -76px;
    font-size: 100px;
  }
  .voice .container .slide-wrap .item {
    font-size: 15px;
    padding: 30px 10px;
    border-radius: 30px;
    width: 300px;
    margin: 0 15px;
    margin-bottom: 25px;
  }
  .voice .container .slide-wrap .item::after {
    width: 25px;
    height: 25px;
  }
  .voice .more-btn {
    width: 100%;
    padding: 0 10px;
    margin-top: 100px;
  }
  .voice .more-btn a {
    width: 100%;
    padding: 16px 0 15px;
    font-size: 20px;
    letter-spacing: 0.05em;
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
  }
}

.movies {
  /*margin-bottom: 100px;*/
  text-align: center;
  padding-top: 50px;
}
/*.movies h2 {
  text-align: center;
  max-width: 1000px;
  margin: auto;
}*/
.movies h2 img {
  width: 100%;
}
.movies p {
  font-family: "游ゴシック";
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1;
  background: #EC427C;
  color: #FFF;
  border-radius: 100px;
  padding: 6px 30px 3px;
  margin-bottom: 40px;
  display: inline-block;
}
.movies ul {
  display: flex;
  align-items: center;
  justify-content: center;
  /* 230706 */
  margin-bottom: 70px;
  /* /230706 */
}
.movies ul li {
  width: 370px;
  margin: 0 22.5px;
  position: relative;
  /*height: 0;*/
  /*padding-top: 208px;*/
}
.movies ul li iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/* 230706 */
.movies h2 {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  color: #222;
  margin: 0 auto 60px;
  position: relative;
  z-index: 2;
}
.movies h2 small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  color: #222;
  margin-top: 20px;
  display: block;
  letter-spacing: 0;
}
.movies h2::before {
  position: absolute;
  top: -76px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Movie";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.movies .movie h3 {
  width: 1200px;
  margin: auto;
  margin-bottom: 30px;
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 28px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  text-align: center;
  white-space: nowrap;
  color: #222;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.movies .movie h3::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  margin-right: 32px !important;
  background: #222;
}
.movies .movie h3::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  margin-left: 32px !important;
  background: #222;
}
.movies .movie .movie-wrap {
  position: relative;
  width: 1000px;
  margin: 0 auto 70px;
  /*padding-bottom: 563px;*/
  /*height: 0;*/
  overflow: hidden;
}
.movies .movie .movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.movies .static_movie {
  position: relative;
  width: 720px;
  max-width: 100%;
  margin: auto;
  /*padding-bottom: 405px;*/
  padding-top: 0;
  /*height: 0;*/
  overflow: hidden;
}
.movies .static_movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.movies .static_movie_caption {
  display: block;
  margin-top: 20px;
}
.movies .static_movie .slick-prev,
.movies .static_movie .slick-next {
  outline: 0;
  z-index: 9999;
  text-decoration: none;
  font-size: 20px;
  font-weight: bold;
  color: #FFF;
  background: none;
  transform: translateY(-50%);
}
.movies .static_movie .slick-prev {
  left: 20px;
}
.movies .static_movie .slick-next {
  right: 20px;
}
.movies .static_movie .slick-prev:focus,
.movies .static_movie .slick-next:focus {
  outline: 0;
  border: none;
}
@media screen and (max-width: 1366px) {
  .movies .movie h3 {
    width: 87.8477306003vw;
    margin-bottom: 2.196193265vw;
    font-size: 2.0497803807vw;
  }
  .movies .movie h3::before {
    margin-right: 2.3426061493vw !important;
  }
  .movies .movie h3::after {
    margin-left: 2.3426061493vw !important;
  }
  .movies .movie .movie-wrap {
    width: 73.2064421669vw;
    /*padding-bottom: 41.21522694vw;*/
  }
  /* 230706 */
  .movies h2 {
    font-size: 2.9282576867vw;
    margin-bottom: 2.196193265vw;
  }
  .movies h2 small {
    font-size: 1.2445095168vw;
    margin-top: 1.4641288433vw;
  }
  .movies ul {
    margin-bottom: 30px;
  }
  /* /230706 */
}
/* /230706 */
@media screen and (max-width: 1280px) {
  .movies {
    margin-bottom: 13.4375vw;
  }
  .movies h2 {
    max-width: 78.125vw;
  }
  .movies p {
    font-size: 1.875vw;
    border-radius: 7.8125vw;
    padding: 0.46875vw 2.34375vw 3px;
    margin-bottom: 3.125vw;
  }
  .movies ul li {
    width: 28.90625vw;
    margin: 0 1.7578125vw;
    /*padding-top: 16.25vw;*/
  }
}
/* 230706 */
@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .movies h2 {
    font-size: 24px;
    text-align: center;
    margin-bottom: 30px;
  }
  .movies h2 small {
    font-size: 17px;
    margin-top: 13px;
  }
}
/* /230706 */
@media screen and (max-width: 767px) {
  .movies {
    margin-bottom: 0px;
    margin-top: 80px;
  }
  .movies h2 {
    max-width: 100%;
    padding: 0 10px;
    margin-top: -45px;
  }
  .movies p {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 10px 5px;
  }
  .movies ul {
    flex-direction: column;
    padding: 0 10px;
  }
  .movies ul li {
    margin-bottom: 20px;
    width: 100%;
    /*padding-top: 50vw;*/
  }
  /* 230706 */
  .movies .movie h3 {
    width: 100%;
    margin-bottom: 30px;
    font-size: 18px;
  }
  .movies .movie h3::before {
    margin-right: 5px !important;
  }
  .movies .movie h3::after {
    margin-left: 5px !important;
  }
  .movies .movie .movie-wrap {
    width: 100%;
    /*padding-bottom: 56.2801932367vw;*/
    margin-bottom: 50px;
  }
  .movies .static_movie .slick-prev,
  .movies .static_movie .slick-next {
    font-size: 16px;
    margin-top: -12.5%;
  }
  .movies .static_movie .slick-prev {
    left: 2px;
  }
  .movies .static_movie .slick-next {
    right: 2px;
  }
  .movies .static_movie {
    width: 100%;
    /*padding-bottom: 56.2801932367vw;*/
  }
  /* /230706 */
}

.banners {
  width: 1200px;
  margin: auto;
  margin-bottom: 100px;
}
.banners .full ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.banners .full ul li {
  width: calc(50% - 20px);
  margin-bottom: 40px;
  max-height: 130px;
}
/*20230825
.banners .full ul li:first-of-type {
  width: 100%;
  max-height: 280px;
}
*/

.banners .full ul li:first-of-type a {
  display: block;
  text-align: center;
}
.banners .full ul li::after {
  content: "";
  display: inline-block;
  width: calc(50% - 20px);
  height: 0;
  order: 2;
}
.banners .row {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  margin-top: 40px;
}
.banners .row .mini {
  width: 50%;
  display: flex;
  flex-wrap: wrap;
}
.banners .row .mini li {
  margin-right: 38px;
  margin-bottom: 26px;
}
/*230825修正
.banners .row .mini li:last-of-type, .banners .row .mini li:nth-last-of-type(2) {
  margin-bottom: 0;
}
*/
.banners .row .mini li:last-of-type, .banners .row .mini li:nth-last-of-type(2) {
  margin-bottom: 20px;
}
.banners .row .half {
  width: 50%;
  display: flex;
  align-items: flex-start;
}
.banners .row .half li:first-of-type {
  margin-right: 40px;
  width: 200px;
}
.banners .row .half li:first-of-type img {
  display: inline-block;
  margin-bottom: 10px;
}
.banners .row .half li:first-of-type p {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 15px;
  line-height: 1.4;
  text-align: left;
  color: #222;
}
.banners .row .half li:last-of-type {
  position: relative;
  width: 355px;
  margin: 0;
  /*height: 0;*/
  /*padding-top: 200px;*/
}
.banners .row .half li:last-of-type iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding-bottom: 10px;
}
.banners .row .half li:last-of-type p {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 15px;
  line-height: 1.4;
}
.banners .row .half li:last-of-type p img {
  float: left;
}
@media screen and (max-width: 1280px) {
  .banners {
    width: 93.75vw;
    margin-bottom: 7.8125vw;
  }
  .banners .full ul li {
    margin-bottom: 3.125vw;
  }
  .banners .full ul li::after {
    width: calc(50% - 20px);
  }
  .banners .row .mini li {
    margin-right: 2.96875vw;
    margin-bottom: 2.03125vw;
  }
  .banners .row .half li:first-of-type {
    margin-right: 3.125vw;
    width: 15.625vw;
  }
  .banners .row .half li:first-of-type img {
    margin-bottom: 0.78125vw;
  }
  .banners .row .half li:first-of-type p {
    font-size: 1.171875vw;
  }
  .banners .row .half li:last-of-type {
    width: 27.734375vw;
    /*padding-top: 15.625vw;*/
  }
  .banners .row .half li:last-of-type p {
    font-size: 1.171875vw;
  }
}
@media screen and (max-width: 767px) {
  .banners {
    width: 100%;
    margin-bottom: 120px;
    padding: 20px 10px;
  }
  .banners .full ul {
    flex-direction: column;
    justify-content: center;
  }
  .banners .full ul li {
    width: 100%;
    margin-bottom: 30px;
    max-height: 100%;
  }
  .banners .full ul li::after {
    content: none;
  }
  .banners .mini {
    margin-bottom: 30px;
  }
  .banners .row {
    flex-direction: column;
  }
  .banners .row .mini {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .banners .row .mini li {
    margin: 8px;
    margin-bottom: 20px;
  }
  .banners .row .half {
    width: 100%;
    flex-direction: column;
  }
  .banners .row .half li:first-of-type {
    margin-right: 0;
    margin-bottom: 20px;
    width: 100%;
    text-align: center;
  }
  .banners .row .half li:first-of-type img {
    display: inline-block;
    margin-bottom: 10px;
  }
  .banners .row .half li:first-of-type p {
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 500;
    font-size: 15px;
    line-height: 1.4;
    text-align: left;
    color: #222;
  }
  .banners .row .half li:last-of-type {
    position: relative;
    width: 100%;
    margin: 0;
    /*height: 0;*/
    /*padding-top: 200px;*/
  }
  .banners .row .half li:last-of-type iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .banners .row .half li:last-of-type p {
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 500;
    font-size: 15px;
    line-height: 1.4;
  }
  .banners .row .half li:last-of-type p img {
    float: left;
  }
}
@media screen and (max-width: 896px) and (orientation: landscape) {
  .banners {
    margin-bottom: 80px;
  }
  .banners .full ul li img {
    width: 100%;
  }
  .banners .row .half {
    flex-direction: row;
  }
}

.wedding {
  margin-bottom: 50px;
  margin-top: 200px;
}
.wedding .main {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
  color: #222;
  margin-bottom: 44px;
  position: relative;
  z-index: 2;
}
.wedding .main small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  color: #222;
  margin-top: 20px;
  display: block;
}
.wedding .main::before {
  position: absolute;
  top: -106px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Blog";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.wedding .sub-tit {
  text-align: center;
  margin-bottom: 30px;
}
.wedding .blog-wrap ul {
  padding: 0;
}
.wedding .blog-wrap ul li {
  background: #F0F9FD;
  width: 19.2708333333vw;
  padding: 1.0416666667vw;
  border-radius: 1.0416666667vw;
  margin: 0 0.5208333333vw;
}
.wedding .blog-wrap ul li img {
  display: block;
  width: 100%;
  height: 11.4583333333vw;
  border-radius: 1;
  overflow: hidden;
  margin-bottom: 0.5208333333vw;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}
.wedding .blog-wrap ul li .item {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  text-decoration: underline;
  font-size: 0.8854166667vw;
  line-height: 1.6;
  text-align: left;
  color: #222;
  margin-bottom: 0.78125vw;
}
.wedding .blog-wrap ul li .description {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 0.8854166667vw;
  line-height: 1.6;
  color: #222;
  margin-bottom: 0.78125vw;
}
.wedding .blog-wrap ul li .date {
  font-family: Lora;
  font-weight: normal;
  font-size: 0.78125vw;
  letter-spacing: 0.04em;
  line-height: 1.2666;
  color: #758f9b;
  margin-bottom: 0;
}
.wedding .blog-wrap .more-btn {
  text-align: center;
  margin-top: 60px;
}
.wedding .blog-wrap .more-btn a {
  font-family: Lora;
  font-weight: 400;
  font-size: 1.0416666667vw;
  letter-spacing: 0.1em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  display: inline-block;
  width: 10.4166666667vw;
  position: relative;
  padding-bottom: 0.6770833333vw;
}
.wedding .blog-wrap .more-btn a::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  border: 1px solid #222;
  position: absolute;
  bottom: 0;
  left: 0;
  transition-duration: 0.3s;
}
.wedding .blog-wrap .more-btn a:hover::after {
  background-color: #222;
  width: 2.8125vw;
  left: 35%;
}
@media screen and (max-width: 1581px) {
  .wedding .blog-wrap ul li {
    padding: 1.2650221379vw;
    border-radius: 1.2650221379vw;
    margin: 0 1.2650221379vw;
  }
  .wedding .blog-wrap ul li img {
    height: 13.9152435168vw;
    margin-bottom: 0.6325110689vw;
  }
  .wedding .blog-wrap ul li .item {
    font-size: 1.0752688172vw;
    margin-bottom: 0.9487666034vw;
  }
  .wedding .blog-wrap ul li .description {
    font-size: 1.0752688172vw;
    margin-bottom: 0.9487666034vw;
  }
  .wedding .blog-wrap ul li .date {
    font-size: 0.9487666034vw;
  }
  .wedding .blog-wrap .more-btn a {
    font-size: 1.2650221379vw;
    width: 12.6502213789vw;
    padding-bottom: 0.8222643896vw;
  }
}
@media screen and (max-width: 1366px) {
  .wedding .main {
    font-size: 2.9282576867vw;
    margin-bottom: 2.196193265vw;
  }
  .wedding .main small {
    font-size: 1.2445095168vw;
    margin-top: 1.4641288433vw;
  }
}
@media screen and (max-width: 767px) {
  .wedding {
    margin-bottom: 50px;
    margin-top: 120px;
  }
  .wedding .main {
    font-size: 24px;
  }
  .wedding .main small {
    font-size: 17px;
    margin-top: 20px;
  }
  .wedding .main::before {
    top: -76px;
    font-size: 100px;
  }
  .wedding .blog-wrap ul li {
    padding: 20px;
    border-radius: 20px;
    margin: 0 10px;
  }
  .wedding .blog-wrap ul li img {
    height: 200px;
    margin-bottom: 10px;
  }
  .wedding .blog-wrap ul li .item {
    font-size: 20px;
    margin-bottom: 15px;
  }
  .wedding .blog-wrap ul li .description {
    font-size: 17px;
    margin-bottom: 15px;
  }
  .wedding .blog-wrap ul li .date {
    font-size: 15px;
  }
  .wedding .blog-wrap .more-btn a {
    font-size: 20px;
    width: 50%;
    padding-bottom: 13px;
  }
}

.summarys {
  border-top: 1px solid #EEEEEE;
  border-bottom: 1px solid #EEEEEE;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  margin-bottom: 80px;
}
.summarys .main {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 30px;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
  color: #222;
  margin-bottom: 30px;
  position: relative;
  z-index: 2;
}
.summarys .main small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  color: #222;
  margin-top: 20px;
  display: block;
}
.summarys .main::before {
  position: absolute;
  top: -62px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 80px;
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.summarys .blog-content {
  width: 640px;
  padding: 120px 40px 100px;
}
.summarys .blog-content ul li {
  margin-bottom: 20px;
}
.summarys .blog-content ul li a {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.summarys .blog-content ul li a img {
  width: 100px;
  height: 100px;
  -o-object-fit: cover;
     object-fit: cover;
}
.summarys .blog-content ul li a .txt-wrap {
  width: 445px;
}
.summarys .blog-content ul li a .txt-wrap .item {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  text-decoration: underline;
  font-size: 17px;
  line-height: 1.6;
  color: #222;
  margin-bottom: 10px;
}
.summarys .blog-content ul li a .txt-wrap p {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.4;
  color: #222;
  margin-bottom: 4px;
}
.summarys .blog-content ul li a .txt-wrap .date {
  font-family: Lora;
  font-weight: normal;
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 1.2666;
  color: #758f9b;
}
.summarys .blog-content .more-btn {
  text-align: center;
  margin-top: 60px;
}
.summarys .blog-content .more-btn a {
  font-family: Lora;
  font-weight: 400;
  font-size: 1.0416666667vw;
  letter-spacing: 0.1em;
  line-height: 1.4;
  text-align: center;
  color: #222;
  display: inline-block;
  width: 10.4166666667vw;
  position: relative;
  padding-bottom: 0.6770833333vw;
}
.summarys .blog-content .more-btn a::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  border: 1px solid #222;
  position: absolute;
  bottom: 0;
  left: 0;
  transition-duration: 0.3s;
}
.summarys .blog-content .more-btn a:hover::after {
  background-color: #222;
  width: 2.8125vw;
  left: 35%;
}
.summarys .ceo-blog .main {
    font-family: "Noto Serif JP";
    font-weight: 600;
    font-size: 30px;
    letter-spacing: 0.1em;
    line-height: 1.3;
    text-align: center;
    color: #222;
    margin-bottom: 30px;
    position: relative;
    z-index: 2;
}

.summarys .ceo-blog .main::before {
  content: "Advice";
  position: absolute;
    top: -62px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
    font-family: "Dancing Script";
    font-weight: 400;
    font-size: 80px;
    letter-spacing: 0;
    line-height: 1;
    text-align: center;
    color: #c2a33c;
    opacity: 0.07;
}
.summarys .ceo-blog > p {
  margin-bottom: 43px;
  text-align: center;
}
.summarys .news-blog {
  border-left: 1px solid #EEE;
}
/* .summarys .news-blog h2 {
  margin-bottom: 95px;
} */
.summarys .news-blog .main::before {
  content: "News";
}
@media screen and (max-width: 1280px) {
  .summarys {
    margin-bottom: 7.8125vw;
  }
  .summarys .main {
    font-size: 2.34375vw;
    margin-bottom: 2.34375vw;
  }
  .summarys .main small {
    font-size: 1.328125vw;
    margin-top: 1.5625vw;
  }
  .summarys .main::before {
    top: -4.84375vw;
    font-size: 6.25vw;
  }
  .summarys .blog-content {
    width: 50vw;
    padding: 12.65625vw 3.125vw 7.8125vw;
  }
  .summarys .blog-content ul li {
    margin-bottom: 1.5625vw;
  }
  .summarys .blog-content ul li a img {
    width: 7.8125vw;
    height: 7.8125vw;
  }
  .summarys .blog-content ul li a .txt-wrap {
    width: 34.765625vw;
  }
  .summarys .blog-content ul li a .txt-wrap .item {
    font-size: 1.328125vw;
    margin-bottom: 0.78125vw;
  }
  .summarys .blog-content ul li a .txt-wrap p {
    font-size: 1.25vw;
    margin-bottom: 0.3125vw;
  }
  .summarys .blog-content ul li a .txt-wrap .date {
    font-size: 1.171875vw;
  }
  .summarys .blog-content .more-btn a {
    font-size: 1.5625vw;
    width: 15.625vw;
    padding-bottom: 1.015625vw;
  }
  .summarys .ceo-blog .main {
    margin-bottom: 2.34375vw;
  }
  .summarys .ceo-blog > p {
    margin-bottom: 3.359375vw;
  }
  .summarys .news-blog .main {
    margin-bottom: 7.421875vw;
  }
}
@media screen and (max-width: 767px) {
  .summarys {
    margin-bottom: 60px;
    flex-direction: column;
  }
  .summarys .main {
    font-size: 24px;
    margin-bottom: 30px;
  }
  .summarys .main small {
    font-size: 17px;
    margin-top: 20px;
  }
  .summarys .main::before {
    top: -62px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 80px;
  }
  .summarys .blog-content {
    width: 100%;
    padding: 100px 10px 20px;
  }
  .summarys .blog-content ul li {
    margin-bottom: 20px;
  }
  .summarys .blog-content ul li a img {
    width: 100px;
    height: 100px;
  }
  .summarys .blog-content ul li a .txt-wrap {
    width: calc(100% - 110px);
  }
  .summarys .blog-content ul li a .txt-wrap .item {
    font-size: 17px;
    margin-bottom: 10px;
  }
  .summarys .blog-content ul li a .txt-wrap p {
    font-size: 16px;
    margin-bottom: 4px;
  }
  .summarys .blog-content ul li a .txt-wrap .date {
    font-size: 15px;
  }
  .summarys .blog-content .more-btn {
    margin-top: 30px;
  }
  .summarys .blog-content .more-btn a {
    font-size: 20px;
    width: 50%;
    padding-bottom: 13px;
  }
  .summarys .ceo-blog .main {
    margin-bottom: 20px;
    font-size: 24px;
  }
  .summarys .ceo-blog > p {
    margin-bottom: 20px;
  }
  .summarys .news-blog {
    border-left: none;
  }
  .summarys .news-blog .main {
    margin-bottom: 20px;
    font-size: 24px;
  }
}

.store {
  border-top: 1px solid #EEE;
  padding-top: 120px;
  /*margin-bottom: 60px;*/
}
.store h2 {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  color: #222;
  margin-bottom: 72.3px;
  position: relative;
  z-index: 2;
}
.store h2::before {
  position: absolute;
  top: -76px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Access";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.store .adminTable {
  border: none;
}
.store .store-wrap {
  margin: auto;
  max-width: 1200px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.store .store-wrap::after {
  display: block;
  content: "";
  width: 370px;
}
.store .store-wrap .loop-wrap {
  width: 370px;
  display: block;
  margin-bottom: 60px;
}
.store .store-wrap .loop-wrap .map-img {
  width: 370px;
  height: 320px;
}
.store .store-wrap .loop-wrap .map-img iframe {
  width: 100%;
  height: 100%;
}
.store .store-wrap .loop-wrap .store-info .name {
  font-family: "Noto Serif JP";
  font-size: 22px;
  font-weight: 500;
  line-height: 1.4;
  margin-top: 11px;
}
.store .store-wrap .loop-wrap .store-info .address {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.62;
}
.store .store-wrap .loop-wrap .store-info .tel {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.62;
}
.store .store-wrap .loop-wrap .open-data {
  background-color: #F0F9FD;
  padding: 10px 10px 8px 10px;
  margin-top: 10px;
}
.store .store-wrap .loop-wrap .open-data p {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.62;
}
.store .store-wrap.area-page {
  justify-content: center;
}
.store .store-wrap.area-page::after {
  content: none;
}
.store .store-wrap.area-page .loop-wrap {
  width: 800px;
}
.store .store-wrap.area-page .loop-wrap .map-img {
  width: 100%;
}
@media screen and (max-width: 1300px) {
  .store h2 {
    font-size: 3.0769230769vw;
    margin-bottom: 5.5615384615vw;
  }
  .store h2::before {
    top: -5.8461538462vw;
    font-size: 7.6923076923vw;
  }
  .store .store-wrap {
    width: 92.3076923077vw;
  }
  .store .store-wrap::after {
    width: 28.4615384615vw;
  }
  .store .store-wrap .loop-wrap {
    width: 28.4615384615vw;
    margin-bottom: 4.6153846154vw;
  }
  .store .store-wrap .loop-wrap .map-img {
    width: 28.4615384615vw;
    height: 24.6153846154vw;
  }
  .store .store-wrap .loop-wrap .store-info .name {
    font-size: 1.6923076923vw;
    margin-top: 0.8461538462vw;
  }
  .store .store-wrap .loop-wrap .store-info .address {
    font-size: 1.2307692308vw;
  }
  .store .store-wrap .loop-wrap .store-info .tel {
    font-size: 1.2307692308vw;
  }
  .store .store-wrap .loop-wrap .open-data {
    padding: 0.7692307692vw 0.7692307692vw 0.6153846154vw 0.7692307692vw;
    margin-top: 0.7692307692vw;
  }
  .store .store-wrap .loop-wrap .open-data p {
    font-size: 1.2307692308vw;
  }
  .store .store-wrap.area-page .loop-wrap {
    width: 61.5384615385vw;
  }
}
@media screen and (max-width: 767px) {
  .store {
    padding-top: 90px;
  }
  .store h2 {
    font-size: 24px;
    margin-bottom: 30px;
  }
  .store h2::before {
    top: -76px;
    font-size: 100px;
  }
  .store .store-wrap {
    max-width: 100%;
    display: block;
  }
  .store .store-wrap .loop-wrap {
    width: 100%;
    margin-bottom: 60px;
  }
  .store .store-wrap .loop-wrap .map-img {
    width: 100%;
    height: 220px;
  }
  .store .store-wrap .loop-wrap .store-info .name {
    font-family: "Noto Serif JP";
    font-size: 22px;
    font-weight: 500;
    line-height: 1.4;
    margin-top: 11px;
  }
  .store .store-wrap .loop-wrap .store-info .address {
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.62;
  }
  .store .store-wrap .loop-wrap .store-info .tel {
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.62;
  }
  .store .store-wrap .loop-wrap .open-data {
    background-color: #F0F9FD;
    padding: 10px 10px 8px 10px;
    margin-top: 10px;
  }
  .store .store-wrap .loop-wrap .open-data p {
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.62;
  }
  .store .store-wrap.area-page .loop-wrap {
    width: 100%;
  }
}

/* 230623 */
/* 男女の声 */
.voice-example {
  width: 1200px;
  max-width: 100%;
  margin: 0 auto 6.0208333333vw;
}
.voice-example h3 {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 26px;
  letter-spacing: 0.1em;
  line-height: 56px;
  text-align: center;
}
.voice-example .sp-table-scroll {
  width: 580px;
}
.voice-example .women-voice-table h3 {
  color: #ec427c;
}
.voice-example .men-voice-table h3 {
  color: #24ABE8;
}
.voice-example table {
  border-collapse: collapse;
  border: 1px solid #CCC;
  width: 580px;
  margin: 0 auto;
}
.voice-example table th, .voice-example table td {
  text-align: center;
  vertical-align: middle;
  padding: 12px 12px;
}
.voice-example .women-voice-table table tbody tr:nth-child(4n+3) th, .voice-example .women-voice-table table tbody tr:nth-child(4n+3) td,
.voice-example .women-voice-table table tbody tr:nth-child(4n+4) th, .voice-example .women-voice-table table tbody tr:nth-child(4n+4) td {
  background: #FCF5F7;
}
.voice-example .men-voice-table table tbody tr:nth-child(4n+3) th, .voice-example .men-voice-table table tbody tr:nth-child(4n+3) td,
.voice-example .men-voice-table table tbody tr:nth-child(4n+4) th, .voice-example .men-voice-table table tbody tr:nth-child(4n+4) td {
  background: #F0F9FD;
}
.voice-example table th {
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 25.2px;
  text-align: center;
  color: #fff;
}
.voice-example .women-voice-table table th {
  background: #EC427C;
}
.voice-example .men-voice-table table th {
  background: #24ABE8;
}
.voice-example table td {
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 28.8px;
  text-align: center;
  color: #222;
}
.voice-example table tr.marriage-clincher-tr {
  border-bottom: 1px solid #CCC;
}
.voice-example table tr.marriage-clincher-tr td {
  text-align: left;
  margin: 0 10px;
  border-top: 1px dotted #CCC;
}
.voice-example table td .marriage-clincher {
  font-weight: 700;
}
.voice-example .women-voice-table table td .marriage-clincher {
  color: #EC427C;
}
.voice-example .men-voice-table table td .marriage-clincher {
  color: #24ABE8;
}

@media screen and (max-width: 767px) {
  .voice-example {
    margin: 50px 0;
  }
  .voice-example .voice-table-wrap {
    display: block;
  }
  .voice-example .women-voice-table,
  .voice-example .men-voice-table {
    margin: 0 1.5373352855vw;
  }
  .voice-example .men-voice-table {
    margin-top: 40px;
  }
  .voice-example h3 {
    line-height: 39px;
  }
  .voice-example .sp-table-scroll {
    width: 100%;
    overflow-x: scroll;
  }
}

/* 店舗情報（エリア別） */
.store-region {
  width: 800px;
  max-width: 100%;
  margin: 0 auto 6.0625vw;
}
.store-region .store-region-wrap {
  margin: 0 auto;
}
.store-region .store-region-wrap .store-region-loop {
  margin-bottom: 60px;
}
.store-region .store-region-wrap .store-region-loop:last-of-type {
  margin-bottom: 0;
}
.store-region .store-region-map {
  width: 370px;
  height: 320px;
}
.store-region .store-region-map iframe {
    width: 100%;
    height: 100%;
}
.store-region .store-region-txt {
  max-width: 402px;
}
.store-region .store-region-store-name {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 20px;
  line-height: 30.8px;
  text-align: left;
  color: #222;
  margin-bottom: 10px;
}
.store-region .store-region-address, .store-region .store-region-tel {
  font-weight: 500;
  font-size: 16px;
  line-height: 26px;
  text-align: left;
  color: #222;
}
.store-region .store-region-address {
}
.store-region .store-region-tel {
  margin-bottom: 10px;
}
.store-region .store-region-open-data {
  padding: 10px;
  font-weight: 500;
  font-size: 16px;
  line-height: 20px;
  text-align: left;
  color: #222;
  background: #F0F9FD;
}
.store-region-date {
}
.store-region-venue {
}
.store-region-access {
}

@media screen and (max-width: 767px) {
  .store-region {
    margin-bottom: 14.0625vw;
  }
  .store-region-wrap {
    width: 92.3076923077vw;
  }
  .store-region .store-region-wrap .store-region-loop {
    justify-content: center;
  }
  .store-region .store-region-map {
    max-width: 100%;
    height: 220px;
    margin-bottom: 20px;
  }
  .store-region .store-region-store-name {
    font-size: 20px;
  }
}

/* デートスポット */
.date-spot {
  width: 1200px;
  max-width: 100%;
  margin: 0 auto 50px;
}
.date-spot h2 {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  color: #222;
  margin-bottom: 92px;
  position: relative;
  z-index: 2;
}
.date-spot h2::before {
  position: absolute;
  top: -76px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Date Spot";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.date-spot .date-spot-wrap {
  margin: 0 auto;
}
.date-spot .date-spot-loop {
  width: 100%;
  max-width: 580px;
  margin-bottom: 40px;
}
.date-spot .date-spot-loop .date-spot-photo {
  margin-bottom: 10px;
  max-height: 386px;
  overflow: hidden;
}
.date-spot .date-spot-loop .date-spot-photo img {
  width: 100%;
  min-height: 386px;
}
.date-spot .date-spot-loop .date-spot-name {
  margin-bottom: 10px;
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 20px;
  line-height: 33.6px;
  text-align: left;
  color: #222;
}
.date-spot .date-spot-loop .date-spot-explanation {
  margin-bottom: 10px;
  font-weight: 500;
  font-size: 17px;
  line-height: 27.2px;
  text-align: left;
  color: #222;
}
.date-spot .date-spot-loop .date-spot-link {
  margin-bottom: 10px;
  font-weight: 500;
  text-decoration: underline;
  font-size: 17px;
  line-height: 27.2px;
  text-align: left;
  color: #222;
}
.date-spot .date-spot-loop .date-spot-link a {
  word-break: break-word;
}

@media screen and (max-width: 1300px) {
  .date-spot {
    margin-top: 100px;
  }
  .date-spot h2 {
    font-size: 3.0769230769vw;
    margin-bottom: 5.5615384615vw;
  }
  .date-spot h2::before {
    top: -5.8461538462vw;
    font-size: 7.6923076923vw;
  }
}
@media screen and (max-width: 767px) {
  .date-spot-wrap {
    width: 92.3076923077vw;
  }
  .date-spot h2 {
    font-size: 24px;
  }
  .date-spot h2::before {
    top: -92px;
    font-size: 90px;
    ine-height: 0.9;
  }
  .date-spot .date-spot-loop .date-spot-photo {
    height: calc(100vw / (580 / 386));
  }
  .date-spot .date-spot-loop .date-spot-name {
    font-size: 20px;
  }
}
/* /230623 */

/* 230801 */
/* 無料相談フォーム */
.free-form {
  padding: 150px 0 0;
}
.free-form h2.section-tit {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
  color: #222;
  margin: 0 auto 120px;
  position: relative;
  z-index: 2;
}
.free-form h2.section-tit::before {
  position: absolute;
  top: -120px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Free Consultation";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 0.9;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}

@media screen and (max-width: 1366px) {
  .free-form h2.section-tit::before {
    top: -6.8814055637vw;
    z-index: 1;
    font-size: 7.3206442167vw;
  }
}

@media screen and (max-width: 767px) {
  .free-form h2.section-tit::before {
    top: -60px;
    font-size: 70px;
  }
  .free-form {
  padding: 100px 0 0;
  }
  .free-form h2.section-tit {
    font-size: 24px;
    margin-bottom: 60px;
  }
}
/* /無料相談フォーム */
/* /230801 */

/* 230906 */
/* サービス対象エリア */
.counseling .area ul li a span {
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .counseling .area ul li a span {
      font-size: 11px;
  }
}
/* /サービス対象エリア */
/* /230906 */

/* 231030 */
/* 代表カウンセラー片桐由裕　インタビュー */
.q-a {
  margin-bottom: 50px;
  margin-top: 100px;
}
.q-a .main {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  color: #222;
  margin-bottom: 44px;
  position: relative;
  z-index: 2;
}
.q-a .main::before {
  position: absolute;
  top: -106px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Interview";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.faq .main small , .wedding .main small , .free-form .main small {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  color: #222;
  margin-top: 20px;
  display: block;
}
.faq-group-contents {
  max-width: 1200px;
  margin: 0 auto;
}
.faq-group-contents .faq-content .faq-q {
  cursor: pointer;
}
.faq-group-contents .faq-content .faq-q span.ui-accordion-header {
  display: block;
  cursor: inherit;
  position: inherit;
  margin: 0;
  padding: 0;
  font-size: inherit;
  border: inherit;
  background: inherit;
  color: inherit;
  border: none;
}
.faq-group-contents .faq-content .faq-q span.ui-accordion-header span {
  display: none;
}
.faq-group-contents .faq-content .faq-q span.ui-accordion-header::before, .faq-group-contents .faq-content .faq-q span.ui-accordion-header::after {
  content: "";
  position: absolute;
  width: 15px;
  height: 2px;
  top: 50%;
  right: 15px;
  left: auto;
  background: #C2A33C;
  transition: all .4s ease-in-out;
}
.faq-group-contents .faq-content .faq-q span.ui-accordion-header::before {
  transform: rotate(90deg);
}
.faq-group-contents .faq-content .faq-q.open span.ui-accordion-header::before {
  transform: rotate(180deg);
}
.faq-group-contents .faq-content .faq-a {
  display: none;
  line-height: 2;
}
.faq-group-contents .faq-content .faq-a a {
  text-decoration: underline;
}
.faq-group-contents .faq-content .faq-a a:hover {
  text-decoration: none;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .q-a {
    padding: 0 10px;
    margin-top: 50px;
  }
  .q-a .main {
    font-size: 24px;
    text-align: center;
    margin-bottom: 30px;
  }
  .faq-group-contents .faq-content {
    margin-bottom: 30px;
  }
  .faq-group-contents .faq-content .faq-q {
    font-size: 1.8rem;
  }
  .faq-group-contents .faq-content .faq-q span.ui-accordion-header {
    padding-right: 40px;
  }
}

@media screen and (max-width: 767px) {
  .q-a .main {
    max-width: 100%;
    padding: 0 10px;
    line-height: 30px;
  }
}

/* よくある質問 */
.faq {
  margin-bottom: 100px;
  margin-top: 150px;
}
.faq .main {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
  color: #222;
  margin-bottom: 44px;
  position: relative;
  z-index: 2;
}
.faq .main::before {
  position: absolute;
  top: -106px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "FAQ";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .faq {
    padding: 0 10px;
  }
  .faq .main {
    font-size: 24px;
    text-align: center;
    margin-bottom: 30px;
  }
}

@media screen and (max-width: 767px) {
  .faq .main {
    max-width: 100%;
    padding: 0 10px;
  }
}
/* /よくある質問 */
/* /231030 */

/* 240110 */
/* 成婚カップルインタビュー */
.couple-interview {margin-bottom: 5.208333333333vw;}

.interview-heading .main {font-family: "Noto Serif JP";
    font-weight: 600;
    font-size: 40px;
    letter-spacing: 0.1em;
    line-height: 1;
    text-align: center;
    color: #222;
    margin-bottom: 44px;
    position: relative;
    z-index: 2;
    margin-top: 170px;}

.interview-heading p {text-align: center;
    margin-bottom: 30px;}

.couple-interview .more-btn,.embedsocial .more-btn {
    width: 380px;
    margin: auto;
    margin-top: 40px;
    text-align: center;
}
.embedsocial .more-btn {
    margin-bottom: 80px;
    padding: 0 10px;
}
.couple-interview .more-btn a,.embedsocial .more-btn a {
    display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #222;
    background: #FFF;
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
}

.couple-interview .interview-heading .main::before {
    position: absolute;
    top: -7vw;
    left: 50%;
    transform: rotate(-7deg) translateX(-50%);
    z-index: 1;
    content: "couple interview";
    font-family: "Dancing Script";
    font-weight: 400;
    font-size: 5.2083333333vw;
    letter-spacing: 0.04em;
    line-height: 1;
    text-align: center;
    color: #c2a33c;
    opacity: 0.07;
}

@media screen and (max-width: 767px) {
  .couple-interview .more-btn {
    margin-bottom: 50px;
    width: 100%;
    padding: 0 10px;
  }
  
  .couple-interview .sub-tit {text-align: left; padding: 0 15px;}
  
  .interview-heading .main {font-size: 25px; margin-bottom: 25px; margin-top: 120px;}
  
  .embedsocial .more-btn {
    margin-top: 0;
  }
  
  .couple-interview .interview-heading .main::before {
    top: -27vw;
    font-size: 20vw;
  }
}

/*240416*/
/*無料カウンセリングコンテンツ*/
.free-counseling{
  margin-bottom: 5.208333333333vw;
}

.free-counseling h2 {
  font-family: "Noto Serif JP";
    font-weight: 600;
    font-size: 40px;
    letter-spacing: 0.1em;
    line-height: 1;
    text-align: center;
    color: #222;
    margin-bottom: 30px;
    position: relative;
    z-index: 2;
}

.free-counseling h2::before {
  position: absolute;
  top: -5.5208333333vw;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Free counseling";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 5.2083333333vw;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}

.free-counseling .fc_heading {
  text-align: center;
  margin-top: 75px;
}

.free-counseling .fc_heading p {
  font-size: 19px;
  font-family: "Noto Serif JP";
  text-align: center;
  line-height: 35px;
  margin-top: 45px;
  margin-bottom: 80px;
}

.fc_bluebase {
  background-color:#F0F9FD;
  font-family: "Noto Serif JP";
  font-size: 34px;
  font-weight: bold;
  color: #78552A;
  text-align: center;
  letter-spacing:5px;
  padding: 30px;
}

.free-counseling .fc_bluebase2 {
  background-color:#F0F9FD;
  text-align: center;
  padding-bottom: 1px;
}

.free-counseling .fc_bluebase2 p {
  font-size: 19px;
  font-family: "Noto Serif JP";
  line-height: 35px;
  padding: 60px;
}

/*
.free-counseling .more-btn {
    width: 348px;
    margin: auto;
    text-align: center;
    margin-bottom: 85px;
}

.free-counseling .more-btn a {
   display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #222;
    background: #FFF;
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
}
*/
.free-counseling .more-btn_spe {
    width: 348px;
    margin: auto;
    text-align: center;
    margin-bottom: 85px;
}

.free-counseling .more-btn_spe a {
    display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #fff;
    background: linear-gradient(135deg, #C2A33C, #e6cc63);
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease-in-out;
    opacity: 1;
}

.free-counseling .more-btn_spe a::before {
    content: '';
    position: absolute;
    top: 0;
    left: -75%;
    width: 50%;
    height: 100%;
    background: linear-gradient(
        120deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.6) 50%,
        rgba(255, 255, 255, 0) 100%
    );
    transform: skewX(-25deg);
}

.free-counseling .more-btn_spe a:hover::before {
    animation: shine 1s forwards;
}

@keyframes shine {
    0% {
        left: -75%;
    }
    100% {
        left: 125%;
    }
}

.free-counseling .fc_content {
  background-image: url(../images/top/fc_background-img.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  padding: 100px;
}

.free-counseling .fc_content .fc_content-box {
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  max-width: 1314px;
  margin: 0 auto;
}
.free-counseling .fc_content .fc_content-box img {
  max-width: calc((100% - 90px) / 4);
}

@media screen and (max-width: 767px){
  .free-counseling{
    margin-bottom: 0;
    padding: 60px 0 0;
  }
  .free-counseling h2{
    font-size: 24px;
    line-height: 30px;
  }
  .free-counseling .fc_heading {
    padding: 10px;
  }
   .fc_bluebase {
    font-size: 25px;   
  }
  .free-counseling .fc_bluebase2 {
    margin-bottom: 50px;
    padding-bottom: 65px;
  }
  .free-counseling .fc_bluebase2 p{
    font-size: 17px;
    padding: 20px;
    line-height: 30px;
    padding-top: 50px;
  }
  .free-counseling h2::before {
    position: absolute;
    top: -18.5208333333vw;
    font-size: 17.2083333333vw;
    line-height: 0.8;
  }
  .free-counseling .fc_heading {
    margin-top: 50px; 
  }
  .free-counseling .fc_heading p {
    font-size: 17px;
    margin-bottom: 35px;
    line-height: 30px;
  }
  .free-counseling .fc_content {
    background-image: url(../images/top/fc_background-imgsp.jpg);
    padding: 70px;
  }
  .free-counseling .more-btn {
    width: 320px;
    margin: auto;
    text-align: center;
    margin-top: 20px;
  }
  
  .free-counseling .fc_content .fc_content-box img {
    max-width: 100%;
  }
}

 .municipality {
    width: 1200px;
    margin: auto;
    margin-bottom: 50px;
    /*margin-top: -50px;*/
    line-height: 1.5;
    color: #666;
}

  .municipality .heading {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 5px;
  }

.municipality .sp_only {
    display: none;
}

@media screen and (max-width: 767px){
  .municipality {
    width: 100%;
    margin-bottom: 20px;
    /*font-size: 14px;*/
    line-height: 1.5;
    padding: 0 10px;
  }
  
  .municipality .heading {
  }
  
  .municipality .sp_only {
    display: inline-block;
  }
 
}

/*240703*/
/*エリアカウンセラーインタビューコンテンツ*/
.area-counselor{
  margin-bottom: 5.208333333333vw;
}

.area-counselor .main {
  font-family: "Noto Serif JP";
    font-weight: 600;
    font-size: 40px;
    letter-spacing: 0.1em;
    line-height: 1;
    text-align: center;
    color: #222;
    margin-bottom: 44px;
    position: relative;
    z-index: 2;
}

.area-counselor .main::before {
  position: absolute;
  top: -7.520833vw;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  content: "Area counselor interview";
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 5.2083333333vw;
  letter-spacing: 0.04em;
  line-height: 0.7;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}

.area-counselor .area-c-heading {
  text-align: center;
  margin-top: 170px;
}

.area-counselor .sub-tit p {
  font-size: 19px;
  font-family: "Noto Serif JP";
  text-align: center;
  line-height: 35px;
  margin-top: 45px;
  margin-bottom: 80px;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .area-counselor {
    padding: 0 10px;
    margin-top: 50px;
  } 
  .area-counselor .area-c-heading {
  margin-top: 120px;
}
  .area-counselor .main {
    font-size: 25px;
    text-align: center;
    margin-bottom: 30px;
    line-height: 30px;
  }  
  .area-counselor .main::before {
  top: -21.520833vw;
  font-size: 19.208333vw;
  line-height: 0.7;
}
  .faq-group-contents .faq-content {
    margin-bottom: 30px;
  }
  .faq-group-contents .faq-content .faq-q {
    font-size: 1.8rem;
  }
  .faq-group-contents .faq-content .faq-q span.ui-accordion-header {
    padding-right: 40px;
  }
}

/*240903 worries追加ボタン*/
/*
.worries .more-btn {
    width: 348px;
    margin: auto;
    text-align: center;
    margin-bottom: 55px;
    margin-top: 50px;
}

.worries .more-btn a {
   display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #222;
    background: #FFF;
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
}
*/


.worries .more-btn_spe {
    width: 348px;
    margin: auto;
    text-align: center;
    margin-bottom: 55px;
    margin-top: 50px;
}

.worries .more-btn_spe a {
    display: block;
    width: 100%;
    padding: 16px 0 15px;
    font-family: "Noto Serif JP";
    font-weight: 500;
    font-size: 20px;
    letter-spacing: 0.05em;
    line-height: 1.4;
    text-align: center;
    color: #fff;
    background: linear-gradient(135deg, #C2A33C, #e6cc63);
    border-radius: 100px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease-in-out;
    opacity: 1;
}

.worries .more-btn_spe a::before {
    content: '';
    position: absolute;
    top: 0;
    left: -75%;
    width: 50%;
    height: 100%;
    background: linear-gradient(
        120deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.6) 50%,
        rgba(255, 255, 255, 0) 100%
    );
    transform: skewX(-25deg);
}

.worries .more-btn_spe a:hover::before {
    animation: shine 1s forwards;
}

@keyframes shine {
    0% {
        left: -75%;
    }
    100% {
        left: 125%;
    }
}

@media screen and (max-width: 767px){
  .worries .more-btn {
    width: 320px;
    margin: auto;
    text-align: center;
    margin-top: 50px;
    margin-bottom: 20px;}
}

/*Instagramコンテンツ*/
.instagram {
  padding-top: 10px;
  margin-bottom: 40px;
}
.instagram h2 {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 40px;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
  color: #222;
  margin-bottom: 0;
  position: relative;
  z-index: 2;
}
.instagram h2::before {
  position: absolute;
  top: -76px;
  left: 50%;
  transform: rotate(-7deg) translateX(-50%);
  z-index: 1;
  /*content: "Instagram";*/
  font-family: "Dancing Script";
  font-weight: 400;
  font-size: 100px;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #c2a33c;
  opacity: 0.07;
}
.instagram .instagram-contents {
  max-width: 900px;
  margin: 0 auto;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .instagram {
  padding-top: 10px;
}
  .instagram h2::before {
  font-size: 65px;
}
  .instagram h2 {
    font-size: 24px;
    text-align: center;
    margin-bottom: 0;
  }
  .instagram h2 small {
    font-size: 17px;
    margin-top: 13px;
  }
}

/* 250623 banners-main */
.banners-main {
  width: 1200px;
  margin: 100px auto 40px;
}
.banners-main .full ul {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
}
.banners-main .full ul li {
  width: calc(50% - 20px);
  max-height: 222px;
}

.banners-main .full ul li:first-of-type a {
  display: block;
  text-align: center;
}
.banners-main .full ul li::after {
  content: "";
  display: inline-block;
  width: calc(50% - 20px);
  height: 0;
  order: 2;
}

@media screen and (max-width: 1280px) {
  .banners-main {
    width: 93.75vw;
    margin-bottom: 7.8125vw;
  }
  .banners-main .full ul li {
  }
  .banners-main .full ul li::after {
    width: calc(50% - 20px);
  }
}
@media screen and (max-width: 767px) {
  .banners-main {
    width: 100%;
    margin: 50px auto 0;
    padding: 20px 10px;
  }
  .banners-main .full ul {
    flex-direction: column;
    gap: 20px;
  }
  .banners-main .full ul li {
    width: 100%;
    max-height: 100%;
  }
  .banners-main .full ul li::after {
    content: none;
  }
}
@media screen and (max-width: 896px) and (orientation: landscape) {
  .banners-main {
    margin-bottom: 80px;
  }
  .banners-main .full ul li img {
    width: 100%;
  }
}
/* /250623 banners-main */