/* Workova design tokens + shared styles */
:root {
  --bg: #1e1f21;
  --bg-2: #25262a;
  --bg-3: #2e2f33;
  --card: #25262a;
  --card-2: #2e2f33;
  --border: rgba(255, 255, 255, 0.07);
  --border-2: rgba(255, 255, 255, 0.12);
  --text: #f6f6f6;
  --text-2: #a8a8a8;
  --text-3: #6e6e6e;
  --accent: #7c5cff;
  --accent-2: #5b9dff;
  --accent-grad: linear-gradient(135deg, #7c5cff 0%, #5b9dff 100%);
  --success: #22c55e;
  --warn: #f59e0b;
  --danger: #ef4444;
  --info: #3b82f6;
  --radius: 16px;
  --radius-lg: 24px;
  --shadow-1: 0 4px 24px rgba(0, 0, 0, 0.35);
  --shadow-2: 0 10px 40px rgba(0, 0, 0, 0.45);
  --blur: 16px;
}
:root.light {
  --bg: #ffffff;
  --bg-2: #f7f8fa;
  --bg-3: #eef0f3;
  --card: #ffffff;
  --card-2: #f1f2f5;
  --border: #e5e7eb;
  --border-2: #d1d5db;
  --text: #1f2328;
  --text-2: #4b5563;
  --text-3: #8a93a0;
  --shadow-1: 0 1px 3px rgba(0, 0, 0, 0.06);
  --shadow-2: 0 8px 24px rgba(0, 0, 0, 0.08);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--text); font-family: 'Cairo', 'Inter', system-ui, -apple-system, sans-serif; min-height: 100vh; }
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(700px circle at 92% 8%, rgba(124, 92, 255, 0.05), transparent 55%),
    radial-gradient(600px circle at 8% 92%, rgba(91, 157, 255, 0.04), transparent 60%);
}
:root.light body::before { background: none; }
body > * { position: relative; z-index: 1; }
a { color: var(--accent-2); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Glassmorphic cards */
.card {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  backdrop-filter: blur(var(--blur)); -webkit-backdrop-filter: blur(var(--blur));
  box-shadow: var(--shadow-1);
}
.card-lg { border-radius: var(--radius-lg); box-shadow: var(--shadow-2); }

/* Collapsible company group cards (super admin Users page) */
.company-group { transition: box-shadow .15s ease; }
.company-group[open] { box-shadow: var(--shadow-2); }
.company-group > summary { list-style: none; cursor: pointer; user-select: none; }
.company-group > summary::-webkit-details-marker { display: none; }
.company-group-head {
  display: flex; align-items: center; gap: .75rem;
  padding: .9rem 1rem; border-radius: var(--radius);
  transition: background .15s ease;
}
.company-group-head:hover { background: var(--bg-3); }
.company-group[open] > summary > .company-group-head { border-bottom: 1px solid var(--border); border-radius: var(--radius) var(--radius) 0 0; }
.company-group-head::after {
  content: '▾'; font-size: .8rem; color: var(--text-2); margin-inline-start: .25rem;
  transition: transform .15s ease;
}
.company-group[open] > summary > .company-group-head::after { transform: rotate(180deg); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .6rem 1rem; border-radius: 12px; font-weight: 600; font-size: .95rem;
  border: 1px solid var(--border-2); background: var(--card-2); color: var(--text);
  cursor: pointer; transition: transform .12s, box-shadow .2s, background .2s;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,0.2); }
.btn:active { transform: translateY(0); }
.btn-primary { background: var(--accent-grad); color: white; border: 0; }
.btn-ghost { background: transparent; }
.btn-danger { background: var(--danger); color: white; border: 0; }
.btn-info { background: var(--info); color: white; border: 0; }
.btn-success { background: var(--success); color: white; border: 0; }
.btn-sm { padding: .35rem .7rem; font-size: .85rem; border-radius: 10px; }
.btn-icon { padding: .5rem; border-radius: 10px; }
.btn:disabled { opacity: .6; cursor: not-allowed; }

/* Inputs */
.input, select.input, textarea.input {
  width: 100%; padding: .65rem .9rem; border-radius: 12px; border: 1px solid var(--border-2);
  background: var(--bg-2); color: var(--text); font-family: inherit; font-size: .95rem; outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.input:focus, select.input:focus, textarea.input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(124, 92, 255, 0.22); }
.label { display: block; font-size: .8rem; color: var(--text-2); margin-bottom: .35rem; font-weight: 600; }

/* Layout */
.shell { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; transition: grid-template-columns .22s ease; }
.shell.sidebar-collapsed { grid-template-columns: 68px 1fr; }
.sidebar {
  position: sticky; top: 0; height: 100vh; padding: .8rem .6rem 1rem;
  background: var(--bg);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column; overflow: hidden;
}
.sidebar-head { display: flex; align-items: center; gap: .5rem; padding: .2rem .4rem .9rem; }
.sidebar-toggle {
  background: transparent; border: none; border-radius: 8px;
  width: 36px; height: 36px; color: var(--text-2); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: background .15s, color .15s;
}
.sidebar-toggle:hover { background: var(--card-2); color: var(--text); }
.sidebar-toggle .lucide-ic { width: 20px; height: 20px; }
.sidebar .brand { font-weight: 800; font-size: 1.1rem; display: flex; align-items: center; gap: .55rem; min-width: 0; }
.sidebar .brand .logo { width: 28px; height: 28px; border-radius: 8px; background: var(--accent-grad); box-shadow: 0 4px 10px rgba(0,0,0,.25); flex-shrink: 0; }
.sidebar .brand-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sidebar .nav { flex: 1; overflow-y: auto; overflow-x: hidden; scrollbar-width: thin; }
.sidebar .nav::-webkit-scrollbar { width: 6px; }
.sidebar .nav::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 3px; }
.sidebar-foot { margin-top: auto; padding-top: .7rem; border-top: 1px solid var(--border); }
.sidebar-user { padding: .55rem .6rem; border-radius: 12px; background: var(--card-2); }

