@charset "UTF-8";
/* 共通 */
p , h1 , h2 , h3{
	line-height: 1.5;
}
p{
	margin: 0;
}
img{
	width: 100%;
	vertical-align: top;
}
a {
    color: #478fde;
}
a:hover {
    opacity: 0.7;
}

html{
    font-family:sans-serif;
    -ms-text-size-adjust:100%;
    -webkit-text-size-adjust:100%
}
body{
    margin:0;
    word-wrap:break-word;
    max-width: 620px;
    width: 100%;
    margin: 0 auto 20px;
}
/*@media screen and (min-width: 920px) {
    body {
        width: 620px;
        margin: 0 auto;
    }
}*/
article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{
    display:block
}
audio,canvas,progress,video{
    display:inline-block;vertical-align:baseline
}
audio:not([controls]){
    display:none;
    height:0
}
[hidden],template{
    display:none
}
a{
    background-color:transparent
}
a:active,a:hover{
    outline:0
}
abbr[title]{
    border-bottom:1px dotted
}
b,strong{
    font-weight:700
}
dfn{
    font-style:italic
}
h1{
    font-size:2em;
    margin:.67em 0
}
mark{
    background:#ff0;
    color:#000
}
small{
    font-size:80%
}
sub,sup{
    font-size:75%;
    line-height:0;
    position:relative;
    vertical-align:baseline
}
sup{
    top:-.5em
}
sub{
    bottom:-.25em
}
img{
    border:0
}
svg:not(:root){
    overflow:hidden
}
figure{
    margin:0
}
hr{
    -moz-box-sizing:content-box;
    box-sizing:content-box;
    height:0
}
pre{
    overflow:auto
}
code,kbd,pre,samp{
    font-family:monospace,monospace;
    font-size:1em
}
button,input,optgroup,select,textarea{
    color:inherit;
    font:inherit;
    margin:0
}
button{
    overflow:visible
}
button,select{
    text-transform:none
}
body{
    font-size:17px;
    background-color:#F4F4F4;
    /*user-select:none;
    -webkit-user-select:none;
    -ms-user-select:none;
    -moz-user-select:none;
    -khtml-user-select:none;
    -webkit-user-drag:none;
    -khtml-user-drag:none;*/
}

.article-body {
    font-family: Hiragino Sans, Arial, sans-serif !important;
    color: #000000 !important;
    padding: 15px !important;
}
.article-body p {
    font-size: 17px;
    font-weight: normal;
    line-height: 1.8 !important;
}
body .article-header-wrapper img{
    max-width:100%
}
body .article-body{
    font-size:17px;
    line-height:1.8;
    background-color:#ffffff;
    text-align: center;
}
body .article-body span,body .article-body p,body .article-body div,body .article-body h1,body .article-body h2,body .article-body h3,body .article-body h4,body .article-body h5,body .article-body h6{
    max-width:100%
}

/*装飾*/
.sans{
    font-family: sans-serif !important;
}
.co_re{
    color: #ff1b1b !important;
}
.co_br{
    color: #0066cc !important;
}
.co_p{
    color: #ff6387;
}
.co_g{
    color: #888888;
}
.co_w{
    color: #fff;
}

.line1 {
    background-color: #ffff00;
}
.line2{
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #ffff00 0%) repeat scroll 0 0;
}
.line3 {
    background: -webkit-linear-gradient(left, #ffff00 50%, transparent 50%) 100% 0% / 200% 70% no-repeat;
    background-position: bottom 0 right 100% !important;
}
.line4 {
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #ffffcc 0%) repeat scroll 0 0;
}
.line_b {
background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #cce0f5 0%) repeat scroll 0 0;
}
/*余白*/
/*.mt1{
	margin-top: 1%;
}*/
.mt2{
	margin-top: 2% !important;
}
/*.mt3{
	margin-top: 3%;
}*/
.mt5{
	margin-top: 5% !important;
}
.mt7{
	margin-top: 7% !important;
}
.mt10{
	margin-top: 10% !important;
}
.mt15{
	margin-top: 15% !important;
}
.mt20{
	margin-top: 20% !important;
}
.mt40{
	margin-top: 40% !important;
}
.mb5{
	margin-bottom: 5% !important;
}
/*.mb2{
	margin-bottom: 2%;
}*/
.mt-2{
	margin-top: -2% !important;
}

/*揃え*/
.teC{
    text-align: center !important;
}
.teL{
    text-align: left !important;
}
.teR{
    text-align: right !important;
}

#content {
	max-width: 620px;
	margin: 0 auto;
}
#content02{
    text-align: left;
    margin: 0 auto;
	padding: 2%;
	background-color: #fff;
}

