@charset "UTF-8";
/* ============================================
  会社案内 共通
============================================ */
#about .p-about__image {
  background-image: url(../media/about/top.png);
  background-repeat: no-repeat;
  background-size: contain;
  aspect-ratio: 1280/486;
  width: 100%;
  height: 37.96875vw;
}

@media screen and (max-width: 767px) {
  #about .p-about__image {
    background-image: url(../media/about/top_sp.png);
    aspect-ratio: 375/383;
    height: 100%;
  }
}
.c-company-menu {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 342px 30px 342px 30px 342px;
  grid-template-columns: repeat(3, 342px);
  -ms-grid-rows: 263px 30px 263px;
  grid-template-rows: repeat(2, 263px);
  gap: 30px;
  margin-top: 200px;
}
.c-company-menu > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.c-company-menu > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
}
.c-company-menu > *:nth-child(3) {
  -ms-grid-row: 1;
  -ms-grid-column: 5;
}
.c-company-menu > *:nth-child(4) {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
}
.c-company-menu > *:nth-child(5) {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
}
.c-company-menu > *:nth-child(6) {
  -ms-grid-row: 3;
  -ms-grid-column: 5;
}
@media screen and (max-width: 1279px) {
  .c-company-menu {
    -ms-grid-columns: 1fr 2.34375vw 1fr 2.34375vw 1fr;
    grid-template-columns: repeat(3, 1fr);
    -ms-grid-rows: 1fr 2.34375vw 1fr;
    grid-template-rows: repeat(2, 1fr);
    gap: 2.34375vw;
    margin-top: 15.625vw;
  }
  .c-company-menu > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .c-company-menu > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .c-company-menu > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 5;
  }
  .c-company-menu > *:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .c-company-menu > *:nth-child(5) {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
  .c-company-menu > *:nth-child(6) {
    -ms-grid-row: 3;
    -ms-grid-column: 5;
  }
}
@media screen and (max-width: 767px) {
  .c-company-menu {
    -ms-grid-columns: 1fr 4.8vw 1fr;
    grid-template-columns: repeat(2, 1fr);
    -ms-grid-rows: 1fr 5.3333333333vw 1fr 5.3333333333vw 1fr;
    grid-template-rows: repeat(3, 1fr);
    gap: 5.3333333333vw 4.8vw;
    margin-top: 26.1333333333vw;
  }
  .c-company-menu > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .c-company-menu > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .c-company-menu > *:nth-child(3) {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .c-company-menu > *:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
  .c-company-menu > *:nth-child(5) {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
  }
  .c-company-menu > *:nth-child(6) {
    -ms-grid-row: 5;
    -ms-grid-column: 3;
  }
}
.c-company-menu__link {
  aspect-ratio: 342/263;
  background-color: #f6f6f6;
  height: auto;
  width: 100%;
}
@media only screen and (min-width: 1280px) {
  .c-company-menu__link {
    position: relative;
  }
  .c-company-menu__link::before {
    background-color: #f6f6f6;
    content: "";
    display: block;
    height: 0;
    left: 0;
    position: absolute;
    bottom: 0;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    width: 100%;
  }
  .c-company-menu__link:hover::before {
    background-color: #A41A55;
    height: 100%;
  }
  .c-company-menu__link:hover .c-company-menu__item {
    color: #f6f6f6;
  }
}
@media screen and (max-width: 767px) {
  .c-company-menu__link {
    width: 41.0666666667vw;
    height: 31.4666666667vw;
    aspect-ratio: 154/118;
  }
}
.c-company-menu__link.c-link-me {
  background-color: #A41A55;
  pointer-events: none;
}
.c-company-menu__link.c-link-me .c-company-menu__item {
  color: white;
}
.c-company-menu__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 30px;
  font-weight: 400;
  text-align: center;
  line-height: 1.33;
  height: 100%;
  -webkit-transform: rotate(0.3deg);
          transform: rotate(0.3deg);
  -webkit-transition: 0.5s color;
  transition: 0.5s color;
  color: #5b5657;
}
@media screen and (max-width: 1279px) {
  .c-company-menu__item {
    font-size: 2.34375vw;
  }
}
@media screen and (max-width: 767px) {
  .c-company-menu__item {
    font-size: 5.234375vw;
    line-height: 1.5;
  }
}

