*{
    box-sizing: border-box;
}
body{
    max-width: 1100px;
    font-family: Arial,europa;
    margin: 0 auto;
    padding: 0 1%;
    color: #404040;
    letter-spacing: .1em;
    line-height: 1.6;
}
a{
    text-decoration: none;
}
a:hover{
    opacity: 0.7;
}
ul{
    list-style: none;
}
h2{
    padding-bottom: 25px;
    font-size: 20px;
}
h3{
    font-size: 16px;
    font-weight: lighter;
}
h4{
    font-size: 18px;
    padding-bottom: 10px;
}
h5{
    font-size: 16px;
    padding-bottom: 10px;
}
span{
    font-weight: bold;
}
section{
    padding: 30px 0;
}
.margin{
    flex-grow: 2;
}
/* ヘッダー */
.header{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 9px 30px 9px;
}
.header ul{
    display: flex;
}
.header li a{
    padding: 9px 0px;
    margin: 0px 9px;
    color: #999999;
    font-size: 14px;
}
h1 img{
    width: 120px;
    padding: 8px 7px;
}
/* メインビジュアル */
.main_visual{
    text-align: center;
    padding-top: 20px;
}
.main_visual img{
    width: 70%;
    vertical-align: top;
}
/* キャンペーン */
.campaign{
    display:flex;
    justify-content: space-between;
}
.briefing_campaign,.free_campaign{
    width: 48%;
    padding: 4%;
    background-color: #f7f7f7;
}
.campaign img{
    width: 100%;
}
.campaign p{
    font-size: 14px;
    color: #999999;
}
.free_campaign h2{
    padding-bottom: 60px;
}
.free_campaign a{
    color: #ffba66;
    font-size: 14px;
}
.free_campaign a:hover{
    color: #8c8c8c;
}
/* TVCM */
.tvcm p{
    color: #999999;
    font-size: 14px;
}
/* iframe */
.media{
    display: flex;
    justify-content: space-between;
}
.iframe_wrapper{
    display: flex;
    justify-content: space-between;
}
.iframe_wrapper iframe{
    width: 49%;
}
.release a{
    color:#fff;
    background-color: #ffba66;
    border-radius: 2em;
    display: block;
    width: 25%;
    padding: 2px 0px;
    text-align: center;
    font-size: 14px;
}
/* リリース */
.release{
    letter-spacing: .1em;
}
.ranking{
    width: 48%;
}
.ranking img{
    width: 100%;
    display: flex;
}
.release{
    width: 47%;
}
.release_title{
    display: flex;
    font-weight: bold;
}
date{
    padding-right: 20px;
}
.release_item{
    padding-bottom: 5%;
}
.release_sentence{
    padding-bottom: 2%;
}
.down{
    position: absolute;
    top: 5px;
    left: 0;
    transform: rotateZ(0deg);
    transition: 0.3s;
    height: 20px;
}
.label{
    width: 100%;
    font-size: 16px;
    text-align: left;
    padding-left: 40px;
    padding-bottom: 30px;
    
}
.toggle{
    display: none;
}
.label{
    display: block;
    position: relative;
    padding-left: 40px;
    cursor: pointer;
}
.add_content{
    height: 0;
    opacity: 0;
    transition: 0.2s;
    visibility: hidden;
}
.toggle:checked+.label+.add_content{
    height: auto;
    opacity: 1;
    visibility: visible;
}
.toggle:checked+.label img{
    content:"";
    display: block;
    transform: rotate(180deg);
    transition: 0.3s;
    position: absolute;
}
/* 悩み */
.worries img{
    width: 100%;
}
.worries p{
    font-size: 15px;
    padding-top: 2%;
}
/* at home */
.athome{
    display: flex;
    justify-content: space-between;
    height: 100%;
    margin: 0 auto;
}
.course,.workbalance{
    width: 44%;
    display: flex;
    flex-direction: column;
}
.course img,.workbalance img{
    width: 100%;
    padding-top: 20px;
}
/* サービス */
.service ul{
    list-style: disc;
    padding-left: 1em;
    font-size: 15px;
}
.service p{
    font-size: 15px;
}
.service_sentence{
    font-weight: bold;
    padding: 3% 0 2% 0;
}
.service_items{
    display: flex;
    justify-content: space-between;
    width: 80%;
}
.service_item{
    width: 15%;
}
.service_items p{
    font-size: 14px;
    color: #999999;
}
.service_item img{
    width: 100%;
}
/* スクール */
.school_contents{
    display: flex;
    justify-content: space-between;
}
.school_content{
    width:30%;
}
.school_content img{
    width: 100%;
    height: 172px;
    object-fit: cover;
}
.school1 p{
    padding-bottom: 1em;
}
.school2 p{
    padding-bottom: 66px;
}
.school3 img{
    margin-top: 111px;
}
/* 特徴 */
.feature{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.feature_title p{
    font-size: 20px;
    font-weight: bold;
    color: #404040;
}
.feature_contents{
    width: 48%;
    padding-bottom: 20px;
    padding: 5%;
    margin-bottom: 30px;
    background-color: #f7f7f7;
}
.feature_contents img{
    width: 100%;
}
.feature_contents h4{
    height: 65px;
}
.feature_contents p{
    padding-bottom:21px;
}
.feature_title{
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #ffba66;
}
/* 応用講座 */
.feature_advanced{
    width: 100%;
}
.advanced{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    max-width: 980px;
    margin: 0 auto;
}
.advanced_contents{
    width: 49%;
    padding: 15px 0;
}
.advanced_contents img{
    width: 100%;
}
/* おすすめ */
.recommend_image{
    display:flex;
    justify-content: space-between;
    align-content: flex-start;
    width: 70%;
    padding-top: 30px;
    align-items: flex-start;
}
.recommend_image img{
    width: 30%;
}
.comment_image{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.comment_image img{
    width: 45%;
}
.comment_link a{
    color: #ffba66;
}
.comment_link{
    text-align: center;
    padding-top: 100px;
}
.lesson_contents{
    display: flex;
    justify-content: space-between;
}
.lesson_content,.lesson_schedule{
    width: 49%;
}
.lesson_item{
    padding: 18px 0px ;
}
.lesson_item p{
    padding-bottom:15px;
    color: #888888;
    font-size: 14px;
}
.lesson_item p:nth-child(n+2){
    padding-top: 30px;
}
.lesson_caution{
    font-size:14px;
    color: #888888;
}
.lesson_schedule ul{
    list-style: disc;
    padding-left: 1em;
    padding-top: 20px;
}
.lesson_schedule li{
    line-height: 1.75;
    font-size: 15px;
}
/* 満足度アンケート */
.satisfaction_image{
    display: flex;
    justify-content: space-between;
    padding: 30px 0px;
    align-items: flex-start;
}
.satisfaction_image img{
    width: 48%;
}
.satisfaction p{
    padding-top:20px;
}
/* サポート */
.support_contents{
    display: flex;
    justify-content: space-between;
}
.support_content{
    width: 30%;
}
.support_content img{
    width: 98%;
}
.support_content h4{
    font-weight: lighter;
    font-size: 16px;
    padding: 15px 0px 20px 0px;
}
.support_content p{
    font-size: 14px;
    color: #888888;
}
/* 講師紹介 */
.instructor{
    line-height: 1.75;
}
.instructor_contents{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.instructor_content{
    display: flex;
    justify-content:left;
    width: 49%;
    background-color: #f7f7f7;
    margin: 10px 0px;
    padding: 4%;
}
.instructor_image img{
    width: 150px;
    padding-right: 15px;
}
.instructor_title{
    font-weight: bold;
}
.instructor_sentence ul{
    font-size: 15px;
    list-style: disc;
    padding-left: 1em;
    padding-bottom: 15px;
    width: 100%;
}
/* スクール詳細 */
.school_detail{
    display: flex;
    justify-content: space-between;
    flex-shrink: 0;
}
.price,.comparison{
    width: 45%;
}
.price img,.comparison img{
    width: 100%;
}
/* スケジュール */
.schedule{
    display: flex;
    justify-content: space-between;
    line-height: 1.75;
}
.schedule_image{
    text-align: center;
}
.day{
    font-size: 16px;
    font-weight: bold;
    padding-bottom: 10px;
}
.time{
    font-size: 15px;
}
.one_day{
    padding-bottom: 20px;
}
.schedule_sentence{
    color: #888888;
}
/* Q & A */
.question{
    line-height: 1.75;
}
.q{
    font-size: 16px;
    padding-bottom: 7px;
}
.a{
    font-size: 14px;
    padding-bottom: 15px;
    color: #888888;
}
/* 他コース */
.other_courses{
    display: flex;
    justify-content: space-between;
    padding-bottom: 100px;
}
.other_course{
    width: 30%;
}
.other_course img{
    width: 100%;
    padding-bottom: 15px;
}
.other_course p{
    font-size: 14px;
    color: #888888;
    padding-bottom:30px;
}
.other_course a{
    color: #ffba66;
    font-size: 14px;
}
.other_course a:hover{
    color: #8c8c8c;
}
/* ABOUT */
.about{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.about_image,.about_contents{
    width: 48%;
}
.about_image img{
    width: 100%;
}
.about{
    border-top: 1px solid #dddddd;
    padding: 50px 0px 80px 0px;
}
/* フッター */
footer{
    text-align: center;
    padding-bottom: 250px;
}
.footer_link a{
    display: inline-block;
    background-color:#ffaa33;
    border-radius: 2em;
    font-size: 16px;
    width: 400px;
    padding: 1em 0;
    color: #fff;
    font-weight: bold;
    margin-bottom: 43px;
}
.footer_list ul{
    display: flex;
    justify-content: center;
}
.footer_list li a{
    padding-right:20px ;
    color: #ffba66;
    line-height: 1.75;
    padding-top: 0.8px;
}