:root{--bg: #0e121b;--panel: #0b0f17;--card: #121826;--line: #1c2636;--text: #e7eefc;--muted: #6b7b96;--accent: #1f6feb;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font:15px/1.4 -apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}.ws{display:flex;height:100%;position:relative}.ws-drag:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;border:3px dashed var(--accent);pointer-events:none;z-index:100}.ws-drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#0a0f1ae0;font-size:22px;font-weight:800;pointer-events:none}.ws-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}.sidebar{width:200px;flex-shrink:0;display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--line);overflow:hidden}.sb-header{display:flex;align-items:center;gap:8px;padding:10px;border-bottom:1px solid var(--line);flex-shrink:0}.sb-upload{flex:1;background:var(--accent);color:#fff;border:0;border-radius:7px;padding:7px 10px;font-size:12px;font-weight:700;cursor:pointer;text-align:center}.sb-upload input[type=file]{display:none}.sb-upload-busy{opacity:.5;pointer-events:none}.sb-count{font-size:12px;font-weight:700;color:var(--muted);white-space:nowrap}.sb-error{font-size:11px;color:#f87171;padding:4px 10px;margin:0;border-bottom:1px solid #7f1d1d44}.sb-list{flex:1;overflow-y:auto;scrollbar-width:thin}.sb-row{display:flex;align-items:center;gap:7px;width:100%;padding:6px 8px;background:none;border:0;border-bottom:1px solid var(--line);cursor:pointer;text-align:left;transition:background .1s}.sb-row:hover{background:#12182688}.sb-row-active{background:#12182699;border-left:3px solid var(--accent)}.sb-row-labeled{opacity:.45;cursor:default}.sb-row-skipped{opacity:.35}.sb-row-error{opacity:.4}.sb-thumb{width:36px;height:27px;object-fit:cover;border-radius:4px;background:#1a1f2e;flex-shrink:0;display:block}.sb-label{flex:1;font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-status{font-size:12px;font-weight:900;flex-shrink:0;color:#2ec27e}.sb-row-skipped .sb-status{color:var(--muted)}.sb-row-error .sb-status{color:#f87171}.sb-done{padding:16px 10px;font-size:13px;font-weight:700;color:#2ec27e;text-align:center}.sb-empty{padding:24px 10px;font-size:13px;color:var(--muted);text-align:center}.ws-main{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}.app{display:flex;flex-direction:column;height:100%}.top{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--panel);border-bottom:1px solid var(--line);flex-shrink:0}.top .link{background:none;border:0;color:var(--muted);font-size:14px;cursor:pointer;padding:6px 2px}.top-spacer{flex:1}.top .save{background:var(--accent);color:#fff;border:0;border-radius:8px;padding:9px 20px;font-weight:800;font-size:14px;cursor:pointer}.top .save:disabled{opacity:.4;cursor:default}.sail-toggle{display:flex;background:var(--card);border-radius:8px;overflow:hidden}.sail-toggle button{background:none;border:0;color:var(--muted);padding:7px 14px;font-weight:800;font-size:12px;cursor:pointer;letter-spacing:.5px}.sail-toggle button.on{background:var(--accent);color:#fff}.count-stepper{display:flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--line);border-radius:8px;padding:4px 8px;flex-shrink:0}.stepper-tab{background:none;border:1px solid var(--line);color:var(--muted);border-radius:5px;padding:3px 10px;font-size:13px;font-weight:700;cursor:pointer}.stepper-tab.on{background:var(--accent);border-color:var(--accent);color:#fff}.stepper-tab:disabled{opacity:.35;cursor:default}.stepper-btn{background:none;border:0;color:var(--muted);font-size:16px;cursor:pointer;padding:0 3px;line-height:1}.stepper-btn:disabled{opacity:.3;cursor:default}.stepper-count{color:var(--text);font-weight:700;font-size:14px;min-width:18px;text-align:center}.stepper-label{color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.3px}.line-selector{display:flex;gap:8px;padding:10px 14px;overflow-x:auto;background:var(--panel);border-bottom:1px solid var(--line);flex-shrink:0;scrollbar-width:none}.line-selector::-webkit-scrollbar{display:none}.chip-group{display:flex;gap:6px}.chip-count{display:flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--line);border-radius:8px;padding:5px 10px;font-size:13px;font-weight:700}.chip-count button{background:none;border:0;color:var(--muted);font-size:16px;cursor:pointer;padding:0 3px;line-height:1}.chip-count span{color:var(--muted);font-weight:400}.chip{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;border:2px solid;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;background:transparent;transition:opacity .1s}.chip.active{background:#12182666}.chip.done{opacity:.55}.chip-dot{width:8px;height:8px;border-radius:50%}.chip-add{background:var(--card);color:#5a7cc0;border:1px dashed #2a3a55;border-radius:20px;padding:6px 12px;font-size:13px;font-weight:700;cursor:pointer}.chip-add:disabled{opacity:.3;cursor:default}.chip-done-btn{background:none;border:1px solid currentColor;border-radius:6px;color:inherit;font-size:11px;font-weight:700;cursor:pointer;padding:2px 7px;opacity:.7}.chip-done-btn:hover{opacity:1}.canvas-wrap{flex:1;position:relative;overflow:hidden;background:#060a12;touch-action:none;-webkit-user-select:none;user-select:none}.canvas-wrap canvas{position:absolute;top:0;left:0;width:100%;height:100%}.dot-delete-btn{position:absolute;z-index:10;transform:translate(-50%,-150%);background:#c0392b;color:#fff;border:0;width:28px;height:28px;border-radius:50%;font-size:13px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0008}.canvas-undo-btn{position:absolute;top:8px;left:8px;z-index:5;background:#1a2336cc;color:var(--text);border:1px solid var(--line);border-radius:8px;padding:5px 10px;font-size:15px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.canvas-undo-btn:hover{background:#253047cc}.metrics-bar{display:flex;gap:8px;padding:10px 14px;overflow-x:auto;background:var(--panel);border-top:1px solid var(--line);flex-shrink:0;scrollbar-width:none}.metrics-bar::-webkit-scrollbar{display:none}.metric-card{flex-shrink:0;min-width:80px;background:var(--card);border-left:3px solid var(--accent);border-radius:8px;padding:8px 10px}.metric-label{font-size:10px;font-weight:800;letter-spacing:.5px;margin-bottom:3px}.metric-values{display:flex;flex-direction:column}.metric-big{font-size:18px;font-weight:800}.metric-sub{font-size:11px;color:var(--muted)}.metric-empty{font-size:12px;color:var(--muted)}.hint{text-align:center;color:var(--muted);font-size:12px;margin:8px 14px 12px}.meta-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--panel);border-bottom:1px solid var(--line);flex-wrap:wrap;flex-shrink:0}.meta-group{display:flex;align-items:center;gap:6px}.meta-label{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.4px}.meta-toggle{display:flex;background:var(--card);border-radius:6px;overflow:hidden}.meta-toggle button{background:none;border:0;color:var(--muted);padding:5px 10px;font-weight:700;font-size:12px;cursor:pointer;letter-spacing:.3px}.meta-toggle button.on{background:#1c3050;color:#7eb8f7}.meta-notes{flex:1;min-width:160px;background:var(--card);border:1px solid var(--line);border-radius:6px;color:var(--text);font-size:13px;padding:5px 10px;outline:none}.meta-notes::placeholder{color:var(--muted)}.meta-notes:focus{border-color:var(--accent)}.save-spinner{display:inline-block;width:12px;height:12px;margin-right:6px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.upload-error{display:flex;align-items:center;gap:12px;background:#2d0f0f;color:#f87171;border-bottom:1px solid #7f1d1d;padding:8px 14px;font-size:13px;font-weight:600;flex-shrink:0}.upload-error button{margin-left:auto;background:#7f1d1d;color:#fca5a5;border:0;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer}.draft-pill{font-size:12px;font-weight:700;color:#f59e0b;background:#f59e0b22;border:1px solid #f59e0b44;border-radius:12px;padding:3px 10px}.skip-btn{color:var(--muted)!important;font-size:13px!important}.reset-btn{color:#f87171!important;font-size:13px!important}
