@charset "utf-8";
/* general
-------------------------------------------------------------- */
.point .txt-area {
  width: 250px;
}

.point ul {
  width: calc(100% - 380px);
}
@media (max-width: 767px) {
  .point h3 strong {
    margin-bottom: 0;
  }
  .point h3 strong:last-of-type {
    margin-left: -22px;
  }
  
  .point .txt-area,
  .point ul {
    width: 100%;
  }

  .point li::before {
    top: 5px;
  }
}


/* services
-------------------------------------------------------------- */
.services {
  position: relative;
}

#care {
  padding: 100px 0;
}

#eco {
  padding-top: 80px;
}

.lead-box {
  position: relative;
  align-items: center;
  padding-bottom: 110px;
}

.lead-box .photo-area {
  position: relative;
  width: 34%;
}

#care .lead-box .photo-area ,
#eco .lead-box .photo-area {
  width: 27%;
}

.lead-box .photo-area h2 {
  position: absolute;
  top: 30px;
  right: 0;
  gap: 5px;
  align-items: flex-start;
}

#flow .lead-box .photo-area h2 {
  top: -40px;
  right: -20px;
}
.lead-box .photo-area h2 strong {
  display: block;
  background: var(--color-blue);
  color: var(--color-white);
}

.lead-box .photo-area h2 strong:last-child {
  margin-top: 20px;
  order: -1;
}

.lead-box .photo-area h2 span {
  display: inline-block;
}

.lead-box .photo-area h2 .jp {
  padding: 5px 8px 15px 5px;
  font-size: 4.3rem;
  font-weight: 700;
  line-height: 1;
  writing-mode: vertical-lr;
}

.lead-box .photo-area h2 .jp span {
  font-weight: 700;
}

.lead-box h2.ttl {
  position: absolute;
  top: 0;
  left: 21%;
}

.lead-box h2.ttl strong {
  display: block;
  background: var(--color-blue);
  color: var(--color-white);
}

.lead-box h2.ttl span {
  display: inline-block;
}

.lead-box h2.ttl .jp {
  padding: 5px 8px 15px 5px;
  font-size: 4.3rem;
  font-weight: 700;
  line-height: 1;
}

.lead-box h2.ttl .jp span {
  font-weight: 700;
}

.lead-box .txt {
  width: 60%;
  color: var(--color-blue);
  font-size: 2rem;
  font-weight: 500;
  line-height: 2;
}

#care .lead-box .txt,
#eco .lead-box .txt {
  padding-top: 80px;
  width: 67%;
}

.service-box {
  padding-bottom: 50px;
}

.service-box figure {
  position: relative;
  width: 48.5%;
}

.service-box.before figure {
  width: 50%;
}

.service-box figcaption {
  position: absolute;
  top: -80px;
  left: 0;
  color: #E5F9FF;
  font-size: 12rem;
  font-weight: 900;
  line-height: 1;
  mix-blend-mode: multiply;
}

#air .service-box figcaption {
  top: -75px;
  left: auto;
  right: 0;
}

.service-box .txt-area {
  width: 48%;
}

.service-box.before .txt-area {
  width: 46.5%;
}

.service-box h3 span.en {
  display: block;
  padding: 40px 0 20px;
  color: var(--color-blue);
  font-size: 1.4rem;
  font-style: italic;
  line-height: 1;
  letter-spacing: .5px;
}

.service-box h3 span.jp {
  display: block;
  padding-bottom: 30px;
  color: var(--color-blue);
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
}

.service-box  p {
  font-size: 1.6rem;
}

.service-box.line {
  padding: 60px 0 100px;
  border-top: 1px solid var(--color-blue);
}
.service-box.line figure {
  order: 1;
}
@media (max-width: 767px) {
  #care {
    padding: 50px 0;
  }
  
  #eco {
    padding-top: 80px;
  }
  
  .lead-box {
    padding: 0 5% 80px;
  }
  
  .lead-box .photo-area {
    width: 100%;
  }
  
  #care .lead-box .photo-area ,
  #eco .lead-box .photo-area {
    position: relative;
    width: 100%;
    z-index: -1;
  }
  
  .lead-box .photo-area h2 {
    position: absolute;
    top: 30px;
    right: 0;
    gap: 5px;
    align-items: flex-start;
  }
  
  #flow .lead-box .photo-area h2 {
    top: -10px;
    right: 0;
  }
  .lead-box .photo-area h2 strong {
    display: block;
    background: var(--color-blue);
    color: var(--color-white);
  }
  
  .lead-box .photo-area h2 strong:last-child {
    margin-top: 20px;
    order: -1;
  }
  
  .lead-box .photo-area h2 span {
    display: inline-block;
  }
  
  .lead-box .photo-area h2 .jp {
    padding: 5px 5px 10px 3px;
    font-size: 3rem;
  }

  .lead-box .photo-area figure {
    margin: auto;
    width: 80%;
  }

  #care .photo-area figure {
    margin: auto;
  }
  .lead-box h2.ttl {
    position: static;
    margin-top: -10px;
  }
  
  .lead-box h2.ttl strong {
    display: inline-block;
  }
  
  .lead-box h2.ttl strong:first-child {
    margin-bottom: 5px;
  }
  
  .lead-box h2.ttl span {
    display: inline-block;
  }
  
  .lead-box h2.ttl .jp {
    padding: 5px 5px 10px 3px;
    font-size: 3rem;
  }
  
  .lead-box .txt {
    padding-top: 30px;
    width: 100%;
    font-size: 1.6rem;
  }
  
  #care .lead-box .txt,
  #eco .lead-box .txt {
    padding-top: 30px;
    width: 100%;
  }
  
  .service-box {
    padding-bottom: 30px;
  }
  
  .service-box figure {
    position: relative;
    width: 100%;
  }
  
  .service-box.before figure {
    width: 100%;
  }
  
  .service-box figcaption {
    top: -40px;
    font-size: 7rem;
  }
  
  #air .service-box figcaption {
    top: -40px;
  }
  
  .service-box .txt-area {
    width: 100%;
  }
  
  .service-box.before .txt-area {
    width: 100%;
  }
  
  .service-box h3 span.en {
    padding: 40px 0 10px;
    font-size: 1.2rem;
  }
  
  .service-box h3 span.jp {
    padding-bottom: 20px;
    font-size: 2.2rem;
  }
  
  .service-box  p {
    font-size: 1.4rem;
  }
  
  .service-box.line {
    padding: 30px 0 50px;
  }
  .service-box.line figure {
    order: -1;
  }
}