.c-ttl {
  text-align: center;
  margin-left: -5px;
}
.c-ttl h2 {
  font-size: 20px;
}
.c-ttl p {
  font-family: 'Barlow Semi Condensed';
  font-size: 12px;
  font-weight: bold;
  margin-top: -2px;
}
@media screen and (min-width: 768px) {
  .c-ttl {
    margin-left: -3px;
  }
  .c-ttl h2 {
    font-size: 32px;
    line-height: 1;
  }
  .c-ttl p {
    font-size: 18px;
    margin-top: 3px;
  }
}

.c-sec {
  position: relative;
}
.c-sec:before {
  content: '';
  position: absolute;
  bottom: 0%;
  left: 0;
  width: 100%;
  height: 17vw;
  background: url('../img/sec01_curve_sp.png') no-repeat center top;
  background-size: auto 100%;
}
@media screen and (min-width: 768px) {
  .c-sec:before {
    background: url('../img/s1_curve.png') no-repeat center top;
    background-size: auto 100%;
    height: 75px;
    bottom: -15px;
  }
}
@media screen and (min-width: 1441px) {
  .c-sec:before {
    background-size: 100% 100% !important;
  }
}

/*--------------------------------------
    mv
--------------------------------------*/
#mv {
  padding: 17.8vw 3px 0 0;
  text-align: center;
}
#mv h2 {
  font-size: 21px;
}
#mv .logo {
  width: 61%;
  margin: 3vw auto 4.4vw;
}
#mv h3 {
  font-size: 24px;
  line-height: 1.4;
}
#mv .txt {
  text-align: center;
  font-size: 12px;
  margin: 17px auto 24px;
  line-height: 2;
  width: 100%;
  max-width: 290px;
  color: #5d5d5d;
}
#mv .mv-key {
  flex-direction: row-reverse;
  margin-top: 15vw;
}
#mv .mv-key p {
  position: relative;
}
#mv .mv-key p span {
  display: block;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 71%;
}
#mv .mv-key p:nth-child(1) {
  width: 44%;
  margin-left: auto;
  margin-right: -3%;
}
#mv .mv-key p:nth-child(1) span {
  margin: -7.4vw 0 0 -1vw;
}
#mv .mv-key p:nth-child(2) {
  width: 42.6%;
  margin: 23vw 0 0 10.7%;
}
#mv .deco {
  position: relative;
  margin: -13.5vw -2% -7vw -7%;
}
@media screen and (min-width: 768px) {
  #mv {
    padding: 127px 0 105px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
  }
  #mv .mv-content {
    min-width: 420px;
    width: 420px;
    margin-left: calc(50% - 532px);
    position: relative;
    z-index: 2;
  }
  #mv .mv-content h2 {
    font-size: 38px;
    margin-left: -2px;
  }
  #mv .mv-content .logo {
    width: auto;
    margin: 7px 10px 21px 0px;
  }
  #mv .mv-content h3 {
    font-size: 32px;
    text-align: left;
    line-height: 47px;
  }
  #mv .mv-content .txt {
    font-size: 15px;
    max-width: unset;
    margin: 12px 0 30px;
    text-align: left;
  }
  #mv .mv-key {
    width: 47.1%;
    margin-top: -8px;
    align-items: start;
  }
  #mv .mv-key p span {
    width: 160px;
    margin: -3px 0 0 -2px;
  }
  #mv .mv-key p:nth-child(1) {
    width: 48.7%;
    margin-left: auto;
    margin-right: -3.9%;
  }
  #mv .mv-key p:nth-child(1) span {
    margin: -17px 0 0 -4px;
  }
  #mv .mv-key p:nth-child(2) {
    margin: 11.8vw auto 0 0;
    width: 47.2%;
  }
  #mv .deco {
    position: absolute;
    margin: 0;
    bottom: -54px;
    width: 841px;
    max-width: 100%;
    right: 0px;
  }
}
@media (max-width: 1300px) and (min-width: 768px) {
  #mv {
    padding-bottom: 265px;
  }
}
@media (max-width: 1100px) and (min-width: 768px) {
  #mv .mv-content {
    margin-left: 15px;
  }
  #mv .mv-key {
    width: calc(100% - 460px);
  }
}
@media (max-width: 900px) and (min-width: 768px) {
  #mv {
    align-items: center;
  }
  #mv .mv-content {
    width: 48%;
    min-width: 320px;
  }
  #mv .mv-content h2 {
    font-size: 33px;
  }
  #mv .mv-key {
    width: 48%;
  }
}

