/* 共通 */

.tongaricorn-club {
    text-align: center;
    padding-bottom: 195px;
}

.tongaricorn-club .sec-title {
    width: 100%;
    height: 57px;
    justify-items: center;
    margin-bottom: 15px;
}

.tongaricorn-club .sec-title img {
    height: 100%;
    width: auto;
    margin: auto;
}

@media (max-width: 768px) {

    .tongaricorn-club .p-inner {
        padding-right: 15px;
        padding-left: 15px;
    }

    .tongaricorn-club .sec-title {
        height: fit-content;
        width: auto;
    }

    .tongaricorn-club .sec-title img {
        width: 100%;
        height: auto;
    }

    .tongaricorn-club .sec-title picture img {
        width: revert-layer;
        height: auto;
    }
}

.u-nowrap {
    white-space: nowrap;
}


/* kvArea */

.kvArea {
    overflow: hidden;
}

.kvArea .kv-bg {
    z-index: 0;
}

.kvArea .kv-top {
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
    /* animation: swing 3s infinite ease-in-out; */
    transform-origin: center center;
}

.kvArea .kv-ttl {
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 3;
}

@keyframes swing {
    0% {
        transform: rotate(-3deg);
    }
    50% {
        transform: rotate(3deg);
    }
    100% {
        transform: rotate(-3deg);
    }
}

.kvArea .kv-mid {

}

.back-wapper {
    display: block;
    position: absolute;
    top: -100px;
    left: 0;
    width: 100%;
    height: 150%;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}

.back-wapper span {
    position: absolute;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 240px;
    height: 240px;
    opacity: 1;
    animation: fall linear infinite;
}

@keyframes fall {
    0% {
        transform: translateY(-10%) rotate(0deg);
        opacity: 1;
    }
    100% {
        transform: translateY(110vh) rotate(720deg);
        opacity: 0.3;
    }
}

/* kvArea */

/* recruitingArea */

.recruitingArea {
    position: relative;
    padding-top: 55px;
    padding-bottom: 64px;
    background-color: #fff6dd;
}

.recruiting_leadTxt {
    width: 100%;
    font-size: 20px;
    line-height: 1.74;
    text-align: center;
    margin-bottom: 51px;
}

.recruiting_leadTxt p {
    transform: translate(4px, 0px);
}

.recruitingArea_cont {
    position: relative;
    width: 100%;
    border-radius: 20px;
    border: 3px solid #f8bb01;
    box-sizing: border-box;
    padding: 20px 0 10px;
    background-color: white;
    background-image: url('../images/bg_recruiting.png');
    background-repeat: repeat;
}

@media (max-width: 768px) {

    .recruitingArea {
        padding-top: 27px;
        margin-bottom: -25px;
    }
    .recruiting_leadTxt {
        font-size: 16px;
        letter-spacing: -0.5px;
        margin-bottom: 64px;
    }

    .recruiting_leadTxt p {
        transform: translate(2px, 0px);
    }

    .recruitingArea_cont {
        border-radius: 10px;
        border: 1.5px solid #f8bb01;
        padding: 15px 18px 10px 4px;
        margin-top: -7px;
    }
}



.recruitingArea_cont picture {
    position: relative;
    transform: translate(0, 0);
    z-index: 1;
}

.recruitingArea_cont img {
    width: 100%;
    max-width: 931px;
    margin: auto;
    transform: translate(5px, 7px);
}

/* recruitingArea */

/* privilegesArea */

.privilegesArea {
    position: relative;
    padding-top: 40px;
    padding-bottom: 71px;
    background-image: url('../images/bg_privileges.png');
    background-repeat: repeat;
}

.privilegesArea_cont {
    width: 100%;
    margin-top: 53px;
}

.privilegesArea_list {
    display: flex;
    gap: clamp(24px, 3.12vw, 40px);
    flex-wrap: wrap;
}

.privilegesArea_item {
    position: relative;
    flex: 1;
    background-color: #FFFFFF;
    border-radius: 30px;
    display: flex;
    flex-direction: column;
    padding: 83px 20px 20px;
    box-sizing: border-box;
}

.privilegesArea_item::before {
    content: "";
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
    width: 110px;
    height: 110px;
    background-size: contain;
    background-repeat: no-repeat;
}

