@charset "UTF-8";

/* MV
-------------------------------------------------------------*/
/* .shadow #mv-area .maincatch02 .subcatch ,.main-img{
	filter: drop-shadow(0 2px 30px rgba(0, 0, 0, 0.70));
} */
.mv-inner {
  filter: drop-shadow(0 2px 30px rgba(0, 0, 0, 0.7));
}

#contents #mv-area {
  background: url("../images/top/mv_bg.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 100px 0 60px;
  display: flex;
  align-items: center;
  height: 800px;
}

#mv-area .maincatch {
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);
  line-height: 27px;
  letter-spacing: 1.6px;
  font-size: 1.6rem;
}

#mv-area .maincatch02 {
  text-align: center;
  font-family: "source-han-sans-japanese", sans-serif;
  font-size: 5rem;
  font-weight: 700;
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);
  line-height: 70px;
  letter-spacing: 2.5px;

  sup {
    vertical-align: super;
    font-size: 30px;
    @media (max-width:767px) {
      font-size: 15px;
    }
  }

  .lg {
    font-size: 60px;
    line-height: 1;

    @media (max-width:767px) {
      font-size: 28px;
    }
  }
}

#mv-area .main-img {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 3.2rem;
}

#mv-area .main-img-left {
  max-width: 671px;
  width: 56%;
  padding-left: 40px;
}

#mv-area .main-img-right {
  max-width: 340px;
  width: 50%;
  text-align: left;
  margin: auto;
}

.mv-btn {
  max-width: 340px;
  background: #fff;
}

.subcatch {
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 31px;
  letter-spacing: 1.8px;
}

.sec-subttl .ririsu {
  display: table;
  position: relative;
  margin: 2rem auto 0;
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);
}

.ririsu::before,
.ririsu::after {
  content: "";
  display: block;
  position: absolute;
  left: -10.5rem;
  top: 50%;
  width: 9.5rem;
  height: 0.1rem;
  background: #fff;
  font-size: 1.6rem;
}

.ririsu::after {
  right: -10.5rem;
  left: auto;
}

@media screen and (max-width: 1024px) {
  #mv-area .maincatch {
    font-size: 3.8rem;
  }
}

@media screen and (max-width: 767px) {
  #contents #mv-area {
    background: url("../images/top/mv_bg-sp.jpg");
    /* background: url("../images/top/bg.png"), url("../images/top/mv_bg-sp.jpg"); */
    background-size: cover;
    background-position: center;
    height: 566px;
    padding: 10rem 0 3rem;
    box-shadow: 0px 2px 30px 0px rgba(0, 0, 0, 0.7);
  }

  #mv-area .maincatch {
    font-size: 2.2rem;
  }

  #mv-area .maincatch02 {
    font-size: 2.4rem;
    letter-spacing: 1.2px;
    line-height: 34px;
  }

  .ririsu::before,
  .ririsu::after {
    left: -4.5rem;
    width: 3.5rem;
  }

  .ririsu::after {
    right: -4.5rem;
    left: auto;
  }

  .mv-btn {
    max-width: 300px;
    width: 100%;
  }

  #mv-area .main-img {
    padding: 0 1.5% 10%;
    margin-top: 20px;
  }

  #mv-area .main-img-left {
    max-width: 100%;
    width: 100%;
    padding-right: 0;
    padding-left: 0;
  }

  #mv-area .main-img-right {
    max-width: 100%;
    width: 100%;
    padding: 0 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  #mv-area .main-img-right div a {
    font-size: 1.6rem;
    padding: 13px;
  }

  .subcatch {
    text-align: center;
    font-family: "Noto Sans JP",  sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 24px;
    letter-spacing: 1.4px;
  }
}

/* collaboration */
.collaboration {
  background: #fff;
}
.collaboration__img {
  display: block;
  margin: -60px auto -40px;
  @media (max-width: 767px) {
    margin: -20px auto -10px;
    padding: 0 30px;
  }
}
.collaboration__lead-text {
  text-align: center;
  line-height: 2;
  font-weight: 500;
  font-size: 14px;
}
.collaboration__text {
  text-align: center;
  line-height: 2;
  font-weight: 400;
  font-size: 16px;
  @media (max-width: 767px) {
    font-size: 14px;
  }
}

/*about-area*/
#strong {
}

.about-strong-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #002c56;
}

.no01.about-strong-box {
  background: url("../images/top/no01.svg") no-repeat right center #002c56;
}

.no02.about-strong-box {
  background: url("../images/top/no02.svg") no-repeat left center #26537d;
}

.no03.about-strong-box {
  background: url("../images/top/no03.svg") no-repeat right center #4173b0;
}

.ap-txt {
  width: 50%;
  padding: 0 50px;
  color: #fff;
  font-weight: 500;
}

.ap-txt > div {
  display: table;
  margin-left: auto;
}

.ap-txt h3 {
  font-size: 3.6rem;
  margin-bottom: 2rem;
  line-height: 1.5;
  font-weight: bold;
  letter-spacing: 1pt;
}

.ap-txt p {
  text-indent: -1.6rem;
  margin-left: 1.6rem;
  font-size: 1.6rem;
}

.ap-img {
  width: 50%;
}

@media screen and (max-width: 900px) {
  .ap-txt h3 {
    font-size: 2.6rem;
  }

  .ap-txt p {
    text-indent: -1.3rem;
    margin-left: 1.3rem;
    font-size: 1.3rem;
  }
}

@media screen and (max-width: 767px) {
  .about-strong-box {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 0;
  }

  .ap-txt {
    width: 100%;
    margin-bottom: 2rem;
    order: 2;
    padding: 2rem 2rem 1rem 2rem;
  }

  .ap-txt h3 {
    font-size: 2.6rem;
    margin-bottom: 1rem;
  }

  .ap-img {
    width: 100%;
  }

  .ap-txt p {
    text-indent: -1.3rem;
    margin-left: 1.3rem;
    font-size: 1.3rem;
  }

  .ap-txt > div {
    margin-left: 0;
  }

  .no01 .ap-txt {
    background: url(../images/top/no01.svg) no-repeat right center #002c56;
    background-size: 26%;
  }

  .no02 .ap-txt {
    background: url("../images/top/no02-sp.svg") no-repeat right center #26537d;
    background-size: 26%;
  }

  .no03 .ap-txt {
    background: url("../images/top/no03.svg") no-repeat right center #4173b0;
    background-size: 26%;
  }
}

/* ISSUE
-------------------------------------------------------------*/
#issue {
}

.issue-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8rem 2rem;
}

.issue-list li {
  border: 0.1rem solid #fff;
  position: relative;
  padding: 6rem 4rem 4rem 4rem;
  text-align: center;
  color: #fff;
  background: #00274d;
  width: 48%;
}

.issue-list .gjyu {
  position: absolute;
  top: -4.1rem;
  left: 0;
  right: 0;
  margin: auto;
}

.issue-list h3 {
  font-weight: bold;
  font-size: 2.4rem;
  border-bottom: 0.1rem solid #dfff;
  padding-bottom: 2rem;
  margin-bottom: 2rem;
  position: relative;
}

.issue-list p {
  font-weight: 400;
  font-size: 1.8rem;
}

@media screen and (max-width: 767px) {
  .issue-list {
    gap: 5rem 3rem;
    margin-top: 7rem;
  }

  .issue-list li {
    padding: 4rem 1rem 2rem 1rem;
    width: 100%;
  }

  .issue-list h3 {
    font-size: 1.8rem;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
  }

  .issue-list p {
    font-size: 1.3rem;
  }

  .issue-list .gjyu {
    width: 8rem;
    top: -3.3rem;
  }
}

/* FEATURES
-------------------------------------------------------------*/
#features {
  background: url("../images/top/features.jpg") center top no-repeat;
  background-size: cover;
}

.features-list01 {
  display: flex;
  justify-content: space-between;
  gap: 3rem 2%;
  flex-wrap: wrap;
}

.features-list01 li {
  width: 48.5%;
  background: #fff;
  padding: 4rem 2rem;
  font-weight: bold;
  font-size: 2.2rem;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}

.features-list02 {
  display: flex;
  justify-content: space-between;
  gap: 0;
}

.features-list02 li {
  width: 25%;
  padding: 4rem 1.5rem;
  font-weight: bold;
  text-align: center;
  border-right: 2px dotted #4173b0;
  font-weight: 500;
}

.features-list02 li:last-child {
  border: none;
}

.features-list02 li h3 {
  font-size: 2.8rem;
  color: #002c56;
  font-weight: bold;
  margin: 2rem 0;
}

.features-list02 li .features-icon {
  display: flex;
  justify-content: center;
  align-items: center;
}

.features-list02 li .features-icon img {
  max-width: 10rem;
}

.features-list02 li:nth-child(2) .features-icon img {
  max-width: 11.1rem;
}

.features-list02 li:nth-child(3) .features-icon img {
  max-width: 11rem;
}

.features-list02 li:nth-child(4) .features-icon img {
  max-width: 6.1rem;
}

@media screen and (max-width: 767px) {
  #features {
    background: url("../images/top/features-sp.jpg") center top no-repeat;
    background-size: cover;
  }

  .features-list01 li {
    width: 100%;
    padding: 2rem 1rem;
    font-size: 1.6rem;
  }

  .features-list01 {
    gap: 1.5rem 2%;
  }

  .features-list02 {
    flex-wrap: wrap;
  }

  .features-list02 li {
    width: 50%;
    padding: 2rem 1.5rem;
    font-weight: bold;
    text-align: center;
    border-right: 2px dotted #4173b0;
    font-weight: 500;
  }

  .features-list02 li .features-icon img {
    max-width: 6rem;
  }

  .features-list02 li:nth-child(2) .features-icon img {
    max-width: 6.5rem;
  }

  .features-list02 li:nth-child(3) .features-icon img {
    max-width: 6.4rem;
  }

  .features-list02 li:nth-child(4) .features-icon img {
    max-width: 4rem;
  }

  .features-list02 li:nth-child(2) {
    border: none;
  }

  .features-list02 li:nth-child(1),
  .features-list02 li:nth-child(2) {
    border-bottom: 2px dotted #4173b0;
  }

  .features-list02 li h3 {
    font-size: 2rem;
    margin: 1.5rem 0;
  }

  .features-list02 li p {
    font-size: 1.3rem;
  }
}

/* MERIT
-------------------------------------------------------------*/
#merit {
  background: #f0f0f0;
}

.merit-list01 {
  display: flex;
  justify-content: space-between;
  gap: 4rem 2%;
  flex-wrap: wrap;
}

.merit-list01 li {
  position: relative;
  background: #fff;
  padding: 3rem;
  text-align: center;
  width: 49%;
}

.merit-list01 li p {
  font-weight: 400;
}

.merit-list01 li .mno {
  position: absolute;
  top: -1.5rem;
  left: 1rem;
}

.merit-list01 li h3 {
  font-size: 2.4rem;
  font-weight: bold;
  margin-bottom: 1.5rem;
  padding: 0 5.2rem;
}

.merit-list02 {
  display: flex;
  gap: 1rem;
}

.merit-list02 li {
  box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.15);
  background: #fff;
  padding: 1rem;
  text-align: center;
}

.merit-list02 li .plan-img:last-child {
  margin-top: 1rem;
}

.merit-list02 li h3 {
  font-size: 2rem;
  color: #002c56;
  padding-bottom: 1rem;
}

