@import"https://fonts.googleapis.com/css2?family=Great+Vibes&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Cinzel:wght@400;500;700&family=Tangerine:wght@400;700&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--gold: #c9a84c;--gold-light: #e8d5a3;--gold-dark: #8b6914;--cream: #f5f0e1;--blush: #d4a0a0;--deep: #0d0b1a;--royal: #2d1b4e;--rose: #c77d8a;--bridgerton-blue: #7ba7c9;--glass-bg: rgba(13, 11, 26, .75);--glass-border: rgba(201, 168, 76, .2)}html,body{width:100%;height:100%;overflow:hidden;background:var(--deep);color:var(--cream);font-family:Cormorant Garamond,serif;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}canvas#game{display:block;width:100%;height:100%;position:fixed;top:0;left:0;z-index:1}.overlay{position:fixed;inset:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;transition:opacity .8s ease,visibility .8s ease;pointer-events:auto}.overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}#title-screen{background:radial-gradient(ellipse at 50% 40%,rgba(45,27,78,.6),transparent 70%),radial-gradient(ellipse at 50% 100%,rgba(201,168,76,.08),transparent 50%),var(--deep)}.title-ornament{font-size:1.5rem;color:var(--gold);letter-spacing:.8em;opacity:0;animation:fadeUp 1.2s ease forwards .3s}.title-main{font-family:Great Vibes,cursive;font-size:clamp(2.8rem,12vw,6rem);color:var(--gold);text-shadow:0 0 60px rgba(201,168,76,.3),0 0 120px rgba(201,168,76,.1);opacity:0;animation:fadeUp 1.2s ease forwards .6s;line-height:1.1}.title-sub{font-family:Cormorant Garamond,serif;font-size:clamp(.9rem,3.5vw,1.4rem);font-style:italic;font-weight:300;color:var(--gold-light);margin-top:.8rem;opacity:0;animation:fadeUp 1.2s ease forwards 1s}.title-tap{margin-top:3rem;font-size:.8rem;letter-spacing:.4em;text-transform:uppercase;color:var(--blush);opacity:0;animation:fadeUp 1.2s ease forwards 1.6s}.title-tap .pulse{display:inline-block;animation:pulse 2s ease-in-out infinite}.title-date{position:absolute;bottom:2rem;font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:#c9a84c66;opacity:0;animation:fadeUp 1.2s ease forwards 2s}#narrative-screen{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.narr-frame{max-width:420px;width:100%;border:1px solid var(--glass-border);padding:2rem 1.8rem;position:relative;background:linear-gradient(135deg,#2d1b4e33,#0d0b1a80);border-radius:4px;box-shadow:0 8px 32px #0000004d,inset 0 0 60px #c9a84c05}.narr-frame:before,.narr-frame:after{content:"❧";position:absolute;font-size:1.5rem;color:var(--gold);opacity:.35}.narr-frame:before{top:.4rem;left:.8rem}.narr-frame:after{bottom:.4rem;right:.8rem;transform:rotate(180deg)}.narr-header{font-family:Playfair Display,serif;font-size:.8rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);padding-bottom:1rem;margin-bottom:1.2rem;border-bottom:1px solid rgba(201,168,76,.15);text-align:center}.narr-body{font-family:EB Garamond,Cormorant Garamond,serif;font-size:clamp(1.05rem,3.8vw,1.25rem);line-height:2;font-style:italic;color:var(--cream);min-height:100px}.narr-body .cursor{display:inline-block;width:2px;height:1em;background:var(--gold);animation:blink 1s step-end infinite;vertical-align:text-bottom}.narr-signature{text-align:right;margin-top:1.5rem;font-family:Tangerine,Great Vibes,cursive;font-size:1.6rem;color:var(--gold)}.narr-tap{margin-top:1.5rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--blush);opacity:0;transition:opacity .5s ease}.narr-loading{color:var(--gold-light);font-style:italic;font-size:.95rem}.narr-loading .dots:after{content:"";animation:dots 1.5s steps(3) infinite}#hud{position:fixed;top:0;left:0;right:0;z-index:5;padding:.8rem 1.2rem;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(180deg,rgba(13,11,26,.7),transparent);pointer-events:none;transition:opacity .5s}#hud.hidden{opacity:0}.hud-chapter{font-family:Cinzel,Playfair Display,serif;font-size:.65rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--gold)}.hud-right{display:flex;gap:.6rem;align-items:center;pointer-events:auto}.hud-mute{background:none;border:none;font-size:.9rem;cursor:pointer;opacity:.45;transition:opacity .3s;padding:.2rem;line-height:1}.hud-mute:active{opacity:.8}.hud-mute.muted{opacity:.25}.hud-lives{font-size:.85rem;transition:transform .3s ease}.hud-lives.hit{animation:hudShake .5s ease}@keyframes hudShake{0%,to{transform:translate(0)}20%{transform:translate(-4px) scale(1.2)}40%{transform:translate(4px)}60%{transform:translate(-2px)}}.hud-hearts{font-family:Cormorant Garamond,serif;font-size:.9rem;color:var(--gold-light)}#celebration{background:#0d0b1af2;backdrop-filter:blur(8px)}.celeb-title{font-family:Great Vibes,cursive;font-size:clamp(2.5rem,10vw,5rem);color:var(--gold);text-shadow:0 0 80px rgba(201,168,76,.4);animation:celebPulse 2s ease-in-out infinite}.celeb-sub{font-size:1.2rem;color:var(--gold-light);font-style:italic;margin-top:.8rem;max-width:350px;line-height:1.8}.celeb-emoji{font-size:3rem;margin-top:1.5rem;animation:celebPulse 1.5s ease-in-out infinite}.falling-heart{position:fixed;top:-60px;font-size:1.5rem;animation:fall linear forwards;opacity:.8;pointer-events:none;z-index:15}#config-screen{background:var(--deep)}.config-box{max-width:400px;width:100%;padding:2.5rem 2rem;border:1px solid var(--glass-border);text-align:center;background:linear-gradient(135deg,#2d1b4e1a,#0d0b1a4d);border-radius:6px;box-shadow:0 8px 32px #0000004d}.config-box h2{font-family:Great Vibes,cursive;font-size:2rem;color:var(--gold);margin-bottom:1rem}.config-box p{font-size:.9rem;color:var(--gold-light);font-style:italic;margin-bottom:1.5rem;line-height:1.6}.config-box input{width:100%;padding:.8rem 1rem;background:#f5f0e10d;border:1px solid rgba(201,168,76,.3);color:var(--cream);font-family:Cormorant Garamond,serif;font-size:.95rem;outline:none;margin-bottom:.8rem;text-align:center;border-radius:4px;transition:border-color .3s,box-shadow .3s}.config-box input::placeholder{color:#f5f0e14d;font-style:italic}.config-box input:focus{border-color:var(--gold);box-shadow:0 0 20px #c9a84c1a}.config-btn{display:inline-block;padding:.8rem 2rem;background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:var(--deep);border:none;cursor:pointer;font-family:Cormorant Garamond,serif;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;margin:.3rem;border-radius:4px;transition:transform .3s,box-shadow .3s}.config-btn:hover{box-shadow:0 4px 20px #c9a84c4d}.config-btn:active{transform:scale(.95)}.config-btn.secondary{background:transparent;color:var(--gold-light);border:1px solid rgba(201,168,76,.3)}.config-btn.secondary:hover{border-color:var(--gold)}.config-note{font-size:.7rem;color:#c9a84c66;margin-top:1rem;line-height:1.5}.config-label{display:block;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem;margin-top:.8rem;text-align:left;opacity:.7}@keyframes fadeUp{0%{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes dots{0%{content:""}33%{content:"."}66%{content:".."}to{content:"..."}}@keyframes celebPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes fall{to{transform:translateY(110vh) rotate(720deg);opacity:0}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}#intro-screen{background:radial-gradient(ellipse at 50% 30%,rgba(45,27,78,.5),transparent 70%),var(--deep);z-index:20}.intro-container{max-width:420px;width:100%;padding:2rem;text-align:center}.intro-wax-seal{width:60px;height:60px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#c94040,#8b2020);color:var(--cream);font-family:Great Vibes,cursive;font-size:1.8rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;box-shadow:0 4px 20px #b428284d,inset 0 -2px 6px #0000004d;animation:fadeUp 1s ease forwards}.intro-line{margin-bottom:.8rem;line-height:1.8;opacity:1}.intro-signature{font-family:Great Vibes,cursive;font-size:clamp(1.8rem,6vw,2.5rem);color:var(--gold);text-shadow:0 0 40px rgba(201,168,76,.3)}.intro-narr{font-family:Cormorant Garamond,serif;font-size:clamp(.9rem,3.2vw,1.1rem);font-style:italic;color:var(--cream)}.intro-challenge{font-family:Cormorant Garamond,serif;font-size:1rem;color:var(--gold-light);font-weight:600}.intro-challenge.hidden{display:none}.challenge-phrase{font-family:Great Vibes,cursive;font-size:clamp(2rem,8vw,3.5rem);color:var(--gold);margin:1.5rem 0 1rem;text-shadow:0 0 30px rgba(201,168,76,.25);transition:all .5s ease}.challenge-phrase.challenge-solved{color:var(--rose);text-shadow:0 0 40px rgba(199,125,138,.4),0 0 80px rgba(201,168,76,.2);transform:scale(1.1)}.challenge-input-wrap{display:flex;gap:.5rem;max-width:280px;margin:0 auto}.challenge-input-wrap input{flex:1;padding:.7rem 1rem;background:#f5f0e10f;border:1px solid rgba(201,168,76,.3);color:var(--cream);font-family:Cormorant Garamond,serif;font-size:1rem;text-align:center;outline:none;border-radius:4px;transition:border-color .3s}.challenge-input-wrap input:focus{border-color:var(--gold);box-shadow:0 0 15px #c9a84c1a}.challenge-btn{padding:.5rem 1rem;background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:var(--deep);border:none;border-radius:4px;font-size:1.2rem;cursor:pointer;transition:transform .2s}.challenge-btn:active{transform:scale(.9)}.challenge-feedback{margin-top:.8rem;font-size:.85rem;font-style:italic;line-height:1.6;min-height:2.5em;transition:all .3s}.challenge-feedback.wrong{color:var(--blush)}.challenge-feedback.success{color:var(--gold)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.shake{animation:shake .4s ease}.celeb-meeting{display:flex;align-items:center;justify-content:center;gap:0;width:100%;max-width:400px;position:relative;height:200px}.celeb-silhouette{width:80px;height:160px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;transition:transform 2s cubic-bezier(.25,.46,.45,.94);opacity:0}.celeb-silhouette.left{transform:translate(-120px)}.celeb-silhouette.right{transform:translate(120px)}.celeb-silhouette.left.enter,.celeb-silhouette.right.enter{transform:translate(0);opacity:1}.celeb-char-name{font-family:Cormorant Garamond,serif;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-light);margin-top:.5rem;white-space:nowrap}.celeb-heart-center{position:absolute;left:50%;top:40%;transform:translate(-50%,-50%) scale(0);transition:transform .8s cubic-bezier(.34,1.56,.64,1);z-index:2}.celeb-heart-center.active{transform:translate(-50%,-50%) scale(1)}.celeb-heart-icon{font-size:3rem;color:var(--rose);text-shadow:0 0 40px rgba(199,125,138,.6),0 0 80px rgba(199,125,138,.3);animation:celebPulse 1.5s ease-in-out infinite}#celeb-fireworks{position:fixed;inset:0;pointer-events:none;z-index:12}.firework-spark{position:absolute;width:6px;height:6px;border-radius:50%;animation:fireworkBurst 1.2s ease-out forwards}@keyframes fireworkBurst{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(0);opacity:0}}.celeb-final{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;animation:fadeUp 1.5s ease forwards;z-index:3}.celeb-final-emoji{font-size:3rem;animation:celebPulse 1.5s ease-in-out infinite}.celeb-credit{position:absolute;bottom:1.5rem;font-size:.7rem;color:#c9a84c59;letter-spacing:.2em}#meeting-overlay{background:radial-gradient(ellipse at 50% 40%,rgba(199,125,138,.15),transparent 60%),var(--deep);z-index:15}.meeting-container{text-align:center;animation:fadeUp 1.5s ease forwards}.meeting-emoji{font-size:clamp(4rem,12vw,6rem);animation:celebPulse 1.5s ease-in-out infinite;margin-bottom:1rem}.meeting-title{font-family:Great Vibes,cursive;font-size:clamp(1.8rem,7vw,2.8rem);color:var(--gold);text-shadow:0 0 40px rgba(201,168,76,.3);margin-bottom:.5rem}.meeting-sub{font-family:EB Garamond,Cormorant Garamond,serif;font-size:clamp(.9rem,3.5vw,1.1rem);font-style:italic;color:var(--cream);max-width:320px;line-height:1.8;margin-bottom:1.5rem}.meeting-tap{font-family:Playfair Display,serif;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);opacity:.5;animation:pulse 2s ease-in-out infinite}@media(max-height:500px)and (orientation:landscape){.narr-frame{max-width:600px;padding:1rem 1.5rem}.narr-body{min-height:60px;font-size:.9rem;line-height:1.6}.config-box{max-width:500px;padding:1.5rem}.intro-container{padding:1rem}.celeb-meeting{height:120px}}
