*{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{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}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)}30%{transform:translateY(-16px)}60%{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{flex-direction:column;align-items:center;width:100%;height:100%;padding:24px 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-intro-page{background:linear-gradient(160deg,#f0fff0 0%,#e0ffe8 100%);justify-content:center;gap:24px}.af-intro-visual{align-items:center;gap:20px;font-size:52px;display:flex}.af-house{animation:2.5s ease-in-out infinite float}.af-farm{animation:2.5s ease-in-out .5s infinite float}.af-arrow{color:#4a904a;font-size:28px;font-weight:900}.af-narration-block{text-align:center;background:#ffffffb3;border-radius:20px;flex-direction:column;gap:10px;padding:20px;display:flex;box-shadow:0 4px 16px #0000000f}.af-narration{color:#3d2000;text-align:center;font-size:20px;font-weight:800}.af-narration-small{color:#7a5020;font-size:15px;font-weight:600}.af-book-page{justify-content:center;gap:20px}.af-progress{gap:8px;margin-bottom:8px;display:flex}.af-progress-dot{background:#ddd;border-radius:50%;width:10px;height:10px;transition:background .3s}.af-progress-dot.done{background:#ff8c42}.af-progress-dot.active{background:#ff4d6d;transform:scale(1.3)}.af-book-narration{text-align:center;max-width:300px;font-size:18px;font-weight:700;line-height:1.6}.af-animal-pair{align-items:center;gap:16px;display:flex}.af-animal-card{cursor:pointer;background:#fffc;border-radius:20px;flex-direction:column;align-items:center;min-width:100px;padding:20px 16px;transition:transform .15s;display:flex;position:relative;box-shadow:0 4px 16px #0000001a}.af-animal-card:active{transform:scale(.93)}.af-animal-emoji{font-size:64px;line-height:1}.af-animal-label{color:#fff;border-radius:20px;margin-top:8px;padding:4px 12px;font-size:13px;font-weight:800}.af-sound-bubble{color:#fff;white-space:nowrap;background:#ff8c42;border-radius:12px;padding:4px 10px;font-size:13px;font-weight:800;animation:.2s fadeInUp;position:absolute;top:-16px;right:-10px}.af-family-heart{font-size:28px}.af-tap-hint{color:#888;font-size:13px;font-weight:600}.af-quiz-page{background:linear-gradient(160deg,#fff8e0 0%,#fff0c0 100%);gap:16px}.af-feedback{border-radius:12px;padding:10px 20px;font-size:15px;font-weight:700;animation:.3s fadeInUp}.af-feedback.correct{color:#fff;background:#06d6a0}.af-feedback.wrong{color:#fff;background:#ff8c8c}.af-quiz-area{gap:16px;width:100%;max-width:360px;display:flex}.af-quiz-col{flex-direction:column;flex:1;gap:8px;display:flex}.af-col-label{color:#888;text-align:center;margin-bottom:4px;font-size:13px;font-weight:800}.af-quiz-card{cursor:pointer;background:#fff;border:3px solid #0000;border-radius:16px;flex-direction:column;align-items:center;padding:12px 8px;transition:transform .15s,border-color .15s;display:flex;box-shadow:0 2px 8px #00000014}.af-quiz-card:active{transform:scale(.95)}.af-quiz-card.sel{border-color:#ff8c42;box-shadow:0 4px 16px #ff8c424d}.af-quiz-name{color:#555;margin-top:4px;font-size:12px;font-weight:700}.af-quiz-done{flex-direction:column;align-items:center;gap:12px;margin-top:20px;display:flex}.af-narration-page{background:linear-gradient(160deg,#f0f8ff 0%,#e8f4ff 100%);gap:8px}.af-lines-list{flex-direction:column;gap:8px;width:100%;max-width:380px;display:flex}.af-line-row{background:#fff;border-radius:14px;align-items:center;gap:10px;padding:10px 14px;display:flex;box-shadow:0 2px 8px #0000000f}.af-line-emoji{flex-shrink:0;font-size:22px}.af-line-text{color:#2d2d2d;flex:1;font-size:14px;font-weight:600}.af-line-actions{flex-shrink:0;gap:6px;display:flex}.af-icon-btn{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:background .15s;display:flex}.af-icon-btn:active{background:#e0e0e0;transform:scale(.9)}.af-icon-btn.rec{color:#fff;background:#ff4d6d;animation:1s infinite pulse}.af-share-page{background:linear-gradient(160deg,#fff5e0 0%,#ffe8c0 100%);justify-content:center;gap:24px}.af-share-card{background:#fff;border-radius:24px;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:340px;padding:28px 24px;display:flex;box-shadow:0 8px 32px #ff8c4226}.af-share-card h2{color:#7a4000;font-size:22px;font-weight:900}.af-share-text{color:#555;text-align:center;font-size:15px;font-weight:600}.af-animal-row{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.af-share-tag{color:#ff8c42;font-size:12px;font-weight:700}.af-share-actions{flex-direction:column;align-items:center;gap:10px;width:100%;max-width:300px;display:flex}.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}
