@charset "UTF-8";
main {
  padding-top: 130px;
}

section#lead {
  position: relative;
}
section#lead .image {
  flex-wrap: nowrap;
  width: 96%;
  height: 565px;
  margin: 0 auto;
}
section#lead h1 {
  position: absolute;
  top: 173px;
  left: 11.3%;
}

.navi {
  width: 90%;
  margin: 0 auto;
  line-height: 70px;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}
.navi span {
  margin: 10px;
}

@media screen and (max-width: 1280px) {
  main {
    padding-top: 110px;
  }
}
@media screen and (max-width: 900px) {
  main {
    padding-top: 80px;
  }
  section#lead .image {
    height: 450px;
  }
  section#lead h1 {
    top: 50%;
    left: 10%;
    transform: translateY(-50%);
    width: 50vw;
  }
  .navi {
    line-height: 50px;
  }
}
@media screen and (max-width: 540px) {
  main {
    padding-top: 62px;
  }
  section#lead .image {
    width: 100%;
    height: 300px;
  }
  section#lead h1 {
    position: absolute;
    top: 70px;
    left: 4%;
    width: 86%;
  }
  .navi {
    width: 90%;
    margin: 0 auto;
    line-height: 50px;
    font-size: 14px;
  }
  .navi a {
    font-size: 14px;
  }
}
/*==========================================================================
# section#web01
========================================================================== */
section#web01 {
  position: relative;
}
section#web01 .pc_img {
  position: absolute;
  right: 0.5vw;
  top: -20vw;
  width: 52.24vw;
  height: 30.4vw;
}
section#web01 .top_img {
  width: 76%;
  margin: 0 auto;
  align-items: center;
  gap: 5vw;
  margin-top: 1vw;
}
section#web01 .top_img > div {
  width: 14.7vw;
}
section#web01 .top_img > div:nth-child(2) {
  width: 12.71vw;
}
section#web01 .ttl {
  position: relative;
  margin-left: 7%;
  margin-top: 3vw;
}
section#web01 .ttl:before {
  content: "";
  background: url(../img/web01_ttl_bg.svg) center no-repeat;
  background-size: 100%;
  width: 54.95vw;
  height: 303px;
  display: block;
}
section#web01 .ttl > div {
  position: absolute;
  top: 50%;
  left: 9%;
  transform: translateY(-50%);
}
section#web01 .ttl > div h2 {
  font-size: 42px;
  font-weight: 700;
  border-bottom: solid 1px #707070;
  padding-bottom: 10px;
}
section#web01 .ttl > div p {
  font-size: 22px;
  margin-top: 21px;
  font-weight: 500;
}
section#web01 .box {
  margin-top: 100px;
  align-items: initial;
}
section#web01 .box .in {
  width: 50%;
}
section#web01 .box .in .top_image {
  position: relative;
  border-bottom: solid 1px #707070;
  margin: 0 auto;
  margin-bottom: 55px;
  margin-top: 29px;
  text-align: center;
  width: 80%;
}
section#web01 .box .in .top_image img {
  width: 326px;
  height: auto;
  margin: 0 auto;
}
section#web01 .box .in .item {
  width: 75%;
  margin: 0 auto;
}
section#web01 .box .in h3 {
  color: #fff;
  background: #626262;
  padding: 7px 0;
  padding-left: 15px;
  display: flex;
  align-items: center;
  border-radius: 5px;
  font-size: 28px;
  font-weight: 700;
}
section#web01 .box .in ul {
  width: 90%;
  margin: 40px auto 70px;
}
section#web01 .box .in ul li {
  font-size: 24px;
  margin-bottom: 20px;
  font-weight: 500;
}
section#web01 .box .in ul li h4 {
  font-size: 24px;
  font-weight: 700;
  border-bottom: solid 1px #707070;
  margin-bottom: 0.3em;
  padding-bottom: 0.3em;
}
section#web01 .box .in ul li span {
  font-size: 24px;
  font-weight: 500;
}
section#web01 .box .in ul li:last-child {
  margin: 0;
}
section#web01 .box .in p.link {
  width: 308px;
  height: 63px;
  border-radius: 63px;
  margin: 0 auto;
  background: #585757;
}
section#web01 .box .in p.link a {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: 700;
  color: #fff;
  position: relative;
}
section#web01 .box .in p.link a:after {
  content: "";
  background: url(../img/link_arrow_fff.svg) center no-repeat;
  background-size: 100%;
  width: 14px;
  height: 24px;
  display: block;
  margin-left: 30px;
}
section#web01 .box .in .item.i1 ul li {
  position: relative;
  padding-left: 61px;
}
section#web01 .box .in .item.i1 ul li::before {
  content: "";
  width: 38px;
  height: 31px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
section#web01 .box .in:nth-child(1) {
  background: #EBEBEB;
}
section#web01 .box .in:nth-child(1) .item.i1 ul li::before {
  background: url(../img/Web02_list_icon01.svg) center no-repeat;
  background-size: 100%;
}
section#web01 .box .in:nth-child(2) {
  background: #FFE0ED;
  padding-bottom: 137px;
}
section#web01 .box .in:nth-child(2) h3 {
  background: #FE0C71;
}
section#web01 .box .in:nth-child(2) .item.i1 ul li::before {
  background: url(../img/Web02_list_icon02.svg) center no-repeat;
  background-size: 100%;
}
section#web01 .box .in:nth-child(2) p.link {
  background: #FE0C71;
}

