@charset "UTF-8";

@import "settings.css";

/*============================================================================================
      Header
=============================================================================================*/
.header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 3.2rem 3.2rem 1.6rem;
  position: sticky;
  top: 0;
  z-index: 9999;
  background: var(--color-main);
  transition: var(--transition);
}

body:has(.g_pgHd) .header {
  background: none;
  position: fixed;
}

.header_logo{
  background: url(../img/common/logo_wh.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 23.6rem;
  height: 6.4rem;
  display: block;
}

body:has(.g_pgHd) .header_logo{
  background: url(../img/common/header_logo.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 23.6rem;
  height: 6.4rem;
  display: block;
  transition: var(--transition);
}

.header:has(.js_open),
body:has(.g_pgHd) .header.scrolled,
.header.scrolled{
  padding: 1.4rem 3.2rem;
  background: var(--color-reverse);
  border-bottom: 0.4rem solid var(--color-main);
}
.header:has(.js_open){
  border-bottom: none;
}
.header:has(.js_open) .header_logo,
.header.scrolled .header_logo{
  background: url(../img/common/header_logo.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 17.7rem;
  height: 4.8rem;
}

/*プルダウンメニュー*/
.header_list{
  position: relative;
}
.header_list_itm{
  opacity: 0;
  pointer-events: none;
  line-height: 1.5;
  background: var(--color-reverse);
  border-radius: var(--radius-lg);
  padding: 2.4rem;
  box-shadow: var(--box-shadow);
  font-weight: 700;
  width: 30rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  transition: var(--transition);
}
.header_list_itm.header_list_itm__last{
  left: 20%;
}
.header_list:hover .header_list_itm{
  opacity: 1;
  pointer-events: all;
}
.header_icon::after{
  content: "";
  display: inline-block;
  width: 1.4rem;
  height: 1.4rem;
  background: url(../img/common/ico_tab.svg);
  background-size: contain;
  background-repeat: no-repeat;
  filter: var(--color-filter-text);
  margin-left: 0.4rem;
}
.header_icon:hover:after{
  filter: var(--color-filter-reverse);
}

@media (max-width: 896px) {
  .header,
  .header.scrolled{
    padding: 1.6rem;
  }
  .header_logo{
    width: 17.6rem;
    height: 4.8rem;
  }
  .header.scrolled .header_logo{
    background-size: contain;
  }

  /*仮で非表示*/
  .header nav ul{
    display: none;
  }
}

/*============================================================
	MEGAMENU
*/
#megamenu {
	overflow: hidden;
	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
	width: 100%;
	height: 0;
}
.megamenu-active #megamenu {
	height: 100vh;
}

#megamenu .bg svg {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

#megamenu .footer_cont::before {
	content: "";
  display: block;
  background: url(../img/common/footer_left.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: min(calc(var(--vw-calc-lg) * 242), 24.2rem);
  height: min(calc(var(--vw-calc-lg) * 168), 16.8rem);
  position: absolute;
  right: 0;
  top: -6.4rem;
  z-index: -1;
}
#megamenu .container {
	display: flex;
	align-items: center;
	height: 100%;
  width: calc(100% - 2rem * 2);
  margin: auto;
  gap: clamp(8rem, calc(var(--vw-calc-lg) * 104), 10.4rem);
  max-width: var(--cont-width);
}

#megamenu .bg .bg-mask1 {
	fill: var(--color-sub);
}
#megamenu .bg .bg-mask2 {
	fill: var(--color-bg);
}
#megamenu .bg .bg-mask3 {
	fill: var(--color-reverse);
}

/*footerのメガメニュー化*/
.megamenu{
  height: 100%;
}
.megamenu .footer_cont{
  max-width: none;
}
.megamenu .footer_copy{
  display: block;
  margin: 4.8rem 0 0 clamp(5.6rem, calc(var(--vw-calc-lg) * 96), 9.6rem);
  position: relative;
}
.megamenu .footer_copy h2{
  position: relative;
  z-index: 2;
}
.megamenu .top_intro_vertical{
  font-size: clamp(2.4rem, calc(var(--vw-calc-lg) * 32), 3.2rem);
}
.megamenu .footer_copy .top_intro_vertical__line{
  height: 100%;
}
.megamenu .top_intro_vertical:nth-child(2){
  margin-top: 0;
}
.megamenu .top_intro_vertical:first-child{
  margin-top: 2em;
}
.megamenu .footer_copy::after{
  content: "";
  display: block;
  background: url(../img/common/footer_right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: min(calc(var(--vw-calc-lg) * 242), 24.2rem);
  height: min(calc(var(--vw-calc-lg) * 168), 16.8rem);
  position: absolute;
  left: -2.4rem;
  bottom: -4rem;
}
.megamenu .footer_list{
  font-size: clamp(1.4rem, calc(var(--vw-calc-lg) * 18), 1.8rem);
}
.megamenu .mv_nav{
  display: flex;
  position: static;
  margin: 6.4rem 0 0 auto;
}
.megamenu .footer_list_box{
  gap: clamp(1.4rem, calc(var(--vw-calc-lg) * 32), 3.2rem);
  margin-top: 13.6rem;
}
.megamenu_copy{
  display: none;
}

@media (max-width: 980px) {
  .megamenu .footer_copy{
    display: none;
  }
  .megamenu_copy{
    display: block;
    font-size: 2.8rem;
    font-weight: 700;
    position: relative;
    margin-top: 3.2rem;
  }
  .megamenu_copy p{
    position: relative;
    display: block;
    width: fit-content;
    margin-bottom: 0.8rem;
  }
  .megamenu_copy p::after{
    content: "";
    display: block;
    width: 100%;
    height: 0.1rem;
    background: var(--color-text);
    position: absolute;
    bottom: 0;
  }
  .megamenu .mv_nav{
    margin: 3.2rem 0 0;
    width: 100%;
  }
  #megamenu .footer_cont::before{
    display: none;
  }
  .nav-content{
    position: relative;
  }
  .nav-content::before{
    content: "";
    display: block;
    background: url(../img/common/footer_left.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: min(calc(var(--vw-calc-md) * 242), 24.2rem);
    height: min(calc(var(--vw-calc-md) * 168), 16.8rem);
    position: absolute;
    right: 0;
    top: -13.6rem;
    z-index: -1;
  }
}

@media (max-width: 896px) {
  .megamenu .mv_nav{
    margin: 3.2rem auto 0;
    flex-wrap: wrap;
    width: 100%;
  }
  .megamenu .mv_nav .g_btn{
    max-width: none;
    width: 100%;
  }
  .megamenu .footer_list_box{
    margin-top: 0;
  }
}

@media (max-width: 576px) {
  .megamenu{
    overflow-y: auto;
    margin-top: 8rem;
  }
  #megamenu .container{
    display: block;
    margin: 3.2rem auto 0;
    padding-bottom: 8rem;
    height: fit-content;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  #megamenu .footer_cont{
    height: fit-content;
    padding-bottom: 13rem;
  }
  #megamenu .footer_cont::before{
    top: 0;
  }
  .nav-content::before{
    top: 0;
  }
  .megamenu_copy{
    display: none;
  }
}

/*============================================================================================
      Footer
=============================================================================================*/
.footer{
  position: sticky;
  bottom: 0;
}

.footer_inr{
  max-width: var(--cont-width); /* コンテンツ幅 */
  width: calc(100% - 2rem * 2);
  margin: 10.4rem auto 5.6rem;
  position: relative;
}
.footer_inr::before{
  content: "";
  display: inline-block;
  width: min(calc(var(--vw-calc-lg) * 186), 18.6rem);
  height: min(calc(var(--vw-calc-lg) * 128), 12.8rem);
  background: url(../img/common/footer_left.svg);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  left: -3.2rem;
  bottom: 0;
  z-index: -1;
}
.footer_inr::after{
  content: "";
  display: inline-block;
  width: min(calc(var(--vw-calc-lg) * 240), 24rem);
  height: min(calc(var(--vw-calc-lg) * 168), 16.8rem);
  background: url(../img/common/footer_right.svg);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  right: 12.8rem;
  top: -4.8rem;
  z-index: -1;
}

.footer_goTop{
  position: absolute;
  right: 0;
  top: 0;
  font-family: var(--font-Rajdhani);
  z-index: 3;
}
.footer_goTop_inr{
  background: var(--color-main);
  color: var(--color-reverse);
  text-align: center;
  display: block;
  width: 8rem;
  height: 8rem;
  font-size: 1.4rem;
  font-weight: 700;
  border-radius: 50vw;
  padding-top: 1.6rem;
  position: relative;
  transition: var(--transition);
}
.footer_goTop_inr::before{
  content: "";
  display: block;
  width: 3.2rem;
  height: 3.2rem;
  position: absolute;
  right: 0;
  left: 0;
  bottom: 0.2rem;
  margin: 0 auto;
  background-color: var(--color-reverse);
  border-radius: 50vw;
}
.footer_goTop_inr::after{
  content: "";
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  position: absolute;
  right: 0;
  left: 0;
  bottom: 1.2rem;
  margin: 0 auto;
  border-top: 0.2rem solid var(--color-main);
  border-right: 0.2rem solid var(--color-main);
  rotate: -45deg;
  transition: var(--transition);
}
.footer_goTop_inr:hover{
  background: var(--color-btn);
}
.footer_goTop_inr:hover::after{
  filter: var(--color-filter-btn);
}

.footer_cont{
  max-width: var(--cont-width-md);
  width: calc(100% - 2rem * 2);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.footer_list_box{
  margin-top: 5.6rem;
  display: flex;
  gap: clamp(1.4rem, calc(var(--vw-calc-lg) * 72), 7.2rem);
}
.footer_link_ttl{
  font-weight: 700;
  color: var(--color-main);
}
.footer_link_ttl::before{
  content: "・";
  margin-right: 1rem;
}
.footer_list{
  margin: 2.4rem 0 0 2.4rem;
  line-height: 1.5;
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--color-text);
}
.footer_subNav{
  display: flex;
  gap: 2.4rem;
  width: fit-content;
  margin: 4.8rem 0 0 auto;
}

.footer_btm{
  line-height: 3.2rem;
  text-align: center;
  background: var(--color-main);
  color: var(--color-reverse);
  font-size: 1.4rem;
  font-weight: 700;
  font-family: var(--font-Rajdhani)
}

@media (max-width: 896px) {
  .footer_inr{
    margin: 5.6rem auto 3.2rem;
  }
  .footer_inr::before,
  .footer_inr::after{
    display: none;
  }
  .footer_list{
    font-size: clamp(1.4rem, calc(var(--vw-calc-lg) * 18), 1.8rem);
  }
  .footer_cont{
    width: 100%;
  }
  .footer_list_box{
    margin-top: 2.4rem;
  }
  .footer_subNav{
    margin-top: 2.4rem;
  }
}

@media (max-width: 576px) {
  .footer{
    position: static;
  }
  .footer_logo{
    width: min(calc(var(--vw-calc-sm) * 236), 23.6rem);
  }
  .footer_inr{
    margin: 4.8rem auto 3.2rem;
  }
  .footer_subNav{
    margin: 3.2rem auto 0;
  }
  .footer_list_box{
    margin-top: 4.8rem;
    flex-wrap: wrap;
  }
  .footer_list_box > li{
    width: 100%;
  }
  .footer_list{
    font-size: 1.8rem;
  }
}

/*============================================================================================
      Contents
=============================================================================================*/

/*MV*/
.mv{
  padding: clamp(25.6rem, calc(var(--vw-calc-lg) * 416), 92rem) clamp(3rem, calc(var(--vw-calc-lg) * 64), 9.6rem) clamp(1.6rem, calc(var(--vw-calc-lg) * 26), 6.4rem);
  background-color: var(--color-main);
}

.mv_box_left{
  width: calc(100vw - ( (var(--vw-calc-lg) * 96) + (var(--vw-calc-lg) * 852)));
}
.mv_speech{
  position: absolute;
  top: clamp(4rem, calc(var(--vw-calc-lg) * 64), 10.4rem);
  z-index: 2;
}
.mv_speech .g_speech{
  margin-left: 1.6rem;
}
.mv_speech_inr{
  padding: clamp(2rem, calc(var(--vw-calc-lg) * 32), 5.6rem) 0 clamp(2rem, calc(var(--vw-calc-lg) * 32), 5.6rem) clamp(2rem, calc(var(--vw-calc-lg) * 24), 4rem);
}
.mv_ttl{
  font-size: clamp(2rem, calc(var(--vw-calc-lg) * 56), 10.4rem);
  font-weight: 700;
  line-height: 1.4;
  color: var(--color-text);
}
.mv_ttl_sub{
  font-size: clamp(1.4rem, calc(var(--vw-calc-lg) * 20), 3.2rem);
  font-weight: 700;
  color: var(--color-main);
}

