@import url(https://fonts.googleapis.com/css2?family=Lobster&family=Open+Sans:wght@400;600&display=swap);*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Open Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;min-height:100vh}#root{position:relative;z-index:1}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media screen and (max-width:768px){input,select,textarea{font-size:16px}}.bingo-logo{justify-content:center}.bingo-box,.bingo-logo{align-items:center;display:flex}.bingo-box{background:#fffdf8;border:2px solid #c9b99a;border-radius:8px;flex-direction:column;min-height:120px;padding:10px 8px;position:relative;transition:all .2s ease}.bingo-box.filled{background:#f8fdf5;border-color:#6b8e4e;border-width:3px}.bingo-box.duplicate{background:#fdf5f5;border-color:#c94c4c;border-width:3px}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.bingo-box.pop{animation:pop .2s ease-out}.bingo-box.pop .bingo-box-icon{animation:iconPop .2s ease-out}@keyframes iconPop{0%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0deg)}}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-4px)}20%,40%,60%,80%{transform:translateX(4px)}}.bingo-box.shake{animation:shake .5s ease-in-out;background:#fff5f5;border-color:#e57373}.bingo-box-icon{color:#8b7355;font-size:2rem;margin-bottom:4px;opacity:.9}.bingo-box.filled .bingo-box-icon{color:#6b8e4e}.bingo-box.duplicate .bingo-box-icon{color:#c94c4c}.bingo-box-question{align-items:center;display:flex;flex:1 1;font-weight:600;justify-content:center;line-height:1.2;margin:0;padding:6px 0}.bingo-box-input,.bingo-box-question{color:#4a3728;font-size:.7rem;text-align:center}.bingo-box-input{background:#fff;border:1px solid #d4c9b5;border-radius:4px;box-sizing:border-box;padding:6px 8px;width:100%}.bingo-box-input::placeholder{color:#a99f8f;font-style:italic}.bingo-box-input:focus{border-color:#8b7355;box-shadow:0 0 0 2px #8b735533;outline:none}.bingo-box.filled .bingo-box-input{background:#f0f7eb;border-color:#6b8e4e}.bingo-box.duplicate .bingo-box-input{background:#f7ebeb;border-color:#c94c4c}.bingo-box-tooltip{background:#c94c4c;border-radius:6px;box-shadow:0 2px 8px #0003;color:#fff;font-size:.65rem;opacity:0;padding:6px 10px;top:-40px;transition:opacity .2s ease,visibility .2s ease;visibility:hidden;white-space:nowrap;z-index:100}.bingo-box-tooltip,.bingo-box-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.bingo-box-tooltip:after{border:6px solid #0000;border-top-color:#c94c4c;content:"";top:100%}.bingo-box.duplicate:focus-within .bingo-box-tooltip,.bingo-box.duplicate:hover .bingo-box-tooltip{opacity:1;visibility:visible}@media (max-width:400px){.bingo-box{min-height:100px;padding:8px 6px}.bingo-box-icon{font-size:1.5rem}.bingo-box-question{font-size:.65rem}.bingo-box-input{font-size:.65rem;padding:5px 6px}.bingo-box-tooltip{font-size:.6rem;padding:5px 8px;top:-36px}}.bingo-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}@media (orientation:portrait){.bingo-grid{grid-template-columns:repeat(3,1fr)}}@media (orientation:landscape){.bingo-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:400px){.bingo-grid{gap:8px}}.completion-screen{align-items:center;box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.fireworks-canvas{height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}.completion-card{animation:cardAppear .6s ease-out;background:#f5f0e6;border-radius:16px;box-shadow:0 8px 32px #0003;max-width:400px;padding:32px 24px;position:relative;text-align:center;width:100%;z-index:1}@keyframes cardAppear{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.completion-stars{font-size:2rem;margin-bottom:8px}.completion-title{color:#4a3728;font-family:Lobster,cursive;font-size:2.5rem;margin:0 0 8px}.completion-highlight{background:linear-gradient(135deg,gold,#ffb347);border-radius:12px;margin-bottom:20px;padding:16px}.completion-highlight-title{color:#4a3728;font-size:1.5rem;font-weight:700;margin:0 0 8px}.completion-message{color:#5a4738;font-size:.95rem;line-height:1.4;margin:0 0 8px}.completion-code{color:#4a3728;font-size:1.25rem;font-weight:700;letter-spacing:1px;margin:0}.reset-button{align-items:center;background:linear-gradient(135deg,#c67b3c,#a65a2a);border:none;border-radius:24px;box-shadow:0 4px 12px #a65a2a4d;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:14px 32px;transition:all .2s ease}.reset-button:hover{box-shadow:0 6px 16px #a65a2a66;transform:translateY(-2px)}.reset-button:active{transform:translateY(0)}.button-icon{font-size:1.1rem}@media (max-width:480px){.completion-card{padding:24px 16px}.completion-title{font-size:2rem}.completion-highlight-title{font-size:1.25rem}}.App{min-height:100vh;padding:20px 10px}.App-header{margin-bottom:8px;text-align:center}.App-header h1{color:#4a3728;font-family:Lobster,cursive;font-size:2.5rem;margin:0;text-shadow:2px 2px 4px #ffffff4d}.App-subtitle{align-items:center;color:#5a4738;display:flex;font-size:.95rem;font-weight:600;gap:8px;justify-content:center;margin-top:4px}.App-subtitle img{height:24px;width:auto}.bingo-card{background:#f5f0e6;border-radius:16px;box-shadow:0 8px 32px #0003;margin:0 auto;max-width:500px;padding:16px}.bingo-instruction{background:#fff;border-radius:20px;box-shadow:0 2px 8px #0000000d;color:#4a3728;font-size:.9rem;margin-bottom:12px;padding:10px 16px;text-align:center}.show-code-button{background:#6b8e4e;border:none;border-radius:8px;box-shadow:0 4px 12px #6b8e4e4d;color:#fff;cursor:pointer;display:block;font-size:1.1rem;font-weight:600;margin-top:16px;padding:14px 24px;transition:background .2s ease,transform .1s ease;width:100%}.show-code-button:hover{background:#5a7a42}.show-code-button:active{transform:scale(.98)}@media (max-width:480px){.App{padding:16px 8px}.App-header h1{font-size:2rem}.bingo-card{border-radius:12px;padding:12px}.bingo-instruction{font-size:.85rem;padding:8px 12px}}
/*# sourceMappingURL=main.391b8ce6.css.map*/