/* ── Editor Screen ─────────────────────────── */
.editor-screen {
  display: flex; flex-direction: column;
  height: 100%; background: var(--bg);
}
.editor-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px;
  border-bottom: 3px solid var(--ink);
  background: var(--bg2);
  flex-shrink: 0;
}
.editor-header h2 { margin: 0; font-size: 1.6rem; }
.editor-header .btn { font-size: 1rem; padding: 6px 14px; }
.editor-io-btns { display: flex; gap: 8px; }

/* ── Tabs ──────────────────────────────────── */
.editor-tabs {
  display: flex; gap: 0;
  border-bottom: 3px solid var(--ink);
  background: var(--bg2);
  flex-shrink: 0;
  overflow-x: auto;
}
.editor-tab {
  font-family: var(--font);
  font-size: 1.2rem; font-weight: 700;
  padding: 10px 20px;
  background: none; border: none;
  cursor: pointer; color: var(--ink-light);
  border-bottom: 3px solid transparent;
  margin-bottom: -3px;
  transition: color 0.15s, border-color 0.15s;
  white-space: nowrap;
}
.editor-tab:hover { color: var(--ink); }
.editor-tab.active {
  color: var(--blue);
  border-bottom-color: var(--blue);
}

/* ── Content Area ─────────────────────────── */
.editor-content {
  flex: 1; overflow-y: auto;
  padding: 16px;
}

/* ── Item List ────────────────────────────── */
.editor-list {
  display: flex; flex-direction: column; gap: 8px;
  margin-bottom: 16px;
}
.editor-item {
  display: flex; align-items: center; gap: 10px;
  background: var(--panel-bg);
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  padding: 8px 12px;
  cursor: pointer;
  transition: transform 0.1s, box-shadow 0.1s;
}
.editor-item:hover {
  transform: translate(-1px, -1px);
  box-shadow: 2px 3px 0 var(--ink);
}
.editor-item .item-emoji { font-size: 1.6rem; flex-shrink: 0; }
.editor-item .item-info { flex: 1; min-width: 0; }
.editor-item .item-name { font-size: 1.1rem; font-weight: 700; }
.editor-item .item-sub { font-size: 0.85rem; color: var(--ink-light); }
.editor-item .item-badge {
  font-size: 0.7rem; padding: 2px 6px;
  border-radius: 4px; border: 1px solid var(--ink-light);
  color: var(--ink-light); flex-shrink: 0;
}
.editor-item .item-badge.custom {
  background: #e8f4fd; border-color: var(--blue); color: var(--blue);
}
.editor-item-btns { display: flex; gap: 6px; flex-shrink: 0; }
.editor-item-btns .btn {
  font-size: 0.9rem; padding: 4px 10px;
}

/* ── Form / Edit Panel ────────────────────── */
.editor-form-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 60;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.editor-form {
  background: var(--panel-bg);
  border: 3px solid var(--ink);
  border-radius: 8px;
  box-shadow: 4px 4px 0 var(--ink);
  padding: 20px;
  max-width: 520px; width: 100%;
  max-height: 85vh; overflow-y: auto;
}
.editor-form h3 {
  margin: 0 0 16px; font-size: 1.5rem;
  border-bottom: 2px solid var(--ink);
  padding-bottom: 8px;
}

/* ── Form Fields ──────────────────────────── */
.ef-row {
  display: flex; gap: 10px; margin-bottom: 12px;
  align-items: center; flex-wrap: wrap;
}
.ef-field { display: flex; flex-direction: column; gap: 3px; }
.ef-field.grow { flex: 1; min-width: 120px; }
.ef-label {
  font-size: 0.85rem; font-weight: 700;
  color: var(--ink-light);
}
.ef-input, .ef-select {
  font-family: var(--font);
  font-size: 1.1rem;
  padding: 6px 10px;
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  background: var(--card-bg);
  color: var(--ink);
  outline: none;
}
.ef-input:focus, .ef-select:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 2px rgba(36,113,163,0.2);
}
.ef-input[type="number"] { width: 70px; }
.ef-input[type="color"] {
  width: 44px; height: 36px; padding: 2px;
  cursor: pointer;
}
.ef-input.emoji-input { width: 60px; text-align: center; font-size: 1.4rem; }

