: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}}.app-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;width:100vw;height:100vh;height:100dvh;background:linear-gradient(to bottom right,#f3e8ff,#dbeafe);padding:1rem;overflow:hidden;position:fixed;top:0;left:0;box-sizing:border-box}.header{text-align:center;flex-shrink:0;width:100%;max-width:500px}.title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.subtitle{color:#4b5563;font-size:.875rem}.word-display{font-size:.875rem;color:#2563eb;font-weight:600;margin-top:.5rem}.grid-container{position:relative;width:min(80vw,80vh,400px);height:min(80vw,80vh,400px);max-width:400px;max-height:400px;background:transparent;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;user-select:none;-webkit-user-select:none;flex-shrink:0;touch-action:none;margin:0 auto}.svg-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:10}.grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%;gap:0}.cell{display:flex;align-items:center;justify-content:center;font-size:2.25rem;font-weight:700;border:1px solid #e5e7eb;transition:all .2s;background:#f9fafb;color:#374151;cursor:pointer;position:relative;z-index:1}.cell:hover{background:#f3f4f6}.cell.selected{color:#fff}.cell.selected:before{content:"";position:absolute;inset:10%;background:#3b82f6;border-radius:.4rem;z-index:0}.new-grid-button{padding:.875rem 2rem;background:#3b82f6;color:#fff;border-radius:.75rem;font-weight:600;border:none;cursor:pointer;box-shadow:0 10px 15px -3px #0000001a;font-size:1.125rem;flex-shrink:0;touch-action:manipulation;display:block;margin:0 auto}.new-grid-button:hover{background:#2563eb}.new-grid-button:active{transform:scale(.98)}.word-display-container{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.word-label{font-size:.875rem;color:#2563eb;font-weight:600}.word-cells{display:flex;gap:3px}.word-cell{width:28px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#2563eb;border-bottom:3px solid #cbd5e1}.word-cell.hint{color:#10b981;border-bottom:3px solid #10b981}.word-cell.wrong{color:#ef4444;border-bottom:3px solid #ef4444;animation:shake .3s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000;overflow:hidden}.confetti-particle{position:absolute;left:50%;top:50%;border-radius:50%;animation:confetti-fall 2s ease-out forwards;will-change:transform,opacity}@keyframes confetti-fall{0%{transform:translate(-50%,-50%) rotate(0);opacity:1}to{transform:translate(calc(-50% + var(--vx) * 50px),calc(-50% + var(--vy) * 50px + 500px)) rotate(calc(var(--rotation) + var(--rotation-speed) * 360deg));opacity:0}}.bravo-text{position:absolute;top:27%;left:50%;transform:translate(-50%,-50%);font-size:2.5rem;font-weight:700;color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.3),0 0 20px rgba(255,215,0,.5);animation:bravo-bounce .6s ease-out;z-index:1001}@keyframes bravo-bounce{0%{transform:translate(-50%,-50%) scale(0);opacity:0}50%{transform:translate(-50%,-50%) scale(1.2)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@media (max-width: 768px){.bravo-text{font-size:2rem}}