/*--------------------------------------
    sec1
--------------------------------------*/
#sec01 {
  padding: 23vw 0 28vw;
  background: #ffeed7;
}
#sec01 .row {
  margin-top: 20px;
  flex-direction: row;
  flex-wrap: wrap;
  margin-bottom: 34px;
  gap: 8px;
}
#sec01 .row li {
  width: calc((100% / 3) - 7px);
  background: #fff;
  border-radius: 24px;
  padding: 14px 0 11px;
  text-align: center;
  font-size: 12px;
  box-shadow: 4px 4px 24px #ffe1c7;
}
#sec01 .row li img {
  width: 94%;
  margin: 0 auto;
  display: block;
}
#sec01 h3 {
  font-size: 18px;
  text-align: center;
  position: relative;
  display: table;
  margin: 0 auto;
  padding-left: 5px;
}
#sec01 h3:before,
#sec01 h3:after {
  content: '';
  position: absolute;
  top: 9px;
  left: -28px;
  background: url('../img/sec01_ttl_deco.png') no-repeat center top;
  background-size: 100% 100%;
  width: 26px;
  height: 46px;
}
#sec01 h3:after {
  left: auto;
  right: -24px;
  transform: scaleX(-1);
}
#sec01 h3 .orange {
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-thickness: 2px;
}
@media screen and (min-width: 768px) {
  #sec01 {
    padding: 87px 0 188px;
  }
  #sec01 .wrap {
    max-width: 1200px;
  }
  #sec01 .row {
    margin: 28px 2px 57px 0px;
    gap: 32px;
    justify-content: center;
  }
  #sec01 .row li {
    border-radius: 40px;
    padding: 31px 0 34px;
    font-size: 16px;
    width: 173px;
  }
  #sec01 .row li img {
    max-width: 126px;
    margin-bottom: 4px;
  }
  #sec01 .row li:nth-child(n + 7) {
    padding: 23px 0 26px;
  }
  #sec01 h3 {
    font-size: 28px;
  }
  #sec01 h3:before,
  #sec01 h3:after {
    height: 42px;
    top: 9px;
  }
  #sec01 h3:before {
    left: -45px;
  }
  #sec01 h3:after {
    right: -34px;
  }
  #sec01 h3 .orange {
    text-underline-offset: 11px;
  }
}

/*--------------------------------------
    sec2
--------------------------------------*/
#sec02 {
  padding-bottom: 21vw;
}
#sec02 .deco {
  width: 70.8%;
  margin: -20.6vw auto 10vw;
  box-sizing: border-box;
  padding-right: 3px;
  height: 132px;
}
#sec02 .deco img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
#sec02 .row {
  margin-top: 15px;
  gap: 21px;
}
#sec02 .row .item {
  margin-right: 2px;
}
#sec02 .row .item h3 {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  margin: 17px 0 14px -3px;
}
#sec02 .row .item .txt {
  color: #535353;
}
@media screen and (min-width: 768px) {
  #sec02 {
    padding-bottom: 120px;
  }
  #sec02 .wrap {
    max-width: 1200px;
  }
  #sec02 .deco {
    width: 529px;
    margin: -138px auto 17px;
    height: auto;
    padding-left: 5px;
    box-sizing: content-box;
  }
  #sec02 .c-ttl {
    position: relative;
    z-index: 2;
  }
  #sec02 .c-ttl:before {
    content: '';
    position: absolute;
    top: -74px;
    left: 50%;
    transform: translateX(-50%);
    width: 802px;
    max-width: 100%;
    height: 134px;
    border-radius: 50%;
    z-index: -1;
    background: #fff;
  }
  #sec02 .row {
    flex-wrap: wrap;
    gap: 27px;
    margin-top: 43px;
  }
  #sec02 .row .item {
    width: calc((100% / 3) - 20px);
    box-sizing: border-box;
    padding-bottom: 48px;
  }
  #sec02 .row .item h3 {
    font-size: 20px;
    margin: 25px 0 15px -1px;
    line-height: 30px;
  }
  #sec02 .row .item:nth-child(n + 4) {
    padding-bottom: 25px;
  }
  #sec02 .row .item:nth-child(n + 4) h3 {
    margin-top: 28px;
  }
}
@media (max-width: 1000px) and (min-width: 768px) {
  #sec02 .row {
    gap: 36px;
  }
  #sec02 .row .item {
    width: calc(50% - 20px);
  }
}

/*--------------------------------------
    sec3
--------------------------------------*/
#sec03 {
  background: #faf5ef;
  padding: 18.5vw 0 21vw;
}
#sec03 .row {
  margin: 21px 5px 66px 0;
  gap: 26px;
}
#sec03 .row .item {
  padding-top: 24px;
}
#sec03 .row .item .txt {
  margin-top: 15px;
  color: #535353;
}
#sec03 .s3-js {
  line-height: 1;
}
#sec03 .s3-js .slick-arrow {
  top: 45%;
}
#sec03 .s3-js .slick-slide {
  width: 46.4vw !important;
  margin: 0 8px;
}
@media screen and (min-width: 768px) {
  #sec03 {
    padding: 116px 0 216px;
  }
  #sec03 .row {
    margin: 36px auto 50px;
    max-width: 100%;
    width: 790px;
    gap: 31px;
  }
  #sec03 .row .item {
    padding-top: 32px;
    padding-bottom: 40px;
  }
  #sec03 .row .item .logo {
    width: 100%;
    max-width: 315px;
    margin: 0 auto;
  }
  #sec03 .row .item .txt {
    margin-top: 8px;
  }
  #sec03 .s3-js .slick-slide {
    width: 174px !important;
  }
  #sec03 .s3-js .slick-arrow {
    top: 48%;
  }
  #sec03 .s3-js .slick-prev {
    left: 17px;
  }
  #sec03 .s3-js .slick-next {
    right: 16px;
  }
}

