/* ============================================================
   JobSynk — Components
   Clean, professional UI components
   ============================================================ */

/* ---- Tags & Chips ---- */
.tag {
  font-family: var(--font-body);
  font-size: 10px; padding: 2px 8px;
  background: var(--color-primary-dim);
  border: 1px solid var(--color-primary-border);
  border-radius: var(--radius-full);
  color: var(--color-primary-bright);
  text-transform: uppercase; letter-spacing: 1px; font-weight: 600;
  white-space: nowrap;
}
.tag.green { background: var(--color-success-dim); border-color: rgba(74,222,128,0.2); color: var(--color-success); }
.tag.blue { background: var(--color-info-dim); border-color: rgba(96,165,250,0.2); color: var(--color-info); }
.tag.orange { background: var(--color-warning-dim); border-color: rgba(251,191,36,0.2); color: var(--color-warning); }
.tag.cyan { background: var(--color-accent-dim); border-color: rgba(78,205,196,0.2); color: var(--color-accent); }

.chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: var(--radius-full);
  background: var(--color-surface); border: 1px solid var(--color-surface-border);
  font-size: var(--text-xs); color: var(--color-text-dim);
  font-weight: 500;
}

/* ---- Role Select ---- */
.role-sel {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-border);
  color: var(--color-text);
  padding: 7px 10px; border-radius: var(--radius-md);
  font-family: var(--font-body); font-weight: 500; font-size: var(--text-sm);
  cursor: pointer; transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.role-sel:hover { border-color: var(--color-primary); }
.role-sel:focus-visible { box-shadow: var(--shadow-glow); }

/* ---- Nav Buttons ---- */
.nav-btn {
  width: 100%; display: flex; align-items: center; gap: 8px;
  padding: 10px 12px; border: none;
  background: transparent; border-radius: var(--radius-md);
  color: var(--color-text-dim); cursor: pointer; margin: 1px 0;
  font-family: var(--font-body); font-weight: 500; font-size: var(--text-sm);
  transition: all var(--transition-fast);
}
.nav-btn:hover {
  color: var(--color-text);
  background: var(--color-surface-glass);
  transform: translateX(2px);
}
.nav-btn.active {
  background: linear-gradient(90deg, var(--color-primary-dim), var(--color-surface-glass));
  color: var(--color-text-heading);
  font-weight: 600;
  box-shadow: inset 0 0 0 1px rgba(196, 123, 58, 0.14);
}
.nav-btn .nav-icon {
  font-size: 12px;
  flex-shrink: 0;
  opacity: 0.75;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(196, 123, 58, 0.08);
}
.nav-btn.active .nav-icon {
  opacity: 1;
  color: var(--color-primary);
  background: rgba(196, 123, 58, 0.16);
}
.nav-btn .nav-label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---- Panels ---- */
.panel {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-2xl); padding: 20px;
  box-shadow: var(--shadow-sm);
  min-width: 0; overflow: hidden; word-wrap: break-word;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
}
.panel::before { display: none; }
.panel:hover { border-color: var(--color-primary-border); box-shadow: var(--shadow-md); transform: translateY(-1px); }
main > section.panel:hover {
  transform: none;
  box-shadow: var(--shadow-sm);
  border-color: var(--color-surface-border);
}

/* ---- Grids ---- */
.grid { display: grid; gap: 14px; min-width: 0; }
.grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid.cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

/* ---- Toolbar ---- */
.toolbar { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; align-items: center; }

/* ---- Headings ---- */
h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl); font-weight: 700;
  color: var(--color-text-heading);
  letter-spacing: 0.5px;
}
h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg); font-weight: 600;
  color: var(--color-text-heading);
  margin-bottom: 12px;
}
h4 {
  font-family: var(--font-body);
  font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-dim);
  margin-bottom: 5px; text-transform: uppercase;
  letter-spacing: 0.8px;
}

