/* common */
:root {
    --main_br: #362215;
    --main_ye: #ffc600;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    background-size: auto auto;
    background-color: rgba(249, 243, 205, 1);
    background-image: repeating-linear-gradient(45deg, transparent, transparent 10px, rgba(249, 233, 146, 1) 10px, rgba(249, 233, 146, 1) 20px );
}

#page { overflow: hidden;}

.pc_only { display: block;}

.sp_only { display: none;}

.wrapper {
    max-width: 1344px;
    width: 70%;
    margin: 0 auto;
    background-color: #f9f3cd;
    padding: 150px 0;
}

.sec {
    position: relative;
    padding: 50px;
    margin-bottom: 200px;
}

.sec:last-of-type { margin-bottom: 0;}

.sec h2 {
    width: 100%;
    text-align: center;
    margin-bottom: 2%;
}

.sec_ttl_en {
    position: absolute;
    width: 100%;
    text-align: center;
    font-family: 'Oswald', sans-serif;
    font-size: 100px !important;
    left: calc(50% - 50%);
}

.registration {
    display: block;
    width: 55%;
    margin: 0 auto;
    font-size: 25px;
    text-align: center;
    line-height: 2.6;
    background-color: #fff;
    color: var(--main_br);
    border-radius: 50px;
    position: relative;
}

.registration::after {
    position: absolute;
    top: 36%;
    right: 35%;
    content: "";
    display: block;
    width: 3%;
    padding-top: 3%;
    background: url(/clubtvo/images/portal/arrow.png) no-repeat center / 100%;
    transition: all .3s;
}

.registration:hover::after { right: 33%;}
/* common */


/* clubtvo_top */
#clubtvo_top { max-height: 845px;}

.top_wrapper {
    position: relative;
    max-width: 1920px;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    top: 0;
    left: 0;
}

.fadein_img {
    width: 58%;
    position: absolute;
    top: 0;
    right: 0;
}

/*
 * 写真の枚数が変わる場合
 * animationのdurationを要変更
 * 1枚につき 7.5s
 */
.fadein_img li {
    width: 100%;
    position: absolute;
    top: 0;
    right: 0;
    opacity: 0;
    animation:  fade 22.5s infinite; /* n x 7.5s */
}

.fadein_img li img { width: 100%;}

/*
 * 写真の枚数に応じて
 * セレクタを追加
 * 7.5sずつ加算
 */
.fadein_img li:nth-child(1) { animation-delay: 0s;}
.fadein_img li:nth-child(2) { animation-delay: 7.5s;}
.fadein_img li:nth-child(3) { animation-delay: 15s;}
/* .fadein_img li:nth-child(4) { animation-delay: 22.5s;} */

.ttl_and_navi {
    width: 42%;
    background-color: var(--main_br);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 5.45% 0;
}

.ttl_and_navi h1 {
    width: 65%;
    margin-bottom: 5%;
}

.ttl_and_navi h1 img { width: 100%;}

.nav_pc {
    width: 90%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
}

.nav_pc li { width: 48%;}

.nav_pc li a {
    display: block;
    width: 100%;
    padding-top: 18.46%;
    cursor: pointer;
}

.nav_pc li:nth-child(1) a { background: url(/clubtvo/images/portal/bnr_login.png) no-repeat center / 100%;}
.nav_pc li:nth-child(1) a:hover { background: url(/clubtvo/images/portal/bnr_login_hover.png) no-repeat center / 100%;}

.nav_pc li:nth-child(2) a { background: url(/clubtvo/images/portal/bnr_registration.png) no-repeat center / 100%;}
.nav_pc li:nth-child(2) a:hover { background: url(/clubtvo/images/portal/bnr_registration_hover.png) no-repeat center / 100%;}


@keyframes fade {
	0%{ opacity: 0;}
	15%{ opacity: 1;}
	30%{ opacity: 1;}
	45%{ opacity: 0;}
	100%{ opacity: 0;}
}
/* clubtvo_top */


/* intro */
#intro {
    background: url(/clubtvo/images/portal/bk_takoru.png) no-repeat center / 50%, var(--main_br);;
    color: #fff;
}

#intro h2 img, #id_pass h2 img { width: 45%;}

.intro_detail {
    width: 100%;
    text-align: center;
    font-size: 25px;
    line-height: 1.5;
    margin-bottom: 5%;
}

