/* Linear-style design system — dark theme */
:root {
  --bg-base: #0d0d0d;
  --bg-raised: #141414;
  --bg-overlay: #1a1a1a;
  --bg-hover: rgba(255, 255, 255, 0.04);
  --bg-active: rgba(255, 255, 255, 0.08);
  --border-subtle: 1px solid rgba(255, 255, 255, 0.06);
  --border-default: 1px solid rgba(255, 255, 255, 0.08);
  --border-strong: 1px solid rgba(255, 255, 255, 0.12);
  --text-primary: #ededed;
  --text-secondary: #888888;
  --text-tertiary: #6b6b6b;
  --text-placeholder: #525252;
  --accent: #5e6ad2;
  --accent-muted: rgba(94, 106, 210, 0.2);
  --glow-accent: rgba(94, 106, 210, 0.15);
  --border-highlight: rgba(255, 255, 255, 0.12);
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --text-xs: 11px;
  --text-sm: 12px;
  --text-base: 13px;
  --text-md: 14px;
  --text-lg: 15px;
  --text-xl: 16px;
  --sidebar-width: 240px;
  --topbar-height: 40px;
  --header-height: 48px;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-6: 24px;
  --radius-sm: 6px;
  --radius-md: 8px;
  /* Dropdown panels — dark gray panel, selected item blue */
  --bg-dropdown-panel: #2a2a2e;
  --dropdown-selected-bg: #3e6297;
  --dropdown-selected-hover-bg: #4a6fa8;
  /* Scrollbar — used by global scroll UI */
  --scrollbar-track: rgba(255, 255, 255, 0.04);
  --scrollbar-thumb: rgba(255, 255, 255, 0.18);
  --scrollbar-thumb-hover: rgba(255, 255, 255, 0.28);
  --show-archived-border: #2d2d2d;
  --show-archived-checkbox-on: #5b5fc7;
  --show-archived-label-mute: #a3937b;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Global scroll UI — matches dark theme app-wide (WebKit) */
::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}

::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
  border-radius: var(--radius-sm);
  margin: 2px 0;
}

::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-sm);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--scrollbar-thumb-hover);
}

::-webkit-scrollbar-thumb:active {
  background: var(--text-tertiary);
}

::-webkit-scrollbar-corner {
  background: var(--scrollbar-track);
  border-radius: var(--radius-sm);
}

/* Global scroll UI — Firefox (scrollable containers) */
.main,
.content,
.sidebar-nav,
.issue-popup-content .issue-modal-body,
.issue-popup-main,
.issue-attr-menu,
.issue-assignee-list,
.issue-labels-list,
.issue-labels-list-all {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

html,
body {
  margin: 0;
  padding: 0;
  height: 100%;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--text-primary);
  background: var(--bg-base);
  -webkit-font-smoothing: antialiased;
}

body {
  overflow: hidden;
}

.app {
  display: flex;
  height: 100%;
  overflow: hidden;
}

.sidebar {
  width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  height: 100%;
  border-right: var(--border-subtle);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  padding: var(--space-2);
}

.sidebar-header {
  height: var(--topbar-height);
  min-height: var(--topbar-height);
  padding: 0 var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--bg-raised);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}

.sidebar-logo-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  color: inherit;
  width: 100%;
}

.sidebar-logo-img {
  width: fit-content;
  flex-shrink: 0;
}

.sidebar-org-initial {
  display: none;
  width: 28px;
  height: 28px;
  min-width: 28px;
  min-height: 28px;
  border-radius: 50%;
  background: var(--bg-overlay);
  color: var(--text-primary);
  font-weight: 600;
  font-size: var(--text-sm);
  align-items: center;
  justify-content: center;
}

.sidebar-org-initial.show {
  display: flex;
}

.sidebar-brand-name {
  font-weight: 600;
  font-size: var(--text-md);
  color: var(--text-primary);
  letter-spacing: -0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.sidebar-logo-fallback {
  display: none;
  font-weight: 600;
  font-size: var(--text-md);
  color: var(--text-primary);
  letter-spacing: -0.02em;
}

.sidebar-logo-fallback.show {
  display: inline;
}

.sidebar-logo {
  font-weight: 600;
  font-size: var(--text-md);
  color: var(--text-primary);
  letter-spacing: -0.02em;
}

.sidebar-nav {
  flex: 1;
  padding: var(--space-4) var(--space-2);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  background: var(--bg-raised);
}

.sidebar-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: color 0.12s, background 0.12s;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-family: inherit;
}

.sidebar-item:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.sidebar-item.active {
  color: var(--text-primary);
  background: var(--bg-active);
}

.sidebar-item svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  opacity: 0.9;
}

/* Sidebar nav unique color per item (icon + text); active overrides to primary */
.sidebar-item[data-nav="inbox"] {
  color: #60a5fa;
}

.sidebar-item[data-nav="inbox"]:hover {
  color: #93c5fd;
}

.sidebar-item[data-nav="issues"] {
  color: #818cf8;
}

.sidebar-item[data-nav="issues"]:hover {
  color: #a5b4fc;
}

.sidebar-item[data-nav="projects"] {
  color: #2dd4bf;
}

.sidebar-item[data-nav="projects"]:hover {
  color: #5eead4;
}

.sidebar-item[data-nav="cycles"] {
  color: #fbbf24;
}

.sidebar-item[data-nav="cycles"]:hover {
  color: #fcd34d;
}

.sidebar-item[data-nav="admin"] {
  color: #f87171;
}

.sidebar-item[data-nav="admin"]:hover {
  color: #fca5a5;
}

.sidebar-item[data-nav="organization"] {
  color: #FFFFFF;
}

.sidebar-item[data-nav="organization"]:hover {
  color: #FFFFFF;
}

.sidebar-item[data-nav="profile"] {
  color: #FFFFFF;
}

.sidebar-item[data-nav="profile"]:hover {
  color: #FFFFFF;
}

.sidebar-item[data-nav="logout"] {
  color: #f87171;
}

.sidebar-item[data-nav="logout"]:hover {
  color: #fca5a5;
}

.sidebar-footer {
  padding: var(--space-2);
  background: var(--bg-raised);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
}

.topbar {
  height: var(--topbar-height);
  min-height: var(--topbar-height);
  padding: 0 var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  background: rgba(13, 13, 13, 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: var(--border-subtle);
}

.topbar-breadcrumb {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

.topbar-breadcrumb .crumb {
  color: var(--text-secondary);
}

.topbar-search {
  flex: 1;
  max-width: 360px;
  height: 28px;
  padding: 0 var(--space-3);
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.topbar-search::placeholder {
  color: var(--text-placeholder);
}

.topbar-search:focus {
  border-color: var(--border-strong);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.topbar-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.topbar-shortcuts .kbd-shortcut {
  padding: 2px 6px;
  background: var(--bg-overlay);
  border-radius: 4px;
  border: var(--border-subtle);
  font-family: inherit;
  font-size: var(--text-xs);
}

/* Notifications bell + dropdown — matches command-palette / list-row styling */
.topbar-notifications-wrap {
  position: relative;
}

.topbar-notifications-btn {
  position: relative;
  padding: var(--space-1) var(--space-2);
  color: var(--text-secondary);
  transition: color 0.15s ease, background 0.15s ease;
}

.topbar-notifications-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.topbar-notifications-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.topbar-notifications-badge {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  font-size: 10px;
  font-weight: 600;
  line-height: 16px;
  text-align: center;
  color: var(--text-inverse, #fff);
  background: var(--accent, #5e6ad2);
  border-radius: 8px;
}

.topbar-notifications-dropdown {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  width: 380px;
  max-height: 440px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 100;
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
}

.topbar-notifications-dropdown[hidden] {
  display: none !important;
}

.topbar-notifications-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-bottom: var(--border-subtle);
  flex-shrink: 0;
}

.topbar-notifications-title {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.topbar-notifications-header .btn {
  font-size: var(--text-xs);
  color: var(--text-secondary);
}

.topbar-notifications-header .btn:hover {
  color: var(--text-primary);
}

.topbar-notifications-list {
  overflow-y: auto;
  max-height: 380px;
  padding: var(--space-1);
}

.topbar-notifications-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  text-align: left;
  background: none;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  line-height: 1.4;
  cursor: pointer;
  transition: background 0.15s ease;
  position: relative;
}

.topbar-notifications-item+.topbar-notifications-item {
  margin-top: 2px;
}

.topbar-notifications-item:hover {
  background: var(--bg-hover);
}

.topbar-notifications-item:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.topbar-notifications-item.unread {
  background: var(--bg-muted, rgba(255, 255, 255, 0.04));
  border-left: 2px solid var(--accent, #5e6ad2);
  padding-left: calc(var(--space-3) - 2px);
}

.topbar-notifications-item .notif-icon-wrap {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  color: var(--text-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.topbar-notifications-item .notif-icon-wrap svg {
  width: 16px;
  height: 16px;
}

.topbar-notifications-item .notif-body {
  flex: 1;
  min-width: 0;
}

.topbar-notifications-item .notif-line1 {
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.topbar-notifications-item .notif-actor {
  font-weight: 600;
  color: var(--text-primary);
}

.topbar-notifications-item .notif-type {
  color: var(--text-secondary);
  font-weight: 400;
}

.topbar-notifications-item .notif-line2 {
  display: block;
  margin-top: 2px;
  color: var(--text-tertiary);
  font-size: var(--text-xs);
}

.topbar-notifications-item .notif-time {
  flex-shrink: 0;
  margin-left: var(--space-2);
  color: var(--text-tertiary);
  font-size: var(--text-xs);
  white-space: nowrap;
}

.topbar-notifications-empty {
  padding: var(--space-6) var(--space-4);
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

/* Real-time notification toast */
.notif-toast-wrap {
  position: fixed;
  bottom: var(--space-4);
  right: var(--space-4);
  z-index: 9999;
  max-width: 360px;
  animation: notif-toast-in 0.25s ease;
}

.notif-toast-wrap[hidden] {
  display: none !important;
}

@keyframes notif-toast-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.notif-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.notif-toast-content {
  flex: 1;
  min-width: 0;
  font-size: var(--text-sm);
  color: var(--text-primary);
  line-height: 1.4;
}

.notif-toast-content .notif-toast-actor {
  font-weight: 600;
}

.notif-toast-content-error {
  color: var(--danger, #dc2626);
}

.notif-toast-actions {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-shrink: 0;
}

.view-header {
  height: var(--header-height);
  min-height: var(--header-height);
  padding: 0 var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: var(--border-subtle);
  gap: 10px;
}

.view-title {
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0;
}

.view-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-left: auto;
}

/* When bulk bar is visible, separate it from Filter/View/New issue */
.view-header-issues .view-actions {
  gap: var(--space-4);
}

.view-header-issues .view-actions-panel {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  align-items: center;
  gap: 12px;
}

.filter-wrap {
  position: relative;
}

.issues-filter-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: var(--space-2);
  min-width: 280px;
  max-width: 320px;
  padding: var(--space-4);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  background: var(--bg-dropdown-panel, var(--bg-raised));
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}

.issues-filter-dropdown[hidden] {
  display: none;
}

.filter-wrap {
  position: relative;
}

.issues-view-option {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  text-align: left;
  transition: background 0.12s, color 0.12s;
}

.issues-view-option:hover {
  background: var(--bg-hover);
}

.issues-view-option.is-selected {
  color: #fff;
  background: var(--dropdown-selected-bg, #3e6297);
}

.issues-view-option.is-selected:hover {
  background: var(--dropdown-selected-hover-bg, #4a6fa8);
}

#issues-view-dropdown {
  min-width: 200px;
  padding: var(--space-2);
  gap: 2px;
  background: var(--bg-dropdown-panel, var(--bg-raised));
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.issues-filter-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.issues-filter-label {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.issues-filter-select,
.issues-filter-input {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  font-family: inherit;
  min-height: 32px;
}

.issues-filter-input::placeholder {
  color: var(--text-placeholder);
}

.issues-filter-select:focus,
.issues-filter-input:focus {
  outline: none;
  border-color: var(--border-strong);
}

.issues-filter-select:hover,
.issues-filter-input:hover {
  border-color: var(--border-default);
}

.issues-filter-select:disabled,
.issues-filter-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: rgba(0, 0, 0, 0.2);
}

.filter-select-wrap {
  position: relative;
}

.filter-select-wrap svg {
  width: 16px;
  height: 16px;
}

.issues-filter-select-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  font-family: inherit;
  min-height: 32px;
  cursor: pointer;
  text-align: left;
  transition: border-color 0.12s, background 0.12s;
}

.issues-filter-select-btn:hover {
  border-color: var(--border-default);
}

.issues-filter-select-btn[aria-expanded="true"] {
  border-color: var(--border-strong);
}

.issues-filter-select-btn .issues-filter-select-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.issues-filter-select-btn svg {
  width: 14px;
  height: 14px;
  color: var(--text-tertiary);
  flex-shrink: 0;
  transition: transform 0.15s;
}

.issues-filter-select-btn[aria-expanded="true"] svg {
  transform: rotate(180deg);
}

.issues-filter-select-btn--disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.issues-filter-select-menu {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 4px;
  padding: var(--space-2);
  max-height: 240px;
  overflow-y: auto;
  z-index: 50;
  background: var(--bg-dropdown-panel, var(--bg-raised));
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.issues-filter-select-menu[hidden] {
  display: none !important;
}

.issues-filter-option {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: background 0.12s, color 0.12s;
}

.issues-filter-option:hover {
  background: var(--bg-hover);
}

.issues-filter-option.is-selected {
  color: #fff;
  background: var(--dropdown-selected-bg, #3e6297);
}

.issues-filter-option.is-selected:hover {
  background: var(--dropdown-selected-hover-bg, #4a6fa8);
}

.issues-filter-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  padding-right: 28px;
}

.issues-filter-input[type="date"] {
  cursor: pointer;
}

.issues-filter-input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(0.85);
  opacity: 0.7;
  cursor: pointer;
}

.issues-filter-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-top: var(--space-2);
  padding-top: var(--space-3);
  border-top: var(--border-subtle);
}

.issues-filter-actions .btn-ghost {
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

.issues-filter-actions .btn-ghost:hover {
  color: var(--text-secondary);
}

.issues-filter-actions .btn-primary {
  font-size: var(--text-sm);
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
  background: transparent;
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: color 0.12s, background 0.12s, border-color 0.12s;
  font-family: inherit;
  max-width: fit-content;
}

.btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
  border-color: var(--border-default);
}

.btn-primary {
  color: var(--accent);
  border-color: var(--accent-muted);
  background: var(--accent-muted);
}

.btn-primary:hover {
  background: rgba(94, 106, 210, 0.3);
  border-color: var(--accent);
}

.content {
  flex: 1;
  overflow: auto;
}

.list-header {
  display: flex;
  gap: var(--space-6);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
  background: var(--bg-raised);
}

.inbox-list-header span:nth-child(1) {
  max-width: 100px;
  width: 100%;
}

.inbox-list-header span:nth-child(2) {
  max-width: 200px;
  width: 100%;
  margin-right: auto;
}

.inbox-list-header span:nth-child(3) {
  max-width: 160px;
  width: 100%;
  text-align: center;
}

.inbox-list-header span:nth-child(4) {
  max-width: 230px;
  width: 100%;
  text-align: right;
}

.issues-list-header {
  grid-template-columns: 24px 24px 100px 72px 1fr 90px 80px 90px 175px 100px 100px;
}

.bulk-check-col {
  display: flex;
  align-items: center;
  justify-content: center;
}

.title {
  min-width: 200px;
  margin-right: auto;
}

.bulk-check-col .bulk-checkbox {
  width: 16px;
  height: 16px;
  cursor: pointer;
  margin: 0;
  accent-color: var(--accent);
  flex-shrink: 0;
}

/* Ensure checked state is clearly visible (checkmark + fill) */
.bulk-check-col .bulk-checkbox:checked {
  accent-color: var(--accent);
}

/* Custom checkbox so checked state is visible (header "Select all" + row checkboxes) */
#issues-panel .bulk-checkbox,
#issues-panel .bulk-check-col input.bulk-checkbox {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid var(--accent-muted);
  border-radius: 3px;
  background: var(--accent-muted);
}

#issues-panel .bulk-checkbox:checked,
#issues-panel .bulk-check-col input.bulk-checkbox:checked {
  background: var(--accent);
  border-color: var(--accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 8l3 3 7-7'/%3E%3C/svg%3E");
  background-size: 12px 12px;
  background-position: center;
  background-repeat: no-repeat;
}

/* "Select all" header checkbox when some (but not all) issues are selected */
#issues-panel .bulk-checkbox:indeterminate {
  background: var(--accent);
  border-color: var(--accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round'%3E%3Cline x1='4' y1='8' x2='12' y2='8'/%3E%3C/svg%3E");
  background-size: 10px 10px;
  background-position: center;
  background-repeat: no-repeat;
}

#issues-list .list-row {
  grid-template-columns: 24px 24px 100px 72px 1fr 90px 80px 90px 175px 100px 100px;
}

/* Sub-issues column: center badges */
#issues-list .list-row>span:nth-child(6) {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-1);
}

/* Recurring column: always present for alignment; center icon when present */
#issues-list .list-row>span:nth-child(7) {
  display: flex;
  align-items: center;
  justify-content: center;
}

.list-row-recurring-col {
  min-width: 0;
}

/* Title column: prevent overflow and keep alignment */
#issues-list .list-row .title {
  min-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}

/* Due column: align content to the right to match header */
.issues-list-header>span:last-child {
  text-align: right;
}

#issues-list .list-row .due-col,
.due {
  justify-content: flex-end;
  text-align: right;
  width: 100px;
}

.list-header-drag-col {
  display: flex;
  align-items: center;
  justify-content: center;
}

.list-row-drag-handle {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
  color: var(--text-tertiary);
  padding: var(--space-1);
  border-radius: var(--radius-sm);
  user-select: none;
}

.list-row-drag-handle:hover {
  color: var(--text-secondary);
  background: var(--bg-hover);
}

.list-row-drag-handle:active {
  cursor: grabbing;
}

.list-row-drag-handle svg {
  width: 14px;
  height: 14px;
}

/* Source row while dragging — faded slot left behind */
#issues-list .list-row.is-dragging {
  opacity: 0.35;
  background: var(--bg-muted, rgba(255, 255, 255, 0.04));
  border: 2px dashed var(--border-strong);
  border-radius: var(--radius-md);
  transition: opacity 0.15s ease, background 0.15s ease;
}

/* Drag ghost (clone) — solid, readable preview when captured by setDragImage */
.list-row.is-drag-clone {
  display: grid;
  grid-template-columns: 24px 24px 28px 72px 1fr 200px 90px 80px 100px;
  gap: var(--space-4);
  align-items: center;
  pointer-events: none;
  margin: 0;
  padding: var(--space-2) var(--space-4);
  min-height: 44px;
  box-sizing: border-box;
  opacity: 1 !important;
  background: var(--bg-raised) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  transition: none;
}

.list-row.is-drag-clone .list-row-drag-handle,
.list-row.is-drag-clone .status-dot,
.list-row.is-drag-clone .id,
.list-row.is-drag-clone .title,
.list-row.is-drag-clone .assignee,
.list-row.is-drag-clone .list-row-status,
.list-row.is-drag-clone .list-row-priority,
.list-row.is-drag-clone .due-col {
  opacity: 1;
}

/* Drop target highlight */
#issues-list .list-row.over {
  transform: scale(1.02, 1.02);
  background: var(--bg-active);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
  border-radius: var(--radius-md);
  transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.due-col {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.due-reminder-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
  order: 2;
}

.due-reminder-badge.due-reminder-overdue {
  background: rgba(220, 38, 38, 0.15);
  color: var(--danger, #dc2626);
}

.due-reminder-badge.due-reminder-soon {
  background: rgba(245, 158, 11, 0.15);
  color: var(--warning, #d97706);
}

.due-date-text {
  color: var(--text-secondary);
  font-size: var(--text-sm);
}

#issues-list .list-row .bulk-check-col {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 24px;
  width: 100%;
  height: 24px;
}

#issues-list .list-row .bulk-check-col .bulk-checkbox {
  cursor: pointer;
  margin: 0;
}

#issues-panel {
  width: 100%;
  max-width: 100%;
  padding: var(--space-6);
}

#issues-list {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 120px;
}

.issues-group {
  margin-bottom: var(--space-4);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  overflow: visible;
}

.issues-group:last-child {
  margin-bottom: 0;
}

.issues-group-header {
  display: flex;
  gap: var(--space-6);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-secondary);
  border-bottom: var(--border-subtle);
  margin-bottom: 0;
  cursor: pointer;
  transition: background 0.15s ease;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: flex-start;
  align-items: center;
}

.issues-group-header:hover {
  background: var(--bg-hover);
}

.issues-group-header:focus {
  outline: none;
}

.issues-group-header:focus-visible {
  outline: 2px solid var(--focus-ring, var(--accent-primary));
  outline-offset: 2px;
}

.issues-group-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text-tertiary);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: color 0.15s ease, background 0.15s ease;
}

.issues-group-toggle:hover {
  color: var(--text-secondary);
  background: var(--bg-hover);
}

.issues-group-toggle,
.list-row-drag-handle {
  max-width: 24px;
  min-height: 24px;
  width: 100%;
}

