body.page-template-page-company .history h2 {
  align-items: center;
  display: flex;
  flex-direction: column;
  font-size: 4rem;
  font-weight: 900;
  margin-bottom: 2.4rem;
  position: relative;
  text-align: center;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history h2 {
    font-size: 2.4rem;
    margin-bottom: 1.6rem;
  }
}

body.page-template-page-company .history h2::before {
  content: attr(data-en);
  font-family: "Albert Sans", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: #f37f28;
  letter-spacing: 0;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history h2::before {
    font-size: 1.6rem;
  }
}

body.page-template-page-company .history .lead {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.7;
  margin-bottom: 5.7rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .lead {
    margin-bottom: 4.8rem;
  }
}

body.page-template-page-company .history .step-and-map {
  display: flex;
  margin-bottom: 8.8rem;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map {
    gap: 6.9rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map {
    flex-direction: column;
    margin-bottom: 5.6rem;
  }
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map>ul {
    padding-top: 2.3rem;
    width: 64.9rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map>ul {
    display: contents;
    margin-bottom: 4.8rem;
  }
}

body.page-template-page-company .history .step-and-map>ul li {
  margin-bottom: 4rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map>ul li {
    margin-bottom: 2.4rem;
  }
}

body.page-template-page-company .history .step-and-map>ul li:nth-child(1) {
  order: 0;
}

body.page-template-page-company .history .step-and-map>ul li:nth-child(2) {
  order: 2;
}

body.page-template-page-company .history .step-and-map>ul li:nth-child(3) {
  order: 4;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map>ul li:not(:first-child) {
    margin-top: 1.8rem;
  }
}

body.page-template-page-company .history .step-and-map>ul li:not(:first-child)::before {
  background: url(./../img/company/history-before.svg) center/cover;
  content: "";
  display: block;
  height: 4.6rem;
  margin: 0 auto 4rem;
  width: 1rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map>ul li:not(:first-child)::before {
    background: url(./../img/company/history-before_sp.svg) center/cover;
    height: 4rem;
    margin: 0 auto 2.4rem;
  }
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map>ul li:last-child {
    margin-bottom: 0;
  }
}

body.page-template-page-company .history .step-and-map>ul li h3 {
  background: #fff8f4;
  border: 2px solid #f37f28;
  border-radius: 1rem;
  color: #f37f28;
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 2.4rem;
  padding: 0.6rem 3.8rem;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map>ul li h3 {
    display: inline-block;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map>ul li h3 {
    font-size: 2rem;
    margin-bottom: 1.6rem;
    padding: 0.4rem 2.4rem;
    text-align: center;
  }
}

body.page-template-page-company .history .step-and-map>ul li p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map .map {
    display: flex;
    flex-direction: column;
    width: 51rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map {
    display: contents;
  }
}

body.page-template-page-company .history .step-and-map .map .image {
  aspect-ratio: 550/386.3;
  margin-bottom: 2.2rem;
  width: 55rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .image {
    aspect-ratio: auto;
    margin-bottom: 0;
    order: 1;
    width: 32.8rem;
  }
}

body.page-template-page-company .history .step-and-map .map .image img {
  width: 100%;
  height: auto;
  border-radius: 0.8rem;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map .map .area {
    display: flex;
    align-items: flex-start;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .area {
    order: 1;
  }
}

body.page-template-page-company .history .step-and-map .map .area h3 {
  color: #009b71;
  flex-shrink: 0;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.7;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map .map .area h3 {
    margin-right: 1.6rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .area h3 {
    margin-bottom: 0.4rem;
    font-size: 1.4rem;
  }
}

body.page-template-page-company .history .step-and-map .map .area p {
  color: #009b71;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.6;
}

body.page-template-page-company .history .step-and-map .map .numbers {
  gap: 2.4rem;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers {
    display: contents;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction,
body.page-template-page-company .history .step-and-map .map .numbers .transfer {
  align-items: center;
  background: #eefaf7;
  border-radius: 1rem;
  padding: 3.2rem 4rem;
  display: flex;
}

@media screen and (min-width: 769px) {

  body.page-template-page-company .history .step-and-map .map .numbers .construction,
  body.page-template-page-company .history .step-and-map .map .numbers .transfer {
    justify-content: space-between;
  }
}

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

  body.page-template-page-company .history .step-and-map .map .numbers .construction,
  body.page-template-page-company .history .step-and-map .map .numbers .transfer {
    gap: 0;
    align-items: end;
    padding: 2.4rem 1.6rem;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .text,
body.page-template-page-company .history .step-and-map .map .numbers .transfer .text {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  color: #009b71;
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .text h3,
body.page-template-page-company .history .step-and-map .map .numbers .transfer .text h3 {
  font-weight: 700;
}

@media screen and (min-width: 769px) {

  body.page-template-page-company .history .step-and-map .map .numbers .construction .text h3,
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text h3 {
    margin-right: 1.6rem;
  }
}

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

  body.page-template-page-company .history .step-and-map .map .numbers .construction .text h3,
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text h3 {
    margin-bottom: 0.8rem;
    order: 1;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .text .year,
body.page-template-page-company .history .step-and-map .map .numbers .transfer .text .year {
  font-weight: 500;
  padding-bottom: 0.8rem;
}

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

  body.page-template-page-company .history .step-and-map .map .numbers .construction .text .year,
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text .year {
    order: 3;
    padding-bottom: 0.3rem;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .text p:not(.year),
body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) {
  font-family: "Albert Sans", sans-serif;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
}

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

  body.page-template-page-company .history .step-and-map .map .numbers .construction .text p:not(.year),
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) {
    letter-spacing: 0em;
    order: 2;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .text p:not(.year) .unit,
body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) .unit {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 5rem;
  font-weight: 900;
  margin-left: 0.4rem;
  line-height: 1;
}

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

  body.page-template-page-company .history .step-and-map .map .numbers .construction .text p:not(.year) .unit,
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) .unit {
    font-size: 3.2rem;
    margin-left: 0.1rem;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .image,
body.page-template-page-company .history .step-and-map .map .numbers .transfer .image {
  aspect-ratio: 181/151;
  width: 18.1rem;
  border-radius: 1rem;
  overflow: hidden;
  flex-shrink: 0;
  margin: 0;
}

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

  body.page-template-page-company .history .step-and-map .map .numbers .construction .image,
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .image {
    aspect-ratio: auto;
    width: 15.6rem;
    height: 12.8rem;
    transform: translateY(1rem);
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .image img,
body.page-template-page-company .history .step-and-map .map .numbers .transfer .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .history .step-and-map .map .numbers .construction {
    margin-bottom: 3.2rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .construction {
    order: 3;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction h3 {
  font-size: 2rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .construction h3 {
    font-size: 1.6rem;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .construction .year {
  font-size: 1.4rem;
}

body.page-template-page-company .history .step-and-map .map .numbers .construction p:not(.year) {
  font-size: 10rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .construction p:not(.year) {
    font-size: 6rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .transfer {
    order: 5;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .transfer .text h3 {
  font-size: 1.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text h3 {
    font-size: 1.6rem;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .transfer .text .year {
  font-size: 1.3rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text .year {
    font-size: 1.4rem;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) {
  font-size: 9.7rem;
  letter-spacing: -0.03em;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) {
    font-size: 5.7rem;
    letter-spacing: -0.04em;
  }
}

body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) .unit {
  margin-left: 0.1rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .text p:not(.year) .unit {
    margin-left: 0;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .history .step-and-map .map .numbers .transfer .image {
    width: 14.8rem;
  }
}

body.page-template-page-company ul.years {
  background: #f8f9fb;
  border-radius: 1rem;
  margin-bottom: 8.8rem;
  padding: 9rem 8.8rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years {
    margin-bottom: 5.6rem;
    padding: 4rem 2.4rem;
  }
}

body.page-template-page-company ul.years::before {
  background: #bac2d3;
  content: "";
  display: block;
  height: calc(100% - 17.6rem);
  left: 49.1rem;
  top: 8.8rem;
  position: absolute;
  width: 2px;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years::before {
    height: calc(100% - 9rem);
    left: 3rem;
    top: 5rem;
  }
}

body.page-template-page-company ul.years li {
  display: flex;
  flex-direction: column;
  position: relative;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company ul.years li {
    padding-left: 54.5rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li {
    flex-direction: column-reverse;
    padding-left: 6.4rem;
  }
}

body.page-template-page-company ul.years li.no1::before {
  background: url(./../img/company/no1.webp) center/cover;
  content: "";
  display: block;
  height: 19.4rem;
  position: absolute;
  right: -0.9rem;
  top: -11.6rem;
  width: 19.1rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li.no1::before {
    height: 10.6rem;
    right: 0;
    top: 7rem;
    width: 12.1rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li.no1 .blue {
    margin-bottom: 8.8rem;
  }
}

body.page-template-page-company ul.years li:not(:last-child) {
  padding-bottom: 8.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li:not(:last-child) {
    padding-bottom: 4rem;
  }
}

body.page-template-page-company ul.years li.month {
  padding-bottom: 4.8rem;
}

body.page-template-page-company ul.years li:last-child::before {
  background: #f8f9fb;
  content: "";
  display: block;
  height: 100%;
  left: 40rem;
  position: absolute;
  top: 1.3rem;
  width: 1rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li:last-child::before {
    left: 0;
    top: 0.9rem;
  }
}

body.page-template-page-company ul.years li::after {
  background: url(./../img/company/history-line.svg) left center/cover no-repeat;
  content: "";
  display: block;
  height: 1.4rem;
  left: 39.8rem;
  position: absolute;
  top: 1.3rem;
  width: 11.7rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li::after {
    left: 0;
    top: 0.9rem;
    width: 4.8rem;
  }
}

body.page-template-page-company ul.years li .image {
  aspect-ratio: 328/149;
  border-radius: 1rem;
  overflow: hidden;
  width: 32.8rem;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company ul.years li .image {
    position: absolute;
    left: 0;
    top: 0.9rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li .image {
    margin-top: 1.6rem;
    width: 21.7rem;
  }
}

body.page-template-page-company ul.years li .image:empty {
  display: none;
}

body.page-template-page-company ul.years li .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.page-template-page-company ul.years li .text h3 {
  font-family: "Albert Sans", sans-serif;
  font-size: 4rem;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1;
  margin-bottom: 0.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li .text h3 {
    font-size: 3.2rem;
  }
}

body.page-template-page-company ul.years li .text p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li .text p {
    line-height: 1.5;
  }
}

body.page-template-page-company ul.years li .text p.blue {
  color: #0044dd;
  font-size: 2rem;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company ul.years li .text p.blue {
    font-size: 1.8rem;
  }
}

body.page-template-page-company .recruit {
  margin-bottom: 12.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit {
    margin-bottom: 6.4rem;
  }
}

body.page-template-page-company .recruit h3 {
  color: #f37f28;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.7;
  margin-bottom: 4.9rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit h3 {
    font-size: 2.6rem;
    margin-bottom: 3.2rem;
  }
}

body.page-template-page-company .recruit .image-and-text {
  display: flex;
  justify-content: space-between;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .recruit .image-and-text .image {
    aspect-ratio: 571/518;
    width: 57rem;
  }

  body.page-template-page-company .recruit .image-and-text .text {
    width: 59rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit .image-and-text {
    flex-direction: column;
  }

  body.page-template-page-company .recruit .image-and-text .image {
    aspect-ratio: 329/221;
    margin-bottom: 2.4rem;
  }
}

body.page-template-page-company .recruit .image-and-text:not(:last-child) {
  margin-bottom: 8.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit .image-and-text:not(:last-child) {
    margin-bottom: 4rem;
  }
}

body.page-template-page-company .recruit .image-and-text.reverse {
  flex-direction: row-reverse;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .recruit .image-and-text.reverse .image {
    aspect-ratio: 590/279;
    width: 59rem;
  }

  body.page-template-page-company .recruit .image-and-text.reverse .text {
    width: 57rem;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit .image-and-text.reverse {
    flex-direction: column-reverse;
  }

  body.page-template-page-company .recruit .image-and-text.reverse .text {
    margin-bottom: 3.2rem;
  }

  body.page-template-page-company .recruit .image-and-text.reverse .image {
    aspect-ratio: 329/189;
  }
}

body.page-template-page-company .recruit .image {
  border-radius: 1rem;
  overflow: hidden;
}

body.page-template-page-company .recruit .image img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

body.page-template-page-company .recruit .text p {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 2;
}

body.page-template-page-company .recruit .personalities {
  margin-top: 3.2rem;
}

body.page-template-page-company .recruit .personalities li {
  align-items: center;
  background: #fff4ec;
  border: 1px solid #f37f28;
  border-radius: 1rem;
  display: flex;
  gap: 3.2rem;
  padding: 2.4rem 4rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit .personalities li {
    flex-direction: column;
    gap: 0.8rem;
    padding: 1.6rem 3.2rem 2.4rem;
  }
}

body.page-template-page-company .recruit .personalities li::before {
  border-radius: 50%;
  content: "";
  display: block;
  flex-shrink: 0;
  height: 9rem;
  width: 9rem;
}

body.page-template-page-company .recruit .personalities li:nth-child(1)::before {
  background: url(./../img/company/recruit-icon_1.svg) center/cover;
}

body.page-template-page-company .recruit .personalities li:nth-child(2)::before {
  background: url(./../img/company/recruit-icon_2.svg) center/cover;
}

body.page-template-page-company .recruit .personalities li:not(:last-child) {
  margin-bottom: 1.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit .personalities li:not(:last-child) {
    margin-bottom: 1.6rem;
  }
}

body.page-template-page-company .recruit .personalities .text h4,
body.page-template-page-company .recruit .personalities .text p {
  color: #f37f28;
}

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

  body.page-template-page-company .recruit .personalities .text h4,
  body.page-template-page-company .recruit .personalities .text p {
    text-align: center;
  }
}

body.page-template-page-company .recruit .personalities .text h4 {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 0.4rem;
}

body.page-template-page-company .recruit .personalities .text p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.7;
}

body.page-template-page-company .recruit-message {
  background: #efefef;
  padding: 10.4rem 0;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message {
    padding: 6.4rem 0;
  }
}

body.page-template-page-company .recruit-message .left-lined {
  margin-bottom: 9.2rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message .left-lined {
    margin-bottom: 3.2rem;
  }
}

body.page-template-page-company .recruit-message .image-and-text {
  position: relative;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .recruit-message .image-and-text {
    display: flex;
    align-items: end;
    gap: 8rem;
  }
}

body.page-template-page-company .recruit-message .image-and-text::before {
  background: linear-gradient(90deg, #f37f28 0%, #f37f28 60%, #1d1d1d 60%, #1d1d1d 100%);
  background-clip: text;
  color: transparent;
  content: "RECRUITMENT MESSAGE";
  font-family: "Albert Sans", sans-serif;
  font-size: 10rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1;
  position: absolute;
  top: 0;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .recruit-message .image-and-text::before {
    left: -0.2rem;
    top: -2.8rem;
    white-space: nowrap;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message .image-and-text::before {
    background: linear-gradient(-90deg, #f37f28 0%, #f37f28 50%, #1d1d1d 50%, #1d1d1d 100%);
    background-clip: text;
    font-size: 5rem;
    max-height: 50rem;
    right: 0;
    top: 1.5rem;
    writing-mode: vertical-rl;
  }
}

body.page-template-page-company .recruit-message .image-and-text .image {
  aspect-ratio: 536/841;
  border-radius: 1rem;
  flex-shrink: 0;
  overflow: hidden;
  width: 53.6rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message .image-and-text .image {
    aspect-ratio: 329/464;
    margin-bottom: 3.2rem;
    width: 100%;
  }
}

body.page-template-page-company .recruit-message .image-and-text .image img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

body.page-template-page-company .recruit-message .image-and-text .text h3 {
  font-size: 3.2rem;
  font-weight: 900;
  line-height: 1.7;
  margin-bottom: 2.4rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message .image-and-text .text h3 {
    font-size: 2.4rem;
    margin-bottom: 1.6rem;
  }
}

body.page-template-page-company .recruit-message .image-and-text .text h3 .green {
  color: #009b71;
}

body.page-template-page-company .recruit-message .image-and-text .text h3 .blue {
  color: #0044dd;
}

body.page-template-page-company .recruit-message .image-and-text .text p {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.7;
}

body.page-template-page-company .recruit-message .image-and-text .text p+p {
  margin-top: 1.6rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message .image-and-text .text p+p {
    margin-top: 0.8rem;
  }
}

body.page-template-page-company .recruit-message .image-and-text .text p+h3 {
  margin-top: 4.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message .image-and-text .text p+h3 {
    margin-top: 3.2rem;
  }
}

body.page-template-page-company .recruit-message .image-and-text .author p {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.7;
  margin-top: 5.6rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .recruit-message .image-and-text .author p {
    margin-top: 4rem;
  }
}

body.page-template-page-company .recruit-message .image-and-text .author p .name {
  font-size: 2rem;
}

body.page-template-page-company .recruit-message .text h3:nth-of-type(2) {
  line-height: 1.5;
}

body.page-template-page-company .thoughts {
  background: #1d1d1d;
  padding: 10.4rem 0 12.2rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts {
    padding: 6.4rem 0;
  }
}

body.page-template-page-company .thoughts .left-lined {
  color: #fff;
  margin-bottom: 4.8rem;
}

body.page-template-page-company .thoughts .left-lined::before {
  background: #fff;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts .left-lined {
    margin-bottom: 3.2rem;
  }
}

body.page-template-page-company .thoughts li {
  background: #fff;
  border-radius: 1rem;
  padding: 4.8rem 5.6rem;
}

@media screen and (min-width: 769px) {
  body.page-template-page-company .thoughts li {
    align-items: flex-start;
    display: flex;
    gap: 4.8rem;
    justify-content: space-between;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts li {
    padding: 3.2rem 2.4rem;
  }
}

body.page-template-page-company .thoughts li:not(:last-child) {
  margin-bottom: 4rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts li:not(:last-child) {
    margin-bottom: 2.4rem;
  }
}

body.page-template-page-company .thoughts li:nth-child(1) h3::before {
  background: #009b71;
}

body.page-template-page-company .thoughts li:nth-child(1) h3 span {
  background: #009b71;
}

body.page-template-page-company .thoughts li:nth-child(1) .lead {
  color: #009b71;
}

body.page-template-page-company .thoughts li:nth-child(2) h3::before {
  background: #0044dd;
}

body.page-template-page-company .thoughts li:nth-child(2) h3 span {
  background: #0044dd;
}

body.page-template-page-company .thoughts li:nth-child(2) .lead {
  color: #0044dd;
}

body.page-template-page-company .thoughts li:nth-child(3) h3::before {
  background: #f37f28;
}

body.page-template-page-company .thoughts li:nth-child(3) h3 span {
  background: #f37f28;
}

body.page-template-page-company .thoughts li:nth-child(3) .lead {
  color: #f37f28;
}

body.page-template-page-company .thoughts .text h3 {
  display: inline-flex;
  gap: 0.3rem;
  margin-bottom: 2.4rem;
}

body.page-template-page-company .thoughts .text h3 span {
  background: #f37f28;
  border-radius: 0.2rem;
  color: #fff;
  font-family: "Albert Sans", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  padding: 0.2rem 1.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts .text h3 span {
    font-size: 2.4rem;
    line-height: 1;
    padding: 0.8rem 2.3rem;
  }
}

body.page-template-page-company .thoughts .text h3::before {
  background: #f37f28;
  border-radius: 0.2rem;
  content: "";
  display: block;
  width: 0.8rem;
}

body.page-template-page-company .thoughts .text .lead {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.7;
  margin-bottom: 1.6rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts .text .lead {
    font-size: 2.2rem;
    line-height: 1.5;
  }
}

body.page-template-page-company .thoughts .text p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.7;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts .text p {
    margin-bottom: 3.2rem;
  }
}

body.page-template-page-company .thoughts .image {
  aspect-ratio: 333/226;
  border-radius: 1rem;
  flex-shrink: 0;
  overflow: hidden;
  width: 33.3rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts .image {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .thoughts .image.small {
    width: 26.5rem;
  }
}

body.page-template-page-company main>.numbers {
  background: #efefef;
  padding-top: 10.4rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company main>.numbers {
    padding-top: 6.4rem;
  }
}

body.page-template-page-company main>.numbers .left-lined {
  margin-bottom: 4.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company main>.numbers .left-lined {
    margin-bottom: 3.2rem;
  }
}

@media screen and (min-width: 769px) {
  body.page-template-page-company main>.numbers ul {
    display: grid;
    gap: 2.4rem;
  }

  body.page-template-page-company main>.numbers ul.col-3 {
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
  }

  body.page-template-page-company main>.numbers ul.col-3>li {
    grid-column: span 2;
  }

  body.page-template-page-company main>.numbers ul.col-3>li:nth-child(1), body.page-template-page-company main>.numbers ul.col-3>li:nth-child(2) {
    grid-column: span 3;
  }

  body.page-template-page-company main>.numbers ul.col-3>li:nth-child(9) {
    grid-column: span 6;
  }

  body.page-template-page-company main>.numbers ul.col-2 {
    grid-template-columns: 1.142fr 1fr;
    margin-top: 2.4rem;
  }

  body.page-template-page-company main>.numbers ul.col-2>li:nth-child(1) {
    grid-row: span 2;
  }

  body.page-template-page-company main>.numbers ul.col-2>li:nth-child(6) {
    grid-column: span 2;
  }
}

@media screen and (max-width: 768px) {
  body.page-template-page-company main>.numbers ul {
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
  }

  body.page-template-page-company main>.numbers ul.col-3 {
    margin-bottom: 1.6rem;
  }
}

body.page-template-page-company main>.numbers li {
  position: relative;
}

body.page-template-page-company main>.numbers li h3 {
  font-size: 2rem;
  font-weight: 700;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  top: 4rem;
  white-space: nowrap;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company main>.numbers li h3 {
    font-size: 1.8rem;
    top: 3.2rem;
  }
}

body.page-template-page-company main>.numbers li p {
  position: relative;
  z-index: 0;
}

body.page-template-page-company main>.numbers li p img {
  border-radius: 1rem;
  height: auto;
  width: 100%;
}

body.page-template-page-company .global-footer {
  background: #efefef;
}

body.page-template-page-company .global-footer .cta {
  padding-top: 12.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .global-footer .cta {
    padding-top: 6.4rem;
  }
}

body.page-template-page-company .sales-graph {
  margin-bottom: 8.8rem;
}

@media screen and (max-width: 768px) {
  body.page-template-page-company .sales-graph {
    margin-bottom: 4.8rem;
  }
}

/*# sourceMappingURL=page-company.css.map */