/* MSP Time Tracker — shared styles across all pages */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg: #ffffff; --bg2: #f5f5f4; --bg3: #eeece9;
  --text: #1a1a1a; --text2: #666660; --text3: #999993;
  --border: rgba(0,0,0,0.12); --border2: rgba(0,0,0,0.22);
  --blue-bg: #e6f1fb; --blue-text: #0c447c; --blue-border: #85b7eb;
  --green-bg: #eaf3de; --green-text: #27500a; --green-border: #97c459;
  --red-bg: #fcebeb; --red-text: #791f1f; --red-border: #f09595;
  --orange-bg: #fef3e2; --orange-text: #7c4a00; --orange-border: #f0b842;
  --purple-bg: #f3f0ff; --purple-text: #4c1d95; --purple-border: #a78bfa;
}
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #1c1c1a; --bg2: #252523; --bg3: #2e2e2b;
    --text: #f0ede8; --text2: #a09d97; --text3: #6b6865;
    --border: rgba(255,255,255,0.1); --border2: rgba(255,255,255,0.2);
    --blue-bg: #0c447c; --blue-text: #b5d4f4; --blue-border: #378add;
    --green-bg: #27500a; --green-text: #c0dd97; --green-border: #639922;
    --red-bg: #791f1f; --red-text: #f7c1c1; --red-border: #e24b4a;
    --orange-bg: #7c4a00; --orange-text: #fde68a; --orange-border: #d97706;
    --purple-bg: #4c1d95; --purple-text: #ddd6fe; --purple-border: #7c3aed;
  }
}
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: var(--bg3); color: var(--text); min-height: 100vh; padding: 1rem; }
.wrap { max-width: 680px; margin: 0 auto; }
.card { background: var(--bg); border: 0.5px solid var(--border); border-radius: 12px; padding: 1.25rem; margin-bottom: 1rem; }
h1 { font-size: 17px; font-weight: 500; }
.hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; }
.badge { font-size: 12px; color: var(--text2); background: var(--bg2); padding: 4px 10px; border-radius: 6px; border: 0.5px solid var(--border); }
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green-text); display: inline-block; margin-right: 6px; animation: pulse 2.5s ease infinite; }
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:0.3} }
.status { font-size: 13px; min-height: 18px; margin-bottom: 0.75rem; color: var(--text3); }
.status.ok  { color: var(--green-text); }
.status.err { color: var(--red-text); }
.metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 1.25rem; }
.metric { background: var(--bg2); border-radius: 8px; padding: 10px 12px; }
.metric-label { font-size: 10px; color: var(--text2); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 3px; }
.metric-value { font-size: 19px; font-weight: 500; }
.metric-sub { font-size: 11px; color: var(--text3); margin-top: 2px; }

