@charset "UTF-8";

main {
  margin-inline: auto;
  max-width: 144rem;
}
.mv {
  margin-block: -3rem 0;
  width: 100%;
}
.mv picture img {
  width: 100%;
  height: auto;
}
.contents {
  margin-inline: auto;
  max-width: 100rem;
  padding-block: 0 8.5rem;
}
.about {
  text-align: center;
  margin-block: 2rem 0;
}
.about h2 {
  font-size: 2.4rem;
  line-height: 1.64;
  color: var(--color-red);
}
.about p {
  margin-block: 3.5rem 0;
  font-size: 1.6rem;
  line-height: 1.86;
}
.service {
  margin-block: 6rem 0;
}
.service .heading {
  position: relative;
  text-align: center;
}
.service .heading::before,
.service .heading::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 28.6rem;
  height: 2px;
  background-color: var(--color-red);
}
.service .heading::before {
  left: 0;
}
.service .heading::after {
  right: 0;
}
.service .heading p {
  display: inline-block;
  border-radius: 1.5rem;
  background-color: var(--color-red);
  padding-block: 0.5rem;
  padding-inline: 3.5rem;
  font-size: 1.4rem;
  line-height: 1.57;
  color: var(--color-white);
}
.service > h3 {
  text-align: center;
  margin-block: 6rem 0;
  font-size: 4.2rem;
  line-height: 1.3;
}
.service > ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 2rem;
}
.service > ul li > p {
  text-align: center;
  font-size: 2.2rem;
  color: var(--color-red);
}
.service > ul li > p span {
  padding-inline: 0.5rem 0;
  font-size: 3rem;
}
.service > ul li > a {
  position: relative;
  padding-block: 0 3rem;
}
.service > ul li > a .wrap {
  text-align: center;
  display: grid;
  grid-template-rows: repeat(2, 4.5rem);
  gap: 3rem 0;
  border: 2px solid var(--color-gray);
  border-radius: 1.5rem 1.5rem 0 0;
  padding-block: 2.5rem;
}
.service > ul li > a::before {
    content: "";
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 0;
    border-bottom: solid 2px var(--color-white);
    border-right: solid 2px var(--color-white);
    transform: translateX(-50%) rotate(45deg);
    left: 50%;
    bottom: 1.2rem;
    z-index: 1;
  }
