/* CSS Document */
.humb,.pc_none{
  display: none;
}
@media screen and (max-width: 768px){

/*
-------------------------------
共通
-------------------------------
*/
html{
  overflow: auto;
  position: relative;
  min-height: 100%;
  margin-top:0;
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
  font-size:55%;
}
ul.nav{
  display: block;
}
ul.nav li{
  display: block;
  text-align: left;
}
.over_width,.inner_width,#wrap{
  width:100%!important;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
}
.pc_none{
  display: block;
}
.sp_none{
  display: none !important;;
}
.title{
  padding:50px 10px 30px;
  background-position: right;
  background-size: cover;
}
.title h2{
  font-size: 50px;
}
.title p{
  font-size: 20px;
  color:#000;
}
/*
-------------------------------
header
-------------------------------
*/
header{
  background-color: transparent;
  position:fixed;
  top:0;
  left:0;
  z-index: 3;
}
.logo{
  width:80px;
  margin-left:-1rem;
  display: block;
}
.header_content{
  justify-content: space-between;
  align-items: center;
  padding:16px;
  box-sizing: border-box;
}
.fix_btn{
  width:65%;
  margin:0 auto;
  position:fixed;
  top:0;
  left:10px;
  
  border-radius: 5px;
  display: none;
  z-index:900;
}
.fix_btn.active{
  display: block;
  opacity: 0;
  animation-name: fadein;
  animation-duration: 1s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
}
@keyframes fadein {
  0% {
     opacity: 0;
     transform: translateY(0);
  }
  100% {
     opacity: 1;
     transform: translateY(20px);
  }
}
.fix_btn.active a img{
  width:100%;
}
  /*============
.toggle_btn
=============*/
.toggle_btn {
  display: block;
  position: relative;
  width: 40px;
  height: 40px;
  transition: all .5s;
  cursor: pointer;
  z-index: 10;
  background-color: #fff;
}
.toggle_btn span {
  display: block;
  position: absolute;
  left:5px;
  width: 30px;
  height: 2px;
  background-color: #3eb151;
  border-radius: 4px;
  transition: all .5s;
}
.toggle_btn span:nth-child(1) {
  top: 8px;
}
.toggle_btn span:nth-child(2) {
  top:20px;
  left:10px;
  width:20px;
}
.toggle_btn span:nth-child(3) {
  bottom: 8px;
}
.open .toggle_btn span:nth-child(1) {
  -webkit-transform: translateY(10px) rotate(-315deg);
  transform: translateY(12px) rotate(-315deg);
}
.open .toggle_btn span:nth-child(2) {
  opacity: 0;
}
.open .toggle_btn span:nth-child(3) {
  -webkit-transform: translateY(-10px) rotate(315deg);
  transform: translateY(-10px) rotate(315deg);
}
/*
-------------------------------
footer
-------------------------------
*/
.footer_menu{
  padding:5px 0;
}
footer{
  padding:5px;
  background-repeat: repeat;
  box-sizing: border-box;
}
footer .header_inner {
  width: 50%;
  margin: 30px 0 30px auto;
  }
.footer_content a {
  width: 100%;
  display: block;
  padding-left:2rem;
  box-sizing: border-box;
  }
  .footer_content a.footer_logo{
    width:30%;
    margin:36px auto 0;
  }
ul.footer_nav{
  display: block;
  padding:10px 5%;
  width:100%;
  text-align: left;
}
ul.footer_nav li{
  padding:5px 0;
  font-size:14px;
  margin-bottom:0;
}
.footer_content{
  display: block;
  width:95%;
  margin:30px auto;
  text-align: center;
  padding-top:0;
  padding-bottom:0;
}
.footer_content figure{
  width:80%;
  margin:0 auto 30px;
  padding-left:0;
}
.footer_content figure img{
  width:100%;
}
.footer_content img.logo{
  margin-bottom: 30px;
  width:120px;
  margin-left:1rem;
}
.footer_text{
  width:100%;
  padding:5px 10px;
}
.footer_policy a{
  padding:0 5%;
  font-size:var(--fs-small);
}
.footer_policy a::after{
  right:0.5%;
  top:6px;
}
.copy{
  font-size: 12px;
}
/*
-------------------------------
index
-------------------------------
*/
.mv{
  position:relative;
  left:0;
  height:80vh;
  overflow: hidden;
  /* background: url(../images/index/mv_sp.png) top center no-repeat; */
  background-size: cover;
}
/* .mv img{
  display: none;
} */
.mv h1{
  font-size:32px;
  padding-left:15px;
}
/* sec_1 */
.sec_1{
  padding:0 5%;
}
.sec_1 h2{
  font-size:2rem;
  margin:3em auto;
}

