/* ═══════════════════════════════════════════════════════════════
   AsistPro Field · Práctica Module · Shell + Mission Patterns
   Estilos compartidos por las 10 misiones + index del módulo.
   Hereda tokens de _field.css.
   ═══════════════════════════════════════════════════════════════ */

/* ─── Mission hero ─── */
.mission-hero {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-6);
  align-items: center;
  padding: var(--s-6);
  background:
    radial-gradient(circle at 0% 0%, rgba(0,255,178,0.12), transparent 60%),
    linear-gradient(180deg, rgba(11,27,61,0.85), rgba(11,27,61,0.55));
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  margin-bottom: var(--s-6);
}
.mission-hero .num-badge {
  font-family: 'Funnel Display', sans-serif;
  font-size: 88px; font-weight: 800; line-height: 1;
  letter-spacing: -0.04em; color: var(--orange);
  font-variant-numeric: tabular-nums;
}
.mission-hero .meta { display: flex; flex-direction: column; gap: var(--s-2); }
.mission-hero .pills { display: flex; gap: 8px; flex-wrap: wrap; }
.mission-hero .pill {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase;
  font-weight: 700; padding: 4px 10px; border-radius: var(--r-pill);
  border: 1px solid var(--border); color: var(--text-dim);
}
.mission-hero .pill.lvl-1 { color: var(--positive); border-color: rgba(34,197,94,0.40); background: var(--positive-bg); }
.mission-hero .pill.lvl-2 { color: var(--warning);  border-color: rgba(245,158,11,0.40); background: var(--warning-bg); }
.mission-hero .pill.lvl-3 { color: var(--orange);   border-color: rgba(0,255,178,0.40); background: var(--orange-bg); }
.mission-hero .pill.lvl-4 { color: var(--negative); border-color: rgba(239,68,68,0.40);  background: var(--negative-bg); }
.mission-hero .pill.mod   { color: var(--info);     border-color: rgba(59,130,246,0.40); background: var(--info-bg); }
.mission-hero h1 {
  margin: 4px 0 0;
  font-family: 'Funnel Display', sans-serif;
  font-size: clamp(24px, 3.4vw, 36px);
  font-weight: 700; letter-spacing: -0.025em; line-height: 1.1;
  color: var(--text);
}
.mission-hero .lead {
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-md); line-height: var(--lh-loose);
  color: var(--text-dim); margin-top: 6px; max-width: 60ch;
}
.mission-hero .progress-circ { width: 96px; height: 96px; position: relative; flex-shrink: 0; }
.mission-hero .progress-circ svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.mission-hero .progress-circ .pct {
  position: absolute; inset: 0; display: grid; place-items: center;
  font-family: 'Funnel Display', sans-serif;
  font-size: 20px; font-weight: 700;
  color: var(--text); font-variant-numeric: tabular-nums;
}

/* ─── Stepper sticky ─── */
.m-stepper {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-2);
  margin-bottom: var(--s-6);
  padding: var(--s-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  position: sticky; top: 80px; z-index: 10;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.m-stepper .step { text-align: center; }
.m-stepper .step .dot {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--bg-muted);
  border: 1px solid var(--border);
  margin: 0 auto 6px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Geist Mono', monospace;
  font-size: 11px; font-weight: 700; color: var(--text-dim);
  transition: all var(--t-mid);
}
.m-stepper .step.active .dot {
  background: var(--orange); border-color: var(--orange); color: #fff;
  box-shadow: 0 0 0 4px var(--orange-glow);
}
.m-stepper .step.done .dot {
  background: var(--positive); border-color: var(--positive); color: #fff;
}
.m-stepper .step .lbl {
  font-family: 'Geist Mono', monospace;
  font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--text-faint); font-weight: 700;
}
.m-stepper .step.active .lbl { color: var(--orange); }
.m-stepper .step.done .lbl { color: var(--positive); }