@media screen and (max-width: 767px) {
  .merit-list01 li {
    padding: 2rem;
    width: 100%;
  }

  .merit-list01 li h3 {
    font-size: 1.8rem;
    padding: 0 5.2rem;
  }

  .merit-list01 li p {
    font-size: 1.3rem;
  }

  .merit-list01 li .mno {
    width: 5.3rem;
  }

  .merit-list01 {
    gap: 3rem 2%;
  }

  .merit-list02 {
    gap: 0.8rem;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  .merit-list02 li {
    width: 48.8%;
  }
}

/* STEP
-------------------------------------------------------------*/

.step-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4rem;
}

.step-list li {
  border-radius: 1rem 1rem 0 0;
  text-align: center;
  width: 100%;
}

.step-list li img {
  /*filter: drop-shadow(0px 0px 6px rgba(0, 0, 0, 0.5));*/
}

.step-list li h3 {
  background: #002c56;
  color: #fff;
  font-size: 2.8rem;
  font-weight: bold;
  padding: 1.5rem;
  border-radius: 1rem 1rem 0 0;
  position: relative;
}

.step-list li p {
  background: #f0f0f0;
  font-size: 2rem;
  font-weight: 500;
  padding: 2.5rem 5rem;
}

.sno {
  position: absolute;
  left: 8rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
}

.sno::before {
  content: "";
  position: absolute;
  background: url("../images/top/sarrow.svg") center top no-repeat;
  width: 8.5rem;
  height: 20rem;
  z-index: -1;
  left: 0;
  right: 0;
  top: 0.2rem;
  margin: auto;
}

.step-list li:last-child .sno::before {
  background: url("../images/top/sarrow.svg") center bottom no-repeat;
  height: 19rem;
}

@media screen and (max-width: 940px) {
  .sno {
    left: 2rem;
  }
}

@media screen and (max-width: 767px) {
  .sno {
    left: -1rem;
  }

  .step-list li img {
    width: 7rem;
  }

  .step-list li h3 {
    font-size: 1.6rem;
    padding-left: 4rem;
  }

  .step-list li p {
    background: #f0f0f0;
    font-size: 1.3rem;
    padding: 1.5rem 5rem 2rem;
  }

  .sno::before {
    content: "";
    position: absolute;
    background: url(../images/top/sarrow.svg) center top no-repeat;
    background-size: 5.5rem;
    width: auto;
    height: 20rem;
    z-index: -1;
    left: 0;
    right: 0;
    top: 0.2rem;
    margin: auto;
  }

  .step-list li:last-child .sno::before {
    background: url(../images/top/sarrow.svg) center bottom no-repeat;
    height: 14.5rem;
    background-size: 5.5rem;
  }
}

/* WORKS
-------------------------------------------------------------*/
.works-list {
  max-width: 1040px;
  margin: auto;
}

.works-list li {
  display: flex;
  align-items: center;
  margin-bottom: 5rem;
}

.works-list li:last-child {
  margin-bottom: 0rem;
}

.works-list .works-img {
  width: 44%;
  max-width: 457px;
}

.works-list .works-txt {
  width: 56%;
  max-width: 583px;
}

.works-list .works-txt .works-case {
  font-size: 2.8rem;
  font-weight: bold;
  border-bottom: 2px solid #f79421;
  color: #f79421;
  padding: 0 0 2rem 5rem;
}

.works-list .works-txt .works-case.case02 {
  border-bottom: 2px solid #14b76b;
  color: #14b76b;
}

.works-list .works-txt .works-case.case03 {
  border-bottom: 2px solid #5d9cea;
  color: #5d9cea;
}

.works-list .works-txt .works-case-txt {
  padding: 2rem 0 0 5rem;
}

.works-list .works-txt .works-case-txt h3 {
  font-size: 3.4rem;
  font-weight: bold;
  margin-bottom: 2rem;
}

.works-list .works-txt .works-case-txt p {
}

@media screen and (max-width: 767px) {
  .works-list li {
    margin-bottom: 3rem;
    flex-wrap: wrap;
  }

  .works-list .works-img {
    width: 100%;
    max-width: 100%;
  }

  .works-list .works-txt {
    width: 100%;
    max-width: 100%;
  }

  .works-list .works-txt .works-case {
    font-size: 2.4rem;
    padding: 1rem 0 1rem 0rem;
    text-align: center;
  }

  .works-list .works-txt .works-case-txt {
    padding: 1rem 0 0 0rem;
  }

  .works-list .works-txt .works-case-txt h3 {
    font-size: 2rem;
    margin-bottom: 1rem;
  }

  .works-list .works-txt .works-case-txt p {
    font-size: 1.3rem;
  }
}

/* problem
-------------------------------------------------------------*/
#problem {
  overflow: hidden;
}

.problem-box {
  display: flex;
  justify-content: space-between;
  margin-bottom: 5rem;
}

.problem-box.rev {
  flex-direction: row-reverse;
}

.problem-img {
  width: 30%;
  z-index: 2;
  position: relative;
}

.problem-txt {
  width: 70%;
  padding: 0;
  font-weight: 500;
}

.problem-txt h3 {
  font-size: 5rem;
  color: #002c56;
  font-weight: bold;
  padding: 5rem;
  padding-bottom: 2rem;
}

.rev .problem-txt h3 {
  text-align: right;
}

.problem-txt p {
  font-size: 2rem;
  background: #f0f0f0;
  position: relative;
  padding: 5rem 5rem 10rem 5rem;
  line-height: 1.8;
}

.problem-txt p::after {
  content: "";
  position: absolute;
  display: block;
  width: 200%;
  height: 100%;
  right: -200%;
  top: 0;
  border: 0;
  background: #f0f0f0;
}

.rev .problem-txt p::after {
  right: auto;
  left: -200%;
  top: 0;
}

.problem-box02 {
  padding: 0 0 5rem;
  position: relative;
}

.problem-box02::before {
  content: "";
  position: absolute;
  display: block;
  bottom: 0;
  width: 100%;
  height: 35%;
  background: #f0f0f0;
}

.problem-box02 h3 {
  font-size: 5rem;
  font-weight: bold;
  text-align: center;
  color: #002c56;
  margin-bottom: 3rem;
}

.problem-box02 sup {
  font-size: 50%;
  vertical-align: super;
}

.problem-box02 a {
  color: #002c56;
  text-decoration: underline;
}

@media screen and (max-width: 767px) {
  .problem-box02 h3 {
    font-size: 2.6rem;
  }

  .problem-box02::before {
    height: 54%;
  }

  .problem-box02.mijikai::before {
    height: 36%;
  }

  .problem-box02 {
    padding: 0 0 3rem;
  }

  .problem-box {
    flex-wrap: wrap;
    padding-bottom: 3rem;
  }

  .problem-txt {
    width: 100%;
  }

  .problem-txt h3 {
    font-size: 2.6rem;
    padding: 0rem;
    padding-bottom: 2rem;
    text-align: center;
  }

  .problem-txt p {
    font-size: 1.3rem;
    background: none;
    padding: 0 0 1.5rem 0;
  }

  .problem-txt p::after {
    display: none;
  }

  .problem-img {
    width: 100%;
  }

  .problem-box::before {
    content: "";
    position: absolute;
    display: block;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 52%;
    background: #f0f0f0;
  }
}

/* AVANTIA
-------------------------------------------------------------*/
#avantia .inner {
  max-width: 1360px;
}

.avantia-box {
  display: flex;
  gap: 3rem;
}

.avantia-box-txt {
  width: 50%;
}

.avantia-box-img {
  width: 50%;
}

.avantia-box-txt-box {
  display: flex;
  gap: 4rem;
}

.avantia-box-txt-box-item {
  max-width: 30rem;
  width: 100%;
  margin-bottom: 2rem;
}

.avantia-box-txt-box-item.flx {
  display: flex;
  gap: 1.5rem;
}

.avantia-box-txt-box-item.flx p {
  width: 90%;
}

.avantia-g img {
  max-width: 14.8rem;
  margin-bottom: 1rem;
}

.jpx {
  max-width: 9rem;
}

.avantia-logo {
  max-width: 390px;
  width: 100%;
  margin-right: 10px;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  .avantia-box {
    flex-wrap: wrap;
  }

  .avantia-box-txt {
    width: 100%;
  }

  .avantia-box-txt-box {
    flex-wrap: wrap;
    gap: 1rem;
  }

  .avantia-box-txt-box-item {
    max-width: 100%;
  }

  .avantia-box-img {
    width: 100%;
  }

  .avantia-logo {
    max-width: 224px;
    width: 70%;
    margin-top: 10px;
    vertical-align: middle;
  }
}

.l-section {
  padding-block: 0 80px;
}

@media (max-width: 767px) {
  .l-section {
    padding-block: 0 30px;
  }
}

/* service */
.service-wrap {
  background: #e9f3f9;
}

.service-img {
  max-width: 100%;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 30px;
  margin-block: 50px 20px;
}

.service-img .underline {
  max-width: 300px;
  width: 100%;
  height: 2px;
  background: #0a548e;
}

.service-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin-bottom: 75px;
}

.service-col {
  width: calc(100% / 3 - 13px);
  background-color: #fff;
}

.service-col:nth-child(2) .service-col__textwrap {
  background-color: #26537d;
}

.service-col:nth-child(3) .service-col__textwrap {
  background-color: #4173b0;
}

.service-col__text {
  text-align: center;
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 22px;
  width: 90%;
}

.service-col__bg {
  display: inline-block;
  color: #002c56;
  text-align: center;
  font-size: 1.6rem;
  font-size: 2rem;
  font-weight: 700;
  line-height: 28px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  background: #fff;
  margin-right: 15px;
  font-family: "Noto Sans JP",  sans-serif;
  padding-inline: 10px;
  width: 100%;
}

.service-content {
  background-color: #fff;
  padding: 20px;
}

.service-content.padd {
  background-color: #fff;
  padding: 26.5px;
}

.service-content__img {
  max-width: 330px;
  width: 100%;
  margin-inline: auto;
}

.service-content__img.width {
  max-width: 270px;
  width: 100%;
  margin-inline: auto;
}

