/* ── Calendar Slide ───────────────────────────────────────── */

/* ── Raum-Status Row ──────────────────────────────────────── */
.cal-rooms {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1rem;
}

.cal-room {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .5rem .85rem;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  min-width: 12rem;
  flex: 1;
}
.cal-room-busy {
  background: rgba(239,68,68,.12);
  border-color: rgba(239,68,68,.3);
}
.cal-room-free {
  background: rgba(34,197,94,.08);
  border-color: rgba(34,197,94,.2);
}

.cal-room-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cal-room-busy .cal-room-dot { background: var(--accent-red, #ef4444); }
.cal-room-free .cal-room-dot { background: var(--accent-green, #22c55e); }

.cal-room-info   { min-width: 0; }
.cal-room-name   {
  font-weight: 700;
  font-size: var(--font-sm);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cal-room-status {
  font-size: var(--font-2xs);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: .1rem;
}

/* ── Ganztägig ────────────────────────────────────────────── */
.cal-allday-row {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: .75rem;
}
.cal-allday-badge {
  display: inline-block;
  padding: .2rem .65rem;
  border-radius: 999px;
  background: rgba(99,102,241,.18);
  border: 1px solid rgba(99,102,241,.3);
  font-size: var(--font-xs);
  color: #a5b4fc;
}

/* ── Event-Liste ──────────────────────────────────────────── */
.cal-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.cal-event {
  display: grid;
  grid-template-columns: 6rem 1fr auto;
  align-items: center;
  gap: .85rem;
  padding: .7rem 1rem;
  border-radius: var(--radius-md);
  border-left: 3px solid rgba(255,255,255,.1);
  transition: opacity .3s;
}
.cal-event-current {
  border-left-color: var(--accent-green, #22c55e);
  background: rgba(34,197,94,.07);
}
.cal-event-past {
  opacity: .4;
}

/* Zeit-Spalte */
.cal-time {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-variant-numeric: tabular-nums;
  font-size: var(--font-xs);
  line-height: 1.3;
}
.cal-time-start { font-weight: 700; color: var(--text-primary); }
.cal-time-sep   { font-size: var(--font-2xs); color: var(--text-muted); }
.cal-time-end   { color: var(--text-muted); }

/* Event-Body */
.cal-event-body { min-width: 0; }
.cal-event-title {
  font-size: var(--font-md);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.cal-now-badge {
  display: inline-block;
  padding: .1rem .45rem;
  border-radius: 4px;
  background: var(--accent-green, #22c55e);
  color: #fff;
  font-size: var(--font-2xs);
  font-weight: 800;
  letter-spacing: .06em;
  flex-shrink: 0;
}
.cal-progress {
  margin-top: .4rem;
  height: 3px;
}

/* Meta-Spalte */
.cal-event-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .25rem;
  flex-shrink: 0;
}
.cal-location, .cal-attendees {
  font-size: var(--font-xs);
  color: var(--text-muted);
  white-space: nowrap;
}
.cal-location { color: var(--accent-blue, #818cf8); }

/* ── Empty State ──────────────────────────────────────────── */
.cal-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  text-align: center;
  color: var(--text-muted);
}
.cal-empty-icon { font-size: 4rem; opacity: .7; }
.cal-empty-text { font-size: var(--font-sm); line-height: 1.7; }
.cal-empty-text code {
  font-family: ui-monospace, Menlo, monospace;
  background: rgba(255,255,255,.08);
  padding: 1px 5px;
  border-radius: 3px;
}
