@font-face {
    font-family: "Medio";
    src:url("../font/medio.otf") format("opentype");
}

@font-face {
    font-family: "Trajan";
    src:url("../font/TrajanPro-Bold.otf") format("opentype");
}

@font-face {
    font-family: "Ryumin";
    src:url("../font/A-OTF-RyuminPr5-Regular.otf") format("opentype");
}

@font-face {
    font-family: "Matisse";
    src:url("../font/FOT-MatisseElegantoPro-M.otf") format("opentype");
}

@font-face {
    font-family: "Futura";
    src: url('../font/futura_medium_bt.ttf') format('truetype');
}

@media screen and (min-width: 501px) {
    #registration_sp {
        display: none;
    }

}

@media screen and (max-width: 500px) {
    #registration_pc {
        display: none;
    }

}

.test {

}

#registration_pc {
    overflow-x: hidden;
    overflow-y: hidden;
}

#registration_sp {
    width: 100%;
    overflow-x: hidden;
    visibility: hidden;
}

body {
    font-family: ten-mincho, serif;
    background: #FDF9EF 0% 0% no-repeat padding-box;

}

header {
    background: none;
    letter-spacing: 0px;
    color: #FFFFFF;
    display: flex;
    padding: 20px 50px;
    justify-content: space-between;
    /* background-image: url(../img/bg_header.png); */
    position: fixed;
    width: 100%;
    z-index: 5000;
    background: #FDF9EF 0% 0% no-repeat padding-box;
}
.header_menu {
    display: flex;
    align-items: center;
    gap: .5rem;
}
.header_margin {
    margin-top:110px;
}
.header_logo_img {
    display: block;
    position: relative;
    top: 0px;
    width: 325px;
}
.header_btn {
    width: 220px;
}
.header_logo {
    margin: auto;
    position: relative;
    margin-left: 0px;
}
.header_logo_sp {
    margin: auto;
}

.tel_btn_pc {
    width: 384px;
    position: relative;
    left: -3px;
}
.top_bg1 {
    position: relative;
    width: 100%;
    padding-top: 51.25%; /* 984px ÷ 1920px = 0.5125 */
    background-image: url(../img/top_bg1.png);
    background-position: center;
    background-size: cover;
}

.top_bg1::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}
.top1_text {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font: normal normal normal 40px/70px Ten Mincho;
    letter-spacing: 0px;
    color: #000;
    text-shadow: 1px 2px 3px #000000;
    margin: auto;
    padding-top: 80px;
}
.top1_contact {
    display: block;
}
.top1_left {
    display: inline-block;
    margin-left: 30px;
    position: fixed;
    bottom: 7vh;
    width: 380px;
    height: 200px;
    z-index: 6000;
}
.top1_flex {
    display: flex;
    justify-content: space-between;
}
.top1_right {
    font: normal normal normal 16px/20px Hiragino Kaku Gothic Pro;
    letter-spacing: 0px;
    color: #FFFFFF;
    margin-right: 30px;
    position: relative;
    top: 30vw;
    width: 380px;
    height: 200px;
}

.top_bg2 {
    width:100%;
    text-align: center;
    font: normal normal normal 18px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #000;
    padding: 100px 0;
}
.amane_img {
    display: block;
    margin: 0 auto 20px;
}
.top2_title {
    text-align: center;
    font: normal normal normal 30px/35px Ten Mincho;
    letter-spacing: 0px;
    margin-bottom: 50px;
}
.top2_youtube_text {
    font: normal normal normal 20px/25px Kozuka Gothic Pr6N;
    letter-spacing: 0px;
    color: #000000;
    width: 800px;
    margin: auto;
    text-align: left;
}
.top2_text1 {
    width: 990px;
    text-align: left;
    display: block;
    margin: 40px auto;
    font: normal normal normal 25px/30px Ten Mincho;
}

.top2_text2 {
    font: normal normal normal 25px/30px Ten Mincho;
    text-align: center;
    display: block;
}
.top2_pet_title1 {
    text-align: center;
    font: normal normal bold 35px/35px Kozuka Gothic Pr6N;
    letter-spacing: 3.5px;
    color: #000000;
    text-shadow: 0px 0px 5px #FFBB00;
    margin-top: 100px;
}

