@media screen and (min-width:1201px){
  .pc_hide{
    display: none!important;
  }
}/*@media screen and (min-width:1201px){*/

@media screen and (max-width:1200px){
  .pad_hide{
    display: none!important;
  }

  body.fixed {
    width: 100%;
    height: 100%;
    position: fixed;
  }

  
  main{
    padding-top: 80px;
  }

  /*
  ------------------------------------
  共通パーツ
  ------------------------------------
  */

  .container{
    max-width: 720px;
    margin:0 auto;
  }

  .common_title_set{

  }

  .common_title_set .ja_title{
    font-size: 16px;
  }

  .common_title_set .ja_title::before{
    width: 23px;
    height: 12px;
    margin-right:9px;
  }

  .common_title_set .en_title{
    font-size: 64px;
    padding-left:24px ;
    line-height: 1;  
  }

  .common_title_set .sub_title{
    font-size: 16px;
    padding-left:32px ;
    margin-top: 32px;
    
  }


  /*共通のリンクボタン*/
  .common_blue_button{
    min-width: 240px;
    min-height:40px;
    border-radius: 5px;
    padding:4px 16px;
  }




  /*staffのswiperエリア*/

  .common_staff_area{

  }

  .common_staff_area .staff_swiper_frame{
    margin: 0 calc(50% - 50vw);
  }

  .common_staff_area .staff_swiper_block{
    width:calc(50% + 360px);
  }

  .common_staff_area .staff_swiper_block::after{
    width:100vw;
    left:400px;
  }

  .common_staff_area .staff_slide{
    width:450px;
    padding-right: 100px;
  }


  .common_staff_area .staff_button_flex{
    margin-top: 32px;
  }

  .common_staff_area .staff_nav{
    width: 96px;
    height: 46px;
    font-size: 32px;
  }

  .common_staff_area .staff_nav_next{
    margin-left: 28px;
  }

  .common_staff_area .staff_text_area{
    left:380px;
    bottom:24px;
    width:300px;
  }

  .common_staff_area .staff_text_block .icon{
    width: 23px;
    height: 12px;
    margin-bottom: 10px;
  }

  .common_staff_area .staff_text_block .staff_msg{
    font-size: 20px;
    line-height:1.3;
    padding-bottom: 12px;
  }

  .common_staff_area .staff_text_block .staff_info{
    margin-top: 16px;
    line-height: 1.3;
  }

  .common_staff_area .staff_text_block .staff_name{
    font-size: 20px;
    font-weight: 900;
    }



  /*下層ページへのリンク一覧*/

  .common_page_link_list{

  }

  .common_page_link_list .link_line + .link_line{
    margin-top: 80px;
  }

  .common_page_link_list .link_item{
    gap:0 40px;
  }

  .common_page_link_list .link_title{
    transform: translateY(8px);
  }

  .common_page_link_list .link_title_en{
    font-size: 36px;
  }

  .common_page_link_list .link_title_ja{
    font-size: 16px;
    margin-top: 8px;
  }

  .common_page_link_list .link_border{
    width:100%;
  }

  .common_page_link_list .link_radi{
    width: 106px;
    height: 106px;
  }

  .common_page_link_list .link_radi::after{
    width:36px;
    height:29px;
  }



  /*
  ------------------------------------
  共通アニメーション
  ------------------------------------
  */





  /*
  ------------------------------------
  ヘッダー
  ------------------------------------
  */

  header{

  }

  header .header_inner{
    padding-left:24px;
    padding-right: 24px;
  }

  header .header_flex{
    height: 80px;
  }

  header .header_left{
    padding-top: 0;
    padding-bottom: 0;
  }
  header .header_logo{
    width:56px;
  }

  header .header_right{
    display: flex;
    align-items: center;
  }

  header .header_nav{
    display: none;
  }
  

  header .drawer_open{
    cursor: pointer;
  }

  header .drawer_open_inner{
    width: 72px;
    height: 24px;
    border-radius: 3px;
    background: #00A0E9;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding:0 10px;
    gap:0 8px;
  }

  header .drawer_open_inner span{
    width:6px;
    height:6px;
    border-radius: 50%;
    background-color: #fff;
    display: block;
  }

  #drawer_menu{
    position: fixed;
    top:0;
    right:0;
    z-index:90;
    width:100%;
    height: 100vh;
    height: calc(var(--vh2, 1vh) * 100);
    background-color: rgba(0,0,0,0.6);
    transition-duration: 0.7s;
    opacity: 0;
    transition-property: opacity;
    pointer-events: none;
    display: flex;
    justify-content: flex-end;
  }

  #drawer_menu.show{
    opacity: 1;
    pointer-events: auto;
  }

  #drawer_menu .drawer_menu_inner{
    position: relative;
    width:340px;
    height:calc(100vh);
    height: calc(calc(var(--vh2, 1vh) * 100));
    background-color: #fff;
  }

  #drawer_menu .drawer_menu_inner{
    position: relative;
    width:340px;
    height:calc(100vh);
    height: calc(calc(var(--vh2, 1vh) * 100));
    background-color: #fff;
    overflow-y: auto;
  }

  #drawer_menu .drawer_menu_contents{
    padding:16px 16px 32px;
  }

  #drawer_menu .drawer_menu_head{
    padding-bottom: 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom:1px solid #000;
  }

  #drawer_menu .drawer_logo{
    width:48px;
  }

  #drawer_menu .drawer_logo img{
    width:100%;
  }

  #drawer_menu .drawer_close{
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
  }

  #drawer_menu .drawer_close::after{
    content:'';
    width:32px;
    height:20px;
    background-image: url('../img/common/icon_close_blue.svg');
    background-size: contain;
  }

  #drawer_menu .drawer_nav{
    margin-top: 24px;
  }

  #drawer_menu .drawer_parent_item + .drawer_parent_item{
    margin-top: 16px;
  }
  
  #drawer_menu .drawer_parent_link{
    font-weight: 700;
  }

  #drawer_menu .drawer_child_menu{
    margin-top: 16px;
    padding-left: 16px;
  }

  #drawer_menu .drawer_child_item + .drawer_child_item{
    margin-top: 16px;
  }

  #drawer_menu .drawer_child_link{
    font-size: 12px;
    font-weight: 700;
  }

  #drawer_menu .drawer_sns_list{
    margin-top: 32px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap:0 12px;
  }

  #drawer_menu .drawer_sns_list a{
    display: block;
  }

  #drawer_menu .drawer_sns_list img{
    width:50px;
  }
  /*
  ------------------------------------
  フッター
  ------------------------------------
  */

  footer{
    padding-top: 56px;
    padding-bottom: 16px;
  }

  footer .footer_inner{
    max-width: 720px;
    margin:0 auto;

  }

  footer .footer_flex{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-direction: column;
    
  }

  footer .footer_left{
    display: flex;
    align-items: flex-start;
  }

  footer .footer_logo{
    display: block;
    width:80px;
    flex-shrink: 0;
    margin-right: 40px;
  }

  footer .footer_name{
    margin-top:0;
  }

  footer .footer_address{
    margin-top: 16px;
    line-height: 1.5;
  }

  footer .footer_tel{
    margin-top: 16px;
    line-height: 1.5;
  }

  footer .footer_right{
    padding-bottom: 20px;
    margin-top: 40px;
    width: 100%;
  }

  footer .footer_nav{
    display: flex;
    align-items: flex-start;
    width: fit-content;
    margin:0 auto;
  }

  footer .parent_menu + .parent_menu{
    margin-left: 80px;
  }

  footer .parent_item + .parent_item{
    margin-top: 16px;
  }

  footer .insta_frame{
    display: flex;
    justify-content: center;
    margin-top: 40px;
  }

  footer .insta_frame .insta{
    width:50px;
  }

  footer .footer_copy{
    margin-top: 40px;
    display: flex;
    justify-content: center;
  }
  /*
  ------------------------------------
  ページ下部のお問い合わせ
  ------------------------------------
  */

  .common_contact_section{
    padding-top: 40px;
    padding-bottom: 64px;
  }



  .common_contact_section::after{
    width:100%;
    height:100%;
    background-image: url('../img/common/contact_sec_bg.jpg');
    top:0;
    left:0;
    z-index:-2;
  }

  .common_contact_section .contact_head{
    font-size: 64px;
  }

  .common_contact_section .contact_text_list{
    margin-top: 140px;
  }

  .common_contact_section .contact_flex{
    margin-top: 100px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
  }

  .common_contact_section .contact_flex .contact_border{
    width: 2px;
    height: 241px;
  }

  .common_contact_section .tel_block{
    width:calc(50% - 2px);
    padding-top: 18px;
  }

  .common_contact_section .tel_block .tel{
    font-size: 40px;
  }

  .common_contact_section .tel_block .tel::before{
    width:56px;
    height:56px;
    margin-bottom: 24px;
  }

  .common_contact_section .tel_block .tel_time{
    margin-top: 28px;
  }

  .common_contact_section .mail_block{
    width:calc(50% - 2px);
    padding-top: 18px;
  }

  .common_contact_section .mail_block .mail_icon{
    width:60px;
    height:48px;
  }

  .common_contact_section .contact_button{
    margin:64px auto 0;
  }


  /*
  ------------------------------------
  パートナー紹介セクション
  ------------------------------------
  */

  .common_partner_section{
    padding-top: 180px;
    padding-bottom: 200px;
  }

  .common_partner_section .sec_title{
    font-size: 24px;
    font-weight: 700;

  }

  .common_partner_section .partner_area{
    padding-left: 0;
  }

  .common_partner_section .partner_list{
    margin-top: 40px;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    flex-direction: column;
    gap:48px 0;
  }

  .common_partner_section .partner_item{
    width:100%;
    min-height: 72px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }

  .common_partner_section .partner_item01 img{
    width:307px;
  }
  .common_partner_section .partner_item02 img{
    width:327px;
  }
  .common_partner_section .partner_item03 img{
    width:242px;
  }

  /*
  ------------------------------------
  トップページ
  ------------------------------------
  */
  body.top_body{
    
  }

  main.top_main{

  }

  .top_section{
    position: relative;
  }

  .top_mv_section{

  }

  .top_mv_section .mv_area{
    /* height:690px; */
    height:500px;
    background-image:url('../img/top/top_mv.jpg');
  }

  .top_mv_section .mv_textarea{
    position: absolute;
    z-index: 1;
    top:0;
    left:0;
    right:0;
    margin:0 auto;
    width:90%;
    height:100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }

  .top_mv_section .mv_text01{
    font-size: 50px;
    line-height:1.18;
  }

  .top_mv_section .mv_text02{
    margin-top: 40px;
    font-size: 24px;
  }

  .top_about_section{
    padding-top: 100px;
    padding-bottom: 40px;
    position: relative;
  } 


  .top_about_section .about_radi01{
    width:2100px;
    height:1050px;
    top:-525px;
    left:calc(50% - 1145px);
  }
  .top_about_section .about_radi02{    
    width: 1500px;
    height: 750px;
    top:0;
    left:calc(50% - 1020px);
  }

  .top_about_section .anime_active .about_radi01{
    width: 1050px;
  }

  .top_about_section .anime_active .about_radi02{
    width: 750px;
  }

  .top_about_section .about_frame{
    display: flex;
    justify-content: flex-end;
  }

  .top_about_section .about_block{

  }

  .top_about_section .about_text{
    margin-top: 20px;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.6;
  }

  .top_about_section .about_button{
    margin-top: 60px;
  }

  .top_about_section .about_slide_area{
    width: 100vw;
    margin: 200px calc(50% - 50vw) 0;
  }


  .top_about_section .about_slide{
    padding:0 15px;
  }

  .top_about_section .about_card01{
    width:296px;
    padding-top: 210px;
  }
  .top_about_section .about_card02{
    width:342px;
  }
  .top_about_section .about_card03{
    width:242px;
    padding-top: 270px;
  }
  .top_about_section .about_card04{
    width:413px;
    padding-top: 40px;
  }
  .top_about_section .about_card05{
    width:305px;
    padding-top: 190px;
  }
  .top_about_section .about_card06{
    width:344px;
    padding-top: 20px; 
  }

  .top_about_section .about_card img{
    border-radius: 10px;
  }

  .top_service_section{
    padding-top: 60px;
    padding-bottom: 120px;
  } 

  .top_service_section .service_bg{
    width:1200px;
    top:-50px;
  }

  .top_service_section .service_list{
    margin-top: 100px;
    --delay-step: 0.15s;
  }

  .top_service_section .service_item{
    width: 144px;
    height:200px;
  }

  .top_service_section .service_item:first-child{
    width: 148px;
  }

  .top_service_section .service_card{
    font-size: 18px;
  }

  .top_service_section .anime_active .service_card{
    animation-duration: 0.4s;
  }

  .top_service_section .service_card01{
    background-image: url('../img/top/top_serice_card01.png');
    
  }
  .top_service_section .service_card02{
    background-image: url('../img/top/top_serice_card02.png');
  }
  .top_service_section .service_card03{
    background-image: url('../img/top/top_serice_card03.png');
  }
  .top_service_section .service_card04{
    background-image: url('../img/top/top_serice_card04.png');

  }
  .top_service_section .service_card05{
    background-image: url('../img/top/top_serice_card05.png');
  }

  .top_service_section .service_text{
    margin-top: 188px;
    text-align: center;
    line-height: 1.45;
  }

  .top_service_section .serivice_button_frame{
    display: flex;
    justify-content: center;
    margin-top: 24px;
  }

  .top_staff_section{
    padding-top: 30px;
    padding-bottom: 160px;
  } 

  .top_staff_section .common_staff_area{
    margin-top: 80px;
  }

  .top_intro_section{
    padding-top: 104px;
  }

  .top_intro_section .js_radi_move_point{
    bottom: -500px;
  }

  .top_intro_section .js_radi_fix_start{
    top: -70px;
  }
  .top_intro_section .js_radi_fix_end{
    top: 100%;
  }

  .top_intro_section .intro_radi01{
    top: -70px;
    width:1280px;
  }

  .top_intro_section .js_intro_radi01_start_pos{
    top: -70px;
  }

  .top_intro_section .intro_radi01.fixed{
    top: 0 !important;
    position: fixed;
  }

  .top_intro_section .js_intro_radi01 .intro_radi_inner::after{
    width: 400px;
    height: 400px;
    transform: translateX(calc(1280px - 400px));
  }

  .top_intro_section .intro_radi02{
    top: 590px;
    width:1420px;
  }

  .top_intro_section .js_intro_radi02_start_pos{
    top: 590px;
  }

  .top_intro_section .intro_radi02.fixed{
    top: 660px !important;
    position: fixed;
  }

  .top_intro_section .js_intro_radi02 .intro_radi_inner::after{
    width: 464px;
    height: 464px;
    transform: translateX(calc(-1420px + 464px));
  }

  .top_intro_section .anime_active .js_intro_radi01 .intro_radi_inner::after{
    transform: translateX(0);
  }
  .top_intro_section .anime_active .js_intro_radi02 .intro_radi_inner::after{
    transform: translateX(0);
  }

  .top_intro_section .anime_active .js_intro_radi01.move .intro_radi_inner::after{
    transform: translateX(calc(1280px - 400px));
  }
  .top_intro_section .anime_active .js_intro_radi02.move .intro_radi_inner::after{
    transform: translateX(calc(-1420px + 464px));
  }


  .top_intro_section .flex{
    display: flex;
    justify-content: space-between;

  }

  .top_intro_section .news_area{
    width:620px;
  }


  .top_intro_section .news_area .news_contents{
    padding-left: 32px;
    margin-top: 40px;
  }

  .top_intro_section .news_area .news_block{
    padding-top: 16px;
    padding-bottom: 24px;
    padding-right: 48px;
  }

  .top_intro_section .news_area .news_date{

  } 
  .top_intro_section .news_area .news_title {
    margin-top: 16px;
    padding-left: 28px;
    line-height: 1.5;
  }

  .top_intro_section .news_area .news_button_frame{
    margin-top: 40px;
  }

  .top_intro_section .seminer_area{
    width:420px;
  }

  .top_intro_section .seminer_area .seminer_contents{
    padding-left: 32px;
    margin-top: 60px;
  }

  .top_intro_section .seminer_area .seminer_text{
    margin-top: 20px;
    font-size: 20px;
    font-weight: 700;
  }

  .top_intro_section .seminer_area .seminer_button_frame{
    margin-top: 40px;
  }


  .top_recruit_section{
    padding-top: 540px;
    padding-bottom: 360px;
  }


  .top_recruit_section .recruit_img_frame .recruit01{
    width: 133px;
    top:117px;
    right:calc(50% + 230px);
  }
  .top_recruit_section .recruit_img_frame .recruit02{
    width: 201px;
    top:425px;
    right:calc(50% + 157px);
  }
  .top_recruit_section .recruit_img_frame .recruit03{
    width: 202px;
    top: 13px;
    left: calc(50% + 203px);
  }

  .top_recruit_section .common_title_set .ja_title{
    justify-content: center;
  }

  .top_recruit_section .common_title_set .en_title {
    padding-left: 0;
    text-align: center;
  }

  .top_recruit_section .recruit_msg{
    margin-top: 64px;
    text-align: center;
    font-size: 24px;
    font-weight: 900;
    line-height: 1.4;
  }

  .top_recruit_section .recruit_text{
    margin-top: 60px;
    font-weight: 900;
    line-height: 1.4;
    text-align: center;
  }

  .top_recruit_section .recruit_button_frame{
    display: flex;
    justify-content: center;
    margin-top: 60px;
  }



  /*
  ------------------------------------
  下層共通 ページタイトルエリア
  ------------------------------------
  */

  main.page_main{
    padding-top: 120px;
  }

  .page_title_section {
    padding-bottom: 12px;
  }

  .page_title_section .flex{
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    justify-content: flex-end;
  }

  .page_title_section .page_title_area{
    display: none;
  }

  .page_title_section .page_title{
    display: flex;
    align-items: flex-start;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.3;
  }

  .page_title_section .page_title::before{
    content:'';
    width: 23px;
    height: 12px;
    flex-shrink: 0;
    border-radius: 2px;
    background: #00A0E9;
    margin-right: 9px;
    margin-top: 4px;
  }


  /*
  ------------------------------------
  追従のページナビ
  ------------------------------------
  */

  .common_page_nav_area{
    position: static;
    white-space: normal;
    padding-top: 24px;
  } 

  .common_page_nav_contents{
    max-width: 720px;
    margin: 0 auto;
  }



  .common_page_nav_area .en_name{
    font-size: 64px;
    font-weight: 900;
    line-height: 1;
  }

  .common_page_nav_area .nav_list{
    display: none;
  }

  .common_page_nav_area.fixed{
    position: static;
  }

  #section_wrap .js_nav_fix_start{
    position: static;
  }

  /*
  ------------------------------------
  下層のセクションまとめ
  ------------------------------------
  */

  #section_wrap{
    position: relative;
    overflow: hidden;
  }

  #section_wrap .page_container{
    max-width: 720px;
    margin:0 auto;
    padding-left: 0;
    
  }



  /*
  ------------------------------------
  下層のmv
  ------------------------------------
  */
  .page_mv_section{
    padding-top: 40px;
  }

  .page_mv_section .page_mv_frame{
    width:100%;
    max-width: 1220px;
    height:450px;
    border-radius: 0;
    display: flex;
    justify-content: center;
    overflow: visible;
  }


  .page_mv_section .page_mv{
    width: 100vw;
    flex-shrink: 0;
  }
  /*
  ------------------------------------
  Mフレンドについて
  ------------------------------------
  */

  body.about_body{
    
  }

  main.about_main{

  }

  main.about_main .about_radi{
    display: none;
    border-radius: 50%;
  }

  .about_mv_section .page_mv{
    background-image: url('../img/about/about_mv.jpg');
  }

  .about_section{
    position: relative;
  }

  .about_section01{
    padding-top: 120px;
    padding-bottom: 120px;
  }

  .about_section01 .about_msg{
    font-size: 36px;
    letter-spacing: 0;
  }

  .about_section01 .about_block{

  }

  .about_section01 .about_block .about_title_block{
    height:90px;
    display: flex;
    align-items: center;
    padding-left: 64px;
    border-radius: 100px;
    width: 100vw;
    
  }

  .about_section01 .about_block .about_title{
    color: #FFF;
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    font-size: 36px;
    font-weight: 700;
    line-height: 1;
  }

  .about_section01 .about_block .about_head{
    margin-top: 40px;
    font-size: 24px;  
    line-height: 1.3;
    font-weight: 700;

  }

  .about_section01 .about_block .about_text{
    margin-top: 40px;
    line-height: 1.5;
  }

  .about_section01 .about_block01{
    margin-top: 120px;
  }

  .about_section01 .about_block01 .about_title_frame{
    padding-left: 460px;
  }

  .about_section01 .about_block02{
    margin-top:80px;
  }
  .about_section01 .about_block02 .about_title_frame{
    padding-left: 300px;
  }

  .about_section01 .about_block03{
    margin-top:80px;
  }
  .about_section01 .about_block03 .about_title_frame{
    padding-left: 140px;
  }



  /*
  ------------------------------------
  代表の言葉
  ------------------------------------
  */

  body.message_body{
    
  }

  main.message_main{

  }

  .message_mv_section .page_mv{
    background-image: url('../img/message/message_mv.jpg');
  }

  .message_section01{
    padding-top: 120px;
    padding-bottom: 120px;
  }


  .message_section01 .message_radi{
    display: none;
  }

  .message_section01 .message_block{
    position: relative;
    /* min-height: 612px; */
    padding-right: 0;
  }

  .message_section01 .message_catch{
    font-size: 48px;
    font-weight: 700;
    line-height: 1.2;
  }

  .message_section01 .message_img{
    position: static;
    width:340px;
    margin:32px auto 0;
  }

  .message_section01 .message_img img{
    border-radius: 10px;
  }

  .message_section01 .message_info{
    margin-top: 40px;
  }

  .message_section01 .message_job{
    font-size: 24px;
    line-height: 1.3;
  }

  .message_section01 .message_name{
    gap:10px 24px;
    margin-top: 10px;
  }

  .message_section01 .message_name_ja{
    font-size: 40px;
  }

  .message_section01 .message_name_en{
    font-size: 24px;
  }

  .message_section01 .message_title{
    margin-top: 40px;
    font-size: 32px;
  }

  .message_section01 .message_text{
    margin-top: 40px;
  }

  /*
  ------------------------------------
  会社情報
  ------------------------------------
  */

  body.company_body{
    
  }

  main.company_main{

  }

  .company_mv_section .page_mv{
    background-image: url('../img/company/company_mv.jpg');
    background-position: left;
  }

  .company_section{
    position: relative;
  }

  .company_section01{
    padding-top: 120px;
    padding-bottom: 120px;
  }

  .company_section01 .company_radi{
    display: none;
  }

  .company_section01 .company_line{
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding:24px 0;
  }

  .company_section01 .company_title{
    min-width: 210px;
    padding-right: 12px;
    font-size: 24px;
  }

  .company_section01 .company_contents{
    width:100%;
    font-size: 24px;
    line-height: 1.3; 
  }

  .company_section01 .company_contents ul li{

    padding-left: 12px;
  }

  .company_section01 .company_contents ul li + li{
    margin-top: 8px;
  }

  .company_section01 .company_contents ul li::before{
    font-size: 24px;
    line-height: 1.3; 
    left:-8px;
    top:0;
  }

  .company_section01 .company_img_frame{
    margin-top: 80px;
    padding-right: 0;
    display: flex;
    justify-content: flex-end;
  }

  .company_section01 .company_img{
    width:100%;
    flex-shrink: 0;
  }

  .company_section01 .company_img img{
    border-radius:0;
  }

  /*
  ------------------------------------
  事業紹介
  ------------------------------------
  */

  body.service_body{
    
  }

  main.service_main{

  }

  .service_section{
    position: relative;
  }

  .service_section01{
    padding-top: 120px;
  }

  .service_section01 .service_text_frame{
    display: flex;
    justify-content: flex-end;
  }

  .service_section01 .service_text_block{
    font-weight: 700;
    line-height: 1.5;
  }

  .service_slide_section{
    padding-top: 80px;
  }

  .service_slide_section .service_nation_area{
    /* position: static;
    padding-left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap:0 6px; */

    display: none;
  }

  .service_slide_section .service_nation{
    font-size: 36px;
  }

  .service_slide_section .service_slide_list{
    position: relative;
    min-height: 452px;
    margin-top: 32px;
  }

  .service_slide_section .service_slide{
    position: static;
    opacity: 1;
    pointer-events: auto;
  }

  .service_slide_section .service_slide + .service_slide{
    margin-top: 56px;
  }

  .service_slide_section .service_card{
    display: flex;
    align-items: center;
  }

  .service_slide_section .service_thumb{
    width:40%;
    margin-right: 32px;
  }


  .service_slide_section .service_num{
    font-size: 56px;
    left:-24px;
    top:-32px;
  }

  .service_slide_section .service_title{
    font-size: 22px;
    line-height: 1.4;
  }

  .service_slide_section .service_title span{
    font-size: 28px;
  }

  .service_slide_section .service_list{
    margin-top: 24px;
  }

  .service_slide_section .service_list li{
    line-height: 1.3;
    font-weight: 700;
    font-size: 15px;
    min-height: 45px;
  }

  .service_slide_section .service_list li::before{
    width:36px;
    height:36px;
    margin-right: 12px;
  }

  .service_slide_section .service_list li + li{
    margin-top: 12px;
  }

  .service_slide_section .service_nav_area{
    display: none;
  }


  .service_link_section{
    padding-top: 160px;
  }

  /*
  ------------------------------------
  事業紹介 詳細 (法人のお客様、個人のお客様 ほぼ共通)
  ------------------------------------
  */

  body.detail_body{
    
  }

  main.detail_main{

  }

  .detail_section{
    position: relative;
  }

  .detail_text_section{
    padding-top: 120px;
  }

  .detail_text_section .detail_text_frame{
    display: flex;
    justify-content: flex-end;
    padding-left: 0;
  }

  .detail_text_section .detail_text_block{
    max-width: 100%;
  }

  .detail_text_section .detail_head{
    font-size: 36px;
  }


  .detail_text_section .detail_text{
    margin-top: 20px;
  }

  .detail_info_section{
    padding-top: 100px;
  } 

  .detail_info_section .intro_block{

  }

  .detail_info_section .intro_block .intro_head{
    height: 140px;
  }

  .detail_info_section .intro_block .intro_head::before{
    width:32px;
    height:32px;
    right:32px;
  }


  .detail_info_section .intro_block .intro_head::after{
    border-width: 20px 80px 0 80px;
  }

  .detail_info_section .intro_block .intro_title{
    font-size: 28px;
    margin-top: 8px;
  }

  .detail_info_section .intro_block .intro_num{
    font-size: 72px;
    left:16px;
  }

  .detail_info_section .intro_block .icon_frame{
    min-height: 72px;
  }

  .detail_info_section .intro_block .icon{
    width: 64px;
    height: 64px;
  }

  .detail_info_section .intro_block .intro_body{
    padding: 40px 24px 56px;

  }

  /*
  ------------------------------------
  スタッフ一覧
  ------------------------------------
  */

  body.staff_body{
    
  }

  .staff_slide_section{
    padding-top: 120px;
  }


  .staff_link_section{
    padding-top: 160px;
    padding-bottom: 120;
  }

  /*
  ------------------------------------
  スタッフ一覧
  ------------------------------------
  */

  body.staff_single_body{
    
  }


  main.staff_single_main{

  }

  .staff_single_section{
    position: relative;
  }

  .staff_single_section{
    padding-top: 24px;
    padding-bottom: 120px;
  }

  .staff_single_section .staff_info_frame{
    display: flex;
    justify-content: flex-start;
    padding-left: 0;
    padding-right: 0;
  }

  .staff_single_section .staff_info_block{
    
  }

  .staff_single_section .staff_job{
    text-align: left;
    line-height: 1.3;
  }

  .staff_single_section .staff_name{
    margin-top: 10px;
    text-align: left;
    font-size: 20px;
  }

  .staff_single_section .staff_message{
    margin-top: 16px;
    font-size: 36px;

  }

  .staff_single_section .staff_main_img{
    margin-top: 40px;
    aspect-ratio: 1/0.54;
    border-radius: 10px;
  }

  .staff_single_section .staff_interview_area{
    position: relative;
    margin-top: 56px;
    padding-right: 0;
  }

  .staff_single_section .staff_pic{
    display: none;
  }

  .staff_single_section .staff_pic.fixed{
    position: static;
  }

  #section_wrap .js_staff_pic_fix_start{
    position: static;
  }

  .staff_single_section .staff_interview_block + .staff_interview_block{
    margin-top: 48px;
  }

  .staff_single_section .staff_question{
    font-size: 20px;
  }

  .staff_single_section .staff_answer{
    margin-top: 16px;
  }

  .staff_list_section{
    padding-top: 120px;
    padding-bottom: 120px;
  }

  .staff_list_section .staff_list{
    display: flex;
    flex-wrap: wrap;
    gap:60px 40px;
  }

  .staff_list_section .staff_item{
    width:340px;
  }


  .staff_list_section .staff_body{
    margin-top: 20px;
    max-width: 95%;
  } 

  .staff_list_section .staff_message{
    padding-bottom: 24px;
    font-size: 20px;
    line-height: 1.5;
  }


  .staff_list_section .staff_info{
    margin-top: 24px;
  }

  .staff_list_section .staff_job{
    
  }

  .staff_list_section .staff_history{
    margin-top: 8px;
    
  }

  .staff_list_section .staff_name{
    margin-top: 8px;
    font-size: 20px;
  }


  /*
  ------------------------------------
  採用情報
  ------------------------------------
  */

  body.recruit_body{
    
  }

  main.recruit_main{

  }


  .recruit_mv_section .page_mv{
    background-image: url('../img/recruit/recruit_mv.jpg');
    background-position: left;
  }

  .recruit_section{
    position: relative;
  }

  .recruit_thought_section{
    padding-top: 100px;
  }

  .recruit_thought_section .thought_block{
    padding-left: 48px;
    padding-right: 80px;
  }

  .recruit_thought_section .thought_head{
    font-size: 32px;
  }

  .recruit_thought_section .thought_text{
    margin-top: 40px;
  }

  .recruit_thought_section .thought_img{
    margin-top: 72px;
  }

  .recruit_thought_section .thought_img img{
    border-radius: 10px;
  }

  .recruit_flow_section{
    padding-top: 160px;
  }

  .recruit_flow_section .flow_block{
    position: relative;
  }

  .recruit_flow_section .flow_block + .flow_block{
    margin-top: 80px;
  }

  .recruit_flow_section .flow_head{
    height: 80px;
    border-radius: 20px;
  }

  .recruit_flow_section .flow_head_text{
    font-size: 28px;
    font-weight: 700;
    line-height: 1;
  }

  .recruit_flow_section .flow_num{
    font-size: 72px;
    left:-16px;
    top:-40px;
  }

  .recruit_flow_section .flow_body{
    margin-top: 24px;
  }

  .recruit_flow_section .flow_text{
    line-height: 1.75;
    text-align: center;
  }

  .recruit_flow_section .flow_img{
    margin-top: 120px;
  }

  .recruit_flow_section .flow_img img{
    border-radius: 10px;
  }

  .recruit_appli_section{
    padding-top: 120px;
  }

  .recruit_appli_section .appli_block{
    padding:24px 0;

  }

  .recruit_appli_section .appli_head{
    font-size: 24px;
  }

  .recruit_appli_section .appli_contents{
    margin-top: 16px;
    font-size: 20px;
  }

  .recruit_seek_section {
    /* padding-top: 80px; */
  }

  .recruit_seek_section .seek_block{
    padding:24px 0;
  }

  .recruit_seek_section .seek_head{
    font-size: 24px;
  }

  .recruit_seek_section .seek_contents{
    margin-top: 16px;
    font-size: 20px;
  }

  .recruit_seek_section .seek_button_frame{
    display: flex;
    justify-content: flex-end;
    margin-top: 88px;
  }

  .recruit_staff_section{
    padding-top:120px;
    padding-bottom: 120px;
  }

  .recruit_staff_section .common_staff_area .staff_swiper_block {
    width: calc(50% + 360px);
    
  }

  .recruit_staff_section .common_staff_area .staff_swiper_block::after {
    background-color: rgba(255, 255, 255, 0.80);
  }

  .recruit_staff_section .common_staff_area .staff_button_flex {
    padding-left: 0;
  }

  /*
  ------------------------------------
  お問い合わせ
  ------------------------------------
  */

  body.contact_body{
    
  }

  main.contact_main{

  }


  .contact_section{
    position: relative;
    padding-top: 120px;
    padding-bottom: 120px;
  }


  .contact_section .flex{
    display: flex;
    justify-content: flex-end;
  }


  .contact_section .form_frame{
    width:100%;
  }

  .contact_section .form_text{
    font-weight: 700;
    line-height: 1.5;
  }

  .contact_section .form_block{
    margin-top: 80px;
  }

  .contact_section .form_line{
    display: flex;
    align-items: flex-start;
  }

  .contact_section .form_line + .form_line{
    margin-top: 48px;
    
  }

  .contact_section .form_label{
    min-width:220px;
    padding-right: 10px;
  }

  .contact_section .form_label::after{
    content:'※';
  }


  .contact_section .form_right{
    width: 100%;
  }

  .contact_section .radio_area label{
    display: flex;
    align-items: center;
    cursor: pointer;
  }

  .contact_section .radio_area label input{
    margin-right: 6px;
    transform: translateY(1px);
  }

  .contact_section .radio_area .wpcf7-list-item + .wpcf7-list-item {
    display: inline-block;
    margin-left: 20px;
  }

  .contact_section .radio_area label + label{
    margin-left: 10px;
  }

  .contact_section .input_frame select{
    height: 50px;
    padding:0 12px;
    font-size: 16px;
  }

  .contact_section .input_frame input{
    height: 50px;
    padding:0 12px;
    font-size: 16px;
  } 


  .contact_section .input_frame textarea{
    font-size: 16px;
    height: 215px;
    padding:12px;
  }

  .contact_section .privacy_area{
    padding-top: 20px;
  }

  .contact_section .privacy_text{
    line-height: 1.5;
  }

  .contact_section .submit_frame{
    display: flex;
    justify-content: flex-end;
  }

  /*共通のリンクボタン*/
  .contact_section .submit_frame .submit{
    min-width: 240px;
    min-height:40px;
    padding:4px 16px;
  }


  .contact_section .contact_nav_area{
    display: none;
  }

  /*
  ------------------------------------
  お知らせ
  ------------------------------------
  */

  body.archive_body{
    
  }

  main.archive_main{

  }

  .archive_section01{
    padding-top: 120px;
    padding-bottom: 120px;
  }

  .archive_section01 .news_category_list{
    gap:16px 0;
  }

  .archive_section01 .news_category_list li{
    margin-right: 16px;
    font-size: 24px;
  }

  .archive_section01 .news_category_list li::after{
    margin-left: 16px;
    font-size: 24px;
  }

  .archive_section01 .news_year_list{
    margin-top: 40px;
    gap:12px 24px;
  }

  .archive_section01 .news_year_list a{
    font-size: 24px;
  }

  .archive_section01 .news_list{
    margin-top: 60px;
    max-width: 780px;
  }

  .archive_section01 .news_card{
    padding:24px 0;
    padding-right: 44px;
  }

  .archive_section01 .news_card::after{
    font-size: 30px;
    right:6px;
  }

  .archive_section01 .news_card .news_thumb{
    width:208px;
    margin-right: 40px;
  }

  .archive_section01 .news_card .news_text_area{
    width:100%;
  }

  .archive_section01 .news_card .news_info_flex{
    display: flex;
    align-items: center;
    gap:0 20px;
  }

  .archive_section01 .news_card .news_date{
    font-size: 15px;
  }

  .archive_section01 .news_card .news_category{
    font-size: 15px;
  }

  .archive_section01 .news_card .news_title{
    margin-top: 12px;
    font-size: 20px;
    line-height: 1.3;
  }

  .archive_section01 .pagination{
    margin-top: 40px;
    gap:12px 20px;
  }


  /*
  ------------------------------------
  お知らせ詳細
  ------------------------------------
  */

  body.single_body{
    
  }

  main.single_main{

  }

  .single_section01{
    padding-top: 80px;
    padding-bottom: 80px;
  }

  .single_section01 .single_inner{
    margin-inline: auto;
  }

  .single_section01 .news_info_flex{
    display: flex;
    align-items: center;
    gap:0 20px;
  }

  .single_section01 .news_date{
    font-size: 15px;
  }

  .single_section01 .news_category{
    font-size: 15px;
  }

  .single_section01 .news_title{
    margin-top: 24px;
    font-size: 36px;
  }

  .single_section01 .news_thumb{
    margin-top: 32px;
  }

  .single_section01 .single_block{
    margin-top: 80px;
    padding-bottom: 40px;
  }

  .single_section01 .single_block::after{
    width: 433px;
    max-width: 100%;
  }

  .common_single_block h2{
    font-size: 25px;
    margin:24px 0;
  }


  .common_single_block h3{
    font-size: 20px;
    margin:16px 0;
  }

  .common_single_block p{
    line-height: 1.8;
    margin:24px 0;
  }

  .common_single_block figure{
    margin-top:32px;
    margin-bottom:32px;
  }

  .single_section01 .sns_area{
    margin-top: 8px;
  }

  .single_section01 .sns_head{
    font-size: 24px;
  }

  .single_section01 .sns_list{
    margin-top: 32px;
    gap:0 120px;
  }

  .single_section01 .sns_list a img{
    width:48px;
  }

  .single_section01 .link_list{
    margin-top: 150px;
  }

  .single_section01 .link_list .link_border{
    height:140px;
  }

  .single_section01 .link_list .link_frame{
    width:50%;
  }

  .single_section01 .link_list .link{
    display: flex;
  }

  .single_section01 .link_list .link_contents{
    max-width: 100%;
  }


  .single_section01 .link_list .link_info_flex{
    display: flex;
    align-items: center;
    gap:0 20px;
    margin-top: 12px;
  }

  .single_section01 .link_list .link_date{
    font-size: 16px;
  }

  .single_section01 .link_list .link_category{
    font-size: 16px;
  }

  .single_section01 .link_list .link_title{
    margin-top: 12px;
    font-size: 20px;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
  }

  .single_section01 .link_list .link.prev{
    padding-right: 16px;
  }

  .single_section01 .link_list .link.next{
    padding-left: 16px;
    justify-content: flex-end;
  }

  .single_section01 .link_list .link.next .link_nav{
    text-align: right;
    display: block;
  }

  .single_section01 .link_list .link.next .link_info_flex{
    justify-content: flex-end;
  }
  
}/*@media screen and (max-width:1200px){*/