@charset "UTF-8";
/* トップページ */
h2.section_ttl {
  text-align: center;
  padding-left: 0;
  letter-spacing: 0.06em;
}
@media screen and (width <= 767px) {
  h2.section_ttl {
    margin-bottom: 3rem;
    font-size: 2.8rem;
  }
}
@media screen and (width > 767px), print {
  h2.section_ttl {
    margin-bottom: 4rem;
    font-size: 4rem;
  }
}
h2.section_ttl::before {
  content: none;
}

@media screen and (width <= 767px) {
  .btn_wrap.-center {
    margin-top: 3rem;
  }
}
@media screen and (width > 767px), print {
  .btn_wrap.-center {
    margin-top: 4rem;
  }
}
.btn_wrap.-center .btn {
  padding: 1.1rem 6rem;
  background-color: var(--white);
  border-width: 0.3rem;
  font-size: 1.6rem;
}

.top_mv .splide {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  background-position: top center;
  background-size: 100% auto;
  background-repeat: no-repeat;
  overflow: hidden;
}
@media screen and (width <= 767px) {
  .top_mv .splide {
    padding: 3rem 0 3.2rem 2rem;
    background-image: url(../images/top/mv_bg_sp.jpg);
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide {
    padding-block: 2.5rem 3rem;
    background-image: url(../images/top/mv_bg_pc.jpg);
  }
}
.top_mv .splide__list {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (width <= 767px) {
  .top_mv .splide__list {
    margin-right: -2rem !important;
  }
}
.top_mv .splide__slide {
  width: 93%;
  position: relative;
}
.top_mv .splide__slide.is-active .slide_inner {
  -webkit-transform: scale(1);
          transform: scale(1);
}
.top_mv .splide__slide.is-active .slide_inner video {
  -webkit-filter: none;
          filter: none;
}
.top_mv .splide__slide .slide_txt {
  z-index: 1;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
@media screen and (width <= 767px) {
  .top_mv .splide__slide .slide_txt {
    height: 8rem;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__slide .slide_txt {
    position: absolute;
    left: 7.25%;
    bottom: 6rem;
  }
}
.top_mv .splide__slide .slide_txt[data-is-active=false] {
  opacity: 0;
}
.top_mv .splide__slide .slide_txt p {
  margin-top: 0;
  color: var(--white);
  font-family: var(--font-serif);
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (width <= 767px) {
  .top_mv .splide__slide .slide_txt p {
    text-shadow: 0 0 1rem #000;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__slide .slide_txt p {
    text-shadow: 0 0 2rem #000;
  }
}
@media screen and (width <= 767px) {
  .top_mv .splide__slide .slide_txt p.-main {
    font-size: 2.4rem;
  }
    .top_mv .splide__slide .slide_txt p.-right {
    text-align: right;
    margin-right: 48%;
  }

}
@media screen and (width > 767px), print {
  .top_mv .splide__slide .slide_txt p.-main {
    font-size: 4.2rem;
  }
}
@media screen and (width <= 767px) {
  .top_mv .splide__slide .slide_txt p.-en {
    font-size: 1.3rem;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__slide .slide_txt p.-en {
    font-size: 2.3rem;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__slide .slide_txt p.-right {
    text-align: right;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__slide .slide_txt.-first {
    top: 4rem;
    left: 10.48%;
    bottom: auto;
  }
}
@media screen and (width <= 767px) {
  .top_mv .splide__slide .slide_txt.-first .-main {
    font-size: 2.7rem;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__slide .slide_txt.-first .-main {
    font-size: 4.7rem;
  }
}
.top_mv .splide .slide_inner {
  clip-path: polygon(7.66% 0%, 100% 0%, 92.34% 100%, 0 100%);
  position: relative;
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
}
@media screen and (width <= 767px) {
  .top_mv .splide .slide_inner {
    aspect-ratio: 382.88/216.31;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide .slide_inner {
    aspect-ratio: 1240/500;
  }
}
.top_mv .splide .slide_inner video {
  -webkit-filter: grayscale(80%);
          filter: grayscale(80%);
}
.top_mv .splide video {
  width: 100%;
  height: auto;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.top_mv .splide__pagination {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (width <= 767px) {
  .top_mv .splide__pagination {
    padding-inline: 2rem;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__pagination {
    padding-right: 8.3rem;
  }
}
.top_mv .splide__pagination__page {
  background-color: var(--gray-e0);
  height: 0.3rem;
  border-radius: 0;
}
@media screen and (width <= 767px) {
  .top_mv .splide__pagination__page {
    width: 1.2rem;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__pagination__page {
    width: 2rem;
  }
}
.top_mv .splide__pagination__page.is-active {
  background-color: var(--main-color);
  -webkit-transform: none;
          transform: none;
}
@media screen and (width <= 767px) {
  .top_mv .splide__pagination__page.is-active {
    width: 2.7rem;
  }
}
@media screen and (width > 767px), print {
  .top_mv .splide__pagination__page.is-active {
    width: 4.5rem;
  }
}

@media screen and (width <= 767px) {
  .top_lead {
    margin-top: 1.5rem;
    line-height: 1.625;
  }
}
@media screen and (width > 767px), print {
  .top_lead {
    margin-top: 2rem;
    text-align: center;
    font-size: 1.8rem;
    line-height: 2.1111111111;
  }
}

#reason {
  position: relative;
}
@media screen and (width <= 767px) {
  #reason {
    margin-top: 4rem;
  }
}
@media screen and (width > 767px), print {
  #reason {
    margin-top: 5rem;
  }
}
#reason .reason_img {
  position: relative;
}
@media screen and (width <= 767px) {
  #reason .reason_img {
    height: 10.5rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_img {
    height: 22rem;
  }
}
#reason .reason_img::before {
  content: "";
  display: block;
  height: 100%;
  background-image: url(../images/top/reason_img01.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: right bottom;
  position: absolute;
  top: 0;
}
@media screen and (width <= 767px) {
  #reason .reason_img::before {
    width: calc(100% + 2rem);
    right: 0;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_img::before {
    width: calc(50vw + 50% - 14rem);
    right: 14rem;
  }
}
#reason .reason_content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: relative;
}
@media screen and (width <= 767px) {
  #reason .reason_content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 3rem;
    padding-bottom: 4rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_content {
    gap: 6rem;
    padding: 0 5rem 7rem;
  }
}
#reason .reason_content h2 {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background-color: var(--dark-blue);
  color: var(--white);
  font-weight: 500;
  letter-spacing: 0.2em;
}
@media screen and (width <= 767px) {
  #reason .reason_content h2 {
    margin: 2rem 0 0 0;
    padding: 2.2rem 2rem;
    font-size: 2.2rem;
    line-height: 1.3;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_content h2 {
    margin: -6.9rem 0 0 0;
    padding: 4rem 3.6rem 4rem 4.4rem;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    font-size: 3.2rem;
    line-height: 1;
    white-space: pre;
  }
}
#reason .reason_content h2 span {
  display: block;
  font-family: var(--font-en);
  letter-spacing: 0;
}
@media screen and (width <= 767px) {
  #reason .reason_content h2 span {
    font-size: 1.4rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_content h2 span {
    margin-top: 0.4rem;
    margin-left: 1.4rem;
    font-size: 1.7rem;
  }
}
#reason .reason_content h2::before {
  content: none;
}
@media screen and (width > 767px), print {
  #reason .reason_list {
    padding-top: 5rem;
  }
}
#reason .reason_list > li {
  background-color: var(--white);
  border-bottom: 0.1rem solid var(--table-border);
}
#reason .reason_list > li:first-of-type {
  border-top: 0.1rem solid var(--table-border);
}
#reason .reason_list > li a {
  --hover-color: var(--light-gray);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, var(--hover-color)), color-stop(50%, transparent));
  background-image: linear-gradient(to right, var(--hover-color) 50%, transparent 50%);
  background-position: 100%;
  background-size: 300%;
  -webkit-transition: background-position 0.6s;
  transition: background-position 0.6s;
}
@media screen and (width <= 767px) {
  #reason .reason_list > li a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.5rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_list > li a {
    gap: 3rem;
  }
}
#reason .reason_list > li a::after {
  content: "→";
  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;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background-color: var(--dark-navy);
  color: var(--white);
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
}
@media screen and (width <= 767px) {
  #reason .reason_list > li a::after {
    width: 3.5rem;
    height: 3.5rem;
    font-size: 2rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_list > li a::after {
    width: 4rem;
    height: 4rem;
    font-size: 2.3rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_list > li a:hover {
    background-position: 0;
  }
  #reason .reason_list > li a:hover::after {
    background-color: var(--main-color);
  }
}
#reason .reason_list > li .reason_list_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (width <= 767px) {
  #reason .reason_list > li .reason_list_inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.1rem;
  }
}
#reason .reason_list > li .reason_list_inner h3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0;
  color: var(--ttl-black);
  font-family: var(--font-serif);
  font-weight: 500;
  line-height: 1;
}
@media screen and (width <= 767px) {
  #reason .reason_list > li .reason_list_inner h3 {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 0.6rem;
    margin: 2.2rem 0 0 1rem;
    font-size: 2.4rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_list > li .reason_list_inner h3 {
    min-width: 22rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-inline: 2rem;
    font-size: 3.7rem;
  }
}
#reason .reason_list > li .reason_list_inner h3 span {
  display: block;
  color: var(--main-color);
  font-family: var(--font-en);
  font-size: 1.4rem;
}
@media screen and (width > 767px), print {
  #reason .reason_list > li .reason_list_inner h3 span {
    margin-top: 1.8rem;
  }
}
#reason .reason_list > li .reason_list_inner p {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  line-height: 1.75;
}
@media screen and (width <= 767px) {
  #reason .reason_list > li .reason_list_inner p {
    padding-inline: 1rem;
    font-size: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #reason .reason_list > li .reason_list_inner p {
    padding-block: 3rem;
  }
}

