/* =========================
   IMPORTS
   ========================= */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap');

/* =========================
   DESIGN TOKENS
   ========================= */
:root {
  /* Core palette */
  --bg:           #f0f2f5;
  --panel:        #ffffff;
  --panel-raised: #ffffff;
  --border:       #e2e6ec;
  --border-focus: #94a3b8;
  --text:         #0f172a;
  --muted:        #64748b;
  --subtle:       #94a3b8;

  /* Brand */
  --accent:       #4f6ef7;
  --accent-hover: #3b56e8;
  --accent-dim:   #e8ecfd;
  --accent-glow:  rgba(79,110,247,0.14);

  /* Semantic */
  --blue:         #4f6ef7;
  --blueH:        #3b56e8;
  --green:        #10b981;
  --greenH:       #059669;
  --red:          #ef4444;
  --redH:         #dc2626;
  --amber:        #f59e0b;
  --gray:         #64748b;
  --grayH:        #475569;

  /* Event pills */
  --pill:         #4f6ef7;
  --pillH:        #3b56e8;
  --pillDim:      #c7d2fe;

  /* State overlays */
  --today-bg:          rgba(79,110,247,0.06);
  --today-border:      rgba(79,110,247,0.30);
  --task-open-bg:      rgba(79,110,247,0.05);
  --task-open-border:  rgba(147,197,253,0.7);
  --task-done-bg:      rgba(16,185,129,0.08);
  --doc-checked-bg:    rgba(16,185,129,0.07);

  /* Elevation */
  --shadow-xs: 0 1px 2px rgba(15,23,42,.06);
  --shadow-sm: 0 2px 8px rgba(15,23,42,.08), 0 0 0 1px rgba(15,23,42,.04);
  --shadow-md: 0 8px 24px rgba(15,23,42,.10), 0 0 0 1px rgba(15,23,42,.04);
  --shadow-lg: 0 20px 48px rgba(15,23,42,.14), 0 0 0 1px rgba(15,23,42,.05);

  /* Radii */
  --r-xs: 6px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-pill: 999px;

  /* Typography */
  --font: 'DM Sans', system-ui, -apple-system, sans-serif;
  --font-mono: 'DM Mono', 'Menlo', monospace;
  --font-size-base: 13.5px;

  /* Spacing rhythm */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
}

/* =========================
   RESET & BASE
   ========================= */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  font-family: var(--font);
  font-size: var(--font-size-base);
  line-height: 1.5;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.muted { color: var(--muted); }

/* =========================
   TOP BAR
   ========================= */
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
  gap: 12px;
  position: sticky;
  top: 0;
  z-index: 40;
}

.left,
.right {
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
}

.month-title {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
  min-width: 160px;
  text-align: center;
}

/* =========================
   SEARCH
   ========================= */
.search,
#eventSearchWrap {
  position: relative;
  flex: 1;
  max-width: 480px;
  margin: 0 8px;
  width: 100%;
}

.search { display: flex; align-items: center; gap: 8px; }
.search-box { position: relative; flex: 1; min-width: 0; }
.btn-weekend { white-space: nowrap; }

.search-input,
#eventSearchInput {
  width: 100%;
  padding: 8px 14px;
  border-radius: var(--r-md);
  border: 1.5px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  outline: none;
  transition: border-color .15s, box-shadow .15s, background .15s;
}

.search-input::placeholder,
#eventSearchInput::placeholder {
  color: var(--subtle);
  font-weight: 400;
}

.search-input:focus,
#eventSearchInput:focus {
  border-color: var(--accent);
  background: var(--panel);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.search-results,
#searchResults {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--panel);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  max-height: 320px;
  overflow-y: auto;
}

.search-item {
  padding: 10px 14px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  border-top: 1px solid var(--border);
  transition: background .1s;
}
.search-item:first-child { border-top: 0; }
.search-item:hover { background: var(--accent-dim); }

.search-item .si-title {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text);
}

.search-item .si-date {
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  color: var(--muted);
}

.search-empty {
  padding: 12px 14px;
  color: var(--muted);
  font-size: 13px;
}

.search-pop {
  animation: searchPop .55s ease-in-out 0s 2;
  transform-origin: center;
}

@keyframes searchPop {
  0%  { transform: scale(1); }
  35% { transform: scale(1.06); }
  100%{ transform: scale(1); }
}

.search-selected {
  animation: searchSelect 1.1s ease-in-out 0s 1;
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

@keyframes searchSelect {
  0%  { transform: scale(1); }
  25% { transform: scale(1.08); }
  100%{ transform: scale(1); }
}

@media (max-width: 980px) { .search { max-width: 320px; } }
@media (max-width: 780px) { .search { display: none; } }

/* =========================
   BUTTONS
   ========================= */
.btn {
  border: 0;
  border-radius: var(--r-sm);
  padding: 7px 14px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  color: #fff;
  transition: background .12s, transform .06s, box-shadow .12s;
  box-shadow: var(--shadow-xs);
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); box-shadow: none; }
.btn:disabled { opacity: .4; cursor: not-allowed; transform: none; }

.btn-blue  { background: var(--blue);  }
.btn-blue:hover  { background: var(--blueH); }
.btn-green { background: var(--green); }
.btn-green:hover { background: var(--greenH); }
.btn-red   { background: var(--red);   }
.btn-red:hover   { background: var(--redH); }
.btn-gray  { background: transparent; border: 1.5px solid var(--border); color: var(--text); box-shadow: none; }
.btn-gray:hover  { background: var(--bg); border-color: var(--border-focus); }

