.lp-fv {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 450px;
}

.lp-fv-bg {
  position: absolute;
  inset: 0;
}

.lp-fv-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lp-fv-inner {
  position: relative;
  width: 100%;
  max-width: 1100px;
  height: 100%;
  margin: 0 auto;
}

/* =========================
コピー
========================= */
.lp-copy {
  position: absolute;
  top: 55px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 420px;
  height: 115px;
  background: url(../images/waterheater/title_bg.webp) no-repeat center center / contain;
  color: #fff;
  font-size: 44px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .04em;
  z-index: 100;
}

.lp-copy span {
  position: relative;
  top: -12.5px;
}

/* =========================
タイトル
========================= */
.lp-title {
  position: absolute;
  top: 160px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  z-index: 5;
  margin: 0;
  color: #00a0e9;
  font-size: 72px;
  width: 100%;
  text-align: center;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.02em;
  -webkit-text-stroke: 8px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 6px 12px rgba(255, 255, 255, .18);
}

.lp-title small {
  font-size: 42px;
  padding-left: 10px;
  -webkit-text-stroke: 6px #007ac7;
  paint-order: stroke fill;
  color: #fff;
}

/* =========================
丸
========================= */
.lp-merit {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  bottom: 10px;
  z-index: 5;
  display: flex;
  gap: 20px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.lp-merit li {
  position: relative;
  width: 15vw;
  height: 15vw;
  max-width: 180px;
  max-height: 180px;
  min-width: 180px;
  min-height: 180px;
  border-radius: 50%;
  background:
    linear-gradient(180deg,
      #18c4f3 0%,
      #1198db 28%,
      #1653be 68%,
      #162f9f 100%);
  box-shadow:
    0 8px 20px rgba(0, 0, 0, .18);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
  overflow: hidden;
}

.lp-merit li::before {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .9);
  pointer-events: none;
}

.lp-merit p {
  position: relative;
  z-index: 2;
  margin: 0 0 4px;
  color: #fff;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.25;
}

.lp-merit p span {
  color: #ffdc00;
  font-size: 34px;
  font-weight: 900;
}

.lp-merit p span.sml {
  font-size: 24px;
}

.lp-merit strong {
  position: relative;
  z-index: 2;
  display: block;
  background: linear-gradient(180deg,
      #fff8d6 0%,
      #ffe68a 28%,
      #f9d65d 52%,
      #c7971f 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: 50px;
  font-weight: 900;
  line-height: 1;
}

/* =========================
人物
========================= */
.lp-people {
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 3;
  width: 315px;
}

/* =========================
給湯器
========================= */
.lp-machine {
  position: absolute;
  right: -40px;
  bottom: -10px;
  z-index: 2;
  width: 325px;
  filter: drop-shadow(0 12px 20px rgba(0, 0, 0, .35));
}

/* =========================
キャラ
========================= */
.lp-chara {
  position: absolute;
  top: 70px;
  right: 215px;
  z-index: 5;
  width: 125px;
}

.gas-conro-fv .lp-people {
  width: 360px;
}

.gas-conro-fv .lp-title {
  top: 155px;
}

.gas-conro-fv .lp-merit {
  bottom: 25px;
}

.gas-conro-fv .lp-chara {
  top: initial;
  bottom: 25px;
  right: 125px;
}

@media screen and (max-width: 1000px) {
  .lp-chara {
    top: 40px;
    right: 30px;
    z-index: 5;
    width: 100px;
  }

  .lp-machine {
    right: -50px;
    bottom: -15px;
  }

  .gas-conro-fv .lp-chara {
    right: 10px;
  }
}

@media screen and (max-width: 767px) {
  .lp-fv {
    height: 135vw;
  }

  .lp-fv-inner {
    max-width: none;
  }

  .lp-copy {
    top: 7.5vw;
    width: 72.5vw;
    height: 23vw;
    font-size: 8.25vw;
  }

  .lp-copy span {
    top: -2vw;
  }

  .lp-title {
    top: 28.5vw;
    font-size: 9.5vw;
    -webkit-text-stroke: 6px #fff;
  }

  .lp-title small {
    font-size: 6vw;
    padding-left: 1.5vw;
    -webkit-text-stroke: 4px #007ac7;
  }

  .lp-merit {
    top: 42.5vw;
    bottom: auto;
    justify-content: space-between;
    gap: 2vw;
  }

  .lp-merit li {
    width: 31vw;
    height: 31vw;
    min-width: unset;
    min-height: unset;
    max-width: unset;
    max-height: unset;
    flex-shrink: 0;
  }

  .lp-merit li::before {
    inset: .9vw;
  }

  .lp-merit p {
    margin: 0 0 .5vw;
    font-size: 4vw;
  }

  .lp-merit p span {
    font-size: 5.25vw;
  }

  .lp-merit p span.sml {
    font-size: 4vw;
  }

  .lp-merit strong {
    font-size: 7.5vw;
  }

  .lp-people {
    left: 1vw;
    width: 50vw;
    bottom: -4.5vw;
  }

  .lp-machine {
    right: -2vw;
    bottom: -4.5vw;
    width: 50vw;
  }

  .lp-chara {
    top: 17.5vw;
    right: 5px;
    width: 16.5vw;
  }

  .gas-conro-fv .lp-title {
    top: 28.5vw;
  }

  .gas-conro-fv .lp-chara {
    right: 5px;
    bottom: initial;
    top: 17.5vw;
  }

  .gas-conro-fv .lp-people {
    width: 60vw;
    left: -5.5vw;
  }
}
