/* Standtom HQ Cockpit — Design System */
:root {
  --font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Inter", "Helvetica Neue", Arial, sans-serif;
  --bg: #f5f5f7; --bg-elev: #ffffff; --bg-sidebar: rgba(255,255,255,0.72);
  --card: #ffffff; --card-hover: #fbfbfd; --text: #1d1d1f; --text-2: #6e6e73; --text-3: #8e8e93;
  --hairline: rgba(0,0,0,0.08); --hairline-strong: rgba(0,0,0,0.12);
  --accent: #0071e3; --accent-soft: rgba(0,113,227,0.10);
  --green: #1a8f3c; --green-soft: rgba(26,143,60,0.12);
  --amber: #b25e00; --amber-soft: rgba(178,94,0,0.12);
  --red: #c8102e; --red-soft: rgba(200,16,46,0.12);
  --purple: #7a3df5; --purple-soft: rgba(122,61,245,0.12);
  --shadow: 0 1px 2px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.06);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
  --radius: 18px; --radius-sm: 12px;
}
:root[data-theme="dark"] {
  --bg: #000; --bg-elev: #1c1c1e; --bg-sidebar: rgba(28,28,30,0.72);
  --card: #1c1c1e; --card-hover: #242426; --text: #f5f5f7; --text-2: #aeaeb2; --text-3: #8e8e93;
  --hairline: rgba(255,255,255,0.10); --hairline-strong: rgba(255,255,255,0.16);
  --accent: #0a84ff; --accent-soft: rgba(10,132,255,0.16);
  --green: #30d158; --green-soft: rgba(48,209,88,0.16);
  --amber: #ff9f0a; --amber-soft: rgba(255,159,10,0.16);
  --red: #ff453a; --red-soft: rgba(255,69,58,0.16);
  --purple: #bf5af2; --purple-soft: rgba(191,90,242,0.16);
  --shadow: 0 1px 2px rgba(0,0,0,0.3), 0 12px 32px rgba(0,0,0,0.5);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
}
@media (prefers-color-scheme: dark) {
  :root[data-theme="auto"] {
    --bg: #000; --bg-elev: #1c1c1e; --bg-sidebar: rgba(28,28,30,0.72);
    --card: #1c1c1e; --card-hover: #242426; --text: #f5f5f7; --text-2: #aeaeb2; --text-3: #8e8e93;
    --hairline: rgba(255,255,255,0.10); --hairline-strong: rgba(255,255,255,0.16);
    --accent: #0a84ff; --accent-soft: rgba(10,132,255,0.16);
    --green: #30d158; --green-soft: rgba(48,209,88,0.16);
    --amber: #ff9f0a; --amber-soft: rgba(255,159,10,0.16);
    --red: #ff453a; --red-soft: rgba(255,69,58,0.16);
    --purple: #bf5af2; --purple-soft: rgba(191,90,242,0.16);
    --shadow: 0 1px 2px rgba(0,0,0,0.3), 0 12px 32px rgba(0,0,0,0.5);
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  }
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body { font-family: var(--font); background: var(--bg); color: var(--text); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; letter-spacing: -0.01em; transition: background .35s ease, color .35s ease; }

.app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }

