:root{--c-bg-sky: #aee9ff;--c-bg-cream: #fff5e6;--c-bg-grass: #c9eeb0;--c-primary: #ff8c69;--c-primary-dark: #d96a4a;--c-secondary: #ffd166;--c-secondary-dark: #d9a847;--c-success: #5cd684;--c-success-dark: #3eaa61;--c-stop: #ff6b6b;--c-stop-dark: #cc4a4a;--c-wait: #ffd700;--c-wait-dark: #cc9b00;--c-go: #5cd684;--c-go-dark: #3eaa61;--c-text: #4a3a3a;--c-text-soft: #6a5a4a;--c-card: #ffffff;--c-shadow: rgba(0, 0, 0, .08);--r-lg: 24px;--r-md: 16px;--r-sm: 12px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;font-weight:600;color:var(--c-text);user-select:none;-webkit-user-select:none;overscroll-behavior:none;touch-action:manipulation;background:#000}button{font-family:inherit;font-weight:700;cursor:pointer;border:none;outline:none}.app{width:100%;max-width:480px;height:100dvh;margin:0 auto;background:linear-gradient(180deg,var(--c-bg-sky) 0%,var(--c-bg-cream) 55%,var(--c-bg-grass) 100%);display:flex;flex-direction:column;position:relative;overflow:hidden}.btn{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:64px;padding:12px 20px;border-radius:var(--r-lg);font-size:22px;font-weight:800;background:var(--c-primary);color:#fff;box-shadow:0 6px 0 var(--c-primary-dark),0 8px 16px var(--c-shadow);transition:transform .08s,box-shadow .08s}.btn:active{transform:translateY(4px);box-shadow:0 2px 0 var(--c-primary-dark),0 4px 8px var(--c-shadow)}.btn-secondary{background:var(--c-secondary);box-shadow:0 6px 0 var(--c-secondary-dark),0 8px 16px var(--c-shadow)}.btn-secondary:active{box-shadow:0 2px 0 var(--c-secondary-dark),0 4px 8px var(--c-shadow)}.btn-success{background:var(--c-success);box-shadow:0 6px 0 var(--c-success-dark),0 8px 16px var(--c-shadow)}.btn-success:active{box-shadow:0 2px 0 var(--c-success-dark),0 4px 8px var(--c-shadow)}.btn-ghost{background:#fff;color:var(--c-text-soft);box-shadow:0 6px #ddd,0 8px 16px var(--c-shadow)}.btn-ghost:active{box-shadow:0 2px #ddd,0 4px 8px var(--c-shadow)}.btn-row{display:flex;gap:12px;width:100%}.start-page{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:36px 28px 32px;text-align:center}.start-title{font-size:36px;font-weight:900;color:#ff5252;text-shadow:3px 3px 0 #fff,5px 5px 0 rgba(0,0,0,.06);margin:28px 0 12px;letter-spacing:2px}.start-subtitle{font-size:17px;color:var(--c-text-soft);margin:0 0 16px}.start-art{flex:1;display:flex;align-items:center;justify-content:center;width:100%;position:relative}.start-actions{width:100%;display:flex;flex-direction:column;gap:14px}.parent-link{background:transparent;color:var(--c-text-soft);font-size:14px;text-decoration:underline;padding:8px;margin-top:8px}.cloud{position:absolute;background:#fff;border-radius:50px;opacity:.85}.cloud:before,.cloud:after{content:"";position:absolute;background:#fff;border-radius:50%}.cloud-1{width:70px;height:22px;top:18%;left:8%}.cloud-1:before{width:30px;height:30px;top:-14px;left:10px}.cloud-1:after{width:22px;height:22px;top:-10px;left:38px}.cloud-2{width:60px;height:18px;top:30%;right:12%}.cloud-2:before{width:26px;height:26px;top:-12px;left:6px}.cloud-2:after{width:20px;height:20px;top:-8px;left:30px}.sun{position:absolute;top:14%;right:14%;font-size:44px;filter:drop-shadow(0 0 8px rgba(255,200,0,.4))}.progress-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#ffffffd9;border-radius:0 0 var(--r-md) var(--r-md);box-shadow:0 2px 6px var(--c-shadow);font-size:16px;z-index:5}.progress-text{font-weight:800;color:var(--c-text);font-size:18px}.progress-stars{display:flex;gap:3px;font-size:22px}.progress-stars .filled{filter:drop-shadow(0 0 4px #ffd700)}.progress-stars .empty{opacity:.3;filter:grayscale(1)}.home-btn{background:#0000000d;border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:20px}.task{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.task-prompt{text-align:center;font-size:22px;font-weight:800;color:var(--c-text);padding:18px 16px 6px;text-shadow:1px 1px 0 #fff}.task-prompt .target-color{font-size:26px;padding:2px 12px;border-radius:8px;margin:0 4px;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.tl-task .sky-area{flex:1;position:relative;display:flex;align-items:center;justify-content:center}.traffic-light{width:90px;height:230px;background:#2a2a2a;border-radius:18px;padding:12px;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:center;position:relative;box-shadow:0 8px 14px #0003}.traffic-light:after{content:"";position:absolute;bottom:-42px;left:50%;transform:translate(-50%);width:14px;height:42px;background:#555;border-radius:4px}.tl-light{width:60px;height:60px;border-radius:50%;background:#444;transition:background .3s,box-shadow .3s}.tl-light.on-red{background:var(--c-stop);box-shadow:0 0 24px var(--c-stop),inset 0 0 8px #ffffff4d}.tl-light.on-yellow{background:var(--c-wait);box-shadow:0 0 24px var(--c-wait),inset 0 0 8px #ffffff4d}.tl-light.on-green{background:var(--c-go);box-shadow:0 0 24px var(--c-go),inset 0 0 8px #ffffff4d}.road{height:110px;background:#4a4a4a;border-top:4px solid #888;border-bottom:4px solid #888;position:relative;overflow:hidden}.road:before{content:"";position:absolute;top:50%;left:0;right:0;height:5px;background:repeating-linear-gradient(90deg,#fff58c 0,#fff58c 28px,transparent 28px,transparent 56px);transform:translateY(-50%)}.road .car-on-road{position:absolute;top:50%;left:30px;transform:translateY(-50%);transition:left 1.2s ease-out}.road .car-on-road.driving{left:calc(100% - 130px)}.action-row{display:flex;gap:10px;padding:18px 14px 24px}.action-btn{flex:1;min-height:96px;border-radius:22px;font-size:20px;font-weight:900;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 6px #00000026,0 8px 16px var(--c-shadow);transition:transform .08s,box-shadow .08s}.action-btn .icon{font-size:32px;line-height:1}.action-btn.stop{background:var(--c-stop);box-shadow:0 6px 0 var(--c-stop-dark),0 8px 16px var(--c-shadow)}.action-btn.wait{background:var(--c-wait);color:#6a5300;box-shadow:0 6px 0 var(--c-wait-dark),0 8px 16px var(--c-shadow)}.action-btn.go{background:var(--c-go);box-shadow:0 6px 0 var(--c-go-dark),0 8px 16px var(--c-shadow)}.action-btn:active{transform:translateY(4px);box-shadow:0 2px #00000026,0 4px 8px var(--c-shadow)}.parking-task{flex:1;display:flex;flex-direction:column;position:relative}.parking-area{flex:1;position:relative;margin:0 14px}.parking-car{position:absolute;left:50%;top:24px;z-index:3;cursor:grab;touch-action:none;filter:drop-shadow(0 4px 6px rgba(0,0,0,.15))}.parking-car.dragging{cursor:grabbing}.parking-hint-arrow{position:absolute;left:50%;top:130px;transform:translate(-50%);font-size:36px;opacity:.7;animation:bounce-down 1.4s infinite;pointer-events:none}@keyframes bounce-down{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.parking-lot{display:flex;gap:6px;padding:10px 12px 22px;background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.3) 100%)}.parking-spot{flex:1;aspect-ratio:.62;background:#3a3a3a;border:4px dashed #ffe066;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:38px;font-weight:900;color:#ffe066;cursor:pointer;transition:transform .12s,border-color .2s,background .2s;box-shadow:0 4px #1a1a1a}.parking-spot:active{transform:translateY(2px);box-shadow:0 2px #1a1a1a}.parking-spot.target{border-color:var(--c-go);animation:spot-pulse 1.4s infinite ease-in-out}@keyframes spot-pulse{0%,to{box-shadow:0 4px #1a1a1a,0 0 #5cd68480}50%{box-shadow:0 4px #1a1a1a,0 0 0 12px #5cd68400}}.color-task{flex:1;display:flex;flex-direction:column}.color-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:14px;align-content:center}.color-cell{background:#ffffffb3;border-radius:22px;padding:10px;display:flex;align-items:center;justify-content:center;aspect-ratio:1.1;border:4px solid transparent;transition:transform .12s,border-color .15s,background .15s;box-shadow:0 6px 12px var(--c-shadow);cursor:pointer}.color-cell:active{transform:scale(.94)}.color-cell.picked-correct{border-color:var(--c-success);background:#e8fbe8}.color-cell.picked-wrong{animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000052;z-index:30;animation:fade-in .25s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.success-card{background:#fff;border-radius:var(--r-lg);padding:28px 28px 22px;width:80%;max-width:320px;text-align:center;box-shadow:0 14px 40px #00000040;animation:pop-in .4s cubic-bezier(.34,1.56,.64,1)}@keyframes pop-in{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}.success-emoji{font-size:72px;margin-bottom:8px;animation:star-bounce .8s ease-in-out infinite;display:inline-block}@keyframes star-bounce{0%,to{transform:scale(1) rotate(-6deg)}50%{transform:scale(1.12) rotate(6deg)}}.success-text{font-size:24px;font-weight:900;color:#ff8c69;margin-bottom:18px}.toast{position:absolute;top:24%;left:50%;transform:translate(-50%);background:#3c3228eb;color:#fff;padding:14px 22px;border-radius:var(--r-md);font-size:17px;font-weight:700;z-index:25;max-width:80%;text-align:center;box-shadow:0 8px 16px #0003;animation:toast-pop .3s ease-out}@keyframes toast-pop{0%{transform:translate(-50%) translateY(-8px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.rest-page{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:36px 28px 32px;text-align:center}.rest-title{font-size:30px;font-weight:900;color:#ff6b6b;text-shadow:2px 2px 0 #fff;margin:12px 0 6px}.rest-stars{font-size:56px;margin:12px 0 6px;letter-spacing:4px;filter:drop-shadow(0 0 8px rgba(255,215,0,.6))}.rest-stars-text{font-size:18px;color:var(--c-text-soft);margin-bottom:18px}.rest-reminder{background:#ffffffd9;padding:22px;border-radius:var(--r-md);font-size:18px;color:var(--c-text);line-height:1.6;box-shadow:0 4px 10px var(--c-shadow);margin:12px 0}.rest-reminder .eye{font-size:44px;display:block;margin-bottom:8px}.parent-page{flex:1;display:flex;flex-direction:column;padding:22px;overflow-y:auto}.parent-page h2{font-size:26px;margin:6px 0 16px;color:var(--c-text)}.parent-card{background:#fff;border-radius:var(--r-md);padding:18px 18px 16px;margin-bottom:14px;box-shadow:0 4px 10px var(--c-shadow)}.parent-card h3{font-size:17px;margin:0 0 10px;color:var(--c-text)}.parent-card p{font-size:15px;color:var(--c-text-soft);margin:6px 0;line-height:1.5}.task-count-row{display:flex;gap:10px}.count-pill{flex:1;padding:14px 0;background:#f4f4f4;border-radius:var(--r-sm);font-size:18px;font-weight:800;text-align:center;color:var(--c-text-soft);cursor:pointer;border:3px solid transparent}.count-pill.active{background:#fff0e6;color:var(--c-primary);border-color:var(--c-primary)}.parent-textarea{width:100%;min-height:70px;padding:10px;border-radius:var(--r-sm);border:2px solid #eee;font-size:15px;font-family:inherit;font-weight:600;resize:vertical;color:var(--c-text)}.parent-textarea:focus{outline:none;border-color:var(--c-primary)}.parent-info-list{list-style:none;padding:0;margin:6px 0 0}.parent-info-list li{font-size:15px;color:var(--c-text-soft);padding:4px 0}.parent-info-list li:before{content:"✓ ";color:var(--c-success-dark);font-weight:900}.start-header{width:100%;text-align:center}.mode-row{display:flex;flex-direction:column;gap:12px;width:100%}.mode-card{flex-direction:column;align-items:center;min-height:88px;padding:14px 20px;gap:2px;text-align:center}.mode-card .emoji{font-size:32px;line-height:1;margin-bottom:4px}.mode-card .main{font-size:22px;font-weight:900}.mode-card .sub{font-size:13px;font-weight:600;opacity:.85}.mode-learning{background:var(--c-secondary);box-shadow:0 6px 0 var(--c-secondary-dark),0 8px 16px var(--c-shadow);color:#5a3a00}.mode-learning:active{box-shadow:0 2px 0 var(--c-secondary-dark),0 4px 8px var(--c-shadow)}.start-links{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px}.link-divider{color:var(--c-text-soft);opacity:.5}.link-btn{background:transparent;color:var(--c-text-soft);font-size:14px;font-weight:700;text-decoration:underline;padding:6px 8px;border:none;cursor:pointer}.link-btn.inline{display:inline;padding:0 4px;color:var(--c-primary)}.start-meta{font-size:12px;color:var(--c-text-soft);margin:0;opacity:.8}.limit-card{background:#ffffffe0;border-radius:var(--r-md);padding:24px 20px 22px;text-align:center;box-shadow:0 4px 12px var(--c-shadow);width:100%}.limit-card.compact{padding:16px;margin:8px 0 4px}.limit-card .moon{font-size:44px;display:block;margin-bottom:8px}.limit-card .limit-text{font-size:18px;font-weight:800;color:var(--c-text);margin:0 0 4px;line-height:1.5}.limit-card .limit-sub{font-size:14px;color:var(--c-text-soft);margin:4px 0 0}.learn-card{background:#fff;border-radius:var(--r-lg);padding:28px 24px 22px;width:84%;max-width:340px;text-align:center;box-shadow:0 14px 40px #00000040;animation:pop-in .4s cubic-bezier(.34,1.56,.64,1)}.learn-emoji{font-size:56px;margin-bottom:12px}.learn-text{font-size:17px;font-weight:700;line-height:1.65;color:var(--c-text);margin-bottom:20px}.success-detail{font-size:15px;font-weight:700;color:var(--c-text-soft);line-height:1.6;margin:-8px 0 16px}.quiz-task{flex:1;display:flex;flex-direction:column}.quiz-scene-wrap{flex:1;margin:8px 14px 4px;min-height:200px;display:flex}.quiz-options{display:flex;flex-direction:column;gap:10px;padding:12px 14px 22px}.quiz-option{display:flex;align-items:center;background:#fff;border-radius:18px;padding:14px 18px;font-size:19px;font-weight:800;color:var(--c-text);box-shadow:0 5px #ddd,0 8px 12px var(--c-shadow);text-align:left;border:none;font-family:inherit;transition:transform .08s,box-shadow .08s;cursor:pointer}.quiz-option:active{transform:translateY(3px);box-shadow:0 2px #ddd,0 4px 8px var(--c-shadow)}.quiz-option .emoji{font-size:28px;margin-right:14px;line-height:1}.quiz-option.picked-wrong{animation:shake .5s;background:#fff0f0}.scene{flex:1;position:relative;background:linear-gradient(180deg,#aee9ff99,#ffffff80 70%,#c9eeb080);border-radius:var(--r-md);overflow:hidden;display:flex;align-items:flex-end;justify-content:center}.scene .cloud-1{top:16px;left:14px}.scene-car{position:relative;z-index:2;margin-bottom:22px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.15))}.crosswalk-scene .zebra-road{position:absolute;bottom:0;left:0;right:0;height:70px;background:#4a4a4a;border-top:4px solid #888}.crosswalk-scene .zebra-stripes{position:absolute;bottom:0;left:0;right:0;height:70px;background:repeating-linear-gradient(90deg,#fff 0,#fff 18px,transparent 18px,transparent 30px);opacity:.95}.crosswalk-scene .scene-car{margin-bottom:6px}.pedestrian-scene .ground-line{position:absolute;bottom:30px;left:0;right:0;height:4px;background:#c9a98a}.pedestrian-scene .scene-car{margin-right:60px;margin-bottom:12px}.pedestrian-walking{position:absolute;bottom:22px;right:24px;font-size:50px;z-index:3;animation:walk-bob 1.4s ease-in-out infinite}@keyframes walk-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.redlight-scene .scene-light{position:absolute;left:40px;bottom:40px;transform:scale(.7);transform-origin:bottom left}.redlight-scene .redlight-car{margin-right:18px;margin-bottom:18px}.seatbelt-scene{align-items:center;padding:8px}.seatbelt-scene svg{max-height:220px}.sticker-book{flex:1;display:flex;flex-direction:column;padding:22px 18px 16px;overflow-y:auto}.sticker-book h2{font-size:26px;margin:0 0 4px;text-align:center;color:var(--c-text)}.sticker-count{text-align:center;color:var(--c-text-soft);margin:0 0 14px;font-size:15px}.sticker-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.sticker-cell{background:#fff;border-radius:var(--r-md);padding:14px 10px;display:flex;flex-direction:column;align-items:center;box-shadow:0 4px 8px var(--c-shadow);position:relative;border:3px solid transparent}.sticker-cell.locked{background:#f3efe9;opacity:.55}.sticker-cell.locked:after{content:"🔒";position:absolute;top:8px;right:8px;font-size:18px}.sticker-cell.owned{border-color:var(--c-secondary);background:#fffaf0}.sticker-cell .sticker-art{margin:4px 0}.sticker-cell .sticker-name{font-size:13px;font-weight:800;color:var(--c-text);margin-top:4px;text-align:center}.sticker-complete{text-align:center;font-size:16px;font-weight:800;color:var(--c-primary);background:#fff0e6;padding:12px;border-radius:var(--r-sm);margin-bottom:12px}.sticker-back-row{margin-top:auto;padding-top:12px}.sticker-reward{background:#fff;border-radius:var(--r-md);padding:16px 18px 14px;text-align:center;box-shadow:0 4px 8px var(--c-shadow);margin:8px 0;animation:sticker-pop .6s cubic-bezier(.34,1.56,.64,1)}@keyframes sticker-pop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}.sticker-reward .new-text{font-size:14px;color:var(--c-text-soft);margin:0 0 6px}.sticker-reward .sticker-art{margin:4px 0}.sticker-reward .sticker-name{font-size:17px;font-weight:800;color:var(--c-primary);margin:4px 0 6px}.sticker-reward.all-collected{padding:18px}.voice-toggle{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:var(--c-text);padding:4px 0}.voice-toggle input{width:22px;height:22px;accent-color:var(--c-primary);cursor:pointer}.voice-toggle input:disabled{opacity:.5}
