@charset "UTF-8";

.p-footer {
  position: relative;
  background: transparent linear-gradient(91deg, #011e55 0%, #055893 100%) 0% 0% no-repeat padding-box;
  padding-top: 450px;
}
@media screen and (min-width:1024px) {
  .p-footer {
    padding-top: 126px;
  }
}

.p-contact {
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50%;
  width: min(500px, 100vw - 40px);
  border-radius: 10px;
}
@media screen and (min-width:1024px) {
  .p-contact {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    width: min(1107px, 100vw - 40px);
  }
}

.p-contact__content {
  padding: 40px 20px;
  color: #ffffff;
  position: relative;
}
@media screen and (min-width:1024px) {
  .p-contact__content {
    max-width: 369px;
  }
}

@media screen and (min-width:1200px) {
  .p-contact__content {
    padding: 40px 53.5px;
  }
}

.meeting {
  border-radius: 10px 10px 0 0;
}
@media screen and (min-width:1024px) {
  .meeting {
    border-radius: 10px 0 0 10px;
  }
}
.meeting .p-contact__bg::before {
  border-radius: 10px 10px 0 0;
}
@media screen and (min-width:1024px) {
  .meeting .p-contact__bg::before {
    border-radius: 10px 0 0 10px;
  }
}
.meeting .p-contact__bg img {
  border-radius: 10px 10px 0 0;
}
@media screen and (min-width:1024px) {
  .meeting .p-contact__bg img {
    border-radius: 10px 0 0 10px;
  }
}

.contact .p-contact__btn-text {
  color: #0167B3;
}
.contact .p-contact__btn-text::before {
  top: 4px;
  left: 18px;
  width: 15px;
  height: 12px;
  background: url(../images/contact-mail.svg) no-repeat center center/cover;
}
.contact .p-contact__btn-text::after {
  background: url(../images/contact-arrow.svg) no-repeat center center/cover;
}
.contact .p-contact__bg::before {
  background: url(../images/contact-filter.png) no-repeat center center/cover;
}

.partner {
  border-radius: 0 0 10px 10px;
}
@media screen and (min-width:1024px) {
  .partner {
    border-radius: 0 10px 10px 0;
  }
}
.partner .p-contact__btn-text {
  color: #2680E9;
}
.partner .p-contact__btn-text::before {
  top: 3px;
  left: 17px;
  width: 17.14px;
  height: 13px;
  background: url(../images/contact-partner.svg) no-repeat center center/cover;
}
.partner .p-contact__btn-text::after {
  background: url(../images/contact-arrow-partner.svg) no-repeat center center/cover;
}
.partner .p-contact__bg::before {
  border-radius: 0 0 10px 10px;
  background: url(../images/partner-filter.png) no-repeat center center/cover;
}
@media screen and (min-width:1024px) {
  .partner .p-contact__bg::before {
    border-radius: 0 10px 10px 0;
  }
}
.partner .p-contact__bg img {
  border-radius: 0 0 10px 10px;
}
@media screen and (min-width:1024px) {
  .partner .p-contact__bg img {
    border-radius: 0 10px 10px 0;
  }
}

.p-contact__head {
  text-align: center;
}

.p-contact__title-ja {
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: 1.1px;
  font-weight: 700;
}

.p-contact__title-en {
  padding-top: 3px;
  font-family: "Lato", sans-serif;
  font-size: 12px;
  line-height: 1.25;
  letter-spacing: 2.52px;
  font-weight: 500;
}

.p-contact__desc {
  margin-top: 30px;
  font-size: 15px;
  line-height: 1.8;
  letter-spacing: 1.2px;
  font-weight: 500;
}

.p-contact__btn {
  display: block;
  margin-top: 25px;
  padding-block: 15px;
  max-width: 262px;
  margin-inline: auto;
  border-radius: 4px;
  background: #ffffff;
  border: 1px solid #ffffff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-contact__btn:hover {
    background: transparent;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    opacity: 1;
  }
  .p-contact__btn:hover .p-contact__btn-text {
    color: #ffffff;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
}

.p-contact__btn-text {
  padding-inline: 45px;
  color: #004C98;
  font-size: 13px;
  line-height: 1.4615384615;
  letter-spacing: 1.04px;
  font-weight: 500;
  position: relative;
}
.p-contact__btn-text::before {
  content: "";
  position: absolute;
  top: 2.5px;
  left: 16.97px;
  width: 17.11px;
  height: 14px;
  background: url(../images/contact-users.svg) no-repeat center center/cover;
}
.p-contact__btn-text::after {
  content: "";
  position: absolute;
  top: 6px;
  right: 22.52px;
  width: 10px;
  height: 8px;
  background: url(../images/contact-arrow-meeting.svg) no-repeat center center/cover;
}

.p-contact__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.p-contact__bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../images/meeting-filter.png) no-repeat center center/cover;
  pointer-events: none;
}

.p-footer__wrap {
  padding-block: 450px 168px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  background: #f5f5f5;
  border-radius: 40px 40px 0px 0px;
}
@media screen and (min-width:1024px) {
  .p-footer__wrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 20px;
    padding-block: 226px 168px;
  }
}

@media screen and (min-width:1367px) {
  .p-footer__wrap {
    padding-inline: calc((100vw - 1366px) / 2);
  }
}

.p-footer__info {
  padding-top: 37px;
  padding-left: 20px;
}
@media screen and (min-width:768px) {
  .p-footer__info {
    padding-left: 50px;
  }
}
@media screen and (min-width:1024px) {
  .p-footer__info {
    padding-left: 100px;
  }
}
@media screen and (min-width:1200px) {
  .p-footer__info {
    padding-left: 130px;
  }
}

.p-footer__logo {
  width: 142px;
  height: 38px;
}

.p-footer__menu {
  margin-top: 64px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-footer__menu-line:nth-of-type(n + 2) {
  margin-left: 30px;
}
@media screen and (min-width:768px) {
  .p-footer__menu-line:nth-of-type(n + 2) {
    margin-left: 60px;
  }
}
@media screen and (min-width:1200px) {
  .p-footer__menu-line:nth-of-type(n + 2) {
    margin-left: 120px;
  }
}

.p-footer__menu-line a:nth-of-type(n + 2) {
  margin-top: 38px;
}


.business .c-link.gray {
  margin-top: 0;
}
.business .c-link.gray {
  margin-top: 15px;
}
.business .c-link.gray .p-footer__menu-text {
  color: #5C5C5C;
  font-size: 13px;
  line-height: 1.4615384615;
}
.business .c-link.gray:first-of-type {
  margin-top: 26px;
}

.p-footer__menu-text {
  color: #032159;
  font-size: 14px;
  line-height: 1.4285714286;
  font-weight: 500;
}

.p-footer__icons {
  margin-top: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
}

.p-footer__icon {
  width: 40px;
  height: 40px;
}
.p-footer__bg-text {
  margin-left: auto;
  width: clamp(150px, 32.2840409956vw, 441px);
}

.p-copyright-wrap {
  padding-block: 52px 49px;
  border-radius: 40px 40px 0px 0px;
  background: #022159;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 110px;
}

.p-copyright-text {
  font-size: 11px;
  line-height: 1.5454545455;
  letter-spacing: 0.55px;
  color: #eff0ef;
  text-align: center;
}