/* ─── Variables ───────────────────────────────────────────────────────────── */
:root {
  --color-primary:     #6366f1;
  --color-primary-h:   #4f46e5;
  --color-primary-bg:  #eef2ff;
  --color-success:     #10b981;
  --color-warning:     #f59e0b;
  --color-danger:      #ef4444;
  --color-danger-bg:   #fef2f2;

  --urgency-todo:      #94a3b8;
  --urgency-mittel:    #f59e0b;
  --urgency-dringend:  #ef4444;

  --bg:                #f1f5f9;
  --bg-2:              #e9eef5;
  --bg-card:           #ffffff;
  --bg-hover:          #f8fafc;
  --border:            #e2e8f0;
  --border-h:          #cbd5e1;

  --text:              #0f172a;
  --text-2:            #475569;
  --text-3:            #94a3b8;
  --text-inv:          #ffffff;

  --sidebar-bg:        #1e1e2e;
  --sidebar-fg:        #c4c4d4;
  --sidebar-fg-h:      #ffffff;
  --sidebar-active:    rgba(99,102,241,.2);
  --sidebar-border:    rgba(255,255,255,.06);

  --radius:            8px;
  --radius-lg:         12px;
  --shadow-sm:         0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow:            0 4px 16px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:         0 20px 40px rgba(0,0,0,.12);

  --sidebar-w:         240px;
  --topbar-h:          56px;
  --transition:        150ms ease;
}

/* ─── Dark theme ──────────────────────────────────────────────────────────── */
[data-theme="dark"] {
  --color-primary:     #818cf8;
  --color-primary-h:   #6366f1;
  --color-primary-bg:  rgba(99,102,241,.15);

  --bg:                #0f172a;
  --bg-2:              #1e293b;
  --bg-card:           #1e293b;
  --bg-hover:          #334155;
  --border:            #334155;
  --border-h:          #475569;

  --text:              #f1f5f9;
  --text-2:            #94a3b8;
  --text-3:            #64748b;

  --sidebar-bg:        #080d18;
  --sidebar-fg:        #94a3b8;
  --sidebar-fg-h:      #f1f5f9;
  --sidebar-border:    rgba(255,255,255,.05);
  --sidebar-active:    rgba(129,140,248,.18);

  --shadow-sm:         0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);
  --shadow:            0 4px 16px rgba(0,0,0,.5);
  --shadow-lg:         0 20px 40px rgba(0,0,0,.6);
}

/* ─── Warm theme ──────────────────────────────────────────────────────────── */
[data-theme="warm"] {
  --color-primary:     #d97706;
  --color-primary-h:   #b45309;
  --color-primary-bg:  #fffbeb;

  --bg:                #fdf6ec;
  --bg-2:              #f0e0c8;
  --bg-card:           #fffdf9;
  --bg-hover:          #f5ebe0;
  --border:            #e8d5b7;
  --border-h:          #d4b896;

  --text:              #2c1810;
  --text-2:            #6b4c3b;
  --text-3:            #a07860;

  --sidebar-bg:        #1c1208;
  --sidebar-fg:        #c4a882;
  --sidebar-fg-h:      #fdf6ec;
  --sidebar-border:    rgba(255,255,255,.07);
  --sidebar-active:    rgba(217,119,6,.22);
}

/* ─── Ocean theme ─────────────────────────────────────────────────────────── */
[data-theme="ocean"] {
  --color-primary:     #0891b2;
  --color-primary-h:   #0e7490;
  --color-primary-bg:  #ecfeff;

  --sidebar-bg:        #0c1d2e;
  --sidebar-fg:        #94b8d4;
  --sidebar-fg-h:      #e0f2fe;
  --sidebar-border:    rgba(255,255,255,.06);
  --sidebar-active:    rgba(8,145,178,.2);
}

/* ─── Forest theme ────────────────────────────────────────────────────────── */
[data-theme="forest"] {
  --color-primary:     #059669;
  --color-primary-h:   #047857;
  --color-primary-bg:  #ecfdf5;

  --sidebar-bg:        #0a1f16;
  --sidebar-fg:        #86b8a0;
  --sidebar-fg-h:      #d1fae5;
  --sidebar-border:    rgba(255,255,255,.06);
  --sidebar-active:    rgba(5,150,105,.2);
}

/* ─── Rose theme ──────────────────────────────────────────────────────────── */
[data-theme="rose"] {
  --color-primary:     #e11d48;
  --color-primary-h:   #be123c;
  --color-primary-bg:  #fff1f2;

  --sidebar-bg:        #1f0a14;
  --sidebar-fg:        #c49aaa;
  --sidebar-fg-h:      #fce7f3;
  --sidebar-border:    rgba(255,255,255,.06);
  --sidebar-active:    rgba(225,29,72,.18);
}

/* ─── Theme grid (settings page) ─────────────────────────────────────────── */
.settings-card-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 18px 20px 16px; border-bottom: 1px solid var(--border);
}
.settings-card-header-text {}
.settings-card-title {
  font-size: 1rem; font-weight: 600; color: var(--text); margin-bottom: 2px;
}
.settings-card-subtitle { font-size: .8rem; color: var(--text-3); }
.settings-card-body { padding: 20px; }
.settings-section-label {
  display: flex; align-items: center;
  font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 14px;
}
.theme-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 12px;
}
.theme-card {
  border: 2px solid var(--border); border-radius: 12px; overflow: hidden;
  cursor: pointer; transition: border-color .2s, box-shadow .2s, transform .15s;
  background: none; text-align: left; padding: 0; position: relative;
}
.theme-card:hover { border-color: var(--border-h); box-shadow: var(--shadow); transform: translateY(-2px); }
.theme-card--active {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-bg), var(--shadow);
  transform: translateY(-2px);
}
.theme-card--active .theme-check {
  opacity: 1; transform: scale(1);
}
.theme-check {
  position: absolute; top: 6px; right: 6px;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--color-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(.6); transition: opacity .2s, transform .2s;
}
.theme-preview {
  height: 64px; display: flex; overflow: hidden;
}
.theme-preview-sidebar { width: 24px; flex-shrink: 0; }
.theme-preview-content { flex: 1; padding: 8px 10px; display: flex; flex-direction: column; gap: 5px; }
.theme-preview-bar { height: 5px; border-radius: 3px; width: 55%; }
.theme-preview-lines { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.theme-card-label {
  font-size: .78rem; font-weight: 600; color: var(--text);
  padding: 7px 10px; border-top: 1px solid var(--border);
  background: var(--bg-card);
}

/* ─── Reset ───────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--bg); color: var(--text); line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; -webkit-appearance: none; appearance: none; }
input, textarea, select {
  font: inherit;
  -webkit-appearance: none; appearance: none;
  border-radius: 0; /* iOS rounds inputs by default */
}
img { max-width: 100%; display: block; }
ul { list-style: none; }
.hidden { display: none !important; }

