
@charset "Shift_JIS";
@import url(https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css);


html {
    font-size: 62.5%;
}

body {
    overflow-x: hidden;
    font-family:'Lato', 'Noto Sans Japanese', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    color: #000;
}


img{
    width: 100%;
    height: auto;
    display: block;
}

h1{
    margin: 0px;
    padding: 10px 0;
    background: #003e92;
    color: #fff;
    font-size: 0.7rem;
    text-align: center
}

@media screen and (max-width: 1024px) {
    .sp-none {
        display: none;
    }
}

@media screen and (min-width:1025px) {
    .pc-none {
        display: none;
    }
}
@media screen and (min-width: 650px){
    .br-pc { display:block; }
    .br-sp { display:none; }
}
@media screen and (max-width: 650px){
    .br-pc { display:none; }
    .br-sp { display:block; }
}


@media screen and (min-width: 1025px) {

    header {
        width: 100%;
        background: rgba(255, 255, 255, .6);
    }
    header ul{
        display: flex;
        flex-wrap: wrap;
        width: 1200px;
        margin: auto
    }
    header li.logo{
        width: 650px;
    }
    header li.contact{
        width: 550px;
        margin-left: auto
    }
    header li.contact p{
        padding: 10px 10px 0px 0px;
        font-size: 0.8rem;
        font-weight: bold;
        text-align: right
    }
    header li.contact span{
        color: #ff0000;
        font-size: 1.0rem
    }
    header li.contact .tel{
        width: 350px;
        margin-left: auto
    }
    header li.contact .mail{
        width: 280px;
        margin-left: auto
    }


    footer {
        width: 100%;
        background: rgba(255, 255, 255, .6);
        text-align: center;
    }

    footer p {
        margin-top: 20px;
        padding: 20px;
        color: #000;
        border-top: solid 1px #003e92;
        font-size: 0.8rem;
        font-weight: bold;
    }

    footer a {
        color: #000;
        text-decoration: none;
    }


    nav {
        width: 100%;
        height: 55px;
        background: #555;
    }

    nav ul {
        width: 1200px;
        height: 55px;
        margin: auto;
        display: flex;
        flex-wrap: wrap;
        border-left: 1px #fff dotted;
    }

    nav li {
        width : calc(100% / 7) ;
        text-align: center;
        margin-left: -1px;
        border-right: 1px #fff dotted;
    }
    nav li a{
        display: block;
        height: 55px;
        color: #fff;
        font-size: 0.6rem;
        font-weight: bold;
        text-decoration: none;
    }
    nav li a:hover {
        background-color: transparent;
        transition: 0.8s;
        background: #fff;
        color: #000;
    }
    nav li p{
        padding: 12px 0px 5px 0px;
        font-size: 1.0rem;
        font-weight: normal
    }


    #main{
        display: flex;
        flex-wrap: wrap;
        width: 1200px;
        margin: auto;
    }
    #main .menu{
        width: 280px;
    }
    #main .contents{
        width: 100%;
    }


    .breadcrumb {
        margin-left:0;
        background: rgba(170, 170, 170, .5);
        padding: 6px 10px 10px 10px;
        overflow: hidden;
    }
    .breadcrumb ul{
        width: 1200px;
        margin: auto
    }
    .breadcrumb li{
        display:inline;
        list-style: none;
        font-size: 0.7rem;
        font-weight: bold;
    }

    .breadcrumb li:after{
        content: '>';
        padding: 0 3px;
    }

    .breadcrumb li:last-child:after{
        content: '';
    }

    .breadcrumb li a {
        text-decoration: none;
        color: #000;
    }

    .breadcrumb li a:hover {
        text-decoration: underline;
    }

    .language{
        padding-bottom: 20px
    }
    .language ul{
        display: flex;
        flex-wrap: wrap;
    }
    .language li{
        width: calc(100% / 5);
    }
    .language div{
        width: 98%;
        margin: auto;
        padding-bottom: 5px
    }
    .language div p{
        padding: 10px;
        background: #dbf7ff;
        color: #003e92;
        border-radius: 3px;
        font-size: 1rem;
        font-weight: bold;
        text-align: center
    }

    .teacher{
        width: 1210px;
        margin-left: -5px;
        padding-bottom: 30px
    }
    .teacher ul{
        display: flex;
        flex-wrap: wrap;
    }
    .teacher li{
        width: calc(100% / 3);
    }
    .teacher p{
        padding: 5px
    }

    .feature{
        padding: 20px 0;
        line-height: 2
    }
    .feature span{
        color: #f00;
        font-weight: bold
    }
    .reasonable{
        margin-bottom: 20px;
        background: #dbf7ff;
        border-radius: 6px;
    }
    .reasonable p{
        padding: 20px;
        color: #003e92;
        font-size: 1.2rem;
        font-weight: bold;
        text-align: center
    }


    .price table{
        width: 100%;
        margin-bottom: 30px;
        border-top: dotted 1px #ccc;
        border-right: dotted 1px #ccc;
        font-weight: bold
    }
    .price th{
        padding: 15px 0;
        background: #003e92;
        color: #fff;
        border-bottom: dotted 1px #ccc;
        border-left: dotted 1px #ccc;
        text-align: center
    }
    .price td{
        padding: 15px 0;
        border-bottom: dotted 1px #ccc;
        border-left: dotted 1px #ccc;
        text-align: center;
        vertical-align: middle;
        line-height: 1.3
    }
    .price td.lesson{
        width: 50%;
        background: #fffff0;
    }
    .price span{
        color: #f00
    }
    .price img{
        width: 200px;
    }
    .price em{
        display: inherit;
        padding-bottom: 20px;
        color: #003e92;
        font-weight: bold
    }


    .price-list{
        font-size: 0.9rem;
        line-height: 2
    }
    .price-list span{
        color: #f00;
        font-weight: bold
    }
    .price-list em{
        display: inherit;
        color: #a89600;
        font-size: 1.2rem;
        font-weight: bold
    }

    .teaching{
        width: 1200px;
        padding: 20px 0
    }
    .teaching ul{
        display: flex;
        flex-wrap: wrap;
    }
    .teaching li.text{
        width: 880px;
    }
    .teaching li.photo{
        width: 320px
    }
    .teaching li.photo img{
        width: 300px;
        margin-left: auto
    }
    .teaching li p{
        font-size: 0.9rem;
        line-height: 3
    }


    .lecturer{
        width: 1200px;
        padding: 20px 0
    }
    .lecturer ul{
        display: flex;
        flex-wrap: wrap;
    }
    .lecturer li.text{
        width: 580px;
    }
    .lecturer li.photo{
        width: 620px
    }
    .lecturer li.photo img{
        width: 600px;
    }
    .lecturer li p{
        font-size: 0.9rem;
        line-height: 1.8
    }
    .lecturer span{
        display: inherit;
        color: #a89600;
        font-size: 1.2rem;
        font-weight: bold
    }
    .lecturer em{
        display: inherit;
        color: #003e92;
        font-size: 1.3rem;
        font-weight: bold
    }


    .cost{
        padding: 25px 0;
        line-height: 1.6
    }
    .cost em{
        display: inherit;
        color: #a89600;
        font-size: 1.5rem;
        font-weight: bold
    }
    .cost span{
        color: #f00;
        font-weight: bold
    }


    .support{
        line-height: 1.6
    }
    .support em{
        display: inherit;
        color: #a89600;
        font-size: 1.3rem;
        font-weight: bold
    }
    .support span{
        color: #f00;
        font-size: 1rem;
        font-weight: bold
    }


    .membership{
        line-height: 1.6
    }
    .membership em{
        display: inherit;
        color: #a89600;
        font-size: 1.3rem;
        font-weight: bold
    }
    .membership span{
        color: #f00;
        font-size: 1rem;
        font-weight: bold
    }



    .banner{
        background-image: url("../img/main.jpg") ;
        background-size: cover;
        height: 400px;
        margin-bottom: 25px;
    }
    .banner img{
        width: 980px;
        margin: auto
    }


    .title{
        margin-bottom: 10px
    }
    .title h2 {
        padding-bottom: 7px;
        border-bottom: solid 3px #cce4ff;
        position: relative;
        font-size: 1.2rem;
        font-weight: bold
    }

    .title h2:after {
        position: absolute;
        content: " ";
        display: block;
        border-bottom: solid 3px #003e92;
        bottom: -3px;
        width: 20%;
    }
    .title span{
        padding-left: 10px;
        color: #003e92;
        font-size: 1.5rem
    }


    .ranking{
        width: 1200px;
        margin-bottom: 25px;
        padding-top: 10px;
        border: dotted 1px #ccc;
    }
    .ranking ul{
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 1px #ccc;
        margin-bottom: 10px;
        padding-bottom: 10px
    }
    .ranking ul:last-child {
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 0px #ccc;
        margin-bottom: 0px;
        padding-bottom: 10px
    }
    .ranking li.image{
        width: 180px;
    }
    .ranking li.image img{
        width: 160px;
    }
    .ranking li.description{
        width: 990px;
        font-size: 0.9rem;
        line-height: 1.6
    }
    .ranking li.description h3{
        padding-bottom: 5px;
        color: #003e92;
        font-size: 1.2rem;
        font-weight: bold
    }
    .description span{
        color: #f00;
        font-weight: bold
    }


    .security{
        width: 1200px;
        margin-bottom: 25px;
        padding-top: 10px;
        background: #f5f5f5;
        border: dotted 1px #ccc;
    }
    .security ul{
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 1px #ccc;
        margin-bottom: 10px;
        padding-bottom: 10px
    }
    .security ul:last-child {
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 0px #ccc;
        margin-bottom: 0px;
        padding-bottom: 10px
    }
    .security li.image{
        width: 250px;
    }
    .security li.image img{
        width: 230px;
    }
    .security li.description{
        width: 920px;
        font-size: 0.9rem;
        line-height: 1.6
    }
    .security li.description h3{
        padding-bottom: 5px;
        color: #003e92;
        font-size: 1.2rem;
        font-weight: bold
    }
    .security li.description p{
        color: #a89600;
        font-size: 1.4rem;
        font-weight: bold
    }
    .security li.description a{
        color: #a89600
    }



    .search{

    }
    .search h2 {
        position: relative;
        padding: 15px;
        background: #003e92;
        color: #fff;
        font-size: 1.4rem;
        font-weight: bold
    }

    .search h2:after {
        position: absolute;
        content: '';
        top: 100%;
        left: 30px;
        border: 15px solid transparent;
        border-top: 15px solid #003e92;
        width: 0;
        height: 0;
    }
    .search ul{
        display: flex;
        flex-wrap: wrap;
        width: 638px;
        margin-top: 15px;
        margin-bottom: 15px;
        padding: 28px 20px 15px 20px;
        border: dotted 1px #ccc;
    }
    .search li{
        width: calc(100% / 2);
    }

    .search-list{
        width: 95%;
        margin: auto
    }
    .search-list h3{
        padding: 10px 0px;
        background: #f5fdff;
        border: 1px solid #003e92;
        color: #003e92;
        font-size: 1.0rem;
        font-weight: bold;
        text-align: center
    }
    .search-list ul{
        width: 100%;
        padding: 0px;
        border: dotted 0px #ccc;
    }
    .search-list li{
        width: calc(100% / 1);
        padding: 10px;
        font-size: 0.8rem;
    }
    .search-list li:nth-child(even){
        background: #eee
    }


    .contact{
        padding-bottom: 25px
    }

    .adjustment{
        padding-top: 30px
    }


    .inner{
        padding-top: 10px
    }
    .inner h3 {
        position: relative;
        padding: 15px;;
        background: #003e92;
        color: #fff100;
        font-size: 1.1rem;
        font-weight: bold
    }

    .inner h3:after {
        position: absolute;
        content: '';
        top: 100%;
        left: 30px;
        border: 15px solid transparent;
        border-top: 15px solid #003e92;
        width: 0;
        height: 0;
    }
    .inner i{
        font-size: 1.4rem
    }
    .inner .text{
        margin: 20px 0 15px;
        border: #ddd dotted 1px;
        background: #fffff3
    }
    .inner .text p{
        padding: 20px;
        font-size: 0.8rem;
        line-height: 2
    }
    .inner .text .image-sub{
        float: left;
        width: 150px;
        margin: 20px 15px 20px 20px;
    }
    .inner .text .image-sub img {
        width: 150px;
        height: 150px;
        object-fit: cover;け！ */
    }


    .overview{
        padding-bottom: 25px
    }




    .contact{
        padding-top: 10px
    }
    .contact h3 {
        position: relative;
        padding: 15px;;
        background: #003e92;
        color: #fff100;
        font-size: 1.1rem;
        font-weight: bold
    }
    .contact h3:after {
        position: absolute;
        content: '';
        top: 100%;
        left: 30px;
        border: 15px solid transparent;
        border-top: 15px solid #003e92;
        width: 0;
        height: 0;
    }
    .contact h4 {
        margin-bottom: 10px;
        padding: 15px;
        font-weight: bold;
        background: #fff3f3;
        border-left: solid 5px #cc0000;
    }
    .contact i{
        font-size: 1.4rem
    }
    .contact .text{
        margin: 20px 0 15px;
        border: #ddd dotted 1px;
        background: #fffff3
    }
    .contact .text p{
        padding: 20px;
        font-size: 0.8rem;
        line-height: 2
    }
    .contact .text-sub{
        padding: 10px 0 20px;
        font-size: 0.8rem;
        line-height: 2
    }
    .contact .text-sub span{
        color: #f00;
        font-weight: bold
    }
    .contact-tel{
        padding: 10px 0 20px 20px;
        color: #cc0000;
        font-size: 2rem;
        font-weight: bold
    }
    .contact-tel i{
        font-size: 2.2rem;
    }
    .contact-access{
        padding: 0 0 10px
    }
    .contact-inp{
        width: 90%;
        height: 20px;
        border: 1px solid #ddd
    }
    .contact-text{
        width: 90%;
        height: 200px;
        border: 1px solid #ddd
    }



    .flow{

    }
    .flow h4{
        color: #6cb4e4;
        text-align: center;
        padding: 15px;
        border: solid 1px #6cb4e4;
        font-size: 1.5rem;
        font-weight: bold;
        background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
        background: repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
    }
    .flow p{
        padding-bottom: 20px;
        font-size: 0.9rem;
        font-weight: bold;
        line-height: 1.8
    }
    .flow .arrow{
        margin-top: -15px;
        margin-bottom: -10px;
        color: #6cb4e4;
        text-align: center
    }
    .flow .arrow i{
        font-size: 4rem;
    }
    .table-01{
        padding-bottom: 30px;
    }
    .table-01 table{
        width: 100%;
        border-collapse: collapse
    }

    .table-01 table tr{
        border-bottom: solid 2px white;
    }

    .table-01 table tr:last-child{
        border-bottom: none;
    }

    .table-01 table th{
        position: relative;
        width: 40%;
        background-color: #003e92;
        color: white;
        font-size: 0.9rem;
        font-weight: bold;
        text-align: center;
        vertical-align: middle;
        padding: 15px 0;
    }

    .table-01 table th:after{
        display: block;
        content: "";
        width: 0px;
        height: 0px;
        position: absolute;
        top:calc(50% - 10px);
        right:-10px;
        border-left: 10px solid #003e92;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
    }

    .table-01 table td{
        text-align: left;
        width: 70%;
        background-color: #f5f5f5;
        padding: 10px 0 10px 30px;
        font-size: 0.9rem;
        font-weight: bold
    }
    .table-01 table span{
        color: #f00
    }



    .table-02{
        padding: 10px 0 25px
    }
    .table-02 table{
        width: 100%;
    }

    .table-02 table tr{
    }

    .table-02 table th{
        position: relative;
        background-color: #aaa;
        border-right: 1px solid #fff;
        border-bottom: 1px solid #fff;
        color: white;
        font-size: 0.8rem;
        font-weight: bold;
        text-align: center;
        vertical-align: middle;
        padding: 15px 0;
    }

    .table-02 table td{
        text-align: left;
        vertical-align: middle;
        background-color: #fff;
        padding: 10px;
        border-right: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
        font-size: 0.7rem;
        font-weight: bold;
        line-height: 2
    }
    .table-02 table span{
        color: #f00
    }
}