@media screen and (max-width: 1280px) {
  section#web01 .pc_img {
    right: 0;
    top: -120px;
    width: 51vw;
    height: 24.4vw;
  }
  section#web01 .top_img {
    width: 100%;
  }
  section#web01 .top_img > div {
    width: 21.9vw;
  }
  section#web01 .top_img > div:nth-child(2) {
    width: 19.1vw;
  }
  section#web01 .ttl {
    margin-left: 50px;
    width: calc(88% - 50px);
  }
  section#web01 .ttl:before {
    width: 62vw;
  }
  section#web01 .ttl > div {
    left: 5%;
  }
  section#web01 .ttl > div p {
    font-size: 18px;
  }
}
@media screen and (max-width: 900px) {
  section#web01 .pc_img {
    display: none;
  }
  section#web01 .top_img {
    display: none;
  }
  section#web01 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-top: 40px;
  }
  section#web01 .ttl::before {
    width: 100%;
    height: 26vw;
  }
  section#web01 .ttl > div h2 {
    font-size: 32px;
  }
  section#web01 .ttl > div p {
    font-size: 18px;
  }
  section#web01 .box {
    margin-top: 50px;
    flex-wrap: wrap;
  }
  section#web01 .box .in {
    width: 100%;
  }
  section#web01 .box .in .top_image {
    border: none;
    margin: 0 auto;
  }
  section#web01 .box .in .top_image img {
    width: 65%;
  }
  section#web01 .box .in h3 {
    font-size: 24px;
  }
  section#web01 .box .in .item {
    width: 85%;
    margin: 0 auto;
  }
  section#web01 .box .in ul li {
    font-size: 18px;
  }
  section#web01 .box .in ul {
    width: 95%;
  }
  section#web01 .box .in ul li h4 {
    font-size: 18px;
  }
  section#web01 .box .in ul li span {
    font-size: 18px;
  }
  section#web01 .box .in:nth-child(1) {
    padding-bottom: 70px;
  }
  section#web01 .box .in:nth-child(2) {
    padding-bottom: 70px;
  }
}
@media screen and (max-width: 540px) {
  section#web01 .pc_img {
    display: none;
  }
  section#web01 .top_img {
    display: none;
  }
  section#web01 .ttl {
    width: 90%;
    margin: 0 auto 30px;
  }
  section#web01 .ttl:before {
    width: 100%;
    height: 25.5vw;
  }
  section#web01 .ttl > div {
    left: 10px;
  }
  section#web01 .ttl > div h2 {
    font-size: 24px;
    font-weight: 900;
    padding-bottom: 5px;
  }
  section#web01 .ttl > div p {
    font-size: 14px;
    margin-top: 5px;
  }
  section#web01 .ttl > div p br {
    display: none;
  }
  section#web01 .box {
    margin-top: 30px;
  }
  section#web01 .box .in {
    width: 100%;
    padding-bottom: 60px;
  }
  section#web01 .box .in .top_image {
    border: none;
    margin: 0 auto;
  }
  section#web01 .box .in .top_image img {
    width: 278px;
    height: auto;
    margin: 0 auto;
  }
  section#web01 .box .in .item {
    width: 85%;
    margin: 0 auto;
  }
  section#web01 .box .in h3 {
    font-size: 18px;
  }
  section#web01 .box .in ul {
    width: 94%;
    margin: 25px auto;
  }
  section#web01 .box .in ul li {
    font-size: 16px;
  }
  section#web01 .box .in ul li h4 {
    font-size: 18px;
  }
  section#web01 .box .in ul li span {
    font-size: 16px;
  }
  section#web01 .box .in p.link {
    width: 70%;
    height: 49px;
  }
  section#web01 .box .in p.link a {
    font-size: 18px;
  }
  section#web01 .box .in .item.i1 ul li {
    padding-left: 56px;
  }
  section#web01 .box .in .item.i1 ul li::before {
    width: 26px;
    height: 21.5px;
  }
  section#web01 .box .in .item.i3 ul {
    margin: 25px auto 40px;
  }
  section#web01 .box .in:nth-child(2) {
    padding-bottom: 60px;
  }
}
/*==========================================================================
# section#web02
========================================================================== */
section#web02 {
  background: #928E8D;
  padding: 100px 0 138px;
}
section#web02 .ttl {
  position: relative;
  margin-left: 5.47vw;
  margin-bottom: 7.1vw;
}
section#web02 .ttl h2 {
  font-size: 42px;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 7.7vw;
  transform: translateY(-50%);
  color: #ffffff;
}
section#web02 .ttl::before {
  content: "";
  background: url(../img/web02_ttl_bg.svg) center no-repeat;
  background-size: 100%;
  width: 35.3vw;
  height: 303px;
  display: block;
}
section#web02 ul {
  display: flex;
  flex-wrap: wrap;
  width: 75%;
  margin: 0 auto;
  -moz-column-gap: 4.4%;
       column-gap: 4.4%;
  row-gap: 3vw;
}
section#web02 ul li {
  width: calc(30% - 50px);
  background: #fff;
  padding: 25px;
  border-radius: 15px;
  position: relative;
}
section#web02 ul li::after {
  content: "";
  width: 3.5vw;
  height: 5px;
  background: #ffffff;
  position: absolute;
  right: -3.5vw;
  top: calc(42px + 8.5vw);
}
section#web02 ul li .image {
  width: 100%;
  height: 9.85vw;
  position: relative;
  margin-bottom: 1.15vw;
}
section#web02 ul li .image img {
  border-radius: 13px;
}
section#web02 ul li .image h3 {
  position: absolute;
  z-index: 2;
  color: #ffffff;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 30px;
  font-weight: 700;
  width: 90%;
  text-align: center;
}
section#web02 ul li .image::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  border-radius: 13px;
}
section#web02 ul li p {
  font-size: 18px;
  font-weight: 500;
  width: 95%;
  margin: 0 auto;
}
section#web02 ul li:nth-of-type(3n)::after {
  content: none;
}

