body {
  background: #f7f6f5;
  margin-inline: auto;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 3.4666666667vw;
  line-height: 1em;
  color: #333;
}
body * {
  box-sizing: border-box;
  line-height: 1em;
}

a {
  text-decoration: none;
}

p {
  margin: 0;
}

img {
  width: 100%;
  vertical-align: bottom;
}

ul,
li {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

.serif {
  font-family: "Noto Serif JP", serif;
}

.shippori {
  font-family: "Shippori Mincho", serif;
}

.en {
  font-family: "Bodoni Moda", serif;
}

.wrapper {
  background: #f7f6f5;
  margin-inline: auto;
  padding-bottom: 26.6666666667vw;
  box-shadow: 0 0 2.6666666667vw rgba(0, 0, 0, 0.2);
  overflow-x: hidden;
}

.btn {
  display: block;
  padding: 0;
}

#fv {
  background: #d9d3ce url(../img/fv_bg.jpg) no-repeat center 0/100%;
  padding: 8vw 0 6.6666666667vw;
}
#fv .logo {
  width: 24.5333333333vw;
  margin-inline: auto;
}
#fv h1 {
  width: 83.7333333333vw;
  margin: 5.6vw auto 8.6666666667vw;
}
#fv .fv_list01 {
  margin: 0 4vw 15.3333333333vw auto;
  width: 29.3333333333vw;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 2.6666666667vw;
}
#fv .fv_list01 li {
  width: 100%;
}
#fv .fv_list02 {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 4vw;
}
#fv .fv_list02 li {
  background: #fff;
  width: 42.6666666667vw;
  height: 26.6666666667vw;
  padding: 2.6666666667vw 0 0;
  text-align: center;
}
#fv .fv_list02 li:nth-child(1) {
  border-radius: 4vw 0vw 0vw 0vw;
}
#fv .fv_list02 li:nth-child(2) {
  border-radius: 0vw 4vw 0vw 0vw;
}
#fv .fv_list02 li:nth-child(3) {
  border-radius: 0vw 0vw 0vw 4vw;
  padding-top: 3.3333333333vw;
}
#fv .fv_list02 li:nth-child(3) .ico {
  margin-bottom: 3.6vw;
}
#fv .fv_list02 li:nth-child(4) {
  border-radius: 0vw 0vw 4vw 0vw;
  padding-top: 4vw;
}
#fv .fv_list02 li:nth-child(4) .ico {
  margin-bottom: 3.6vw;
}
#fv .fv_list02 .ico {
  width: 10.9333333333vw;
  margin: 0 auto 1.3333333333vw;
}
#fv .fv_list02 p {
  font-size: 4.5333333333vw;
  line-height: 5.3333333333vw;
  letter-spacing: 0.1em;
}
#fv .note {
  width: 89.3333333333vw;
  text-align: right;
  font-size: 2.6666666667vw;
  letter-spacing: 0.12em;
  color: #999999;
  margin: 3.6vw auto 0;
  padding: 0 0.9333333333vw 0 0;
}

#sec01 {
  background: url(../img/sec01_bg.jpg) no-repeat center 0/100% 100%;
  height: 125.3333333333vw;
  padding: 15.8666666667vw 0 0;
  text-align: center;
}
#sec01 .ttl {
  font-size: 7.3333333333vw;
  line-height: 9.6vw;
  letter-spacing: 0.22em;
  font-weight: 700;
}
#sec01 .txt {
  font-size: 4.8vw;
  line-height: 9.0666666667vw;
  font-weight: 400;
  margin: 4.6666666667vw auto 8.5333333333vw;
}
#sec01 .btn p {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 4.6666666667vw;
  letter-spacing: 0.135em;
  color: #9d494b;
  gap: 0 4vw;
  margin: 0 0 4.6666666667vw;
}
#sec01 .btn p::before, #sec01 .btn p::after {
  content: "";
  display: block;
  width: 0.2666666667vw;
  height: 5.3333333333vw;
  background: #9d494b;
}
#sec01 .btn p::before {
  rotate: -25deg;
}
#sec01 .btn p::after {
  rotate: 25deg;
}
#sec01 .btn a {
  display: block;
  width: 86.6666666667vw;
  margin: 0 auto;
  filter: drop-shadow(0.4vw 0.4vw 0.2666666667vw rgba(0, 0, 0, 0.2));
}
@media (any-hover: hover) {
  #sec01 .btn a:hover {
    opacity: 0.8;
  }
}

