/* ============================================================
   app.css — 绩效考核OA 主样式 (Linear/Notion 极简专业风)
   ============================================================ */

/* ── Reset & Base ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--gray-700);
  background: var(--gray-50);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }

/* ── App Header ── */
.app-header {
  background: var(--header-bg);
  color: var(--header-text);
  padding: 10px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 100;
}
.app-header .logo {
  color: var(--header-text);
  font-size: var(--text-base);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.header-left  { display: flex; align-items: center; gap: var(--space-2); }
.header-right { display: flex; align-items: center; gap: var(--space-3); }
.header-link {
  color: rgba(232,232,236,0.75);
  font-size: var(--text-sm);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  transition: color 0.15s, background 0.15s;
}
.header-link:hover { color: #fff; background: rgba(255,255,255,0.08); }
.user-name { font-size: var(--text-sm); opacity: 0.85; }

/* Notification */
.notif-bell {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  color: rgba(232,232,236,0.75); font-size: var(--text-base);
  transition: background 0.15s;
}
.notif-bell:hover { color: #fff; background: rgba(255,255,255,0.08); }
.notif-badge {
  position: absolute; top: 2px; right: 2px;
  background: var(--danger); color: #fff; font-size: 10px; font-weight: 600;
  min-width: 16px; height: 16px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  line-height: 1;
}

/* Dev badge */
.dev-badge {
  font-size: 10px; font-weight: 600;
  background: #ff6b35; color: #fff;
  padding: 2px 6px; border-radius: 4px;
  letter-spacing: 0.04em;
}

/* ── Main Content ── */
.app-main {
  padding: var(--space-3);
  max-width: 720px;
  margin: 0 auto;
}

/* ── Page Header ── */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
  gap: var(--space-2);
}
.page-header h2 {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--gray-900);
  letter-spacing: -0.01em;
}

/* Role tag */
.role-tag {
  font-size: var(--text-xs);
  font-weight: 500;
  padding: 2px 10px;
  border-radius: 10px;
}
.role-employee { background: var(--info-bg); color: var(--info); }
.role-manager  { background: var(--warning-bg); color: var(--warning); }
.role-director { background: var(--danger-bg); color: var(--danger); }

.user-label { font-size: var(--text-sm); color: var(--gray-500); }

/* ── Cards ── */
.card {
  background: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-3);
  margin-bottom: var(--space-2);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--gray-200);
}

/* ── Dashboard: Linear-style row list ── */
.assessment-list { display: flex; flex-direction: column; gap: 2px; }

.assessment-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: inherit;
  transition: background 0.12s, border-color 0.12s;
  cursor: pointer;
}
.assessment-row:hover {
  background: var(--gray-50);
  border-color: var(--gray-300);
}
.assessment-row.own-row {
  border-style: dashed;
  border-color: var(--gray-300);
  background: #fdfdfd;
}

/* Status dot */
.status-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.status-dot.draft              { border: 2px solid var(--status-draft); background: transparent; }
.status-dot.employee_submitted { border: 2px solid var(--status-submit); background: var(--status-submit); }
.status-dot.manager_reviewed   { border: 2px solid var(--status-review); background: var(--status-review); }
.status-dot.completed          { border: 2px solid var(--status-done); background: var(--status-done); }

/* Row content */
.assessment-row-body {
  flex: 1; min-width: 0;
  display: flex; align-items: center; gap: var(--space-2);
  flex-wrap: wrap;
}
.assessment-row-body .period-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--gray-900);
}
.assessment-row-body .row-user {
  font-size: var(--text-sm);
  color: var(--gray-500);
}
.assessment-row-body .row-sep {
  color: var(--gray-300); font-size: var(--text-xs);
}
.assessment-row-body .row-score {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--gray-500);
  margin-left: auto;
}
.assessment-row-body .row-grade {
  font-weight: 600; font-size: var(--text-xs);
}
.own-label {
  font-size: 10px; font-weight: 600; color: var(--accent);
  background: var(--accent-light);
  padding: 1px 6px; border-radius: 4px;
  white-space: nowrap;
}
.assessment-row-arrow {
  color: var(--gray-300); font-size: var(--text-base);
  flex-shrink: 0;
  transition: transform 0.15s;
}
.assessment-row:hover .assessment-row-arrow {
  transform: translateX(2px);
  color: var(--gray-400);
}

