body {
  overflow-x: hidden;
  margin: 0;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #363033;
}

main h1 {
  display: inline-block;
  /* 背景が文字幅に収まる */
  background-color: #fff4f4;
  /* 普通の背景色 */
  padding: 0.8em 1em;
  /* 余白 */
  position: relative;
  /* 擬似要素用に基準にする */
  font-weight: bold;
  color: #DA238B;
  width: 12em;
  border-radius: 25px;
  font-size: 3.2em;
}

main h1::after {
  content: "";
  position: absolute;
  top: -11px;
  /* 縦に少しずらす */
  left: -18px;
  /* 横に少しずらす */
  width: 100%;
  height: 100%;
  border: 0.2vw solid #333;
  /* ボーダー色 */
  z-index: 1;
  /* 背景の下に置く */
  border-radius: 25px;
}

main h3 {
  font-size: 2.75vw;
}

main .top {
  text-align: center;
  margin: 0;
  margin-top: 3em;
}

main .content1 {
  margin-top: 5vw;
}

main .content1-title {
  display: flex;
  align-items: center;
}

main .line1 {
  height: 0.2vw;
  background-color: #DA238B;
  flex: none;
  width: 5%;
  margin-right: 1.5rem;
}

main .line2 {
  height: 0.2vw;
  background-color: #DA238B;
  flex: none;
  width: 45%;
  margin-left: 1.5rem;
}

main .content1-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 4em;
}

main .outer {
  display: inline-block;
  padding: 2.2em 2em;
  background-color: rgba(253, 225, 225, 0.5);
  border-radius: 50px;
  width: 100%;
}

main .content1-text {
  font-size: 1.85vw;
  background-color: white;
  padding: 2.5em 5em;
  padding-bottom: 1em;
  padding-right: 0em;
  border-radius: 50px;
}

main .content1-text p {
  margin: 0;
  min-width: 8.5em;
}

main .content1-text p+p {
  margin-top: 1em;
}

main .item img {
  height: 2em;
  width: 2em;
}

main .content1-text .item {
  display: flex;
  gap: 3em;
  margin-bottom: 1.5em;
}

main .content1-text .icon2 {
  padding-top: 0.3em;
  margin-right: 2em;
  height: 0.8em;
  width: 1.5em;
}

main .content2-text .icon2 {
  padding-top: 0.3em;
  margin-right: 2em;
  height: 0.8em;
  width: 1.5em;
}

main .content2-button {
  display: flex;
  align-items: center;
  background-color: rgba(231, 231, 231, 0.3);
  border-radius: 25px;
  height: 3.5em;
  font-size: 1.67vw;
  width: 94%;
  margin-left: 3%;
  margin-top: 1em;
  margin-bottom: 2em;
  color: #000;
}

main .content2-button div p {
  padding: 0 4.2em;
  padding: 0 7vw;
}

main .content2-button div+div p {
  border-left: solid 2px rgba(29, 29, 29, 0.4);
}

main .outer2 {
  display: inline-block;
  padding: 1.8em 2em;
  background-color: rgba(253, 225, 225, 0.5);
  border-radius: 50px;
  width: 100%;
}

main .content2-text {
  font-size: 1.85vw;
  background-color: white;
  padding: 1.5em 8.5em;
  padding-right: 0em;
  border-radius: 50px;
  padding-bottom: 0.1em;
  color: #000;
}

main .content2-text p {
  margin: 0;
  min-width: 14em;
}

main .content2-text p+p {
  margin-top: 1em;
}

main .content2-text .icon2 {
  margin-right: 3.5em;
}

main .content2-text .item {
  display: flex;
  gap: 3em;
  margin-bottom: 0.8em;
}

main .content3-text {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  font-size: 1.5vw;
  background-color: white;
  padding-right: 0em;
  border-radius: 100px;
  padding-bottom: 0.1em;
  height: 100%;
}

main h4 {
  margin: 0;
  font-size: 1.1em;
}

main .content3-text p {
  margin: 0;
}

main .outer31 {
  display: inline-block;
  padding: 1.2em 1.2em;
  background-color: rgba(255, 0, 0, 0.05);
  border-radius: 100px;
  width: 29.5%;
  width: 27%;
  height: 28vw;
}

main .outer32 {
  display: inline-block;
  padding: 1.2em 1.2em;
  background-color: rgba(253, 225, 225, 0.2);
  border-radius: 100px;
  width: 29.5%;
  width: 28%;
  height: 28vw;
}

main .outer33 {
  display: inline-block;
  padding: 1.2em 1.2em;
  background-color: rgba(214, 0, 111, 0.05);
  border-radius: 100px;
  width: 29.5%;
  width: 28%;
  height: 28vw;
}

main .content3-warp {
  display: flex;
  justify-content: space-evenly;
  justify-self: center;
  width: 93%;
  width: 100%;
  margin-top: 5em;
  margin-top: 0vw;
}

main .content4-wrap {
  margin: 0 4em;
}

main .outer4 {
  display: inline-block;
  padding: 1.5em 2em;
  background-color: rgba(253, 225, 225, 0.5);
  border-radius: 50px;
  width: 100%;
}

