/* ESL 工場向けソリューションページ
-------------------------------------------------- */
#SOLUTION.esl-manufacturer #TOP {
  margin-top: -20px;
  height: 320px;
  margin-bottom: 50px;
}

#SOLUTION.esl-manufacturer #TOP .banner-wrap .img img {
  width: 45%;
  margin-top: -50px;
}

#SOLUTION.esl-manufacturer #TOP .banner-wrap .text {
  top: 120px;
}

#SOLUTION.esl-manufacturer #TOP .banner-wrap .text .btn-group button,
#SOLUTION.esl-manufacturer .contact-banner button {
  border: none;
  display: inline-block;
  padding: 7px 40px;
  border-radius: 25px;
  text-decoration: none;
  color: #FFF;
  background-image: linear-gradient(45deg, #ffc400 0%, #fc743e 100%);
  transition: .4s;
}

#SOLUTION.esl-manufacturer #TOP .banner-wrap .text .btn-group button:hover,
#SOLUTION.esl-manufacturer .contact-banner button:hover {
  background-image: linear-gradient(45deg, #ffd043 0%, #f85c23 100%);
}

#SOLUTION.esl-manufacturer .em-summary {
  margin-top: 80px;
  margin-bottom: 60px;
  color: black;
}

#SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-text {
  color: black;
}

#SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-text h3 .fa-triangle-exclamation {
  color: #ff9215;
  padding-right: 7px;
}

#SOLUTION.esl-manufacturer .feature-card .card-label {
  position: absolute;
  top: -0.9em;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 15px;
  padding: 0.3rem 3rem;
  font-weight: bold;
  background-color: #40878F;
  color: white;
}

#SOLUTION.esl-manufacturer .feature-card .circle-icon {
  background-color: #F28200;
  width: 80px;
  height: 80px;
  margin: 4rem auto 2rem;
}

#SOLUTION.esl-manufacturer .feature-card .feature-text {
  padding: 0 10px;
  color: black;
}

#SOLUTION.esl-manufacturer .feature-card .feature-text h3 {
  text-align: center;
  color: #F28200;
}

/* 機能比較表 */
#SOLUTION.esl-manufacturer .tbl-comparison {
  width: 100%;
  border-collapse: collapse;
  margin: 40px auto;
}

#SOLUTION.esl-manufacturer .tbl-comparison th,
#SOLUTION.esl-manufacturer .tbl-comparison td {
  padding: 2rem;
  border: 1px solid #ddd;
  text-align: center;
}

#SOLUTION.esl-manufacturer .tbl-comparison th {
  color: white;
  font-size: clamp(22px, 1.6vw, 26px);
}

#SOLUTION.esl-manufacturer .tbl-comparison td {
  color: black;
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: clamp(22px, 2vw, 28px);
}

#SOLUTION.esl-manufacturer .tbl-comparison .comm-caso-point {
  font-size: clamp(20px, 1.2vw, 24px);
  font-weight: bold;
}

#SOLUTION.esl-manufacturer .tbl-comparison td .fa-circle-check {
  color: #40878F;
}

#SOLUTION.esl-manufacturer .check-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.75em;
}

#SOLUTION.esl-manufacturer .check-item {
  display: flex;
  align-items: center;
  gap: 0.3em;
}

/* 列ごとの背景色 */
#SOLUTION.esl-manufacturer .tbl-comparison th:nth-child(2) {
  background-color: #F59718;
  color: white;
}

#SOLUTION.esl-manufacturer .tbl-comparison td:nth-child(2) {
  background-color: #FFF4E0;
}

#SOLUTION.esl-manufacturer .tbl-comparison th:nth-child(3) {
  background-color: #B4B4B4;
  color: white;
}

#SOLUTION.esl-manufacturer .tbl-comparison td:nth-child(3) {
  background-color: #F8F8F8;
}

#SOLUTION.esl-manufacturer .tbl-comparison td:first-child {
  background: #F8F8F8;
  text-align: left;
}

#SOLUTION.esl-manufacturer .usecase-section .system-diagram img {
  max-width: 100%;
  margin: 20px auto 60px;
}

#SOLUTION.esl-manufacturer .usecase-section .point-box {
  background-color: #FFF4E5;
  margin: 0 auto;
  padding: 2rem 7rem;
  max-width: 60%;
  border-radius: 25px;
}

#SOLUTION.esl-manufacturer .web-ui-ttl {
  line-height: clamp(36px, 2vw, 46px);
}

#SOLUTION.esl-manufacturer .web-ui {
  margin: 40px auto 60px;
  text-align: center;
}

#SOLUTION.esl-manufacturer .web-ui img {
  max-width: 100%;
}

#SOLUTION.esl-manufacturer .usecase-box {
  background-color: #FFF4E5;
  margin: 100px auto 50px;
  padding: 4rem 6rem 1rem;
  max-width: 100%;
  border-radius: 25px;
}

#SOLUTION.esl-manufacturer .usecase-box .usecase-box-txt {
  padding-left: 2rem;
  color: black;
}

#SOLUTION.esl-manufacturer .usecase-box .usecase-box-txt h4 {
  position: relative;
  padding-left: 1.5em;
  line-height: 1.4;
}

