/* /Pages/Asistente.razor.rz.scp.css */
/* Asistente / Wizard — estilos propios (usan siempre tokens del sistema).
   El grueso del diseño vive en app.css; acá solo lo puntual del wizard. */

/* ── Progreso del wizard (3 pasos) ──────────────────────────────────────── */
.wiz-steps[b-bdswxn03sz] {
    display: flex;
    gap: var(--space-2);
    margin-bottom: var(--space-5);
    flex-wrap: wrap;
}

.wiz-step[b-bdswxn03sz] {
    flex: 1 1 160px;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-sm);
    border: 1.5px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-muted);
    font-size: 0.85rem;
    font-weight: 600;
}

.wiz-step__n[b-bdswxn03sz] {
    width: 1.7rem;
    height: 1.7rem;
    flex-shrink: 0;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface-2);
    color: var(--color-muted);
    font-weight: 800;
    font-size: 0.9rem;
}

.wiz-step--active[b-bdswxn03sz] {
    border-color: var(--color-primary);
    background: var(--color-primary-soft);
    color: var(--color-text);
}
.wiz-step--active .wiz-step__n[b-bdswxn03sz] {
    background: var(--color-primary);
    color: var(--color-primary-contrast);
}

.wiz-step--done[b-bdswxn03sz] {
    border-color: var(--color-success);
    color: var(--color-success);
}
.wiz-step--done .wiz-step__n[b-bdswxn03sz] {
    background: var(--color-success);
    color: #fff;
}

/* ── Mini-cards de receta (paso 1) ──────────────────────────────────────── */
.asis-recipe[b-bdswxn03sz] {
    display: flex;
    flex-direction: column;
}
.asis-recipe .card__body[b-bdswxn03sz] {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    flex: 1;
}

.asis-recipe__missing[b-bdswxn03sz] {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    font-size: 0.82rem;
}
.asis-recipe__missing li[b-bdswxn03sz] { color: var(--color-danger); }

/* El botón queda anclado abajo para que todas las cards midan igual. */
.asis-actions[b-bdswxn03sz] { margin-top: auto; }

/* ── Lista de descuento de stock (paso 2) ───────────────────────────────── */
.asis-discount[b-bdswxn03sz] {
    margin: 0.35rem 0 0;
    padding-left: 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.asis-discount .miss[b-bdswxn03sz] {
    color: var(--color-danger);
    font-weight: 600;
    margin-left: 0.25rem;
}

/* ── Resumen del lote creado (paso 3) ───────────────────────────────────── */
.facts[b-bdswxn03sz] {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.35rem var(--space-4);
    margin: 0;
    font-size: 0.92rem;
    align-items: baseline;
}
.facts dt[b-bdswxn03sz] { color: var(--color-muted); font-weight: 600; }
.facts dd[b-bdswxn03sz] { margin: 0; font-weight: 700; }
/* /Pages/Dashboard.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════════════
   Panel (Dashboard) · estilos scoped
   Solo detalles propios del centro de mando: filas de lote, chips de receta
   y filas de stock. Todo lo demás sale del sistema global (app.css).
   ═══════════════════════════════════════════════════════════════════════ */

/* Próxima tarea: acento cálido para que resalte como lo más urgente. */
.next-task[b-b16s5ox4bv] {
    align-items: center;
    box-shadow: var(--shadow-sm);
}
.next-task strong[b-b16s5ox4bv] {
    display: block;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.1rem;
}

/* Stats clicables: heredan .stat de app.css, sin subrayado de link. */
.stat-link[b-b16s5ox4bv] {
    text-decoration: none;
    color: var(--color-text);
    cursor: pointer;
}
.stat-link:hover[b-b16s5ox4bv] { text-decoration: none; }

/* ── Filas de lote activo ─────────────────────────────────────────────── */
.batch-row[b-b16s5ox4bv] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    text-decoration: none;
    color: var(--color-text);
    transition: background 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
}
.batch-row:hover[b-b16s5ox4bv] {
    text-decoration: none;
    background: var(--color-surface-2);
    border-color: var(--color-primary-soft);
    transform: translateX(2px);
}

.batch-row__main[b-b16s5ox4bv] { min-width: 0; display: flex; flex-direction: column; gap: 0.3rem; }
.batch-row__title[b-b16s5ox4bv] { font-weight: 700; line-height: 1.25; }
.batch-row__meta[b-b16s5ox4bv] { gap: var(--space-2); }
.batch-row__action[b-b16s5ox4bv] { font-size: 0.85rem; line-height: 1.35; }
.batch-row__action.is-due[b-b16s5ox4bv] { color: var(--color-danger); font-weight: 600; }

