/*
* Datei: /css/app.css
* Beschreibung: Zentrale Grundgestaltung der App.
*/
:root {
    --hintergrund: #101820;
    --flaeche: #182533;
    --flaeche2: #223246;
    --linie: #314357;
    --text: #f3f7fb;
    --text2: #9fb0c2;
    --akzent: #39c177;
    --fehler: #df5b57;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
    box-sizing: border-box
}

body {
    margin: 0;
    background: var(--hintergrund);
    color: var(--text)
}

button,
input {
    font: inherit
}

button {
    border: 0;
    border-radius: 8px;
    background: var(--akzent);
    color: #06120b;
    padding: 11px 13px;
    font-weight: 700
}

button.sekundaer {
    background: var(--flaeche2);
    color: var(--text);
    border: 1px solid var(--linie)
}

input {
    width: 100%;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
    color: var(--text);
    padding: 12px;
    font-size: 16px
}

h1 {
    font-size: 28px;
    line-height: 1.1;
    margin: 0 0 8px
}

h2 {
    font-size: 22px;
    margin: 0 0 8px
}

p {
    color: var(--text2)
}

.app {
    min-height: 100svh
}

.bildschirm {
    display: none;
    min-height: 100svh
}

.bildschirm.aktiv {
    display: block
}

.login-box {
    width: min(420px, calc(100% - 28px));
    margin: 0 auto;
    padding-top: 12svh
}

form {
    display: grid;
    gap: 12px
}

label {
    display: grid;
    gap: 6px;
    color: var(--text2);
    font-size: 14px
}

.meldung {
    min-height: 22px;
    color: var(--fehler)
}

#app-bildschirm.aktiv {
    display: grid;
    grid-template-rows: auto 1fr auto
}

.app-kopf {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px;
    border-bottom: 1px solid var(--linie);
    background: var(--flaeche)
}

.app-kopf span {
    display: block;
    color: var(--text2);
    font-size: 13px
}

.inhalt {
    padding: 12px 12px 78px
}

.karte {
    background: var(--flaeche);
    border: 1px solid var(--linie);
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 10px
}

.app-fuss {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    background: #0d151c;
    border-top: 1px solid var(--linie)
}

.navigation {
    display: flex;
    gap: 6px;
    overflow: auto;
    padding: 8px
}

.navigation button {
    white-space: nowrap;
    border: 1px solid var(--linie);
    background: var(--flaeche);
    color: var(--text);
    padding: 9px 10px;
    font-size: 14px
}

.navigation button.aktiv {
    background: var(--akzent);
    color: #06120b;
    border-color: var(--akzent)
}

@media (min-width:760px) {
    #app-bildschirm.aktiv {
        grid-template-rows: auto auto 1fr
    }

    .app-fuss {
        position: static;
        grid-row: 2
    }

    .inhalt {
        padding: 16px
    }

    .navigation {
        justify-content: flex-start
    }
}