/*--------------------------------------
    sec5
--------------------------------------*/
#sec05 {
  padding-bottom: 21.5vw;
  background: #ffeed7;
}
#sec05 .row1 .content {
  padding: 33px 14px 32px;
  text-align: center;
}
#sec05 .row1 .content .logo {
  width: 160px;
  margin: 0 auto 14px;
  padding-right: 3px;
}
#sec05 .row1 .content h2 {
  font-size: 24px;
  line-height: 1.5;
}
#sec05 .row1 .content .txt {
  margin-top: 25px;
  font-size: 18px;
  line-height: 27px;
}
#sec05 .main {
  margin-right: 3px;
}
#sec05 .main .item .photo {
  border-radius: 25px;
  overflow: hidden;
}
#sec05 .main .item .flex {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  font-weight: bold;
  margin-top: 10px;
  align-items: center;
  gap: 11px;
}
#sec05 .main .item .numb {
  font-size: 32px;
  font-family: 'Barlow Semi Condensed';
}
#sec05 .main .item h3 {
  margin-top: 1px;
  font-size: 18px;
}
#sec05 .main .item .c-list {
  text-align: left;
}
#sec05 .main .item h4 {
  font-size: 18px;
  text-align: center;
  margin: 16px 0 5px;
  line-height: 27px;
}
#sec05 .main .item + .item {
  margin-top: 24px;
}
#sec05 .main .item + .item .flex {
  gap: 6px;
}
#sec05 .main .item + .item .flex h3 {
  margin-top: 9px;
}
#sec05 .main .item + .item .c-list li + li {
  margin: 6px 0 0;
}
@media screen and (min-width: 768px) {
  #sec05 {
    padding-bottom: 200px;
  }
  #sec05 .row1 {
    align-items: end;
  }
  #sec05 .row1 .photo {
    margin-top: -80px;
    width: 50%;
    border-radius: 0 40px 40px 0;
    overflow: hidden;
    box-shadow: 4px 4px 14px rgba(0, 0, 0, 0.07);
    height: 456px;
  }
  #sec05 .row1 .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  #sec05 .row1 .content {
    width: 510px;
    min-width: 453px;
    box-sizing: border-box;
    padding: 0;
    margin: 10px 0 32px 63px;
  }
  #sec05 .row1 .content .logo {
    width: 202px;
    margin: 0;
  }
  #sec05 .row1 .content h2 {
    font-size: 32px;
    text-align: left;
    margin: 14px 0 0;
  }
  #sec05 .row1 .content .txt {
    margin-top: 16px;
  }
  #sec05 .main {
    margin: 65px auto 0;
  }
  #sec05 .main .item {
    margin: 0 3px 0 3px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    padding-top: 29px;
    padding-bottom: 29px;
    gap: 32px;
    align-items: center;
  }
  #sec05 .main .item .photo {
    width: 47.2%;
    border-radius: 10px;
  }
  #sec05 .main .item .content {
    width: 432px;
  }
  #sec05 .main .item .content .flex {
    margin-top: -13px;
    margin-bottom: 2px;
  }
  #sec05 .main .item .content .numb {
    font-size: 48px;
  }
  #sec05 .main .item .content h3 {
    margin-top: 8px;
    font-size: 24px;
  }
  #sec05 .main .item .content h4 {
    font-size: 20px;
    text-align: left;
    margin: 26px 0 16px;
  }
  #sec05 .main .item .content .txt {
    font-size: 16px;
    line-height: 1.5;
  }
  #sec05 .main .item + .item {
    margin-top: 40px;
  }
  #sec05 .main .item + .item .flex {
    gap: 2px;
    margin-bottom: -4px;
  }
  #sec05 .main .item + .item .c-list {
    margin-right: -30px;
  }
}
@media (max-width: 1000px) and (min-width: 768px) {
  #sec05 .row1 {
    justify-content: space-between;
  }
  #sec05 .row1 .content {
    margin-left: 25px;
    width: 50%;
    margin-right: 15px;
    min-width: unset;
  }
  #sec05 .row1 .content h2 {
    font-size: clamp(25px, 3.2vw, 32px);
  }
}