.issues-group-chevron {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

.issues-group.is-collapsed .issues-group-chevron {
  transform: rotate(-90deg);
}

.issues-group.is-collapsed .issues-group-list {
  display: none;
}

.issues-group-count-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  padding: 0.2rem 0.5rem;
  border-radius: 9999px;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-tertiary);
  background: var(--bg-muted, rgba(255, 255, 255, 0.06));
  max-width: 20px;
  width: 100%;
  min-height: 20px;
}

.issues-group-icon {
  width: 16px;
  height: 16px;
  color: var(--text-tertiary);
  flex-shrink: 0;
  margin: auto;
}

/* Issues group header icon color by status (target icon and SVG for Lucide) */
.issues-group[data-status="triage"] .issues-group-icon,
.issues-group[data-status="triage"] .issues-group-icon svg {
  color: #60a5fa;
  stroke: #60a5fa;
  margin: 0;
}

.issues-group[data-status="backlog"] .issues-group-icon,
.issues-group[data-status="backlog"] .issues-group-icon svg {
  color: #94a3b8;
  stroke: #94a3b8;
  margin: 0;
}

.issues-group[data-status="backlog"] .issues-group-icon {
  max-width: 30px;
  width: 100%;
}

.issues-group[data-status="todo"] .issues-group-icon,
.issues-group[data-status="todo"] .issues-group-icon svg {
  color: #3b82f6;
  stroke: #3b82f6;
  margin: 0;
}

.issues-group[data-status="in-progress"] .issues-group-icon,
.issues-group[data-status="in-progress"] .issues-group-icon svg {
  color: #f59e0b;
  stroke: #f59e0b;
  margin: 0;
}

.issues-group[data-status="in-review"] .issues-group-icon,
.issues-group[data-status="in-review"] .issues-group-icon svg {
  color: #a78bfa;
  stroke: #a78bfa;
  margin: 0;
}

.issues-group[data-status="reopen"] .issues-group-icon,
.issues-group[data-status="reopen"] .issues-group-icon svg {
  color: #fbbf24;
  stroke: #fbbf24;
  margin: 0;
}

.issues-group[data-status="ready-for-deployment"] .issues-group-icon,
.issues-group[data-status="ready-for-deployment"] .issues-group-icon svg {
  color: #2dd4bf;
  stroke: #2dd4bf;
  margin: 0;
}

.issues-group[data-status="deployed-not-qa"] .issues-group-icon,
.issues-group[data-status="deployed-not-qa"] .issues-group-icon svg {
  color: #fb923c;
  stroke: #fb923c;
  margin: 0;
}

.issues-group[data-status="deployed-qa-ready"] .issues-group-icon,
.issues-group[data-status="deployed-qa-ready"] .issues-group-icon svg {
  color: #22d3ee;
  stroke: #22d3ee;
  margin: 0;
}

.issues-group[data-status="in-qa"] .issues-group-icon,
.issues-group[data-status="in-qa"] .issues-group-icon svg {
  color: #06b6d4;
  stroke: #06b6d4;
  margin: 0;
}

.issues-group[data-status="deployed-qad"] .issues-group-icon,
.issues-group[data-status="deployed-qad"] .issues-group-icon svg {
  color: #34d399;
  stroke: #34d399;
  margin: 0;
}

.issues-group[data-status="on-production-qa-ready"] .issues-group-icon,
.issues-group[data-status="on-production-qa-ready"] .issues-group-icon svg {
  color: #4ade80;
  stroke: #4ade80;
  margin: 0;
}

.issues-group[data-status="blocked"] .issues-group-icon,
.issues-group[data-status="blocked"] .issues-group-icon svg {
  color: #f87171;
  stroke: #f87171;
  margin: 0;
}

.issues-group[data-status="done"] .issues-group-icon,
.issues-group[data-status="done"] .issues-group-icon svg {
  color: #22c55e;
  stroke: #22c55e;
  margin: 0;
}

.issues-group[data-status="on-production-tested"] .issues-group-icon,
.issues-group[data-status="on-production-tested"] .issues-group-icon svg {
  color: #16a34a;
  stroke: #16a34a;
  margin: 0;
}

.issues-group[data-status="canceled"] .issues-group-icon,
.issues-group[data-status="canceled"] .issues-group-icon svg {
  color: #94a3b8;
  stroke: #94a3b8;
  margin: 0;
}

.issues-group[data-status="duplicate"] .issues-group-icon,
.issues-group[data-status="duplicate"] .issues-group-icon svg {
  color: #64748b;
  stroke: #64748b;
  margin: 0;
}

.issues-group-title,
.list-row .id {
  max-width: 100px;
  width: 100%;
}

.issues-group-count {
  font-weight: 500;
  color: var(--text-tertiary);
  font-size: var(--text-xs);
  margin-left: auto;
}

.issues-group-list {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.list-row {
  display: flex;
  gap: var(--space-6);
  padding: var(--space-2) var(--space-4);
  cursor: pointer;
  cursor: pointer;
  transition: background 0.1s;
  width: 100%;
  max-width: 100%;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: flex-start;
  align-items: center;
}

.list-row:hover {
  background: var(--bg-hover);
}

.list-row {
  transition: background 0.15s ease;
}

.list-row:focus {
  outline: none;
}

.list-row:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  background: rgba(59, 130, 246, 0.12);
}

.list-row:hover:focus-visible {
  background: rgba(59, 130, 246, 0.16);
}

.list-row.selected {
  background: var(--bg-active);
  border-color: var(--border-default);
}

.list-row .status-dot {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}

.list-row .status-dot>div {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--text-tertiary);
}

/* Status dot color by status (matches group icon; distinct for index Issues list) */
.list-row .status-dot .triage {
  background: #60a5fa;
}

.list-row .status-dot .backlog {
  background: #94a3b8;
}

.list-row .status-dot .todo {
  background: #3b82f6;
}

.list-row .status-dot .in-progress {
  background: #f59e0b;
}

.list-row .status-dot .in-review {
  background: #a78bfa;
}

.list-row .status-dot .reopen {
  background: #fbbf24;
}

.list-row .status-dot .ready-for-deployment {
  background: #2dd4bf;
}

.list-row .status-dot .deployed-not-qa {
  background: #fb923c;
}

.list-row .status-dot .deployed-qa-ready {
  background: #22d3ee;
}

.list-row .status-dot .in-qa {
  background: #06b6d4;
}

.list-row .status-dot .deployed-qad {
  background: #34d399;
}

.list-row .status-dot .on-production-qa-ready {
  background: #4ade80;
}

.list-row .status-dot .blocked {
  background: #f87171;
}

.list-row .status-dot .done {
  background: #22c55e;
}

.list-row .status-dot .on-production-tested {
  background: #16a34a;
}

.list-row .status-dot .canceled {
  background: #94a3b8;
}

.list-row .status-dot .duplicate {
  background: #64748b;
}

.list-row .id {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

.list-row-recurring-badge,
.recurring {
  display: inline-flex;
  align-items: center;
  color: var(--text-tertiary);
  max-width: 60px;
  width: 100%;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}

.list-row-recurring-badge svg {
  width: 14px;
  height: 14px;
}

.list-row .title {
  font-size: var(--text-sm);
  color: var(--text-primary);
}

/* Sub-issues: visual hierarchy in list */
.list-row--child {
  background: var(--bg-muted, rgba(255, 255, 255, 0.02));
}

.list-row-parent-ref {
  font-size: var(--text-xs);
  color: #3b82f6;
  margin-left: var(--space-2);
  background: var(--accent-muted, rgba(94, 106, 210, 0.25));
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid rgb(59 130 246 / 30%);
  max-width: 90px;
  width: 100%;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}

.list-row-sub-count {
  font-size: var(--text-xs);
  margin-left: var(--space-2);
  font-weight: 500;
  background: rgba(245, 158, 11, 0.15);
  color: var(--warning, #d97706);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid rgb(217 119 6 / 30%);
  max-width: 90px;
  width: 100%;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}

.list-row-sub-issues-col .list-row-sub-count,
.list-row-sub-issues-col .list-row-parent-ref,
.sub-issues {
  margin-left: 0;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}

.list-row-sub-issues-col,
.sub-issues {
  width: 90px;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}

.list-row-display-id {
  font-size: var(--text-xs);
  font-weight: 500;
  background: rgba(59, 130, 246, 0.15);
  color: var(--link-color, var(--color-primary, #2563eb));
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid rgb(59 130 246 / 30%);
}

.list-row .assignee {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

/* Inline quick-edit: status and assignee dropdowns on list row */
.list-row-status-wrap,
.list-row-assignee-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.list-row-assignee-wrap {
  max-width: 55px;
  width: 100%;
}

.list-row-status-wrap,
.status {
  max-width: 160px;
  width: 100%;
  text-align: center;
}

.list-row-status-btn,
.list-row-assignee-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  min-height: 22px;
  padding: 0;
  justify-content: center;
}

.list-row-status-btn {
  max-width: 100%;
  width: 100%;
  padding: var(--space-2) var(--space-2);
}

.list-row-status-btn:hover,
.list-row-assignee-btn:hover {
  background: var(--bg-overlay);
  border-color: var(--border-subtle);
}

.list-row-status-btn .list-row-status-icon,
.list-row-status-btn .list-row-status-icon svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.list-row-status-btn .list-row-status-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;

}

.list-row-assignee-btn .assignee-avatar-sm {
  width: 22px;
  height: 22px;
  font-size: 10px;
}

.list-row-assignee-empty {
  color: var(--text-tertiary);
}

.list-row-status-menu,
.list-row-assignee-menu {
  position: absolute;
  left: 0;
  top: 100%;
  margin-top: 2px;
  padding: var(--space-2);
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  z-index: 50;
  min-width: 180px;
  max-height: 280px;
  overflow-y: auto;
}

.list-row-status-menu {
  min-width: 220px;
  max-height: 320px;
}

.list-row-status-menu .issue-attr-menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.list-row-assignee-menu .issue-assignee-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--text-primary);
  text-align: left;
}

.list-row-assignee-menu .issue-assignee-item:hover {
  background: var(--bg-overlay);
}

/* Status icon colors on inline status button */
.list-row-status-btn[data-status="triage"] .list-row-status-icon,
.list-row-status-btn[data-status="triage"] .list-row-status-icon svg {
  color: #60a5fa;
  stroke: #60a5fa;
}

.list-row-status-btn[data-status="backlog"] .list-row-status-icon,
.list-row-status-btn[data-status="backlog"] .list-row-status-icon svg {
  color: #94a3b8;
  stroke: #94a3b8;
}

.list-row-status-btn[data-status="todo"] .list-row-status-icon,
.list-row-status-btn[data-status="todo"] .list-row-status-icon svg {
  color: #3b82f6;
  stroke: #3b82f6;
}

.list-row-status-btn[data-status="in-progress"] .list-row-status-icon,
.list-row-status-btn[data-status="in-progress"] .list-row-status-icon svg {
  color: #f59e0b;
  stroke: #f59e0b;
}

.list-row-status-btn[data-status="in-review"] .list-row-status-icon,
.list-row-status-btn[data-status="in-review"] .list-row-status-icon svg {
  color: #a78bfa;
  stroke: #a78bfa;
}

.list-row-status-btn[data-status="reopen"] .list-row-status-icon,
.list-row-status-btn[data-status="reopen"] .list-row-status-icon svg {
  color: #fbbf24;
  stroke: #fbbf24;
}

.list-row-status-btn[data-status="ready-for-deployment"] .list-row-status-icon,
.list-row-status-btn[data-status="ready-for-deployment"] .list-row-status-icon svg {
  color: #2dd4bf;
  stroke: #2dd4bf;
}

.list-row-status-btn[data-status="deployed-not-qa"] .list-row-status-icon,
.list-row-status-btn[data-status="deployed-not-qa"] .list-row-status-icon svg {
  color: #fb923c;
  stroke: #fb923c;
}

.list-row-status-btn[data-status="deployed-qa-ready"] .list-row-status-icon,
.list-row-status-btn[data-status="deployed-qa-ready"] .list-row-status-icon svg {
  color: #22d3ee;
  stroke: #22d3ee;
}

.list-row-status-btn[data-status="in-qa"] .list-row-status-icon,
.list-row-status-btn[data-status="in-qa"] .list-row-status-icon svg {
  color: #06b6d4;
  stroke: #06b6d4;
}

.list-row-status-btn[data-status="deployed-qad"] .list-row-status-icon,
.list-row-status-btn[data-status="deployed-qad"] .list-row-status-icon svg {
  color: #34d399;
  stroke: #34d399;
}

.list-row-status-btn[data-status="on-production-qa-ready"] .list-row-status-icon,
.list-row-status-btn[data-status="on-production-qa-ready"] .list-row-status-icon svg {
  color: #4ade80;
  stroke: #4ade80;
}

.list-row-status-btn[data-status="blocked"] .list-row-status-icon,
.list-row-status-btn[data-status="blocked"] .list-row-status-icon svg {
  color: #f87171;
  stroke: #f87171;
}

.list-row-status-btn[data-status="done"] .list-row-status-icon,
.list-row-status-btn[data-status="done"] .list-row-status-icon svg {
  color: #22c55e;
  stroke: #22c55e;
}

.list-row-status-btn[data-status="on-production-tested"] .list-row-status-icon,
.list-row-status-btn[data-status="on-production-tested"] .list-row-status-icon svg {
  color: #16a34a;
  stroke: #16a34a;
}

.list-row-status-btn[data-status="canceled"] .list-row-status-icon,
.list-row-status-btn[data-status="canceled"] .list-row-status-icon svg {
  color: #94a3b8;
  stroke: #94a3b8;
}

.list-row-status-btn[data-status="duplicate"] .list-row-status-icon,
.list-row-status-btn[data-status="duplicate"] .list-row-status-icon svg {
  color: #64748b;
  stroke: #64748b;
}

.assignee-no-user {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-tertiary);
}

.assignee-no-user .icon-assignee-empty {
  flex-shrink: 0;
  color: var(--text-tertiary);
}

.assignee-no-user-label {
  font-size: var(--text-sm);
}

.list-row .status,
.list-row-status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.list-row .status {
  justify-content: center;
}

.list-row-status .list-row-status-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: var(--text-tertiary);
}

.list-row-status .status-text {
  white-space: nowrap;
}

/* Status column icon color by status (matches group header and status dot) */
.list-row .list-row-status[data-status="triage"] .list-row-status-icon,
.list-row .list-row-status[data-status="triage"] .list-row-status-icon svg {
  color: #60a5fa;
  stroke: #60a5fa;
}

.list-row .list-row-status[data-status="backlog"] .list-row-status-icon,
.list-row .list-row-status[data-status="backlog"] .list-row-status-icon svg {
  color: #94a3b8;
  stroke: #94a3b8;
}

.list-row .list-row-status[data-status="todo"] .list-row-status-icon,
.list-row .list-row-status[data-status="todo"] .list-row-status-icon svg {
  color: #3b82f6;
  stroke: #3b82f6;
}

.list-row .list-row-status[data-status="in-progress"] .list-row-status-icon,
.list-row .list-row-status[data-status="in-progress"] .list-row-status-icon svg {
  color: #f59e0b;
  stroke: #f59e0b;
}

.list-row .list-row-status[data-status="in-review"] .list-row-status-icon,
.list-row .list-row-status[data-status="in-review"] .list-row-status-icon svg {
  color: #a78bfa;
  stroke: #a78bfa;
}

.list-row .list-row-status[data-status="reopen"] .list-row-status-icon,
.list-row .list-row-status[data-status="reopen"] .list-row-status-icon svg {
  color: #fbbf24;
  stroke: #fbbf24;
}

.list-row .list-row-status[data-status="ready-for-deployment"] .list-row-status-icon,
.list-row .list-row-status[data-status="ready-for-deployment"] .list-row-status-icon svg {
  color: #2dd4bf;
  stroke: #2dd4bf;
}

.list-row .list-row-status[data-status="deployed-not-qa"] .list-row-status-icon,
.list-row .list-row-status[data-status="deployed-not-qa"] .list-row-status-icon svg {
  color: #fb923c;
  stroke: #fb923c;
}

.list-row .list-row-status[data-status="deployed-qa-ready"] .list-row-status-icon,
.list-row .list-row-status[data-status="deployed-qa-ready"] .list-row-status-icon svg {
  color: #22d3ee;
  stroke: #22d3ee;
}

.list-row .list-row-status[data-status="in-qa"] .list-row-status-icon,
.list-row .list-row-status[data-status="in-qa"] .list-row-status-icon svg {
  color: #06b6d4;
  stroke: #06b6d4;
}

.list-row .list-row-status[data-status="deployed-qad"] .list-row-status-icon,
.list-row .list-row-status[data-status="deployed-qad"] .list-row-status-icon svg {
  color: #34d399;
  stroke: #34d399;
}

.list-row .list-row-status[data-status="on-production-qa-ready"] .list-row-status-icon,
.list-row .list-row-status[data-status="on-production-qa-ready"] .list-row-status-icon svg {
  color: #4ade80;
  stroke: #4ade80;
}

.list-row .list-row-status[data-status="blocked"] .list-row-status-icon,
.list-row .list-row-status[data-status="blocked"] .list-row-status-icon svg {
  color: #f87171;
  stroke: #f87171;
}

.list-row .list-row-status[data-status="done"] .list-row-status-icon,
.list-row .list-row-status[data-status="done"] .list-row-status-icon svg {
  color: #22c55e;
  stroke: #22c55e;
}

.list-row .list-row-status[data-status="on-production-tested"] .list-row-status-icon,
.list-row .list-row-status[data-status="on-production-tested"] .list-row-status-icon svg {
  color: #16a34a;
  stroke: #16a34a;
}

.list-row .list-row-status[data-status="canceled"] .list-row-status-icon,
.list-row .list-row-status[data-status="canceled"] .list-row-status-icon svg {
  color: #94a3b8;
  stroke: #94a3b8;
}

.list-row .list-row-status[data-status="duplicate"] .list-row-status-icon,
.list-row .list-row-status[data-status="duplicate"] .list-row-status-icon svg {
  color: #64748b;
  stroke: #64748b;
}

.list-row .priority,
.priority {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  width: 100px;
  display: flex;
  padding: var(--space-1) var(--space-2);
}

.list-row-priority {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.list-row-priority .list-row-priority-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.list-row-priority .list-row-priority-icon svg,
.list-row-priority .list-row-priority-icon .priority-icon-svg {
  width: 14px;
  height: 14px;
  display: block;
  color: currentColor;
}

/* Priority colors: pill background + icon + text */
.list-row-priority[data-priority="Urgent"] {
  color: #f87171;
}

.list-row-priority[data-priority="Urgent"] .list-row-priority-icon svg.priority-icon-urgent,
.list-row-priority[data-priority="Urgent"] .list-row-priority-icon .priority-icon-urgent {
  color: #f87171;
}

.list-row-priority[data-priority="High"] {
  color: #fb923c;
}

.list-row-priority[data-priority="High"] .list-row-priority-icon svg {
  color: #fb923c;
}

.list-row-priority[data-priority="Medium"] {
  color: #fbbf24;
}

.list-row-priority[data-priority="Medium"] .list-row-priority-icon svg {
  color: #fbbf24;
}

.list-row-priority[data-priority="Low"],
.list-row-priority[data-priority=""] {
  color: var(--text-tertiary, #94a3b8);
}

.list-row-priority[data-priority="Low"] .list-row-priority-icon svg,
.list-row-priority[data-priority=""] .list-row-priority-icon svg {
  color: var(--text-tertiary, #94a3b8);
}

.list-row-priority .priority-text {
  white-space: nowrap;
}

/* Inbox: extra Quick actions column */
.inbox-list-header {
  grid-template-columns: 28px 72px 1fr 100px 90px 80px minmax(200px, 1fr);
}

.inbox-panel .list-row.inbox-row {
  grid-template-columns: 28px 72px 1fr 100px 90px 80px minmax(200px, 1fr);
}

.inbox-quick-actions-head {
  font-size: var(--text-xs);
}

.inbox-quick-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  overflow: visible;
  max-width: 230px;
  width: 100%;
  justify-content: flex-end;
}

.inbox-quick-actions .btn {
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-2);
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
}

.inbox-quick-dropdown {
  position: relative;
  display: inline-block;
  flex: 1;
}

.inbox-quick-menu[hidden] {
  display: none !important;
}

.inbox-quick-menu {
  position: absolute;
  top: 100%;
  right: 0;
  z-index: 100;
  min-width: 160px;
  max-height: 240px;
  overflow-y: auto;
  margin-top: var(--space-1);
  padding: var(--space-2);
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  display: block;
}

.inbox-quick-menu .issue-assignee-item,
.inbox-quick-menu .issue-attr-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  text-align: left;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--text-primary);
}

.inbox-quick-menu .issue-assignee-item:hover,
.inbox-quick-menu .issue-attr-menu-item:hover {
  background: var(--bg-hover);
}

.inbox-quick-menu .issue-assignee-item.is-selected,
.inbox-quick-menu .issue-attr-menu-item.is-selected {
  color: #fff;
  background: var(--dropdown-selected-bg, #3e6297);
}

.loading {
  padding: var(--space-2);
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  text-align: center;
}

/* App loader — full-screen with centered logo (index.php) */
.app-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-base, #0d1117);
  transition: opacity 0.3s ease;
}

.app-loader.app-loader-hidden {
  opacity: 0;
  pointer-events: none;
}

.app-loader-inner {
  display: flex;
  align-items: center;
  justify-content: center;
}

