/* Mitt KOSA — egna stilar ovanpå shared/kosa-design.css */

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: 'Inter', -apple-system, system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
}

/* ── Topbar ──────────────────────────────────────────────────── */
.topbar {
  background: var(--card);
  border-bottom: 1px solid var(--border);
  padding: 8px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  position: sticky;
  top: 0;
  z-index: 10;
  flex-shrink: 0;
  min-height: 44px;
}
body.board-page-body {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}
.topbar .brand {
  font-weight: 600;
  font-size: 17px;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 10px;
}
.topbar .brand .dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--gold);
}
.topbar .spacer { flex: 1; }
.topbar .back-link {
  color: var(--muted);
  text-decoration: none;
  font-size: 13px;
  padding: 6px 10px;
  border-radius: 6px;
  transition: all .15s;
}
.topbar .back-link:hover { background: var(--card2); color: var(--text); }

.me-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px 6px 6px;
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 13px;
}
.me-chip .avatar {
  width: 28px; height: 28px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 12px;
  color: #fff;
}

/* ── Layout ──────────────────────────────────────────────────── */
.page {
  max-width: 1400px;
  margin: 0 auto;
  padding: 24px;
}
.page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 16px;
  flex-wrap: wrap;
}
.page-header h1 {
  margin: 0 0 4px;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -.01em;
}
.page-header .subtitle {
  color: var(--muted);
  font-size: 14px;
}
.page-header .actions { display: flex; gap: 8px; }

/* ── Knappar ─────────────────────────────────────────────────── */
.btn {
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  padding: 9px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s;
  font-family: inherit;
}
.btn:hover { background: var(--card2); border-color: var(--border-strong); }
.btn.primary {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.btn.primary:hover { background: var(--gold-light); border-color: var(--gold-light); }
.btn.small { padding: 5px 10px; font-size: 12px; }

/* ── KPI-rad ────────────────────────────────────────────────── */
.kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.kpi {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
}
.kpi .label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }
.kpi .value { font-size: 22px; font-weight: 600; margin-top: 4px; }
.kpi .value.accent { color: var(--gold); }
.kpi .value.pos    { color: var(--pos); }
.kpi .value.neg    { color: var(--neg); }

/* ── Grid: tasks + boards ───────────────────────────────────── */
.main-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 20px;
}
@media (max-width: 1000px) { .main-grid { grid-template-columns: 1fr; } }

.section {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px 20px;
}
.section h2 {
  margin: 0 0 14px;
  font-size: 15px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.section h2 .count {
  background: var(--card2);
  color: var(--muted);
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
}

/* ── Task-rader ─────────────────────────────────────────────── */
.task-list { display: flex; flex-direction: column; }
.task-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 12px;
  align-items: center;
  padding: 11px 2px;
  border-top: 1px solid var(--border);
  cursor: pointer;
  transition: background .12s;
}
.task-row:first-child { border-top: none; }
.task-row:hover { background: var(--card2); }
.task-row .title-cell {
  min-width: 0;
}
.task-row .task-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.task-row .task-meta {
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.task-row .board-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 7px;
  background: var(--card2);
  border-radius: 999px;
  font-size: 10px;
  font-weight: 500;
  color: var(--text2);
}
.task-row .board-chip .dot {
  width: 7px; height: 7px; border-radius: 50%;
}

.status-chip {
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  color: #fff;
  white-space: nowrap;
}
.status-chip.empty { background: var(--muted2); }

.due-chip {
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 500;
  background: var(--card2);
  color: var(--muted);
  white-space: nowrap;
}
.due-chip.overdue { background: var(--neg-bg); color: var(--neg); }
.due-chip.today   { background: var(--gold-bg); color: var(--amber); }

/* ── Full-fill cells (Monday-stil: hela cellen blir färg, rundade hörn) ─── */
.task-table tbody td.cell[data-type="status"],
.task-table tbody td.cell[data-type="date"] {
  padding: 3px 4px;
}
.status-fill {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 26px;
  padding: 4px 10px;
  box-sizing: border-box;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
  transition: filter .12s, transform .08s;
  box-shadow: 0 1px 2px rgba(0,0,0,.08);
}
.status-fill:hover { filter: brightness(1.08); }
.status-fill.empty {
  background: var(--card2);
  color: var(--muted2);
  font-weight: 400;
  box-shadow: none;
  border: 1px dashed var(--border);
}
.date-fill {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 26px;
  padding: 4px 8px;
  box-sizing: border-box;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--muted);
  background: var(--card2);
  white-space: nowrap;
  cursor: pointer;
  transition: filter .12s;
}
.date-fill:hover { filter: brightness(1.03); }
.date-fill.overdue { background: var(--neg-bg); color: var(--neg); font-weight: 600; }
.date-fill.today   { background: var(--gold-bg); color: var(--amber); font-weight: 600; }
.date-fill.empty   {
  background: transparent;
  color: var(--muted2);
  font-weight: 400;
  border: 1px dashed var(--border);
}

/* Kanban-korten ska ha chips, inte full-fill — behåll gamla stil där */
.kanban-card .status-fill,
.kanban-card .date-fill {
  width: auto;
  min-height: 0;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
}
.kanban-card .date-fill {
  border-radius: 6px;
  background: var(--card2);
}

.empty-state {
  text-align: center;
  padding: 32px 16px;
  color: var(--muted);
  font-size: 13px;
}
.empty-state .emoji { font-size: 28px; display: block; margin-bottom: 6px; }

/* ── Board-kort ─────────────────────────────────────────────── */
.board-list { display: flex; flex-direction: column; gap: 8px; }
.board-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card);
  cursor: pointer;
  transition: all .15s;
  text-decoration: none;
  color: inherit;
}
.board-card:hover {
  border-color: var(--gold-border);
  background: var(--gold-bg);
}
.board-card .icon {
  width: 38px; height: 38px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.board-card .info { flex: 1; min-width: 0; }
.board-card .name {
  font-size: 13px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.board-card .desc {
  font-size: 11px; color: var(--muted); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.board-card .kind-badge {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--card2);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ── Loading / modal ────────────────────────────────────────── */
.loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
  color: var(--muted);
  font-size: 13px;
}

.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.35);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 100;
}
.modal-backdrop.open { display: flex; }
.modal {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 22px 24px;
  width: 420px;
  max-width: calc(100vw - 32px);
  box-shadow: var(--shadow-md);
}
.modal h3 { margin: 0 0 14px; font-size: 16px; font-weight: 600; }
.modal .field { margin-bottom: 12px; }
.modal label {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.modal input, .modal textarea, .modal select {
  width: 100%;
  padding: 9px 11px;
  border: 1px solid var(--border);
  border-radius: 7px;
  font-size: 13px;
  background: var(--white);
  color: var(--text);
  font-family: inherit;
}
.modal input:focus, .modal textarea:focus, .modal select:focus {
  outline: none;
  border-color: var(--gold);
}
.modal .actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 18px;
}

/* ─────────────────────────────────────────────────────────────
   BOARD VIEW — Monday-tight layout med sidebar
   ───────────────────────────────────────────────────────────── */

.app-shell {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* ─── Sidebar ───────────────────────────────────────────────── */
.sidebar {
  width: 230px;
  background: var(--card);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  transition: width .2s, margin-left .2s;
  overflow: hidden;
}
.sidebar.collapsed {
  width: 0;
  border-right: none;
}
.sidebar-header {
  padding: 12px 14px 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.sidebar-header .title {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  flex: 1;
}
.sidebar-header .add-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 16px;
  padding: 2px 6px;
  border-radius: 4px;
  line-height: 1;
}
.sidebar-header .add-btn:hover { background: var(--card2); color: var(--text); }

.sidebar-search {
  padding: 0 12px 8px;
}
.sidebar-search input {
  width: 100%;
  background: var(--card2);
  border: 1px solid transparent;
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 12px;
  color: var(--text);
  font-family: inherit;
  outline: none;
}
.sidebar-search input:focus { border-color: var(--gold); background: var(--white); }

.sidebar-list {
  flex: 1;
  overflow-y: auto;
  padding: 4px 8px 12px;
}
.sidebar-board {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  color: var(--text);
  text-decoration: none;
  margin-bottom: 1px;
  border: 1px solid transparent;
}
.sidebar-board:hover { background: var(--card2); }
.sidebar-board.active {
  background: var(--gold-bg);
  border-color: var(--gold-border);
  color: var(--text);
  font-weight: 500;
}
.sidebar-board .icon {
  width: 22px; height: 22px;
  border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
}
.sidebar-board .name {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidebar-board .kind-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--muted2);
  flex-shrink: 0;
}
.sidebar-board .kind-dot.shared { background: var(--pos); }

.sidebar-section-title {
  font-size: 10px;
  font-weight: 600;
  color: var(--muted2);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 12px 10px 4px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.sidebar-section-title .chev { font-size: 8px; }
.sidebar-section-title .add-folder-btn {
  margin-left: auto;
  background: transparent;
  border: none;
  color: var(--muted2);
  cursor: pointer;
  font-size: 12px;
  padding: 0 6px;
  border-radius: 4px;
  line-height: 1;
}
.sidebar-section-title .add-folder-btn:hover { background: var(--card2); color: var(--text); }

/* ─── Folders i sidebaren ─── */
.sidebar-folder {
  margin: 1px 0;
}
.sidebar-folder-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  border: 1px solid transparent;
  user-select: none;
}
.sidebar-folder-header:hover { background: var(--card2); }
.sidebar-folder-header .chev {
  font-size: 9px;
  color: var(--muted);
  transition: transform .15s;
  flex-shrink: 0;
  width: 10px;
  text-align: center;
}
.sidebar-folder.collapsed .sidebar-folder-header .chev { transform: rotate(-90deg); }
.sidebar-folder-header .folder-icon {
  font-size: 13px;
  flex-shrink: 0;
}
.sidebar-folder-header .folder-name {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidebar-folder-header .folder-menu-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 13px;
  padding: 0 4px;
  border-radius: 3px;
  line-height: 1;
  opacity: 0;
  transition: opacity .1s;
}
.sidebar-folder-header:hover .folder-menu-btn { opacity: 1; }
.sidebar-folder-header .folder-menu-btn:hover { background: var(--border); color: var(--text); }

.sidebar-folder-body {
  padding-left: 14px;
  border-left: 2px solid var(--border);
  margin-left: 10px;
  margin-top: 2px;
}
.sidebar-folder.collapsed .sidebar-folder-body { display: none; }

/* Tom-folder placeholder + folder-root drop-zones */
.sidebar-folder-empty {
  font-size: 11px;
  color: var(--muted2);
  padding: 4px 8px;
  font-style: italic;
}