/* ---- Buttons ---- */
.btn {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-border);
  color: var(--color-text);
  padding: 9px 16px; border-radius: 999px;
  cursor: pointer; font-family: var(--font-body);
  font-weight: 600; font-size: var(--text-sm);
  transition: all var(--transition-fast);
  display: inline-flex; align-items: center; justify-content: center; gap: 5px;
  min-height: 38px;
}
.btn:hover { border-color: var(--color-primary); color: var(--color-text-heading); box-shadow: var(--shadow-sm); }
.btn:active { transform: scale(0.98); }
.btn.brand {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-bright));
  border-color: transparent;
  color: #1a1a1e;  font-weight: 700;
  box-shadow: 0 10px 20px rgba(196, 123, 58, 0.22);
}
.btn.brand:hover { background: linear-gradient(135deg, var(--color-primary-bright), #dd9557); }
.btn.ghost { background: transparent; border: 1px dashed rgba(196, 123, 58, 0.24); color: var(--color-text-dim); }
.btn.ghost:hover { border-color: var(--color-primary); color: var(--color-primary); }
.btn.danger { border-color: rgba(248,113,113,0.3); color: var(--color-danger); }
.btn.green { border-color: rgba(74,222,128,0.3); color: var(--color-success); }
.btn.blue { border-color: rgba(96,165,250,0.3); color: var(--color-info); }
.btn.small { padding: 6px 12px; font-size: var(--text-xs); min-height: 32px; }
.btn.large { padding: 13px 24px; font-size: var(--text-base); min-height: 46px; }
.btn:disabled { opacity: .3; cursor: not-allowed; transform: none !important; }

/* ---- Inputs ---- */
.input, select, textarea {
  background: var(--color-bg);
  border: 1px solid var(--color-surface-border);
  color: var(--color-text);
  padding: 9px 12px; border-radius: var(--radius-md);
  font-family: var(--font-body); font-size: var(--text-sm); font-weight: 400;
  transition: border-color var(--transition-fast);
  width: 100%;
}
.input::placeholder, textarea::placeholder { color: var(--color-muted); }
.input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--color-primary);
  box-shadow: 0 0 0 2px var(--color-primary-dim);
}
textarea { resize: vertical; min-height: 80px; }

/* ---- Tables ---- */
.table { width: 100%; border-collapse: separate; border-spacing: 0; margin-top: 10px; }
.table th {
  background: var(--color-bg-elevated);
  border-bottom: 1px solid var(--color-surface-border);
  padding: 8px 12px; text-align: left;
  font-family: var(--font-body);
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 1px;
  color: var(--color-muted); font-weight: 600;
}
.table td {
  border-bottom: 1px solid var(--color-surface-border);
  padding: 10px 12px; font-size: var(--text-sm);
  color: var(--color-text-dim);
}
.table tr:hover td { background: var(--color-surface); color: var(--color-text); }
.table-wrapper, .table-wrap {
  overflow-x: auto;
  border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface-glass);
}

/* ---- Kanban ---- */
.kanban { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 10px; }
.col {
  background: var(--color-bg-secondary); border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-lg); min-height: 250px; padding: 12px;
}
.col h5 {
  font-family: var(--font-body);
  margin: 4px 0 10px; color: var(--color-text-dim); font-weight: 600;
  text-transform: uppercase; letter-spacing: 1px; text-align: center;
  font-size: var(--text-xs); border-bottom: 1px solid var(--color-surface-border); padding-bottom: 8px;
}
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-border); border-radius: var(--radius-md);
  padding: 10px; margin: 6px 0; cursor: grab;
  transition: all var(--transition-fast);
  box-shadow: 0 4px 10px rgba(32, 24, 16, 0.04);
}
.card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); }

/* ---- Modals ---- */
.modal {
  position: fixed; inset: 0;
  background: rgba(26,26,30,0.62); backdrop-filter: blur(10px);
  display: none; align-items: center; justify-content: center;
  padding: 20px; z-index: var(--z-modal);
}
.modal.show { display: flex; }
.modal .content {
  background: var(--color-surface-gradient-strong);
  border: 1px solid var(--color-surface-border);
  border-radius: 24px; padding: 24px;
  max-width: 860px; width: 100%;
  box-shadow: var(--shadow-xl);
  max-height: 90vh; overflow-y: auto;
}

/* ---- Toasts ---- */
.toast-container {
  position: fixed; top: calc(var(--header-height) + 8px); right: 12px;
  z-index: var(--z-toast); display: flex; flex-direction: column; gap: 6px;
  pointer-events: none;
}
.toast {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-border);
  border-left: 3px solid var(--color-primary);
  border-radius: var(--radius-md); padding: 10px 14px;
  color: var(--color-text); font-size: var(--text-sm);
  box-shadow: var(--shadow-md); animation: slideIn .25s ease-out;
  max-width: 320px; pointer-events: auto;
}
.toast.success { border-left-color: var(--color-success); }
.toast.error { border-left-color: var(--color-danger); }