.mv_speech_circle01{
  display: block;
  width: clamp(1.4rem, calc(var(--vw-calc-lg) * 18), 3.2rem);
  height: clamp(1.4rem, calc(var(--vw-calc-lg) * 18), 3.2rem);
  border-radius: 50vw;
  background: var(--color-reverse);
  margin: clamp(2rem, calc(var(--vw-calc-lg) * 40), 5.6rem) 0 0 0.4rem;
}

.mv_speech_circle02{
  display: block;
  width: clamp(0.8rem, calc(var(--vw-calc-lg) * 10), 1.6rem);
  height: clamp(0.8rem, calc(var(--vw-calc-lg) * 10), 1.6rem);
  border-radius: 50vw;
  background: var(--color-reverse);
  margin-top: clamp(0.8rem, calc(var(--vw-calc-lg) * 10), 2.4rem);
}

.mv_copy{
  font-size: clamp(2.2rem, calc(var(--vw-calc-lg) * 28), 5.6rem);
  color: var(--color-reverse);
  font-weight: 600;
  font-family: var(--font-Rajdhani);
  line-height: 1.1;
  margin-bottom: clamp(1.6rem, calc(var(--vw-calc-lg) * 28), 5.6rem);
}

.mv_slider_btn{
  background: var(--color-reverse);
  width: clamp(3.2rem, calc(var(--vw-calc-lg) * 32), 4.8rem);
  height: clamp(3.2rem, calc(var(--vw-calc-lg) * 32), 4.8rem);
  position: relative;
  cursor: pointer;
  transition: var(--transition);
}
.mv_slider_btn:hover{
  background: var(--color-btn);
}
.mv_slider_btn:hover::before{
  filter: var(--color-filter-reverse);
}
.mv_slider_btn::before{
  content: "";
  display: block;
  background: url(../img/common/ico_arrow.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: clamp(2rem, calc(var(--vw-calc-lg) * 32), 4.8rem);
  height: clamp(1.2rem, calc(var(--vw-calc-lg) * 12), 2.4rem);
  filter: var(--color-filter-main);
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  position: absolute;
}
.mv_slider_btn.mv_slider_btn__back::before{
  transform: scale(-1,1);
}
.mv_slider_dots{
  display: flex;
  gap: 1.8rem;
}
.mv_slider_dots span{
  display: block;
  width: 0.6rem;
  height: 0.6rem;
  background: var(--color-reverse);
  opacity: 0.3;
  border-radius: 50vw;
}
.mv_slider_dots .mv_slider_dots__current{
  opacity: 1;
}

.mv_news{
  color: var(--color-reverse);
  margin-top: clamp(1.6rem, calc(var(--vw-calc-lg) * 28), 5.6rem);
  font-size: clamp(1.4rem, calc(var(--vw-calc-lg) * 16), 5.6rem);
  display: flex;
  gap: 1em;
}
.mv_news_txt{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: calc(100vw - (7.2rem + (var(--vw-calc-lg) * 852)));
  display: block;
}

.mv_nav .g_btn{
  width: calc(var(--vw-calc-lg) * 336);
}

.mv_box_right{
  position: absolute;
  top: 0;
  right: 0;
}

.mv_scroll{
  width: 0.8rem;
  height: clamp(6.4rem, calc(var(--vw-calc-lg) * 72), 12rem);
}
.mv_scroll::before{
  bottom: 0px;
  left: 0px;
  right: 0px;
  width: 0.1rem;
  height: 100%;
  background-color: var(--color-reverse);
  margin: auto;
}
.mv_scroll::after{
  left: 0;
  right: 0px;
  bottom: 8.2rem;
  width: 0.5rem;
  height: 0.5rem;
  background-color: var(--color-reverse);
  margin: auto;
  border-radius: 50vw;
  animation: 3.06s cubic-bezier(0.61, 0, 0.29, 0.99) 0s infinite normal none running mvScroll;
}
@keyframes mvScroll{
  0%{
    bottom: clamp(7.2rem, calc(var(--vw-calc-lg) * 80), 12rem);
  }
  50%{
    transform: scale(1.75);
    bottom: -1.4rem;
  }
  100%{
    bottom: clamp(7.2rem, calc(var(--vw-calc-lg) * 80), 12rem);
  }
}

.mv_nav{
  display: flex;
  gap: 1.6rem;
  position: absolute;
  bottom: clamp(8rem, calc(var(--vw-calc-lg) * 120), 24rem);
  right: clamp(3.2rem, calc(var(--vw-calc-lg) * 64), 19.2rem);
  z-index: 999;
  width: fit-content;
}

.mv_slider{
  width: min(calc(var(--vw-calc-lg) * 852), 147rem);
  height: min(calc(var(--vw-calc-lg) * 745), 133.6rem);
  mask-image: url(../img/top/mv_path.svg);
  mask-size: cover;
  mask-repeat: no-repeat;
}

@media (max-width: 896px) {
  .mv{
    display: flex;
    flex-wrap: wrap;
    padding: clamp(32rem, calc(var(--vw-calc-md) * 416), 92rem) 3.2rem clamp(1.6rem, calc(var(--vw-calc-md) * 26), 6.4rem);
  }
  .mv_box_left {
    width: 100%;
    position: relative;
    z-index: 2;
  }
  .mv_speech{
    position: static;
    margin-bottom: 0.8rem;
  }
  .mv_news{
    display: block;
  }
  .mv_news_txt{
    width: 100%;
  }
  .mv_ttl{
    font-size: clamp(2rem, calc(var(--vw-calc-md) * 56), 10.4rem);
  }
  .mv_ttl_sub{
    font-size: clamp(1.4rem, calc(var(--vw-calc-md) * 20), 3.2rem);
  }
  .mv_slider{
    width: min(calc(var(--vw-calc-lg) * 852), 147rem);
    height: min(calc(var(--vw-calc-lg) * 745), 133.6rem);
    transform: scale(1.25);
    transform-origin: top right;
  }

  /*非表示*/
  .mv_nav{
    display: none;
  }
}

@media (max-width: 576px) {
  .mv{
    padding: 0 0 0.8rem 0;
    flex-wrap: wrap-reverse;
  }
  .mv_box_left{
    width: calc(100% - 2rem * 2);
    margin: 0 auto;
  }
  .mv_box_right{
    position: static;
    width: 100%;
  }
  .mv_speech .g_speech{
    margin-left: 0.8rem;
  }
  .mv_ttl {
    font-size: clamp(2rem, calc(var(--vw-calc-sm) * 40), 4rem);
  }
  .mv_ttl_sub{
    font-size: clamp(1.4rem, calc(var(--vw-calc-sm) * 18), 1.8rem);
  }
  .mv_speech_circle01{
    margin-top: 4rem;
  }
  .mv_slider{
    width: 100%;
    height: calc(100vw * 0.873);
  }
}

/*イントロダクション*/
.top_sec__intro{
  padding-top: clamp(8rem, calc(var(--vw-calc-lg) * 150), 22.4rem);
  background: var(--color-bg);
  position: relative;
  z-index: -1;
}
.top_sec__intro::before{
  content: "";
  display: block;
  width: 100%;
  height: 70%;
  background: var(--color-sub);
  position: absolute;
  top: 0;
  z-index: -1;
}
.top_intro_inr{
  background: var(--color-reverse);
  padding-left: clamp(12rem, calc(var(--vw-calc-lg) * 144), 15.2rem);
  margin: 0 auto;
  border-radius: 50vw 6.4rem 6.4rem 50vw;
  display: flex;
  gap: 10.4rem;
}
.top_intro_vertical{
  display: block;
  font-size: 3.2rem;
  font-weight: 700;
  position: relative;
  height: fit-content;
}
/* .top_intro_vertical:nth-child(2){
  margin-top: -2em;
} */
.top_intro_vertical span > *{
  display: block;
  line-height: 1;
  margin-bottom: 0.4rem;
}
/* .top_intro_vertical__dot{
  transform: rotateY(180deg);
  margin-top: -0.5em;
} */
.top_intro_vertical__line{
  width: 0.1rem;
  background-color: var(--color-text);
  position: absolute;
  top: 0;
  right: -1rem;
  transition: 1.8s;
}
.js_fadeIn02.js_active02.top_intro_vertical__line {
  animation: drawline 1.5s forwards 0.2s;
}
@keyframes drawline {
  0% {
    height: 0;
  }
  100% {
    height: 100%;
  }
}
@keyframes drawline_sm {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}

.top_intro_txt{
  padding: 8rem 2.4rem 8rem 0;
  font-size: 1.8rem;
}
.top_intro_txt > *{
  display: block;
  line-height: 1.5;
  margin-bottom: 1.6rem;
}

.top_intro_txt > *:last-child{
  margin-bottom: 0;
}

@media (max-width: 896px) {
  .top_sec__intro::before{
    height: 50%;
  }
  .top_intro_inr{
    padding: 4.8rem 3.2rem;
    flex-wrap: wrap;
    border-radius: 1.6rem;
    gap: 3.2rem;
  }
  .top_intro_inr .l_flexNoShrink{
    flex-shrink: 1;
  }
  .top_intro_inr .l_flex{
    flex-wrap: wrap-reverse;
    gap: 0;
  }
  .top_intro_vertical span > *{
    display: inline;
  }
  .top_intro_txt{
    padding: 0;
  }
  .top_intro_txt > *{
    margin-bottom: 0.4rem;
  }
  .top_intro_vertical:nth-child(2){
    margin-top: 0;
  }
  .top_intro_vertical__line{
    width: 0;
    height: 0.1rem;
    top: auto;
    bottom: 0;
    right: auto;
    left: 0;
  }
  .js_fadeIn02.js_active02.top_intro_vertical__line {
    animation: drawline_sm 1.5s forwards 0.2s;
  }
}

@media (max-width: 576px) {
  .top_sec__intro{
    padding-top: 6.4rem;
  }
  .top_intro_inr{
    padding: 3.2rem 1.6rem;
  }
  .top_intro_vertical span > *{
    margin-bottom: 0;
    margin-left: -0.4rem;
  }
  .top_intro_vertical{
    font-size: 2.4rem;
  }
  .top_intro_txt{
    font-size: 1.6rem;
    font-weight: 700;
  }
}

/*メニュー*/
.top_sec__menu{
  background: var(--color-gradient);
  padding-top: 12rem;
}
.top_menu_img{
  position: relative;
  z-index: 2;
}
.top_menu_img img{
  border-radius: var(--radius-lg);
}
.top_menu{
  position: relative;
}
.top_menu_img__about{
  width: min(calc(var(--vw-calc-lg) * 500), 50rem);
  padding: min(calc(var(--vw-calc-lg) * 80), 8rem) 0 0 min(calc(var(--vw-calc-lg) * 85), 8.5rem);
}
.top_menu_img__business{
  width: min(calc(var(--vw-calc-lg) * 400), 40rem);
  margin-left: auto;
  margin-right: 0;
  margin-top: clamp(13.6rem, calc(var(--vw-calc-lg) * 264), 26.4rem);
}

.top_menu_img__department{
  width: min(calc(var(--vw-calc-lg) * 400), 40rem);
  margin-top: min(calc(var(--vw-calc-lg) * 104), 104px);
}

.top_menu_box{
  display: flex;
  gap: clamp(4rem, calc(var(--vw-calc-lg) * 72), 7.2rem);
  margin-left: auto;
  margin-right: 0;
  margin-top: clamp(10.4rem, calc(var(--vw-calc-lg) * 120), 12rem);
  align-items: flex-end;
  width: fit-content;
  padding-bottom: 12rem;
}
.top_menu_img__dx{
  width: min(calc(var(--vw-calc-lg) * 300), 30rem);
  padding-bottom: clamp(1.6rem, calc(var(--vw-calc-lg) * 32), 3.2rem);
}
.top_menu_img__keyword{
  width: min(calc(var(--vw-calc-lg) * 352), 35.2rem);
}
.top_menu_speech{
  position: absolute;
  z-index: 3;
  box-shadow: var(--box-shadow);
}
.top_menu_speech01{
  width: fit-content;
  height: fit-content;
  position: static;
}
.top_menu_speech02{
  top: -130%;
  right: clamp(7.2rem, calc(var(--vw-calc-lg) * 104), 10.4rem);
}
.top_menu_speech03{
  top: -160%;
  left: clamp(4.8rem, calc(var(--vw-calc-lg) * 72), 7.2rem);
}
.top_menu_speech04{
  top: clamp(-6.4rem, calc(var(--vw-calc-lg) * -72), -7.2rem);
  right: clamp(24rem, calc(var(--vw-calc-lg) * 320), 32rem);
}
.top_menu_speech05{
  top: -64%;
  right: clamp(10.4rem, calc(var(--vw-calc-lg) * 264), 26.4rem);
}

/*メニュー 吹き出しアニメーション*/
.js_zoomIn{
  opacity: 0;
}
.js_zoomIn.is_show{
  animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
.g_speech_inr.js_zoomIn.is_show{
  animation-delay: .3s;
}

@keyframes zoomIn {
  0% {
    transform: scale(0.8);
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@media (max-width: 896px) {
  .top_sec__menu{
    padding-top: 8rem;
  }
  .top_menu_speech.top_menu_speech__sp{
    position: static;
    height: fit-content;
  }
  /* .top_menu_box{
    padding-bottom: 8rem;
    margin-top: 19.2rem;
  }
  .top_menu_img__about{
    padding: 0;
  }
  .top_menu_img__keyword{
    width: min(calc(var(--vw-calc-md) * 352), 35.2rem);
  }
  .top_menu_img__department{
    width: min(calc(var(--vw-calc-md) * 400), 40rem);
  }
  .top_menu_img__business{
    width: min(calc(var(--vw-calc-md) * 350), 35rem);
    margin-top: 3.2rem;
  }
  .top_menu_img__dx{
    width: min(calc(var(--vw-calc-md) * 300), 30rem);
    padding-bottom: 0;
  }
  .top_menu_speech02{
    top: 0;
    right: auto;
    left: 3.2rem;
  }
  .top_menu_speech03{
    top: 0;
    left: auto;
    right: 0;
  }
  .top_menu_speech04{
    top: -14.4rem;
    right: auto;
    left: -5.6rem;
  }
  .top_menu_speech05{
    top: -52%;
    right: 3.2rem;
  } */
}

@media (max-width: 576px) {
  .top_sec__menu .l_wrap_inr{
    width: 100%;
  }
  .top_menu_box{
    margin: 17.6rem auto 0;
    flex-wrap: wrap-reverse;
    gap: 16rem;
  }
  .top_menu{
    width: 100%;
  }
  /* .top_menu_img__about{
    width: 100%;
    margin-top: 11.2rem;
  }
  .top_menu_img__business{
    width: 100%;
    margin: 14.4rem 0 0;
  }
  .top_menu_img__business figure{
    margin: 0 0 0 auto;
    width: 32rem;
  }
  .top_menu_img__department{
    width: 100%;
    margin-top: 24rem;
  }
  .top_menu_img__keyword{
    width: 20rem;
    margin: 0 0 0 auto;
  }
  .top_menu_img__dx{
    width: 30rem;
    margin: 0 auto;
  } */
  .top_menu_speech{
    width: calc(100% - 2rem * 2);
    right: 0;
    left: 0;
    margin: 0 auto;
  }
  /* .top_menu_speech03{
    top: -75%;
  }
  .top_menu_speech04{
    top: -12.8rem;

  }
  .top_menu_speech05{
    top: -15.2rem;
  } */
}

/*働く環境*/
.top_sec__education{
  position: relative;
  background: var(--color-reverse);
}
.top_education_inr{
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
}
.top_education_box {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 3.2rem;
  grid-row-gap: 0px;
  margin-top: 6.4rem;
}

.top_education_img::after{
  content: "";
  display: block;
  width: 100%;
  height: min(calc(var(--vw-calc-lg) * 176), 17.6rem);
  background: var(--color-gradient);
}
.top_education_img img{
  height: min(calc(var(--vw-calc-lg) * 1000), 100rem);
  object-fit: cover;
}

.top_education_ttl{
  color: var(--color-reverse);
  line-height: 1.5;
  font-size: clamp(2.8rem, calc(var(--vw-calc-lg) * 40), 4rem);
  font-weight: 700;
}
.top_education_ttl_sub{
  font-size: clamp(1.8rem, calc(var(--vw-calc-lg) * 24), 2.4rem);
  display: block;
  margin-bottom: clamp(1.6rem, calc(var(--vw-calc-lg) * 32), 3.2rem);
}

@media (max-width: 896px) {
  .top_education_box{
    display: block;
    margin-top: 3.2rem;
  }
  .top_education_box li{
    margin-top: 2.4rem;
  }
  .top_education_box li:first-child{
    margin-top: 0;
  }
  .top_education_img img{
    height: min(calc(var(--vw-calc-lg) * 1400), 140rem);
  }
}

@media (max-width: 576px) {
  .top_education_box li{
    margin-top: 4rem;
  }
  .top_education_inr{
    position: relative;
    margin-top: -44.8rem;
    z-index: 2
  }
  .top_education_ttl{
    font-size: 2.6rem;
  }
  .top_education_img img{
    height: min(calc(var(--vw-calc-sm) * 600), 60rem);
    object-position: top 0 left -24rem;
  }
  .top_education_img::after{
    height: min(calc(var(--vw-calc-sm) * 176), 17.6rem);
  }
}

/*社員インタビュー*/
.top_sec__interview{
  padding-top: 12rem;
  background: var(--color-reverse);
  margin-bottom: 12rem;
}
.top_interview_ttl{
  color: var(--color-text);
  line-height: 1.5;
  font-size: clamp(2.8rem, calc(var(--vw-calc-lg) * 40), 4rem);
  font-weight: 700;
}
.top_interview_ttl_sub{
  color: var(--color-main);
  font-size: clamp(1.8rem, calc(var(--vw-calc-lg) * 24), 2.4rem);
  display: block;
  margin-bottom: clamp(1.6rem, calc(var(--vw-calc-lg) * 32), 3.2rem);
}
.top_interview_box{
  display: flex;
  flex-wrap: wrap;
  grid-column-gap: 2.4rem;
  grid-row-gap: 2.4rem;
  margin-top: 6.4rem;
  justify-content: center;
}
.top_interview_itm{
  position: relative;
  width: calc((100% - 48px)/3);
}
.top_interview_itm:nth-child(2){
  transition-delay: 0.3s;
}
.top_interview_itm:nth-child(3){
  transition-delay: 0.6s;
}
.top_interview_itm a{
  transition: var(--transition);
}
.top_interview_itm a:hover{
  opacity: var(--opacity);
}
.top_interview_img img{
  border-radius: var(--radius-sm);
}
.top_interview_name{
  color: var(--color-main);
  font-weight: 700;
  font-family: var(--font-Rajdhani);
  width: 35px;
}

@media (max-width: 896px) {
  .top_interview_box{
    display: block;
  }
  .top_interview_itm{
    width: 80%;
    margin: 4rem auto 0;
  }
}
@media (max-width: 576px) {
  .top_sec__interview{
    padding-top: 8rem;
  }
  .top_interview_box{
    margin-top: 3.2rem;
  }
  .top_interview_itm{
    width: 100%;
    margin: 2.4rem auto 0;
  }
}


/*採用メッセージ*/
.top_sec__message{
  padding-top: 12rem;
  background: var(--color-reverse);
}
.top_message_inr{
  max-width: var(--cont-width-md);
  width: calc(100% - 2rem * 2);
  margin: auto;
  position: relative;
  z-index: 2;
}
.top_message_copy{
  font-size: 7.8rem;
  font-family: var(--font-Rajdhani);
  line-height: 1.5;
}
.top_message_box{
  margin: 6.4rem auto 0;
  max-width: 60.4rem;
}
.top_message_ttl{
  color: var(--color-text);
  line-height: 1.5;
  font-size: clamp(2.8rem, calc(var(--vw-calc-lg) * 40), 4rem);
}
.top_message_ttl_sub{
  color: var(--color-main);
  font-size: clamp(1.6rem, calc(var(--vw-calc-lg) * 20), 2rem);
  display: block;
  margin-bottom: clamp(1rem, calc(var(--vw-calc-lg) * 16), 1.6rem);
  font-weight: 700;
}
.top_message_img{
  position: sticky;
  bottom: 0;
  margin-top: -10.4rem;
}
.top_message_img img{
  height: clamp(1rem, calc(var(--vw-calc-lg) * 652), 96rem);
  object-fit: cover;
  object-position: left top;
}

@media (max-width: 896px){
  .top_message_copy{
    font-size: 5.6rem;
    line-height: 1.25;
  }
}
@media (max-width: 576px) {
  .top_sec__message{
    padding-top: 8rem;
  }
  .top_message_copy{
    font-size: 4.8rem;
  }
  .top_message_ttl{
    font-weight: 700;
  }
}

/*募集要項*/
.top_sec__new{
  padding: 10rem 0 16rem;
  border-radius: 0 0 3.2rem 3.2rem;
  background: var(--color-main);
}
.top_new_btn{
  display: flex;
  gap: 1.6rem;
  justify-content: center;
  margin-top: 6.4rem;
}
.top_sec__new_ttl{
  font-size: 4rem;
  font-weight: 700;
  text-align: center;
  color: var(--color-reverse);
}
@media (max-width: 896px) {
  .top_sec__new{
    padding: 4.8rem 0 ;
  }
  .top_new_btn{
    flex-wrap: wrap;
    gap: 2.4rem;
    margin-top: 4.8rem;
  }
}
@media (max-width: 576px) {
  .top_sec__new{
    padding: 4rem 0 ;
  }
  .top_new_btn{
    gap: 1.6rem;
    margin-top: 3.2rem;
  }
  .top_sec__new_ttl{
    font-size: 2.8rem;
  }
}

/*新卒採用*/
.new_data{
  padding: 8rem 10rem;
}
.new_data_ttl{
  font-size: 3.2rem;
  font-weight: 700;
  color: var(--color-text);
}
.new_data_itm{
  display: flex;
  align-items: center;
  gap: 2.4rem;
  border-bottom: 0.1rem solid var(--color-border);
  padding-bottom: 2.4rem;
  margin-bottom: 2.4rem;
  
}
.new_data_itm.new_data_itm__last{
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}
.new_data_itm dt{
  font-weight: 700;
  font-size: 1.8rem;
  width: clamp(10rem, calc(var(--vw-calc-lg) * 256), 20rem);;
  padding-left:  2rem;
  position: relative;
  flex-shrink: 0;
}

.new_data_itm dt::before{
  content: "";
  display: block;
  width: 1.2rem;
  height: 1.2rem;
  background: var(--color-main);
  border-radius: 50vW;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.new_data_itm_ttl{
  color: var(--color-main);
  font-weight: 700;
  display: block;
}

.new_select_box {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 4.8rem;
  margin-top: 2.4rem;
}

.new_select_itm{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  color: var(--color-reverse);
  background: var(--color-main);
  border-radius: var(--radius-sm);
  font-size: 2rem;
  font-weight: 700;
  height: 16rem;
  position: relative;
}

.new_select_itm::after{
  content: "";
  display: block;
  background: url(../img/new/new_select.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 3.6rem;
  height: 2.4rem;
  position: absolute;
  transform: rotate(270deg);
  right: -2.8rem;
  top: 0;
  bottom: 0;
  margin: auto 0;
}

.new_select_itm.new_select_itm__last::after{
  display: none;
}

.new_select_sub{
  font-size: 1.6rem;
  font-weight: 500;
  display: block;
  margin-top: 1rem;
}

.new_select_itm > *{
  width: 100%;
  text-align: center;
}

.new_btn.g_btn{
  margin: 8rem auto;
  padding: 4rem 5.6rem 4rem 8rem;
  max-width: none;
  width: fit-content;
}
.new_btn.g_btn > *{
  height: auto;
  padding: 0;
  gap: 16rem;
}

.new_btn_ttl{
  font-size: 3.2rem;
}
.new_btn_txt_en{
  font-size: 1.8rem;
  display: block;
  font-family: var(--font-Rajdhani);
}
.new_btn_txt{
  font-size: 1.6rem;
  display: block;
  margin-top: 0.8rem;
}

.new_btn.g_btn .g_arrow{
  width: 8.8rem;
  height: 8.8rem;
}

.new_btn.g_btn .g_arrow_inr::after{
  transform: translateX(-300%);
}

.new_btn.g_btn .g_arrow_inr::before,
.new_btn.g_btn .g_arrow_inr::after{
  width: 2rem;
  height: 2rem;
}

.new_btn.g_btn:hover .g_arrow_inr::before{
  animation-name: transformRightLeft2;
}

.new_btn.g_btn:hover .g_arrow_inr::after{
  animation-name: transformLeftRight2;
}

@keyframes transformLeftRight2 {
  0% {
    transform: translateX(-300%);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes transformRightLeft2 {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(300%);
  }
}

.no_recruit{
  margin: 8rem auto;
  padding: 4rem 5.6rem 4rem 8rem;
  max-width: none;
  width: fit-content;
  position: relative;
  display: block;
  width: 100%;
  max-width: 600px;
  color: var(--color-btn);
  background-color: var(--color-reverse);
  border: 0.1rem solid var(--color-border);
  border-radius: 50vw;
  overflow: hidden;
  transition: color var(--transition), background var(--transition);

}
.no_recruit > * {
    height: auto;
    padding: 0;
    gap: 16rem;
    font-size: 3.2rem;
}

.no_recruit_menu {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 267px;
  color: var(--color-btn);
  background-color: var(--color-reverse);
  border: 0.1rem solid var(--color-border);
  border-radius: 50vw;
  overflow: hidden;
  transition: color var(--transition), background var(--transition);
  font-weight: 700;
}

.new_box{
  display: flex;
  gap: 1.6rem;
  justify-content: center;
  padding: 3.2rem;
  border-radius: var(--radius-lg);
  border: 1px dashed var(--color-border);
  width: fit-content;
  margin: 0 auto 16rem;
}

@media (max-width: 896px) {
  .new_data{
    padding: 4rem 5rem;
  }
  .new_data_itm{
    flex-wrap: wrap;
    gap: 0.8rem;
    padding-bottom: 1.6rem;
    margin-bottom: 1.6rem;
  }
  .new_data_itm dt{
    width: 100%;
  }
  .new_select_box{
    display: flex;
    flex-wrap: wrap;
    gap: 3.6rem;
  }
  .new_select_itm{
    width: 100% ;
    padding: 1.6rem 2.4rem;
    height: auto;
  }
  .new_select_itm::after{
    transform: none;
    right: 0;
    left: 0;
    top: auto;
    bottom: -2rem;
    margin: auto;
  }
  .new_select_itm.new_select_itm__last::after{
    display: block;
  }
  .new_btn.g_btn{
    border-radius: 1.6rem;
    width: 100%;
    margin: 5.2rem 0 3.2rem;
    padding: 2.4rem;
  }
  .new_btn.g_btn > *{
    gap: 2rem;
  }
  .new_btn_ttl{
    font-size: 2.4rem;
  }
  .new_btn_txt_en{
    font-size: 1.6rem;
  }
  .new_btn_txt{
    font-size: 1.4rem;
  }
  .new_btn.g_btn .g_arrow{
    width: 6rem;
    height: 6rem;
  }
  .new_btn.g_btn .g_arrow_inr::before,
  .new_btn.g_btn .g_arrow_inr::after{
    width: 1.6rem;
    height: 1.6rem;
  }
  .new_box{
    margin-bottom: 8.4rem;
  }
  .no_recruit{
    border-radius: 1.6rem;
    width: 100%;
    margin: 5.2rem 0 3.2rem;
    padding: 2.4rem;
 
  }
  .no_recruit > * {
   font-size: 2.4rem;
  }
  .no_recruit_menu{
    max-width: unset;
  }
}

@media (max-width: 576px) {
  .new_data{
    padding: 2.4rem;
  }
  .new_data_ttl{
    text-align: center;
    font-size: 2.4rem;
  }
  .new_select_box{
    margin-top: 1.6rem;
  }
  .new_box{
    flex-wrap: wrap;
    gap: 0.8rem;
    justify-content: flex-start;
    padding: 1.6rem;
  }
  .new_btn.g_btn > *{
    gap: 1.6rem;
  }
}

/*会社概要*/
.about_btn_box{
  margin: 3.2rem auto 16rem;
  max-width: 107rem;
  width: calc(100% - 2rem * 2);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
  grid-column-gap: 2.4rem;
}
.about_btn_box .g_speech_inr{
  display: grid;
  grid-row: span 2;
  grid-template-columns: subgrid;
  border-radius: var(--radius-sm);
  background: var(--color-sub);
  width: min(calc(var(--vw-calc-lg) * 344), 34.4rem);
  height: 14.8rem;
  padding: 2.4rem;
  border: 0.1rem solid var(--color-sub);
  transition: var(--transition);
}
.about_btn_box .g_speech_inr:hover{
  background: var(--color-reverse);
}
.about_btn .g_arrow{
  width: 3.6rem;
  height: 3.6rem;
}
.about_btn_box .g_speech_ttl{
  font-size: clamp(1.6rem, calc(var(--vw-calc-lg) * 20), 2rem);
}

@media (max-width: 896px) {
  .about_btn_box{
    grid-template-columns: repeat(1, 1fr);
    grid-row-gap: 1.6rem;
  }
}

@media (max-width: 576px) {
  .about_btn_box{
    margin: 2.4rem auto 6.4rem;
  }
  .about_btn_box .g_speech_inr{
    width: auto;
    height: auto;
  }
  .about_btn_box .g_speech_ttl,
  .about_btn_box .g_speech_ttl_sub{
    font-size: 2rem;
  }
}


/*業務内容*/
.business_sec{
  display: flex;
  gap: 3.2rem;
}
.business_box{
  margin-left: 2.8rem;
}
.business_ttl{
  font-size: clamp(2.8rem, calc(var(--vw-calc-lg) * 32), 3.2rem);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1;
}
.business_maintenance_img{
  object-fit: contain;
  background: var(--color-sub2);
  border-radius: var(--radius-sm);
  height: min(calc(var(--vw-calc-lg) * 216), 21.6rem);
}

.business_img{
  width: min(calc(var(--vw-calc-lg) * 400), 40rem);
  flex-shrink: 0;
}

.business_img img{
  border-radius: var(--radius-lg);
}
.business_maintenance_img.business_maintenance_img__investigation{
  width: min(calc(var(--vw-calc-lg) * 400), 40rem);
  height: min(calc(var(--vw-calc-lg) * 240), 24rem);
  border-radius: var(--radius-lg);
}

@media (max-width: 1050px) {
  .business_maintenance_img.business_maintenance_img__investigation,
  .business_img{
    margin-top: 9.6rem;
  }
}

@media (max-width: 896px) {
  .business_sec{
    flex-wrap: wrap;
    gap: 1.6rem;
  }
  .business_maintenance_img.business_maintenance_img__investigation, .business_img,
  .u_img:has(.business_maintenance_img__investigation),
  .business_img{
    margin: 0 auto;
    width: min(calc(var(--vw-calc-md) * 400), 40rem);
  }
  .business_maintenance_img.business_maintenance_img__investigation{
    margin-top: 0;
    height: min(calc(var(--vw-calc-md) * 240), 24rem);
  }
  .business_ttl{
    font-size: clamp(2.4rem, calc(var(--vw-calc-md) * 28), 2.8rem);
  }
}

@media (max-width: 576px) {
  .business_maintenance_img{
    height: min(calc(var(--vw-calc-sm) * 180), 18rem);
  }
  .business_sec.business_sec__first{
    gap: 3.2rem;
  }
  .business_maintenance_img.business_maintenance_img__investigation, .business_img,
  .u_img:has(.business_maintenance_img__investigation),
  .business_img{
    width: 100%;
  }
  .business_maintenance_img.business_maintenance_img__investigation{
    height: min(calc(var(--vw-calc-sm) * 240), 24rem);
  }
  .business_box{
    margin-left: 0;
  }
}

/*座談会*/
.cross-talk_mv{
  background-image: url(../img/cross-talk/cross-talk_mv.jpg);
}
.cross-talk_topimg_box{
  display: flex;
  gap: clamp(2.4rem, calc(var(--vw-calc-lg) * 40), 4rem);
  margin: clamp(2.4rem, calc(var(--vw-calc-lg) * 72), 7.2rem) 0 0 2.4rem;
  text-align: center;
}
.cross-talk_topimg{
  width: min(calc(var(--vw-calc-lg) * 120), 12rem);
  height: min(calc(var(--vw-calc-lg) * 120), 12rem);
}
.cross-talk_topimg img{
  border-radius: 50vw;
}
.cross-talk_affiliation{
  display: block;
  margin-top: 1.6rem;
}
.cross-talk_lead {
  padding-top: 10.4rem;
  padding-bottom: 12rem;
}
.cross-talk_lead_txt {
  position: relative;
  width: fit-content;
  margin: 0 auto;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.96px;
  text-align: center;
}
.cross-talk_lead_txt::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -14.7rem;
  width: 9.9rem;
  height: 7.6rem;
  background-image: url(../img/cross-talk/ico_lead_left.svg);
  transform: translateY(-50%);
}
.cross-talk_lead_txt::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -14.3rem;
  width: 9.5rem;
  height: 8.1rem;
  background-image: url(../img/cross-talk/ico_lead_right.svg);
  transform: translateY(-50%);
}
.cross-talk_num {
  font-family: var(--font-Rajdhani);
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.72px;
}
.cross-talk_ttl {
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.78px;
}
.cross-talk_cont {
  margin-top: 6.4rem;
  padding-bottom: 8rem;
  display: flex;
  flex-direction: column;
  gap: 5.2rem;
}
.cross-talk_itm_img {
  width: 10rem;
  height: 10rem;
  flex-shrink: 0;
}
.cross-talk_itm_img img {
  border-radius: 50%;
}
.cross-talk_itm {
  display: flex;
  gap: 5.6rem;
}
.cross-talk_itm_name {
  margin-top: 0.8rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.54px;
  text-align: center;
}
.cross-talk_itm_txt {
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.48px;
}
.cross-talk_main_img {
  width: 100%;
  padding-bottom: 6.4rem;
}
.cross-talk_sideNav_box {
  padding-bottom: 12.6rem;
}

@media (max-width: 896px) {
  .cross-talk_top_left{
    width: 100%;
  }
  main:has(.g_pgHd_mv) .g_pgHd_ttl{
    width: 100%;
    padding-top: 4.8rem;
  }
  main:has(.g_pgHd_mv) .g_pgHd_ttl_sub{
    margin-bottom: 0.8rem;
  }
  .cross-talk_topimg_box{
    justify-content: center;
  }
  .cross-talk_topimg{
    width: min(calc(var(--vw-calc-md) * 120), 12rem);
    height: min(calc(var(--vw-calc-md) * 120), 12rem);
  }
  .cross-talk_topimg_box{
    gap: clamp(2.4rem, calc(var(--vw-calc-md) * 40), 4rem);
  }
  .l_main.l_main__child.l_main__discusstion::before {
    height: 170rem;
  }
  .cross-talk_lead {
    padding-top: 3.2rem;
    padding-bottom: 3.2rem;
  }
  .cross-talk_sideNav_box {
    margin-top: 0;
  }
  .cross-talk_sideNav {
    display: none;
  }
  .cross-talk_sideNav_contents {
    width: 100%;
  }
  .cross-talk_lead_txt {
    font-size: 2rem;
    line-height: 1.6;
    letter-spacing: 0.5px;
  }
  .cross-talk_lead_txt::before {
    width: 5rem;
    height: 4rem;
    left: -6.6rem;
    background-size: cover;
  }
  .cross-talk_lead_txt::after {
    width: 5rem;
    height: 4rem;
    right: -6.6rem;
    background-size: cover;
  }
  .cross-talk_num {
    font-size: 2.2rem;
    letter-spacing: 0.66px;
  }
  .cross-talk_ttl {
    font-size: 2.4rem;
    letter-spacing: 0.6px;
  }
  .cross-talk_cont {
    gap: 2.4rem;
    margin-top: 2.4rem;
    padding-bottom: 5.6rem;
  }
  .cross-talk_itm {
    gap: 1.6rem;
  }
  .cross-talk_main_img {
    padding-bottom: 5.6rem;
  }
  .cross-talk_sideNav_box {
    padding-bottom: 6.4rem;
  }
}
@media (max-width: 576px) {
  .cross-talk_topimg_box{
    margin: 5.6rem auto 0;
    gap: 0;
    justify-content: space-between;
  }
  .cross-talk_topimg{
    width: min(calc(var(--vw-calc-sm) * 96), 9.6rem);
    height: min(calc(var(--vw-calc-sm) * 96), 9.6rem);
  }
  .cross-talk_itm_img {
    width: 5.2rem;
    height: 5.2rem;
  }
  .cross-talk_itm_name {
    font-size: 1.6rem;
    letter-spacing: 0.48px;
  }
}

/*社員紹介*/
.interview_data{
  display: flex;
  gap: 2.4rem;
  margin: 7.2rem 0 0 2.4rem;
  padding-top: 3.2rem;
  position: relative;
}
.interview_data::before{
  content: "";
  display: block;
  width: 3.2rem;
  height: 0.2rem;
  background: var(--color-main);
  position: absolute;
  top: 0;
  left: 0;
}
.interview_affiliation{
  display: block;
  font-weight: 700;
  color: var(--color-text);
}
.interview_join{
  font-weight: 400;
  color: var(--color-gray);
  font-size: 1.4rem;
}
.interview_name{
  font-weight: 700;
  font-size: 2.6rem;
  color: var(--color-main);
}

/*******************************************/
/*************** interview  ****************/
/*******************************************/

.interview_sec {
  margin-bottom: 120px;
}

.interview_card_wrp {
  gap: min(4%, 64px);
  justify-content: center;
}

.interview_card {
  max-width: 29.8%;
  width: 100%;
  position: relative;
  margin-bottom: 64px;
}

.g_arrow_inr {
  display: inline-block;
}

.interview_card a:hover {
  opacity: var(--opacity);
}

.g_arrow_inr {
  display: inline-block;
}

/* Run animation only once on hover */
.interview_card:hover .g_arrow_inr,
.interview_card a:hover .g_arrow_inr {
  animation: slide-arrow 0.6s ease-in-out 1 forwards;
}

/* Keyframes */
@keyframes slide-arrow {
  0% {
    transform: translateX(0);
    opacity: 1;
  }

  50% {
    transform: translateX(8px);
    opacity: 0;
    /* fade out to the right */
  }

  51% {
    transform: translateX(-8px);
    opacity: 0;
    /* reset off left */
  }

  100% {
    transform: translateX(0);
    opacity: 1;
    /* fade back in at origin */
  }
}

.interview_card_img img {
  width: 100%;
  object-fit: cover;
  border-radius: 4px;
}

.interview_txt_wrp {
  margin: 8px 0 0 0;
}

.interview_tags {
  font-family: "Noto Sans CJK JP", "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
}

.interview_dept {
  font-family: "Noto Sans CJK JP", "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 2.6rem;
  color: var(--color-main);
}

.interview_wrk_rec {
  margin: 11px 0 0 0;
}

.interview_info {
  font-weight: 400;
  font-size: clamp(1rem, calc(var(--vw-calc-lg) * 16), 1.6rem);
  line-height: 1.5;
  letter-spacing: 3%;
  color: var(--color-text);
}

.g_arrow__interview {
  width: 3.4rem;
  height: 3.4rem;
}

@media (max-width: 896px) {
  .interview_info{
    font-size: clamp(1rem, calc(var(--vw-calc-md) * 16), 1.6rem);
  }
  .interview_card {
    max-width: 45%;
    width: 100%;
    position: relative;
    margin-bottom: 32px;
  }
}

@media (max-width: 576px) {
  .interview_info{
    font-size: clamp(1rem, calc(var(--vw-calc-sm) * 14), 1.4rem);
  }
  .interview_card {
    max-width: 100%;
    width: 100%;
    position: relative;
    margin-bottom: 32px;
  }
  .interview_data{
    margin: 7.2rem auto 0;
  }
}

/********************************************/
/************ Single interview **************/
/*******************************************/
.sec02 {
  margin-top: 80px;
}

.sec03 {
  margin-bottom: 96px;
}

.interview_hist_item {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  flex-direction: row;
}

.interview_hist_yr {
  align-self: flex-start;
  width: 100%;
  color: #009fb9;
  font-weight: 500;
  font-size: 2.4rem;
  font-family: var(--font-Rajdhani);
}

.interview_hist_yr span {
  color: #1a1a1a;
  margin-left: 15px;
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.03;
}

.interview_hist_co {
  align-self: flex-end;
  border-left: 1px solid #bfbfbf;
  margin-left: 24px;
  padding-left: 40px;
  padding-bottom: 10px;
  font-weight: 400;
}

.interview_interview_item {
  margin-bottom: 8rem;
}

.interview_interview_img img {
  margin-top: 53px;
}

.interview_interview_ttl {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  color: #1a1a1a;
  margin-bottom: 6.4rem;
}
.interview_interview_ttl.interview_interview_ttl__schedule {
  margin-bottom: 4rem;
}

.interview_interview_ttl span {
  font-family: var(--font-Rajdhani);
  color: var(--color-main);
  font-weight: 500;
  line-height: 1.5;
  font-size: 2.4rem;
  letter-spacing: 0.72px;
}

.interview_interview_txt {
  color: #1a1a1a;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.03em;
  margin-bottom: 30px;
}

.schedule_wrp {
  max-width: 874px;
  width: 100%;
  /* margin: auto; */
  flex-wrap: wrap;
  justify-content: center;
}

.schdl_timeline {
  max-width: 783px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  position: relative;
}

.timeline-line {
  content: "";
  position: absolute;
  top: 65px;
  left: 7px;
  transform: translateX(-50%);
  width: 1px;
  height: calc(100% - 140px);
  background-color: #bfbfbf;
  z-index: -1;
}

.schdl_timeline li {
  position: relative;
  display: flex;
  align-items: center;
  margin-bottom: 16px;
}

/* Time styling */
.schdl_time {
  max-width: 120px;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--color-main);
  font-family: var(--font-Rajdhani);
  /* font-size: 2.4rem; */
  font-size: clamp(
    20px,
    calc(20px + (24 - 20) * ((100vw - 372px) / (1360 - 372))),
    24px
  );
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.03em;
  position: relative;
}

.schdl_dot {
  position: absolute;
  content: "";
  width: 1.3rem;
  height: 1.3rem;
  border-radius: 50%;
  background-color: var(--color-main);
  left: 0;
  top: 44%;
}
.schdl_timeline li {
  position: relative;
}

.schdl_txt_wrp {
  background-color: #d5e7f3;
  padding: 28px 24px 36px 24px;
  flex: 1;
  border-radius: var(--radius-sm);
  margin-left: 10px;
}

.schdl_txt_wrp p {
  color: #1a1a1a;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin-top: 0;
}

.schdl_txt_wrp:has(.schdl_lbl) p {
  margin-top: 8px;
}

.schdl_lbl {
  background-color: var(--color-main);
  color: var(--color-reverse);
  border-radius: var(--radius-sm);
  font-size: 1.4rem;
  font-weight: 700;
  padding: 4px 24px;
}

.interview_msg_wrp {
  display: flex;
  background-color: var(--color-main);
  color: var(--color-reverse);
  max-width: 920px;
  border-radius: var(--radius-sm) var(--radius-sm) var(--radius-sm) 0;
  flex-direction: column;
  padding: 60px 48px;
  margin: 0 auto 90px;
  position: relative;
}

.interview_msg_wrp::after {
  content: "";
  display: block;
  width: 2.4rem;
  height: 1rem;
  background: var(--color-main);
  mask-image: url(../img/common/speech.svg);
  mask-size: contain;
  transform: scale(-3, 3);
  position: absolute;
  bottom: -1.7rem;
  left: 24px;
}

.interview_msg_wrp p {
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin-bottom: 20px;
}

.interview_msg_ttl {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: clamp(
    2.4rem,
    calc(2.4rem + (3.2rem - 2.4rem) * ((100vw - 372px) / (1360 - 372))),
    3.2rem
  );
  /* font-size: 3.2rem; */
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: center;
  margin-bottom: 40px;
}

.interview_msg_ttl span:first-child {
  position: relative;
  display: block;
  height: 10px;
  width: 10px;
  background-color: #ffff;
  margin-right: 40px;
}

.interview_msg_ttl span:first-child::before {
  position: absolute;
  content: "";
  height: 10px;
  width: 10px;
  background-color: #ffff;
  opacity: 0.6;
  left: 20px;
  top: 0;
}

.interview_msg_ttl span:last-child {
  position: relative;
  display: block;
  height: 10px;
  width: 10px;
  background-color: #ffff;
  margin-left: 40px;
}

.interview_msg_ttl span:last-child::before {
  position: absolute;
  content: "";
  height: 10px;
  width: 10px;
  background-color: #ffff;
  opacity: 0.6;
  right: 20px;
  top: 0;
}

.interview_img_lst {
  width: min(calc(var(--vw-calc-lg) * 1022), 102.2rem);
  display: block;
  margin: auto;
  border-radius: var(--radius-sm);
  position: relative;
}

.interview_img_lst:after {
  content: "";
  display: block;
  width: 16rem;
  height: 8.4rem;
  background: url(../img/common/pgHd_speech_left.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  bottom: -3.2rem;
  left: clamp(-6.4rem, calc(var(--vw-calc-lg) * -64), -0.4rem);
}

.interview_img_lst:before {
  content: "";
  display: block;
  width: 28.3rem;
  height: 81.8rem;
  background: url(../img/common/pgHd_speech_right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: -3.2rem;
  right: clamp(-6.4rem, calc(var(--vw-calc-lg) * -64), -0.4rem);
  z-index: -1;
}

.interview_img_lst_accent {
  position: relative;
}

.interview_img_lst_accent:before {
  content: "";
  display: block;
  width: 7.2rem;
  height: 4rem;
  background: url(../img/common/pgHd_speech_right.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  bottom: -38.8rem;
  left: -107px;
}

.interview_img_lst_accent:after {
  content: "";
  display: block;
  width: 7.2rem;
  height: 4rem;
  background: url(../img/common/pgHd_speech_left.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 19.8rem;
  right: -87px;
}

.interview_img_text{
  display: block;
  font-size: 12px;
  width: min(calc(var(--vw-calc-lg) * 1022), 102.2rem);
  margin: 0 auto;
  text-align: right;
}

@media (max-width: 896px) {
  .interview_img_lst:before {
    content: "";
    display: block;
    width: 7.9rem;
    height: 5rem;
    top: -1.2rem;
    right: -9%;
    z-index: -1;
  }

  .interview_img_lst:after {
    width: 4.4rem;
    height: 2.6rem;
    bottom: -5px;
    left: -6%;
  }

  .schdl_timeline::after {
    top: 8%;
    height: calc(100% - 16%);
  }

  .interview_img_lst_accent:before {
    content: "";
    display: block;
    width: 2rem;
    height: 1.125rem;
    bottom: -119px;
    left: -33px;
  }

  .interview_img_lst_accent:after {
    content: "";
    width: 2rem;
    height: 1.25rem;
    top: 59px;
    right: -35px;
  }

  .schdl_txt_wrp {
    background-color: #d5e7f3;
    padding: 16px 8px 16px 16px;
    flex: 1;
    border-radius: var(--radius-sm);
  }

  .interview_msg_wrp {
    margin: 0 16px 60px;
  }

  .interview_img_lst {
    width: 295px;
  }

  .interview_interview_ttl {
    margin-bottom: 2.4rem;
  }
  .interview_interview_img img {
    margin-top: 0;
  }
  .interview_interview_item {
    margin-bottom: 5.6rem;
  }
}

@media (max-width: 576px) {
  .schdl_timeline::after {
    top: 7%;
    left: 7px;
    height: calc(100% - 16%);
  }

  .schdl_lbl {
    padding: 4px 12px;
  }
}

@media (max-width: 376px) {
  .schdl_timeline::after {
    top: 8%;
    left: 2%;
    height: calc(100% - 16%);
  }
}

/*技術開発・DXに向けた取り組み*/
.projects_box {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 2.4rem;
  grid-row-gap: 2.4rem;
  padding: 4rem 3.2rem;
}
.projects_img{
  border-radius: var(--radius-sm);
}
.projects_bg{
  background: var(--color-bg_lg2);
  padding: 1.6rem 2.4rem;
  border-radius: var(--radius-sm);
}
.projects_box.projects_box__dx{
  display: block;
}
.projects_list_icon{
  display: block;
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 50vw;
  background: var(--color-main);
}
.projects_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 3.2rem;
  grid-row-gap: 2.4rem;
  margin-top: 2.4rem;
}
.projects_list_itm{
  background: var(--color-bg_lg2);
}
.projects_dx_wrap{
  overflow-x: auto;
  padding-bottom: 1.6rem;
}
.projects_dx_wrap::-webkit-scrollbar {
  height: 8px;
}
.projects_dx_wrap::-webkit-scrollbar-track {
  background: #ECECEC;
  border-radius: 10px;
}
.projects_dx_wrap::-webkit-scrollbar-thumb {
  background: var(--color-main);
  border-radius: 10px;
}
.projects_dx_wrap::-webkit-scrollbar-button {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
}
.projects_dx{
  background: var(--color-bg_lg2);
  padding: 1.2rem;
  margin-top: 2.4rem;
  border-radius: var(--radius-sm);
  min-width: 110.4rem;
}
.projects_dx_inr{
  background: var(--color-reverse);
  border-radius: var(--radius-sm);
  padding: 4.4rem 2rem 2rem;
}
.projects_dx_list{
  display: grid; 
  grid-template-columns: repeat(4, 1fr);
  grid-column-gap: 1.2rem;
  grid-row-gap: 1rem;
  margin-top: 1rem;
}
.projects_dx_img{
  width: min(calc(var(--vw-calc-lg) * 128), 12.8rem);
  margin: 0 auto;
}
.projects_dx_step{
  display: block;
  font-family: var(--font-Rajdhani);
}
.projects_dx_list_itm{
  width: 100%;
  display: flex;
  align-items: center;
  padding: 1.6rem 1.2rem;
  color: var(--color-reverse);
  font-weight: 700;
  font-size: 2rem;
}
.projects_dx_list_itm01{
  background: #2DB1C7;
  height: 15.6rem;
}
.projects_dx_list_itm02{
  background: #009FB9;
  height: 17.6rem;
}
.projects_dx_list_itm03{
  background: #007F94;
  height: 19.6rem;
}
.projects_dx_list_itm04{
  background: #005F6F;
  height: 21.6rem;
}
.projects_dx_list_itm.projects_dx_list_itm__next{
  height: auto;
  display: block;
  font-size: 1.4rem;
}
.projects_dx_list_box{
  background: #E2FBFF;
  border-radius: var(--radius-sm);
  color: var(--color-text);
  font-weight: 400;
  display: flex;
  gap: 1.6rem;
  padding: 1.2rem 1.6rem;
  margin-top: 1rem;
}

@media (max-width: 896px) {
  .projects_box {
    display: flex;
    flex-wrap: wrap;
    grid-column-gap: 2.4rem;
    grid-row-gap: 2.4rem;
    padding: 4rem 3.2rem;
  }
  .projects_box picture{
    margin: 0 auto;
  }
  .projects_bg{
    width: 100%;
  }
  .projects_list{
    display: flex;
    flex-wrap: wrap;
  }
}

@media (max-width: 576px) {
  .projects_bg{
    padding: 1.6rem;
  }
  .projects_list{
    grid-row-gap: 1.6rem;
  }
}

/*数字で見る*/
.data_sec {
  padding-top: 9rem;
  padding-bottom: 16rem;
  width: 100%;
  max-width: 107.1rem;
  margin: 0 auto;
}
.data_itm {
  position: relative;
  padding: 4rem 2.6rem;
  border-bottom: 1px solid #BFBFBF;
}
.data_itm:nth-of-type(3)::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: calc(100% - 80px);
  background-color: #BFBFBF;
  transform: translateY(-50%);
}
.data_itm:nth-of-type(7)::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: calc(100% - 80px);
  background-color: #BFBFBF;
  transform: translateY(-50%);
}
.data_itm:nth-last-of-type(1) {
  border-bottom: none;
}
.data_itm:nth-last-of-type(2) {
  border-bottom: none;
} 
.data_ttl {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.96px;
}
.data_interviews {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3.6rem;
  margin-top: 2.4rem;
}
.data_interviews_img {
  width: 42rem;
}
.data_value {
  text-wrap: nowrap;
}
.data_num_lg {
  font-family: var(--font-Rajdhani);
  font-size: 14rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 4.2px;
}
.data_num {
  font-family: var(--font-Rajdhani);
  font-size: 10.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 3.12px;
}
.data_unit_lg {
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 2.15;
  letter-spacing: 1.44px;
}
.data_unit {
  font-size: 4rem;
  font-weight: 700;
  line-height: 2.2;
  letter-spacing: 1.2px;
}
.data_note {
  color:#BFBFBF;
  font-size: 1.6rem;
  line-height: 1.75;
  text-align: center;
}
.data_age {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4rem;
  margin-top: 5.2rem;
}
.data_age_img {
  width: 6rem;
}
.data_overtime {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4rem;
  margin-top: 3.4rem;
}
.data_overtime_img {
  width: 21.9rem;
}
.data_newgraduate {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  top: -3rem;
  gap: 12rem;
  height: 25rem;
}
.data_newgraduate_img {
  width: 25rem;
}
.data_retention {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7.8rem;
  margin-top: 2.4rem;
}
.data_retention_img {
  width: 35rem;
}
.data_retention_value {
  margin-top: 3.2rem;
}
.data_pto {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3.2rem;
  margin-top: 2.6rem;
}
.data_pto_img {
  width: 18.4rem;
}
.data_summer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4.6rem;
  margin-top: 2.4rem;
}
.data_summer_img {
  width: 20.6rem;
}
@media (max-width: 896px) {
  .data_sec {
    padding: 4rem 1.6rem 6.4rem;
  }
  .data_ttl  {
    font-size: 2rem;
    line-height: 1.6;
    text-align: center;
  }
  .data_itm {
    padding: 2.4rem 0;
  }
  .data_itm:nth-of-type(1) {
    padding-top: 0;
  }
  .data_itm:nth-of-type(3)::before {
    display: none;
  }
  .data_itm:nth-of-type(7)::before {
    display: none;
  }
  .data_itm:nth-last-of-type(2) {
  border-bottom: 1px solid var(--color-border);
  } 
  .data_interviews {
    gap: 2.4rem;
  }
  .data_interviews_img {
    width: 16.4rem;
  }
  .data_num_lg {
    font-size: 7.2rem;
    letter-spacing: 2.16px;
  }
  .data_num {
    font-size: 5.6rem;
    letter-spacing: 1.68px;
  }
  .data_unit_lg {
    font-size: 2.8rem;
    line-height: 1.6;
    letter-spacing: 0.56px;
  }
  .data_unit {
    font-size: 2.4rem;
  }
  .data_note {
    font-size: 1.4rem;
    line-height: 1.7;
  }
  .data_age {
    margin-top: 1.6rem;
    gap: 1.6rem;
  }
  .data_age_img {
    width: 4rem;
  }
  .data_value {
    text-align: center;
  }
  .data_overtime {
    gap: 3.2rem;
    margin-top: 1.6rem;
  }
  .data_overtime_img {
    width: 13.4rem;
  }
  .data_newgraduate {
    position: static;
    gap: 0.8rem;
    margin-top: 1.6rem;
    height: auto;
  }
  .data_newgraduate_img {
    width: 11.4rem;
  }
  .data_retention {
    gap: 1.6rem;
  }
  .data_retention_img {
    width: 17.2rem;
  }
  .data_retention_value {
    margin-top: 0;
  }
  .data_pto {
    margin-top: 2.4rem;
  }
  .data_pto_img {
    width: 12.3rem;
  }
  .data_summer {
    gap: 2.4rem;
  }
  .data_summer_img {
    width: 13.6rem;
  }
}

/*ワークライフバランス*/
/* 働く環境を知る(2コラム) */
.about_btn_box.about_btn_box__2col {
  max-width: 70.533rem;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 896px) {
  .about_btn_box.about_btn_box__2col {
    max-width: none;
    grid-template-columns: repeat(1, 1fr);
  }
}

/* worklife */
.worklife_sec {
  padding-top: 6.4rem;
}
.worklife_itm {
  padding: 3.2rem;
  border-radius: 8px;
  background: linear-gradient(90deg, #E9F7F9 0%, #E5F5FF 100%);
}
.worklife_itm_ttl {
  padding-left: 8rem;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.5px;
}
.worklife_itm_ttl.u_ic::before {
  top: 50%;
  left: 0;
  width: 6.4rem;
  height: 6.4rem;
  transform: translateY(-50%);
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 4px;
}
.worklife_itm_slide .worklife_itm_ttl.u_ic::before {
  background-image: url(../img/worklife/ico_slide.svg);
}
.worklife_itm_overwork .worklife_itm_ttl.u_ic::before {
  background-image: url(../img/worklife/ico_overwork.svg);
}
.worklife_itm_holiday .worklife_itm_ttl.u_ic::before {
  background-image: url(../img/worklife/ico_holiday.svg);
}
.worklife_itm_others .worklife_itm_ttl.u_ic::before {
  background-image: url(../img/worklife/ico_others.svg);
}
.worklife_itm_txt {
  margin-top: 3.6rem;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.48px;
}
@media (max-width: 896px) {
  .worklife_sec {
    padding-top: 3.2rem;
  }
  .worklife_itm {
    padding: 2.4rem;
  }
  .worklife_itm_txt {
    margin-top: 3rem;
  }
  .worklife_itm_ttl {
    padding-left: 7.2rem;
    font-size: 1.8rem;
    line-height: 1.68;
    letter-spacing: 0.54px;
  }
  .worklife_itm_ttl.u_ic::before {
    width: 5.6rem;
    height: 5.6rem;
  }
}

/*インターンシップ情報*/
.intern_sec_lead {
  padding-top: 12.9rem;
  padding-bottom: 12rem;
}
.intern_lead_hd {
  position: relative;
  width: fit-content;
  margin: 0 auto;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.2px;
}
.intern_lead_hd::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -17.9rem;
  width: 9.9rem;
  height: 7.6rem;
  background-image: url(../img/intern/ico_blocks_left.svg);
  background-size: cover;
  transform: translateY(-50%);
}
.intern_lead_hd::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -16.6rem;
  width: 9.5rem;
  height: 8.1rem;
  background-image: url(../img/intern/ico_blocks_right.svg);
  background-size: cover;
  transform: translateY(-50%);
}
.intern_lead_hd small {
  font-size: 3.2rem;
  letter-spacing: 0.96px;
}
.intern_lead_txt {
  margin-top: 1.6rem;
  font-size: 1.6rem;
  line-height: 2.05;
  letter-spacing: 0.48px;
}
.intern_sec_overview {
  padding: 6.4rem;
  background-color: var(--color-sub);
}
.intern_overview_inr {
  padding: 8rem 10rem;
  background-color: var(--color-reverse);
  border-radius: 8px;
}
.intern_overview_hd {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.96px;
}
.intern_overview_list {
  margin-top: 6.4rem;
}
.intern_overview_itm {
  position: relative;
  padding: 2.4rem 0;
  display: flex;
  align-items: center;
  gap: 2.4rem;
}
.intern_overview_itm::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0.1rem;
  background-color: var(--color-border);
}
.intern_overview_itm:nth-last-of-type(1):after {
  display: none;
}
.intern_overview_itm:nth-of-type(1) {
  padding-top: 0;
}
.intern_overview_itm_ttl {
  position: relative;
  min-width: 22rem;
  padding-left: 2rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.54px;
}
.intern_overview_itm_ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 50%;
  background-color: var(--color-main);
  transform: translateY(-50%);
}
.intern_overview_itm_ttl small {
  font-size: 1.4rem;
}
.intern_overview_itm_detail {
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.48px;
}
.intern_sec_review {
  padding: 12rem 6.4rem;
}
.intern_review_hd {
  position: relative;
  width: fit-content;
  margin: 0 auto;
  padding-bottom: 1.6rem;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.96px;
}
.intern_review_hd::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 6.4rem;
  height: 0.6rem;
  background-color: var(--color-main);
  border-radius: 999px;
  transform: translateX(-50%);
}
.intern_review_list {
  width: 100%;
  max-width: 123.2rem;
  margin: 0 auto;
}
.intern_review_itm {
  position: relative;
  display: flex;
  gap: 2.4rem;
  align-items: center;
  padding: 2.4rem 2.2rem;
  background-color: var(--color-sub);
  border-radius: 4px;
}
.intern_review_itm::before {
  content: "";
  position: absolute;
  bottom: -1rem;
  left: 0;
  width: 7.6rem;
  height: 1.9rem;
  background-image: url(../img/intern/ico_bbl_tail.svg);
}
.intern_review_acd {
  position: absolute;
  top: 50%;
  right: 2.2rem;
  width: 1.6rem;
  height: 1.6rem;
  cursor: pointer;
  transform: translateY(-50%);
}
.intern_review_acd::before,
.intern_review_acd::after {
  width: 1.6rem;
  height: 0.2rem;
  background-color: var(--color-reverse);
  border-radius: var(--bdrs-infinite);
  inset: 0;
  margin: auto;
  transition: var(--transition); 
}
.intern_review_acd::before {
  rotate: 90deg;
}
.js_acd.js_open .intern_review_acd::before {
rotate: 0deg;
}
.intern_review_itm_txt {
  padding-right: 4rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.js_acd.js_open .intern_review_itm_txt {
  display: block;
  -webkit-line-clamp: none;
  overflow: visible;
  text-overflow: initial;
}
.intern_review_list {
  gap: 4rem;
}
.intern_review_itm_img img {
  border-radius: 50%;
}
.intern_sec_info {
  padding: 6.4rem;
  background-color: var(--color-sub);
}
.intern_info_year {
  display: block;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.72px;
  text-align: center;
}
.intern_info_hd {
  position: relative;
  width: fit-content;
  margin: 0 auto;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.96px;
}
.intern_info_hd::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -3.4rem;
  width: 1rem;
  height: 2.4rem;
  background-image: url(../img/intern/ico_ttl_left.svg);
  transform: translateY(-50%);
}
.intern_info_hd::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -3.4rem;
  width: 1rem;
  height: 2.4rem;
  background-image: url(../img/intern/ico_ttl_right.svg);
  background-size: cover;
  transform: translateY(-50%);
}
.intern_info_inr {
  padding: 8rem 10rem;
  background-color: var(--color-reverse);
  border-radius: 8px;
}
.intern_info_ttl {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.96px;
}
.intern_info_itm {
  position: relative;
  display: flex;
  align-items: center;
  gap: 2.4rem;
  padding: 2.4rem 0;
}
.intern_info_itm::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0.1rem;
  background-color: var(--color-border);
}
.intern_info_itm:nth-of-type(1) {
  padding-top: 0;
}
.intern_info_itm:nth-last-of-type(1)::after {
  display: none;
}
.intern_info_itm_ttl {
  position: relative;
  min-width: 22rem;
  padding-left: 2rem;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.54px;
}
.intern_info_itm_ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 50%;
  background-color: var(--color-main);
  transform: translateY(-50%);
}
.intern_info_itm_detail {
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.48px;
}
.intern_info_itm_detail__note {
  margin-top: 1.6rem;
  font-size: 1.4rem;
  line-height: 1.75;
  letter-spacing: 0.42px;
}
.intern_info_img {
  width: min(calc(var(--vw-calc-lg) * 290), 29rem);
}
.intern_pdf_btn {
  max-width: 31.3rem;
  margin-left: auto;
  margin-right: auto; 
}
.intern_pdf_btn.u_ic::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1rem;
  width: 4.4rem;
  height: 4.4rem;
  background-image: url(../img/intern/ico_download.svg);
  background-size: cover;
  transform: translateY(-50%);
  z-index: 3;
}
.intern_application_btn {
  color: var(--color-reverse);
  background-color: var(--color-main); 
  border: 0.1rem solid var(--color-main);
  max-width: 44.2rem; 
  margin-top: 4rem;
}
.intern_application_btn > * {
  justify-content: center;
  padding-left: 1rem;
}
.intern_application_btn::before {
  background: var(--color-reverse); 
}
.intern_application_btn.u_ic::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1rem;
  width: 4.4rem;
  height: 4.4rem;
  background-image: url(../img/intern/ico_tab.svg);
  background-size: cover;
  transform: translateY(-50%);
  z-index: 3;
}
@media (any-hover: hover) {
  .intern_pdf_btn:hover::after {
    background-image: url(../img/intern/ico_download_reverse.svg);
  }
  
  .intern_application_btn:hover,
  .intern_application_btn:focus-visible {
    color: var(--color-main); 
    border-color: var(--color-main);
  }
  .intern_application_btn:hover::after {
    background-image: url(../img/intern/ico_tab_reverse.svg);
  }
}
.intern_sec_application {
  padding: 12rem 0 16rem;
  background-color: var(--color-reverse);
}
.intern_application_inr {
  width: fit-content;
  margin: 0 auto;
}
.intern_application_hd {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
}
.intern_application_hd.u_ic::before {
  top: 50%;
  left: -3.9rem;
  width: 1rem;
  height: 2.4rem;
  background-image: url(../img/intern/ico_ttl_left.svg);
  background-size: contain;
  background-repeat: no-repeat;
  transform: translateY(-50%);
}
.intern_application_hd.u_ic::after {
  top: 50%;
  right: -3.9rem;
  width: 1rem;
  height: 2.4rem;
  background-image: url(../img/intern/ico_ttl_right.svg);
  background-size: contain;
  background-repeat: no-repeat; 
  transform: translateY(-50%);
}
@media (max-width: 1120px) {
  .intern_lead_hd {
    font-size: 3.2rem;
  }
  .intern_lead_hd small {
    font-size: 2.4rem;
  }
  .intern_lead_hd::before {
    left: -12.8rem;
    width: 9.1rem;
    height: 6.2rem;
  }
  .intern_lead_hd::after {
    right: -12.3rem;
    width: 8.7rem;
    height: 7.3rem;
  }
  .intern_lead_txt {
    font-size: 1.5rem;
  }
}
@media (max-width: 896px) {
  .intern_sec_lead {
    padding-top: 3.2rem;
    padding-bottom: 4.8rem;
  }
  .intern_lead_hd {
    font-size: 2rem;
  }
  .intern_lead_hd small {
    font-size: 1.6rem;
  }
  .intern_lead_hd::before {
    left: -6.7rem;
    width: 5.1rem;
    height: 3.9rem;
  }
  .intern_lead_hd::after {
    right: -6.9rem;
    width: 5.3rem;
    height: 4.5rem;
  }
  .intern_lead_txt {
    font-size: 1.4rem;
    line-height: 1.7;
    letter-spacing: 0.42px;
  }
  .intern_sec_overview {
    padding: 1.6rem;
  }
  .intern_overview_inr {
    padding: 2.4rem;
  }
  .intern_overview_hd {
    font-size: 2.4rem;
    line-height: 1.57;
    text-align: center;
  }
  .intern_overview_list {
    margin-top: 4rem;
  }
  .intern_overview_itm {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.8rem;
    padding: 1.6rem;
  }
  .intern_sec_review {
    padding: 4.8rem 1.6rem 5.6rem;
  }
  .intern_review_list {
    gap: 3.2rem 0;
  }
  .intern_review_hd {
    font-size: 2.4rem;
  }
  .intern_review_itm {
    padding: 1.6rem;
    gap: 1.6rem;
  }
  .intern_review_itm_txt {
    padding-right: 3.2rem;
  }
  .intern_review_acd {
    right: 1.6rem;
  }
  .intern_sec_info {
    padding: 2.4rem 1.6rem;
  }
  .intern_info_year {
    font-size: 2rem;
    line-height: 1.6;
  }
  .intern_info_inr {
    padding: 2.4rem;
  }
  .intern_info_ttl {
    font-size: 2.4rem;
    line-height: 1.57;
    letter-spacing: 0.6px;
    text-align: center;
  }
  .intern_info_ttl small {
    font-size: 2rem;
    line-height: 1.6;
    letter-spacing: 0.5px;
  }
  .intern_info_itm {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.8rem;
    padding: 1.6rem;
  }
  .intern_info_itm_detail__note {
    margin-top: 0.4rem;
  }
  .intern_sec_application {
    padding: 4.8rem 1.6rem 6.4rem;
  }
  .intern_application_hd {
    width: fit-content;
    font-size: 2.4rem;
    text-align: center;
    margin: 0 auto;
  }
  .intern_application_hd.u_ic::before {
    top: auto;
    bottom: 0;
    left: -2.15rem;
    width: 0.9rem;
    height: 2.2rem;
  }
  .intern_application_hd.u_ic::after {
    top: auto;
    bottom: 0;
    right: -2.05rem;
    width: 0.9rem;
    height: 2.2rem;
  }
  .intern_application_inr {
    width: 100%;
  }
  .intern_application_btn {
    margin-top: 2.4rem;
    margin-left: auto;
    margin-right: auto;
  }
  .intern_application_btn > * {
    justify-content: space-between;
    padding-left: 5.6rem;
  }
}
@media (max-width: 576px) {
  .intern_pdf_btn,
  .intern_application_btn {
    max-width: none;
  }
}