.intro_bk {
    position: absolute;
    width: 44%;
    top: -2.5%;
}

.intro_bk img { width: 100%;}

.intro_bk:nth-of-type(1) { left: -20%;}
.intro_bk:nth-of-type(2) { right: -20%;}

#intro .sec_ttl_en {
    color: var(--main_br);
    top: -100px;
}
/* intro */


/* advantages */
#advantages { background-color: var(--main_ye);}

#advantages .sec_ttl_en {
    color: var(--main_ye);
    top: -100px;
}

#advantages h2 {
    position: relative;
    width: 80%;
    margin: 0 auto 3% auto;
}

#advantages h2 img,
.advantage_list li { width: 100%;}

#advantages h2::after {
    position: absolute;
    content: "";
    display: block;
}

#advantages h2:first-of-type:after {
    width: 20%;
    padding-top: 22%;
    background: url(/clubtvo/images/portal/present_takoru.png) no-repeat center / 100%;
    bottom: -45%;
    right: -19.5%;
    z-index: 10;
}

#advantages h2:last-of-type::after {
    width: 18%;
    padding-top: 19%;
    background: url(/clubtvo/images/portal/welcome_takobe.png) no-repeat center / 100%;
    bottom: 0;
    left: -21%;
}

#advantages h3 {
    text-align: center;
    font-size: 35px;
    font-weight: 900;
    color: #ff6000;
    background: rgb(255,255,0);
    background: linear-gradient(0deg, rgba(255,255,0,1) 0%, rgba(255,255,0,1) 50%, rgba(255,255,0,0) 50%, rgba(255,255,0,0) 100%);
    margin-bottom: 4%;
}

.advantage_list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2em;
}

.point { margin-bottom: 7%;}

.point li {
    background-color: #fff;
    border: solid 3px var(--main_br);
    box-shadow: 5px 5px 0 #ffa800;
    border-radius: 10px;
    position: relative;
    padding: 12% 5% 5% 5%;
}

.point_num {
    position: absolute;
    width: 21%;
    top: -23%;
    left: calc(50% - 10.5%);
}

.point_num img,
.mailmagazine_list li img { width: 100%;}

.point_detail {
    font-size: 20px;
    line-height: 1.5;
    text-align: justify;
}

.mailmagazine_list li {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: end;
    transition: all .3s;
}

.mailmagazine_list li:hover { transform: translateY(-8%);}
/* advantages */


/* id_pass */
#id_pass {
    background-color: var(--main_br);
    color: #fff;
}

#id_pass .sec_ttl_en {
    color: var(--main_br);
    top: -100px;
}

.id_pass_detail {
    text-align: center;
    font-size: 25px;
    line-height: 1.7;
    margin-bottom: 4%;
}

#id_pass h3 {
    width: 100%;
    text-align: center;
    margin: 8% auto 6% auto;
}

#id_pass h3 img { width: 60%;}

.step_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.step_list li {
   width: 28%;
   padding: 2%;
   background-color: #fff;
   border: solid 3px var(--main_ye);
   border-top-right-radius: 10px;
   border-bottom-left-radius: 10px;
   border-bottom-right-radius: 10px;
   box-shadow: 5px 5px 0 #000000;
   color: var(--main_br);
   position: relative;
   display: flex;
   flex-direction: column-reverse;
}

.step_list li:nth-child(1)::after,
.step_list li:nth-child(2)::after {
    position: absolute;
    display: block;
    content: "";
    width: 10%;
    height: 20%;
    background-color: var(--main_ye);
    clip-path: polygon(0 0, 0% 100%, 100% 50%);
    top: calc(50% - 10%);
    right: -22%;
}

.step_list li img {
    width: 100%;
    margin-bottom: 5%;
}

.step_list p {
    width: 100%;
    text-align: center;
    font-size: 22px;
    line-height: 1;
}

.step_num {
    position: absolute;
    top: -57px;
    left: -3px;
    background-color: var(--main_ye);
    color: #fff;
    text-align: center;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    font-size: 30px;
    padding: 10px 15px;
}
/* id_pass */


/* footer_nav */
#footer_nav {
    width: 100%;
    background-color: var(--main_ye);
    color: #fff;
    padding: 70px 0;
}

#footer_nav ul {
    max-width: 1344px;
    width: 70%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    font-size: 22px;
}

#footer_nav ul li { transition: all .2s;}

#footer_nav ul li:hover { opacity: .5;}
/* footer_nav */


