html {
    font-size: 62.5%;
}



* {
    max-height: 100%;
    margin: 0px;
    padding: 0px;
    word-break: normal !important;
    word-wrap: break-word;
    line-break:normal;
    border: 0;
    outline: 0;
    box-sizing: border-box;
    vertical-align:top;
    }

body {
margin: 0;
overflow-x: hidden;
font-family: "Zen Maru Gothic", serif;
font-weight: 400;
font-size: 1.6rem;
letter-spacing: 0;
color: #595757;
position: relative;
}

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video, button {
margin: 0;
padding: 0;
border: 0;
outline: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main, small {
display: block;
}

h1, h2, h3, h4, h5, h6 {
font-size: 100%;
font-weight: unset;
line-height: 1.5;
letter-spacing: 0.05rem;
}


table, input, textarea, select, option {
}

ol, ul {
list-style: none;
}

blockquote, q {
quotes: none;
}

:focus {
outline: 0;
}

ins {
text-decoration: none;
}

del {
text-decoration: line-through;
}

img {
display: block;
vertical-align: middle;
max-width: 100%;
}

a {
text-decoration: none;
display: block;
color: inherit;
}

a:hover {
    opacity:0.7;
    transition: all 1s;
}

p {
}

.clearfix:after {
content:" ";
display:block;
clear:both;
}

i {
padding-right: 5px;
}







header {
    width: 100%;
    padding-top: 20px;
}
h1 img{
    width: 100%;
}
main {
    line-height: 1.6;
}
h2 {
}

.con375 {
    max-width: 375px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 10px;
    padding-right: 10px;
}
.txt-l {
    font-size: 24px;
    text-align: center;
    margin: 0 auto;
    padding: 30px 0;
}
.txt-m {
    font-size: 20px;
    text-align: center;
    margin: 0 auto;
    padding: 30px 0;
}
.txt-s {
    display: block;
    font-size: 11px;
    padding: 3px 0;
}
.txt-s2 {
    display: inline-block;
    font-size: 11px;
    padding: 3px 0;
}
.txt-s3 {
    display: inline-block;
    font-size: 12px;
    padding: 0 0 3px;
}
.txt-center {
    text-align: center;
}
.txt-color01 {
    color: #e06a7f;
}
.txt-color02 {
    color: #5ac8c7;
}
.txt-color03 {
    color: #ffa559;
}
.txt-color04 {
    color: #7e8fdc;
}
.txt-color05 {
    color: #fffe9e;
}
.txt-bold {
    font-weight: 700;
}
.bg01 {
    display:inline-block;
    font-weight: 700;
    background: #fffd51;
}
.letter-s {
    letter-spacing: -1px;
}


.mt30 {
    margin-top: 30px;
}
.mt15 {
    margin-top: 15px;
}
.mt0 {
    margin-top: 0;
}

.mb30 {
    margin-bottom: 30px;
}
.mb15 {
    margin-bottom: 15px;
}
.mb0 {
    margin-bottom: 0;
}

.pt30 {
    padding-top: 30px;
}
.pt15 {
    padding-top: 15px;
}
.pt0 {
    padding-top: 0;
}

.pb30 {
    padding-bottom: 30px;
}
.pb15 {
    padding-bottom: 15px;
}
.pb0 {
    padding-bottom: 0px;
}








.mv,
.merit,
.soudan,
.yobou,
.step,
.oshiete,
.about01,
.about02,
.about03,
.contact {
    padding-bottom: 50px;
}




.deco01-wrap {
    max-width: 375px;
    margin-left: auto;
    margin-right: auto;
}

.deco01 {
    width: calc(100% - 10px);
    color: #fff;
    font-size: 20px;
    padding: 15px 2px 15px 60px;
    margin-left: 10px;
    margin-bottom: 30px;
    background: #5ac8c7;
    border-top-left-radius: 100vh;
    border-bottom-left-radius: 100vh;
    position: relative;
}
.deco01.deco01-p {
    background: #f3a8b4;
}
.deco01::before {
    content: '';
    position: absolute;
    width: 26.5px;
    height: 33px;
    top: 12px;
    left: 15px;
    background: url(../img/icon-logo.png);
    background-size: contain;
}




.mv {
    margin-top: 20px;
    position: relative;
}
.mv-bg {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    object-fit: cover;
}
.stc-wrap {
    position: absolute;
    content: '';
    top: 7vw;
    left:50%;
    width: 100%;
    transform: translateX(-50%);
    -webkit- transform: translateX(-50%);
}
.stc-wrap .stc01 {
    margin: 0 auto;
    width: fit-content;
    font-size: calc(100vw * 20 / 375);
    color: #00b1af;
    font-weight: 700;
    padding-bottom: 5vw;
    position: relative;
}
.stc-wrap .stc01::before {
    content: '';
    position: absolute;
    width: calc(100vw * 14 / 375);
    height: calc(100vw * 17 / 375);
    top: -1.1vw;
    left: -5vw;
    background: url(../img/pika.png);
    background-size: contain;
}
.stc-wrap .stc01::after{
    content: '';
    position: absolute;
    width: calc(100vw * 250 / 375);
    height: calc(100vw * 3.5 / 375);
    bottom: 3.5vw;
    left: 50%;
    background: url(../img/mv-line.png);
    background-size: contain;
    transform: translateX(-50%);
    -webkit- transform: translateX(-50%);
}
.stc-wrap .stc02 {
    margin: 0 auto;
    width: fit-content;
    font-size: calc(100vw * 45 / 375);
    font-weight: 700;
    text-align: center;
    line-height: 1.2;
    letter-spacing: calc(100vw * 5 / 375);
    padding: 0 0 4vw;
    position: relative;
}
.stc-wrap .stc02::after{
    content: '';
    position: absolute;
    width: calc(100vw * 32 / 375);
    height: calc(100vw * 32 / 375);
    bottom: 2vw;
    right: -14vw;
    background: url(../img/kira.png);
    background-size: contain;
}
.stc-wrap .stc03 {
    margin: 0 auto;
    width: fit-content;
    font-size: calc(100vw * 18 / 375);
    font-weight: 700;
    text-align: center;
    line-height: 1.2;
}



/*

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

    .stc-wrap {
        top: 70px;
    }

}
*/


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

    .stc-wrap {
        top: 50px;
    }
    .stc-wrap .stc01 {
        font-size: 26.5px;
        padding-bottom: 25px;
    }
    .stc-wrap .stc01::before {
        content: '';
        position: absolute;
        width: 19px;
        height: 22.5px;
        top: -7px;
        left: -25px;
        background: url(../img/pika.png);
        background-size: contain;
    }
    .stc-wrap .stc01::after{
        content: '';
        position: absolute;
        width: 333px;
        height: 4.5px;
        bottom: 18px;
        left: 50%;
        background: url(../img/mv-line.png);
        background-size: contain;
    }
    .stc-wrap .stc02 {
        font-size: 60px;
        padding: 0 0 20px;
        letter-spacing: 7px;
    }
    .stc-wrap .stc02::after{
        content: '';
        position: absolute;
        width: 42px;
        height: 42px;
        bottom: 10px;
        right: -70px;
        background: url(../img/kira.png);
        background-size: contain;
    }
    .stc-wrap .stc03 {
        font-size: 24px;
    }
    



}






