@charset "utf-8";
.pc_none{
display: none !important;
}
/*pc1400設定
----------------------------------------------------------- */
@media(max-width:1400px) {
}

/*pc1024設定
----------------------------------------------------------- */
@media(max-width:1200px) {
.warp{
width: auto;
padding: 0 20px;
}

.fv h2 .text02 {
    font-size: 4.8vw !important;
}

.fv h2 span.text01 {
    font-size: 2.5vw !important;
}

/*

.fv h2 span {
  padding: 0 5px;
}

.fv h2 span.text01{
font-size: 20px;
line-height: 30px;
}

.fv h2 span.text02 {
  font-size: 40px;
  line-height: 53px;
  margin-top: 8px;
}

.fv p.text01{
margin-bottom: 5px;
font-size: 16px;
}

.fv p.text02{
font-size: 12px;
}*/
}
/*pc1024設定
----------------------------------------------------------- */
@media(max-width:1024px) {
#top .cont01 .box02{
background: url("../img/img02.jpg") no-repeat center right;
background-size: 70% auto;
}

#top .cont02 ul li {
  margin: 10px 15px 20px;
}
#top .cont02 .box p.btm br{
display: none;
}

.slider02{
width: 90%;
}
#top .cont05 .fl{
  flex-direction: column;
  align-items: center;
}
#top .cont05 .slick-prev {
  left: -20px;
  top: 175px;
}

#top .cont05 .slick-next {
  right: -20px;
  top: 175px;
}



.accordion_area .accordion_one .ac_header{
padding-right: 50px;
}

#top .cont04 .fl h3 br{
display: none;
}

#top .cont00 h2 {
  font-size: 20px;
  margin-bottom: 15px;
  color: #1847C7;
}
#top .cont00 h2 span {
  font-size: 30px;
  display: block;
  position: unset;
  top: unset;
  right: unset;
  bottom: unset;
  left: unset;
  margin: unset;
  color: #1847C7;
}
#top .cont00 .inner {
  padding-top: 30px;
  padding-bottom: 20px;
}
#top .cont00 .inner .content .item {
  width: 32%;
}
#top .cont00 .inner .content .item:nth-of-type(2) {
  margin: 0 2%;
}
#top .cont00 .inner .content .item h3 {
  font-size: 15px;
}
#top .cont00 .inner .content .item .img_box {
  width: 100%;
}
#top .cont00 .inner .text {
  width: fit-content;
  margin: 0 auto;
  font-size: 8px;
  margin-top: 15px;
}
#top .cont01_2 {
  width: 95%;
  margin-bottom: 80px;
}
#top .cont01_2 .inner .content {
  margin-top: 0;
  margin-bottom: 0;
}
#top .cont01_2 .inner .content .text {
  width: 90%;
  padding: 0 !important;
}
#top .cont01_2 .inner .content .img {
  width: 90%;
  margin-top: 20px;
}


}
@media(max-width:767px){
    .cont01_boxwrapper {
        gap: 14vw;
    }
	.fv h2{
margin-bottom: 7px;
}

.fv h2 span {
  padding: 0 5px;
}

.fv h2 span.text01{
font-size: 16px;
line-height: 1.4;
}
.fv h2 span.text01 .add {
  padding: 0;
  transform: translateY(-4px);
}

.fv h2 img {
    width: 69vw;
    margin-top: 4vw;
    margin-left: 5vw;
    margin-bottom: -1vw;
    padding-left: 0;
}

.fv h2 span.text02{
font-size: 8vw !important;
line-height: 1.4;
margin-top: 0;
}

.fv p.text01{
margin-bottom: 10px;
font-size: 14px;
}

.fv p.text02{
font-size: 10px;
}
}