/* Small icon button */
.btn-x {
  border: 1.5px solid transparent;
  background: transparent;
  color: var(--muted);
  width: 28px;
  height: 28px;
  border-radius: var(--r-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 0;
  transition: background .12s, border-color .12s, color .12s, transform .06s;
}
.btn-x:hover {
  background: rgba(239,68,68,.08);
  border-color: rgba(239,68,68,.2);
  color: var(--red);
}
.btn-x:active { transform: translateY(1px); }

/* =========================
   LAYOUT
   ========================= */
.main { padding: 0 14px 14px; }

.split {
  display: flex;
  gap: 0;
  height: calc(100vh - 57px);
}

.pane {
  background: var(--panel);
  border: 1.5px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
  min-width: 280px;
  box-shadow: var(--shadow-xs);
}

.calendar-pane {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}

.right-pane {
  width: 400px;
  min-width: 300px;
  max-width: 680px;
  display: flex;
  flex-direction: column;
}

.gutter {
  width: 10px;
  cursor: col-resize;
  margin: 0 8px;
  border-radius: var(--r-pill);
  transition: background .15s;
}
.gutter:hover { background: var(--accent-glow); }

/* =========================
   STATUS FILTER PANE
   ========================= */
.status-filter-pane {
  width: 210px;
  min-width: 210px;
  max-width: 250px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.status-filter-pane .filter-toggle {
  margin-left: auto;
  width: 26px;
  height: 38px;
  border-radius: var(--r-pill);
  border: 1.5px solid var(--border);
  background: var(--panel);
  font-size: 12px;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .12s, box-shadow .12s, background .12s;
  color: var(--muted);
}
.filter-toggle:hover {
  transform: translateX(-1px);
  box-shadow: var(--shadow-md);
  color: var(--accent);
}
.filter-toggle:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.status-filter-inner {
  padding: 12px;
  overflow: auto;
  flex: 1;
}

.status-filter-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.status-filter-title {
  font-weight: 700;
  font-size: 11px;
  color: var(--muted);
  letter-spacing: .06em;
  text-transform: uppercase;
}

.status-filter-actions { display: flex; gap: 6px; }

.btn-filter-small {
  padding: 5px 9px;
  border-radius: var(--r-sm);
  font-size: 11px;
}

.status-filter-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.status-filter-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  background: transparent;
  transition: background .1s, border-color .1s;
  cursor: pointer;
}
.status-filter-item:hover { background: var(--accent-dim); border-color: rgba(79,110,247,.25); }

.status-filter-item input[type="checkbox"] {
  transform: scale(1.15);
  cursor: pointer;
  accent-color: var(--accent);
}

.status-filter-label {
  font-weight: 600;
  font-size: 12.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.status-filter-pane.collapsed {
  width: 32px;
  min-width: 32px;
  max-width: 32px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.status-filter-pane.collapsed .status-filter-head { margin: 0; padding: 0; justify-content: center; }
.status-filter-pane.collapsed .status-filter-title,
.status-filter-pane.collapsed .status-filter-actions,
.status-filter-pane.collapsed #statusFilterList { display: none; }
.status-filter-pane.collapsed .filter-toggle { margin-left: 0; }
.status-filter-pane.collapsed .status-filter-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  overflow: hidden;
}
.status-filter-pane.collapsed .status-filter-head { width: 100%; justify-content: center; }

.status-hidden { display: none !important; }

/* =========================
   CALENDAR
   ========================= */
.dow {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  padding: 10px 14px 8px;
  border-bottom: 1px solid var(--border);
  color: var(--muted);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.dow > div { text-align: center; }

.calendar-pane.weekend-narrow .dow {
  grid-template-columns: minmax(0,.2fr) repeat(5,minmax(0,1fr)) minmax(0,.2fr);
}
.calendar-pane.weekend-narrow .grid {
  grid-template-columns: minmax(0,.2fr) repeat(5,minmax(0,1fr)) minmax(0,.2fr);
}

.calendar { padding: 10px 12px; overflow: auto; flex: 1; }

.grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 4px;
}

.day {
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  padding: 6px;
  min-height: 112px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: box-shadow .12s, border-color .12s, background .12s;
  min-width: 0;
  overflow: hidden;
  background: var(--panel);
}
.day:hover {
  border-color: rgba(79,110,247,.3);
  box-shadow: 0 2px 12px var(--accent-glow);
}
.day.dim { opacity: .45; }

.day-head {
  display: flex;
  justify-content: flex-end;
  font-weight: 600;
  font-size: 12px;
  color: var(--muted);
  padding-right: 2px;
}

.events {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  overflow: hidden;
}

/* PILLS */
.pill {
  background: var(--pill);
  color: #fff;
  border-radius: var(--r-xs);
  padding: 3px 4px 3px 5px;
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  user-select: none;
  transition: background .1s, transform .1s, box-shadow .1s;
  display: flex;
  align-items: center;
  gap: 2px;
  min-width: 0;
  overflow: hidden;
}
.pill-icons {
  display: inline-flex;
  align-items: center;
  gap: 0;
  flex: 0 0 auto;
  width: 24px;
  min-width: 24px;
}
.pill-icon { font-size: 11px; line-height: 1; opacity: .95; }
.pill-icon-doc.none  { color: rgba(255,255,255,.45); }
.pill-icon-doc.open  { color: #fff; }
.pill-icon-task.none { color: rgba(255,255,255,.45); }
.pill-icon-task.open { color: #fff; }
.pill-icon-doc .doc-svg { width: 12px; height: 12px; display: block; }

.pill-title {
  flex: 1 1 auto;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pill:hover {
  background: var(--pillH);
  transform: translateY(-1px);
  box-shadow: 0 3px 8px rgba(79,110,247,.28);
}
.pill.dim { background: var(--pillDim); color: #4f6ef7; cursor: default; }
.pill.search-hit {
  animation: searchPop .35s ease-in-out;
  box-shadow: 0 0 0 2px rgba(79,110,247,.4);
}

.day.today {
  background: var(--today-bg);
  border-color: var(--today-border);
}
.day.today .day-head {
  color: var(--accent);
  font-weight: 700;
}

/* =========================
   RIGHT PANE: EVENT HEADER
   ========================= */
.event-header {
  padding: 16px 16px 0;
  border-bottom: 1px solid var(--border);
  padding-bottom: 12px;
}
.event-title { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; }
.event-meta { margin-top: 2px; color: var(--muted); font-size: 12px; }

/* =========================
   TASK BAR / CONTROLS
   ========================= */
.taskbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 10px 14px;
}
.taskbar input {
  padding: 7px 11px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-family: var(--font);
  font-size: 13px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  background: var(--bg);
  color: var(--text);
}
.taskbar input:focus {
  border-color: var(--accent);
  background: var(--panel);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.event-actions {
  display: flex;
  gap: 8px;
  padding: 10px 14px;
  flex-wrap: wrap;
  align-items: center;
}

/* Notes button */
.btn-notes {
  min-width: 76px;
  padding: 7px 12px;
  font-weight: 600;
  border-radius: var(--r-sm);
}
.btn-notes.no-note {
  background: transparent;
  border: 1.5px dashed var(--border);
  color: var(--muted);
  box-shadow: none;
}
.btn-notes.no-note:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.btn-notes.has-note {
  background: rgba(16,185,129,.10);
  border: 1.5px solid rgba(16,185,129,.3);
  color: #065f46;
}
.btn-notes:disabled { opacity: .45; cursor: not-allowed; }

/* Event Notes modal */
.note-textarea {
  width: 100%;
  min-height: 280px;
  resize: vertical;
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  padding: 12px 14px;
  font-family: var(--font);
  font-size: 13.5px;
  line-height: 1.55;
  outline: none;
  background: var(--bg);
  color: var(--text);
  transition: border-color .15s, box-shadow .15s;
}
.note-textarea:focus {
  border-color: var(--accent);
  background: var(--panel);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.note-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.note-actions { display: flex; gap: 8px; align-items: center; }

.select {
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 7px 11px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  background: var(--bg);
  color: var(--text);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  cursor: pointer;
}
.select:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.select:disabled { opacity: .5; cursor: not-allowed; }

/* =========================
   TASKS LIST
   ========================= */
.tasks {
  padding: 10px 14px 14px;
  overflow: auto;
  flex: 1;
  border-top: 1px solid var(--border);
}

.task {
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  padding: 8px 10px;
  margin-bottom: 6px;
  background: var(--panel);
  transition: box-shadow .12s, border-color .12s;
}
.task:not(.done) {
  background: var(--task-open-bg);
  border-color: var(--task-open-border);
}

.task-top {
  display: grid;
  grid-template-columns: auto auto 1fr auto;
  gap: 8px;
  align-items: center;
}

/* drag handle */
.task-handle {
  width: 16px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-xs);
  color: var(--subtle);
  cursor: grab;
  user-select: none;
  transition: background .1s, color .1s;
}
.task-handle:hover { background: var(--accent-dim); color: var(--accent); }
.task-handle:active { cursor: grabbing; }
.task.dragging { opacity: .5; }

.task-group-sep {
  margin: 8px 0 10px;
  font-size: 11px;
  color: var(--muted);
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.task-top input[type="checkbox"] {
  transform: scale(1.3);
  transform-origin: left center;
  cursor: pointer;
  accent-color: var(--accent);
}

.task-top input[type="text"] {
  width: 100%;
  padding: 5px 8px;
  border: 1.5px solid transparent;
  border-radius: var(--r-sm);
  font-family: var(--font);
  font-size: 13px;
  background: transparent;
  color: var(--text);
  transition: border-color .15s, background .15s;
  outline: none;
}
.task-top input[type="text"]:hover { border-color: var(--border); background: var(--panel); }
.task-top input[type="text"]:focus { border-color: var(--accent); background: var(--panel); box-shadow: 0 0 0 3px var(--accent-glow); }

.task-note {
  margin-top: 4px;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.task-note textarea {
  font-family: var(--font);
  width: 100%;
  min-height: 32px;
  resize: vertical;
  padding: 6px 9px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg);
  color: var(--text);
  font-size: 12.5px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.task-note textarea:focus {
  border-color: var(--accent);
  background: var(--panel);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.task-note.collapsed { align-items: center; }
.task-note.collapsed textarea { display: none; }

.task.done {
  border-color: rgba(16,185,129,.35);
  background: var(--task-done-bg);
}
.task.done .task-top input[type="text"] {
  color: #065f46;
  text-decoration: line-through;
  opacity: .85;
}

.note-plus {
  border: 1.5px dashed var(--border);
  background: transparent;
  color: var(--muted);
  width: 22px;
  height: 22px;
  border-radius: var(--r-xs);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .12s, color .12s, border-color .12s;
}
.note-plus:hover {
  background: var(--accent-dim);
  color: var(--accent);
  border-color: var(--accent);
}

/* =========================
   STATUS PILL OVERRIDES
   ========================= */
.pill.status-ready {
  background: #10b981 !important;
  color: #fff !important;
}
.pill.status-ready:hover { background: #059669 !important; }

.pill.status-progress {
  background: #7c3aed !important;
  color: #fff !important;
}
.pill.status-progress:hover { background: #6d28d9 !important; }

.pill.status-attention {
  background: #ef4444 !important;
  color: #fff !important;
}
.pill.status-attention:hover { background: #dc2626 !important; }

.pill.status-complete {
  background: rgba(16,185,129,.2) !important;
  color: #065f46 !important;
  text-decoration: line-through;
  opacity: .85;
}

/* =========================
   SUMMARY BAR
   ========================= */
.summarybar {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: start;
  padding: 0 14px 10px;
}
.summarybar textarea {
  width: 100%;
  min-height: 52px;
  max-height: 120px;
  resize: vertical;
  padding: 7px 10px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-family: var(--font);
  font-size: 13px;
  line-height: 1.45;
  background: var(--bg);
  color: var(--text);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.summarybar textarea:focus {
  border-color: var(--accent);
  background: var(--panel);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.summarybar textarea:disabled { opacity: .5; cursor: not-allowed; }
.summarybar label { font-size: 12px; font-weight: 600; color: var(--muted); padding-top: 8px; }

/* =========================
   FOOTER / MENU
   ========================= */
.footer {
  border-top: 1px solid var(--border);
  padding: 8px 14px;
  background: var(--bg);
}
.footer .muted { font-size: 11.5px; }

.menu {
  position: fixed;
  background: var(--panel);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  padding: 6px;
  z-index: 1000;
  width: 186px;
}
.menu.hidden { display: none; }
.menu button {
  width: 100%;
  background: transparent;
  border: 0;
  text-align: left;
  padding: 8px 10px;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  transition: background .1s;
}
.menu button:hover { background: var(--accent-dim); color: var(--accent); }
.menu .danger:hover { background: rgba(239,68,68,.08); color: var(--red); }

/* =========================
   UPDATE BANNER
   ========================= */
.update-banner { display: none !important; }
.update-banner.hidden { display: none; }

.link-btn {
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  font-weight: 700;
  cursor: pointer;
  color: var(--red);
  text-decoration: underline;
}

/* =========================
   TOOLTIP
   ========================= */
.tooltip {
  position: fixed;
  max-width: 240px;
  padding: 7px 10px;
  background: var(--text);
  color: #fff;
  font-size: 12px;
  line-height: 1.35;
  border-radius: var(--r-sm);
  box-shadow: var(--shadow-md);
  z-index: 2000;
  pointer-events: none;
  opacity: 0;
  transition: opacity .12s;
}
.tooltip.show { opacity: 1; }

/* =========================
   UPCOMING TASKS VIEW
   ========================= */
.right-pane.upcoming .event-actions,
.right-pane.upcoming .summarybar,
.right-pane.upcoming .taskbar { display: none; }

.upcoming-wrap {
  padding: 12px 14px 14px;
  overflow: auto;
  flex: 1;
  border-top: 1px solid var(--border);
}

.upcoming-date {
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 16px 0 8px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--border);
}

.upcoming-event {
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  padding: 10px;
  margin-bottom: 8px;
  background: var(--panel);
  transition: box-shadow .12s;
}
.upcoming-event:hover { box-shadow: var(--shadow-sm); }

.upcoming-event-head {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: stretch;
  margin-bottom: 8px;
}

.upcoming-event-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  line-height: 1.2;
  min-width: 0;
}

.upcoming-event-title-text {
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.upcoming-notes-btn {
  border: 1.5px solid rgba(255,255,255,.3);
  background: rgba(255,255,255,.12);
  color: inherit;
  width: 24px;
  height: 24px;
  border-radius: var(--r-pill);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 1;
  flex: 0 0 auto;
  transition: background .1s;
}
.upcoming-notes-btn:hover { background: rgba(255,255,255,.22); }
.upcoming-notes-btn:active { transform: translateY(1px); }

.upcoming-event-subrow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.upcoming-event-status-small {
  font-size: 11.5px;
  color: var(--muted);
  font-weight: 600;
  white-space: nowrap;
}

.upcoming-event-title {
  font-weight: 700;
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--r-sm);
  line-height: 1.2;
}

.upcoming-event-meta { font-size: 12px; color: var(--muted); white-space: nowrap; }

.upcoming-event-titlewrap { display: flex; align-items: baseline; gap: 10px; }

.upcoming-event-status {
  font-size: 11px;
  padding: 2px 7px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: var(--r-pill);
  white-space: nowrap;
}

.upcoming-event-summary {
  margin: -2px 0 8px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
  white-space: pre-wrap;
}

.upcoming-task {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
  padding: 6px 0;
  border-top: 1px solid var(--border);
}
.upcoming-task:first-of-type { border-top: 0; }
.upcoming-task label { font-weight: 400; font-size: 13px; }
.upcoming-task input[type="checkbox"] { transform: scale(1.3); transform-origin: left center; cursor: pointer; accent-color: var(--accent); }

.upcoming-task.done {
  background: var(--task-done-bg);
  border-radius: var(--r-sm);
  padding-left: 8px;
  padding-right: 8px;
}
.upcoming-task.done label { color: #065f46; text-decoration: line-through; opacity: .85; }

.upcoming-task-note {
  grid-column: 1 / -1;
  margin-left: 34px;
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
  white-space: pre-wrap;
}

/* =========================
   MODAL
   ========================= */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,.4);
  backdrop-filter: blur(3px);
  z-index: 5000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}

.modal-card {
  width: min(960px, 96vw);
  max-height: min(720px, 92vh);
  background: var(--panel);
  border: 1.5px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
#dlModal .modal-card { width: min(1300px, 96vw); }

.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}

.modal-title { font-weight: 700; font-size: 15px; letter-spacing: -0.01em; }

.modal-body {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 0;
  flex: 1;
  min-height: 0;
}

.tl-left {
  border-right: 1px solid var(--border);
  padding: 12px;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: var(--bg);
}

.tl-left-actions { display: flex; gap: 8px; margin-bottom: 10px; }

.tl-list {
  overflow: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.tl-list .tl-rowbtn {
  width: 100%;
  background: transparent;
  border: 0;
  text-align: left;
  padding: 9px 11px;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  transition: background .1s, color .1s;
}
.tl-list .tl-rowbtn:hover { background: var(--accent-dim); color: var(--accent); }
.tl-list .tl-rowbtn.active { background: var(--accent-dim); color: var(--accent); font-weight: 600; }

.tl-right { padding: 14px; display: flex; flex-direction: column; min-height: 0; }

.tl-form {
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  padding: 10px 12px;
  margin-bottom: 12px;
  background: var(--bg);
}

.tl-input {
  width: 100%;
  padding: 8px 10px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-family: var(--font);
  font-size: 13px;
  background: var(--panel);
  color: var(--text);
  outline: none;
  margin-top: 6px;
  transition: border-color .15s, box-shadow .15s;
}
.tl-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }

.tl-row { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }

.tl-items {
  flex: 1;
  min-height: 0;
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  padding: 10px;
  overflow: auto;
  background: var(--bg);
}

.tl-add-item { display: grid; grid-template-columns: 1fr auto; gap: 8px; margin: 10px 0; }

.tl-items-list .tl-item {
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 7px 9px;
  margin-bottom: 6px;
  display: flex;
  gap: 8px;
  align-items: center;
  background: var(--panel);
  transition: box-shadow .12s;
}
.tl-items-list .tl-item:hover { box-shadow: var(--shadow-xs); }

.list-move { display: flex; flex-direction: column; gap: 3px; flex: 0 0 auto; }

.btn-move {
  border: 1.5px solid var(--border);
  background: var(--panel);
  color: var(--muted);
  width: 22px;
  height: 18px;
  border-radius: var(--r-xs);
  padding: 0;
  cursor: pointer;
  font-size: 9px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .12s, border-color .12s, color .12s, transform .06s;
}
.btn-move:hover:not(:disabled) { background: var(--accent-dim); border-color: rgba(79,110,247,.35); color: var(--accent); }
.btn-move:active:not(:disabled) { transform: translateY(1px); }
.btn-move:disabled { opacity: .3; cursor: not-allowed; }

.tl-item input {
  flex: 1;
  padding: 7px 10px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-family: var(--font);
  font-size: 13px;
  outline: none;
  background: var(--bg);
  color: var(--text);
}
.tl-item input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }

.modal-foot {
  border-top: 1px solid var(--border);
  padding: 10px 14px;
  background: var(--bg);
}

.modal.hidden { display: none; }

/* =========================
   DOCUMENT LISTS (MODAL)
   ========================= */
.dl-add-item { display: grid; grid-template-columns: 1fr auto; gap: 8px; margin: 10px 0; }
.dt-add-item { display: grid; grid-template-columns: 1fr 1fr auto; gap: 8px; margin: 10px 0; }

.dl-items-list .dl-item {
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 6px 8px;
  margin-bottom: 5px;
  display: grid;
  grid-template-columns: auto auto 1fr 1.2fr auto;
  gap: 8px;
  align-items: center;
  background: var(--panel);
  transition: background .1s, border-color .1s;
}

.dl-item input[type="checkbox"] { transform: scale(1.3); transform-origin: left center; cursor: pointer; accent-color: var(--accent); }

.dl-item input[type="text"] {
  width: 100%;
  padding: 5px 8px;
  font-size: 12.5px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-xs);
  font-family: var(--font);
  outline: none;
  background: var(--bg);
  color: var(--text);
}
.dl-item input[type="text"]:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }

.dl-item .dl-note {
  width: 100%;
  padding: 5px 8px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-xs);
  font-family: var(--font);
  font-size: 12.5px;
  background: var(--bg);
  color: var(--text);
  outline: none;
}
.dl-item .dl-note:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }

.dl-item.checked {
  background: var(--doc-checked-bg);
  border-color: rgba(16,185,129,.3);
}
.dl-item.checked input[type="text"] { color: #065f46; text-decoration: line-through; opacity: .9; }

/* =========================
   UPCOMING: HEADER TOGGLE
   ========================= */
.upcoming-title-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.upcoming-toggle { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: var(--muted); user-select: none; }
.upcoming-toggle input { transform: scale(1.1); cursor: pointer; accent-color: var(--accent); }

/* Clickable pill icon */
.pill-icon-link { border: 0; background: transparent; padding: 0; margin: 0; cursor: pointer; line-height: 1; }
.pill-icon-link:hover { filter: brightness(.88); }
.pill-icon-link:active { transform: translateY(1px); }

/* Focus icon on event pill */
.pill-focus {
  border: 0;
  background: transparent;
  padding: 0 2px;
  margin-left: 4px;
  cursor: pointer;
  line-height: 1;
  font-size: 12px;
  opacity: .5;
  color: rgba(255,255,255,.9);
}
.pill:hover .pill-focus { opacity: .9; }
.pill-focus:active { transform: translateY(1px); }

/* Focus modal */
#focusModal .modal-card { width: min(1520px, 96vw); max-height: min(880px, 92vh); }
.focus-body { display: grid; grid-template-columns: 1fr 390px; gap: 16px; padding: 16px; overflow: auto; }
.focus-section { border: 1.5px solid var(--border); border-radius: var(--r-lg); background: var(--bg); padding: 12px; }
.focus-h2 { font-weight: 700; margin-bottom: 8px; font-size: 14px; }
.focus-text { white-space: pre-wrap; color: var(--text); line-height: 1.45; font-size: 13px; }
.focus-text.muted-empty { color: var(--muted); }
.focus-list { display: flex; flex-direction: column; gap: 6px; }

.focus-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: flex-start;
  padding: 8px 10px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--panel);
  transition: box-shadow .12s;
}
.focus-item input[type="checkbox"] { transform: scale(1.2); transform-origin: left top; cursor: pointer; margin-top: 2px; accent-color: var(--accent); }
.focus-item .fi-title { font-weight: 600; line-height: 1.25; font-size: 13px; }
.focus-item .fi-note { margin-top: 3px; color: var(--muted); font-size: 12px; line-height: 1.35; white-space: pre-wrap; }
.focus-item.done { opacity: .6; }

.focus-docs { display: grid; grid-template-columns: 220px 1fr; gap: 10px; min-height: 240px; }
.focus-doclists { border-right: 1px solid var(--border); padding-right: 10px; display: flex; flex-direction: column; gap: 6px; overflow: auto; max-height: 340px; }
.focus-docbtn {
  width: 100%;
  text-align: left;
  border: 1.5px solid var(--border);
  background: var(--panel);
  border-radius: var(--r-sm);
  padding: 9px 11px;
  cursor: pointer;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  transition: background .1s, color .1s;
}
.focus-docbtn:hover { background: var(--accent-dim); color: var(--accent); }
.focus-docbtn.active { background: var(--accent-dim); border-color: rgba(79,110,247,.35); color: var(--accent); font-weight: 600; }

/* Event actions menu */
.event-actions { position: relative; display: flex; align-items: center; gap: 8px; }

.icon-btn {
  width: 34px;
  height: 34px;
  border: 1.5px solid var(--border);
  background: var(--panel);
  border-radius: var(--r-sm);
  font-size: 16px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--muted);
  transition: background .12s, border-color .12s, color .12s, box-shadow .12s;
}
.icon-btn:disabled { opacity: .4; cursor: default; }
.icon-btn:not(:disabled):hover { background: var(--bg); border-color: var(--border-focus); color: var(--text); }

.event-actions-menu {
  position: absolute;
  top: 42px;
  right: 0;
  background: var(--panel);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  padding: 8px;
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: 6px;
  z-index: 50;
  min-width: 210px;
}
.event-actions-menu .btn { width: 100%; }

/* Top-right menu */
.top-actions { position: relative; display: flex; align-items: center; }
.top-menu-btn { background: var(--accent); border-color: var(--accent-hover); color: #fff; }
.top-menu-btn:hover { background: var(--accent-hover); }

.top-actions-menu {
  position: absolute;
  top: 42px;
  right: 0;
  background: var(--panel);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  padding: 6px;
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: 2px;
  z-index: 80;
  min-width: 210px;
}

.top-actions-menu .menu-item {
  width: 100%;
  text-align: left;
  padding: 9px 12px;
  border: 0;
  background: transparent;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-family: var(--font);
  font-size: 13px;
  color: var(--text);
  font-weight: 500;
  transition: background .1s, color .1s;
}
.top-actions-menu .menu-item:hover { background: var(--accent-dim); color: var(--accent); }
.top-actions-menu .menu-item:active { background: var(--accent-dim); }
.top-actions-menu .menu-sep { height: 1px; background: var(--border); margin: 4px 6px; }
.top-actions-menu .btn { width: 100%; }

/* Ensure hidden always wins */
[hidden] { display: none !important; }
.hidden { display: none !important; }

/* =========================
   SETTINGS MODAL
   ========================= */
.modal-card-wide { max-width: 1040px; width: 92vw; }
.settings-body { display: flex; gap: 16px; min-height: 520px; }
.settings-left { width: 230px; min-width: 210px; border-right: 1px solid var(--border); padding-right: 12px; }
.settings-nav { display: flex; flex-direction: column; gap: 4px; }
.settings-navbtn {
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  border-radius: var(--r-sm);
  padding: 9px 11px;
  cursor: pointer;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  transition: background .1s, color .1s;
}
.settings-navbtn:hover { background: var(--accent-dim); color: var(--accent); }
.settings-navbtn.active { background: var(--accent-dim); color: var(--accent); font-weight: 700; }
.settings-right { flex: 1; min-width: 0; padding: 2px 4px 2px 2px; }
.settings-panel.hidden { display: none; }
.settings-panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 12px; }
.settings-h1 { font-size: 16px; font-weight: 700; margin-bottom: 4px; letter-spacing: -0.01em; }
.settings-tablewrap { border: 1.5px solid var(--border); border-radius: var(--r-lg); overflow: auto; background: var(--bg); }
.settings-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.settings-table thead th { position: sticky; top: 0; background: var(--panel); z-index: 2; text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--border); font-size: 11px; color: var(--muted); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.settings-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.settings-table tr:last-child td { border-bottom: 0; }
.settings-table input[type='text'] { width: 100%; padding: 7px 10px; border: 1.5px solid var(--border); border-radius: var(--r-sm); font-family: var(--font); outline: none; background: var(--panel); color: var(--text); }
.settings-table input[type='text']:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.settings-table input[type='color'] { width: 40px; height: 32px; border: 1.5px solid var(--border); border-radius: var(--r-sm); padding: 0; background: var(--panel); cursor: pointer; }
.settings-style-dropdown { position: relative; min-width: 170px; }
.settings-style-toggle { list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 8px 11px; border: 1.5px solid var(--border); border-radius: var(--r-sm); background: var(--panel); font-size: 12px; font-weight: 600; color: var(--text); cursor: pointer; user-select: none; }
.settings-style-toggle::-webkit-details-marker { display: none; }
.settings-style-toggle::after { content: '▾'; font-size: 10px; color: var(--muted); }
.settings-style-dropdown[open] .settings-style-toggle { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.settings-style-dropdown[open] .settings-style-toggle::after { content: '▴'; }
.settings-style-count { color: var(--muted); font-weight: 500; }
.settings-stylebits { position: absolute; top: calc(100% + 6px); left: 0; z-index: 5; min-width: 210px; display: grid; gap: 6px; padding: 10px; border: 1.5px solid var(--border); border-radius: var(--r-md); background: var(--panel); box-shadow: var(--shadow-md); }
.settings-stylebits label { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: var(--muted); user-select: none; }
.settings-stylebits input[type='checkbox'] { transform: scale(1.1); cursor: pointer; accent-color: var(--accent); }
.settings-actions { display: flex; gap: 8px; justify-content: flex-end; flex-wrap: wrap; }
.settings-formgrid { display: grid; grid-template-columns: repeat(3, minmax(180px,1fr)); gap: 12px; }
.settings-field { border: 1.5px solid var(--border); border-radius: var(--r-md); padding: 12px; background: var(--panel); }
.settings-field input[type='color'] { width: 52px; height: 34px; border: 1.5px solid var(--border); border-radius: var(--r-sm); cursor: pointer; padding: 0; }
.settings-row { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }

.settings-formgrid--stack { grid-template-columns: 1fr; }
.settings-field--task-color label { display: block; margin-bottom: 10px; line-height: 1.25; }
.settings-field--task-color input[type='color'] { display: block; margin-left: auto; }

.account-mgmt-layout { display: flex; flex-direction: column; gap: 12px; }
.account-add-card { padding: 16px; background: var(--bg); border-radius: var(--r-lg); border: 1.5px solid var(--border); }
.account-add-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.account-admin-notice { white-space: nowrap; }
.account-add-grid { display: grid; grid-template-columns: minmax(220px,1fr) minmax(240px,1fr) auto; gap: 12px; align-items: end; }
.account-add-field { display: flex; flex-direction: column; gap: 8px; padding: 12px; border: 1.5px solid var(--border); border-radius: var(--r-md); background: var(--panel); }
.account-add-field input { width: 100%; padding: 9px 11px; border: 1.5px solid var(--border); border-radius: var(--r-sm); font-family: var(--font); outline: none; background: var(--bg); color: var(--text); }
.account-add-field input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.account-add-actions { display: flex; align-items: stretch; }
.account-add-actions .btn { min-width: 120px; }
.account-subnav { display: flex; gap: 6px; }
.account-subnav-btn { border: 1.5px solid var(--border); background: var(--panel); color: var(--text); border-radius: var(--r-sm); padding: 7px 12px; font-family: var(--font); font-size: 13px; font-weight: 500; cursor: pointer; }
.account-subnav-btn.active { background: var(--accent-dim); border-color: rgba(79,110,247,.35); color: var(--accent); }
.settings-field input[type='email'] { width: 100%; padding: 7px 10px; border: 1.5px solid var(--border); border-radius: var(--r-sm); font-family: var(--font); outline: none; }
.account-user-status { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: var(--r-pill); font-size: 11.5px; font-weight: 700; }
.account-user-status.is-active   { background: rgba(16,185,129,.12); color: #065f46; }
.account-user-status.is-pending  { background: rgba(245,158,11,.12); color: #92400e; }
.account-user-status.is-suspended{ background: rgba(239,68,68,.12);  color: #991b1b; }
.account-user-name { font-weight: 700; margin-bottom: 4px; }
.account-user-meta { display: flex; gap: 6px; flex-wrap: wrap; }
.account-role-badge { display: inline-flex; align-items: center; padding: 3px 8px; border-radius: var(--r-pill); font-size: 11px; font-weight: 700; }
.account-role-badge.is-super { background: rgba(124,58,237,.12); color: #6d28d9; }
.account-role-badge.is-admin { background: rgba(79,110,247,.12); color: #3b56e8; }
.account-actions { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.account-status-select { min-width: 140px; padding: 8px 11px; border: 1.5px solid var(--border); border-radius: var(--r-sm); font-family: var(--font); outline: none; background: var(--panel); color: var(--text); font-weight: 500; }
.account-status-select:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.account-status-select:disabled { opacity: .65; cursor: not-allowed; }
.btn-account-invite, .btn-account-delete { white-space: nowrap; }
.btn-account-delete { background: transparent; border: 1.5px solid rgba(239,68,68,.25); color: var(--red); box-shadow: none; }
.btn-account-delete:hover { background: rgba(239,68,68,.08); border-color: var(--red); }
.auth-help { line-height: 1.45; margin-top: 2px; font-size: 12px; color: var(--muted); }
@media (max-width: 900px) {
  .settings-body { flex-direction: column; }
  .settings-left { width: auto; border-right: 0; border-bottom: 1px solid var(--border); padding-bottom: 10px; padding-right: 0; }
  .settings-formgrid { grid-template-columns: 1fr; }
  .account-add-grid { grid-template-columns: 1fr; }
  .account-admin-notice { white-space: normal; }
}

/* =========================
   EVENT NOTES MODAL
   ========================= */
#eventNoteModal .modal-card { width: min(520px, 96vw); max-height: min(580px, 92vh); }
#eventNoteModal .modal-body { display: block; }
#eventNoteModal .note-textarea { width: 100%; min-height: 200px; }

.btn-save { background: var(--accent); }
.btn-save:hover { background: var(--accent-hover); }

/* =========================
   PARKED EVENTS
   ========================= */
.right-pane.parked .event-actions,
.right-pane.parked .summarybar,
.right-pane.parked .taskbar { display: none; }

.parked-wrap { display: flex; flex-direction: column; gap: 10px; padding: 10px 0; }

.parked-drop {
  border: 2px dashed var(--border);
  border-radius: var(--r-md);
  padding: 12px;
  background: var(--bg);
  transition: border-color .15s, background .15s;
}
.parked-drop.dragover { border-color: rgba(79,110,247,.45); background: var(--accent-dim); }
.parked-drop-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.parked-drop-title { font-weight: 600; margin-bottom: 0; }
.btn-parked-new { padding: 5px 10px; border-radius: var(--r-sm); }

.parked-list { display: flex; flex-direction: column; gap: 6px; max-height: calc(100vh - 250px); overflow: auto; padding-right: 4px; }
.parked-pill { cursor: grab; }

/* =========================
   FOCUS POPUP ITEM NOTE
   ========================= */
.focus-item .fi-line { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.focus-item .fi-note.pill {
  margin-top: 0;
  font-size: 11px;
  line-height: 1.15;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  background: rgba(15,23,42,.06);
  border: 1px solid rgba(15,23,42,.09);
  color: var(--muted);
  max-width: 400px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.focus-item .fi-note { margin-top: 0; }

/* =========================
   CALENDAR VIEW MODES
   ========================= */
.calendar-pane.view-month .dow { display: grid; }
.calendar-pane.view-week .dow,
.calendar-pane.view-agenda .dow { display: none; }

.week-wrap, .agenda-wrap { display: flex; flex-direction: column; gap: 8px; }

.week-day-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; font-weight: 700; font-size: 13px; color: var(--text); }
.week-day-head .muted-small { font-weight: 500; font-size: 12px; color: var(--muted); }
.week-day-head .btn-mini { padding: 5px 10px; border-radius: var(--r-sm); font-size: 12px; }

.calendar-pane.view-week .day,
.calendar-pane.view-agenda .day { min-height: unset; padding: 10px; }
.calendar-pane.view-week .day-head,
.calendar-pane.view-agenda .day-head { justify-content: space-between; font-size: 12px; }
.calendar-pane.view-week .pill,
.calendar-pane.view-agenda .pill { padding: 7px 10px 7px 8px; border-radius: var(--r-sm); font-size: 13px; }

/* =========================
   MOBILE
   ========================= */
.mobile-only { display: none; }
.mobile-viewbar { display: none; }

@media (min-width: 901px) {
  .mobile-viewbar {
    display: flex;
    gap: 6px;
    align-items: center;
    margin-left: 8px;
  }
  .mobile-viewbar .btn-view {
    padding: 6px 11px;
    border-radius: var(--r-sm);
    font-weight: 600;
    font-size: 12.5px;
    box-shadow: none;
  }
  .mobile-viewbar .btn-view.active {
    background: var(--accent-dim);
    border: 1.5px solid rgba(79,110,247,.35);
    color: var(--accent);
  }
}

@media (max-width: 900px) {
  .topbar { position: sticky; top: 0; z-index: 50; flex-wrap: wrap; gap: 8px; padding: 8px 10px; }
  .topbar .left { width: 100%; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
  .month-title { flex: 1 1 auto; min-width: 140px; font-size: 14px; text-align: center; }
  .topbar .search { width: 100%; }
  .search-box { width: 100%; }
  .topbar .right { width: 100%; display: flex; flex-wrap: wrap; gap: 8px; justify-content: space-between; }
  .mobile-viewbar { display: flex; gap: 6px; width: 100%; }
  .mobile-viewbar .btn-view { flex: 1 1 0; padding: 8px 10px; border-radius: var(--r-sm); font-weight: 600; }
  .mobile-viewbar .btn-view.active { background: var(--accent-dim); border-color: rgba(79,110,247,.35); color: var(--accent); }
  .split { flex-direction: column; height: calc(100vh - 110px); min-height: 0; }
  .status-filter-pane { display: none; }
  .gutter { display: none; }
  .calendar-pane { width: 100%; min-width: 0; max-width: none; }
  .calendar { padding: 8px; }
  .calendar-pane.view-month .calendar { overflow: auto; }
  .calendar-pane.view-month .grid { min-width: 700px; }
  .right-pane {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    height: min(72vh, 700px);
    max-height: 80vh;
    border-left: 0;
    border-top: 1.5px solid var(--border);
    border-radius: 20px 20px 0 0;
    transform: translateY(105%);
    transition: transform .2s cubic-bezier(.4,0,.2,1);
    z-index: 60;
    box-shadow: 0 -12px 40px rgba(15,23,42,.18);
    background: var(--panel);
  }
  body.mobile-details-open .right-pane { transform: translateY(0); }
  .mobile-only { display: inline-flex; }
  #btnMobileCloseDetails { margin-left: auto; }
  .event-header { display: flex; align-items: flex-start; gap: 10px; }
  .event-title { font-size: 15px; }
  .mobile-overlay { position: fixed; inset: 0; background: rgba(15,23,42,.35); z-index: 55; backdrop-filter: blur(2px); }
  .mobile-overlay.hidden { display: none; }
  .taskbar { grid-template-columns: 1fr; gap: 8px; }
  .taskbar label { display: none; }
  .taskbar input { width: 100%; }
  .event-actions { gap: 8px; }
  .select { flex: 1 1 auto; min-width: 130px; }
  #dlModal .modal-card, #dtModal .modal-card, #settingsModal .modal-card { width: 96vw; max-height: 92vh; }
  #dlModal .modal-body, #dtModal .modal-body { display: flex; flex-direction: column; gap: 10px; overflow: auto; }
  #dlModal .tl-left, #dtModal .tl-left { border-right: 0; border-bottom: 1px solid var(--border); padding: 10px; }
  #dlModal .tl-left-actions, #dtModal .tl-left-actions { flex-wrap: wrap; }
  #dlModal .tl-list, #dtModal .tl-list { display: flex; flex-direction: row; gap: 6px; overflow: auto; padding: 8px; white-space: nowrap; }
  #dlModal .tl-list .tl-rowbtn, #dtModal .tl-list .tl-rowbtn { width: auto; flex: 0 0 auto; border: 1.5px solid var(--border); background: var(--panel); padding: 8px 12px; }
  #dlModal .tl-right, #dtModal .tl-right { padding: 10px; min-height: 0; }
  .settings-body { min-height: unset; max-height: calc(92vh - 120px); overflow: auto; }
  .settings-left { width: auto; min-width: 0; border-right: 0; border-bottom: 1px solid var(--border); padding-right: 0; padding-bottom: 10px; }
  .settings-nav { flex-direction: row; gap: 6px; overflow: auto; padding-bottom: 4px; }
  .settings-navbtn { width: auto; flex: 0 0 auto; white-space: nowrap; }
}

/* =========================
   UPCOMING EMPTY STATE
   ========================= */
.upcoming-empty { padding: 8px 10px; font-size: 12.5px; color: var(--muted); }

/* =========================
   LOADING OVERLAY
   ========================= */
.loading-overlay {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(6px);
  z-index: 9999;
}
.loading-overlay.hidden { display: none; }
.loading-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--panel);
  box-shadow: var(--shadow-md);
}
.loading-text { font-weight: 600; color: var(--muted); font-size: 13.5px; }
.loading-spinner {
  width: 18px;
  height: 18px;
  border-radius: var(--r-pill);
  border: 2.5px solid var(--border);
  border-top-color: var(--accent);
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* =========================
   SETTINGS CHECKBOX
   ========================= */
.settings-row-tight { margin-top: 10px; margin-bottom: 10px; }
.settings-check { display: flex; align-items: center; gap: 10px; font-weight: 500; color: var(--text); }
.settings-check input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--accent); }

/* =========================
   DARK MODE
   ========================= */
html.dark {
  --bg:           #0d1117;
  --panel:        #161b22;
  --panel-raised: #1e2530;
  --border:       #30363d;
  --border-focus: #58a6ff;
  --text:         #e6edf3;
  --muted:        #8b949e;
  --subtle:       #6e7681;

  --accent:       #58a6ff;
  --accent-hover: #388bfd;
  --accent-dim:   rgba(88,166,255,.12);
  --accent-glow:  rgba(88,166,255,.18);

  --blue:         #58a6ff;
  --blueH:        #388bfd;
  --green:        #3fb950;
  --greenH:       #2ea043;
  --red:          #f85149;
  --redH:         #da3633;
  --gray:         #8b949e;
  --grayH:        #6e7681;

  --pill:         #58a6ff;
  --pillH:        #388bfd;
  --pillDim:      #1f3a5f;

  --today-bg:          rgba(88,166,255,.10);
  --today-border:      rgba(88,166,255,.38);
  --task-open-bg:      rgba(88,166,255,.08);
  --task-open-border:  rgba(88,166,255,.28);
  --task-done-bg:      rgba(63,185,80,.12);
  --doc-checked-bg:    rgba(63,185,80,.09);

  --shadow-xs: 0 1px 2px rgba(0,0,0,.3);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.04);
  --shadow-md: 0 8px 24px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.04);
  --shadow-lg: 0 20px 48px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.06);
}

html.dark .topbar { background: var(--panel); border-bottom-color: var(--border); }
html.dark .day { background: var(--panel); }
html.dark .search-input, html.dark #eventSearchInput { background: var(--bg); color: var(--text); }
html.dark .search-input::placeholder, html.dark #eventSearchInput::placeholder { color: var(--subtle); }
html.dark .search-results, html.dark #searchResults { background: var(--panel); color: var(--text); }
html.dark input, html.dark select, html.dark textarea { background: var(--bg); color: var(--text); }
html.dark .btn-gray { background: transparent; border-color: var(--border); color: var(--text); }
html.dark .btn-gray:hover { background: rgba(255,255,255,.06); border-color: var(--border-focus); }
html.dark .tl-left { background: var(--bg); }
html.dark .tl-items { background: var(--bg); }
html.dark .tl-form { background: var(--bg); }
html.dark .settings-navbtn { background: transparent; }
html.dark .settings-tablewrap { background: var(--bg); }
html.dark .settings-table thead th { background: var(--panel); }
html.dark .settings-field { background: var(--panel); }
html.dark .account-add-field { background: var(--bg); }
html.dark .account-add-card { background: var(--bg); }
html.dark .focus-section { background: var(--bg); }
html.dark .focus-item { background: var(--panel); }
html.dark .modal-foot { background: var(--bg); }
html.dark .footer { background: var(--bg); }
html.dark .parked-drop { background: var(--bg); }
html.dark .upcoming-event { background: var(--panel); }
html.dark .task { background: var(--panel); }
html.dark .task:not(.done) { background: var(--task-open-bg); }
html.dark .icon-btn { background: var(--panel); border-color: var(--border); color: var(--muted); }
html.dark .icon-btn:not(:disabled):hover { background: rgba(255,255,255,.08); border-color: var(--accent); color: var(--text); }
html.dark .btn-notes.no-note { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.15); color: var(--muted); }
html.dark .btn-notes.has-note { background: rgba(63,185,80,.14); border-color: rgba(63,185,80,.3); color: #7ee787; }
html.dark .task.done, html.dark .dl-item.checked { background: var(--task-done-bg); }
html.dark .task.done .task-top input[type="text"], html.dark .upcoming-task.done label, html.dark .dl-item.checked input[type="text"] { color: #56d364; }
html.dark .event-actions-menu, html.dark .top-actions-menu, html.dark .menu { box-shadow: var(--shadow-lg); }
html.dark .task-handle:hover, html.dark .note-plus:hover { background: var(--accent-dim); color: var(--accent); border-color: rgba(88,166,255,.4); }
html.dark .note-plus { border-color: var(--border); }
html.dark .btn-move { background: var(--panel); border-color: var(--border); color: var(--muted); }
html.dark .btn-move:hover:not(:disabled) { background: var(--accent-dim); border-color: rgba(88,166,255,.4); color: var(--accent); }
html.dark .settings-panel-head { background: linear-gradient(180deg, var(--panel) 78%, rgba(22,27,34,0)); }
html.dark .account-admin-notice { background: var(--accent-dim); border-color: rgba(88,166,255,.3); color: #cae8ff; }
html.dark .settings-table tbody tr:hover td { background: rgba(88,166,255,.06); }
html.dark .taskbar input, html.dark .summarybar textarea, html.dark .note-textarea, html.dark .search-input, html.dark .select, html.dark .task-top input[type="text"], html.dark .task-note textarea, html.dark .dl-item input[type="text"], html.dark .dl-item .dl-note { background: var(--bg); border-color: var(--border); color: var(--text); }
html.dark .event-edit-field input, html.dark .event-edit-field select, html.dark .event-edit-field textarea { background: var(--bg); border-color: var(--border); color: var(--text); }
html.dark .event-edit-field input[type="date"], html.dark .event-edit-field input[type="time"] { color-scheme: dark; }
html.dark .event-edit-field input[type="date"]::-webkit-calendar-picker-indicator, html.dark .event-edit-field input[type="time"]::-webkit-calendar-picker-indicator { filter: invert(1) brightness(1.2); opacity: .9; cursor: pointer; }

/* =========================
   SETTINGS GROUP
   ========================= */
.settings-group {
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  padding: 14px;
  margin-bottom: 12px;
  background: var(--bg);
}
html.dark .settings-group { background: rgba(255,255,255,.03); }
.settings-group-title { font-weight: 700; margin-bottom: 10px; font-size: 13.5px; letter-spacing: -0.01em; }

/* =========================
   SETTINGS MODAL OVERRIDES
   ========================= */
#settingsModal .modal-card, .modal-card-wide {
  width: min(1160px, 96vw);
  max-width: min(1160px, 96vw);
  max-height: min(860px, 94vh);
  border-radius: var(--r-xl);
}
#settingsModal .modal-head { padding: 14px 18px; }
#settingsModal .modal-title { font-size: 14px; font-weight: 700; letter-spacing: -0.01em; }
#settingsModal .modal-foot { padding: 12px 16px; color: var(--muted); }

.settings-body {
  gap: 16px;
  min-height: 0;
  max-height: calc(94vh - 112px);
  padding: 16px 18px 14px;
  overflow: hidden;
}
.settings-left { width: 210px; min-width: 210px; padding-right: 14px; display: flex; flex-direction: column; gap: 14px; }
.settings-nav { gap: 4px; }
.settings-navbtn { padding: 10px 12px; border-radius: var(--r-sm); font-size: 13px; }
.settings-left .muted, .settings-left p { font-size: 12px; line-height: 1.5; }
.settings-right { min-width: 0; padding: 0; overflow: auto; }
.settings-panel { display: flex; flex-direction: column; gap: 14px; }
.settings-panel-head { position: sticky; top: 0; z-index: 3; margin-bottom: 0; padding: 2px 0 10px; background: linear-gradient(180deg, var(--panel) 78%, rgba(255,255,255,0)); }
.settings-h1 { font-size: 14.5px; line-height: 1.2; margin-bottom: 3px; }
.settings-panel-head .muted, .settings-panel-head p, .settings-panel > .muted { font-size: 12px; line-height: 1.45; }
.settings-tablewrap { border-radius: var(--r-lg); border-color: var(--border); box-shadow: var(--shadow-xs); }
.settings-tablewrap { overflow: auto; background: var(--panel); }
.settings-table { min-width: 750px; }
.settings-table thead th { padding: 10px 12px; font-size: 11px; }
.settings-table td { padding: 8px 12px; }
.settings-table input[type='text'], .settings-field input[type='text'], .settings-field input[type='email'], .account-add-field input { min-height: 36px; padding: 7px 10px; border-radius: var(--r-sm); }
.settings-table input[type='color'] { width: 38px; height: 28px; border-radius: var(--r-sm); }
.settings-stylebits { gap: 6px 10px; }
.settings-stylebits label { font-size: 11px; font-weight: 600; }
.settings-actions, .account-actions { gap: 6px; flex-wrap: wrap; }
.settings-actions .btn, .account-actions .btn, .account-add-actions .btn, .settings-panel .btn, .settings-table .btn { padding: 6px 11px; border-radius: var(--r-sm); font-size: 12.5px; }
.settings-formgrid { gap: 10px; }
.settings-field { padding: 12px; }
.settings-group { padding: 12px; margin-bottom: 10px; }
.settings-group-title { font-size: 13px; margin-bottom: 8px; }
.account-mgmt-layout { gap: 12px; }
.account-subnav { gap: 6px; }
.account-subnav-btn { padding: 7px 11px; border-radius: var(--r-sm); font-size: 12.5px; }
.account-add-card { padding: 14px 16px; }
.account-add-head { align-items: flex-start; gap: 14px; margin-bottom: 12px; }
.account-admin-notice { font-size: 12px; font-weight: 600; color: var(--muted); background: var(--accent-dim); border: 1.5px solid rgba(79,110,247,.2); padding: 6px 10px; border-radius: var(--r-pill); }
.account-add-grid { gap: 12px; }
.account-add-field { gap: 6px; padding: 12px; }
.account-add-field label, .settings-field label { font-size: 12px; font-weight: 600; color: var(--muted); }
.account-add-actions { align-items: flex-end; }
.account-add-actions .btn { min-width: 110px; min-height: 42px; }
.account-user-name { font-size: 14px; }
.account-role-badge, .account-user-status { font-size: 11px; padding: 3px 8px; }
.account-actions { justify-content: flex-start; }
.settings-table tbody tr:hover td { background: rgba(79,110,247,.03); }
.settings-tablewrap .settings-table td:last-child, .settings-tablewrap .settings-table th:last-child { white-space: nowrap; }
.settings-tablewrap .settings-table td:last-child { width: 1%; }

@media (max-width: 1100px) {
  .settings-body { padding: 14px; gap: 14px; }
  .settings-left { width: 190px; min-width: 190px; }
  .account-add-grid { grid-template-columns: 1fr 1fr; }
  .account-add-actions { grid-column: 1 / -1; }
}
@media (max-width: 900px) {
  #settingsModal .modal-card, .modal-card-wide { width: 96vw; max-width: 96vw; max-height: 92vh; }
  .settings-body { padding: 12px; max-height: calc(92vh - 110px); overflow: auto; background: none; }
  .settings-left { width: auto; min-width: 0; padding-right: 0; gap: 10px; }
  .settings-right { overflow: visible; }
  .settings-nav { flex-direction: row; overflow: auto; padding-bottom: 4px; }
  .settings-navbtn { flex: 0 0 auto; white-space: nowrap; }
  .settings-panel-head { position: static; background: none; padding-bottom: 2px; }
  .account-add-grid { grid-template-columns: 1fr; }
  .account-add-actions { grid-column: auto; }
  .settings-table { min-width: 650px; }
}

/* =========================
   AUTH
   ========================= */
.auth-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,.55);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5000;
  padding: 24px;
}
.auth-card {
  width: min(400px, 100%);
  background: var(--panel);
  border: 1.5px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg);
  padding: 28px;
}
.auth-title { font-size: 22px; font-weight: 700; margin-bottom: 4px; letter-spacing: -0.02em; }
.auth-subtitle { color: var(--muted); margin-bottom: 20px; font-size: 13.5px; }
.auth-form { display: flex; flex-direction: column; gap: 10px; }
.auth-label { font-weight: 600; font-size: 12.5px; color: var(--muted); }
.auth-input {
  width: 100%;
  padding: 10px 12px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 13.5px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.auth-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.auth-submit { margin-top: 8px; }
.auth-error { color: var(--red); font-weight: 600; min-height: 18px; font-size: 12.5px; }
.menu-user-label { padding: 8px 12px 6px; font-size: 11.5px; font-weight: 600; color: var(--muted); border-bottom: 1px solid var(--border); }
.auth-mode-toggle { display: flex; gap: 6px; margin: 2px 0 4px; }
.auth-mode-btn {
  flex: 1;
  border: 1.5px solid var(--border);
  background: transparent;
  color: var(--text);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background .1s, border-color .1s, color .1s;
}
.auth-mode-btn.active { background: var(--accent-dim); border-color: rgba(79,110,247,.4); color: var(--accent); font-weight: 600; }
#passwordWrap.hidden { display: none; }

/* =========================
   IKAL CARD
   ========================= */
.account-ical-card { display: grid; gap: 12px; padding: 14px; border: 1.5px solid var(--border); border-radius: var(--r-lg); background: var(--panel); }
.account-ical-copy { line-height: 1.5; font-size: 13px; }
.account-ical-field input { width: 100%; font-family: var(--font-mono); font-size: 12px; }
.account-ical-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.account-ical-hint { line-height: 1.5; font-size: 12px; color: var(--muted); }

/* =========================
   TIMED EVENTS + EVENT EDITOR
   ========================= */
.pill-time {
  flex: 0 0 auto;
  font-size: 10.5px;
  font-weight: 700;
  padding: 0 5px 0 0;
  margin-left: 2px;
  white-space: nowrap;
  opacity: .9;
}
.pill-all-day .pill-title { margin-left: 0; }

.event-edit-card { max-width: 660px; width: min(660px, calc(100vw - 32px)); }
.event-edit-body { display: block; padding: 18px 20px 16px; }
.event-edit-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }

.event-edit-field, .event-edit-check { display: flex; flex-direction: column; gap: 6px; }
.event-edit-field--full { grid-column: 1 / -1; }
.event-edit-field label { font-size: 12px; font-weight: 600; color: var(--muted); }
.event-edit-field input, .event-edit-field select, .event-edit-field textarea {
  width: 100%;
  padding: 9px 11px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 13.5px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.event-edit-field input:focus, .event-edit-field select:focus, .event-edit-field textarea:focus {
  border-color: var(--accent);
  background: var(--panel);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.event-edit-field textarea { min-height: 90px; resize: vertical; }
.event-edit-check { flex-direction: row; align-items: center; justify-content: flex-start; gap: 10px; align-self: end; min-height: 42px; padding: 0 0 8px; }
.event-edit-check span { font-weight: 500; line-height: 1; font-size: 13.5px; }
.event-edit-check input {
  appearance: none;
  -webkit-appearance: none;
  width: 17px;
  height: 17px;
  margin: 0;
  border: 1.5px solid var(--border);
  border-radius: 4px;
  background: var(--bg);
  display: inline-grid;
  place-content: center;
  cursor: pointer;
}
.event-edit-check input::after { content: ""; width: 8px; height: 5px; border-left: 2px solid transparent; border-bottom: 2px solid transparent; transform: rotate(-45deg) scale(0); margin-top: -1px; transition: transform .1s; }
.event-edit-check input:checked { background: var(--accent); border-color: var(--accent); }
.event-edit-check input:checked::after { border-left-color: #fff; border-bottom-color: #fff; transform: rotate(-45deg) scale(1); }
.event-edit-check input:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--accent-glow); }
.event-edit-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; }

/* =========================
   WEEK VIEW GRID
   ========================= */
.week-wrap-grid { padding-bottom: 8px; display: flex; flex-direction: column; gap: 0; min-width: 0; }
.week-header-grid, .week-all-day-grid, .week-body-grid { display: grid; grid-template-columns: 72px repeat(7,minmax(170px,1fr)); gap: 0; min-width: 1260px; }
.week-time-corner, .week-all-day-side { position: sticky; left: 0; z-index: 3; background: var(--bg); border-right: 1px solid var(--border); color: var(--muted); font-size: 10.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 12px 10px; }
.week-day-head { position: sticky; top: 0; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 10px 12px; border: 1px solid var(--border); border-left: none; background: var(--panel); }
.week-day-head.today { background: var(--today-bg); border-color: var(--today-border); }
.week-all-day-cell { min-height: 60px; padding: 8px; border: 1px solid var(--border); border-top: none; border-left: none; background: var(--panel); display: flex; flex-direction: column; gap: 4px; }
.week-all-day-cell.today { background: var(--today-bg); border-color: var(--today-border); }
.week-all-day-cell.drag-over, .week-day-column.drag-over { box-shadow: inset 0 0 0 2px rgba(79,110,247,.3); }
.week-scroller { overflow: auto; border-bottom: 1px solid var(--border); }
.week-time-gutter { position: sticky; left: 0; z-index: 2; background: var(--bg); border-right: 1px solid var(--border); }
.week-gutter-hour { position: absolute; left: 0; width: 100%; height: 64px; margin-top: -8px; padding: 0 10px; color: var(--muted); font-size: 10.5px; font-weight: 700; }
.week-day-column { position: relative; background: var(--panel); border-right: 1px solid var(--border); }
.week-day-column.today { background: var(--today-bg); }
.week-hour-line { position: absolute; left: 0; right: 0; height: 1px; border-top: 1px dashed var(--border); }
.week-event-block {
  position: absolute;
  left: 6px;
  right: 6px;
  z-index: 1;
  overflow: hidden;
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto;
  grid-template-areas: "icons time focus" "title title title";
  column-gap: 4px;
  row-gap: 2px;
  align-content: start;
  align-items: start;
  padding: 5px 6px;
}
.week-event-block .pill-icons { grid-area: icons; width: auto; min-width: 0; }
.week-event-block .pill-time { grid-area: time; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; padding: 0; margin: 0; min-width: 0; }
.week-event-block .pill-title { grid-area: title; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; white-space: normal; max-width: 100%; line-height: 1.2; }
.week-event-block .pill-focus { grid-area: focus; justify-self: end; align-self: start; margin-left: 0; padding: 0; }
.week-empty { font-size: 12px; color: var(--muted); padding: 4px 2px; }

@media (max-width: 900px) {
  .event-edit-grid { grid-template-columns: 1fr; }
  .event-edit-foot { flex-direction: column; align-items: stretch; }
}
@media (max-width: 900px) {
  .week-header-grid, .week-all-day-grid, .week-body-grid { grid-template-columns: 60px repeat(7,minmax(130px,1fr)); min-width: 980px; }
}

/* =========================
   USER TASKS VIEW
   ========================= */
.view-actions .btn { white-space: nowrap; }
.user-task-toolbar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; width: 100%; }
.user-task-toolbar > label, .user-task-toolbar > .user-task-new-label { flex: 0 0 auto; }
.user-task-toolbar > .select { flex: 0 1 180px; min-width: 130px; }
.user-task-toolbar > input[type="text"] { flex: 1 1 220px; min-width: 0; }
.user-task-toolbar > #newUserTaskAssignHost { flex: 0 1 auto; min-width: 0; }
.user-task-new-label { margin-left: 6px; }
.user-task-settings-wrap { position: relative; display: inline-flex; align-items: center; }
.user-task-settings-wrap.compact .icon-btn { width: 30px; height: 30px; }
.user-task-settings-btn { font-size: 14px; }
.user-task-assign-menu { position: absolute; top: 40px; right: 0; min-width: 210px; max-width: 270px; background: var(--panel); border: 1.5px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-lg); padding: 8px; z-index: 90; }
.user-task-assign-title { font-size: 11px; font-weight: 700; color: var(--muted); padding: 4px 6px 8px; text-transform: uppercase; letter-spacing: .04em; }
.user-task-assign-row { display: flex; align-items: center; gap: 10px; padding: 7px 10px; border-radius: var(--r-sm); cursor: pointer; transition: background .1s; }
.user-task-assign-row:hover { background: var(--accent-dim); }
.user-task-assignment-badge { border: 1.5px solid var(--border); background: var(--panel); color: var(--text); border-radius: var(--r-pill); padding: 5px 10px; font-weight: 500; font-size: 12px; white-space: nowrap; max-width: 180px; overflow: hidden; text-overflow: ellipsis; }
.user-task-assignment-badge.draft { max-width: none; }
.user-task-new-assignment { display: flex; align-items: center; gap: 6px; }
.user-task-card .task-top { gap: 8px; }
.user-task-card .task-top input[type="text"] { flex: 1 1 auto; }

.right-pane.usertasks .summarybar,
.right-pane.usertasks .event-actions-menu,
.right-pane.usertasks #btnEventNotes,
.right-pane.usertasks #btnEventActionsMenu,
.right-pane.usertasks #btnAddTaskListToEvent,
.right-pane.usertasks #btnFileDocs,
.right-pane.usertasks #btnMoveEvent,
.right-pane.usertasks #btnEditEventDetails,
.right-pane.usertasks #btnRenameEvent,
.right-pane.usertasks #btnDeleteEvent,
.right-pane.usertasks #eventStatus { display: none !important; }

.right-pane.usertasks .event-actions { justify-content: flex-start; min-height: 0; padding-bottom: 0; }
.user-task-card .task-top { grid-template-columns: auto 1fr auto auto; align-items: center; }
.user-task-card .task-top .user-task-settings-wrap { justify-self: end; }
.user-task-card .task-top .btn-x { justify-self: end; }
.pane.right-pane.usertasks { overflow: visible; }
.user-task-settings-wrap { z-index: 120; }
.user-task-settings-wrap:has(.user-task-assign-menu) { z-index: 5200; }
.user-task-assign-menu { z-index: 5300; }

@media (max-width: 1200px) { .user-task-toolbar > input[type="text"] { flex-basis: 100%; order: 3; } }
@media (max-width: 980px) {
  .user-task-toolbar { align-items: stretch; }
  .user-task-toolbar > label, .user-task-toolbar > .user-task-new-label, .user-task-toolbar > .select, .user-task-toolbar > input[type="text"], .user-task-toolbar > #newUserTaskAssignHost, .user-task-toolbar > .btn { flex: 1 1 100%; }
  .user-task-new-label { margin-left: 0; }
  .user-task-assignment-badge { max-width: none; }
}

/* =========================
   REORDER TRANSITIONS
   ========================= */
.list-shell.is-reordering, #tlItems.is-reordering, #dtItems.is-reordering, #dlItems.is-reordering { overflow-anchor: none; }
.tl-item, .dl-item { transition: background-color .15s, box-shadow .15s, border-color .15s; will-change: transform; }
.tl-item.is-reordering, .dl-item.is-reordering { position: relative; z-index: 2; box-shadow: var(--shadow-md); }
.btn-move { overflow: hidden; }

/* =========================
   AUTH SECONDARY
   ========================= */
.auth-secondary-actions { display: flex; gap: 8px; margin-top: 2px; }
.auth-secondary-btn { flex: 1; }
#loginAccountWrap.hidden, #registerNameWrap.hidden, #loginEmailWrap.hidden, #authModeToggle.hidden, #btnShowRegister.hidden, #btnBackToLogin.hidden, #setupPasswordWrap.hidden, #passwordWrap.hidden { display: none; }

/* =========================
   PRINT
   ========================= */
@media print {
  .topbar, .update-banner, .status-filter-pane, .right-pane, .gutter, .modal, #loadingOverlay { display: none !important; }
  .main, .split { display: block !important; }
  .pane.calendar-pane { width: 100% !important; max-width: none !important; border: 0 !important; box-shadow: none !important; }
  #calendar { overflow: visible !important; height: auto !important; max-height: none !important; }
  body { background: #fff !important; color: #000 !important; }
}


/* =========================
   SMOOTH MODAL & PANEL TRANSITIONS
   ========================= */

/*
  Problem: when switching lists in the Task Lists / Document Lists / Document Templates
  modals, the right panel (tl-right) does an instant innerHTML wipe → new content,
  causing the modal-card to snap/jitter to a new height.

  Fix strategy:
  1. Lock modal-card to a stable min-height so it never collapses.
  2. Give tl-right a fixed height so the panel itself never resizes.
  3. Fade + subtle slide the items container on content change via
     a CSS animation that fires whenever the element is re-rendered.
  4. Smooth the modal entrance/exit with opacity + scale.
*/

/* --- Stable modal sizing: never let the card collapse --- */
#tlModal .modal-card,
#dtModal .modal-card,
#dlModal .modal-card,
#focusModal .modal-card,
#settingsModal .modal-card {
  /* Height is now controlled: modal never resizes when content changes */
  height: min(720px, 92vh);
  max-height: min(720px, 92vh);
  transition: opacity .18s ease, transform .18s ease;
}

#dlModal .modal-card  { height: min(720px, 92vh); }
#focusModal .modal-card { height: min(880px, 92vh); }
#settingsModal .modal-card { height: min(860px, 94vh); }

/* --- Right-side panel: fixed height, inner scroll, no layout shift --- */
.tl-right,
.tl-left {
  /* overflow is already set; make sure height is pinned so content swap
     doesn't change parent height */
  height: 100%;
  overflow: hidden;
}

.tl-right {
  /* Items area inside scrolls, not the pane itself */
  display: flex;
  flex-direction: column;
}

/* --- Items containers: always scrollable, never resize the modal --- */
.tl-items,
#tlItems,
#dtItems,
#dlItems {
  flex: 1;
  overflow-y: auto;
  /* Smooth scrollbar appearance */
  scroll-behavior: smooth;
}

/* --- Content fade-in animation: fires on every re-render ---
   Because JS does innerHTML = "" then fills it, the elements are
   new DOM nodes each time → the animation plays fresh each switch. */
@keyframes panelFadeIn {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Animate the tl-items wrapper itself */
.tl-items,
#tlItems,
#dtItems,
#dlItems {
  animation: panelFadeIn .22s cubic-bezier(.4, 0, .2, 1) both;
}

/* Each individual row staggers slightly for a cascade feel */
.tl-item,
.dl-item {
  animation: panelFadeIn .18s cubic-bezier(.4, 0, .2, 1) both;
}

/* Stagger rows 1-8 (beyond 8 they all use the same delay) */
.tl-item:nth-child(1), .dl-item:nth-child(1) { animation-delay: .02s; }
.tl-item:nth-child(2), .dl-item:nth-child(2) { animation-delay: .04s; }
.tl-item:nth-child(3), .dl-item:nth-child(3) { animation-delay: .06s; }
.tl-item:nth-child(4), .dl-item:nth-child(4) { animation-delay: .08s; }
.tl-item:nth-child(5), .dl-item:nth-child(5) { animation-delay: .10s; }
.tl-item:nth-child(6), .dl-item:nth-child(6) { animation-delay: .12s; }
.tl-item:nth-child(7), .dl-item:nth-child(7) { animation-delay: .14s; }
.tl-item:nth-child(8), .dl-item:nth-child(8) { animation-delay: .16s; }

/* Active list button: smooth highlight swap instead of instant */
.tl-rowbtn {
  transition: background .15s ease, color .15s ease, font-weight .1s ease;
}

/* --- Modal entrance animation --- */
@keyframes modalIn {
  from {
    opacity: 0;
    transform: scale(.97) translateY(8px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.modal:not(.hidden) .modal-card {
  animation: modalIn .22s cubic-bezier(.4, 0, .2, 1) both;
}

/* --- Settings panel tab switch: fade between panels --- */
@keyframes settingsPanelIn {
  from { opacity: 0; transform: translateX(6px); }
  to   { opacity: 1; transform: translateX(0); }
}

.settings-panel:not(.hidden) {
  animation: settingsPanelIn .18s cubic-bezier(.4, 0, .2, 1) both;
}

/* --- Focus modal section fade --- */
.focus-section {
  transition: opacity .15s ease;
}

/* --- Upcoming / parked / event task list content: fade on switch --- */
@keyframes rightPaneFadeIn {
  from { opacity: 0; transform: translateY(5px); }
  to   { opacity: 1; transform: translateY(0); }
}

.upcoming-wrap,
.parked-wrap,
#tasks {
  animation: rightPaneFadeIn .2s cubic-bezier(.4, 0, .2, 1) both;
}

/* --- Smooth the right-pane mode switch (event → upcoming → parked) ---
   The .right-pane itself gets classes toggled; transition the content. */
.right-pane {
  transition: none; /* Don't animate the pane box itself on desktop */
}

/* --- Task rows in event view: stagger on load --- */
.task {
  animation: panelFadeIn .18s cubic-bezier(.4, 0, .2, 1) both;
}
.task:nth-child(1) { animation-delay: .02s; }
.task:nth-child(2) { animation-delay: .04s; }
.task:nth-child(3) { animation-delay: .06s; }
.task:nth-child(4) { animation-delay: .08s; }
.task:nth-child(5) { animation-delay: .10s; }
.task:nth-child(6) { animation-delay: .12s; }

/* --- Left list panel: stable width, no reflow --- */
.tl-left {
  flex-shrink: 0;
  overflow-y: auto;
}

/* Animate list buttons on initial load */
.tl-list .tl-rowbtn {
  animation: panelFadeIn .16s cubic-bezier(.4, 0, .2, 1) both;
}
.tl-list .tl-rowbtn:nth-child(1) { animation-delay: .03s; }
.tl-list .tl-rowbtn:nth-child(2) { animation-delay: .06s; }
.tl-list .tl-rowbtn:nth-child(3) { animation-delay: .09s; }
.tl-list .tl-rowbtn:nth-child(4) { animation-delay: .12s; }
.tl-list .tl-rowbtn:nth-child(5) { animation-delay: .15s; }

/* --- Upcoming event cards: stagger --- */
.upcoming-event {
  animation: panelFadeIn .18s cubic-bezier(.4, 0, .2, 1) both;
}
.upcoming-event:nth-child(1) { animation-delay: .03s; }
.upcoming-event:nth-child(2) { animation-delay: .06s; }
.upcoming-event:nth-child(3) { animation-delay: .09s; }
.upcoming-event:nth-child(4) { animation-delay: .12s; }
.upcoming-event:nth-child(5) { animation-delay: .15s; }

/* --- Respect reduced motion preference --- */
@media (prefers-reduced-motion: reduce) {
  .modal-card,
  .tl-items, #tlItems, #dtItems, #dlItems,
  .tl-item, .dl-item, .tl-rowbtn,
  .settings-panel:not(.hidden),
  .task, .upcoming-event, .upcoming-wrap, .parked-wrap, #tasks {
    animation: none !important;
    transition-duration: 0s !important;
  }
}