/* Drag-and-drop states */
.sidebar-board[draggable="true"] { cursor: grab; }
.sidebar-board.dragging,
.sidebar-folder.dragging { opacity: .35; }
.sidebar-board.drop-above { border-top: 2px solid var(--gold) !important; padding-top: 4px; }
.sidebar-board.drop-below { border-bottom: 2px solid var(--gold) !important; padding-bottom: 4px; }
.sidebar-folder-header.drop-into {
  background: var(--gold-bg);
  border-color: var(--gold-border);
  box-shadow: 0 0 0 1px var(--gold) inset;
}
.sidebar-folder-header.drop-above { border-top: 2px solid var(--gold); padding-top: 3px; }
.sidebar-folder-header.drop-below { border-bottom: 2px solid var(--gold); padding-bottom: 3px; }
.sidebar-dropzone {
  height: 6px;
  margin: 2px 0;
  border-radius: 3px;
  transition: background .1s;
}
.sidebar-dropzone.active { background: var(--gold); height: 4px; margin: 4px 0; }

/* Folder-menu (kontextmeny) */
.sidebar-folder-menu {
  position: fixed;
  z-index: 1000;
  min-width: 160px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
  padding: 4px;
  font-size: 12px;
}
.sidebar-folder-menu button {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  padding: 7px 10px;
  border-radius: 4px;
  cursor: pointer;
  color: var(--text);
  font-size: 12px;
}
.sidebar-folder-menu button:hover { background: var(--card2); }
.sidebar-folder-menu button.danger { color: var(--neg); }
.sidebar-folder-menu .palette {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 4px; padding: 6px 8px 8px;
}
.sidebar-folder-menu .palette .sw {
  width: 22px; height: 22px;
  border-radius: 5px; cursor: pointer;
  border: 2px solid transparent;
}
.sidebar-folder-menu .palette .sw:hover { border-color: var(--border); }
.sidebar-folder-menu .divider {
  height: 1px; background: var(--border); margin: 4px 0;
}

/* Sidebar toggle button (i topbar) */
.sidebar-toggle {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 18px;
  padding: 4px 8px;
  border-radius: 5px;
  line-height: 1;
}
.sidebar-toggle:hover { background: var(--card2); color: var(--text); }

/* ─── Main board area ───────────────────────────────────────── */
.board-main {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  background: var(--bg);
}

.board-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px 10px;
  background: var(--card);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.board-header .icon {
  width: 32px; height: 32px; border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
}
.board-header .info { flex: 1; min-width: 0; }
.board-header h1 {
  margin: 0;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -.005em;
}
.board-header .desc {
  color: var(--muted);
  font-size: 12px;
  margin-top: 1px;
}
.board-header .members {
  display: flex;
  align-items: center;
}
.board-header .members .avatar {
  margin-left: -5px;
  border: 2px solid var(--card);
}

.board-toolbar {
  display: flex;
  gap: 6px;
  padding: 8px 22px;
  align-items: center;
  background: var(--card);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.board-toolbar .view-tabs {
  display: flex;
  gap: 1px;
  background: var(--card2);
  padding: 2px;
  border-radius: 6px;
}
.board-toolbar .view-tab {
  padding: 5px 12px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  color: var(--muted);
  border: none;
  background: transparent;
  font-family: inherit;
}
.board-toolbar .view-tab.active {
  background: var(--card);
  color: var(--text);
  box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.board-toolbar .toolbar-spacer { flex: 1; }
.board-toolbar .btn-icon {
  background: transparent;
  border: 1px solid transparent;
  padding: 5px 10px;
  border-radius: 5px;
  font-size: 12px;
  color: var(--muted);
  cursor: pointer;
  font-family: inherit;
}
.board-toolbar .btn-icon:hover { background: var(--card2); color: var(--text); }

/* ── Sök + sortering i toolbar ──────────────────────────── */
.board-toolbar .board-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  margin-left: 4px;
}
.board-toolbar .board-search-input {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 28px 6px 10px;
  font-size: 12px;
  color: var(--text);
  font-family: inherit;
  width: 200px;
  outline: none;
  transition: width .15s, border-color .12s, background .12s;
}
.board-toolbar .board-search-input::placeholder { color: var(--muted2); }
.board-toolbar .board-search-input:focus {
  width: 280px;
  border-color: var(--gold);
  background: var(--card);
}
.board-toolbar .board-search-clear {
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  font-size: 16px;
  line-height: 1;
  padding: 0;
}
.board-toolbar .board-search-clear:hover {
  background: var(--border);
  color: var(--text);
}
/* Sort-pilar i kolumnrubriker (Monday-stil — klick på rubriken cyklar) */
.task-table thead th.sortable-col {
  cursor: pointer;
  user-select: none;
  transition: background .12s;
}
.task-table thead th.sortable-col:hover {
  background: var(--card2);
}
.task-table thead th.sortable-col.sorted {
  background: var(--gold-bg);
  color: var(--amber);
}
.task-table thead th.sortable-col .col-title-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.task-table thead th .sort-arrow {
  font-size: 9px;
  color: var(--amber);
  line-height: 1;
}
.task-table thead th.sortable-col.sorted .col-menu-btn { color: var(--amber); }

.board-content {
  padding: 14px 22px 80px;
}

.group {
  margin-bottom: 14px;
}
.group.dragover .group-table-wrap {
  box-shadow: 0 0 0 2px var(--gold);
  border-radius: 6px;
}

/* Group header — Monday-style med chevron + title + räknare */
.group-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 4px 6px 0;
  cursor: pointer;
  user-select: none;
  border-radius: 5px;
  transition: background .12s, padding .12s;
}
.group-header .chevron {
  width: 16px;
  text-align: center;
  color: var(--muted);
  transition: transform .15s;
  font-size: 10px;
}
.group-header.collapsed .chevron { transform: rotate(-90deg); }
.group-header .group-title {
  font-weight: 600;
  font-size: 14px;
  background: transparent;
  border: none;
  outline: none;
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--gold);
  font-family: inherit;
  min-width: 80px;
  max-width: 280px;
}
.group-header .group-title:hover { background: var(--card2); }
.group-header .group-title:focus { background: var(--white); color: var(--text); }
.group-header .group-count {
  color: var(--muted);
  font-size: 12px;
  font-weight: 400;
}
.group-header .group-menu-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  font-size: 18px;
  cursor: pointer;
  padding: 0 6px;
  border-radius: 4px;
  line-height: 1;
  opacity: 0;
  transition: opacity .12s, background .12s, color .12s;
}
.group-header:hover .group-menu-btn { opacity: 1; }
.group-header .group-menu-btn:hover {
  background: var(--card2);
  color: var(--gold);
}

/* Ihopfälld grupp — bubbla i full bredd (Monday-style) */
.group-header.collapsed {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 4px solid var(--group-color, #579bfc);
  padding: 8px 12px;
  margin-bottom: 0;
}
.group-header.collapsed:hover {
  background: var(--card2);
}
.group-header.collapsed .group-title {
  pointer-events: none; /* Klick går till headern, inte input:en */
}
.group-header.collapsed .group-count {
  margin-left: auto;
  background: var(--card2);
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
}

/* Done-grupper (is_done=true) — tasks försvinner från Mina uppgifter */
.group-header .group-done-badge {
  background: #e8f7ec;
  color: #037f4c;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.4px;
  margin-left: 4px;
}
.group.is-done .group-header {
  opacity: 0.72;
}
.group.is-done .group-body {
  opacity: 0.88;
}
.group.is-done:hover .group-header,
.group.is-done:hover .group-body {
  opacity: 1;
}

.group-table-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 4px solid var(--group-color, #579bfc);
  border-radius: 5px;
  overflow-x: auto; /* horisontell scroll när tabellen är bredare än containern */
  overflow-y: visible;
  /* Gömd scrollbar — all horisontell scroll sker via sticky proxy längst ner */
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.group-table-wrap::-webkit-scrollbar { display: none; }
.group-body.collapsed { display: none; }

/* ── Fixed horisontell scroll-proxy (Monday-stil) ──────────
   Ligger utanför .board-main (direktbarn av <body>) för att INTE
   stjäla vertikal drag-scroll — sticky barn i scroll-container gjorde
   att draghandtaget på scrollbaren inte följde med content. */
.board-scroll-proxy {
  position: fixed;
  bottom: 0;
  /* left + width sätts dynamiskt i JS (updateScrollProxy) så proxyn alltid
     matchar tabellens faktiska bredd och horisontella position. Annars hamnar
     thumben under rail-en (56px) eller sidebaren (230px) och scroll-range
     blir inkonsekvent med .group-table-wrap. Fallback-värdena används bara
     om JS-positioneringen misslyckas. */
  left: 286px;
  right: 0;
  height: 14px;
  overflow-x: auto;
  overflow-y: hidden;
  background: var(--card);
  border-top: 1px solid var(--border);
  z-index: 20;
}
.board-scroll-proxy-inner {
  height: 1px;
  pointer-events: none;
}
/* Gör proxy-scrollbaren tydligare — Monday-känsla */
.board-scroll-proxy::-webkit-scrollbar { height: 12px; }
.board-scroll-proxy::-webkit-scrollbar-track {
  background: var(--card2);
  border-radius: 6px;
}
.board-scroll-proxy::-webkit-scrollbar-thumb {
  background: var(--muted2);
  border-radius: 6px;
  border: 2px solid var(--card);
}
.board-scroll-proxy::-webkit-scrollbar-thumb:hover {
  background: var(--muted);
}

/* ─── Tabellen ────────────────────────────────────────────── */
.task-table {
  width: max-content;
  min-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}
.task-table thead th {
  background: var(--card);
  border-bottom: 1px solid var(--border);
  padding: 6px 10px;
  text-align: left;
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
  height: 28px;
  position: relative;
}
.task-table thead th.editable-col {
  cursor: pointer;
  user-select: none;
}
.task-table thead th.editable-col:hover {
  background: var(--card2);
  color: var(--text);
}
.task-table thead th.editable-col {
  padding-right: 24px; /* lämna plats för ⋮-knappen */
}
.task-table thead th.editable-col .col-menu-btn {
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: var(--muted2);
  font-size: 16px;
  padding: 2px 4px;
  border-radius: 3px;
  cursor: pointer;
  opacity: 0.55;
  transition: opacity .12s, background .12s;
  font-family: inherit;
  line-height: 1;
  font-weight: 700;
}
.task-table thead th.editable-col:hover .col-menu-btn { opacity: 1; }
.task-table thead th.editable-col .col-menu-btn:hover {
  background: var(--white);
  color: var(--gold);
}

/* Label-editor modal — större än vanlig modal */
.modal-wide {
  width: 720px !important;
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
}
.modal-wide > h3 { flex: 0 0 auto; }
.modal-wide > .share-tabs { flex: 0 0 auto; }
.modal-wide > .actions { flex: 0 0 auto; }
.modal-wide > .share-pane { flex: 1 1 auto; overflow-y: auto; min-height: 0; }
.label-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
  max-height: 360px;
  overflow-y: auto;
}
.label-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px;
  background: var(--card2);
  border-radius: 6px;
}
.label-row .drag-handle {
  color: var(--muted2);
  cursor: grab;
  padding: 0 2px;
  user-select: none;
}
.label-row .color-swatch {
  width: 28px;
  height: 28px;
  border-radius: 5px;
  cursor: pointer;
  border: 2px solid transparent;
  position: relative;
  flex-shrink: 0;
}
.label-row .color-swatch:hover { border-color: var(--text); }
.label-row input.label-name {
  flex: 1;
  background: var(--white);
  border: 1px solid var(--border);
  padding: 6px 10px;
  border-radius: 5px;
  font-size: 13px;
  color: var(--text);
  font-family: inherit;
  outline: none;
}
.label-row input.label-name:focus { border-color: var(--gold); }
.label-row .delete-btn {
  background: transparent;
  border: 1px solid transparent;
  color: var(--muted2);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 5px;
  font-size: 14px;
  line-height: 1;
}
.label-row .delete-btn:hover {
  color: var(--neg);
  background: var(--neg-bg);
}