/* ---- Empty State ---- */
.empty-state { text-align: center; padding: 40px 20px; }
.empty-state-icon { font-size: 40px; margin-bottom: 12px; line-height: 1; }
.empty-state h3 { font-size: 16px; font-weight: 600; color: var(--color-text-heading); margin-bottom: 8px; }
.empty-state p { font-size: 14px; color: var(--color-text-dim); line-height: 1.6; max-width: 360px; margin: 0 auto; }
.empty-state .btn { margin-top: 16px; }

/* ---- Status Indicators ---- */
.api-status { display: inline-block; width: 6px; height: 6px; border-radius: 50%; margin-right: 5px; }
.api-status.active { background: var(--color-success); }
.api-status.inactive { background: var(--color-muted); opacity: .3; }

/* ---- Spinner ---- */
.spinner { display: inline-block; width: 14px; height: 14px; border: 2px solid var(--color-surface-border); border-top-color: var(--color-primary); border-radius: 50%; animation: spin .5s linear infinite; }

/* ---- Salary Bar ---- */
.salary-bar { height: 5px; background: var(--color-surface-border); border-radius: var(--radius-full); margin-top: 4px; overflow: hidden; }
.salary-bar .fill { height: 100%; border-radius: var(--radius-full); background: linear-gradient(90deg, var(--color-success), var(--color-accent)); }

