/* ─── Summary Bar ───────────────────────────────────────────────── */
.summary-bar {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-8);
  margin-bottom: var(--space-6);
}

.stat-card {
  padding: var(--space-5) var(--space-6);
  text-align: left;
  border: 1px solid var(--color-border);
  cursor: pointer;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.stat-card-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: var(--space-4);
}

.stat-card-text {
  display: flex;
  flex-direction: column; /* stacks label on the top, of number */
  gap: var(--space-1);
}

.stat-card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-md);
}

.stat-card.active {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.15);
}

.stat-number {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  line-height: 1.1;
  color: var(--color-text-theme);
}

.stat-label {
  font-size: var(--text-sm);
  color: var(--color-text-theme);
  margin-top: var(--space-1);
}

.stat-open {
  background: var(--status-open-bg);
  border-color: var(--status-open);
}
.stat-open .stat-number {
  color: var(--status-open);
}

.stat-progress {
  background: var(--status-in-progress-bg);
  border-color: var(--status-in-progress);
}
.stat-progress .stat-number {
  color: var(--status-in-progress);
}

.stat-review {
  background: var(--status-pending-review-bg);
  border-color: var(--status-pending-review);
}
.stat-review .stat-number {
  color: var(--status-pending-review);
}

.stat-blocked {
  background: var(--status-blocked-bg);
  border-color: var(--status-blocked);
}
.stat-blocked .stat-number {
  color: var(--status-blocked);
}

.stat-closed {
  background: var(--status-closed-bg);
  border-color: var(--status-closed);
}
.stat-closed .stat-number {
  color: var(--status-closed);
}

/* ─── Toolbar ───────────────────────────────────────────────────── */
.list-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

/* ─── Filter Bar ────────────────────────────────────────────────── */
.filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-10);
  flex: 1;
  flex-wrap: wrap;
}

.filter-bar .form-select,
.filter-bar .form-input {
  height: 36px;
  padding-top: 0;
  padding-bottom: 0;
  width: auto;
}

.filter-select {
  min-width: 140px;
}

.filter-search,
.filter-input {
  flex: 1;
  min-width: 140px;
  max-width: 220px;
}

/* ─── Toolbar right (view toggle + new issue) ───────────────────── */
.toolbar-right {
  display: flex;
  align-items: center;
  gap: var(--space-10);
}

.view-toggle {
  display: inline-flex;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-background-theme);
}

.view-toggle-btn {
  padding: var(--space-2) var(--space-4);
  border: none;
  background: transparent;
  color: var(--color-text-theme);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  cursor: pointer;
  height: 36px;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  transition:
    background var(--transition-fast),
    color var(--transition-fast);
}

.view-toggle-btn + .view-toggle-btn {
  border-left: 1px solid var(--color-border);
}

.view-toggle-btn:hover {
  background: var(--color-background-theme);
  color: var(--color-text-theme);
}

.view-toggle-btn.active {
  background: var(--color-accent);
  color: #ffffff;
}

/* ─── Issue Table ───────────────────────────────────────────────── */
.issue-table-wrapper {
  overflow-x: scroll;
}

.issue-table {
  table-layout: auto;
  border-collapse: collapse;
  font-size: var(--text-sm);
  min-width: 800px;
  width: 100%;
}

.issue-table thead tr {
  border-bottom: 1px solid var(--color-border);
  background: var(--color-fill-theme);
}

.issue-table th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--color-text-theme);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

.align-center {
  text-align: center;
}

.issue-table th.align-center {
  text-align: center;
}

.issue-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
  color: var(--color-text-theme);
}

.col-date,
.issue-table td:nth-child(7) {
  text-align: right;
}

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

.issue-table tbody tr[data-issue-row] {
  cursor: pointer;
  transition: background var(--transition-fast);
  background-color: var(--color-background-theme);
}

.issue-table tbody tr[data-issue-row]:hover {
  background: var(--color-hover-theme);
}