.color-picker-popover {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 8px;
  z-index: 1100;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  width: 220px;
}
.color-picker-popover .swatch {
  width: 26px;
  height: 26px;
  border-radius: 5px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform .1s;
}
.color-picker-popover .swatch:hover { transform: scale(1.1); }
.color-picker-popover .swatch.selected { border-color: var(--text); }

.add-label-btn {
  display: block;
  width: 100%;
  padding: 8px;
  border: 1px dashed var(--border);
  background: transparent;
  border-radius: 6px;
  color: var(--muted);
  font-size: 12px;
  cursor: pointer;
  font-family: inherit;
}
.add-label-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: var(--gold-bg);
}

/* ─────────────────────────────────────────────────────────────
   KANBAN VIEW
   ───────────────────────────────────────────────────────────── */
.kanban-board {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding: 4px 4px 20px;
  align-items: flex-start;
}
.kanban-column {
  flex-shrink: 0;
  width: 280px;
  background: var(--card2);
  border-radius: 8px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 220px);
}
.kanban-column.dragover {
  background: var(--gold-bg);
  outline: 2px dashed var(--gold);
}
.kanban-column-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding: 4px 6px;
}
.kanban-column-header .swatch {
  width: 12px;
  height: 12px;
  border-radius: 3px;
  flex-shrink: 0;
}
.kanban-column-header .title {
  font-size: 13px;
  font-weight: 600;
  flex: 1;
  color: var(--text);
}
.kanban-column-header .count {
  font-size: 11px;
  color: var(--muted);
}
.kanban-cards {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-right: 2px;
}
.kanban-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 9px 11px;
  cursor: pointer;
  transition: all .12s;
  user-select: none;
}
.kanban-card:hover {
  border-color: var(--gold-border);
  box-shadow: 0 2px 6px rgba(0,0,0,.06);
}
.kanban-card.dragging { opacity: 0.4; }
.kanban-card.drop-above { box-shadow: 0 -3px 0 var(--gold); }
.kanban-card.drop-below { box-shadow: 0 3px 0 var(--gold); }
.kanban-card .card-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 6px;
  word-wrap: break-word;
}
.kanban-card .card-update-preview {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.35;
  margin: 0 0 8px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}
.kanban-card .card-update-preview .card-update-author {
  color: var(--text);
  font-weight: 600;
}
.kanban-card .card-statuses {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 6px;
}
.kanban-card .card-statuses .status-chip {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  color: #fff;
  white-space: nowrap;
}
.kanban-card .card-icon {
  font-size: 11px;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.kanban-card .card-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.kanban-card .card-meta .status-chip,
.kanban-card .card-meta .due-chip,
.kanban-card .card-meta .status-fill,
.kanban-card .card-meta .date-fill {
  font-size: 10px;
  padding: 1px 7px;
}
.kanban-card .card-meta .people-cell {
  margin-left: auto;
}
.kanban-card .card-meta .avatar-sm {
  width: 22px;
  height: 22px;
  font-size: 9px;
}
.kanban-add-card {
  background: transparent;
  border: 1px dashed var(--border);
  border-radius: 6px;
  padding: 8px;
  color: var(--muted);
  font-size: 12px;
  cursor: pointer;
  font-family: inherit;
  margin-top: 4px;
}
.kanban-add-card:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: var(--gold-bg);
}

.kanban-empty {
  padding: 20px;
  color: var(--muted);
  text-align: center;
  font-size: 13px;
}
.kanban-empty .emoji { display: block; font-size: 28px; margin-bottom: 8px; }

.kanban-grouping-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 4px 12px;
  font-size: 12px;
  color: var(--muted);
}
.kanban-grouping-bar select {
  background: var(--card);
  border: 1px solid var(--border);
  padding: 4px 8px;
  border-radius: 5px;
  font-size: 12px;
  color: var(--text);
  font-family: inherit;
}

/* ─────────────────────────────────────────────────────────────
   MAP VIEW + LOCATION CELL
   ───────────────────────────────────────────────────────────── */
.map-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
}
.map-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.location-cell {
  display: inline-block;
  font-size: 12px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.location-picker {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 10px;
  z-index: 1000;
  width: 320px;
  max-width: calc(100vw - 20px);
}
.location-picker .loc-input {
  width: 100%;
  border: 1px solid var(--border);
  background: var(--white);
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  outline: none;
  color: var(--text);
}
.location-picker .loc-input:focus { border-color: var(--gold); }
.location-picker .loc-results {
  margin-top: 6px;
  max-height: 240px;
  overflow-y: auto;
}
.location-picker .loc-loading,
.location-picker .loc-empty {
  padding: 10px;
  font-size: 11px;
  color: var(--muted);
  text-align: center;
}
.location-picker .loc-result {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
  background: transparent;
  border: 1px solid transparent;
  text-align: left;
  padding: 7px 9px;
  border-radius: 5px;
  cursor: pointer;
  font-family: inherit;
  font-size: 11px;
  color: var(--text);
  line-height: 1.35;
  margin-bottom: 2px;
}
.location-picker .loc-result:hover {
  background: var(--gold-bg);
  border-color: var(--gold-border);
}
.location-picker .loc-result .pin {
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
}
.location-picker .loc-result .text {
  flex: 1;
  word-wrap: break-word;
}
.location-picker .loc-clear {
  margin-top: 6px;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 5px 10px;
  border-radius: 5px;
  font-size: 11px;
  cursor: pointer;
  font-family: inherit;
  width: 100%;
}
.location-picker .loc-clear:hover { color: var(--neg); border-color: var(--neg); }

/* Leaflet z-index så pickers ligger ovanför */
.leaflet-container { z-index: 1; }

/* ─────────────────────────────────────────────────────────────
   TIMELINE cell + picker
   ───────────────────────────────────────────────────────────── */
.timeline-chip {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 4px 8px;
  border-radius: 5px;
  background: var(--card2);
  min-width: 130px;
  max-width: 220px;
}
.timeline-chip.active { background: var(--gold-bg); }
.timeline-chip.past { background: var(--pos-bg); }
.timeline-chip.future { background: var(--blue-bg); }
.timeline-chip .timeline-bar {
  height: 4px;
  background: rgba(0,0,0,.08);
  border-radius: 2px;
  overflow: hidden;
}
.timeline-chip .timeline-fill {
  height: 100%;
  background: var(--gold);
  border-radius: 2px;
  transition: width .3s;
}
.timeline-chip.past .timeline-fill { background: var(--pos); }
.timeline-chip.future .timeline-fill { background: var(--blue); }
.timeline-chip .timeline-text {
  font-size: 10px;
  color: var(--muted);
  font-weight: 500;
  white-space: nowrap;
}

.timeline-picker {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 14px;
  z-index: 1000;
  min-width: 240px;
}
.timeline-field {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.timeline-field label {
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  width: 40px;
}
.timeline-field input {
  flex: 1;
  padding: 6px 9px;
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: 12px;
  font-family: inherit;
  color: var(--text);
  background: var(--white);
}
.timeline-field input:focus { outline: none; border-color: var(--gold); }
.timeline-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  margin-top: 8px;
}
.timeline-actions button {
  background: transparent;
  border: 1px solid var(--border);
  padding: 5px 12px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 11px;
  font-family: inherit;
  color: var(--text);
}
.timeline-actions .tl-save {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.timeline-actions .tl-save:hover { background: var(--gold-light); }
.timeline-actions .tl-clear:hover { color: var(--neg); border-color: var(--neg); }

/* ─────────────────────────────────────────────────────────────
   RATING cell + picker
   ───────────────────────────────────────────────────────────── */
.rating-cell {
  color: var(--gold);
  font-size: 14px;
  letter-spacing: 2px;
}
.rating-picker {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 8px 10px;
  z-index: 1000;
  display: flex;
  align-items: center;
  gap: 3px;
}
.rating-picker .rating-star {
  background: transparent;
  border: none;
  font-size: 22px;
  cursor: pointer;
  padding: 4px;
  color: var(--muted2);
  font-family: inherit;
  transition: transform .1s;
}
.rating-picker .rating-star:hover { transform: scale(1.15); }
.rating-picker .rating-star.active { color: var(--gold); }
.rating-picker .rating-clear {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 4px 9px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 10px;
  font-family: inherit;
  margin-left: 6px;
}
.rating-picker .rating-clear:hover { color: var(--neg); border-color: var(--neg); }

/* ─────────────────────────────────────────────────────────────
   COUNTRY cell + picker
   ───────────────────────────────────────────────────────────── */
.country-cell {
  font-size: 12px;
  color: var(--text);
}
.country-picker {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 8px;
  z-index: 1000;
  width: 240px;
  max-height: 360px;
  display: flex;
  flex-direction: column;
}
.country-picker .country-search {
  width: 100%;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: 12px;
  font-family: inherit;
  background: var(--white);
  color: var(--text);
  outline: none;
  margin-bottom: 6px;
}
.country-picker .country-search:focus { border-color: var(--gold); }
.country-picker .country-list {
  flex: 1;
  overflow-y: auto;
}
.country-picker .country-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: transparent;
  border: 1px solid transparent;
  padding: 6px 10px;
  border-radius: 5px;
  cursor: pointer;
  font-family: inherit;
  font-size: 12px;
  color: var(--text);
  text-align: left;
  margin-bottom: 1px;
}
.country-item:hover { background: var(--card2); }
.country-item.selected {
  background: var(--gold-bg);
  border-color: var(--gold-border);
}
.country-picker .country-clear {
  margin-top: 6px;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 6px 10px;
  border-radius: 5px;
  font-size: 11px;
  cursor: pointer;
  font-family: inherit;
  width: 100%;
}
.country-picker .country-clear:hover { color: var(--neg); border-color: var(--neg); }

/* ─────────────────────────────────────────────────────────────
   CALENDAR VIEW
   ───────────────────────────────────────────────────────────── */
.calendar-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
}
.calendar-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.calendar-header h2 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  flex: 1;
}
.calendar-header .nav-btn {
  background: var(--card2);
  border: 1px solid var(--border);
  padding: 5px 12px;
  border-radius: 5px;
  font-size: 13px;
  cursor: pointer;
  font-family: inherit;
  color: var(--text);
}
.calendar-header .nav-btn:hover { background: var(--gold-bg); border-color: var(--gold); }

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
}
.calendar-day-header {
  background: var(--card2);
  padding: 6px 8px;
  font-size: 10px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  text-align: center;
}
.calendar-day {
  background: var(--card);
  min-height: 100px;
  padding: 5px 6px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  cursor: pointer;
}
.calendar-day:hover { background: var(--card2); }
.calendar-day.other-month { background: var(--bg); opacity: 0.5; }
.calendar-day.today { background: var(--gold-bg); }
.calendar-day .day-number {
  font-size: 11px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 2px;
}
.calendar-day.today .day-number { color: var(--gold); }
.calendar-day .day-event {
  background: var(--gold-bg);
  border-left: 3px solid var(--gold);
  padding: 2px 5px;
  border-radius: 3px;
  font-size: 10px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
}
.calendar-day .day-event:hover {
  background: var(--gold);
  color: #fff;
}
.calendar-day .day-event.more {
  background: transparent;
  border: none;
  color: var(--muted);
  text-align: center;
  font-style: italic;
}