/*お知らせ*/
/*******************************************/
/*************** NEWS  ****************/
/*******************************************/
.news_wrap {
  max-width: 1232px;
  width: 100%;
  margin: auto;
}

.news_box {
  position: relative;
  box-shadow: var(--box-shadow);
  background-color: #fff;
  margin-bottom: 16px;
  margin-left: 16px;
  margin-right: 16px;
}

.news_box a {
  position: relative;
  max-width: 100%;
  width: 100%;
  padding: 22px 90px 22px 39px;
}

.news_box a::after {
  position: absolute;
  content: "";
  height: 7px;
  width: 7px;
  border-top: 2px solid #1a1a1a;
  border-left: 2px solid #1a1a1a;
  top: 41%;
  right: 44px;
  transform: rotate(130deg) translateY(-50%);
}

.news_date {
  color: var(--color-main);
  font-family: "Rajdhani", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.03em;
  margin-right: 39px;
  flex-shrink: 0;
}

.news_ttl {
  color: #1a1a1a;
  font-family: "Noto Sans CJK JP", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.03em;
}

@media (max-width: 576px) {
  .news_box {
    margin-left: 16px;
    margin-right: 16px;
    padding: 0;
  }
  .news_box a {
    padding-right: 65px;
  }

  .news_box a::after {
    top: 45%;
    right: 37px;
    transform: rotate(130deg) translateY(-45%);
  }

  .news_date {
    margin-right: 0;
    padding: 16px 0 0 16px;
  }
  .news_ttl {
    padding: 0 0 20px 17px;
    line-height: 1.5;
  }
}