.c-company-list.-founder .c-company-list__wrap {
  display: -ms-grid;
  display: grid;
  border-bottom: #e5e4e4 1px solid;
  -ms-grid-columns: 249px 30px 1fr;
  grid-template-columns: 249px 1fr;
  -webkit-column-gap: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
  padding: 13px 0;
}
@media screen and (max-width: 1279px) {
  .c-company-list.-founder .c-company-list__wrap {
    -ms-grid-columns: 170px 1fr;
    grid-template-columns: 170px 1fr;
  }
}
@media screen and (max-width: 767px) {
  .c-company-list.-founder .c-company-list__wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    row-gap: 1.3333333333vw;
    padding-bottom: 3.4666666667vw;
  }
  .c-company-list.-founder .c-company-list__wrap:has(.c-company-list__name), .c-company-list.-founder .c-company-list__wrap:has(.c-company-list__post) {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 53.0666666667vw 10.9333333333vw 22.9333333333vw;
    grid-template-columns: 53.0666666667vw 22.9333333333vw;
    -webkit-column-gap: 10.9333333333vw;
       -moz-column-gap: 10.9333333333vw;
            column-gap: 10.9333333333vw;
    row-gap: 0;
  }
  .c-company-list.-founder .c-company-list__wrap:has(.c-company-list__name) .c-company-list__heading, .c-company-list.-founder .c-company-list__wrap:has(.c-company-list__post) .c-company-list__heading {
    padding-bottom: 1.6vw;
  }
}
.c-company-list.-founder .c-company-list__wrap:last-child {
  border: none;
}

.c-company-list {
  margin-top: 79px;
}
@media screen and (max-width: 1279px) {
  .c-company-list {
    row-gap: 1.09375vw;
    margin-top: 6.171875vw;
  }
}
@media screen and (max-width: 767px) {
  .c-company-list {
    row-gap: 3.2vw;
    margin-top: 9.6vw;
  }
}
.c-company-list:nth-child(2) {
  margin-top: 39px;
}
@media screen and (max-width: 1279px) {
  .c-company-list:nth-child(2) {
    margin-top: 3.046875vw;
  }
}
@media screen and (max-width: 767px) {
  .c-company-list:nth-child(2) {
    margin-top: 12.5333333333vw;
  }
}
.c-company-list__ttl {
  font-size: 25px;
  line-height: 1.5555555556;
  font-weight: 400;
  color: #5b5657;
}
@media screen and (max-width: 767px) {
  .c-company-list__ttl {
    font-size: 6.6666666667vw;
  }
}
.c-company-list__ttl + .c-company-list__wrap {
  margin-top: 34px;
}
@media screen and (max-width: 767px) {
  .c-company-list__ttl + .c-company-list__wrap {
    margin-top: 0px;
  }
}
.c-company-list__wrap {
  display: -ms-grid;
  display: grid;
  border-bottom: #e5e4e4 1px solid;
  -ms-grid-columns: auto 30px 249px 30px 435px;
  grid-template-columns: auto 249px 435px;
  -webkit-column-gap: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
  padding: 13px 0;
}
@media screen and (max-width: 1279px) {
  .c-company-list__wrap {
    -ms-grid-columns: auto 28.125vw 28.125vw;
    grid-template-columns: auto 28.125vw 28.125vw;
  }
}
@media screen and (max-width: 767px) {
  .c-company-list__wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    row-gap: 1.3333333333vw;
    padding-bottom: 3.4666666667vw;
  }
  .c-company-list__wrap:has(.c-company-list__name), .c-company-list__wrap:has(.c-company-list__post) {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 53.0666666667vw 10.9333333333vw 22.9333333333vw;
    grid-template-columns: 53.0666666667vw 22.9333333333vw;
    -webkit-column-gap: 10.9333333333vw;
       -moz-column-gap: 10.9333333333vw;
            column-gap: 10.9333333333vw;
    row-gap: 0;
  }
  .c-company-list__wrap:has(.c-company-list__name) .c-company-list__heading, .c-company-list__wrap:has(.c-company-list__post) .c-company-list__heading {
    padding-bottom: 1.6vw;
  }
}
.c-company-list__wrap:last-child {
  border: none;
}
.c-company-list__heading {
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  grid-column: 1/2;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.5555555556;
  color: #A41A55;
}
@media screen and (max-width: 767px) {
  .c-company-list__heading {
    font-size: 4.8vw;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    grid-column: 1/3;
  }
}
.c-company-list__post {
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-column: 2/3;
}
@media screen and (max-width: 767px) {
  .c-company-list__post {
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-column: 1/2;
  }
}
.c-company-list__name {
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  grid-column: 3/4;
}
@media screen and (max-width: 767px) {
  .c-company-list__name {
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-column: 2/3;
  }
}
.c-company-list__txt {
  -ms-grid-column: 2;
  -ms-grid-column-span: 2;
  grid-column: 2/4;
}
@media screen and (max-width: 767px) {
  .c-company-list__txt {
    padding-top: 0.5333333333vw;
  }
}
.c-company-list__post, .c-company-list__name, .c-company-list__txt {
  font-size: 18px;
  font-weight: 300;
  line-height: 1.5555555556;
  color: #5b5657;
}
@media screen and (max-width: 767px) {
  .c-company-list__post, .c-company-list__name, .c-company-list__txt {
    font-size: 4.8vw;
  }
}

