@charset "UTF-8";
#page_company #message {
  overflow: hidden;
  padding: 20rem 0;
}
@media screen and (max-width: 767px) {
  #page_company #message {
    padding: 12rem 0 14rem;
  }
}
#page_company #message .wrapper {
  z-index: 10;
}
#page_company #message .message {
  width: 62rem;
}
@media screen and (max-width: 767px) {
  #page_company #message .message {
    width: 100%;
  }
}
#page_company #message .message .photo {
  display: none;
}
@media screen and (max-width: 767px) {
  #page_company #message .message .photo {
    display: block;
    margin: 0 -2rem 3rem;
  }
}
#page_company #message .message .president {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  font-size: 1.5rem;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  #page_company #message .message .president {
    -moz-column-gap: 2rem;
         column-gap: 2rem;
  }
}
#page_company #message .message .president dd {
  position: relative;
  top: -0.1rem;
}
#page_company #message .message .president dd img {
  width: 12rem;
}
@media screen and (max-width: 767px) {
  #page_company #message .message .president dd img {
    width: 10rem;
  }
}
#page_company #message .projectStory {
  width: 62rem;
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  #page_company #message .projectStory {
    width: 100%;
    padding: 0 2rem;
  }
}
#page_company #message .projectStory a {
  display: flex;
  align-items: center;
  position: relative;
  padding: 1rem;
  color: #005bac;
  background: #fafafa;
  box-shadow: 2rem 3rem 5rem rgba(0, 88, 169, 0.15);
}
@media screen and (max-width: 767px) {
  #page_company #message .projectStory a {
    display: block;
  }
}
#page_company #message .projectStory a:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 1.5rem;
  width: 1.3rem;
  height: 1.3rem;
  background: #005bac;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 1.3rem auto;
          mask-size: 1.3rem auto;
}
#page_company #message .projectStory a picture {
  width: 19rem;
}
@media screen and (max-width: 767px) {
  #page_company #message .projectStory a picture {
    width: 100%;
  }
}
#page_company #message .projectStory a .txtBox {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  padding: 0.5rem 5rem 0;
}
@media screen and (max-width: 767px) {
  #page_company #message .projectStory a .txtBox {
    text-align: center;
    padding: 1.5rem 0 1rem;
  }
}
#page_company #message .projectStory a .txtBox p {
  font-size: 1.2rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  #page_company #message .projectStory a .txtBox p {
    font-size: 1rem;
    margin-bottom: 0.5rem;
  }
}
#page_company #message .projectStory a .txtBox h3 {
  font-size: 2.2rem;
}
@media screen and (max-width: 767px) {
  #page_company #message .projectStory a .txtBox h3 {
    font-size: 1.8rem;
  }
}
#page_company #message .bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 55%;
  height: 100%;
  display: flex;
  justify-content: flex-end;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  #page_company #message .bg {
    display: none;
  }
}
#page_company #message .bg img {
  max-width: unset;
  height: 100%;
}
#page_company #business {
  background: url("../img/bg_noise.webp") #f5faff;
  background-size: 16rem auto !important;
  padding-bottom: 20rem;
}
@media screen and (max-width: 767px) {
  #page_company #business {
    padding-bottom: 8rem;
  }
}
#page_company #business:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 140rem;
  background: linear-gradient(0deg, rgba(0, 91, 172, 0) 0%, rgba(0, 91, 172, 0.9) 40%, rgba(0, 91, 172, 0.9) 100%);
  background-size: 16rem auto !important;
}
@media screen and (max-width: 767px) {
  #page_company #business:before {
    height: 210rem;
  }
}
#page_company #business .wrapper {
  z-index: 10;
}
#page_company #business .overview {
  color: #fafafa;
}
#page_company #business .theme {
  position: relative;
}
@media screen and (max-width: 767px) {
  #page_company #business .theme {
    row-gap: 0rem;
  }
}
#page_company #business .theme ul {
  width: calc(50% - 3rem);
}
@media screen and (max-width: 767px) {
  #page_company #business .theme ul {
    width: 100%;
  }
}
#page_company #business .theme ul li {
  margin-bottom: 3rem;
}
#page_company #business .theme ul li:last-child h3 {
  font-size: 2.6rem;
}
#page_company #business .theme ul li p {
  white-space: normal;
  word-break: break-all;
  font-size: 1.8rem;
}
@media screen and (max-width: 1400px) {
  #page_company #business .theme ul li p {
    font-size: 1.6rem;
  }
}
#page_company #business .theme ul li img {
  position: absolute;
  width: 45.5%;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0.5rem 0.2rem 2rem rgba(0, 49, 93, 0.3);
}
@media screen and (max-width: 767px) {
  #page_company #business .theme ul li img {
    position: relative;
    gap: 2rem;
    width: 100%;
    margin-top: 2rem;
  }
}
#page_company #business .theme ul li img.-theme_01 {
  right: 3rem;
  top: 5rem;
}
@media screen and (max-width: 767px) {
  #page_company #business .theme ul li img.-theme_01 {
    top: 0;
    right: 0rem;
    margin-bottom: 1rem;
  }
}
#page_company #business .theme ul li img.-theme_02 {
  right: -5rem;
  top: 32rem;
}
@media screen and (max-width: 767px) {
  #page_company #business .theme ul li img.-theme_02 {
    right: 0;
    top: 0;
  }
}
#page_company #business ul.pentagon {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 20%));
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  row-gap: 0;
  margin: 10rem -6rem 0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 0;
  }
}
@media screen and (max-width: 1400px) {
  #page_company #business ul.pentagon {
    margin: 10rem -8rem 0;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon {
    margin: 3rem -2rem;
    text-align: left;
  }
}
#page_company #business ul.pentagon li {
  position: relative;
  border-radius: 99rem;
  overflow: hidden;
  background: #fafafa;
  border: 0.6rem solid #fafafa;
  padding-bottom: 4rem;
  box-shadow: 2rem 3rem 5rem rgba(0, 88, 169, 0.03);
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon li {
    border: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-radius: 0;
    padding: 0 0 0 11rem;
    min-height: 9rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon li + li {
    border-top: 0.2rem solid #d2d9e1;
  }
}
#page_company #business ul.pentagon li picture {
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon li picture {
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    width: 9.5rem;
    height: 100%;
    border: 0.6rem solid #fafafa;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon li picture img {
    height: 100%;
  }
}
#page_company #business ul.pentagon li h3 {
  color: #005bac;
  font-size: 2rem;
  margin-bottom: 1.2rem;
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon li h3 {
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
  }
}
#page_company #business ul.pentagon li p {
  font-size: 1.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon li p {
    font-size: 1.3rem;
  }
}
#page_company #business ul.pentagon li p + p {
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  #page_company #business ul.pentagon li p + p {
    margin-top: 0.2rem;
  }
}
#page_company #business dl.sdgs {
  display: flex;
  -moz-column-gap: 3rem;
       column-gap: 3rem;
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #page_company #business dl.sdgs {
    display: block;
    margin-top: 5rem;
  }
}
#page_company #business dl.sdgs dt {
  flex-shrink: 0;
  width: 25rem;
}
@media screen and (max-width: 767px) {
  #page_company #business dl.sdgs dt {
    width: 100%;
    text-align: center;
    margin-bottom: 3rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business dl.sdgs dt img {
    width: 14rem;
  }
}
#page_company #business dl.sdgs dd {
  display: grid;
  grid-template-columns: repeat(9, minmax(0, 11.1111111111%));
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  row-gap: 1rem;
}
@media screen and (max-width: 767px) {
  #page_company #business dl.sdgs dd {
    grid-template-columns: repeat(6, minmax(0, 16.6666666667%));
    -moz-column-gap: 0.2rem;
         column-gap: 0.2rem;
    row-gap: 0.2rem;
  }
}
#page_company #business .m_btn_main {
  text-align: center;
  margin: 5rem 0 10rem;
}
#page_company #business .m_btn_main a {
  font-size: 2rem;
  padding: 2rem 6rem 2rem 7rem;
}
@media screen and (max-width: 767px) {
  #page_company #business .m_btn_main a {
    font-size: 1.5rem;
    padding: 2rem 5rem 2rem 6rem;
  }
}
#page_company #business .surveying {
  position: relative;
  margin-top: 8rem;
  border: 0.5rem solid #d3dce9;
  padding: 6rem 10rem;
}
@media screen and (max-width: 1400px) {
  #page_company #business .surveying {
    padding: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying {
    border: 0.4rem solid #d3dce9;
    padding: 13rem 2rem 1rem;
  }
}
#page_company #business .surveying picture {
  position: absolute;
  top: -3.5rem;
  right: 8rem;
  width: 44rem;
}
@media screen and (max-width: 1400px) {
  #page_company #business .surveying picture {
    right: 4rem;
    width: 42rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying picture {
    top: -4.5rem;
    right: 0;
    width: 100%;
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying picture img {
    width: 20rem;
  }
}
#page_company #business .surveying p.sub {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 2rem;
  color: #005bac;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying p.sub {
    font-size: 1.5rem;
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying .hd {
    text-align: center;
  }
}
#page_company #business .surveying .row {
  display: flex;
  flex-wrap: wrap;
  row-gap: 1rem;
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying .row {
    margin: 2rem -1rem 0;
  }
}
#page_company #business .surveying .row dl {
  width: calc(33.3% - 1rem);
  background: #fafafa;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1rem 2rem rgba(0, 88, 169, 0.03);
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying .row dl {
    width: 100%;
  }
}
#page_company #business .surveying .row dl:nth-child(1), #page_company #business .surveying .row dl:nth-child(2) {
  width: calc(50% - 1rem);
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying .row dl:nth-child(1), #page_company #business .surveying .row dl:nth-child(2) {
    width: 100%;
  }
}
#page_company #business .surveying .row dl dt {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: relative;
  background: #005bac;
  color: #fafafa;
  padding: 1.2rem 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying .row dl dt {
    padding: 1.2rem 1.5rem;
    font-size: 1.6rem;
  }
}
#page_company #business .surveying .row dl dt i {
  display: inline-block;
  margin-right: 1rem;
  opacity: 0.5;
}
#page_company #business .surveying .row dl dd {
  font-size: 1.5rem;
  padding: 2rem;
  line-height: 1.8;
  text-align: justify;
  text-justify: inter-ideograph;
}
@media screen and (max-width: 1400px) {
  #page_company #business .surveying .row dl dd {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #business .surveying .row dl dd {
    padding: 1.5rem;
  }
}
#page_company #service {
  background: url("../img/bg_noise.webp") #f5faff;
  background-size: 16rem auto !important;
  padding: 0;
}
#page_company #service .m_txt_hd {
  margin-bottom: 4rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .m_txt_hd {
    margin-bottom: 3rem;
  }
}
#page_company #service .m_txt_hd.-large {
  margin-bottom: 3.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .m_txt_hd.-large {
    margin-bottom: 4rem;
  }
}
#page_company #service .loopTxt {
  position: relative;
  z-index: 1;
  width: 140rem;
  margin: 0 auto;
  padding-bottom: 20rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .loopTxt {
    width: 118rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .loopTxt {
    width: 100%;
    padding: 0 0 13rem;
  }
}
#page_company #service .loopTxt .city {
  position: absolute;
  bottom: 8rem;
  right: 0;
  z-index: 10;
  margin: auto;
  width: 75rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .loopTxt .city {
    bottom: 3rem;
    left: 0;
    width: 80%;
  }
}
#page_company #service .contents {
  position: relative;
  z-index: 10;
  padding: 20rem 0 28rem;
  color: #fafafa;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents {
    padding: 12rem 0 16rem;
  }
}
#page_company #service .contents_inner:not(:last-child) {
  padding-bottom: 12rem;
  border-bottom: solid 1px #6D778E;
  margin-bottom: 14rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents_inner:not(:last-child) {
    padding-bottom: 5rem;
    margin-bottom: 5rem;
  }
}
#page_company #service .contents .segment {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 50%));
  -moz-column-gap: 0;
       column-gap: 0;
  row-gap: 0;
  margin-top: 8rem;
  gap: 7rem;
  align-content: center;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment {
    margin-top: 3rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment picture {
    margin: 0 -2rem;
  }
}
#page_company #service .contents .segment .txtBox {
  padding: 0;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment .txtBox {
    padding: 3rem 0 0;
  }
}
#page_company #service .contents .segment .sub {
  font-size: 1.3rem;
  color: #6d778d;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment .sub {
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment .hd {
    font-size: 2.5rem;
  }
}
#page_company #service .contents .segment .txt {
  font-size: 2.2rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .contents .segment .txt {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment .txt {
    font-size: 1.5rem;
  }
}
#page_company #service .contents .segment dl.client {
  display: flex;
  align-items: flex-start;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  font-size: 1.5rem;
  margin-top: 3rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment dl.client {
    display: block;
    font-size: 1.3rem;
    margin-top: 2rem;
  }
}
#page_company #service .contents .segment dl.client dt {
  flex-shrink: 0;
  font-size: 1.3rem;
  background: #6d778d;
  padding: 0.2rem 1rem 0;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment dl.client dt {
    display: inline-block;
    font-size: 1rem;
    padding: 0.2rem 1rem 0.1rem;
    margin-bottom: 1rem;
  }
}
#page_company #service .contents .segment ol {
  list-style-type: decimal;
  padding-left: 2rem;
  margin-top: 4rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
