/* ============================================================================
   POSTULACIONES — Manolito Almacenes 24HS
   Identidad: noir / rojo profundo / verde neon LED. Mobile-first.
   Prefijos:  post-*  => panel interno (admin/encargado)
              cand-*  => wizard publico del candidato
   Este archivo es 100% scopeado a esas clases: no pisa estilos globales.
   ============================================================================ */

:root {
    --mn-bg:        #0c0c0e;
    --mn-bg-2:      #141417;
    --mn-card:      #18181c;
    --mn-card-2:    #1f1f25;
    --mn-line:      #2a2a31;
    --mn-line-2:    #34343d;
    --mn-text:      #ececf0;
    --mn-text-dim:  #9a9aa5;
    --mn-text-faint:#6a6a74;
    --mn-red:       #c81e2e;
    --mn-red-soft:  #e23a48;
    --mn-red-glow:  rgba(200, 30, 46, .35);
    --mn-green:     #2bd96b;
    --mn-green-dim: #1f9e4e;
    --mn-green-glow:rgba(43, 217, 107, .30);
    --mn-amber:     #f0b429;
    --mn-radius:    14px;
    --mn-radius-sm: 9px;
    --mn-shadow:    0 10px 30px rgba(0,0,0,.45);
    --mn-mono:      "JetBrains Mono", ui-monospace, "Cascadia Code", Consolas, monospace;
    --mn-display:   "Anton", "Archivo Black", "Bebas Neue", system-ui, sans-serif;

    /* ── Sistema de movimiento armónico (curvas + escala de duracion) ── */
    --ease-out:  cubic-bezier(.22,.61,.36,1);   /* entradas y reveals: llega suave */
    --ease-soft: cubic-bezier(.4,0,.2,1);        /* cambios de estado: foco, color */
    --ease-pop:  cubic-bezier(.34,1.56,.64,1);   /* feedback positivo: rebote sutil */
    --t-fast: .14s;   /* micro-interacciones */
    --t-base: .24s;   /* transiciones de estado */
    --t-mid:  .38s;   /* reveals de campos / feedback */
    --t-slow: .52s;   /* entrada de tarjeta / paso */
}

/* ===========================================================================
   PANEL INTERNO  (post-*)
   =========================================================================== */

.post-wrap {
    max-width: 1180px;
    margin: 0 auto;
    padding: 22px 18px 64px;
    color: var(--mn-text);
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

.post-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--mn-line);
}

.post-title {
    font-family: var(--mn-display);
    font-size: clamp(28px, 5vw, 42px);
    letter-spacing: .5px;
    text-transform: uppercase;
    line-height: .98;
    margin: 0;
    color: #fff;
}
.post-title span { color: var(--mn-red-soft); }

.post-sub {
    color: var(--mn-text-dim);
    font-size: 13.5px;
    margin: 6px 0 0;
}

/* ── Generar invitacion ─────────────────────────────────────────────────── */
.post-invitar {
    background: var(--mn-card);
    border: 1px solid var(--mn-line);
    border-radius: var(--mn-radius);
    padding: 16px;
    margin-bottom: 18px;
    box-shadow: var(--mn-shadow);
}
.post-invitar .post-row { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; }
.post-link-box {
    margin-top: 12px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
    background: var(--mn-bg-2);
    border: 1px dashed var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    padding: 10px 12px;
    font-family: var(--mn-mono);
    font-size: 12.5px;
    color: var(--mn-green);
    word-break: break-all;
}

/* ── Filtros ────────────────────────────────────────────────────────────── */
.post-filtros {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: flex-end;
    margin-bottom: 16px;
}
.post-col { display: flex; flex-direction: column; gap: 5px; }
.post-lbl {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .7px;
    color: var(--mn-text-faint);
    font-weight: 600;
}

.post-input,
.post-textarea {
    background: var(--mn-bg-2);
    border: 1px solid var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    color: var(--mn-text);
    padding: 9px 11px;
    font-size: 14px;
    font-family: inherit;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    min-width: 0;
}
.post-input:focus,
.post-textarea:focus {
    border-color: var(--mn-red);
    box-shadow: 0 0 0 3px var(--mn-red-glow);
}
.post-textarea { resize: vertical; min-height: 84px; line-height: 1.5; }
select.post-input { cursor: pointer; }

