#service-wrap,
#company-wrap {
    display: inline-block;
}
#company-wrap {
    margin-top: 146px;
}
h1.section-title {
    text-align: center;
    font-size: 1.5em;
}
h1.section-title i {
    display: block;
    font-size: 2em;
}
h1.section-title span {
    font-size: 0.6em !important;
    display: block;
    font-weight: normal;
    margin-top: 8px;
}
h2.section-sub-title {
    font-size: 1.2em;
    text-align: center;
}
li.step-list {
    height: auto;
}

#vision-wrap {
    margin-top: 124px;
}
#vision-detail {
    padding-right: 64px;
}
#philosophy-wrap {
    margin-top: 64px;
}
#philosophy-detail {
    padding-left: 64px;
}

.vp-detail h1 {
    font-size: 2em;
    font-weight: bold;
    margin-bottom: 20px;
}
.vp-detail h1 span {
    font-size: 0.4em;
    font-weight: normal;
}
.vp-detail h1 span.sub-detail {
    font-size: 1em !important;
}
.vp-detail p {
    font-size: 0.8em;
}

img.vision-philosophy,
img.vision-philosophy-sp {
    height: 24vw;
    max-height: 300px;
    object-fit: cover;
    width: 100%;
}
img.vision-philosophy {
    display: block;
}
img.vision-philosophy-sp {
    display: none;
    height: 28vw;
    margin-bottom: 20px;
}
img.right-vision {
    position: absolute;
    top: 50%;
    right: 0px;
    transform: translateY(-50%);
    -webkit- transform: translateY(-50%);
}

table.company-info-table {
  width: 100%;
  border-collapse: collapse;
}

table.company-info-table tr {
  border-bottom: solid 2px white;
}

table.company-info-table tr:last-child {
  border-bottom: none;
}

table.company-info-table th {
  position: relative;
  text-align: left;
  width: 30%;
  background-color: #3EB8CE;
  color: white;
  text-align: center;
  padding: 10px 0;
}

table.company-info-table th:after {
  display: block;
  content: "";
  width: 0px;
  height: 0px;
  position: absolute;
  top:calc(50% - 10px);
  right:-10px;
  border-left: 10px solid #52c2d0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
}

table.company-info-table td {
  text-align: left;
  width: 70%;
  text-align: center;
  background-color: #eee;
  padding: 10px 0;
}



@media screen and (max-width: 991px) {
    #vision-detail {
        padding-right: 15px;
    }
    #philosophy-detail {
        padding-left: 15px;
    }
    img.vision-philosophy {
        display: none;
    }
    img.vision-philosophy-sp {
        display: block;
    }
}

@media screen and (max-width: 768px) {
    #vision-wrap {
        margin-top: 84px;
    }
    #service-wrap h1.section-title {
        margin-top: 40px;
    }
    span.sub-detail {
        display: none;
    }
    #company-wrap {
        margin-top: 64px;
        margin-bottom: 46px;
    }
}

@media screen and (max-width: 480px) {

}
