/* tasks.css – Aufgaben-View-Komponenten (Lese-Pfad, S24a) */

/* ─── View-Container + Header ──────────────────────────────────────────────── */

.tasks-view {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.tasks-view__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.tasks-view__title {
  font-size: var(--font-size-xl);
  font-weight: 700;
  letter-spacing: -0.02em;
}

/* ─── Orphan-Streifen (anklickbar) ─────────────────────────────────────────── */

.tasks-orphan-banner {
  background: var(--color-warning-bg);
  color: var(--color-warning);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-warning);
  font-size: var(--font-size-sm);
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.tasks-orphan-banner__cta {
  padding: 4px var(--space-sm);
  font-size: var(--font-size-sm);
  color: var(--color-warning);
  border-color: var(--color-warning);
  flex-shrink: 0;
}

.tasks-orphan-banner__cta:hover:not(:disabled) {
  background: var(--color-warning-bg);
  opacity: 0.8;
}

.tasks-orphan-banner__cta:focus-visible {
  outline: 2px solid var(--color-warning);
  outline-offset: 2px;
}

/* ─── Backup-Erinnerungs-Banner ────────────────────────────────────────────── */

.tasks-backup-banner {
  background: var(--color-primary-bg);
  color: var(--color-text);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-primary);
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.tasks-backup-banner__text { flex: 1; }

.tasks-backup-banner__actions {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  flex-shrink: 0;
}

.tasks-backup-banner__cta {
  padding: 4px var(--space-sm);
  font-size: var(--font-size-sm);
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.tasks-backup-banner__cta:hover:not(:disabled) {
  background: var(--color-primary-bg);
  opacity: 0.8;
}

.tasks-backup-banner__cta:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.tasks-backup-banner__dismiss {
  width: 28px;
  height: 28px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-lg);
  line-height: 1;
  color: var(--color-text-muted);
  background: transparent;
  border: none;
  cursor: pointer;
}

.tasks-backup-banner__dismiss:hover { background: var(--color-overlay-light); }
.tasks-backup-banner__dismiss:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ─── Card-Liste ───────────────────────────────────────────────────────────── */

.task-cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.task-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.task-card--overdue {
  border-left: 3px solid var(--color-warning);
}

.task-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.task-card__header-text {
  flex: 1;
  font-weight: 600;
  font-size: var(--font-size-base);
  color: var(--color-text);
}

.task-card--overdue .task-card__header-text {
  color: var(--color-warning);
}

.task-card__warning {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-pill);
  background: var(--color-warning-bg);
  color: var(--color-warning);
  font-size: 14px;
  flex-shrink: 0;
}

.task-card__warning:focus-visible {
  outline: 2px solid var(--color-warning);
  outline-offset: 2px;
}

/* ─── Pflanzen-Zeile (in Card) ─────────────────────────────────────────────── */

.task-card__plants {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.task-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--duration-fast);
}

.task-row:hover {
  background: var(--color-surface-alt);
}

.task-row__check {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.task-row--overdue .task-row__check {
  color: var(--color-danger);
}

.task-row__emoji {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
}

.task-row__name {
  flex: 1;
  min-width: 0;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.task-row__amount {
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  letter-spacing: -0.05em; /* Wassertropfen rücken näher zusammen */
}

.task-row__preview-mark {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

/* ─── Vorschau-Block (klappbar) ────────────────────────────────────────────── */

.tasks-preview {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.tasks-preview__toggle {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-surface-alt);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  text-align: left;
  cursor: pointer;
  width: 100%;
}

.tasks-preview__toggle:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.tasks-preview__chevron {
  flex-shrink: 0;
  font-size: var(--font-size-sm);
  width: 14px;
  text-align: center;
}

.tasks-preview__label {
  flex: 1;
}

/* ─── Inline-Empty (Hauptblock leer, Vorschau ggf. da) ─────────────────────── */

.tasks-empty-line {
  color: var(--color-text-muted);
  text-align: center;
  padding: var(--space-lg) var(--space-md);
  background: var(--color-surface-alt);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-base);
}

/* ─── Empty-State (volle Fläche) ──────────────────────────────────────────── */

.tasks-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-xl) var(--space-lg);
  gap: var(--space-md);
}

.tasks-empty__icon {
  font-size: 52px;
  line-height: 1;
}

.tasks-empty__headline {
  font-size: var(--font-size-xl);
  font-weight: 700;
}

.tasks-empty__text {
  color: var(--color-text-muted);
  max-width: 290px;
  line-height: 1.6;
}

.tasks-empty__cta {
  width: 100%;
  max-width: 320px;
  justify-content: center;
}

/* ─── S24b/S24c: Snapshot-Mode, Card-Fade, Bulk ───────────────────────────── */

/* Pflanzenzeile im Snapshot: durchgestrichen, ausgegraut, kein Tap.
   Bleibt sichtbar bis Card-Fade oder View-Remount. */
.task-row--checked {
  cursor: default;
  opacity: 0.5;
  text-decoration: line-through;
  text-decoration-thickness: 1px;
}
.task-row--checked:hover {
  background: transparent;
}
.task-row--checked .task-row__check {
  color: var(--color-primary);
}

/* Card-Footer mit Bulk-Aktion. */
.task-card__footer {
  display: flex;
  justify-content: flex-end;
  padding-top: var(--space-xs);
}

.task-card__bulk {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: var(--font-size-sm);
  font-weight: 500;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  cursor: pointer;
}
.task-card__bulk:hover {
  background: var(--color-surface-alt);
}
.task-card__bulk:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.task-card__bulk[disabled] {
  opacity: 0.4;
  cursor: default;
}

/* Card-Fade-Out nach vollständiger Erledigung. Triggern erst nach Toast-Close. */
.task-card--fading {
  opacity: 0;
  transform: scale(0.98);
  transition: opacity 1s ease-out, transform 1s ease-out;
  pointer-events: none;
}

/* ─── S30c: Hybrid-Cards (Cutting-Sub-Block) ──────────────────────────────── */

/* Trennt Pflanzen- von Stecklings-Zeilen innerhalb derselben Card. */
.task-card__sub-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-xs) var(--space-sm);
  list-style: none;
}

/* Stecklings-Zeile: anderer Emoji (🌱) — Layout sonst identisch zur Pflanzen-Zeile. */
.task-row__cutting-action {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

/* Soft-Task (plant_suggestion) — kein Checkbox-Glyph (• statt ☐), Primärfarbe als Akzent. */
.task-row--soft .task-row__check {
  color: var(--color-primary);
}

/* Dringlichkeits-Pill bei plant_suggestion. Eskaliert primary → warning → danger. */
.task-row__urgency {
  font-size: var(--font-size-sm);
  font-weight: 500;
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  flex-shrink: 0;
}
.task-row__urgency--1 {
  background: var(--color-primary-bg);
  color: var(--color-primary);
}
.task-row__urgency--2 {
  background: var(--color-warning-bg);
  color: var(--color-warning);
}
.task-row__urgency--3 {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}