/* ─── Phase blocks ─── */
.phase {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  margin-bottom: var(--s-5);
  scroll-margin-top: 160px;
  transition: opacity var(--t-slow) var(--ease-out-quart), filter var(--t-slow);
}
.phase.locked { opacity: 0.42; pointer-events: none; filter: grayscale(35%); }
.phase-head {
  display: flex; align-items: center; gap: var(--s-3);
  margin-bottom: var(--s-5);
  padding-bottom: var(--s-4);
  border-bottom: 1px solid var(--border-soft);
}
.phase-head .ic {
  width: 40px; height: 40px;
  background: var(--orange-bg);
  border: 1px solid rgba(0,255,178,0.30);
  border-radius: var(--r-md);
  display: grid; place-items: center;
  font-size: 18px;
}
.phase-head h2 {
  margin: 0;
  font-family: 'Funnel Display', sans-serif;
  font-size: var(--fs-xl); font-weight: 700;
  letter-spacing: -0.020em; color: var(--text); flex: 1;
}
.phase-head .tag {
  font-family: 'Geist Mono', monospace;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--text-faint);
}

/* ─── Brief / text content ─── */
.brief-text {
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-md); line-height: var(--lh-loose);
  color: var(--text); max-width: 65ch;
}
.brief-text + .brief-text { margin-top: var(--s-3); }
.brief-text strong { color: var(--orange-soft); font-weight: 600; }

.brief-callout {
  background: rgba(34,197,94,0.06);
  border: 1px solid rgba(34,197,94,0.25);
  border-radius: var(--r-md);
  padding: var(--s-4) var(--s-5);
  margin-top: var(--s-5);
  display: flex; gap: var(--s-3); align-items: flex-start;
}
.brief-callout.warn { background: rgba(245,158,11,0.06); border-color: rgba(245,158,11,0.25); }
.brief-callout.info { background: rgba(59,130,246,0.06); border-color: rgba(59,130,246,0.25); }
.brief-callout .ic { font-size: 22px; line-height: 1; }
.brief-callout p {
  margin: 0;
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-base); line-height: var(--lh-base); color: var(--text);
}
.brief-callout p strong { color: var(--positive); }
.brief-callout.warn p strong { color: var(--warning); }
.brief-callout.info p strong { color: var(--info); }

.goals-list { display: grid; gap: 8px; margin-top: var(--s-5); }
.goal-row {
  display: grid; grid-template-columns: auto 1fr;
  gap: var(--s-3); align-items: flex-start;
  padding: var(--s-3) var(--s-4);
  background: rgba(11,27,61,0.55);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
}
.goal-row .check {
  width: 22px; height: 22px;
  background: var(--bg-muted);
  border: 1px solid var(--border);
  border-radius: 6px;
  display: grid; place-items: center;
  font-family: 'Geist Mono', monospace; font-size: 11px;
  color: var(--text-faint); font-weight: 700; margin-top: 1px;
}
.goal-row .txt {
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-base); line-height: 1.5; color: var(--text);
}

/* ─── Tool tour mini-cards ─── */
.tools-tour {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-3);
  margin-top: var(--s-3);
}
.tool-mini {
  background: rgba(11,27,61,0.55);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  padding: var(--s-4);
  display: grid; grid-template-columns: auto 1fr;
  gap: var(--s-3); align-items: flex-start;
  transition: all var(--t-mid);
}
.tool-mini:hover {
  border-color: var(--orange);
  background: rgba(0,255,178,0.06);
  transform: translateY(-1px);
}
.tool-mini .icon {
  width: 38px; height: 38px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  display: grid; place-items: center;
  font-size: 18px;
}
.tool-mini .num {
  font-family: 'Geist Mono', monospace;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.12em; color: var(--orange); margin-bottom: 2px;
}
.tool-mini h4 {
  margin: 0 0 4px;
  font-family: 'Funnel Display', sans-serif;
  font-size: var(--fs-base); font-weight: 600;
  color: var(--text); letter-spacing: -0.010em;
}
.tool-mini p {
  margin: 0;
  font-family: 'Funnel Sans', sans-serif;
  font-size: 12px; line-height: 1.45; color: var(--text-dim);
}

