html{
    scroll-behavior:smooth;
}

.rules-page{
    position:relative;
    z-index:5;

    padding:140px 60px 80px;
}

.rules-layout{
    display: flex;
    align-items: flex-start;
    gap: 30px;
}
.scroll-top{

    position:fixed;

    right:30px;

    bottom:30px;

    width:58px;

    height:58px;

    border:none;

    border-radius:50%;

    background:#9eff00;

    color:black;

    font-size:28px;

    font-weight:700;

    cursor:pointer;

    z-index:9999;

    opacity:0;

    pointer-events:none;

    transform:translateY(20px);

    transition:.3s;

    box-shadow:
    0 0 25px rgba(158,255,0,.25);
}

.show-scroll{

    opacity:1;

    pointer-events:auto;

    transform:translateY(0);
}

.scroll-top:hover{

    transform:scale(1.08);

}
.rules-sidebar{
    height: calc(100vh - 230px);

    overflow-y: auto;

    background: rgba(10,10,10,.75);

    border:1px solid rgba(255,255,255,.06);

    border-radius:18px;

    padding:30px;

    backdrop-filter:blur(12px);
}
.rules-switch{
    position: relative;

    z-index: 5;
}

.sidebar-wrapper{
    position: sticky;

    top: 120px;

    align-self: flex-start;

    min-width: 280px;

    max-height: calc(100vh - 140px);

    display: flex;

    flex-direction: column;

    gap: 15px;
}
.rules-sidebar::-webkit-scrollbar{
    width:6px;
}

.rules-sidebar::-webkit-scrollbar-track{
    background:transparent;
}

.rules-sidebar::-webkit-scrollbar-thumb{
    background:#9eff00;

    border-radius:20px;
}

.rules-sidebar h3{
    color:#9eff00;

    font-size:14px;

    letter-spacing:4px;

    margin-bottom:25px;
}

.rules-sidebar a{
    display:block;

    padding:14px 18px;

    margin-bottom:10px;

    border-radius:10px;

    text-decoration:none;

    color:#bdbdbd;

    transition:.25s;
}

.rules-sidebar a:hover{
    background:rgba(158,255,0,.08);

    color:white;
}

.rules-content{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.rules-contentgp{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.rules-block{
    width: 100%;
}
.rules-block:last-child{
    border-bottom:none;

    margin-bottom:0;

    padding-bottom:0;
}



.rules-block span{
    color:#9eff00;

    letter-spacing:4px;

    font-size:14px;
}

.rules-block h2{
    margin-top:15px;

    margin-bottom:30px;

    font-size:42px;

    line-height:50px;
}

.rules-list{
    list-style:none;
}

.rules-list li{
    position:relative;

    padding-left:28px;

    margin-bottom:20px;

    color:#bdbdbd;

    line-height:32px;

    font-size:17px;
}

.rules-list li::before{
    content:"▸";

    position:absolute;

    left:0;

    color:#9eff00;
}

.safezone-gallery{
    display:flex;

    flex-direction:column;

    gap:35px;

    margin-top:40px;
}

.safezone-image{
    background:rgba(10,10,10,.65);

    border:1px solid rgba(255,255,255,.06);

    border-radius:18px;

    overflow:hidden;

    backdrop-filter:blur(10px);
}

.safezone-image h3{
    padding:20px 25px;

    font-size:22px;

    color:#9eff00;

    border-bottom:1px solid rgba(255,255,255,.05);

    letter-spacing:2px;
}

.safezone-image img{
    width:100%;

    display:block;

    object-fit:cover;
}

.rules-switch{
    display:flex;

    gap:12px;

    margin-bottom:20px;
}

.switch-btn{
    height:50px;

    padding:0 25px;

    border:none;

    border-radius:12px;

    background:rgba(20,20,20,.85);

    color:#bdbdbd;

    font-size:14px;

    cursor:pointer;

    transition:.25s;
}

.switch-btn:hover{
    background:rgba(158,255,0,.12);

    color:white;
}

.switch-btn.active{
    background:#9eff00;

    color:black;

    font-weight:700;
}

.rules-menu{
    display:none;
}

.rules-menu.active-menu{
    display:block;
}

.sidebar-wrapper {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.rules-switch {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.rules-contentgp{
    display:none;

    flex-direction:column;

    gap:30px;
}

.rules-contentgp.active-content{
    display:flex;
}

.rules-layout{
    display: flex;
    align-items: flex-start;
    gap: 40px;
}

.sidebar-wrapper{
    min-width: 280px;
}

.rules-contentgp{
    flex: 1;
}

/* ========================= */
/* RULES MOBILE */
/* ========================= */

@media (max-width:768px){

    .rules-page{

        padding:170px 15px 60px;
    }

    .rules-layout{

        flex-direction:column;

        gap:25px;
    }

    .sidebar-wrapper{

        width:100%;

        min-width:100%;
    }

    .rules-switch{

        width:100%;

        position:static;
    }

    .switch-btn{

        width:100%;

        height:52px;

        font-size:15px;
    }

    /* ========================= */
/* MOBILE FLOAT SIDEBAR */
/* ========================= */

@media (max-width:768px){

    .sidebar-wrapper{

        position:fixed;

        top:125px;

        left:0;

        width:100%;

        z-index:500;

        padding:0 12px;

        transition:.35s;
    }

    .sidebar-wrapper.hide-sidebar{

        transform:translateY(-140%);
    }

    .rules-switch{

        width:100%;

        display:flex;

        flex-direction:column;

        gap:8px;

        margin-bottom:8px;
    }

    .switch-btn{

        width:100%;

        height:42px;

        font-size:13px;

        border-radius:10px;
    }

    .rules-sidebar{

        width:100%;

        height:95px;

        overflow-y:auto;

        padding:10px;

        border-radius:14px;

        background:rgba(10,10,10,.96);

        backdrop-filter:blur(16px);
    }

    .rules-sidebar a{

        padding:8px 10px;

        margin-bottom:4px;

        font-size:13px;

        line-height:18px;
    }

    .rules-content,
    .rules-contentgp{

        margin-top:190px;
    }

}
    .rules-sidebar h3{

        font-size:13px;

        letter-spacing:3px;

        margin-bottom:20px;
    }

    .rules-sidebar a{

        font-size:14px;

        line-height:22px;

        padding:12px 14px;
    }

    .rules-content,
    .rules-contentgp{

        width:100%;
    }

    .rules-block{

        width:100%;
    }

    .rules-block h2{

        font-size:34px;

        line-height:40px;

        margin-bottom:25px;
    }

    .rules-block span{

        font-size:12px;

        letter-spacing:3px;
    }

    .rules-list li{

        font-size:15px;

        line-height:28px;

        padding-left:24px;

        margin-bottom:16px;
    }

    .safezone-gallery{

        gap:20px;
    }

    .safezone-image h3{

        font-size:18px;

        padding:16px 18px;
    }

    .safezone-image img{

        max-height:240px;

        object-fit:cover;
    }

    .faction-header h2{

        font-size:38px;

        line-height:44px;
    }

    .faction-header p{

        font-size:15px;

        line-height:28px;
    }

}

/* ========================= */
/* SMALL MOBILE */
/* ========================= */

@media (max-width:480px){

    .rules-page{

        padding:160px 12px 50px;
    }

    .rules-sidebar{

        padding:16px;
    }

    .rules-block h2{

        font-size:28px;

        line-height:34px;
    }

    .rules-list li{

        font-size:14px;

        line-height:26px;
    }

    .switch-btn{

        height:48px;

        font-size:14px;
    }

    .faction-header h2{

        font-size:30px;
    }

}