/* kalender-list.css — Custom list/agenda view
   Uses same category color system as month view (cat-{key} CSS classes).
   Clean, scrollable, modern. No FullCalendar dependencies. */

/* ── Container — fills available space, scrolls independently ── */
.cal-list-view {
  position: absolute;
  top: 56px;  /* below toolbar */
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  background: var(--color-card, #fff);
}

.cal-list-view__scroll {
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0 24px 100px;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* Scrollbar styling */
.cal-list-view__scroll::-webkit-scrollbar { width: 6px; }
.cal-list-view__scroll::-webkit-scrollbar-track { background: transparent; }
.cal-list-view__scroll::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.12);
  border-radius: 6px;
}
.cal-list-view__scroll::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.2);
}

/* ── Day group ── */
.cal-lv-day {
  margin-bottom: 2px;
}

.cal-lv-day__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 8px 10px;
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--color-card, #fff);
}

.cal-lv-day__name {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-tertiary, rgb(115, 113, 108));
  text-transform: capitalize;
  letter-spacing: 0.3px;
}

.cal-lv-day__date {
  font-size: 15px;
  font-weight: 650;
  color: var(--color-text-primary, rgb(19, 19, 19));
}

.cal-lv-day__badge {
  font-size: 11px;
  font-weight: 650;
  color: #fff;
  background: var(--color-text-primary);
  padding: 2px 10px;
  border-radius: 10px;
  letter-spacing: 0.3px;
}

/* Past days — subtle */
.cal-lv-day--past .cal-lv-day__header {
  opacity: 0.45;
}

/* Today — highlighted header */
.cal-lv-day--today .cal-lv-day__header {
  opacity: 1;
}

.cal-lv-day--today .cal-lv-day__date {
  color: var(--color-text-primary);
}

/* ── Event card — tinted background matching month view ── */
.cal-lv-event {
  --_cat-color: var(--lv-cat-color, #4A90E2);
  --_cat-bg: rgba(74, 144, 226, 0.10);
  --_cat-bg-hover: rgba(74, 144, 226, 0.18);
  --_cat-text: #2563a8;
  display: flex;
  align-items: stretch;
  gap: 0;
  padding: 0;
  margin: 0 0 6px;
  border-radius: 8px;
  background: var(--_cat-bg);
  border: none;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
  overflow: hidden;
}

.cal-lv-event:hover {
  background: var(--_cat-bg-hover);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  transform: translateY(-1px);
}

.cal-lv-event:active {
  transform: translateY(0);
  box-shadow: none;
}

/* Color bar — left edge */
.cal-lv-event__bar {
  width: 4px;
  align-self: stretch;
  background: var(--_cat-color);
  border-radius: 8px 0 0 8px;
  flex-shrink: 0;
}

/* Time column */
.cal-lv-event__time {
  width: 110px;
  min-width: 110px;
  padding: 12px 10px 12px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--_cat-text);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  flex-shrink: 0;
  opacity: 0.7;
}

/* Event body — title + chip + description */
.cal-lv-event__body {
  flex: 1;
  min-width: 0;
  padding: 10px 16px 10px 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px 10px;
}

.cal-lv-event__title {
  font-size: 14px;
  font-weight: 600;
  color: var(--_cat-text);
  line-height: 1.35;
}

.cal-lv-event:hover .cal-lv-event__title {
  opacity: 0.85;
}

/* Category chip */
.cal-lv-event__chip {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 600;
  padding: 1px 8px;
  border-radius: 10px;
  white-space: nowrap;
  background: rgba(255, 255, 255, 0.65);
  color: var(--_cat-text);
  line-height: 1.6;
}