.app-loader-logo {
  width: 48px;
  height: 48px;
  animation: app-loader-spin 2s linear infinite;
}

@keyframes app-loader-spin {
  0% {
    opacity: 0.5;
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 0.5;
  }
}

/* Inbox screen */
.inbox-panel {
  min-height: 200px;
  padding: var(--space-6);
}

.inbox-issues-list {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.inbox-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-6) var(--space-4);
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

.inbox-empty-icon {
  width: 48px;
  height: 48px;
  margin-bottom: var(--space-4);
  opacity: 0.4;
}

.inbox-empty strong {
  display: block;
  color: var(--text-secondary);
  font-size: var(--text-md);
  margin-bottom: var(--space-2);
}

.inbox-empty p {
  margin: 0;
  font-size: var(--text-sm);
}

/* My work — matches Reports/Dashboard layout and cards */
.view-header-mywork {
  height: var(--header-height);
  min-height: var(--header-height);
  padding-top: var(--space-5);
  padding-bottom: var(--space-5);
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.view-header-mywork .view-header-text {
  display: flex;
  flex-direction: row;
  gap: 2px;
  align-items: center;
  gap: 10px;
}

.view-header-mywork .view-subtitle {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  max-width: 480px;
}

.mywork-summary {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
  padding: var(--space-2) var(--space-6);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.mywork-summary-inner-wrapper {
  padding: var(--space-2) var(--space-4);
  background: var(--bg-raised);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  max-width: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
}

.mywork-summary-item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.mywork-summary-item svg {
  width: 18px;
  height: 18px;
}

.mywork-summary-item strong {
  font-weight: 600;
  color: var(--text-primary);
}

.mywork-summary-sep {
  color: var(--text-tertiary);
  user-select: none;
}

.mywork-summary-item.mywork-summary-overdue strong {
  color: var(--danger, #dc2626);
}

.mywork-dashboard {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  padding: var(--space-6);
}

.issues-group-count-badge,
.list-row .status-dot {
  max-width: 30px;
  width: 100%;
}

.mywork-section.reports-section.reports-card {
  min-height: 200px;
}

.mywork-section-overdue .reports-section-title {
  color: var(--danger, #dc2626);
}

.mywork-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-height: 0;
}

.mywork-row {
  display: grid;
  grid-template-columns: auto auto 1fr auto auto auto auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  cursor: pointer;
}

.mywork-row:hover {
  background: var(--bg-hover);
}

/* Reports view header */
.view-header-reports {
  height: var(--header-height);
  min-height: var(--header-height);
  padding: 0 var(--space-6);
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.view-header-reports .view-header-text {
  display: flex;
  flex-direction: row;
  gap: 2px;
  align-items: center;
  gap: 10px;
}

.view-header-reports .view-subtitle {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.view-header-actions-reports {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.reports-export-msg {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.reports-export-msg-error {
  color: var(--danger, #dc2626);
}

/* Reports dashboard */
.reports-dashboard {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  padding: var(--space-6);
}

.reports-section.reports-card {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  min-width: 250px;
  background: var(--bg-raised);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
}

.reports-section-title {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: var(--space-2);
}

.reports-section-title svg {
  width: 18px;
  height: 18px;
}

.reports-section-title i {
  width: 18px;
  height: 18px;
  color: var(--text-tertiary);
}

.reports-table-wrap {
  min-height: 80px;
  flex: 1;
  padding: var(--space-3) var(--space-4);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  overflow: auto;
}

.reports-table-wrap .loading {
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  padding: var(--space-2) 0;
}

.reports-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.reports-table thead tr {
  border-bottom: 1px solid var(--border-subtle);
}

.reports-table th,
.reports-table td {
  padding: var(--space-2) var(--space-3);
  text-align: left;
}

.reports-table th {
  font-weight: 600;
  color: var(--text-secondary);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.reports-table th:first-child {
  text-align: left;
}

.reports-table th:last-child {
  text-align: right;
}

.reports-table tbody tr {
  border-bottom: 1px solid var(--border-subtle);
}

.reports-table tbody tr:last-child {
  border-bottom: none;
}

.reports-table tbody tr:hover {
  background: var(--bg-hover);
}

.reports-table td:last-child {
  text-align: right;
  font-weight: 500;
  color: var(--text-secondary);
}

.reports-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  text-align: center;
  min-height: 120px;
}

.reports-empty[hidden] {
  display: none !important;
}

.reports-empty-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin-bottom: var(--space-2);
  border-radius: var(--radius-full);
  background: var(--bg-muted);
  color: var(--text-tertiary);
}

.reports-empty-icon i {
  width: 20px;
  height: 20px;
}

.reports-empty p {
  margin: 0 0 var(--space-2);
}

.reports-empty-link {
  font-size: var(--text-sm);
  color: var(--primary, #6366f1);
  text-decoration: none;
  font-weight: 500;
}

.reports-empty-link:hover {
  text-decoration: underline;
}

/* Burndown chart (Reports) */
.reports-burndown-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0 0 var(--space-3);
}

.reports-burndown-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  flex-direction: column;
  align-content: flex-start;
}

.reports-burndown-label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  font-weight: 500;
}

.reports-burndown-dropdown {
  position: relative;
  display: inline-block;
  margin-bottom: var(--space-2);
}

.reports-burndown-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  min-width: 180px;
  padding: var(--space-2) var(--space-3);
  background: var(--bg-overlay, #1e293b);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.reports-burndown-dropdown-trigger:hover {
  border-color: rgba(255, 255, 255, 0.18);
  background: var(--bg-hover, #334155);
}

.reports-burndown-dropdown-trigger[aria-expanded="true"] {
  border-color: var(--accent, #2563eb);
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.35);
}

.reports-burndown-dropdown-trigger svg,
.reports-burndown-dropdown-trigger i[data-lucide] {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--text-secondary);
}

.reports-burndown-dropdown-value {
  flex: 1;
  text-align: left;
}

.reports-burndown-dropdown-menu {
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  min-width: 100%;
  max-height: 280px;
  overflow-y: auto;
  padding: var(--space-1);
  background: var(--bg-overlay, #1e293b);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.35);
  z-index: 100;
}

.reports-burndown-dropdown-menu[hidden] {
  display: none !important;
}

.reports-section.reports-card {
  overflow: visible;
}

.reports-burndown-dropdown-item {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  text-align: left;
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.reports-burndown-dropdown-item:hover {
  background: var(--bg-hover, #334155);
}

.reports-burndown-dropdown-item.is-selected {
  background: var(--dropdown-selected-bg, #2563eb);
  color: #fff;
}

.reports-burndown-dropdown-item.is-selected:hover {
  background: var(--dropdown-selected-hover-bg, #3b82f6);
}

.reports-burndown-chart {
  min-height: 280px;
  margin-bottom: var(--space-2);
}

.reports-burndown-loading {
  padding: var(--space-4);
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

.burndown-svg {
  display: block;
  max-width: 100%;
  height: auto;
}

.burndown-grid-line {
  stroke: var(--border-subtle);
  stroke-width: 1;
  opacity: 0.6;
}

.burndown-line {
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.burndown-line-ideal {
  stroke: var(--text-tertiary);
  stroke-dasharray: 6 4;
}

.burndown-line-actual {
  stroke: var(--primary, #6366f1);
}

.burndown-point {
  fill: var(--primary, #6366f1);
  stroke: var(--bg-raised);
  stroke-width: 2;
}

.burndown-legend {
  font-size: 11px;
  fill: var(--text-secondary);
}

.burndown-legend-text {
  dominant-baseline: middle;
}

/* Velocity / capacity (Reports) */
.reports-velocity-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0 0 var(--space-3);
}

.reports-velocity-average {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0 0 var(--space-3);
}

.reports-velocity-average strong {
  color: var(--text-primary);
}

.reports-velocity-table {
  margin-top: 0;
  min-width: 600px;
}

.reports-velocity-by-assignee {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  max-width: 280px;
  white-space: normal;
}

.reports-velocity-loading {
  padding: var(--space-4);
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

/* Dashboard — configurable widgets (matches Reports / My work theme) */
.view-header-dashboard {
  height: var(--header-height);
  min-height: var(--header-height);
  padding: 0 var(--space-6);
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.view-header-dashboard .view-header-text {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-2);
}

.view-header-dashboard .view-subtitle {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  max-width: 480px;
}

.view-header-actions-dashboard {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  position: relative;
}

#dashboard-content {
  position: relative;
  max-width: 1280px;
}

.dashboard-widgets {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  padding: var(--space-6);
}

.dashboard-widget {
  display: flex;
  flex-direction: column;
  min-height: 200px;
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  position: relative;
}

.dashboard-widget-title {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0;
  border-bottom: var(--border-subtle);
  padding: var(--space-3) var(--space-4);
}

.dashboard-widget-title svg {
  width: 18px;
  height: 18px;
}

.dashboard-widget-title i {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  color: var(--text-tertiary);
}

.dashboard-widget-content {
  flex: 1;
  overflow: auto;
  min-height: 0;
  padding: var(--space-2) var(--space-3);
}

.dashboard-widget-content .dashboard-widget-list {
  max-height: 280px;
  overflow-y: auto;
}

.dashboard-widget-empty {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  padding: var(--space-3) 0;
}

.dashboard-widget-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.dashboard-widget-table thead tr {
  border-bottom: var(--border-subtle);
}

.dashboard-widget-table th,
.dashboard-widget-table td {
  padding: var(--space-2) var(--space-3);
  text-align: left;
}

.dashboard-widget-table th {
  font-weight: 600;
  color: var(--text-secondary);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dashboard-widget-table tbody tr {
  border-bottom: var(--border-subtle);
}

.dashboard-widget-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: center;
}

.dashboard-widget-row {
  display: grid;
  grid-template-columns: auto auto 1fr auto auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  cursor: pointer;
}

.dashboard-widget-row:hover {
  background: var(--bg-hover);
}

.dashboard-configure-dropdown {
  position: absolute;
  top: var(--space-6);
  right: 0;
  z-index: 100;
  min-width: 260px;
  max-width: 320px;
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
}

.dashboard-configure-dropdown[hidden] {
  display: none !important;
}

.dashboard-configure-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 var(--space-2);
}

.dashboard-configure-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.dashboard-configure-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  cursor: pointer;
}

.dashboard-configure-item input {
  margin: 0;
}

.dashboard-configure-save {
  width: 100%;
}

.dashboard-configure-error {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

/* Audit log — compliance (uses shared .issues-filter-*, .reports-table, .reports-empty) */
.audit-log-panel {
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-content: center;
  justify-content: flex-start;
  gap: var(--space-4);
}

.audit-log-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  max-width: 100%;
  width: 100%;
}

.audit-log-filters .issues-filter-section {
  min-width: 150px;
  flex: 1;
}

.audit-log-filters .audit-log-section-select {
  min-width: 140px;
}

/* Audit log — Change type dropdown (match reference: dark trigger + menu, blue highlight) */
.audit-change-type-dropdown {
  position: relative;
  width: 100%;
  min-width: 140px;
}

.audit-change-type-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-height: 36px;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-family: inherit;
  color: var(--text-primary);
  background: var(--bg-base);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color 0.12s ease, background 0.12s ease;
}

.audit-change-type-trigger:hover {
  background: var(--bg-hover);
  border-color: rgba(255, 255, 255, 0.14);
}

.audit-change-type-label {
  flex: 1;
  text-align: left;
}

.audit-change-type-chevron {
  width: 14px;
  height: 14px;
  opacity: 0.8;
  flex-shrink: 0;
  margin-left: var(--space-2);
}

.audit-change-type-menu {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 4px;
  min-width: 100%;
  max-height: 280px;
  overflow-y: auto;
  padding: var(--space-2);
  background: var(--bg-overlay);
  border-radius: var(--radius-sm);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  z-index: 50;
}

.audit-change-type-menu[hidden] {
  display: none !important;
}

.audit-change-type-option {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-family: inherit;
  color: var(--text-primary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-align: left;
  transition: background 0.1s ease, color 0.1s ease;
}

.audit-change-type-option:hover,
.audit-change-type-option.is-selected {
  color: #fff;
  background: rgba(59, 130, 246, 0.35);
}

.audit-change-type-option.is-selected:hover {
  background: rgba(59, 130, 246, 0.45);
}

.audit-log-filter-actions.issues-filter-actions {
  flex-basis: 100%;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: var(--space-3);
  border-top: var(--border-subtle);
  justify-content: flex-end;
}

.reports-table .audit-log-time {
  white-space: nowrap;
  color: var(--text-secondary);
}

.audit-log-issue-link {
  color: var(--accent);
  text-decoration: none;
}

.audit-log-issue-link:hover {
  text-decoration: underline;
}

.audit-log-error {
  padding: var(--space-3);
  color: var(--danger, #dc2626);
  font-size: var(--text-sm);
}

.audit-log-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  border-top: var(--border-subtle);
  padding: var(--space-3) var(--space-4);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
}

.audit-log-summary {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

/* New issue form */
.form-panel {
  padding: var(--space-6);
  max-width: 560px;
}

.issue-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
}

.form-required {
  color: #ef4444;
}

.form-input,
.form-select {
  width: 100%;
  height: 36px;
  padding: 0 var(--space-3);
  background: var(--bg-overlay, #1e293b);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.form-input:hover,
.form-select:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.form-input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.form-input:focus,
.form-select:focus {
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.form-select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  padding-right: 28px;
}

.form-error {
  font-size: var(--text-sm);
  color: #ef4444;
  margin: 0;
}

.form-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: var(--border-subtle);
}

.form-actions .btn-primary {
  margin-left: auto;
}

/* New issue modal (Linear-style) */
.content-center {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.issue-modal {
  width: 100%;
  max-width: 100%;
  height: 100%;
}

.issue-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-bottom: var(--border-subtle);
  position: sticky;
  top: 0;
  background: rgba(13, 13, 13);
  z-index: 5;
}

.issue-modal-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.issue-modal-form {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  height: 100%;
}

.issue-modal-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  background: var(--bg-overlay);
  border-radius: var(--radius-sm);
  padding: 6px 10px;
  border: var(--border-subtle);
}

.issue-modal-tag svg {
  width: 12px;
  height: 12px;
}

.popup-issue-id-copy,
#popup-issue-id.popup-issue-id-copy {
  cursor: pointer;
}

.popup-issue-id-copy:hover {
  opacity: 0.9;
}

.issue-modal-arrow {
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

.btn-ghost {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  transition: color 0.15s ease, background 0.15s ease;
}

.btn-ghost:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
  border: none;
}

.btn-ghost:disabled,
.btn-ghost:disabled:hover {
  background: transparent;
  border: none;
  cursor: unset;
  opacity: 0 !important;
}

.btn-sm {
  padding: 4px 8px;
  font-size: var(--text-xs);
}

.btn-icon {
  padding: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-icon svg {
  width: 16px;
  height: 16px;
}

.issue-modal-header-right {
  display: flex;
  align-items: center;
  gap: 2px;
}

.issue-modal-body {
  padding: var(--space-4);
  max-width: calc(100% - 200px);
  width: 100%;
}

input {
  outline: none;
}

.issue-title-input {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--text-primary);
  background: var(--bg-overlay, #1e293b);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  outline: none;
  font-family: var(--font-sans);
  margin-bottom: var(--space-2);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.issue-title-input:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.issue-title-input:focus {
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.issue-title-input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

/* Rich description editor wrapper */
.issue-description-editor-wrap {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  background: var(--bg-overlay, #1e293b);
  overflow: hidden;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.issue-description-editor-wrap:focus-within {
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.issue-description-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px;
  padding: var(--space-1) var(--space-2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.2);
}

.issue-description-toolbar-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  font-size: var(--text-xl);
  color: var(--text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  transition: color 0.12s, background 0.12s;
}

.issue-description-toolbar-btn svg {
  width: 16px;
  height: 16px;
}

.issue-description-toolbar-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.issue-description-toolbar-btn:focus {
  outline: none;
  background: var(--bg-active);
}

.issue-description-toolbar-btn i {
  width: 14px;
  height: 14px;
}

.issue-description-toolbar-sep {
  width: 1px;
  height: 16px;
  margin: 0 var(--space-1);
  background: rgba(255, 255, 255, 0.12);
}

.issue-description-editor {
  display: block;
  width: 100%;
  min-height: 80px;
  max-height: 280px;
  padding: var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: transparent;
  border: none;
  outline: none;
  font-family: var(--font-sans);
  box-sizing: border-box;
  overflow-wrap: break-word;
}

.issue-description-editor:empty::before {
  content: attr(data-placeholder);
  color: var(--text-placeholder, #94a3b8);
}

.issue-description-input {
  width: 100%;
  min-height: 80px;
  padding: var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: var(--bg-overlay, #1e293b);
  border-radius: var(--radius-md);
  outline: none;
  font-family: var(--font-sans);
  resize: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  box-sizing: border-box;
  height: auto !important;
  border-color: rgba(255, 255, 255, 0.12);
}

.issue-description-input.issue-description-input-scroll {
  overflow-y: auto;
}

.issue-description-input:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.issue-description-input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.issue-description-input:focus {
  border-color: rgba(255, 255, 255, 0.25);
}

.issue-popup-readonly .issue-title-readonly {
  font-size: var(--text-lg);
  font-weight: 600;
  margin: 0 0 var(--space-2);
}

.issue-popup-readonly .issue-description-readonly {
  margin-bottom: var(--space-3);
  white-space: pre-wrap;
  color: var(--text-secondary);
}

.issue-description-readonly-rich {
  white-space: normal;
}

.issue-description-readonly a {
  color: var(--accent, #5e6ad2);
  text-decoration: none;
}

.issue-description-readonly a:hover {
  text-decoration: underline;
}

.issue-description-readonly blockquote {
  margin: var(--space-2) 0;
  padding-left: var(--space-3);
  border-left: 3px solid rgba(255, 255, 255, 0.2);
  color: var(--text-secondary);
}

/* Code block — ONE dark container for all lines (only the outer pre has the box) */
.issue-description-editor pre.description-code-block,
.issue-description-readonly pre.description-code-block {
  display: block;
  margin: var(--space-3) 0;
  padding: var(--space-4);
  font-family: ui-monospace, 'SF Mono', 'Cascadia Code', Consolas, monospace;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-primary);
  background: #16181c;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  overflow-x: auto;
  white-space: pre-wrap;
  box-sizing: border-box;
  list-style: none;
  min-height: 54px;
}

/* Fallback: pre without class (e.g. from formatBlock) — same single block */
.issue-description-editor pre:not(.description-code-block),
.issue-description-readonly pre:not(.description-code-block) {
  display: block;
  margin: var(--space-3) 0;
  padding: var(--space-4);
  font-family: ui-monospace, 'SF Mono', 'Cascadia Code', Consolas, monospace;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-primary);
  background: #16181c;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  overflow-x: auto;
  white-space: pre-wrap;
  box-sizing: border-box;
  list-style: none;
}

/* Inner elements (div, p, li) must NOT look like separate blocks — no box, just lines inside the one pre */
.issue-description-editor pre div,
.issue-description-editor pre p,
.issue-description-editor pre li,
.issue-description-editor pre code div,
.issue-description-editor pre code p,
.issue-description-editor pre code li,
.issue-description-editor .description-code-block div,
.issue-description-editor .description-code-block p,
.issue-description-editor .description-code-block li,
.issue-description-editor .description-code-block code div,
.issue-description-editor .description-code-block code p,
.issue-description-editor .description-code-block code li,
.issue-description-readonly pre div,
.issue-description-readonly pre p,
.issue-description-readonly pre li,
.issue-description-readonly pre code div,
.issue-description-readonly pre code p,
.issue-description-readonly pre code li,
.issue-description-readonly .description-code-block div,
.issue-description-readonly .description-code-block p,
.issue-description-readonly .description-code-block li,
.issue-description-readonly .description-code-block code div,
.issue-description-readonly .description-code-block code p,
.issue-description-readonly .description-code-block code li {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-family: inherit;
  white-space: pre;
  min-height: 0;
}

/* Force code block inner content to look like code — no list bullets/markers */
.issue-description-editor pre,
.issue-description-editor .description-code-block,
.issue-description-editor pre code,
.issue-description-editor .description-code-block code,
.issue-description-readonly pre,
.issue-description-readonly .description-code-block,
.issue-description-readonly pre code,
.issue-description-readonly .description-code-block code {
  list-style: none !important;
  list-style-type: none !important;
}

.issue-description-editor pre ul,
.issue-description-editor pre ol,
.issue-description-editor .description-code-block ul,
.issue-description-editor .description-code-block ol,
.issue-description-editor pre li,
.issue-description-editor .description-code-block li,
.issue-description-readonly pre ul,
.issue-description-readonly pre ol,
.issue-description-readonly .description-code-block ul,
.issue-description-readonly .description-code-block ol,
.issue-description-readonly pre li,
.issue-description-readonly .description-code-block li {
  list-style: none !important;
  list-style-type: none !important;
  margin: 0 !important;
  padding: 0 !important;
  padding-left: 0 !important;
  display: block;
  font-family: inherit;
  white-space: pre;
}

.issue-description-editor pre li::marker,
.issue-description-editor .description-code-block li::marker,
.issue-description-editor pre li::before,
.issue-description-editor .description-code-block li::before,
.issue-description-readonly pre li::marker,
.issue-description-readonly .description-code-block li::marker,
.issue-description-readonly pre li::before,
.issue-description-readonly .description-code-block li::before {
  display: none !important;
  content: none !important;
}

.issue-description-editor pre code,
.issue-description-editor .description-code-block code,
.issue-description-readonly pre code,
.issue-description-readonly .description-code-block code {
  padding: 0;
  background: none;
  font-size: inherit;
  color: inherit;
  border-radius: 0;
  display: block;
  white-space: pre;
  font-family: inherit;
}

/* Inline code (unchanged) */
.issue-description-readonly code:not(pre code):not(.description-code-block code) {
  font-family: ui-monospace, monospace;
  font-size: var(--text-xs);
  background: rgba(0, 0, 0, 0.3);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
}

/* Syntax highlight colors for code blocks (no-JS fallback + override Prism) */
.issue-description-readonly .description-code-block .token.selector,
.issue-description-readonly .description-code-block .token.attr-name,
.issue-description-readonly pre .token.selector {
  color: #e06c75;
}

.issue-description-readonly .description-code-block .token.property,
.issue-description-readonly pre .token.property {
  color: #e5c07b;
}

.issue-description-readonly .description-code-block .token.string,
.issue-description-readonly .description-code-block .token.attr-value,
.issue-description-readonly pre .token.string {
  color: #98c379;
}

.issue-description-readonly .description-code-block .token.number,
.issue-description-readonly pre .token.number {
  color: #61afef;
}

.issue-description-readonly .description-code-block .token.keyword,
.issue-description-readonly pre .token.keyword {
  color: #c678dd;
}

.issue-description-readonly .description-code-block .token.punctuation,
.issue-description-readonly pre .token.punctuation {
  color: #abb2bf;
}

.issue-description-readonly .description-code-block .token.comment,
.issue-description-readonly pre .token.comment {
  color: #5c6370;
  font-style: italic;
}

/* Keep our code block container when Prism is loaded */
.issue-description-readonly pre[class*="description-code-block"],
.issue-description-readonly pre.description-code-block {
  background: #16181c !important;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.issue-description-readonly pre .token {
  background: none !important;
}

.issue-description-readonly ul,
.issue-description-readonly ol {
  margin: var(--space-2) 0;
  padding-left: var(--space-6);
}

.issue-description-readonly p {
  margin: 0 0 var(--space-2);
}

.issue-description-readonly p:last-child {
  margin-bottom: 0;
}

.issue-popup-readonly .issue-attributes-readonly {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.issue-popup-readonly .issue-attr-readonly {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.issue-popup-readonly .popup-view-only-hint {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  margin-top: var(--space-2);
}

.issue-attributes {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  justify-content: flex-start;
  flex-direction: column;
  max-width: 200px;
  width: 100%;
  padding: var(--space-4);
  position: sticky;
  top: 54px;
  right: 0;
}

.issue-attributes .issue-attributes {
  padding: 0;
}

/* Mobile: trigger to open attributes in a popup (hidden on desktop) */
.issue-attributes-mobile-trigger {
  display: none;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--bg-overlay);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: var(--text-sm);
  cursor: pointer;
  width: 100%;
  justify-content: flex-start;
  max-width: fit-content;
}

.issue-attributes-mobile-trigger svg {
  width: 16px;
  height: 16px;
}

.issue-attributes-mobile-trigger:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.issue-attributes-mobile-trigger i {
  flex-shrink: 0;
}

.issue-attributes-popup-header {
  display: none;
}

.issue-attributes-popup-backdrop {
  display: none;
}

/* Sub-issue attrs: mobile popup trigger (hidden on desktop) */
.issue-subissue-attrs-mobile-trigger {
  display: none;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--bg-overlay);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: var(--text-sm);
  cursor: pointer;
  width: 100%;
  justify-content: flex-start;
}

.issue-subissue-attrs-mobile-trigger:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.issue-subissue-attrs-mobile-trigger svg {
  width: 16px;
  height: 16px;
}

.issue-subissue-attrs-popup-header {
  display: none;
}

.issue-subissue-attrs-backdrop {
  display: none;
}

/* Sub-issues section */
.issue-subissues-section {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: var(--border-subtle);
  display: flex;
  flex-direction: column;
}

.issue-subissues-heading {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.issue-subissues-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-primary);
}

.issue-subissues-progress {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--bg-overlay);
  padding: 2px var(--space-2);
  border-radius: var(--radius-sm);
}

.issue-subissues-hint {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  width: 100%;
}

.issue-subissues-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.issue-subissue-row {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-3);
  background: var(--bg-overlay);
  border-radius: var(--radius-md, 6px);
  border: var(--border-subtle);
  cursor: pointer;
  min-width: 0;
}

.issue-subissue-field-wrapper {
  max-width: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
  flex-wrap: wrap;
}

.issue-subissue-row:focus {
  outline: 2px solid var(--color-primary, #2563eb);
  outline-offset: 2px;
}

/* First line: checkbox + title + remove. Second line: attrs (full width) so assignee never clips */
.issue-subissue-attrs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  max-width: 200px;
  width: 100%;
}

.issue-subissue-checkbox-wrap {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  margin-top: 8px;
}

.issue-subissue-checkbox {
  width: 16px;
  height: 16px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  flex-shrink: 0;
  border: 1px solid var(--accent-muted);
  border-radius: 3px;
  background: var(--accent-muted);
}

.issue-subissue-checkbox:checked {
  background: var(--accent, #6366f1);
  border-color: var(--accent, #6366f1);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

.issue-subissue-checkbox-wrap:hover .issue-subissue-checkbox,
.issue-subissue-checkbox:hover {
  border-color: rgba(255, 255, 255, 0.35);
}

.issue-subissue-checkbox:focus {
  outline: none;
  box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.4);
}

.issue-subissue-checkbox-wrap:hover,
.issue-subissue-checkbox:focus {
  outline: none;
}

.issue-subissue-title-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
  max-width: 100%;
  width: 100%;
  max-height: fit-content;
}

.issue-subissue-description-wrap {
  max-width: 100%;
  width: 100%;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.issue-subissue-description-label {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-bottom: var(--space-1);
}

.issue-subissue-description-input {
  min-height: 60px;
  flex: 1;
}

.issue-subissue-attrs .issue-attr-btn {
  flex-shrink: 0;
}

.issue-subissue-attrs .issue-attr-dropdown {
  position: relative;
}

.issue-subissue-attrs .issue-attr-btn {
  padding: 6px 10px;
  font-size: var(--text-sm);
  border-radius: var(--radius-sm);
  min-height: 28px;
}

.issue-subissue-assignee .assignee-avatar-sm {
  width: 22px;
  height: 22px;
  font-size: 10px;
}

.issue-subissue-assignee .issue-attr-btn {
  padding: 4px 8px;
}

.issue-subissue-assignee-menu .issue-assignee-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--text-primary);
  text-align: left;
}

.issue-subissue-assignee-menu .issue-assignee-item:hover {
  background: var(--bg-overlay);
}

.issue-subissue-attrs .issue-attr-menu {
  position: absolute;
  right: 0;
  top: 100%;
  margin-top: 4px;
  padding: var(--space-2);
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  z-index: 40;
  min-width: 125px;
  max-height: 320px;
  overflow-y: auto;
}

.issue-subissue-attrs .issue-subissue-status-menu {
  min-width: 220px;
}

.issue-subissue-status-menu .issue-attr-menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.issue-subissue-status-menu .issue-attr-menu-item svg {
  width: 14px;
  height: 14px;
  opacity: 0.95;
  flex-shrink: 0;
}

.issue-subissue-assignee .issue-attr-menu {
  left: auto;
  right: 0;
}

/* Sub-issue row: due date and assignee icon colors */
.issue-subissue-duedate-btn svg,
.issue-subissue-duedate-btn i[data-lucide] {
  color: #22d3ee;
}

.issue-subissue-assignee-btn svg,
.issue-subissue-assignee-btn i[data-lucide] {
  color: #a78bfa;
}

.issue-subissue-attrs .issue-subissue-assignee-menu .issue-subissue-assignee-list,
.issue-subissue-assignee-menu .issue-subissue-assignee-list {
  max-height: 160px;
  overflow-y: auto;
}

.issue-subissue-input {
  flex: 1;
  min-width: 0;
  height: 32px;
  padding: 0 var(--space-3);
  background: var(--bg-overlay, #1e293b);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color 0.15s ease;
}

.issue-subissue-input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.issue-subissue-input:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.issue-subissue-input:focus {
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.issue-subissue-remove {
  flex-shrink: 0;
  color: var(--text-tertiary);
}

.issue-subissue-remove:hover {
  color: var(--text-primary);
}

.issue-subissue-add {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-left: auto;
}

.issue-subissue-add:hover {
  color: var(--text-primary);
}

.issue-subissue-add svg {
  width: 14px;
  height: 14px;
}

.issue-attr-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  transition: color 0.12s, background 0.12s, border-color 0.12s;
  max-width: 100%;
  width: 100%;
}

.issue-attr-btn span {
  text-align: left;
}

#popup-due-date-btn {
  flex-wrap: wrap;
}

#popup-due-date-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  order: 3;
}

.issue-attr-btn:hover {
  border: var(--border-subtle);
}

.issue-attr-btn svg {
  min-width: 14px;
  min-height: 14px;
  width: 14px;
  height: 14px;
  order: 1;
}

.issue-attr-dropdown {
  position: relative;
  max-width: 100%;
  width: 100%;
}

.issue-attr-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 4px;
  min-width: 125px;
  padding: var(--space-2);
  background: var(--bg-dropdown-panel, var(--bg-raised));
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  z-index: 40;
}

.issue-attr-menu[hidden],
.issue-status-menu[hidden],
.issue-assignee-menu[hidden],
.issue-estimate-menu[hidden],
.issue-labels-menu[hidden],
.issue-priority-menu[hidden],
.issue-duedate-menu[hidden] {
  display: none !important;
}

.issue-attr-menu-item {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  text-align: left;
  transition: background 0.12s, color 0.12s;
}

.issue-attr-menu-item:hover {
  background: var(--bg-hover);
}

.issue-attr-menu-item.is-selected {
  color: #fff;
  background: var(--dropdown-selected-bg, #3e6297);
}

.issue-attr-menu-item.is-selected:hover {
  background: var(--dropdown-selected-hover-bg, #4a6fa8);
}

.issue-status-menu {
  min-width: 220px;
  max-height: 320px;
  overflow-y: auto;
}

.issue-status-menu .issue-attr-menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.issue-status-menu .issue-attr-menu-item svg {
  width: 14px;
  height: 14px;
  opacity: 0.95;
  flex-shrink: 0;
}

.issue-template-menu .issue-attr-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.issue-template-menu .issue-attr-menu-item svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* Status icon colors by functionality (dropdown items and status buttons) */
.issue-status-menu .issue-attr-menu-item[data-value="triage"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="triage"] svg,
.issue-status-wrap .issue-attr-btn[data-value="triage"] svg,
.issue-subissue-status .issue-attr-btn[data-value="triage"] svg {
  color: #60a5fa;
}

.issue-status-menu .issue-attr-menu-item[data-value="backlog"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="backlog"] svg,
.issue-status-wrap .issue-attr-btn[data-value="backlog"] svg,
.issue-subissue-status .issue-attr-btn[data-value="backlog"] svg {
  color: #94a3b8;
}

.issue-status-menu .issue-attr-menu-item[data-value="todo"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="todo"] svg,
.issue-status-wrap .issue-attr-btn[data-value="todo"] svg,
.issue-subissue-status .issue-attr-btn[data-value="todo"] svg {
  color: #818cf8;
}

.issue-status-menu .issue-attr-menu-item[data-value="in-progress"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="in-progress"] svg,
.issue-status-wrap .issue-attr-btn[data-value="in-progress"] svg,
.issue-subissue-status .issue-attr-btn[data-value="in-progress"] svg {
  color: #6366f1;
}

.issue-status-menu .issue-attr-menu-item[data-value="in-review"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="in-review"] svg,
.issue-status-wrap .issue-attr-btn[data-value="in-review"] svg,
.issue-subissue-status .issue-attr-btn[data-value="in-review"] svg {
  color: #a78bfa;
}

.issue-status-menu .issue-attr-menu-item[data-value="reopen"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="reopen"] svg,
.issue-status-wrap .issue-attr-btn[data-value="reopen"] svg,
.issue-subissue-status .issue-attr-btn[data-value="reopen"] svg {
  color: #fbbf24;
}

.issue-status-menu .issue-attr-menu-item[data-value="ready-for-deployment"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="ready-for-deployment"] svg,
.issue-status-wrap .issue-attr-btn[data-value="ready-for-deployment"] svg,
.issue-subissue-status .issue-attr-btn[data-value="ready-for-deployment"] svg {
  color: #2dd4bf;
}

.issue-status-menu .issue-attr-menu-item[data-value="deployed-not-qa"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="deployed-not-qa"] svg,
.issue-status-wrap .issue-attr-btn[data-value="deployed-not-qa"] svg,
.issue-subissue-status .issue-attr-btn[data-value="deployed-not-qa"] svg {
  color: #fb923c;
}

.issue-status-menu .issue-attr-menu-item[data-value="deployed-qa-ready"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="deployed-qa-ready"] svg,
.issue-status-wrap .issue-attr-btn[data-value="deployed-qa-ready"] svg,
.issue-subissue-status .issue-attr-btn[data-value="deployed-qa-ready"] svg {
  color: #22d3ee;
}

.issue-status-menu .issue-attr-menu-item[data-value="in-qa"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="in-qa"] svg,
.issue-status-wrap .issue-attr-btn[data-value="in-qa"] svg,
.issue-subissue-status .issue-attr-btn[data-value="in-qa"] svg {
  color: #06b6d4;
}

.issue-status-menu .issue-attr-menu-item[data-value="deployed-qad"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="deployed-qad"] svg,
.issue-status-wrap .issue-attr-btn[data-value="deployed-qad"] svg,
.issue-subissue-status .issue-attr-btn[data-value="deployed-qad"] svg {
  color: #34d399;
}

.issue-status-menu .issue-attr-menu-item[data-value="on-production-qa-ready"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="on-production-qa-ready"] svg,
.issue-status-wrap .issue-attr-btn[data-value="on-production-qa-ready"] svg,
.issue-subissue-status .issue-attr-btn[data-value="on-production-qa-ready"] svg {
  color: #4ade80;
}

.issue-status-menu .issue-attr-menu-item[data-value="blocked"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="blocked"] svg,
.issue-status-wrap .issue-attr-btn[data-value="blocked"] svg,
.issue-subissue-status .issue-attr-btn[data-value="blocked"] svg {
  color: #f87171;
}

.issue-status-menu .issue-attr-menu-item[data-value="done"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="done"] svg,
.issue-status-wrap .issue-attr-btn[data-value="done"] svg,
.issue-subissue-status .issue-attr-btn[data-value="done"] svg {
  color: #22c55e;
}

.issue-status-menu .issue-attr-menu-item[data-value="on-production-tested"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="on-production-tested"] svg,
.issue-status-wrap .issue-attr-btn[data-value="on-production-tested"] svg,
.issue-subissue-status .issue-attr-btn[data-value="on-production-tested"] svg {
  color: #16a34a;
}

.issue-status-menu .issue-attr-menu-item[data-value="canceled"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="canceled"] svg,
.issue-status-wrap .issue-attr-btn[data-value="canceled"] svg,
.issue-subissue-status .issue-attr-btn[data-value="canceled"] svg {
  color: #94a3b8;
}

.issue-status-menu .issue-attr-menu-item[data-value="duplicate"] svg,
.issue-subissue-status-menu .issue-attr-menu-item[data-value="duplicate"] svg,
.issue-status-wrap .issue-attr-btn[data-value="duplicate"] svg,
.issue-subissue-status .issue-attr-btn[data-value="duplicate"] svg {
  color: #64748b;
}

/* Priority dropdown — search + list with icons, numbers, checkmark */
.issue-priority-menu {
  min-width: 220px;
  max-width: 280px;
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.priority-menu-search-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3);
  border-bottom: var(--border-subtle);
}

.priority-menu-search {
  flex: 1;
  min-width: 0;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s;
}

.priority-menu-search::placeholder {
  color: var(--text-placeholder);
}

.priority-menu-search:focus {
  border-color: var(--border-strong);
}

.priority-menu-shortcut {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-tertiary);
  background: var(--bg-muted, rgba(255, 255, 255, 0.06));
  border-radius: 3px;
  flex-shrink: 0;
}

.priority-menu-list {
  padding: var(--space-2);
  max-height: 280px;
  overflow-y: auto;
}

.priority-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background 0.12s, color 0.12s;
}

.priority-menu-item:hover {
  background: var(--bg-hover);
}

.priority-menu-item.is-selected {
  background: var(--bg-active);
}

.priority-menu-item-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--text-secondary);
}

.priority-menu-item-icon svg,
.priority-menu-item-icon .priority-icon-svg {
  width: 16px;
  height: 16px;
  display: block;
}

.priority-menu-item-icon .priority-icon-urgent {
  color: #e67e22;
}

.priority-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--text-secondary);
}

.priority-btn-icon svg,
.priority-btn-icon .priority-icon-svg {
  width: 16px;
  height: 16px;
  display: block;
}

.priority-btn-icon .priority-icon-urgent {
  color: #e67e22;
}

/* Priority icon colors — buttons (main + sub-issue) and menu items */
.issue-attr-btn[data-value="Urgent"] .priority-btn-icon .priority-icon-urgent,
.issue-attr-btn[data-value="Urgent"] .priority-btn-icon svg {
  color: #e67e22;
}

.issue-attr-btn[data-value="High"] .priority-btn-icon svg {
  color: #f87171;
}

.issue-attr-btn[data-value="Medium"] .priority-btn-icon svg {
  color: #fbbf24;
}

.issue-attr-btn[data-value="Low"] .priority-btn-icon svg {
  color: #94a3b8;
}

.priority-menu-item[data-value="Urgent"] .priority-menu-item-icon .priority-icon-urgent,
.priority-menu-item[data-value="Urgent"] .priority-menu-item-icon svg {
  color: #e67e22;
}

.priority-menu-item[data-value="High"] .priority-menu-item-icon svg {
  color: #f87171;
}

.priority-menu-item[data-value="Medium"] .priority-menu-item-icon svg {
  color: #fbbf24;
}

.priority-menu-item[data-value="Low"] .priority-menu-item-icon svg {
  color: #94a3b8;
}

.priority-menu-item-label {
  flex: 1;
  min-width: 0;
}

.priority-menu-item-number {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin-left: auto;
  flex-shrink: 0;
}

.priority-menu-item-check {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: var(--accent);
}

.priority-menu-item-check svg {
  width: 14px;
  height: 14px;
}

/* Due date dropdown */
.issue-duedate-menu {
  min-width: 240px;
  padding: var(--space-2);
  display: flex;
  flex-direction: column;
}

.issue-duedate-hint {
  margin-bottom: var(--space-2);
  padding: 0 var(--space-2);
}

.issue-duedate-input {
  width: 100%;
  height: 28px;
  padding: 0 var(--space-3);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color 0.15s;
}

.issue-duedate-input::placeholder {
  color: var(--text-placeholder);
}

.issue-duedate-input:focus {
  border-color: var(--border-strong);
}

.issue-duedate-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.issue-duedate-item-icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}

.issue-duedate-item svg {
  width: 14px;
  height: 14px;
  opacity: 0.7;
  flex-shrink: 0;
  stroke-dasharray: 2 1;
}

.issue-duedate-item.is-selected .issue-duedate-item-icon {
  color: var(--accent);
}

.issue-duedate-item.is-selected .issue-duedate-item-icon svg {
  opacity: 1;
  stroke-dasharray: none;
}

.issue-duedate-item-label {
  flex: 1;
  min-width: 0;
  text-align: left;
}

.issue-duedate-item-date {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  flex-shrink: 0;
}

.issue-duedate-separator {
  height: 1px;
  background: var(--border-subtle);
  margin: var(--space-2) 0;
}

.issue-duedate-custom {
  padding: var(--space-2) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.issue-duedate-custom-label {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-tertiary);
  display: block;
}

.issue-duedate-custom-input {
  width: 100%;
  height: 32px;
  padding: 0 var(--space-3);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color 0.15s;
}

.issue-duedate-custom-input:focus {
  border-color: var(--border-strong);
}

.issue-duedate-custom-input::-webkit-calendar-picker-indicator {
  filter: invert(0.8);
  opacity: 0.7;
  cursor: pointer;
}

/* Assignee dropdown */
.issue-assignee-menu {
  min-width: 260px;
  max-height: 360px;
  padding: var(--space-2);
  display: flex;
  flex-direction: column;
}

.issue-assignee-search-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  padding: 0 var(--space-2);
}

.issue-assignee-search {
  flex: 1;
  height: 28px;
  padding: 0 var(--space-3);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color 0.15s;
}

.issue-assignee-search::placeholder {
  color: var(--text-placeholder);
}

.issue-assignee-search:focus {
  border-color: var(--border-strong);
}

.issue-assignee-search-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-tertiary);
  background: var(--bg-hover);
  border-radius: 4px;
}

.issue-assignee-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  text-align: left;
  transition: background 0.1s, color 0.1s;
}

.issue-assignee-item:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.issue-assignee-item-label {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.issue-assignee-check {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}

.issue-assignee-check svg {
  width: 14px;
  height: 14px;
  color: var(--accent);
}

.issue-assignee-count {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin-left: var(--space-2);
  flex-shrink: 0;
}

.issue-assignee-separator {
  height: 1px;
  background: var(--border-subtle);
  margin: var(--space-2) 0;
}

.issue-assignee-section-label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0 var(--space-3);
  margin-bottom: var(--space-2);
}

.issue-assignee-list {
  overflow-y: auto;
  max-height: 240px;
}

/* Labels dropdown */
.issue-labels-menu {
  min-width: 260px;
  max-height: 360px;
  padding: var(--space-2);
  display: flex;
  flex-direction: column;
}

.issue-labels-search-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  padding: 0 var(--space-2);
}

