:root {
    color-scheme: light;
    --hintergrund: #f4f7f3;
    --flaeche: #ffffff;
    --linie: #d9e1dc;
    --text: #17211d;
    --gedaempft: #607069;
    --akzent: #116a62;
    --akzent-dunkel: #0c4d47;
    --warnung: #a25b13;
    --funk: #d6f05d;
    --schatten: 0 18px 50px rgba(17, 39, 30, 0.10);
}

* {
    box-sizing: border-box;
}

body {
    min-height: 100vh;
    margin: 0;
    display: flex;
    flex-direction: column;
    background: var(--hintergrund);
    color: var(--text);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.5;
}

a {
    color: inherit;
}

button,
input,
select,
textarea {
    font: inherit;
}

.kopfzeile {
    min-height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 0 32px;
    border-bottom: 1px solid var(--linie);
    background: rgba(255, 255, 255, 0.86);
    backdrop-filter: blur(12px);
}

.marke {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 800;
    text-decoration: none;
}

.marke__signal {
    width: 18px;
    height: 18px;
    border: 3px solid var(--akzent);
    border-radius: 50%;
    box-shadow: 0 0 0 5px rgba(17, 106, 98, 0.13);
}

.navigation {
    display: flex;
    align-items: center;
    gap: 14px;
}

.navigation a,
.navigation__knopf,
.navigation__aktion,
.primaerknopf,
.sekundaerknopf {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    padding: 0 16px;
    text-decoration: none;
    border: 1px solid transparent;
    cursor: pointer;
}

.navigation__knopf {
    background: transparent;
    color: var(--text);
}

.navigation__aktion,
.primaerknopf {
    background: var(--akzent);
    color: #ffffff;
    font-weight: 700;
}

.primaerknopf:hover,
.navigation__aktion:hover {
    background: var(--akzent-dunkel);
}

.sekundaerknopf {
    background: #ffffff;
    border-color: var(--linie);
    color: var(--text);
    font-weight: 700;
}

.inhalt {
    width: min(1120px, calc(100% - 32px));
    margin: 0 auto;
    padding: 48px 0;
    flex: 1;
}

.zugang,
.arbeitsflaeche {
    display: grid;
    gap: 28px;
}

.zugang {
    min-height: 420px;
    align-items: center;
    grid-template-columns: minmax(0, 1fr) auto;
}

.zugang__text {
    max-width: 680px;
}

.zugang h1,
.formularrahmen h1,
.arbeitsflaeche h1 {
    margin: 0;
    font-size: 2.2rem;
    line-height: 1.15;
    letter-spacing: 0;
}

.zugang p,
.mission p {
    color: var(--gedaempft);
}

.kennung {
    margin: 0 0 10px;
    color: var(--akzent);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0;
}

.zugang__aktionen {
    display: flex;
    gap: 12px;
    align-items: center;
}

.formularseite {
    display: grid;
    place-items: start center;
}

.formularrahmen {
    width: min(480px, 100%);
    padding: 28px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
    box-shadow: var(--schatten);
}

.formular {
    display: grid;
    gap: 18px;
    margin-top: 24px;
}

.formular__gruppe {
    display: grid;
    gap: 7px;
}

.formular label {
    font-weight: 700;
}

.formular input,
.formular select,
.filterleiste input,
.filterleiste select,
.kompaktformular select,
.kompaktformular textarea {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    padding: 8px 11px;
    background: #fbfdfc;
}

.formular input:focus,
.formular select:focus,
.filterleiste input:focus,
.filterleiste select:focus,
.kompaktformular select:focus,
.kompaktformular textarea:focus {
    outline: 3px solid rgba(17, 106, 98, 0.18);
    border-color: var(--akzent);
}

.kompaktformular textarea {
    min-width: 220px;
    resize: vertical;
}

.formular__hilfe {
    margin: 0;
    color: var(--gedaempft);
    font-size: 0.92rem;
}

.formular__fehler,
.formular__fehlerblock {
    margin: 0;
    color: #9f2727;
    font-weight: 700;
}

.meldungen {
    display: grid;
    gap: 10px;
    margin-bottom: 24px;
}

.meldung {
    margin: 0;
    padding: 12px 14px;
    border-radius: 8px;
    background: #e9f7ef;
    border: 1px solid #b9dfc8;
}

