﻿@import url("../coreware/coreware.1.1.css");
@import url("../soline/soline.1.1.css");

:root {
    --pixel: min(1dvh, 1.66666dvw);
    --fixel: 5px;
    --nixel: calc(var(--pixel) * -1);
    --dixel: calc(var(--pixel) * 2);
    --hixel: calc(var(--pixel) * 0.5);
    --size: calc(var(--pixel) * 100);
    --desk-back-img: linear-gradient(#000, #A1A3, #000, #136, #000);
    --form-height: 9%;
    --font-size: var(--pixel);
    --font-family: "Roboto";
}

body {
    background-color: #050b15;
    background-image: url("home/back.png");
    background-size: 100% 100%;
    background-attachment: fixed;
    padding: var(--pixel);
}

body, td, input, select {
    font-family: var(--font-family);
    font-size: var(--font-size);
    color: #FFF;
}

.fc {
    align-items: center;
}

.fade {
    opacity: 0.5;
}

.gap {
    gap: var(--pixel);
}

.big {
    font-size: calc(var(--pixel) * 3);
}

.med {
    font-size: calc(var(--pixel) * 2);
}

canvas.shader-canvas {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

div.banner {
    position: relative;
    min-width: 0;

    .logo {
        width: calc(var(--pixel) * 5);
        aspect-ratio: 1;
        background-image: url("home/soline.svg");
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        flex: 0 0 auto;
    }

    canvas {
        mix-blend-mode: lighten;
    }
}

.icon {
    width: calc(var(--pixel) * 3);
    aspect-ratio: 1;
    border-radius: var(--hixel);
    background-color: #FFF1;
    background-position: center;
    background-repeat: no-repeat;
    background-size: auto 85%;
    flex: 0 0 auto;
}

main {
    display: flex;
    flex-direction: column;
    gap: var(--pixel);
    align-items: center;

    > * {
        width: 100%;
        max-width: calc(var(--pixel) * 100);
        overflow: auto;
    }

    > .header {
        display: flex;
        flex-direction: row;
        gap: var(--pixel);
        align-items: stretch;

        > .banner {
            flex: 2 1 auto;
            min-width: 0;
            min-height: 100%;
        }

        > .header-column {
            flex: 1 1 auto;
            min-width: 0;
            display: flex;
            flex-direction: column;
            gap: var(--pixel);

            > .header-card {
                min-width: 0;
                flex: 1 1 auto;
            }
        }
    }

    > .buttons {
        display: flex;
        padding: calc(var(--pixel) * 0.8);
        gap: calc(var(--pixel) * 0.8);
        overflow: auto;
        justify-content: center;
        align-items: center;
        font-size: 120%;
    }

    > .body {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: var(--pixel);
    }
}

.game {
    display: flex;
    flex-direction: column;
    gap: var(--pixel);
    min-width: 0;
    transition: filter 200ms linear;

    &:hover {
        cursor: pointer;
        filter: brightness(1.5);
    }

    .thumb {
        position: relative;
        width: 100%;
        aspect-ratio: 6 / 4;
        border-radius: calc(var(--pixel) * 0.8);
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        border: calc(var(--pixel) * 0.1) solid #FFF3;
        box-shadow: var(--pixel) var(--pixel) var(--pixel) var(--nixel) #FFF4 inset, var(--nixel) var(--nixel) var(--pixel) var(--nixel) #0006 inset, 0px 0px var(--hixel) #0004;

        > .object {
            position: absolute;
            background-position: center;
            background-size: contain;
            background-repeat: no-repeat;
        }
    }

    .badge {
        position: absolute;
        top: -2.5%;
        left: -2%;
        height: 50%;
        aspect-ratio: 1;
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
    }

    .info > span {
        display: flex;
        flex-wrap: wrap;
        gap: var(--hixel);

        div {
            display: inline-block;
            padding: calc(var(--pixel) * 0.25) calc(var(--pixel) * 0.7);
            border-radius: var(--pixel);
            background: rgba(255, 255, 255, 0.08);
            border: 1px solid rgba(255, 255, 255, 0.10);
            opacity: 0.85;
        }
    }

    &[data-game="Comandante"] {
        .thumb .object {
            height: 50%;
            aspect-ratio: 200 / 87;
            bottom: 25%;
            right: 0px;
            transform: rotate(-30deg);
            background-image: url(home/Comandante/object.png);
            animation: comandante 15s ease-in-out infinite;
        }
    }
}

.button {
    display: inline-flex;
    padding: var(--hixel) var(--pixel);
    border-radius: var(--pixel);
    background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03) 35%, rgba(255,255,255,0.01) 100%), linear-gradient(180deg, rgba(20,32,55,0.88), rgba(12,20,36,0.94));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 10px 30px rgba(0,0,0,0.25);
    border: calc(var(--pixel) * 0.1) solid #FFF3;
    white-space: nowrap;

    &.sel,
    &.active {
        color: #123;
        background: #FFFA;
    }

    &:hover {
        cursor: pointer;
        color: #123;
        background: #FFF6;
    }
}

.glass {
    padding: var(--pixel);
    border-radius: var(--pixel);
    position: relative;
    background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03) 35%, rgba(255,255,255,0.01) 100%), linear-gradient(180deg, rgba(20,32,55,0.88), rgba(12,20,36,0.94));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 10px 30px rgba(0,0,0,0.25);
    overflow: hidden;

    &::before {
        content: "";
        position: absolute;
        inset: 0;
        border-radius: inherit;
        padding: calc(var(--pixel) * 0.15);
        background: linear-gradient(135deg, #FFF3, #FFF0);
        -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
        -webkit-mask-composite: xor;
        mask-composite: exclude;
        pointer-events: none;
    }
}

@media (max-aspect-ratio: 2/3) {
    main > .header {
        flex-direction: column;

        > .header-column {
            flex-direction: row;

            > .header-card {
                flex: 1 1 0;
            }
        }
    }
}

@media (max-width: 900px) {
    main {
        > .body {
            grid-template-columns: repeat(3, minmax(0, 1fr));
        }
    }
}

@media (max-width: 600px) {
    main {
        > .body {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }
    }
}

@media (max-width: 300px) {
    main {
        > .body {
            grid-template-columns: repeat(1, minmax(0, 1fr));
        }
    }
}
