:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-color:#2d1b14;--text-color:#f8e3d0;--accent-color:#e27d60;--secondary-accent:#e8a87c;--bubble-me:#e27d6040;--bubble-her:#e8a87c40;--bubble-text-me:#fff;--bubble-text-her:#fff;--surface-color:#442b20;--border-color:#ffeddb26;--muted-text:#c39ea0;--shadow-color:#0000004d;font-family:Inter,system-ui,sans-serif}body,html{background-color:var(--bg-color);width:100%;height:100%;color:var(--text-color);margin:0;padding:0;overflow:hidden}#root{text-align:left;width:100%;max-width:none;height:100%;margin:0;padding:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.landing-screen{background:radial-gradient(circle,#5a3628 0%,#2d1b14 100%);flex-direction:column;justify-content:center;align-items:center;height:100vh;animation:1.5s ease-out fadeIn;display:flex}.title{background:linear-gradient(45deg, var(--accent-color), var(--secondary-accent));-webkit-text-fill-color:transparent;text-shadow:0 0 28px #f7b7d240;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:4rem;font-weight:700}.subtitle{color:var(--muted-text);opacity:.9;margin-bottom:3rem;font-size:1.5rem}.enter-btn{background:var(--accent-color);color:var(--accent-deep);cursor:pointer;border:none;border-radius:50px;padding:1rem 3rem;font-size:1.2rem;transition:all .3s;animation:2s infinite pulse;box-shadow:0 0 22px #f7b7d259}.enter-btn:hover{transform:scale(1.08);box-shadow:0 0 40px #f7b7d28c}.chat-screen{background:var(--surface-color);flex-direction:column;width:100%;max-width:800px;height:100vh;margin:0 auto;display:flex;position:relative}.chat-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:10;background:#2d1b14d9;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.chat-header h2{color:var(--accent-color);margin:0;font-size:1.5rem}.next-btn{color:var(--accent-color);background:0 0;border:1px solid #f7b7d2b3;border-radius:20px;padding:.5rem 1.5rem;transition:all .3s}.next-btn:hover{background:var(--accent-color);color:#fff}.chat-container{scroll-behavior:smooth;flex-direction:column;flex:1;padding:2rem;display:flex;overflow-y:auto}.message-row{opacity:0;width:100%;margin-bottom:1rem;transition:opacity .6s ease-out,transform .6s ease-out;display:flex;transform:translateY(20px)}.message-row.visible{opacity:1;transform:translateY(0)}.message-row.me{justify-content:flex-end}.message-row.her{justify-content:flex-start}.message-bubble{-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-color);max-width:70%;box-shadow:0 10px 20px var(--shadow-color);border-radius:18px;padding:1rem 1.5rem;font-size:1rem;line-height:1.4;position:relative}.message-row.me .message-bubble{background:var(--bubble-me);color:var(--bubble-text-me);border-bottom-right-radius:6px}.message-row.her .message-bubble{background:var(--bubble-her);color:var(--bubble-text-her);border-bottom-left-radius:6px}.message-time{color:var(--muted-text);opacity:.85;text-align:right;margin-top:.5rem;font-size:.75rem}.message-row.her .message-time{text-align:left}.proposal-screen{text-align:center;background:radial-gradient(circle,#5a3628 0%,#2d1b14 100%);flex-direction:column;justify-content:center;align-items:center;height:100vh;animation:2s ease-in fadeIn;display:flex}.proposal-screen h1{background:linear-gradient(to right, var(--accent-color), var(--secondary-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4rem;font-size:4rem;line-height:1.2}.proposal-buttons{gap:2rem;display:flex;position:relative}.yes-btn{color:#0f2a1a;cursor:pointer;background:#7fd6a2;border:none;border-radius:15px;padding:1.5rem 4rem;font-size:2rem;transition:transform .2s;box-shadow:0 0 28px #7fd6a240}.yes-btn:hover{transform:scale(1.08)}.no-btn{color:#3a0f0f;cursor:pointer;background:#f1a3a3;border:none;border-radius:15px;padding:1.5rem 4rem;font-size:2rem;transition:all .2s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff0f}::-webkit-scrollbar-thumb{background:#ffffff29;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff3d}.celebration-screen{background:var(--bg-color);flex-direction:column;justify-content:flex-start;align-items:center;min-height:100vh;padding:2rem;display:flex;overflow-y:auto}.celebration-title{background:linear-gradient(45deg, var(--accent-color), var(--secondary-accent));-webkit-text-fill-color:transparent;text-align:center;-webkit-background-clip:text;background-clip:text;margin-bottom:2rem;font-size:3rem;animation:1s infinite pulse}.gif-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;width:100%;max-width:350px;padding:0 .5rem;display:grid}.celebration-gif{object-fit:cover;border-radius:8px;width:100%;max-height:140px;animation:.5s ease-out fadeIn;box-shadow:0 2px 8px #0003}.intro-screen{background:var(--bg-color);flex-direction:column;justify-content:center;align-items:center;height:100vh;animation:3s ease-in-out forwards fadeOut;display:flex}.intro-text{color:var(--text-color);opacity:0;text-align:center;max-width:80%;margin:0 2rem;font-size:3rem;font-weight:300;line-height:1.4;animation:1s ease-in forwards textFadeIn}@keyframes textFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}80%{opacity:1}to{opacity:0}}.outro-subtitle{color:var(--accent-color);opacity:0;margin-top:1rem;font-size:2rem;font-weight:300;animation:1s ease-in 1s forwards textFadeIn}.feeling-screen{background:var(--bg-color);flex-direction:column;justify-content:center;align-items:center;height:100vh;animation:4s ease-in-out forwards fadeOut4s;display:flex}@keyframes fadeOut4s{0%{opacity:1}75%{opacity:1}to{opacity:0}}