/* Status badge (compact) */
.status-badge {
  font-size: var(--text-xs); font-weight: 500;
  padding: 1px 8px; border-radius: 10px;
  white-space: nowrap;
}
.status-draft              { background: var(--status-draft-bg); color: var(--status-draft); }
.status-employee_submitted { background: var(--status-submit-bg); color: var(--status-submit); }
.status-manager_reviewed   { background: var(--status-review-bg); color: var(--status-review); }
.status-completed          { background: var(--status-done-bg); color: var(--status-done); }

/* Grade colors */
.grade-S { color: #1b5e20; }
.grade-A { color: #2d8a56; }
.grade-B { color: #c2710a; }
.grade-C { color: #c53434; }
.grade-D { color: #b71c1c; }

/* ── Empty State ── */
.empty-state {
  text-align: center;
  padding: 64px 16px;
  color: var(--gray-400);
}
.empty-state .empty-icon {
  font-size: 40px; margin-bottom: var(--space-3); opacity: 0.5;
}
.empty-state p {
  font-size: var(--text-base);
  color: var(--gray-500);
  margin-bottom: var(--space-2);
}
.empty-state .empty-hint { font-size: var(--text-sm); color: var(--gray-400); }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 8px 16px;
  border: none; border-radius: var(--radius-sm);
  font-size: var(--text-sm); font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s, opacity 0.15s;
  text-decoration: none;
  line-height: 1.4;
}
.btn:hover { opacity: 0.88; }
.btn:active { transform: scale(0.98); }

.btn-primary   { background: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent-hover); opacity: 1; }
.btn-success   { background: var(--success); color: #fff; }
.btn-secondary { background: var(--gray-100); color: var(--gray-700); border: 1px solid var(--gray-200); }
.btn-secondary:hover { background: var(--gray-200); opacity: 1; }
.btn-danger    { background: var(--danger); color: #fff; }
.btn-outline   { background: transparent; color: var(--accent); border: 1px solid var(--accent); }
.btn-outline:hover { background: var(--accent-light); opacity: 1; }
.btn-sm { padding: 4px 12px; font-size: var(--text-xs); }
.btn-text {
  background: none; border: none; color: var(--accent);
  padding: 4px 8px; font-size: var(--text-xs); font-weight: 500;
  cursor: pointer; font-family: inherit;
}
.btn-text:hover { background: var(--accent-light); border-radius: 4px; }
.btn-text-danger { color: var(--danger); }
.btn-text-danger:hover { background: var(--danger-bg); }

.form-actions {
  display: flex; gap: var(--space-2);
  margin: var(--space-4) 0;
  flex-wrap: wrap;
}

/* ── Progress Steps ── */
.progress-steps {
  display: flex; align-items: center; justify-content: center;
  gap: 0; margin-bottom: var(--space-5); padding: var(--space-3) 0;
}
.progress-step {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-xs); color: var(--gray-400);
}
.progress-step .step-num {
  width: 24px; height: 24px; border-radius: 50%;
  border: 2px solid var(--gray-300);
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: var(--text-xs);
  flex-shrink: 0;
}
.progress-step.active .step-num {
  border-color: var(--accent); background: var(--accent); color: #fff;
}
.progress-step.active { color: var(--gray-700); font-weight: 500; }
.progress-line {
  width: 32px; height: 2px; background: var(--gray-200);
  margin: 0 var(--space-1);
}
.progress-line.done { background: var(--accent); }

/* ── Dimension Header ── */
.dimension-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-2) var(--space-1);
  margin-top: var(--space-5); margin-bottom: var(--space-1);
  border-bottom: 2px solid var(--gray-200);
}
.dimension-header h3, .dimension-header h4 {
  font-size: var(--text-sm); font-weight: 600; color: var(--gray-900);
  letter-spacing: -0.01em;
}
.dimension-header h2 {
  font-size: var(--text-lg); font-weight: 600; color: var(--gray-900);
}
.dim-weight { font-size: var(--text-xs); color: var(--gray-500); }
.dim-hint { font-size: var(--text-xs); color: var(--warning); }

/* ── Item Card ── */
.item-card { padding: var(--space-3); }
.item-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: var(--space-2); gap: var(--space-2);
}
.item-name { font-weight: 600; font-size: var(--text-sm); color: var(--gray-900); }
.item-weight { font-size: var(--text-xs); color: var(--gray-500); white-space: nowrap; }
.item-content { font-size: var(--text-sm); color: var(--gray-500); margin-bottom: var(--space-2); }

/* ── Scoring Pills (replaces <details> + <select>) ── */
.scoring-pills {
  display: flex; gap: var(--space-1); flex-wrap: wrap;
  margin-bottom: var(--space-2);
}
.scoring-pill {
  display: inline-flex; align-items: center;
  padding: 3px 10px;
  border: 1px solid var(--gray-200);
  border-radius: 20px;
  font-size: var(--text-xs); font-weight: 500;
  cursor: pointer;
  transition: all 0.12s;
  user-select: none;
  background: #fff;
  color: var(--gray-500);
  font-family: inherit;
}
.scoring-pill:hover {
  border-color: var(--accent); color: var(--accent);
  background: var(--accent-light);
}
.scoring-pill.selected {
  border-color: var(--accent); color: var(--accent);
  background: var(--accent-light); font-weight: 600;
}
.scoring-pill .pill-label { color: var(--gray-400); margin-right: 4px; }

/* ── Quote block (manager/director review: employee data) ── */
.quote-block {
  background: var(--accent-light);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-3);
  font-size: var(--text-sm);
}
.quote-block .quote-title {
  font-size: var(--text-xs); font-weight: 600;
  color: var(--accent); margin-bottom: var(--space-1);
  text-transform: uppercase; letter-spacing: 0.04em;
}