.top2_pet_title2 {
    text-align: center;
    font: normal normal normal 35px/40px MinIWA-Hv-V3;
    letter-spacing: 0px;
    color: #000000;
    margin-bottom: 15px;
}
.top2_photo {
    background-image: url(../img/top2_photo.png);
    width:100%;
    height: 450px;
    background-position: right;
    background-repeat: no-repeat;

}

.top_bg_black {
    background: #131313 0% 0% no-repeat padding-box;
    text-align: center;
    font: normal normal normal 30px/35px Ten Mincho;
    letter-spacing: 0px;
    color: #FFFFFF;
    padding:120px 0;
    top: -3px;
    position: relative;
}

.top_bg3 {
    background-image: url(../img/top_bg3.png);
    width:100%;
    height: 35vw;
    background-position: center;
    background-size: cover;
    min-height: 580px;
}
.top3_img {
    width:100%;
    display: block;
    position: relative;
}
.top3_text {
    font: normal normal normal 16px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #000000;
    width: 1000px;
    margin: auto;
    position: relative;
    top: -80px;
}

.top_bg4 {
    background-image: url(../img/top_bg4.png);
    width:100%;
    background-position: center;
    background-size: cover;
    padding: 100px 0;
}
.top4_img {
    width:400px;
    display: block;
    margin: auto;
}

.top4_text {
    text-align: center;
    font: normal normal normal 20px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #231815;
    margin-top: 20px;
}
.top4_list {
    width:1000px;
    display: block;
    margin: 50px auto;
}
.top4_contact {
    display: inline-block;
    min-width: 490px;
    background-color: #4E322B;
    color: #FFFFFF;
    font-size: 25px;
    padding: 1.5rem 0;
}
.top4_contact:hover {
    text-decoration: none;
    color: #FFFFFF;
}
.top_bg5 {
    background-image: url(../img/top_bg5.png);
    background-repeat: no-repeat;
    background-size: cover;
    width:100%;
    padding-bottom: 100px;
}
.top5_box {
    width: 1000px;
    margin:auto;
}
.top5_title {
    font: normal normal normal 30px/34px MinIWA-Hv-V3;
    letter-spacing: 0px;
    color: #986C15;
    text-shadow: 0px 3px 4px #00000073;
    opacity: 1;
    padding-top: 70px;
}
.top5_flex {
    display: flex;
    width: 100%;
    justify-content: space-between;
    margin-top: 30px;
}
.top5_img {
    display: block;
    width: 230px;
    height: 230px;
}
.top5_text {
    text-align: center;
    font: normal normal normal 16px/34px Ten Mincho;
    letter-spacing: 0px;
    color: #000000;
}

.top_bg_black2 {
    font: normal normal normal 30px/35px Ten Mincho;
    letter-spacing: 0px;
    color: #FFFFFF;
    padding:120px 0;
    top: -3px;
    position: relative;
}

.henson_img {
    width:100%;
    margin-bottom: 100px;
    display: block;
}

.other_bg {
    background-image: url(../img/other_bg.png);
    width:100%;
    background-size: 100vw;
    padding: 100px 0;
}

.other_title {
    width:320px;
    margin-left:45%;
}
.other_img {
    display: block;
    width: 270px;
    height: 270px;
}
.other_big {
    text-align: center;
    font: normal normal normal 30px/34px MinIWA-Hv-V3;
    letter-spacing: 0px;
    color: #000000;
    margin-bottom: 40px;
}

.top_flower {
    position: absolute;
    top: -40px;
    left: -100px;
}
.top_flower2 {
    position: relative;
    top: -950px;
    right: -59vw;
    left: auto;
}
.top_black_title {
    width:600px;
    margin: auto;
    display: block;
}
.ma_flex {
    display: flex;
    width:1000px;
    margin:0 auto 50px;
    justify-content: space-between;
    align-items: start;
}
.ma_title {
    width:260px;
    display: block;
    margin: 0px auto 20px 29%;
}
.ma_text {
    text-align: left;
    font: normal normal normal 16px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #000;
    width: 400px;
}
.ma_text_flex {
    display: flex;
    width: 400px;
    text-align: left;
    justify-content: space-between;
    margin-top: 30px;
}
.ma_right_text {
    text-align: right;
    display: flex;
    justify-content: flex-end;
    align-items: start;
}
.ma_price_text {
    font-size: 20px;
}
.ma_price_text span {
    font-size: 36px;
}
.pet_line {
    width: 90px;
}
.ma_btn {
    width: 270px;
    border-radius: 10px;
    display: block;
    margin: 20px auto 0;
}
.ma_img {
    width:550px;
}
.ma_price {
    text-align: right;
    padding-top: 30px;
}
.ma_map {
    margin: 100px auto ;
    width:1000px;
    display: block;
}