.tyu{
    font-size: 10px !important;
    color: #bbbbbb;
    font-weight: normal;
}
.lis{
    border: 3px solid #80c7ff;
    border-radius: 10px;
    padding: 2%;
    margin: 2% 0;
    line-height: 2;
    font-weight: bold;
}
/*.img-area{
    text-align: center;  
}*/
.fs13{
    font-size:13px !important;
}
.fs19{
    font-size:19px !important;
}
.fs21{
    font-size:21px !important;
}
.fs25{
    font-size:25px !important;
}
.fs27{
    font-size:27px !important;
}
.fs29{
    font-size:29px !important;
}
body .article-body p{
    margin:0
}
body .article-body a{
    text-decoration:underline;
    color:#4682b4
}
body .article-body iframe{
    display:block;
    max-width:100%;
    margin-top:20px !important;
    margin-bottom:20px !important
}
body .article-body video{
    display:block;
    max-width:100%;
    margin-top:20px !important;
    margin-bottom:20px !important
}

.w380{
    max-width: 380px !important;
    width: 100%;
    margin: auto;
}
.w480{
    max-width: 480px !important;
    width: 100%;
    margin: auto;
}


/* 共通 end */


/* 記事 */
.mv {
    max-width: 580px;
    width: 100%;
    margin: auto;
    display: block;
}


/* ふきだし 左*/
.balloon {
    width: 100%;
    /*周りの余白。上下｜左右*/
    margin: 1.5em 0;
    overflow: hidden;
    display: flex;
}
.chatting {
    /*吹き出しの幅を変更する場合、下記autoを削除して20%から100%の値を指定してください*/
    width: auto;
}
.faceicon {
    flex-basis: 55px;
    flex-shrink: 0;
}
.faceicon img {
    width: 55px;
    max-width: 55px;
    height: 55px !important;
    object-fit: cover;
    /*画像周りの線。線の種類｜線の太さ｜線の色*/
    border: solid 3px #d7ebfe;
    border-radius: 50%;
    box-sizing: border-box;
}
.says {
    display: block;
    position: relative;
    margin: 0 0 0 20px;
    padding: 10px;
    border-radius: 10pt;
    /*ボーダーの色を調整できます、下の.says:afterのborder-rightと色を合わせてください*/
    border: 3px solid #d7ebfe;
    /*吹き出しの背景色*/
    background: #fff;
}
.says:before {
    content: "";
    position: absolute;
    top: 24px;
    left: -20px;
    margin-top: -10px;
    border: 10px solid transparent;
    border-right: 10px solid #FFF;
    z-index: 2;
}
.says:after {
    content: "";
    position: absolute;
    top: 24px;
    left: -28px;
    margin-top: -14px;
    border: 14px solid transparent;
    /*ボーダーの色を下記カラーコードで調整できます*/
    border-right: 14px solid #d7ebfe;
    z-index: 1;
}
.says p {
    margin: 0;
    padding: 0;
    letter-spacing: -0.01em;
}

/*ふきだし 右*/
.balloon2 {
    width: 100%;
    /*周りの余白。上下｜左右*/
    margin: 1.5em 0;
    overflow: hidden;
    display: flex;
    flex-direction: row-reverse;
}
.chatting2 {
width: auto;
}
.faceicon2 {
    flex-basis: 55px;
    flex-shrink: 0;
}
.faceicon2 img {
    width: 55px;
    max-width: 55px;
    height: 55px !important;
    object-fit: cover;
    /*画像周りの線の指定。左から、線の種類、線の太さ、線の色*/
    border: solid 3px #d7ebfe;
    border-radius: 50%;
    box-sizing: border-box;
}
.says2 {
    display: block;
    position: relative;
    margin: 0 20px 0 0;
    padding: 10px;
    border-radius: 10pt;
    /*ボーダーの色を調整できます、下の.says:afterのborder-leftと色を合わせてください*/
    border: 3px solid #d7ebfe;
    /*吹き出しの背景色*/
    background: #fff;
}

.says2:before {
    content: "";
    position: absolute;
    top: 24px;
    right: -21px;
    margin-top: -11px;
    border: 11px solid transparent;
    border-left: 11px solid #FFF;
    z-index: 2;
}

