*{box-sizing:border-box}body{margin:0;min-height:100vh}button{font-family:inherit}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0f0f0f;color:#e0e0e0;min-height:100vh}#root{max-width:900px;margin:0 auto;padding:0 1.5rem 4rem}header{padding:2rem 0 1.5rem;border-bottom:1px solid #222;margin-bottom:2rem;display:flex;align-items:baseline;gap:1rem}header h1{font-size:1.6rem;font-weight:700;color:#fff;letter-spacing:-.5px}.tagline{color:#555;font-size:.85rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.page-header h2{font-size:1.2rem;font-weight:600}.machines-table{width:100%;border-collapse:collapse;font-size:.9rem}.machines-table th{text-align:left;padding:.6rem 1rem;color:#666;font-weight:500;border-bottom:1px solid #222;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.machines-table td{padding:.85rem 1rem;border-bottom:1px solid #1a1a1a}.machines-table tr:hover td{background:#141414}.btn-primary{background:#6c63ff;color:#fff;border:none;padding:.5rem 1.2rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:background .15s}.btn-primary:hover{background:#5a52d5}.btn-primary:disabled{background:#3a3a3a;color:#666;cursor:not-allowed}.btn-secondary{background:transparent;color:#888;border:1px solid #333;padding:.45rem 1rem;border-radius:6px;font-size:.82rem;cursor:pointer;transition:border-color .15s,color .15s}.btn-secondary:hover{border-color:#555;color:#ccc}.btn-back{background:none;border:none;color:#666;font-size:.85rem;cursor:pointer;padding:0;margin-bottom:1.2rem;display:block}.btn-back:hover{color:#aaa}.machine-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:1rem 1.2rem;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.3rem}.machine-card strong{font-size:1rem;color:#fff}.machine-card span{font-size:.82rem;color:#666}.submit-form{display:flex;flex-direction:column;gap:1rem;max-width:480px}.submit-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;color:#aaa}.submit-form input[type=file]{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:.6rem;color:#ccc;font-size:.85rem;cursor:pointer}.file-name{font-size:.8rem;color:#666}.job-card{background:#141414;border:1px solid #222;border-radius:10px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;max-width:560px}.job-id{font-size:.8rem;color:#555}.job-id code{color:#888;font-size:.78rem}.status-badge{display:inline-block;padding:.3rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;width:fit-content}.status-pending{background:#2a2200;color:#f0a500}.status-running{background:#001a2a;color:#4ab4ff}.status-done{background:#0a2200;color:#4caf50}.status-failed{background:#2a0000;color:#f44336}.spinner-wrap{display:flex;align-items:center;gap:.8rem;color:#666;font-size:.85rem}.spinner{width:18px;height:18px;border:2px solid #333;border-top-color:#6c63ff;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.done-section{display:flex;flex-direction:column;gap:.8rem}.done-section p{font-size:.9rem;color:#aaa}.file-list{list-style:none;font-size:.8rem;color:#555}.file-list li:before{content:"· "}.job-meta{display:flex;flex-direction:column;gap:.2rem;font-size:.78rem;color:#444;border-top:1px solid #1e1e1e;padding-top:.8rem}.progress-bar-wrap{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;height:32px;position:relative;overflow:hidden}.progress-bar{height:100%;background:#6c63ff;transition:width .3s ease;border-radius:6px}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.8rem;font-weight:600;color:#fff}.render-progress-wrap{display:flex;flex-direction:column;gap:.45rem}.render-progress-track{position:relative;overflow:hidden;width:100%;height:10px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:999px}.render-progress-fill{height:100%;background:linear-gradient(90deg,#6c63ff,#4ab4ff);border-radius:inherit;transition:width .2s ease}.render-progress-track.indeterminate .render-progress-fill{width:40%;animation:render-slide 1.1s ease-in-out infinite}.render-progress-meta{display:flex;justify-content:space-between;gap:.75rem;font-size:.78rem;color:#777}@keyframes render-slide{0%{transform:translate(-100%)}to{transform:translate(250%)}}.seg-wrap{margin-top:14px}.seg-track{display:flex;width:100%;height:14px;border-radius:999px;overflow:hidden;gap:1px;background:#111;border:1px solid #2a2a2a}.seg-segment{position:relative;height:100%;overflow:hidden;min-width:2px;background:#1e1e1e;flex-shrink:0}.seg-segment:first-child{border-radius:999px 0 0 999px}.seg-segment:last-child{border-radius:0 999px 999px 0;flex-grow:1}.seg-failed .seg-fill{width:100%!important}.seg-fill{height:100%;transition:width .3s ease}.seg-labels{display:flex;flex-wrap:wrap;gap:6px 14px;margin-top:8px}.seg-label{display:flex;align-items:center;gap:5px;font-size:11px;color:#777}.seg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.seg-gpu{font-weight:600;color:#ccc}.seg-range{opacity:.6}.seg-pct{font-weight:600;color:#6c63ff}.pct-done{color:#10b981}.pct-failed{color:#ef4444}.row-selected{background:#6c63ff14}.row-selected td{border-color:#6c63ff4d}.check-box{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:2px solid #333;font-size:10px;font-weight:700;color:#6c63ff}.check-box.checked{background:#6c63ff;border-color:#6c63ff;color:#fff}.selection-hint{padding:8px 12px;background:#6c63ff1a;border:1px solid rgba(108,99,255,.25);border-radius:6px;font-size:13px;color:#aaa;margin-bottom:14px}.status{color:#555;font-size:.9rem;padding:1rem 0}.error{color:#f44336;font-size:.85rem;padding:.5rem 0}h2{font-size:1.1rem;font-weight:600;color:#ddd;margin-bottom:1rem}