.issue-labels-search {
  flex: 1;
  height: 28px;
  padding: 0 var(--space-3);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color 0.15s;
}

.issue-labels-search::placeholder {
  color: var(--text-placeholder);
}

.issue-labels-search:focus {
  border-color: var(--border-strong);
}

.issue-labels-search-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-tertiary);
  background: var(--bg-hover);
  border-radius: 4px;
}

.issue-labels-section-label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0 var(--space-3);
  margin-bottom: var(--space-2);
}

.issue-labels-separator {
  height: 1px;
  background: var(--border-subtle);
  margin: var(--space-2) 0;
}

.issue-labels-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.issue-labels-list-all {
  overflow-y: auto;
  max-height: 220px;
}

.issue-labels-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  text-align: left;
  transition: background 0.1s, color 0.1s;
}

.issue-labels-item:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.issue-labels-item-label {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.issue-labels-check {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}

.issue-labels-check svg {
  width: 14px;
  height: 14px;
  color: var(--accent);
}

.label-dot {
  width: 8px;
  height: 8px;
  min-width: 8px;
  min-height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.label-dot-red {
  background: #ef4444;
}

.label-dot-blue {
  background: #3b82f6;
}

.label-dot-cyan {
  background: #06b6d4;
}

.label-dot-grey {
  background: #6b7280;
}

.label-dot-purple {
  background: #8b5cf6;
}

.label-dot-green {
  background: #22c55e;
}

.label-dot-black {
  background: #1f2937;
}

.label-dot-orange {
  background: #f97316;
}

.assignee-avatar {
  width: 24px;
  height: 24px;
  min-width: 24px;
  min-height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 400;
  color: #fff;
  background: var(--accent);
  flex-shrink: 0;
}

.assignee-avatar-none {
  background: var(--bg-hover);
  color: var(--text-tertiary);
}

.assignee-avatar-none svg {
  width: 14px;
  height: 14px;
}

.assignee-avatar-sm {
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
  font-size: 8px;
}

/* Avatar color by first letter of initials */
.assignee-avatar[data-initials]:not(.assignee-avatar-none) {
  background: var(--accent);
}

.issue-assignee-item .assignee-avatar[data-initials^="A"] {
  background: #6366f1;
}

.issue-assignee-item .assignee-avatar[data-initials^="B"] {
  background: #8b5cf6;
}

.issue-assignee-item .assignee-avatar[data-initials^="C"] {
  background: #a855f7;
}

.issue-assignee-item .assignee-avatar[data-initials^="D"] {
  background: #d946ef;
}

.issue-assignee-item .assignee-avatar[data-initials^="E"] {
  background: #ec4899;
}

.issue-assignee-item .assignee-avatar[data-initials^="F"] {
  background: #f43f5e;
}

.issue-assignee-item .assignee-avatar[data-initials^="G"] {
  background: #f97316;
}

.issue-assignee-item .assignee-avatar[data-initials^="H"] {
  background: #eab308;
}

.issue-assignee-item .assignee-avatar[data-initials^="I"] {
  background: #84cc16;
}

.issue-assignee-item .assignee-avatar[data-initials^="J"] {
  background: #22c55e;
}

.issue-assignee-item .assignee-avatar[data-initials^="K"] {
  background: #14b8a6;
}

.issue-assignee-item .assignee-avatar[data-initials^="L"] {
  background: #06b6d4;
}

.issue-assignee-item .assignee-avatar[data-initials^="M"] {
  background: #0ea5e9;
}

.issue-assignee-item .assignee-avatar[data-initials^="N"] {
  background: #3b82f6;
}

.issue-assignee-item .assignee-avatar[data-initials^="O"] {
  background: #6366f1;
}

.issue-assignee-item .assignee-avatar[data-initials^="P"] {
  background: #8b5cf6;
}

.issue-assignee-item .assignee-avatar[data-initials^="Q"] {
  background: #a855f7;
}

.issue-assignee-item .assignee-avatar[data-initials^="R"] {
  background: #d946ef;
}

.issue-assignee-item .assignee-avatar[data-initials^="S"] {
  background: #ec4899;
}

.issue-assignee-item .assignee-avatar[data-initials^="T"] {
  background: #f43f5e;
}

.issue-assignee-item .assignee-avatar[data-initials^="U"] {
  background: #f97316;
}

.issue-assignee-item .assignee-avatar[data-initials^="V"] {
  background: #eab308;
}

.issue-assignee-item .assignee-avatar[data-initials^="W"] {
  background: #84cc16;
}

.issue-assignee-item .assignee-avatar[data-initials^="X"] {
  background: #22c55e;
}

.issue-assignee-item .assignee-avatar[data-initials^="Y"] {
  background: #14b8a6;
}

.issue-assignee-item .assignee-avatar[data-initials^="Z"] {
  background: #06b6d4;
}

/* Button pill avatar uses same palette */
.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="A"] {
  background: #6366f1;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="B"] {
  background: #8b5cf6;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="C"] {
  background: #a855f7;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="D"] {
  background: #d946ef;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="E"] {
  background: #ec4899;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="F"] {
  background: #f43f5e;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="G"] {
  background: #f97316;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="H"] {
  background: #eab308;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="I"] {
  background: #84cc16;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="J"] {
  background: #22c55e;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="K"] {
  background: #14b8a6;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="L"] {
  background: #06b6d4;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="M"] {
  background: #0ea5e9;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="N"] {
  background: #3b82f6;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="O"] {
  background: #6366f1;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="P"] {
  background: #8b5cf6;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="Q"] {
  background: #a855f7;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="R"] {
  background: #d946ef;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="S"] {
  background: #ec4899;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="T"] {
  background: #f43f5e;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="U"] {
  background: #f97316;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="V"] {
  background: #eab308;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="W"] {
  background: #84cc16;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="X"] {
  background: #22c55e;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="Y"] {
  background: #14b8a6;
}

.issue-assignee-wrap .issue-attr-btn .assignee-avatar[data-initials^="Z"] {
  background: #06b6d4;
}

.issue-more-wrap {
  position: relative;
}

.issue-more-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 4px;
  min-width: 220px;
  padding: var(--space-2);
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  z-index: 50;
}

