* {
  color: inherit;
  box-sizing: border-box;
}

html, body, p, h1, h2, h3, h4, ul, ol, img, figure, dl, dd, dt {
  margin: 0;
  padding: 0;
}

ul, ol {
  list-style-type: none;
}

figure {
  line-height: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

html {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
}

body {
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  body {
    font-size: 1.4rem;
  }
}

.is-pc {
  display: block;
}
@media screen and (max-width: 767px) {
  .is-pc {
    display: none;
  }
}
.is-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .is-sp {
    display: block;
  }
}
.is-tab {
  display: none;
}
@media screen and (max-width: 999px) {
  .is-tab {
    display: block;
  }
}

.main#for-business {
  overflow-x: hidden;
}

.ttl {
  color: #E4007F;
  background: linear-gradient(to bottom, transparent 80%, #E6F6FF 20%);
  font-size: 5.5rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .ttl {
    font-size: 3rem;
  }
}
.ttl.white {
  background: linear-gradient(to bottom, transparent 80%, #fff 20%);
}
.ttl--lg {
  font-family: Lato, sans-serif;
  font-size: 10.3rem;
}
@media screen and (max-width: 767px) {
  .ttl--lg {
    font-size: 6rem;
  }
}
.ttl--sm {
  font-size: 4.2rem;
}
@media screen and (max-width: 767px) {
  .ttl--sm {
    font-size: 2.2rem;
  }
}

.mv {
  position: relative;
  height: 100%;
  padding: 10.8rem 4rem 6.6rem 9.4rem;
  background: url(../img/img_mv.png) no-repeat 0 0/cover;
}
@media screen and (max-width: 767px) {
  .mv {
    padding: 3rem 2.2rem 6.7rem;
    background: url(../img/img_mv-sp.png) no-repeat 0 0/cover;
  }
}
.mv__inner {
  display: flex;
  flex-direction: column;
  gap: 6.6rem;
  max-width: 130rem;
  width: 100%;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .mv__inner {
    gap: 13.2rem;
  }
}
.mv__inner h1 {
  font-size: 5rem;
  font-weight: 700;
  filter: drop-shadow(0 0 0.4rem rgba(0, 0, 0, 0.39)) drop-shadow(0 0.4rem 0.4rem rgba(0, 0, 0, 0.25));
}
@media screen and (max-width: 767px) {
  .mv__inner h1 {
    font-size: 3rem;
  }
}
.mv__text {
  font-size: 2.5rem;
  font-weight: 700;
  filter: drop-shadow(0 0 0.9rem rgba(15, 39, 119, 0.93)) drop-shadow(0 0 1.3rem #0F2777);
}
@media screen and (max-width: 767px) {
  .mv__text {
    font-size: 1.5rem;
  }
}
.mv__text--sm {
  font-size: 3.8rem;
}
@media screen and (max-width: 767px) {
  .mv__text--sm {
    font-size: 2.6rem;
  }
}

.point {
  margin-top: 6.3rem;
}
.point img {
  width: auto;
  margin: 0 auto;
}
.point__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(auto, 62rem));
  gap: 3.8rem 1.2rem;
  max-width: 125.2rem;
  width: 100%;
  margin: 6.3rem auto 0;
}
@media screen and (max-width: 1251px) {
  .point__grid {
    grid-template-columns: repeat(auto-fit, minmax(auto, calc(50% - 0.6rem)));
    max-width: 100rem;
    padding: 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .point__grid {
    grid-template-columns: 1fr;
  }
}
.point__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 2.9rem;
  padding: 3.1rem 0.3rem 3.8rem;
  border: 0.3rem solid #0F2777;
  border-radius: 4.9rem;
  background-color: #fff;
  filter: drop-shadow(0 1.4rem 0 #E6F6FF);
}
@media screen and (max-width: 999px) {
  .point__item {
    grid-template-rows: auto;
    grid-template-columns: 15rem 1fr;
    padding: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  .point__item {
    grid-template-columns: 9.9rem 1fr;
    gap: 0.5rem;
    padding: 2.1rem 1rem 3rem 0.9rem;
    border-radius: 3.1rem;
  }
}
.point__img {
  text-align: center;
}
@media screen and (max-width: 999px) {
  .point__img {
    grid-area: 1/1/3/2;
    margin: auto 0;
  }
}
@media screen and (max-width: 999px) {
  .point__img img {
    width: 100%;
  }
}
.point__ttl {
  margin: auto 0;
  color: #E4007F;
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 1251px) {
  .point__ttl {
    font-size: 3.4rem;
  }
}
@media screen and (max-width: 999px) {
  .point__ttl {
    grid-area: 1/2/2/3;
  }
}
@media screen and (max-width: 767px) {
  .point__ttl {
    font-size: 1.8rem;
  }
}
.point__desc {
  color: #0F2777;
  font-size: 2.5rem;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 1251px) {
  .point__desc {
    font-size: 2rem;
  }
}
@media screen and (max-width: 999px) {
  .point__desc {
    grid-area: 2/2/3/3;
  }
}
@media screen and (max-width: 767px) {
  .point__desc {
    font-size: 1.5rem;
  }
}

.flow {
  display: flex;
  flex-direction: column;
  gap: 7.2rem;
  margin-top: 22.7rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .flow {
    margin-top: 10.3rem;
  }
}
.flow__inner {
  display: flex;
  flex-direction: column;
  gap: 5.6rem;
  max-width: 126rem;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 1251px) {
  .flow__inner {
    padding: 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .flow__inner {
    gap: 2rem;
  }
}
.flow__inner p {
  color: #0F2777;
  font-size: 2.2rem;
  font-weight: 500;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .flow__inner p {
    max-width: 29.2rem;
    width: 100%;
    margin: 0 auto;
    padding-left: 1em;
    font-size: 1.2rem;
    text-align: left;
    text-indent: -1em;
  }
}

.item-list {
  margin-top: 7.9rem;
  padding: 8.7rem 1.5rem 0;
  background-color: #E6F6FF;
}
.item-list .ttl__wrapper {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  max-width: 125.2rem;
  width: 100%;
  margin: 0 auto;
}
.item-list__ttl {
  padding: 1.5rem 0;
  color: #fff;
  background-color: #0F2777;
  border-radius: 5.2rem;
  font-size: 5rem;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .item-list__ttl {
    font-size: 2rem;
  }
}
.item-list__ttl--sub {
  color: #E4007F;
  font-size: 2.2rem;
  font-weight: 500;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .item-list__ttl--sub {
    font-size: 1.2rem;
    text-align: center;
  }
}
.item-list__grid {
  display: grid;
  grid-template-columns: repeat(3, 40rem);
  gap: 2.7rem;
}
@media screen and (max-width: 1251px) {
  .item-list__grid {
    grid-template-columns: repeat(3, calc(33.3333333333% - 1.8rem));
    max-width: 100rem;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .item-list__grid {
    grid-template-columns: 1fr;
    gap: 1.6rem;
  }
}
.item-list__card {
  display: grid;
}
.item-list__card .wrapper {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  padding: 4rem 1.9rem;
  border-radius: 5rem;
  background-color: #fff;
}
@media screen and (max-width: 1251px) {
  .item-list__card .wrapper {
    border-radius: 3rem;
  }
}
@media screen and (max-width: 767px) {
  .item-list__card .wrapper {
    grid-template-columns: 13.1rem 1fr;
    grid-template-rows: auto;
    padding: 2.7rem 1.9rem;
    border-radius: 1.2rem;
  }
}
.item-list__card--img {
  max-height: 36.2rem;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .item-list__card--img {
    grid-area: 1/1/3/2;
    display: flex;
    align-items: center;
  }
}
.item-list__card--ttl {
  color: #0F2777;
  font-size: 4.5rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .item-list__card--ttl {
    grid-area: 1/2/2/3;
    font-size: 3rem;
  }
}
.item-list__card--desc {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  margin-top: auto;
  padding-top: 2.1rem;
}
@media screen and (max-width: 767px) {
  .item-list__card--desc {
    padding-top: 0.7rem;
    grid-area: 2/2/3/3;
  }
}
.item-list__card--desc p {
  padding: 0.8rem 0;
  border: 0.3rem solid #0F2777;
  border-radius: 0.9rem;
  color: #0F2777;
  font-size: 2.5rem;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .item-list__card--desc p {
    font-size: 1.5rem;
  }
}
.item-list__wifi, .item-list__sim {
  display: flex;
  flex-direction: column;
  gap: 4.6rem;
  max-width: 125.2rem;
  width: 100%;
  margin: 0 auto;
  margin-top: 5.5rem;
}
@media screen and (max-width: 767px) {
  .item-list__wifi, .item-list__sim {
    gap: 1.6rem;
  }
}
.item-list__wifi .wifi-1, .item-list__sim .wifi-1 {
  grid-area: 1/1/2/4;
  max-width: 40rem;
}
@media screen and (max-width: 1251px) {
  .item-list__wifi .wifi-1, .item-list__sim .wifi-1 {
    max-width: calc(33.3333333333% - 1.8rem);
  }
}
@media screen and (max-width: 767px) {
  .item-list__wifi .wifi-1, .item-list__sim .wifi-1 {
    grid-area: auto;
    max-width: none;
    width: 100%;
  }
}
.item-list__wifi .wifi-2, .item-list__sim .wifi-2 {
  grid-area: 2/1/3/2;
}
@media screen and (max-width: 767px) {
  .item-list__wifi .wifi-2, .item-list__sim .wifi-2 {
    grid-area: auto;
  }
}
.item-list__wifi .wifi-3, .item-list__sim .wifi-3 {
  grid-area: 2/2/3/3;
}
@media screen and (max-width: 767px) {
  .item-list__wifi .wifi-3, .item-list__sim .wifi-3 {
    grid-area: auto;
  }
}
.item-list__wifi .wifi-4, .item-list__sim .wifi-4 {
  grid-area: 2/3/3/4;
}
@media screen and (max-width: 767px) {
  .item-list__wifi .wifi-4, .item-list__sim .wifi-4 {
    grid-area: auto;
  }
}
.item-list__wifi.wifi-docomo, .item-list__sim.wifi-docomo {
  margin-top: 16.1rem;
}
@media screen and (max-width: 767px) {
  .item-list__wifi.wifi-docomo, .item-list__sim.wifi-docomo {
    margin-top: 4.8rem;
  }
}
.item-list__sim {
  margin-top: 16.1rem;
}
@media screen and (max-width: 767px) {
  .item-list__sim {
    margin-top: 4.8rem;
  }
}
.item-list__btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3.4rem 0;
  color: #fff;
  border-radius: 5.7rem;
  background-color: #E4007F;
  font-size: 5.3rem;
  font-weight: 700;
  filter: drop-shadow(0 1.1rem 0 rgba(0, 0, 0, 0.25));
  transition: opacity 0.3s;
}
.item-list__btn:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .item-list__btn {
    padding: 1.1rem 0;
    border-radius: 1.8rem;
    font-size: 1.6rem;
    filter: drop-shadow(0 0.5rem 0 rgba(0, 0, 0, 0.25));
  }
}
.item-list__btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 7rem;
  transform: translate(-50%, -50%);
  display: block;
  width: 2.5rem;
  height: 4.5rem;
  background: url(../img/ico_btn-arrow.svg) no-repeat 0 0/cover;
}
@media screen and (max-width: 767px) {
  .item-list__btn::after {
    right: 2rem;
    width: 0.7rem;
    height: 1.5rem;
  }
}
.item-list__btn.estimate::before {
  content: "";
  display: block;
  width: 13.3rem;
  height: 13.3rem;
  background: url(../img/ico_btn.svg) no-repeat 0 0/cover;
}
@media screen and (max-width: 767px) {
  .item-list__btn.estimate::before {
    width: 4.28rem;
    height: 4.28rem;
  }
}
.item-list__btn.mail {
  padding: 6.1rem 0 6.4rem;
}
@media screen and (max-width: 767px) {
  .item-list__btn.mail {
    padding: 1.8rem 0;
  }
}
.item-list__btn.mail::before {
  content: "";
  display: block;
  width: 10.6rem;
  height: 7.6rem;
  margin-right: 1.6rem;
  background: url(../img/ico_mail.svg) no-repeat 0 0/cover;
}
@media screen and (max-width: 767px) {
  .item-list__btn.mail::before {
    width: 4.2rem;
    height: 3rem;
  }
}
.item-list__btn.dairiten {
  background-color: #00A0E9;
}
.item-list__btn.dairiten::before {
  content: "";
  display: block;
  width: 10.7rem;
  height: 8.9rem;
  margin-right: 1.6rem;
  background: url(../img/ico_dairiten.svg) no-repeat 0 0/cover;
}
@media screen and (max-width: 767px) {
  .item-list__btn.dairiten::before {
    width: 5.1rem;
    height: 4.2rem;
  }
}
.item-list__estimate {
  display: flex;
  flex-direction: column;
  gap: 4.3rem;
  max-width: 96.3rem;
  width: 100%;
  margin: 12.6rem auto 0;
  padding: 7.8rem 1rem;
}
@media screen and (max-width: 767px) {
  .item-list__estimate {
    gap: 1.5rem;
    margin: 8.4rem auto 0;
    padding: 3.6rem 1rem;
  }
}
.item-list__estimate p {
  color: #0F2777;
  font-size: 6.1rem;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .item-list__estimate p {
    font-size: 2rem;
  }
}

.payment {
  max-width: none;
  margin: 0;
  padding: 18.9rem 0 15.1rem;
  background-color: #E6F6FF;
}
@media screen and (max-width: 767px) {
  .payment {
    padding: 4.3rem 0 3.6rem;
  }
}
.payment__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10rem 3rem;
  max-width: 126rem;
  width: 100%;
  margin: 10rem auto 0;
}
@media screen and (max-width: 999px) {
  .payment__list {
    display: grid;
    grid-template-columns: repeat(2, calc(50% - 2rem));
    max-width: 100rem;
    padding: 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .payment__list {
    display: grid;
    grid-template-columns: repeat(2, 16rem);
    gap: 6rem 1.1rem;
    padding: 0 2rem;
  }
}
.payment__item {
  position: relative;
  display: block;
  max-width: 40rem;
  width: 100%;
  margin: 0 auto;
  padding: 8rem 2.5rem 3.4rem;
  border-radius: 5rem;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .payment__item {
    padding: 3.4rem 0.7rem 2.5rem;
    border-radius: 1.7rem;
  }
}
.payment__item::before {
  content: "";
  position: absolute;
  top: -6rem;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: 13.7rem;
  height: 13.7rem;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .payment__item::before {
    top: -4rem;
    width: 6.6rem;
    height: 6.6rem;
  }
}
.payment__item figure {
  margin: 1.9rem auto 0;
}
.payment__item:nth-of-type(1) figure {
  max-width: 37.2rem;
}
@media screen and (max-width: 767px) {
  .payment__item:nth-of-type(1) figure {
    max-width: 14.7rem;
  }
}
.payment__item:nth-of-type(1)::before {
  background-image: url(../img/ico_credit-card.svg);
}
.payment__item:nth-of-type(2) figure {
  max-width: 21.9rem;
}
@media screen and (max-width: 767px) {
  .payment__item:nth-of-type(2) figure {
    max-width: 9.4rem;
  }
}
.payment__item:nth-of-type(2)::before {
  background-image: url(../img/ico_paypay.svg);
}
.payment__item:nth-of-type(3) figure {
  max-width: 18.2rem;
}
@media screen and (max-width: 767px) {
  .payment__item:nth-of-type(3) figure {
    max-width: 9.6rem;
  }
}
.payment__item:nth-of-type(3)::before {
  background-image: url(../img/ico_bank.svg);
}
.payment__item:nth-of-type(4) {
  max-width: 54.7rem;
}
@media screen and (max-width: 999px) {
  .payment__item:nth-of-type(4) {
    grid-area: 3/1/4/3;
    max-width: none;
  }
}
.payment__item:nth-of-type(4)::before {
  background-image: url(../img/ico_invoice.svg);
}
.payment__item:nth-of-type(5) {
  max-width: 54.7rem;
}
@media screen and (max-width: 999px) {
  .payment__item:nth-of-type(5) {
    grid-area: 2/2/3/3;
    max-width: 40rem;
  }
}
.payment__item:nth-of-type(5) figure {
  max-width: 50.6rem;
}
@media screen and (max-width: 767px) {
  .payment__item:nth-of-type(5) figure {
    max-width: 14.8rem;
  }
}
.payment__item:nth-of-type(5)::before {
  background-image: url(../img/ico_conveni.svg);
}
.payment__name {
  color: #0F2777;
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .payment__name {
    font-size: 1.7rem;
  }
}
.payment__text {
  max-width: -moz-max-content;
  max-width: max-content;
  width: 100%;
  margin: 2.3rem auto 0;
  color: #0F2777;
  font-size: 2.3rem;
}
@media screen and (max-width: 767px) {
  .payment__text {
    margin: 1.6rem auto 0;
    font-size: 1.5rem;
    text-align: center;
  }
}

.add-recharge {
  margin: 9.9rem 0 13.7rem;
  color: #0F2777;
  font-size: 4rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .add-recharge {
    margin: 4.9rem 0 10.2rem;
    font-size: 1.5rem;
  }
}
.add-recharge__lead {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .add-recharge__lead {
    margin-top: 2.2rem;
  }
}
.add-recharge__inner {
  max-width: 125.2rem;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 1251px) {
  .add-recharge__inner {
    padding: 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .add-recharge__inner {
    padding: 0 2.3rem;
  }
}
.add-recharge__item {
  display: flex;
  flex-direction: column;
  gap: 5.6rem;
}
@media screen and (max-width: 767px) {
  .add-recharge__item {
    gap: 1.3rem;
  }
}
.add-recharge__item:nth-of-type(1) {
  margin-top: 7rem;
}
@media screen and (max-width: 767px) {
  .add-recharge__item:nth-of-type(1) {
    margin-top: 2.1rem;
  }
}
.add-recharge__item:nth-of-type(2) {
  margin-top: 9.3rem;
}
@media screen and (max-width: 767px) {
  .add-recharge__item:nth-of-type(2) {
    margin-top: 5rem;
  }
}
.add-recharge__note {
  margin-top: 2.6rem;
  color: #0F2777;
  font-size: 2rem;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .add-recharge__note {
    display: none;
  }
}
.add-recharge .item-list__btn {
  max-width: 96.3rem;
  width: 100%;
  margin: 0 auto;
}

.scene {
  padding: 13.7rem 0 16rem;
}
@media screen and (max-width: 767px) {
  .scene {
    padding: 5.3rem 0 5.2rem;
  }
}
.scene__inner {
  padding: 9rem 1.5rem 6.7rem;
  background-color: #E6F6FF;
}
@media screen and (max-width: 767px) {
  .scene__inner {
    padding: 3rem 2rem 2.3rem;
  }
}
.scene__list {
  display: flex;
  flex-wrap: wrap;
  gap: 4.3rem 2.8rem;
  max-width: 125.2rem;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 1251px) {
  .scene__list {
    max-width: 100rem;
  }
}
@media screen and (max-width: 767px) {
  .scene__list {
    gap: 1.4rem 0.8rem;
  }
}
.scene__list + p {
  margin-top: 6.5rem;
  color: #0F2777;
  font-size: 4.5rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .scene__list + p {
    margin-top: 2rem;
    font-size: 2rem;
  }
}
.scene__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.4rem;
  padding-bottom: 2.4rem;
  border: 0.2rem solid #fff;
  border-radius: 4.1rem;
  background-color: #fff;
  flex: 0 1 calc(33.3333333333% - 1.8666666667rem);
  filter: drop-shadow(0 0.4rem 0 rgba(0, 0, 0, 0.25));
}
@media screen and (max-width: 999px) {
  .scene__item {
    flex: 0 1 calc(50% - 1.4rem);
  }
}
@media screen and (max-width: 767px) {
  .scene__item {
    gap: 1.2rem;
    padding-bottom: 1.3rem;
    border-radius: 2.1rem;
    flex: 0 1 calc(50% - 0.4rem);
  }
}
.scene__item img {
  border-radius: 4.1rem 4.1rem 0 0;
}
@media screen and (max-width: 767px) {
  .scene__item img {
    border-radius: 2.1rem 2.1rem 0 0;
  }
}
.scene__item p {
  margin: auto 0;
  color: #0F2777;
  font-size: 3.5rem;
  font-weight: 500;
  line-height: 38px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .scene__item p {
    font-size: 1.8rem;
    line-height: normal;
  }
}
.scene__item .sm {
  display: inline-block;
  font-size: 2rem;
  font-weight: 500;
  line-height: normal;
}
@media screen and (max-width: 767px) {
  .scene__item .sm {
    font-size: 1.2rem;
  }
}

.faq {
  display: flex;
  flex-direction: column;
  gap: 9.3rem;
  padding: 14.6rem 0 18.5rem;
  background-color: #E6F6FF;
}
@media screen and (max-width: 767px) {
  .faq {
    gap: 3.4rem;
    padding: 5.2rem 0 5.8rem;
  }
}
.faq__list {
  display: flex;
  flex-direction: column;
  gap: 3.1rem;
  max-width: 118.5rem;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 1251px) {
  .faq__list {
    padding: 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .faq__list {
    gap: 1.3rem;
  }
}
.faq__item {
  padding: 4.4rem 5.3rem;
  border-radius: 2.7rem;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .faq__item {
    padding: 1.4rem;
    border-radius: 1rem;
  }
}
.faq__item .question {
  position: relative;
  display: flex;
  align-items: center;
  gap: 2.2rem;
  color: #0F2777;
  font-size: 3.5rem;
  font-weight: 500;
}
.faq__item .question:hover {
  cursor: pointer;
}
@media screen and (max-width: 999px) {
  .faq__item .question {
    display: grid;
    grid-template-columns: auto 1fr 4rem;
  }
}
@media screen and (max-width: 767px) {
  .faq__item .question {
    grid-template-columns: auto 1fr 1.5rem;
    gap: 0.4rem;
    font-size: 1.6rem;
  }
}
.faq__item .question__icon {
  color: #00A0E9;
  font-family: Inter, sans-serif;
  font-weight: 700;
  font-size: 7.4rem;
}
@media screen and (max-width: 767px) {
  .faq__item .question__icon {
    font-size: 2.5rem;
  }
}
.faq__item .question__plus {
  position: absolute;
  top: 50%;
  right: 2rem;
  transform: translateY(-50%);
  width: 3.7rem;
}
@media screen and (max-width: 999px) {
  .faq__item .question__plus {
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  .faq__item .question__plus {
    width: 1.5rem;
  }
}
.faq__item .question__plus .border {
  position: absolute;
  left: 0;
  display: block;
  width: 100%;
  height: 0.1rem;
  background-color: #0F2777;
  transition: transform 0.3s;
}
.faq__item .question__plus .border:nth-of-type(1) {
  transform: rotate(90deg);
}
.faq__item .question__plus .border:nth-of-type(2) {
  top: 50%;
  transform: translateY(-50%);
}
.faq__item .question__plus.close .border:nth-of-type(1) {
  transform: rotate(0);
}
.faq__item .question__plus.close .border:nth-of-type(2) {
  display: none;
}
.faq__item .body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.3s, padding-top 0.3s;
}
.faq__item .body.is-view {
  padding-top: 7.3rem;
  grid-template-rows: 1fr;
}
@media screen and (max-width: 767px) {
  .faq__item .body.is-view {
    padding-top: 2.3rem;
  }
}
.faq__item .body__inner {
  overflow: hidden;
}
.faq__item .answer {
  display: flex;
  gap: 2.2rem;
}
@media screen and (max-width: 767px) {
  .faq__item .answer {
    gap: 0.4rem;
  }
}
.faq__item .answer__text {
  display: inline-block;
  margin: auto 0;
  color: #0F2777;
  font-size: 3rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .faq__item .answer__text {
    font-size: 1.4rem;
  }
}
.faq__item .answer__text--sm {
  font-size: 2.5rem;
}
@media screen and (max-width: 767px) {
  .faq__item .answer__text--sm {
    font-size: 1.2rem;
  }
}
.faq__item .answer__icon {
  color: #E4007F;
  font-family: Inter, sans-serif;
  font-size: 7.4rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .faq__item .answer__icon {
    font-size: 2.5rem;
  }
}

.footer__links {
  display: grid;
  grid-template-columns: repeat(2, 60rem);
  justify-content: center;
  gap: 5.3rem;
  padding: 0 9.4rem 14.5rem;
  background-color: #E6F6FF;
}
@media screen and (max-width: 1251px) {
  .footer__links {
    grid-template-columns: 1fr;
    padding: 0 2rem 14.5rem;
  }
}
@media screen and (max-width: 767px) {
  .footer__links {
    grid-template-columns: 1fr;
    gap: 3.2rem;
    padding: 0 2rem 5.2rem;
  }
}
.footer__links .item-list__btn {
  justify-content: start;
  padding: 7rem 0 7rem 4.8rem;
}
@media screen and (max-width: 767px) {
  .footer__links .item-list__btn {
    height: 6.4rem;
    padding: 1.2rem 0 1.2rem 5.8rem;
  }
}
.footer__links .item-list__btn::after {
  right: 2rem;
}
.footer__links .item-list__btn.mail::before {
  width: 8.1rem;
  height: 5.8rem;
}
@media screen and (max-width: 767px) {
  .footer__links .item-list__btn.mail::before {
    width: 3.9rem;
    height: 2.8rem;
  }
}
.footer__links .item-list__btn.dairiten {
  padding: 7rem 0 7rem 8.6rem;
}
@media screen and (max-width: 767px) {
  .footer__links .item-list__btn.dairiten {
    padding: 1.2rem 0 1.2rem 5.4rem;
  }
}