:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:Comic Sans MS,Segoe UI,system-ui,sans-serif;line-height:1.45}body{margin:0}#root{min-height:100svh}:root{--ink:#1f2937;--line:#e5e7eb}*{box-sizing:border-box}body{color:var(--ink);background:#f8fafc;margin:0;font-family:Comic Sans MS,Segoe UI,system-ui,sans-serif}.app{max-width:760px;margin:0 auto;padding:20px 16px 60px}header h1{margin:0;font-size:2rem}.topbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.progress{color:#4b5563;align-items:center;gap:10px;font-weight:700;display:flex}.icon-btn{border:2px solid var(--line);cursor:pointer;background:#fff;border-radius:10px;padding:4px 8px;font-size:1rem}.icon-btn:hover{background:#f1f5f9}.levels{flex-wrap:wrap;gap:8px;display:flex}.chip{border:2px solid var(--line);cursor:pointer;background:#fff;border-radius:999px;padding:6px 12px;font-size:.85rem}.chip.on{background:#eef2ff;border-color:#6366f1;font-weight:700}.goal-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin:18px 0 10px;display:flex}.goal{margin:0;font-size:1.15rem;font-weight:700}.dice-btn{color:#4338ca;cursor:pointer;white-space:nowrap;background:#eef2ff;border:2px solid #c7d2fe;border-radius:12px;padding:8px 14px;font-size:.95rem;font-weight:700}.dice-btn:hover{background:#e0e7ff}.dice-btn:disabled{opacity:.5;cursor:default}.board{border:2px solid var(--line);background:#fff;border-radius:16px;padding:18px}.numbers{justify-content:center;gap:14px;display:flex}.num-cell{flex-direction:column;align-items:center;display:flex}.num{background:#f1f5f9;border-radius:14px;place-items:center;width:64px;height:64px;font-size:1.8rem;font-weight:700;transition:transform .15s,background .15s;display:grid}.num.active{background:#fde68a;transform:translateY(-4px)scale(1.06);box-shadow:0 6px #f59e0b}.arrow{color:#f59e0b;height:22px;font-size:1.1rem}.slots{gap:12px;margin-top:16px;display:flex}.slot{border:2px dashed var(--line);border-radius:12px;flex-direction:column;min-width:90px;padding:8px 14px;display:flex}.slot.grow{flex:1}.slot-label{color:#6b7280;font-size:.75rem}.slot-value{font-size:1.4rem;font-weight:700}.controls{align-items:center;gap:12px;margin:16px 0 6px;display:flex}.btn{cursor:pointer;background:#e5e7eb;border:none;border-radius:12px;padding:10px 18px;font-size:1rem;font-weight:700}.btn.play{color:#fff;background:#22c55e}.btn:disabled{opacity:.5;cursor:default}.speed{color:#6b7280;align-items:center;gap:6px;margin-left:auto;font-size:.8rem;display:flex}.note{color:#4b5563;min-height:1.4em;margin:4px 0 10px;font-style:italic}.builder{grid-template-columns:1fr 200px;align-items:start;gap:14px;display:grid}@media (width<=620px){.builder{grid-template-columns:1fr}}.zone{border-radius:14px;flex-direction:column;gap:8px;min-height:60px;padding:10px;transition:background .12s,box-shadow .12s;display:flex}.zone.program{border:2px solid var(--line);background:#fff}.zone.bin{background:#fafafa;border:2px dashed #cbd5e1}.zone.over{background:#eef2ff;box-shadow:0 0 0 3px #818cf8}.empty{color:#9ca3af;text-align:center;padding:18px;font-style:italic}.bin-label{color:#6b7280;margin-bottom:2px;font-size:.8rem;font-weight:700}.bin-empty{color:#cbd5e1;text-align:center;border:2px dashed #e5e7eb;border-radius:10px;padding:12px;font-size:.8rem}.program{flex-direction:column;gap:8px;display:flex}.card{border:2px solid #0000000f;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;font-size:1rem;transition:transform .12s,box-shadow .12s;display:flex}.card.active{transform:translate(6px);box-shadow:0 0 0 3px #6366f1}.card-step{color:#fff;background:#00000026;border-radius:50%;place-items:center;width:24px;height:24px;font-size:.8rem;font-weight:700;display:grid}.card-icon{font-size:1.2rem}.banner{text-align:center;border-radius:12px;margin-top:16px;padding:14px;font-size:1.2rem;font-weight:700}.banner.win{color:#15803d;background:#dcfce7}.banner.miss{color:#a16207;background:#fef9c3}.banner.error{color:#b91c1c;background:#fee2e2}.banner-sub{opacity:.85;margin-top:6px;font-size:.9rem;font-weight:400}.stars{letter-spacing:2px}.banner.pop{animation:.45s cubic-bezier(.18,.89,.32,1.28) pop}@keyframes pop{0%{opacity:0;transform:scale(.7)}60%{transform:scale(1.06)}to{opacity:1;transform:scale(1)}}.banner.win .stars{animation:.6s ease-in-out .2s 2 wiggle;display:inline-block}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}@media (prefers-reduced-motion:reduce){.banner.pop,.banner.win .stars{animation:none}}