.nav a {
  display: flex; align-items: center; gap: .7rem; padding: .5rem .7rem; border-radius: 8px; color: var(--text-2);
  text-decoration: none; margin-bottom: .15rem; font-weight: 500; font-size: .9rem; white-space: nowrap; overflow: hidden;
  border: 1px solid transparent; transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.nav a:hover { background: var(--bg-3); color: var(--text); border-color: var(--border); }
.nav a.active { background: var(--card-2); color: var(--text); font-weight: 600; border-color: var(--border); }
.nav a .ic { width: 20px; height: 20px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.nav a .ic .lucide-ic, .nav a .ic svg { width: 20px; height: 20px; stroke-width: 2; }
.nav a .nav-label { overflow: hidden; text-overflow: ellipsis; flex: 1; }

/* Collapsed state — icons only */
.shell.sidebar-collapsed .sidebar { padding-inline: .45rem; }
.shell.sidebar-collapsed .sidebar-head { padding-inline: .2rem; gap: .3rem; flex-direction: column; align-items: center; }
.shell.sidebar-collapsed .sidebar .brand-text,
.shell.sidebar-collapsed .nav a .nav-label,
.shell.sidebar-collapsed .sidebar-user-info,
.shell.sidebar-collapsed .sidebar-logout .nav-label { display: none; }
.shell.sidebar-collapsed .nav a { justify-content: center; padding: .6rem .4rem; }
.shell.sidebar-collapsed .nav a .nav-badge { position: absolute; top: 2px; inset-inline-end: 2px; margin: 0; min-width: 16px; padding: 0 4px; font-size: .62rem; }
.shell.sidebar-collapsed .sidebar-user { justify-content: center; padding: .4rem; }
.shell.sidebar-collapsed .sidebar-logout { justify-content: center; padding: .5rem; }
.nav a { position: relative; }
.nav-badge {
  margin-inline-start: auto; background: var(--danger); color: #fff; font-size: .7rem;
  font-weight: 700; padding: 1px 7px; border-radius: 999px; line-height: 1.4; min-width: 20px;
  text-align: center; box-shadow: 0 2px 6px rgba(239,68,68,.45);
}
.nav a.active .nav-badge { background: #fff; color: var(--accent); box-shadow: none; }
.lucide-ic { display: inline-flex; align-items: center; justify-content: center; width: 1em; height: 1em; vertical-align: -0.15em; color: currentColor; }
.lucide-ic svg { width: 1em; height: 1em; stroke-width: 2; }
.btn .lucide-ic { width: 1.05em; height: 1.05em; }
.btn-icon .lucide-ic { width: 1.15rem; height: 1.15rem; }
.chip .lucide-ic { width: .95em; height: .95em; }
.nav-section { font-size: .7rem; text-transform: uppercase; color: var(--text-3); letter-spacing: .08em; padding: .9rem .8rem .3rem; transition: color .15s ease; }
.nav-section:hover { color: var(--text); }

.topbar {
  display: flex; align-items: center; justify-content: space-between; padding: .9rem 1.2rem;
  border-bottom: 1px solid var(--border); background: var(--bg); position: sticky; top: 0; z-index: 10;
}

/* Topbar notifications bell */
.topbar-bell {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--card-2); border: 1px solid var(--border); color: var(--text-2);
  cursor: pointer; transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.topbar-bell:hover { background: var(--bg-3); color: var(--text); }
.topbar-bell .lucide-ic { width: 1.1rem; height: 1.1rem; }
.bell-badge {
  position: absolute; top: -4px; inset-inline-end: -4px;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--danger); color: #fff; font-size: .65rem; font-weight: 700;
  border-radius: 999px; border: 2px solid var(--bg-2);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(239,68,68,.45);
}
.bell-badge.hidden { display: none; }
.bell-panel {
  position: absolute; top: calc(100% + 8px); inset-inline-end: 0;
  width: min(380px, calc(100vw - 24px));
  background: var(--card); border: 1px solid var(--border); border-radius: 14px;
  box-shadow: 0 14px 40px rgba(0,0,0,.28);
  backdrop-filter: blur(var(--blur)); -webkit-backdrop-filter: blur(var(--blur));
  z-index: 60; display: none; overflow: hidden;
}
.bell-panel.open { display: block; animation: bell-panel-in .18s ease; }
@keyframes bell-panel-in { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.bell-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 1rem; border-bottom: 1px solid var(--border);
}
.bell-panel-head h4 { margin: 0; font-size: .95rem; font-weight: 700; }
.bell-mark-all {
  background: transparent; border: 0; color: var(--accent-2);
  cursor: pointer; font-size: .8rem; font-weight: 600; padding: .25rem .4rem; border-radius: 6px;
}
.bell-mark-all:hover { background: var(--bg-3); }
.bell-panel-tabs {
  display: flex; gap: .4rem; padding: .6rem 1rem;
  border-bottom: 1px solid var(--border);
}
.bell-tab {
  appearance: none; background: transparent; border: 0;
  padding: .4rem .9rem; border-radius: 10px; cursor: pointer;
  font-size: .85rem; font-weight: 600; color: var(--text-2);
  transition: background .15s ease, color .15s ease;
}
.bell-tab:hover { background: var(--bg-3); color: var(--text); }
.bell-tab.active { background: var(--accent); color: #fff; }
.bell-panel-list { max-height: 480px; overflow-y: auto; }
.bell-panel-empty { padding: 2rem 1rem; text-align: center; color: var(--text-3); font-size: .9rem; }
.bell-item {
  position: relative;
  display: flex; gap: .7rem;
  padding: .75rem 2rem .75rem 1rem;
  padding-inline-start: 1rem; padding-inline-end: 2rem;
  border-bottom: 1px solid var(--border); cursor: pointer;
  transition: background .15s ease;
}
.bell-item:last-child { border-bottom: 0; }
.bell-item:hover { background: var(--bg-3); }
.bell-item::after {
  content: '';
  position: absolute; top: 50%; inset-inline-end: 14px; transform: translateY(-50%);
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--accent-2); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-2) 25%, transparent);
  opacity: 0; transition: opacity .2s ease, transform .2s ease;
  pointer-events: none;
}
.bell-item.unread::after { opacity: 1; }
.bell-item-icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--card-2); border: 1px solid var(--border);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--accent-2); flex-shrink: 0;
}
.bell-item.attendance-started .bell-item-icon { color: var(--success); background: color-mix(in srgb, var(--success) 12%, var(--card-2)); }
.bell-item.attendance-ended .bell-item-icon { color: #f59e0b; background: color-mix(in srgb, #f59e0b 12%, var(--card-2)); }
.bell-item.task-created .bell-item-icon { color: var(--accent-2); background: color-mix(in srgb, var(--accent-2) 12%, var(--card-2)); }
.bell-item.task-waiting_approval .bell-item-icon { color: #f59e0b; background: color-mix(in srgb, #f59e0b 12%, var(--card-2)); }
.bell-item.task-needs_changes .bell-item-icon { color: var(--danger); background: color-mix(in srgb, var(--danger) 12%, var(--card-2)); }
.bell-item.task-approved .bell-item-icon { color: var(--success); background: color-mix(in srgb, var(--success) 12%, var(--card-2)); }
.bell-item-body { flex: 1; min-width: 0; }
.bell-item-title { font-weight: 600; font-size: .88rem; margin: 0 0 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bell-item-sub { font-size: .8rem; color: var(--text-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bell-item-time { font-size: .7rem; color: var(--text-3); margin-top: 2px; }
.main { padding: 1.2rem; }

.chip { display: inline-flex; align-items: center; gap: .35rem; padding: .25rem .55rem; border-radius: 999px; border: 1px solid var(--border-2); background: var(--card-2); font-size: .78rem; color: var(--text-2); }
.chip.primary { background: var(--accent-grad); color: white; border: 0; }
.chip.success { background: rgba(34,197,94,.15); color: var(--success); border: 1px solid rgba(34,197,94,.3); }
.chip.warn { background: rgba(245,158,11,.15); color: var(--warn); border: 1px solid rgba(245,158,11,.3); }
.chip.danger { background: rgba(239,68,68,.15); color: var(--danger); border: 1px solid rgba(239,68,68,.3); }

.grid { display: grid; gap: 1rem; }
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.grid-3 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

.stat {
  padding: 1rem 1.1rem; border-radius: var(--radius); background: var(--card); border: 1px solid var(--border);
  backdrop-filter: blur(var(--blur));
}
.stat .label { font-size: .75rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .05em; }
.stat .value { font-size: 1.8rem; font-weight: 800; margin-top: .25rem; }

.table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.table th, .table td { text-align: start; padding: .7rem .75rem; border-bottom: 1px solid var(--border); }
.table th { color: var(--text-3); font-weight: 600; text-transform: uppercase; font-size: .74rem; letter-spacing: .05em; }
.table tr:hover td { background: var(--card-2); }

.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.55); backdrop-filter: blur(6px); display: none; align-items: center; justify-content: center; z-index: 100; padding: 1rem; overflow-y: auto; }
.modal-backdrop.open { display: flex; }
.modal { background: var(--bg-2); border: 1px solid var(--border-2); border-radius: var(--radius-lg); padding: 1.5rem; max-width: 480px; width: 90%; box-shadow: var(--shadow-2); max-height: calc(100vh - 2rem); overflow-y: auto; }

/* Permissions modal (admin / employees) */
.btn-xs { padding: .2rem .55rem; font-size: .72rem; border-radius: 8px; font-weight: 600; }
.perm-modal {
  width: min(900px, 96vw);
  height: min(92vh, 940px); max-height: min(92vh, 940px);
  display: flex; flex-direction: column;
  background: var(--bg-2); border: 1px solid var(--border-2);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-2);
  overflow: hidden;
}
.perm-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.2rem; border-bottom: 1px solid var(--border); gap: 1rem;
  flex-shrink: 0;
}
.perm-head-user { display: flex; align-items: center; gap: .8rem; min-width: 0; flex: 1; }
.perm-head-user-text { min-width: 0; flex: 1; }
.perm-head-title { font-weight: 700; font-size: 1rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.perm-head-sub { display: flex; align-items: center; gap: .4rem; margin-top: .25rem; font-size: .78rem; color: var(--text-3); }
.perm-close {
  appearance: none; background: transparent; border: 0; cursor: pointer;
  width: 34px; height: 34px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-2); transition: background .15s ease, color .15s ease;
  flex-shrink: 0;
}
.perm-close:hover { background: var(--bg-3); color: var(--text); }
.perm-body { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 1rem 1.2rem; display: flex; flex-direction: column; gap: .9rem; scrollbar-width: thin; scrollbar-color: var(--border-2) transparent; }
.perm-body::-webkit-scrollbar { width: 8px; }
.perm-body::-webkit-scrollbar-track { background: transparent; }
.perm-body::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 4px; }
.perm-body::-webkit-scrollbar-thumb:hover { background: var(--text-3); }
.perm-body-split { flex-direction: row; padding: 0; gap: 0; overflow: hidden; }
.perm-sidebar {
  flex: 0 0 240px; min-width: 240px;
  border-inline-end: 1px solid var(--border);
  background: var(--card-2);
  padding: .6rem .5rem;
  overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--border-2) transparent;
  display: flex; flex-direction: column; gap: 2px;
}
.perm-sidebar::-webkit-scrollbar { width: 6px; }
.perm-sidebar::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 3px; }
.perm-sidebar-item {
  appearance: none; background: transparent; border: 0; border-radius: 10px;
  padding: .65rem .7rem; cursor: pointer; text-align: start;
  display: flex; align-items: center; gap: .65rem;
  color: var(--text-2); font: inherit; font-weight: 600;
  transition: background .15s ease, color .15s ease;
  width: 100%;
}
.perm-sidebar-item:hover { background: var(--bg-3); color: var(--text); }
.perm-sidebar-item.active { background: color-mix(in srgb, var(--accent) 14%, transparent); color: var(--text); }
.perm-sidebar-item.active .perm-sidebar-icon { color: var(--accent); background: color-mix(in srgb, var(--accent) 18%, var(--bg-2)); }
.perm-sidebar-icon {
  width: 30px; height: 30px; border-radius: 9px;
  background: var(--bg-3); color: var(--text-2);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: background .15s ease, color .15s ease;
}
.perm-sidebar-label { flex: 1; font-size: .9rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.perm-sidebar-count {
  font-size: .72rem; font-weight: 700; color: var(--text-3);
  background: var(--bg-2); border: 1px solid var(--border);
  padding: .12rem .45rem; border-radius: 999px;
  font-variant-numeric: tabular-nums; flex-shrink: 0;
}
.perm-sidebar-item.active .perm-sidebar-count { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 40%, var(--border)); }
.perm-content {
  flex: 1 1 auto; min-width: 0; overflow-y: auto;
  padding: 1rem 1.2rem; display: flex; flex-direction: column; gap: .65rem;
  scrollbar-width: thin; scrollbar-color: var(--border-2) transparent;
}
.perm-content::-webkit-scrollbar { width: 8px; }
.perm-content::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 4px; }
.perm-content-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 1rem; padding-bottom: .8rem; margin-bottom: .2rem;
  border-bottom: 1px solid var(--border);
}
.perm-content-head h4 { margin: 0 0 .2rem; font-size: 1.02rem; font-weight: 700; }
.perm-content-head p { margin: 0; font-size: .82rem; color: var(--text-3); line-height: 1.45; }
.perm-content-actions { display: flex; gap: .3rem; flex-shrink: 0; }
@media (max-width: 720px) {
  .perm-body-split { flex-direction: column; }
  .perm-sidebar { flex: 0 0 auto; min-width: 0; width: 100%; border-inline-end: 0; border-bottom: 1px solid var(--border); flex-direction: row; overflow-x: auto; overflow-y: hidden; padding: .5rem .5rem; }
  .perm-sidebar-item { width: auto; flex-shrink: 0; }
  .perm-sidebar-label { max-width: 140px; }
}
.perm-group {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden;
}
.perm-group-head {
  display: flex; align-items: center; gap: .6rem;
  padding: .7rem .9rem; border-bottom: 1px solid var(--border);
  background: var(--card-2);
}
.perm-group-icon {
  width: 32px; height: 32px; border-radius: 10px;
  background: color-mix(in srgb, var(--accent-2) 10%, var(--bg-2));
  color: var(--accent-2);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.perm-group-head h4 { margin: 0; font-size: .9rem; font-weight: 700; }
.perm-group-count { font-size: .75rem; color: var(--text-3); font-variant-numeric: tabular-nums; flex: 1; margin-inline-start: .2rem; }
.perm-group-actions { display: flex; gap: .3rem; flex-shrink: 0; }
.perm-group-body { display: flex; flex-direction: column; padding: .35rem .45rem .5rem; }
.perm-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: .7rem .8rem; border-radius: 10px; cursor: pointer;
  transition: background .15s ease;
  width: 100%; box-sizing: border-box;
}
.perm-row + .perm-row { margin-top: 2px; }
.perm-row:hover { background: var(--bg-3); }
.perm-row:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.perm-row-text { min-width: 0; flex: 1; }
.perm-row-title { font-weight: 600; font-size: .9rem; }
.perm-row-desc { font-size: .78rem; color: var(--text-3); margin-top: 2px; line-height: 1.35; }

