@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

body {
    font-family: YakuHanJP, "Noto Sans JP", serif;
    padding: 0;
    margin: 0;
    color: #333333;
}

img {
    max-width: 100%;
    vertical-align: top;
}

h1 {
    margin: 0;
}

p {
    margin: 0;
}

a:hover {
    opacity: 0.7;
}


@media screen and (max-width:768px) {

    header {
        padding: 0 20px;
    }

    .header_inr {
        margin: 0 auto;
        display: grid;
        grid-template-columns: 1fr 0 1fr 1fr;
        align-items: center;
        grid-gap: 20px;
        height: 68px;
    }



    section.fv {
        margin-bottom: 30px;
    }

    .fv_inr {
        position: relative;
    }

    .fv_main_wrap {
        position: absolute;
        z-index: 1;
        top: 40px;
        left: 50%;
        transform: translate(-50%, 0);
        text-align: center;
        width: calc(100% - 20px);
        margin-top: 4vw;
        height: calc(90% - 16vw);
        display: flex;
        flex-direction: column;
    }

    p.fv_main_wrap_p01 {
        color: #fff;
        font-size: clamp(16px, 4.2vw, 32px);
    }

    p.fv_main_wrap_p02 {
        color: #fff;
        font-size: clamp(20px, 4.8vw, 50px);
        margin-bottom: 1em;
        font-weight: bold;
    }


    img.fv_main {
        width: 100%;
    }

    .fv_main_wrap h1 + p {
        background: #fff;
        color: #BF0030;
        border: solid 2px;
        font-size: clamp(13px, 1.2vw, 22px);
        border-radius: 6px;
        padding: 10px 6px;
        font-weight: bold;
        margin: auto 0 0;
    }




    main {}

    section.s01 {
        text-align: center;
        padding: 10px 20px 0;
        margin: 0 auto 50px;
    }

    p.s01_ttl01 {
        font-size: clamp(14px, 1.2vw, 20px);
        margin-bottom: 1em;
        text-align: left;
        font-weight: 500;
    }

    p.s01_ttl01 strong {}

    p.s01_ttl02 {
        font-size: clamp(21px, 2.4vw, 45px);
        font-weight: 900;
        margin-bottom: 0.4em;
    }

    p.s01_ttl02 span {
        font-size: 0.78em;
    }

    p.s01_txt01 {
        font-size: 10px;
        margin-bottom: 4em;
    }

    h2.s01_ttl03 {
        display: block;
        font-size: clamp(20px, 2.8vw, 40px);
        background: #F7B400;
        width: 80%;
        max-width: 558px;
        margin: 0 auto 1.4em;
        font-weight: 500;
        border-radius: 2em;
        padding: 0.4em 0;
        border: solid 4px;
        box-shadow: 2px 4px 0px 2px;
    }

    img.s02_img01 {
        width: 100%;
        max-width: 834px;
        margin-bottom: 16px;
    }

    p.s01_txt02 {
        font-size: clamp(25px, 2.1vw, 35px);
        margin-bottom: 20px;
        font-weight: 800;
    }

    img.s02_img02 {
        width: 100%;
        margin-bottom: 2em;
    }

    p.s01_txt03 {
        font-size: clamp(18px, 1.8vw, 30px);
        display: block;
        width: 100%;
        margin: 0 auto 1.4em;
        font-weight: 500;
        padding: 0 1em;
        background: url(image/s02_img03.png), url(image/s02_img04.png);
        background-position: left, right;
        background-repeat: no-repeat;
        background-size: contain;
        box-sizing: border-box;
    }


    .s01_txt04_05wrap {
        margin-bottom: 10vw;
    }


    p.s01_txt04 {
        font-size: 12px;
        text-align: left;
        margin: 0 auto;
        width: fit-content;
        position: relative;
    }

    p.s01_txt04::before {}

    p.s01_txt05 {
        font-size: 12px;
    }

    p.s01_txt06 {
        font-size: clamp(25px, 1.8vw, 30px);
        font-weight: bold;
        margin: 0 auto 1.4em;
    }


    h3.s01_ttl04 {
        font-size: clamp(20px, 2.2vw, 30px);
        background: #9B9B9B;
        color: #fff;
        border: solid 2px #333333;
        width: 100%;
        margin: 0 auto 1em;
        line-height: 2em;
        font-weight: 400;
    }

    p.s01_txt07 {
        font-size: clamp(25px, 2.6vw, 35px);
        margin: 0 0 1em;
    }

    p.s01_txt08 {
        text-align: left;
        width: fit-content;
        margin: 0 auto 2.5em;
        font-size: 12px;
    }

    p.s01_txt09 {
        font-size: clamp(16px, 1.6vw, 20px);
        background: #E6E6E6;
        width: 100%;
        margin: 0 auto 1em;
        border: solid 1px #333333;
        padding: 1em 0;
    }

    ul.s01_txt10 {
        text-align: left;
        width: fit-content;
        margin: 0 auto 4em;
        font-size: 15px;
        list-style: circle;
        padding: 0 20px;
    }

    h3.s01_ttl05 {
        font-size: clamp(20px, 1.8vw, 25px);
        background: #222;
        color: #fff;
        width: 80%;
        margin: 0 auto 1em;
        border-radius: 2em;
        line-height: 2.2em;
    }

    .s01_txt11 {
        max-width: 768px;
        text-align: left;
        margin: 0 auto 3em;
        padding: 0;
        font-size: 12px;
    }

    .s01_txt12 {
        text-align: left;
        margin: 4em auto 6px;
        width: fit-content;
        position: relative;
        font-size: clamp(18px, 1.4vw, 20px);
    }

    .s01_txt12::before {
        font-size: 20px;
        content: "楽天ポイント進呈予定日";
        position: absolute;
        top: -2.6em;
        left: 50%;
        background: #ddd;
        width: 100%;
        align-content: center;
        padding: 0 0 2px;
        transform: translateX(-50%);
        text-align: center;
    }









    section.s02 {
        background: url(image/s02_bg.jpg);
        background-repeat: no-repeat;
        background-size: cover;
        padding: 100px 0 200px;
        margin-top: -100px;
    }

    h2.s02_inr_ttl {
        display: block;
        font-size: clamp(20px, 2.8vw, 40px);
        background: #4FA8EA;
        margin: 0 auto 1em;
        border-radius: 2em;
        padding: 8px 0;
        width: 74%;
        text-align: center;
        color: #fff;
        line-height: 2em;
        z-index: 1;
        position: relative;
        font-weight: 500;
    }

    p.s02_inr01_box_txt01 {
        font-size: 16px;
        margin-bottom: 1em;
    }



    .s02_inr01 {
        margin: 0 auto 5vw;
        padding: 0 40px 20px;
        overflow: hidden;
    }

    .s02_inr01_box {
        display: grid;
        grid-template-columns: 1fr;
        align-items: center;
    }

    h3.s02_inr01_box_ttl {
        font-size: clamp(30px, 2.1vw, 35px);
        margin: 0 0 12px;
        color: #3984BC;
        font-weight: 600;
        line-height: 1.2em;
    }

    .s02_inr01_box_img02 {
        transform: scale(1.15);
        margin: 10px 0 20px;
    }

    p.s02_inr01_txt01 {
        font-size: 14px;
    }





    .s02_inr02 {
        margin: 0 auto;
        padding: 0 20px;
    }

    h2.s02_inr02_ttl {
        font-size: clamp(20px, 1.8vw, 30px);
        color: #349BE7;
        font-weight: 500;
        text-align: center;
        border-top: solid 2px #ccc;
        border-bottom: solid 2px #ccc;
        padding: 10px;
        margin: 0 0 1em;
    }

    .s02_inr02_box {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-gap: 40px 0;
    }

    .s02_inr02_box h3 {
        color: #3984BC;
        font-size: clamp(20px, 1.6vw, 28px);
        font-weight: 500;
        padding-left: 0.4em;
        margin: 0;
        line-height: 1.2em;
    }

    p.s02_inr02_box_txt01 {
        font-size: 14px;
        padding-left: 1em;
    }

    p.s02_inr02_box_txt02 {
        font-size: 14px;
        padding-left: 1.4em;
        margin-top: 1em
    }





    section.s03 {
        background: #F7B400;
        padding: 0;
        position: sticky;
        top: calc(100% - 150px);
        height: 150px;
        z-index: 10;
        box-sizing: border-box;
    }

    .s03_inr {
        margin: 0 auto;
        padding: 20px;
    }

    .s03_inr_ttl {
        font-size: clamp(20px, 2.8vw, 40px);
        text-align: center;
        color: #000;
        margin-bottom: 0.8em;
        font-weight: 500;
    }

    .s03_inr_box {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        grid-gap: 2px;
        margin-bottom: 30px;
    }

    .s03_inr_box a {
        width: 100%;
        background: #fff;
        text-align: center;
        text-decoration: none;
        color: #222;
        font-weight: bold;
        padding: 6px;
        border-radius: 10px;
        box-shadow: 0px 10px 0px rgba(0, 0, 0, 0.2);
        font-size: clamp(14px, 1.4vw, 20px);
        box-sizing: border-box;
        line-height: 1.4;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .s03_inr_box a.mizumawari {
        color: #3984BC !important;
    }

    .s03_inr_box a.aircon {
        color: #D93A49 !important;
    }


    img.link_ico {
        filter: drop-shadow(4px 4px 8px rgba(0, 0, 0, 0.4));
    }

    p.s03_inr_txt {
        font-size: clamp(18px, 1.5vw, 25px);
        text-align: center;
        font-weight: bold;
        margin: 0 0 1em;
    }



    footer {
        padding: 0 20px;
    }

    .footer_inr {
        margin: 0 auto;
        display: grid;
        grid-template-columns: repeat(2, auto);
        align-items: center;
        grid-gap: 20px;
        height: 76px;
    }

    a.footer_link {
        text-decoration: none;
        font-size: clamp(14px, 1.2vw, 20px);
        color: #333333;
        position: relative;
        font-weight: 300;
    }

    a.footer_link::after {
        content: "";
        width: 0;
        height: 0;
        border: solid 4px #80B7D9;
        border-left: solid 4px transparent;
        border-bottom: solid 4px transparent;
        display: inline-block;
        position: absolute;
        top: 54%;
        right: -0.8em;
        transform: translateY(-50%) rotate(45deg);
    }

    .copyright {
        font-size: 12px;
        padding: 8px;
        text-align: center;
    }



    .sp_none {
        display: none;
    }

}























































@media screen and (min-width:769px) {
    .header_inr {
        max-width: 1000px;
        margin: 0 auto;
        display: grid;
        grid-template-columns: 135px 1fr 135px 135px;
        align-items: center;
        grid-gap: 20px;
        height: 86px;
    }


    section.fv {
        margin-bottom: 60px;
    }

    .fv_inr {
        position: relative;
    }

    .fv_main_wrap {
        position: absolute;
        z-index: 1;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        text-align: center;
    }

    p.fv_main_wrap_p01 {
        color: #fff;
        font-size: clamp(16px, 1.8vw, 26px);
    }

    p.fv_main_wrap_p02 {
        color: #fff;
        font-size: clamp(18px, 2.0vw, 35px);
        margin-bottom: 1em;
        font-weight: bold;
    }

    img.fv_main {
        width: 40vw;
    }

    .fv_main_wrap h1 + p {
        background: #fff;
        color: #BF0030;
        border: solid 2px;
        font-size: clamp(14px, 1.2vw, 22px);
        border-radius: 6px;
        padding: 10px 20px;
        font-weight: bold;
        margin: 1.4em auto 0;
    }




    main {}

    section.s01 {
        text-align: center;
        margin-bottom: 6vw;
    }

    p.s01_ttl01 {
        font-size: clamp(14px, 1.2vw, 20px);
        margin-bottom: 1em;
    }

    p.s01_ttl01 strong {
        font-size: 1.25em;
    }

    p.s01_ttl02 {
        font-size: clamp(21px, 2.4vw, 45px);
        font-weight: bold;
        margin-bottom: 0.4em;
    }

    p.s01_ttl02 span {
        font-size: 0.78em;
    }

    p.s01_txt01 {
        font-size: 15px;
        margin-bottom: 4em;
    }

    h2.s01_ttl03 {
        display: block;
        font-size: clamp(20px, 2.8vw, 40px);
        background: #F7B400;
        width: 88%;
        max-width: 558px;
        margin: 0 auto 1em;
        font-weight: 500;
        border-radius: 2em;
        padding: 0.2em 0;
        border: solid 4px;
        box-shadow: 6px 6px 0px 2px;
    }

    img.s02_img01 {
        width: 88%;
        max-width: 834px;
        margin-bottom: 16px;
    }

    p.s01_txt02 {
        font-size: clamp(25px, 2.1vw, 35px);
        margin-bottom: 0.6em;
    }

    img.s02_img02 {
        width: 88%;
        max-width: 734px;
        margin-bottom: 2em;
    }

    p.s01_txt03 {
        font-size: clamp(18px, 1.8vw, 30px);
        display: block;
        width: fit-content;
        margin: 0 auto 1em;
        font-weight: 500;
        padding: 0 2em;
        background: url(image/s02_img03.png), url(image/s02_img04.png);
        background-position: left, right;
        background-repeat: no-repeat;
        background-size: contain;
    }

    .s01_txt04_05wrap {
        width: fit-content;
        margin: 0 auto 4em;
    }

    p.s01_txt04::before {}


    p.s01_txt04 {
        text-align: left;
        position: relative;
        margin-bottom: 1em;
    }


    p.s01_txt05 {
        text-align: left;
    }

    p.s01_txt06 {
        font-size: clamp(18px, 1.8vw, 30px);
        margin: 0 0 1.4em;
    }

    h3.s01_ttl04 {
        font-size: clamp(18px, 2.2vw, 30px);
        background: #9B9B9B;
        color: #fff;
        border: solid 4px #333333;
        width: 88%;
        max-width: 558px;
        margin: 0 auto 1em;
        line-height: 2em;
        font-weight: 400;
    }

    p.s01_txt07 {
        font-size: clamp(18px, 2.6vw, 35px);
        margin: 0 0 1em;
    }

    p.s01_txt08 {
        text-align: left;
        width: fit-content;
        margin: 0 auto 2.5em;
        font-size: 12px;
    }

    p.s01_txt09 {
        font-size: clamp(16px, 1.6vw, 20px);
        background: #E6E6E6;
        width: 88%;
        max-width: 558px;
        margin: 0 auto 1em;
        border: solid 1px #333333;
        line-height: 2.4em;
    }

    ul.s01_txt10 {
        text-align: left;
        width: fit-content;
        margin: 0 auto 6em;
        font-size: 15px;
        list-style: circle;
    }

    h3.s01_ttl05 {
        font-size: clamp(18px, 1.8vw, 25px);
        background: #222;
        color: #fff;
        max-width: 768px;
        margin: 0 auto 1em;
        border-radius: 2em;
        line-height: 2.2em;
    }

    .s01_txt11 {
        max-width: 768px;
        text-align: left;
        margin: 0 auto 3em;
        padding: 0;
    }

    .s01_txt12 {
        width: fit-content;
        margin: 0 auto 4em;
        position: relative;
        text-align: left;
        padding-left: 10em;
        margin-bottom: 2em;
        font-size: clamp(18px, 1.4vw, 20px);
    }

    .s01_txt12::before {
        font-size: 20px;
        content: "楽天ポイント進呈予定日";
        position: absolute;
        left: 0;
        background: #ddd;
        height: 100%;
        align-content: center;
        padding: 0 1em;
        width: 6em;
        text-align: center;
    }








    section.s02 {
        background: url(image/s02_bg.jpg);
        background-repeat: no-repeat;
        background-size: cover;
        padding: 220px 0 300px;
        margin-top: -220px;
    }

    h2.s02_inr_ttl {
        display: block;
        font-size: clamp(20px, 2.8vw, 40px);
        background: #4FA8EA;
        margin: 0 auto 1em;
        font-weight: 300;
        border-radius: 2em;
        padding: 0 1em;
        width: 88%;
        max-width: 558px;
        text-align: center;
        color: #fff;
        line-height: 2em;
        z-index: 1;
        position: relative;
        font-weight: 500;
    }

    p.s02_inr01_box_txt01 {
        font-size: 16px;
        margin-bottom: 1em;
    }



    .s02_inr01 {
        width: 96%;
        max-width: 780px;
        margin: 0 auto 5vw;
    }

    .s02_inr01_box {
        display: grid;
        grid-template-columns: 40% 1fr;
        align-items: center;
    }

    h3.s02_inr01_box_ttl {
        font-size: clamp(30px, 2.1vw, 35px);
        margin: 0 0 12px;
        color: #3984BC;
        font-weight: 600;
        line-height: 1.2em;
    }

    p.s02_inr01_txt01 {
        font-size: 18px;
    }





    .s02_inr02 {
        width: 96%;
        max-width: 780px;
        margin: 0 auto;
    }

    h2.s02_inr02_ttl {
        font-size: clamp(20px, 1.8vw, 30px);
        color: #349BE7;
        font-weight: 500;
        text-align: center;
        border-top: solid 2px #ccc;
        border-bottom: solid 2px #ccc;
        padding: 10px;
        margin: 0 0 1em;
    }

    .s02_inr02_box {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-gap: 40px 0;
    }

    .s02_inr02_box h3 {
        color: #3984BC;
        font-size: clamp(20px, 1.6vw, 28px);
        font-weight: 500;
        padding-left: 0.4em;
        margin: 0;
    }

    p.s02_inr02_box_txt01 {
        font-size: 16px;
        padding-left: 1em;
    }

    p.s02_inr02_box_txt02 {
        font-size: 16px;
        padding-left: 1.4em;
        margin-top: 1em
    }





    section.s03 {
        background: #F7B400;
        padding: 1vw 0;
        position: sticky;
        top: calc(100% - 220px);
        height: 220px;
        z-index: 10;
        box-sizing: border-box;
    }

    .s03_inr {
        width: 96%;
        max-width: 1000px;
        margin: 0 auto;
    }

    .s03_inr_ttl {
        font-size: clamp(20px, 2.8vw, 40px);
        text-align: center;
        color: #000;
        margin-bottom: 0.8em;
    }

    .s03_inr_box {
        display: flex;
        gap: 46px;
        margin-bottom: 30px;
    }

    .s03_inr_box a {
        width: 80%;
        background: #fff;
        text-align: center;
        text-decoration: none;
        color: #222;
        font-weight: bold;
        max-width: 477px;
        padding: 1em;
        border-radius: 10px;
        box-shadow: 0px 10px 0px rgba(0, 0, 0, 0.2);
        font-size: clamp(14px, 1.4vw, 20px);
        display: flex;
        align-items: center;
        justify-content: center;
    }


    .s03_inr_box a.mizumawari {
        color: #3984BC !important;
    }

    .s03_inr_box a.aircon {
        color: #D93A49 !important;
    }


    img.link_ico {
        filter: drop-shadow(4px 4px 8px rgba(0, 0, 0, 0.4));
    }

    p.s03_inr_txt {
        font-size: clamp(18px, 1.8vw, 30px);
        text-align: center;
        margin-bottom: 1em;
    }




    .footer_inr {
        width: fit-content;
        max-width: 1000px;
        margin: 0 auto;
        display: grid;
        grid-template-columns: repeat(3, auto);
        align-items: center;
        grid-gap: 60px;
        height: 96px;
    }

    a.footer_link {
        text-decoration: none;
        font-size: clamp(14px, 1.2vw, 20px);
        color: #333333;
        position: relative;
        font-weight: 300;
    }

    a.footer_link::after {
        content: "";
        width: 0;
        height: 0;
        border: solid 4px #80B7D9;
        border-left: solid 4px transparent;
        border-bottom: solid 4px transparent;
        display: inline-block;
        position: absolute;
        top: 54%;
        right: -0.8em;
        transform: translateY(-50%) rotate(45deg);
    }

    .copyright {
        font-size: 12px;
        padding: 8px;
        text-align: center;
    }





    .pc_none {
        display: none;
    }



}