/* ============================================
  会社案内 - #about
============================================ */
#about #s-about {
  padding-bottom: 200px;
}
@media screen and (max-width: 1279px) {
  #about #s-about {
    padding-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  #about #s-about {
    padding-bottom: 26.6666666667vw;
  }
}
#about #s-about .c-company-menu {
  margin-top: 92px;
}
@media screen and (max-width: 1279px) {
  #about #s-about .c-company-menu {
    margin-top: 7.1875vw;
  }
}
@media screen and (max-width: 767px) {
  #about #s-about .c-company-menu {
    margin-top: 13.3333333333vw;
  }
}
#about #s-about .c-page-ttl {
  margin-top: 42px;
}
@media screen and (max-width: 1279px) {
  #about #s-about .c-page-ttl {
    margin-top: 3.28125vw;
  }
}
@media screen and (max-width: 767px) {
  #about #s-about .c-page-ttl {
    margin-top: 13.828125vw;
  }
}
#about .p-about__cont {
  display: -ms-grid;
  display: grid;
}
#about .p-about__image {
  background-image: url(../media/about/top.png);
  background-repeat: no-repeat;
  background-size: contain;
  aspect-ratio: 1280/486;
  width: 100%;
  height: 37.96875vw;
}
@media screen and (max-width: 767px) {
  #about .p-about__image {
    background-image: url(../media/about/top_sp.png);
    aspect-ratio: 375/383;
    height: 100%;
  }
}

/* ============================================
  ご挨拶 - #presidents-message
============================================ */
#presidents-message #s-presidents-message {
  padding-bottom: 200px;
}
@media screen and (max-width: 1279px) {
  #presidents-message #s-presidents-message {
    padding-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message #s-presidents-message {
    padding-top: 13.8666666667vw;
    padding-bottom: 26.6666666667vw;
  }
}
#presidents-message .p-greeting__cont {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 122px 622px;
  grid-template-columns: auto 622px;
  gap: 0 122px;
  margin-top: 40px;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__cont {
    -ms-grid-columns: auto 9.53125vw 48.59375vw;
    grid-template-columns: auto 48.59375vw;
    gap: 0 9.53125vw;
    margin-top: 3.125vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__cont {
    display: block;
    margin-top: 13.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__cont-inr + .p-greeting__cont-inr {
    margin-top: 13.3333333333vw;
  }
}
#presidents-message .p-greeting__photo img {
  width: 342px;
  height: 448px;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__photo img {
    width: 26.71875vw;
    height: 35vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__photo img {
    width: 64vw;
    height: 83.7333333333vw;
  }
}
#presidents-message .p-greeting__message-txt {
  font-size: 20px;
  line-height: 1.5;
  font-weight: 300;
  color: #5b5657;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__message-txt {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__message-txt {
    font-size: 4.8vw;
    line-height: 1.5555555556;
  }
}
#presidents-message .p-greeting__message-txt + .p-greeting__message-txt {
  margin-top: 30px;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__message-txt + .p-greeting__message-txt {
    margin-top: 2.34375vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__message-txt + .p-greeting__message-txt {
    margin-top: 7.2vw;
  }
}
#presidents-message .p-greeting__sign {
  position: relative;
  left: -8px;
  margin-top: 22px;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__sign {
    left: -0.625vw;
    margin-top: 1.71875vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__sign {
    left: -2.1333333333vw;
    margin-top: 4.2666666667vw;
  }
}
#presidents-message .p-greeting__sign img {
  display: inline-block;
  width: 149px;
  height: 61px;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__sign img {
    width: 11.640625vw;
    height: 4.765625vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__sign img {
    width: 39.7333333333vw;
    height: 16.2666666667vw;
  }
}
#presidents-message .p-greeting__ttl {
  font-size: 25px;
  font-weight: 400;
  line-height: 1.4;
  color: #5b5657;
  margin-top: 98px;
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__ttl {
    font-size: 6.6666666667vw;
    margin-top: 13.3333333333vw;
  }
}
#presidents-message .p-greeting__profile {
  margin-top: 45px;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__profile {
    margin-top: 3.515625vw;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__profile {
    margin-top: 7.7333333333vw;
  }
}
#presidents-message .p-greeting__profile-txt {
  font-size: 20px;
  font-weight: 300;
  line-height: 1.5;
  color: #5b5657;
}
@media screen and (max-width: 1279px) {
  #presidents-message .p-greeting__profile-txt {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  #presidents-message .p-greeting__profile-txt {
    font-size: 4.8vw;
    line-height: 1.5555555556;
  }
}

