@import"https://fonts.googleapis.com/css2?family=Dancing+Script:wght@600;700&family=Poppins:wght@400;600;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;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{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.love-root{--bg1: #ff6a6a;--bg2: #ff3d7f;--bg3: #ff7a3d;background:linear-gradient(120deg,var(--bg1),var(--bg2),var(--bg3));background-size:200% 200%;animation:bgShift 14s ease infinite;display:flex;justify-content:center;align-items:center;height:auto;margin:0;font-family:Poppins,Arial,sans-serif;color:#fff;text-align:center;padding:18px;overflow:hidden;position:relative}.message-container{background:#ffffff2e;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:40px 32px;border-radius:18px;box-shadow:0 10px 28px #00000040;animation:fadeIn .9s ease;position:relative;overflow:hidden;max-width:820px}.heart{font-size:clamp(56px,8vw,96px);color:#de5816;animation:pulse 1.5s infinite;cursor:pointer}.message-title{font-size:clamp(34px,6vw,64px);margin-top:10px;font-family:Dancing Script,cursive;letter-spacing:.5px}.message-text{font-size:clamp(16px,2.6vw,24px)}.typewriter{font-weight:600;margin-top:8px;min-height:1.6em;position:relative}.typewriter:after{content:"";display:inline-block;width:2px;height:1em;background:#fff;margin-left:4px;animation:caret 1s step-start infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes caret{50%{opacity:0}}@keyframes bgShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.controls{margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn{background:#fffc;color:#b02020;border:none;border-radius:999px;padding:10px 16px;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px #00000026}.btn:active{transform:translateY(0);box-shadow:0 2px 6px #0000001f}.photo-wrap{margin-top:22px;display:inline-block;background:#fff;color:#333;padding:10px 10px 18px;border-radius:10px;transform:rotate(-2deg);box-shadow:0 6px 18px #00000040;opacity:0;pointer-events:none;transition:opacity .4s ease,transform .4s ease}.photo-wrap.visible{opacity:1;pointer-events:auto;transform:rotate(0)}.photo{width:min(70vw,360px);height:auto;border-radius:8px;display:block;-webkit-user-select:none;user-select:none}.caption{margin-top:8px;font-weight:700}.gallery{margin-top:16px;position:relative}.thumbs{display:flex;gap:10px;overflow-x:auto;padding:8px 6px;scroll-snap-type:x mandatory}.thumbs::-webkit-scrollbar{height:8px}.thumbs::-webkit-scrollbar-thumb{background:#fff5;border-radius:999px}.thumb{flex:0 0 auto;width:96px;height:72px;border-radius:8px;scroll-snap-align:start;object-fit:cover;box-shadow:0 4px 12px #00000040;cursor:pointer;opacity:.85;transition:transform .15s ease,opacity .15s ease,box-shadow .15s ease}.thumb:hover{transform:translateY(-2px);opacity:1;box-shadow:0 6px 16px #0000004d}.thumb.selected{outline:3px solid #ffc2c2;opacity:1}.gallery-btn{position:absolute;top:50%;transform:translateY(-50%);background:#fffb;color:#b02020;border:none;border-radius:999px;width:34px;height:34px;display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 14px #00000040}.gallery-btn.prev{left:6px}.gallery-btn.next{right:6px}.heart-field{position:absolute;inset:0;pointer-events:none}.floating-heart{position:absolute;bottom:8px;font-size:var(--size, 22px);left:var(--left, 50%);will-change:transform,opacity;animation:floatUp var(--duration, 1.6s) linear forwards;animation-delay:var(--delay, 0ms)}@keyframes floatUp{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(calc(-1 * var(--rise, 72vh))) scale(1.6);opacity:0}}.stats{margin-top:10px;opacity:.9;font-weight:600}.backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:20;animation:fadeIn .2s ease}.modal{width:min(92vw,720px);background:#fff;color:#5a2a2a;border-radius:16px;box-shadow:0 14px 34px #00000059;padding:22px 20px}.modal h2{margin:0 0 10px;font-family:Dancing Script,cursive;color:#c02b2b;font-size:2.2rem}.modal .body{line-height:1.55;font-size:1.06rem}.modal .row{margin-top:14px;display:flex;gap:10px;justify-content:flex-end}.modal .close{background:#c02b2b;color:#fff}.photo-spray{position:absolute;inset:0;pointer-events:none}.spray-photo{position:absolute;left:var(--x);top:var(--y);width:var(--size, 160px);height:auto;border-radius:10px;box-shadow:0 8px 20px #00000059;transform:translate(var(--fromX),var(--fromY)) rotate(var(--fromR, -8deg));will-change:transform,opacity;animation:sprayIn var(--duration, .9s) ease-out forwards;animation-delay:var(--delay, 0ms)}@keyframes sprayIn{0%{opacity:0;transform:translate(var(--fromX),var(--fromY)) rotate(var(--fromR))}to{opacity:1;transform:translate(0) rotate(0)}}@media(max-width:480px){.message-container{padding:28px 20px}.photo{width:min(86vw,360px)}}@media(min-width:1024px){.photo{width:min(52vw,420px)}}