#page_company #service .contents .segment ol li {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 2.2rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .contents .segment ol li {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .segment ol li {
    font-size: 1.5rem;
  }
}
#page_company #service .contents .product {
  padding-top: 12rem;
}
#page_company #service .contents .product .genre + .genre {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .product .genre + .genre {
    margin-top: 5rem;
  }
}
#page_company #service .contents .product .genre ul {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 25%));
  -moz-column-gap: 0.5rem;
       column-gap: 0.5rem;
  row-gap: 0.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .product .genre ul {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 0.5rem;
  }
}
#page_company #service .contents .product .genre ul li {
  transition: opacity 0.3s;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  background: #6d778d;
  border-radius: 0.5rem;
  padding: 2rem 2rem 1.5rem;
  min-height: 11rem;
  cursor: pointer;
}
#page_company #service .contents .product .genre ul li:hover {
  opacity: 0.6;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .product .genre ul li {
    min-height: 7.8rem;
    padding: 1.5rem 2rem 1.5rem;
  }
}
#page_company #service .contents .product .genre ul li:after {
  content: "";
  position: absolute;
  margin: auto;
  bottom: 1rem;
  right: 1.3rem;
  width: 1.3rem;
  height: 1.3rem;
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 1.3rem auto;
          mask-size: 1.3rem auto;
}
#page_company #service .contents .product .genre ul li span {
  display: block;
  font-size: 1.3rem;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .contents .product .genre ul li span {
    font-size: 1.2rem;
  }
}
#page_company #service .point {
  position: relative;
  z-index: 1;
  margin-top: 11rem;
  padding-bottom: 6rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 767px) {
  #page_company #service .point {
    align-items: flex-start;
  }
}
#page_company #service .point::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  clip-path: polygon(5% 0%, 100% 0%, 95% 100%, 0% 100%);
  background-color: rgba(109, 119, 142, 0.3);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  #page_company #service .point::before {
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
}
#page_company #service .point_inner {
  width: 80%;
}
@media screen and (max-width: 767px) {
  #page_company #service .point_inner {
    width: 100%;
    padding-left: 3rem;
    padding-right: 3rem;
  }
}
#page_company #service .point h3 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  margin-top: -2.8rem;
  font-size: 3.5rem;
  margin-bottom: 5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_company #service .point h3 {
    margin-top: -2rem;
    font-size: 2.5rem;
    margin-bottom: 3rem;
    text-align: left;
  }
}
#page_company #service .point_list {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 4.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .point_list {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 3rem;
  }
}
#page_company #service .point_list li {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  text-align: center;
  font-size: 2.9rem;
  padding: 0.5rem 2.5rem;
  text-wrap: nowrap;
  position: relative;
}
@media screen and (max-width: 1400px) {
  #page_company #service .point_list li {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .point_list li {
    font-size: 1.8rem;
    padding: 1.5rem 1.5rem;
  }
  #page_company #service .point_list li::after {
    content: "";
    position: absolute;
    top: 53%;
    left: 0;
    transform: translateY(-50%);
    height: 60%;
    width: 2px;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  #page_company #service .point_list li::after {
    background-color: #6D778E;
  }
}
#page_company #service .point_list li:not(:last-child) {
  border-right: solid 1px #6D778E;
  border-bottom: initial;
}
@media screen and (max-width: 767px) {
  #page_company #service .point_list li:not(:last-child) {
    border-right: initial;
  }
}
#page_company #service .point p {
  font-size: 1.6rem;
  margin-bottom: 4.5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_company #service .point p {
    font-size: 1.4rem;
    font-weight: 300;
    text-align: left;
  }
}
#page_company #service .point .detail_list {
  display: flex;
  gap: 3rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .point .detail_list {
    flex-direction: column;
  }
}
#page_company #service .point .detail_list_inner {
  display: grid;
  gap: 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .point .detail_list_inner {
    gap: 3rem;
  }
}
#page_company #service .point .detail_list li {
  text-wrap: nowrap;
  padding-left: 3.3rem;
  position: relative;
  font-size: 2rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .point .detail_list li {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .point .detail_list li {
    font-size: 1.5rem;
    text-wrap: wrap;
  }
}
#page_company #service .point .detail_list li::before {
  position: absolute;
  top: 46%;
  transform: translateY(-50%);
  left: 0;
  content: "";
  background-image: url("../img/i-check.svg");
  background-size: 90%;
  background-repeat: no-repeat;
  background-position: center;
  width: 2.4rem;
  height: 2.4rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .point .detail_list li::before {
    top: 1.1rem;
    width: 2.1rem;
    height: 2.1rem;
  }
}
#page_company #service .point .detail_list li span {
  border-radius: 99rem;
  border: solid 1px #6D778E;
  font-size: 0.8em;
  padding: 0.65rem 2rem 0.6rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .point .detail_list li span {
    display: block;
    text-align: center;
    padding: 0.3rem 1.5rem 0.3rem;
    margin-top: 0.5rem;
    margin-left: -3.3rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .point .service_Ttl {
    font-size: 2.2rem;
  }
}
#page_company #service .point .service_list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .point .service_list {
    gap: 1rem;
    flex-direction: column;
  }
}
#page_company #service .point .service_list li {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  border-radius: 99rem;
  border: solid 1px #6D778E;
  font-size: 2rem;
  padding: 0.65rem 3rem 0.6rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_company #service .point .service_list li {
    padding: 0.35rem 1.5rem 0.6rem;
    margin-top: 0.5rem;
    font-size: 1.8rem;
  }
}
#page_company #service .future {
  padding-top: 10rem;
}
#page_company #service .future .future_list_01 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 33.3333333333%));
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  row-gap: 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_01 {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_01 {
    row-gap: 2rem;
  }
}
#page_company #service .future .future_list_01 li {
  padding: 6rem 3rem;
  background-color: rgba(109, 119, 142, 0.3);
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_01 li {
    padding: 3rem 3rem;
  }
}
#page_company #service .future .future_list_01 li h4 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  text-align: center;
  font-size: 2.5rem;
  margin-bottom: 3.5rem;
  position: relative;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_list_01 li h4 {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_01 li h4 {
    font-size: 1.8rem;
    margin-bottom: 2.5rem;
    row-gap: 2rem;
  }
}
#page_company #service .future .future_sec {
  margin-bottom: 10rem;
}
#page_company #service .future .future_sec h4 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 3.5rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_sec h4 {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_sec h4 {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_sec_01 {
    margin-bottom: 5rem;
  }
}
#page_company #service .future .future_sec_01 picture {
  width: 100%;
}
#page_company #service .future .future_sec_01 picture img {
  width: 110%;
  max-width: initial;
  margin-right: -5rem;
  margin-bottom: 5rem;
  min-width: 800px;
}
#page_company #service .future .future_list_02 {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
#page_company #service .future .future_list_02 li {
  text-wrap: nowrap;
  padding-left: 3.3rem;
  position: relative;
  font-size: 2.4rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_list_02 li {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_02 li {
    font-size: 1.5rem;
    text-wrap: wrap;
  }
}
#page_company #service .future .future_list_02 li::before {
  position: absolute;
  top: 46%;
  transform: translateY(-50%);
  left: 0;
  content: "";
  background-image: url("../img/i-check.svg");
  background-size: 90%;
  background-repeat: no-repeat;
  background-position: center;
  width: 2.6rem;
  height: 2.6rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_list_02 li::before {
    width: 2.4rem;
    height: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_02 li::before {
    top: 1.1rem;
    width: 2.1rem;
    height: 2.1rem;
  }
}
#page_company #service .future .future_summary h4 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 3.7rem;
  display: flex;
  justify-content: center;
  align-items: center;
  text-wrap: nowrap;
  gap: 2rem;
  margin-bottom: 6rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_summary h4 {
    font-size: 2.2rem;
    text-align: center;
    text-wrap: wrap;
  }
}
#page_company #service .future .future_summary h4::before, #page_company #service .future .future_summary h4::after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: #6D778E;
  position: relative;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_summary h4::before, #page_company #service .future .future_summary h4::after {
    width: 10%;
  }
}
#page_company #service .future .future_summary .m_txt_lead {
  margin-bottom: 5rem;
  font-size: 2.4rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_summary .m_txt_lead {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_summary .m_txt_lead {
    font-size: 1.5rem;
    text-wrap: wrap;
  }
}
#page_company #service .future .future_list_03 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 50%));
  -moz-column-gap: 8rem;
       column-gap: 8rem;
  row-gap: 8rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_03 {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 5rem;
  }
}
#page_company #service .future .future_list_03 .detail_item_Ttl {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
}
#page_company #service .future .future_list_03 .detail_item_Ttl div {
  font-size: 2rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_list_03 .detail_item_Ttl div {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_03 .detail_item_Ttl div {
    font-size: 1.2rem;
    text-wrap: wrap;
  }
}
#page_company #service .future .future_list_03 .detail_item_Ttl h5 {
  font-size: 2.8rem;
  padding-bottom: 1rem;
  border-bottom: solid 1px #fafafa;
  margin-bottom: 3rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_list_03 .detail_item_Ttl h5 {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_03 .detail_item_Ttl h5 {
    font-size: 2.2rem;
    text-wrap: wrap;
  }
}
#page_company #service .future .future_list_03 .detail_item_content {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 50%));
  -moz-column-gap: 4rem;
       column-gap: 4rem;
  row-gap: 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_03 .detail_item_content {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 5rem;
  }
}
#page_company #service .future .future_list_03 .detail_item_content div h6 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 2.4rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_list_03 .detail_item_content div h6 {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_03 .detail_item_content div h6 {
    font-size: 2rem;
    text-wrap: wrap;
  }
}
#page_company #service .future .future_list_03 .detail_item_content div h6 span {
  font-size: 0.7em;
}
#page_company #service .future .future_list_03 .detail_item_content div img {
  margin-bottom: 2.5rem;
}
#page_company #service .future .future_list_03 .detail_item_content div p {
  font-size: 1.8rem;
}
@media screen and (max-width: 1400px) {
  #page_company #service .future .future_list_03 .detail_item_content div p {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #service .future .future_list_03 .detail_item_content div p {
    font-size: 1.5rem;
    text-wrap: wrap;
  }
}
#page_company #about {
  position: relative;
  z-index: 20;
}
#page_company #about #about_company,
#page_company #about #about_base,
#page_company #about #about_group {
  display: flex;
  padding-top: 10rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company,
  #page_company #about #about_base,
  #page_company #about #about_group {
    display: block;
    padding-top: 5rem;
  }
}
#page_company #about #about_company h3,
#page_company #about #about_base h3,
#page_company #about #about_group h3 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  flex-shrink: 0;
  width: 32rem;
  font-size: 2.8rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company h3,
  #page_company #about #about_base h3,
  #page_company #about #about_group h3 {
    width: 100%;
    font-size: 2.5rem;
    margin-bottom: 2rem;
  }
}
#page_company #about #about_company .wrap,
#page_company #about #about_base .wrap,
#page_company #about #about_group .wrap {
  width: 100%;
  padding-top: 1rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company .wrap,
  #page_company #about #about_base .wrap,
  #page_company #about #about_group .wrap {
    padding-top: 0;
  }
}
#page_company #about #about_company {
  padding-top: 3rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company {
    padding-top: 3rem;
  }
}
#page_company #about #about_company dl {
  display: flex;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl {
    display: block;
    line-height: 1.8;
  }
}
#page_company #about #about_company dl + dl {
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl + dl {
    margin-top: 2rem;
  }
}
#page_company #about #about_company dl dt {
  font-size: 1.6rem;
  flex-shrink: 0;
  width: 21rem;
  padding-top: 0.2rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl dt {
    width: 100%;
    font-size: 1.3rem;
    color: #6d778d;
    padding-top: 0;
  }
}
#page_company #about #about_company dl dd a {
  text-decoration: underline;
}
#page_company #about #about_company dl dd a:after {
  content: "";
  display: inline-block;
  position: relative;
  top: -0.2rem;
  width: 1rem;
  height: 1rem;
  background: #191e29;
  -webkit-mask: url("../img/i_blank.svg") no-repeat center;
          mask: url("../img/i_blank.svg") no-repeat center;
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  margin: 0 0.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl dd a:after {
    top: -0.1rem;
  }
}
#page_company #about #about_company dl dd ul li {
  position: relative;
  padding-left: 1.5rem;
}
#page_company #about #about_company dl dd ul li:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 1.7rem;
  left: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 1rem;
  background: #191e29;
}
@media screen and (max-width: 1400px) {
  #page_company #about #about_company dl dd ul li:before {
    top: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl dd ul li:before {
    top: 1.1rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl dd .segment {
    margin-top: 1rem;
    padding-left: 1.5rem;
  }
}
#page_company #about #about_company dl dd .segment + .segment {
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl dd .segment + .segment {
    margin-top: 1rem;
  }
}
#page_company #about #about_company dl dd .segment h5 {
  font-size: 1.8rem;
  color: #6d778d;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 1400px) {
  #page_company #about #about_company dl dd .segment h5 {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #about #about_company dl dd .segment h5 {
    font-size: 1.3rem;
  }
}
#page_company #about #about_base .wrap {
  display: flex;
  -moz-column-gap: 5rem;
       column-gap: 5rem;
  position: relative;
  border-radius: 0.5rem;
  padding: 6rem;
  overflow: hidden;
  color: #fafafa;
  background: url("../img/bg_noise.webp") #005bac;
  background-size: 16rem auto !important;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_base .wrap {
    display: block;
    padding: 2.5rem 0 28rem 2rem;
    margin: 0 -2rem;
    border-radius: 0;
    width: auto;
  }
}
#page_company #about #about_base .wrap ol {
  counter-reset: num;
}
#page_company #about #about_base .wrap ol + ol {
  counter-reset: num 10;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_base .wrap ol + ol {
    margin-top: 1rem;
  }
}
#page_company #about #about_base .wrap ol li {
  counter-increment: num;
  position: relative;
  padding-left: 3rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_base .wrap ol li {
    display: flex;
    align-items: center;
    padding-left: 2.5rem;
  }
}
#page_company #about #about_base .wrap ol li:before {
  content: counter(num, decimal-leading-zero);
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.5;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_base .wrap ol li:before {
    top: 0.1rem;
    font-size: 1.2rem;
  }
}
#page_company #about #about_base .wrap ol li + li {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_base .wrap ol li + li {
    margin-top: 0.8rem;
  }
}
#page_company #about #about_base .wrap ol li span {
  display: block;
  opacity: 0.5;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_base .wrap ol li span {
    flex-shrink: 0;
    position: relative;
    top: -0.1rem;
    font-size: 1.2rem;
    margin-right: 1.5rem;
  }
}
#page_company #about #about_base .wrap .img {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 66.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_base .wrap .img {
    transform: scale(0.55);
    transform-origin: bottom right;
    right: 0.5rem;
  }
}
#page_company #about #about_base .wrap .img .marker i {
  position: absolute;
  z-index: 10;
  margin: auto;
  width: 0.8rem;
  height: 0.8rem;
  background: #fafafa;
  border-radius: 9rem;
}
#page_company #about #about_base .wrap .img .marker i:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  width: 0.8rem;
  height: 0.8rem;
  background: #fafafa;
  border-radius: 9rem;
  animation: scaleUp 2s infinite;
}
#page_company #about #about_base .wrap .img .marker i.marker01 {
  bottom: 45rem;
  right: 21rem;
}
#page_company #about #about_base .wrap .img .marker i.marker02 {
  bottom: 38.5rem;
  right: 19rem;
}
#page_company #about #about_base .wrap .img .marker i.marker03 {
  bottom: 26rem;
  right: 22.5rem;
}
#page_company #about #about_base .wrap .img .marker i.marker04 {
  bottom: 24.5rem;
  right: 24rem;
}
#page_company #about #about_base .wrap .img .marker i.marker05 {
  bottom: 28rem;
  right: 29rem;
}
#page_company #about #about_base .wrap .img .marker i.marker06 {
  bottom: 22rem;
  right: 33rem;
}
#page_company #about #about_base .wrap .img .marker i.marker07 {
  bottom: 21rem;
  right: 40rem;
}
#page_company #about #about_base .wrap .img .marker i.marker08 {
  bottom: 19rem;
  right: 51rem;
}
#page_company #about #about_base .wrap .img .marker i.marker09 {
  bottom: 14.5rem;
  right: 58.5rem;
}
#page_company #about #about_base .wrap .img .marker i.marker10 {
  bottom: 11rem;
  right: 62rem;
}
#page_company #about #about_base .wrap .img .number span {
  position: absolute;
  z-index: 10;
  display: flex;
  flex-direction: column;
  text-align: center;
  row-gap: 0.4rem;
}
#page_company #about #about_base .wrap .img .number span i {
  padding-top: 0.1rem;
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 9rem;
  font-size: 1.3rem;
  color: #005bac;
  background: #fafafa;
}
#page_company #about #about_base .wrap .img .number span.number01 {
  bottom: 47rem;
  right: 20.2rem;
}
#page_company #about #about_base .wrap .img .number span.number02 {
  bottom: 40rem;
  right: 18.2rem;
}
#page_company #about #about_base .wrap .img .number span.number03 {
  bottom: 27.7rem;
  right: 21.7rem;
}
#page_company #about #about_base .wrap .img .number span.number04 {
  top: 51.7rem;
  right: 23.2rem;
}
#page_company #about #about_base .wrap .img .number span.number05 {
  bottom: 29.6rem;
  right: 28.2rem;
}
#page_company #about #about_base .wrap .img .number span.number06 {
  top: 54.4rem;
  right: 32.1rem;
}
#page_company #about #about_base .wrap .img .number span.number07 {
  top: 55.4rem;
  right: 39.2rem;
}
#page_company #about #about_base .wrap .img .number span.number08 {
  top: 57.3rem;
  right: 50.2rem;
}
#page_company #about #about_base .wrap .img .number span.number09 {
  top: 62rem;
  right: 57.6rem;
}
#page_company #about #about_base .wrap .img .number span.number10 {
  top: 65.5rem;
  right: 61.2rem;
}
#page_company #about #about_group .row {
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row {
    display: block;
  }
}
#page_company #about #about_group .row + .row {
  margin-top: 4rem;
  padding-top: 4rem;
  border-top: 0.1rem solid #d3dce9;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row + .row {
    margin-top: 3rem;
    padding-top: 3rem;
  }
}
#page_company #about #about_group .row picture {
  flex-shrink: 0;
  width: 25rem;
  margin-right: 5rem;
  box-shadow: 2rem 3rem 5rem rgba(0, 88, 169, 0.03);
  background: #fff;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row picture {
    width: 100%;
    padding: 0 6rem;
    margin: 0 0 1.5rem;
  }
}
#page_company #about #about_group .row .txtBox {
  position: relative;
  top: -0.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row .txtBox {
    position: static;
  }
}
#page_company #about #about_group .row .txtBox h5 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 2.2rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row .txtBox h5 {
    font-size: 1.8rem;
  }
}
#page_company #about #about_group .row .txtBox h5 a {
  display: inline-block;
  text-decoration: underline;
}
#page_company #about #about_group .row .txtBox h5 a:after {
  content: "";
  display: inline-block;
  position: relative;
  top: -0.2rem;
  width: 1rem;
  height: 1rem;
  background: #191e29;
  -webkit-mask: url("../img/i_blank.svg") no-repeat center;
          mask: url("../img/i_blank.svg") no-repeat center;
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  margin: 0 0.5rem;
}
#page_company #about #about_group .row .txtBox ol {
  counter-reset: num;
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row .txtBox ol {
    font-size: 1.5rem;
  }
}
#page_company #about #about_group .row .txtBox ol li {
  counter-increment: num;
  position: relative;
  padding-left: 2.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row .txtBox ol li {
    margin-right: -1rem;
    padding-left: 1.5rem;
  }
}
#page_company #about #about_group .row .txtBox ol li + li {
  margin-top: 0.5rem;
}
#page_company #about #about_group .row .txtBox ol li:before {
  content: counter(num) ".";
  position: absolute;
  top: -0.3rem;
  left: 0;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row .txtBox ol li:before {
    top: -0.2rem;
  }
}
#page_company #about #about_group .row .txtBox p {
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  #page_company #about #about_group .row .txtBox p {
    font-size: 1.5rem;
  }
}
#page_company #modalProduct {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  background: rgba(41, 48, 61, 0.9);
  padding: 8rem 0 0 0;
  transition: transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1), opacity 0.3s;
  transform: scale(1.1);
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct {
    padding: 5rem 2rem 0;
  }
}
#page_company #modalProduct.is-show {
  transform: scale(1);
  opacity: 1;
  pointer-events: auto;
}
#page_company #modalProduct .contents {
  position: relative;
  background: #fafafa;
  border-radius: 0.5rem;
  max-width: 80rem;
  max-height: 80vh;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents {
    width: 90rem;
    min-height: 50vh;
    max-height: 75vh;
  }
}
#page_company #modalProduct .contents .wrap {
  max-height: 80vh;
  overflow-y: scroll;
}
#page_company #modalProduct .contents .close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 10;
  width: 8rem;
  height: 5rem;
  background: #d2d9e1;
  overflow: hidden;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .close {
    width: 6rem;
    height: 4rem;
  }
}
#page_company #modalProduct .contents .close:before, #page_company #modalProduct .contents .close:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  left: -1.1rem;
  width: 10.4rem;
  height: 0.1rem;
  background: #191e29;
  transform: rotate(31deg);
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .close:before, #page_company #modalProduct .contents .close:after {
    width: 8.4rem;
  }
}
#page_company #modalProduct .contents .close:after {
  transform: rotate(-31deg);
}
#page_company #modalProduct .contents .panel {
  display: none;
  padding: 5rem;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel {
    padding: 0rem;
  }
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel .txtBox {
    padding: 2rem 2rem;
  }
}
#page_company #modalProduct .contents .panel p.sub {
  font-size: 1.5rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel p.sub {
    font-size: 1.3rem;
    margin-bottom: 0;
  }
}
#page_company #modalProduct .contents .panel p.sub.-reverse {
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel p.sub.-reverse {
    margin-bottom: 0;
  }
}
#page_company #modalProduct .contents .panel h3.name {
  font-size: 3.5rem;
  color: #005bac;
  line-height: 1.4;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel h3.name {
    font-size: 2.5rem;
    margin-bottom: 0;
  }
}
#page_company #modalProduct .contents .panel h3.name.-reverse {
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel h3.name.-reverse {
    margin-bottom: 0;
  }
}
#page_company #modalProduct .contents .panel picture {
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel picture {
    margin-bottom: 0;
  }
}
#page_company #modalProduct .contents .panel picture img {
  width: 100%;
}
#page_company #modalProduct .contents .panel .txt {
  line-height: 2;
  font-size: 1.8rem;
  text-align: justify;
  text-justify: inter-ideograph;
}
@media screen and (max-width: 767px) {
  #page_company #modalProduct .contents .panel .txt {
    line-height: 1.8;
    font-size: 1.5rem;
  }
}

