@charset "UTF-8";
*,
*:before,
*:after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "source-han-serif-japanese", "Hiragino Mincho ProN", "Yu Mincho", "游明朝", serif;
  font-style: normal;
  color: #434952;
  letter-spacing: 0.05em;
  background-color: #ffffff;
}

h1, h2, h3, h4, h5, h6, p {
  font-size: inherit;
}

a {
  color: inherit;
  text-decoration: none;
  transition: 0.4s;
}
a:hover {
  opacity: 0.7;
}

ul, ol {
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
}

button {
  font-family: "source-han-serif-japanese", "Hiragino Mincho ProN", "Yu Mincho", "游明朝", serif;
  font-style: normal;
  letter-spacing: 0.05em;
  border: none;
  background-color: transparent;
  cursor: pointer;
  transition: 0.4s;
}
button:hover {
  opacity: 0.7;
}

.sp-only {
  display: block;
}
@media screen and (min-width: 1000px) {
  .sp-only {
    display: none;
  }
}

.pc-only {
  display: none;
}
@media screen and (min-width: 1000px) {
  .pc-only {
    display: block;
  }
}

dl, dt, dd {
  margin: 0;
  padding: 0;
}

em {
  font-style: normal;
}

address {
  font-style: normal;
}

header {
  padding-top: 15px;
  padding-bottom: 15px;
}
@media screen and (min-width: 1000px) {
  header {
    padding-top: 30px;
    padding-bottom: 25px;
  }
}
header h1 {
  text-align: center;
  line-height: 0;
}
header h1 img {
  width: 143.31px;
}
@media screen and (min-width: 1000px) {
  header h1 img {
    width: 272.11px;
  }
}

