@import url("https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("lib/ress.min.css");
.p-btns {
  padding: 5.7rem 0 0;
}
@media screen and (max-width: 767px) {
  .p-btns {
    padding: 2.5rem 0 0;
  }
}
.p-btns .u-flex {
  gap: 2.4rem;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-btns .u-flex {
    flex-direction: column;
    gap: 2.8rem;
  }
}

.p-product {
  padding: 10.8rem 0 0;
}
@media screen and (max-width: 767px) {
  .p-product {
    padding: 5.7rem 0 0;
  }
}
.p-product-items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 5.3rem 0 0;
  row-gap: 6rem;
}
@media screen and (max-width: 767px) {
  .p-product-items {
    padding: 4rem 0 0;
    row-gap: 3.4rem;
  }
}
.p-product-item {
  background: var(--white);
  width: 54.4rem;
}
@media screen and (max-width: 767px) {
  .p-product-item {
    width: 100%;
  }
}
.p-product-item-body {
  border: 1px solid var(--light-blue);
  border-top: none;
  display: flex;
  flex-direction: column;
  min-height: 18rem;
  padding: 2.2rem 1.6rem 1.3rem 0.9rem;
}
@media screen and (max-width: 767px) {
  .p-product-item-body {
    display: block;
    min-height: unset;
    padding: 2.7rem 2.3rem 1rem;
  }
}
.p-product-item-body .ttl {
  flex: 1;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.0714285714;
  letter-spacing: 0.14rem;
  text-align: justify;
}
@media screen and (max-width: 767px) {
  .p-product-item-body .ttl {
    font-size: 1.6rem;
    letter-spacing: 0.08rem;
  }
}
.p-product-item-body > div {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 7rem;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .p-product-item-body > div {
    display: block;
    height: unset;
  }
}
.p-product-item-body > div .company {
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-product-item-body > div .company {
    padding: 1rem 0 2.3rem;
  }
}
.p-product-item-body > div .link {
  align-items: center;
  display: flex;
  gap: 0.8rem;
  justify-content: end;
  font-weight: 700;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .p-product-item-body > div .link {
    gap: 0.6rem;
  }
}
.p-product-item-body > div .link .c-icon-next {
  transform: translateY(0.1rem);
  width: 1rem;
}
@media screen and (max-width: 767px) {
  .p-product-item-body > div .link .c-icon-next {
    width: 0.7rem;
  }
}

.p-case {
  padding: 12.7rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .p-case {
    padding: 8.8rem 0 7.7rem;
  }
}
.p-case-items {
  padding: 6rem 0 0;
}
@media screen and (max-width: 767px) {
  .p-case-items {
    padding: 4.3rem 0 0;
  }
}
.p-case-item-mv .ttl {
  align-items: center;
  background-color: #E7F4FF;
  border-radius: 0 2rem 0 0;
  bottom: 0;
  color: var(--blue);
  display: flex;
  font-family: var(--font-2);
  font-size: 4rem;
  font-weight: 300;
  height: 8.2rem;
  left: 0;
  letter-spacing: 0.2rem;
  padding: 0 3rem;
  position: absolute;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-case-item-mv .ttl {
    border-radius: 0 1.253rem 0 0;
    font-size: 2rem;
    letter-spacing: 0.1rem;
    height: 4.6rem;
    padding: 0.2rem 2.3rem 0 1.5rem;
  }
}
.p-case-item-ttl {
  color: var(--blue);
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 0.14rem;
  line-height: 1.0714285714;
  padding: 3.3rem 0 3.7rem;
}
@media screen and (max-width: 767px) {
  .p-case-item-ttl {
    font-size: 1.8rem;
    letter-spacing: 0.09rem;
    line-height: 1.8888888889;
    padding: 3.8rem 0 3rem;
  }
}
.p-case-item-body {
  display: flex;
  flex-direction: column;
  gap: 3.3rem;
}
@media screen and (max-width: 767px) {
  .p-case-item-body {
    gap: 2.9rem;
  }
}
.p-case-item-body .box {
  background: var(--white);
  border: 1px solid var(--blue);
  border-radius: 0.5rem;
  overflow: hidden;
}
.p-case-item-body .box-head {
  background: var(--blue);
  color: var(--white);
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
  line-height: 1.5;
  padding: 2.3rem 4rem 2.3rem 2.7rem;
}
@media screen and (max-width: 767px) {
  .p-case-item-body .box-head {
    align-items: center;
    display: flex;
    font-size: 1.6rem;
    line-height: 1.375;
    letter-spacing: 0.08rem;
    min-height: 6.7rem;
    padding: 1.1rem 5.3rem 1.1rem 0.9rem;
  }
}
.p-case-item-body .box-body {
  font-weight: 500;
  line-height: 1.875;
  padding: 1.4rem 2.7rem 1.7rem;
}
@media screen and (max-width: 767px) {
  .p-case-item-body .box-body {
    line-height: 1.5714285714;
    padding: 1rem 0.9rem;
  }
}/*# sourceMappingURL=products.css.map */