/* ── Botones ────────────────────────────────────────────────────────────── */
.post-btn,
.post-btn-green {
    border: none;
    border-radius: var(--mn-radius-sm);
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .3px;
    cursor: pointer;
    transition: transform .08s, filter .15s, box-shadow .15s;
    font-family: inherit;
    white-space: nowrap;
}
.post-btn { background: var(--mn-red); color: #fff; box-shadow: 0 4px 14px var(--mn-red-glow); }
.post-btn:hover { filter: brightness(1.08); }
.post-btn:active { transform: translateY(1px); }
.post-btn-green { background: var(--mn-green-dim); color: #04130a; box-shadow: 0 4px 14px var(--mn-green-glow); }
.post-btn-green:hover { filter: brightness(1.08); }
.post-btn-block { width: 100%; }

.post-icon-btn {
    background: var(--mn-card-2);
    border: 1px solid var(--mn-line-2);
    color: var(--mn-text);
    border-radius: var(--mn-radius-sm);
    padding: 7px 11px;
    font-size: 13px;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: border-color .15s, background .15s;
}
.post-icon-btn:hover { border-color: var(--mn-green); background: var(--mn-bg-2); }

/* ── Tabla / lista ──────────────────────────────────────────────────────── */
.post-card {
    background: var(--mn-card);
    border: 1px solid var(--mn-line);
    border-radius: var(--mn-radius);
    overflow: hidden;
    box-shadow: var(--mn-shadow);
}
.post-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.post-th {
    text-align: left;
    text-transform: uppercase;
    letter-spacing: .6px;
    font-size: 11px;
    color: var(--mn-text-faint);
    font-weight: 700;
    padding: 12px 14px;
    background: var(--mn-bg-2);
    border-bottom: 1px solid var(--mn-line);
    white-space: nowrap;
}
.post-tr { border-bottom: 1px solid var(--mn-line); transition: background .12s; }
.post-tr:last-child { border-bottom: none; }
.post-tr:hover { background: var(--mn-card-2); }
.post-tr td { padding: 11px 14px; vertical-align: middle; }

.post-k { font-weight: 700; color: #fff; }
.post-meta { color: var(--mn-text-dim); font-size: 12.5px; }
.post-meta-faint { color: var(--mn-text-faint); font-size: 12px; font-family: var(--mn-mono); }

/* ── Badges ─────────────────────────────────────────────────────────────── */
.post-badges { display: flex; flex-wrap: wrap; gap: 5px; }
.post-badge {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .3px;
    padding: 3px 8px;
    border-radius: 999px;
    border: 1px solid var(--mn-line-2);
    color: var(--mn-text-faint);
    background: var(--mn-bg-2);
    white-space: nowrap;
}
.post-badge.ok   { color: var(--mn-green); border-color: rgba(43,217,107,.4); background: rgba(43,217,107,.08); }
.post-badge.off  { color: var(--mn-text-faint); opacity: .55; }
.post-badge.wa   { color: #25d366; border-color: rgba(37,211,102,.4); background: rgba(37,211,102,.08); }

/* ── Estados (e-0 .. e-11) ──────────────────────────────────────────────── */
.post-estado {
    display: inline-block;
    font-size: 11.5px;
    font-weight: 800;
    letter-spacing: .4px;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text-dim);
}
.post-estado.e-0  { color: var(--mn-text-faint); }                                          /* Invitado */
.post-estado.e-1  { color: #6ea8ff; border-color: rgba(110,168,255,.4); background: rgba(110,168,255,.08); } /* Recibido */
.post-estado.e-2  { color: #8a9bff; border-color: rgba(138,155,255,.4); background: rgba(138,155,255,.08); } /* EnRevision */
.post-estado.e-3  { color: var(--mn-amber); border-color: rgba(240,180,41,.4); background: rgba(240,180,41,.08); } /* Entrevista */
.post-estado.e-4,
.post-estado.e-5,
.post-estado.e-6  { color: #ffcf5c; border-color: rgba(255,207,92,.4); background: rgba(255,207,92,.08); } /* Pruebas */
.post-estado.e-7  { color: var(--mn-green); border-color: rgba(43,217,107,.45); background: rgba(43,217,107,.10); } /* Aprobado */
.post-estado.e-8  { color: #04130a; background: var(--mn-green); border-color: var(--mn-green); box-shadow: 0 0 12px var(--mn-green-glow); } /* Contratado */
.post-estado.e-9  { color: var(--mn-red-soft); border-color: rgba(226,58,72,.4); background: rgba(226,58,72,.08); } /* Descartado */
.post-estado.e-10 { color: var(--mn-text-faint); border-style: dashed; } /* NoResponde */
.post-estado.e-11 { color: #c79bff; border-color: rgba(199,155,255,.4); background: rgba(199,155,255,.08); } /* EnEspera */

.post-actions { display: flex; gap: 6px; flex-wrap: wrap; }

.post-empty {
    text-align: center;
    padding: 48px 20px;
    color: var(--mn-text-faint);
    font-size: 14px;
}

/* ── Detalle ────────────────────────────────────────────────────────────── */
.post-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 16px;
    align-items: start;
}
.post-detalle-card,
.post-gestion {
    background: var(--mn-card);
    border: 1px solid var(--mn-line);
    border-radius: var(--mn-radius);
    padding: 18px;
    box-shadow: var(--mn-shadow);
}
.post-gestion { position: sticky; top: 16px; }

.post-row {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 9px 0;
    border-bottom: 1px solid var(--mn-line);
    font-size: 14px;
}
.post-row:last-child { border-bottom: none; }
.post-row > .post-lbl { flex: 0 0 auto; }
.post-row > span:last-child { text-align: right; color: var(--mn-text); }

.post-archivo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    background: var(--mn-bg-2);
    border: 1px solid var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    padding: 10px 12px;
    margin-top: 8px;
}
.post-check-inline { display: inline-flex; align-items: center; gap: 7px; font-size: 14px; }

/* ── Dato sensible (Ley 25.326) ─────────────────────────────────────────── */
.post-sensible {
    margin-top: 14px;
    border: 1px solid rgba(200,30,46,.4);
    border-radius: var(--mn-radius-sm);
    background: rgba(200,30,46,.05);
    padding: 14px;
}
.post-lock {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--mn-red-soft);
    font-weight: 700;
    font-size: 13px;
    letter-spacing: .3px;
}
.post-sensible-text {
    margin-top: 10px;
    white-space: pre-wrap;
    line-height: 1.55;
    font-size: 14px;
    color: var(--mn-text);
}
.post-hint { color: var(--mn-text-faint); font-size: 12px; margin-top: 6px; }
.post-ok-msg {
    color: var(--mn-green);
    font-weight: 700;
    font-size: 13.5px;
    margin-top: 10px;
}

@media (max-width: 880px) {
    .post-grid { grid-template-columns: 1fr; }
    .post-gestion { position: static; }
    /* Tabla -> tarjetas apiladas en celular */
    .post-table, .post-table tbody, .post-table tr, .post-table td { display: block; width: 100%; }
    .post-table thead { display: none; }
    .post-tr { padding: 12px 14px; border-bottom: 1px solid var(--mn-line); }
    .post-tr td { padding: 4px 0; }
    .post-tr td::before {
        content: attr(data-lbl);
        display: block;
        font-size: 10.5px;
        text-transform: uppercase;
        letter-spacing: .6px;
        color: var(--mn-text-faint);
        margin-bottom: 2px;
    }
}

/* ===========================================================================
   WIZARD DEL CANDIDATO  (cand-*)  — mobile-first
   =========================================================================== */

.cand-bg {
    min-height: 100vh;
    background:
        radial-gradient(1100px 600px at 50% -10%, rgba(200,30,46,.18), transparent 60%),
        var(--mn-bg);
    color: var(--mn-text);
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    padding: 18px 14px 48px;
}
.cand-wrap { max-width: 520px; margin: 0 auto; }

.cand-header { text-align: center; margin-bottom: 18px; }
.cand-logo {
    font-family: var(--mn-display);
    font-size: clamp(30px, 9vw, 46px);
    text-transform: uppercase;
    letter-spacing: 1px;
    line-height: .95;
    color: #fff;
    margin: 0;
}
.cand-logo span { color: var(--mn-red-soft); }
.cand-tag {
    display: inline-block;
    margin-top: 8px;
    font-size: 12px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--mn-green);
    font-family: var(--mn-mono);
}

/* ── Progreso ───────────────────────────────────────────────────────────── */
.cand-progress { display: flex; gap: 6px; justify-content: center; margin: 16px 0 6px; }
.cand-bar {
    flex: 1; max-width: 48px; height: 5px; border-radius: 999px;
    background: var(--mn-line-2);
    transition: background .25s, box-shadow .25s;
}
.cand-bar.done { background: var(--mn-green-dim); }
.cand-bar.on { background: var(--mn-green); box-shadow: 0 0 10px var(--mn-green-glow); }
.cand-dot {
    width: 34px; height: 5px; border-radius: 999px;
    background: var(--mn-line-2);
    transition: background .25s, box-shadow .25s;
}
.cand-dot.on { background: var(--mn-green); box-shadow: 0 0 10px var(--mn-green-glow); }

/* ── Tarjeta del paso ───────────────────────────────────────────────────── */
.cand-card {
    background: var(--mn-card);
    border: 1px solid var(--mn-line);
    border-radius: var(--mn-radius);
    padding: 20px 18px;
    box-shadow: var(--mn-shadow);
}
.cand-card h2 {
    font-family: var(--mn-display);
    text-transform: uppercase;
    letter-spacing: .5px;
    font-size: 22px;
    margin: 0 0 4px;
    color: #fff;
}
.cand-hint { color: var(--mn-text-dim); font-size: 13.5px; line-height: 1.5; margin: 0 0 16px; }

.cand-lbl {
    display: block;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .6px;
    color: var(--mn-text-faint);
    font-weight: 700;
    margin: 14px 0 6px;
}

.cand-input,
.cand-textarea {
    width: 100%;
    box-sizing: border-box;
    background: var(--mn-bg-2);
    border: 1px solid var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    color: var(--mn-text);
    padding: 12px 13px;
    font-size: 16px; /* 16px evita zoom automatico en iOS */
    font-family: inherit;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
}
.cand-input:focus,
.cand-textarea:focus {
    border-color: var(--mn-green);
    box-shadow: 0 0 0 3px var(--mn-green-glow);
}
.cand-textarea { resize: vertical; min-height: 92px; line-height: 1.5; }

/* ── Chips (multiseleccion / si-no) ─────────────────────────────────────── */
.cand-chips { display: flex; flex-wrap: wrap; gap: 9px; }
.cand-chips-col { flex-direction: column; }
.cand-chips-row { flex-direction: row; }
.cand-wrap-chips { flex-wrap: wrap; }
.cand-chip {
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text);
    border-radius: 999px;
    padding: 11px 16px;
    font-size: 14.5px;
    font-weight: 600;
    cursor: pointer;
    text-align: left;
    transition: border-color .15s, background .15s, color .15s, box-shadow .15s;
    font-family: inherit;
}
.cand-chips-row .cand-chip { flex: 1; text-align: center; }
.cand-wrap-chips .cand-chip { flex: 0 1 auto; }
.cand-chips-col .cand-chip { border-radius: var(--mn-radius-sm); width: 100%; }
.cand-chip:hover { border-color: var(--mn-green-dim); }
.cand-chip.on {
    border-color: var(--mn-green);
    background: rgba(43,217,107,.12);
    color: var(--mn-green);
    box-shadow: 0 0 0 1px var(--mn-green) inset, 0 0 12px var(--mn-green-glow);
}

/* ── Sucursales (lista seleccionable, nombre arriba + direccion abajo) ───── */
.cand-suclist { display: flex; flex-direction: column; gap: 9px; }
.cand-suc {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    border-radius: var(--mn-radius-sm);
    padding: 12px 14px;
    cursor: pointer;
    text-align: left;
    transition: border-color .15s, background .15s, box-shadow .15s;
    font-family: inherit;
}
.cand-suc:hover { border-color: var(--mn-green-dim); }
.cand-suc.on {
    border-color: var(--mn-green);
    background: rgba(43,217,107,.10);
    box-shadow: 0 0 0 1px var(--mn-green) inset, 0 0 12px var(--mn-green-glow);
}
.cand-suc-check {
    flex: 0 0 24px;
    width: 24px; height: 24px;
    border-radius: 50%;
    border: 2px solid var(--mn-line-2);
    display: flex; align-items: center; justify-content: center;
    color: #07120b; font-weight: 800; font-size: 14px;
    transition: background .15s, border-color .15s;
}
.cand-suc.on .cand-suc-check { background: var(--mn-green); border-color: var(--mn-green); }
.cand-suc-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
.cand-suc-name { font-weight: 700; font-size: 15px; color: var(--mn-text); line-height: 1.2; }
.cand-suc.on .cand-suc-name { color: var(--mn-green); }
.cand-suc-dir { font-size: 12.5px; color: var(--mn-text-dim); line-height: 1.2; }
.cand-suc-badge {
    flex: 0 0 auto;
    font-size: 10.5px; font-weight: 700; letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--mn-amber);
    background: rgba(240,180,41,.12);
    border: 1px solid rgba(240,180,41,.35);
    border-radius: 999px;
    padding: 3px 9px;
}

/* ── Turnos (3 tarjetas) ────────────────────────────────────────────────── */
.cand-turnos { display: flex; flex-direction: column; gap: 9px; }
.cand-turno {
    display: flex; align-items: baseline; justify-content: space-between;
    gap: 10px; width: 100%;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    border-radius: var(--mn-radius-sm);
    padding: 13px 16px;
    cursor: pointer;
    transition: border-color .15s, background .15s, box-shadow .15s;
    font-family: inherit;
}
.cand-turno:hover { border-color: var(--mn-green-dim); }
.cand-turno.on {
    border-color: var(--mn-green);
    background: rgba(43,217,107,.10);
    box-shadow: 0 0 0 1px var(--mn-green) inset, 0 0 12px var(--mn-green-glow);
}
.cand-turno-name { font-weight: 700; font-size: 15px; color: var(--mn-text); }
.cand-turno.on .cand-turno-name { color: var(--mn-green); }
.cand-turno-hr { font-size: 13px; color: var(--mn-text-dim); font-variant-numeric: tabular-nums; }

/* ── Tiempo de traslado por sucursal ────────────────────────────────────── */
.cand-traslados { display: flex; flex-direction: column; gap: 8px; }
.cand-traslado {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px;
    border: 1px solid var(--mn-line);
    background: var(--mn-bg-2);
    border-radius: var(--mn-radius-sm);
    padding: 9px 12px 9px 14px;
}
.cand-traslado-name { font-weight: 600; font-size: 14px; color: var(--mn-text); min-width: 0; flex: 1; }
.cand-traslado-input { display: flex; align-items: center; gap: 7px; flex: 0 0 auto; }
.cand-input-min { width: 72px; text-align: center; margin: 0; padding: 9px 8px; }
.cand-traslado-unit { font-size: 13px; color: var(--mn-text-dim); }

/* ── Grilla de estudio (dias x franjas) ─────────────────────────────────── */
.cand-grilla {
    border: 1px solid var(--mn-line);
    border-radius: var(--mn-radius-sm);
    padding: 10px;
    background: var(--mn-bg-2);
    overflow-x: auto;
}
.cand-grilla-head, .cand-grilla-row {
    display: grid;
    grid-template-columns: 58px repeat(7, 1fr);
    gap: 5px;
    align-items: center;
}
.cand-grilla-head { margin-bottom: 5px; }
.cand-grilla-row { margin-bottom: 5px; }
.cand-grilla-row:last-child { margin-bottom: 0; }
.cand-grilla-dia {
    text-align: center; font-size: 11.5px; font-weight: 700;
    color: var(--mn-text-dim); text-transform: uppercase; letter-spacing: .02em;
}
.cand-grilla-franja { font-size: 12px; font-weight: 600; color: var(--mn-text-dim); }
.cand-celda {
    height: 34px; min-width: 0;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-card);
    border-radius: 7px;
    cursor: pointer; padding: 0;
    transition: background .12s, border-color .12s, box-shadow .12s;
}
.cand-celda:hover { border-color: var(--mn-red-soft); }
.cand-celda.on {
    background: var(--mn-red);
    border-color: var(--mn-red-soft);
    box-shadow: 0 0 8px var(--mn-red-glow);
}

/* ── Uploads (CV / audio) ───────────────────────────────────────────────── */
.cand-upload {
    border: 1.5px dashed var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    padding: 14px;
    background: var(--mn-bg-2);
    transition: border-color .15s, background .15s;
}
.cand-upload.ok { border-color: var(--mn-green); border-style: solid; background: rgba(43,217,107,.06); }

/* ── Grid de 2 columnas (edad + whatsapp) ───────────────────────────────── */
.cand-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cand-grid2 > div { min-width: 0; }

/* ── Info de paso ───────────────────────────────────────────────────────── */
.cand-stepinfo {
    text-align: center; font-size: 12px; color: var(--mn-text-faint);
    margin: 6px 0 14px; letter-spacing: .02em;
}

/* ── Checkboxes de condiciones ──────────────────────────────────────────── */
.cand-checkrow {
    display: flex;
    align-items: flex-start;
    gap: 11px;
    padding: 12px;
    border: 1px solid var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    background: var(--mn-bg-2);
    margin-bottom: 9px;
    cursor: pointer;
    transition: border-color .15s;
}
.cand-checkrow:hover { border-color: var(--mn-line); }
.cand-check {
    flex: 0 0 auto;
    width: 20px; height: 20px;
    margin-top: 1px;
    accent-color: var(--mn-green);
    cursor: pointer;
}
.cand-checkrow span { font-size: 14px; line-height: 1.45; }

/* ── Manual ─────────────────────────────────────────────────────────────── */
.cand-manual {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--mn-bg-2);
    border: 1px solid var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    padding: 14px;
    margin: 6px 0 4px;
}

