* {
    box-sizing: border-box;
}

body {
    display: flex;
    flex-direction: column;
    height: 100vh;
    width: 100vw;
    margin: 0;

    padding: 5rem 1rem 1rem 16rem;
}

html {
    font-family: 'Open Sans', sans-serif;
    font-size: 15px;
}

.form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 2rem;
}

h1, h2, h3, h4, h5, h6, .button {
    font-family: Goldman, sans-serif;
}

h1, h2, h3, h4, h5, h6, p {
    margin: 0;
}

textarea {
    min-height: 200px;
}

.alert {
    color: var( --sng-brand-white );
    padding: 0.25rem 0.4rem;
    font-weight: 500;
}

    .alert.success { background: var( --sng-brand-success ); }
    .alert.error { background: var( --sng-brand-danger ); }

header {
    display: flex;
    position: fixed;
    top: 0;
    left: 0rem;
    width: 100vw;
}

    header h1 {
        background: var( --sng-brand-primary );
        color: var( --sng-brand-white );
        padding: 1rem 1.5rem;
        font-size: 2rem;
        line-height: 1em;
        width: 100%;
    }

    header img {
        padding: 1rem;
        width: 15rem;
    }


aside {
    position: fixed;
    display: flex;
    flex-direction: column;
    left: 0;
    top: 4rem;
    bottom: 0;
    width: 15rem;
    background: var( --sng-brand-gray-light );
    gap: 1px;
}

    aside .button {
        border: none;
        display: flex;
        align-items: center;
        padding: 0 0.75rem;
        margin: 0;
        font-size: 1rem;
        height: 2.5rem;
        line-height: 1.1rem;
        outline: none;
        text-decoration: none;
        cursor: pointer;
        text-align: left;
        background: var( --sng-brand-gray );
        color: var( --sng-brand-black );
        font-family: "Goldman", sans-serif;
    }

        aside .button.active {
            font-size: 1.2rem;
            background: var( --sng-brand-primary );
        }

        aside .button:hover {
            background: var( --sng-brand-gray-hover );
        }

main {
    width: 100%;
    height: 100%;
    overflow: scroll;
    border: solid 1px var( --sng-brand-black );
    padding: 1rem;
}

    main form {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        max-width: 800px;
        min-height: 100%;
    }

        main form h3 {
            font-size: 1.5rem;
        }

            main form h3.statistics {
                display: flex;
                justify-content: space-between;
                align-items: flex-end;
                border-bottom: 1px dotted var( --sng-brand-black );
            }

                main form h3.statistics strong {
                    font-size: 200%;
                    bottom: -7px;
                    position: relative;
                }

        main form h4 {
            font-size: 1rem;
        }

        main form h3:not(:first-child),
        main form .button:not(:first-child) {
            margin-top: 2rem;
        }

        main form .button {
            border: 0;
            padding: 0.75rem 1rem;
            font-size: 1.5rem;
            background: var( --sng-brand-primary );
            color: var( --sng-brand-white );
            cursor: pointer;
            text-align: center;
        }

            main form .button:hover {
                background: var( --sng-brand-primary-hover );
            }

        main form input {
            border: solid 2px var( --sng-brand-gray-hover );
            padding: 0.3rem 0.5rem;
        }

            main form input:focus,
            main form input:hover {
                outline: 0;
                border-color: var( --sng-brand-primary-hover );
            }

        main form label {
            position: relative;

        }

            main form label.checkbox {
                cursor: pointer;
                padding: 0.25rem 0.25rem 0.25rem 2rem;
            }

            main form label.checkbox input {
                position: absolute;
                top: 0.25rem;
                left: 0.25rem;
            }

            main form label:hover {
                background: var( --sng-brand-primary-hover );
            }

        main .scanner {
            position: relative;
            display: none;
            flex-direction: column;
        }

            main .scanner .scanner-list {
                display: flex;
                max-width: calc( 75% - 1rem );
                flex-direction: column;
                gap: 0.5rem;
            }

            main .scanner .video {
                position: absolute !important;
                background: #181818;
                right: 0;
                aspect-ratio: 1;
                max-width: 25%;
                height: 100px;
                width: 100px;
                top: 0;
            }

                main .scanner .video video {
                    max-width: 100%;
                    height: 100%;
                    aspect-ratio: 1;
                    object-fit: cover;
                    object-position: center;
                }

    main .frame {
        margin: -1rem -1rem 1rem -1rem;
        flex-direction: column;
        display: flex;
        gap: 1px;
    }

        main .frame .video {
            position: relative;
            padding-top: calc( 100% / 16 * 9 );
            background: var( --sng-brand-black );
        }

            main .frame .video video {
                position: absolute;
                display: block;
                top: 0;
                left: 0;
                right: 0;
                bottom: 0;
                width: 100%;
                height: 100%;
                object-fit: cover;
                object-position: center;
            }

        main .frame .buttons {
            display: flex;
            gap: 1px;
        }

            main .frame .buttons .button {
                margin-top: 0 !important;
                flex: 1 1 100%;
            }

    main .results {
        height: 100%;
        flex: 1 1 auto;
        display: flex;
    }

        main .results .result {
            display: none;
            border: 1rem solid var( --sng-brand-gray-light );
            padding: 1rem;
            flex: 1 1 auto;
            flex-direction: column;
            align-items: center;
            gap: 1rem;
        }

            main .results .result h3 {
                align-items: center;
                display: flex;
                gap: 1rem;
            }

                main .results .result h3 .bi { font-size: 2em; }

            main .results .result p[rel=ticket-event] {
                font-weight: 600;
                text-align: center;
            }

            main .results .result.active { display:flex; }

            main .results .result.waiting { border-color: var( --sng-brand-gray ); }
            main .results .result.waiting h3 { color: var( --sng-brand-gray ); }

            main .results .result.success { border-color: var( --sng-brand-success ); }
            main .results .result.success h3 { color: var( --sng-brand-success ); }

            main .results .result.error { border-color: var( --sng-brand-danger ); }
            main .results .result.error h3 { color: var( --sng-brand-danger ); }

    main .scandata {
        background: var( --sng-brand-black );
        margin: 0;
        margin-top: 1rem;
        min-height: 2rem;
        color: var( --sng-brand-white );
        padding: 0.25rem 0.5rem;
        display: flex;
        align-items: center;
    }

@media ( max-width: 800px ) {
    body {
        display: flex;
        flex-direction: column;
        padding: 8rem 1rem 1rem;
    }

    header img {
        display: none;
    }

    aside {
        bottom: auto;
        width: 100vw;
        flex-direction: row;
        padding-top: 1px;
    }

        aside .button {
            flex: 1 1 100%;
            justify-content: center;
            align-items: center;
            text-align: center;
        }
}

@media ( min-width: 800px ) {
    body.scan main {
    }
        body.scan main form {
            display: grid;
            gap: 1rem;
            grid-template-columns: 1fr 1fr;
            max-width: 100%;
            grid-template-rows: 1fr 2rem;
        }

        body.scan main form .frame {
            grid-row: 1 / 3;
            margin: -1rem 0rem -1rem -1rem;
            display: grid;
            grid-template-rows: 1fr 4rem;
        }

        body.scan main form .results {
            grid-column: 2 / 3;
            grid-row: 1 / 2;
        }

        body.scan main form .scandata {
            margin: 0;
            grid-column: 2 / 3;
            grid-row: 2 / 3;
        }

}