#products {
  margin-top: 0;
  background-image: url(../images/top/products_bg_pc.jpg);
  background-size: max(1320px, 100%) auto;
  background-repeat: no-repeat;
  background-position: top center;
  position: relative;
}
#products::after {
  content: "";
  display: block;
  width: 100%;
  height: 44rem;
  background-image: -webkit-gradient(linear, left top, left bottom, from(transparent), to(var(--white)));
  background-image: linear-gradient(to bottom, transparent, var(--white));
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 0;
}
@media screen and (width <= 767px) {
  #products {
    padding-block: 4rem 3rem;
  }
}
@media screen and (width > 767px), print {
  #products {
    padding-block: 6rem 4rem;
  }
}
#products .container {
  position: relative;
  z-index: 1;
}
#products .container.-s {
  position: relative;
  z-index: 1;
}
#products h3 {
  color: var(--ttl-black);
  font-weight: 700;
  line-height: 1.4;
  position: relative;
}
@media screen and (width <= 767px) {
  #products h3 {
    margin-bottom: 1.5rem;
    padding-left: 1.5rem;
    font-size: 2rem;
  }
}
@media screen and (width > 767px), print {
  #products h3 {
    margin-top: 7rem;
    margin-bottom: 2rem;
    padding-left: 2rem;
    font-size: 2.8rem;
  }
}
#products h3::before {
  content: "";
  display: block;
  width: 0.6rem;
  background-color: var(--ttl-blue);
  position: absolute;
  left: 0;
}
@media screen and (width <= 767px) {
  #products h3::before {
    height: 3rem;
    top: 0;
  }
}
@media screen and (width > 767px), print {
  #products h3::before {
    height: 3.4rem;
    top: 0.5rem;
  }
}
@media screen and (width <= 767px) {
  #products .column2 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 3rem;
  }
}
@media screen and (width > 767px), print {
  #products .column2 {
    gap: 0;
  }
}
#products .products_category {
  position: relative;
}
@media screen and (width <= 767px) {
  #products .products_category {
    width: 100%;
    padding: 7.2rem 8.3rem 8.9rem 9.3rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_category {
    width: 50%;
    padding: 11.9rem 13rem 14.7rem 13.5rem;
  }
}
#products .products_category_list > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
  will-change: transform;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
