@charset "UTF-8";
@font-face {
  font-family: "GT-Ultra";
  src: url("../font/GT-Ultra-Standard-Regular.woff") format("woff");
}
html {
  font-size: 62.5%;
  color: #333;
  scroll-behavior: smooth;
}

body {
  font-family: YakuHanJP_Narrow, "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.08em;
  line-height: 1.8;
  font-feature-settings: "palt";
}

img {
  width: 100%;
}

.pc {
  display: inline-block;
}

.sp {
  display: none;
}

.gt {
  font-family: "GT-Ultra";
  letter-spacing: -0.02em;
}

h2 {
  font-size: min(2.8125vw, 5.4rem);
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
}

header {
  width: 70%;
  margin: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: 1%;
}
header .logo {
  width: min(8.3333333333vw, 16rem);
}
header p {
  font-size: min(1.3541666667vw, 2.6rem);
}
header p span {
  font-weight: 600;
  color: #872327;
  text-decoration: underline;
  text-underline-offset: 0.3em;
}

.mv {
  width: 100%;
  background-color: #872327;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  height: 48.5vw;
}
.mv img {
  margin-top: -5%;
}

.fix_btn {
  display: none;
  position: fixed;
  bottom: 0;
  width: 100%;
  background-color: rgba(225, 225, 225, 0.8);
  padding-block: 1.6%;
  z-index: 999;
}
.fix_btn a {
  background-color: #872327;
  text-align: center;
  color: #fff;
  font-size: 3.2rem;
  font-weight: 600;
  text-align: center;
  display: block;
  width: 69rem;
  padding-block: 0.4em 0.5em;
  margin: auto;
  border-radius: 0.4rem;
  position: relative;
}
.fix_btn a::before {
  position: absolute;
  content: "";
  background-image: url(../img/flag.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 9rem;
  aspect-ratio: 1/1;
  top: -7px;
  left: 4.5%;
}
.fix_btn a::after {
  position: absolute;
  content: "";
  background-image: url(../img/arrow_small.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  width: 1.4%;
  aspect-ratio: 21/37;
  top: 50%;
  transform: translateY(-50%);
  right: 4%;
}

.case {
  padding-block: 7.5% 3%;
}
.case ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 3.2vw 3%;
  margin-top: 3%;
}
.case ul .box {
  background-color: #f6f4f0;
  width: 43%;
  padding: 2.4% 2.6% 2% 2.6%;
  position: relative;
}
.case ul .box .info {
  display: flex;
  flex-direction: column;
  gap: 1vw;
  padding-bottom: 5%;
  border-bottom: 1px solid #333;
}
.case ul .box .info dl {
  display: flex;
  gap: 1.4em;
  line-height: 1;
  align-items: center;
}
.case ul .box .info dl dt {
  font-size: min(0.8333333333vw, 1.6rem);
  color: #fff;
  background-color: #222;
  padding-block: 0.5em;
  width: 10%;
  text-align: center;
  font-weight: 400;
}
.case ul .box .info dl dd {
  font-size: min(1.25vw, 2.4rem);
  font-weight: 500;
}
.case ul .box .price_rise {
  display: flex;
  align-items: center;
  gap: 8%;
  padding-block: 4% 2%;
}
.case ul .box .price_rise .before .title {
  font-size: min(1.25vw, 2.4rem);
  font-weight: 500;
  line-height: 1.1;
}
.case ul .box .price_rise .before .title small {
  font-size: 0.7em;
}
.case ul .box .price_rise .before .price {
  font-size: min(1.4583333333vw, 2.8rem);
  font-weight: 500;
  line-height: 1.4;
}
.case ul .box .price_rise .before .price span {
  font-size: 1.7em;
  vertical-align: -3%;
}
.case ul .box .price_rise .arrow {
  width: 3%;
}
.case ul .box .price_rise .after .title {
  font-size: min(1.25vw, 2.4rem);
  font-weight: 500;
  line-height: 1.1;
}
.case ul .box .price_rise .after .price {
  font-size: min(2.5520833333vw, 4.9rem);
  font-weight: 500;
  line-height: 1.1;
}
.case ul .box .price_rise .after .price span {
  font-size: 1.7em;
  vertical-align: -3%;
}
.case ul .box .up {
  font-size: min(7.3958333333vw, 14.2rem);
  color: #872327;
  line-height: 1;
  position: relative;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 0 16%;
}
.case ul .box .up small {
  font-size: 0.7em;
}
.case ul .box .up .up_img {
  position: absolute;
  width: 36%;
  top: -1%;
  right: -38%;
}
.case ul .box .ill01 {
  position: absolute;
  top: -5%;
  right: 12%;
  width: 20%;
}
.case ul .box .ill02 {
  position: absolute;
  top: -9%;
  right: 12%;
  width: 18%;
}
.case ul .box .ill03 {
  position: absolute;
  top: -3%;
  right: 10%;
  width: 23%;
}
.case ul .box .ill04 {
  position: absolute;
  top: -3%;
  right: 10%;
  width: 21%;
}
.case ul .box .ill05 {
  position: absolute;
  top: -2%;
  right: 10%;
  width: 24%;
}
.case ul .box .ill06 {
  position: absolute;
  top: -1%;
  right: 9%;
  width: 24%;
}
.case ul .box .ill07 {
  position: absolute;
  top: 2%;
  right: 9%;
  width: 24%;
}
.case ul .box .ill08 {
  position: absolute;
  top: -3%;
  right: 11%;
  width: 19%;
}

.assessment {
  width: 100%;
  padding-block: 5%;
  background-image: url(../img/back_a.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.assessment .wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2vw 3%;
  margin: auto;
}
.assessment .wrap .img {
  width: 28%;
}
.assessment .wrap .text {
  font-size: min(1.4583333333vw, 2.8rem);
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.assessment .wrap .text span {
  color: #872327;
  font-weight: 700;
}
.assessment a {
  font-size: min(1.875vw, 3.6rem);
  font-weight: 500;
  background-color: #872327;
  width: 37%;
  margin: 5% auto 0;
  position: relative;
  color: #fff;
  display: block;
  text-align: center;
  padding-block: 0.6em 0.8em;
  letter-spacing: 0.1em;
}
.assessment a::after {
  position: absolute;
  content: "";
  background-image: url(../img/arrow_small.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  width: 1.4%;
  aspect-ratio: 21/37;
  top: 50%;
  transform: translateY(-50%);
  right: 4%;
}

.achievements {
  padding-block: 4%;
  /*===================================
      slick 矢印
  ===================================*/
  /* 共通設定 */
  /* next */
  /* prev */
}
.achievements .slider {
  width: 80%;
  margin: 2% auto 0;
}
.achievements .slider .content {
  height: auto;
  margin-inline: 0.8vw;
}
.achievements .slider .content .text {
  margin-top: 4%;
}
.achievements .slider .content .text .name {
  font-size: min(1.1458333333vw, 2.2rem);
  border-left: 1px #872327 solid;
  padding-left: 0.8em;
  line-height: 1.6;
}
.achievements .slider .content .text .price {
  font-size: min(2.2916666667vw, 4.4rem);
  color: #872327;
}
.achievements .slick-next::before,
.achievements .slick-next::after,
.achievements .slick-prev::before,
.achievements .slick-prev::after {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
.achievements .slick-next::after,
.achievements .slick-prev::after {
  width: 1.4rem;
  height: 1.4rem;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
}
.achievements .slick-next {
  top: 38%;
  right: -2.5%;
}
.achievements .slick-next::after {
  transform: rotate(45deg);
}
.achievements .slick-prev {
  top: 38%;
  left: -2%;
}
.achievements .slick-prev::after {
  transform: rotate(-135deg);
}

.chosen {
  padding-block: 6%;
  background-image: url(../img/back_chosen.png);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.chosen .list {
  display: flex;
  flex-direction: column;
  gap: 2vw;
  margin-top: 2%;
}
.chosen .list .box {
  display: flex;
  width: 80%;
  margin: auto;
  background-color: #fff;
  padding: 3% 5% 4% 3%;
}
.chosen .list .box p {
  font-size: min(9.1145833333vw, 17.5rem);
  color: #f6f4f0;
  line-height: 1;
  width: 18%;
}
.chosen .list .box dl {
  width: 82%;
}
.chosen .list .box dl dt {
  font-size: min(2.6041666667vw, 5rem);
  font-weight: 500;
  color: #872327;
  line-height: 1.5;
}
.chosen .list .box dl dd {
  font-size: min(1.5625vw, 3rem);
  text-align: justify;
  margin-top: 1%;
}
.chosen .list .box dl dd span {
  font-weight: 700;
}
.chosen .list .box dl dd ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 3%;
}
.chosen .list .box dl dd ul li {
  width: 23%;
}
.chosen a {
  font-size: min(1.875vw, 3.6rem);
  font-weight: 500;
  background-color: #872327;
  width: 37%;
  margin: 5% auto 0;
  position: relative;
  color: #fff;
  display: block;
  text-align: center;
  padding-block: 0.6em 0.8em;
  letter-spacing: 0.1em;
}
.chosen a::after {
  position: absolute;
  content: "";
  background-image: url(../img/arrow_small.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  width: 1.4%;
  aspect-ratio: 21/37;
  top: 50%;
  transform: translateY(-50%);
  right: 4%;
}

.flow {
  padding-block: 6%;
}
.flow .list {
  display: flex;
  flex-direction: column;
  gap: 1.5vw;
  margin-top: 3%;
}
.flow .list .box {
  display: flex;
  width: 64%;
  margin: auto;
  border: #ccc solid 1px;
  padding: 2.5% 3%;
  justify-content: space-between;
  position: relative;
}
.flow .list .box .text {
  width: 60%;
}
.flow .list .box .text h3 {
  font-size: min(2.0833333333vw, 4rem);
  font-weight: 500;
  color: #872327;
  margin-left: 5em;
  line-height: 1.5;
}
.flow .list .box .text p {
  font-size: min(1.0416666667vw, 2rem);
  text-align: justify;
  margin-top: 2%;
}
.flow .list .box .text p span {
  font-weight: 700;
  color: #872327;
}
.flow .list .box .img {
  width: 35%;
}
.flow .list .box.n1::before {
  position: absolute;
  content: "01";
  font-family: "GT-Ultra";
  font-size: min(8.8541666667vw, 17rem);
  color: #c4bb9c;
  line-height: 1;
  left: 2%;
  top: -0.25em;
}
.flow .list .box.n2::before {
  position: absolute;
  content: "02";
  font-family: "GT-Ultra";
  font-size: min(8.8541666667vw, 17rem);
  color: #c4bb9c;
  line-height: 1;
  left: 2%;
  top: -0.25em;
}
.flow .list .box.n3::before {
  position: absolute;
  content: "03";
  font-family: "GT-Ultra";
  font-size: min(8.8541666667vw, 17rem);
  color: #c4bb9c;
  line-height: 1;
  left: 2%;
  top: -0.25em;
}
.flow .list .box.n4::before {
  position: absolute;
  content: "04";
  font-family: "GT-Ultra";
  font-size: min(8.8541666667vw, 17rem);
  color: #c4bb9c;
  line-height: 1;
  left: 2%;
  top: -0.25em;
}
.flow .list .box.n5::before {
  position: absolute;
  content: "05";
  font-family: "GT-Ultra";
  font-size: min(8.8541666667vw, 17rem);
  color: #c4bb9c;
  line-height: 1;
  left: 2%;
  top: -0.25em;
}
.flow .list .box.n6::before {
  position: absolute;
  content: "06";
  font-family: "GT-Ultra";
  font-size: min(8.8541666667vw, 17rem);
  color: #c4bb9c;
  line-height: 1;
  left: 2%;
  top: -0.25em;
}
.flow .list .box .table {
  width: 35%;
  background-color: #f6f4f0;
  padding: 3%;
}
.flow .list .box .table h4 {
  font-size: min(1.3541666667vw, 2.6rem);
  font-weight: 500;
}
.flow .list .box .table .list {
  display: flex;
  flex-direction: column;
  gap: 1vw;
  margin-top: 2%;
}
.flow .list .box .table .list h5 {
  font-size: min(0.9375vw, 1.8rem);
  border: #ccc 1px solid;
  background-color: #fff;
  text-align: center;
  padding-block: 0.1em;
}
.flow .list .box .table .list p {
  font-size: min(0.9375vw, 1.8rem);
  margin-top: 0.4em;
  line-height: 1.6;
}
.flow .list .box .table .list p span {
  font-size: 1.4em;
  font-weight: 500;
  line-height: 1.2;
}
.flow .list .arrow {
  width: 3.2%;
  margin: auto;
}

.faq {
  background-color: #c4bb9c;
  padding-block: 5%;
}
.faq .list {
  display: flex;
  flex-direction: column;
  width: 64%;
  margin: 2% auto 0;
  gap: 1.5vw;
}
.faq .list details summary {
  background-color: #fff;
  font-size: min(1.4583333333vw, 2.8rem);
  font-weight: 500;
  letter-spacing: 0.09em;
  line-height: 1.6;
  text-align: justify;
  display: flex;
  gap: 4%;
  align-items: center;
  padding: 1.4% 3% 1.4% 3%;
  border-radius: 4px;
  position: relative;
}
.faq .list details summary .btn {
  position: absolute;
  top: 37%;
  right: 3%;
  width: 18px;
  height: 18px;
  transform-origin: center center;
  transition-duration: 0.2s;
}
.faq .list details summary .btn:before, .faq .list details summary .btn:after {
  content: "";
  background-color: #333;
  border-radius: 10px;
  width: 18px;
  height: 2px;
  position: absolute;
  top: 8px;
  left: 0;
  transform-origin: center center;
}
.faq .list details summary .btn:before {
  width: 2px;
  height: 18px;
  top: 0;
  left: 8px;
}
.faq .list details summary.is-active .btn {
  transform: rotate(-180deg);
}
.faq .list details summary.is-active .btn:before {
  content: none;
}
.faq .list details summary span {
  display: block;
  color: #c4bb9c;
  font-size: 1.2em;
}
.faq .list details .answer {
  font-size: min(1.25vw, 2.4rem);
  padding-block: 2% 4%;
  display: flex;
  gap: 4.5%;
  align-items: center;
  padding: 1.8% 10% 1.8% 3%;
  text-align: justify;
}
.faq .list details .answer span.gt {
  display: block;
  color: #fff;
  font-size: 1.6em;
}
.faq .list details .answer .il {
  display: inline;
}
.faq .list details .answer .il a {
  text-decoration: underline;
  color: #872327;
}

footer {
  background-color: #333;
  padding-block: 1% 10%;
}
footer p {
  font-size: min(0.8333333333vw, 1.6rem);
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  h2 {
    font-size: 6vw;
  }
  header {
    width: 90%;
    padding-block: 3% 2.4%;
  }
  header .logo {
    width: 24vw;
  }
  header p {
    font-size: 3.2vw;
    text-align: right;
    line-height: 1.5;
  }
  .mv {
    margin-top: 1.5%;
    height: 123.5vw;
    background-position: bottom;
    position: relative;
  }
  .mv img {
    position: absolute;
    top: 2.8%;
  }
  .fix_btn {
    padding-block: 4%;
  }
  .fix_btn a {
    font-size: 4.6vw;
    width: 86%;
    border-radius: 1vw;
  }
  .fix_btn a::before {
    width: 11vw;
    top: -6%;
    left: 4.5%;
  }
  .fix_btn a::after {
    width: 2%;
  }
  .case {
    padding-block: 9% 12%;
  }
  .case ul {
    gap: 5vw 3%;
    margin-top: 5%;
  }
  .case ul .box {
    width: 86%;
    padding: 6% 6% 4% 6%;
  }
  .case ul .box .info {
    gap: 1vw;
    padding-bottom: 5%;
  }
  .case ul .box .info dl {
    gap: 0.8em;
  }
  .case ul .box .info dl dt {
    font-size: 2.2vw;
    width: 15%;
  }
  .case ul .box .info dl dd {
    font-size: 2.8vw;
    line-height: 1.4;
  }
  .case ul .box .price_rise {
    gap: 4%;
    padding-block: 4% 2%;
  }
  .case ul .box .price_rise .before .title {
    font-size: 2.8vw;
  }
  .case ul .box .price_rise .before .price {
    font-size: 3.2vw;
  }
  .case ul .box .price_rise .arrow {
    width: 3%;
  }
  .case ul .box .price_rise .after .title {
    font-size: 2.8vw;
  }
  .case ul .box .price_rise .after .price {
    font-size: 5.4vw;
  }
  .case ul .box .up {
    font-size: 14vw;
    margin: 0 auto 0 24%;
  }
  .case ul .box .ill01 {
    top: 5%;
    right: 8%;
    width: 18%;
  }
  .case ul .box .ill02 {
    top: 4%;
    right: 8%;
    width: 16%;
  }
  .case ul .box .ill03 {
    top: 8%;
    right: 7%;
    width: 21%;
  }
  .case ul .box .ill04 {
    top: 3%;
    right: 8%;
    width: 20%;
  }
  .case ul .box .ill05 {
    top: 7%;
    right: 8%;
    width: 20%;
  }
  .case ul .box .ill06 {
    top: 9%;
    right: 8%;
    width: 20%;
  }
  .case ul .box .ill07 {
    top: 11%;
    right: 7%;
    width: 22%;
  }
  .case ul .box .ill08 {
    top: 4%;
    right: 8%;
    width: 18%;
  }
  .assessment {
    padding-block: 12%;
  }
  .assessment .wrap {
    gap: 6vw 3%;
  }
  .assessment .wrap .img {
    width: 86%;
  }
  .assessment .wrap .text {
    font-size: 4.4vw;
    width: 86%;
    text-align: justify;
    gap: 1em;
  }
  .assessment a {
    font-size: 5vw;
    width: 86%;
    margin: 8% auto 0;
  }
  .assessment a::after {
    width: 2%;
  }
  .achievements {
    padding-block: 10%;
    /*===================================
        slick 矢印
    ===================================*/
    /* 共通設定 */
    /* next */
    /* prev */
  }
  .achievements .slider {
    width: 80%;
    margin: 4% auto 0;
  }
  .achievements .slider .content {
    margin-inline: 0.8vw;
  }
  .achievements .slider .content .text {
    margin-top: 4%;
  }
  .achievements .slider .content .text .name {
    font-size: 3.8vw;
  }
  .achievements .slider .content .text .price {
    font-size: 10vw;
  }
  .achievements .slick-next::after,
  .achievements .slick-prev::after {
    width: 1.4rem;
    height: 1.4rem;
  }
  .achievements .slick-next {
    right: -7%;
  }
  .achievements .slick-prev {
    left: -6%;
  }
  .chosen {
    padding-block: 12%;
  }
  .chosen .list {
    gap: 4vw;
    margin-top: 4%;
  }
  .chosen .list .box {
    width: 86%;
    padding: 6% 6% 6% 3%;
  }
  .chosen .list .box p {
    font-size: 10vw;
    width: 18%;
    color: #c4bb9c;
  }
  .chosen .list .box dl {
    width: 82%;
  }
  .chosen .list .box dl dt {
    font-size: 5.6vw;
  }
  .chosen .list .box dl dd {
    font-size: 4.6vw;
    margin-top: 3%;
  }
  .chosen .list .box dl dd ul {
    gap: 2vw 0;
    margin-top: 7%;
  }
  .chosen .list .box dl dd ul li {
    width: 48%;
  }
  .chosen a {
    font-size: 5vw;
    width: 86%;
    margin: 8% auto 0;
  }
  .chosen a::after {
    width: 2%;
  }
  .flow {
    padding-block: 12%;
  }
  .flow .list {
    gap: 4vw;
    margin-top: 8%;
  }
  .flow .list .box {
    width: 86%;
    padding: 15% 7% 7% 7%;
    flex-wrap: wrap;
  }
  .flow .list .box .text {
    width: 100%;
  }
  .flow .list .box .text h3 {
    font-size: 6.4vw;
    margin-left: 0;
  }
  .flow .list .box .text p {
    font-size: 4.6vw;
    margin-block: 3% 5%;
  }
  .flow .list .box .img {
    width: 100%;
    margin-top: 3%;
  }
  .flow .list .box.n1::before {
    font-size: 19vw;
    left: 3%;
    top: -0.3em;
  }
  .flow .list .box.n2::before {
    font-size: 19vw;
    left: 3%;
    top: -0.3em;
  }
  .flow .list .box.n3::before {
    font-size: 19vw;
    left: 3%;
    top: -0.3em;
  }
  .flow .list .box.n4::before {
    font-size: 19vw;
    left: 3%;
    top: -0.3em;
  }
  .flow .list .box.n5::before {
    font-size: 19vw;
    left: 3%;
    top: -0.3em;
  }
  .flow .list .box.n6::before {
    font-size: 19vw;
    left: 3%;
    top: -0.3em;
  }
  .flow .list .box .table {
    width: 100%;
    padding: 6% 8%;
    margin-top: 3%;
  }
  .flow .list .box .table h4 {
    font-size: 5vw;
  }
  .flow .list .box .table .list {
    gap: 2vw;
    margin-top: 2%;
  }
  .flow .list .box .table .list h5 {
    font-size: 4vw;
  }
  .flow .list .box .table .list p {
    font-size: 3.8vw;
  }
  .flow .list .arrow {
    width: 12%;
  }
  .faq {
    padding-block: 12%;
  }
  .faq .list {
    width: 86%;
    margin: 5% auto 0;
    gap: 4vw;
  }
  .faq .list details summary {
    font-size: 4.2vw;
    letter-spacing: 0.08em;
    padding: 3% 14% 4% 3%;
  }
  .faq .list details summary .btn {
    right: 4%;
    width: 12px;
    height: 12px;
    top: 44%;
  }
  .faq .list details summary .btn:before, .faq .list details summary .btn:after {
    width: 12px;
    height: 2px;
    top: 5px;
    left: 0;
  }
  .faq .list details summary .btn:before {
    width: 2px;
    height: 12px;
    top: 0;
    left: 5px;
  }
  .faq .list details .answer {
    font-size: 4.2vw;
    padding-block: 2% 4%;
    gap: 4.5%;
    padding: 3% 5% 3% 3%;
  }
  footer {
    padding-block: 3% 24%;
  }
  footer p {
    font-size: 3vw;
  }
}/*# sourceMappingURL=style.css.map */