/* Permissions toggle (button-based, RTL-safe, no input-absolute trick) */
.perm-switch {
  appearance: none; -webkit-appearance: none;
  border: 1px solid var(--border); background: var(--bg-3);
  width: 44px; height: 24px; border-radius: 999px; padding: 0;
  position: relative; cursor: pointer; flex-shrink: 0;
  transition: background .18s ease, border-color .18s ease;
  display: inline-block; vertical-align: middle;
}
.perm-switch-thumb {
  position: absolute; top: 1px; inset-inline-start: 1px;
  width: 20px; height: 20px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.3);
  transition: inset-inline-start .18s ease;
  pointer-events: none;
}
.perm-switch.on { background: var(--accent); border-color: var(--accent); }
.perm-switch.on .perm-switch-thumb { inset-inline-start: 22px; }
.perm-switch:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.perm-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: .9rem 1.2rem; border-top: 1px solid var(--border);
  background: var(--bg-2); flex-shrink: 0;
}
.perm-foot-summary { font-size: .85rem; color: var(--text-2); font-weight: 600; font-variant-numeric: tabular-nums; }
.modal h3 { margin: 0 0 .5rem; }

/* Workspace tabs (segmented horizontal pill) */
.ws-tabs { display: flex; gap: .25rem; padding: .35rem; background: var(--card-2); border: 1px solid var(--border); border-radius: 14px; margin-bottom: 1.1rem; overflow-x: auto; scrollbar-width: none; }
.ws-tabs::-webkit-scrollbar { display: none; }
.ws-tab { appearance: none; border: 0; background: transparent; padding: .6rem 1rem; border-radius: 10px; font-weight: 600; font-size: .9rem; color: var(--text-2); cursor: pointer; transition: background .15s ease, color .15s ease; white-space: nowrap; display: inline-flex; align-items: center; gap: .5rem; flex-shrink: 0; font-family: inherit; }
.ws-tab .lucide-ic, .ws-tab svg { width: 16px; height: 16px; }
.ws-tab:hover { color: var(--text); background: var(--bg-3); }
.ws-tab.active { background: var(--bg); color: var(--text); box-shadow: 0 1px 2px rgba(0,0,0,.18); }
html.light .ws-tab.active { box-shadow: 0 1px 3px rgba(15,23,42,.08); }

.kbd { font-family: ui-monospace, SF Mono, Menlo, monospace; font-size: .85rem; padding: 2px 6px; background: var(--bg-3); border: 1px solid var(--border); border-radius: 6px; }

.toast { position: fixed; bottom: 24px; inset-inline-end: 24px; background: var(--bg-2); border: 1px solid var(--border-2); padding: .9rem 1.1rem; border-radius: 12px; box-shadow: var(--shadow-2); z-index: 200; opacity: 0; transform: translateY(8px); transition: opacity .2s, transform .2s; }
.toast.show { opacity: 1; transform: translateY(0); }
.toast.error { border-inline-start: 4px solid var(--danger); }
.toast.success { border-inline-start: 4px solid var(--success); }

