/* ==========================================================================
  LP
========================================================================== */
.section {
  padding-block: max(12.8vw, 48px);
}
.section__title {
  font-size: max(4.2666666667vw, 16px);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.03em;
}
.section__title .--en {
  display: block;
  font-family: "Outfit", sans-serif;
  font-size: max(10.6666666667vw, 40px);
  font-weight: 700;
}
@media (900px <= width) {
  .section {
    padding-block: 6.75rem;
  }
  .section__title {
    font-size: 1.25rem;
  }
  .section__title .--en {
    font-size: 4rem;
  }
}

.fv {
  overflow: hidden;
  background: center/cover no-repeat url("../img/bg.webp");
}
.fv__inner {
  position: relative;
  margin-inline: auto;
}
.fv__body {
  position: relative;
  z-index: 5;
  width: max(87.2vw, 327px);
  aspect-ratio: 327/596;
  margin-inline: auto;
}
.fv__title, .fv__badge, .fv__tagline, .fv__text, .fv__contents {
  position: absolute;
}
.fv__title {
  top: max(7.2vw, 27px);
  left: 0;
  width: 100%;
}
.fv__tagline {
  top: max(105.3333333333vw, 395px);
  left: max(-6.4vw, -24px);
  width: max(74.9333333333vw, 281px);
}
.fv__text {
  top: max(125.6vw, 471px);
  left: 0;
  width: 100%;
}
.fv__contents {
  bottom: 0;
  left: max(-6.4vw, -24px);
  width: calc(100% + max(6.4vw, 24px) * 2);
}
.fv__packages {
  display: flex;
  justify-content: space-between;
}
.fv__package {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  color: #fff;
}
.fv__package::before {
  aspect-ratio: 1/1;
  content: "";
  background: center/contain no-repeat;
  aspect-ratio: 2/1;
  background-image: url("../img/icon_forjapan.svg");
}
.fv__image {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  width: 100%;
}
@media (width < 900px) {
  .fv__packages {
    padding: max(1.0666666667vw, 4px) max(0.8vw, 3px);
    background-color: #1a1a1a;
  }
  .fv__package {
    gap: max(2.4vw, 9px);
    width: max(19.2vw, 72px);
    text-align: center;
    background: rgba(255, 255, 255, 0.2);
  }
  .fv__package::before {
    width: max(3.84vw, 14.4px);
  }
}
@media (900px <= width) {
  .fv__inner {
    max-width: 1440px;
  }
  .fv__body {
    width: min(61.6666666667vw, 888px);
    aspect-ratio: 888/692;
  }
  .fv__title {
    top: min(7.2916666667vw, 105px);
    left: 0;
    width: min(42.2222222222vw, 608px);
  }
  .fv__badge {
    top: min(1.9444444444vw, 28px);
    left: min(13.9583333333vw, 201px);
    width: min(9.0277777778vw, 130px);
    aspect-ratio: 130/65;
  }
  .fv__tagline {
    top: min(16.1111111111vw, 232px);
    left: 0;
    width: min(26.3888888889vw, 380px);
  }
  .fv__text {
    top: min(23.5416666667vw, 339px);
    left: 0;
    width: min(33.75vw, 486px);
  }
  .fv__contents {
    bottom: min(3.0555555556vw, 44px);
    left: 0;
    width: min(43.8888888889vw, 632px);
  }
  .fv__packages {
    margin-bottom: min(0.8333333333vw, 12px);
  }
  .fv__package {
    gap: min(0.6944444444vw, 10px);
    width: min(8.3333333333vw, 120px);
    background: rgba(0, 0, 0, 0.2);
    opacity: 1;
    transition: all 0.5s;
  }
  .fv__package::before {
    width: min(1.6666666667vw, 24px);
  }
  .fv__package:hover, .fv__package:focus-visible {
    opacity: 0.5;
  }
  .fv__image {
    top: auto;
    bottom: min(-0.2777777778vw, -4px);
    width: min(42.2222222222vw, 608px);
  }
}