/* Sidebar */
.sidebar { background: var(--bg-sidebar); -webkit-backdrop-filter: saturate(180%) blur(20px); backdrop-filter: saturate(180%) blur(20px); border-right: 1px solid var(--hairline); padding: 18px 14px; display: flex; flex-direction: column; gap: 4px; position: sticky; top: 0; height: 100vh; }
.brand { display: flex; align-items: center; gap: 11px; padding: 8px 10px 18px; text-decoration: none; }
.brand .mark { width: 34px; height: 34px; border-radius: 9px; background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, var(--purple))); display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 16px; box-shadow: var(--shadow-sm); }
.brand .name { font-size: 15px; font-weight: 650; color: var(--text); }
.brand .sub { font-size: 11px; color: var(--text-3); margin-top: 1px; }
.nav-label { font-size: 11px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.04em; padding: 14px 12px 6px; }
.nav-item { display: flex; align-items: center; gap: 11px; padding: 8px 12px; border-radius: 10px; color: var(--text-2); font-size: 14px; font-weight: 500; cursor: pointer; text-decoration: none; transition: background .15s ease, color .15s ease; }
.nav-item:hover { background: var(--hairline); color: var(--text); }
.nav-item.active { background: var(--accent-soft); color: var(--accent); font-weight: 600; }
.nav-item .ico { width: 18px; height: 18px; flex: none; opacity: .9; }
.nav-item .badge { margin-left: auto; font-size: 11px; font-weight: 600; background: var(--hairline-strong); color: var(--text-2); padding: 1px 7px; border-radius: 8px; }
.nav-item.active .badge { background: var(--accent); color: #fff; }
.sidebar-foot { margin-top: auto; }
.userchip { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 12px; cursor: pointer; text-decoration: none; }
.userchip:hover { background: var(--hairline); }
.avatar { width: 30px; height: 30px; border-radius: 50%; color: #fff; display: grid; place-items: center; font-size: 12px; font-weight: 650; }
.userchip .u-name { font-size: 13px; font-weight: 600; color: var(--text); }
.userchip .u-role { font-size: 11px; color: var(--text-3); }

/* Topbar */
.main { padding: 0; overflow-x: hidden; }
.topbar { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; gap: 16px; padding: 16px 32px; background: color-mix(in srgb, var(--bg) 72%, transparent); -webkit-backdrop-filter: saturate(180%) blur(20px); backdrop-filter: saturate(180%) blur(20px); border-bottom: 1px solid var(--hairline); }
.search { flex: 1; max-width: 460px; position: relative; }
.search input { width: 100%; border: 1px solid var(--hairline); background: var(--bg-elev); color: var(--text); padding: 9px 14px 9px 38px; border-radius: 11px; font-size: 13.5px; font-family: var(--font); outline: none; transition: border-color .15s ease, box-shadow .15s ease; }
.search input:focus { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }
.search svg { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--text-3); }
.spacer { flex: 1; }
.seg { display: inline-flex; background: var(--hairline); border-radius: 9px; padding: 2px; }
.seg button { border: 0; background: transparent; color: var(--text-2); font-family: var(--font); font-size: 12px; font-weight: 600; padding: 5px 11px; border-radius: 7px; cursor: pointer; display: flex; align-items: center; gap: 5px; transition: color .15s ease; }
.seg button.on { background: var(--bg-elev); color: var(--text); box-shadow: var(--shadow-sm); }

/* Privacy-Toggle: Beträge verbergen (für unterwegs) */
.privacy-toggle { display: inline-grid; place-items: center; width: 32px; height: 30px; border: 0; border-radius: 9px; background: var(--hairline); color: var(--text-2); cursor: pointer; transition: color .15s, background .15s; }
.privacy-toggle:hover { color: var(--text); }
.privacy-toggle.on { background: var(--accent-soft); color: var(--accent); }
/* Geldbeträge: standardmäßig sichtbar; im Privacy-Modus geblurrt */
.money { transition: filter .18s ease; }
body.hide-money .money { filter: blur(7px); cursor: pointer; user-select: none; }
body.hide-money .money:hover { filter: blur(0); }
.icon-btn { width: 36px; height: 36px; border-radius: 10px; border: 1px solid var(--hairline); background: var(--bg-elev); color: var(--text-2); cursor: pointer; display: grid; place-items: center; transition: background .15s ease, color .15s ease; }
.icon-btn:hover { background: var(--card-hover); color: var(--text); }
.btn-primary { border: 0; background: var(--accent); color: #fff; font-family: var(--font); font-size: 13.5px; font-weight: 600; padding: 9px 16px; border-radius: 11px; cursor: pointer; display: flex; align-items: center; gap: 7px; box-shadow: var(--shadow-sm); transition: filter .15s ease, transform .05s ease; text-decoration: none; }
.btn-primary:hover { filter: brightness(1.06); }
.btn-primary:active { transform: scale(.98); }

.content { padding: 28px 32px 56px; max-width: 1320px; }
.page-head { margin-bottom: 22px; }
.page-head h1 { font-size: 26px; font-weight: 700; letter-spacing: -0.03em; }
.page-head p { color: var(--text-2); font-size: 14px; margin-top: 4px; }

/* Stats */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.stat { background: var(--card); border: 1px solid var(--hairline); border-radius: var(--radius); padding: 18px 18px 16px; box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .18s ease; }
.stat:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.stat .top { display: flex; align-items: center; justify-content: space-between; }
.stat .label { font-size: 13px; color: var(--text-2); font-weight: 500; }
.stat .pill { width: 32px; height: 32px; border-radius: 9px; display: grid; place-items: center; }
.stat .value { font-size: 30px; font-weight: 700; letter-spacing: -0.03em; margin-top: 12px; }
.stat .delta { font-size: 12.5px; margin-top: 4px; font-weight: 500; }
.delta.up { color: var(--green); } .delta.down { color: var(--red); } .delta.flat { color: var(--text-3); }

.grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 16px; }
.col { display: flex; flex-direction: column; gap: 16px; }
.card { background: var(--card); border: 1px solid var(--hairline); border-radius: var(--radius); box-shadow: var(--shadow-sm); overflow: hidden; }
.card-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; border-bottom: 1px solid var(--hairline); }
.card-head h2 { font-size: 15.5px; font-weight: 650; letter-spacing: -0.02em; }
.card-head .more { font-size: 13px; color: var(--accent); font-weight: 600; cursor: pointer; text-decoration: none; }

