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

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

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

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

  .container{
    max-width: 650px;
  }


  .sec_title_set{

  }
  .sec_title_set .en_title{
    white-space: nowrap;
    left:-50px;
    top:-54px;
    font-size: 100px;
  }

  .sec_title_set .ja_title{
    font-size: 50px;
  }


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

  header{
    position: fixed;
    width:100%;
    top:0;
    left:0;
    z-index: 30;
    pointer-events: none;
    font-family: "Inter", sans-serif;
  }


  header .header_inner{
    max-width: 1200px;
    margin:0 auto;
    padding:15px 15px 0;
  }

  header .header_frame{
    box-shadow:none;
    width: 100%;
  }

  header .header_flex{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-left:0;
    padding-right: 0;
    background-color: transparent;
    border-radius:0;
    height:auto;
    z-index: 25;
  }

  header .header_logo{
    display: block;
    width:180px;
    pointer-events: auto;
  }

  header .parent_menu{
    display: none;
  }

  header .header_contact{
    display: none;
  }

  header .drawer_open{
    pointer-events: auto;
    cursor: pointer;
    width: 120px;
    height: 50px;
    border-radius: 60px;
    background-color: #fff;
    border: 1px solid #000;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 18px;
    font-weight: 600;
    line-height: 1;
    color:#000;
    margin-top: 4px;
  }


  #drawer_menu_bg{
    position: fixed;
    top:0;
    left:0;
    z-index:15;
    width:100%;
    height:100vh;
    opacity: 0;
    pointer-events: none;
    transition-duration:0.7s;
    background-color: rgba(0,0,0,0.6);
  }

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

  #drawer_menu{
    position: fixed;
    top:0;
    right:0;
    z-index:20;
    width:100%;
    max-width: 450px;
    height: calc(100vh );
    height: calc(var(--vh2, 1vh) * 100);
    background-color: #19276C;
    transition-duration: 0.7s;
    opacity: 0;
    pointer-events: none;
    padding-top: 90px;
    font-family: "Inter", sans-serif;
  }

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

  #drawer_menu .drawer_menu_inner{
    height:100%;
    overflow-y: scroll; 
    scrollbar-width: none; 
    -ms-overflow-style: none;
  }

  #drawer_menu .drawer_menu_inner::-webkit-scrollbar{
    display: none;
  }

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

  #drawer_menu .parent_menu{

  }

  #drawer_menu .parent_item{
    border-bottom:1px solid #fff;
  }

  #drawer_menu .parent_item:last-child{
    border-bottom: none;
  }

  #drawer_menu .parent_link{
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    text-shadow: 1px 2px 2px #000000;
    padding:24px 0;
  }

  #drawer_menu .parent_link::before{
    content:'';
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background-color: #fff;
    margin-right: 14px;
  }

  #drawer_menu .contact_button{
    display: flex;
    justify-content: center;
    align-items: center;
    width: 232px;
    height: 60px;
    border-radius: 60px;
    background-color: #315AE8;
    margin:56px auto 0;
    position: relative;
    box-shadow: 2px 1px 1px 0px #00000040;
    font-size: 14px;
    font-weight: 700;
    text-shadow: 1px 2px 2px #000000;
  }

  #drawer_menu .contact_button::after{
    content:"";
    width: 27px;
    height: 27px;
    border-radius: 50%;
    background-image: url('../img/common/icon_radi_arrow_right_black.svg');
    position: absolute;
    right:15px;
    top:0;
    bottom:0;
    margin:auto;
  }

  #drawer_menu .contact_button::before{
    content:'';
    width:100px;
    height:100px;
    background-image: url('../img/common/header_contact_icon.png');
    left:-20px;
    top:-35px;
    position: absolute;
  }
  /*
  ------------------------------------
  フッター
  ------------------------------------
  */

  footer{
    padding:120px 0 20px;
  }

  footer .contact_button{
    width: 405px;
    height: 68px;
    font-size: 18px;
    top:-34px;
  }

  footer .contact_button::before{
    width: 25px;
    height: 20px;
    margin-right: 6px;
  }

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

  footer .footer_flex{
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
    margin:0 auto;
  }

  footer .footer_logo{
    display: block;
    width:163px;
  }

  footer .parent_menu{
    display: flex;
    align-items: center;
    margin-top: 32px;
  }

  footer .parent_item{
    margin-left: 20px;
  }

  footer .parent_link{
    font-size: 14px;
    font-weight: 700;
  }

  footer .footer_copy{
    padding-top: 24px;
    margin-top: 36px;
    font-size: 12px;
    
  }
  /*
  ------------------------------------
  トップ
  ------------------------------------
  */

  body.top_body{
    
  }
  main.top_main{

  }

  .top_section{
    position: relative;
  }

  .top_mv_section{
    
  }
  .top_mv_section .mv_area{
    max-width: 100%;
    margin:0 auto;
  }

  .top_mv_section .mv_text{
    max-width: 720px;

    margin: 8px auto 0;
    font-size: 14px;
    line-height: 1.4;
  }

  .top_about_section{
    padding-top: 110px;
  }

  .top_about_section::before{
    width: 561px;
    height: 243px;
    background-image: url('../img/top/top_about_bg.png');
    top:40px;
    left:calc(50% + 64px);

  }

  .top_about_section .about_msg{
    margin-top: 24px;
    max-width: 756px;
  }

  .top_about_section .about_list{
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
    margin-top: 56px;
    gap:56px 0;
  }

  .top_about_section .about_block{
    position: relative;
    width: 280px;
    padding-left: 50px;
    margin-left: -50px;
  }

  .top_about_section .about_num{
    position: absolute;
    top:0;
    left:8px;
    font-size: 50px;
  }

  .top_about_section .about_slash{
    left:110px;
    top:40px;
    width:82px;
  }

  .top_about_section .about_icon{
    display: flex;
    min-height:200px;
    align-items: flex-end;
  }

  .top_about_section .about_icon01{
    width:166px;
    margin-left: 72px;
  }
  .top_about_section .about_icon02{
    width:113px;
    margin-left: 100px;
  }
  .top_about_section .about_icon03{
    width:134px;
    margin-left: 96px;
  }

  .top_about_section .about_text{
    margin-top: 24px;
    white-space: nowrap;
  }

  .top_service_section{
    padding-top: 160px;
  }

  .top_service_section .service_text{
    margin-top: 40px;
    line-height: 1.5;
  }


  .top_service_section .youtube_frame{
    margin: 56px auto 0;
  }


  .top_service_section .youtube_frame .youtube_play{
    width:175px;
    height:175px;
  }


  .top_feature_section{
    padding-top: 160px;
  }

  .top_feature_section .feature_list{
    margin-top: 88px;
  }

  .top_feature_section .feature_block{
    display: flex;
    justify-content: flex-start;
    flex-direction: column;
    align-items: center;
  }

  .top_feature_section .feature_block .feature_img_area{
    display: flex;
    justify-content: center;
    position: relative;
    width:450px;
    flex-shrink: 0;
  }

  .top_feature_section .feature_block .feature_img01{
    width:295px;
    margin-left: 10px;
    margin-top: 24px;
  }
  .top_feature_section .feature_block .feature_img02{
    width:277px;
    margin-top: 60px;
    margin-left: 24px;
  }
  .top_feature_section .feature_block .feature_img03{
    width:280px;
    margin-top: 10px;
  }

  .top_feature_section .feature_block .feature_num{
    position: absolute;
    z-index: 2;
  }

  .top_feature_section .feature_block .feature_num01{
    width:92px;
    left:-10px;
    top:-50px;
  }
  .top_feature_section .feature_block .feature_num02{
    width:106px;
    left:50px;
    top:-60px;
  }
  .top_feature_section .feature_block .feature_num03{
    width:109px;
    left:-10px;
    top:-70px;
  }


  .top_feature_section .feature_block .feature_text_area{
    width: 100%;
    margin-top: 32px;
  }

  .top_feature_section .feature_block .feature_head{
    font-family: "Inter", sans-serif;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.2;
    padding-bottom: 32px;
    position: relative;
  }

  .top_feature_section .feature_block .feature_head::after{
    content:'';
    width: 50px;
    height: 2px;
    position: absolute;
    bottom: 0;
    left: 0;
    background-color: #fff;
  }

  .top_feature_section .feature_block .feature_text{
    margin-top: 24px;
    line-height: 1.9;
  }



  .top_feature_section .feature_block02{
    flex-direction: column;
    margin-top: 150px;
  }
  .top_feature_section .feature_block03{
    margin-top: 150px;
  }


  .top_place_section{
    padding-top: 160px;
  }

  .top_place_section .place_msg{
    margin-top: 24px;
  }

  .top_place_section .place_list{
    padding:0;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 40px;
  }

  .top_place_section .place_block{
    width:32%;
  }

  .top_place_section .place_block .place_num{
    font-size: 50px;
    min-height:60px;
  }

  .top_place_section .place_block .place_num img{
    width:11px;
    flex-shrink: 0;
    margin-right: 6px;
    margin-top: 6px;
  }

  .top_place_section .place_block .place_title{
    font-size: 20px;
  }

  .top_place_section .place_block .place_img{
    margin-top: 24px;
  }


  .top_place_section .place_block .place_text{
    margin-top: 16px;
    font-weight: 400;
    line-height: 1.9;
  }

  .top_plan_section{
    padding-top: 160px;
  }

  .top_plan_section .plan_msg{
    margin-top: 24px;
  }

  .top_plan_section .plan_flex{
    padding:0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 56px;
    gap:40px 0;
  }

  .top_plan_section .plan_block{
    width:450px;
    max-width: 100%;
  }

  .top_plan_section .plan_block .plan_head{
    min-height:115px;
    padding:12px;
    font-size: 26px;    
  }

  .top_plan_section .plan_block .plan_body{
    padding:0 32px;
    padding-bottom: 8px;
  }

  .top_plan_section .price_area{
    padding-top: 48px;
    padding-bottom: 56px;
  }

  .top_plan_section .price_head{
    font-size: 18px;
  }

  .top_plan_section .price_num{
    font-size: 40px;
    margin-top: 14px;
  }

  .top_plan_section .price_num .mark{
    font-size: 30px;
  }

  .top_plan_section .price_num .yen{
    font-size: 20px;
    margin-left: 4px;
  }

  .top_plan_section .price_num .yen_text{
    font-size: 12px;
    position: absolute;
  }

  .top_plan_section .contact_button{
    min-width: 196px;
    height: 54px;
    padding:0 8px;
    margin:24px auto 0;
  }

  .top_plan_section .plan_list{

  }

  .top_plan_section .plan_line{
    padding:24px 0;
    font-size: 18px;
  }


  .top_plan_section .plan_line .big{
    font-size: 22px;
  }

  .top_plan_section .plan_line p + p{
    margin-top: 10px;
  }

  .top_plan_section .plan_line ul{
    font-size: 22px;
    margin:10px auto 0;
    
  }

  .top_plan_section .plan_line li{
    padding-left: 20px;
  }

  .top_plan_section .plan_line li::before{
    line-height: 1.5;
    font-size: 22px;
  }

  .top_plan_section .plan_line li + li{
    margin-top: 4px;
    
  }

  .top_intro_section{
    padding-top: 160px;
  }

  .top_intro_section .intro_msg{
    margin-top: 24px;
  }

  .top_intro_section .intro_list{
    display: flex;
    justify-content: space-between;
    align-items:center;
    flex-direction: column;
    flex-wrap: wrap;
    padding:0;
    margin-top: 56px;
    gap:40px 0;
  }
  

  .top_intro_section .intro_block{
    width:455px;
    max-width: 100%;
  }

  .top_intro_section .intro_head{
    font-size: 20px;
    padding-left: 16px;
    border-left:3px solid #fff;
  }

  .top_intro_section .intro_thumb{
    margin-top: 16px;
  }

  .top_intro_section .intro_icon01{
    width:295px;
  }
  .top_intro_section .intro_icon02{
    width:341px;
  }

  .top_flow_section{
    padding-top: 160px;
  }

  .top_flow_section .flow_frame{
    padding-right: 0;
    margin-top: 64px;
  }

  .top_flow_section .flow_block{
    padding-bottom: 32px;
    min-height: 200px;
  }
  .top_flow_section .flow_block::before{
    top:56px;
    left:56px;
  }

  .top_flow_section .flow_block:last-child{
    padding-bottom: 0;
    min-height: auto;
  }


  .top_flow_section .flow_left{
    width: 113px;
    height: 113px;
    margin-right: 28px;
  }

  .top_flow_section .flow_left .step_num_text{
    font-size: 14px;  
  }

  .top_flow_section .flow_left .step_num{
    font-size: 30px;
    margin-top: 6px;
  }

  .top_flow_section .flow_right{
    padding-top: 24px;
  } 

  .top_flow_section .flow_head{
    font-size: 20px;
  }

  .top_flow_section .flow_text{
    margin-top: 8px;
  }

  .top_faq_section{
    padding-top: 160px;
    padding-bottom: 320px;
  }

  .top_faq_section .tab_list{
    margin-top: 64px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
    flex-direction: column;
    padding:0 ;
    gap:20px 0;
  }

  .top_faq_section .tab{
    padding-bottom: 6px;
    font-size: 20px;
  
  }

  .top_faq_section .tab::after{
    width:100%;
    height:2px;
  }



  .top_faq_section .faq_frame{
    margin-top: 56px;
  }

  .top_faq_section .faq_block + .faq_block{
    margin-top: 28px;
  }

  .top_faq_section .faq_question{

    padding:24px 64px 24px 60px;
    font-size: 20px;
  }

  .top_faq_section .faq_question::before{
    font-size: 35px;
    left:10px;
    top:20px;

  }

  .top_faq_section .faq_question::after{
    width:24px;
    height:12px;
    right:24px;
    top:36px;
  }

  .top_faq_section .faq_answer{
    padding:28px 32px 0 60px;
    font-size: 20px;
  }



  .top_faq_section .faq_answer::before{

    font-size: 35px;
    left:10px;
    top:30px;

  }

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

  body.contact_body{
    
  }

  body.contact_body footer .contact_button{
    display: none;
  }

  main.contact_main{

  }

  .contact_section{
    padding-top: 226px;
    padding-bottom: 260px;
  }

  .contact_section .p01{
    margin-top: 20px;
    line-height: 1.5;
  }

  .contact_section .form_area{
    margin-top: 72px;
  }

  .contact_section .form_head{
    padding:16px 90px;
    font-size: 14px;
  }

  .contact_section .form_box{
    padding:56px 0 0 0;
  } 

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

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

  .contact_section .form_left{
    width:190px;
    margin-right: 50px;
  }

  .contact_section .form_label{
    text-align: right;
    padding-right: 28px;
  }


  .contact_section .form_label::after{
    position: absolute;
    right:0;
    top:0;
  }


  .contact_section .form_right{
    width:100%;
  }

  .contact_section .radio_area{
    margin-top: -4px;
  }

  .contact_section .radio_area .wpcf7-radio{
    display: flex;
    align-items: center;
    gap:16px 40px;
  }

  .contact_section .radio_area label input{
    margin-right: 8px;
  }

  .contact_section .select_frame{
    max-width: 330px;
    margin-top: -8px;
  }

  .contact_section .select_frame select{    
    height: 35px;
    padding:0 16px;
  }

  .contact_section .input_frame{
    margin-top: -8px;
  }

  .contact_section .input_frame.half{
    max-width: 330px;
  }

  .contact_section .input_frame input{
    height: 35px;
    padding:0 16px;
  }

  .contact_section .input_frame textarea{
    height: 200px;
    padding:16px;
  }

  .contact_section .submit{
    width: 92px;
    height: 33px;
    font-size: 14px;
  }
  
}/*@media screen and (max-width:1200px){*/