@charset "UTF-8";
/* common
---------------------------------------------------------------------------- */
.p-about-sec:not(:last-child) {
  padding-bottom: 8rem;
}

@media screen and (max-width: 767px) {
  .p-about-sec:not(:last-child) {
    padding-bottom: 13.3333333333vw;
  }
}
/* 01
---------------------------------------------------------------------------- */
.p-about01-box {
  padding: 2rem;
  background: #5CD3E1;
  background-image: repeating-linear-gradient(135deg, transparent, transparent 1.5rem, rgba(255, 255, 255, 0.1) 1.5rem, rgba(255, 255, 255, 0.1) 2.5rem), linear-gradient(130deg, #5CD3E1 0%, #FFD8E6 60%, #FFA7C6 100%);
}

.p-about01-box-inner {
  display: flex;
  align-items: center;
  gap: 6rem;
  padding: 5rem 8rem;
  background-color: #fff;
}
.p-about01-box-inner img {
  width: 27.5rem;
  min-width: 27.5rem;
}

.p-about01-box-ttl01 {
  font-size: 2rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: 700;
}

.p-about01-box-ttl02 {
  color: #FB73A2;
  font-size: 3.5rem;
  line-height: 1.4857142857;
  letter-spacing: 0.06em;
  font-weight: 900;
  margin-bottom: 1.5rem;
}

@media screen and (max-width: 767px) {
  .p-about01-box {
    padding: 2.6666666667vw;
  }
  .p-about01-box-inner {
    flex-direction: column-reverse;
    gap: 4vw;
    padding: 8vw 5.3333333333vw;
  }
  .p-about01-box-inner img {
    width: 38.6666666667vw;
    min-width: 38.6666666667vw;
  }
  .p-about01-box-inner p {
    line-height: 1.8125;
  }
  .p-about01-box-ttl01 {
    font-size: 4.8vw;
  }
  .p-about01-box-ttl02 {
    font-size: 5.3333333333vw;
    margin-bottom: 2.6666666667vw;
  }
}
/* 02
---------------------------------------------------------------------------- */
.p-about02-box {
  padding: 5rem 10rem;
  background: #E4F8FC;
}

.p-about02-list {
  display: flex;
  gap: 0.5rem;
}

.p-about02-list-item {
  flex: 1;
  padding: 5rem 2rem 4rem;
  background-color: #fff;
}
.p-about02-list-item p {
  font-weight: 700;
  padding: 0 2rem;
}

.p-about02-list-item-ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  font-size: 3.5rem;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 900;
  width: fit-content;
  padding-bottom: 1.8rem;
  margin: 0 auto 3rem;
  position: relative;
}
.p-about02-list-item-ttl::before, .p-about02-list-item-ttl::after {
  position: absolute;
  content: "";
  height: auto;
}
.p-about02-list-item-ttl::before {
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 11.2rem;
  aspect-ratio: 112/6;
  background: url(../../images/about/img_ttl-deco-01.svg) no-repeat center/contain;
}
.p-about02-list-item-ttl::after {
  top: -0.7rem;
  left: -1.7rem;
  width: 2.2rem;
  aspect-ratio: 22/21;
  background: url(../../images/about/img_ttl-deco-02.svg) no-repeat center/contain;
}
.p-about02-list-item-ttl span {
  font-size: 4.6rem;
}
.p-about02-list-item-ttl span._gradation {
  color: #E4F8FC;
  font-family: "Montserrat";
  font-size: 6.1rem;
  position: relative;
}
.p-about02-list-item-ttl span._gradation::before {
  position: absolute;
  content: "S";
  top: -0.3rem;
  left: -0.4rem;
  width: fit-content;
  height: 100%;
  background: #FFA7C6;
  background: linear-gradient(0deg, #FFA7C6 0%, #FFB7E9 30%, #5CD3E1 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .p-about02-box {
    padding: 8vw 5.3333333333vw;
  }
  .p-about02-list {
    flex-direction: column;
    gap: 1.3333333333vw;
  }
  .p-about02-list-item {
    padding: 8vw 5.3333333333vw 6.6666666667vw;
  }
  .p-about02-list-item p {
    padding: 0;
  }
  .p-about02-list-item-ttl {
    gap: 1.3333333333vw;
    font-size: 4.8vw;
    width: fit-content;
    padding: 0 0 2.6666666667vw 2.6666666667vw;
    margin: 0 auto 4vw;
  }
  .p-about02-list-item-ttl::before {
    width: 16.5333333333vw;
  }
  .p-about02-list-item-ttl::after {
    top: -0.8vw;
    left: 0;
    width: 3.2vw;
  }
  .p-about02-list-item-ttl span {
    font-size: 6.4vw;
  }
  .p-about02-list-item-ttl span._gradation {
    font-size: 8.5333333333vw;
  }
  .p-about02-list-item-ttl span._gradation::before {
    top: -0.5333333333vw;
    left: -0.5333333333vw;
  }
}
/* 03
---------------------------------------------------------------------------- */
.p-about03 {
  padding-bottom: 10rem;
}

