*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}:root{--red:#ff4d6d;--orange:#ff8c42;--yellow:#ffd166;--green:#06d6a0;--blue:#4cc9f0;--purple:#7b2fbe;--warm-bg:#fff8f0;--text-dark:#2d2d2d;--text-mid:#6b6b6b;--radius:24px;--shadow:0 8px 32px #0000001f}html,body{background:var(--warm-bg);-webkit-font-smoothing:antialiased;width:100%;height:100%;font-family:Nunito,PingFang SC,Microsoft YaHei,sans-serif;overflow:hidden}#root{width:100%;height:100%}.page{flex-direction:column;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden auto}.btn-primary{color:#fff;cursor:pointer;letter-spacing:.5px;border:none;border-radius:50px;justify-content:center;align-items:center;gap:8px;padding:16px 40px;font-size:20px;font-weight:800;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 6px 20px #0003}.btn-primary:active{transform:scale(.95)}.btn-secondary{cursor:pointer;background:0 0;border:3px solid;border-radius:50px;justify-content:center;align-items:center;padding:12px 28px;font-size:16px;font-weight:700;transition:transform .15s;display:inline-flex}.btn-secondary:active{transform:scale(.95)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes starFloat{0%{opacity:.8;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(-100vh)rotate(360deg)}}@property --c1{syntax:"<color>";inherits:false;initial-value:#ff2d55}@property --c2{syntax:"<color>";inherits:false;initial-value:#ff6b6b}@property --c3{syntax:"<color>";inherits:false;initial-value:#ff8c42}.ob-page{background:linear-gradient(160deg, var(--c1) 0%, var(--c2) 50%, var(--c3) 100%);flex-direction:column;align-items:center;width:100%;height:100%;transition:--c1 .8s,--c2 .8s,--c3 .8s;display:flex;position:relative;overflow:hidden}.ob-blob{filter:blur(60px);pointer-events:none;mix-blend-mode:screen;opacity:.35;border-radius:50%;position:absolute}.ob-blob1{background:#fff9;width:280px;height:280px;animation:8s ease-in-out infinite blobDrift1;top:-80px;left:-60px}.ob-blob2{background:#ffffff80;width:200px;height:200px;animation:10s ease-in-out infinite blobDrift2;bottom:20%;right:-40px}.ob-blob3{background:#fff6;width:160px;height:160px;animation:7s ease-in-out infinite blobDrift3;top:40%;left:10%}@keyframes blobDrift1{0%,to{transform:translate(0)scale(1)}50%{transform:translate(30px,40px)scale(1.1)}}@keyframes blobDrift2{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-20px,-30px)scale(.95)}}@keyframes blobDrift3{0%,to{transform:translate(0)}50%{transform:translate(15px,-20px)}}.ob-floats{pointer-events:none;z-index:1;position:absolute;inset:0}.ob-float-item{opacity:0;animation:linear infinite floatUp;position:absolute;bottom:-30px}@keyframes floatUp{0%{opacity:0;transform:translateY(0)rotate(0)}10%{opacity:.8}90%{opacity:.6}to{opacity:0;transform:translateY(-110vh)rotate(360deg)}}.ob-status-bar{z-index:10;justify-content:space-between;align-items:center;padding:12px 24px 0;display:flex;position:absolute;top:0;left:0;right:0}.ob-time{color:#ffffffe6;letter-spacing:.5px;font-size:15px;font-weight:700}.ob-status-icons{color:#fffc;gap:6px;font-size:10px;display:flex}.ob-top-actions{z-index:10;justify-content:space-between;padding:0 24px;display:flex;position:absolute;top:40px;left:0;right:0}.ob-icon-pill{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff59;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;transition:background .2s;display:flex}.ob-icon-pill:active{background:#ffffff59}.ob-image-area{z-index:5;justify-content:center;align-items:center;margin-top:90px;animation:.55s cubic-bezier(.34,1.56,.64,1) both contentIn;display:flex;position:relative}.ob-glow-ring{border-radius:50%;width:220px;height:220px;transition:box-shadow .8s;animation:3s ease-in-out infinite glowPulse;position:absolute}@keyframes glowPulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.ob-circle{-webkit-backdrop-filter:blur(16px);background:#ffffff40;border:3px solid #ffffff80;border-radius:50%;justify-content:center;align-items:center;width:210px;height:210px;display:flex;position:relative;box-shadow:inset 0 2px 20px #ffffff4d,0 20px 60px #00000026}.ob-circle-inner{background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;width:180px;height:180px;display:flex}.ob-main-emoji{filter:drop-shadow(0 8px 24px #0003);font-size:80px;animation:3s ease-in-out infinite emojiFloat}@keyframes emojiFloat{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-10px)scale(1.05)}}.ob-card{z-index:10;animation:.55s cubic-bezier(.22,1,.36,1) both cardSlideUp;position:absolute;bottom:0;left:0;right:0}.ob-card-content{-webkit-backdrop-filter:blur(28px);background:#ffffff2e;border:1px solid #ffffff59;border-bottom:none;border-radius:36px 36px 0 0;padding:32px 28px 44px;box-shadow:inset 0 1px #fff6,0 -20px 60px #00000014}.ob-card-title{color:#fff;letter-spacing:-.5px;text-shadow:0 2px 12px #00000026;margin-bottom:14px;font-size:28px;font-weight:900}.ob-card-text{color:#ffffffe0;text-shadow:0 1px 6px #0000001a;min-height:80px;font-size:16px;font-weight:500;line-height:1.7}.ob-dots{align-items:center;gap:8px;margin:24px 0 28px;display:flex}.ob-dot{cursor:pointer;background:#fff6;border:none;border-radius:3px;width:6px;height:6px;padding:0;transition:width .35s,background .35s,opacity .35s}.ob-dot.active{opacity:1;background:#fff;width:28px}.ob-actions{justify-content:space-between;align-items:center;display:flex}.ob-skip-btn{color:#ffffffbf;cursor:pointer;letter-spacing:.3px;background:0 0;border:none;padding:10px 0;font-size:16px;font-weight:600;transition:color .2s}.ob-skip-btn:active{color:#fff}.ob-next-btn{color:#333;cursor:pointer;letter-spacing:.3px;background:#fffffff2;border:none;border-radius:50px;padding:14px 32px;font-size:16px;font-weight:800;transition:transform .15s,box-shadow .15s;box-shadow:0 8px 24px #00000026}.ob-next-btn:active{transform:scale(.95);box-shadow:0 4px 12px #0000001f}.ob-cta-btn{color:#6b00cc;cursor:pointer;white-space:nowrap;letter-spacing:.2px;background:#fffffff2;border:none;border-radius:50px;padding:14px 22px;font-size:15px;font-weight:900;transition:transform .15s,box-shadow .15s;box-shadow:0 8px 28px #0003}.ob-cta-btn:active{transform:scale(.95);box-shadow:0 4px 12px #0000001f}@keyframes contentIn{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.sub-backdrop{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#00000073;justify-content:center;align-items:flex-end;animation:.18s both subFadeIn;display:flex;position:fixed;inset:0}@keyframes subFadeIn{0%{opacity:0}to{opacity:1}}.sub-card{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:480px;padding:32px 28px 40px;animation:.28s cubic-bezier(.22,1,.36,1) both subSlideUp;position:relative}@keyframes subSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sub-close{color:#6b7280;cursor:pointer;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;transition:background .12s;display:flex;position:absolute;top:16px;right:18px}.sub-close:hover{background:#e5e7eb}.sub-headline{color:#1f2937;margin-bottom:6px;padding-right:36px;font-size:20px;font-weight:900}.sub-sub{color:#6b7280;margin-bottom:24px;font-size:14px;line-height:1.5}.sub-form{flex-direction:column;gap:10px;display:flex}.sub-input{box-sizing:border-box;color:#1f2937;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:12px;outline:none;width:100%;padding:13px 16px;font-size:15px;transition:border-color .15s}.sub-input:focus{background:#fff;border-color:#9b5de5}.sub-error{color:#ef4444;margin:0;font-size:12px}.sub-btn{color:#fff;cursor:pointer;letter-spacing:.2px;background:linear-gradient(135deg,#9b5de5,#7b3fc4);border:none;border-radius:12px;width:100%;padding:14px;font-size:15px;font-weight:800;transition:opacity .15s,transform .1s}.sub-btn:hover{opacity:.92}.sub-btn:active{transform:scale(.98)}.sub-btn:disabled{opacity:.45;cursor:not-allowed}.sub-skip{color:#9ca3af;cursor:pointer;text-align:center;background:0 0;border:none;width:100%;margin-top:12px;padding:6px;font-size:13px;display:block}.sub-skip:hover{color:#6b7280}.sub-success{text-align:center;padding:12px 0 8px}.sub-success-icon{margin-bottom:12px;font-size:52px}.sub-success-title{color:#1f2937;margin-bottom:8px;font-size:22px;font-weight:900}.sub-success-msg{color:#6b7280;font-size:14px;line-height:1.5}.home-page{width:100%;min-height:100%;padding-bottom:calc(80px + env(safe-area-inset-bottom));background:linear-gradient(160deg,#fff4ec 0%,#fed 100%);flex-direction:column;align-items:center;display:flex;position:relative;overflow-y:auto}.home-gallery-btn{color:#c05800;cursor:pointer;-webkit-backdrop-filter:blur(8px);letter-spacing:.3px;z-index:10;background:#ffffffd9;border:2px solid #ff8c4259;border-radius:20px;padding:7px 14px;font-size:13px;font-weight:800;transition:transform .15s,box-shadow .15s;position:absolute;top:20px;right:16px;box-shadow:0 2px 12px #ff8c0026}.home-gallery-btn:active{transform:scale(.95)}.home-header{align-items:center;gap:14px;width:100%;max-width:480px;padding:24px 16px 20px;animation:.5s both fadeInUp;display:flex}.home-logo{filter:drop-shadow(0 4px 12px #ff8c004d);font-size:44px;animation:3s ease-in-out infinite float}.home-title{color:#3d1c00;letter-spacing:-.5px;font-size:32px;font-weight:900}.home-subtitle{color:#8b5e3c;margin-top:2px;font-size:14px;font-weight:600}.bubble-field{flex-shrink:0;width:100%;max-width:390px;height:700px;position:relative}.bubble{cursor:pointer;-webkit-tap-highlight-color:transparent;border:1.5px solid #ffffff80;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;transition:transform .18s,box-shadow .18s;animation-timing-function:ease-in-out;animation-iteration-count:infinite;display:flex;position:absolute;overflow:hidden}.bubble:not(.soon):active{transform:scale(.9)!important}.bubble.soon{opacity:.55;cursor:default}.bubble-highlight{filter:blur(5px);pointer-events:none;background:#fff9;border-radius:50%;width:32%;height:18%;position:absolute;top:11%;left:20%}.bubble-shimmer{pointer-events:none;background:conic-gradient(#0000 0%,#ffffff1f 20%,#0000 40%);border-radius:50%;animation:5s linear infinite bubbleShimmer;position:absolute;inset:0}@keyframes bubbleShimmer{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.bubble-emoji{filter:drop-shadow(0 2px 6px #0000002e);z-index:1;margin-bottom:5px;line-height:1;position:relative}.bubble-title{color:#ffffffeb;text-align:center;white-space:pre-line;text-shadow:0 1px 5px #00000038;z-index:1;padding:0 10px;font-size:10.5px;font-weight:800;line-height:1.35;position:relative}.bubble-soon{color:#fffc;letter-spacing:.4px;z-index:1;background:#0000002e;border-radius:8px;margin-top:4px;padding:2px 7px;font-size:9px;font-weight:800;position:relative}@keyframes bubbleFloat1{0%,to{transform:translate(0)scale(1)}38%{transform:translate(5px,-11px)scale(1.02)}70%{transform:translate(-4px,5px)scale(.99)}}@keyframes bubbleFloat2{0%,to{transform:translate(0)scale(1)}32%{transform:translate(-6px,-8px)scale(1.01)}68%{transform:translate(5px,7px)scale(1.02)}}@keyframes bubbleFloat3{0%,to{transform:translate(0)scale(1)}45%{transform:translate(4px,-9px)scale(1.02)}75%{transform:translate(-5px,4px)scale(.98)}}@keyframes bubbleFloat4{0%,to{transform:translate(0)scale(1)}30%{transform:translate(-4px,-12px)scale(1.02)}65%{transform:translate(6px,6px)scale(.99)}}@keyframes bubbleFloat5{0%,to{transform:translate(0)scale(1)}40%{transform:translate(6px,-8px)scale(1.03)}72%{transform:translate(-3px,5px)scale(.98)}}@keyframes bubbleFloat6{0%,to{transform:translate(0)scale(1)}35%{transform:translate(-5px,-10px)scale(1.02)}62%{transform:translate(4px,6px)scale(1.01)}}.home-sub-bar{padding:14px 24px;padding-bottom:calc(14px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(16px);z-index:100;background:#fff8f0e0;border-top:1px solid #ff8c4226;justify-content:space-between;align-items:center;gap:12px;display:flex;position:fixed;bottom:0;left:0;right:0}.home-author{color:#8b5e3c;letter-spacing:.1px;font-size:13px;font-weight:700}.home-sub-btn{color:#fff;cursor:pointer;letter-spacing:.3px;white-space:nowrap;background:linear-gradient(135deg,#9b5de5,#7b3fc4);border:none;border-radius:20px;padding:8px 20px;font-size:13px;font-weight:800;transition:opacity .15s,transform .1s}.home-sub-btn:hover{opacity:.9}.home-sub-btn:active{transform:scale(.96)}.home-subscribed{color:#06d6a0;letter-spacing:.2px;font-size:13px;font-weight:700}.ff-page{flex-direction:column;align-items:center;width:100%;height:100%;padding:24px 20px 32px;display:flex;overflow-y:auto}.cover-page{background:linear-gradient(160deg,#fff0f0 0%,#ffe0e5 60%,#ffd0c0 100%);justify-content:center;gap:24px}.cover-bg{pointer-events:none;background:radial-gradient(at 50% 40%,#ff646426 0%,#0000 70%);position:absolute;inset:0}.cover-fingers{gap:8px;margin-bottom:8px;display:flex}.cover-finger{border-radius:50px;flex-direction:column;align-items:center;min-width:52px;padding:12px 10px;animation:1s infinite bounce;display:flex;box-shadow:0 4px 12px #0000001f}.finger-emoji{font-size:28px}.finger-label{color:#fff;margin-top:4px;font-size:10px;font-weight:800}.cover-title{color:#c0002a;text-align:center;text-shadow:0 2px 8px #ff64644d;font-size:30px;font-weight:900}.cover-desc{color:#8b3030;text-align:center;max-width:280px;font-size:16px;font-weight:600}.cover-author{cursor:pointer;opacity:.45;-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:6px;margin-top:8px;padding:8px 16px;transition:opacity .2s;display:flex}.cover-author:active{opacity:.7}.cover-author-avatar{font-size:18px;line-height:1}.cover-author-name{color:#7a3030;letter-spacing:.1px;font-size:13px;font-weight:700}.cover-author-sep{color:#c08080;font-size:12px}.cover-author-link{color:#c05050;letter-spacing:.2px;font-size:12px;font-weight:600}.guide-page{background:linear-gradient(160deg,#fff8e0 0%,#fff0d0 100%);justify-content:center;gap:20px}.hand-outline{justify-content:center;align-items:center;margin:8px 0;display:flex;position:relative}.hand-emoji{filter:drop-shadow(0 8px 20px #ffa0004d);font-size:120px;animation:2.5s ease-in-out infinite float}.hand-glow{background:radial-gradient(circle,#ffc8504d 0%,#0000 70%);border-radius:50%;width:160px;height:160px;animation:2s ease-in-out infinite pulse;position:absolute}.guide-labels{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.guide-label{color:#8b5e00;background:#ffa00026;border:2px solid #ffa00066;border-radius:20px;padding:6px 14px;font-size:14px;font-weight:700;animation:.4s both fadeInUp}.role-page{background:linear-gradient(160deg,#fff5f0 0%,#ffe8e0 100%);gap:24px}.fingers-row{flex-wrap:wrap;justify-content:center;gap:10px;margin:16px 0;display:flex}.finger-btn{background:var(--fc);cursor:pointer;border-radius:50px;flex-direction:column;align-items:center;min-width:58px;padding:14px 10px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 12px #0000001f}.finger-btn:active,.finger-btn.active{transform:scale(1.15);box-shadow:0 8px 24px #0003}.finger-btn.done{opacity:.8}.finger-btn.highlight{animation:.6s infinite pulse;box-shadow:0 0 0 4px #fffc,0 8px 24px #0003}.fb-emoji{font-size:32px}.fb-label{color:#fff;margin-top:4px;font-size:11px;font-weight:800}.role-callout{color:#fff;text-align:center;border-radius:16px;padding:12px 24px;font-size:16px;font-weight:700;animation:.3s fadeInUp;box-shadow:0 4px 16px #00000026}.role-hint{color:#a07050;font-size:15px;font-weight:600}.music-page{background:linear-gradient(160deg,#f0fff8 0%,#e0fff0 100%);gap:16px}.lyric-box{text-align:center;background:#fffc;border-radius:16px;max-width:320px;padding:16px 24px;box-shadow:0 4px 16px #00000014}.lyric-text{color:#1a6b4a;font-size:17px;font-weight:700;line-height:1.5}.feedback-toast{color:#fff;background:#06d6a0;border-radius:16px;padding:10px 20px;font-size:15px;font-weight:700;animation:.3s fadeInUp}.score-badge{color:#fff;background:linear-gradient(135deg,#ffd166,#ff8c42);border-radius:50px;padding:8px 20px;font-size:18px;font-weight:900;box-shadow:0 4px 12px #ff8c004d}.doodle-page{background:#fff8f0;gap:12px;padding-bottom:16px}.doodle-canvas{cursor:crosshair;touch-action:none;border:3px solid #ffd0a0;border-radius:20px;width:100%;max-width:380px;height:260px;box-shadow:0 4px 20px #0000001a}.doodle-toolbar{background:#fffc;border-radius:16px;flex-direction:column;align-items:center;gap:10px;padding:12px 16px;display:flex;box-shadow:0 2px 12px #00000014}.color-row{justify-content:space-between;align-items:center;gap:0;display:flex}.color-dot{cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 0 0 2px #e0e0e0}.color-dot:active,.color-dot.selected{transform:scale(1.25);box-shadow:0 0 0 3px #0000004d}.eraser-btn{background:#f0f0f0}.size-row{align-items:center;gap:10px;display:flex}.size-dot{cursor:pointer;opacity:.6;border-radius:50%;transition:transform .15s}.size-dot.selected{opacity:1;transform:scale(1.2);box-shadow:0 0 0 3px #0003}.result-page{background:linear-gradient(160deg,#fff5f0 0%,#ffe8e0 100%);justify-content:center;gap:24px}.result-card{background:#fff;border-radius:24px;width:100%;max-width:340px;padding:20px;box-shadow:0 8px 32px #ff646426}.result-header{justify-content:center;align-items:center;gap:10px;margin-bottom:16px;display:flex}.result-header h2{color:#c0002a;font-size:20px;font-weight:900}.result-img{border:2px solid #ffd0c0;border-radius:16px;width:100%}.result-placeholder{color:#888;background:#fff5f0;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:180px;font-size:14px;font-weight:600;display:flex}.result-tag{color:#ff8c8c;text-align:center;margin-top:8px;font-size:12px;font-weight:700}.result-actions{flex-direction:column;align-items:center;gap:10px;width:100%;max-width:300px;display:flex}.ff-narration{color:#3d1c00;text-align:center;max-width:300px;font-size:20px;font-weight:800;line-height:1.5}.ff-narration-sub{color:#7a5030;text-align:center;max-width:280px;font-size:16px;font-weight:600}.ff-btn{padding:14px 36px;font-size:18px}.mp-progress-track{background:#ff646426;border-radius:6px;width:100%;max-width:320px;height:6px;margin-bottom:10px;overflow:hidden}.mp-progress-fill{background:linear-gradient(90deg,#ff4d6d,#ff8c42);border-radius:6px;height:100%;transition:width .15s linear}.mp-lyric-wrap{justify-content:center;align-items:center;min-height:72px;padding:0 16px;display:flex}.mp-lyric{color:#1a6b4a;text-align:center;white-space:pre-line;background:#ffffffd9;border-radius:16px;max-width:300px;padding:12px 20px;font-size:17px;font-weight:800;line-height:1.55;animation:.25s both fadeInUp;box-shadow:0 3px 12px #00000012}.mp-lyric-placeholder{color:#a0c8b0;text-align:center;font-size:20px;font-weight:700}.mp-hand-wrap{justify-content:center;align-items:center;width:100%;margin:4px 0;display:flex;position:relative}.music-page{padding-left:8px;padding-right:8px}.mp-tap-burst{pointer-events:none;font-size:18px;font-weight:900;animation:.3s both fadeInUp;position:absolute;top:20px;right:10px}.mp-tap-hint{color:#555;text-align:center;font-size:15px;font-weight:700;animation:.3s both fadeInUp}.mp-score-badge{color:#fff;background:linear-gradient(135deg,#ffd166,#ff8c42);border-radius:50px;margin-top:6px;padding:8px 22px;font-size:18px;font-weight:900;box-shadow:0 4px 12px #ff8c004d}.du-tab-row{gap:8px;margin-bottom:2px;display:flex}.du-tab{color:#c07840;cursor:pointer;background:0 0;border:2px solid #ffd0a8;border-radius:20px;flex:1;max-width:140px;padding:8px 0;font-size:13px;font-weight:800;transition:background .15s,color .15s}.du-tab.active{color:#fff;background:linear-gradient(135deg,#ff8c42,#ff4d6d);border-color:#0000}.doodle-hint{color:#9b6040;text-align:center;min-height:20px;font-size:14px;font-weight:700}.doodle-hand-wrap{justify-content:center;align-items:center;width:100%;padding:0 4px;display:flex}.song-page{background:linear-gradient(160deg,#fff5f0 0%,#ffe8f0 60%,#ffd0e8 100%);gap:0;padding:12px 12px 24px;overflow:hidden}.song-topbar{justify-content:flex-end;align-items:center;width:100%;margin-bottom:8px;display:flex}.song-finger-chips{scrollbar-width:none;flex:1;gap:6px;display:flex;overflow-x:auto}.song-finger-chips::-webkit-scrollbar{display:none}.song-chip{border:2px solid var(--chip-color);cursor:pointer;white-space:nowrap;color:var(--chip-color);background:#ffffffb3;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:5px 10px;font-size:12px;font-weight:800;transition:background .15s,transform .15s;display:flex}.song-chip.has-doodle{background:var(--chip-color);color:#fff}.song-chip:active{transform:scale(.93)}.song-chip-dot{background:currentColor;border-radius:50%;width:8px;height:8px}.song-chip.has-doodle .song-chip-dot{background:#fffc}.song-chip-name{font-size:11px}.song-share-btn{color:#c0406a;cursor:pointer;white-space:nowrap;background:#ffffffe6;border:2.5px solid #ffb0c8;border-radius:22px;padding:10px 20px;font-size:15px;font-weight:900;transition:transform .12s;box-shadow:0 2px 8px #c0406a1f}.song-share-btn:active{transform:scale(.95)}.song-seek-wrap{align-items:center;gap:8px;width:100%;margin-bottom:6px;padding:0 4px;display:flex}.song-seek-time{color:#c06080;text-align:center;flex-shrink:0;min-width:30px;font-size:11px;font-weight:700}.song-seek-track{flex:1;align-items:center;height:20px;display:flex;position:relative}.song-seek-fill{pointer-events:none;z-index:1;background:linear-gradient(90deg,#ff4d6d,#ff8c42);border-radius:6px;height:6px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.song-seek-input{opacity:0;cursor:pointer;-webkit-appearance:none;z-index:2;width:100%;height:100%;margin:0;position:absolute}.song-seek-track:before{content:"";background:#ff649626;border-radius:6px;height:6px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.song-seek-input::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#ff4d6d;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #ff466466}.song-seek-input::-moz-range-thumb{cursor:pointer;background:#ff4d6d;border:none;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #ff466466}.song-seek-input{opacity:1;-webkit-appearance:none;background:0 0}.song-seek-input::-webkit-slider-runnable-track{background:0 0;height:6px}.song-seek-input::-moz-range-track{background:0 0;height:6px}.song-hand-wrap{flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex}.song-sway-wrap{transform-origin:50% 85%;will-change:transform;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.song-lyric-area{justify-content:center;align-items:center;width:100%;min-height:72px;padding:0 12px;display:flex}.song-lyric-card{text-align:center;opacity:.5;background:#ffffffd9;border-radius:16px;max-width:320px;padding:10px 20px;transition:opacity .2s;box-shadow:0 3px 12px #00000012}.song-lyric-card.active{opacity:1}.song-lyric-text{color:#c0002a;white-space:pre-line;margin:0;font-size:16px;font-weight:800;line-height:1.55}.song-controls{align-items:center;gap:14px;padding-top:6px;display:flex}.song-play-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff4d6d,#ff8c42);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:22px;transition:transform .12s;display:flex;box-shadow:0 4px 16px #ff466466}.song-play-btn:active{transform:scale(.92)}.song-doodle-cta{color:#fff;text-align:center;cursor:pointer;background:linear-gradient(135deg,#9b5de5,#c77dff);border:none;border-radius:28px;flex:1;padding:13px 20px;font-size:15px;font-weight:900;transition:transform .12s;box-shadow:0 4px 16px #9b5de559}.song-doodle-cta:active{transform:scale(.96)}.song-doodle-cta.selecting{box-shadow:none;background:linear-gradient(135deg,#888,#aaa)}.song-select-banner{color:#fff;white-space:nowrap;z-index:2;pointer-events:none;background:#9b5de5eb;border-radius:20px;padding:5px 18px;font-size:13px;font-weight:800;animation:.25s both fadeInUp;position:absolute;top:8px;left:50%;transform:translate(-50%)}.song-tap-label{text-align:center;white-space:nowrap;text-shadow:0 4px 20px #00000026;pointer-events:none;z-index:10;background:#ffffffe6;border-radius:24px;padding:14px 32px;font-size:38px;font-weight:900;animation:1.8s forwards tapLabelAnim;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes tapLabelAnim{0%{opacity:0;transform:translate(-50%,-50%)scale(.6)}20%{opacity:1;transform:translate(-50%,-50%)scale(1.08)}35%{opacity:1;transform:translate(-50%,-50%)scale(1)}65%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(.85)}}.doodle-page-new{background:#fff8f2;gap:0;padding:0;overflow:hidden}.dp-header{background:#fffffff2;border-bottom:1.5px solid #ffe0c8;justify-content:space-between;align-items:center;width:100%;padding:12px 16px 10px;display:flex}.dp-back-btn{color:#b07040;cursor:pointer;letter-spacing:-.2px;background:0 0;border:none;padding:6px 4px;font-size:15px;font-weight:800}.dp-back-btn:active{opacity:.6}.dp-done-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#06d6a0,#00b38a);border:none;border-radius:20px;padding:8px 18px;font-size:15px;font-weight:900;transition:transform .12s;box-shadow:0 3px 10px #06d6a059}.dp-done-btn:active{transform:scale(.94)}.dp-name-banner{color:#3d1c00;text-align:center;letter-spacing:-.5px;width:100%;padding:14px 20px 6px;font-size:26px;font-weight:900}.dp-finger-wrap{flex-direction:column;flex:1;justify-content:center;align-items:center;width:100%;min-height:0;padding:8px 0;display:flex;position:relative}.dp-sticker-hint{color:#fff;white-space:nowrap;z-index:1;background:#9b5de5e6;border-radius:12px;padding:4px 14px;font-size:12px;font-weight:800;position:absolute;top:6px;left:50%;transform:translate(-50%)}.finger-detail-svg{touch-action:none;width:auto;height:100%;max-height:320px;display:block}.dp-toolbar{background:#fffffff2;border-top:1.5px solid #ffe0c8;flex-direction:column;flex-shrink:0;gap:8px;width:100%;height:180px;padding:8px 12px 10px;display:flex;overflow:hidden}.dp-tool-tabs{gap:6px;display:flex}.dp-tool-tab{color:#c07840;cursor:pointer;background:0 0;border:2px solid #ffd0a8;border-radius:20px;flex:1;padding:7px 0;font-size:13px;font-weight:800;transition:background .15s,color .15s,border-color .15s}.dp-tool-tab.active{color:#fff;background:linear-gradient(135deg,#ff8c42,#ff4d6d);border-color:#0000}.dp-draw-panel{flex-direction:column;gap:6px;display:flex}.dp-tool-row{align-items:center;gap:6px;display:flex}.dp-mode-btn{cursor:pointer;background:#fff0e0;border:2px solid #ffd0a8;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:17px;transition:background .15s,border-color .15s,transform .12s;display:flex}.dp-mode-btn.active{background:linear-gradient(135deg,#ff8c42,#ff4d6d);border-color:#0000;transform:scale(1.08)}.dp-mode-btn:active{transform:scale(.92)}.dp-tool-spacer{flex:1}.dp-sticker-panel{flex-direction:column;gap:6px;display:flex}.dp-sticker-cats{scrollbar-width:none;gap:5px;padding-bottom:2px;display:flex;overflow-x:auto}.dp-sticker-cats::-webkit-scrollbar{display:none}.dp-sticker-cat{color:#b07040;cursor:pointer;white-space:nowrap;background:0 0;border:2px solid #ffd0a8;border-radius:16px;flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:800;transition:background .15s,color .15s}.dp-sticker-cat.active{color:#fff;background:linear-gradient(135deg,#ff8c42,#ff4d6d);border-color:#0000}.dp-sticker-grid{scrollbar-width:none;flex-wrap:wrap;align-content:flex-start;gap:6px;height:86px;display:flex;overflow:hidden auto}.dp-sticker-grid::-webkit-scrollbar{display:none}.dp-sticker-btn{cursor:pointer;background:#fff5ec;border:2px solid #0000;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:52px;height:52px;transition:transform .12s,border-color .12s,background .12s;display:flex}.dp-sticker-btn.selected{background:#fff0e0;border-color:#ff8c42;transform:scale(1.12)}.dp-sticker-btn:active{transform:scale(.92)}.dp-sticker-label{color:#b07040;font-size:9px;font-weight:800;line-height:1}.dp-action-btn{color:#c07840;cursor:pointer;background:#fff0e0;border:2px solid #ffd0a8;border-radius:16px;padding:7px 14px;font-size:13px;font-weight:800;transition:background .12s,transform .1s}.dp-action-btn:active{background:#ffe0c0;transform:scale(.95)}.hand-svg{width:100%;max-width:420px;display:block}.hf-finger-group{transform-box:fill-box;transform-origin:50% 94%;transition:filter .2s}.hf-finger-0{transform-origin:76% 85%}.hf-finger-group:hover{filter:drop-shadow(0 6px 8px #78461e38)}.hf-finger-shape,.hf-palm-shape{stroke:#c98c63;stroke-width:4px;stroke-linejoin:round}.hf-crease{fill:none;stroke:#925b376b;stroke-width:3px;stroke-linecap:round}.hf-name{pointer-events:none;font-size:18px;font-weight:800}@keyframes hfHighlightPulse{0%,to{opacity:.5;r:34px}50%{opacity:1;r:38px}}.hf-highlight-ring{animation:.8s ease-in-out infinite hfHighlightPulse}.af-page{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;gap:20px;width:100%;height:100%;padding:28px 20px 36px;display:flex;overflow-y:auto}.af-cover{background:linear-gradient(160deg,#fff5e0 0%,#ffe8c0 100%);justify-content:center;gap:20px}.af-cover-scene{gap:12px;margin-bottom:8px;display:flex}.af-scene-item{filter:drop-shadow(0 4px 8px #0000001a);font-size:40px;animation:1s infinite bounce}.af-title{color:#7a4000;text-align:center;font-size:28px;font-weight:900;line-height:1.2}.af-subtitle{color:#a06020;font-size:16px;font-weight:700}.af-desc{color:#8b6030;text-align:center;font-size:15px}.af-btn{padding:14px 36px;font-size:18px}.af-progress-row{align-self:center;gap:8px;display:flex}.af-dot{background:#00000026;border-radius:50%;width:10px;height:10px;transition:all .3s}.af-dot.done{background:#00000047}.af-dot.active{border-radius:5px;width:26px}.af-bubble{color:#333;text-align:center;background:#fff;border-radius:18px;max-width:250px;padding:12px 18px;font-size:15px;font-weight:700;line-height:1.45;position:relative;box-shadow:0 3px 18px #0000001a}.af-bubble-top:after{content:"";border:7px solid #0000;border-top-color:#fff;position:absolute;bottom:-13px;left:50%;transform:translate(-50%)}.af-bubble-thanks{background:linear-gradient(135deg,#fffde7,#fff);font-size:17px}.af-bubble-thanks:after{content:"";border:7px solid #0000;border-top-color:#fffde7;position:absolute;bottom:-13px;left:50%;transform:translate(-50%)}.af-mum-scene{flex-direction:column;align-items:center;gap:6px;width:100%;padding:8px 0;display:flex;overflow:hidden}.af-mum-emoji{filter:drop-shadow(0 4px 14px #0000001f);font-size:84px;line-height:1}@keyframes afCowEnter{0%{transform:translate(130%)}12%{transform:translate(95%,-36px)}24%{transform:translate(65%,28px)}36%{transform:translate(38%,-32px)}50%{transform:translate(18%,22px)}62%{transform:translate(6%,-18px)}74%{transform:translateY(10px)}84%{transform:translate(-2%,-5px)}92%{transform:translate(1%,2px)}to{transform:translate(0)}}.af-mum-entering{animation:1.05s cubic-bezier(.22,.61,.36,1) forwards afCowEnter}@keyframes afWorry{0%,to{transform:rotate(0)}20%{transform:rotate(-9deg)translate(-4px)}40%{transform:rotate(9deg)translate(4px)}60%{transform:rotate(-5deg)translate(-2px)}80%{transform:rotate(5deg)translate(2px)}}.af-mum-worry{animation:2s ease-in-out infinite afWorry}@keyframes afBubblePop{0%{opacity:0;transform:translateY(10px)scale(.92)}60%{opacity:1;transform:translateY(-3px)scale(1.03)}to{opacity:1;transform:translateY(0)scale(1)}}.af-bubble-hidden{opacity:0;pointer-events:none}.af-bubble-visible{animation:.45s forwards afBubblePop}@keyframes afFadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.af-intro-reveal{animation:.5s forwards afFadeUp}.af-intro-hidden{opacity:0;pointer-events:none}.af-intro-label{text-align:center;margin:0;font-size:18px;font-weight:700}.af-cta-btn{color:#fff;cursor:pointer;letter-spacing:.2px;-webkit-tap-highlight-color:transparent;border:none;border-radius:30px;padding:15px 44px;font-size:16px;font-weight:800;transition:transform .12s,box-shadow .12s;box-shadow:0 4px 20px #00000026}.af-cta-btn:active{transform:scale(.96);box-shadow:0 2px 10px #0000001f}.af-unified{box-sizing:border-box;flex-direction:column;align-items:center;gap:0;width:100%;height:100%;padding:0;display:flex;overflow:hidden}.af-busy-top{background:linear-gradient(#daeefb 0%,#e6f5e0 55%,#c5e0be 100%);flex:1;width:100%;min-height:0;position:relative;overflow:hidden}.af-busy-top:before{content:"🌱🌿🌱🌿🌱🌿🌱🌿🌱🌿";text-align:center;letter-spacing:4px;opacity:.55;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:18px;position:absolute;bottom:3px;left:0;right:0}.af-busy-top:after{content:"☀️";opacity:.55;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:26px;position:absolute;top:8px;right:12px}.af-bottom-strip{-webkit-backdrop-filter:blur(14px);box-sizing:border-box;background:#ffffff8c;border-top:1px solid #ffffffb3;flex-shrink:0;justify-content:center;align-items:center;width:100%;padding:12px 24px 20px;display:flex;overflow:hidden}.af-bottom-inner{flex-direction:column;align-items:flex-start;gap:10px;display:flex}.af-cards-row{align-items:center;gap:20px;display:flex}.af-animal-card{background:#ffffffe0;border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:88px;height:88px;display:flex;position:relative;box-shadow:0 4px 18px #0000001c}.af-card-emoji{-webkit-user-select:none;user-select:none;font-size:52px;line-height:1}.af-animal-card{-webkit-tap-highlight-color:transparent}.af-parent-tappable{cursor:pointer}.af-parent-tappable:active{transform:scale(.91)}@keyframes afParentPulse{0%{box-shadow:0 0 #0000002e}55%{box-shadow:0 0 0 10px #0000}to{box-shadow:0 0 #0000}}.af-parent-pulse{animation:.4s afParentPulse}@keyframes afWalkIn{0%{transform:translate(110vw)translateY(0)}20%{transform:translate(68vw)translateY(-16px)}36%{transform:translate(44vw)translateY(0)}50%{transform:translate(24vw)translateY(-14px)}62%{transform:translate(10vw)translateY(0)}72%{transform:translate(3vw)translateY(-9px)}80%{transform:translate(0)translateY(0)}87%{transform:translate(-4px)translateY(-5px)}93%{transform:translate(2px)translateY(0)}97%{transform:translate(-1px)}to{transform:translate(0)translateY(0)}}.af-parent-slide{animation:.75s cubic-bezier(.22,.61,.36,1) both afWalkIn}.af-slot-pre{opacity:0;pointer-events:none}@keyframes afSlotAppear{0%{opacity:0;transform:scale(.55)}65%{opacity:1;transform:scale(1.12)}to{opacity:1;transform:scale(1)}}.af-slot-appear{animation:.42s cubic-bezier(.34,1.56,.64,1) both afSlotAppear}.af-baby-slot{box-shadow:none;background:#ffffff61;border:2.5px dashed #00000038}.af-baby-slot .af-slot-q{opacity:.35;color:#374151;font-size:32px;font-weight:900}.af-slot-filled{background:#ffffffe0;border:2px solid #fffffff2;box-shadow:0 4px 18px #0000001c}@keyframes afBabyLand{0%{opacity:0;transform:scale(.4)}65%{opacity:1;transform:scale(1.18)}to{opacity:1;transform:scale(1)}}.af-baby-arrived{animation:.5s cubic-bezier(.34,1.56,.64,1) both afBabyLand}.af-bubble-parent:after{left:44px;transform:none}.af-slot-heart{opacity:0;flex-shrink:0;font-size:28px;line-height:1}@keyframes afHeartPop{0%{opacity:0;transform:scale(0)}60%{opacity:1;transform:scale(1.4)}to{opacity:1;transform:scale(1)}}.af-heart-pop{opacity:1;animation:.45s cubic-bezier(.34,1.56,.64,1) .15s both afHeartPop}.af-found-caption{text-align:center;flex-shrink:0;min-height:24px;margin:6px 0 0;padding:0 20px;font-size:15px;font-weight:700;line-height:1.5}.af-found-caption strong{font-weight:900}.af-next-slot{flex-shrink:0;justify-content:center;align-items:center;height:72px;padding-bottom:8px;display:flex}.af-item-gone{cursor:default;pointer-events:none;box-shadow:none!important;background:0 0!important;border:2.5px dashed #0003!important;border-radius:50%!important}.af-item-gone .af-item-emoji{opacity:0}.af-flying{pointer-events:none;z-index:9999;will-change:transform;font-size:46px;line-height:1;position:fixed;transform:translate(-50%,-50%)}.af-search-wrap{justify-content:flex-start;gap:0;padding:0}.af-item{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff9;border:2px solid #ffffffd9;border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;transition:transform .1s;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 10px #0000001a}.af-item:active:not(.af-item-ok){transform:translate(-50%,-50%)scale(.91)}.af-item-emoji{pointer-events:none;-webkit-user-select:none;user-select:none;font-size:38px;line-height:1}.af-item-deco{box-shadow:none;cursor:default;background:#ffffff61;border-color:#ffffff80}@keyframes afOk{0%{transform:translate(-50%,-50%)scale(1)}35%{transform:translate(-50%,-50%)scale(1.65)}60%{transform:translate(-50%,-50%)scale(1.45)}to{transform:translate(-50%,-50%)scale(1.5)}}.af-item-ok{z-index:10;animation:.75s cubic-bezier(.34,1.56,.64,1) forwards afOk;background:#dcfce7eb!important;border-color:#22c55e!important}@keyframes afNo{0%,to{transform:translate(-50%,-50%)}20%{transform:translate(calc(-50% - 8px),-50%)}40%{transform:translate(calc(8px - 50%),-50%)}60%{transform:translate(calc(-50% - 5px),-50%)}80%{transform:translate(calc(5px - 50%),-50%)}}.af-item-no{animation:.5s afNo;background:#fee2e2eb!important;border-color:#ef4444!important}.af-badge{pointer-events:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:900;display:flex;position:absolute;top:-10px;right:-10px}.af-badge-ok{color:#fff;background:#22c55e}.af-badge-no{color:#fff;background:#ef4444}.af-search-hint{color:#6b7280;text-align:center;box-sizing:border-box;background:#ffffffa6;flex-shrink:0;width:100%;margin:0;padding:10px 20px 12px;font-size:13px;font-weight:600}.af-reunion{align-items:center;gap:14px;display:flex}@keyframes afPopIn{0%{opacity:0;transform:scale(.25)}to{opacity:1;transform:scale(1)}}.af-reu-mum{font-size:76px;animation:.45s cubic-bezier(.34,1.56,.64,1) .1s both afPopIn}.af-reu-heart{font-size:36px;animation:.45s cubic-bezier(.34,1.56,.64,1) .3s both afPopIn}.af-reu-baby{font-size:64px;animation:.45s cubic-bezier(.34,1.56,.64,1) .5s both afPopIn}.af-found-card{text-align:center;color:#1f2937;background:#ffffffb8;border-radius:18px;max-width:300px;padding:16px 22px;font-size:17px;font-weight:600;line-height:1.65}.af-found-card strong{font-weight:900}.af-interlude{background:linear-gradient(160deg,#f5f0ff 0%,#ede9fe 100%)}.af-interlude-emoji{font-size:72px}.af-interlude-title{color:#1f2937;text-align:center;margin:0;font-size:22px;font-weight:900}.af-interlude-sub{color:#6b7280;text-align:center;margin:0;font-size:15px;line-height:1.65}.af-read-pg{box-sizing:border-box;flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.af-read-picture{aspect-ratio:1;flex-shrink:0;justify-content:center;align-items:center;gap:22px;width:100%;max-height:55vh;display:flex;position:relative}.af-pic-arrow{-webkit-backdrop-filter:blur(6px);color:#374151;cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:2;background:#fff9;border:none;justify-content:center;align-items:center;width:34px;height:56px;font-size:22px;font-weight:900;transition:background .15s,transform .1s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.af-pic-arrow:disabled{opacity:.18;cursor:default}.af-pic-arrow:active:not(:disabled){background:#ffffffe0;transform:translateY(-50%)scale(.93)}.af-pic-prev{border-radius:0 14px 14px 0;left:0}.af-pic-next{border-radius:14px 0 0 14px;right:0}.af-pic-badge{color:#fff;letter-spacing:.3px;pointer-events:none;-webkit-user-select:none;user-select:none;background:#00000038;border-radius:10px;padding:3px 10px;font-size:12px;font-weight:700;position:absolute;bottom:10px;right:12px}.af-read-animal{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffffbf;border:2px solid #ffffffeb;border-radius:26px;justify-content:center;align-items:center;width:120px;height:120px;transition:transform .12s;display:flex;position:relative;box-shadow:0 6px 24px #0000001a}.af-read-animal:active{transform:scale(.9)}.af-read-emoji{font-size:68px}.af-read-emoji-sm{font-size:58px}.af-read-heart{flex-shrink:0;font-size:34px}@keyframes afSoundFloat{0%{opacity:0;transform:translate(-50%)translateY(0)scale(.8)}25%{opacity:1;transform:translate(-50%)translateY(-14px)scale(1.1)}to{opacity:0;transform:translate(-50%)translateY(-30px)scale(.9)}}.af-sound-pop{color:#374151;white-space:nowrap;pointer-events:none;background:#fff;border-radius:10px;padding:4px 12px;font-size:14px;font-weight:800;animation:.9s forwards afSoundFloat;position:absolute;top:-8px;left:50%;box-shadow:0 2px 8px #0000001a}.af-read-content{-webkit-backdrop-filter:blur(12px);box-sizing:border-box;background:#fff9;border-top:1px solid #ffffffb8;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:22px;padding:20px 28px 28px;display:flex}.af-text-row{align-items:flex-start;gap:12px;width:100%;display:flex}.af-tts-btn{cursor:pointer;opacity:.65;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-shrink:0;margin-top:2px;padding:2px;font-size:26px;transition:opacity .12s,transform .1s}.af-tts-btn:active{opacity:1;transform:scale(.88)}.af-page-text{color:#1f2937;white-space:pre-line;margin:0;font-size:20px;font-weight:700;line-height:1.65}.af-rec-btn{color:#374151;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:2px solid #e5e7eb;border-radius:30px;width:100%;max-width:320px;padding:15px 24px;font-size:15px;font-weight:800;transition:all .15s;box-shadow:0 2px 14px #00000012}.af-rec-btn:active{transform:scale(.96)}@keyframes afRecPulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 9px #ef444400}}.af-rec-on{color:#dc2626;background:#fee2e2;border-color:#ef4444;animation:1.2s infinite afRecPulse}.af-rec-done{color:#16a34a;background:#dcfce7;border-color:#22c55e}.af-share-pg{background:linear-gradient(160deg,#fff9e6 0%,#fff0d0 100%);gap:16px}.af-ghost-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;margin-top:4px;padding:8px;font-size:14px;transition:color .12s}.af-ghost-btn:hover{color:#6b7280}.af-bgm-btn{z-index:9997;-webkit-backdrop-filter:blur(10px);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffffd1;border:none;border-radius:20px;align-items:center;gap:5px;padding:7px 12px 7px 10px;transition:background .2s,box-shadow .2s,transform .1s;display:flex;position:fixed;top:14px;right:14px;box-shadow:0 2px 12px #00000021}.af-bgm-btn:active{transform:scale(.91)}.af-bgm-on{background:#9b5de524;box-shadow:0 2px 14px #9b5de540}.af-bgm-icon{font-size:16px;line-height:1}.af-bgm-label{color:#6b7280;letter-spacing:.1px;font-size:12px;font-weight:700}.af-bgm-on .af-bgm-label{color:#7b3fc4}.af-bgm-dot{background:#d1d5db;border-radius:50%;flex-shrink:0;width:7px;height:7px;transition:background .2s}@keyframes afDotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.75)}}.af-bgm-dot-on{background:#22c55e;animation:1.6s infinite afDotPulse}.ft-page{flex-direction:column;align-items:center;width:100%;height:100%;padding:24px 20px 36px;display:flex;overflow-y:auto}.ft-cover{background:linear-gradient(160deg,#e8fff4 0%,#d0ffe8 100%);justify-content:center;gap:24px}.ft-tree-visual{justify-content:center;align-items:center;display:flex;position:relative}.ft-tree-emoji{filter:drop-shadow(0 8px 24px #06d6a04d);font-size:100px;animation:3s ease-in-out infinite float}.ft-tree-photos{gap:4px;font-size:22px;animation:2s ease-in-out infinite pulse;display:flex;position:absolute;top:10px}.ft-title{color:#005c40;text-align:center;font-size:28px;font-weight:900}.ft-subtitle{color:#00906a;font-size:16px;font-weight:700}.ft-btn{padding:14px 36px;font-size:18px}.ft-narration{color:#005c40;text-align:center;max-width:300px;font-size:20px;font-weight:800}.ft-add{background:linear-gradient(160deg,#f0fff8 0%,#e0fff0 100%);gap:16px}.ft-roles-grid{flex-wrap:wrap;justify-content:center;gap:10px;max-width:340px;display:flex}.ft-role-chip{cursor:pointer;background:#fffc;border:3px solid #0000;border-radius:16px;flex-direction:column;align-items:center;min-width:72px;padding:12px 10px;transition:transform .15s,border-color .15s;display:flex;position:relative;box-shadow:0 2px 8px #00000014}.ft-role-chip:active{transform:scale(.93)}.ft-role-chip.active{border-color:var(--rc);box-shadow:0 4px 16px #0000001f}.ft-role-emoji{font-size:32px}.ft-role-label{color:#555;margin-top:4px;font-size:12px;font-weight:700}.ft-check{background:var(--rc);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:800;display:flex;position:absolute;top:-6px;right:-6px}.ft-names-section{background:#fffc;border-radius:16px;flex-direction:column;gap:10px;width:100%;max-width:340px;padding:16px;display:flex}.ft-section-label{color:#888;margin-bottom:4px;font-size:13px;font-weight:700}.ft-name-row{align-items:center;gap:10px;display:flex}.ft-name-emoji{font-size:24px}.ft-name-input{border:2px solid #e0e0e0;border-radius:10px;outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:15px;transition:border-color .2s}.ft-name-input:focus{border-color:#06d6a0}.ft-editor{background:linear-gradient(160deg,#f0fff8 0%,#e8fff0 100%);gap:12px}.ft-tree-container{background:linear-gradient(#e8fff4 0%,#c8f5e0 100%);border:3px solid #a8e6cf;border-radius:20px;flex-direction:column;justify-content:space-around;align-items:center;width:100%;max-width:360px;height:260px;padding:12px 8px;display:flex;position:relative;overflow:hidden}.ft-tree-svg{width:100%;height:100%;position:absolute;inset:0}.ft-row{z-index:1;justify-content:center;gap:16px;display:flex;position:relative}.ft-member-node{flex-direction:column;align-items:center;gap:4px;display:flex}.ft-member-avatar{border:3px solid var(--mcolor,#06d6a0);background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;display:flex;box-shadow:0 3px 10px #00000026}.ft-member-name{color:#005c40;text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:60px;font-size:10px;font-weight:800;overflow:hidden}.ft-deco{cursor:pointer;z-index:2;-webkit-user-select:none;user-select:none;font-size:20px;transition:transform .15s;position:absolute}.ft-deco:active{transform:scale(.7)}.ft-decos-bar{background:#fffc;border-radius:16px;width:100%;max-width:360px;padding:12px 16px}.ft-decos-row{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:6px;display:flex}.ft-deco-btn{cursor:pointer;font-size:26px;transition:transform .15s}.ft-deco-btn:active{transform:scale(.8)}.ft-record{background:linear-gradient(160deg,#f0fff8 0%,#e0fff0 100%);gap:8px}.ft-record-list{flex-direction:column;gap:8px;width:100%;max-width:380px;display:flex}.ft-record-row{background:#fff;border-radius:14px;align-items:center;gap:10px;padding:10px 12px;display:flex;box-shadow:0 2px 8px #0000000f}.ft-rec-avatar{border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;display:flex}.ft-rec-script{flex:1;min-width:0}.ft-rec-name{color:#333;font-size:13px;font-weight:800}.ft-rec-text{color:#888;font-size:12px;font-weight:500}.ft-rec-controls{flex-shrink:0;gap:6px;display:flex}.ft-rec-btn{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;transition:background .15s;display:flex}.ft-rec-btn.play{color:#fff;background:#06d6a0}.ft-rec-btn.stop{color:#fff;background:#ff4d6d;animation:1s infinite pulse}.ft-rec-btn.mic{background:#f0f0f0}.ft-share{background:linear-gradient(160deg,#e8fff4 0%,#d0ffe8 100%);justify-content:center;gap:24px}.ft-share-card{background:#fff;border-radius:24px;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:340px;padding:24px 20px;display:flex;box-shadow:0 8px 32px #06d6a026}.ft-share-tree{font-size:52px;animation:3s ease-in-out infinite float}.ft-share-card h2{color:#005c40;font-size:20px;font-weight:900}.ft-share-sub{color:#777;font-size:14px;font-weight:600}.ft-share-members{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.ft-share-member{flex-direction:column;align-items:center;gap:4px;display:flex}.ft-share-mname{color:#555;font-size:11px;font-weight:700}.ft-share-tag{color:#06d6a0;font-size:12px;font-weight:700}.ft-share-actions{flex-direction:column;align-items:center;gap:10px;width:100%;max-width:300px;display:flex}.du-page{flex-direction:column;align-items:center;width:100%;height:100%;padding:24px 20px 36px;display:flex;overflow-y:auto}.du-cover{background:linear-gradient(160deg,#fffbe0 0%,#fff0c0 100%);justify-content:center;gap:20px}.du-cover-family{gap:16px;margin-bottom:8px;display:flex}.du-char{justify-content:center;align-items:flex-end;animation:1.2s infinite bounce;display:flex;position:relative}.du-char-emoji{font-size:52px}.du-hat{font-size:32px;animation:2s ease-in-out infinite float;position:absolute;top:-12px}.du-title{color:#6b4200;text-align:center;font-size:28px;font-weight:900;line-height:1.2}.du-subtitle{color:#a07020;font-size:16px;font-weight:700}.du-desc{color:#8b6030;text-align:center;max-width:280px;font-size:14px}.du-btn{padding:14px 36px;font-size:18px}.du-photo-pick{background:linear-gradient(160deg,#fffbe0 0%,#fff5d0 100%);gap:24px}.du-narration{color:#3d2000;text-align:center;font-size:20px;font-weight:800}.du-photo-options{flex-direction:column;gap:12px;width:100%;max-width:320px;display:flex}.du-option-card{cursor:pointer;background:#fff;border:3px solid #0000;border-radius:20px;align-items:center;gap:16px;padding:20px 24px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 16px #00000014}.du-option-card:active{transform:scale(.97)}.du-option-card.demo{background:#fffbe8;border-color:#ffd166}.du-option-label{color:#3d2000;font-size:16px;font-weight:800}.du-option-sub{color:#888;margin-top:2px;font-size:12px;font-weight:500}.du-editor{background:#fffbe0;gap:10px;padding-bottom:16px}.du-canvas{cursor:crosshair;touch-action:none;border:3px solid #ffd166;border-radius:16px;width:100%;max-width:380px;height:230px;display:block;box-shadow:0 4px 20px #0000001a}.du-caption-row{background:#fffc;border-radius:12px;align-items:center;gap:8px;width:100%;max-width:380px;padding:8px 12px;display:flex}.du-caption-text{color:#6b4200;flex:1;font-size:14px;font-weight:700}.du-icon-btn{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:background .15s;display:flex}.du-icon-btn:active{background:#e0e0e0;transform:scale(.9)}.du-icon-btn.del{background:#ffe8e8}.du-sticker-panel{background:#ffffffd9;border-radius:16px;width:100%;max-width:380px;padding:10px}.du-cat-tabs{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.du-cat-tab{cursor:pointer;color:#8b6030;background:0 0;border:2px solid #ffd166;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700;transition:background .15s}.du-cat-tab.active{color:#3d2000;background:#ffd166}.du-stickers-row{flex-wrap:wrap;justify-content:flex-start;gap:8px;display:flex}.du-sticker-btn{cursor:pointer;font-size:32px;line-height:1;transition:transform .15s}.du-sticker-btn:active{transform:scale(.8)}.du-share{background:linear-gradient(160deg,#fffbe0 0%,#fff0c0 100%);justify-content:center;gap:24px}.du-share-card{background:#fff;border:4px solid #ffd166;border-radius:24px;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:360px;padding:20px;display:flex;box-shadow:0 8px 32px #f2c94c33}.du-share-header{align-items:center;gap:10px;display:flex}.du-share-header h2{color:#6b4200;font-size:18px;font-weight:900}.du-share-img{border:2px solid #ffe8a0;border-radius:12px;width:100%}.du-share-placeholder{background:#fff8e0;border-radius:12px;justify-content:center;align-items:center;width:100%;height:160px;font-size:60px;display:flex}.du-share-tag{color:#f2c94c;font-size:12px;font-weight:700}.du-share-actions{flex-direction:column;align-items:center;gap:10px;width:100%;max-width:300px;display:flex}.admin-page{background:#f3f4f6;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.admin-topbar{color:#fff;background:#1f2937;justify-content:space-between;align-items:center;height:52px;padding:0 24px;display:flex}.admin-topbar h1{letter-spacing:.3px;margin:0;font-size:15px;font-weight:700}.admin-logout{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;padding:5px 14px;font-size:12px;font-weight:600;transition:background .15s}.admin-logout:hover{background:#fff3}.admin-body{max-width:1000px;margin:0 auto;padding:24px}.admin-cards{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}@media (width<=640px){.admin-cards{grid-template-columns:repeat(2,1fr)}}.admin-card{background:#fff;border-radius:12px;padding:18px 20px;box-shadow:0 1px 4px #00000012}.admin-card-label{text-transform:uppercase;letter-spacing:.6px;color:#9ca3af;margin-bottom:6px;font-size:11px;font-weight:700}.admin-card-value{color:#111827;font-size:28px;font-weight:800;line-height:1}.admin-filters{gap:6px;margin-bottom:16px;display:flex}.admin-filter-btn{color:#6b7280;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:600;transition:all .12s}.admin-filter-btn.active{color:#fff;background:#1f2937;border-color:#1f2937}.admin-table-wrap{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #00000012}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;background:#f9fafb;border-bottom:1px solid #f3f4f6;padding:10px 16px;font-size:11px;font-weight:700}.admin-table td{color:#374151;border-bottom:1px solid #f9fafb;padding:12px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#f9fafb}.admin-page-name{color:#1f2937;font-family:monospace;font-weight:600}.admin-null{color:#d1d5db}.admin-login{background:#f3f4f6;justify-content:center;align-items:center;min-height:100vh;display:flex}.admin-login-card{background:#fff;border-radius:16px;flex-direction:column;gap:16px;width:320px;padding:36px 40px;display:flex;box-shadow:0 4px 24px #00000014}.admin-login-card h2{color:#1f2937;text-align:center;margin:0;font-size:20px;font-weight:800}.admin-login-card input{box-sizing:border-box;border:1.5px solid #e5e7eb;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:15px;transition:border-color .15s}.admin-login-card input:focus{border-color:#1f2937}.admin-login-btn{color:#fff;cursor:pointer;background:#1f2937;border:none;border-radius:8px;width:100%;padding:11px;font-size:14px;font-weight:700;transition:background .15s}.admin-login-btn:hover{background:#374151}.admin-login-btn:disabled{opacity:.5;cursor:not-allowed}.admin-login-error{color:#ef4444;text-align:center;font-size:13px}.admin-tabs{gap:6px;margin-bottom:20px;display:flex}.admin-tab-btn{color:#6b7280;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:700;transition:all .12s;display:flex}.admin-tab-btn.active{color:#fff;background:#1f2937;border-color:#1f2937}.admin-tab-badge{color:#fff;text-align:center;background:#9b5de5;border-radius:10px;min-width:20px;padding:1px 7px;font-size:11px;font-weight:800}.admin-sub-summary{align-items:baseline;gap:6px;margin-bottom:16px;display:flex}.admin-sub-count{color:#1f2937;font-size:36px;font-weight:900}.admin-sub-count-label{color:#9ca3af;font-size:14px;font-weight:600}.admin-loading{text-align:center;color:#9ca3af;padding:60px 0;font-size:14px}