/* ============================================
  コーポレートメッセージ - #corporate-message
============================================ */
#corporate-message #s-corporate-message {
  padding-bottom: 200px;
}
@media screen and (max-width: 1279px) {
  #corporate-message #s-corporate-message {
    padding-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  #corporate-message #s-corporate-message {
    padding-top: 13.8666666667vw;
    padding-bottom: 26.6666666667vw;
  }
}
#corporate-message .p-corporate__slogan {
  background-color: #f6f6f6;
  margin-top: 41px;
  width: 100%;
  height: 408px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 1279px) {
  #corporate-message .p-corporate__slogan {
    margin-top: 3.203125vw;
    height: 31.875vw;
  }
}
@media screen and (max-width: 767px) {
  #corporate-message .p-corporate__slogan {
    margin-top: 13.3333333333vw;
    height: 108.8vw;
  }
}
#corporate-message .p-corporate__slogan-img {
  display: block;
  width: 528px;
  height: 49px;
}
@media screen and (max-width: 1279px) {
  #corporate-message .p-corporate__slogan-img {
    width: 41.25vw;
    height: 3.828125vw;
  }
}
@media screen and (max-width: 767px) {
  #corporate-message .p-corporate__slogan-img {
    width: 86.9333333333vw;
    height: 8.2666666667vw;
  }
}
#corporate-message .p-corporate__list {
  margin-top: 110px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 30px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 98px 30px;
}
@media screen and (max-width: 1279px) {
  #corporate-message .p-corporate__list {
    margin-top: 8.59375vw;
    gap: 7.65625vw 2.34375vw;
  }
}
@media screen and (max-width: 767px) {
  #corporate-message .p-corporate__list {
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    margin-top: 13.6vw;
    gap: 12.8vw;
  }
}
#corporate-message .p-corporate__img-wrap {
  aspect-ratio: 528/330;
}
#corporate-message .p-corporate__img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
#corporate-message .p-corporate__ttl {
  font-size: 18px;
  font-weight: 400;
  line-height: 1.5555555556;
  color: #5b5657;
  margin-top: 19px;
}
@media screen and (max-width: 767px) {
  #corporate-message .p-corporate__ttl {
    font-size: 4.8vw;
    margin-top: 5.0666666667vw;
  }
}
#corporate-message .p-corporate__txt {
  font-size: 16px;
  font-weight: 300;
  line-height: 1.625;
  color: #5b5657;
  margin-top: 14px;
}
@media screen and (max-width: 767px) {
  #corporate-message .p-corporate__txt {
    font-size: 4.2666666667vw;
    margin-top: 4.2666666667vw;
  }
}

/* ============================================
  企業情報 - #outline
============================================ */
#outline #s-outline {
  padding-bottom: 200px;
}
@media screen and (max-width: 1279px) {
  #outline #s-outline {
    padding-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  #outline #s-outline {
    padding-top: 13.8666666667vw;
    padding-bottom: 26.6666666667vw;
  }
}
#outline .c-btn {
  margin-top: 84px;
}
@media screen and (max-width: 1279px) {
  #outline .c-btn {
    margin-top: 6.5625vw;
  }
}
@media screen and (max-width: 767px) {
  #outline .c-btn {
    margin-top: 13.3333333333vw;
  }
}
#outline .p-outline-link {
  background-color: #f6f6f6;
  width: 1086px;
  height: 100px;
  margin-top: 84px;
}
@media screen and (max-width: 1279px) {
  #outline .p-outline-link {
    display: block;
    width: 84.84375vw;
    height: 7.8125vw;
    margin-top: 6.5625vw;
  }
}
@media screen and (max-width: 767px) {
  #outline .p-outline-link {
    width: 86.9333333333vw;
    height: 26.6666666667vw;
    margin-top: 9.8666666667vw;
  }
}
#outline .p-outline-link__txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  line-height: 1.4;
  height: 100%;
  -webkit-transform: rotate(0.3deg);
          transform: rotate(0.3deg);
}
@media screen and (max-width: 1279px) {
  #outline .p-outline-link__txt {
    font-size: 1.953125vw;
  }
}
@media screen and (max-width: 767px) {
  #outline .p-outline-link__txt {
    font-size: 6.6666666667vw;
  }
}
#outline .p-icon__link1 {
  display: inline-block;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-image: url("../media/icon/icon-file.svg");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 1279px) {
  #outline .p-icon__link1 {
    width: 2.5vw;
    height: 2.5vw;
  }
}
@media screen and (max-width: 767px) {
  #outline .p-icon__link1 {
    width: 8.5333333333vw;
    height: 8.5333333333vw;
  }
}
@media screen and (min-width: 1280px) {
  #outline .p-icon__link1:hover {
    background-image: url("../media/icon/icon-file-hover.svg");
    background-color: #A41A55;
    cursor: pointer;
  }
}
#outline *:has(> .p-icon__link1) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 1279px) {
  #outline *:has(> .p-icon__link1) {
    -webkit-column-gap: 0.78125vw;
       -moz-column-gap: 0.78125vw;
            column-gap: 0.78125vw;
  }
}
@media screen and (max-width: 767px) {
  #outline *:has(> .p-icon__link1) {
    -webkit-column-gap: 2.6666666667vw;
       -moz-column-gap: 2.6666666667vw;
            column-gap: 2.6666666667vw;
  }
}