/* Top nav */
.topnav { max-width: 680px; margin: 0 auto 1rem; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.nav-links { display: flex; gap: 4px; background: var(--bg); border: 0.5px solid var(--border); border-radius: 10px; padding: 4px; }
.nav-link { font-size: 12px; padding: 6px 12px; border-radius: 7px; color: var(--text2); text-decoration: none; }
.nav-link:hover { background: var(--bg2); color: var(--text); }
.nav-link.active { background: var(--text); color: var(--bg); font-weight: 500; }
.nav-gear { display: flex; gap: 2px; background: var(--bg); border: 0.5px solid var(--border); border-radius: 10px; padding: 4px; }
.nav-gear-btn { font-size: 14px; padding: 5px 10px; border-radius: 7px; border: none; background: transparent; color: var(--text2); cursor: pointer; line-height: 1; display: flex; align-items: center; }
.nav-gear-btn:hover { background: var(--bg2); color: var(--text); }
.nav-gear-btn.active { background: var(--text); color: var(--bg); }
/* Admin-mode gating */
.nav-admin-link { display: none; }
body.admin-mode .nav-admin-link { display: flex; }
.admin-only { display: none; }
body.admin-mode .admin-only { display: flex; }

/* Timer widget(s) — one chip per open timer (running or paused) */
.timer-list { display: none; flex-direction: column; gap: 8px; margin-bottom: 1.25rem; }
.timer-list.visible { display: flex; }
.timer-widget { background: var(--green-bg); border: 0.5px solid var(--green-border); border-radius: 10px; padding: 12px 14px; display: flex; align-items: center; gap: 12px; }
.timer-widget.paused { background: var(--orange-bg); border-color: var(--orange-border); }
.timer-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--green-text); flex-shrink: 0; animation: pulse 1.5s ease infinite; }
.timer-widget.paused .timer-dot { background: var(--orange-text); animation: none; }
.timer-info { flex: 1; min-width: 0; }
.timer-client { font-size: 13px; font-weight: 500; color: var(--green-text); }
.timer-widget.paused .timer-client { color: var(--orange-text); }
.timer-desc { font-size: 12px; color: var(--text2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.timer-elapsed { font-size: 22px; font-weight: 500; font-variant-numeric: tabular-nums; color: var(--green-text); flex-shrink: 0; margin-right: 4px; }
.timer-widget.paused .timer-elapsed { color: var(--orange-text); }
.timer-actions { display: flex; gap: 6px; flex-shrink: 0; }
.btn-stop { height: 32px; padding: 0 14px; border-radius: 8px; background: var(--red-bg); color: var(--red-text); border: 0.5px solid var(--red-border); font-size: 12px; font-family: inherit; cursor: pointer; flex-shrink: 0; }
.btn-stop:hover { opacity: 0.85; }
.btn-pause { height: 32px; padding: 0 14px; border-radius: 8px; background: var(--orange-bg); color: var(--orange-text); border: 0.5px solid var(--orange-border); font-size: 12px; font-family: inherit; cursor: pointer; flex-shrink: 0; }
.btn-pause:hover { opacity: 0.85; }
.btn-resume { height: 32px; padding: 0 14px; border-radius: 8px; background: var(--green-bg); color: var(--green-text); border: 0.5px solid var(--green-border); font-size: 12px; font-family: inherit; cursor: pointer; flex-shrink: 0; }
.btn-resume:hover { opacity: 0.85; }

/* Tabs */
.tabs { display: flex; gap: 4px; margin-bottom: 0.75rem; border-bottom: 0.5px solid var(--border); padding-bottom: 0.5rem; }
.tab { font-size: 12px; padding: 5px 12px; border-radius: 6px; border: 0.5px solid transparent; background: none; cursor: pointer; color: var(--text2); font-family: inherit; }
.tab.active { background: var(--bg2); border-color: var(--border); color: var(--text); font-weight: 500; }

.sec-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.6rem; flex-wrap: wrap; gap: 6px; }
.sec-title { font-size: 10px; font-weight: 600; color: var(--text2); text-transform: uppercase; letter-spacing: 0.06em; }
.notes-vis-btn { border: none; background: none; cursor: pointer; font-size: 13px; padding: 1px 3px; border-radius: 5px; line-height: 1; opacity: 0.25; vertical-align: middle; }
.notes-vis-btn:hover { background: var(--bg2); opacity: 0.7; }
.notes-vis-btn.active { opacity: 1; }
.entry { background: var(--bg); border: 0.5px solid var(--border); border-left: 3px solid var(--border2); border-radius: 10px; padding: 11px 13px; display: flex; align-items: flex-start; gap: 12px; margin-bottom: 8px; flex-wrap: wrap; }
.entry:hover { border-color: var(--border2); }
.entry-left { flex: 0 0 100%; min-width: 0; }
.entry-desc { font-size: 13px; line-height: 1.5; margin-bottom: 5px; word-break: break-word; }
.entry-desc[contenteditable="true"] { outline: none; border-bottom: 1px dashed var(--border2); cursor: text; }
.entry-meta { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.pill { font-size: 11px; padding: 2px 8px; border-radius: 20px; }
.pill-client { background: var(--blue-bg); color: var(--blue-text); }
.pill-noclient { background: var(--bg2); color: var(--text3); border: 0.5px solid var(--border); }
.pill-user { background: var(--purple-bg); color: var(--purple-text); }
.pill-time { font-size: 11px; color: var(--text3); }
.pill-source { font-size: 10px; padding: 1px 6px; border-radius: 10px; background: var(--bg2); color: var(--text3); border: 0.5px solid var(--border); }
.pill-prio-urgent { background: var(--red-bg);    color: var(--red-text);    border: 0.5px solid var(--red-border); }
.pill-prio-high   { background: var(--orange-bg); color: var(--orange-text); border: 0.5px solid var(--orange-border); }
.pill-prio-normal { background: var(--bg2);       color: var(--text3);       border: 0.5px solid var(--border); }
.pill-prio-low    { background: var(--bg2);       color: var(--text3);       border: 0.5px solid var(--border); opacity: 0.6; }
.entry-right { display: flex; flex: 0 0 100%; flex-direction: row; align-items: center; gap: 6px; padding-top: 6px; border-top: 0.5px solid var(--border); }
.entry-dur { font-size: 13px; font-weight: 500; margin-right: auto; }
.entry-actions { gap: 6px; }
.del, .edit-btn { background: none; border: none; cursor: pointer; color: var(--text3); font-size: 17px; line-height: 1; padding: 4px; }
.del { font-size: 21px; }
.del:hover { color: var(--red-text); }
.edit-btn:hover { color: var(--blue-text); }
.empty { text-align: center; padding: 2rem; color: var(--text3); font-size: 13px; border: 0.5px dashed var(--border); border-radius: 10px; margin-bottom: 1.25rem; }

/* Date grouping in history */
.date-group { margin-bottom: 1rem; }
.date-header { font-size: 11px; color: var(--text2); font-weight: 600; padding: 4px 0; margin-bottom: 6px; display: flex; justify-content: space-between; border-bottom: 0.5px solid var(--border); }
.date-total { color: var(--text3); font-weight: 400; }

button { font-family: inherit; cursor: pointer; }
.btn { height: 34px; padding: 0 14px; border-radius: 8px; border: 0.5px solid var(--border2); background: var(--bg); color: var(--text); font-size: 12px; display: inline-flex; align-items: center; gap: 5px; }
.btn:hover { background: var(--bg2); }
.btn:active { transform: scale(0.97); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }
.btn-red { background: var(--red-bg); color: var(--red-text); border-color: var(--red-border); }
.btn-red:hover { opacity: 0.85; background: var(--red-bg); }
.btn-dark { background: var(--text); color: var(--bg); border: none; }
.btn-dark:hover { opacity: 0.85; background: var(--text); }
.btn-sm { height: 28px; padding: 0 10px; font-size: 11px; }
select, input, textarea { font-family: inherit; font-size: 12px; padding: 5px 8px; border-radius: 6px; border: 0.5px solid var(--border2); background: var(--bg); color: var(--text); }
.export-row { border-top: 0.5px solid var(--border); padding-top: 1rem; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.export-label { font-size: 12px; color: var(--text2); }

/* Task panel */
.task-panel { background: var(--bg); border: 0.5px solid var(--border); border-radius: 12px; padding: 1.25rem; margin-bottom: 1rem; }
.task-panel-hdr { display: flex; align-items: center; justify-content: space-between; cursor: pointer; user-select: none; }
.task-panel-title { font-size: 13px; font-weight: 500; display: flex; align-items: center; gap: 8px; }
.task-count { font-size: 11px; background: var(--red-bg); color: var(--red-text); border: 0.5px solid var(--red-border); border-radius: 20px; padding: 1px 8px; }
.task-count.ok { background: var(--green-bg); color: var(--green-text); border-color: var(--green-border); }
.task-chevron { font-size: 12px; color: var(--text3); transition: transform 0.2s; }
.task-panel.collapsed .task-chevron { transform: rotate(-90deg); }
.task-panel.collapsed .task-body { display: none; }
.task-body { margin-top: 1rem; }
.task-item { display: flex; align-items: flex-start; gap: 10px; padding: 9px 10px; border-radius: 8px; border: 0.5px solid var(--border); border-left: 3px solid var(--border2); margin-bottom: 6px; background: var(--bg2); flex-wrap: wrap; }
.task-item:hover { border-color: var(--border2); }
.task-prio { font-size: 14px; flex-shrink: 0; margin-top: 1px; }
.task-body-text { flex: 1; min-width: 0; }
.task-title-text { font-size: 13px; line-height: 1.4; }
.task-title-text[contenteditable="true"] { outline: none; border-bottom: 1px dashed var(--border2); cursor: text; }
.task-meta { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; align-items: center; }
.task-client-pill { font-size: 10px; padding: 1px 7px; border-radius: 10px; color: white; }
.task-due { font-size: 11px; color: var(--text3); }
.task-due.overdue { color: var(--red-text); font-weight: 500; }
.task-done-btn { background: none; border: 0.5px solid var(--border); border-radius: 6px; color: var(--text3); font-size: 11px; padding: 2px 8px; cursor: pointer; flex-shrink: 0; white-space: nowrap; margin-right: auto; }
.task-done-btn:hover { background: var(--green-bg); color: var(--green-text); border-color: var(--green-border); }
.task-actions { display: flex; flex: 0 0 100%; flex-direction: row; align-items: center; gap: 6px; padding-top: 6px; border-top: 0.5px solid var(--border); }
.task-assign-sel { font-size: 10px; padding: 2px 6px; }

.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 50; align-items: center; justify-content: center; padding: 1rem; }
.modal-overlay.open { display: flex; }
.modal { background: var(--bg); border-radius: 12px; border: 0.5px solid var(--border2); padding: 1.25rem; width: 100%; max-width: 520px; max-height: 85vh; display: flex; flex-direction: column; }
.modal-title { font-size: 14px; font-weight: 500; margin-bottom: 1rem; }
.modal pre { font-family: monospace; font-size: 11px; background: var(--bg2); padding: 1rem; border-radius: 8px; overflow: auto; white-space: pre-wrap; word-break: break-word; flex: 1; }
.modal-foot { display: flex; gap: 8px; margin-top: 1rem; justify-content: flex-end; }
.modal label { font-size: 11px; color: var(--text2); display: block; margin-bottom: 3px; margin-top: 10px; }
.modal input, .modal select, .modal textarea { width: 100%; }

/* Stop-timer modal */
.stop-modal { background: var(--bg); border-radius: 12px; border: 0.5px solid var(--border2); padding: 1.25rem; width: 100%; max-width: 400px; }
.stop-modal-title { font-size: 14px; font-weight: 500; margin-bottom: 0.75rem; }
.stop-modal textarea { width: 100%; font-family: inherit; font-size: 13px; border: 0.5px solid var(--border2); border-radius: 8px; padding: 10px; background: var(--bg2); color: var(--text); resize: vertical; min-height: 80px; }
.stop-modal textarea:focus { outline: none; border-color: var(--blue-border); }
.stop-modal-foot { display: flex; gap: 8px; margin-top: 0.75rem; justify-content: flex-end; }

/* Clients/Projects/Users pages */
.list-item { background: var(--bg2); border: 0.5px solid var(--border); border-radius: 10px; padding: 12px 14px; margin-bottom: 8px; }
.list-item-hdr { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.list-item-name { font-size: 13px; font-weight: 500; display: flex; align-items: center; gap: 8px; }
.swatch { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.list-item-meta { font-size: 11px; color: var(--text3); margin-top: 4px; }
.list-item-actions { display: flex; gap: 6px; }
.inactive-tag { font-size: 10px; color: var(--text3); background: var(--bg3); padding: 1px 6px; border-radius: 8px; border: 0.5px solid var(--border); }
.project-sub { margin-top: 8px; padding-left: 12px; border-left: 2px solid var(--border); }
.project-row { display: flex; align-items: center; justify-content: space-between; padding: 5px 0; font-size: 12px; }
.form-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.form-row > * { flex: 1; min-width: 120px; }

/* Notes panel — collapsed by default, expand arrow to view/add */
.notes-panel { margin-top: 6px; }
.notes-controls { display: flex; align-items: center; gap: 8px; }
.notes-toggle { background: none; border: none; padding: 0; color: var(--text3); font-size: 11px; cursor: pointer; font-family: inherit; }
.notes-toggle:hover { color: var(--text2); }
.notes-add-btn { background: none; border: none; padding: 0; color: var(--text3); font-size: 11px; cursor: pointer; font-family: inherit; }
.notes-add-btn:hover { color: var(--accent); }
.notes-body { margin-top: 6px; background: var(--bg2); border: 0.5px solid var(--border); border-radius: 8px; padding: 8px 10px; }
.notes-loading, .notes-empty { font-size: 11px; color: var(--text3); }
.note-source { font-size: 10px; color: var(--text3); font-style: italic; }
.note-edit-btn { background: none; border: none; padding: 0 0 0 6px; color: var(--text3); font-size: 11px; cursor: pointer; opacity: 0; transition: opacity 0.15s; }
.note:hover .note-edit-btn { opacity: 1; }
.note-edit-input { width: 100%; resize: vertical; min-height: 40px; margin-top: 4px; }
.note-edit-actions { display: flex; gap: 6px; margin-top: 4px; }
.optional-label { font-size: 11px; color: var(--text3); font-weight: normal; }
.notes-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 8px; }
.note { font-size: 12px; }
.note-meta { font-size: 10px; color: var(--text3); margin-bottom: 1px; }
.note-body { line-height: 1.4; word-break: break-word; }
.notes-add { display: flex; gap: 6px; align-items: flex-end; }
.notes-input { flex: 1; resize: vertical; min-height: 32px; }

/* ── Mobile (≤ 540px) ──────────────────────────────────────────────────── */
@media (max-width: 540px) {
  body { padding: 0.5rem; }
  .card { padding: 0.9rem; }

  /* Nav: stack if needed */
  .topnav { flex-wrap: wrap; }

  /* Timer widget: allow elapsed + actions to wrap */
  .timer-widget { flex-wrap: wrap; }
  .timer-elapsed { order: -1; }
  .timer-actions { margin-left: auto; }

  /* sec-hdr filter controls: allow wrapping without extra gap */
  .sec-hdr { gap: 4px; }

  /* Modal: full-width on small screens */
  .modal { max-height: 92vh; }
}
