@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Inter:wght@300;400;500;600&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0E1320;--bg-secondary: #0B0F1A;--text-primary: #F5F3EF;--text-muted: rgba(245, 243, 239, .72);--accent-rose: #CFA6A0;--accent-rose-light: rgba(207, 166, 160, .2);--accent-rose-glow: rgba(207, 166, 160, .4);--divider: rgba(245, 243, 239, .12)}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.app{position:relative;min-height:100vh}.particle-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#0e132099;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--divider)}.nav-container{max-width:1400px;margin:0 auto;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600;letter-spacing:.05em;color:var(--text-primary);text-decoration:none;transition:color .3s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.nav-logo:hover{color:var(--accent-rose)}.nav-logo:active{opacity:.7}.nav-links{display:flex;gap:2.5rem}.nav-links a{color:var(--text-muted);text-decoration:none;font-size:.95rem;font-weight:400;transition:color .3s ease;padding:.5rem 0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.nav-links a:hover{color:var(--text-primary)}.nav-links a:active{color:var(--accent-rose)}@media (hover: hover){.nav-links a:hover{color:var(--text-primary)}}.hero{position:relative;z-index:10;min-height:100vh;display:flex;align-items:center;padding:8rem 2rem 4rem}.hero-container{max-width:1400px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}.hero-left{max-width:600px}.hero-title{font-family:Playfair Display,serif;font-size:4rem;font-weight:600;line-height:1.15;margin-bottom:1.5rem;color:var(--text-primary)}.hero-subtitle{font-size:1.25rem;line-height:1.6;color:var(--accent-rose);margin-bottom:1.5rem;font-weight:400}.accent-letter{font-weight:600;font-size:1.35rem;color:var(--text-primary);text-shadow:0 0 20px rgba(207,166,160,.4);position:relative;display:inline-block}.hero-description{font-size:1.05rem;line-height:1.7;color:var(--text-muted);margin-bottom:2.5rem}.hero-actions{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2.5rem;background:var(--accent-rose);color:var(--bg-primary);text-decoration:none;border:none;border-radius:999px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px #cfa6a033;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px #cfa6a059;background:#d9b4ae}.btn-primary:active{transform:translateY(0);box-shadow:0 6px 24px #cfa6a040}.link-secondary{color:var(--text-muted);text-decoration:none;font-size:1rem;border-bottom:1px solid transparent;transition:all .3s ease;padding-bottom:2px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.link-secondary:hover{color:var(--text-primary);border-bottom-color:var(--text-primary)}.link-secondary:active{color:var(--accent-rose)}.hero-right{display:flex;justify-content:center;align-items:center}.presence-container{position:relative;width:500px;height:600px;display:flex;align-items:center;justify-content:center}.presence-glow{position:absolute;border-radius:50%;filter:blur(60px);animation:breathe 8s ease-in-out infinite}.presence-glow-1{width:300px;height:400px;background:radial-gradient(circle,rgba(207,166,160,.35) 0%,transparent 70%);animation-delay:0s}.presence-glow-2{width:250px;height:350px;background:radial-gradient(circle,rgba(245,243,239,.18) 0%,transparent 70%);animation-delay:2s}.presence-glow-3{width:200px;height:300px;background:radial-gradient(circle,rgba(207,166,160,.28) 0%,transparent 70%);animation-delay:4s}.presence-silhouette{position:absolute;width:180px;height:280px;background:radial-gradient(ellipse at center,rgba(245,243,239,.08) 0%,transparent 65%);border-radius:50%/60% 60% 40% 40%;filter:blur(20px);animation:breathe 8s ease-in-out infinite;animation-delay:1s}.presence-veil{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,transparent 20%,rgba(14,19,32,.4) 80%);border-radius:24px}@keyframes breathe{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.85}}.what-it-is,.how-it-works,.preview,.final-cta{position:relative;z-index:10;padding:10rem 2rem}.what-it-is{padding-top:12rem}.section-container{max-width:900px;margin:0 auto;text-align:center}.kicker{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent-rose);margin-bottom:1.5rem;font-weight:500}.section-title{font-family:Playfair Display,serif;font-size:3rem;font-weight:600;line-height:1.2;margin-bottom:2rem;color:var(--text-primary)}.section-description{font-size:1.15rem;line-height:1.7;color:var(--text-muted);max-width:700px;margin:0 auto}.steps{margin-top:6rem;display:flex;flex-direction:column;gap:4rem;max-width:700px;margin-left:auto;margin-right:auto}.step{text-align:left;transition:transform .3s ease}.step:hover{transform:translate(8px)}.step-content{border-left:2px solid var(--accent-rose);padding-left:2rem;transition:border-color .3s ease}.step:hover .step-content{border-left-color:var(--text-primary)}.step-title{font-family:Playfair Display,serif;font-size:1.75rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.step-description{font-size:1.05rem;line-height:1.7;color:var(--text-muted)}.preview-content{display:flex;align-items:center;justify-content:center;gap:3rem;margin-top:4rem}.preview-play{position:relative;width:100px;height:100px;background:transparent;border:2px solid var(--accent-rose);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.preview-play:hover{border-color:var(--text-primary);transform:scale(1.05)}.preview-play:active{transform:scale(.98)}.preview-play-icon{width:0;height:0;border-left:20px solid var(--accent-rose);border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:4px;transition:border-left-color .3s ease}.preview-play.playing .preview-play-icon:before{border-left-color:transparent;border-right:4px solid currentColor;margin-left:0}.preview-play.loading{pointer-events:none}.preview-play.loading .preview-play-icon:before{border:none;width:20px;height:20px;border-radius:50%;border-top:2px solid currentColor;border-right:2px solid transparent;animation:spin .8s linear infinite;margin-left:0}@keyframes spin{to{transform:rotate(360deg)}}.preview-play:hover .preview-play-icon{border-left-color:var(--text-primary)}.preview-ripple{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border:2px solid var(--accent-rose);border-radius:50%;opacity:0;animation:ripple 2s ease-out infinite}.preview-play.playing .preview-ripple{animation:ripple 2s ease-out infinite}@keyframes ripple{0%{transform:scale(1);opacity:.6}to{transform:scale(1.4);opacity:0}}.preview-text{text-align:left;max-width:400px}.preview-quote{font-family:Playfair Display,serif;font-size:1.5rem;font-style:italic;line-height:1.5;color:var(--text-primary);margin-bottom:.75rem;position:relative;padding-left:1.5rem}.preview-quote:before{content:'"';position:absolute;left:0;top:-.1em;font-size:2rem;color:var(--accent-rose);opacity:.5}.preview-caption{font-size:.85rem;color:var(--text-muted);font-weight:400}.final-cta{background:var(--bg-secondary);border-top:1px solid var(--divider);border-bottom:1px solid var(--divider)}.cta-title{font-family:Playfair Display,serif;font-size:2.5rem;font-weight:600;margin-bottom:2rem;color:var(--text-primary)}.cta-note{margin-top:1.5rem;font-size:.9rem;color:var(--text-muted)}.footer{position:relative;z-index:10;padding:3rem 2rem;background:var(--bg-secondary)}.footer-container{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.footer-copyright{font-size:.9rem;color:var(--text-muted)}.footer-links{display:flex;gap:2rem}.footer-links a{color:var(--text-muted);text-decoration:none;font-size:.9rem;transition:color .3s ease;padding:.5rem 0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.footer-links a:hover{color:var(--text-primary)}.footer-links a:active{color:var(--accent-rose)}.fade-in{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}.fade-in.visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.fade-in{opacity:1;transform:none}}@media (max-width: 1200px){.nav-container{padding:1.5rem}.hero{padding:8rem 1.5rem 4rem}.hero-title{font-size:3.5rem}}@media (max-width: 1024px){.hero-container{grid-template-columns:1fr;gap:4rem}.hero-left{max-width:100%}.hero-title{font-size:3rem}.presence-container{width:400px;height:500px;margin:0 auto}.section-title{font-size:2.5rem}.steps{margin-top:4rem}}@media (max-width: 900px){.nav-container{padding:1.25rem 1.5rem}.nav-logo{font-size:1.35rem}.nav-links{gap:2rem}.nav-links a{font-size:.9rem}.hero-title{font-size:2.75rem}.what-it-is,.how-it-works,.preview,.final-cta{padding:8rem 1.5rem}.what-it-is{padding-top:10rem}}@media (max-width: 768px){.nav-links{display:none}.nav-container{padding:1.25rem}.nav-logo{font-size:1.25rem}.hero{padding:6rem 1.25rem 3rem}.hero-title{font-size:2.5rem;line-height:1.2}.hero-subtitle{font-size:1.1rem;line-height:1.65}.accent-letter{font-size:1.2rem}.hero-description{font-size:1rem;line-height:1.7}.hero-actions{flex-direction:column;align-items:stretch;gap:1rem;width:100%}.btn-primary{width:100%;text-align:center;padding:1rem 2rem}.link-secondary{text-align:center;display:block}.presence-container{width:300px;height:400px;margin:0 auto}.section-title{font-size:2.25rem;line-height:1.25}.section-description{font-size:1rem;line-height:1.7}.what-it-is,.how-it-works,.preview,.final-cta{padding:6rem 1.25rem}.what-it-is{padding-top:8rem}.steps{margin-top:3rem;gap:3rem}.step:hover{transform:none}.step-content{padding-left:1.5rem}.step-title{font-size:1.5rem;line-height:1.3}.step-description{font-size:1rem;line-height:1.7}.preview-content{flex-direction:column;gap:2.5rem}.preview-play{width:90px;height:90px}.preview-play-icon{border-left:18px solid var(--accent-rose);border-top:11px solid transparent;border-bottom:11px solid transparent}.preview-text{text-align:center;max-width:100%}.preview-quote{font-size:1.35rem;line-height:1.55}.cta-title{font-size:2rem}.footer{padding:2.5rem 1.25rem}.footer-container{flex-direction:column;gap:1.5rem;text-align:center}.footer-links{gap:1.5rem}}@media (max-width: 480px){.nav-logo{font-size:1.15rem}.nav-container{padding:1rem}.hero{padding:5rem 1rem 2.5rem}.hero-title{font-size:2rem;line-height:1.2}.hero-subtitle{font-size:1rem;line-height:1.65}.accent-letter{font-size:1.1rem}.hero-description{font-size:.95rem;line-height:1.7}.btn-primary{padding:.9rem 1.75rem;font-size:.95rem}.link-secondary{font-size:.95rem}.presence-container{width:260px;height:340px}.what-it-is,.how-it-works,.preview,.final-cta{padding:5rem 1rem}.what-it-is{padding-top:6rem}.kicker{font-size:.7rem;margin-bottom:1.25rem}.section-title{font-size:1.85rem;line-height:1.25}.section-description{font-size:.95rem;line-height:1.7}.steps{margin-top:2.5rem;gap:2.5rem}.step-content{padding-left:1.25rem}.step-title{font-size:1.35rem;line-height:1.3}.step-description{font-size:.95rem;line-height:1.7}.preview-content{gap:2rem}.preview-play{width:80px;height:80px}.preview-play-icon{border-left:16px solid var(--accent-rose);border-top:10px solid transparent;border-bottom:10px solid transparent}.preview-quote{font-size:1.2rem;line-height:1.55;padding-left:1.25rem}.preview-quote:before{font-size:1.75rem}.preview-caption{font-size:.8rem}.cta-title{font-size:1.75rem;line-height:1.3}.cta-note{font-size:.85rem}.footer{padding:2rem 1rem}.footer-copyright,.footer-links a{font-size:.85rem}.footer-links{gap:1.25rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-content{background:var(--bg-secondary);border:1px solid var(--divider);border-radius:24px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative;padding:2.5rem}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease}.modal-close:hover{color:var(--text-primary);background:var(--divider)}.modal-step{display:flex;flex-direction:column;gap:1.5rem}.modal-title{font-family:Playfair Display,serif;font-size:1.75rem;font-weight:600;color:var(--text-primary);text-align:center}.modal-description{color:var(--text-muted);text-align:center;font-size:.95rem;line-height:1.6}.capture-options{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem}.record-section{display:flex;flex-direction:column;align-items:center;gap:1rem}.record-btn{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 3rem;background:transparent;border:2px solid var(--accent-rose);border-radius:16px;color:var(--accent-rose);cursor:pointer;transition:all .3s ease;width:100%}.record-btn:hover{background:var(--accent-rose-light);transform:translateY(-2px)}.record-btn span{font-size:1rem;font-weight:500}.recording-active{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;padding:1.5rem;background:#cfa6a01a;border-radius:16px;border:1px solid var(--accent-rose)}.recording-indicator{display:flex;align-items:center;gap:.75rem}.recording-dot{width:12px;height:12px;background:#ef4444;border-radius:50%;animation:pulse-recording 1s ease-in-out infinite}@keyframes pulse-recording{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.recording-time{font-size:1.5rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.recording-progress{width:100%;height:4px;background:var(--divider);border-radius:2px;position:relative;overflow:visible}.recording-progress-bar{height:100%;background:var(--accent-rose);border-radius:2px;transition:width .3s ease}.recording-min-marker{position:absolute;top:-4px;width:2px;height:12px;background:var(--text-muted);border-radius:1px}.recording-hint{font-size:.85rem;color:var(--text-muted);text-align:center}.stop-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ef4444;border:none;border-radius:999px;color:#fff;cursor:pointer;font-weight:500;transition:all .2s ease}.stop-btn:hover{background:#dc2626;transform:scale(1.02)}.divider{display:flex;align-items:center;gap:1rem;color:var(--text-muted);font-size:.85rem}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--divider)}.upload-section{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:transparent;border:1px dashed var(--text-muted);border-radius:12px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;width:100%;justify-content:center}.upload-btn:hover{border-color:var(--text-primary);color:var(--text-primary)}.upload-hint{font-size:.75rem;color:var(--text-muted)}.preview-section{display:flex;flex-direction:column;gap:1.5rem}.audio-preview{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--divider);border-radius:12px}.play-preview-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-rose);border:none;border-radius:50%;color:var(--bg-primary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.play-preview-btn:hover{transform:scale(1.05)}.preview-info{display:flex;flex-direction:column;gap:.25rem}.preview-label{font-size:.9rem;color:var(--text-primary)}.preview-duration{font-size:.8rem;color:var(--text-muted)}.preview-actions{display:flex;gap:1rem}.preview-actions .btn-secondary{flex:1;padding:.875rem 1.5rem;background:transparent;border:1px solid var(--divider);border-radius:999px;color:var(--text-muted);cursor:pointer;font-size:.95rem;transition:all .2s ease}.preview-actions .btn-secondary:hover{border-color:var(--text-primary);color:var(--text-primary)}.preview-actions .btn-primary{flex:1}.error-message{color:#ef4444;font-size:.9rem;text-align:center;padding:.75rem;background:#ef44441a;border-radius:8px}.processing-step{align-items:center;padding:2rem 0}.processing-animation{margin-bottom:1rem}.spinner{animation:spin 1s linear infinite;color:var(--accent-rose)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-status{color:var(--text-muted);font-size:.95rem}.result-step{gap:2rem}.result-card{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;background:#cfa6a014;border-radius:16px;border:1px solid var(--divider)}.result-meta{display:flex;gap:1.5rem;flex-wrap:wrap}.meta-item{font-size:.85rem;color:var(--text-muted)}.meta-item strong{color:var(--accent-rose)}.result-greeting{font-family:Playfair Display,serif;font-size:1.25rem;font-style:italic;line-height:1.6;color:var(--text-primary);margin:0;padding-left:1rem;border-left:3px solid var(--accent-rose)}.result-audio{display:flex;align-items:center;gap:1rem;padding-top:.5rem}.play-result-btn{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--accent-rose);border:none;border-radius:50%;color:var(--bg-primary);cursor:pointer;transition:all .2s ease}.play-result-btn:hover{transform:scale(1.05);box-shadow:0 8px 24px #cfa6a04d}.play-label{font-size:.95rem;color:var(--text-muted)}.result-actions{display:flex;gap:1rem}.result-actions .btn-secondary,.result-actions .btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:999px;font-size:.95rem;cursor:pointer;transition:all .2s ease}.result-actions .btn-secondary{background:transparent;border:1px solid var(--divider);color:var(--text-muted)}.result-actions .btn-secondary:hover{border-color:var(--text-primary);color:var(--text-primary)}.back-btn{display:flex;align-items:center;gap:.25rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:0;margin-bottom:.5rem;transition:color .2s ease}.back-btn:hover{color:var(--text-primary)}.occasion-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:.5rem}.occasion-grid .occasion-btn:last-child{grid-column:span 2}.occasion-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .5rem;background:transparent;border:1px solid var(--divider);border-radius:12px;cursor:pointer;transition:all .2s ease}.occasion-btn:hover{border-color:var(--text-muted);background:#f5f3ef08}.occasion-btn.selected{border-color:var(--accent-rose);background:var(--accent-rose-light)}.occasion-emoji{font-size:1.5rem}.occasion-label{font-size:.8rem;color:var(--text-muted)}.occasion-btn.selected .occasion-label{color:var(--text-primary)}.custom-message-section,.recipient-section,.special-request-section{margin-top:1rem}.input-hint{font-size:.75rem;color:var(--text-muted);opacity:.7;margin-top:.35rem}.terms-section{display:flex;flex-direction:column;gap:1.25rem;margin-top:.5rem}.terms-notice{background:#cfa6a014;border:1px solid var(--divider);border-radius:12px;padding:1.25rem}.terms-title{font-family:Playfair Display,serif;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.terms-text{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin-bottom:.75rem}.terms-text strong{color:var(--accent-rose)}.terms-list{margin:.75rem 0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.5rem}.terms-list li{font-size:.85rem;color:var(--text-muted);line-height:1.5}.terms-warning{font-size:.8rem;color:var(--accent-rose);opacity:.9;margin-bottom:0}.terms-checkbox{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-size:.9rem;color:var(--text-muted);line-height:1.5}.terms-checkbox input[type=checkbox]{width:18px;height:18px;margin-top:2px;accent-color:var(--accent-rose);cursor:pointer;flex-shrink:0}.terms-checkbox span{flex:1}.terms-continue-btn{width:100%}.terms-continue-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.script-preview{display:flex;flex-direction:column;gap:.75rem}.script-meta{display:flex;gap:.5rem;flex-wrap:wrap}.meta-badge{display:inline-block;padding:.35rem .75rem;background:var(--divider);border-radius:999px;font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.tone-badge{background:var(--accent-rose-light);color:var(--accent-rose)}.script-textarea{width:100%;padding:1rem;background:var(--bg-primary);border:1px solid var(--divider);border-radius:12px;color:var(--text-primary);font-size:1rem;font-family:Playfair Display,serif;font-style:italic;line-height:1.6;resize:none;transition:border-color .2s ease}.script-textarea:focus{outline:none;border-color:var(--accent-rose)}.script-textarea::-moz-placeholder{color:var(--text-muted);opacity:.5;font-style:normal}.script-textarea::placeholder{color:var(--text-muted);opacity:.5;font-style:normal}.script-hint{font-size:.8rem;color:var(--text-muted);opacity:.7}.generation-limit-hint{font-size:.75rem;color:var(--text-muted);text-align:center;margin-top:.75rem;opacity:.7}.voice-orb-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem 0}.voice-orb{position:relative;width:140px;height:140px;display:flex;align-items:center;justify-content:center}.orb-ring{position:absolute;border-radius:50%;border:1px solid var(--accent-rose);opacity:.3;transition:all .3s ease}.orb-ring-1{width:100%;height:100%;animation:orb-pulse 2s ease-in-out infinite}.orb-ring-2{width:120%;height:120%;animation:orb-pulse 2s ease-in-out infinite .3s}.orb-ring-3{width:140%;height:140%;animation:orb-pulse 2s ease-in-out infinite .6s}.voice-orb.playing .orb-ring{opacity:.6;border-color:var(--accent-rose)}.voice-orb.playing .orb-ring-1{animation:orb-wave .8s ease-in-out infinite}.voice-orb.playing .orb-ring-2{animation:orb-wave .8s ease-in-out infinite .15s}.voice-orb.playing .orb-ring-3{animation:orb-wave .8s ease-in-out infinite .3s}@keyframes orb-pulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.05);opacity:.5}}@keyframes orb-wave{0%,to{transform:scale(1);opacity:.4}50%{transform:scale(1.1);opacity:.8}}.orb-play-btn{width:80px;height:80px;border-radius:50%;background:var(--accent-rose);border:none;color:var(--bg-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:1}.orb-play-btn:hover{transform:scale(1.05);box-shadow:0 8px 32px #cfa6a066}.orb-hint{font-size:.9rem;color:var(--text-muted)}.start-over-link{display:flex;align-items:center;justify-content:center;gap:.35rem;background:transparent;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;padding:.5rem;margin-top:.5rem;transition:color .2s ease}.start-over-link:hover{color:var(--text-primary)}.result-step .result-actions{display:flex;gap:1rem;width:100%}.result-step .result-actions .btn-secondary,.result-step .result-actions .btn-primary{flex:1}.input-label{display:block;font-size:.9rem;color:var(--text-muted);margin-bottom:.5rem}.custom-textarea{width:100%;padding:1rem;background:var(--bg-primary);border:1px solid var(--divider);border-radius:12px;color:var(--text-primary);font-size:.95rem;font-family:inherit;resize:none;transition:border-color .2s ease}.custom-textarea:focus{outline:none;border-color:var(--accent-rose)}.custom-textarea::-moz-placeholder{color:var(--text-muted);opacity:.6}.custom-textarea::placeholder{color:var(--text-muted);opacity:.6}.recipient-input{width:100%;padding:.875rem 1rem;background:var(--bg-primary);border:1px solid var(--divider);border-radius:12px;color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:border-color .2s ease}.recipient-input:focus{outline:none;border-color:var(--accent-rose)}.recipient-input::-moz-placeholder{color:var(--text-muted);opacity:.6}.recipient-input::placeholder{color:var(--text-muted);opacity:.6}.generate-btn{width:100%;margin-top:1.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.generate-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 480px){.modal-content{padding:2rem 1.5rem;border-radius:20px}.modal-title{font-size:1.5rem}.record-btn{padding:1.5rem 2rem}.occasion-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.occasion-btn{padding:.875rem .5rem}.occasion-emoji{font-size:1.35rem}.occasion-label{font-size:.75rem}.result-meta{flex-direction:column;gap:.5rem}.result-greeting{font-size:1.1rem}.result-actions{flex-direction:column}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.block{display:block}.hidden{display:none}.resize{resize:both}