/* ── Scoring details (fallback) ── */
.scoring-details { margin-bottom: var(--space-2); }
.scoring-details summary {
  font-size: var(--text-xs); color: var(--accent); cursor: pointer; padding: 4px 0;
}
.scoring-table { margin-top: var(--space-2); }
.scoring-row {
  display: flex; gap: var(--space-2); padding: 4px 0;
  font-size: var(--text-xs); border-bottom: 1px solid var(--gray-100);
}
.scoring-label {
  white-space: nowrap; font-weight: 500; min-width: 80px; color: var(--gray-500);
}

/* ── Inputs ── */
.item-inputs { margin-top: var(--space-2); }
.input-group { margin-bottom: var(--space-2); }
.input-group label {
  display: block; font-size: var(--text-xs); color: var(--gray-500);
  margin-bottom: 4px; font-weight: 500;
}
.input-group textarea,
.input-group input[type="text"],
.input-group input[type="number"],
.input-group select {
  width: 100%; padding: 8px 10px;
  border: 1px solid var(--gray-200); border-radius: var(--radius-sm);
  font-size: var(--text-sm); font-family: inherit;
  color: var(--gray-700); background: #fff;
  transition: border-color 0.15s;
}
.input-group textarea:focus,
.input-group input:focus,
.input-group select:focus {
  outline: none; border-color: var(--accent);
}

/* Coefficient row */
.coef-row {
  display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap;
}
.coef-input {
  width: 72px; padding: 6px 8px;
  border: 2px solid var(--accent); border-radius: var(--radius-sm);
  font-size: var(--text-base); font-weight: 600; text-align: center;
  font-family: inherit; color: var(--gray-900);
  background: var(--accent-light);
  transition: border-color 0.15s, background 0.15s;
}
.coef-input:focus { outline: none; border-color: var(--accent-hover); background: #fff; }
.calc-result { font-size: var(--text-xs); color: var(--gray-500); font-weight: 500; }

/* ── Read-only display ── */
.item-readonly {
  background: var(--gray-50); border-radius: var(--radius-sm); padding: var(--space-2);
}
.read-row { display: flex; gap: var(--space-2); margin-bottom: 4px; font-size: var(--text-sm); }
.read-label { color: var(--gray-500); min-width: 70px; }
.employee-data, .manager-data {
  background: var(--gray-50); border-radius: var(--radius-sm);
  padding: var(--space-2); margin-bottom: var(--space-2); font-size: var(--text-sm);
}
.data-row { display: flex; gap: var(--space-2); margin-bottom: 4px; }
.data-label { color: var(--gray-500); min-width: 70px; white-space: nowrap; }

/* ── Score Summary Card ── */
.score-summary {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
}
.summary-row {
  display: flex; justify-content: space-between;
  padding: 6px 0; font-size: var(--text-sm);
  border-bottom: 1px solid var(--gray-100);
}
.summary-row:last-child { border-bottom: none; }
.final-row { font-size: var(--text-base); font-weight: 600; color: var(--gray-900); padding: 10px 0; }
.grade-row  { font-size: var(--text-base); color: var(--accent); }

/* ── Result Page ── */
.result-banner {
  text-align: center; padding: var(--space-6) var(--space-4);
  border-radius: var(--radius-lg); margin-bottom: var(--space-4);
  background: #fff; border: 1px solid var(--gray-200);
}
.result-score {
  font-size: var(--text-2xl); font-weight: 700;
  color: var(--gray-900); line-height: 1;
  letter-spacing: -0.02em;
}
.result-grade {
  font-size: var(--text-lg); font-weight: 600;
  margin-top: var(--space-2);
  color: var(--gray-700);
}
.result-ratio {
  font-size: var(--text-sm); color: var(--gray-500);
  margin-top: var(--space-2);
}

/* Score progress bar */
.score-bar-wrap {
  margin-top: var(--space-3);
  background: var(--gray-100); border-radius: 4px;
  height: 8px; overflow: hidden;
}
.score-bar-fill {
  height: 100%; border-radius: 4px;
  background: var(--accent);
  transition: width 0.3s ease;
}
.score-bar-label {
  display: flex; justify-content: space-between;
  font-size: var(--text-xs); color: var(--gray-400); margin-top: 4px;
}

/* Detail grid */
.detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
  margin-top: 4px;
}
.detail-col { font-size: var(--text-sm); }
.detail-label { color: var(--gray-400); font-size: var(--text-xs); }
.detail-value { font-weight: 500; }