.issue-table tbody tr:hover .row-action-btn,
.row-action-btn:focus-visible {
  opacity: 1;
}

.col-edit-cell {
  text-align: center;
  padding-left: 0;
}
/* Created-by icon inside title cell */
.created-by-icon {
  display: inline-block;
  font-size: 14px;
  margin-right: var(--space-1);
  vertical-align: middle;
}

.issue-title-link {
  display: inline-block;
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
  color: var(--color-text-theme);
  font-weight: var(--weight-medium);
}

.issue-title-link:hover {
  color: var(--color-accent);
}

.issue-id {
  color: var(--color-text-theme);
  letter-spacing: 0.2px;
}

.issue-id:hover {
  color: var(--color-accent);
}

/* ─── Column Widths ─────────────────────────────────────────────── */

.col-pri {
  width: 15%;

}
.col-id {
  width: 5%;
}
.col-title {
  width: 45%;
}
.col-status {
  width: 15%;
}
.col-assign {
  width: 10%;
}
.col-date {
  width: 10%;
}
.col-edit-cell {
  text-align: center;
  padding-left: 0;
}

/* ─── Cell Content ──────────────────────────────────────────────── */
.issue-title {
  font-weight: var(--weight-medium);
}

/* ─── Badges (table context) ────────────────────────────────────── */
.issue-table .badge {
  text-transform: uppercase;
  letter-spacing: 0.4px;
  font-size: 10px;
  font-weight: var(--weight-semibold);
}

/* ─── Kanban Board Empty State for No Issues ──────────────────────────────────────────────── */

.board-empty-state {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-4);
  flex: 1;
  gap: var(--space-3);
}

.board-empty-state p {
  color: var(--color-text-theme);
  font-size: var(--text-sm);
  font-style: italic;
}

.board-empty-cta {
  padding: var(--space-10) var(--space-5);
}

.board-empty-cta .empty-state-icon {
  font-size: var(--text-2xl);
  line-height: 1;
}

.board-empty-cta .empty-state-title {
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--color-text-theme);
  font-style: normal;
}

.board-empty-cta .empty-state-desc {
  font-size: var(--text-sm);
  font-style: normal;
  color: var(--color-text-theme);
}


/* ─── Multi-screen modal screens ────────────────────────────────── */
.screen.hidden {
  display: none !important;
}

/* ─── Choice screen ──────────────────────────────────────────────── */
.choice-intro {
  margin-bottom: var(--space-5);
}

.choice-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.choice-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-6) var(--space-4);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-background-theme);
  cursor: pointer;
  text-align: center;
  transition:
    border-color var(--transition-base),
    background var(--transition-base),
    box-shadow var(--transition-base);
}

.choice-card:hover {
  border-color: var(--color-accent);
  background: rgba(37, 99, 235, 0.03);
  box-shadow: var(--shadow-md);
}

.choice-card-ai:hover {
  border-color: var(--status-pending-review);
  background: rgba(124, 58, 237, 0.04);
}

.choice-emoji {
  font-size: 28px;
  line-height: 1;
  display: block;
}

.choice-name {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text-theme);
  display: block;
}

.choice-hint {
  font-size: var(--text-xs);
  color: var(--color-text-theme);
  display: block;
  line-height: 1.4;
}

.required {
  color: var(--color-danger);
}

/* ─── AI Input screen ────────────────────────────────────────────── */
.ai-desc-textarea {
  min-height: 120px;
  resize: vertical;
}

.ai-hint {
  margin-top: var(--space-1);
}

/* ─── AI Loading screen ──────────────────────────────────────────── */
.ai-loading-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  padding: var(--space-10) var(--space-6);
}

.ai-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid var(--color-border);
  border-top-color: var(--status-pending-review);
  border-radius: 50%;
  animation: ai-spin 0.75s linear infinite;
}

@keyframes ai-spin {
  to {
    transform: rotate(360deg);
  }
}

