:root{--bg:#06060e;--rose:#e63946;--rose-glow:rgba(230,57,70,0.6);--rose-soft:#ff6b7a;--gold:#d4a574;--gold-glow:rgba(212,165,116,0.5);--gold-light:#f0d9b5;--pink:#ff85a1;--cream:#fff5ee;--white:#fff;--text:#e8e0d8;--muted:#7a706a}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow:hidden;font-family:'Cormorant Garamond',serif;background:var(--bg);color:var(--text);user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}
#bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}

/* SCENES */
.scene{position:fixed;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 1.2s cubic-bezier(.4,0,.2,1);perspective:1200px}
.scene.active{opacity:1;pointer-events:auto;z-index:10}
.scene.exit-left{animation:exitLeft 1s cubic-bezier(.4,0,.2,1) forwards}
.scene.enter-right{animation:enterRight 1s cubic-bezier(.4,0,.2,1) forwards}
@keyframes exitLeft{0%{opacity:1;transform:scale(1) translateX(0)}100%{opacity:0;transform:scale(.8) translateX(-15%)}}
@keyframes enterRight{0%{opacity:0;transform:scale(.8) translateX(15%)}100%{opacity:1;transform:scale(1) translateX(0)}}
.scene-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}

/* SCENE 0 - ENVELOPE */
.stars-container{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.star{position:absolute;width:2px;height:2px;background:#fff;border-radius:50%;animation:twinkle var(--dur) ease-in-out infinite;opacity:0}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.5)}50%{opacity:var(--bright);transform:scale(1)}}
.shooting-stars{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.shooting-stars span{position:absolute;width:3px;height:3px;background:#fff;border-radius:50%;box-shadow:0 0 6px 2px rgba(255,255,255,.6);opacity:0;animation:shoot 4s ease-in-out infinite}
.shooting-stars span::after{content:'';position:absolute;top:50%;left:0;transform:translateY(-50%);width:80px;height:1px;background:linear-gradient(to left,rgba(255,255,255,.8),transparent)}
.shooting-stars span:nth-child(1){top:15%;left:70%}.shooting-stars span:nth-child(2){top:35%;left:85%;animation-delay:2.5s}.shooting-stars span:nth-child(3){top:8%;left:50%;animation-delay:5s}
@keyframes shoot{0%{opacity:0;transform:translate(0,0) rotate(-35deg)}5%{opacity:1}15%{opacity:1;transform:translate(-200px,120px) rotate(-35deg)}16%{opacity:0}100%{opacity:0}}
.envelope-3d{cursor:pointer;transform-style:preserve-3d;animation:envFloat 4s ease-in-out infinite;transition:transform .6s ease}
.envelope-3d:hover{transform:scale(1.05) rotateY(5deg)}
@keyframes envFloat{0%,100%{transform:translateY(0) rotateX(2deg)}50%{transform:translateY(-15px) rotateX(-2deg)}}
.envelope-wrapper{position:relative;width:260px;height:180px;transform-style:preserve-3d}
.env-back{position:absolute;inset:0;background:linear-gradient(145deg,#c1121f,#9b0d18);border-radius:8px;box-shadow:0 20px 80px rgba(230,57,70,.3),inset 0 0 30px rgba(0,0,0,.2)}
.env-front{position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(145deg,#d4202f,#b01525);clip-path:polygon(0 40%,50% 0,100% 40%,100% 100%,0 100%);border-radius:0 0 8px 8px;z-index:2}
.env-flap{position:absolute;top:0;left:0;right:0;height:55%;background:linear-gradient(to bottom,#a50e1c,#c1121f);clip-path:polygon(0 0,50% 100%,100% 0);transform-origin:top center;transition:transform .8s cubic-bezier(.4,0,.2,1);z-index:3}
.envelope-3d.opened .env-flap{transform:rotateX(180deg)}
.env-letter{position:absolute;width:80%;height:65%;left:10%;top:15%;background:var(--cream);border-radius:4px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.3);transition:transform .8s cubic-bezier(.175,.885,.32,1.275) .3s;z-index:1}
.env-letter p{font-family:'Great Vibes',cursive;font-size:1.8rem;color:var(--rose)}
.envelope-3d.opened .env-letter{transform:translateY(-70px) scale(1.05)}
.hint-text{margin-top:3rem;color:var(--gold);font-size:.95rem;letter-spacing:4px;text-transform:uppercase;animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* SCENE 1 - NAME */
.petals-layer{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.petal{position:absolute;width:14px;height:14px;background:var(--rose);border-radius:50% 0 50% 50%;opacity:0;animation:petalFall linear infinite;filter:blur(.5px)}
@keyframes petalFall{0%{opacity:0;transform:translateY(-20px) rotate(0deg) scale(.6)}10%{opacity:.7}90%{opacity:.5}100%{opacity:0;transform:translateY(calc(100vh + 20px)) rotate(720deg) scale(.3)}}
.cinematic-text{text-align:center;position:relative;z-index:2}
.pre-text{display:block;font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(1.3rem,4vw,2.5rem);color:var(--gold-light);opacity:0;transform:translateY(30px);animation:fadeUp 1.2s ease forwards .5s}
.mega-name{display:flex;justify-content:center;gap:.1em;margin-top:.5rem}
.mega-name .char{font-family:'Great Vibes',cursive;font-size:clamp(6rem,20vw,14rem);color:var(--rose);display:inline-block;opacity:0;transform:translateY(80px) scale(0) rotateY(90deg);animation:charReveal 1s cubic-bezier(.175,.885,.32,1.275) forwards;animation-delay:calc(1.2s + var(--i)*.25s);text-shadow:0 0 40px var(--rose-glow),0 0 80px rgba(230,57,70,.3);filter:drop-shadow(0 5px 20px var(--rose-glow))}
@keyframes charReveal{to{opacity:1;transform:translateY(0) scale(1) rotateY(0deg)}}
.light-burst{position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%) scale(0);background:radial-gradient(circle,rgba(230,57,70,.15),transparent 70%);border-radius:50%;animation:burst 2s ease-out forwards 1.5s;pointer-events:none}
@keyframes burst{0%{transform:translate(-50%,-50%) scale(0);opacity:1}100%{transform:translate(-50%,-50%) scale(3);opacity:0}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* SCENE 2 - LINKEDIN */
.floating-particles{position:absolute;inset:0;pointer-events:none}
.f-particle{position:absolute;border-radius:50%;animation:fFloat linear infinite;opacity:0}
@keyframes fFloat{0%{opacity:0;transform:translateY(0) scale(1)}20%{opacity:.6}80%{opacity:.4}100%{opacity:0;transform:translateY(-100vh) scale(.5)}}
.story-container{width:min(88vw,500px);background:linear-gradient(170deg,rgba(18,12,18,.97),rgba(12,8,14,.99));border:1px solid rgba(212,165,116,.2);border-radius:20px;padding:clamp(2rem,5vw,3rem);position:relative;overflow:hidden;box-shadow:0 30px 100px rgba(0,0,0,.5);animation:paperIn 1s ease forwards;opacity:0;transform:translateY(40px) rotateX(5deg)}
@keyframes paperIn{to{opacity:1;transform:translateY(0) rotateX(0)}}
.story-icon{width:60px;height:60px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#0077b5,#005fa3);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px rgba(0,119,181,.3);animation:iconFloat 3s ease-in-out infinite}
.linkedin-icon{width:32px;height:32px;color:#fff}
@keyframes iconFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.story-title{font-family:'Great Vibes',cursive;font-size:clamp(1.6rem,4vw,2.2rem);color:var(--gold);text-align:center;margin-bottom:1.5rem}
.story-text{position:relative;min-height:120px}
.story-text p{font-size:clamp(1rem,2.5vw,1.15rem);line-height:2.1;color:var(--text)}
.tw-cursor{color:var(--rose);font-weight:300;animation:blink .7s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* SCENE 3 - JOURNEY */
.journey-container{width:min(92vw,550px);text-align:center;z-index:2}
.journey-title{margin-bottom:1.5rem}
.journey-map{position:relative;width:100%;height:220px;background:linear-gradient(170deg,rgba(15,10,20,.9),rgba(10,8,15,.95));border:1px solid rgba(212,165,116,.15);border-radius:20px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4)}
#journey-canvas{position:absolute;inset:0;width:100%;height:100%}
.journey-labels{position:absolute;inset:0;pointer-events:none}
.j-label{position:absolute;display:flex;flex-direction:column;align-items:center;opacity:0;transition:opacity .8s ease}
.j-label.visible{opacity:1}
.j-label.start{bottom:25px;left:10%}.j-label.end{bottom:25px;right:10%}
.j-pin{font-size:1.8rem;animation:pinBounce 1.5s ease-in-out infinite}
@keyframes pinBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.j-label span{font-family:'Dancing Script',cursive;font-size:1rem;color:var(--gold);margin-top:.2rem;text-shadow:0 0 10px rgba(0,0,0,.8)}
.journey-car{position:absolute;font-size:2rem;bottom:55px;left:8%;opacity:0;transition:opacity .5s ease;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5));transform:scaleX(-1)}
.journey-car.visible{opacity:1}
.journey-km{position:absolute;top:15px;right:15px;font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--rose);text-shadow:0 0 15px var(--rose-glow);opacity:0;transition:opacity .5s ease}
.journey-km.visible{opacity:1}
.journey-texts{margin-top:2rem;min-height:80px;position:relative}
.j-text{font-size:clamp(1rem,3vw,1.3rem);font-style:italic;color:var(--text);line-height:1.8;opacity:0;transform:translateY(15px);transition:all .8s ease;position:absolute;width:100%;text-align:center}
.j-text.visible{opacity:1;transform:translateY(0)}

/* SCENE 4 - PHOTOS */
.photo-gallery{position:relative;width:min(85vw,380px);height:min(70vh,480px);perspective:800px}
.photo-frame{position:absolute;inset:0;border-radius:16px;overflow:hidden;opacity:0;transform:scale(.85) rotateY(40deg);transition:all .8s cubic-bezier(.4,0,.2,1);pointer-events:none;box-shadow:0 25px 80px rgba(0,0,0,.5)}
.photo-frame.active{opacity:1;transform:scale(1) rotateY(0deg);pointer-events:auto;z-index:5}
.photo-frame.prev{opacity:.4;transform:scale(.8) translateX(-60%) rotateY(25deg);z-index:3}
.photo-frame.next{opacity:.4;transform:scale(.8) translateX(60%) rotateY(-25deg);z-index:3}
.photo-frame img{width:100%;height:100%;object-fit:cover;display:block}
.photo-glow{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(6,6,14,.7) 100%);pointer-events:none}
.photo-frame::before{content:'';position:absolute;inset:-2px;border-radius:18px;z-index:-1;background:linear-gradient(135deg,var(--rose),var(--gold),var(--rose));opacity:0;transition:opacity .5s ease}
.photo-frame.active::before{opacity:1}
.photo-dots{display:flex;gap:10px;margin-top:1.5rem;z-index:10}
.p-dot{width:10px;height:10px;border-radius:50%;background:var(--muted);cursor:pointer;transition:all .4s ease}
.p-dot.active{background:var(--rose);box-shadow:0 0 14px var(--rose-glow);transform:scale(1.4)}

/* SCENE 5 - LETTER */
.letter-paper{width:min(88vw,500px);background:linear-gradient(170deg,rgba(18,12,18,.97),rgba(12,8,14,.99));border:1px solid rgba(212,165,116,.2);border-radius:20px;padding:clamp(2rem,5vw,3.5rem);position:relative;overflow:hidden;box-shadow:0 30px 100px rgba(0,0,0,.5);animation:paperIn 1s ease forwards;opacity:0;transform:translateY(40px) rotateX(5deg)}
.letter-seal{position:absolute;top:-1px;right:30px;width:40px;height:55px;background:var(--rose);clip-path:polygon(0 0,100% 0,100% 80%,50% 100%,0 80%);box-shadow:0 4px 15px var(--rose-glow)}
.letter-seal::after{content:'M';position:absolute;top:12px;left:50%;transform:translateX(-50%);font-family:'Great Vibes',cursive;font-size:1.2rem;color:var(--cream)}
.letter-body{position:relative;min-height:200px}
.letter-body p{font-size:clamp(1rem,2.8vw,1.2rem);line-height:2.2;color:var(--text)}

/* SCENE 6 - CAROUSEL */
.scene-title{font-family:'Great Vibes',cursive;font-size:clamp(2rem,6vw,3.5rem);color:var(--gold);text-shadow:0 0 30px var(--gold-glow);margin-bottom:2rem;z-index:2}
.carousel-3d{width:280px;height:340px;position:relative;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.4,0,.2,1)}
.carousel-card{position:absolute;width:260px;height:320px;backface-visibility:hidden;transform-style:preserve-3d;transition:all .8s cubic-bezier(.4,0,.2,1);border-radius:20px;overflow:hidden}
.card-inner{width:100%;height:100%;background:linear-gradient(160deg,rgba(20,12,24,.95),rgba(14,8,18,.98));border:1px solid rgba(212,165,116,.15);border-radius:20px;padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.4);position:relative;overflow:hidden}
.card-inner::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent,rgba(230,57,70,.08),transparent,rgba(212,165,116,.08),transparent);animation:cardShine 6s linear infinite}
@keyframes cardShine{to{transform:rotate(360deg)}}
.card-icon{font-size:3rem;color:var(--rose);margin-bottom:1.5rem;filter:drop-shadow(0 0 15px var(--rose-glow));animation:iconPulse 2s ease-in-out infinite;position:relative;z-index:1}
@keyframes iconPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.card-inner h3{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--gold-light);margin-bottom:1rem;position:relative;z-index:1}
.card-inner p{font-size:1.05rem;line-height:1.8;color:var(--muted);position:relative;z-index:1}
.carousel-nav{display:flex;align-items:center;gap:1.5rem;margin-top:2rem;z-index:5}
.car-btn{width:48px;height:48px;border-radius:50%;background:rgba(20,15,25,.8);border:1px solid rgba(212,165,116,.3);color:var(--gold);font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}
.car-btn:hover,.car-btn:active{background:rgba(230,57,70,.2);border-color:var(--rose);transform:scale(1.1)}
.car-dots{display:flex;gap:8px}
.car-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);transition:all .4s ease;cursor:pointer}
.car-dot.active{background:var(--rose);box-shadow:0 0 12px var(--rose-glow);transform:scale(1.3)}

/* SCENE 7 - GAME */
.game-container{width:min(92vw,420px);height:min(80vh,600px);position:relative;background:linear-gradient(170deg,rgba(15,10,20,.95),rgba(10,6,14,.98));border:1px solid rgba(212,165,116,.15);border-radius:20px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.game-header{padding:1rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;background:rgba(0,0,0,.3);border-bottom:1px solid rgba(212,165,116,.1)}
.game-title{font-family:'Dancing Script',cursive;font-size:1.5rem;color:var(--gold)}
.game-stats{display:flex;gap:2rem;font-size:1.1rem}
.game-score{color:var(--rose)}.game-time{color:var(--gold)}
#game-canvas{width:100%;height:calc(100% - 80px);display:block}
.game-overlay{position:absolute;inset:0;background:rgba(6,6,14,.92);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;gap:1rem;padding:2rem;text-align:center;backdrop-filter:blur(8px)}
.game-overlay.hidden{display:none}
.game-overlay p{font-size:1.2rem;color:var(--text);line-height:1.8}
.game-goal{color:var(--gold);font-family:'Dancing Script',cursive;font-size:1.5rem!important}
.game-btn{margin-top:1rem;padding:.8rem 2.5rem;font-family:'Cormorant Garamond',serif;font-size:1.1rem;background:linear-gradient(135deg,var(--rose),#c1121f);color:#fff;border:none;border-radius:30px;cursor:pointer;box-shadow:0 8px 30px var(--rose-glow);transition:all .3s ease;letter-spacing:1px}
.game-btn:hover,.game-btn:active{transform:scale(1.05);box-shadow:0 12px 40px var(--rose-glow)}
.game-win-heart{font-size:4rem;animation:heartBeat 1.2s ease-in-out infinite;filter:drop-shadow(0 0 20px var(--rose-glow))}
.game-win-text{font-family:'Great Vibes',cursive;font-size:clamp(1.4rem,4vw,2rem);color:var(--gold)}

/* SCENE 8 - QUIZ */
.quiz-container{width:min(88vw,450px);z-index:2;text-align:center}
.quiz-progress{width:100%;height:6px;background:rgba(255,255,255,.1);border-radius:3px;margin-bottom:2rem;overflow:hidden}
.quiz-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--rose),var(--gold));border-radius:3px;transition:width .5s ease}
.quiz-card{background:linear-gradient(170deg,rgba(18,12,18,.97),rgba(12,8,14,.99));border:1px solid rgba(212,165,116,.2);border-radius:20px;padding:2rem;box-shadow:0 20px 60px rgba(0,0,0,.4);animation:paperIn .6s ease forwards}
.quiz-question{font-size:clamp(1.2rem,3vw,1.5rem);color:var(--gold-light);margin-bottom:1.5rem;font-family:'Playfair Display',serif;font-style:italic;line-height:1.6}
.quiz-options{display:flex;flex-direction:column;gap:.8rem}
.quiz-opt{padding:1rem 1.5rem;background:rgba(255,255,255,.03);border:1px solid rgba(212,165,116,.15);border-radius:12px;color:var(--text);font-size:1.1rem;cursor:pointer;transition:all .3s ease;font-family:'Cormorant Garamond',serif}
.quiz-opt:hover,.quiz-opt:active{border-color:var(--rose);background:rgba(230,57,70,.1)}
.quiz-opt.correct{border-color:#4caf50;background:rgba(76,175,80,.15);color:#81c784}
.quiz-opt.wrong{border-color:#f44336;background:rgba(244,67,54,.1);color:#e57373}
.quiz-result{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem}
.quiz-result.hidden{display:none}
.quiz-result-icon{font-size:4rem}
.quiz-result-text{font-family:'Great Vibes',cursive;font-size:clamp(1.3rem,4vw,1.8rem);color:var(--gold);line-height:1.6}

/* SCENE 9 - ROULETTE */
.roulette-container{text-align:center;z-index:2}
.roulette-wrapper{position:relative;width:300px;height:300px;margin:0 auto 1.5rem}
.roulette-pointer{position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-size:2rem;color:var(--gold);z-index:5;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5))}
#roulette-canvas{border-radius:50%;box-shadow:0 0 40px rgba(230,57,70,.15),0 0 80px rgba(0,0,0,.3)}
.roulette-spin-btn{margin-bottom:1rem}
.roulette-result{margin-top:1rem;animation:paperIn .6s ease forwards}
.roulette-result.hidden{display:none}
.roulette-result-card{background:linear-gradient(170deg,rgba(18,12,18,.97),rgba(12,8,14,.99));border:1px solid rgba(212,165,116,.2);border-radius:16px;padding:1.5rem 2rem;max-width:350px;margin:0 auto;box-shadow:0 15px 50px rgba(0,0,0,.4)}
.roulette-result-card h3{font-family:'Dancing Script',cursive;font-size:1.4rem;color:var(--rose);margin-bottom:.8rem}
.roulette-result-card p{font-size:1.05rem;line-height:1.7;color:var(--text)}
.roulette-memory-icon{font-size:2rem;margin-top:.8rem}
.roulette-counter{color:var(--muted);font-size:.9rem;margin-top:1rem;letter-spacing:2px}
.roulette-next{margin-top:1rem}

/* SCENE 10 - PUZZLE */
.puzzle-container{text-align:center;z-index:2}
.puzzle-sub{color:var(--muted);font-size:.95rem;margin-bottom:1rem;letter-spacing:1px}
#puzzle-canvas{border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.4);cursor:pointer;max-width:min(85vw,360px);max-height:min(85vw,360px)}
.puzzle-status{margin-top:1rem;color:var(--gold);font-size:1rem}
.puzzle-win{margin-top:1.5rem;animation:paperIn .6s ease forwards}
.puzzle-win.hidden{display:none}
.puzzle-win-text{font-family:'Great Vibes',cursive;font-size:clamp(1.2rem,3.5vw,1.6rem);color:var(--gold);margin-bottom:1rem;line-height:1.6}

/* SCENE 11 - PROMISES */
.promises-container{width:min(88vw,480px);z-index:2}
.promises-list{display:flex;flex-direction:column;gap:1.2rem;margin-top:1rem}
.promise-item{display:flex;align-items:center;gap:1rem;background:linear-gradient(160deg,rgba(20,12,24,.85),rgba(14,8,18,.9));border:1px solid rgba(212,165,116,.1);border-radius:14px;padding:1.2rem 1.5rem;opacity:0;transform:translateX(-30px);transition:all .6s cubic-bezier(.175,.885,.32,1.275)}
.promise-item.visible{opacity:1;transform:translateX(0)}
.promise-check{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--rose);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;font-weight:bold;box-shadow:0 4px 15px var(--rose-glow);transform:scale(0)}
.promise-item.visible .promise-check{animation:checkPop .5s ease forwards}
@keyframes checkPop{0%{transform:scale(0) rotate(-180deg)}100%{transform:scale(1) rotate(0deg)}}
.promise-item p{font-size:clamp(1rem,2.5vw,1.15rem);line-height:1.6;color:var(--text)}

/* SCENE 12 - COUNTER */
.counter-container{text-align:center;z-index:2}
.time-counter{display:flex;align-items:center;justify-content:center;gap:clamp(.5rem,2vw,1.5rem);margin:2rem 0}
.time-block{display:flex;flex-direction:column;align-items:center;background:linear-gradient(160deg,rgba(20,12,24,.9),rgba(14,8,18,.95));border:1px solid rgba(212,165,116,.15);border-radius:16px;padding:clamp(1rem,3vw,1.8rem) clamp(.8rem,2.5vw,1.5rem);min-width:clamp(60px,15vw,90px);box-shadow:0 10px 40px rgba(0,0,0,.3)}
.time-num{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,5vw,3rem);font-weight:700;color:var(--rose);text-shadow:0 0 20px var(--rose-glow);line-height:1}
.time-label{font-size:clamp(.7rem,1.8vw,.9rem);color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-top:.5rem}
.time-sep{font-size:clamp(1.5rem,4vw,2.5rem);color:var(--gold);animation:pulse 1s ease-in-out infinite;margin-top:-1rem}
.counter-sub{font-family:'Dancing Script',cursive;font-size:clamp(1.2rem,3vw,1.6rem);color:var(--gold);animation:pulse 3s ease-in-out infinite}

