@charset "UTF-8";



html {
    font-size: 100%;
    visibility: hidden;
}

html.wf-active {
    visibility: visible;
}

body {
    font-size: large;
    background: url(../images/bg.jpg);
    line-height: 1.7;
    font-family: "hiragino-kaku-gothic-pron", sans-serif;
    font-weight: 300;
    font-style: normal;
    color: #45331d;
}

.load-fade {
    opacity: 0;
    visibility: hidden;
    transition: all 1s;
}

.load-fade.is-show {
    opacity: 1;
    visibility: visible;
}


/* aタグの.class以外適用 */
a:not(.moushikomi) {
    text-decoration: none;
}

p {
    margin-bottom: 2rem;
}

img {
    max-width: 100%;
}

.pctop {
    display: none;
}

.title {
    text-align: center;
    margin-top: 1rem;
    color: #45331d;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-weight: 700;
    font-style: normal;
    margin-bottom: 1.3rem;
    position: relative;


}

.title::before {
    background: url(../images/layered-waves-haikei.png);
    display: block;
    content: "";
    position: absolute;
    width: 100%;
    height: 250%;
    top: -55%;
    background-repeat: no-repeat;
}

.wrapper:not(.bana) {
    margin: 0 auto;
    padding: 0 4%;

}



.header-boader {
    margin-bottom: 1.5rem;

}

.atype {
    font-size: 1.5rem;
    margin-top: 2rem;
    margin-bottom: 1rem;
    margin-left: 0.5rem;
    position: relative;
    text-align: center;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-weight: 700;
    font-style: normal;
    display: block;
}

.atype::before {
    display: block;
    content: "";
    width: 98%;
    height: 25px;
    background-color: rgba(255, 208, 0, 0.432);
    position: absolute;
    bottom: 15.5%;
    left: 0%;
    border-radius: 10px;
    z-index: -1;

}

.syoua {
    font-size: 1rem;
}

.aspan {
    background: linear-gradient(transparent 60%, rgba(255, 208, 0, 0.432) 60%);
    white-space: nowrap;
}

.sdouga {
    font-size: 1.4rem;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    margin-bottom: 0.5rem;
}

.sdouga::after {
    background-image: url(../images/nuriashi_3.svg);
    width: 1.8rem;
    height: 1.8rem;
    content: "";
    display: inline-block;
    margin-left: 1rem;
    margin-bottom: -0.3rem;

}

.sdouga::before {
    background-image: url(../images/nuriashi_3.svg);
    width: 1.8rem;
    height: 1.8rem;
    content: "";
    display: inline-block;
    margin-right: 0.7rem;
    margin-bottom: -0.3rem;
}

.sample {

    text-align: center;
    margin: auto;
}

.vid_main {
    width: 75vw;
    height: auto;
    border-radius: 9px;
}



.dbr {
    display: none;
}

.brd {
    display: inline;
}

.wrapper-w {
    display: flex;
}

.d {
    background: #F2B2A4;
    border-radius: 9px;
}

span.c {

    font-weight: bold;

}

span.s {
    font-weight: bold;
    display: inline-block;
    text-wrap: nowrap;
}


.btype {
    font-size: 1.5rem;
    margin-top: 3.5rem;
    margin-bottom: 1rem;
    margin-left: 0.5rem;
    position: relative;
    text-align: center;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-weight: 700;
    font-style: normal;
}

.btype::before {
    display: block;
    content: "";
    width: 98%;
    height: 25px;
    background-color: #f8b04596;
    position: absolute;
    bottom: 15.5%;
    left: 0%;
    border-radius: 10px;
    z-index: -1;
}

.ctype {
    font-size: 1.5rem;
    margin-top: 3.5rem;
    margin-bottom: 1rem;
    margin-left: 0.5rem;
    position: relative;
    text-align: center;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-weight: 700;
    font-style: normal;

}

.ctype::before {
    display: block;
    content: "";
    width: 98%;
    height: 25px;
    background-color: #f8894596;
    position: absolute;
    bottom: 15.5%;
    left: 0%;
    border-radius: 10px;
    z-index: -1;
}

