.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center;box-shadow:0 2px 10px #0000001a}.app-header h1{margin:0;font-size:2rem;font-weight:700}.app-header p{margin:.5rem 0 0;opacity:.9}.credits-info{margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.credits-info span{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-weight:600}.credits-info .low-credits{background:#ff64644d}.container{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}section{background:#fff;border-radius:10px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 10px #0000000d}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.section-header h2{margin:0;color:#333;font-size:1.5rem}.section-header p{margin:.5rem 0 0;color:#666;font-size:.9rem}.config-panel{display:grid;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333;font-size:.9rem}.form-group input,.form-group select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group small{color:#666;font-size:.85rem}.form-group small a{color:#667eea;text-decoration:none}.form-group small a:hover{text-decoration:underline}.info-box{background:#e3f2fd;color:#1565c0;padding:.75rem;border-radius:6px;font-size:.85rem;margin-top:.5rem}.records-panel{margin-top:1rem}.records-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.records-header h3{margin:0;color:#333}.button-group{display:flex;gap:.5rem}.records-list{max-height:400px;overflow-y:auto;border:2px solid #f0f0f0;border-radius:6px;padding:.5rem}.record-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:6px;cursor:pointer;transition:all .2s;margin-bottom:.25rem}.record-item:hover{background:#f5f5f5}.record-item.selected{background:#e8eaf6;border:1px solid #667eea}.record-item input[type=checkbox]{cursor:pointer}.mapping-grid{display:grid;gap:1rem}.mapping-row{display:grid;grid-template-columns:200px 1fr;gap:1rem;align-items:center}.mapping-row label{font-weight:600;color:#333;font-size:.9rem}.mapping-row select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem}.generation-panel{display:flex;flex-direction:column;gap:1rem}.selection-info{padding:1rem;border-radius:6px;text-align:center;font-weight:600}.selection-info .success{color:#2e7d32}.selection-info .warning{color:#f57c00}.status-message{padding:1rem;background:#f5f5f5;border-radius:6px;text-align:center;color:#333}.results-panel{padding:1rem;border-radius:6px;margin-top:1rem}.success-panel{background:#e8f5e9;border:2px solid #66bb6a}.error-panel{background:#ffebee;border:2px solid #ef5350}.results-panel h3{margin:0 0 1rem;color:#333}.result-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border-radius:6px;margin-bottom:.5rem}.result-item a{color:#667eea;text-decoration:none;font-weight:600}.result-item a:hover{text-decoration:underline}.error-text{color:#d32f2f;font-size:.85rem}button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f5f5f5;color:#333;border:2px solid #e0e0e0}.btn-secondary:hover:not(:disabled){background:#eee;border-color:#d0d0d0}.btn-icon{background:#fff3;color:#fff;padding:.5rem;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#ffffff4d}.btn-large{font-size:1.1rem;padding:1rem 2rem;width:100%}button:disabled{opacity:.5;cursor:not-allowed}.loading-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-screen h1{font-size:2rem;margin-bottom:1rem}.login-section{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-card{max-width:500px;width:100%;text-align:center}.login-card h2{margin-bottom:1rem;color:#333}.login-card p{color:#666;margin-bottom:2rem}.login-card ul{list-style:none;padding:0}.login-card li{padding:.5rem 0;color:#1565c0}.login-card li:before{content:"✓ ";font-weight:700;margin-right:.5rem}.app-footer{background:#333;color:#fff;text-align:center;padding:1.5rem;margin-top:auto}.app-footer p{margin:0;font-size:.9rem;opacity:.8}@media (max-width: 768px){.container{padding:1rem}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.mapping-row{grid-template-columns:1fr}.records-header{flex-direction:column;align-items:flex-start;gap:1rem}}*{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}#root{min-height:100vh}
