/* ==========================================================================
   multifenster Intranet – Design im Stil von www.multifenster.de
   Markenfarben: Hellblau #5BC5F2, Dunkel #2F3431, Weiß #FFFFFF
   Schrift: Avenir Next (sans) für UI, serifenbetont (Italia-Look) für Headlines
   Mobile-first.
   ========================================================================== */
:root {
    --brand:        #5bc5f2;   /* Markenblau */
    --brand-strong: #1f9fd1;   /* dunkleres Blau für Links/Fokus auf Hell */
    --ink:          #2f3431;   /* Dunkel (Text, dunkle Flächen) */
    --bg:           #eef3f6;   /* zarter Seitenhintergrund */
    --card:         #ffffff;
    --muted:        #6b736f;
    --border:       #e2e8ec;
    --danger:       #b42318;

    --font-sans: "Avenir Next", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Roboto, Helvetica, Arial, sans-serif;
    --font-display: "Italia", "Rockwell", "Roboto Slab", Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--ink);
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 700; }

a { color: var(--brand-strong); }

.wrap {
    width: 100%;
    max-width: 460px;
    margin: 0 auto;
    padding: 24px 16px;
}

/* ---------- Login ---------- */
.center {
    min-height: 100dvh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(31, 52, 49, 0.10);
    width: 100%;
}

/* dunkles Kopfband mit Logo (Logo ist weiß -> braucht dunklen Grund) */
.card-head {
    background: var(--ink);
    padding: 28px 22px 26px;
    text-align: center;
}

.card-head img {
    width: 180px;
    max-width: 70%;
    height: auto;
    display: inline-block;
}

.card-body { padding: 26px 22px 30px; }

.card-body h1 {
    font-size: 1.3rem;
    margin: 0 0 4px;
}

.muted {
    color: var(--muted);
    font-size: 0.95rem;
    margin: 0 0 20px;
}

.signin {
    display: flex;
    justify-content: center;
    margin-top: 10px;
}

.notice {
    background: #f0faff;
    border: 1px solid var(--brand);
    color: #0c5878;
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 0.9rem;
    margin-top: 8px;
}

/* ---------- Intranet ---------- */
.topbar {
    background: var(--ink);
    position: sticky;
    top: 0;
    z-index: 10;
}

.topbar .inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.topbar .brand-logo { height: 34px; width: auto; display: block; }

.topbar .spacer { flex: 1; }

.user {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
    color: #c9d1ce;
}

.user img { width: 32px; height: 32px; border-radius: 50%; }
.user .email { display: none; }   /* E-Mail im Header immer ausblenden (Avatar bleibt) */

/* Brand-Akzentstreifen unter der Topbar */
.accent-bar { height: 4px; background: var(--brand); }

.btn {
    display: inline-block;
    border: 1px solid transparent;
    background: var(--brand);
    color: var(--ink);
    border-radius: 8px;
    padding: 7px 16px;
    font-size: 0.88rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
}
.btn:hover { background: #7ad2f6; }

.btn-ghost {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.35);
    color: #fff;
}
.btn-ghost:hover { background: rgba(255, 255, 255, 0.10); }

/* Icon-Button (z. B. Abmelden) – Desktop & Mobil */
.iconbtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    flex: 0 0 auto;
    border-radius: 8px;
    color: #fff;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.30);
    text-decoration: none;
}
.iconbtn:hover { background: rgba(255, 255, 255, 0.12); }
.iconbtn svg { display: block; }

.content {
    max-width: 960px;
    margin: 0 auto;
    padding: 28px 16px;
}

.content h1 { font-size: 1.7rem; margin: 0 0 6px; }

/* ---------- Firmenwechsler (Topbar) ---------- */
.switcher { position: relative; }

.switcher summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: #fff;
    font-size: 0.92rem;
    font-weight: 600;
    max-width: 52vw;
}
.switcher summary::-webkit-details-marker { display: none; }
.switcher .co-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.switcher .caret { color: var(--brand); font-size: 0.8rem; }
.switcher[open] summary { background: rgba(255, 255, 255, 0.16); }