.calendar-empty-message {
  text-align: center;
  color: var(--muted);
  font-size: 13px;
  padding: 24px;
}

/* ─────────────────────────────────────────────────────────────
   DELA TAVLA-MODAL (board settings + members)
   ───────────────────────────────────────────────────────────── */
.share-section {
  margin-bottom: 16px;
}
.share-section h4 {
  margin: 0 0 8px;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.share-icon-row {
  display: flex;
  gap: 8px;
  align-items: center;
}
.share-icon-row .big-icon {
  width: 56px;
  height: 56px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  flex-shrink: 0;
  cursor: pointer;
  border: 2px solid var(--border);
}
.share-icon-row .big-icon:hover { border-color: var(--gold); }
.share-icon-row input.icon-input {
  width: 56px;
  text-align: center;
  font-size: 22px;
  padding: 4px;
}

.color-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.color-row .swatch {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform .1s;
}
.color-row .swatch:hover { transform: scale(1.1); }
.color-row .swatch.selected { border-color: var(--text); }

.members-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px;
  background: var(--card2);
}
.member-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px;
  border-radius: 5px;
  background: var(--card);
}
.member-row .info {
  flex: 1;
  min-width: 0;
}
.member-row .name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.member-row .email {
  font-size: 10px;
  color: var(--muted);
}
.member-row .role-select {
  background: var(--card2);
  border: 1px solid var(--border);
  font-size: 10px;
  padding: 2px 5px;
  border-radius: 4px;
  color: var(--muted);
  font-family: inherit;
}
.member-row .add-btn,
.member-row .remove-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 4px 10px;
  border-radius: 5px;
  font-size: 11px;
  cursor: pointer;
  font-family: inherit;
}
.member-row .add-btn { color: var(--gold); border-color: var(--gold); }
.member-row .add-btn:hover { background: var(--gold); color: #fff; }
.member-row .remove-btn:hover { color: var(--neg); border-color: var(--neg); }
.member-row.is-owner .role-badge {
  background: var(--gold);
  color: #fff;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 500;
}

/* Info-rutor för dela-modalen */
.share-help {
  background: var(--gold-bg);
  border-left: 3px solid var(--gold);
  border-radius: 5px;
  padding: 10px 12px;
  margin-bottom: 14px;
  font-size: 12px;
  color: var(--text2);
  line-height: 1.5;
}
.share-help strong { color: var(--gold); display: block; margin-bottom: 3px; font-size: 13px; }
.share-help ul { margin: 6px 0 0; padding-left: 18px; }
.share-help li { margin: 2px 0; }

.share-tabs {
  display: flex;
  gap: 2px;
  background: var(--card2);
  padding: 3px;
  border-radius: 6px;
  margin-bottom: 14px;
}
.share-tab {
  flex: 1;
  padding: 6px 12px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 500;
  color: var(--muted);
  border: none;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
}
.share-tab.active {
  background: var(--card);
  color: var(--text);
  box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.share-pane { display: none; }
.share-pane.active { display: block; }

.share-danger {
  margin-top: 24px;
  padding: 12px;
  background: var(--neg-bg);
  border: 1px solid var(--neg);
  border-radius: 6px;
}
.share-danger .label {
  font-size: 11px;
  color: var(--neg);
  font-weight: 600;
  margin-bottom: 6px;
}
.share-danger .delete-btn {
  background: var(--neg);
  color: #fff;
  border: none;
  padding: 6px 12px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 12px;
  font-family: inherit;
}

/* Column-context menu */
.col-context-menu {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 4px;
  z-index: 1000;
  min-width: 180px;
}
.col-context-menu button {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  background: transparent;
  border: none;
  text-align: left;
  padding: 7px 10px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 13px;
  color: var(--text);
  font-family: inherit;
}
.col-context-menu button:hover { background: var(--card2); }
.col-context-menu button.danger { color: var(--neg); }
.col-context-menu button.danger:hover { background: var(--neg-bg); }
.col-context-menu hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 4px 0;
}
.task-table thead th.col-handle {
  width: 22px;
  padding: 0;
  position: sticky;
  left: 32px;
  z-index: 3;
  background: var(--card);
}
.task-table thead th.col-title {
  position: sticky;
  left: 54px;
  z-index: 3;
  background: var(--card);
  border-right: 1px solid var(--border);
}
/* Resize-handle på höger kant av Uppgift-headern */
.col-title-resizer {
  position: absolute;
  right: -3px;
  top: 0;
  bottom: 0;
  width: 6px;
  cursor: col-resize;
  background: transparent;
  z-index: 4;
}
.col-title-resizer:hover {
  background: var(--gold);
}
.col-title-resizer.dragging {
  background: var(--gold);
}

/* Resize-handtag på övriga kolumner — samma mönster som titel */
.task-table thead th.editable-col {
  position: relative;
}
.col-resizer {
  position: absolute;
  right: -3px;
  top: 0;
  bottom: 0;
  width: 6px;
  cursor: col-resize;
  background: transparent;
  z-index: 4;
}
.col-resizer:hover,
.col-resizer.dragging {
  background: var(--gold);
}

/* ── Dropdown-kolumn (chip-lista) ──────────────────────── */
.dropdown-fill {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  padding: 3px 6px;
  align-items: center;
  min-height: 32px;
  cursor: pointer;
  width: 100%;
  box-sizing: border-box;
}
.dropdown-fill.empty { color: var(--muted2); justify-content: center; font-size: 12px; }
.dropdown-chip {
  background: var(--card2);
  color: var(--text);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
}
.dropdown-picker {
  min-width: 200px;
  max-height: 300px;
  overflow-y: auto;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px;
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
}
.dropdown-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.dropdown-row:hover { background: var(--card2); }
.dropdown-row.selected { background: var(--gold-bg); color: var(--amber); }
.dropdown-row .dropdown-check {
  width: 14px;
  color: var(--gold);
  font-weight: 700;
}
.dropdown-empty {
  padding: 12px;
  text-align: center;
  color: var(--muted);
  font-size: 12px;
}

/* ── Item-ID-kolumn ───────────────────────────────────── */
.item-id-fill {
  display: inline-block;
  padding: 2px 8px;
  background: var(--card2);
  color: var(--muted);
  font-family: 'SF Mono', monospace;
  font-size: 11px;
  border-radius: 4px;
  letter-spacing: 0.3px;
}

/* ── Button-kolumn ────────────────────────────────────── */
.column-button-fill {
  padding: 5px 12px;
  border: none;
  border-radius: 5px;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: filter .12s;
}
.column-button-fill:hover { filter: brightness(1.1); }

/* ── Time-tracking-kolumn ─────────────────────────────── */
.time-tracking-fill {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  font-size: 12px;
  color: var(--muted);
  cursor: pointer;
  min-height: 32px;
  width: 100%;
  box-sizing: border-box;
}
.time-tracking-fill.running {
  background: var(--gold-bg);
  color: var(--amber);
  font-weight: 600;
}
.time-tracking-fill .time-value { font-variant-numeric: tabular-nums; }

/* ── Formula-kolumn ───────────────────────────────────── */
.formula-result {
  display: inline-block;
  padding: 3px 8px;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  font-weight: 500;
  cursor: help;
}

/* ── Subitems (nested tabell under parent-rader) ───────── */
.task-table tbody td.col-handle:has(.subitem-chevron) {
  cursor: default;
}
.subitem-chevron {
  width: 20px;
  height: 20px;
  border: none;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: transform .15s, color .12s, background .12s;
}
.task-table tbody tr:hover .subitem-chevron { color: var(--gold); }
.subitem-chevron:hover {
  background: var(--gold-bg);
  color: var(--gold);
}
.subitem-chevron.has-items {
  color: var(--gold);
}
.subitem-chevron.open {
  transform: rotate(90deg);
  color: var(--gold);
}

/* Hint-rad när ett nyöppnat subitems-block är tomt */
.subitem-empty-hint {
  margin-top: 10px;
  padding: 10px 14px;
  background: var(--card);
  border: 1px dashed var(--gold);
  border-radius: 6px;
  font-size: 12px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.5;
}
.subitem-empty-hint .hint-arrow {
  color: var(--gold);
  font-weight: 700;
}
.btn-inline-add-subcol {
  background: var(--gold);
  color: #fff;
  border: none;
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  margin-left: 4px;
}
.btn-inline-add-subcol:hover {
  filter: brightness(1.1);
}
.subitem-count {
  display: inline-block;
  background: var(--card2);
  color: var(--muted);
  font-size: 10px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 999px;
  margin-left: 6px;
  vertical-align: middle;
}
.task-table tbody tr.has-subitems td.col-handle {
  color: var(--gold);
}

/* Expanderat subitems-block — en <tr> med colspan som inehåller en nested tabell */
.task-table tbody tr.subitems-row > td.subitems-cell {
  padding: 0 !important;
  background: var(--bg);
  border-bottom: 2px solid var(--border);
}
.subitems-container {
  padding: 8px 8px 10px 48px;
  border-left: 4px solid var(--gold);
  background: linear-gradient(to bottom, var(--gold-bg), transparent 90%);
}
.subitem-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
  font-size: 12px;
}
.subitem-table thead th {
  padding: 5px 10px;
  background: var(--card2);
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  font-weight: 500;
  font-size: 11px;
  color: var(--muted);
  text-align: left;
  vertical-align: middle;
  text-transform: none;
  letter-spacing: 0;
}
.subitem-table thead th:last-child { border-right: none; }
.subitem-table thead th.col-add {
  width: 30px;
  text-align: center;
  cursor: pointer;
  color: var(--muted2);
  font-size: 14px;
}
.subitem-table thead th.col-add:hover {
  background: var(--gold-bg);
  color: var(--gold);
}
.subitem-table tbody td {
  padding: 4px 10px;
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  vertical-align: middle;
  height: 28px;
  background: var(--card);
}
.subitem-table tbody tr:last-child td { border-bottom: none; }
.subitem-table tbody td:last-child { border-right: none; }
.subitem-table tbody tr:hover td { background: var(--card2); }
.subitem-table tbody td.col-title {
  font-weight: 400;
}
.subitem-table tbody td.col-title .title-text {
  cursor: pointer;
  padding: 2px 5px;
  margin: -2px -5px;
  border-radius: 3px;
  display: inline-block;
  max-width: calc(100% - 60px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.subitem-table tbody td.col-title .title-text:hover { background: var(--card2); }
.subitem-table tbody td.col-title .open-detail-btn {
  float: right;
  background: var(--white);
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 1px 6px;
  border-radius: 3px;
  cursor: pointer;
  font-size: 10px;
  opacity: 0;
  transition: opacity .12s;
  font-family: inherit;
}
.subitem-table tbody tr:hover .open-detail-btn { opacity: 1; }
.subitem-table tbody td.col-add {
  border-right: none;
  width: 30px;
}
.subitem-add-row {
  margin-top: 4px;
  padding: 0 4px;
}
.subitem-add-row input {
  width: 100%;
  max-width: 300px;
  border: 1px dashed var(--border);
  background: transparent;
  padding: 5px 10px;
  border-radius: 4px;
  font-size: 11px;
  color: var(--muted);
  font-family: inherit;
  outline: none;
}
.subitem-add-row input:focus {
  border-style: solid;
  border-color: var(--gold);
  background: var(--card);
  color: var(--text);
}

/* Drag-and-drop på kolumnrubriker — Monday-stil */
.task-table thead th.editable-col[draggable="true"] .col-title-label {
  cursor: grab;
}
.task-table thead th.editable-col.col-dragging {
  opacity: 0.35;
}
.task-table thead th.editable-col.drop-before {
  box-shadow: inset 3px 0 0 var(--gold);
}
.task-table thead th.editable-col.drop-after {
  box-shadow: inset -3px 0 0 var(--gold);
}
body.column-dragging,
body.column-dragging * {
  cursor: grabbing !important;
}

.task-table tbody td.col-handle {
  position: sticky;
  left: 32px;
  z-index: 1;
  background: var(--card);
}
.task-table tbody td.col-title {
  position: sticky;
  left: 54px;
  z-index: 1;
  background: var(--card);
  border-right: 1px solid var(--border);
}
.task-table tbody tr:hover td.col-handle,
.task-table tbody tr:hover td.col-title {
  background: var(--card2);
}
.task-table tfoot td.col-handle {
  position: sticky;
  left: 32px;
  z-index: 1;
  background: var(--card);
}
.task-table tfoot td.col-title {
  position: sticky;
  left: 54px;
  z-index: 1;
  background: var(--card);
  border-right: 1px solid var(--border);
}
/* col-add expanderar och fyller resterande bredd (Monday-stil) */
.task-table { width: 100%; }
.task-table thead th.col-add {
  width: auto;
  min-width: 36px;
  padding: 0 12px;
  text-align: left;
  cursor: pointer;
  color: var(--muted2);
  font-weight: 400;
  font-size: 16px;
  background: var(--card);
  border-right: none;
}
.task-table thead th.col-add:hover {
  background: var(--gold-bg);
  color: var(--gold);
}
.task-table tbody td.col-add,
.task-table tfoot td.col-add {
  width: auto;
  min-width: 36px;
  border-right: none;
  background: var(--card2);
}

.task-table tbody tr {
  border-bottom: 1px solid var(--border);
  height: 32px;
  background: var(--card);
}
.task-table tbody tr:hover { background: var(--card2); }
.task-table tbody tr.dragging { opacity: 0.4; }
.task-table tbody tr.drop-above td:first-child { box-shadow: inset 0 2px 0 0 var(--gold); }
.task-table tbody tr.drop-below td:first-child { box-shadow: inset 0 -2px 0 0 var(--gold); }

.task-table tbody td {
  padding: 4px 10px;
  font-size: 13px;
  vertical-align: middle;
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  position: relative;
  height: 32px;
}
.task-table tbody td:last-child { border-right: none; }

.task-table tbody td.col-handle {
  padding: 0;
  text-align: center;
  cursor: grab;
  color: var(--muted2);
  user-select: none;
  width: 22px;
  border-right: none;
}
.task-table tbody td.col-handle:hover { color: var(--text); }
.task-table tbody td.col-title {
  font-weight: 400;
  padding-left: 8px;
}
.task-table tbody td.col-title .title-text {
  display: inline-block;
  padding: 3px 5px;
  margin: -3px -5px;
  border-radius: 4px;
  cursor: pointer;
  max-width: calc(100% - 70px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}
.task-table tbody td.col-title .title-text:hover { background: var(--card); }
.task-table tbody td.col-title .open-detail-btn {
  float: right;
  background: var(--white);
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 2px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 11px;
  opacity: 0;
  transition: opacity .12s;
  font-family: inherit;
}
.task-table tbody tr:hover td.col-title .open-detail-btn { opacity: 1; }
.task-table tbody td.col-title .open-detail-btn:hover {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
}

/* Kommentarbubbla bredvid titeln — visar att en task har uppdateringar.
   Röd prick om inläsningen är äldre än senaste uppdatering. */
.task-table tbody td.col-title .update-bubble {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  vertical-align: middle;
  margin-left: 6px;
  padding: 2px 7px;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  background: var(--card);
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  font-family: inherit;
  position: relative;
  transition: background .12s, color .12s, border-color .12s;
}
.task-table tbody td.col-title .update-bubble:hover {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
}
.task-table tbody td.col-title .update-bubble.unread {
  background: #fff5e6;
  color: #b36a00;
  border-color: #f5c27a;
}
.task-table tbody td.col-title .update-bubble.unread::after {
  content: "";
  position: absolute;
  top: -2px;
  right: -2px;
  width: 7px;
  height: 7px;
  background: #df2f4a;
  border-radius: 50%;
  border: 1.5px solid #fff;
}

.task-table tfoot td {
  background: var(--card);
  border-top: 2px solid var(--border-strong);
  border-right: 1px solid var(--border);
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  height: 28px;
}
.task-table tfoot td:last-child { border-right: none; }

/* Tom rad i grupp */
.task-table tbody tr.empty-row { height: auto; }
.task-table tbody tr.empty-row td {
  text-align: center;
  color: var(--muted2);
  padding: 12px;
  font-style: italic;
  font-size: 12px;
}

/* Add-row footer per grupp */
.group-add-row {
  padding: 4px 10px;
  background: var(--card);
  border-top: 1px solid var(--border);
}
.group-add-row input {
  width: 100%;
  border: none;
  background: transparent;
  padding: 5px 4px 5px 30px;
  font-size: 13px;
  color: var(--text);
  font-family: inherit;
  outline: none;
}
.group-add-row input::placeholder { color: var(--muted2); font-size: 12px; }

.add-group-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border: 1px solid var(--border);
  background: var(--card);
  border-radius: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  transition: all .12s;
}
.add-group-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: var(--gold-bg);
}

/* ─── Cells ──────────────────────────────────────────────────── */
.cell-empty   { color: var(--muted2); }
.cell-text    { color: var(--text); }
.cell-number  { font-variant-numeric: tabular-nums; font-weight: 500; }
.cell-link    { color: var(--blue); text-decoration: none; }
.cell-link:hover { text-decoration: underline; }
.check-cell {
  display: inline-block;
  width: 22px; height: 22px;
  border-radius: 5px;
  border: 1.5px solid var(--border-strong);
  text-align: center;
  font-size: 13px;
  line-height: 19px;
  cursor: pointer;
}
.check-cell.checked {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.file-cell { font-size: 12px; color: var(--muted); }

/* File-kolumn — chip i cellen */
.file-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  padding: 2px 8px;
  background: var(--bg-soft, #f6f1e4);
  border: 1px solid var(--border);
  border-radius: 12px;
  font-size: 12px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.file-chip-count {
  padding: 0 5px;
  background: var(--gold);
  color: #fff;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
}

/* File-picker popover */
.file-picker {
  position: fixed;
  z-index: 1000;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15), 0 2px 6px rgba(0,0,0,.08);
  padding: 12px;
  width: 320px;
  max-width: 90vw;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.file-picker-header {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.file-picker-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 240px;
  overflow-y: auto;
}
.file-picker-empty {
  padding: 10px;
  text-align: center;
  color: var(--muted);
  font-size: 12px;
  font-style: italic;
}
.file-row {
  display: grid;
  grid-template-columns: 28px 1fr auto 22px;
  gap: 8px;
  align-items: center;
  padding: 4px 6px;
  border-radius: 6px;
}
.file-row:hover { background: var(--bg-soft, #f6f1e4); }
.file-row-thumb {
  width: 28px; height: 28px;
  border-radius: 5px;
  object-fit: cover;
  background: var(--bg-soft, #f6f1e4);
  border: 1px solid var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}
.file-row-ico { font-size: 14px; }
.file-row-name {
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.file-row-name:hover { color: var(--gold); text-decoration: underline; }
.file-row-size {
  font-size: 11px;
  color: var(--muted);
}
.file-row-del {
  width: 22px; height: 22px;
  border: none;
  background: transparent;
  color: var(--muted);
  border-radius: 4px;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
}
.file-row-del:hover { background: #fee; color: #c33; }
.file-picker-drop {
  padding: 18px 10px;
  border: 2px dashed var(--border-strong);
  border-radius: 8px;
  text-align: center;
  font-size: 12px;
  color: var(--muted);
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.file-picker-drop:hover,
.file-picker-drop.dragover {
  background: var(--bg-soft, #f6f1e4);
  border-color: var(--gold);
  color: var(--text);
}
.file-picker-status {
  font-size: 12px;
  color: var(--muted);
  min-height: 16px;
}
.file-picker-status-err { color: #c33; }
.file-picker-error {
  padding: 10px;
  color: #c33;
  font-size: 12px;
}
.file-picker-actions {
  display: flex;
  justify-content: flex-end;
}
.file-picker-done {
  padding: 6px 14px;
  border: 1px solid var(--border-strong);
  background: var(--gold);
  color: #fff;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}
.file-picker-done:hover { filter: brightness(1.05); }

.cell-editor {
  width: 100%;
  border: 1.5px solid var(--gold);
  background: var(--white);
  padding: 6px 9px;
  border-radius: 5px;
  font-size: 13px;
  font-family: inherit;
  color: var(--text);
}
.cell-editor:focus { outline: none; }
.cell-editor-textarea { resize: vertical; min-height: 60px; }

/* Status / people picker — body-portaled, fixed position */
.status-picker, .people-picker {
  position: fixed;
  z-index: 1000;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15), 0 2px 6px rgba(0,0,0,.08);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 200px;
  max-height: 360px;
  overflow-y: auto;
}
.status-pick {
  border: 1px solid transparent;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  font-size: 12px;
  padding: 6px 10px;
}
.status-pick.selected {
  border-color: var(--text);
  box-shadow: 0 0 0 2px var(--card);
}
.status-clear {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 6px 10px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 11px;
  margin-top: 4px;
  font-family: inherit;
}
.status-clear:hover { color: var(--neg); border-color: var(--neg); }

.status-edit-link {
  background: transparent;
  border: none;
  border-top: 1px solid var(--border);
  color: var(--muted);
  padding: 8px 6px 4px;
  cursor: pointer;
  font-size: 11px;
  font-weight: 500;
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
  text-align: left;
  border-radius: 0;
}
.status-edit-link:hover { color: var(--gold); }
.status-edit-link span { font-size: 13px; }

/* People picker */
.people-pick {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 5px;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  font-size: 12px;
  color: var(--text);
}
.people-pick:hover { background: var(--card2); }
.people-pick.selected {
  background: var(--gold-bg);
  border-color: var(--gold-border);
}
.people-pick .check { margin-left: auto; color: var(--gold); font-weight: 600; }
.people-done { margin-top: 6px; }

/* Avatar */
.avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #fff;
  font-weight: 600;
  font-size: 11px;
}
.avatar-sm { width: 26px; height: 26px; font-size: 10px; }
.avatar-md { width: 32px; height: 32px; font-size: 11px; }
.avatar-lg { width: 40px; height: 40px; font-size: 13px; }
.avatar-extra { background: var(--card2) !important; color: var(--muted); }

.people-cell {
  display: flex;
  align-items: center;
}
.people-cell .avatar { margin-left: -4px; border: 2px solid var(--card); }
.people-cell .avatar:first-child { margin-left: 0; }

/* ─────────────────────────────────────────────────────────────
   DETALJPANEL — slide-in från höger
   ───────────────────────────────────────────────────────────── */
.detail-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.25);
  display: none;
  z-index: 200;
}
.detail-overlay.open { display: block; }

.detail-panel {
  position: fixed;
  top: 0; right: 0;
  height: 100vh;
  width: 720px;
  max-width: calc(100vw - 40px);
  background: var(--card);
  border-left: 1px solid var(--border);
  box-shadow: -10px 0 40px rgba(0,0,0,.15);
  display: flex;
  flex-direction: column;
  z-index: 201;
  transform: translateX(100%);
  transition: transform .25s cubic-bezier(.4,0,.2,1);
  overflow: hidden; /* förhindra att hela panelen skalar — inre barn får scrolla */
}
.detail-panel.open { transform: translateX(0); }

/* Header: titeln är alltid synlig, meta-bar (fältvärden) scrollar internt om
   det finns fler kolumner än som får plats (Säljmappen har 19 kolumner). */
.detail-header {
  padding: 18px 22px 14px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: var(--detail-header-max, 55vh);
}

/* Drag-handle mellan meta-bar och flikar — låter användaren ge mer plats
   åt Uppdateringar/Filer/Aktivitet utan att meta-fälten försvinner. */
.detail-resize-handle {
  height: 8px;
  cursor: ns-resize;
  background: transparent;
  position: relative;
  flex-shrink: 0;
  user-select: none;
  touch-action: none;
}
.detail-resize-handle::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 40px;
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  transition: background .15s, width .15s;
}
.detail-resize-handle:hover::before,
.detail-resize-handle.dragging::before {
  background: var(--gold);
  width: 60px;
}
.detail-header .top {
  flex-shrink: 0;
}
.detail-header .detail-meta-bar {
  overflow-y: auto;
  min-height: 0;
  /* Diskret scroll-indikator längst ner när det finns mer att se */
  mask-image: linear-gradient(to bottom, black calc(100% - 20px), transparent);
  -webkit-mask-image: linear-gradient(to bottom, black calc(100% - 20px), transparent);
}
.detail-header .detail-meta-bar:hover {
  mask-image: none;
  -webkit-mask-image: none;
}
.detail-header .top {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.detail-header .top .close-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  font-size: 22px;
  cursor: pointer;
  padding: 0 6px;
  line-height: 1;
}
.detail-header .top .close-btn:hover { color: var(--text); }
.detail-header h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  flex: 1;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
}
.detail-header h2:hover { background: var(--card2); }
.detail-header h2 input {
  width: 100%;
  background: var(--card2);
  border: 1.5px solid var(--gold);
  font-size: 18px;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 4px;
  font-family: inherit;
  color: var(--text);
}

.detail-meta-bar {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 6px 14px;
  font-size: 12px;
  color: var(--muted);
}
.detail-meta-bar .label { padding: 6px 0; }
.detail-meta-bar .value { padding: 4px 0; position: relative; }
.detail-meta-bar .value > .editable {
  display: inline-block;
  padding: 3px 7px;
  margin: -3px -7px;
  border-radius: 5px;
  cursor: pointer;
}
.detail-meta-bar .value > .editable:hover { background: var(--card2); }

.detail-tabs {
  display: flex;
  gap: 4px;
  padding: 0 18px;
  border-bottom: 1px solid var(--border);
  background: var(--card);
}
.detail-tab {
  background: transparent;
  border: none;
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  font-family: inherit;
}
.detail-tab:hover { color: var(--text); }
.detail-tab.active {
  color: var(--gold);
  border-bottom-color: var(--gold);
}
.detail-tab .badge {
  background: var(--card2);
  color: var(--muted);
  padding: 1px 7px;
  border-radius: 999px;
  font-size: 10px;
  margin-left: 4px;
}

.detail-body {
  flex: 1;
  overflow-y: auto;
  padding: 18px 22px;
}
.detail-pane { display: none; }
.detail-pane.active { display: block; }

/* Updates-tråd */
.update-composer {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px;
  margin-bottom: 18px;
}
.update-composer textarea {
  width: 100%;
  border: none;
  background: transparent;
  resize: vertical;
  min-height: 48px;
  font-family: inherit;
  font-size: 13px;
  color: var(--text);
  outline: none;
}
.update-composer .composer-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  border-top: 1px solid var(--border);
  padding-top: 8px;
}
.update-composer .composer-actions .file-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 5px 10px;
  border-radius: 5px;
  cursor: pointer;
  font-size: 12px;
  font-family: inherit;
}
.update-composer .composer-actions .file-btn:hover { color: var(--text); }
.update-composer .composer-actions .spacer { flex: 1; }
.update-composer .hint {
  font-size: 10px;
  color: var(--muted2);
}

.composer-attachments {
  display: none;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.composer-attach-chip {
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px 4px 4px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  max-width: 180px;
  font-size: 11px;
  color: var(--text);
}
.composer-attach-chip img {
  width: 36px;
  height: 36px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}
.composer-attach-chip .attach-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--card2);
  border-radius: 4px;
  font-size: 16px;
}
.composer-attach-chip .attach-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}
.composer-attach-chip .attach-remove {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  padding: 0 4px;
}
.composer-attach-chip .attach-remove:hover { color: var(--text); }

.update-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}
.update-attachments .update-image {
  display: block;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--border);
  max-width: 320px;
}
.update-attachments .update-image img {
  display: block;
  max-width: 100%;
  max-height: 240px;
  object-fit: contain;
  background: var(--card);
}
.update-attachments .update-file {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 12px;
  color: var(--text);
  text-decoration: none;
}
.update-attachments .update-file:hover { background: var(--card2); }