@media screen and (max-width: 1024px) {
    header {
        width: 100%;
        background: rgba(255, 255, 255, .6);
    }
    header ul{
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        margin: auto
    }
    header li.logo{
        width: 100%;
        padding: 0px;
    }
    header li.contact{
        width: 100%;
        padding: 5px;
        background: #e0f8ff;
        text-align: center
    }
    header li.contact p{
        padding: 0px;
        font-size: 0.7rem;
        font-weight: bold;
    }
    header li.contact span{
        color: #ff0000;
        font-size: 0.7rem
    }
    header li.contact .tel{
        width: 50%;
        margin: auto
    }
    header li.contact .mail{
        width: 50%;
        margin: auto
    }


    footer {
        width: 100%;
        background: rgba(255, 255, 255, .6);
        text-align: center;
    }

    footer p {
        margin-top: 20px;
        padding: 20px;
        color: #000;
        border-top: solid 1px #003e92;
        font-size: 0.8rem;
        font-weight: bold;
    }

    footer a {
        color: #000;
        text-decoration: none;
    }


    nav {
        width: 100%;
        background: #555;
    }

    nav ul {
        width: 100%;
        height: 92px;
        margin: auto;
        display: flex;
        flex-wrap: wrap;
        border-left: 1px #fff dotted;
    }

    nav li {
        width : calc(100% / 3) ;
        text-align: center;
        margin-left: -1px;
        border-right: 1px #fff dotted;
        border-bottom: 1px #fff dotted;
    }
    nav li a{
        display: block;
        height: 45px;
        color: #fff;
        font-size: 0.6rem;
        font-weight: bold;
        text-decoration: none;
    }
    nav li a:hover {
        background-color: transparent;
        transition: 0.8s;
        background: #fff;
        color: #000;
    }
    nav li p{
        padding: 8px 0px 5px 0px;
        font-size: 0.8rem;
        font-weight: bold
    }


    #main{
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        margin: auto;
    }
    #main .menu{
        width: 280px;
    }
    #main .contents{
        width: 100%;
        overflow-x: hidden
    }


    .breadcrumb {
        margin-left:0;
        background: rgba(170, 170, 170, .5);
        padding: 6px 10px 10px 10px;
        overflow: hidden;
    }
    .breadcrumb ul{
        width: 100%;
        margin: auto
    }
    .breadcrumb li{
        display:inline;
        list-style: none;
        font-size: 0.7rem;
        font-weight: bold;
    }

    .breadcrumb li:after{
        content: '>';
        padding: 0 3px;
    }

    .breadcrumb li:last-child:after{
        content: '';
    }

    .breadcrumb li a {
        text-decoration: none;
        color: #000;
    }

    .breadcrumb li a:hover {
        text-decoration: underline;
    }

    .language{
        padding-bottom: 20px
    }
    .language ul{
        display: flex;
        flex-wrap: wrap;
    }
    .language li{
        width: calc(100% / 4);
    }
    .language div{
        width: 98%;
        margin: auto;
        padding-bottom: 5px
    }
    .language div p{
        padding: 10px 0;
        background: #dbf7ff;
        color: #003e92;
        border-radius: 3px;
        font-size: 0.7rem;
        font-weight: bold;
        text-align: center
    }

    .teacher{
        width: 1210px;
        margin-left: -5px;
        padding-bottom: 30px
    }
    .teacher ul{
        display: flex;
        flex-wrap: wrap;
    }
    .teacher li{
        width: calc(100% / 3);
    }
    .teacher p{
        padding: 5px
    }

    .feature{
        width: 95%;
        margin: auto;
        font-size: 0.9rem;
        line-height: 1.2
    }
    .feature span{
        color: #f00;
        font-weight: bold
    }
    .reasonable{
        margin-bottom: 20px;
        background: #dbf7ff;
        border-radius: 6px;
    }
    .reasonable p{
        padding: 10px;
        color: #003e92;
        font-size: 1.0rem;
        font-weight: bold;
        text-align: center
    }


    .price table{
        width: 100%;
        margin-bottom: 15px;
        border-top: dotted 1px #ccc;
        border-right: dotted 1px #ccc;
        font-size: 0.8rem;
        font-weight: bold
    }
    .price th{
        padding: 10px 0;
        background: #003e92;
        color: #fff;
        border-bottom: dotted 1px #ccc;
        border-left: dotted 1px #ccc;
        text-align: center
    }
    .price td{
        padding: 10px 0;
        border-bottom: dotted 1px #ccc;
        border-left: dotted 1px #ccc;
        text-align: center;
        vertical-align: middle;
        line-height: 1.3
    }
    .price td.lesson{
        width: 50%;
        background: #fffff0;
    }
    .price span{
        color: #f00
    }
    .price img{
        width: 200px;
    }
    .price em{
        display: inherit;
        padding-bottom: 20px;
        color: #003e92;
        font-weight: bold
    }


    .price-list{
        width: 95%;
        margin: auto;
        font-size: 0.8rem;
        line-height: 1.4
    }
    .price-list span{
        color: #f00;
        font-weight: bold
    }
    .price-list em{
        display: inherit;
        color: #a89600;
        font-size: 1.1rem;
        font-weight: bold
    }

    .teaching{
        width: 100%;
        padding: 20px 0
    }
    .teaching ul{
        display: flex;
        flex-wrap: wrap;
    }
    .teaching li.text{
        width: 100%;
    }
    .teaching li.photo{
        width: 100%;
        padding-top: 10px
    }
    .teaching li.photo img{
        width: 100%;
        margin-left: auto
    }
    .teaching li p{
        font-size: 0.8rem;
        line-height: 1.5
    }


    .lecturer{
        width: 100%;
        padding-bottom: 20px
    }
    .lecturer ul{
        display: flex;
        flex-wrap: wrap;
    }
    .lecturer li.text{
        width: 95%;
        margin: auto
    }
    .lecturer li.photo{
        width: 100%;
    }
    .lecturer li.photo img{
        width: 100%;
    }
    .lecturer li p{
        font-size: 0.8rem;
        line-height: 1.4
    }
    .lecturer span{
        display: inherit;
        color: #a89600;
        font-size: 1.1rem;
        font-weight: bold
    }
    .lecturer em{
        display: inherit;
        color: #003e92;
        font-size: 1.3rem;
        font-weight: bold
    }


    .cost{
        width: 95%;
        margin: auto;
        padding: 15px 0;
        font-size: 0.9rem;
        line-height: 1.4
    }
    .cost em{
        display: inherit;
        color: #a89600;
        font-size: 1.2rem;
        font-weight: bold
    }
    .cost span{
        color: #f00;
        font-weight: bold
    }


    .support{
        width: 95%;
        margin: auto;
        font-size: 0.9rem;
        line-height: 1.4
    }
    .support em{
        display: inherit;
        color: #a89600;
        font-size: 1.1rem;
        font-weight: bold
    }
    .support span{
        color: #f00;
        font-size: 1rem;
        font-weight: bold
    }


    .membership{
        width: 95%;
        margin: auto;
        font-size: 0.9rem;
        line-height: 1.4
    }
    .membership em{
        display: inherit;
        color: #a89600;
        font-size: 1.2rem;
        font-weight: bold
    }
    .membership span{
        color: #f00;
        font-size: 1rem;
        font-weight: bold
    }


    .banner{
        background-image: url("../img/main.jpg");
        background-size: cover;
        background-position: bottom center;
        background-repeat: no-repeat;
        margin-bottom: 25px;
    }
    .banner img{
        width: 100%;
        margin: auto
    }

    .title{
        margin-bottom: 10px
    }
    .title h2 {
        padding-bottom: 7px;
        border-bottom: solid 3px #cce4ff;
        position: relative;
        font-size: 1.2rem;
        font-weight: bold
    }

    .title h2:after {
        position: absolute;
        content: " ";
        display: block;
        border-bottom: solid 3px #003e92;
        bottom: -3px;
        width: 20%;
    }
    .title span{
        padding-left: 10px;
        color: #003e92;
        font-size: 1.5rem
    }


    .ranking{
        width: auto;
        padding-top: 10px;
        border: dotted 1px #ccc;
    }
    .ranking ul{
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 1px #ccc;
        margin-bottom: 10px;
        padding-bottom: 10px
    }
    .ranking ul:last-child {
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 0px #ccc;
        margin-bottom: 0px;
        padding-bottom: 10px
    }
    .ranking li.image{
        width: 180px;
        margin: auto
    }
    .ranking li.image img{
        width: 160px;
    }
    .ranking li.description{
        width: 100%;
        font-size: 0.8rem;
        line-height: 1.4
    }
    .ranking li.description h3{
        padding: 5px 0;
        color: #003e92;
        font-size: 1.1rem;
        font-weight: bold
    }
    .description span{
        color: #f00;
        font-weight: bold
    }


    .security{
        width: auto;
        margin-bottom: 25px;
        padding-top: 10px;
        background: #f5f5f5;
        border: dotted 1px #ccc;
    }
    .security ul{
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 1px #ccc;
        margin-bottom: 10px;
        padding-bottom: 10px
    }
    .security ul:last-child {
        display: flex;
        flex-wrap: wrap;
        padding: 0px 15px;
        border-bottom: dotted 0px #ccc;
        margin-bottom: 0px;
        padding-bottom: 10px
    }
    .security li.image{
        width: 220px;
        margin: auto;
        padding-bottom: 10px
    }
    .security li.image img{
        width: 220px;
    }
    .security li.description{
        width: 100%;
        font-size: 0.8rem;
        line-height: 1.4
    }
    .security li.description h3{
        padding-bottom: 5px;
        color: #003e92;
        font-size: 1.1rem;
        font-weight: bold
    }
    .security li.description p{
        color: #a89600;
        font-size: 1.4rem;
        font-weight: bold
    }
    .security li.description a{
        color: #a89600
    }



    .search{

    }
    .search h2 {
        position: relative;
        padding: 10px;
        background: #003e92;
        color: #fff;
        font-size: 1.1rem;
        font-weight: bold
    }

    .search h2:after {
        position: absolute;
        content: '';
        top: 100%;
        left: 30px;
        border: 15px solid transparent;
        border-top: 15px solid #003e92;
        width: 0;
        height: 0;
    }
    .search ul{
        display: flex;
        flex-wrap: wrap;
        width: 638px;
        margin-top: 15px;
        margin-bottom: 15px;
        padding: 28px 20px 15px 20px;
        border: dotted 1px #ccc;
    }
    .search li{
        width: calc(100% / 2);
    }

    .search-list{
        width: 95%;
        margin: auto
    }
    .search-list h3{
        padding: 10px 0px;
        background: #f5fdff;
        border: 1px solid #003e92;
        color: #003e92;
        font-size: 1.0rem;
        font-weight: bold;
        text-align: center
    }
    .search-list ul{
        width: 100%;
        padding: 0px;
        border: dotted 0px #ccc;
    }
    .search-list li{
        width: calc(100% / 1);
        padding: 10px;
        font-size: 0.8rem;
    }
    .search-list li:nth-child(even){
        background: #eee
    }


    .contact{
        padding-bottom: 25px
    }

    .adjustment{
        padding-top: 30px
    }


    .inner{
        padding-top: 10px
    }
    .inner h3 {
        position: relative;
        padding: 15px;;
        background: #003e92;
        color: #fff100;
        font-size: 1.1rem;
        font-weight: bold
    }

    .inner h3:after {
        position: absolute;
        content: '';
        top: 100%;
        left: 30px;
        border: 15px solid transparent;
        border-top: 15px solid #003e92;
        width: 0;
        height: 0;
    }
    .inner i{
        font-size: 1.4rem
    }
    .inner .text{
        margin: 20px 0 15px;
        border: #ddd dotted 1px;
        background: #fffff3
    }
    .inner .text p{
        padding: 20px;
        font-size: 0.8rem;
        line-height: 2
    }
    .inner .text .image-sub{
        float: left;
        width: 150px;
        margin: 20px 15px 20px 20px;
    }
    .inner .text .image-sub img {
        width: 150px;
        height: 150px;
        object-fit: cover;け！ */
    }


    .overview{
        padding-bottom: 25px
    }




    .contact{
        padding-top: 10px
    }
    .contact h3 {
        position: relative;
        padding: 15px;;
        background: #003e92;
        color: #fff100;
        font-size: 1.1rem;
        font-weight: bold
    }
    .contact h3:after {
        position: absolute;
        content: '';
        top: 100%;
        left: 30px;
        border: 15px solid transparent;
        border-top: 15px solid #003e92;
        width: 0;
        height: 0;
    }
    .contact h4 {
        margin-bottom: 10px;
        padding: 15px;
        font-weight: bold;
        background: #fff3f3;
        border-left: solid 5px #cc0000;
    }
    .contact i{
        font-size: 1.4rem
    }
    .contact .text{
        margin: 20px 0 15px;
        border: #ddd dotted 1px;
        background: #fffff3
    }
    .contact .text p{
        padding: 20px;
        font-size: 0.8rem;
        line-height: 2
    }
    .contact .text-sub{
        padding: 10px 0 20px;
        font-size: 0.8rem;
        line-height: 2
    }
    .contact .text-sub span{
        color: #f00;
        font-weight: bold
    }
    .contact-tel{
        padding: 10px 0 20px 20px;
        color: #cc0000;
        font-size: 2rem;
        font-weight: bold
    }
    .contact-tel i{
        font-size: 2.2rem;
    }
    .contact-access{
        padding: 0 0 10px
    }
    .contact-inp{
        width: 90%;
        height: 20px;
        border: 1px solid #ddd
    }
    .contact-text{
        width: 90%;
        height: 200px;
        border: 1px solid #ddd
    }



    .flow{

    }
    .flow h4{
        color: #6cb4e4;
        text-align: center;
        padding: 15px;
        border: solid 1px #6cb4e4;
        font-size: 1.5rem;
        font-weight: bold;
        background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
        background: repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
    }
    .flow p{
        padding-bottom: 20px;
        font-size: 0.9rem;
        font-weight: bold;
        line-height: 1.8
    }
    .flow .arrow{
        margin-top: -15px;
        margin-bottom: -10px;
        color: #6cb4e4;
        text-align: center
    }
    .flow .arrow i{
        font-size: 4rem;
    }
    .table-01{
        padding-bottom: 30px;
    }
    .table-01 table{
        width: 100%;
        border-collapse: collapse
    }

    .table-01 table tr{
        border-bottom: solid 2px white;
    }

    .table-01 table tr:last-child{
        border-bottom: none;
    }

    .table-01 table th{
        position: relative;
        width: 40%;
        background-color: #003e92;
        color: white;
        font-size: 0.9rem;
        font-weight: bold;
        text-align: center;
        vertical-align: middle;
        padding: 15px 0;
    }

    .table-01 table th:after{
        display: block;
        content: "";
        width: 0px;
        height: 0px;
        position: absolute;
        top:calc(50% - 10px);
        right:-10px;
        border-left: 10px solid #003e92;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
    }

    .table-01 table td{
        text-align: left;
        width: 70%;
        background-color: #f5f5f5;
        padding: 10px 0 10px 30px;
        font-size: 0.9rem;
        font-weight: bold
    }
    .table-01 table span{
        color: #f00
    }



    .table-02{
        padding: 10px 0 25px
    }
    .table-02 table{
        width: 100%;
    }

    .table-02 table tr{
    }

    .table-02 table th{
        position: relative;
        background-color: #aaa;
        border-right: 1px solid #fff;
        border-bottom: 1px solid #fff;
        color: white;
        font-size: 0.8rem;
        font-weight: bold;
        text-align: center;
        vertical-align: middle;
        padding: 15px 0;
    }

    .table-02 table td{
        text-align: left;
        vertical-align: middle;
        background-color: #fff;
        padding: 10px;
        border-right: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
        font-size: 0.7rem;
        font-weight: bold;
        line-height: 2
    }
    .table-02 table span{
        color: #f00
    }

}


