#main #environment .cardset .card .item a .read-more, #main #environment .cardset .card .item a .title, #main #business .blockwrap .block .txtbox a .title .read-more, #main #business .blockwrap .block .txtbox a .title small {
  font-family: "Montserrat", sans-serif;
}

#main #news, #main #environment .cardset .card .item a .title small, #main #company, #main #recruit, #main #business, #main #introduction, #main #top {
  font-family: "Noto Sans JP", sans-serif;
}

#main a {
  color: inherit;
  font-weight: inherit;
  font-family: inherit;
  text-decoration: none;
}

.contents {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
}
@media (max-width: 1200px) {
  .contents {
    width: calc(100% - 20px);
    margin: 0 10px;
  }
}

#main #top {
  position: relative;
  height: 900px;
  min-height: 370px;
  max-height: 100vh;
}
#main #top .contents {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  color: #ffffff;
  font-weight: bold;
  font-size: 64px;
  line-height: 1.40625;
  text-align: center;
  letter-spacing: 0.1em;
}
#main #top .contents .top-text {
  margin-bottom: 6px;
}
#main #top .hero-image {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
}
#main #top .hero-image .slick-list,
#main #top .hero-image .slick-track {
  height: 100%;
}
#main #top .hero-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 1023px) {
  #main #top {
    height: 56.25vw;
    max-height: 100vh;
  }
  #main #top .contents {
    font-size: 44px;
    line-height: 1.6;
  }
}
@media (max-width: 767px) {
  #main #top {
    min-height: 384px;
    max-height: calc(100vh - 50px);
  }
  #main #top .contents {
    font-size: calc(3.5714285714vw + 16.5714285714px);
  }
}
#main #introduction {
  margin-bottom: 138px;
  padding: 113px 0;
  background: no-repeat center/cover url(../images/introduction-bg.jpg);
}
#main #introduction .contents {
  min-height: 734px;
  padding: 98px 10px 90px 10px;
  background-color: rgba(255, 255, 255, 0.8);
}
#main #introduction .contents h2 {
  margin-bottom: 72px;
  color: inherit;
  font-weight: bold;
  font-size: 60px;
  line-height: 1.3333333333;
  font-family: inherit;
  letter-spacing: 0.1em;
  text-align: center;
}
#main #introduction .contents h2::before {
  display: none;
}
#main #introduction .contents h2 small {
  display: block;
  margin-top: 19px;
  font-weight: bold;
  font-size: 34px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
#main #introduction .contents .text {
  max-width: 889px;
  margin: 0 auto 81px auto;
  font-weight: 500;
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.1em;
}
@media (max-width: 1023px) {
  #main #introduction .contents {
    min-height: auto;
    padding: 49px 10px 45px 10px;
  }
  #main #introduction .contents h2 {
    margin-bottom: 36px;
    font-size: 40px;
    line-height: 2;
  }
  #main #introduction .contents h2 small {
    font-size: 22px;
  }
  #main #introduction .contents .text {
    margin-bottom: 40px;
    font-size: 17px;
    line-height: 1.6;
  }
}
@media (max-width: 767px) {
  #main #introduction .contents h2 {
    margin-bottom: 30px;
    font-size: calc(2.2321428571vw + 22.8571428571px);
    line-height: 1.6;
  }
  #main #introduction .contents h2 small {
    font-size: 20px;
  }
  #main #introduction .contents .text {
    margin-bottom: 40px;
    font-size: 16px;
    line-height: 1.6;
  }
}
#main #business {
  margin-bottom: 110px;
}
#main #business .flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#main #business .flex .text {
  margin-bottom: 10px;
  font-weight: 500;
  font-size: 30px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
#main #business .blockwrap {
  display: flex;
  flex-direction: column;
  gap: 60px;
  margin-top: 53px;
  overflow: hidden;
}
#main #business .blockwrap .block {
  display: flex;
  position: relative;
}
#main #business .blockwrap .block .image {
  width: 66.25%;
}
#main #business .blockwrap .block .image img {
  display: block;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#main #business .blockwrap .block .txtbox {
  transition: opacity 0.5s ease-out;
  position: absolute;
  top: 10vw;
  right: 0;
  width: 50%;
  height: 31.25vw;
  background-color: var(--bg-color2);
}
#main #business .blockwrap .block .txtbox:hover {
  opacity: 0.6;
}
#main #business .blockwrap .block .txtbox a {
  display: block;
  width: 100%;
  height: 100%;
}
#main #business .blockwrap .block .txtbox a .title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 8px;
  position: relative;
  width: 100%;
  max-width: 590px;
  height: 100%;
  padding-top: 5px;
  font-weight: bold;
  font-size: 50px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
#main #business .blockwrap .block .txtbox a .title small {
  color: var(--accent-color);
  font-weight: bold;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
