@tailwind base;
@tailwind components;
@tailwind utilities;

:root {
    font-family: "Press Start 2P", VT323, Courier New, monospace;
    line-height: 1.6;
    font-weight: 400;
    color-scheme: light dark;
    --color-primary: #11d462;
    --color-primary-dark: #0ba34a;
    --color-background-dark: #0a1f13;
    --color-background-light: #f8f9fa;
    font-synthesis: none;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: auto;
    image-rendering: pixelated
}

.pixel-border {
    border: 3px solid #000 !important;
    border-radius: 0 !important;
    box-shadow: 3px 3px #000
}

.pixel-border-white {
    border: 3px solid #fff !important;
    border-radius: 0 !important;
    box-shadow: 3px 3px #ffffff4d
}

.pixel-border-primary {
    border: 3px solid var(--color-primary) !important;
    border-radius: 0 !important
}

.shadow-pixel {
    box-shadow: 4px 4px #000 !important
}

.shadow-pixel-sm {
    box-shadow: 2px 2px #000 !important
}

.shadow-pixel-dark {
    box-shadow: 4px 4px #00000080 !important
}

.shadow-pixel-primary {
    box-shadow: 4px 4px 0 var(--color-primary) !important
}

.shadow-pixel-primary-inset {
    box-shadow: inset 0 0 0 2px var(--color-primary) !important
}

button,
input,
select,
textarea,
.rounded,
.rounded-lg,
.rounded-md,
.rounded-sm,
.rounded-xl,
.rounded-2xl,
.rounded-full {
    border-radius: 0 !important
}

.btn-pixel-green {
    background-color: var(--color-primary);
    color: #000;
    border: 3px solid #000;
    border-radius: 0 !important;
    box-shadow: 3px 3px #000;
    padding: 10px 20px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    cursor: pointer;
    transition: transform .1s, box-shadow .1s
}

.btn-pixel-green:hover {
    transform: translate(-1px, -1px);
    box-shadow: 4px 4px #000
}

.btn-pixel-green:active {
    transform: translate(2px, 2px);
    box-shadow: 1px 1px #000
}

.btn-pixel-light {
    background-color: #fff;
    color: #000;
    border: 3px solid #000;
    border-radius: 0 !important;
    box-shadow: 3px 3px #000;
    padding: 10px 20px;
    cursor: pointer
}

body {
    margin: 0;
    min-width: 320px;
    min-height: 100vh;
    background-color: var(--color-background-light)
}

@media(prefers-color-scheme:dark) {
    body {
        background-color: var(--color-background-dark);
        color: #fff
    }
}

a {
    font-weight: 500;
    color: var(--color-primary);
    text-decoration: none
}

a:hover {
    text-decoration: underline
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Press Start 2P", monospace;
    letter-spacing: 2px
}

.image-rendering-pixelated,
img.pixel {
    image-rendering: pixelated;
    image-rendering: -moz-crisp-edges;
    image-rendering: crisp-edges
}

.grid-responsive {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem
}

@media(min-width:640px) {
    .grid-responsive {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media(min-width:1024px) {
    .grid-responsive {
        grid-template-columns: repeat(3, 1fr)
    }
}

@media(min-width:1280px) {
    .grid-responsive {
        grid-template-columns: repeat(4, 1fr)
    }
}

@media(max-width:639px) {
    .container {
        padding-left: 1rem;
        padding-right: 1rem
    }

    .mobile-full-width {
        width: 100% !important;
        max-width: 100% !important
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0;
        transform: translateY(-10px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.animate-fadeIn {
    animation: fadeIn .3s ease-out
}

@keyframes pixelBlink {

    0%,
    to {
        opacity: 1
    }

    50% {
        opacity: 0
    }
}

.animate-pixel-blink {
    animation: pixelBlink 1s step-end infinite
}