/*backgroung_img_set*/
@media (min-width: 769px), print {
  #inside_ttl {
    background: url("../../../img/service/mansion_m/management/kv_bg_pc.jpg") center center no-repeat;
    background-size: cover;
  }
}
@media screen and (max-width: 768px) {
  #inside_ttl {
    background: url("../../../img/service/mansion_m/management/kv_bg_sp.jpg") center center no-repeat;
    background-size: cover;
  }
}

@media (min-width: 769px), print {
  #contact_section {
    background: url("../../../img/service/contact_bg_pc.jpg") center center no-repeat;
    background-size: cover;
  }
}
@media screen and (max-width: 768px) {
  #contact_section {
    background: url("../../../img/service/contact_bg_sp.jpg") center center no-repeat;
    background-size: cover;
  }
}

#services {
  overflow: hidden;
  margin-top: 8rem;
}
@media (min-width: 769px), print {
  #services {
    margin-top: 6.4rem;
  }
}
@media (min-width: 769px), print {
  #services .services__items {
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  #services .services__items {
    margin: 0 -1.2rem;
  }
}
#services .services__item {
  width: 20%;
  margin: 0;
  padding: 0 0.6rem;
}
#services .services__item:nth-child(n+5) {
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  #services .services__item {
    width: 50%;
    margin-top: 0 !important;
    margin-bottom: 4rem;
    padding: 0 1.2rem;
  }
}

#h2_section {
  padding-bottom: 0;
  position: relative;
  z-index: 2;
}

.text_desc {
  text-align: center;
  margin-top: 2.4rem;
  position: relative;
  z-index: 2;
  padding: 0 2rem 3.2rem;
}
@media screen and (max-width: 768px) {
  .text_desc {
    width: 66rem;
    text-align: left;
    margin: 5rem auto 0;
    padding: 0 0 8rem;
  }
}

#lead {
  padding-bottom: 6.4rem;
}
@media (min-width: 769px), print {
  #lead img {
    width: 80%;
    margin: 0 auto;
    display: block;
  }
}
@media screen and (max-width: 768px) {
  #lead {
    border: none;
    background: none;
    position: relative;
    overflow: visible;
    padding-bottom: 8rem;
  }
  #lead .js-scroll__horiz--content {
    padding-bottom: 3rem;
  }
  #lead .js-scroll__horiz--content img {
    padding-bottom: 0;
    width: 144rem;
  }
}