.service-col__textwrap {
  background-color: #002c56;
  min-height: 75px;
  min-height: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.service-col__textwrap.flex-col {
  flex-direction: column;
}

.service-col__smtext {
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 1.4rem;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 10px;
  padding-bottom: 15px;
  padding-top: 15px;
}

.service-content__text {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 23px;
  padding-top: 18px;
}

.service-box {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 30px;
  max-width: 1150px;
  width: 100%;
  margin-inline: auto;
}

.service-box__left,
.service-box__right {
  background-color: #fff;
  padding: 44px 35px 35px;
  position: relative;
  border-radius: 20px;
  width: 50%;
}

.service-box__heading {
  color: #f79421;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 2.6rem;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 19px;
  display: inline-block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -34px;
  padding: 15px 45px;
  border-radius: 60px;
  background: #fff;
  width: 100%;
  width: 70%;
  max-width: 448px;
}

.service-box__flex {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.service-box__text {
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 33px;
  padding-block: 31px;
  border-radius: 10px;
  background: #f79421;
  width: calc(100% / 2 - 5px);
}

.service-box__right .service-box__heading {
  color: #4173b0;
  max-width: 386px;
  max-width: 460px;
  width: 100%;
}

.service-box__right .service-box__text {
  padding-block: 13.5px;
  border-radius: 10px;
  background: #4173b0;
}

@media (max-width: 1199px) {
  .sec-des .org {
    font-size: 2.4rem;
  }

  .sec-des {
    font-size: 2.4rem;
  }

  .service-col__text {
    font-size: 1.4rem;
  }

  .service-col__bg {
    margin-right: 5px;
    font-size: 1.4rem;
  }

  .service-row {
    align-items: stretch;
  }
}

@media (max-width: 991px) {
  .sec-des .org {
    font-size: 1.8rem;
  }

  .sec-des {
    font-size: 1.8rem;
  }

  .service-row {
    gap: 5px;
  }

  .service-col {
    width: calc(100% / 3 - 3px);
  }

  .service-col__bg {
    font-size: 1.2rem;
  }

  .service-col__text {
    font-size: 1.2rem;
  }

  .service-col__smtext {
    font-size: 1.2rem;
  }

  .service-box__heading {
    padding: 10px 30px;
    font-size: 1.5rem;
    font-size: 2.5rem;
  }

  .service-box__left,
  .service-box__right {
    padding: 30px 20px;
  }

  .service-box__text {
    font-size: 1.6rem;
    padding-block: 32px;
  }

  .service-box__right .service-box__text {
    padding-block: 14px;
  }
}

@media (max-width: 767px) {
  .service-content {
    background-color: #fff;
    padding: 20px 10px;
  }

  .service-img {
    gap: 10px;
    margin-block: 30px 10px;
  }

  .service-img img {
    max-width: 170px;
    width: 100%;
    height: auto;
  }

  .service-row {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin-bottom: 43px;
  }

  .service-col {
    width: calc(100%);
  }

  .service-col__bg {
    font-size: 1.6rem;
    line-height: 12px;
    padding: 8px 10px;
  }

  .service-col__text {
    font-size: 1.6rem;
    line-height: 22px;
  }

  .service-box {
    flex-direction: column;
    gap: 45px;
  }

  .service-box__left,
  .service-box__right {
    width: 100%;
    padding: 35px 10px 20px;
  }

  .service-box__heading {
    font-size: 2rem;
    padding: 15px 16px;
    max-width: 100%;
    width: fit-content;
  }

  .service-box__flex {
    gap: 6px;
  }

  .service-box__text {
    font-size: 1.8rem;
    line-height: 13px;
    padding-block: 18.5px;
  }

  .service-box__right .service-box__heading {
    max-width: 280px;
    width: 100%;
    line-height: 15px;
    top: -25px;
  }

  .service-box__heading {
    line-height: 15px;
    top: -25px;
  }
}

/* target content*/

.target {
  background: #f0f0f0;
}

.tab {
  max-width: 1140px;
  width: 100%;
  overflow: hidden;
  background-color: #f1f1f1;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  flex-wrap: wrap;
}

.tablinks {
  line-height: 1.2;
  max-width: calc(100% / 6 - 18px);
  width: 100%;
  border-radius: 10px 15px 0px 0px;
}

.tablinks.active {
  max-width: 280px;
  width: 100%;
  height: 75px;

  @media (max-width: 767px) {
    width: 110px;
  }
}

.tablinks:first-child {
  background: #21bdb5;
}

.tablinks:nth-child(2) {
  background: #0e6fb8;
}

.tablinks:nth-child(3) {
  background: #f39800;
}

.tablinks:nth-child(4) {
  background: #727171;
}

.tablinks:nth-child(5) {
  background: #c8a5a4;
}

.tablinks:last-child {
  background: #09913a;
}

.tab button {
  background-color: inherit;
  /* float: left; */
  border: none;
  outline: none;
  cursor: pointer;
  padding: 10px 0;
  transition: 0.3s;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 20px;
  color: #fff;
}

.tab button:hover {
  opacity: 0.8;
}

.tab button.active {
  opacity: 0.8;
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
}

.tabcontent {
  display: none;
  /* padding: 5px; */
  border-top: none;
  max-width: 1140px;
}

.tabcontent.minimumpackage {
  display: block;
}

@media (max-width: 1199px) {
  .tab {
    flex-wrap: nowrap;
    overflow-x: auto;
    align-items: flex-end;
    justify-content: flex-start;
  }

  .tab button.active {
    font-size: 1.4rem;
  }

  .tab button {
    font-size: 1.2rem;
  }
}

@media (max-width: 767px) {
  .tab {
    flex-wrap: nowrap;
    overflow-x: auto;
    align-items: flex-end;
    justify-content: flex-start;
  }

  /* .tab::-webkit-scrollbar {
		display: none;
	} */

  .target .inner {
    padding: 0 13px;
  }

  .tablinks {
    width: 100%;
    width: calc(100% / 2 - 0px);
  }

  .tablinks:first-child,
  .tablinks:nth-child(2) {
    width: 110px;
    border-radius: 10px 15px 0 0;
  }

  .tab button {
    font-size: 1.3rem;
    font-weight: 700;
    line-height: 15.6px;
    color: #fff;
    padding: 4.5px 0;
    flex-shrink: 0;
    max-width: 100%;
    width: 110px;
  }

  .tab button.active {
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 16.8px;
    color: #fff;
  }

  .tablinks.active {
    max-width: 173px;
    height: 50px;
  }
}

/* target  pc*/
.familyapartment {
  max-width: 1140px;
  width: 100%;
  font-family: "Noto Sans JP",  sans-serif;
}

.target-plan__row {
  font-family: "Noto Sans JP",  sans-serif;
  display: flex;
  justify-content: flex-end;
  align-items: stretch;
  gap: 30px;
  background: #0e6fb8;
  padding: 30px;
}

.target-plan__row.-turquoise {
  background: #21bdb5;
}
.target-plan__row.-orange {
  background: #f39800;
}

.target-plan__row.-pink {
  background: #c8a5a4;
}

.target-plan__row.-gray {
  background: #727171;
}

.target-plan__image img {
  max-width: 100%;
  width: 100%;
  height: auto;
}

.target-plan__col-title {
  font-size: 28px;
  font-weight: 700;
  line-height: 21px;
  color: #0e6fb8;
  padding: 15px 10px;
  background: #fff;
  text-align: center;
}
.target-plan__pink {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 20px;
  margin-top: 15px;

  @media (max-width: 767px) {
    flex-direction: column;
  }
}

.target-plan-table-ttl {
  color: #fff;
  text-align: center;
  font-size: 17px;
  font-family: "Noto Sans JP",  sans-serif;
  font-weight: 700;
  line-height: 12px;
  width: 100%;
  border: 1px solid #fff;
  padding: 15px;
}

.target-plan__pink-left {
  max-width: 270px;

  @media (max-width: 767px) {
    max-width: 100%;
  }
}

.target-plan__pink-right {
  max-width: 270px;
  @media (max-width: 767px) {
    max-width: 100%;
  }
}

.target-plan__col-title.-orange {
  color: #f39800;
}

.target-plan__col-title.-pink {
  color: #c8a5a4;
}

.target-plan__col-title.-gray {
  color: #727171;
}

.target-plan__col:first-child {
  flex: 1;
}

.target-plan__col:last-child {
  max-width: 490px;
  width: 100%;
}

.target-plan__table {
  width: 100%;
}
.target-plan__tr.-pink {
  border-bottom: unset;
  align-items: center;
  display: flex;
}
.target-plan__tr {
  border-bottom: 1px solid #fff;

  &.-pink {
    border-bottom: 1px solid #fff;

    .target-plan__td {
      width: 80px;
    }

    .target-plan__th {
      width: calc(100% - 80px);
    }
  }

  &:first-of-type {
    .target-plan__td {
      padding: 20px 0 15px 0;
    }

    .target-plan__th {
      padding-block: 20px 0 15px 0;
    }
  }
}

.target-plan__td {
  width: 150px;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  line-height: 12px;
  padding-block: 15px;
}

.target-plan__th {
  flex: 1;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
  padding: 15px 10px;
}

.target-plan__th.lh {
  line-height: 17px;
}

.target-issue {
  padding: 30px;
  background-color: #fff;
}

.target-plan__title {
  border-top: 1px solid #0e6fb8;
  border-bottom: 1px solid #0e6fb8;
  background: #fff;
  padding: 14px 10px;
  color: #0e6fb8;
  font-size: 28px;
  font-weight: 700;
  line-height: 21px;
  text-align: center;
}

.target-plan__title.-orange {
  border-top: 1px solid #f39800;
  border-bottom: 1px solid #f39800;
  color: #f39800;
}

.target-plan__title.-pink {
  border-top: 1px solid #c8a5a4;
  border-bottom: 1px solid #c8a5a4;
  color: #c8a5a4;
}

.target-plan__title.-gray {
  border-top: 1px solid #727171;
  border-bottom: 1px solid #727171;
  color: #727171;
}

.target-issue__content {
  background: #e9f3f9;
  display: flex;
  margin-top: 15px;
  margin-left: 15px;
}

.target-issue__content.-orange {
  background: #fff2db;
}

.target-issue__content.-pink {
  background: #fbf4f4;
}

.target-issue__content.-gray {
  background: #f0f0f0;
}
.target-solution__content.-turquoise {
  background: #ecfffe;
}
.target-solution__content.-orange {
  background: #fff2db;
}

.target-solution__content.-pink {
  background: #fbf4f4;
}

.target-solution__content.-gray {
  background: #f0f0f0;
}

.target-issue__content:first-of-type {
  margin-top: 20px;
}

.target-issue__head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  max-width: 275px;
  width: 100%;
  margin-left: -10px;
  gap: 10px;
}

.target-issue__head .num {
  color: #0e6fb8;
  font-size: 50px;
  font-weight: 700;
  line-height: 35px;
  font-family: "din-2014", sans-serif;
  display: inline-block;
}

.target-issue__head .num.-orange {
  color: #f39800;
}

.target-issue__head .num.-pink {
  color: #c8a5a4;
}

.target-issue__head .num.-gray {
  color: #727171;
}

.target-issue__head .text {
  color: #0e6fb8;
  font-size: 20px;
  font-weight: 700;
  line-height: 29px;
}

.target-issue__head .text.-orange {
  color: #f39800;
}

.target-issue__head .text.-pink {
  color: #c8a5a4;
}

.target-issue__head .text.-gray {
  color: #727171;
}

.target-issue__text {
  background: #fff;
  padding: 10px 20px;
  color: #222;
  font-size: 16px;
  font-weight: 500;
  line-height: 23px;
  margin-bottom: 10px;
}

.target-issue__text:last-of-type {
  margin-bottom: 0;
}

.target-issue__desc {
  flex: 1;
  padding: 15px;
}

.target-survey {
  border: 1px solid #0e6fb8;
  margin-top: 35px;
  position: relative;

  &.-pink {
    .target-survey__row {
      @media (max-width: 767px) {
        padding-top: 48px;
      }
    }
  }

  &.-orange {
    .target-survey__row {
      @media (max-width: 767px) {
        padding-top: 48px;
      }
    }
  }

  &.-gray {
    .target-survey__title {
      max-width: 310px;
    }

    .target-survey__row {
      @media (max-width: 767px) {
        padding-top: 48px;
      }
    }
  }

  &.-green {
    @media (max-width: 767px) {
      .target-survey__title {
        max-width: 310px;
      }
    }

    .target-survey__row {
      @media (max-width: 767px) {
        padding-top: 48px;
      }
    }
  }
}

.target-survey.-orange {
  border: 1px solid #f39800;
}

.target-survey.-pink {
  border: 1px solid #c8a5a4;
}

.target-survey.-gray {
  border: 1px solid #727171;
}

.target-survey__title {
  color: #0e6fb8;
  font-size: 20px;
  font-weight: 700;
  line-height: 29px;
  background: #fff;
  padding-inline: 15px;
  position: absolute;
  top: -15px;
  margin-left: 15px;
}

.target-survey__title.-orange {
  color: #f39800;
}

.target-survey__title.-pink {
  color: #c8a5a4;
}

.target-survey__title.-gray {
  color: #727171;
}

.target-survey__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
  padding-block: 30px 20px;
}

.target-survey__contents {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 910px;
  width: 100%;
  margin-inline: auto;
  margin-bottom: 30px;
}

.target-survey__rtxt {
  color: #222;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
}