/* ─── Offline bar ─────────────────────────────────────────────────────────── */
.offline-bar {
  grid-column: 1 / -1;
  background: #1e293b;
  color: #e2e8f0;
  font-size: .8rem;
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  position: sticky;
  top: 0;
  z-index: 200;
}
.offline-bar svg { flex-shrink: 0; stroke: #94a3b8; }

/* ─── Auth screen ─────────────────────────────────────────────────────────── */
.auth-screen {
  position: fixed; inset: 0; z-index: 500;
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  -webkit-justify-content: center; justify-content: center;
  background: #0a0a14;
  padding: 24px; overflow-y: auto;
}
.auth-screen::before {
  content: ''; position: fixed;
  top: -240px; left: 50%; transform: translateX(-50%);
  width: 900px; height: 900px; border-radius: 50%;
  background: radial-gradient(circle, rgba(99,102,241,.18) 0%, transparent 65%);
  pointer-events: none;
}
.auth-screen::after {
  content: ''; position: fixed; bottom: -180px; right: -180px;
  width: 600px; height: 600px; border-radius: 50%;
  background: radial-gradient(circle, rgba(139,92,246,.1) 0%, transparent 70%);
  pointer-events: none;
}
.auth-card {
  background: rgba(23,23,42,.9);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 44px 40px;
  width: 100%; max-width: 420px;
  box-shadow: 0 40px 100px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
  position: relative; z-index: 1;
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
}
.auth-logo {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  gap: 12px; font-size: 1.15rem; font-weight: 700;
  color: #f8fafc; margin-bottom: 40px;
}
.auth-title {
  font-size: 1.75rem; font-weight: 800; margin-bottom: 8px;
  color: #f8fafc; letter-spacing: -.02em; line-height: 1.2;
}
.auth-subtitle { color: #94a3b8; font-size: .9rem; margin-bottom: 32px; line-height: 1.55; }

/* Override form controls inside auth to dark theme */
.auth-screen .form-label { color: #64748b; font-size: .78rem; letter-spacing: .04em; text-transform: uppercase; }
.auth-screen .form-control {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
  color: #f8fafc; border-radius: 10px;
  padding: 12px 14px;
}
.auth-screen .form-control:focus {
  border-color: #6366f1;
  background: rgba(255,255,255,.08);
  box-shadow: 0 0 0 3px rgba(99,102,241,.18);
}
.auth-screen .form-control::placeholder { color: #334155; }
.auth-screen .btn--primary {
  background: #6366f1; margin-top: 4px;
  padding: 13px; font-size: .95rem; font-weight: 600; border-radius: 10px;
}
.auth-screen .btn--primary:hover { background: #4f46e5; }
.auth-screen .btn--ghost {
  border-color: rgba(255,255,255,.12); color: #94a3b8;
}
.auth-screen .btn--ghost:hover { background: rgba(255,255,255,.06); color: #f8fafc; }
.auth-success {
  background: rgba(16,185,129,.1); border: 1px solid rgba(16,185,129,.25);
  border-radius: var(--radius); padding: 16px;
  color: #6ee7b7; text-align: center; line-height: 1.6;
}
.auth-screen .form-error { color: #fca5a5; }

/* ─── App shell ───────────────────────────────────────────────────────────── */
.app {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: var(--sidebar-w) 1fr;
  grid-template-columns: var(--sidebar-w) 1fr;
  grid-template-rows: auto auto 1fr;
  min-height: 100vh;
  min-height: -webkit-fill-available;
}

/* ─── Sidebar ─────────────────────────────────────────────────────────────── */
.sidebar {
  grid-row: 1 / -1;
  background: var(--sidebar-bg);
  color: var(--sidebar-fg);
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  position: -webkit-sticky;
  position: sticky;
  top: 0; height: 100vh;
  overflow-y: auto; overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  transition: transform var(--transition);
  z-index: 100;
}
.sidebar-header {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  padding: 20px 16px 16px;
  border-bottom: 1px solid var(--sidebar-border);
}
.sidebar-logo {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 10px;
  font-weight: 700; font-size: .95rem; color: var(--sidebar-fg-h);
}
.sidebar-close { display: none; color: var(--sidebar-fg); padding: 4px; border-radius: 4px; min-width: 32px; min-height: 32px; }
.sidebar-close:hover { color: var(--sidebar-fg-h); }

.sidebar-nav { -webkit-flex: 1; flex: 1; padding: 12px 8px; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.nav-section-label {
  font-size: .7rem; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--text-3);
  padding: 16px 8px 6px;
}
.nav-item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 10px;
  padding: 8px 10px; border-radius: 6px;
  color: var(--sidebar-fg); font-size: .875rem;
  transition: background var(--transition), color var(--transition);
  cursor: pointer; width: 100%; text-align: left;
  min-height: 40px; /* touch target */
}
.nav-item:hover { background: rgba(255,255,255,.06); color: var(--sidebar-fg-h); }
.nav-item.active { background: var(--sidebar-active); color: #a5b4fc; }
.nav-item svg { -webkit-flex-shrink: 0; flex-shrink: 0; opacity: .7; }
.nav-item.active svg, .nav-item:hover svg { opacity: 1; }
.nav-item--add { color: var(--text-3); margin-top: 4px; }
.nav-item--add:hover { color: var(--sidebar-fg-h); }
.nav-item--small { font-size: .8rem; padding: 6px 10px; min-height: 36px; }

.nav-project-item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 8px;
  padding: 6px 10px; border-radius: 6px;
  color: var(--sidebar-fg); font-size: .875rem;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  min-height: 36px;
  -webkit-user-select: none;
  user-select: none;
}
.nav-project-item:hover { background: rgba(255,255,255,.06); color: var(--sidebar-fg-h); }
.nav-project-item.active { background: var(--sidebar-active); color: #a5b4fc; }
.nav-project-name { -webkit-user-select: none; user-select: none; -webkit-flex: 1; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nav-project-edit-btn {
  opacity: 0; border: none; background: transparent; cursor: pointer; padding: 3px;
  color: var(--sidebar-fg); border-radius: 4px; -webkit-flex-shrink: 0; flex-shrink: 0;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  transition: opacity .12s, color .12s;
}
.nav-project-item:hover .nav-project-edit-btn { opacity: .6; }
.nav-project-edit-btn:hover { opacity: 1 !important; color: var(--sidebar-fg-h); }
.nav-rename-input {
  background: transparent; border: none; outline: none;
  border-bottom: 1.5px solid #a5b4fc; color: inherit;
  font-size: inherit; font-weight: inherit; font-family: inherit;
  padding: 0; width: 100%; min-width: 60px;
}
.nav-project-dot {
  width: 8px; height: 8px; border-radius: 50%; -webkit-flex-shrink: 0; flex-shrink: 0;
}
.nav-project-boards {
  padding-left: 26px;
  overflow: hidden;
  max-height: 0;
  transition: max-height 300ms ease;
}
.nav-project-boards.open { max-height: 600px; }

.nav-board-item {
  display: block; padding: 5px 10px; border-radius: 6px;
  color: var(--text-3); font-size: .82rem;
  transition: background var(--transition), color var(--transition);
  width: 100%; text-align: left; min-height: 30px;
  cursor: pointer;
}
.nav-board-item:hover { background: rgba(255,255,255,.04); color: var(--sidebar-fg); }
.nav-board-item.active { color: #a5b4fc; }
.nav-board-empty { opacity: .4; cursor: default; font-style: italic; }
.nav-board-add {
  color: var(--color-primary) !important;
  opacity: .75;
  margin-top: 2px;
}
.nav-board-add:hover { opacity: 1; background: rgba(99,102,241,.12) !important; color: var(--color-primary) !important; }

/* ─── Planner sub-nav ─────────────────────────────────────────────────────── */
.nav-dashboard-group {
  border-bottom: 1px solid var(--sidebar-border);
  padding-bottom: 6px;
  margin-bottom: 6px;
}

.nav-planner {
  overflow: hidden; max-height: 0;
  transition: max-height 300ms ease, opacity 200ms ease;
  opacity: 0; padding-left: 10px;
}
.nav-planner.open { max-height: 400px; opacity: 1; }
.nav-planner-item {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  gap: 7px; padding: 5px 10px; border-radius: 6px; cursor: pointer;
  color: var(--sidebar-fg); font-size: .82rem;
  transition: background .12s, color .12s;
  -webkit-user-select: none; user-select: none;
}
.nav-planner-item:hover  { background: rgba(255,255,255,.06); color: var(--sidebar-fg-h); }
.nav-planner-item.active { background: var(--sidebar-active); color: #a5b4fc; }
.nav-planner-item.drag-over { background: rgba(99,102,241,.25); color: #a5b4fc; outline: 1px dashed rgba(165,180,252,.5); }
.nav-planner-icon  { font-size: .85rem; line-height: 1; -webkit-flex-shrink: 0; flex-shrink: 0; }
.nav-planner-label { -webkit-flex: 1; flex: 1; }
.nav-planner-count {
  font-size: .7rem; font-weight: 700; background: rgba(255,255,255,.1);
  color: var(--sidebar-fg); border-radius: 8px; padding: 1px 6px; min-width: 18px; text-align: center;
}
.nav-planner-item.active .nav-planner-count { background: rgba(255,255,255,.2); color: #fff; }

.sidebar-footer {
  padding: 12px 8px;
  border-top: 1px solid var(--sidebar-border);
}
.sidebar-user {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 10px;
  padding: 8px 10px; margin-bottom: 4px;
}
.sidebar-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--color-primary); color: white;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  font-size: .75rem; font-weight: 700; -webkit-flex-shrink: 0; flex-shrink: 0;
}
.sidebar-user-info { min-width: 0; }
.sidebar-user-name {
  font-size: .8rem; font-weight: 600; color: var(--sidebar-fg-h);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.sidebar-user-role { font-size: .7rem; color: var(--text-3); text-transform: capitalize; }
.sidebar-actions { display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; gap: 2px; }

/* ─── Topbar ──────────────────────────────────────────────────────────────── */
.topbar {
  display: none;
  -webkit-align-items: center;
  align-items: center;
  gap: 12px;
  background: var(--bg-card); border-bottom: 1px solid var(--border);
  padding: 0 16px; height: var(--topbar-h);
  position: -webkit-sticky;
  position: sticky;
  top: 0; z-index: 50;
}
.topbar-menu { color: var(--text); padding: 4px; min-width: 40px; min-height: 40px; }
.topbar-title { font-weight: 600; font-size: .95rem; -webkit-flex: 1; flex: 1; }
.topbar-right { display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 8px; }
.notif-btn { position: relative; color: var(--text-2); padding: 6px; min-width: 40px; min-height: 40px; }
.notif-btn:hover { color: var(--text); }
.notif-badge {
  position: absolute; top: 2px; right: 2px;
  background: var(--color-danger); color: white;
  font-size: .6rem; font-weight: 700; min-width: 16px; height: 16px;
  border-radius: 8px; display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  -webkit-justify-content: center; justify-content: center;
  padding: 0 3px;
}

/* ─── Main content ────────────────────────────────────────────────────────── */
.main { overflow: auto; min-height: 0; -webkit-overflow-scrolling: touch; }

/* ─── Page layouts ────────────────────────────────────────────────────────── */
.page { padding: 28px 32px; max-width: 1400px; }
.page-header {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-bottom: 28px; gap: 16px; -webkit-flex-wrap: wrap; flex-wrap: wrap;
}
.page-title { font-size: 1.4rem; font-weight: 700; }
.page-subtitle { color: var(--text-2); font-size: .875rem; margin-top: 2px; }

/* ─── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: -webkit-inline-flex;
  display: inline-flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 6px;
  padding: 8px 16px; border-radius: var(--radius);
  font-size: .875rem; font-weight: 500;
  transition: background var(--transition), opacity var(--transition), transform .08s;
  cursor: pointer; border: none;
  min-height: 36px;
  -webkit-tap-highlight-color: transparent;
}
.btn:active:not(:disabled) { transform: scale(.97); }
.btn--primary { background: var(--color-primary); color: white; }
.btn--primary:hover { background: var(--color-primary-h); }
.btn--danger { background: var(--color-danger); color: white; }
.btn--danger:hover { opacity: .85; }
.btn--secondary { background: transparent; color: var(--color-primary); border: 1.5px solid var(--color-primary); }
.btn--secondary:hover { background: var(--color-primary); color: #fff; }
.btn--ghost {
  background: transparent; color: var(--text-2);
  border: 1px solid var(--border);
}
.btn--ghost:hover { background: var(--bg-hover); color: var(--text); border-color: var(--border-h); }
.btn--warning { background: var(--color-warning); color: white; }
.btn--sm { padding: 5px 10px; font-size: .8rem; min-height: 30px; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ─── Forms ───────────────────────────────────────────────────────────────── */
.form-group { margin-bottom: 18px; }
.form-label {
  display: block; font-size: .8rem; font-weight: 600;
  color: var(--text-2); margin-bottom: 6px;
}
.form-control {
  width: 100%; padding: 9px 12px;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  background: var(--bg-card); color: var(--text);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
  -webkit-appearance: none; appearance: none;
}
.form-control:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(99,102,241,.1);
  /* iOS: remove blue outline glow */
  -webkit-tap-highlight-color: transparent;
}
.form-control::placeholder { color: var(--text-3); }
textarea.form-control { resize: vertical; min-height: 80px; }
select.form-control {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}
.form-row { display: -ms-grid; display: grid; -ms-grid-columns: 1fr 16px 1fr; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-error { color: var(--color-danger); font-size: .8rem; margin-top: 4px; }
.form-hint { color: var(--text-3); font-size: .78rem; margin-top: 4px; }

/* ─── Cards (UI components) ───────────────────────────────────────────────── */
.card {
  background: var(--bg-card); border-radius: var(--radius-lg);
  border: 1px solid var(--border); box-shadow: var(--shadow-sm);
}
.card-body { padding: 20px; }

/* ─── Dashboard ───────────────────────────────────────────────────────────── */
.dashboard-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 24px 1fr;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.dash-section-title {
  font-size: .8rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-3); margin-bottom: 12px;
}
.dash-card-list { display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; gap: 8px; }
.dash-ticket {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: var(--radius);
  cursor: pointer; transition: box-shadow var(--transition), border-color var(--transition);
  -webkit-tap-highlight-color: transparent;
}
.dash-ticket:hover { box-shadow: var(--shadow); border-color: var(--border-h); }
.dash-ticket-title { font-size: .875rem; font-weight: 500; -webkit-flex: 1; flex: 1; }
.dash-ticket-meta { font-size: .75rem; color: var(--text-3); margin-top: 3px; }
.dash-project-dot { width: 8px; height: 8px; border-radius: 50%; -webkit-flex-shrink: 0; flex-shrink: 0; margin-top: 5px; }
.dash-empty {
  text-align: center; padding: 32px; color: var(--text-3);
  font-size: .875rem; border: 1.5px dashed var(--border); border-radius: var(--radius);
}
.filter-bar {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px; -webkit-flex-wrap: wrap; flex-wrap: wrap;
}
.filter-bar select {
  padding: 6px 28px 6px 10px; border-radius: 20px; border: 1px solid var(--border);
  background: var(--bg-card); font-size: .8rem; color: var(--text); cursor: pointer;
  -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
}

/* ─── Board view ──────────────────────────────────────────────────────────── */
.board-wrap { display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; height: 100%; }
.board-header {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  padding: 20px 24px 14px; gap: 12px; -webkit-flex-wrap: wrap; flex-wrap: wrap;
  background: var(--bg);
  border-bottom: 2.5px solid var(--board-pc, var(--color-primary));
}
.board-header-left { display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 12px; }
.board-project-badge {
  display: -webkit-inline-flex; display: inline-flex;
  -webkit-align-items: center; align-items: center;
  gap: 5px; font-size: .8rem; color: var(--text-2);
}
.board-project-badge::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%;
  background: var(--board-pc, var(--color-primary)); -webkit-flex-shrink: 0; flex-shrink: 0;
}
.board-title { font-size: 1.2rem; font-weight: 700; }
.board-title--editable { cursor: text; border-radius: 4px; padding: 2px 4px; margin: -2px -4px; transition: background .15s; }
.board-title--editable:hover { background: var(--border); }
.board-title-input {
  font-size: 1.2rem; font-weight: 700; font-family: inherit;
  border: none; outline: none; background: transparent;
  border-bottom: 2px solid var(--color-primary);
  padding: 0; margin: 0; width: 100%; min-width: 120px; color: var(--text);
}
.board-actions { display: -webkit-flex; display: flex; gap: 8px; }

.board-logo-wrap { position: relative; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; }
.board-logo { height: 36px; width: auto; max-width: 120px; -o-object-fit: contain; object-fit: contain; border-radius: 4px; display: block; }
.board-logo-overlay {
  position: absolute; inset: 0; border-radius: 4px;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  background: rgba(0,0,0,0); color: #fff; cursor: pointer; transition: background .15s;
}
.board-logo-wrap:hover .board-logo-overlay { background: rgba(0,0,0,.45); }
.board-logo-overlay svg { opacity: 0; transition: opacity .15s; }
.board-logo-wrap:hover .board-logo-overlay svg { opacity: 1; }
.board-logo-placeholder {
  height: 32px; padding: 0 10px; border: 1.5px dashed var(--border); border-radius: 6px;
  color: var(--text-3); font-size: .75rem;
  display: -webkit-inline-flex; display: inline-flex; -webkit-align-items: center; align-items: center; gap: 5px;
  cursor: pointer; white-space: nowrap; transition: border-color .15s, color .15s; -webkit-user-select: none; user-select: none;
}
.board-logo-placeholder:hover { border-color: var(--color-primary); color: var(--color-primary); }

.board-lists {
  display: -webkit-flex;
  display: flex;
  gap: 16px;
  padding: 20px 24px 24px;
  overflow-x: auto;
  -webkit-flex: 1;
  flex: 1;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  min-height: 0;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}
.board-lists::-webkit-scrollbar { height: 6px; }
.board-lists::-webkit-scrollbar-track { background: transparent; }
.board-lists::-webkit-scrollbar-thumb { background: var(--border-h); border-radius: 3px; }

/* Grid layout mode */
.board-wrap--grid { height: auto; min-height: 100%; }

.board-lists--grid {
  /* Override flex:1 (flex-basis:0%) which collapses to 0 in an auto-height parent */
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  width: 100%;
  /* Wrap into rows */
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-content: flex-start;
  align-content: flex-start;
  overflow-x: hidden;
  overflow-y: visible;
  height: auto;
}
.board-lists--grid .list-col {
  max-height: none;
  height: auto;
}
.board-lists--grid .list-cards {
  -webkit-flex: none;
  flex: none;
  overflow-y: visible;
  max-height: none;
}
.board-lists--grid .add-list-col {
  -webkit-align-self: flex-start;
  align-self: flex-start;
}

/* ─── Headline separator ─────────────────────────────────────────────────── */

/* Hide in kanban mode */
.board-lists:not(.board-lists--grid) .list-headline { display: none; }

/* In grid mode: full-width row separator.
   Higher specificity (0,2,0) + flex shorthand beats .list-col { width:280px } */
.board-lists--grid .list-headline {
  -webkit-flex: 0 0 100%;
  flex: 0 0 100%;               /* flex-basis:100% is authoritative in flex layout */
  width: 100%;
  max-width: 100%;
  min-width: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  max-height: none;
  padding: 4px 0 0;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-align-items: stretch;
  align-items: stretch;
}
.board-lists--grid .list-headline.drag-over {
  background: var(--color-primary-bg);
  border-radius: 8px;
}

.list-headline-inner {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  gap: 12px;
  padding: 8px 8px 12px;
  border-bottom: 2px solid var(--border);
  width: 100%;
}
.list-headline-text {
  -webkit-flex: 1; flex: 1;
  font-size: .9rem; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--text-2);
  cursor: text;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.list-headline-input {
  -webkit-flex: 1; flex: 1;
  font-size: .9rem; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--text-2);
  background: var(--bg-2); border: 1.5px solid var(--color-primary);
  border-radius: 4px; padding: 2px 8px; outline: none;
}
.list-headline-grip {
  cursor: grab; color: var(--text-3);
  font-size: 1rem; padding: 0 2px;
  -webkit-flex-shrink: 0; flex-shrink: 0;
  line-height: 1;
  user-select: none; -webkit-user-select: none;
}
.list-headline-grip:active { cursor: grabbing; }
.list-headline-delete {
  -webkit-flex-shrink: 0; flex-shrink: 0;
  color: var(--text-3); padding: 3px 6px;
  border-radius: 4px;
  opacity: 0; transition: opacity var(--transition), color var(--transition);
}
.list-headline:hover .list-headline-delete { opacity: 1; }
.list-headline-delete:hover { color: var(--color-danger); background: var(--bg-2); }

/* ─── List column ─────────────────────────────────────────────────────────── */
.list-col {
  -webkit-flex-shrink: 0; flex-shrink: 0; width: 280px;
  background: #f8fafc; border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column;
  max-height: calc(100vh - 160px);
}
.list-col.drag-over { border-color: var(--color-primary); background: var(--color-primary-bg); }

.list-header {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  padding: 12px 14px 8px; -webkit-flex-shrink: 0; flex-shrink: 0;
}
.list-name { font-weight: 600; font-size: .875rem; -webkit-flex: 1; flex: 1; }
.list-count {
  font-size: .75rem; color: var(--text-3); background: var(--border);
  border-radius: 10px; padding: 1px 7px;
}
.list-menu-btn { color: var(--text-3); padding: 4px; border-radius: 4px; min-width: 28px; min-height: 28px; }
.list-menu-btn:hover { color: var(--text); background: var(--border); }

.list-cards {
  -webkit-flex: 1; flex: 1; overflow-y: auto; padding: 0 8px 8px;
  display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column;
  gap: 6px;
  min-height: 40px;
  -webkit-overflow-scrolling: touch;
}
.list-cards::-webkit-scrollbar { width: 4px; }
.list-cards::-webkit-scrollbar-thumb { background: var(--border-h); border-radius: 2px; }

.list-add-btn {
  margin: 4px 8px 8px; padding: 7px 10px;
  border-radius: 6px; font-size: .82rem; color: var(--text-3);
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  gap: 6px;
  transition: background var(--transition), color var(--transition);
  -webkit-flex-shrink: 0; flex-shrink: 0;
  min-height: 36px;
  width: calc(100% - 16px);
  text-align: left;
}
.list-add-btn:hover { background: var(--border); color: var(--text); }

.add-list-col {
  -webkit-flex-shrink: 0; flex-shrink: 0; width: 280px;
  background: rgba(255,255,255,.5);
  border: 2px dashed var(--border);
  border-radius: var(--radius-lg);
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  -webkit-justify-content: center; justify-content: center;
  min-height: 80px; cursor: pointer;
  transition: border-color var(--transition), background var(--transition);
}
.add-list-col:hover { border-color: var(--color-primary); background: var(--color-primary-bg); color: var(--color-primary); }

/* ─── Kanban card ─────────────────────────────────────────────────────────── */
.k-card {
  background: var(--bg-card); border-radius: var(--radius);
  border: 1px solid var(--border);
  padding: 10px 12px; cursor: pointer;
  transition: box-shadow var(--transition), border-color var(--transition), transform var(--transition);
  position: relative;
  -webkit-tap-highlight-color: transparent;
  touch-action: none; /* for drag & drop */
}
.k-card:hover { box-shadow: var(--shadow); border-color: var(--border-h); transform: translateY(-2px); }
.k-card:hover .k-card-trash-btn { opacity: 1; }
.k-card.dragging { opacity: .4; }
.k-card.drag-ghost { opacity: 1; box-shadow: var(--shadow-lg); -webkit-transform: rotate(2deg); transform: rotate(2deg); }
.k-card--done { opacity: .6; }
.k-card--muted { border-style: dashed; }
.k-card-urgency {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; border-radius: 3px 0 0 3px;
}
.k-card-urgency--todo     { background: var(--urgency-todo); }
.k-card-urgency--mittel   { background: var(--urgency-mittel); }
.k-card-urgency--dringend { background: var(--urgency-dringend); }

.k-card-top {
  display: -webkit-flex; display: flex; -webkit-align-items: flex-start; align-items: flex-start;
  gap: 6px; margin-bottom: 6px;
}
.k-card-done-btn {
  -webkit-flex-shrink: 0; flex-shrink: 0; width: 18px; height: 18px; margin-top: 1px;
  border: none; background: transparent; cursor: pointer; padding: 0;
  color: var(--text-3); transition: color .12s;
}
.k-card-done-btn:hover  { color: var(--color-success); }
.k-card-done-btn.is-done { color: var(--color-success); }
.k-card-title { font-size: .85rem; font-weight: 500; padding-left: 0; -webkit-flex: 1; flex: 1; }
.k-card-title--done { text-decoration: line-through; opacity: .6; }

.k-card-footer {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  -webkit-justify-content: space-between; justify-content: space-between; padding-left: 4px;
}
.k-card-footer-left {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 6px;
}
.k-card-actions {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 4px;
}
.k-card-trash-btn {
  opacity: 0; border: none; background: transparent; cursor: pointer; padding: 2px;
  color: var(--text-3); border-radius: 4px; transition: opacity .12s, color .12s, background .12s;
}
.k-card-trash-btn:hover { opacity: 1 !important; color: var(--color-danger); background: var(--color-danger-bg); }
.k-card-muted-icon { font-size: .75rem; opacity: .5; }

.k-card-labels { display: -webkit-flex; display: flex; -webkit-flex-wrap: wrap; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.k-card-label {
  font-size: .68rem; font-weight: 600; padding: 2px 7px; border-radius: 10px;
  color: white; letter-spacing: .02em;
}
.k-card-meta { display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 8px; }
.k-card-due {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 3px;
  font-size: .72rem; color: var(--text-3);
}
.k-card-due--overdue { color: var(--color-danger); font-weight: 600; }
.k-card-due--soon    { color: var(--urgency-mittel); }
.k-card-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--color-primary); color: white;
  font-size: .65rem; font-weight: 700;
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  -webkit-justify-content: center; justify-content: center;
}
.k-card-icons { display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 6px; color: var(--text-3); font-size: .72rem; }

.k-card-fields {
  display: -webkit-flex; display: flex;
  -webkit-flex-wrap: wrap; flex-wrap: wrap;
  gap: 4px; padding-left: 4px; margin-bottom: 8px;
}
.k-card-field {
  display: -webkit-inline-flex; display: inline-flex;
  -webkit-align-items: center; align-items: center;
  gap: 3px;
  font-size: .7rem; padding: 2px 6px; border-radius: 4px;
  background: var(--bg); border: 1px solid var(--border);
  color: var(--text-2); white-space: nowrap; max-width: 120px;
  overflow: hidden; text-overflow: ellipsis;
}
.k-card-field-label { color: var(--text-3); margin-right: 1px; }
.k-card-field--on  { background: #f0fdf4; border-color: #bbf7d0; color: #15803d; }
.k-card-field--off { background: var(--bg); color: var(--text-3); }

/* ─── Urgency badge ───────────────────────────────────────────────────────── */
.urgency-badge {
  display: -webkit-inline-flex;
  display: inline-flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 4px;
  font-size: .72rem; font-weight: 600; padding: 2px 8px;
  border-radius: 10px; text-transform: capitalize;
}
.urgency-badge--todo     { background: #f1f5f9; color: var(--urgency-todo); }
.urgency-badge--mittel   { background: #fffbeb; color: #d97706; }
.urgency-badge--dringend { background: var(--color-danger-bg); color: var(--color-danger); }

/* ─── Modal ───────────────────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.4);
  z-index: 200; display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  -webkit-justify-content: center; justify-content: center;
  padding: 20px;
  /* Safari/Chrome prefix for backdrop-filter */
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
.modal {
  background: var(--bg-card); border-radius: var(--radius-lg);
  width: 100%; max-width: 680px; max-height: 90vh;
  display: -webkit-flex; display: flex;
  -webkit-flex-direction: column; flex-direction: column;
  box-shadow: var(--shadow-lg);
  -webkit-animation: modal-in 200ms ease;
  animation: modal-in 200ms ease;
}
@-webkit-keyframes modal-in {
  from { opacity: 0; -webkit-transform: scale(.96) translateY(8px); }
  to   { opacity: 1; -webkit-transform: none; }
}
@keyframes modal-in {
  from { opacity: 0; transform: scale(.96) translateY(8px); }
  to   { opacity: 1; transform: none; }
}
.modal-header {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  gap: 12px;
  padding: 20px 20px 0;
}
.modal-title { font-size: 1rem; font-weight: 700; -webkit-flex: 1; flex: 1; }
.modal-close {
  color: var(--text-3); padding: 4px; border-radius: 6px;
  -webkit-flex-shrink: 0; flex-shrink: 0; margin-top: -2px;
  min-width: 32px; min-height: 32px;
}
.modal-close:hover { color: var(--text); background: var(--bg-hover); }
.modal-body { -webkit-flex: 1; flex: 1; overflow-y: auto; padding: 20px; -webkit-overflow-scrolling: touch; }
.modal-footer {
  padding: 16px 20px; border-top: 1px solid var(--border);
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  -webkit-justify-content: flex-end; justify-content: flex-end;
  gap: 8px;
}

/* Card modal specifics */
.card-modal-grid { display: -ms-grid; display: grid; -ms-grid-columns: 1fr 220px; grid-template-columns: 1fr 220px; gap: 24px; }
.card-modal-sidebar-label {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-3); margin-bottom: 6px; margin-top: 16px;
}
.card-modal-sidebar-label:first-child { margin-top: 0; }

.attachment-list { display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; gap: 6px; }
.attachment-item {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  gap: 8px; padding: 8px 10px; background: var(--bg); border-radius: 6px; border: 1px solid var(--border);
}
.attachment-item--img {
  padding: 6px 8px; gap: 10px;
}
.attachment-thumb {
  width: 52px; height: 52px; object-fit: cover; border-radius: 5px;
  cursor: zoom-in; flex-shrink: 0; border: 1px solid var(--border);
  transition: opacity .15s, transform .15s;
}
.attachment-thumb:hover { opacity: .85; transform: scale(1.03); }
.attachment-info { -webkit-flex: 1; flex: 1; min-width: 0; display: -webkit-flex; display: flex; flex-direction: column; gap: 2px; }
.attachment-icon { -webkit-flex-shrink: 0; flex-shrink: 0; display: -webkit-flex; display: flex; }
.att-type-icon {
  width: 28px; height: 28px; border-radius: 6px; color: #fff;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  -webkit-flex-shrink: 0; flex-shrink: 0;
}
.attachment-name { font-size: .8rem; -webkit-flex: 1; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text); }
.attachment-info .attachment-name { flex: unset; }
.attachment-size { font-size: .72rem; color: var(--text-3); white-space: nowrap; }
.attachment-del {
  color: var(--text-3); background: transparent; border: none; cursor: pointer;
  padding: 4px; border-radius: 4px; display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; -webkit-flex-shrink: 0; flex-shrink: 0;
  transition: color .12s, background .12s;
}
.attachment-del:hover { color: var(--color-danger); background: var(--bg-hover); }

/* ─── Lightbox ───────────────────────────────────────────────────────────── */
#pb-lightbox { position: fixed; inset: 0; z-index: 9999; pointer-events: none; }
#pb-lightbox.lb--open { pointer-events: all; }
.lb-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.88); backdrop-filter: blur(4px);
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  opacity: 0; transition: opacity .2s;
}
#pb-lightbox.lb--open .lb-backdrop { opacity: 1; }
.lb-stage {
  display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column;
  -webkit-align-items: center; align-items: center; gap: 12px;
  max-width: calc(100vw - 120px); max-height: calc(100vh - 80px);
}
.lb-img {
  max-width: 100%; max-height: calc(100vh - 120px);
  object-fit: contain; border-radius: 8px;
  box-shadow: 0 24px 80px rgba(0,0,0,.6);
  transition: opacity .2s;
  display: block;
}
.lb-img--loading { opacity: .3; }
.lb-caption {
  color: rgba(255,255,255,.75); font-size: .8rem; text-align: center;
  max-width: 500px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.lb-counter {
  color: rgba(255,255,255,.45); font-size: .72rem;
}
.lb-close {
  position: absolute; top: 16px; right: 16px;
  width: 38px; height: 38px; border-radius: 50%; border: none; cursor: pointer;
  background: rgba(255,255,255,.12); color: #fff;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  transition: background .15s;
}
.lb-close:hover { background: rgba(255,255,255,.22); }
.lb-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 50%; border: none; cursor: pointer;
  background: rgba(255,255,255,.12); color: #fff;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  transition: background .15s;
}
.lb-arrow:hover { background: rgba(255,255,255,.25); }
.lb-prev { left: 16px; }
.lb-next { right: 16px; }

.link-list { display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; gap: 6px; }
.link-item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 8px;
  padding: 6px 10px; background: var(--bg); border-radius: 6px; border: 1px solid var(--border);
}
.link-item a { font-size: .8rem; -webkit-flex: 1; flex: 1; color: var(--color-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.link-item a:hover { text-decoration: underline; }

.upload-zone {
  border: 2px dashed var(--border); border-radius: var(--radius);
  padding: 20px; text-align: center; color: var(--text-3);
  font-size: .82rem; cursor: pointer; transition: border-color var(--transition);
}
.upload-zone:hover, .upload-zone.drag-over { border-color: var(--color-primary); color: var(--color-primary); }

/* ─── Admin / User management ─────────────────────────────────────────────── */
.user-table { width: 100%; border-collapse: collapse; }
.user-table th, .user-table td {
  text-align: left; padding: 10px 14px; font-size: .85rem;
  border-bottom: 1px solid var(--border);
}
.user-table th { font-weight: 600; color: var(--text-2); background: var(--bg); font-size: .78rem; }
.user-table tr:hover td { background: var(--bg-hover); }
.role-badge {
  display: -webkit-inline-flex;
  display: inline-block;
  padding: 2px 8px; border-radius: 10px;
  font-size: .72rem; font-weight: 600; text-transform: capitalize;
}
.role-badge--admin       { background: #ede9fe; color: #7c3aed; }
.role-badge--mitarbeiter { background: var(--color-primary-bg); color: var(--color-primary); }
.role-badge--client      { background: #f0fdf4; color: #16a34a; }
.role-badge--viewer      { background: #f1f5f9; color: var(--text-3); }

/* ─── Notifications panel ─────────────────────────────────────────────────── */
.notif-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 340px; background: var(--bg-card);
  border-left: 1px solid var(--border); box-shadow: var(--shadow-lg);
  z-index: 150; display: -webkit-flex; display: flex;
  -webkit-flex-direction: column; flex-direction: column;
  -webkit-animation: slide-in 200ms ease;
  animation: slide-in 200ms ease;
}
@-webkit-keyframes slide-in { from { -webkit-transform: translateX(100%); } to { -webkit-transform: none; } }
@keyframes slide-in { from { transform: translateX(100%); } to { transform: none; } }
.notif-panel-header {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  font-weight: 700;
}
.notif-list { -webkit-flex: 1; flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.notif-item {
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background var(--transition);
}
.notif-item:hover { background: var(--bg-hover); }
.notif-item--unread { background: var(--color-primary-bg); }
.notif-item--unread:hover { background: #e0e7ff; }
.notif-msg { font-size: .83rem; line-height: 1.5; }
.notif-time { font-size: .72rem; color: var(--text-3); margin-top: 4px; }
.notif-overlay { position: fixed; inset: 0; z-index: 149; }

/* ─── Dropdown menu ───────────────────────────────────────────────────────── */
.dropdown { position: relative; }
.dropdown-menu {
  position: absolute; right: 0; top: calc(100% + 4px);
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow);
  min-width: 160px; z-index: 80;
  overflow: hidden;
}
.dropdown-item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 8px;
  padding: 9px 14px; font-size: .85rem; color: var(--text);
  cursor: pointer; width: 100%; transition: background var(--transition);
  min-height: 40px;
}
.dropdown-item:hover { background: var(--bg-hover); }
.dropdown-item--danger { color: var(--color-danger); }
.dropdown-divider { height: 1px; background: var(--border); margin: 4px 0; }

/* ─── Misc ────────────────────────────────────────────────────────────────── */
.tag-list { display: -webkit-flex; display: flex; -webkit-flex-wrap: wrap; flex-wrap: wrap; gap: 6px; }
.tag {
  display: -webkit-inline-flex;
  display: inline-flex;
  -webkit-align-items: center;
  align-items: center;
  gap: 4px;
  padding: 3px 8px; border-radius: 10px;
  font-size: .75rem; font-weight: 500;
  background: var(--color-primary-bg); color: var(--color-primary);
}
.color-picker { display: -webkit-flex; display: flex; -webkit-flex-wrap: wrap; flex-wrap: wrap; gap: 8px; }
.color-swatch {
  width: 28px; height: 28px; border-radius: 50%; cursor: pointer;
  transition: transform var(--transition);
  border: 2px solid transparent;
}
.color-swatch:hover, .color-swatch.selected {
  -webkit-transform: scale(1.2); transform: scale(1.2);
  border-color: var(--text);
}
.color-swatch--dark { box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.3); }
.color-swatch--dark:hover, .color-swatch--dark.selected { border-color: #fff; }

.spinner {
  display: inline-block; width: 20px; height: 20px;
  border: 2.5px solid var(--border); border-top-color: var(--color-primary);
  border-radius: 50%;
  -webkit-animation: spin .7s linear infinite;
  animation: spin .7s linear infinite;
}
@-webkit-keyframes spin { to { -webkit-transform: rotate(360deg); } }
@keyframes spin { to { transform: rotate(360deg); } }
.loading { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; padding: 48px; }

.toast-container {
  position: fixed; bottom: 24px; right: 24px; z-index: 999;
  display: -webkit-flex; display: flex;
  -webkit-flex-direction: column; flex-direction: column;
  gap: 8px;
  /* Respect iOS safe area */
  bottom: calc(24px + env(safe-area-inset-bottom));
}
.toast {
  background: var(--text); color: white; padding: 10px 16px;
  border-radius: var(--radius); font-size: .85rem; box-shadow: var(--shadow);
  -webkit-animation: toast-in 200ms ease;
  animation: toast-in 200ms ease;
  max-width: 320px;
}
@-webkit-keyframes toast-in { from { opacity: 0; -webkit-transform: translateY(8px); } to { opacity: 1; -webkit-transform: none; } }
@keyframes toast-in  { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@keyframes toast-out { from { opacity: 1; transform: none; } to { opacity: 0; transform: translateY(6px); } }
.toast--success { background: var(--color-success); }
.toast--error   { background: var(--color-danger); }
.toast--warning { background: var(--color-warning); }
.toast.exiting  { animation: toast-out 180ms ease forwards; }

@keyframes modal-out {
  from { opacity: 1; transform: scale(1) translateY(0); }
  to   { opacity: 0; transform: scale(.96) translateY(6px); }
}
.modal.closing { animation: modal-out 140ms ease forwards; pointer-events: none; }

@keyframes form-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: none; }
}

@keyframes card-appear {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: none; }
}
.k-card.is-new { animation: card-appear .2s ease; }

@keyframes done-pop {
  0%   { transform: scale(1); }
  45%  { transform: scale(1.45); }
  100% { transform: scale(1); }
}
.k-card-done-btn.popping { animation: done-pop .22s ease; }

/* ─── Quick card add form ─────────────────────────────────────────────────── */
.quick-add-form {
  padding: 8px; background: var(--bg-card);
  border-radius: var(--radius); border: 1px solid var(--border);
  margin: 0 8px 8px;
  animation: form-in .18s ease;
}
.quick-add-form textarea {
  width: 100%; border: none; outline: none; resize: none;
  font-size: .85rem; background: transparent; color: var(--text);
  min-height: 60px; padding: 4px;
  -webkit-appearance: none; appearance: none;
}
.quick-add-footer { display: -webkit-flex; display: flex; gap: 6px; margin-top: 6px; }

/* ─── Keyboard shortcuts modal ────────────────────────────────────────────── */
kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 7px;
  border-radius: 5px;
  font-size: .75rem;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', monospace;
  font-weight: 600;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-bottom-width: 2.5px;
  color: var(--text-2);
  min-width: 28px;
  text-align: center;
  white-space: nowrap;
}
.shortcuts-section { margin-bottom: 20px; }
.shortcuts-section:last-child { margin-bottom: 0; }
.shortcuts-group-label {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--text-3);
  margin-bottom: 10px; padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.shortcut-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  font-size: .85rem;
  color: var(--text-2);
}
.shortcut-row span { color: var(--text); }

/* ─── Sidebar overlay ─────────────────────────────────────────────────────── */
.sidebar-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.4);
  z-index: 99;
  -webkit-backdrop-filter: blur(1px);
  backdrop-filter: blur(1px);
}

/* ─── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .app {
    grid-template-columns: 1fr;
    grid-template-rows: auto var(--topbar-h) 1fr;
  }
  /* Offline bar spans full width on mobile */
  .offline-bar {
    grid-column: 1;
    grid-row: 1;
    position: relative;
  }
  .sidebar {
    position: fixed; left: 0; top: 0; bottom: 0;
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    box-shadow: none;
    /* iOS notch padding */
    padding-bottom: env(safe-area-inset-bottom);
    padding-left: env(safe-area-inset-left);
  }
  .sidebar.open {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    box-shadow: var(--shadow-lg);
  }
  .sidebar-close { display: -webkit-flex; display: flex; }
  .topbar { display: -webkit-flex; display: flex; grid-row: 2; }
  .main { grid-column: 1; grid-row: 3; }

  .dashboard-grid { grid-template-columns: 1fr; }
  .card-modal-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .page { padding: 16px; }
  .board-header { padding: 12px 16px 0; }
  .board-lists { padding: 12px 16px 16px; }
  .notif-panel { width: 100%; }

  /* Narrower list columns on small screens */
  .list-col { width: 260px; }
  .add-list-col { width: 260px; }
}

@media (max-width: 480px) {
  .modal-backdrop {
    padding: 0;
    -webkit-align-items: flex-end;
    align-items: flex-end;
  }
  .modal {
    max-height: 92vh;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    /* Respect iOS home indicator */
    padding-bottom: env(safe-area-inset-bottom);
  }
  .auth-card { padding: 28px 20px; }
  .toast-container { right: 12px; left: 12px; }
  .toast { max-width: 100%; }
}

/* ─── Desktop: hide topbar ────────────────────────────────────────────────── */
@media (min-width: 769px) {
  .topbar { display: none; }
  .offline-bar { grid-column: 1 / -1; }
}

/* ════════════════════════════════════════════════════════════════════════════
   Analytics Dashboard
   ════════════════════════════════════════════════════════════════════════════ */
.analytics-page { max-width: 1200px; }

.an-filters {
  display: -webkit-flex; display: flex; flex-wrap: wrap; gap: 10px;
  margin-bottom: 24px;
}
.an-filter-group {
  display: -webkit-flex; display: flex; flex-wrap: wrap; gap: 6px;
  padding-right: 14px; border-right: 1px solid var(--border);
}
.an-filter-group:last-child { border-right: none; padding-right: 0; }
.an-pill {
  display: -webkit-inline-flex; display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 20px; font-size: .8rem; font-weight: 500;
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-2); cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
}
.an-pill:hover  { border-color: var(--border-h); color: var(--text); }
.an-pill.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.an-pill-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.an-pill.active .an-pill-dot { background: rgba(255,255,255,.8) !important; }

/* ─── KPI grid ────────────────────────────────────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}
@media (max-width: 900px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .kpi-grid { grid-template-columns: 1fr; } }

.kpi-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-left: 4px solid var(--kpi-accent, var(--color-primary));
  border-radius: var(--radius-lg);
  padding: 18px 20px 14px;
  display: -webkit-flex; display: flex;
  -webkit-flex-direction: column; flex-direction: column;
  gap: 3px;
}
.kpi-value {
  font-size: 2.25rem; font-weight: 800; line-height: 1;
  color: var(--kpi-accent, var(--text-1));
  letter-spacing: -.02em;
}
.kpi-label { font-size: .875rem; font-weight: 600; color: var(--text-1); }
.kpi-sub   { font-size: .75rem; color: var(--text-3); margin-top: 1px; }

/* ─── Analytics card (generic wrapper) ───────────────────────────────────── */
.a-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 22px;
  margin-bottom: 14px;
}
.a-card-title {
  font-size: .9375rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 16px;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  gap: 10px;
}
.a-card-title-sub {
  font-size: .78rem; font-weight: 400; color: var(--text-3);
}
.a-empty {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  gap: 10px; color: var(--text-3); font-size: .875rem;
}
.a-empty-small { color: var(--text-3); font-size: .82rem; padding: 8px 0; }

