/* default settings */
/* CUSTOM STYLES */
/* =================================================================== */
.bgd-fixed {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 0;
}
.bgd-fixed img {
  min-width: 100%;
  min-height: 100%;
  max-width: none;
}
@media (max-width: 750px) {
  .bgd-fixed img {
    min-height: auto;
    min-width: none;
    height: 100%;
  }
}

.banner {
  width: 100%;
  height: 50rem;
  overflow: hidden;
  min-height: 100%;
  width: 100%;
  height: 100vh;
  position: relative;
  z-index: 2;
  opacity: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  transition: opacity ease 0.5s;
  background-color: transparent;
}
@media (max-width: 750px) {
  .banner {
    margin-top: 3.75rem;
    background-color: transparent;
    height: calc(100vh - 3.75rem);
  }
}
.banner.is-complete {
  opacity: 1;
}
.banner__title {
  color: #fff;
}
.banner__title__big {
  width: 100%;
  text-align: center;
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  position: relative;
  z-index: 3;
  overflow: hidden;
  display: block;
}
@media (max-width: 750px) {
  .banner__title__big {
    font-size: 3.25rem;
  }
}
.banner__title__big .banner__title-wrap {
  opacity: 0;
  transform: translateY(150%);
}
.banner__title__big.show .banner__title-wrap {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.4s cubic-bezier(0.645, 0.045, 0.355, 1) 0.8s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.8s;
}
.banner__title__big img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  mix-blend-mode: multiply;
  z-index: -1;
  filter: blur(0.3125rem);
}
@media (max-width: 750px) {
  .banner__title__big img {
    width: 48.75rem;
    max-width: none;
  }
}
.banner__title__sub {
  position: relative;
  z-index: 3;
  overflow: hidden;
  display: block;
}
.banner__title__sub img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  mix-blend-mode: multiply;
  z-index: -1;
  filter: blur(0.3125rem);
}
@media (max-width: 750px) {
  .banner__title__sub img {
    width: 50.25rem;
    max-width: unset;
    top: 57%;
    left: 49%;
  }
}
.banner__title__sub .banner__title-wrap {
  opacity: 0;
  transform: translateY(150%);
}
.banner__title__sub.show .banner__title-wrap {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.4s cubic-bezier(0.645, 0.045, 0.355, 1) 0.8s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.8s;
}
.banner__title p {
  padding-top: 1.125rem;
  width: 100%;
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.6666666667;
  letter-spacing: 0.15em;
}
@media (max-width: 750px) {
  .banner__title p {
    padding-top: 0.75rem;
    font-size: 2rem;
  }
}
.banner--second {
  height: 31.25rem;
}
@media (max-width: 750px) {
  .banner--second {
    height: 26.25rem;
    position: relative;
  }
}
.banner--second__desc {
  height: 100%;
  display: flex;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
}
.banner--second__desc .icon {
  margin: 0;
  width: 5.4375rem;
}
@media (max-width: 750px) {
  .banner--second__desc .icon {
    width: 6.875rem;
  }
}
.banner--second__desc h4 {
  margin-top: 0.625rem;
  width: 100%;
}
.banner--second__desc p {
  margin-top: 1.875rem;
  width: 100%;
  font-size: 1rem;
  line-height: 2.1875;
  letter-spacing: 0.1em;
}