.target-survey__ltxt {
  color: #222;
  font-size: 20px;
  font-weight: 700;
  line-height: 29px;
  padding: 15px 20px;
  border: 3px solid #ea5514;
}

.target-survey__col.-gray:first-child {
  max-width: 480px;
  width: 100%;
}

.target-survey__col.g-txt {
  max-width: 380px;
  width: 100%;

  @media (max-width: 767px) {
    max-width: 100%;
  }
}

.target-survey__col {
  &.greenw {
    @media (min-width: 992px) {
      max-width: 380px;
      width: 100%;
    }
  }
}

.target-survey__head {
  display: flex;
  align-items: center;
  gap: 20px;
}

.target-survey__num {
  color: #0e6fb8;
  text-align: center;
  font-family: "din-2014", sans-serif;
  font-size: 50px;
  font-weight: 700;
  line-height: 35px;
}

.target-survey__num.-orange {
  color: #f39800;
}

.target-survey__num.-pink {
  color: #c8a5a4;
}

.target-survey__num.-gray {
  color: #727171;
}

.target-survey__qs {
  color: #222;
  font-size: 20px;
  font-weight: 500;
  line-height: 29px;
}

.target-survey__text {
  color: #222;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  padding-top: 20px;
}

.target-survey__image {
  max-width: 380px;
  width: 100%;
  line-height: 0;

  &.w300 {
    max-width: 300px;
    margin-left: auto;
  }
}

.target-survey__image img {
  max-width: 100%;
  height: auto;
}

.target-solution {
  padding-inline: 30px;
  background: #fff;
  padding-bottom: 30px;

  @media (max-width: 767px) {
    padding-bottom: 10px;
  }
}

.target-solution__content {
  padding: 20px 30px 30px 30px;
  background: #e9f3f9;
  margin-top: 20px;
}

.target-solution__head {
  display: flex;
  align-items: center;
}

.target-solution__head .ttl {
  max-width: 260px;
  width: 100%;
  border-right: 1px solid #0e6fb8;
  color: #0e6fb8;
  font-size: 22px;
  font-weight: 700;
  line-height: 32px;
  padding-block: 7px;
}

.target-solution__head .ttl.-orange {
  border-right: 1px solid #f39800;
  color: #f39800;

  @media (max-width: 767px) {
    border-left: 4px solid #f39800;
    border-right: 0;
  }
}

.target-solution__head .ttl.-pink {
  border-right: 1px solid #c8a5a4;
  color: #c8a5a4;

  @media (max-width: 767px) {
    border-left: 4px solid #c8a5a4;
    border-right: 0;
  }
}

.target-solution__head .ttl.-gray {
  border-right: 0;
  color: #727171;

  @media (max-width: 767px) {
    border-left: 4px solid #727171;
    border-right: 0;
  }
}

.target-solution__head .ttl.-orange.noborder {
  border-right: unset;
}

.target-solution__head .ttl.-pink.noborder {
  border-right: unset;
}

.target-solution__head .ttl.-gray.noborder {
  border-right: unset;
}

.target-solution__head .txt {
  flex: 1;
  color: #222;
  font-size: 16px;
  font-weight: 500;
  line-height: 23px;
  padding-left: 25px;

  .tag {
    background: #c8a5a4;
    display: inline-block;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 80px;
    width: 100%;
    color: #fff;
    height: auto;
  }
}

.target-solution__head-w {
  width: 100%;
}

.target-solution__head .txt.-orange {
  border-left: 1px solid #f39800;
  @media (max-width: 767px) {
    border-left: 0;
  }
}

.target-solution__head .txt.-pink {
  border-left: 1px solid #c8a5a4;
  display: inline-flex;
  align-items: stretch;
  width: 100%;
  gap: 10px;
  margin-bottom: 5px;

  &:last-of-type {
    margin-bottom: 0;
  }

  @media (max-width: 767px) {
    border-left: 0;
  }
}

.target-solution__head .txt.-gray {
  border-left: 1px solid #727171;

  @media (max-width: 767px) {
    border-left: 0;
  }
}

.target-solution__row {
  display: flex;
  align-items: stretch;
  justify-content: flex-start;
  gap: 15px;
  flex-wrap: wrap;
  padding-top: 20px;
}

.target-solution__col {
  width: calc(100% / 4 - 15px);
  background: #fff;
  padding: 15px;
}

.target-solution__col-title {
  color: #0e6fb8;
  font-size: 18px;
  font-weight: 700;
  line-height: 26px;
  border-bottom: 1px solid #0e6fb8;
  padding-block: 15px 5px;
  text-align: center;
}

.target-solution__col-title.-orange {
  color: #f39800;
  border-bottom: 1px solid #f39800;
}

.target-solution__col-title.-pink {
  color: #c8a5a4;
  border-bottom: 1px solid #c8a5a4;
  letter-spacing: -1px;
}

.target-solution__col-title.-gray {
  color: #727171;
  border-bottom: 1px solid #727171;
}

.target-solution__col-text {
  color: #222;
  font-size: 16px;
  font-weight: 500;
  line-height: 23px;
  padding-top: 10px;
}

.target-solution__image {
  max-width: 210px;
  width: 100%;
  line-height: 0;
  height: auto;
}

.target-solution__image img {
  object-fit: cover;
  height: auto;
}

@media (max-width: 991px) {
  .target-plan__col:last-child {
    max-width: 275px;
    width: 100%;
  }

  .target-survey__row {
    padding-inline: 15px;
  }

  .target-plan__row {
    align-items: center;
  }

  .target-solution__col {
    width: calc(100% / 3 - 15px);
    padding: 10px;
  }

  .target-solution__col-title {
    font-size: 15px;
  }

  .target-solution__col-text {
    font-size: 14px;
  }
}

@media (max-width: 767px) {
  .target-plan__row {
    flex-direction: column;
    gap: 10px;
    padding: 10px;
  }

  .target-plan__col:last-child {
    max-width: 100%;
    width: 100%;
  }

  .target-plan__col:first-child {
    width: 100%;
  }

  .target-plan__image img {
    aspect-ratio: 326 / 200;
    object-fit: cover;
  }

  .target-plan__td {
    width: 80px;
    font-size: 13px;
    line-height: 10px;
    padding-block: 10px 15px;
  }

  .target-plan__th {
    font-size: 13px;
    line-height: 13px;
    padding: 10px 0px 15px 10px;
  }

  .target-plan__th.lh {
    line-height: 14px;
  }

  .target-plan__tr {
    &:first-of-type {
      .target-plan__td {
        padding-block: 10px 15px;
      }

      .target-plan__th {
        padding-block: 10px 0 15px 10px;
      }
    }
  }

  .target-plan__col-title {
    font-size: 16px;
    line-height: 12px;
    padding: 10px;
  }

  .target-plan__title {
    font-size: 16px;
    line-height: 12px;
    padding-block: 14px;
  }

  .target-issue {
    padding: 20px 10px;
  }

  .target-issue__desc {
    padding: 15px 10px;
  }

  .target-issue__content {
    flex-direction: column;
    margin-top: 10px;
    padding-top: 10px;
    margin-left: 0;
  }

  .target-issue__head {
    margin-left: 10px;
  }

  .target-issue__head .num {
    font-size: 40px;
    line-height: 28px;
  }

  .target-issue__head .text {
    font-size: 16px;
    line-height: 23px;
  }

  .target-issue__text {
    padding: 10px;
    font-size: 13px;
    line-height: 19px;
  }

  .target-issue__content:first-of-type {
    margin-top: 10px;
  }

  .target-survey {
    margin-top: 30px;
  }

  .target-survey__row {
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
    padding-block: 30px 20px;
    margin-inline: 0;
  }

  .target-survey__contents {
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
    padding-inline: 10px;
  }

  .target-survey__rtxt {
    color: #222;
    font-size: 10px;
    font-weight: 500;
    line-height: 14px;
    text-align: start;
  }

  .target-survey__ltxt {
    color: #222;
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
    border: 3px solid #ea5514;
    width: 100%;
    margin-bottom: 10px;
    text-align: center;
    padding: 12px 0;
  }

  .target-survey__head {
    gap: 10px;
  }

  .target-survey__num {
    font-size: 30px;
    line-height: 21px;
  }

  .target-survey__qs {
    font-size: 15px;
    line-height: 22px;
  }

  .target-survey__text {
    font-size: 10px;
    line-height: 14px;
    padding-top: 5px;
  }

  .target-survey__title {
    padding-inline: 5px;
    top: -15px;
    margin-left: 0;
    max-width: 230px;
    width: 100%;
    display: inline-block;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
  }

  .target-survey__image {
    max-width: 100%;
    width: 100%;
    padding-inline: 9.5px;
  }

  .target-survey__image img {
    max-width: 100%;
    width: 100%;
  }

  .target-solution__head {
    flex-direction: column;
  }

  .target-solution__head .ttl {
    max-width: 100%;
    width: 100%;
    border-left: 4px solid #0e6fb8;
    border-right: unset;
    font-size: 16px;
    line-height: 23px;
    padding-block: 3.5px;
    padding-left: 11px;
  }

  .target-soultion__head .ttl.-orange {
    border-right: 1px solid #f39800;
    color: #f39800;
  }

  .target-soultion__head .ttl.-pink {
    border-right: 1px solid #c8a5a4;
    color: #c8a5a4;
  }

  .target-soultion__head .ttl.-gray {
    border-right: 1px solid #727171;
    color: #727171;
  }

  .target-solution__head .txt {
    flex: 1;
    font-size: 13px;
    line-height: 19px;
    padding-left: unset;
    padding-top: 10px;
  }

  .target-solution__content {
    padding: 15px 10px 10px 10px;
    margin-top: 10px;
  }

  .target-solution {
    padding-inline: 10px;
  }

  .target-solution__row {
    flex-direction: column;
    gap: 10px;
    padding-top: 15px;
  }

  .target-solution__col {
    width: 100%;
    padding: 5px 10px 5px 5px;
    display: flex;
    align-items: center;
    gap: 5px;
  }

  .target-solution__desc {
    display: flex;
    flex-direction: column;
    width: 100%;
  }

  .target-solution__col-title {
    font-size: 16px;
    line-height: 23px;
    padding-block: 5px;
    text-align: left;
  }

  .target-solution__col-text {
    font-size: 13px;
    line-height: 19px;
    text-align: left;
  }

  .target-solution__image {
    max-width: 100px;
  }

  .target-solution__image img {
    max-width: 100%;
  }
}

/* partner */
.partner-list {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 1.5%;
}

.partner-list li {
  width: 32.3%;
}

.partner-list h3 {
  font-size: 2.2rem;
  font-weight: bold;
  padding-block: 43px;
  background: #fff;
  color: #222;
  text-align: center;
  min-height: 150px;
  line-height: 32px;
  font-family: "Noto Sans JP",  sans-serif;
}

.partner-list h3 .org {
  display: inline-block;
  color: #f79421;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 0;
}