.sec_1_content{
  display: block;
  align-items: flex-end;
  justify-content: space-between;
}
.sec_1_content h3{
  font-size:3rem;
  margin-bottom:1.5em;
  font-family: var(--kozuka);
}
.sec_1_content p{
  font-size:1.6rem;
  text-align: left;
  padding:0;
  box-sizing: border-box;
  line-height: 1.5;
  margin-bottom:48px;
}
.sec_1 img{
  width:100%;
}
.sec_1 ul{
  display: flex;
  justify-content: space-between;
  margin:90px auto;
  flex-wrap: wrap;
}
.sec_1 ul li{
  width:48%;
}
.sec_1 ul li img{
  width:100%;
}
/* service */
.service{
  margin:96px auto 0;
  padding:0 5%;
}
.service h3{
  font-size:3rem;
  position:relative
}
.service h3::after{
  position:absolute;
  content:"";
  width:300px;
  height:4px;
  left:0;
  bottom:10px;
  background-color: #e0e0e0;
  z-index: -1;
}
.service_head{
  display: block;
  justify-content: space-between;
  margin-bottom:24px;
}
.service_head h4{
  color:#3eb151;
  font-size:3rem;
  font-weight:bold;
}
.service_head img{
  width:100%;
}
.service_wrap{
  display: block;
  gap: 24px;
}
.service_detail{
  padding:16px;
  border:1px solid #3eb151;
  width:100%;
}
.service_detail dl{
  display: block;
  flex-wrap: wrap;
  width:100%;
}
.service_detail dl dt{
  width:100%;
}
.service_detail dl dd{
  width:100%;
}
.service_detail p{
  margin-top:12px;
  padding:12px;
  border:1px solid #3eb151;
}
.service_image{
  width:100%;
  background-color: #e0e0e0;
  text-align: center;
  padding:16px;
  margin-top:16px;
}
.service_image img{
  width:100%;
}
.course{
  margin-top:1.5em;
  font-size:1.2rem;
}
.service_detail p.course_title{
  border:none;
  font-size:1.4rem;
}
.course ul{
  display: block;
  justify-content: space-between;
}
.course ul li{
  width:100%;
  font-size:1.4rem;
  text-align: center;
  border:1px solid #3eb151;
  padding:1.5em;
  font-weight:bold;
  margin-bottom:1em;
}
.course ul li span{
  font-size:1.2em;
}
/* sec_5 */
.sec_5{
  margin-top:96px;
  position:static;
  padding:0 5%;
}
.sec_5 img{
  position:static;
  width:100%;
}
.sec_5_detail{
  width:100%;
  margin: 0 auto;
}
.sec_5_detail h3{
  font-size:3rem;
  font-weight:bold;
  position:relative;
  text-align: left;
}
.sec_5_detail h3::after{
  position:absolute;
  content:"";
  width:300px;
  left:-10%;
  bottom:8px;
  height:8px;
  background-color: #e0e0e0;
  z-index: -1;
}
.sec_5_detail p{
  width:80%;
  margin:36px auto;
  font-size:2rem;
}
.sec_5_detail ul{
  position:static;
  padding:30px 16px;
  background-color: #e0e0e0;
  z-index: -2;
}
.sec_5_detail ul::before{
  opacity: 0;
}
.sec_5_detail ul li{
  width:90%;
  line-height: 2;
  font-size:1.6rem;
}
/* sec_6 */
.sec_6{
  margin-top:96px;
  padding:0 5%;
}
.sec_6_wrap{
  display: block;
  justify-content: space-between;
}
.sec_6_detail p{
  margin-top:36px;
  padding:16px;
  font-size:1.6rem;
  background-color: #e0e0e0;
  position:relative;
}
.sec_6_detail p::after{
  opacity: 0;
}
img.sec_6_image{
  width:100%;
  height:100%;
  margin-top:16px;
}
/* profile */
.profile{
  position:static;
  margin:48px auto 96px;
  padding:60px 5%;
  background: url(../images/index/profile_bg.jpg) center center no-repeat;
}
.profile::after{
  opacity: 0;
}
.profile_wrap{
  width:100%;
  max-width: 1280px;
  margin:0 auto;
}
.profile_head{
  display: block;
  flex-direction: row-reverse;
  justify-content: space-between;
}
.profile_head h3{
  font-size:3rem;
  font-weight:bold;
  position:relative;
  height:min-content;
  text-align: left;
  width:100%;
}
.profile_head img{
  width:100%;
  margin-top:24px;
}
.profile_head h3::after{
  position:absolute;
  content:"";
  width:80%;
  left:0;
  bottom:8px;
  height:8px;
  background-color: #e0e0e0;
  z-index: 1;
}
p.profile_detail{
  padding:1em;
  font-size:1.4rem;
  text-align: left;
  width:100%;
  margin:24px auto 0;
  background-color: rgba(255, 255, 255, 0.8);
  position:relative;
  z-index: 1;
  line-height: 1.6;
}
.price,.contact{
  margin-top:60px;
}
.price h3,.contact h3{
  font-size:3rem;
  position:relative;
  z-index: 2;
}
.price h3::after,.contact h3::after{
  position:absolute;
  content:"";
  width:360px;
  height:8px;
  left:0;
  bottom:8px;
  background-color: #e0e0e0;
  z-index: 1;
}
.price p{
  font-size:1.6rem;
}
.price ul{
  margin-top:1rem;
}
.price ul,
.price p.attention{
  font-size:1.6rem;
}
.contact dl{
  display: block;
  margin-top:1em;
  font-size:2rem;
}
.contact dl dd{
  padding-left:1em;
}
.contact a{
  text-decoration: none;
  color:#3e3e3e;
}
.contact .btn{
  margin:24px auto;
}
.contact a:hover{
  text-decoration: underline;
}
/* 問い合わせフォーム */
.mw_wp_form{
  padding:30px 5%;
  background-color: #f1f1f1;
}
.contact_form{
  margin:50px auto 150px;
  width:100%;
  max-width:880px;
  padding:0 5%;
}
.contact_head{
  margin-bottom:100px;
}
.contact_head h3{
  font-size:36px;
  font-weight:bold;
  color:rgb(38,97,52);
  margin-bottom:50px;
  text-align: center;
  background: url(../images/index/recruit_bg.jpg) center center no-repeat;
  background-size: cover;
  padding-top:130px;
  padding-bottom:130px;
  box-sizing: border-box;
  font-family: var(--english-font);
}

