.greeting-page{min-height:100vh;padding:var(--space-lg) var(--space-md);padding-bottom:120px;position:relative;overflow:hidden}.decorations{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0}.decoration{position:absolute;font-size:3rem;opacity:.3;filter:blur(1px)}.decoration-1{top:10%;left:5%}.decoration-2{top:20%;right:10%}.decoration-3{bottom:30%;left:8%}.decoration-4{bottom:20%;right:5%}.greeting-content{max-width:700px;margin:0 auto;position:relative;z-index:1}.greeting-header{text-align:center;margin-bottom:var(--space-lg)}.photo-container{width:180px;height:180px;margin:0 auto var(--space-md);border-radius:50%;padding:5px;background:linear-gradient(135deg,var(--primary-gold) 0%,var(--primary-gold-light) 100%);box-shadow:0 10px 30px #d4af374d}.recipient-photo{width:100%;height:100%;object-fit:cover;border-radius:50%;border:4px solid var(--bg-dark)}.greeting-title{font-family:var(--font-display);font-size:clamp(2.5rem,8vw,4rem);font-weight:700;letter-spacing:.02em;margin-bottom:var(--space-xs)}.recipient-name{font-family:var(--font-display);font-size:1.5rem;color:var(--text-cream);font-weight:400;margin-top:var(--space-xs)}.greeting-message{padding:var(--space-lg);margin-bottom:var(--space-lg)}.message-intro{font-family:var(--font-display);font-size:1.3rem;color:var(--primary-gold);margin-bottom:var(--space-md);font-style:italic}.message-body{font-size:1.1rem;line-height:1.8;color:var(--text-cream);opacity:.9}.message-footer{margin-top:var(--space-lg);text-align:right;padding-top:var(--space-md);border-top:1px solid rgba(255,255,255,.1)}.signature{color:var(--text-cream);opacity:.7;font-size:.95rem}.signature-name{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-top:var(--space-xs)}.action-buttons{display:flex;justify-content:center;margin-bottom:var(--space-lg)}.send-letter-btn{display:inline-flex;align-items:center;gap:10px;padding:1rem 2rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--primary-gold);border-radius:50px;color:var(--primary-gold);text-decoration:none;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #0003}.send-letter-btn:hover{background:var(--primary-gold);color:var(--bg-dark);transform:translateY(-3px);box-shadow:0 8px 25px #d4af3766}.btn-icon{font-size:1.2rem}.wishes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.wish-card{padding:var(--space-md);text-align:center;cursor:default;transition:all .3s ease}.wish-icon{font-size:2.5rem;display:block;margin-bottom:var(--space-xs)}.wish-card p{font-size:.95rem;color:var(--text-cream);font-weight:500}@media(max-width:600px){.greeting-page{padding:var(--space-md) var(--space-sm);padding-bottom:140px}.greeting-message{padding:var(--space-md)}.photo-container{width:140px;height:140px}.decoration{font-size:2rem}.wishes-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-xs)}.wish-card{padding:var(--space-sm)}.wish-icon{font-size:2rem}}.share-section{text-align:center;background:#ffffff0d;padding:20px;border-radius:15px;border:1px solid rgba(212,175,55,.2);width:100%;margin-top:20px}.share-text{color:var(--text-cream);margin-bottom:15px;font-size:.95rem;opacity:.9}.share-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.share-btn,.view-letters-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:50px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease;text-decoration:none}.share-btn{background:transparent;border:1px solid var(--primary-gold);color:var(--primary-gold)}.share-btn:hover{background:#d4af371a;transform:translateY(-2px)}.view-letters-btn{background:linear-gradient(135deg,var(--primary-gold) 0%,var(--primary-gold-light) 100%);border:none;color:var(--bg-dark)}.view-letters-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #d4af374d}@media(max-width:600px){.share-buttons{flex-direction:column;gap:10px}.share-btn,.view-letters-btn{width:100%;justify-content:center}}.music-player-container{position:fixed;bottom:20px;left:20px;z-index:100}.floating-music-btn{width:60px;height:60px;border-radius:50%;border:none;background:conic-gradient(#333,#111,#333,#111,#333,#111,#333,#111,#333,#111,#333);border:2px solid var(--primary-gold);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #00000080;position:relative;z-index:102;overflow:hidden;transition:transform .3s ease}.floating-music-btn:before{content:"";position:absolute;width:40%;height:40%;background:var(--primary-gold);border-radius:50%;z-index:1}.floating-music-btn:after{content:"";position:absolute;width:10%;height:10%;background:#000;border-radius:50%;z-index:2}.floating-music-btn.playing{animation:rotate 3s linear infinite;box-shadow:0 0 20px #d4af3766}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.music-icon,.pulse-ring{display:none}.player-expanded{position:absolute;bottom:60px;left:0;width:280px;padding:15px;background:#0f0c29f2;border:1px solid rgba(212,175,55,.3);border-radius:15px;box-shadow:0 10px 30px #00000080;z-index:101;transform-origin:bottom left}.player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.track-name{font-size:.85rem;color:var(--text-cream);font-weight:500}.close-btn{background:none;border:none;color:var(--text-cream);font-size:1.2rem;cursor:pointer;padding:0 5px;opacity:.7}.close-btn:hover{opacity:1}.progress-container{margin-bottom:10px;cursor:pointer}.progress-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-gold)}.time-display{display:flex;justify-content:space-between;font-size:.7rem;color:#ffffff80;margin-top:4px}.controls-row{display:flex;align-items:center;gap:15px}.mini-play-btn{background:none;border:1px solid var(--primary-gold);color:var(--primary-gold);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;transition:all .2s}.mini-play-btn:hover{background:var(--primary-gold);color:var(--bg-dark)}.volume-control{flex:1;display:flex;align-items:center;gap:8px}.volume-icon{font-size:.9rem}.volume-slider{flex:1;height:4px;-webkit-appearance:none;background:#ffffff1a;border-radius:2px;outline:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--primary-gold);cursor:pointer}.music-tooltip{position:absolute;left:70px;bottom:15px;background:#0f0c29e6;color:var(--primary-gold);padding:8px 12px;border-radius:8px;font-size:.85rem;white-space:nowrap;border:1px solid rgba(212,175,55,.3);box-shadow:0 4px 15px #0000004d;pointer-events:none;z-index:103}.confetti-container{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden;z-index:1000}.confetti-particle{position:absolute;top:0;box-shadow:0 2px 10px #0003}.confetti-particle.square{transform-origin:center center}.send-letter-page{min-height:100vh;padding:var(--space-lg) var(--space-md);padding-bottom:100px;display:flex;justify-content:center}.form-container{width:100%;max-width:600px;padding:var(--space-lg)}.page-title{text-align:center;margin-bottom:var(--space-xs)}.page-subtitle{text-align:center;color:var(--text-cream);margin-bottom:var(--space-lg);line-height:1.6}.letter-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--primary-gold);font-weight:500;font-size:.9rem}.form-group input,.form-group textarea{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;color:#fff;font-family:inherit;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-gold);background:#ffffff1a}.submit-btn{background:linear-gradient(135deg,var(--primary-gold),#bf953f);color:var(--primary-dark);border:none;padding:1rem;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:var(--space-sm)}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #d4af374d}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{background:#ff44441a;border:1px solid rgba(255,68,68,.3);color:#f44;padding:1rem;border-radius:8px;text-align:center;font-size:.9rem}.voice-recorder-container{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.recorder-controls{display:flex;justify-content:center;width:100%}.record-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;color:#fff}.mic-icon{width:60px;height:60px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.record-btn:hover .mic-icon{background:#ffffff4d;transform:scale(1.1)}.recording-active{display:flex;flex-direction:column;align-items:center;gap:1rem}.recording-indicator{width:20px;height:20px;background-color:#f44;border-radius:50%;box-shadow:0 0 10px #f44}.timer{font-size:1.5rem;font-weight:700;font-family:monospace}.stop-btn{padding:.5rem 2rem;background:#f44;color:#fff;border:none;border-radius:20px;font-weight:700;cursor:pointer;transition:transform .2s}.stop-btn:hover{transform:scale(1.05)}.audio-preview{width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}.delete-recording-btn{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fffc;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .2s}.delete-recording-btn:hover{background:#ffffff1a;color:#fff}.letters-page{min-height:100vh;padding:var(--space-lg) var(--space-md);padding-bottom:100px;max-width:1000px;margin:0 auto}.letters-header{text-align:center;margin-bottom:var(--space-lg)}.letters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-md)}.letter-card{padding:var(--space-md);display:flex;flex-direction:column;height:100%}.back-link{color:#fff9;text-decoration:none;font-size:.9rem;transition:color .2s;display:inline-block;margin-bottom:var(--space-sm)}.back-link:hover{color:var(--primary-gold)}.letter-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:8px;gap:1rem}.sender-name{color:var(--primary-gold);font-family:var(--font-display);font-size:1.2rem}.instagram-link{font-size:.85rem;color:var(--text-cream);opacity:.7;text-decoration:none;transition:opacity .2s}.instagram-link:hover{opacity:1;color:var(--primary-gold)}.letter-message{flex:1;color:var(--text-cream);line-height:1.6;white-space:pre-wrap;margin-bottom:var(--space-md)}.letter-footer{text-align:right}.timestamp{font-size:.75rem;color:#fff6}.loading,.error,.empty-state{text-align:center;padding:var(--space-lg);color:var(--text-cream)}.cta-link{display:inline-block;margin-top:var(--space-md);color:var(--primary-gold);text-decoration:none;font-weight:600}@media(max-width:600px){.letters-grid{grid-template-columns:1fr}.letter-header{flex-direction:column;align-items:flex-start;gap:.25rem}.timestamp{align-self:flex-start}}.intro-animation{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;background:var(--bg-dark);z-index:1000}.intro-text-container{max-width:80%;text-align:center;padding:20px;position:relative;z-index:1}.intro-text{font-family:Playfair Display,serif;font-size:2rem;color:var(--text-cream);line-height:1.6;text-shadow:0 2px 10px rgba(0,0,0,.5)}.skip-hint{position:absolute;bottom:30px;font-size:.8rem;color:#ffffff4d;text-transform:uppercase;letter-spacing:2px}@media(max-width:768px){.intro-text{font-size:1.5rem}}.bokeh-container{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:0;pointer-events:none}.bokeh-circle{position:absolute;border-radius:50%;background:radial-gradient(circle,#d4af3733,#d4af3700 70%);filter:blur(40px);animation:float 20s infinite ease-in-out}.bokeh-circle:nth-child(1){width:400px;height:400px;top:-100px;left:-100px;background:radial-gradient(circle,#d4af3726,#d4af3700 70%);animation-duration:25s}.bokeh-circle:nth-child(2){width:300px;height:300px;top:40%;right:-50px;background:radial-gradient(circle,#ffffff1a,#fff0 70%);animation-duration:20s;animation-delay:-5s}.bokeh-circle:nth-child(3){width:250px;height:250px;bottom:-50px;left:20%;background:radial-gradient(circle,#d4af371a,#d4af3700 70%);animation-duration:18s;animation-delay:-10s}.bokeh-circle:nth-child(4){width:350px;height:350px;bottom:20%;right:20%;background:radial-gradient(circle,#ffffff0d,#fff0 70%);animation-duration:22s;animation-delay:-2s}.bokeh-circle:nth-child(5){width:200px;height:200px;top:20%;left:40%;background:radial-gradient(circle,#d4af371f,#d4af3700 70%);animation-duration:28s;animation-delay:-8s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-50px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.app{min-height:100vh;position:relative}.intro-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.intro-content{text-align:center;padding:var(--space-lg);max-width:400px}.intro-emoji{font-size:5rem;display:block;margin-bottom:var(--space-md);filter:drop-shadow(0 0 20px rgba(212,175,55,.4))}.intro-subtitle{font-family:var(--font-display);font-size:1.5rem;color:var(--text-cream);margin-bottom:var(--space-lg);font-weight:400}.start-button{font-family:var(--font-body);font-size:1.1rem;font-weight:600;padding:1rem 2.5rem;border:none;border-radius:50px;background:linear-gradient(135deg,var(--primary-gold) 0%,var(--primary-gold-light) 100%);color:var(--bg-dark);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #d4af374d}.start-button:hover{transform:translateY(-2px)}@media(max-width:480px){.intro-content{padding:var(--space-md)}.intro-emoji{font-size:4rem}.intro-subtitle{font-size:1.2rem}}:root{--primary-gold: #d4af37;--primary-gold-light: #f4d03f;--accent-purple: #6b5b95;--accent-purple-dark: #4a3f6b;--bg-dark: #0f0c29;--bg-mid: #302b63;--bg-light: #24243e;--text-light: #ffffff;--text-cream: #fef9e7;--font-display: "Playfair Display", Georgia, serif;--font-body: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--space-xs: .5rem;--space-sm: 1rem;--space-md: 2rem;--space-lg: 4rem;--space-xl: 6rem}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:linear-gradient(135deg,var(--bg-dark) 0%,var(--bg-mid) 50%,var(--bg-light) 100%);color:var(--text-light);min-height:100vh;overflow-x:hidden;line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}.text-gradient{background:linear-gradient(135deg,var(--primary-gold) 0%,var(--primary-gold-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glass-card{background:#ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--accent-purple);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-gold)}::selection{background:var(--primary-gold);color:var(--bg-dark)}