#sec02 {
  background: url(../img/sec02_bg.jpg) no-repeat center 0/100% 100%;
  height: 505.3333333333vw;
}
#sec02 .ttl {
  height: 57.3333333333vw;
  padding: 12.6666666667vw 0 0;
  text-align: center;
  font-size: 6.5333333333vw;
  line-height: 9.6vw;
  font-weight: 700;
  letter-spacing: 0.12em;
}
#sec02 .ttl span {
  display: block;
  font-weight: 500;
  font-size: 4.2666666667vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.22em;
  margin: 3.7333333333vw auto 0;
}
#sec02 .list01 {
  margin: 0 0 37.0666666667vw;
}
#sec02 .list01 li {
  display: flex;
  align-items: center;
  color: #fff;
  height: 13.3333333333vw;
  padding-left: 10vw;
  margin-bottom: 4vw;
}
#sec02 .list01 li p {
  font-size: 3.8666666667vw;
  line-height: 7.0666666667vw;
  letter-spacing: 0.1em;
}
#sec02 .list01 li:nth-child(2), #sec02 .list01 li:nth-child(4) {
  margin-left: 8vw;
  padding-left: 6.6666666667vw;
}
#sec02 .list01 li:nth-child(5) {
  height: 21.3333333333vw;
  margin-bottom: 0;
}
#sec02 .sub {
  text-align: center;
  color: #3d5143;
  font-size: 6.2666666667vw;
  line-height: 9.6vw;
  font-weight: 700;
  letter-spacing: 0.12em;
  margin: 0 0 7.3333333333vw;
}
#sec02 .list02 {
  margin: 0 0 37.3333333333vw 8vw;
}
#sec02 .list02 li {
  display: flex;
  align-items: center;
  gap: 4vw;
  margin-bottom: 6.6666666667vw;
}
#sec02 .list02 .ico {
  width: 18.6666666667vw;
}
#sec02 .list02 p {
  font-size: 4vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.12em;
}
#sec02 .list02 p strong {
  font-size: 4.5333333333vw;
  color: #3d5143;
}
#sec02 .txt_area h3 {
  color: #fff;
  margin: 0 0 11.0666666667vw 7.3333333333vw;
}
#sec02 .txt_area h3 span {
  width: fit-content;
  width: -moz-fit-content;
  display: block;
  background: #3d5143;
  height: 5.3333333333vw;
  font-size: 5.0666666667vw;
  letter-spacing: 0.16em;
  padding: 0 2.6666666667vw;
  margin: 0 0 4vw;
}
#sec02 .txt_area p {
  font-size: 3.7333333333vw;
  line-height: 8.2666666667vw;
  letter-spacing: 0.06em;
  margin: 0 0 8.2666666667vw 10vw;
}

#sec03 {
  background: #d9d3ce url(../img/sec03_bg.jpg) no-repeat center 0/100%;
  padding: 22vw 0 18.6666666667vw;
}
#sec03 .ttl {
  text-align: center;
  font-size: 6.9333333333vw;
  line-height: 9.6vw;
  font-weight: 700;
  letter-spacing: 0.12em;
  margin: 0 0 9.3333333333vw;
}
#sec03 .block {
  position: relative;
  margin-bottom: 20vw;
}
#sec03 .block .sub {
  color: #fff;
  margin: -86.6666666667vw 0 56vw 8vw;
  position: relative;
  z-index: 2;
}
#sec03 .block .sub span {
  width: fit-content;
  width: -moz-fit-content;
  display: block;
  background: #352e35;
  height: 5.3333333333vw;
  font-size: 4.8vw;
  letter-spacing: 0.16em;
  padding: 0 2.6666666667vw;
  margin: 0 0 4vw;
}
#sec03 .block .sub span:nth-last-of-type(1) {
  margin-bottom: 0;
}
#sec03 .block .txt {
  position: relative;
  z-index: 2;
  width: 93.3333333333vw;
  background: rgba(255, 255, 255, 0.95);
  margin: 0 0 0 auto;
  padding: 5.0666666667vw 0 5.7333333333vw 6.6666666667vw;
  box-shadow: 1.3333333333vw 1.3333333333vw 1.3333333333vw rgba(115, 99, 87, 0.2);
}
#sec03 .block .txt p {
  width: 80vw;
  line-height: 2;
  letter-spacing: 0.12em;
}
#sec03 .block02 .sub {
  margin-top: -62vw;
  margin-bottom: 12.6666666667vw;
}
#sec03 .block02 .txt {
  margin: 0 auto 0 0;
}
#sec03 .block02 .txt p {
  width: 80.5333333333vw;
  letter-spacing: 0.1em;
}
#sec03 .block03 .sub {
  margin-top: -88.6666666667vw;
  margin-bottom: 58vw;
}
#sec03 .block03 .txt p {
  width: 80.5333333333vw;
  letter-spacing: 0.1em;
}
#sec03 .block04 {
  margin-bottom: 0;
}
#sec03 .block04 .sub {
  margin-top: -94.1333333333vw;
  margin-bottom: 54.1333333333vw;
}
#sec03 .block04 .txt p {
  width: 80.5333333333vw;
  letter-spacing: 0.1em;
}