@media screen and (width > 767px), print {
  #products .products_category_list > li {
    cursor: pointer;
  }
}
#products .products_category_list > li p {
  margin-top: 0;
  text-align: center;
  color: var(--gray-8);
  font-weight: 500;
  line-height: 1.4;
  white-space: nowrap;
  -webkit-transition: color 0.2s;
  transition: color 0.2s;
  will-change: color;
}
@media screen and (width <= 767px) {
  #products .products_category_list > li p {
    font-size: 1.2rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_category_list > li p {
    font-size: 1.7rem;
  }
}
#products .products_category_list > li img {
  -webkit-transition: -webkit-filter 0.4s;
  transition: -webkit-filter 0.4s;
  transition: filter 0.4s;
  transition: filter 0.4s, -webkit-filter 0.4s;
  will-change: filter;
}
@media screen and (width <= 767px) {
  #products .products_category_list > li[data-category=probe] {
    width: 10.4rem;
    top: 0;
    left: 13.1rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_category_list > li[data-category=probe] {
    width: 32.72%;
    top: 1.5rem;
    right: 31.6%;
  }
}
#products .products_category_list > li[data-category=probe_cards] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}
@media screen and (width <= 767px) {
  #products .products_category_list > li[data-category=probe_cards] {
    width: 8.5rem;
    left: 4rem;
    bottom: 2.3rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_category_list > li[data-category=probe_cards] {
    width: 25.63%;
    left: 8.5%;
    bottom: 4rem;
  }
}
#products .products_category_list > li[data-category=ic_sockets] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}
@media screen and (width <= 767px) {
  #products .products_category_list > li[data-category=ic_sockets] {
    width: 6.4rem;
    right: 4.8rem;
    bottom: 1.8rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_category_list > li[data-category=ic_sockets] {
    width: 19.09%;
    right: 13.27%;
    bottom: 3rem;
  }
}
#products .products_category_list > li[data-category=test_fixtures] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  bottom: 0;
}
@media screen and (width <= 767px) {
  #products .products_category_list > li[data-category=test_fixtures] {
    width: 5.2rem;
    left: 14.9rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_category_list > li[data-category=test_fixtures] {
    width: 15.63%;
    left: 41.45%;
  }
}
#products .products_category_list > li[data-open=true] {
  -webkit-transform: scale(1.24);
          transform: scale(1.24);
}
#products .products_category_list > li[data-open=true] p {
  color: var(--dark-blue);
  font-weight: 700;
}
#products .products_details {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.5rem;
}
@media screen and (width <= 767px) {
  #products .products_details {
    width: 100%;
  }
}
@media screen and (width > 767px), print {
  #products .products_details {
    width: 50%;
    padding-left: 2rem;
  }
}
#products .details {
  width: 100%;
  -webkit-box-shadow: 0 0 3rem rgba(0, 0, 0, 0.16);
          box-shadow: 0 0 3rem rgba(0, 0, 0, 0.16);
}
#products .details .details_summary {
  display: block;
  background-color: var(--white);
  color: var(--dark-blue);
  font-weight: 700;
  line-height: 1.4583333333;
  -webkit-transition: background-color 0.4s, color 0.4s;
  transition: background-color 0.4s, color 0.4s;
  position: relative;
}
@media screen and (width <= 767px) {
  #products .details .details_summary {
    padding: 1.2rem 4.8rem 1.2rem 2rem;
    font-size: 1.7rem;
  }
}
@media screen and (width > 767px), print {
  #products .details .details_summary {
    padding: 1rem 4.8rem 1rem 2.5rem;
    font-size: 2rem;
    cursor: pointer;
  }
}
#products .details .details_summary::after {
  content: "";
  display: block;
  width: 1.8rem;
  height: 1rem;
  background-color: var(--dark-blue);
  -webkit-mask-image: url(../images/top/arw_down.png);
          mask-image: url(../images/top/arw_down.png);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  position: absolute;
  top: 50%;
  right: 2rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
