html,
body {
    position: relative;
    background-color: #fff9e9;
    height: 100%;
    width: 100%;
    margin: 0;
    -webkit-tap-highlight-color: transparent;
}

body,
input[type=text] {
    font-weight: bold;
    display: flex;
    justify-content: flex-start;
}

body.rotate {
    transform: rotate(90deg);
    transform-origin: left top;
}

button {
    font-weight: bold;
    cursor: pointer;
}

#filterPanel {
    transition: background-color.3s;
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
    position: fixed;
    z-index: 15;
    background-color: #00000000;
}

#filterPanel.show {
    display: flex;
    background-color: #00000070;
    animation: showFilterPanel.3s;
}

#filterPanel.close {
    display: flex;
}

#filterPanel .filterBox {
    display: flex;
    flex-direction: column;
    width: 600px;
    height: 450px;
    border-radius: 8px;
    background-color: #fff9e9;
    padding-bottom: 10px;
}

#filterPanel.show .filterBox {
    animation: showFilterBox.4s;
}

#filterPanel.close .filterBox {
    transition: scale.3s, filter.2s;
    scale: 1.1;
    filter: opacity(0);
}

#filterPanel .filterBox > .title {
    position: relative;
    text-align: center;
    display: block;
    background-color: #000000db;
    color: white;
    margin: 5px;
    height: 40px;
    line-height: 40px;
    border-radius: 6px;
}

#filterPanel .filterBox > .title .closeFilterBtn {
    position: absolute;
    width: 26px;
    height: 26px;
    right: 10px;
    top: 8px;
    cursor: pointer;
}

#filterPanel .filterBox > .title .closeFilterBtn .x {
    position: relative;
    width: 100%;
    height: 100%;
    right: -9px;
    pointer-events: none;
}

#filterPanel .filterBox > .title .closeFilterBtn .xLeft,
#filterPanel .filterBox > .title .closeFilterBtn .xRight {
    position: absolute;
    margin: auto;
    width: 7px;
    height: 100%;
    border-radius: 2px;
    background-color: white;
    transform: rotate(45deg);
    pointer-events: none;
}

#filterPanel .filterBox > .title .closeFilterBtn .xRight {
    margin: auto;
    width: 7px;
    height: 100%;
    background-color: white;
    transform: rotate(-45deg);
}

#filterPanel .filterBox hr {
    width: 585px;
    margin-top: -2px;
    border-radius: 5px;
    border: 2px solid #000000db;
}

#filterPanel .filterBox .filterContent {
    flex: 1;
    display: flex;
    flex-direction: row;
}

#filterPanel .filterBox .filterContent .content div:hover {
    background-color: #c7c1ad !important;
    cursor: pointer;
}

#filterPanel .filterBox .filterContent .content div.select {
    background-color: #ffb01e !important;
}

#filterPanel .filterBox .filterContent .filterClass {
    position: relative;
    width: 290px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    border-right: 1px dotted gray;
}

#filterPanel .filterBox .filterContent .filterClass .title {
    display: flex;
    flex-direction: row;
}

#filterPanel .filterBox .filterContent .filterClass .title p {
    margin: 0 0 0 20px;
}

#filterPanel .filterBox .filterContent .filterClass .title div {
    position: absolute;
    right: 20px;
    display: flex;
    flex-direction: row;
}

#filterPanel .filterBox .filterContent .filterClass .title div input[type=checkbox] {
    transition: background-color.1s;
    appearance: none;
    position: relative;
    margin: 0;
    width: 45px;
    height: 23px;
    border-radius: 30px;
    background-color: #000000db;
    margin-left: 5px;
}

#filterPanel .filterBox .filterContent .filterClass .title div input[type=checkbox]:checked {
    background-color: green;
}

#filterPanel .filterBox .filterContent .filterClass .title div input[type=checkbox]::after {
    transition: left.1s;
    content: "";
    height: 23px;
    width: 23px;
    background-color: #fff9e9;
    position: absolute;
    border-radius: 30px;
    left: 0px;
    top: 50%;
    transform: translateY(-50%);
    box-shadow: 0 0 3px gray;
}

#filterPanel .filterBox .filterContent .filterClass .title div input[type=checkbox]:checked::after {
    left: 22px;
}

#filterPanel .filterBox .filterContent .filterClass .content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
    text-align: center;
}

#filterPanel .filterBox .filterContent .filterClass .content div {
    transition: background-color.1s;
    background-color: #e1dbc9;
    margin: 0 20px;
    height: 27px;
    line-height: 27px;
    border-radius: 30px;
}

#filterPanel .filterBox .filterContent .filterTypes {
    margin-left: 10px;
    display: flex;
    flex-direction: column;
} 