#voice {
  background: #f2f2f2;
  padding-bottom: 4.6666666667vw;
}
#voice .ttl {
  background: url(../img/voice_ttl_bg.jpg) no-repeat center 0/100% 100%;
  height: 53.3333333333vw;
  padding: 13.7333333333vw 0 0;
  margin: 0 0 14.6666666667vw;
  color: #fff;
  font-weight: 600;
}
#voice .ttl img {
  width: 27.7333333333vw;
  margin: 0 0 0 7.0666666667vw;
}
#voice .ttl span {
  display: block;
  font-size: 4.5333333333vw;
  line-height: 8.2666666667vw;
  letter-spacing: 0.14em;
  margin: 6vw 0 0 19.3333333333vw;
}
#voice .block {
  width: 80vw;
  margin: 0 auto 13.3333333333vw;
  padding: 2.2666666667vw 0 12.6666666667vw;
  position: relative;
  border-bottom: 1px solid #3d5143;
}
#voice .block:nth-last-of-type(1) {
  border: none;
  margin-bottom: 0;
}
#voice .block .photo {
  width: 29.3333333333vw;
  position: absolute;
  top: 0;
  right: 0;
}
#voice .block .sub {
  font-size: 4.5333333333vw;
  line-height: 7.4666666667vw;
  letter-spacing: 0.12em;
  color: #3d5143;
  font-weight: 700;
  margin: 0 0 8.4vw;
}
#voice .block .prof {
  background: #fff;
  border-radius: 2.6666666667vw;
  box-shadow: 0.6666666667vw 0.6666666667vw 1.3333333333vw rgba(115, 99, 87, 0.1);
  padding: 3.4666666667vw 0 4vw 6.1333333333vw;
  margin: 0 0 4.6666666667vw;
}
#voice .block .prof p {
  font-size: 2.9333333333vw;
  line-height: 5.8666666667vw;
  letter-spacing: 0.12em;
  font-weight: 500;
}
#voice .block .txt p {
  font-size: 3.3333333333vw;
  line-height: 2;
  letter-spacing: 0;
}
#voice .block02 .sub {
  margin-bottom: 10vw;
}
#voice .block03 .sub {
  margin-bottom: 10vw;
}

.cta {
  background: #f2f2f2;
}

