:root{--pink: #ffb7d5;--pink-deep: #ff7ab0;--mint: #b9f1d8;--mint-deep: #5fd6a8;--lavender: #d8c8ff;--lavender-deep: #a98cff;--cream: #fff7e6;--butter: #ffe79a;--sky: #c5e8ff;--ink: #3d2b56;--ink-soft: #6b5d80;--shadow: 0 8px 24px rgba(125, 90, 170, .18);--shadow-soft: 0 3px 10px rgba(125, 90, 170, .12);--radius: 18px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Fredoka,system-ui,-apple-system,sans-serif;color:var(--ink);background:radial-gradient(circle at 20% 10%,#ffe2f0 0%,transparent 50%),radial-gradient(circle at 80% 20%,#e5d8ff 0%,transparent 45%),radial-gradient(circle at 50% 90%,#d5f5e8 0%,transparent 50%),linear-gradient(180deg,#fff7e6,#ffeaf5);overflow:hidden;-webkit-font-smoothing:antialiased}button{font-family:inherit;font-weight:600;cursor:pointer;border:none;border-radius:999px;padding:10px 18px;background:var(--pink-deep);color:#fff;box-shadow:var(--shadow-soft);transition:transform .12s ease,box-shadow .12s ease,background .12s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.55;cursor:not-allowed}button.ghost{background:#fff;color:var(--ink)}button.mint{background:var(--mint-deep)}button.lav{background:var(--lavender-deep)}input{font-family:inherit;font-size:16px;padding:12px 16px;border:2px solid #f0d9ec;border-radius:14px;background:#fff;color:var(--ink);outline:none;transition:border-color .15s ease,box-shadow .15s ease}input:focus{border-color:var(--pink-deep);box-shadow:0 0 0 4px #ff7ab026}#root{position:relative}#canvas-host{position:absolute;inset:0;z-index:0}canvas{outline:none;display:block;width:100%;height:100%;touch-action:none}.overlay{position:absolute;inset:0;z-index:1;pointer-events:none}.overlay>*{pointer-events:auto}.login-wrap{position:absolute;inset:0;display:grid;place-items:center;background:#fff7e6bf;backdrop-filter:blur(8px)}.login-card{width:min(420px,92vw);background:#fff;border-radius:var(--radius);padding:28px 28px 24px;box-shadow:var(--shadow);text-align:center;animation:pop .45s cubic-bezier(.2,.9,.3,1.4)}.login-card h1{margin:0 0 4px;font-family:Nunito,sans-serif;font-weight:800;font-size:28px;letter-spacing:-.5px}.login-card .sub{margin:0 0 18px;color:var(--ink-soft);font-size:14px}.login-card .logo{font-size:56px;display:block;margin-bottom:4px;animation:bounce 2.2s ease-in-out infinite}.login-row{display:flex;gap:8px;flex-direction:column}.login-row input{width:100%}.login-err{color:#d24a7a;font-size:13px;margin-top:8px;min-height:18px}.login-foot{margin-top:14px;font-size:12px;color:var(--ink-soft)}.hud-top{position:absolute;top:14px;left:14px;right:14px;display:flex;align-items:center;gap:12px;justify-content:space-between}.brand{display:flex;align-items:center;gap:10px;background:#fff;padding:8px 14px;border-radius:999px;box-shadow:var(--shadow-soft)}.brand .emoji{font-size:22px}.brand .title{font-weight:700}.brand .sub{color:var(--ink-soft);font-size:12px}.me{display:flex;align-items:center;gap:10px;background:#fff;padding:6px 14px 6px 6px;border-radius:999px;box-shadow:var(--shadow-soft)}.me .av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px}.me .info{line-height:1.1}.me .name{font-weight:700;font-size:14px}.me .pts{color:var(--ink-soft);font-size:12px}.chore-panel{position:absolute;right:14px;top:70px;bottom:14px;width:min(360px,88vw);background:#ffffffeb;backdrop-filter:blur(10px);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.chore-panel header{padding:16px 18px 8px;display:flex;align-items:baseline;justify-content:space-between}.chore-panel h2{margin:0;font-family:Nunito,sans-serif;font-weight:800;font-size:20px}.chore-panel .count{color:var(--ink-soft);font-size:13px}.chore-list{flex:1;overflow-y:auto;padding:6px 12px 14px;display:flex;flex-direction:column;gap:8px}.chore-list::-webkit-scrollbar{width:8px}.chore-list::-webkit-scrollbar-thumb{background:#f1d9ea;border-radius:4px}.chore{background:#fff;border-radius:14px;padding:12px 14px;box-shadow:var(--shadow-soft);border:2px solid transparent;transition:border-color .15s ease,transform .12s ease;display:flex;flex-direction:column;gap:8px}.chore.mine{border-color:var(--mint-deep);background:linear-gradient(180deg,#f5fff9,#fff)}.chore.taken{opacity:.78}.chore.done{opacity:.5;background:#f7f5fb}.chore .top{display:flex;align-items:center;gap:10px}.chore .ico{font-size:26px}.chore .title{font-weight:700;flex:1;font-size:15px;line-height:1.2}.chore .pts{color:var(--pink-deep);font-weight:700;font-size:13px}.chore .desc{color:var(--ink-soft);font-size:13px;line-height:1.35}.chore .row{display:flex;gap:6px;align-items:center}.chore .who{font-size:12px;color:var(--ink-soft);flex:1}.chore button{padding:6px 12px;font-size:13px}.toast-stack{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;align-items:center;z-index:5;pointer-events:none}.toast{background:#fff;padding:10px 18px;border-radius:999px;box-shadow:var(--shadow);font-weight:600;font-size:14px;display:flex;align-items:center;gap:10px;animation:rise .4s cubic-bezier(.2,.9,.3,1.4)}.toast.reward{background:linear-gradient(120deg,#fff7e6,#ffe2f0);font-size:16px;padding:14px 22px}.toast .emoji{font-size:22px}.ach-btn{position:absolute;bottom:18px;left:18px;background:#fff;color:var(--ink);display:flex;align-items:center;gap:8px}.ach-modal{position:absolute;inset:0;background:#3d2b5673;display:grid;place-items:center;z-index:6}.ach-card{background:#fff;border-radius:var(--radius);width:min(560px,92vw);max-height:80vh;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;animation:pop .35s cubic-bezier(.2,.9,.3,1.4)}.ach-card header{padding:18px 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f3e7f0}.ach-card h2{margin:0;font-family:Nunito,sans-serif;font-weight:800}.ach-grid{padding:16px 18px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.ach{background:#fff7e6;border-radius:14px;padding:12px;display:flex;gap:10px;align-items:center}.ach.locked{opacity:.45;background:#f4f0fa}.ach .ico{font-size:28px}.ach .name{font-weight:700;font-size:14px}.ach .desc{color:var(--ink-soft);font-size:12px}.lb{position:absolute;bottom:18px;right:14px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:10px 14px;display:flex;gap:12px;align-items:center}.lb .row{display:flex;align-items:center;gap:6px;font-size:13px}.lb .av{width:22px;height:22px;border-radius:50%;color:#fff;font-weight:800;font-size:11px;display:grid;place-items:center}@keyframes pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}@keyframes rise{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:720px){.chore-panel{width:calc(100vw - 28px);top:70px;bottom:70px}.lb{display:none}}