#products .details .details_summary h3 {
  margin: 0;
  padding-left: 0;
  color: inherit;
  font-size: inherit;
}
#products .details .details_summary h3::before {
  content: none;
}
#products .details .details_content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  background-color: var(--white);
}
@media screen and (width <= 767px) {
  #products .details .details_content {
    gap: 0.5rem;
    padding: 1.2rem 1.5rem 1.5rem;
    font-size: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #products .details .details_content {
    gap: 0.5rem;
    padding: 1rem 2.5rem 1.5rem;
  }
}
#products .details .details_content > *:first-child {
  margin-top: 0;
}
#products .details .details_content a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: auto;
  gap: 0.9rem;
  color: var(--dark-blue);
  line-height: 1.5rem;
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
#products .details .details_content a::after {
  content: "";
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  margin-top: 0.3rem;
  border-top: 0.2rem solid currentColor;
  border-right: 0.2rem solid currentColor;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (width > 767px), print {
  #products .details .details_content a:hover {
    color: var(--main-color);
  }
}
#products .details[open] .details_summary {
  background-color: var(--dark-blue);
  color: var(--white);
}
#products .details[open] .details_summary::after {
  background-color: var(--white);
  -webkit-transform: translateY(-50%) rotate(180deg);
          transform: translateY(-50%) rotate(180deg);
}
#products .products_field {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (width <= 767px) {
  #products .products_field {
    margin-top: 2rem;
    gap: 1.5rem 2rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field {
    margin-top: 4rem;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (width <= 767px) {
  #products .products_field > li {
    width: calc(50% - 1rem);
    min-height: 14rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field > li {
    width: 21.818182%;
    min-height: 18rem;
  }
}
#products .products_field > li a {
  width: 100%;
  height: 100%;
  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;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  background-color: var(--white);
  border-radius: 2rem;
  -webkit-box-shadow: 0 0.8rem 2.4rem rgba(0, 0, 0, 0.1);
          box-shadow: 0 0.8rem 2.4rem rgba(0, 0, 0, 0.1);
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
}
#products .products_field > li a::before {
  content: "";
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  -webkit-transition: background-image 0.4s, -webkit-mask-image 0.4s;
  transition: background-image 0.4s, -webkit-mask-image 0.4s;
  transition: background-image 0.4s, mask-image 0.4s;
  transition: background-image 0.4s, mask-image 0.4s, -webkit-mask-image 0.4s;
}
#products .products_field > li a span {
  text-align: center;
  color: var(--ttl-black);
  font-weight: 700;
  line-height: 1.3;
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
@media screen and (width <= 767px) {
  #products .products_field > li a span {
    font-size: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field > li a span {
    font-size: 1.8rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field > li a:hover {
    background-color: var(--dark-blue);
  }
  #products .products_field > li a:hover::before {
    background-color: var(--white);
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
    -webkit-mask-size: contain;
            mask-size: contain;
  }
  #products .products_field > li a:hover span {
    color: var(--white);
  }
}
#products .products_field > li:first-of-type a::before {
  background-image: url(../images/top/product_icon01.svg);
}
@media screen and (width <= 767px) {
  #products .products_field > li:first-of-type a {
    padding-block: 3rem 2rem;
  }
  #products .products_field > li:first-of-type a::before {
    width: 5.5rem;
    height: 5.5rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field > li:first-of-type a {
    padding-block: 2.61rem 2.7rem;
  }
  #products .products_field > li:first-of-type a::before {
    width: 7.456rem;
    height: 7.456rem;
  }
  #products .products_field > li:first-of-type a:hover::before {
    background-image: none;
    -webkit-mask-image: url(../images/top/product_icon01.svg);
            mask-image: url(../images/top/product_icon01.svg);
  }
}
#products .products_field > li:nth-of-type(2) a::before {
  background-image: url(../images/top/product_icon02.svg);
}
@media screen and (width <= 767px) {
  #products .products_field > li:nth-of-type(2) a {
    padding-block: 2.3rem 1rem;
  }
  #products .products_field > li:nth-of-type(2) a::before {
    width: 5.498rem;
    height: 5.5rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field > li:nth-of-type(2) a {
    padding-block: 2.7rem 1.5rem;
  }
  #products .products_field > li:nth-of-type(2) a::before {
    width: 6.914rem;
    height: 6.917rem;
    background-image: url(../images/top/product_icon02.svg);
  }
  #products .products_field > li:nth-of-type(2) a:hover::before {
    background-image: none;
    -webkit-mask-image: url(../images/top/product_icon02.svg);
            mask-image: url(../images/top/product_icon02.svg);
  }
}
#products .products_field > li:nth-of-type(3) a::before {
  background-image: url(../images/top/product_icon03.svg);
}
@media screen and (width <= 767px) {
  #products .products_field > li:nth-of-type(3) a {
    padding-block: 3.9rem 2rem;
  }
  #products .products_field > li:nth-of-type(3) a::before {
    width: 6.262rem;
    height: 3.8rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field > li:nth-of-type(3) a {
    padding-block: 4.39rem 2.6rem;
  }
  #products .products_field > li:nth-of-type(3) a::before {
    width: 8.766rem;
    height: 5.319rem;
    background-image: url(../images/top/product_icon03.svg);
  }
  #products .products_field > li:nth-of-type(3) a:hover::before {
    background-image: none;
    -webkit-mask-image: url(../images/top/product_icon03.svg);
            mask-image: url(../images/top/product_icon03.svg);
  }
}
#products .products_field > li:nth-of-type(4) a::before {
  background-image: url(../images/top/product_icon04.svg);
}
@media screen and (width <= 767px) {
  #products .products_field > li:nth-of-type(4) a {
    padding-block: 3.2rem 2rem;
  }
  #products .products_field > li:nth-of-type(4) a::before {
    width: 5.462rem;
    height: 4.9rem;
  }
}
@media screen and (width > 767px), print {
  #products .products_field > li:nth-of-type(4) a {
    padding-block: 3.41rem 2.6rem;
  }
  #products .products_field > li:nth-of-type(4) a::before {
    width: 7.464rem;
    height: 6.669rem;
  }
  #products .products_field > li:nth-of-type(4) a:hover::before {
    background-image: none;
    -webkit-mask-image: url(../images/top/product_icon04.svg);
            mask-image: url(../images/top/product_icon04.svg);
  }
}