/* ── Worklog (time entry cards) ── */
.wl-sections { display: flex; flex-direction: column; gap: var(--space-3); }
.wl-section {
  background: #fff; border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm); border: 1px solid var(--gray-200);
  overflow: hidden;
}
.wl-section-hd {
  padding: var(--space-2) var(--space-3);
  background: var(--gray-50); border-bottom: 1px solid var(--gray-200);
}
.wl-section-title { font-weight: 600; font-size: var(--text-sm); color: var(--gray-900); }
.te-cards { padding: var(--space-2) var(--space-3); display: flex; flex-direction: column; gap: var(--space-2); }

.te-card {
  background: var(--gray-50); border: 1px solid var(--gray-200);
  border-radius: var(--radius-md); padding: var(--space-2) var(--space-3);
  transition: border-color 0.15s;
}
.te-card:focus-within { border-color: var(--accent); }
.te-card-hd { display: flex; align-items: center; gap: var(--space-2); }
.te-card-title {
  flex: 1; border: none; background: transparent;
  font-size: var(--text-sm); font-weight: 500; padding: 4px 0;
  color: var(--gray-700); outline: none; font-family: inherit; min-width: 0;
}
.te-card-title::placeholder { color: var(--gray-400); font-weight: 400; }
.te-card-days {
  font-size: var(--text-xs); font-weight: 600; color: var(--accent);
  background: var(--accent-light); padding: 2px 8px; border-radius: 10px;
  white-space: nowrap;
}
.te-card-del {
  width: 24px; height: 24px; border: none; background: transparent;
  color: var(--gray-300); font-size: 14px; cursor: pointer;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.te-card-del:hover { color: var(--danger); background: var(--danger-bg); }
.te-card-bd {
  display: flex; align-items: center; gap: 6px;
  margin-top: var(--space-2); padding-top: var(--space-2);
  border-top: 1px solid var(--gray-200);
}
.te-card-bd input[type="date"] {
  padding: 4px 6px; border: 1px solid var(--gray-200); border-radius: 4px;
  font-size: var(--text-xs); font-family: inherit; color: var(--gray-500);
  outline: none;
}
.te-card-bd input[type="date"]:focus { border-color: var(--accent); }
.te-date-sep { color: var(--gray-300); font-size: var(--text-xs); }
.te-add-btn {
  display: block; width: calc(100% - 24px); margin: 4px 12px var(--space-2);
  padding: var(--space-2); border: 1px dashed var(--gray-300); border-radius: var(--radius-md);
  background: transparent; color: var(--gray-500); font-size: var(--text-sm);
  cursor: pointer; font-family: inherit;
  transition: all 0.15s;
}
.te-add-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }

.wl-section-ft {
  display: flex; justify-content: space-between;
  padding: var(--space-2) var(--space-3); border-top: 1px solid var(--gray-100);
  font-size: var(--text-xs); color: var(--gray-500);
}
.wl-section-ft strong { color: var(--gray-700); }