#page_culture #value .policy,
#page_culture #value .philosophy,
#page_culture #value .slogan {
  margin-top: 10rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .policy,
  #page_culture #value .philosophy,
  #page_culture #value .slogan {
    margin-top: 5rem;
  }
}
#page_culture #value .policy .wrap {
  text-align: center;
  padding: 8rem 20rem;
  box-shadow: inset 0 0 4rem rgba(255, 255, 255, 0.4);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.4) 0%, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.4) 50%, rgba(255, 255, 255, 0) 75%, rgba(255, 255, 255, 0.8029586835) 100%);
}
@media screen and (max-width: 1400px) {
  #page_culture #value .policy .wrap {
    padding: 8rem 10rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy .wrap {
    padding: 4rem 2rem 3rem;
  }
}
#page_culture #value .policy ul {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 33.3333333333%));
  -moz-column-gap: 10rem;
       column-gap: 10rem;
  row-gap: 0;
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy ul {
    grid-template-columns: repeat(2, minmax(0, 50%));
    -moz-column-gap: 2rem;
         column-gap: 2rem;
    row-gap: 2rem;
  }
}
#page_culture #value .policy ul li {
  position: relative;
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy ul li:first-child {
    grid-column: 1/3;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy ul li:first-child picture {
    left: 8rem;
  }
}
#page_culture #value .policy ul li * {
  position: relative;
  z-index: 10;
}
#page_culture #value .policy ul li p.en {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  color: #fafafa;
  padding-top: 4rem;
  font-size: 1.8rem;
  margin-bottom: 17rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy ul li p.en {
    padding-top: 2.5rem;
    font-size: 1.3rem;
    margin-bottom: 7rem;
  }
}
#page_culture #value .policy ul li h4 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 6rem;
  line-height: 0.8;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy ul li h4 {
    font-size: 3rem;
    margin-bottom: 1.5rem;
  }
}
#page_culture #value .policy ul li picture {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy ul li picture {
    width: 13.5rem;
  }
}
#page_culture #value .policy p.lead {
  text-align: center;
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .policy p.lead {
    text-align: justify;
    text-justify: inter-ideograph;
    margin-top: 3rem;
  }
}
#page_culture #value .philosophy picture,
#page_culture #value .philosophy .catch {
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .philosophy picture,
  #page_culture #value .philosophy .catch {
    margin-bottom: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .philosophy .catch {
    font-size: 2.2rem;
  }
}
#page_culture #value .slogan .hd {
  margin-bottom: 1rem;
}
#page_culture #value .slogan .year {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 1.8rem;
  margin-bottom: 3rem;
}
#page_culture #value .slogan .wrap {
  position: relative;
  text-align: center;
  padding: 12rem 20rem 10rem;
  box-shadow: inset 0 0 4rem rgba(255, 255, 255, 0.4);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.4) 0%, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.4) 50%, rgba(255, 255, 255, 0) 75%, rgba(255, 255, 255, 0.8029586835) 100%);
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .wrap {
    padding: 12rem 10rem 10rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .wrap {
    padding: 14rem 2rem 3rem;
  }
}
#page_culture #value .slogan picture.sloganTxt {
  position: relative;
  z-index: 10;
  text-align: center;
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan picture.sloganTxt {
    margin-bottom: 4rem;
  }
}
#page_culture #value .slogan picture.sloganTxt img {
  width: 54.3rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan picture.sloganTxt img {
    width: 23rem;
  }
}
#page_culture #value .slogan .txtBox {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 6rem;
       column-gap: 6rem;
  text-align: left;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .txtBox {
    flex-direction: column;
    align-items: flex-start;
    row-gap: 1rem;
  }
}
#page_culture #value .slogan .txtBox h4.catch {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 2.5rem;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .txtBox h4.catch {
    font-size: 1.8rem;
    letter-spacing: 0;
  }
}
#page_culture #value .slogan .txtBox h4.catch em {
  font-size: 4rem;
  margin-right: 0.5rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .txtBox h4.catch em {
    font-size: 2.8rem;
    letter-spacing: -0.05em;
  }
}
#page_culture #value .slogan .txtBox p.txt {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 2.5rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .txtBox p.txt {
    font-size: 1.6rem;
    line-height: 1.8;
  }
}
#page_culture #value .slogan .bg .obj {
  position: absolute;
  z-index: 1;
  width: 5.5rem;
  height: 5.5rem;
  border-radius: 0.5rem;
  background: #d5dae1;
  animation: sloganTile 4s infinite linear;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj {
    width: 4rem;
    height: 4rem;
  }
}
#page_culture #value .slogan .bg .obj.blue {
  opacity: 0.2;
  background: #005bac;
}
#page_culture #value .slogan .bg .obj.black {
  opacity: 0.2;
  background: #1f242f;
}
#page_culture #value .slogan .bg .obj.blur {
  filter: blur(0.5rem);
}
#page_culture #value .slogan .bg .obj.obj01 {
  top: 22rem;
  left: -3.5rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj01 {
    top: 3rem;
    left: -3rem;
  }
}
#page_culture #value .slogan .bg .obj.obj02 {
  bottom: 5rem;
  left: -4rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj02 {
    bottom: 2rem;
    left: -5rem;
  }
}
#page_culture #value .slogan .bg .obj.obj03 {
  top: 11rem;
  left: 11rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj03 {
    top: -6rem;
    left: 17rem;
  }
}
#page_culture #value .slogan .bg .obj.obj04 {
  top: -3rem;
  left: 21rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj04 {
    top: 2rem;
    left: 13rem;
  }
}
#page_culture #value .slogan .bg .obj.obj05 {
  top: 8rem;
  left: 40rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj05 {
    top: 21rem;
    left: 5rem;
  }
}
#page_culture #value .slogan .bg .obj.obj06 {
  top: 12rem;
  right: 27rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .obj.obj06 {
    top: 15rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj06 {
    top: 20rem;
    right: -2rem;
  }
}
#page_culture #value .slogan .bg .obj.obj07 {
  top: -10rem;
  right: 13rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .obj.obj07 {
    top: -12rem;
    right: 8rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj07 {
    top: 3rem;
    right: 3rem;
  }
}
#page_culture #value .slogan .bg .obj.obj08 {
  top: 34rem;
  right: 8rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj08 {
    top: -8rem;
    right: -3rem;
  }
}
#page_culture #value .slogan .bg .obj.obj09 {
  top: 22.5rem;
  right: -2rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj09 {
    top: 45rem;
    right: -1rem;
  }
}
#page_culture #value .slogan .bg .obj.obj10 {
  top: -8rem;
  right: -8rem;
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .obj.obj10 {
    top: 50rem;
    right: 8rem;
  }
}
#page_culture #value .slogan .bg .img {
  position: absolute;
  z-index: 5;
  width: 10rem;
  height: 10rem;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 2rem 2rem 3rem rgba(42, 48, 61, 0.1);
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .img {
    width: 6rem;
    height: 6rem;
  }
}
#page_culture #value .slogan .bg .img:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 99%, rgb(255, 255, 255) 100%);
  opacity: 0.3;
}
#page_culture #value .slogan .bg .img.img01 {
  top: 3rem;
  left: -7.5rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .img.img01 {
    top: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .img.img01 {
    top: 7.5rem;
    left: 18rem;
  }
}
#page_culture #value .slogan .bg .img.img02 {
  bottom: 8.5rem;
  left: -1.5rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .img.img02 {
    bottom: 22rem;
    left: -2.5rem;
  }
}
#page_culture #value .slogan .bg .img.img03 {
  top: 14rem;
  left: 14rem;
  width: 20rem;
  height: 20rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .img.img03 {
    top: 13rem;
    left: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .img.img03 {
    top: 4rem;
    left: 2.5rem;
    width: 12rem;
    height: 12rem;
  }
}
#page_culture #value .slogan .bg .img.img04 {
  top: -6rem;
  right: 28rem;
  width: 20rem;
  height: 20rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .img.img04 {
    top: -5rem;
    right: 18rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .img.img04 {
    top: -5rem;
    right: 3rem;
    width: 10rem;
    height: 10rem;
  }
}
#page_culture #value .slogan .bg .img.img05 {
  top: 20rem;
  right: 11.5rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .img.img05 {
    top: 21rem;
    right: -3rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .img.img05 {
    display: none;
  }
}
#page_culture #value .slogan .bg .img.img06 {
  top: 2.5rem;
  right: -5rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .img.img06 {
    top: 7rem;
    right: -2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .img.img06 {
    display: none;
  }
}
#page_culture #value .slogan .bg .img.img07 {
  bottom: 3rem;
  right: -5rem;
  width: 15rem;
  height: 15rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #value .slogan .bg .img.img07 {
    bottom: 2rem;
    right: -7rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #value .slogan .bg .img.img07 {
    bottom: 21rem;
    right: -6rem;
    width: 12rem;
    height: 12rem;
  }
}
#page_culture #environment {
  color: #fafafa;
}
#page_culture #environment:before {
  content: "";
  position: absolute;
  margin: auto;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 90rem;
  background: linear-gradient(0deg, rgb(249, 208, 212) 0%, rgb(238, 150, 164) 35%, rgb(238, 150, 164) 50%, rgba(238, 150, 164, 0) 100%);
  mix-blend-mode: soft-light;
}
#page_culture #environment ul.anchor {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 50%));
  -moz-column-gap: 5rem;
       column-gap: 5rem;
  row-gap: 0;
}
@media screen and (max-width: 767px) {
  #page_culture #environment ul.anchor {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 0;
  }
}
#page_culture #environment ul.anchor li a {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: relative;
  display: block;
  font-size: 3.4rem;
  padding: 2rem 0;
  border-bottom: 0.1rem solid #6d778d;
}
@media screen and (max-width: 767px) {
  #page_culture #environment ul.anchor li a {
    font-size: 2rem;
    padding: 1.5rem 0;
  }
}
#page_culture #environment ul.anchor li a:before, #page_culture #environment ul.anchor li a:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 2rem;
  width: 3rem;
  height: 3rem;
  border-radius: 9rem;
}
#page_culture #environment ul.anchor li a:before {
  background: #6d778d;
}
#page_culture #environment ul.anchor li a:after {
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 1.1rem auto;
          mask-size: 1.1rem auto;
  transform: rotate(90deg);
}
#page_culture #environment #environment_education,
#page_culture #environment #environment_benefit {
  padding-top: 15rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education,
  #page_culture #environment #environment_benefit {
    padding-top: 10rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education h3.hd,
  #page_culture #environment #environment_benefit h3.hd {
    line-height: 1.2;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education h3.hd .sub,
  #page_culture #environment #environment_benefit h3.hd .sub {
    font-size: 1.3rem;
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education h3.hd .main,
  #page_culture #environment #environment_benefit h3.hd .main {
    font-size: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education h4.hd,
  #page_culture #environment #environment_benefit h4.hd {
    font-size: 2rem;
    margin-bottom: 1rem;
  }
}
#page_culture #environment #environment_education .newEmployee .overview {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education .newEmployee .overview {
    display: block;
  }
}
#page_culture #environment #environment_education .newEmployee .overview picture {
  flex-shrink: 0;
  width: 47rem;
  padding-top: 1.2rem;
  margin-left: 6rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education .newEmployee .overview picture {
    width: 100%;
    margin: 0 0 2rem;
  }
}
#page_culture #environment #environment_education .newEmployee .tableWrap {
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education .newEmployee .tableWrap {
    margin-top: 3rem;
  }
}
#page_culture #environment #environment_education .career {
  margin-top: 8rem;
}
#page_culture #environment #environment_education .career .year {
  margin: 3rem 0 1rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education .career .year {
    margin: 2rem 0 1rem;
  }
}
#page_culture #environment #environment_education .career .training + .training {
  margin-top: 1rem;
}
#page_culture #environment #environment_education .career .training.training01 .tableWrap .attent,
#page_culture #environment #environment_education .career .training.training01 .tableTxt {
  background: rgba(59, 97, 186, 0.2);
}
#page_culture #environment #environment_education .career .training.training02 .tableWrap .attent,
#page_culture #environment #environment_education .career .training.training02 .tableTxt {
  background: rgba(124, 72, 201, 0.2);
}
#page_culture #environment #environment_education .career .training.training03 .tableWrap .attent,
#page_culture #environment #environment_education .career .training.training03 .tableTxt {
  background: rgba(73, 157, 92, 0.2);
}
#page_culture #environment #environment_education .career .training .tableTxt {
  border-top: 0.1rem solid #6d778d;
  padding: 3rem 5rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education .career .training .tableTxt {
    padding: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education .career .training .tableTxt ul {
    margin-top: 0.5rem;
  }
}
#page_culture #environment #environment_education .career .training .tableTxt ul li {
  position: relative;
  padding-left: 2rem;
}
#page_culture #environment #environment_education .career .training .tableTxt ul li:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 1.4rem;
  left: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 9rem;
  background: #fafafa;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_education .career .training .tableTxt ul li:before {
    top: 0.9rem;
  }
}
#page_culture #environment #environment_education .career .training .tableTxt h5 {
  margin: 2rem 0 0.5rem;
}
#page_culture #environment #environment_benefit .box {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_benefit .box {
    margin-top: 5rem;
  }
}
#page_culture #environment #environment_benefit .box .hd {
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_benefit .box .hd {
    margin-bottom: 0.5rem;
  }
}
#page_culture #environment #environment_benefit .box ul {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 25%));
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  row-gap: 3rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_benefit .box ul {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 0;
  }
}
#page_culture #environment #environment_benefit .box ul li {
  position: relative;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_benefit .box ul li {
    padding: 1.5rem 0 0 6.5rem;
    margin-top: 1.5rem;
    border-top: 0.1rem solid #384050;
  }
}
#page_culture #environment #environment_benefit .box ul li img {
  width: 7rem;
  margin-bottom: 1rem;
  filter: invert(100%) sepia(0%) saturate(7500%) hue-rotate(149deg) brightness(107%) contrast(104%);
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_benefit .box ul li img {
    position: absolute;
    top: 1rem;
    left: 0;
    width: 5rem;
  }
}
#page_culture #environment #environment_benefit .box ul li h5 {
  font-size: 1.8rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_benefit .box ul li h5 {
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
  }
}
#page_culture #environment #environment_benefit .box ul li p {
  font-size: 1.5rem;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_benefit .box ul li p {
    font-size: 1.3rem;
  }
}
#page_culture #environment #environment_women {
  position: relative;
  padding: 20rem 10rem 2rem;
  color: #191e29;
}
@media screen and (max-width: 1400px) {
  #page_culture #environment #environment_women {
    padding: 20rem 3rem 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women {
    padding: 10rem 0rem 2rem;
  }
}
#page_culture #environment #environment_women .wrap {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 20;
  border-radius: 0.5rem;
  background: url("../img/bg_noise.webp") #f5faff;
  background-size: 16rem auto !important;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap {
    display: block;
  }
}
#page_culture #environment #environment_women .wrap:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0.5rem;
  box-shadow: inset 0 0 4rem rgba(255, 255, 255, 0.4);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.4) 0%, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.4) 50%, rgba(255, 255, 255, 0) 75%, rgba(255, 255, 255, 0.8029586835) 100%);
}
#page_culture #environment #environment_women .wrap picture.license {
  flex-shrink: 0;
  position: relative;
  z-index: 20;
  width: 32rem;
  overflow: hidden;
  border-radius: 0.5rem 0 0 0.5rem;
  background: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap picture.license {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap picture.license img {
    width: 18rem;
  }
}
#page_culture #environment #environment_women .wrap .txtBox {
  position: relative;
  z-index: 20;
  padding: 0 5rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap .txtBox {
    padding: 3rem;
  }
}
#page_culture #environment #environment_women .wrap .txtBox .hd {
  margin-bottom: 2rem;
  color: #da425e;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap .txtBox .hd {
    line-height: 1;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap .txtBox .hd .sub {
    font-size: 1.3rem;
    margin-bottom: 0.5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap .txtBox .hd .main {
    font-size: 2.2rem;
  }
}
#page_culture #environment #environment_women .wrap .obj {
  position: absolute;
  z-index: 30;
}
#page_culture #environment #environment_women .wrap .obj.obj01 {
  top: -0.3rem;
  right: -0.7rem;
  width: 11.8rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap .obj.obj01 {
    right: -0.3rem;
    width: 5.9rem;
  }
}
#page_culture #environment #environment_women .wrap .obj.obj02 {
  bottom: 0;
  left: 0;
  width: 10.2rem;
}
@media screen and (max-width: 767px) {
  #page_culture #environment #environment_women .wrap .obj.obj02 {
    width: 5.1rem;
  }
}
#page_culture #environment #environment_women .loopTxt {
  position: absolute;
  bottom: -1.5rem;
  left: 0;
  z-index: 10;
  mix-blend-mode: overlay;
  opacity: 0.2;
}
#page_culture #nunmer .year {
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .year {
    margin-bottom: 1rem;
  }
}
#page_culture #nunmer .row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 33.3333333333%));
  -moz-column-gap: 3rem;
       column-gap: 3rem;
  row-gap: 3rem;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row {
    display: block;
  }
}
#page_culture #nunmer .row > div {
  position: relative;
  min-height: 29rem;
  overflow: hidden;
  background-size: 16rem auto !important;
  background-image: url("../img/bg_noise.webp");
  color: #fafafa;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row > div {
    min-height: auto;
    height: 18rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row > div + div {
    margin-top: 1rem;
  }
}
#page_culture #nunmer .row > div h3.hd {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: absolute;
  top: 3rem;
  left: 3rem;
  z-index: 10;
  font-size: 3rem;
  line-height: 1.4;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row > div h3.hd {
    top: 2rem;
    left: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row > div h3.hd {
    top: 1.5rem;
    left: 1.5rem;
    font-size: 2.5rem;
  }
}
#page_culture #nunmer .row > div h3.hd span {
  position: relative;
  top: 0.1rem;
  margin-left: 1rem;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row > div h3.hd span {
    font-size: 1.3rem;
  }
}
#page_culture #nunmer .row > div picture.bg {
  opacity: 0.25;
  width: 100%;
  height: 100%;
}
#page_culture #nunmer .row > div picture.bg img {
  width: 100%;
  height: 100%;
}
#page_culture #nunmer .row .sales {
  background-color: #005baa;
  grid-column: 1/3;
}
#page_culture #nunmer .row .salary {
  background-color: #217941;
}
#page_culture #nunmer .row .established {
  background-color: #4b5486;
}
#page_culture #nunmer .row .age {
  background-color: #af7c39;
  grid-column: 2/4;
  grid-row: 2/4;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age {
    height: 35rem;
  }
}
#page_culture #nunmer .row .age dl.num {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: absolute;
  z-index: 20;
  line-height: 0.8;
}
#page_culture #nunmer .row .age dl.num.num01 {
  top: 8rem;
  right: 18rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .age dl.num.num01 {
    top: 12rem;
    right: 14rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num.num01 {
    top: 6rem;
    right: 5rem;
  }
}
#page_culture #nunmer .row .age dl.num.num02 {
  bottom: 16rem;
  right: 15rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .age dl.num.num02 {
    bottom: 15rem;
    right: 14rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num.num02 {
    bottom: 9rem;
    right: 3rem;
  }
}
#page_culture #nunmer .row .age dl.num.num03 {
  bottom: 9rem;
  left: 25rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .age dl.num.num03 {
    bottom: 9rem;
    left: 20rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num.num03 {
    bottom: 5.5rem;
    left: 7.5rem;
  }
}
#page_culture #nunmer .row .age dl.num.num04 {
  top: 18rem;
  left: 16rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .age dl.num.num04 {
    top: 16rem;
    left: 12rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num.num04 {
    top: 14rem;
    left: 3rem;
  }
}
#page_culture #nunmer .row .age dl.num.num05 {
  top: 3rem;
  left: 40rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .age dl.num.num05 {
    left: 35rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num.num05 {
    top: 7.5rem;
    left: 13rem;
  }
}
#page_culture #nunmer .row .age dl.num dt {
  display: block;
  font-size: 2rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num dt {
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
  }
}
#page_culture #nunmer .row .age dl.num dd {
  font-size: 5rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .age dl.num dd {
    font-size: 4rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num dd {
    font-size: 2rem;
  }
}
#page_culture #nunmer .row .age dl.num dd em {
  font-size: 8rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .age dl.num dd em {
    font-size: 6rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age dl.num dd em {
    font-size: 4rem;
  }
}
#page_culture #nunmer .row .age canvas.graph {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10;
  margin: auto;
  pointer-events: none;
  width: 50rem !important;
  height: 50rem !important;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .age canvas.graph {
    width: 25rem !important;
    height: 25rem !important;
  }
}
#page_culture #nunmer .row .manRatio {
  background-color: #ab5272;
}
#page_culture #nunmer .row .yearsOfService {
  background-color: #2584a9;
}
#page_culture #nunmer .row .established {
  background-color: #879a42;
}
#page_culture #nunmer .row .recruitRatio {
  background-color: #c75052;
}
#page_culture #nunmer .row .overtime {
  background-color: #baa830;
}
#page_culture #nunmer .row .childcareLeave {
  background-color: #005baa;
}
#page_culture #nunmer .row .paid {
  background-color: #4b5486;
}
#page_culture #nunmer .row .sales p.num,
#page_culture #nunmer .row .salary p.num,
#page_culture #nunmer .row .established p.num,
#page_culture #nunmer .row .yearsOfService p.num,
#page_culture #nunmer .row .established p.num,
#page_culture #nunmer .row .overtime p.num,
#page_culture #nunmer .row .paid p.num {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: absolute;
  bottom: 4rem;
  right: 3rem;
  z-index: 10;
  font-size: 5rem;
  line-height: 0.8;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .sales p.num,
  #page_culture #nunmer .row .salary p.num,
  #page_culture #nunmer .row .established p.num,
  #page_culture #nunmer .row .yearsOfService p.num,
  #page_culture #nunmer .row .established p.num,
  #page_culture #nunmer .row .overtime p.num,
  #page_culture #nunmer .row .paid p.num {
    bottom: 3rem;
    right: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .sales p.num,
  #page_culture #nunmer .row .salary p.num,
  #page_culture #nunmer .row .established p.num,
  #page_culture #nunmer .row .yearsOfService p.num,
  #page_culture #nunmer .row .established p.num,
  #page_culture #nunmer .row .overtime p.num,
  #page_culture #nunmer .row .paid p.num {
    bottom: 2rem;
    right: 1.5rem;
    font-size: 4rem;
  }
}
#page_culture #nunmer .row .sales p.num em,
#page_culture #nunmer .row .salary p.num em,
#page_culture #nunmer .row .established p.num em,
#page_culture #nunmer .row .yearsOfService p.num em,
#page_culture #nunmer .row .established p.num em,
#page_culture #nunmer .row .overtime p.num em,
#page_culture #nunmer .row .paid p.num em {
  font-size: 10rem;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .sales p.num em,
  #page_culture #nunmer .row .salary p.num em,
  #page_culture #nunmer .row .established p.num em,
  #page_culture #nunmer .row .yearsOfService p.num em,
  #page_culture #nunmer .row .established p.num em,
  #page_culture #nunmer .row .overtime p.num em,
  #page_culture #nunmer .row .paid p.num em {
    font-size: 8rem;
  }
}
#page_culture #nunmer .row .manRatio,
#page_culture #nunmer .row .recruitRatio,
#page_culture #nunmer .row .childcareLeave {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
}
#page_culture #nunmer .row .manRatio .num,
#page_culture #nunmer .row .recruitRatio .num,
#page_culture #nunmer .row .childcareLeave .num {
  display: flex;
  justify-content: center;
  -moz-column-gap: 3rem;
       column-gap: 3rem;
  position: absolute;
  bottom: 3rem;
  left: 0;
  width: 100%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_culture #nunmer .row .manRatio .num,
  #page_culture #nunmer .row .recruitRatio .num,
  #page_culture #nunmer .row .childcareLeave .num {
    bottom: 2rem;
  }
}
#page_culture #nunmer .row .manRatio .num dl dt,
#page_culture #nunmer .row .recruitRatio .num dl dt,
#page_culture #nunmer .row .childcareLeave .num dl dt {
  font-size: 2rem;
  margin-bottom: 0.5rem;
}
#page_culture #nunmer .row .manRatio .num dl dd,
#page_culture #nunmer .row .recruitRatio .num dl dd,
#page_culture #nunmer .row .childcareLeave .num dl dd {
  font-size: 5rem;
  line-height: 0.8;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .manRatio .num dl dd,
  #page_culture #nunmer .row .recruitRatio .num dl dd,
  #page_culture #nunmer .row .childcareLeave .num dl dd {
    font-size: 4rem;
  }
}
#page_culture #nunmer .row .manRatio .num dl dd em,
#page_culture #nunmer .row .recruitRatio .num dl dd em,
#page_culture #nunmer .row .childcareLeave .num dl dd em {
  font-size: 8rem;
}
@media screen and (max-width: 1400px) {
  #page_culture #nunmer .row .manRatio .num dl dd em,
  #page_culture #nunmer .row .recruitRatio .num dl dd em,
  #page_culture #nunmer .row .childcareLeave .num dl dd em {
    font-size: 6rem;
  }
}

