:root{--ground: #f2f5f4;--surface: #ffffff;--surface-2: #e9efed;--ink: #16211e;--soft: #52625d;--faint: #8a9793;--line: #dde4e1;--accent: #0f766e;--accent-strong: #0b5c55;--on-accent: #ffffff;--warm: #a16207;--danger: #b23a48;--radius: 10px;--serif: Georgia, "Iowan Old Style", "Times New Roman", serif;--sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono: ui-monospace, "SF Mono", Menlo, monospace}@media (prefers-color-scheme: dark){:root{--ground: #0d1412;--surface: #141d1a;--surface-2: #1b2622;--ink: #e7edea;--soft: #a7b5b0;--faint: #74827d;--line: #263430;--accent: #3cc2ab;--accent-strong: #5ad4bf;--on-accent: #0d1412;--warm: #d9a441;--danger: #e0697a}}*{box-sizing:border-box}body{margin:0;background:var(--ground);color:var(--ink);font-family:var(--sans);line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.topbar{display:flex;align-items:center;gap:1rem;padding:.7rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--line)}.topbar .brand{font-family:var(--serif);font-size:1.1rem;font-weight:600;color:var(--ink);margin-right:auto}.demo-badge{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--warm);border:1px solid currentColor;border-radius:20px;padding:.1rem .55rem}.page{max-width:52rem;margin:0 auto;padding:2rem 1.25rem 5rem}h1.page-title{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,5vw,2.3rem);letter-spacing:-.01em;line-height:1.15;text-wrap:balance;margin:.5rem 0 1rem}.crumb{font-size:.85rem;color:var(--faint)}button{font:inherit;cursor:pointer;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:.45rem .9rem}button.primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent);font-weight:600}button.primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}input,textarea,select{font:inherit;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:calc(var(--radius) - 4px);padding:.45rem .6rem;width:100%}label{font-size:.85rem;font-weight:600;color:var(--soft)}button.linklike{border:none;background:none;color:var(--accent);padding:.2rem}.error{color:var(--danger);font-size:.9rem;margin:.5rem 0 0}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:1.25rem}.login-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;width:100%;max-width:22rem;display:grid;gap:.9rem}.login-card h1{font-family:var(--serif);font-size:1.5rem;font-weight:600;margin:0 0 .3rem;text-align:center}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(14rem,1fr));gap:.8rem;margin-top:1.5rem}.card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.1rem;color:var(--ink)}.card:hover{border-color:var(--accent);text-decoration:none}.card h2{font-family:var(--serif);font-weight:600;font-size:1.05rem;margin:0 0 .6rem}.card .count{font-family:var(--mono);font-size:.75rem;color:var(--faint)}.stitches{display:flex;gap:3px;margin:.4rem 0 .3rem}.stitches span{height:5px;flex:1;border-radius:2px;background:var(--surface-2)}.stitches span.done{background:var(--accent)}.content{max-width:42rem}.content h2{font-family:var(--serif);font-weight:600;font-size:1.35rem;margin:2.2rem 0 .5rem;padding-bottom:.3rem;border-bottom:1px solid var(--line)}.content h3{font-size:1rem;margin:1.4rem 0 .3rem}.content img{max-width:100%;height:auto;border-radius:var(--radius)}.content ul{padding-left:1.3rem}.task{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:.8rem;overflow:hidden}.task>button.task-head{display:flex;align-items:baseline;gap:.7rem;width:100%;text-align:left;border:none;border-radius:0;background:none;padding:1rem 1.2rem;font-weight:600}.task-head .target{font-weight:400;font-size:.85rem;color:var(--faint);margin-left:auto;white-space:nowrap}.badge{font-family:var(--mono);font-size:.72rem;color:var(--warm);border:1px solid currentColor;border-radius:20px;padding:0 .5rem;white-space:nowrap}.task-body{padding:0 1.2rem 1.2rem}.video-wrap{position:relative;padding-bottom:56.25%;height:0;margin:1rem 0}.video-wrap iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0;border-radius:calc(var(--radius) - 4px)}.log-form{border-top:1px solid var(--line);margin-top:1.2rem;padding-top:1rem;display:grid;gap:.8rem}.log-form .row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.timer{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:1.6rem;min-width:5.2rem}.difficulty{display:flex;gap:.35rem}.difficulty button{width:2.2rem;padding:.35rem 0;font-variant-numeric:tabular-nums}.difficulty button.on{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.saved{color:var(--accent);font-size:.9rem}.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(9rem,1fr));gap:.8rem;margin:1.2rem 0 2rem}.tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.1rem}.tile .n{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:600;display:block}.tile .l{font-size:.8rem;color:var(--faint)}.section-progress{display:grid;gap:.55rem;margin:1rem 0 2rem}.section-progress .sp-row{display:grid;grid-template-columns:11rem 1fr 3.5rem auto;gap:.8rem;align-items:center;font-size:.9rem}.linklike.danger{color:var(--danger);font-size:.85rem}.section-progress .count{font-family:var(--mono);font-size:.75rem;color:var(--faint);text-align:right}.history{list-style:none;margin:1rem 0 0;padding:0;display:grid;gap:.5rem}.history li{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.7rem 1rem;display:grid;grid-template-columns:5rem 1fr auto auto;gap:.8rem;align-items:baseline;font-size:.9rem}.history .date,.history .dur{font-family:var(--mono);font-size:.78rem;color:var(--faint);font-variant-numeric:tabular-nums}.history .notes{grid-column:2 / -1;color:var(--soft);font-size:.85rem;font-style:italic}@media (max-width: 34rem){.history li{grid-template-columns:1fr auto}.history .date{grid-column:1 / -1}.section-progress .sp-row{grid-template-columns:1fr;gap:.25rem}.section-progress .count{text-align:left}}.profile-details{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.9rem 1.1rem;margin:1rem 0 .5rem}.profile-details summary{cursor:pointer;font-weight:600;color:var(--soft)}.profile-form{display:grid;grid-template-columns:repeat(auto-fill,minmax(13rem,1fr));gap:.8rem;margin-top:1rem}.profile-form-actions{grid-column:1 / -1;display:flex;align-items:center;gap:.8rem}.hero{max-width:44rem;margin:0 auto;padding:clamp(3rem,9vw,6rem) 1.25rem 2rem;text-align:center}.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,6vw,3.2rem);line-height:1.1;letter-spacing:-.015em;text-wrap:balance;margin:1.2rem 0 .8rem}.hero-sub{color:var(--soft);font-size:1.05rem;max-width:34rem;margin:0 auto 1.8rem}.hero-stitchbar{width:11rem;margin:0 auto}.hero-cta{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}.landing-features .card h2{margin-bottom:.3rem}.landing-features .card p{margin:0;font-size:.9rem;color:var(--soft)}.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.8rem}.chip{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:.25rem .8rem;font-size:.85rem}.landing-research{color:var(--faint);font-size:.85rem;margin-top:2.5rem;text-align:center}.legal-footer{display:flex;justify-content:center;gap:1.5rem;padding:1.5rem;font-size:.8rem}.legal-footer a{color:var(--faint)}.print-header{display:none}@media print{.topbar,.crumb,button,.profile-details,.stitches,.legal-footer{display:none!important}body{background:#fff;color:#000}.page{max-width:none;padding:0}.print-header{display:block;margin-bottom:1.5rem;font-size:.9rem}.tile,.history li{border-color:#bbb;break-inside:avoid}.section-progress .sp-row{grid-template-columns:11rem 1fr 3.5rem}}h2.sub{font-family:var(--serif);font-weight:600;font-size:1.2rem;margin:2rem 0 .4rem}