.merit {
    background: url(../img/merit-bg.jpg);
    background-size: cover;
    background-position: top;
}
h3.check {
    font-weight: 700;
    padding-left: 30px;
    margin-bottom: 15px;
    position: relative;
}
h3.check::before {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    top: 2px;
    left: 0;
    background: url(../img/check.png);
    background-size: contain;
}
h3.check + p {
    margin-bottom: 30px;
}




.yobou {
    background: url(../img/yobou-bg.jpg);
    background-size: cover;
    background-position: top;
}
.deco01.letter-s {
    padding-left: 18px;
    padding-right: 4px;
}
.deco01.letter-s::before {
    display: none;
}


.step-wrap {
    display: flex;
    flex-wrap: wrap;
}
.step-wrap li {
    background: #f9f9ee;
    font-weight: 700;
    width: 48.5%;
    padding: 10px 5px;
    margin-bottom: 12px;
    border-radius: 5px;
    line-height: 1.2;
}
.step-wrap li:nth-child(2n+1) {
    margin-right: 3%;
}
.step-wrap li img {
    margin: 0 auto;
}
.flex01 {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}
/***  pが2行以上になる場合は.flex02を使う  ***/
.flex02 {
    display: flex;
    margin-bottom: 10px;
}
.number01 {
    color: #fff;
    background: url(../img/number-bg01.png) no-repeat;
    width: 32px;
    height: 32px;
    background-size: contain;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 4px;
}
.number02 {
    color: #fff;
    background: url(../img/number-bg02.png) no-repeat;
    width: 32px;
    height: 32px;
    background-size: contain;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 4px;
}
.number03 {
    color: #fff;
    background: url(../img/number-bg03.png) no-repeat;
    width: 32px;
    height: 32px;
    background-size: contain;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 4px;
}
.number01 + p,
.number02 + p {
    width: calc(100% - 36px);
}
.step01 {
    padding-bottom: 30px;
}
.step02 {
    background: #f9f9ee;
    padding-bottom: 50px;
}
.step02 .step-wrap li {
    background: #fff;
}
.step02 .detail {
    font-size: 20px;
    display: flex;
    align-items: center;
    padding: 0 20px;
    border: 2.5px solid #ffa559;
    position: relative;
}
.step02 .detail::before {
    content: '';
    position: absolute;
    width: calc(100% - 24px);
    height: 10px;
    top: -5px;
    left: 12px;
    background: #f9f9ee;
}
.step02 .detail::after {
    content: '';
    position: absolute;
    width: calc(100% - 24px);
    height: 10px;
    bottom: -5px;
    left: 12px;
    background: #f9f9ee;
}
.step02 .detail .in01 {
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 76px;
    height: 76px;
    margin-right: 20px;
    background: url(../img/step-img01.png) no-repeat;
    background-size: contain;
}
.step-wrap.care li {
    padding: 0;
}
.step-wrap.care li:nth-child(1) .in01 {
    background: #5ac8c7;
}
.step-wrap.care li:nth-child(2) .in01 {
    background: #7e8fdc;
}
.step-wrap.care .in01 {
    color: #fff;
    text-align: center;
    padding: 10px ;
    border-radius: 5px 5px 0px 0px;
}
.step-wrap.care .in02 {
    padding: 10px;
    font-weight: 400;
    line-height: 1.6;
    border-radius: 0px 0px 5px 5px;
}