.arbeitsflaeche__kopf,
.bereich__kopf,
.mission,
.kennzahlen {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.statusmarke {
    border-radius: 8px;
    padding: 6px 10px;
    background: #fff7df;
    color: var(--warnung);
    font-weight: 800;
    white-space: nowrap;
}

.statusmarke--offen {
    background: #eef3ef;
    color: #4f6259;
}

.statusmarke--gestartet {
    background: #e6f3ff;
    color: #245f8f;
}

.statusmarke--abgeschlossen {
    background: #e9f7ef;
    color: #1f6b40;
}

.statusmarke--wiederholen {
    background: #fff1e2;
    color: var(--warnung);
}

.kennzahlen {
    align-items: stretch;
}

.kennzahl {
    flex: 1;
    min-height: 108px;
    display: grid;
    align-content: center;
    gap: 4px;
    padding: 20px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
}

.kennzahl__wert {
    font-size: 2rem;
    line-height: 1;
    font-weight: 850;
}

.kennzahl__label {
    color: var(--gedaempft);
}

.lernpfadstand {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 280px);
    gap: 22px;
    align-items: center;
    padding: 22px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
    box-shadow: var(--schatten);
}

.lernpfadstand h2,
.lernpfadstand p {
    margin: 0;
}

.lernpfadstand p {
    color: var(--gedaempft);
}

.lernpfadstand__aktion {
    display: grid;
    gap: 10px;
}

.lernpfadstand__aktion strong {
    font-size: 1.85rem;
    line-height: 1;
}

.fortschrittsbalken {
    height: 14px;
    overflow: hidden;
    border-radius: 8px;
    background: #edf2ef;
    border: 1px solid var(--linie);
}

