/* ===========================================================
   To-do · Persönlich — Aufgabenliste mit Windows-Benachrichtigungen
   Inherits tokens from styles.css, components from tracker.css
   =========================================================== */

:root {
  --td-hoch: #ff6b6b;
  --td-mittel: var(--accent);
  --td-niedrig: #41d77f;
}

/* ---------- Notification banner ---------- */
.td-notice {
  max-width: 1080px; margin: 18px auto 0; padding: 0 var(--pad);
}
.td-notice-inner {
  display: flex; align-items: center; gap: 16px; padding: 16px 20px;
  border: 1px solid var(--line); border-radius: var(--radius);
  background: linear-gradient(180deg, color-mix(in oklab, var(--accent) 11%, transparent), rgba(255,255,255,.02));
}
.td-notice-inner.granted { background: linear-gradient(180deg, color-mix(in oklab, #41d77f 11%, transparent), rgba(255,255,255,.02)); border-color: color-mix(in oklab, #41d77f 26%, transparent); }
.td-notice-inner.denied { background: linear-gradient(180deg, color-mix(in oklab, #ff6b6b 10%, transparent), rgba(255,255,255,.02)); border-color: color-mix(in oklab, #ff6b6b 26%, transparent); }
.td-notice .bic {
  width: 44px; height: 44px; border-radius: 13px; flex: none; display: grid; place-items: center; font-size: 20px;
  color: var(--accent); background: color-mix(in oklab, var(--accent) 14%, transparent);
}
.td-notice-inner.granted .bic { color: #41d77f; background: color-mix(in oklab, #41d77f 14%, transparent); }
.td-notice-inner.denied .bic { color: #ff6b6b; background: color-mix(in oklab, #ff6b6b 14%, transparent); }
.td-notice .bt { flex: 1; min-width: 0; }
.td-notice .bt b { display: block; font-size: 15px; font-weight: 600; letter-spacing: -.01em; }
.td-notice .bt span { color: var(--muted); font-size: 13px; margin-top: 3px; display: block; text-wrap: pretty; }
.td-notice .btn { flex: none; }

/* ---------- Stage + composer ---------- */
.td-stage { padding: 20px var(--pad) 90px; max-width: 1080px; margin: 0 auto; }

.td-composer {
  display: flex; align-items: center; gap: 12px; padding: 9px 9px 9px 18px;
  border: 1px solid var(--line-strong); border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.018));
  transition: border-color .2s, background .2s;
}
.td-composer:focus-within { border-color: var(--accent); background: color-mix(in oklab, var(--accent) 7%, transparent); }
.td-composer .ic { color: var(--faint); font-size: 18px; flex: none; }
.td-composer input {
  flex: 1; min-width: 0; background: none; border: none; outline: none; color: var(--fg);
  font-family: var(--font-body); font-size: 15.5px;
}
.td-composer input::placeholder { color: var(--faint); }
.td-composer .td-quick {
  display: inline-flex; gap: 5px; flex: none;
}
.td-quick-btn {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--muted); border: 1px solid var(--line); background: rgba(255,255,255,.03);
  border-radius: 999px; padding: 7px 11px; cursor: pointer; transition: all .2s; white-space: nowrap;
}
.td-quick-btn:hover { color: var(--fg); border-color: var(--line-strong); }
.td-quick-btn.active { color: #1c0f06; background: var(--accent); border-color: var(--accent); }
.td-composer .add {
  width: 44px; height: 44px; flex: none; border-radius: 50%; border: none; cursor: pointer;
  background: var(--accent); color: #1c0f06; font-size: 22px; display: grid; place-items: center;
  box-shadow: 0 12px 30px -12px var(--accent-glow); transition: transform .2s;
}
.td-composer .add:hover { transform: translateY(-2px) scale(1.04); }
@media (max-width: 620px) { .td-composer .td-quick { display: none; } }

/* ---------- Filter row ---------- */
.td-filters { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: 22px 0 6px; }
.td-filters .lbl { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); margin-right: 2px; }
.td-seg { display: inline-flex; gap: 4px; padding: 4px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.02); }
.td-seg button { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); padding: 8px 14px; border-radius: 999px; border: none; background: transparent; cursor: pointer; transition: all .2s; display: inline-flex; align-items: center; gap: 7px; }
.td-seg button:hover { color: var(--fg); }
.td-seg button.active { color: #1c0f06; background: var(--accent); }
.td-seg button .cnt { font-family: var(--font-mono); font-size: 9.5px; padding: 1px 6px; border-radius: 999px; background: rgba(255,255,255,.1); color: inherit; }
.td-seg button.active .cnt { background: rgba(0,0,0,.18); }
.td-filters .spacer { flex: 1; }
.td-clear-done {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--faint); border: 1px solid var(--line); background: rgba(255,255,255,.02);
  border-radius: 999px; padding: 8px 13px; cursor: pointer; transition: all .2s;
}
.td-clear-done:hover { color: #ff6b6b; border-color: color-mix(in oklab, #ff6b6b 38%, transparent); }

/* ---------- Group ---------- */
.td-group { margin-top: 30px; }
.td-group:first-of-type { margin-top: 22px; }
.td-group-head { display: flex; align-items: center; gap: 11px; margin-bottom: 13px; }
.td-group-head b { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -.02em; }
.td-group-head .gc { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); border: 1px solid var(--line); border-radius: 999px; padding: 3px 9px; }
.td-group-head.over b { color: var(--td-hoch); }
.td-group-head .gline { flex: 1; height: 1px; background: var(--line); }

.td-list { display: flex; flex-direction: column; gap: 10px; }

/* ---------- Task row ---------- */
.td-item {
  position: relative; display: flex; align-items: flex-start; gap: 14px;
  padding: 15px 17px 15px 19px; border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  transition: border-color .2s, box-shadow .25s, transform .15s, opacity .3s;
  animation: td-in .35s var(--ease-out);
}
@keyframes td-in { from { transform: translateY(8px); } to { transform: none; } }
.td-item:hover { border-color: var(--line-strong); box-shadow: 0 18px 40px -28px rgba(0,0,0,.9); }
.td-item::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; border-radius: 999px 0 0 999px; background: var(--prio, var(--faint)); }
.td-item[data-prio="hoch"]   { --prio: var(--td-hoch); }
.td-item[data-prio="mittel"] { --prio: var(--td-mittel); }
.td-item[data-prio="niedrig"]{ --prio: var(--td-niedrig); }
.td-item.is-over { border-color: color-mix(in oklab, var(--td-hoch) 36%, transparent); }

/* checkbox */
.td-check {
  width: 24px; height: 24px; flex: none; margin-top: 1px; border-radius: 50%;
  border: 2px solid var(--line-strong); background: transparent; cursor: pointer; position: relative;
  transition: border-color .2s, background .2s; display: grid; place-items: center;
}
.td-check:hover { border-color: var(--accent); }
.td-check::after { content: "✓"; font-size: 13px; font-weight: 700; color: #06120b; opacity: 0; transform: scale(.5); transition: opacity .2s, transform .2s var(--ease-out); }
.td-item.done .td-check { background: #41d77f; border-color: #41d77f; }
.td-item.done .td-check::after { opacity: 1; transform: none; }

.td-main { flex: 1; min-width: 0; }
.td-title { font-size: 15px; font-weight: 600; letter-spacing: -.01em; line-height: 1.35; text-wrap: pretty; cursor: text; }
.td-item.done .td-title { color: var(--faint); text-decoration: line-through; text-decoration-color: var(--dim); }
.td-note { color: var(--muted); font-size: 13px; line-height: 1.45; margin-top: 5px; text-wrap: pretty; }
.td-item.done .td-note { color: var(--dim); }

.td-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.td-tag {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .05em; color: var(--muted);
  border: 1px solid var(--line); border-radius: 999px; padding: 4px 9px; display: inline-flex; align-items: center; gap: 6px;
}
.td-tag .ic { opacity: .75; font-size: 11px; }
.td-tag.due.over { color: var(--td-hoch); border-color: color-mix(in oklab, var(--td-hoch) 36%, transparent); }
.td-tag.due.today { color: var(--accent); border-color: color-mix(in oklab, var(--accent) 36%, transparent); }
.td-tag.remind { color: var(--accent-2); border-color: color-mix(in oklab, var(--accent-2) 30%, transparent); }
.td-tag.prio { text-transform: uppercase; letter-spacing: .1em; }
.td-tag.prio .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--prio, var(--faint)); }

.td-actions { display: inline-flex; gap: 5px; flex: none; align-self: center; opacity: 0; transition: opacity .2s; }
.td-item:hover .td-actions, .td-item:focus-within .td-actions { opacity: 1; }
.td-act-btn {
  width: 32px; height: 32px; border-radius: 9px; border: 1px solid transparent; background: transparent;
  color: var(--faint); cursor: pointer; font-size: 14px; display: grid; place-items: center; transition: all .2s;
}
.td-act-btn:hover { color: var(--fg); background: rgba(255,255,255,.06); border-color: var(--line); }
.td-act-btn.del:hover { color: var(--td-hoch); border-color: color-mix(in oklab, var(--td-hoch) 38%, transparent); }
@media (max-width: 620px) { .td-actions { opacity: 1; } }

/* ---------- Empty state ---------- */
.td-empty { text-align: center; padding: 80px 20px; color: var(--faint); }
.td-empty .ic { font-size: 44px; margin-bottom: 16px; opacity: .45; }
.td-empty b { display: block; font-family: var(--font-display); font-size: 20px; color: var(--muted); letter-spacing: -.01em; }
.td-empty p { font-size: 14px; margin-top: 8px; }

/* ---------- Detail modal extras ---------- */
.td-remind-seg { display: flex; flex-wrap: wrap; gap: 6px; }
.td-remind-seg button {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .05em; color: var(--muted);
  border: 1px solid var(--line-strong); background: rgba(255,255,255,.03); border-radius: 999px;
  padding: 9px 14px; cursor: pointer; transition: all .2s;
}
.td-remind-seg button:hover { color: var(--fg); border-color: var(--line-strong); }
.td-remind-seg button.active { color: var(--fg); border-color: var(--accent); background: color-mix(in oklab, var(--accent) 13%, transparent); }

/* notification status pill in app bar */
.td-bell {
  display: inline-flex; align-items: center; gap: 9px; padding: 9px 14px;
  border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.02);
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--muted); cursor: pointer; transition: all .2s; white-space: nowrap;
}
.td-bell:hover { color: var(--fg); border-color: var(--line-strong); }
.td-bell i { width: 7px; height: 7px; border-radius: 50%; flex: none; background: var(--dim); }
.td-bell.on i { background: #41d77f; box-shadow: 0 0 9px rgba(65,215,127,.5); animation: pulse 2.4s infinite; }
.td-bell.off i { background: #ff6b6b; }
@media (max-width: 760px) { .td-bell .txt { display: none; } .td-bell { padding: 9px 11px; } }

@media (prefers-reduced-motion: reduce) {
  .td-item { animation: none; }
  .td-bell.on i { animation: none; }
}