.privilegesArea_item:nth-child(1)::before {
    background-image: url('../images/privileges_tag01.png');
}

.privilegesArea_item:nth-child(2)::before {
    background-image: url('../images/privileges_tag02.png');
}

.privilegesArea_item:nth-child(3)::before {
    background-image: url('../images/privileges_tag03.png');
}

.privilegesArea_item figure {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0;
    height: 100%;
    position: relative;
}

.privilegesArea_item figure img {
    width: auto;
    height: auto;
    max-height: 161px;
    margin-bottom: 15px;
}

.privilegesArea_item:nth-child(1) figure img {
    width: 100%;
    max-width: 298px;
    height: auto;
    max-height: none;
    margin-bottom: -6px;
    transform: translate(7px, -4px);

}

.privilegesArea_item:nth-child(2) figure img {
    transform: translate(-6px, 0px);
}

.privilegesArea_item:nth-child(3) figure img {
    transform: translate(-17px, -1px);
}


.privilegesArea_item figure figcaption {
    text-align: center;
    font-size: clamp(18px, 2.34vw, 24px);
    line-height: 32px;
    font-weight: bold;
}

.privilegesArea_item figure figcaption .c-text-note {
    font-size: 14px;
}

@media (max-width: 768px) {

    .privilegesArea {
        padding-bottom: 39px;
    }

    .privilegesArea_cont {
        margin-top: 35px;
    }

    .privilegesArea_list {
        flex-direction: column;
        gap: 25px;
    }

    .privilegesArea_item {
        padding: 50px 10px 18px;
        border-radius: 15px;
    }

    .privilegesArea_item::before {
        width: 70px;
        height: 70px;
        top: -20px;
    }

    .privilegesArea_item figure {
        flex-direction: row;
        align-items: center;
    }

    .privilegesArea_item figure img {
        width: 50%;
        max-width: none;
    }
    
    .privilegesArea_item figure figcaption {
        font-size: 16px;
        line-height: 20px;
        width: 50%; 
        margin-top: -5px;
        box-sizing: border-box; 
    }

    .privilegesArea_item:nth-child(1) figure img {
        width: 46%;
        max-width: fit-content;
        height: auto;
        max-height: 105px;
        transform: translate(2px, 0px);
        margin: auto;
    }

    .privilegesArea_item:nth-child(1) figcaption {
        transform: translate(-6px, -2px);
    }
    
    .privilegesArea_item:nth-child(2) {
        padding: 43px 12px 5px;
    }

    .privilegesArea_item:nth-child(2) figure img {
        transform: translate(-4px, -15px);
        height: 105px;
        width: auto;
        margin: auto;
    }

    .privilegesArea_item:nth-child(2) figcaption {
        transform: translate(-6px, -1px);
    }

    .privilegesArea_item:nth-child(3) {
        padding: 43px 12px 5px;
    }

    .privilegesArea_item:nth-child(3) figure img {
        transform: translate(-4px, -10px);
        height: 105px;
        width: auto;
        margin: auto;
    }

    .privilegesArea_item:nth-child(3) figcaption {
        transform: translate(-13px, 2px);
    }

    

    .privilegesArea_item figure figcaption .c-text-note {
        font-size: 11px;
        margin-top: 6px;
        margin-left: 4px;
        display: block;
    }
}

/* privilegesArea */

/* registerArea */

.registerArea {
    padding-top: 92px;
    padding-bottom: 40px;
    background: #FFFFFF;
}

.registerArea .p-point {
    background: #FFFFFF;
}

@media (max-width: 768px) {
    .registerArea {
        padding-top: 56px;
        padding-bottom: 0;
    }

    .registerArea .c-blockTitle {
        font-size: 16px;
        line-height: 19px;
    }

    .registerArea .c-lede {
        font-size: 14px;
        line-height: 16px;
    }

    .registerArea .text-l {
        font-size: 100%;
    }
}

/* registerArea */

/* eventArea */

.eventArea {
    position: relative;
    padding-top: 76px;
    padding-bottom: 43px;
    background-color: #fff6dd;
}

.eventArea .bnrDetailList__link {
    gap: 0;
}

.eventArea_cont .bnrDetailList__item {
    box-shadow: 0 0 10px rgba(0, 0, 0, .2);
    margin-bottom: 30px;
}