.top8_box {
    background: #FFFFFF 0% 0% no-repeat padding-box;
    border-radius: 8px;
    padding:20px;
    font: normal normal normal 18px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #000000;
    width: 700px;
    margin: 20px auto;
}
.top8_age {
    color: #986C15;
    margin-top: 20px;

}


.top_bg6 {
    background-image: url(../img/top_bg6.png);
    width: 100%;
    background-position: center;
    background-size: cover;
    font: normal normal normal 20px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #000000;
    padding: 100px 0;
    text-align: center;
}
.top6_title {
    display: block;
    margin: 0 auto 3rem;
    padding-left: 10rem;
}
.top6_text_wrapper {
    max-width: 1100px;
    margin: auto;
    text-align: left;
}
.top6_text1 {
    font: normal normal normal 1.5vw/2vw Ten Mincho;
    letter-spacing: 0px;
    color: #000000;
    margin-bottom: 15px;
}
.top6_text2 {
    font: normal normal normal 1.5vw/2vw Ten Mincho;
    letter-spacing: 0px;
    color: #D11F1F;
    margin-bottom: 50px;
}

.top_bg7 {
    background-image: url(../img/top_bg7.png);
    width:100%;
    background-position: center;
    background-size: cover;
    min-height: 510px;
    position: relative;
    top: -1px;
    margin: 0 0 70px 0;
}
.top7_title {
    margin: auto;
    display: block;
    width: 100%
}

.top_bg8 {
    background-image: url(../img/top_bg8.png);
    height: 1200px;
    background-position: center;
    background-size: cover;
    position: relative;
    top: -2px;
    padding-top: 100px;
}
.top_bg9 {
    width:100%;
    /* height: 1300px; */
    background-position: center;
    background-size: cover;
    position: relative;
    top: -2px;
    padding-top: 100px;
    padding-bottom: 100px;
}
.mail_comp {
    background-image: url(../img/top_bg8.png);
    width:100%;
    height: 500px;
    background-position: center;
    background-size: cover;
    position: relative;
    top: -2px;
    padding-top: 150px;
    font-size: 35px;
    text-align: center;
}
.error_message{
    height: 50px;
    color: red;
    text-align: center;
    font-size: 20px;
}
.top8_title {
    margin: 0 auto 30px 42%;
    display: block;
    width: 400px;
}
.contact_div {
    width:700px;
    margin: 5px auto 20px;
}
.contact_name {
    font: normal normal normal 16px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #000000;
    margin-bottom: 5px;
}
.contact_text {
    border: none;
    height: 40px;
    width: 100%;
    padding: 10px;
}
.contact_textarea {
    border: none;
    height: 200px;
    width: 100%;
    padding: 10px;

}
.send_btn, .send_btn:hover {
    background: #000000 0% 0% no-repeat padding-box;
    padding:20px;
    width:250px;
    text-align: center;
    font: normal normal normal 30px/25px Ten Mincho;
    letter-spacing: 0px;
    color: #FFFFFF;
    display: block;
    margin: auto;
    text-decoration: none;
    border-radius: 8px;
}


footer {
    letter-spacing: 0px;
    color: #000;
    padding-top: 120px;
    padding-bottom: 20px;
    background-image: url(../img/footer_bg.png);
    width:100%;
    background-size: cover;
}
.footer_title {
    font: normal normal normal 30px/35px Ten Mincho;
    letter-spacing: 0px;
    color: #000;
    margin-bottom: 50px;
    text-align: center;
}
.footer_title2 {
    font: normal normal normal 20px/35px Ten Mincho;
    letter-spacing: 0px;
    color: #000;
    margin: 0 auto 20px;
    width: 280px;
}
.footer_text1 {
    font: normal normal normal 16px/20px Ten Mincho;
    letter-spacing: 0px;
    color: #000;
    margin: 0 auto 20px;
    width: 280px;
}
.footer_logo {
    width: 250px;
    margin: 50px auto 30px;
    display: block;
}
.copyright {
    text-align: center;
    font: normal normal normal 12px/35px Ten Mincho;
    letter-spacing: 0px;
    color: #000;
}