#service {
  margin-top: 3rem;
  overflow-x: hidden;
}
@media screen and (width <= 767px) {
  #service {
    padding-bottom: 4rem;
  }
}
@media screen and (width > 767px), print {
  #service {
    padding-bottom: 7rem;
  }
}
#service .service_inner {
  padding-top: 4rem;
  position: relative;
}
#service .service_inner::after {
  content: "";
  display: block;
  height: calc(100% - 7.2rem);
  background-color: var(--light-gray);
  position: absolute;
  top: 0;
  z-index: -1;
}
@media screen and (width <= 767px) {
  #service .service_inner::after {
    width: 100vw;
    left: -2rem;
  }
}
@media screen and (width > 767px), print {
  #service .service_inner::after {
    width: calc(50vw + 50% + 7rem);
    left: -7rem;
  }
}
#service h3 {
  margin-top: 0;
  margin-bottom: 3rem;
  text-align: center;
  color: var(--ttl-black);
  letter-spacing: 0.06em;
}
@media screen and (width <= 767px) {
  #service h3 {
    font-size: 2.3rem;
  }
}
@media screen and (width > 767px), print {
  #service h3 {
    font-size: 2.8rem;
  }
}
#service h3::before {
  content: none;
}
#service .service_list {
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem 8rem;
}
@media screen and (width <= 767px) {
  #service .service_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#service .service_list > li {
  background-color: var(--white);
}
@media screen and (width <= 767px) {
  #service .service_list > li {
    width: 100%;
  }
}
@media screen and (width > 767px), print {
  #service .service_list > li {
    width: calc(50% - 4rem);
  }
}
#service .service_list > li a {
  display: block;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0 0 3rem rgba(0, 0, 0, 0.16);
          box-shadow: 0 0 3rem rgba(0, 0, 0, 0.16);
  position: relative;
}
#service .service_list > li a::after {
  content: "→";
  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;
  background-color: var(--dark-navy);
  color: var(--white);
  position: absolute;
  right: 0;
  bottom: 0;
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
}
@media screen and (width <= 767px) {
  #service .service_list > li a::after {
    width: 3.5rem;
    height: 3.5rem;
    font-size: 2rem;
  }
}
@media screen and (width > 767px), print {
  #service .service_list > li a::after {
    width: 4rem;
    height: 4rem;
    font-size: 2.3rem;
  }
}
@media screen and (width > 767px), print {
  #service .service_list > li a:hover::after {
    background-color: var(--main-color);
  }
  #service .service_list > li a:hover .service_img img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