.bspan {
    background: linear-gradient(transparent 60%, #f8b04596 60%);
    white-space: nowrap;
}

.bana {
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    margin-top: 4rem;
    margin-bottom: -1rem;

}

.title2 {
    font-size: 1.5em;
    margin-top: 4rem;
    color: #000;
    font-weight: bold;
    color: #45331d;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    margin-bottom: 1.5rem;
    padding: 3px 5px;
    text-wrap: nowrap;
    vertical-align: middle;

}

.title2::before {
    background-color: #2eacb0;
    border-radius: 3.5px;
    content: "";
    display: inline-block;
    height: 47px;
    margin-right: 10px;
    margin-left: -5px;
    vertical-align: top;
    width: 6px;
}

/**{
    outline: 2px red solid;
}*/

a.moushikomi {

    color: #F86767;
    cursor: pointer;
    font-weight: bold;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-size: 1.3rem;
}

.zukai {

    margin-bottom: -1rem;
}

.container {
    display: flex;
    display: -webkit-box;
    /* Safari 6.1+ */
    display: -moz-box;
    /* Firefox (buggy but required prefix up to 28) */
    display: -ms-flexbox;
    /* IE 10 */
    display: -webkit-flex;
    gap: 20px;
    align-items: center;
    margin-top: 2rem;
    margin-bottom: 1rem;
    position: relative;
}

.container::after {
    content: "";
    position: absolute;
    width: 10%;
    height: 55%;
    z-index: -1;
    background-repeat: no-repeat;
    background-image: url(../images/nuriashidai11.svg);
    background-position-x: right;
    right: 0;
    top: 120%;
    transform: scale3d(1.5, 1.5, 1.5);
    display: none;
}

.container-content {
    background-color: #fff;
    padding: 1rem;
    border-radius: 9px;
    flex-direction: column;
    display: flex;
    row-gap: 2rem;

}

.disc,
.blu-ray {
    width: 45%;
    display: flex;
    display: -webkit-box;
    /* Safari 6.1+ */
    display: -moz-box;
    /* Firefox (buggy but required prefix up to 28) */
    display: -ms-flexbox;
    /* IE 10 */
    display: -webkit-flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    flex: 1;
    /*もしかしたらiphone6のはこれがきくかも
    -webkit-align-items:center;
    justify-content:space-evenly;*/

}

.disc {
    margin: 0 auto;
    margin-bottom: 2.5rem;
}

.disc::after {
    content: '';
    position: absolute;
    z-index: -1;
    top: 0;
    left: -89.0625%;
    width: 103.59375%;
    height: 345px;
    content: '';
    position: absolute;
    z-index: -1;
    top: 0;
    left: -79.0625%;
    width: 153.59375%;
    height: 166px;


}

/*flexの意味を調べる*/
.pac,
.pac2 {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    width: 10%;
    display: flex;
    display: -webkit-box;
    /* Safari 6.1+ */
    display: -moz-box;
    /* Firefox (buggy but required prefix up to 28) */
    display: -ms-flexbox;
    /* IE 10 */
    display: -webkit-flex;
    justify-content: center;
    align-items: center;
    -webkit-align-items: center;
    text-wrap: nowrap;
    font-size: 1rem;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    color: #45331d;
    /*border-radius: 8px;*/
    /*background: url(../images/bg.jpg); */
    /*border: dashed 4px #2eacb0;*/
    white-space: nowrap;
    /* テキストの折り返しを禁止 */

}

.pac2 {
    height: 20%;
}

img.y1,
.y2 {
    width: 37vw;
    height: auto;
}

/*キャンペーン*/
.B {
    margin-bottom: 6rem;
}

.ne {
    text-decoration: line-through
}

.akaji {
    color: #B74646;
}

.akaji_2 {
    color: #B74646;
    font-size: 13px;
}



/*追加*/

#koe {

    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.card {
    /*font-family: "fot-tsukuardgothic-std", sans-serif;*/
    margin: 0 auto;
    background-color: #fff;
    padding: 2rem 1.5rem 0.5rem 1.5rem;
    border-radius: 38px;
    text-align: justify;
    width: 100%;
    font-family: "hiragino-kaku-gothic-pron", sans-serif;
}



.review {
    position: relative;
    margin-bottom: 3rem;

}

.initials-wrapper {
    position: absolute;
    left: 40%;

}

.initials {
    font-size: 1.3rem;
    font-weight: 600;
    letter-spacing: 3px;
}

.stars {
    color: transparent;
    -webkit-text-stroke: 1px black;
    /*text-stroke: 1px black; */
    position: absolute;
    right: 0;
    margin-top: 0.4rem;
    font-size: 0.9rem;

}

.otext {
    line-height: 1.8;
    margin-top: 3.5rem;
    font-size: 1rem;
}

.star.filled {
    color: #fbee3a;
}


/*よくあるご質問*/

.rotate {
    transform: rotate(180deg);
    /* 下向きから上向きに回転 */
    transition: transform 0.3s ease;
    /*回転アニメーションを追加*/
}


.faq {

    font-family: "fot-tsukuardgothic-std", sans-serif;
    margin: 0 auto;

}

.question {
    margin-bottom: 10px;
}

.question-text {
    font-family: "fot-tsukuardgothic-std", sans-serif;
}

.yokuaru {
    font-family: "fot-tsukuardgothic-std", sans-serif;
    text-align: center;
    font-size: 1.5em;
    margin-top: 3rem;
    margin-bottom: 2rem;
}

.toggle-answer {
    border: none;
    padding: 10px;
    width: 100%;
    text-align: left;
    cursor: pointer;
    outline: none;
    display: flex;
    /* 質問テキストと矢印を横並びにする */
    justify-content: space-between;
    /* 質問テキストと矢印をコンテナの両端に配置 */
    align-items: center;
    /* 質問テキストと矢印を垂直方向に中央揃え */
}

.arrow-wrapper {
    margin-left: auto;
    /* 矢印を右端に配置 */
}

.answer {
    display: none;
    padding: 10px;
    text-align: center;
    font-size: small;
}

.answer p {
    margin: 0;
    font-size: 15px;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    color: #45331dcb;
}

/*お問合せリンク*/
.ybutton {
    color: #F86767;
    text-align: start;
    font-family: "fot-tsukuardgothic-std", sans-serif;
}

p.ys2 {
    margin-top: 5rem;
    margin-bottom: 6rem;
}

p.ys2::before {
    background-image: url(../images/nuriashi_4.svg);
    width: 1.3rem;
    height: 1.5rem;
    content: "";
    display: inline-block;
    margin-right: 0.7rem;
    margin-bottom: -0.3rem;
}

/*固定申し込みボタン*/
a.button {
    color: #fff;
    background: #F86767;
    padding: 15px 25px;
    border-radius: 50px;
    border-bottom: 6px solid #B74646;
    color: #fff;
    text-align: center;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-weight: 700;
    font-style: normal;


}

.mail {
    width: 1.6rem;
    height: 1.2rem;
    margin-left: 2%;
    margin-bottom: -2px;
}

.dainari {
    width: 0.5rem;
    height: 1rem;
    margin-left: 3%;
    vertical-align: -2px;
}

span.p1 {
    text-wrap: nowrap;

}

#ten_1 {
    display: none;
}

