*{margin:0;padding:0;box-sizing:border-box}body{font-family:"Noto Serif SC",SimSun,serif;background-color:#1a1a2e;color:#4a4a4a;min-height:100vh;display:flex;justify-content:center;overflow-x:hidden}#root{width:100%;max-width:480px}.app-wrapper{width:100%;min-height:100vh}.pokeball-screen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(160deg,#1a1a2e,#16213e,#0f3460);z-index:100;overflow:hidden}.pokeball-screen.idle{cursor:default}.bg-pokeballs{position:absolute;inset:0;pointer-events:none}.bg-pokeball{position:absolute;width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 50% 55%,#fff 40%,#333 42% 44%,#ee1515 46% 100%);opacity:.08;animation:float-bg 8s infinite ease-in-out;animation-delay:calc(var(--i) * -1.3s)}.bg-pokeball:nth-child(1){top:10%;left:10%;width:20px;height:20px}.bg-pokeball:nth-child(2){top:25%;right:15%;width:35px;height:35px}.bg-pokeball:nth-child(3){top:60%;left:5%;width:25px;height:25px}.bg-pokeball:nth-child(4){top:75%;right:10%;width:18px;height:18px}.bg-pokeball:nth-child(5){top:40%;left:80%;width:28px;height:28px}.bg-pokeball:nth-child(6){top:85%;left:40%;width:22px;height:22px}@keyframes float-bg{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.pokeball-container{position:relative;width:180px;height:180px}.pokeball-svg{width:100%;height:100%;filter:drop-shadow(0 0 20px rgba(238,21,21,.3));transition:filter .3s}.pokeball-screen.idle .pokeball-svg{animation:pokeball-idle 2s ease-in-out infinite}@keyframes pokeball-idle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.pokeball-button{transition:fill .2s}.pokeball-screen.idle:hover .pokeball-button{fill:#ee1515}.pokeball-screen.opening .pokeball-svg,.pokeball-screen.flash .pokeball-svg{animation:none}.pokeball-screen.opening .pokeball-top,.pokeball-screen.flash .pokeball-top{animation:open-top .6s ease-out forwards}.pokeball-screen.opening .pokeball-bottom,.pokeball-screen.flash .pokeball-bottom{animation:open-bottom .6s ease-out forwards}@keyframes open-top{0%{transform:translateY(0) rotate(0)}60%{transform:translateY(-30px) rotate(-8deg)}to{transform:translateY(-50px) rotate(-12deg);opacity:.6}}@keyframes open-bottom{0%{transform:translateY(0) rotate(0)}60%{transform:translateY(30px) rotate(5deg)}to{transform:translateY(50px) rotate(8deg);opacity:.6}}.pokeball-unlock{position:absolute;bottom:14%;left:50%;transform:translate(-50%);width:100%;max-width:280px;padding:0 20px;text-align:center}.pokeball-hint{text-align:center;margin-bottom:20px}.hint-text{font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;color:#ffffffd9;font-size:14px;letter-spacing:2px}.hint-bounce{color:#ffffff80;font-size:18px;margin-top:8px;animation:bounce-hint 1.5s ease-in-out infinite}@keyframes bounce-hint{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(8px);opacity:.8}}.unlock-form{margin-top:4px}.unlock-input-wrap{display:flex;align-items:stretch;gap:0;border-radius:28px;overflow:hidden;box-shadow:0 4px 20px #00000040,0 0 0 2px #ee151533,inset 0 1px #ffffff1a;background:#ffffff14;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.unlock-input{flex:1;min-width:0;height:48px;padding:0 20px;font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;font-size:15px;color:#fff;background:transparent;border:none;outline:none;letter-spacing:1px}.unlock-input::placeholder{color:#ffffff73}.unlock-btn{height:48px;padding:0 24px;font-family:Fredoka,ZCOOL KuaiLe,sans-serif;font-size:15px;font-weight:600;color:#fff;background:linear-gradient(180deg,#ee1515,#c41111);border:none;cursor:pointer;transition:transform .15s,box-shadow .15s;letter-spacing:2px;box-shadow:inset 0 1px #fff3}.unlock-btn:hover{transform:scale(1.02);box-shadow:0 0 16px #ee151580}.unlock-btn:active{transform:scale(.98)}.unlock-error{margin-top:12px;font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;font-size:13px;color:#ff6b6b;text-shadow:0 0 8px rgba(255,107,107,.4);animation:unlock-error-shake .4s ease-out}@keyframes unlock-error-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.sparkles{position:absolute;top:50%;left:50%;width:0;height:0;pointer-events:none}.sparkle{position:absolute;width:var(--size);height:var(--size);background:#fff;border-radius:50%;box-shadow:0 0 6px 2px #fffc,0 0 12px 4px #ee151566;animation:sparkle-burst .8s ease-out forwards;animation-delay:var(--delay);opacity:0}@keyframes sparkle-burst{0%{transform:translate(0) scale(0);opacity:1}50%{opacity:1}to{transform:translate(calc(cos(var(--angle)) * var(--distance)),calc(sin(var(--angle)) * var(--distance))) scale(1);opacity:0}}.flash-overlay{position:fixed;inset:0;background:#fff;z-index:200;animation:flash-anim 1s ease-out forwards}@keyframes flash-anim{0%{opacity:0}20%{opacity:1}to{opacity:0}}.invitation.pokemon-theme{background:linear-gradient(180deg,#fef9f0,#fff5f5,#fef9f0 60%,#fff5f5);min-height:100vh;padding-bottom:0;position:relative;overflow:hidden;border:3px solid #F4A0C0;box-sizing:border-box}.fade-in{animation:invitation-enter .8s ease-out}@keyframes invitation-enter{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.sakura-layer{position:fixed;inset:0;pointer-events:none;z-index:10;overflow:hidden}.sakura-petal{position:absolute;top:-20px;left:var(--x);width:12px;height:12px;background:radial-gradient(ellipse 60% 70% at 50% 50%,#ffb7c5,#f4a0c0);border-radius:50% 50% 50% 0;transform:rotate(0);opacity:.85;animation:sakura-fall var(--duration) var(--delay) linear infinite}@keyframes sakura-fall{0%{transform:translateY(0) translate(0) rotate(0);opacity:.85}15%{transform:translateY(15vh) translate(var(--sway)) rotate(90deg)}30%{transform:translateY(30vh) translate(calc(-1 * var(--sway))) rotate(180deg)}50%{transform:translateY(50vh) translate(var(--sway)) rotate(270deg)}70%{transform:translateY(70vh) translate(calc(-.5 * var(--sway))) rotate(360deg)}to{transform:translateY(100vh) translate(0) rotate(450deg);opacity:.6}}.header{padding:28px 30px 0;position:relative}.header-badge{position:absolute;top:20px;right:25px}.mini-pokeball{width:22px;height:22px;border-radius:50%;background:linear-gradient(180deg,#ee1515 49%,#333 49% 51%,#fff 51%);border:2px solid #333;position:relative}.mini-pokeball:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:7px;height:7px;border-radius:50%;background:#fff;border:1.5px solid #333}.header-title{font-family:Fredoka,sans-serif;font-size:18px;color:#ee1515;font-weight:600;letter-spacing:1px}.header-subtitle{font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;font-size:13px;color:#999;margin-top:2px;font-weight:400}.header-hi{font-family:Fredoka,sans-serif;font-size:52px;color:#ee1515;text-align:right;margin-top:-20px;padding-right:20px;font-weight:700}.photo-section{padding:0 35px;margin-top:10px}.photo-frame{width:100%;aspect-ratio:3 / 4;border-radius:12px;overflow:hidden;border:3px solid #EE1515;box-shadow:0 4px 20px #ee15151a,inset 0 0 0 2px #fff;position:relative}.photo-frame img{width:100%;height:100%;object-fit:cover}.welcome-section{position:relative;text-align:center;padding:35px 30px}.welcome-title{font-family:Fredoka,sans-serif;font-size:26px;color:#ee1515;margin-bottom:25px;font-weight:600}.welcome-text{font-family:"Noto Serif SC",serif;font-size:14px;color:#555;line-height:2.2;font-weight:400}.couple-names{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:25px;font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;font-size:17px;color:#444;font-weight:400}.heart-icon{display:flex;align-items:center;animation:heartbeat 1.5s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.section-divider{display:flex;align-items:center;justify-content:center;padding:0 30px;gap:0}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:linear-gradient(to right,transparent,#e0c8c8,transparent)}.divider-pokeball{width:14px;height:14px;border-radius:50%;background:linear-gradient(180deg,#ee1515 49%,#555 49% 51%,#fff 51%);border:1.5px solid #555;margin:0 12px;position:relative;flex-shrink:0}.divider-pokeball:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:50%;background:#fff;border:1px solid #555}.info-section{text-align:center;padding:30px}.section-title{font-family:Fredoka,sans-serif;font-size:24px;color:#ee1515;margin-bottom:16px;font-weight:600}.info-text{font-family:"Noto Serif SC",serif;font-size:15px;color:#666;line-height:1.8;font-weight:300}.info-text .lunar{font-size:13px;color:#999}.info-venue{font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;font-size:18px;color:#1a1a1a;margin-top:4px;margin-bottom:10px;font-weight:600}.info-section .info-text{margin-top:0}.map-wrap{display:block;margin-top:16px;width:100%;max-width:340px;margin-left:auto;margin-right:auto;border-radius:12px;overflow:hidden;border:2px solid rgba(238,21,21,.25);box-shadow:0 2px 12px #00000014;text-decoration:none;color:inherit;transition:border-color .2s,box-shadow .2s}.map-wrap:hover{border-color:#ee151580;box-shadow:0 4px 16px #ee151526}.map-img{display:block;width:100%;height:auto;vertical-align:top}.map-open-baidu{display:block;padding:10px 16px;font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;font-size:13px;color:#ee1515;text-align:center;background:#ee15150f;transition:background .2s}.map-wrap:hover .map-open-baidu{background:#ee15151f}.process-section{text-align:center;padding:30px}.process-timeline{margin-top:20px;display:flex;flex-direction:column}.timeline-item{display:flex;align-items:center;padding:14px 0;gap:12px}.timeline-pokeball-dot{width:18px;height:18px;border-radius:50%;background:linear-gradient(180deg,#ee1515 49%,#444 49% 51%,#fff 51%);border:2px solid #444;flex-shrink:0;position:relative}.timeline-pokeball-dot:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:5px;height:5px;border-radius:50%;background:#fff;border:1px solid #444}.timeline-line{flex:1;display:flex;align-items:center}.timeline-dots{flex:1;border-bottom:2px dashed #e0c8c8}.timeline-label{font-family:"Noto Serif SC",serif;font-size:14px;color:#555;white-space:nowrap;font-weight:400}.timeline-time{font-family:"Noto Serif SC",serif;font-size:14px;color:#999;white-space:nowrap;min-width:44px;text-align:right;font-weight:300}.tips-section{position:relative;padding:30px}.tips-title{font-family:Fredoka,sans-serif;font-size:24px;color:#ee1515;margin-bottom:16px}.tips-list{list-style:none;padding:0}.tips-list li{font-family:"Noto Serif SC",serif;font-size:13px;color:#777;line-height:2;padding-left:8px;font-weight:300}.game-section{padding:28px 30px 20px;text-align:center}.game-title{font-family:Fredoka,sans-serif;font-size:20px;color:#ee1515;margin-bottom:14px;font-weight:600}.game-desc{font-family:"Noto Serif SC",serif;font-size:13px;color:#666;line-height:2;font-weight:400}.footer{position:relative;text-align:center;padding:40px 30px 0}.footer-pokeballs{display:flex;justify-content:center;gap:12px;margin-bottom:25px}.footer-mini-pokeball{width:16px;height:16px;border-radius:50%;background:linear-gradient(180deg,#ee1515 49%,#555 49% 51%,#fff 51%);border:1.5px solid #555;opacity:.5;position:relative}.footer-mini-pokeball:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:50%;background:#fff;border:1px solid #555}.footer-blessing{font-family:Ma Shan Zheng,cursive;font-size:18px;color:#a77;line-height:2;margin-bottom:20px}.footer-initials{font-family:Fredoka,sans-serif;font-size:22px;color:#ee1515;letter-spacing:3px;margin-bottom:10px}.hidden-egg{position:absolute;width:68px;height:68px;padding:0;border:none;background:none;cursor:pointer;opacity:.58;transition:transform .2s,opacity .2s;z-index:5}.hidden-egg:hover{opacity:.88;transform:scale(1.12)}.hidden-egg.found{pointer-events:none;opacity:0;transform:scale(0)}.hidden-egg-img{width:100%;height:100%;object-fit:contain;display:block;filter:brightness(.88) contrast(1.05);background:none;border:none;vertical-align:middle}.gift-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;animation:overlay-in .3s ease-out}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.gift-modal{background:linear-gradient(160deg,#fef9f0,#fff8e7,#fff5f5);border:3px solid #EE1515;border-radius:20px;padding:28px 24px;max-width:340px;width:100%;box-shadow:0 10px 40px #ee151540;position:relative;z-index:502;animation:modal-pop .4s ease-out}@keyframes modal-pop{0%{opacity:0;transform:scale(.85) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.gift-modal-title{font-family:Fredoka,sans-serif;font-size:20px;color:#ee1515;text-align:center;margin-bottom:8px}.gift-modal-subtitle{font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;font-size:14px;color:#666;text-align:center;margin-bottom:20px}.gift-modal-address{font-family:"Noto Serif SC",serif;font-size:15px;color:#333;line-height:1.8;text-align:center;padding:16px;background:#ee15150f;border-radius:12px;margin-bottom:20px}.gift-modal-close{font-family:ZCOOL KuaiLe,"Noto Serif SC",serif;display:block;width:100%;padding:12px;background:#ee1515;color:#fff;border:none;border-radius:12px;font-size:15px;cursor:pointer}.confetti-layer{position:fixed;inset:0;pointer-events:none;z-index:501}.confetti-piece{position:absolute;width:10px;height:10px;left:50%;top:40%;transform:translate(-50%,-50%);border-radius:50%;animation:confetti-fly 1.2s ease-out forwards}.confetti-piece.yellow{background:#f5d000;box-shadow:0 0 6px #f5d000}.confetti-piece.red{background:#ee1515;box-shadow:0 0 6px #ee1515}.confetti-piece.orange{background:#ff8c00}@keyframes confetti-fly{0%{transform:translate(-50%,-50%) translate(0) scale(1);opacity:1}to{transform:translate(-50%,-50%) translate(var(--tx),var(--ty)) scale(0);opacity:0}}@media(max-width:360px){.header-hi{font-size:42px}.welcome-title{font-size:22px}.section-title{font-size:20px}.pokeball-container{width:150px;height:150px}}