.program {
  background: linear-gradient(135deg, #8b978e 0%, #88948b 0.96%, #6d7c71 11.45%, #58695d 22.85%, #495b4e 35.47%, #405346 50.29%, #3d5143 72.64%);
  padding: 19.0666666667vw 0 21.3333333333vw;
  position: relative;
}
.program::after {
  content: "";
  display: block;
  width: 36vw;
  height: 9.3333333333vw;
  background-color: #d9d3ce;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin-inline: auto;
  left: 0;
  right: 0;
  bottom: -6vw;
  position: absolute;
}
.program .ttl {
  width: 43.8666666667vw;
  margin: 0 0 4vw 10.6666666667vw;
}
.program .sub {
  color: #fff;
  font-size: 4.9333333333vw;
  line-height: 8vw;
  letter-spacing: 0.12em;
  font-weight: 600;
  margin: 0 0 8.6666666667vw 11.3333333333vw;
}
.program .sub span {
  font-size: 4vw;
}
.program .inner {
  background: #fff;
  width: 88vw;
  margin: 0 auto 6.6666666667vw;
  padding: 5.3333333333vw 0 0;
}
.program .headline {
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.22em;
  font-size: 5.6vw;
  line-height: 8vw;
  color: #3d5143;
  margin: 0 auto 6.6666666667vw;
}
.program .headline span {
  font-size: 3.7333333333vw;
  font-weight: 400;
  letter-spacing: 0.12em;
}
.program .schedule {
  background: url(../img/program_base.png) no-repeat center 0/100%;
  height: 80vw;
}
.program .schedule li {
  display: flex;
  align-items: center;
  height: 13.3333333333vw;
  font-size: 3.3333333333vw;
  letter-spacing: 0.12em;
}
.program .schedule .time {
  width: 29.7333333333vw;
  padding: 0 0 0 14vw;
}
.program .schedule .act {
  padding: 0 0 0 5.6vw;
}
.program .program_contents {
  background: #fff;
  width: 88vw;
  margin-inline: auto;
  padding: 6.4vw 0 6vw;
}
.program .program_contents h4 {
  text-align: center;
  font-size: 5.6vw;
  letter-spacing: 0.22em;
  color: #3d5143;
  margin: 0 0 6.6666666667vw;
}
.program .program_contents ul {
  margin: 0 0 0 6.1333333333vw;
}
.program .program_contents li {
  background: url(../img/chk.png) no-repeat 0 0/6.6666666667vw;
  padding: 0.8vw 0 0 9.3333333333vw;
  margin: 0 0 4.2666666667vw;
  height: 6.6666666667vw;
  font-size: 4vw;
  letter-spacing: 0.12em;
}
.program .program_contents li:last-child {
  margin-bottom: 0;
}

.satisfaction {
  padding: 13.3333333333vw 0 0;
}
.satisfaction .graph {
  width: 72vw;
  margin: 0 auto 10.6666666667vw;
}
.satisfaction .graph p {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 5.7333333333vw;
  letter-spacing: 0.135em;
  color: #9d494b;
  gap: 0 4vw;
  margin: 0 0 4.6666666667vw;
}
.satisfaction .graph p::before, .satisfaction .graph p::after {
  content: "";
  display: block;
  width: 0.2666666667vw;
  height: 5.3333333333vw;
  background: #9d494b;
}
.satisfaction .graph p::before {
  rotate: -25deg;
}
.satisfaction .graph p::after {
  rotate: 25deg;
}
.satisfaction .graph span {
  color: #666;
  display: block;
  font-size: 2.6666666667vw;
  text-align: center;
  letter-spacing: 0.12em;
  margin: 4vw auto 0;
}

.users_voice {
  padding: 0 0 13.3333333333vw;
}
.users_voice h3 {
  font-size: 4vw;
  text-align: center;
  font-weight: 400;
  margin: 0 0 8vw;
}
.users_voice h3 span {
  display: block;
  font-size: 4.8vw;
  font-weight: 700;
  margin: 2.6666666667vw 0 0;
}
.users_voice h3 strong {
  color: #3D5143;
  font-size: 6.6666666667vw;
  font-weight: 700;
}
.users_voice .slick-slide {
  margin: 0 2.4vw;
}
.users_voice .btn {
  width: 86.6666666667vw;
  margin: 9.3333333333vw auto 0;
  filter: drop-shadow(0.4vw 0.4vw 0.2666666667vw rgba(0, 0, 0, 0.2));
}
@media (any-hover: hover) {
  .users_voice .btn:hover {
    opacity: 0.8;
  }
}

.support {
  background: url(../img/support_bg.jpg) no-repeat center 0/100%;
  height: 133.3333333333vw;
  padding: 14.6666666667vw 0 0;
}
.support .sub {
  text-align: center;
  color: #fff;
  font-size: 6.1333333333vw;
  line-height: 9.3333333333vw;
  letter-spacing: 0.12em;
  font-weight: 600;
}
.support .img {
  width: 73.3333333333vw;
  margin: 10.6666666667vw auto 4.8vw;
}
.support .txt {
  text-align: center;
  font-weight: 700;
  font-size: 4.4vw;
  line-height: 6.8vw;
  letter-spacing: 0.1em;
}

.user_cmnt {
  padding: 9.3333333333vw 0 18.6666666667vw;
}
.user_cmnt .sub {
  text-align: center;
  font-size: 5.0666666667vw;
  line-height: 9.6vw;
  letter-spacing: 0.12em;
  font-weight: 700;
}
.user_cmnt .cmnt_list {
  width: 92vw;
  margin: 6.6666666667vw auto 0;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  gap: 6.6666666667vw 0;
}
.user_cmnt .cmnt_list li {
  width: 44vw;
  filter: drop-shadow(0.6666666667vw 0.6666666667vw 1.3333333333vw rgba(115, 99, 82, 0.1));
}

.present {
  background: #f8e8e7;
  padding: 16.6666666667vw 0 14.6666666667vw;
}
.present .sub {
  width: fit-content;
  width: -moz-fit-content;
  text-align: center;
  color: #fff;
  position: relative;
  margin: 0 auto 26.6666666667vw;
}
.present .sub::before, .present .sub::after {
  content: "";
  display: block;
  width: 0.2666666667vw;
  height: 19.7333333333vw;
  background: #9d494b;
  position: absolute;
  top: -1.3333333333vw;
}
.present .sub::before {
  rotate: -25deg;
  left: -6.6666666667vw;
}
.present .sub::after {
  rotate: 25deg;
  right: -6.6666666667vw;
}
.present .sub span {
  width: fit-content;
  width: -moz-fit-content;
  display: block;
  background: #9d494b;
  margin: 0 auto 1.3333333333vw;
  padding: 0.4vw 1.3333333333vw 0.9333333333vw;
  font-size: 6vw;
  font-weight: 600;
}
.present .sub span:nth-last-of-type(1) {
  margin-bottom: 0;
}
.present .sub strong {
  font-size: 7.6vw;
  font-weight: 600;
}
.present .inner {
  background: #fff;
  width: 88vw;
  margin: 0 auto;
  padding: 0 0 9.0666666667vw;
}
.present .inner img {
  position: relative;
  top: -20vw;
  width: 73.3333333333vw;
  display: block;
  margin: 0 auto -20vw;
}
.present .inner .catch {
  font-size: 4.5333333333vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.12em;
  margin: 7.7333333333vw auto -1.3333333333vw;
}
.present .inner ul {
  margin: 7.3333333333vw 0 0 7.0666666667vw;
}
.present .inner ul li {
  font-size: 3.2vw;
  line-height: 6.9333333333vw;
  letter-spacing: 0.06em;
}
.present .diploma {
  margin: 33.3333333333vw auto 14.6666666667vw;
}
.present .diploma p {
  width: 74.6666666667vw;
  margin: 7.3333333333vw auto 0;
  font-size: 3.3333333333vw;
  line-height: 6.9333333333vw;
  letter-spacing: 0.06em;
}
.present .catch {
  text-align: center;
  font-size: 5.0666666667vw;
  line-height: 9.6vw;
  letter-spacing: 0.12em;
  font-weight: 700;
}
.present .seminar_photo {
  margin: 4.5333333333vw auto 0;
}
.present .poster {
  width: 85.6vw;
  margin: -8.6666666667vw auto 4.6666666667vw;
  position: relative;
}
.present .poster p {
  width: 100%;
  position: absolute;
  top: 14.6666666667vw;
  text-align: center;
  font-weight: 700;
  font-size: 4.8vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.16em;
}
.present .price {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 2.1333333333vw;
}
.present .price .txt {
  border-top: 0.2666666667vw solid #ed5479;
  border-bottom: 0.2666666667vw solid #ed5479;
  width: 22.6666666667vw;
  font-size: 3.6vw;
  line-height: 4.4vw;
  letter-spacing: 0.1em;
  color: #ed5479;
  text-align: center;
  padding: 2vw 0;
}
.present .price .num {
  font-size: 14.6666666667vw;
  color: #ed5479;
  font-weight: 600;
  margin-top: -2vw;
}
.present .price .num span {
  font-size: 60%;
}
.present .price .num i {
  font-style: normal;
  font-family: initial;
  font-weight: 400;
  font-size: 3.3333333333vw;
}
.present .btn {
  width: 86.6666666667vw;
  margin: 6.6666666667vw auto 0;
  filter: drop-shadow(0.4vw 0.4vw 0.2666666667vw rgba(0, 0, 0, 0.2));
}
@media (any-hover: hover) {
  .present .btn:hover {
    opacity: 0.8;
  }
}

#impression {
  padding: 0 0 17.3333333333vw;
}
#impression .headline {
  background: #dce4e7;
  padding: 19.0666666667vw 0;
  position: relative;
}
#impression .headline::after {
  content: "";
  display: block;
  width: 36.8vw;
  height: 9.6vw;
  background-color: #ccc;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin-inline: auto;
  left: 0;
  right: 0;
  bottom: -6vw;
  position: absolute;
}
#impression .headline .ttl {
  text-align: center;
  font-size: 5.8666666667vw;
  letter-spacing: 0.12em;
  font-weight: 700;
  margin-bottom: 11.3333333333vw;
}
#impression .headline .eyebrow {
  background: #333333;
  height: 21.3333333333vw;
  display: flex;
  align-items: center;
  gap: 3.3333333333vw;
  padding: 0 0 0 12.6666666667vw;
}
#impression .headline .eyebrow p {
  color: #fff;
  font-size: 3.6vw;
  line-height: 6.8vw;
  letter-spacing: 0.1em;
  width: 40vw;
}
#impression .headline .eyebrow img {
  width: 37.3333333333vw;
}
#impression .headline .txt {
  text-align: center;
  font-size: 3.6vw;
  line-height: 8vw;
  letter-spacing: 0.12em;
  margin: 10.6666666667vw 0 0;
}
#impression .revo {
  padding: 21.3333333333vw 0 0;
}
#impression .revo .catch {
  text-align: center;
  color: #3d5143;
  font-size: 6.6666666667vw;
  font-weight: 700;
  letter-spacing: 0.12em;
}
#impression .revo .catch span {
  font-size: 4.8vw;
  display: block;
  margin-bottom: 2.9333333333vw;
}
#impression .revo .catch strong {
  font-weight: 700;
  border-bottom: 0.2666666667vw solid #3d5143;
}
#impression .revo .img {
  width: 84vw;
  margin: 15.0666666667vw auto 12.4vw;
}
#impression .revo .txt {
  text-align: center;
}
#impression .revo .txt p {
  font-size: 3.6vw;
  line-height: 8vw;
  letter-spacing: 0.12em;
  margin-bottom: 8vw;
}
#impression .revo .txt p:nth-last-of-type(1) {
  margin-bottom: 0;
}
#impression .revo .txt p strong {
  color: #3d5143;
}