#page_projectStory #pageTtl {
  padding-top: 100vh;
  overflow: hidden;
  background: url("../img/bg_noise.webp") #005bac;
}
#page_projectStory #pageTtl .txtBox {
  position: relative;
  z-index: 10;
  padding-top: 30rem;
  color: #fafafa;
}
#page_projectStory #pageTtl .txtBox p.sub {
  position: relative;
  display: block;
  margin-bottom: 3rem;
  font-size: 1.5rem;
  letter-spacing: 0.22em;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  #page_projectStory #pageTtl .txtBox p.sub {
    margin-bottom: 2.5rem;
    font-size: 1.3rem;
  }
}
#page_projectStory #pageTtl .txtBox p.sub span {
  margin-right: 2rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #pageTtl .txtBox p.sub span {
    display: block;
    margin: 0 0 0.5rem;
  }
}
#page_projectStory #pageTtl .txtBox h1.ttl {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 6.5rem;
  line-height: 1.3;
  margin-bottom: 6rem;
}
@media screen and (max-width: 1400px) {
  #page_projectStory #pageTtl .txtBox h1.ttl {
    font-size: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #page_projectStory #pageTtl .txtBox h1.ttl {
    font-size: 3rem;
    margin-bottom: 3rem;
  }
}
#page_projectStory #pageTtl .txtBox .lead {
  width: 65rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #pageTtl .txtBox .lead {
    width: 100%;
  }
}
#page_projectStory #pageTtl .txtBox ul.anchor {
  width: 65rem;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #pageTtl .txtBox ul.anchor {
    width: 100%;
  }
}
#page_projectStory #pageTtl .bg {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  max-width: unset;
  height: 100vh;
}
#page_projectStory #pageTtl .bg img {
  height: 100%;
}
#page_projectStory #member {
  padding: 20rem 0;
}
@media screen and (max-width: 767px) {
  #page_projectStory #member {
    padding: 12rem 0;
  }
}
#page_projectStory #member .wrapper {
  display: flex;
}
@media screen and (max-width: 767px) {
  #page_projectStory #member .wrapper {
    display: block;
  }
}
#page_projectStory #member .wrapper h2 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  flex-shrink: 0;
  width: 32rem;
  font-size: 2.8rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #member .wrapper h2 {
    width: 100%;
    font-size: 2.5rem;
    margin-bottom: 4rem;
  }
}
#page_projectStory .episodeStyle h2.ttl {
  margin-bottom: 8rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle h2.ttl {
    margin-bottom: 3rem;
  }
}
#page_projectStory .episodeStyle p.txt_normal,
#page_projectStory .episodeStyle .txt_rightImg,
#page_projectStory .episodeStyle .txt_leftImg {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle p.txt_normal,
  #page_projectStory .episodeStyle .txt_rightImg,
  #page_projectStory .episodeStyle .txt_leftImg {
    margin-top: 3rem;
  }
}
#page_projectStory .episodeStyle p.txt_normal,
#page_projectStory .episodeStyle p.txt {
  line-height: 2;
  text-align: justify;
  text-justify: inter-ideograph;
}
#page_projectStory .episodeStyle p.wipeL {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: relative;
  font-size: 3rem;
  line-height: 1.8;
  padding-left: 8rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle p.wipeL {
    font-size: 1.6rem;
    padding: 0 0 2rem 0;
  }
}
#page_projectStory .episodeStyle p.wipeL:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 2.8rem;
  left: 0;
  width: 5rem;
  height: 1px;
  background: #191e29;
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle p.wipeL:before {
    top: auto;
    bottom: 0;
    width: 3rem;
  }
}
#page_projectStory .episodeStyle p.question {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 3rem;
  padding-left: 5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle p.question {
    font-size: 2rem;
    padding-left: 3rem;
  }
}
#page_projectStory .episodeStyle p.question:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 2.3rem;
  left: 0;
  width: 3rem;
  height: 1px;
  background: #191e29;
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle p.question:before {
    top: 1.4rem;
    width: 2rem;
  }
}
#page_projectStory .episodeStyle .txt_rightImg,
#page_projectStory .episodeStyle .txt_leftImg {
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle .txt_rightImg,
  #page_projectStory .episodeStyle .txt_leftImg {
    display: block;
  }
}
#page_projectStory .episodeStyle .txt_rightImg picture,
#page_projectStory .episodeStyle .txt_leftImg picture {
  padding-top: 1.2rem;
  width: 65rem;
}
@media screen and (max-width: 1400px) {
  #page_projectStory .episodeStyle .txt_rightImg picture,
  #page_projectStory .episodeStyle .txt_leftImg picture {
    width: 55rem;
  }
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle .txt_rightImg picture,
  #page_projectStory .episodeStyle .txt_leftImg picture {
    width: auto;
    margin: 0 -2rem 4rem;
  }
}
#page_projectStory .episodeStyle .txt_rightImg picture img,
#page_projectStory .episodeStyle .txt_leftImg picture img {
  max-width: unset;
  width: 140%;
  box-shadow: 2rem 3rem 5rem rgba(0, 88, 169, 0.15);
}
@media screen and (max-width: 1400px) {
  #page_projectStory .episodeStyle .txt_rightImg picture img,
  #page_projectStory .episodeStyle .txt_leftImg picture img {
    width: 120%;
  }
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle .txt_rightImg picture img,
  #page_projectStory .episodeStyle .txt_leftImg picture img {
    width: 100%;
    box-shadow: none;
  }
}
#page_projectStory .episodeStyle .txt_rightImg p.txt,
#page_projectStory .episodeStyle .txt_leftImg p.txt {
  width: 65rem;
}
@media screen and (max-width: 1400px) {
  #page_projectStory .episodeStyle .txt_rightImg p.txt,
  #page_projectStory .episodeStyle .txt_leftImg p.txt {
    width: 55rem;
  }
}
@media screen and (max-width: 767px) {
  #page_projectStory .episodeStyle .txt_rightImg p.txt,
  #page_projectStory .episodeStyle .txt_leftImg p.txt {
    width: 100%;
  }
}
#page_projectStory .episodeStyle .txt_rightImg {
  flex-direction: row-reverse;
}
#page_projectStory .episodeStyle .txt_rightImg picture {
  margin-left: auto;
}
#page_projectStory .episodeStyle .txt_leftImg picture {
  display: flex;
  justify-content: flex-end;
}
#page_projectStory .episodeStyle .txt_leftImg p.txt {
  margin-left: auto;
}
#page_projectStory .talkStyle {
  padding: 0;
}
#page_projectStory .talkStyle .visual {
  background: #fafafa;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle .visual {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 30rem;
  }
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle .visual img {
    height: 100%;
  }
}
#page_projectStory .talkStyle .contents {
  position: relative;
  z-index: 10;
  padding: 20rem 0;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle .contents {
    padding: 12rem 0;
  }
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle h2.ttl em {
    font-size: 2.7rem;
    letter-spacing: -0.06em;
  }
}
#page_projectStory .talkStyle dl.wipeL,
#page_projectStory .talkStyle dl.wipeR {
  display: flex;
  align-items: flex-start;
  -moz-column-gap: 3rem;
       column-gap: 3rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL,
  #page_projectStory .talkStyle dl.wipeR {
    -moz-column-gap: 2rem;
         column-gap: 2rem;
  }
}
#page_projectStory .talkStyle dl.wipeL dt,
#page_projectStory .talkStyle dl.wipeR dt {
  position: relative;
  text-align: center;
}
#page_projectStory .talkStyle dl.wipeL dt picture,
#page_projectStory .talkStyle dl.wipeR dt picture {
  width: 10rem;
  border-radius: 10rem;
  overflow: hidden;
  box-shadow: 2rem 2rem 3rem rgba(0, 88, 169, 0.05);
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL dt picture,
  #page_projectStory .talkStyle dl.wipeR dt picture {
    position: relative;
    top: 0.7rem;
    width: 6rem;
  }
}
#page_projectStory .talkStyle dl.wipeL dt p.name,
#page_projectStory .talkStyle dl.wipeR dt p.name {
  position: absolute;
  bottom: -3rem;
  left: 0;
  width: 100%;
  font-size: 1.5rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL dt p.name,
  #page_projectStory .talkStyle dl.wipeR dt p.name {
    bottom: -2.8rem;
    font-size: 1.2rem;
  }
}
#page_projectStory .talkStyle dl.wipeL dd,
#page_projectStory .talkStyle dl.wipeR dd {
  padding-top: 0.6rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL dd,
  #page_projectStory .talkStyle dl.wipeR dd {
    padding: 0;
  }
}
#page_projectStory .talkStyle dl.wipeL dd p.blow,
#page_projectStory .talkStyle dl.wipeR dd p.blow {
  position: relative;
  display: block;
  padding: 3rem 4rem;
  line-height: 1.8;
  box-shadow: 2rem 2rem 3rem rgba(0, 88, 169, 0.05);
  text-align: justify;
  text-justify: inter-ideograph;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL dd p.blow,
  #page_projectStory .talkStyle dl.wipeR dd p.blow {
    padding: 1.5rem 2rem;
    line-height: 1.6;
    font-size: 1.3rem;
  }
}
#page_projectStory .talkStyle dl.wipeL dd p.blow:before,
#page_projectStory .talkStyle dl.wipeR dd p.blow:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 3.8rem;
  border-style: solid;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL dd p.blow:before,
  #page_projectStory .talkStyle dl.wipeR dd p.blow:before {
    top: 3rem;
  }
}
#page_projectStory .talkStyle dl.wipeL dd p.blow i,
#page_projectStory .talkStyle dl.wipeR dd p.blow i {
  background: linear-gradient(0deg, rgba(36, 175, 245, 0) 13%, rgba(36, 175, 245, 0.3) 13%, rgba(36, 175, 245, 0.3) 50%, rgba(36, 175, 245, 0) 50%);
}
#page_projectStory .talkStyle dl.wipeL {
  padding-right: 24rem;
  margin: 5rem 0;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL {
    margin: 3rem -2rem;
    padding: 0 0 0 1rem;
  }
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL dd {
    width: 100%;
  }
}
#page_projectStory .talkStyle dl.wipeL dd p.blow {
  border-radius: 3rem;
  background: linear-gradient(0deg, rgb(242, 242, 242) 0%, rgb(255, 255, 255) 15%);
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL dd p.blow {
    border-radius: 1.5rem 0 0 1.5rem;
    min-height: 7.2rem;
  }
}
#page_projectStory .talkStyle dl.wipeL dd p.blow:before {
  content: "";
  position: absolute;
  margin: auto;
  left: -1rem;
  border-top: 0.8rem solid transparent;
  border-bottom: 0.8rem solid transparent;
  border-right: 1.5rem solid #fafafa;
  border-left: 0;
}
#page_projectStory .talkStyle dl.wipeL.-bl dd p.blow {
  color: #fafafa;
  background: linear-gradient(0deg, rgb(11, 85, 152) 0%, rgb(0, 91, 172) 15%);
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeL.-bl dd p.blow {
    display: flex;
    align-items: center;
  }
}
#page_projectStory .talkStyle dl.wipeL.-bl dd p.blow:before {
  border-right: 1.5rem solid #005bac;
}
#page_projectStory .talkStyle dl.wipeR {
  flex-direction: row-reverse;
  justify-content: flex-end;
  padding-left: 24rem;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeR {
    margin: 2rem -2rem 0;
    padding: 0 1rem 0 0;
  }
}
#page_projectStory .talkStyle dl.wipeR dd {
  width: 100%;
}
#page_projectStory .talkStyle dl.wipeR dd p.blow {
  border-radius: 3rem;
  background: linear-gradient(0deg, rgb(242, 242, 242) 0%, rgb(255, 255, 255) 15%);
}
@media screen and (max-width: 767px) {
  #page_projectStory .talkStyle dl.wipeR dd p.blow {
    border-radius: 0 1.5rem 1.5rem 0;
  }
}
#page_projectStory .talkStyle dl.wipeR dd p.blow:before {
  content: "";
  position: absolute;
  margin: auto;
  right: -1rem;
  border-top: 0.8rem solid transparent;
  border-bottom: 0.8rem solid transparent;
  border-left: 1.5rem solid #fafafa;
  border-right: 0;
}
#page_projectStory #projectStory:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  right: 0;
  width: 100%;
  height: 122.8rem;
  background: url("../img/bg_wave.webp") transparent no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory:before {
    height: 30rem;
  }
}
#page_projectStory #projectStory .swiperControl {
  position: absolute;
  top: 0.5rem;
  right: 0;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperControl {
    justify-content: center;
    position: absolute;
    top: 35rem;
    left: 0;
    margin: auto;
    width: 100%;
  }
}
#page_projectStory #projectStory .swiperControl .prev,
#page_projectStory #projectStory .swiperControl .next {
  flex-shrink: 0;
  position: relative;
  background: rgba(255, 255, 255, 0.1);
  width: 3rem;
  height: 3rem;
  border-radius: 9rem;
  cursor: pointer;
}
#page_projectStory #projectStory .swiperControl .prev:before,
#page_projectStory #projectStory .swiperControl .next:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 0.9rem auto;
          mask-size: 0.9rem auto;
}
#page_projectStory #projectStory .swiperControl .prev:before {
  transform: rotate(180deg);
}
#page_projectStory #projectStory .swiperControl .pagination {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: relative;
  bottom: auto;
  left: auto;
  width: 6rem;
  height: 6rem;
  font-size: 2rem;
  color: transparent;
  line-height: 1;
  margin: 0 3rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperControl .pagination {
    width: 4rem;
    height: 4rem;
    font-size: 1.3rem;
  }
}
#page_projectStory #projectStory .swiperControl .pagination:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  right: 0;
  width: 8rem;
  height: 0.1rem;
  background: #fafafa;
  transform: rotate(-45deg);
  transform-origin: top right;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperControl .pagination:before {
    width: 5.5rem;
  }
}
#page_projectStory #projectStory .swiperControl .pagination span {
  display: block;
  color: #fafafa;
}
#page_projectStory #projectStory .swiperControl .pagination span.swiper-pagination-total {
  text-align: right;
}
#page_projectStory #projectStory .swiperWrap {
  width: 100%;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperWrap {
    position: static;
    margin: 4rem -2rem 0;
    width: auto;
  }
}
#page_projectStory #projectStory .swiperWrap .swiper {
  overflow: visible;
  width: 85rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperWrap .swiper {
    width: 100%;
  }
}
#page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide {
  display: block;
  position: relative;
  background: #fafafa;
}
#page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  padding: 4rem 2rem 1.5rem;
  color: #fafafa;
  background: linear-gradient(0deg, rgba(40, 46, 59, 0.3) 0%, rgba(205, 220, 231, 0) 100%);
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt {
    padding: 4rem 1.5rem 1rem;
  }
}
#page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt span.sub {
  display: block;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt span.sub {
    font-size: 1rem;
  }
}
#page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt em.main {
  font-size: 3rem;
}
@media screen and (max-width: 767px) {
  #page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt em.main {
    font-size: 2rem;
  }
}
#page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:before, #page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:after {
  content: "";
  position: absolute;
  margin: auto;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 4.5rem;
  height: 4.5rem;
}
#page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:before {
  border: 0.1rem solid #fafafa;
  border-radius: 9rem;
}
#page_projectStory #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:after {
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 1.1rem auto;
          mask-size: 1.1rem auto;
}