.update-list { display: flex; flex-direction: column; gap: 14px; }
.update-item {
  display: flex;
  gap: 12px;
}
.update-item .body-wrap { flex: 1; min-width: 0; }
.update-item .meta {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}
.update-item .update-delete-btn {
  margin-left: auto;
  background: transparent;
  border: none;
  padding: 2px 6px;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.15s, background 0.15s;
  color: var(--muted);
}
.update-item:hover .update-delete-btn { opacity: 0.6; }
.update-item .update-delete-btn:hover { opacity: 1; background: var(--card2); }
.update-item .update-delete-btn:disabled { opacity: 0.3; cursor: wait; }
.update-item .author { font-weight: 600; font-size: 13px; }
.update-item .when { font-size: 11px; color: var(--muted); }
.update-item .body {
  font-size: 13px;
  color: var(--text);
  line-height: 1.5;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.update-item .body .mention {
  background: var(--gold-bg);
  color: var(--amber);
  padding: 1px 5px;
  border-radius: 4px;
  font-weight: 500;
}
.update-item .reactions {
  display: flex;
  gap: 4px;
  margin-top: 6px;
  flex-wrap: wrap;
}
.update-item .reaction {
  background: var(--card2);
  border: 1px solid var(--border);
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  cursor: pointer;
}
.update-item .reaction.mine {
  background: var(--gold-bg);
  border-color: var(--gold-border);
}
.update-item .reaction-add {
  background: transparent;
  border: 1px dashed var(--border);
  padding: 2px 7px;
  border-radius: 999px;
  font-size: 11px;
  color: var(--muted2);
  cursor: pointer;
}

/* Mention dropdown */
.mention-dropdown {
  position: absolute;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-md);
  padding: 4px;
  z-index: 300;
  max-height: 220px;
  overflow-y: auto;
  min-width: 200px;
}
.mention-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  cursor: pointer;
  border-radius: 5px;
  font-size: 12px;
}
.mention-item:hover, .mention-item.active { background: var(--gold-bg); }

