/* ─────────────────────────────────────────────────────────────────
   26-calendar.css — Kalender (Woche + Monat)

   Layout: Toolbar · Sidebar (Mini-Kal · Picker · KPI · Legende · Homebase)
           · Haupt-Grid (Week-View ODER Month-View)
   Drag: nur Markup-Hooks (data-draggable), keine externe Lib.
   Namespace: .mb-cal*
   Tokens: --bg --s1..s4 --b1..b3 --t1..t4 --np --r --r2 --tr --font --mono
   ───────────────────────────────────────────────────────────────── */

.mb-cal {
  --day-col: minmax(0, 1fr);
  --gutter-w: 56px;
  --px-per-hour: 56px;
  --start-hour: 7;
  --end-hour: 21;

  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 16px;
  padding: 16px 20px 28px;
  height: 100%;
  min-height: 600px;
  background: var(--bg);
  font-size: 13px;
  color: var(--t1);
}

/* ══ TOOLBAR (sitzt oben, spans both columns) ════════════════════ */
.mb-cal__toolbar {
  grid-column: 1 / -1;
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: var(--s1);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
}
.mb-cal__toolbar-group {
  display: inline-flex; align-items: center; gap: 6px;
}
.mb-cal__nav {
  display: inline-flex; align-items: center; gap: 2px;
}
.mb-cal__nav-btn {
  width: 30px; height: 30px; border-radius: var(--r);
  background: transparent; border: 1px solid var(--b1); color: var(--t2);
  display: grid; place-items: center; cursor: pointer;
  transition: var(--tr);
}
.mb-cal__nav-btn:hover { background: var(--s2); color: var(--t1); }
.mb-cal__today-btn {
  height: 30px; padding: 0 12px; border-radius: var(--r);
  background: transparent; border: 1px solid var(--b1); color: var(--t2);
  cursor: pointer; font: inherit; font-size: 12px; font-weight: 500;
  transition: var(--tr);
}
.mb-cal__today-btn:hover { background: var(--s2); color: var(--t1); }

.mb-cal__title {
  font-size: 15px; font-weight: 600; color: var(--t1);
  letter-spacing: -0.2px;
  margin: 0 4px 0 8px;
  min-width: 200px;
}

.mb-cal__toolbar-spacer { flex: 1; }

.mb-cal__search {
  display: inline-flex; align-items: center; gap: 8px;
  width: 220px; padding: 0 10px; height: 30px;
  background: var(--s2); border: 1px solid var(--b1);
  border-radius: var(--r);
  color: var(--t3);
}
.mb-cal__search:focus-within { border-color: var(--b3); }
.mb-cal__search input {
  flex: 1; min-width: 0; border: 0; background: transparent; outline: none;
  font: inherit; font-size: 12.5px; color: var(--t1);
}
.mb-cal__search input::placeholder { color: var(--t4); }

/* ══ SIDEBAR (left) ══════════════════════════════════════════════ */
.mb-cal__sidebar {
  display: flex; flex-direction: column; gap: 12px;
  overflow-y: auto;
}

