@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;min-height:100vh;position:relative;overflow-x:hidden}.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{grid-template-columns:1fr 420px;align-items:stretch;min-height:100vh;display:grid}.login-marketing{flex-direction:column;justify-content:center;gap:40px;min-height:100vh;padding:56px 64px;display:flex;position:relative}.login-marketing:after{content:"";background:linear-gradient(#0000,#ff69872e,#0000);width:1px;position:absolute;top:8%;bottom:8%;right:0}.login-brand{align-items:center;gap:10px;display:flex}.login-brand-icon{color:#ffb6c1d9;background:linear-gradient(135deg,#ff698733,#b4327826);border:1px solid #ff698747;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.login-brand-name{letter-spacing:.14em;color:#ffb6c180;font-size:13px;font-weight:400}.login-hero{flex-direction:column;gap:18px;display:flex}.login-badge{color:#ffb6c1b3;letter-spacing:.07em;background:#ff698717;border:1px solid #ff69872e;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(2.2rem,3.5vw,3.4rem);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:#f0e8f57a;max-width:460px;margin:0;font-size:15px;font-weight:300;line-height:1.8}.login-features{grid-template-columns:1fr 1fr;gap:12px;max-width:520px;display:grid}.feature-card{background:var(--fc-bg);border:1px solid #ffffff0d;border-radius:14px;align-items:flex-start;gap:12px;padding:16px 14px;transition:border-color .25s,transform .2s;display:flex}.feature-card:hover{border-color:#ffb6c124;transform:translateY(-1px)}.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:4px;padding-top:1px;display:flex}.feature-label{color:#f0e8f5d9;font-size:13px;font-weight:500;line-height:1}.feature-desc{color:#f0e8f561;font-size:11.5px;font-weight:300;line-height:1.55}.login-form-side{flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100vh;padding:56px 40px;display:flex}.login-card{-webkit-backdrop-filter:blur(16px);background:#ffffff0a;border:1px solid #ffb6c121;border-radius:24px;width:100%;max-width:340px;padding:36px 30px;box-shadow:0 0 60px #b432781a,inset 0 1px #ffffff0f}.login-card-header{text-align:center;flex-direction:column;align-items:center;gap:10px;margin-bottom:30px;display:flex}.login-lock-icon{color:#ffb6c1bf;background:linear-gradient(135deg,#ff69872e,#b4327821);border:1px solid #ff698738;border-radius:16px;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.login-title{color:#f0e8f5f2;margin:0;font-family:Playfair Display,serif;font-size:22px;font-weight:600;line-height:1.2}.login-subtitle{color:#f0e8f561;margin:0;font-size:13px;font-weight:300}.login-form{flex-direction:column;gap:20px;display:flex}.field-group{flex-direction:column;gap:8px;display:flex}.field-label{color:#f0e8f580;letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:500}.field-wrapper{align-items:center;display:flex;position:relative}.field-icon{color:#ffb6c159;pointer-events:none;flex-shrink:0;position:absolute;left:14px}.field-input{color:#f0e8f5e6;-webkit-text-fill-color:#f0e8f5e6;background:#ffffff0a;border:1px solid #ffb6c11c;border-radius:12px;outline:none;width:100%;padding:13px 42px;font-family:Inter,sans-serif;font-size:14px;line-height:1;transition:border-color .2s,box-shadow .2s}.field-input::placeholder{color:#f0e8f52e}.field-input:focus{border-color:#ff698761;box-shadow:0 0 0 3px #ff698712}.field-input:-webkit-autofill{-webkit-text-fill-color:#f0e8f5e6;-webkit-box-shadow:inset 0 0 0 1000px #12081cfa}.field-input:-webkit-autofill:focus{-webkit-text-fill-color:#f0e8f5e6;-webkit-box-shadow:inset 0 0 0 1000px #12081cfa}.field-eye{cursor:pointer;color:#ffb6c14d;background:0 0;border:none;align-items:center;padding:6px;line-height:0;transition:color .2s;display:flex;position:absolute;right:12px}.field-eye:hover{color:#ffb6c1a6}.login-error{color:#ff7878d9;text-align:center;background:#ff505012;border:1px solid #ff505024;border-radius:10px;margin:0;padding:10px 14px;font-size:13px;line-height:1.4}.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%;min-height:50px;padding:14px;font-family:Inter,sans-serif;font-size:15px;font-weight:500;transition:box-shadow .2s;display:flex;box-shadow:0 0 20px #ff69874d,0 4px 12px #00000040}.login-btn:disabled{opacity:.65;cursor:not-allowed}.login-btn:not(:disabled):hover{box-shadow:0 0 30px #ff698780,0 4px 16px #0000004d}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin;display:block}@keyframes spin{to{transform:rotate(360deg)}}.login-no-signup{text-align:center;color:#f0e8f540;margin:0;font-size:12px;line-height:1.5}.login-footer{color:#ffb6c138;letter-spacing:.08em;align-items:center;gap:5px;font-size:11px;display:flex}@media (width<=960px){.login-layout{grid-template-rows:auto auto;grid-template-columns:1fr}.login-form-side{order:1;justify-content:flex-start;min-height:auto;padding:64px 24px 40px}.login-marketing{order:2;justify-content:flex-start;gap:32px;min-height:auto;padding:40px 24px 56px}.login-marketing:after{display:none}.login-features,.login-subtext{max-width:100%}}@media (width<=480px){.login-form-side{padding:48px 20px 32px}.login-card{max-width:100%;padding:28px 22px}.login-marketing{gap:28px;padding:32px 20px 48px}.login-headline{font-size:2rem}.login-subtext{font-size:14px}.login-features{grid-template-columns:1fr;gap:10px}}@media (width>=1280px){.login-layout{grid-template-columns:1fr 460px}.login-marketing{padding:72px 80px}.login-form-side{padding:72px 56px}}
