:root{--bg: #f6f8fc;--surface: #ffffff;--surface-soft: #f1f4fa;--surface-soft-2: #e6ebf3;--text: #152238;--muted: #5c677d;--primary: #0059bb;--primary-strong: #004493;--border: #d8deea;--border-strong: #c2c9d8;--ok-bg: #e7f6ec;--ok-text: #1f7a39;--warn-bg: #fff4df;--warn-text: #9a5a00;--err-bg: #fdeced;--err-text: #b1202c;--pending-bg: #ebf1ff;--pending-text: #2252a7}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:linear-gradient(180deg,#fbfcff 0%,var(--bg) 100%);color:var(--text);font-family:Inter,Segoe UI,Roboto,Arial,sans-serif}h1,h2,h3,h4,p{margin:0}.muted-text{color:var(--muted)}.app-shell{display:flex;min-height:100vh}.app-sidenav{width:260px;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;gap:24px;padding:24px 16px;background:var(--surface);border-right:1px solid var(--border);box-shadow:0 8px 30px #1a294c14;z-index:30}.app-brand{display:flex;align-items:center;gap:10px}.app-brand-mark{width:44px;height:44px;border-radius:999px;display:grid;place-items:center;background:#dce8ff;color:var(--primary-strong);font-weight:800}.app-brand h1{font-size:22px;line-height:1.2}.app-brand p{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.app-nav{display:grid;gap:6px}.nav-link{display:block;padding:12px 14px;border-radius:10px;text-decoration:none;color:var(--muted);font-weight:600;border:1px solid transparent;transition:all .14s ease}.nav-link:hover{color:var(--primary);background:var(--surface-soft)}.nav-link-active{color:var(--primary);background:#edf3ff;border-color:#d3e2ff}.app-stage{width:100%;margin-left:260px;min-height:100vh;display:flex;flex-direction:column}.app-topbar{height:80px;border-bottom:1px solid var(--border);background:#ffffffd1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:14px 32px;display:flex;align-items:center;justify-content:space-between;gap:16px}.app-topbar h2{font-size:24px;line-height:1.15;margin-bottom:4px}.app-topbar p{color:var(--muted);font-size:14px}.app-user-panel{display:flex;align-items:center;gap:12px;min-width:0}.app-user-email{max-width:280px;overflow:hidden;color:var(--muted);font-size:14px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.app-logout-button{padding:9px 12px;white-space:nowrap}.app-main{width:min(1320px,100%);margin:0 auto;padding:28px 28px 40px}.page-headline{margin-bottom:8px;display:grid;gap:6px}.page-title{font-size:30px;line-height:1.1}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:0 10px 28px #1f2d4e0f}.card h3{font-size:20px;margin-bottom:12px}.form-row{display:grid;gap:8px}label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}.input,.button,.select{font:inherit;border-radius:10px;border:1px solid var(--border-strong);padding:11px 12px}.input,.select{background:#fff;color:var(--text)}.input:focus,.select:focus{outline:none;border-color:#7ea8f5;box-shadow:0 0 0 3px #0059bb1f}.button{background:var(--primary);color:#fff;border-color:transparent;cursor:pointer;font-weight:700;transition:all .15s ease}.button:hover{background:var(--primary-strong)}.button:disabled{cursor:not-allowed;background:#8baed9}.button-secondary{background:var(--surface-soft);color:var(--text);border-color:var(--border)}.button-secondary:hover{background:var(--surface-soft-2)}.button-verify{font-size:17px;padding:13px 16px}.status-message{margin-top:8px;padding:11px 12px;border-radius:10px;border:1px solid var(--border);font-weight:600;line-height:1.35}.status-message--error{color:var(--err-text);background:var(--err-bg);border-color:#efc1c5}.status-message--warning{color:var(--warn-text);background:var(--warn-bg);border-color:#f3ddb0}.status-message--success{color:var(--ok-text);background:var(--ok-bg);border-color:#bfdfc9}.status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 11px;font-size:12px;line-height:1;font-weight:700;letter-spacing:.02em;background:var(--surface-soft-2);color:var(--text)}.status-badge--validado{background:var(--ok-bg);color:var(--ok-text)}.status-badge--revision{background:var(--warn-bg);color:var(--warn-text)}.status-badge--no-coincide{background:var(--err-bg);color:var(--err-text)}.status-badge--pending{background:var(--pending-bg);color:var(--pending-text)}.camera-video{width:100%;border-radius:12px;background:#131827;border:1px solid #273452}.camera-actions{display:flex;flex-wrap:wrap;gap:8px}.attempts-table-wrap{overflow-x:auto}.attempts-table{width:100%;border-collapse:collapse;min-width:980px}.attempts-table th{background:var(--surface-soft);color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.attempts-table th,.attempts-table td{border-bottom:1px solid var(--border);padding:12px;text-align:left}.attempts-table tbody tr:hover{background:#f8faff}.attempts-observations-cell{max-width:340px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.verification-page,.register-page,.attempts-page{display:grid;gap:12px}.verification-search{display:grid;gap:10px}.verification-search-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}.citizen-summary-grid,.verification-result-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.summary-item{display:grid;gap:4px}.summary-label{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.05em;font-weight:700}.verification-layout,.register-layout{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.verification-column,.register-side-column{display:grid;gap:12px}.reference-photo-card p,.camera-panel p{margin-bottom:8px}.reference-photo-frame,.camera-frame{border:1px solid var(--border);border-radius:12px;padding:8px;background:#f4f7fb;min-height:260px;display:flex;align-items:center;justify-content:center}.reference-photo{width:100%;max-width:420px;border-radius:10px;border:1px solid var(--border)}.verification-actions{display:grid;gap:12px}.verification-action-buttons{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.verification-actions-head{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:space-between}.verification-progress{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--surface-soft);display:grid;gap:6px}.verification-result-card{border-width:2px}.verification-result-card--validado{border-color:#b8dec4;background:linear-gradient(180deg,#f8fffa,#f1faf3)}.verification-result-card--revision{border-color:#f2d59f;background:linear-gradient(180deg,#fffef8,#fff8e9)}.verification-result-card--no-coincide{border-color:#efc0c6;background:linear-gradient(180deg,#fffafb,#fff1f2)}.validation-results-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}.biometric-result-card{display:grid;gap:10px}.ai-review-card{border-width:2px;display:grid;gap:10px}.ai-review-card--apto{border-color:#b8dec4;background:linear-gradient(180deg,#f8fffa,#f1faf3)}.ai-review-card--manual{border-color:#f2d59f;background:linear-gradient(180deg,#fffef8,#fff8e9)}.ai-review-card--no-apto{border-color:#efc0c6;background:linear-gradient(180deg,#fffafb,#fff1f2)}.ai-review-observations{display:grid;gap:8px;border:1px solid var(--border);border-radius:12px;padding:12px;background:#ffffffbf}.ai-review-observations ul{margin:0;padding-left:18px;display:grid;gap:6px}.attempts-card--full h3{margin-bottom:10px}.attempts-metrics-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:0 10px 24px #1f2d4e0d;display:grid;gap:8px}.metric-card span{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}.metric-card strong{font-size:24px}.attempts-filter-card{display:grid;gap:10px}.attempts-filter-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}.register-models-card{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px}.register-models-actions{display:flex;gap:8px;align-items:center}.register-form{display:grid;gap:12px;min-width:0}.form-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.register-submit-row{display:flex;justify-content:flex-start}.register-form .input,.register-form .select{width:100%;min-width:0}.register-submit-row .button-verify{width:min(100%,390px);min-height:52px}.image-preview{border:1px dashed var(--border-strong);border-radius:12px;padding:10px;min-height:220px;background:#f8fbff;display:flex;justify-content:center;align-items:center}.image-preview img{width:100%;max-width:420px;min-width:0;border-radius:10px;border:1px solid var(--border)}.descriptor-summary{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--surface-soft);display:grid;gap:8px}.register-result-card{display:grid;gap:12px}@media (max-width: 1024px){.app-sidenav{position:static;width:100%;border-right:0;border-bottom:1px solid var(--border);box-shadow:none}.app-stage{margin-left:0}.app-topbar{padding-inline:18px;height:auto;min-height:68px;align-items:flex-start;flex-direction:column}.app-main{padding:18px 14px 28px}}@media (max-width: 720px){.verification-search-row,.attempts-filter-row{grid-template-columns:1fr}.page-title{font-size:24px}}.login-page{position:relative;overflow:hidden;min-height:100vh;display:grid;grid-template-columns:1fr;align-items:center;justify-items:end;padding:32px clamp(32px,6vw,88px);background:radial-gradient(circle at top right,rgba(0,89,187,.12),transparent 34%),linear-gradient(180deg,#fbfcff,#edf3fb)}.login-visual{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:linear-gradient(90deg,#002d5e0a,#edf3fb14),url(/images/fondo-login.png) center center / cover no-repeat;pointer-events:none}.login-card{width:min(100%,420px);display:grid;gap:20px;padding:32px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 18px 48px #1f2d4e1f;position:relative;z-index:1}.login-card--loading{min-height:180px;place-items:center}.login-brand-mark{width:54px;height:54px;display:grid;place-items:center;border-radius:999px;background:#dce8ff;color:var(--primary-strong);font-size:18px;font-weight:800}.login-heading{display:grid;gap:4px}.login-heading h1{font-size:34px;line-height:1.1}.login-heading p{color:var(--muted);font-size:16px}.login-form{display:grid;gap:14px}.login-input,.login-button{width:100%}.login-button{min-height:46px;margin-top:4px}.login-error{padding:11px 12px;border:1px solid #efc1c5;border-radius:10px;background:var(--err-bg);color:var(--err-text);font-weight:600;line-height:1.35}.login-loader{color:var(--muted);font-weight:700}.auth-route-loader{min-height:100vh;display:grid;place-items:center;color:var(--muted);font-weight:700}.login-divider{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:14px;margin:-6px 0}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--border)}.login-divider span{padding:0 12px}.login-button-google{width:100%;min-height:46px;display:flex;align-items:center;justify-content:center;gap:12px;background-color:#fff;color:#3c4043;border:1px solid #dadce0;border-radius:8px;font-weight:500;font-family:inherit;font-size:15px;cursor:pointer;transition:background-color .2s,box-shadow .2s}.login-button-google:hover{background-color:#f8f9fa;box-shadow:0 1px 2px #3c40434d,0 1px 3px 1px #3c404326}.login-button-google:active{background-color:#f1f3f4}.google-icon{width:20px;height:20px}@media (max-width: 900px){.login-page{grid-template-columns:1fr;padding:24px;place-items:center}.login-visual{opacity:.2;background-position:center}.login-card{position:relative;z-index:1}}@media (max-width: 520px){.login-page{padding:16px}.login-card{padding:24px}.login-heading h1{font-size:30px}}