/* Reaction picker */
.emoji-picker {
  position: absolute;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-md);
  padding: 4px 6px;
  z-index: 300;
  display: flex;
  gap: 2px;
}
.emoji-picker button {
  background: transparent;
  border: none;
  font-size: 18px;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 5px;
}
.emoji-picker button:hover { background: var(--card2); }

/* Filer-fliken */
.file-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}
.file-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px;
  background: var(--card);
  cursor: pointer;
  transition: all .15s;
}
.file-card:hover { border-color: var(--gold-border); background: var(--gold-bg); }
.file-card .preview {
  width: 100%;
  height: 90px;
  background: var(--card2);
  border-radius: 5px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  overflow: hidden;
}
.file-card .preview img {
  width: 100%; height: 100%; object-fit: cover;
}
.file-card .name {
  font-size: 11px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.file-card .meta {
  font-size: 10px;
  color: var(--muted);
  margin-top: 2px;
}
.file-upload-zone {
  border: 2px dashed var(--border);
  border-radius: 10px;
  padding: 28px;
  text-align: center;
  color: var(--muted);
  font-size: 13px;
  margin-bottom: 14px;
  cursor: pointer;
  transition: all .15s;
}
.file-upload-zone:hover, .file-upload-zone.dragover {
  border-color: var(--gold);
  background: var(--gold-bg);
  color: var(--gold);
}

/* Aktivitet-fliken */
.activity-list { display: flex; flex-direction: column; gap: 10px; }
.activity-item {
  display: flex;
  gap: 10px;
  font-size: 12px;
  color: var(--muted);
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
}
.activity-item:last-child { border-bottom: none; }
.activity-item .when { font-size: 10px; color: var(--muted2); white-space: nowrap; }
.activity-item .text strong { color: var(--text); font-weight: 500; }

/* ═══════════════════════════════════════════════════════════
   Bulk selection — checkbox-kolumn, selected-rad-highlight
   och floating bulk action bar (likt Monday.com)
═══════════════════════════════════════════════════════════ */

/* Checkbox-kolumn: sticky längst till vänster, före col-handle */
.task-table thead th.col-select,
.task-table tbody td.col-select,
.task-table tfoot td.col-select {
  width: 32px;
  min-width: 32px;
  max-width: 32px;
  padding: 0;
  text-align: center;
  position: sticky;
  left: 0;
  background: var(--card);
  border-right: 1px solid var(--border);
}
.task-table thead th.col-select { z-index: 4; }
.task-table tbody td.col-select { z-index: 2; }
.task-table tfoot td.col-select { z-index: 2; }

.task-table tbody tr:hover td.col-select { background: var(--card2); }

/* Checkbox själv — visuell enhetlig stil över hela systemet */
.row-check,
.group-select-all {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--muted2);
  border-radius: 3px;
  background: var(--card);
  cursor: pointer;
  position: relative;
  vertical-align: middle;
  transition: all 0.12s ease;
  margin: 0;
}
.row-check:hover,
.group-select-all:hover { border-color: var(--gold); }
.row-check:checked,
.group-select-all:checked {
  background: var(--gold);
  border-color: var(--gold);
}
.row-check:checked::after,
.group-select-all:checked::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -52%);
  color: #fff;
  font-size: 12px;
  font-weight: bold;
  line-height: 1;
}
.group-select-all.indeterminate {
  background: var(--gold);
  border-color: var(--gold);
}
.group-select-all.indeterminate::after {
  content: "–";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  color: #fff;
  font-size: 13px;
  font-weight: bold;
  line-height: 1;
}