.service > ul li > a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  border-radius: 0 0 1.5rem 1.5rem;
  background-color: var(--color-red);
  width: 100%;
  height: 3rem;
}
.service > ul li > a .wrap figure {
  margin-inline: auto;
  width: 4.4rem;
}
.service > ul li:last-child > a .wrap figure {
  width: 5.8rem;
}
.service > ul li > a .wrap figure img {
  width: 100%;
  height: auto;
}
.service > ul li > a .wrap .text {
  display: flex;
  align-items: center;
  justify-content: center;
}
.service > ul li > a .wrap .text p {
  font-size: 1.6rem;
  line-height: 1.62;
}
.service > ul li > a .wrap .text p span {
  color: var(--color-red);
}
.service > .point-details {
  margin-block: 8rem 0;
}
.service > .point-details > ul {
  display: grid;
  gap: 8rem 0;
}
.service > .point-details > ul > li {
  position: relative;
  border-radius: 1.5rem;
  background-color: var(--color-gray);
  padding-block: 8.5rem 2.5rem;
  padding-inline: 4rem;
  z-index: 1;
}
.service > .point-details > ul > li:nth-of-type(2) {
  padding-block: 9.5rem 2.5rem;
}
.service > .point-details > ul > li:nth-of-type(3) {
  padding-block: 10.5rem 2.5rem;
}
/* .service > .point-details > ul > li::before {
  content: "";
  position: absolute;
  top: 9rem;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 1.5rem;
  background-color: var(--color-white);
  width: 92rem;
  height: 33rem;
  z-index: -1;
}
.service > .point-details > ul > li:nth-of-type(3)::before {
  top: 10rem;
} */
.service > .point-details > ul > li .grid {
  display: grid;
  grid-template-columns: auto 42.7rem;
  grid-template-rows: 7.6rem auto;
  grid-template-areas:
  "image number"
  "image textarea"
  ;
  gap: 0 3.5rem;
  border-radius: 1.5rem;
  background-color: var(--color-white);
}
.service > .point-details > ul > li:nth-of-type(2) .grid {
  padding-block: 0 2rem;
}
.service > .point-details > ul > li:nth-of-type(3) .grid {
  padding-block: 0 3rem;
}
.service > .point-details > ul > li .grid picture {
  grid-area: image;
  margin-block: -7rem 0;
}
.service > .point-details > ul > li:nth-of-type(1) .grid picture {
  padding-inline: 6rem 0;
  width: 42rem;
}
.service > .point-details > ul > li:nth-of-type(2) .grid picture {
  padding-inline: 2rem 0;
  width: 44rem;
}
.service > .point-details > ul > li:nth-of-type(3) .grid picture {
  padding-inline: 7rem 0;
  width: 44rem;
}
.service > .point-details > ul > li .grid picture img {
  width: 100%;
  height: auto;
}
.service > .point-details > ul > li .grid .number {
  grid-area: number;
  margin-block: -6.5rem 0;
  font-size: 3.2rem;
  color: var(--color-red);
}
.service > .point-details > ul > li .grid .number span {
  padding-inline: 0.5rem 0;
  font-size: 5.4rem;
}
.service > .point-details > ul > li .grid .textarea {
  grid-area: textarea;
  margin-block: -6.5rem 0;
  padding-inline: 0 3.5rem;
}
.service > .point-details > ul > li .grid .textarea .summary {
  margin-block: 5rem 0;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.75;
}
.service > .point-details > ul > li .grid .textarea .text {
  margin-block: 2rem 0;
  font-size: 1.4rem;
  line-height: 1.86;
}
.service > .point-details > ul > li .grid .textarea .text a {
  display: inline;
  text-decoration: underline;
  color: var(--color-blue);
}
.service > .point-details > ul > li .grid .textarea > .caution-text {
  display: block;
  margin-block: 2rem 0;
  font-size: 1.3rem;
  line-height: 1.5;
}
.service > .point-details > ul > li .link-btn {
  position: relative;
  text-align: center;
  margin-block: 3rem 0;
  border-radius: 1.5rem;
  background-color: var(--color-red);
  padding-block: 1.5rem;
  font-size: 1.8rem;
  line-height: 1.78;
  color: var(--color-white);
}
.service > .point-details > ul > li .link-btn::before {
  content: "";
  position: absolute;
  width: 1.3rem;
  height: 1.3rem;
  border: 0;
  border-bottom: solid 2px var(--color-white);
  border-right: solid 2px var(--color-white);
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
  right: 2.5rem;
  z-index: 1;
}
.service > .point-details > ul > li .accordion {
  margin-block: 3rem 0;
  border-radius: 1.5rem;
  background-color: var(--color-red);
}
.service > .point-details > ul > li .accordion summary {
  position: relative;
  text-align: center;
  margin-block: 2rem 0;
  padding-block: 1.5rem;
  font-size: 1.8rem;
  line-height: 1.78;
  color: var(--color-white);
}
.service > .point-details > ul > li .accordion summary .icon {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.6rem;
  transform: translateY(-50%);
  border: 1px solid var(--color-white);
  border-radius: 50%;
  width: 2.5rem;
  height: 2.5rem;
  z-index: 1;
}
.service > .point-details > ul > li .accordion summary .icon::before,
.service > .point-details > ul > li .accordion summary .icon::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 1.3rem;
  height: 1px;
  background-color: var(--color-white);
  z-index: 1;
}
.service > .point-details > ul > li .accordion summary .icon::before {
  transform: translateY(-50%) rotate(90deg);
  transition: transform 0.4s ease;
}
.service > .point-details > ul > li .accordion[data-expanded="true"] summary .icon::before {
  transform: translateY(-50%) rotate(0deg);
}
.service > .point-details > ul > li .accordion .content {
  position: relative;
  border-radius: 0 0 1.5rem 1.5rem;
  background-color: var(--color-red);
  padding-block: 1.5rem 4rem;
  padding-inline: 3.5rem;
}
.service > .point-details > ul > li .accordion .content .steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 4.5rem;
}
.service > .point-details > ul > li .accordion .content .steps li {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
}
.service > .point-details > ul > li .accordion .content .steps li:not(:nth-child(3n + 1))::before {
  content: "";
  position: absolute;
  top: 38rem;
  left: -2.7rem;
  background-color: var(--color-white);
  width: 1.5rem;
  height: calc(tan(60deg) * 2.8rem / 2);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.service > .point-details > ul > li:nth-of-type(3) .accordion .content .steps li:not(:nth-child(3n + 1))::before {
  top: 32rem;
}
.service > .point-details > ul > li .accordion .content .steps li p {
  color: var(--color-white);
}
.service > .point-details > ul > li .accordion .content .steps li .number {
  background-image : linear-gradient(to right, var(--color-white) 2px, transparent 2px);
  background-size: 10px 2px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding-block: 0 1rem;
  font-size: 2rem;
  color: var(--color-white);
}
.service > .point-details > ul > li .accordion .content .steps li .number span {
  padding-inline: 0.5rem 0;
  font-size: 3.2rem;
}
.service > .point-details > ul > li .accordion .content .steps li .desc {
  padding-block: 1rem;
  font-size: 1.4rem;
  line-height: 1.86;
  color: var(--color-white);
}
.service > .point-details > ul > li .accordion .content .steps li picture img {
  width: 100%;
  height: auto;
}
.mypage {
  margin-block: 8rem 0;
}
.mypage h3 {
  text-align: center;
  font-size: 2rem;
  line-height: 1.58;
}
.mypage h3 span {
  font-size: 2.4rem;
  color: var(--color-red);
}
.mypage .inner {
  margin-block: 3.2rem 0;
  border-radius: 1.5rem;
  background-color: var(--color-pink);
  padding-block: 4rem;
  padding-inline: 4rem;
}
.mypage .inner .links {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
.mypage .inner .links li {
  width: calc((100% - 2rem) / 2);
}
.mypage .inner .links li a {
  display: flex;
  align-items: center;
  gap: 0 1rem;
  border-radius: 1rem;
  background-color: var(--color-white);
  padding-block: 1.7rem;
  padding-inline: 1.5rem 0.5rem;
  min-height: 8rem;
}
.mypage .inner .links li a > figure {
  width: 4.5rem;
}
/* .mypage .inner .links li:nth-of-type(1) a,
.mypage .inner .links li:nth-of-type(7) a,
.mypage .inner .links li:nth-of-type(8) a
 {
  padding-block: 0.8rem;
  padding-inline: 1.2rem 0.5rem;
}
.mypage .inner .links li:nth-of-type(1) a > figure,
.mypage .inner .links li:nth-of-type(7) a > figure,
.mypage .inner .links li:nth-of-type(8) a > figure
 {
  width: 3.3rem;
} */
.mypage .inner .links li figure img {
  width: 100%;
  height: auto;
}
.mypage .inner .links li a p {
  font-size: 1.4rem;
}
.mypage .inner .links li a span {
  margin-inline: auto 1.5rem;
}
.mypage .inner .links li a span > figure {
  width: 1.2rem;
}
.mypage .inner .card {
  margin-block: 6rem 0;
  margin-inline: auto;
  max-width: 63.4rem;
}
.mypage .inner .card figure img {
  width: 100%;
  height: auto;
}
.mypage .inner .register {
  margin-block: 3.5rem 0;
}
.mypage .inner .register h4 {
  text-align: center;
  font-size: 2.4rem;
  color: var(--color-red);
}
.mypage .inner .register h4 span {
  font-size: 2rem;
}
.mypage .inner .register .accordion {
  margin-block: 2rem 0;
  border-radius: 1.5rem;
  background-color: var(--color-red);
}
.mypage .inner .register .accordion summary {
  position: relative;
  text-align: center;
  margin-block: 2rem 0;
  padding-block: 1.5rem;
  font-size: 1.8rem;
  line-height: 1.78;
  color: var(--color-white);
}
.mypage .inner .register .accordion summary .icon {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.6rem;
  transform: translateY(-50%);
  border: 1px solid var(--color-white);
  border-radius: 50%;
  width: 2.5rem;
  height: 2.5rem;
  z-index: 1;
}
.mypage .inner .register .accordion summary .icon::before,
.mypage .inner .register .accordion summary .icon::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 1.3rem;
  height: 1px;
  background-color: var(--color-white);
  z-index: 1;
}
.mypage .inner .register .accordion summary .icon::before {
  transform: translateY(-50%) rotate(90deg);
  transition: transform 0.4s ease;
}
.mypage .inner .register .accordion[data-expanded="true"] summary .icon::before {
  transform: translateY(-50%) rotate(0deg);
}
.mypage .inner .register .accordion .content {
  position: relative;
  border-radius: 0 0 1.5rem 1.5rem;
  background-color: var(--color-red);
  padding-block: 1.5rem 4rem;
  padding-inline: 3.5rem;
}
.mypage .inner .register .accordion .content .steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3.5rem 4.5rem;
  padding-block: 0 6rem;
}
.mypage .inner .register .accordion .content .steps li {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
}
.mypage .inner .register .accordion .content .steps li:not(:nth-child(3n + 1))::before {
  content: "";
  position: absolute;
  left: -2.7rem;
  background-color: var(--color-white);
  width: 1.5rem;
  height: calc(tan(60deg) * 2.8rem / 2);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.mypage .inner .register .accordion .content .steps li p {
  color: var(--color-white);
}
.mypage .inner .register .accordion .content .steps li .number {
  background-image : linear-gradient(to right, var(--color-white) 2px, transparent 2px);
  background-size: 10px 2px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding-block: 0 1rem;
  font-size: 2rem;
  color: var(--color-white);
}
.mypage .inner .register .accordion .content .steps li .number span {
  padding-inline: 0.5rem 0;
  font-size: 3.2rem;
}
.mypage .inner .register .accordion .content .steps li .desc {
  padding-block: 1rem;
  font-size: 1.4rem;
  line-height: 1.86;
  color: var(--color-white);
}
.mypage .inner .register .accordion .content .steps li picture img {
  width: 100%;
  height: auto;
}
.mypage .inner .register .accordion .content .anchor-links {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 4rem;
}
.mypage .inner .register .accordion .content .anchor-links02 {
  text-align: center;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 1.5rem;
}
.mypage .inner .register .accordion .content .anchor-links li a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 2px solid var(--color-white);
  border-radius: 5rem;
  background-color: var(--color-yellow);
  padding-block: 0.9rem;
  width: 100%;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
}
.mypage .inner .register .accordion .content .anchor-links li a span {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 1rem;
  width: 2rem;
  height: 2rem;
}
.mypage .inner .register .accordion .content .anchor-links li a span figure img {
  width: 100%;
  height: auto;
}
.mypage .inner .register .accordion .content .anchor-links01 li a {
  padding-block: 1.3rem;
}
.mypage .inner .register .accordion .content > h5 {
  text-align: center;
  margin-block: 5rem 0;
  font-size: 1.8rem;
  line-height: 1.78;
  color: var(--color-white);
}
.mypage .inner .register .accordion .content > .heading {
  text-align: center;
  margin-block: 1.5rem 0;
  font-size: 1.4rem;
  line-height: 1.86;
  color: var(--color-white);
}
.mypage .inner .register .accordion .content .steps {
  padding-block: 5rem 6rem;
}
.mypage .inner .register .accordion .content .steps.steps02 {
  padding-block: 5rem 8rem;
}
.mypage .inner .register .accordion .content .steps01,
.mypage .inner .register .accordion .content .steps03,
.mypage .inner .register .accordion .content .steps04 {
  border-bottom: 1px solid var(--color-white);
}
.mypage .inner .register .accordion .content .steps01 li::before {
  bottom: 22rem;
}
.mypage .inner .register .accordion .content .steps02 li::before {
  bottom: 23rem;
}
.mypage .inner .register .accordion .content .steps03 li::before {
  top: 51rem;
}
.mypage .inner .register .accordion .content .steps04 li::before {
  top: 50rem;
}
.mypage .inner .register .accordion .content .steps05 li::before {
  top: 50rem;
}
.caution {
  padding-block: 4rem 6rem;
  background-color: var(--color-gray);
}
.caution .inner {
  margin-inline: auto;
  max-width: 100rem;
}
.caution .inner .heading {
  text-align: center;
}
.caution .inner .heading figure {
  margin-inline: auto;
  width: 4rem;
}
.caution .inner .heading figure img {
  width: 100%;
  height: auto;
}
.caution .inner .heading p {
  margin-block: 0.5rem 0;
  font-size: 1.6rem;
  line-height: 1.75;
  color: var(--color-red);
}
.caution .inner > ul {
  margin-block: 3.5rem 0;
}
.caution .inner > ul > li {
  position: relative;
  margin-block: 0.5rem 0;
  padding-inline: 1.5rem 0;
  font-size: 1.4rem;
  line-height: 1.75;
}
.caution .inner > ul > li::before {
  content: "※";
  position: absolute;
  left: 0;
}
.caution .inner > ul > li ul {
  margin-inline: -1.5rem 0;
}
.caution .inner > ul > li ul li {
  margin-block: 0.5rem 0;
  line-height: 1.75;
  font-size: 1.4rem;
}