/* ============================================
  業務内容 - #services
============================================ */
#services #s-services {
  padding-bottom: 200px;
}
@media screen and (max-width: 1279px) {
  #services #s-services {
    padding-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  #services #s-services {
    padding-top: 13.8666666667vw;
    padding-bottom: 26.6666666667vw;
  }
}

/* ============================================
  創業者 安井武雄 - #founder
============================================ */
#founder #s-founder {
  padding-bottom: 200px;
}
@media screen and (max-width: 1279px) {
  #founder #s-founder {
    padding-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  #founder #s-founder {
    padding-top: 13.8666666667vw;
    padding-bottom: 26.6666666667vw;
  }
}

/* ============================================
  CSR - #csr
============================================ */
#csr #s-csr {
  padding-bottom: 200px;
}
@media screen and (max-width: 1279px) {
  #csr #s-csr {
    padding-bottom: 15.625vw;
  }
}
@media screen and (max-width: 767px) {
  #csr #s-csr {
    padding-top: 13.8666666667vw;
    padding-bottom: 26.6666666667vw;
  }
}

/* ============================================
  コンポーネント
============================================ */
.p-about-column {
  margin-top: 41px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 714px;
  grid-template-columns: 1fr 714px;
}
@media screen and (max-width: 1279px) {
  .p-about-column {
    margin-top: 3.203125vw;
    -ms-grid-columns: 1fr 55.78125vw;
    grid-template-columns: 1fr 55.78125vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column {
    display: block;
    margin-top: 11.2vw;
  }
}
.p-about-column .c-img {
  position: relative;
}
@media only screen and (max-width: 767px) {
  .p-about-column .c-img.--name {
    padding-bottom: 19.7333333333vw;
  }
}
.p-about-column .c-img.--name .c-img__txt {
  bottom: -2px;
  left: 39%;
  font-size: 1.40625vw;
  font-weight: 500;
  line-height: 1.5555555556;
}
@media only screen and (max-width: 767px) {
  .p-about-column .c-img.--name .c-img__txt {
    left: 0;
    font-size: 4.8vw;
  }
}
.p-about-column .c-img__txt {
  position: absolute;
  color: #A41A55;
}
.p-about-column .c-img + .c-txt {
  margin-top: 19px;
}
@media screen and (max-width: 1279px) {
  .p-about-column .c-img + .c-txt {
    margin-top: 1.484375vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column .c-img + .c-txt {
    margin-top: 5.0666666667vw;
  }
}
.p-about-column .c-sub-ttl + .c-txt {
  margin-top: 19px;
}
@media screen and (max-width: 1279px) {
  .p-about-column .c-sub-ttl + .c-txt {
    margin-top: 1.484375vw;
  }
}
.p-about-column .c-txt__txt {
  line-height: 1.5555555556;
}
.p-about-column .c-txt + .c-sub-ttl {
  margin-top: 48px;
}
@media screen and (max-width: 1279px) {
  .p-about-column .c-txt + .c-sub-ttl {
    margin-top: 3.75vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column .c-txt + .c-sub-ttl {
    margin-top: 10.1333333333vw;
  }
}
.p-about-column .c-txt + .c-txt {
  margin-top: 47px;
}
@media screen and (max-width: 1279px) {
  .p-about-column .c-txt + .c-txt {
    margin-top: 3.671875vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column .c-txt + .c-txt {
    margin-top: 12.5333333333vw;
  }
}
.p-about-column .c-txt + .c-btn-wrap,
.p-about-column .c-txt + .c-btn {
  margin-top: 19px;
}
@media screen and (max-width: 1279px) {
  .p-about-column .c-txt + .c-btn-wrap,
  .p-about-column .c-txt + .c-btn {
    margin-top: 1.484375vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column .c-txt + .c-btn-wrap,
  .p-about-column .c-txt + .c-btn {
    margin-top: 5.0666666667vw;
  }
}
.p-about-column .c-btn-wrap + .c-sub-ttl,
.p-about-column .c-btn + .c-sub-ttl {
  margin-top: 49px;
}
@media screen and (max-width: 1279px) {
  .p-about-column .c-btn-wrap + .c-sub-ttl,
  .p-about-column .c-btn + .c-sub-ttl {
    margin-top: 3.828125vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column .c-btn-wrap + .c-sub-ttl,
  .p-about-column .c-btn + .c-sub-ttl {
    margin-top: 10.4vw;
  }
}
.p-about-column .c-btn-wrap + .c-txt,
.p-about-column .c-btn + .c-txt {
  margin-top: 49px;
}
@media screen and (max-width: 1279px) {
  .p-about-column .c-btn-wrap + .c-txt,
  .p-about-column .c-btn + .c-txt {
    margin-top: 3.828125vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column .c-btn-wrap + .c-txt,
  .p-about-column .c-btn + .c-txt {
    margin-top: 13.0666666667vw;
  }
}
.p-about-column__sp-trigger {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-about-column__sp-trigger {
    display: block;
    font-size: 4.8vw;
    font-weight: 400;
    line-height: 1.5555555556;
    color: #5b5657;
    background-color: #f6f6f6;
    border-radius: 2.6666666667vw;
    min-height: 12vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0.8vw 10.6666666667vw 1.0666666667vw 5.6vw;
    cursor: pointer;
    -webkit-transition: 0.5s color, 0.5s background-color;
    transition: 0.5s color, 0.5s background-color;
    position: relative;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column__sp-trigger + .p-about-column__sp-trigger {
    margin-top: 10px;
  }
}
.p-about-column__sp-trigger:before {
  content: "";
  width: 2.4vw;
  height: 2.4vw;
  position: absolute;
  top: calc(50% - 0.5333333333vw);
  right: 5.3333333333vw;
  display: block;
  border-bottom: 1px solid #5b5657;
  border-right: 1px solid #5b5657;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.p-about-column__sp-trigger.-active {
  color: #ffffff;
  background-color: #5b5657;
}
.p-about-column__sp-trigger.-active:before {
  content: "";
  width: 2.4vw;
  height: 2.4vw;
  position: absolute;
  top: calc(50% + 0.5333333333vw);
  right: 5.3333333333vw;
  display: block;
  border-top: 1px solid #f6f6f6;
  border-left: 1px solid #f6f6f6;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
@media screen and (max-width: 767px) {
  .p-about-column__sp-trigger + .p-about-column__cont {
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column__inr.-side {
    display: none;
  }
}
.p-about-column__cont {
  margin-top: 100px;
}
@media screen and (max-width: 1279px) {
  .p-about-column__cont {
    margin-top: 7.65625vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column__cont {
    margin-top: 0;
    display: none;
    margin-bottom: 40px;
  }
}
.p-about-column__cont#csr-link_01 {
  margin-top: 0px;
}
@media screen and (max-width: 767px) {
  .p-about-column__cont#csr-link_01 {
    margin-top: 10.6666666667vw;
  }
}
.p-about-column__cont#founder-link_01 {
  margin-top: 0px;
}
@media screen and (max-width: 767px) {
  .p-about-column__cont#founder-link_01 {
    margin-top: 10.6666666667vw;
  }
}
.p-about-column__img-txt {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 156px 30px 1fr;
  grid-template-columns: 156px 1fr;
  gap: 30px;
}
@media screen and (max-width: 1279px) {
  .p-about-column__img-txt {
    -ms-grid-columns: 12.1875vw 2.34375vw 1fr;
    grid-template-columns: 12.1875vw 1fr;
    gap: 2.34375vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column__img-txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 5.3333333333vw;
    margin-top: 20px;
  }
}
.p-about-column__img-txt .c-img {
  padding-top: 20px;
}
@media screen and (max-width: 1279px) {
  .p-about-column__img-txt .c-img {
    padding-top: 1.5625vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column__img-txt .c-img {
    padding-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column__img-txt .c-img + .c-txt {
    margin-top: 0px;
  }
}
.p-about-column__img-txt + .c-btn-wrap,
.p-about-column__img-txt + .c-btn {
  margin-top: 20px;
}
@media screen and (max-width: 1279px) {
  .p-about-column__img-txt + .c-btn-wrap,
  .p-about-column__img-txt + .c-btn {
    margin-top: 1.5625vw;
  }
}
@media screen and (max-width: 767px) {
  .p-about-column__img-txt + .c-btn-wrap,
  .p-about-column__img-txt + .c-btn {
    margin-top: 5.3333333333vw;
  }
}

.c-side-list {
  position: sticky;
  top: 132px;
  padding-right: 1em;
}
@media screen and (max-width: 767px) {
  .c-side-list {
    padding-right: 0;
  }
}
.c-side-list__item + .c-side-list__item {
  margin-top: 10px;
}
.c-side-list__link {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.625;
  color: #5b5657;
  background-color: #f6f6f6;
  border-radius: 10px;
  padding: 6px 15px;
  -webkit-transition: 0.5s background-color;
  transition: 0.5s background-color;
  display: inline-block;
}
.c-side-list__link.-active {
  background-color: #5b5657;
  color: #ffffff;
}
.c-side-list__link:hover {
  background-color: #e5e4e4;
}

.c-flexImg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .c-flexImg {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
@media screen and (max-width: 767px) {
  .c-flexImg__imgWrap {
    width: 100% !important;
  }
  .c-flexImg__imgWrap + .c-flexImg__imgWrap {
    margin-bottom: 5.3333333333vw;
  }
}
.c-flexImg__imgWrap.--tokyo01 {
  width: 34.8739495798%;
}
.c-flexImg__imgWrap.--tokyo02 {
  width: 61.2044817927%;
}
.c-flexImg__imgWrap.--kataoka01 {
  width: 60.9243697479%;
}
.c-flexImg__imgWrap.--kataoka02 {
  width: 35.1540616246%;
}
.c-flexImg__imgWrap.--nomura01 {
  width: 34.8739495798%;
}
.c-flexImg__imgWrap.--nomura02 {
  width: 60.9243697479%;
}
.c-flexImg__imgWrap.--yasui01 {
  width: 47.8991596639%;
}
.c-flexImg__imgWrap.--yasui02 {
  width: 48.1792717087%;
}
.c-flexImg__imgWrap.--era01 {
  width: 47.8991596639%;
}
.c-flexImg__imgWrap.--era02 {
  width: 47.8991596639%;
}
.c-flexImg__imgWrap.--osaka01 {
  width: 60.9243697479%;
}
.c-flexImg__imgWrap.--osaka02 {
  width: 34.8739495798%;
}
.c-flexImg__imgWrap.--yamaguchi01 {
  width: 34.8739495798%;
}
.c-flexImg__imgWrap.--yamaguchi02 {
  width: 60.9243697479%;
}
.c-flexImg__imgWrap.--yasuitei01 {
  width: 60.9243697479%;
}
.c-flexImg__imgWrap.--yasuitei02 {
  width: 34.8739495798%;
}

.p-csr-cont h2,
.p-csr-cont h3,
.p-csr-cont h4,
.p-founder-cont h2,
.p-founder-cont h3,
.p-founder-cont h4 {
  font-weight: 400;
  line-height: 1.4;
  font-size: 25px;
}
@media screen and (max-width: 1279px) {
  .p-csr-cont h2,
  .p-csr-cont h3,
  .p-csr-cont h4,
  .p-founder-cont h2,
  .p-founder-cont h3,
  .p-founder-cont h4 {
    font-size: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-csr-cont h2,
  .p-csr-cont h3,
  .p-csr-cont h4,
  .p-founder-cont h2,
  .p-founder-cont h3,
  .p-founder-cont h4 {
    font-size: 6.6666666667vw;
    line-height: 1.4;
  }
}
.p-csr-cont h2 + p,
.p-csr-cont h3 + p,
.p-csr-cont h4 + p,
.p-founder-cont h2 + p,
.p-founder-cont h3 + p,
.p-founder-cont h4 + p {
  margin-top: 19px;
}
@media screen and (max-width: 1279px) {
  .p-csr-cont h2 + p,
  .p-csr-cont h3 + p,
  .p-csr-cont h4 + p,
  .p-founder-cont h2 + p,
  .p-founder-cont h3 + p,
  .p-founder-cont h4 + p {
    margin-top: 1.484375vw;
  }
}
@media screen and (max-width: 767px) {
  .p-csr-cont h2 + p,
  .p-csr-cont h3 + p,
  .p-csr-cont h4 + p,
  .p-founder-cont h2 + p,
  .p-founder-cont h3 + p,
  .p-founder-cont h4 + p {
    margin-top: 5.0666666667vw;
  }
}
.p-csr-cont figure img,
.p-founder-cont figure img {
  width: 100%;
}
.p-csr-cont p,
.p-founder-cont p {
  font-weight: 400;
  line-height: 1.5;
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-csr-cont p,
  .p-founder-cont p {
    font-size: 4.8vw;
  }
}
.p-csr-cont p + h2,
.p-csr-cont p + h3,
.p-csr-cont p + h4,
.p-founder-cont p + h2,
.p-founder-cont p + h3,
.p-founder-cont p + h4 {
  margin-top: 48px;
}
@media screen and (max-width: 1279px) {
  .p-csr-cont p + h2,
  .p-csr-cont p + h3,
  .p-csr-cont p + h4,
  .p-founder-cont p + h2,
  .p-founder-cont p + h3,
  .p-founder-cont p + h4 {
    margin-top: 3.75vw;
  }
}
@media screen and (max-width: 767px) {
  .p-csr-cont p + h2,
  .p-csr-cont p + h3,
  .p-csr-cont p + h4,
  .p-founder-cont p + h2,
  .p-founder-cont p + h3,
  .p-founder-cont p + h4 {
    margin-top: 10.1333333333vw;
  }
}
.p-csr-cont p + div,
.p-csr-cont p + a,
.p-founder-cont p + div,
.p-founder-cont p + a {
  margin-top: 19px;
}
@media screen and (max-width: 1279px) {
  .p-csr-cont p + div,
  .p-csr-cont p + a,
  .p-founder-cont p + div,
  .p-founder-cont p + a {
    margin-top: 1.484375vw;
  }
}
@media screen and (max-width: 767px) {
  .p-csr-cont p + div,
  .p-csr-cont p + a,
  .p-founder-cont p + div,
  .p-founder-cont p + a {
    margin-top: 5.0666666667vw;
  }
}
.p-csr-cont a,
.p-founder-cont a {
  width: 100%;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #ffffff;
  color: #5b5657;
  min-height: 100px;
  font-size: 25px;
  padding: 5px 10px 6px;
  -webkit-transition: 0.5s background-color, 0.5s color, 0.5s border;
  transition: 0.5s background-color, 0.5s color, 0.5s border;
  min-height: 50px;
  font-size: 18px;
  line-height: 1.5555555556;
  font-weight: 400;
  margin-top: 19px;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  outline: none;
  background-color: #f6f6f6;
  border: none;
  color: #5b5657;
  position: relative;
}
@media screen and (max-width: 1279px) {
  .p-csr-cont a,
  .p-founder-cont a {
    margin-top: 1.484375vw;
  }
}
@media screen and (max-width: 767px) {
  .p-csr-cont a,
  .p-founder-cont a {
    min-height: 26.6666666667vw;
    font-size: 6.6666666667vw;
    padding: 1.3333333333vw 2.6666666667vw 1.6vw;
    margin-top: 5.0666666667vw;
  }
}
.p-csr-cont a::before,
.p-founder-cont a::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  background-color: #A41A55;
  width: 100%;
  height: 0;
  -webkit-transition: 0.3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transition: 0.3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
}
@media screen and (min-width: 1280px) {
  .p-csr-cont a:hover,
  .p-founder-cont a:hover {
    color: #f6f6f6;
    background-color: transparent;
  }
  .p-csr-cont a::before,
  .p-founder-cont a::before {
    background-color: #ffffff;
    content: "";
    display: block;
    height: 0;
    left: 0;
    position: absolute;
    bottom: 0;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    width: 100%;
    z-index: -1;
  }
  .p-csr-cont a:hover::before,
  .p-founder-cont a:hover::before {
    background-color: #A41A55;
    height: 100%;
  }
}
.p-csr-cont dl + h2,
.p-csr-cont dl + h3,
.p-csr-cont dl + h4,
.p-founder-cont dl + h2,
.p-founder-cont dl + h3,
.p-founder-cont dl + h4 {
  margin-top: 49px;
}
@media screen and (max-width: 1279px) {
  .p-csr-cont dl + h2,
  .p-csr-cont dl + h3,
  .p-csr-cont dl + h4,
  .p-founder-cont dl + h2,
  .p-founder-cont dl + h3,
  .p-founder-cont dl + h4 {
    margin-top: 3.828125vw;
  }
}
@media screen and (max-width: 767px) {
  .p-csr-cont dl + h2,
  .p-csr-cont dl + h3,
  .p-csr-cont dl + h4,
  .p-founder-cont dl + h2,
  .p-founder-cont dl + h3,
  .p-founder-cont dl + h4 {
    margin-top: 10.4vw;
  }
}
.p-csr-cont dt,
.p-founder-cont dt {
  margin-top: 19px;
  color: #A41A55;
  font-weight: 500;
}
@media screen and (max-width: 1279px) {
  .p-csr-cont dt,
  .p-founder-cont dt {
    margin-top: 1.484375vw;
  }
}
@media screen and (max-width: 767px) {
  .p-csr-cont dt,
  .p-founder-cont dt {
    margin-top: 5.0666666667vw;
  }
}
.p-csr-cont dd img,
.p-founder-cont dd img {
  width: auto;
}
.p-csr-cont .cmn_spNone,
.p-founder-cont .cmn_spNone {
  display: block !important;
}