/* =================================================================
   Wohntraum CRM — Light-Mode Theme
   Inspiration: claude.ai/design styles.css (warm neutrals + Bloomberg-density)
   ================================================================= */

:root {
    --bg:        #F6F2EA;
    --paper:     #FFFFFF;
    --paper-2:   #FBF7EE;
    --ink:       #14110D;
    --ink-2:     #4A4439;
    --ink-3:     #8E8579;
    --ink-4:     #B5AC9E;
    --line:      #E5E0D2;
    --line-soft: #EEEAE0;
    --forest:    #1F3D2E;
    --forest-2:  #2E5740;
    --amber:     #B8862D;
    --pos:       #2E6A48;
    --neg:       #B83A2A;
    --hot:       #C76A3E;
    --hl:        #F3DD9E;
    --dark-bg:   #11130F;

    --shadow-sm: 0 1px 2px rgba(20,17,13,0.06);
    --shadow-md: 0 4px 12px rgba(20,17,13,0.08);
    --r-sm: 4px;
    --r-md: 6px;
    --r-lg: 10px;
}

* { box-sizing: border-box; }
html, body { height: 100%; margin: 0; }
body {
    font: 13px/1.5 "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    color: var(--ink);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    letter-spacing: -0.005em;
}
.mono  { font-family: "IBM Plex Mono", ui-monospace, SFMono-Regular, monospace; font-feature-settings: "tnum"; }
.serif { font-family: "IBM Plex Serif", Georgia, serif; }
.up    { text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; color: var(--ink-3); }
.up-b  { text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; color: var(--ink); font-weight: 600; }
.muted { color: var(--ink-3); }
.kbd   { font-family: "IBM Plex Mono", monospace; font-size: 11px; padding: 1px 5px; border: 1px solid var(--line); border-radius: 3px; color: var(--ink-3); background: var(--paper); }

a { color: var(--ink); text-decoration: none; }
a:hover { color: var(--forest); }