.issue-more-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  text-align: left;
  transition: background 0.1s, color 0.1s;
}

.issue-more-item:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.issue-more-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  opacity: 0.8;
}

.issue-more-item kbd {
  margin-left: auto;
  font-size: 10px;
  color: var(--text-tertiary);
  font-weight: normal;
}

.issue-modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: var(--space-3) var(--space-4);
  border-top: var(--border-subtle);
  background: var(--bg-base);
  max-width: 100%;
  width: 100%;
  position: sticky;
  bottom: 0;
  margin-top: auto;
  min-height: 51px;
}

.issue-modal-footer-right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.issue-create-more {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  cursor: pointer;
  user-select: none;
}

.issue-create-more input {
  width: 14px;
  height: 14px;
  accent-color: var(--accent);
  cursor: pointer;
}

/* Login page — Linear-style */
.login-page {
  min-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  position: relative;
}

.login-backdrop {
  position: fixed;
  inset: 0;
  background: var(--bg-base);
  z-index: 0;
}

.login-backdrop::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 50% at 50% -20%, var(--glow-accent), transparent);
  opacity: 0.4;
  pointer-events: none;
}

.login-wrap {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 400px;
}

.login-logo {
  text-align: center;
  margin-bottom: var(--space-6);
}

.login-logo img {
  width: 48px;
  height: 48px;
  display: inline-block;
  vertical-align: middle;
}

.login-card {
  padding: var(--space-6);
}

.login-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--text-2xl, 20px);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin: 0 0 var(--space-1);
}

.login-title svg {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.input-wrapper .login-label {
  padding-bottom: 5px;
  display: block;
}

.login-subtitle {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  margin: 0 0 var(--space-6);
}

.login-section-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 var(--space-1);
}

.login-section-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0 0 var(--space-4);
}

.login-divider {
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  margin: var(--space-6) 0;
}

.login-footer-note {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  margin: var(--space-6) 0 0;
  text-align: center;
}

.login-footer-note a {
  color: var(--accent);
  text-decoration: underline;
}

.login-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.login-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
}

.login-input {
  width: 100%;
  height: 36px;
  padding: 0 var(--space-3);
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.login-input::placeholder {
  color: var(--text-placeholder);
}

.login-input:focus {
  border-color: var(--border-strong);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.login-error {
  font-size: var(--text-sm);
  color: #ef4444;
  margin-top: 5px;
}

.login-error-invite {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0.5rem 0 0;
}

.login-error-invite a {
  color: var(--accent);
  text-decoration: underline;
}

.login-error-invite a:hover {
  color: var(--accent-hover, var(--accent));
}

.join-error-wrap {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-default);
}

.join-error-wrap .join-error-message {
  font-size: var(--text-sm);
  color: #ef4444;
  margin: 0;
}

.join-error-hint {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0.5rem 0 var(--space-4);
  line-height: 1.5;
}

.join-paste-wrap {
  margin-top: 1rem;
}

.join-paste-wrap .login-label {
  display: block;
  margin-bottom: 0.375rem;
}

.join-paste-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.join-paste-row .login-input {
  flex: 1;
  min-width: 200px;
}

.join-paste-error {
  font-size: var(--text-sm);
  color: #ef4444;
  margin: 0.375rem 0 0;
}

.login-invite-paste-wrap {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border-default);
}

.login-invite-paste-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0 0 0.75rem;
  line-height: 1.5;
}

.join-error-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

.join-error-actions .btn {
  text-decoration: none;
}

.login-submit {
  height: 36px;
  width: 100%;
  cursor: pointer;
  max-width: fit-content;
  margin-left: auto;
}

.login-hint {
  margin: var(--space-4) 0 0;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.login-hint code {
  padding: 2px 6px;
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  font-size: 11px;
}

.login-toggle {
  margin: var(--space-4) 0 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  gap: 5px;
}

.login-toggle-btn {
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  color: var(--accent);
  cursor: pointer;
  text-decoration: none;
}

.login-toggle-btn:hover {
  text-decoration: underline;
}

.btn-link {
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  color: var(--accent);
  cursor: pointer;
  text-decoration: none;
}

.btn-link:hover {
  text-decoration: underline;
}

/* Issue popup modal */
body.issue-popup-open {
  overflow: hidden;
}

.issue-popup-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  box-sizing: border-box;
}

.issue-popup-overlay[hidden] {
  display: none !important;
  pointer-events: none;
  visibility: hidden;
}

.issue-popup-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer;
}

.issue-popup-container {
  position: relative;
  width: 100%;
  max-width: 1000px;
  background: var(--bg-raised);
  border-radius: var(--radius-md);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.issue-popup-close {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  z-index: 2;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  z-index: 6;
}

.issue-popup-close:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.issue-popup-content {
  width: 100%;
  background: var(--bg-base);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.issue-popup-form {
  display: flex;
  flex-direction: column;
  min-height: 200px;
  overflow: hidden;
  flex-wrap: wrap;
}

.issue-popup-form .issue-modal-wrapper {
  max-width: 100%;
  width: 100%;
  position: relative;
  display: flex;
}

.issue-popup-form .issue-modal-body {
  max-height: calc(100dvh - 20.5dvh);
  overflow: auto;
  width: 100%;
  max-width: 100%;
}

.issue-popup-header {
  padding: var(--space-3) var(--space-4);
  padding-right: 48px;
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  width: 100%;
}

.issue-popup-fields {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-2) var(--space-4);
  align-items: center;
  margin-top: var(--space-4);
}

.issue-popup-label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.issue-popup-select,
.issue-popup-input {
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-overlay);
  color: var(--text-primary);
}

.issue-popup-form .issue-modal-footer {
  border-top: 1px solid var(--border-subtle);
  padding: var(--space-3) var(--space-4);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

.issue-popup-error {
  padding: var(--space-6);
  text-align: center;
}

.issue-popup-error p {
  margin: 0 0 var(--space-4);
  color: var(--text-secondary);
}

.issue-popup-form-error {
  margin-top: var(--space-2);
}

.issue-popup-layout {
  display: flex;
  gap: 0;
  min-height: 0;
  flex: 1;
}

.issue-popup-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}

.issue-popup-sidebar {
  width: 280px;
  flex-shrink: 0;
  border-left: 1px solid var(--border-subtle);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  background: var(--bg-overlay);
}

.popup-sidebar-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-secondary);
  margin: 0 0 var(--space-2);
}

.popup-copy-branch {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.issue-popup-header .popup-copy-branch .btn {
  padding: 6px;
}

.issue-popup-header .popup-branch-name {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  word-break: break-all;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.popup-branch-name {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  word-break: break-all;
}

.popup-header-actions {
  position: relative;
  display: flex;
  align-items: center;
}

.popup-context-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: var(--space-1);
  min-width: 200px;
  padding: var(--space-1) 0;
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  z-index: 100;
  display: flex;
  flex-direction: column;
}

.popup-context-menu[hidden] {
  display: none !important;
}

.popup-context-menu-separator {
  height: 1px;
  background: var(--border-subtle);
  margin: var(--space-1) 0;
  border: none;
}

.popup-context-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: background 0.1s;
}

.popup-context-menu-item:hover:not(:disabled) {
  background: var(--bg-hover);
}

.popup-context-menu-item i,
.popup-context-menu-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  opacity: 0.9;
}

.popup-context-menu-item span:first-of-type {
  flex: 1;
}

.popup-context-menu-shortcut {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin-left: var(--space-2);
}

.popup-context-menu-item-danger:hover:not(:disabled),
.popup-context-menu-item-danger:not(:disabled) {
  color: var(--danger, #dc2626);
}

.popup-context-menu-item-danger:hover:not(:disabled) {
  background: rgba(220, 38, 38, 0.08);
}

.issue-popup-sidebar-attrs.issue-attributes {
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: stretch;
}

.issue-popup-sidebar-attrs .issue-attr-dropdown {
  width: 100%;
}

.issue-popup-sidebar-attrs .issue-attr-btn {
  width: 100%;
  justify-content: flex-start;
}

.popup-sub-issue-of {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: var(--space-2) 0;
}

.popup-sub-issue-of-id {
  font-weight: 500;
  color: var(--text-primary);
}

.popup-sub-issue-of-link {
  font-weight: 500;
  color: var(--link-color, var(--color-primary, #2563eb));
  text-decoration: none;
}

.popup-sub-issue-of-link:hover {
  text-decoration: underline;
}

.popup-section-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-secondary);
  margin: var(--space-4) 0 var(--space-2);
}

.popup-activity-list,
.popup-comment-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.popup-activity-item,
.popup-comment-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: var(--text-sm);
  background-color: var(--bg-overlay);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: lch(0 0 0 / 0.06) 0px 4px 4px -1px, lch(0 0 0 / 0.12) 0px 1px 1px 0px;
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
}

.popup-activity-empty,
.popup-comment-empty {
  padding: var(--space-3) 0;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  list-style: none;
}

.popup-attachments,
.new-issue-attachments {
  margin: var(--space-4) 0 var(--space-2);
}

.attachment-drop-zone {
  border: 2px dashed transparent;
  border-radius: var(--radius-md);
  padding: var(--space-2);
  padding-left: var(--space-2);
  padding-right: var(--space-2);
  transition: border-color 0.2s, background 0.2s;
  /* border: var(--border-subtle); */
  background: var(--bg-hover);
}

.attachment-drop-zone-drag-over {
  border-color: var(--accent-primary);
  background: var(--bg-hover);
}

.popup-attachments-hint {
  margin: 0 0 var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

.popup-attachment-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}

.popup-attachment-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  border-bottom: 1px solid var(--border-subtle);
  font-size: var(--text-sm);
  position: relative;
}

.popup-attachment-item:last-of-type {
  border-bottom: none;
}

.popup-attachment-preview-wrap {
  flex-shrink: 0;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--bg-muted, rgba(255, 255, 255, 0.06));
  border: 1px solid var(--border-subtle);
  width: 100%;
  height: 100%;
}

.popup-attachment-preview {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.popup-attachment-item-has-preview .popup-attachment-link {
  flex: 1;
  min-width: 0;
}

.popup-attachment-link {
  color: var(--accent-primary);
  text-decoration: none;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  position: absolute;
  width: 100%;
  height: 100%;
  opacity: 0;
}

.popup-attachment-link:hover {
  text-decoration: underline;
}

.popup-attachment-size {
  color: var(--text-tertiary);
  font-size: var(--text-xs);
  flex-shrink: 0;
  display: none;
}

.popup-attachment-delete {
  flex-shrink: 0;
  position: absolute;
  z-index: 1;
  right: 5px;
  top: 5px;
  border: var(--border-subtle);
  color: var(--text-secondary);
  cursor: pointer;
  background: var(--bg-overlay);
}

.popup-attachment-delete:hover {
  border: var(--border-subtle);
  background: var(--bg-overlay);
  color: var(--text-primary);
}

.popup-attachment-upload {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
  flex-wrap: wrap;
  justify-content: flex-end;
}

.popup-attachment-input {
  position: absolute;
  width: 0.1px;
  height: 0.1px;
  opacity: 0;
  overflow: hidden;
  z-index: -1;
}

.popup-attachment-upload-label {
  cursor: pointer;
  margin: 0;
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
}

.popup-attachment-upload-label:hover {
  border: var(--border-subtle);
  background: var(--bg-hover);
  color: var(--text-primary);
}

.popup-attachment-empty {
  padding: var(--space-3) 0;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  list-style: none;
}

.popup-activity-avatar,
.popup-comment-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bg-overlay);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  flex-shrink: 0;
}

.popup-activity-text,
.popup-comment-text {
  flex: 1;
  color: var(--text-primary);
}

.popup-activity-time,
.popup-comment-time {
  color: var(--text-tertiary);
  font-size: var(--text-xs);
}

.popup-comment-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.popup-comment-reactions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
}

.popup-comment-reaction-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-xs);
  cursor: pointer;
  transition: color 0.15s, background 0.15s, border-color 0.15s;
  max-width: fit-content;
  box-shadow: lch(0 0 0 / 0.06) 0px 4px 4px -1px, lch(0 0 0 / 0.12) 0px 1px 1px 0px;
  padding: 4px 7px 5px;
  border-radius: 30px;
  background: lch(17.085 19.664 285.566);
  border: 1px solid lch(24.108 20.17 285.566);
}

.popup-comment-reaction-btn svg {
  width: 16px;
  height: 16px;
}

.popup-comment-reaction-btn:hover {
  color: var(--text-secondary);
  background: var(--bg-tertiary);
}

.popup-comment-reaction-btn:disabled {
  opacity: 0.7;
  cursor: wait;
}

.popup-comment-reaction-btn-active {
  color: var(--primary, #6366f1);
}

.popup-comment-reaction-btn-active svg {
  fill: var(--primary, #6366f1);
}

.popup-comment-reaction-btn .popup-comment-reaction-count {
  font-variant-numeric: tabular-nums;
  min-width: 0.9em;
  text-align: left;
}

.popup-comment-reaction-btn .popup-comment-reaction-emoji {
  font-size: 1em;
  line-height: 1;
}

.popup-comment-reaction-add-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  padding: 0;
  font-size: 14px;
  color: var(--text-tertiary);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}

.popup-comment-reaction-add-btn:hover {
  color: var(--text-secondary);
  background: var(--bg-tertiary);
}

/* Emoji picker popover */
.popup-emoji-picker {
  position: fixed;
  z-index: 10010;
  width: 280px;
  max-height: 320px;
  padding: var(--space-2);
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.popup-emoji-picker-search {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-overlay);
  color: var(--text-primary);
}

.popup-emoji-picker-search::placeholder {
  color: var(--text-tertiary);
}

.popup-emoji-picker-section-label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-tertiary);
  margin-bottom: var(--space-1);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.popup-emoji-picker-row,
.popup-emoji-picker-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  margin-bottom: var(--space-2);
}

.popup-emoji-picker-grid {
  max-height: 180px;
  overflow-y: auto;
}

.popup-emoji-picker-emoji {
  width: 32px;
  height: 32px;
  padding: 0;
  font-size: 1.25rem;
  line-height: 1;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  cursor: pointer;
  transition: background 0.12s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.popup-emoji-picker-emoji:hover {
  background: var(--bg-tertiary);
}

.popup-comment-author {
  font-weight: 500;
  color: var(--text-primary);
}

.popup-comment-add {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-4);
  position: relative;
}

.popup-comment-input {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-overlay);
  color: var(--text-primary);
  resize: vertical;
  min-height: 60px;
}

.popup-comment-add .btn.btn-primary {
  position: absolute;
  right: 5px;
  bottom: 5px;
  padding: 4px;
  border-radius: 200px;
}