.batch-row__end[b-b16s5ox4bv] {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}
.batch-row__chev[b-b16s5ox4bv] {
    font-size: 1.4rem;
    color: var(--color-muted);
    line-height: 1;
}

.pill--due[b-b16s5ox4bv] {
    background: var(--color-danger-soft);
    color: var(--color-danger);
    font-weight: 700;
}

/* ── Alertas clicables ────────────────────────────────────────────────── */
.alert--clickable[b-b16s5ox4bv] { cursor: pointer; transition: filter 0.15s ease, transform 0.12s ease; }
.alert--clickable:hover[b-b16s5ox4bv] { filter: brightness(0.98); transform: translateX(2px); }

/* ── Filas "puedo hacer hoy" ──────────────────────────────────────────── */
.brewable-row[b-b16s5ox4bv] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-success-soft);
}
.brewable-row__main[b-b16s5ox4bv] { min-width: 0; display: flex; flex-direction: column; gap: 0.35rem; }
.brewable-row__title[b-b16s5ox4bv] { font-weight: 700; line-height: 1.25; }

/* ── Filas de stock a controlar ───────────────────────────────────────── */
.section-label[b-b16s5ox4bv] {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-muted);
    margin-bottom: var(--space-2);
}

.stock-row[b-b16s5ox4bv] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: 0.5rem var(--space-3);
    border-radius: var(--radius-sm);
    text-decoration: none;
    color: var(--color-text);
    transition: background 0.15s ease;
}
.stock-row:hover[b-b16s5ox4bv] { text-decoration: none; background: var(--color-surface-2); }

.stock-row__main[b-b16s5ox4bv] { min-width: 0; display: flex; align-items: baseline; gap: var(--space-2); flex-wrap: wrap; }
.stock-row__name[b-b16s5ox4bv] { font-weight: 600; }
.stock-row__type[b-b16s5ox4bv] { font-size: 0.82rem; }
.stock-row__qty[b-b16s5ox4bv] { font-size: 0.82rem; font-variant-numeric: tabular-nums; white-space: nowrap; }

/* En móvil, apilar las filas para que no se aprieten los datos. */
@media (max-width: 480px) {
    .batch-row[b-b16s5ox4bv], .brewable-row[b-b16s5ox4bv], .stock-row[b-b16s5ox4bv] {
        flex-direction: column;
        align-items: stretch;
    }
    .batch-row__end[b-b16s5ox4bv] { justify-content: space-between; }
    .stock-row .row[b-b16s5ox4bv] { justify-content: space-between; }
}
/* /Pages/LoteDetalle.razor.rz.scp.css */
/* LoteDetalle — estilos puntuales (tokens del sistema). Stepper/timeline/alert
   son globales; acá solo la ficha, la cuenta atrás y el estado "lista". */

/* ── Ficha de datos del lote ────────────────────────────────────────────── */
.lote-facts[b-axz9pahedr] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--space-4);
}
.lote-fact[b-axz9pahedr] {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}
.lote-fact__k[b-axz9pahedr] {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-muted);
    font-weight: 700;
}
.lote-fact__v[b-axz9pahedr] {
    font-weight: 700;
    font-size: 0.98rem;
}