/*--------------------------------------
    sec6
--------------------------------------*/
#sec06 {
  padding: 18.3vw 0;
  background: #faf5ef;
  text-align: center;
}
#sec06 .content {
  position: relative;
  z-index: 2;
}
#sec06 .content .c-ttl p {
  text-transform: uppercase;
}
#sec06 .content h3 {
  font-size: 18px;
  margin: 20px 0 16px -6px;
}
#sec06 .content .txt {
  margin: 0 15px 14px;
}
#sec06 .left {
  position: relative;
  padding-bottom: 135px;
  margin-bottom: -80px;
}
#sec06 .left:before,
#sec06 .left:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% + 153px);
  height: auto;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid var(--orange);
  opacity: 0.2;
}
#sec06 .left:after {
  width: calc(100% + 67px);
  opacity: 0.4;
}
#sec06 .left .deco {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  height: 100%;
  z-index: 2;
}
#sec06 .left .deco:before,
#sec06 .left .deco:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 164px;
  height: auto;
  aspect-ratio: 1;
  border-radius: 50%;
  opacity: 0.1;
  background: var(--orange);
}
#sec06 .left .deco:after {
  width: 9px;
  opacity: 1;
}
#sec06 .left .map {
  margin: -5px 58px 0 -34px;
}
@media screen and (min-width: 768px) {
  #sec06 {
    padding: 83px 0 124px;
  }
  #sec06:before {
    transform: scaleX(-1);
  }
  #sec06 .row {
    flex-direction: row-reverse;
    justify-content: space-between;
    max-width: 990px;
    align-items: center;
  }
  #sec06 .content .c-ttl {
    margin-left: -1px;
  }
  #sec06 .content .c-ttl p {
    text-transform: unset;
    margin-top: 7px;
  }
  #sec06 .content h3 {
    font-size: 24px;
    margin: 19px 0 8px -1px;
  }
  #sec06 .content .txt {
    text-align: center;
    margin: 0 0px 31px;
    line-height: 2;
  }
  #sec06 .left {
    width: 564px;
    padding-bottom: 227px;
    margin-bottom: -246px;
  }
  #sec06 .left:before {
    width: calc(100% + 213px);
  }
  #sec06 .left:after {
    width: calc(100% + 80px);
  }
  #sec06 .left .deco:before {
    width: 256px;
  }
  #sec06 .left .deco:after {
    width: 15px;
  }
  #sec06 .left .map {
    margin: 0 auto 0 -43px;
    width: 506px;
  }
}

/*--------------------------------------
    sec7
--------------------------------------*/
#sec07 {
  padding: 11.7vw 0 38vw;
}
#sec07 .row {
  margin-top: 21px;
  margin-right: 5px;
  gap: 24px;
  margin-bottom: 22px;
}
#sec07 .row .item {
  position: relative;
  padding: 0;
  padding-bottom: 40px;
  overflow: hidden;
}
#sec07 .row .item .tag {
  position: absolute;
  color: #fff;
  background: var(--orange);
  font-size: 20px;
  font-weight: bold;
  top: 18px;
  left: 18px;
  border-radius: 24px;
  z-index: 2;
  padding: 7px 29px;
}
#sec07 .row .item h3 {
  font-size: 18px;
  text-align: center;
  border-bottom: 1px solid #e4e4e4;
  margin: 23px 16px 7px;
  padding-bottom: 11px;
}
#sec07 .row .item dl {
  margin-left: 15px;
}
#sec07 .row .item dl dd {
  font-size: 12px;
  margin-top: 8px;
  color: #535353;
}
@media screen and (min-width: 768px) {
  #sec07 {
    padding: 120px 0 213px;
  }
  #sec07 .wrap {
    max-width: 1200px;
  }
  #sec07 .c-ttl {
    margin-left: 0;
  }
  #sec07 .c-ttl p {
    margin-top: 7px;
  }
  #sec07 .row {
    flex-wrap: wrap;
    gap: 30px;
    margin: 46px 0 40px;
  }
  #sec07 .row .item {
    width: calc((100% / 3) - 20px);
  }
  #sec07 .row .item h3 {
    font-size: 20px;
    margin: 19px 33px 20px;
    padding-bottom: 12px;
  }
  #sec07 .row .item dl {
    margin-left: 32px;
  }
  #sec07 .row .item dl dt {
    font-size: 16px;
  }
  #sec07 .row .item dl dd {
    font-size: 14px;
    margin-top: 6px;
  }
  #sec07 .button {
    width: 320px;
  }
  #sec07 .button a {
    height: 64px;
    font-size: 20px;
    border-width: 5px;
    line-height: 64px;
  }
  #sec07 .button a:before {
    right: 16px;
  }
  #sec07 .button a:after {
    right: 23px;
  }
}
@media (max-width: 1000px) and (min-width: 768px) {
  #sec07 .row {
    gap: 40px;
  }
  #sec07 .row .item {
    width: calc(50% - 20px);
  }
}