.popup-comment-text .mention {
  font-weight: 600;
  color: var(--primary, #6366f1);
  background: var(--bg-muted, rgba(99, 102, 241, 0.1));
  padding: 0 4px;
  border-radius: 4px;
}

.popup-comment-mention-dropdown {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 100%;
  margin-bottom: 4px;
  max-height: 180px;
  overflow-y: auto;
  background: var(--bg-overlay);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
  z-index: 20;
  list-style: none;
  padding: 4px 0;
}

.popup-comment-mention-dropdown li {
  padding: 6px 12px;
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.popup-comment-mention-dropdown li:hover,
.popup-comment-mention-dropdown li[aria-selected="true"] {
  background: var(--bg-muted);
}

.popup-comment-mention-dropdown li .mention-email {
  font-size: 0.85em;
  color: var(--text-tertiary);
  margin-left: 6px;
}

.popup-deps-section {
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}

.popup-deps-section .popup-section-title {
  margin-top: 0;
}

.popup-deps-blocked-by,
.popup-deps-blocks {
  margin-bottom: var(--space-3);
}

.popup-deps-label {
  display: block;
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-tertiary);
  margin-bottom: var(--space-1);
}

.popup-deps-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.popup-dep-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  background: var(--bg-muted);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}

.popup-dep-chip .popup-dep-link {
  color: var(--primary, #6366f1);
  text-decoration: none;
  font-weight: 500;
}

.popup-dep-chip .popup-dep-link:hover {
  text-decoration: underline;
}

.popup-dep-chip .popup-dep-title {
  color: var(--text-secondary);
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.popup-deps-add {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.popup-deps-input {
  width: 180px;
  padding: 6px 10px;
  font-size: var(--text-sm);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  background: var(--bg-overlay, #1e293b);
  color: var(--text-primary);
}

.popup-deps-input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.popup-deps-input:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.popup-deps-input:focus {
  outline: none;
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.popup-deps-blocks-list {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.popup-deps-blocks-list .popup-dep-link {
  color: var(--primary, #6366f1);
  text-decoration: none;
  font-weight: 500;
}

.popup-deps-blocks-list .popup-dep-link:hover {
  text-decoration: underline;
}

/* Issue links in description and comments (#456, #PROJ-123) */
.issue-link {
  color: var(--primary, #6366f1);
  text-decoration: none;
  font-weight: 500;
  cursor: pointer;
}

.issue-link:hover {
  text-decoration: underline;
}

.issue-description-readonly .issue-link,
.popup-comment-text .issue-link {
  color: var(--primary, #6366f1);
}

.popup-deps-empty {
  color: var(--text-tertiary);
  font-style: italic;
}

.popup-comment-error {
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  color: var(--danger, #dc2626);
}

.org-page {
  max-width: 100%;
  margin: 0 auto;
}

.org-page h1 {
  margin-top: 0;
}

.org-section-title {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 var(--space-2);
  color: var(--text-primary);
}

.org-section-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0 0 var(--space-4);
}

.org-card {
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  margin-bottom: var(--space-4);
}

.org-org-card {
  margin-bottom: var(--space-4);
}

.org-has-org {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.org-main-card, #org-admin-wrap {
  padding: var(--space-6);
}

.org-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.org-card-header-wrapper {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.org-card-header h2,
.org-org-name {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0;
  color: var(--text-primary);
}

.org-header-logo-wrap {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm, 4px);
  overflow: hidden;
  background: var(--bg-muted, rgba(255, 255, 255, 0.08));
}

.org-header-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: var(--radius-sm, 4px);
}

.org-header-logo-placeholder {
  display: none;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
}


.org-card-logo-wrap {
  display: inline-flex;
  align-items: center;
}

.org-card-logo {
  width: 32px;
  height: 32px;
  object-fit: contain;
  border-radius: var(--radius-sm, 4px);
  margin-right: var(--space-1);
}

.org-card-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0 0 var(--space-5);
}

.org-members-title {
  font-size: var(--text-base);
  font-weight: 600;
  margin: 0;
  color: var(--text-primary);
}

.org-input {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
  background: transparent;
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: color 0.12s, background 0.12s, border-color 0.12s;
  font-family: inherit;
  width: 100%;
}

.org-input:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.org-input:focus {
  outline: none;
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.org-input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.org-add-section {
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  padding: 10px 14px;
  background: var(--bg-base);
  border: 1px solid var(--show-archived-border);
  border-radius: 10px;
  margin-bottom: var(--space-6);
  background: var(--bg-raised);
}

.org-add-hint {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  margin: 0 0 var(--space-3);
}

.org-delete-org-section {
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-subtle);
  margin-left: auto;
}

.org-delete-org-section .org-workspace-hint {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin: 0 0 var(--space-3);
}

.org-delete-org-section .btn-danger {
  margin-top: var(--space-2);
}

.org-card-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.org-invite-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.org-invite-email {
  min-width: 200px;
}

.org-invite-link-wrap {
  width: 100%;
  margin-top: var(--space-2);
}

.org-invite-link-label {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin-bottom: var(--space-1);
}

.org-invite-link-inp {
  width: 100%;
  font-size: var(--text-xs);
}

.org-form-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
  color: var(--text-primary);
}

.org-form-fields {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.org-form-actions {
  display: flex;
  gap: var(--space-2);
}

.org-add-user-form.panel {
  margin: var(--space-2) 0;
}

.org-loading {
  padding: var(--space-6);
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

.org-view-only .org-user-edit,
.org-view-only .org-user-remove {
  display: none !important;
}

.org-user-select-cell {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  margin-right: var(--space-2);
}

.org-view-only .org-user-select-cell {
  display: none !important;
}

.org-members-bulk-hint {
  font-size: 0.8125rem;
  color: var(--text-secondary);
  margin: 0 0 var(--space-0);
}

.org-members-bulk-hint--inline {
  margin-bottom: var(--space-2);
}

.org-members-bulk-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) 0;
}

.org-members-bulk-select-all {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-base);
  border: 1px solid var(--show-archived-border);
  border-radius: 10px;
  cursor: pointer;
  user-select: none;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.org-members-bulk-select-all:hover {
  border-color: #3a3a3a;
  background: rgba(255, 255, 255, 0.02);
}

.org-members-bulk-select-all:focus-within {
  outline: none;
  box-shadow: 0 0 0 2px var(--bg-base), 0 0 0 4px rgba(91, 95, 199, 0.45);
}

.org-members-bulk-count {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
  min-width: 5.5rem;
}

/* Bulk project picker — custom dark dropdown (matches reference: dark panel, blue hover pill) */
.org-bulk-project-dd {
  position: relative;
  min-width: 160px;
  max-width: 220px;
  flex: 0 1 auto;
  z-index: 1;
}

.org-bulk-project-dd.is-open {
  z-index: 60;
}

.org-bulk-project-select--native.org-bulk-project-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.org-bulk-project-dd-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  width: 100%;
  min-height: 36px;
  padding: 8px 10px;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  background: var(--bg-base, #0d0d0d);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.org-bulk-project-dd-trigger:hover {
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.03);
}

.org-bulk-project-dd-trigger:focus {
  outline: none;
  border-color: rgba(91, 95, 199, 0.65);
  box-shadow: 0 0 0 2px rgba(91, 95, 199, 0.25);
}

.org-bulk-project-dd-value {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
  color: var(--text-primary);
}

.org-bulk-project-dd-value.is-placeholder {
  color: var(--text-tertiary);
  font-weight: 400;
}

.org-bulk-project-dd-chevron {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  pointer-events: none;
}

.org-bulk-project-dd-chevron svg {
  width: 16px;
  height: 16px;
  transition: transform 0.18s ease;
}

.org-bulk-project-dd.is-open .org-bulk-project-dd-chevron svg {
  transform: rotate(180deg);
}

.org-bulk-project-dd-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  min-width: 100%;
  padding: var(--space-2);
  margin: 0;
  list-style: none;
  background: var(--bg-dropdown-panel, #2a2a2e);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.55);
  z-index: 70;
  max-height: 280px;
  overflow-y: auto;
}

.org-bulk-project-dd-menu[hidden] {
  display: none !important;
}

.org-bulk-project-dd-item {
  display: block;
  width: 100%;
  margin: 0;
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  text-align: left;
  background: transparent;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}

.org-bulk-project-dd-item--placeholder {
  color: var(--text-secondary);
  font-weight: 400;
  cursor: pointer;
}

.org-bulk-project-dd-item:hover {
  background: var(--accent);
  color: #fff;
}

.org-bulk-project-dd-item--placeholder:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
}

.org-bulk-project-dd-item.is-selected:not(:hover) {
  background: rgba(94, 106, 210, 0.35);
  color: #fff;
}

.org-bulk-project-dd-item.is-selected:hover {
  background: var(--accent);
  color: #fff;
}

.org-bulk-project-dd-item--placeholder.is-selected:not(:hover) {
  background: transparent;
  color: var(--text-secondary);
}

/* Profile page */
.profile-page {
  max-width: 640px;
  margin: 0 auto;
  padding: var(--space-6, 24px);
}

.profile-title {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0 0 var(--space-6);
  color: var(--text-primary);
}

.settings-page {
  max-width: 560px;
  padding: var(--space-6, 24px);
}

.settings-list {
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

.settings-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  color: var(--text-primary);
  transition: background-color 0.15s ease;
}

.settings-item:last-child {
  border-bottom: none;
}

.settings-item:hover {
  background: var(--bg-hover);
}

.settings-item i:first-of-type {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--text-secondary);
}

.settings-item span {
  flex: 1;
  font-size: var(--text-sm);
  font-weight: 500;
}

.settings-item-chevron {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  color: var(--text-tertiary);
}

.settings-item-logout {
  color: var(--text-secondary);
}

.settings-item-logout:hover {
  color: var(--text-primary);
}

.profile-section {
  margin-bottom: var(--space-6);
  padding: var(--space-6, 20px);
  background: var(--bg-overlay);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}

.profile-section-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 var(--space-4);
  color: var(--text-primary);
}

.profile-details {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.profile-detail-row {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: space-between;
}

.profile-label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  padding-top: var(--space-2);
}

.profile-hint {
  grid-column: 1;
  grid-row: 2;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin: 0;
}

.profile-detail-row .profile-value {
  grid-column: 2;
}

.profile-detail-row .profile-hint+.profile-value {
  grid-row: 1 / -1;
}

.profile-value {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.profile-value-edit {
  flex-wrap: wrap;
}

.profile-input {
  padding: var(--space-2) var(--space-3);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  background: var(--bg-overlay, #1e293b);
  color: var(--text-primary);
  min-width: 200px;
  max-width: 100%;
  text-align: right;
  transition: border-color 0.15s ease, background-color 0.15s ease;
}

.profile-input:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.profile-input:focus {
  outline: none;
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.profile-input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.profile-input:disabled,
.profile-input-readonly {
  background: var(--bg-overlay);
  color: var(--text-secondary);
  cursor: default;
}

.profile-edit-icon {
  flex-shrink: 0;
  min-width: 28px;
  min-height: 28px;
}

.profile-edit-actions {
  display: inline-flex;
  gap: var(--space-2);
  align-items: center;
}

.profile-error {
  grid-column: 2;
  font-size: var(--text-sm);
  color: var(--danger, #dc2626);
  margin: var(--space-1) 0 0;
}

.profile-avatar {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 600;
}

.profile-workspace {
  padding: var(--space-3) 0;
}

.profile-workspace-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.profile-workspace-row .btn-danger {
  /* border: none; */
}

.profile-workspace-text {
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.profile-workspace-hint {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin: var(--space-2) 0 0;
}

.profile-delete-section .profile-workspace-hint {
  margin-bottom: var(--space-3);
}

.profile-delete-confirm {
  margin-top: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}

.profile-delete-confirm .profile-label {
  display: block;
  margin-bottom: var(--space-2);
}

.profile-delete-confirm .profile-input {
  max-width: 280px;
  margin-bottom: var(--space-2);
}

.profile-delete-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.profile-digest {
  padding: var(--space-3) 0;
}

.profile-digest-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-primary);
  cursor: pointer;
}

.profile-digest-toggle input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  border-radius: 4px;
  border: 1px solid var(--accent-muted);
  background: var(--accent-muted);
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}

.profile-digest-toggle input[type="checkbox"]:hover {
  background: rgba(99, 102, 241, 0.5);
  border-color: rgba(129, 140, 248, 0.6);
}

.profile-digest-toggle input[type="checkbox"]:checked {
  background: var(--accent, #6366f1);
  border-color: var(--accent-muted);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 8l3 3 7-7'/%3E%3C/svg%3E");
  background-size: 12px 12px;
  background-position: center;
  background-repeat: no-repeat;
}

.profile-digest-frequency {
  margin-top: var(--space-4);
  position: relative;
}

.profile-digest-frequency .profile-label {
  display: block;
  margin-bottom: var(--space-1);
  font-size: var(--text-sm);
}

.profile-digest-dropdown {
  position: relative;
  display: inline-block;
}

.profile-digest-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  min-width: 120px;
  padding: var(--space-2) var(--space-3);
  background: var(--bg-overlay, #1e293b);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease;
}

.profile-digest-dropdown-trigger:hover {
  background: var(--bg-hover, #334155);
}

.profile-digest-dropdown-trigger svg,
.profile-digest-dropdown-trigger i[data-lucide] {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--text-secondary);
}

.profile-digest-dropdown-value {
  flex: 1;
  text-align: left;
}

.profile-digest-dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  min-width: 100%;
  padding: var(--space-1);
  z-index: 100;
  list-style: none;
  background: var(--bg-overlay);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.profile-digest-dropdown-menu[hidden] {
  display: none !important;
}

.profile-digest-dropdown-item {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-primary);
  font-size: var(--text-sm);
  text-align: left;
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.profile-digest-dropdown-item:hover {
  background: var(--bg-hover, #334155);
}

.profile-digest-dropdown-item.is-selected {
  background: var(--dropdown-selected-bg, #2563eb);
  color: #fff;
}

.profile-digest-dropdown-item.is-selected:hover {
  background: var(--dropdown-selected-hover-bg, #3b82f6);
}

.profile-select {
  padding: var(--space-2) var(--space-3);
  background: var(--bg-overlay);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-sm);
  min-width: 140px;
}

.profile-digest-hint {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin: var(--space-2) 0 0;
}

/* Admin — Real-time notifications panel + toggle */
.admin-realtime-panel {
  max-width: 480px;
}

.admin-realtime-desc {
  color: var(--text-secondary);
  font-size: var(--text-sm);
  margin: 0 0 var(--space-4);
}

.admin-realtime-form .profile-detail-row {
  margin-bottom: var(--space-4);
}

.admin-realtime-toggle-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.admin-realtime-toggle-label {
  margin: 0;
  flex-shrink: 0;
  padding: 0;
}

.admin-realtime-switch {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  user-select: none;
}

.admin-realtime-switch-input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.admin-realtime-switch-track {
  position: relative;
  width: 44px;
  height: 24px;
  background: var(--bg-overlay);
  border: 1px solid var(--border-default);
  border-radius: 12px;
  transition: background 0.2s ease, border-color 0.2s ease;
  background: var(--bg-active);
  border-color: var(--accent-muted, rgba(94, 106, 210, 0.3));
}

.admin-realtime-switch-thumb {
  position: absolute;
  top: 50%;
  left: 2px;
  width: 18px;
  height: 18px;
  background: var(--text-tertiary);
  border-radius: 50%;
  transition: transform 0.2s ease, background 0.2s ease;
  transform: translate(0, -50%);
}

.admin-realtime-switch-input:checked+.admin-realtime-switch-track .admin-realtime-switch-thumb {
  transform: translate(20px, -50%);
  background: var(--accent, #5e6ad2);
}

.admin-realtime-switch-input:focus-visible+.admin-realtime-switch-track {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.admin-realtime-switch-input:checked+.admin-realtime-switch-track {
  background: var(--bg-active);
  border-color: var(--accent-muted, rgba(94, 106, 210, 0.3));
}

.admin-realtime-switch-text {
  font-size: var(--text-sm);
  color: var(--text-primary);
  font-weight: 500;
  min-width: 5em;
}

.admin-realtime-interval-wrap {
  display: none;
  align-items: center;
  gap: var(--space-3);
}

.admin-realtime-interval-input-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.admin-realtime-interval-input-wrap .profile-input {
  width: 72px;
}

.admin-realtime-interval-hint {
  color: var(--text-tertiary);
  font-size: var(--text-xs);
}

.admin-realtime-hint {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin: 0 0 var(--space-4);
  line-height: 1.45;
}

.admin-realtime-server-note {
  margin-top: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--bg-muted, rgba(255, 255, 255, 0.04));
  border-radius: var(--radius-sm);
  border-left: 2px solid var(--accent-muted, rgba(94, 106, 210, 0.4));
}

.admin-realtime-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.admin-realtime-msg {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.btn-danger {
  color: var(--text-primary);
  background: var(--danger, #dc2626);
  border: 1px solid var(--danger, #dc2626);
}

.btn-danger:hover {
  color: var(--text-primary);
  background: var(--danger-muted, #dc2626);
  border: 1px solid var(--danger-muted, #dc2626);
}

.org-edit-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}

.org-edit-wrap input {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  min-width: 200px;
}

.org-edit-actions {
  display: flex;
  gap: var(--space-2);
}

.org-users-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-content: flex-start;
  justify-content: flex-start;
  align-items: flex-start;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.org-user-row {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  font-size: 0.875rem;
  justify-content: space-between;
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
  max-width: 100%;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.org-users-list .org-user-row:hover {
  background: var(--bg-hover);
}

.org-user-avatar {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--bg-muted, rgba(255, 255, 255, 0.08));
  color: var(--text-secondary);
  font-size: var(--text-xs);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.02em;
}

.org-user-info {
  min-width: 0;
  display: grid;
  grid-template-columns: 150px 200px 1fr;
  gap: var(--space-6);
  align-items: center;
  justify-content: flex-start;
  width: 100%;
}

.org-user-name {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text-primary);
  max-width: 200px;
  width: 100%;
}

.org-user-email {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.org-user-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-direction: row;
  max-width: 100%;
  width: 100%;
  justify-content: flex-end;
}

.org-user-lead-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 500;
}

.org-user-lead-badge--yes {
  background: var(--accent-muted, rgba(59, 130, 246, 0.15));
  color: var(--accent);
  white-space: nowrap;
  max-width: 250px;
  width: fit-content;
  overflow: hidden;
  text-overflow: ellipsis;
}

.org-user-lead-badge--no {
  background: var(--bg-muted, rgba(255, 255, 255, 0.06));
  color: var(--text-tertiary);
}

.org-user-role-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 500;
}

.org-user-role-badge--admin {
  background: var(--accent-muted, rgba(59, 130, 246, 0.15));
  color: var(--accent);
  margin-right: auto;
  color: var(--warning, #d97706);
  background: rgba(245, 158, 11, 0.15);
}

.org-user-role-badge--lead {
  background: rgba(94, 106, 210, 0.22);
  color: #c4c9f5;
  border: 1px solid rgba(94, 106, 210, 0.35);
}

.org-user-actions {
  display: flex;
  gap: var(--space-1);
  flex-shrink: 0;
  margin-top: 2px;
}

.org-user-edit-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) 0;
}

.org-user-edit-form input {
  padding: var(--space-2) var(--space-3);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  min-width: 120px;
  background: var(--bg-overlay, #1e293b);
  color: var(--text-primary);
}

.org-user-edit-form input::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.org-user-edit-save {
  margin-left: auto;
}

.org-create-form,
.org-add-user-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.org-create-form input[type="text"],
.org-create-form input[type="email"],
.org-create-form input[type="password"],
.org-add-user-form input,
.org-invite-email-inp,
.org-edit-org-name,
.org-user-email-inp,
.org-user-password-inp,
.org-user-name-inp {
  padding: var(--space-2) var(--space-3);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  background: var(--bg-overlay, #1e293b);
  color: var(--text-primary);
}

.org-create-form input::placeholder,
.org-add-user-form input::placeholder,
.org-invite-email-inp::placeholder,
.org-edit-org-name::placeholder,
.org-user-email-inp::placeholder,
.org-user-password-inp::placeholder,
.org-user-name-inp::placeholder {
  color: var(--text-placeholder, #94a3b8);
}

.org-add-user-toggle {
  margin-top: var(--space-4);
}

.org-empty {
  color: var(--text-tertiary);
  font-size: 0.875rem;
  padding: var(--space-4);
  text-align: center;
}

.org-error {
  color: var(--danger, #dc2626);
  font-size: 0.875rem;
  margin-top: var(--space-2);
}

.org-error[hidden] {
  display: none !important;
}

/* Projects page */
.projects-page {
  max-width: 720px;
  margin: auto;
  padding: var(--space-6);
}

.projects-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

/* Show archived: pill + purple checkbox + muted gold label (reference UI) */
.projects-show-archived-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-base);
  border: 1px solid var(--show-archived-border);
  border-radius: 10px;
  cursor: pointer;
  user-select: none;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.projects-show-archived-label:hover {
  border-color: #3a3a3a;
  background: rgba(255, 255, 255, 0.02);
}

.projects-show-archived-label:focus-within {
  outline: none;
  box-shadow: 0 0 0 2px var(--bg-base), 0 0 0 4px rgba(91, 95, 199, 0.45);
}

.projects-show-archived,
.org-bulk-select-all-cb,
.org-user-select-cb {
  --show-archived-checkbox-on: #5b5fc7;
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  margin: 0;
  border: 1px solid #3d3d3d;
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.projects-show-archived:hover,
.org-bulk-select-all-cb:hover,
.org-user-select-cb:hover {
  border-color: #505050;
}

.projects-show-archived:checked,
.org-bulk-select-all-cb:checked,
.org-user-select-cb:checked {
  background-color: var(--show-archived-checkbox-on);
  border-color: var(--show-archived-checkbox-on);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23ffffff' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3.5 8.2l2.8 2.8L12.5 4.8'/%3E%3C/svg%3E");
  background-size: 11px 11px;
  background-position: center;
  background-repeat: no-repeat;
}

.projects-show-archived:focus,
.org-bulk-select-all-cb:focus,
.org-user-select-cb:focus {
  outline: none;
}

.org-user-select-cell:focus-within {
  outline: none;
  border-radius: 6px;
  box-shadow: 0 0 0 2px var(--bg-base), 0 0 0 4px rgba(91, 95, 199, 0.35);
}

.projects-show-archived-text,
.org-members-bulk-select-all-text {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
}

.project-create-card .project-create-form .input-wrapper {
  max-width: 100%;
  width: 100%;
}

.project-create-card .project-create-form .input-wrapper input {
  max-width: 100%;
  width: 100%;
}

.project-create-title,
.project-edit-title {
  font-size: 1.125rem;
  margin: 0 0 var(--space-3);
  color: var(--text-primary);
}

.project-create-form,
.project-edit-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.project-input {
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: var(--bg-base);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  font-family: inherit;
  width: 100%;
}

.project-input:focus {
  outline: none;
}

/* Custom file input for project logo — one clickable area: placeholder or preview */
.project-file-wrap {
  position: relative;
  width: 100%;
}

.project-file-input {
  position: absolute;
  width: 0.1px;
  height: 0.1px;
  opacity: 0;
  overflow: hidden;
  z-index: -1;
}

.project-file-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 80px;
  width: 100%;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  border: var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--bg-base);
  cursor: pointer;
  font-family: inherit;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  max-width: fit-content;
  min-width: 100px;
  height: 100px;
  padding: var(--space-2);
}

.project-file-trigger:hover {
  background: var(--bg-hover, rgba(255, 255, 255, 0.06));
  border-color: var(--accent-muted, rgba(59, 130, 246, 0.5));
  color: var(--text-primary);
}

.project-file-trigger:focus {
  outline: none;
  border-color: var(--accent-muted, rgba(59, 130, 246, 0.6));
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
}

/* Placeholder state: icon + "Choose file" + filename */
.project-file-placeholder {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 1;
  min-width: 0;
  flex-direction: column;
  border-radius: var(--radius-sm);
  justify-content: center;
}

.project-file-preview.is-visible~.project-file-placeholder {
  display: none;
}

.project-file-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-tertiary);
}

.project-file-icon svg {
  width: 18px;
  height: 18px;
}

.project-file-trigger:hover .project-file-icon {
  color: var(--accent, #3b82f6);
}

.project-file-text {
  flex-shrink: 0;
}

.project-file-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-primary);
  font-weight: 500;
}

.project-file-name:empty::before {
  content: 'No file chosen';
  color: var(--text-tertiary);
  font-weight: 400;
}

/* Preview state: show image when selected */
.project-file-preview {
  display: none;
  width: auto;
  height: 100%;
  border-radius: var(--radius-sm);
  overflow: hidden;
  flex-shrink: 0;
}

.project-file-preview.is-visible {
  display: block;
}

.project-file-preview-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.projects-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-4);
}

.project-card {
  padding: 0;
  overflow: hidden;
}

.project-card-inner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
}

.project-card-logo-wrap {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  align-items: center;
}

.project-card-logo-wrap .project-card-logo {
  height: 100%;
  width: auto;
}

.project-card-logo {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}

.project-card-logo-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-hover);
  color: var(--text-tertiary);
}

.project-card-logo-placeholder svg {
  width: 24px;
  height: 24px;
}

.project-card-body {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.project-card-name-wrap {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.project-card-name {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-card-lead {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.project-card-archived-badge {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  background: var(--bg-muted, rgba(255, 255, 255, 0.06));
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}

.project-card--archived .project-card-name {
  opacity: 0.85;
}

.project-card-actions {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.project-edit-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

.project-edit-overlay[hidden] {
  display: none;
}

.project-edit-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}

.project-edit-modal {
  position: relative;
  min-width: 320px;
  max-width: 420px;
  padding: var(--space-4);
  border: var(--border-default);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
}


.project-edit-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  justify-content: flex-end;
}

/* Required "create or join organization" modal — dashboard when user has no org */
.app-no-org .sidebar,
.app-no-org .main {
  pointer-events: none;
  user-select: none;
  opacity: 0.7;
}

.org-required-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

.org-required-backdrop {
  position: absolute;
  inset: 0;
  background: var(--bg-overlay, rgba(0, 0, 0, 0.6));
}

.org-required-modal {
  position: relative;
  max-width: 480px;
  width: 100%;
  padding: var(--space-6);
}

.org-required-title {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 var(--space-2);
}

.org-required-desc {
  color: var(--text-secondary);
  font-size: 0.875rem;
  margin: 0 0 var(--space-4);
}

.org-required-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.org-required-subtitle {
  font-size: 0.9375rem;
  font-weight: 600;
  margin: 0 0 var(--space-2);
}

.org-required-desc-sm {
  color: var(--text-tertiary);
  font-size: 0.8125rem;
  margin: 0 0 var(--space-2);
}

.org-required-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.org-required-form .login-error {
  margin: 0;
}

/* Confirm modal (delete issue) */
.confirm-modal {
  position: fixed;
  inset: 0;
  z-index: 10001;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  box-sizing: border-box;
}

.confirm-modal[hidden] {
  display: none !important;
  pointer-events: none;
  visibility: hidden;
}

.confirm-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer;
}

.confirm-modal-panel {
  position: relative;
  max-width: 400px;
  width: 100%;
  padding: var(--space-6);
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
}

.confirm-modal-title {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 var(--space-2);
  color: var(--text-primary);
}

.confirm-modal-message {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin: 0 0 var(--space-4);
  line-height: 1.5;
}

.confirm-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
}

/* Shortcuts help modal */
.shortcuts-help-modal {
  position: fixed;
  inset: 0;
  z-index: 10002;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  box-sizing: border-box;
}

.shortcuts-help-modal[hidden] {
  display: none !important;
  pointer-events: none;
  visibility: hidden;
}

.shortcuts-help-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer;
}

.shortcuts-help-panel {
  position: relative;
  max-width: 520px;
  width: 100%;
  max-height: 85vh;
  overflow: auto;
  padding: var(--space-6);
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
}

.shortcuts-help-title {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 var(--space-4);
  color: var(--text-primary);
}

.shortcuts-help-content {
  margin-bottom: var(--space-4);
}

.shortcuts-help-note {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin: 0 0 var(--space-3);
}

.shortcuts-help-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.shortcuts-help-table th,
.shortcuts-help-table td {
  text-align: left;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: top;
}

.shortcuts-help-table th {
  font-weight: 600;
  color: var(--text-secondary);
}

.shortcuts-help-table kbd {
  display: inline-block;
  padding: 2px 6px;
  font-family: inherit;
  font-size: 0.8em;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.shortcuts-help-context {
  font-size: 0.8125rem;
  color: var(--text-secondary);
  margin: var(--space-3) 0 0;
}

.shortcuts-help-close {
  margin-top: var(--space-2);
}

/* Command palette (⌘K) */
.command-palette {
  position: fixed;
  inset: 0;
  z-index: 10002;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 15vh 16px 16px;
  box-sizing: border-box;
}

.command-palette[hidden] {
  display: none !important;
  pointer-events: none;
  visibility: hidden;
}

.command-palette-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer;
}

.command-palette-panel {
  position: relative;
  width: 100%;
  max-width: 560px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.4);
  overflow: hidden;
}

.command-palette-search-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3);
  border-bottom: 1px solid var(--border-subtle);
}

