/*! tailwindcss v3.4.10 | MIT License | https://tailwindcss.com*/
*,:after,:before {
    box-sizing: border-box;
    border: 0 solid #e5e7eb
}

:after,:before {
    --tw-content: ""
}

:host,html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    font-family: ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;
    font-feature-settings: normal;
    font-variation-settings: normal;
    -webkit-tap-highlight-color: transparent
}

body {
    margin: 0;
    line-height: inherit
}

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1,h2,h3,h4,h5,h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    text-decoration: inherit
}

b,strong {
    font-weight: bolder
}

code,kbd,pre,samp {
    font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;
    font-feature-settings: normal;
    font-variation-settings: normal;
    font-size: 1em
}

small {
    font-size: 80%
}

sub,sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse
}

button,input,optgroup,select,textarea {
    font-family: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    font-size: 100%;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
    margin: 0;
    padding: 0
}

button,select {
    text-transform: none
}

button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]) {
    -webkit-appearance: button;
    appearance: button;
    background-color: transparent;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

:-moz-ui-invalid {
    box-shadow: none
}

progress {
    vertical-align: baseline
}

::-webkit-inner-spin-button,::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre {
    margin: 0
}

fieldset {
    margin: 0
}

fieldset,legend {
    padding: 0
}

menu,ol,ul {
    list-style: none;
    margin: 0;
    padding: 0
}

dialog {
    padding: 0
}

textarea {
    resize: vertical
}

input::-moz-placeholder,textarea::-moz-placeholder {
    opacity: 1;
    color: #9ca3af
}

input::placeholder,textarea::placeholder {
    opacity: 1;
    color: #9ca3af
}

[role=button],button {
    cursor: pointer
}

:disabled {
    cursor: default
}

audio,canvas,embed,iframe,img,object,svg,video {
    display: block;
}

img,video {
    max-width: 100%;
    height: auto
}

[hidden] {
    display: none
}

*,:after,:before {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59,130,246,.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59,130,246,.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

.glitch {
    position: relative;
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity));
    font-size: calc(.4vw + .4vh);
    letter-spacing: 1px;
    line-height: 1.2;
    text-shadow: 0 0 5px hsla(0,0%,100%,.7),0 0 10px hsla(0,0%,100%,.5),0 0 15px hsla(0,0%,100%,.3);
    animation: glitch-anim .7s infinite,color-change .7s infinite alternate-reverse
}

.glitch,.glitch:after,.glitch:before {
    overflow: hidden
}

.glitch:after,.glitch:before {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    content: attr(data-text);
    clip: rect(0,0,0,0);
    color: #fff
}

.glitch:before {
    animation: glitch-anim-before .7s infinite,color-change .7s infinite alternate-reverse
}

.glitch:after {
    animation: glitch-anim-after .7s infinite,color-change .7s infinite alternate-reverse;
    z-index: 2
}

@keyframes glitch-anim {
    0% {
        transform: translate(0)
    }

    20% {
        transform: translate(-5px,-5px)
    }

    40% {
        transform: translate(5px,5px)
    }

    60% {
        transform: translate(-5px,5px)
    }

    80% {
        transform: translate(5px,-5px)
    }

    to {
        transform: translate(0)
    }
}

@keyframes glitch-anim-before {
    0% {
        clip: rect(0,100%,0,0)
    }

    20% {
        clip: rect(0,100%,20%,0)
    }

    40% {
        clip: rect(20%,100%,40%,0)
    }

    60% {
        clip: rect(40%,100%,60%,0)
    }

    80% {
        clip: rect(60%,100%,80%,0)
    }

    to {
        clip: rect(0,100%,0,0)
    }
}

@keyframes glitch-anim-after {
    0% {
        clip: rect(0,0,0,0)
    }

    20% {
        clip: rect(0,100%,20%,0)
    }

    40% {
        clip: rect(20%,100%,40%,0)
    }

    60% {
        clip: rect(40%,100%,60%,0)
    }

    80% {
        clip: rect(60%,100%,80%,0)
    }

    to {
        clip: rect(0,100%,0,0)
    }
}

@keyframes color-change {
    0% {
        color: #fff
    }

    25% {
        color: #a3a3a3
    }

    50% {
        color: #a3a3a3
    }

    to {
        color: #fff
    }
}

@keyframes scrollBackground {
    0% {
        transform: translate(-1%,-1%)
    }

    to {
        transform: translate(-50%,-50%)
    }
}

body:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    height: 200%;
    width: 200%;
    overflow: hidden;
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0/var(--tw-bg-opacity));
    content: "";
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Ctext x='50%25' y='50%25' fill='%23fff' dominant-baseline='middle' font-family='monospace' font-size='40' text-anchor='middle' transform='rotate(45 100 100)'%3E(◣_◢)%3C/text%3E%3C/svg%3E");
    background-size: 150px 150px;
    background-repeat: repeat;
    filter: blur(4px);
    animation: scrollBackground 100s linear infinite
}

.ascii-container {
    position: relative;
    z-index: 1;
    display: inline-block;
    white-space: pre;
    text-align: center;
    font-size: 1.5vh
}

a {
    margin-top: 5px;
    display: inline-block;
    cursor: pointer;
    border-radius: .25rem;
    border-style: none;
    --tw-bg-opacity: 1;
    background-color: rgb(51 51 51/var(--tw-bg-opacity));
    padding: 5px 15px;
    text-align: center;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-text-opacity: 1;
    color: rgb(148 148 148/var(--tw-text-opacity));
    text-decoration-line: none;
    opacity: .7;
    outline-width: 1px;
    outline-color: #000;
    transition-property: all;
    transition-duration: .2s;
    transition-timing-function: cubic-bezier(.4,0,.2,1)
}

a:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(110 110 110/var(--tw-bg-opacity));
    opacity: 1
}

.mt-4 {
    margin-top: 1rem
}

.flex {
    display: flex
}

.inline-flex {
    display: inline-flex
}

.min-h-screen {
    min-height: 100vh
}

.touch-none {
    touch-action: none
}

.select-none {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.flex-col {
    flex-direction: column
}

.items-center {
    align-items: center
}

.justify-center {
    justify-content: center
}

.space-x-2>:not([hidden])~:not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-right: calc(.5rem*var(--tw-space-x-reverse));
    margin-left: calc(.5rem*(1 - var(--tw-space-x-reverse)))
}

.overflow-hidden {
    overflow: hidden
}

.rounded {
    border-radius: .25rem
}

.\!bg-stone-900 {
    --tw-bg-opacity: 1!important;
    background-color: rgb(28 25 23/var(--tw-bg-opacity))!important
}

.\!bg-opacity-50 {
    --tw-bg-opacity: 0.5!important
}

.p-2 {
    padding: .5rem
}

.text-center {
    text-align: center
}

.font-mono {
    font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem
}

.text-sm {
    font-size: .875rem;
    line-height: 1.25rem
}

.leading-none {
    line-height: 1
}

.\!text-stone-400 {
    --tw-text-opacity: 1!important;
    color: rgb(168 162 158/var(--tw-text-opacity))!important
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity))
}