.contact_head h3 span{
  font-size:18px;
}
.contact_head p{
  text-align: left;
  font-size:14px;
  margin-top:100px;
}
.mw_wp_form h3{
  margin-bottom:8px;
}
.mw_wp_form h3 span{
  display: inline-block;
  padding:3px 5px;
  background-color: rgb(38,97,52);
  color:#fff;
  font-size:1.2rem;
}
.contact_form form p{
  font-size:14px;
  margin-bottom:8px;
}
.contact_form form p span.form_label{
  padding:3px 5px;
  background-color: #808080;
  color:#fff;
}
.contact_form form p span.red{
  padding:3px 5px;
  margin-left:3px;
  font-size:10px;
  background-color: #29abe2;
  color:#fff;
}
.contact_form form select{
  box-sizing: border-box;
  appearance: none;
  border:none;
}
.contact_form form input[name="name"],
.contact_form form input[name="rubi"],
.contact_form form input[name="address"],
.contact_form form input[type="email"],
.contact_form form textarea,
.contact_form form select{
  width:100%;
  padding:8px;
  font-size:14px;
  border:none;
  background-color: rgb(250, 250, 250);
  border-radius:7px;
}
.contact_form form input[type="text"]{
  padding:8px;
  border:none;
  background-color: rgb(250, 250, 250);
  border-radius:7px;
  width:100%;
}
.contact_form form input[type="text"][name="tel[data][0]"],
.contact_form form input[type="text"][name="tel[data][1]"],
.contact_form form input[type="text"][name="tel[data][2]"]
{
  width:25%;
}
.contact_form form input[type=submit]{
  padding:15px 0;
  width:200px;
  border:none;
  background-color: rgb(161, 161, 161);
  color:#fff;
}
.mw_wp_form .error{
  margin-top:5px;
}
}