.worklog-summary {
  display: flex; justify-content: space-between;
  padding: var(--space-2) var(--space-1); font-size: var(--text-sm); color: var(--gray-500);
  margin-bottom: var(--space-2);
}

/* ── Divider ── */
.divider { height: 1px; background: var(--gray-200); margin: var(--space-5) 0; }

/* ── Alerts ── */
.alert {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm); font-size: var(--text-sm);
  margin-bottom: var(--space-3);
}
.alert-error { background: var(--danger-bg); color: var(--danger); }
.alert-info  { background: var(--info-bg); color: var(--info); }
.alert-success { background: var(--success-bg); color: var(--success); }

/* ── Tables ── */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.data-table {
  width: 100%; border-collapse: collapse; font-size: var(--text-xs);
}
.data-table th {
  background: var(--gray-50); padding: 8px 8px; text-align: left;
  font-weight: 600; white-space: nowrap;
  border-bottom: 2px solid var(--gray-200);
  color: var(--gray-500); font-size: var(--text-xs);
}
.data-table td {
  padding: 7px 8px; border-bottom: 1px solid var(--gray-100);
  white-space: nowrap; color: var(--gray-700);
}
.data-table tr:hover td { background: var(--gray-50); }

/* ── Stats Cards ── */
.stats-cards {
  display: flex; gap: var(--space-2); margin-bottom: var(--space-4); flex-wrap: wrap;
}
.stat-card {
  flex: 1; min-width: 80px;
  background: #fff; border-radius: var(--radius-md); padding: var(--space-3);
  text-align: center; box-shadow: var(--shadow-sm);
  border: 1px solid var(--gray-200);
}
.stat-number { font-size: var(--text-xl); font-weight: 700; color: var(--accent); }
.stat-label  { font-size: var(--text-xs); color: var(--gray-500); margin-top: 2px; }

/* Chart card */
.chart-card { padding: var(--space-3); margin-bottom: var(--space-3); }
.chart-card h3 { font-size: var(--text-sm); margin-bottom: var(--space-2); color: var(--gray-900); }
.chart-row { display: flex; gap: var(--space-3); }
.chart-row .half { flex: 1; min-width: 0; }

/* ── Admin Nav ── */
.admin-nav-list { display: flex; flex-direction: column; gap: 1px; }
.admin-nav-row {
  display: flex; align-items: center;
  padding: var(--space-4);
  background: #fff; border: 1px solid var(--gray-200);
  border-radius: var(--radius-md);
  text-decoration: none; color: inherit;
  transition: background 0.12s;
}
.admin-nav-row:hover { background: var(--gray-50); }
.admin-nav-body { flex: 1; }
.admin-nav-body h3 { font-size: var(--text-base); font-weight: 600; color: var(--gray-900); margin-bottom: 2px; }
.admin-nav-body p  { font-size: var(--text-sm); color: var(--gray-500); margin: 0; }
.admin-nav-arrow { color: var(--gray-300); font-size: var(--text-base); flex-shrink: 0; transition: transform 0.15s; }
.admin-nav-row:hover .admin-nav-arrow { transform: translateX(2px); color: var(--gray-400); }

/* ── Inline Form ── */
.inline-form {
  display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap;
}
.inline-form input, .inline-form select {
  padding: 6px 10px; border: 1px solid var(--gray-200); border-radius: var(--radius-sm);
  font-size: var(--text-sm); font-family: inherit;
}
.inline-form input:focus, .inline-form select:focus { outline: none; border-color: var(--accent); }

/* ── Form Row ── */
.form-row {
  display: flex; gap: var(--space-2); align-items: center; margin-bottom: 6px;
}
.form-row label { font-size: var(--text-sm); font-weight: 500; white-space: nowrap; }
.form-row input, .form-row select {
  padding: 4px 8px; border: 1px solid var(--gray-200); border-radius: 4px;
  font-size: var(--text-sm); font-family: inherit;
}
.form-row input:focus, .form-row select:focus { outline: none; border-color: var(--accent); }

/* Action cell */
.action-cell { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }
.action-cell input, .action-cell select {
  padding: 4px 6px; border: 1px solid var(--gray-200); border-radius: 3px;
  font-size: var(--text-xs); font-family: inherit;
}