/*--------------------------------------
    sec8
--------------------------------------*/
#sec08 {
  background: #faf5ef;
  padding: 11vw 0 21.4vw;
}
#sec08:before {
  bottom: calc(100% - 1px);
  background: url('../img/s8_curve_sp.png') no-repeat center top;
  background-size: auto 100%;
}
#sec08 .row {
  margin-top: 29px;
  gap: 43px;
}
#sec08 .row .item {
  padding-left: 28px;
  padding-right: 3px;
  position: relative;
}
#sec08 .row .item:before {
  content: '';
  position: absolute;
  top: 18px;
  left: 0;
  width: 16px;
  height: 16px;
  background: var(--orange);
  border-radius: 50%;
}
#sec08 .row .item:after {
  content: '';
  position: absolute;
  top: 23px;
  left: 7px;
  width: 2px;
  bottom: -65px;
  background: var(--orange);
}
#sec08 .row .item .flex {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin-bottom: 3px;
}
#sec08 .row .item .flex .numb {
  font-size: 32px;
  font-family: 'Barlow Semi Condensed';
}
#sec08 .row .item .flex h3 {
  font-size: 24px;
  margin: 6px 0 0 9px;
}
#sec08 .row .item .bg {
  position: relative;
  z-index: 1;
}
#sec08 .row .item .bg .inner {
  box-shadow: 4px 4px 14px rgba(0, 0, 0, 0.07);
  border-radius: 40px;
  background: #fff;
  padding: 23px 4px 25px;
}
#sec08 .row .item .bg:after {
  content: '';
  position: absolute;
  top: -73px;
  right: 11px;
  background: url('../img/sec08_d1.png') no-repeat center top;
  background-size: contain;
  width: 90px;
  height: 123px;
  z-index: -2;
}
#sec08 .row .item .c-list {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 9px;
}
#sec08 .row .item .c-list li {
  margin: 0;
  font-size: 14px;
}
#sec08 .row .item .c-list li img {
  width: 20px;
}
#sec08 .row .item:nth-child(2) .bg:after {
  background: url('../img/sec08_d2.png') no-repeat center top;
  background-size: contain;
}
#sec08 .row .item:nth-child(3):after {
  display: none;
}
#sec08 .row .item:nth-child(3) .bg:after {
  width: 136px;
  height: 96px;
  top: -80px;
  right: 5px;
  background: url('../img/sec08_d3.png') no-repeat center top;
  background-size: contain;
}
@media screen and (min-width: 768px) {
  #sec08 {
    padding: 105px 0 121px;
  }
  #sec08:before {
    background: url('../img/s8_curve.png') no-repeat center top;
    background-size: auto 100%;
    bottom: calc(100% - 16px);
  }
  #sec08 .wrap {
    max-width: 1200px;
  }
  #sec08 .row {
    gap: 27px;
    margin-top: 61px;
    position: relative;
  }
  #sec08 .row::before {
    content: '';
    position: absolute;
    top: 102px;
    left: 196px;
    right: 196px;
    height: 2px;
    background: var(--orange);
  }
  #sec08 .row .item {
    flex: 1 1 0;
    padding-left: 0;
  }
  #sec08 .row .item:before {
    top: 95px;
    left: calc(50% - 11px);
  }
  #sec08 .row .item:after {
    display: none;
  }
  #sec08 .row .item .flex {
    flex-direction: column;
    align-items: center;
    margin-bottom: 81px;
  }
  #sec08 .row .item .flex .numb {
    margin-left: -7px;
  }
  #sec08 .row .item .flex h3 {
    font-size: 28px;
    margin: 1px 0 0 -3px;
    line-height: 1;
  }
  #sec08 .row .item .bg:before {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    width: 30px;
    height: 30px;
    background: #fff;
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  }
  #sec08 .row .item .bg:after {
    top: -138px;
    right: auto;
    left: 25px;
    width: 95px;
    height: 144px;
  }
  #sec08 .row .item .bg .inner {
    padding: 0px 22px 0px;
    height: 381px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
  }
  #sec08 .row .item .bg .c-list li {
    font-size: 16px;
  }
  #sec08 .row .item:nth-child(2) .bg:after {
    top: -143px;
    left: 16px;
    width: 101px;
    height: 143px;
  }
  #sec08 .row .item:nth-child(3) .bg:after {
    width: 200px;
    height: 141px;
    top: -138px;
    right: auto;
    left: -52px;
  }
}
@media (max-width: 1200px) and (min-width: 768px) {
  #sec08 .over-x {
    overflow-x: scroll;
  }
  #sec08 .row {
    min-width: 1200px;
  }
}