/* ─── Action steps ─── */
.action-steps { margin-top: var(--s-3); }
.action-step {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-4); align-items: center;
  padding: var(--s-4) var(--s-5);
  background: rgba(11,27,61,0.55);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  margin-bottom: var(--s-2);
  transition: all var(--t-mid);
}
.action-step.done {
  background: rgba(34,197,94,0.06);
  border-color: rgba(34,197,94,0.30);
}
.action-step .num {
  width: 32px; height: 32px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: 'Geist Mono', monospace;
  font-size: 13px; font-weight: 700; color: var(--text);
}
.action-step.done .num {
  background: var(--positive); border-color: var(--positive); color: #fff;
}
.action-step .txt {
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-base); line-height: 1.5; color: var(--text);
}
.action-step .txt small {
  display: block; margin-top: 2px;
  font-size: 12px; color: var(--text-dim);
}
.action-step .step-cta {
  font-family: 'Geist Mono', monospace;
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  background: var(--orange); color: #fff; border: 0;
  padding: 9px 14px; border-radius: var(--r-md);
  cursor: pointer; transition: all var(--t-fast);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
}
.action-step .step-cta:hover { background: var(--orange-deep); }
.action-step .step-cta.ghost {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-dim);
}
.action-step .step-cta.ghost:hover { border-color: var(--orange); color: var(--orange); }
.action-step.done .step-cta { display: none; }
.action-step .done-mark {
  display: none;
  font-family: 'Geist Mono', monospace;
  font-size: 10px; font-weight: 700; letter-spacing: 0.08em;
  color: var(--positive);
}
.action-step.done .done-mark { display: block; }

/* ─── Numeric input validation row ─── */
.input-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: var(--s-3); align-items: center;
  padding: var(--s-4) var(--s-5);
  background: rgba(11,27,61,0.55);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  margin-bottom: var(--s-2);
}
.input-row .lbl {
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-base); color: var(--text);
}
.input-row .lbl small {
  display: block; margin-top: 2px;
  font-size: 12px; color: var(--text-dim);
}
.input-row input[type="number"], .input-row input[type="text"] {
  width: 110px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 9px 12px;
  font-family: 'Geist Mono', monospace;
  font-size: var(--fs-base);
  color: var(--text);
  outline: none;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.input-row input:focus { border-color: var(--orange); box-shadow: var(--sh-glow-orange); }
.input-row.correct { border-color: rgba(34,197,94,0.40); background: rgba(34,197,94,0.06); }
.input-row.correct input { border-color: var(--positive); }
.input-row.incorrect { border-color: rgba(239,68,68,0.30); }
.input-row .unit {
  font-family: 'Geist Mono', monospace;
  font-size: 11px; font-weight: 700;
  color: var(--text-dim); letter-spacing: 0.06em;
}

/* ─── Quiz ─── */
.quiz-q {
  background: rgba(11,27,61,0.55);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s-5);
  margin-bottom: var(--s-3);
}
.quiz-q .q-num {
  font-family: 'Geist Mono', monospace;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.10em; color: var(--orange); margin-bottom: 4px;
}
.quiz-q .q-txt {
  font-family: 'Funnel Display', sans-serif;
  font-size: var(--fs-md); font-weight: 600;
  color: var(--text); line-height: 1.4; margin-bottom: var(--s-4);
}
.quiz-options { display: grid; gap: 8px; }
.quiz-opt {
  display: flex; gap: 12px; align-items: center;
  padding: 12px 14px;
  background: var(--bg-deep);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  cursor: pointer;
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-base); color: var(--text);
  transition: all var(--t-fast);
  user-select: none;
}
.quiz-opt:hover { border-color: var(--orange); background: rgba(0,255,178,0.04); }
.quiz-opt input { display: none; }
.quiz-opt .key {
  font-family: 'Geist Mono', monospace;
  font-size: 11px; font-weight: 700;
  width: 22px; height: 22px;
  background: var(--bg-muted);
  border: 1px solid var(--border);
  border-radius: 6px;
  display: grid; place-items: center;
  color: var(--text-dim); flex-shrink: 0;
}
.quiz-opt.selected { border-color: var(--orange); background: rgba(0,255,178,0.08); }
.quiz-opt.selected .key { background: var(--orange); border-color: var(--orange); color: #fff; }
.quiz-opt.correct  { border-color: var(--positive); background: rgba(34,197,94,0.10); }
.quiz-opt.correct .key { background: var(--positive); border-color: var(--positive); color: #fff; }
.quiz-opt.incorrect { border-color: var(--negative); background: rgba(239,68,68,0.08); }
.quiz-opt.incorrect .key { background: var(--negative); border-color: var(--negative); color: #fff; }

.quiz-feedback {
  margin-top: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-radius: var(--r-sm);
  font-family: 'Funnel Sans', sans-serif;
  font-size: 13px; line-height: 1.5;
  display: none;
}
.quiz-feedback.show { display: block; }
.quiz-feedback.ok {
  background: rgba(34,197,94,0.08);
  border: 1px solid rgba(34,197,94,0.30);
  color: var(--text);
}
.quiz-feedback.no {
  background: rgba(245,158,11,0.08);
  border: 1px solid rgba(245,158,11,0.30);
  color: var(--text);
}
.quiz-feedback strong { color: var(--orange); }

.quiz-validate { margin-top: var(--s-5); display: flex; gap: var(--s-2); align-items: center; flex-wrap: wrap; }
.btn-validate {
  font-family: 'Geist Mono', monospace;
  font-size: 12px; font-weight: 700; letter-spacing: 0.06em;
  background: var(--orange); color: #fff; border: 0;
  padding: 12px 22px; border-radius: var(--r-md);
  cursor: pointer; transition: all var(--t-fast);
}
.btn-validate:hover { background: var(--orange-deep); }
.btn-validate:disabled { opacity: 0.4; cursor: not-allowed; }
.quiz-score {
  font-family: 'Geist Mono', monospace;
  font-size: 12px; font-weight: 700; color: var(--text-dim);
}
.quiz-score strong { color: var(--positive); }

/* ─── Cierre / refl ─── */
.refl-grid { display: grid; gap: var(--s-3); margin-top: var(--s-4); }
.refl-card {
  background: rgba(11,27,61,0.55);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  padding: var(--s-5);
}
.refl-card .lbl {
  font-family: 'Geist Mono', monospace;
  font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--orange); font-weight: 700; margin-bottom: 8px;
}
.refl-card p {
  margin: 0;
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-base); line-height: var(--lh-loose); color: var(--text);
}

.badge-unlock {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-5); align-items: center;
  padding: var(--s-6);
  background: linear-gradient(135deg, rgba(0,255,178,0.10), rgba(0,255,178,0.02));
  border: 1px solid rgba(0,255,178,0.35);
  border-radius: var(--r-lg);
  margin: var(--s-4) 0;
}
.badge-unlock .badge-art {
  width: 80px; height: 80px;
  background: radial-gradient(circle at 30% 30%, var(--orange-soft), var(--orange-deep));
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 38px;
  box-shadow: 0 8px 24px rgba(0,255,178,0.30), inset 0 -3px 8px rgba(0,0,0,0.20);
  flex-shrink: 0;
}
.badge-unlock .body h3 {
  margin: 0 0 4px;
  font-family: 'Funnel Display', sans-serif;
  font-size: var(--fs-lg); font-weight: 700;
  color: var(--text); letter-spacing: -0.015em;
}
.badge-unlock .body p {
  margin: 0;
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-sm); color: var(--text-dim); line-height: 1.5;
}