@media screen and (max-width: 1280px) {
  section#web02 .ttl {
    margin-left: 50px;
    width: calc(88% - 50px);
    margin-bottom: 100px;
  }
  section#web02 .ttl::before {
    width: 39vw;
  }
  section#web02 ul {
    width: 83%;
  }
  section#web02 ul li .image {
    width: 100%;
    height: 164px;
  }
  section#web02 ul li p {
    font-size: 16px;
  }
  section#web02 ul li::after {
    width: 4vw;
    right: -4vw;
    top: 184px;
    height: 4px;
  }
}
@media screen and (max-width: 900px) {
  section#web02 {
    padding: 70px 0;
  }
  section#web02 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 50px;
  }
  section#web02 .ttl:before {
    width: 59vw;
    height: 26vw;
    margin: 0 auto;
  }
  section#web02 .ttl h2 {
    font-size: 32px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  section#web02 ul {
    width: 85%;
    -moz-column-gap: initial;
         column-gap: initial;
    justify-content: space-between;
  }
  section#web02 ul li {
    width: calc(48% - 50px);
  }
  section#web02 ul li .image {
    height: 145px;
  }
  section#web02 ul li p {
    font-size: 18px;
  }
  section#web02 ul li:nth-child(2n+1):after {
    content: "";
    top: 165px;
  }
  section#web02 ul li:nth-child(2n):after {
    content: none;
  }
}
@media screen and (max-width: 540px) {
  section#web02 {
    padding: 50px 0;
  }
  section#web02 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 40px;
  }
  section#web02 .ttl::before {
    width: 59vw;
    height: 25.5vw;
    margin: 0 auto;
  }
  section#web02 .ttl h2 {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 26px;
    width: 90%;
    text-align: center;
  }
  section#web02 ul {
    width: 80%;
    row-gap: 20px;
  }
  section#web02 ul li {
    width: calc(100% - 60px);
    padding: 30px;
  }
  section#web02 ul li::after {
    content: "";
    width: 5px;
    height: 20px;
    right: initial;
    top: initial;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
  }
  section#web02 ul li .image {
    width: 100%;
    height: 150px;
    margin-bottom: 15px;
  }
  section#web02 ul li .image h3 {
    font-size: 24px;
    width: 90%;
    text-align: center;
  }
  section#web02 ul li p {
    width: 100%;
    font-size: 16px;
  }
  section#web02 ul li:nth-child(2n+1):after {
    content: "";
    top: initial;
  }
  section#web02 ul li:nth-child(2n):after {
    content: "";
    top: initial;
  }
  section#web02 ul li:nth-of-type(3n)::after {
    content: "";
  }
  section#web02 ul li:last-child::after {
    content: none;
  }
}
/*==========================================================================
# section#web03
========================================================================== */
section#web03 {
  padding-top: 110px;
  position: relative;
}
section#web03:before {
  content: "";
  background: url(../img/web03_side.svg) center no-repeat;
  background-size: 100%;
  width: 16vw;
  height: 63.5vw;
  position: absolute;
  right: 0;
  top: 60%;
  transform: translateY(-50%);
  z-index: -1;
}
section#web03 .ttl {
  position: relative;
  margin-left: 7%;
  margin-bottom: 75px;
}
section#web03 .ttl:before {
  content: "";
  background: url(../img/web03_ttl_bg.svg) center no-repeat;
  background-size: 100%;
  width: 52.77vw;
  height: 14.4vw;
  display: block;
}
section#web03 .ttl > div {
  position: absolute;
  top: 50%;
  left: 9%;
  transform: translateY(-50%);
}
section#web03 .ttl > div h2 {
  font-size: 42px;
  font-weight: 700;
  border-bottom: solid 1px #707070;
  padding-bottom: 10px;
  display: flex;
  align-items: center;
}
section#web03 .ttl > div h2:before {
  content: "";
  background: url(../img/web03_ttl_icon.svg) center no-repeat;
  background-size: 100%;
  width: 58px;
  height: 58px;
  display: inline-block;
  margin: 0 18.5px;
}
section#web03 .ttl > div p {
  font-size: 22px;
  margin-top: 21px;
  font-weight: 500;
}
section#web03 ul {
  width: 68.5%;
  margin: 0 auto;
  margin-bottom: 170px;
}
section#web03 ul li h3 {
  font-size: 38px;
  font-weight: 700;
  border-bottom: solid 1px #707070;
  padding-bottom: 15px;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}