/* Dold normalt, visas vid hover på rad eller när markerad — som Monday */
.task-table tbody td.col-select .row-check {
  opacity: 0;
}
.task-table tbody tr:hover td.col-select .row-check,
.task-table tbody tr.selected td.col-select .row-check {
  opacity: 1;
}

/* Markerad rad — guldtintad bakgrund */
.task-table tbody tr.selected td {
  background: rgba(201, 169, 97, 0.10) !important;
}
.task-table tbody tr.selected:hover td {
  background: rgba(201, 169, 97, 0.16) !important;
}

/* ─── Bulk action bar ─────────────────────────────────────── */
.bulk-bar {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  z-index: 900;
  background: var(--text);
  color: #fff;
  border-radius: 10px;
  padding: 10px 14px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25), 0 2px 6px rgba(0, 0, 0, 0.12);
  display: flex;
  align-items: center;
  gap: 8px;
  opacity: 0;
  pointer-events: none;
  transition: transform 0.22s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.18s ease;
  max-width: calc(100vw - 40px);
  flex-wrap: nowrap;
  overflow-x: auto;
}
.bulk-bar.visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.bulk-count {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px 0 4px;
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  border-right: 1px solid rgba(255, 255, 255, 0.18);
  margin-right: 4px;
}
.bulk-count .badge {
  background: var(--gold);
  color: #fff;
  padding: 2px 9px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 700;
}

.bulk-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.12s ease;
}
.bulk-btn:hover {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(255, 255, 255, 0.30);
}
.bulk-btn.danger {
  color: #ff8080;
  border-color: rgba(255, 128, 128, 0.35);
}
.bulk-btn.danger:hover {
  background: rgba(255, 128, 128, 0.14);
  color: #ff9999;
}
.bulk-btn .icon {
  font-size: 14px;
  line-height: 1;
}

.bulk-clear {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: transparent;
  color: rgba(255, 255, 255, 0.65);
  border: none;
  cursor: pointer;
  font-size: 16px;
  padding: 0;
  margin-left: 4px;
  transition: all 0.12s ease;
}
.bulk-clear:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}

/* Bulk-picker popover — kopplad till bulk-bar-knapp */
.bulk-popover {
  position: fixed;
  z-index: 950;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
  padding: 8px;
  min-width: 220px;
  max-width: 340px;
  animation: bulkPopIn 0.15s ease;
}
@keyframes bulkPopIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.bulk-popover .bulk-popover-title {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 4px 6px 8px;
  font-weight: 600;
}

/* Hjälptext i bulk-baren — förklarar för användaren att cellklick = bulk-apply */
.bulk-hint {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0 10px 0 4px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.72);
  font-style: italic;
  white-space: nowrap;
  border-right: 1px solid rgba(255, 255, 255, 0.14);
  margin-right: 4px;
}

/* Banner ovanpå cell-editorn i multi-mode — "Ändrar X markerade rader" */
.bulk-edit-header {
  background: var(--gold);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  padding: 6px 10px;
  text-align: center;
  border-radius: 5px 5px 0 0;
  margin: -8px -8px 8px -8px;
}

/* När en popover-picker är i multi-mode, ge den en guldkant */
.status-picker.bulk-editing,
.people-picker.bulk-editing,
.country-picker.bulk-editing,
.timeline-picker.bulk-editing,
.rating-picker.bulk-editing {
  border: 2px solid var(--gold);
  box-shadow: 0 10px 28px rgba(201, 169, 97, 0.25), 0 2px 6px rgba(0, 0, 0, 0.12);
}

/* Inline-editors i multi-mode (text/number/date/email/phone osv) — wrappa i box */
.bulk-inline-wrap {
  background: var(--card);
  border: 2px solid var(--gold);
  border-radius: 6px;
  padding: 6px;
  box-shadow: 0 6px 18px rgba(201, 169, 97, 0.25);
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 160px;
}
.bulk-inline-wrap .bulk-edit-header {
  margin: -6px -6px 4px -6px;
}
.bulk-inline-wrap .cell-editor {
  width: 100%;
}

/* ─────────────────────────────────────────────────────────────
   CUSTOMER_LINK + CUSTOMER_METRIC (Säljmappen-kolumner)
   ───────────────────────────────────────────────────────────── */
.customer-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  background: var(--gold-bg);
  border: 1px solid var(--gold-border);
  color: var(--text);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: all .12s ease;
}
.customer-chip:hover {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
}

.customer-picker {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 10px;
  z-index: 1000;
  width: 340px;
  max-width: calc(100vw - 20px);
}
.customer-picker .cust-search {
  width: 100%;
  border: 1px solid var(--border);
  background: var(--white);
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  outline: none;
  color: var(--text);
}
.customer-picker .cust-search:focus { border-color: var(--gold); }
.customer-picker .cust-results {
  margin-top: 6px;
  max-height: 260px;
  overflow-y: auto;
}
.customer-picker .cust-loading,
.customer-picker .cust-empty {
  padding: 10px;
  font-size: 11px;
  color: var(--muted);
  text-align: center;
}
.customer-picker .cust-result {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
  background: transparent;
  border: 1px solid transparent;
  text-align: left;
  padding: 7px 10px;
  border-radius: 5px;
  cursor: pointer;
  font-family: inherit;
  color: var(--text);
  margin-bottom: 2px;
}
.customer-picker .cust-result:hover {
  background: var(--gold-bg);
  border-color: var(--gold-border);
}
.customer-picker .cust-result .cust-name {
  font-size: 12px;
  font-weight: 600;
}
.customer-picker .cust-result .cust-sales {
  display: flex;
  gap: 8px;
  font-size: 10px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}
.customer-picker .cust-result .cust-sales-vt { color: var(--text); font-weight: 600; }
.customer-picker .cust-result .cust-sales-prev { color: var(--muted); }
.customer-picker .cust-result .cust-meta {
  font-size: 10px;
  color: var(--muted);
}
.customer-picker .cust-actions {
  display: flex;
  gap: 6px;
  margin-top: 6px;
}
.customer-picker .cust-manual,
.customer-picker .cust-clear {
  flex: 1;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 6px 10px;
  border-radius: 5px;
  font-size: 11px;
  cursor: pointer;
  font-family: inherit;
}
.customer-picker .cust-manual:hover { color: var(--gold); border-color: var(--gold); }
.customer-picker .cust-clear:hover  { color: var(--neg);  border-color: var(--neg);  }

/* Kundsiffra / customer_metric */
.metric-cell {
  display: inline-block;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
}
.metric-cell.stale { opacity: 0.55; font-style: italic; }
.metric-empty { color: var(--muted); cursor: help; }

.metric-info {
  position: fixed;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 12px 14px;
  z-index: 1000;
  width: 280px;
  max-width: calc(100vw - 20px);
}
.metric-info-title { font-size: 13px; font-weight: 700; margin-bottom: 6px; }
.metric-info-body  { font-size: 12px; color: var(--text); margin-bottom: 8px; }
.metric-info-hint  { font-size: 11px; color: var(--muted); line-height: 1.5; margin-bottom: 10px; }
.metric-info .metric-close {
  width: 100%;
  background: var(--gold-bg);
  border: 1px solid var(--gold-border);
  color: var(--text);
  padding: 6px 10px;
  border-radius: 5px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
}

/* Kund-detaljpanel / artikel-modal */
.customer-panel-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.35);
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 2000;
  padding: 40px 20px;
  overflow-y: auto;
}
.customer-panel-backdrop.open { display: flex; }
.customer-panel {
  background: var(--card);
  border-radius: 12px;
  box-shadow: 0 16px 48px rgba(0,0,0,.25);
  width: min(900px, 100%);
  padding: 0;
  overflow: hidden;
}
.customer-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 22px;
  border-bottom: 1px solid var(--border);
  background: var(--gold-bg);
}
.customer-panel-header h3 { margin: 0; font-size: 18px; }
.customer-panel-header .cp-sub { font-size: 11px; color: var(--muted); margin-top: 2px; }
.customer-panel-header .cp-close {
  background: transparent; border: none; color: var(--muted);
  font-size: 22px; cursor: pointer; padding: 0 6px;
}
.customer-panel-header .cp-actions {
  display: flex; gap: 8px; align-items: center;
}
.cp-action-btn {
  background: rgba(255,255,255,0.8);
  border: 1px solid var(--gold-border);
  color: var(--text);
  padding: 7px 14px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all .12s ease;
  white-space: nowrap;
}
.cp-action-btn:hover {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
}
.cp-action-btn.cp-danger {
  border-color: #f0a6af;
  color: #bb3354;
  background: #fff;
}
.cp-action-btn.cp-danger:hover {
  background: #df2f4a;
  color: #fff;
  border-color: #df2f4a;
}
.customer-panel-body { padding: 18px 22px; }
.customer-panel .cp-kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.customer-panel .cp-kpi {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
}
.customer-panel .cp-kpi .label { font-size: 10px; text-transform: uppercase; color: var(--muted); letter-spacing: .5px; }
.customer-panel .cp-kpi .value { font-size: 18px; font-weight: 700; margin-top: 2px; font-variant-numeric: tabular-nums; }
.customer-panel .cp-kpi .sub   { font-size: 10px; color: var(--muted); margin-top: 2px; }
.customer-panel .cp-section-title {
  font-size: 12px; text-transform: uppercase; color: var(--muted);
  letter-spacing: .6px; margin: 16px 0 8px 0;
}
.customer-panel table.cp-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
}
.customer-panel table.cp-table th,
.customer-panel table.cp-table td {
  text-align: left; padding: 6px 10px;
  border-bottom: 1px solid var(--border);
}
.customer-panel table.cp-table th {
  font-size: 10px; text-transform: uppercase;
  color: var(--muted); letter-spacing: .5px; font-weight: 600;
}
.customer-panel table.cp-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.customer-panel .cp-empty { padding: 14px; color: var(--muted); text-align: center; font-size: 12px; }
.customer-panel .cp-loading { padding: 20px; color: var(--muted); text-align: center; font-size: 12px; }

/* Verktygsradknapp: Uppdatera kundsiffror */
.btn-refresh-metrics { display: inline-flex; align-items: center; gap: 4px; }
.btn-refresh-metrics.spinning { opacity: 0.6; pointer-events: none; }
.btn-refresh-metrics.spinning::before { content: '⏳ '; }

