:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;min-width:320px;min-height:100vh}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2rem;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1{margin:0 0 .5rem;color:#333;font-size:1.5rem;text-align:center}.login-box h2{margin:0 0 1.5rem;color:#666;font-size:1.2rem;text-align:center;font-weight:400}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:5px;font-size:1rem;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.error-message{color:#d32f2f;margin-bottom:1rem;padding:.5rem;background:#ffebee;border-radius:5px;text-align:center}.login-button{width:100%;padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:background .3s}.login-button:hover:not(:disabled){background:#5568d3}.login-button:disabled{background:#ccc;cursor:not-allowed}.contracts-list{padding:2rem;max-width:1400px;margin:0 auto}.btn-secondary{padding:.75rem 1.5rem;background:#666;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s}.btn-primary{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s}.filter-group select,.filter-group input{padding:.5rem;border:1px solid #ddd;border-radius:5px;font-size:.9rem}.filter-group input{min-width:200px}.totals-bar{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem;background:#e3f2fd;border-radius:5px}.total-item{display:flex;gap:.5rem}.total-label{font-weight:500;color:#555}.total-value{font-weight:700;color:#1976d2}.contracts-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 4px #0000001a;border-radius:5px;overflow:hidden}.contracts-table thead{background:#667eea;color:#fff}.contracts-table th{padding:1rem;text-align:left;font-weight:600}.contracts-table td{padding:.75rem 1rem;border-bottom:1px solid #eee}.contracts-table tbody tr:hover,.contracts-table tfoot{background:#f5f5f5}.footer-totals td{padding:1rem;font-size:1.1rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:10px;max-width:90%;max-height:90%;overflow:auto;box-shadow:0 10px 25px #0000004d}.modal-large{width:90%;max-width:1200px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.modal-header h2{margin:0;color:#333}.close-button{background:none;border:none;font-size:2rem;cursor:pointer;color:#666;line-height:1;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#333}.modal-body{padding:1.5rem}.schedule-table{width:100%;border-collapse:collapse}.schedule-table thead{background:#667eea;color:#fff}.schedule-table th{padding:.75rem;text-align:left;font-weight:600}.schedule-table td{padding:.75rem;border-bottom:1px solid #eee}.schedule-table tbody tr:hover{background:#f5f5f5}.schedule-table tbody tr.paid-row{background:#e8f5e9}.schedule-table tbody tr.paid-row:hover{background:#c8e6c9}.schedule-table input[type=checkbox]{width:20px;height:20px;cursor:pointer}.contract-detail{padding:2rem;max-width:1200px;margin:0 auto}.btn-primary,.btn-success,.btn-danger{padding:.75rem 1.5rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:opacity .3s}.btn-success{background:#4caf50;color:#fff}.btn-large{padding:1rem 2rem;font-size:1.1rem}.btn-primary:hover,.btn-success:hover,.btn-danger:hover{opacity:.8}.contract-form{padding:2rem;max-width:900px;margin:0 auto}.input-with-button{display:flex;gap:.5rem}.input-with-button input,.input-with-button select{flex:1}.btn-new-customer{padding:.75rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:5px;cursor:pointer;white-space:nowrap}.btn-new-customer:hover{background:#45a049}.btn-calculate{padding:.75rem 1rem;background:#667eea;color:#fff;border:none;border-radius:5px;cursor:pointer;white-space:nowrap}.btn-calculate:hover{background:#5568d3}.customers-list{padding:2rem;max-width:1400px;margin:0 auto}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:background .3s}.btn-primary{background:#667eea}.btn-primary:hover{background:#5568d3}.btn-secondary{background:#666}.btn-secondary:hover{background:#555}.filters{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#f5f5f5;border-radius:5px}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-weight:500;color:#333}.filter-group select{padding:.5rem;border:1px solid #ddd;border-radius:5px;font-size:.9rem}.customers-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 4px #0000001a;border-radius:5px;overflow:hidden}.customers-table thead{background:#667eea;color:#fff}.customers-table th{padding:1rem;text-align:left;font-weight:600}.customers-table td{padding:.75rem 1rem;border-bottom:1px solid #eee}.customers-table tbody tr:hover{background:#f5f5f5}.no-data{text-align:center;padding:2rem;color:#999}.action-buttons{display:flex;gap:.5rem}.btn-small{padding:.4rem .8rem;border:none;border-radius:3px;cursor:pointer;font-size:.85rem;transition:opacity .3s}.btn-warning{background:#ff9800;color:#fff}.loading{text-align:center;padding:2rem;color:#666}.customer-detail{padding:2rem;max-width:1200px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header-actions{display:flex;gap:.5rem}.btn-primary,.btn-danger{padding:.75rem 1.5rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:opacity .3s}.btn-primary{background:#667eea;color:#fff}.btn-danger{background:#f44336;color:#fff}.btn-primary:hover,.btn-danger:hover{opacity:.8}.detail-sections{display:flex;flex-direction:column;gap:2rem}.section{background:#fff;padding:1.5rem;border-radius:5px;box-shadow:0 2px 4px #0000001a}.section h2{margin:0 0 1rem;color:#333;border-bottom:2px solid #667eea;padding-bottom:.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column}.info-item label{font-weight:600;color:#666;margin-bottom:.25rem;font-size:.9rem}.info-item span{color:#333;font-size:1rem}.contracts-table{width:100%;border-collapse:collapse;margin-top:1rem}.contracts-table thead{background:#f5f5f5}.contracts-table th{padding:.75rem;text-align:left;font-weight:600;border-bottom:2px solid #ddd}.contracts-table td{padding:.75rem;border-bottom:1px solid #eee}.contracts-table tbody tr:hover{background:#f9f9f9}.btn-small{padding:.4rem .8rem;border:none;border-radius:3px;cursor:pointer;font-size:.85rem}.btn-small:hover{opacity:.8}.btn-info{background:#2196f3;color:#fff}.loading,.error{text-align:center;padding:2rem;color:#666}.error{color:#f44336}.customer-form{padding:2rem;max-width:900px;margin:0 auto}.header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.header h1{margin:0;color:#333}.btn-back{padding:.5rem 1rem;background:#666;color:#fff;border:none;border-radius:5px;cursor:pointer;text-decoration:none;display:inline-block}.btn-back:hover{background:#555}.form{background:#fff;padding:2rem;border-radius:5px;box-shadow:0 2px 4px #0000001a}.form-group{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:5px;font-size:1rem;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.error-message{color:#d32f2f;margin-bottom:1rem;padding:.75rem;background:#ffebee;border-radius:5px}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.btn-cancel,.btn-submit{padding:.75rem 1.5rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem}.btn-cancel{background:#ccc;color:#333}.btn-cancel:hover{background:#bbb}.btn-submit{background:#667eea;color:#fff}.btn-submit:hover:not(:disabled){background:#5568d3}.btn-submit:disabled{background:#ccc;cursor:not-allowed}*{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:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