section#web03 ul li h3:before {
  content: "";
  margin-right: 25px;
  display: inline-block;
}
section#web03 ul li p {
  font-size: 20px;
  font-weight: 500;
}
section#web03 ul li:nth-of-type(1) h3:before {
  background: url(../img/web03_list_icon01.svg) center no-repeat;
  background-size: 100%;
  width: 40px;
  height: 49px;
}
section#web03 ul li:nth-of-type(2) h3:before {
  background: url(../img/web03_list_icon02.svg) center no-repeat;
  background-size: 100%;
  width: 42px;
  height: 40px;
}
section#web03 ul li:nth-of-type(3) h3:before {
  background: url(../img/web03_list_icon03.svg) center no-repeat;
  background-size: 100%;
  width: 30px;
  height: 42px;
}
section#web03 ul li:nth-of-type(4) h3:before {
  background: url(../img/web03_list_icon04.svg) center no-repeat;
  background-size: 100%;
  width: 40px;
  height: 49px;
}
section#web03 ul li:nth-of-type(5) h3:before {
  background: url(../img/web03_list_icon05.svg) center no-repeat;
  background-size: 100%;
  width: 36px;
  height: 36px;
}
section#web03 ul li:nth-of-type(n+2) {
  margin-top: 75px;
}

@media screen and (max-width: 1280px) {
  section#web03 .ttl {
    margin-left: 50px;
    width: calc(88% - 50px);
  }
  section#web03 .ttl:before {
    width: 100%;
    height: 23.4vw;
  }
  section#web03 .ttl > div {
    left: 7%;
  }
  section#web03 .ttl > div h2 {
    font-size: 42px;
  }
  section#web03 .ttl > div p br {
    display: none;
  }
  section#web03 ul {
    width: 64%;
  }
  section#web03 ul li p {
    font-size: 18px;
  }
}
@media screen and (max-width: 900px) {
  section#web03 {
    padding-top: 70px;
  }
  section#web03 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 50px;
  }
  section#web03 .ttl:before {
    width: 100%;
    height: 25.4vw;
  }
  section#web03 .ttl > div {
    left: 5%;
  }
  section#web03 .ttl > div h2 {
    font-size: 32px;
  }
  section#web03 .ttl > div p {
    font-size: 18px;
  }
  section#web03 ul {
    width: 85%;
    margin-bottom: 70px;
  }
  section#web03 ul li h3 {
    font-size: 24px;
  }
}
@media screen and (max-width: 540px) {
  section#web03 {
    padding: 30px 0;
  }
  section#web03:before {
    top: 40vw;
    transform: initial;
    width: 26vw;
    height: 108.5vw;
  }
  section#web03::after {
    content: "";
    background: url(../img/web03_side.svg) center no-repeat;
    background-size: 100%;
    width: 26vw;
    height: 108.5vw;
    position: absolute;
    right: 0;
    top: 155vw;
    transform: initial;
    z-index: -1;
  }
  section#web03 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 30px;
  }
  section#web03 .ttl::before {
    width: 90vw;
    height: 26.2vw;
    margin: 0 auto;
  }
  section#web03 .ttl > div {
    width: calc(100% - 20px);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  section#web03 .ttl > div h2 {
    font-size: 26px;
    padding-bottom: 5px;
  }
  section#web03 .ttl > div h2::before {
    width: 32px;
    height: 32px;
    margin: 0 10px;
    margin-left: 5px;
  }
  section#web03 .ttl > div p {
    font-size: 14px;
    margin-top: 6px;
  }
  section#web03 .ttl > div p br {
    display: none;
  }
  section#web03 ul {
    width: 80%;
    margin-bottom: 30px;
  }
  section#web03 ul li h3 {
    font-size: 20px;
    margin-bottom: 8px;
    padding-bottom: 8px;
  }
  section#web03 ul li h3::before {
    margin-right: 10px;
  }
  section#web03 ul li p {
    font-size: 14px;
  }
  section#web03 ul li:nth-of-type(1) h3:before {
    width: 26px;
    height: 32px;
  }
  section#web03 ul li:nth-of-type(2) h3:before {
    width: 26px;
    height: 24px;
  }
  section#web03 ul li:nth-of-type(3) h3:before {
    width: 24px;
    height: 29px;
  }
  section#web03 ul li:nth-of-type(4) h3:before {
    width: 30px;
    height: 30px;
  }
  section#web03 ul li:nth-of-type(n+2) {
    margin-top: 25px;
  }
}
/*==========================================================================
# section#web04
========================================================================== */
section#web04 {
  width: 96%;
  background: #6a6a6a;
  margin: 0 auto;
  padding: 100px 0 120px;
  border-radius: 40px;
}
section#web04 .ttl {
  position: relative;
  margin-left: 7%;
  margin-bottom: 80px;
}
section#web04 .ttl:before {
  content: "";
  background: url(../img/web04_ttl_bg.svg) center no-repeat;
  background-size: 100%;
  width: 45.06vw;
  height: 18.65vw;
  display: block;
}
section#web04 .ttl > div {
  position: absolute;
  top: 50%;
  left: 9%;
  transform: translateY(-50%);
}
section#web04 .ttl > div h2 {
  font-size: 42px;
  font-weight: 700;
  border-bottom: solid 1px #ffffff;
  padding-bottom: 10px;
  display: flex;
  align-items: center;
  color: #fff500;
}
section#web04 .ttl > div h2:before {
  content: "";
  background: url(../img/web03_ttl_icon.svg) center no-repeat;
  background-size: 100%;
  width: 58px;
  height: 58px;
  display: inline-block;
  margin: 0 18.5px;
}
section#web04 .ttl > div p {
  font-size: 22px;
  margin-top: 21px;
  font-weight: 500;
  color: #ffffff;
}
section#web04 .box {
  width: calc(71.5% - 60px);
  padding: 30px;
  margin: 0 auto;
  background: white;
  border-radius: 25px;
}