.analytics-charts-row {
  display: -webkit-flex; display: flex;
  gap: 14px; margin-bottom: 0;
  -webkit-flex-wrap: wrap; flex-wrap: wrap;
}
.analytics-charts-row > .a-card { margin-bottom: 14px; }

/* ─── Bar chart ───────────────────────────────────────────────────────────── */
.bar-chart { display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; gap: 9px; }
.bar-row   { display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 10px; }
.bar-label {
  width: 110px; -webkit-flex-shrink: 0; flex-shrink: 0;
  font-size: .78rem; color: var(--text-2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-align: right;
}
.bar-track {
  -webkit-flex: 1; flex: 1; height: 8px;
  background: var(--border); border-radius: 4px; overflow: hidden;
}
.bar-fill  { height: 100%; border-radius: 4px; transition: width .5s cubic-bezier(.4,0,.2,1); }
.bar-count { width: 28px; -webkit-flex-shrink: 0; flex-shrink: 0; font-size: .78rem; font-weight: 600; color: var(--text-2); text-align: right; }

/* ─── Donut chart ─────────────────────────────────────────────────────────── */
.donut-wrap {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  gap: 20px; -webkit-flex-wrap: wrap; flex-wrap: wrap;
}
.donut-total-num { font-size: 22px; font-weight: 800; fill: var(--text-1); }
.donut-total-lbl { font-size: 10px; fill: var(--text-3); }
.donut-legend {
  display: -webkit-flex; display: flex;
  -webkit-flex-direction: column; flex-direction: column; gap: 9px;
}
.donut-row {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  gap: 7px; font-size: .8125rem;
}
.donut-dot  { width: 10px; height: 10px; border-radius: 50%; -webkit-flex-shrink: 0; flex-shrink: 0; }
.donut-lbl  { -webkit-flex: 1; flex: 1; color: var(--text-2); }
.donut-cnt  { font-weight: 700; color: var(--text-1); min-width: 24px; text-align: right; }
.donut-pct  { color: var(--text-3); font-size: .74rem; min-width: 34px; text-align: right; }

/* ─── Stale cards table ───────────────────────────────────────────────────── */
.stale-wrap { overflow-x: auto; }
.stale-table { width: 100%; border-collapse: collapse; }
.stale-table th {
  font-size: .72rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .04em; color: var(--text-3); text-align: left;
  padding: 8px 12px; border-bottom: 1px solid var(--border);
}
.stale-table td { font-size: .8125rem; padding: 9px 12px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.stale-table tbody tr:last-child td { border-bottom: none; }
.stale-row { cursor: pointer; transition: background var(--transition); }
.stale-row:hover { background: var(--bg-2); }
.stale-title { font-weight: 500; color: var(--text-1); max-width: 280px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.stale-meta  { color: var(--text-2); }
.age-badge {
  display: inline-block; padding: 2px 8px; border-radius: 10px;
  font-size: .75rem; font-weight: 700;
  background: var(--border); color: var(--text-2);
}
.age-badge.age--orange { background: #fef3c7; color: #b45309; }
.age-badge.age--red    { background: #fee2e2; color: #b91c1c; }

/* ─── AI Chat ────────────────────────────────────────────────────────────── */
#ai-chat-root { position: fixed; bottom: 24px; right: 24px; z-index: 10000; }

.ai-fab {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--color-primary); color: #fff; border: none; cursor: pointer;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(99,102,241,.45);
  transition: transform .2s, box-shadow .2s;
}
.ai-fab:hover { transform: scale(1.08); box-shadow: 0 6px 24px rgba(99,102,241,.55); }
.ai-fab.active { background: var(--color-primary-h); }

.ai-panel {
  position: absolute; bottom: 64px; right: 0;
  width: 400px; max-height: 600px;
  background: var(--bg-card); border-radius: 16px;
  box-shadow: 0 12px 48px rgba(0,0,0,.18);
  display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column;
  border: 1px solid var(--border);
  opacity: 0; pointer-events: none; transform: translateY(12px) scale(.97);
  transition: opacity .2s, transform .2s;
}
.ai-panel.open { opacity: 1; pointer-events: all; transform: none; }

.ai-panel-header {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: space-between; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  -webkit-flex-shrink: 0; flex-shrink: 0;
}
.ai-panel-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-success); }
.ai-panel-title { font-weight: 600; font-size: .9rem; }
.ai-icon-btn {
  width: 28px; height: 28px; border: none; background: transparent; cursor: pointer;
  border-radius: 6px; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  color: var(--text-3); transition: background .15s, color .15s;
}
.ai-icon-btn:hover { background: var(--bg); color: var(--text); }

.ai-messages {
  -webkit-flex: 1; flex: 1; overflow-y: auto; padding: 12px 16px;
  display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; gap: 8px;
  min-height: 200px;
}

.ai-welcome { text-align: center; padding: 24px 16px; color: var(--text-3); }
.ai-welcome-icon { font-size: 2rem; margin-bottom: 8px; }
.ai-welcome-text { font-weight: 600; color: var(--text-2); font-size: .9rem; margin-bottom: 4px; }
.ai-welcome-sub  { font-size: .8rem; line-height: 1.4; }

.ai-msg { display: -webkit-flex; display: flex; }
.ai-msg--user     { -webkit-justify-content: flex-end; justify-content: flex-end; }
.ai-msg--assistant { -webkit-justify-content: flex-start; justify-content: flex-start; }

.ai-msg-bubble {
  max-width: 88%; padding: 9px 13px; border-radius: 14px;
  font-size: .84rem; line-height: 1.5;
}
.ai-msg--user .ai-msg-bubble {
  background: var(--color-primary); color: #fff; border-bottom-right-radius: 4px;
}
.ai-msg--assistant .ai-msg-bubble {
  background: var(--bg); color: var(--text); border-bottom-left-radius: 4px; border: 1px solid var(--border);
}
/* ── Markdown elements inside assistant bubble ─────────────────────────── */
.ai-msg--assistant .ai-msg-bubble h3 {
  font-size: .85rem; font-weight: 700; color: var(--text);
  margin: 10px 0 4px; padding-bottom: 3px; border-bottom: 1px solid var(--border);
}
.ai-msg--assistant .ai-msg-bubble h4 {
  font-size: .82rem; font-weight: 600; color: var(--text-2); margin: 8px 0 3px;
}
.ai-msg--assistant .ai-msg-bubble p  { margin: 2px 0; }
.ai-msg--assistant .ai-msg-bubble .ai-gap { height: 6px; }
.ai-msg--assistant .ai-msg-bubble ul, .ai-msg--assistant .ai-msg-bubble ol {
  margin: 4px 0; padding-left: 18px;
}
.ai-msg--assistant .ai-msg-bubble li { margin: 3px 0; line-height: 1.45; }
.ai-msg--assistant .ai-msg-bubble code {
  background: rgba(0,0,0,.07); padding: 1px 4px; border-radius: 3px; font-size: .79em; font-family: monospace;
}
.ai-msg--assistant .ai-msg-bubble pre {
  background: rgba(0,0,0,.06); padding: 10px 12px; border-radius: 7px;
  overflow-x: auto; margin: 6px 0; font-size: .78em; line-height: 1.5;
}
.ai-msg--assistant .ai-msg-bubble pre code { background: none; padding: 0; }
.ai-msg--assistant .ai-msg-bubble hr {
  border: none; border-top: 1px solid var(--border); margin: 8px 0;
}
.ai-msg--assistant .ai-msg-bubble strong { font-weight: 700; color: var(--text); }
.ai-msg--assistant .ai-msg-bubble em     { font-style: italic; color: var(--text-2); }

.ai-thinking { display: -webkit-flex; display: flex; gap: 4px; -webkit-align-items: center; align-items: center; padding: 12px 13px !important; }
.ai-thinking span {
  width: 7px; height: 7px; background: var(--text-3); border-radius: 50%;
  -webkit-animation: ai-bounce .9s infinite ease-in-out; animation: ai-bounce .9s infinite ease-in-out;
}
.ai-thinking span:nth-child(2) { -webkit-animation-delay: .15s; animation-delay: .15s; }
.ai-thinking span:nth-child(3) { -webkit-animation-delay: .3s;  animation-delay: .3s; }
@-webkit-keyframes ai-bounce { 0%, 80%, 100% { -webkit-transform: scale(.8); transform: scale(.8); opacity: .4; } 40% { -webkit-transform: scale(1.1); transform: scale(1.1); opacity: 1; } }
@keyframes ai-bounce { 0%, 80%, 100% { transform: scale(.8); opacity: .4; } 40% { transform: scale(1.1); opacity: 1; } }

.ai-quick-prompts {
  display: -webkit-flex; display: flex; gap: 6px; -webkit-flex-wrap: wrap; flex-wrap: wrap;
  padding: 0 16px 8px; -webkit-flex-shrink: 0; flex-shrink: 0;
}
.ai-quick-btn {
  font-size: .75rem; padding: 4px 10px; border-radius: 20px;
  border: 1px solid var(--border); background: var(--bg); color: var(--text-2); cursor: pointer;
  transition: border-color .15s, color .15s;
  white-space: nowrap;
}
.ai-quick-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }

.ai-input-row {
  display: -webkit-flex; display: flex; gap: 8px; padding: 12px 16px;
  border-top: 1px solid var(--border); -webkit-flex-shrink: 0; flex-shrink: 0;
  -webkit-align-items: flex-end; align-items: flex-end;
}
.ai-textarea {
  -webkit-flex: 1; flex: 1; border: 1px solid var(--border); border-radius: 10px;
  padding: 8px 12px; font-size: .85rem; resize: none; outline: none;
  font-family: inherit; line-height: 1.4; max-height: 120px; overflow-y: auto;
  background: var(--bg); color: var(--text);
  transition: border-color .15s;
}
.ai-textarea:focus { border-color: var(--color-primary); }
.ai-send-btn {
  width: 36px; height: 36px; border-radius: 10px; border: none;
  background: var(--color-primary); color: #fff; cursor: pointer;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  -webkit-flex-shrink: 0; flex-shrink: 0;
  transition: background .15s;
}
.ai-send-btn:hover { background: var(--color-primary-h); }

@-webkit-keyframes spin { to { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
@keyframes spin { to { transform: rotate(360deg); } }

@media (max-width: 540px) {
  #ai-chat-root { bottom: 16px; right: 16px; }
  .ai-panel { width: calc(100vw - 32px); right: 0; bottom: 60px; }
}

/* ─── Task Planner (Dashboard) ───────────────────────────────────────────── */
.tp-wrap { max-width: 680px; margin: 0 auto; padding: 32px 24px 60px; }

.tp-header {
  display: -webkit-flex; display: flex;
  -webkit-align-items: flex-start; align-items: flex-start;
  -webkit-justify-content: space-between; justify-content: space-between;
  gap: 12px; margin-bottom: 32px;
}
.tp-header-main { -webkit-flex: 1; flex: 1; min-width: 0; }
.tp-greeting { font-size: 1.5rem; font-weight: 700; color: var(--text); }
.tp-date { font-size: .85rem; color: var(--text-3); margin-top: 2px; }

/* ─── Quick-add bar ─────────────────────────────────────────────────────── */
.tp-quick-add-wrap {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.tp-quick-add {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  gap: 10px; padding: 9px 12px; border-radius: 8px;
  background: var(--bg-card); border: 1.5px dashed var(--border);
  transition: border-color .15s, box-shadow .15s;
}
.tp-quick-add:focus-within {
  border-color: var(--color-primary); border-style: solid;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 12%, transparent);
}
.tp-qa-plus {
  -webkit-flex-shrink: 0; flex-shrink: 0; color: var(--text-3);
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  transition: color .12s;
}
.tp-quick-add:focus-within .tp-qa-plus { color: var(--color-primary); }
.tp-qa-input {
  -webkit-flex: 1; flex: 1; min-width: 0; border: none; background: transparent;
  font-size: .875rem; color: var(--text); outline: none; padding: 0;
}
.tp-qa-input::placeholder { color: var(--text-3); }
.tp-qa-target {
  -webkit-flex-shrink: 0; flex-shrink: 0;
  display: -webkit-inline-flex; display: inline-flex;
  -webkit-align-items: center; align-items: center; gap: 3px;
  padding: 3px 8px; border-radius: 5px; font-size: .75rem; font-weight: 500;
  background: var(--bg); border: 1px solid var(--border);
  color: var(--text-3); cursor: pointer; white-space: nowrap;
  max-width: 200px; overflow: hidden; text-overflow: ellipsis;
  transition: border-color .12s, color .12s;
}
.tp-qa-target:hover { border-color: var(--border-h); color: var(--text-2); }
.tp-qa-target.has-target { color: var(--color-primary); border-color: color-mix(in srgb, var(--color-primary) 40%, transparent); }
.tp-qa-picker {
  flex-direction: column; gap: 7px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 12px; margin-top: 4px;
  box-shadow: var(--shadow-lg);
}
.tp-qa-select {
  width: 100%; padding: 6px 8px; border-radius: 5px;
  border: 1px solid var(--border); background: var(--bg);
  color: var(--text); font-size: .82rem; cursor: pointer;
}
.tp-qa-select:focus { outline: none; border-color: var(--color-primary); }
.tp-qa-select:disabled { opacity: .45; cursor: not-allowed; }

/* ─── Project filter pills ──────────────────────────────────────────────── */
.tp-project-filter {
  display: -webkit-flex; display: flex; flex-wrap: wrap; gap: 6px;
  margin-bottom: 20px;
}
.tp-pf-pill {
  display: -webkit-inline-flex; display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 20px; font-size: .8rem; font-weight: 500;
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-2); cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
  -webkit-user-select: none; user-select: none;
}
.tp-pf-pill:hover  { border-color: var(--border-h); color: var(--text); }
.tp-pf-pill.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.tp-pf-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.tp-pf-pill.active .tp-pf-dot { background: rgba(255,255,255,.8) !important; }

.tp-group { margin-bottom: 28px; }
.tp-group-label {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 7px;
  font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 8px; padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.tp-section-icon { font-style: normal; font-size: .9rem; line-height: 1; }
.tp-group-count {
  margin-left: auto; font-size: .72rem; font-weight: 600;
  background: var(--border); color: var(--text-3);
  border-radius: 10px; padding: 1px 7px;
}
.tp-group-label--overdue  { color: var(--color-danger); }
.tp-group-label--today    { color: var(--color-primary); }
.tp-group-label--tomorrow { color: #0ea5e9; }
.tp-group-label--thisweek { color: var(--color-success); }
.tp-group-label--nextweek { color: var(--text-2); }
.tp-group-label--later    { color: var(--text-3); }
.tp-group-label--none     { color: var(--text-3); }

.tp-task {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 8px; cursor: pointer;
  transition: background .12s;
  background: var(--bg-card); border: 1px solid var(--border);
  margin-bottom: 6px;
}
.tp-task:hover { background: var(--bg-hover); }
.tp-task:hover .tp-plan-btn,
.tp-task:hover .tp-trash-btn { opacity: 1; }
.tp-task--dragging { opacity: .4; cursor: grabbing; }
.tp-task--done { opacity: .55; }

.tp-done-btn {
  -webkit-flex-shrink: 0; flex-shrink: 0; width: 22px; height: 22px;
  border: none; background: transparent; cursor: pointer; padding: 0;
  color: var(--text-3); transition: color .12s; display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
}
.tp-done-btn:hover { color: var(--color-success); }
.tp-done-btn.is-done { color: var(--color-success); }
.tp-task-title--done { text-decoration: line-through; opacity: .6; }

.tp-trash-btn {
  opacity: 0; border: none; background: transparent; cursor: pointer; padding: 2px;
  color: var(--text-3); border-radius: 4px; transition: opacity .12s, color .12s, background .12s;
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
}
.tp-trash-btn:hover { color: var(--color-danger); background: var(--color-danger-bg); }

.tp-back-btn {
  display: -webkit-inline-flex; display: inline-flex; -webkit-align-items: center; align-items: center;
  gap: 4px; font-size: .82rem; color: var(--color-primary); background: none; border: none;
  cursor: pointer; padding: 0; margin-bottom: 8px; opacity: .8;
}
.tp-back-btn:hover { opacity: 1; }

.tp-task-dot {
  width: 10px; height: 10px; border-radius: 50%; -webkit-flex-shrink: 0; flex-shrink: 0;
  border: 2px solid currentColor;
}
.tp-task-dot--dringend { color: var(--urgency-dringend); }
.tp-task-dot--mittel   { color: var(--urgency-mittel); }
.tp-task-dot--todo     { color: var(--text-3); }

.tp-task-body { -webkit-flex: 1; flex: 1; min-width: 0; }
.tp-task-title { font-size: .875rem; font-weight: 500; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tp-task-meta  {
  font-size: .75rem; color: var(--text-3); margin-top: 2px;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 5px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tp-project-badge {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--pc, #6366f1); -webkit-flex-shrink: 0; flex-shrink: 0; display: inline-block;
}

.tp-task-aside {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 8px;
  -webkit-flex-shrink: 0; flex-shrink: 0;
}
.tp-due { font-size: .75rem; color: var(--text-3); white-space: nowrap; }
.tp-due--overdue { color: var(--color-danger); font-weight: 600; }
.tp-plan-badge {
  font-size: .75rem; color: var(--color-primary); white-space: nowrap;
  background: var(--color-primary-bg); border-radius: 5px; padding: 1px 6px;
}

.tp-plan-btn {
  width: 26px; height: 26px; border: none; border-radius: 6px; background: transparent;
  color: var(--text-3); cursor: pointer; display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center;
  transition: background .12s, color .12s; opacity: 0;
}
.tp-plan-btn:hover { background: var(--border); color: var(--text); }

.tp-plan-menu {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12); padding: 4px; min-width: 170px;
}
.tp-plan-option {
  display: block; width: 100%; text-align: left; padding: 8px 12px; border: none;
  background: transparent; border-radius: 6px; font-size: .84rem; cursor: pointer; color: var(--text);
  transition: background .12s;
}
.tp-plan-option:hover { background: var(--bg); }
.tp-plan-option--remove { color: var(--color-danger); }
.tp-plan-divider { height: 1px; background: var(--border); margin: 3px 4px; }

.tp-empty {
  display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column;
  -webkit-align-items: center; align-items: center; gap: 10px;
  padding: 48px 0; color: var(--text-3); font-size: .9rem; text-align: center;
}

/* ─── Archive panel ──────────────────────────────────────────────────────── */
.archive-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.3); z-index: 1100;
  backdrop-filter: blur(2px);
}
.archive-panel {
  position: fixed; top: 0; right: 0; bottom: 0; width: 380px; max-width: 100%;
  background: var(--bg-card); border-left: 1px solid var(--border);
  z-index: 1101; display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column;
  transform: translateX(100%); transition: transform .25s ease;
  box-shadow: -8px 0 32px rgba(0,0,0,.12);
}
.archive-panel.open { transform: none; }
.archive-panel-header {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  -webkit-justify-content: space-between; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  -webkit-flex-shrink: 0; flex-shrink: 0;
}
.archive-panel-title {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  gap: 8px; font-weight: 600; font-size: .95rem; color: var(--text);
}
.archive-panel-close {
  border: none; background: transparent; cursor: pointer; color: var(--text-3);
  padding: 4px; border-radius: 6px; transition: background .12s, color .12s;
}
.archive-panel-close:hover { background: var(--bg); color: var(--text); }
.archive-panel-body {
  -webkit-flex: 1; flex: 1; overflow-y: auto; padding: 12px 16px;
}
.archive-card {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  gap: 10px; padding: 10px 12px; border-radius: 8px; border: 1px solid var(--border);
  margin-bottom: 8px; background: var(--bg-card);
}
.archive-card-info { -webkit-flex: 1; flex: 1; min-width: 0; }
.archive-card-title {
  font-size: .875rem; font-weight: 500; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.archive-card-meta { font-size: .75rem; color: var(--text-3); margin-top: 2px; }
.archive-card-actions {
  display: -webkit-flex; display: flex; gap: 4px; -webkit-flex-shrink: 0; flex-shrink: 0;
}
.archive-empty {
  text-align: center; color: var(--text-3); padding: 48px 0; font-size: .9rem;
}

/* ─── Search overlay ──────────────────────────────────────────────────────── */
.search-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.45);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  display: -webkit-flex; display: flex;
  -webkit-align-items: flex-start; align-items: flex-start;
  -webkit-justify-content: center; justify-content: center;
  padding: 80px 20px 20px;
}
.search-box {
  background: var(--bg-card); border-radius: var(--radius-lg);
  width: 100%; max-width: 580px;
  box-shadow: 0 24px 64px rgba(0,0,0,.2);
  overflow: hidden;
  -webkit-animation: modal-in 160ms ease; animation: modal-in 160ms ease;
}
.search-input-wrap {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; gap: 10px;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
}
.search-icon { color: var(--text-3); -webkit-flex-shrink: 0; flex-shrink: 0; }
.search-input {
  -webkit-flex: 1; flex: 1; border: none; background: transparent;
  font-size: 1rem; color: var(--text); outline: none;
  font-family: inherit;
}
.search-input::placeholder { color: var(--text-3); }
.search-esc-hint {
  font-size: .7rem; padding: 2px 6px; border-radius: 4px;
  background: var(--bg); border: 1px solid var(--border-h);
  color: var(--text-3); -webkit-flex-shrink: 0; flex-shrink: 0; font-family: inherit;
}
.search-results { max-height: 420px; overflow-y: auto; padding: 6px 0; }
.search-hint {
  padding: 16px 18px; font-size: .85rem; color: var(--text-3); text-align: center;
}
.search-group-label {
  font-size: .68rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--text-3); padding: 10px 16px 4px;
}
.search-result-item {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; gap: 11px;
  width: 100%; padding: 9px 16px; cursor: pointer;
  background: transparent; border: none; text-align: left;
  transition: background .1s;
}
.search-result-item:hover,
.search-result-item.active { background: var(--bg-hover); }
.search-result-dot {
  width: 9px; height: 9px; border-radius: 50%;
  -webkit-flex-shrink: 0; flex-shrink: 0;
}
.search-result-dot--todo     { background: var(--urgency-todo); }
.search-result-dot--mittel   { background: var(--urgency-mittel); }
.search-result-dot--dringend { background: var(--urgency-dringend); }
.search-result-board-dot {
  width: 9px; height: 9px; border-radius: 3px;
  -webkit-flex-shrink: 0; flex-shrink: 0;
}
.search-result-body { -webkit-flex: 1; flex: 1; min-width: 0; }
.search-result-title {
  font-size: .875rem; font-weight: 500; color: var(--text);
  display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.search-result-meta {
  font-size: .75rem; color: var(--text-3); margin-top: 1px;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; gap: 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.search-result-proj {
  width: 7px; height: 7px; border-radius: 50%;
  -webkit-flex-shrink: 0; flex-shrink: 0;
  background: var(--pc, #6366f1);
}
mark.search-hl {
  background: #fef08a; color: inherit; border-radius: 2px; padding: 0 1px;
}

/* Search trigger button in sidebar */
.sidebar-search-btn {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; gap: 8px;
  width: calc(100% - 24px); margin: 10px 12px 4px;
  padding: 7px 10px; border-radius: var(--radius); border: none; cursor: pointer;
  background: rgba(255,255,255,.06); color: var(--sidebar-fg);
  font-size: .8rem; font-family: inherit; transition: background .12s;
  -webkit-justify-content: space-between; justify-content: space-between;
}
.sidebar-search-btn:hover { background: rgba(255,255,255,.1); }
.sidebar-search-btn-left {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center; gap: 8px;
}
.sidebar-search-btn kbd {
  font-size: .65rem; padding: 1px 5px; border-radius: 4px;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15);
  color: var(--sidebar-fg); font-family: inherit; opacity: .8;
}

/* Board search filter */
.board-search-wrap {
  position: relative; display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
}
.board-search-input {
  width: 0; overflow: hidden; opacity: 0; border: none;
  background: var(--bg); color: var(--text); border-radius: var(--radius);
  padding: 0; font-size: .82rem; font-family: inherit; outline: none;
  transition: width .2s ease, opacity .2s ease, padding .2s ease;
}
.board-search-input.open {
  width: 180px; opacity: 1; padding: 5px 10px;
  border: 1px solid var(--border-h);
}
.board-search-input::placeholder { color: var(--text-3); }
.k-card--search-hidden { display: none !important; }

/* Board filter bar */
.board-filter-bar {
  display: -webkit-flex; display: flex;
  -webkit-align-items: center; align-items: center;
  flex-wrap: wrap; gap: 6px;
  padding: 8px 20px 10px;
  background: var(--bg-2); border-bottom: 1px solid var(--border);
}
.board-filter-label {
  font-size: .72rem; font-weight: 600; color: var(--text-3);
  text-transform: uppercase; letter-spacing: .06em; margin-right: 4px; white-space: nowrap;
}
.board-filter-sep { width: 1px; height: 16px; background: var(--border); margin: 0 4px; }
.board-filter-chip {
  display: -webkit-inline-flex; display: inline-flex;
  -webkit-align-items: center; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 20px; font-size: .75rem; font-weight: 600;
  border: 1px solid var(--border); background: var(--bg); color: var(--text-2);
  cursor: pointer; transition: all .15s; white-space: nowrap;
}
.board-filter-chip:hover { border-color: var(--color-primary); color: var(--color-primary); }
.board-filter-chip--active {
  background: var(--color-primary); border-color: var(--color-primary);
  color: #fff !important;
}
.board-filter-chip--clear {
  border-color: transparent; color: var(--text-3); margin-left: auto;
}
.board-filter-chip--clear:hover { color: var(--color-danger); border-color: var(--color-danger); }

/* ─── Share modal ─────────────────────────────────────────────────────────── */
.share-admin-note {
  display: flex; align-items: center; gap: 6px; margin: 0 0 14px;
  font-size: .78rem; color: var(--text-3); padding: 7px 10px;
  background: var(--bg-2); border-radius: 8px; border: 1px solid var(--border);
}
.share-admin-note svg { flex-shrink: 0; color: var(--text-3); }
.share-section-label {
  font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 8px;
}
.share-section-hint { font-weight: 400; text-transform: none; letter-spacing: 0; }
.share-user-list { display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; gap: 4px; }
.share-user-row {
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  gap: 10px; padding: 6px 8px; border-radius: 8px;
  transition: background .1s;
}
.share-user-row:hover { background: var(--bg-hover); }
.share-avatar {
  width: 30px; height: 30px; border-radius: 50%; -webkit-flex-shrink: 0; flex-shrink: 0;
  background: var(--color-primary); color: #fff;
  display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center;
  -webkit-justify-content: center; justify-content: center;
  font-size: .7rem; font-weight: 700;
}
.share-user-info { -webkit-flex: 1; flex: 1; min-width: 0; }
.share-user-name { font-size: .85rem; font-weight: 500; }
.share-user-meta { font-size: .75rem; color: var(--text-3); margin-top: 1px; }
.share-empty { font-size: .82rem; color: var(--text-3); padding: 4px 0; margin: 0; }
.share-role-badge {
  display: inline-block; font-size: .68rem; font-weight: 600; padding: 1px 6px;
  border-radius: 10px; text-transform: uppercase; letter-spacing: .04em;
}
.share-role--admin      { background: #ede9fe; color: #6d28d9; }
.share-role--mitarbeiter{ background: #e0f2fe; color: #0369a1; }
.share-role--client     { background: #fef3c7; color: #92400e; }
.share-role--viewer     { background: #f1f5f9; color: #475569; }

/* ─── Print ───────────────────────────────────────────────────────────────── */
@media print {
  @page { margin: 1.5cm; size: A4 landscape; }

  /* Force white background, black text everywhere */
  *, *::before, *::after {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }

  /* Hide chrome */
  .sidebar, .topbar, .offline-bar,
  .board-actions, .board-filter-bar, .board-search-wrap,
  .list-add-btn, .list-menu-btn,
  .k-card-actions, .k-card-done-btn, .k-card-trash-btn,
  .add-list-col, .ai-fab, #ai-chat-panel,
  .notif-panel, .notif-btn, .sidebar-overlay,
  .modal-overlay:not(:has(.modal-content)) { display: none !important; }

  /* App shell: single column, no overflow */
  .app { display: block !important; }
  .main { overflow: visible !important; height: auto !important; padding: 0 !important; }

  /* Board: full width block */
  .board-wrap { display: block !important; height: auto !important; overflow: visible !important; }
  .board-header {
    position: static !important; border-bottom: 2px solid #000 !important;
    padding: 0 0 10px !important; margin-bottom: 16px !important;
  }
  .board-title { font-size: 16pt !important; font-weight: 700 !important; }
  .board-project-badge { font-size: 10pt !important; color: #444 !important; background: #eee !important;
    padding: 2px 8px !important; border-radius: 4px !important; }

  /* Lists: wrap, break across pages */
  .board-lists {
    display: flex !important; flex-wrap: wrap !important; gap: 12px !important;
    height: auto !important; overflow: visible !important; padding: 0 !important;
    align-items: flex-start !important;
  }
  .list-col {
    flex: 0 0 calc(33.33% - 10px) !important; min-width: 180px !important;
    break-inside: avoid !important; page-break-inside: avoid !important;
    border: 1px solid #ccc !important; border-radius: 6px !important; padding: 8px !important;
  }
  .list-header { border-bottom: 1px solid #ddd !important; padding-bottom: 6px !important; margin-bottom: 6px !important; }
  .list-name { font-weight: 700 !important; font-size: 9pt !important; }
  .list-count { font-size: 8pt !important; color: #666 !important; margin-left: 6px !important; }
  .list-cards { overflow: visible !important; max-height: none !important; }

  /* Cards */
  .k-card {
    border: 1px solid #ddd !important; border-radius: 4px !important;
    margin-bottom: 5px !important; padding: 6px 8px 6px 10px !important;
    break-inside: avoid !important; page-break-inside: avoid !important;
    display: block !important;
  }
  .k-card--done { opacity: .5 !important; }
  .k-card-urgency {
    position: static !important; display: inline-block !important;
    width: 6px !important; height: 6px !important; border-radius: 50% !important;
    vertical-align: middle !important; margin-right: 4px !important;
  }
  .k-card-urgency--dringend { background: #ef4444 !important; }
  .k-card-urgency--mittel   { background: #f59e0b !important; }
  .k-card-urgency--todo     { background: #94a3b8 !important; }
  .k-card-top { display: flex !important; align-items: flex-start !important; gap: 4px !important; }
  .k-card-title { font-size: 8pt !important; line-height: 1.35 !important; }
  .k-card-footer { font-size: 7pt !important; color: #555 !important; margin-top: 4px !important; }

  /* Dashboard */
  .dashboard-card { border: 1px solid #ccc !important; border-radius: 6px !important; margin-bottom: 12px !important; }
  .task-group-label { font-size: 8pt !important; font-weight: 700 !important; text-transform: uppercase !important; }
  .task-row { border-bottom: 1px solid #eee !important; padding: 4px 0 !important; font-size: 8.5pt !important; }

  /* Modal: if a card modal is open, print just it */
  .modal-overlay { display: block !important; position: static !important; background: transparent !important; }
  .modal-content { box-shadow: none !important; border: 1px solid #ccc !important; max-width: 100% !important; }

  /* Page title from board name */
  .board-header-left::before {
    content: 'Project Beard – ';
    font-size: 9pt; color: #888;
  }
}