.p-about03-box {
  padding: 2rem;
  background: #4DC6D4;
  background: linear-gradient(110deg, #4DC6D4 0%, #B1EDF3 100%);
}

.p-about03-box-inner {
  display: flex;
  align-items: start;
  gap: 6rem;
  padding: 5rem 8rem;
  background-color: #fff;
}

.p-about03-box-ttl {
  font-size: 3.5rem;
  line-height: 1.4857142857;
  letter-spacing: 0.06em;
  font-weight: 700;
  white-space: nowrap;
  padding-left: 4.4rem;
  position: relative;
}
.p-about03-box-ttl::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 2.3rem;
  height: auto;
  aspect-ratio: 23/42;
  background: url(../../images/about/img_clip.svg) no-repeat center/contain;
}

.p-about03-box-list {
  counter-reset: num;
}
.p-about03-box-list li {
  font-size: 2rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: 700;
  padding-left: 4.1rem;
  position: relative;
}
.p-about03-box-list li:not(:last-child) {
  margin-bottom: 1.3rem;
}
.p-about03-box-list li::before {
  position: absolute;
  top: 0.4rem;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-family: "Montserrat";
  line-height: 1;
  letter-spacing: 0;
  width: 2.8rem;
  height: 2.9rem;
  padding-left: 0.1rem;
  border-radius: 9999px;
  background-color: #FB73A2;
  counter-increment: num;
  content: counter(num);
}

@media screen and (max-width: 767px) {
  .p-about03 {
    padding-bottom: 17.3333333333vw;
  }
  .p-about03-box {
    padding: 2.6666666667vw;
  }
  .p-about03-box-inner {
    flex-direction: column;
    align-items: center;
    gap: 4vw;
    padding: 6.6666666667vw 5.3333333333vw;
  }
  .p-about03-box-ttl {
    font-size: 6.9333333333vw;
    padding-left: 6.9333333333vw;
  }
  .p-about03-box-ttl::before {
    width: 3.7333333333vw;
  }
  .p-about03-box-list li {
    font-size: 4.2666666667vw;
    padding-left: 8.5333333333vw;
  }
  .p-about03-box-list li:not(:last-child) {
    margin-bottom: 2.6666666667vw;
  }
  .p-about03-box-list li::before {
    top: 1.0666666667vw;
    width: 5.8666666667vw;
    height: 5.8666666667vw;
    padding-left: 0;
  }
}
/* 04
---------------------------------------------------------------------------- */
.p-about04 {
  padding: 8rem 0;
  margin-top: -2rem;
  background: url(../../images/about/bg_sec04_pc.png) no-repeat center top/cover;
}

.p-about04-box {
  padding: 5rem 10rem;
  position: relative;
}
.p-about04-box::before {
  position: absolute;
  content: "";
  top: 1.2rem;
  right: 1.2rem;
  width: 2.7rem;
  height: auto;
  aspect-ratio: 1/1;
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  background-color: #1A3667;
}