/* ---- Pills / Tags ---- */
.pill        { display: inline-block; padding: 2px 7px; border-radius: 3px; font-size: 11px; font-weight: 500; letter-spacing: 0.02em; }
.pill.live   { background: var(--forest); color: #F6F2EA; }
.pill.draft  { background: var(--line); color: var(--ink); }
.pill.sold   { background: var(--ink); color: #F6F2EA; }
.pill.reserved{background: var(--hot); color: #fff; }
.pill.hot    { background: var(--neg); color: #fff; }
.pill.warm   { background: var(--amber); color: #fff; }
.pill.cold   { background: var(--line); color: var(--ink-2); }
.pill.ghost  { background: transparent; color: var(--ink-3); border: 1px solid var(--line); }
.pill.scout  { background: #1E58C6; color: #fff; }
.pill.kleinanz { background: #1E8F4B; color: #fff; }
.pill.wa     { background: #128C7E; color: #fff; }
.pill.sms    { background: #5C564C; color: #fff; }
.pill.email  { background: #4A4439; color: #fff; }

/* ---- Buttons ---- */
.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 10px; border-radius: var(--r-sm);
    background: var(--paper); color: var(--ink);
    border: 1px solid var(--line); font-size: 12px; cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
}
.btn:hover     { background: var(--paper-2); }
.btn.forest    { background: var(--forest); color: #F6F2EA; border-color: var(--forest); }
.btn.forest:hover { background: var(--forest-2); }
.btn.ghost     { background: transparent; border-color: var(--line); }
.btn.icon      { padding: 6px; }
.btn.sm        { padding: 4px 8px; font-size: 11.5px; }
.btn.primary   { background: var(--ink); color: #F6F2EA; border-color: var(--ink); }
.btn.primary:hover { background: #000; }

/* ---- Avatar ---- */
.av { display: inline-grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; font-size: 11px; font-weight: 600; background: var(--line); color: var(--ink); }
.av.amber { background: var(--amber); color: #fff; }
.av.forest{ background: var(--forest); color: #F6F2EA; }

/* =================================================================
   Auth (Login)
   ================================================================= */
body.auth {
    display: grid; place-items: center; padding: 24px;
    background: linear-gradient(160deg, var(--bg) 0%, var(--paper-2) 100%);
}
.auth-card {
    width: 100%; max-width: 380px;
    background: var(--paper); border: 1px solid var(--line);
    border-radius: var(--r-lg); padding: 36px 32px;
    box-shadow: var(--shadow-md);
}
.brand { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; }
.brand .logo, .sidebar .logo {
    width: 36px; height: 36px;
    background: var(--forest); color: #F6F2EA;
    display: grid; place-items: center;
    border-radius: 8px; font-weight: 600;
    font-family: "IBM Plex Serif", Georgia, serif;
    font-style: italic; font-size: 22px;
}
.brand-title { font-weight: 600; font-size: 16px; }
.brand-sub   { color: var(--ink-3); font-size: 12px; }

.auth-card label { display: block; margin: 14px 0; font-size: 12px; color: var(--ink-2); font-weight: 500; }
.auth-card input {
    width: 100%; margin-top: 5px;
    padding: 10px 12px; border-radius: var(--r-sm);
    background: var(--paper-2); color: var(--ink);
    border: 1px solid var(--line); font-size: 14px;
}
.auth-card input:focus { outline: 2px solid var(--forest); outline-offset: -1px; background: var(--paper); }
.auth-card button {
    width: 100%; margin-top: 20px; padding: 12px;
    background: var(--forest); color: #F6F2EA; border: 0;
    border-radius: var(--r-sm); font-weight: 600; cursor: pointer; font-size: 14px;
}
.auth-card button:hover { background: var(--forest-2); }
.alert { background: #FCE5DC; color: var(--neg); padding: 10px 12px; border-radius: var(--r-sm); margin-bottom: 12px; font-size: 12.5px; border: 1px solid #F4C8B4; }
.hint  { color: var(--ink-3); font-size: 11px; text-align: center; margin: 24px 0 0; }

/* =================================================================
   App-Layout (3-Spalten + Sidebar)
   ================================================================= */
body.app { display: flex; background: var(--bg); }

.sidebar {
    width: 216px; flex: 0 0 216px; height: 100vh;
    background: var(--paper); border-right: 1px solid var(--line);
    display: flex; flex-direction: column; padding: 14px 10px;
    position: sticky; top: 0;
}
.logo-row { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; padding: 0 6px; }
.logo-row .brand-title { font-family: "IBM Plex Serif", serif; font-size: 17px; font-weight: 500; }
.sidebar nav { display: flex; flex-direction: column; gap: 1px; flex: 1; }
.sidebar nav a {
    display: flex; align-items: center; justify-content: space-between;
    padding: 7px 10px; border-radius: var(--r-sm);
    color: var(--ink-2); font-size: 13px; gap: 8px;
}
.sidebar nav a:hover { background: var(--paper-2); color: var(--ink); }
.sidebar nav a.active { background: var(--paper-2); color: var(--ink); font-weight: 600; border-left: 2px solid var(--forest); padding-left: 8px; }
.badge {
    background: var(--forest); color: #F6F2EA;
    padding: 1px 6px; border-radius: 9px; font-size: 10px; font-weight: 600; font-family: "IBM Plex Mono", monospace;
}
.badge.muted { background: var(--line); color: var(--ink-3); }
.sidebar-foot { border-top: 1px solid var(--line); padding-top: 12px; margin-top: 6px; }
.user-chip { display: flex; gap: 10px; align-items: center; padding: 4px 6px; }
.user-name { font-size: 13px; font-weight: 500; }
.muted, .muted:visited { color: var(--ink-3); font-size: 11px; }

/* ---- 3-Spalten-Hauptbereich ---- */
.three-cols { flex: 1; display: grid; grid-template-columns: 348px 1fr 308px; height: 100vh; }
.conv-list, .conv-detail, .context-panel { height: 100vh; overflow-y: auto; }
.conv-list { border-right: 1px solid var(--line); background: var(--paper); }

.conv-head {
    position: sticky; top: 0;
    padding: 12px 14px; background: var(--paper);
    border-bottom: 1px solid var(--line); z-index: 2;
}
.conv-head input[type=search] {
    width: 100%; padding: 7px 12px;
    background: var(--paper-2); border: 1px solid var(--line);
    border-radius: var(--r-sm); color: var(--ink); font-size: 12.5px;
}
.conv-head input[type=search]:focus { outline: 2px solid var(--forest); outline-offset: -1px; }
.filter-pills { display: flex; gap: 5px; margin-top: 10px; flex-wrap: wrap; }
.filter-pills .pill { cursor: pointer; background: var(--paper-2); color: var(--ink-2); border: 1px solid var(--line); padding: 2px 8px; font-size: 11px; transition: background .12s, color .12s; }
.filter-pills .pill:hover { background: var(--paper); color: var(--ink); }
.filter-pills .pill.on { background: var(--forest); color: #F6F2EA; border-color: var(--forest); }
.pill-cnt { margin-left: 4px; font-family: "IBM Plex Mono", monospace; font-size: 10px; opacity: 0.7; }
.filter-pills .pill.on .pill-cnt { opacity: 0.85; }

/* ---- Quarantäne (Kontext-Panel: Kontakt anlegen) ---- */
.quar-card {
    background: #FCF4E0; border: 1px solid #F1DDA3;
    border-radius: var(--r-md); padding: 12px 14px;
    margin-bottom: 14px;
}
.quar-hint { margin: 0 0 12px; font-size: 12px; color: var(--ink-2); line-height: 1.5; }
.quar-hint em { font-style: normal; color: var(--neg); font-weight: 500; }
.quar-form label {
    display: block; margin-bottom: 8px;
    font-size: 10.5px; color: var(--ink-3); font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.04em;
}
.quar-form input, .quar-form select {
    width: 100%; margin-top: 3px;
    padding: 6px 8px; border-radius: var(--r-sm);
    background: var(--paper); border: 1px solid var(--line);
    color: var(--ink); font: 12.5px "IBM Plex Sans", sans-serif;
    letter-spacing: normal; text-transform: none;
}
.quar-form input:focus, .quar-form select:focus { outline: 2px solid var(--forest); outline-offset: -1px; }
.quar-actions { display: flex; gap: 6px; margin-top: 10px; }
.quar-actions .btn { flex: 1; justify-content: center; }
.filter-pills .pill.on { background: var(--ink); color: #F6F2EA; }

.conv-items { list-style: none; padding: 0; margin: 0; }
.conv-items li { border-bottom: 1px solid var(--line-soft); }
.conv-items li.on { background: var(--paper-2); border-left: 3px solid var(--forest); }
.conv-items li a { display: block; padding: 11px 14px; }
.conv-items li:not(.on):hover { background: var(--paper-2); }
.conv-top { display: flex; justify-content: space-between; margin-bottom: 4px; align-items: baseline; gap: 10px; }
.conv-name { font-weight: 600; font-size: 13px; color: var(--ink); }
.conv-time { color: var(--ink-3); font-size: 11px; font-family: "IBM Plex Mono", monospace; flex-shrink: 0; }
.conv-mid { display: flex; gap: 5px; margin-bottom: 5px; flex-wrap: wrap; }
.conv-prev { color: var(--ink-2); font-size: 12.5px; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.kanal-tag { font-size: 10px; padding: 1px 5px; border-radius: 3px; background: var(--line); color: var(--ink-2); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; }
.obj-tag   { font-size: 10px; padding: 1px 5px; border-radius: 3px; background: var(--amber); color: #fff; font-family: "IBM Plex Mono", monospace; }
.state-tag { font-size: 10px; padding: 1px 5px; border-radius: 3px; background: var(--ink-3); color: #fff; }
.state-tag.s-neu                 { background: #5470B3; }
.state-tag.s-erstkontakt         { background: #7C5BA4; }
.state-tag.s-qualifiziert        { background: var(--pos); }
.state-tag.s-termin_geplant      { background: var(--amber); }
.state-tag.s-termin_durchgefuehrt{ background: var(--hot); }
.state-tag.s-verkauft            { background: var(--forest); }
.state-tag.s-abgesagt            { background: var(--ink-3); }

.kanal-whatsapp .kanal-tag { background: #128C7E; color: #fff; }
.kanal-mail     .kanal-tag { background: #4A4439; color: #fff; }
.kanal-webform  .kanal-tag { background: #B8862D; color: #fff; }
.kanal-calcom   .kanal-tag { background: #6D28D9; color: #fff; }
.kanal-immowelt .kanal-tag { background: #FFAB00; color: #14110D; }
.kanal-immoscout .kanal-tag { background: #1E58C6; color: #fff; }
.kanal-kleinanzeigen .kanal-tag { background: #1E8F4B; color: #fff; }

/* ---- Konversations-Detail ---- */
.conv-detail { padding: 22px 28px; background: var(--bg); }

/* Action-Bar im Konversations-Header */
.inbox-actions {
    display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
    margin: 0 0 16px;
    padding: 8px 0;
    border-bottom: 1px solid var(--line-soft);
}
.inbox-actions .btn { font-size: 11.5px; padding: 5px 9px; }
.inbox-actions .btn.danger { color: var(--neg); border-color: #F4C8B4; }
.inbox-actions .btn.danger:hover { background: #FCE5DC; color: var(--neg); border-color: var(--neg); }
.empty-big   { color: var(--ink-3); text-align: center; padding: 80px 20px; }
.conv-header {
    display: flex; justify-content: space-between; align-items: start;
    margin-bottom: 24px; padding-bottom: 14px; border-bottom: 1px solid var(--line);
}
.conv-header h2 { margin: 0 0 6px; font-family: "IBM Plex Serif", serif; font-weight: 500; font-size: 22px; }
.conv-header .meta { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; }
.conv-header .actions { display: flex; gap: 6px; }
.conv-header .actions a {
    background: var(--paper); padding: 5px 10px; border-radius: var(--r-sm);
    font-size: 12px; color: var(--ink); border: 1px solid var(--line);
}
.conv-header .actions a:hover { background: var(--paper-2); }

.msg {
    background: var(--paper); border: 1px solid var(--line);
    border-radius: var(--r-md); padding: 16px 18px; margin-bottom: 14px;
    box-shadow: var(--shadow-sm);
}
.msg header { color: var(--ink-3); font-size: 11.5px; margin-bottom: 10px; font-family: "IBM Plex Mono", monospace; }
.msg h3 { margin: 0 0 10px; font-size: 14.5px; font-weight: 600; }
.msg .body { color: var(--ink); font-size: 13px; line-height: 1.55; }
.msg.draft { border-color: var(--amber); background: #FFF8E8; }
.msg.draft header { color: var(--amber); font-weight: 600; font-family: "IBM Plex Sans", sans-serif; text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; }

.msg.draft textarea {
    width: 100%; min-height: 180px; padding: 12px;
    background: var(--paper); color: var(--ink);
    border: 1px solid var(--line); border-radius: var(--r-sm);
    font: 13px/1.6 "IBM Plex Sans", sans-serif;
}
.msg.draft textarea:focus { outline: 2px solid var(--forest); outline-offset: -1px; }
.send-row { display: flex; gap: 8px; margin-top: 10px; align-items: center; }
.send-row select { background: var(--paper); color: var(--ink); padding: 7px 9px; border-radius: var(--r-sm); border: 1px solid var(--line); font-size: 12.5px; }
button.primary {
    background: var(--forest); color: #F6F2EA; border: 0;
    padding: 8px 18px; border-radius: var(--r-sm); font-weight: 600; cursor: pointer; font-size: 13px;
}
button.primary:hover { background: var(--forest-2); }
button.ghost { background: transparent; color: var(--ink-3); border: 1px solid var(--line); padding: 8px 14px; border-radius: var(--r-sm); cursor: pointer; font-size: 12.5px; }

/* ---- Context-Panel rechts ---- */
.context-panel { border-left: 1px solid var(--line); padding: 18px 18px; background: var(--paper); }
.ctx-h { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3); margin: 18px 0 8px; font-weight: 600; }
.ctx-h:first-child { margin-top: 0; }
.obj-card { background: var(--paper-2); border-radius: var(--r-md); padding: 14px; border: 1px solid var(--line); }
.obj-titel { font-family: "IBM Plex Serif", serif; font-weight: 500; font-size: 15px; margin-bottom: 4px; }
.obj-meta  { font-size: 11.5px; color: var(--ink-3); margin-bottom: 10px; font-family: "IBM Plex Mono", monospace; }
.obj-preis { font-size: 19px; color: var(--ink); font-weight: 600; font-family: "IBM Plex Mono", monospace; }
.link      { display: inline-block; margin-top: 10px; color: var(--forest); font-size: 12.5px; font-weight: 500; }
.funnel-chip { background: var(--paper-2); padding: 8px 12px; border-radius: var(--r-sm); font-size: 12.5px; border: 1px solid var(--line); }
.ctx-list { list-style: none; padding: 0; margin: 0; }
.ctx-list li { padding: 6px 0; font-size: 12.5px; color: var(--ink-2); border-bottom: 1px solid var(--line-soft); }
.ctx-list li:last-child { border-bottom: 0; }

/* =================================================================
   Cmd+K Palette
   ================================================================= */
.cmdk-backdrop {
    position: fixed; inset: 0; z-index: 50;
    background: rgba(20,17,13,0.32);
    backdrop-filter: blur(2px);
    display: grid; place-items: start center;
    padding-top: 12vh;
}
.cmdk {
    width: 560px; max-width: 92vw;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    box-shadow: 0 20px 60px rgba(20,17,13,0.18);
    overflow: hidden;
}
.cmdk-input-row {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 18px; border-bottom: 1px solid var(--line-soft);
}
.cmdk-input-row svg { width: 16px; height: 16px; color: var(--ink-3); flex-shrink: 0; }
.cmdk input {
    flex: 1; border: 0; outline: 0; background: transparent;
    font: 15px/1 "IBM Plex Sans", sans-serif; color: var(--ink);
}
.cmdk input::placeholder { color: var(--ink-3); }
.cmdk-hint { font-size: 11px; color: var(--ink-3); display: flex; gap: 4px; align-items: center; }
.cmdk-section { padding: 6px 10px 4px; font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-3); font-weight: 600; }
.cmdk-list { max-height: 56vh; overflow-y: auto; padding: 4px 6px 10px; }
.cmdk-item {
    display: flex; align-items: center; gap: 12px;
    padding: 9px 12px; border-radius: var(--r-sm);
    cursor: pointer; font-size: 13.5px; color: var(--ink);
}
.cmdk-item.on, .cmdk-item:hover { background: var(--paper-2); }
.cmdk-item .ico { width: 22px; height: 22px; display: grid; place-items: center; background: var(--paper-2); border-radius: var(--r-sm); font-size: 13px; flex-shrink: 0; }
.cmdk-item.on .ico { background: var(--forest); color: #F6F2EA; }
.cmdk-item .label { flex: 1; }
.cmdk-item .sub { color: var(--ink-3); font-size: 11.5px; }
.cmdk-foot {
    display: flex; gap: 14px; align-items: center; justify-content: flex-end;
    padding: 8px 14px; border-top: 1px solid var(--line-soft);
    font-size: 11px; color: var(--ink-3); background: var(--paper-2);
}

/* =================================================================
   Standard-Seite (single column) — settings, kontakte-detail, etc.
   ================================================================= */
.app-page {
    flex: 1; height: 100vh; overflow-y: auto;
    padding: 28px 36px 60px;
    background: var(--bg);
}
.app-page .page-head {
    margin: 0 0 22px;
    display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap;
}
.app-page .page-head h1 { margin: 0; font-size: 24px; font-weight: 500; }
.app-page .page-head p  { margin: 0; }
.page-foot { margin-top: 28px; font-size: 11px; text-align: center; }

/* ---- Card ------------------------------------------------ */
.card {
    background: var(--paper); border: 1px solid var(--line);
    border-radius: var(--r-lg); padding: 22px 24px 24px;
    margin-bottom: 18px; box-shadow: var(--shadow-sm);
    max-width: 820px;
}
.card-head {
    display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap;
    margin: 0 0 16px;
    padding-bottom: 12px; border-bottom: 1px solid var(--line-soft);
}
.card-head h2 { margin: 0; font-family: "IBM Plex Serif", serif; font-size: 17px; font-weight: 500; }
.card-head code { font-family: "IBM Plex Mono", monospace; font-size: 11px; padding: 1px 5px; background: var(--paper-2); border-radius: 3px; }

/* ---- Form-Grid -------------------------------------------- */
.form-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 14px 18px;
}
.form-grid label {
    display: flex; flex-direction: column; gap: 5px;
    font-size: 11.5px; color: var(--ink-2); font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.04em;
}
.form-grid label.full { grid-column: 1 / -1; }
.form-grid input, .form-grid textarea, .form-grid select {
    padding: 9px 11px; border-radius: var(--r-sm);
    background: var(--paper-2); color: var(--ink);
    border: 1px solid var(--line);
    font: 13px/1.4 "IBM Plex Sans", system-ui, sans-serif;
    letter-spacing: normal; text-transform: none;
    width: 100%;
}
.form-grid input:focus, .form-grid textarea:focus, .form-grid select:focus {
    outline: 2px solid var(--forest); outline-offset: -1px; background: var(--paper);
}
.form-grid input:disabled, .form-grid textarea:disabled {
    background: var(--paper); color: var(--ink-3); cursor: not-allowed;
}
.form-grid textarea { resize: vertical; font-family: "IBM Plex Mono", monospace; font-size: 12px; }
.hint-inline { font-size: 11px; color: var(--ink-3); font-weight: 400; text-transform: none; letter-spacing: 0; margin-top: 2px; }
.form-actions { display: flex; gap: 8px; margin-top: 6px; }
.form-actions.full { grid-column: 1 / -1; }

/* ---- Key-Value-Liste (read-only Stammdaten) -------------- */
.kv {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 24px;
}
.kv > div { display: flex; flex-direction: column; gap: 3px; }
.kv > div > div { font-size: 13.5px; color: var(--ink); }

/* ---- Flash-Banner ---------------------------------------- */
.flash {
    max-width: 820px; padding: 10px 14px;
    border-radius: var(--r-sm); font-size: 13px;
    margin: 0 0 18px; border: 1px solid transparent;
}
.flash-ok  { background: #E0EBDF; color: var(--pos); border-color: #BFD3BC; }
.flash-err { background: #FCE5DC; color: var(--neg); border-color: #F4C8B4; }

/* =================================================================
   Kontakt-Detail-Seite (2-spaltig wie Propstack)
   ================================================================= */
.kontakt-page { max-width: none; }
.kontakt-page .card { max-width: none; margin-bottom: 14px; padding: 16px 18px 18px; }
.kontakt-page .card-head h2 { font-size: 15px; }
.kontakt-page .form-grid { gap: 10px 14px; }
.kontakt-page .form-grid label { font-size: 10.5px; }

.kontakt-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 18px; margin: 0 0 16px;
}
.kontakt-head h1 { margin: 4px 0 6px; font-size: 24px; font-weight: 500; }
.kontakt-meta { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; font-size: 12.5px; }
.kontakt-meta a { color: var(--ink-2); }
.kontakt-meta a:hover { color: var(--forest); }
.kontakt-meta .state-tag { font-size: 11px; padding: 2px 7px; }
.kontakt-head-actions { display: flex; gap: 6px; }

.kontakt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.kontakt-grid .col-l, .kontakt-grid .col-r { display: flex; flex-direction: column; }

.kontakt-submit {
    grid-column: 1 / -1; position: sticky; bottom: 0;
    background: var(--bg);
    padding: 12px 16px;
    margin: 4px -16px -10px;
    display: flex; justify-content: space-between; align-items: center;
    border-top: 1px solid var(--line); gap: 14px;
    z-index: 5;
}
.kontakt-submit .btn { padding: 8px 16px; font-size: 13px; }

/* Inbox-Mini (innerhalb Kontakt-Detail) */
.inbox-mini { list-style: none; padding: 0; margin: 0; }
.inbox-mini li { border-bottom: 1px solid var(--line-soft); }
.inbox-mini li:last-child { border-bottom: 0; }
.inbox-mini li a { display: flex; gap: 8px; align-items: center; padding: 7px 4px; font-size: 12.5px; }
.inbox-mini li a:hover { background: var(--paper-2); }

/* =================================================================
   Kontakte-Liste
   ================================================================= */
.kontakte-toolbar {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-md);
    padding: 12px 14px; margin: 0 0 16px;
    display: flex; flex-direction: column; gap: 10px;
}
.kontakte-toolbar input[type=search] {
    padding: 8px 12px; border-radius: var(--r-sm);
    background: var(--paper-2); border: 1px solid var(--line);
    color: var(--ink); font: 13px "IBM Plex Sans", sans-serif;
    width: 100%; max-width: 480px;
}
.kontakte-toolbar input[type=search]:focus { outline: 2px solid var(--forest); outline-offset: -1px; background: var(--paper); }

.kontakte-table-wrap {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-md);
    overflow: auto;
}
.kontakte-table {
    width: 100%; border-collapse: collapse; font-size: 12.5px;
}
.kontakte-table th {
    text-align: left; padding: 9px 12px;
    background: var(--paper-2); border-bottom: 1px solid var(--line);
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em;
    color: var(--ink-3); font-weight: 600; position: sticky; top: 0;
}
.kontakte-table td { padding: 9px 12px; border-bottom: 1px solid var(--line-soft); vertical-align: middle; }
.kontakte-table tr:hover { background: var(--paper-2); }
.kontakte-table .kontakt-name { font-weight: 500; color: var(--ink); }
.kontakte-table .kontakt-name:hover { color: var(--forest); text-decoration: underline; }
.kontakte-table .stars { color: var(--amber); font-size: 13px; letter-spacing: 1px; }
.kontakte-table .row-archived td { opacity: 0.55; }
.kontakte-table .pill { padding: 2px 7px; font-size: 10.5px; }

.pagination {
    display: flex; gap: 14px; justify-content: center; align-items: center;
    margin: 20px 0; font-size: 13px;
}
.pagination a { color: var(--forest); }

/* =================================================================
   Objekt-Detail spezifisch
   ================================================================= */
/* Ausstattungs-Grid (3 Spalten) */
.ausst-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px 14px; }
.ausst-item {
    display: flex !important; flex-direction: row !important; align-items: center; gap: 8px;
    font-weight: 400; text-transform: none; letter-spacing: 0; font-size: 12.5px;
    color: var(--ink-2); cursor: pointer;
}
.ausst-item input[type=checkbox] { width: auto !important; margin: 0; }

/* Portal-Liste */
.portal-list { list-style: none; padding: 0; margin: 0; }
.portal-list li { padding: 6px 0; border-bottom: 1px solid var(--line-soft); font-size: 13px; }
.portal-list li:last-child { border-bottom: 0; }
.portal-list li input[type=checkbox] { width: auto; }
.portal-list li:hover { background: var(--paper-2); }

/* Ansprechpartner-Liste */
.ansp-list { list-style: none; padding: 0; margin: 0; }
.ansp-list li { padding: 6px 0; border-bottom: 1px solid var(--line-soft); font-size: 13px; }
.ansp-list li:last-child { border-bottom: 0; }
.ansp-list .rolle {
    display: inline-block; padding: 1px 6px; margin-right: 8px;
    background: var(--paper-2); border-radius: 3px; font-size: 10.5px;
    text-transform: uppercase; letter-spacing: 0.04em; color: var(--ink-3);
}

/* Status-Pills (Farb-Codierung wie Propstack) */
.pill.akquise      { background: #E0EBDF; color: var(--pos); }
.pill.vorbereitung { background: #F3DD9E; color: var(--ink); }
.pill.aktiv        { background: var(--forest); color: #F6F2EA; }
.pill.reserviert   { background: var(--hot); color: #fff; }
.pill.beurkundet   { background: var(--amber); color: #fff; }
.pill.verkauft, .pill.vermittelt { background: var(--ink); color: #F6F2EA; }
.pill.vermietet    { background: #1E8F4B; color: #fff; }
.pill.inaktiv, .pill.archiviert  { background: var(--line); color: var(--ink-3); }

/* Notiz-Form + Liste */
.note-form { display: flex; gap: 8px; align-items: flex-end; }
.note-form textarea {
    flex: 1; padding: 8px 10px; border-radius: var(--r-sm);
    background: var(--paper-2); border: 1px solid var(--line); resize: vertical;
    font: 13px "IBM Plex Sans", sans-serif;
}
.note-form textarea:focus { outline: 2px solid var(--forest); outline-offset: -1px; }

.note-list { list-style: none; padding: 0; margin: 0; }
.note-item {
    padding: 10px 12px; margin-bottom: 8px;
    background: var(--paper-2); border: 1px solid var(--line-soft);
    border-radius: var(--r-sm); border-left: 3px solid var(--line);
}
.note-item.pinned { border-left-color: var(--amber); background: #FCF4E0; }
.note-item header { display: flex; gap: 8px; align-items: baseline; margin-bottom: 4px; font-size: 11.5px; }
.note-item .note-body { font-size: 13px; line-height: 1.5; color: var(--ink); }

/* Tabellen-Spalten "num" rechtsbündig */
.kontakte-table .num { text-align: right; font-family: "IBM Plex Mono", monospace; font-size: 12px; white-space: nowrap; }

/* =================================================================
   Dashboard — Apple-inspired (helle Karten, große Typo, viel Whitespace)
   ================================================================= */
.dashboard { background: #FAFAF7; padding: 32px 40px 60px; max-width: 1280px; margin: 0 auto; }

.dash-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    margin: 0 0 28px; flex-wrap: wrap; gap: 16px;
}
.dash-greet { margin: 0 0 4px; color: var(--ink-3); font-size: 13px; font-weight: 500; }
.dash-head h1 { margin: 0; font-size: 32px; font-weight: 500; letter-spacing: -0.01em; }
.dash-quick { display: flex; gap: 8px; flex-wrap: wrap; }
.dash-quick .btn { padding: 7px 14px; font-size: 12.5px; }

/* ---- KPI-Karten (Hero-Style) ---- */
.kpi-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
    margin: 0 0 28px;
}
.kpi-card {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 18px 20px 20px;
    display: flex; flex-direction: column; gap: 4px;
    transition: transform .15s, box-shadow .15s, border-color .15s;
    text-decoration: none; color: inherit;
}
.kpi-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(20,17,13,0.06);
    border-color: var(--ink-4);
}
.kpi-label {
    font-size: 12px; color: var(--ink-3); font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.04em;
}
.kpi-value {
    font-family: "IBM Plex Serif", Georgia, serif;
    font-size: 44px; font-weight: 500; line-height: 1.05;
    margin: 6px 0 2px; color: var(--ink);
    font-feature-settings: "tnum";
    letter-spacing: -0.02em;
}
.kpi-sub { font-size: 12px; }

/* ---- Zwei Spalten ---- */
.dash-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.dash-col  { display: flex; flex-direction: column; gap: 14px; }
.dash-card {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 18px 22px 20px;
}
.dash-card-head {
    display: flex; justify-content: space-between; align-items: baseline;
    margin: 0 0 12px; padding-bottom: 10px;
    border-bottom: 1px solid var(--line-soft);
}
.dash-card-head h2 { margin: 0; font-family: "IBM Plex Serif", serif; font-size: 18px; font-weight: 500; }
.dash-sub {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--ink-3); margin: 4px 0 8px; font-weight: 600;
}

/* ---- Dash-Listen ---- */
.dash-list { list-style: none; padding: 0; margin: 0; }
.dash-list li {
    display: flex; align-items: center; gap: 8px;
    padding: 7px 0; border-bottom: 1px solid var(--line-soft);
    font-size: 13px; flex-wrap: wrap;
}
.dash-list li:last-child { border-bottom: 0; }
.dash-list li:hover { background: rgba(0,0,0,0.015); }
.dash-time { color: var(--ink-3); font-size: 11.5px; flex-shrink: 0; }
.dash-title { font-weight: 500; color: var(--ink); }
.dash-title:hover { color: var(--forest); }
.dash-empty { margin: 0; color: var(--ink-3); font-size: 13px; padding: 4px 0; }

/* Prio-Punkte für Aufgaben */
.prio-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--line); flex-shrink: 0; }
.prio-dot.prio-dringend { background: var(--neg); }
.prio-dot.prio-hoch     { background: var(--hot); }
.prio-dot.prio-normal   { background: var(--forest); }
.prio-dot.prio-niedrig  { background: var(--ink-4); }

/* "neu"-Pill smaller */
.pill.ghost.neu { background: var(--amber); color: #fff; border-color: var(--amber); }

/* Responsive */
@media (max-width: 1100px) {
    .kpi-grid  { grid-template-columns: repeat(2, 1fr); }
    .dash-cols { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .dashboard { padding: 18px 16px 40px; }
    .dash-head h1 { font-size: 26px; }
    .kpi-grid  { grid-template-columns: 1fr; gap: 10px; }
    .kpi-value { font-size: 36px; }
}

/* =================================================================
   Objekte-Liste (Apple-Style mit Thumbnails)
   ================================================================= */
.obj-list-wrap {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 14px;
    overflow: hidden;
}
.obj-list { list-style: none; padding: 0; margin: 0; }
.obj-row {
    border-bottom: 1px solid var(--line-soft);
    display: flex; align-items: stretch;
}
.obj-row:last-child { border-bottom: 0; }
.obj-row:hover { background: rgba(0,0,0,0.015); }
.obj-row:has(.obj-check:checked) { background: rgba(15,118,110,0.06); }

.obj-check-cell {
    display: flex; align-items: center; justify-content: center;
    padding: 0 6px 0 14px; cursor: pointer;
    user-select: none; flex-shrink: 0;
}
.obj-check-cell input { width: 18px; height: 18px; cursor: pointer; }

.obj-list-head {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 18px; border-bottom: 1px solid var(--line-soft);
    background: var(--paper-2, #FBF7EE);
}

.obj-link {
    flex: 1; min-width: 0;
    display: grid;
    grid-template-columns: 64px 1fr auto auto;
    gap: 18px;
    align-items: center;
    padding: 14px 18px;
    text-decoration: none;
    color: inherit;
}

/* ===== Bulk-Aktions-Leiste ===== */
.bulk-bar {
    position: sticky; top: 0; z-index: 50;
    background: var(--paper-2, #FBF7EE); color: var(--ink, #14110D);
    border: 1px solid var(--line, #E5E0D2);
    border-radius: 8px;
    padding: 10px 16px; margin: 0 0 12px;
    display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
    transition: background 0.2s, color 0.2s, box-shadow 0.2s;
}
.bulk-bar.has-selection {
    background: #14110D; color: #fff;
    border-color: #14110D;
    box-shadow: 0 4px 14px rgba(20,17,13,0.22);
}
.bulk-bar-all { display: flex; align-items: center; gap: 8px; font-weight: 500; }
.bulk-bar-all input { width: 18px; height: 18px; cursor: pointer; }

.bulk-bar-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-left: auto; align-items: center; }
.bulk-bar select {
    padding: 7px 12px; border-radius: 6px; font-size: 13.5px;
    font-family: inherit;
    background: var(--paper, #fff); color: var(--ink);
    border: 1px solid var(--line);
}
.bulk-bar.has-selection select {
    background: rgba(255,255,255,0.1); color: #fff;
    border: 1px solid rgba(255,255,255,0.2);
}
.bulk-bar.has-selection select option { color: #14110D; }

.bulk-bar .btn { padding: 7px 14px; }
.bulk-bar.has-selection .btn:not(.ghost) { background: rgba(255,255,255,0.14); color: #fff; border: 0; }
.bulk-bar.has-selection .btn:not(.ghost):hover:not(:disabled) { background: rgba(255,255,255,0.24); }
.bulk-bar.has-selection .btn.ghost { background: transparent; border: 1px solid rgba(255,255,255,0.3); color: #fff; }
.bulk-bar .btn:disabled { opacity: 0.45; cursor: not-allowed; }
.bulk-bar select:disabled { opacity: 0.55; cursor: not-allowed; }
.bulk-bar.has-selection .muted { color: rgba(255,255,255,0.75); }

/* ===== Bulk-Edit Modal ===== */
.modal {
    position: fixed; inset: 0; z-index: 200;
    display: flex; align-items: flex-start; justify-content: center;
    padding: 40px 16px; overflow-y: auto;
}
.modal-backdrop {
    position: fixed; inset: 0; background: rgba(20,17,13,0.55);
    backdrop-filter: blur(2px);
}
.modal-box {
    position: relative; z-index: 1;
    background: var(--paper, #fff); border-radius: 10px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.25);
    width: 100%; max-width: 760px;
    padding: 24px 28px;
}
.modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.modal-head h2 { font-family: "IBM Plex Serif", serif; font-size: 22px; font-weight: 500; margin: 0; }
.btn-x { border: 0; background: transparent; font-size: 28px; cursor: pointer; color: var(--ink-3); line-height: 1; padding: 0 4px; }
.btn-x:hover { color: var(--ink); }

.bulk-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 14px 18px;
    margin-top: 8px;
}
.bulk-grid label { display: flex; flex-direction: column; gap: 4px; }
.bulk-grid label > span { font-size: 12px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
.bulk-grid label.span2 { grid-column: span 2; }
.bulk-grid input, .bulk-grid select {
    padding: 8px 10px; border: 1px solid var(--line);
    border-radius: 6px; font-size: 14px;
    background: var(--paper); font-family: inherit; color: var(--ink);
}
.bulk-grid input:focus, .bulk-grid select:focus {
    outline: 2px solid var(--forest); border-color: var(--forest);
}
.bulk-grid small.muted { font-size: 11.5px; color: var(--ink-3); margin-top: 2px; }

.modal-foot {
    display: flex; justify-content: flex-end; gap: 10px;
    padding-top: 16px; margin-top: 12px;
    border-top: 1px solid var(--line);
}

@media (max-width: 640px) {
    .bulk-grid { grid-template-columns: 1fr; }
    .bulk-grid label.span2 { grid-column: span 1; }
}

.obj-thumb {
    width: 64px; height: 64px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 2px 4px rgba(20,17,13,0.08);
    flex-shrink: 0;
}
.obj-init {
    font-family: "IBM Plex Serif", Georgia, serif;
    font-size: 20px; font-weight: 600;
    color: rgba(255,255,255,0.92);
    letter-spacing: 0.04em;
}

.obj-main { min-width: 0; }
.obj-title {
    display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
    margin-bottom: 4px;
}
.obj-titel-text { font-size: 14.5px; font-weight: 600; color: var(--ink); }
.obj-link:hover .obj-titel-text { color: var(--forest); }
.obj-nr { font-size: 11px; color: var(--ink-3); background: var(--paper-2); padding: 1px 6px; border-radius: 3px; }
.obj-sub {
    display: flex; gap: 5px; margin-bottom: 4px; flex-wrap: wrap;
}
.obj-sub .pill { padding: 1px 7px; font-size: 10.5px; }
.obj-addr { font-size: 12.5px; }

.obj-stats {
    display: flex; gap: 18px; align-items: center;
    flex-shrink: 0;
}
.obj-stat { text-align: right; min-width: 70px; }
.obj-stat-val {
    font-family: "IBM Plex Serif", Georgia, serif;
    font-size: 17px; font-weight: 500; color: var(--ink);
    line-height: 1.1; letter-spacing: -0.01em;
    font-feature-settings: "tnum";
}
.obj-stat-lbl {
    font-size: 10px; color: var(--ink-3); text-transform: uppercase;
    letter-spacing: 0.06em; margin-top: 2px; font-weight: 500;
}

.obj-meta {
    text-align: right; font-size: 11.5px;
    color: var(--ink-2); flex-shrink: 0; min-width: 96px;
}
.obj-meta .mono { display: block; margin-top: 2px; font-size: 10.5px; }

@media (max-width: 900px) {
    .obj-link { grid-template-columns: 56px 1fr; gap: 12px; }
    .obj-stats, .obj-meta { grid-column: 1 / -1; padding-left: 68px; padding-top: 4px; }
    .obj-meta { text-align: left; min-width: 0; }
    .obj-stats { justify-content: flex-start; }
}

/* =================================================================
   Marktwert-Karte (Hero im Objekt-Detail)
   ================================================================= */
.wert-card {
    background: linear-gradient(180deg, var(--paper) 0%, #FCFAF4 100%);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 24px 26px;
    margin: 0 0 16px;
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 1.4fr) auto;
    gap: 28px;
    align-items: center;
}
.wert-main { min-width: 0; }
.wert-label {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--ink-3); font-weight: 600;
}
.wert-price {
    font-family: "IBM Plex Serif", Georgia, serif;
    font-size: 42px; font-weight: 500; line-height: 1.05;
    margin: 4px 0 6px; letter-spacing: -0.02em;
    font-feature-settings: "tnum";
}
.wert-sub { display: flex; gap: 8px; align-items: center; font-size: 12.5px; flex-wrap: wrap; }
.wert-sub .pill { padding: 2px 8px; font-size: 10.5px; }
.wert-sub .pill.forest { background: var(--forest); color: #F6F2EA; }
.wert-sub .pill.amber  { background: var(--amber);  color: #fff; }
.wert-sub .pill.hot    { background: var(--hot);    color: #fff; }

/* ---- Wert-Balken ---- */
.wert-bar-wrap { display: flex; flex-direction: column; gap: 6px; }
.wert-bar {
    position: relative; height: 8px;
    background: var(--line); border-radius: 999px;
}
.wert-bar-track {
    position: absolute; left: 0; right: 0; top: 0; bottom: 0;
    background: linear-gradient(90deg, var(--amber) 0%, var(--forest) 50%, var(--hot) 100%);
    border-radius: 999px;
    opacity: 0.35;
}
.wert-bar-marker {
    position: absolute; top: 50%; transform: translate(-50%, -50%);
    width: 16px; height: 16px;
    background: var(--ink); border: 3px solid #fff;
    border-radius: 50%;
    box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}
.wert-bar-labels {
    display: flex; justify-content: space-between;
    font-size: 11px; color: var(--ink-2); font-family: "IBM Plex Mono", monospace;
    font-feature-settings: "tnum";
}

/* ---- Wert-Grid (rechts) ---- */
.wert-grid {
    display: grid; grid-template-columns: repeat(2, auto); gap: 10px 22px;
}
.wert-stat-lbl {
    font-size: 10px; color: var(--ink-3); text-transform: uppercase;
    letter-spacing: 0.05em; font-weight: 500;
}
.wert-stat-val {
    font-size: 13.5px; font-weight: 500; color: var(--ink);
    margin-top: 1px; font-feature-settings: "tnum";
}

@media (max-width: 1100px) {
    .wert-card { grid-template-columns: 1fr; gap: 18px; }
    .wert-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
    .wert-price { font-size: 32px; }
    .wert-grid  { grid-template-columns: repeat(2, 1fr); }
}

/* =================================================================
   Termine-Liste (gruppiert nach Tag, Apple-Style)
   ================================================================= */
.termine-list { display: flex; flex-direction: column; gap: 18px; }
.termin-day-h {
    margin: 0 0 8px; font-family: "IBM Plex Serif", Georgia, serif;
    font-size: 16px; font-weight: 500;
    display: flex; gap: 10px; align-items: baseline;
}
.termin-list-items {
    list-style: none; padding: 0; margin: 0;
    background: var(--paper); border: 1px solid var(--line); border-radius: 14px;
    overflow: hidden;
}
.termin-item {
    display: grid;
    grid-template-columns: 70px 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--line-soft);
    border-left: 3px solid transparent;
}
.termin-item:last-child { border-bottom: 0; }
.termin-item.status-bestaetigt   { border-left-color: var(--forest); }
.termin-item.status-geplant      { border-left-color: var(--amber); }
.termin-item.status-durchgefuehrt{ border-left-color: var(--ink-4); }
.termin-item.status-abgesagt     { border-left-color: var(--neg); background: rgba(184,58,42,0.02); }
.termin-item.status-no_show      { border-left-color: var(--ink); background: rgba(0,0,0,0.02); }

.termin-time {
    text-align: center; padding-right: 4px; border-right: 1px solid var(--line-soft);
}
.termin-time-start {
    font-family: "IBM Plex Mono", monospace;
    font-size: 15px; font-weight: 600; color: var(--ink);
    line-height: 1.1;
}
.termin-time-end { font-size: 11px; }

.termin-title {
    display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
    margin-bottom: 3px;
}
.termin-title a { font-weight: 600; color: var(--ink); font-size: 13.5px; }
.termin-title a:hover { color: var(--forest); }
.termin-meta { font-size: 12px; }
.termin-actions { display: flex; gap: 4px; flex-shrink: 0; }
.termin-actions .btn.sm { padding: 4px 8px; font-size: 11.5px; }

/* Status-Pills für Termine */
.pill.geplant      { background: var(--amber); color: #fff; }
.pill.bestaetigt   { background: var(--forest); color: #F6F2EA; }
.pill.durchgefuehrt{ background: var(--ink-4); color: #fff; }
.pill.abgesagt     { background: var(--neg); color: #fff; }
.pill.no_show      { background: var(--ink); color: #fff; }

/* =================================================================
   Aufgaben-Liste (kanban-light)
   ================================================================= */
.aufgaben-list { display: flex; flex-direction: column; gap: 8px; }
.aufgabe-item {
    background: var(--paper); border: 1px solid var(--line);
    border-radius: 10px;
    padding: 12px 16px;
    display: grid;
    grid-template-columns: 22px 1fr auto;
    gap: 12px; align-items: center;
    border-left: 4px solid transparent;
}
.aufgabe-item.prio-dringend { border-left-color: var(--neg); }
.aufgabe-item.prio-hoch     { border-left-color: var(--hot); }
.aufgabe-item.prio-normal   { border-left-color: var(--forest); }
.aufgabe-item.prio-niedrig  { border-left-color: var(--ink-4); }
.aufgabe-item.done { opacity: 0.5; }
.aufgabe-item.done .auf-title { text-decoration: line-through; }
.aufgabe-check {
    width: 20px; height: 20px; border-radius: 50%; border: 1.5px solid var(--ink-3);
    display: inline-block; cursor: pointer; flex-shrink: 0;
    transition: background 0.15s, border-color 0.15s;
    background: transparent;
}
.aufgabe-check:hover { border-color: var(--forest); }
.aufgabe-check.done { background: var(--forest); border-color: var(--forest); }
.aufgabe-check.done::after { content: '✓'; color: #F6F2EA; font-size: 12px; display: block; text-align: center; line-height: 18px; }
.auf-title { font-size: 13.5px; font-weight: 500; color: var(--ink); }
.auf-meta { font-size: 11.5px; color: var(--ink-3); margin-top: 2px; }
.auf-faellig { font-family: "IBM Plex Mono", monospace; font-size: 11.5px; flex-shrink: 0; }
.auf-faellig.overdue { color: var(--neg); font-weight: 600; }

/* =================================================================
   Entity-Tabs (Propstack-Style — Detail/Aktivitäten/Deals/...)
   ================================================================= */
.entity-tabs {
    display: flex; gap: 4px;
    border-bottom: 1px solid var(--line);
    margin: 0 0 18px;
    overflow-x: auto;
}
.entity-tab {
    padding: 9px 14px; font-size: 13px; color: var(--ink-2); font-weight: 500;
    border-bottom: 2px solid transparent; margin-bottom: -1px;
    text-decoration: none; white-space: nowrap;
    transition: color .15s, border-color .15s;
}
.entity-tab:hover { color: var(--ink); }
.entity-tab.on { color: var(--forest); border-bottom-color: var(--forest); font-weight: 600; }
.entity-tab .tab-cnt {
    display: inline-block; margin-left: 4px;
    background: var(--paper-2); color: var(--ink-3);
    padding: 1px 7px; border-radius: 9px;
    font-size: 10.5px; font-family: "IBM Plex Mono", monospace; font-weight: 500;
}
.entity-tab.on .tab-cnt { background: var(--forest); color: #F6F2EA; }

/* Aktivitäten-Stream */
.act-stream { list-style: none; padding: 0; margin: 0; }
.act-stream li {
    display: grid; grid-template-columns: 24px 120px auto 1fr; gap: 12px;
    padding: 8px 4px; border-bottom: 1px solid var(--line-soft);
    font-size: 13px; align-items: center;
}
.act-stream li:hover { background: var(--paper-2); }
.act-icon { font-size: 14px; text-align: center; }
.act-time { font-size: 11.5px; color: var(--ink-3); }
.act-typ {
    font-size: 10.5px; padding: 1px 7px; background: var(--paper-2); border-radius: 3px;
    color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.04em;
}
.act-titel { color: var(--ink); font-weight: 500; }
.act-titel:hover { color: var(--forest); }

/* Medien-Grid */
.medien-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; }
.medien-grid figure { margin: 0; background: var(--paper-2); border-radius: 8px; overflow: hidden; position: relative; }
.medien-grid img { width: 100%; height: 140px; object-fit: cover; display: block; background: var(--line); }
.medien-grid figcaption { padding: 8px 10px; font-size: 12px; color: var(--ink-2); display: flex; justify-content: space-between; align-items: center; gap: 6px; flex-wrap: wrap; }

/* Hover-Aktions-Overlay */
.medien-actions {
    position: absolute; top: 6px; right: 6px; z-index: 2;
    display: flex; gap: 3px;
    opacity: 0; transition: opacity 0.15s;
    background: rgba(20,17,13,0.78);
    border-radius: 6px; padding: 3px;
    backdrop-filter: blur(4px);
}
.medien-fig:hover .medien-actions,
.medien-fig:focus-within .medien-actions { opacity: 1; }
.ma-btn {
    width: 28px; height: 28px;
    border: 0; background: transparent;
    cursor: pointer; font-size: 14px; line-height: 1;
    border-radius: 4px; color: #fff;
    padding: 0; display: inline-flex; align-items: center; justify-content: center;
}
.ma-btn:hover { background: rgba(255,255,255,0.18); }
.ma-btn.ma-del:hover { background: rgba(220,38,38,0.45); }
.ma-btn:disabled { opacity: 0.4; cursor: wait; }

/* ===== Vorlagen-Editor ===== */
.vorlagen-layout {
    display: grid;
    grid-template-columns: minmax(360px, 420px) 1fr 240px;
    gap: 16px;
    align-items: start;
}
/* Kein Editor aktiv (keine Vorlage gewählt) → Liste nimmt volle Breite, 2-spaltig */
.vorlagen-layout.no-editor {
    grid-template-columns: 1fr;
}
.vorlagen-layout.no-editor .vorlagen-list {
    position: static; max-height: none;
}
.vorlagen-layout.no-editor .vorlagen-ul {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 6px 12px;
}
.vorlagen-layout.no-editor .vorlagen-section {
    grid-column: 1 / -1;
}
.vorlagen-layout.no-editor .vorlagen-editor,
.vorlagen-layout.no-editor .vl-platzhalter {
    display: none;
}
@media (max-width: 1180px) {
    .vorlagen-layout { grid-template-columns: minmax(320px, 380px) 1fr; }
    .vl-platzhalter { display: none; }
}
@media (max-width: 880px) {
    .vorlagen-layout { grid-template-columns: 1fr; }
}
.vorlagen-list {
    background: var(--paper); border: 1px solid var(--line); border-radius: 8px;
    padding: 10px; position: sticky; top: 12px; max-height: calc(100vh - 80px); overflow: auto;
}
.vorlagen-list-filter { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.vorlagen-list-filter .pill { font-size: 11.5px; padding: 4px 10px; }
.vorlagen-ul { list-style: none; padding: 0; margin: 0; }
.vorlagen-section {
    font-size: 11px; font-weight: 600; color: var(--ink-3);
    text-transform: uppercase; letter-spacing: 0.05em;
    padding: 10px 4px 4px; border-bottom: 1px solid var(--line-soft);
}
.vorlagen-item a {
    display: block; padding: 8px 6px; text-decoration: none; color: inherit;
    border-radius: 5px; transition: background 0.15s; line-height: 1.3;
}
.vorlagen-item a:hover { background: var(--paper-2); }
.vorlagen-item.on a { background: var(--paper-2); border-left: 3px solid var(--forest); padding-left: 10px; }
.vorlagen-item.inaktiv a { opacity: 0.55; }
.vorlagen-item strong { display: block; font-size: 13.5px; }
.vl-betreff { display: block; font-size: 12px; color: var(--ink-3); margin-top: 2px;
              overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Bulk-Bar oben in der Vorlagen-Liste */
.vl-bulk-bar {
    display: flex; align-items: center; gap: 6px;
    background: var(--paper-2); border: 1px solid var(--line);
    border-radius: 6px; padding: 6px 10px; margin-bottom: 8px;
    font-size: 12.5px;
    transition: background 0.15s, color 0.15s;
}
.vl-bulk-bar.has-selection { background: #14110D; color: #fff; }
.vl-bulk-bar.has-selection .btn { color: #fff; border-color: rgba(255,255,255,0.25); background: transparent; }
.vl-bulk-bar.has-selection .btn:hover:not(:disabled) { background: rgba(255,255,255,0.15); }
.vl-bulk-bar .btn { padding: 3px 8px; font-size: 11.5px; }
.vl-bulk-bar .btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* Checkbox-Spalte pro Listen-Item */
.vorlagen-item { display: flex !important; align-items: stretch; padding: 0 !important; }
.vorlagen-item a { flex: 1; padding-left: 4px !important; }
.vl-check-cell {
    display: flex; align-items: center; padding: 0 8px 0 6px;
    cursor: pointer; user-select: none;
}
.vl-check-cell input { width: 15px; height: 15px; cursor: pointer; }

.vorlagen-editor {
    background: var(--paper); border: 1px solid var(--line); border-radius: 8px;
    padding: 18px 22px;
}
.vl-form .vl-row.two { display: grid; grid-template-columns: 1fr 200px; gap: 12px; }
.vl-form label { display: block; margin-bottom: 12px; }
.vl-form label > span {
    display: block; font-size: 11.5px; color: var(--ink-3);
    text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; margin-bottom: 4px;
}
.vl-form input, .vl-form textarea, .vl-form select {
    width: 100%; padding: 8px 10px;
    border: 1px solid var(--line); border-radius: 6px;
    font-family: inherit; font-size: 14px; color: var(--ink); background: var(--paper);
}
.vl-form textarea { font-family: "IBM Plex Mono", monospace; font-size: 13px; line-height: 1.5; }

/* Quill-Editor styling — passt zum Wohntraum-Theme */
#vl-quill-wrap { background: var(--paper); border-radius: 6px; overflow: hidden; }
#vl-quill-wrap .ql-toolbar.ql-snow {
    border: 1px solid var(--line);
    border-top-left-radius: 6px; border-top-right-radius: 6px;
    background: var(--paper-2);
}
#vl-quill-wrap .ql-container.ql-snow {
    border: 1px solid var(--line); border-top: 0;
    border-bottom-left-radius: 6px; border-bottom-right-radius: 6px;
    font-family: "IBM Plex Sans", sans-serif; font-size: 14px;
}
#vl-quill .ql-editor {
    min-height: 280px; line-height: 1.6;
    color: var(--ink);
}
#vl-quill .ql-editor.ql-blank::before {
    color: var(--ink-3); font-style: italic;
}
/* Toggle-Link */
#vl-toggle-html { color: var(--forest); text-decoration: none; }
#vl-toggle-html:hover { text-decoration: underline; }

/* Quill im Mail-Composer (gleiches Theme wie Vorlagen) */
#mc-quill-wrap { background: var(--paper); border-radius: 6px; overflow: hidden; }
#mc-quill-wrap .ql-toolbar.ql-snow {
    border: 1px solid var(--line);
    border-top-left-radius: 6px; border-top-right-radius: 6px;
    background: var(--paper-2);
}
#mc-quill-wrap .ql-container.ql-snow {
    border: 1px solid var(--line); border-top: 0;
    border-bottom-left-radius: 6px; border-bottom-right-radius: 6px;
    font-family: "IBM Plex Sans", sans-serif; font-size: 14px;
}
#mc-quill .ql-editor { min-height: 300px; line-height: 1.6; color: var(--ink); }
#mc-quill .ql-editor.ql-blank::before { color: var(--ink-3); font-style: italic; }
#mc-toggle-html { text-decoration: none; }
#mc-toggle-html:hover { text-decoration: underline; }

/* ===== Mail-Composer Verknüpfungs-Card (kompakt, empro-style) ===== */
.mc-card {
    background: var(--paper-2);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 8px 14px;
    margin-bottom: 16px;
}
.mc-field-row {
    display: grid;
    grid-template-columns: 80px 1fr;
    align-items: start;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid rgba(0,0,0,0.04);
}
.mc-field-row:last-of-type { border-bottom: 0; }
.mc-flbl {
    font-size: 12px; color: var(--ink-3);
    text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600;
    padding-top: 8px; margin: 0;
}
.mc-flv { min-width: 0; }
.mc-flv input[type=text],
.mc-flv input[type=email],
.mc-flv input[type=search],
.mc-flv select {
    width: 100%;
    padding: 7px 10px;
    border: 1px solid var(--line);
    border-radius: 5px;
    font-size: 14px; background: var(--paper);
    font-family: inherit;
}
.mc-flv input:focus, .mc-flv select:focus { outline: 2px solid var(--forest); border-color: var(--forest); }

/* Such-Box im Card-Kontext schlanker */
.mc-card .mc-search-wrap input[type=search] {
    border: 1px solid var(--line); padding: 7px 10px;
}
.mc-card .mc-search-wrap input[type=search]:focus { border-color: var(--forest); outline: 2px solid var(--forest); }

/* "Direkte E-Mail / Name überschreiben"-Akkordeon */
.mc-adv > summary {
    cursor: pointer; padding: 6px 0;
    font-size: 12px; color: var(--ink-3);
    list-style: none; user-select: none;
}
.mc-adv > summary::before { content: '▸ '; font-size: 10px; }
.mc-adv[open] > summary::before { content: '▾ '; }
.mc-adv > summary:hover { color: var(--forest); }
.mc-adv .mc-field-row:first-of-type { border-top: 1px solid rgba(0,0,0,0.04); margin-top: 4px; }

@media (max-width: 600px) {
    .mc-field-row { grid-template-columns: 1fr; gap: 4px; }
    .mc-flbl { padding-top: 0; }
}
.vl-form input:focus, .vl-form textarea:focus, .vl-form select:focus {
    outline: 2px solid var(--forest); border-color: var(--forest);
}
.vl-aktiv { display: flex !important; align-items: center; gap: 8px; }
.vl-aktiv input { width: auto !important; }
.vl-aktiv span { text-transform: none !important; letter-spacing: 0 !important; font-size: 14px !important; color: var(--ink) !important; font-weight: 400 !important; }
.vl-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }

.vl-platzhalter {
    background: var(--paper); border: 1px solid var(--line); border-radius: 8px;
    padding: 12px 14px; position: sticky; top: 12px;
    max-height: calc(100vh - 80px); overflow: auto;
}
.vl-platzhalter header { margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--line); display: flex; align-items: baseline; gap: 6px; }
.vl-platzhalter details { margin-bottom: 6px; }
.vl-platzhalter summary {
    cursor: pointer; font-size: 13px; font-weight: 600;
    padding: 4px 0; color: var(--ink);
}
.vl-platzhalter ul { list-style: none; padding: 0; margin: 4px 0 8px; }
.ph-btn {
    width: 100%; text-align: left;
    background: transparent; border: 0; border-radius: 4px;
    padding: 6px 8px; cursor: pointer;
    font-family: inherit; font-size: 12px; color: var(--ink);
    display: flex; flex-direction: column; gap: 1px;
    transition: background 0.1s;
}
.ph-btn:hover { background: var(--paper-2); }
.ph-btn.inserted { background: #ecfdf5; }
.ph-btn code {
    font-size: 11px; color: var(--forest); font-family: "IBM Plex Mono", monospace;
}
.ph-btn span { font-size: 11.5px; color: var(--ink-3); }

.vl-preview {
    margin: 6px 0 16px;
    background: var(--paper); border: 1px solid var(--forest); border-radius: 8px;
    padding: 14px 18px;
}
.vl-preview header {
    display: flex; align-items: center; gap: 8px;
    margin-bottom: 10px; padding-bottom: 8px;
    border-bottom: 1px solid var(--line);
    flex-wrap: wrap;
}
.vl-preview header .muted { font-size: 12px; }
.vl-preview-subject {
    font-weight: 600; font-size: 15px; padding: 8px 12px;
    background: var(--paper-2); border-radius: 4px; margin-bottom: 8px;
    color: var(--ink);
}
.vl-preview-body {
    padding: 12px 14px; background: var(--paper-2); border-radius: 4px;
    line-height: 1.6; font-size: 13.5px;
    max-height: 500px; overflow-y: auto;
    color: var(--ink);
}
.vl-preview-body img { max-width: 100%; height: auto; }
.vl-preview-body em.muted { color: var(--ink-3); font-style: italic; }

.ph-help-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 24px; }
@media (max-width: 720px) { .ph-help-grid { grid-template-columns: 1fr; } }

/* ===== Mail-Composer Platzhalter-Popup + Preview ===== */
.mc-pop {
    display: none;
    background: var(--paper); border: 1px solid var(--line);
    border-radius: 8px; padding: 12px 14px; margin-bottom: 8px;
    max-height: 280px; overflow-y: auto;
    box-shadow: 0 8px 22px rgba(0,0,0,0.08);
}
.mc-pop.open { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px 14px; }
.mc-pop-group { font-size: 12.5px; }
.mc-pop-group strong { display: block; font-size: 11px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.mc-pop-btn {
    display: block; width: 100%; text-align: left;
    background: transparent; border: 0;
    padding: 4px 6px; cursor: pointer;
    font-family: inherit; font-size: 12.5px; color: var(--ink);
    border-radius: 4px;
}
.mc-pop-btn:hover { background: var(--paper-2); color: var(--forest); }
.mc-pop-btn.flash { background: #ecfdf5; }

.mc-preview {
    margin-top: 12px;
    background: var(--paper); border: 1px solid var(--forest); border-radius: 8px;
    padding: 14px 18px;
}
.mc-preview header { display: flex; align-items: baseline; gap: 8px; margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--line); }
.mc-preview-subject { font-weight: 600; font-size: 15px; padding: 6px 10px; background: var(--paper-2); border-radius: 4px; margin-bottom: 8px; }
.mc-preview-body { padding: 10px 12px; background: var(--paper-2); border-radius: 4px; line-height: 1.6; font-size: 13.5px; }

/* ===== Empfänger- + Objekt-Picker im Composer ===== */
.mc-chip-row {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    margin: 4px 0 0;
}
.mc-chip {
    display: inline-flex; align-items: center; gap: 6px;
    background: #e0f2f1; color: #115e59;
    border: 1px solid #99f6e4; border-radius: 16px;
    padding: 4px 8px 4px 12px; font-size: 13px;
}
.mc-chip .muted { color: #115e59; opacity: 0.7; font-weight: 400; }
.mc-chip-x {
    border: 0; background: transparent; color: inherit;
    cursor: pointer; font-size: 16px; line-height: 1;
    padding: 0 2px 0 4px; border-radius: 50%;
}
.mc-chip-x:hover { background: rgba(0,0,0,0.1); }

.mc-search-wrap { }
.mc-search-wrap input[type=search] {
    width: 100%; padding: 10px 12px;
    border: 2px solid var(--forest); border-radius: 6px;
    font-size: 14px; background: var(--paper);
}
.mc-search-wrap input[type=search]:focus { outline: 2px solid var(--forest); }
.mc-search-results {
    display: none; margin-top: 6px;
    background: var(--paper); border: 1px solid var(--line);
    border-radius: 6px; max-height: 260px; overflow-y: auto;
}
.mc-search-item {
    padding: 10px 14px; cursor: pointer;
    border-bottom: 1px solid var(--line-soft);
    transition: background 0.1s;
}
.mc-search-item:hover { background: var(--paper-2); }
.mc-search-item:last-child { border-bottom: 0; }
.mc-search-item strong { display: block; font-size: 14px; font-weight: 500; color: var(--ink); }
.mc-search-item small { display: block; font-size: 12px; color: var(--ink-3); margin-top: 1px; }
.mc-search-item.mc-search-freemail { background: #ecfdf5; }
.mc-search-item.mc-search-freemail:hover { background: #d1fae5; }
.mc-search-item.mc-search-freemail strong { color: #065f46; }
.mc-search-empty { padding: 12px 14px; color: var(--ink-3); font-size: 13px; border-bottom: 1px solid var(--line-soft); }
.mc-search-empty:last-child { border-bottom: 0; }

.mc-search-header {
    padding: 6px 12px;
    background: var(--paper-2);
    border-bottom: 1px solid var(--line);
    font-size: 11.5px; color: var(--ink-3);
    text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600;
    position: sticky; top: 0; z-index: 1;
}
.mc-search-results { border: 1px solid var(--forest); }

/* ===== Mail-Body-Anzeige (Inbox, Konversations-Detail) ===== */
.mail-body {
    line-height: 1.65; font-size: 14px;
    word-wrap: break-word; overflow-wrap: break-word;
}
.mail-body a {
    color: var(--forest, #0f766e);
    text-decoration: underline;
    word-break: break-all;
}
.mail-body a:hover { color: var(--forest-dark, #115e59); }
.mail-body img { max-width: 100%; height: auto; }
.mail-body blockquote {
    border-left: 3px solid var(--line);
    padding: 4px 12px; margin: 8px 0;
    color: var(--ink-3); font-size: 13px;
}
.mail-body table { border-collapse: collapse; max-width: 100%; }
.mail-body td, .mail-body th { padding: 4px 8px; }

/* ===== Aktivitäten-Timeline (Konversation) ===== */
.act-filter {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin: 12px 0 14px; padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
}
.act-filter .pill { font-size: 12.5px; padding: 4px 10px; }

.notiz-quick {
    background: var(--paper-2);
    border: 1px dashed var(--line);
    border-radius: 8px;
    padding: 12px; margin-bottom: 14px;
}
.notiz-quick textarea {
    width: 100%; resize: vertical;
    border: 1px solid var(--line); border-radius: 6px;
    padding: 8px 10px; font-family: inherit; font-size: 13.5px;
    background: var(--paper); min-height: 50px;
}
.notiz-quick textarea:focus { outline: 2px solid var(--forest); border-color: var(--forest); }

.verknuepfte-obj {
    display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
    padding: 10px 0 16px; border-bottom: 1px solid var(--line-soft); margin-bottom: 14px;
}
.vo-chip {
    display: inline-flex; flex-direction: column;
    padding: 6px 10px;
    background: var(--paper-2); border: 1px solid var(--line);
    border-radius: 6px; text-decoration: none; color: var(--ink);
    font-size: 12.5px; font-weight: 500;
    transition: background 0.15s, border-color 0.15s;
}
.vo-chip:hover { background: #f0fdfa; border-color: var(--forest); }
.vo-chip small { color: var(--ink-3); font-weight: 400; margin-top: 1px; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Timeline */
.act-timeline { position: relative; }
.act-timeline::before {
    content: ''; position: absolute;
    left: 18px; top: 8px; bottom: 8px; width: 2px;
    background: var(--line-soft);
}

.act-day-header {
    margin: 18px 0 8px;
    font-size: 12.5px; font-weight: 600;
    color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.06em;
    padding: 4px 0 4px 44px;
    position: relative; background: var(--paper);
}

.act-item {
    display: flex; gap: 12px;
    padding: 10px 0;
    position: relative;
}
.act-item .act-icon {
    flex-shrink: 0; width: 38px; height: 38px;
    background: var(--paper); border: 2px solid var(--line);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; z-index: 1;
}
.act-item.act-q-inbox     .act-icon { border-color: #93c5fd; background: #eff6ff; }
.act-item.act-q-termin    .act-icon { border-color: #c4b5fd; background: #f5f3ff; }
.act-item.act-q-aufgabe   .act-icon { border-color: #fde68a; background: #fefce8; }
.act-item.act-q-aktivitaet .act-icon{ border-color: #6ee7b7; background: #ecfdf5; }

.act-body {
    flex: 1; min-width: 0;
    background: var(--paper); border: 1px solid var(--line);
    border-radius: 8px; padding: 10px 14px;
}
.act-body > header {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
    margin-bottom: 4px;
    font-size: 12px; color: var(--ink-3);
}
.act-typ { font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; font-size: 11px; }
.act-time { font-size: 11.5px; }
.act-user { color: var(--ink-3); font-size: 11.5px; }
.act-obj {
    background: var(--paper-2); padding: 2px 8px; border-radius: 12px;
    font-family: "IBM Plex Mono", monospace; font-size: 11px; font-weight: 600;
    color: var(--forest); text-decoration: none; border: 1px solid var(--line);
}
.act-obj:hover { background: #f0fdfa; }

.act-titel { display: block; font-size: 14px; font-weight: 500; color: var(--ink); text-decoration: none; line-height: 1.3; }
a.act-titel:hover { color: var(--forest); text-decoration: underline; }
.act-snippet {
    margin: 4px 0 0; font-size: 13px; line-height: 1.55;
    color: var(--ink-2); white-space: pre-wrap;
}
.act-notiz-del { margin-top: 6px; }

/* Audit-Liste */
.audit-day h3 { font-family: "IBM Plex Serif", serif; font-size: 15px; font-weight: 500; margin: 14px 0 6px; color: var(--ink-2); }
.audit-list { list-style: none; padding: 0; margin: 0; }
.audit-list li {
    display: flex; gap: 12px; padding: 6px 0;
    border-bottom: 1px solid var(--line-soft); font-size: 12.5px;
}
.audit-list li:last-child { border-bottom: 0; }
.audit-time { color: var(--ink-3); flex-shrink: 0; min-width: 50px; }

/* ---- Empty / responsive ---------------------------------- */
.empty { padding: 32px; color: var(--ink-3); text-align: center; }
@media (max-width: 1100px) {
    .kontakt-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1100px) {
    .three-cols { grid-template-columns: 320px 1fr; }
    .context-panel { display: none; }
}
@media (max-width: 780px) {
    .form-grid { grid-template-columns: 1fr; }
    .kv        { grid-template-columns: 1fr; }
    .app-page  { padding: 18px 18px 40px; }
}
@media (max-width: 700px) {
    .sidebar { display: none; }
    .three-cols { grid-template-columns: 1fr; }
    .conv-list { display: none; }
}
