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


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

  .container{
    width: 88%;
    max-width: 400px;
  }


  .sec_title_set{

  }
  .sec_title_set .en_title{
    white-space: nowrap;
    left:-10px;
    top:-20px;
    font-size: 40px;
  }

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


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

  header{

  }


  header .header_inner{
    padding:15px 15px 0;
  }


  header .header_logo{
    width:112px;
  }


  header .drawer_open{
    width: 91px;
    height: 30px;
    font-size: 14px;
    margin-top: 4px;
  }


  #drawer_menu{
    max-width: 450px;
    padding-top: 60px;
  }


  #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{
    font-size: 14px;
    padding:24px 0;
  }


  /*
  ------------------------------------
  フッター
  ------------------------------------
  */

  footer{
    padding:64px 0 20px;
  }


  footer::before{
    width:155px;
    height:190px;
    right: calc(50% + 35px);
    top: -130px;
  }
  footer::after{
    width:130px;
    height:200px;
    left: calc(50% + 50px);
    top: -170px;
  }
  

  footer .contact_button{
    width: 240px;
    height: 68px;
    font-size: 16px;
    top:-34px;
    text-align: center;
  }

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

  footer .footer_inner{
    max-width: 400px;
    width: 88%;
    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:168px;
  }

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

  footer .parent_item{
    margin-left: 0;
    width:50%;
  }

  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: 400px;
    width: 92%;
    margin: 8px auto 0;
    font-size: 12px;
    line-height: 1.4;
  }

  .top_about_section{
    padding-top: 64px;
  }

  .top_about_section::before{
    width: 195px;
    height: 84px;
    background-image: url('../img/top/top_about_bg_sp.png');
    top:30px;
    left:calc(50% - 24px);

  }

  .top_about_section .about_msg{
    margin-top: 16px;
    line-height: 1.5;
  }

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

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


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


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


  .top_feature_section{
    padding-top: 72px;
  }

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

  .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:100%;
    flex-shrink: 0;
  }

  .top_feature_section .feature_block .feature_img01{
    width:192px;
    margin-left: 50px;
    margin-top: 20px;
  }
  .top_feature_section .feature_block .feature_img02{
    width:183px;
    margin-top: 24px;
    margin-left: 64px;
  }
  .top_feature_section .feature_block .feature_img03{
    width:190px;
    margin-top: 24px;
    margin-left: 56px;
  }

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

  .top_feature_section .feature_block .feature_num01{
    width:53px;
    left:0;
    top:0;
  }
  .top_feature_section .feature_block .feature_num02{
    width:60px;
    left:0;
    top:0;
  }
  .top_feature_section .feature_block .feature_num03{
    width:61px;
    left:0;
    top:0;
  }


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

  .top_feature_section .feature_block .feature_head{
    font-size: 20px;
    padding-bottom:16px;
    line-height: 1.5;
  }

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



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


  .top_place_section{
    padding-top: 72px;
  }

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

  .top_place_section .place_list{
    padding:0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
    margin-top: 40px;
    gap:32px 0;
  }

  .top_place_section .place_block{
    width:284px;
  }

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

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

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

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

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

  .top_plan_section{
    padding-top: 72px;
  }

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

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

  .top_plan_section .plan_block{
    width:345px;
    max-width: none;
  }

  .top_plan_section .plan_block .plan_head{
    min-height:54px;
    padding:8px 12px;
    font-size: 20px;    
  }

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

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

  .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:20px 0;
    font-size: 18px;
  }


  .top_plan_section .plan_line .big{
    font-size: 16px;
    font-weight: normal;
  }

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

  .top_plan_section .plan_line ul{
    font-size: 16px;
    font-weight: normal;
    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: 72px;
  }

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

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

  .top_intro_section .intro_block{
    width:100%;
    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:80%;
  }
  .top_intro_section .intro_icon02{
    width:80%;
  }

  .top_flow_section{
    padding-top: 72px;
  }

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

  .top_flow_section .flow_block{
    padding-bottom: 24px;
    min-height: 100px;
  }
  .top_flow_section .flow_block::before{
    top:30px;
    left:30px;
  }

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


  .top_flow_section .flow_left{
    width: 60px;
    height: 60px;
    margin-right: 20px;
  }

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

  .top_flow_section .flow_left .step_num{
    font-size: 20px;
    margin-top: 2px;
  }

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

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

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

  .top_faq_section{
    padding-top: 80px;
    padding-bottom: 230px;
  }

  .top_faq_section .ja_title {
    font-size: 20px;
  }

  .top_faq_section .tab_list{
    margin-top: 40px;
    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: 16px;
  
  }

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

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

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

  .top_faq_section .faq_question{
    padding:16px 32px 16px 48px;
    font-size: 16px;
    line-height: 1.5;
  }

  .top_faq_section .faq_question::before{
    font-size: 28px;
    left:10px;
    top:12px;

  }

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

  .top_faq_section .faq_answer{
    padding:16px 32px 24px 48px;
    font-size: 16px;
  }

  .top_faq_section .faq_answer::before{
    font-size: 28px;
    left:10px;
    top:12px;
  }

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

  body.contact_body{
    
  }

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

  main.contact_main{

  }

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

  .contact_section .p01{
    margin-top: 12px;
    line-height: 1.5;
    font-size: 14px;
  }

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

  .contact_section .form_head{
    padding:10px 12px;
    font-size: 14px;
  }

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

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

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

  .contact_section .form_left{
    width:auto;
    margin-right:0;
  }

  .contact_section .form_label{
    text-align: left;
    padding-right:0;
    display: flex;
    align-items: center;
  }


  .contact_section .form_label::after{
    position: static;
    right:0;
    top:0;
    margin-left: 8px;
  }


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

  .contact_section .radio_area{
    margin-top: 0;
  }


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

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

  .contact_section .input_frame{
    margin-top: 0;
  }

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

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

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

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