.package {
  background: center/cover no-repeat url("../img/bg2.webp");
}
.package__list {
  display: flex;
  flex-direction: column;
  gap: max(4.2666666667vw, 16px);
}
.package .packageItem {
  display: flex;
  flex-direction: column;
  gap: max(6.4vw, 24px);
  padding: max(6.4vw, 24px);
  background: rgba(0, 0, 0, 0.5);
}
.package .packageItem__image {
  display: flex;
  flex-direction: column;
  gap: max(2.1333333333vw, 8px);
  align-items: center;
  justify-content: center;
  width: 100%;
  height: max(35.2vw, 132px);
  background: #fff;
}
.package .packageItem__category {
  font-size: max(3.7333333333vw, 14px);
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}
.package .packageItem__info {
  color: #fff;
}
.package .packageItem__header {
  position: relative;
  padding-left: max(13.8666666667vw, 52px);
  margin-bottom: max(4.8vw, 18px);
}
.package .packageItem__header::before {
  aspect-ratio: 1/1;
  content: "";
  background: center/contain no-repeat;
  aspect-ratio: 2/1;
  background-image: url("../img/icon_forjapan.svg");
  position: absolute;
  top: max(2.6666666667vw, 10px);
  left: 0;
  display: block;
  width: max(10.6666666667vw, 40px);
}
.package .packageItem__title {
  font-size: max(5.3333333333vw, 20px);
  font-weight: 900;
}
.package .packageItem__explain {
  font-size: max(3.7333333333vw, 14px);
  font-weight: 700;
  line-height: 1.4;
}
.package .packageItem__details {
  font-size: max(4vw, 15px);
  line-height: 1.5;
}
.package .packageItem#SalesCrowd .packageItem__logo {
  width: max(59.7333333333vw, 224px);
}
.package .packageItem#Members .packageItem__logo {
  width: max(46.1333333333vw, 173px);
}
.package .packageItem#PBX .packageItem__logo {
  width: max(17.6vw, 66px);
}
.package .packageItem#Net .packageItem__logo {
  width: max(18.1333333333vw, 68px);
}
.package .packageItem#AIReception .packageItem__logo {
  width: max(50.4vw, 189px);
}
@media (900px <= width) {
  .package__list {
    gap: 1rem;
  }
  .package .packageItem {
    flex-direction: row;
    gap: 3rem;
    padding: 1.5rem 3rem 1.5rem 1.5rem;
  }
  .package .packageItem__image {
    flex-shrink: 0;
    gap: 0.5rem;
    width: 12.5rem;
    height: 12.5rem;
  }
  .package .packageItem__category {
    font-size: 0.875rem;
  }
  .package .packageItem__header {
    padding-left: 3.25rem;
    margin-bottom: 2rem;
  }
  .package .packageItem__header::before {
    top: 0.625rem;
    width: 2.5rem;
  }
  .package .packageItem__title {
    font-size: 1.75rem;
  }
  .package .packageItem__explain {
    font-size: 1.0625rem;
  }
  .package .packageItem__details {
    font-size: 1rem;
    line-height: 1.6;
  }
  .package .packageItem#SalesCrowd .packageItem__logo {
    width: 11.75rem;
  }
  .package .packageItem#Members .packageItem__logo {
    width: 10.8125rem;
  }
  .package .packageItem#PBX .packageItem__logo {
    width: 5.25rem;
  }
  .package .packageItem#Net .packageItem__logo {
    width: 5.125rem;
  }
  .package .packageItem#AIReception .packageItem__logo {
    width: 11.8125rem;
  }
}

.purpose {
  color: #fff;
  background: center/cover no-repeat url("../img/bg.webp");
}

.contact {
  background: #f4eeee;
}
.contact__title {
  font-size: max(6.4vw, 24px);
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}
@media (width < 900px) {
  .contact .container {
    gap: max(8.5333333333vw, 32px);
  }
}
@media (900px <= width) {
  .contact__title {
    font-size: 2.25rem;
    line-height: 1.4;
  }
  .contact .container {
    width: 46rem;
  }
}