/* ── Login ── */
.page-center {
  display: flex; justify-content: center; align-items: center;
  min-height: 80vh; padding: var(--space-4);
}
.login-card {
  max-width: 360px; width: 100%; text-align: center;
  background: #fff; border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6);
  box-shadow: var(--shadow-md); border: 1px solid var(--gray-200);
}
.login-logo {
  width: 48px; height: 48px; border-radius: var(--radius-lg);
  background: var(--header-bg);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--space-4);
  color: #fff; font-size: 20px; font-weight: 700;
}
.login-card h1 { font-size: var(--text-xl); font-weight: 700; color: var(--gray-900); margin-bottom: 4px; }
.login-card .subtitle { color: var(--gray-500); font-size: var(--text-sm); margin-bottom: var(--space-6); }
.login-card .form-group { margin-bottom: var(--space-4); }
.login-card .form-group label {
  display: block; font-size: var(--text-sm); font-weight: 500;
  margin-bottom: 6px; color: var(--gray-700); text-align: left;
}
.login-card .form-group input {
  width: 100%; padding: 10px 12px; border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm); font-size: var(--text-base);
  font-family: inherit; box-sizing: border-box;
}
.login-card .form-group input:focus { outline: none; border-color: var(--accent); }
.login-submit {
  width: 100%; padding: 10px; font-size: var(--text-base); margin-top: var(--space-3);
}

/* User list (login) */
.user-list { display: flex; flex-direction: column; gap: var(--space-2); }
.user-btn {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3); border: 1px solid var(--gray-200);
  border-radius: var(--radius-md); background: #fff;
  cursor: pointer; font-size: var(--text-base); font-family: inherit;
  width: 100%; text-align: left; transition: all 0.15s;
}
.user-btn:hover { border-color: var(--accent); background: var(--accent-light); }
.user-role-badge {
  font-size: var(--text-xs); padding: 2px 10px; border-radius: 10px; white-space: nowrap;
}
.user-name-btn { font-weight: 500; }

/* ── Time entry badge (readonly) ── */
.te-entry-badge {
  display: inline-block; background: var(--accent-light); color: var(--accent);
  padding: 2px 8px; border-radius: 4px; font-size: var(--text-xs);
  margin: 2px 4px 2px 0;
}
.te-loading { color: var(--gray-400); font-style: italic; }

/* ── Stats Dashboard ── */
.stats-tabs {
  display: flex; gap: 4px; margin-bottom: var(--space-3);
  background: var(--gray-100); padding: 4px; border-radius: var(--radius-md);
}
.stats-tab {
  flex: 1; text-align: center; padding: 6px 0;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm); font-weight: 500;
  color: var(--gray-500); text-decoration: none;
  transition: all 0.15s;
}
.stats-tab:hover { color: var(--gray-700); }
.stats-tab.active {
  background: #fff; color: var(--gray-900); font-weight: 600;
  box-shadow: var(--shadow-sm);
}

.stats-subbar {
  display: flex; align-items: center; justify-content: center;
  gap: var(--space-3); margin-bottom: var(--space-3);
  flex-wrap: wrap;
}
.stats-arrow {
  font-size: var(--text-sm); color: var(--gray-500); text-decoration: none;
  padding: 4px 12px; border: 1px solid var(--gray-200); border-radius: var(--radius-sm);
  transition: all 0.15s;
}
.stats-arrow:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }
.stats-current {
  font-size: var(--text-base); font-weight: 600; color: var(--gray-900);
  min-width: 120px; text-align: center;
}
.stats-select {
  padding: 6px 10px; border: 1px solid var(--gray-200); border-radius: var(--radius-sm);
  font-size: var(--text-sm); font-family: inherit; color: var(--gray-700);
  background: #fff; cursor: pointer;
}
.stats-select:focus { outline: none; border-color: var(--accent); }

/* Stat card wide variant */
.stat-card-wide { flex: 2; min-width: 200px; text-align: left; padding: var(--space-3) var(--space-4); }

