@media only screen and (max-width: 767px) {
  .tocType01 ul.sp-left {
    justify-content: normal;
  }
}
@media only screen and (max-width: 767px) {
  .tocType01 li.sp-item span::after {
    top: 3.9rem;
  }
}

.company__title {
  margin-top: 10rem;
  margin-bottom: 8rem;
}
@media only screen and (max-width: 767px) {
  .company__title {
    margin-top: 12rem;
    margin-bottom: 10rem;
  }
}
.company__nav .wrapper {
  background-color: #EBEEF5;
  padding: 2rem 0;
}
@media only screen and (max-width: 767px) {
  .company__nav .wrapper {
    padding: 4rem 0;
  }
}
.company__nav .tocType01-profile {
  margin-bottom: 0;
}
.company__nav .list {
  display: flex;
  flex-wrap: wrap;
}
.company__nav .list .item {
  text-align: center;
  border-right: 1.5px solid #CCC;
  border-left: 1.5px solid #CCC;
}
@media only screen and (max-width: 767px) {
  .company__nav .list .item a {
    padding: 0.3rem 0rem 0.4rem;
  }
}
.company__nav .list li {
  position: relative;
  border-left: 2px solid #ccc;
  border-right: 2px solid #ccc;
}
@media only screen and (max-width: 767px) {
  .company__nav .list li {
    width: 90%;
  }
}
.company__nav .list li span {
  position: relative;
}
.company__nav .list li span::after {
  content: "";
  position: absolute;
  top: 0.7rem;
  right: 0;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  transform: rotate(45deg);
  width: 1rem;
  height: 1rem;
}
@media only screen and (max-width: 767px) {
  .company__nav .list li span::after {
    width: 2rem;
    height: 2rem;
    top: 1rem;
  }
}
.company .profile .listType02 {
  font-weight: 500;
}
.company .profile .outline {
  margin-bottom: 10rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .outline {
    margin-bottom: 12rem;
  }
}
.company .profile .outline__content {
  margin: 0 auto;
}
.company .profile .outline__content dl {
  display: flex;
  flex-wrap: wrap;
}
.company .profile .outline__content dl:first-child {
  border-top: 1.5px solid #ccc;
}
.company .profile .outline__content dl dt {
  border-bottom: 1.5px solid #ccc;
  padding: 3rem 0;
  width: 30%;
  color: #004097;
  font-weight: 400;
}
@media only screen and (max-width: 767px) {
  .company .profile .outline__content dl dt {
    padding: 4rem 0;
  }
}
.company .profile .outline__content dl dd {
  border-bottom: 1.5px solid #ccc;
  padding: 3rem 0;
  width: 70%;
}
@media only screen and (max-width: 767px) {
  .company .profile .outline__content dl dd {
    padding: 4rem 0 4rem 2rem;
  }
}
.company .profile .office-factory_bg {
  background-color: #f5f8fa;
  padding: 0.1rem 0 10rem 0;
}
@media only screen and (max-width: 767px) {
  .company .profile .office-factory_bg {
    padding-bottom: 12rem;
  }
}
.company .profile .office .main-office__wrapper {
  margin-top: 2rem;
  padding-bottom: 5rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .main-office__wrapper {
    padding-bottom: 8rem;
  }
}
.company .profile .office .main-office__content {
  display: flex;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .main-office__content {
    flex-wrap: wrap;
  }
}
.company .profile .office .main-office__content figure {
  margin-right: 5rem;
  width: 40rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .main-office__content figure {
    margin: 2rem 0 4rem 0;
    width: 100%;
  }
}
.company .profile .office .main-office .info {
  line-height: 1.6;
}
.company .profile .office .main-office .info .detail {
  margin-top: 0.6rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .main-office .info .detail {
    margin-top: 1rem;
  }
}
.company .profile .office .main-office .main-office_map {
  width: 100%;
  height: 30rem;
  margin-top: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .main-office .main-office_map {
    height: 45rem;
  }
}
@media only screen and (max-width: 767px) {
  .company .profile .office .another-office {
    margin-top: 6rem;
  }
}
.company .profile .office .another-office:not(:last-child) {
  border-bottom: 1.5px solid #ccc;
}
.company .profile .office .another-office .titleType03_office {
  position: relative;
  top: 3.5rem;
  padding-right: 10rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .another-office .titleType03_office {
    top: 0;
  }
}
.company .profile .office .another-office .titleType03_office + .another-office__wrapper .office__info {
  margin-top: 5rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .another-office .titleType03_office + .another-office__wrapper .office__info {
    margin-top: 3rem;
  }
}
.company .profile .office .another-office__wrapper {
  padding-bottom: 5rem;
  gap: 2rem 2%;
  display: block;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .another-office__wrapper {
    gap: 3rem;
    padding-bottom: 8rem;
  }
}
.company .profile .office .another-office__content {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .another-office__content {
    width: 100%;
  }
}
.company .profile .office .another-office__content.half {
  width: 49%;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .another-office__content.half {
    width: 100%;
  }
}
.company .profile .office .another-office__wrap {
  border-top: 1.5px solid #ccc;
}
.company .profile .office .another-office__content .link-blue {
  text-decoration: underline;
}
.company .profile .office .flex_wrap .another-office {
  width: 32%;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .flex_wrap .another-office {
    width: 100%;
  }
}
@media print, screen and (min-width: 768px) {
  .company .profile .office .flex_wrap .another-office {
    border: none;
  }
}
.company .profile .office .flex_wrap .another-office__wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 2%;
}
@media only screen and (max-width: 767px) {
  .company .profile .office .flex_wrap .another-office__wrap {
    gap: 0;
  }
}
.company .profile .office .flex_wrap .another-office__wrapper {
  border: none;
}
@media print, screen and (min-width: 768px) {
  .company .profile .office .flex_wrap .another-office .another-office__wrapper {
    padding-bottom: 0;
  }
}
.company .profile .office .flex_wrap .another-office .another-office__content {
  width: 100%;
}
.company .profile .office__info {
  line-height: 1.6;
  margin: 5rem 0 1rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office__info {
    margin-bottom: 2rem;
  }
}
.company .profile .office__info .detail {
  margin-top: 0.6rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .office__info .detail {
    margin-top: 1rem;
  }
}
.company .profile .group .titleType04 {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .group .titleType04 {
    margin-bottom: 0.5rem;
  }
}
.company .profile .group__content {
  display: flex;
  justify-content: space-between;
  padding-bottom: 5rem;
  margin-bottom: 5rem;
  border-bottom: 1.5px solid #ccc;
}
@media only screen and (max-width: 767px) {
  .company .profile .group__content {
    flex-wrap: wrap;
    margin: 8rem 0;
    padding-bottom: 8rem;
  }
}
.company .profile .group__content:last-child {
  border: 0;
}
@media only screen and (max-width: 767px) {
  .company .profile .group__content:last-child {
    padding-bottom: 0;
  }
}
.company .profile .group__content figure {
  width: 30%;
}
@media only screen and (max-width: 767px) {
  .company .profile .group__content figure {
    width: 100%;
  }
}
.company .profile .group__info {
  width: 64%;
  line-height: 1.6;
}
@media only screen and (max-width: 767px) {
  .company .profile .group__info {
    margin-top: 4rem;
    width: 100%;
  }
}
.company .profile .group__info .detail {
  margin-top: 0.6rem;
}
@media only screen and (max-width: 767px) {
  .company .profile .group__info .detail {
    margin-top: 1rem;
  }
}
.company .profile .group__info .link-blue {
  display: inline-block;
}
@media print, screen and (min-width: 768px) {
  .company .profile .link-tel {
    pointer-events: none;
  }
}
@media only screen and (max-width: 767px) {
  .company .profile .link-tel {
    color: #00b1dd;
  }
}
.company .about h3.greeting__title {
  font-weight: 500;
  font-size: 3rem;
  line-height: 1.4;
  color: #004097;
  margin-bottom: 6rem;
}
@media only screen and (max-width: 767px) {
  .company .about h3.greeting__title {
    display: inline;
    font-weight: 500;
    font-size: 3.8rem;
  }
}
.company .about p.text--decoration {
  position: relative;
  padding-left: 3rem;
  line-height: 1.8;
}
@media only screen and (max-width: 767px) {
  .company .about p.text--decoration {
    padding-left: 4.5rem;
  }
}
.company .about p.text--decoration::before {
  content: url(../img/common/icon-hexagon.svg);
  display: block;
  width: 1.6rem;
  position: absolute;
  left: 0.5rem;
  top: 0.3rem;
  margin-right: 0.8rem;
}
@media only screen and (max-width: 767px) {
  .company .about p.text--decoration::before {
    width: 2.8rem;
    top: 0.6rem;
  }
}
.company .about span.marker {
  color: #00b1dd;
}
.company .about .clean__wrapper {
  margin-bottom: 10rem;
}
.company .about .clean__content {
  margin-top: 4rem;
}
.company .about .clean__text {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 767px) {
  .company .about .clean__text {
    margin-bottom: 8rem;
  }
}
.company .about .clean__text span {
  color: #00b1dd;
}
.company .about .clean__img {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 767px) {
  .company .about .clean__img {
    margin-bottom: 8rem;
  }
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__content {
    padding-bottom: 4rem;
  }
}
.company .about .greeting__wrapper {
  position: relative;
  padding-top: 0.1rem;
}
.company .about .greeting__box {
  padding-top: 14rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__box {
    position: inherit;
    padding-bottom: 5rem;
    padding-top: 0;
  }
}
.company .about .greeting__president-message {
  padding: 8rem 10rem;
  background-color: #f5f8fa;
  width: 77rem;
  z-index: 99;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__president-message {
    width: 100vw;
    position: relative;
    left: 50%;
    top: 1rem;
    transform: translateX(-50%);
    padding: 8rem 10.5%;
    line-height: 2;
  }
}
.company .about .greeting__president-message p {
  margin-top: 5rem;
}
.company .about .greeting__president-img {
  position: absolute;
  top: 25rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__president-img {
    position: relative;
    width: 100vw;
    left: 50%;
    transform: translateX(-50%);
    margin: -24rem 0px;
    padding-bottom: 50rem;
  }
}
.company .about .greeting__president-img figure {
  width: 80%;
  margin-left: auto;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__president-img figure {
    width: 100%;
  }
}
.company .about .greeting__president-signature {
  position: absolute;
  right: 22rem;
  bottom: -14rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__president-signature {
    display: flex;
    justify-content: flex-end;
    position: relative;
    margin-right: -15rem;
    top: 4rem;
  }
}
.company .about .greeting__president-signature p {
  font-size: 1.4rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__president-signature p {
    font-size: 2rem;
  }
}
.company .about .greeting__president-signature figure {
  display: inline-block;
  width: 16rem;
  margin-top: 1rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__president-signature figure {
    width: 25rem;
    margin-left: 3rem;
  }
}
.company .about .greeting__idea {
  margin-top: 5rem;
  padding-bottom: 5rem;
  border-bottom: 1.5px solid #ccc;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__idea {
    padding-bottom: 8rem;
  }
}
.company .about .greeting__idea.border-no {
  border-top: 0 !important;
}
.company .about .greeting__idea:last-child {
  border: 0;
}
.company .about .greeting__idea:first-child {
  border-top: 1.5px solid #ccc;
  padding-top: 5rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__idea:first-child {
    padding-top: 8rem;
  }
}
.company .about .greeting__idea h3 {
  font-size: 2.6rem;
  margin-left: 7rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__idea h3 {
    font-size: 3.6rem;
    margin-left: 9rem;
  }
}
.company .about .greeting__idea .idea__wrap {
  margin-top: 5rem;
}
.company .about .greeting__idea .idea__wrap figure.motto {
  width: 95rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__idea .idea__wrap figure.motto {
    width: 45rem;
  }
}
.company .about .greeting__idea .idea__wrap .rows {
  display: flex;
  gap: 23rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__idea .idea__wrap .rows {
    flex-wrap: wrap;
    gap: 0;
  }
}
.company .about .greeting__idea .idea__title {
  margin-bottom: 3rem;
  position: relative;
}
.company .about .greeting__idea .title-number {
  display: inline-block;
  font-size: 5.5rem;
  font-weight: 600;
  color: #004097;
  margin-right: 2rem;
  font-family: "Roboto Condensed", sans-serif;
  position: absolute;
  top: -0.3rem;
}
@media only screen and (max-width: 767px) {
  .company .about .greeting__idea .title-number {
    font-size: 7.5rem;
  }
}
.company .about .greeting .greeting__content {
  margin-bottom: 10rem;
}
.company .about .iso__wrapper {
  background-image: url(../img/company/about/iso-pc.jpg);
  background-repeat: no-repeat;
  background-size: contain;
  padding-top: 20rem;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__wrapper {
    background-image: url(../img/company/about/iso-sp.jpg);
    background-size: contain;
  }
}
.company .about .iso__content {
  margin-bottom: 10rem;
  padding: 8rem;
  margin-top: 3rem;
  background-color: rgba(255, 255, 255, 0.95);
  border: 1.5px solid #e6e6e6;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__content {
    padding: 8rem 3rem;
    margin-bottom: 14rem;
    margin-top: 12rem;
  }
}
.company .about .iso__content p.text--decoration {
  margin-bottom: 2rem;
}
.company .about .iso__item {
  display: flex;
  margin-top: 5rem;
  margin-bottom: 6rem;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__item {
    flex-wrap: wrap;
    margin: 6rem 0;
  }
}
@media print, screen and (min-width: 768px) {
  .company .about .iso__item .iso__text {
    margin-bottom: 7rem;
  }
}
.company .about .iso__item figure.iso-badge {
  width: 80%;
  margin-left: 4rem;
  background-color: #fff;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__item figure.iso-badge {
    width: 70%;
    margin: 0 auto;
    margin-top: 5rem;
  }
}
.company .about .iso__item figure.iso-badge img {
  border: 1.5px solid #e6e6e6;
}
.company .about .iso__item figure.iso-badge img.border-style {
  padding: 1rem 2rem;
}
.company .about .iso__item figure.iso-badge img + img {
  margin-top: 1rem;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__item figure.iso-badge img + img {
    margin-top: 1.7rem;
  }
}
.company .about .iso__box {
  background-color: #f5f8fa;
  padding: 3rem;
  margin: 3rem 0;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__box {
    margin: 5rem 0;
  }
}
.company .about .iso__box .box__title {
  font-size: 3rem;
  margin-bottom: 2rem;
  color: #00b1dd;
  font-weight: bold;
}
.company .about .iso__box dd span {
  color: #004097;
}
.company .about .iso__box dl {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}
.company .about .iso__box dl dt {
  width: 8.5rem;
  color: #004097;
}
.company .about .iso__box dl dt.title {
  font-weight: normal;
  color: #004097;
  margin: 1rem 0;
  display: block;
  width: 100%;
  text-align: left;
}
.company .about .iso__box dl dt.title span {
  border: 1px solid #004097;
  display: inline-block;
  padding: 0.4rem 1rem;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__box dl dt {
    width: 15.5rem;
  }
}
.company .about .iso__box dl dd {
  width: calc(100% - 8.5rem);
}
.company .about .iso__box dl dd.mb2 {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 767px) {
  .company .about .iso__box dl dd {
    width: calc(100% - 15.5rem);
  }
}
.company .about .clean_bg {
  background: #f5f8fa;
  padding: 0.1rem 0;
  position: relative;
}
.company .about .txt-link {
  color: #333;
  display: flex;
  align-items: center;
}
.company .about .txt-link img {
  margin: 0 1rem;
  width: 2.5rem;
}
.company .about .txt-link .byte {
  display: flex;
  align-items: baseline;
}
@media only screen and (max-width: 767px) {
  .company .about .txt-link .byte {
    align-items: center;
  }
}
.company .about .txt-link .byte::after {
  content: "";
  background: url("../img/company/about/link-arrow.svg") no-repeat center/100%;
  width: 1.6rem;
  height: 1.3rem;
}
.company .about .c-policy {
  margin-bottom: 3rem;
}
.company .history .chronology__wrapper {
  border-bottom: 1.5px solid #ccc;
}
.company .history .chronology__content {
  border-top: 1.5px solid #ccc;
  display: flex;
  justify-content: space-between;
}
.company .history .chronology__content dl {
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .company .history .chronology__content dl {
    border-top: 1.5px solid #ccc;
    border-bottom: 1.5px solid #ccc;
  }
}
.company .history .chronology__content dt {
  padding: 3rem 0;
  width: 30%;
  color: #004097;
  font-weight: 400;
}
@media print, screen and (min-width: 768px) {
  .company .history .chronology__content dt {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.company .history .chronology__content dt:not(:first-child) {
  border-top: 1.5px solid #ccc;
}
@media only screen and (max-width: 767px) {
  .company .history .chronology__content dt {
    width: 24%;
    padding: 3.8rem 0 3rem;
  }
}
.company .history .chronology__content dd {
  padding: 3rem 0;
  width: 70%;
  line-height: 1.6;
}
.company .history .chronology__content dd:not(:first-of-type) {
  border-top: 1.5px solid #ccc;
}
@media only screen and (max-width: 767px) {
  .company .history .chronology__content dd {
    width: 76%;
  }
}
/*# sourceMappingURL=company.css.map */