#page_recruit #demand ul {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 25%));
  -moz-column-gap: 6rem;
       column-gap: 6rem;
  row-gap: 0;
  text-align: center;
  padding: 0 5rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #demand ul {
    grid-template-columns: repeat(2, minmax(0, 50%));
    -moz-column-gap: 1rem;
         column-gap: 1rem;
    row-gap: 2rem;
  }
}
@media screen and (max-width: 1400px) {
  #page_recruit #demand ul {
    padding: 0;
  }
}
#page_recruit #demand ul li {
  position: relative;
  padding-top: 26rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #demand ul li {
    padding-top: 15rem;
  }
}
#page_recruit #demand ul li * {
  position: relative;
  z-index: 10;
}
#page_recruit #demand ul li h4 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 4rem;
  line-height: 0.8;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #demand ul li h4 {
    font-size: 3rem;
    margin-bottom: 1.5rem;
  }
}
#page_recruit #demand ul li p.cap {
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #demand ul li p.cap {
    font-size: 1.5rem;
  }
}
#page_recruit #demand ul li picture {
  position: absolute;
  top: 4rem;
  left: 0;
  z-index: 1;
  width: 100%;
  min-height: 24rem;
  background: url("../img/recruit/demand_item_bg.webp") no-repeat top center;
  background-size: 26rem auto;
}
@media screen and (max-width: 1400px) {
  #page_recruit #demand ul li picture {
    background-size: 24.5rem auto;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #demand ul li picture {
    min-height: 13rem;
    background-size: 15rem auto;
  }
}
#page_recruit #demand ul li picture img {
  position: absolute;
  top: -4rem;
  left: 0;
  right: 0;
  margin: auto;
  width: 18.4rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #demand ul li picture img {
    width: 10rem;
  }
}
#page_recruit #message {
  color: #fafafa;
}
#page_recruit #message .tab .tabBtn {
  display: flex;
  position: relative;
  border-bottom: 0.1rem solid #6d778d;
}
#page_recruit #message .tab .tabBtn:before {
  content: "";
  position: absolute;
  margin: auto;
  bottom: 0;
  left: 0;
  width: 0.1rem;
  height: 1rem;
  background: #6d778d;
}
#page_recruit #message .tab .tabBtn div {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: relative;
  font-size: 3rem;
  padding: 3rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #message .tab .tabBtn div {
    width: 50%;
    font-size: 2rem;
    text-align: center;
    padding: 2rem 2rem 4rem;
    line-height: 1.4;
  }
}
#page_recruit #message .tab .tabBtn div:after {
  content: "";
  position: absolute;
  margin: auto;
  bottom: 0;
  right: 0;
  width: 0.1rem;
  height: 1rem;
  background: #6d778d;
}
#page_recruit #message .tab .tabBtn div.is-tab {
  opacity: 0.3;
}
#page_recruit #message .tab .tabBtn div i {
  display: inline-block;
  position: relative;
  top: 0.3rem;
  width: 3rem;
  height: 3rem;
  margin-left: 1rem;
  border-radius: 9rem;
  background: #6d778d;
}
@media screen and (max-width: 767px) {
  #page_recruit #message .tab .tabBtn div i {
    position: absolute;
    top: auto;
    bottom: 1rem;
    right: 0;
    left: 0;
    margin: auto;
    width: 2rem;
    height: 2rem;
  }
}
#page_recruit #message .tab .tabBtn div i:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 9rem;
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 1.1rem auto;
          mask-size: 1.1rem auto;
  transform: rotate(90deg);
}
@media screen and (max-width: 767px) {
  #page_recruit #message .tab .tabBtn div i:after {
    width: 2rem;
    height: 2rem;
    -webkit-mask-size: 0.6rem auto;
            mask-size: 0.6rem auto;
  }
}
#page_recruit #message .movie {
  margin-top: 10rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #message .movie {
    margin-top: 5rem;
  }
}
#page_recruit #recruitment .genre {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 50%));
  -moz-column-gap: 6rem;
       column-gap: 6rem;
  row-gap: 6rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .genre {
    grid-template-columns: repeat(1, minmax(0, 100%));
    row-gap: 3rem;
  }
}
#page_recruit #recruitment .genre picture {
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .genre picture {
    margin-bottom: 1.5rem;
  }
}
#page_recruit #recruitment .genre .hd {
  color: #005bac;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .genre .hd {
    font-size: 2rem;
    margin-bottom: 1rem;
  }
}
#page_recruit #recruitment .genre p.txt {
  font-size: 1.8rem;
  line-height: 1.8;
  text-align: justify;
  text-justify: inter-ideograph;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .genre p.txt {
    font-size: 1.5rem;
  }
}
#page_recruit #recruitment .info {
  margin-top: 8rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .info {
    margin-top: 5rem;
    line-height: 1.6;
  }
}
#page_recruit #recruitment .info table tr {
  display: flex;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .info table tr {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .info table tr + tr {
    margin-top: 2rem;
  }
}
#page_recruit #recruitment .info table tr th,
#page_recruit #recruitment .info table tr td {
  border-top: 0.1rem solid #d3dce9;
  padding: 3rem 0;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .info table tr th,
  #page_recruit #recruitment .info table tr td {
    display: block;
    border-top: none;
    padding: 0;
  }
}
#page_recruit #recruitment .info table tr th {
  flex-shrink: 0;
  width: 22rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .info table tr th {
    width: 100%;
    color: #6d778d;
    font-size: 1.3rem;
    margin-bottom: 0.2rem;
  }
}
#page_recruit #recruitment .info table tr td {
  width: 100%;
}
#page_recruit #recruitment .info dl {
  display: flex;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .info dl {
    display: block;
    padding-left: 1.5rem;
  }
}
#page_recruit #recruitment .info dl + dl {
  margin-top: 2rem;
}
#page_recruit #recruitment .info dl dt {
  flex-shrink: 0;
  width: 22rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #recruitment .info dl dt {
    width: 100%;
    color: #6d778d;
    font-size: 1.3rem;
  }
}
#page_recruit #recruitment .info dl dd {
  width: 100%;
}
#page_recruit #process {
  color: #fafafa;
}
#page_recruit #process .wrap {
  margin-top: 8rem;
  padding: 0 10rem;
}
@media screen and (max-width: 1400px) {
  #page_recruit #process .wrap {
    margin-top: 0;
    padding: 0;
  }
}
#page_recruit #process .wrap ol {
  position: relative;
}
#page_recruit #process .wrap ol:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 4.5rem;
  z-index: 10;
  width: 0.4rem;
  height: 95%;
  background: #6d778d;
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol:before {
    left: 1.8rem;
    height: 100%;
  }
}
#page_recruit #process .wrap ol > li {
  position: relative;
  z-index: 20;
  padding-left: 15rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li {
    padding-left: 6rem;
  }
}
#page_recruit #process .wrap ol > li + li {
  margin-top: 8rem;
}
@media screen and (max-width: 1400px) {
  #page_recruit #process .wrap ol > li + li {
    margin-top: 5rem;
  }
}
#page_recruit #process .wrap ol > li i.num {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: absolute;
  top: 0;
  left: 0;
  width: 10rem;
  height: 10rem;
  padding-bottom: 0.5rem;
  border-radius: 10rem;
  font-size: 3rem;
  background: #6d778d;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li i.num {
    width: 4rem;
    height: 4rem;
    font-size: 2rem;
    padding-bottom: 0.2rem;
  }
}
#page_recruit #process .wrap ol > li i.num:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 10rem;
  background: #6d778d;
  transform: scale(1.2);
  opacity: 0.5;
}
#page_recruit #process .wrap ol > li picture.icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 10;
  width: 40rem;
  height: 100%;
}
@media screen and (max-width: 1400px) {
  #page_recruit #process .wrap ol > li picture.icon {
    right: 0rem;
    width: 32.4rem;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li picture.icon {
    position: static;
    width: 100%;
    margin-top: 3rem;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li picture.icon img {
    width: 24rem;
  }
}
#page_recruit #process .wrap ol > li.step01 ul.btn {
  margin-top: 2.5rem;
}
#page_recruit #process .wrap ol > li.step01 ul.btn {
  -moz-column-gap: 2rem;
       column-gap: 2rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step01 ul.btn {
    display: block;
    margin-top: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step01 ul.btn li + li {
    margin-top: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step01 ul.btn li p {
    margin: 0;
  }
}
#page_recruit #process .wrap ol > li.step01 ul.btn li p a {
  min-width: 28rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step01 ul.btn li p a {
    min-width: 100%;
  }
}
#page_recruit #process .wrap ol > li.step01 ul.btn li p a span {
  font-weight: 600;
}
#page_recruit #process .wrap ol > li.step01 ul.btn li p a br {
  display: none;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step01 ul.btn li p a br {
    display: block;
  }
}
#page_recruit #process .wrap ol > li.step01 ul.btn li p.-entryMynav a:nth-child(2) {
  margin-top: 1rem;
}
#page_recruit #process .wrap ol > li.step01 ul.btn li .notes {
  display: block;
  font-size: 1.5rem;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step01 ul.btn li .notes {
    font-size: 1.3rem;
    text-align: center;
  }
}
#page_recruit #process .wrap ol > li.step01 ul.btn li .notes span {
  font-weight: 600;
}
#page_recruit #process .wrap ol > li.step02 ul.btn {
  -moz-column-gap: 2rem;
       column-gap: 2rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step02 ul.btn {
    display: block;
    margin-top: 2rem;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step02 ul.btn li + li {
    margin-top: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step02 ul.btn li p {
    margin: 0;
  }
}
#page_recruit #process .wrap ol > li.step02 ul.btn li p a {
  min-width: 28rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step02 ul.btn li p a {
    min-width: 100%;
  }
}
#page_recruit #process .wrap ol > li.step02 ul.btn li p a span {
  font-weight: 600;
}
#page_recruit #process .wrap ol > li.step02 ul.btn li p a br {
  display: none;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step02 ul.btn li p a br {
    display: block;
  }
}
#page_recruit #process .wrap ol > li.step02 ul.btn li p.-entryMynav a:nth-child(2) {
  margin-top: 1rem;
}
#page_recruit #process .wrap ol > li.step02 ul.btn li .notes {
  display: block;
  font-size: 1.5rem;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step02 ul.btn li .notes {
    font-size: 1.3rem;
    text-align: center;
  }
}
#page_recruit #process .wrap ol > li.step02 ul.btn li .notes span {
  font-weight: 600;
}
#page_recruit #process .wrap ol > li.step03 dl {
  display: flex;
  align-items: flex-start;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  font-size: 2rem;
  margin-top: 2rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step03 dl {
    display: block;
    font-size: 1.3rem;
    margin: 1rem -2rem 0 0;
  }
}
#page_recruit #process .wrap ol > li.step03 dl dt {
  flex-shrink: 0;
  position: relative;
  top: 0.2rem;
  font-size: 1.5rem;
  background: #6d778d;
  padding: 0.2rem 1rem 0;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step03 dl dt {
    display: inline-block;
    font-size: 1rem;
    padding: 0.2rem 1rem 0.1rem;
    margin-bottom: 1rem;
  }
}
#page_recruit #process .wrap ol > li.step04 picture.icon {
  top: 10rem;
  bottom: auto;
}
#page_recruit #process .wrap ol > li.step04 h3, #page_recruit #process .wrap ol > li.step05 h3 {
  margin: 0;
  padding: 2.3rem 0;
}
@media screen and (max-width: 767px) {
  #page_recruit #process .wrap ol > li.step04 h3, #page_recruit #process .wrap ol > li.step05 h3 {
    padding: 0.1rem 0;
  }
}
#page_recruit #faq .wrap {
  display: flex;
  padding-top: 8rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap {
    display: block;
    padding-top: 5rem;
  }
}
#page_recruit #faq .wrap h3 {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  flex-shrink: 0;
  width: 38rem;
  font-size: 2.8rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap h3 {
    width: 100%;
    font-size: 2.5rem;
    margin-bottom: 2rem;
  }
}
#page_recruit #faq .wrap .faq {
  width: 100%;
  padding-top: 1rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap .faq {
    padding-top: 0;
  }
}
#page_recruit #faq .wrap .faq dl {
  border-bottom: 0.1rem solid #d3dce9;
}
#page_recruit #faq .wrap .faq dl:first-child {
  border-top: 0.1rem solid #d3dce9;
}
#page_recruit #faq .wrap .faq dl dt {
  position: relative;
  padding: 3rem 0 3rem 5rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap .faq dl dt {
    padding: 2rem 3.5rem;
  }
}
#page_recruit #faq .wrap .faq dl dt:before {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  content: "";
  position: absolute;
  margin: auto;
  top: 1.8rem;
  left: 0;
  content: "Q";
  color: #005bac;
  font-size: 3rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap .faq dl dt:before {
    top: 1rem;
    font-size: 2.2rem;
  }
}
#page_recruit #faq .wrap .faq dl dt i {
  position: absolute;
  top: 3.2rem;
  right: 3rem;
  width: 3rem;
  height: 3rem;
  border-radius: 3rem;
  background: #6d778d;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap .faq dl dt i {
    top: 2rem;
    right: 0rem;
    width: 2.4rem;
    height: 2.4rem;
  }
}
#page_recruit #faq .wrap .faq dl dt i:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 9rem;
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 1.1rem auto;
          mask-size: 1.1rem auto;
  transform: rotate(90deg);
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap .faq dl dt i:after {
    width: 2.4rem;
    height: 2.4rem;
    -webkit-mask-size: 0.8rem auto;
            mask-size: 0.8rem auto;
  }
}
#page_recruit #faq .wrap .faq dl dt.is-open i:after {
  transform: rotate(-90deg);
}
#page_recruit #faq .wrap .faq dl dd {
  position: relative;
  padding: 0 0 3rem 5rem;
  text-align: justify;
  text-justify: inter-ideograph;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap .faq dl dd {
    padding: 0 0 2rem 3.5rem;
  }
}
#page_recruit #faq .wrap .faq dl dd:before {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  content: "";
  position: absolute;
  margin: auto;
  top: -1.2rem;
  left: 0;
  content: "A";
  color: #b62b27;
  font-size: 3rem;
}
@media screen and (max-width: 767px) {
  #page_recruit #faq .wrap .faq dl dd:before {
    top: -1rem;
    font-size: 2.2rem;
  }
}