#filterPanel .filterBox .filterContent .filterTypes p {
    margin: 0 0 0 5px;
}

#filterPanel .filterBox .filterContent .filterTypes .content {
    flex: 1;
    display: flex;
    text-align: center;
    flex-direction: row;
    flex-wrap: wrap;
    margin-top: 5px;
}

#filterPanel .filterBox .filterContent .filterTypes .content div {
    transition: background-color.1s;
    background-color: #e1dbc9;
    display: flex;
    justify-content: flex-start;
    margin: 0 5px;
    height: 27px;
    width: 70px;
    border-radius: 30px;
}

#filterPanel .filterBox .filterContent .filterTypes .content div img {
    height: 27px;
    pointer-events: none;
}

#filterPanel .filterBox .filterContent .filterTypes .content div span {
    display: inline-block;
    position: relative;
    height: 27px;
    line-height: 27px;
    pointer-events: none;
}

#filterPanel .filterBtns {
    display: flex;
    justify-content: space-evenly;
    width: 600px;
    margin-top: 20px;
}

#filterPanel .filterBtns button {
    transition: background-color.1s, scale.3s, filter.3s;
    background-color: #fff8e6;
    border: none;
    border-radius: 18px;
    padding: 5px;
    box-shadow: 0 1px 2px black;
    font-size: 17px;
    width: 120px;
    height: 40px;
    scale: 1.2;
    filter: opacity(0);
}

#filterPanel.show .filterBtns button {
    animation: showFilterButton.3s;
    scale: 1;
    filter: opacity(1);
}

#filterPanel .filterBtns button:hover {
    background-color: #e5decd;
}

.sideBar {
    display: flex;
    flex-direction: column;
    width: 260px;
    height: 100%;
    border-right: 5px solid #918973;
}

.sideBar .search {
    position: relative;
    z-index: 9;
    transition: box-shadow.3s;
    margin-left: 30px;
    width: 170px;
    padding: 9px;
    padding-left: 15px;
    margin-bottom: 5px;
    border-radius: 50px;
    border: none;
    background-color: #e1dbc9;
    box-shadow: 0 0 0 0 transparent;
}

.sideBar .search:focus {
    box-shadow: 0 0 0 9999px #00000070;
}

.sideBar .elfList {
    overflow-x: hidden;
    overflow-y: auto;
    flex: 1;
}

body.rotate .sideBar .elfList {
    overflow-x: auto;
    overflow-y: auto;
}

.sideBar .elfList .elfBox {
    transition: height.3s, margin.3s;
    display: flex;
    position: relative;
    flex-direction: row;
    justify-content: flex-start;
    margin: 10px 0;
    padding-left: 45px;
    left: -10px;
    height: 50px;
    width: 190px;
    cursor: pointer;
}

.sideBar .elfList .elfBox.hidden {
    height: 0;
    margin: 0;
    overflow: hidden;
}

