/*
 * crafting_manager.css - Crafting Manager UI
 * Author:    Steven J. Cook (Shinra.Engineer)
 * Date:      2026-05-07
 * Time:      06:25 UTC
 * Model:     Claude Opus 4.7 (1M context)
 * Project:   Abyssal Engine
 * Chat:      Prod-push staging + verbatim/gating audit
 * Revision:  1.1.0
 *
 * v1.1.0:    Spheres + Seeds builder styling. New rules for
 *            .cm-card-sphere, .cm-card-seed, .cm-tier-summary,
 *            .cm-tier-row family, .cm-tag-ok / .cm-tag-bad
 *            badges, the .ss-tier-row editor modal rows, and
 *            the .cm-tag-legend reference details element.
 *            Mobile-tweak block extended for the new rows.
 *            Pairs with crafting_manager.js v2.1.0.
 *
 * v1.0.0:    Phase 5 rollout. Pairs with crafting_manager.js
 *            v2.0.0 which pivots the manager from a name+notes
 *            bookkeeping list into a live tracker with rollable
 *            checks, project clocks, benefit pickers, and an
 *            inventory-handoff path.
 *
 * Style notes:
 *   * All component classes are prefixed cm-* (or ss-* for
 *     sphere/seed-specific editor rows) so the cog cannot
 *     collide with sheet, equipment, or inventory styling.
 *   * Modal overlays use z-index 11000 to match the technosphere
 *     and garden modal stack established in Phase 3 / Phase 4.
 *   * Color palette per category:
 *       Recipes               = amber  (#f0b232)
 *       Blueprints / Formulas = cyan   (#5fb6c5)
 *       Spheres               = cyan   (Hoplo + Mnemo)
 *       Seeds                 = green  (#79e9a3)
 *       Ingredients/Materials = green
 *   * Card layout is flex-column with a fixed head, body, and
 *     foot so cards align across categories even when content
 *     length varies.
 */

/* ============================================================
 * ROOT + TOP BAR
 * ============================================================ */

.cm-root {
  padding: 0.5em 0.25em;
  max-width: 1100px;
  margin: 0 auto;
}

.cm-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1em;
  flex-wrap: wrap;
  gap: 0.5em;
}

.cm-title {
  margin: 0;
  font-family: var(--font-display, 'Cinzel', serif);
}

.cm-active-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  margin-left: 0.6em;
  padding: 0.2em 0.55em;
  font-size: 0.55em;
  font-family: var(--font-code, monospace);
  font-weight: 400;
  color: var(--accent-blue, #5865f2);
  background: rgba(88, 101, 242, 0.08);
  border: 1px solid rgba(88, 101, 242, 0.25);
  border-radius: 4px;
  letter-spacing: 0.04em;
  text-transform: none;
}

/* ============================================================
 * SECTIONS
 * ============================================================ */

.cm-section {
  margin-bottom: 1.5em;
  padding: 0.75em;
  background: var(--bg-dark, #2b2d31);
  border: 1px solid var(--border-thin, rgba(255,255,255,0.06));
  border-radius: var(--radius-md, 8px);
}

.cm-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75em;
  flex-wrap: wrap;
  gap: 0.5em;
}

.cm-section-title {
  margin: 0;
  font-family: var(--font-display, 'Cinzel', serif);
  font-size: 1.05em;
  letter-spacing: 0.03em;
}