@media screen and (max-width: 1280px) {
  section#web04 .ttl {
    margin-left: 5%;
    width: calc(88% - 50px);
  }
  section#web04 .ttl:before {
    width: 52.75vw;
    height: 22.65vw;
  }
  section#web04 .ttl > div {
    left: 5%;
  }
  section#web04 .box {
    width: calc(86% - 60px);
  }
}
@media screen and (max-width: 900px) {
  section#web04 {
    width: 100%;
    border-radius: 0;
    padding: 70px 0;
  }
  section#web04 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 50px;
  }
  section#web04 .ttl:before {
    width: 70vw;
    height: 29.65vw;
    margin: 0 auto;
  }
  section#web04 .ttl > div h2 {
    font-size: 32px;
  }
  section#web04 .ttl > div p {
    font-size: 18px;
  }
  section#web04 .box {
    width: calc(85% - 60px);
  }
  section#web04 .wq-Form .wq-Option {
    width: 49%;
  }
}
@media screen and (max-width: 540px) {
  section#web04 {
    width: 100%;
    border-radius: 0;
    padding: 40px 0;
  }
  section#web04 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 30px;
  }
  section#web04 .ttl::before {
    width: 65vw;
    height: 28.2vw;
    margin: 0 auto;
  }
  section#web04 .ttl > div {
    width: calc(90% - 20px);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  section#web04 .ttl > div h2 {
    font-size: 26px;
    padding-bottom: 5px;
  }
  section#web04 .ttl > div h2::before {
    width: 32px;
    height: 32px;
    margin: 0 10px;
    margin-left: 5px;
  }
  section#web04 .ttl > div p {
    font-size: 14px;
    margin-top: 6px;
  }
  section#web04 .ttl > div p br {
    display: none;
  }
  section#web04 .box {
    width: calc(90% - 40px);
    padding: 20px;
    border-radius: 10px;
  }
}
section#web04 .wq-Form .wq-HNavigator > .wq--items > :not(:last-child) {
  margin-bottom: 40px;
}

section#web04 .wq-Form .wq-Quantity > .wq--head, section#web04 .wq-Form .wq-Selector > .wq--head, section#web04 .wq-Form .wq-Slider > .wq--head {
  font-weight: 700;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 22px;
  padding: 0;
  background: transparent;
  border: none;
  margin-bottom: 20px;
}

section#web04 .wq-Form .wq-Selector > .wq--body {
  overflow: initial;
  flex-wrap: wrap;
  gap: 1.5vw 2%;
}

section#web04 .wq-Form .wq-Option > .wq--label {
  padding: 20px;
  padding-bottom: 40px;
}

section#web04 .wq-Form .wq-Option > .wq-type-checkbox + label:after {
  color: hsl(0deg, 0%, 83.51%);
}

section#web04 .wq-Form .wq-Option > .wq-type-checkbox:checked + label:after {
  -webkit-animation: spin 0.3s;
          animation: spin 0.3s;
  color: #d9613d;
  transform: scale(1.2);
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--media {
  flex: 0 0 auto;
  justify-content: center;
  margin-bottom: 10px;
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--name {
  font-size: 22px;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--note {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-size: 16px;
  margin-top: 10px;
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--note p {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 14px;
  font-weight: 400;
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--note p span {
  display: block;
  font-size: 16px;
  font-weight: 500;
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--note p:nth-child(n+2) {
  margin: 0;
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--prices {
  padding-top: 15px;
}

section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--prices > .wq--price {
  font-size: 22px;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
}

section#web04 .wq-Form .wq-Quantity, section#web04 .wq-Form .wq-Selector, .wq-Form .wq-Slider {
  border: none;
  padding: 0 10px;
  padding-bottom: 10px;
}

section#web04 .wq-Form .wq-Option:hover {
  background-color: rgba(217, 97, 61, 0.25);
}

section#web04 .wq-Form .wq-Option > .wq--select:not(:disabled):hover + .wq--label {
  background-color: rgba(217, 97, 61, 0.25);
}

section#web04 .wq-Form .wq-Option > .wq--input:checked + .wq--label, section#web04 .wq-Form .wq-Option > .wq--select.wq-is-selected + .wq--label {
  background: rgba(217, 97, 61, 0.25);
}

section#web04 .wq-Form #wq-selector-detail-3 .wq-Option > .wq--label {
  padding-top: 40px;
}

section#web04 .wq-Form #wq-selector-detail-3 .wq-Option > .wq--label > .wq--media {
  display: none;
}