.says2:after {
    content: "";
    position: absolute;
    top: 24px;
    right: -28px;
    margin-top: -14px;
    border: 14px solid transparent;
    /*ボーダーの色を調整できます*/
    border-left: 14px solid #d7ebfe;
    z-index: 1;
}

.says2 p {
    margin: 0;
    padding: 0;
    letter-spacing: -0.01em;
}



/* クチコミ */
.box-contents {
    border: 1px solid #f48d91;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.box-contents .title {
    background-color: #f48d91;
    padding: 0.5em;
}
.box-contents .content {
    padding: 10px;
}
.box-contents .content video {
    max-width: 558px;
    width: 100%;
    margin: auto;
}
.box-contents .content>img+p {
    margin-top: 1em;
}


h2 {
    padding: 10px 5px 10px 10px;
    border-left: 6px solid #f68384;
    background-color: #fff1f1;
    margin-top: 40px;
    font-size: 19px;
    line-height: 2;
}


.frame {
    padding: 10px;
    position: relative;
    margin-top: 5px;
}
.frame-dotted-middle {
    border: 2.5px dotted;
    border-color: #007fff;
}
.radius {
    border-radius: 10px;
}
.bgBeige {
    background-color: #FFF8ED;
}


/* クチコミ２ */
.review {
    /*最大幅の指定。max-widthで指定した値の最大幅以上には広がらずに表示*/
    max-width: 580px;
    /*行間調整*/
    line-height: 1.5;
    margin: 0 auto;
    box-sizing: border-box;
}
.in {
    box-sizing: border-box;
    position: relative;
    /*枠内側の余白*/
    padding: 12px;
    /*背景色*/
    background: #fff;
    /*角を丸くする*/
    border-radius: 6px;
    /*線の指定。左から線の太さ、線の種類、線の色*/
    border: 1px solid #ccc;
    /*影の指定。左から水平方向の距離、垂直方向の距離、影の色*/
    box-shadow: 3px 3px #ffc7d3;
}
.speech-bubble {
    /*吹き出しの背景色*/
    background-color: #ff7ba1;
    margin: 0 auto;
    /*吹き出しの内側の余白。左の値が上下、右の値が左右の余白*/
    padding: 10px;
    /*吹き出し文字の水平方向の位置。*/
    text-align: left;
    position: absolute;
    /*吹き出しの影。左から、水平方向の距離、垂直方向の距離、ぼかし距離、影の色の順*/
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3);
    border-radius: 6px;
    top: 0;
    left: 0;
    /*吹き出しの文字の色*/
    color: #fff;
    /*吹き出し文字の太さ*/
    font-weight: 600;
    /*吹き出し文字の影。左から、水平方向の距離、垂直方向の距離、ぼかし距離、影の色の順*/
    text-shadow: 1px 2px 3px #808080;
    /*水平方向の字間のスペース*/
    letter-spacing: .05em;
    max-width: 100%;
    box-sizing: border-box;
    width: auto;
}
.speech-bubble:after {
    content: "";
    position: absolute;
    /*吹き出しの影*/
    box-shadow: rgba(0, 0, 0, 0.3) 2px 2px 2px;
    -moz-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    bottom: -7px;
    /*吹き出しのしっぽ部分の左からの距離*/
    left: 70%;
    /*吹き出しのしっぽの部分の背景色*/
    border-color: #ff7ba1;
    border-width: 7px;
    border-style: solid;
}
.kuchikomi {
    /*クチコミ部分の文章周りの余白。上の余白、左右の余白、下の余白*/
    margin: 12px 0;
}
.speech-bubble p {
    margin: 0;
}


/* 流れる矢印１ */
.arrowFlow__area {
    width: 100%;
    height: auto;
}
.arrowFlow__inner {
    padding-bottom: 200px;
    overflow-y: hidden;
    position: relative;
}
.arrowFlow__beforeG,
.arrowFlow__afterG {
    width: 80%;
    max-width: 400px;
    height: auto;
    margin: 0 auto;
    display: flex;
    justify-content: space-evenly;
    align-items: flex-start;
    animation-name: arrowFlow;
    animation-duration: 2s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    transform: translate(-50%, -300%);
    position: absolute;
    top: 0;
    left: 50%;
}
.arrowFlow__afterG {
    animation-delay: 1s;
}
.arrow {
    display: inline-block;
    vertical-align: middle;
    color: #ba0d0d;
    line-height: 1;
    position: relative;
    width: 40px;
    height: 60px !important;
    background: currentColor;
    margin: 0 30px;
}
.arrow:before {
    content: "";
    display: inline-block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 50px 50px 0 50px;
    border-color: #ba0d0d transparent transparent transparent;
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
}
@keyframes arrowFlow {
    0% {
        transform: translate(-50%, -300%);
    }

    60% {
        transform: translate(-50%, 100%);
    }

    100% {
        transform: translate(-50%, 400%);
    }
}

