:root{--pink:#ff7ab8;--pink-deep:#ff4f9a;--pink-soft:#ffd9ec;--lilac:#c79bff;--purple:#9b6cff;--mint:#7ce6c4;--sky:#7ec8ff;--peach:#ffb38a;--lemon:#ffe27a;--ink:#7a4a64;--ink-strong:#4a2740;--ink-soft:#b98aa6;--card:#fff;--card-2:#fff4fa;--radius-lg:30px;--radius-md:22px;--radius-sm:14px;--pill:999px;--shadow-sm:0 6px 16px #ff4f9a29;--shadow-md:0 14px 30px #ff4f9a38;--shadow-lg:0 22px 48px #ff4f9a47;--font:"Segoe UI Rounded", "SF Pro Rounded", "Nunito", "Quicksand", ui-rounded, system-ui, "Segoe UI", Roboto, sans-serif;font-family:var(--font);color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:18px;line-height:1.45}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background-color:#0000;background-image:radial-gradient(1200px 600px at 15% -10%,#fff0f8 0%,#0000 60%),radial-gradient(1000px 700px at 110% 10%,#efe2ff 0%,#0000 55%),linear-gradient(160deg,#ffe7f4 0%,#fbe9ff 45%,#e8f3ff 100%);background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;overflow-x:hidden}#root{flex-direction:column;width:100%;display:flex}.route{flex-direction:column;flex:1;min-height:100%;display:flex}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}button:focus-visible{outline:3px solid var(--purple);outline-offset:2px}.sparkle-layer{pointer-events:none;z-index:0;position:fixed;inset:0}.float-sparkle{filter:drop-shadow(0 4px 6px #ff4f9a40);-webkit-user-select:none;user-select:none;position:absolute}.screen.home{z-index:1;flex-direction:column;flex:1;align-items:center;padding:clamp(20px,4vw,48px);display:flex;position:relative}.home-header{text-align:center;margin-bottom:clamp(20px,4vw,40px)}.home-title{letter-spacing:-1.5px;background:linear-gradient(100deg, var(--pink-deep), var(--purple) 60%, var(--sky));color:#0000;text-shadow:0 6px 18px #ff4f9a2e;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(38px,8vw,76px);font-weight:900}.home-sub{color:var(--ink);margin:6px 0 18px;font-size:clamp(16px,2.6vw,24px);font-weight:700}.progress-pill{background:var(--card);color:var(--pink-deep);border-radius:var(--pill);box-shadow:var(--shadow-sm);align-items:center;gap:10px;padding:10px 22px;font-weight:800;display:inline-flex}.progress-stars{letter-spacing:3px;font-size:18px}.card-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(16px,2.5vw,28px);width:100%;max-width:1100px;display:grid}.pattern-card{text-align:center;background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:3px solid #0000;flex-direction:column;align-items:center;gap:10px;min-height:230px;padding:26px 20px 28px;transition:border-color .2s,box-shadow .2s;display:flex;position:relative}.pattern-card:not(.is-locked):hover{border-color:var(--pink);box-shadow:var(--shadow-lg)}.pattern-card.is-locked{cursor:not-allowed;box-shadow:var(--shadow-sm);opacity:.85;background:#f4ecf3}.pattern-card.is-done{border-color:var(--mint)}.card-emoji{filter:drop-shadow(0 6px 8px #ff4f9a40);font-size:58px;line-height:1}.card-name{color:var(--ink-strong);font-size:24px;font-weight:900}.card-blurb{color:var(--ink-soft);font-size:15px;font-weight:600;line-height:1.35}.done-tick{background:linear-gradient(140deg, var(--mint), var(--sky));color:#fff;width:42px;height:42px;box-shadow:var(--shadow-sm);border-radius:50%;place-items:center;font-size:22px;font-weight:900;display:grid;position:absolute;top:-12px;right:-12px}.reset-btn{border-radius:var(--pill);color:var(--ink-soft);box-shadow:var(--shadow-sm);background:#fff;margin-top:30px;padding:12px 26px;font-weight:800}.reset-btn:hover{color:var(--pink-deep)}.badge{border-radius:var(--pill);color:#fff;white-space:nowrap;align-items:center;gap:8px;padding:6px 14px;font-size:13px;font-weight:800;display:inline-flex}.badge-stars{letter-spacing:1px}.badge-d1{background:linear-gradient(120deg, var(--mint), #5fcf9e)}.badge-d2{background:linear-gradient(120deg, var(--sky), #5aa9f0)}.badge-d3{background:linear-gradient(120deg, var(--lilac), var(--purple))}.badge-d4{background:linear-gradient(120deg, var(--pink), var(--pink-deep))}.screen.tutorial{z-index:1;flex-direction:column;flex:1;height:100%;display:flex;position:relative}.tutorial-topbar{flex-wrap:wrap;align-items:center;gap:16px;padding:14px clamp(14px,3vw,28px);display:flex}.home-btn{border-radius:var(--pill);color:var(--pink-deep);box-shadow:var(--shadow-sm);background:#fff;flex-shrink:0;padding:12px 22px;font-size:16px;font-weight:800}.home-btn:hover{background:var(--pink-soft)}.tutorial-title{color:var(--ink-strong);align-items:center;gap:12px;font-size:clamp(20px,3vw,30px);font-weight:900;display:flex}.t-emoji{font-size:1.3em}.stage{border-radius:var(--radius-lg);min-height:280px;box-shadow:var(--shadow-md);background:linear-gradient(#fff7fc,#fdeff8);flex:1;margin:0 clamp(10px,2vw,22px);position:relative;overflow:hidden}.stage canvas{touch-action:none;display:block}.stage-loading{color:var(--pink-deep);place-items:center;font-size:22px;font-weight:800;display:grid;position:absolute;inset:0}.instruction-row{justify-content:center;padding:4px clamp(12px,3vw,28px) 8px;display:flex}.instruction-row .instruction{width:min(94%,680px)}.instruction{flex-direction:column;align-items:center;gap:8px;display:flex}.step-counter{background:var(--purple);color:#fff;border-radius:var(--pill);box-shadow:var(--shadow-sm);padding:5px 16px;font-size:13px;font-weight:800}.bubble{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-md);box-shadow:var(--shadow-md);text-align:center;border:2px solid var(--pink-soft);background:#fffffff2;padding:16px 22px}.bubble-text{color:var(--ink-strong);font-size:clamp(16px,2.4vw,22px);font-weight:800}.bubble-tip{color:var(--pink-deep);margin-top:8px;font-size:14px;font-weight:700}.tutorial-bottom{flex-direction:column;align-items:center;gap:14px;padding:14px clamp(12px,3vw,28px) clamp(16px,3vw,26px);display:flex}.progress-track{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.pip{width:16px;height:16px;box-shadow:inset 0 0 0 2px var(--pink-soft);background:#fff;border-radius:50%;transition:transform .15s,background .2s}.pip.on{background:var(--pink);box-shadow:inset 0 0 0 2px var(--pink)}.pip.current{background:var(--pink-deep);box-shadow:inset 0 0 0 2px var(--pink-deep), 0 0 0 3px #ff4f9a40;transform:scale(1.4)}.controls{flex-wrap:wrap;justify-content:center;gap:clamp(10px,2vw,18px);display:flex}.ctrl{border-radius:var(--pill);color:#fff;min-width:120px;min-height:58px;box-shadow:var(--shadow-md);padding:0 26px;font-size:19px;font-weight:900;transition:transform .12s,filter .2s}.ctrl:hover{filter:brightness(1.05)}.ctrl:active{transform:translateY(2px)scale(.98)}.ctrl:disabled{opacity:.4;cursor:not-allowed;box-shadow:var(--shadow-sm)}.ctrl-back{background:linear-gradient(120deg, #d7c4ec, var(--lilac))}.ctrl-play{background:linear-gradient(120deg, var(--sky), var(--purple))}.ctrl-next{background:linear-gradient(120deg, var(--pink), var(--pink-deep))}.ctrl-finish{background:linear-gradient(120deg, var(--mint), var(--sky))}.bracelet{flex-direction:column;align-items:center;gap:6px;width:100%;display:flex}.bracelet-label{color:var(--pink-deep);font-size:14px;font-weight:800}.bracelet-track{border-radius:var(--pill);width:min(94%,780px);min-height:56px;box-shadow:var(--shadow-sm);background:#fffc;justify-content:center;align-items:center;gap:0;padding:8px 16px;display:flex;overflow-x:auto}.bracelet-empty{color:var(--ink-soft);font-size:14px;font-weight:700}.bracelet-links{align-items:center;display:flex}.bracelet-link{border:3px solid #fff;border-radius:50%;flex:none;place-items:center;width:40px;height:28px;margin-left:-10px;display:grid;position:relative;box-shadow:0 3px 6px #00000029,inset 0 -3px 5px #0000001f}.bracelet-link:first-child{margin-left:0}.bracelet-link:nth-child(2n){transform:translateY(7px)}.bracelet-link.is-locked{box-shadow:0 3px 6px #00000029,inset 0 0 0 3px #ffffffbf}.link-sparkle{font-size:11px;line-height:1}.clasp{background:linear-gradient(140deg, var(--lemon), var(--peach));z-index:1;border-radius:50%;flex:none;width:14px;height:14px;box-shadow:0 2px 4px #00000038}.color-picker{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:#ffffffb3;flex-wrap:wrap;justify-content:center;gap:14px 28px;padding:12px 20px;display:flex}.color-slot{flex-direction:column;align-items:center;gap:6px;display:flex}.slot-label{color:var(--ink-soft);font-size:13px;font-weight:800}.swatches{flex-wrap:wrap;justify-content:center;gap:8px;max-width:360px;display:flex}.swatch{border:3px solid #fff;border-radius:50%;width:38px;height:38px;transition:transform .12s,box-shadow .2s;box-shadow:0 3px 8px #0000001f,inset 0 -3px 6px #0000001f}.swatch:hover{transform:scale(1.12)}.swatch.is-active{box-shadow:0 0 0 3px var(--pink-deep), 0 3px 8px #0000002e;border-color:#fff;transform:scale(1.18)}@media (width<=760px){:root{font-size:16px}.ctrl{min-width:96px;min-height:54px;padding:0 16px;font-size:17px}.card-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.pattern-card{min-height:200px;padding:20px 14px 22px}.card-emoji{font-size:46px}}@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