.wq-Form .wq-Monitor > .wq--entries > .wq--entry {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}

section#web04 .wq-Form .wq-Monitor > .wq--entries > .wq--entry.wq-for-header {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}

section#web04 .wq-Form .wq-Monitor > .wq--footer > .wq--entry > .wq--prop.wq-for-name {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}

section#web04 .wq-Form .wq-Monitor > .wq--footer > .wq--entry > .wq--prop.wq-for-value {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}

section#web04 .wq-Form .wq-Control {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}

section#web04 .wq-Form .wq-Option {
  width: 48%;
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.4901960784);
}

section#web04 .wq-Form .wq-Monitor {
  padding: 10px;
}

section#web04 .wq-Form .wq-Attributes {
  padding: 10px;
}

#wq-option-detail-3-125-wrapper > .wq--label > .wq--main > .wq--prices:after {
  content: "〜";
  font-size: 22px;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  color: #eb4266;
}

@media screen and (min-width: 782.001px) {
  section#web04 .wq-Form .wq-Option {
    width: 32%;
  }
}
@media screen and (max-width: 900px) {
  section#web04 .wq-Form .wq-Option {
    width: 48%;
  }
  section#web04 .wq-Form .wq-Selector > .wq--body {
    gap: 3vw 4%;
  }
}
@media screen and (max-width: 540px) {
  section#web04 .wq-Form .wq-Selector > .wq--body {
    gap: 0;
    row-gap: 25px;
    justify-content: space-between;
  }
  section#web04 .wq-Form .wq-Option {
    width: 100%;
  }
  section#web04 .wq-Form .wq-Option > .wq--label {
    padding: 20px;
    padding-bottom: 20px;
  }
  section#web04 .wq-Form .wq-Image.wq-belongs-option.wq-belongs-hnavigator {
    height: auto;
    width: 70%;
  }
  section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--name {
    font-size: 20px;
  }
  section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--note {
    text-align: start;
    margin-top: 5px;
  }
  section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--note br {
    display: none;
  }
  section#web04 .wq-Form .wq-Option > .wq--label > .wq--main > .wq--prices > .wq--price {
    font-weight: 700;
    padding-top: 10px;
  }
  #wq-option-detail-3-125-wrapper > .wq--label > .wq--main > .wq--prices:after {
    font-weight: 700;
  }
  section#web04 .wq-Form div#wq-selector-detail-1 .wq-Option > .wq--label > .wq--main > .wq--note {
    text-align: center;
  }
  section#web04 .wq-Form #wq-selector-detail-3 .wq-Option > .wq--label {
    padding-top: 15px;
  }
}
/*==========================================================================
# section#web05
========================================================================== */
section#web05 {
  padding-top: 110px;
}
section#web05 .ttl {
  position: relative;
  margin-left: 7%;
  margin-bottom: 40px;
}
section#web05 .ttl:before {
  content: "";
  background: url(../img/web05_ttl_bg.svg) center no-repeat;
  background-size: 100%;
  width: 52.77vw;
  height: 14.4vw;
  display: block;
}
section#web05 .ttl > div {
  position: absolute;
  top: 50%;
  left: 9%;
  transform: translateY(-50%);
}
section#web05 .ttl > div h2 {
  font-size: 42px;
  font-weight: 700;
  border-bottom: solid 1px #707070;
  padding-bottom: 10px;
  display: flex;
  align-items: center;
}
section#web05 .ttl > div h2:before {
  content: "";
  background: url(../img/web03_ttl_icon.svg) center no-repeat;
  background-size: 100%;
  width: 58px;
  height: 58px;
  display: inline-block;
  margin: 0 18.5px;
}
section#web05 .ttl > div p {
  font-size: 22px;
  margin-top: 21px;
  font-weight: 500;
}

.s_02 {
  background: #FFFFFF;
  margin-top: 5vw;
  width: 69%;
  margin: 0 auto;
}

.s_02 .accordion_one {
  width: 100%;
  margin: 0 auto;
  margin-bottom: 10px;
}

.s_02 .accordion_one .accordion_header {
  font-size: 24px;
  line-height: 1.4em;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  padding: 16px 110px;
  text-align: start;
  position: relative;
  z-index: 1;
  cursor: pointer;
  transition-duration: 0.2s;
  border-bottom: 3px solid #191919;
}