#steps {
  padding: 7rem 2rem 7rem;
  background: #F1F1F1;
}
@media (min-width: 769px), print {
  #steps {
    padding: 5.6rem 2rem 5.6rem;
  }
}
#steps h3 {
  margin-bottom: 4rem;
  text-align: center;
}
@media (min-width: 769px), print {
  #steps h3 {
    margin-bottom: 3.2rem;
  }
}
#steps .steps {
  display: flex;
  justify-content: space-between;
  position: relative;
  padding-top: 8.4rem;
}
@media screen and (max-width: 768px) {
  #steps .steps {
    flex-wrap: wrap;
    padding-top: 0;
    padding-left: 13rem;
  }
}
#steps .steps:before {
  content: "";
  position: absolute;
  top: 2.7rem;
  height: 1.6rem;
  left: 10.5%;
  right: 10.5%;
  background: #000;
}
@media screen and (max-width: 768px) {
  #steps .steps:before {
    right: auto;
    height: auto;
    top: 0%;
    bottom: 15%;
    width: 1rem;
    left: 4.5rem;
  }
}
#steps .steps .step {
  width: 21.667%;
  position: relative;
}
#steps .steps .step:nth-child(1):before {
  content: "1";
  position: absolute;
  top: -8.4rem;
  left: 50%;
  transform: translate(-50%, 0);
  font-size: 2.4rem;
  line-height: 4.8rem;
  width: 5.6rem;
  height: 5.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #000;
  color: #fff;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  #steps .steps .step:nth-child(1):before {
    top: 0;
    left: -13rem;
    transform: none;
    font-size: 4.2rem;
    line-height: 5.7rem;
    width: 10rem;
    height: 10rem;
  }
}
#steps .steps .step:nth-child(2):before {
  content: "2";
  position: absolute;
  top: -8.4rem;
  left: 50%;
  transform: translate(-50%, 0);
  font-size: 2.4rem;
  line-height: 4.8rem;
  width: 5.6rem;
  height: 5.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #000;
  color: #fff;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  #steps .steps .step:nth-child(2):before {
    top: 0;
    left: -13rem;
    transform: none;
    font-size: 4.2rem;
    line-height: 5.7rem;
    width: 10rem;
    height: 10rem;
  }
}
#steps .steps .step:nth-child(3):before {
  content: "3";
  position: absolute;
  top: -8.4rem;
  left: 50%;
  transform: translate(-50%, 0);
  font-size: 2.4rem;
  line-height: 4.8rem;
  width: 5.6rem;
  height: 5.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #000;
  color: #fff;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  #steps .steps .step:nth-child(3):before {
    top: 0;
    left: -13rem;
    transform: none;
    font-size: 4.2rem;
    line-height: 5.7rem;
    width: 10rem;
    height: 10rem;
  }
}
#steps .steps .step:nth-child(4):before {
  content: "4";
  position: absolute;
  top: -8.4rem;
  left: 50%;
  transform: translate(-50%, 0);
  font-size: 2.4rem;
  line-height: 4.8rem;
  width: 5.6rem;
  height: 5.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #000;
  color: #fff;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  #steps .steps .step:nth-child(4):before {
    top: 0;
    left: -13rem;
    transform: none;
    font-size: 4.2rem;
    line-height: 5.7rem;
    width: 10rem;
    height: 10rem;
  }
}
@media screen and (max-width: 768px) {
  #steps .steps .step {
    width: 100%;
    padding-top: 2rem;
  }
  #steps .steps .step + .step {
    margin-top: 7rem;
  }
}
#steps .steps .step_ttl {
  line-height: 1.459em;
  font-size: min(19.2px, 1.715vw);
  font-weight: bold;
  margin-bottom: 1.2rem;
}
@media screen and (max-width: 768px) {
  #steps .steps .step_ttl {
    line-height: 1.648em;
    font-size: 3.4rem;
    margin-bottom: 2.5rem;
  }
}

#section_box {
  padding: 8rem 0;
}
@media (min-width: 769px), print {
  #section_box {
    padding: 6.4rem 0;
  }
}
#section_box .border_box {
  padding: 6.5rem 4rem 8rem;
}
@media (min-width: 769px), print {
  #section_box .border_box {
    padding: 5.2rem 4rem 6.4rem;
  }
}
#section_box h3 {
  margin-bottom: 4rem;
}
@media (min-width: 769px), print {
  #section_box h3 {
    margin-bottom: 3.2rem;
  }
}
#section_box .row {
  display: flex;
  margin: 0 -1.5rem 3.2rem;
}
@media screen and (max-width: 768px) {
  #section_box .row {
    margin-bottom: 5rem;
  }
}
#section_box .row .col {
  width: 50%;
  padding: 0 1.5rem;
}
@media screen and (max-width: 768px) {
  #section_box .row {
    flex-wrap: wrap;
  }
  #section_box .row .col {
    width: 100%;
  }
  #section_box .row .col + .col {
    margin-top: 5rem;
  }
}
#section_box .feature {
  background: #f1f1f1;
  padding: 2.8rem 4rem 3.2rem;
  text-align: left;
  height: 100%;
}
@media screen and (max-width: 768px) {
  #section_box .feature {
    padding: 8rem 4rem;
  }
}
#section_box .feature .feature_ttl {
  display: flex;
  align-items: flex-end;
  line-height: 1.667em;
  font-size: min(19.2px, 1.715vw);
  border-bottom: 2px solid #000;
  margin-bottom: 2.4rem;
}
#section_box .feature .feature_ttl span {
  font-size: 2.4rem;
  width: 2.8rem;
  height: 2.8rem;
  line-height: 2.4rem;
  text-align: center;
  border: 2px solid #000;
  border-bottom: none;
  color: #3dae35;
  font-weight: 500;
  background: #fff;
  margin-right: 1.4rem;
}
#section_box .feature .feature_ttl h4 {
  width: calc(100% - 3.8rem);
  display: block;
}
@media screen and (max-width: 768px) {
  #section_box .feature .feature_ttl h4 {
    width: calc(100% - 7.4rem);
  }
}
@media screen and (max-width: 768px) {
  #section_box .feature .feature_ttl {
    line-height: 1.648em;
    font-size: 3.4rem;
    margin-bottom: 3rem;
  }
  #section_box .feature .feature_ttl span {
    font-size: 4.5rem;
    width: 5.4rem;
    height: 5.4rem;
    line-height: 4.5rem;
    margin-right: 2rem;
  }
}
#section_box .feature.feature1 .feature_photo {
  width: 24.161rem;
  margin: 1.2rem auto 0;
}
@media screen and (max-width: 768px) {
  #section_box .feature.feature1 .feature_photo {
    width: 100%;
    margin-top: 4rem;
  }
}
#section_box .feature.feature2 .feature_photo {
  width: 36rem;
  margin: 2.721rem auto 0;
}
@media screen and (max-width: 768px) {
  #section_box .feature.feature2 .feature_photo {
    width: 100%;
    margin-top: 4rem;
  }
}
#section_box .feature .feature_txt span {
  line-height: 1.8em;
  font-size: min(16px, 1.429vw);
  color: #3dae35;
  font-weight: 500;
  display: block;
  margin-left: -1rem;
}
@media screen and (max-width: 768px) {
  #section_box .feature .feature_txt span {
    line-height: 1.648em;
    font-size: 3.4rem;
    margin-left: 0rem;
    text-indent: -1.5rem;
  }
  #section_box .feature .feature_txt span:not(:nth-child(1)) {
    margin-top: 1rem;
    margin-bottom: 1rem;
  }
}