/* anchor */
#anchor {
    width: 110px;
    position: fixed;
    right: 0;
    bottom: 100px;
    color: var(--main_br);
    z-index: 50;
}

#anchor li {
    text-align: center;
    border-top-left-radius: 15px;
    border-bottom-left-radius: 15px;
    border-top: solid 3px var(--main_br);
    border-bottom: solid 3px var(--main_br);
    border-left: solid 3px var(--main_br);
    transition: all .2s;
    margin-bottom: 15px;
    font-size: 20px;
}

#anchor li:first-child,
#anchor li:last-child {
    background-color: #ff722c;
}

#anchor li:nth-child(2) { background-color: #fffd4d;}

#anchor li:last-child {
    margin-bottom: 0;
    font-size: 16px;
}
#anchor li:last-child p:first-of-type { letter-spacing: -0.1em;}

#anchor li:last-child p:last-of-type { margin-bottom: 15px;}

#anchor li img {
    width: 50%;
    margin-bottom: 5%;
}

#anchor li:last-child img { width: 60%;}

#anchor li a {
    width: 100%;
    display: flex;
    flex-direction: column-reverse;
    /* padding: 15% 3%; */
    padding: 20px 0;
}

#anchor li:hover { background-color: #fff;}
/* anchor */



/* ============================================ responsive ============================================ */
@media (max-width: 1920px) {
    /* common */
    .wrapper { padding: 9% 0 6% 0;}

    .sec {
        padding: 4%;
        margin-bottom: 18%;
    }

    .sec_ttl_en { font-size: 5vw !important;}

    .registration { font-size: 1.3vw;}
    /* common */

    /* intro */
    #intro .sec_ttl_en { top: -12.5%;}

    .intro_detail { font-size: 1.3vw;}
    /* intro */

    /* advantages */
    #advantages .sec_ttl_en { top: -7.5%;}

    #advantages h3 { font-size: 1.8vw;}

    .point_detail { font-size: 1.1vw;}
    /* advantages */


    /* id_pass */
    #id_pass .sec_ttl_en { top: -8.3%;}

    .id_pass_detail { font-size: 1.3vw;}

    .step_num {
        top: -16%;
        left: -0.9%;
        font-size: 1.5vw;
        padding: 2% 7%;
    }

    .step_list p { font-size: 1.2vw;}
    /* id_pass */


    /* footer_nav */
    #footer_nav { padding: 3% 0;}

    #footer_nav ul { font-size: 1.1vw;}
    /* footer_nav */


    /* anchor */
    #anchor {
        width: 6%;
        bottom: 10%;
    }

    #anchor li {
        margin-bottom: 15%;
        font-size: 1vw;
    }

    #anchor li a { padding: 15% 0;}

    #anchor li:last-child { font-size: 0.9vw;}
    /* anchor */
}

@media (max-width: 899px) {
    /* advantages */
    #advantages .sec_ttl_en { top: -7%;}
    /* advantages */

    /* anchor */
    #anchor { width: 8%;}
    /* anchor */
}