@media screen and (max-width: 991px) {
  .partner-list h3 {
    font-size: 1.5rem;
  }

  .partner-list h3 .org {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 767px) {
  .partner-list {
    display: flex;
    flex-direction: column;
  }

  .partner-list li {
    width: 100%;
  }

  .partner-list {
    gap: 30px;
  }

  .partner-img img {
    aspect-ratio: 346/170;
    object-fit: cover;
  }

  .partner-list h3 {
    color: #222;
    text-align: center;
    font-family: "Noto Sans JP",  sans-serif;
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
    padding-block: 30px;
    min-height: auto;
  }

  .partner-list h3 .org {
    color: #f79421;
    font-family: "Noto Sans JP",  sans-serif;
    font-size: 16px;
    font-weight: 700;
    line-height: 0;
  }
}

.avantia-bg img {
  width: 100%;
  height: auto;
}

@media (max-width: 767px) {
  .avantia-bg img {
    aspect-ratio: 376/250;
    object-fit: cover;
  }
}

.target-plan__row.-green {
  background: #09913a;
}
.target-plan__col-title.-green {
  color: #09913a;
}
.target-plan__title.-green {
  border-top: 1px solid #09913a;
  border-bottom: 1px solid #09913a;
  color: #09913a;
}
.target-issue__content.-green {
  background: #e8f3ec;
}
.target-solution__content.-green {
  background: #e8f3ec;
}
.target-issue__head .num.-green {
  color: #09913a;
}
.target-issue__head .text.-green {
  color: #09913a;
}
.target-survey.-green {
  border: 1px solid #09913a;
}
.target-survey__title.-green {
  color: #09913a;
}
.target-survey__num.-green {
  color: #09913a;
}
.target-solution__head .ttl.-green {
  border-right: 1px solid #09913a;
  color: #09913a;

  @media (max-width: 767px) {
    border-left: 4px solid #09913a;
    border-right: 0;
  }
}
.target-solution__head .ttl.-green.noborder {
  border-right: unset;
}
.target-solution__head .txt.-green {
  border-left: 1px solid #09913a;
}
.target-solution__col-title.-green {
  color: #09913a;
  border-bottom: 1px solid #09913a;
}
@media (max-width: 767px) {
  .target-soultion__head .ttl.-green {
    border-right: 1px solid #09913a;
    color: #09913a;
  }
  .target-soultion__head .ttl.-green {
    border-right: 1px solid #09913a;
    color: #09913a;
  }
}

.target-survey__row.width {
  max-width: 968px;
  width: 100%;
}

.target-survey-gtext {
  color: #222;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 46px;
  border: 3px solid #ea5514;
  padding: 0 3px;
  text-align: center;
  max-width: 242px;
  width: 100%;

  @media (max-width: 776px) {
    max-width: 100%;
    padding: 17px;
    font-size: 22px;
    line-height: 16px;
  }
}

.minimumpackage .target-plan__row {
  justify-content: center;
  text-align: center;
  flex-direction: column;
  gap: 10px;
}
.minimumpackage .target-plan__row.-turquoise p {
  color: #fff;
}
.minimumpackage .target-solution {
  padding-top: 30px;
}
.target-plan__title.-turquoise {
  border-top: 1px solid #21bdb5;
  border-bottom: 1px solid #21bdb5;
  color: #21bdb5;
}
.minimumpackage .target-solution__col-title {
  color: #21bdb5;
}
.minimumpackage .target-solution__col {
  width: calc(100% / 3 - 15px);
  @media (max-width: 767px) {
    width: 100%;
  }
}
.minimumpackage .target-solution__image {
  margin: 0 auto;
}
.minimumpackage .red-rabel {
  padding: 5px 20px;
  background: #ff2929;
  color: #fff;
  width: fit-content;
  margin: 0 auto;
}

/* リード文 */
.tabcontent__lead {
  margin-top: 30px;
}
.tabcontent__lead p {
  text-align: center;
  /*margin-bottom: 1em;*/
}
.tabcontent__lead p .b {
  font-size: 20px;
  font-size: 2.4rem;
  @media (max-width: 767px) {
    font-size: 16px;
  }
}
.tabcontent__lead p span {
  color: #4173b0;
}
.tabcontent__lead p span.-turquoise {
  color: #4173b0;
}
.tabcontent__lead p span.-orange {
  color: #f79421;
}
.tabcontent__lead p span.-pink {
  color: #4173b0;
}
.tabcontent__lead p span.-gray {
  color: #4173b0;
}
.tabcontent__lead p span.-green {
  color: #4173b0;
}

/*全棟標準*/
.zentou {
  margin: 10px auto;
  display: table;
  background: #ff0000;
  color: #fff;
}

/* SALES */
.sales {
  .inner {
    max-width: 1230px;
  }
}

.sales-row {
  display: flex;
  align-items: stretch;
  gap: 30px;
  flex-wrap: wrap;
  margin-top: 50px;

  @media (max-width: 991px) {
    gap: 15px;
  }

  @media (max-width: 767px) {
    gap: 20px;
    margin-top: 20px;
  }
}

.sales-box {
  width: calc((100% / 3) - (30px * 2) / 3);
  background: #f7f7f7;

  @media (max-width: 991px) {
    width: calc((100% / 3) - (15px * 2) / 3);
  }

  @media (max-width: 767px) {
    width: 100%;
  }
}

.sales-top-t {
  @media (min-width:768px) and (max-width:991px) {
    font-size: 2.1rem !important;
  }
}

.sales-top-b {
  line-height: 26px;

   @media (min-width:768px) and (max-width:991px) {
    font-size: 1.6rem !important;
  }

  @media (max-width: 767px) {
    line-height: 17px;
  }
}

.sales-box-t {
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  background: #002c56;
  line-height: 16px;
  padding: 30px 0 29px;

  @media (max-width: 991px) {
    font-size: 16px;
    padding: 25px 0;
  }

  @media (max-width: 767px) {
    font-size: 1.8rem;
    font-style: normal;
    font-weight: 700;
    line-height: 13px;
    padding: 24px 0 23px;
  }

  &.second {
    background-color: #26537d;
  }
  &.third {
    background-color: #4173b0;
  }
}

.sales-box-b {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 15px;
  padding: 38px 0 37px;

  @media (max-width: 991px) {
    font-size: 1.4rem;
    line-height: 1;
    padding: 25px 0;
  }

  @media (max-width: 767px) {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 12px;
    padding: 34px 0;
  }
}

.sales-box-img {
  img {
    width: 100%;
    height: auto;
  }
}

/* SALES */

/* OVERVIEW */
.overview {
  background: #f7f7f7;

  .inner {
    max-width: 1200px;
  }
}

.overview-b-ttl {
  color: #26537d;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 28px;
  font-weight: 700;
  line-height: 21px;
  padding: 14px 0;
  border-block: 1px solid #26537d;
  margin-bottom: 55px;

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 12px;
    margin-bottom: 30px;
  }
}

.overview-box-wrp {
  padding: 40px 30px 30px;
  border-radius: 15px;
  background: #fff;
  position: relative;

  @media (max-width: 767px) {
    padding: 25px 10px 20px;
    border-radius: 15px;
  }

  &:not(:first-of-type) {
    margin-top: 75px;
  }
}

.overview-box-tag {
  max-width: 400px;
  width: 100%;
  padding: 13.5px 0;
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 18px;
  border-radius: 60px;
  background: #26537d;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -25px;

  @media (max-width: 767px) {
    top: -20px;
    font-size: 20px;
    font-weight: 700;
    line-height: 15px;
    padding: 10px 0;
    max-width: 296px;
  }
  &.width {
    max-width: 450px;

    @media (max-width: 767px) {
      max-width: 296px;
    }
  }
}

.overview-box-row {
  display: flex;
  align-items: stretch;
  gap: 30px;
  flex-wrap: wrap;

  @media (max-width: 767px) {
    gap: 10px;
  }
}

.overview-box-b {
  width: calc((100% / 3) - (30px * 2) / 3);
  border-radius: 10px;
  background: #e9f3f9;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 140px;
  padding: 15px;

  @media (max-width: 767px) {
    width: 100%;
    min-height: 100px;
    padding: 7px;
  }
}

.overview-box-num {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  color: #dae9f5;
  font-family: "din-2014", sans-serif;
  font-size: 130px;
  font-weight: 700;
  line-height: 90px;
  z-index: 0;

  @media (max-width: 767px) {
    font-size: 100px;
    font-weight: 700;
    line-height: 69px;
  }
}

.overview-box-b-txt {
  z-index: 1;
  color: #002c56;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 29px;

  @media (max-width: 991px) {
    font-size: 15px;
    font-weight: 700;
    line-height: 22px;
  }

  @media (max-width: 767px) {
    font-size: 18px;
    font-weight: 700;
    line-height: 26px;
  }

  &.lh {
    line-height: 24px;

    @media (max-width: 767px) {
      line-height: 23.2px;
    }
  }

  .xs {
    font-size: 14px;
    line-height: 20px !important;
    font-weight: 500;
    display: block;

    @media (max-width: 767px) {
      font-size: 12px;
      font-weight: 400;
    }
  }
}

.overview-system-box {
  width: calc((100% / 3) - (30px * 2) / 3);
  border-radius: 10px;
  background: #e9f3f9;
  display: flex;
  align-items: center;
  padding: 21px 30px;

  @media (max-width: 1199px) {
    padding: 21px 15px;
  }

  @media (max-width: 767px) {
    width: 100%;
    gap: 10px;
    padding: 10px 10px 10px 20px;
  }
}

.overview-system-left {
  max-width: 80px;
  width: 100%;

  img {
    width: 100%;
    height: auto;
  }

  @media (max-width: 991px) {
    max-width: 50px;
  }
}

.overview-system-right {
  width: 100%;
}

.overview-system-ttl {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 35px;

  @media (max-width: 991px) {
    font-size: 18px;
    line-height: 26px;
  }
}

.overview-system-txt {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 29px;
  margin-top: 5px;

  @media (max-width: 991px) {
    font-size: 16px;
    font-weight: 500;
    line-height: 23px;
    margin-top: 0;
  }
}

.overview-basic-btm {
  color: #222;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 26px;
  margin-top: 15px;

  @media (max-width: 767px) {
    font-size: 12px;
    line-height: 17px;
    margin-top: 10px;
  }
}

.overview-cost-row {
  display: flex;
  align-items: stretch;
  @media (max-width: 767px) {
    flex-direction: column;
  }
}

.overview-cost-left {
  width: 400px;
  background: #26537d;
  padding: 10px;
  display: flex;
  align-items: center;
  min-height: 70px;
  justify-content: center;

  @media (max-width: 991px) {
    width: 300px;
  }

  @media (max-width: 767px) {
    width: 100%;
    min-height: 53px;
    padding: 20px;
  }
}

.overview-cost-right {
  width: calc(100% - 400px);
  background: #e9f3f9;
  padding: 10px;
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;

  @media (max-width: 991px) {
    width: calc(100% - 300px);
  }

  @media (max-width: 767px) {
    width: 100%;
    padding: 20px;
    min-height: 53px;
  }
}

.overview-cost-txt {
  color: #fff;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 16px;

  @media (max-width: 767px) {
    font-size: 18px;
    font-weight: 700;
    line-height: 13px;
  }
}

.overview-cost-price {
  color: #26537d;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 16px;

  @media (max-width: 767px) {
    font-size: 18px;
    line-height: 13px;
  }

  .xs {
    line-height: 1;
    font-size: 16px;
    color: #222;

    @media (max-width: 767px) {
      font-size: 14px;
    }
  }
}

.overview-basic-wrp {
  padding: 60px 30px 30px 30px;
  border-radius: 10px;
  background: #e9f3f9;
  margin-bottom: 20px;

  @media (max-width: 767px) {
    padding: 31px 11px 20px;
  }
}

.overview-basic-row {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 45px 20px;

  @media (max-width: 767px) {
    gap: 26px 8px;
  }
}

.overview-basic-box {
  width: calc((100% / 4) - (20px * 3) / 4);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  min-height: 120px;
  border: 2px solid #26537d;
  background-color: #26537d;
  border-radius: 10px;
  color: #fff;

  &.no-out {
    border: 0;
    background-color: #fff;
    .overview-basic-txt {
      color: #222;
    }
  }

  @media (max-width: 767px) {
    width: calc((100% / 4) - (8px * 3) / 4);
    min-height: 80px;
  }
}

