@charset "utf-8";
/* CSS Document */
html{font-size:62.5%}
body{overflow-x:hidden; width:100%; height:100%; text-align:center;color:#000; font-family: "ヒラギノ角ゴ ProN W3",ArialMT,"Hiragino Kaku Gothic ProN",メイリオ,sans-serif; -webkit-tap-highlight-color:rgba(0, 0, 0, 0); margin:0 auto}
ul{list-style-type:none; margin-block-start:0; margin-block-end:0; padding-inline-start:0}
img{max-width:100%; height:auto; width /***/:auto; vertical-align:bottom; display:block}
a:hover img, input[type="image"]:hover, input[type="submit"]{cursor:pointer; cursor:hand} input[type="submit"]:hover{opacity:0.7}
	/* link */
	a:link, a:visited, a, a:hover, a:active{text-decoration: none}
	a:hover{opacity:0.8}
	
/*--共通--*/
        .red{color:#F00} .white{color:#fff} .black{color:#000}.gray{color:#a0a0a0}.yellow{color:#ffff00}  .blue{color:#0000ff}.green{color:#07b53b}.purple{color:#5900ff}.orange{color:#ff7800}.amber{color:#f4d599}.navy{color:#00348f}
        .bold{font-weight:bold} .under{text-decoration:underline; text-underline-offset: 0.1em}
        .none{display:none}
        img.imgbt2{margin-bottom:2%} img.imgbt4{margin-bottom:4%} img.imgbt7{margin-bottom:7%}
        .borderd{border-bottom:dotted 2px #e2e2e2}
    /*画像回り込み*/
        img.txt-r, img.txt-l{float:right; margin:0 0 2% 2%} img.txt-l{float:left; margin:0 2% 2% 0}
    /*marker*/
        .marker, .marker-yellow, .marker-red, .marker-blue {background:#ffff00; padding:0 2px 2px 2px}
        .marker-yellow{background:#ffde00}.marker-red{background:#F00; color:#fff}.marker-blue{background:#0000ff; color:#fff}
    /*フォント*/
        .size08{font-size:0.8em}
        .size12,.size13,.size14,.size16,.size22,.size24,.size26,.size30,.size36{font-size:1.2em; line-height:1.5em}.size13{font-size:1.36em}.size14{font-size:1.4em}.size16{font-size:1.6em}.size22{font-size:2.25em}.size24{font-size:2.425em}.size26{font-size:2.625em}.size30{font-size:3.055em}.size36{font-size:3.625em}
        .mincyou6{font-family:"ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif}
        .mincyou3{font-family:"ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif}
             /*白境界線ぼかし(text、box用)*/
                .tswb{text-shadow:2px 2px 0 #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff}
                .bswb{box-shadow:2px 2px 0 #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff,0 0 10px #fff}
        /*リストスタイル*/
        ul.disc, ul.circle, ul.square, ol.decimal, ul.reference{box-sizing:border-box; padding-left:28px}ol.decimal{padding-left:1.4em}
        ul.disc li, ul.circle li, ul.square li, ol.decimal li, ul.reference li,ul.reference li:before{list-style:disc; list-style-position:outside; background:none}
        ul.circle li{list-style:circle} ul.square li{list-style:square} ol.decimal li{list-style:decimal} ul.reference li{list-style:none}
        ol.decimal li a{color:#0000ff}
            /*-- 擬似要素リファレンスのリストスタイル --*/
            ul.reference{list-style-type:none!important}
            ul.reference li:before{content:'※'; margin-left:-1.0em}
        /*listimg*/
        ul.listimg{margin-bottom:4%}
        ul.listimg li{list-style-type:none; background:url(../images/listimg.png) no-repeat 0 4px; list-style-position:inside; background-size:17px; padding-left:23px; line-height:1.5em}
    /*border*/
        .bdboxg,.bdboxr{border:solid 2px #e2e2e2; box-sizing:border-box; padding:2%}
        .bdboxr{border:solid 2px #F00; box-sizing:border-box}
        hr{height:0; margin:0; padding:0; border:0}hr.grayb{border-top:2px solid #e2e2e2}hr.whiteb{border-top:2px solid #fff}
    /*見出し*/
        .leadg,.leadr{border-left:solid 8px #e2e2e2; box-sizing:border-box; padding:1% 0 1% 4%; margin-bottom:4%}.leadr{border-left:solid 8px #F00}
    /*layout*/
        .left{text-align:left} .center{text-align:center} .right{text-align:right}
    /*padding*/
        .pt2{padding-top:2%}.pt4{padding-top:4%}.pt5{padding-top:5%}.pt7{padding-top:7%}.pt8{padding-top:8%}
        .pb2{padding-bottom:2%}.pb4{padding-bottom:4%}.pb5{padding-bottom:5%}.pb7{padding-bottom:7%}.pb8{padding-bottom:8%}
        .pd2{padding:2%}.pd3{padding:3%}.pd4{padding:4%}.pd5{padding:5%}.pd022{padding:0 2% 2%}.pd033{padding:0 3% 3%}.pd044{padding:0 4% 4%}.pd055{padding:0 5% 5%}.pd407{padding:4% 0 7%}
        .pd4-0{padding:4% 0}.pd4-2{padding:4% 2%}.pd5-0{padding:5% 0}.pd5-2{padding:5% 2%}.pd7-0{padding:7% 0}.pd7-5{padding:70px 5.2%}
    /*margin*/
        .mt2{margin-top:2%}.mt4{margin-top:4%}.mt5{margin-top:5%}.mt7{margin-top:7%}.mt8{margin-top:8%}
        .mb2{margin-bottom:2%}.mb4{margin-bottom:4%}.mb5{margin-bottom:5%}.mb7{margin-bottom:7%}.mb8{margin-bottom:8%}
    /*background*/
        .whitebg{background:#fff}.blackbg{background:#000}.graybg{background:#fafafa}.yellowbg{background:#ffff00}.yellow2bg{background:#ffde00}.redbg{background:#F00}.bluedbg{background:#0000ff}.navybg{background:#022157}.greenbg{background:#07b53b}.purplebg{background:#5900ff}.amberbg{background:#f4d599}.ivorybg{background:#fffbea}
    /*inner*/
        .inner{max-width:880px; margin:0 auto}

/*背景*/
    .bg{padding:70px 0}.bgt0{padding:0 0 70px}.bgb0{padding:70px 0 0}

/*block*/
    #block_wrapper, .block_wrapper, .shadow{box-shadow: 0 5px 10px rgba(0,0,0,0.4)}
    .block{padding:0 5.2% 50px; text-align:left}
    .hl, .h, .hlh{padding:50px 1% 4%; font-weight:900; font-size:2.4em; line-height:1.5em; text-align:center}.h{padding:0 1% 4%}.hlh{padding:70px 2% 40px}
/* container */
    .container {
        margin-top: -450px;
    }

/*mv*/
    .bg-mv {
        background-color: #fffdf3;
        /* height: 960px; */
    }
    .mv-txt {
        font-size:1.6em;
        line-height:1.5em;
        text-align:center;
        font-weight:900;
        padding: 10px 0;
    }

    .mv-video-wrapper {
        padding: 0 5%;
    }

    .mv-video {
        width: 100%;
        max-width: 830px;
        aspect-ratio: 16/9;
        object-fit: contain;
        height: auto;
        margin: 0 auto;
        position: relative;
        top: -50%;
        transform: translateY(-143%);
    }

    .mv-video iframe {
        width: 100%;
        height: 100%;
    }

/* sec01 */
    .sec01-ttl {
        font-size:2.4em;
        line-height:1.5em;
        text-align:center;
        font-weight:900;
        background-color: #ff6a00;
        color: #fff;
        padding: 10px 0;
        width: 100vw;
        margin: 0 calc(50% - 50vw);
    }

    .bg-sec01 {
        background: url(../images/bg.png) no-repeat center center / cover;
        background-color: #fff;
    }
    .sec01__content {
        padding-top: 100px;
    }

    .sec01__step {
        border: 3px solid #018d57;
        padding: 20px;
        background-color: #fff;
        position: relative;
    }
    .sec01__step::before {
        content: '';
        position: absolute;
        top: -5px;
        width: 270px;
        height: 10px;
        background-color: #fff;
        left: 50%;
        transform: translate(-50%,0);
    }

    .sec01__step:nth-child(2) {
        margin-top: 100px;
    }
    .sec01__step-ttl {
        width: 233px;
        height: auto;
        margin: -70px auto 0;
        position: relative;
    }
    .sec01__step-txt {
        font-size: 2.6em;
        line-height: 1.2em;
        text-align: center;
        font-weight: 700;
        margin-top: 10px;
    }

    .sec01__arrow {
        width: 100%;
        max-width: 700px;
        margin: 40px auto 0;
    }

/* sec02 */
    .sec02__content {
        padding-top: 100px;
    }

    .sec02__step {
        border: 3px solid #018d57;
        padding: 20px;
        background-color: #fff;
    }

    .sec02__step-txt {
        font-size: 1.6em;
        line-height: 2em;
        text-align: center;
    }

    .sec02__step-txt-big {
        font-size: 2em;
        font-weight: 700;
        line-height: 1.5em;
    }

    .sec02__step-txt-redBig {
        font-size: 2.3em;
        font-weight: 700;
        color: #f94100;
        background: linear-gradient(to bottom, #f0b300 30%, #f94100 70%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }

    .sec02__step-tokuten-btn {
        position: relative;
        top: -190px;
        margin: 0 auto;
        width: 100%;
        max-width: 745px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .sec02__step-txt--step02 {
        margin-top: -100px;
    }

/* sec03 */
    .sec03 {
        padding-top: 80px;
        background-color: #eef9ee;
        position: relative;

        &::after {
            content: '';
            position: absolute;
            width: 0;
            height: 0;
            border-style: solid;
            border-right: 85px solid transparent;
            border-left: 85px solid transparent;
            border-top: 50px solid #eef9ee;
            border-bottom: 0;
            bottom: -50px;
            left: 50%;
            transform: translateX(-50%);
            z-index: 1;
        }
    }

/* sec04 */
    .sec04__table {
        width: 100%;
        max-width: 960px;
        margin: 0 auto;
        border-collapse: collapse;
        margin-top: 100px;
    }

    .sec04__table th,
    .sec04__table td {
        padding: 15px;
        border: 1px solid #018d57;
        text-align: center;
    }

    .sec04__table th {
        background: #018d57;
        width: 50%;
    }

    .sec04__table td {
        background: #fff;
        font-size: 2em;
        vertical-align: middle;
        font-weight: 900;
    }

    .sec04__table-ttl {
        color: #fff;
        font-size: 2em;
        line-height: 1.5em;
    }

    .sec04__table-ttl--yellow {
        color: #f0e801;
        font-size:  1.7em;
        position: relative;
    }

    .sec04__table-ttl--yellow::after {
        position: absolute;
        content: '';
        width: 100%;
        height: 1px;
        background-color: #f0e801;
        bottom: 0;
        left: 0;
    }

    .sec04__caution {
        font-size: 2.2em;
        font-weight: 700;
        margin-top: 20px;
        line-height: 1.5em;
    }

/*footer*/
    #footer{width:100%; margin:0 auto}
    .footer-inner{
        padding:40px 0 40px;
        text-align:center;
        background-color: #000;
    }
    #footer a{
        color:#fff;
        text-decoration:none
    }
    .footer-line {
        color: #fff;
        margin: 0 8px;
    }
    .fco{
        font-style:normal;
        margin:0;
        padding:0;
    }

    .fco-txt {
        line-height:2.4em;
        text-align:center;
        color:#fff;
    }

@media screen and (min-width:960px) {
    /*for PC*/
    #wrapper, .wrapper{font-size:1.8rem; font-feature-settings:"palt"; line-height:1.5em; margin:0 auto; padding:0}
    .contents,.hpb{width:960px; margin:0 auto}.hpb{width:100%; text-align: center}
    .pc{display:block}.sp{display:none}
}

@media screen and (max-width:960px) {
    /*for iPad tb(タブレット)*/
    #wrapper, .wrapper{font-size:1.8rem; font-feature-settings:"palt"; line-height:1.5em; margin:0 auto; padding:0}
    .hpb{width:100%; margin:0 auto}
    .pc{display:none}.sp{display:block}
    /*共通*/
    .size12{font-size:1.125em}.size13{font-size:1.18em}.size14{font-size:1.225em}.size12{font-size:1.125em}.size13{font-size:1.18em}.size14{font-size:1.225em}
    .size16{font-size:1.3125em}.size22{font-size:1.3625em}.size24{font-size:1.425em}.size26{font-size:1.625em}.size30{font-size:1.76em}.size36{font-size:2.3em}
    /*背景*/
    .bg{padding:70px 2%}.bgt0{padding:0 2% 70px}.bgb0{padding:50px 2% 0}
    /*block*/
    .container {
        margin-top: -40vw;
    }

    /* mv */
    .mv-txt {
        padding: 20px 5px;
    }
    .mv-video {
        transform: translateY(-160%);
    }

    /* sec01 */
    .sec01-ttl {
        font-size: 1.8em;
    }
    .sec01__step {
        padding-left: 10px;
        padding-bottom: 10px;
        padding-right: 10px;
        padding-top: 30px;
    }

    .sec01__step::before {
        width: 190px;
    }

    .sec01__step:nth-child(2) {
        margin-top: 50px;
    }

    .sec01__step-ttl {
        width: 160px;
    }

    .sec01__step-txt {
        font-size: 1.3em;
    }

    .sec01__arrow {
        margin-top: 20px;
    }

    /* sec02 */
    .sec02__content {
        padding-top: 30px;
    }
    .sec02__step {
        padding: 10px;
    }
    .sec02__step-txt {
        font-size: 1em;
    }
    .sec02__step-txt-big {
        font-size: 1.1em;
    }
    .sec02__step-txt-redBig {
        font-size: 1.8em;
    }
    .sec02__step-tokuten-btn {
        top: -160px;
        max-width: 500px;
    }
    .sec02__step-txt--step02 {
        margin-top: -70px;
    }
    /* sec03 */
    .sec03 {
        &::after {
            border-right: 50px solid transparent;
            border-left: 50px solid transparent;
            border-top: 60px solid #eef9ee;
            bottom: -60px;
        }
    }
    /* sec04 */
    .sec04 {
        padding: 50px 20px 0;
    }

    .sec04__table th, .sec04__table td {
        padding: 15px 5px;
        border: 1px solid #018d57;
        text-align: center;
    }

    .sec04__table {
        margin-top: 50px;
    }

    .sec04__table,
    .sec04__table tbody,
    .sec04__table tr,
    .sec04__table th,
    .sec04__table td {
        display: block;
        width: 100%;
    }
    .sec04__table td {
        font-size: 1.2em;
    }

    .sec04__table-ttl {
        font-size: 1.5em;
    }

    .sec04__table-ttl--yellow {
        font-size: 1.3em;
    }

    .sec04__table tr:not(:last-child) td {
        border-bottom: none;
    }
    .sec04__table-ttl--yellow::after {
        display: none;
    }
    .sec04__caution {
        font-size: 1em;
    }
}

@media screen and (max-width:580px) {
    .sec02__step-tokuten-btn {
        max-width: 80vw;
        top: -140px;
    }
}

@media screen and (max-width: 480px) {
    /*for iPhone sp(スマートフォン)*/    
    #wrapper, .wrapper{font-size:1.8rem; font-feature-settings:"palt"; line-height:1.5em; margin:0 auto; padding:0}
    .hpb{width:100%; margin:0 auto}
    .pc{display:none}.sp{display:block}
	::placeholder{font-size:0.7em}
    /*--共通--*/
        /*padding*/
        .pd5-0{padding:5% 2%}.pd7-5{padding:35px 2%}.pd02{padding:0 2%}
    
    /*背景*/
    .bg{padding:35px 2%}.bgt0{padding:0 2% 35px}

    /*block*/
    .block{padding:0 2% 25px; text-align:left}
    .hl, .h, .hlh{padding:25px 1% 4%; font-size:1.625em}.h{padding:0 1% 4%}.hlh{padding:35px 2% 20px; margin-bottom:0}

    /* mv */
    .mv-txt {
        font-size: 1em;
    }

    /* sec02 */
    .sec02__step-txt--02 {
        text-align: left;
    }
    .sec02__step-tokuten-btn {
        top: -80px;
        max-width: 300px;
    }
    .sec02__step-txt--step02 {
        margin-top: -50px;
        text-align: left;
    }

/*-- ▼▼ footer ここから ▼▼ --*/
    .fco, #footer p{font-size:0.8em}.footer-inner{padding:35px 0 20px}
} 