main section.main-visual .headline {
  padding-top: 12px;
  padding-bottom: 12px;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
  color: #5D4400;
  background-color: #F8F4E7;
  outline-offset: -5px;
  outline: 1px solid #EAD9AE;
}
@media screen and (min-width: 1000px) {
  main section.main-visual .headline {
    padding-top: 20px;
    padding-bottom: 20px;
    font-size: 20px;
  }
}
main section.main-visual .headline h2 {
  display: inline-block;
  margin-bottom: 8px;
  border-bottom: 1px solid #5D4400;
}
main section.main-visual .headline p {
  color: #98761C;
  line-height: 22px;
}
@media screen and (min-width: 1000px) {
  main section.main-visual .headline p {
    line-height: 38px;
  }
}
main section.main-visual > section.content {
  padding-top: 15px;
  padding-bottom: 34px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  background-image: url(../img/main-visual-bg-sp.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content {
    padding-top: 40px;
    padding-bottom: 45px;
    padding-right: 0;
    padding-left: 0;
    background-image: url(../img/main-visual-bg-pc.webp);
    background-position: top;
  }
}
main section.main-visual > section.content div.inner {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto auto;
    align-items: stretch;
    width: calc(100% - 120px);
    max-width: 1160px;
    margin: 0 auto;
  }
}
main section.main-visual > section.content div.inner > img {
  width: 100%;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner > img {
    grid-column: 1/2;
    grid-row: 1/5;
    width: 100%;
    aspect-ratio: 583/661;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
main section.main-visual > section.content div.inner > h2 {
  position: absolute;
  top: 35px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 18px;
  line-height: 26px;
  color: #434952;
  white-space: nowrap;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner > h2 {
    position: static;
    transform: none;
    grid-column: 2/3;
    grid-row: 1/2;
    justify-self: center;
    font-size: 33px;
    line-height: 47px;
  }
}
main section.main-visual > section.content div.inner > h2 em {
  font-size: 40px;
  line-height: 57px;
  color: #FB6876;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner > h2 em {
    font-size: 73px;
    line-height: 105px;
  }
}
main section.main-visual > section.content div.inner > h2 em span {
  font-size: 30px;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner > h2 em span {
    font-size: 55px;
  }
}
main section.main-visual > section.content div.inner .access {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row;
  -moz-column-gap: 15px;
       column-gap: 15px;
  margin-top: 18px;
  padding: 11px 12px;
  background-color: #FDFCF7;
  border: 1px solid #FB6876;
  border-radius: 15px;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner .access {
    width: 441px;
    margin: 50px auto 0;
    padding: 10px 27px;
  }
}
main section.main-visual > section.content div.inner .access h3 {
  font-weight: normal;
  color: #FB6876;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner .access h3 {
    font-size: 20px;
  }
}
main section.main-visual > section.content div.inner .access ul {
  padding-left: 15px;
  font-size: 11px;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner .access ul {
    font-size: 13px;
  }
}
main section.main-visual > section.content div.inner .access ul li {
  position: relative;
  margin-bottom: 5px;
}
main section.main-visual > section.content div.inner .access ul li:last-child {
  margin-bottom: 0px;
}
main section.main-visual > section.content div.inner .access ul li:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -15px;
  transform: translateY(-50%);
  background-image: url(../img/check-mark.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 10.67px;
  height: 6.65px;
}
main section.main-visual > section.content div.inner .access ul li em {
  color: #FB6876;
}
main section.main-visual > section.content div.inner .access ul li em strong {
  font-size: 14px;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner .access ul li em strong {
    font-size: 15px;
  }
}
main section.main-visual > section.content div.inner > ul {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row;
  margin-top: 10px;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner > ul {
    grid-column: 2/3;
    grid-row: 3/4;
    width: 441px;
    margin: 10px auto 0;
  }
}
main section.main-visual > section.content div.inner > ul li {
  width: 33.3333333333%;
}
main section.main-visual > section.content div.inner > ul li img {
  width: 100%;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner > ul li img {
    width: 143px;
  }
}
main section.main-visual > section.content div.inner a.cv-btn {
  position: relative;
  display: inline-block;
  margin-top: 35px;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner a.cv-btn {
    grid-column: 2/3;
    grid-row: 4/5;
    justify-self: center;
  }
}
main section.main-visual > section.content div.inner a.cv-btn span {
  position: absolute;
  top: -25px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 13px;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "YuGothic", "Meiryo", sans-serif;
  font-style: normal;
  letter-spacing: 0.08em;
  color: #A82121;
  white-space: nowrap;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner a.cv-btn span {
    font-size: 18px;
  }
}
main section.main-visual > section.content div.inner a.cv-btn img {
  width: 276px;
}
@media screen and (min-width: 1000px) {
  main section.main-visual > section.content div.inner a.cv-btn img {
    width: 457px;
    padding-top: 10px;
  }
}
main section.issue {
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  padding-top: 45px;
  padding-bottom: 73px;
  background-color: #F8F4E7;
}
@media screen and (min-width: 1000px) {
  main section.issue {
    padding-top: 70px;
    padding-bottom: 104px;
    padding-right: calc(50vw - 580px);
    padding-left: calc(50vw - 580px);
  }
}
main section.issue h2 {
  position: relative;
  margin-left: 63px;
  padding-top: 18px;
  padding-bottom: 18px;
  padding-right: 15px;
  padding-left: 39px;
  line-height: 25px;
  text-align: center;
  background-color: #ffffff;
  border: 1px solid #EAD9AE;
  border-radius: 20px;
}
@media screen and (min-width: 1000px) {
  main section.issue h2 {
    width: 460px;
    margin: 0 auto;
    padding-top: 22px;
    padding-bottom: 22px;
    padding-right: 70px;
    padding-left: 78px;
    font-size: 23px;
    line-height: 36px;
  }
}
main section.issue h2::before {
  content: "";
  position: absolute;
  top: -23px;
  left: -74px;
  background-image: url(../img/issue-illust.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 125px;
  height: 135px;
}
@media screen and (min-width: 1000px) {
  main section.issue h2::before {
    top: -38px;
    left: -100px;
    width: 187px;
    height: 191px;
  }
}
main section.issue h2 em {
  color: #FB6876;
}
main section.issue p {
  margin-top: 18px;
  line-height: 31px;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.issue p {
    font-size: 20px;
    line-height: 35px;
  }
}
main section.issue p em {
  border-bottom: 1px solid #FB6876;
}
main section.lisk {
  position: relative;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  padding-bottom: 10px;
  background-color: #BEA564;
}
@media screen and (min-width: 1000px) {
  main section.lisk {
    padding-right: calc(50vw - 483.5px);
    padding-left: calc(50vw - 483.5px);
  }
}
main section.lisk:before, main section.lisk:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 52px;
}
main section.lisk:before {
  background-image: url(../img/lisk-top-bg-sp.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 52px;
  top: -51px;
  left: 50%;
  transform: translateX(-50%);
}
main section.lisk:after {
  background-image: url(../img/lisk-bottom-bg-sp.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 52px;
  bottom: -51px;
  left: 50%;
  transform: translateX(-50%);
}
main section.lisk h2 {
  margin-bottom: 30px;
  font-size: 20px;
  font-weight: 400;
  color: #ffffff;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.lisk h2 {
    font-size: 30px;
  }
}
main section.lisk h2 em {
  font-size: 33px;
  font-weight: 600;
}
@media screen and (min-width: 1000px) {
  main section.lisk h2 em {
    font-size: 56px;
  }
}
main section.lisk ol > li {
  margin-bottom: 35px;
  padding: 50px 17px 17px;
  background-color: #ffffff;
  border-radius: 30px;
  box-shadow: 3px 3px 6px #897237;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li {
    margin-bottom: 45px;
    padding: 40px 20px 17px;
  }
}
main section.lisk ol > li:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    -moz-column-gap: 32px;
         column-gap: 32px;
    margin-bottom: 30px;
  }
}
main section.lisk ol > li .inner h3 {
  margin-bottom: 20px;
  font-size: 55px;
  font-weight: 500;
  text-align: center;
  color: #FB6876;
  line-height: 79px;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner h3 {
    margin-bottom: 30px;
    flex: 1;
    font-size: 82px;
    line-height: 117px;
  }
}
main section.lisk ol > li .inner h3 span {
  position: relative;
  font-size: 40px;
  font-weight: 600;
  color: #000000;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner h3 span {
    font-size: 59px;
  }
}
main section.lisk ol > li .inner h3 span:before {
  content: "01";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 120px;
  font-weight: 400;
  color: #BEA564;
  opacity: 0.1;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner h3 span:before {
    top: 35%;
    font-size: 178px;
  }
}
main section.lisk ol > li .inner .deta {
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner .deta {
    width: 462px;
  }
}
main section.lisk ol > li .inner .deta p {
  margin-bottom: 25px;
  font-size: 18px;
  font-weight: 400;
  line-height: 25px;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner .deta p {
    font-size: 20px;
  }
}
main section.lisk ol > li .inner .deta p em {
  display: inline-block;
  margin-right: 10px;
  margin-left: 10px;
  margin-bottom: 9px;
  font-size: 25px;
  font-weight: 600;
  line-height: 37px;
  color: #28B7BE;
  border-bottom: 1px solid #28B7BE;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner .deta p em {
    font-size: 29px;
  }
}
main section.lisk ol > li .inner .deta > img {
  width: 100%;
}
main section.lisk ol > li .inner .deta > small {
  display: block;
  margin-top: 10px;
  margin-bottom: 15px;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "YuGothic", "Meiryo", sans-serif;
  font-style: normal;
  font-size: 8px;
  text-align: right;
  color: #9C9C9C;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner .deta > small {
    margin-bottom: 30px;
    font-size: 11px;
  }
}
main section.lisk ol > li .inner .deta .explanation {
  margin-bottom: 25px;
  font-size: 16px;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner .deta .explanation {
    margin-bottom: 0;
    font-size: 20px;
    line-height: 35px;
  }
}
main section.lisk ol > li .inner .deta .explanation em {
  margin: 0;
  font-size: inherit;
  font-weight: 400;
  color: #28B7BE;
  line-height: 28px;
  border-bottom: none;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li .inner .deta .explanation em {
    line-height: 35px;
  }
}
main section.lisk ol > li section.inspection {
  padding-right: 15px;
  padding-left: 15px;
  background-color: #67A220;
  border-radius: 20px;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li section.inspection {
    padding-right: 20px;
    padding-left: 20px;
  }
}
main section.lisk ol > li section.inspection .accordion-btn {
  position: relative;
  display: block;
  width: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  color: #ffffff;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li section.inspection .accordion-btn {
    font-size: 18px;
  }
}
main section.lisk ol > li section.inspection .accordion-btn:before, main section.lisk ol > li section.inspection .accordion-btn:after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 10px;
  height: 1px;
  background: #ffffff;
  transform: translateY(-50%);
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li section.inspection .accordion-btn:before, main section.lisk ol > li section.inspection .accordion-btn:after {
    width: 16px;
  }
}
main section.lisk ol > li section.inspection .accordion-btn:after {
  transform: translateY(-50%) rotate(90deg);
  transition: opacity 0.2s ease;
}
main section.lisk ol > li section.inspection .accordion-btn.is-open:after {
  opacity: 0;
}
main section.lisk ol > li section.inspection .accordion-content {
  display: none;
  padding-bottom: 20px;
}
main section.lisk ol > li section.inspection .accordion-content.is-open {
  display: block;
}
main section.lisk ol > li section.inspection .accordion-content > ul {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  row-gap: 5px;
  margin-bottom: 23px;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li section.inspection .accordion-content > ul {
    justify-content: center;
    flex-direction: row;
    -moz-column-gap: 10px;
         column-gap: 10px;
    row-gap: 0;
  }
}
main section.lisk ol > li section.inspection .accordion-content > ul li {
  padding: 5px 13px;
  text-align: center;
  color: #67A220;
  background-color: #ffffff;
}
main section.lisk ol > li section.inspection .accordion-content h4 {
  margin-bottom: 10px;
  color: #ffffff;
  text-align: center;
}
main section.lisk ol > li section.inspection .accordion-content p {
  font-size: 15px;
  font-weight: 400;
  text-align: center;
  line-height: 23px;
  color: #ffffff;
}
@media screen and (min-width: 1000px) {
  main section.lisk ol > li section.inspection .accordion-content p {
    font-size: 18px;
  }
}
main section.lisk ol > li section.inspection .accordion-content p em {
  font-weight: 600;
  color: #FCFFBA;
}
main section.lisk ol > li:nth-child(2) .inner h3 span:before {
  content: "02";
}
main section.suggestion {
  padding-top: 92px;
  padding-bottom: 72px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
}
@media screen and (min-width: 1000px) {
  main section.suggestion {
    padding-top: 110px;
    padding-bottom: 100px;
    padding-right: calc(50vw - 483.5px);
    padding-left: calc(50vw - 483.5px);
  }
}
main section.suggestion h2 {
  width: 288px;
  margin: 0 auto 28px;
  padding-top: 18px;
  padding-bottom: 18px;
  text-align: center;
  font-size: 25px;
  font-weight: 600;
  color: #BEA564;
  border: 1px solid #EAD9AE;
  border-radius: 10px;
}
@media screen and (min-width: 1000px) {
  main section.suggestion h2 {
    width: 452px;
    margin-bottom: 30px;
    padding-top: 20px;
    padding-bottom: 20px;
    white-space: nowrap;
  }
}
main section.suggestion p {
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  line-height: 30px;
}
@media screen and (min-width: 1000px) {
  main section.suggestion p {
    font-size: 20px;
    line-height: 35px;
  }
}
main section.suggestion p em {
  border-bottom: 1px solid #FB6876;
}
main section.suggestion p strong {
  display: inline-block;
  padding-bottom: 10px;
  font-size: 18px;
  color: #98761C;
}
@media screen and (min-width: 1000px) {
  main section.suggestion p strong {
    font-size: 22px;
  }
}
main section.suggestion .pink-text {
  position: relative;
  display: block;
  width: calc(100% - 14px);
  max-width: 764.19px;
  margin: 15px auto 28px;
  padding: 45px 0 30px;
  font-size: 19px;
  color: #FB6876;
  text-align: center;
  line-height: 32px;
}
@media screen and (min-width: 1000px) {
  main section.suggestion .pink-text {
    font-size: 25px;
    line-height: 40px;
  }
}
main section.suggestion .pink-text:before, main section.suggestion .pink-text:after {
  content: "";
  position: absolute;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
main section.suggestion .pink-text:before {
  background-image: url(../img/suggestion-decoration-left.webp);
  top: 0;
  left: 0;
  width: 39.16px;
  height: 55.96px;
}
@media screen and (min-width: 1000px) {
  main section.suggestion .pink-text:before {
    width: 86px;
    height: 94px;
  }
}
main section.suggestion .pink-text:after {
  background-image: url(../img/suggestion-decoration-right.webp);
  bottom: 0;
  right: 0;
  width: 54px;
  height: 65px;
}
@media screen and (min-width: 1000px) {
  main section.suggestion .pink-text:after {
    width: 73px;
    height: 89px;
  }
}
main section.inspection1 {
  position: relative;
  padding-top: 38px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  background-color: #FFDBDE;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 {
    padding-right: calc(50vw - 483.5px);
    padding-left: calc(50vw - 483.5px);
  }
}
main section.inspection1:before, main section.inspection1:after {
  content: "";
  position: absolute;
  width: 100%;
}
main section.inspection1:before {
  background-image: url(../img/inspection1-top-bg-sp.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 50px;
  top: -50px;
  left: 50%;
  transform: translateX(-50%);
  height: 50px;
}
main section.inspection1:after {
  background-image: url(../img/inspection1-bottom-bg-sp.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 180px;
  bottom: -158px;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  height: 180px;
}
main section.inspection1 h2 {
  margin-bottom: 32px;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 h2 {
    margin-bottom: 64px;
    font-size: 23px;
  }
}
main section.inspection1 h2 em {
  padding-top: 10px;
  font-size: 27px;
  color: #E32437;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 h2 em {
    padding-top: 13px;
    font-size: 35px;
  }
}
main section.inspection1 div.detail {
  position: relative;
  padding: 32px 20px 25px;
  background-color: #ffffff;
  border-radius: 30px;
  border: 3px solid #FB6876;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail {
    width: 606px;
    margin: 0 auto;
    padding: 40px 20px 30px;
  }
}
main section.inspection1 div.detail > span {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  padding: 7px 10px;
  font-size: 13px;
  color: #ffffff;
  background-color: #FB6876;
  border-radius: 16px;
  white-space: nowrap;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail > span {
    padding: 10px 38px;
    font-size: 18px;
  }
}
main section.inspection1 div.detail > span:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -27px;
  transform: translateY(-50%);
  background-image: url(../img/inspection1-headline-illust.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 38px;
  height: 50px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail > span:before {
    width: 55px;
    height: 71px;
  }
}
main section.inspection1 div.detail h3 {
  margin-bottom: 25px;
  padding-bottom: 19px;
  font-size: 32px;
  font-weight: 600;
  color: #D31C2E;
  text-align: center;
  border-bottom: 1px solid #D7E3E5;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail h3 {
    padding-bottom: 11px;
  }
}
main section.inspection1 div.detail .required-time {
  margin-bottom: 48px;
  font-size: 11px;
  font-weight: 400;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail .required-time {
    margin-bottom: 25px;
    font-size: 11px;
  }
}
main section.inspection1 div.detail .required-time span {
  position: relative;
  display: block;
  font-size: 17px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail .required-time span {
    display: inline;
    padding-right: 15px;
  }
}
main section.inspection1 div.detail .required-time span:before {
  content: "";
  position: absolute;
  top: 52%;
  left: 50px;
  transform: translateY(-50%);
  background-image: url(../img/inspection-clock.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 13.86px;
  height: 14.01px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail .required-time span:before {
    left: -20px;
  }
}
main section.inspection1 div.detail .list-title {
  margin-bottom: 10px;
  text-align: center;
}
main section.inspection1 div.detail > ul {
  margin-bottom: 27px;
  text-align: center;
}
main section.inspection1 div.detail > ul li {
  margin-bottom: 10px;
  padding-left: 20px;
  font-size: 17px;
  font-weight: 600;
  color: #FB6876;
}
main section.inspection1 div.detail > ul li:last-child {
  margin-bottom: 0;
}
main section.inspection1 div.detail > ul li span {
  position: relative;
}
main section.inspection1 div.detail > ul li span:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -20px;
  transform: translateY(-50%);
  background-image: url(../img/inspection-list-mark.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 15px;
  height: 15px;
}
main section.inspection1 div.detail div.inspection-list {
  padding: 20px 10px;
  background-color: #FFF5F5;
  border-radius: 20px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail div.inspection-list {
    width: 505px;
    margin: 0 auto;
  }
}
main section.inspection1 div.detail div.inspection-list h4 {
  margin-bottom: 10px;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
}
main section.inspection1 div.detail div.inspection-list ul {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: wrap;
  -moz-column-gap: 5px;
       column-gap: 5px;
  row-gap: 12px;
}
main section.inspection1 div.detail div.inspection-list ul li {
  padding: 5px 7px;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "YuGothic", "Meiryo", sans-serif;
  font-style: normal;
  font-size: 14px;
  color: #3E6689;
  border: 1px solid #3E6689;
  border-radius: 2px;
}
main section.inspection1 div.detail div.inspection-list ul li:nth-child(n+10) {
  color: #D8367A;
  border: 1px solid #D8367A;
}
main section.inspection1 div.detail div.price {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  margin-top: 25px;
  margin-bottom: 25px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail div.price {
    justify-content: center;
    align-items: flex-start;
    flex-direction: row;
  }
}
main section.inspection1 div.detail div.price > div {
  width: 233px;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail div.price > div {
    width: 50%;
    height: 135.29px;
  }
}
main section.inspection1 div.detail div.price > div:first-child {
  margin-bottom: 18px;
  padding-bottom: 15px;
  background: repeating-linear-gradient(to right, #D7E3E5 0, #D7E3E5 4px, transparent 4px, transparent 8px);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 100% 2px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail div.price > div:first-child {
    margin-bottom: 0;
    padding-bottom: 0;
    background: repeating-linear-gradient(to bottom, #D7E3E5 0, #D7E3E5 4px, transparent 4px, transparent 8px);
    background-repeat: no-repeat;
    background-position: right center;
    background-size: 2px 100%;
  }
}
main section.inspection1 div.detail div.price > div h5 {
  font-size: 17px;
  font-weight: 500;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail div.price > div h5 {
    font-size: 19px;
  }
}
main section.inspection1 div.detail div.price > div p {
  font-size: 17px;
  font-weight: 600;
  color: #D31C2E;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail div.price > div p {
    font-size: 21px;
  }
}
main section.inspection1 div.detail div.price > div p em {
  font-size: 33px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail div.price > div p em {
    font-size: 40px;
  }
}
main section.inspection1 div.detail .cv-btn-wrap {
  text-align: center;
}
main section.inspection1 div.detail .cv-btn-wrap .cv-btn img {
  width: 276px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 div.detail .cv-btn-wrap .cv-btn img {
    width: 457px;
  }
}
main section.inspection1 > p {
  position: absolute;
  bottom: -90px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  font-size: 18px;
  color: #ffffff;
  text-align: center;
  white-space: nowrap;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 > p {
    bottom: -105px;
    font-size: 21px;
  }
}
main section.inspection1 > p em {
  font-size: 21px;
}
@media screen and (min-width: 1000px) {
  main section.inspection1 > p em {
    font-size: 25px;
  }
}
main section.another-inspection {
  margin-top: 200px;
  margin-bottom: 32px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
}
@media screen and (min-width: 1000px) {
  main section.another-inspection {
    display: grid;
    padding-right: calc(50vw - 580px);
    padding-left: calc(50vw - 580px);
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    row-gap: 20px;
    margin-top: 160px;
  }
}
main section.another-inspection p {
  font-weight: 400;
  text-align: center;
  line-height: 30px;
}
@media screen and (min-width: 1000px) {
  main section.another-inspection p {
    font-size: 20px;
  }
}
main section.another-inspection p em {
  font-size: 18px;
  font-weight: 600;
  color: #FB6876;
}
@media screen and (min-width: 1000px) {
  main section.another-inspection p em {
    font-size: 20px;
  }
}
main section.another-inspection p strong {
  font-size: 18px;
  font-weight: 600;
}
main section.another-inspection p:first-child {
  grid-column: 2/3;
  grid-row: 1/2;
  align-self: flex-end;
}
main section.another-inspection p:last-child {
  grid-column: 2/3;
  grid-row: 2/3;
}
main section.another-inspection img {
  margin-top: 30px;
  margin-bottom: 10px;
  width: 100%;
}
@media screen and (min-width: 1000px) {
  main section.another-inspection img {
    grid-column: 1/2;
    grid-row: 1/3;
  }
}
main section.appeal {
  padding-top: 170px;
  padding-bottom: 60px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  background-color: #FFF5F5;
}
@media screen and (min-width: 1000px) {
  main section.appeal {
    padding-top: 67px;
    padding-bottom: 105px;
    padding-right: calc(50vw - 483.5px);
    padding-left: calc(50vw - 483.5px);
  }
}
main section.appeal div.detail {
  position: relative;
  margin-bottom: 32px;
  padding: 39px 22px 32px;
  background-color: #ffffff;
  border: 1px solid #FB6876;
  border-radius: 25px;
}
@media screen and (min-width: 1000px) {
  main section.appeal div.detail {
    padding: 39px 252px 31px 113px;
  }
}
main section.appeal div.detail:before {
  content: "";
  position: absolute;
  top: -145px;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../img/appeal-illust.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 145px;
  height: 144px;
}
@media screen and (min-width: 1000px) {
  main section.appeal div.detail:before {
    top: auto;
    bottom: 0;
    left: auto;
    right: 34px;
    transform: none;
    width: 218.35px;
    height: 216.85px;
  }
}
main section.appeal div.detail h2 {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  padding: 7px 10px;
  font-size: 16px;
  color: #ffffff;
  background-color: #FB6876;
  border-radius: 16px;
  white-space: nowrap;
}
@media screen and (min-width: 1000px) {
  main section.appeal div.detail h2 {
    width: 401px;
    padding: 7px 0;
    font-size: 18px;
    text-align: center;
    border-radius: 19px;
  }
}
main section.appeal div.detail p {
  font-size: 15px;
  font-weight: 600;
  text-align: center;
  line-height: 27px;
}
@media screen and (min-width: 1000px) {
  main section.appeal div.detail p {
    font-size: 18px;
    line-height: 35px;
  }
}
main section.appeal div.detail p em {
  font-size: 18px;
  color: #BEA564;
}
@media screen and (min-width: 1000px) {
  main section.appeal div.detail p em {
    font-size: 20px;
  }
}
main section.appeal div.detail p span {
  font-size: 16px;
}
@media screen and (min-width: 1000px) {
  main section.appeal div.detail p span {
    font-size: 18px;
  }
}
main section.appeal > p {
  line-height: 30px;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main section.appeal > p {
    font-size: 20px;
  }
}
main section.appeal > p em {
  color: #FB6876;
}
main .inspection2 {
  position: relative;
  padding-top: 25px;
  padding-bottom: 45px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  background-color: #FFFBEF;
}
@media screen and (min-width: 1000px) {
  main .inspection2 {
    padding-right: calc(50vw - 483.5px);
    padding-left: calc(50vw - 483.5px);
  }
}
main .inspection2:before {
  content: "";
  position: absolute;
  top: -51px;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../img/inspection2-top-bg-sp.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 52px;
  width: 100%;
  height: 52px;
}
main .inspection2 h2 {
  margin-bottom: 34px;
  font-size: 27px;
  font-weight: 600;
  line-height: 40px;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main .inspection2 h2 {
    margin-bottom: 64px;
    font-size: 35px;
  }
}
main .inspection2 h2 small {
  display: block;
  margin-bottom: 15px;
  font-size: 21px;
  color: #D31C2E;
}
@media screen and (min-width: 1000px) {
  main .inspection2 h2 small {
    font-size: 23px;
  }
}
main .inspection2 div.detail {
  position: relative;
  padding: 32px 20px 25px;
  background-color: #ffffff;
  border-radius: 30px;
  border: 3px solid #9A7A3A;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail {
    width: 606px;
    margin: 0 auto;
    padding: 40px 20px 30px;
  }
}
main .inspection2 div.detail > span {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  padding: 7px 10px 7px 28px;
  font-size: 13px;
  color: #ffffff;
  background-color: #BFA269;
  border-radius: 16px;
  white-space: nowrap;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail > span {
    padding: 10px 38px;
    font-size: 18px;
  }
}
main .inspection2 div.detail > span:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -38px;
  transform: translateY(-50%);
  background-image: url(../img/inspection2-headline-illust.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 67.11px;
  height: 67.11px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail > span:before {
    left: -57px;
    width: 92px;
    height: 96px;
  }
}
main .inspection2 div.detail > h3 {
  margin-bottom: 25px;
  padding-bottom: 19px;
  font-size: 28px;
  font-weight: 600;
  color: #67490B;
  text-align: center;
  border-bottom: 1px solid #D7E3E5;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail > h3 {
    padding-bottom: 11px;
    font-size: 40px;
  }
}
main .inspection2 div.detail .required-time {
  margin-bottom: 23px;
  font-size: 11px;
  font-weight: 400;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail .required-time {
    margin-bottom: 25px;
    font-size: 11px;
  }
}
main .inspection2 div.detail .required-time span {
  position: relative;
  display: block;
  font-size: 17px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail .required-time span {
    display: inline;
    padding-right: 15px;
  }
}
main .inspection2 div.detail .required-time span:before {
  content: "";
  position: absolute;
  top: 52%;
  left: 58px;
  transform: translateY(-50%);
  background-image: url(../img/inspection-clock.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 13.86px;
  height: 14.01px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail .required-time span:before {
    left: -20px;
  }
}
main .inspection2 div.detail .list-title {
  margin-bottom: 10px;
  text-align: center;
}
main .inspection2 div.detail > ul {
  margin-bottom: 27px;
  text-align: center;
}
main .inspection2 div.detail > ul li {
  margin-bottom: 10px;
  padding-left: 20px;
  font-size: 17px;
  font-weight: 600;
  color: #CC4C65;
}
main .inspection2 div.detail > ul li:last-child {
  margin-bottom: 0;
}
main .inspection2 div.detail > ul li span {
  position: relative;
}
main .inspection2 div.detail > ul li span:before {
  content: "";
  position: absolute;
  top: 25%;
  left: -20px;
  transform: translateY(-50%);
  background-image: url(../img/inspection2-list-mark.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 15px;
  height: 15px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail > ul li span:before {
    top: 50%;
  }
}
main .inspection2 div.detail > ul li:last-child span:before {
  top: 50%;
}
main .inspection2 div.detail div.inspection-list {
  padding: 20px 10px;
  background-color: #FFFBEF;
  border-radius: 20px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail div.inspection-list {
    width: 505px;
    margin: 0 auto;
  }
}
main .inspection2 div.detail div.inspection-list h4 {
  margin-bottom: 10px;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
}
main .inspection2 div.detail div.inspection-list > ul {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: wrap;
  -moz-column-gap: 5px;
       column-gap: 5px;
  row-gap: 12px;
}
main .inspection2 div.detail div.inspection-list > ul li {
  padding: 5px 7px;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "YuGothic", "Meiryo", sans-serif;
  font-style: normal;
  font-size: 14px;
  color: #3E6689;
  border: 1px solid #3E6689;
  border-radius: 2px;
}
main .inspection2 div.detail div.inspection-list > ul li:nth-child(n+18) {
  color: #D8367A;
  border: 1px solid #D8367A;
}
main .inspection2 div.detail div.price {
  margin-top: 25px;
  margin-bottom: 23px;
  text-align: center;
}
main .inspection2 div.detail div.price p {
  font-size: 17px;
  font-weight: 600;
  color: #D31C2E;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail div.price p {
    font-size: 21px;
  }
}
main .inspection2 div.detail div.price p em {
  font-size: 33px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail div.price p em {
    font-size: 40px;
  }
}
main .inspection2 div.detail section.about-dwi > span {
  display: block;
  margin-bottom: 12px;
  font-size: 15px;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi > span {
    font-size: 16px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner {
  margin-bottom: 15px;
  padding: 12px;
  border: 1px solid #FB6876;
  border-radius: 22.5px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner {
    width: 380px;
    margin: 0 auto 30px;
    padding: 12px 27px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn {
  position: relative;
  display: block;
  width: 100%;
  padding-right: 35px;
  color: #FB6876;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn {
    font-size: 18px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn:before, main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn:after {
  content: "";
  position: absolute;
  right: 25px;
  top: 55%;
  width: 10px;
  height: 1px;
  background: #FB6876;
  transform: translateY(-50%);
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn:before, main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn:after {
    right: 0;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn:after {
  transform: translateY(-50%) rotate(90deg);
  transition: opacity 0.2s ease;
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-btn.is-open:after {
  opacity: 0;
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content {
  display: none;
  padding-top: 30px;
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content.is-open {
  display: block;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content {
    padding-top: 25px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 {
  text-align: center;
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span {
  position: relative;
  font-weight: 400;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span {
    font-size: 17px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:before, main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: #FEE8E3;
  width: 8px;
  height: 8px;
  border-radius: 4px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:before, main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:after {
    width: 9px;
    height: 9px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:before {
  left: -15px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:before {
    left: -35px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:after {
  right: -15px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content h3 span:after {
    right: -35px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content > p {
  margin-top: 12px;
  margin-bottom: 15px;
  font-size: 18px;
  text-align: center;
  color: #28B7BE;
  letter-spacing: 0;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content > p {
    margin-bottom: 18px;
    font-size: 20px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content .image {
  margin-bottom: 26px;
  width: 100%;
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content > ul {
  margin-top: 5px;
  margin-bottom: 24px;
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content > ul li {
  font-size: 18px;
  color: #28B7BE;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content > ul li {
    font-size: 20px;
  }
}
main .inspection2 div.detail section.about-dwi .about-dwi-inner .accordion-content img {
  width: 100%;
}
main .inspection2 div.detail section.about-dwi .cv-btn-wrap {
  text-align: center;
}
main .inspection2 div.detail section.about-dwi .cv-btn-wrap .cv-btn {
  display: inline-block;
  width: 276px;
}
@media screen and (min-width: 1000px) {
  main .inspection2 div.detail section.about-dwi .cv-btn-wrap .cv-btn {
    width: 457px;
  }
}
main .inspection2 div.detail section.about-dwi .cv-btn-wrap .cv-btn img {
  width: 100%;
}
main section.solution .headline {
  padding-top: 41px;
  padding-bottom: 200px;
  background-image: url("../img/solution-headline-bg-sp.webp"), url("../img/solution-headline-bg-color-sp.webp");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover, 100% 638px;
  width: 100%;
  height: 638px;
  clip-path: polygon(100% 0, 100% 92%, 50% 100%, 0 92%, 0 0);
}
@media screen and (min-width: 500px) {
  main section.solution .headline {
    background-image: url("../img/solution-headline-bg-tab.webp"), url("../img/solution-headline-bg-color-sp.webp");
  }
}
@media screen and (min-width: 1000px) {
  main section.solution .headline {
    padding-top: 70px;
    padding-bottom: 0;
    background-image: url("../img/solution-headline-bg-pc.webp"), url("../img/solution-headline-bg-color-pc.webp");
    background-size: cover, 100% 517.85px;
    height: 517.85px;
    clip-path: polygon(100% 0, 100% 83%, 50% 100%, 0 83%, 0 0);
  }
}
main section.solution .headline ul {
  margin-bottom: 25px;
  padding-right: calc(50vw - 163px);
  padding-left: calc(50vw - 163px);
}
@media screen and (min-width: 1000px) {
  main section.solution .headline ul {
    position: relative;
    width: 914px;
    height: 239.35px;
    margin: 0 auto;
    padding-right: 0;
    padding-left: 0;
  }
}
main section.solution .headline ul li {
  position: relative;
  width: 288px;
  margin-bottom: 25px;
  padding: 12px 20px;
  background-color: #ffffff;
  font-size: 15px;
  line-height: 23px;
  border-radius: 10px;
}
main section.solution .headline ul li:nth-child(even) {
  margin-left: auto;
}
@media screen and (min-width: 1000px) {
  main section.solution .headline ul li {
    position: absolute;
    width: 343.06px;
    margin-bottom: 0;
    padding: 15px 25px;
    font-size: 17px;
    line-height: 28px;
  }
  main section.solution .headline ul li:nth-child(1) {
    bottom: 0;
    left: 0;
  }
  main section.solution .headline ul li:nth-child(2) {
    bottom: 0;
    right: 0;
  }
  main section.solution .headline ul li:nth-child(3) {
    top: 0;
    left: 84px;
  }
  main section.solution .headline ul li:nth-child(4) {
    top: 0;
    right: 84px;
  }
}
main section.solution .headline ul li:last-child {
  margin-bottom: 0;
}
main section.solution .headline ul li em {
  color: #98761C;
}
main section.solution .headline ul li:nth-child(even):before {
  content: "";
  position: absolute;
  bottom: -15px;
  right: 15px;
  background-image: url(../img/solution-even-arrow.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 16px;
  height: 16px;
}
main section.solution .headline ul li:nth-child(odd):before {
  content: "";
  position: absolute;
  bottom: -15px;
  left: 15px;
  background-image: url(../img/solution-odd-arrow.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 16px;
  height: 16px;
}
main section.solution .headline h2 {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  display: inline-block;
  margin: 0 auto;
  font-size: 23px;
  font-weight: 600;
  text-align: center;
  line-height: 36px;
  white-space: nowrap;
}
@media screen and (min-width: 1000px) {
  main section.solution .headline h2 {
    bottom: -20px;
    font-size: 30px;
    line-height: 47px;
  }
}
main section.solution .headline h2:before, main section.solution .headline h2:after {
  content: "";
  position: absolute;
  bottom: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
main section.solution .headline h2:before {
  bottom: -54px;
  left: 13px;
  background-image: url(../img/solution-illust1-sp.webp);
  width: 65.87px;
  height: 88.47px;
}
@media screen and (min-width: 1000px) {
  main section.solution .headline h2:before {
    bottom: -15px;
    left: -135px;
    background-image: url(../img/solution-illust1-pc.webp);
    width: 136px;
    height: 158px;
  }
}
main section.solution .headline h2:after {
  bottom: -59px;
  right: 0;
  background-image: url(../img/solution-illust2-sp.webp);
  width: 96.41px;
  height: 93.21px;
}
@media screen and (min-width: 1000px) {
  main section.solution .headline h2:after {
    bottom: -18px;
    right: -210px;
    background-image: url(../img/solution-illust2-pc.webp);
    width: 201px;
    height: 156px;
  }
}
main section.solution .solution-list {
  position: relative;
  top: -50px;
  z-index: -1;
  padding-top: 107px;
  padding-bottom: 62px;
  background-image: url(../img/solution-list-bg-sp.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list {
    top: -90px;
    padding-top: 150px;
    background-image: url(../img/solution-list-bg-pc.webp);
  }
}
main section.solution .solution-list ul {
  width: 100%;
  max-width: 375px;
  margin: 0 auto;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list ul {
    max-width: 1160px;
  }
}
main section.solution .solution-list ul li {
  position: relative;
  width: calc(100% - 35px);
  margin-bottom: 60px;
  padding: 40px 17px;
  background-color: #ffffff;
  box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.16);
  border-radius: 0 50px 50px 0;
}
main section.solution .solution-list ul li:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list ul li {
    display: grid;
    grid-template-columns: 467px 1fr;
    grid-template-rows: min-content 1fr;
    -moz-column-gap: 25px;
         column-gap: 25px;
    row-gap: 15px;
    width: calc(100% - 68px);
    padding: 42px 30px 40px;
  }
}
main section.solution .solution-list ul li:nth-child(even) {
  margin-left: auto;
  border-radius: 50px 0 0 50px;
}
main section.solution .solution-list ul li:nth-child(odd) .point-number {
  position: absolute;
  top: -20px;
  right: -10px;
  width: 111px;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list ul li:nth-child(odd) .point-number {
    top: -28px;
    right: -18px;
    width: 170px;
  }
}
main section.solution .solution-list ul li:nth-child(even) .point-number {
  position: absolute;
  top: -25px;
  left: -12px;
  width: 111px;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list ul li:nth-child(even) .point-number {
    top: -28px;
    left: -38px;
    width: 170px;
  }
}
main section.solution .solution-list ul li h3 {
  margin-bottom: 20px;
  font-size: 23px;
  font-weight: 600;
  text-align: center;
  color: #BEA564;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list ul li h3 {
    grid-column: 2/3;
    grid-row: 1/2;
    margin-bottom: 0;
    font-size: 35px;
  }
}
main section.solution .solution-list ul li .image {
  width: 100%;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list ul li .image {
    grid-column: 1/2;
    grid-row: 1/3;
  }
}
main section.solution .solution-list ul li p {
  margin-top: 20px;
  font-weight: 400;
  text-align: center;
  line-height: 28px;
}
@media screen and (min-width: 1000px) {
  main section.solution .solution-list ul li p {
    grid-column: 2/3;
    grid-row: 2/3;
    margin-top: 0;
    font-size: 20px;
    line-height: 38px;
  }
}
main section.solution .solution-list ul li p em {
  color: #FB6876;
}
main section.solution .solution-list ul li p small {
  font-size: 12px;
}
main div.splide {
  margin-top: -50px;
}
@media screen and (min-width: 1000px) {
  main div.splide {
    margin-top: -90px;
  }
}
main div.splide .splide__track .splide__list .splide__slide img {
  height: auto;
  width: 100%;
}
main div.video-area {
  margin-top: 30px;
  margin-bottom: 30px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
}
@media screen and (min-width: 1000px) {
  main div.video-area {
    width: 100%;
    max-width: 724px;
    margin: 40px auto;
    padding: 0;
  }
}
main div.video-area > p {
  margin-bottom: 8px;
  font-size: 15px;
  text-align: center;
  letter-spacing: 0.45px;
}
@media screen and (min-width: 1000px) {
  main div.video-area > p {
    font-size: 20px;
  }
}
main div.video-area .iframe-wrap {
  position: relative;
  height: 0;
  margin: 0 auto;
  padding-top: 50.25%;
  aspect-ratio: 16/9;
}
main div.video-area .iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

p.about-cestlavie {
  margin-bottom: 30px;
  padding-top: 12px;
  padding-bottom: 12px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 23px;
  color: #BEA564;
  background-color: #F8F4E7;
  outline-offset: -5px;
  outline: 1px solid #EAD9AE;
}
@media screen and (min-width: 1000px) {
  p.about-cestlavie {
    padding-top: 20px;
    padding-bottom: 20px;
    font-size: 20px;
  }
}

.cv-btn-wrap {
  text-align: center;
}
.cv-btn-wrap .cv-btn {
  display: inline-block;
  width: 276px;
  margin: 0 auto;
}
@media screen and (min-width: 1000px) {
  .cv-btn-wrap .cv-btn {
    width: 457px;
  }
}
.cv-btn-wrap .cv-btn img {
  width: 100%;
}

section.faq {
  margin-top: 35px;
  padding-top: 28px;
  padding-bottom: 44px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  background-color: #FEE8E3;
}
@media screen and (min-width: 1000px) {
  section.faq {
    padding-right: calc(50vw - 483.5px);
    padding-left: calc(50vw - 483.5px);
  }
}
section.faq h2 {
  margin-bottom: 24px;
  font-size: 20px;
  font-weight: 600;
  color: #FB6876;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  section.faq h2 {
    font-size: 30px;
  }
}
section.faq dl dt {
  position: relative;
  margin-top: 20px;
  padding: 15px 40px 15px 12px;
  font-size: 15px;
  font-weight: 400;
  background-color: #ffffff;
  border-radius: 5px;
  cursor: pointer;
  transition: 0.4s;
}
section.faq dl dt:first-child {
  margin-top: 0;
}
@media screen and (min-width: 1000px) {
  section.faq dl dt {
    font-size: 18px;
  }
}
section.faq dl dt:hover {
  opacity: 0.7;
}
section.faq dl dt:before, section.faq dl dt:after {
  content: "";
  position: absolute;
  right: 17px;
  top: 50%;
  width: 10px;
  height: 1px;
  background: #434952;
  transform: translateY(-50%);
}
section.faq dl dt:after {
  transform: translateY(-50%) rotate(90deg);
}
section.faq dl dt.is-open {
  background-color: #BEA564;
  border-radius: 5px 5px 0 0;
  color: #ffffff;
}
section.faq dl dt.is-open:before, section.faq dl dt.is-open:after {
  background: #ffffff;
}
section.faq dl dt.is-open:after {
  opacity: 0;
}
section.faq dl dd {
  display: none;
  padding: 15px 12px 15px 25px;
  font-size: 15px;
  line-height: 28px;
  background-color: #ffffff;
  border-radius: 0 0 5px 5px;
}
@media screen and (min-width: 1000px) {
  section.faq dl dd {
    font-size: 18px;
  }
}
section.faq dl dd:last-child {
  margin-bottom: 0;
}
section.faq dl dd a {
  text-decoration: underline;
}
section.faq dl dd span {
  font-size: 12px;
}
@media screen and (min-width: 1000px) {
  section.faq dl dd span {
    font-size: 18px;
  }
}
section.faq dl dd.is-open {
  display: block;
  margin-bottom: 20px;
}

footer .inner {
  padding-top: 30px;
  padding-bottom: 30px;
  padding-right: calc(50vw - 170px);
  padding-left: calc(50vw - 170px);
  background-color: #BFB089;
  color: #ffffff;
}
@media screen and (min-width: 1000px) {
  footer .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    -moz-column-gap: 105px;
         column-gap: 105px;
    padding-top: 52px;
    padding-bottom: 64px;
    padding-right: calc(50vw - 483.5px);
    padding-left: calc(50vw - 483.5px);
  }
}
footer .inner .text-area {
  text-align: center;
}
@media screen and (min-width: 1000px) {
  footer .inner .text-area {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-direction: column;
    flex: 1;
  }
}
footer .inner .text-area > img {
  width: 218.13px;
  margin-bottom: 30px;
}
@media screen and (min-width: 1000px) {
  footer .inner .text-area > img {
    width: 342.59px;
    margin-bottom: 51px;
  }
}
footer .inner .text-area .tel {
  display: inline-block;
  margin-bottom: 15px;
  font-size: 27px;
  font-weight: 400;
  border-bottom: 1px solid #ffffff;
}
@media screen and (min-width: 1000px) {
  footer .inner .text-area .tel {
    margin-bottom: 13px;
    font-size: 35px;
  }
}
footer .inner .text-area span {
  display: inline-block;
  margin-bottom: 30px;
  font-size: 13px;
}
@media screen and (min-width: 1000px) {
  footer .inner .text-area span {
    margin-bottom: 50px;
    font-size: 17px;
  }
}
footer .inner .text-area .cv-btn {
  display: inline-block;
  margin-bottom: 40px;
}
@media screen and (min-width: 1000px) {
  footer .inner .text-area .cv-btn {
    margin-bottom: 0;
  }
}
footer .inner .text-area .cv-btn img {
  width: 276px;
}
@media screen and (min-width: 1000px) {
  footer .inner .text-area .cv-btn img {
    width: 457px;
  }
}
@media screen and (min-width: 1000px) {
  footer .inner .map-area {
    width: 357px;
  }
}
footer .inner .map-area address {
  margin-bottom: 10px;
  font-size: 15px;
  text-align: center;
}
@media screen and (min-width: 1000px) {
  footer .inner .map-area address {
    margin-bottom: 20px;
    font-size: 18px;
    text-align: left;
  }
}
footer .inner .map-area .iframe-wrap {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}
@media screen and (min-width: 1000px) {
  footer .inner .map-area .iframe-wrap {
    padding-top: 80.25%;
  }
}
footer .inner .map-area .iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
footer .about-privacy-mark {
  padding-top: 22px;
  padding-bottom: 20px;
  font-size: 10px;
  text-align: center;
  letter-spacing: 0.045em;
}
@media screen and (min-width: 1000px) {
  footer .about-privacy-mark {
    padding-top: 25px;
    padding-bottom: 25px;
    font-size: 13px;
    line-height: 25px;
  }
}
footer > small {
  display: block;
  padding-top: 7px;
  padding-bottom: 7px;
  font-size: 8px;
  color: #ffffff;
  text-align: center;
  background-color: #67490B;
}
@media screen and (min-width: 1000px) {
  footer > small {
    padding-top: 9px;
    font-size: 10px;
  }
}