#reason {
  background: #d9d3ce url(../img/reason_bg.jpg) no-repeat center 0/100%;
  padding: 20vw 0 14vw;
  position: relative;
  z-index: 5;
}
#reason .ttl {
  text-align: center;
  color: #3d5143;
  font-size: 4.5333333333vw;
  font-weight: 700;
  letter-spacing: 0.12em;
  margin-bottom: 11.7333333333vw;
}
#reason .ttl span {
  display: block;
  width: fit-content;
  width: -moz-fit-content;
  margin: 6vw auto 2vw;
  padding-bottom: 1.4666666667vw;
  border-bottom: 1px solid #3d5143;
  font-size: 6.6666666667vw;
}
#reason .ttl strong {
  display: block;
  width: fit-content;
  width: -moz-fit-content;
  margin: 0 auto 4vw;
  padding-bottom: 1.8666666667vw;
  border-bottom: 1px solid #3d5143;
  font-size: 10.8vw;
  font-weight: 700;
}
#reason .block {
  position: relative;
  padding: 2.9333333333vw 0 0;
  margin-bottom: 13.3333333333vw;
}
#reason .block::before {
  content: "";
  display: block;
  width: 74.6666666667vw;
  height: 46.6666666667vw;
  background: #3d5143;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
#reason .block .num {
  margin: 0 0 13.4666666667vw 8.2666666667vw;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#reason .block .num img {
  width: 30.2666666667vw;
}
#reason .block .num::after {
  content: "";
  display: block;
  background: #fff;
  height: 1px;
  width: 57.3333333333vw;
}
#reason .block .inner {
  background: #fff;
  width: 94.6666666667vw;
  border-radius: 0vw 0vw 0vw 6.6666666667vw;
  margin: 0 0 0 auto;
  padding: 0 0 10.6666666667vw;
}
#reason .block .bfaf {
  width: 84vw;
  position: relative;
  top: -10vw;
  margin: 0 0 1.3333333333vw 5.3333333333vw;
}
#reason .block .comment {
  display: flex;
  gap: 0 6.6666666667vw;
}
#reason .block .comment .user {
  padding-top: 1.3333333333vw;
  margin: 0 0 0 8vw;
}
#reason .block .comment .user .sub {
  font-size: 4.2666666667vw;
  color: #3d5143;
  letter-spacing: 0.12em;
  text-align: center;
  margin-bottom: 5.3333333333vw;
}
#reason .block .comment .user .photo {
  width: 29.3333333333vw;
}
#reason .block .comment .txt {
  width: 42.6666666667vw;
}
#reason .block .comment .txt p {
  font-size: 3.2vw;
  line-height: 6.4vw;
  letter-spacing: 0.06em;
}
#reason .block02::before {
  top: 0;
  left: auto;
  right: 0;
}
#reason .block02 .num {
  margin: 0 8.2666666667vw 13.4666666667vw 0;
}
#reason .block02 .num::after {
  content: none;
}
#reason .block02 .num::before {
  content: "";
  display: block;
  background: #fff;
  height: 1px;
  width: 57.3333333333vw;
}
#reason .block02 .comment .user {
  margin: 0 8vw 0 0;
}
#reason .block02 .comment .txt {
  margin-left: 8vw;
}
#reason .block03 {
  margin-bottom: 0;
}
#reason .block03 .comment .txt p {
  letter-spacing: 0.02em;
}

