:root{--bg: #0f1419;--surface: #1a2332;--surface2: #243044;--border: #2d3d52;--text: #e8eef4;--muted: #8fa3b8;--accent: #3b82f6;--accent-dim: #2563eb;--ok: #22c55e;--warn: #eab308;--danger: #ef4444;--radius: 10px;font-family:DM Sans,system-ui,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);min-height:100vh}#root{min-height:100vh}.app-shell{max-width:1280px;margin:0 auto;padding:1rem 1.25rem 2rem}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2rem}.login-card h1{margin:0 0 .25rem;font-size:1.5rem}.login-card p{margin:0 0 1.5rem;color:var(--muted);font-size:.9rem}label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:.35rem}input{width:100%;padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);margin-bottom:1rem;font:inherit}button{font:inherit;cursor:pointer;border:none;border-radius:8px;padding:.65rem 1rem}.btn-primary{width:100%;background:var(--accent);color:#fff;font-weight:600}.btn-primary:hover{background:var(--accent-dim)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--muted)}.header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.header h1{margin:0;font-size:1.35rem}.header-meta{font-size:.85rem;color:var(--muted)}.tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tab{background:var(--surface);color:var(--muted);border:1px solid var(--border);padding:.5rem .9rem;border-radius:999px;font-size:.85rem}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-bottom:1.25rem}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem}.stat .label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.stat .value{font-size:1.5rem;font-weight:700;margin-top:.25rem}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.toolbar input,.toolbar select{width:auto;min-width:160px;margin-bottom:0}.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--border)}th{background:var(--surface2);color:var(--muted);font-weight:600;position:sticky;top:0}tr:hover td{background:#3b82f60f}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.badge-pendiente{background:#eab30833;color:#facc15}.badge-en_curso,.badge-en_proceso,.badge-activa{background:#3b82f633;color:#93c5fd}.badge-completado,.badge-terminada{background:#22c55e33;color:#86efac}.badge-en_pausa,.badge-pausada{background:#94a3b833;color:#cbd5e1}.badge-pendiente_control{background:#ef444426;color:#fca5a5}.badge-liberada_procesos{background:#22c55e33;color:#86efac}.error{color:#fca5a5;font-size:.9rem;margin-top:.5rem}.loading{color:var(--muted);padding:2rem;text-align:center}.progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;min-width:60px}.progress-bar span{display:block;height:100%;background:var(--accent)}.stages-mini{font-size:.75rem;color:var(--muted);max-width:220px}.activity-list{list-style:none;padding:0;margin:0}.activity-list li{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.activity-list li:last-child{border-bottom:none}.activity-list time{font-size:.75rem;color:var(--muted)}.activity-list strong{color:var(--accent);font-weight:600}
