* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
  background-color: #fff;
}

.top {
  height: 720px;
  position: relative;
}
.top .parallax-fixed {
  z-index: -1;
}
.top .parallax-fixed::before {
  background: url("../image/top.webp") no-repeat center center/cover;
  content: "";
  display: block;
  width: 100%;
  height: 800px;
  position: fixed;
  bottom: 0;
  top: 0;
  right: 0;
  left: 0;
  z-index: -1;
}
.top h1 {
  font-family: "Oswald", sans-serif;
  position: absolute;
  font-weight: 900;
  font-size: 120px;
  letter-spacing: 0.01em;
  line-height: 1.2;
  top: 56%;
  left: 38%;
  transform: translate(-50%, -50%);
  text-decoration-color: #fff;
  text-decoration-style: solid;
  z-index: -1;
  padding-bottom: 9px;
}

@media (max-width: 980px) {
  .top {
    height: 680px;
    position: relative;
  }
  .top .parallax-fixed {
    z-index: -1;
  }
  .top .parallax-fixed::before {
    background: url("../image/top.webp") no-repeat center center/cover;
    content: "";
    display: block;
    width: 100%;
    height: 800px;
    position: fixed;
    bottom: 0;
    top: 0;
    right: 0;
    left: 0;
    z-index: -1;
  }
  .top h1 {
    font-family: "Oswald", sans-serif;
    position: absolute;
    font-weight: 900;
    font-size: 60px;
    letter-spacing: 0.01em;
    line-height: 1.2;
    top: 45%;
    left: 32%;
    transform: translate(-50%, -50%);
    text-decoration-color: #fff;
    text-decoration-style: solid;
    z-index: -1;
    padding-bottom: 9px;
    margin-left: 70px;
  }
}
.mission {
  margin: -3px;
  -webkit-clip-path: polygon(0 0, 100% 0px, 100% 100%, 0 calc(100% - 130px));
          clip-path: polygon(0 0, 100% 0px, 100% 100%, 0 calc(100% - 130px));
  background-color: #28292b;
  display: block;
  text-align: center;
  padding: 104px 0 145px 0;
}
.mission .wrapper {
  width: 66.6666666667vw;
  background-color: #e4e4e4;
  margin: 0 auto;
  padding: 30px;
}
.mission .card {
  background-color: #f98f8f;
  width: 200px;
  max-width: 100%;
  height: 200px;
  margin: 100px auto;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.mission h1 {
  font-family: "Noto Serif JP";
  font-weight: 900;
  font-size: 120px;
  letter-spacing: 0.01em;
  color: #fff;
  margin-bottom: -32px;
  color: #3d3e40;
}
.mission h2 {
  font-weight: 900;
  font-size: 32px;
  width: 425px;
  margin: auto;
  padding-bottom: 32px;
  line-height: 150%;
}
.mission p {
  font-weight: 900;
  font-size: 14px;
  width: 495px;
  margin: auto;
  line-height: 150%;
  color: #d5d5d5;
}

@media (max-width: 980px) {
  .mission {
    padding: 48px 0 100px 0;
    -webkit-clip-path: polygon(0 0, 100% 0px, 100% 100%, 0 calc(100% - 60px));
            clip-path: polygon(0 0, 100% 0px, 100% 100%, 0 calc(100% - 60px));
  }
  .mission h1 {
    font-size: 80px;
    margin-bottom: -32px;
  }
  .mission h2 {
    font-size: 22px;
    width: 425px;
    padding-bottom: 32px;
    max-width: 335px;
  }
  .mission p {
    font-size: 12px;
    max-width: 335px;
  }
}
.about {
  -webkit-clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
          clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
  background-color: #fff;
  padding: 130px 0 130px;
  margin: -130px 0 -130px;
}
.about img {
  width: 463px;
}
.about .title {
  display: flex;
  align-items: center;
}
.about h1 {
  font-weight: 900;
  font-size: 50px;
  line-height: 0.7;
  padding: 137x 0 80px 0;
  color: #28292b;
}
.about span {
  font-size: 16px;
}
.about .title::before {
  content: "";
  width: 52px;
  height: 5px;
  background-color: #19d28e;
  display: block;
  margin: -35px 27px 0 0;
}
.about .box_1 {
  max-width: 960px;
  margin: 0 auto 64px;
  display: flex;
  flex-direction: row-reverse;
}
.about .box_1 .text_1 {
  margin: auto auto auto 0;
  color: #28292b;
}
.about .box_1 h2 {
  font-size: 20px;
  margin-bottom: 32px;
  color: #28292b;
}
.about .box_1 h3 {
  font-size: 48px;
  color: #28292b;
  margin-bottom: 16px;
}
.about .box_1 p {
  font-size: 16px;
  width: 424px;
  line-height: 2;
}
.about .box_2 {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
}
.about .box_2 .text_2 {
  color: #28292b;
  margin: auto 0 auto auto;
}
.about .box_2 h2 {
  font-size: 20px;
  margin-bottom: 32px;
  color: #28292b;
}
.about .box_2 h3 {
  font-size: 48px;
  color: #28292b;
  margin-bottom: 16px;
}
.about .box_2 p {
  font-size: 16px;
  width: 424px;
  line-height: 2;
}

@media (max-width: 980px) {
  .about {
    padding-bottom: 32px;
    -webkit-clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
            clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
    padding: 60px 0 100px;
    margin: -60px 0 -60px;
  }
  .about img {
    display: block;
    width: 300px;
    margin: 0 auto 24px;
  }
  .about .title {
    margin-bottom: 36px;
  }
  .about h1 {
    font-size: 35px;
    margin-left: -22px;
  }
  .about span {
    font-size: 12px;
  }
  .about .title::before {
    content: "";
    width: 20px;
    height: 3px;
    background-color: #19d28e;
    display: block;
    margin: -28px 27px 0 0;
  }
  .about .box_1 {
    max-width: 335px;
    display: block;
    margin: 0 auto 56px;
  }
  .about .box_1 .text_1 {
    max-width: 335px;
  }
  .about .box_1 .text_1 h2 {
    font-size: 16px;
    margin-bottom: 24px;
  }
  .about .box_1 .text_1 h3 {
    font-size: 32px;
    margin-bottom: 8px;
  }
  .about .box_1 .text_1 p {
    max-width: 335px;
    font-size: 14px;
  }
  .about .box_2 {
    max-width: 335px;
    display: block;
  }
  .about .box_2 .text_2 {
    max-width: 335px;
  }
  .about .box_2 h2 {
    font-size: 16px;
    margin-bottom: 24px;
  }
  .about .box_2 h3 {
    font-size: 32px;
    margin-bottom: 8px;
  }
  .about .box_2 p {
    max-width: 335px;
    font-size: 14px;
  }
}
.business {
  -webkit-clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
          clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
  background-color: #28292b;
}
.business .title {
  display: flex;
  align-items: center;
}
.business h1 {
  font-weight: 900;
  font-size: 50px;
  line-height: 0.7;
  padding: 108px 0 80px 0;
}
.business span {
  font-size: 16px;
}
.business .title::before {
  content: "";
  width: 52px;
  height: 5px;
  background-color: #fff;
  display: block;
  margin: -8px 27px 0 0;
}
.business .box {
  margin: 0 auto;
  max-width: 960px;
  display: flex;
  padding-bottom: 108px;
}
.business img {
  width: 290px;
  height: 340px;
}
.business .box_1,
.business .box_2,
.business .box_3 {
  text-align: center;
}
.business .sample_box {
  border: 2px solid #fff;
  height: 340px;
  width: 290px;
  margin: 0 auto;
  overflow: hidden;
}
.business .sample_box img {
  transition: 1s all;
}
.business .sample_box img:hover {
  transform: scale(1.2, 1.2);
  transition: 1s all;
}
.business h2 {
  padding-top: 42px;
  font-size: 24px;
  font-weight: 900;
}
.business p {
  padding-top: 10px;
  font-size: 14px;
}
.business .box_2 {
  margin: 62px 45px 0 45px;
}
.business .box_3 {
  margin-top: 124px;
}

@media (max-width: 980px) {
  .business {
    background-color: #28292b;
    -webkit-clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
            clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
    padding: 60px 0 60px;
    margin: -60px 0 -60px;
    padding: 60px 0 60px;
    margin: -60px 0 -60px;
  }
  .business h1 {
    color: #fff;
    font-size: 35px;
    margin-left: -22px;
    padding: 20px 0 36px 0;
  }
  .business span {
    color: #fff;
    font-size: 12px;
  }
  .business .title::before {
    content: "";
    width: 20px;
    height: 3px;
    background-color: #fff;
    display: block;
    margin: -38px 27px 0 0;
  }
  .business .box {
    margin: 0 auto;
    max-width: 960px;
    display: block;
    padding-bottom: 20px;
  }
  .business img {
    width: 290px;
    height: auto;
  }
  .business .box_1,
  .business .box_2,
  .business .box_3 {
    text-align: center;
  }
  .business h2 {
    padding-top: 24px;
    font-size: 22px;
    font-weight: 900;
  }
  .business p {
    padding-top: 10px;
    font-size: 12px;
  }
  .business .box_2 {
    margin: 42px 0 42px 0;
  }
  .business .box_3 {
    margin-top: 0;
  }
}
.creative {
  -webkit-clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
          clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
  background-color: #fff;
  padding: 130px 0 130px;
  margin: -130px 0 -133px;
  color: #28292b;
}
.creative .title {
  display: flex;
  align-items: center;
}
.creative h1 {
  font-weight: 900;
  font-size: 50px;
  line-height: 0.7;
  padding: 0 0 36px 0;
  color: #28292b;
}
.creative span {
  font-size: 16px;
}
.creative .title::before {
  content: "";
  width: 52px;
  height: 5px;
  background-color: #19d28e;
  display: block;
  margin: -68px 27px 0 0;
}
.creative .box {
  margin: 0 auto;
  max-width: 960px;
  display: flex;
}
.creative .box .box_1,
.creative .box .box_2,
.creative .box .box_3 {
  width: 300px;
}
.creative .box .box_2 {
  margin: 0 auto;
}
.creative img {
  width: 300px;
  height: auto;
  box-shadow: 15px 15px 15px rgba(0, 0, 0, 0.16);
  margin-bottom: 32px;
}
.creative h2 {
  font-weight: 900;
  font-size: 20px;
  margin-bottom: 24px;
}
.creative p {
  font-size: 16px;
  line-height: 32px;
}

@media (max-width: 980px) {
  .creative {
    color: #28292b;
    padding-bottom: 46px;
    -webkit-clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
            clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
    padding: 70px 0 100px;
    margin: -60px 0 -60px;
  }
  .creative h1 {
    font-size: 35px;
    margin-left: -22px;
  }
  .creative span {
    font-size: 12px;
  }
  .creative .title::before {
    content: "";
    width: 20px;
    height: 3px;
    background-color: #19d28e;
    display: block;
    margin: -60px 27px 0 0;
  }
  .creative .box {
    margin: 0 auto;
    display: block;
  }
  .creative .box .box_1,
  .creative .box .box_2,
  .creative .box .box_3 {
    width: 335px;
    margin: 0 auto;
  }
  .creative .box .box_2 {
    margin: 40px auto;
  }
  .creative img {
    width: 335px;
    height: auto;
    margin: 0 auto 24px;
    display: block;
  }
  .creative h2 {
    font-weight: 900;
    font-size: 16px;
    margin-bottom: 16px;
  }
  .creative p {
    font-size: 14px;
    line-height: 1.5;
    max-width: 335px;
  }
}
.company {
  -webkit-clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
          clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
  background: #ededed;
  color: #28292b;
  padding-bottom: 160px;
}
.company .title {
  display: flex;
  align-items: center;
}
.company h1 {
  font-weight: 900;
  font-size: 50px;
  line-height: 0.7;
  padding: 108px 0 80px 0;
  color: #28292b;
}
.company span {
  font-size: 16px;
}
.company .title::before {
  content: "";
  width: 52px;
  height: 5px;
  background-color: #19d28e;
  display: block;
  margin: -5px 27px 0 0;
}
.company .box {
  display: flex;
  flex-direction: row-reverse;
  max-width: 960px;
  margin: 0 auto;
}
.company .text_box {
  margin: auto 0;
}
.company .text_box p {
  font-size: 16px;
  width: 404px;
  line-height: 32px;
}
.company img {
  width: 464px;
  height: auto;
  margin-left: auto;
}
.company a.btn {
  margin: 72px 0 0 0;
}

@media (max-width: 980px) {
  .company {
    -webkit-clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
            clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
    padding: 60px 0 60px;
    margin: -60px 0 -60px;
    background: #ededed;
    color: #28292b;
    padding-bottom: 100px;
  }
  .company .title {
    display: flex;
    align-items: center;
  }
  .company h1 {
    font-size: 35px;
    margin-left: -22px;
    padding: 20px 0 36px 0;
  }
  .company span {
    font-size: 12px;
  }
  .company .title::before {
    content: "";
    width: 20px;
    height: 3px;
    background-color: #19d28e;
    display: block;
    margin: -36px 27px 0 0;
  }
  .company .box {
    display: block;
    max-width: 960px;
    margin: 0 auto;
  }
  .company .text_box {
    margin: auto 0;
  }
  .company .text_box p {
    font-size: 14px;
    width: 335px;
    line-height: 1.5;
    margin: auto;
  }
  .company img {
    width: 335px;
    height: auto;
    margin: auto;
    display: block;
  }
  .company a.btn {
    margin: 56px auto 0;
    text-align: center;
  }
}
.knowledge {
  margin: 0 auto;
  margin-bottom: 64px;
  -webkit-clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
          clip-path: polygon(0 0, 100% 130px, 100% 100%, 0 calc(100% - 130px));
  background-color: #fff;
  padding: 130px 0 130px;
  margin: -133px 0 -133px;
  color: #28292b;
}
.knowledge .title {
  display: flex;
  align-items: center;
}
.knowledge h1 {
  font-weight: 900;
  font-size: 50px;
  line-height: 0.7;
  padding: 0 0 80px 0;
  color: #28292b;
}
.knowledge span {
  font-size: 16px;
}
.knowledge .title::before {
  content: "";
  width: 52px;
  height: 5px;
  background-color: #19d28e;
  display: block;
  margin: -108px 27px 0 0;
}
.knowledge .info_list {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  padding-top: 64px;
  padding-bottom: 32px;
  max-width: 960px;
  margin: 0 auto;
}
.knowledge .info_item {
  width: 30%;
  background: #fff;
  transition: transform 0.3s ease;
}
.knowledge .info_item:hover {
  transform: translateY(-5px);
}
.knowledge .info_image {
  width: 100%;
  height: auto;
  aspect-ratio: 294/180;
  overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  margin-bottom: 16px;
}
.knowledge .info_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.knowledge .info_date {
  padding: 10px 16px;
  margin-bottom: 8px;
}
.knowledge .info_date p {
  color: #666;
  font-size: 0.9rem;
}
.knowledge .info_title {
  padding: 0 16px 0px;
}
.knowledge .info_title p {
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1.5;
}

@media screen and (max-width: 959px) {
  .knowledge {
    padding: 0 20px;
    -webkit-clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
            clip-path: polygon(0 0, 100% 60px, 100% 100%, 0 calc(100% - 60px));
    padding: 80px 0 60px;
    margin: -60px 0 -60px;
  }
  .knowledge h1 {
    font-size: 35px;
    margin-left: -22px;
    padding-bottom: 36px;
  }
  .knowledge span {
    font-size: 12px;
  }
  .knowledge .title::before {
    content: "";
    width: 20px;
    height: 3px;
    background-color: #19d28e;
    display: block;
    margin: -60px 27px 0 0;
  }
  .knowledge .info_list {
    gap: 1.5rem;
    padding: 0 20px;
  }
  .knowledge .info_item {
    width: 100%;
  }
}
.contact {
  background-color: #fff;
  color: #28292b;
  padding-bottom: 80px;
}
.contact .title {
  display: flex;
  align-items: center;
}
.contact h1 {
  font-weight: 900;
  font-size: 50px;
  line-height: 0.7;
  padding: 108px 0 80px 0;
  color: #28292b;
}
.contact span {
  font-size: 16px;
}
.contact .title::before {
  content: "";
  width: 52px;
  height: 5px;
  background-color: #19d28e;
  display: block;
  margin: -7px 27px 0 0;
}
.contact h2 {
  text-align: center;
  font-weight: 500;
  font-size: 16px;
  line-height: 32px;
  margin-bottom: 30px;
}
.contact .form {
  border-radius: 5px;
  display: flex;
  padding: 0 148px;
  margin: 0 auto 22px;
  width: 737px;
  height: 116px;
  text-decoration: none;
  background: linear-gradient(#29eb8b 0%, #24e48c 17%, #19d28e 40%, #06b493 68%, #00ab95 75%, #00ab95 100%);
}
.contact .form img {
  width: 40px;
  height: 49px;
  margin: auto 0;
}
.contact .form span {
  font-weight: 600;
  font-size: 32px;
  border: none;
  color: #fff;
  margin: auto 0 auto auto;
}

@media (max-width: 980px) {
  .contact {
    padding-bottom: 72px;
  }
  .contact h1 {
    font-size: 35px;
    margin-left: -22px;
    padding: 90px 0 36px 0;
  }
  .contact span {
    font-size: 12px;
  }
  .contact .title::before {
    content: "";
    width: 20px;
    height: 3px;
    background-color: #19d28e;
    display: block;
    margin: 30px 27px 0 0;
  }
  .contact h2 {
    text-align: center;
    font-weight: 500;
    font-size: 14px;
    line-height: 2;
    margin: 0 20px 30px;
  }
  .contact .form {
    padding: 28px 30px;
    margin: 0 auto 22px;
    width: 80%;
    height: 87px;
    min-width: 335px;
    display: block;
    text-align: center;
  }
  .contact .form img {
    width: 20px;
    height: auto;
    margin: auto 0;
  }
  .contact .form span {
    font-weight: 600;
    font-size: 20px;
    border: none;
    color: #fff;
    margin: auto 0 auto 10px;
  }
  .contact p {
    font-size: 12px;
    line-height: 2;
    text-align: center;
    margin: 0 20px;
  }
}/*# sourceMappingURL=style.css.map */