/* Project rows */
.proj { display: flex; align-items: center; gap: 14px; padding: 14px 18px; cursor: pointer; transition: background .15s ease; text-decoration: none; color: inherit; }
.proj:hover { background: var(--card-hover); }
.proj + .proj { border-top: 1px solid var(--hairline); }
.proj .pa { width: 40px; height: 40px; border-radius: 11px; flex: none; display: grid; place-items: center; font-weight: 650; font-size: 14px; color: #fff; }
.proj .pinfo { flex: 1; min-width: 0; }
.proj .pname { font-size: 14.5px; font-weight: 600; display: flex; align-items: center; gap: 8px; color: var(--text); }
.proj .pmeta { font-size: 12.5px; color: var(--text-2); margin-top: 2px; }
.src-badge { font-size: 10px; font-weight: 700; padding: 2px 6px; border-radius: 6px; letter-spacing: 0.02em; text-transform: uppercase; }
.src-tb { background: var(--accent-soft); color: var(--accent); }
.src-lx { background: var(--purple-soft); color: var(--purple); }
.progress { width: 120px; flex: none; }
.progress .bar { height: 6px; background: var(--hairline); border-radius: 4px; overflow: hidden; }
.progress .fill { height: 100%; border-radius: 4px; background: var(--accent); }
.progress .pct { font-size: 11px; color: var(--text-3); margin-top: 5px; text-align: right; }
.status-dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.invoice-tag { font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 8px; white-space: nowrap; }
.proj .progress ~ .invoice-tag { width: 124px; text-align: center; flex: none; }
.t-paid { background: var(--green-soft); color: var(--green); }
.t-open { background: var(--amber-soft); color: var(--amber); }
.t-overdue { background: var(--red-soft); color: var(--red); }

/* Tasks */
.task { display: flex; align-items: flex-start; gap: 12px; padding: 13px 18px; position: relative; }
.task + .task { border-top: 1px solid var(--hairline); }
.check { width: 19px; height: 19px; border-radius: 6px; border: 1.8px solid var(--hairline-strong); flex: none; margin-top: 1px; cursor: pointer; transition: all .15s ease; display: grid; place-items: center; }
.check:hover { border-color: var(--accent); }
.check.done { background: var(--accent); border-color: var(--accent); }
.check.done svg { color: #fff; }
.check:not(.done) svg { display: none; }
.task .tbody { flex: 1; min-width: 0; }
.task .ttitle { font-size: 14px; font-weight: 500; }
.task.completed .ttitle { color: var(--text-3); text-decoration: line-through; }
.task .tmeta { font-size: 12px; color: var(--text-2); margin-top: 3px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.mini-av { width: 20px; height: 20px; border-radius: 50%; font-size: 9px; font-weight: 700; color: #fff; display: grid; place-items: center; flex: none; }
.due { font-size: 11px; font-weight: 600; padding: 2px 7px; border-radius: 7px; }
.due.soon { background: var(--amber-soft); color: var(--amber); }
.due.today { background: var(--red-soft); color: var(--red); }
.due.later { background: var(--hairline); color: var(--text-2); }
.note-pill { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 6px; background: var(--purple-soft); color: var(--purple); text-transform: uppercase; }
.ev-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; padding: 1px 7px 1px 6px; border-radius: 6px; background: var(--accent-soft); color: var(--accent); cursor: pointer; }
.ev-badge:hover { filter: brightness(.95); }
.ev-badge svg { flex: none; }
/* Typ-Kennzeichnung (Aufgabe / Notiz) — gleichwertig nebeneinander */
.type-pill { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 6px; text-transform: uppercase; letter-spacing: .02em; }
.type-pill.type-task { background: var(--accent-soft); color: var(--accent); }
.type-pill.type-note { background: var(--purple-soft); color: var(--purple); }

/* Priorities */
.prio-pill { font-size: 10px; font-weight: 700; padding: 1px 7px; border-radius: 6px; text-transform: uppercase; letter-spacing: .02em; cursor: pointer; user-select: none; }
.prio-high { background: var(--red-soft); color: var(--red); }
.prio-med  { background: var(--amber-soft); color: var(--amber); }
.prio-low  { background: var(--hairline); color: var(--text-2); }
.task.lvl-high::before, .task.lvl-medium::before { content: ''; position: absolute; left: 0; top: 9px; bottom: 9px; width: 3px; border-radius: 0 2px 2px 0; }
.task.lvl-high::before { background: var(--red); }
.task.lvl-medium::before { background: var(--amber); }

/* Agenda */
.agenda-day { padding: 14px 18px; }
.agenda-day + .agenda-day { border-top: 1px solid var(--hairline); }
.agenda-date { font-size: 12px; font-weight: 700; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.03em; margin-bottom: 10px; }
.event { display: flex; gap: 11px; align-items: center; padding: 7px 0; }
.event .stripe { width: 3px; align-self: stretch; border-radius: 2px; flex: none; background: var(--accent); }
.event .etime { font-size: 12px; color: var(--text-2); font-variant-numeric: tabular-nums; width: 46px; flex: none; }
.event .etitle { font-size: 13.5px; font-weight: 500; }
.event .eloc { font-size: 12px; color: var(--text-3); }
.event.ev-warn { background: var(--red-soft); border-radius: 8px; padding-left: 8px; padding-right: 8px; }
.event .task-actions { margin-left: auto; flex: none; }

/* Inline-Editieren: Text anklicken → direkt tippen */
.inline-edit { cursor: text; border-radius: 5px; transition: background .12s; }
.inline-edit:hover { background: var(--hairline); box-shadow: 0 0 0 4px var(--hairline); }
.inline-edit[data-editing="1"] { background: transparent; box-shadow: none; cursor: auto; }
.inline-input { width: 100%; font: inherit; color: inherit; background: var(--card); border: 1.5px solid var(--accent); border-radius: 7px; padding: 4px 8px; outline: none; resize: vertical; box-sizing: border-box; }

/* Monatskalender */
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.cal-wd { font-size: 11px; font-weight: 700; color: var(--text-3); text-transform: uppercase; letter-spacing: .04em; text-align: center; padding: 2px 0 6px; }
.cal-cell { min-height: 92px; border: 1px solid var(--hairline); border-radius: 10px; padding: 6px; display: flex; flex-direction: column; gap: 3px; overflow: hidden; }
.cal-cell.empty { border: 0; background: transparent; }
.cal-cell.today { border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); }
.cal-daynum { font-size: 12px; font-weight: 600; color: var(--text-2); margin-bottom: 2px; }
.cal-cell.today .cal-daynum { color: var(--accent); }
.cal-chip { display: flex; align-items: center; gap: 5px; font-size: 11.5px; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: default; }
.cal-chip .cal-dot { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.cal-chip.editable { cursor: pointer; }
.cal-chip.editable:hover { background: var(--hairline); border-radius: 5px; }
@media (max-width: 720px) {
  .cal-cell { min-height: 64px; }
  .cal-chip { font-size: 0; gap: 0; }
  .cal-chip .cal-dot { width: 6px; height: 6px; }
}

.foot-note { margin-top: 26px; padding: 14px 18px; border-radius: var(--radius-sm); background: var(--accent-soft); color: var(--text-2); font-size: 12.5px; display: flex; gap: 10px; align-items: center; }
.foot-note b { color: var(--text); }

/* Composer */
.composer { position: relative; }
.composer .ctop { display: flex; align-items: center; gap: 10px; padding: 14px 16px 8px; }
.composer .ctop h2 { font-size: 15.5px; font-weight: 650; letter-spacing: -0.02em; }
.type-seg { margin-left: auto; display: inline-flex; background: var(--hairline); border-radius: 8px; padding: 2px; }
.type-seg button { border: 0; background: transparent; color: var(--text-2); font-family: var(--font); font-size: 12px; font-weight: 600; padding: 4px 11px; border-radius: 6px; cursor: pointer; display: flex; gap: 5px; align-items: center; transition: color .15s ease; }
.type-seg button.on { background: var(--bg-elev); color: var(--text); box-shadow: var(--shadow-sm); }
.editor { position: relative; min-height: 44px; padding: 6px 16px 8px; font-size: 14px; line-height: 1.55; outline: none; color: var(--text); }
.editor:empty:before { content: attr(data-placeholder); color: var(--text-3); pointer-events: none; }
.mention-chip { background: var(--accent-soft); color: var(--accent); font-weight: 600; padding: 1px 6px; border-radius: 6px; white-space: nowrap; }
.mention-menu { position: absolute; z-index: 60; min-width: 244px; background: var(--bg-elev); border: 1px solid var(--hairline); border-radius: 13px; box-shadow: var(--shadow); padding: 6px; max-height: 250px; overflow: auto; }
.mention-menu.hidden { display: none; }
.mention-item { display: flex; align-items: center; gap: 10px; padding: 7px 9px; border-radius: 9px; cursor: pointer; }
.mention-item.active { background: var(--accent-soft); }
.mention-item .mi-name { font-size: 13.5px; font-weight: 600; }
.mention-item .mi-role { margin-left: auto; font-size: 11px; color: var(--text-3); }
.cfoot { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-top: 1px solid var(--hairline); flex-wrap: wrap; }
.prio-seg { display: inline-flex; background: var(--hairline); border-radius: 8px; padding: 2px; flex: none; }
.prio-seg button { border: 0; background: transparent; color: var(--text-2); font-family: var(--font); font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 6px; cursor: pointer; }
.prio-seg button.on { background: var(--bg-elev); box-shadow: var(--shadow-sm); }
.prio-seg button[data-p="high"].on { color: var(--red); }
.prio-seg button[data-p="medium"].on { color: var(--amber); }
.prio-seg button[data-p="low"].on { color: var(--text); }
.recip { display: flex; gap: 6px; flex-wrap: wrap; flex: 1; min-width: 120px; align-items: center; }
.recip .empty { font-size: 12px; color: var(--text-3); }
.recip .rchip { display: flex; align-items: center; gap: 6px; background: var(--hairline); padding: 3px 9px 3px 4px; border-radius: 20px; font-size: 12px; font-weight: 600; }
.send-btn { border: 0; background: var(--accent); color: #fff; font-family: var(--font); font-weight: 650; font-size: 13px; padding: 8px 15px; border-radius: 10px; cursor: pointer; display: flex; gap: 7px; align-items: center; transition: filter .15s ease, opacity .15s ease; }
.send-btn:hover { filter: brightness(1.06); }
.send-btn:disabled { opacity: .4; cursor: not-allowed; }
.task.fresh { animation: pop .45s ease; }
@keyframes pop { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
.note-ico { border: 0 !important; background: var(--purple-soft); color: var(--purple); cursor: default; }
.note-ico:hover { border: 0 !important; }
/* Notizen dezent abheben (kein Abhaken, lila Akzent) */
.task.is-note { background: color-mix(in srgb, var(--purple) 4%, transparent); }
/* Edit/Löschen pro Zeile — dezent, bei Hover/Fokus sichtbar */
.task-actions { display: flex; gap: 2px; flex: none; align-self: center; opacity: 0; transition: opacity .12s; }
.task:hover .task-actions, .task:focus-within .task-actions { opacity: 1; }
.task-actions .iact { padding: 5px 7px; }
@media (hover: none) { .task-actions { opacity: 1; } }

/* AI suggest */
.ai-suggest { display: flex; align-items: center; gap: 11px; margin: 4px 14px 0; padding: 10px 12px; background: var(--accent-soft); border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent); border-radius: 12px; }
.ai-suggest.hidden { display: none; }
.ai-suggest .cal { width: 34px; height: 34px; border-radius: 9px; background: var(--accent); color: #fff; display: grid; place-items: center; flex: none; }
.ai-suggest .as-body { flex: 1; min-width: 0; }
.ai-suggest .as-title { font-size: 13.5px; font-weight: 650; display: flex; align-items: center; gap: 7px; }
.ai-suggest .as-when { color: var(--text-2); font-size: 12px; margin-top: 2px; }
.ai-spark { font-size: 10px; font-weight: 700; color: var(--accent); background: var(--bg-elev); border: 1px solid var(--hairline); padding: 1px 6px; border-radius: 6px; letter-spacing: .03em; }
.switch { position: relative; width: 42px; height: 25px; flex: none; cursor: pointer; }
.switch input { display: none; }
.switch .track { position: absolute; inset: 0; background: var(--hairline-strong); border-radius: 20px; transition: background .2s ease; }
.switch input:checked ~ .track { background: var(--green); }
.switch .knob { position: absolute; top: 2px; left: 2px; width: 21px; height: 21px; background: #fff; border-radius: 50%; transition: transform .2s ease; box-shadow: var(--shadow-sm); }
.switch input:checked ~ .knob { transform: translateX(17px); }

/* Toast */
.toast { position: fixed; left: 50%; bottom: 28px; transform: translate(-50%, 20px); background: var(--text); color: var(--bg); padding: 11px 16px; border-radius: 13px; font-size: 13.5px; font-weight: 500; box-shadow: var(--shadow); opacity: 0; pointer-events: none; transition: opacity .3s ease, transform .3s ease; display: flex; align-items: center; gap: 10px; z-index: 100; max-width: 90vw; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.toast b { font-weight: 700; }
.toast .t-av { width: 22px; height: 22px; border-radius: 50%; font-size: 10px; font-weight: 700; color: #fff; display: grid; place-items: center; flex: none; }

/* Login */
/* ===== Login — animiert ===== */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 24px; position: relative; overflow: hidden; }
/* Aurora-Hintergrund: drei farbige Blobs, die langsam wandern */
.login-wrap::before, .login-wrap::after {
  content: ''; position: absolute; border-radius: 50%; filter: blur(70px); opacity: .55; z-index: 0; pointer-events: none;
  background: radial-gradient(circle at 30% 30%, var(--accent), transparent 70%);
}
.login-wrap::before { width: 520px; height: 520px; top: -160px; left: -120px; animation: aurora1 18s ease-in-out infinite; }
.login-wrap::after  { width: 460px; height: 460px; bottom: -180px; right: -120px; background: radial-gradient(circle at 30% 30%, var(--purple), transparent 70%); animation: aurora2 22s ease-in-out infinite; }
@keyframes aurora1 { 0%,100% { transform: translate(0,0) scale(1); } 33% { transform: translate(80px,60px) scale(1.15); } 66% { transform: translate(-50px,40px) scale(.95); } }
@keyframes aurora2 { 0%,100% { transform: translate(0,0) scale(1); } 33% { transform: translate(-70px,-50px) scale(1.1); } 66% { transform: translate(50px,-30px) scale(.9); } }
@media (prefers-reduced-motion: reduce) { .login-wrap::before, .login-wrap::after { animation: none; } }

.login-card {
  position: relative; z-index: 1; width: 100%; max-width: 380px;
  background: color-mix(in srgb, var(--card) 82%, transparent);
  -webkit-backdrop-filter: blur(20px) saturate(160%); backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid color-mix(in srgb, var(--hairline) 70%, transparent);
  border-radius: 22px; box-shadow: 0 20px 60px -15px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.04) inset;
  padding: 36px 30px;
  animation: loginIn .7s cubic-bezier(.16,1,.3,1) both;
}
@keyframes loginIn { from { opacity: 0; transform: translateY(24px) scale(.97); } to { opacity: 1; transform: none; } }
.login-card.shake { animation: loginShake .5s cubic-bezier(.36,.07,.19,.97); }
@keyframes loginShake { 10%,90%{transform:translateX(-2px)} 20%,80%{transform:translateX(4px)} 30%,50%,70%{transform:translateX(-8px)} 40%,60%{transform:translateX(8px)} }

.login-card .mark {
  width: 54px; height: 54px; border-radius: 15px;
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 50%, var(--purple)));
  display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 24px; margin: 0 auto 18px;
  box-shadow: 0 8px 24px -6px var(--accent); animation: markFloat 4s ease-in-out infinite;
}
@keyframes markFloat { 0%,100% { transform: translateY(0); box-shadow: 0 8px 24px -6px var(--accent); } 50% { transform: translateY(-6px); box-shadow: 0 16px 32px -8px var(--accent); } }
@media (prefers-reduced-motion: reduce) { .login-card .mark { animation: none; } }

.login-card h1 { font-size: 21px; font-weight: 750; text-align: center; letter-spacing: -0.02em; animation: fadeUp .6s .15s both; }
.login-card p { font-size: 13px; color: var(--text-2); text-align: center; margin: 4px 0 24px; animation: fadeUp .6s .22s both; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

.field { margin-bottom: 14px; animation: fadeUp .6s both; }
.field:nth-of-type(1) { animation-delay: .3s; } .field:nth-of-type(2) { animation-delay: .38s; }
.login-card form > .field ~ .field { animation-delay: .38s; }
.field label { display: block; font-size: 12.5px; font-weight: 600; color: var(--text-2); margin-bottom: 6px; }
.field input { width: 100%; border: 1px solid var(--hairline); background: var(--bg-elev); color: var(--text); padding: 12px 14px; border-radius: 12px; font-size: 14px; font-family: var(--font); outline: none; transition: border-color .2s, box-shadow .2s, transform .15s; }
.field input:focus { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }

.login-btn {
  position: relative; overflow: hidden; width: 100%; border: 0; color: #fff;
  background: linear-gradient(120deg, var(--accent), color-mix(in srgb, var(--accent) 55%, var(--purple)));
  font-family: var(--font); font-size: 14.5px; font-weight: 700; padding: 13px; border-radius: 12px; cursor: pointer; margin-top: 10px;
  box-shadow: 0 8px 22px -8px var(--accent); transition: transform .15s, box-shadow .2s, filter .2s;
  animation: fadeUp .6s .46s both;
}
.login-btn:hover { transform: translateY(-2px); box-shadow: 0 14px 30px -8px var(--accent); filter: brightness(1.05); }
.login-btn:active { transform: translateY(0); }
/* Shimmer-Licht, das über den Button gleitet */
.login-btn::after { content: ''; position: absolute; top: 0; left: -120%; width: 60%; height: 100%; background: linear-gradient(100deg, transparent, rgba(255,255,255,.35), transparent); transform: skewX(-20deg); animation: shimmer 3.2s ease-in-out infinite; }
@keyframes shimmer { 0% { left: -120%; } 55%,100% { left: 130%; } }
@media (prefers-reduced-motion: reduce) { .login-btn::after { display: none; } }

.login-err { background: var(--red-soft); color: var(--red); font-size: 13px; font-weight: 500; padding: 10px 13px; border-radius: 10px; margin-bottom: 16px; animation: fadeUp .35s both; }
.login-hint { font-size: 11.5px; color: var(--text-3); text-align: center; margin-top: 18px; line-height: 1.5; }

/* Hamburger + Drawer-Overlay Grundzustand (Media-Queries am Dateiende) */
.nav-burger { display: none; align-items: center; justify-content: center; width: 38px; height: 38px; margin-right: 4px; border: 0; border-radius: 10px; background: var(--hairline); color: var(--text); cursor: pointer; flex: none; }
.nav-overlay { display: none; position: fixed; inset: 0; z-index: 40; background: rgba(0,0,0,.45); -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
.nav-overlay.show { display: block; }
body.nav-locked { overflow: hidden; }

/* ====================== Erweiterungen (alle Seiten) ====================== */

/* Buttons */
.btn { border: 0; background: var(--accent); color: #fff; font-family: var(--font); font-size: 13.5px; font-weight: 650; padding: 9px 16px; border-radius: 11px; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; text-decoration: none; }
.btn:hover { filter: brightness(1.06); }
.btn.secondary { background: var(--hairline); color: var(--text); }
.btn.secondary:hover { background: var(--hairline-strong); filter: none; }
.btn.small { padding: 6px 12px; font-size: 12.5px; border-radius: 9px; }

/* Modal */
.modal-backdrop { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,.4); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); display: none; place-items: center; padding: 20px; }
.modal-backdrop.show { display: grid; }
.modal { width: 100%; max-width: 460px; background: var(--card); border: 1px solid var(--hairline); border-radius: var(--radius); box-shadow: var(--shadow); padding: 24px; max-height: 90vh; overflow: auto; animation: pop .25s ease; }
.modal h3 { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 4px; }
.modal .msub { font-size: 13px; color: var(--text-2); margin-bottom: 18px; }
.form-row { margin-bottom: 13px; }
.form-row.two { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-row label { display: block; font-size: 12.5px; font-weight: 600; color: var(--text-2); margin-bottom: 6px; }
.fld { width: 100%; border: 1px solid var(--hairline); background: var(--bg-elev); color: var(--text); padding: 10px 12px; border-radius: 10px; font-size: 14px; font-family: var(--font); outline: none; }
.fld:focus { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }
textarea.fld { resize: vertical; min-height: 70px; }
.btn-row { display: flex; gap: 10px; justify-content: flex-end; margin-top: 18px; }

/* Empty state */
.empty-state { padding: 54px 24px; text-align: center; color: var(--text-3); }
.empty-state .es-ico { width: 52px; height: 52px; border-radius: 14px; background: var(--hairline); display: grid; place-items: center; margin: 0 auto 14px; color: var(--text-2); }
.empty-state h3 { font-size: 16px; font-weight: 650; color: var(--text); margin-bottom: 4px; }
.empty-state p { font-size: 13.5px; margin-bottom: 16px; }

/* Page header with action */
.page-head.row { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; }
.crumb { font-size: 13px; color: var(--text-3); margin-bottom: 14px; }
.crumb a { color: var(--text-2); text-decoration: none; } .crumb a:hover { color: var(--accent); }

/* Theme grid */
.tgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.tcard { background: var(--card); border: 1px solid var(--hairline); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 18px; text-decoration: none; color: inherit; transition: transform .18s ease, box-shadow .18s ease; display: block; }
.tcard:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.tcard .av { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 16px; margin-bottom: 14px; }
.tcard .tname { font-size: 16px; font-weight: 650; letter-spacing: -0.02em; }
.tcard .tmeta { font-size: 12.5px; color: var(--text-2); margin-top: 4px; }
.tcard .tbar { height: 6px; background: var(--hairline); border-radius: 4px; overflow: hidden; margin-top: 14px; }
.tcard .tfill { height: 100%; background: var(--accent); border-radius: 4px; }

/* Sub-tabs (Unterprojekte) */
.tours { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; align-items: center; }
.tour-tab { border: 1px solid var(--hairline); background: var(--bg-elev); color: var(--text-2); font-size: 13.5px; font-weight: 600; padding: 9px 15px; border-radius: 12px; cursor: pointer; text-decoration: none; transition: all .15s ease; display: flex; flex-direction: column; gap: 1px; min-width: 130px; }
.tour-tab:hover { color: var(--text); }
.tour-tab.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.tour-tab .tt-sub { font-size: 11px; font-weight: 500; opacity: .75; }
.tour-add { border: 1px dashed var(--hairline-strong); background: transparent; color: var(--text-3); font-size: 13px; font-weight: 600; padding: 9px 14px; border-radius: 12px; cursor: pointer; }

/* Summary boxes */
.sumstrip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 18px; }
.sumbox { background: var(--card); border: 1px solid var(--hairline); border-radius: 14px; padding: 14px 16px; box-shadow: var(--shadow-sm); }
.sumbox .sl { font-size: 12.5px; color: var(--text-2); font-weight: 500; }
.sumbox .sv { font-size: 23px; font-weight: 700; margin-top: 7px; letter-spacing: -0.02em; }
.sumbox .ss { font-size: 12px; color: var(--text-3); margin-top: 3px; }

.split { display: grid; grid-template-columns: 1.55fr 1fr; gap: 16px; align-items: start; }

/* Documents */
.doc { display: flex; align-items: center; gap: 13px; padding: 13px 16px; }
.doc + .doc { border-top: 1px solid var(--hairline); }
.doc .dico { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; flex: none; }
.dico.quote { background: var(--accent-soft); color: var(--accent); }
.dico.invoice { background: var(--purple-soft); color: var(--purple); }
.doc .dinfo { flex: 1; min-width: 0; }
.doc .dt { font-size: 14px; font-weight: 600; }
.doc .dm { font-size: 12.5px; color: var(--text-2); margin-top: 2px; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.doc .right { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex: none; }
.doc .amount { font-weight: 650; font-size: 14px; font-variant-numeric: tabular-nums; }
.tag { font-size: 10.5px; font-weight: 700; padding: 2px 8px; border-radius: 7px; white-space: nowrap; }
.t-draft { background: var(--hairline); color: var(--text-2); }
.t-rej { background: var(--red-soft); color: var(--red); }
.srcmini { font-size: 10.5px; color: var(--text-3); display: inline-flex; align-items: center; gap: 4px; }

/* Filters */
.filters { display: flex; gap: 8px; margin-bottom: 18px; flex-wrap: wrap; }
.chip { border: 1px solid var(--hairline); background: var(--bg-elev); color: var(--text-2); font-size: 13px; font-weight: 600; padding: 7px 13px; border-radius: 20px; cursor: pointer; text-decoration: none; transition: all .15s ease; }
.chip:hover { color: var(--text); }
.chip.on { background: var(--accent); border-color: var(--accent); color: #fff; }

/* Contacts */
.clist .row { display: flex; align-items: center; gap: 13px; padding: 13px 16px; cursor: pointer; transition: background .15s ease; text-decoration: none; color: inherit; }
.clist .row + .row { border-top: 1px solid var(--hairline); }
.clist .row:hover { background: var(--card-hover); }
.clist .row.sel { background: var(--accent-soft); }
.av { width: 42px; height: 42px; border-radius: 12px; flex: none; display: grid; place-items: center; color: #fff; font-weight: 650; font-size: 14px; }
.row .info { flex: 1; min-width: 0; }
.row .nm { font-size: 14.5px; font-weight: 600; }
.row .mt { font-size: 12.5px; color: var(--text-2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.t-kunde { background: var(--accent-soft); color: var(--accent); }
.t-mgmt  { background: var(--purple-soft); color: var(--purple); }
.t-venue { background: var(--green-soft); color: var(--green); }
.t-book  { background: var(--amber-soft); color: var(--amber); }
.detail .dhead { padding: 22px; border-bottom: 1px solid var(--hairline); display: flex; gap: 16px; align-items: center; }
.detail .av-lg { width: 60px; height: 60px; border-radius: 16px; font-size: 20px; }
.detail .dh-name { font-size: 20px; font-weight: 700; letter-spacing: -0.02em; }
.detail .dh-sub { color: var(--text-2); font-size: 13.5px; margin-top: 3px; }
.dsection { padding: 18px 22px; border-bottom: 1px solid var(--hairline); }
.dsection:last-child { border-bottom: 0; }
.dsection h3 { font-size: 11.5px; font-weight: 700; color: var(--text-3); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 12px; }
.inforow { display: flex; align-items: center; gap: 11px; padding: 7px 0; font-size: 14px; }
.inforow .lbl { color: var(--text-3); width: 80px; flex: none; font-size: 12.5px; }
.inforow a { color: var(--accent); text-decoration: none; }
.note { display: flex; gap: 11px; padding: 11px 0; }
.note + .note { border-top: 1px solid var(--hairline); }
.note .nbody { flex: 1; min-width: 0; }
.note .ntext { font-size: 13.5px; line-height: 1.5; }
.note .nmeta { font-size: 11.5px; color: var(--text-3); margin-top: 4px; display: flex; align-items: center; gap: 7px; }
.note .nlink { font-weight: 600; color: var(--accent); cursor: pointer; }
.note .nlink:hover { text-decoration: underline; }
.linked-badge { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 6px; background: var(--accent-soft); color: var(--accent); }
.addnote { display: flex; gap: 9px; margin-top: 12px; }
.addnote .fld { flex: 1; }

/* Dropbox row */
.dropbox { display: flex; align-items: center; gap: 11px; padding: 13px 16px; }
.dropbox .db-ico { width: 34px; height: 34px; border-radius: 9px; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; flex: none; }
.dropbox .db-t { font-size: 13.5px; font-weight: 600; }
.dropbox .db-s { font-size: 12px; color: var(--text-3); margin-top: 1px; }
.dropbox a { margin-left: auto; font-size: 12.5px; font-weight: 600; color: var(--accent); text-decoration: none; }

/* Strength meter */
.strength { height: 6px; background: var(--hairline); border-radius: 4px; overflow: hidden; margin-top: 9px; }
.strength span { display: block; height: 100%; width: 0; background: var(--red); border-radius: 4px; transition: width .2s ease, background .2s ease; }
.strength-txt { font-size: 11.5px; color: var(--text-3); margin-top: 6px; }

/* Inline-Aktionen (Bearbeiten/Löschen) */
.iact { background: none; border: 0; cursor: pointer; color: var(--text-3); padding: 4px 8px; border-radius: 7px; display: inline-flex; align-items: center; gap: 5px; text-decoration: none; font-family: var(--font); font-size: 12.5px; font-weight: 600; }
.iact:hover { background: var(--hairline); color: var(--text); }
.iact.danger:hover { background: var(--red-soft); color: var(--red); }
.rowact { display: flex; gap: 2px; }

/* ============================================================
   MOBILE / TABLET  — am Dateiende, damit die Media-Queries alle
   davor definierten Layout-Regeln zuverlässig überschreiben.
   ============================================================ */

/* Tablet */
@media (max-width: 1080px) {
  .grid { grid-template-columns: 1fr; }
  .split { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .content { padding: 22px 20px 48px; }
}

/* Handy (Hochformat) */
@media (max-width: 900px) {
  .app { grid-template-columns: 1fr; }

  /* Sidebar -> Off-Canvas-Drawer */
  .sidebar {
    position: fixed; top: 0; left: 0; z-index: 50; height: 100vh; width: 264px; max-width: 84vw;
    transform: translateX(-100%); transition: transform .26s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 0 40px rgba(0,0,0,.25); display: flex;
  }
  .sidebar.open { transform: translateX(0); }
  .nav-burger { display: inline-flex; }

  .topbar { padding: 12px 14px; gap: 10px; }
  .search { max-width: none; }
  #themeSeg { display: none; }            /* spart Platz; Auto-Theme bleibt aktiv */

  .content { padding: 16px 14px 48px; }
  .page-head h1 { font-size: 22px; }
  .page-head.row { flex-direction: column; align-items: stretch; gap: 12px; }
  .page-head.row > div:first-child { min-width: 0; }
  .page-head.row .btn, .page-head.row .seg { align-self: flex-start; }

  /* Stat-/Summen-Kacheln */
  .stats { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .stat .value { font-size: 24px; }
  .sumstrip { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .sumbox .sv { font-size: 19px; word-break: break-word; }
  .tgrid { grid-template-columns: 1fr; }

  /* Projekt-Kopf (Avatar + Name + Buttons) stapeln statt rauslaufen */
  .theme-head { flex-wrap: wrap; gap: 12px !important; }
  .theme-head h1 { font-size: 21px !important; }
  .theme-head-actions { margin-left: 0 !important; width: 100%; flex-wrap: wrap; }
  .theme-head-actions .btn, .theme-head-actions .iact { flex: 1 1 auto; justify-content: center; }

  /* Dokumente / Notizen / Termine immer untereinander, volle Breite */
  .split { grid-template-columns: 1fr; gap: 14px; }
  .split > * { min-width: 0; }

  /* KERN-FIX: Grid-/Flex-Kinder müssen unter Inhaltsbreite schrumpfen dürfen,
     sonst läuft der Inhalt rechts raus und wird von overflow-x:hidden gekappt. */
  .grid > .col, .col, .card { min-width: 0; }

  /* Composer: Kopf + Fußzeile umbrechen, Senden gut erreichbar */
  .composer .ctop { flex-wrap: wrap; }
  .composer .ctop h2 { flex: 1 1 100%; }
  .type-seg { margin-left: 0; }
  .cfoot { gap: 8px; }
  .cfoot .recip { flex: 1 1 100%; order: 3; }
  .cfoot .send-btn { flex: 1; justify-content: center; }

  /* To-Do-Zeilen: Aktionen kompakt + immer sichtbar, Meta darf umbrechen */
  .task { gap: 9px; padding: 12px 14px; }
  .task-actions { gap: 0; }
  .task-actions .iact { padding: 5px 5px; }

  /* horizontal scrollbare Leisten statt Umbruch/Abschneiden */
  .tours, .filters { overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .tours::-webkit-scrollbar, .filters::-webkit-scrollbar { display: none; }
  .tour-tab, .chip { flex: none; }

  /* Zeilen-Aktionen auf Touch dauerhaft sichtbar */
  .task-actions { opacity: 1 !important; }

  /* Belege/Notizen-Zeilen dürfen umbrechen statt rauszulaufen */
  .doc { flex-wrap: wrap; }
  .doc .right { margin-left: auto; }

  /* Dashboard-Reihenfolge fürs Handy: erst was zu tun ist, dann der Rest.
     1) To-Do's  2) Schnell erfassen  3) Anstehend  4) Projekte/Rechnungen */
  .grid { display: flex; flex-direction: column; }
  .grid > .col { display: flex; flex-direction: column; }
  .grid > .col:last-child { order: -1; }                 /* rechte Spalte zuerst */
  .grid > .col:last-child #tasksCard { order: 1; }       /* To-Do's ganz oben */
  .grid > .col:last-child .composer  { order: 2; }       /* Schnell erfassen */
  .grid > .col:last-child #agendaCard { order: 3; }      /* Anstehend */

  /* Card-Köpfe (Titel + Such-/Filterleiste) dürfen umbrechen */
  .card-head { flex-wrap: wrap; }

  /* Belege-Zuordnen: Such-/Sortierleiste nicht rausschieben */
  #docSearch, #docSearch:first-child { min-width: 0; }

  /* Modals fast vollflächig (auch die mit inline max-width) */
  .modal, .modal-backdrop .modal { max-width: none !important; width: 100%; border-radius: 18px; }
}

/* Sehr schmal */
@media (max-width: 560px) {
  .stats { grid-template-columns: 1fr; }
  .sumstrip { grid-template-columns: 1fr 1fr; }
}