.sideBar .elfList .elfBox.select {
    background: linear-gradient(90deg, #ffb01e, #fad081);
    animation: selectElf.15s;
    box-shadow: 3px 3px 5px gray;
}

.sideBar .elfList .elfBox .info {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.sideBar .elfList .elfBox .info p {
    white-space: nowrap;
}

.sideBar .elfList .elfBox .info .id {
    margin-bottom: -3px;
    letter-spacing: 1px;
    font-size: 18px;
}

.sideBar .elfList .elfBox .info .name {
    margin-top: -3px;
}

.sideBar .elfList .elfBox .avatarBox {
    position: absolute;
    margin-left: 100px;
    margin-top: 8px;
    height: 35px;
    width: 35px;
    background-color: #343434;
    border-radius: 50px;
}

.sideBar .elfList .elfBox .avatarBox .avatar {
    position: relative;
    height: 50px;
    left: -7px;
    top: -7px;
}

.sideBar .elfList .elfBox .progress {
    position: absolute;
    margin-left: 150px;
    white-space: nowrap;
}

.sideBar .elfList .elfBox .progress.finish {
    color: rgb(191, 121, 16);
}

.sideBar .otherFunc {
    display: flex;
    flex-direction: row;
    margin: 10px;
    margin-left: 20px;
}

.sideBar .otherFunc button,
.sideBar .otherFunc .data {
    transition: background-color.1s;
    background-color: #fff8e6;
    border: none;
    border-radius: 20px;
    padding: 5px;
    box-shadow: 0 1px 2px black;
    height: 30px;
}

.sideBar .otherFunc .data {
    transition: height.2s, box-shadow.2s, border-radius.2s;
    display: flex;
    flex-direction: column-reverse;
    margin-left: 50px;
    padding: 0;
    height: 30px;
    bottom: 10px;
    position: absolute;
    overflow: hidden;
}

.sideBar .otherFunc .data.show {
    height: 94px;
    box-shadow: 0 0 4px black;
    border-radius: 18px;
}

.sideBar .otherFunc .data button {
    box-shadow: none;
    background-color: transparent;
    margin-top: 3px;
}

.sideBar .otherFunc button:hover {
    background-color: #e5decd;
}


.sideBar .otherFunc .data .showBtns span {
    transition: transform.2s, bottom.2s;
    border: 5px solid transparent;
    border-bottom: 5px solid black;
    position: absolute;
    bottom: 11px;
    right: 10px;
    pointer-events: none;
}

.sideBar .otherFunc .data.show .showBtns span {
    transform: rotate(-180deg);
    bottom: 7px;
}

.elfClass {
    flex: 1;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.elfClass .backImg {
    position: fixed;
    height: 100%;
    width: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    filter: opacity(0.5);
    z-index: -1;
}

.elfClass .elfInfo {
    margin-left: 10px;
    display: flex;
    flex-direction: row;
}

.elfClass .elfInfo .type {
    background-color: #e1dbc9;
    display: flex;
    justify-content: flex-start;
    margin: 10px;
    margin-right: 0;
    height: 40px;
    width: 100px;
    border-radius: 30px;
}

.elfClass .elfInfo .type img {
    height: 40px;
    pointer-events: none;
}

.elfClass .elfInfo .type span {
    display: inline-block;
    position: relative;
    font-size: 18px;
    height: 40px;
    line-height: 40px;
    pointer-events: none;
}

.elfClass .elfInfo .className {
    width: auto;
    position: absolute;
    right: 10px;
    padding: 0 20px;
}

.elfClass .elfInfo .className span {
    width: 100%;
    text-align: center;
}

.elfClass .elfInfo .finishAll,
.elfClass .elfInfo .uncheckAll {
    transition: background-color.1s;
    margin: 10px;
    margin-right: 0;
    padding: 10px;
    width: 120px;
    height: 40px;
    background-color: #f8cb43;
    border: none;
    border-radius: 20px;
    font-size: 17px;
    line-height: 17px;
    box-shadow: 0 0 3px rgb(80, 63, 37);
}

.elfClass .elfInfo .finishAll:hover,
.elfClass .elfInfo .uncheckAll:hover {
    background-color: #deb53d;
}

.elfClass .classBox {
    transition: filter.1s;
    display: flex;
    position: relative;
    flex-direction: column;
    filter: opacity(1);
    flex: 1;
    min-height: 0;
}

.elfClass .classBox.switch {
    filter: opacity(0);
}

.elfClass .classBox .class {
    transition: filter.3s;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
    margin: 10px 10px;
    border-radius: 20px;
    background-color: #F6EDCFDD;
    box-shadow: 0 0 6px #3b361e;
    cursor: pointer;
}

.elfClass .classBox .classContent {
    height: 100%;
    overflow: auto;
}

.elfClass .classBox .class:has(input[type=checkbox]:checked) {
    filter: brightness(0.7);
}

.elfClass .classBox .class input[type=checkbox] {
    transition: background-color.3s;
    appearance: none;
    position: relative;
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: 30px;
    background-color: white;
    pointer-events: none;
}

.elfClass .classBox .class input[type=checkbox]:checked {
    background-color: #f6d922;
}

.elfClass .classBox .class input[type=checkbox]::after {
    transition: font-size.1s;
    content: "✓";
    position: absolute;
    font-size: 0px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.elfClass .classBox .class input[type=checkbox]:checked::after {
    font-size: 17px;
}

@keyframes selectElf {
    0% {
        width: 100px;
        box-shadow: 3px 3px 0 gray;
    }
    50% {
        width: 200px;
    }
    100% {
        width: 190px;
        box-shadow: 3px 3px 5px gray;
    }
}

@keyframes showFilterPanel {
    0% {
        background-color: #00000000;
    }
    100% {
        background-color: #00000070;
    }
}

@keyframes showFilterBox {
    0% {
        transform: scaleX(0.5) scaleY(0);
    }
    30% {
        transform: scaleX(0.97) scaleY(1.03);
    }
    60% {
        transform: scaleX(1.03) scaleY(0.97);
    }
    100% {
        transform: scaleX(1) scaleY(1);
    }
}

@keyframes showFilterButton {
    0% {
        scale: 0.5;
        filter: opacity(0);
    }
    100% {
        scale: 1;
        filter: opacity(1);
    }
}