.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.error-container{max-width:600px;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 20px 40px #0000001a;text-align:center}.error-container h1{color:#dc3545;margin:0 0 1rem;font-size:2rem}.error-message{color:#6c757d;margin-bottom:2rem;line-height:1.6;font-size:1.1rem}.error-details{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;margin-bottom:2rem;text-align:left}.error-details h3{margin:0 0 1rem;color:#495057;font-size:1.2rem}.error-text{margin-bottom:1rem;font-family:monospace;font-size:.9rem;color:#dc3545;background:#fff;padding:.75rem;border-radius:4px;border:1px solid #f5c6cb}.error-stack{margin-top:1rem}.error-stack summary{cursor:pointer;font-weight:600;color:#6c757d;margin-bottom:.5rem}.error-stack pre{background:#2d3748;color:#e2e8f0;padding:1rem;border-radius:4px;overflow-x:auto;font-size:.8rem;line-height:1.4;margin:.5rem 0 0}.error-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.retry-button,.reload-button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem}.retry-button{background:#646cff;color:#fff}.retry-button:hover{background:#535bf2;transform:translateY(-1px)}.reload-button{background:#6c757d;color:#fff}.reload-button:hover{background:#5a6268;transform:translateY(-1px)}.error-help{background:#e7f3ff;border:1px solid #b8daff;border-radius:8px;padding:1.5rem;text-align:left}.error-help h3{margin:0 0 1rem;color:#004085;font-size:1.1rem}.error-help ul{margin:0;padding-left:1.5rem;color:#004085}.error-help li{margin-bottom:.5rem;line-height:1.4}@media (prefers-color-scheme: dark){.error-container{background:#2d3748;color:#e2e8f0}.error-container h1{color:#f56565}.error-message{color:#a0aec0}.error-details{background:#1a202c;border-color:#4a5568}.error-details h3{color:#e2e8f0}.error-text{background:#2d3748;color:#f56565;border-color:#e53e3e}.error-stack summary{color:#a0aec0}.error-help{background:#1a365d;border-color:#2c5282}.error-help h3,.error-help li{color:#90cdf4}}@media (max-width: 768px){.error-boundary{padding:1rem}.error-container{padding:1.5rem}.error-container h1{font-size:1.5rem}.error-actions{flex-direction:column}.retry-button,.reload-button{width:100%}}.module-selector{max-width:800px;margin:0 auto;padding:2rem}.module-selector h2{color:#333;margin-bottom:.5rem;font-size:1.8rem}.selector-description{color:#666;margin-bottom:2rem;font-size:1rem;line-height:1.5}.groups-container{display:flex;flex-direction:column;gap:2rem}.module-group{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;transition:box-shadow .2s ease}.module-group:hover{box-shadow:0 2px 8px #0000001a}.group-title{color:#495057;margin:0 0 1rem;font-size:1.3rem;font-weight:600;border-bottom:2px solid #dee2e6;padding-bottom:.5rem}.options-container{display:flex;flex-direction:column;gap:.75rem}.option-label{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:1px solid #dee2e6;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease}.option-label:hover{border-color:#646cff;background:#f8f9ff}.option-label:has(.option-radio:checked){border-color:#646cff;background:#f0f2ff;box-shadow:0 0 0 2px #646cff1a}.option-radio{margin:2px 0 0;width:18px;height:18px;accent-color:#646cff;flex-shrink:0}.option-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.option-name{font-weight:500;color:#333;font-size:1rem}.option-description{font-size:.875rem;color:#666;line-height:1.4}@media (prefers-color-scheme: dark){.module-selector h2{color:#f1f3f4}.selector-description{color:#9aa0a6}.module-group{background:#2d3748;border-color:#4a5568}.group-title{color:#e2e8f0;border-bottom-color:#4a5568}.option-label{background:#1a202c;border-color:#4a5568}.option-label:hover{background:#2d3748;border-color:#646cff}.option-label:has(.option-radio:checked){background:#2a2f3a;border-color:#646cff}.option-name{color:#f1f3f4}.option-description{color:#9aa0a6}}@media (max-width: 768px){.module-selector{padding:1rem}.module-selector h2{font-size:1.5rem}.group-title{font-size:1.2rem}.option-label{padding:.5rem}}.rom-file-picker{max-width:600px;margin:2rem auto;padding:2rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.rom-file-picker h3{color:#333;margin:0 0 .5rem;font-size:1.5rem}.file-input-container{display:flex;gap:.5rem;margin-bottom:1rem}.file-input{display:none}.file-input-label{flex:1;padding:.75rem 1rem;background:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;text-align:center;transition:background-color .2s ease;font-size:1rem}.file-input-label:hover{background:#535bf2}.clear-button{padding:.75rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.validation-status{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:6px;margin-bottom:1rem}.validation-status.validating{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.validation-status.valid{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.validation-status.invalid{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.status-icon{font-size:1.2rem;flex-shrink:0}.status-content{flex:1}.status-message{font-weight:600;margin-bottom:.25rem}.error-message{font-size:.9rem;margin-bottom:.25rem}.crc-info{font-size:.85rem;font-family:monospace;opacity:.8}.file-info{background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:1rem}.file-info h4{margin:0 0 .75rem;color:#333;font-size:1.1rem}.info-grid{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;font-size:.9rem}.info-grid span:nth-child(odd){font-weight:600;color:#495057}.info-grid span:nth-child(2n){color:#6c757d;font-family:monospace}@media (prefers-color-scheme: dark){.rom-file-picker{background:#2d3748;border-color:#4a5568}.rom-file-picker h3{color:#f1f3f4}.picker-description{color:#9aa0a6}.validation-status.validating{background:#3d3d1a;border-color:#5a5a2a;color:#f4e79d}.validation-status.valid{background:#1a3d2e;border-color:#2a5a4a;color:#9df4c4}.validation-status.invalid{background:#3d1a1a;border-color:#5a2a2a;color:#f49d9d}.file-info{background:#1a202c;border-color:#4a5568}.file-info h4{color:#f1f3f4}.info-grid span:nth-child(odd){color:#e2e8f0}.info-grid span:nth-child(2n){color:#9aa0a6}}@media (max-width: 768px){.rom-file-picker{margin:1rem;padding:1rem}.file-input-container{flex-direction:column}.info-grid{grid-template-columns:1fr;gap:.25rem}}.rom-builder{max-width:600px;margin:2rem auto;padding:2rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.rom-builder h3{color:#333;margin:0 0 .5rem;font-size:1.5rem}.builder-description{color:#666;margin-bottom:1.5rem;line-height:1.5}.build-status{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;padding:1rem;background:#fff;border:1px solid #dee2e6;border-radius:6px}.status-info{display:flex;align-items:center;gap:.5rem;font-size:.95rem}.status-indicator.pending{color:#ffc107}.status-indicator.optional{color:#6c757d}.progress-container{margin-bottom:1.5rem;padding:1rem;background:#fff;border:1px solid #dee2e6;border-radius:6px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.progress-stage{font-weight:600;color:#495057}.progress-percentage{font-size:.9rem;color:#6c757d;font-family:monospace}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#646cff,#535bf2);transition:width .3s ease;border-radius:4px}.progress-message{font-size:.9rem;color:#6c757d;font-style:italic}.build-actions{display:flex;justify-content:center;margin-bottom:1.5rem}.build-button{padding:.75rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;min-width:150px}.build-button.ready{background:#646cff;color:#fff}.build-button.ready:hover{background:#535bf2;transform:translateY(-1px);box-shadow:0 4px 8px #646cff4d}.build-button.disabled{background:#6c757d;color:#adb5bd;cursor:not-allowed}.build-complete{text-align:center;padding:1.5rem;background:#d4edda;border:1px solid #c3e6cb;border-radius:6px;color:#155724}.build-complete h4{margin:0 0 .5rem;color:#155724}.build-complete p{margin:0 0 1rem}.download-button{padding:.75rem 1.5rem;background:#28a745;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.download-button:hover{background:#218838}@media (prefers-color-scheme: dark){.rom-builder{background:#2d3748;border-color:#4a5568}.rom-builder h3{color:#f1f3f4}.builder-description{color:#9aa0a6}.build-status,.progress-container{background:#1a202c;border-color:#4a5568}.progress-stage{color:#e2e8f0}.progress-percentage,.progress-message{color:#9aa0a6}.progress-bar{background:#4a5568}.build-complete{background:#1a3d2e;border-color:#2a5a4a;color:#9df4c4}.build-complete h4{color:#9df4c4}}@media (max-width: 768px){.rom-builder{margin:1rem;padding:1rem}.build-status,.progress-container{padding:.75rem}.build-button{padding:.75rem 1.5rem;font-size:1rem}}.notepad{max-width:600px;margin:2rem auto;padding:2rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.notepad h3{color:#333;margin:0 0 .5rem;font-size:1.5rem}.notepad-description{color:#666;margin-bottom:1.5rem;line-height:1.5}.notepad-content{background:#fff;border:1px solid #dee2e6;border-radius:6px;overflow:hidden}.notepad-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8f9fa;border-bottom:1px solid #dee2e6;font-size:.9rem}.content-info{color:#666;font-weight:500}.clear-button{padding:.25rem .75rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .2s ease}.notepad-textarea{width:100%;min-height:300px;padding:1rem;border:none;outline:none;font-family:Consolas,Monaco,Courier New,monospace;font-size:.9rem;line-height:1.4;resize:vertical;background:#fff;color:#333}.notepad-textarea::placeholder{color:#999;font-style:italic}.notepad-textarea:focus{background:#fafbfc}.notepad-status{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#f8f9fa;border-top:1px solid #dee2e6;font-size:.9rem}.status-indicator{font-size:1rem;width:20px;text-align:center}@media (max-width: 768px){.notepad{margin:1rem;padding:1.5rem}.notepad-textarea{min-height:250px;font-size:.85rem}.notepad-header{flex-direction:column;gap:.5rem;align-items:flex-start}}.folder-picker{max-width:600px;margin:2rem auto;padding:2rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.folder-picker h3{color:#333;margin:0 0 .5rem;font-size:1.5rem}.picker-description{color:#666;margin-bottom:1.5rem;line-height:1.5}.folder-input-container{display:flex;gap:.5rem;margin-bottom:1rem}.folder-input{display:none}.folder-input-label{flex:1;padding:.75rem 1rem;background:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;text-align:center;transition:background-color .2s ease;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.folder-input-label:hover{background:#535bf2}.clear-button{padding:.75rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease;font-size:1rem}.clear-button:hover{background:#c82333}.scanning-status{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;margin-bottom:1rem;color:#1565c0}.loading-spinner{width:20px;height:20px;border:2px solid #bbdefb;border-top:2px solid #1565c0;border-radius:50%;animation:spin 1s linear infinite}.scan-error{display:flex;align-items:center;gap:.5rem;padding:1rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;margin-bottom:1rem;color:#856404}.error-icon{font-size:1.1rem}.folder-status{background:#fff;border:1px solid #dee2e6;border-radius:6px;overflow:hidden}.status-info{display:flex;align-items:center;gap:.5rem;padding:1rem;font-size:.95rem}.status-indicator{font-size:1.1rem;width:20px;text-align:center}.status-indicator.ready{color:#28a745}.status-indicator.empty{color:#6c757d}.file-list{border-top:1px solid #dee2e6}.file-list details{padding:0}.file-list summary{padding:.75rem 1rem;background:#f8f9fa;cursor:pointer;font-weight:500;color:#495057;border:none;outline:none;transition:background-color .2s ease}.file-list summary:hover{background:#e9ecef}.file-list-items{list-style:none;padding:0;margin:0;max-height:200px;overflow-y:auto}.file-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;border-bottom:1px solid #f1f3f4;font-size:.9rem}.file-item:last-child{border-bottom:none}.file-name{font-family:Consolas,Monaco,Courier New,monospace;color:#333;flex:1;margin-right:1rem;word-break:break-all}.file-type{font-family:Consolas,Monaco,Courier New,monospace;margin-right:1rem}.file-size{color:#666;font-size:.85rem;white-space:nowrap}@media (max-width: 768px){.folder-picker{margin:1rem;padding:1.5rem}.folder-input-container{flex-direction:column}.file-item{flex-direction:column;align-items:flex-start;gap:.25rem}.file-name{margin-right:0}}.notification-system{position:fixed;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:.75rem;max-width:400px;pointer-events:none}.notification{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;border-left:4px solid;overflow:hidden;transform:translate(100%);animation:slideIn .3s ease-out forwards;pointer-events:auto}.notification-success{border-left-color:#28a745}.notification-error{border-left-color:#dc3545}.notification-warning{border-left-color:#ffc107}.notification-info{border-left-color:#17a2b8}.notification-content{padding:1rem}.notification-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.notification-icon{font-size:1.1rem;flex-shrink:0}.notification-title{font-weight:600;color:#333;flex:1;font-size:.95rem}.notification-close{background:none;border:none;font-size:1.5rem;color:#6c757d;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.notification-close:hover{background:#f8f9fa;color:#495057}.notification-message{color:#6c757d;font-size:.9rem;line-height:1.4;margin-left:1.6rem}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.notification.dismissing{animation:slideOut .3s ease-in forwards}@media (prefers-color-scheme: dark){.notification{background:#2d3748;box-shadow:0 4px 12px #0000004d}.notification-title{color:#e2e8f0}.notification-message,.notification-close{color:#a0aec0}.notification-close:hover{background:#4a5568;color:#e2e8f0}}@media (max-width: 768px){.notification-system{top:10px;right:10px;left:10px;max-width:none}.notification{margin:0}.notification-content{padding:.75rem}.notification-header{margin-bottom:.25rem}.notification-message{margin-left:1.4rem;font-size:.85rem}}@media (prefers-reduced-motion: reduce){.notification{animation:none;transform:translate(0)}.notification.dismissing{animation:none;opacity:0}}@media (prefers-contrast: high){.notification{border:2px solid}.notification-success{border-color:#28a745}.notification-error{border-color:#dc3545}.notification-warning{border-color:#ffc107}.notification-info{border-color:#17a2b8}}#root{max-width:1200px;margin:0 auto;padding:1rem;min-height:100vh}.app-header{text-align:center;margin-bottom:3rem;padding:2rem 0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a}.app-header h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3)}.app-header h2{margin:0;font-size:1.3rem;font-weight:400;opacity:.9}.card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000d;transition:box-shadow .2s ease}.card:hover{box-shadow:0 4px 16px #0000001a}.card.error{border-color:#f5c6cb;background:#f8d7da}.card h3{margin:0 0 1rem;color:#333;font-size:1.4rem}.card p{margin:.5rem 0;color:#666;line-height:1.5}.card pre{background:#2d3748;color:#e2e8f0;padding:1rem;border-radius:6px;overflow-x:auto;font-size:.85rem;line-height:1.4;margin:1rem 0 0}.workflow-container{display:grid;gap:2rem;margin-bottom:2rem}.workflow-step{position:relative}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid #f3f3f3;border-top:3px solid #646cff;border-radius:50%;animation:spin 1s linear infinite;margin-right:.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-color-scheme: dark){.app-header{background:linear-gradient(135deg,#4a5568,#2d3748)}.card{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.card.error{background:#3d1a1a;border-color:#5a2a2a}.card h3{color:#f1f3f4}.card p{color:#a0aec0}}@media (max-width: 768px){#root{padding:.5rem}.app-header{margin-bottom:2rem;padding:1.5rem 1rem}.app-header h1{font-size:2rem}.app-header h2{font-size:1.1rem}.card{padding:1.5rem;margin-bottom:1.5rem}.workflow-step:before{left:-.5rem;width:3px}}@media (max-width: 480px){.app-header h1{font-size:1.7rem}.app-header h2{font-size:1rem}.card{padding:1rem}.card pre{font-size:.75rem;padding:.75rem}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:inherit;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