.top-toast-host { position: fixed; top: 14px; inset-inline: 0; display: flex; flex-direction: column; align-items: center; gap: 8px; z-index: 300; pointer-events: none; }
.top-toast { background: var(--bg-2); border: 1px solid var(--border-2); box-shadow: var(--shadow-2); padding: .6rem 1rem; border-radius: 999px; display: inline-flex; align-items: center; gap: .6rem; max-width: 90vw; font-weight: 600; opacity: 0; transform: translateY(-12px); transition: opacity .25s, transform .25s; pointer-events: auto; }
.top-toast.show { opacity: 1; transform: translateY(0); }
.top-toast.success { border-inline-start: 4px solid var(--success); }
.top-toast.info { border-inline-start: 4px solid var(--info, #4ea1ff); }
.top-toast-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--success); box-shadow: 0 0 0 3px rgba(0,200,120,.18); animation: top-toast-pulse 1.4s ease-out infinite; }
.top-toast.info .top-toast-dot { background: var(--info, #4ea1ff); box-shadow: 0 0 0 3px rgba(78,161,255,.18); }
@keyframes top-toast-pulse { 0% { box-shadow: 0 0 0 0 rgba(0,200,120,.35); } 100% { box-shadow: 0 0 0 10px rgba(0,200,120,0); } }

.status-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: var(--bg-3); margin-inline-end: .4rem; vertical-align: middle; }
.status-dot.working { background: var(--success); box-shadow: 0 0 0 0 rgba(0,200,120,.55); animation: top-toast-pulse 1.6s ease-out infinite; }
.status-dot.paused { background: var(--warn); }
.status-dot.ended { background: var(--text-subtle, #888); }
.status-dot.completed { background: var(--success); }
.status-dot.overtime { background: var(--info); box-shadow: 0 0 0 0 rgba(78,161,255,.55); animation: top-toast-pulse 1.6s ease-out infinite; }

/* Auth / splash */
.splash { min-height: 100vh; display: grid; place-items: center; padding: 1.25rem; }
.auth-card { width: 100%; max-width: 440px; padding: 2rem; }
.auth-card h1 { margin: 0 0 .5rem; font-size: 1.7rem; }
.auth-card p.sub { color: var(--text-2); margin: 0 0 1.5rem; }

/* Avatar */
.avatar { width: 36px; height: 36px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; color: white; background: var(--accent-grad); flex-shrink: 0; font-size: .85rem; }
.avatar.lg { width: 48px; height: 48px; font-size: 1rem; }

/* Kanban */
.kanban { display: grid; grid-template-columns: repeat(6, minmax(240px, 1fr)); gap: 1rem; overflow-x: auto; padding-bottom: 1rem; }
.kanban-col { min-width: 240px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: .8rem; }
.kanban-col h4 { margin: 0 0 .6rem; font-size: .85rem; text-transform: uppercase; letter-spacing: .05em; color: var(--text-2); display: flex; justify-content: space-between; }
.kanban-task { background: var(--bg-2); border: 1px solid var(--border-2); border-radius: 12px; padding: .7rem .8rem; margin-bottom: .55rem; cursor: grab; transition: transform .12s, box-shadow .15s; }
.kanban-task:hover { box-shadow: 0 4px 16px rgba(0,0,0,.2); transform: translateY(-1px); }
.kanban-task.dragging { opacity: .4; }
.kanban-task .t-title { font-weight: 600; margin-bottom: .3rem; }
.kanban-task .t-meta { display: flex; justify-content: space-between; color: var(--text-3); font-size: .78rem; align-items: center; }

/* Gantt */
.gantt { display: grid; grid-template-columns: 220px 1fr; overflow: auto; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); }
.gantt .rows { display: contents; }
.gantt .row-label { padding: .55rem .8rem; border-bottom: 1px solid var(--border); font-size: .85rem; background: var(--card-2); position: sticky; inset-inline-start: 0; z-index: 2; }
.gantt .row-track { position: relative; border-bottom: 1px solid var(--border); height: 38px; background:
  repeating-linear-gradient(to right, transparent 0, transparent calc(var(--cell) - 1px), var(--border) calc(var(--cell) - 1px), var(--border) var(--cell));
}
.gantt .bar { position: absolute; top: 6px; bottom: 6px; background: var(--accent-grad); border-radius: 8px; color: white; padding: 0 .5rem; font-size: .78rem; display: flex; align-items: center; box-shadow: 0 2px 8px rgba(0,0,0,.2); }
.gantt .bar.overdue { background: linear-gradient(135deg, #ef4444, #b91c1c); }
.gantt .bar.completed { background: linear-gradient(135deg, #22c55e, #15803d); }
.gantt .today { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--warn); }

/* Chat layout — Phase 1 */
main:has(.chat-shell) { display: flex; flex-direction: column; height: 100vh; min-height: 100vh; overflow: hidden; }
main:has(.chat-shell) > .main { flex: 1; min-height: 0; padding: 0; display: flex; }
.chat-shell { display: grid; grid-template-columns: var(--chat-sb-w, 240px) 1fr; height: 100%; width: 100%; min-height: 0; }
.chat-sidebar { border-inline-end: 1px solid var(--border); display: flex; flex-direction: column; overflow: hidden; min-height: 0; position: relative; }
.chat-sidebar-resize { position: absolute; top: 0; bottom: 0; inset-inline-end: -3px; width: 6px; cursor: col-resize; z-index: 5; user-select: none; }
.chat-sidebar-resize::before { content: ''; position: absolute; top: 0; bottom: 0; inset-inline-end: 2px; width: 2px; background: transparent; transition: background .15s ease; }
.chat-sidebar-resize:hover::before, body.chat-sb-dragging .chat-sidebar-resize::before { background: var(--accent, #6c5ce7); }
body.chat-sb-dragging { cursor: col-resize !important; user-select: none; }
body.chat-sb-dragging * { cursor: col-resize !important; }
.chat-sidebar-section { display: flex; flex-direction: column; min-height: 0; flex: 1 1 0; border-bottom: 1px solid var(--border); overflow: hidden; }
.chat-sidebar-section:last-child { border-bottom: 0; }
.chat-sidebar-section:not(.open) { flex: 0 0 auto; }
.chat-sidebar-section:not(.open) .chat-sidebar-body { display: none; }
.chat-sidebar-body { display: flex; flex-direction: column; flex: 1 1 0; min-height: 0; overflow: hidden; }
.chat-sidebar-title {
  display: flex; align-items: center; justify-content: space-between; gap: .4rem;
  padding: .55rem .8rem; font-weight: 700; font-size: .8rem;
  letter-spacing: .02em; color: var(--text-2);
  background: var(--card-2); border: 0; border-bottom: 1px solid var(--border);
  cursor: pointer; user-select: none; flex: 0 0 auto; width: 100%; text-align: start; font-family: inherit;
}
.chat-sidebar-title:hover { background: var(--bg-3); color: var(--text); }
.chat-sidebar-chev { display: inline-flex; transition: transform .18s ease; color: var(--text-3); }
.chat-sidebar-chev .lucide-ic { width: 1rem; height: 1rem; }
.chat-sidebar-section.open > .chat-sidebar-title .chat-sidebar-chev { transform: rotate(180deg); }
.chat-sidebar-body .input { margin: .4rem .6rem; width: calc(100% - 1.2rem); font-size: .85rem; padding: .45rem .7rem; flex: 0 0 auto; }
.chat-list-inner { overflow-y: auto; overflow-x: hidden; flex: 1 1 0; min-height: 0; scrollbar-width: thin; }
.chat-list-inner::-webkit-scrollbar { width: 8px; }
.chat-list-inner::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 4px; }
.chat-list-inner::-webkit-scrollbar-track { background: transparent; }

.chat-row { padding: .6rem .9rem; border-bottom: 1px solid var(--border); cursor: pointer; display: flex; gap: .6rem; align-items: center; transition: background .15s; }
.chat-row:hover { background: var(--card-2); }
.chat-row.active { background: var(--card-2); }
.chat-row-info { flex: 1; min-width: 0; }
.chat-row-top { display: flex; justify-content: space-between; gap: .3rem; align-items: center; }
.chat-row-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.chat-row-preview { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.member-row { padding: .5rem .9rem; cursor: pointer; display: flex; gap: .6rem; align-items: center; border-bottom: 1px solid var(--border); transition: background .15s; }
.member-row:hover { background: var(--card-2); }
.member-info { flex: 1; min-width: 0; }
.member-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.chat-body { display: flex; flex-direction: column; min-height: 0; }
.chat-header { padding: .7rem 1rem; border-bottom: 1px solid var(--border); background: var(--card-2); min-height: 56px; display: flex; align-items: center; }
.chat-header-info { display: flex; align-items: center; gap: .6rem; cursor: pointer; padding: .2rem .3rem; border-radius: 8px; transition: background .15s; user-select: none; flex: 1; min-width: 0; }
.chat-header-info:hover { background: var(--card); }
.chat-header-info:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.chat-header-actions { display: flex; align-items: center; gap: .25rem; margin-inline-start: auto; }

/* In-chat search */
.chat-search-bar { border-bottom: 1px solid var(--border); background: var(--card-2); display: flex; flex-direction: column; max-height: 50%; }
.csb-input-wrap { display: flex; align-items: center; gap: .5rem; padding: .5rem .8rem; border-bottom: 1px solid var(--border); }
.csb-input-wrap .lucide-ic { color: var(--text-3); width: 18px; height: 18px; flex-shrink: 0; }
.csb-input-wrap input { flex: 1; border: 0; background: transparent; color: var(--text); font: inherit; outline: none; padding: .3rem 0; font-size: .95rem; }
.csb-close { background: transparent; border: 0; cursor: pointer; color: var(--text-2); width: 28px; height: 28px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; }
.csb-close:hover { background: var(--card); color: var(--text); }
.csb-results { overflow-y: auto; flex: 1; max-height: 320px; }
.csb-empty { padding: 1rem; text-align: center; font-size: .88rem; }
.csb-hit { display: block; width: 100%; text-align: start; background: transparent; border: 0; border-bottom: 1px solid var(--border); padding: .55rem .9rem; cursor: pointer; color: inherit; font: inherit; }
.csb-hit:hover { background: var(--card); }
.csb-hit-top { display: flex; justify-content: space-between; gap: .5rem; margin-bottom: .15rem; }
.csb-hit-name { font-weight: 600; font-size: .85rem; color: var(--accent); }
.csb-hit-snippet { font-size: .88rem; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.csb-hit-snippet mark { background: rgba(124,92,255,.35); color: var(--text); padding: 0 2px; border-radius: 3px; }

.pinned-banner { display: flex; align-items: center; gap: .5rem; padding: .5rem .9rem; background: var(--card-2); border-bottom: 1px solid var(--border); color: var(--text-2); font-size: .85rem; }
.pinned-banner .lucide-ic { color: var(--accent); }
.chat-messages, .msgs { flex: 1; overflow-y: auto; padding: 1rem; display: flex; flex-direction: column; gap: .35rem; scrollbar-width: thin; background-image: url('/assets/img/chat-bg-dark.jpg'); background-repeat: repeat; background-size: 420px auto; background-attachment: local; }
html.light .chat-messages, html.light .msgs { background-image: url('/assets/img/chat-bg-light.jpg'); }
.chat-messages::-webkit-scrollbar, .msgs::-webkit-scrollbar { width: 10px; }
.chat-messages::-webkit-scrollbar-thumb, .msgs::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 5px; }
.chat-messages::-webkit-scrollbar-track, .msgs::-webkit-scrollbar-track { background: transparent; }

.msg-row { display: flex; gap: .5rem; align-items: flex-end; }
.msg-row.mine { flex-direction: row-reverse; }
.msg-row .avatar { width: 28px; height: 28px; font-size: .75rem; flex-shrink: 0; }
.msg-avatar-btn { appearance: none; background: transparent; border: 0; padding: 0; border-radius: 50%; cursor: pointer; display: inline-flex; flex-shrink: 0; transition: transform .12s ease, box-shadow .12s ease; }
.msg-avatar-btn:hover { transform: scale(1.08); box-shadow: 0 0 0 2px var(--accent) inset; }
.msg-avatar-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.msg { max-width: 70%; padding: .5rem .8rem; border-radius: 14px; background: var(--card-2); border: 1px solid var(--border-2); position: relative; word-wrap: break-word; }
.msg.mine { margin-inline-start: auto; background: var(--accent-grad); color: white; border: 0; }
.msg .sender-name { font-size: .75rem; font-weight: 600; margin-bottom: .15rem; opacity: .85; color: var(--accent); }
.msg .msg-text { white-space: pre-wrap; word-break: break-word; }
.msg .meta { font-size: .7rem; opacity: .75; margin-top: .25rem; display: flex; gap: .3rem; align-items: center; justify-content: flex-end; }
.msg .ticks { display: inline-flex; align-items: center; color: rgba(255,255,255,.85); }
.msg .ticks svg { width: 16px; height: 16px; stroke-width: 2.5; }
.msg .ticks.double svg { color: #fff; }
.msg.deleted { opacity: .6; font-style: italic; }

.typing-indicator { font-size: .8rem; opacity: .7; padding: .25rem 1rem; font-style: italic; min-height: 1.2rem; }
.composer { border-top: 1px solid var(--border); padding: .6rem .7rem; display: flex; gap: .5rem; align-items: flex-end; background: var(--card-2); }
.composer textarea { flex: 1; resize: none; min-height: 38px; max-height: 120px; padding: .5rem .7rem; border-radius: 10px; border: 1px solid var(--border); background: var(--card); color: inherit; font: inherit; line-height: 1.4; }
.composer textarea:focus { outline: none; border-color: var(--accent); }

/* Chat Phase 2: context menu, reactions, reply, edit */
.msg-dots { position: absolute; top: 4px; inset-inline-end: 4px; background: transparent; border: 0; cursor: pointer; color: inherit; opacity: 0; font-size: 1rem; padding: 0 .3rem; border-radius: 4px; line-height: 1; }
.msg:hover .msg-dots { opacity: .7; }
.msg-dots:hover { opacity: 1 !important; background: rgba(0,0,0,.15); }
.msg-ctx-menu { position: absolute; z-index: 50; background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: .3rem; min-width: 160px; box-shadow: 0 6px 20px rgba(0,0,0,.18); display: flex; flex-direction: column; }
.msg-ctx-menu button { background: transparent; border: 0; padding: .5rem .7rem; text-align: start; cursor: pointer; color: inherit; border-radius: 6px; display: flex; gap: .5rem; align-items: center; font: inherit; }
.msg-ctx-menu button:hover { background: var(--card-2); }
.msg-ctx-menu button.danger { color: #ef4444; }
.reaction-picker { position: absolute; top: -40px; inset-inline-end: 0; background: var(--card); border: 1px solid var(--border); border-radius: 20px; padding: .3rem .5rem; display: flex; gap: .3rem; box-shadow: 0 4px 12px rgba(0,0,0,.15); z-index: 20; }
.reaction-picker button { background: transparent; border: 0; font-size: 1.15rem; cursor: pointer; padding: 0 .2rem; }
.msg .reactions { display: flex; gap: .25rem; flex-wrap: wrap; margin-top: .3rem; }
.msg .reaction-chip { background: rgba(0,0,0,.15); border-radius: 12px; padding: .1rem .45rem; font-size: .78rem; cursor: pointer; user-select: none; }
.msg .reaction-chip.mine { background: rgba(124,58,237,.45); }
.msg.mine .reaction-chip { background: rgba(255,255,255,.22); }
.msg.mine .reaction-chip.mine { background: rgba(255,255,255,.4); }
.msg .reply-quote { display: flex; gap: .5rem; align-items: center; border-inline-start: 3px solid currentColor; padding: .3rem .5rem; margin-bottom: .3rem; font-size: .85rem; border-radius: 6px; background: rgba(0,0,0,.12); cursor: pointer; }
.msg.mine .reply-quote { background: rgba(255,255,255,.15); }
.reply-thumb { flex-shrink: 0; width: 36px; height: 36px; border-radius: 6px; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; background: rgba(0,0,0,.2); }
.reply-thumb img { width: 100%; height: 100%; object-fit: cover; }
.reply-thumb-icon { font-size: 1.2rem; }
.reply-quote-body { min-width: 0; flex: 1; }
.reply-quote-name { font-weight: 700; font-size: .8rem; opacity: .95; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.reply-quote-text { opacity: .85; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.msg .edited-tag { font-size: .68rem; opacity: .7; font-style: italic; }
.reply-preview { padding: .4rem .8rem; background: var(--card-2); border-inline-start: 3px solid var(--accent); display: flex; justify-content: space-between; align-items: center; gap: .5rem; }
.reply-preview .close { background: transparent; border: 0; cursor: pointer; color: inherit; padding: .2rem .4rem; border-radius: 4px; }
.reply-preview .close:hover { background: rgba(0,0,0,.1); }

/* Jump-to-message flash */
.msg.flash { animation: msg-flash 1.4s ease-out; }
@keyframes msg-flash {
  0% { box-shadow: 0 0 0 3px rgba(124,58,237,.7); background-color: rgba(124,58,237,.25); }
  100% { box-shadow: 0 0 0 0 rgba(124,58,237,0); background-color: transparent; }
}

/* Drag & drop overlay */
.chat-body { position: relative; }
.chat-body .drop-overlay { position: absolute; inset: 0; z-index: 30; display: none; align-items: center; justify-content: center; background: rgba(124,58,237,.18); border: 3px dashed var(--accent); border-radius: 12px; margin: .5rem; pointer-events: none; }
.chat-body.dragging .drop-overlay { display: flex; }
.chat-body .drop-hint { display: flex; flex-direction: column; align-items: center; gap: .5rem; color: var(--accent); font-weight: 700; font-size: 1.1rem; background: var(--card); padding: 1rem 1.5rem; border-radius: 10px; box-shadow: 0 4px 14px rgba(0,0,0,.2); }
.chat-body .drop-hint svg { width: 28px; height: 28px; }

/* Telegram-style voice player */
.voice-msg { display: flex; align-items: center; gap: .6rem; min-width: 240px; padding: .15rem 0; }
.voice-msg .voice-play { flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%; border: 0; cursor: pointer; background: #fff; color: var(--accent); display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 1px 3px rgba(0,0,0,.2); }
.msg:not(.mine) .voice-msg .voice-play { background: var(--accent); color: #fff; }
.voice-msg .voice-play svg { width: 18px; height: 18px; }
.voice-msg .voice-body { flex: 1; display: flex; flex-direction: column; gap: .2rem; min-width: 0; }
.voice-msg .voice-wave { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 2px; height: 28px; cursor: pointer; overflow: hidden; }
.voice-msg .voice-wave .vb { display: inline-block; width: 2.5px; min-height: 4px; border-radius: 2px; background: rgba(255,255,255,.55); transition: background .1s; flex: 0 0 auto; }
.msg:not(.mine) .voice-msg .voice-wave .vb { background: rgba(124,58,237,.35); }
.voice-msg .voice-progress { position: absolute; inset-block: 0; inset-inline-start: 0; width: 0%; background: rgba(255,255,255,.25); pointer-events: none; border-radius: 3px; mix-blend-mode: overlay; }
.msg:not(.mine) .voice-msg .voice-progress { background: rgba(124,58,237,.25); }
.voice-msg .voice-meta { display: flex; align-items: center; gap: .3rem; font-size: .75rem; font-variant-numeric: tabular-nums; opacity: .85; }
.voice-msg .voice-time { font-weight: 600; }

/* Telegram-style composer */
.tg-composer { align-items: center; gap: .5rem; padding: .35rem .55rem; background: var(--card-2); border: 0; border-radius: 28px; margin: .6rem 1rem 1rem; box-shadow: 0 2px 10px rgba(0,0,0,.18); }
.tg-composer textarea { border: 0; background: transparent; padding: .4rem .2rem; }
.tg-composer textarea:focus { outline: none; }
.comp-btn { background: transparent; border: 0; width: 38px; height: 38px; border-radius: 50%; cursor: pointer; color: var(--text-2); font-size: 1.2rem; display: inline-flex; align-items: center; justify-content: center; transition: background .12s, color .12s; }
.comp-btn:hover { background: var(--border); color: var(--text); }
.comp-primary { color: var(--accent); }
.comp-primary.is-send { color: #fff; background: var(--accent); }
.comp-primary.recording { color: #fff; background: var(--accent); }
@keyframes pulse-rec { 0%,100% { box-shadow:0 0 0 0 rgba(239,68,68,.6); } 50% { box-shadow:0 0 0 8px rgba(239,68,68,0); } }
.comp-cancel { color: #ef4444; }
.comp-cancel:hover { background: rgba(239,68,68,.12); color: #ef4444; }
.rec-ui { flex: 1; display: flex; align-items: center; gap: .6rem; padding: .4rem .2rem; font-variant-numeric: tabular-nums; font-weight: 600; color: var(--text); }
.rec-ui #rec-time { margin-inline-start: auto; }
.rec-dot { width: 10px; height: 10px; border-radius: 50%; background: #ef4444; animation: rec-blink 1s infinite; flex-shrink: 0; }
@keyframes rec-blink { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

.attach-menu { position: absolute; bottom: 72px; inset-inline-end: 50px; background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: .4rem; box-shadow: 0 8px 22px rgba(0,0,0,.2); z-index: 40; flex-direction: column; min-width: 190px; }
.attach-menu button { background: transparent; border: 0; padding: .6rem .8rem; text-align: start; cursor: pointer; color: inherit; display: flex; gap: .6rem; align-items: center; border-radius: 8px; font: inherit; }
.attach-menu button:hover { background: var(--card-2); }

.emoji-pop { position: fixed; background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: .35rem; box-shadow: 0 8px 22px rgba(0,0,0,.2); display: grid; grid-template-columns: repeat(8, 1fr); gap: .15rem; z-index: 60; max-width: 320px; }
.emoji-pop button { background: transparent; border: 0; font-size: 1.25rem; cursor: pointer; padding: .25rem; border-radius: 6px; }
.emoji-pop button:hover { background: var(--card-2); }

/* Date separator */
.date-sep { display: flex; justify-content: center; margin: .6rem 0; }
.date-sep span { background: rgba(0,0,0,.45); color: #fff; font-size: .78rem; padding: .2rem .7rem; border-radius: 12px; font-weight: 600; backdrop-filter: blur(4px); }

/* Telegram-style context menu wrap (reactions row + actions) */
.msg-ctx-wrap { position: absolute; z-index: 60; display: flex; flex-direction: column; gap: .4rem; align-items: flex-start; }
.msg-ctx-wrap .msg-ctx-menu { position: static; }
.ctx-reactions { display: flex; gap: .2rem; background: var(--card); border: 1px solid var(--border); border-radius: 22px; padding: .3rem .5rem; box-shadow: 0 6px 18px rgba(0,0,0,.2); align-self: flex-start; }
.ctx-reactions button { background: transparent; border: 0; font-size: 1.25rem; cursor: pointer; padding: .15rem .25rem; border-radius: 50%; transition: transform .12s; }
.ctx-reactions button:hover { transform: scale(1.25); }

/* Attachment styles */
.att-image { max-width: 280px; max-height: 320px; border-radius: 10px; display: block; cursor: pointer; }
.att-video { max-width: 320px; max-height: 320px; border-radius: 10px; display: block; }
.att-file { display: flex; align-items: center; gap: .5rem; padding: .4rem .6rem; background: rgba(0,0,0,.12); border-radius: 8px; color: inherit; text-decoration: none; }
.att-file:hover { background: rgba(0,0,0,.2); }
.forwarded-tag { font-size: .75rem; opacity: .7; font-style: italic; margin-bottom: .2rem; }

/* Utilities */
.flex { display: flex; } .items-center { align-items: center; } .justify-between { justify-content: space-between; }
.gap-1 { gap: .25rem; } .gap-2 { gap: .5rem; } .gap-3 { gap: .75rem; } .gap-4 { gap: 1rem; }
.w-full { width: 100%; } .text-sm { font-size: .88rem; } .text-xs { font-size: .78rem; }
.mt-1 { margin-top: .25rem; } .mt-2 { margin-top: .5rem; } .mt-3 { margin-top: .75rem; } .mt-4 { margin-top: 1rem; } .mt-6 { margin-top: 1.5rem; }
.mb-2 { margin-bottom: .5rem; } .mb-3 { margin-bottom: .75rem; } .mb-4 { margin-bottom: 1rem; }
.text-muted { color: var(--text-2); } .text-subtle { color: var(--text-3); }
.hidden { display: none !important; }
.spinner { width: 20px; height: 20px; border: 2px solid transparent; border-top-color: var(--accent); border-right-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

.fade-in { animation: fadeIn .25s ease both; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* Chat info side panel */
.info-panel {
  position: absolute; top: 0; bottom: 0; inset-inline-end: 0; width: 340px; max-width: 90%;
  background: var(--bg-2); border-inline-start: 1px solid var(--border);
  display: flex; flex-direction: column; z-index: 40;
  transform: translateX(100%); transition: transform .22s ease;
  box-shadow: -8px 0 24px rgba(0,0,0,.18);
}
html[dir="rtl"] .info-panel { transform: translateX(-100%); }
.info-panel.open,
html[dir="rtl"] .info-panel.open { transform: translateX(0); }
.info-panel-head { display: flex; align-items: center; gap: .6rem; padding: .7rem 1rem; border-bottom: 1px solid var(--border); background: var(--card-2); min-height: 56px; }
.info-panel-title { font-weight: 700; font-size: 1rem; }
.info-close { background: transparent; border: 0; cursor: pointer; color: var(--text); width: 36px; height: 36px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; }
.info-close:hover { background: var(--card); }
.info-panel-body { flex: 1; overflow-y: auto; padding: 1rem; }
.info-hero { display: flex; flex-direction: column; align-items: center; text-align: center; gap: .4rem; padding: 1rem 0 1.2rem; border-bottom: 1px solid var(--border); }
.info-hero .avatar.lg { width: 96px; height: 96px; font-size: 2rem; }
.info-hero .avatar.lg img, .info-hero img.avatar.lg { width: 96px; height: 96px; object-fit: cover; }
.info-avatar-btn { position: relative; padding: 0; border: 0; background: transparent; cursor: pointer; border-radius: 50%; line-height: 0; }
.info-avatar-btn .avatar.lg { display: block; }
.info-avatar-overlay { position: absolute; inset: 0; border-radius: 50%; background: rgba(0,0,0,.45); color: #fff; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .15s ease; }
.info-avatar-overlay svg { width: 26px; height: 26px; }
.info-avatar-btn:hover .info-avatar-overlay, .info-avatar-btn:focus-visible .info-avatar-overlay { opacity: 1; }
.info-title { font-size: 1.25rem; font-weight: 700; }
.info-title-row { display: flex; align-items: center; justify-content: center; gap: .5rem; flex-wrap: wrap; }
.info-rename-btn { background: transparent; border: 0; cursor: pointer; color: var(--text-3); width: 30px; height: 30px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; }
.info-rename-btn:hover { background: var(--card-2); color: var(--text); }
.info-rename-btn svg { width: 16px; height: 16px; }
.info-rename-input { max-width: 220px; text-align: center; font-weight: 600; }
.info-subtitle { color: var(--text-3); font-size: .85rem; }
.info-section-title { font-size: .75rem; text-transform: uppercase; color: var(--text-3); letter-spacing: .08em; margin: 1rem 0 .4rem; font-weight: 700; }
.msg-system { display: flex; justify-content: center; margin: .5rem 0; }
.msg-system span { background: var(--card-2); color: var(--text-3); border: 1px solid var(--border); border-radius: 12px; padding: .25rem .7rem; font-size: .8rem; max-width: 80%; text-align: center; }
.att-image { cursor: zoom-in; }
.lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.92); z-index: 9999; display: flex; align-items: center; justify-content: center; }
.lightbox-stage { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; overflow: hidden; cursor: zoom-out; }
.lightbox-img { max-width: 92vw; max-height: 92vh; object-fit: contain; transition: transform .15s ease; user-select: none; -webkit-user-drag: none; will-change: transform; }
.lightbox-toolbar { position: absolute; top: 14px; right: 14px; display: flex; gap: .35rem; z-index: 2; }
.lightbox-toolbar button { background: rgba(255,255,255,.08); border: 0; color: #fff; width: 38px; height: 38px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; font-size: .85rem; }
.lightbox-toolbar button:hover { background: rgba(255,255,255,.18); }
.lightbox-toolbar svg { width: 18px; height: 18px; }
.lightbox-nav { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.08); border: 0; color: #fff; width: 44px; height: 44px; border-radius: 50%; cursor: pointer; font-size: 1.6rem; line-height: 1; z-index: 2; }
.lightbox-nav:hover { background: rgba(255,255,255,.18); }
.lightbox-nav.prev { left: 18px; }
.lightbox-nav.next { right: 18px; }
.lightbox-counter { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); color: rgba(255,255,255,.8); font-size: .85rem; background: rgba(0,0,0,.4); padding: .25rem .6rem; border-radius: 12px; }
html[dir="rtl"] .lightbox-toolbar { right: auto; left: 14px; }
html[dir="rtl"] .lightbox-nav.prev { left: auto; right: 18px; }
html[dir="rtl"] .lightbox-nav.next { right: auto; left: 18px; }
.info-section-row { display: flex; align-items: center; justify-content: space-between; gap: .5rem; margin: 1rem 0 .4rem; }
.info-section-row .info-section-title { margin: 0; }
.info-add-btn { display: inline-flex; align-items: center; gap: .3rem; background: transparent; border: 1px solid var(--border); color: var(--text); border-radius: 8px; padding: .25rem .55rem; cursor: pointer; font-size: .8rem; }
.info-add-btn:hover { background: var(--card-2); }
.info-add-btn svg { width: 14px; height: 14px; }
.info-details { display: flex; flex-direction: column; gap: .5rem; }
.info-row { padding: .5rem .6rem; background: var(--card-2); border-radius: 10px; border: 1px solid var(--border); }
.info-row-label { font-size: .7rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .05em; }
.info-row-value { font-size: .95rem; color: var(--text); word-break: break-word; }
.info-members { display: flex; flex-direction: column; gap: .2rem; }
.info-member { display: flex; align-items: center; gap: .6rem; padding: .5rem .4rem; border-radius: 8px; }
.info-member:hover { background: var(--card-2); }
.info-member-info { flex: 1; min-width: 0; }
.info-member-av { background: transparent; border: 0; padding: 0; line-height: 0; border-radius: 50%; }
.info-member-dm { cursor: pointer; transition: transform .12s ease, box-shadow .12s ease; }
.info-member-dm:hover { transform: scale(1.06); box-shadow: 0 0 0 2px var(--accent, #6c5ce7) inset; }
.info-member-name { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.info-member-remove { background: transparent; border: 0; color: var(--text-3); width: 28px; height: 28px; border-radius: 50%; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .15s ease, background .15s ease; }
.info-member-remove svg { width: 14px; height: 14px; }
.info-member:hover .info-member-remove { opacity: 1; }
.info-member-remove:hover { background: color-mix(in srgb, var(--danger, #e25), 15% transparent); color: var(--danger, #e25); }
.info-member-promote { background: transparent; border: 0; color: var(--text-3); width: 28px; height: 28px; border-radius: 50%; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .15s ease, background .15s ease, color .15s ease; }
.info-member-promote svg { width: 15px; height: 15px; }
.info-member:hover .info-member-promote { opacity: 1; }
.info-member-promote[data-state="on"] { color: var(--accent, #6c5ce7); opacity: 1; }
.info-member-promote:hover { background: var(--card-2); color: var(--accent, #6c5ce7); }
.info-member-badge { display: inline-block; font-size: .65rem; font-weight: 700; padding: .1rem .4rem; border-radius: 8px; margin-inline-start: .35rem; vertical-align: middle; }
.info-member-badge.owner { background: color-mix(in srgb, var(--accent, #6c5ce7), 80% transparent); color: var(--accent, #6c5ce7); border: 1px solid color-mix(in srgb, var(--accent, #6c5ce7), 60% transparent); }
.info-member-badge.admin { background: color-mix(in srgb, var(--accent, #6c5ce7), 88% transparent); color: var(--accent, #6c5ce7); }

/* Telegram-style delete chat dialog */
.delete-chat-backdrop { background: rgba(0,0,0,.55); backdrop-filter: blur(6px); }
.delete-chat-dialog {
  background: #1f232b; color: #fff; border-radius: 14px; padding: 1.1rem 1.25rem 0;
  width: min(92vw, 420px); box-shadow: var(--shadow-2); overflow: hidden;
}
html.light .delete-chat-dialog { background: #fff; color: var(--text); }
.delete-chat-dialog .dcd-head { display: flex; align-items: center; gap: .7rem; margin-bottom: .7rem; }
.delete-chat-dialog .dcd-head .avatar { width: 44px; height: 44px; font-size: 1rem; }
.delete-chat-dialog .dcd-title { font-size: 1.15rem; font-weight: 700; }
.delete-chat-dialog .dcd-body { font-size: .95rem; line-height: 1.4; opacity: .92; padding-bottom: .5rem; }
.delete-chat-dialog .dcd-actions { display: flex; flex-direction: column; align-items: stretch; margin: 0 -1.25rem; }
.delete-chat-dialog .dcd-btn {
  background: transparent; border: 0; padding: .95rem 1.25rem; text-align: end;
  font: inherit; font-weight: 700; font-size: .95rem; letter-spacing: .04em;
  text-transform: uppercase; cursor: pointer; color: var(--accent);
  border-top: 1px solid rgba(255,255,255,.06);
}
html.light .delete-chat-dialog .dcd-btn { border-top-color: rgba(0,0,0,.08); }
.delete-chat-dialog .dcd-btn:hover { background: rgba(255,255,255,.04); }
html.light .delete-chat-dialog .dcd-btn:hover { background: rgba(0,0,0,.04); }
.delete-chat-dialog .dcd-btn.danger { color: #ef4444; }
.delete-chat-dialog .dcd-btn.primary { color: var(--accent); }

/* Day chips (work / vacation toggles) */
.day-chips { display: flex; gap: .35rem; flex-wrap: wrap; }
.day-chip {
  appearance: none; border: 1px solid var(--border); background: var(--card-2);
  color: var(--text-2); padding: .4rem .7rem; border-radius: 999px;
  font: inherit; font-size: .8rem; font-weight: 600; cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease, transform .12s ease;
  user-select: none;
}
.day-chip:hover { transform: translateY(-1px); }
.day-chip.on {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent);
}
.day-chip.off {
  background: var(--card-2); color: var(--text-3);
  border-color: var(--border); opacity: .85;
  text-decoration: line-through;
}

/* Chat compose FAB (lives in chat header) */
.chat-shell { position: relative; }
.chat-header-side { display: inline-flex; align-items: center; gap: .35rem; }
.chat-fab {
  width: 38px; height: 38px; border-radius: 50%; border: 0;
  background: var(--accent); color: #fff; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px color-mix(in srgb, var(--accent) 40%, transparent);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  flex-shrink: 0;
}
.chat-fab:hover { transform: translateY(-1px) scale(1.05); box-shadow: 0 8px 18px color-mix(in srgb, var(--accent) 55%, transparent); }
.chat-fab:active { transform: scale(0.96); }
.chat-fab .lucide-ic { width: 18px; height: 18px; }
.chat-fab-sm { width: 36px; height: 36px; }
.chat-fab-menu {
  position: absolute; top: calc(100% + 6px); inset-inline-end: 0; z-index: 30;
  min-width: 200px; background: var(--card); border: 1px solid var(--border); border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.28);
  padding: .35rem; opacity: 0; pointer-events: none; transform: translateY(-4px);
  transition: opacity .14s ease, transform .14s ease;
}
.chat-fab-menu.open { opacity: 1; pointer-events: auto; transform: translateY(0); }
.chat-fab-menu button {
  display: flex; align-items: center; gap: .55rem; width: 100%;
  padding: .55rem .7rem; border: 0; background: transparent; color: var(--text);
  border-radius: 8px; cursor: pointer; font: inherit; text-align: start;
}
.chat-fab-menu button:hover { background: var(--card-2); color: var(--accent); }
.chat-fab-menu button .lucide-ic { width: 18px; height: 18px; flex-shrink: 0; }

/* Member picker (used by new-group / new-chat modals) */
.new-chat-modal { display: flex; flex-direction: column; max-height: 70vh; }
.pick-list {
  border: 1px solid var(--border); border-radius: 10px;
  max-height: 320px; overflow-y: auto; background: var(--card-2);
}
.pick-list .pick-row {
  display: flex; align-items: center; gap: .6rem;
  padding: .5rem .7rem; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background .12s ease;
}
.pick-list .pick-row:last-child { border-bottom: 0; }
.pick-list .pick-row:hover { background: var(--card); }
.pick-row input[type="checkbox"] { flex-shrink: 0; }
.pick-row-av .avatar { width: 32px; height: 32px; font-size: .8rem; }
.pick-row-info { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.pick-row-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pick-row-sub { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pick-row-btn { width: 100%; border: 0; background: transparent; color: inherit; font: inherit; text-align: start; }

/* ── Push-to-talk mic button (admin) ─────────────────────────────────── */
.mic-btn { user-select: none; touch-action: none; transition: background .15s ease, color .15s ease, transform .12s ease; }
.mic-btn:hover { background: color-mix(in srgb, var(--accent) 10%, transparent); color: var(--accent); }
.mic-btn.recording { background: var(--danger); color: white; transform: scale(1.05); animation: ptt-pulse 1.2s ease-out infinite; }
@keyframes ptt-pulse { 0% { box-shadow: 0 0 0 0 rgba(255,72,72,.55); } 100% { box-shadow: 0 0 0 14px rgba(255,72,72,0); } }

/* Admin HUD shown while holding the mic button */
.ptt-hud { position: fixed; inset: auto 0 1.2rem 0; display: grid; place-items: center; z-index: 110; pointer-events: none; }
.ptt-hud-card {
  pointer-events: auto;
  background: var(--bg-2); border: 1px solid var(--border-2); border-radius: 14px;
  padding: .7rem 1rem; box-shadow: var(--shadow-2);
  display: flex; align-items: center; gap: .8rem;
}
.ptt-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--danger); box-shadow: 0 0 0 0 rgba(255,72,72,.55); animation: ptt-pulse 1.2s ease-out infinite; }
.ptt-text { display: flex; flex-direction: column; min-width: 0; }
.ptt-time { font-family: ui-monospace, monospace; font-weight: 700; font-size: 1.05rem; }
.ptt-hint { font-size: .75rem; color: var(--text-3); margin-inline-start: .4rem; }

/* Overlay the employee sees while admin talks */
.admin-voice-overlay {
  position: fixed; inset: 1rem; top: 1rem; left: 50%; transform: translateX(-50%);
  z-index: 200; display: flex; align-items: flex-start; justify-content: center;
  pointer-events: none;
}
.admin-voice-overlay .avl-card {
  pointer-events: auto; min-width: 320px; max-width: 460px;
  background: var(--bg-2); border: 1px solid var(--accent);
  border-radius: 16px; padding: 1rem 1.1rem;
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
  display: grid; grid-template-columns: auto 1fr auto; gap: .8rem; align-items: center; position: relative;
}
.admin-voice-overlay .avl-pulse {
  position: absolute; inset-inline-start: 1rem; top: 1rem; width: 48px; height: 48px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 50%, transparent) 0%, transparent 70%);
  animation: ptt-pulse 1.4s ease-out infinite; pointer-events: none;
}
.admin-voice-overlay .avl-avatar { position: relative; }
.admin-voice-overlay .avl-title { font-weight: 700; font-size: .95rem; }
.admin-voice-overlay .avl-name { font-size: .85rem; color: var(--text-2); }
.admin-voice-overlay .avl-status { font-size: .75rem; color: var(--accent); margin-top: .2rem; }
.admin-voice-overlay .avl-close { appearance: none; background: transparent; border: 0; color: var(--text-2); width: 30px; height: 30px; border-radius: 8px; cursor: pointer; }
.admin-voice-overlay .avl-close:hover { background: var(--bg-3); }
.admin-voice-overlay .avl-play { grid-column: 1 / -1; margin-top: .5rem; }

/* Contact admin panel (employee topbar) */
.contact-panel .bell-panel-list { padding: .3rem .3rem .1rem; }
.contact-row {
  display: flex; align-items: center; gap: .7rem;
  padding: .55rem .7rem; border-radius: 10px;
  transition: background .12s ease;
}
.contact-row + .contact-row { border-top: 1px solid var(--border); }
.contact-row:hover { background: var(--bg-3); }
.contact-row-av .avatar { width: 34px; height: 34px; font-size: .82rem; }
.contact-row-info { flex: 1; min-width: 0; }
.contact-row-name { font-weight: 600; font-size: .9rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.contact-row-sub { font-size: .72rem; color: var(--text-3); }
.contact-panel-hint {
  padding: .55rem .9rem; border-top: 1px solid var(--border);
  font-size: .72rem; color: var(--text-3); text-align: center; background: var(--card-2);
}
.contact-group + .contact-group { margin-top: .2rem; border-top: 1px solid var(--border); }
.contact-group-head {
  width: 100%; display: flex; align-items: center; gap: .5rem;
  padding: .6rem .9rem; border: 0; background: var(--card-2);
  font-weight: 700; font-size: .82rem; color: var(--text-2); cursor: pointer;
  text-align: start; font-family: inherit;
  transition: background .12s ease;
}
.contact-group-head:hover { background: var(--bg-3); }
.contact-group-title { flex: 1; }
.contact-group-count {
  background: var(--bg-2); border: 1px solid var(--border);
  padding: .08rem .5rem; border-radius: 999px;
  font-size: .72rem; font-weight: 700; color: var(--text-3);
}
.contact-group-caret { color: var(--text-3); transform: rotate(0); transition: transform .18s ease; }
.contact-group-caret .lucide-ic { width: .95rem; height: .95rem; }
.contact-group-head.collapsed .contact-group-caret { transform: rotate(-90deg); }
.contact-group-body { padding: .15rem 0; }

/* Urgent message — admin send panel */
.urgent-panel .urgent-body { padding: .9rem 1rem 1rem; }
.urgent-panel textarea.input { resize: vertical; min-height: 90px; max-height: 240px; }

/* Urgent message — employee-side pinned stack (bottom-inline-end) */
.urgent-stack {
  position: fixed; bottom: 1rem; inset-inline-end: 1rem;
  display: flex; flex-direction: column; gap: .6rem;
  z-index: 180; max-width: min(380px, calc(100vw - 2rem));
  pointer-events: none;
}
.urgent-card {
  pointer-events: auto;
  background: var(--bg-2);
  border: 1px solid var(--danger);
  border-inline-start: 4px solid var(--danger);
  border-radius: 14px; padding: .85rem 1rem;
  box-shadow: 0 10px 32px rgba(0,0,0,.35);
  animation: urgent-in .22s ease;
  display: flex; flex-direction: column; gap: .6rem;
}
@keyframes urgent-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.urgent-card-head { display: flex; align-items: center; gap: .6rem; }
.urgent-card-who { min-width: 0; flex: 1; }
.urgent-card-name { font-weight: 700; font-size: .92rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.urgent-card-sub { font-size: .72rem; color: var(--danger); font-weight: 600; }
.urgent-card-text { font-size: .92rem; line-height: 1.45; white-space: pre-wrap; word-break: break-word; color: var(--text); }
.urgent-card-actions { display: flex; gap: .4rem; justify-content: flex-end; }
.urgent-card .btn-primary { background: var(--danger); border-color: var(--danger); }
.urgent-card .btn-primary:hover { filter: brightness(1.08); }

/* Monthly payroll/attendance report table — highlight totals row */
.report-table thead th {
  position: sticky; top: 0; background: var(--card-2); z-index: 1;
  font-size: .75rem; letter-spacing: .04em; text-transform: uppercase; color: var(--text-3);
}
.report-table tbody td { vertical-align: middle; }
.report-table tfoot .report-totals td {
  background: color-mix(in srgb, var(--accent) 8%, var(--card-2));
  border-top: 2px solid var(--border-2);
  padding-top: .85rem; padding-bottom: .85rem;
  font-size: .92rem;
}

@media print {
  body * { visibility: hidden; }
  #rep-table-wrap, #rep-table-wrap * { visibility: visible; }
  #rep-table-wrap { position: absolute; left: 0; top: 0; width: 100%; }
  .topbar, .sidebar, .ws-tabs { display: none !important; }
}

/* ── Date range picker (GHL-inspired) ─────────────────────────────── */
.dr-wrap { position: relative; display: inline-flex; align-items: center; gap: .5rem; direction: ltr; }
.dr-field {
  display: inline-flex; align-items: center; gap: .6rem;
  background: var(--card); border: 1.5px solid var(--accent);
  border-radius: 10px; padding: .35rem .7rem; cursor: pointer;
  font-family: ui-monospace, monospace; font-weight: 600; font-size: .9rem;
}
.dr-field:hover { background: var(--card-2); }
.dr-date { color: var(--text); min-width: 9ch; text-align: center; }
.dr-arrow { color: var(--text-3); display: inline-flex; }
.dr-arrow .lucide-ic { width: .9rem; height: .9rem; transform: rotate(-90deg); }
.dr-toggle {
  appearance: none; background: transparent; border: 0; padding: .2rem;
  color: var(--text-2); cursor: pointer; display: inline-flex;
}
.dr-toggle:hover { color: var(--text); }
.dr-reload {
  appearance: none; border: 0; background: var(--accent); color: #fff;
  width: 38px; height: 38px; border-radius: 10px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: filter .15s ease;
}
.dr-reload:hover { filter: brightness(1.08); }
.dr-popover {
  position: absolute; top: calc(100% + 8px); inset-inline-start: 0;
  z-index: 80; direction: ltr;
  background: var(--card); border: 1px solid var(--border-2);
  border-radius: 14px; box-shadow: 0 14px 40px rgba(0,0,0,.32);
  padding: .75rem; min-width: 500px; max-width: 92vw;
  max-height: min(520px, 85vh); overflow-y: auto;
}
.dr-popover.dr-pop-flip-x { inset-inline-start: auto; inset-inline-end: 0; }
.dr-popover.dr-pop-flip-y { top: auto; bottom: calc(100% + 8px); }
.dr-calendars { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; margin-bottom: .6rem; }
.dr-cal { min-width: 0; }
.dr-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .35rem; gap: .3rem; }
.dr-cal-title { font-weight: 700; font-size: .88rem; color: var(--text); }
.dr-cal-nav {
  appearance: none; background: transparent; border: 0; padding: .2rem; border-radius: 6px;
  color: var(--text-2); cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px;
}
.dr-cal-nav:hover { background: var(--bg-3); color: var(--text); }
.dr-cal-nav .lucide-ic { width: .9rem; height: .9rem; }
.dr-cal-nav[data-nav="-1"] .lucide-ic { transform: rotate(90deg); }
.dr-cal-nav[data-nav="1"] .lucide-ic { transform: rotate(-90deg); }
.dr-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; }
.dr-dow { font-size: .68rem; color: var(--text-3); text-align: center; padding: .25rem 0 .2rem; font-weight: 600; }
.dr-day {
  appearance: none; background: transparent; border: 0;
  padding: .3rem 0; font: inherit; font-size: .8rem; color: var(--accent);
  cursor: pointer; border-radius: 6px; text-align: center;
  transition: background .1s ease, color .1s ease;
  min-width: 0;
}
.dr-day:hover { background: var(--bg-3); }
.dr-day.outside { color: var(--text-3); opacity: .45; }
.dr-day.in-range { background: color-mix(in srgb, var(--accent) 14%, transparent); border-radius: 0; }
.dr-day.start, .dr-day.end {
  background: var(--accent); color: #fff; font-weight: 700;
}
.dr-day.start { border-start-end-radius: 0; border-end-end-radius: 0; }
.dr-day.end { border-start-start-radius: 0; border-end-start-radius: 0; }
.dr-day.single { border-radius: 999px; }
.dr-presets {
  display: flex; gap: .3rem; flex-wrap: wrap;
  padding: .55rem 0 .4rem; border-top: 1px solid var(--border);
  margin-top: .3rem;
}
.dr-preset {
  appearance: none; background: var(--card-2); border: 1px solid var(--border);
  border-radius: 999px; padding: .3rem .7rem; font: inherit; font-size: .76rem;
  color: var(--text-2); cursor: pointer; transition: background .12s ease, color .12s ease, border-color .12s ease;
  white-space: nowrap;
}
.dr-preset:hover { background: var(--bg-3); color: var(--text); border-color: var(--border-2); }
.dr-footer { display: flex; justify-content: flex-end; gap: .4rem; padding-top: .45rem; border-top: 1px solid var(--border); }
.dr-footer .btn { padding: .4rem .9rem; font-size: .82rem; }

@media (max-width: 560px) {
  .dr-popover { min-width: 280px; }
  .dr-calendars { grid-template-columns: 1fr; }
}

/* ── Employee multiselect (GHL-inspired) ───────────────────────────── */
.emp-multi { position: relative; display: inline-block; }
.emp-multi-trigger {
  appearance: none; background: transparent; border: 0; padding: 0;
  display: inline-flex; align-items: center; gap: .35rem; cursor: pointer;
  font: inherit;
}
.emp-multi-chip-area { display: inline-flex; gap: .3rem; flex-wrap: nowrap; }
.emp-multi-chip {
  display: inline-flex; align-items: center;
  background: var(--card-2); color: var(--text-2);
  border: 1px solid var(--border);
  border-radius: 999px; padding: .3rem .8rem;
  font-size: .82rem; font-weight: 600; line-height: 1.1;
  white-space: nowrap;
}
.emp-multi-chip.all {
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
}
.emp-multi-chip.more { opacity: .85; }
.emp-multi-caret {
  color: var(--text-3); display: inline-flex; align-items: center;
  transition: transform .18s ease;
}
.emp-multi-caret .lucide-ic { width: 1rem; height: 1rem; }
.emp-multi.open .emp-multi-caret { transform: rotate(180deg); color: var(--accent); }
.emp-multi-trigger:hover .emp-multi-caret { color: var(--text-2); }

.emp-multi-pop {
  position: absolute; top: calc(100% + 8px); inset-inline-start: 0;
  z-index: 80;
  min-width: 320px; width: max-content; max-width: min(420px, 92vw);
  background: var(--card); border: 1px solid var(--border-2);
  border-radius: 14px; box-shadow: 0 18px 50px rgba(0,0,0,.35);
  padding: .5rem;
  display: flex; flex-direction: column; gap: .45rem;
}
.emp-multi-pop.emp-multi-flip-x { inset-inline-start: auto; inset-inline-end: 0; }
.emp-multi-pop.emp-multi-flip-y { top: auto; bottom: calc(100% + 8px); }
.emp-multi-search-wrap { padding: .2rem .2rem 0; }
.emp-multi-search { font-size: .88rem; border-radius: 10px; background: var(--card-2); }
.emp-multi-list {
  display: flex; flex-direction: column;
  max-height: 320px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: var(--border-2) transparent;
}
.emp-multi-list::-webkit-scrollbar { width: 6px; }
.emp-multi-list::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 3px; }
.emp-multi-row {
  display: flex; align-items: center; gap: .6rem;
  padding: .5rem .65rem; border-radius: 8px; cursor: pointer;
  transition: background .1s ease;
  margin: 1px 0;
}
.emp-multi-row:hover { background: var(--bg-3); }
.emp-multi-row input[type="checkbox"] {
  appearance: none; -webkit-appearance: none;
  width: 18px; height: 18px; border-radius: 5px;
  border: 1.5px solid var(--border-2); background: var(--card);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; transition: background .15s ease, border-color .15s ease;
  position: relative;
}
.emp-multi-row input[type="checkbox"]:checked {
  background: var(--accent); border-color: var(--accent);
}
.emp-multi-row input[type="checkbox"]:checked::after {
  content: ""; position: absolute;
  width: 5px; height: 9px;
  border: solid #fff; border-width: 0 2px 2px 0;
  transform: rotate(45deg); top: 1px; left: 5px;
}
.emp-multi-row .avatar { width: 30px; height: 30px; font-size: .76rem; flex-shrink: 0; }
.emp-multi-row .emp-multi-name {
  flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-size: .88rem; font-weight: 500; color: var(--text);
}
.emp-multi-row.all-row {
  border-bottom: 1px solid var(--border);
  padding-bottom: .6rem; margin-bottom: .2rem;
  font-weight: 600;
}
.emp-multi-row.all-row .emp-multi-name { font-weight: 700; }

/* ── Staff table (GHL-inspired) ─────────────────────────────────── */
.staff-bar {
  display: grid;
  grid-template-columns: minmax(180px, 240px) 1fr auto;
  gap: .8rem;
  align-items: center;
}
.staff-role { font-weight: 600; }
.staff-search {
  display: flex; align-items: center; gap: .5rem;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 0 .8rem;
  transition: border-color .15s ease;
}
.staff-search:focus-within { border-color: var(--accent); }
.staff-search .lucide-ic { width: 1rem; height: 1rem; color: var(--text-3); flex-shrink: 0; }
.staff-search .input {
  background: transparent; border: 0; padding: .6rem 0;
  font-size: .92rem; flex: 1; outline: none; color: var(--text);
}
.staff-add { padding: .6rem 1.3rem; font-weight: 700; }

.staff-table thead th {
  padding: .9rem 1rem; font-size: .82rem; color: var(--text-3);
  text-transform: none; letter-spacing: 0;
  background: var(--card-2);
}
.staff-table tbody td { padding: .9rem 1rem; vertical-align: middle; }
.staff-table tbody tr + tr td { border-top: 1px solid var(--border); }
.staff-row-off { opacity: .55; }
.staff-name-cell { display: flex; align-items: center; gap: .7rem; min-width: 0; }
.staff-name { font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 220px; }
.staff-muted { color: var(--text-2); font-size: .9rem; }

.staff-role-tag {
  display: inline-block; padding: .28rem .7rem;
  background: var(--card-2); color: var(--text-2);
  border: 1px solid var(--border); border-radius: 999px;
  font-size: .72rem; font-weight: 700; letter-spacing: .04em;
}
.staff-role-tag.admin {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
}

.staff-actions { display: inline-flex; gap: .35rem; }
.staff-icon-btn {
  appearance: none; background: transparent; border: 0;
  width: 34px; height: 34px; border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-2); cursor: pointer;
  transition: background .12s ease, color .12s ease;
}
.staff-icon-btn:hover { background: var(--bg-3); color: var(--text); }
.staff-icon-btn.danger:hover { background: color-mix(in srgb, var(--danger) 16%, transparent); color: var(--danger); }
.staff-icon-btn .lucide-ic { width: 1.05rem; height: 1.05rem; }

.staff-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: .7rem 1rem; border-top: 1px solid var(--border);
  background: var(--card-2);
  gap: .8rem; flex-wrap: wrap;
}
.staff-pager { display: inline-flex; gap: .35rem; }
.staff-pager .btn-sm { min-width: 36px; }

@media (max-width: 780px) {
  .staff-bar { grid-template-columns: 1fr; }
  .staff-table tbody td { padding: .75rem .6rem; }
  .staff-name { max-width: 140px; }
}

/* ── Edit employee modal extras ─────────────────────────────────── */
.edit-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: .8rem 1rem;
}
.edit-grid .label { margin-bottom: .25rem; }
.edit-grid > div { min-width: 0; }
@media (max-width: 680px) { .edit-grid { grid-template-columns: 1fr; } }

/* Permission groups as tabs inside the Permissions section */
.perm-group-tabs {
  display: flex; gap: .35rem; flex-wrap: wrap;
  padding: .3rem; margin-bottom: .7rem;
  background: var(--card-2); border: 1px solid var(--border); border-radius: 12px;
}
.perm-group-tab {
  appearance: none; background: transparent; border: 0;
  padding: .45rem .7rem; border-radius: 8px; cursor: pointer;
  display: inline-flex; align-items: center; gap: .4rem;
  font: inherit; font-size: .82rem; font-weight: 600; color: var(--text-2);
  transition: background .12s ease, color .12s ease;
}
.perm-group-tab:hover { background: var(--bg-3); color: var(--text); }
.perm-group-tab.active {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--accent);
}
.perm-group-tab .lucide-ic { width: .9rem; height: .9rem; }
.perm-group-tab .chip { background: var(--bg-2); color: var(--text-3); font-size: .7rem; padding: .1rem .4rem; }
.perm-group-tab.active .chip { background: var(--bg-2); color: var(--accent); }

/* ── Settings shell (sectioned sidebar, GHL-inspired) ─────────────── */
.settings-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 1.2rem;
  align-items: start;
}
.settings-aside {
  position: sticky; top: 0;
  background: var(--bg-2); border: 1px solid var(--border); border-radius: 16px;
  padding: .4rem;
  max-height: calc(100vh - var(--topbar-h, 4rem) - 2rem);
  overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: var(--border-2) transparent;
}
.settings-aside-head { padding: .7rem .8rem .3rem; }
.settings-aside-head h3 { font-size: 1.1rem; font-weight: 800; }
.settings-nav { display: flex; flex-direction: column; gap: 1px; padding: .2rem; }
.settings-group-label {
  padding: .7rem .7rem .35rem;
  font-size: .68rem; font-weight: 700; letter-spacing: .08em;
  color: var(--text-3); text-transform: uppercase;
}
.settings-nav-item {
  appearance: none; background: transparent; border: 0; border-radius: 10px;
  padding: .55rem .7rem; cursor: pointer; text-align: start;
  display: flex; align-items: center; gap: .6rem;
  color: var(--text-2); font: inherit; font-weight: 600; font-size: .9rem;
  transition: background .12s ease, color .12s ease;
  position: relative;
}
.settings-nav-item:hover { background: var(--bg-3); color: var(--text); }
.settings-nav-item.active {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--text);
}
.settings-nav-item.active::before {
  content: ""; position: absolute; inset-inline-start: -.4rem; top: 25%; bottom: 25%;
  width: 3px; border-radius: 2px; background: var(--accent);
}
.settings-nav-icon {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--bg-3); color: var(--text-2);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: background .12s ease, color .12s ease;
}
.settings-nav-item.active .settings-nav-icon {
  background: color-mix(in srgb, var(--accent) 18%, var(--bg-2));
  color: var(--accent);
}
.settings-nav-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.settings-content { min-width: 0; }
.settings-section { animation: fade-in .2s ease; }
.settings-section-head { margin-bottom: 1rem; }
.settings-section-head h2 { margin: 0 0 .25rem; font-size: 1.35rem; font-weight: 800; }
.settings-section-head p { margin: 0; color: var(--text-3); font-size: .88rem; line-height: 1.5; }

@keyframes fade-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 780px) {
  .settings-shell { grid-template-columns: 1fr; }
  .settings-aside { position: static; max-height: none; }
  .settings-nav { flex-direction: row; flex-wrap: wrap; gap: .3rem; }
  .settings-group-label { width: 100%; padding: .4rem .5rem .2rem; }
  .settings-nav-item { flex: 1 1 auto; }
  .settings-nav-item.active::before { display: none; }
}