.oshiete {
    background: url(../img/oshiete-bg.jpg);
    background-size: cover;
    background-position: top;
}
.deco01-oshiete01,
.deco01-oshiete02,
.deco01-oshiete03 {
    padding-left: 55px;
    margin-bottom: 15px;
    letter-spacing: -1.5px;
    position: relative;
}
.deco01-oshiete01::before,
.deco01-oshiete02::before ,
.deco01-oshiete03::before{
    content: '01';
    position: absolute;
    color: #5ac8c7;
    font-weight: 700;
    letter-spacing: 1px;
    width: 40px;
    height: 40px;
    top: 50%;
    left: 8px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    transform: translateY(-50%);
    -webkit- transform: translateY(-50%);
}
.deco01-oshiete02::before {
    content: '02';
}
.deco01-oshiete03::before {
    content: '03';
}




.about01 {
    background: #f3a8b4;
    color: #fff;
}
.about01 .about01_txt {
margin-top: 30px;
}

.about02 {
    background: url(../img/about02-bg.jpg);
    background-size: cover;
    background-position: top;
}
.deco02 {
    font-size: 20px;
    letter-spacing: -1px;
    text-align: center;
    border-radius: 100vh;
    background: #fff;
    padding: 10px 5px;
}
.deco02.language,
.deco02.houmon {
    text-align: left;
    padding-left: 75px;
    margin-bottom: 10px;
    font-weight: 700;
    position: relative;
}
.deco02.language::before{
    content: '';
    position: absolute;
    width: 33px;
    height: 33px;
    top: 50%;
    left: 25px;
    background: url(../img/icon-language.png);
    background-size: contain;
    transform: translateY(-50%);
    -webkit- transform: translateY(-50%);
}
.deco02.houmon::before {
    content: '';
    position: absolute;
    width: 30px;
    height: 30px;
    top: 50%;
    left: 27px;
    background: url(../img/icon-houmon.png);
    background-size: contain;
    transform: translateY(-50%);
    -webkit- transform: translateY(-50%);
}


.schedule {
    padding-bottom: 20px;
    border-bottom: dotted 2px #000;
}

.mail {
    width: 100%;
    font-size: 26.5px;
    letter-spacing: 1.5px;
    color: #fff;
    background: #f3a8b4;
    border-radius: 10px;
    border-bottom: 5px solid #e28292;
    padding: 25px 0 25px 100px;
    position: relative;
}
.mail::before {
    content: '';
    position: absolute;
    width: 39px;
    height: 27px;
    top: 50%;
    left: 40px;
    background: url(../img/icon-mail.png);
    background-size: contain;
    transform: translateY(-50%);
    -webkit- transform: translateY(-50%);
}

.contact_btn {
margin-bottom: 20px;
text-align: center;
}
.contact_btn a {
display: inline-block;
font-weight: bold;
color: #e06a7f;
}


.sns {
    display: flex;
    align-items: center;
    justify-content: center;
}
.sns a:not(:first-child) {
    margin-left: 16px;
}
.sns a img {
    width: 42px;
    height: 42px;
    object-fit: contain;
}





footer {
    text-align: center;
    color: #fff;
    padding: 8px;
    background: #626573;
}







