
.top_main_text,
.top_title_size,
.top_text_size_1,
.top_text_size_2,
.top_text_size_3,
.top_recruit_subtitle,
.top_contact_text{
    font-weight: 500;
    font-family: "Noto Sans JP", sans-serif;
}

.top_title_size{
    font-size: 3.3rem;
    letter-spacing: 0;
    line-height: 1.4;
}

.top_text_size_1{
    font-size: 2.5rem;
}

.top_text_size_2,
.top_main_text{
    font-size: 1.6rem;
}

.top_text_size_3{
    font-size: 1.4rem;
}


.top_text_box_width{
    width:32rem ;
}

.top_text_box_width_1{
    width:34.8rem ;
}


.text_height{
    line-height:1.8 ;
}

.text_height_2{
    line-height:1.5 ;
}



.main_visual_flex,
.top_arc_layout_flex,
.top_arc_wrapper_space_flex,
.top_arc_button_layout_flex,
.top_about_flex_outside,
.top_about_flex_inside,
.top_se_layout_flex,
.top_works_box_layout,
.top_recruit_layout_flex,
.top_recruit_button_layout_flex,.top_arc_button_layout_flex_2{
    display: flex;  
}


.top_arc_button_layout_flex{
    align-items: center;
    gap: 1.4rem;
}

.top_arc_button_layout_flex_2{
    align-items: end;
    gap: 1.4rem;
}

.arrow_anchor_button,.arrow_anchor_button_white{
    display: block;
    width:4.8rem ;
    height:4.8rem  ;
    border-radius: 100%;
}

.arrow_anchor_button{
    border:#000000 0.2rem solid;
}

.arrow_anchor_button_white{
    border:#fff 0.2rem solid;
}


.top_arc_text_hover:hover{
    color: #003A98;
}


.banner_text_order:hover{
    background-color: #003A98;
    color:#fff  ;
}

.arrow_anchor_button_white:hover,.arrow_anchor_button:hover {
  background-color: #003A98;
  border-color:#003A98 ;

}


.arrow_anchor_button_white:hover .top_arrow_white_1,
.arrow_anchor_button_white:hover .top_arrow_white_2,
.arrow_anchor_button_white:hover .top_arrow_white_3 {
  background-color: #fff; 
}


.arrow_anchor_button:hover .top_arrow_black_1,
.arrow_anchor_button:hover .top_arrow_black_2,
.arrow_anchor_button:hover .top_arrow_black_3 {
  background-color: #fff;
}

.banner_text_order,
.top_arc_text_hover,
.arrow_anchor_button,
.arrow_anchor_button_white,
.top_arc_text_hover,.banner_img_telephone{
    transition: background-color 0.2s ease;
}


.top_arrow{
    position: relative;
}

.top_arrow_black_1,
.top_arrow_black_2,
.top_arrow_black_3{
    background-color: #000;
}

.top_arrow_white_1,
.top_arrow_white_2,
.top_arrow_white_3{
    background-color: #fff;
}

.top_arrow_black_1,.top_arrow_white_1{
    border-radius: 0.2rem;
    width: 3rem;
    height:0.2rem ;
     display: block;
    margin:2.2rem auto;
}

.top_arrow_black_2,
.top_arrow_black_3,
.top_arrow_white_2,
.top_arrow_white_3{
    width:1.183rem ;
    height:1.183rem ;
     display: block;
    position: absolute;
    right: 0.6rem;
    transform: rotate(35deg);
}

.top_arrow_black_2,
.top_arrow_black_3,
.top_arrow_white_2,
.top_arrow_white_3{
    border-radius: 0.2rem;
    height:0.2rem ;
     display: block;
}

.top_arrow_black_2,.top_arrow_white_2{
    top: -0.33rem;
}

.top_arrow_black_3,.top_arrow_white_3{
    top: 0.3rem;
    transform: rotate(-30deg);
}

.top_visual_wrapper,
.top_wrapper,
.top_arc_wrapper{
    margin: 0 auto;
}


.top_arc_wrapper{
    width: 97.1rem;
}


.top_visual_wrapper,.top_wrapper{
    width: 118rem;
}

.top_visual_wrapper{
    padding:7rem 0 4.7rem;
}


