.p-top1 {
  -webkit-clip-path: inset(0 0 0 0);
          clip-path: inset(0 0 0 0);
  padding: 146px 0 118px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-top1 {
    -webkit-clip-path: none;
            clip-path: none;
    padding: 85px 0 94px;
  }
}
.p-top1::after {
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.6);
  -webkit-backdrop-filter: blur(10px) brightness(115%);
          backdrop-filter: blur(10px) brightness(115%);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.p-top1__wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .p-top1__heading {
    display: none;
  }
}
.p-top1__ttl {
  padding-left: 90px;
}
.p-top1__ttl.is-fixtop {
  position: fixed;
  top: 202px;
}
@media screen and (max-width: 767px) {
  .p-top1__ttl {
    position: relative;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    padding: 0;
    margin: -18px 0 0;
  }
}
@media screen and (max-height: 750px) and (min-width: 768px) {
  .p-top1__ttl img {
    height: 64vh;
  }
}
.p-top1__content {
  width: 66.7%;
  max-width: 840px;
}
@media screen and (max-width: 767px) {
  .p-top1__content {
    max-width: 100%;
    width: 100%;
  }
}
.p-top1 .c-title1 {
  margin-bottom: 57px;
}
@media screen and (max-width: 767px) {
  .p-top1 .c-title1 {
    margin-bottom: 37px;
  }
}
.p-top2 {
  background: #ffffff;
  position: relative;
  padding: 135px 0 140px;
}
@media screen and (max-width: 767px) {
  .p-top2 {
    padding: 85px 0 68px;
  }
}
.p-top3 {
  background: #f4f4f4;
  position: relative;
  padding: 146px 0 140px;
}
@media screen and (max-width: 767px) {
  .p-top3 {
    padding: 85px 0 62px;
  }
}
.p-top3 .c-title1 {
  margin-bottom: 49px;
}
@media screen and (max-width: 767px) {
  .p-top3 .c-title1 {
    margin-bottom: 29px;
  }
}
.p-top3 .c-slider01 {
  margin-top: 49px;
}
@media screen and (max-width: 767px) {
  .p-top3 .c-slider01 {
    margin-top: 29px;
  }
}
.p-top4 {
  background: #ffffff;
  position: relative;
  padding: 146px 0 111px;
}
@media screen and (max-width: 767px) {
  .p-top4 {
    padding: 85px 0 70px;
  }
}
.p-top4 .c-title1 {
  margin-bottom: 49px;
}
@media screen and (max-width: 767px) {
  .p-top4 .c-title1 {
    margin-bottom: 29px;
  }
}
.p-top4 .c-list1 {
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  .p-top4 .c-list1 {
    margin-top: 20px;
  }
}