#main #business .blockwrap .block .txtbox a .title .read-more {
  display: flex;
  align-items: center;
  gap: 15px;
  position: absolute;
  right: 0;
  bottom: 3.125vw;
  color: var(--accent-color);
  font-weight: bold;
  font-size: 20px;
  line-height: 1.7;
  letter-spacing: 0.1em;
}
#main #business .blockwrap .block .txtbox a .title .read-more::after {
  display: block;
  width: 42px;
  height: 9px;
  background: no-repeat center/contain url(../images/business-arrow.png);
  content: "";
}
#main #business .blockwrap .block:nth-of-type(2n) .image {
  margin-left: auto;
}
#main #business .blockwrap .block:nth-of-type(2n) .txtbox {
  right: auto;
  left: 0;
}
#main #business .blockwrap .block:nth-of-type(2n) .txtbox a .title {
  margin-left: auto;
}
#main #business .blockwrap .block:nth-of-type(2n) .txtbox a .title .read-more {
  right: 3.75vw;
}
@media (max-width: 1200px) {
  #main #business .blockwrap .block .txtbox a .title {
    width: calc(100% - 10px);
  }
}
@media (max-width: 1023px) {
  #main #business .flex {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }
  #main #business .flex .text {
    font-size: 25px;
  }
  #main #business .blockwrap .block .txtbox a .title {
    font-size: 40px;
  }
  #main #business .blockwrap .block .txtbox a .title small {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  #main #business .flex .text {
    font-size: 20px;
  }
  #main #business .blockwrap .block {
    min-height: calc(min(-14.1071428571vw + 185.1428571429px, 34.375vw) + 240px);
  }
  #main #business .blockwrap .block .image {
    width: 508.8px;
    max-width: 90%;
  }
  #main #business .blockwrap .block .txtbox {
    top: min(-14.1071428571vw + 185.1428571429px, 34.375vw);
    width: 384px;
    max-width: 90%;
    height: 240px;
  }
  #main #business .blockwrap .block .txtbox a .title {
    font-size: calc(3.3482142857vw + 14.2857142857px);
  }
  #main #business .blockwrap .block .txtbox a .title small {
    font-size: calc(0.4464285714vw + 10.5714285714px);
  }
  #main #business .blockwrap .block .txtbox a .title .read-more {
    font-size: 16px;
  }
  #main #business .blockwrap .block .txtbox a .title .read-more::after {
    width: 28px;
    height: 6px;
  }
}
#main #recruit {
  padding: 90px 0 141px;
  background: no-repeat center/cover url(../images/recruit-bg.jpg);
}
#main #recruit h2 {
  margin-bottom: 44px;
}
#main #recruit .text {
  width: 50%;
  margin-bottom: 83px;
  color: #ffffff;
  font-weight: 500;
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.1em;
}
#main #recruit .btn-like {
  margin: 0;
}
@media (max-width: 767px) {
  #main #recruit {
    padding-bottom: 60px;
  }
  #main #recruit .text {
    width: 100%;
    margin-bottom: 30px;
    font-size: 16px;
  }
  #main #recruit .btn-like {
    margin: 0 auto;
  }
}
#main #company {
  display: flex;
  position: relative;
  padding: 110px 0 220px;
  overflow: hidden;
  background-color: var(--bg-color2);
}
#main #company .left {
  width: calc(50% + 470px);
  max-width: 92.7272727273%;
  min-height: 837px;
  background: no-repeat center/cover url(../images/company-bg.jpg) var(--accent-color);
  color: #ffffff;
}
#main #company .left .left-inner {
  width: 100%;
  max-width: 1060px;
  height: 100%;
  margin-left: auto;
  padding: 205px 610px 205px 0;
}
#main #company .left .left-inner .company-name {
  margin-bottom: 54px;
}
#main #company .left .left-inner .company-name img {
  display: block;
  width: 393.5px;
  height: auto;
}
#main #company .left .left-inner .text {
  font-weight: 500;
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.1em;
}
#main #company .right {
  position: absolute;
  top: 209px;
  right: 0;
  width: calc(50.5% + 42px);
  min-height: 640px;
  background-color: #ffffff;
}
#main #company .right .right-inner {
  width: 100%;
  max-width: 640px;
  height: 100%;
  padding: 90px;
  padding-right: 89px;
}
#main #company .right .right-inner h2 {
  margin-bottom: 45px;
}
#main #company .right .right-inner .text {
  font-weight: bold;
  font-size: 40px;
  line-height: 1.915;
  letter-spacing: 0.1em;
}
@media (max-width: 1200px) {
  #main #company .left .left-inner {
    width: calc(100% - 10px);
    padding: 205px 10px 205px 0;
  }
  #main #company .right .right-inner {
    width: calc(100% - 10px);
  }
}
@media (max-width: 1023px) {
  #main #company {
    display: block;
    padding: 110px 0 720px;
  }
  #main #company .left {
    position: absolute;
    top: 390px;
    left: 0;
    min-height: auto;
  }
  #main #company .left .left-inner {
    padding: 205px 10px 150px 0;
  }
  #main #company .right {
    position: relative;
    top: 0;
    min-height: auto;
    margin-left: auto;
  }
  #main #company .right .right-inner {
    max-width: none;
    padding: 55px;
  }
  #main #company .right .right-inner .text {
    font-size: 30px;
  }
}
@media (max-width: 767px) {
  #main #company .left {
    top: calc(2.2321428571vw + 327.8571428571px);
  }
  #main #company .left .left-inner .company-name img {
    width: 262.3px;
  }
  #main #company .left .left-inner .text {
    font-size: 16px;
  }
  #main #company .right {
    width: 94%;
  }
  #main #company .right .right-inner {
    padding: 55px calc(3.3482142857vw + 29.2857142857px) 100px;
    padding-right: unset;
  }
  #main #company .right .right-inner h2 {
    margin-bottom: 25px;
  }
  #main #company .right .right-inner .text {
    font-size: calc(0.8928571429vw + 15.1428571429px);
  }
}
#main #environment {
  position: relative;
  margin: min(-10vw, -160px) 0 111px;
  padding-top: calc(max(10vw, 160px) + 85px);
  background: no-repeat top center/max(100%, 1600px) url(../images/environment-bg.png);
}
#main #environment .cardset {
  display: flex;
  gap: 80px;
}
#main #environment .cardset .card {
  position: relative;
  width: 46.6101694915%;
  height: 610px;
}
#main #environment .cardset .card .image {
  width: 85.4545454545%;
  height: 100%;
  margin-left: auto;
}
#main #environment .cardset .card .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#main #environment .cardset .card .item {
  transition: opacity 0.5s ease-out;
  position: absolute;
  top: 6.5573770492%;
  width: 43.6363636364%;
  height: 81.9672131148%;
}
#main #environment .cardset .card .item:hover {
  opacity: 0.6;
}
#main #environment .cardset .card .item a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  background-color: var(--accent-color);
  color: #ffffff;
}
#main #environment .cardset .card .item a .title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 33px;
  font-weight: bold;
  font-size: 40px;
  line-height: 1.15;
  letter-spacing: 0.1em;
  text-align: center;
}
#main #environment .cardset .card .item a .title small {
  display: block;
  margin: 0 auto;
  font-weight: 500;
  font-size: 20px;
  line-height: 1.7;
  letter-spacing: 0.1em;
  writing-mode: vertical-rl;
}
#main #environment .cardset .card .item a .read-more {
  display: flex;
  align-items: center;
  gap: 17px;
  position: absolute;
  right: 19px;
  bottom: 11px;
  color: #ffffff;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
