:root{--card:#fffdfb;--ink:#5a4a55;--ink-soft:#9a8a96;--line:#ecdfe9;--pink:#f6b8cd;--peach:#f8cda4;--butter:#f3e29c;--mint:#a9e0c0;--sky:#a8d4f0;--peri:#bcc2f0;--lav:#dcc1ee;--accent:#f6b8cd;--rs:#86c5ae;--ws:#c2a6e0;--shadow:rgba(150,120,150,.2)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{font-family:Comfortaa,system-ui,sans-serif;color:var(--ink);background-color:#fffaf7;background-image:radial-gradient(circle at 25% 25%,rgba(246,184,205,.34) 0 7px,transparent 8px),radial-gradient(circle at 75% 35%,rgba(168,212,240,.32) 0 4px,transparent 5px),radial-gradient(circle at 50% 60%,rgba(243,226,156,.38) 0 7px,transparent 8px),radial-gradient(circle at 88% 80%,rgba(169,224,192,.32) 0 4px,transparent 5px),radial-gradient(circle at 15% 80%,rgba(220,193,238,.34) 0 4px,transparent 5px),radial-gradient(circle at 62% 10%,rgba(248,205,164,.32) 0 4px,transparent 5px);background-size:120px 120px;background-attachment:fixed}.app{max-width:440px;margin:0 auto;min-height:100%;display:flex;flex-direction:column}.scroll{flex:1;overflow-y:auto;padding:16px 14px 96px}@media (min-width:760px){.app{max-width:1000px}.topbar{padding:20px 28px 10px}.brand{font-size:28px}.scroll{padding:22px 28px 60px}.grid-wide{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;align-items:start}.grid-wide .item{margin-bottom:0}.tracker-wrap,.detail-wrap{max-width:560px;margin:0 auto}.h1{font-size:30px}.menu-panel{max-width:320px}.sheet-bg{align-items:center}.sheet{max-width:520px;border-radius:24px}}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 6px}.brand{font-family:Fraunces,serif;font-size:24px;font-weight:500;background:linear-gradient(90deg,#ef9bb8,#f3b07e,#e7cf6c,#7fc99e,#7cbbe6,#a9a4ea,#cf9ee0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.synced{font-size:10.5px;font-weight:600;display:flex;align-items:center;gap:5px;color:var(--ink-soft)}.synced i{width:8px;height:8px;border-radius:50%;background:#cfc4d0;display:inline-block}.synced.s-synced i{background:#8cbfa9}.synced.s-syncing i{background:var(--butter)}.synced.s-offline i{background:var(--peach)}.tabs{position:sticky;bottom:0;display:flex;background:var(--card);border-top:1px solid var(--line);box-shadow:0 -8px 24px -16px var(--shadow)}.tab{flex:1;border:none;background:none;padding:11px 4px 14px;font-family:Comfortaa,sans-serif;font-size:11px;font-weight:600;color:var(--ink-soft);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px}.tab .ic{font-size:20px;line-height:1}.tab.active{color:var(--ink)}.tab.active .ic{filter:saturate(1.2)}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:15px 16px;box-shadow:0 8px 24px -18px var(--shadow);margin-bottom:12px}.h1{font-family:Fraunces,serif;font-size:26px;font-weight:500;margin:4px 2px 14px}.h2{font-family:Fraunces,serif;font-size:18px;font-weight:500}.muted{color:var(--ink-soft);font-size:12.5px;line-height:1.5}.eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}.row-between{display:flex;align-items:center;justify-content:space-between;gap:10px}.item{display:flex;gap:12px;align-items:center;background:var(--card);border:1px solid var(--line);border-left:6px solid var(--accent);border-radius:16px;padding:13px 14px;margin-bottom:10px;cursor:pointer;box-shadow:0 8px 24px -20px var(--shadow);transition:transform .08s}.item:active{transform:scale(.99)}.item .title{font-family:Fraunces,serif;font-size:17px;font-weight:500;line-height:1.15}.item .sub{font-size:11.5px;color:var(--ink-soft);margin-top:3px}.item .right{margin-left:auto;text-align:right;font-size:11px;color:var(--ink-soft)}.chip{display:inline-block;font-size:10px;font-weight:700;color:#7a6470;background:#fbeef5;border:1px solid var(--line);border-radius:50px;padding:2px 8px;letter-spacing:.04em}.swatch{width:34px;height:34px;border-radius:9px;flex-shrink:0;border:1px solid rgba(0,0,0,.06)}.btn{border:none;font-family:Comfortaa,sans-serif;cursor:pointer;border-radius:14px;font-weight:700;transition:transform .08s,filter .2s}.btn:active{transform:translateY(1px)}.btn-primary{color:#5a4a55;padding:14px;font-size:15px;width:100%;background:linear-gradient(100deg,#f8c6d8,#f9d6b6,#f3e6ad,#aee3c8,#aed7f2,#c7cbf3,#e0c8f0);box-shadow:0 10px 24px -14px #bea0c8cc}.btn-soft{background:var(--card);border:1.5px solid var(--line);color:var(--ink-soft);padding:11px 14px;font-size:13px;font-weight:600}.btn-row{display:flex;gap:10px}.btn-row .btn{flex:1}.fab{position:fixed;left:50%;transform:translate(-50%);bottom:78px;z-index:20;width:min(412px,calc(100% - 28px))}label.fld{display:block;margin-bottom:11px}label.fld span{display:block;font-size:11px;font-weight:600;color:var(--ink-soft);margin-bottom:5px;letter-spacing:.02em}input,select,textarea{width:100%;font-family:Comfortaa,sans-serif;font-size:14px;color:var(--ink);background:#fffaf7;border:1.5px solid var(--line);border-radius:12px;padding:11px 12px}textarea{min-height:120px;resize:vertical;line-height:1.5}input:focus,select,textarea:focus{outline:none;border-color:var(--peri)}.two{display:flex;gap:10px}.two>*{flex:1}.sheet-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#6e5a6e6b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;z-index:60}.sheet{background:var(--card);width:100%;max-width:440px;border-radius:24px 24px 0 0;padding:18px 16px 26px;max-height:90vh;overflow-y:auto;box-shadow:0 -10px 40px -10px var(--shadow)}.sheet h3{font-family:Fraunces,serif;font-weight:500;font-size:21px;margin-bottom:3px}.sheet .muted{margin-bottom:14px}.sheet-close{width:100%;margin-top:8px;background:var(--ink);color:#fffdfb;border:none;border-radius:14px;padding:13px;font-family:Comfortaa,sans-serif;font-weight:700;font-size:14px;cursor:pointer}.empty{text-align:center;color:var(--ink-soft);font-size:13px;padding:34px 18px;line-height:1.6}.empty .big{font-size:30px;margin-bottom:8px}.backlink{background:none;border:none;color:var(--ink-soft);font-family:Comfortaa,sans-serif;font-size:13px;font-weight:600;cursor:pointer;padding:4px 0;margin-bottom:4px}.seqcard{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:15px 16px 13px;box-shadow:0 10px 30px -18px var(--shadow);margin-bottom:12px}.panel-name{font-family:Fraunces,serif;font-size:24px;font-weight:500;margin-top:5px;line-height:1.1}.chart-tag{display:inline-block;font-size:11px;font-weight:700;color:#fff;background:var(--accent);border-radius:6px;padding:1px 7px;letter-spacing:.04em;margin-left:3px;text-shadow:0 1px 1px rgba(140,100,130,.3)}.dots{display:flex;gap:5px;margin-top:13px;flex-wrap:wrap}.dot{flex:1;min-width:0;height:8px;border-radius:50px;background:var(--line);transition:.25s}.dot.done{background:var(--accent);opacity:.5}.dot.cur{background:var(--accent);transform:scaleY(1.6)}.caston{background:linear-gradient(135deg,#9fd8c2,#a8d4f0);color:#3f5a52;border-radius:16px;padding:13px 16px;text-align:center;margin-bottom:12px;box-shadow:0 10px 24px -16px #82beaab3}.caston .big{font-family:Fraunces,serif;font-size:21px;font-weight:500}.caston .big b{font-size:28px}.caston .sm{font-size:11px;opacity:.8;margin-top:2px}.rowcard{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:20px 18px 22px;box-shadow:0 16px 40px -22px var(--shadow);position:relative;overflow:hidden;margin-bottom:12px}.rowcard:before{content:"";position:absolute;left:0;top:0;bottom:0;width:7px;background:var(--accent)}.rowhead{display:flex;align-items:center;justify-content:space-between;gap:10px}.rownum{font-family:Fraunces,serif;font-size:16px;font-weight:500}.rownum b{font-size:32px;font-weight:600}.side{font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#fff;background:var(--rs);padding:5px 11px;border-radius:999px;text-shadow:0 1px 1px rgba(120,120,120,.25)}.side.ws{background:var(--ws)}.side small{display:block;font-size:8px;letter-spacing:.1em;opacity:.9;margin-top:1px}.instr{margin-top:15px;font-size:20px;line-height:1.5;font-weight:500}.note{margin-top:11px;font-size:12px;line-height:1.5;color:var(--ink-soft);background:#fdf3f8;border-radius:12px;padding:9px 11px;border:1px dashed var(--line)}.note b{color:#d98aa9}.preview{text-align:center;font-size:12px;color:var(--ink-soft);background:#ffffff8c;border-radius:14px;padding:8px 12px;border:1px solid var(--line);margin-bottom:12px}.preview b{color:var(--ink)}.nav{display:flex;gap:11px}.btn-next{flex:1;color:#5a4a55;font-size:17px;padding:18px 14px;font-weight:700;border:none;border-radius:18px;cursor:pointer;background:linear-gradient(100deg,#f8c6d8,#f9d6b6,#f3e6ad,#aee3c8,#aed7f2,#c7cbf3,#e0c8f0);box-shadow:0 12px 26px -14px #bea0c8cc}.btn-next .s{display:block;font-size:11px;font-weight:600;opacity:.62;margin-top:3px}.btn-back{background:var(--card);color:var(--ink-soft);border:1.5px solid var(--line);min-width:66px;font-size:15px;font-weight:600;border-radius:18px;cursor:pointer}.btn-back:disabled{opacity:.4}.hello-eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#b08aa0;font-weight:600;margin:6px 2px 2px}.hello-title{font-family:Fraunces,serif;font-size:30px;font-weight:500;margin:0 2px 16px;line-height:1.1;color:var(--ink)}.spotlight{background:var(--card);border:1px solid var(--line);border-left:6px solid var(--accent);border-radius:20px;padding:16px 17px 17px;box-shadow:0 12px 30px -18px var(--shadow);margin-bottom:18px}.spotlight-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#b08aa0;font-weight:600}.spotlight-name{font-family:Fraunces,serif;font-size:23px;font-weight:500;margin:4px 0 2px;line-height:1.1}.spotlight-sub{font-size:12.5px;color:var(--ink-soft)}.spotlight-bar{margin-top:11px;height:7px;border-radius:50px;background:#f3ecef;overflow:hidden}.spotlight-bar>div{height:7px;border-radius:50px;background:var(--accent);transition:width .3s}.spotlight-empty{border-left-color:var(--mint);text-align:center}.home-links{display:flex;flex-direction:column;gap:10px}.home-link{display:flex;align-items:center;gap:13px;width:100%;text-align:left;cursor:pointer;background:var(--card);border:1px solid var(--line);border-left:6px solid var(--accent);border-radius:16px;padding:13px 15px;font-family:Comfortaa,sans-serif;box-shadow:0 8px 24px -20px var(--shadow);transition:transform .08s}.home-link:active{transform:scale(.99)}.home-link .hl-ic{font-size:22px;line-height:1}.home-link b{display:block;font-family:Fraunces,serif;font-size:16px;font-weight:500;color:var(--ink)}.home-link small{display:block;font-size:11px;color:var(--ink-soft);margin-top:2px}.hamburger,.night-toggle{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 6px;line-height:1;color:var(--ink)}.hamburger{font-size:22px}.topbar-left{display:flex;align-items:center;gap:2px}.home-arrow{background:none;border:1.5px solid var(--line);border-radius:50px;cursor:pointer;font-size:14px;line-height:1;color:var(--ink);padding:5px 11px 5px 8px;font-family:Comfortaa,sans-serif}.home-arrow:active{background:var(--line)}html.night .home-arrow{color:var(--ink);border-color:#ffffff24}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 6px}.topbar .brand{flex:1;text-align:center}.menu-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#6e5a6e6b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:80;display:flex;justify-content:flex-start}.menu-panel{width:78%;max-width:300px;height:100%;background:var(--card);box-shadow:6px 0 30px -10px var(--shadow);padding:16px 14px;display:flex;flex-direction:column;animation:slidein .18s ease-out}@keyframes slidein{0%{transform:translate(-100%)}to{transform:translate(0)}}.menu-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding:0 4px}.menu-close{background:none;border:none;font-size:24px;color:var(--ink-soft);cursor:pointer;line-height:1}.menu-item{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:Comfortaa,sans-serif;font-size:16px;font-weight:600;color:var(--ink);padding:13px 12px;border-radius:13px}.menu-item.active{background:#fbeaf0;color:#993556}.menu-item .mi-ic{font-size:20px}.menu-divider{height:1px;background:var(--line);margin:8px 6px}.celebrate-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#6e5a6e80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:120;display:flex;align-items:center;justify-content:center;padding:24px}.celebrate-card{background:var(--card);border-radius:24px;padding:28px 22px;text-align:center;max-width:340px;width:100%;box-shadow:0 20px 50px -16px var(--shadow);animation:pop .3s ease-out}@keyframes pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.celebrate-emoji{font-size:54px;line-height:1;margin-bottom:8px}.celebrate-title{font-family:Fraunces,serif;font-size:26px;font-weight:500;color:var(--ink)}.celebrate-name{font-family:Fraunces,serif;font-size:18px;font-style:italic;color:var(--terra,#a8674d);margin-top:4px}html.night{--card:#2e2833;--ink:#f3e9ef;--ink-soft:#a89aa0;--line:#3f3845;--shadow:rgba(0,0,0,.5)}html.night body{background-color:#241f29;background-image:radial-gradient(circle at 25% 25%,rgba(201,122,150,.2) 0 7px,transparent 8px),radial-gradient(circle at 75% 35%,rgba(122,160,200,.18) 0 4px,transparent 5px),radial-gradient(circle at 50% 60%,rgba(200,185,120,.2) 0 7px,transparent 8px),radial-gradient(circle at 88% 80%,rgba(120,180,150,.18) 0 4px,transparent 5px),radial-gradient(circle at 15% 80%,rgba(170,150,200,.2) 0 4px,transparent 5px),radial-gradient(circle at 62% 10%,rgba(200,165,130,.18) 0 4px,transparent 5px);background-size:120px 120px}html.night .brand{background:linear-gradient(90deg,#e89bb4,#e0b896,#d8cf8c,#9fc9b0,#8cb9e6,#a9a4ea,#cf9ee0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}html.night .hamburger,html.night .night-toggle{color:var(--ink)}html.night input,html.night select,html.night textarea{background:#241f29;color:var(--ink);border-color:var(--line)}html.night .menu-item.active{background:#7a3a52;color:#fbe0ea}html.night .note{background:#3a2e38}html.night .spotlight-bar,html.night .dot{background:#3f3845}html.night .preview,html.night .caston{filter:saturate(.85)}html.night .hello-eyebrow,html.night .spotlight-label{color:#c98aa6}html.night .home-link small,html.night .item .sub{color:var(--ink-soft)}html.night .sizeopt,html.night .seqitem{background:#241f29}html.night .btn-soft{background:#2e2833;color:var(--ink-soft)}.proj-thumb{width:42px;height:42px;border-radius:10px;object-fit:cover;flex:none;border:1px solid rgba(0,0,0,.06)}.icon-btn{background:none;border:none;font-size:20px;color:var(--ink-soft);cursor:pointer;line-height:1;padding:2px 6px}html.night .proj-thumb{border-color:#ffffff14}.special-banner{background:linear-gradient(100deg,#f8c6d8,#f9d6b6,#e0c8f0);border-radius:14px;padding:11px 14px;text-align:center;font-size:13.5px;font-weight:600;color:#7a4a60;margin-bottom:12px;cursor:pointer}.streak-row{display:flex;gap:9px;margin-bottom:14px;flex-wrap:wrap}.streak-pill{flex:1;min-width:130px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 12px;font-size:12.5px;color:var(--ink-soft);text-align:center}.streak-pill b{font-family:Fraunces,serif;font-size:18px;color:var(--ink);font-weight:600}.theme-pick{display:flex;align-items:center;gap:9px;text-align:left;cursor:pointer;background:var(--card);border:1.5px solid var(--line);border-radius:13px;padding:11px 12px;font-family:Comfortaa,sans-serif}.theme-pick.on{border-color:#d98aa9;background:#fceff7}.theme-pick b{display:block;font-size:13px;color:var(--ink);font-weight:600}.theme-pick small{display:block;font-size:10px;color:var(--ink-soft);margin-top:1px}html.night .theme-pick.on{background:#3a2e38;border-color:#c97a96}.share-card{position:relative;background:#fff;border-radius:20px;padding:22px 20px 18px;text-align:center;border:1px solid var(--line);overflow:hidden;margin-bottom:14px;background-image:radial-gradient(circle at 20% 18%,rgba(246,184,205,.4) 0 6px,transparent 7px),radial-gradient(circle at 80% 30%,rgba(168,212,240,.38) 0 5px,transparent 6px),radial-gradient(circle at 60% 82%,rgba(220,193,238,.4) 0 5px,transparent 6px),radial-gradient(circle at 12% 78%,rgba(169,224,192,.38) 0 5px,transparent 6px);background-size:130px 130px}.share-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:7px;background:var(--accent)}.share-photo{width:100%;max-height:220px;object-fit:cover;border-radius:14px;margin-bottom:14px}.share-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#b08aa0;font-weight:600}.share-name{font-family:Fraunces,serif;font-size:24px;font-weight:500;color:#5a4a55;margin:4px 0;line-height:1.1}.share-line{font-size:13px;color:#9a8a96}.share-bar{margin:12px auto 0;height:9px;width:80%;border-radius:50px;background:#f3ecef;overflow:hidden}.share-bar>div{height:9px;border-radius:50px;background:var(--accent)}.share-foot{margin-top:14px;font-family:Fraunces,serif;font-style:italic;font-size:14px;color:#c9a0bc}.stitchcount{margin-top:11px;font-size:12.5px;color:var(--ink-soft);background:#f1ecf4;border-radius:10px;padding:8px 11px;text-align:center}.stitchcount b{color:#8a6a82;font-weight:700}html.night .stitchcount{background:#322a39}.focus-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;cursor:pointer;border-top:8px solid var(--accent)}.focus-head{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;cursor:default}.focus-exit{background:none;border:1.5px solid var(--line);border-radius:50px;padding:8px 16px;font-family:Comfortaa,sans-serif;font-size:14px;font-weight:600;color:var(--ink-soft);cursor:pointer}.focus-meta{font-size:13px;color:var(--ink-soft);font-weight:600}.focus-rownum{font-family:Fraunces,serif;font-size:22px;color:var(--accent);font-weight:600;margin-bottom:18px}.focus-instr{font-size:min(13vw,52px);line-height:1.3;font-weight:500;text-align:center;color:var(--ink);max-width:760px;font-family:Comfortaa,sans-serif}.focus-note{margin-top:22px;font-size:15px;color:var(--ink-soft);background:var(--line);border-radius:12px;padding:12px 16px;max-width:600px;text-align:center}.focus-hint{position:absolute;bottom:104px;font-size:13px;color:var(--ink-soft);opacity:.7;letter-spacing:.05em}.focus-controls{position:absolute;bottom:24px;left:24px;right:24px;display:flex;gap:12px;cursor:default;max-width:600px;margin:0 auto}.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (min-width:760px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}.trophy{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;cursor:pointer;box-shadow:0 8px 24px -20px var(--shadow);transition:transform .08s;border-top:5px solid var(--accent)}.trophy:active{transform:scale(.98)}.trophy-img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.trophy-noimg{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:40px;background:#faf3f8}html.night .trophy-noimg{background:#2a2430}.trophy-cap{padding:10px 11px 12px}.trophy-name{font-family:Fraunces,serif;font-size:15px;font-weight:500;color:var(--ink);line-height:1.15}.trophy-date{font-size:11px;color:var(--ink-soft);margin-top:3px}.zoom-card{background:var(--card);border-radius:22px;padding:16px;max-width:460px;width:100%;text-align:center;box-shadow:0 20px 50px -16px var(--shadow)}.zoom-card img{width:100%;border-radius:16px;display:block}
