.word-formation{min-height:100vh;width:100%;position:relative;background:var(--color-bg);overflow:hidden}.background-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(139,21,56,.2) 0%,transparent 60%),radial-gradient(circle at 20% 80%,rgba(212,113,143,.15) 0%,transparent 40%),radial-gradient(circle at 80% 20%,rgba(212,113,143,.15) 0%,transparent 40%);pointer-events:none;animation:pulse 8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.header{position:absolute;top:0;left:0;right:0;padding:1.5rem 2rem;display:flex;align-items:center;gap:1.5rem;z-index:10;background:linear-gradient(180deg,rgba(26,10,15,.9) 0%,transparent 100%)}.back-button{font-size:.9rem;font-weight:300;letter-spacing:.05em;color:var(--color-text-muted);transition:color .3s ease;padding:.5rem 1rem;border-radius:8px;border:1px solid transparent}.back-button:hover{color:var(--color-text);border-color:#d4718f4d;background:#8b15381a}.mode-title{font-family:var(--font-display);font-size:1.5rem;font-weight:300;font-style:italic;color:var(--color-accent)}.instructions{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:5;font-size:1rem;font-weight:300;letter-spacing:.05em;color:var(--color-text-muted);pointer-events:none}.progress-dots{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.dot{width:8px;height:8px;border-radius:50%;background:#d4718f4d;transition:all .3s ease}.dot.active{background:var(--color-secondary);box-shadow:0 0 12px var(--color-secondary)}.hearts-canvas{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.floating-heart{position:absolute;color:var(--color-primary);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .3s ease;filter:drop-shadow(0 2px 8px rgba(139,21,56,.4));will-change:transform}.floating-heart:hover{color:var(--color-primary-light);filter:drop-shadow(0 4px 16px rgba(139,21,56,.6))}.floating-heart.clicked{color:var(--color-secondary);cursor:default;filter:drop-shadow(0 0 20px var(--color-secondary))}.celebration-heart{position:fixed;font-size:2rem;color:var(--color-accent);pointer-events:none;filter:drop-shadow(0 0 12px var(--color-accent));z-index:100}.message-reveal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:20;padding:2rem;max-width:90%}.revealed-message{font-family:var(--font-display);font-size:clamp(2rem,8vw,4.5rem);font-weight:300;font-style:italic;letter-spacing:.05em;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:2rem;text-shadow:0 0 40px rgba(255,214,224,.3)}.message-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.reset-button{padding:.75rem 1.5rem;background:#8b153833;border:1px solid rgba(212,113,143,.4);border-radius:12px;font-size:.9rem;font-weight:300;letter-spacing:.05em;color:var(--color-text);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.reset-button:hover{background:#8b15384d;border-color:var(--color-secondary);transform:translateY(-2px);box-shadow:0 4px 16px #8b15384d}.message-selector{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;max-width:90%;z-index:10}.message-option{padding:.5rem 1rem;background:#1a0a0fcc;border:1px solid rgba(212,113,143,.2);border-radius:8px;font-size:.75rem;font-weight:300;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.message-option:hover{border-color:#d4718f66;color:var(--color-text)}.message-option.active{background:#8b15384d;border-color:var(--color-secondary);color:var(--color-accent)}@media (max-width: 768px){.header{padding:1rem 1.5rem}.mode-title{font-size:1.25rem}.instructions{font-size:.9rem;padding:0 1rem}.message-selector{bottom:1.5rem;gap:.4rem}.message-option{font-size:.7rem;padding:.4rem .8rem}}@media (max-width: 480px){.floating-heart{font-size:.8em}.revealed-message{padding:0 1rem}.message-actions{flex-direction:column}}.shape-formation{min-height:100vh;width:100%;position:relative;background:var(--color-bg);overflow:hidden}.progress-bar{width:200px;height:4px;background:#d4718f33;border-radius:2px;margin:1rem auto .5rem;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-secondary) 100%);transition:width .3s ease;box-shadow:0 0 12px var(--color-secondary)}.progress-text{font-size:.85rem;color:var(--color-text-muted);font-weight:300}.formation-complete{position:absolute;top:0;right:0;bottom:0;left:0;background:#1a0a0ff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;z-index:30}.complete-content{text-align:center;padding:2rem;max-width:90%}.complete-title{font-family:var(--font-display);font-size:clamp(2.5rem,10vw,5rem);font-weight:300;font-style:italic;letter-spacing:.05em;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;filter:drop-shadow(0 0 40px rgba(255,214,224,.3))}.complete-subtitle{font-size:1.1rem;font-weight:300;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:2rem}.complete-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.shape-controls{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:1rem;align-items:center;max-width:90%;z-index:10}.shape-buttons{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.shape-option{padding:.75rem 1.5rem;background:#1a0a0fcc;border:1px solid rgba(212,113,143,.3);border-radius:12px;font-size:.9rem;font-weight:300;letter-spacing:.05em;color:var(--color-text-muted);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.shape-option:hover{border-color:#d4718f80;color:var(--color-text);transform:translateY(-2px)}.shape-option.active{background:#8b15384d;border-color:var(--color-secondary);color:var(--color-accent);box-shadow:0 4px 16px #8b15384d}.initials-input-group{overflow:hidden}.initials-input{padding:.75rem 1.5rem;background:#1a0a0fcc;border:1px solid rgba(212,113,143,.3);border-radius:12px;font-family:var(--font-display);font-size:1.25rem;font-weight:300;letter-spacing:.1em;color:var(--color-text);text-align:center;width:200px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.initials-input:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 4px 16px #8b15384d}.initials-input::placeholder{color:var(--color-text-muted);opacity:.5}@media (max-width: 768px){.shape-controls{bottom:1.5rem}.shape-buttons{gap:.5rem}.shape-option{font-size:.85rem;padding:.6rem 1.2rem}.initials-input{width:180px;font-size:1.1rem}.complete-content{padding:1.5rem}}@media (max-width: 480px){.shape-buttons{flex-direction:column;width:100%}.shape-option{width:100%;max-width:300px}.complete-actions{flex-direction:column}.initials-input{width:160px}}.app{min-height:100vh;width:100%;position:relative;overflow:hidden}.menu{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;background:radial-gradient(circle at 20% 80%,rgba(139,21,56,.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(212,113,143,.1) 0%,transparent 50%),var(--color-bg);position:relative}.menu:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 2px 2px,rgba(255,214,224,.03) 1px,transparent 0);background-size:40px 40px;pointer-events:none}.menu-title{font-family:var(--font-display);font-size:clamp(3rem,10vw,6rem);font-weight:300;font-style:italic;letter-spacing:.02em;margin-bottom:.5rem;text-align:center;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.menu-subtitle{font-size:clamp(.9rem,2vw,1.1rem);font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:4rem}.menu-buttons{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;max-width:800px}.menu-button{background:#8b15381a;border:1px solid rgba(212,113,143,.3);border-radius:16px;padding:2.5rem 2rem;min-width:280px;display:flex;flex-direction:column;align-items:center;gap:1rem;transition:all .4s var(--transition-smooth);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.menu-button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(139,21,56,.2) 0%,transparent 100%);opacity:0;transition:opacity .4s var(--transition-smooth)}.menu-button:hover:before{opacity:1}.menu-button:hover{border-color:var(--color-secondary);box-shadow:0 8px 32px #8b15384d}.button-icon{font-size:3rem;filter:grayscale(.3);transition:filter .3s ease}.menu-button:hover .button-icon{filter:grayscale(0)}.button-text{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--color-text)}.button-desc{font-size:.85rem;font-weight:300;color:var(--color-text-muted);letter-spacing:.05em}.menu-footer{position:absolute;bottom:2rem;font-size:.75rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);opacity:.6}@media (max-width: 768px){.menu-buttons{flex-direction:column;gap:1.5rem}.menu-button{min-width:100%;max-width:400px;padding:2rem 1.5rem}.menu-title{margin-bottom:.25rem}.menu-subtitle{margin-bottom:3rem}}@media (max-width: 480px){.menu{padding:1.5rem}.button-icon{font-size:2.5rem}.button-text{font-size:1.25rem}}:root{--color-bg: #1a0a0f;--color-bg-lighter: #2a1520;--color-primary: #8B1538;--color-primary-light: #b91d47;--color-secondary: #d4718f;--color-accent: #ffd6e0;--color-text: #f5e6ea;--color-text-muted: #c9a8b3;--font-display: "Cormorant Garamond", serif;--font-body: "Montserrat", sans-serif;--transition-smooth: cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;width:100%}button{font-family:var(--font-body);cursor:pointer;border:none;background:none;color:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-lighter)}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-light)}::selection{background:var(--color-primary);color:var(--color-accent)}