/* ─── Footer acción ─── */
.m-action-footer {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-4); align-items: center;
  margin-top: var(--s-6);
  padding: var(--s-4) var(--s-5);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.m-action-footer .progress-mini {
  display: flex; align-items: center; gap: var(--s-3);
  font-family: 'Geist Mono', monospace;
  font-size: 11px; color: var(--text-dim); font-weight: 700;
}
.m-action-footer .bar {
  width: 120px; height: 4px;
  background: var(--bg-muted);
  border-radius: var(--r-pill); overflow: hidden;
}
.m-action-footer .bar i {
  display: block; height: 100%; width: 20%;
  background: linear-gradient(90deg, var(--orange), var(--orange-soft));
  transition: width var(--t-slow) var(--ease-out-quart);
}
.m-action-footer .next-btn {
  font-family: 'Geist Mono', monospace;
  font-size: 12px; font-weight: 700; letter-spacing: 0.06em;
  background: var(--orange); color: #fff;
  padding: 11px 18px; border-radius: var(--r-md);
  border: 0; cursor: pointer; text-decoration: none;
  transition: all var(--t-fast); white-space: nowrap;
}
.m-action-footer .next-btn:disabled {
  opacity: 0.40; cursor: not-allowed;
  background: var(--bg-muted); color: var(--text-faint);
}
.m-action-footer .next-btn:not(:disabled):hover { background: var(--orange-deep); }