#service .service_list .service_img {
  width: 100%;
  aspect-ratio: 3/1;
  overflow: hidden;
}
#service .service_list .service_img img {
  width: 100%;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
@media screen and (width <= 767px) {
  #service .service_list .service_txt {
    padding: 1.5rem 1.5rem 4.5rem;
  }
}
@media screen and (width > 767px), print {
  #service .service_list .service_txt {
    padding: 1.5rem 2.5rem 5rem;
  }
}
#service .service_list .service_txt .ttl {
  margin-top: 0;
  color: var(--ttl-black);
}
@media screen and (width <= 767px) {
  #service .service_list .service_txt .ttl {
    margin-bottom: 1rem;
    font-size: 1.7rem;
  }
}
@media screen and (width > 767px), print {
  #service .service_list .service_txt .ttl {
    margin-bottom: 1.1rem;
    font-size: 2rem;
  }
}

#about {
  background-size: cover;
  margin-top: 0;
}
@media screen and (width <= 767px) {
  #about {
    padding-block: 4rem;
    background-image: url(../images/top/about_bg_sp.jpg);
  }
}
@media screen and (width > 767px), print {
  #about {
    padding-block: 4rem 5rem;
    background-image: url(../images/top/about_bg_pc.jpg);
  }
}
#about h3 {
  margin-top: 0;
  margin-bottom: 3rem;
  text-align: center;
  color: var(--white);
  letter-spacing: 0.06em;
}
@media screen and (width <= 767px) {
  #about h3 {
    font-size: 2.3rem;
  }
}
@media screen and (width > 767px), print {
  #about h3 {
    font-size: 3.4rem;
  }
}
#about h3::before {
  content: none;
}
#about .btn_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (width <= 767px) {
  #about .btn_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #about .btn_wrap {
    gap: 4rem;
  }
}
#about .btn.-arrow {
  --hover-color: var(--ttl-black);
  background-color: var(--white);
  border-color: var(--ttl-black);
  border-width: 0.3rem;
  color: var(--ttl-black);
  position: relative;
}
@media screen and (width <= 767px) {
  #about .btn.-arrow {
    width: 100%;
    padding: 1.8rem 2.5rem 1.8rem 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #about .btn.-arrow {
    width: calc((100% - 8rem) / 3);
    padding: 1.4rem 4rem 1.2rem;
  }
  #about .btn.-arrow:hover {
    color: var(--white);
  }
}
#about .btn.-arrow::after {
  content: "";
  display: block;
  border-top: 0.15rem solid currentColor;
  border-right: 0.15rem solid currentColor;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
@media screen and (width <= 767px) {
  #about .btn.-arrow::after {
    width: 1.1rem;
    height: 1.1rem;
    right: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #about .btn.-arrow::after {
    width: 1.2rem;
    height: 1.2rem;
    right: 2rem;
  }
}
#about .btn.-arrow p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 0;
  font-weight: 400;
  line-height: 1.4;
}
@media screen and (width <= 767px) {
  #about .btn.-arrow p {
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    gap: 0.3rem;
  }
}
@media screen and (width > 767px), print {
  #about .btn.-arrow p {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    text-align: center;
    font-size: 1.6rem;
  }
}
#about .btn.-arrow p span {
  font-weight: 700;
}
@media screen and (width <= 767px) {
  #about .btn.-arrow p span {
    font-size: 1.8rem;
  }
}
@media screen and (width > 767px), print {
  #about .btn.-arrow p span {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    font-size: 2.6rem;
    line-height: 1.357;
  }
}

#case_study {
  margin-top: 0;
  background-color: var(--light-gray);
  position: relative;
}
@media screen and (width <= 767px) {
  #case_study {
    padding-block: 4rem;
  }
}
@media screen and (width > 767px), print {
  #case_study {
    padding-block: 6rem 7rem;
  }
}
#case_study .container {
  position: relative;
}
@media screen and (width > 767px), print {
  #case_study .case_list {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
#case_study .case_list > li a {
  -webkit-box-shadow: 0.3rem 0.3rem 3rem rgba(0, 0, 0, 0.1);
          box-shadow: 0.3rem 0.3rem 3rem rgba(0, 0, 0, 0.1);
}