/* Description preview */
.cal-lv-event__desc {
  width: 100%;
  font-size: 13px;
  color: var(--_cat-text);
  opacity: 0.5;
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Past events */
.cal-lv-event--past {
  opacity: 0.45;
}
.cal-lv-event--past:hover {
  opacity: 0.75;
}

/* ── Empty state ── */
.cal-lv-empty {
  text-align: center;
  padding: 80px 20px;
  font-size: 15px;
  color: var(--color-text-tertiary, rgb(115, 113, 108));
  font-weight: 500;
}

/* ════════════════════════════════════════
   CATEGORY COLORS — matches month view exactly
   (from kalender-grid.css + kalender-dark.css)
   ════════════════════════════════════════ */

/* Personlig — blue */
.cal-lv-event.cat-personlig {
  --_cat-color: #4A90E2;
  --_cat-bg: rgba(74, 144, 226, 0.15);
  --_cat-bg-hover: rgba(74, 144, 226, 0.22);
  --_cat-text: #2563a8;
}

/* Aflevering — red */
.cal-lv-event.cat-aflevering {
  --_cat-color: #e24668;
  --_cat-bg: rgba(226, 70, 104, 0.15);
  --_cat-bg-hover: rgba(226, 70, 104, 0.22);
  --_cat-text: #be3a59;
}

/* Grammatik — green */
.cal-lv-event.cat-grammatik {
  --_cat-color: #22c55e;
  --_cat-bg: rgba(34, 197, 94, 0.15);
  --_cat-bg-hover: rgba(34, 197, 94, 0.22);
  --_cat-text: #15803d;
}

/* Skole — cyan */
.cal-lv-event.cat-skole {
  --_cat-color: #06b6d4;
  --_cat-bg: rgba(6, 182, 212, 0.15);
  --_cat-bg-hover: rgba(6, 182, 212, 0.22);
  --_cat-text: #0e7490;
}

/* Prøve — purple */
.cal-lv-event.cat-proeve {
  --_cat-color: #8b5cf6;
  --_cat-bg: rgba(139, 92, 246, 0.15);
  --_cat-bg-hover: rgba(139, 92, 246, 0.22);
  --_cat-text: #6d28d9;
}

/* Andet — amber */
.cal-lv-event.cat-andet {
  --_cat-color: #f59e0b;
  --_cat-bg: rgba(245, 158, 11, 0.15);
  --_cat-bg-hover: rgba(245, 158, 11, 0.22);
  --_cat-text: #b45309;
}

/* Deadline — pink */
.cal-lv-event.cat-deadline {
  --_cat-color: #d946a8;
  --_cat-bg: rgba(217, 70, 168, 0.15);
  --_cat-bg-hover: rgba(217, 70, 168, 0.22);
  --_cat-text: #a8348a;
}

/* Møder — sky blue */
.cal-lv-event.cat-moeder {
  --_cat-color: #0ea5e9;
  --_cat-bg: rgba(14, 165, 233, 0.15);
  --_cat-bg-hover: rgba(14, 165, 233, 0.22);
  --_cat-text: #0369a1;
}

/* Arbejde — teal */
.cal-lv-event.cat-arbejde {
  --_cat-color: #0d9488;
  --_cat-bg: rgba(13, 148, 136, 0.15);
  --_cat-bg-hover: rgba(13, 148, 136, 0.22);
  --_cat-text: #115e59;
}

/* Google Calendar — blue */
.cal-lv-event.cat-google_cal {
  --_cat-color: #4285F4;
  --_cat-bg: rgba(66, 133, 244, 0.15);
  --_cat-bg-hover: rgba(66, 133, 244, 0.22);
  --_cat-text: #1a65d1;
}

/* ════════════════════════════════════════
   DARK MODE
   ════════════════════════════════════════ */
[data-theme="dark"] .cal-list-view {
  background: var(--color-card, #1e1e2d);
}

[data-theme="dark"] .cal-list-view__scroll::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.12);
}

