*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e8e8f0;-webkit-text-size-adjust:100%;background:#0f0f13;min-height:100vh;font-family:system-ui,sans-serif}#root{max-width:900px;margin:0 auto;padding:1.25rem 1rem}h1{margin-bottom:.25rem;font-size:clamp(1.3rem,5vw,1.8rem);font-weight:700}p.subtitle{color:#888;margin-bottom:1.5rem;font-size:.9rem}.tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.tab-btn{color:#aaa;cursor:pointer;text-align:center;-webkit-tap-highlight-color:transparent;background:#1a1a24;border:1px solid #333;border-radius:8px;flex:auto;min-width:max-content;padding:.65rem 1rem;font-size:.9rem;transition:all .15s}.tab-btn:hover{color:#ddd;border-color:#555}.tab-btn.active{color:#fff;background:#5b5bf7;border-color:#5b5bf7}.card{background:#1a1a24;border:1px solid #2a2a3a;border-radius:12px;padding:1.25rem}.card h2{margin-bottom:.4rem;font-size:1.05rem}.card p.desc{color:#888;margin-bottom:1.25rem;font-size:.88rem;line-height:1.5}.upload-zone{text-align:center;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#13131c;border:2px dashed #333;border-radius:10px;margin-bottom:1.25rem;padding:2rem 1.25rem;transition:border-color .15s}.upload-zone:hover{border-color:#5b5bf7}.upload-zone input{display:none}.upload-zone span{color:#666;font-size:.9rem}.canvas-row{flex-direction:column;align-items:stretch;gap:1rem;display:flex}@media (width>=540px){.canvas-row{flex-direction:row;align-items:flex-start}}.canvas-wrap{flex:1;min-width:0}.canvas-wrap label{color:#666;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;font-size:.78rem;display:block}.canvas-wrap canvas,.canvas-wrap img{background:#0f0f13;border:1px solid #2a2a3a;border-radius:8px;width:100%;height:auto;display:block}.extract-controls{flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:1.25rem;display:flex}.field{flex-direction:column;gap:.3rem;display:flex}.field label{color:#888;font-size:.8rem}.field input[type=number]{color:#e8e8f0;background:#13131c;border:1px solid #333;border-radius:6px;width:90px;padding:.5rem .6rem;font-size:1rem}.btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:#5b5bf7;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.95rem;font-weight:500;transition:opacity .15s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:not(:disabled):hover{opacity:.85}.btn.secondary{color:#ccc;background:#2a2a3a;border:1px solid #444}.video-wrap{background:#0f0f13;border:1px solid #2a2a3a;border-radius:10px;margin-bottom:1rem;position:relative;overflow:hidden}.video-wrap video{opacity:0;pointer-events:none;width:100%;display:block;position:absolute}.video-wrap canvas{width:100%;display:block}.status-badge{border-radius:20px;align-items:center;gap:.4rem;margin-bottom:1rem;padding:.3rem .8rem;font-size:.8rem;display:inline-flex}.status-badge.loading{color:#f0b429;background:#2a2410;border:1px solid #5a4a10}.status-badge.ready{color:#4ade80;background:#102a14;border:1px solid #1a5a24}.status-badge .dot{background:currentColor;border-radius:50%;width:7px;height:7px}.actions{flex-wrap:wrap;gap:.75rem;display:flex}.actions .btn{text-align:center;flex:auto}