#SOLUTION.esl-manufacturer .usecase-box .usecase-box-txt p {
  border-bottom: 1px solid black;
  padding-bottom: 5px;
}

#SOLUTION.esl-manufacturer .usecase-box .usecase-box-txt h4:before {
  font-family: "Font Awesome 5 Free";
  content: "\f111";
  font-weight: 900;
  position: absolute;
  font-size: 1.2em;
  left: 0;
  top: -0.2em;
  color: #F59718;
}

#SOLUTION.esl-manufacturer .usecase-box .feature-grid {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  padding: 0;
  margin-top: 0;
}

#SOLUTION.esl-manufacturer .usecase-box .feature-card {
  padding: 2rem 0;
}

#SOLUTION.esl-manufacturer .usecase-box .feature-card img {
  max-width: 100%;
  text-align: center;
}
#SOLUTION.esl-manufacturer .contact-banner .container {
  padding: 40px 0 !important;
  text-align: center;
}

@media screen and (max-width: 1030px) {
  #SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-text p br {
    display: none;
  }

  #SOLUTION.esl-manufacturer .usecase-section .point-box {
    padding: 2rem 3rem;
    max-width: 70%;
  }
}

@media screen and (max-width: 820px) {
  #SOLUTION.esl-manufacturer #TOP {
    height: 260px;
  }

  #SOLUTION.esl-manufacturer .em-summary {
    margin-top: 40px;
    margin-bottom: 20px;
  }

  #SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-text {
    padding-right: 3rem;
  }

  #SOLUTION.esl-manufacturer .feature-card .card-label {
    top: -1.5em;
    border-radius: 15px;
    padding: 0.5rem 2rem;
  }
#SOLUTION.esl-manufacturer .usecase-box {
  padding: 4rem 1rem 1rem;
}
}

@media screen and (max-width: 768px) {
  #SOLUTION.esl-manufacturer .usecase-section .point-box {
    padding: 1rem 2rem;
    max-width: 80%;
  }
#SOLUTION.esl-manufacturer .tbl-comparison th,
#SOLUTION.esl-manufacturer .tbl-comparison td {
  padding: 1.6rem;
}
}

@media screen and (max-width: 640px) {
#SOLUTION.esl-manufacturer #TOP .banner-wrap .text {
  top: 80px;
  left: 40px;
}
  #SOLUTION.esl-manufacturer #TOP .banner-wrap .img{
    text-align: center;
  }
  #SOLUTION.esl-manufacturer #TOP .banner-wrap .img img {
    width: 80%;
    margin: 0px auto 20px;
  }

  #SOLUTION.esl-manufacturer .em-summary {
    margin-top: 220px;
    width: 100%;
  }

  #SOLUTION.esl-manufacturer .arrow-divider .sol-card {
    padding: 1rem 2rem;
  }

  #SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-text {
    padding-right: 0rem;
  }

  #SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-img {
    text-align: center;
  }

  #SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-img img {
    max-width: 70%;
  }

  #SOLUTION.esl-manufacturer .tbl-comparison {
    width: 100%;
  }

  #SOLUTION.esl-manufacturer .tbl-comparison .thead {
    display: none;
  }

  #SOLUTION.esl-manufacturer .tbl-comparison tr {
    width: 100%;
  }

  #SOLUTION.esl-manufacturer .tbl-comparison td {
    display: block;
    text-align: right;
    width: 100%;
  }

  #SOLUTION.esl-manufacturer .tbl-comparison td:first-child {
    background: #F59718;
    color: #fff;
    font-weight: bold;
    text-align: center;
  }

  #SOLUTION.esl-manufacturer .tbl-comparison td:before {
    content: attr(data-label);
    float: left;
    font-weight: bold;
    margin-right: 10px;
  }
#SOLUTION.esl-manufacturer .check-list {
  justify-content: flex-end;
}

  #SOLUTION.esl-manufacturer .usecase-section .point-box {
    padding: 0.5rem;
    max-width: 100%;
  }
}
@media screen and (max-width: 460px) {
  #SOLUTION.esl-manufacturer .em-summary {
    margin-top: 150px;
  }
#SOLUTION.esl-manufacturer .arrow-divider .sol-grid{
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
#SOLUTION.esl-manufacturer .arrow-divider .sol-card{
    flex-direction: column;
    text-align: center;
    padding: 10px 20px 0px;
  }
#SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-text p {
  text-align: left;
}
#SOLUTION.esl-manufacturer .arrow-divider .sol-card .card-img{
  text-align: center;
  margin: 0 auto;
}
#SOLUTION.esl-manufacturer .usecase-box{
  margin: 50px auto 25px;
  padding: 2rem 1rem 0rem;
}
#SOLUTION.esl-manufacturer .usecase-box .feature-grid{
  grid-template-columns: repeat(auto-fit, minmax(60px, 1fr));
}
#SOLUTION.esl-manufacturer .usecase-box .usecase-box-txt{
  padding-left: 0;
}
}

/* 共通 */

#SOLUTION h2.header {
  color: #FFF;
  background-color: #93B119;
  font-size: clamp(18px, 3vw, 24px);
  line-height: 160%;
  padding: 1.5em;
  text-align: center;
  margin-top: 0;
  margin-bottom: 2em;
}