.command-palette-search-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  color: var(--text-tertiary);
}

.command-palette-input {
  flex: 1;
  min-width: 0;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-primary);
  font-size: 0.9375rem;
  font-family: inherit;
  outline: none;
}

.command-palette-input::placeholder {
  color: var(--text-placeholder);
}

.command-palette-list {
  max-height: 320px;
  overflow-y: auto;
  padding: var(--space-1);
}

.command-palette-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--text-primary);
  font-size: 0.875rem;
  border: none;
  width: 100%;
  text-align: left;
  background: transparent;
  font-family: inherit;
}

.command-palette-item:hover,
.command-palette-item.selected {
  background: var(--bg-overlay);
}

.command-palette-item .command-palette-item-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  color: var(--text-tertiary);
}

.command-palette-item .command-palette-item-meta {
  color: var(--text-tertiary);
  font-size: 0.8125rem;
  margin-left: auto;
}

.command-palette-item .command-palette-item-id {
  flex-shrink: 0;
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
}

.command-palette-section-label {
  padding: var(--space-2) var(--space-3);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-tertiary);
}

/* Cycles (sprints) page */
.cycle-wrappre {
  padding: var(--space-6);
}

.cycles-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: flex-start;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 15px;
}

.cycle-card {
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
}

.cycle-card:hover {
  background: var(--bg-overlay);
}

.cycle-card-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-1);
  align-items: flex-start;
  justify-content: space-between;
}

.cycle-card-name {
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary);
}

.cycle-card-dates {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
}

.cycle-card-placeholder {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
}

.cycle-create-card {
  padding: var(--space-6);
  max-width: 480px;
}

.cycle-create-title {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 var(--space-4);
  color: var(--text-primary);
}

.cycle-dates-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.cycle-create-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

.cycle-progress {
  padding: var(--space-4);
}

.cycle-progress-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-2);
}

.cycle-progress-label {
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--text-primary);
}

.cycle-progress-count {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
}

.cycle-progress-bar-wrap {
  height: 8px;
  background: var(--bg-overlay);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: var(--space-2);
}

.cycle-progress-bar {
  height: 100%;
  background: var(--accent-primary);
  border-radius: 4px;
  transition: width 0.2s;
}

.cycle-progress-dates {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
}

.cycle-issues-list {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.cycle-issues-list .cycle-issues-header {
  margin-bottom: var(--space-2);
  width: 100%;
}

.cycle-issue-row {
  display: grid;
  grid-template-columns: 28px 72px 1fr 100px 90px 80px;
  padding: var(--space-2) var(--space-4);
  align-items: center;
  border-bottom: 1px solid var(--border-subtle);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
}

.cycle-issue-row .title {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Roadmap */
.view-header-roadmap .view-subtitle {
  color: var(--text-secondary);
  font-size: var(--text-sm);
  margin: 0;
}

.roadmap-actions {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
}

.roadmap-actions-menu-btn {
  display: none;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 500;
  font-family: var(--font-sans);
  color: #fff;
  background: linear-gradient(180deg, #6b7ae8 0%, var(--accent, #5e6ad2) 100%);
  border: none;
  border-radius: var(--radius-md);
  box-shadow: 0 2px 8px rgba(94, 106, 210, 0.35);
  cursor: pointer;
  transition: box-shadow 0.2s ease;
}

.roadmap-actions-menu-btn:hover {
  color: #fff;
  background: linear-gradient(180deg, #7a88eb 0%, #6b7ae8 100%);
  box-shadow: 0 4px 12px rgba(94, 106, 210, 0.4);
}

.roadmap-actions-menu-btn:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.8);
  outline-offset: 2px;
}

.roadmap-actions-menu-btn svg {
  width: 16px;
  height: 16px;
  color: #fff;
  flex-shrink: 0;
}

.roadmap-actions-panel {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
}

.roadmap-view-toggle {
  display: flex;
  gap: var(--space-1);
}

.roadmap-view-toggle .roadmap-tab.active {
  background: var(--bg-active);
  color: var(--text-primary);
}

.roadmap-filter-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.roadmap-filter-label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.roadmap-status-dropdown {
  position: relative;
}

.roadmap-status-trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  background: var(--bg-raised);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  cursor: pointer;
  font-family: inherit;
  min-width: 120px;
  transition: border-color 0.12s, background 0.12s;
}

.roadmap-status-trigger:hover {
  background: var(--bg-hover);
  border-color: rgba(255, 255, 255, 0.14);
}

.roadmap-status-trigger svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  opacity: 0.9;
}

.roadmap-status-trigger .roadmap-status-trigger-chevron {
  margin-left: auto;
  opacity: 0.7;
}

.roadmap-status-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  min-width: 180px;
  max-height: 320px;
  overflow-y: auto;
  padding: var(--space-2);
  background: var(--bg-overlay);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  z-index: 50;
}

.roadmap-status-menu[hidden] {
  display: none !important;
}

.roadmap-status-option {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background 0.1s, color 0.1s;
}

.roadmap-status-option:hover,
.roadmap-status-option.is-selected {
  color: #fff;
  background: rgba(59, 130, 246, 0.35);
}

.roadmap-status-option.is-selected:hover {
  background: rgba(59, 130, 246, 0.45);
}

.roadmap-status-option svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.roadmap-status-option[data-value="backlog"] svg {
  color: #94a3b8;
}

.roadmap-status-option[data-value="todo"] svg {
  color: #818cf8;
}

.roadmap-status-option[data-value="in-progress"] svg {
  color: #6366f1;
}

.roadmap-status-option[data-value="done"] svg {
  color: #22c55e;
}

.roadmap-status-select {
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-md);
  color: var(--text-primary);
}

/* New milestone form: Project dropdown (same look as Status dropdown) */
.roadmap-milestone-form .roadmap-project-dropdown {
  width: 100%;
}

.roadmap-milestone-form .roadmap-project-trigger {
  width: 100%;
  min-width: 0;
  justify-content: flex-start;
}

.roadmap-project-option svg {
  color: var(--text-tertiary);
  flex-shrink: 0;
}

.roadmap-project-option.is-selected svg {
  color: rgba(255, 255, 255, 0.95);
}

.roadmap-loading {
  padding: var(--space-6);
  text-align: center;
  color: var(--text-tertiary);
}

.roadmap-list-view {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.roadmap-project-card {
  padding: var(--space-6);
}

.roadmap-project-title {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 var(--space-4);
  color: var(--text-primary);
}

.roadmap-section-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-secondary);
  margin: 0 0 var(--space-2);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.roadmap-milestones-section,
.roadmap-issues-section {
  margin-bottom: var(--space-4);
}

.roadmap-milestones-section:last-child,
.roadmap-issues-section:last-child {
  margin-bottom: 0;
}

.roadmap-milestones-list,
.roadmap-issues-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.roadmap-milestone-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--bg-overlay);
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
}

.roadmap-milestone-name {
  color: var(--text-primary);
}

.roadmap-milestone-date {
  color: var(--text-tertiary);
  font-size: var(--text-xs);
}

.roadmap-milestone-no-date {
  font-style: italic;
}

.roadmap-issue-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: var(--text-sm);
}

.roadmap-issue-item:last-child {
  border-bottom: none;
}

.roadmap-issue-link {
  color: var(--accent-primary);
  text-decoration: none;
}

.roadmap-issue-link:hover {
  text-decoration: underline;
}

.roadmap-issue-meta {
  display: flex;
  gap: var(--space-3);
  color: var(--text-tertiary);
  font-size: var(--text-xs);
}

.roadmap-no-data {
  color: var(--text-tertiary);
  padding: var(--space-6);
}

.roadmap-timeline-wrap {
  overflow-x: auto;
  padding-bottom: var(--space-4);
}

.roadmap-timeline-header {
  display: grid;
  grid-template-columns: 160px repeat(8, 1fr);
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: var(--border-default);
  min-width: min-content;
}

.roadmap-timeline-corner {
  min-width: 140px;
}

.roadmap-timeline-month {
  min-width: 72px;
  text-align: center;
}

.roadmap-timeline-row {
  display: grid;
  grid-template-columns: 160px repeat(8, 1fr);
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  align-items: center;
  border-bottom: var(--border-subtle);
  min-width: min-content;
}

.roadmap-timeline-row-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  min-width: 140px;
}

.roadmap-timeline-cells {
  display: contents;
}

.roadmap-timeline-cell {
  min-width: 72px;
  min-height: 36px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
}

.roadmap-timeline-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  color: var(--text-primary);
  background: var(--bg-overlay);
  text-decoration: none;
  transition: background 0.15s;
}

.roadmap-timeline-dot:hover {
  background: var(--bg-hover);
}

.roadmap-dot-milestone {
  color: var(--accent-primary);
}

.roadmap-dot-issue {
  color: var(--text-secondary);
}

.roadmap-milestone-form-wrap {
  padding: var(--space-6);
}

.roadmap-milestone-form-title {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 var(--space-4);
  color: var(--text-primary);
}

.roadmap-milestone-form-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

/* ========== Mobile responsive (full app) ========== */
/* Sidebar close button: visible only on mobile */
.sidebar-close-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  padding: 0;
  margin-right: var(--space-2);
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  cursor: pointer;
}

.sidebar-close-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.sidebar-close-btn svg {
  width: 20px;
  height: 20px;
}

/* Overlay: hidden on desktop */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

/* Hamburger: hidden on desktop */
.topbar-menu-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  cursor: pointer;
}

.topbar-menu-btn:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.topbar-menu-btn svg {
  width: 22px;
  height: 22px;
}

/* Issues view header: hamburger menu button (shown only at 1440px) */
.view-actions-menu-btn {
  display: none;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  background: var(--bg-overlay);
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
}

.view-actions-menu-btn:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.view-actions-menu-btn svg {
  width: 14px;
  height: 14px;
}


issue-attributes-mobile-wrap {
  max-width: 200px;
  width: 100%;
}

.issue-attributes-popup {
  max-width: 100%;
  width: 100%;
}

/* Issues view header (index.php): responsive from 1536px and below */
@media (max-width: 1536px) {
  #issues-list .list-row {
    margin-left: 0;
  }

  .issues-group-list {
    align-items: flex-start;
  }

  .list-row-recurring-badge,
  .recurring {
    display: none !important;
  }
}

/* Issues view header (index.php): responsive from 1440px and below */
@media (max-width: 1440px) {
  .view-header-issues {
    padding: var(--space-3);
    flex-direction: row;
    gap: var(--space-3);
    height: auto;
  }

  .view-header-issues .view-title {
    flex: 0 0 auto;
    margin: 0;
  }

  .view-header-issues .view-actions {
    position: relative;
    gap: 0;
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
    justify-content: flex-end;
  }

  .view-header-issues .view-actions-menu-btn {
    display: inline-flex;
    flex-shrink: 0;
  }

  .view-header-issues .view-actions-panel {
    display: none;
    position: absolute;
    top: calc(100% + var(--space-2));
    right: 0;
    min-width: 280px;
    max-width: min(400px, calc(100vw - var(--space-6)));
    max-height: min(85vh, 520px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-4);
    background: var(--bg-raised);
    border: var(--border-default);
    border-radius: var(--radius-md);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
    z-index: 200;
  }

  .view-header-issues .view-actions.is-open .view-actions-panel {
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: space-between;
    overflow: visible;
  }

  .view-header-issues .view-actions.is-open .view-actions-menu-btn {
    background: var(--bg-hover);
    color: var(--text-primary);
  }

  .view-header-issues .view-actions-panel .filter-wrap,
  .view-header-issues .view-actions-panel>.btn,
  .view-header-issues .view-actions-panel>a.btn {
    flex: 1;
    display: flex;
    max-width: 100%;
    width: 100%;
    flex-direction: column;
  }

  .view-header-issues .view-actions-panel .filter-wrap>*:not(svg),
  .view-header-issues .view-actions-panel>.btn>*:not(svg),
  .view-header-issues .view-actions-panel>a.btn>*:not(svg) {
    flex: 1;
    max-width: 100%;
    width: 100%;
    position: unset;
  }

  .view-header-issues .view-actions-panel .filter-wrap>.issues-filter-dropdown {
    position: absolute;
  }

  .view-header-issues .view-actions-panel #issues-export-csv {
    background: transparent;
    border: var(--border-subtle);
    border-radius: var(--radius-sm);
    flex: 1;
    flex-direction: row;
  }

  .view-header-issues .view-actions-panel .issues-filter-dropdown,
  .view-header-issues .view-actions-panel #issues-view-dropdown {
    position: static;
    margin-top: var(--space-2);
    max-height: none;
    box-shadow: none;
    border: var(--border-subtle);
  }

  .view-header-issues .issues-filter-dropdown {
    left: 0;
    right: auto;
    max-width: min(320px, calc(100vw - var(--space-6)));
    max-height: min(80vh, 400px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .view-header-issues #issues-view-dropdown {
    max-height: min(70vh, 280px);
    overflow-y: auto;
  }

  .view-header-issues~.content #issues-panel,
  #issues-panel {
    padding: var(--space-4);
  }

  /* Issues group list: responsive from 1440px */
  .issues-group-list {
    width: 100%;
    min-width: 0;
  }

  .issues-groups-container {
    -webkit-overflow-scrolling: touch;
  }

  .issues-list-header {
    font-size: var(--text-xs);
    padding: var(--space-2) var(--space-3);
  }

  #issues-list .list-row {
    padding: var(--space-2) var(--space-3);
  }

  #issues-list .list-row .due-col,
  .due,
  .list-row .status-dot,
  .inbox-list-header span:nth-child(1),
  .inbox-list-header span:nth-child(5),
  .list-row .status {
    display: none;
  }

  .list-row .priority,
  .priority {
    justify-content: flex-end;
  }

  .org-user-meta {
    position: absolute;
    right: -100%;
    top: 0;
    max-width: fit-content;
    width: 100%;
    height: 100%;
    padding: var(--space-2) var(--space-4);
    border-left: 1px solid var(--show-archived-border);
    border-radius: 10px;
    background: var(--bg-raised);
    transition: right 0.25s ease;
  }

  .org-user-row:hover .org-user-meta {
    right: 0;
  }
}

