*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}html,body,#root{width:100%;height:100%;overflow:hidden}@media (max-width: 768px){html{height:auto;overflow-y:auto}body{height:auto;min-height:100dvh;overflow-x:hidden;overflow-y:auto}#root{height:auto;min-height:100dvh;overflow:visible}}body{font-family:"Baloo 2",Nunito,Poppins,sans-serif;background:#bae6fd;color:#0f172a}.app{width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden;position:relative;background:linear-gradient(160deg,#0ea5e9,#38bdf8 30%,#bae6fd,#e0f2fe)}.clouds-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.cloud{position:absolute;animation:cloudDrift linear infinite alternate}.cloud-blob{position:absolute;background:#ffffffe0;border-radius:50%;width:90px;height:55px}.cloud-blob-2{width:65px;height:45px;left:45px;top:-12px;background:#ffffffd9}.cloud-blob-3{width:55px;height:38px;left:22px;top:8px;background:#ffffffd1}@keyframes cloudDrift{0%{transform:translate(0)}to{transform:translate(36px)}}.sparkles-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.sparkle{position:absolute;color:#fbbf24;animation:sparklePulse ease-in-out infinite}@keyframes sparklePulse{0%,to{opacity:.3;transform:scale(.8) rotate(0)}50%{opacity:.7;transform:scale(1.2) rotate(15deg)}}.home-screen{width:100%;height:100%;display:flex;flex-direction:column;position:relative;z-index:1}.home-header{height:110px;flex-shrink:0;display:flex;align-items:center;gap:24px;padding:16px 40px 0;background:#0284c78c;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.25)}.header-left{flex:0 0 auto;min-width:280px}.home-title{font-size:52px;font-weight:800;color:#fff;line-height:1.1;text-shadow:0 1px 0 rgba(0,0,0,.3),0 3px 12px rgba(0,0,0,.3)}.home-date{font-size:24px;font-weight:600;color:#fffffff2;margin-top:2px;text-shadow:0 1px 6px rgba(0,0,0,.25)}.header-center{flex:1;display:flex;justify-content:center}.family-progress-bar{width:400px;height:56px;border-radius:28px;background:#ffffff40;border:2px solid rgba(255,255,255,.5);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #00000014}.family-progress-fill{position:absolute;left:4px;top:4px;bottom:4px;border-radius:24px;background:linear-gradient(90deg,#f97316,#eab308,#22c55e);transition:width .7s cubic-bezier(.34,1.56,.64,1);min-width:0}.family-progress-text{position:relative;z-index:1;font-size:23px;font-weight:700;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.4)}.header-right{flex:0 0 auto;display:flex;align-items:center;gap:12px}.header-badge{display:flex;align-items:center;gap:10px;background:#ffffff40;border:2px solid rgba(255,255,255,.5);border-radius:24px;padding:10px 20px;height:80px;box-shadow:0 2px 12px #00000014}.badge-icon{font-size:36px;line-height:1}.badge-info{display:flex;flex-direction:column;align-items:flex-start}.badge-number{font-size:34px;font-weight:800;color:#fff;line-height:1;text-shadow:0 1px 6px rgba(0,0,0,.35)}.badge-label{font-size:17px;color:#fffffff2;font-weight:600;line-height:1.2;text-shadow:0 1px 4px rgba(0,0,0,.25)}.parent-btn{background:#ffffff40;border:2px solid rgba(255,255,255,.5);border-radius:24px;width:80px;height:80px;font-size:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s;flex-shrink:0}.parent-btn:active{transform:scale(.9);background:#fff6}.home-body{flex:1;display:flex;gap:20px;padding:16px 40px 32px;overflow:hidden;min-height:0}.kids-panel{flex:1;min-width:0;overflow:visible;position:relative}.kids-panel-inner{display:flex;flex-direction:column;height:100%;gap:0;position:relative}.kids-row{display:flex;gap:16px;flex:1;min-height:0}.mobile-kids{display:none}@keyframes slideInFromLeft{0%{transform:translate(-60px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromRight{0%{transform:translate(60px);opacity:0}to{transform:translate(0);opacity:1}}.kids-row.slide-in-left{animation:slideInFromLeft .3s cubic-bezier(.34,1.56,.64,1)}.kids-row.slide-in-right{animation:slideInFromRight .3s cubic-bezier(.34,1.56,.64,1)}.kids-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:72px;height:72px;border-radius:50%;border:none;background:#0369a1;color:#fff;font-size:44px;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px #01558a,0 8px 24px #0369a173;transition:transform .1s,box-shadow .1s;font-family:inherit;z-index:10}.kids-nav-prev{left:-36px}.kids-nav-next{right:-36px}.kids-nav-btn:active{transform:translateY(calc(-50% + 5px));box-shadow:0 1px #01558a,0 3px 12px #0369a14d}.kids-nav-btn:disabled{opacity:0;pointer-events:none}.kids-nav-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:10px;align-items:center;z-index:10}.kids-nav-dot{width:14px;height:14px;border-radius:50%;border:none;background:#ffffff80;cursor:pointer;transition:background .2s,transform .2s;padding:0}.kids-nav-dot.active{background:#fff;transform:scale(1.4);box-shadow:0 2px 6px #00000040}.kid-card{flex:1;min-width:0;border-radius:28px;border:none;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px #0000002e,0 12px 32px #00000026;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s;position:relative;background:#fff}.kid-card:active{transform:translateY(3px);box-shadow:0 4px #0000002e,0 6px 20px #0000001f}.kid-card.all-done{box-shadow:0 8px #16a34a80,0 12px 32px #22c55e33}.kid-card-top{display:flex;flex-direction:column;align-items:center;padding:16px 16px 14px;cursor:pointer;flex-shrink:0;position:relative;overflow:hidden}.kid-card-top:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffff2e,#fff0 60%);pointer-events:none}.kid-card-top:active{filter:brightness(.95)}.kid-crown{font-size:30px;margin-bottom:-6px;animation:crownFloat 2s ease-in-out infinite;filter:drop-shadow(0 2px 6px rgba(251,191,36,.7));z-index:1}@keyframes crownFloat{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-5px) rotate(5deg)}}.kid-ring-wrap{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kid-avatar-circle{border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;background:#ffffff40!important;box-shadow:0 4px 16px #0003,inset 0 1px #fff6}.kid-avatar-emoji{font-size:40px;line-height:1}.kid-card-name{font-size:30px;font-weight:800;color:#fff;text-align:center;margin-top:8px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.kid-card-stars{font-size:19px;font-weight:700;margin-top:3px;text-align:center;color:#ffffffe6}.kid-card-progress-label{font-size:15px;font-weight:600;color:#ffffffbf;text-align:center;margin-top:2px}.kid-card-chores-wrap{flex:1;min-height:0;position:relative;display:flex;flex-direction:column;background:#fff}.chores-scroll-btns{display:flex;flex-direction:row;gap:8px;justify-content:center;align-items:center;padding:8px 10px;border-top:1px solid #f1f5f9;background:#fafafa;flex-shrink:0;border-radius:0 0 28px 28px}.chores-scroll-btn{flex:1;height:44px;border-radius:12px;border:none;background:var(--scroll-color, #3b82f6);color:#fff;font-size:20px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px #0000002e;transition:transform .1s,box-shadow .1s;font-family:inherit;line-height:1}.chores-scroll-btn:active{transform:translateY(3px);box-shadow:0 1px #0000002e}.chores-scroll-btn:disabled{opacity:.2;cursor:default;box-shadow:none;transform:none}.chores-scroll-btn.bounce-down{animation:scrollBounceDown 1s ease-in-out infinite}.chores-scroll-btn.bounce-up{animation:scrollBounceUp 1s ease-in-out infinite}@keyframes scrollBounceDown{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}@keyframes scrollBounceUp{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.kid-card-chores{flex:1;min-height:0;overflow-y:scroll;padding:8px 10px 10px;display:flex;flex-direction:column;gap:7px;background:#fff;scrollbar-width:none;-webkit-overflow-scrolling:touch;touch-action:pan-y}.kid-card-chores::-webkit-scrollbar{display:none}.kid-card-empty{text-align:center;color:#94a3b8;font-size:15px;font-weight:600;padding:20px 8px}.mission-card{background:#fff;border:2px solid #e8edf2;border-radius:16px;padding:10px 12px 10px 10px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:transform .1s,box-shadow .1s;min-height:72px;flex-shrink:0;box-shadow:0 4px #d1d9e0}.mission-card:active{transform:translateY(4px);box-shadow:0 1px #d1d9e0}.mission-card.done{background:#f0fdf4;border-color:#86efac;box-shadow:0 5px #6ee7a0}.mission-card.done:active{box-shadow:0 1px #6ee7a0}.mission-card.toggling{opacity:.6}.mission-icon{font-size:30px;line-height:1;flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:14px}.mission-card.done .mission-icon{background:#dcfce7}.mission-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0;overflow:hidden}.mission-text{font-size:22px;font-weight:700;color:#0f172a;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mission-card.done .mission-text{color:#94a3b8;text-decoration:line-through}.mission-sub{font-size:14px;font-weight:600;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mission-sub.done-sub{color:#22c55e;font-weight:700}.mission-check{width:46px;height:46px;border-radius:50%;border:3px solid #d1d9e0;background:#f8fafc;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;flex-shrink:0;color:transparent;transition:background .18s,border-color .18s,color .18s,transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .18s}.mission-card.done .mission-check{background:#22c55e;border-color:#22c55e;color:#fff;transform:scale(1.15);box-shadow:0 3px 10px #22c55e73}.group-panel{width:88px;flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;background:#ffffffe6;border:2px solid #e2e8f0;border-radius:28px;box-shadow:0 4px #d1d9e0,0 6px 24px #00000014;transition:width .35s cubic-bezier(.34,1.2,.64,1)}.group-panel.group-panel-open{width:440px}.group-panel-toggle{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 10px;background:linear-gradient(180deg,#0ea5e924,#0ea5e90f);border:none;cursor:pointer;font-family:inherit;width:100%;flex-shrink:0;transition:background .15s,transform .1s}.group-panel.group-panel-open .group-panel-toggle{flex-direction:row;padding:16px 20px;border-bottom:2px solid rgba(14,165,233,.25);gap:12px}.group-panel-toggle:active{background:#0ea5e942;transform:scale(.98)}.group-panel-toggle-title{font-size:26px;font-weight:800;color:#0f172a;white-space:nowrap;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}.group-panel.group-panel-open .group-panel-toggle-title{writing-mode:horizontal-tb;transform:none;font-size:28px}.group-panel-toggle-right{display:flex;flex-direction:column;align-items:center;gap:8px}.group-panel.group-panel-open .group-panel-toggle-right{flex-direction:row;margin-left:auto;gap:10px}.group-panel-chevron{font-size:22px;font-weight:900;color:#0369a1;background:#0ea5e926;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.group-pending-badge{background:#ef4444;color:#fff;font-size:15px;font-weight:800;border-radius:99px;padding:4px 12px;white-space:nowrap;box-shadow:0 3px #b91c1c;animation:pendingPulse 2s ease-in-out infinite}@keyframes pendingPulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.group-rotate-badge{background:#e0f2fe;color:#0369a1;font-size:13px;font-weight:700;border-radius:99px;padding:2px 10px;white-space:nowrap}.group-all-done-badge{background:#22c55e;color:#fff;font-size:15px;font-weight:800;border-radius:99px;padding:4px 12px;white-space:nowrap;box-shadow:0 3px #16a34a}.group-tap-hint{background:#0000002e;color:#fff;font-size:11px;font-weight:900;letter-spacing:.08em;border-radius:6px;padding:3px 7px;white-space:nowrap;text-transform:uppercase}.group-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#94a3b8;font-size:22px;font-weight:700;text-align:center;border:2px dashed #e2e8f0;border-radius:20px;padding:32px}.group-chore-list{flex:1;overflow-y:scroll;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch;touch-action:pan-y}.group-chore-list::-webkit-scrollbar{width:12px}.group-chore-list::-webkit-scrollbar-track{background:#e2e8f0;border-radius:6px;margin:6px 0}.group-chore-list::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:6px;border:2px solid #e2e8f0;min-height:40px}.group-chore-item{background:#fef3c780;border:2.5px solid #fbbf24;border-radius:20px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;box-shadow:0 2px 8px #0000000a}.group-chore-item.all-done{background:#dcfce7;border-color:#86efac}.group-chore-header{display:flex;align-items:center;gap:10px}.group-chore-icon{font-size:36px;line-height:1;flex-shrink:0}.group-chore-info{flex:1;display:flex;flex-direction:column;gap:3px}.group-chore-text{font-size:24px;font-weight:700;color:#92400e;line-height:1.2}.group-chore-item.all-done .group-chore-text{color:#15803d}.group-chore-rewards{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.group-done-count{font-size:16px;font-weight:700;color:#b45309;background:#fef3c7;border-radius:8px;padding:3px 9px}.chore-points{font-size:17px;font-weight:800;color:#92400e;background:#fef3c7;border:1px solid #fbbf24;border-radius:99px;padding:3px 12px;white-space:nowrap;flex-shrink:0}.chore-dollar{font-size:17px;font-weight:800;color:#15803d;background:#dcfce7;border:1px solid #86efac;border-radius:99px;padding:3px 12px;white-space:nowrap}.kid-complete-row{display:flex;gap:14px;flex-wrap:wrap}.kid-complete-btn{display:flex;flex-direction:column;align-items:center;gap:6px;background:#fff;border:2.5px solid #e2e8f0;border-radius:20px;padding:14px 18px;cursor:pointer;transition:transform .1s,box-shadow .1s,border-color .15s,background .15s;min-width:86px;font-family:inherit;box-shadow:0 5px #d1d9e0}.kid-complete-btn:active{transform:translateY(4px);box-shadow:0 1px #d1d9e0}.kid-complete-btn.done{background:#f0fdf4;border-color:#86efac;box-shadow:0 5px #6ee7a0}.kid-complete-btn.done:active{box-shadow:0 1px #6ee7a0}.kid-complete-btn.loading{opacity:.6}.kid-avatar-wrap{position:relative;width:52px;height:52px;display:flex;align-items:center;justify-content:center}.kid-avatar-emoji{font-size:40px}.kid-done-check{position:absolute;bottom:-2px;right:-4px;background:#22c55e;color:#fff;font-size:13px;font-weight:900;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.kid-name-label{font-size:17px;font-weight:700;color:#0f172a;white-space:nowrap}.kid-screen{width:100%;height:100%;display:flex;flex-direction:column;animation:slideInRight .28s cubic-bezier(.34,1.56,.64,1);position:relative;z-index:1;background:linear-gradient(160deg,#0ea5e9,#38bdf8 30%,#e0f2fe)}@keyframes slideInRight{0%{transform:translate(50px);opacity:0}to{transform:translate(0);opacity:1}}.kid-header{display:flex;align-items:center;gap:20px;padding:16px 48px;background:#fff3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.3);box-shadow:0 2px 16px #00000014}.back-btn{background:#ffffff4d;border:2px solid rgba(255,255,255,.5);border-radius:16px;padding:10px 22px;font-size:19px;font-weight:700;color:#fff;cursor:pointer;display:flex;align-items:center;gap:6px;transition:transform .12s,background .12s;font-family:inherit;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.15)}.back-btn:active{transform:scale(.93);background:#ffffff80}.kid-header-avatar{font-size:52px;line-height:1}.kid-header-info{flex:1}.kid-header-name{font-size:46px;font-weight:800;line-height:1.1;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.15)}.kid-header-progress{font-size:22px;font-weight:600;color:#ffffffd9;margin-top:2px}.kid-header-bar{width:280px;flex-shrink:0}.progress-bar-wrap{width:100%;background:#00000012;border-radius:99px;height:20px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;border-radius:99px;background:var(--kid-color, #3b82f6);transition:width .6s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.progress-bar-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:sweep 2.5s linear infinite}@keyframes sweep{0%{transform:translate(-100%)}to{transform:translate(200%)}}.progress-bar-fill.full{background:linear-gradient(90deg,#f97316,#eab308,#22c55e)}.chore-list{flex:1;overflow-y:scroll;padding:24px 48px 32px;display:flex;flex-direction:column;gap:14px;background:#ffffff1f;-webkit-overflow-scrolling:touch;touch-action:pan-y}.chore-list::-webkit-scrollbar{width:12px}.chore-list::-webkit-scrollbar-track{background:#ffffff40;border-radius:6px;margin:8px 0}.chore-list::-webkit-scrollbar-thumb{background:#ffffffb3;border-radius:6px;min-height:40px}.chore-item{background:#fff;border:none;border-radius:22px;display:flex;align-items:center;min-height:84px;overflow:hidden;box-shadow:0 4px #0000001a,0 6px 20px #00000014;cursor:default;padding:0;transition:transform .12s,box-shadow .12s}.chore-item:active{transform:translateY(2px);box-shadow:0 2px #0000001a,0 3px 12px #00000014}.chore-item.done{background:#f0fdf4;box-shadow:0 4px #22c55e4d,0 6px 20px #22c55e1a}.chore-icon{font-size:30px;line-height:1;flex-shrink:0;width:58px;height:58px;display:inline-flex;align-items:center;justify-content:center;background:#0000000d;border-radius:14px;margin:12px 0 12px 12px}.chore-item.done .chore-icon{background:#22c55e1f}.chore-text{font-size:26px;font-weight:700;color:#0f172a;line-height:1.25}.chore-item.done .chore-text{text-decoration:line-through;color:#94a3b8}.chore-check{width:52px;height:52px;border-radius:50%;border:2.5px solid #cbd5e1;background:#f8fafc;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;color:transparent;transition:background .2s,border-color .2s,transform .25s cubic-bezier(.34,1.56,.64,1),color .2s;margin-right:6px}.chore-item.done .chore-check{background:#22c55e;border-color:#22c55e;color:#fff;transform:scale(1.1);box-shadow:0 0 12px #22c55e59}.chore-item-pop{animation:pop .32s cubic-bezier(.34,1.56,.64,1)}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.06) translateY(-2px)}to{transform:scale(1)}}.all-done-banner{margin:0 48px 16px;background:#22c55e;border:2.5px solid #16a34a;border-radius:20px;padding:18px 32px;display:flex;align-items:center;justify-content:center;gap:16px;animation:bounceIn .45s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px #16a34a,0 8px 24px #22c55e40}@keyframes bounceIn{0%{transform:scale(.5) translateY(20px);opacity:0}70%{transform:scale(1.04)}to{transform:scale(1);opacity:1}}.all-done-text{font-size:38px;font-weight:900;color:#fff;text-align:center;text-shadow:0 2px 0 rgba(0,0,0,.15)}.all-done-emoji{font-size:44px;animation:spin 2.5s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.drag-handle{width:48px;min-width:48px;height:100%;min-height:80px;display:flex;align-items:center;justify-content:center;cursor:grab;color:#fffc;font-size:20px;letter-spacing:-2px;touch-action:none;flex-shrink:0;border-radius:22px 0 0 22px;transition:color .12s,background .12s;background:var(--kid-color, #3b82f6)}.drag-handle:active{cursor:grabbing;color:#fff;filter:brightness(.9)}.chore-item.dragging{opacity:.45;box-shadow:0 8px 24px #0f172a26}.chore-tap-area{flex:1;display:flex;align-items:center;gap:14px;padding:16px 16px 16px 4px;cursor:pointer;background:transparent;border:none;color:inherit;font-family:inherit;text-align:left;min-height:80px;border-radius:0 18px 18px 0;transition:background .12s;width:100%}.chore-tap-area:active{background:#00000008}.chore-text-wrap{flex:1;display:flex;flex-direction:column;gap:4px;align-items:flex-start}.chore-rewards{display:flex;align-items:center;gap:8px;flex-shrink:0}.chore-badge{display:inline-flex;align-items:center;gap:4px;font-size:14px;font-weight:800;border-radius:7px;padding:3px 10px;letter-spacing:.2px;text-transform:uppercase;font-size:12px}.badge-once{background:#f97316;color:#fff;box-shadow:0 2px #c2410c}.badge-bonus{background:#eab308;color:#fff;box-shadow:0 2px #a16207}.badge-group{background:#a855f7;color:#fff;box-shadow:0 2px #7c3aed}.chore-item.chore-once{border-left-color:#f97316}.chore-item.chore-bonus{border-left-color:#eab308}.chore-item.chore-group{border-left-color:#a855f7}.chore-item.done{border-left-color:#22c55e!important}.points-badge{background:#fef9c3;border:1.5px solid #fbbf24;border-radius:99px;padding:4px 14px;font-size:16px;font-weight:800;color:#92400e;white-space:nowrap;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:#fff;border:1.5px solid #e2e8f0;border-radius:28px;padding:40px 48px;width:min(96vw,900px);max-height:90vh;overflow-y:auto;animation:slideUp .28s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px #0f172a26}.modal-box::-webkit-scrollbar{width:6px}.modal-box::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.modal-box::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:32px;font-weight:700;color:#0f172a;margin-bottom:6px}.modal-subtitle{font-size:17px;color:#64748b;margin-bottom:24px}.pin-screen{display:flex;flex-direction:column;align-items:center;gap:24px}.pin-title{font-size:38px;font-weight:700;color:#0f172a;text-align:center}.pin-display{display:flex;gap:16px}.pin-dot{width:20px;height:20px;border-radius:50%;border:2.5px solid #e2e8f0;background:transparent;transition:background .12s,border-color .12s}.pin-dot.filled{background:#0f172a;border-color:#0f172a}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:300px}.pin-btn{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:16px;height:72px;font-size:28px;font-weight:600;color:#0f172a;cursor:pointer;transition:background .12s,transform .1s;font-family:inherit;display:flex;align-items:center;justify-content:center}.pin-btn:active{background:#e2e8f0;transform:scale(.94)}.pin-btn.backspace{font-size:22px}.pin-error{color:#dc2626;font-size:18px;font-weight:700;animation:shake .35s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-8px)}80%{transform:translate(8px)}}.admin-section{margin-bottom:28px}.admin-section-title{font-size:22px;font-weight:700;color:#0f172a;margin-bottom:14px;display:flex;align-items:center;gap:8px}.kids-admin-list{display:flex;flex-direction:column;gap:10px}.kid-admin-row{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:18px;padding:14px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.kid-admin-avatar{font-size:32px;flex-shrink:0}.kid-admin-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.kid-admin-name{font-size:20px;font-weight:700;color:#0f172a}.kid-chore-count{font-size:15px;color:#64748b;font-weight:600}.kid-admin-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.kid-chores-expanded{padding:12px 14px 14px 20px;background:color-mix(in srgb,var(--kid-color) 10%,#f8fafc);border-left:4px solid var(--kid-color);border-radius:0 0 16px 16px;margin-top:-4px}.chore-edit-wrap{padding:4px 0}.kid-chores-expanded .chore-admin-row{border-left:3px solid color-mix(in srgb,var(--kid-color) 40%,#e2e8f0);background:#fff}.btn{border:1.5px solid transparent;border-radius:14px;padding:10px 18px;font-size:16px;font-weight:700;cursor:pointer;transition:transform .12s,opacity .12s;font-family:inherit;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn:active{transform:scale(.94);opacity:.9}.btn-primary{background:#3b82f6;color:#fff;border-color:#2563eb}.btn-success{background:#22c55e;color:#fff;border-color:#16a34a}.btn-danger{background:#fff;color:#dc2626;border-color:#fca5a5}.btn-secondary{background:#f1f5f9;color:#0f172a;border-color:#e2e8f0}.btn-sm{padding:7px 12px;font-size:14px;border-radius:10px}.modal-close-row{display:flex;justify-content:flex-end;gap:12px;margin-top:28px;padding-top:20px;border-top:1.5px solid #e2e8f0}.admin-input{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:14px;padding:11px 16px;font-size:18px;font-weight:600;color:#0f172a;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.admin-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.admin-input::placeholder{color:#cbd5e1}.emoji-picker{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}.emoji-opt{background:#f8fafc;border:1.5px solid transparent;border-radius:12px;width:50px;height:50px;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s,border-color .12s,background .12s}.emoji-opt:active{transform:scale(.88)}.emoji-opt.selected{border-color:#3b82f6;background:#eff6ff}.color-picker{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.color-opt{width:44px;height:44px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .12s,border-color .12s;box-shadow:0 2px 6px #0000001f}.color-opt:active{transform:scale(.88)}.color-opt.selected{border-color:#0f172a;transform:scale(1.18)}.chore-admin-row{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:14px;padding:10px 14px;display:flex;align-items:center;gap:10px;margin-bottom:7px;flex-wrap:wrap}.chore-admin-icon{font-size:26px;flex-shrink:0}.chore-admin-text{flex:1;font-size:17px;font-weight:700;color:#0f172a;min-width:80px}.chore-admin-pts{font-size:14px;color:#92400e;font-weight:800;white-space:nowrap}.chore-admin-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-left:auto}.add-form{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:18px;padding:18px;margin-top:12px;display:flex;flex-direction:column;gap:12px}.form-row{display:flex;gap:12px;align-items:center}.divider{height:1.5px;background:#e2e8f0;margin:18px 0;border-radius:99px}.tab-bar{display:flex;gap:4px;margin-bottom:22px;background:#f1f5f9;border-radius:18px;padding:5px}.tab-btn{flex:1;background:transparent;border:none;border-radius:14px;padding:11px 14px;font-size:16px;font-weight:700;color:#64748b;cursor:pointer;transition:background .15s,color .15s;font-family:inherit;text-align:center}.tab-btn.active{background:#fff;color:#0f172a;box-shadow:0 1px 4px #0f172a14}.no-kids-msg{text-align:center;padding:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%}.type-selector{display:flex;gap:8px;flex-wrap:wrap}.type-btn{background:#f1f5f9;border:1.5px solid #e2e8f0;border-radius:12px;padding:7px 16px;font-size:14px;font-weight:700;color:#64748b;cursor:pointer;font-family:inherit;transition:all .12s}.type-btn:active{transform:scale(.94)}.type-btn.active-daily{background:#eff6ff;border-color:#3b82f6;color:#1d4ed8}.type-btn.active-once{background:#fff7ed;border-color:#f97316;color:#c2410c}.type-btn.active-bonus{background:#fefce8;border-color:#eab308;color:#a16207}.type-btn.active-group{background:#faf5ff;border-color:#a855f7;color:#6d28d9}.edit-form{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:18px;padding:14px 18px;display:flex;flex-direction:column;gap:10px;margin:4px 0}.kid-check-row{display:flex;flex-wrap:wrap;gap:8px}.rotate-selector{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}.rotate-opt{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:6px 12px;font-size:14px;font-family:inherit;font-weight:600;color:#475569;cursor:pointer;transition:background .15s,border-color .15s}.rotate-opt.selected{background:#e0f2fe;border-color:#0369a1;color:#0369a1}.kid-check-btn{display:flex;align-items:center;gap:7px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;padding:7px 13px;font-size:16px;font-weight:700;color:#0f172a;cursor:pointer;font-family:inherit;transition:all .12s}.kid-check-btn:active{transform:scale(.94)}.kid-check-btn.selected{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.chore-admin-type{font-size:12px;font-weight:700;padding:2px 7px;border-radius:6px;flex-shrink:0}.chore-admin-type.type-daily{background:#eff6ff;color:#1d4ed8}.chore-admin-type.type-once{background:#fff7ed;color:#c2410c}.chore-admin-type.type-bonus{background:#fefce8;color:#a16207}.chore-admin-type.type-group{background:#faf5ff;color:#6d28d9}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;position:relative;z-index:1}.loading-spinner{font-size:88px;line-height:1;animation:rocketLaunch 1.4s ease-in-out infinite}@keyframes rocketLaunch{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}.loading-text{font-size:30px;font-weight:700;color:#64748b}#confetti-canvas{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999}@media (max-width: 768px){.app,.home-screen,.home-body,.kids-panel,.kids-row,.kid-screen,.chore-list{height:auto!important;max-height:none!important;overflow:visible!important}.app{min-height:100dvh;display:block}input,select,textarea{font-size:16px!important}.clouds-layer,.sparkles-layer{display:none}.home-header{height:auto;padding:16px 16px 12px;flex-wrap:wrap;gap:10px;background:#0ea5e9eb;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.25)}.header-left{min-width:unset;flex:1 1 auto;order:1}.header-center{flex:1 1 100%;order:3}.header-right{flex:0 0 auto;order:2;gap:8px}.home-title{font-size:26px}.home-date{font-size:15px}.family-progress-bar{width:100%;height:40px;background:#fff3;border-color:#fff6}.family-progress-text{font-size:14px}.header-badge{height:52px;padding:6px 12px;background:#fff3;border-color:#fff6}.badge-icon{font-size:22px}.badge-number{font-size:18px}.badge-label{font-size:12px}.parent-btn{width:52px;height:52px;font-size:20px;border-radius:14px}.home-body{flex-direction:column;padding:12px 12px 24px;gap:12px}.kids-panel-inner{height:auto}.kids-nav-btn,.kids-nav-dots{display:none}.desktop-kids{display:none!important}.mobile-kids{display:flex;flex-direction:column;gap:16px;flex:none}.kid-card{flex:none;width:100%;flex-direction:column;border-radius:20px}.kid-card-top{flex-direction:column;flex:none;padding:20px 16px 12px;gap:4px;border-right:none;border-bottom:2px solid rgba(0,0,0,.06)}.kid-ring-wrap{width:80px!important;height:80px!important}.kid-avatar-circle{width:60px!important;height:60px!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.kid-avatar-emoji{font-size:26px}.kid-crown{font-size:20px;margin-bottom:-4px}.kid-card-name{font-size:22px;margin-top:8px}.kid-card-stars{font-size:16px}.kid-card-progress-label{font-size:14px}.kid-card-chores{flex:none;overflow:visible!important;max-height:none!important;padding:12px 14px 16px;gap:10px}.mission-text,.mission-sub{white-space:normal!important;overflow:visible!important;text-overflow:clip!important}.mission-card{min-height:70px;padding:10px 12px 10px 8px;gap:10px;flex-shrink:0}.mission-icon{font-size:24px;width:44px;height:44px;border-radius:12px}.mission-info{min-width:0}.mission-text{font-size:18px;line-height:1.3}.mission-sub{font-size:13px}.mission-check{width:40px;height:40px;font-size:18px;flex-shrink:0}.group-panel,.group-panel.group-panel-open{width:100%;border-radius:20px;transition:none}.group-panel-toggle{flex-direction:row!important;padding:14px 16px!important;border-bottom:2px solid #f1f5f9}.group-panel-toggle-title{writing-mode:horizontal-tb!important;transform:none!important;font-size:22px!important}.group-panel-toggle-right{flex-direction:row!important;margin-left:auto}.group-chore-list{overflow:visible!important;max-height:none!important}.group-pending-badge,.group-all-done-badge{font-size:13px;padding:3px 10px}.rewards-panel,.rewards-panel.rewards-panel-open{width:100%;border-radius:20px;transition:none}.rewards-panel-toggle{flex-direction:row!important;padding:14px 16px!important;border-bottom:2px solid #f1f5f9}.rewards-panel-toggle-title{writing-mode:horizontal-tb!important;transform:none!important;font-size:20px!important}.rewards-panel-toggle-right{flex-direction:row!important;margin-left:auto}.rewards-content{overflow:visible;flex:none;height:auto;max-height:none}.reward-card{flex-wrap:wrap}.reward-claim-btn{width:100%;text-align:center;justify-content:center;margin-top:4px}.kid-screen{min-height:100dvh;display:block}.kid-header{position:sticky;top:0;z-index:10;background:#0ea5e9eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.25);flex-wrap:wrap;padding:12px 16px;gap:10px}.back-btn{font-size:16px;padding:8px 16px;background:#ffffff40;border-color:#fff6;color:#fff}.kid-header-avatar{font-size:34px}.kid-header-name{font-size:24px}.kid-header-progress{font-size:15px}.kid-header-bar{width:100%;flex:1 1 100%}.chore-list{padding:14px 14px 32px;gap:10px}.chore-item{min-height:68px;border-radius:16px}.chore-icon{width:46px;height:46px;font-size:22px;margin:8px 0 8px 8px}.chore-text{font-size:18px}.chore-check{width:44px;height:44px;font-size:18px;margin-right:4px}.drag-handle{width:36px;min-width:36px;min-height:64px}.all-done-banner{margin:0 14px 12px;padding:14px 16px;border-radius:16px}.all-done-text{font-size:20px}.all-done-emoji{font-size:30px}.modal-overlay{align-items:flex-end;padding:0}.modal-box{width:100%;max-height:92dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:20px 20px 0 0;padding:20px 16px 40px;border-bottom:none;box-shadow:0 -8px 40px #0f172a33}.modal-title{font-size:22px}.modal-subtitle{font-size:14px;margin-bottom:14px}.pin-screen{gap:20px}.pin-title{font-size:26px}.pin-pad{width:100%;max-width:280px;gap:10px}.pin-btn{height:64px;font-size:24px;border-radius:14px}.tab-bar{display:grid;grid-template-columns:1fr 1fr;margin-bottom:14px;gap:4px}.tab-btn{font-size:14px;padding:11px 8px}.admin-input{font-size:16px!important;padding:12px 14px;border-radius:12px}.btn{font-size:15px;padding:12px 16px;min-height:48px}.btn-sm{font-size:14px;padding:9px 12px;min-height:40px}.emoji-opt{width:46px;height:46px;font-size:22px}.color-opt{width:40px;height:40px}.admin-section-title{font-size:18px}.kid-admin-row{padding:12px 14px;gap:10px;border-radius:14px}.kid-admin-avatar{font-size:28px}.kid-admin-name{font-size:17px}.kid-admin-actions{width:100%;justify-content:flex-end}.chore-admin-row{padding:10px 12px}.chore-admin-text{font-size:15px}.chore-admin-actions{width:100%;justify-content:flex-end;border-top:1px solid #e2e8f0;padding-top:6px;margin-top:2px}.kid-chores-expanded{padding:8px 8px 8px 12px}.chore-edit-wrap{padding:4px 8px 4px 0}.kids-admin-list{gap:8px}.kid-check-btn{font-size:15px;padding:9px 12px;min-height:44px}.type-btn{font-size:13px;padding:8px 12px;min-height:40px}.type-selector{gap:6px}.add-form{padding:14px;gap:10px}.edit-form{padding:12px 14px}.form-row{flex-wrap:wrap}.divider{margin:12px 0}.modal-close-row{margin-top:20px;padding-top:16px}}.rewards-panel{width:88px;flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;background:#ffffffe6;border:2px solid #e2e8f0;border-radius:28px;box-shadow:0 4px #d1d9e0,0 6px 24px #00000014;transition:width .35s cubic-bezier(.34,1.2,.64,1)}.rewards-panel.rewards-panel-open{width:460px}.rewards-panel-toggle{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 10px;background:linear-gradient(180deg,#f9731624,#f973160f);border:none;cursor:pointer;font-family:inherit;width:100%;flex-shrink:0;transition:background .15s,transform .1s}.rewards-panel.rewards-panel-open .rewards-panel-toggle{flex-direction:row;padding:16px 20px;border-bottom:2px solid rgba(249,115,22,.25);gap:12px}.rewards-panel-toggle:active{background:#f9731642;transform:scale(.98)}.rewards-panel-toggle-title{font-size:24px;font-weight:800;color:#0f172a;white-space:nowrap;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}.rewards-panel.rewards-panel-open .rewards-panel-toggle-title{writing-mode:horizontal-tb;transform:none;font-size:26px}.rewards-panel-toggle-right{display:flex;flex-direction:column;align-items:center;gap:6px}.rewards-panel.rewards-panel-open .rewards-panel-toggle-right{flex-direction:row;margin-left:auto;gap:10px}.rewards-panel-chevron{font-size:22px;font-weight:900;color:#c2410c;background:#f9731626;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rewards-pending-badge{background:#f97316;color:#fff;font-size:14px;font-weight:800;border-radius:99px;padding:4px 12px;white-space:nowrap;box-shadow:0 3px #c2410c;animation:pendingPulse 2s ease-in-out infinite}.rewards-stars-total{font-size:16px;font-weight:800;color:#0f172a;white-space:nowrap}.rewards-content{flex:1;overflow-y:scroll;padding:12px 16px 16px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch;touch-action:pan-y;scrollbar-width:none}.rewards-content::-webkit-scrollbar{display:none}.rewards-stars-header{display:flex;flex-direction:column;gap:6px;background:linear-gradient(135deg,#fbbf24,#f97316);border-radius:20px;padding:14px 20px;box-shadow:0 4px #c2410c}.rewards-stars-header-row{display:flex;align-items:center;justify-content:space-between}.rewards-stars-label{font-size:22px;font-weight:700;color:#ffffffe6}.rewards-stars-big{font-size:34px;font-weight:900;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.2)}.rewards-empty{text-align:center;color:#94a3b8;font-size:18px;font-weight:700;padding:24px 8px;display:flex;flex-direction:column;align-items:center;gap:8px}.rewards-list{display:flex;flex-direction:column;gap:10px}.reward-card{background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 4px #d1d9e0;transition:border-color .15s,box-shadow .15s}.reward-card.claimable{border-color:#f97316;box-shadow:0 4px #c2410c;animation:rewardGlow 2s ease-in-out infinite}@keyframes rewardGlow{0%,to{box-shadow:0 4px #c2410c,0 0 #f9731600}50%{box-shadow:0 4px #c2410c,0 0 16px #f973164d}}.reward-card.claimed{background:#f0fdf4;border-color:#86efac;box-shadow:0 4px #6ee7a0;opacity:.75}.reward-card-icon{font-size:44px;flex-shrink:0;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-radius:16px}.reward-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.reward-card-name{font-size:22px;font-weight:800;color:#0f172a;line-height:1.2}.reward-card-cost{font-size:18px;font-weight:700;color:#f97316}.reward-progress-wrap{display:flex;align-items:center;gap:8px;margin-top:4px}.reward-progress-bar{flex:1;height:14px;border-radius:99px;background:#f1f5f9;overflow:hidden;display:flex;flex-direction:row}.reward-progress-fill{height:100%;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.reward-progress-fill.committed{background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:99px 0 0 99px}.reward-progress-fill.today{background:linear-gradient(90deg,#38bdf8,#0ea5e9);border-radius:0 99px 99px 0;opacity:.9}.reward-progress-fill.committed:last-child{border-radius:99px}.reward-progress-label{font-size:16px;font-weight:700;color:#64748b;white-space:nowrap;flex-shrink:0}.reward-progress-today-note{color:#0369a1;font-size:12px}.rewards-stars-breakdown{display:flex;align-items:baseline;gap:10px}.rewards-stars-today{font-size:16px;font-weight:700;color:#f97316;background:#ffffffe6;border-radius:99px;padding:2px 10px}.rewards-stars-legend{display:flex;align-items:center;gap:6px;font-size:13px;color:#ffffffd9;font-weight:600}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.legend-dot.committed{background:#22c55e}.legend-dot.today{background:#38bdf8}.reward-claimed-label{font-size:14px;font-weight:700;color:#22c55e;margin-top:2px}.reward-claim-btn{background:#f97316;border:none;border-radius:14px;padding:10px 14px;font-size:16px;font-weight:800;color:#fff;cursor:pointer;box-shadow:0 4px #c2410c;transition:transform .1s,box-shadow .1s;font-family:inherit;white-space:nowrap;flex-shrink:0}.reward-claim-btn:active{transform:translateY(3px);box-shadow:0 1px #c2410c}.reward-claim-btn.loading{opacity:.6;cursor:default}@media (min-width: 1900px){.app{height:calc(100vh - 96px);max-height:calc(100vh - 96px)}}@media (min-width: 769px) and (max-width: 1024px){.home-title{font-size:34px}.home-header{padding:0 24px}.home-body{padding:12px 24px 24px}.family-progress-bar{width:300px;height:48px}.kids-row{gap:14px}.kid-card-name{font-size:22px}.mission-text{font-size:17px}.group-panel{width:320px;padding:18px}.modal-box{padding:32px 36px}.admin-input{font-size:16px!important}}
