/* Agentic Software Factory – Basis-Stylesheet */

:root {
    --farbe-hintergrund: #f6f7fb;
    --farbe-flaeche: #ffffff;
    --farbe-text: #1f2430;
    --farbe-text-leise: #4a5363;
    --farbe-rahmen: #d6dae3;
    --farbe-akzent: #1f5fbf;
    --farbe-akzent-dunkel: #143f80;
    --farbe-fokus: #ffae42;
    --farbe-erfolg: #1f7a3a;
    --farbe-warnung: #b06a00;
    --farbe-fehler: #b3261e;
    --abstand-xs: 0.25rem;
    --abstand-s: 0.5rem;
    --abstand-m: 1rem;
    --abstand-l: 1.5rem;
    --abstand-xl: 2.5rem;
    --radius: 6px;
    --schrift-monospace: ui-monospace, "Cascadia Mono", Menlo, Consolas, monospace;
}

*, *::before, *::after { box-sizing: border-box; }

html {
    /*
     * Verhindert Layout-Shift, wenn manche Seiten scrollen und andere nicht.
     * Ohne diese Regel rueckt der Browser den Inhalt um die Scrollbar-Breite
     * (typisch 15px) hin und her, je nachdem ob eine Vertical-Scrollbar
     * eingeblendet wird oder nicht. Ergebnis: der Header sprang zwischen
     * Dashboard, Projekte und allen anderen Seiten in der Position.
     *
     * scrollbar-gutter: stable reserviert den Scrollbar-Platz immer und ist
     * die moderne, semantisch saubere Variante; alle aktuellen Browser
     * (Chromium >=94, Firefox >=97, Safari >=16) unterstuetzen das. Fuer
     * aeltere Browser greift "overflow-y: scroll" als Fallback.
     */
    overflow-y: scroll;
    scrollbar-gutter: stable;
}

html, body {
    margin: 0;
    padding: 0;
    background: var(--farbe-hintergrund);
    color: var(--farbe-text);
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    line-height: 1.5;
    font-size: 16px;
}

a { color: var(--farbe-akzent); }
a:hover { color: var(--farbe-akzent-dunkel); }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
    outline: 3px solid var(--farbe-fokus);
    outline-offset: 2px;
}

.skiplink {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--farbe-akzent-dunkel);
    color: #fff;
    padding: var(--abstand-s) var(--abstand-m);
}
.skiplink:focus { left: var(--abstand-m); top: var(--abstand-m); z-index: 10; }

.kopfbereich {
    background: var(--farbe-akzent-dunkel);
    color: #fff;
    padding: var(--abstand-m) var(--abstand-xl);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--abstand-m);
}
.kopfbereich a { color: #fff; }
.kopfbereich .marke { display: inline-flex; align-items: center; gap: var(--abstand-s); font-size: 1.2rem; font-weight: 700; text-decoration: none; }
.kopfbereich .marke img { height: 40px; width: auto; display: block; border-radius: 6px; }
.kopfbereich .marke .markenname { white-space: nowrap; }
@media (max-width: 640px) { .kopfbereich .marke .markenname { display: none; } }
.kopfbereich nav ul { display: flex; gap: var(--abstand-m); list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.kopfbereich nav a { text-decoration: none; padding: var(--abstand-xs) var(--abstand-s); border-radius: var(--radius); }
.kopfbereich nav a[aria-current="page"] { background: rgba(255,255,255,0.18); }

main {
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--abstand-xl);
}

h1, h2, h3 { color: var(--farbe-text); margin-top: 0; }
h1 { font-size: 1.7rem; }
h2 { font-size: 1.25rem; margin-top: var(--abstand-l); }
h3 { font-size: 1.05rem; }

.karte {
    background: var(--farbe-flaeche);
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius);
    padding: var(--abstand-l);
    margin-bottom: var(--abstand-l);
    box-shadow: 0 1px 2px rgba(20,30,50,0.04);
}

.karten-raster {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--abstand-m);
    margin-bottom: var(--abstand-l);
}
.kennzahl { background: var(--farbe-flaeche); padding: var(--abstand-m); border: 1px solid var(--farbe-rahmen); border-radius: var(--radius); }
.kennzahl .wert { font-size: 1.8rem; font-weight: 700; color: var(--farbe-akzent); }
.kennzahl .label { color: var(--farbe-text-leise); font-size: 0.9rem; }