/* Issues list + sidebar: proper responsive from 1280px (e.g. 1349px) */
@media (max-width: 1280px) {

  /* Sidebar as drawer so main content gets full width */
  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 1000;
    width: min(280px, 85vw);
    min-width: 0;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.3);
  }

  .app.sidebar-open .sidebar {
    transform: translateX(0);
  }

  .sidebar-close-btn {
    display: flex;
  }

  .sidebar-overlay {
    display: block;
  }

  .app.sidebar-open .sidebar-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .topbar-menu-btn {
    display: flex;
    flex-shrink: 0;
  }

  .main {
    min-width: 0;
  }

  /* Tighter issues grid: hide Recurring column, smaller fixed columns */
  .issues-list-header>span:nth-child(7) {
    display: none !important;
  }

  #issues-list .list-row {
    padding: var(--space-2) var(--space-3);
  }

  .issues-group-header>span:nth-child(7) {
    display: none !important;
  }
}

@media (max-width: 1024px) {

  .mywork-dashboard,
  .reports-dashboard,
  .dashboard-widgets {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {

  .list-row .priority,
  .priority,
  .inbox-list-header span:nth-child(6) {
    display: none;
  }

  .issue-attr-menu {
    left: unset;
    right: 0;
  }

  .list-row {
    gap: var(--space-4);
  }
}

@media (max-width: 820px) {

  .list-row-status-wrap,
  .status {
    display: none;
  }
}

@media (max-width: 768px) {
  /* Issue attributes: show as popup on mobile */
  .issue-attributes-mobile-trigger {
    display: flex;
  }

  .issue-attributes-mobile-wrap .issue-attributes-popup {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1100;
    height: 90%;
    background: var(--bg-base);
    border-top-left-radius: var(--radius-lg);
    border-top-right-radius: var(--radius-lg);
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.25);
    transform: translateY(100%);
    transition: transform 0.25s ease;
    overflow: auto;
    padding: 0;
    margin: 0;
    top: auto;
    width: 100%;
    max-width: none;
    border-radius: var(--radius-sm);
    border: var(--border-subtle);
  }

  .issue-attributes-mobile-wrap .issue-attributes-popup.issue-attributes-popup-open {
    transform: translateY(0);
  }

  .issue-attributes-popup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border-subtle);
    flex-shrink: 0;
  }

  .issue-attributes-popup-title {
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
  }

  .issue-attributes-popup-close {
    font-size: var(--text-sm);
  }

  .issue-attributes-mobile-wrap .issue-attributes-popup .issue-attributes {
    align-items: stretch;
    max-width: none;
    position: static;
    padding: var(--space-4);
    margin: 0;
    flex-wrap: wrap;
    height: calc(100% - 55px);
    align-content: flex-start;
  }

  .issue-attributes-mobile-wrap .issue-attributes-popup .issue-attr-dropdown {
    width: 100%;
    flex: 1 1 33%;
    max-width: calc(100% / 3 - 6px);
  }

  .issue-attributes-mobile-wrap .issue-attributes-popup .issue-attr-btn {
    width: 100%;
    justify-content: flex-start;
  }

  .issue-attributes-mobile-wrap .issue-attributes-popup .issue-attr-btn #assignee-label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .issue-attributes-popup-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1099;
  }

  .issue-attributes-popup-backdrop:not([hidden]) {
    display: block;
  }

  /* Sub-issue attrs: popup on mobile */
  .issue-subissue-attrs-mobile-trigger {
    display: flex;
  }

  .issue-subissue-attrs-mobile-wrap .issue-subissue-attrs-popup {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1100;
    background: var(--bg-base);
    border-top-left-radius: var(--radius-lg);
    border-top-right-radius: var(--radius-lg);
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.25);
    transform: translateY(100%);
    transition: transform 0.25s ease;
    overflow: auto;
    padding: 0;
    margin: 0;
    top: auto;
    width: 100%;
    max-width: none;
    height: 90%;
    border-radius: var(--radius-sm);
    border: var(--border-subtle);
  }

  .issue-subissue-attrs-mobile-wrap .issue-subissue-attrs-popup.issue-attributes-popup-open {
    transform: translateY(0);
  }

  .issue-subissue-attrs-popup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border-subtle);
    flex-shrink: 0;
  }

  .issue-subissue-attrs-popup-title {
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
  }

  .issue-subissue-attrs-popup-close {
    font-size: var(--text-sm);
  }

  .issue-subissue-attrs-mobile-wrap .issue-subissue-attrs-popup .issue-subissue-attrs {
    align-items: stretch;
    max-width: none;
    padding: var(--space-4);
    margin: 0;
    justify-content: flex-end;
  }

  .issue-subissue-attrs-mobile-wrap .issue-subissue-attrs-popup .issue-attr-dropdown {
    width: 100%;
    flex: 1 1 33%;
    max-width: calc(100% / 3 - 6px);
  }

  .issue-subissue-attrs-mobile-wrap .issue-subissue-attrs-popup .issue-attr-btn {
    width: 100%;
    justify-content: flex-start;
  }

  .issue-subissue-attrs-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1099;
  }

  .issue-subissue-attrs-backdrop:not([hidden]) {
    display: block;
  }

  /* Sidebar: drawer overlay on mobile */
  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 1000;
    width: min(280px, 85vw);
    min-width: 0;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.3);
  }

  .app.sidebar-open .sidebar {
    transform: translateX(0);
  }

  .sidebar-close-btn {
    display: flex;
  }

  .sidebar-header {
    display: flex;
    align-items: center;
  }

  .sidebar-overlay {
    display: block;
  }

  .app.sidebar-open .sidebar-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .topbar-menu-btn {
    display: flex;
    flex-shrink: 0;
  }

  .topbar {
    padding: 0 var(--space-3);
    gap: var(--space-2);
    flex-wrap: wrap;
    min-height: var(--topbar-height);
    height: auto;
  }

  .org-main-card {
    padding: var(--space-6) 0;
  }

  .topbar-breadcrumb {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .topbar-search {
    order: 3;
    flex: 1 1 100%;
    max-width: none;
    min-height: 40px;
  }

  .topbar-meta .kbd-shortcut {
    display: none;
  }

  .topbar-notifications-dropdown {
    left: var(--space-2);
    right: var(--space-2);
    max-width: none;
    width: calc(100vw - var(--space-4));
  }

  .main {
    min-width: 0;
  }

  .view-header {
    padding: var(--space-3) var(--space-3) var(--space-3);
    flex-wrap: wrap;
    gap: var(--space-3);
    min-height: 0;
    height: auto;
  }

  .view-title {
    font-size: var(--text-base);
  }

  .view-actions {
    flex-wrap: wrap;
    margin-left: 0;
    gap: var(--space-2);
  }

  /* Roadmap: wrap actions in hamburger menu with settings icon */
  .roadmap-actions {
    position: relative;
    gap: 0;
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-end;
    margin-left: auto;
  }

  .roadmap-actions-menu-btn {
    display: inline-flex;
    flex-shrink: 0;
    min-width: 44px;
    min-height: 44px;
    padding: var(--space-2);
  }

  .roadmap-actions-menu-btn .roadmap-actions-menu-label {
    display: none;
  }

  .roadmap-actions-panel {
    display: none;
    position: absolute;
    top: calc(100% + var(--space-2));
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
    padding: var(--space-4);
    min-width: 220px;
    max-width: min(320px, calc(100vw - var(--space-6)));
    background: var(--bg-raised);
    border: var(--border-default);
    border-radius: var(--radius-md);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
    z-index: 200;
  }

  .roadmap-actions.is-open .roadmap-actions-panel {
    display: flex;
  }

  .roadmap-actions.is-open .roadmap-actions-menu-btn {
    background: linear-gradient(180deg, #5a68c9 0%, #4d5ab8 100%);
    box-shadow: 0 2px 12px rgba(94, 106, 210, 0.5);
  }

  .roadmap-actions-panel .roadmap-view-toggle {
    width: 100%;
    justify-content: stretch;
  }

  .roadmap-actions-panel .roadmap-view-toggle .roadmap-tab {
    flex: 1;
  }

  .roadmap-actions-panel .roadmap-filter-wrap {
    flex-direction: column;
    align-items: stretch;
  }

  .roadmap-actions-panel .roadmap-status-trigger {
    width: 100%;
  }

  .content {
    padding: var(--space-3);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Issues list: horizontal scroll, show all 11 columns again */
  .issues-list-header {
    font-size: var(--text-xs);
    padding: var(--space-2) var(--space-3);
  }

  #issues-list .list-row {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
  }

  #issues-list .list-row .title,
  .title {
    min-width: 0;
    max-width: 150px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .issues-groups-container {
    min-width: 0;
    overflow: visible;
    -webkit-overflow-scrolling: touch;
  }

  .issues-group-list .list-row {
    min-height: 44px;
    padding: var(--space-2) var(--space-3);
  }

  .issues-list-wrap {
    min-width: 600px;
  }

  /* Issue popup: full screen on mobile */
  .issue-popup-container {
    max-width: none;
    display: flex;
    flex-direction: column;
    max-height: 90vh;
  }

  .issue-popup-content {
    flex: 1;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  .issue-popup-form {
    min-height: unset;
    overflow: unset;
  }

  .issue-popup-form .issue-modal-wrapper {
    flex-direction: column-reverse;
    height: calc(100vh - 214px);
    overflow: auto;
  }

  .issue-modal-header {
    position: unset;
    padding-right: 60px;
  }

  .issue-popup-header .popup-copy-branch .btn {
    min-width: 32px;
    min-height: 32px;
  }

  .issue-modal-form {
    align-content: flex-start;
  }

  .issue-modal-body {
    max-width: 100%;
    width: 100%;
    order: 2;
  }

  .issue-attributes {
    max-width: 100%;
    flex-direction: row;
    padding: var(--space-2) var(--space-4) 0 var(--space-2);
    margin-bottom: 0;
    order: 1;
    height: fit-content;
    position: unset;
    justify-content: flex-end;
  }

  .issue-modal-footer {
    order: 3;
    bottom: -12px;
  }

  .issue-popup-form .issue-modal-body {
    padding: 0 var(--space-4) var(--space-4);
  }

  .issue-attr-dropdown {
    max-width: fit-content;
  }

  .issue-popup-close {
    top: var(--space-4);
    right: var(--space-4);
    min-width: 32px;
    min-height: 32px;
  }

  .issue-attr-btn {
    white-space: nowrap;
  }

  .issue-popup-backdrop {
    display: block;
  }

  .confirm-modal-panel {
    margin: var(--space-4);
    max-width: calc(100% - var(--space-8));
  }

  .command-palette-panel {
    left: var(--space-3);
    right: var(--space-3);
    width: auto;
    max-width: none;
  }

  .notif-toast-wrap .notif-toast {
    left: var(--space-3);
    right: var(--space-3);
    width: auto;
    max-width: none;
  }

  .org-required-modal {
    margin: var(--space-4);
    max-width: calc(100% - var(--space-8));
  }

  /* Touch-friendly minimum sizes */
  .btn {
    padding: var(--space-2) var(--space-3);
  }

  .btn.btn-icon {
    min-width: 40px;
    min-height: 40px;
  }

  .sidebar-item {
    min-height: 44px;
    padding: var(--space-2) var(--space-3);
  }

  /* My work / Reports grids */
  .mywork-dashboard,
  .reports-dashboard,
  .dashboard-widgets {
    grid-template-columns: 1fr;
    padding: 0;
  }

  .mywork-row,
  .dashboard-widget-row {
    grid-template-columns: auto 1fr auto;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
  }

  .mywork-row>*:nth-child(n+4),
  .dashboard-widget-row>*:nth-child(n+4) {
    display: none !important;
  }

  .mywork-row .title,
  .dashboard-widget-row .title {
    grid-column: 2;
  }

  .view-header-reports,
  .view-header-mywork {
    padding: var(--space-3) 0;
    flex-wrap: wrap;
  }
  
  .org-user-info {
    display: flex;
    gap: 0;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: column;
  }

  .org-user-avatar {
    display: none;
  }

  .org-user-row {
    gap: var(--space-2);
  }

  .org-user-actions {
    gap: 0;
}

  .org-user-actions .btn {
    min-width: 30px;
    min-height: 30px;
    padding: var(--space-1) var(--space-1);
  }

  .view-header-actions-reports {
    margin-left: 0;
  }

  .reports-section.reports-card,
  .mywork-section.reports-section.reports-card {
    min-width: 0;
  }

  .form-panel {
    padding: var(--space-4);
    max-width: none;
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .profile-page,
  .profile-section.panel,
  .settings-list.panel {
    padding: var(--space-4);
  }

  .login-wrap {
    max-width: none;
    margin: 0 var(--space-4);
  }

  .login-card {
    padding: var(--space-4);
  }

  .list-row,
  .issues-group-header {
    gap: var(--space-4);
  }

  .issues-group-title,
  .list-row .id {
    max-width: 90px;
    width: 100%;
  }

  .issues-group-count-badge,
  .list-row .status-dot {
    display: none;
  }

  .view-header-reports .view-header-text,
  .view-header-dashboard .view-header-text {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
  }

  .view-header-actions-dashboard {
    margin-left: 0;
  }

  .inbox-panel,
  #issues-panel,
  .projects-page,
  .roadmap-project-card,
  .cycle-wrappre,
  .settings-page,
  .org-page,
  .audit-log-panel,
  .profile-page {
    padding: 0 !important;
  }

  .audit-log-panel {
    padding-top: var(--space-2) !important;
  }

  .inbox-quick-actions {
    max-width: 100%;
    width: 100%;
  }

  .inbox-quick-dropdown,
  .inbox-quick-actions .btn {
    display: flex;
    flex: 1;
  }

  .issue-subissue-row {
    gap: 0;
    flex-direction: column-reverse;
    align-items: flex-end;
  }

  .issue-popup-header .popup-branch-name {
    display: none;
  }

  .org-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: column;
  }

  .org-delete-org-section {
    margin-left: 0;
  }

  .org-card-header-wrapper {
    margin-bottom: 0;
  }

  #org-admin-wrap {
    padding: var(--space-2) 0;
  }
}

@media (max-width: 520px) {
  .profile-detail-row {
    grid-template-columns: 1fr;
  }

  #issues-list .list-row>span:nth-child(6),
  .assignee {
    display: none;
  }

  .issue-popup-header {
    flex-wrap: wrap;
  }

  .issue-popup-overlay {
    padding: var(--space-2);
  }

  .issue-popup-container,
  .issue-popup-content,
  .issue-popup-form {
    max-height: 100vh;
  }

  .issue-modal-footer-right {
    flex-direction: column;
    width: 100%;
    gap: var(--space-2);
  }

  .issue-modal-footer-right .btn {
    max-width: 100%;
    width: 100%;
    justify-content: center;
  }

  .issue-popup-form .issue-modal-footer {
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  .issue-attributes {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    min-height: fit-content;
  }

  .assignee-avatar-sm {
    width: 16px;
    height: 16px;
    min-width: 16px;
    min-height: 16px;
    font-size: 6px;
  }

  .issue-popup-header {
    flex-wrap: wrap;
  }
}

@media (max-width: 480px) {
  .sidebar {
    width: min(260px, 92vw);
  }

  .view-header-issues .view-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .view-header-issues .view-actions>.filter-wrap .btn,
  .view-header-issues .view-actions>.btn,
  .view-header-issues .view-actions>a.btn {
    width: 100%;
  }

  /* Issues list: show only checkbox, ID, title, due (cols 2, 4, 5, 11) */
  .issues-list-header>span:nth-child(1),
  .issues-list-header>span:nth-child(3),
  .issues-list-header>span:nth-child(6),
  .issues-list-header>span:nth-child(7),
  .issues-list-header>span:nth-child(8),
  .issues-list-header>span:nth-child(9),
  .issues-list-header>span:nth-child(10) {
    display: none !important;
  }

  .issues-list-header>span:nth-child(2) {
    grid-column: 1;
  }

  .issues-list-header>span:nth-child(4) {
    grid-column: 2;
  }

  .issues-list-header>span:nth-child(5) {
    grid-column: 3;
  }

  .issues-list-header>span:nth-child(11) {
    grid-column: 4;
    text-align: right;
  }

  #issues-list .list-row {
    grid-template-columns: 24px 50px 1fr 72px;
  }

  #issues-list .list-row>span:nth-child(1),
  #issues-list .list-row>span:nth-child(3),
  #issues-list .list-row>span:nth-child(8),
  #issues-list .list-row>span:nth-child(9),
  #issues-list .list-row>span:nth-child(10),
  .issues-group-toggle {
    display: none !important;
  }

  #issues-list .list-row>span:nth-child(2) {
    grid-column: 1;
  }

  #issues-list .list-row>span:nth-child(4) {
    grid-column: 2;
  }

  #issues-list .list-row>span:nth-child(5) {
    grid-column: 3;
  }

  #issues-list .list-row>span:nth-child(11) {
    grid-column: 4;
  }

  .due-col {
    justify-content: flex-end;
  }

  .issues-group-list {
    min-width: 0;
    width: 100%;
  }

  .issues-group-list .list-row {
    min-height: 44px;
  }

  .list-row,
  .issues-group-header {
    gap: var(--space-2);
  }

  #issues-list .list-row .title,
  .title {
    max-width: 124px;
  }
}

/* Time tracking — popup section */
.popup-time {
  margin: var(--space-4) 0 var(--space-2);
}

.popup-time-summary {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
}

.popup-time-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column-reverse;
}

.popup-time-item {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: var(--text-sm);
  padding: 0 var(--space-3);
  border-radius: var(--radius-sm);
}

.popup-time-item:hover {
  background: var(--bg-overlay);
}

.popup-time-item .btn-icon {
  margin-left: auto;
  background: none;
}

.popup-time-item .btn-icon svg {
  transition: all 0.2s ease;
}

.popup-time-item .btn-icon:hover svg {
  stroke: #FF746C;
}

.popup-time-empty {
  padding: var(--space-3) 0;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  list-style: none;
}

.popup-time-add {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.popup-time-minutes {
  width: 70px;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
}

.popup-time-date {
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
}

.popup-time-desc {
  flex: 1;
  min-width: 120px;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  background: var(--bg-raised);
  border: var(--border-default);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
}

.popup-time-entry-mins {
  font-weight: 500;
  color: var(--text-primary);
}

.popup-time-entry-date {
  color: var(--text-secondary);
}

.popup-time-entry-user {
  color: var(--text-secondary);
}

.popup-time-entry-desc {
  color: var(--text-tertiary);
  font-size: var(--text-xs);
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.popup-time-timer-wrap {
  margin-top: var(--space-3);
}

.popup-time-start-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.popup-time-running {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.popup-time-elapsed {
  font-variant-numeric: tabular-nums;
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--accent);
  min-width: 4ch;
}

.popup-time-running .popup-time-desc {
  flex: 1;
  min-width: 140px;
}

.popup-time-other-running {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
}

.popup-time-other-label {
  color: var(--text-secondary);
}

.popup-time-sep {
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

/* Time tracking view */
.timetracking-panel {
  padding: var(--space-4);
}

.timetracking-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  background: var(--bg-raised);
  border-radius: var(--radius-md);
  border: var(--border-subtle);
  padding: var(--space-4);
}

.timetracking-filter-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.timetracking-label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.timetracking-input {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  background: var(--bg-base);
  border: var(--border-default);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
}

.timetracking-sep {
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

.timetracking-user-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  background: var(--bg-base);
  border: var(--border-default);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  cursor: pointer;
}

.timetracking-user-btn:hover {
  background: var(--bg-hover);
}

.timetracking-summary {
  font-size: var(--text-md);
  margin-bottom: var(--space-3);
  color: var(--text-secondary);
}

.timetracking-list {
  border: var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-raised);
}

.timetracking-list-header {
  display: grid;
  grid-template-columns: 1fr 100px 120px 70px 40px;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-secondary);
  border-bottom: var(--border-default);
  padding: var(--space-2) var(--space-3);
}

.timetracking-entry-row {
  display: grid;
  grid-template-columns: 1fr 100px 120px 70px 40px;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
  border-bottom: var(--border-subtle);
  padding: var(--space-2) var(--space-3);
}

.timetracking-entry-row:last-child {
  border-bottom: none;
}

.timetracking-cell-issue {
  min-width: 0;
}

.timetracking-issue-link {
  color: var(--accent);
  text-decoration: none;
}

.timetracking-issue-link:hover {
  text-decoration: underline;
}

.timetracking-cell-date,
.timetracking-cell-user {
  color: var(--text-secondary);
}

.timetracking-cell-mins {
  font-weight: 500;
  color: var(--text-primary);
}

.timetracking-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  text-align: center;
  color: var(--text-secondary);
}

.timetracking-empty[hidden] {
  display: none !important;
}

.timetracking-empty-icon {
  width: 48px;
  height: 48px;
  margin-bottom: var(--space-3);
  color: var(--text-tertiary);
}

.timetracking-empty strong {
  display: block;
  margin-bottom: var(--space-1);
  color: var(--text-primary);
}

.timetracking-empty p {
  margin: 0 0 var(--space-3);
  font-size: var(--text-sm);
}

.timetracking-loading {
  padding: var(--space-4);
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}