/* Grade bar (inline distribution) */
.grade-bar {
  display: flex; flex-direction: column; gap: 3px; margin-top: var(--space-1);
}
.grade-bar-item {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-xs);
}
.grade-bar-label { font-weight: 700; width: 18px; flex-shrink: 0; }
.grade-bar-fill {
  height: 6px; border-radius: 3px; min-width: 2px;
  transition: width 0.3s ease;
}
.grade-bar-item:nth-child(1) .grade-bar-fill { background: #2d8a56; }
.grade-bar-item:nth-child(2) .grade-bar-fill { background: #43a047; }
.grade-bar-item:nth-child(3) .grade-bar-fill { background: #f57c00; }
.grade-bar-item:nth-child(4) .grade-bar-fill { background: #e53935; }
.grade-bar-item:nth-child(5) .grade-bar-fill { background: #b71c1c; }
.grade-bar-count { color: var(--gray-500); min-width: 18px; flex-shrink: 0; }

@media (max-width: 767px) {
  .stats-tab { font-size: var(--text-xs); padding: 5px 0; }
  .stats-arrow { font-size: var(--text-xs); padding: 4px 8px; }
  .stat-card-wide { flex: 1 1 100%; min-width: 0; }
  .stats-subbar { gap: var(--space-1); }
  .stats-select { font-size: var(--text-xs); }
}

/* ── Utilities ── */
.hide-mobile { display: none; }
@media (min-width: 768px) { .hide-mobile { display: inline; } }

/* ── Responsive ── */
@media (min-width: 768px) {
  .app-main { padding: var(--space-4) var(--space-5); }
}

@media (max-width: 767px) {
  .app-header { padding: 8px 12px; }
  .app-header .logo { font-size: var(--text-sm); }

  .app-main { max-width: 100%; padding: var(--space-2); }

  .card { padding: var(--space-2); border-radius: var(--radius-sm); }

  .page-header { flex-direction: column; align-items: flex-start; }
  .page-header h2 { font-size: var(--text-base); }

  .assessment-row { padding: var(--space-2); flex-wrap: wrap; }
  .assessment-row-body { flex-wrap: wrap; }
  .assessment-row-arrow { margin-left: auto; }

  .form-actions { flex-direction: column; }
  .form-actions .btn { width: 100%; }
  .btn { padding: 10px 16px; font-size: var(--text-sm); }

  .coef-row { flex-direction: column; align-items: flex-start; }
  .coef-input { width: 100%; max-width: 120px; }

  .input-group textarea,
  .input-group input[type="text"],
  .input-group input[type="number"] { font-size: 16px; }

  .detail-grid { grid-template-columns: 1fr; gap: 4px; }

  .result-banner { padding: var(--space-4); }
  .result-score { font-size: var(--text-xl); }

  .login-card { max-width: 100%; padding: var(--space-6) var(--space-4); }

  .admin-nav-row { padding: var(--space-3); }
  .admin-nav-body h3 { font-size: var(--text-sm); }

  .stats-cards { gap: 6px; }
  .stat-card { min-width: 70px; padding: var(--space-2); }
  .stat-number { font-size: var(--text-lg); }

  .inline-form { flex-direction: column; align-items: stretch; }
  .inline-form input, .inline-form select { width: 100%; }
  .form-row { flex-direction: column; align-items: stretch; }

  .data-table th, .data-table td { padding: 4px 4px; font-size: 10px; }
  .chart-row { flex-direction: column; }

  /* Item card mobile */
  .item-header { flex-wrap: wrap; gap: 4px; }
  .dimension-header { flex-wrap: wrap; gap: 4px; }
  .employee-data { padding: var(--space-2); }
  .data-row { flex-direction: column; gap: 2px; }
  .data-label { min-width: auto; }
  .scoring-row { flex-wrap: wrap; gap: 4px; padding: 6px 0; }
  .scoring-label { min-width: 60px; }
  .read-row { flex-direction: column; gap: 2px; }
  .scoring-pills { gap: 4px; }
  .scoring-pill { padding: 4px 10px; font-size: var(--text-xs); }

  /* Time entry mobile */
  .te-card { padding: var(--space-2); }
  .te-card-hd { gap: 4px; }
  .te-card-bd { flex-direction: column; gap: 4px; align-items: stretch; }
  .te-card-bd input[type="date"] { width: 100%; }
  .te-date-sep { display: none; }
  .te-add-btn { width: calc(100% - 16px); margin: 4px 8px 6px; }
  .wl-section-hd { padding: var(--space-2); }
  .wl-section-ft { flex-direction: column; gap: 4px; padding: var(--space-2); }

  .progress-steps { gap: 0; }
  .progress-step { font-size: 10px; gap: 4px; }
  .progress-step .step-num { width: 20px; height: 20px; font-size: 10px; }
  .progress-line { width: 20px; }

  .summary-row { flex-direction: column; gap: 2px; }
}