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

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


  main{
    padding-top: 70px;
  }

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

  .container{
    width: 92%;
    max-width: 400px;
    margin:0 auto;
  }

  .common_title_set{

  }

  .common_title_set .ja_title{
    font-size: 12px;
    position: relative;
  }

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

  .common_title_set .en_title{
    font-size: 40px;
    padding-left:30px ;
    line-height: 1;  
    position: relative;
  }

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


  /*共通のリンクボタン*/
  .common_blue_button{
    min-width: 160px;
    min-height:30px;
    border-radius: 5px;
    padding:4px 16px;
    font-size: 14px;
  }


  /*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% + 180px);
  }

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

  .common_staff_area .staff_slide{
    width:205px;
    padding-right: 80px;
  }


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

  .common_staff_area .staff_nav{
    width: 50px;
    height: 24px;
    font-size: 16px;
  }

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

  .common_staff_area .staff_text_area{
    left:150px;
    bottom:20px;
    width:200px;
  }

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

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

  .common_staff_area .staff_text_block .staff_info{
    margin-top: 8px;
    line-height: 1.3;
    font-size: 12px;
  }

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


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

  .common_page_link_list{

  }

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

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

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

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

  .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: 60px;
    height: 60px;
  }

  .common_page_link_list .link_radi::after{
    width:24px;
    height:15px;
  }

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





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

  header{

  }

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

  header .header_flex{
    height: 70px;
  }

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

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

  header .header_nav{
    display: none;
  }
  

  header .drawer_open_inner{
    width: 48px;
    height: 24px;
    padding:0 5px;
    gap:0 4px;
  }

  header .drawer_open_inner span{
    width:4px;
    height:4px;
  }

  #drawer_menu{
  
  }


  #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: 32px;
    padding-bottom: 24px;
  }

  footer .footer_inner{
    width: 92%;
    max-width: 400px;
    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:56px;
    flex-shrink: 0;
    margin-right: 24px;
  }

  footer .footer_name{
    margin-top:0;
    font-size: 14px;
  }

  footer .footer_address{
    margin-top: 8px;
    line-height: 1.5;
    font-size: 14px;
  }

  footer .footer_tel{
    margin-top: 8px;
    line-height: 1.5;
    font-size: 14px;
  }

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

  footer .footer_nav{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    width: 100%;
    margin:0 auto;
  }

  footer .parent_menu + .parent_menu{
    margin-left: 0;
    font-size: 14px;
  }

  footer .parent_item{
    font-size: 14px;
  }

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

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

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

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

  .common_contact_section{
    padding-top: 20px;
    padding-bottom: 20px;
  }



  .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: 40px;
  }

  .common_contact_section .contact_text_list{
    margin-top: 32px;
    gap:16px 0;
    flex-direction: column;
    width: fit-content;
    margin-inline: auto;
  }

  .common_contact_section .contact_text_list li{
    padding-left: 0;
    width: auto;
    max-width: 100%;
  }

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

  

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

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

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

  .common_contact_section .tel_block .tel::before{
    width:34px;
    height:34px;
    margin-bottom: 16px;
  }

  .common_contact_section .tel_block .tel_time{
    margin-top: 16px;
    font-size: 12px;  
    text-align: center;
  }

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

  .common_contact_section .mail_block .mail_icon{
    width:30px;
    height:24px;
  }

  .common_contact_section .contact_button{
    margin:28px auto 0;
    min-width:126px;
  }



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

  .common_partner_section{
    padding-top: 100px;
    padding-bottom: 100px;
  }

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

  }


  .common_partner_section .partner_list{
    margin-top: 40px;
    gap:32px 0;
  }

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

  .common_partner_section .partner_item01 img{
    width:240px;
  }
  .common_partner_section .partner_item02 img{
    width:260px;
  }
  .common_partner_section .partner_item03 img{
    width:190px;
  }

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

  main.top_main{

  }

  .top_section{
    position: relative;
  }

  .top_mv_section{

  }

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

  .top_mv_section .mv_textarea{
    width:90%;
    height:100%;
  }

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

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

  .top_about_section{
    padding-top: 36px;
    padding-bottom: 24px;
  } 


  .top_about_section .about_radi01{
    width:686px;
    height:343px;
    top:-100px;
    left:calc(50% - 400px);
  }
  .top_about_section .about_radi02{    
    width: 488px;
    height: 244px;
    top:64px;
    left:calc(50% - 360px);
  }

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

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

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

  .top_about_section .about_block{

  }

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

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

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


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

  .top_about_section .about_card01{
    width:162px ;
    padding-top: 116px;
  }
  .top_about_section .about_card02{
    width:188px;
  }
  .top_about_section .about_card03{
    width:133px;
    padding-top: 148px;
  }
  .top_about_section .about_card04{
    width:228px;
    padding-top: 20px;
  }
  .top_about_section .about_card05{
    width:168px;
    padding-top: 106px;
  }
  .top_about_section .about_card06{
    width:190px;
    padding-top: 6px; 
  }

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

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

  .top_service_section .service_bg{
    width:580px;
    top:20px;
  }

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

  .top_service_section .service_item{
    width: 78px;
    height:117px;
    flex-shrink: 0;
    
  }

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

  .top_service_section .service_item + .service_item{
    margin-left: -6px;
  }

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

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

  .top_service_section .service_card01{
    background-image: url('../img/top/top_serice_card01_sp.png');
    
  }
  .top_service_section .service_card02{
    background-image: url('../img/top/top_serice_card02_sp.png');
  }
  .top_service_section .service_card03{
    background-image: url('../img/top/top_serice_card03_sp.png');
  }
  .top_service_section .service_card04{
    background-image: url('../img/top/top_serice_card04_sp.png');

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

  .top_service_section .service_text{
    margin-top: 80px;
    text-align: center;
    line-height: 1.6;
    font-size: 14px;
    white-space: nowrap;
  }

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

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

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

  .top_intro_section{
    padding-top: 80px;
  }

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

  .top_intro_section .js_radi_fix_start{
    top: -48px;
  }
  .top_intro_section .js_radi_fix_end{
    top:calc(100% + 100px);
  }

  .top_intro_section .intro_radi01{
    top: -48px;
    width:556px;
  }

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

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

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

  .top_intro_section .intro_radi02{
    top: 366px;
    width:666px;
  }

  .top_intro_section .js_intro_radi02_start_pos{
    top: 366px;
  }

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

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

  .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 - 222px));
  }
  .top_intro_section .anime_active .js_intro_radi02.move .intro_radi_inner::after{
    transform: translateX(calc(-666px + 266px));
  }


  .top_intro_section .flex{
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    align-items: center;
  }

  .top_intro_section .news_area{
    width:92%;
  }


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

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

  .top_intro_section .news_area .news_date{
    font-size: 14px;
  } 
  .top_intro_section .news_area .news_title {
    margin-top: 16px;
    padding-left: 20px;
    line-height: 1.5;
    font-size: 14px;
  }

  .top_intro_section .news_area .news_button_frame{
    margin-top: 24px;
    display: flex;
    justify-content: center;
  }

  .top_intro_section .seminer_area{
    width:92%;
    margin-top: 80px;
  }

  .top_intro_section .seminer_area .seminer_contents{
    padding-left: 0;
    margin-top: 40px;
  }

  .top_intro_section .seminer_area .seminer_text{
    margin-top: 20px;
    font-size: 16px;
    font-weight: 700;
    display: flex;
    justify-content: center;
  }

  .top_intro_section .seminer_area .seminer_button_frame{
    margin-top: 24px;
    display: flex;
    justify-content: center;
  }


  .top_recruit_section{
    padding-top: 160px;
    padding-bottom: 180px;
  }


  .top_recruit_section .recruit_img_frame .recruit01{
    width: 86px;
    top: 200px;
    right: calc(50% + 110px);
  }
  .top_recruit_section .recruit_img_frame .recruit02{
    width: 131px;
    top: 480px;
    right: calc(50% - 180px);
  }
  .top_recruit_section .recruit_img_frame .recruit03{
    width: 104px;
    top: 54px;
    left: calc(50% + 90px);
  }

  .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: 40px;
    text-align: center;
    font-size: 20px;
    font-weight: 900;
    line-height: 1.4;
  }

  .top_recruit_section .recruit_text{
    margin-top: 40px;
    font-weight: 900;
    line-height: 1.5;
    font-size: 14px;
    text-align: center;
  }

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


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

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

  .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;
  }

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

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

  .common_page_nav_contents{
    width: 92%;
    max-width: 400px;
    margin: 0 auto;
  }

  .common_page_nav_area .en_name{
    font-size: 48px;
    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{
    width: 92%;
    max-width: 400px;
    margin: 0 auto;
    
  }



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

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

  /*
  ------------------------------------
  Mフレンドについて
  ------------------------------------
  */

  body.about_body{
    
  }

  main.about_main{

  }


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

  .about_section{
    position: relative;
  }

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

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

  .about_section01 .about_block{

  }

  .about_section01 .about_block .about_title_block{
    height:60px;
    padding-left: 32px;
    border-radius: 100px;
    width: 100vw;
  }

  .about_section01 .about_block .about_title{
    font-size: 24px;
  }

  .about_section01 .about_block .about_head{
    font-size: 20px;  
    font-weight: 700;
    line-height: 1.5;
  }


  .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: 200px;
  }

  .about_section01 .about_block02{
    margin-top:60px;
  }
  .about_section01 .about_block02 .about_title_frame{
    padding-left: 120px;
  }

  .about_section01 .about_block03{
    margin-top:60px;
  }
  .about_section01 .about_block03 .about_title_frame{
    padding-left: 40px;
  }



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

  body.message_body{
    
  }

  main.message_main{

  }

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

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


  .message_section01 .message_radi{
    display: none;
  }

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

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

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

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

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

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

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

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

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

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

  .message_section01 .message_text{
    margin-top: 24px;
    letter-spacing: 0;
  }

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

  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: 100px;
    padding-bottom: 100px;
  }

  .company_section01 .company_radi{
    display: none;
  }

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

  .company_section01 .company_title{
    min-width: 100%;
    padding-right: 0;
    font-size: 18px;
  }

  .company_section01 .company_contents{
    width:100%;
    font-size: 18px;
    line-height: 1.3; 
    margin-top: 12px;
  }

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

  .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: 40px;
  }

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


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

  body.service_body{
    
  }

  main.service_main{

  }

  .service_section{
    position: relative;
  }

  .service_section01{
    padding-top: 100px;
  }

  .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: 60px;
  }

  .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_slide_list{
    position: relative;
    min-height: auto;
    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;
    flex-direction: column;
  }

  .service_slide_section .service_thumb{
    width:100%;
    margin-right: 0;
  }

  .service_slide_section .service_textarea{
    margin-top: 32px;
  }


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

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

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

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

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

  .service_slide_section .service_list li::before{
    width:24px;
    height:24px;
    margin-right: 8px;
  }

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

  .service_slide_section .service_nav_area{
    display: none;
  }


  .service_link_section{
    padding-top: 100px;
  }

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

  body.detail_body{
    
  }

  main.detail_main{

  }

  .detail_section{
    position: relative;
  }

  .detail_text_section{
    padding-top: 100px;
  }

  .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: 24px;
  }


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

  .detail_info_section{
    padding-top: 100px;
  } 

  .detail_info_section .intro_list{
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .detail_info_section .intro_block{
    flex-shrink: 0;
    width: 100vw;
    max-width: 400px;
  }

  .detail_info_section .intro_block .intro_head{
    height: 100px;
    border-radius: 0;
  }

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


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

  .detail_info_section .intro_block .intro_title{
    font-size: 20px;
    margin-top: 4px;
  }

  .detail_info_section .intro_block .intro_num{
    font-size: 48px;
    left:16px;
    top:10px;
  }

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

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

  .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: 100px;
    padding-bottom: 100px;
  }

  /*
  ------------------------------------
  スタッフ詳細
  ------------------------------------
  */

  body.staff_single_body{
    
  }


  main.staff_single_main{

  }

  .staff_single_section{
    position: relative;
  }

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

  .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: 32px;
    font-size: 28px;

  }

  .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: 18px;
  }

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

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

  .staff_list_section .staff_list{
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap:50px 0;
  }

  .staff_list_section .staff_item{
    width:100%;
  }


  .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: 0;
    padding-right: 0;
  }

  .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: 100px;
  }

  .recruit_flow_section .flow_block{
    position: relative;
  }

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

  .recruit_flow_section .flow_head{
    height: 60px;
    border-radius: 10px;
  }

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

  .recruit_flow_section .flow_num{
    font-size: 50px;
    left:-16px;
    top:-30px;
  }

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

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

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

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

  .recruit_appli_section{
    padding-top: 100px;
  }

  .recruit_appli_section .appli_block{
    padding:24px 0;

  }

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

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

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

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

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

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

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

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


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

  body.contact_body{
    
  }

  main.contact_main{

  }


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


  .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;
    flex-direction: column;
  }


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

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

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


  .contact_section .form_right{
    width: 100%;
    margin-top: 10px;
  }

  .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;
    flex-direction: column;
    align-items: center;
  }

  /*共通のリンクボタン*/
  .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: 100px;
    padding-bottom: 100px;
  }

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

  .archive_section01 .news_category_list li{
    margin-right: 12px;
    font-size: 20px;
  }

  .archive_section01 .news_category_list li::after{
    margin-left: 12px;
    font-size: 20px;
  }

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

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

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

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

  .archive_section01 .news_card::after{
    font-size: 20px;
    right:0px;
  }

  .archive_section01 .news_card .news_thumb{
    width:120px;
    margin-right: 20px;
  }

  .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: 13px;
  }

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

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

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


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

  body.single_body{
    
  }

  main.single_main{

  }

  .single_section01{
    padding-top: 24px;
    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: 24px;
  }

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

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

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

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


  .common_single_block h3{
    font-size: 18px;
    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: 24px;
  }

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

  .single_section01 .sns_list{
    margin-top: 24px;
    gap:0 60px;
  }

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

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

  .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_nav{
    font-size: 14px;
  }

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

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

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

  .single_section01 .link_list .link_title{
    margin-top: 12px;
    font-size: 14px;
    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;
  }
  
  
}/*@media screen and (max-width:767px){*/