/*アンケート*/
.anc-wrapper {
    padding: 0 15px 15px;
    /* 枠の色 */
    margin: 0;
    background: linear-gradient(#deebf3, #b9d2e4);
    vertical-align: bottom;
    font-family: serif;
}
.container {
    /* コンテンツ部分の背景色 */
    background-color: #ffffff;
    padding: 0 0 4%;
}
.box-title {
    /* Q1部分の背景色 */
    background-color: #deebf3;
    text-align: center;
}
.tit {
    position: relative;
    bottom: -25px;
    z-index: 1;
    width: 80px;
    height: 80px;
    font-weight: bold;
    /* Q1部分の文字色 */
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}
.box-content {
    padding: 0 2%;
    width: 96%;
    margin: 0 auto;
}
.box-content p {
    margin: 60px 0 0 !important;
    font-size: 1.4em;
    font-weight: bold;
    text-align: center;
}
.main {
    padding: 10px 2% 10px;
    margin: 0 auto;
    width: 94%;
}
.questions {
    font-size: 8px;
    margin: 15px auto 0;
}
.questions ul,li,label,span {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 0;
    outline: 0;
    vertical-align: baseline;
    background: transparent;
    max-height: 99999px;
    text-align: center;
}

.btn_list {
    overflow: hidden;
    padding: 4.68% 5% 5% 5%;
    display: flex;
}

.btn_list li:first-child {
    padding-right: 2%;
}

.btn_list li {
    width: 50%;
}

.radio-input {
    display: none;
}

input[type="radio"]:checked+.y01,
input[type="radio"]:checked+.n01,
.input_img:hover {
    margin-top: 3px;
    /* 選択時のボタン文字色 */
    color: #010346;
    /* 選択時のボタン背景色 */
    background: #b2b7bd;
    /* 選択時のボタン影色 */
    border-bottom: 2px solid #8fa2b0;
}

.input_img {
    display: block;
    width: 100%;
    cursor: pointer;
    background-repeat: no-repeat;
    background-size: contain;
    padding: 10%;
    border-radius: 8px;
    font-size: 8vw;
    line-height: 1;
    /* 非選択時のボタン文字色 */
    color: #fff;
    font-weight: bold;
    /* 非選択時のボタン背景色 */
    background: linear-gradient(#d8b45c, #a9751b);
    /* 非選択時のボタン影色 */
    border-bottom: 5px solid #92610b;
    box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
    transition: all .3s;
    box-sizing: border-box;
    font-family: serif !important;
}

@media (min-width: 620px) {
    .input_img {
        font-size: 40px;
    }
}

.btn_list li:last-child {
    padding-left: 2%;
}

.sp {
    display: none;
}

@media (max-width: 750px) {
    .sp {
        display: block;
    }
}

/*アンケート３*/
.anc-wrapper {
    padding: 0 15px 15px;
    /* 枠の色 */
    margin: 0;
    background: linear-gradient(#deebf3, #b9d2e4);
    vertical-align: bottom;
    font-family: serif;
}
.container {
    /* コンテンツ部分の背景色 */
    background-color: #ffffff;
    padding: 0 0 4%;
}
.box-title {
    /* Q1部分の背景色 */
    background-color: #deebf3;
    font-family: sans-serif;
    text-align: center;
}
.tit {
    position: relative;
    bottom: -25px;
    z-index: 1;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    font-size: 25px;
    font-weight: bold;
    /* Q1部分の文字色 */
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}
.box-content {
    padding: 0 2%;
    width: 90%;
    margin: 0 auto;
}
p {
    margin: 60px 0 0;
    font-size: 1.4em;
    font-weight: bold;
    text-align: center;
}
.main {
    padding: 10px 2% 10px;
    margin: 0 auto;
    width: 90%;
}
.questions {
    font-size: 8px;
    margin: 15px auto 0;
}
.questions {
margin-top: 30px;
font-size: 16px;
font-family: sans-serif;
}
input[type="checkbox"] {
    display: none;
    appearance: checkbox;
    box-sizing: border-box;
}
input[type="checkbox"]+span {
    display: block;
    position: relative;
    padding-left: 35px;
    margin-bottom: 20px;
    font-weight: bold;
    cursor: pointer;
    text-align: left;
}
input[type="checkbox"]:checked+span:before {
    width: 10px;
    top: -5px;
    left: 10px;
    border-radius: 0;
    opacity: 1;
    border-top-color: transparent;
    border-right-color: #cd666f;
    border-bottom-color: #cd666f;
    border-left-color: transparent;
    transform: rotate(45deg);
}
input[type="checkbox"]+span:before {
    content: '';
    display: block;
    width: 20px;
    height: 20px;
    border: 1px solid #000;
    position: absolute;
    left: 0;
    top: 0;
    opacity: .6;
    transition: all .12s, border-color .08s;
    }


/*流れる矢印*/
.center {
    text-align: center;
    font-family: serif;
}
.words {
/* 数字下の文字色 */
color: #fff;
/* 数字下の背景色 */
background: linear-gradient(to bottom, #1a2287, #010346);
padding: 20px;
max-width: unset;
/* 数字下の文字サイズ */
font-size: 17px;
line-height: 1.3em;
padding: 20px 0 20px 0;
}
.step_arr {
position: relative;
padding-top: 22vw;
padding-bottom: 3vw;
margin-top: -4vw;
}
.step_arr span {
position: absolute;
top: 0;
left: 50%;
width: 10vw;
height: 10vw;
margin-left: -5vw;
border-left: 1px solid #333;
border-bottom: 1px solid #333;
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
-webkit-animation: sdb 2s infinite;
animation: sdb 2s infinite;
opacity: 0;
box-sizing: border-box;
}
.step_arr span:nth-of-type(1) {
-webkit-animation-delay: 0s;
animation-delay: 0s;
}
.step_arr span:nth-of-type(2) {
top: 4vw;
-webkit-animation-delay: .15s;
animation-delay: .15s;
}
.step_arr span:nth-of-type(3) {
top: 8vw;
-webkit-animation-delay: .3s;
animation-delay: .3s;
}
@-webkit-keyframes sdb {
    0% {
    opacity: 0;
    }

    50% {
    opacity: 1;
    }

    100% {
    opacity: 0;
    }
}
@keyframes sdb {
    0% {
    opacity: 0;
    }

    50% {
    opacity: 1;
    }

    100% {
    opacity: 0;
    }
}
@media (min-width: 620px) {
    .step_arr {
        position: relative;
        padding-top: 136px;
        margin-top: -25px;
    }

    .step_arr span {
        width: 62px;
        height: 62px;
        margin-left: -31px;
    }

    .step_arr span:nth-of-type(2) {
        top: 24.8px;
    }

    .step_arr span:nth-of-type(3) {
        top: 49.6px;
    }
}


/* CTA */
.purupuru {
    /*アニメーション名、動きの速さ0.8s（=0.8秒）、動き具合、開始時間5s(=5秒後)、動く回数infinite(=無限 3=3回など)   */
    animation: purupuru 2s linear 0s infinite;
}

@keyframes purupuru {
    /*アニメーションの最初の動き*/
    0% {
    /*skew = 傾斜変形する、1番目の値はX軸、2番目に値がある場合はY軸に傾斜変形する9deg = 9度*/
    transform: skew(9deg);
    }
    10% {
    transform: skew(-8deg);
    }
    20% {
    transform: skew(7deg);
    }
    30% {
    transform: skew(-6deg);
    }
    40% {
    transform: skew(5deg);
    }
    50% {
    transform: skew(-4deg);
    }
    60% {
    transform: skew(3deg);
    }
    70% {
    transform: skew(-2deg);
    }
    80% {
    transform: skew(1deg);
    }
    90% {
    transform: skew(0deg);
    }
    /*アニメーションの最後の動き*/
    100% {
    transform: skew(0deg);
    }
}


footer {
    font-size: 13px;
    padding: 2%;
    background: #ECECEC;
    text-align: center;
    margin-top: 10px;
}
footer a{
    font-weight: normal;
}
@media (max-width: 767px) {
    footer {
        padding:2%;
        font-size: 14px;
    }
}