#feature .ttl {
  background: url(../img/feature_bg.jpg) no-repeat center 0/100%;
  height: 53.3333333333vw;
  text-align: center;
  color: #fff;
  font-size: 4.5333333333vw;
  font-weight: 600;
  letter-spacing: 0.12em;
  padding: 12vw 0 0;
}
#feature .ttl span {
  display: block;
  width: fit-content;
  width: -moz-fit-content;
  margin: 4vw auto 0.6666666667vw;
  padding-bottom: 1.4666666667vw;
  border-bottom: 1px solid #3d5143;
  font-size: 7.3333333333vw;
  letter-spacing: 0.12em;
}
#feature .ttl strong {
  display: block;
  width: fit-content;
  width: -moz-fit-content;
  margin: 0 auto 4vw;
  padding-bottom: 1.8666666667vw;
  border-bottom: 1px solid #3d5143;
  font-size: 12vw;
  font-weight: 700;
  letter-spacing: 0.08em;
}
#feature .block {
  padding: 13.3333333333vw 0 12vw;
}
#feature .block .inner {
  width: 88.1333333333vw;
  margin: 0 0 0 5.3333333333vw;
}
#feature .block .img {
  width: 88.1333333333vw;
  margin-bottom: -6.6666666667vw;
}
#feature .block .txt_wrap {
  background: rgba(255, 255, 255, 0.9);
  width: 78.6666666667vw;
  position: relative;
  z-index: 2;
  margin: 0 0 0 5.3333333333vw;
  padding: 10vw 0 7.3333333333vw;
}
#feature .block .txt_wrap .sub {
  text-align: center;
  font-weight: 400;
  letter-spacing: 0.1em;
  font-size: 3.4666666667vw;
  margin-bottom: 6vw;
}
#feature .block .txt_wrap .sub span {
  display: block;
  font-weight: 700;
  font-size: 5.3333333333vw;
  line-height: 8vw;
  letter-spacing: 0.14em;
  margin: 1.3333333333vw auto 0;
}
#feature .block .txt_wrap .txt {
  width: 66.6666666667vw;
  margin-inline: auto;
  line-height: 2;
  letter-spacing: 0.1em;
}
#feature .block01 {
  background: url(../img/feature_bg01.jpg) no-repeat center bottom/100%;
  padding-top: 0;
}
#feature .block01 .img {
  position: relative;
  top: -2.9333333333vw;
}
#feature .block02 {
  background: url(../img/feature_bg02.jpg) no-repeat center bottom/100%;
}
#feature .block03 {
  background: url(../img/feature_bg03.jpg) no-repeat center bottom/100%;
}
#feature .block04 {
  background: url(../img/feature_bg04.jpg) no-repeat center bottom/100%;
  padding-bottom: 22.6666666667vw;
}
#feature .block04 .txt_wrap .sub {
  margin-bottom: 4vw;
}
#feature .block04 .txt_wrap .sub span {
  padding-top: 2vw;
}