.overview-basic-tag {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -30px;
  max-width: 60px;

  @media (max-width: 767px) {
    max-width: 35px;
    top: -20px;
  }

  img {
    width: 100%;
    height: auto;
  }
}

.overview-basic-txt {
  color: #fff;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 26px;

  @media (max-width: 767px) {
    font-size: 14px;
    font-weight: 700;
    line-height: 20px;
  }
}

.overview-appendices {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 21px;
  gap: 20px;

  @media (max-width: 767px) {
    flex-direction: column-reverse;
    margin-top: 10px;
  }
}

.overview-appendices-txt {
  color: #222;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 29px;

  @media (max-width: 991px) {
    font-size: 16px;
  }

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
    text-align: center;
  }
}

.overview-appendices-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.overview-appendices-box {
  display: flex;
  align-items: center;
  gap: 5px;
}

.overview-appendices-box-txt {
  color: #222;
  font-size: 18px;
  font-weight: 700;
  line-height: 26px;

  @media (max-width: 991px) {
    font-size: 14px;
  }

  @media (max-width: 767px) {
    font-size: 12px;
    font-weight: 700;
    line-height: 17px;
  }
}

.overview-appendices-box-img {
  max-width: 40px;

  @media (max-width: 767px) {
    max-width: 25px;
  }

  img {
    width: 100%;
    height: auto;
  }
}

/* OVERVIEW */

/* OPERATION */
.operation {
  .inner {
    max-width: 1200px;
  }
}

.operation-box-wrap {
  border-radius: 15px;
  background: #e9f3f9;
  padding: 30px;

  @media (max-width: 767px) {
    padding: 15px 10px;
  }

  .overview-b-ttl {
    margin-bottom: 30px;

    @media (max-width: 767px) {
      margin-bottom: 10px;
    }
  }
}

.operation-flow-img {
  overflow-x: auto;

  img {
    width: 100%;
    height: auto;


  }
}

.operation-mid-text {
  line-height: 32px;

   @media (min-width:768px) and (max-width:991px) {
    font-size: 1.8rem !important;
  }
  @media (max-width: 767px) {
    line-height: 20px;
  }
}

.operation-box-wrap.fit {
  padding: 20px;
}

.operation-fit {
  display: flex;
  align-items: center;
  gap: 10px;

  @media (max-width: 767px) {
    flex-direction: column;
    gap: 20px;
  }
}

.operation-fit-left {
  max-width: 380px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;

  @media (max-width: 1199px) {
    max-width: 300px;
  }

  @media (max-width: 991px) {
    max-width: 270px;
  }

  @media (max-width: 767px) {
    max-width: 100%;
  }
}

.operation-fit-right {
  max-width: 710px;
  width: 100%;
}

.operation-fit-content {
  line-height: 1;
}

.operation-fit-left-txt {
  text-align: center;
  color: #26537d;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 34px;
  font-weight: 700;
  line-height: 25px;

  @media (max-width: 767px) {
    font-size: 24px;
    font-weight: 700;
    line-height: 18px;
  }

  &.xs {
    font-size: 28px;
    font-weight: 700;
    line-height: 21px;
    margin-top: 30px;

    @media (max-width: 767px) {
      margin-top: 15px;
      font-size: 18px;
      font-weight: 700;
      line-height: 13px;
    }
  }
}

.operation-fit-left-btm {
  color: #26537d;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 19px;
  margin-top: 30px;

  @media (max-width: 767px) {
    margin-top: 15px;
    font-size: 12px;
    font-weight: 500;
    line-height: 14.33px;
  }
}

.operation-fit-btm {
  font-family: "Noto Sans JP",  sans-serif;
  color: #222;
  font-size: 14px;
  font-weight: 500;
  line-height: 16px;
  margin-top: 10px;

  @media (max-width: 767px) {
    font-size: 12px;
    line-height: 13px;
    text-indent: -10px;
    padding-left: 10px;
  }
}

.operation-fit-row {
  display: flex;
  align-items: center;
  background-color: #fff;
  padding: 17px 20px;
  font-family: "Noto Sans JP",  sans-serif;
  width: 100%;
  gap: 20px;
  border-radius: 10px;

  &:not(:last-of-type) {
    margin-bottom: 10px;
  }

  @media (max-width: 991px) {
    gap: 10px;
  }

  @media (max-width: 767px) {
    flex-direction: column;
    padding: 10px;
  }
}

.operation-fit-dis {
  border-radius: 60px;
  background: #26537d;
  max-width: 230px;
  color: #fff;
  width: 100%;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  line-height: 18px;
  padding: 14px 0;

  @media (max-width: 991px) {
    max-width: 135px;
    font-size: 18px;
    padding: 10px 0;
  }

  @media (max-width: 767px) {
    padding: 9px 0;
    font-size: 16px;
    font-weight: 700;
    line-height: 12px;
    max-width: 200px;
  }
}

.operation-fit-km {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 18px;
  width: 100%;

  @media (max-width: 991px) {
    font-size: 16px;
  }

  @media (max-width: 767px) {
    font-size: 18px;
    line-height: 13px;
  }

  .xs {
    font-size: 20px;
    line-height: 1;

    @media (max-width: 991px) {
      font-size: 14px;
    }
  }
}

/* OPERATION */

/* CONTACT */
.contact {
  background-color: #002c56;

  .inner {
    max-width: 1090px;

    @media (max-width: 767px) {
      padding: 0 18px;
    }
  }
  .sec-ttl {
    color: #fff;

    &::before {
      background-color: #fff;
    }
  }

  .ttljp {
    color: #fff;
  }
}

.contact-txt {
  line-height: 29px;

  @media (max-width: 767px) {
    line-height: 19px;
  }
}

.contact-sub-ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 38px;
  margin-top: 30px;
  padding-inline: 16px;

  @media (max-width: 767px) {
    padding-inline: 6px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 23px;
    gap: 10px;
  }

  span {
    flex-shrink: 0;
  }

  &::after {
    content: "";
    width: 100%;
    height: 2px;
    background-color: #fff;
  }

  &::before {
    content: "";
    width: 100%;
    height: 2px;
    background-color: #fff;
  }
}

.contact-btn-row {
  display: flex;
  align-items: center;
  gap: 30px;
  margin-top: 30px;
  flex-wrap: wrap;

  @media (max-width: 767px) {
    gap: 10px;
    margin-top: 15px;
  }

  .btn-arrow {
    width: 100%;
    max-width: 100%;
    align-items: center;
    font-size: 2.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    height: 90px;

    @media (max-width: 991px) {
      font-size: 2rem;
    }

    @media (max-width: 767px) {
      flex-direction: column;
      height: 110px;
      font-size: 1.6rem;
      padding: 10px;
    }

    img {
      @media (max-width: 767px) {
        width: 30px;
        height: 30px;
      }
    }
  }
}

.contact-btn {
  width: calc((100% / 2) - (30px) / 2);

  @media (max-width: 767px) {
    width: calc((100% / 2) - (15px) / 2);
  }

  a {
    @media (max-width: 767px) {
      letter-spacing: 0.8px;
    }
  }
}

/* CONTACT */

/* OWNER NENIFITS */
.owner {
  background: #e9f3f9;

  .inner {
    max-width: 1200px;
  }

  .overview-b-ttl {
    margin-bottom: 30px;

    @media (max-width: 767px) {
      margin-bottom: 10px;
    }
  }

  img {
    width: 100%;
    height: auto;
  }
}

.owner-row {
  display: flex;
  gap: 30px;
  margin-bottom: 50px;
  align-items: flex-start;

  @media (max-width: 767px) {
    align-items: center;
    flex-direction: column;
    gap: 10px;
  }
}

.owner-box {
  padding: 15px;
  background-color: #fff;
  border-radius: 15px;

  @media (max-width: 767px) {
    padding: 10px;
  }

  &:not(:last-of-type) {
    margin-bottom: 15px;
  }

  .operation-fit-row {
    background-color: #f7f7f7;
    padding: 10px 20px;

    @media (max-width: 767px) {
      flex-direction: row;
      padding: 10px;
    }
  }

  .operation-fit-dis {
    max-width: 170px;
    font-size: 18px;
    padding: 8.5px 0;
    line-height: 13px;

    @media (max-width: 767px) {
      max-width: 120px;
      font-size: 14px;
      line-height: 10px;
      padding: 10px 0;
    }
  }

  .operation-fit-km {
    font-size: 20px;
    line-height: 15px;
    width: 100%;

    @media (max-width: 767px) {
      font-size: 16px;
    }

    .xs {
      font-size: 14px;

      @media (max-width: 767px) {
        font-size: 12px;
      }
    }
  }
}

.owner-left {
  max-width: 580px;
  width: 100%;
}

.owner-img {
  max-width: 530px;

  @media (max-width: 991px) {
    max-width: 300px;
  }
  @media (max-width: 767px) {
    max-width: 100%;
  }
}

.owner-box-tt {
  color: #26537d;
  font-size: 18px;
  font-weight: 700;
  line-height: 26px;
  border-left: 5px solid #26537d;
  padding: 2px 0;
  padding-left: 15px;
  margin-bottom: 10px;

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
    padding: 1px 0;
    padding-left: 15px;
  }
}

.owner-payback {
  display: flex;
  align-items: stretch;
  gap: 10px;

  @media (max-width: 767px) {
    flex-direction: column;
  }
}

.owner-payback-box {
  border-radius: 10px;
  background: #f7f7f7;
  width: 100%;
  padding: 30px;

  @media (max-width: 1199px) {
    padding: 5px 10px;
  }

  @media (max-width: 767px) {
    padding: 10px;
  }
}

.owner-payback-tag {
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 13px;
  border-radius: 60px;
  padding: 11px 0;
  background: #26537d;
  max-width: 200px;
  margin: 0 auto;

  @media (max-width: 1199px) {
    font-size: 15px;
    max-width: 145px;
  }

  @media (max-width: 767px) {
    font-size: 14px;
    font-weight: 700;
    line-height: 10px;
    max-width: 200px;
  }
}

.owner-payback-price {
  text-align: center;
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 26px;
  font-weight: 700;
  line-height: 22.5px;
  margin-top: 20px;

  @media (max-width: 767px) {
    margin-top: 10px;
    font-size: 20px;
    line-height: 15px;
  }

  .xs {
    font-size: 18px;
    font-weight: 500;
    line-height: 1;

    @media (max-width: 767px) {
      font-size: 14px;
    }
  }
}

.owner-box.rate {
  padding: 50px 30px 30px;

  @media (max-width: 767px) {
    padding: 45px 10px 20px;
  }
}

.owner-rate-btm {
  color: #222;
  text-align: right;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 23px;
  margin-top: 15px;

  @media (max-width: 767px) {
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
  }
}

.owner-rate-row {
  display: flex;
  align-items: center;
  gap: 30px;
  flex-wrap: wrap;

  @media (max-width: 767px) {
    gap: 35px;
  }
}

.owner-rate-box {
  width: calc((100% / 3) - (30px * 2) / 3);
  min-height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: #f7f7f7;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;

  @media (max-width: 767px) {
    width: 100%;
    min-height: 110px;
    padding: 40px 0 24px;
  }

  &::after {
    content: "";
    background-image: url("../images/top/home.svg");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: -30px;
    width: 60px;
    height: 60px;

    @media (max-width: 767px) {
      width: 50px;
      height: 50px;
      top: -25px;
    }
  }
}

.owner-rate-content {
  @media (min-width: 768px) {
    padding-top: 15px;
  }
}

.owner-rate-txt {
  text-align: center;
  color: #222;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 29px;

  .color {
    line-height: 1;
    color: #f79421;
  }

  @media (max-width: 991px) {
    font-size: 14px;
    line-height: 22px;
  }

  @media (max-width: 767px) {
    font-size: 16px;
    line-height: 23px;
  }
}

