/* components.css — Veriweld buttons, pills, modals, badges, toast, inputs */

/* ── Buttons ── */
/* Brand spec: 2px radius, Archivo display font, ink/paper inverse for primary */
.btn{font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:.01em;padding:7px 14px;border-radius:var(--radius);border:1px solid var(--border-2);background:var(--ink-2);color:var(--paper);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .12s}
.btn:hover{background:var(--ink-3);border-color:var(--mist)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn.primary{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn.primary:hover{background:var(--bp-200);border-color:var(--bp-200);color:var(--ink)}
.btn.sm{padding:4px 10px;font-size:11px}
.btn.danger{border-color:rgba(255,90,31,.35);color:var(--arc-dark)}
.btn.danger:hover{background:rgba(255,90,31,.12);border-color:var(--arc)}
.btn.success{border-color:rgba(63,181,95,.35);color:var(--success-dark)}
.btn.success:hover{background:rgba(63,181,95,.12);border-color:var(--success-dark)}
.btn.arc{background:var(--arc);color:var(--paper);border-color:var(--arc)}
.btn.arc:hover{background:var(--arc-700);border-color:var(--arc-700)}

/* ── Modal ── */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:100;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.mo.open{display:flex}
.md{background:var(--ink-2);border:1px solid var(--border);border-radius:var(--radius)}
.mh{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--ink-2)}
.mh h3{font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:-.01em;color:var(--paper)}
.mx{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;color:var(--mist);font-size:18px;background:transparent;border:none}
.mx:hover{background:var(--ink-3);color:var(--paper)}
.mbody{padding:20px}
.mfoot{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;background:var(--ink-2)}

/* Modal sections */
.msec{margin-bottom:18px}
.msec:last-child{margin-bottom:0}
.msec-title{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--mist);font-weight:600;margin-bottom:8px}

/* ── Toast ── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);padding:10px 20px;border-radius:var(--radius);font-family:var(--font-display);font-size:12.5px;font-weight:600;z-index:200;opacity:0;transition:opacity .3s;pointer-events:none;background:var(--success-dark);color:var(--ink);letter-spacing:.02em}
.toast.show{opacity:1}
.toast.success{background:var(--success-dark);color:var(--ink)}
.toast.info{background:var(--bp-200);color:var(--ink)}
.toast.error{background:var(--arc);color:var(--paper)}

/* ── Score badge (verify.html heat candidate scoring) ── */
.score{display:inline-block;padding:2px 8px;border-radius:var(--radius);font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.02em}
.score.high{background:rgba(63,181,95,.15);color:var(--success-dark);border:1px solid rgba(63,181,95,.35)}
.score.med{background:rgba(157,181,208,.15);color:var(--bp-200);border:1px solid var(--blueprint)}
.score.low{background:rgba(255,90,31,.15);color:var(--arc-dark);border:1px solid rgba(255,90,31,.35)}
.score.zero{background:var(--border);color:var(--mist);border:1px solid var(--border-2)}

/* ── Chip (small mono tag) ── */
.chip{font-family:var(--mono);font-size:10px;padding:1px 6px;border-radius:var(--radius);background:var(--ink-3);color:var(--mist);font-weight:500;letter-spacing:.04em;border:1px solid var(--border)}

/* ── Status pill (brand: mono uppercase, 2px radius, not rounded) ── */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:var(--radius);font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;white-space:nowrap}
.pill.pass{background:rgba(63,181,95,.15);color:var(--success-dark)}
.pill.fail{background:rgba(255,90,31,.18);color:var(--arc-dark)}
.pill.review{background:rgba(157,181,208,.15);color:var(--bp-200)}
.pill.muted{background:var(--border);color:var(--mist)}
.pill.hot{background:rgba(255,90,31,.15);color:var(--arc-200)}
.pill.warn{background:rgba(242,194,0,.18);color:var(--hivis)}

/* ── Warning banner ── */
.warn-banner{background:rgba(242,194,0,.12);border:1px solid rgba(242,194,0,.35);border-left:3px solid var(--hivis);border-radius:var(--radius);padding:10px 14px;margin-bottom:12px;font-size:12.5px;color:var(--paper)}
.warn-banner strong{color:var(--hivis)}

/* ── MTR small button (used inline in tables) ── */
.mtr-btn{font-family:var(--mono);font-size:9px;padding:1px 5px;border:1px solid var(--border-2);border-radius:var(--radius);background:var(--ink-2);color:var(--mist);cursor:pointer;margin-left:3px;white-space:nowrap;vertical-align:middle;letter-spacing:.06em}
.mtr-btn:hover{background:var(--blueprint);color:var(--paper);border-color:var(--blueprint)}

/* ── Notes / textarea ── */
.notes-area{width:100%;background:var(--ink);border:1px solid var(--border-2);border-radius:var(--radius);padding:8px 10px;color:var(--paper);font-size:12px;font-family:var(--font);resize:vertical;min-height:48px}
.notes-area:focus{outline:none;border-color:var(--blueprint)}

/* ── Placeholder ── */
.placeholder{display:flex;align-items:center;justify-content:center;height:300px;color:var(--mist);font-size:14px;font-family:var(--font)}

/* ── Manual override / correction badges (kept on paper for visibility) ── */
.mo-badge,.mc-badge{display:inline-block;font-family:var(--mono);font-size:8px;font-weight:700;padding:1px 5px;margin-left:6px;background:var(--hivis);color:var(--ink);border:none;border-radius:1px;text-transform:uppercase;letter-spacing:.1em;cursor:help;vertical-align:middle}

/* ── Extraction strategy badges (carry over from old tables.css for convenience) ── */
.extraction-badge{font-family:var(--mono);padding:2px 6px;border-radius:var(--radius);font-size:9px;font-weight:700;letter-spacing:.1em;white-space:nowrap;text-transform:uppercase}
.extraction-badge.acroform{background:rgba(63,181,95,.15);color:var(--success-dark);border:1px solid rgba(63,181,95,.35)}
.extraction-badge.zip-image{background:rgba(27,79,140,.25);color:var(--bp-200);border:1px solid var(--blueprint)}
.extraction-badge.tesseract{background:rgba(255,90,31,.15);color:var(--arc-dark);border:1px solid rgba(255,90,31,.35)}
.extraction-badge.claude{background:rgba(192,132,252,.18);color:var(--purple);border:1px solid rgba(192,132,252,.35)}

/* ── Intake Review source column (weld log + coating) ── */
.src-cell{white-space:nowrap;font-family:var(--mono)}
.src-badge{display:inline-block;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;padding:2px 5px;border:1px solid currentColor;border-radius:1px;background:transparent}
.src-sig{display:inline-block;margin-left:6px;color:var(--success-dark);font-size:12px;cursor:help}
.src-pdf{display:inline-block;margin-left:6px;padding:1px 5px;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;color:var(--blueprint);border:1px solid var(--blueprint);border-radius:1px;text-decoration:none;background:transparent}
.src-pdf:hover{background:var(--blueprint);color:var(--paper)}