/* ─── Index del módulo (grilla 10 misiones) ─── */
.practica-intro {
  padding: var(--s-6);
  background:
    radial-gradient(circle at 0% 0%, rgba(0,255,178,0.12), transparent 60%),
    linear-gradient(180deg, rgba(11,27,61,0.85), rgba(11,27,61,0.55));
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  margin-bottom: var(--s-6);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-5); align-items: center;
}
.practica-intro h1 {
  margin: 0 0 6px;
  font-family: 'Funnel Display', sans-serif;
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700; letter-spacing: -0.025em;
  color: var(--text);
}
.practica-intro h1 span { color: var(--orange); }
.practica-intro p {
  margin: 0;
  font-family: 'Funnel Sans', sans-serif;
  font-size: var(--fs-md); line-height: var(--lh-loose);
  color: var(--text-dim); max-width: 65ch;
}
.practica-intro .right {
  display: flex; flex-direction: column; gap: var(--s-2);
  align-items: flex-end;
}
.practica-intro .big-num {
  font-family: 'Funnel Display', sans-serif;
  font-size: 56px; font-weight: 800; line-height: 1;
  color: var(--orange); letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}
.practica-intro .big-num small {
  font-size: 16px; color: var(--text-dim); font-weight: 600; letter-spacing: 0;
}
.practica-intro .pbar { width: 220px; height: 4px; background: var(--bg-muted); border-radius: var(--r-pill); overflow: hidden; }
.practica-intro .pbar i { display: block; height: 100%; background: linear-gradient(90deg, var(--orange), var(--orange-soft)); }
.practica-intro .pbar-lbl {
  font-family: 'Geist Mono', monospace;
  font-size: 10px; font-weight: 700;
  color: var(--text-dim); letter-spacing: 0.06em;
}

.level-section { margin-bottom: var(--s-8); }
.level-title {
  display: flex; align-items: center; gap: var(--s-3);
  margin-bottom: var(--s-4);
}
.level-title .num {
  font-family: 'Geist Mono', monospace;
  font-size: 10px; font-weight: 700; letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
  background: var(--bg-elevated); border: 1px solid var(--border);
  color: var(--text-dim);
}
.level-title.l-1 .num { color: var(--positive); border-color: rgba(34,197,94,0.40); background: var(--positive-bg); }
.level-title.l-2 .num { color: var(--warning);  border-color: rgba(245,158,11,0.40); background: var(--warning-bg); }
.level-title.l-3 .num { color: var(--orange);   border-color: rgba(0,255,178,0.40); background: var(--orange-bg); }
.level-title.l-4 .num { color: var(--negative); border-color: rgba(239,68,68,0.40);  background: var(--negative-bg); }
.level-title h2 {
  margin: 0;
  font-family: 'Funnel Display', sans-serif;
  font-size: var(--fs-lg); font-weight: 700;
  letter-spacing: -0.015em; color: var(--text);
}
.level-title .meta {
  font-family: 'Geist Mono', monospace;
  font-size: 11px; color: var(--text-faint); font-weight: 600;
  margin-left: auto;
}

.missions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--s-3);
}
.mission-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--s-5);
  text-decoration: none;
  color: inherit;
  display: flex; flex-direction: column;
  gap: var(--s-3);
  position: relative;
  overflow: hidden;
  transition: all var(--t-mid);
}
.mission-card:hover {
  border-color: var(--orange);
  transform: translateY(-2px);
  box-shadow: var(--sh-md);
}
.mission-card.locked {
  opacity: 0.55;
  filter: grayscale(60%);
  pointer-events: none;
}
.mission-card.done {
  border-color: rgba(34,197,94,0.40);
  background: linear-gradient(180deg, rgba(34,197,94,0.04), rgba(11,27,61,0.55));
}
.mission-card .row-top {
  display: flex; align-items: center; gap: var(--s-2);
}
.mission-card .num {
  font-family: 'Funnel Display', sans-serif;
  font-size: 32px; font-weight: 800;
  color: var(--orange); letter-spacing: -0.04em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.mission-card.done .num { color: var(--positive); }
.mission-card .icon-big {
  font-size: 28px; line-height: 1;
}
.mission-card .filler { flex: 1; }
.mission-card .badge {
  font-family: 'Geist Mono', monospace;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.10em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--r-pill);
}
.mission-card .badge.live  { background: var(--positive-bg); color: var(--positive); border: 1px solid rgba(34,197,94,0.30); }
.mission-card .badge.now   { background: var(--orange-bg); color: var(--orange); border: 1px solid rgba(0,255,178,0.30); }
.mission-card .badge.lock  { background: var(--bg-muted); color: var(--text-faint); border: 1px solid var(--border); }
.mission-card h3 {
  margin: 0;
  font-family: 'Funnel Display', sans-serif;
  font-size: var(--fs-md); font-weight: 700;
  color: var(--text); letter-spacing: -0.015em; line-height: 1.3;
}
.mission-card p {
  margin: 0;
  font-family: 'Funnel Sans', sans-serif;
  font-size: 13px; line-height: 1.5;
  color: var(--text-dim);
}
.mission-card .meta {
  display: flex; gap: 8px; flex-wrap: wrap;
  font-family: 'Geist Mono', monospace;
  font-size: 10px; color: var(--text-faint); font-weight: 600;
  letter-spacing: 0.04em;
}
.mission-card .meta .sep::before { content: '·'; margin-right: 6px; color: var(--text-mute); }