.moushikomibutton {
    white-space: nowrap;
    display: flex;
    justify-content: center;
    position: fixed;
    z-index: 99999;
    left: 45%;
    right: 50%;
    top: 87%;
    transform: translateX(-50%) translateY(-50%);

}



p.f {
    margin-bottom: 0rem;
}

footer {
    background: #2eacb0;
    text-align: center;
    padding: 0.7rem 0;


}

footer p {
    color: #fff;
    font-size: 1rem;
}



.video-container {
    position: relative;
    width: 100%;
    height: 90%;
    /* padding-bottom: 56.25%; */    
    aspect-ratio: 16 / 9;    
    padding-bottom: 56.35%;
    /* 16:9アスペクト比 - 古いブラウザ用 */
    border: none;
}

.video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 90%;
    border: 0;
    border: none;
    position: absolute;
    top: 5%;
    left: 5%;
    width: 90%;
    height: 90%;
    border: 0;
    border: none;
    border-radius: 9px;
}

.html5-video-player:not(.ytp-transparent) {
    background-color: #fff;
}


@media (max-width:389px) {
    .video-container{
        padding-bottom: 56.25%;
    }


}


@media (min-width:440px) {

    /* .atype::before,
    .btype::before {
        width: %;
        left: 25%;
    } */


    .header-boader {
        padding: 8px 0;
        border: none;
        line-height: 1.5;

        background-image: url(../images/ten15.svg);
        /*画像URLを指定 */
        background-repeat: repeat-x;
        background-position: left bottom;
        background-size: 28px 5px;
        margin-bottom: 2rem;

    }

    .title::before {
        display: none;
        background-image: url(../images/);
        background-size: 7.3rem;
        background-repeat: no-repeat;
        background-position: left;
        margin-left: 2.5rem;
        top: -3rem;
    }

    .y1 {
        max-width: 65%;
    }

    .y2 {
        max-width: 70%;
    }

    .pac,
    .pac2 {
        font-size: 1.5rem;
    }

    .blu-ray,
    .disc {
        justify-content: space-evenly;
    }

    .vid_main {
        width: 60vw;
        height: auto;
    }

    .moushikomibutton {
        white-space: nowrap;
        display: flex;
        justify-content: center;
        position: fixed;
        z-index: 99999;
        left: 48%;
        right: 50%;
        top: 85%;
        transform: translateX(-50%) translateY(-50%);

    }

    a.button {
        font-size: 1.7rem;
        padding: 10px 15px;
        border-radius: 50px;
        margin-top: 1rem;
    }

    .dainari {
        width: 0.8rem;
        height: auto;
        margin-left: 1rem;
    }

    .mail {
        width: 1.7rem;
        height: 1.5rem;
        vertical-align: 0;
        margin-right: 0.5rem;
    }

    /*追加*/
    .yokuaru {
        font-size: 2rem;
        margin-top: 4rem;
    }

    .initials-wrapper {
        position: absolute;
        left: 45%;

    }

    .stars {
        position: absolute;

    }

    .atype,
    .btype,
    .ctype {
        font-size: 2rem;
    }


}

