.invitation-card{width:320px;min-height:400px;background:linear-gradient(135deg,#ff6b9df2,#ffa06bf2);border-radius:var(--radius-xl);padding:2rem 1.5rem;box-shadow:var(--shadow-xl);cursor:pointer;transition:all var(--transition-slow);position:relative;overflow:hidden;border:2px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);will-change:transform;transform:translateZ(0);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.invitation-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%,rgba(255,255,255,.05) 100%);pointer-events:none}.invitation-card:hover,.invitation-card.hovered{transform:scale(1.05) translateY(-5px);box-shadow:0 30px 80px #ff6b9d99;border-color:#ffffff80}.invitation-card:active{transform:scale(1.02) translateY(-2px)}.invitation-header{text-align:center;margin-bottom:1.5rem;position:relative;z-index:2}.invitation-icon{font-size:3rem;margin-bottom:.5rem;animation:iconBounce 2s ease-in-out infinite;display:inline-block;transition:transform var(--transition-normal)}.invitation-card:hover .invitation-icon{animation-play-state:paused;transform:scale(1.2)}.invitation-title{font-size:1.8rem;font-weight:700;color:#fff;margin:0 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.2);letter-spacing:.05em}.invitation-subtitle{font-size:.95rem;color:#ffffffe6;margin:0;font-weight:300}.invitation-baby{text-align:center;padding:1rem 0;margin-bottom:1.5rem;border-top:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.2);position:relative;z-index:2}.baby-name{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .3rem;text-shadow:0 2px 8px rgba(0,0,0,.2);transition:transform var(--transition-normal)}.invitation-card:hover .baby-name{transform:scale(1.05)}.baby-age{font-size:1rem;color:#ffffffe6;margin:0;font-weight:300}.invitation-details{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;position:relative;z-index:2}.detail-item{display:flex;align-items:flex-start;gap:.8rem;padding:.8rem;background:#ffffff26;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all var(--transition-normal)}.invitation-card:hover .detail-item{background:#fff3;transform:translate(5px)}.detail-icon{font-size:1.5rem;flex-shrink:0;transition:transform var(--transition-normal)}.detail-item:hover .detail-icon{transform:scale(1.2)}.detail-text{flex:1}.detail-date,.detail-venue{font-size:1rem;font-weight:500;color:#fff;margin:0 0 .2rem}.detail-time,.detail-hall{font-size:.9rem;color:#ffffffd9;margin:0}.invitation-footer{text-align:center;position:relative;z-index:2}.invitation-hint{font-size:.85rem;color:#fffc;margin:0;animation:hintPulse 2s ease-in-out infinite}.invitation-decoration{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:1}.decoration-circle{position:absolute;border-radius:50%;background:#ffffff1a;animation:circleFloat 8s ease-in-out infinite}.decoration-circle-1{width:80px;height:80px;top:-20px;right:-20px;animation-delay:0s}.decoration-circle-2{width:120px;height:120px;bottom:-30px;left:-30px;animation-delay:2s}.decoration-circle-3{width:60px;height:60px;top:50%;right:-10px;animation-delay:4s}@keyframes hintPulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes circleFloat{0%,to{transform:translate(0) scale(1);opacity:.1}50%{transform:translate(10px,-10px) scale(1.1);opacity:.2}}@media (max-width: 768px){.invitation-card{width:280px;min-height:360px;padding:1.5rem 1.2rem}.invitation-icon{font-size:2.5rem}.invitation-title{font-size:1.5rem}.invitation-subtitle{font-size:.9rem}.baby-name{font-size:1.8rem}.baby-age{font-size:.9rem}.detail-icon{font-size:1.3rem}.detail-date,.detail-venue{font-size:.95rem}.detail-time,.detail-hall{font-size:.85rem}}@media (max-width: 480px){.invitation-card{width:260px;min-height:340px;padding:1.3rem 1rem;border-radius:20px}.invitation-header{margin-bottom:1.2rem}.invitation-icon{font-size:2.2rem}.invitation-title{font-size:1.35rem}.baby-name{font-size:1.6rem}.invitation-baby{padding:.8rem 0;margin-bottom:1.2rem}.detail-item{padding:.7rem}.invitation-footer{margin-top:auto}}@media (max-width: 375px){.invitation-card{width:240px;min-height:320px;padding:1.2rem .9rem}.invitation-icon{font-size:2rem}.invitation-title{font-size:1.25rem}.baby-name{font-size:1.4rem}}@media (max-height: 500px) and (orientation: landscape){.invitation-card{width:280px;min-height:auto;padding:1.2rem}.invitation-header{margin-bottom:1rem}.invitation-baby{padding:.8rem 0;margin-bottom:1rem}.invitation-details{gap:.8rem;margin-bottom:1rem}.detail-item{padding:.6rem}}@media (prefers-reduced-motion: reduce){.invitation-card,.invitation-icon,.baby-name,.detail-item,.detail-icon{transition:none;animation:none}}.scene3d-container{width:100%;height:100vh;height:100dvh;position:relative;overflow:hidden;background:linear-gradient(180deg,var(--color-bg-dark) 0%,var(--color-bg-mid) 100%);touch-action:none}.loading-hint{position:absolute;bottom:120px;left:50%;transform:translate(-50%);pointer-events:none;z-index:10}.loading-hint p{color:var(--color-text-subtle);font-size:14px;text-align:center;margin:0;animation:fadeInOut 2s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.3}50%{opacity:.8}}.debug-info{position:absolute;top:20px;right:20px;padding:12px 20px;background:#ff6b9d26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,107,157,.3);border-radius:var(--radius-sm);color:#fff;font-size:14px;z-index:10;pointer-events:none;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.interaction-hint{position:absolute;bottom:200px;left:50%;transform:translate(-50%);pointer-events:none;z-index:10}.interaction-hint p{color:var(--color-text-subtle);font-size:13px;text-align:center;margin:0;padding:8px 16px;background:#0a162899;border-radius:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:hintFloat 3s ease-in-out infinite}@keyframes hintFloat{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-5px);opacity:.8}}.scene-controls{position:absolute;bottom:30px;right:30px;z-index:10;display:flex;flex-direction:column;gap:10px}.scene-control-btn{width:44px;height:44px;border:none;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;color:#fff;font-size:18px;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.scene-control-btn:hover,.scene-control-btn:active{background:#ff6b9d4d;transform:scale(1.1)}.scene-control-btn:active{transform:scale(.95)}@media (max-width: 768px){.loading-hint{bottom:100px}.loading-hint p{font-size:12px}.debug-info{top:10px;right:10px;font-size:12px;padding:8px 12px}.interaction-hint{bottom:160px}.interaction-hint p{font-size:12px;padding:6px 12px}.scene-controls{bottom:20px;right:20px}.scene-control-btn{width:40px;height:40px;font-size:16px}}@media (max-width: 480px){.loading-hint{bottom:90px}.loading-hint p{font-size:11px}.debug-info{font-size:11px;padding:6px 10px;border-radius:6px}.interaction-hint{bottom:140px}.interaction-hint p{font-size:11px}.scene-controls{bottom:15px;right:15px;gap:8px}.scene-control-btn{width:36px;height:36px;font-size:14px}}@media (max-height: 500px) and (orientation: landscape){.loading-hint{bottom:80px}.interaction-hint{bottom:120px}.debug-info{top:60px}.scene-controls{bottom:15px;right:15px;flex-direction:row}}@media (prefers-reduced-motion: reduce){.loading-hint p,.debug-info,.interaction-hint p{animation:none}.scene-control-btn{transition:none}}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;background:linear-gradient(135deg,var(--color-bg-dark) 0%,var(--color-bg-mid) 100%);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .5s ease-out;overflow:hidden}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none}.loading-star{position:absolute;width:2px;height:2px;background:#fffc;border-radius:50%;animation:starTwinkle 2s ease-in-out infinite;box-shadow:0 0 4px #ffffff80}.loading-star-1{top:20%;left:15%;animation-delay:0s}.loading-star-2{top:40%;right:20%;animation-delay:.4s}.loading-star-3{bottom:30%;left:25%;animation-delay:.8s}.loading-star-4{top:60%;right:30%;animation-delay:1.2s}.loading-star-5{bottom:20%;left:50%;animation-delay:1.6s}.loading-content{position:relative;z-index:1;text-align:center;padding:2rem;max-width:500px;width:100%;will-change:transform}.loading-logo{margin-bottom:3rem;animation:logoFadeIn 1s ease-out}.logo-icon{font-size:4rem;margin-bottom:1rem;animation:iconBounce 2s ease-in-out infinite;display:inline-block;transition:transform var(--transition-normal);cursor:default}.logo-icon:hover{transform:scale(1.1);animation-play-state:paused}.logo-title{font-size:2.5rem;font-weight:700;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;animation:titleSlideIn .8s ease-out;filter:drop-shadow(0 0 10px rgba(255,107,157,.3))}.logo-subtitle{font-size:1rem;color:var(--color-text-muted);margin:0;opacity:.9;animation:subtitleFadeIn 1s ease-out .3s both}.loading-progress-container{margin-bottom:1.5rem;animation:progressFadeIn 1s ease-out .5s both}.loading-progress-bar{width:100%;height:6px;background:#ffffff1a;border-radius:10px;overflow:hidden;margin-bottom:.8rem;box-shadow:inset 0 1px 3px #0000004d}.loading-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:10px;transition:width .05s linear;box-shadow:0 0 10px #ff6b9d80;position:relative;overflow:hidden;will-change:width;transform:translateZ(0)}.loading-progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progressShine 1.5s ease-in-out infinite}.loading-progress-text{font-size:1rem;font-weight:600;color:var(--color-secondary);margin:0;font-variant-numeric:tabular-nums;letter-spacing:.05em}.loading-status{font-size:1.1rem;color:var(--color-text-secondary);margin:0 0 2rem;font-weight:500;animation:statusFadeIn .5s ease-out;min-height:1.5rem}.loading-hint{animation:hintFadeIn 1.5s ease-out 1s both}.loading-hint p{font-size:.9rem;color:var(--color-text-subtle);margin:0;animation:hintPulse 2s ease-in-out infinite}@keyframes starTwinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}@keyframes logoFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes titleSlideIn{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes subtitleFadeIn{0%{opacity:0}to{opacity:.9}}@keyframes progressFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes progressShine{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes statusFadeIn{0%{opacity:0}to{opacity:1}}@keyframes hintFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes hintPulse{0%,to{opacity:.4}50%{opacity:.8}}@media (max-width: 768px){.loading-content{padding:1.5rem}.logo-icon{font-size:3rem}.logo-title{font-size:2rem}.logo-subtitle{font-size:.9rem}.loading-status{font-size:1rem}.loading-hint p{font-size:.85rem}}@media (max-width: 480px){.loading-content{padding:1.2rem}.loading-logo{margin-bottom:2rem}.logo-icon{font-size:2.5rem}.logo-title{font-size:1.75rem}.logo-subtitle{font-size:.85rem}.loading-status{font-size:.95rem;margin-bottom:1.5rem}.loading-progress-container{margin-bottom:1.2rem}.loading-hint p{font-size:.8rem}}@media (max-width: 375px){.logo-icon{font-size:2rem}.logo-title{font-size:1.5rem}.loading-progress-bar{height:5px}}@media (max-height: 600px){.loading-logo{margin-bottom:1.5rem}.logo-icon{font-size:2rem;margin-bottom:.5rem}.logo-title{font-size:1.5rem}.loading-status,.loading-progress-container{margin-bottom:1rem}}@media (max-height: 500px) and (orientation: landscape){.loading-content{padding:1rem}.loading-logo{margin-bottom:1rem}.logo-icon{font-size:1.8rem;margin-bottom:.3rem}.logo-title{font-size:1.3rem}.logo-subtitle{font-size:.75rem}.loading-status{font-size:.85rem;margin-bottom:.8rem}}@media (prefers-reduced-motion: reduce){.loading-screen *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.app{width:100%;height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.header{position:absolute;top:0;left:0;right:0;z-index:100;text-align:center;padding:1.5rem 1rem;background:linear-gradient(180deg,#0a1628e6,#0a162800);animation:fadeIn 1s ease-in;user-select:none;-webkit-user-select:none}.title{font-size:2.5rem;font-weight:700;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.3rem;text-shadow:0 0 20px rgba(255,107,157,.3);animation:titleGlow 3s ease-in-out infinite}.subtitle{font-size:1rem;color:var(--color-text-muted);font-weight:300;letter-spacing:.1em}.main{flex:1;width:100%;height:100%;position:relative}.footer{position:absolute;bottom:0;left:0;right:0;z-index:100;text-align:center;padding:1.5rem 1rem;background:#0a1628d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--color-border);animation:slideUp 1s ease-out;will-change:transform;transform:translateZ(0)}.info-card{max-width:600px;margin:0 auto}.event-time,.event-location{margin:.5rem 0;font-size:.95rem;color:var(--color-text-secondary);line-height:1.6;display:flex;align-items:center;justify-content:center;gap:.5rem}.event-time{font-weight:500}.event-location{opacity:.9}.rsvp-button{margin-top:1rem;padding:.8rem 2rem;font-size:1rem;font-weight:600;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-md);touch-action:manipulation;white-space:nowrap;position:relative;overflow:hidden}.rsvp-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.rsvp-button:hover:before{left:100%}.rsvp-button:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.rsvp-button:active{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.rsvp-button:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.rsvp-button:active:after{width:300px;height:300px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes titleGlow{0%,to{text-shadow:0 0 20px rgba(255,107,157,.3)}50%{text-shadow:0 0 30px rgba(255,107,157,.5),0 0 60px rgba(255,107,157,.3)}}@media (max-width: 768px){.title{font-size:2rem}.subtitle{font-size:.9rem}.placeholder p{font-size:1.2rem}.footer p{font-size:.9rem}.rsvp-button{padding:.7rem 1.8rem;font-size:.95rem}}@media (max-width: 480px){.header{padding:1rem .8rem}.title{font-size:1.75rem}.subtitle{font-size:.85rem;letter-spacing:.08em}.footer{padding:1.2rem .8rem}.event-time,.event-location{font-size:.85rem;flex-direction:column;gap:.3rem}.rsvp-button{padding:.7rem 1.5rem;font-size:.9rem;margin-top:.8rem}}@media (max-width: 375px){.title{font-size:1.5rem}.subtitle,.event-time,.event-location{font-size:.8rem}}@media (max-height: 500px) and (orientation: landscape){.header{padding:.8rem}.title{font-size:1.5rem}.footer{padding:.8rem}.rsvp-button{padding:.5rem 1.2rem;font-size:.85rem;margin-top:.5rem}}@media (prefers-reduced-motion: reduce){.header,.footer,.title,.rsvp-button:before,.rsvp-button:after{animation:none;transition:none}}@media (prefers-contrast: high){.rsvp-button{border:2px solid white}.footer{border-top-width:2px}}:root{--color-primary: #ff6b9d;--color-primary-light: #ff8fb3;--color-primary-dark: #e85a8a;--color-secondary: #ffa06b;--color-secondary-light: #ffb88a;--color-bg-dark: #0a1628;--color-bg-mid: #1a2a4a;--color-bg-light: rgba(26, 42, 74, .9);--color-text-primary: #ffffff;--color-text-secondary: #d8e2f8;--color-text-muted: #a8b8d8;--color-text-subtle: rgba(255, 255, 255, .6);--color-border: rgba(255, 107, 157, .2);--color-border-light: rgba(255, 255, 255, .15);--color-border-highlight: rgba(255, 107, 157, .3);--shadow-sm: 0 2px 10px rgba(0, 0, 0, .2);--shadow-md: 0 4px 15px rgba(255, 107, 157, .3);--shadow-lg: 0 6px 20px rgba(255, 107, 157, .4);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .5);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 50px}*{margin:0;padding:0;box-sizing:border-box}html{overscroll-behavior:none;scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg-dark);color:var(--color-text-primary);overflow:hidden;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#root{width:100vw;height:100vh;position:relative}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}::-webkit-scrollbar-thumb{background:#ff6b9d4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ff6b9d80}*{scrollbar-width:thin;scrollbar-color:rgba(255,107,157,.3) rgba(255,255,255,.05)}::selection{background:#ff6b9d4d;color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus{outline:none}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input:focus,textarea:focus{outline:none}@media (max-width: 320px){html{font-size:14px}}@media (min-width: 321px) and (max-width: 375px){html{font-size:15px}}@media (max-height: 500px) and (orientation: landscape){html{font-size:14px}}
