@chrset 'utf-8';
img{
    max-width:100%;
    height:auto;
}
.cf:before,
.cf:after {
    content: " ";
    display: table;
}
.cf:after {
    clear: both;
}
.cf {
    *zoom: 1;
}
html,body{
    font-family:'游ゴシック',YuGothic,'メイリオ',Meiryo, 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',sans-serif;
    height: 100%;
    background: #ebf1f7;
}
img{
    width: 100%;
    height: auto;
}
#container-wrapper{
    width: 100%;
}
section{
    width: 100%;
    background: #fff;
}
@media screen and (min-width:1200px) {
    #container-wrapper{
        max-width: 800px;
        margin: 0 auto;
    }
}
@media screen and (min-width:768px) {
    #container-wrapper{
        max-width: 800px;
        margin: 0 auto;
    }
}
.fs{
    font-family: "游明朝体", "Yu Mincho", YuMincho, serif;
}
h1,
.title,
.subtitle{
    text-align: center;
    font-weight: 600;
}
.title-plaid{
    text-align: center;
    margin: 0 4.79166666% 3.125%;
    padding: 4.16666666% 0;
    color: #ffffff;
    font-weight: 600;
    /*
    background: url(../img/bg-plaid.png) repeat 0 0;
    background-size: 3% auto;
    */
    background: #0e8ed1;
    margin-top: 20px;
}
table{
    border-collapse:collapse;
    border-spacing:0;
}
table,
table th,
table td{
    border-style:solid;
    border-color:#17a1e6;
    padding: 0.8em;
}
table{
    width:100%;
    border-width:1px 0 0 1px;
}
table th,
table td{
    border-width:0 1px 1px 0;
}
table th{
    background: #7ecef4;
    color: #ffffff;
}
table td{
    text-align: right;
}
.box-btn{
    padding: 0 4.79166666%;
}
.box-btn a{
    line-height: 1.6;
    font-size: 120%;
    font-weight: 600;
}
@media screen and (max-width:480px) {
    .box-btn a{
        font-size: 100%;
    }
}
.box-btn a:before{
    display: inline-block;
    box-sizing: border-box;
    content: ' ';
    width: 1em;
    height: 1em;
    background: url(../img/arrow-btn-right.png) no-repeat 50% 50%;
    background-size: 100%;
    vertical-align: top;
    margin-top: 0.3em;
    margin-right: 0.5em;
    
}
.bt-registration{
    display: block;
    text-align: center;
  background: #f15f75;
  background-image: -webkit-linear-gradient(top, #f15f75, #ea4c59);
  background-image: -moz-linear-gradient(top, #f15f75, #ea4c59);
  background-image: -ms-linear-gradient(top, #f15f75, #ea4c59);
  background-image: -o-linear-gradient(top, #f15f75, #ea4c59);
  background-image: linear-gradient(to bottom, #f15f75, #ea4c59);
  -webkit-border-radius: 9;
  -moz-border-radius: 9;
  border-radius: 9px;
  -webkit-box-shadow: 0px 7px 0px #e5304b;
  -moz-box-shadow: 0px 7px 0px #e5304b;
  box-shadow: 0px 7px 0px #e5304b;
  color: #ffffff;
  padding: 10px 10px 10px 10px;
  text-decoration: none;
    margin-bottom: 4%;
}
.bt-registration:hover{
    color: #ffffff;
  background: #ea4c59;
  background-image: -webkit-linear-gradient(top, #ea4c59, #f15f75);
  background-image: -moz-linear-gradient(top, #ea4c59, #f15f75);
  background-image: -ms-linear-gradient(top, #ea4c59, #f15f75);
  background-image: -o-linear-gradient(top, #ea4c59, #f15f75);
  background-image: linear-gradient(to bottom, #ea4c59, #f15f75);
  text-decoration: none;
}
.bt-coursesearch{
  display: block;
  text-align: center;
  background: #ff9831;
  background-image: -webkit-linear-gradient(top, #ff9831, #ff8103);
  background-image: -moz-linear-gradient(top, #ff9831, #ff8103);
  background-image: -ms-linear-gradient(top, #ff9831, #ff8103);
  background-image: -o-linear-gradient(top, #ff9831, #ff8103);
  background-image: linear-gradient(to bottom, #ff9831, #ff8103);
  -webkit-border-radius: 9;
  -moz-border-radius: 9;
  border-radius: 9px;
  -webkit-box-shadow: 0px 7px 0px #ff6200;
  -moz-box-shadow: 0px 7px 0px #ff6200;
  box-shadow: 0px 7px 0px #ff6200;
  color: #ffffff;
  padding: 10px 20px 10px 20px;
  text-decoration: none;
    margin-bottom: 4%;
}
.bt-coursesearch:hover{
    color: #ffffff;
  background: #ff8103;
  background-image: -webkit-linear-gradient(top, #ff8103, #ff9831);
  background-image: -moz-linear-gradient(top, #ff8103, #ff9831);
  background-image: -ms-linear-gradient(top, #ff8103, #ff9831);
  background-image: -o-linear-gradient(top, #ff8103, #ff9831);
  background-image: linear-gradient(to bottom, #ff8103, #ff9831);
  text-decoration: none;
}

section{
    padding: 4% 0 8%;
}
header{
    padding: 0 0 8%;
}

/*= KUMON QUALITY
---------------------------------*/
.box-quality1{
    background: #7ecef4;
}
.box-quality .kumon-logo{
    width: 29.13333333%;
    text-align: center;
    margin: 0 auto 4%;
}
.box-quality .kumon-quality{
    padding: 0 14.433333335%;
    margin-bottom: 4.66666666%;
}
.box-quality h1{
    color: #ffffff;
    font-weight: 600;
    font-size: 228.6875%;
    margin: 0;
    padding: 4% 0 4%;
}
@media screen and (max-width:640px) {
    .box-quality h1{
        /*font-size: 175%;*/
        font-size: 150%;
    }
}
.box-quality .read{
    /*font-size: 156%;*/
    font-size: 120%;
    padding: 0 0 4%;
    text-align: center;
    font-weight: 600;
}
.box-quality2 .kumon-quality{
    background: url(../img/bg-quality2.png) no-repeat 50% 0;
    background-size: cover;
}
.box-quality2 p{
    margin-bottom: 1em;
    padding: 0 4.79166666%;
}

/*= 公文品質6つのポイント
---------------------------------*/
.box-quality-point .section-inner{
    padding: 0 4.79166666%;
    color: #006699;
}
.box-quality-point .title{
    color: #17a1e6;
    margin: 0;
    padding: 6.45833333% 0;
    font-size: 220%;
}
.pointlist{
    margin: 0;
    padding: 0;
}
.pointlist li{
    list-style: none outside;
    counter-increment: num;
    width: 100%;
    margin-bottom: 2.70833333%;
    display: table;
    border: 3px solid #7ecef4;
    -moz-border-radius: 0.5em;
    -webkit-border-radius: 0.5em;
    border-radius: 0.5em;
}
.pointlist li:before{
    content: counter(num);
    display: table-cell;
    vertical-align: middle;
    text-align: center;
    font-weight: 600;
    color: #ffffff;
    background: #7ecef4;
    padding: 10px 0;
    width: 3em;
    font-size: 125%;
}
.pointlist li span{
    display: table-cell;
    vertical-align: middle;
    padding: 10px;
    font-weight: 600;
    font-size: 125%;
}
.box-quality-point p{
    font-weight: 600;
}
@media screen and (max-width:480px) {
    .pointlist li span{
        font-size: 100%;
    }
}

/*= 日本語でお悩みありませんか？
---------------------------------*/
.box-cloud{
    box-sizing: border-box;
    background: url(../img/cloud-bg-photo.jpg) no-repeat 0 0 #7ecef4;
    background-size: 100%;
}
.box-cloud .title{
    box-sizing: border-box;
    color: #ffffff;
    font-size: 190%;
    text-align: left;
    padding: 6.4% 0 5% 4.2%;
    margin: 0;
}
.box-cloud .subtitle{
    font-size: 220%;
}
.box-cloud .content-cloud{
    position: relative;
}
.box-cloud .cloud{
    width: 48.54166666%;
    display: table;
    position: absolute;
}
.box-cloud .cloud-md{
    width: 15%;
    position: absolute;
    top: 0;
    left: 48.2%;
}
.box-cloud .cloud-xs{
    width: 12.08333333%;
    position: absolute;
    top: 86.16071428%;
    right: 22.08333333%;
}
.box-cloud .cloud p{
    margin: 0;
    padding: 0;
    text-align: center;
    font-weight: 600;
    font-size: 100%;
    line-height: 1.5;
    color: #006699;
    display: table-cell;
    vertical-align: middle;
    padding-bottom: 3.125%;
}
.box-cloud .cloud-left{
    background: url(../img/cloud-left.png) no-repeat 0 0;
    background-size: 100%;
}
.box-cloud .cloud-right{
    background: url(../img/cloud-right.png) no-repeat 0 0;
    background-size: 100%;
}
.box-cloud .cloud.cloud1{
    top: 0.89285714%;
    left: 3.75%;
}
.box-cloud .cloud.cloud2{
    top: 10.22619047%;
    right: 3.75%
}
.box-cloud .cloud.cloud3{
    top: 26.33928571%;
    left: 3.75%;
}
.box-cloud .cloud.cloud4{
    top: 35.52380952%;
    right: 3.75%
}
.box-cloud .cloud.cloud5{
    top: 51.19047619%;
    left: 3.75%;
}
.box-cloud .cloud.cloud6{
    top: 61.375%;
    right: 3.75%
}
.box-cloud .cloud.cloud7{
    top: 76.63690476%;
    left: 3.75%;
}
@media screen and (max-width:480px) {
    .box-cloud .cloud p{
        font-size: 100%;
    }
}
/*= 公文日本語プログラムのポイント
---------------------------------*/
section.box-point{
    padding-top: 0;
    border-bottom: 1px solid #ff7e00;
}
section.box-point.box-point6{
    border-bottom: none;
}
section.box-point .content-point,
section.box-point .content-point-img{
    padding: 0 4.79166666%;
}
section.box-point .content-point-img{
    padding-bottom: 2%;
}
.box-point .title{
    background: #fffaea;
    margin: 0;
    padding: 10.41666666% 0;
    border-bottom: 2px solid #ffb266;
    color: #ff7e00;
    font-size: 260%;
}
.point-title{
    text-align: center;
    line-height: 1;
    padding: 1.66666666% 4.79166666% 6.25%;
}
.point-title .ic-light{
    width: 100%;
    padding: 5% 0 4.2%;
    background: url(../img/bg-light.png) no-repeat 50% 0;
    background-size: 20.83333333% auto;
}
.point-title .ic-light span{
    font-size: 160%;
}
.point-title .ic-light strong{
    font-size: 320%;
}
.point-title h3{
    margin: 0;
    padding: 0;
    font-weight: 600;
    color: #ff7e00;
    font-size: 150%;
}
.box-point .content-point h4{
    font-weight: 600;
    font-size: 140%;
}
@media screen and (max-width:480px) {
    .point-title h3{
        font-size: 120%;
    }
}

/*= 2つのコースとは
---------------------------------*/
section.box-about-course{
    background: #e8f9ff;
    border-top: 1px solid #009fe8;
    padding: 0;
}
.box-about-course .header-about-course{
    vertical-align: top;
    padding-bottom: 1em;
}
.box-about-course .content-about-course{
    padding: 0 4.79166666%;
    padding-top: 10px;
}
.box-about-course .about-couse-arrow,
.box-about-course .about-couse-arrow img{
    font-size: 0;
    line-height: 0;
    vertical-align: top;
}
.box-about-course .content-about-course p strong.blue{
    color: #009fe8;
}
.box-about-course .title{
    padding: 5% 4.79166666% 7.5%;
    margin: 0;
    background: #009fe8;
    color: #ffffff;
    font-size: 260%;
}
@media screen and (max-width:480px) {
    .box-about-course .title{
        font-size: 230%;
    }
}

/*= イラスト説明
---------------------------------*/
.box-coursecomm1{
    border-bottom: 1px solid #009fe8;
}
.box-coursecomm .read{
    padding: 0 4.79166666%;
}
.box-coursecomm .title{
    text-align: left;
    color: #009fe8;
    font-weight: 600;
    padding: 0 4.79166666%;
    font-size: 140%;
}
.box-coursecomm .img{
    padding: 0 4.79166666%;
}
.cloud-title{
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    background: url(../img/line-cloud.png) no-repeat 50% 0;
    background-size: 100%;
    font-weight: 600;
    text-align: center;
    padding: 9.58333333% 4.79166666% 6.875%;
}
.cloud-title strong{
    color: #fb7600;
}
@media screen and (max-width:480px) {
    .cloud-title{
        font-size: 110%;
    }
}

/*= イラスト説明2
---------------------------------*/
.box-coursecomm2 .title-plaid{
    margin-top: 4%;
    font-size: 200%;
}

/*= 入会までの流れ
---------------------------------*/
section.box-flow.box-flow-distance{
    padding-top: 0;
}
.box-flow{
    background: #d2eefd;
}
section.box-flow.box-flow-distance .title{
    background: #7ecef4;
    padding: 7.5% 0;
    text-align: center;
    margin: 0 0 5%;
}
.ic-num{
    display: inline-block;
    -moz-border-radius: 1em;
    -webkit-border-radius: 1em;
    border-radius: 1em;
    background: #009fe8;
    color: #ffffff;
    width: 1.5em;
    height: 1.5em;
    line-height: 1.5em;
    text-align: center;
}
.box-flow ol{
    margin: 0;
    padding: 0;
}
.box-flow li{
    list-style: none outside;
    counter-increment: num;
    padding: 0 0 6.125%;
    margin: 0 4.79166666% 2.08333333%;
    background: url(../img/arrow-ic-bold-down.png) no-repeat center bottom;
    background-size: 14.97695852%;
}
.box-flow li:before{
    content: counter(num);
    float: left;
    display: inline-block;
    margin-right: 0.5em;
    -moz-border-radius: 1em;
    -webkit-border-radius: 1em;
    border-radius: 1em;
    background: #009fe8;
    color: #ffffff;
    width: 1.5em;
    height: 1.5em;
    line-height: 1.5em;
    text-align: center;
}
.box-flow li p{
    margin-left: 1.8em;
}
section.box-flow-commute{
    /*margin-bottom: 6.91244239%;*/
}

/*= インストラクターのご紹介
---------------------------------*/
.box-teacher{
    border-top: 1px solid #f84862;
    /*background: #fdecea;*/
    background: #fff;
    padding-bottom: 0;
    /*margin-bottom: 6.25%;*/
}
.box-teacher .title{
    color: #f84862;
    margin: 4.75% 0 7.91666666%;
    padding: 0 4.79166666%;
    font-size: 220%;
}
.box-teacher .read{
    padding: 0 4.79166666%;
}
.box-teacher .teacher-profile{
    border-bottom: 1px solid #f84862;
    padding: 6.25% 4.79166666% 11.45833333%;
}
.box-teacher .teacher-profile .img {
    width: 67.91666666%;
    margin: 0 auto 4.16666666%;
}
.box-teacher .teacher-profile .name{
    color: #f84862;
    font-weight: 600;
    text-align: center;
    margin-bottom: 6.25%;
}

/*= 学習者の声
---------------------------------*/
.box-voice{
    background: #e8f9ff;
    border-bottom: 1px solid #55bff0;
    /*padding: 0 0 0;*/
}
.box-voice .img {
    width: 67.91666666%;
    margin: 4.16666666% auto 4.16666666%;
}
.box-voice .title{
    margin: 0;
    padding: 0;
    background: url(../img/bg-title-voice.png) no-repeat 0 0;
    box-sizing: border-box;
    background-size: 100%;
    padding: 8.29166666% 0;
    font-size: 320%;
}
.box-voice .voice-name{
    padding: 1em 0;
    margin: 0 4.79166666% 1em;
    border-bottom: 1px solid #bde7f9;
}
.box-voice .voice-name dt{
    font-weight: 600;
}
.box-voice .voice-name dt.name{
    color: #009fe8;
}
.box-voice .voice-content{
    padding: 0 4.79166666% 1em;
}
@media screen and (max-width:480px) {
    .box-voice .title{
        font-size: 230%;
    }
}
/*= footer
---------------------------------*/
.box-pagetop{
    padding: 0 4.79166666% 4.16666666%;
    background: #fff;
}
.box-pagetop .bt-pagetop{
    display: block;
    box-sizing: border-box;
    text-align: center;
    width: 100%;
    border: 1px solid #ededed;
    -moz-border-radius: 0.5em;
    -webkit-border-radius: 0.5em;
    border-radius: 0.5em;
}
.box-pagetop .bt-pagetop span{
    display: inline-block;
    padding: 3.33333333% 1em;
    font-weight: 600;
    font-size: 160%;
    color: #000000;
    text-align: center;
    
}
.box-pagetop .bt-pagetop span:after{
    content: ' ';
    display: inline-block;
    margin-left: 0.3em;
    width: 1em;
    height: 1em;
    box-sizing: border-box;
    background: url(../img/arrow-pagetop.png) no-repeat 0 50%;
    background-size: 100%;
}

footer{
    text-align: center;
    border-top: 1px solid #c9c9c9;
    padding: 7.08333333% 0 26.875%;
    background: #fff;
}
footer p{
    font-size: 120%;
}
@media screen and (max-width:480px) {
    footer p{
        font-size: 100%;
    }
}

/*= float footer
---------------------------------*/
#floatfooter{
    width: 100%;
    background: #fb7600;
    position: fixed;
    bottom: 0;
    left: 0;
}
#floatfooter .section-inner{
    width: 46.875%;
    margin: 0 auto;
}
@media screen and (max-width:768px) {
    #floatfooter .section-inner{
        width: 100%;
        margin: 0 auto;
    }
}

@media screen and (min-width:768px) {
    .box-quality h1 {
        font-size: 300%;
    }
    .box-quality p.read {
        /* font-size: 156%; */
        font-size: 180%;
    }
    .box-btn a {
        line-height: 1.6;
        font-size: 160%;
        font-weight: 600;
    }
    .box-cloud .title {
        font-size: 300%;
    }
    .box-cloud .cloud p {
        font-size: 180%;
    }
}

@media screen and (max-width:325px) {
    .box-cloud .cloud p {
        font-size: 80%;
    }
}


/* 2026年1月20日リリース時に反映させるcss */
.important-notice {
  color: #d60000;
  text-align: center;
  padding: 0 4.79166666%;
  margin-bottom: 10px;
}

.important-notice.add-mt {
  margin-top: 30px;
}

.important-notice__title {
  font-size: 18px;
  font-weight: bold;
  margin: 0;
}

.important-notice__text {
  margin-top: 10px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.6;
  margin: 10px 0 0 0;
}