/* ---- Search Results ---- */
.search-result {
  background: var(--color-surface); border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-lg); padding: 16px; margin: 10px 0;
  transition: border-color var(--transition-fast);
}
.search-result:hover { border-color: var(--color-primary-border); }
.search-result h4 { color: var(--color-text-heading); text-transform: none; letter-spacing: 0; font-size: var(--text-base); font-weight: 600; margin-bottom: 2px; }
.search-result .company-row { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.search-result .company-logo { width: 20px; height: 20px; border-radius: var(--radius-sm); object-fit: contain; background: var(--color-bg-elevated); }
.search-result .meta { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 6px; }
.search-result .meta span { font-size: var(--text-xs); color: var(--color-muted); }

/* ---- Form Validation ---- */
.input.error { border-color: var(--color-danger); box-shadow: 0 0 0 2px var(--color-danger-dim); }
.input.success { border-color: var(--color-success); box-shadow: 0 0 0 2px var(--color-success-dim); }
.field-error { color: var(--color-danger); font-size: var(--text-xs); margin-top: 3px; }

/* ---- User Info ---- */
.user-info { display: flex; align-items: center; gap: 6px; }
.user-avatar {
  width: 28px; height: 28px; border-radius: var(--radius-md);
  background: var(--color-primary-dim);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: var(--text-xs); color: var(--color-primary);
}
.user-name { font-size: var(--text-sm); color: var(--color-text); font-weight: 500; max-width: 100px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.sidebar-user { padding: 4px 12px; font-size: var(--text-xs); }

/* ---- Header Overflow Menu ---- */
.header-overflow { position: relative; }
.header-overflow-menu {
  display: none; position: absolute; top: 100%; right: 0; margin-top: 4px;
  background: var(--color-surface); border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
  z-index: 150; min-width: 170px; padding: 4px 0;
  animation: fadeIn 0.1s ease-out;
}
.header-overflow-menu.show { display: block; }
.overflow-item {
  display: block; width: 100%; text-align: left;
  padding: 8px 14px; background: none; border: none;
  color: var(--color-text-dim); font-family: var(--font-body);
  font-size: var(--text-sm); font-weight: 500;
  cursor: pointer; transition: background var(--transition-fast);
}
.overflow-item:hover { background: var(--color-surface-hover); color: var(--color-text); }

/* ============================================================
   UI Component Library Styles
   ============================================================ */

/* ---- Badge Component ---- */
.badge {
  display: inline-flex; align-items: center;
  padding: 2px 8px; border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: 600;
  white-space: nowrap; line-height: 1.4;
}
.badge-md { padding: 4px 12px; font-size: var(--text-sm); }
.badge-default { background: var(--color-surface-border); color: var(--color-text-dim); }
.badge-success { background: var(--color-success-dim); color: var(--color-success); }
.badge-warning { background: var(--color-warning-dim); color: var(--color-warning); }
.badge-danger { background: var(--color-danger-dim); color: var(--color-danger); }
.badge-info { background: var(--color-info-dim); color: var(--color-info); }
.badge-accent { background: var(--color-accent-dim); color: var(--color-accent); }
.badge-muted { background: var(--color-surface); color: var(--color-muted); }

/* ---- Stat Card Component ---- */
.stat-card {
  text-align: center; padding: 16px;
}
.stat-card-value {
  font-family: var(--font-display);
  font-size: 28px; font-weight: 700;
  color: var(--color-text-heading);
  line-height: 1.2; margin-bottom: 4px;
}
.stat-card-label {
  font-size: var(--text-xs); color: var(--color-muted);
  text-transform: uppercase; letter-spacing: 0.8px; font-weight: 600;
}
.stat-card-sublabel { font-size: 11px; color: var(--color-muted); margin-top: 2px; }
.stat-grid {
  display: grid; gap: 1px;
  background: var(--color-surface-border);
  border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.stat-grid .stat-card { background: var(--color-surface); }

/* ---- UI Card Component ---- */
.ui-card {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.ui-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--color-surface-border);
  gap: 12px;
}
.ui-card-header h3 {
  font-size: var(--text-base); font-weight: 600;
  color: var(--color-text-heading); margin: 0; letter-spacing: 0; text-transform: none;
}
.ui-card-header .subtitle { font-size: var(--text-xs); color: var(--color-muted); margin-top: 2px; }
.ui-card-body { padding: 18px; }
.ui-card-footer { padding: 12px 18px; border-top: 1px solid var(--color-surface-border); }

/* ---- Progress Bar Component ---- */
.ui-progress { width: 100%; }
.ui-progress-track {
  background: var(--color-surface-border);
  border-radius: var(--radius-full); overflow: hidden;
}
.ui-progress-track-sm { height: 4px; }
.ui-progress-track-md { height: 8px; }
.ui-progress-track-lg { height: 12px; }
.ui-progress-fill {
  height: 100%; border-radius: var(--radius-full);
  background: var(--color-primary);
  transition: width 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.ui-progress-meta {
  display: flex; justify-content: space-between;
  font-size: var(--text-xs); color: var(--color-muted); margin-top: 4px;
}

/* ---- Button press enhancement ---- */
.btn:active { transform: scale(0.95); transition: transform 0.08s; }

/* ---- Skip to content (a11y) ---- */
.skip-link {
  position: absolute; top: -50px; left: 12px;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-bright));
  color: #1a1a1e;
  padding: 8px 16px; border-radius: var(--radius-md);
  font-weight: 700; font-size: var(--text-sm);
  z-index: 10000; transition: top 0.2s;
  box-shadow: var(--shadow-lg);
}
.skip-link:focus { top: 8px; }

/* ---- Screen reader only ---- */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); border: 0;
}

/* ============================================================
   View Tabs Component
   ============================================================ */