.s_02 .accordion_one .accordion_header span {
  position: absolute;
  left: 0;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.4em;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
  transform: translateY(-50%);
  top: 50%;
  color: #f36c00;
}

.s_02 .accordion_one .accordion_header .i_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 1vw;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  box-sizing: border-box;
  transform-origin: center center;
  transition-duration: 0.2s;
}

.s_02 .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 24px;
  height: 24px;
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.s_02 .accordion_one .accordion_header .i_box .one_i:before, .s_02 .accordion_one .accordion_header .i_box .one_i:after {
  display: flex;
  content: "";
  background-color: #901d90;
  border-radius: 10px;
  width: 24px;
  height: 4px;
  position: absolute;
  top: 10px;
  left: 0;
  transform: rotate(0deg);
  transform-origin: center center;
}

.s_02 .accordion_one .accordion_header .i_box .one_i:before {
  width: 4px;
  height: 24px;
  top: 0;
  left: 10px;
}

.s_02 .accordion_one .accordion_header.open .i_box {
  transform: rotate(-360deg);
}

.s_02 .accordion_one .accordion_header.open .i_box .one_i:before {
  transform: rotate(135deg);
}

.s_02 .accordion_one .accordion_header.open .i_box .one_i:after {
  transform: rotate(-45deg);
}

.s_02 .accordion_one .accordion_inner {
  display: none;
  padding: 16px 110px 16px;
  box-sizing: border-box;
  position: relative;
}

.s_02 .accordion_one .accordion_inner .box_one {
  display: flex;
}

.s_02 .accordion_one .accordion_inner .box_one p.answer {
  font-size: 36px;
  font-weight: 700;
  line-height: 1.4em;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
  position: absolute;
  top: 16px;
  left: 0;
  color: #24b324;
  line-height: 1;
}

.s_02 .accordion_one .accordion_inner .box_one p.txt_a_ac {
  margin: 0;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.4em;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
}

@media screen and (max-width: 1280px) {
  section#web05 .ttl {
    width: calc(88% - 50px);
    margin-left: 50px;
    margin-bottom: 60px;
  }
  section#web05 .ttl:before {
    width: 100%;
    height: 22.4vw;
  }
  section#web05 .ttl > div {
    left: 5%;
  }
  section#web05 .ttl > div p br {
    display: none;
  }
  .s_02 {
    width: 83%;
  }
}
@media screen and (max-width: 900px) {
  section#web05 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 50px;
  }
  section#web05 .ttl::before {
    height: 25.4vw;
  }
  section#web05 .ttl > div h2 {
    font-size: 32px;
  }
  section#web05 .ttl > div p {
    font-size: 18px;
  }
  .s_02 {
    width: 85%;
  }
  .s_02 .accordion_one .accordion_header {
    padding: 16px 70px;
  }
  .s_02 .accordion_one .accordion_inner {
    padding: 16px 70px 16px;
  }
}
@media screen and (max-width: 540px) {
  section#web05 {
    width: 100%;
    border-radius: 0;
    padding: 40px 0 0;
  }
  section#web05 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 30px;
  }
  section#web05 .ttl:before {
    width: 100%;
    height: 24.2vw;
  }
  section#web05 .ttl > div {
    width: calc(100% - 20px);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  section#web05 .ttl > div h2 {
    font-size: 26px;
    padding-bottom: 5px;
  }
  section#web05 .ttl > div h2::before {
    width: 32px;
    height: 32px;
    margin: 0 10px;
    margin-left: 5px;
  }
  section#web05 .ttl > div p {
    font-size: 14px;
    margin-top: 6px;
  }
  section#web05 .ttl > div p br {
    display: none;
  }
  .s_02 {
    width: 85%;
    margin: 0 auto;
  }
  .s_02 .accordion_one .accordion_header {
    padding: 10px 40px;
    font-size: 16px;
  }
  .s_02 .accordion_one .accordion_header span {
    font-size: 24px;
  }
  .s_02 .accordion_one .accordion_inner {
    padding: 10px 40px 10px;
  }
  .s_02 .accordion_one .accordion_inner .box_one p.answer {
    font-size: 24px;
  }
  .s_02 .accordion_one .accordion_inner .box_one p.txt_a_ac {
    font-size: 16px;
  }
}
/*==========================================================================
# section#web06
========================================================================== */
section#web06 {
  padding-top: 110px;
}
section#web06 .ttl {
  position: relative;
  margin-left: 7%;
  margin-bottom: 40px;
}
section#web06 .ttl:before {
  content: "";
  background: url(../img/web06_ttl_bg.svg) center no-repeat;
  background-size: 100%;
  width: 48.7vw;
  height: 15.84vw;
  display: block;
}
section#web06 .ttl > div {
  position: absolute;
  top: 50%;
  left: 9%;
  transform: translateY(-50%);
}
section#web06 .ttl > div h2 {
  font-size: 42px;
  font-weight: 700;
  border-bottom: solid 1px #707070;
  padding-bottom: 10px;
  display: flex;
  align-items: center;
}
section#web06 .ttl > div h2:before {
  content: "";
  background: url(../img/web03_ttl_icon.svg) center no-repeat;
  background-size: 100%;
  width: 58px;
  height: 58px;
  display: inline-block;
  margin: 0 18.5px;
}
section#web06 .ttl > div p {
  font-size: 22px;
  margin-top: 21px;
  font-weight: 500;
}
section#web06 .box {
  width: 80%;
  margin: 0 auto;
}
section#web06 .box ul {
  gap: 60px 20px;
  flex-wrap: wrap;
}
section#web06 .box ul li {
  width: calc(33.333% - 13.334px);
}
section#web06 .box ul li a .image {
  width: 96%;
  margin: 0 auto;
}
section#web06 .box ul li a .cat {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin: 35px 0 20px;
}
section#web06 .box ul li a .cat span {
  font-size: 20px;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New";
  padding: 7px 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background: rgb(88, 87, 87);
}
section#web06 .box ul li a .cat span:nth-child(2) {
  background: rgb(0, 0, 0);
}
section#web06 .box ul li a p {
  font-size: 22px;
  font-weight: 600;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New";
  margin-bottom: 10px;
}
section#web06 .box ul li a p span {
  font-weight: 600;
  font-family: "Noto Sans JP", "Zen Kaku Gothic New";
}
section#web06 .box ul li a p.link {
  margin: 0;
  font-size: 20px;
  padding: 8px 25px;
  background: #ea582e;
  display: flex;
  align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 50px;
  color: #ffffff;
  margin-top: 30px;
}
section#web06 .box ul li a p.link:after {
  content: "▶︎";
  color: #ffffff;
  font-size: 16px;
  margin-left: 15px;
}
section#web06 .box p.link {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-top: 80px;
}
section#web06 .box p.link a {
  font-family: "Noto Sans JP", "Zen Kaku Gothic New", sans-serif;
  font-size: 20px;
  font-weight: 700;
  display: flex;
  align-items: center;
}
section#web06 .box p.link a:after {
  content: "";
  background: url(../img/link_icon.svg) center no-repeat;
  background-size: 100%;
  height: 41px;
  width: 41px;
  margin-left: 15px;
  display: inline-block;
}