/********************************************/
/*************** NEWS Single ****************/
/*******************************************/
.news_single_wrp {
  padding-bottom: 16rem;
}

.news_main_ttl {
  font-size: 4rem;
  padding-bottom: 11.3rem;
  padding-right: clamp(24rem, calc(var(--vw-calc-lg) * 400), 48rem);
}

.news_img_main {
  border-radius: 4px;
  max-width: 1070px;
  object-fit: cover;
  margin: auto;
}

/* .news_content_wrp {
  margin-top: 4rem;
} */

.news_content_full {
  width: 100%;
}

.news_content_full h3 {
  position: relative;
  font-weight: 700;
  font-style: normal;
  font-size: 3.2rem;
  line-height: 4.8rem;
  letter-spacing: 0;
  text-indent: 4.6rem;
  margin-bottom: 40px;
}

.news_content_full h3::before {
  position: absolute;
  content: "・";
  color: var(--color-main);
  width: 7px;
  height: 7px;
  top: -10%;
  left: -50px;
}

.news_content_full p {
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.03em;
  padding: 0 0 0 10px;
}

.news_content_left,
.news_content_right {
  width: 48%;
  margin-left: 8px;
}

.news_content_right {
  padding: 0 0 0 55px;
}

.news_content_left picture {
  display: block;
  max-width: 576px;
  width: 100%;
  object-fit: cover;
  border-radius: 4px;
}

