:root{--color-primary: #1e3a5f;--color-secondary: #2c7da0;--color-accent: #52b788;--color-bg: #f4f6f8;--color-danger: #d64545;--color-success: #2e7d32;--color-warning: #f0ad4e;--color-border: #dde3e8;--color-text: #1f2933;--color-text-light: #6b7280;--sidebar-width: 240px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Arial,sans-serif;background-color:var(--color-bg);color:var(--color-text);font-size:14px}.layout-container{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-primary);color:#fff;display:flex;flex-direction:column;padding:1.5rem 1rem;position:fixed;top:0;left:0;height:100vh;overflow-y:auto}.sidebar-header h2{font-size:1.4rem;font-weight:700;letter-spacing:1px}.rol-badge{font-size:.65rem;background:var(--color-secondary);padding:2px 8px;border-radius:10px;display:inline-block;margin-top:4px}.sidebar nav{margin-top:1.5rem}.sidebar nav ul{list-style:none}.sidebar nav ul li{margin-bottom:.3rem}.sidebar nav ul li a{color:#ffffffd9;text-decoration:none;display:block;padding:.5rem .8rem;border-radius:6px;transition:background .2s}.sidebar nav ul li a:hover,.sidebar nav ul li a.active{background:#ffffff1f;color:#fff}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.15);padding-top:1rem}.sidebar-footer p{font-size:.85rem;color:#ffffffb3;margin-bottom:.5rem}.sidebar-footer button{background:var(--color-danger);color:#fff;border:none;padding:.4rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem;width:100%}.sidebar-footer button:hover{background:#b83232}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2rem;min-height:100vh}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}h1{font-size:1.6rem;color:var(--color-primary);margin-bottom:1rem}h2{font-size:1.2rem;color:var(--color-primary);margin:1.5rem 0 .8rem}h3{font-size:1rem;margin:.8rem 0 .5rem}h4{font-size:.95rem;margin-bottom:.5rem;color:var(--color-text-light)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem;margin-bottom:1.5rem}.kpi-card{background:#fff;border-radius:10px;padding:1.2rem;box-shadow:0 1px 4px #00000012;border-left:4px solid var(--color-secondary)}.kpi-card.kpi-alerta{border-left-color:var(--color-danger)}.kpi-titulo{font-size:.8rem;color:var(--color-text-light);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.5px}.kpi-valor{font-size:1.7rem;font-weight:700;color:var(--color-primary)}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;margin-top:1rem;box-shadow:0 1px 4px #00000012}.data-table th,.data-table td{padding:.65rem 1rem;border-bottom:1px solid var(--color-border);text-align:left}.data-table th{background:var(--color-primary);color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8fafc}.fila-alerta td{background:#fff5f5!important}.badge{padding:3px 10px;border-radius:12px;font-size:.72rem;font-weight:600;color:#fff;display:inline-block}.estado-planificado{background:#9e9e9e}.estado-en_proceso{background:var(--color-secondary)}.estado-secado{background:var(--color-warning)}.estado-finalizado{background:var(--color-success)}.estado-cancelado{background:var(--color-danger)}.estado-pendiente{background:var(--color-warning);color:#333}.estado-entregada{background:var(--color-success)}.form-card{background:#fff;padding:1.5rem;border-radius:10px;max-width:520px;display:flex;flex-direction:column;gap:1rem;box-shadow:0 1px 4px #00000012;margin-top:1rem}.form-card label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600}.form-card input,.form-card select,.form-card textarea{padding:.5rem .7rem;border:1px solid var(--color-border);border-radius:6px;font-size:.9rem;background:#fafafa}.form-card input:focus,.form-card select:focus,.form-card textarea:focus{outline:none;border-color:var(--color-secondary);background:#fff}.form-card textarea{min-height:70px;resize:vertical}.item-row{display:flex;gap:.5rem;align-items:flex-start;flex-wrap:wrap}.item-row select,.item-row input{flex:1;min-width:120px}.qty-with-hint{display:flex;flex-direction:column;flex:1}.qty-with-hint small{color:var(--color-text-light);font-size:.72rem;margin-top:2px}.total-preview{background:#f0f7ff;border:1px solid #cce3f5;border-radius:8px;padding:.8rem 1rem;font-size:.9rem}.total-preview p{margin-bottom:.2rem}.formula-preview{background:#f8f9fa;border-radius:8px;padding:1rem;border:1px solid var(--color-border)}button{cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.88rem;font-weight:600;transition:background .2s}button:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#162d4a}.btn-secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:#e8ecf0}.btn-danger-small{background:var(--color-danger);color:#fff;padding:.3rem .6rem;font-size:.8rem}.btn-danger-small:hover{background:#b83232}.btn-primary-link{background:var(--color-primary);color:#fff;padding:.5rem 1rem;border-radius:6px;text-decoration:none;font-size:.88rem;font-weight:600}.btn-primary-link:hover{background:#162d4a}.success{color:var(--color-success);font-weight:600;font-size:.9rem}.error{color:var(--color-danger);font-weight:600;font-size:.9rem}.hint{color:var(--color-text-light);font-size:.88rem;margin-top:.5rem}.alert-box{background:#fff3cd;border:1px solid #ffe69c;padding:.8rem 1rem;border-radius:8px;margin:1rem 0;font-size:.9rem}.alert-box ul{margin-top:.4rem;padding-left:1.2rem}.filtros{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem;align-items:flex-end}.filtros label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600}.filtros input,.filtros select{padding:.4rem .6rem;border:1px solid var(--color-border);border-radius:6px;font-size:.88rem}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1rem;margin-top:1rem}.chart-container{background:#fff;border-radius:10px;padding:1rem;box-shadow:0 1px 4px #00000012}.eficiencia-resultado{margin-top:1.5rem}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%)}.login-container h1{color:#fff;font-size:2.2rem;letter-spacing:2px;margin-bottom:.3rem}.login-subtitle{color:#ffffffb3;margin-bottom:2rem;font-size:.9rem}.login-container form{display:flex;flex-direction:column;gap:.8rem;width:300px;background:#fff;padding:2rem;border-radius:12px;box-shadow:0 8px 32px #0003}.login-container input{padding:.65rem .8rem;border-radius:6px;border:1px solid var(--color-border);font-size:.95rem}.login-container input:focus{outline:none;border-color:var(--color-secondary)}.login-container button{padding:.65rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:700}.login-container button:hover:not(:disabled){background:#162d4a}.no-autorizado-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;gap:.8rem}.no-autorizado-container h1{font-size:5rem;color:var(--color-danger);margin:0}.no-autorizado-container a{color:var(--color-secondary);font-weight:600;text-decoration:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-wide{max-width:680px}.modal h2{margin-bottom:1rem;color:var(--color-primary);font-size:1.2rem}.modal-form{display:flex;flex-direction:column;gap:.8rem}.modal-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600}.modal-form input,.modal-form select,.modal-form textarea{padding:.5rem .7rem;border:1px solid var(--color-border);border-radius:6px;font-size:.9rem}.modal-form input:focus,.modal-form select:focus{outline:none;border-color:var(--color-secondary)}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.modal-actions{display:flex;gap:.8rem;justify-content:flex-end;margin-top:.5rem}.acciones-td{display:flex;gap:.4rem;flex-wrap:wrap}.cat-estandar{background:#2c7da0}.cat-rh{background:#52b788}.cat-rf{background:#e07a5f}.perfil-info{display:flex;flex-direction:column;gap:.5rem}.perfil-info p{font-size:.95rem}.perfil-link{color:#ffffffd9;text-decoration:none;font-size:.85rem;display:block;margin-bottom:.5rem}.perfil-link:hover{color:#fff}.menu-divider{border-top:1px solid rgba(255,255,255,.15);margin:.5rem 0;list-style:none}@media (max-width: 768px){.sidebar{width:100%;height:auto;position:relative}.main-content{margin-left:0;padding:1rem}.layout-container,.item-row{flex-direction:column}.modal-grid{grid-template-columns:1fr}}