/*--------------------------------------
    cta
--------------------------------------*/
#cta {
  background: var(--orange);
  color: #fff;
  padding: 16vw 0 8vw;
}
#cta:before {
  background: url('../img/s9_curve_sp.png') no-repeat center top;
  background-size: auto 100%;
  z-index: 3;
}
#cta .orange {
  color: inherit;
}
#cta .button {
  margin-top: 17px;
}
#cta .button a {
  background: #ffca28;
  border-color: #c86926;
  color: #232323;
}
#cta .deco {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin-top: 9vw;
}
#cta .deco p:nth-child(1) {
  margin: 0 -13% 0 4.4%;
  position: relative;
  z-index: 2;
}
#cta .deco p:nth-child(2) {
  margin: 0 4% 0 -8%;
}
@media screen and (min-width: 768px) {
  #cta {
    padding: 58px 0 110px;
    z-index: 1;
  }
  #cta:before {
    background: url('../img/s8_curve.png') no-repeat center top;
    background-size: auto 100%;
    transform: scaleX(-1);
  }
  #cta .wrap:before {
    content: '';
    position: absolute;
    top: -11px;
    left: 86px;
    width: 78px;
    height: 41px;
    background: url('../img/cta_dots1.png') no-repeat center top;
    background-size: contain;
  }
  #cta .wrap:after {
    content: '';
    position: absolute;
    top: -20px;
    right: 36px;
    width: 112px;
    height: 46px;
    background: url('../img/cta_dots2.png') no-repeat center top;
    background-size: contain;
  }
  #cta .c-ttl {
    margin-left: 0;
  }
  #cta .c-ttl p {
    margin-top: 8px;
  }
  #cta .button {
    padding-left: 8px;
  }
  #cta .deco {
    position: absolute;
    top: 0;
    margin: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 983px;
    max-width: 100%;
    z-index: -1;
  }
  #cta .deco p:nth-child(1) {
    width: 354px;
    margin: -12px 0 0;
  }
  #cta .deco p:nth-child(2) {
    margin: -17px 36px 0 auto;
    width: 296px;
  }
}

