@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--primary-color:#d2386c;--primary-hover:#b52c5a;--primary-light:#d2386c14;--bg-dark:#101820;--bg-dark-2:#1a2530;--bg-light:#f4f6f9;--text-dark:#1a1a2e;--text-light:#fff;--surface-white:#fff;--border-color:#e2e8f0;--status-red:#ef4444;--status-yellow:#f59e0b;--status-green:#22c55e;--status-red-bg:#fef2f2;--status-yellow-bg:#fffbeb;--status-green-bg:#f0fdf4;color:var(--text-dark);background-color:var(--bg-light);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{min-height:100vh;margin:0;display:flex}#root{width:100%}h1,h2,h3,h4,h5,h6{color:var(--text-dark);margin-top:0;font-weight:600}.alert{border-radius:6px;margin-bottom:1rem;padding:.6rem .9rem;font-size:.9rem}.alert-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.alert-success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.alert-info{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.container{max-width:1280px;margin:0 auto;padding:2rem}.auth-container{background:linear-gradient(135deg, var(--bg-dark) 0%, var(--bg-dark-2) 60%, #1e3a4a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:var(--surface-white);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-align:center;border-radius:16px;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 20px 60px #00000059}.auth-logo-wrap{margin-bottom:1.5rem}.auth-logo-wrap img{object-fit:contain;max-width:220px;max-height:70px}.auth-brand-fallback{color:var(--primary-color);margin:0;font-size:1.4rem;font-weight:700}.auth-title{color:var(--text-dark);margin-bottom:.25rem;font-size:1.15rem}.auth-subtitle{color:#888;margin-bottom:1.5rem;font-size:.85rem}.auth-footer{color:#aaa;margin-top:2rem;font-size:.78rem}.form-group{text-align:left;margin-bottom:1.25rem}.form-group label{color:#374151;margin-bottom:.4rem;font-size:.9rem;font-weight:500;display:block}.form-control{border:1px solid var(--border-color);background:#fff;border-radius:8px;width:100%;padding:.65rem .9rem;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-control:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #d2386c1f}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.4rem;padding:.65rem 1.4rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--primary-color);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #d2386c4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-outline{border:1px solid var(--border-color);color:var(--text-dark);background:0 0}.btn-outline:hover{background:var(--bg-light)}.dashboard-header{background-color:var(--bg-dark);color:var(--text-light);z-index:100;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1.5rem;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #00000040}.header-left{flex-wrap:wrap;align-items:center;gap:1.25rem;display:flex}.header-logo{object-fit:contain;width:auto;height:36px}.header-brand{color:var(--primary-color);white-space:nowrap;font-size:1.05rem;font-weight:700}.header-nav{gap:.5rem;display:flex}.nav-btn{color:#fff;cursor:pointer;background:#ffffff12;border:1px solid #ffffff26;border-radius:6px;padding:.4rem .85rem;font-family:inherit;font-size:.85rem;transition:all .2s}.nav-btn:hover{border-color:var(--primary-color);background:#ffffff26}.header-right{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.header-link{color:#fff9;font-size:.82rem;text-decoration:none;transition:color .2s}.header-link:hover{color:var(--primary-color)}.header-divider{background:#fff3;width:1px;height:20px}.user-chip{color:#fff;cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.3rem 0;display:flex}.user-chip:hover{opacity:.8}.role-badge{color:var(--primary-color);background:#d2386c33;border:1px solid #d2386c4d;border-radius:20px;padding:.15rem .6rem;font-size:.78rem;font-weight:600}.page-title-row{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.page-title-row h2{margin:0}.badge-count{background:var(--primary-light);color:var(--primary-color);border-radius:20px;padding:.2rem .75rem;font-size:.85rem;font-weight:600}.loading-state,.empty-state{text-align:center;color:#888;padding:4rem 2rem}.spinner{border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;width:36px;height:36px;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.card-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.card{background:var(--surface-white);border:1px solid var(--border-color);cursor:pointer;border-radius:12px;padding:1.4rem;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 2px 8px #0000000f}.card:hover{border-color:var(--primary-color);transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.card-title{color:var(--primary-color);margin-bottom:.4rem;font-size:1.1rem;font-weight:700}.card-meta{color:#888;justify-content:space-between;font-size:.85rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;background:#10182099;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{background:var(--surface-white);border-radius:14px;width:100%;max-height:90vh;animation:.2s modal-in;overflow-y:auto;box-shadow:0 20px 60px #00000040}@keyframes modal-in{0%{opacity:0;transform:scale(.96)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);background:var(--surface-white);z-index:1;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;display:flex;position:sticky;top:0}.modal-body{padding:1.5rem}.items-table{border-collapse:collapse;width:100%}.items-table th,.items-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:.75rem .85rem}.items-table th{color:#374151;text-transform:uppercase;letter-spacing:.03em;background:#f8fafc;font-size:.85rem;font-weight:600}.items-table tbody tr:hover{background:var(--bg-light)}.traffic-light-container{background:var(--bg-dark);border-radius:24px;align-items:center;gap:.45rem;padding:.3rem .5rem;display:inline-flex}.traffic-light-bulb{cursor:pointer;opacity:.2;border-radius:50%;flex-shrink:0;width:22px;height:22px;transition:all .25s;box-shadow:inset 0 0 4px #0009}.traffic-light-bulb:hover{opacity:.6;transform:scale(1.1)}.traffic-light-bulb.red{background-color:var(--status-red)}.traffic-light-bulb.yellow{background-color:var(--status-yellow)}.traffic-light-bulb.green{background-color:var(--status-green)}.traffic-light-bulb.active{opacity:1}.traffic-light-bulb.red.active{box-shadow:0 0 10px var(--status-red), 0 0 20px #ef444466}.traffic-light-bulb.yellow.active{box-shadow:0 0 10px var(--status-yellow), 0 0 20px #f59e0b66}.traffic-light-bulb.green.active{box-shadow:0 0 10px var(--status-green), 0 0 20px #22c55e66}.history-button{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.3rem;transition:all .2s;display:inline-flex}.history-button:hover{background:var(--bg-light);color:var(--primary-color)}.history-timeline{flex-direction:column;gap:0;display:flex}.history-entry{border-bottom:1px solid var(--border-color);gap:1rem;padding:.75rem 0;display:flex}.history-entry:last-child{border-bottom:none}.history-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:4px;box-shadow:0 0 6px}.history-info{flex:1}.history-estado{margin-bottom:.2rem;font-size:.85rem;font-weight:600}.history-user{margin-bottom:.15rem;font-size:.88rem}.history-date{color:#94a3b8;font-size:.78rem}