.form-sent{
    width: 320px;
    margin: auto;
    padding-top: 30px
}
input.sysNextSubmit {
    width: 150px;
    border-radius: 0;
    background: -moz-linear-gradient(top, #FFF 0%, #EEE);
    background: -webkit-gradient(linear, left top, left bottom, from(#FFF), to(#EEE));
    border: 1px solid #DDD;
    color: #111;
    font-size: 1.0rem;
    font-weight: bold;
    padding: 8px 0px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}
input.sysNextSubmit:hover {
    background: -moz-linear-gradient(top, #EFEFEF 0%, #EEE);
    background: -webkit-gradient(linear, left top, left bottom, from(#EFEFEF), to(#EEE));
}


.cp_qa *, .cp_qa *:after, .cp_qa *:before {
    font-family: 'FontAwesome', sans-serif;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.cp_qa .cp_actab {
    position: relative;
    overflow: hidden;
    width: 98%;
    margin: 0 0 1em 0;
    color: #ffffff;
}
.cp_qa .cp_actab input {
    position: absolute;
    opacity: 0;
}
/* 質問 */
.cp_qa .cp_actab label {
    line-height: 1.6em;
    position: relative;
    display: block;
    margin: 0 0.5em 0.5em 2em;
    padding: 1em 0 2em 0;
    font-weight: bold;
    cursor: pointer;
    border-radius: 0.3em;
    background: #f28890;
    box-shadow: 0 1px 2px 0 rgba(0,0,0,0.3);
}
.cp_qa .cp_actab label span {
    display: block;
    padding: 0 2em 1em 2em;
    border-bottom: 1px dotted #ffbbc0;
}
/* --?アイコン */
.cp_qa .cp_actab label::before {
    font-size: 2em;
    position: absolute;
    z-index: 99;
    top: 0.5em;
    left: -1em;
    padding: 0 0.5em;
    content: '\f128';
    border: 3px solid #ffffff;
    border-radius: 50%;
    background: #cc0000;
    display: inline-block;
    width: 1.8em;
    height: 1.8em;
    line-height: 1.6em;
}
/* --▼アイコン */
.cp_qa .cp_actab label::after {
    font-size: 1em;
    font-weight: normal;
    line-height: 1em;
    position: absolute;
    right: 0;
    bottom: 1em;
    content: '▼';
    display: inline-block;
    width: 100%;
    height: 1em;
    padding: 0.5em;
    text-align: right;
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
}
/* 答え */
.cp_qa .cp_actab .cp_actab-content {
    position: relative;
    overflow: hidden;
    max-height: 0;
    margin: 0 0 0.5em 0;
    padding: 0 0 0 5em;
    -webkit-transition: max-height 0.5s ease;
    transition: max-height 0.5s ease;
    color: #ffffff;
}
/* --!アイコン */
.cp_qa .cp_actab .cp_actab-content::before {
    font-size: 1.5em;
    position: absolute;
    z-index: 99;
    top: calc(50% - 0.9em);
    left: 2.5em;
    padding: 0 0.6em;
    content: '\f12a';
    color: #ffffff;
    border: 3px solid #ffffff;
    border-radius: 50%;
    background: #003e92;
    width: 1.8em;
    height: 1.8em;
    line-height: 1.8em;
}
.cp_qa .cp_actab .cp_actab-content p {
    margin: 0.5em 0.5em 0.5em 0;
    padding: 1em 1em 1em 3em;
    border-radius: 0.3em;
    background: #dbf7ff;
    color: #003e92;
    font-size: 0.9rem;
    line-height: 1.8;
    box-shadow: 0 1px 2px 0 rgba(0,0,0,0.3);
}
/* 質問を開いた時の仕様 */
/* --答えの高さ */
.cp_qa .cp_actab input:checked ~ .cp_actab-content {
    max-height: 40em;
}
/* 質問をクリックした時の▼アイコンの動き */
.cp_qa .cp_actab input[type=checkbox]:checked + label::after {
    bottom: 0em;
    -webkit-transform: rotateX(180deg);
    transform: rotateX(180deg);
}


/*===============================

ページトップ

================================*/

#page_top{
    width: 100px;
    height: 70px;
    position: fixed;
    right: 20px;
    bottom: 0px;
    background: #000;
    opacity: 0.8;
    line-height: 2;
    z-index: 100000
}
#page_top a{
    position: relative;
    display: block;
    width: 100px;
    height: 60px;
    text-decoration: none;
}
#page_top a::before{
    font-family: FontAwesome;
    font-weight: 900;
    content: "\f077";
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -45px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}
#page_top a::after{
    content: 'PAGE TOP';
    font-size: 13px;
    color: #fff;
    position: absolute;
    top: 30px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

@media screen and ( max-width:479px ){
    #page_top{
        width: 100px;
        height: 50px;
        position: fixed;
        right: 0px;
        bottom: 0px;
        background: #000;
        opacity: 0.8;
    }
    #page_top a{
        position: relative;
        display: block;
        width: 100px;
        height: 40px;
        text-decoration: none;
    }
    #page_top a::before{
        font-family: FontAwesome;
        font-weight: 900;
        content: "\f077";
        font-size: 25px;
        color: #fff;
        position: absolute;
        width: 25px;
        height: 25px;
        top: -25px;
        bottom: 0;
        right: 0;
        left: 0;
        margin: auto;
        text-align: center;
    }
    #page_top a::after{
        content: 'PAGE TOP';
        font-size: 10px;
        color: #fff;
        position: absolute;
        top: 30px;
        bottom: 0;
        right: 0;
        left: 0;
        margin: auto;
        text-align: center;
    }

}