:root{--bg:#f4f6f9;--panel:#fff;--ink:#1f2733;--muted:#6b7785;--line:#dde3ea;--accent:#2563eb;--accent-soft:#e6efff;--good:#16a34a;--good-soft:#dcfce7;--bad:#dc2626;--bad-soft:#fee2e2;--tut:#7c3aed;--radius:10px;color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg)}img{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}button{font-family:inherit}.btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);cursor:pointer;white-space:nowrap;border-radius:8px;padding:6px 10px;font-size:13px;transition:background .12s,border-color .12s,transform 50ms}.btn:hover:not(:disabled){background:#f0f3f8}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--ghost{background:0 0;border-color:#0000}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:#1d4fd0}.badge{vertical-align:middle;border-radius:999px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600}.badge--tut{color:var(--tut);background:#f1e9ff}.badge--prac{background:var(--accent-soft);color:var(--accent)}.badge--cut{color:#0d9488;background:#ccfbf1}.home{max-width:1040px;margin:0 auto;padding:40px 24px 80px}.brand{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;display:flex}.brand__logobox{background:#eef1f5;border-radius:16px;flex:none;justify-content:center;align-items:center;width:60px;height:60px;padding:7px;display:flex}.brand__logobox img{object-fit:contain;width:100%;height:100%}.brand__name{flex-direction:column;line-height:1;display:flex}.brand__name h1{letter-spacing:-1px;margin:0;font-size:44px;font-weight:800}.brand__name h1 span{color:var(--accent)}.brand__beta{letter-spacing:1.5px;color:#d97706;margin-top:4px;font-size:13px;font-weight:800}.poweredby{align-self:flex-end;align-items:center;gap:8px;padding-bottom:10px;text-decoration:none;display:inline-flex}.poweredby__label{color:var(--muted);font-size:15px}.poweredby__name{color:var(--ink);letter-spacing:-.3px;font-size:19px;font-weight:800}.poweredby__star{object-fit:contain;width:22px;height:22px;display:block}.poweredby--sm .poweredby__label{font-size:12px}.poweredby--sm .poweredby__name{font-size:15px}.poweredby--sm .poweredby__star{width:16px;height:16px}.cta{background:linear-gradient(90deg, var(--accent-soft), #f1e9ff);border:1px solid #d9def0;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:4px 0 24px;padding:14px 18px;font-size:14px;line-height:1.5;display:flex}.cta .btn--primary{flex:none;text-decoration:none}.sitefoot{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;margin-top:48px;padding-top:20px;display:flex}.sitefoot__brand{align-items:center;gap:10px;font-size:18px;display:flex}.sitefoot__brand img{object-fit:contain;width:28px;height:28px}.sitefoot__meta{text-align:right;color:var(--muted);font-size:13px;line-height:1.7}.sitefoot__meta a{color:var(--accent);text-decoration:none}.card--locked .card__thumb img{filter:grayscale(.6)brightness(1.05)}.card__lock{background:#ffffff8c;flex-direction:column;justify-content:center;align-items:center;gap:4px;display:flex;position:absolute;inset:0}.card__lock-icon{font-size:26px}.card__lock-text{color:var(--ink);background:var(--panel);border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700;box-shadow:0 1px 4px #00000026}.home__hero h1{letter-spacing:-.5px;margin:0 0 8px;font-size:40px}.home__hero h1 span{color:var(--accent)}.home__hero p{color:var(--muted);max-width:640px;margin:0 0 8px;line-height:1.5}.home__section{margin:32px 0 12px;font-size:16px}.home__error{background:var(--bad-soft);color:var(--bad);border-radius:8px;margin:16px 0;padding:10px 14px}.home__foot{color:var(--muted);text-align:center;margin-top:40px;font-size:12px}.cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.card{text-align:left;border:1px solid var(--line);background:var(--panel);border-radius:var(--radius);cursor:pointer;padding:0;transition:box-shadow .15s,transform .1s,border-color .15s;overflow:hidden}.card:hover{border-color:#c6d0db;transform:translateY(-2px);box-shadow:0 8px 24px #1f27331a}.card__thumb{aspect-ratio:1.1;background:#eef1f5;justify-content:center;align-items:center;display:flex;position:relative}.card__thumb img{object-fit:cover;width:100%;height:100%}.card__badge{color:#fff;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;position:absolute;top:8px;left:8px}.card__badge.is-tut{background:var(--tut)}.card__badge.is-prac{background:var(--accent)}.card__body{padding:10px 12px 12px}.card__title{font-size:14px;font-weight:600}.card__meta{color:var(--muted);margin-top:2px;font-size:12px}.workspace{flex-direction:column;height:100vh;display:flex;overflow:hidden}.workspace__main{flex:1;min-height:0;display:flex}.workspace__grid{background:#fff;flex:1;padding:8px 16px 12px;position:relative;overflow:auto}.grid-zoom{background:var(--panel);border:1px solid var(--line);z-index:5;border-radius:8px;align-items:center;gap:2px;padding:2px;display:flex;position:absolute;bottom:10px;right:12px;box-shadow:0 2px 8px #0000001a}.grid-zoom button{cursor:pointer;width:24px;height:24px;color:var(--ink);background:0 0;border:none;border-radius:6px;font-size:16px}.grid-zoom button:hover{background:#eef1f5}.grid-zoom span{color:var(--muted);text-align:center;min-width:34px;font-size:11px}.workspace__side{border-left:1px solid var(--line);background:var(--panel);width:260px;padding:14px;overflow:auto}.toolbar{background:var(--panel);border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:8px 14px;display:flex;position:relative}.toolbar__progressline{background:linear-gradient(90deg,#34d399,#2563eb);height:3px;transition:width .25s;position:absolute;bottom:0;left:0}.toolbar__count{color:var(--muted);flex:none;font-size:12px;font-weight:700}.toolbar__hint{color:#1e3a8a;background:var(--accent-soft);white-space:nowrap;text-overflow:ellipsis;border-radius:8px;max-width:100%;padding:5px 12px;font-size:12.5px;overflow:hidden}.toolbar__hint.is-bad{background:var(--bad-soft);color:#7f1d1d}.toolbar__left,.toolbar__right{align-items:center;gap:6px;display:flex}.toolbar__left{flex:1}.toolbar__center{flex:1;justify-content:center;align-items:center;gap:8px;min-width:0;display:flex}.toolbar__right{flex-wrap:wrap;flex:1;justify-content:flex-end}.toolbar__title{align-items:center;font-size:14px;font-weight:600;display:flex}.toolbar__sep{background:var(--line);width:1px;height:22px;margin:0 4px}.progress{background:#eef1f5;border-radius:999px;width:240px;height:20px;position:relative;overflow:hidden}.progress__bar{background:linear-gradient(90deg,#34d399,#2563eb);transition:width .25s;position:absolute;inset:0 auto 0 0}.progress__text{color:var(--ink);justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex;position:absolute;inset:0}.hintbar{border-bottom:1px solid var(--line);padding:8px 16px;font-size:13px}.hintbar--info{background:var(--accent-soft);color:#1e3a8a}.hintbar--good{background:var(--good-soft);color:#14532d}.hintbar--bad{background:var(--bad-soft);color:#7f1d1d}.grid{width:fit-content;min-width:100%;margin:0 auto}.grid__band{flex-wrap:nowrap;justify-content:center;align-items:flex-end;gap:42px;padding:1px 8px 2px;display:flex}.grid__group-label{display:none}.grid__pairs{gap:14px;display:flex}.pair{border-radius:8px;padding:4px;transition:background .15s,box-shadow .15s}.pair--target{box-shadow:0 0 0 2px var(--tut);background:#f1e9ff;animation:1.4s ease-in-out infinite targetPulse}@keyframes targetPulse{0%,to{box-shadow:0 0 0 2px var(--tut)}50%{box-shadow:0 0 0 5px #7c3aed40}}.pair__slots{gap:4px;display:flex}.pair__label{text-align:center;color:var(--ink);margin-top:2px;font-size:13px;font-weight:700}.slot{background:0 0;border:1px solid #0000;border-radius:5px;justify-content:center;align-items:flex-end;min-width:46px;height:130px;transition:border-color .12s,background .12s;display:flex}.slot--over{border-color:var(--accent);background:#2563eb0a}.tile{cursor:grab;touch-action:none;position:relative}.tile--dragging{opacity:.25}.tile__inner{transform-origin:50%;position:relative}.tile__inner img{object-fit:contain;pointer-events:none;width:100%;height:100%;display:block}.tile--selected .tile__inner{outline:2px solid var(--accent);outline-offset:1px;border-radius:3px}.tile--correct .tile__inner{outline:2px solid var(--good);background:var(--good-soft);border-radius:3px}.tile--wrong .tile__inner{outline:2px solid var(--bad);background:var(--bad-soft);border-radius:3px}.tile--flash-right .tile__inner{animation:.6s flashRight}.tile--flash-wrong{animation:.4s shake}@keyframes flashRight{0%{box-shadow:0 0 #16a34a99}to{box-shadow:0 0 0 14px #16a34a00}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.tile__handle{background:var(--accent);cursor:grab;touch-action:none;border:2px solid #fff;border-radius:50%;width:14px;height:14px;margin-left:-7px;position:absolute;left:50%;box-shadow:0 1px 3px #0000004d}.tile__handle:active{cursor:grabbing}.tile__handle--top{top:-9px}.tile__handle--bottom{bottom:-9px}.drag-overlay{pointer-events:none;filter:drop-shadow(0 6px 10px #0000004d)}.bin-resizer{background:var(--panel);border-top:1px solid var(--line);cursor:ns-resize;touch-action:none;flex:none;height:9px;position:relative}.bin-resizer:before{content:"";background:var(--line);border-radius:2px;width:46px;height:3px;position:absolute;top:3px;left:50%;transform:translate(-50%)}.bin-resizer:hover:before{background:var(--accent)}.bin__badge{z-index:3;color:var(--muted);background:#ffffffd9;border-radius:999px;align-items:center;gap:4px;padding:1px 6px;font-size:11px;display:flex;position:absolute;top:4px;right:12px}.bin__info{cursor:help;color:var(--accent);font-size:12px}.bin{background:var(--panel);flex-direction:row;flex:none;align-items:stretch;gap:8px;padding:2px 12px 6px;transition:background .12s;display:flex;position:relative;overflow:hidden}.bin__nextup{border-right:1px solid var(--line);background:linear-gradient(#2563eb0a,#0000 60%);border-radius:8px 8px 0 0;flex-direction:column;flex:none;justify-content:flex-end;align-items:center;padding:0 12px 2px;display:flex}.bin__nextup-label{letter-spacing:.6px;text-transform:uppercase;color:var(--accent);margin-bottom:3px;font-size:9px;font-weight:700}.bin--over{background:var(--accent-soft)}.bin__header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.bin__title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.bin__count{color:var(--muted);font-size:12px}.bin__strip{flex:1;align-items:flex-end;gap:6px;min-height:0;padding-bottom:4px;display:flex;overflow:auto hidden}.bin__cell{border-radius:6px;flex:none;justify-content:center;align-items:flex-end;padding:4px;display:flex}.bin__cell:hover{background:#f0f3f8}.bin__empty{color:var(--good);padding:30px 10px;font-size:14px;font-weight:600}.metaphase__header{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:700}.metaphase__img-wrap{border:1px solid var(--line);cursor:zoom-in;background:#000;border-radius:8px;width:100%;padding:0;display:block;position:relative;overflow:hidden}.metaphase__img-wrap img{width:100%;display:block}.metaphase__mark{pointer-events:none;border:2px solid #ef4444;border-radius:3px;position:absolute;box-shadow:0 0 0 1px #fff9,0 0 8px #ef444499}.metaphase__expand{color:#fff;background:#0000008c;border-radius:5px;padding:1px 6px;font-size:13px;position:absolute;bottom:6px;right:6px}.metafull__frame{display:inline-block;position:relative}.metafull__frame img{object-fit:contain;border-radius:6px;max-width:92vw;max-height:86vh;display:block}.metaphase__caption{color:var(--muted);margin-top:8px;font-size:12px}.modal-backdrop{z-index:50;background:#0f172a80;justify-content:center;align-items:center;animation:.2s fade;display:flex;position:fixed;inset:0}@keyframes fade{0%{opacity:0}}.modal{background:var(--panel);border-radius:14px;width:min(480px,92vw);padding:28px;box-shadow:0 20px 60px #0000004d}.modal__title{margin:0 0 10px;font-size:24px}.modal__lead{color:var(--muted);margin:0 0 16px;line-height:1.5}.modal__lead--warn{color:var(--bad)}.modal__actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.score{align-items:center;gap:24px;margin:16px 0;display:flex}.score__ring{--pct:0;background:conic-gradient(var(--good) calc(var(--pct) * 1%), #eef1f5 0);border-radius:50%;flex:none;place-items:center;width:110px;height:110px;display:grid}.score__ring span{background:var(--panel);border-radius:50%;place-items:center;width:80px;height:80px;font-size:22px;font-weight:700;display:grid}.score__stats{color:var(--muted);font-size:14px;line-height:1.8}.score__stats strong{color:var(--ink);font-size:18px}.home__subtle{color:var(--muted);max-width:640px;margin:-4px 0 12px;font-size:13px;line-height:1.5}.card__badge.is-cut{background:#0d9488}.cutlab{flex-direction:column;height:100vh;display:flex;overflow:hidden}.cutlab__bar{background:var(--panel);border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:8px 14px;display:flex}.cutlab__title{font-size:14px}.cutlab__bar-right{margin-left:auto}.cutlab__count{color:var(--muted);font-size:13px}.cutlab__main{flex:1;min-height:0;display:flex;overflow:hidden}.cutlab__stage{background:#eef1f5;flex:1;justify-content:center;align-items:flex-start;padding:20px;display:flex;overflow:auto}.cutlab__canvas-wrap{background:#fff;border-radius:6px;position:relative;overflow:hidden;box-shadow:0 4px 18px #0000001f}.cutlab__img,.cutlab__overlay{image-rendering:auto;display:block;position:absolute;inset:0}.cutlab__overlay{touch-action:none}.cutlab__panel{border-left:1px solid var(--line);background:var(--panel);width:270px;padding:14px;overflow-y:auto}.cutlab__panel h3{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:18px 0 8px;font-size:12px}.cutlab__panel h3:first-child{margin-top:0}.cutlab__slider{margin-bottom:10px;font-size:12px;display:block}.cutlab__slider span{justify-content:space-between;margin-bottom:2px;display:flex}.cutlab__slider em{color:var(--accent);font-style:normal;font-weight:600}.cutlab__slider input[type=range]{width:100%}.cutlab__check{align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.cutlab__wide{width:100%;margin-top:8px}.cutlab__tip{color:var(--muted);margin:8px 0;font-size:12px;line-height:1.4}.cutlab__tray{border-top:1px solid var(--line);background:var(--panel);padding:8px 12px 10px}.cutlab__tray-head{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.cutlab__tray-head>span:first-child{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-size:12px;font-weight:700}.cutlab__tray-hint{color:var(--muted);font-size:12px}.cutlab__tray-strip{align-items:flex-end;gap:8px;min-height:116px;padding-bottom:4px;display:flex;overflow-x:auto}.cutlab__tray-empty{color:var(--muted);padding:28px 8px;font-size:13px}.cutlab__tile{cursor:pointer;border:1px solid #0000;border-radius:6px;flex:none;justify-content:center;align-items:flex-end;padding:4px;display:flex}.cutlab__tile:hover{border-color:var(--accent);background:var(--accent-soft)}.seg{border:1px solid var(--line);border-radius:8px;display:flex;overflow:hidden}.seg__btn{background:var(--panel);cursor:pointer;border:none;flex:1;padding:7px 8px;font-size:13px}.seg__btn.is-on{background:var(--accent);color:#fff}.editor{background:var(--panel);border-radius:14px;width:min(860px,96vw);padding:18px;box-shadow:0 20px 60px #0000004d}.editor__head{align-items:center;gap:10px;margin-bottom:12px;display:flex}.editor__hint{color:var(--muted);flex:1;font-size:12px}.editor__stage{background:#eef1f5;border-radius:8px;justify-content:center;align-items:flex-start;gap:16px;min-height:200px;max-height:60vh;padding:16px;display:flex;overflow:auto}.editor__frame{border:2px dashed var(--line);cursor:zoom-in;background:#fff;border-radius:8px;flex:none;padding:18px;position:relative}.editor__frame-tag{color:var(--muted);pointer-events:none;white-space:nowrap;font-size:10px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.uncut{z-index:4;border:1px solid var(--accent);background:var(--panel);width:24px;height:24px;color:var(--accent);cursor:pointer;border-radius:6px;font-size:11px;line-height:1;position:absolute;box-shadow:0 1px 4px #00000026}.uncut:hover{background:var(--accent-soft)}.uncut--up{top:1px;left:50%;transform:translate(-50%)}.uncut--down{bottom:16px;left:50%;transform:translate(-50%)}.uncut--left{top:50%;left:1px;transform:translateY(-50%)}.uncut--right{top:50%;right:1px;transform:translateY(-50%)}.editor__expand-wrap{position:relative}.editor__halo{opacity:.32;pointer-events:none;image-rendering:auto;border-radius:4px;position:absolute;top:0;left:0}.editor__canvas{touch-action:none;image-rendering:auto;cursor:crosshair;background:#fff;border-radius:3px;display:block;position:absolute;box-shadow:0 0 0 1px #2563eb59}.editor__preview{max-width:160px}.editor__preview-label{color:var(--muted);margin-bottom:6px;font-size:12px}.editor__preview-tiles{background:#fff;border-radius:6px;flex-wrap:wrap;gap:8px;padding:8px;display:flex}.editor__status{background:var(--accent-soft);color:#1e3a8a;border-radius:8px;margin-top:12px;padding:8px 12px;font-size:13px}.editor__status.is-ready{background:var(--good-soft);color:#14532d;font-weight:600}.editor__tools{flex-wrap:wrap;align-items:center;gap:14px;margin-top:12px;display:flex}.editor__tools .seg{width:340px}.editor__tools .seg__btn{white-space:nowrap;padding:7px 6px}.ctl{align-items:center;gap:8px;font-size:12px;display:flex}.ctl--check{cursor:pointer;white-space:nowrap;gap:5px}.editor__actions{gap:8px;margin-left:auto;display:flex}.btn--magic{color:#fff;background:linear-gradient(90deg,#7c3aed,#2563eb);border-color:#0000}.btn--magic:hover:not(:disabled){filter:brightness(1.08)}.btn--save{color:#fff;background:#0d9488;border-color:#0d9488}.btn--save:hover:not(:disabled){background:#0b8278}.assign-pill{color:#fff;z-index:40;background:#1f2733;border-radius:999px;padding:8px 16px;font-size:13px;position:fixed;bottom:120px;left:50%;transform:translate(-50%);box-shadow:0 6px 20px #0000004d}.assign-pill kbd{background:#3b4654;border-radius:4px;margin:0 2px;padding:1px 6px;font-family:ui-monospace,monospace}.assign-pill span{opacity:.7;margin-left:6px}.metafull{z-index:60;cursor:zoom-out;background:#0a0e14eb;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.metafull img{object-fit:contain;border-radius:6px;max-width:92vw;max-height:86vh;box-shadow:0 10px 40px #00000080}.metafull__cap{color:#cbd5e1;margin-top:14px;font-size:13px}.iconbtn{color:var(--muted);cursor:pointer;opacity:.55;background:0 0;border:none;border-radius:7px;width:28px;height:28px;font-size:15px;line-height:1;transition:opacity .12s,background .12s,color .12s}.iconbtn:hover{opacity:1;color:var(--ink);background:#eef1f5}.help{background:var(--panel);border-radius:14px;width:min(760px,94vw);padding:22px 24px;box-shadow:0 20px 60px #0000004d}.help__head{justify-content:space-between;align-items:center;margin-bottom:14px;font-size:18px;display:flex}.help__cols{grid-template-columns:1fr 1fr;gap:28px;display:grid}.help h4{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:0 0 8px;font-size:12px}.help__row{align-items:baseline;gap:10px;margin-bottom:8px;font-size:13px;display:flex}.help__row kbd{text-align:center;border:1px solid var(--line);background:#eef1f5;border-bottom-width:2px;border-radius:5px;flex:none;min-width:64px;padding:2px 6px;font-family:ui-monospace,monospace;font-size:12px}.help__row span{color:var(--ink);line-height:1.35}@media (width<=640px){.help__cols{grid-template-columns:1fr;gap:16px}}