/* ── Fase actual (guía) ─────────────────────────────────────────────────── */
.lote-guide .card__body[b-axz9pahedr] {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* Cuenta atrás de fases temporizadas */
.lote-timed[b-axz9pahedr] {
    display: flex;
    gap: var(--space-5);
    align-items: stretch;
    flex-wrap: wrap;
}
.lote-countdown[b-axz9pahedr] {
    flex: 0 0 auto;
    min-width: 180px;
    justify-content: center;
    background: var(--color-primary-soft);
    border-color: transparent;
}
.lote-countdown .stat__value[b-axz9pahedr] { color: var(--color-primary-strong); }
.lote-countdown.is-due[b-axz9pahedr] { background: var(--color-warning-soft); }
.lote-countdown.is-due .stat__value[b-axz9pahedr] { color: var(--color-warning); }

.lote-timed__side[b-axz9pahedr] {
    flex: 1 1 260px;
    justify-content: center;
}

/* ── Estado "lista" (celebración) ───────────────────────────────────────── */
.lote-done[b-axz9pahedr] {
    text-align: center;
    padding: var(--space-4) 0;
}
.lote-done__emoji[b-axz9pahedr] { font-size: 2.6rem; line-height: 1; }
.lote-done__title[b-axz9pahedr] {
    font-size: 1.2rem;
    font-weight: 800;
    margin-top: var(--space-2);
}

@media (max-width: 560px) {
    .lote-timed[b-axz9pahedr] { flex-direction: column; }
    .lote-countdown[b-axz9pahedr] { width: 100%; }
}
/* /Pages/Lotes.razor.rz.scp.css */
/* Lotes — estilos puntuales (tokens del sistema). La tabla y badges son globales. */

.lotes-filter[b-98wrw6nt6f] { max-width: 200px; }

.lote-name[b-98wrw6nt6f] { font-weight: 700; }

/* Acciones compactas dentro de la celda: no deben envolver. */
.lote-actions[b-98wrw6nt6f] {
    display: flex;
    gap: var(--space-1);
    flex-wrap: nowrap;
}

.lote-actiontext[b-98wrw6nt6f] { margin-left: 0.35rem; }
/* /Pages/Recipes.razor.rz.scp.css */
/* ── Recetas · estilos scoped ──────────────────────────────────────────────
   Solo ajustes puntuales sobre las clases globales del kit (app.css). */

/* Barra de filtros: los contadores como pastillita dentro del botón */
.filtros[b-am4achpd6a] {
    gap: var(--space-2);
}

.filtro__n[b-am4achpd6a] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.4rem;
    height: 1.4rem;
    padding: 0 0.35rem;
    margin-left: 0.35rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.08);
    font-size: 0.72rem;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
}

/* Tarjeta de receta: cuerpo en columna para alinear las acciones abajo */
.recipe-card .card__body[b-am4achpd6a] {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    height: 100%;
}

.recipe-meta[b-am4achpd6a] {
    gap: var(--space-2);
}

.recipe-times[b-am4achpd6a] {
    font-size: 0.82rem;
}

/* Mensaje del semáforo: altura mínima para que las tarjetas queden parejas */
.recipe-msg[b-am4achpd6a] {
    font-size: 0.88rem;
    line-height: 1.4;
    min-height: 2.5rem;
    margin: var(--space-1) 0 var(--space-2);
}

/* Acciones al pie de la tarjeta; el botón de borrar empujado a la derecha */
.recipe-actions[b-am4achpd6a] {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-top: auto;
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-border);
}

.recipe-del[b-am4achpd6a] {
    margin-left: auto;
}

/* Detalle: resaltar filas de ingredientes faltantes */
.detalle-modal[b-am4achpd6a] { max-width: 640px; }

.detalle-modal .linea-falta[b-am4achpd6a] {
    background: var(--color-danger-soft);
}
.detalle-modal .linea-falta td[b-am4achpd6a] { color: var(--color-danger); }
/* /Pages/Stock.razor.rz.scp.css */
/* Estilos propios de la pantalla de Inventario.
   Solo detalles puntuales; el grueso viene del sistema global (app.css). */

/* ── Barra de filtros ─────────────────────────────────────────────────── */
.se-search[b-lm5c0yy5vq] {
    flex: 1 1 260px;
    max-width: 420px;
}

.se-catfilter[b-lm5c0yy5vq] {
    flex: 0 1 220px;
    min-width: 170px;
}

/* ── Resaltado de filas según estado ──────────────────────────────────── */
/* Fila con algún insumo vencido: tinte rojo suave. */
.se-row-danger td[b-lm5c0yy5vq] {
    background: var(--color-danger-soft);
}

/* Fila con stock bajo o próximo a vencer: tinte dorado suave. */
.se-row-warn td[b-lm5c0yy5vq] {
    background: var(--color-warning-soft);
}

/* Acento vertical a la izquierda de la fila para lectura rápida. */
.se-row-danger td:first-child[b-lm5c0yy5vq] {
    box-shadow: inset 4px 0 0 var(--color-danger);
}
.se-row-warn td:first-child[b-lm5c0yy5vq] {
    box-shadow: inset 4px 0 0 var(--color-warning);
}

/* ── Celdas de la tabla ───────────────────────────────────────────────── */
/* Apilar varios badges de estado sin demasiado espacio. */
.se-states[b-lm5c0yy5vq] {
    gap: var(--space-1);
    align-items: flex-start;
}

/* Botones de acción juntos y sin salto de línea. */
.se-actions[b-lm5c0yy5vq] {
    gap: var(--space-1);
    flex-wrap: nowrap;
}