.cm-count {
  margin-left: 0.4em;
  font-size: 0.78em;
  font-family: var(--font-code, monospace);
  color: var(--text-muted, #a8a9ad);
  font-weight: 400;
}

.cm-section-actions {
  display: flex;
  gap: 0.4em;
  flex-wrap: wrap;
}

.cm-ref-btn {
  color: var(--accent-cyan, #5fb6c5) !important;
}

/* Category accent icons */
.cm-icon-amber { color: var(--accent-amber, #f0b232); }
.cm-icon-cyan  { color: var(--accent-cyan,  #5fb6c5); }
.cm-icon-green { color: var(--accent-green, #79e9a3); }

/* ============================================================
 * EMPTY / NO-CHARACTER STATES
 * ============================================================ */

.cm-empty {
  padding: 1em 0.75em;
  text-align: center;
  background: var(--bg-darkest, #1e1f22);
  border: 1px dashed var(--border-thin, rgba(255,255,255,0.08));
  border-radius: var(--radius-sm, 4px);
  color: var(--text-faint, #6e7075);
  font-size: 0.9em;
}

.cm-no-char {
  padding: 2em 1em;
  text-align: center;
  background: var(--bg-darkest, #1e1f22);
  border: 1px dashed var(--border-thin, rgba(255,255,255,0.08));
  border-radius: var(--radius-md, 8px);
}

.cm-no-char-icon {
  font-size: 2em;
  color: var(--accent-blue, #5865f2);
  margin-bottom: 0.4em;
}

.cm-no-char h3 {
  margin: 0.3em 0;
  font-family: var(--font-display, 'Cinzel', serif);
}

.cm-no-char p {
  color: var(--text-muted, #a8a9ad);
  max-width: 520px;
  margin: 0.5em auto;
  line-height: 1.5;
}

.cm-legacy-note {
  color: var(--text-faint, #6e7075) !important;
  font-size: 0.85em !important;
  margin-top: 1em !important;
}

.cm-legacy-bar {
  margin-top: 1.5em;
  padding: 0.75em;
  background: var(--bg-darkest, #1e1f22);
  border: 1px dashed var(--accent-amber, #f0b232);
  border-radius: var(--radius-sm, 4px);
  text-align: center;
}

.cm-legacy-bar p {
  margin: 0 0 0.5em;
  font-size: 0.85em;
  color: var(--text-muted, #a8a9ad);
}

.cm-legacy-discard {
  color: var(--accent-amber, #f0b232) !important;
}

/* ============================================================
 * CARDS (Recipe, Blueprint, Formula)
 * ============================================================ */

.cm-card {
  display: flex;
  flex-direction: column;
  gap: 0.6em;
  margin-bottom: 0.6em;
  padding: 0.75em;
  background: var(--bg-darkest, #1e1f22);
  border: 1px solid var(--border-thin, rgba(255,255,255,0.06));
  border-left: 3px solid transparent;
  border-radius: var(--radius-sm, 4px);
  transition: border-color 0.15s ease, background 0.15s ease;
}

.cm-card:hover {
  background: rgba(0, 0, 0, 0.18);
}

.cm-card-recipe    { border-left-color: var(--accent-amber, #f0b232); }
.cm-card-blueprint { border-left-color: var(--accent-cyan,  #5fb6c5); }
.cm-card-formula   { border-left-color: var(--accent-cyan,  #5fb6c5); }

.cm-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.5em;
}

.cm-card-title-row {
  display: flex;
  align-items: center;
  gap: 0.5em;
  flex-wrap: wrap;
}

.cm-card-title {
  margin: 0;
  font-family: var(--font-display, 'Cinzel', serif);
  font-size: 1em;
  font-weight: 700;
  color: var(--text-primary, #f2f3f5);
}

.cm-card-actions {
  display: flex;
  gap: 0.25em;
  flex-shrink: 0;
}

.cm-btn-danger { color: var(--accent-red, #ed4245) !important; }

.cm-card-notes {
  margin: 0;
  font-size: 0.85em;
  line-height: 1.45;
  color: var(--text-secondary, #cfd0d4);
}

.cm-card-flavor {
  margin: 0;
  padding: 0.4em 0.6em;
  font-size: 0.85em;
  font-style: italic;
  line-height: 1.45;
  color: var(--text-muted, #a8a9ad);
  background: rgba(255, 255, 255, 0.025);
  border-radius: var(--radius-sm, 4px);
}

.cm-card-foot {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.5em;
  flex-wrap: wrap;
  padding-top: 0.5em;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.cm-card-hint {
  font-size: 0.78em;
  color: var(--text-faint, #6e7075);
  font-style: italic;
  margin-right: auto;
}

.cm-generated-marker {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  font-size: 0.78em;
  color: var(--accent-green, #79e9a3);
  margin-right: auto;
}

/* ============================================================
 * STATUS BADGES
 * ============================================================ */

.cm-status {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  padding: 0.18em 0.55em;
  font-size: 0.7em;
  font-family: var(--font-display, 'Cinzel', serif);
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 4px;
  border: 1px solid;
}

.cm-status-planned {
  color: var(--text-muted, #a8a9ad);
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.12);
}

.cm-status-cooked {
  color: var(--accent-green, #79e9a3);
  background: rgba(121, 233, 163, 0.1);
  border-color: rgba(121, 233, 163, 0.4);
}

.cm-status-progress {
  color: var(--accent-amber, #f0b232);
  background: rgba(240, 178, 50, 0.1);
  border-color: rgba(240, 178, 50, 0.4);
}

.cm-status-finished {
  color: var(--accent-cyan, #5fb6c5);
  background: rgba(95, 182, 197, 0.1);
  border-color: rgba(95, 182, 197, 0.4);
}

.cm-status-formula {
  color: var(--accent-cyan, #5fb6c5);
  background: rgba(95, 182, 197, 0.08);
  border-color: rgba(95, 182, 197, 0.3);
  font-family: var(--font-code, monospace);
  letter-spacing: 0.04em;
}

/* ============================================================
 * STAT ROW (roll button + status text inline)
 * ============================================================ */

.cm-stat-row {
  display: flex;
  align-items: center;
  gap: 0.6em;
  flex-wrap: wrap;
}

.cm-roll-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  padding: 0.4em 0.8em;
  background: rgba(88, 101, 242, 0.08);
  border: 1px solid rgba(88, 101, 242, 0.3);
  border-radius: var(--radius-sm, 4px);
  color: var(--accent-blue, #5865f2);
  font-family: var(--font-display, 'Cinzel', serif);
  font-size: 0.85em;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cm-roll-btn:hover {
  background: rgba(88, 101, 242, 0.16);
  border-color: rgba(88, 101, 242, 0.6);
  color: #8c97ff;
}

.cm-attr-pair {
  font-family: var(--font-code, monospace);
  font-size: 0.85em;
  letter-spacing: 0.05em;
  color: var(--accent-cyan, #5fb6c5);
}

/* ============================================================
 * RECIPE-SPECIFIC
 * ============================================================ */

.cm-recipe-picks {
  flex: 1;
  font-size: 0.85em;
  color: var(--text-secondary, #cfd0d4);
}

.cm-picks-none   { color: var(--text-faint, #6e7075); font-style: italic; }
.cm-picks-bad    { color: var(--accent-red, #ed4245); }
.cm-picks-ok     { color: var(--text-secondary, #cfd0d4); }
.cm-picks-great  { color: var(--accent-green, #79e9a3); }

.cm-recipe-benefits {
  padding: 0.5em 0.6em;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: var(--radius-sm, 4px);
}

.cm-benefits-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.4em;
  font-size: 0.8em;
  letter-spacing: 0.03em;
}

.cm-benefit-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3em;
}

.cm-benefit-tag {
  padding: 0.2em 0.5em;
  font-size: 0.78em;
  font-weight: 600;
  border-radius: 4px;
  border: 1px solid;
}

.cm-tag-std {
  color: #b6f0c5;
  background: rgba(87, 242, 135, 0.08);
  border-color: rgba(87, 242, 135, 0.3);
}

.cm-tag-gourmet {
  color: #ffd479;
  background: rgba(240, 178, 50, 0.1);
  border-color: rgba(240, 178, 50, 0.4);
}

.cm-benefit-empty {
  font-size: 0.8em;
  color: var(--text-faint, #6e7075);
  font-style: italic;
}

/* ============================================================
 * BLUEPRINT CLOCKS
 * ============================================================ */

.cm-clock-row {
  padding: 0.5em 0.6em;
  background: rgba(95, 182, 197, 0.04);
  border: 1px solid rgba(95, 182, 197, 0.15);
  border-radius: var(--radius-sm, 4px);
}

.cm-clock-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.4em;
  font-family: var(--font-display, 'Cinzel', serif);
  font-size: 0.78em;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--accent-cyan, #5fb6c5);
}

.cm-clock-fill {
  font-family: var(--font-code, monospace);
  font-size: 1em;
  font-weight: 700;
  color: var(--text-primary, #f2f3f5);
  letter-spacing: 0.04em;
}

.cm-clock-bar {
  height: 6px;
  background: rgba(0, 0, 0, 0.4);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 0.4em;
}

.cm-clock-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-cyan, #5fb6c5), var(--accent-blue, #5865f2));
  transition: width 0.25s ease;
}

.cm-clock-pips {
  display: flex;
  gap: 0.25em;
  flex-wrap: wrap;
}

.cm-clock-pip {
  width: 14px;
  height: 14px;
  background: rgba(0, 0, 0, 0.5);
  border: 1px solid rgba(95, 182, 197, 0.3);
  border-radius: 3px;
  transition: background 0.15s;
}

.cm-clock-pip-filled {
  background: var(--accent-cyan, #5fb6c5);
  border-color: var(--accent-cyan, #5fb6c5);
  box-shadow: 0 0 4px rgba(95, 182, 197, 0.5);
}

.cm-bp-summary {
  display: flex;
  flex: 1;
  flex-wrap: wrap;
  gap: 0.4em;
  justify-content: flex-end;
}

.cm-bp-summary-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  padding: 0.18em 0.5em;
  font-size: 0.75em;
  font-family: var(--font-code, monospace);
  color: var(--text-secondary, #cfd0d4);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  letter-spacing: 0.04em;
}

.cm-bp-log {
  margin-top: 0.3em;
  padding: 0.4em 0.6em;
  background: rgba(0, 0, 0, 0.2);
  border-radius: var(--radius-sm, 4px);
  font-size: 0.82em;
}

.cm-bp-log summary {
  cursor: pointer;
  font-family: var(--font-display, 'Cinzel', serif);
  font-size: 0.85em;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--text-secondary, #cfd0d4);
  outline: none;
}

.cm-bp-log summary:hover {
  color: var(--text-primary, #f2f3f5);
}

.cm-bp-log-list {
  margin: 0.5em 0 0;
  padding-left: 1.2em;
  list-style: disc;
  color: var(--text-secondary, #cfd0d4);
}

.cm-bp-log-list li {
  margin-bottom: 0.25em;
  line-height: 1.4;
}

.cm-bp-log-fail {
  color: var(--accent-red, #ed4245);
  font-weight: 700;
  letter-spacing: 0.04em;
}

/* ============================================================
 * SIMPLE LIST (Ingredients, Materials)
 * ============================================================ */

.cm-simple-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.cm-simple-row {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.45em 0.6em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
}

.cm-simple-info {
  flex: 1;
  min-width: 0;
}

.cm-simple-name {
  color: var(--text-primary, #f2f3f5);
  font-weight: 500;
  font-size: 0.95em;
}

.cm-simple-notes {
  font-size: 0.78em;
  color: var(--text-muted, #a8a9ad);
  margin-top: 0.15em;
}

.cm-simple-qty {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  padding: 0.15em 0.4em;
  background: rgba(0, 0, 0, 0.3);
  border-radius: var(--radius-sm, 4px);
}

.cm-qty-btn {
  width: 22px;
  height: 22px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 3px;
  color: var(--text-primary, #f2f3f5);
  font-family: var(--font-code, monospace);
  font-size: 0.95em;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}

.cm-qty-btn:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.3);
}

.cm-qty-num {
  min-width: 22px;
  text-align: center;
  font-family: var(--font-code, monospace);
  font-weight: 700;
  color: var(--text-primary, #f2f3f5);
}

/* ============================================================
 * MODAL OVERLAYS (picker, aux, reference)
 * z-index 11000 to match Phase 3 / Phase 4 stack.
 * ============================================================ */

.cm-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 11000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1em;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.cm-modal-box {
  width: 100%;
  max-width: 520px;
  max-height: 88vh;
  overflow-y: auto;
  padding: 1em 1.2em;
  background: var(--bg-medium, #313338);
  border: 1px solid var(--border-thick, rgba(255,255,255,0.12));
  border-radius: var(--radius-md, 8px);
  box-shadow: var(--shadow-high, 0 10px 30px rgba(0,0,0,0.4));
}

.cm-modal-wide { max-width: 720px; }

.cm-modal-box h3 {
  margin: 0 0 0.5em;
  font-family: var(--font-display, 'Cinzel', serif);
}

.cm-modal-sub {
  margin: 0 0 0.75em;
  color: var(--text-secondary, #cfd0d4);
  font-size: 0.9em;
  line-height: 1.5;
}

.cm-modal-foot {
  margin: 0.5em 0 0.75em;
  font-size: 0.8em;
  color: var(--text-muted, #a8a9ad);
  font-style: italic;
}

.cm-modal-form {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  margin-bottom: 0.75em;
}

.cm-form-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6em;
  padding: 0.4em 0.6em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
}

.cm-form-row span {
  font-size: 0.88em;
  color: var(--text-secondary, #cfd0d4);
}

.cm-form-row input {
  width: 100px;
  padding: 0.3em 0.5em;
  background: var(--bg-dark, #2b2d31);
  border: 1px solid var(--border-thin, rgba(255,255,255,0.1));
  border-radius: 4px;
  color: var(--text-primary, #f2f3f5);
  font-family: var(--font-code, monospace);
  text-align: right;
}

.cm-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5em;
  margin-top: 0.75em;
  padding-top: 0.75em;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

/* ============================================================
 * BENEFITS PICKER
 * ============================================================ */

.cm-picker-progress {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4em;
  margin-bottom: 0.75em;
  padding: 0.5em 0.6em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
}

.cm-progress-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2em 0.6em;
  font-size: 0.82em;
  font-family: var(--font-code, monospace);
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--accent-green, #79e9a3);
  background: rgba(121, 233, 163, 0.1);
  border: 1px solid rgba(121, 233, 163, 0.3);
  border-radius: 4px;
}

.cm-progress-gourmet {
  color: var(--accent-amber, #f0b232) !important;
  background: rgba(240, 178, 50, 0.1) !important;
  border-color: rgba(240, 178, 50, 0.35) !important;
}

.cm-pick-group-label {
  margin: 0.6em 0 0.4em;
  font-family: var(--font-display, 'Cinzel', serif);
  font-size: 0.82em;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 0.4em;
}

.cm-pick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 0.35em;
  margin-bottom: 0.6em;
}

.cm-pick-pill {
  display: flex;
  align-items: center;
  gap: 0.4em;
  padding: 0.4em 0.55em;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-sm, 4px);
  cursor: pointer;
  font-size: 0.85em;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}

.cm-pick-pill:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.25);
}

.cm-pick-pill input {
  cursor: pointer;
  accent-color: var(--accent-blue, #5865f2);
}

.cm-pick-pill span {
  color: var(--text-secondary, #cfd0d4);
}

.cm-pick-std.cm-pick-on {
  background: rgba(87, 242, 135, 0.12);
  border-color: rgba(87, 242, 135, 0.5);
}

.cm-pick-std.cm-pick-on span {
  color: #b6f0c5;
  font-weight: 600;
}

.cm-pick-gourmet.cm-pick-on {
  background: rgba(240, 178, 50, 0.14);
  border-color: rgba(240, 178, 50, 0.55);
}

.cm-pick-gourmet.cm-pick-on span {
  color: #ffd479;
  font-weight: 600;
}

/* ============================================================
 * REFERENCE MODALS
 * ============================================================ */

.cm-ref-overlay {
  /* extends cm-modal-overlay; nothing extra needed today,
   * scoped class kept for future ref-specific tweaks */
}

.cm-ref-box {
  max-width: 640px;
}

.cm-ref-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75em;
  padding-bottom: 0.5em;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.cm-ref-head h3 {
  margin: 0;
  font-family: var(--font-display, 'Cinzel', serif);
}

.cm-ref-body {
  /* container; no extra rules */
}

.cm-ref-block {
  margin-bottom: 1em;
}

.cm-ref-callout {
  padding: 0.6em 0.75em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
}

.cm-ref-callout p {
  margin: 0.3em 0 0;
  color: var(--text-secondary, #cfd0d4);
  line-height: 1.5;
  font-size: 0.92em;
}

.cm-ref-warn {
  padding: 0.6em 0.75em;
  background: rgba(237, 66, 69, 0.06);
  border-left: 3px solid var(--accent-red, #ed4245);
  border-radius: 0 6px 6px 0;
}

.cm-ref-warn p {
  margin: 0.2em 0 0;
  color: var(--text-secondary, #cfd0d4);
  font-size: 0.9em;
}

.cm-ref-strong-amber  { color: var(--accent-amber, #f0b232); }
.cm-ref-strong-cyan   { color: var(--accent-cyan, #5fb6c5); }
.cm-ref-strong-green  { color: var(--accent-green, #79e9a3); }
.cm-ref-strong-red    { color: var(--accent-red, #ed4245); }

.cm-ref-scale {
  display: flex;
  flex-direction: column;
  gap: 0.15em;
  margin-top: 0.4em;
}

.cm-ref-scale-row {
  display: flex;
  justify-content: space-between;
  padding: 0.25em 0.5em;
  background: rgba(255, 255, 255, 0.025);
  border-radius: 3px;
  font-size: 0.88em;
  color: var(--text-secondary, #cfd0d4);
}

.cm-ref-scale-row span:first-child {
  font-family: var(--font-code, monospace);
  font-weight: 700;
  color: var(--accent-amber, #f0b232);
  min-width: 50px;
}

.cm-ref-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3em;
  margin-top: 0.4em;
}

.cm-ref-tag {
  padding: 0.2em 0.55em;
  font-size: 0.85em;
  border-radius: 4px;
  border: 1px solid;
  color: var(--text-primary, #f2f3f5);
}

.cm-ref-tag-std {
  background: rgba(87, 242, 135, 0.08);
  border-color: rgba(87, 242, 135, 0.25);
}

.cm-ref-tag-gourmet {
  background: rgba(240, 178, 50, 0.1);
  border-color: rgba(240, 178, 50, 0.3);
}

.cm-ref-foot {
  margin: 0.4em 0;
  font-size: 0.85em;
  color: var(--text-muted, #a8a9ad);
  font-style: italic;
}

.cm-ref-checks {
  display: flex;
  gap: 0.6em;
  margin-top: 0.4em;
  flex-wrap: wrap;
}

.cm-ref-check-card {
  flex: 1;
  min-width: 160px;
  padding: 0.5em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
  text-align: center;
}

.cm-ref-check-card-wide {
  margin-bottom: 1em;
}

.cm-ref-check-name {
  font-size: 0.78em;
  color: var(--text-muted, #a8a9ad);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.cm-ref-check-formula {
  font-family: var(--font-display, 'Cinzel', serif);
  color: var(--accent-cyan, #5fb6c5);
  font-weight: 700;
  font-size: 1.1em;
  margin-top: 0.2em;
}

.cm-ref-clocks {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4em;
  margin-top: 0.4em;
}

.cm-ref-clock {
  background: var(--bg-darkest, #1e1f22);
  border: 1px solid var(--border-thin, rgba(255,255,255,0.08));
  border-radius: var(--radius-sm, 4px);
  padding: 0.4em 0.6em;
  text-align: center;
  min-width: 90px;
}

.cm-ref-clock-name {
  font-weight: 700;
  color: var(--text-primary, #f2f3f5);
  font-size: 0.9em;
}

.cm-ref-clock-size {
  font-family: var(--font-code, monospace);
  color: var(--accent-amber, #f0b232);
  font-size: 0.85em;
  margin-top: 0.15em;
}

.cm-ref-materials {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 0.4em;
}

.cm-ref-material-row {
  display: flex;
  justify-content: space-between;
  padding: 0.3em 0.5em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: 3px;
  font-size: 0.85em;
}

.cm-ref-material-name {
  font-weight: 600;
  color: var(--text-primary, #f2f3f5);
}

.cm-ref-material-c {
  color: var(--accent-green, #79e9a3);
}

.cm-ref-material-z {
  color: var(--accent-amber, #f0b232);
}

.cm-ref-recipe-row {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.4em 0.6em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
  margin-top: 2px;
}

.cm-ref-recipe-name {
  font-weight: 700;
  min-width: 90px;
  color: var(--text-primary, #f2f3f5);
}

.cm-ref-recipe-ip {
  font-family: var(--font-code, monospace);
  font-size: 0.82em;
  color: var(--accent-amber, #f0b232);
  min-width: 40px;
}

.cm-ref-recipe-e {
  color: var(--text-secondary, #cfd0d4);
  font-size: 0.88em;
}

.cm-ref-tinkerer-note {
  padding: 0.5em 0.75em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
  font-size: 0.85em;
  color: var(--text-muted, #a8a9ad);
}

.cm-ref-tinkerer-note i {
  color: var(--accent-cyan, #5fb6c5);
  margin-right: 0.3em;
}

/* ============================================================
 * SPHERES + SEEDS BUILDER (v2.1.0)
 * Card variants for the two new categories, the tier ladder
 * summary that appears in each card, and the live tag-count
 * badges (ok / err) the parser emits per row.
 * ============================================================ */

.cm-card-sphere {
  border-left: 3px solid var(--accent-cyan, #5fb6c5);
}

.cm-card-seed {
  border-left: 3px solid #79e9a3;
}

.cm-tier-summary {
  margin-top: 0.5em;
  padding: 0.5em 0.75em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
}

.cm-tier-summary-head {
  font-size: 0.78em;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted, #a8a9ad);
  margin-bottom: 0.4em;
  font-weight: 600;
}

.cm-tier-row {
  display: flex;
  align-items: flex-start;
  gap: 0.5em;
  padding: 0.3em 0;
  font-size: 0.85em;
  border-top: 1px solid var(--border-thin, #2a2b30);
}

.cm-tier-row:first-of-type {
  border-top: none;
  padding-top: 0;
}

.cm-tier-key {
  flex: 0 0 auto;
  min-width: 2.5em;
  padding: 0.1em 0.45em;
  background: var(--bg-darker, #25262b);
  border-radius: var(--radius-sm, 4px);
  font-weight: 600;
  text-align: center;
  font-family: var(--font-code, ui-monospace, "Courier New", monospace);
}

.cm-tier-text {
  flex: 1 1 auto;
  color: var(--text-primary, #e0e1e6);
  line-height: 1.45;
}

.cm-tag-ok {
  display: inline-block;
  padding: 0.05em 0.45em;
  margin-left: 0.3em;
  background: rgba(121, 233, 163, 0.15);
  color: #79e9a3;
  border-radius: var(--radius-sm, 4px);
  font-size: 0.78em;
  font-weight: 600;
  white-space: nowrap;
}

.cm-tag-bad {
  display: inline-block;
  padding: 0.05em 0.45em;
  margin-left: 0.3em;
  background: rgba(232, 96, 96, 0.15);
  color: #e86060;
  border-radius: var(--radius-sm, 4px);
  font-size: 0.78em;
  font-weight: 600;
  white-space: nowrap;
}

.cm-icon-cyan {
  color: var(--accent-cyan, #5fb6c5);
}

/* ============================================================
 * SPHERE / SEED EDITOR MODAL (custom dynamic-row form)
 * The cm-modal-overlay/cm-modal-box base classes are shared
 * with the benefits picker; the rules below style the dynamic
 * tier rows, the per-row feedback line, and the tag legend.
 * ============================================================ */

.ss-radio-row {
  display: flex;
  flex-direction: column;
  gap: 0.4em;
}

.ss-tier-row {
  display: flex;
  align-items: flex-start;
  gap: 0.5em;
  padding: 0.6em 0.7em;
  margin-bottom: 0.5em;
  background: var(--bg-darker, #25262b);
  border-radius: var(--radius-sm, 4px);
  border: 1px solid var(--border-thin, #2a2b30);
}

.ss-tier-row-fields {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 0.45em;
  min-width: 0;
}

.ss-tier-key {
  max-width: 16em;
  font-family: var(--font-code, ui-monospace, "Courier New", monospace);
  font-weight: 600;
}

.ss-tier-text {
  resize: vertical;
  min-height: 3.5em;
  font-size: 0.92em;
  line-height: 1.4;
}

.ss-tier-tags {
  font-family: var(--font-code, ui-monospace, "Courier New", monospace);
  font-size: 0.85em;
}

.ss-tier-feedback {
  font-size: 0.78em;
  min-height: 1em;
  color: var(--text-muted, #a8a9ad);
  line-height: 1.4;
}

.ss-tier-remove {
  flex: 0 0 auto;
  padding: 0.3em 0.55em;
  align-self: flex-start;
}

.cm-tag-legend {
  margin-top: 0.75em;
  padding: 0.5em 0.75em;
  background: var(--bg-darkest, #1e1f22);
  border-radius: var(--radius-sm, 4px);
  font-size: 0.85em;
  border: 1px solid var(--border-thin, #2a2b30);
}

.cm-tag-legend summary {
  cursor: pointer;
  user-select: none;
  color: var(--text-muted, #a8a9ad);
  font-weight: 600;
  outline: none;
}

.cm-tag-legend summary:hover {
  color: var(--text-primary, #e0e1e6);
}

.cm-tag-legend code {
  background: var(--bg-darker, #25262b);
  padding: 0.05em 0.3em;
  border-radius: 2px;
  font-family: var(--font-code, ui-monospace, "Courier New", monospace);
  font-size: 0.92em;
  color: var(--accent-cyan, #5fb6c5);
}

/* ============================================================
 * MOBILE TWEAKS
 * ============================================================ */

@media (max-width: 640px) {
  .cm-card-head { flex-wrap: wrap; }
  .cm-card-actions { width: 100%; justify-content: flex-end; }
  .cm-stat-row { flex-direction: column; align-items: stretch; }
  .cm-roll-btn { width: 100%; justify-content: center; }
  .cm-bp-summary { justify-content: flex-start; }
  .cm-pick-grid { grid-template-columns: 1fr; }
  .cm-modal-box { padding: 0.75em; }
  .cm-section { padding: 0.5em; }
  .ss-tier-row { flex-direction: column; }
  .ss-tier-key { max-width: none; }
  .ss-tier-remove { align-self: flex-end; }
}
