@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(../media/32687112bd2dd8db-s.cfdd66c2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(../media/28868e710e86be81-s.c30238d4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(../media/0c89a48fa5027cee-s.p.4564287c.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk Fallback;src:local(Arial);ascent-override:89.71%;descent-override:26.62%;line-gap-override:0.0%;size-adjust:109.69%}.space_grotesk_be3706e9-module__qTy7eW__className{font-family:Space Grotesk,Space Grotesk Fallback;font-style:normal}.space_grotesk_be3706e9-module__qTy7eW__variable{--font-space-grotesk:"Space Grotesk","Space Grotesk Fallback"}
:root{--bg-1:#fef7ea;--bg-2:#e9f9f3;--ink:#1f2430;--muted:#5b6070;--card:#ffffffd6;--line:#ccd6c8;--accent:#e67e22;--accent-2:#2c8a6d}*{box-sizing:border-box}body{min-height:100vh;font-family:var(--font-space-grotesk),sans-serif;color:var(--ink);background:radial-gradient(circle at 15% 10%,#e67e2233,transparent 28%),radial-gradient(circle at 90% 90%,#2c8a6d40,transparent 35%),linear-gradient(140deg,var(--bg-1),var(--bg-2));margin:0;padding-top:70px}.navbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;background:#fffffff2;border-bottom:1px solid #ccd6c899;height:70px;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #1620190d}.navbar-content{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 2rem;display:flex}.navbar-user{align-items:center;display:flex}.navbar-username{color:var(--accent-2);cursor:pointer;background:#2c8a6d1a;border:1px solid #2c8a6d4d;border-radius:8px;padding:.5rem 1rem;font-size:.95rem;font-weight:600;transition:all .2s}.navbar-username:hover{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}.navbar-username-empty{color:var(--accent);background:#e67e221a;border-color:#e67e224d}.navbar-username-empty:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.navbar-username-input{border:2px solid var(--accent-2);color:var(--ink);background:#fff;border-radius:8px;min-width:150px;padding:.5rem 1rem;font-size:.95rem;font-weight:600}.navbar-brand{color:var(--ink);align-items:center;gap:.75rem;text-decoration:none;transition:transform .2s;display:flex}.navbar-brand:hover{transform:scale(1.02)}.navbar-logo{color:var(--accent-2);align-items:center;display:flex}.navbar-title{background:linear-gradient(135deg,var(--accent-2),var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.page-shell{grid-template-columns:1fr;gap:1.25rem;width:min(1100px,92vw);margin:2.5rem auto;display:grid}.single-column{max-width:920px;margin-left:auto;margin-right:auto}.create-panel,.preview-panel{background:var(--card);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid #ffffffb3;border-radius:20px;padding:1.25rem;animation:.38s ease-out both fade-up;box-shadow:0 18px 45px #1620191a}.create-panel h1{margin:0;font-size:clamp(1.4rem,2.8vw,2.15rem)}.create-panel p{color:var(--muted);margin:.5rem 0 1rem}.form-stack{gap:.75rem;display:grid}label,legend{font-size:.92rem;font-weight:700}input,textarea,button{font:inherit}input,textarea{border:1px solid var(--line);background:#fcfefb;border-radius:10px;padding:.65rem .8rem}input:focus,textarea:focus{outline:2px solid color-mix(in srgb,var(--accent-2),white 55%);border-color:var(--accent-2)}fieldset{border:1px solid var(--line);border-radius:12px;padding:.7rem .8rem .85rem}.preset-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;margin-top:.4rem;display:grid}.preset-option{border:1px solid var(--line);background:#fff;border-radius:10px;justify-content:center;align-items:center;gap:.35rem;padding:.55rem;display:flex}button{background:linear-gradient(90deg,var(--accent),#f1b451);color:#222;cursor:pointer;border:none;border-radius:11px;margin-top:.2rem;padding:.72rem .9rem;font-weight:700}.error-text{color:#a12f3d;margin-top:-.3rem;font-size:.82rem}.submit-error{margin-top:.4rem}.success-text{color:#1b6e55;margin:.35rem 0 0;font-size:.88rem}.preview-card h2{margin:0}.preview-card p{color:var(--muted);margin:.4rem 0 .9rem}.bingo-grid{gap:.5rem;display:grid}.bingo-cell{cursor:pointer;background:linear-gradient(#fff,#f4fff8);border:1px solid #b4c6b9;border-radius:12px;justify-content:center;align-items:center;min-height:80px;padding:.1rem;transition:all .2s;display:flex;overflow:hidden}.bingo-cell:hover{border-color:var(--accent-2);transform:scale(1.02)}.bingo-cell.selected{border-color:var(--accent-2);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-2),white 60%);background:linear-gradient(#d4f4e3,#b8e8d1);border-width:2px}.bingo-cell-text{text-align:center;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;justify-content:center;align-items:center;width:100%;padding:.1rem;font-size:.5rem;line-height:1.3;display:flex}.bingo-cell:focus-within{border-color:var(--accent-2);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-2),white 60%)}.bingo-cell-input{text-align:center;resize:none;background:0 0;border:none;border-radius:9px;width:100%;height:100%;min-height:0;padding:.35rem;font-size:clamp(.72rem,1.2vw,.9rem);line-height:1.2;overflow:hidden}.bingo-cell-input:focus{border-color:#0000;outline:none}.create-bingo-button{width:100%;margin-top:.8rem}.share-url-container{margin-bottom:1.5rem}.share-url-container label{margin-bottom:.5rem;font-size:.95rem;font-weight:600;display:block}.share-url-box{scrollbar-width:thin;background:#2c8a6d0d;border:1px solid #2c8a6d33;border-radius:10px;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex;overflow-x:auto}.share-url-box::-webkit-scrollbar{height:4px}.share-url-box::-webkit-scrollbar-thumb{background:#2c8a6d4d;border-radius:2px}.share-url-text{min-width:0;color:var(--accent-2);text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.85rem;overflow:hidden}@media (max-width:600px){.share-url-text{max-width:200px;font-size:.75rem}}.copy-button{border:1px solid var(--line);cursor:pointer;color:var(--accent-2);background:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.copy-button:hover{background:var(--accent-2);border-color:var(--accent-2);color:#fff;transform:scale(1.05)}.copy-button:active{transform:scale(.95)}.submissions-count{margin:.2rem 0 .9rem;font-weight:700}.submission-list{gap:.85rem;display:grid}.submission-card{background:#ffffffb3;border:1px solid #d6dfd8;border-radius:14px;padding:.75rem}.submission-card h3{margin:0}.muted{color:var(--muted);margin:.35rem 0 .75rem}.preview-only-cell{place-items:center;display:grid}.bingo-cell-readonly{text-align:center;overflow-wrap:anywhere;width:100%;font-size:clamp(.72rem,1.2vw,.9rem);line-height:1.2;display:block}.aggregated-cell{cursor:help;flex-direction:column;justify-content:center;align-items:center;padding:.5rem .35rem;display:flex}.aggregated-cell:hover{background:linear-gradient(#fffdf7,#fff9e8)}.bingo-cell-content{flex-direction:column;align-items:center;gap:.25rem;width:100%;height:100%;display:flex;overflow:hidden}.field-text{text-align:center;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;font-size:.5rem;font-weight:500;line-height:1.3}.selection-count{color:var(--accent-2);margin-top:.15rem;font-size:.75rem;font-weight:700}.user-list{color:var(--muted);text-align:center;text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;margin-top:.1rem;font-size:.65rem;line-height:1.3;display:-webkit-box;overflow:hidden}.deadline-info,.max-selections-info{border-left:3px solid var(--accent-2);color:var(--ink);background:#2c8a6d1a;border-radius:6px;margin:.5rem 0;padding:.6rem .8rem;font-size:.88rem}.info-box{border-left:3px solid var(--accent);color:var(--ink);background:#e67e2214;border-radius:6px;margin:.5rem 0;padding:.6rem .8rem;font-size:.88rem}.expired-badge{color:#a12f3d;font-weight:700}.expired-message{text-align:center;background:#a12f3d1a;border:2px solid #a12f3d;border-radius:10px;padding:1rem}.view-results-link{border:1px solid var(--accent-2);width:100%;color:var(--accent-2);text-align:center;background:#2c8a6d1a;border-radius:11px;padding:.72rem .9rem;font-size:1rem;font-weight:700;text-decoration:none;transition:all .2s;display:block}.view-results-link:hover{background:var(--accent-2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #2c8a6d4d}.recent-bingos-card{background:var(--card);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:18px;padding:1.25rem;animation:.42s ease-out fade-up;box-shadow:0 2px 8px #16201914,0 .5px 1.5px #1620190d}.recent-bingos-card h2{color:var(--ink);margin:0 0 1rem;font-size:1.25rem;font-weight:700}.recent-bingos-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.recent-bingos-list li{font-size:.95rem}.recent-bingo-link{color:var(--accent-2);text-decoration:underline;-webkit-text-decoration-color:var(--accent-2);text-decoration-color:var(--accent-2);font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.9rem;transition:all .2s;display:inline-block}.recent-bingo-link:after{content:" →";margin-left:.25rem;font-family:system-ui,-apple-system,sans-serif;transition:transform .2s;display:inline-block}.recent-bingo-link:hover{-webkit-text-decoration-color:var(--accent-2);text-decoration-color:var(--accent-2);color:var(--accent);transform:translate(4px)}.recent-bingo-link:hover:after{transform:translate(2px)}@media (min-width:920px){.page-shell{grid-template-columns:.95fr 1.05fr;gap:1.4rem}.create-panel,.preview-panel{padding:1.5rem}.recent-bingos-card{grid-column:1/-1;padding:1rem 1.25rem}.recent-bingos-card h2{margin-bottom:.75rem;font-size:1.1rem}.recent-bingos-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem 1rem;display:grid}}@keyframes fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.aggregated-cell{position:relative;overflow:visible!important}.aggregated-cell.has-selections{transition:all .2s}.aggregated-cell.has-selections:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2c8a6d33}.aggregated-cell.active{box-shadow:0 0 0 2px var(--accent)}.selection-badge{background:var(--accent);color:#fff;z-index:1;border-radius:12px;justify-content:center;align-items:center;min-width:24px;height:24px;padding:0 6px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 8px #2c8a6d66}.context-menu{background:var(--card);z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #2c8a6d33;border-radius:12px;min-width:220px;max-width:min(320px,80vw);animation:.2s ease-out context-appear;position:absolute;transform:translate(-50%,-100%);box-shadow:0 12px 32px #00000026,0 2px 8px #0000001a}.context-menu-header{border-bottom:1px solid #ffffff1a;flex-direction:column;gap:.25rem;padding:.875rem 1rem;display:flex}.context-menu-header strong{color:var(--accent-2);word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;font-size:.95rem;font-weight:600;line-height:1.3}.context-menu-count{color:var(--ink);opacity:.7;font-size:.8rem}.context-menu-list{max-height:280px;margin:0;padding:.5rem;list-style:none;overflow-y:auto}.context-menu-list li{border-left:2px solid var(--accent);color:var(--ink);word-wrap:break-word;overflow-wrap:break-word;background:#2c8a6d0d;border-radius:6px;margin-bottom:.375rem;padding:.625rem .75rem;font-size:.9rem}.context-menu-list li:last-child{margin-bottom:0}@keyframes context-appear{0%{opacity:0;transform:translate(-50%,calc(8px - 100%))}to{opacity:1;transform:translate(-50%,-100%)}}