.news_content_right h4 {
  position: relative;
  font-weight: 700;
  font-size: 2.8rem;
  line-height: 4.2rem;
  letter-spacing: 0;
  text-indent: 35px;
  margin: 12px 0 40px 0;
}

.news_content_right h4::before {
  position: absolute;
  content: "・";
  color: var(--color-main);
  width: 7px;
  height: 7px;
  top: -2%;
  left: -44px;
}

.news_content_right p {
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.03em;
}

.news_nav_btn_wrp {
  margin-top: 11.2rem;
  margin-bottom: 4rem;
}

.news_nav_btn {
  border: 1px solid #bcbcbc;
  border-radius: 4px;
  width: 415px;
  display: flex;
  min-height: 120px;
  background: var(--color-reverse);
}

.nav_txt_wrp {
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.5;
  letter-spacing: 0.015em;
  text-transform: uppercase;
  max-width: 310px;
  width: 100%;
}

.nav_txt_wrp span{
  display: block;
  width: 100%;
}

.news_nav_prev {
  margin-right: 24px;
}

.news_nav_prev .nav_txt_wrp {
  padding: 16px 40px 16px 0;
}

.news_nav_nxt .nav_txt_wrp {
  text-align: right;
  justify-content: flex-end;
  padding: 16px 0px 16px 40px;
}