[data-theme="dark"] .cal-lv-day__header {
  background: var(--color-card, #1e1e2d);
}

[data-theme="dark"] .cal-lv-day__name {
  color: var(--color-text-tertiary);
}

[data-theme="dark"] .cal-lv-day__date {
  color: #e2e8f0;
}

[data-theme="dark"] .cal-lv-day__badge {
  background: #3b82f6;
  color: #fff;
}

[data-theme="dark"] .cal-lv-day--today .cal-lv-day__date {
  color: #93c5fd;
}

/* Dark mode base card */
[data-theme="dark"] .cal-lv-event {
  --_cat-bg: rgba(74, 144, 226, 0.12);
  --_cat-bg-hover: rgba(74, 144, 226, 0.20);
  --_cat-text: #93c5fd;
}

[data-theme="dark"] .cal-lv-event:hover {
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .cal-lv-event__chip {
  background: rgba(0, 0, 0, 0.25);
}

[data-theme="dark"] .cal-lv-event__desc {
  opacity: 0.4;
}

/* Dark mode category overrides */
[data-theme="dark"] .cal-lv-event.cat-personlig {
  --_cat-color: #7ab4f5;
  --_cat-bg: rgba(74, 144, 226, 0.16);
  --_cat-bg-hover: rgba(74, 144, 226, 0.24);
  --_cat-text: #93c5fd;
}

[data-theme="dark"] .cal-lv-event.cat-aflevering {
  --_cat-color: #f87171;
  --_cat-bg: rgba(239, 68, 68, 0.16);
  --_cat-bg-hover: rgba(239, 68, 68, 0.24);
  --_cat-text: #fca5a5;
}

[data-theme="dark"] .cal-lv-event.cat-grammatik {
  --_cat-color: #4ade80;
  --_cat-bg: rgba(34, 197, 94, 0.16);
  --_cat-bg-hover: rgba(34, 197, 94, 0.24);
  --_cat-text: #86efac;
}

[data-theme="dark"] .cal-lv-event.cat-skole {
  --_cat-color: #22d3ee;
  --_cat-bg: rgba(6, 182, 212, 0.16);
  --_cat-bg-hover: rgba(6, 182, 212, 0.24);
  --_cat-text: #67e8f9;
}

[data-theme="dark"] .cal-lv-event.cat-proeve {
  --_cat-color: #a78bfa;
  --_cat-bg: rgba(139, 92, 246, 0.16);
  --_cat-bg-hover: rgba(139, 92, 246, 0.24);
  --_cat-text: #c4b5fd;
}

[data-theme="dark"] .cal-lv-event.cat-andet {
  --_cat-color: #fbbf24;
  --_cat-bg: rgba(245, 158, 11, 0.16);
  --_cat-bg-hover: rgba(245, 158, 11, 0.24);
  --_cat-text: #fcd34d;
}

[data-theme="dark"] .cal-lv-event.cat-deadline {
  --_cat-color: #fb7185;
  --_cat-bg: rgba(225, 29, 72, 0.16);
  --_cat-bg-hover: rgba(225, 29, 72, 0.24);
  --_cat-text: #fda4af;
}

[data-theme="dark"] .cal-lv-event.cat-moeder {
  --_cat-color: #38bdf8;
  --_cat-bg: rgba(14, 165, 233, 0.16);
  --_cat-bg-hover: rgba(14, 165, 233, 0.24);
  --_cat-text: #7dd3fc;
}

[data-theme="dark"] .cal-lv-event.cat-arbejde {
  --_cat-color: #2dd4bf;
  --_cat-bg: rgba(13, 148, 136, 0.16);
  --_cat-bg-hover: rgba(13, 148, 136, 0.24);
  --_cat-text: #5eead4;
}

[data-theme="dark"] .cal-lv-event.cat-google_cal {
  --_cat-color: #60a5fa;
  --_cat-bg: rgba(66, 133, 244, 0.16);
  --_cat-bg-hover: rgba(66, 133, 244, 0.24);
  --_cat-text: #93c5fd;
}

/* ════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════ */
@media (max-width: 768px) {
  .cal-list-view__scroll {
    padding: 0 12px 100px;
  }

  .cal-lv-event__time {
    width: 100px;
    min-width: 100px;
    font-size: 12px;
    padding: 10px 6px 10px 12px;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .cal-lv-event__body {
    padding: 10px 12px 10px 0;
  }

  .cal-lv-event__title {
    font-size: 13px;
  }

  .cal-lv-event__chip {
    font-size: 10px;
    padding: 1px 6px;
  }

  .cal-lv-event__desc {
    font-size: 12px;
  }
}
