@charset "UTF-8";
@keyframes zoomIn {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1); /* 拡大率：お好みで調整可能 */
  }
}

/* load_anime
----------------------------------------------------------------- */
.load_anime {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  opacity: 0;
  top: 0;
  left: 0;
  z-index: 100000;
  transform: translateX(0%);
}
.load_anime.load {
  opacity: 1;
}
.load_anime .curtain{
  content: "";
  display: inline-block;
  width: 50.5%;
  height: 100%;
  background: #333;
  transition: all .5s;
  position: absolute;
  top: 0;
  z-index: 1;
}
.load_anime .curtain.left{
  left: 0;
  animation: curtain_L .75s 3s ease-in forwards;
}
.load_anime .curtain.right{
  right: 0;
  animation: curtain_R .75s 3s ease-in forwards;
}
.load_anime.complate {
  animation: disnone 1s .75s linear forwards;
}
.load_anime.opacity {
  background: unset;
}
.load_anime.reload {
  display: none !important;
  z-index: -100 !important;
  transform: translateX(-500%) !important;
  opacity: 0 !important;
}
.load_anime .load_anime__contet .typewriter {
  font-size: clamp(1.125rem, 0.225rem + 2.4vw, 2.625rem);/*18~42px(600~1600px)*/
  font-weight: bold;
  color: #fff;
  transition: all .5s;
}
.load_anime .load_anime__contet .typewriter.none {
  opacity: 0;
}
.load_anime__contet{
  position: relative;
  z-index: 20;
}