.ai-loading-text {
  font-size: var(--text-sm);
  color: var(--color-text-theme);
  font-weight: var(--weight-medium);
}

/* ─── AI Preview screen ──────────────────────────────────────────── */
.ai-created-by-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--status-pending-review);
  background: rgba(124, 58, 237, 0.08);
  border: 1px solid rgba(124, 58, 237, 0.2);
  padding: 3px var(--space-3);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-3);
}

/* ─── View container ────────────────────────────────────────────── */
.view-container.hidden {
  display: none !important;
}

/* ─── Board view (merged from former board.css) ─────────────────── */
.board {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-5);
  align-items: start;
}

.board-column {
  background: var(--color-background-theme);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  min-height: 480px;
}

.board-col-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
}

.board-col-title {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--color-text-theme);
}

.board-col-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 var(--space-2);
  background: var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--color-text-theme);
}

.board-cards {
  padding: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
  min-height: 80px;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  transition:
    background var(--transition-base),
    border var(--transition-base);
}

.board-cards.drag-over {
  background: rgba(37, 99, 235, 0.04);
  outline: 2px dashed var(--color-accent);
  outline-offset: -4px;
}

.board-card {
  padding: var(--space-4);
  cursor: pointer;
  border-left: 3px solid transparent;
  user-select: none;
  background-color: var(--color-background-theme);
  transition:
    box-shadow var(--transition-fast),
    transform var(--transition-fast);
}

.board-card[data-priority='P0'] {
  border-left-color: var(--priority-p0);
}
.board-card[data-priority='P1'] {
  border-left-color: var(--priority-p1);
}
.board-card[data-priority='P2'] {
  border-left-color: var(--priority-p2);
}
.board-card[data-priority='P3'] {
  border-left-color: var(--priority-p3);
}

/* Blocked overlay — red left border per spec */
.board-card-blocked {
  border-left-color: var(--color-danger) !important;
  border-left-width: 4px;
}

.board-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.board-card.dragging {
  opacity: 0.4;
  transform: rotate(1deg);
  box-shadow: var(--shadow-lg);
}

.board-card-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-theme);
  line-height: 1.45;
  margin-bottom: var(--space-3);
}

.board-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.board-card-assignee {
  font-size: var(--text-xs);
  color: var(--color-text-theme);
  flex: 1;
}

.board-card-budget {
  font-size: var(--text-xs);
  color: var(--color-text-theme);
}

.board-card .badge {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

/* Color for the Board Columns (Open, In Progress, Pending Review, Blocked, Closed */
.board-column-open {
  background: var(--status-open-bg);
  border-color: var(--status-open);
}
.board-column-open .board-col-title {
  color: var(--color-text-theme);
}

.board-column-open .board-col-count {
  color: var(--color-text-light);
  background-color: var(--status-open);
}

.board-column-progress {
  background: var(--status-in-progress-bg);
  border-color: var(--status-in-progress);
}
.board-column-progress .board-col-title {
  color: var(--color-text-theme);
}

.board-column-progress .board-col-count {
  color: var(--color-text-light);
  background-color: var(--status-in-progress);
}

.board-column-review {
  background: var(--status-pending-review-bg);
  border-color: var(--status-pending-review);
}
.board-column-review .board-col-title {
  color: var(--color-text-theme);
}

.board-column-review .board-col-count {
  color: var(--color-text-light);
  background-color: var(--status-pending-review);
}

.board-column-blocked {
  background: var(--status-blocked-bg);
  border-color: var(--status-blocked);
}
.board-column-blocked .board-col-title {
  color: var(--color-text-theme);
}

.board-column-blocked .board-col-count {
  color: var(--color-text-light);
  background-color: var(--status-blocked);
}

.board-column-closed {
  background: var(--status-closed-bg);
  border-color: var(--status-closed);
}
.board-column-closed .board-col-title {
  color: var(--color-text-theme);
}

.board-column-closed .board-col-count {
  color: var(--color-text-light);
  background-color: var(--status-closed);
}