/*--------------------------------------
    sec9
--------------------------------------*/
#sec09 {
  background: #faf5ef;
  margin-top: -1px;
  position: relative;
  z-index: 2;
  padding: 10.8vw 0;
}
#sec09 .over-x {
  overflow-x: scroll;
  margin-top: 19px;
  padding-bottom: 60px;
  padding-right: 20px;
}
#sec09 .chart {
  flex-direction: row;
  gap: 4px;
  margin-right: -14px;
  align-items: start;
}
#sec09 .chart .col {
  background: #fff;
  border-radius: 20px;
  width: 195px;
  min-width: 195px;
}
#sec09 .chart .col1 {
  width: 155px;
  min-width: 155px;
  background: #ffedd7;
  border-radius: 20px 0 0 20px;
  margin-top: 218px;
  font-size: 10px;
  color: #535353;
  text-align: center;
  overflow: hidden;
}
#sec09 .chart .col1 p {
  border-bottom: 1px solid #edc89c;
  line-height: 1.3;
  box-sizing: border-box;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#sec09 .chart .col1 p small {
  display: block;
  font-weight: 400;
}
#sec09 .chart .col1 p.sp-80 {
  height: 80px;
}
#sec09 .chart .col1 p:last-child {
  border: none;
}
#sec09 .chart .col-price {
  text-align: center;
  padding: 20px 0;
  position: relative;
  z-index: 1;
}
#sec09 .chart .col-price:before {
  content: '';
  position: absolute;
  top: calc(100% - 20px);
  left: 0;
  width: 100%;
  height: 140px;
  background: inherit;
  border-radius: 0 0 20px 20px;
}
#sec09 .chart .col-price h3 {
  font-size: 24px;
}
#sec09 .chart .col-price > p {
  color: #535353;
  font-size: 10px;
  margin-left: 3px;
}
#sec09 .chart .col-price .discount {
  color: var(--orange);
  border-radius: 10px;
  margin: 25px 15px 24px 17px;
  border: 1px solid;
  padding-top: 5px;
  padding-bottom: 13px;
}
#sec09 .chart .col-price .discount p {
  font-size: 10px;
}
#sec09 .chart .col-price .discount p.fnt-barlow {
  margin-bottom: -5px;
  font-weight: bold;
  font-size: 23px;
}
#sec09 .chart .col-price .main p {
  color: #535353;
  padding: 18px 0 0;
  height: 60px;
  box-sizing: border-box;
  border-bottom: 1px solid #e4e4e4;
}
#sec09 .chart .col-price .main p:last-child {
  border: none;
}
#sec09 .chart .col-price .main p img {
  width: 25px;
  margin: 0 auto;
}
#sec09 .chart .col2 {
  background: #ffdbaf;
}
#sec09 .chart .col2 .discount {
  background: var(--orange);
  color: #fff;
  border-color: var(--orange);
}
#sec09 .chart .col2 .main p {
  border-color: #ddb88b;
}
#sec09 .chart.chart2 .col-price {
  padding: 0;
  padding-bottom: 40px;
}
#sec09 .chart.chart2 .col-price:before {
  display: none;
}
#sec09 .toggle {
  border: 1px solid var(--orange);
  border-radius: 20px;
  margin: 9px -13px 0 2px;
  min-width: max-content;
  padding: 0 20px 1px 10px;
  position: relative;
  z-index: 2;
}
#sec09 .toggle-link {
  text-align: center;
  color: var(--orange);
  font-weight: bold;
  font-size: 14px;
  padding: 8px 0 14px;
}
#sec09 .toggle-link:after {
  content: '';
  display: inline-block;
  background: url('../img/shared/icon_plus.png') no-repeat center top;
  background-size: contain;
  width: 24px;
  height: 24px;
  margin: 5px -20px -5px 9px;
}
#sec09 .toggle-main {
  margin: 23px 0 22px 0px;
}
#sec09 .toggle-main .col1 {
  margin-top: 0;
  width: 142px;
  min-width: 142px;
}
@media screen and (min-width: 768px) {
  #sec09 {
    padding: 147px 0 201px;
  }
  #sec09 .c-ttl p {
    margin-left: -17px;
  }
  #sec09 .wrap {
    max-width: 1200px;
  }
  #sec09 .over-x {
    margin-top: 17px;
    padding-top: 27px;
    overflow: hidden;
    padding-bottom: 70px;
  }
  #sec09 .chart {
    gap: 17px;
  }
  #sec09 .chart .col1 {
    margin-top: 254px;
    width: 275px;
    min-width: 275px;
    font-size: 14px;
    margin-right: -5px;
  }
  #sec09 .chart .col1 p.pb {
    padding-bottom: 20px;
  }
  #sec09 .chart .col1 small {
    font-size: 12px;
  }
  #sec09 .chart .col1 .pc-80 {
    height: 80px;
  }
  #sec09 .chart .col-price {
    width: 286px;
    min-width: 286px;
    border-radius: 40px;
    padding-top: 24px;
  }
  #sec09 .chart .col-price:before {
    top: calc(100% - 40px);
    height: 203px;
    border-radius: 0 0 40px 40px;
  }
  #sec09 .chart .col-price h3 {
    font-size: 40px;
    margin-left: 7px;
  }
  #sec09 .chart .col-price > p {
    font-size: 13px;
    margin: 2px 0 0;
  }
  #sec09 .chart .col-price .discount {
    margin: 23px 25px 24px 23px;
    padding-top: 9px;
    padding-bottom: 22px;
  }
  #sec09 .chart .col-price .discount p {
    font-size: 13px;
  }
  #sec09 .chart .col-price .discount p.fnt-barlow {
    margin-bottom: -5px;
    font-size: 30px;
    margin-left: 8px;
  }
  #sec09 .chart .col2:after {
    content: '';
    position: absolute;
    top: -29px;
    left: 3px;
    background: url('../img/sec09_catch.png') no-repeat center top;
    background-size: contain;
    width: 89px;
    height: 93px;
  }
  #sec09 .chart.chart2 .col1 {
    margin-top: -1px;
    width: 264px;
    min-width: 264px;
  }
  #sec09 .chart.chart2 .col-price {
    padding-bottom: 60px;
  }
  #sec09 .chart.chart2 .col-price:before {
    display: none;
  }
  #sec09 .chart.chart2 .col-price .main p:nth-child(1) {
    border-top: 1px solid #e4e4e4;
    padding-top: 25px;
    height: 79px;
  }
  #sec09 .chart.chart2 .col2:after {
    display: none;
  }
  #sec09 .chart.chart2 .col2 .main p:nth-child(1) {
    border-color: #ddb88b;
  }
  #sec09 .toggle {
    margin: 13px 1px 0 0px;
    width: 1186px;
    box-sizing: border-box;
    padding-right: 0;
  }
  #sec09 .toggle-link {
    font-size: 21px;
    padding: 21px 0 22px 12px;
  }
  #sec09 .toggle-main {
    margin-top: 8px;
  }
}
@media (max-width: 1200px) and (min-width: 768px) {
  #sec09 .over-x {
    overflow-x: scroll;
  }
}

/*--------------------------------------
    sec10
--------------------------------------*/
#sec10 .set1 {
  padding: 15.9vw 0 17vw;
  text-align: center;
}
#sec10 .set1 h3 {
  font-size: 16px;
  margin-top: 20px;
  margin-left: -3px;
  color: #505050;
}
#sec10 .set2 {
  padding: 20vw 0 21vw;
  position: relative;
  z-index: 1;
}
#sec10 .set2:before {
  content: '';
  position: absolute;
  top: 0;
  right: calc(50% - 154px);
  background: url('../img/sec10_deco.png') no-repeat center top;
  background-size: contain;
  width: 106px;
  height: 143px;
  z-index: -1;
}
#sec10 .set2:after {
  content: '';
  position: absolute;
  top: 15px;
  left: 0;
  width: 100%;
  bottom: 0;
  background: #fff3e3;
  z-index: -2;
}
#sec10 .set2 .tabs-switch {
  margin-top: 19px;
}
#sec10 .set2 .tabs-switch .tab-link {
  border-bottom: 2px solid var(--orange);
  gap: 2px;
  justify-content: center;
  margin: 0 -14px 22px;
  padding: 0 14px;
  align-items: start;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