/* ─── Stagger entry ─── */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.phase { animation: fade-up var(--t-slow) var(--ease-out-quart) backwards; }
.phase:nth-of-type(1) { animation-delay: 0.05s; }
.phase:nth-of-type(2) { animation-delay: 0.10s; }
.phase:nth-of-type(3) { animation-delay: 0.15s; }
.phase:nth-of-type(4) { animation-delay: 0.20s; }
.phase:nth-of-type(5) { animation-delay: 0.25s; }
.mission-card { animation: fade-up var(--t-slow) var(--ease-out-quart) backwards; }
.mission-card:nth-child(1) { animation-delay: 0.04s; }
.mission-card:nth-child(2) { animation-delay: 0.08s; }
.mission-card:nth-child(3) { animation-delay: 0.12s; }
.mission-card:nth-child(4) { animation-delay: 0.16s; }

@media (prefers-reduced-motion: reduce) {
  .phase, .mission-card { animation: none; }
  * { transition: none !important; }
}

@media (max-width: 900px) {
  .mission-hero { grid-template-columns: 1fr; gap: var(--s-3); }
  .mission-hero .num-badge { font-size: 56px; }
  .mission-hero .progress-circ { display: none; }
  .practica-intro { grid-template-columns: 1fr; }
  .practica-intro .right { align-items: flex-start; }
  .m-stepper { top: 56px; padding: var(--s-3); }
  .m-stepper .step .lbl { font-size: 8px; }
  .phase { padding: var(--s-5); }
  .phase-head h2 { font-size: var(--fs-lg); }
  .action-step, .input-row { grid-template-columns: auto 1fr; }
  .action-step .step-cta, .input-row input { grid-column: 1 / -1; justify-self: stretch; }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE · misiones · 2026-04-25
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 991px) {
  /* Hero misión mobile: stack vertical */
  .mission-hero {
    grid-template-columns: 1fr !important;
    gap: var(--s-3) !important;
    padding: var(--s-4) !important;
  }
  .mission-hero .num-badge { font-size: 56px; }
  .mission-hero h1 { font-size: 22px; }
  .mission-hero .lead { font-size: 13.5px; }
  .mission-hero .progress-circ { display: none; }

  /* Stepper sticky con offset bajo del topbar fijo */
  .m-stepper {
    top: 56px !important;
    padding: var(--s-2) !important;
    border-radius: var(--r-md);
  }
  .m-stepper .step .dot { width: 22px; height: 22px; font-size: 10px; }
  .m-stepper .step .lbl { font-size: 8px; letter-spacing: 0.06em; }

  /* Phases padding compacto */
  .phase {
    padding: var(--s-4) !important;
    border-radius: var(--r-md);
  }
  .phase-head { gap: var(--s-2); margin-bottom: var(--s-3); padding-bottom: var(--s-3); }
  .phase-head .ic { width: 32px; height: 32px; font-size: 14px; }
  .phase-head h2 { font-size: 16px; }
  .phase-head .tag { display: none; }

  /* Brief textos */
  .brief-text { font-size: 14px; }
  .brief-callout { padding: var(--s-3); }
  .brief-callout p { font-size: 13px; }

  /* Tools tour mobile: 1col */
  .tools-tour {
    grid-template-columns: 1fr !important;
    gap: var(--s-2) !important;
  }
  .tool-mini { padding: var(--s-3); }
  .tool-mini h4 { font-size: 13px; }
  .tool-mini p { font-size: 11.5px; }

  /* Goals list */
  .goal-row { padding: var(--s-2) var(--s-3); }
  .goal-row .txt { font-size: 13px; }

  /* Action steps stack vertical */
  .action-step {
    grid-template-columns: auto 1fr !important;
    grid-template-areas:
      "num txt"
      "cta cta" !important;
    gap: var(--s-2) var(--s-3) !important;
    padding: var(--s-3) !important;
  }
  .action-step .num { grid-area: num; }
  .action-step .txt { grid-area: txt; font-size: 13.5px; }
  .action-step .txt small { font-size: 11.5px; }
  .action-step .step-cta {
    grid-area: cta;
    width: 100%;
    justify-content: center;
    min-height: 44px;
    padding: 11px 16px !important;
    font-size: 12px !important;
  }
  .action-step .done-mark { grid-area: cta; text-align: center; }

  /* Input rows stack */
  .input-row {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding: var(--s-3) !important;
  }
  .input-row input[type="number"], .input-row input[type="text"] {
    width: 100%;
    min-height: 44px;
    font-size: 16px; /* iOS no zoom */
  }
  .input-row .lbl { font-size: 13.5px; }

  /* Quiz options touch friendly */
  .quiz-q { padding: var(--s-4); }
  .quiz-q .q-txt { font-size: 14px; line-height: 1.35; }
  .quiz-opt {
    padding: 14px 12px;
    min-height: 48px;
    font-size: 13.5px;
  }
  .quiz-opt .key { width: 24px; height: 24px; font-size: 11px; }
  .quiz-validate { flex-wrap: wrap; gap: 8px; }
  .btn-validate {
    width: 100%;
    min-height: 44px;
    padding: 13px 18px;
    font-size: 13px;
  }
  .quiz-score { width: 100%; text-align: center; font-size: 11px; }

  /* Reflection cards */
  .refl-card { padding: var(--s-3); }
  .refl-card p { font-size: 13px; }

  /* Badge unlock */
  .badge-unlock {
    grid-template-columns: 1fr !important;
    text-align: center;
    padding: var(--s-4);
    gap: var(--s-3) !important;
  }
  .badge-unlock .badge-art {
    width: 64px; height: 64px; font-size: 30px;
    margin: 0 auto;
  }
  .badge-unlock .body h3 { font-size: 15px; }
  .badge-unlock .body p { font-size: 12.5px; }

  /* Footer acción */
  .m-action-footer {
    grid-template-columns: 1fr !important;
    gap: var(--s-2) !important;
    padding: var(--s-3) !important;
    text-align: center;
  }
  .m-action-footer .progress-mini { justify-content: center; font-size: 10px; }
  .m-action-footer .next-btn {
    width: 100%;
    min-height: 44px;
    padding: 13px 18px;
    font-size: 12px;
  }

  /* Hub: practica/index */
  .practica-intro {
    grid-template-columns: 1fr !important;
    padding: var(--s-4) !important;
    gap: var(--s-3) !important;
  }
  .practica-intro h1 { font-size: 22px; }
  .practica-intro p { font-size: 13px; }
  .practica-intro .right { align-items: flex-start; }
  .practica-intro .big-num { font-size: 44px; }

  /* Level title wrap */
  .level-title { flex-wrap: wrap; gap: 8px; }
  .level-title h2 { font-size: 14px; flex-basis: 100%; }
  .level-title .meta { font-size: 10px; }

  /* Mission cards 1col mobile chico, 2col tablet */
  .missions-grid {
    grid-template-columns: 1fr !important;
    gap: var(--s-3) !important;
  }
  .mission-card { padding: var(--s-4); }
  .mission-card .num { font-size: 26px; }
  .mission-card h3 { font-size: 14px; }
  .mission-card p { font-size: 12px; }
}

@media (max-width: 600px) {
  .mission-hero .num-badge { font-size: 44px; }
  .mission-hero h1 { font-size: 18px; }
  .phase { padding: var(--s-3) !important; }
  .phase-head h2 { font-size: 14px; }
  .badge-unlock .badge-art { width: 56px; height: 56px; font-size: 24px; }
}