/* ── Mini-calendar ──────────────────────────────────────────────── */
.mb-minical {
  background: var(--s1); border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 12px;
}
.mb-minical__hd {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.mb-minical__month {
  font-size: 12.5px; font-weight: 600; color: var(--t1);
}
.mb-minical__nav {
  display: flex; gap: 2px;
}
.mb-minical__nav-btn {
  width: 22px; height: 22px; border-radius: 5px;
  background: transparent; border: 0; color: var(--t3);
  display: grid; place-items: center; cursor: pointer;
}
.mb-minical__nav-btn:hover { background: var(--s2); color: var(--t1); }

.mb-minical__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  font-variant-numeric: tabular-nums;
}
.mb-minical__dow {
  text-align: center;
  font-size: 10px; color: var(--t4);
  padding: 4px 0 2px;
  font-weight: 500;
  letter-spacing: 0.2px;
}
.mb-minical__day {
  aspect-ratio: 1;
  display: grid; place-items: center;
  font-size: 11px; color: var(--t2);
  background: transparent; border: 0; cursor: pointer;
  border-radius: 5px;
  position: relative;
  transition: var(--tr);
}
.mb-minical__day:hover { background: var(--s2); color: var(--t1); }
.mb-minical__day--other { color: var(--t4); }
.mb-minical__day--today {
  color: var(--np); font-weight: 600;
}
.mb-minical__day--selected {
  background: var(--np); color: #fff !important; font-weight: 600;
}
.mb-minical__day--has-events::after {
  content: ""; position: absolute; bottom: 2px; left: 50%;
  transform: translateX(-50%);
  width: 3px; height: 3px; border-radius: 999px; background: var(--np);
}
.mb-minical__day--selected.mb-minical__day--has-events::after { background: #fff; }

/* ── Sidebar KPI ────────────────────────────────────────────────── */
.mb-cal__kpi {
  padding: 12px 14px;
  background: var(--s1); border: 1px solid var(--b1);
  border-radius: var(--r2);
  display: flex; flex-direction: column; gap: 4px;
}
.mb-cal__kpi-label { font-size: 11px; color: var(--t3); letter-spacing: 0.1px; }
.mb-cal__kpi-value {
  font-size: 20px; font-weight: 600; color: var(--t1);
  font-variant-numeric: tabular-nums;
}
.mb-cal__kpi-sub { font-size: 11.5px; color: var(--t3); }

/* ── Legende ────────────────────────────────────────────────────── */
.mb-cal__legend {
  background: var(--s1); border: 1px solid var(--b1);
  border-radius: var(--r2); padding: 10px 12px;
}
.mb-cal__legend-title {
  font-size: 11px; color: var(--t3); text-transform: uppercase;
  letter-spacing: 0.6px; margin-bottom: 6px;
}
.mb-cal__legend-row {
  display: flex; align-items: center; gap: 8px;
  padding: 3px 0;
  font-size: 12px; color: var(--t2);
}
.mb-cal__legend-dot {
  width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0;
}

/* ── Homebase ───────────────────────────────────────────────────── */
.mb-cal__homebase {
  padding: 10px 12px;
  background: var(--s1); border: 1px solid var(--b1);
  border-radius: var(--r2);
  display: flex; align-items: center; gap: 10px;
  color: var(--t2);
  font-size: 12px;
}
.mb-cal__homebase svg { color: var(--np); flex-shrink: 0; }

/* ══ MAIN VIEW ═══════════════════════════════════════════════════ */
.mb-cal__view {
  background: var(--s1);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  overflow: hidden;
  display: flex; flex-direction: column;
  min-width: 0;
}

/* ── WEEK VIEW ──────────────────────────────────────────────────── */
.mb-cal-week__hd {
  display: grid;
  grid-template-columns: var(--gutter-w) repeat(7, var(--day-col));
  border-bottom: 1px solid var(--b1);
  background: var(--s1);
  position: sticky; top: 0; z-index: 4;
}
.mb-cal-week__dow-cell {
  padding: 10px 8px;
  border-right: 1px solid var(--b1);
  font-size: 11px; font-weight: 500;
  color: var(--t3); letter-spacing: 0.4px;
  text-transform: uppercase;
  display: flex; flex-direction: column; gap: 2px;
  align-items: flex-start;
}
.mb-cal-week__dow-cell:last-child { border-right: 0; }
.mb-cal-week__dow-cell--gutter { padding: 0; border-right: 1px solid var(--b1); }
.mb-cal-week__dom {
  font-size: 15px; font-weight: 600; color: var(--t1);
  letter-spacing: -0.3px;
  text-transform: none;
  font-variant-numeric: tabular-nums;
}
.mb-cal-week__dow-cell--today .mb-cal-week__dom {
  color: var(--np);
}
.mb-cal-week__dow-cell--today {
  background: rgba(200,149,90,0.06);
}

.mb-cal-week__body {
  flex: 1; overflow-y: auto;
  position: relative;
  display: grid;
  grid-template-columns: var(--gutter-w) repeat(7, var(--day-col));
}
.mb-cal-week__gutter {
  position: relative;
  border-right: 1px solid var(--b1);
  height: calc((var(--end-hour) - var(--start-hour)) * var(--px-per-hour));
}
.mb-cal-week__hour-label {
  position: absolute; right: 8px;
  font-size: 10.5px; color: var(--t4);
  font-variant-numeric: tabular-nums;
  transform: translateY(-50%);
}

.mb-cal-week__col {
  position: relative;
  border-right: 1px solid var(--b1);
  height: calc((var(--end-hour) - var(--start-hour)) * var(--px-per-hour));
  background-image:
    linear-gradient(to bottom, var(--b1) 1px, transparent 1px);
  background-size: 100% var(--px-per-hour);
  background-position: 0 0;
}
.mb-cal-week__col:last-child { border-right: 0; }
.mb-cal-week__col--today {
  background-color: rgba(200,149,90,0.04);
}
.mb-cal-week__col--weekend {
  background-color: rgba(0,0,0,0.08);
}
[data-theme="light"] .mb-cal-week__col--weekend {
  background-color: rgba(0,0,0,0.02);
}

/* Now-line */
.mb-cal__now {
  position: absolute; left: 0; right: 0;
  border-top: 1.5px solid var(--na);
  z-index: 3; pointer-events: none;
}
.mb-cal__now::before {
  content: ""; position: absolute;
  left: -4px; top: -5px;
  width: 9px; height: 9px; border-radius: 999px; background: var(--na);
}

/* ── APPOINTMENT block ─────────────────────────────────────────── */
.mb-cal-appt {
  position: absolute;
  left: 3px; right: 3px;
  padding: 5px 8px;
  border-radius: 5px;
  background: var(--s2);
  border-left: 3px solid var(--t3);
  color: var(--t1);
  font-size: 11.5px; line-height: 1.35;
  cursor: grab;
  overflow: hidden;
  transition: var(--tr);
  display: flex; flex-direction: column; gap: 1px;
  z-index: 1;
}
.mb-cal-appt:hover {
  box-shadow: var(--sh2);
  z-index: 2;
}
.mb-cal-appt:active { cursor: grabbing; }
.mb-cal-appt[data-dragging="true"] { opacity: 0.5; }
.mb-cal-appt.is-selected {
  background: var(--t1); color: var(--bg);
  border-left-color: var(--np);
  z-index: 2;
}
.mb-cal-appt__time {
  font-weight: 600; font-size: 11px;
  font-variant-numeric: tabular-nums;
  opacity: 0.8;
}
.mb-cal-appt__title {
  font-weight: 500; font-size: 11.5px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mb-cal-appt__sub {
  font-size: 10.5px; opacity: 0.7;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* Category accents — reuse existing tokens from dashboard or defaults */
.mb-cal-appt[data-category="beauty"]   { border-left-color: var(--cat-beauty, #d4943a); }
.mb-cal-appt[data-category="wellness"] { border-left-color: var(--cat-wellness, #0bbdd6); }
.mb-cal-appt[data-category="auto"]     { border-left-color: var(--cat-auto, #3b9eff); }
.mb-cal-appt[data-category="craft"]    { border-left-color: var(--cat-craft, #c8955a); }
.mb-cal-appt[data-category="pet"]      { border-left-color: var(--cat-pet, #1dd97a); }
.mb-cal-appt[data-category="fitness"]  { border-left-color: var(--cat-fitness, #9b6fd4); }

/* Time-block (Urlaub / Puffer) — diagonal stripes */
.mb-cal-appt--block {
  background: repeating-linear-gradient(
    135deg,
    var(--s2), var(--s2) 6px,
    var(--s3) 6px, var(--s3) 12px
  );
  border-left-color: var(--t3);
  color: var(--t2);
}

/* Conflict overlay */
.mb-cal-appt--conflict {
  box-shadow: 0 0 0 2px rgba(224,82,82,0.4) inset;
}
.mb-cal-appt--conflict::before {
  content: "⚠";
  position: absolute; top: 2px; right: 4px;
  font-size: 10px; color: #e05252;
}

/* Drop target (when dragging) */
.mb-cal-week__col[data-drop-target="true"] {
  background-color: rgba(200,149,90,0.14);
  outline: 2px dashed var(--np);
  outline-offset: -2px;
}

/* ── MONTH VIEW ─────────────────────────────────────────────────── */
.mb-cal-month {
  display: grid;
  grid-template-rows: auto repeat(6, 1fr);
  height: 100%;
  min-height: 520px;
}
.mb-cal-month__dow-hd {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--b1);
}
.mb-cal-month__dow {
  padding: 10px 12px;
  font-size: 11px; font-weight: 500;
  color: var(--t3); letter-spacing: 0.4px;
  text-transform: uppercase;
  border-right: 1px solid var(--b1);
}
.mb-cal-month__dow:last-child { border-right: 0; }

.mb-cal-month__row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--b1);
  min-height: 100px;
}
.mb-cal-month__row:last-child { border-bottom: 0; }
.mb-cal-month__cell {
  position: relative;
  padding: 6px 8px;
  border-right: 1px solid var(--b1);
  display: flex; flex-direction: column; gap: 2px;
  min-height: 0;
  overflow: hidden;
  cursor: pointer;
  transition: var(--tr);
}
.mb-cal-month__cell:last-child { border-right: 0; }
.mb-cal-month__cell:hover { background: var(--s2); }
.mb-cal-month__cell--other { background: var(--bg); color: var(--t4); }
.mb-cal-month__cell--today {
  background: rgba(200,149,90,0.06);
}
.mb-cal-month__cell[data-drop-target="true"] {
  background-color: rgba(200,149,90,0.14);
  outline: 2px dashed var(--np);
  outline-offset: -2px;
}

.mb-cal-month__dom {
  font-size: 12px; font-weight: 500; color: var(--t2);
  font-variant-numeric: tabular-nums;
  margin-bottom: 2px;
  align-self: flex-end;
}
.mb-cal-month__cell--today .mb-cal-month__dom {
  color: #fff;
  background: var(--np);
  width: 20px; height: 20px; border-radius: 999px;
  display: grid; place-items: center;
  font-weight: 600;
}
.mb-cal-month__cell--other .mb-cal-month__dom { color: var(--t4); }

.mb-cal-month__pill {
  display: flex; align-items: center; gap: 5px;
  padding: 2px 6px;
  background: var(--s2); color: var(--t1);
  border-left: 2px solid var(--t3);
  border-radius: 3px;
  font-size: 10.5px; line-height: 1.2;
  cursor: grab;
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}
.mb-cal-month__pill:hover { background: var(--s3); }
.mb-cal-month__pill:active { cursor: grabbing; }
.mb-cal-month__pill[data-category="beauty"]   { border-left-color: var(--cat-beauty, #d4943a); }
.mb-cal-month__pill[data-category="wellness"] { border-left-color: var(--cat-wellness, #0bbdd6); }
.mb-cal-month__pill[data-category="auto"]     { border-left-color: var(--cat-auto, #3b9eff); }
.mb-cal-month__pill[data-category="craft"]    { border-left-color: var(--cat-craft, #c8955a); }
.mb-cal-month__pill[data-category="pet"]      { border-left-color: var(--cat-pet, #1dd97a); }
.mb-cal-month__pill[data-category="fitness"]  { border-left-color: var(--cat-fitness, #9b6fd4); }
.mb-cal-month__pill-time {
  font-weight: 600; font-variant-numeric: tabular-nums; opacity: 0.75;
}
.mb-cal-month__more {
  font-size: 10.5px; color: var(--t3);
  padding: 2px 6px; cursor: pointer;
  background: transparent; border: 0;
  text-align: left;
}
.mb-cal-month__more:hover { color: var(--np); }

/* ── Keyboard shortcuts hint (toolbar) ─────────────────────────── */
.mb-cal__kbd {
  font-family: var(--mono); font-size: 10px;
  padding: 0 5px; border-radius: 4px;
  background: var(--s3); color: var(--t3);
  border: 1px solid var(--b1);
  line-height: 18px;
}

/* ══ RESPONSIVE ══════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .mb-cal { grid-template-columns: 1fr; }
  .mb-cal__sidebar {
    flex-direction: row; flex-wrap: wrap; gap: 8px;
  }
  .mb-cal__sidebar > * { flex: 1 1 240px; }
}
@media (max-width: 768px) {
  .mb-cal { padding: 12px; gap: 10px; }
  .mb-cal__toolbar {
    flex-wrap: wrap; gap: 8px; padding: 8px 10px;
  }
  .mb-cal__title { min-width: 0; font-size: 14px; }
  .mb-cal__search { display: none; }
  .mb-cal-week__hd,
  .mb-cal-week__body {
    --gutter-w: 40px;
  }
  .mb-cal-week__dom { font-size: 13px; }
  .mb-cal-appt__sub { display: none; }
  .mb-cal-month__cell { padding: 4px 5px; min-height: 0; }
  .mb-cal-month__pill { font-size: 10px; padding: 1px 4px; }
  .mb-cal-month__pill-time { display: none; }
}