table { width: 100%; border-collapse: collapse; }
thead th { text-align: left; background: #eef1f7; padding: var(--abstand-s); border-bottom: 1px solid var(--farbe-rahmen); font-weight: 600; }
tbody td { padding: var(--abstand-s); border-bottom: 1px solid var(--farbe-rahmen); vertical-align: top; }
tbody tr:hover { background: #f3f5fa; }

form .feld { margin-bottom: var(--abstand-m); }
form label { display: block; font-weight: 600; margin-bottom: var(--abstand-xs); }
form .hinweis { color: var(--farbe-text-leise); font-size: 0.9rem; }
form input[type="text"], form input[type="email"], form input[type="password"], form select, form textarea {
    width: 100%;
    padding: var(--abstand-s);
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius);
    background: #fff;
    color: var(--farbe-text);
    font-family: inherit;
    font-size: 1rem;
}
form textarea { min-height: 6rem; font-family: inherit; }
form .knopfleiste { display: flex; gap: var(--abstand-s); margin-top: var(--abstand-m); }

button, .knopf {
    display: inline-block;
    background: var(--farbe-akzent);
    color: #fff;
    border: none;
    padding: var(--abstand-s) var(--abstand-m);
    border-radius: var(--radius);
    cursor: pointer;
    font-weight: 600;
    text-decoration: none;
    font-family: inherit;
    font-size: 1rem;
}
button:hover, .knopf:hover { background: var(--farbe-akzent-dunkel); color: #fff; }
button.sekundaer, .knopf.sekundaer { background: #e6e9f1; color: var(--farbe-text); }
button.warnung, .knopf.warnung { background: var(--farbe-warnung); }
button.gefahr, .knopf.gefahr { background: var(--farbe-fehler); }

.statusabzeichen {
    display: inline-block;
    padding: var(--abstand-xs) var(--abstand-s);
    border-radius: var(--radius);
    background: #eef1f7;
    color: var(--farbe-text-leise);
    font-size: 0.85rem;
    font-weight: 600;
}
.statusabzeichen.erfolg { background: #e6f4ea; color: var(--farbe-erfolg); }
.statusabzeichen.warnung { background: #fff4e0; color: var(--farbe-warnung); }
.statusabzeichen.fehler { background: #fdecea; color: var(--farbe-fehler); }
.statusabzeichen.aktiv { background: #e1ecff; color: var(--farbe-akzent-dunkel); }

.fehler { color: var(--farbe-fehler); font-weight: 600; }
.hinweisbox {
    border-left: 4px solid var(--farbe-akzent);
    background: #f0f4fc;
    padding: var(--abstand-s) var(--abstand-m);
    margin-bottom: var(--abstand-m);
    border-radius: var(--radius);
}

.markdown-vorschau {
    background: #fbfcff;
    padding: var(--abstand-m);
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius);
    overflow-x: auto;
}
.markdown-vorschau pre, .log-anzeige {
    font-family: var(--schrift-monospace);
    background: #1f2430;
    color: #d8dde6;
    padding: var(--abstand-m);
    border-radius: var(--radius);
    overflow-x: auto;
    font-size: 0.9rem;
}

.fusszeile {
    text-align: center;
    color: var(--farbe-text-leise);
    padding: var(--abstand-l);
    font-size: 0.85rem;
}

.lizenz-tier {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin-right: 0.4rem;
}
.lizenz-tier.demo { background: #e1ecff; color: var(--farbe-akzent-dunkel); }
.lizenz-tier.community { background: #e6f4ea; color: var(--farbe-erfolg); }
.lizenz-tier.full { background: #fff4e0; color: var(--farbe-warnung); }
.lizenz-limits { list-style: none; padding: 0; margin: var(--abstand-s) 0 0; color: var(--farbe-text-leise); font-size: 0.9rem; }
.lizenz-limits li { padding: 0.15rem 0; }
.lizenz-flow { margin-top: var(--abstand-m); padding: var(--abstand-m); border: 1px dashed var(--farbe-rahmen); border-radius: var(--radius); background: #fafbfe; }
.lizenz-flow code { background: #eef1f7; padding: 0.1rem 0.4rem; border-radius: 4px; font-size: 1rem; font-weight: 700; }
.lizenz-flow-status { margin-top: var(--abstand-s); color: var(--farbe-text-leise); font-style: italic; }
.lizenz-kennzahl { display: flex; align-items: center; gap: var(--abstand-s); }
.lizenz-kennzahl .lizenz-tier { margin-right: 0; }
.lizenz-hinweis { margin: var(--abstand-s) 0 0; padding: 0.5rem 0.9rem; border-radius: 12px; font-size: 0.92rem; }
.lizenz-hinweis.ok { background: #e6f4ea; color: var(--farbe-erfolg); border: 1px solid #b5dec1; }
.lizenz-hinweis.warn { background: #fff4e0; color: var(--farbe-warnung); border: 1px solid #f0d9a6; }

/*
 * Benutzer-Box im Header: Avatar-Initial-Kreis + Klick-Popover mit User-Info.
 * Nutzt die native HTML5-Popover-API (popover="auto" + popovertarget),
 * also kein JavaScript noetig.
 */
.benutzer-box { position: relative; }
.benutzer-knopf {
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: 999px;
    padding: 4px;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.benutzer-knopf:hover { background: rgba(255,255,255,0.20); }
.benutzer-knopf:focus-visible {
    outline: 3px solid var(--farbe-fokus);
    outline-offset: 2px;
}
.benutzer-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--farbe-akzent);
    color: #fff;
    font-weight: 700;
    font-size: 0.95rem;
    text-transform: uppercase;
    user-select: none;
}
.benutzer-avatar.gross { width: 44px; height: 44px; font-size: 1.2rem; }

.benutzer-popover {
    /* Native [popover] - inset:auto plus margin steuern die Position;
       der Browser positioniert das Popover absolut. Wir setzen es per
       margin/inset oben rechts unter dem Knopf. */
    position: fixed;
    inset: auto;
    top: 4.2rem;
    right: 1rem;
    margin: 0;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius);
    background: var(--farbe-flaeche);
    color: var(--farbe-text);
    box-shadow: 0 8px 24px rgba(15, 32, 64, 0.18);
    padding: var(--abstand-m);
    min-width: 240px;
    max-width: 320px;
}
.benutzer-popover-kopf {
    display: flex;
    align-items: center;
    gap: var(--abstand-s);
    padding-bottom: var(--abstand-s);
    border-bottom: 1px solid var(--farbe-rahmen);
    margin-bottom: var(--abstand-s);
}
.benutzer-popover-name { font-weight: 700; font-size: 1rem; }
.benutzer-popover-meta { color: var(--farbe-text-leise); font-size: 0.85rem; margin-top: 2px; }
.benutzer-popover-info { color: var(--farbe-text-leise); font-size: 0.85rem; margin-bottom: var(--abstand-s); }
.benutzer-popover-aktion { margin: 0; }

/* Visually-hidden fuer Screenreader-only-Texte (aria-haspopup-Beschriftung). */
.visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}