/* ── Archivo (CV / audio) ───────────────────────────────────────────────── */
.cand-file {
    display: block;
    border: 1px dashed var(--mn-line-2);
    border-radius: var(--mn-radius-sm);
    background: var(--mn-bg-2);
    padding: 16px;
    text-align: center;
    color: var(--mn-text-dim);
    font-size: 14px;
    transition: border-color .15s, color .15s;
}
.cand-file:hover { border-color: var(--mn-green-dim); color: var(--mn-text); }

/* ── Botones nav ────────────────────────────────────────────────────────── */
.cand-nav { display: flex; gap: 10px; margin-top: 22px; }
.cand-btn,
.cand-btn-green,
.cand-btn-line {
    flex: 1;
    border: none;
    border-radius: var(--mn-radius-sm);
    padding: 14px 18px;
    font-size: 15.5px;
    font-weight: 800;
    letter-spacing: .3px;
    cursor: pointer;
    font-family: inherit;
    transition: transform .08s, filter .15s, box-shadow .15s;
}
.cand-btn { background: var(--mn-red); color: #fff; box-shadow: 0 6px 18px var(--mn-red-glow); }
.cand-btn:hover { filter: brightness(1.08); }
.cand-btn:active { transform: translateY(1px); }
.cand-btn-green { background: var(--mn-green); color: #04130a; box-shadow: 0 6px 18px var(--mn-green-glow); }
.cand-btn-green:hover { filter: brightness(1.06); }
.cand-btn-green:active { transform: translateY(1px); }
.cand-btn-line { background: transparent; color: var(--mn-text-dim); border: 1px solid var(--mn-line-2); box-shadow: none; }
.cand-btn-line:hover { border-color: var(--mn-text-faint); color: var(--mn-text); }
.cand-btn:disabled,
.cand-btn-green:disabled { opacity: .5; cursor: not-allowed; filter: none; transform: none; }

.cand-error {
    margin-top: 14px;
    color: var(--mn-red-soft);
    font-size: 13.5px;
    font-weight: 600;
    text-align: center;
}

/* Confirmación inline de archivo cargado */
.cand-filedone {
    color: var(--mn-green);
    font-size: 13.5px;
    font-weight: 700;
    margin: 8px 0 0;
}

/* Honeypot anti-bots: fuera de pantalla, invisible e inaccesible para personas */
.cand-trampa {
    position: absolute !important;
    left: -9999px !important;
    top: -9999px !important;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

/* ── Pantalla final (ok) ────────────────────────────────────────────────── */
.cand-center { text-align: center; padding: 30px 12px; }
.cand-ok {
    width: 78px; height: 78px;
    margin: 0 auto 18px;
    border-radius: 50%;
    background: rgba(43,217,107,.12);
    border: 2px solid var(--mn-green);
    display: flex; align-items: center; justify-content: center;
    font-size: 38px; color: var(--mn-green);
    box-shadow: 0 0 24px var(--mn-green-glow);
}

/* ── Guia de preguntas del audio ────────────────────────────────────────── */
.cand-guia-toggle {
    width: 100%; text-align: left;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text-dim);
    border-radius: var(--mn-radius-sm);
    padding: 11px 14px; font-size: 13.5px; font-weight: 600;
    cursor: pointer; font-family: inherit;
    transition: border-color .15s, color .15s;
}
.cand-guia-toggle:hover { border-color: var(--mn-green-dim); color: var(--mn-text); }
.cand-guia {
    border: 1px solid var(--mn-line);
    border-left: 3px solid var(--mn-green);
    background: var(--mn-bg-2);
    border-radius: var(--mn-radius-sm);
    padding: 12px 14px 12px 8px;
    margin-top: 8px;
}
.cand-guia-intro { font-size: 13px; color: var(--mn-text-dim); margin: 0 0 8px 8px; }
.cand-guia-list { margin: 0; padding-left: 26px; }
.cand-guia-list li { font-size: 13px; color: var(--mn-text); line-height: 1.45; margin-bottom: 7px; }
.cand-guia-list li::marker { color: var(--mn-green); font-weight: 700; }

/* ── Grabacion de audio ─────────────────────────────────────────────────── */
.cand-rec { display: flex; align-items: center; gap: 12px; margin-bottom: 9px; }
.cand-rec-btn {
    flex: 1;
    border: 1px solid var(--mn-red-soft);
    background: rgba(200,30,46,.10);
    color: var(--mn-red-soft);
    border-radius: var(--mn-radius-sm);
    padding: 13px 16px; font-size: 15px; font-weight: 700;
    cursor: pointer; font-family: inherit;
    transition: background .15s, box-shadow .15s, border-color .15s;
}
.cand-rec-btn:hover { background: rgba(200,30,46,.18); }
.cand-rec-btn:disabled { opacity: .5; cursor: not-allowed; }
.cand-rec-btn.rec-on {
    border-color: var(--mn-red);
    background: var(--mn-red);
    color: #fff;
    animation: recPulse 1.4s ease-in-out infinite;
}
@keyframes recPulse {
    0%, 100% { box-shadow: 0 0 0 0 var(--mn-red-glow); }
    50% { box-shadow: 0 0 0 7px rgba(200,30,46,0); }
}
.cand-rec-time { font-variant-numeric: tabular-nums; margin-left: 6px; opacity: .9; }
.cand-rec-sep { font-size: 12px; color: var(--mn-text-faint); text-transform: uppercase; letter-spacing: .05em; }
.cand-rec-err { color: var(--mn-amber); }

/* ===== P3: selfie preview (wizard) + selfie admin + grabacion minima ===== */
.cand-selfie-preview {
    display: block;
    max-width: 180px;
    max-height: 220px;
    border-radius: 12px;
    margin-top: 10px;
    border: 2px solid var(--mn-green, #2bd96b);
    object-fit: cover;
}
.post-selfie {
    display: block;
    max-width: 240px;
    max-height: 300px;
    border-radius: 10px;
    margin: 8px 0 4px;
    border: 1px solid rgba(0,0,0,.12);
    object-fit: cover;
    cursor: zoom-in;
}
/* Estado "grabando pero todavia no llego al minimo de 30s" */
.cand-rec-btn.rec-min {
    background: #c8102e;
    opacity: .92;
}

/* P3: checkbox del manual deshabilitado hasta descargar */
.cand-checkrow.cand-disabled { opacity: .5; }
.cand-checkrow.cand-disabled span { color: #888; }

/* ═══════════════════════════════════════════════════════════════
   P3 · EXPERIENCIA FASCINANTE — animaciones, dinámica y microinteracciones
   Todo degrada con elegancia y respeta prefers-reduced-motion.
   ═══════════════════════════════════════════════════════════════ */

/* ---- Fondo con sutil gradiente vivo ---- */
.cand-bg {
    position: relative;
    overflow-x: clip;
}
.cand-bg::before {
    content: "";
    position: fixed;
    inset: 0;
    background:
        radial-gradient(60vw 60vw at 15% -10%, rgba(200,16,46,.10), transparent 60%),
        radial-gradient(50vw 50vw at 110% 10%, rgba(200,16,46,.07), transparent 55%);
    pointer-events: none;
    z-index: 0;
    animation: cand-bg-breathe 14s ease-in-out infinite;
}
@keyframes cand-bg-breathe {
    0%,100% { opacity: .8; transform: translateY(0); }
    50%     { opacity: 1;  transform: translateY(-12px); }
}
.cand-wrap { position: relative; z-index: 1; }

/* ---- Entrada de la tarjeta ---- */
.cand-card {
    animation: cand-card-in var(--t-slow) var(--ease-out) both;
}
@keyframes cand-card-in {
    from { opacity: 0; transform: translateY(14px) scale(.985); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ---- Transición entre pasos (el wrapper cambia de @key) ---- */
.cand-step-anim {
    animation: cand-step-in var(--t-base) var(--ease-soft) both;
}
@keyframes cand-step-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ---- Barra de progreso: gradiente animado + brillo en el activo ---- */
.cand-bar {
    transition: background var(--t-mid) var(--ease-soft), transform var(--t-mid) var(--ease-out), box-shadow var(--t-mid) var(--ease-soft);
    border-radius: 99px;
}
.cand-bar.done {
    background: linear-gradient(90deg, #c8102e, #ff3b5c);
    background-size: 200% 100%;
    animation: cand-bar-fill .6s ease both;
}
.cand-bar.on {
    background: linear-gradient(90deg, #c8102e, #ff3b5c, #c8102e);
    background-size: 200% 100%;
    transform: scaleY(1.5);
    box-shadow: 0 0 12px rgba(200,16,46,.5);
    animation: cand-bar-shimmer 2s linear infinite;
}
@keyframes cand-bar-fill { from { background-position: 100% 0; } to { background-position: 0 0; } }
@keyframes cand-bar-shimmer { from { background-position: 0 0; } to { background-position: 200% 0; } }

/* ---- Inputs: foco con realce suave ---- */
.cand-input, .cand-textarea {
    transition: border-color var(--t-base) var(--ease-soft), box-shadow var(--t-base) var(--ease-soft), transform var(--t-fast) var(--ease-soft);
}
.cand-input:focus, .cand-textarea:focus {
    box-shadow: 0 0 0 4px rgba(200,16,46,.12);
    transform: translateY(-1px);
}

/* ---- Chips Sí/No: rebote sutil al activar ---- */
.cand-chip {
    transition: transform var(--t-base) var(--ease-pop), background var(--t-base) var(--ease-soft), color var(--t-base) var(--ease-soft), border-color var(--t-base) var(--ease-soft);
}
.cand-chip:active { transform: scale(.94); }
.cand-chip.on { animation: cand-chip-pop var(--t-base) var(--ease-pop) both; }
@keyframes cand-chip-pop {
    0% { transform: scale(.9); } 60% { transform: scale(1.06); } 100% { transform: scale(1); }
}

/* ---- Zona de subida (CV/audio/selfie): hover y estado OK ---- */
.cand-upload {
    transition: border-color var(--t-base) var(--ease-soft), background var(--t-base) var(--ease-soft), transform var(--t-fast) var(--ease-soft);
}
.cand-upload:hover { transform: translateY(-2px); }
.cand-upload.ok { animation: cand-upload-ok var(--t-mid) var(--ease-out) both; }
@keyframes cand-upload-ok {
    0% { transform: scale(.97); } 55% { transform: scale(1.02); } 100% { transform: scale(1); }
}

/* ---- "✓ listo" aparece con check dibujado ---- */
.cand-filedone {
    animation: cand-done-in var(--t-mid) ease both;
}
@keyframes cand-done-in {
    from { opacity: 0; transform: translateX(-8px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* ---- Preview de selfie: entra con zoom suave ---- */
.cand-selfie-preview {
    animation: cand-selfie-in var(--t-mid) var(--ease-out) both;
}
@keyframes cand-selfie-in {
    from { opacity: 0; transform: scale(.85) rotate(-2deg); }
    to   { opacity: 1; transform: scale(1) rotate(0); }
}

/* ---- Botón de grabar: pulso latente cuando graba ---- */
.cand-rec-btn.rec-on {
    position: relative;
    animation: cand-rec-pulse 1.3s ease-in-out infinite;
}
@keyframes cand-rec-pulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(200,16,46,.45); }
    50%     { box-shadow: 0 0 0 10px rgba(200,16,46,0); }
}
.cand-rec-time { font-variant-numeric: tabular-nums; }

/* ---- Aviso de validación: shake corto para llamar la atención ---- */
.cand-error, .cand-rec-err {
    animation: cand-shake .4s cubic-bezier(.36,.07,.19,.97) both;
}
@keyframes cand-shake {
    10%,90% { transform: translateX(-1px); }
    20%,80% { transform: translateX(2px); }
    30%,50%,70% { transform: translateX(-4px); }
    40%,60% { transform: translateX(4px); }
}

/* ---- Botones de navegación: feedback al presionar ---- */
.cand-btn-green, .cand-btn-line {
    transition: transform var(--t-fast) var(--ease-soft), box-shadow var(--t-base) var(--ease-soft), filter var(--t-base) var(--ease-soft);
}
.cand-btn-green:active, .cand-btn-line:active { transform: scale(.96); }
.cand-btn-green:hover { filter: brightness(1.05); box-shadow: 0 6px 20px rgba(43,217,107,.3); }

/* ---- PANTALLA DE ÉXITO: check que se dibuja + confeti ---- */
.cand-success { position: relative; overflow: hidden; }
.cand-ok {
    animation: cand-ok-pop var(--t-slow) var(--ease-pop) both;
}
@keyframes cand-ok-pop {
    0% { transform: scale(0) rotate(-30deg); opacity: 0; }
    60% { transform: scale(1.15) rotate(6deg); opacity: 1; }
    100% { transform: scale(1) rotate(0); opacity: 1; }
}
.cand-success h2 { animation: cand-done-in var(--t-mid) .15s ease both; }
.cand-success p  { animation: cand-done-in var(--t-mid) .3s ease both; }

/* Confeti: 24 piezas cayendo, 6 colores/tiempos distintos */
.cand-confetti {
    position: absolute; inset: 0; pointer-events: none; overflow: hidden;
}
.cand-conf {
    position: absolute; top: -12px; width: 9px; height: 14px; border-radius: 2px;
    opacity: 0;
    animation: cand-fall 2.6s ease-in forwards;
}
.cand-conf-0 { left: 8%;  background: #c8102e; animation-delay: .05s; }
.cand-conf-1 { left: 22%; background: #ff3b5c; animation-delay: .25s; }
.cand-conf-2 { left: 38%; background: #2bd96b; animation-delay: .12s; }
.cand-conf-3 { left: 54%; background: #ffd23f; animation-delay: .32s; }
.cand-conf-4 { left: 70%; background: #3fa9ff; animation-delay: .18s; }
.cand-conf-5 { left: 86%; background: #c8102e; animation-delay: .4s; }
.cand-conf:nth-child(7)  { top: -20px; left: 15%; }
.cand-conf:nth-child(8)  { left: 30%; }
.cand-conf:nth-child(9)  { left: 46%; }
.cand-conf:nth-child(10) { left: 62%; }
.cand-conf:nth-child(11) { left: 78%; }
.cand-conf:nth-child(12) { left: 92%; }
.cand-conf:nth-child(n+13) { width: 7px; height: 11px; }
@keyframes cand-fall {
    0%   { opacity: 0; transform: translateY(-10px) rotate(0); }
    10%  { opacity: 1; }
    100% { opacity: 0; transform: translateY(360px) rotate(540deg); }
}

/* ---- Edad calculada: aparece con fade ---- */
.cand-hint { transition: opacity var(--t-base) var(--ease-soft); }


/* ═══════ MEJORAS EXPERTAS P3 (alto impacto, GPU-friendly) ═══════ */

/* 1) Entrada escalonada de los campos dentro de cada paso (stagger).
   Cada hijo directo del paso aparece con un pequeño retraso incremental. */
.cand-step-anim > * {
    animation: cand-field-in var(--t-mid) var(--ease-out) both;
}
.cand-step-anim > *:nth-child(1) { animation-delay: .06s; }
.cand-step-anim > *:nth-child(2) { animation-delay: .12s; }
.cand-step-anim > *:nth-child(3) { animation-delay: .18s; }
.cand-step-anim > *:nth-child(4) { animation-delay: .24s; }
.cand-step-anim > *:nth-child(5) { animation-delay: .30s; }
.cand-step-anim > *:nth-child(6) { animation-delay: .36s; }
.cand-step-anim > *:nth-child(7) { animation-delay: .42s; }
.cand-step-anim > *:nth-child(n+8) { animation-delay: .48s; }
@keyframes cand-field-in {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* 2) Contador de grabacion: ROJO mientras falta, VERDE cuando ya llego a 30s.
   Da feedback instantaneo de "ya podes guardar". */
.cand-rec-btn.rec-min .cand-rec-time { color: #ffd23f; }            /* ambar: contando */
.cand-rec-btn.rec-on:not(.rec-min) .cand-rec-time {
    color: #7CFFB0;                                                  /* verde: habilitado */
    text-shadow: 0 0 10px rgba(43,217,107,.5);
}
/* El boton cambia de borde/halo al cruzar el minimo */
.cand-rec-btn.rec-on:not(.rec-min) {
    box-shadow: 0 0 0 2px rgba(43,217,107,.5), 0 6px 20px rgba(43,217,107,.25);
}

/* 3) Brillo recorriendo los botones primarios al pasar el mouse (shine sweep) */
.cand-btn-green {
    position: relative;
    overflow: hidden;
}
.cand-btn-green::after {
    content: "";
    position: absolute; top: 0; left: -120%;
    width: 60%; height: 100%;
    background: linear-gradient(115deg, transparent, rgba(255,255,255,.28), transparent);
    transform: skewX(-18deg);
    transition: left var(--t-slow) var(--ease-soft);
}
.cand-btn-green:hover::after { left: 140%; }

/* 4) Selfie preview: halo verde latente + leve zoom al pasar el mouse */
.cand-selfie-preview {
    box-shadow: 0 0 0 2px rgba(43,217,107,.4), 0 8px 24px rgba(0,0,0,.4);
    transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-soft);
}
.cand-selfie-preview:hover {
    transform: scale(1.03);
    box-shadow: 0 0 0 3px rgba(43,217,107,.6), 0 12px 30px rgba(0,0,0,.5);
}

/* 5) Chips Si/No: glow de color segun seleccion */
.cand-chip.on {
    box-shadow: 0 0 14px rgba(200,16,46,.35);
}

/* 6) El "Paso X de Y" cambia con un fade sutil */
.cand-stepinfo { transition: opacity var(--t-base) var(--ease-soft); }

/* ═══════ ACCESIBILIDAD: respetar preferencia de menos movimiento ═══════ */
@media (prefers-reduced-motion: reduce) {
    .cand-bg::before,
    .cand-card, .cand-step-anim, .cand-step-anim > *, .cand-bar.done, .cand-bar.on,
    .cand-chip.on, .cand-upload.ok, .cand-filedone, .cand-selfie-preview,
    .cand-rec-btn.rec-on, .cand-error, .cand-rec-err,
    .cand-ok, .cand-success h2, .cand-success p, .cand-conf {
        animation: none !important;
    }
    .cand-input:focus, .cand-textarea:focus, .cand-chip:active,
    .cand-btn-green:active, .cand-btn-line:active, .cand-upload:hover,
    .cand-selfie-preview:hover {
        transform: none !important;
    }
    .cand-btn-green::after { display: none !important; }
}

/* ═══════ PANEL ADMIN: vida sutil (post-*) ═══════ */
/* Tarjetas de la ficha entran con un fade-up escalonado al abrir el detalle */
.post-card {
    animation: post-card-in var(--t-mid) var(--ease-out) both;
}
.post-grid > .post-card:nth-child(1) { animation-delay: .02s; }
.post-grid > .post-card:nth-child(2) { animation-delay: .08s; }
.post-grid > .post-card:nth-child(3) { animation-delay: .14s; }
.post-grid > .post-card:nth-child(n+4) { animation-delay: .2s; }
@keyframes post-card-in {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}
/* La selfie del admin: zoom suave al pasar el mouse (para mirarla mejor) */
.post-selfie { transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-soft); }
.post-selfie:hover { transform: scale(1.04); box-shadow: 0 10px 28px rgba(0,0,0,.4); }
/* Botones del admin: feedback al presionar */
.post-btn { transition: transform var(--t-fast) var(--ease-soft), filter var(--t-base) var(--ease-soft), background var(--t-base) var(--ease-soft); }
.post-btn:active { transform: scale(.96); }

@media (prefers-reduced-motion: reduce) {
    .post-card { animation: none !important; }
    .post-selfie:hover, .post-btn:active { transform: none !important; }
}

/* ═══════ PULIDO MILIMÉTRICO FINAL (armonía de ritmo y foco) ═══════ */

/* El primer elemento de cada paso no necesita margen superior extra:
   el h2 ya da el aire. Evita el "salto" al entrar a un paso. */
.cand-step-anim > h2:first-child { margin-top: 2px; }

/* Ritmo vertical consistente: el h2 de cada paso respira igual siempre */
.cand-step-anim > h2 {
    margin: 0 0 4px;
    line-height: 1.2;
}

/* Al volver el foco a la tarjeta tras cambiar de paso, scroll suave arriba.
   (scroll-margin para que el sticky header no tape el inicio del paso) */
.cand-card { scroll-margin-top: 12px; }
html { scroll-behavior: smooth; }

/* Coherencia de glow: TODOS los realces de foco/seleccion usan el mismo
   tinte rojo de marca, misma intensidad. Unifica la "luz" del wizard. */
.cand-input:focus,
.cand-textarea:focus {
    border-color: var(--mn-red-soft);
}

/* Los botones de navegacion comparten exactamente el mismo lift al hover,
   para que se sientan "del mismo material". */
.cand-btn-line:hover { filter: brightness(1.08); }

/* El check verde de "listo" y la selfie comparten el mismo verde de marca
   en sus halos (ya usan var --mn-green*), reforzamos consistencia del radio. */
.cand-filedone { border-radius: var(--mn-radius-sm); }

/* prefers-reduced-motion: desactivar el smooth-scroll tambien */
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
}

/* ═══════════════════════════════════════════════════════════════
   REDISEÑO ADMIN — LISTADO DE FICHAS (pa-* = postulantes admin)
   ═══════════════════════════════════════════════════════════════ */

.pa-wrap { max-width: 1080px; }

/* ── Métricas del header ── */
.pa-stats {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 10px;
    margin: 4px 0 18px;
}
.pa-stat {
    background: var(--mn-card);
    border: 1px solid var(--mn-line);
    border-radius: var(--mn-radius-sm);
    padding: 12px 10px;
    text-align: center;
    animation: post-card-in var(--t-mid) var(--ease-out) both;
}
.pa-stat-n {
    display: block;
    font-family: var(--mn-display);
    font-size: 26px;
    line-height: 1;
    color: var(--mn-text);
}
.pa-stat-l {
    display: block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mn-text-faint);
    margin-top: 4px;
}

/* ── Toolbar: búsqueda + orden + toggle de filtros ── */
.pa-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}
.pa-search {
    position: relative;
    flex: 1 1 280px;
    min-width: 220px;
}
.pa-search-ico {
    position: absolute;
    left: 12px; top: 50%;
    transform: translateY(-50%);
    opacity: .6;
    pointer-events: none;
}
.pa-search-input { padding-left: 38px !important; width: 100%; }

.pa-order {
    display: flex;
    align-items: center;
    gap: 8px;
}
.pa-order-lbl {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mn-text-faint);
    white-space: nowrap;
}
.pa-order-sel { min-width: 168px; }
.pa-dir {
    width: 42px; height: 42px;
    flex: none;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text);
    border-radius: var(--mn-radius-sm);
    font-size: 18px;
    cursor: pointer;
    transition: transform var(--t-fast) var(--ease-pop), border-color var(--t-base) var(--ease-soft), background var(--t-base) var(--ease-soft);
}
.pa-dir:hover { border-color: var(--mn-red-soft); }
.pa-dir:active { transform: scale(.9); }

.pa-adv-toggle { white-space: nowrap; }

/* ── Filtros avanzados ── */
.pa-filtros-adv { animation: cand-field-in var(--t-mid) var(--ease-out) both; }
.pa-fgrid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px 14px;
    margin-bottom: 14px;
}
.pa-fcol { display: flex; flex-direction: column; }
.pa-range { display: flex; align-items: center; gap: 8px; }
.pa-range .post-input { width: 100%; }
.pa-range span { color: var(--mn-text-faint); }

.pa-chips-filtro {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px;
}
.pa-chk {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 8px 14px;
    border: 1px solid var(--mn-line-2);
    border-radius: 999px;
    background: var(--mn-bg-2);
    color: var(--mn-text-dim);
    font-size: 13.5px;
    cursor: pointer;
    user-select: none;
    transition: border-color var(--t-base) var(--ease-soft), background var(--t-base) var(--ease-soft), color var(--t-base) var(--ease-soft), transform var(--t-fast) var(--ease-pop);
}
.pa-chk input { accent-color: var(--mn-green); margin: 0; }
.pa-chk.on {
    border-color: var(--mn-green);
    background: rgba(43,217,107,.1);
    color: var(--mn-text);
}
.pa-chk:active { transform: scale(.96); }

.pa-fadv-actions { display: flex; gap: 10px; }

/* ── Grid de cards ── */
.pa-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
    gap: 14px;
}
.pa-card {
    background: var(--mn-card);
    border: 1px solid var(--mn-line);
    border-radius: var(--mn-radius);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    position: relative;
    overflow: hidden;
    animation: pa-card-in var(--t-mid) var(--ease-out) both;
    transition: border-color var(--t-base) var(--ease-soft), transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-soft);
}
.pa-card:hover {
    border-color: var(--mn-line-2);
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
/* Borde de acento para fichas completas */
.pa-card.completo::before {
    content: "";
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 3px;
    background: linear-gradient(90deg, var(--mn-green), transparent);
}
@keyframes pa-card-in {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}
/* Stagger de aparición de las cards */
.pa-cards > .pa-card:nth-child(1) { animation-delay: .03s; }
.pa-cards > .pa-card:nth-child(2) { animation-delay: .07s; }
.pa-cards > .pa-card:nth-child(3) { animation-delay: .11s; }
.pa-cards > .pa-card:nth-child(4) { animation-delay: .15s; }
.pa-cards > .pa-card:nth-child(5) { animation-delay: .19s; }
.pa-cards > .pa-card:nth-child(6) { animation-delay: .23s; }
.pa-cards > .pa-card:nth-child(n+7) { animation-delay: .26s; }

/* Top: avatar + nombre + estado */
.pa-card-top { display: flex; align-items: flex-start; gap: 12px; }
.pa-avatar {
    width: 46px; height: 46px;
    flex: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--mn-display);
    font-size: 18px;
    color: #fff;
    letter-spacing: .5px;
    box-shadow: 0 2px 10px rgba(0,0,0,.3);
}
.pa-card-id { flex: 1; min-width: 0; }
.pa-nombre {
    margin: 0 0 5px;
    font-size: 17px;
    line-height: 1.2;
    color: var(--mn-text);
    word-break: break-word;
}
.pa-sub { display: flex; flex-wrap: wrap; gap: 6px; }
.pa-pill {
    font-size: 12px;
    padding: 3px 9px;
    border-radius: 999px;
    background: var(--mn-bg-2);
    border: 1px solid var(--mn-line);
    color: var(--mn-text-dim);
    white-space: nowrap;
}
.pa-pill-time { color: var(--mn-amber); border-color: rgba(245,158,11,.3); }
.pa-estado { flex: none; align-self: flex-start; }

/* Mid: metadatos */
.pa-card-mid {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 10px 0;
    border-top: 1px solid var(--mn-line);
    border-bottom: 1px solid var(--mn-line);
}
.pa-meta-line { display: flex; gap: 10px; font-size: 13.5px; }
.pa-meta-k {
    flex: none;
    width: 88px;
    color: var(--mn-text-faint);
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: .4px;
    padding-top: 2px;
}
.pa-meta-v { color: var(--mn-text-dim); flex: 1; }

/* Badges de completitud */
.pa-card-badges { display: flex; flex-wrap: wrap; gap: 6px; }
.pa-badge {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .3px;
    padding: 4px 9px;
    border-radius: 6px;
    text-transform: uppercase;
}
.pa-badge.ok  { background: rgba(43,217,107,.14); color: #7CFFB0; border: 1px solid rgba(43,217,107,.3); }
.pa-badge.off { background: rgba(255,255,255,.04); color: var(--mn-text-faint); border: 1px solid var(--mn-line); }
.pa-badge.wa  { background: rgba(37,211,102,.12); color: #25D366; border: 1px solid rgba(37,211,102,.3); }

/* Foot: fecha + acciones */
.pa-card-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.pa-fecha { font-size: 12px; color: var(--mn-text-faint); }
.pa-card-actions { display: flex; gap: 7px; align-items: center; }
.pa-act {
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text);
    border-radius: var(--mn-radius-sm);
    padding: 8px 12px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    transition: transform var(--t-fast) var(--ease-soft), background var(--t-base) var(--ease-soft), border-color var(--t-base) var(--ease-soft), filter var(--t-base) var(--ease-soft);
}
.pa-act:active { transform: scale(.94); }
.pa-act-wa { color: #25D366; border-color: rgba(37,211,102,.3); }
.pa-act-wa:hover { background: rgba(37,211,102,.1); }
.pa-act-zip { color: var(--mn-amber); border-color: rgba(245,158,11,.3); }
.pa-act-zip:hover { background: rgba(245,158,11,.1); }
.pa-act-ver { background: var(--mn-red); border-color: var(--mn-red); color: #fff; }
.pa-act-ver:hover { filter: brightness(1.1); }

/* Loading + empty */
.pa-loading {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 40px;
    justify-content: center;
    color: var(--mn-text-dim);
}
.pa-spinner {
    width: 22px; height: 22px;
    border: 3px solid var(--mn-line-2);
    border-top-color: var(--mn-red);
    border-radius: 50%;
    animation: pa-spin .8s linear infinite;
}
@keyframes pa-spin { to { transform: rotate(360deg); } }
.pa-empty { text-align: center; padding: 40px 20px; }
.pa-empty-ico { font-size: 40px; margin-bottom: 10px; opacity: .7; }

/* ── Responsive ── */
@media (max-width: 720px) {
    .pa-stats { grid-template-columns: repeat(3, 1fr); }
    .pa-toolbar { flex-direction: column; align-items: stretch; }
    .pa-order { justify-content: space-between; }
    .pa-cards { grid-template-columns: 1fr; }
}
@media (max-width: 420px) {
    .pa-stats { grid-template-columns: repeat(2, 1fr); }
    .pa-card-foot { flex-direction: column; align-items: stretch; }
    .pa-card-actions { justify-content: flex-end; }
}

@media (prefers-reduced-motion: reduce) {
    .pa-stat, .pa-card, .pa-filtros-adv { animation: none !important; }
    .pa-card:hover, .pa-dir:active, .pa-chk:active, .pa-act:active { transform: none !important; }
    .pa-spinner { animation-duration: 2s; }
}

/* ═══════════════════════════════════════════════════════════════
   ETAPA DE COCINA + ÁREA DE INTERÉS (wizard)
   ═══════════════════════════════════════════════════════════════ */

/* Área de interés (cocina / salón / ambas) + experiencia cocina */
.cand-areas, .cand-cocina-exp {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 8px 0 4px;
}
.cand-area {
    width: 100%;
    text-align: left;
    padding: 14px 16px;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text);
    border-radius: var(--mn-radius-sm);
    font-size: 15px;
    cursor: pointer;
    transition: border-color var(--t-base) var(--ease-soft), background var(--t-base) var(--ease-soft), transform var(--t-fast) var(--ease-pop);
}
.cand-area:hover { border-color: var(--mn-green-dim); }
.cand-area:active { transform: scale(.98); }
.cand-area.on {
    border-color: var(--mn-green);
    background: rgba(43,217,107,.1);
}

/* Escalas de respuesta (opciones únicas) */
.cand-escala {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 6px 0 4px;
}
.cand-op {
    width: 100%;
    text-align: left;
    padding: 12px 15px;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text-dim);
    border-radius: var(--mn-radius-sm);
    font-size: 14.5px;
    cursor: pointer;
    transition: border-color var(--t-base) var(--ease-soft), background var(--t-base) var(--ease-soft), color var(--t-base) var(--ease-soft), transform var(--t-fast) var(--ease-pop);
}
.cand-op:hover { border-color: var(--mn-green-dim); }
.cand-op:active { transform: scale(.98); }
.cand-op.on {
    border-color: var(--mn-green);
    background: rgba(43,217,107,.12);
    color: var(--mn-text);
}

/* Lista de habilidades (multi-select) */
.cand-hablist {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin: 6px 0 4px;
}
.cand-hab {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 12px;
    border: 1px solid var(--mn-line-2);
    background: var(--mn-bg-2);
    color: var(--mn-text-dim);
    border-radius: var(--mn-radius-sm);
    font-size: 13.5px;
    text-align: left;
    cursor: pointer;
    transition: border-color var(--t-base) var(--ease-soft), background var(--t-base) var(--ease-soft), color var(--t-base) var(--ease-soft), transform var(--t-fast) var(--ease-pop);
}
.cand-hab:active { transform: scale(.97); }
.cand-hab.on {
    border-color: var(--mn-green);
    background: rgba(43,217,107,.12);
    color: var(--mn-text);
}
.cand-hab-check {
    width: 20px; height: 20px;
    flex: none;
    border-radius: 5px;
    border: 1.5px solid var(--mn-line-2);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px;
    color: var(--mn-green);
}
.cand-hab.on .cand-hab-check { border-color: var(--mn-green); }

@media (max-width: 420px) {
    .cand-hablist { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
    .cand-area:active, .cand-op:active, .cand-hab:active { transform: none !important; }
}

/* Pill de aptitud de cocina en las cards del admin */
.pa-cocina { font-weight: 600; }
.pa-cocina-4 { color: #7CFFB0; border-color: rgba(43,217,107,.4); background: rgba(43,217,107,.12); }  /* Alto */
.pa-cocina-3 { color: var(--mn-amber); border-color: rgba(245,158,11,.4); background: rgba(245,158,11,.1); } /* Medio */
.pa-cocina-2 { color: var(--mn-text-faint); border-color: var(--mn-line); }  /* Bajo */
.pa-cocina-1 { color: #7aa2ff; border-color: rgba(31,111,235,.35); background: rgba(31,111,235,.08); }  /* Quiere aprender */

/* ── Elementos nuevos: papelera, audio cocina, regrabar ── */
.pa-head-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.pa-pill-audio { color: #7aa2ff; border-color: rgba(31,111,235,.35); background: rgba(31,111,235,.08); }
.pa-act-trash {
    background: transparent; border: 1px solid var(--mn-line-2); color: var(--mn-text-faint);
    cursor: pointer; border-radius: var(--mn-radius-sm); padding: 6px 10px;
    transition: border-color var(--t-base) var(--ease-soft), color var(--t-base) var(--ease-soft);
}
.pa-act-trash:hover { border-color: #e5484d; color: #e5484d; }
.pa-act-restore {
    background: rgba(43,217,107,.1); border: 1px solid var(--mn-green-dim); color: var(--mn-green);
    cursor: pointer; border-radius: var(--mn-radius-sm); padding: 6px 12px;
    transition: background var(--t-base) var(--ease-soft);
}
.pa-act-restore:hover { background: rgba(43,217,107,.18); }

/* Botón "grabar/subir otro" del audio */
.cand-rec-redo {
    margin-top: 8px; background: transparent; border: 1px solid var(--mn-line-2);
    color: var(--mn-text-dim); border-radius: var(--mn-radius-sm); padding: 8px 14px;
    font-size: 13.5px; cursor: pointer;
    transition: border-color var(--t-base) var(--ease-soft), color var(--t-base) var(--ease-soft);
}
.cand-rec-redo:hover { border-color: var(--mn-green-dim); color: var(--mn-text); }

/* Mensaje de suerte en pantalla final */
.cand-suerte { font-size: 18px; font-weight: 600; color: var(--mn-green); margin-top: 12px; }

/* ── Consentimiento de datos / privacidad ── */
.cand-privacy {
    margin-top: 18px; padding: 16px; border-radius: var(--mn-radius);
    background: rgba(255,255,255,.03); border: 1px solid var(--mn-line-2);
}
.cand-privacy-tit { font-size: 15px; font-weight: 700; margin: 0 0 8px; color: var(--mn-text); }
.cand-privacy-txt { font-size: 13px; line-height: 1.55; color: var(--mn-text-dim); margin: 0 0 10px; }
.cand-consent { margin-top: 8px; align-items: flex-start; }
.cand-consent .cand-check { margin-top: 2px; }
.cand-tutor {
    margin-top: 14px; padding-top: 14px; border-top: 1px dashed var(--mn-line-2);
}
.cand-tutor-aviso {
    background: rgba(200,16,46,.08); border: 1px solid rgba(200,16,46,.25);
    border-radius: var(--mn-radius-sm); padding: 10px 12px; color: var(--mn-text);
}

/* ── Borrado definitivo: botón y modal ── */
.pa-act-delete {
    background: rgba(229,72,77,.1); border: 1px solid rgba(229,72,77,.4); color: #e5484d;
    cursor: pointer; border-radius: var(--mn-radius-sm); padding: 6px 12px;
    transition: background var(--t-base) var(--ease-soft);
}
.pa-act-delete:hover { background: rgba(229,72,77,.2); }
.pa-modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 1000;
    display: flex; align-items: center; justify-content: center; padding: 20px;
}
.pa-modal {
    background: var(--mn-surface, #1b1b1f); border: 1px solid var(--mn-line-2);
    border-radius: var(--mn-radius); padding: 22px; max-width: 440px; width: 100%;
    box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.pa-modal-tit { margin: 0 0 10px; font-size: 18px; font-weight: 700; color: #e5484d; }
.pa-modal-txt { margin: 0 0 18px; font-size: 14px; line-height: 1.55; color: var(--mn-text-dim); }
.pa-modal-acts { display: flex; gap: 10px; justify-content: flex-end; }
.pa-btn-danger { background: #e5484d; border-color: #e5484d; color: #fff; }
.pa-btn-danger:hover { background: #c93b40; }

/* ── Aptitud para tareas / referencias / compromiso ── */
.cand-aptitud, .cand-refs {
    margin-top: 16px; padding: 14px; border-radius: var(--mn-radius);
    background: rgba(255,255,255,.025); border: 1px solid var(--mn-line-2);
}
.cand-refs-aviso { font-size: 12px; color: var(--mn-text-faint); margin-top: 6px; }
.cand-compromiso { margin-top: 14px; align-items: flex-start; }
.cand-compromiso .cand-check { margin-top: 2px; }
.post-ok-inline { color: var(--mn-green, #2bd96b); font-weight: 600; }

/* ── Transcripción de audio + carga admin (ficha postulante) ── */
.post-trans { margin: 8px 0; padding: 8px 12px; background: rgba(255,255,255,.03); border-radius: 8px; border: 1px solid var(--mn-line-2, #2a2a2a); }
.post-trans summary { cursor: pointer; font-weight: 600; color: var(--mn-text, #eee); }
.post-trans-text { margin: 8px 0 4px; white-space: pre-wrap; line-height: 1.5; }
.post-audio-admin { margin: 14px 0; padding: 12px; border-radius: 10px; background: rgba(255,255,255,.025); border: 1px dashed var(--mn-line-2, #333); }
.post-audio-admin form { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.post-file-admin { max-width: 100%; color: var(--mn-text-faint, #999); }
.post-btn-ghost { background: transparent; border: 1px solid var(--mn-line-2, #444); }

/* ── Aviso de progreso recuperado (persistencia del wizard) ── */
.cand-aviso-recuperado {
    position: relative;
    margin: 0 0 16px;
    padding: 12px 38px 12px 14px;
    background: rgba(34, 197, 94, 0.12);
    border: 1px solid rgba(34, 197, 94, 0.45);
    border-radius: var(--mn-radius-sm, 10px);
    color: #bbf7d0;
    font-size: 13.5px;
    line-height: 1.5;
}
.cand-aviso-x {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 24px;
    height: 24px;
    border: none;
    background: transparent;
    color: #bbf7d0;
    font-size: 14px;
    cursor: pointer;
    border-radius: 6px;
    line-height: 1;
}
.cand-aviso-x:hover { background: rgba(34, 197, 94, 0.2); }

/* ═══════════════════════════════════════════════════════════════════════════
   TANDA POSTUL-MEJORAS — destaque "sucursal más cercana" + MOBILE del panel
   admin (ficha post-* y listado pa-*). Objetivo: que el admin vea y TOQUE todo
   desde el celular, sin scroll horizontal ni texto cortado. Sólo agrega; no
   pisa reglas previas. Usa el design system --mn-*.
   ═══════════════════════════════════════════════════════════════════════════ */

/* Destaque de la sucursal a la que el candidato está MÁS CERCA (ficha) */
.post-cerca {
    background: rgba(43, 217, 107, .09);
    border: 1px solid rgba(43, 217, 107, .25);
    border-radius: var(--mn-radius-sm);
    padding: 7px 11px;
    margin: 7px 0 !important;
    line-height: 1.4;
}
.post-cerca strong { color: var(--mn-green); }

/* Anti-overflow horizontal (clip no rompe position:sticky, hidden sí) */
.post-wrap, .pa-wrap { overflow-x: clip; }

/* ── FICHA (post-*) en celular ───────────────────────────────────────────── */
@media (max-width: 880px) {
    /* Cabecera: volver/título/WhatsApp apilados y full-width */
    .post-head { flex-direction: column; align-items: stretch; gap: 10px; }
    .post-head .post-btn,
    .post-head .post-btn-green { width: 100%; text-align: center; }

    /* Cada dato como bloque: etiqueta arriba, valor debajo (textos largos no se cortan) */
    .post-card p .post-k { display: block; margin-bottom: 1px; }
    .post-card p { line-height: 1.5; }

    /* Controles de gestión cómodos y sin zoom automático en iOS (font 16px) */
    .post-input, .post-textarea { width: 100%; box-sizing: border-box; font-size: 16px; }
    .post-btn, .post-btn-green { min-height: 44px; }

    /* Adjuntos / badges que envuelvan bien y no desborden */
    .post-badges { gap: 6px; }
    .post-archivo { flex-direction: column; align-items: stretch; gap: 6px; }
    .post-archivo .post-btn { width: 100%; text-align: center; }
    .post-selfie { max-width: 100%; height: auto; }
    .post-audio { width: 100%; }
}

/* ── LISTADO (pa-*) en celular ───────────────────────────────────────────── */
@media (max-width: 720px) {
    /* Cabecera del listado: título + acciones apiladas y tocables */
    .pa-head { flex-direction: column; align-items: stretch; gap: 10px; }
    .pa-head-actions { width: 100%; }
    .pa-head-actions .post-btn { flex: 1 1 auto; text-align: center; min-height: 44px; }
}
@media (max-width: 560px) {
    /* Acciones de cada card: que entren todas y sean tocables */
    .pa-card-actions { flex-wrap: wrap; gap: 6px; }
    .pa-act { min-height: 40px; padding: 8px 12px; }
    .pa-meta-v { word-break: break-word; }
    /* Filtros avanzados a una sola columna en pantallas muy chicas */
    .pa-fgrid { grid-template-columns: 1fr; }
    /* Pills de la card que no fuercen scroll horizontal */
    .pa-sub { gap: 5px; }
}

/* ===== AGILIZADOR: resaltado breve del campo al que se salta (irACampo JS) ===== */
.cand-flash {
    border-radius: var(--mn-radius-sm, 10px);
    animation: candFlash 1.6s ease-out 1;
}
@keyframes candFlash {
    0%   { box-shadow: 0 0 0 0 rgba(200,16,46,.55); }
    25%  { box-shadow: 0 0 0 4px rgba(200,16,46,.30); }
    100% { box-shadow: 0 0 0 0 rgba(200,16,46,0); }
}
/* Aviso de error del paso, fijado arriba del contenido para que se vea sí o sí. */
.cand-aviso-top {
    /* Sin la animacion heredada de .cand-step-anim > * : un error debe verse YA
       (sin delay ni transform de entrada), y asi el sticky queda sin interferencia. */
    animation: none;
    position: sticky;
    top: 6px;
    z-index: 6;
    margin: 0 0 12px;
    padding: 10px 12px;
    border-radius: var(--mn-radius-sm, 10px);
    background: var(--mn-red-soft, rgba(200,16,46,.10));
    border: 1px solid rgba(200,16,46,.35);
    box-shadow: 0 2px 10px rgba(0,0,0,.10);
    color: var(--mn-red, #c8102e);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.35;
}
.cand-aviso-top .cand-aviso-top-ico { margin-right: 6px; }

/* ===== Aptitudes Sí/No (paso 7): cada requisito con respuesta obligatoria ===== */
.cand-aptitud-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 10px 0;
    border-bottom: 1px solid var(--mn-line, rgba(0,0,0,.08));
}
.cand-aptitud-row:last-of-type { border-bottom: 0; }
.cand-aptitud-q { font-size: 14px; line-height: 1.35; }

/* ===== Condiciones legibles del puesto (paso 4) — POSTUL-V2 ===== */
.cand-condbox{
  border:1px solid rgba(127,127,127,.28);
  border-radius:12px;
  padding:14px 16px;
  margin:12px 0;
  background:rgba(127,127,127,.06);
}
.cand-cond-title{
  font-weight:700;
  font-size:15px;
  margin-bottom:8px;
  color:#c8102e;
}
.cand-cond-text{
  font-size:14px;
  line-height:1.55;
  margin:0 0 10px;
  opacity:.95;
}
.cand-condbox .cand-checkrow{ margin-top:8px; }

/* ===== Resumen "qué falta" + separadores del paso final — POSTUL-V2 ===== */
.cand-falta{
  border:1px solid rgba(200,16,46,.35);
  background:rgba(200,16,46,.07);
  border-radius:12px;
  padding:12px 16px;
  margin:16px 0 4px;
}
.cand-falta-tit{ font-weight:700; color:#c8102e; margin-bottom:6px; font-size:14px; }
.cand-falta-list{ margin:0; padding-left:18px; font-size:14px; line-height:1.5; }
.cand-falta-list li{ margin:2px 0; }
.cand-listo{
  display:flex; align-items:center; gap:10px;
  border:1px solid rgba(34,160,90,.4);
  background:rgba(34,160,90,.08);
  border-radius:12px;
  padding:12px 16px;
  margin:16px 0 4px;
  font-weight:600; font-size:15px;
}
.cand-listo-ico{
  display:inline-flex; align-items:center; justify-content:center;
  width:26px; height:26px; border-radius:50%;
  background:#22a05a; color:#fff; font-weight:800; flex:0 0 auto;
}
.cand-sec-sep{
  display:flex; align-items:center; gap:12px;
  margin:22px 0 12px; color:#888;
  font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
}
.cand-sec-sep::before, .cand-sec-sep::after{
  content:""; height:1px; background:rgba(127,127,127,.28); flex:1;
}

/* ===== Veredicto de un vistazo en la ficha de detalle — POSTUL-V2 ===== */
.post-veredicto{ padding:14px 16px; }
.post-veredicto-cols{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:640px){ .post-veredicto-cols{ grid-template-columns:1fr; } }
.post-veredicto-tit{
  margin:0 0 8px; font-size:12px; font-weight:800;
  letter-spacing:.06em; text-transform:uppercase;
}
.post-veredicto-tit.ok{ color:#22a05a; }
.post-veredicto-tit.alert{ color:#c8102e; }
.post-flag{
  display:block; font-size:13.5px; line-height:1.5;
  padding:3px 0; font-weight:600;
}
.post-flag.verde{ color:#1c8a4e; }
.post-flag.rojo{ color:#c8102e; }

/* ══════════════════════════════════════════════════════════════════════════
   MOBILE FICHAS — refinamiento milimétrico para teléfonos (POSTUL-V2)
   Pulido fino de la LISTA (/admin/postulantes) y la FICHA (/admin/postulantes/{id})
   en pantallas reales de 360–430px. Todo aditivo y scopeado dentro de @media:
   no afecta el desktop. Ataca 9 puntos detectados en auditoría.
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 560px) {

  /* (1) El panel de gestión NO debe quedar sticky en mobile: al colapsar a 1
     columna, un panel pegado tapa contenido y salta. Fluye normal. */
  .post-gestion { position: static; top: auto; }

  /* (PRIORIDAD MOBILE) En el celular, el caso de uso #1 es: abrir la ficha y
     cambiar el estado / dejar una nota. Por eso subimos la columna de gestión
     ARRIBA (justo bajo el veredicto), para no scrollear 7 tarjetas de info.
     Solo afecta mobile: en desktop la gestión sigue a la derecha. */
  .post-grid { display: flex; flex-direction: column; }
  .post-grid > .post-col:last-child { order: -1; }

  /* (5) Selects de la lista a 16px → iOS no hace zoom automático al tocarlos.
     (los inputs de la ficha ya lo tienen; faltaban estos). */
  .pa-search-input,
  .pa-order-sel,
  .pa-filtros-adv .post-input,
  .post-gestion .post-input { font-size: 16px; }

  /* (4) Orden: el bloque ocupa el ancho y el <select> se estira; el botón de
     dirección queda fijo a su lado. Nada apretado. */
  .pa-order { width: 100%; }
  .pa-order-sel { flex: 1 1 auto; min-width: 0; }
  .pa-order-lbl { display: none; } /* el "Ordenar por" ocupa lugar; el select ya se entiende */

  /* (3) Metadatos de la card: etiqueta arriba, valor abajo (igual que la ficha).
     Las sucursales largas dejan de quedar en una columna angosta de 88px. */
  .pa-meta-line { flex-direction: column; gap: 1px; }
  .pa-meta-k { width: auto; padding-top: 0; }
  .pa-meta-v { font-size: 14px; }

  /* (6) Pills de la card: ninguna pill individual puede ser más ancha que la
     tarjeta (evita scroll horizontal por un texto largo de sucursal cercana). */
  .pa-sub { gap: 6px; }
  .pa-pill { max-width: 100%; overflow: hidden; text-overflow: ellipsis; }

  /* (8) Acciones de la card a lo ancho y bien tocables (44px). Tres botones que
     reparten el ancho en vez de quedar chiquitos a la derecha. */
  .pa-card-foot { flex-direction: column; align-items: stretch; gap: 10px; }
  .pa-card-actions { width: 100%; gap: 8px; }
  .pa-card-actions .pa-act { flex: 1 1 0; min-height: 44px; text-align: center; padding: 10px 8px; display: flex; align-items: center; justify-content: center; }
  .pa-fecha { order: 2; text-align: center; }

  /* (2) Form de subida de audio del admin: el <input type=file> nativo no debe
     desbordar; todo apilado y a lo ancho. */
  .post-audio-admin form { display: flex; flex-direction: column; gap: 10px; align-items: stretch; }
  .post-file-admin { width: 100%; max-width: 100%; box-sizing: border-box; }
  .post-audio-admin .post-btn { width: 100%; text-align: center; min-height: 44px; }

  /* Filtros avanzados: acciones a lo ancho y rango (edad mín–máx) que no se
     desarme; los dos números siguen en fila pero ocupan el ancho. */
  .pa-fadv-actions { flex-direction: column; }
  .pa-fadv-actions .post-btn { width: 100%; text-align: center; min-height: 44px; }

  /* (7) Veredicto: banderas con respiro táctil; las dos columnas ya colapsan a 1
     en 640px, acá solo afinamos el texto. */
  .post-flag { font-size: 14px; padding: 5px 0; }
  .post-veredicto { padding: 14px; }

  /* (9) Que el header sticky (si lo hay) no tape el inicio de cada card al saltar
     con un ancla. */
  .post-card, .pa-card { scroll-margin-top: 12px; }

  /* Estado de la card (badge) que no quede flotando raro al apilarse el top. */
  .pa-estado { align-self: flex-start; }
}

/* Teléfonos chicos (≤380px): apretar un punto más sin romper la legibilidad. */
@media (max-width: 380px) {
  .pa-stats { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .pa-stat-n { font-size: 22px; }
  .pa-card { padding: 14px; }
  .pa-card-actions { flex-wrap: wrap; }
  .pa-card-actions .pa-act { flex: 1 1 40%; }
  .post-veredicto-cols { gap: 12px; }
}