/* SCENE 13 - CAKE */
.wish-title{margin-bottom:2rem;animation:pulse 3s ease-in-out infinite}
.cake-scene{position:relative;cursor:pointer;text-align:center}
.cake-glow{position:absolute;width:300px;height:300px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,200,50,.08),transparent 70%);border-radius:50%;animation:cakeGlow 3s ease-in-out infinite;pointer-events:none}
@keyframes cakeGlow{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}}
.cake3d{display:flex;flex-direction:column;align-items:center;position:relative}
.candles-row{display:flex;gap:20px;margin-bottom:-2px;z-index:3}
.candle3d{display:flex;flex-direction:column;align-items:center}
.stick{width:8px;height:45px;background:linear-gradient(90deg,#fff5cc,#ffe066,#fff5cc);border-radius:2px;position:relative}
.stick::after{content:'';position:absolute;top:-4px;left:50%;transform:translateX(-50%);width:3px;height:6px;background:#444;border-radius:0 0 1px 1px}
.flame3d{width:14px;height:22px;background:radial-gradient(ellipse at 50% 80%,#ffef9f,#ff8c00 40%,#ff4500 70%,transparent);border-radius:50% 50% 50% 50%/60% 60% 40% 40%;animation:flicker .15s ease-in-out infinite alternate;position:relative;margin-bottom:-1px;box-shadow:0 0 12px 4px rgba(255,150,0,.4),0 0 30px 8px rgba(255,100,0,.15);transition:all .5s ease}
.flame3d.out{opacity:0;transform:scaleY(0) translateY(-15px)}
.flame-core{position:absolute;width:6px;height:10px;background:radial-gradient(ellipse at bottom,#fff 20%,#ffe 50%,transparent);border-radius:50% 50% 50% 50%/60% 60% 40% 40%;bottom:3px;left:50%;transform:translateX(-50%)}
@keyframes flicker{0%{transform:scaleY(1) scaleX(1) rotate(-3deg)}100%{transform:scaleY(1.15) scaleX(.85) rotate(3deg)}}
.cake-layer{position:relative}.top-layer{width:180px;height:55px;background:linear-gradient(180deg,#e8365a,#c12040);border-radius:12px 12px 0 0;overflow:visible;z-index:2}
.frosting{position:absolute;bottom:-18px;left:-5px;right:-5px;display:flex;justify-content:space-around;z-index:3}
.frosting span{width:18px;height:22px;background:var(--rose);border-radius:0 0 50% 50%;display:block}
.frosting span:nth-child(2n){height:28px}
.mid-layer{width:210px;height:60px;background:linear-gradient(180deg,#ffc8d0,#ffaab5)}
.bot-layer{width:240px;height:70px;background:linear-gradient(180deg,var(--rose-soft),var(--rose));border-radius:0 0 14px 14px}
.cake-base{width:290px;height:16px;background:linear-gradient(180deg,#d8c8b8,#b8a898);border-radius:50%;margin-top:-4px}
.blow-hint{margin-top:1.5rem;color:var(--gold);font-size:1rem;letter-spacing:2px;animation:pulse 2s ease-in-out infinite;transition:opacity .5s ease}
.blow-hint.gone{opacity:0}
#fireworks-canvas{position:absolute;inset:0;pointer-events:none;z-index:20}

/* SCENE 14 - FINAL */
#hearts-rain{position:absolute;inset:0;z-index:0;pointer-events:none}
.final-reveal{text-align:center;position:relative;z-index:2;max-width:min(90vw,550px)}
.infinity-container{position:relative;width:160px;height:80px;margin:0 auto 2rem}
.infinity-svg{width:100%;height:100%}
.inf-path{fill:none;stroke:var(--rose);stroke-width:2.5;stroke-dasharray:500;stroke-dashoffset:500;filter:drop-shadow(0 0 8px var(--rose-glow))}
.scene.active .inf-path{animation:drawPath 3s ease forwards .5s}
@keyframes drawPath{to{stroke-dashoffset:0}}
.inf-glow{position:absolute;inset:-20px;background:radial-gradient(circle,rgba(230,57,70,.12),transparent 70%);border-radius:50%;animation:glowPulse 2s ease-in-out infinite}
@keyframes glowPulse{0%,100%{transform:scale(.9);opacity:.4}50%{transform:scale(1.2);opacity:.8}}
.poem-lines{margin-bottom:2rem}
.poem-line{font-size:clamp(1rem,3vw,1.3rem);line-height:2.2;opacity:0;transform:translateY(20px)}
.scene.active .poem-line{animation:fadeUp 1s ease forwards;animation-delay:calc(1s + var(--d)*.6s)}
.poem-line.big{font-family:'Great Vibes',cursive;font-size:clamp(1.8rem,5vw,3rem);color:var(--gold-light);font-style:normal;margin-top:1.5rem;text-shadow:0 0 20px var(--gold-glow)}
.poem-line.golden{color:var(--rose-soft);font-size:clamp(1.1rem,3vw,1.4rem);margin-top:.5rem}
.heart-mega{font-size:clamp(3rem,8vw,5rem);color:var(--rose);animation:heartBeat 1.2s ease-in-out infinite;filter:drop-shadow(0 0 30px var(--rose-glow));margin:1rem 0}
@keyframes heartBeat{0%,100%{transform:scale(1)}14%{transform:scale(1.3)}28%{transform:scale(1)}42%{transform:scale(1.2)}56%{transform:scale(1)}}
.signature-final{font-family:'Great Vibes',cursive;font-size:clamp(1.5rem,4vw,2.2rem);color:var(--gold);opacity:0}
.scene.active .signature-final{animation:fadeUp 1s ease forwards 5s}

/* MUSIC */
.music-float{position:fixed;bottom:1.5rem;right:1.5rem;width:50px;height:50px;border-radius:50%;background:rgba(12,8,16,.9);border:1px solid rgba(212,165,116,.25);color:var(--gold);cursor:pointer;z-index:100;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);transition:all .3s ease}
.music-float:hover{border-color:var(--gold);transform:scale(1.1)}
.music-float svg{width:20px;height:20px}
.eq-bars{position:absolute;bottom:-6px;display:flex;gap:2px;opacity:0;transition:opacity .3s ease}
.eq-bars.on{opacity:1}
.eq-bars span{width:3px;height:6px;background:var(--gold);border-radius:1px;animation:eqBar .6s ease-in-out infinite}
.eq-bars span:nth-child(2){animation-delay:.15s}.eq-bars span:nth-child(3){animation-delay:.3s}
@keyframes eqBar{0%,100%{height:4px}50%{height:12px}}

/* NAV */
.nav-hint{color:var(--muted);font-size:.8rem;letter-spacing:3px;text-transform:uppercase;animation:pulse 3s ease-in-out infinite}
.bottom-hint{position:absolute;bottom:0;left:0;right:0;text-align:center;padding:clamp(1.2rem,3vh,2.5rem) 1rem;z-index:20}

/* RESPONSIVE */

/* Touch targets - bigger hit areas for dots */
.p-dot{width:10px;height:10px;padding:0;position:relative}
.p-dot::before{content:'';position:absolute;inset:-15px;border-radius:50%}
.car-dot{width:8px;height:8px;position:relative}
.car-dot::before{content:'';position:absolute;inset:-18px;border-radius:50%}

/* Tablets */
@media(max-width:768px){
    .mega-name .char{font-size:clamp(4.5rem,16vw,10rem)}
    .scene-title{font-size:clamp(1.8rem,5.5vw,3rem)}
    .carousel-3d{width:260px;height:320px}
    .carousel-card{width:240px;height:300px}
    .card-inner{padding:2rem 1.5rem}
    .card-inner h3{font-size:1.3rem}
    .roulette-wrapper{width:min(280px,75vw);height:min(280px,75vw)}
    #roulette-canvas{width:100%!important;height:100%!important}
    .game-container{width:min(95vw,420px);height:min(78vh,560px)}
    .quiz-opt{padding:.9rem 1.2rem;font-size:1.05rem;min-height:48px;display:flex;align-items:center;justify-content:center}
    .photo-gallery{width:min(85vw,380px);height:min(65vh,450px)}
    .journey-map{height:200px}
    .heart-mega{font-size:clamp(2.5rem,7vw,4rem)}
}

/* Mobile */
@media(max-width:480px){
    .envelope-wrapper{width:min(210px,70vw);height:min(150px,50vw)}
    .env-letter p{font-size:1.4rem}
    .mega-name .char{font-size:clamp(3.5rem,14vw,6rem)}
    .pre-text{font-size:clamp(1.1rem,3.5vw,1.8rem)}
    .scene-title{font-size:clamp(1.5rem,5vw,2.2rem)}
    .story-container,.letter-paper,.quiz-container,.promises-container{width:92vw;padding:1.5rem 1.2rem}
    .story-icon{width:50px;height:50px}
    .linkedin-icon{width:26px;height:26px}
    .story-title{font-size:clamp(1.3rem,4vw,1.8rem)}
    .journey-container{width:94vw}
    .journey-map{height:180px}
    .j-label span{font-size:.85rem}
    .j-pin{font-size:1.4rem}
    .journey-km{font-size:.95rem}
    .j-text{font-size:clamp(.9rem,2.8vw,1.1rem)}
    .photo-gallery{width:88vw;height:55vh}
    .carousel-3d{width:min(240px,80vw);height:min(300px,55vh)}
    .carousel-card{width:min(220px,75vw);height:min(280px,52vh)}
    .card-inner{padding:1.5rem 1rem}
    .card-icon{font-size:2.2rem;margin-bottom:1rem}
    .card-inner h3{font-size:1.2rem}
    .card-inner p{font-size:.95rem}
    .car-btn{width:44px;height:44px;font-size:1rem}
    .game-container{width:96vw;height:82vh}
    .game-header{padding:.8rem 1rem}
    .game-title{font-size:1.2rem}
    .game-stats{font-size:1rem;gap:1.5rem}
    .game-btn{padding:.7rem 2rem;font-size:1rem}
    .game-win-text{font-size:clamp(1.1rem,3.5vw,1.5rem)}
    .quiz-question{font-size:clamp(1.05rem,3vw,1.3rem)}
    .quiz-opt{padding:.85rem 1rem;font-size:1rem;min-height:48px;display:flex;align-items:center;justify-content:center}
    .quiz-result-text{font-size:clamp(1.1rem,3.5vw,1.5rem)}
    .quiz-result-icon{font-size:3rem}
    .roulette-wrapper{width:min(250px,70vw);height:min(250px,70vw)}
    #roulette-canvas{width:100%!important;height:100%!important}
    .roulette-result-card{padding:1.2rem 1rem}
    .roulette-result-card h3{font-size:1.2rem}
    .roulette-result-card p{font-size:.95rem}
    .roulette-counter{font-size:.8rem}
    #puzzle-canvas{max-width:min(82vw,300px);max-height:min(82vw,300px)}
    .puzzle-sub{font-size:.85rem}
    .puzzle-win-text{font-size:clamp(1rem,3vw,1.3rem)}
    .promise-item{padding:1rem 1.2rem;gap:.8rem}
    .promise-check{width:32px;height:32px;font-size:.95rem}
    .promise-item p{font-size:clamp(.9rem,2.5vw,1.05rem)}
    .time-block{padding:.8rem .6rem;min-width:clamp(52px,14vw,75px)}
    .time-num{font-size:clamp(1.5rem,4.5vw,2.5rem)}
    .time-label{font-size:clamp(.6rem,1.6vw,.8rem)}
    .time-sep{font-size:clamp(1.2rem,3vw,2rem)}
    .counter-sub{font-size:clamp(1rem,3vw,1.3rem)}
    .top-layer{width:min(140px,42vw);height:45px}
    .mid-layer{width:min(165px,50vw);height:50px}
    .bot-layer{width:min(190px,56vw);height:58px}
    .cake-base{width:min(230px,66vw)}
    .candles-row{gap:clamp(8px,3vw,15px)}
    .blow-hint{font-size:.9rem}
    .poem-line{font-size:clamp(.9rem,2.8vw,1.15rem)}
    .poem-line.big{font-size:clamp(1.5rem,4.5vw,2.5rem)}
    .poem-line.golden{font-size:clamp(.95rem,2.8vw,1.2rem)}
    .heart-mega{font-size:clamp(2.5rem,7vw,4rem)}
    .signature-final{font-size:clamp(1.2rem,3.5vw,1.8rem)}
    .infinity-container{width:120px;height:60px}
    .nav-hint{font-size:.7rem;letter-spacing:2px}
    .bottom-hint{bottom:clamp(1rem,3vh,2rem)}
    .music-float{width:44px;height:44px;bottom:1rem;right:1rem}
}

/* Very small screens */
@media(max-width:350px){
    .mega-name .char{font-size:clamp(2.8rem,13vw,4rem)}
    .envelope-wrapper{width:180px;height:130px}
    .env-letter p{font-size:1.2rem}
    .carousel-3d{width:200px;height:260px}
    .carousel-card{width:185px;height:245px}
    .card-inner{padding:1.2rem .8rem}
    .card-icon{font-size:1.8rem}
    .card-inner h3{font-size:1.05rem}
    .card-inner p{font-size:.85rem}
    .game-container{width:98vw;height:85vh}
    .story-container,.letter-paper,.quiz-container,.promises-container{width:96vw;padding:1.2rem 1rem}
    .photo-gallery{width:92vw;height:50vh}
    .roulette-wrapper{width:65vw;height:65vw}
    .time-block{min-width:48px;padding:.7rem .5rem}
}