@keyframes curtain_L {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-110%);
  }
}
@keyframes curtain_R {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(110%);
  }
}
@keyframes disnone {
  0% {
    display: flex;
    z-index: 100000;
    transform: translateX(0%);
    opacity: 1;
  }
  99% {
    display: flex;
    z-index: 100000;
    transform: translateX(0%);
    opacity: 0;
  }
  100% {
    display: none;
    z-index: -100;
    transform: translateX(-500%);
    opacity: 0;
  }
}
/* ----------------------------------------------
　PC設定
------------------------------------------------*/
@media all and (min-width: 769px) {
  #contents .rectangle_title {
    margin-bottom: var(--m27);
    padding: 0.5em 3em;
    background-color: var(--gray01);
    color: #fff;
    font-size: 16px;
    max-width: -moz-fit-content;
    max-width: fit-content;
    line-height: 1;
  }
  #contents .jp_en {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--m60);
  }
  #contents .jp_en .jp {
    font-size: var(--s22_42);
    font-weight: 500;
    color: var(--black01);
    letter-spacing: 0.25em;
  }
  #contents .jp_en .en {
    color: var(--brown03);
    font-size: var(--s18_26);
    font-weight: 500;
  }
  #contents .text_bg {
    position: absolute;
    top: 0;
    z-index: -1;
    background-position: center;
    background-size: 100%;
    background-repeat: no-repeat;
  }
  #contents .top_text {
    margin-bottom: var(--m40);
  }
  #contents .top_text .br {
    font-size: var(--s14_16);
    text-align: center;
  }
  #contents .mv {
    position: relative;
    z-index: 1;
  }
  #contents .mv .main_slider {
    aspect-ratio: 2/1;
    overflow: hidden;
    position: relative;
    z-index: 1;
  }
  #contents .mv .main_slider .swiper-slide {
    /* アクティブじゃないときも、transformを保つ */
  }
  #contents .mv .main_slider .swiper-slide.swiper-slide-active .bg_img img {
    animation: zoomIn 7s ease-in-out forwards;
  }
  #contents .mv .main_slider .swiper-slide.swiper-slide-prev .bg_img img, #contents .mv .main_slider .swiper-slide.swiper-slide-next .bg_img img {
    transform: scale(1.1); /* 最終状態に固定 */
  }
  #contents .mv .main_slider .swiper-slide .wrapper {
    padding-left: 7vw;
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch {
    margin-bottom: var(--m55);
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .en {
    display: block;
    width: 100%;
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .en img {
    width: auto;
    max-width: 90vw;
    height: clamp(60px, 6vw, 95px);
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .jp {
    font-size: var(--s24_40);
    font-weight: 500;
    color: #fff;
    text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.35);
  }
  #contents .mv .main_slider .swiper-slide .wrapper .sub_catch .br {
    font-size: var(--s16_24);
    color: #fff;
    text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.35);
  }
  #contents .mv .main_slider .swiper-slide .bg_img {
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1;
  }
  #contents .mv .main_slider .swiper-slide .bg_img::after {
    content: "";
    display: inline-block;
    width: 100%;
    height: 100%;
    mix-blend-mode: multiply;
    opacity: 0.15;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/common/main_cover.png) top left/100px repeat;
  }
  #contents .mv .pop {
    position: absolute;
    bottom: 0;
    right: 0;
    transform: translate(-28%, 27%);
    width: 30%;
    max-width: 310px;
    z-index: 10;
  }
  #contents .mv .pop a {
    display: block;
    padding: var(--s8_10) var(--s14_20);
    background-color: #fff;
  }
  #contents .mv .pop a .tit {
    font-size: var(--s16_24);
    font-weight: 500;
    color: #fff;
    text-align: center;
    padding: 0.25em 1em;
    background-color: var(--brown03);
  }
  #contents .mv .pop a .img {
    width: 100%;
  }
  #contents .mv .pop a .txt {
    font-size: var(--s14_18);
    color: var(--brown03);
    text-align: center;
    line-height: 1.75;
    display: block;
  }
  #contents .news {
    padding: 30px 0 20px;
    background-color: var(--brown01);
  }
  #contents .news .news_row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    grid-gap: 0.5rem 2%;
    margin-bottom: var(--m16);
  }
  #contents .news dt {
    width: 5em;
    font-size: 16px;
    font-weight: normal;
  }
  #contents .news dd {
    width: calc(98% - 5em);
    font-size: 16px;
    font-weight: normal;
  }
  #contents .news .button a {
    max-width: -moz-fit-content;
    max-width: fit-content;
    margin-left: auto;
  }
  #contents .bg_area {
    position: relative;
    z-index: 1;
    background-color: var(--brown01);
    overflow: hidden;
  }
  #contents .about {
    margin-bottom: var(--m80);
  }
  #contents .about .wrapper {
    padding: var(--m30);
    background-color: #fff;
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }
  #contents .about .text_area {
    width: 44.4%;
  }
  #contents .about .text_area .logo {
    width: 90%;
    margin-bottom: var(--m35);
  }
  #contents .about .text_area .text .br {
    font-size: var(--s14_18);
    line-height: 1.7;
  }
  #contents .about .img_area {
    width: 52.6%;
    position: relative;
  }
  #contents .about .img_area .img01 {
    width: 60.81%;
    position: relative;
    margin-left: auto;
    z-index: 1;
  }
  #contents .about .img_area .img02 {
    width: 54.054%;
    position: absolute;
    top: 0;
    transform: translate(-9%,20%);
    z-index: 3;
  }
  #contents .about .img_area .img03 {
    width: 47.297%;
    position: relative;
    margin: -1rem 20px 0 auto;
    z-index: 2;
  }
  #contents .about .img_area .img04 {
    width: 37.162%;
    position: absolute;
    bottom: 0;
    transform: translate(33%, -10%);
    z-index: 4;
  }
  #contents .about .text_bg {
    width: 95%;
    left: 0;
    aspect-ratio: 1130/140;
    background-image: url(/images/top/text_shuken.svg);
  }
  #contents .business {
    position: relative;
    padding-bottom: var(--m80);
    background: linear-gradient(to bottom, var(--brown01) 0%, var(--brown01) 24%, var(--brown02) 24%, var(--brown02) 100%);
  }
  #contents .business .wrapper {
    padding: var(--m65) var(--m50) var(--m90);
    position: relative;
    z-index: 1;
  }
  #contents .business .wrapper::after {
    content: "";
    display: inline-block;
    width: 100vw;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.8);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
  #contents .business .business_row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: space-between;
    position: relative;
    z-index: 2;
  }
  #contents .business .business_box {
    width: 31.5%;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
  }
  #contents .business .business_box a {
    background-color: #fff;
    border: 3px solid var(--brown02);
    padding: var(--m30) var(--m45);
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  #contents .business .business_box a .tit {
    font-size: var(--s16_20);
    margin-bottom: var(--s16_32);
    order: 1;
  }
  #contents .business .business_box a .text {
    order: 3;
    font-size: 14px;
  }
  #contents .business .business_box a .image {
    order: 2;
    margin-bottom: var(--m20);
  }
  #contents .business .text_bg {
    width: 64.07142vw;
    max-width: 645px;
    top: 7%;
    right: -19vw;
    aspect-ratio: 645/220;
    z-index: 1;
    background-image: url(/images/top/text_business.svg);
  }
  #contents .cases {
    padding-bottom: var(--m100);
    background: linear-gradient(to bottom, var(--brown02) 0%, var(--brown02) 24%, var(--brown03) 24%, var(--brown03) 100%);
  }
  #contents .cases .wrapper {
    padding: var(--m65) var(--m50) var(--m90);
    position: relative;
    z-index: 1;
  }
  #contents .cases .wrapper::after {
    content: "";
    display: inline-block;
    width: 100vw;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.8);
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
  }
  #contents .cases .slider_box {
    position: relative;
    z-index: 2;
  }
  #contents .cases .case_slider {
    overflow: hidden;
    max-width: 800px;
    margin: 0 auto var(--m80);
  }
  #contents .cases .case_slider .swiper-slide .inner {
    width: 100%;
    aspect-ratio: 800/533;
  }
  #contents .cases .case_slider .swiper-slide .inner img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #contents .cases .case_slider .swiper-slide .txt {
    font-size: var(--s16_24);
    color: #fff;
    background-color: var(--brown02);
    padding: 0.25em 1em;
    width: 100%;
    display: inline-block;
    text-align: center;
  }
  #contents .cases .button_area {
    margin: 0 auto;
    max-width: 960px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    grid-gap: 1rem 3.125%;
  }
  #contents .cases .button_area .button {
    width: 31.25%;
  }
  #contents .cases .button_area .button a .txt {
    font-size: var(--s16_22);
  }
  #contents .cases .text_bg {
    width: 30.21428vw;
    max-width: 423px;
    top: 4%;
    left: -14vw;
    aspect-ratio: 423/219;
    z-index: 1;
    background-image: url(/images/top/text_cases.svg);
  }
  #contents .consultation {
    margin: var(--m90) 0;
  }
  #contents .consultation .jp_en {
    margin-bottom: var(--m40);
  }
  #contents .consultation .consul_row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: center;
    grid-gap: var(--s16_24) 2.5%;
  }
  #contents .consultation .consul_box {
    width: 31.6666%;
  }
  #contents .consultation .consul_box .image {
    position: relative;
    z-index: 1;
    margin-bottom: var(--m30);
  }
  #contents .consultation .consul_box .image::after {
    content: "";
    display: inline-block;
    width: 100%;
    height: 100%;
    mix-blend-mode: multiply;
    opacity: 0.15;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/common/main_cover.png) top left/100px repeat;
  }
  #contents .consultation .consul_box .button .txt {
    color: #fff;
    font-size: var(--s18_24);
  }
  #contents .consultation .consul_box .button .arrow {
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
  }
  #contents .group {
    padding: var(--m70) var(--m100);
    background-color: var(--purple01);
  }
  #contents .group .title {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--m70);
  }
  #contents .group .title .sub {
    font-size: var(--s14_24);
    color: var(--gray01);
    letter-spacing: 0.3em;
  }
  #contents .group .title .jp {
    font-size: var(--s22_40);
    color: var(--black01);
    letter-spacing: 0.3em;
    font-weight: 500;
  }
  #contents .group .group_list {
    display: flex;
    flex-wrap: wrap;
    grid-gap: var(--s16_24) 1.875%;
    margin: 0 auto var(--m40);
    max-width: 1140px;
  }
  #contents .group .group_box {
    width: 18.5%;
    position: relative;
    z-index: 1;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
  }
  #contents .group .group_box a {
    width: 100%;
    height: 100%;
    background-color: #fff;
    padding: var(--m45) var(--s10_18);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: all 0.3s;
    grid-gap: var(--m20);
    position: relative;
  }
  #contents .group .group_box .logo {
  }
  #contents .group .group_box .logo img {
    max-height: 70px;
  }
  #contents .group .group_box .logo img[src$=".svg"] {
    width: 200px;
  }
  #contents .group .group_box .name {
    font-size: var(--s14_16);
    text-align: center;
    font-weight: 500;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .75);
    transition: all .5s;
    z-index: 10;
    opacity: 0;
  }
  #contents .group .group_box .occupation {
    font-size: 13px;
    color: var(--black01);
    text-align: center;
    display: block;
  }
  #contents .group .group_box a:hover .name {
    opacity: 1;
    z-index: 10;
  }
}
@media all and (min-width: 769px) and (max-width: 980px) {
  #contents .business .business_row {
    justify-content: center;
    grid-gap: var(--s16_24) 5%;
  }
  #contents .business .business_box {
    width: 47.5%;
  }
  #contents .consultation .consul_row {
    grid-gap: var(--s16_24) 5%;
  }
  #contents .consultation .consul_box {
    width: 47.5%;
  }
  #contents .group .group_list {
    grid-gap: var(--s16_24) 2%;
  }
  #contents .group .group_box {
    width: 32%;
  }
}
/* ----------------------------------------------
　PAD以下設定
------------------------------------------------*/
@media all and (max-width: 768px) {
  #contents .rectangle_title {
    margin-bottom: var(--m27);
    padding: 0.5em 3em;
    background-color: var(--gray01);
    color: #fff;
    font-size: 16px;
    max-width: -moz-fit-content;
    max-width: fit-content;
    line-height: 1;
  }
  #contents .jp_en {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--m60);
  }
  #contents .jp_en .jp {
    font-size: var(--s22_42);
    font-weight: 500;
    color: var(--black01);
    letter-spacing: 0.25em;
  }
  #contents .jp_en .en {
    color: var(--brown03);
    font-size: var(--s18_26);
    font-weight: 500;
  }
  #contents .text_bg {
    position: absolute;
    top: 0;
    z-index: -1;
    background-position: center;
    background-size: 100%;
    background-repeat: no-repeat;
  }
  #contents .top_text {
    margin-bottom: var(--m40);
  }
  #contents .top_text .br {
    font-size: var(--s14_16);
    text-align: center;
  }
  #contents .mv {
    position: relative;
    z-index: 1;
  }
  #contents .mv .main_slider {
    aspect-ratio: 2/1;
    overflow: hidden;
    position: relative;
    z-index: 1;
  }
  #contents .mv .main_slider .swiper-slide {
    /* アクティブじゃないときも、transformを保つ */
  }
  #contents .mv .main_slider .swiper-slide.swiper-slide-active .bg_img img {
    animation: zoomIn 7s ease-in-out forwards;
  }
  #contents .mv .main_slider .swiper-slide.swiper-slide-prev .bg_img img, #contents .mv .main_slider .swiper-slide.swiper-slide-next .bg_img img {
    transform: scale(1.1); /* 最終状態に固定 */
  }
  #contents .mv .main_slider .swiper-slide .wrapper {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch {
    margin-bottom: var(--m55);
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .en {
    display: block;
    width: 100%;
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .en img {
    width: auto;
    max-width: 90vw;
    height: clamp(60px, 6vw, 95px);
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .jp {
    font-size: var(--s24_40);
    font-weight: 500;
    color: #fff;
    text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.35);
  }
  #contents .mv .main_slider .swiper-slide .wrapper .sub_catch .br {
    font-size: var(--s16_24);
    color: #fff;
    text-shadow: 3px 3px 5px rgba(0, 0, 0, 0.35);
  }
  #contents .mv .main_slider .swiper-slide .bg_img {
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1;
  }
  #contents .mv .main_slider .swiper-slide .bg_img::after {
    content: "";
    display: inline-block;
    width: 100%;
    height: 100%;
    mix-blend-mode: multiply;
    opacity: 0.15;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/common/main_cover.png) top left/100px repeat;
  }
  #contents .mv .pop {
    position: absolute;
    bottom: -3vw;
    right: 1vw;
    width: 30%;
    min-width: 190px;
    z-index: 10;
  }
  #contents .mv .pop a {
    display: block;
    padding: var(--s6_10) var(--s14_20);
    background-color: #fff;
  }
  #contents .mv .pop a .tit {
    font-size: var(--s16_24);
    font-weight: 500;
    color: #fff;
    text-align: center;
    padding: 0.25em 1em;
    background-color: var(--brown03);
    white-space: nowrap;
  }
  #contents .mv .pop a .img {
    width: 100%;
  }
  #contents .mv .pop a .txt {
    font-size: var(--s14_18);
    color: var(--brown03);
    text-align: center;
    line-height: 1.75;
    display: block;
  }
  #contents .news {
    padding: 30px 0 20px;
    background-color: var(--brown01);
  }
  #contents .news .news_row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    grid-gap: 0.5rem 2%;
    margin-bottom: var(--m16);
  }
  #contents .news dt {
    width: 5em;
    font-size: 16px;
    font-weight: normal;
  }
  #contents .news dd {
    width: 100%;
    font-size: 16px;
    font-weight: normal;
  }
  #contents .news .button a {
    max-width: -moz-fit-content;
    max-width: fit-content;
    margin-left: auto;
  }
  #contents .bg_area {
    position: relative;
    z-index: 1;
    background-color: var(--brown01);
    overflow: hidden;
  }
  #contents .about {
    margin-bottom: var(--m80);
  }
  #contents .about .wrapper {
    padding: var(--m30);
    background-color: #fff;
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }
  #contents .about .text_area {
    width: 44.4%;
  }
  #contents .about .text_area .logo {
    width: 90%;
    margin-bottom: var(--m35);
  }
  #contents .about .text_area .text .br {
    font-size: var(--s14_18);
    line-height: 1.7;
  }
  #contents .about .img_area {
    width: 52.6%;
    position: relative;
  }
  #contents .about .img_area .img01 {
    width: 60.81%;
    position: relative;
    margin-left: auto;
    z-index: 1;
  }
  #contents .about .img_area .img02 {
    width: 54.054%;
    position: absolute;
    top: 0;
    transform: translate(-9%,20%);
    z-index: 3;
  }
  #contents .about .img_area .img03 {
    width: 47.297%;
    position: relative;
    margin: -1rem 20px 0 auto;
    z-index: 2;
  }
  #contents .about .img_area .img04 {
    width: 37.162%;
    position: absolute;
    bottom: 0;
    transform: translate(33%, -10%);
    z-index: 4;
  }
  #contents .about .text_bg {
    width: 95%;
    left: 0;
    aspect-ratio: 1130/140;
    background-image: url(/images/top/text_shuken.svg);
  }
  #contents .business {
    position: relative;
    padding-bottom: var(--m80);
    background: linear-gradient(to bottom, var(--brown01) 0%, var(--brown01) 24%, var(--brown02) 24%, var(--brown02) 100%);
  }
  #contents .business .wrapper {
    padding: var(--m65) var(--m50) var(--m90);
    position: relative;
    z-index: 1;
  }
  #contents .business .wrapper::after {
    content: "";
    display: inline-block;
    width: 100vw;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.8);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
  #contents .business .business_row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: center;
    grid-gap: var(--s16_24) 5%;
    position: relative;
    z-index: 2;
  }
  #contents .business .business_box {
    width: 47.5%;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
  }
  #contents .business .business_box a {
    background-color: #fff;
    border: 3px solid var(--brown02);
    padding: var(--m30) var(--m45);
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  #contents .business .business_box a .tit {
    font-size: var(--s16_20);
    margin-bottom: var(--s16_32);
    order: 1;
  }
  #contents .business .business_box a .text {
    order: 3;
    font-size: 14px;
  }
  #contents .business .business_box a .image {
    order: 2;
    margin-bottom: var(--m20);
  }
  #contents .business .text_bg {
    width: 64.07142vw;
    max-width: 645px;
    top: 7%;
    right: -19vw;
    aspect-ratio: 645/220;
    z-index: 1;
    background-image: url(/images/top/text_business.svg);
  }
  #contents .cases {
    padding-bottom: var(--m100);
    background: linear-gradient(to bottom, var(--brown02) 0%, var(--brown02) 24%, var(--brown03) 24%, var(--brown03) 100%);
  }
  #contents .cases .wrapper {
    padding: var(--m65) var(--m50) var(--m90);
    position: relative;
    z-index: 1;
  }
  #contents .cases .wrapper::after {
    content: "";
    display: inline-block;
    width: 100vw;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.8);
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
  }
  #contents .cases .slider_box {
    position: relative;
    z-index: 2;
  }
  #contents .cases .case_slider {
    overflow: hidden;
    max-width: 800px;
    margin: 0 auto var(--m80);
  }
  #contents .cases .case_slider .swiper-slide .inner {
    width: 100%;
    aspect-ratio: 800/533;
  }
  #contents .cases .case_slider .swiper-slide .inner img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #contents .cases .case_slider .swiper-slide .txt {
    font-size: var(--s16_24);
    color: #fff;
    background-color: var(--brown02);
    padding: 0.25em 1em;
    width: 100%;
    display: inline-block;
    text-align: center;
  }
  #contents .cases .button_area {
    margin: 0 auto;
    max-width: 960px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    grid-gap: 1rem 3.125%;
  }
  #contents .cases .button_area .button {
    width: 100%;
    max-width: 500px;
  }
  #contents .cases .button_area .button a .txt {
    font-size: var(--s16_22);
  }
  #contents .cases .text_bg {
    width: 30.21428vw;
    max-width: 423px;
    top: 4%;
    left: -2vw;
    aspect-ratio: 423/219;
    z-index: 1;
    background-image: url(/images/top/text_cases.svg);
  }
  #contents .consultation {
    margin: var(--m90) 0;
  }
  #contents .consultation .jp_en {
    margin-bottom: var(--m40);
  }
  #contents .consultation .consul_row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: center;
    grid-gap: var(--s16_24) 5%;
  }
  #contents .consultation .consul_box {
    width: 47.5%;
  }
  #contents .consultation .consul_box .image {
    position: relative;
    z-index: 1;
    margin-bottom: var(--m30);
  }
  #contents .consultation .consul_box .image::after {
    content: "";
    display: inline-block;
    width: 100%;
    height: 100%;
    mix-blend-mode: multiply;
    opacity: 0.15;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/common/main_cover.png) top left/100px repeat;
  }
  #contents .consultation .consul_box .button .txt {
    color: #fff;
    font-size: var(--s18_24);
  }
  #contents .consultation .consul_box .button .arrow {
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
  }
  #contents .group {
    padding: var(--m70) 0%;
    background-color: var(--purple01);
  }
  #contents .group .title {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--m70);
  }
  #contents .group .title .sub {
    font-size: var(--s14_24);
    color: var(--gray01);
    letter-spacing: 0.3em;
  }
  #contents .group .title .jp {
    font-size: var(--s22_40);
    color: var(--black01);
    letter-spacing: 0.3em;
    font-weight: 500;
  }
  #contents .group .group_list {
    display: flex;
    flex-wrap: wrap;
    grid-gap: var(--s16_24) 2%;
    margin: 0 auto var(--m40);
    max-width: 1140px;
  }
  #contents .group .group_box {
    width: 32%;
    position: relative;
    z-index: 1;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
  }
  #contents .group .group_box a {
    width: 100%;
    height: 100%;
    background-color: #fff;
    padding: var(--s20_60) var(--s10_18) var(--s8_24);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: all 0.3s;
  }
  #contents .group .group_box .logo {
    margin-bottom: var(--s16_32);
  }
  #contents .group .group_box .logo img {
    max-height: 50px;
  }
  #contents .group .group_box .logo img[src$=".svg"] {
    width: 200px;
  }
  #contents .group .group_box .name {
    font-size: 14px;
    font-weight: 500;
    color: var(--black01);
  }
  #contents .group .group_box .occupation {
    font-size: 13px;
    color: var(--black01);
    margin-bottom: var(--m20);
  }
  #contents .group .group_box.daijuku img, #contents .group .group_box.atlas img, #contents .group .group_box.okamoto img, #contents .group .group_box.ikesugi img {
    max-height: 70px;
  }
}
/* ----------------------------------------------
　SP調整
------------------------------------------------*/
@media all and (max-width: 620px) {
  #contents .mv .main_slider {
    aspect-ratio: 1/1.55;
  }
  #contents .mv .main_slider .swiper-slide .wrapper {
    justify-content: flex-start;
    padding-top: 20vw;
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch {
    width: 100%;
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .en {
    width: 100%;
  }
  #contents .mv .main_slider .swiper-slide .wrapper .main_catch .en img {
    width: 100%;
    height: auto;
  }
  #contents .mv .pop {
    width: 80%;
    bottom: 0;
    right: unset;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  #contents .about .text_area {
    width: 100%;
  }
  #contents .about .img_area {
    width: 100%;
  }
  #contents .business .business_box {
    width: 100%;
  }
  #contents .consultation .consul_box {
    width: 100%;
  }
  #contents .group .group_box {
    width: 49%;
  }

  #contents .about .img_area .img01 {
    width: 57.81%;
  }
  #contents .about .img_area .img02 {
    transform: translate(-5%,18.3%);
  }
  #contents .about .img_area .img04 {
    transform: translate(26%, 0%);
  }
  }