.p-about04-box-ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8rem;
  margin-bottom: 2.5rem;
}
.p-about04-box-ttl .m-ttl03 {
  margin-bottom: 0;
}

.p-about04-box-ttl-img {
  position: relative;
}
.p-about04-box-ttl-img img {
  width: 21.7rem;
}

.p-about04-box-ttl-name {
  position: absolute;
  bottom: 2.5rem;
  right: -5rem;
  color: #fff;
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  padding: 0.6rem 0.8rem;
  background-color: #13b8c9;
}
.p-about04-box-ttl-name span {
  font-size: 1.4rem;
  font-weight: 400;
}

.p-about04-box02 {
  padding: 5rem;
  margin-top: 5rem;
  background: #FFEEF4;
}

.p-about04-box02-ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4rem;
  color: #FB73A2;
  font-size: 2.6rem;
  line-height: 1.8076923077;
  letter-spacing: 0.06em;
  font-weight: 700;
  margin-bottom: 2.5rem;
}
.p-about04-box02-ttl .p-about04-box-ttl-img {
  text-align: center;
  width: 22rem;
}
.p-about04-box02-ttl .p-about04-box-ttl-img img {
  width: 17rem;
}
.p-about04-box02-ttl .p-about04-box-ttl-name {
  bottom: 0;
  right: auto;
  background-color: #FB73A2;
}

.p-about04-table-ttl {
  color: #919397;
  font-size: 1.5rem;
  font-weight: 700;
  margin-top: 2rem;
}

.p-about04-table {
  color: #919397;
  font-size: 1.5rem;
}
.p-about04-table th {
  padding-right: 1.5em;
  position: relative;
}
.p-about04-table th::before {
  position: absolute;
  content: "ー";
  top: 0;
  right: 0.3rem;
}

@media screen and (max-width: 767px) {
  .p-about04 {
    padding: 13.3333333333vw 0;
    margin-top: -4vw;
    background: url(../../images/about/bg_sec04_sp.png) no-repeat center top/cover;
  }
  .p-about04-box {
    padding: 8vw 5.3333333333vw;
  }
  .p-about04-box::before {
    top: 2.1333333333vw;
    right: 2.1333333333vw;
    width: 5.3333333333vw;
  }
  .p-about04-box-ttl {
    flex-direction: column;
    gap: 8vw;
    margin-bottom: 5.3333333333vw;
  }
  .p-about04-box-ttl .m-ttl03 {
    margin-bottom: 0;
  }
  .p-about04-box-ttl-img img {
    width: 37.3333333333vw;
    margin-right: 2.6666666667vw;
  }
  .p-about04-box-ttl-name {
    bottom: 2.6666666667vw;
    right: -9.3333333333vw;
    font-size: 4.2666666667vw;
    padding: 1.6vw 2.1333333333vw;
  }
  .p-about04-box-ttl-name span {
    font-size: 3.7333333333vw;
  }
  .p-about04-box02 {
    padding: 8vw 5.3333333333vw 6.6666666667vw;
    margin-top: 8vw;
  }
  .p-about04-box02-ttl {
    flex-direction: column;
    gap: 6.6666666667vw;
    font-size: 4.8vw;
    margin-bottom: 2.6666666667vw;
  }
  .p-about04-box02-ttl .p-about04-box-ttl-img {
    width: 100%;
  }
  .p-about04-box02-ttl .p-about04-box-ttl-img img {
    width: 34.6666666667vw;
    margin-right: 0;
  }
  .p-about04-box02-ttl .p-about04-box-ttl-name {
    bottom: -1.8666666667vw;
    right: 50%;
    transform: translateX(50%);
    white-space: nowrap;
  }
  .p-about04-table-ttl {
    font-size: 4vw;
    margin: 2.6666666667vw 0 1.3333333333vw;
  }
  .p-about04-table {
    font-size: 3.7333333333vw;
  }
  .p-about04-table tr {
    display: flex;
    flex-direction: column;
    align-items: start;
  }
  .p-about04-table th {
    padding-right: 0;
  }
  .p-about04-table th::before {
    content: none;
  }
  .p-about04-table td {
    line-height: 1.5;
  }
}
/* 05
---------------------------------------------------------------------------- */
.p-about05 {
  padding-top: 14.5rem;
}