@media screen and (max-width: 500px) {
    header {
        background-position: center;
        background-size: cover;
        height: 70px;
        padding: 10px;
        background: transparent linear-gradient(180deg, #FDF9EF 0%, #FDF9EF00 100%) 0% 0% no-repeat padding-box;
    }
    .header_menu {
        display: inline;
    }
    .header_margin {
        margin-top: 70px;
    }
    .top1_sp {
        width:100%;
        display: block;
    }
    .sp_fixed_left {
        font: normal normal normal 15px/30px Hiragino Kaku Gothic Pro;
        letter-spacing: 0px;
        color: #FFFFFF;
        text-shadow: 1px 1px 2px #000000;
    }
    .top1_left {
        margin: 0;
        padding: 5px 3%;
        position: fixed;
        bottom: 0;
        width: 100%;
        height: auto;
        z-index: 6000;
        display: flex;
        justify-content: space-between;
        background: #FDF9EF 0% 0% no-repeat padding-box;
        flex-direction: column;
        align-items: center;
        gap: .5rem;
    }
    .top1_left2 {
        margin: 0 3%;
        position: fixed;
        bottom: 5vw;
        width: 94%;
        height: auto;
        z-index: 6000;
        display: flex;
        justify-content: space-between;
        font: normal normal normal 15px/30px Hiragino Kaku Gothic Pro;
        letter-spacing: 0px;
        color: #FFFFFF;
        text-shadow: 1px 1px 2px #000000;
    }
    .top1_text {
        font: normal normal normal 29px/40px Ten Mincho;
        padding-top: 50px;
    }
    .top1_right {
        font: normal normal normal 12px/16px Hiragino Kaku Gothic Pro;
        letter-spacing: 0px;
        color: #FFFFFF;
        margin-right: 20px;
        margin-left: auto;
        position: relative;
        top: 8vw;
        width: 210px;
        height: 200px;
    }
    .top_bg2 {
        width: 100%;
        background-position: center;
        background-size: cover;
        text-align: center;
        font: normal normal normal 14px/25px Ten Mincho;
        letter-spacing: 0px;
        padding-top: 50px;
    }
    .top2_title {
        text-align: center;
        font: normal normal normal 20px/35px Ten Mincho;
        letter-spacing: 0px;
        margin-bottom: 20px;
    }
    .top2_youtube_text {
        font: normal normal normal 10px/15px Kozuka Gothic Pr6N;
        letter-spacing: 0px;
        color: #000000;
        width: 350px;
        margin: auto;
        text-align: left;
    }
    .top2_text {
        width: 350px;
        margin: 30px auto;
        text-align: left;
    }
    .top2_pet_title1 {
        text-align: center;
        font: normal normal normal 20px/25px Kozuka Gothic Pr6N;
        letter-spacing: 2px;
        color: #000000;
        text-shadow: 0px 0px 5px #FFBB00;
        margin-top: 60px;
    }
    .top2_text1 {
        width: 350px;
        text-align: left;
        display: block;
        margin: 40px auto;
        font: normal normal normal 14px/20px Ten Mincho;
    }
    .top2_pet_title2 {
        text-align: left;
        margin-bottom: 0;
        margin-left:20px;
        width:360px;
        font: normal normal normal 20px/30px MinIWA-Hv-V3;
        letter-spacing: 0px;
        color: #000000;
        text-shadow: 0px 2px 3px #FFFFFF;
    }
    .top2_text2 {
        width: 350px;
        text-align: center;
        display: block;
        margin: 20px auto;
        font: normal normal normal 14px/20px Ten Mincho;
    }
    .top2_photo {
        background-image: url(../img/top2_photo.png);
        width: 100%;
        height: 450px;
        background-position: 150% 60%;
        background-repeat: no-repeat;
        background-size: 250px;
    }
    .top_bg4 {
        padding-top: 50px;
    }
    .top4_img {
        width: 250px;
    }
    .top4_text {
        font: normal normal normal 14px/20px Ten Mincho;
    }
    .top4_list {
        width:350px;
    }
    .top4_contact {
        display: flex;
        justify-content: center;
        min-width: 350px;
        background-color: unset;
        color: #FFFFFF;
        padding: .5rem 0;
    }
    .top_bg6 .top4_contact {
        background-color: #4E322B;
    }
    .nokotsu_bg1 {
        background-image: url(../img/nokotsu_bg1.png);
        width: 100%;
        height: 480px;
        background-position: 100% 0%;
        background-repeat: no-repeat;
    }
    .nokotsu_div {
        margin: auto;
        padding: 20px 0;
        width:350px;
        font: normal normal normal 14px/20px Ten Mincho;
        letter-spacing: 0px;
        color: #000000;
    }
    .nokotsu_title {
        font: normal normal normal 20px/25px MinIWA-Hv-V3;
        letter-spacing: 0px;
        color: #986C15;
        text-shadow: 0px 3px 4px #00000073;
        margin-bottom: 15px;
    }
    .nokotsu_img {
        width: 100%;
        margin-bottom: 10px;
        display: block;
    }
    .nokotsu_bg2 {
        background-image: url(../img/nokotsu_bg2.png);
        width: 100%;
        height: 480px;
        background-position: 100% 100%;
        background-repeat: no-repeat;
        background-size: contain;
    }

    .top_black_title {
        width: 350px;
    }

    .top_bg_black {
        background: #131313 0% 0% no-repeat padding-box;
        text-align: center;
        font: normal normal normal 26px/35px Ten Mincho;
        letter-spacing: 0px;
        color: #FFFFFF;
        padding: 50px 0 80px;
        top: -3px;
        position: relative;
    }

    .top_bg5 {
        background-image: url(../img/top_bg5_sp.png);
        width: 100%;
        height: 38vw;
        background-position: center;
        background-size: cover;
        min-height: 260px;
        text-align: right;
        padding-top: 10vw;
        padding-right: 6vw;
    }
    .top5_title {
        font: normal normal normal 20px/25px Ten Mincho;
        letter-spacing: 0px;
        color: #FFFFFF;
        text-shadow: 1px 1px 2px #000000;
        margin-bottom: 10px;
    }
    .top5_text {
        font: normal normal normal 14px/20px Ten Mincho;
        letter-spacing: 0px;
        color: #FFFFFF;
        text-shadow: 1px 1px 2px #000000;
    }
    .top_bg_black2 {
        font: normal normal normal 30px/35px Ten Mincho;
        letter-spacing: 0px;
        color: #FFFFFF;
        padding: 50px 0;
        top: -3px;
        position: relative;
        height: auto;
    }

    .ma_img {
        width: 100%;
        margin: auto;
        display: block;
    }
    .ma_title {
        width: 150px;
        display: block;
        margin: 20px auto 10px 39%;
    }
    .ma_text {
        text-align: left;
        font: normal normal normal 14px/20px Ten Mincho;
        letter-spacing: 0px;
        color: #000;
        margin-bottom: 30px;
        width: 350px;
        margin: 30px auto;
    }
    .ma_text a {
        color:#000;
        text-decoration: underline;
    }
    .ma_price {
        padding-top: 20px;
        padding-right: 20px;
    }
    .ma_text_flex {
        display: flex;
        width: 280px;
        text-align: left;
        margin: auto;
        justify-content: space-between;
    }
    .ma_btn {
        width: 180px;
        margin-top: 10px;
    }
    .ma_right_text {
        text-align: right;
        margin-top: 25px;
        display: flex;
        justify-content: end;
    }
    .ma_price_text {
        font-size: 14px;
        margin-bottom: 10px;
        padding-top: 0px;
    }
    .ma_price_text span {
        font-size: 25px;
    }
    .top_bg6 {
        background-image: url(../img/top_bg6.png);
        width: 100%;
        background-position: right;
        background-size: cover;
        font: normal normal normal 20px/25px Ten Mincho;
        letter-spacing: 0px;
        color: #000000;
        padding: 50px 10px 50px 10px;
    }
    .top6_text1 {
        letter-spacing: 0px;
        color: #000000;
        margin-bottom: 5px;
        font: normal normal normal 13px/18px Ten Mincho;
        padding-left: 1em;
        text-indent: -1.8em;
        width: 335px;
        margin: 5px auto;
    }
    .top6_text2 {
        font: normal normal normal 13px/18px Ten Mincho;
        padding-left: 1em;
        text-indent: -1.8em;
        letter-spacing: 0px;
        color: #D11F1F;
        margin-bottom: 10px;
        width: 335px;
        margin: 10px auto;
    }
    .top6_title {
        display: block;
        margin: 10px auto;
        padding: 0;
        width: 220px;
    }
    .henson_text_div {
        font: normal normal normal 14px/20px Ten Mincho;
        letter-spacing: 0px;
        color: #000000;
        width: 350px;
        margin:10px auto;
    }
    .henson_img {
        margin-bottom: 0px;
    }

    .top_bg7 {
        background-image: url(../img/top_bg7_sp.png);
        width: 100%;
        height: 28vw;
        background-position: center;
        background-size: cover;
        min-height: 370px;
        position: relative;
        top: -1px;
        margin: 70px 0 0;
    }
    .top7_title {
        margin: auto;
        display: block;
        width: 100%
    ;
    }
    .other_bg {
        padding-top: 50px;
    }
    .other_title {
        width: 200px;
        margin-left: 35%;
    }
    .other_big {
        margin-top: 30px;
        margin-bottom: 30px;
        font: normal normal normal 18px/22px MinIWA-Hv-V3;
    }
    .other_img {
        width: 350px;
        margin:auto;
        height: auto;
    }
    .top8_title {
        margin: 0px auto 30px 30%;
        display: block;
        width: 200px;
    }

    .top_bg9 {
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .contact_div {
        width: 350px;
        margin: 5px auto 20px;
    }
    .contact_text, .contact_textarea {
        border: 1px solid #707070;
    }
    .send_btn, .send_btn:hover {
        background: #000000 0% 0% no-repeat padding-box;
        padding: 10px;
        width: 350px;
        text-align: center;
        font: normal normal normal 20px/25px Ten Mincho;
        letter-spacing: 0px;
        color: #FFFFFF;
        display: block;
        margin: auto;
        text-decoration: none;
    }
    .top_bg8 {
        background-image: url(../img/top_bg8.png);
        width: 100%;
        height: 1200px;
        background-position: center;
        background-size: cover;
        position: relative;
        top: -2px;
        padding-top: 50px;
    }
    footer {
        background: #F1EBDC;
        letter-spacing: 0px;
        color: #000;
        padding-top: 50px;
        padding-bottom: 20px;
        background-image: url(../img/footer_bg_sp.png);
        width: 100%;
        height: 520px;
        background-size: auto;
        margin-bottom: 50px;
    }
    .footer_title {
        font: normal normal normal 20px/35px Ten Mincho;
        letter-spacing: 0px;
        color: #000;
        margin-bottom: 10px;
        text-align: center;
    }
    .footer_title2 {
        font: normal normal normal 16px/35px Ten Mincho;
        letter-spacing: 0px;
        color: #000;
        margin: 0 auto 10px;
        width: 250px;
    }
    .footer_text1 {
        font: normal normal normal 14px/20px Ten Mincho;
        letter-spacing: 0px;
        color: #000;
        margin: 0 auto 20px;
        width: 250px;
    }
    .footer_logo {
        width: 180px;
        margin: 30px auto 10px;
        display: block;
    }
    .mail_comp {
        background-image: url(../img/top_bg8.png);
        width: 100%;
        height: 200px;
        background-position: center;
        background-size: cover;
        position: relative;
        top: -2px;
        padding-top: 80px;
        font-size: 17px;
        text-align: center;
    }
}

.g-recaptcha {
    width: 300px;
    margin-right: auto;
    margin-left: auto;
}

.grecaptcha-badge { visibility: hidden; }


/*ポップアップ */
.popup_bg {
    position: fixed; /* ブラウザの定位置に固定 */
	background: rgba(0, 0, 0, .5); /* 背景色を半透明の黒色に */
	width: 100%; /* 要素の横幅を画面全体に */
	height: 100%; /* 要素の高さを画面全体に */
	top: 0; /* 要素の固定位置をブラウザ最上部に合わせる */
	left: 0; /* 要素の固定位置をブラウザ左側に合わせる */
	z-index: 8000; /* 要素をコンテンツより前面に（要調整） */
    transition: 0.5s;
    opacity: 0;
}
.sample_popup_content {
	/* ポップアップ本体 */
	display: inline-block;
	position: fixed;
    width: 62vw;
    height: 43vw;
    z-index: 9000;
    background-image: url(../img/popup_bg.png);
    background-position: 0px 0vw;
    background-size: cover;
	padding: 1vw 1vw 10%;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	overflow-y: scroll;
    font: normal normal normal 20px/30px Hiragino Kaku Gothic Pro;
    color: #000;
    border-radius: 2vw;
    overflow: hidden;
}

.popup_close_btn {
    display: inline-block;
    color:#000;
    font: normal normal normal 25px/25px Hiragino Kaku Gothic Pro;
    float: right;
    position: relative;
    width: 5vw;
    cursor: pointer;
}

.popup_title {
    display: block;
    margin: 2vw auto 0 9vw;
    width: 44vw;
}

.popup_text {
    text-align: center;
    font: normal normal normal 1.4vw/2.2vw MinIWA-Hv-V3;
    margin-top: 4.5vw;
    text-shadow: 0px 3px 6px #00000029;
}

.popup_red_text {
    text-align: center;
    font: normal normal normal 2.6vw/3.5vw MinIWA-Hv-V3;
    margin-top: 5.7vw;
    letter-spacing: 0.1vw;
    color: #E10000;
    margin-left: 22.5vw;
    width: 35vw;
}

.popup_text2 {
    text-align: center;
    font: normal normal normal 1.2vw/2.6vw MinIWA-Hv-V3;
    margin-top: 2.5vw;
    width: 30vw;
    margin-left: 23.8vw;
}
.popup_text2 span {
    font: normal normal normal 2vw/2.6vw MinIWA-Hv-V3;
    color: #E10000;
}

.popup_btn {
    width: 30vw;
    margin-left: 24.5vw;
    margin-top: 0.5vw;
}

.policy_a {
    color: #000;
    display: table;
    margin: 10px auto;
    text-decoration: underline;
}

@media screen and (max-width: 500px) {
    .sample_popup_content_sp {
        display: inline-block;
        position: fixed;
        width: 90vw;
        height: 155vw;
        z-index: 9000;
        background-image: url(../img/popup_bg_sp.png);
        background-position: center;
        background-size: cover;
        padding: 3vw 3vw 10%;
        top: 48%;
        left: 50%;
        transform: translate(-50%,-50%);
        overflow-y: scroll;
        font: normal normal normal 20px/30px Hiragino Kaku Gothic Pro;
        color: #000;
        border-radius: 2vw;
        overflow: hidden;

    }

    .popup_close_btn {
        display: inline-block;
        color: #000;
        font: normal normal normal 25px/25px Hiragino Kaku Gothic Pro;
        float: right;
        position: relative;
        width: 12vw;
        cursor: pointer;
    }

    .popup_text {
        text-align: center;
        font: normal normal normal 3.6vw/5.4vw MinIWA-Hv-V3;
        margin-top: 39vw;
        text-shadow: 0px 3px 6px #00000029;
        letter-spacing: 0.1vw;
    }

    .popup_red_text {
        text-align: center;
        font: normal normal normal 4.5vw/6vw MinIWA-Hv-V3;
        margin-top: 21vw;
        letter-spacing: 0.05vw;
        color: #E10000;
        margin-left: 38.8vw;
        width: 40vw;
    }

    .popup_text2 {
        text-align: center;
        font: normal normal normal 4.8vw/8.2vw MinIWA-Hv-V3;
        margin-top: 20vw;
        width: 100%;
        margin-left: 0;
    }
    .popup_text2 span {
        font: normal normal normal 7.5vw/8.2vw MinIWA-Hv-V3;
        color: #E10000;
        margin-left: 6vw;
    }
    .popup_btn {
        width: 100%;
        margin: 3vw auto 0;
    }


}

/* 20240827追加分 */
.top_bg4_text {
    max-width: 680px;
    margin: auto;
    font-weight: bold;
    padding-bottom: 2rem;
}

.top_bg4_text p:nth-child(1) {
    font-size: 20px;
}

.top_bg4_text p:nth-child(2) {
    font-size: 25px;
    margin-bottom: 0;
}

.top_bg4_text p:nth-child(2) span {
    color: #B10002;
}

.top_bg4_text p:nth-child(3) {
    font-size: 20px;
}

.top_bg4_text p:nth-child(3) span {
    color: #B10002;
    font-size: 35px;
}

.request_information {
    display: block;
    width: 490px;
    background-color: #000000;
    color: #FFFFFF;
    font-size: 25px;
    margin: auto;
    padding: 1.5rem 0;
    text-align: center;
}

.request_information:hover {
    text-decoration: none;
    color: #FFFFFF;
}

.customer_comments {
    background-image: url("../img/customer_comments_bg.png");
    background-repeat: no-repeat;
    background-size: cover;
    text-align: center;
    padding: 100px 0;
}
.customer_comments_text.text1 {
    margin-bottom: 3rem;
}

.header_btn_wrapper {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

@media screen and (max-width: 500px) {
    .top_bg4_text {
        display: flex;
        justify-content: center;
    }
}

/* 20240924追記分 */
.info_tv {
    width: 1080px;
    margin: auto;
    padding: 100px 40px 100px;
    text-align: center;
}

img.info_tv-header {
    display:block;
    width: 100%;
    margin-bottom: 3rem;
}

.info_tv p.info_tv-title {
    font-size: 3rem;
    display: flex;
    align-items: center;
}

.info_tv h3.info_tv-title {
    font-size: 3rem;
    display: flex;
    align-items: center;
    margin-bottom: 3rem;
}

.info_tv-detail-img {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(1, 1fr);
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    margin-bottom: 2rem;
}

.info_tv-detail-text {
    margin-bottom: 2rem;
}

.info_tv-detail-text h3 {
    font-size: 2rem;
    margin-bottom: 1rem;
}

.info_tv-detail-text p {
    font-size: 1.25rem;
}

.info_tv-campaign p:nth-child(1) {
    font-size: 1.25rem;
}

.info_tv-campaign p:nth-child(2) {
    color: #986C15;
    font-size: 1.25rem;
    margin-bottom: 1rem;
}

.info_tv-campaign p:nth-child(3) {
    width: 70%;
    color: #fff;
    font-size: 2rem;
    line-height: 3rem;
    background-color: #B10002;
    margin: 0 auto 2rem;
}

.info_tv-campaign p:nth-child(4) {
    font-size: 3rem;
}

.info_tv-campaign img {
    display: block;
    margin: 40px auto;
}

.info_tv-campaign p:last-child {
    font-size: 1.25rem;
}

@media screen and (max-width: 500px) {
    .info_tv {
        width: 90%;
        margin: auto;
        padding: 40px 0;
    }

    .info_tv-title-wrapper {
        width: 90%;
        margin: auto;
    }

    .info_tv p.info_tv-title {
        font-size: 1.125rem;
        display: flex;
        align-items: center;
    }

    .info_tv p.info_tv-title img {
        width: 100px;
    }

    .info_tv h3.info_tv-title {
        display: block;
        text-align: left;
        font-size: 1.125rem;
        margin-bottom: 1.5rem;
    }

    .info_tv-detail {
        width: 100%;
        margin: auto;
        padding-bottom: 2rem;
    }

    .info_tv-detail-text {
        margin: 1.5rem 0 0;
    }

    .info_tv-detail-text h3 {
        font-size: 1.75rem;
        margin-bottom: 1rem;
    }

    .info_tv-detail-text p {
        font-size: 1rem;
        text-align: left;
    }

    .info_tv-campaign p:nth-child(1) {
        font-size: 1rem;
        text-align: left;
    }

    .info_tv-campaign p:nth-child(2) {
        color: #986C15;
        font-size: 1.25rem;
        margin-bottom: 1rem;
    }

    .info_tv-campaign p:nth-child(3) {
        width: 100%;
        color: #fff;
        font-size: 1.5rem;
        background-color: #B10002;
        margin: 0 auto 2rem;
    }

    .info_tv-campaign p:nth-child(4) {
        font-size: 1.75rem;
    }

    .info_tv-campaign img {
        display: block;
        width: 100%;
        margin: 40px auto;
    }

    .info_tv-campaign p:last-child {
        font-size: .85rem;
    }
}