.feature {
  margin-top: 25rem;
  position: relative;
  z-index: 2;
}
@media (max-width: 750px) {
  .feature {
    overflow-x: hidden;
  }
}
.feature__ttl {
  background-color: #fff;
}
.feature__ttl img {
  width: 14.8125rem;
}
@media (max-width: 750px) {
  .feature__ttl img {
    width: 16.0625rem;
  }
}
@media (min-width: 751px) {
  .feature__mold__sec1 {
    background: #161614;
    position: relative;
    overflow: hidden;
  }
  .feature__mold__sec1:after {
    content: "";
    width: 100%;
    height: 56.3125rem;
    background: url(../img/top/feature-mold-bgd2-pc.png) center center no-repeat;
    background-size: auto auto;
    position: absolute;
    top: -10.625rem;
    left: 12.5rem;
    z-index: 0;
  }
}
@media (max-width: 750px) {
  .feature__mold__sec1 {
    background-image: url(../img/top/feature-mold-bgd-sp.jpg);
    background-size: contain;
  }
}
@media (min-width: 751px) {
  .feature__mold__sec1 .banner--second__desc {
    position: relative;
    z-index: 2;
  }
}
@media (max-width: 750px) {
  .feature__mold__sec1 .banner--second__desc {
    position: relative;
  }
  .feature__mold__sec1 .banner--second__desc h4 {
    margin-top: -0.5625rem;
  }
  .feature__mold__sec1 .banner--second__desc h4 img {
    width: 23.125rem;
  }
}
.feature__mold__sec1 .banner--second__desc p {
  color: #fff;
}
@media (max-width: 750px) {
  .feature__mold__sec1 .banner--second__desc p {
    margin-top: 2.5rem;
    padding: 0 3.4375rem;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    color: #3c485a;
    font-size: 1.75rem;
    line-height: 1.8571428571;
    font-weight: 700;
    letter-spacing: -0.05em;
  }
}
.feature__mold__sec2 {
  background-color: #c7d1db;
  overflow: hidden;
}
@media (max-width: 750px) {
  .feature__mold__sec2 {
    padding-top: 16.25rem;
    background-color: #fff;
  }
}
.feature__mold__sec2 > div {
  display: flex;
  align-items: center;
}
@media (min-width: 751px) {
  .feature__mold__sec2 > div.only-sp {
    display: none;
  }
}
@media (max-width: 750px) {
  .feature__mold__sec2 > div {
    flex-wrap: wrap;
    align-items: stretch;
  }
  .feature__mold__sec2 > div.only-sp {
    display: flex;
  }
  .feature__mold__sec2 > div.only-pc {
    display: none;
  }
}
.feature__mold__sec2__desc {
  padding: 5.375rem 2.5rem 3rem;
  width: 33.333%;
  text-align: center;
}
.feature__mold__sec2__desc:nth-child(2n) {
  background-color: #3c485a;
  color: #fff;
}
@media (max-width: 750px) {
  .feature__mold__sec2__desc:nth-child(2n+1) {
    background-color: #c7d1db;
  }
}
@media (max-width: 750px) {
  .feature__mold__sec2__desc {
    padding: 3.875rem 1.25rem 3rem;
    width: 100%;
    height: 27.875rem;
    display: block;
    position: relative;
  }
  .feature__mold__sec2__desc .ttl {
    width: 100%;
    text-align: centers;
  }
  .feature__mold__sec2__desc .ttl img {
    width: 7.875rem;
  }
}
.feature__mold__sec2__desc p {
  padding-top: 2.625rem;
  font-size: 1.25rem;
  letter-spacing: 0.1em;
  line-height: 1.75;
}
@media (max-width: 750px) {
  .feature__mold__sec2__desc p {
    margin-top: 3.5rem;
    padding-top: 0;
    padding-left: 5.625rem;
    width: 100%;
    min-height: 11.25rem;
    font-size: 2rem;
    line-height: 1.625;
    font-weight: 700;
    text-align: left;
    display: flex;
    align-items: center;
    align-content: center;
  }
}
.feature__mold__sec2__desc .thumb {
  margin-top: 1.75rem;
  height: 7.5625rem;
  width: 100%;
  display: flex;
  align-items: center;
  align-content: center;
}
.feature__mold__sec2__desc .thumb img {
  max-height: 100%;
}
@media (max-width: 750px) {
  .feature__mold__sec2__desc .thumb {
    margin-top: 0;
    width: 50%;
    height: auto;
    width: 11.625rem;
    position: absolute;
    top: 50%;
    right: 7.125rem;
    transform: translateY(-2rem);
  }
}
.feature__mold__sec3 {
  padding-top: 6.25rem;
  padding-bottom: 7.5rem;
  position: relative;
}
.feature__mold__sec3:after {
  content: "";
  width: 187.5rem;
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
@media (max-width: 750px) {
  .feature__mold__sec3 {
    padding-top: 4.125rem;
    padding-bottom: 5rem;
  }
}
.feature__mold__sec3 h4 {
  margin-bottom: 1.125rem;
}
@media (max-width: 750px) {
  .feature__mold__sec3 h4 {
    margin-bottom: 1.75rem;
  }
}
.feature__mold__sec3 p {
  font-size: 1.125rem;
  line-height: 2.1111111111;
  letter-spacing: -0.025em;
}
@media (max-width: 750px) {
  .feature__mold__sec3 p {
    font-size: 1.75rem;
    font-weight: 400;
    line-height: 1.7142857143;
    letter-spacing: 0.025em;
  }
}
.feature__mold__sec3 small {
  margin-top: 1.5625rem;
  font-size: 0.75rem;
  font-weight: 400;
  display: block;
  line-height: 1.75;
}
@media (max-width: 750px) {
  .feature__mold__sec3 small {
    margin-top: 1rem;
    font-size: 1.25rem;
    line-height: 1.8;
    letter-spacing: 0.01em;
  }
}
.feature__mold__sec3 small.note {
  margin-top: 0.625rem;
  text-align: right;
}
@media (max-width: 750px) {
  .feature__mold__sec3 small.note {
    margin-top: -1.25rem;
  }
}
.feature__mold__sec3__desc {
  margin-top: 3.125rem;
  display: flex;
  justify-content: space-between;
  overflow: hidden;
}
@media (max-width: 750px) {
  .feature__mold__sec3__desc {
    margin-top: 5rem;
    flex-wrap: wrap;
  }
}
.feature__mold__sec3__desc li {
  width: 31.7095588235%;
  background-color: #c7d1db;
  text-align: center;
}
@media (max-width: 750px) {
  .feature__mold__sec3__desc li {
    margin-bottom: 2.5rem;
    width: 100%;
  }
}
.feature__mold__sec3__desc h5 {
  padding-top: 1.4375rem;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
}
@media (max-width: 750px) {
  .feature__mold__sec3__desc h5 {
    padding-top: 2rem;
    font-size: 2.5rem;
  }
}
.feature__mold__sec3__desc p {
  padding: 0.875rem 1.875rem 1.4375rem 1.875rem;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}
@media (max-width: 750px) {
  .feature__mold__sec3__desc p {
    padding: 1.25rem 1.875rem 2.625rem 1.875rem;
    font-size: 1.75rem;
    font-weight: 700;
  }
}
.feature__mold__sec3__cost {
  margin-top: 3.125rem;
  padding: 3.5rem 1.5625rem 2.125rem;
  background-color: #3c485a;
  color: #fff;
  overflow: hidden;
}
@media (max-width: 750px) {
  .feature__mold__sec3__cost {
    margin-top: 2.375rem;
    padding: 3.5rem 1.5625rem 1.625rem;
  }
}
.feature__mold__sec3__cost ul {
  display: flex;
  align-items: center;
}
@media (max-width: 750px) {
  .feature__mold__sec3__cost ul {
    display: block;
  }
}
.feature__mold__sec3__cost ul li:nth-child(1) {
  padding: 0.9375rem 1.875rem 1.25rem 4.875rem;
  width: 37.5%;
  position: relative;
}
@media (max-width: 750px) {
  .feature__mold__sec3__cost ul li:nth-child(1) {
    padding: 0;
    padding-bottom: 3.75rem;
    width: 100%;
    text-align: center;
    font-size: 2.75rem;
    font-weight: 700;
    line-height: 1.6363636364;
  }
}
.feature__mold__sec3__cost ul li:nth-child(1):after {
  content: "";
  width: 1px;
  height: 5.4375rem;
  background-color: #fff;
  position: absolute;
  right: -0.5rem;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 750px) {
  .feature__mold__sec3__cost ul li:nth-child(1):after {
    width: 77%;
    height: 1px;
    top: auto;
    bottom: 0;
    right: auto;
    left: 50%;
    transform: translate(-50%, 0);
  }
}
.feature__mold__sec3__cost ul li:nth-child(2) {
  width: 62.5%;
  text-align: center;
}
@media (max-width: 750px) {
  .feature__mold__sec3__cost ul li:nth-child(2) {
    padding-top: 3.375rem;
    width: 100%;
    text-align: center;
  }
  .feature__mold__sec3__cost ul li:nth-child(2) img {
    width: 27.875rem;
  }
}
.feature__mold__sec3__cost p {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.5;
}
@media (max-width: 750px) {
  .feature__mold__sec3__cost p {
    font-size: 2.75rem;
  }
}
.feature__mold__sec3__cost small {
  margin-top: 2.4375rem;
  padding: 0 1.8125rem 0 2.1875rem;
  font-size: 0.75rem;
  font-weight: 400;
  display: block;
}
@media (max-width: 750px) {
  .feature__mold__sec3__cost small {
    padding: 0.875rem 0.5rem 0;
    font-size: 1.25rem;
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: -0.055em;
  }
}
.feature__mold__sec3__rate {
  padding-top: 6.25rem;
}
@media (max-width: 750px) {
  .feature__mold__sec3__rate {
    padding-top: 7.875rem;
  }
}
.feature__mold__sec3__rate h5 {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media (max-width: 750px) {
  .feature__mold__sec3__rate h5 {
    font-size: 3rem;
    letter-spacing: 0.05em;
  }
}
.feature__mold__sec3__rate img {
  margin-top: -3.75rem;
}
@media (max-width: 750px) {
  .feature__mold__sec3__rate img {
    margin-top: -8.125rem;
  }
}
.feature__mold__sec3__rate small {
  margin-top: 2.5rem;
  font-size: 0.8125rem;
  line-height: 1.7692307692;
}
@media (max-width: 750px) {
  .feature__mold__sec3__rate small {
    margin-top: 2.875rem;
    font-size: 1.25rem;
    line-height: 1.8;
    letter-spacing: -0.05em;
  }
}
.feature__remote {
  padding-bottom: 5rem;
  position: relative;
  background-color: #fff;
}
@media (max-width: 750px) {
  .feature__remote {
    padding-bottom: 9rem;
  }
}
@media (min-width: 751px) {
  .feature__remote__sec1 {
    background: #E0E1E3 url(../img/top/feature-remote-bgd-right2-pc.png) top right repeat-y;
    position: relative;
    overflow: hidden;
  }
  .feature__remote__sec1:after {
    content: "";
    width: 100%;
    height: 100%;
    background: url(../img/top/feature-remote-bgd-right-pc.png) center center no-repeat;
    background-size: auto 100%;
    position: absolute;
    top: 0;
    left: 0.125rem;
  }
}
@media (max-width: 750px) {
  .feature__remote__sec1 {
    margin-bottom: 25rem;
    background-image: url(../img/top/feature-remote-bgd-sp.jpg);
    background-size: contain;
  }
  .feature__remote__sec1 p {
    margin-top: 3rem;
    padding: 0 1.5625rem 0 1.875rem;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    font-size: 1.75rem;
    line-height: 1.7142857143;
    letter-spacing: 0.075em;
  }
  .feature__remote__sec1 .banner--second__desc h4 img {
    margin-top: 0;
    margin-left: 3.5rem;
    width: 11.375rem;
  }
}
.feature__remote__sec2 ul {
  padding: 3.3125rem 2.8125rem 1.25rem;
  display: flex;
}
@media (max-width: 750px) {
  .feature__remote__sec2 ul {
    padding: 3.375rem 0 1.25rem;
  }
}
.feature__remote__sec2 ul li {
  width: 50%;
  text-align: center;
}
.feature__remote__sec2 ul li > p {
  font-size: 1rem;
  letter-spacing: 0.1em;
}
@media (max-width: 750px) {
  .feature__remote__sec2 ul li > p {
    margin-top: 0;
    font-size: 1.5rem;
    font-weight: 700;
  }
}
.feature__remote__sec2 ul li:nth-child(1) .thumb-wrap {
  width: 22.25rem;
  height: 20.8125rem;
  overflow: hidden;
}
@media (max-width: 750px) {
  .feature__remote__sec2 ul li:nth-child(1) .thumb-wrap {
    width: 18.375rem;
    height: 18.375rem;
  }
}
.feature__remote__sec2 ul li:nth-child(2) .thumb-wrap {
  width: 21.4375rem;
  height: 21.5rem;
  overflow: hidden;
}
@media (max-width: 750px) {
  .feature__remote__sec2 ul li:nth-child(2) .thumb-wrap {
    width: 18.375rem;
    height: 18.375rem;
  }
}
.feature__remote__sec2 ul .thumb {
  margin-top: -0.8125rem;
  height: 25.4375rem;
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: center;
}
.feature__remote__sec2 ul .thumb img {
  max-height: 100%;
}
@media (max-width: 750px) {
  .feature__remote__sec2 ul .thumb {
    margin-top: 0.625rem;
    height: auto;
  }
}
.feature__remote__sec2 ul + img {
  margin: 0 auto;
  display: block;
  width: 12.6875rem;
}
@media (max-width: 750px) {
  .feature__remote__sec2 ul + img {
    width: 18.75rem;
  }
}
.feature__remote__sec2 p {
  margin-top: 3.125rem;
}
.feature__remote__sec2 .desc {
  margin-top: 3.5rem;
  padding-left: 1.875rem;
  line-height: 2.45;
  letter-spacing: 0.055em;
}
@media (max-width: 750px) {
  .feature__remote__sec2 .desc {
    margin-top: 3.875rem;
    padding-left: 0;
    font-size: 1.75rem;
    line-height: 1.7142857143;
    font-weight: 400;
  }
}

.heating {
  background-color: #c7d1db;
  position: relative;
}
.heating__ttl {
  padding-top: 9.0625rem;
  padding-bottom: 6.8125rem;
}
@media (max-width: 750px) {
  .heating__ttl {
    padding-top: 5.875rem;
    padding-bottom: 6.25rem;
  }
}
.heating__ttl img {
  width: 15.3125rem;
}
@media (max-width: 750px) {
  .heating__ttl img {
    width: 16.5rem;
  }
}
.heating__sec1 {
  color: #3C485A;
}
@media (min-width: 751px) {
  .heating__sec1 .banner--second {
    background: url(../img/top/heating-bgd-pc.jpg) center center repeat-y;
    background-size: 100%;
    position: relative;
    overflow: hidden;
  }
  .heating__sec1 .banner--second:after {
    content: "";
    width: 100%;
    height: 100%;
    background: url(../img/top/heating-bgd-right-pc.png) center center no-repeat;
    background-size: auto 100%;
    position: absolute;
    top: 0;
    left: 2.3125rem;
    z-index: 0;
  }
}
@media (max-width: 750px) {
  .heating__sec1 .banner--second {
    background: none;
    height: auto;
  }
}
@media (min-width: 751px) {
  .heating__sec1 .banner--second__desc {
    position: relative;
    z-index: 2;
  }
}
@media (max-width: 750px) {
  .heating__sec1 .banner--second__desc {
    margin-top: 2.5rem;
    color: #3c485a;
  }
}
.heating__sec1 .banner--second__desc h4 {
  margin-top: 0;
}
.heating__sec1 .banner--second__desc p {
  font-size: 1.125rem;
  letter-spacing: normal;
}
@media (max-width: 750px) {
  .heating__sec1 .banner--second__desc p {
    margin-top: 2.25rem;
    font-size: 1.75rem;
    line-height: 1.7142857143;
  }
}
.heating__sec1 small {
  margin-top: 1.25rem;
  font-size: 0.8125rem;
  font-weight: 300;
}
@media (max-width: 750px) {
  .heating__sec1 small {
    margin-top: 1.25rem;
    font-size: 1.25rem;
    font-weight: 500;
  }
}
.heating__sec2 {
  padding-top: 9.0625rem;
}
@media (max-width: 750px) {
  .heating__sec2 {
    padding-top: 7.75rem;
  }
}
.heating__sec2 h4 {
  text-align: center;
}
.heating__sec2 h4 img {
  margin: 0 auto;
  width: 19.6875rem;
}
@media (max-width: 750px) {
  .heating__sec2 h4 img {
    width: 23.25rem;
  }
}
.heating__sec2__desc {
  padding-top: 3.5625rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (max-width: 750px) {
  .heating__sec2__desc {
    padding-top: 3.875rem;
    display: block;
  }
}
.heating__sec2__desc .thumb {
  order: 2;
}
@media (min-width: 751px) {
  .heating__sec2__desc .thumb {
    width: 36.0625rem;
    height: 25.1875rem;
    overflow: hidden;
  }
}
@media (max-width: 750px) {
  .heating__sec2__desc .thumb {
    overflow: hidden;
  }
}
.heating__sec2__desc .desc {
  order: 1;
}
@media (max-width: 750px) {
  .heating__sec2__desc .desc {
    padding-top: 3.375rem;
  }
}
.heating__sec2__desc h5 {
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.7;
}
@media (max-width: 750px) {
  .heating__sec2__desc h5 {
    font-size: 3rem;
    line-height: 1.5833333333;
  }
}
.heating__sec2__desc p {
  padding-top: 2.0625rem;
  font-size: 1rem;
  line-height: 2.1875;
  letter-spacing: 0.1em;
}
@media (max-width: 750px) {
  .heating__sec2__desc p {
    padding-top: 1.5rem;
    font-size: 1.75rem;
    line-height: 1.7142857143;
    letter-spacing: -0.03em;
  }
}

.heating__sec3 {
  padding-top: 4.5625rem;
  padding-bottom: 10.125rem;
}
@media (max-width: 750px) {
  .heating__sec3 {
    padding-top: 5.225rem;
    padding-bottom: 5.125rem;
  }
}
.heating__sec3__desc {
  background-color: #fff;
  padding-top: 1.875rem;
  padding-bottom: 1.875rem;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  column-gap: 2.5rem;
}
@media (max-width: 750px) {
  .heating__sec3__desc {
    padding: 0;
    display: block;
  }
  .heating__sec3__desc .desc {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
    padding-left: 2.5rem;
    padding-right: 2.5rem;

  }
}
.heating__sec3__desc .thumb {
  width: 23.25rem;
  height: 14.125rem;
}
@media (max-width: 750px) {
  .heating__sec3__desc .thumb {
    width: 100%;
    height: auto;
  }
  .heating__sec3__desc .thumb img {
    width: 100%;
  }
}
.heating__sec3__desc h5 {
  padding-top: 1.563rem;
  font-size: 1.688rem;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0.118rem;
}
@media (max-width: 750px) {
  .heating__sec3__desc h5 {
    padding-top: 0;
    font-size: 2.75rem;
    line-height: 140%;
  }
}
.heating__sec3__desc p {
  padding-top: 1.25rem;
  font-size: 1rem;
  line-height: 187.5%;
  letter-spacing: 0;
}
@media (max-width: 750px) {
  .heating__sec3__desc p {
    padding-top: 1.5rem;
    font-size: 1.75rem;
    line-height: 1.7142857143;
    letter-spacing: -0.03em;
  }
}
.heating__sec3__desc a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: fit-content;
  margin-top: 2rem;
  padding-top: 0.3rem;
  padding-right: 1.25rem;
  padding-bottom: 0.3rem;
  padding-left: 1.25rem;
  border-radius: 5rem;
  color: #fff;
  font-size: 0.875rem;
  letter-spacing: 0;
  background-color: #3C485A;
}

.heating__sec3__desc a::after {
  width: 1.25rem;
  height: 0.375rem;
  margin-left: 0.625rem;
  content: "";
  background: url(../img/top/arr-right3-white.svg) center no-repeat;
  background-size: 100% auto;
}
@media (max-width: 750px) {
  .heating__sec3__desc a {
    margin-top: 2.5rem;
    padding-top: 0.53rem;
    padding-right: 2.5rem;
    padding-bottom: 0.53rem;
    padding-left: 2.5rem;
    border-radius: 5rem;
    font-size: 1.75rem;
  }
  
  .heating__sec3__desc a::after {
    width: 2.5rem;
    height: 0.75rem;
    margin-left: 1.25rem;
  }
}

.dry {
  padding-bottom: 11.4375rem;
  position: relative;
  background-color: #fff;
}
@media (max-width: 750px) {
  .dry {
    padding-bottom: 5.625rem;
  }
}
.dry__ttl {
  padding-top: 9.3125rem;
  padding-bottom: 10.5625rem;
}
@media (max-width: 750px) {
  .dry__ttl {
    padding-top: 6.5rem;
    padding-bottom: 6.5rem;
  }
  .dry__ttl img {
    width: 14.125rem;
  }
}
.dry__desc p {
  padding-top: 0.8125rem;
  font-size: 1.3125rem;
  line-height: 2.0476190476;
}
@media (max-width: 750px) {
  .dry__desc p {
    padding-top: 1.625rem;
    font-size: 1.75rem;
    line-height: 1.7142857143;
    letter-spacing: -0.08em;
  }
}
.dry__desc small {
  padding-top: 1rem;
  font-size: 0.8125rem;
  font-weight: 400;
  display: inline-block;
}
@media (max-width: 750px) {
  .dry__desc small {
    padding-top: 1rem;
    font-size: 1.25rem;
    line-height: 1.8;
  }
}
.dry__desc img {
  margin-top: 5.5625rem;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 750px) {
  .dry__desc img {
    margin-top: 2.875rem;
  }
}

.flasma {
  padding-top: 9.6875rem;
  padding-bottom: 7.625rem;
  background-color: #c7d1db;
  position: relative;
}
@media (max-width: 750px) {
  .flasma {
    padding-top: 6rem;
    padding-bottom: 5.25rem;
  }
}
.flasma__ttl {
  text-align: center;
}
.flasma__ttl img {
  margin: 0 auto;
  width: 31.0625rem;
}
@media (max-width: 750px) {
  .flasma__ttl img {
    width: 33.625rem;
  }
}
@media (min-width: 751px) {
  .flasma .banner--second {
    position: relative;
    z-index: 2;
    height: 29.07rem;
  }
  .flasma .banner--second:before {
    content: "";
    width: 50%;
    height: 100%;
    background: url(../img/top/flasma-bgd-left-pc.png) right top no-repeat;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
  }
  .flasma .banner--second:after {
    content: "";
    width: 50%;
    height: 100%;
    background: linear-gradient(to bottom, #0d0605, #332725); 
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
  }
}

@media (max-width: 750px) {
  .flasma .banner--second {
    background: none;
    height: auto;
  }
  .flasma .banner--second img {
    width: 100%;
  }
}
.flasma__desc {
  margin-top: 6.25rem;
}
@media (min-width: 751px) and (max-width: 1440px) {
  .flasma .banner--second:before {
    display: none;
  }
  .flasma .banner--second::after {
    display: none;
  }
  .flasma__desc > .flasma-img-tab {
    display: block;
    max-width: 100%;
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
  }
}
@media (min-width: 1441px) {
  .flasma__desc > .flasma-img-tab {
    display: none;
  }
  .flasma__desc > img {
    max-width: 2560px;
    width: auto;
    height: 31.25rem;
    position: absolute;
    top: 0;
    left: 52%;
    transform: translateX(-50%);
    z-index: 3;
  }
}
@media (max-width: 750px) {
  .flasma__desc {
    margin-top: 3.5rem;
  }
  .flasma__desc > .flasma-img-tab {
    display: none;
  }
}
.flasma__desc p {
  margin-top: 0.6875rem;
  font-size: 1.3125rem;
  letter-spacing: normal;
}
@media (max-width: 750px) {
  .flasma__desc p {
    margin-top: 1.625rem;
    font-size: 1.75rem;
    line-height: 1.7142857143;
  }
}
.flasma__desc .banner--second__desc {
  padding-top: 1.75rem;
  display: block;
}
@media (min-width: 751px) {
  .flasma__desc .banner--second__desc {
    position: relative;
    z-index: 4;
  }
}
@media (min-width: 751px) and (max-width: 1440px) {
  .flasma__desc .banner--second__desc {
    margin-top: -16.5rem;
  }
}
@media (max-width: 750px) {
  .flasma__desc .banner--second__desc {
    padding-top: 4.5rem;
  }
}
.flasma__desc .banner--second__desc h4 {
  margin-top: 0;
}
.flasma__desc .banner--second__desc small {
  margin-top: 0.6875rem;
  font-size: 0.8125rem;
  letter-spacing: normal;
  display: block;
  line-height: 186%;
}
.flasma__step {
  padding: 10.125rem 0 0;
}
@media (max-width: 750px) {
  .flasma__step {
    padding: 3.625rem 1.875rem 0;
  }
}
.flasma__step ul {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.flasma__step ul li {
  width: 18.9375rem;
  height: 18.9375rem;
  border-radius: 100%;
  border: 2px solid #3c485a;
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.75;
  text-align: center;
  position: relative;
}
@media (max-width: 750px) {
  .flasma__step ul li {
    width: 12.5rem;
    height: 12.5rem;
    border-width: 1px;
    font-size: 1.5rem;
    line-height: 1.5;
  }
}
.flasma__step ul li:after {
  content: "";
  width: 0.9375rem;
  height: 1.6875rem;
  background: url(../img/common/arr-right2.svg) center no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
  margin-left: 2.5625rem;
}
@media (max-width: 750px) {
  .flasma__step ul li:after {
    margin-left: 1.25rem;
    width: 0.75rem;
    height: 1.75rem;
  }
}
.flasma__step ul li:last-child:after {
  content: none;
}
.flasma__step small {
  display: block;
  padding-top: 5.375rem;
  font-weight: 400;
  font-size: 0.8125rem;
  line-height: 1.7692307692;
  letter-spacing: 0.02em;
}
@media (max-width: 750px) {
  .flasma__step small {
    padding-top: 3rem;
    font-weight: 500;
    font-weight: 700;
    font-size: 1.25rem;
    line-height: 1.8;
    letter-spacing: -0.08em;
  }
}
.flasma__step p {
  padding-top: 2.3125rem;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 151%;
  text-align: center;
}
@media (max-width: 750px) {
  .flasma__step p {
    padding-top: 1.8rem;
    font-size: 2rem;
    line-height: 167%;
  }
}
/*# sourceMappingURL=top.css.map */