.cta_2 .program {
  padding-top: 14.9333333333vw;
}
.cta_2 .program .ttl {
  margin: 0 auto 6.1333333333vw;
}
.cta_2 .program .sub {
  width: fit-content;
  width: -moz-fit-content;
  color: #3d5143;
  text-align: center;
  margin: 0 auto 9.7333333333vw;
}
.cta_2 .program .sub span {
  width: fit-content;
  width: -moz-fit-content;
  background: #fff;
  display: block;
  height: 6.6666666667vw;
  border-radius: 2.6666666667vw 0vw 0vw 0vw;
  font-size: 5.2vw;
  padding: 0.6666666667vw 0 0 5.0666666667vw;
  margin: 0 auto 2.2666666667vw;
  text-align: center;
}
.cta_2 .program .sub strong {
  background: #fff;
  display: block;
  width: 82.6666666667vw;
  height: 8vw;
  border-radius: 0vw 0vw 2.6666666667vw 0vw;
  font-size: 6vw;
  font-weight: 600;
  padding: 0.6666666667vw 0 0;
  letter-spacing: 0.14em;
}

#faq {
  background: #f4f2f0;
  padding: 12.5333333333vw 0 10.6666666667vw;
}
#faq .ttl {
  width: 21.0666666667vw;
  margin: 0 auto 6.6666666667vw;
}
#faq dl {
  width: 90.6666666667vw;
  margin: 0 auto 4vw;
}
#faq dt {
  background: #333 url(../img/q.png) no-repeat 4.2666666667vw 4.1333333333vw/5.6vw;
  padding: 2.6666666667vw 0 2.6666666667vw 14vw;
  margin: 0;
  position: relative;
  cursor: pointer;
}
#faq dt::after {
  content: "";
  display: block;
  width: 2.9333333333vw;
  height: 2.9333333333vw;
  border-right: 0.2666666667vw solid #fff;
  border-bottom: 0.2666666667vw solid #fff;
  position: absolute;
  top: 7.3333333333vw;
  right: 5.3333333333vw;
  rotate: 45deg;
  transition: all 0.3s;
}
#faq dt.active::after {
  top: 8vw;
  rotate: -135deg;
}
@media (any-hover: hover) {
  #faq dt:hover {
    opacity: 0.8;
  }
}
#faq dt p {
  color: #fff;
  font-size: 4.2666666667vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.14em;
  font-weight: 600;
}
#faq dd {
  background: url(../img/a.png) no-repeat 4vw 7.7333333333vw/5.4666666667vw;
  padding: 7.3333333333vw 0 8.6666666667vw 14vw;
  margin: 0;
  display: none;
}
#faq dd p {
  width: 70.6666666667vw;
  line-height: 2;
  letter-spacing: 0.1em;
}

footer {
  background: #3d5143;
  padding: 14.6666666667vw 0 0;
}
footer .logo {
  width: 26.6666666667vw;
  margin-inline: auto;
}
footer .link {
  width: fit-content;
  width: -moz-fit-content;
  display: block;
  color: #fff;
  margin: 8vw auto;
  text-decoration: underline;
}
@media (any-hover: hover) {
  footer .link:hover {
    text-decoration: none;
    opacity: 0.7;
  }
}
footer small {
  display: block;
  text-align: center;
  border-top: 1px solid #fff;
  font-size: 2.6666666667vw;
  color: #fff;
  font-weight: 400;
  padding: 6.4vw 0;
}

.float {
  background: rgba(255, 255, 255, 0.8);
  height: 26.6666666667vw;
  padding: 5.3333333333vw 0 0;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  margin-inline: auto;
  z-index: 999;
}
.float a {
  display: block;
  width: 86.6666666667vw;
  margin-inline: auto;
  filter: drop-shadow(0.4vw 0.4vw 0.2666666667vw rgba(0, 0, 0, 0.2));
}
@media (any-hover: hover) {
  .float a:hover {
    opacity: 0.8;
  }
}

/*# sourceMappingURL=style_sp.css.map */
