.navbar{background-color:#1a1a1a;padding:0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px #0000001a}.navbar-container{max-width:1400px;margin:0 auto;display:flex;align-items:center;padding:0 20px;justify-content:space-between}.navbar-logo{color:#fff;text-decoration:none;font-size:24px;font-weight:700;padding:20px 0;margin-right:40px;white-space:nowrap}.navbar-logo:hover{color:#4caf50}.user-menu{display:flex;align-items:center;gap:15px;margin-left:auto;padding-left:20px}.user-info{display:flex;align-items:center;gap:10px;padding:8px 15px;background:#ffffff1a;border-radius:8px}.user-icon{font-size:20px}.user-details{display:flex;flex-direction:column;align-items:flex-start}.user-name{color:#fff;font-size:14px;font-weight:600}.user-role{color:#ddd;font-size:12px}.logout-btn{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease}.logout-btn:hover{background:#ff3b30cc;border-color:#ff3b30}.nav-menu{display:flex;list-style:none;margin:0;padding:0;flex-wrap:wrap;gap:5px}.nav-item{margin:0}.nav-link{color:#ddd;text-decoration:none;padding:20px 15px;display:block;transition:all .3s ease;font-size:14px;font-weight:500}.nav-link:hover{background-color:#333;color:#4caf50}.nav-link.active{background-color:#4caf50;color:#fff}@media (max-width: 1200px){.navbar-container{flex-direction:column;align-items:flex-start}.navbar-logo{margin-right:0;padding:15px 0}.nav-menu{width:100%}.nav-link{padding:12px 15px;font-size:13px}.user-menu{width:100%;padding:15px 0;margin-left:0;border-top:1px solid #333}}@media (max-width: 768px){.nav-menu{flex-direction:column;gap:0}.nav-item{width:100%}.nav-link{border-top:1px solid #333}.user-menu{flex-direction:column;gap:10px}.user-info{width:100%;justify-content:center}.logout-btn{width:100%}.user-details{align-items:center}}.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;position:relative;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.login-box{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:450px;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:30px}.login-icon{font-size:64px;margin-bottom:10px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1{color:#333;margin-bottom:5px;font-size:28px}.login-header p{color:#666;font-size:14px}.login-form,.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:all .3s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:15px;font-size:14px;border:1px solid #fcc}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.login-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #667eea4d}.login-button:active{transform:translateY(0)}.login-footer{margin-top:20px;text-align:center}.show-credentials-btn{background:transparent;border:2px solid #e0e0e0;color:#666;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;transition:all .3s ease}.show-credentials-btn:hover{border-color:#667eea;color:#667eea}.credentials-demo{margin-top:20px;padding:20px;background:#f8f9fa;border-radius:8px;text-align:left}.credentials-demo p{color:#333;margin:0;font-size:14px}.credentials-list{display:flex;flex-direction:column;gap:10px}.credential-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fff;border-radius:6px;border:1px solid #e0e0e0}.credential-item strong{color:#333;font-size:13px}.credential-item button{background:#667eea;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-family:monospace;transition:all .3s ease}.credential-item button:hover{background:#5568d3}.security-notice{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.security-notice p{color:#666;font-size:13px;margin:0}.spinner{border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@media (max-width: 480px){.login-box{padding:30px 20px}.login-header h1{font-size:24px}.login-icon{font-size:48px}.credential-item{flex-direction:column;gap:8px;align-items:flex-start}.credential-item button{width:100%}}.pruebas-container{display:grid;grid-template-columns:400px 1fr;gap:20px;margin-top:20px}.pruebas-list{display:flex;flex-direction:column;gap:15px;max-height:800px;overflow-y:auto;padding-right:10px}.prueba-card{padding:20px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease}.prueba-card:hover{border-color:#4caf50;box-shadow:0 4px 8px #0000001a}.prueba-card.selected{border-color:#4caf50;background-color:#f0f9ff;box-shadow:0 4px 12px #4caf5033}.prueba-card.destacado{border-color:#ff9800;background:linear-gradient(135deg,#fff8e1,#fff)}.prueba-card.destacado.selected{border-color:#ff9800;box-shadow:0 4px 12px #ff98004d}.prueba-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.prueba-header h3{margin:0;color:#333;font-size:18px}.prueba-titulo{font-weight:600;color:#555;margin:10px 0}.prueba-tipo{color:#666;font-size:14px;margin:5px 0}.prueba-fecha{color:#999;font-size:13px;margin:5px 0}.destacado-badge{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700;text-align:center;margin-top:10px}.prueba-details{background:#fff;border-radius:8px;padding:30px;box-shadow:0 2px 8px #0000001a;max-height:800px;overflow-y:auto}.prueba-details h2{color:#333;margin-bottom:20px;font-size:26px}.detail-section{margin-top:30px;padding-top:20px;border-top:2px solid #f0f0f0}.detail-section h3{color:#333;margin-bottom:15px;font-size:20px}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.info-item{padding:15px;background:#f8f9fa;border-radius:6px}.info-item strong{display:block;margin-bottom:5px;color:#555}.destacado-section{background:linear-gradient(135deg,#fff8e1,#fff);padding:25px;border-radius:8px;border:2px solid #ff9800}.detection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:20px}.detection-card{background:#fff;padding:20px;border-radius:8px;border:2px solid #e0e0e0;transition:all .3s ease}.detection-card:hover{border-color:#4caf50;box-shadow:0 4px 8px #0000001a}.detection-card h4{color:#333;margin-bottom:15px;font-size:16px}.detection-status{font-size:14px;font-weight:700;color:#4caf50;margin-bottom:10px;padding:8px;background:#e8f5e9;border-radius:4px;text-align:center}.detection-card p{font-size:13px;color:#666;margin:8px 0}.precision{font-weight:700;color:#4caf50}.evidencias-list{list-style:none;padding:0}.evidencias-list li{padding:10px;margin:8px 0;background:#f8f9fa;border-radius:6px;display:flex;align-items:center;gap:10px}.evidencia-icon{font-size:20px}@media (max-width: 1024px){.pruebas-container{grid-template-columns:1fr}.pruebas-list{max-height:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.detection-grid{grid-template-columns:1fr}}@media (max-width: 768px){.pruebas-list,.info-grid{grid-template-columns:1fr}}.filters-container{margin:20px 0}.filter-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.filter-btn{padding:8px 16px;border:2px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease}.filter-btn:hover{border-color:#4caf50;background-color:#f0f9ff}.filter-btn.active{background-color:#4caf50;color:#fff;border-color:#4caf50}.filter-btn.highlight{border-color:#ff9800;color:#ff9800}.filter-btn.highlight.active{background-color:#ff9800;color:#fff}.trazabilidad-table tbody tr.expanded{background-color:#f0f9ff}.trazabilidad-table .expanded-content{background-color:#fafafa}.expand-btn{background:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-weight:700}.expand-btn:hover{background:#45a049}.details-panel{padding:20px;background:#fff;border-radius:6px;margin:10px}.details-section{margin-bottom:20px}.details-section h3{color:#333;margin-bottom:10px;font-size:18px}.details-section h4{color:#555;margin:10px 0;font-size:16px}.details-section ul{list-style:none;padding-left:0}.details-section ul li{padding:5px 0;color:#666}.badge-id{display:inline-block;padding:4px 10px;background-color:#e3f2fd;color:#1976d2;border-radius:4px;font-size:12px;font-weight:600}.badge-id.obj{background-color:#f3e5f5;color:#7b1fa2}.badge-id.esf{background-color:#fff3e0;color:#e65100}.badge-id.pe{background-color:#e8f5e9;color:#2e7d32}@media (max-width: 768px){.filter-buttons{gap:5px}.filter-btn{padding:6px 12px;font-size:12px}.details-panel{padding:15px}}.App{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:20px;max-width:1400px;margin:0 auto;width:100%}.footer{background-color:#1a1a1a;color:#fff;text-align:center;padding:20px;margin-top:auto}.footer p{margin:0;font-size:14px}.page{background:#fff;border-radius:8px;padding:30px;box-shadow:0 2px 4px #0000001a}.page h1{color:#1a1a1a;margin-bottom:10px;font-size:32px}.page h2{color:#333;margin-top:30px;margin-bottom:15px;font-size:24px}.page p{color:#666;line-height:1.6;margin-bottom:15px}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.badge.ok,.badge.completado{background-color:#d4edda;color:#155724}.badge.pendiente{background-color:#fff3cd;color:#856404}.badge.error{background-color:#f8d7da;color:#721c24}.table-container{overflow-x:auto;margin-top:20px}table{width:100%;border-collapse:collapse;background:#fff}table thead{background-color:#f8f9fa}table th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}table td{padding:12px;border-bottom:1px solid #dee2e6;color:#666}table tbody tr:hover{background-color:#f8f9fa}.search-box{margin:20px 0}.search-box input{width:100%;padding:12px 20px;border:1px solid #ddd;border-radius:6px;font-size:16px}.search-box input:focus{outline:none;border-color:#4caf50}.card{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.card h3{color:#333;margin-bottom:10px}.card p{color:#666;margin-bottom:8px}.btn{display:inline-block;padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .3s ease}.btn-primary{background-color:#4caf50;color:#fff}.btn-primary:hover{background-color:#45a049}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.spinner{border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.main-content{padding:10px}.page{padding:20px}.page h1{font-size:24px}table{font-size:14px}table th,table td{padding:8px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
