* { box-sizing: border-box; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  margin: 0; padding: 0; background: #f5f7fa; color: #1a202c;
}
.topbar {
  background: linear-gradient(135deg, #ff8fab 0%, #fb6f92 100%);
  color: white; padding: 14px 24px;
  display: flex; justify-content: space-between; align-items: center;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}
.topbar .brand { font-size: 1.3em; font-weight: 600; }
.topbar nav a { color: white; text-decoration: none; margin-left: 16px; }
.topbar nav .logout-btn {
  margin-left: 16px; background: transparent; color: white; border: 1px solid rgba(255,255,255,0.4);
  padding: 6px 14px; border-radius: 6px; cursor: pointer; font-size: 0.85em;
}
.topbar nav .logout-btn:hover { background: rgba(255,255,255,0.15); }

main { max-width: 1100px; margin: 24px auto; padding: 0 16px; }

.card {
  background: white; border-radius: 12px; padding: 20px;
  margin-bottom: 20px; box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.card h2 { margin: 0 0 14px; font-size: 1.15em; color: #2d3748; }
.card h3 { margin: 16px 0 8px; font-size: 1em; color: #4a5568; }

.banner { padding: 10px 14px; border-radius: 8px; margin-bottom: 16px; font-size: 0.95em; }
.banner.ok { background: #d4edda; color: #155724; border-left: 4px solid #28a745; }
.banner.err { background: #f8d7da; color: #721c24; border-left: 4px solid #dc3545; }

.row { display: flex; gap: 16px; margin-bottom: 14px; }
.col { flex: 1; }
label { display: block; margin-bottom: 6px; font-size: 0.9em; color: #4a5568; font-weight: 500; }
input[type=text], select, textarea {
  width: 100%; padding: 8px 10px; border: 1px solid #cbd5e0;
  border-radius: 6px; font-size: 0.95em; font-family: inherit;
}
textarea { font-family: ui-monospace, "Cascadia Mono", monospace; resize: vertical; }
button {
  padding: 8px 16px; border: 1px solid #cbd5e0; background: white;
  border-radius: 6px; cursor: pointer; font-size: 0.95em;
}
button:hover { background: #edf2f7; }
button.primary { background: #fb6f92; color: white; border-color: #fb6f92; padding: 10px 22px; font-weight: 600; }
button.primary:hover { background: #f4537d; }
button.del { background: transparent; color: #c53030; padding: 2px 8px; border: none; font-weight: 600; }

.folders-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.bookmark-list { list-style: none; padding: 0; margin: 0 0 12px; }
.bookmark-list li {
  display: flex; align-items: center; gap: 10px; padding: 8px 10px;
  background: #f7fafc; border-radius: 6px; margin-bottom: 4px;
}
.bookmark-list .name { font-weight: 500; }
.bookmark-list .id { font-family: ui-monospace, monospace; font-size: 0.82em; color: #718096; flex: 1; }

.add-form { display: flex; gap: 6px; margin-top: 8px; }
.add-form input { flex: 1; }
.add-form button { white-space: nowrap; }

.muted { color: #a0aec0; font-style: italic; }

label.sub { font-size: 0.85em; color: #718096; margin-top: 4px; }
.batch-row { gap: 12px; }
.batch-row textarea { font-size: 0.88em; }

.jobs { width: 100%; border-collapse: collapse; font-size: 0.9em; }
.jobs th, .jobs td { text-align: left; padding: 8px 10px; border-bottom: 1px solid #e2e8f0; }
.jobs th { background: #f7fafc; font-weight: 600; color: #4a5568; }
.jobs code { font-size: 0.85em; color: #718096; }
.jobs .err { color: #c53030; }

.badge {
  display: inline-block; padding: 2px 10px; border-radius: 10px;
  font-size: 0.78em; font-weight: 600; text-transform: uppercase;
}
.badge.pending { background: #e2e8f0; color: #4a5568; }
.badge.scraping { background: #fef5e7; color: #c05621; }
.badge.uploading_tq, .badge.uploading_vn { background: #ebf8ff; color: #2b6cb0; }
.badge.localizing { background: #faf5ff; color: #6b46c1; }
.badge.describing { background: #f0fff4; color: #2f855a; }
.badge.done { background: #d4edda; color: #155724; }
.badge.failed { background: #f8d7da; color: #721c24; }

footer {
  text-align: center; padding: 20px; color: #a0aec0; font-size: 0.85em;
}

@media (max-width: 768px) {
  .row, .folders-grid { grid-template-columns: 1fr; flex-direction: column; }
}
