*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#f5f7fa;color:#333;line-height:1.6}.app{display:flex;min-height:100vh}.sidebar{width:250px;background:#2d3748;color:#fff;padding:2rem 0;display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.sidebar h2{padding:0 1.5rem;margin-bottom:2rem;font-size:1.5rem;color:#4299e1}.sidebar nav{flex:1}.sidebar-item{padding:1rem 1.5rem;cursor:pointer;transition:background .2s ease;display:flex;align-items:center;gap:.75rem;color:#e2e8f0;font-weight:500}.sidebar-item:hover{background:#4a5568}.sidebar-item.active{background:#4299e1;color:#fff;border-left:4px solid #2c5282}.main-content{flex:1;margin-left:250px;padding:2rem;max-width:1400px}.header{text-align:center;margin-bottom:2rem}.header h1{color:#1a365d;font-size:2rem;margin-bottom:.5rem}.header p{color:#666}.dropzone{border:3px dashed #cbd5e0;border-radius:12px;padding:3rem;text-align:center;cursor:pointer;transition:all .2s ease;background:#fff;margin-bottom:2rem}.dropzone:hover,.dropzone.active{border-color:#4299e1;background:#ebf8ff}.dropzone h3{color:#2d3748;margin-bottom:.5rem}.dropzone p{color:#718096;font-size:.9rem}.file-list{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem}.file-list h4{margin-bottom:.5rem;color:#2d3748}.file-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f7fafc;border-radius:4px;margin-bottom:.5rem}.file-item:last-child{margin-bottom:0}.file-item .name{font-weight:500}.file-item .size{color:#718096;font-size:.85rem}.file-item .remove{color:#e53e3e;cursor:pointer;padding:.25rem .5rem;border:none;background:none;font-size:1.2rem}.actions{display:flex;gap:1rem;margin-bottom:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s ease;font-weight:500}.btn-primary{background:#4299e1;color:#fff}.btn-primary:hover:not(:disabled){background:#3182ce}.btn-primary:disabled{background:#a0aec0;cursor:not-allowed}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover{background:#cbd5e0}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:#4299e1}.spinner{width:24px;height:24px;border:3px solid #e2e8f0;border-top-color:#4299e1;border-radius:50%;animation:spin 1s linear infinite;margin-right:.75rem}@keyframes spin{to{transform:rotate(360deg)}}.results{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.results-header h2{color:#2d3748}.stats{display:flex;gap:1rem}.stat{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.stat.success{background:#c6f6d5;color:#276749}.stat.failed{background:#fed7d7;color:#c53030}.result-item{border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;overflow:hidden}.result-item:last-child{margin-bottom:0}.result-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f7fafc;cursor:pointer;transition:all .2s ease}.result-header:hover{background:#edf2f7;box-shadow:0 2px 4px #0000000d}.result-header .expand-arrow{color:#4299e1;font-size:.7rem;margin-right:.5rem;transition:transform .2s ease}.result-header .header-left{display:flex;align-items:center;gap:.75rem}.result-header .filename{font-weight:600;color:#2d3748}.result-header .doc-type{font-size:.75rem;padding:.25rem .6rem;background:#bee3f8;color:#2c5282;border-radius:12px;font-weight:500}.result-header .status{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.result-header .status.success{background:#c6f6d5;color:#276749}.result-header .status.error{background:#fed7d7;color:#c53030}.result-body{padding:1rem;border-top:1px solid #e2e8f0}.json-view{background:#1a202c;color:#e2e8f0;padding:1rem;border-radius:6px;overflow-x:auto;font-family:Fira Code,Monaco,monospace;font-size:.85rem;line-height:1.5;max-height:500px;overflow-y:auto}.section{margin-bottom:1.5rem}.section:last-child{margin-bottom:0}.section h4{color:#4a5568;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.data-item{display:flex;flex-direction:column;padding:.75rem;background:#f7fafc;border-radius:6px}.data-item .label{font-size:.75rem;color:#718096;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.25rem}.data-item .value{font-weight:600;color:#2d3748}.data-item .value.currency{color:#2f855a}.data-item .value.negative{color:#c53030}.fees-table{width:100%;border-collapse:collapse}.fees-table th,.fees-table td{padding:.5rem;text-align:left;border-bottom:1px solid #e2e8f0}.fees-table th{background:#f7fafc;font-weight:600;font-size:.85rem;color:#4a5568}.fees-table td:last-child{text-align:right;font-family:Fira Code,monospace}.view-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.view-toggle button{padding:.5rem 1rem;border:1px solid #e2e8f0;background:#fff;border-radius:4px;cursor:pointer;font-size:.9rem}.view-toggle button.active{background:#4299e1;color:#fff;border-color:#4299e1}.error-message{background:#fff5f5;border:1px solid #feb2b2;color:#c53030;padding:1rem;border-radius:6px}.copy-btn{padding:.5rem 1rem;background:#4a5568;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.copy-btn:hover{background:#2d3748}.settings-container{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.settings-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e2e8f0}.settings-section:last-child{border-bottom:none;margin-bottom:0}.settings-section h3{color:#2d3748;margin-bottom:1.5rem;font-size:1.1rem}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.setting-item{display:flex;flex-direction:column}.setting-item label{font-weight:600;color:#4a5568;margin-bottom:.5rem;font-size:.9rem}.setting-item input[type=number]{padding:.75rem;border:1px solid #cbd5e0;border-radius:6px;font-size:1rem;transition:border-color .2s ease}.setting-item input[type=number]:focus{outline:none;border-color:#4299e1}.setting-item input[type=checkbox]{accent-color:#4299e1}.setting-item .helper-text{font-size:.85rem;color:#718096;margin-top:.25rem}.completed-container{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.loan-card{border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;margin-bottom:1rem;transition:box-shadow .2s ease}.loan-card:hover{box-shadow:0 4px 6px #0000001a}.loan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.loan-header h3{color:#2d3748;font-size:1.1rem}.loan-number{color:#718096;font-size:.9rem;font-family:monospace}.loan-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.detail-item{display:flex;flex-direction:column}.detail-item .label{font-size:.8rem;color:#718096;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.25rem}.detail-item .value{font-weight:600;color:#2d3748}.calculation-section{background:#f7fafc;padding:1rem;border-radius:6px;margin-top:1rem}.calculation-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #e2e8f0}.calculation-row:last-child{border-bottom:none;font-weight:700;font-size:1.1rem;color:#2f855a;padding-top:1rem;margin-top:.5rem;border-top:2px solid #2f855a}.calculation-row.subtraction{color:#c53030}.btn-payroll{background:#48bb78;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;font-weight:600;transition:background .2s ease}.btn-payroll:hover{background:#38a169}.empty-state{text-align:center;padding:4rem 2rem;color:#718096}.empty-state h3{color:#4a5568;margin-bottom:.5rem}
