:root{--text:#4a3335;--text-h:#180a0b;--bg:#fff;--panel:#faf7f7;--border:#e8dede;--accent:#c41c2a;--accent-bg:#c41c2a12;--accent-border:#c41c2a66;--pass:#16a34a;--fail:#ea580c;--shadow:#00000014 0 10px 15px -3px, #0000000a 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/145% var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{min-height:100svh;margin:0}#root{min-height:100svh}h1,h2{color:var(--text-h);margin:0;font-weight:600}p{margin:0}button{font:inherit;cursor:pointer;border:1px solid var(--border);background:var(--panel);color:var(--text-h);border-radius:8px;padding:8px 14px;transition:border-color .15s,background .15s}button:hover{border-color:var(--accent-border)}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button:disabled{opacity:.38;cursor:not-allowed}button:disabled:hover{border-color:var(--border)}.app{max-width:1100px;margin:0 auto;padding:24px 20px 48px}.app-header{border-bottom:1px solid var(--border);margin-bottom:24px;padding-bottom:16px}.app-header-row{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.app-header h1{letter-spacing:-.5px;font-size:26px}.app-header-sub{color:var(--text);max-width:60ch;margin-top:4px;font-size:13px}.app-main{flex-direction:column;gap:20px;max-width:760px;margin:0 auto;display:flex}.stage{position:relative}.camera-view{aspect-ratio:4/3;width:100%;box-shadow:var(--shadow);background:#000;border-radius:12px;position:relative;overflow:hidden}.camera-view video{object-fit:cover;width:100%;height:100%;display:block}.camera-view.mirrored video{transform:scaleX(-1)}.camera-view .blur-feed{filter:blur(14px);position:absolute;inset:0}.frame-box{aspect-ratio:1;pointer-events:none;border:2px dashed #ffffffb3;border-radius:10px;place-items:center;display:grid;position:absolute;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.camera-view.state-settling .frame-box{border-color:var(--accent);border-style:solid}.camera-view.state-captured .frame-box{border-color:var(--pass);border-style:solid}.settle-ring{aspect-ratio:1;border:4px solid var(--accent);border-radius:50%;width:70%;transition:opacity .2s,transform .1s linear;position:absolute}.state-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600;position:absolute;top:12px;left:12px}.badge-settling{background:var(--accent)}.badge-captured{background:var(--pass)}.badge-waiting{background:#000000b3}.mirror-btn{min-width:92px}.auto-btn{min-width:78px}.camera-cover{color:#fff;text-align:center;background:#0009;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:20px;display:flex;position:absolute;inset:0}.camera-error{color:#fca5a5;max-width:40ch}.stage-controls{align-items:flex-end;gap:16px;margin-top:14px;display:flex}.metrics-overlay{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:1;gap:8px;padding:12px 14px;display:flex}.metric-row{grid-template-columns:70px 1fr 48px;align-items:center;gap:10px;font-size:13px;display:grid}.metric-label{color:var(--text-h);font-weight:500}.metric-value{font-family:var(--mono);text-align:right}.metric-row.pass .metric-value{color:var(--pass)}.metric-row.fail .metric-value{color:var(--text)}.metric-bar{background:var(--border);border-radius:4px;height:8px;position:relative;overflow:hidden}.metric-fill{background:var(--accent);transition:width .1s linear;position:absolute;inset:0 auto 0 0}.metric-row.pass .metric-fill{background:var(--pass)}.metric-mark{background:var(--text-h);opacity:.5;width:2px;position:absolute;top:-2px;bottom:-2px}.carousel{aspect-ratio:4/3;width:100%;box-shadow:var(--shadow);background:#000;border-radius:12px;position:relative;overflow:hidden}.carousel img{object-fit:contain;width:100%;height:100%;display:block}.carousel-arrow{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border:none;border-radius:50%;place-items:center;width:40px;height:40px;font-size:24px;line-height:1;display:grid;position:absolute;top:50%;transform:translateY(-50%)}.carousel-arrow:hover{background:#000000c7}.carousel-arrow.prev{left:10px}.carousel-arrow.next{right:10px}.carousel-dots{gap:6px;display:flex;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.carousel-dots .dot{background:#ffffff80;border-radius:50%;width:8px;height:8px}.carousel-dots .dot.active{background:#fff}.app-single{justify-content:center;display:flex}.loading{text-align:center;padding:40px 0}.panel{border:1px solid var(--border);background:var(--panel);border-radius:12px;padding:16px}.app-single .panel{width:100%;max-width:520px}.panel h2{margin-bottom:4px;font-size:18px}.panel-note{color:var(--text);margin-bottom:14px;font-size:14px}.lock-form{margin-top:16px}.duration-row{align-items:center;gap:8px;font-size:14px;display:flex}.duration-row input{width:72px;font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;padding:8px}.duration-row select{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;padding:8px}.unlock-preview{font-size:13px;font-family:var(--mono);color:var(--text);margin-top:8px}.time-warning{color:var(--fail);margin-top:10px;font-size:13px}.countdown{text-align:center;font-family:var(--mono);letter-spacing:1px;color:var(--text-h);margin:18px 0 6px;font-size:34px;font-weight:600}.panel-actions{gap:8px;margin-top:16px;display:flex}.panel-actions button{flex:1;font-size:14px}.puzzle-screen{flex-direction:column;width:100%;height:100dvh;display:flex}.puzzle-topbar{border-bottom:1px solid var(--border);background:var(--panel);flex:none;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;min-height:52px;padding:0 16px;display:grid}.puzzle-topbar-left{align-items:baseline;gap:8px;min-width:0;display:flex}.puzzle-topbar-center{justify-self:center}.puzzle-topbar-label{color:var(--text);font-size:13px}.puzzle-topbar-time{font-family:var(--mono);letter-spacing:1px;color:var(--text-h);font-size:18px;font-weight:600}.puzzle-topbar-unlock{padding:6px 16px;font-size:14px}.puzzle-topbar-right{justify-self:end;align-items:center;gap:12px;min-width:0;display:flex}.puzzle-topbar-step{font-size:13px;font-family:var(--mono);color:var(--text)}.puzzle-topbar-warn{color:var(--fail);font-size:12px}.puzzle-stage{flex:1;min-height:0;display:flex}.task-runner{flex-direction:column;flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex}.task-runner .panel{width:100%;max-width:520px}.progress-track{background:var(--bg);border:1px solid var(--border);border-radius:7px;height:14px;margin:18px 0 6px;overflow:hidden}.progress-fill{background:var(--accent,#4f8cff);height:100%;transition:width 80ms linear}.hold-arena{touch-action:none;-webkit-user-select:none;user-select:none;flex:1;align-self:stretch;width:100%;min-height:0;position:relative;overflow:hidden}.hold-caption{text-align:center;color:var(--text);padding:0 16px;font-size:14px;position:absolute;top:12px;left:0;right:0}.hold-circle{border:3px solid var(--text-h);cursor:grab;will-change:transform;border-radius:50%;position:absolute;top:0;left:0;box-shadow:0 0 0 2px #ffffffe6,inset 0 0 0 2px #ffffffe6}.hold-circle.held{cursor:grabbing;border-color:var(--accent,#4f8cff)}.focus-arena{background:var(--bg);flex:1;align-self:stretch;width:100%;min-height:0;position:relative;overflow:hidden}.focus-overlay{background:color-mix(in srgb, var(--panel) 88%, transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-top:3px solid var(--border);z-index:3;padding:12px 16px;position:absolute;bottom:0;left:0;right:0}.focus-overlay.alert{border-top-color:var(--fail)}.focus-overlay h2{color:var(--text-h);margin-bottom:4px;font-size:16px}.focus-cam-hidden{opacity:0;pointer-events:none;clip:rect(0 0 0 0);width:1px;height:1px;position:absolute}.focus-cam-visible{object-fit:cover;background:var(--bg);width:100%;height:100%;position:absolute;inset:0}.focus-cam-visible.mirrored{transform:scaleX(-1)}.focus-slide{object-fit:contain;width:100%;height:100%;animation:.5s forwards jigsaw-fade-in;position:absolute;inset:0}.focus-cam-cover{text-align:center;background:var(--panel);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:16px;display:flex;position:absolute;inset:0}.hold-slide{object-fit:contain;opacity:.55;pointer-events:none;width:100%;height:100%;animation:.5s forwards jigsaw-fade-in;position:absolute;inset:0}.sequence-task{box-sizing:border-box;flex-direction:column;flex:1;align-self:stretch;gap:12px;width:100%;min-height:0;padding:12px 16px;display:flex}.sequence-header{color:var(--text);flex:none;justify-content:space-between;align-items:center;min-height:22px;font-size:14px;display:flex}.sequence-grid-wrap{flex:1;justify-content:center;align-items:center;min-width:0;min-height:0;display:flex}.sequence-wrong-msg{color:var(--fail,#f44);font-weight:600}.sequence-progress{color:var(--accent,#4f8cff);white-space:nowrap;font-size:13px;font-weight:600}.sequence-grid{gap:8px;max-width:100%;max-height:100%;display:grid}.sequence-tile{aspect-ratio:1;border:3px solid var(--border);cursor:pointer;background:var(--panel);opacity:.55;border-radius:8px;padding:0;transition:opacity .1s,border-color .1s,transform .12s,box-shadow .12s;overflow:hidden}.sequence-tile img{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.sequence-tile.seq-lit{border-color:var(--accent,#4f8cff);opacity:1;box-shadow:0 0 18px 3px color-mix(in srgb, var(--accent,#4f8cff) 55%, transparent);transform:scale(1.05)}.sequence-tile.seq-correct{border-color:var(--ok,#4caf50);opacity:1;box-shadow:0 0 18px 3px color-mix(in srgb, var(--ok,#4caf50) 55%, transparent)}.sequence-tile.seq-wrong{border-color:var(--fail,#f44);opacity:1;box-shadow:0 0 18px 3px color-mix(in srgb, var(--fail,#f44) 55%, transparent)}.sequence-tile:not(:disabled):hover{opacity:.8}.sequence-tile:disabled{cursor:default}.tap-arena{touch-action:none;-webkit-user-select:none;user-select:none;flex:1;align-self:stretch;width:100%;min-height:0;position:relative;overflow:hidden}.steady-arena{touch-action:none;-webkit-user-select:none;user-select:none;flex-direction:column;flex:1;align-self:stretch;width:100%;min-height:0;display:flex;position:relative}.steady-canvas{touch-action:none;cursor:crosshair;z-index:1;flex:1;width:100%;min-height:0;display:block;position:relative}.tap-button{border:2px solid var(--border);cursor:pointer;will-change:transform;border-radius:50%;width:64px;height:64px;position:absolute;top:0;left:0}.tap-button:hover{border-color:var(--accent,#4f8cff)}.tap-progress{background:var(--bg);border:1px solid var(--border);border-radius:4px;height:8px;position:absolute;bottom:12px;left:16px;right:16px;overflow:hidden}.tap-progress-fill{background:var(--accent,#4f8cff);height:100%;transition:width 80ms linear}.wait-arena{flex:1;justify-content:center;align-self:stretch;align-items:center;width:100%;min-height:0;display:flex;position:relative;overflow:hidden}.wait-slide{object-fit:contain;width:100%;height:100%;animation:.5s forwards jigsaw-fade-in;position:absolute;inset:0}.wait-overlay{z-index:2;justify-content:center;align-items:center;display:flex;position:relative}.focus-meter{background:var(--bg);border:1px solid var(--border);border-radius:5px;height:10px;margin:12px 0 6px;position:relative;overflow:hidden}.focus-meter-fill{background:var(--fail);height:100%;transition:width .1s linear}.focus-meter-fill.ok{background:var(--accent,#4f8cff)}.focus-meter-min{background:var(--text-h);opacity:.7;width:2px;position:absolute;top:0;bottom:0;left:50%}.typing-target{white-space:pre-wrap;font-family:var(--mono);margin:12px 0;font-size:15px;line-height:1.6}.typing-char.pending{color:var(--text);opacity:.5}.typing-char.ok{color:var(--text-h)}.typing-char.bad{color:var(--fail);background:color-mix(in srgb, var(--fail) 20%, transparent)}.typing-arena{flex:1;justify-content:center;align-self:stretch;align-items:center;width:100%;min-height:0;display:flex;position:relative;overflow:hidden}.typing-slide-overlay{z-index:1;justify-content:center;align-items:center;width:100%;padding:16px;display:flex;position:relative}.typing-reps{align-items:center;gap:8px;margin-bottom:8px;font-size:15px;font-weight:600;display:flex;position:relative}.typing-progress-track{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.typing-progress-fill{background:var(--accent,#4f8cff);border-radius:3px;height:100%;transition:width .2s}@keyframes typing-flash-out{0%{opacity:1;transform:translateY(0)}60%{opacity:1;transform:translateY(-4px)}to{opacity:0;transform:translateY(-10px)}}.typing-penalty-flash{color:var(--fail,#f44);margin-left:8px;font-size:13px;animation:1.2s forwards typing-flash-out;display:inline-block}.typing-input{width:100%;font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;padding:10px}.typing-task-line-input{width:100%;min-height:60px;font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);resize:vertical;border-radius:6px;padding:8px;font-size:13px}.sliding{justify-content:center;width:100%;display:flex}.memory{box-sizing:border-box;flex:1;justify-content:center;align-self:stretch;align-items:center;width:100%;min-height:0;padding:12px 16px;display:flex;container-type:size}.sliding-board{background:var(--border);border:1px solid var(--border);border-radius:8px;gap:2px;display:grid;overflow:hidden}.sliding-tile{cursor:pointer;background-repeat:no-repeat;border:none;padding:0;position:relative}.sliding-hint{color:#fff;opacity:.55;pointer-events:none;text-shadow:0 0 3px #000,0 0 6px #000;justify-content:center;align-items:center;font-size:clamp(11px,35%,22px);font-weight:700;display:flex;position:absolute;inset:0}.sliding-gap{background:var(--bg)}.sliding-solved{flex-direction:column;align-items:center;gap:16px;display:flex}.sliding-finished{object-fit:contain;border-radius:8px;width:min(80vmin,480px);max-height:70vh;animation:.6s forwards jigsaw-fade-in}.memory-grid{width:min(100cqw, calc(100cqh * var(--cols) / var(--rows)));gap:6px;max-width:100%;display:grid}.memory-card{aspect-ratio:1;border:1px solid var(--border);background:var(--panel);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0;display:flex;overflow:hidden}.memory-card img{object-fit:contain;width:100%;height:100%}.memory-back{color:var(--text);font-size:22px;font-weight:700}.memory{position:relative}.memory-pause{z-index:2;border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow);color:var(--text);border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-size:13px;font-weight:600;display:flex;position:absolute;top:8px;left:50%;transform:translate(-50%)}.memory-pause-track{background:var(--accent-bg);border-radius:999px;width:80px;height:5px;overflow:hidden}.memory-pause-bar{background:var(--accent);transform-origin:0;border-radius:999px;width:100%;height:100%;animation:linear forwards memory-pause-deplete}@keyframes memory-pause-deplete{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.flow-add-menu{display:inline-block;position:relative}.flow-add-trigger{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:8px;padding:6px 12px;font-size:13px}.flow-add-trigger:hover{border-color:var(--accent-border)}.flow-add-dropdown{z-index:200;background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:10px;flex-direction:column;min-width:190px;padding:6px;display:flex;position:fixed;overflow-y:auto}.flow-add-group{color:var(--text);opacity:.5;text-transform:uppercase;letter-spacing:.06em;margin:0;padding:6px 8px 3px;font-size:11px;font-weight:600}.flow-add-item{text-align:left;font:inherit;color:var(--text-h);cursor:pointer;background:0 0;border:none;border-radius:6px;width:100%;padding:7px 10px;font-size:13px}.flow-add-item:hover{background:var(--accent-bg);border-color:#0000}.flow-add-divider{background:var(--border);height:1px;margin:4px 0}.flow-row-edit{border:1px solid var(--border);background:var(--bg);color:var(--text-h);font:inherit;text-align:left;cursor:pointer;border-radius:8px;flex:1;align-items:center;gap:8px;min-width:0;padding:8px 10px;display:flex}.flow-row-edit:hover{border-color:var(--accent,#4f8cff)}.flow-summary-text{font-family:var(--mono);color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;overflow:hidden}.flow-edit-hint{color:var(--text);opacity:.7;font-size:11px}.flow-row-preview{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:8px;flex:none;padding:6px 10px;font-size:13px;line-height:1}.flow-row-preview:hover{border-color:var(--accent,#4f8cff)}.puzzle-topbar-back{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:8px;padding:4px 10px;font-size:14px}.modal-backdrop{z-index:100;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:100%;max-width:640px;max-height:92vh;padding:28px;display:flex;box-shadow:0 18px 60px #00000080}.modal-title{color:var(--text-h);margin-bottom:4px;font-size:18px}.modal-desc{color:var(--text);max-width:50ch;margin-bottom:14px;font-size:13px}.modal-section{text-transform:uppercase;letter-spacing:.07em;color:var(--text);opacity:.55;border-top:1px solid var(--border);margin-top:4px;padding-top:10px;padding-bottom:4px;font-size:11px;font-weight:600}.modal-checkbox{color:var(--text-h);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:inline-flex}.modal-validation{color:var(--fail);margin:-4px 0 0;font-size:13px}.modal-body{flex-direction:column;flex:1;gap:12px;display:flex;overflow:auto}.modal-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.modal-row-label{color:var(--text);flex:0 0 160px;font-size:13px}.modal-row-controls{flex-wrap:wrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.modal-row-controls input[type=number],.modal-row-controls select{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;padding:6px 8px}.modal-row-controls input[type=number]{width:80px}.modal-actions{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.flow-list{flex-direction:column;gap:8px;margin:12px 0;list-style:none;display:flex}.flow-row{align-items:center;gap:8px;display:flex}.flow-controls{flex-wrap:wrap;flex:1;align-items:center;gap:8px;display:flex}.flow-tag{color:var(--text-h);white-space:nowrap;font-size:13px;font-weight:600}.flow-dash,.flow-unit{color:var(--text);font-size:13px}.flow-random{color:var(--text);white-space:nowrap;border:1px solid var(--border);background:var(--bg);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:4px;padding:2px 6px;font-size:11px;display:inline-flex}.flow-random input[type=checkbox]{appearance:none;opacity:0;width:0;height:0;margin:0;padding:0;position:absolute}.flow-random:has(input:checked){border-color:var(--accent-border);background:var(--accent-bg);color:var(--text-h)}.flow-controls input,.flow-controls select,.flow-loop-head input{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;padding:6px 8px}.flow-controls input,.flow-loop-head input{width:64px}.flow-row-actions{gap:4px;display:flex}.flow-row-actions button{padding:4px 8px;font-size:12px;line-height:1}.flow-add{flex-wrap:wrap;gap:8px;display:flex}.flow-add button{font-size:13px}.flow-loop{border:1px dashed var(--border);border-radius:10px;padding:10px}.flow-loop-head{align-items:center;gap:8px;display:flex}.flow-loop-list{border-left:2px solid var(--border);margin:8px 0;padding-left:10px}.flow-option{color:var(--text);cursor:pointer;align-items:center;gap:8px;margin-top:12px;font-size:13px;display:flex}.flow-option-row{cursor:default;justify-content:space-between}.flow-option-label{flex-shrink:0}.flow-option-select{font-size:13px}.flow-pools-col{flex-direction:column;align-items:flex-end;gap:8px;min-width:0;display:flex}.flow-pools{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.flow-pool{align-items:center;display:inline-flex}.flow-pool:has(.flow-pool-remove) .flow-random{border-top-right-radius:0;border-bottom-right-radius:0}.flow-pool-remove{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-left:none;border-top-right-radius:6px;border-bottom-right-radius:6px;padding:4px 6px;font-size:11px;line-height:1}.flow-pool-remove:hover{color:var(--fail);border-color:var(--fail)}.flow-pools-add{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.flow-pools-add button{font-size:12px}.flow-readonly-options{background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:6px;gap:6px;margin:12px 0 0;padding:10px 12px;font-size:13px;display:grid}.flow-readonly-option{justify-content:space-between;gap:12px;margin:0;display:flex}.flow-readonly-option dt{color:var(--text);font-weight:500}.flow-readonly-option dd{color:var(--text-h);text-align:right;font-family:var(--mono);margin:0}.flow-maxtotal{margin-top:8px;margin-left:24px}.flow-summary{font-size:13px;font-family:var(--mono);color:var(--text);margin-top:10px}.loaded-config-banner{background:color-mix(in srgb, var(--accent) 12%, var(--panel));border:1px solid color-mix(in srgb, var(--accent) 30%, var(--border));border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:10px 14px;display:flex}.loaded-config-name{color:var(--text-h);font-size:15px;display:block}.loaded-config-label{color:var(--text);margin-top:2px;font-size:12px;display:block}.loaded-config-hidden{color:var(--text);margin:4px 0 12px;font-style:italic}.flow-row-readonly{cursor:default;gap:10px;padding:8px 12px}.share-import-btn{margin-bottom:10px;padding:5px 10px;font-size:13px}.share-panel{border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:10px;margin-bottom:12px;padding:14px;display:flex}.share-panel-title{color:var(--text-h);margin:0;font-size:14px;font-weight:600}.share-panel-row{align-items:center;gap:10px;display:flex}.about-link{color:var(--text);opacity:.6;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:7px;flex-shrink:0;padding:3px 10px;font-size:13px;text-decoration:none}.about-link:hover{opacity:1;border-color:var(--border)}.about-body{flex-direction:column;gap:12px;max-width:600px;margin:0 auto;padding:32px 20px 48px;display:flex}.about-body h2{color:var(--text-h);margin-top:20px;font-size:16px;font-weight:700}.about-body h2:first-child{margin-top:0}.about-body p{color:var(--text);max-width:60ch;font-size:14px;line-height:1.65}.saved-empty{color:var(--text);opacity:.6;margin:0;font-size:13px}.saved-row{align-items:center;gap:8px;display:flex}.saved-info{flex:1;align-items:baseline;gap:8px;min-width:0;display:flex}.saved-name{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.saved-date{color:var(--text);opacity:.55;flex-shrink:0;font-size:12px}.saved-delete{opacity:.5;padding:4px 8px;font-size:12px}.saved-delete:hover{opacity:1}.saved-footer{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:4px;padding-top:10px;display:flex}.saved-save-row{flex:1;align-items:center;gap:8px;display:flex}.saved-save-row .share-name-input{flex:1}.share-panel-label{color:var(--text);flex-shrink:0;font-size:13px}.share-name-input{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;flex:1;padding:6px 10px;font-size:13px}.share-panel-actions{justify-content:flex-end;gap:8px;display:flex}.share-code-input,.share-code-output{width:100%;font:12px/1.5 var(--mono,monospace);border:1px solid var(--border);background:var(--bg);color:var(--text-h);resize:vertical;box-sizing:border-box;border-radius:6px;padding:8px}.share-code-output{background:color-mix(in srgb, var(--border) 30%, var(--panel));cursor:text}.share-error{color:var(--fail,#f44);margin:0;font-size:13px}.share-error-panel{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.shared-log-viewer{margin-top:16px}.session-history{margin-top:12px}.session-history-list{flex-direction:column;gap:8px;margin:8px 0 0;padding:0;list-style:none;display:flex}.session-history-row{align-items:stretch;gap:8px;display:flex}.session-history-toggle{text-align:left;border:1px solid var(--border);background:var(--panel);cursor:pointer;border-radius:8px;flex-direction:column;flex:1;align-items:flex-start;gap:2px;padding:8px 12px;display:flex}.session-history-toggle:hover{border-color:var(--accent-border)}.session-history-date{color:var(--text-h);font-size:13px;font-weight:600}.session-history-meta{color:var(--text);font-size:12px}.session-history-remove{width:32px;color:var(--text);border:1px solid var(--border);background:var(--panel);cursor:pointer;border-radius:8px;flex-shrink:0;font-size:18px;line-height:1}.session-history-remove:hover{color:var(--fail);border-color:var(--fail)}.session-log{flex-direction:column;gap:8px;margin:16px 0 8px;display:flex}.session-log-title{color:var(--text-h);margin:0;font-size:14px;font-weight:600}.session-log-table{border-collapse:collapse;width:100%;font-size:13px}.session-log-table th,.session-log-table td{text-align:left;border-bottom:1px solid var(--border);padding:5px 10px}.session-log-table th{color:var(--text);font-weight:600}.session-log-table td{color:var(--text-h)}.session-log-label{color:var(--text);width:90px}.session-log-config{color:var(--text);font-size:12px}.session-log-method{color:var(--text);margin:0;font-size:13px}.jigsaw{flex:1;width:100%;min-height:0;display:flex;position:relative}.jigsaw-loading{color:var(--text);justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;inset:0}.jigsaw-finished{object-fit:cover;animation:.9s forwards jigsaw-fade-in;position:absolute}@keyframes jigsaw-fade-in{0%{opacity:0}to{opacity:1}}.jigsaw-solved-bar{border-top:1px solid var(--border);background:var(--panel);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex;position:absolute;bottom:0;left:0;right:0}.jigsaw-solved-msg{color:var(--text-h);font-size:15px;font-weight:600}.jigsaw-board{background:var(--bg);touch-action:none;flex:1;width:100%;min-height:0;overflow:hidden}.jigsaw-board--grey{background:#888}.jigsaw-bg-toggle{z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text);cursor:pointer;background:#ffffffbf;border:1px solid #00000026;border-radius:999px;padding:4px 10px;font-size:12px;line-height:1;position:absolute;top:10px;right:10px}.jigsaw-bg-toggle.active{color:#fff;background:#505050d9;border-color:#0000}@media (width<=600px){.modal-backdrop{align-items:flex-start;padding:6px}.modal{border-radius:10px;max-height:calc(100vh - 12px);padding:16px}.modal-title{font-size:17px}.modal-desc{margin-bottom:10px;font-size:12.5px}.modal-body{gap:10px}.modal-row{flex-direction:column;align-items:stretch;gap:6px}.modal-row-label{color:var(--text-h);flex:none;font-weight:500}.modal-row-controls{width:100%}.modal-row-controls input[type=number],.modal-row-controls select{padding:8px 10px;font-size:16px}.modal-row-controls select{max-width:100%}.modal-row-controls input[type=number]{width:72px}.modal-section{padding-top:8px}.modal-actions{margin-top:10px}.typing-task-line-input{font-size:16px}.session-log{margin:12px 0 4px}.session-log-table{font-size:12px}.session-log-table th,.session-log-table td{padding:5px 6px}.session-log-label{white-space:nowrap;width:auto;padding-right:8px}.session-log-config{font-size:11px}.share-code-input,.share-code-output{font-size:12px}.flow-row{flex-wrap:wrap;gap:6px}.flow-row-edit{flex:100%;padding:8px 10px}.flow-edit-hint,.flow-row-preview{margin-left:auto}.flow-option-row{flex-direction:column;align-items:stretch;gap:6px}.flow-option-select{width:100%;max-width:100%;padding:8px 10px;font-size:16px}.flow-pools{justify-content:flex-start}.flow-loop-head,.panel-actions{flex-wrap:wrap}.stage-controls{flex-direction:column;align-items:stretch;gap:10px}.stage-controls>button{width:100%;min-width:0}}