@media (max-width: 767px) {
  .mv {
    margin-block: 0;
  }
  .contents {
    padding-inline: 5rem;
    max-width: initial;
  }
  .about {
    margin-block: 8rem 0;
  }
  .about h2 {
    font-size: 3.6rem;
  }
  .about p {
    margin-block: 6rem 0;
    font-size: 2.8rem;
  }
  .service {
    margin-block: 10rem 0;
  }
  .service .heading::before,
  .service .heading::after {
    display: none;
  }
  .service .heading p {
    border-radius: 5rem;
    padding-block: 0.8rem;
    padding-inline: 2.5rem;
    font-size: 2.8rem;
  }
  .service > h3 {
    margin-block: 7.5rem 0;
    font-size: 7rem;
  }
  .service > ul {
    display: grid;
    grid-template-columns: initial;
    gap: 8rem 0;
  }
  .service > ul li > p {
    font-size: 3.6em;
  }
  .service > ul li > p span {
    padding-inline: 1rem 0;
    font-size: 5.2rem;
  }
  .service > ul li > a {
    padding-block: 0 6rem;
  }
  .service > ul li > a .wrap {
    text-align: center;
    display: grid;
    grid-template-rows: repeat(2, 8rem);
    gap: 4rem 0;
    padding-block: 3.5rem;
  }
  .service > ul li > a::before {
      width: 2rem;
      height: 2rem;
      bottom: 2.2rem;
    }
  .service > ul li > a::after {
    height: 6rem;
  }
  .service > ul li > a .wrap figure {
    width: 8.4rem;
  }
  .service > ul li:last-child > a .wrap figure {
    width: 8.8rem;
  }
  .service > ul li > a .wrap .text p {
    font-size: 3rem;
  }


  .service > .point-details {
    margin-block: 9rem 0;
  }
  .service > .point-details > ul {
    gap: 5rem 0;
  }
  .service > .point-details > ul > li {
    padding-block: 11.6rem 3.5rem;
  }
  .service > .point-details > ul > li:nth-of-type(2) {
    padding-block: 11.6rem 3.5rem;
  }
  .service > .point-details > ul > li:nth-of-type(3) {
    padding-block: 11.6rem 3.5rem;
  }
  .service > .point-details > ul > li:nth-of-type(1)::before {
    top: 11rem;
    width: 57rem;
    height: 75%;
  }
  .service > .point-details > ul > li:nth-of-type(2)::before {
    top: 11rem;
    width: 57rem;
    height: 111.5rem;
  }
  .service > .point-details > ul > li:nth-of-type(3)::before {
    top: 11rem;
    width: 57rem;
    height: 85.7rem;
  }
  .service > .point-details > ul > li .grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    grid-template-areas:
    "number"
    "image"
    "textarea"
    ;
    gap: 0;
  }
  .service > .point-details > ul > li:nth-of-type(2) .grid {
    padding-block: 0;
  }
  .service > .point-details > ul > li .grid picture {
    margin-block: 3rem 0;
  }
  .service > .point-details > ul > li:nth-of-type(1) .grid picture {
    margin-inline: auto -3rem;
    padding-inline: 0;
    width: 44rem;
  }
  .service > .point-details > ul > li:nth-of-type(2) .grid picture {
    margin-inline: auto;
    padding-inline: 0;
    width: 52.3rem;
  }
  .service > .point-details > ul > li:nth-of-type(3) .grid picture {
    margin-inline: auto;
    padding-inline: 0;
    width: 48.7rem;
  }
  .service > .point-details > ul > li .grid .number {
    margin-block: -10.5rem 0;
    font-size: 5rem;
  }
  .service > .point-details > ul > li .grid .number span {
    padding-inline: 2.5rem 0;
    font-size: 8rem;
  }
  .service > .point-details > ul > li .grid .textarea {
    margin-block: 1rem 0;
    padding-inline: 4.5rem;
  }
  .service > .point-details > ul > li:nth-of-type(1) .grid .textarea {
    margin-block: 2rem 0;
    padding-block: 0 4rem;
  }
  .service > .point-details > ul > li:nth-of-type(2) .grid .textarea {
    padding-block: 0 4rem;
  }
  .service > .point-details > ul > li:nth-of-type(3) .grid .textarea {
    margin-block: 2.5rem 0;
  }
  .service > .point-details > ul > li .grid .textarea .summary {
    margin-block: 0;
    font-size: 3.4rem;
  }
  .service > .point-details > ul > li .grid .textarea .text {
    font-size: 2.8rem;
  }
  .service > .point-details > ul > li .grid .textarea > .caution-text {
    font-size: 2.4rem;
  }
  .service > .point-details > ul > li .link-btn {
    margin-block: 5rem 0;
    font-size: 3rem;
  }
  .service > .point-details > ul > li .link-btn::before {
    width: 1.1rem;
    height: 1.1rem;
    border-bottom: solid 0.2rem var(--color-white);
    border-right: solid 0.2rem var(--color-white);
    right: 3.5rem;
  }
  .service > .point-details > ul > li .accordion {
    margin-block: 4rem 0;
  }
  .service > .point-details > ul > li .accordion summary {
    padding-inline: 4.5rem 8rem;
    font-size: 3rem;
  }
  .service > .point-details > ul > li .accordion summary::before,
  .service > .point-details > ul > li .accordion summary::after {
    right: 2.6rem;
    width: 2.6rem;
  }
  .service > .point-details > ul > li .accordion .content {
    padding-block: 1.5rem 4rem;
    padding-inline: 4.5rem;
  }
  .service > .point-details > ul > li .accordion .content .steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8rem 0;
  }
  .service > .point-details > ul > li .accordion .content .steps li:not(:nth-child(3n + 1))::before {
    top: -4.5rem;
    left: 50%;
    transform: translateX(-50%);
    width: 4.5rem;
    height: calc(tan(60deg) * 3rem / 2);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
  }
  .service > .point-details > ul > li:nth-of-type(3) .accordion .content .steps li:not(:nth-child(3n + 1))::before {
    top: -4.5rem;
  }
  .service > .point-details > ul > li .accordion .content .steps li .number {
    background-image : linear-gradient(to right, var(--color-white) 0.2rem, transparent 0.2rem);
    background-size: 0.8rem 0.2rem;
    font-size: 3.4rem;
  }
  .service > .point-details > ul > li .accordion .content .steps li .number span {
    padding-inline: 1rem 0;
    font-size: 5rem;
  }
  .service > .point-details > ul > li .accordion .content .steps li .desc {
    font-size: 2.8rem;
  }

  .mypage h3 {
    margin-inline: -3rem;
    font-size: 3.6rem;
  }
  .mypage h3 span {
    font-size: 4rem;
  }
  .mypage .inner {
    margin-block: 5rem 0;
  }
  .mypage .inner .links {
    flex-direction: column;
    flex-wrap: nowrap;
  }
  .mypage .inner .links li {
    width: 100%;
  }
  .mypage .inner .links li a {
    padding-block: 3.3rem;
    padding-inline: 1.5rem;
    gap: 0 2rem;
    min-height: initial;
  }
  .mypage .inner .links li a > figure {
    width: 6.5rem;
  }
  /* .mypage .inner .links li:nth-of-type(1) a,
  .mypage .inner .links li:nth-of-type(7) a,
  .mypage .inner .links li:nth-of-type(8) a
   {
    padding-block: 3.5rem;
  }
  .mypage .inner .links li:nth-of-type(1) a {
    padding-inline: 2.2rem 0.5rem;
  }
  .mypage .inner .links li:nth-of-type(7) a {
    padding-inline: 2.5rem 0.5rem;
  }
  .mypage .inner .links li:nth-of-type(8) a {
    padding-inline: 2.5rem 0.5rem;
  }
  .mypage .inner .links li:nth-of-type(1) a > figure {
    width: 5.2rem;
  }
  .mypage .inner .links li:nth-of-type(7) a > figure {
    width: 4.7rem;
  }
  .mypage .inner .links li:nth-of-type(8) a > figure {
    width: 4.8rem;
  } */
  .mypage .inner .links li a p {
    font-size: 2.6rem;
    font-weight: 700;
  }
  .mypage .inner .links li a span {
    margin-inline: auto 1.5rem;
  }
  .mypage .inner .links li a span > figure {
    width: 2.3rem;
  }
  .mypage .inner .card {
    margin-block: 8rem 0;
    max-width: 48.4rem;
  }
  .mypage .inner .register h4 {
    font-size: 4rem;
  }
  .mypage .inner .register h4 span {
    font-size: 3.4rem;
  }
  .mypage .inner .register .accordion {
    margin-block: 6rem 0;
  }
  .mypage .inner .register .accordion summary {
    padding-block: 4.3rem;
    font-size: 3rem;
  }
  .mypage .inner .register .accordion summary .icon {
    right: 2rem;
    width: 3.5rem;
    height: 3.5rem;
  }
  .mypage .inner .register .accordion summary .icon::before,
  .mypage .inner .register .accordion summary .icon::after {
    width: 1.7rem;
  }
  .mypage .inner .register .accordion .content {
    padding-inline: 4rem;
  }
  .mypage .inner .register .accordion .content .steps {
    grid-template-columns: 1fr;
    gap: 8rem 0;
    padding-block: 3rem 6rem;
  }
  .mypage .inner .register .accordion .content .steps.steps02 {
    padding-block: 3rem 8rem;
  }
  .mypage .inner .register .accordion .content .steps li:not(:nth-child(3n + 1))::before {
    left: 50%;
    transform: translateX(-50%);
    width: 4.5rem;
    height: calc(tan(60deg)* 3rem / 2);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
  }
  .mypage .inner .register .accordion .content .steps li:nth-child(n + 4)::before {
    content: "";
    position: absolute;
    background-color: var(--color-white);
    left: 50%;
    transform: translateX(-50%);
    width: 4.5rem;
    height: calc(tan(60deg)* 3rem / 2);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
  }
  .mypage .inner .register .accordion .content .steps li:not(:nth-child(3n + 1))::before {
    top: -4.5rem;
  }
  .mypage .inner .register .accordion .content .steps li:nth-child(n + 4)::before {
    top: -4.5rem;
  }
  .mypage .inner .register .accordion .content .steps li .number {
    background-image : linear-gradient(to right, var(--color-white) 0.2rem, transparent 0.2rem);
    background-size: 0.8rem 0.2rem;
    padding-block: 0 1.5rem;
    font-size: 3.4rem;
  }
  .mypage .inner .register .accordion .content .steps li .number span {
    padding-inline: 1rem 0;
    font-size: 5rem;
  }
  .mypage .inner .register .accordion .content .steps li .desc {
    font-size: 2.8rem;
  }
  .mypage .inner .register .accordion .content .anchor-links {
    gap: 0 1.5rem;
  }
  .mypage .inner .register .accordion .content .anchor-links02 {
    grid-template-columns: 1fr;
    gap: 2rem 0;
  }
  .mypage .inner .register .accordion .content .anchor-links li a {
    border: 0.2rem solid var(--color-white);
    border-radius: 1.5rem;
    padding-block: 2.5rem;
    font-size: 2.4rem;
  }
  .mypage .inner .register .accordion .content .anchor-links li a span {
    right: 2.5rem;
    width: 3.5rem;
    height: 3.5rem;
  }
  .mypage .inner .register .accordion .content .anchor-links01 li a {
    text-align: center;
    padding-block: 3rem 8rem;
  }
  .mypage .inner .register .accordion .content .anchor-links01 li a span {
    top: initial;
    bottom: 3.5rem;
    right: 50%;
    transform: translateX(50%);
    width: 3rem;
    height: 3rem;
  }
  .mypage .inner .register .accordion .content > h5 {
    margin-block: 7rem 0;
    font-size: 3.2rem;
  }
  .mypage .inner .register .accordion .content > .heading {
    margin-block: 3rem 0;
    font-size: 2.8rem;
  }
  .mypage .inner .register .accordion .content .steps01 li::before {
    bottom: initial;
  }
  .mypage .inner .register .accordion .content .steps02 li::before {
    bottom: initial;
  }
  .mypage .inner .register .accordion .content .steps03 li::before {
    top: initial;
  }
  .mypage .inner .register .accordion .content .steps04 li::before {
    top: initial;
  }
  .mypage .inner .register .accordion .content .steps05 li::before {
    top: initial;
  }
  .mypage .inner .register .accordion .content .steps05 {
    padding-block: 3rem 0;
  }
  .caution {
    padding-block: 7rem 10rem;
  }
  .caution .inner {
    padding-inline: 5rem;
    max-width: initial;
  }
  .caution .inner .heading figure {
    width: 8rem;
  }
  .caution .inner .heading p {
    margin-block: 1.5rem 0;
    font-size: 3rem;
  }
  .caution .inner > ul {
    margin-block: 6rem 0;
  }
  .caution .inner > ul > li {
    padding-inline: 3rem 0;
    font-size: 2.8rem;
  }
  .caution .inner > ul > li ul {
    margin-inline: -3rem 0;
  }
  .caution .inner > ul > li ul li {
    font-size: 2.8rem;
  }
}