@media (min-width:600px) {

    .atype::before,
    .btype::before,
    .ctype::before {
        width: 73%;
        left: 15%;
    }

    .indent {
        margin-left: 2rem;
    }

    .brd {
        display: none;
    }
    .bana{
        margin-top: 4.5rem;
    }
}


@media (min-width:1025px) {

    body {
        font-size: 1.2rem;
        width: 100%;
        font-weight: 500;
        line-height: 1.6;
    }

    p {
        margin-bottom: 1.5rem;
    }

    .title {
        font-size: 2.8rem;
        margin-top: 1.5rem;
        margin-bottom: 1.5rem;
    }

    .title::before {
        display: none;
        background-image: url(../images/);
        background-size: 7.3rem;
        background-repeat: no-repeat;
        background-position: left;
        margin-left: 2.5rem;
        top: -3rem;
    }

    .dbr {
        display: none;
    }



    hr {
        margin-bottom: 1rem;
    }

    .container-a {
        border: 2px solid #000;
        box-sizing: border-box;
    }

    .container-content {
        display: flex;
        align-items: center;
        /*border:2px solid #000;*/
        box-sizing: border-box;
        background: #fff;
        border-radius: 9px;
        flex-direction: row;
        column-gap: 2rem;
        padding: 2.5rem;
    }

    .atype {
        margin-top: 5rem;
        font-size: 2.5rem;
        border-radius: 5px;
    }

    .atype::before {
        width: 45%;
        bottom: 15.5%;
        /* 任意 */
        left: 26%;
        height: 28px;
    }

    .syoua {
        font-size: 1.5rem;

    }

    .btype {
        margin-top: 5rem;
        font-size: 2.2rem;
        border-radius: 5px;
    }

    .btype::before {
        width: 45%;
        bottom: 15.5%;
        /* 任意 */
        left: 26%;
        height: 28px;
    }

    .ctype {
        margin-top: 5rem;
        font-size: 2.2rem;
        border-radius: 5px;
    }

    .ctype::before {
        width: 45%;
        bottom: 15.5%;
        /* 任意 */
        left: 26%;
        height: 28px;
    }

    a.moushikomi {
        font-weight: bold;
        font-size: 1.6rem;
    }

    .sdouga {
        font-size: 2rem;
        margin: 1rem;
        color: #45331d;
    }

    .sample {
        margin: 1rem;

        width: 55%;
        text-align: center;
    }

    .vid_main {
        width: 45vw;

    }

    .title2 {
        font-size: 2rem;

    }

    .title2::before {
        height: 50px;
        margin-left: -10px;
        vertical-align: text-top;
        margin-right: 1rem;
    }

    .zukai {
        max-width: 50%;
        margin: 0 auto;
        margin-bottom: -3rem;
    }

    .url {
        font-size: 1.5rem;

    }


    .pac {
        font-size: 2rem;
        margin-right: -3rem;
        /*border: dashed 4px #2eacb0;*/
        width: 10%;
        height: 57%;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        white-space: nowrap;
        /* テキストの折り返しを禁止 */
    }

    .pac2 {
        font-size: 2rem;
        margin-right: -3rem;
        /*border: dashed 4px #2eacb0;*/
        width: 10%;
        height: 37%;

    }

    img.y1,
    .y2 {
        max-width: 50%;
    }

    .container-o {
        margin-top: 6rem;
        margin-bottom: 5rem;
    }

    a.button {
        font-size: 2rem;
        padding: 18px 40px;
        border-radius: 50px;
        margin-top: 1rem;
    }

    .mail {
        width: 2.6rem;
        height: 1.8rem;
        vertical-align: 0;
    }

    .disc {

        margin-bottom: 6rem;
    }


    .disc::after {
        left: -89.0625%;
        width: 183.59375%;
        height: 400px;
        z-index: -6;
        border-radius: 9px;
    }

    .d {
        margin-bottom: 2.5rem;

    }

    .container {
        margin-top: 3rem;
        padding: 60px;
        margin: 0 calc(50% - 50vw);
        width: 100vw;
        background-position: 93%;
        position: relative;
        justify-content: space-evenly;
    }

    .container::after {
        transform: scale3d(1.5, 1.5, 1.5);
        background-image: url(../images/nuriashidai11.svg);
        height: 65%;
        background-position: 0%;
        right: 3rem;
        top: -19rem;
        display: block;
        content: "";
        position: absolute;
        width: 10%;
        z-index: -1;
        background-repeat: no-repeat;
    }

    .header-boader {
        padding: 8px 0;
        border: none;
        line-height: 1.5;

        background-image: url(../images/ten15.svg);
        /*画像URLを指定 */
        background-repeat: repeat-x;
        background-position: left bottom;
        background-size: 28px 5px;
        margin-bottom: 2rem;

    }

    .moushikomibutton {
        white-space: nowrap;
        display: flex;
        justify-content: center;
        position: fixed;
        z-index: 99999;
        left: 48%;
        right: 50%;
        top: 83%;
        transform: translateX(-50%) translateY(-50%);

    }

    .B {
        margin-bottom: 7rem;
    }

    .dainari {
        width: 1rem;
        height: auto;
        margin-left: 1rem;
    }

    footer p {
        font-size: 1.7rem;
    }

    .non {
        display: none;
    }

    .faq {
        font-family: Arial, sans-serif;
        margin: 0 auto;
        padding: 0 28%;
    }

    p.ys,
    p.ys2 {

        font-size: 1.3rem;
    }

    p.ys2 {
        margin-bottom: 13rem;
    }

    p.ys {
        margin-bottom: 1rem;
    }

    .blu-ray,
    .disc {
        justify-content: space-evenly;
    }

    footer.sfooter {
        position: sticky;
        top: 100vh;
        width: 100%;
    }

    .wrapper-f {
        padding: auto;
    }

    .f {
        margin-bottom: 0rem;
    }

    /*追加*/

    #koe {
        display: flex;
        flex-direction: row;
        gap: 1rem;
    }

    .stars {
        position: absolute;

    }

    .initials-wrapper {
        position: absolute;
        left: 38%;

    }

    .yokuaru {
        margin-top: 8rem;
    }

    .video-container {
        position: relative;
        width: 50%;
        /* height: 0; */
        /* padding-bottom: 56.25%; */
        /* aspect-ratio: 16 / 9; */
        padding-bottom: 30.25%;
        /* width: 560px;
        height: 315px; */
        padding-bottom: 3.99%;
        background-color: #fff;

    }

    .video-container iframe {
        position: absolute;
        top: 0;
        left: 0;
        /* width: 100%; */
        /* height: 100%; */
        border: 0;
        border-radius: 9px;


    }

    .html5-video-player:not(.ytp-transparent) {
        background-color: #fff;
    }

    /* .atype::before,.btype::before {
        width: 38%;
        bottom: 15.5%;
        left: 30.5%;
        height: 28px;
    } */

    .nedan {
        width: 48%;
    }

    .bana{
        margin-top: 6rem;
    }



}

@media (min-width:1300px) {
    .dbr {
        display: inline;
    }

    .video-container iframe {
        width: 560px;
        height: 315px;
    }
}

/*==== 2K and 4K Responsive Support ====*/
@media screen and (min-width: 2000px) {


    body,
    html {
        font-size: 2vh;
    }
    .video-container{
        width: 30%;
    }
}