.owner-rate-btm-row {
  display: flex;
  align-items: center;
  gap: 20px;
  border-radius: 10px;
  justify-content: center;
  background: #f7f7f7;
  padding: 30px 0;
  margin-top: 26px;
  font-family: "Noto Sans JP",  sans-serif;

  @media (max-width: 767px) {
    margin-top: 20px;
    padding: 20px;
  }
}

.owner-rate-btm-img {
  max-width: 70px;

  @media (max-width: 767px) {
    max-width: 60px;
    width: 100%;
  }
  img {
    width: 100%;
    height: auto;
  }
}

.owner-rate-btm-txt {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 30px;
  font-weight: 700;
  line-height: 69px;
  display: flex;
  align-items: center;

  @media (max-width: 767px) {
    flex-direction: column;
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
    gap: 0;
    width: 100%;
  }

  .color {
    color: #f79421;
    line-height: 1;
  }

  .lg {
    font-size: 60px;
    margin-left: 15px;

    @media (max-width: 767px) {
      font-size: 40px;
    }
  }

  .xs {
    font-size: 38px;

    @media (max-width: 767px) {
      font-size: 24px;
    }
  }
}

.owner-rate-sm-txt {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  margin-top: 5px;

  @media (max-width: 767px) {
    font-size: 12px;
    line-height: 17px;
  }

  a {
    color: #4173b0;
    text-align: center;
    display: inline-flex;
    align-items: center;
    border-bottom: 1px solid #4173b0;

    &::after {
      content: "";
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M15.8333 10.8333V15.8333C15.8333 16.2754 15.6577 16.6993 15.3452 17.0118C15.0326 17.3244 14.6087 17.5 14.1667 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V5.83333C2.5 5.39131 2.67559 4.96738 2.98816 4.65482C3.30072 4.34226 3.72464 4.16667 4.16667 4.16667H9.16667V5.83333H4.16667V15.8333H14.1667V10.8333H15.8333ZM10.8333 2.5V4.16667H14.655L8.16083 10.6608L9.33917 11.8392L15.8333 5.345V9.16667H17.5V2.5H10.8333Z' fill='%234173B0'/%3E%3C/svg%3E");
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain;
      width: 20px;
      height: 20px;
      display: block;

      @media (max-width: 767px) {
        width: 15px;
        height: 15px;
      }
    }
  }
}

/* OWNER NENIFITS */

/* PROFITIABLITY & ROI */
.roi {
  .inner {
    max-width: 1200px;
  }

  @media (max-width: 767px) {
    .sec-ttl {
      margin-bottom: 50px;
    }
  }

  .overview-box-wrp {
    border-radius: 15px;
    background: #f7f7f7;
    padding-top: 70px;

    @media (max-width: 767px) {
      padding-top: 50px;
    }
  }
}

.roi-row {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 30px;

  @media (max-width: 991px) {
    gap: 15px;
  }

  @media (max-width: 767px) {
    gap: 35px;
  }
}

.roi-box {
  width: calc((100% / 2) - (30px * 1) / 2);
  border-radius: 10px;
  background: #fff;
  position: relative;
  min-height: 140px;
  padding: 40px 0 15px;
  display: flex;
  align-items: center;
  justify-content: center;

  @media (max-width: 991px) {
    width: calc((100% / 2) - (15px * 1) / 2);
  }

  @media (max-width: 767px) {
    width: 100%;
    padding: 35px 0 10px;
    min-height: 121px;
  }
}

.roi-img {
  max-width: 60px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -30px;

  @media (max-width: 767px) {
    max-width: 50px;
    top: -25px;
  }

  &.two {
    position: static;
    transform: none;
  }

  &.one {
  }
}

.roi-tow-img {
  display: flex;
  align-items: center;
  gap: 15px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -30px;

  @media (max-width: 767px) {
    top: -25px;
  }
}

.roi-content-top {
  color: #222;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  font-family: "Noto Sans JP",  sans-serif;
  line-height: 29px;

  @media (max-width: 991px) {
    font-size: 15px;
  }

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
  }
}

.roi-content-btm {
  color: #222;
  text-align: center;
  font-size: 28px;
  font-weight: 700;
  line-height: 41px;
  font-family: "Noto Sans JP",  sans-serif;
  margin-top: 5px;

  @media (max-width: 767px) {
    font-size: 26px;
    font-weight: 700;
    line-height: 38px;
  }

  .xs {
    font-size: 14px;
    font-weight: 500;
    line-height: 1;

    @media (max-width: 991px) {
      font-size: 14px;
    }

    @media (max-width: 767px) {
      font-size: 13px;
      font-weight: 400;
    }
  }

  &.lh {
    line-height: 30.5px;

    @media (max-width: 767px) {
      line-height: 27px;
    }
  }
}

.roi-btm {
  border-radius: 10px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Sans JP",  sans-serif;
  gap: 20px;
  padding: 30px 0;
  margin-top: 30px;

  @media (max-width: 767px) {
    margin-top: 20px;
    padding: 20px 0;
  }

  img {
    width: 100%;
    height: auto;
  }
}

.roi-btm-img {
  max-width: 70px;

  @media (max-width: 767px) {
    max-width: 60px;
  }
}

.roi-btm-txt {
  color: #222;
  text-align: center;
  font-size: 30px;
  font-weight: 700;
  line-height: 44px;
  display: flex;
  align-items: center;
  gap: 15px;

  @media (max-width: 991px) {
    font-size: 26px;
  }

  @media (max-width: 767px) {
    font-size: 20px;
    gap: 10px;
    flex-direction: column;
    line-height: 9px;
  }

  span {
    line-height: 1;
  }

  .lg {
    font-size: 60px;
    font-weight: 700;
    @media (max-width: 991px) {
      font-size: 45px;
    }

    @media (max-width: 767px) {
      font-size: 40px;
    }
  }

  .md {
    font-size: 40px;
    @media (max-width: 991px) {
      font-size: 34px;
    }
  }

  .xs {
    font-size: 26px;
    @media (max-width: 767px) {
      font-size: 14px;
    }
  }

  .color {
    color: #f79421;
  }
}

.roi-graph-img {
  margin-top: 25px;

  @media (max-width: 767px) {
    margin-top: 10px;
  }
  img {
    width: 100%;
    height: auto;
  }
}

.roi-period {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}

.roi-period-box {
  width: calc((100% / 2) - (20px * 1) / 2);
  border-radius: 10px;
  background: #fff;
  display: flex;
  align-items: center;
  min-height: 120px;
  padding: 0 30px;

  @media (max-width: 767px) {
    width: 100%;
    padding: 0 10px;
    min-height: 66px;
  }
}

.roi-period-txt {
  color: #222;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 35px;
  position: relative;
  padding-left: 50px;

  @media (max-width: 991px) {
    font-size: 16px;
    line-height: 30px;
  }
  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
    padding-left: 40px;
  }

  &::after {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='35' height='36' viewBox='0 0 35 36' fill='none'%3E%3Cmask id='mask0_6015_2519' style='mask-type:luminance' maskUnits='userSpaceOnUse' x='1' y='2' width='33' height='32'%3E%3Cpath d='M17.5 32.5837C19.4155 32.586 21.3125 32.2099 23.0821 31.4769C24.8518 30.7438 26.4591 29.6683 27.8119 28.3122C29.168 26.9595 30.2435 25.3521 30.9765 23.5825C31.7096 21.8128 32.0857 19.9158 32.0833 18.0003C32.0857 16.0849 31.7096 14.1878 30.9765 12.4182C30.2435 10.6486 29.168 9.04119 27.8119 7.68846C26.4591 6.33233 24.8518 5.25685 23.0821 4.52382C21.3125 3.79078 19.4155 3.41464 17.5 3.417C15.5845 3.41464 13.6875 3.79078 11.9179 4.52382C10.1482 5.25685 8.54086 6.33233 7.18813 7.68846C5.83199 9.04119 4.75651 10.6486 4.02348 12.4182C3.29045 14.1878 2.91431 16.0849 2.91667 18.0003C2.91431 19.9158 3.29045 21.8128 4.02348 23.5825C4.75651 25.3521 5.83199 26.9595 7.18813 28.3122C8.54086 29.6683 10.1482 30.7438 11.9179 31.4769C13.6875 32.2099 15.5845 32.586 17.5 32.5837Z' fill='white' stroke='white' stroke-width='2' stroke-linejoin='round'/%3E%3Cpath d='M11.6667 18L16.0417 22.375L24.7917 13.625' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/mask%3E%3Cg mask='url(%23mask0_6015_2519)'%3E%3Cpath d='M0 0.5H35V35.5H0V0.5Z' fill='%2326537D'/%3E%3C/g%3E%3C/svg%3E");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    width: 35px;
    height: 35px;

    @media (max-width: 767px) {
      width: 30px;
      height: 30px;
    }
  }

  .color {
    color: #f79421;
    line-height: 1;
  }
}

.roi-timeline {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  flex-wrap: wrap;

  @media (max-width: 767px) {
    gap: 4px;
  }
}

.roi-timeline-box {
  border-radius: 10px;
  background: #fff;
  padding: 23px 15px;
  width: calc((100% / 4) - (20px * 3) / 4);

  @media (max-width: 991px) {
    width: calc((100% / 2) - (20px * 1) / 2);
  }

  @media (max-width: 767px) {
    padding: 17px 10px;
    width: calc((100% / 2) - (4px * 1) / 2);
  }
}

.roi-timeline-b {
  color: #26537d;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 15px;
  border-block: 1px solid #26537d;
  padding: 9px 0;

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 12px;
  }
}

.roi-timeline-ttl {
  color: #26537d;
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  line-height: 38px;
  font-family: "Noto Sans JP",  sans-serif;
  margin-top: 5px;

  @media (max-width: 767px) {
    font-size: 20px;
    font-weight: 700;
    line-height: 29px;
  }
}

.roi-timeline-btm {
  color: #26537d;
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  line-height: 26px;

  @media (max-width: 767px) {
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
  }
}

.roi-top-txt {
  color: #222;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 26px;
  text-align: center;
  margin-bottom: 15px;

  @media (max-width: 767px) {
    font-size: 12px;
    font-weight: 500;
    line-height: 17px;
    margin-bottom: 10px;
  }
}

/* PROFITIABLITY & ROI */

/* RESIDENT BENEFIT */
.resident {
  .inner {
    max-width: 1200px;
  }

  @media (max-width: 767px) {
    .sec-ttl {
      margin-bottom: 65px;
    }
  }

  .overview-box-wrp {
    border-radius: 15px;
    background: #e9f3f9;

    &.sp-pt40 {
      padding-top: 30px;
      @media (max-width: 767px) {
        padding-top: 35px;

        .overview-box-tag {
          line-height: 20px;
          top: -35px;
        }
      }
    }
  }
  .owner-box {
    @media (max-width: 767px) {
      padding: 10px;
    }
  }

  img {
    width: 100%;
    height: auto;
  }

  .operation-fit-km {
    @media (min-width: 768px) and (max-width: 991px) {
      font-size: 18px;
    }
    .xs {
      font-size: 16px;

      @media (max-width: 991px) {
        font-size: 14px;
      }
    }
  }

  .owner-left {
    max-width: 520px;
  }

  .operation-fit-dis {
    max-width: 140px;
    padding: 11px 0;

    @media (max-width: 776px) {
      max-width: 120px;
      padding: 10px 0;
    }
  }

  .operation-fit-row {
    padding: 11px 20px;

    @media (max-width: 991px) {
      padding: 10px;
    }
  }
}

