@keyframes stripes {
    from {
        background-position: 0 0;
    }

    to {
        background-position: var(--stripe-calc) 0;
    }
}

:root {
    --stripe-width: 8em;
    --stripe-calc: calc(var(--stripe-width) * 1.41421356237);
    --anim-time: 8s;
}

[data-theme="light"] {
    --bg: #ffffff;
    --txt: #1c1c1c;
}

*::selection {
    background-color: var(--txt);
    color: var(--bg);
}



[data-theme="grapefruit"] {
    --bg: #fff1e6;
    --txt: #1c1c1c;
}
[data-theme="blue"] {
    --bg: #f0f8ff;
    --txt: #1c1c1c;
}

.musicFrame {
    display: none;
}

body[data-format="music"] .messages {
    height: 65vh;
    position: absolute;
    left: 15vw;
    top: 30vh;
    overflow-y: scroll;
    overflow-x: hidden;
    overflow-wrap: break-word;
    width: 85vw;
    font-size: 14px;
}

body[data-format="music"] .musicFrame {
    display: block;
    height: 30vh;
    width: 70vw;
    left: 20vw;
    position: absolute;
}

body[data-format="normal"] .musicFrame {
    display: none;
}

[data-theme="dark"] {
    --bg: #1a1a1e;
    --txt: white;
}

[data-theme="forest"] {
    --bg: #f1f8f1;
    --txt: #1c1c1c;
}

[data-theme="sunset"] {
    --bg: #fff3e0;
    --txt: #1c1c1c;
}

[data-theme="amethyst"] {
    --bg: #f3e5f5;
    --txt: #1c1c1c;
}

[data-theme="greyscale"] {
    --bg: #f5f5f5;
    --txt: #212121;
}

[data-theme="mint"] {
    --bg: #e0f2f1;
    --txt: #1c1c1c;
}

h1 {
    color: var(--txt);
}

a {
    color: var(--txt);
    text-decoration: underline double var(--txt) 1px;
}
a:hover {
    color: var(--txt);
    text-decoration: underline dashed var(--txt) 1px;
}
a:visited {
    color: var(--txt);
    text-decoration: underline solid var(--txt) 1px;
}
a:focus {
    color: var(--txt);
    text-decoration: underline solid var(--txt) 2px;
}

.sendput {
    font-family: inherit;
    border: 0;
    background-color: var(--bg);
    position: absolute;
    bottom: 5px;
    width: 20%;
    min-width: 200px;
    left: calc(15vw + 50px);
    outline: 0;
    color: var(--txt);
}
.sendput:focus {
    outline: 0;
}

.roomsList {
    list-style: none;
    padding-left: 0;
    margin-left: 0;
}

.roomsTitle {
    margin-left: 10px;
}

.roomsList li {
    cursor: pointer;
    width: calc(100% - 10px);
    margin-right: 3px;
    box-sizing: border-box;
    height: 30px;
    display: flex;
    align-items: center;
    padding-left: 10px;
}

.roomsList li:hover {
    text-decoration: underline;
}

.roomsListDiv {
    margin-left: 1vw;
}

.room {
    border-radius: 7px;
    padding: 0.5px;
    margin-top: 2px;
    padding-top: 1px;
    padding-bottom: 1px;
    font-size: 17px;
    bottom: 4px;
}

.roomActive {
    display: block;
    width: 100%;
    border-radius: 7px;
    padding: 0.5px;
    margin-top: 2px;
    padding-top: 1px;
    padding-bottom: 1px;
    font-size: 17px;
    color: var(--txt);
    font-weight: bold;
}

.rooms {
    top: 0px;
    height: 100vh;
    width: 13vw;
    color: var(--txt);
    overflow: hidden;
    background-color: var(--bg);
    margin: 0px;
    position: absolute;
    left: 0px;
    border-right: 2px var(--txt) solid;
}

.messages[data-theme="normal"] {
    height: 80vh;
    overflow-y: scroll;
    overflow-x: hidden;
    overflow-wrap: break-word;
    width: 85vw;
    font-size: 14px;
}

body {
    background-color: var(--bg);
    font-family: "Courier New", monospace, serif;
    overflow: hidden;
}

.usernameBg {
    color: var(--txt);
    font-weight: bold;
    margin-bottom: 2px;
}

@media (max-width: 500px) {
    .desktopDiv {
        display: none;
        color: var(--txt);
        position: absolute;
        left: 30px;
        top: 20vh;
    }

    .themesDiv {
        display: none;
    }

    .rooms {
        display: none;
        width: 50vw;
        overflow: scroll;
    }

    .sendput {
        bottom: 30px;
    }

    .showUsersMobile,
    .showRoomsMobile {
        display: block;
        position: absolute;
        right: 5px;
    }

    .showUsersMobile {
        bottom: 30px;
    }

    .showRoomsMobile {
        bottom: 60px;
    }
}

@media (min-width: 500px) {
    .desktopDiv {
        color: var(--txt);
        position: absolute;
        right: 5px;
        top: 5px;
    }

    .showUsersMobile,
    .showRoomsMobile {
        display: none;
    }

    .messages {
        height: 85vh;
        position: absolute;
        left: 15vw;
        top: 80px;
    }

    .sendput {
        left: calc(15vw + 50px);
    }
}

.messages div {
    display: flex;
    align-items: flex-start;
    margin-bottom: 0px;
}

.avatar {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin-right: 10px;
    flex-shrink: 0;
    border: 2px solid var(--txt);
}

.msgContent {
    display: flex;
    flex-direction: column;
    /*background-color: var(--bg-accent);*/
    padding: 5px 10px;
    border-radius: 5px;
    max-width: 80%;
    word-wrap: break-word;
}