#page_top #mainImg {
  padding: max(100vh, 70rem) 0 0;
  color: #fafafa;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg {
    padding: max(100vh, 60rem) 0 0;
  }
}
#page_top #mainImg .visual {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  min-height: 70rem;
  overflow: hidden;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .visual {
    height: 100vh;
    min-height: 60rem;
  }
}
#page_top #mainImg .visual .txtBox {
  position: absolute;
  bottom: 5rem;
  left: 0;
  z-index: 20;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .visual .txtBox {
    bottom: auto;
    top: 9rem;
  }
}
@media (max-width: 767px) and (max-height: 375px) {
  #page_top #mainImg .visual .txtBox {
    top: 7rem;
    text-align: left;
    padding-left: 2rem;
  }
}
#page_top #mainImg .visual .txtBox p.en {
  font-size: 2.5rem;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .visual .txtBox p.en {
    font-size: 1.2rem;
    margin-bottom: 1rem;
  }
}
@media (max-width: 767px) and (max-height: 375px) {
  #page_top #mainImg .visual .txtBox p.en {
    font-size: 0.7rem;
    padding-left: 0.5rem;
  }
}
#page_top #mainImg .visual .txtBox h1.catch {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  font-size: 20rem;
  line-height: 1;
  text-shadow: 3rem 3rem 7rem rgba(0, 88, 169, 0.08);
  letter-spacing: 0.0325em;
}
@media screen and (max-width: 1400px) {
  #page_top #mainImg .visual .txtBox h1.catch {
    font-size: 16rem;
  }
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .visual .txtBox h1.catch {
    font-size: 6.5rem;
    line-height: 1.1;
    padding-left: 3.5rem;
  }
}
@media (max-width: 767px) and (max-height: 375px) {
  #page_top #mainImg .visual .txtBox h1.catch {
    font-size: 3.5rem;
    text-indent: 0;
    padding-left: 0;
  }
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .visual .txtBox h1.catch span:nth-child(n+1):nth-child(-n+3) {
    position: relative;
    left: -1.5rem;
  }
}
@media (max-width: 767px) and (max-height: 375px) {
  #page_top #mainImg .visual .txtBox h1.catch span:nth-child(n+1):nth-child(-n+3) {
    left: auto;
  }
}
#page_top #mainImg .visual .man {
  position: relative;
  z-index: 10;
  padding-top: 20rem;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .visual .man {
    display: flex;
    justify-content: center;
    padding-top: 40vh;
  }
}
@media (max-width: 767px) and (max-height: 375px) {
  #page_top #mainImg .visual .man {
    justify-content: flex-end;
    padding-right: 1rem;
  }
}
#page_top #mainImg .visual .man img {
  width: 100vh;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .visual .man img {
    width: 42rem;
    max-width: 42rem;
  }
}
@media (max-width: 767px) and (max-height: 375px) {
  #page_top #mainImg .visual .man img {
    width: 20rem;
    max-width: 20rem;
  }
}
#page_top #mainImg .visual .grad {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50rem;
  background: linear-gradient(0deg, rgb(167, 219, 243) 30%, rgba(167, 219, 243, 0) 100%);
}
#page_top #mainImg .concept {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  padding: 20rem 0 30rem;
  text-shadow: 3rem 3rem 7rem rgba(0, 88, 169, 0.08);
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .concept {
    padding: 10rem 0 14rem;
  }
}
#page_top #mainImg .concept h2.catch {
  font-size: 5rem;
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .concept h2.catch {
    font-size: 3rem;
    margin-bottom: 3rem;
  }
}
#page_top #mainImg .concept p.txt {
  font-size: 2.5rem;
  line-height: 2.2;
}
@media screen and (max-width: 767px) {
  #page_top #mainImg .concept p.txt {
    font-size: 1.5rem;
  }
}
#page_top #company {
  padding-bottom: 20rem;
}
@media screen and (max-width: 767px) {
  #page_top #company {
    padding-bottom: 8rem;
  }
}
#page_top #company .overview {
  position: relative;
  width: 118rem;
  margin: 0 auto;
}
@media screen and (max-width: 1400px) {
  #page_top #company .overview {
    position: relative;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #page_top #company .overview h2.ttl {
    margin-bottom: 1rem;
  }
}
#page_top #company .overview picture.img {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 62.1rem;
  filter: drop-shadow(3rem 3rem 3rem rgb(255, 255, 255)) drop-shadow(6rem 6rem 3rem rgba(49, 55, 69, 0.1));
  text-align: center;
}
@media screen and (max-width: 767px) {
  #page_top #company .overview picture.img {
    position: static;
    width: 100%;
    padding-right: 2rem;
    margin-bottom: 2rem;
    filter: drop-shadow(3rem 3rem 3rem rgb(255, 255, 255));
  }
}
@media screen and (max-width: 767px) {
  #page_top #company .overview picture.img img {
    width: 28rem;
  }
}
#page_top #company .imgLink {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #page_top #company .imgLink {
    margin: 5rem -2rem 0;
  }
}
#page_top #company .movie {
  margin-top: 15rem;
}
@media screen and (max-width: 767px) {
  #page_top #company .movie {
    margin-top: 8rem;
  }
}
#page_top #culture {
  background: url("../img/bg_noise.webp") #f5faff;
  background-size: 16rem auto !important;
  padding-top: 0;
}
#page_top #culture:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  right: 0;
  width: 100%;
  height: 108.6rem;
  background: url("../img/bg_tone.webp") transparent no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  #page_top #culture:before {
    height: 50rem;
  }
}
#page_top #culture .loopTxt {
  position: relative;
  z-index: 10;
  padding: 20rem 0;
  width: 118rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #page_top #culture .loopTxt {
    width: 100%;
    padding: 10rem 0 13rem;
  }
}
#page_top #culture .loopTxt .man picture {
  position: absolute;
  z-index: 10;
  width: 46.2rem;
}
@media screen and (max-width: 767px) {
  #page_top #culture .loopTxt .man picture {
    width: 21rem;
  }
}
#page_top #culture .loopTxt .man .man01 {
  top: 5rem;
  left: -2rem;
}
@media screen and (max-width: 767px) {
  #page_top #culture .loopTxt .man .man01 {
    top: 6rem;
    left: 1rem;
  }
}
#page_top #culture .loopTxt .man .man02 {
  top: -9rem;
  left: 30rem;
}
@media screen and (max-width: 767px) {
  #page_top #culture .loopTxt .man .man02 {
    top: -4rem;
    left: 13rem;
  }
}
#page_top #culture .loopTxt .man .man03 {
  top: 2rem;
  left: 54rem;
}
@media screen and (max-width: 767px) {
  #page_top #culture .loopTxt .man .man03 {
    top: 2rem;
    left: 23rem;
  }
}
#page_top #culture .loopTxt .man .man04 {
  top: 54rem;
  right: 0;
}
@media screen and (max-width: 767px) {
  #page_top #culture .loopTxt .man .man04 {
    display: none;
  }
}
#page_top #culture .loopTxt .man .man05 {
  top: 35rem;
  right: -25rem;
}
@media screen and (max-width: 767px) {
  #page_top #culture .loopTxt .man .man05 {
    display: none;
  }
}
#page_top #culture .contents .imgLink {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #page_top #culture .contents .imgLink {
    margin: 5rem -2rem 0;
  }
}
#page_top #projectStory {
  color: #fafafa;
}
#page_top #projectStory:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  right: 0;
  width: 100%;
  height: 122.8rem;
  background: url("../img/bg_wave.webp") transparent no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  #page_top #projectStory:before {
    height: 30rem;
  }
}
#page_top #projectStory .overview {
  position: relative;
  z-index: 10;
  width: 46rem;
}
@media screen and (max-width: 1400px) {
  #page_top #projectStory .overview {
    width: 41rem;
  }
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .overview {
    width: 100%;
  }
}
#page_top #projectStory .overview .swiperControl {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .overview .swiperControl {
    justify-content: center;
    position: absolute;
    top: 43rem;
    left: 0;
    margin: auto;
    width: 100%;
  }
}
#page_top #projectStory .overview .swiperControl .prev,
#page_top #projectStory .overview .swiperControl .next {
  flex-shrink: 0;
  position: relative;
  background: rgba(255, 255, 255, 0.1);
  width: 3rem;
  height: 3rem;
  border-radius: 9rem;
  cursor: pointer;
}
#page_top #projectStory .overview .swiperControl .prev:before,
#page_top #projectStory .overview .swiperControl .next:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 0.9rem auto;
          mask-size: 0.9rem auto;
}
#page_top #projectStory .overview .swiperControl .prev:before {
  transform: rotate(180deg);
}
#page_top #projectStory .overview .swiperControl .pagination {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: relative;
  bottom: auto;
  left: auto;
  width: 6rem;
  height: 6rem;
  font-size: 2rem;
  color: transparent;
  line-height: 1;
  margin: 0 3rem;
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .overview .swiperControl .pagination {
    width: 4rem;
    height: 4rem;
    font-size: 1.3rem;
  }
}
#page_top #projectStory .overview .swiperControl .pagination:before {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  right: 0;
  width: 8rem;
  height: 0.1rem;
  background: #fafafa;
  transform: rotate(-45deg);
  transform-origin: top right;
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .overview .swiperControl .pagination:before {
    width: 5.5rem;
  }
}
#page_top #projectStory .overview .swiperControl .pagination span {
  display: block;
  color: #fafafa;
}
#page_top #projectStory .overview .swiperControl .pagination span.swiper-pagination-total {
  text-align: right;
}
#page_top #projectStory .swiperWrap {
  position: absolute;
  bottom: 0;
  left: 54rem;
  z-index: 10;
  overflow: hidden;
  width: 100%;
}
@media screen and (max-width: 1400px) {
  #page_top #projectStory .swiperWrap {
    left: 47rem;
  }
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .swiperWrap {
    position: static;
    margin: 4rem -2rem 0;
    width: auto;
  }
}
#page_top #projectStory .swiperWrap .swiper {
  width: 88rem;
  overflow: visible;
  margin-left: 0;
}
@media screen and (max-width: 1400px) {
  #page_top #projectStory .swiperWrap .swiper {
    width: 80rem;
  }
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .swiperWrap .swiper {
    width: 100%;
  }
}
#page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide {
  display: block;
  position: relative;
  background: #fafafa;
}
#page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt {
  font-family: YakuHanMP, "Shippori Mincho B1", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif, sans-serif;
  letter-spacing: 0.04em;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  padding: 4rem 2rem 1.5rem;
  color: #fafafa;
  background: linear-gradient(0deg, rgba(40, 46, 59, 0.3) 0%, rgba(205, 220, 231, 0) 100%);
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt {
    padding: 4rem 1.5rem 1rem;
  }
}
#page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt span.sub {
  display: block;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt span.sub {
    font-size: 1rem;
  }
}
#page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt em.main {
  font-size: 3rem;
}
@media screen and (max-width: 767px) {
  #page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt em.main {
    font-size: 2rem;
  }
}
#page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:before, #page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:after {
  content: "";
  position: absolute;
  margin: auto;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 4.5rem;
  height: 4.5rem;
}
#page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:before {
  border: 0.1rem solid #fafafa;
  border-radius: 9rem;
}
#page_top #projectStory .swiperWrap .swiper .swiper-wrapper .swiper-slide p.txt:after {
  background: #fafafa;
  -webkit-mask: url("../img/i_arr.svg") no-repeat center;
          mask: url("../img/i_arr.svg") no-repeat center;
  -webkit-mask-size: 1.1rem auto;
          mask-size: 1.1rem auto;
}/*# sourceMappingURL=style.css.map */