.eventArea .bnrDetailList__contBox {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    padding: 0 0 0 30px;
    max-width: none;
}

.eventArea .bnrDetailList__ttl{
    line-height: 30px;
}

.eventArea .bnrDetailList__txt {
    padding-top: 0;
    margin-top: -2px;
    text-align: left;
    font-size: 16px;
    line-height: 24px;
}

.eventArea .bnrDetailList__note {
    position: relative;
    top: 0;
    left: auto;
    transform: none;
    padding: 4px 5px 4px 9px;
    text-align: left;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.4;
    white-space: normal;
    background: #e60012;
    color: #fff;
    display: inline-block;
}

.eventArea .btn__link {
    margin-top: 6px;
    margin-right: auto;
    margin-left: 0;
}

@media (max-width: 768px) {

    .eventArea {
        padding-top: 37px;
        padding-bottom: 8px;
    }

    .eventArea_cont {
        margin-top: 17px;
    }

    .eventArea_cont .bnrDetailList__item {
        border-radius: 5px;
    }

    .eventArea .bnrDetailList__contBox {
        align-items: center;
        padding: 0;
        margin-top: 16px;
    }

    .eventArea .bnrDetailList__ttl { 
        font-size: 20px;
        line-height: 25px;
    }

    .eventArea .bnrDetailList__txt {
        font-size: 13px;
        font-weight: 500;
        line-height: 21px;
        letter-spacing: 1px;
    }

    .eventArea .bnrDetailList__note {
        font-size: 13px;
        margin-top: 0;
        left: auto;
    }

    .eventArea .btn__link {
        margin-left: auto;
    }
}

/* eventArea */

/* brandsiteArea */

.brandsiteArea {
    position: relative;
    padding-top: 0;
    padding-bottom: 80px;
    background-color: #fff6dd;
}

.brandsiteArea_banner a {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 410px;
    margin: 34px auto 0;
}

.brandsiteArea_banner .brandsiteArea_img {
    width: 100%;
    max-width: 344px;
    height: auto;
    margin-bottom: 30px;
}

.brandsiteArea_banner .c-roundButton_w377 {
    display: inline-block;
    width: 377px;
    padding: 16px;
    border: 2px solid #e60012;
    border-radius: 30px;
    background-color: #fff;
    color: #e60012;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
    -webkit-transition: 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
    transition: 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
    cursor: pointer;
}

.brandsiteArea_btn-blank span:after {
    content: '';
    display: inline-block;
    width: 15px;
    height: 15px;
    margin-left: 0.5em;
    background-image: url(/assets/images/ic-blank-red.png);
    background-size: 15px 15px;
    transition: 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
}

.brandsiteArea_banner a:hover .c-roundButton_w377 {
    background-color: #e60012;
    color: #fff;
}

.brandsiteArea_banner a:hover span:after {
    background-image: url(/assets/images/ic-blank.png);
}

@media (max-width: 768px) {

    .brandsiteArea {
        padding-bottom: 45px;
    }

    .brandsiteArea_banner a {
        margin-top: 17px;
    }
    .brandsiteArea_banner .brandsiteArea_img {
        max-width: 268px;
        margin-bottom: 23px;
    }

    .brandsiteArea_banner .c-roundButton_w377 {
        width: 300px;
        max-width: 100%;
        line-height: 1.4;
    }
}
/* brandsiteArea */


/* 規約ページ */

.p-form {
    padding: 20px 20px;
}

.p-kiyaku .c-roundButton_w377 {
    display: inline-block;
    width: 377px;
    padding: 16px;
    border: 2px solid #e60012;
    border-radius: 30px;
    background-color: #fff;
    color: #e60012;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    line-height: 1;
    -webkit-transition: 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
    transition: 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
    cursor: pointer;
}

.p-kiyaku .c-roundButton_w377:hover {
    background-color: #e60012;
    color: #fff;
}

.p-kiyaku .c-roundButton_w377 {
    pointer-events: none;
    opacity: 0.5;
}

.p-kiyaku .c-roundButton_w377.is-active {
    pointer-events: auto;
    opacity: 1;
    cursor: pointer;
}

/* 規約ページ */

/* 入会完了ページ */

.c-dialog_img {
    margin: 0 auto;
}

/* 入会完了ページ */