.g_arrow__news {
  width: 36px;
  height: 36px;
  align-self: center;
  margin: 0 16px;
}

.g_arrow_inr.g_arrow_inr_right::before,
.g_arrow_inr.g_arrow_inr_right::after {
  transform: rotate(175deg);
  transform-origin: center;
}

/* Prev arrow hover animation (right → left) */
.news_nav_prev:hover .g_arrow_inr {
  animation: slide-arrow-prev 0.6s ease-in-out 1 forwards;
}

/* Next arrow hover animation (right → right, current behavior) */
.news_nav_nxt:hover .g_arrow_inr {
  animation: slide-arrow-next 0.6s ease-in-out 1 forwards;
}

/* Keyframes for Prev (right → left) */
@keyframes slide-arrow-prev {
  0% {
    transform: translateX(0);
    opacity: 1;
  }

  50% {
    transform: translateX(-8px);
    /* move left */
    opacity: 0;
  }

  51% {
    transform: translateX(8px);
    /* reset off right */
    opacity: 0;
  }

  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

/* Keyframes for Next (right → right, current) */
@keyframes slide-arrow-next {
  0% {
    transform: translateX(0);
    opacity: 1;
  }

  50% {
    transform: translateX(8px);
    /* move right */
    opacity: 0;
  }

  51% {
    transform: translateX(-8px);
    /* reset off left */
    opacity: 0;
  }

  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

.news_nav_back {
  display: block;
  margin: auto;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .03px;
  transition: var(--transition);
}

.news_nav_back:hover{
  background: var(--color-text);
  color: var(--color-reverse);
}

@media (max-width: 896px) {

  .news_single_wrp {
    padding-bottom: 6rem;
  }

  .news_main_ttl {
    font-size: 2.4rem;
    margin: 0 16px;
    padding-right: 0;
    padding-bottom: 4rem;
  }

  .news_content_full h3 {
    text-indent: 2.3rem;
  }

  .news_content_full h3::before {
    top: -2%;
    left: -31px;
  }

  .news_content_right h4::before {
    left: -23px;
  }

  .news_content_left,
  .news_content_right {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .news_content_right h4 {
    text-indent: 17.5px;
  }

  .news_content_left picture {
    max-width: 100%;
    width: 100%;
  }

  .news_content_right {
    padding: 0;
  }

  .news_nav_prev {
    margin-right: 0;
    margin-bottom: 24px;
  }

  .news_nav_btn {
    margin: 0 auto 24px auto;
  }

  .news_nav_btn_wrp {
    margin-bottom: 1.6rem;
  }

  .news_nav_btn {
    width: 343px;
  }

  .g_arrow__news {
    width: 45px;
    height: 36px;
  }
  /* .news_content_wrp {
    margin-top: 3.2rem;
  } */
}
@media (max-width: 576px) {
  .news_nav_btn{
    width: 100%;
  }
}

/*よくあるご質問*/
.faq_sec {
  display: flex;
  flex-direction: column;
  gap: 6.4rem;
  max-width: 102.2rem; 
  width: calc(100% - 2rem * 2);
  margin: 0 auto;
  padding-top: 4rem;
  padding-bottom: 16rem;
}
.faq_ttl {
  margin-bottom: 3.2rem;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.78px;
}
.faq_list {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}
.faq_itm {
  padding: 2.4rem 4rem;
  background-color: var(--color-sub);
  border-radius: 4px;
}
.faq_itm_question {
  padding-left: 6.2rem;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.68;
  letter-spacing: 0.54px;
}
.faq_itm_question.u_ic::before {
  content: "Q.";
  top: 50%;
  left: 0;
  color: var(--color-main);
  font-family: var(--font-Rajdhani);
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.19px;
  transform: translateY(-50%);
}
.faq_acd_ic {
  position: absolute;
  top: 1.4rem;
  right: 2.4rem;
}
.faq_acd_ic.u_ic::before,
.faq_acd_ic.u_ic::after {
    width: 2.4rem;
    height: 0.3rem;
    background-color: var(--color-reverse);
    inset: 0;
    margin: auto;
    transition: var(--transition);
}
.faq_acd_ic.u_ic::before {
  rotate: 90deg;
}
.faq_itm.js_open .faq_acd_ic.u_ic::before {
  rotate: 0deg;
}
.faq_itm_answer {
  display: none;
  margin-top: 2.4rem;
  padding-left: 4.5rem;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.48px;
}
.faq_itm_answer.u_ic::before {
  content: "A.";
  top: 0;
  left: 0;
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.14px;
}
@media (max-width: 896px) {
  .faq_sec {
    gap: 3.2rem;
    padding-top: 3.2rem;
    padding-bottom: 6.4rem;
  }
  .faq_itm {
    padding: 1.6rem;
    border-radius: unset;
    box-shadow: var(--box-shadow);
  }
  .faq_ttl {
    margin-bottom: 1.6rem;
    font-size: 2.4rem;
    line-height: 1.57;
    letter-spacing: 0.6px;
  }
  .faq_itm_question {
    padding-left: 2.8rem;
    padding-right: 5.6rem;
    font-size: 1.6rem;
    line-height: 1.75;
    letter-spacing: 0.48px;
  }
  .faq_itm_question.u_ic::before {
    top: 0;
    font-size: 2.4rem;
    letter-spacing: 0.72px;
    transform: translateY(0);
  }
  .faq_itm_answer {
    margin-top: 1rem;
    padding-left: 2.8rem;
  }
  .faq_itm_answer.u_ic::before {
    font-size: 1.8rem;
    line-height: 1.75;
    letter-spacing: 0.54px;
  }
  .faq_acd_ic {
    right: 2.8rem;
  }
  .faq_acd_ic.u_ic::before,
  .faq_acd_ic.u_ic::after {
    width: 1.6rem;
  }
}

/*教育・福利厚生*/
.employeebenefits_box {
  padding: 6rem 3.2rem;
}
.employeebenefits_box_inr{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 2.4rem;
  grid-row-gap: 2.4rem;
  padding-top: 4.2rem;
}

.employeebenefits_bg {
  background: var(--color-bg_lg2);
  padding: 3.2rem;
  border-radius: var(--radius-sm);
}

.about_btn_box.about_btn_box__2col{
  grid-template-columns: repeat(2, 1fr);
  width: calc((100% - 4.8rem) / 3 * 2  + 2.4rem );
}
@media (max-width:896px){
  .employeebenefits_box {
    padding: 2.4rem;
  }
  .employeebenefits_box_inr{
    display: flex;
    flex-wrap: wrap;
    grid-column-gap: 2.4rem;
    grid-row-gap: 2.4rem;
  }
  .employeebenefits_bg{
    width: 100%;
    padding: 2.4rem;
  }
  .about_btn_box.about_btn_box__2col{
      grid-template-columns: repeat(1, 1fr);
      width: calc(100% - 2rem * 2);
  }
}

/*キーワードで知る首都高技術*/
.keyword_sec{
  padding: 6.4rem 0 10.4rem;
  background: var(--color-bg_lg3);
}
.keyword_sec .l_wrap_inr{
  max-width: 107rem;
}
.keyword_box{
  display: flex;
  gap: 3.2rem;
}
.keyword_ttl{
  font-size: 4rem;
  font-weight: 700;
  color: var(--color-main);
  line-height: 1.5;
}
.keyword_subttl{
  font-size: 2rem;
  font-family: var(--font-Rajdhani);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.2;
}
.keyword_ttl__pd{
  margin-left: 3.2rem;
}
.keyword_speech{
  background: var(--color-reverse);
  padding: 1.6rem;
  position: relative;
}
.keyword_speech::after{
  content: "";
  display: inline-block;
  width: min(calc(var(--vw-calc-lg) * 52), 5.2rem);
  height: min(calc(var(--vw-calc-lg) * 30), 3rem);
  background: var(--color-reverse);
  mask-image: url(../img/keyword/keyword_speech.svg);
  mask-size: cover;
  background-repeat: no-repeat;
  position: absolute;
  transition: var(--transition);
  left: 0;
  bottom: max(calc(var(--vw-calc-lg) * -30), -3rem);
}
.keyword_speech.keyword_speech__right::after{
  transform: scale(-1, 1);
  right: 0;
  left: auto;
}
.keyword_speech__left{
  border-radius: 0.8rem 0.8rem 0.8rem 0;
}
.keyword_speech__right{
  border-radius: 0.8rem 0.8rem 0 0.8rem;
}
.keyword_text_bg{
  color: var(--color-text);
  font-weight: 700;
  line-height: 1.6;
  background: var(--color-bg_lg4);
  display: block;
  width: fit-content;
  padding: 0 1rem;
  border-radius: var(--radius-sm);
}
.keyword_speech__sec01{
  padding-bottom: 20.8rem;
  flex: 1;
}
.keyword_speech__sec01::before{
  content: "";
  display: block;
  background: url(../img/keyword/keyword_sec01.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 15.2rem;
  height: 16rem;
  position: absolute;
  bottom: 2.6rem;
  right: 3.2rem;
}
.keyword_speech__sec02{
  flex: 2;
}

.keyword_sec02img{
    width: 48rem;
    margin: 2.4rem auto 0;
}

.keyword_speech__mask{
  background: var(--color-reverse);
  padding: 1.6rem 0 0 1.6rem;
  width: calc((100% - 3.2rem)/2);
  height: 29.2rem;
  
  mask-size: contain;
  mask-repeat: no-repeat;
  position: relative;
}

.keyword_speech__sec03{
  mask-image: url(../img/keyword/keyword_mask_left.svg);
}

.keyword_speech__sec03::before{
  content: "";
  display: block;
  background: url(../img/keyword/keyword_sec03.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 12.8rem;
  height: 17.6rem;
  position: absolute;
  top: 4.8rem;
  right: 4.8rem;
}

.keyword_speech__sec04{
  mask-image: url(../img/keyword/keyword_mask_right.svg);
}

.keyword_speech__sec04::before{
  content: "";
  display: block;
  width: min(calc(var(--vw-calc-lg) * 288), 28.8rem);
  height: 20rem;
  background: url(../img/keyword/keyword_sec04.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: right;
  position: absolute;
  bottom: 0;
  right: 0;
}

.keyword_speech__sec05{
  padding-bottom: 12.8rem;
}

.keyword_sec05img{
  width: min(calc(var(--vw-calc-lg) * 480), 48rem);
}
@media (max-width: 1000px) {
  .keyword_speech__sec03{
    mask-image: url(../img/keyword/keyword_mask_left_999.svg);
  }
  .keyword_speech__sec04{
    mask-image: url(../img/keyword/keyword_mask_right_999.svg);
  }
}

@media (max-width: 896px) {
  .keyword_box{
    display: block;
  }
  .keyword_speech::after{
    width: min(calc(var(--vw-calc-md) * 52), 5.2rem);
    height: min(calc(var(--vw-calc-md) * 30), 3rem);
    bottom: max(calc(var(--vw-calc-md) * -30), -3rem);
  }
  .keyword_speech__sec01{
    padding-bottom: 1.6rem;
  }
  .keyword_sec02img{
    width: 80%;
    margin: 1.6rem auto 0;
  }
  .keyword_speech.keyword_speech__sec02{
    padding-bottom: 2.4rem;
  }
  .keyword_sec03img{
    width: 25%;
    margin: 2.4rem auto 0;
  }
  .keyword_speech.keyword_speech__sec04_sp{
    padding-bottom: 0;
  }
  .keyword_sec04img{
    width: 75%;
    margin: 4rem auto 0;
  }
}

@media (max-width: 576px) {
  .keyword_subttl{
    font-size: 1.6rem;
  }
  .keyword_ttl{
    font-size: 3.2rem;
  }
  .keyword_text_bg{
    font-size: 1.8rem;
  }
  .keyword_speech__sec01{
    padding-bottom: 19.2rem;
  }
  .keyword_speech__sec01::before{
    right: 1.6rem;
  }
  .keyword_ttl__pd{
    margin-left: 2.4rem;
  }
  .keyword_sec03img {
    width: 35%;
  }
}