.switcher-menu {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 240px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: 0 12px 32px rgba(31, 52, 49, 0.18);
    padding: 6px;
    z-index: 50;
}
.switcher-menu a {
    display: block;
    padding: 9px 12px;
    border-radius: 8px;
    color: var(--ink);
    text-decoration: none;
    font-size: 0.92rem;
}
.switcher-menu a:hover { background: var(--bg); }
.switcher-menu a.is-active { color: var(--brand-strong); font-weight: 700; }
.switcher-menu a.add { color: var(--brand-strong); font-weight: 600; }
.switcher-menu hr { border: none; border-top: 1px solid var(--border); margin: 6px 4px; }

/* ---------- Sektionen (flach, ohne Kasten) ---------- */
.panel { margin-bottom: 22px; }
.panel h2 { font-size: 1.05rem; margin: 0 0 10px; color: var(--muted); font-family: var(--font-sans); }
.co-headline { font-size: 1.25rem; font-weight: 700; font-family: var(--font-display); margin: 0 0 8px; }

/* ---------- Firmen-Karten (bleiben Karten, gleich hoch, Buttons unten) ---------- */
.cards { display: grid; gap: 16px; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); align-items: stretch; }
.cards .panel {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 18px;
    margin-bottom: 0;
    display: flex;
    flex-direction: column;
}
.cards .panel .actions { margin-top: auto; }   /* Buttons an den unteren Rand */

.kv { display: grid; grid-template-columns: max-content 1fr; gap: 4px 16px; margin: 0 0 16px; }
.kv dt { color: var(--muted); }
.kv dd { margin: 0; }

/* ---------- Badges – einheitlich in Button-Größe ---------- */
.badge {
    display: inline-block;
    font-size: 0.88rem;
    font-weight: 600;
    background: var(--brand);
    color: var(--ink);
    border: none;
    border-radius: 8px;
    padding: 7px 16px;
    line-height: 1.2;
    vertical-align: middle;
    font-family: inherit;
}

.page-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.page-head h1 { margin: 0; }