.top_back_layout{
    margin-top:10rem ;
    position: relative;
}

.top_back_layout::after{
    content: '';
    width: 62.5%;
    height:70rem ;
    background-color:#003A98 ;
    clip-path: polygon(0 0, 100% 0, 38.8% 100%, 0 100%); 
    position: absolute;
    top: 0;
    z-index: -1;
}


.top_visual_item{
    display: block;
    width: 75rem;
    height:47rem ;
    margin-bottom: 11.5rem;
}


.main_visual_flex{
    align-items: end;
    justify-content: space-between;
    gap: 3.5rem;
}

.top_text_box{
    flex-flow: column;
    padding-right: 1rem;
}

.top_main_text{
    padding-top: 1.7rem;
    width: 32rem;
    line-height: 1.8;
    color: #000;
}

.top_white_space {
    white-space: nowrap;
}


.matrix { 
  display: flex; 
}

.matrix .bg_wrap {
  display: flex;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.1s; 
}

.matrix .bg_wrap .inn {
  display: block;
  opacity: 0;
  transform: translateY(100px);
  transition: 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  transition-property: opacity, transform;
}

.matrix.is_animated_1 .bg_wrap {
   opacity: 1; 
}

.matrix.is_animated_1 .bg_wrap .inn {
  opacity: 1;
  transform: translateY(0);
}






.backg_color{
    background-color: #F0F0F0;
    color: #000;
}

.top_arc_wrapper_space_flex{
    padding: 5.9rem 0 9.2rem;
    justify-content: space-between;
}

.top_arc_title_space{
    padding-left: 0.5rem;
    padding-bottom: 2.3rem;
}

.top_arc_text_layout_dt{
    padding-right: 3.3rem;
    border-right:#707070 0.1rem solid ;
}

.top_arc_text_layout_dd{
    width: 67.8rem;
    padding-left: 3rem;
}

.top_arc_text_space{
    padding-top: 4.4rem;
}

.top_arc_list_space{
    width: 76.2rem;
    padding-top: 2.9rem;
}



.top_arc_layout_flex{
    align-items: center;
    justify-content: space-between;
}



.top_arc_text_layout_dt,
.top_arc_text_layout_dd{
   line-height:1.5 ;
   color: #000;
}

.top_about_text_height{
    line-height: 1.85;
}

.top_day,.top_month{
    font-size: 2.4rem;
    line-height: 1.54;
}


.top_about_visual_1{
    width: 23.5rem;
    height: 20rem;
}

.top_about_visual_2{
    width:43.5rem ;
    height:25rem ;
}

.top_about_flex_outside,
.top_about_flex_inside{
    justify-content: space-between;
}

.top_about_flex_inside{
    gap:3.2rem ;
    align-items: end;
}
.top_about_button_space{
    justify-content: end;
}


.top_about_text_box{
    padding: 0.1rem 0 7.7rem 3rem;
}

.top_about_flex_outside{
    padding:12.2rem 0 10.4rem ;
}

.top_about_title{
    color: #003A98;
    padding-bottom: 1.9rem;
}


.top_se_baku_img_1,.top_se_baku_img_2 {
    background-image: url(../img/gurupu.png);
    background-repeat: no-repeat;
    background-size: cover;
    height: 100%;
}

.top_se_baku_img_1{
    background-position: 0% 50%;
}

.top_se_baku_img_2{
    background-position:100% 50%;
}

.backdrop{
 backdrop-filter: blur(10px);
 width: 100%;
 height:100%;
}


.top_se_box_wrapper{
    padding: 7rem 5rem 8.4rem ;
}

.top_se_layout_flex{
    justify-content: space-between;
    color:#FFFFFF ;
}


.top_se_outside_space{
    display: block;
    padding-bottom: 11.1rem;
}

.top_blue_title_layout{
    color:#003A98;
    padding-bottom: 3.5rem;
}

.top_se_layout_space{
    padding: 6rem 0 8.5rem;
}

.top_arc_img{
    width: 49rem;
    height: 23rem;
}