.msgText {
    color: var(--txt);
}

.messages::-webkit-scrollbar {
    width: 8px;
}

.messages::-webkit-scrollbar-thumb {
    background-color: var(--txt);
    border-radius: 4px;
}

.messages::-webkit-scrollbar-track {
    background: transparent;
}

.messages div p {
    line-height: 1.6;
}

.userP {
    color: var(--txt);
}

.iden {
    display: none;
}

#messages.showIden .iden {
    display: inline;
}

#messages[data-show="true"] div p .iden {
    display: inline;
    text-decoration: underline;
    font-size: 0.8em;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes wave {
    0% {
        transform: rotate(0deg) translateY(0px);
    }

    25% {
        transform: rotate(5deg) translateY(-2px);
    }

    50% {
        transform: rotate(0deg) translateY(0px);
    }

    75% {
        transform: rotate(-5deg) translateY(2px);
    }

    100% {
        transform: rotate(0deg) translateY(0px);
    }
}

@keyframes glitch {
    0% {
        text-shadow:
            2px 0 red,
            -2px 0 blue;
    }

    20% {
        text-shadow:
            -2px 0 red,
            2px 0 blue;
    }

    40% {
        text-shadow:
            2px 0 red,
            -2px 0 blue;
    }

    60% {
        text-shadow:
            -2px 0 red,
            2px 0 blue;
    }

    80% {
        text-shadow:
            2px 0 red,
            -2px 0 blue;
    }

    100% {
        text-shadow: none;
    }
}

.glitch {
    position: relative;
    animation: glitch 1s infinite;
}

.spoiler {
    background: var(--txt);
    color: var(--txt);
    cursor: pointer;
}

.spoiler:hover {
    color: var(--bg);
}

@keyframes shake {
    0%,
    100% {
        transform: translateX(0);
    }

    25% {
        transform: translateX(-3px);
    }

    50% {
        transform: translateX(3px);
    }

    75% {
        transform: translateX(-3px);
    }
}

.shake {
    display: inline-block;
    animation: shake 0.5s infinite;
}

@keyframes bounce {
    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-8px);
    }
}

.bounce {
    display: inline-block;
    animation: bounce 0.8s infinite;
}

@keyframes fade {
    0%,
    100% {
        opacity: 0;
    }

    50% {
        opacity: 1;
    }
}

.fade {
    animation: fade 2s infinite;
}

.rainbowtext {
    background: linear-gradient(
        90deg,
        red,
        orange,
        yellow,
        green,
        blue,
        indigo,
        violet
    );
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: rainbowShift 3s linear infinite;
}

@keyframes rainbowShift {
    to {
        background-position: 200% center;
    }
}

@keyframes glow {
    from {
        text-shadow: 0 0 5px #ff66cc;
    }

    to {
        text-shadow: 0 0 20px #ff66cc;
    }
}

.glow {
    animation: glow 1.5s infinite alternate;
}

@keyframes zoom {
    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.5);
    }
}

.zoom {
    display: inline-block;
    animation: zoom 1s infinite;
}

/* ----POPUP STYLES---- */
#popupDivWrapper {
    position: fixed;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    top: 0;
    left: 0;
    z-index: 10;
    box-sizing: border-box;
    pointer-events: none;
    margin: 0;
    padding: 0;
}

#popupDiv {
    position: relative;
    height: 100%;
    width: 100%;
    margin: 0;
    padding: 0;
    pointer-events: none;
    z-index: 11;
}

#popupDiv:has(.popup[data-shown="true"]) {
    pointer-events: auto;
    background-color: color-mix(in srgb, var(--bg) 80%, transparent);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
}

.popup {
    visibility: hidden;
    position: absolute;
    height: 10rem;
    width: 30rem;
    max-height: 100dvh;
    max-width: 100dvw;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: var(--bg);
    z-index: 12;
    padding: 5px;
    box-sizing: border-box;
    margin: 0;
    border: 2px solid var(--txt);
    border-radius: 1rem;
    overflow: hidden;
    color: var(--txt);
}

.popup[data-shown="true"] {
    visibility: visible;
}

.popup .text {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow-y: scroll;
    overflow-wrap: break-word;
    overflow-x: hidden;
    box-sizing: border-box;
    cursor: default;
    padding-bottom: 2.5em;
    user-select: none;
    padding-top: 1em;
    padding-left: 0.5em;
    padding-right: 0.5em;
}

.popup .text * {
    margin: 0;
    user-select: none;
}

.popup .buttons {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    box-sizing: border-box;
    padding: 10px;
    display: flex;
    flex-wrap: nowrap;
    overflow-x: scroll;
    overflow-y: hidden;
}

.popup .buttons button {
    cursor: pointer;
    text-transform: uppercase;
}

.buttons input,
.buttons button {
    background-color: var(--bg);
    color: var(--txt);
    margin: 0px 5px;
    font-family: inherit;
    border: 1px solid var(--txt);
    border-radius: 5px;
    padding: 5px;
    font-weight: bold;
}

.fullWrapper {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.themesDiv {
    color: var(--txt);
    position: absolute;
    bottom: 20px;
    padding: 0px;
    left: 75%;
    width: fit-content;
    height: 10px;
    transition: height 0.5s;
}

.themes {
    color: inherit;
    text-decoration: underline;
}

.themesDiv li {
    font-size: inherit + 4px;
}

.themesDiv:hover {
    height: 225px;
}

.themesDiv li {
    list-style: none;
    cursor: pointer;
    padding: 2px 5px;

    margin-top: 2px;
    width: fit-content;
}

/* SECTION special theme modifiers */

[data-theme="greyscale"] img {
    filter: grayscale(1);
}


/* !SECTION */