/* ─────────────────────────────────────────────────────────────
   FAST RAD-HÖJD + ELLIPSIS
   Celler klipps till 32 px och span:en får nowrap + ellipsis så
   en lång text inte expanderar raden. Hovra för att se allt via
   title-attribut, klicka på raden för detaljpanelen.
   ───────────────────────────────────────────────────────────── */
.task-table tbody tr { height: 32px; }
.task-table tbody td.cell {
  height: 32px;
  max-height: 32px;
  overflow: hidden;
}
.task-table tbody td.cell > .cell-text,
.task-table tbody td.cell > .cell-empty,
.task-table tbody td.cell > .location-cell,
.task-table tbody td.cell > .customer-chip,
.task-table tbody td.cell > .country-cell,
.task-table tbody td.cell > .link-cell,
.task-table tbody td.cell > .email-cell,
.task-table tbody td.cell > .phone-cell {
  display: inline-block;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}
/* Cellen ska bli "klickbar" så man kan öppna detaljpanelen snabbt */
.task-table tbody td.cell { cursor: default; }

/* ─────────────────────────────────────────────────────────────
   SCROLL — robusthet
   Säkerställ att .board-main alltid har en egen scroll-kontekst
   även när det är många grupper/rader. overscroll-behavior:contain
   hindrar scroll-proxyn från att stjäla mushjulet från board-main.
   ───────────────────────────────────────────────────────────── */
body.board-page-body { max-height: 100vh; }
.app-shell { height: 100%; }
.board-main {
  min-height: 0;
  flex: 1 1 0;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
}
/* Ge plats för den fixed horisontella scroll-proxyn längst ner */
.board-content { padding-bottom: 30px !important; }

/* ─────────────────────────────────────────────────────────────
   GRUPP DRAG-AND-DROP (Monday-stil)
   ⋮⋮-handtag i varje grupp-header. Dras för att flytta hela
   gruppen upp/ned. Drop-indikator ovanför/under målgruppen.
   ───────────────────────────────────────────────────────────── */
.group-header .group-drag-handle {
  color: var(--muted2);
  cursor: grab;
  padding: 2px 4px;
  font-size: 14px;
  line-height: 1;
  letter-spacing: -2px;
  user-select: none;
  opacity: 0;
  transition: opacity .12s, color .12s;
  font-weight: 700;
}
.group:hover .group-header .group-drag-handle { opacity: 1; }
.group-header .group-drag-handle:hover { color: var(--text); }
.group-header .group-drag-handle:active { cursor: grabbing; }

/* Dra-på-gång: dämpa originalgruppen */
.group.group-dragging { opacity: 0.45; }

/* Drop-zoner: tydlig guldlinje ovanför/under target-gruppen */
.group.group-drop-above {
  box-shadow: 0 -3px 0 0 var(--gold);
  border-radius: 3px;
}
.group.group-drop-below {
  box-shadow: 0 3px 0 0 var(--gold);
  border-radius: 3px;
}

/* När en grupp dras: alla grupp-headers får lite markering så man ser drop-zonerna */
body.group-dragging .group .group-header {
  outline: 1px dashed var(--border);
  outline-offset: -2px;
}

/* ─── Mina uppgifter — tavla-filter ─────────────────────── */
.tasks-filter-btn {
  margin-left: auto;
  font-size: 12px;
  padding: 3px 10px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: var(--surface);
  color: var(--text-muted);
  cursor: pointer;
  transition: border-color .15s, color .15s;
  line-height: 1.6;
}
.tasks-filter-btn:hover {
  border-color: var(--gold);
  color: var(--text);
}
.tasks-filter-panel {
  padding: 0 0 10px 0;
}
.filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.filter-chip {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 20px;
  border: 1.5px solid var(--border);
  font-size: 12px;
  cursor: pointer;
  user-select: none;
  transition: border-color .15s, opacity .15s, background .15s;
  opacity: 0.45;
  background: transparent;
  color: var(--text);
}
.filter-chip.active {
  opacity: 1;
  border-color: var(--gold);
  background: color-mix(in srgb, var(--gold) 10%, transparent);
}
.filter-chip .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════
   Mobil-anpassning — Monday-stil (kompakt, tighta kort med skugga,
   tydliga sektioner). Aktiveras när kosa-mobile-shell är på (<768px).
═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Dölj egen topbar — mobile-shell har redan top + bottom nav */
  html[data-kosa-mobile-shell="1"] .topbar { display: none !important; }
  html[data-kosa-mobile-shell="1"] body.board-page-body { height: auto !important; min-height: 100dvh; }

  html[data-kosa-mobile-shell="1"] body {
    background: var(--bg) !important;
  }
  html[data-kosa-mobile-shell="1"] .page {
    padding: 10px 10px 16px !important;
    max-width: 100% !important;
  }

  /* Page header: kompakt rubrik + actions sida vid sida */
  html[data-kosa-mobile-shell="1"] .page-header {
    flex-direction: column;
    align-items: stretch !important;
    gap: 10px;
    margin-bottom: 12px !important;
  }
  html[data-kosa-mobile-shell="1"] .page-header h1 {
    font-size: 22px !important;
    line-height: 1.1;
  }
  html[data-kosa-mobile-shell="1"] .page-header .subtitle {
    font-size: 12px !important;
  }
  html[data-kosa-mobile-shell="1"] .page-header .actions {
    flex-direction: row;
    gap: 8px;
  }
  html[data-kosa-mobile-shell="1"] .page-header .actions .btn {
    flex: 1;
    min-height: 40px;
    font-size: 13px;
    border-radius: 10px;
  }

  /* KPI-rad 2x2 — Monday-stil: kompaktare, mer markerad */
  html[data-kosa-mobile-shell="1"] .kpi-row {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
  }
  html[data-kosa-mobile-shell="1"] .kpi {
    padding: 10px 12px !important;
    border-radius: 12px !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.03);
  }
  html[data-kosa-mobile-shell="1"] .kpi .label {
    font-size: 10px !important;
    letter-spacing: .03em;
  }
  html[data-kosa-mobile-shell="1"] .kpi .value {
    font-size: 20px !important;
    margin-top: 2px !important;
  }

  /* Sektion-kort — större radius, subtil skugga, mindre padding */
  html[data-kosa-mobile-shell="1"] .section {
    border-radius: 14px !important;
    padding: 14px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.03);
    margin-bottom: 12px;
  }
  html[data-kosa-mobile-shell="1"] .section h2 {
    font-size: 14px !important;
    margin-bottom: 10px !important;
  }

  /* Main-grid stack */
  html[data-kosa-mobile-shell="1"] .main-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* Task-rader: kompaktare med tydligare separator */
  html[data-kosa-mobile-shell="1"] .task-row {
    padding: 10px 0 !important;
    grid-template-columns: 1fr auto !important;
  }
  html[data-kosa-mobile-shell="1"] .task-row .task-title { font-size: 13.5px !important; }
  html[data-kosa-mobile-shell="1"] .task-row .task-meta { font-size: 10.5px !important; }

  /* Board-grid (tavellistan): tighta Monday-stilade kort */
  html[data-kosa-mobile-shell="1"] .boards-grid,
  html[data-kosa-mobile-shell="1"] .board-cards {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  html[data-kosa-mobile-shell="1"] .board-card {
    border-radius: 14px !important;
    padding: 12px 14px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.03);
  }

  /* Board-toolbar (board.html): packa + visa bara tabell-vyn */
  html[data-kosa-mobile-shell="1"] .board-toolbar {
    flex-wrap: wrap;
    gap: 8px !important;
    padding: 8px 10px !important;
    border-radius: 12px;
    background: var(--card);
    margin: 0 0 10px;
  }
  html[data-kosa-mobile-shell="1"] .view-tabs { display: none !important; }

  /* Sökruta + filter på board */
  html[data-kosa-mobile-shell="1"] .board-search { min-width: 0 !important; flex: 1; }
  html[data-kosa-mobile-shell="1"] .board-search input { min-height: 36px; }

  /* Detail-panel som fullscreen overlay */
  html[data-kosa-mobile-shell="1"] .detail-panel,
  html[data-kosa-mobile-shell="1"] #task-detail-panel,
  html[data-kosa-mobile-shell="1"] .task-detail {
    position: fixed !important;
    top: calc(52px + env(safe-area-inset-top, 0px)) !important;
    left: 0 !important;
    right: 0 !important;
    bottom: calc(64px + env(safe-area-inset-bottom, 0px)) !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: auto !important;
    z-index: 950 !important;
  }
  html[data-kosa-mobile-shell="1"] .detail-resize-handle,
  html[data-kosa-mobile-shell="1"] .panel-resize-handle { display: none !important; }

  /* Board-main: stack */
  html[data-kosa-mobile-shell="1"] .board-main { flex-direction: column !important; }
  html[data-kosa-mobile-shell="1"] .board-sidebar { display: none !important; }

  /* Grupp-header Monday-stil: kompakt med tydligare chip-look */
  html[data-kosa-mobile-shell="1"] .group-header,
  html[data-kosa-mobile-shell="1"] .board-group-header {
    padding: 10px 12px !important;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    margin-top: 12px;
  }

  /* Tabell-rader: kompaktare (Monday-aktiga) */
  html[data-kosa-mobile-shell="1"] .table-scroll-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  html[data-kosa-mobile-shell="1"] .board-table th,
  html[data-kosa-mobile-shell="1"] .board-table td {
    padding: 6px 10px !important;
    font-size: 13px;
  }
  html[data-kosa-mobile-shell="1"] .board-table tr { min-height: 36px; }

  /* Inline-edit popovers — mer plats */
  html[data-kosa-mobile-shell="1"] .cell-popover,
  html[data-kosa-mobile-shell="1"] .edit-popover {
    max-width: calc(100vw - 24px) !important;
  }

  /* Modaler: bottom-sheet känsla */
  html[data-kosa-mobile-shell="1"] .modal,
  html[data-kosa-mobile-shell="1"] .modal-content {
    max-width: 100vw !important;
    margin: 0 !important;
    border-radius: 16px 16px 0 0 !important;
  }
  html[data-kosa-mobile-shell="1"] .modal-overlay {
    align-items: flex-end !important;
  }

  /* Profilsida — formulär stack */
  html[data-kosa-mobile-shell="1"] .profile-grid,
  html[data-kosa-mobile-shell="1"] .profile-form {
    grid-template-columns: 1fr !important;
  }

  /* Touch-target på knappar */
  html[data-kosa-mobile-shell="1"] .btn,
  html[data-kosa-mobile-shell="1"] button.btn,
  html[data-kosa-mobile-shell="1"] .icon-btn { min-height: 36px; }
  html[data-kosa-mobile-shell="1"] .btn { border-radius: 10px; }

  /* Notiscenter (klockan) — finns i drawer-headern istället */
  html[data-kosa-mobile-shell="1"] #kosa-notif-bell { display: none !important; }
}

@media (max-width: 480px) {
  html[data-kosa-mobile-shell="1"] .kpi-row {
    grid-template-columns: 1fr !important;
  }
}