.actions { display: flex; gap: 8px; flex-wrap: wrap; }
.btn-soft { background: var(--bg); color: var(--ink); border: 1px solid var(--border); }
.btn-soft:hover { background: #e3eaef; }

/* ---------- Formular ---------- */
.form label { display: block; margin-bottom: 14px; font-size: 0.9rem; color: var(--muted); }
.form input {
    display: block;
    width: 100%;
    margin-top: 5px;
    padding: 11px 12px;
    font-size: 1rem;
    color: var(--ink);
    border: 1px solid var(--border);
    border-radius: 9px;
    background: #fff;
}
.form input:focus { outline: 2px solid var(--brand); border-color: var(--brand); }
.form fieldset { border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px 2px; margin: 0 0 14px; }
.form legend { padding: 0 6px; color: var(--muted); font-size: 0.85rem; }
.form .row { display: flex; gap: 12px; }
.form .row > label { flex: 1; }
.form .w-zip { flex: 0 0 32%; }
.form-actions { margin-top: 6px; }
.btn[type], button.btn { font: inherit; font-weight: 600; }

.flash { border-radius: 10px; padding: 11px 14px; margin-bottom: 16px; font-size: 0.92rem; }
.flash.ok { background: #ecfdf3; border: 1px solid #abefc6; color: #067647; }
.flash.err { background: #fef3f2; border: 1px solid #fecaca; color: var(--danger); }

/* ---------- Hauptnavigation ---------- */
.mainnav {
    background: rgba(0, 0, 0, 0.18);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.mainnav .inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 16px;
    display: flex;
    gap: 4px;
}
.mainnav a {
    display: inline-block;
    padding: 11px 14px;
    color: #c9d1ce;
    text-decoration: none;
    font-size: 0.92rem;
    font-weight: 600;
    border-bottom: 3px solid transparent;
}
.mainnav a:hover { color: #fff; }
.mainnav a.active { color: #fff; border-bottom-color: var(--brand); }

/* ---------- Formular: select/textarea ---------- */
.form select, .form textarea {
    display: block;
    width: 100%;
    margin-top: 5px;
    padding: 11px 12px;
    font: inherit;
    font-size: 1rem;
    color: var(--ink);
    border: 1px solid var(--border);
    border-radius: 9px;
    background: #fff;
}
.form textarea { resize: vertical; }
.form select:focus, .form textarea:focus { outline: 2px solid var(--brand); border-color: var(--brand); }
.hint { display: block; color: var(--muted); font-size: 0.82rem; margin-top: 5px; font-weight: 400; }

/* ---------- Filterleiste ---------- */
.filterbar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.filterbar input[type=search], .filterbar select {
    padding: 9px 11px;
    border: 1px solid var(--border);
    border-radius: 8px;
    font: inherit;
    font-size: 0.92rem;
    background: #fff;
    color: var(--ink);
}
.filterbar input[type=search] { flex: 1; min-width: 140px; }

/* ---------- Aufgabenliste (flach, mit Trennlinien) ---------- */
.todo-list { display: flex; flex-direction: column; }
.todo-row { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 0; padding: 14px 2px; border-bottom: 1px solid var(--border); }
.todo-row:last-child { border-bottom: none; }
.todo-main { flex: 1; min-width: 0; }
.todo-title { font-weight: 600; color: var(--ink); text-decoration: none; font-size: 1.02rem; }
.todo-title:hover { color: var(--brand-strong); }
.todo-meta { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-top: 9px; }
.meta-chip { font-size: 0.82rem; color: var(--muted); background: var(--bg); border-radius: 8px; padding: 6px 12px; }
.meta-chip.overdue, .overdue { color: var(--danger); font-weight: 600; }
.tag { font-size: 0.82rem; color: var(--brand-strong); background: #eef9fe; border-radius: 8px; padding: 6px 12px; }

/* ---------- Badge-Picker (Inline-Auswahl von Status/Priorität) ---------- */
.picker { position: relative; display: inline-block; }
.picker > summary { list-style: none; cursor: pointer; display: inline-block; }
.picker > summary::-webkit-details-marker { display: none; }
.picker > summary::marker { content: ""; }
.picker .badge { cursor: pointer; -webkit-appearance: none; appearance: none; }
.picker-opts {
    position: absolute;
    z-index: 40;
    top: calc(100% + 6px);
    left: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 8px;
    box-shadow: 0 12px 28px rgba(31, 52, 49, 0.18);
}
.picker-opts .badge { text-align: left; white-space: nowrap; }

/* Badges: Priorität & Status */
.badge.prio-hoch   { background: #fee4e2; color: #b42318; }
.badge.prio-mittel { background: #fef0c7; color: #b54708; }
.badge.prio-gering { background: #e6e9ec; color: #475467; }
.badge.status-offen          { background: #e0f2fe; color: #026aa2; }
.badge.status-in_arbeit      { background: #e9d7fe; color: #6941c6; }
.badge.status-abgeschlossen  { background: #d1fadf; color: #067647; }
.badge.status-abgebrochen    { background: #e6e9ec; color: #667085; }

/* Dashboard-Miniliste */
.todo-mini { list-style: none; margin: 0; padding: 0; }
.todo-mini li { display: flex; align-items: center; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--border); }
.todo-mini li:last-child { border-bottom: none; }
.todo-mini a { flex: 1; color: var(--ink); text-decoration: none; font-weight: 600; }
.todo-mini a:hover { color: var(--brand-strong); }
.todo-mini .due { font-size: 0.8rem; color: var(--muted); }

.todo-desc { white-space: pre-line; margin: 14px 0; }

/* Verlauf */
.activity { list-style: none; margin: 0; padding: 0; }
.activity li { display: flex; flex-wrap: wrap; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 0.9rem; }
.activity li:last-child { border-bottom: none; }
.activity .when { color: var(--muted); min-width: 120px; }
.activity .who { font-weight: 600; }

/* Mobil: Benutzer (Name + Avatar) ausblenden – Firmenname genügt */
@media (max-width: 640px) {
    .user { display: none; }
    .switcher summary { max-width: 60vw; }
}

@media (max-width: 420px) {
    .form .row { flex-direction: column; gap: 0; }
    .form .w-zip { flex: 1; }
    .todo-row { flex-direction: column; align-items: stretch; }
}