#main #environment .cardset .card .item a .read-more::after {
  display: block;
  width: 34px;
  height: 8px;
  margin-bottom: 2px;
  background: no-repeat center/contain url(../images/environment-arrow.png);
  content: "";
}
@media (max-width: 1023px) {
  #main #environment .cardset {
    flex-direction: column;
    align-items: center;
  }
  #main #environment .cardset .card {
    width: 100%;
    max-width: 550px;
    height: 540px;
  }
  #main #environment .cardset .card .item {
    width: calc(20% + 130px);
    max-width: 100%;
  }
}
@media (max-width: 767px) {
  #main #environment .cardset {
    gap: 40px;
  }
  #main #environment .cardset .card {
    max-width: 420px;
    height: 460px;
  }
  #main #environment .cardset .card .item a .title {
    gap: 22px;
    font-size: 30px;
  }
  #main #environment .cardset .card .item a .read-more {
    gap: 9px;
    right: 10px;
    bottom: 5px;
    font-size: 14px;
  }
  #main #environment .cardset .card .item a .read-more::after {
    width: 17px;
    height: 4px;
    margin-bottom: 1px;
  }
}
#main #news {
  margin-bottom: 111px;
}
#main #news h2 {
  margin-bottom: 34px;
}
#main #news .articles {
  display: flex;
  flex-direction: column;
  gap: 35px;
  overflow-y: auto;
}
#main #news .articles article {
  display: flex;
  align-items: center;
  gap: 55px;
  padding: 23.1px 20px;
  border-bottom: solid 1px var(--bg-color2);
}
#main #news .articles article time {
  display: block;
  color: var(--accent-color);
  font-weight: 500;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
#main #news .articles article .text {
  font-weight: 500;
  font-size: 18px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
@media (max-width: 1023px) {
  #main #news .articles article time {
    font-size: 14px;
  }
  #main #news .articles article .text {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  #main #news .articles {
    gap: 25px;
  }
  #main #news .articles article {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    padding: 17.325px 15px;
  }
}/*# sourceMappingURL=index.css.map */