@import"https://fonts.googleapis.com/css2?family=Great+Vibes&family=Poppins:wght@300;400;500;600;700&display=swap";:root{--primary: #e63946;--primary-dark: #9d0208;--primary-light: #ff4d6d;--rose: #ff6b81;--rose-light: #ff8fa3;--blush: #ffe5ec;--blush-light: #fff0f3;--deep-red: #6b0f1a;--white: #fff5f7;--gold: #ffd700;--gold-light: #ffe44d;--dark: #1a0a0e;--dark-card: #2a0f15;--shadow-color: rgba(230, 57, 70, .3);--font-script: "Great Vibes", cursive;--font-body: "Poppins", sans-serif;--radius: 16px;--radius-sm: 8px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--dark);color:var(--white);min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border:none;border-radius:50px;font-family:var(--font-body);font-weight:600;font-size:1rem;cursor:pointer;transition:var(--transition);text-decoration:none;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.2),transparent);transform:translate(-100%);transition:transform .6s}.btn:hover:after{transform:translate(100%)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 4px 20px var(--shadow-color)}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px var(--shadow-color)}.btn-secondary{background:transparent;color:var(--rose);border:2px solid var(--rose)}.btn-secondary:hover{background:var(--rose);color:#fff;transform:translateY(-3px)}.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--dark);box-shadow:0 4px 20px #ffd7004d}.btn-gold:hover{transform:translateY(-3px);box-shadow:0 8px 30px #ffd70066}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.form-group label{font-size:.9rem;font-weight:500;color:var(--rose-light)}.form-group input,.form-group textarea{padding:14px 18px;border:2px solid rgba(255,107,129,.2);border-radius:var(--radius-sm);background:#ffffff0d;color:var(--white);font-family:var(--font-body);font-size:1rem;transition:var(--transition);outline:none}.form-group input:focus,.form-group textarea:focus{border-color:var(--rose);background:#ffffff14;box-shadow:0 0 20px #ff6b8126}.form-group input::placeholder,.form-group textarea::placeholder{color:#fff5f74d}.form-group textarea{resize:vertical;min-height:100px}.glass-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,107,129,.15);border-radius:var(--radius);padding:40px;box-shadow:0 8px 32px #0000004d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fadeInUp{animation:fadeInUp .6s ease-out forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}.footer{text-align:center;padding:24px;color:#fff5f766;font-size:.85rem;margin-top:auto}.footer span{color:var(--rose);font-weight:600}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--dark)}::-webkit-scrollbar-thumb{background:var(--primary-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.error-msg{background:#e6394626;border:1px solid var(--primary);color:var(--rose-light);padding:12px 18px;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:16px}.success-msg{background:#00c85326;border:1px solid #00c853;color:#69f0ae;padding:12px 18px;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:16px}@media(max-width:768px){.glass-card{padding:24px;margin:0 16px}.btn{padding:12px 24px;font-size:.9rem}}.floating-hearts-container{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.floating-heart{position:absolute;bottom:-50px;animation:floatUp linear infinite;will-change:transform}@keyframes floatUp{0%{transform:translateY(0) translate(0) rotate(0) scale(1);opacity:0}5%{opacity:1}25%{transform:translateY(-25vh) translate(20px) rotate(90deg) scale(.95)}50%{transform:translateY(-55vh) translate(-15px) rotate(180deg) scale(.85)}75%{transform:translateY(-80vh) translate(10px) rotate(270deg) scale(.7)}90%{opacity:.8}to{transform:translateY(-110vh) translate(-10px) rotate(360deg) scale(.4);opacity:0}}.home-page{min-height:100vh;display:flex;flex-direction:column;position:relative}.home-nav{display:flex;align-items:center;justify-content:space-between;padding:16px clamp(16px,4vw,40px);position:relative;z-index:10}.nav-brand{display:flex;align-items:center;gap:8px}.nav-heart{font-size:clamp(1.4rem,4vw,1.8rem)}.nav-logo{font-family:var(--font-script);font-size:clamp(1.3rem,4vw,1.8rem);color:var(--rose)}.btn-sm{padding:10px 20px;font-size:.85rem}.hero-section{text-align:center;padding:clamp(20px,5vh,40px) 16px 16px;position:relative;z-index:10}.hero-emoji{font-size:clamp(48px,12vw,72px);margin-bottom:12px;animation:float 3s ease-in-out infinite}.hero-title{font-family:var(--font-script);font-size:clamp(2rem,7vw,3.5rem);background:linear-gradient(135deg,var(--rose),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}.hero-subtitle{font-size:clamp(.85rem,2.5vw,1.1rem);color:#fff5f799;max-width:550px;margin:0 auto;line-height:1.6;padding:0 16px}.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,32px);max-width:900px;margin:clamp(20px,4vw,40px) auto;padding:0 16px;position:relative;z-index:10}.action-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;transition:var(--transition);padding:clamp(20px,4vw,40px)}.action-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px #e6394633}.action-icon{font-size:clamp(36px,8vw,48px);animation:float 3s ease-in-out infinite}.action-title{font-family:var(--font-script);font-size:clamp(1.4rem,4vw,2rem);color:var(--rose)}.action-desc{color:#fff5f780;font-size:clamp(.8rem,2.2vw,.95rem);line-height:1.5}.view-wish-form{display:flex;gap:10px;width:100%;margin-top:8px}.wish-name-input{flex:1;padding:12px 16px;border:2px solid rgba(255,107,129,.2);border-radius:50px;background:#ffffff0d;color:var(--white);font-family:var(--font-body);font-size:.95rem;outline:none;transition:var(--transition);min-width:0}.wish-name-input:focus{border-color:var(--rose);box-shadow:0 0 20px #ff6b8126}.wish-name-input::placeholder{color:#fff5f74d}@media(max-width:768px){.home-actions{grid-template-columns:1fr;gap:16px;max-width:500px}.view-wish-form{flex-direction:column}}@media(max-width:360px){.hero-title{font-size:1.8rem}.action-card{padding:16px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:20px}.auth-container{position:relative;z-index:10;width:100%;max-width:440px}.auth-back{display:inline-block;color:var(--rose-light);text-decoration:none;font-size:.9rem;margin-bottom:16px;transition:var(--transition)}.auth-back:hover{color:var(--rose);transform:translate(-4px)}.auth-card{padding:40px}.auth-header{text-align:center;margin-bottom:28px}.auth-emoji{font-size:48px;display:block;margin-bottom:12px}.auth-title{font-family:var(--font-script);font-size:2.5rem;color:var(--rose);margin-bottom:6px}.auth-subtitle{color:#fff5f780;font-size:.9rem}.auth-btn{width:100%;margin-top:8px}.auth-switch{text-align:center;margin-top:20px;font-size:.9rem;color:#fff5f780}.auth-switch a{color:var(--rose);text-decoration:none;font-weight:600;transition:var(--transition)}.auth-switch a:hover{color:var(--gold)}@media(max-width:480px){.auth-card{padding:28px 20px}.auth-title{font-size:2rem}}.sparkles-container{position:absolute;inset:0;pointer-events:none;z-index:100;display:flex;align-items:center;justify-content:center}.sparkle{position:absolute;font-size:28px;pointer-events:none;filter:drop-shadow(0 0 8px rgba(255,215,0,.9))}.card-glow-ring{position:absolute;inset:-15px;border-radius:28px;z-index:-1;transition:box-shadow 1s ease}.wish-card-scene{perspective:1200px;width:min(380px,90vw);height:min(520px,75vh);cursor:pointer;margin:0 auto;position:relative}.wish-card-wrapper{width:100%;height:100%;position:relative;transform-style:preserve-3d}.wish-card-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0006,0 0 40px #e6394633}.wish-card-back{transform:rotateY(180deg)}.card-front-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:24px;text-align:center}.card-heart-icon{font-size:clamp(40px,10vw,64px);margin-bottom:16px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.3))}.card-front-title{font-family:Great Vibes,cursive;font-size:clamp(1.6rem,5vw,2.5rem);color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);margin-bottom:10px}.card-front-to{font-size:clamp(.9rem,3vw,1.2rem);color:#ffffffe6;font-weight:500;margin-bottom:20px}.card-tap-hint{font-size:clamp(.8rem,2.5vw,.95rem);color:#fffc;font-weight:400;letter-spacing:1px}.card-pattern{position:absolute;inset:0;z-index:1;opacity:.15}.card-pattern--roses{background-image:radial-gradient(circle at 20% 30%,rgba(255,255,255,.3) 2px,transparent 2px),radial-gradient(circle at 80% 70%,rgba(255,255,255,.3) 3px,transparent 3px),radial-gradient(circle at 50% 50%,rgba(255,255,255,.2) 4px,transparent 4px),radial-gradient(circle at 30% 80%,rgba(255,255,255,.3) 2px,transparent 2px),radial-gradient(circle at 70% 20%,rgba(255,255,255,.2) 3px,transparent 3px);background-size:60px 60px}.card-pattern--hearts{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='rgba(255,255,255,0.3)' d='M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z'/%3E%3C/svg%3E");background-size:30px 30px}.card-pattern--stars{background-image:radial-gradient(circle,rgba(255,215,0,.4) 1px,transparent 1px),radial-gradient(circle,rgba(255,215,0,.2) 1px,transparent 1px);background-size:40px 40px,20px 20px;background-position:0 0,10px 10px}.card-back-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;height:100%;padding:20px 16px;text-align:center;gap:10px;overflow-y:auto;-webkit-overflow-scrolling:touch}.card-back-content::-webkit-scrollbar{width:4px}.card-back-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.card-image-wrapper{width:clamp(80px,25vw,130px);height:clamp(80px,25vw,130px);border-radius:50%;overflow:hidden;border:3px solid rgba(255,255,255,.3);box-shadow:0 8px 24px #0000004d;flex-shrink:0}.card-image{width:100%;height:100%;object-fit:cover;display:block}.card-message-area{display:flex;flex-direction:column;gap:12px;max-width:100%;min-width:0}.card-message{font-size:clamp(.85rem,2.5vw,1.05rem);line-height:1.6;color:inherit;font-style:italic;padding:0 4px;word-wrap:break-word;overflow-wrap:break-word}.card-names{display:flex;flex-direction:column;gap:4px}.card-to,.card-from{font-size:clamp(.8rem,2.5vw,.95rem);opacity:.8}.card-to span,.card-from span{font-family:Great Vibes,cursive;font-size:clamp(1.1rem,3.5vw,1.5rem);opacity:1}.card-love-decoration{font-size:.7rem;letter-spacing:6px;opacity:.6;margin-top:4px}@media(max-width:480px){.wish-card-scene{width:min(300px,85vw);height:min(420px,70vh)}.card-front-content{padding:20px}.card-back-content{padding:16px;gap:8px}.card-message{max-height:90px}}@media(max-width:360px){.wish-card-scene{width:280px;height:380px}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-content{max-width:480px;width:100%;position:relative;text-align:center;max-height:90vh;overflow-y:auto}.modal-close{position:absolute;top:12px;right:12px;background:#ffffff1a;border:none;color:var(--rose-light);font-size:1.2rem;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;z-index:2}.modal-close:hover{background:var(--primary);color:#fff}.modal-heart-icon{font-size:clamp(36px,8vw,48px);margin-bottom:10px}.modal-title{font-family:var(--font-script);font-size:clamp(1.5rem,5vw,2rem);color:var(--rose);margin-bottom:4px}.modal-subtitle{color:#fff5f799;font-size:clamp(.8rem,2.5vw,.9rem);margin-bottom:20px}.share-qr-section{margin-bottom:20px}.qr-wrapper{background:#ffffff14;border-radius:var(--radius);padding:16px;display:inline-block;border:1px solid rgba(255,107,129,.15)}.qr-label{margin-top:8px;font-size:.8rem;color:#fff5f780}.share-link-section{margin-bottom:16px}.share-link-box{display:flex;align-items:center;background:#ffffff0d;border-radius:var(--radius-sm);border:1px solid rgba(255,107,129,.15);overflow:hidden}.share-link-text{flex:1;padding:10px 12px;font-size:clamp(.7rem,2vw,.8rem);color:var(--rose-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left;min-width:0}.btn-copy{background:var(--primary);border:none;color:#fff;padding:10px 14px;font-family:var(--font-body);font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;flex-shrink:0}.btn-copy:hover{background:var(--primary-dark)}.share-name-section{padding-top:14px;border-top:1px solid rgba(255,107,129,.1)}.share-name-hint{font-size:clamp(.75rem,2.2vw,.85rem);color:#fff5f780;line-height:1.5}.share-name-hint strong{color:var(--gold)}.dashboard-page{min-height:100vh;display:flex;flex-direction:column;position:relative}.dash-nav{display:flex;align-items:center;justify-content:space-between;padding:16px clamp(16px,4vw,40px);position:relative;z-index:10}.dash-main{flex:1;padding:0 16px;position:relative;z-index:10;max-width:900px;margin:0 auto;width:100%}.dash-header{text-align:center;margin-bottom:clamp(16px,4vw,32px)}.dash-title{font-family:var(--font-script);font-size:clamp(1.8rem,6vw,2.8rem);background:linear-gradient(135deg,var(--rose),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dash-subtitle{color:#fff5f780;font-size:clamp(.85rem,2.5vw,1rem);margin-top:4px}.steps-indicator{display:flex;justify-content:center;gap:clamp(20px,6vw,60px);margin-bottom:clamp(20px,4vw,40px);position:relative}.steps-line{position:absolute;top:18px;left:50%;transform:translate(-50%);width:clamp(140px,40vw,280px);height:3px;background:#ff6b8126;border-radius:2px;z-index:0}.steps-progress{height:100%;background:linear-gradient(90deg,var(--primary),var(--rose));border-radius:2px;transition:width .5s ease}.step-dot{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:1}.step-num{width:clamp(32px,8vw,40px);height:clamp(32px,8vw,40px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;background:var(--dark-card);border:2px solid rgba(255,107,129,.2);color:#fff5f766;transition:var(--transition)}.step-dot.active .step-num{background:var(--primary);border-color:var(--primary);color:#fff}.step-dot.current .step-num{box-shadow:0 0 20px var(--shadow-color);animation:pulse 2s infinite}.step-label{font-size:clamp(.55rem,2vw,.75rem);color:#fff5f766;font-weight:500}.step-dot.active .step-label{color:var(--rose-light)}.step-content{max-width:700px;margin:0 auto;width:100%}.step-title{font-family:var(--font-script);font-size:clamp(1.5rem,5vw,2rem);color:var(--rose);text-align:center;margin-bottom:8px}.step-hint{text-align:center;color:#fff5f766;font-size:.9rem;margin-bottom:20px}.step-actions{display:flex;justify-content:center;gap:12px;margin-top:24px;padding-bottom:32px;flex-wrap:wrap}.template-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}.template-card{border-radius:var(--radius);overflow:hidden;border:2px solid rgba(255,107,129,.1);cursor:pointer;transition:var(--transition);position:relative;background:var(--dark-card)}.template-card:hover{transform:translateY(-4px);border-color:var(--rose)}.template-card.selected{border-color:var(--gold);box-shadow:0 0 24px #ffd70033}.template-preview{height:clamp(100px,20vw,160px);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.template-emoji{font-size:clamp(32px,8vw,48px);position:relative;z-index:2;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.template-info{padding:10px;text-align:center}.template-info h3{font-size:clamp(.8rem,2.5vw,1rem);color:var(--white);margin-bottom:2px}.template-info p{font-size:clamp(.65rem,2vw,.8rem);color:#fff5f766}.template-check{position:absolute;top:8px;right:8px;width:24px;height:24px;background:var(--gold);color:var(--dark);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;z-index:3}.message-form{margin-top:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.photo-upload{margin-top:20px;text-align:center}.photo-dropzone{padding:clamp(30px,8vw,60px) 16px;border:2px dashed rgba(255,107,129,.25);border-radius:var(--radius);cursor:pointer;transition:var(--transition)}.photo-dropzone:hover{border-color:var(--rose);background:#ff6b810d}.dropzone-icon{font-size:clamp(32px,8vw,48px);display:block;margin-bottom:10px}.dropzone-text{font-size:.95rem;color:var(--rose-light);margin-bottom:4px}.dropzone-hint{font-size:.8rem;color:#fff5f74d}.photo-preview-area{display:flex;flex-direction:column;align-items:center;gap:12px}.photo-preview-img{width:clamp(120px,30vw,200px);height:clamp(120px,30vw,200px);object-fit:cover;border-radius:50%;border:3px solid var(--rose);box-shadow:0 8px 24px #e6394633}.preview-area{display:flex;justify-content:center;padding:16px 0}@media(max-width:768px){.template-grid{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}}@media(max-width:480px){.template-grid{grid-template-columns:1fr;max-width:280px;margin:20px auto 0}.step-actions{flex-direction:column;align-items:center}}.wish-view-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:16px}.wish-view-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;gap:clamp(16px,4vw,32px);width:100%}.wish-view-header{text-align:center;padding:0 12px}.wish-view-title{font-family:var(--font-script);font-size:clamp(1.6rem,6vw,2.8rem);background:linear-gradient(135deg,var(--rose),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}.wish-view-hint{color:#fff5f780;font-size:clamp(.85rem,2.5vw,1rem)}.wish-view-footer{margin-top:8px}.envelope-intro{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;padding:40px 24px;text-align:center}.envelope-icon{font-size:clamp(64px,18vw,100px);filter:drop-shadow(0 8px 30px rgba(230,57,70,.4))}.envelope-title{font-family:var(--font-script);font-size:clamp(1.6rem,5vw,2.5rem);background:linear-gradient(135deg,var(--rose-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.envelope-from{font-size:clamp(.9rem,3vw,1.1rem);color:#fff5f799;font-style:italic}.envelope-btn{margin-top:12px;font-size:clamp(.9rem,3vw,1.1rem);padding:14px 32px;border-radius:50px;border:none;cursor:pointer;font-weight:600;font-family:var(--font-body);background:linear-gradient(135deg,var(--gold),#ff9500,var(--rose));color:#1a0000;box-shadow:0 6px 30px #ffd70059,0 2px 10px #ff6b8133;letter-spacing:.5px;animation:btnGlow 3s ease-in-out infinite}@keyframes btnGlow{0%,to{box-shadow:0 6px 30px #ffd70059,0 2px 10px #ff6b8133}50%{box-shadow:0 6px 40px #ffd7008c,0 2px 20px #ff6b8159}}.envelope-sparkle-hint{font-size:.8rem;color:#ffe19666;letter-spacing:2px;margin-top:4px}.wish-view-loading{position:relative;z-index:10;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.loading-heart{font-size:clamp(48px,10vw,64px)}.wish-view-loading p{color:var(--rose-light);font-size:1rem}.wish-view-error{position:relative;z-index:10;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;padding:0 16px}.error-emoji{font-size:clamp(48px,10vw,64px)}.wish-view-error h2{font-family:var(--font-script);font-size:clamp(1.8rem,5vw,2.5rem);color:var(--rose)}.wish-view-error p{color:#fff5f780;max-width:400px}