@media (max-width: 767px) {

    /* common */
    .pc_only { display: none;}

    .sp_only { display: block;}

    .wrapper {
        width: 90%;
        padding: 20% 0 12% 0;
    }

    .sec {
        padding: 7%;
        margin-bottom: 30%;
    }

    .registration {
        width: 100%;
        font-size: 4.5vw;
        padding-right: 8%;
    }

    .registration::after {
        top: 30%;
        right: 29%;
        width: 6%;
        padding-top: 7%;
    }

    .registration:hover::after { right: 25%;}
    /* common */


    /* clubtvo_top */

    #clubtvo_top {
        padding-top: 121%;
        position: relative;
    }

    .top_wrapper { position: absolute;}

    .ttl_and_navi h1 {
        width: 38.5%;
        margin-bottom: 0;
    }

    .fadein_img { position: relative;}

    .ttl_and_navi, .fadein_img { width: 100%;}

    .sp_navi {
        width: 100%;
        background-color: var(--main_br);
        padding: 5% 0;
    }

    .sp_navi ul {
        width: 70%;
        margin: 0 auto;
    }

    .sp_navi ul li { width: 100%;}

    .sp_navi ul li a {
        display: block;
        width: 100%;
        padding-top: 18.24%;}

    .sp_navi ul li:first-child { margin-bottom: 5%;}

    .sp_navi ul li:first-child a { background: url(/clubtvo/images/portal/bnr_login.png) no-repeat center / 100%;}

    .sp_navi ul li:first-child a:hover { background: url(/clubtvo/images/portal/bnr_login_hover.png) no-repeat center / 100%;}

    .sp_navi ul li:last-child a { background: url(/clubtvo/images/portal/bnr_registration.png) no-repeat center / 100%;}

    .sp_navi ul li:last-child a:hover { background: url(/clubtvo/images/portal/bnr_registration_hover.png) no-repeat center / 100%;}

    /* clubtvo_top */


    /* intro */
    #intro { padding-bottom: 60%;}

    #intro .sec_ttl_en {
        top: -5.5%;
        font-size: 10vw !important;
    }

    #intro h2 img, #id_pass h2 img { width: 100%;}

    .intro_detail {
        text-align: justify;
        font-size: 4vw;
        margin-bottom: 10%;
    }

    .intro_bk_sp {
        position: absolute;
        width: 110%;
        bottom: -8%;
        left: calc(50% - 55%);
    }

    .intro_bk_sp img { width: 100%;}
    /* intro */


    /* advantages */
    #advantages .sec_ttl_en {
        top: -3.6%;
        font-size: 8.8vw !important;
    }

    #advantages h2 { width: 100%;}

    #advantages h2:first-of-type { margin-bottom: 7%;}

    #advantages h2:last-of-type { margin-bottom: 0;}

    #advantages h2:first-of-type:after {
        width: 29%;
        padding-top: 32%;
        bottom: -180%;
        right: -11.5%;
    }

    #advantages h2:last-of-type::after {
        width: 30%;
        padding-top: 32%;
        bottom: 100%;
        left: -12%;
    }

    #advantages h3 { font-size: 5.4vw;}

    .point {
        margin-bottom: 17%;
        gap: 3.3em;
        grid-template-columns: 1fr;
    }

    .point li { padding: 10% 7% 7% 7%;}

    .point_num {
        width: 18%;
        top: -22%;
        left: calc(50% - 9%);
    }

    .point_detail {
        font-size: 3.5vw;
        text-align: center;
    }

    .mailmagazine_list {
        grid-template-columns: 1fr;
        gap: 1em;
    }
    /* advantages */


    /* id_pass */
    #id_pass .sec_ttl_en {
        top: -2.6%;
        font-size: 8.8vw !important;
    }

    .id_pass_detail {
        text-align: justify;
        font-size: 4vw;
        margin-bottom: 10%;
    }

    #id_pass h3 { margin: 15% auto;}

    #id_pass h3 img { width: 100%;}

    .step_list {
        flex-direction: column;
        align-items: center;
        width: 65%;
        margin: 0 auto;
    }

    .step_list li {
        width: 100%;
        margin-bottom: 45%;
    }

    .step_list li:last-child { margin-bottom: 0;}

    .step_list li:nth-child(1)::after,
    .step_list li:nth-child(2)::after {
        transform: rotate(90deg);
        top: 110%;
        right: calc(50% - 5%);
    }

    .step_list p { font-size: 3.5vw;}

    .step_num {
        top: -19%;
        left: -1.2%;
        font-size: 4.5vw;
        padding: 3% 5%;
    }
    /* id_pass */

    /* anchor */
    #anchor { width: 12%;}

    #anchor li, #anchor li:last-child { font-size: 2vw;}

    #anchor li:last-child p:last-of-type { margin-bottom: 5%;}

    #anchor li img {
        width: 40%;
        margin-bottom: 1%;
    }

    #anchor li:last-child img { width: 50%;}
    /* anchor */


    /* footer_nav */
    #footer_nav { padding: 7% 0;}

    #footer_nav ul {
        flex-direction: column;
        font-size: 3.5vw;
        text-align: center;
    }

    #footer_nav ul li { margin-bottom: 7%;}

    #footer_nav ul li:last-child { margin-bottom: 0;}
    /* footer_nav */
}

@media (max-width: 500px) {
    #advantages .sec_ttl_en { top: -3.3%;}

    #anchor { width: 70px;}

    #anchor li, #anchor li:last-child { font-size: 13px;}

    #anchor li a { padding: 15% 0;}

    #anchor li img {
        width: 40%;
        margin-bottom: 5%;
    }

    #anchor li:last-child img { width: 50%;}
}
