:root{--bg: #0F172A;--bg-panel: #16213A;--bg-card: #1B2740;--border: #2A3957;--text: #E7ECF5;--text-dim: #93A1BC;--accent: #F5A623;--accent-dim: #C8841A;--ok: #34D399;--warn: #F5A623;--danger: #F0556B;--blocked: #F0556B;--font-display: "Space Grotesk", "Segoe UI", sans-serif;--font-body: "Inter", "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", monospace;--radius: 10px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-display);font-weight:600;margin:0 0 4px}a{color:var(--accent)}button{font-family:var(--font-body);cursor:pointer}.app-shell{display:flex;min-height:100vh}.sidebar{width:230px;flex-shrink:0;background:var(--bg-panel);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column}.sidebar .brand{font-family:var(--font-display);font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:28px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar nav a{text-decoration:none;color:var(--text-dim);padding:10px 12px;border-radius:8px;font-size:14px;font-weight:500}.sidebar nav a:hover{background:var(--bg-card);color:var(--text)}.sidebar nav a.active{background:var(--bg-card);color:var(--accent)}.sidebar .footer-user{margin-top:auto;font-size:12px;color:var(--text-dim);border-top:1px solid var(--border);padding-top:14px}.sidebar .footer-user button{background:none;border:none;color:var(--danger);font-size:12px;padding:0;margin-top:8px}.main{flex:1;padding:28px 36px;max-width:1100px}.page-header{margin-bottom:24px}.page-header p{color:var(--text-dim);margin:4px 0 0;font-size:14px}.grid{display:grid;gap:16px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 900px){.grid-3,.grid-2{grid-template-columns:1fr}.app-shell{flex-direction:column}.sidebar{width:auto}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.card h3{font-size:14px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.card .big{font-size:32px;font-family:var(--font-display);margin-top:6px}.list-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.badge-pendiente{background:#f5a62326;color:var(--accent)}.badge-en_curso{background:#63b3ed26;color:#63b3ed}.badge-bloqueado{background:#f0556b26;color:var(--danger)}.badge-hecho{background:#34d39926;color:var(--ok)}input,select,textarea{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:9px 12px;font-size:14px;width:100%;font-family:var(--font-body)}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.btn{background:var(--accent);color:#1b2740;border:none;padding:9px 16px;border-radius:8px;font-weight:600;font-size:14px}.btn:hover{background:var(--accent-dim)}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);padding:9px 16px;border-radius:8px;font-size:14px}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.form-grid{display:grid;gap:12px;margin-bottom:16px}.form-row label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:4px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,#1B2740,var(--bg) 60%)}.login-card{width:360px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:32px}.login-card .brand-mark{width:40px;height:40px;border-radius:10px;background:var(--accent);margin-bottom:18px}.error-text{color:var(--danger);font-size:13px;margin-top:8px}table{width:100%;border-collapse:collapse}th{text-align:left;color:var(--text-dim);font-size:12px;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--border)}td{padding:10px;border-bottom:1px solid var(--border);font-size:14px}.empty-state{text-align:center;padding:40px 20px;color:var(--text-dim)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#070c18b3;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;width:420px;max-height:85vh;overflow-y:auto}
