:root{color-scheme:dark;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--theme-primary: #ff6b6b;--theme-primary-light: #ff7b7b;--theme-primary-dark: #ee5a6f;--theme-secondary: #c44569;--theme-accent: #ff6a7f;--theme-gradient: #ff6b6b, #ee5a6f, #c44569;--theme-gradient-light: rgba(255, 107, 107, .1), rgba(238, 90, 111, .1);--theme-text: rgba(255, 255, 255, .95);--theme-text-secondary: rgba(255, 255, 255, .7);--theme-background: #242424;--theme-card-bg: rgba(26, 26, 26, .9);--theme-border: rgba(255, 107, 107, .3);--page-max: 1120px;--page-pad-x: clamp(1rem, 4vw, 2rem);--page-pad-y: clamp(2.25rem, 5vw, 3.75rem);--section-gap: clamp(1.25rem, 3vw, 2.25rem);--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--shadow-1: 0 10px 30px var(--theme-primary-rgba-1);--shadow-2: 0 18px 50px var(--theme-primary-rgba-2);--focus-ring: 0 0 0 3px rgba(var(--theme-primary-rgb, 255, 107, 107), .35);--christmas-red-rgb: 239, 68, 68;--christmas-green-rgb: 34, 197, 94;--christmas-gold-rgb: 251, 191, 36}*,*:before,*:after{box-sizing:border-box}html{min-height:100%;background:var(--theme-background)}body{margin:0;min-width:320px;min-height:100vh;color:var(--theme-text);position:relative;background:radial-gradient(900px 520px at 15% 88%,rgba(var(--christmas-red-rgb),.08),transparent 62%),radial-gradient(900px 520px at 85% 90%,rgba(var(--christmas-green-rgb),.08),transparent 62%),radial-gradient(800px 460px at 50% 110%,rgba(var(--christmas-gold-rgb),.08),transparent 60%),var(--theme-background)}#root{width:100%;min-height:100vh}a{color:inherit;text-decoration:none}a:hover{color:var(--theme-primary)}button,input,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}.visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.animated-background{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1000000;pointer-events:none;background:transparent}.home-container{max-width:var(--page-max);margin:0 auto;padding:var(--page-pad-y) var(--page-pad-x)}.home-hero{margin-bottom:var(--section-gap)}.home-title{font-size:clamp(2.4rem,4vw,3.2rem);font-weight:650;margin-bottom:.75rem;background:linear-gradient(135deg,var(--theme-primary),var(--theme-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;line-height:1.3}.home-subtitle{font-size:1.05rem;color:#fff9;font-weight:350;line-height:1.5}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.feature-card{background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid var(--theme-border);border-radius:var(--radius-lg);padding:2rem;text-decoration:none;color:inherit;transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column;gap:.75rem;position:relative;overflow:hidden}.feature-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:.6rem 1.2rem;border-radius:8px;font-size:.85rem;font-weight:500;letter-spacing:.01em;color:#fff;background:#000;border:1px solid rgba(255,255,255,.2);box-shadow:0 2px 16px #00000080;z-index:10;pointer-events:none;white-space:nowrap}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--theme-primary),var(--theme-secondary));opacity:0;transition:opacity .3s ease}.feature-card:hover{background:linear-gradient(135deg,#ffffff14,#ffffff0a);border-color:var(--theme-primary);transform:translateY(-4px);box-shadow:var(--shadow-1)}.feature-card:hover:before{opacity:1}.feature-card.coming-soon{opacity:.85;cursor:pointer;border-style:dashed;border-width:1.5px}.feature-card.coming-soon:hover{opacity:1;transform:translateY(-2px);background:linear-gradient(135deg,#ffffff12,#ffffff08);border-color:var(--theme-primary);box-shadow:0 4px 12px #0003}.feature-card.coming-soon:before{opacity:.6}.feature-header{display:flex;align-items:center;gap:1rem}.feature-icon{font-size:2rem;line-height:1;filter:drop-shadow(0 2px 4px var(--theme-primary-rgba-2));flex-shrink:0;display:inline-flex;align-items:center}.feature-icon:empty{display:none}.feature-card.coming-soon .feature-icon{opacity:.7;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.feature-card.coming-soon .feature-title{opacity:.9}.feature-card.coming-soon .feature-description{opacity:.75}.feature-title{font-size:1.25rem;font-weight:600;color:#fffffff2;margin:0;letter-spacing:-.01em}.feature-description{font-size:.9rem;color:#fff9;line-height:1.5;margin:0}.feature-link{margin-top:auto;font-size:.9rem;color:var(--theme-primary);font-weight:600;padding-top:.5rem;transition:transform .2s ease}.feature-card:hover .feature-link{transform:translate(4px)}@media(max-width:768px){.home-container{padding:var(--page-pad-y) var(--page-pad-x)}.home-hero{margin-bottom:var(--section-gap)}.home-title{font-size:clamp(2rem,7vw,2.6rem)}.home-subtitle{font-size:1rem}.features-grid{grid-template-columns:1fr;gap:1rem}.feature-card{padding:1.5rem}}.compliment-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100%;padding:var(--page-pad-y) var(--page-pad-x);max-width:var(--page-max);margin:0 auto;box-sizing:border-box}.compliment-header{text-align:center;margin-bottom:var(--section-gap);overflow:visible;padding-bottom:.3rem}.compliment-title{font-size:clamp(2.1rem,4vw,3rem);font-weight:700;background:linear-gradient(135deg,var(--theme-primary),var(--theme-primary-dark),var(--theme-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;line-height:1.3;padding-bottom:.2rem;animation:fadeInDown .6s ease-out;overflow:visible}.compliment-subtitle{font-size:1.2rem;color:#ffffffb3;font-weight:300;animation:fadeInUp .6s ease-out .2s both}.gift-wrapper{width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;margin:2rem 0;min-height:400px;perspective:1000px}.gift-box{position:relative;width:280px;height:280px;cursor:pointer;transform-style:preserve-3d;transition:transform .3s ease;animation:float 3s ease-in-out infinite;outline:none}.gift-box:hover:not(.opening){transform:scale(1.05)}.gift-box:active:not(.opening){transform:scale(1.02)}.gift-box:focus-visible{box-shadow:var(--focus-ring);border-radius:18px}.gift-box.opening{animation:none;pointer-events:none}.gift-body{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:200px;height:200px;background:linear-gradient(135deg,var(--theme-primary),var(--theme-primary-dark));border-radius:8px;box-shadow:0 10px 30px var(--theme-primary-rgba-4),inset 0 -10px 20px #0003;transition:all .8s cubic-bezier(.68,-.55,.265,1.55)}.gift-box.opening .gift-body{transform:translate(-50%) scale(.9);opacity:.7;animation:bodyShrink .8s ease-out forwards}@keyframes bodyShrink{0%{transform:translate(-50%) scale(1);opacity:1}50%{transform:translate(-50%) scale(.85);opacity:.6}to{transform:translate(-50%) scale(.9);opacity:.7}}.gift-lid{position:absolute;top:0;left:50%;transform:translate(-50%);width:200px;height:80px;background:linear-gradient(135deg,#ff7b7b,#ff6a7f);border-radius:8px 8px 0 0;box-shadow:0 -5px 20px var(--theme-border),inset 0 10px 20px #ffffff1a;transition:all .8s cubic-bezier(.68,-.55,.265,1.55);transform-origin:bottom center}.gift-box.opening .gift-lid{transform:translate(-50%) rotateX(-120deg) translateY(-80px) rotate(15deg);opacity:0;filter:blur(2px)}.gift-ribbon{position:absolute;background:#ffffffe6;box-shadow:0 2px 10px #0003}.gift-ribbon-vertical{top:0;left:50%;transform:translate(-50%);width:20px;height:100%;border-radius:2px}.gift-ribbon-horizontal{top:50%;left:0;transform:translateY(-50%);width:100%;height:20px;border-radius:2px}.gift-bow{position:absolute;top:-30px;left:50%;transform:translate(-50%);width:80px;height:60px;z-index:10}.bow-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;background:linear-gradient(135deg,var(--theme-primary),var(--theme-primary-dark));border-radius:50%;box-shadow:0 4px 15px var(--theme-primary-rgba-4)}.bow-loop{position:absolute;width:40px;height:50px;border:8px solid var(--theme-primary);border-radius:50%/60% 60% 40% 40%;box-shadow:0 4px 15px var(--theme-primary-rgba-4)}.bow-loop-left{left:0;top:0;border-right:none;border-top-right-radius:0;border-bottom-right-radius:0}.bow-loop-right{right:0;top:0;border-left:none;border-top-left-radius:0;border-bottom-left-radius:0}.gift-box.opening .gift-bow{animation:bowPop .8s ease-out forwards}.gift-sparkles{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.sparkle{position:absolute;font-size:1.5rem;opacity:0;animation:sparkleFloat 2s ease-in-out infinite}.gift-box.opening .sparkle{animation:sparklePop .8s ease-out forwards}.sparkle-1{top:10%;left:10%;animation-delay:0s}.sparkle-2{top:20%;right:15%;animation-delay:.2s}.sparkle-3{bottom:15%;left:20%;animation-delay:.4s}.sparkle-4{bottom:10%;right:10%;animation-delay:.6s}.gift-hint{margin:1.25rem 0 0;color:#fffc;font-size:1rem;font-weight:500;text-align:center;white-space:nowrap;animation:pulse 2s ease-in-out infinite}.gift-box.opening .gift-hint{opacity:0;transition:opacity .3s ease}.compliment-card{background:linear-gradient(135deg,var(--theme-gradient-light));border:2px solid var(--theme-border);border-radius:var(--radius-xl);padding:3rem 2.5rem;margin:2rem 0;width:100%;box-shadow:0 20px 60px var(--theme-primary-rgba-2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden;transition:all .3s ease;animation:revealCard .8s ease-out}.compliment-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,var(--theme-gradient-light) 0%,transparent 70%);animation:rotate 20s linear infinite}.compliment-card:hover{transform:translateY(-5px);box-shadow:0 25px 70px var(--theme-primary-rgba-3);border-color:var(--theme-primary)}.compliment-icon{font-size:4rem;text-align:center;margin-bottom:1.5rem;animation:bounce 2s ease-in-out infinite}.compliment-text{font-size:1.5rem;line-height:1.8;color:#fffffff2;text-align:center;font-weight:400;position:relative;z-index:1}.compliment-card.fade-out{opacity:0;transform:translateY(-20px)}.compliment-card.fade-in{opacity:1;transform:translateY(0)}.tomorrow-message{margin-top:2rem;text-align:center;animation:fadeInUp .6s ease-out .3s both}.tomorrow-message p{font-size:1.2rem;color:#ffffffe6;font-weight:500;background:linear-gradient(135deg,var(--theme-gradient-light));border:2px solid var(--theme-border);border-radius:16px;padding:1.5rem 2rem;display:inline-block;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 25px var(--theme-primary-rgba-2)}.compliment-footer{margin-top:1rem;text-align:center}.compliment-note{font-size:.95rem;color:#fff9;font-style:italic;line-height:1.6}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes bowPop{0%{transform:translate(-50%) scale(1) rotate(0);opacity:1}50%{transform:translate(-50%) scale(1.3) rotate(180deg);opacity:.8}to{transform:translate(-50%) scale(0) rotate(360deg);opacity:0}}@keyframes sparkleFloat{0%,to{opacity:0;transform:scale(0) translateY(0)}50%{opacity:.6;transform:scale(1) translateY(-10px)}}@keyframes sparklePop{0%{opacity:0;transform:scale(0) translateY(0)}50%{opacity:1;transform:scale(1.5) translateY(-30px) rotate(180deg)}to{opacity:0;transform:scale(0) translateY(-60px) rotate(360deg)}}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes revealCard{0%{opacity:0;transform:scale(.8) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(max-width:768px){.compliment-title{font-size:clamp(1.9rem,7vw,2.3rem)}.compliment-subtitle{font-size:1rem}.compliment-card{padding:2rem 1.5rem}.compliment-text{font-size:1.2rem}.compliment-icon{font-size:3rem}.gift-box{width:240px;height:240px}.gift-body,.gift-lid{width:170px}.gift-body{height:170px}.gift-lid{height:70px}.gift-bow{width:70px;height:50px}.gift-hint{font-size:.9rem}}.monkey-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100%;padding:var(--page-pad-y) var(--page-pad-x);max-width:var(--page-max);margin:0 auto;box-sizing:border-box}.monkey-header{text-align:center;margin-bottom:var(--section-gap);overflow:visible;padding-bottom:.3rem}.monkey-title{font-size:clamp(2.1rem,4vw,3rem);font-weight:700;background:linear-gradient(135deg,var(--theme-primary),var(--theme-primary-dark),var(--theme-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;line-height:1.2;padding-bottom:.2rem;animation:fadeInDown .6s ease-out;overflow:visible}.monkey-subtitle{font-size:1.2rem;color:var(--theme-text-secondary);font-weight:300;animation:fadeInUp .6s ease-out .2s both}.monkey-gift-wrapper{width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;margin:1.5rem 0;min-height:350px;perspective:1200px}.monkey-gift-box{position:relative;width:280px;height:280px;cursor:pointer;transform-style:preserve-3d;transition:transform .3s ease;animation:monkeyBounce 2.5s ease-in-out infinite;outline:none}.monkey-gift-box:hover:not(.opening){transform:scale(1.08) rotateY(5deg)}.monkey-gift-box:active:not(.opening){transform:scale(1.04)}.monkey-gift-box.opening{animation:monkeyOpen 1s cubic-bezier(.68,-.55,.265,1.55) forwards;pointer-events:none}.monkey-gift-box:focus-visible{box-shadow:var(--focus-ring);border-radius:18px}@keyframes monkeyBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes monkeyOpen{0%{transform:scale(1) rotateY(0)}50%{transform:scale(1.1) rotateY(180deg)}to{transform:scale(0) rotateY(360deg);opacity:0}}.monkey-gift-body{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:200px;height:200px;background:linear-gradient(135deg,var(--theme-secondary),var(--theme-primary));border-radius:12px;box-shadow:0 15px 40px var(--theme-primary-rgba-3),inset 0 -15px 25px #0000004d;transition:all 1s cubic-bezier(.68,-.55,.265,1.55);overflow:hidden}.monkey-gift-pattern{width:100%;height:100%;background-image:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(255,255,255,.1) 20px,rgba(255,255,255,.1) 40px),repeating-linear-gradient(-45deg,transparent,transparent 20px,rgba(255,255,255,.1) 20px,rgba(255,255,255,.1) 40px);opacity:.6}.monkey-gift-top{position:absolute;top:0;left:50%;transform:translate(-50%);width:200px;height:70px;background:linear-gradient(135deg,var(--theme-primary-dark),var(--theme-secondary));border-radius:12px 12px 0 0;transform-origin:bottom center;transition:transform 1s cubic-bezier(.68,-.55,.265,1.55);z-index:2;box-shadow:0 -5px 20px #0000004d}.monkey-gift-box.opening .monkey-gift-top{transform:translate(-50%) rotateX(-120deg)}.monkey-gift-bow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3}.monkey-bow-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:35px;height:35px;background:linear-gradient(135deg,var(--theme-accent),var(--theme-primary));border-radius:50%;box-shadow:0 4px 15px var(--theme-primary-rgba-4);z-index:2}.monkey-bow-loop{position:absolute;width:50px;height:60px;border:10px solid var(--theme-accent);border-radius:50%/60% 60% 40% 40%;box-shadow:0 4px 15px var(--theme-primary-rgba-4)}.monkey-bow-left{left:-30px;top:-30px}.monkey-bow-right{right:-30px;top:-30px}.monkey-gift-sparkles{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:4}.monkey-sparkle{position:absolute;font-size:1.5rem;opacity:0;animation:monkeySparkle 2s ease-in-out infinite}.monkey-sparkle-1{top:20%;left:20%;animation-delay:0s}.monkey-sparkle-2{top:20%;right:20%;animation-delay:.5s}.monkey-sparkle-3{bottom:30%;left:30%;animation-delay:1s}.monkey-sparkle-4{bottom:30%;right:30%;animation-delay:1.5s}@keyframes monkeySparkle{0%,to{opacity:0;transform:scale(0) rotate(0)}50%{opacity:1;transform:scale(1.5) rotate(180deg)}}.monkey-gift-hint{margin:1.25rem 0 0;color:var(--theme-text-secondary);font-size:1rem;font-weight:500;text-align:center;white-space:nowrap;animation:monkeyPulse 2s ease-in-out infinite}@keyframes monkeyPulse{0%,to{opacity:.7}50%{opacity:1}}.monkey-card{background:linear-gradient(135deg,var(--theme-gradient-light));border:2px solid var(--theme-border);border-radius:24px;padding:2rem 1.5rem;margin:1.5rem 0;width:100%;max-width:600px;box-shadow:0 20px 60px var(--theme-primary-rgba-2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;text-align:center;animation:monkeyReveal .8s ease-out}@keyframes monkeyReveal{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.monkey-image-wrapper{width:100%;max-width:300px;height:300px;margin:0 auto 1.5rem;border-radius:20px;overflow:hidden;box-shadow:0 15px 40px var(--theme-primary-rgba-3);background:var(--theme-card-bg);display:flex;align-items:center;justify-content:center}.monkey-image{width:100%;height:100%;object-fit:cover;border-radius:20px;display:block;background:var(--theme-card-bg)}.monkey-emoji-fallback{font-size:8rem;animation:monkeyBounce 2s ease-in-out infinite}.monkey-loading{font-size:1.5rem;color:var(--theme-text-secondary);display:flex;align-items:center;justify-content:center;height:100%;animation:monkeyPulse 1.5s ease-in-out infinite}.monkey-name{font-size:2rem;font-weight:700;color:var(--theme-primary);margin-bottom:1rem;background:linear-gradient(135deg,var(--theme-primary),var(--theme-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.monkey-fun-fact{font-size:1.1rem;color:var(--theme-text);line-height:1.6;font-weight:400;padding:1.2rem;background:#ffffff0d;border-radius:16px;border:1px solid var(--theme-border)}.monkey-tomorrow-message{text-align:center;margin:1.5rem 0;padding:1.2rem;background:linear-gradient(135deg,var(--theme-gradient-light));border:2px solid var(--theme-border);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .8s ease-out .5s both}.monkey-tomorrow-message p{font-size:1.2rem;color:var(--theme-text);font-weight:500;margin:0}.monkey-footer{text-align:center;margin-top:1rem;margin-bottom:1rem}.monkey-note{font-size:1rem;color:var(--theme-text-secondary);font-style:italic;margin:0 0 1rem}.monkey-reset-button{background:linear-gradient(135deg,var(--theme-primary),var(--theme-primary-dark));color:#fff;border:2px solid var(--theme-border);border-radius:12px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.monkey-reset-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--theme-primary-rgba-3);background:linear-gradient(135deg,var(--theme-primary-light),var(--theme-primary))}.monkey-reset-button:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .6s ease-out}.singing-container{max-width:var(--page-max);margin:0 auto;padding:var(--page-pad-y) var(--page-pad-x)}.singing-header{margin-bottom:var(--section-gap)}.singing-title{margin:0 0 .75rem;font-size:clamp(2.1rem,3.2vw,2.6rem);font-weight:700;background:linear-gradient(135deg,var(--theme-primary),var(--theme-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.singing-subtitle{margin:0;font-size:1rem;color:#fff9}.singing-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:2rem}.singing-card{background:var(--theme-card-bg);border-radius:var(--radius-lg);border:1px solid var(--theme-border);padding:1.75rem 2rem;box-shadow:var(--shadow-1);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.singing-soon{text-align:left;position:relative;overflow:hidden;min-height:200px;display:block}.singing-soon:before{content:"";position:absolute;inset:0;background:radial-gradient(900px 500px at 10% 10%,rgba(255,107,107,.12),transparent 60%),radial-gradient(900px 500px at 90% 10%,rgba(34,197,94,.1),transparent 60%),radial-gradient(900px 500px at 50% 120%,rgba(251,191,36,.1),transparent 60%);pointer-events:none;opacity:.9}.singing-soon>*{position:relative;z-index:1}.singing-soon-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:#00000040;color:#ffffffe6;font-weight:750;margin-bottom:1rem}.singing-soon-text{margin:0 0 .75rem;color:#ffffffd1;line-height:1.6;font-size:1.05rem}.singing-soon-text.subtle{color:#ffffffa6;margin-bottom:0}.singing-section-title{margin:0 0 1.25rem;font-size:1.1rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:#ffffffb3}.singing-line{font-size:1.4rem;line-height:1.5;margin:0 0 1.5rem;color:#fffffff2}.singing-note-target{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.note-label{font-size:.9rem;text-transform:uppercase;letter-spacing:.15em;color:#ffffff80}.note-value{font-size:1.4rem;font-weight:600;color:var(--theme-primary)}.note-frequency{font-size:.85rem;color:#ffffff80;margin-left:.35rem}.singing-status{font-size:.95rem;line-height:1.5;margin:0 0 1.5rem;color:#ffffffb3}.singing-status-match{color:#7dffb2}.singing-status-high,.singing-status-low{color:#ffd27d}.singing-status-idle{color:#ffffffa6}.singing-readout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1.75rem}.singing-readout-item{padding:.85rem 1rem;border-radius:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.08)}.readout-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff80;margin-bottom:.25rem}.readout-value{font-size:1.1rem;color:#fffffff2}.singing-controls{display:flex;gap:1rem}.singing-button{border-radius:999px;border:1px solid transparent;padding:.6rem 1.4rem;font-size:.95rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}.singing-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.singing-button:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.singing-button.primary{background:linear-gradient(135deg,var(--theme-primary),var(--theme-secondary));color:#fff}.singing-button.primary:hover{filter:brightness(1.05);box-shadow:0 10px 24px var(--theme-primary-rgba-2);transform:translateY(-1px)}.singing-button.secondary{background:transparent;border-color:#ffffff40;color:#ffffffd9}.singing-button.secondary:hover{background:#ffffff0f}.singing-button.danger{background:transparent;border-color:#ff6b6b99;color:#ffa0a0f2}.singing-button.danger:hover{background:#ff6b6b26}@media(max-width:900px){.singing-container{padding:var(--page-pad-y) var(--page-pad-x)}.singing-layout{grid-template-columns:1fr}}@media(max-width:600px){.singing-card{padding:1.5rem 1.25rem}.singing-title{font-size:clamp(1.9rem,7vw,2.2rem)}.singing-note-target{flex-direction:column;align-items:flex-start}}.musical-container{max-width:var(--page-max);margin:0 auto;padding:var(--page-pad-y) var(--page-pad-x)}.musical-header{margin-bottom:var(--section-gap);text-align:left}.musical-title{margin:0 0 .6rem;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:750;background:linear-gradient(135deg,var(--theme-primary),var(--theme-secondary),var(--theme-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;line-height:1.3}.musical-subtitle{margin:0;color:#ffffffad;font-weight:350;max-width:70ch}.musical-card{background:var(--theme-card-bg);border:1px solid var(--theme-border);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-1);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.musical-card+.musical-card{margin-top:1.25rem}.musical-topline{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;margin-bottom:1.25rem}.musical-score{min-width:110px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;padding:.9rem 1rem}.musical-score-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff8c}.musical-score-value{font-size:2rem;font-weight:800;color:#fffffff2;line-height:1.1;margin-top:.25rem}.musical-timer-row{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;margin-bottom:.5rem}.musical-timer-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff8c}.musical-timer-value{font-size:1.1rem;font-weight:750;color:var(--theme-accent)}.musical-timer-bar{height:10px;border-radius:999px;overflow:hidden;background:#ffffff14;border:1px solid rgba(255,255,255,.1)}.musical-timer-fill{height:100%;transform-origin:left center;background:linear-gradient(90deg,var(--theme-accent),var(--theme-primary))}.musical-timer-hint{margin-top:.5rem;font-size:.9rem;color:#ffffff8c}.musical-lyric{margin:1.25rem 0 1.1rem;padding:1rem;border-radius:18px;border:1px solid rgba(255,255,255,.1);background:#ffffff08}.musical-lyric-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff8c;margin-bottom:.35rem}.musical-lyric-text{font-size:1.35rem;line-height:1.55;color:#fffffff2;font-weight:550}.musical-choices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.musical-choice{width:100%;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:#ffffff08;padding:.9rem 1rem;color:#ffffffe6;font-weight:650;cursor:pointer;text-align:left}.musical-choice:hover:not(:disabled){border-color:#ffffff38;background:#ffffff0d}.musical-choice:focus-visible{outline:none;box-shadow:var(--focus-ring)}.musical-choice:disabled{cursor:not-allowed;opacity:.8}.musical-choice.wrong{border-color:#ff6b6b73;background:#ff6b6b1a}.musical-choice.correct{border-color:#22c55e8c;background:#22c55e1a}.musical-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.25rem}.musical-actionbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-top:1.25rem}.musical-btn{border-radius:999px;border:1px solid rgba(255,255,255,.14);padding:.65rem 1.25rem;font-weight:650;cursor:pointer;background:#ffffff08;color:#ffffffe6}.musical-btn.primary{background:rgba(var(--theme-primary-rgb, 255, 107, 107),.18);border-color:rgba(var(--theme-primary-rgb, 255, 107, 107),.38);color:#ffffffeb}.musical-btn.primary:hover{background:rgba(var(--theme-primary-rgb, 255, 107, 107),.24)}.musical-btn.secondary{background:#ffffff08;border-color:#ffffff2e;color:#ffffffe0}.musical-btn.secondary:hover{background:#ffffff0f}.musical-btn.danger{background:#ff6b6b14;border-color:#ff6b6b66;color:#ffebebf2}.musical-btn.danger:hover{background:#ff6b6b1f}.musical-btn:disabled{opacity:.6;cursor:not-allowed}.musical-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.musical-result{margin-top:1rem;text-align:center}.musical-result-badge{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .8rem;border-radius:999px;font-weight:750;border:1px solid rgba(255,255,255,.16);background:#ffffff0a;color:#ffffffe6}.musical-result-badge.no{border-color:#ff6b6b73;background:#ff6b6b1a}.musical-result-badge.ok{border-color:#22c55e8c;background:#22c55e1a}.musical-result-text{margin-top:.6rem;color:#ffffffb3}.musical-em{color:#fffffff2;font-weight:750}.musical-section-title{margin:0 0 1rem;font-size:1rem;text-transform:uppercase;letter-spacing:.14em;color:#ffffffb3}.musical-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.musical-stat{padding:.9rem 1rem;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#ffffff08}.musical-stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff8c}.musical-stat-value{font-size:1.35rem;font-weight:800;color:#fffffff2;margin-top:.25rem}@media(max-width:700px){.musical-topline,.musical-choices,.musical-actionbar{grid-template-columns:1fr}}.musical-modal-overlay{position:fixed;inset:0;background:#0000008c;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:mmOverlayIn .16s ease-out both}.musical-modal{width:100%;max-width:720px;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.14);background:#121212eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-2);padding:1.25rem;animation:mmModalIn .18s cubic-bezier(.2,.9,.2,1) both}.musical-modal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.musical-modal-title{font-size:1.1rem;font-weight:800;letter-spacing:-.01em;color:#fffffff2}.musical-modal-close{border:1px solid rgba(255,255,255,.16);background:#ffffff0a;color:#ffffffd9;border-radius:999px;padding:.5rem .85rem;font-weight:700;cursor:pointer}.musical-modal-close:hover{background:#ffffff12}.musical-modal-close:focus-visible{outline:none;box-shadow:var(--focus-ring)}.musical-modal-actions{display:flex;justify-content:flex-end;margin-top:1rem}@keyframes mmOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes mmModalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){.musical-modal-overlay,.musical-modal{animation:none!important}}.rhythm-container{max-width:var(--page-max);margin:0 auto;padding:var(--page-pad-y) var(--page-pad-x)}.rhythm-header{margin-bottom:var(--section-gap)}.rhythm-title{margin:0 0 .6rem;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:750;background:linear-gradient(135deg,var(--theme-primary),var(--theme-secondary),var(--theme-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;line-height:1.3}.rhythm-subtitle{margin:0;color:#ffffffad;font-weight:350;max-width:70ch}.rhythm-card{background:var(--theme-card-bg);border:1px solid var(--theme-border);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-1);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.rhythm-settings{display:flex;justify-content:flex-end;margin-bottom:1rem}.rhythm-dropdown{position:relative;display:grid;gap:.35rem;min-width:210px}.rhythm-dropdown-btn{width:100%;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:#ffffff08;color:#ffffffe6;padding:.6rem .75rem;font-weight:750;display:flex;align-items:center;justify-content:space-between;gap:.75rem;cursor:pointer}.rhythm-dropdown-btn:hover{background:#ffffff0f;border-color:#fff3}.rhythm-dropdown-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.rhythm-dropdown-chevron{display:inline-block;transform:rotate(0);transition:transform .16s ease;opacity:.85}.rhythm-dropdown[data-open=true] .rhythm-dropdown-chevron{transform:rotate(180deg)}.rhythm-dropdown-menu{position:absolute;right:0;top:calc(100% + 8px);width:100%;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:#121212eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-2);padding:.4rem;z-index:50;opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:opacity .16s ease,transform .16s ease}.rhythm-dropdown[data-open=true] .rhythm-dropdown-menu{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.rhythm-dropdown-item{width:100%;border:0;background:transparent;color:#ffffffe0;padding:.65rem .75rem;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-weight:700;margin-top:.25rem}.rhythm-dropdown-item:first-child{margin-top:0}.rhythm-dropdown-item:hover{background:#ffffff0f}.rhythm-dropdown-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.rhythm-dropdown-item.selected{background:rgba(var(--theme-primary-rgb, 255, 107, 107),.14);border:1px solid rgba(var(--theme-primary-rgb, 255, 107, 107),.22)}.rhythm-dropdown-item-check{opacity:.9}.rhythm-card+.rhythm-card{margin-top:1.25rem}.rhythm-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem;margin-bottom:1rem}.rhythm-meta-item,.stat{padding:.9rem 1rem;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#ffffff08}.label{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff8c}.value{font-size:1.25rem;font-weight:800;color:#fffffff2;margin-top:.25rem}.rhythm-status{color:#fffc;margin:.25rem 0 1rem}.rhythm-tapcount{margin:-.25rem 0 1rem;color:#ffffff9e;font-weight:650;text-align:center}.rhythm-progress{height:10px;border-radius:999px;overflow:hidden;background:#ffffff14;border:1px solid rgba(255,255,255,.1);margin-bottom:.5rem;position:relative}.rhythm-progress .fill{height:100%;transform-origin:left center;background:linear-gradient(90deg,var(--theme-accent),var(--theme-primary))}.rhythm-markers{position:relative;height:24px;margin-bottom:1rem;border-radius:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.08)}.rhythm-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:var(--theme-primary);box-shadow:0 0 12px rgba(var(--theme-primary-rgb, 255, 107, 107),.9),0 0 24px rgba(var(--theme-primary-rgb, 255, 107, 107),.5);border:2px solid rgba(255,255,255,.5);animation:pulse-marker 1s ease-in-out infinite}@keyframes pulse-marker{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.2)}}.rhythm-actions{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;justify-content:center;margin:.75rem 0 1rem}.btn{border-radius:999px;border:1px solid rgba(255,255,255,.14);padding:.65rem 1.25rem;font-weight:650;cursor:pointer;background:#ffffff08;color:#ffffffe6}.btn.primary{background:rgba(var(--theme-primary-rgb, 255, 107, 107),.18);border-color:rgba(var(--theme-primary-rgb, 255, 107, 107),.38)}.btn.primary:hover{background:rgba(var(--theme-primary-rgb, 255, 107, 107),.24)}.btn.secondary:hover{background:#ffffff0f}.btn.danger{background:#ff6b6b14;border-color:#ff6b6b66;color:#ffebebf2}.btn.danger:hover{background:#ff6b6b1f}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.tap-pad{width:100%;border-radius:22px;border:1px solid rgba(255,255,255,.14);background:#ffffff0a;padding:1.25rem 1rem;font-size:1.35rem;font-weight:850;color:#fffffff2;cursor:pointer}.tap-pad:hover:not(:disabled){background:#ffffff0f}.tap-pad:disabled{opacity:.55;cursor:not-allowed}.tap-pad:focus-visible{outline:none;box-shadow:var(--focus-ring)}.tap-hint{display:block;margin-top:.35rem;font-size:.9rem;font-weight:600;color:#fff9}.rhythm-result{margin-top:1rem;text-align:center}.badge{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .8rem;border-radius:999px;font-weight:850;border:1px solid rgba(255,255,255,.16);background:#ffffff0a;color:#ffffffe6}.detail{margin-top:.5rem;color:#ffffffb3}.section-title{margin:0 0 1rem;font-size:1rem;text-transform:uppercase;letter-spacing:.14em;color:#ffffffb3}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}@media(max-width:720px){.rhythm-meta{grid-template-columns:1fr}.rhythm-settings{justify-content:flex-start}}.rhythm-modal-overlay{position:fixed;inset:0;background:#0000008c;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:rhythmOverlayIn .16s ease-out both}.rhythm-modal{width:100%;max-width:720px;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.14);background:#121212eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-2);padding:1.25rem;animation:rhythmModalIn .18s cubic-bezier(.2,.9,.2,1) both}.rhythm-modal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.rhythm-modal-title{font-size:1.1rem;font-weight:800;letter-spacing:-.01em;color:#fffffff2}.rhythm-modal-close{border:1px solid rgba(255,255,255,.16);background:#ffffff0a;color:#ffffffd9;border-radius:999px;padding:.5rem .85rem;font-weight:700;cursor:pointer}.rhythm-modal-close:hover{background:#ffffff12}.rhythm-modal-close:focus-visible{outline:none;box-shadow:var(--focus-ring)}.rhythm-modal-actions{display:flex;justify-content:flex-end;margin-top:1rem}@keyframes rhythmOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes rhythmModalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){.rhythm-modal-overlay,.rhythm-modal{animation:none!important}}.app{display:flex;flex-direction:column;position:relative;min-height:100dvh}.main-content{flex:1;width:100%;position:relative;z-index:10}