@media screen and (width <= 767px) {
  #company {
    margin-top: 4rem;
    background-image: -webkit-gradient(linear, left bottom, left top, color-stop(4rem, var(--light-gray)), color-stop(4rem, transparent));
    background-image: linear-gradient(to top, var(--light-gray) 4rem, transparent 4rem);
  }
}
@media screen and (width > 767px), print {
  #company {
    margin-top: 6rem;
    background-image: -webkit-gradient(linear, left bottom, left top, color-stop(10rem, var(--light-gray)), color-stop(10rem, transparent));
    background-image: linear-gradient(to top, var(--light-gray) 10rem, transparent 10rem);
  }
}
#company .company_links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (width <= 767px) {
  #company .company_links {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 2.5rem;
  }
}
@media screen and (width > 767px), print {
  #company .company_links {
    gap: 2rem;
  }
}
@media screen and (width <= 767px) {
  #company .company_links > li {
    width: calc((100% - 2.5rem) / 2);
  }
}
@media screen and (width > 767px), print {
  #company .company_links > li {
    width: calc((100% - 6rem) / 4);
  }
  #company .company_links > li:nth-of-type(even) {
    margin-top: 5rem;
  }
}
#company .company_links > li a {
  display: block;
  width: 100%;
  overflow: hidden;
  position: relative;
}
@media screen and (width > 767px), print {
  #company .company_links > li a {
    aspect-ratio: 26/35;
  }
  #company .company_links > li a:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
#company .company_links > li a img {
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
#company .company_links > li h3 {
  margin: 0;
  background-color: var(--dark-blue);
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  color: var(--white);
  font-weight: 400;
  letter-spacing: 0.2em;
  line-height: 1;
  position: absolute;
  top: 0;
  z-index: 1;
}
@media screen and (width <= 767px) {
  #company .company_links > li h3 {
    padding: 1.2rem 0.6rem;
    font-size: 1.5rem;
    left: 1.2rem;
  }
}
@media screen and (width > 767px), print {
  #company .company_links > li h3 {
    padding: 1.5rem 1rem;
    font-size: 2rem;
    left: 2rem;
  }
}

#faq {
  margin-top: 0;
  background-color: var(--light-gray);
}
@media screen and (width <= 767px) {
  #faq {
    padding-block: 4rem;
  }
}
@media screen and (width > 767px), print {
  #faq {
    padding-block: 6rem;
  }
}
#faq .faq_details {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.5rem;
  padding-bottom: 2.5rem;
  border-bottom: 0.1rem solid #ccc;
}
#faq .faq_details .details_summary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.3rem;
  padding-top: 2.3rem;
  border-top: 0.1rem solid #ccc;
  color: var(--ttl-blue);
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (width <= 767px) {
  #faq .faq_details .details_summary {
    font-size: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #faq .faq_details .details_summary {
    font-size: 1.8rem;
    cursor: pointer;
  }
}
#faq .faq_details .details_summary::before {
  content: "Q";
  width: 2.3rem;
  margin-top: -0.3rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: 2rem;
}
#faq .faq_details .details_content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 0.5rem;
  line-height: 1.7;
}
@media screen and (width <= 767px) {
  #faq .faq_details .details_content {
    font-size: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #faq .faq_details .details_content {
    font-size: 1.6rem;
  }
}
#faq .faq_details .details_content::before {
  content: "A";
  width: 2.3rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: 2rem;
  font-weight: 700;
}
#faq .faq_details .details_content > *:first-child {
  margin-top: 0;
}