.top_anim_box_2.top_popup.is_animated_2 {
  animation: top_popup 0.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.top_anim_box_2{
    display: none;
}

.is_animated_2 {
    display: block;
}

@keyframes top_popup {
  0% {
    transform: translateY(40px) scale(0.8);
    opacity: 0;
  }
  100% {
    transform: translateY(0) scale(1.0);
  }
  80%, 100% {
    opacity: 1;
  }
}

.js_slide_box.slide_skew.is_animated_1 {
  animation: slide_skew 0.4s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

.js_slide_box{
    opacity: 0;
}

.is_animated_1{
     opacity: 1;
}

@keyframes slide_skew {
  0% {
    transform: translate(180px,30px);
    opacity: 0;
  }
  100% {
    transform: translate(0,0);
  }
  20%,100% {
    opacity: 1;
  }
}

.top_works_img{
    width: 82rem;
    height: 48rem;
}


.top_works_box_layout{
    align-items: end;
    justify-content: space-between;
}


.top_works_button_space{
    padding:2rem 0 4.7rem;
    margin-right: auto;
    justify-content:end;
}

.top_works_box_space{
    padding-bottom: 19rem;
}


.top_recruit_layout_flex{
    justify-content: space-between;
    padding-bottom: 20rem;
}

.top_recruit_text_box{
    color: #000;
}

.top_recruit_title{
     color: #003A98;
}

.top_recruit_subtitle{
    font-size:2.5rem ;
    line-height:1.6 ;
    padding: 4rem 0 3.2rem;
}

.top_recruit_text{
    width:65.6rem ;
    line-height:1.8 ;
    padding-bottom:5rem;
}

.top_recruit_img{
    width: 50rem;
    height: 45rem;
}

.top_recruit_button_layout_flex{
   align-items: center;
    gap: 1.4rem;
    justify-content: end;
    padding-right:8.4rem;
}


.top_contact_space{
    padding-bottom: 9.8rem;
}

.top_contact_box{
    position: absolute;
    top: 0;
    left: 5rem;
    right: 0;
    margin: 17.7rem auto 16.3rem;
    width: 28rem;
    padding:9.2rem 0 4.8rem 0;
    background-color: #003A98;
}

.top_contact_img{
    height:62rem ;
}

.top_contact_email_img{
    display: block;
    margin: 0 auto 2.3rem ;
    width:11rem ;
    height:8.2rem ;
    transition: background-color 0.2s ease;
}

.top_contact_email_img:hover{
    width:11.5rem ;
    height:8.573rem ;
    margin: 0 auto 1.95rem;
}

.top_contact_text{
    
    font-size:2rem ;
    color:#fff ;
    text-align: center;
}

.top_contact_spoji{
    position: relative;
}

@media screen and (max-width:699.98px){


    .top_title_size{
        font-size: 2.5rem;
        letter-spacing: 0;
    }

    .top_text_size_1{
        font-size: 2.5rem;
    }

    .top_main_text{
        font-size: 1.6rem;
    }

    .top_text_size_3{
        font-size: 1.4rem;
    }

    .top_visual_wrapper,
    .top_wrapper,
    .top_arc_wrapper{
        margin: 0 auto;
    }


    .top_arc_wrapper{
        max-width:35.5rem;
        width: 100%;
    }

    .top_visual_wrapper,.top_wrapper{
        width: 100%;
    }

    .top_wrapper{
        max-width: 35.5rem;
    }

    .top_visual_wrapper{
        max-width: 32.5rem;
        padding:2rem 0 3.2rem;
    }

    .top_back_layout{
        margin-top:6.5rem ;
    }

    .top_back_layout::after{
        width: 100%;
        height:36rem ;
    }

    .top_visual_item{
        display: block;
        width: 28.5rem;
        height:34rem ;
        margin-bottom: 0;
    }

    .main_visual_flex{
        align-items:flex-start;
        gap: 2.44rem;
        flex-flow: column;
    }

    .top_text_box{
        padding-left:0.4rem ;
        padding-right:0;
    }

    .top_main_text{
        padding-top: 1rem;
    }

    .top_arc_wrapper_space_flex{
        padding: 2.6rem 0 5.25rem;
        gap: 0;
        flex-flow: column;
    }

    .top_arc_title_space{
        padding-left: 0;
        padding-bottom: 0.8rem;
    }

    .top_arc_text_layout_dt{
        padding-right: 4.4rem;
        border-right:#707070 0.1rem solid ;
    }

    .top_arc_text_layout_dd{
        width: 23rem;
        padding-left: 2rem;
    }

    .top_arc_text_space{
        padding-top: 0;
    }

    .top_arc_list_space{
        width:31.2rem;
        padding-top: 3.4rem;
        margin: 0 auto;
    }


    .top_arc_layout_flex{
        align-items: center;
    }

    .top_arc_text_layout_dt,
    .top_arc_text_layout_dd{
    line-height:1.5 ;
    }

    .top_day,.top_month{
        font-size: 2rem;
    }

    .top_white_space {
        white-space: wrap;
    }

    .top_about_flex_outside,
    .top_about_flex_inside{
        flex-wrap: wrap;
        flex-flow: column;
    }

    .top_about_flex_inside{
        gap: 2.3rem;
    }

    .top_about_visual_1{
        width: 11rem;
        height: 9.4rem;
        margin-bottom: 1rem;
    }

    .top_about_visual_2{
        width:32rem ;
        height:18.4rem ;
    }


    .top_about_title_sp_style{
        display: none;
    }

  

    .top_about_title{
        padding-bottom: 0.9rem;
    }

    .top_about_sp_space{
        padding-bottom: 0.8rem;
    }

    .top_about_text_box{
        margin: 0 auto;
        padding: 0.1rem 0 0 0;
    }
    

    .top_about_flex_outside{
        padding:3.1rem 0 7.3rem ;
    }
    
    .top_about_button_space{
        margin-right: 0.2rem;
    }

    .top_se_box_wrapper{
        padding: 3rem 1rem 5.1rem ;

    }

    .top_se_layout_flex{
        justify-content: space-between;
        flex-flow: column;
        gap: 6rem;
        color:#FFFFFF ;
    }

    .top_text_box_width_1{
        width:32rem ;
    }


  
    .top_se_layout_sp{
        flex-wrap: wrap;
        gap: 1.1rem;
    }

    .arrow_anchor_button_white{
        display: block;
        margin-left: auto;
    }
  

    .top_se_outside_space{
        display: block;
        padding-bottom: 6rem;
    }

    .top_blue_title_layout{
        color:#003A98;
        padding-bottom: 3.4rem;
    }

    .top_se_layout_space{
        padding: 4.5rem 0 2.1rem;
    }

    .top_arc_img{
        width: 100%;
        height: 23rem;
    }

    .top_sp_none{
        display: none;
    }

    .top_works_img{
        width:35.5rem ;
        height: 20.9rem;
    }


    .top_works_box_layout{
        flex-flow: column;
        align-items: flex-start;
        gap: 1rem;
    }


    .top_works_button_space{
        padding:2rem 0 0;
        margin-right: auto;
        justify-content: flex-start;
    }

    .top_works_box_space{
        padding-bottom: 5rem;
    }

    .top_recruit_layout_flex{
        flex-flow: column;
        padding-bottom: 4rem;
        gap: 1rem;
    }

    .top_recruit_button_layout_flex{
        padding-right:0;
    }


    .top_recruit_text_box{
        color: #000;
    }

    .top_recruit_subtitle{
        padding:2rem 0 1.6rem;
    }

    .top_recruit_text{
        width:100% ;
        line-height: 1.85;
        padding-bottom:2.5rem;
    }

    .top_recruit_img{
        width: 100%;
        height: 32rem;
    }

    .top_contact_space{
        padding-bottom: 4.3rem;
    }

    .top_contact_box{
        left: 0;
        margin: 8.5rem auto ;
        width: 13rem;
        padding:4.264rem 0 0.8rem ;
        background-color: #003A98;
    }

    .top_contact_img{
        height:30rem ;
    }

    .top_contact_email_img{
        width:6rem ;
        height:4.473rem ;
        margin: 0 auto 0.864rem;
        display: block;
    }

    .top_contact_email_img:hover{
    width:6.5rem ;
    height:4.773rem ;
    margin: 0 auto 0.564rem;
    }


    .top_contact_text{
        font-size:1.8rem ;
    }

}
