.love-popup-overlay{position:fixed;inset:0;background:rgba(13,0,29,.65);display:none;align-items:center;justify-content:center;padding:20px;z-index:12000;backdrop-filter:blur(4px)}
.love-popup-overlay.active{display:flex}
.love-popup-card{background:#fff;border-radius:24px;box-shadow:0 20px 60px rgba(183,110,121,.45);padding:35px;max-width:420px;width:100%;border:3px solid rgba(233,30,99,.15);animation:lovePopupIn .25s ease-out}
.love-popup-icon{font-size:3rem;color:#e91e63;margin-bottom:1rem;animation:pulse 1.5s ease-in-out infinite}
.love-popup-title{font-size:1.6rem;font-weight:700;color:#b76e79;margin-bottom:.75rem}
.love-popup-message{font-size:1.05rem;color:#7a4a53;margin-bottom:1.25rem}
.love-popup-btn{border-radius:14px}
.bishwash-btn{background:linear-gradient(135deg,#ff9a9e 0%,#fad0c4 100%);border:none;color:#8a2a45;font-weight:600;padding:14px 28px;border-radius:18px;box-shadow:0 10px 25px rgba(250,208,196,.5);transition:transform .2s ease,box-shadow .2s ease;font-size:1.1rem;min-width:150px}
.bishwash-btn:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 14px 30px rgba(250,208,196,.7)}
.bishwash-btn:disabled{opacity:.65;box-shadow:none;transform:none}
@keyframes lovePopupIn{from{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.choice-btn{background:#fff;border:2px solid rgba(233,30,99,.25);border-radius:18px;padding:16px 32px;font-size:1.1rem;font-weight:600;color:#b76e79;box-shadow:0 12px 30px rgba(183,110,121,.2);transition:transform .2s ease,box-shadow .2s ease,background .2s ease;min-width:170px}
.choice-btn i{color:#e91e63}
.choice-btn:hover{background:linear-gradient(135deg,#ffe1ec 0%,#ffd1d7 100%);box-shadow:0 16px 35px rgba(183,110,121,.35);transform:translateY(-4px)}
.choice-btn:active{transform:translateY(-1px)}
.choice-btn:disabled{opacity:.65;box-shadow:none;transform:none}
body.sad-mode{background:linear-gradient(160deg,#341931 0%,#5c1a2f 50%,#12000d 100%);color:#fbe4ea}
.sad-card{border-color:rgba(233,30,99,.35);box-shadow:0 25px 50px rgba(0,0,0,.45);background:rgba(255,255,255,.97)}
.sad-emoji{font-size:4rem;animation:tears 1.2s ease-in-out infinite}
.sad-message{font-size:1.1rem;color:#7a4a53;line-height:1.6}
.sad-action-card{background:#fff4f7;border-radius:18px;border:2px dashed rgba(233,30,99,.35)}
@keyframes tears{0%{transform:translateY(0)}50%{transform:translateY(4px)}100%{transform:translateY(0)}}
.floating-hearts{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.floating-hearts .heart{position:absolute;font-size:1.2rem;opacity:.65;animation:floatHeart 18s linear infinite;color:#fff}
@keyframes floatHeart{0%{transform:translateY(100vh) scale(.7);opacity:0}10%{opacity:.6}100%{transform:translateY(-120vh) scale(1.2);opacity:0}}
body.ending-screen{background:linear-gradient(140deg,#110019 0%,#371432 40%,#6a1c3c 100%);color:#fff}
.ending-wrapper{position:relative;z-index:2;padding:40px 15px}
.ending-card{background:#fff;border:1px solid rgba(58,7,34,.08);box-shadow:0 40px 80px rgba(0,0,0,.55);color:#50142f}
.ending-confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.confetti-piece{position:absolute;width:8px;height:16px;border-radius:4px;animation:confettiFall 6s linear infinite;top:-15%}
@keyframes confettiFall{0%{transform:translateY(-20%) rotate(0);opacity:0}10%{opacity:1}100%{transform:translateY(140vh) rotate(320deg);opacity:0}}
.celebration-badge{display:inline-flex;align-items:center;gap:8px;background:#ffe4ec;color:#b7264f;padding:8px 18px;border-radius:999px;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase}
.ending-heart-shine{width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,#fff 0%,rgba(255,255,255,.08) 65%);margin:0 auto 20px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px rgba(255,255,255,.35);animation:glowPulse 3s ease-in-out infinite;font-size:3rem;color:#ff87b7;position:relative}
.ending-heart-shine::after{content:'';position:absolute;width:160px;height:160px;border-radius:50%;border:1px solid rgba(255,255,255,.2);animation:glowPulse 4s ease-in-out infinite;opacity:.5}
@keyframes glowPulse{0%,100%{transform:scale(1);box-shadow:0 0 25px rgba(255,255,255,.35)}50%{transform:scale(1.05);box-shadow:0 0 45px rgba(255,255,255,.6)}}
.ending-title{font-size:2.6rem;color:#821a44;margin-bottom:1rem;text-shadow:0 4px 25px rgba(0,0,0,.15)}
.ending-message{font-size:1.1rem;color:#6a1c3c;margin-bottom:1.5rem}
.ending-mini-card{background:#fff6fb;padding:20px;border-radius:18px;border:1px solid rgba(183,34,93,.15);height:100%;text-align:left;color:#701636}
.ending-mini-card i{font-size:1.5rem;color:#ea3f7a;margin-bottom:.75rem}
.ending-mini-card h5{font-size:1.1rem;color:#821a44;margin-bottom:.5rem}
.ending-mini-card p{font-size:.95rem;color:#8b3554;margin-bottom:0}
.ending-actions .btn{border-radius:999px}
.promise-card{background:#fff6fb;border-radius:18px;border:1px solid rgba(183,34,93,.15);padding:25px;color:#6a1c3c}
.promise-list{list-style:none;padding:0;margin:0}
.promise-list li{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;color:#6a1c3c}
.promise-list li:last-child{margin-bottom:0}
.promise-list i{color:#ea3f7a;margin-top:4px}
.ending-footer{font-size:.9rem;color:#6a1c3c}
@media (max-width:768px){
	.ending-title{font-size:2.1rem}
	.ending-mini-card{text-align:center}
}
body.recording-shell{background:linear-gradient(145deg,#ffdde1 0%,#ee9ca7 100%);min-height:100vh;color:#5c0f2b}
body.recording-shell .journey-shell{padding:0}
body.recording-shell .love-card.journey-frame-card{max-width:none;width:100%;min-height:100vh;border-radius:0;border:none;box-shadow:none;padding:0;background:transparent}
.journey-shell .love-card{max-width:1100px;width:100%;padding:0;border-radius:30px}
.recording-status-card{min-height:100%;position:relative}
.recording-pill{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;background:rgba(255,255,255,.8);border-radius:999px;font-weight:600;color:#d81b60}
.recording-dot{width:10px;height:10px;border-radius:50%;background:#ff1744;animation:pulse-red 1.5s ease-in-out infinite;display:inline-block}
.recording-preview-wrapper{position:relative;width:100%;border-radius:20px;overflow:hidden;box-shadow:0 20px 45px rgba(233,30,99,.35);background:#000}
.recording-preview-wrapper video{width:100%;height:240px;object-fit:cover}
.recording-preview-overlay{position:absolute;inset:0;background:linear-gradient(145deg,rgba(0,0,0,.4),rgba(92,15,43,.65));display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:6px;font-weight:600}
.journey-frame-card{border-radius:24px;overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.2)}
.journey-frame{width:100%;height:100%;min-height:78vh;border:none}
body.recording-shell .journey-frame-card{border-radius:0;box-shadow:none}
body.recording-shell .journey-frame{min-height:100vh}
.recording-shell .love-title{color:#b7264f;font-size:2rem}
body.love-theme{background:linear-gradient(135deg,#ffcdd2 0%,#b76e79 100%);min-height:100vh;font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;color:#333;overflow-x:hidden}body.love-theme::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 30%,rgba(233,30,99,.1) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(183,110,121,.15) 0%,transparent 40%);z-index:-1}.love-card{background:#fff8f9;border-radius:20px;box-shadow:0 10px 40px rgba(233,30,99,.15);border:2px solid rgba(233,30,99,.2);position:relative;overflow:hidden;max-width:600px;margin:0 auto}.love-card::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.8) 0%,transparent 70%);z-index:0}.love-card>*{position:relative;z-index:1}.heart-animation{animation:pulse 1.5s ease-in-out infinite;color:#e91e63}.heart-animation i{animation:heartbeat 1.2s ease-in-out infinite}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes heartbeat{0%,100%{transform:scale(1)}10%,30%{transform:scale(1.1)}20%,40%{transform:scale(1.05)}}.love-title{color:#e91e63;font-weight:700;font-size:2.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1);margin-bottom:1.5rem}.btn-love{background:linear-gradient(135deg,#b76e79 0%,#e91e63 100%);border:none;color:#fff;font-weight:600;padding:12px 30px;border-radius:50px;transition:all .3s ease;box-shadow:0 4px 15px rgba(183,110,121,.4)}.btn-love:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(183,110,121,.6);color:#fff}.btn-love:active{transform:translateY(0)}.progress-bar-love{background:linear-gradient(90deg,#ffcdd2 0%,#b76e79 100%);transition:width .6s ease}.question-card{background:#fff;border-radius:15px;padding:20px;box-shadow:0 4px 15px rgba(233,30,99,.15);border-left:4px solid #b76e79;animation:fadeInUp .6s ease forwards;opacity:0}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.question-text{font-size:1.1rem;color:#e91e63;font-weight:500;line-height:1.6}.love-textarea{border:2px solid #ffcdd2;border-radius:12px;padding:15px;font-size:1rem;transition:all .3s ease;resize:vertical}.love-textarea:focus{border-color:#b76e79;box-shadow:0 0 0 .2rem rgba(183,110,121,.25);outline:none}@media (max-width:768px){.love-title{font-size:2rem}.love-card{margin:15px;padding:25px 20px!important}.btn-love{width:100%}}.recording-screen{background:linear-gradient(135deg,#ffebee 0%,#fce4ec 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.record-btn{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#e91e63 0%,#b76e79 100%);border:none;color:#fff;font-size:1.2rem;box-shadow:0 6px 20px rgba(233,30,99,.5);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.record-btn::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}.record-btn:active::after{width:200px;height:200px}.record-btn i{font-size:2rem}.recording-indicator{display:inline-block;width:12px;height:12px;background:#e91e63;border-radius:50%;margin-right:10px;animation:pulse-red 1.5s ease-in-out infinite}@keyframes pulse-red{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.final-reveal{text-align:center;padding:40px 20px}.proposal-message{font-size:3rem;color:#e91e63;font-weight:700;margin:30px 0;text-shadow:3px 3px 6px rgba(0,0,0,.2);animation:fadeIn 1s ease}