#top_news {
  margin-top: 0;
  background-color: var(--light-gray);
  position: relative;
}
@media screen and (width <= 767px) {
  #top_news {
    padding-block: 4rem 8.6rem;
  }
}
@media screen and (width > 767px), print {
  #top_news {
    padding-block: 3.6rem 5rem;
  }
}
#top_news .container.-s {
  position: relative;
}
@media screen and (width > 767px), print {
  #top_news .container.-s {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 3rem;
  }
}
#top_news .ttl_wrap {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
#top_news .ttl_wrap a {
  color: var(--ttl-black);
}
#top_news .ttl_wrap a::after {
  content: "";
  display: inline-block;
  width: 0.9rem;
  height: 0.9rem;
  border-top: 0.15rem solid var(--main-color);
  border-right: 0.15rem solid var(--main-color);
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin-left: 0.8rem;
  margin-bottom: 0.1rem;
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
@media screen and (width <= 767px) {
  #top_news .ttl_wrap a {
    font-size: 1.5rem;
    position: absolute;
    right: 2.2rem;
    bottom: -4.6rem;
  }
}
@media screen and (width > 767px), print {
  #top_news .ttl_wrap a:hover {
    text-decoration: underline;
    color: var(--main-color);
  }
}
@media screen and (width <= 767px) {
  #top_news .section_ttl {
    font-size: 2.8rem;
  }
}
@media screen and (width > 767px), print {
  #top_news .section_ttl {
    margin-bottom: 1.2rem;
    font-size: 3.6rem;
  }
}
#top_news .top_news_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (width <= 767px) {
  #top_news .top_news_list {
    gap: 2rem;
  }
}
@media screen and (width > 767px), print {
  #top_news .top_news_list {
    margin-top: 1.4rem;
    gap: 2.5rem;
  }
}
@media screen and (width > 767px), print {
  #top_news .top_news_list > li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 2rem;
  }
  #top_news .top_news_list > li a:hover time, #top_news .top_news_list > li a:hover p {
    text-decoration: underline;
  }
  #top_news .top_news_list > li a:hover time, #top_news .top_news_list > li a:hover .news_label, #top_news .top_news_list > li a:hover p {
    color: var(--main-color);
  }
}
#top_news .top_news_list > li .date_wrap {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}
#top_news .top_news_list > li time {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: inline-block;
  color: var(--gray-8);
  font-weight: 500;
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
@media screen and (width <= 767px) {
  #top_news .top_news_list > li time {
    width: 11.4rem;
    font-size: 1.4rem;
  }
}
@media screen and (width > 767px), print {
  #top_news .top_news_list > li time {
    width: 14rem;
    font-size: 1.5rem;
  }
}
#top_news .top_news_list > li .news_label {
  display: inline-block;
  border: 0.1rem solid currentColor;
  color: var(--ttl-black);
  line-height: 1.4;
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
@media screen and (width <= 767px) {
  #top_news .top_news_list > li .news_label {
    padding: 0.1rem 2.4rem;
    font-size: 1.3rem;
  }
}
@media screen and (width > 767px), print {
  #top_news .top_news_list > li .news_label {
    padding: 0.1rem 2rem;
    font-size: 1.5rem;
  }
}
#top_news .top_news_list > li p {
  font-weight: 500;
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
@media screen and (width <= 767px) {
  #top_news .top_news_list > li p {
    margin-top: 1rem;
  }
}
@media screen and (width > 767px), print {
  #top_news .top_news_list > li p {
    margin-top: 0;
  }
}
#top_news .top_news_list > li p .label_new {
  display: inline-block;
  margin-left: 0.5em;
  color: #F43A3A;
  font-size: 1.5rem;
}

#group {
  margin-top: 0;
  background-size: cover;
}
@media screen and (width <= 767px) {
  #group {
    padding-block: 4rem;
    background-image: url(../images/top/group_bg_sp.jpg);
  }
}
@media screen and (width > 767px), print {
  #group {
    padding-block: 5rem 7rem;
    background-image: url(../images/top/group_bg_pc.jpg);
  }
}
#group .section_ttl {
  color: var(--white);
}
@media screen and (width > 767px), print {
  #group .section_ttl {
    font-size: 3.4rem;
  }
}
#group .group_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (width <= 767px) {
  #group .group_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 5rem;
  }
}
@media screen and (width > 767px), print {
  #group .group_list {
    gap: 6rem;
  }
}
@media screen and (width > 767px), print {
  #group .group_list > li {
    width: calc((100% - 12rem) / 3);
  }
}
#group .group_list > li a {
  display: block;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
@media screen and (width > 767px), print {
  #group .group_list > li a:hover {
    opacity: 0.7;
  }
  #group .group_list > li a:hover .group_img img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
#group .group_list .group_img {
  width: 100%;
  aspect-ratio: 18/7;
  overflow: hidden;
}
#group .group_list .group_img img {
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
#group .group_list .group_txt {
  color: var(--white);
}
#group .group_list .group_txt .ttl {
  color: var(--white);
  font-size: 2rem;
}
@media screen and (width <= 767px) {
  #group .group_list .group_txt .ttl {
    margin-top: 1rem;
    margin-bottom: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #group .group_list .group_txt .ttl {
    margin-top: 2.5rem;
    margin-bottom: 1rem;
  }
}
@media screen and (width <= 767px) {
  #group .group_list .group_txt .txt {
    font-size: 1.5rem;
  }
}
#group .group_list .group_txt .name {
  padding-right: 1.7rem;
  text-align: right;
  font-weight: 700;
  position: relative;
}
@media screen and (width <= 767px) {
  #group .group_list .group_txt .name {
    margin-top: 1.2rem;
    font-size: 1.5rem;
  }
}
@media screen and (width > 767px), print {
  #group .group_list .group_txt .name {
    margin-top: 1.5rem;
    font-size: 1.7rem;
  }
}
#group .group_list .group_txt .name::after {
  content: "";
  width: 1rem;
  height: 1rem;
  border-top: 0.15rem solid currentColor;
  border-right: 0.15rem solid currentColor;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: absolute;
  right: 0;
  bottom: 0.8rem;
}

#contact_banner {
  margin-top: 0;
}

#footer {
  margin-top: 0.1rem !important;
}