/* ════════════════════════════════════════════
   Change Job + Job View (v3.20)
   ════════════════════════════════════════════ */
.cj-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.cj-cell {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 8px;
  cursor: pointer;
  transition: all var(--t-fast);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
}
.cj-cell input[type="radio"] { display: none; }
.cj-cell.selected,
.cj-cell:has(input:checked) {
  border-color: var(--c-gold);
  background: rgba(200,160,60,0.08);
  box-shadow: 0 0 0 1px var(--c-gold-dim);
}
.cj-name {
  font-size: 0.85em;
  color: var(--c-gold);
  font-weight: bold;
}
.cj-desc {
  font-size: 0.7em;
  color: var(--c-text-dim);
}

/* Job View 列表 */
.job-view { padding: 4px 0; }
.job-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 380px;
  overflow-y: auto;
}
.job-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 9px 11px;
}
.job-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}
.job-name {
  font-size: 0.86em;
  color: var(--c-gold);
  font-weight: bold;
}
.job-pro {
  font-size: 0.72em;
  color: var(--c-text-dim);
}
.job-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 10px;
  font-size: 0.7em;
  color: var(--c-text-dim);
  margin-bottom: 6px;
}
.job-stats b { color: var(--c-text); font-weight: normal; }
.job-actions {
  display: flex;
  gap: 6px;
}
.job-setup-btn, .job-skill-btn {
  flex: 1;
  border-radius: var(--r-sm);
  padding: 6px 4px;
  font-size: 0.76em;
  font-family: var(--font);
  cursor: pointer;
  border: 1px solid var(--c-border);
}
.job-setup-btn {
  background: var(--c-surface2);
  color: var(--c-text);
}
.job-setup-btn:active { background: var(--c-surface3); }
.job-skill-btn {
  background: linear-gradient(135deg, #5a3070, #8050a0);
  color: #fff;
  border: none;
  font-weight: bold;
}
.job-skill-btn:disabled {
  background: var(--c-surface3);
  color: var(--c-text-faint);
  cursor: not-allowed;
  font-weight: normal;
}
.job-skill-btn:active:not(:disabled) { opacity: 0.85; }

/* ════════════════════════════════════════════
   Pet / Mail / Mission / Rbid (v3.21)
   ════════════════════════════════════════════ */
.pet-shop, .mission-shop, .rbid-shop { padding: 4px 0; }

.pet-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 10px 12px;
  margin-bottom: 8px;
}
.pet-card-name {
  font-size: 0.95em;
  color: var(--c-gold);
  font-weight: bold;
  margin-bottom: 8px;
}
.pet-card-mname {
  font-size: 0.78em;
  color: var(--c-text-dim);
  font-weight: normal;
}
.pet-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 12px;
  font-size: 0.78em;
}
.pet-stats-grid > div { display: flex; justify-content: space-between; padding: 2px 0; }
.pet-stats-grid span { color: var(--c-text-faint); }
.pet-stats-grid b { color: var(--c-text); font-weight: normal; }

.pet-actions {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
  margin-bottom: 6px;
}
.pet-switch.selected {
  border-color: var(--c-gold);
  background: rgba(200,160,60,0.08);
}

/* 任務 */
.mission-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 8px;
  max-height: 350px;
  overflow-y: auto;
}
.mission-item {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 9px 12px;
  cursor: pointer;
  transition: all var(--t-fast);
}
.mission-item:active {
  background: var(--c-surface2);
  border-color: var(--c-gold-dim);
}
.mission-meta {
  font-size: 0.7em;
  color: var(--c-text-faint);
  margin-bottom: 3px;
}
.mission-title {
  font-size: 0.86em;
  color: var(--c-gold);
  font-weight: bold;
}

.mission-detail-box {
  background: var(--c-surface);
  border: 1px solid rgba(200,160,60,0.4);
  border-radius: var(--r-md);
  padding: 12px;
  margin-bottom: 10px;
}
.mission-detail-title {
  font-size: 1em;
  color: var(--c-gold);
  font-weight: bold;
  margin-bottom: 4px;
}
.mission-detail-meta {
  font-size: 0.72em;
  color: var(--c-text-faint);
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--c-border);
}
.mission-detail-body {
  font-size: 0.82em;
  color: var(--c-text);
  line-height: 1.6;
  white-space: pre-wrap;
  max-height: 360px;
  overflow-y: auto;
}
.mission-actions {
  display: flex;
  gap: 8px;
}
.mission-pg-btn {
  background: var(--c-surface2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  color: var(--c-text-dim);
  font-size: 0.75em;
  font-family: var(--font);
  padding: 6px 10px;
  cursor: pointer;
}
.mission-pg-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* 拍賣 */
.rbid-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 8px;
  max-height: 380px;
  overflow-y: auto;
}
.rbid-item {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 9px 11px;
}
.rbid-status-1 {
  border-color: rgba(50,160,80,0.5);
  background: rgba(50,160,80,0.06);
}
.rbid-status-0 { opacity: 0.7; }
.rbid-status-2 { opacity: 0.5; }
.rbid-status-3 { opacity: 0.45; filter: grayscale(0.4); }
/* v3.75: 貨幣 chip */
.rbid-currency-row {
  margin: 4px 0 6px;
}
.rbid-currency-chip {
  display: inline-block;
  padding: 2px 9px;
  font-size: 0.72em;
  font-weight: 600;
  color: #ffd862;
  background: rgba(224, 185, 79, 0.12);
  border: 1px solid rgba(224, 185, 79, 0.45);
  border-radius: 10px;
}
.rbid-item-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 5px;
}
.rbid-name {
  font-size: 0.86em;
  color: var(--c-gold);
  font-weight: bold;
}
.rbid-status {
  font-size: 0.72em;
  padding: 2px 7px;
  border-radius: 8px;
  background: var(--c-surface3);
  color: var(--c-text-dim);
}
.rbid-status-1 .rbid-status {
  background: rgba(50,160,80,0.3);
  color: #80d880;
}
.rbid-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 10px;
  font-size: 0.7em;
  color: var(--c-text-dim);
}
.rbid-stats b { color: var(--c-text); font-weight: normal; }
.rbid-meta {
  font-size: 0.7em;
  color: var(--c-text-faint);
  margin-top: 4px;
}