@media screen and (max-width: 1280px) {
  section#web06 .ttl {
    width: calc(88% - 50px);
    margin-left: 50px;
    margin-bottom: 60px;
  }
  section#web06 .ttl > div {
    left: 5%;
  }
  section#web06 .box {
    width: 90%;
  }
  section#web06 .box ul li a p {
    font-size: 16px;
  }
}
@media screen and (max-width: 900px) {
  section#web06 {
    padding-top: 70px;
  }
  section#web06 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 50px;
  }
  section#web06 .ttl::before {
    width: 70vw;
    height: 23.84vw;
  }
  section#web06 .ttl > div h2 {
    font-size: 32px;
  }
  section#web06 .ttl > div p {
    font-size: 18px;
  }
  section#web06 .box {
    width: 85%;
  }
  section#web06 .box ul li {
    width: 48%;
  }
}
@media screen and (max-width: 540px) {
  section#web06 {
    width: 100%;
    border-radius: 0;
    padding: 40px 0 0;
  }
  section#web06 .ttl {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 30px;
  }
  section#web06 .ttl:before {
    width: 100%;
    height: 30.2vw;
  }
  section#web06 .ttl > div {
    width: calc(90% - 20px);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  section#web06 .ttl > div h2 {
    font-size: 26px;
    padding-bottom: 5px;
  }
  section#web06 .ttl > div h2::before {
    width: 32px;
    height: 32px;
    margin: 0 10px;
    margin-left: 5px;
  }
  section#web06 .ttl > div p {
    font-size: 14px;
    margin-top: 6px;
  }
  section#web06 .ttl > div p br {
    display: none;
  }
  section#web06 .box {
    width: 90%;
  }
  section#web06 .box > p.link {
    margin-top: 40px;
  }
  section#web06 .box > p.link a {
    font-size: 16px;
  }
  section#web06 .box > p.link a:after {
    height: 30px;
    width: 30px;
  }
  section#web06 .box ul {
    display: flex;
    gap: 40px 20px;
    flex-wrap: wrap;
  }
  section#web06 .box ul li {
    width: 100%;
  }
  section#web06 .box ul li::after {
    content: "";
    background: #EEEEEE;
    width: 100%;
    height: 1px;
    display: block;
    margin-top: 40px;
  }
  section#web06 .box ul li a .cat {
    display: flex;
    gap: 15px;
    margin: 20px auto;
    justify-content: center;
  }
  section#web06 .box ul li a .cat span {
    font-size: 14px;
    padding: 5px 20px 5px 20px;
  }
  section#web06 .box ul li a p.name {
    margin-bottom: 20px;
    text-align: center;
  }
  section#web06 .box ul li a p.name span {
    display: none;
  }
  section#web06 .box ul li a .un {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    gap: 0px 20px;
  }
  section#web06 .box ul li a .un p {
    font-size: 14px;
  }
  section#web06 .box ul li a p.link {
    margin: 0 auto;
    margin-top: 35px;
  }
}
/*# sourceMappingURL=top.css.map */