.fortschrittsbalken span {
    display: block;
    height: 100%;
    border-radius: 8px;
    background: linear-gradient(90deg, #116a62, #61a66b);
}

.bereich {
    display: grid;
    gap: 16px;
}

.szenenliste {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
}

.szene {
    display: grid;
    gap: 4px;
    padding: 13px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
}

.szene span {
    color: var(--gedaempft);
}

.abzeichenliste {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.abzeichen {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 16px;
    border: 1px solid #d3c77f;
    border-radius: 8px;
    background: #fffbe7;
}

.abzeichen h3,
.abzeichen p {
    margin: 0;
}

.abzeichen p {
    color: #665f32;
}

.abzeichen__symbol {
    width: 38px;
    height: 38px;
    display: inline-grid;
    place-items: center;
    border-radius: 50%;
    background: #f0d85d;
    color: #3f370e;
    font-weight: 900;
}

.filterleiste {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(180px, 1fr) auto auto;
    gap: 12px;
    align-items: end;
    padding: 16px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
}

.filterleiste label,
.kompaktformular label {
    display: grid;
    gap: 6px;
    font-weight: 800;
}

.filterleiste label span,
.kompaktformular label span {
    color: var(--gedaempft);
    font-size: 0.9rem;
}

.bereich h2,
.mission h3 {
    margin: 0;
}

.missionsliste {
    display: grid;
    gap: 12px;
}

.mission {
    padding: 18px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
}

.mission--klickbar {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
}

.mission__nummer {
    width: 34px;
    height: 34px;
    display: inline-grid;
    place-items: center;
    border-radius: 50%;
    background: #eef8f5;
    color: var(--akzent);
    font-weight: 850;
}

.mission__lernziel {
    color: var(--text);
    font-weight: 700;
}

.mission__aktionen {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.mission p {
    margin: 6px 0 0;
}

.missionskarte {
    display: grid;
    gap: 22px;
    padding: 26px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
    box-shadow: var(--schatten);
}

.missionskarte > p {
    margin: 0;
    color: var(--gedaempft);
}

.lernzielbox,
.merkkasten,
.abzeichenhinweis {
    display: grid;
    gap: 5px;
    padding: 15px;
    border: 1px solid #c7d8d2;
    border-radius: 8px;
    background: #f3faf7;
}

.abzeichenhinweis {
    border-color: #d3c77f;
    background: #fffbe7;
}

.lernzielbox strong,
.lernzielbox p,
.merkkasten strong,
.merkkasten p,
.abzeichenhinweis strong,
.abzeichenhinweis p {
    margin: 0;
}

.lernzielbox p,
.merkkasten p,
.abzeichenhinweis p {
    color: var(--gedaempft);
}

.missionsformular fieldset {
    display: grid;
    gap: 16px;
    margin: 0;
    padding: 0;
    border: 0;
}

.missionsformular legend {
    padding: 0;
    font-size: 1.25rem;
    font-weight: 850;
    line-height: 1.3;
}

.antwortauswahl {
    display: grid;
    gap: 10px;
}

.antwortoption {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: #fbfdfc;
    cursor: pointer;
}

.antwortoption input {
    width: 18px;
    min-height: 18px;
    margin-top: 3px;
    accent-color: var(--akzent);
}

.logbuchkontakt {
    display: grid;
    gap: 4px;
    padding: 14px;
    border: 1px solid #c7d8d2;
    border-radius: 8px;
    background: #eef8f5;
}

.logbuchkontakt span {
    color: var(--gedaempft);
    font-size: 0.9rem;
    font-weight: 800;
}

.logbuchkontakt strong {
    overflow-wrap: anywhere;
}

.logbuchraster {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.zuordnungsliste,
.reihenfolge {
    display: grid;
    gap: 10px;
}

.zuordnungszeile {
    display: grid;
    grid-template-columns: minmax(120px, 0.65fr) minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: #fbfdfc;
}

.zuordnungszeile label {
    font-weight: 850;
    overflow-wrap: anywhere;
}

.reihenfolge__karte {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: #fbfdfc;
}

.reihenfolge__nummer {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #e8f1ed;
    color: var(--akzent-dunkel);
    font-weight: 900;
}

.reihenfolge__text {
    min-width: 0;
    font-weight: 760;
    overflow-wrap: anywhere;
}

.reihenfolge__aktionen {
    display: inline-flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.reihenfolge__aktionen .sekundaerknopf {
    min-height: 36px;
    padding: 0 10px;
}

.reihenfolge__aktionen .sekundaerknopf:disabled {
    opacity: 0.42;
    cursor: default;
}

.sprachmission {
    display: grid;
    gap: 14px;
}

.sprachmission__aktionen {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.hinweisband {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px;
    border: 1px solid #c7d8d2;
    border-radius: 8px;
    background: #eef8f5;
}

.hinweisband span {
    color: var(--gedaempft);
    font-weight: 700;
}

.auswertung {
    display: grid;
    gap: 6px;
    padding: 16px;
    border-radius: 8px;
    border: 1px solid var(--linie);
}

.auswertung strong,
.auswertung p {
    margin: 0;
}

.auswertung--erfolg {
    background: #e9f7ef;
    border-color: #b9dfc8;
}

.auswertung--fehler {
    background: #fff1e2;
    border-color: #efceaa;
}

.missionskarte__fuss {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.funkgeraet {
    display: grid;
    gap: 22px;
    padding: 24px;
    border: 1px solid #26342f;
    border-radius: 8px;
    background: #1b2421;
    color: #edf4ef;
    box-shadow: var(--schatten);
}

.funkgeraet__anzeige {
    display: grid;
    grid-template-columns: 1.6fr 0.8fr 0.8fr 1.8fr;
    gap: 14px;
}

.funkgeraet__anzeige > div {
    min-height: 92px;
    display: grid;
    align-content: center;
    gap: 5px;
    padding: 18px;
    border: 1px solid #354741;
    border-radius: 8px;
    background: #111816;
}

.funkgeraet__anzeige strong {
    font-size: clamp(1.08rem, 2vw, 1.65rem);
    line-height: 1.1;
    letter-spacing: 0;
}

.funkgeraet__label {
    color: #9fb1aa;
    font-size: 0.86rem;
    font-weight: 800;
    text-transform: uppercase;
}

.smeter {
    height: 18px;
    overflow: hidden;
    border: 1px solid #40544d;
    border-radius: 8px;
    background: linear-gradient(90deg, #17201d, #26342f);
}

.smeter span {
    width: 0;
    height: 100%;
    display: block;
    border-radius: 8px;
    background: linear-gradient(90deg, #51d88a, #f0d85d, #ef7a4f);
    transition: width 120ms ease-out;
}

.spektrum {
    width: 100%;
    aspect-ratio: 16 / 3;
    display: block;
    border: 1px solid #354741;
    border-radius: 8px;
    background: #0b100f;
}

.funkgeraet__bedienfeld {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 18px;
}

.regler {
    display: grid;
    gap: 8px;
    color: #d9e5df;
    font-weight: 800;
}

.regler input[type="range"] {
    width: 100%;
    accent-color: var(--funk);
}

.funkgeraet__aktionen {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.empfangstatus {
    color: #b9c8c1;
    font-weight: 800;
}

.tabellenrahmen {
    overflow-x: auto;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
}

.datentabelle {
    width: 100%;
    min-width: 920px;
    border-collapse: collapse;
}

.datentabelle th,
.datentabelle td {
    padding: 13px 16px;
    border-bottom: 1px solid var(--linie);
    text-align: left;
    vertical-align: top;
}

.datentabelle th {
    color: var(--gedaempft);
    font-size: 0.9rem;
    font-weight: 800;
}

.datentabelle tr:last-child td {
    border-bottom: 0;
}

.tabellenhinweis {
    display: block;
    margin-top: 4px;
    color: var(--gedaempft);
    font-size: 0.9rem;
}

.kompaktformular {
    display: grid;
    gap: 10px;
    min-width: 220px;
}

.checkboxzeile {
    display: flex !important;
    align-items: center;
    gap: 8px;
}

.checkboxzeile input {
    width: 18px;
    height: 18px;
    accent-color: var(--akzent);
}

.leerer-hinweis {
    margin: 0;
    padding: 18px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
    color: var(--gedaempft);
}

.fehlerseite {
    width: min(680px, 100%);
    display: grid;
    gap: 18px;
    padding: 28px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
    box-shadow: var(--schatten);
}

.fehlerseite h1,
.fehlerseite p {
    margin: 0;
}

.fehlerseite h1 {
    font-size: 2rem;
    line-height: 1.15;
    letter-spacing: 0;
}

.fehlerseite p {
    color: var(--gedaempft);
}

.rechtstext {
    width: min(860px, 100%);
    min-width: 0;
    display: grid;
    gap: 22px;
    padding: 28px;
    border: 1px solid var(--linie);
    border-radius: 8px;
    background: var(--flaeche);
    box-shadow: var(--schatten);
}

.rechtstext__kopf {
    display: grid;
    gap: 10px;
}

.rechtstext h1,
.rechtstext h2,
.rechtstext p,
.rechtstext ul,
.rechtstext dl {
    margin: 0;
}

.rechtstext h1 {
    font-size: 2rem;
    line-height: 1.15;
    letter-spacing: 0;
    overflow-wrap: anywhere;
    hyphens: auto;
}

.rechtstext h2 {
    font-size: 1.2rem;
    line-height: 1.25;
    letter-spacing: 0;
}

.rechtstext p,
.rechtstext li,
.rechtstext dd {
    color: var(--gedaempft);
    overflow-wrap: anywhere;
    hyphens: auto;
}

.rechtstext ul {
    padding-left: 20px;
}

.rechtstext__daten {
    display: grid;
    gap: 10px;
}

.rechtstext__daten div {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    gap: 12px;
}

.rechtstext__daten dt {
    font-weight: 800;
}

.rechtstext__daten dd {
    overflow-wrap: anywhere;
}

.fusszeile {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    flex-wrap: wrap;
    padding: 22px 32px;
    border-top: 1px solid var(--linie);
    color: var(--gedaempft);
    text-align: center;
    background: #ffffff;
}

.fusszeile__links {
    display: inline-flex;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: center;
}

.fusszeile__links a {
    color: var(--text);
    font-weight: 700;
    text-decoration: none;
}

@media (max-width: 760px) {
    .kopfzeile,
    .navigation,
    .zugang,
    .zugang__aktionen,
    .arbeitsflaeche__kopf,
    .funkgeraet__aktionen,
    .sprachmission__aktionen,
    .hinweisband,
    .kennzahlen,
    .mission,
    .lernpfadstand {
        align-items: stretch;
    }

    .kopfzeile,
    .navigation,
    .zugang__aktionen,
    .arbeitsflaeche__kopf,
    .funkgeraet__aktionen,
    .sprachmission__aktionen,
    .hinweisband,
    .kennzahlen {
        flex-direction: column;
    }

    .kopfzeile {
        padding: 18px;
    }

    .zugang {
        grid-template-columns: 1fr;
    }

    .lernpfadstand,
    .mission--klickbar {
        grid-template-columns: 1fr;
    }

    .filterleiste {
        grid-template-columns: 1fr;
    }

    .logbuchraster {
        grid-template-columns: 1fr;
    }

    .zuordnungszeile,
    .reihenfolge__karte {
        grid-template-columns: 1fr;
    }

    .reihenfolge__aktionen {
        justify-content: stretch;
    }

    .reihenfolge__aktionen .sekundaerknopf {
        flex: 1 1 110px;
    }

    .mission__nummer {
        width: 30px;
        height: 30px;
    }

    .funkgeraet__anzeige,
    .funkgeraet__bedienfeld {
        grid-template-columns: 1fr;
    }

    .mission__aktionen {
        justify-content: stretch;
    }

    .navigation form,
    .navigation a,
    .navigation__knopf,
    .navigation__aktion {
        width: 100%;
    }

    .zugang h1,
    .formularrahmen h1,
    .arbeitsflaeche h1,
    .rechtstext h1 {
        font-size: 1.8rem;
    }

    .rechtstext__daten div {
        grid-template-columns: 1fr;
        gap: 2px;
    }
}

/* © 2026 Erik Schauer, do1ffe@darc.de */