.resident-top-t {
  color: #222;
  font-size: 14px;
  font-weight: 500;
  line-height: 26px;
  text-align: center;
  margin-bottom: 15px;

  @media (max-width: 767px) {
    text-align: center;
    font-size: 12px;
    font-weight: 500;
    line-height: 17px;
  }
}

.resident-row {
  display: flex;
  align-items: flex-start;
  margin-bottom: 30px;
  gap: 30px;

  @media (max-width: 991px) {
    margin-bottom: 20px;
    gap: 15px;
    flex-direction: column;
  }
}

.resident-left {
  max-width: 570px;
  width: 100%;

  @media (max-width: 991px) {
    max-width: 100%;
  }
}

.resident-img {
  max-width: 480px;

  @media (max-width: 991px) {
    max-width: 100%;
  }
}

.resident-top {
  color: #fff;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  line-height: 18px;
  padding: 15px 0;
  background: #26537d;
  width: 100%;
  margin-bottom: 20px;
}

.resident-tr {
  display: flex;
  align-items: center;
  border-bottom: 1px solid #26537d;

  &:not(:last-of-type) {
    margin-bottom: 15px;
  }
}

.resident-th {
  width: 200px;
  text-align: center;
  color: #26537d;
  font-size: 20px;
  font-weight: 700;
  line-height: 15px;
  padding-bottom: 14px;
  font-family: "Noto Sans JP",  sans-serif;
  @media (max-width: 767px) {
    width: 120px;
    font-size: 13px;
    font-weight: 700;
    line-height: 10px;
  }
}

.resident-td {
  width: calc((100% - 200px));
  color: #26537d;
  font-size: 20px;
  font-weight: 700;
  line-height: 22px;
  padding-bottom: 14px;
  font-family: "Noto Sans JP",  sans-serif;

  @media (max-width: 767px) {
    width: calc((100% - 120px));
    font-size: 13px;
    font-weight: 700;
    line-height: 10px;
  }

  .xs {
    line-height: 1;
    @media (min-width: 768px) {
      font-size: 16px;
    }
  }
}

.resident-white-txt {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 97px;
  border-radius: 10px;
  background: #fff;
  color: #26537d;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 18px;
  margin-top: 15px;

  @media (max-width: 767px) {
    margin-top: 10px;
    color: #26537d;
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    line-height: 13px;
    min-height: 70px;
  }
}

.resident-system {
  display: flex;
  align-items: stretch;
  gap: 20px;
  flex-wrap: wrap;

  @media (max-width: 767px) {
    gap: 6px;
  }
}

.resident-system-box {
  border-radius: 10px;
  background: #fff;
  padding: 24.5px 0;
  /* width: calc((100% / 3) - (20px * 3) / 4); */
  width: calc((100% / 4) - (20px * 3) / 4);

  @media (max-width: 767px) {
    width: 100%;
    padding: 17.5px 0;
  }
}

.resident-system-img {
  max-width: 40px;
  margin: 0 auto;

  @media (max-width: 767px) {
    max-width: 30px;
  }
}

.resident-system-sub {
  color: #26537d;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 20px;
  font-family: "Noto Sans JP",  sans-serif;
  margin-top: 15px;

  @media (max-width: 767px) {
    margin-top: 10px;
    font-size: 14px;
    font-weight: 700;
    line-height: 10px;
  }
}

.resident-system-ttl {
  color: #26537d;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 24px;
  margin-top: 15px;

  @media (max-width: 767px) {
    font-size: 20px;
    font-weight: 700;
    line-height: 15px;
    margin-top: 10px;
  }

  .xs {
    font-size: 20px;
    line-height: 0;

    @media (max-width: 767px) {
      font-size: 14px;
    }
  }
}

/* RESIDENT BENEFIT */

/* SMART HOME SYNERGY */
.smart {
  background: #f7f7f7;

  img {
    width: 100%;
    height: auto;
  }
  .inner {
    max-width: 1190px;
  }

  .roi-btm {
    margin-top: 50px;
    @media (max-width: 767px) {
      margin-top: 20px;
    }
  }

  .roi-btm-txt {
    @media (max-width: 767px) {
      line-height: 22px;
    }
  }

  .overview-b-ttl {
    margin-bottom: 0;
  }
}

.smart-block-ttl {
  color: #002c56;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 58px;
  margin-top: 50px;

  @media (max-width: 767px) {
    font-size: 20px;
    font-weight: 700;
    line-height: 25px; /* 125% */
    margin-top: 20px;
  }

  span {
    position: relative;

    &::after {
      content: "";
      width: 2px;
      height: 58px;
      transform: rotate(30deg);
      background: #002c56;
      display: block;
      position: absolute;
      right: -30px;
      top: 50%;
      transform: translateY(-50%) rotate(30deg);
      @media (max-width: 767px) {
        height: 50px;
      }
    }

    &::before {
      content: "";
      width: 2px;
      height: 58px;
      transform: rotate(30deg);
      background: #002c56;
      display: block;
      position: absolute;
      left: -30px;
      top: 50%;
      transform: translateY(-50%) rotate(30deg);

      @media (max-width: 767px) {
        height: 50px;
      }
    }
  }
}

.smart-block-top {
   @media (min-width:768px) and (max-width:991px) {
    font-size: 1.5rem !important;
  }
}

.smart-ttl {
  color: #26537d;
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  line-height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
  margin-top: 50px;
  font-family: "Noto Sans JP",  sans-serif;

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
    gap: 10px;
    padding-inline: 13px;
    margin-top: 20px;
  }

  span {
    flex-shrink: 0;
  }

  &::after {
    content: "";
    display: block;
    width: 300px;
    height: 2px;
    background: #26537d;
  }

  &::before {
    content: "";
    display: block;
    width: 300px;
    height: 2px;
    background: #26537d;
  }
}

.smart-iot {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 60px 30px;
  margin-top: 60px;

  @media (max-width: 767px) {
    gap: 35px 6px;
    margin-top: 40px;
  }
}

.smart-iot-box {
  position: relative;
  background: #fff;
  padding: 40px 20px 25px;
  width: calc((100% / 2) - (30px * 1) / 2);
  display: flex;
  align-items: center;
  justify-content: center;

  @media (max-width: 767px) {
    width: calc((100% / 2) - (6px * 1) / 2);
    padding: 40px 5px 20px;
  }
}

.smart-iot-img {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -35px;
  max-width: 70px;

  @media (max-width: 767px) {
    max-width: 50px;
    top: -25px;
  }
}

.smart-iot-ttl {
  color: #222;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  line-height: 36px;
  font-family: "Noto Sans JP",  sans-serif;
  letter-spacing: 1.2px;

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 24px;
    letter-spacing: 0.8px;
  }
}

.smart-iot-btm {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: 0.8px;
  margin-top: 5px;

  @media (max-width: 767px) {
    font-size: 10px;
    font-weight: 500;
    line-height: 15px;
    letter-spacing: 0.5px;
  }
}

.smart-iot-txt {
  color: #222;
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  line-height: 30px;
  letter-spacing: 1px;
  margin-top: 10px;
  font-family: "Noto Sans JP",  sans-serif;

  @media (max-width: 767px) {
    font-size: 13px;
    font-weight: 500;
    line-height: 20px;
    letter-spacing: 0.65px;
  }
}

.smart-rent {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: 65px 40px;
  margin-top: 125px;
  flex-wrap: wrap;
  position: relative;
    z-index: 1;

  @media (max-width: 767px) {
    justify-content: start;
    gap: 35px 8px;
    margin-top: 50px;
  }
}

.smart-rent-box {
  width: calc((100% / 3) - (40px * 2) / 3);
  position: relative;

  @media (max-width: 767px) {
    width: calc((100% / 3) - (8px * 2) / 3);
  }

  &.two {
    margin-top: -50px;

    @media (max-width: 767px) {
      margin-top: -20px;

      .smart-rent-tag {
        padding-block: 4.5px;
      }
    }
  }

  &.b-two {
    margin-top: 50px;
    @media (max-width: 767px) {
      margin-top: 20px;
    }
  }
}

.smart-rent-btm-tcxt {
  text-align: center;
  color: #222;
  text-align: center;
  font-size: 14px;
  font-family: "Noto Sans JP",  sans-serif;
  font-weight: 500;
  line-height: 12px;
  margin-top: 50px;

  @media (max-width: 767px) {
    margin-top: 30px;
    font-size: 12px;
    font-weight: 500;
    line-height: 18px;
  }
}

.smart-rent-tag {
  color: #fff;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 15px;
  border-radius: 60px;
  background: #26537d;
  padding: 12.5px 0;
  max-width: 305px;
  width: 100%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -25px;

  @media (max-width: 1199px) {
    max-width: 250px;
  }

  @media (max-width: 991px) {
    max-width: 180px;
    font-size: 14px;
  }

  @media (max-width: 767px) {
    font-size: 11px;
    font-weight: 700;
    line-height: 10.5px;
    padding: 10px 0;
    max-width: 100px;
    top: -15px;
  }
}

.smart-rent-content {
  padding: 20px 5px 20px 10px;

  @media (max-width: 767px) {
    padding: 15px 0;
  }
}

.smart-rent-top {
  color: #26537d;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 35px;
  letter-spacing: 1.2px;

  @media (max-width: 767px) {
    font-size: 16px;
    font-weight: 700;
    line-height: 23px;
    letter-spacing: 0.8px;
  }
}

.smart-rent-btm {
  color: #222;
  text-align: center;
  margin-top: 5px;
  font-size: 20px;
  font-weight: 500;
  line-height: 29px;
  letter-spacing: 1px;
  font-family: "Noto Sans JP",  sans-serif;
  @media (max-width: 767px) {
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
    letter-spacing: 0.4px;
  }
}

.smart-mid {
  margin-block: 50px 75px;
  position: relative;

  @media (max-width: 767px) {
    margin-block: 20px 35px;
  }

  &::after {
    content: "";
    position: absolute;
    width: 850px;
    height: 700px;
    background-color: #fff;
    border-radius: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;

    @media (max-width:1199px) {
      width: 100%;
    }

    @media (max-width:767px) {
      width: 336px;
      height: 350px;
    }
  }
}

.smart-mid-content {
  position: relative;
  z-index: 1;
}

.smart-mid-t {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 30px;
  font-weight: 700;
  line-height: 22px;

  @media (max-width:767px) {
    font-size: 14px;
    font-weight: 700;
    line-height: 10px;
  }
}

.smart-mid-m {
  color: #222;
  text-align: center;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 29px;
  margin-top: 30px;

  @media (max-width: 767px) {
    font-size: 18px;
    font-weight: 700;
    line-height: 13px;
    margin-top: 15px;
  }
}

.smart-mid-lg {
  color: #f79421;
  font-family: "Noto Sans JP",  sans-serif;
  font-size: 130px;
  font-weight: 700;
  line-height: 95px;
  text-align: center;
  margin-top: 40px;

  @media (max-width: 767px) {
    font-size: 80px;
    line-height: 59px;
    margin-top: 20px;
  }

  span {
    line-height: 0;
  }

  .ls {
    letter-spacing: 13px;

    @media (max-width: 767px) {
      letter-spacing: 8px;
    }
  }

  .sm {
    font-size: 100px;

    @media (max-width: 767px) {
      font-size: 60px;
    }
  }

  .sub {
    vertical-align: super;
    font-size: 40px;
    line-height: 1;

    @media (max-width: 767px) {
      font-size: 20px;
    }
  }
}

.resident .sup {
  font-size: 24px;
  vertical-align: super;

  @media (max-width: 767px) {
    font-size: 20px;
  }
}
/* SMART HOME SYNERGY */