/* ── Action Builder ───────────────────────── */
.action-builder {
  border: 2px dashed var(--ink-light);
  border-radius: var(--radius);
  padding: 10px;
  margin-bottom: 12px;
  background: rgba(0,0,0,0.02);
}
.action-builder-title {
  font-size: 0.9rem; font-weight: 700;
  color: var(--ink-light); margin-bottom: 8px;
}
.action-row {
  display: flex; gap: 6px; align-items: center;
  margin-bottom: 6px; flex-wrap: wrap;
  padding: 6px 8px;
  background: var(--card-bg);
  border: 1px solid var(--ink);
  border-radius: 4px;
}
.action-row .ef-select,
.action-row .ef-input {
  font-size: 0.95rem; padding: 4px 6px;
}
.action-row .ef-input[type="number"] { width: 55px; }
.action-row .btn-remove {
  font-size: 0.85rem; padding: 2px 8px;
  background: #fde8e8; border: 2px solid var(--red);
  color: var(--red); border-radius: 4px;
  cursor: pointer; font-family: var(--font); font-weight: 700;
}
.action-row .btn-remove:hover { background: var(--red); color: #fff; }
.btn-add-action {
  font-family: var(--font);
  font-size: 0.95rem; font-weight: 700;
  padding: 6px 14px;
  background: #e8f4fd; border: 2px dashed var(--blue);
  color: var(--blue); border-radius: 4px;
  cursor: pointer; width: 100%; margin-top: 4px;
}
.btn-add-action:hover { background: var(--blue); color: #fff; }

/* ── Description Preview ──────────────────── */
.desc-preview {
  font-size: 0.95rem;
  color: var(--ink-light);
  padding: 8px;
  background: rgba(0,0,0,0.03);
  border-radius: 4px;
  margin-bottom: 12px;
  min-height: 24px;
  border-left: 3px solid var(--blue);
}

/* ── Card Preview ─────────────────────────── */
.card-preview-wrap {
  display: flex; justify-content: center;
  margin: 12px 0;
}

/* ── Deck Builder (for characters) ────────── */
.deck-builder {
  border: 2px dashed var(--ink-light);
  border-radius: var(--radius);
  padding: 10px; margin-bottom: 12px;
}
.deck-grid {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.deck-chip {
  font-family: var(--font);
  font-size: 0.95rem; font-weight: 700;
  padding: 4px 10px;
  border: 2px solid var(--ink);
  border-radius: 20px;
  background: var(--card-bg);
  cursor: pointer;
  transition: transform 0.1s;
  display: flex; align-items: center; gap: 4px;
}
.deck-chip:hover { transform: scale(1.05); }
.deck-chip.in-deck { background: #e8f4fd; border-color: var(--blue); }
.deck-chip .chip-count {
  background: var(--blue); color: #fff;
  border-radius: 50%; width: 20px; height: 20px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 0.75rem;
  cursor: pointer;
  transition: background 0.15s;
}
.deck-chip .chip-count:hover {
  background: var(--red);
}

/* ── Encounter Builder ────────────────────── */
.encounter-group {
  margin-bottom: 16px;
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  padding: 12px;
  background: var(--panel-bg);
}
.encounter-group h4 {
  margin: 0 0 8px; font-size: 1.2rem;
}
.encounter-wave {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 6px; flex-wrap: wrap;
  padding: 6px; background: var(--card-bg);
  border: 1px solid var(--ink); border-radius: 4px;
}
.encounter-wave .enemy-chip {
  font-family: var(--font);
  font-size: 0.9rem; font-weight: 700;
  padding: 2px 8px;
  border: 2px solid var(--ink);
  border-radius: 4px;
  background: #fde8e8;
  cursor: pointer;
}
.encounter-wave .enemy-chip:hover {
  text-decoration: line-through; opacity: 0.6;
}

/* ── Reward Pool ──────────────────────────── */
.reward-pool-grid {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 8px;
}
.reward-check {
  display: flex; align-items: center; gap: 4px;
  font-size: 0.95rem; cursor: pointer;
  padding: 4px 8px;
  border: 2px solid var(--ink);
  border-radius: 4px;
  background: var(--card-bg);
}
.reward-check.checked { background: #e8f4fd; border-color: var(--blue); }
.reward-check input { display: none; }

/* ── Form Buttons ─────────────────────────── */
.ef-buttons {
  display: flex; gap: 10px; margin-top: 16px;
  justify-content: flex-end;
}

/* ── Responsive ───────────────────────────── */
@media (max-width: 480px) {
  .editor-form { padding: 14px; max-height: 90vh; }
  .ef-row { flex-direction: column; align-items: stretch; }
  .ef-input[type="number"] { width: 100%; }
  .editor-tab { padding: 8px 12px; font-size: 1rem; }
}
