@charset "UTF-8";
/* Sass Document */
.l-content__ttl .u-jp {
  font-size: 1.2rem;
  text-align: center;
}
@media screen and (min-width: 992px) {
  .l-content__ttl .u-jp {
    font-size: 2.4rem;
  }
}

.u-img-ttl {
  max-width: 178px;
}
@media screen and (min-width: 992px) {
  .u-img-ttl {
    max-width: 428px;
  }
}

.p-about__content {
  padding-top: 50px;
  padding-bottom: 46px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-about__content {
    padding-top: 89px;
    padding-bottom: 0;
  }
}
.p-about__content::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
          clip-path: polygon(0 0, 100% 100%, 100% 0);
  height: 96px;
  background-color: #f2f7fc;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .p-about__content::before {
    height: 310px;
  }
}
.p-about__content::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 379px;
  -webkit-clip-path: polygon(0 105px, 100% 0, 100% 100%, 0% 100%);
          clip-path: polygon(0 105px, 100% 0, 100% 100%, 0% 100%);
  z-index: -1;
  background: linear-gradient(0deg, rgba(242, 247, 252, 0) 0%, rgb(242, 247, 252) 100%);
}
@media screen and (min-width: 768px) {
  .p-about__content::after {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .p-about__inner {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    gap: 0 24px;
  }
}

.p-about__ttl {
  font-size: 2.7rem;
  font-weight: 800;
  color: #1655a2;
  text-align: center;
  margin: 0 auto 35px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1.4444444444;
  background: linear-gradient(180deg, rgba(245, 231, 50, 0) 60%, rgb(245, 231, 50) 60%, rgb(245, 231, 50) 100%);
}
@media screen and (min-width: 992px) {
  .p-about__ttl {
    font-size: 3.6rem;
    margin-left: 0;
    margin-bottom: 20px;
    padding: 0 10px;
    background: linear-gradient(180deg, rgba(245, 231, 50, 0) 70%, rgb(245, 231, 50) 70%, rgb(245, 231, 50) 100%);
  }
}

.p-about___img-wrapper {
  margin: 20px 0 0;
}
@media screen and (min-width: 768px) {
  .p-about___img-wrapper {
    max-width: 496px;
    width: 45.9259259259%;
    flex-shrink: 0;
  }
}

.c-txt {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.7142857143;
}
.c-txt + .c-txt {
  margin-top: 2em;
}
@media screen and (min-width: 768px) {
  .c-txt {
    font-size: 1.6rem;
    line-height: 1.5625;
  }
}

.c-section__ttl {
  font-size: 2.4rem;
  text-align: center;
  color: #1655a2;
  line-height: 1.3333333333;
  position: relative;
  padding-top: 30px;
}
@media screen and (min-width: 992px) {
  .c-section__ttl {
    font-size: 3.6rem;
    line-height: 1.4444444444;
  }
}
.c-section__ttl::before {
  content: "";
  width: 40px;
  height: 18px;
  left: 0;
  right: 0;
  top: 0;
  margin: 0 auto;
  position: absolute;
  background: url(../img/about/deco_ttl.svg) no-repeat center center/100% 100%;
}

.p-reason {
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-reason {
    padding-top: 64px;
  }
}

.p-reason__list {
  margin-top: 20px;
}

@media screen and (min-width: 768px) {
  .p-reason__item {
    display: flex;
    gap: 0 40px;
  }
}
.p-reason__item + .p-reason__item {
  margin-top: 25px;
}
@media screen and (min-width: 768px) {
  .p-reason__item + .p-reason__item {
    margin-top: 40px;
  }
}

.p-reason__img-block {
  position: relative;
  max-width: 88.0597014925%;
  padding-bottom: 40px;
  margin: 20px auto 0;
}
@media screen and (min-width: 768px) {
  .p-reason__img-block {
    width: 44.4444444444%;
    max-width: 480px;
    flex-shrink: 0;
    margin: 0;
  }
}
.p-reason__img-block::after {
  content: "";
  position: absolute;
  z-index: -1;
  width: 100vw;
  left: 40px;
  top: 40px;
  height: calc(100% - 40px);
  background-color: #f2f7fc;
}

@media screen and (min-width: 768px) {
  .p-reason__item:nth-of-type(even) {
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 992px) {
  .p-reason__item:nth-of-type(even) {
    gap: 0 120px;
  }
}
.p-reason__item:nth-of-type(even) .p-reason__img-block::after {
  left: auto;
  right: 40px;
}

@media screen and (min-width: 1280px) {
  .p-reason__item:nth-of-type(even) .p-reason__txt-wrapper {
    margin-right: -86px;
  }
}
.p-reason__txt-wrapper {
  flex-grow: 1;
}

.p-reason__img-wrapper {
  margin: 0;
  box-shadow: 5px 6px 5px 2px rgba(35, 24, 21, 0.16);
  aspect-ratio: 480/320;
  overflow: hidden;
  border-radius: 4px;
}
@media screen and (min-width: 768px) {
  .p-reason__img-wrapper {
    border-radius: 8px;
  }
}
.p-reason__img-wrapper img {
  width: 101%;
  height: 101%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-reason__num {
  font-size: 1.3rem;
  font-weight: 700;
  color: #1655a2;
  position: relative;
  display: block;
}
@media screen and (min-width: 768px) {
  .c-reason__num {
    font-size: 2.4rem;
    margin-left: 15px;
    margin-top: 20px;
  }
}
.c-reason__num::before {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  background-color: #dae6f5;
  left: -9px;
  top: -7px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .c-reason__num::before {
    width: 32px;
    height: 32px;
    left: -19px;
    top: -20px;
  }
}

.c-reason__ttl {
  font-size: 2rem;
  line-height: 1.5;
  font-weight: 700;
  color: #1655a2;
  margin: 10px 0;
}
@media screen and (min-width: 992px) {
  .c-reason__ttl {
    font-size: 2.7rem;
    line-height: 1.4;
    margin: 25px 0 20px;
    color: #00355d;
  }
}

/* ----------------------------------------------------------------------------------------------------
*	サービスについて
* --------------------------------------------------------------------------------------------------*/
.p-service {
  padding-top: 40px;
}
@media screen and (min-width: 768px) {
  .p-service {
    padding-top: 80px;
  }
}

.p-service__list {
  padding-top: 20px;
}
@media screen and (min-width: 768px) {
  .p-service__list {
    margin-top: 40px;
    display: flex;
    flex-wrap: wrap;
    gap: 50px 1.3888888889%;
    padding-top: 35px;
    justify-content: center;
  }
}
@media screen and (min-width: 992px) {
  .p-service__list {
    gap: 0 1.3888888889%;
    justify-content: space-between;
  }
}

.p-service__item {
  border: 1px solid #1655a2;
  border-radius: 0 8px 8px 8px;
  position: relative;
  margin-top: 35px;
  padding: 30px 20px;
}
@media screen and (min-width: 768px) {
  .p-service__item {
    margin-top: 0;
    width: 48%;
    display: flex;
    flex-direction: column;
  }
}
@media screen and (min-width: 992px) {
  .p-service__item {
    width: 32.4074074074%;
    margin-top: 0;
  }
  .p-service__item:nth-of-type(1) {
    padding-bottom: 38px;
  }
  .p-service__item:nth-of-type(3) {
    padding-bottom: 38px;
  }
  .p-service__item:nth-of-type(3) .c-txt {
    margin-bottom: 0;
  }
}
.p-service__item + .p-service__item {
  margin-top: 55px;
}
@media screen and (min-width: 768px) {
  .p-service__item + .p-service__item {
    margin-top: 0;
  }
}
.p-service__item .c-txt {
  font-size: 1.6rem;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .p-service__item .c-txt {
    margin-bottom: 33px;
  }
}
.p-service__item .c-ill {
  margin: 20px auto 0;
  width: 29.4915254237%;
}
@media screen and (min-width: 992px) {
  .p-service__item .c-ill {
    margin: 10px auto 20px;
  }
}
.p-service__item .c-ill + .p-btn-wrapper {
  margin-top: 20px;
}
@media screen and (min-width: 992px) {
  .p-service__item .c-ill + .p-btn-wrapper {
    margin-top: auto;
  }
}
.p-service__item .p-btn-wrapper {
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .p-service__item .p-btn-wrapper {
    margin-top: auto;
  }
}

.c-icn-btn {
  min-width: 166px;
  font-size: 1.4rem;
  font-weight: 700;
  border: 1px solid #1655a2;
  border-radius: 100px;
  text-decoration: none;
  color: #1655a2;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-height: 50px;
  padding: 6px 58px 6px 27px;
  position: relative;
  margin: 0 auto;
  display: flex;
  align-items: center;
  line-height: 1.4285714286;
}
@media (any-hover) {
  .c-icn-btn {
    transition: 0.3s;
  }
  .c-icn-btn:hover {
    opacity: 0.7;
  }
}
@media screen and (min-width: 992px) {
  .c-icn-btn {
    font-size: 1.6rem;
    line-height: 1.375;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 22px;
    min-width: 220px;
  }
}
.c-icn-btn::before, .c-icn-btn::after {
  content: "";
  position: absolute;
  top: 50%;
}
.c-icn-btn::before {
  width: 40px;
  height: 40px;
  background-color: #ddebf7;
  border-radius: 50%;
  transform: translateY(-50%);
  right: 5px;
}
@media screen and (min-width: 992px) {
  .c-icn-btn::before {
    right: 9px;
  }
}
.c-icn-btn::after {
  width: 6px;
  height: 6px;
  border-top: 2px solid #1655a2;
  border-right: 2px solid #1655a2;
  right: 22px;
  transform: translateY(-50%) rotate(45deg);
  z-index: 1;
}
@media screen and (min-width: 992px) {
  .c-icn-btn::after {
    right: 25px;
  }
}
.c-icn-btn.u-pl {
  padding-left: 40px;
  padding-right: 53px;
}
@media screen and (min-width: 992px) {
  .c-icn-btn.u-pl {
    padding-left: 22px;
  }
}
.c-icn-btn.u-pr {
  padding-right: 71px;
}

@media screen and (min-width: 769px) and (max-width: 1032px) {
  .p-service__item:nth-of-type(1) {
    padding-bottom: 35px;
  }
  .p-service__item:nth-of-type(3) {
    padding-bottom: 35px;
  }
  .c-icn-btn {
    font-size: 1.4rem;
  }
}
.c-point {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #1655a2;
  border-radius: 10px 10px 0 0;
  font-size: 1.6rem;
  color: #fff;
  padding: 10px;
  position: absolute;
  left: -1px;
  bottom: 100%;
}
@media screen and (min-width: 992px) {
  .c-point {
    font-size: 1.8rem;
    padding: 10px 20px;
  }
}

.c-service__ttl {
  font-size: 2rem;
  line-height: 1.5;
  font-weight: 700;
  color: #1655a2;
  text-align: center;
}

.p-service__ttl-wrapper {
  margin-left: -10px;
  margin-right: -10px;
  margin-bottom: 20px;
}
@media screen and (min-width: 992px) {
  .p-service__ttl-wrapper {
    display: grid;
    place-content: center;
  }
}

/* ----------------------------------------------------------------------------------------------------
*	商品ラインナップ
* --------------------------------------------------------------------------------------------------*/
.p-products {
  padding-top: 68px;
  padding-bottom: 68px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-products {
    padding-top: 80px;
  }
}
.p-products::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100%;
  background-color: #f2f7fc;
  z-index: -1;
  -webkit-clip-path: polygon(0 57px, 100% 111px, 100% calc(100% - 56px), 0 calc(100% - 107px));
          clip-path: polygon(0 57px, 100% 111px, 100% calc(100% - 56px), 0 calc(100% - 107px));
}
@media screen and (min-width: 992px) {
  .p-products::after {
    -webkit-clip-path: polygon(0 170px, 100% 355px, 100% calc(100% - 80px), 0 calc(100% - 279px));
            clip-path: polygon(0 170px, 100% 355px, 100% calc(100% - 80px), 0 calc(100% - 279px));
  }
}

.p-product__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 20px;
  gap: 20px 0;
}
@media screen and (min-width: 768px) {
  .p-product__list {
    margin-top: 40px;
    justify-content: center;
    gap: 40px 1.8518518519%;
  }
}

.p-product__item {
  width: 47.7611940299%;
}
@media screen and (min-width: 768px) {
  .p-product__item {
    width: 23.6111111111%;
  }
  .p-product__item:first-of-type {
    margin-left: 40px;
  }
  .p-product__item:nth-of-type(3) {
    margin-right: 40px;
  }
  .p-product__item:nth-of-type(7) .p-product__img-wrapper {
    border: none;
  }
}
.p-product__item a {
  text-decoration: none;
  color: currentColor;
}
@media (any-hover) {
  .p-product__item a {
    transition: 0.3s;
  }
  .p-product__item a:hover {
    opacity: 0.7;
  }
}
.p-product__item a .c-product__ttl {
  position: relative;
  padding-right: 15px;
}
.p-product__item a .c-product__ttl::after {
  content: "";
  position: absolute;
  width: 4px;
  height: 4px;
  border-top: 1px solid #1655a2;
  border-right: 1px solid #1655a2;
  right: 0;
  top: 55%;
  transform: translateY(-50%) rotate(45deg);
}
@media screen and (min-width: 768px) {
  .p-product__item a .c-product__ttl::after {
    width: 8px;
    height: 8px;
    border-width: 2px;
  }
}

.c-product__ttl {
  font-size: 1.4rem;
  font-weight: 700;
  color: #1655a2;
  line-height: 1.4285714286;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 992px) {
  .c-product__ttl {
    font-size: 2rem;
  }
}

.p-product__img-wrapper {
  margin: 0 0 10px 0;
  aspect-ratio: 160/106;
  border-radius: 4px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-product__img-wrapper {
    border: 1px solid #ddebf7;
  }
}
.p-product__img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* ----------------------------------------------------------------------------------------------------
*	
* --------------------------------------------------------------------------------------------------*/
.p-download {
  background-color: rgba(74, 179, 192, 0.1);
  padding: 50px 0;
  overflow: hidden;
}

.p-download__wrapper {
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .p-download__wrapper {
    display: flex;
    max-width: 964px;
    margin: 40px auto 0;
    justify-content: space-between;
  }
}

.p-download__content {
  background-color: #fff;
  padding: 20px;
  border-radius: 4px;
}
@media screen and (min-width: 768px) {
  .p-download__content {
    width: 47.7178423237%;
    flex-shrink: 0;
    border-radius: 8px;
    padding-top: 40px;
    padding-bottom: 40px;
    display: flex;
    flex-direction: column;
  }
}
.p-download__content .c-icn {
  display: block;
  margin: 0 auto 20px;
}
.p-download__content .c-icn01 {
  width: 40.6779661017%;
}
@media screen and (min-width: 768px) {
  .p-download__content .c-icn01 {
    width: 34.7826086957%;
  }
}
.p-download__content .c-icn02 {
  width: 49.4915254237%;
}
@media screen and (min-width: 768px) {
  .p-download__content .c-icn02 {
    width: 45.652173913%;
  }
}
.p-download__content .p-btn-wrapper {
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .p-download__content .p-btn-wrapper {
    margin-top: auto;
  }
}
.p-download__content .c-btn-download {
  font-size: 1.4rem;
  align-items: center;
  justify-content: flex-start;
  padding-left: 35px;
}
@media screen and (min-width: 768px) {
  .p-download__content .c-btn-download {
    font-size: 1.6rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding-right: 53px;
    margin-left: auto;
    margin-right: auto;
  }
}
.p-download__content + .p-download__content {
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .p-download__content + .p-download__content {
    margin-top: 0;
  }
}

.c-download__ttl {
  font-size: 1.8rem;
  line-height: 1.5555555556;
  text-align: center;
  color: #4ab3c0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  .c-download__ttl {
    margin-bottom: 30px;
  }
}
@media screen and (min-width: 992px) {
  .c-download__ttl {
    font-size: 2rem;
    line-height: 1.6;
    margin: 0 0 30px 0;
  }
}

@media screen and (max-width: 365px) {
  .c-download__ttl {
    margin-left: 0;
    margin-right: 0;
  }
}
/*# sourceMappingURL=about.css.map */