main .content4-text {
  font-size: 1.85vw;
  background-color: white;
  padding: 4.5em 2em;
  padding-bottom: 1em;
  padding-right: 0em;
  border-radius: 50px;
}

main .content4-text .item {
  display: flex;
  gap: 3em;
  margin-bottom: 2em;
}

main .content4-text .icon2 {
  padding-top: 0.3em;
  margin-right: 2em;
  height: 0.8em;
  width: 1.5em;
}

main .content4-text p {
  margin: 0;
  min-width: 10em;
}

main .content4-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 5em;
}

.m-plus-rounded-1c-light {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.m-plus-rounded-1c-regular {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.m-plus-rounded-1c-medium {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.m-plus-rounded-1c-bold {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.m-plus-rounded-1c-extrabold {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 800;
  font-style: normal;
}

main .sp-br {
  display: none;
}

main .sp-only {
  display: none !important;
}

main .content2-button p {
  cursor: pointer;
  color: #aaa; /* 選択されていない文字色を薄く */
  transition: color 0.3s ease;
}

main .content2-button p.active {
  color: #000; /* 選択中は濃く */
}

.sp-br {
  display: none;
}

@media (max-width: 768px) {

  .sp-br {
    display: inline;
  }

  .b {
    word-break: keep-all;
    overflow-wrap: anywhere;
  }

  main .sp-only {
    display: flex !important;
  }

  main .content3-warp {
    display: none;
  }

  main .sp-br {
    display: inline;
  }

  main h1 {
    font-size: 8vw;
    width: 85%;
    padding: 5vw 0.5vw;
  }

  main h1::after {
    top: -1.4vw;
    left: -1.5vw;
  }

  main h2 {
    font-size: 1.3em;
    margin: 1em 1em;
  }

  main h3 {
    font-size: 7vw;
    font-weight: 500;
  }

  main .sp-line {
    height: 2px;
    background-color: #DA238B;
    flex: none;
    width: 10%;
    margin: auto auto;
  }

  main .content1-title {
    justify-content: center;
  }

  main .content1-wrap {
    margin: 0;
  }

  main .outer {
    padding: 0.3em 0.3em;
    width: 95%;
  }

  main .content1-text {
    transform: rotate(0.03deg);
    font-size: 2.8vw;
    font-size: 4vw;
    padding: 2em 1.5em;
    padding-bottom: 0.1em;
  }

  main .content1-text p {
    margin: 0;
    min-width: 6em;
  }

  main .item img {
    height: 1.8em;
    width: 1.8em;
  }

  main .content1-text .icon2 {
    margin-right: 0.2vw;
  }

  main .content1-text .item {
    display: flex;
    gap: 1em;
    margin-bottom: 1.5em;
  }

  main .content2-button {
    transform: rotate(0.03deg);
    font-size: 4vw;
    justify-content: space-around;
    width: 98%;
    margin-left: auto;
    margin-right: auto;
    border-radius: 10px;
    padding: 0.5em 0;
  }

  main .content2-button div p {
    padding: 0 0em;
  }

  main .button-line-sp {
    display: block;
    width: 2px;
    height: 1.5em;
    background-color: rgba(29, 29, 29, 0.4);
  }

  main .content2-button div+div p {
    border-left: none 2px rgba(29, 29, 29, 0.4);
  }

  main .outer2 {
    padding: 0.3em 0.3em;
    width: 95%;
  }

  main .content2-text {
    font-size: 0.9em;
    font-size: 4.4vw;
    padding: 2em 0.2em;
    padding-bottom: 1em;
    transform: rotate(0.03deg);
  }

  main .content2-text .icon2 {
    margin-right: 0.5vw;
  }

  main .content2-text p {
    margin: 0;
    min-width: 12em;
  }

  main .content2-text .item {
    gap: 1em;
    margin-left: 1em;
    margin-bottom: 1.5em;
  }

  main .outer31,
  main .outer32,
  main .outer33 {
    padding: 0.3em 0.3em;
    width: 85%;
    height: 70vw;
    border-radius: 80px;
  }

  main .swiper-slide {
    display: flex !important;
    justify-content: center !important;
    /* 横中央 */
  }

  main .swiper-container {
    position: relative;
  }

  main .swiper-pagination {
    bottom: -40px !important;
  }

  main .swiper-pagination-bullet {
    /*ドットの色を変更*/
    background-color: #DA238B !important;
  }


  main .content3-text {
    transform: rotate(0.03deg);
    border-radius: 80px;
    font-size: 1em;
    font-size: 3.5vw;
    font-size: 4.4vw;
  }

  main .content4-wrap {
    margin: 0;
    margin-bottom: 5em;
  }

  main .outer4 {
    padding: 0.3em 0.3em;
    width: 95%;
  }

  main .content4-text {
    word-break: keep-all;
    transform: rotate(0.03deg);
    font-size: 2.7vw;
    font-size: 4vw;
    padding: 3em 2em;
    padding-bottom: 0.1em;
    padding-left: 1em;
    padding-right: 0;
  }

  .c {
    overflow-wrap: anywhere;
  }

  main .content4-text p {
    margin: 0;
    min-width: 0;
  }

  main .content4-text .icon2 {
    margin-right: 0;
  }

  main .content4-text .item {
    display: flex;
    gap: 1em;
    margin-bottom: 3em;
  }
}