@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@300;400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{color:#f0e8f5;-webkit-font-smoothing:antialiased;background:#0d0a14;font-family:Inter,sans-serif;overflow-x:hidden}.memory-page{z-index:1;justify-content:center;align-items:flex-start;min-height:100vh;padding:48px 20px 64px;display:flex;position:relative}.memory-page:before{content:"";z-index:-1;background:radial-gradient(80% 60% at 20% 0,#641e508c 0%,#0000 60%),radial-gradient(60% 50% at 80% 100%,#280a5099 0%,#0000 60%),linear-gradient(160deg,#0d0a14 0%,#140a1e 40%,#0a0d1a 100%);position:fixed;inset:0}.orb{filter:blur(80px);pointer-events:none;z-index:0;border-radius:50%;position:fixed}.orb-1{background:radial-gradient(circle,#b432782e 0%,#0000 70%);width:400px;height:400px;animation:12s ease-in-out infinite orbFloat;top:-100px;left:-100px}.orb-2{background:radial-gradient(circle,#5014a033 0%,#0000 70%);width:300px;height:300px;animation:15s ease-in-out infinite reverse orbFloat;bottom:0;right:-50px}.orb-3{background:radial-gradient(circle,#c850641a 0%,#0000 70%);width:250px;height:250px;animation:10s ease-in-out 2s infinite orbFloat;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes orbFloat{0%,to{transform:translate(0)scale(1)}33%{transform:translate(20px,-20px)scale(1.05)}66%{transform:translate(-15px,10px)scale(.97)}}.memory-content{z-index:2;text-align:center;flex-direction:column;align-items:center;gap:28px;width:100%;max-width:560px;display:flex;position:relative}.brand{letter-spacing:.18em;text-transform:uppercase;color:#ffb6c18c;align-items:center;gap:6px;font-size:11px;font-weight:400;display:inline-flex}.brand-heart{color:#ff6987b3}.recipient-block{flex-direction:column;align-items:center;gap:6px;display:flex}.for-label{color:#f0e8f580;letter-spacing:.05em;font-size:13px;font-weight:300}.recipient-name{background:linear-gradient(135deg,#ffd6e0 0%,#ffb3c6 40%,#e891b8 80%,#c06fa0 100%);-webkit-text-fill-color:transparent;text-shadow:none;-webkit-background-clip:text;background-clip:text;font-family:Playfair Display,serif;font-size:clamp(2.6rem,8vw,4.2rem);font-weight:600;line-height:1.1}.name-underline{background:linear-gradient(90deg,#0000,#ff6987b3,#0000);border-radius:2px;width:60px;height:2px;margin-top:4px}.memory-title{color:#ffd2e1bf;max-width:400px;font-family:Playfair Display,serif;font-size:clamp(1rem,3.5vw,1.25rem);font-style:italic;font-weight:400;line-height:1.5}.meta-row{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.meta-item{color:#f0e8f573;letter-spacing:.04em;align-items:center;gap:5px;font-size:12px;display:flex}.dedication-card{text-align:left;-webkit-backdrop-filter:blur(12px);background:#ffffff0a;border:1px solid #ffb6c126;border-radius:20px;width:100%;padding:32px 28px 24px;position:relative;box-shadow:0 0 40px #b4327814,inset 0 1px #ffffff0f}.quote-mark{color:#ff698733;pointer-events:none;-webkit-user-select:none;user-select:none;font-family:Playfair Display,serif;font-size:72px;line-height:.5;position:absolute;top:18px;left:18px}.dedication-line{color:#f0e8f5d1;padding-left:8px;font-size:15px;font-weight:300;line-height:1.8}.dedication-signature{color:#ffb6c1a6;text-align:right;margin-top:20px;font-family:Playfair Display,serif;font-size:14px;font-style:italic}.audio-intro{letter-spacing:.08em;text-transform:uppercase;color:#ffb6c180;justify-content:center;align-items:center;gap:6px;margin-bottom:12px;font-size:12px;display:flex}.inline-heart{color:#ff6987b3}.audio-player{width:100%}.player-card{-webkit-backdrop-filter:blur(12px);background:#ffffff0a;border:1px solid #ffb6c12e;border-radius:20px;width:100%;padding:24px 22px 20px;box-shadow:0 0 60px #b432781f,inset 0 1px #ffffff12}.player-header{align-items:center;gap:14px;margin-bottom:18px;display:flex}.mic-icon{background:linear-gradient(135deg,#ff698740,#b4327833);border:1px solid #ff69874d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.mic-icon svg{color:#ffb6c1d9;width:18px;height:18px}.player-meta{text-align:left;flex-direction:column;gap:2px;display:flex}.player-label{text-transform:uppercase;letter-spacing:.1em;color:#f0e8f566;font-size:11px}.player-sender{color:#ffd2e1eb;font-family:Playfair Display,serif;font-size:16px;font-weight:600}.waveform-container{margin-bottom:14px;position:relative}.waveform-canvas{border-radius:8px;width:100%;height:60px;display:block}.waveform-hint{color:#ffb6c159;letter-spacing:.05em;pointer-events:none;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;inset:0}.progress-bar-track{cursor:pointer;background:#ffffff14;border-radius:4px;height:4px;margin-bottom:8px;position:relative}.progress-bar-fill{background:linear-gradient(90deg,#ff6987cc,#c850a0e6);border-radius:4px;height:100%;transition:width .1s linear}.progress-dot{background:#ff6987;border-radius:50%;width:10px;height:10px;transition:left .1s linear;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 0 8px #ff6987cc}.time-row{color:#f0e8f559;justify-content:space-between;margin-bottom:18px;font-size:11px;display:flex}.controls{justify-content:center;align-items:center;gap:16px;display:flex}.ctrl-btn{cursor:pointer;color:#ffb6c199;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:color .2s;display:flex}.ctrl-btn:hover{color:#ffb6c1f2}.ctrl-btn.secondary{width:36px;height:36px}.ctrl-btn.play-btn{color:#fff;background:linear-gradient(135deg,#ff6987 0%,#c060a0 100%);border-radius:50%;width:56px;height:56px;transition:box-shadow .2s;box-shadow:0 0 24px #ff698766,0 4px 12px #0000004d}.ctrl-btn.play-btn:hover{color:#fff;box-shadow:0 0 32px #ff698799,0 4px 16px #00000059}.audio-error{color:#ff8282b3;text-align:center;margin-top:10px;font-size:12px}.page-footer{flex-direction:column;align-items:center;gap:8px;padding-top:8px;display:flex}.page-footer p{color:#f0e8f54d;letter-spacing:.04em;font-size:12px}.footer-brand{color:#ffb6c14d;letter-spacing:.08em;align-items:center;gap:5px;font-size:11px;display:flex}@media (width<=480px){.memory-page{padding:32px 16px 56px}.dedication-card{padding:28px 20px 20px}.player-card{padding:20px 16px 18px}.ctrl-btn.play-btn{width:52px;height:52px}.memory-content{gap:22px}}@media (width>=768px){.memory-page{align-items:center;min-height:100vh}.memory-content{max-width:600px}.dedication-card{padding:40px 36px 30px}.dedication-line{font-size:16px}.player-card{padding:28px 26px 24px}}@media (width>=1024px){.memory-content{max-width:640px}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ff698740;border-radius:4px}::selection{color:#ffd6e0;background:#ff69874d}.login-page{z-index:1;align-items:stretch;min-height:100vh;display:flex;position:relative}.login-page:before{content:"";z-index:-1;background:radial-gradient(70% 60% at 10% 10%,#781e5a80 0%,#0000 60%),radial-gradient(60% 50% at 90% 90%,#320a648c 0%,#0000 60%),linear-gradient(160deg,#0d0a14 0%,#120818 40%,#0a0d1a 100%);position:fixed;inset:0}.login-layout{width:100%;min-height:100vh;display:flex}.login-marketing{flex-direction:column;flex:55%;justify-content:center;gap:36px;padding:48px 52px;display:flex;position:relative}.login-marketing:after{content:"";background:linear-gradient(#0000,#ff698733,#0000);width:1px;position:absolute;top:10%;bottom:10%;right:0}.login-brand{align-items:center;gap:10px;display:flex}.login-brand-icon{color:#ffb6c1e6;background:linear-gradient(135deg,#ff698740,#b4327833);border:1px solid #ff69874d;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.login-brand-name{letter-spacing:.12em;color:#ffb6c199;font-size:14px;font-weight:400}.login-hero{flex-direction:column;gap:16px;display:flex}.login-badge{color:#ffb6c1bf;letter-spacing:.06em;background:#ff69871a;border:1px solid #ff698733;border-radius:100px;align-items:center;gap:6px;width:fit-content;padding:6px 14px;font-size:11px;display:inline-flex}.login-headline{color:#f0e8f5f2;margin:0;font-family:Playfair Display,serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:700;line-height:1.15}.login-headline-accent{background:linear-gradient(135deg,#ffd6e0 0%,#ffb3c6 40%,#e891b8 80%,#c06fa0 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.login-subtext{color:#f0e8f580;max-width:420px;margin:0;font-size:15px;font-weight:300;line-height:1.75}.login-features{grid-template-columns:1fr 1fr;gap:12px;max-width:480px;display:grid}.feature-card{background:var(--fc-bg);border:1px solid #ffffff0d;border-radius:14px;align-items:flex-start;gap:12px;padding:16px;transition:border-color .2s;display:flex}.feature-card:hover{border-color:#ffb6c126}.feature-icon{width:40px;height:40px;color:var(--fc-color);background:#ffffff0d;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.feature-text{flex-direction:column;gap:3px;display:flex}.feature-label{color:#f0e8f5d9;font-size:13px;font-weight:500}.feature-desc{color:#f0e8f566;font-size:11.5px;font-weight:300;line-height:1.5}.login-form-side{flex-direction:column;flex:0 0 420px;justify-content:center;align-items:center;gap:20px;padding:48px 40px;display:flex}.login-card{-webkit-backdrop-filter:blur(16px);background:#ffffff0a;border:1px solid #ffb6c124;border-radius:24px;width:100%;padding:36px 32px;box-shadow:0 0 60px #b432781a,inset 0 1px #ffffff0f}.login-card-header{text-align:center;flex-direction:column;align-items:center;gap:8px;margin-bottom:28px;display:flex}.login-lock-icon{color:#ffb6c1cc;background:linear-gradient(135deg,#ff698733,#b4327826);border:1px solid #ff698740;border-radius:16px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:4px;display:flex}.login-title{color:#f0e8f5f2;margin:0;font-family:Playfair Display,serif;font-size:22px;font-weight:600}.login-subtitle{color:#f0e8f566;margin:0;font-size:13px;font-weight:300}.login-form{flex-direction:column;gap:18px;display:flex}.field-group{flex-direction:column;gap:7px;display:flex}.field-label{color:#f0e8f58c;letter-spacing:.05em;text-transform:uppercase;font-size:12px;font-weight:500}.field-wrapper{align-items:center;display:flex;position:relative}.field-icon{color:#ffb6c166;pointer-events:none;position:absolute;left:14px}.field-input{color:#f0e8f5e6;-webkit-text-fill-color:#f0e8f5e6;background:#ffffff0a;border:1px solid #ffb6c11f;border-radius:12px;outline:none;width:100%;padding:12px 44px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s}.field-input::placeholder{color:#f0e8f533}.field-input:focus{border-color:#ff698766;box-shadow:0 0 0 3px #ff698714}.field-input:-webkit-autofill{-webkit-text-fill-color:#f0e8f5e6;-webkit-box-shadow:inset 0 0 0 1000px #140a1ef2,inset 0 0 0 3px #ff698714}.field-input:-webkit-autofill:focus{-webkit-text-fill-color:#f0e8f5e6;-webkit-box-shadow:inset 0 0 0 1000px #140a1ef2,inset 0 0 0 3px #ff698714}.field-eye{cursor:pointer;color:#ffb6c159;background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;right:14px}.field-eye:hover{color:#ffb6c1b3}.login-error{color:#ff7878d9;text-align:center;background:#ff505012;border:1px solid #ff505026;border-radius:10px;margin:0;padding:10px 14px;font-size:13px}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff6987 0%,#c060a0 100%);border:none;border-radius:12px;justify-content:center;align-items:center;width:100%;margin-top:4px;padding:14px;font-family:Inter,sans-serif;font-size:15px;font-weight:500;transition:box-shadow .2s,opacity .2s;display:flex;box-shadow:0 0 24px #ff698759,0 4px 12px #00000040}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn:not(:disabled):hover{box-shadow:0 0 32px #ff698780,0 4px 16px #0000004d}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:block}@keyframes spin{to{transform:rotate(360deg)}}.login-no-signup{text-align:center;color:#f0e8f547;margin:0;font-size:12px}.login-footer{color:#ffb6c140;letter-spacing:.08em;align-items:center;gap:5px;font-size:11px;display:flex}@media (width<=900px){.login-layout{flex-direction:column}.login-marketing{gap:24px;padding:40px 28px 32px}.login-marketing:after{display:none}.login-form-side{flex:none;padding:0 20px 48px}.login-features{max-width:100%}}@media (width<=480px){.login-marketing{gap:20px;padding:32px 20px 24px}.login-features{grid-template-columns:1fr}.login-headline{font-size:1.75rem}.login-subtext{font-size:14px}.login-form-side{padding:0 16px 40px}.login-card{padding:28px 22px}}@media (width>=1200px){.login-marketing{max-width:680px;padding:64px 80px}.login-form-side{flex:0 0 480px;padding:64px 56px}}