.p-about05-box {
  font-weight: 700;
  text-align: center;
  padding: 15rem 0 6rem;
  background: #E4F8FC;
  background: linear-gradient(140deg, #E4F8FC 0%, #FFEEF4 100%);
  position: relative;
}

.p-about05-box-img {
  position: absolute;
  top: -6.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 18.5rem;
}

.p-about05-box-ttl {
  font-size: 2.6rem;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  width: fit-content;
  padding: 0 2rem;
  margin: 0 auto 2.5rem;
  position: relative;
}
.p-about05-box-ttl::before, .p-about05-box-ttl::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  width: 34.2rem;
  height: 0.5rem;
  background: url(../../images/about/img_ttl-deco-03.svg) no-repeat center/contain;
}
.p-about05-box-ttl::before {
  left: 100%;
}
.p-about05-box-ttl::after {
  right: 100%;
}

.p-about05-link-wrap {
  display: flex;
  gap: 6rem;
  margin-top: 8rem;
}

.p-about05-link {
  flex: 1;
  padding: 1rem;
  background: rgb(59, 197, 212);
  background-image: repeating-linear-gradient(135deg, transparent, transparent 1.5rem, rgba(255, 255, 255, 0.23) 1.5rem, rgba(255, 255, 255, 0.23) 2.5rem), linear-gradient(135deg, rgb(59, 197, 212) 0%, rgb(152, 228, 236) 100%);
  border-radius: 0.6rem;
  position: relative;
}
.p-about05-link::before {
  position: absolute;
  content: "";
  top: 50%;
  right: 3rem;
  transform: translateY(-50%);
  width: 4.2rem;
  height: auto;
  aspect-ratio: 1/1;
  background: url(../../images/common/icn_cicrcle-triangle-r_wh_lb.png) no-repeat center/contain;
}

.p-about05-link-inner {
  display: flex;
  align-items: center;
  color: #fff;
  font-size: 2.6rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  text-align: center;
  background: rgb(59, 197, 212);
  background: linear-gradient(140deg, rgb(59, 197, 212) 0%, rgb(152, 228, 236) 100%);
  border-radius: 0.6rem;
  overflow: hidden;
}

.p-about05-link-img {
  width: 17.8rem;
}

.p-about05-link-txt {
  width: calc(100% - 17.8rem);
  padding-right: 6rem;
}

@media screen and (max-width: 767px) {
  .p-about05 {
    padding-top: 22.6666666667vw;
  }
  .p-about05-box {
    text-align: left;
    padding: 24vw 5.3333333333vw 8vw;
  }
  .p-about05-box-img {
    top: -9.3333333333vw;
    width: 28vw;
  }
  .p-about05-box-ttl {
    font-size: 5.3333333333vw;
    padding: 0 1.3333333333vw;
    margin: 0 auto 5.3333333333vw;
  }
  .p-about05-box-ttl::before, .p-about05-box-ttl::after {
    width: 22.4vw;
    height: 1.0666666667vw;
    background: url(../../images/about/img_ttl-deco-03.svg) no-repeat center/cover;
  }
  .p-about05-link-wrap {
    flex-direction: column;
    gap: 4vw;
    margin-top: 13.3333333333vw;
  }
  .p-about05-link {
    padding: 1.6vw;
    border-radius: 1.3333333333vw;
  }
  .p-about05-link::before {
    right: 5.3333333333vw;
    width: 6.4vw;
  }
  .p-about05-link-inner {
    display: flex;
    align-items: center;
    font-size: 4.8vw;
    border-radius: 1.3333333333vw;
  }
  .p-about05-link-img {
    width: 22.9333333333vw;
  }
  .p-about05-link-txt {
    width: calc(100% - (22.9333333333vw));
    padding-right: 9.3333333333vw;
  }
}
