@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInModal{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn .4s ease-in-out}.nav-link{transition:background-color .3s ease,color .3s ease,border-color .3s ease;border-left:4px solid transparent}.nav-link.active-link{background-color:#eff6ff;color:#1d4ed8;font-weight:600;border-left-color:#3b82f6}#sidebar{position:fixed;left:0;top:0;height:100%;z-index:30}@media (min-width: 640px){#sidebar{position:relative;transform:translate(0)}}.modal-overlay{position:fixed;inset:0;background-color:#11182799;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem;animation:fadeIn .3s ease}.modal-content{background-color:#fff;border-radius:.75rem;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:650px;animation:fadeInModal .3s ease;max-height:90vh;display:flex;flex-direction:column;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.modal-body{padding:1.5rem;overflow-y:auto;flex-grow:1}.modal-footer{padding:1rem 1.5rem;background-color:#f9fafb;border-top:1px solid #e5e7eb;text-align:right;border-bottom-left-radius:.75rem;border-bottom-right-radius:.75rem}.modal-close{background:none;border:none;font-size:2rem;line-height:1;color:#9ca3af;cursor:pointer;transition:color .2s ease}.modal-close:hover{color:#1f2937}.form-input{appearance:none;border:1px solid #d1d5db;background-color:#fff;width:100%;padding:.5rem .75rem;border-radius:.375rem;line-height:1.5;font-size:1rem;color:#1f2937;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.form-input[readonly]{background-color:#f3f4f6;cursor:not-allowed}.form-input:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.btn-action{padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:600;color:#fff;border:none;cursor:pointer;transition:all .2s ease-in-out}.btn-action:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-action:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-edit{background-color:#3b82f6}.btn-edit:hover{background-color:#2563eb}.btn-delete{background-color:#ef4444}.btn-delete:hover{background-color:#dc2626}.btn-view{background-color:#f97316}.btn-view:hover{background-color:#ea580c}.btn-analysis{background-color:#0d9488}.btn-analysis:hover{background-color:#0f766e}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f666}.loader{border:4px solid #f3f3f3;border-top:4px solid #3b82f6;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.loader-overlay{position:absolute;inset:0;background-color:#fffc;display:flex;align-items:center;justify-content:center;z-index:60;border-radius:.75rem}.loader-light{border:4px solid rgba(255,255,255,.2);border-top:4px solid #fff;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.selo-display{font-size:3rem;line-height:1;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.chart-loader{display:flex;align-items:center;justify-content:center;height:100%;min-height:250px}.loader{border:4px solid rgba(0,0,0,.1);border-top:4px solid #3b82f6;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