#sec10 .set2 .tabs-switch .tab-link li {
  width: 25%;
  text-align: center;
  color: #fff;
  font-size: 12px;
  font-weight: bold;
  border-radius: 8px 8px 0 0;
  height: 57px;
  position: relative;
  line-height: 1.4;
  padding-top: 5px;
  box-sizing: border-box;
  background: #fff3e3;
  margin-bottom: -2px;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
#sec10 .set2 .tabs-switch .tab-link li:before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  top: 5px;
  width: 100%;
  background: var(--orange);
  border-radius: 8px 8px 0 0;
  z-index: -1;
}
#sec10 .set2 .tabs-switch .tab-link li.active {
  padding-top: 0;
  padding-bottom: 4px;
  color: inherit;
  border: 2px solid var(--orange);
  border-bottom: none;
}
#sec10 .set2 .tabs-switch .tab-link li.active:before {
  opacity: 0;
}
#sec10 .set2 .tabs-switch .row {
  gap: 24px;
}
#sec10 .set2 .tabs-switch .item {
  padding: 0;
  padding-bottom: 30px;
  position: relative;
  overflow: hidden;
}
#sec10 .set2 .tabs-switch .item .tag {
  position: absolute;
  background: #faf5ef;
  font-size: 14px;
  font-weight: bold;
  top: 18px;
  left: 18px;
  border-radius: 24px;
  z-index: 2;
  padding: 14px 35px;
}
#sec10 .set2 .tabs-switch .item h3 {
  font-size: 18px;
  border-bottom: 1px solid #e4e4e4;
  margin: 21px 16px 8px;
  padding-bottom: 11px;
}
#sec10 .set2 .tabs-switch .item .txt {
  margin: 0 16px;
  color: #535353;
  font-size: 12px;
}
@media screen and (min-width: 768px) {
  #sec10 .set1 {
    padding: 123px 0 92px;
  }
  #sec10 .set1 .c-ttl {
    margin-left: -1px;
  }
  #sec10 .set1 .c-ttl p {
    margin-top: 7px;
  }
  #sec10 .set1 h3 {
    font-size: 32px;
    margin-top: 84px;
    margin-left: 0px;
  }
  #sec10 .set2 {
    padding: 160px 0 139px;
  }
  #sec10 .set2:before {
    right: calc(50% - 310px);
    width: 189px;
    height: 252px;
  }
  #sec10 .set2:after {
    top: 49px;
  }
  #sec10 .set2 .c-ttl {
    margin-left: -2px;
  }
  #sec10 .set2 .c-ttl p {
    margin-top: 7px;
  }
  #sec10 .set2 .wrap {
    max-width: 1200px;
  }
  #sec10 .set2 .tabs-switch {
    margin-top: 34px;
  }
  #sec10 .set2 .tabs-switch .tab-link {
    margin: 0 auto 40px;
    width: 100%;
    max-width: 872px;
    padding: 0 0px 0 54px;
    box-sizing: border-box;
    gap: 6px;
  }
  #sec10 .set2 .tabs-switch .tab-link li {
    font-size: 16px;
    padding-top: 7px;
  }
  #sec10 .set2 .tabs-switch .tab-link li.active {
    padding-top: 8px;
    font-size: 18px;
  }
  #sec10 .set2 .tabs-switch .tab-link li:before {
    top: 8px;
  }
  #sec10 .set2 .tabs-switch .row {
    gap: 30px;
    flex-wrap: wrap;
  }
  #sec10 .set2 .tabs-switch .row .item {
    width: calc((100% / 3) - 20px);
    padding-bottom: 28px;
  }
  #sec10 .set2 .tabs-switch .row .item .tag {
    font-size: 16px;
    padding: 12px 32px 10px 33px;
  }
  #sec10 .set2 .tabs-switch .row .item h3 {
    font-size: 20px;
    border-bottom: 1px solid #e4e4e4;
    margin: 19px 32px 19px;
    padding-bottom: 12px;
  }
  #sec10 .set2 .tabs-switch .row .item .txt {
    margin: 0 32px;
    font-size: 14px;
  }
}
@media (max-width: 1000px) and (min-width: 768px) {
  #sec10 .set2 .tabs-switch .row {
    gap: 40px;
  }
  #sec10 .set2 .tabs-switch .row .item {
    width: calc(50% - 20px);
  }
}

/*# sourceMappingURL=index.css.map */