#view {
  padding: 6.4rem 0;
  background: url("../../../img/service/mansion_m/management/view_bg.jpg") center;
  background-size: cover;
  text-align: center;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  #view {
    background: url("../../../img/service/mansion_m/management/view_bg_sp.jpg") center;
    background-size: cover;
    padding: 8rem 0;
  }
}
#view .section_inner {
  background: #fff;
  padding: 2.4rem 2rem calc(4rem * 0.8);
  text-align: center;
}
@media screen and (max-width: 768px) {
  #view .section_inner {
    padding: 8rem 4rem;
  }
}
#view h3 {
  padding-bottom: 2.4rem;
  border-bottom: 2px solid #000;
  width: 104rem;
  margin: 0 auto 2.8rem;
  max-width: 100%;
}
@media screen and (max-width: 768px) {
  #view h3 {
    width: 100%;
    padding-bottom: 3rem;
    margin: 0 auto 3.5rem;
  }
}
#view h4 {
  line-height: 1.875em;
  font-size: min(19.2px, 1.715vw);
  margin-bottom: 1.6rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  #view h4 {
    line-height: 1.648em;
    font-size: 3.4rem;
    margin-bottom: 2rem;
  }
}
#view .view_desc {
  margin-bottom: 4rem;
  line-height: 1.778em;
  font-size: min(14.4px, 1.286vw);
}
@media screen and (max-width: 768px) {
  #view .view_desc {
    margin-bottom: 4rem;
    text-align: left;
    letter-spacing: 0.05em;
    line-height: 1.75em;
    font-size: 3.2rem;
  }
}
#view .row {
  display: flex;
  width: 86.4rem;
  margin: 0 auto;
  max-width: 100%;
}
@media screen and (max-width: 768px) {
  #view .row {
    flex-wrap: wrap;
    width: 100%;
  }
}
#view .row p {
  width: 50%;
  padding: 0 2rem;
}
@media screen and (max-width: 768px) {
  #view .row p {
    width: 100%;
    padding: 0;
  }
  #view .row p + p {
    margin-top: 2rem;
  }
}
#view .sub {
  line-height: 1.75em;
  font-size: min(12.8px, 1.143vw);
  font-weight: 500;
  margin-top: 0.561rem;
}
@media screen and (max-width: 768px) {
  #view .sub {
    line-height: 1.786em;
    font-size: 2.8rem;
    margin-top: 2rem;
  }
}