/* KircherAI – Branding
   Weiss #FFFFFF · Dunkelblau #001F4F · Rot #E40420 */
:root {
    --white: #FFFFFF;
    --navy: #001F4F;
    --red: #E40420;
    --navy-80: #1a3563;
    --grey-bg: #f4f6fa;
    --grey-line: #d9dee8;
    --text: #1a2238;
    --ok: #1e9e5a;
    --warn: #e8a400;
    --bad: #E40420;
}

* { box-sizing: border-box; }

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

/* ---- Topbar ---- */
.topbar {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    background: var(--navy);
    color: var(--white);
    padding: 0.6rem 1.5rem;
}
.brand { display: flex; align-items: center; gap: 0.7rem; text-decoration: none; color: var(--white); }
.brand-logo { height: 38px; width: auto; background: var(--white); border-radius: 6px; padding: 3px; }
.brand-text { font-weight: 700; font-size: 1.15rem; letter-spacing: 0.5px; }
.topnav { display: flex; gap: 1.2rem; margin-left: 1rem; }
.topnav a { color: var(--white); text-decoration: none; opacity: 0.85; font-weight: 500; }
.topnav a:hover { opacity: 1; border-bottom: 2px solid var(--red); }
.logout-form { margin-left: auto; }

.content { flex: 1; width: 100%; max-width: 1200px; margin: 0 auto; padding: 1.6rem; }

.footer {
    text-align: center;
    padding: 0.8rem;
    color: var(--navy);
    font-style: italic;
    border-top: 3px solid var(--red);
    background: var(--white);
}
.slogan { font-weight: 500; }

/* ---- Buttons ---- */
.btn {
    display: inline-block; border: none; border-radius: 6px; cursor: pointer;
    padding: 0.6rem 1.2rem; font-size: 0.95rem; font-weight: 600; text-decoration: none;
}
.btn-primary { background: var(--red); color: var(--white); }
.btn-primary:hover { background: #c50019; }
.btn-secondary { background: var(--navy); color: var(--white); }
.btn-ghost { background: transparent; color: var(--white); border: 1px solid rgba(255,255,255,.5); }
.btn-ghost:hover { border-color: var(--red); }

/* ---- Cards / Forms ---- */
.card {
    background: var(--white); border: 1px solid var(--grey-line); border-radius: 10px;
    padding: 1.4rem; box-shadow: 0 1px 4px rgba(0,31,79,.06); margin-bottom: 1.2rem;
}
h1, h2 { color: var(--navy); }
label { display: block; font-weight: 600; margin: 0.7rem 0 0.25rem; }
input[type=text], input[type=password], textarea, select {
    width: 100%; padding: 0.55rem 0.7rem; border: 1px solid var(--grey-line);
    border-radius: 6px; font-size: 0.95rem;
}
textarea { min-height: 110px; resize: vertical; }
.field-error { color: var(--red); font-size: 0.85rem; margin-top: 0.3rem; }

/* ---- Login ---- */
.login-wrap { min-height: 100vh; display: grid; place-items: center; background: var(--navy); }
.login-card { background: var(--white); border-radius: 14px; padding: 2.2rem; width: 360px; text-align: center; }
.login-card img { height: 60px; background: var(--white); margin-bottom: 1rem; }
.login-card .slogan { display: block; margin-top: 1rem; color: var(--navy); }

/* ---- Tabelle ---- */
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 0.5rem 0.6rem; border-bottom: 1px solid var(--grey-line); }
th { color: var(--navy); font-size: 0.85rem; text-transform: uppercase; letter-spacing: .4px; }
.status-pill { padding: 2px 10px; border-radius: 999px; font-size: .78rem; font-weight: 600; background: #eef2f9; color: var(--navy); }

/* ---- Konfidenz-Badge / Wahrscheinlichkeit ---- */
.conf { display: inline-block; min-width: 46px; text-align: center; padding: 2px 8px; border-radius: 6px;
        font-size: .8rem; font-weight: 700; color: var(--white); }
.conf-high { background: var(--ok); }
.conf-mid  { background: var(--warn); }
.conf-low  { background: var(--bad); }

/* ---- Review-Layout (Drag & Drop) ---- */
.review-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 1.2rem; align-items: start; }
.token-pool { max-height: 70vh; overflow: auto; }
.token {
    display: inline-block; margin: 3px; padding: 3px 8px; background: #eef2f9; border: 1px solid var(--grey-line);
    border-radius: 6px; cursor: grab; font-size: .85rem;
}
.token:active { cursor: grabbing; }
.field-row { display: grid; grid-template-columns: 150px 1fr 60px; gap: .6rem; align-items: center; margin-bottom: .6rem; }
.dropzone {
    min-height: 40px; border: 2px dashed var(--grey-line); border-radius: 6px; padding: .4rem .6rem;
    background: #fafbfe;
}
.dropzone.dragover { border-color: var(--red); background: #fff0f2; }
.dropzone .val { font-weight: 600; }
.muted { color: #6b7488; font-size: .85rem; }
.page-img { width: 100%; border: 1px solid var(--grey-line); border-radius: 6px; }