.view-tabs {
  display: flex;
  border: 1px solid var(--color-surface-border);
  background: var(--color-surface-glass);
  border-radius: 999px;
  padding: 4px;
  margin-bottom: 20px;
  gap: 4px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.view-tab {
  padding: 10px 18px;
  background: none;
  border: none;
  border-radius: 999px;
  color: var(--color-text-dim);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--transition-fast);
}
.view-tab:hover {
  color: var(--color-text);
  background: var(--color-surface-glass-strong);
}
.view-tab:focus-visible {
  outline: 2px solid rgba(196, 123, 58, 0.45);
  outline-offset: 2px;
}
.view-tab.active {
  color: var(--color-text-heading);
  background: linear-gradient(135deg, var(--color-primary-dim), var(--color-surface-glass-strong));
  box-shadow: inset 0 0 0 1px rgba(196, 123, 58, 0.12);
}
.tab-content {
  animation: fadeIn 0.15s ease-out;
}
.tab-content.hidden {
  display: none !important;
}
.section-shell { display: grid; gap: 18px; }
.section-hero {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--color-primary-border);
  border-radius: var(--radius-2xl);
  background:
    radial-gradient(circle at top right, rgba(196, 123, 58, 0.1), transparent 28%),
    var(--color-surface-gradient);
  box-shadow: var(--shadow-sm);
}
.section-intro {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 4px;
  flex-wrap: wrap;
}
.section-title-row { display: grid; gap: 4px; }
.eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.section-copy {
  max-width: 720px;
  color: var(--color-text-dim);
  font-size: var(--text-sm);
}
.action-cluster {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.glance-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.glance-card {
  padding: 16px;
  border-radius: 16px;
  border: 1px solid var(--color-surface-border);
  background: var(--color-surface-glass);
}
.glance-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-subtle);
}
.glance-value {
  margin-top: 8px;
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 700;
  color: var(--color-text-heading);
}
.glance-copy {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.55;
  color: var(--color-text-dim);
}
.quick-switcher {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.metric-card {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid var(--color-surface-border);
  background: var(--color-surface-gradient);
  box-shadow: var(--shadow-sm);
}
.metric-value {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 700;
  line-height: 1;
  color: var(--color-text-heading);
}
.metric-label {
  margin-top: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-subtle);
}
.metric-detail {
  margin-top: 6px;
  font-size: 12px;
  color: var(--color-text-dim);
}
.list-stack {
  display: grid;
  gap: 10px;
}
.list-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--color-surface-gradient);
  border: 1px solid var(--color-surface-border);
  border-radius: 14px;
}
.list-item-title {
  font-weight: 600;
  color: var(--color-text-heading);
}
.list-item-meta {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.inline-form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: flex-end;
}
.field-group {
  display: grid;
  gap: 6px;
  min-width: 140px;
  flex: 1 1 180px;
}
.field-group.compact {
  flex: 0 1 160px;
}
.surface-inline {
  padding: 16px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-surface-border);
  background: var(--color-surface-glass);
}
.status-note {
  font-size: 13px;
  color: var(--color-text-dim);
}
.compare-picker {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-lg);
  padding: 10px;
  background: var(--color-surface-glass);
}
.compare-picker label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 12px;
  cursor: pointer;
}
.compare-picker label:hover {
  background: var(--color-bg-secondary);
}
.kanban-col {
  background: var(--color-surface-glass-soft);
  border: 1px solid var(--color-surface-border);
  border-radius: var(--radius-lg);
  padding: 12px;
  min-height: 200px;
}
.kanban-col-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-surface-border);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-subtle);
}
.drop {
  min-height: 120px;
}
.empty-inline {
  padding: 18px;
  border: 1px dashed var(--color-surface-border);
  border-radius: var(--radius-lg);
  color: var(--color-text-dim);
  text-align: center;
  background: var(--color-surface-glass-soft);
}
.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}
.table-job-cell {
  display: grid;
  gap: 6px;
}
.fit-inline,
.fit-summary-row,
.fit-chip-row {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.fit-summary-row .muted {
  font-size: 12px;
}
.fit-grade {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid transparent;
}
.fit-grade-a {
  background: rgba(45, 139, 95, 0.12);
  color: var(--color-success);
  border-color: rgba(45, 139, 95, 0.22);
}
.fit-grade-b,
.fit-grade-c {
  background: rgba(196, 123, 58, 0.12);
  color: var(--color-primary);
  border-color: rgba(196, 123, 58, 0.22);
}
.fit-grade-d,
.fit-grade-e,
.fit-grade-f {
  background: rgba(220, 53, 69, 0.1);
  color: var(--color-danger);
  border-color: rgba(220, 53, 69, 0.18);
}
.chip-strong {
  background: var(--color-success-dim);
  color: var(--color-success);
  border-color: rgba(45, 139, 95, 0.14);
}
.chip-risk {
  background: var(--color-danger-dim);
  color: var(--color-danger);
  border-color: rgba(220, 53, 69, 0.14);
}
.story-card,
.prep-card,
.draft-output {
  border: 1px solid var(--color-surface-border);
  border-radius: 16px;
  background: var(--color-surface-glass);
  padding: 16px;
}
.story-card {
  display: grid;
  gap: 10px;
}
.story-meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.story-grid {
  display: grid;
  gap: 8px;
}
.story-grid strong,
.prep-card strong {
  color: var(--color-text-heading);
}
.prep-list {
  display: grid;
  gap: 6px;
  padding-left: 18px;
}
.draft-output textarea,
.draft-output pre {
  width: 100%;
  min-height: 180px;
  border: 0;
  background: transparent;
  resize: vertical;
  color: var(--color-text);
  font: inherit;
  white-space: pre-wrap;
}