/*tablet設定
----------------------------------------------------------- */
@media(max-width:768px) {
    .warp{
        padding: 0 30px;
    }
    .pc_none{
        display: block !important;
    }

    .sp_none{
        display: none !important;
    }

    header{
        height: 44px;
        position: fixed;
        width: 100%;
        background: #fff;
        z-index: 9999;
        top: 0;
        display: flex;
        align-items: center;
    }
    header h1 {
        padding-top: 0;
        padding-left: 3%;
    }

    header h1 img{
        width: 160px;
        vertical-align:top;
    }

    #menu li {
        height: 44px;
        padding-top: 14px;
        width: 50%;
        max-width: 200px;
    }

    #menu li a::before {
        top: 15px;
    }

    .fv{
        margin-top: 44px;
    }

    .fv .sp_none{
        display: none !important;
    }

    .fv h2,
    .fv .text_box{
        width: 100%;
        display: block;
        margin-left: 0;
    }

    .fv h2{
        margin-bottom: 7px;
    }

    .fv h2 span {
        padding: 0 5px;
    }

    .fv h2 span.text01 {
        font-size: 4.6vw !important;
        background: url(../img/h2-bg.png) no-repeat right top;
        background-size: auto 100%;
        line-height: 1.3;
        padding-top: 0.2em;
        padding-bottom: 0.2em;
    }

    .fv h2 span.text01:first-child {
        margin-bottom: 0.3em;
    }

    .fv h2 span.text02 {
        font-size: 6.3vw !important;
        margin-top: 0.2em;
        margin-bottom: 0.2em;
    }

    .fv h2 span.text02 img {
        width: 3.9em;
        position: absolute;
        padding: 0;
        margin: 0;
        bottom: 0;
        right: 0;
        transform: translateX(107%);
    }

    .fv .warp {
        bottom: 5%;
        padding: 0;
    }

    #top h2{
        font-size: 64px;
        margin: 40px auto 30px;
    }

    #top h2 span{
        font-size: 30px;
        top: 22px;
    }
    #top .cont00{
        padding-bottom: 40px;
    }
    #top .cont00 .inner .content .item {
        width: 33%;
    }
    #top .cont00 .inner .content .item:nth-of-type(2) {
        margin: 0 .5%;
    }
    #top .cont00 .inner .content .item h3 {
        font-size: 11px;
    }

    #top .cont01_2 {
        width: 100%;
        margin-top: 0px;
    }

    #top .cont01_2 .inner .img_box {
        width: 100%;
        position: unset;
        left: unset;
        top: unset;
        transform: unset;
    }
    #top .cont01_2 .inner .content {
        width: 90%;
        margin: 0 auto;
        margin-top: -50px;
        padding-bottom: 35px;
    }

    #top .cont01 {
        padding-bottom: 40px;
    }

    #top .cont01 .warp{
        padding: 0 0 2vw;
    }
    #top .cont01 .warp--cta{
        padding: 0 20px;
    }

    #top .cont01 .box01{
        background: url("../img/img01.jpg") no-repeat top left;
        background-size: 100% auto;
    }
    #top .cont01 .box02{
        background: url("../img/img02_sp.jpg") no-repeat top right;
        background-size: 100% auto;
    }
    #top .cont01 .box03{
        background: url("../img/img03_sp.png") no-repeat top left;
        background-size: 100% auto;
    }

    #top .cont01 .box01,
    #top .cont01 .box02,
    #top .cont01 .box03,
    #top .cont01 .box04,
    #top .cont01 .box05{
        height: auto;
        padding-top: 53vw;
        text-align: center;
        background-size: 100% auto;
        background-position: top;
    }

    #top .cont01 .in_box h3 {
        font-size: 6vw;
    }

    #top .cont01 .box01{
    }

    #top .cont01 .box02{
        background-position: top center;
    }

    #top .cont01 .box01 .in_box,
    #top .cont01 .box02 .in_box,
    #top .cont01 .box03 .in_box,
    #top .cont01 .box04 .in_box,
    #top .cont01 .box05 .in_box{
        position: static;
        margin: 0 20px;
        width: auto;
        transform: unset;
    }

    #top .cont01 .in_box{
        width: 100%;
        padding: 40px 5vw;
        text-align: left;
    }

    #top .cont01 .box03 .in_box .img {
        width: 90%;
        margin: 0 auto;
    }

    #top .cont01 p{
        margin-bottom: 20px;
        text-align: left;
    }

    #top .cont01 p.cmn_cta01{
        margin-bottom: 0;
        text-align: center;
        padding: 0;
    }

    #top .cont01 .in_box p span{
        margin-top: 20px;
        display: block;
    }

    #top .cont01 .bule_w{
        margin-bottom: 20px;
        padding: 0;
        text-align: center;
    }

    #top .cont02{
        background: url("../img/bg01_sp.png") no-repeat #1847C7;
        background-size: 100% auto;
        padding-bottom: 35px;
    }

    #top .cont02 p.po {
        font-size: 30px;
        top: 54px;
    }

    #top .cont02 p.top {
        padding: 0 0 20px;
    }

    #top .cont02 .fl{
        display: block;
    }

    #top .cont02 .box{
        width: 100%;
        margin-bottom: 20px;
    }

    #top .cont02 .box h3{
        font-size: 20px;
        line-height: 30px;
    }

    #top .cont02 .box img.po {
        width: 20%;
    }

    #top .cont02 .box img.po01 {
        width: 18%;
    }

    #top .cont02 ul{
        margin-top: 20px;
    }

    #top .cont02 ul li {
        margin: 0px 20px 10px;
    }

    #top .cont03{
        /*padding-bottom: 50px;*/
    }
    #top .cont03 .section_title{
        font-size: 25px;
    }
    #top .cont03 .section_title br{
        display: block;
    }
    #top .cont03 .tab_select_category a img{
        padding-bottom: 2px;
    }

    #top .cont04 {
        padding-bottom: 0px;
    }

    #top .cont04 .fl{
        display: block;
    }

    #top .cont04 .fl .text_box,
    #top .cont04 .img_box{
        width: 100%;
        padding: 0;
    }

    #top .cont04 .warp{
        padding: 0;
    }

    #top .cont04 .img_box img{
        width: 88%;
        margin-left: 12%;
    }

    #top .cont04 .box01 .img_box img {
    }

    #top .cont04 h2{
        font-size: 54px;
        margin-bottom: 70px;
    }

    #top .cont04 h2 span {
        top: 3px;
        line-height: 43px;
    }

    #top .cont04 .fl{
        padding-top: 59vw;
    }

    #top .cont04 .fl .text_box{
        padding: 0 20px;
    }

    #top .cont04 .fl h3{
        font-size: 20px;
        margin-bottom: 20px;
    }

    #top .cont04 .box01 {
        margin-bottom: 50px;
    }

    #top .cont04 .bg01{
        background: url("../img/img06_sp.png") no-repeat;
        background-size: 100% auto;
    }

    #top .cont04 .bg02{
        background: url("../img/img07_sp.png") no-repeat;
        background-size: 100% auto;
    }

    #top .cont04 .bg03{
        background: url("../img/img08_sp.png") no-repeat;
        background-size: 100% auto;
    }

    #top .cont04 .box02 {
        margin-bottom: 50px;
    }

    .slider02{
        width: auto;
    }

    #top .cont05 img{
        margin: 0 auto;
        display: block;
    }

    #top .cont05 .slick-prev{
        left: -10px;
    }

    #top .cont05 .slick-next{
        right: -10px;
    }

    #top .cont05 .slick-arrow {
        width: 20px;
        height: 20px;
    }

    #top .cont05{
        padding-bottom: 30px;
    }

    #top .cont06{
        padding-top: 1px;
    }

    #top .cont06 h2{
        font-size: 50px;
    }

    #top .cont06 h2 span {
        top: 18px;
    }

    #top .cont06 .fl{
        padding: 50px 20px;
        background: #fff;
    }

    #top .cont06 .fl .bg_line{
        background:url("../img/line_sp02.jpg") no-repeat top left, url("../img/line_sp.svg") repeat-y 20px 30px;
    }

    #top .cont06 .bule_w{
        font-size: 16px;
        padding: 0;
        margin-right: 5px;
    }

    #top .cont06 .fl .box {
        display: block;
    }

    #top .cont06 .fl .box .text_box,
    #top .cont06 .fl .box img{
        width: 100%;
    }
    #top .cont06 .text_box h3 {
        font-size: 20px;
    }
    #top .cont06 .text_box p.time {
        padding-left: 107px;
        background: url("../img/time.svg") no-repeat 80px 2px;
        margin-bottom: 30px;
    }

    #top .cont06 .text_box p{
        margin-bottom: 20px;
    }

    #top .cont06 .fl .box{
        padding-bottom: 45px;
    }

    #top .cont06 .text_box p span{
        margin-top: 20px;
        display:block;
    }

    #top .cont06 .fl .box img{
        width: 90%;
        margin-left: 10%;
    }

    #top .cont07{
        padding-bottom: 40px;
    }

    #top .cont07 h2{
        font-size: 62px;
    }

    #top .cont08 {
        padding-bottom: 40px;
    }

    #top .cont03 {
        /*padding-bottom: 40px;*/
    }

    .s_section{
        width: 100%;
    }

    .p-faq__headinner p.p-faq__q-txt {
        margin-right: 40px;
    }

    .accordion_area .accordion_one .ac_header{
        padding: 20px 0;
    }

    .accordion_area .accordion_one .ac_header .i_box {
        width: 14px;
        height: 14px;
    }

    .accordion_area .accordion_one .ac_header .i_box::before {
        width: 14px;
    }


    .accordion_area .accordion_one .ac_header .i_box::after {
        height: 14px;
        right: 6px;
    }

    .p-faq__bodyinner p.p-faq__a-txt{
        font-size: 14px;
    }

    .accordion_area .accordion_one .ac_inner {
        padding: 20px 0 30px;
    }

    #top .cont04 .fl h3 br{
        display: block;
    }

    a.btn{
        color: #fff;
        line-height:100px;
        padding-left: 45px;
        padding-right: 10px;
        width: auto;
        height: 100px;
        background: #FF981A;
        font-size: 22px;
        font-weight: bold;
        margin: 100px auto;
        display:block;
        position: relative;
    }

    a.btn::before{
        content: url("../img/ico03.svg");
        position: absolute;
        top: 37px;
        left: 50%;
        width: 28px;
        height: auto;
        line-height: 0;
        margin-left: -150px;
    } 

    #top .cont01 .box05 .map p {
        margin-bottom: 0.5rem;
    }

    #top .cont01 .box05 .map div a {
        width: 50%;
    }

    #top .cont01 .box05 .map .img_map {
        width: 100%;
    }

    #top .cont06 .text_box h4:after{
        display: none;
    }

    #top .cont06 .text_box.school_info:after{
        content: "";
        display: inline-block;
        width: 5rem;
        height: 1rem;
        transform: rotate(90deg) translate(1rem, -14px);
        background: url(../img/icon_arrowright.svg) no-repeat center left;
        background-size: auto 100%;
    }
}

@media(max-width:500px) {
  #top .cont05 .slick-prev {
    top: 17%;
  }
  #top .cont05 .slick-next {
    top: 17%;
  }
}
/*sp設定
----------------------------------------------------------- */
@media(max-width:375px) {
    .warp{
        padding: 0 20px;
    }

    #top .cont06 .fl .box img {
        width: 82%;
        margin-left: 18%;
    }

    #top .cont04 .fl h3 br {
        display: block;
    }

    .pct_none{
        display: none !important;
    }

    .spt_none{
        display: block !important;
    }

    }
