@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";:root{--font: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--bg: #f1f5f9;--bg-card: #ffffff;--text: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--primary: #4f46e5;--primary-hover: #4338ca;--primary-muted: #eef2ff;--danger: #b91c1c;--danger-bg: #fef2f2;--success: #15803d;--success-bg: #f0fdf4;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgb(15 23 42 / 6%), 0 4px 12px rgb(15 23 42 / 4%);--shadow-lg: 0 4px 6px rgb(15 23 42 / 5%), 0 12px 24px rgb(15 23 42 / 8%);line-height:1.5;color:var(--text);background:var(--bg);font-family:var(--font)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:var(--primary);text-decoration:none;font-weight:500}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit}.page{min-height:100vh;padding:1.5rem 1rem 3rem}.page-narrow{max-width:440px;margin:0 auto}.page-wide{max-width:900px;margin:0 auto}.shell-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.shell-brand{font-weight:700;font-size:1.25rem;letter-spacing:-.02em;color:var(--text);text-decoration:none}.shell-brand:hover{text-decoration:none;color:var(--primary)}.shell-nav{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:1.25rem 1.35rem;margin-bottom:1.25rem}.card h2{margin:0 0 .75rem;font-size:1rem;font-weight:600;letter-spacing:-.01em}.muted{color:var(--text-muted);font-size:.9375rem}.muted.small{font-size:.8125rem}.stack{display:flex;flex-direction:column;gap:.75rem}.field{display:flex;flex-direction:column;gap:.35rem}.field span{font-size:.8125rem;font-weight:500;color:var(--text-muted)}.input,.select,.textarea{width:100%;padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text);transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted)}.textarea{min-height:120px;resize:vertical}.row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-end}.row-grow{flex:1 1 200px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.55rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-weight:600;font-size:.875rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.btn:disabled{opacity:.55;cursor:not-allowed}.btn:not(:disabled):hover{background:#f8fafc}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:not(:disabled):hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-muted);font-weight:500}.btn-ghost:not(:disabled):hover{background:#f1f5f9;color:var(--text)}.segmented{display:inline-flex;border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden;background:#f8fafc}.segmented button{border:none;background:transparent;padding:.45rem 1rem;font-weight:600;font-size:.875rem;color:var(--text-muted);cursor:pointer}.segmented button[data-active=true]{background:#fff;color:var(--primary);box-shadow:0 1px 2px #0f172a0f}.alert{padding:.65rem .85rem;border-radius:var(--radius-sm);font-size:.875rem}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid #bbf7d0}.pill{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize;background:#f1f5f9;color:var(--text-muted)}.pill-active{background:#dcfce7;color:#166534}.list-plain{list-style:none;padding:0;margin:0}.list-plain li{padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.875rem}.list-plain li:last-child{border-bottom:none}.loading-screen{min-height:40vh;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.bingo-grid{display:grid;gap:.45rem;margin-top:1rem}.bingo-cell{aspect-ratio:1;min-height:4.5rem;padding:.35rem;border-radius:var(--radius-sm);border:2px solid var(--border);background:#fff;font-size:clamp(.65rem,2.2vw,.8rem);font-weight:600;line-height:1.2;cursor:pointer;transition:transform .1s,border-color .15s,background .15s;display:flex;align-items:center;justify-content:center;text-align:center;-webkit-hyphens:auto;hyphens:auto;word-break:break-word}.bingo-cell:not(:disabled):hover{border-color:var(--primary);transform:scale(1.02)}.bingo-cell:disabled{cursor:default;opacity:.85}.bingo-cell-marked{background:linear-gradient(145deg,#eef2ff,#e0e7ff);border-color:var(--primary);color:var(--primary-hover)}.bingo-cell-called{box-shadow:inset 0 0 0 2px #fbbf24}.bingo-cell-free{background:linear-gradient(145deg,#fef3c7,#fde68a);border-color:#f59e0b}.bingo-win{margin-top:1rem;padding:1rem;border-radius:var(--radius);background:linear-gradient(135deg,#ecfccb,#d9f99d);border:1px solid #84cc16;font-weight:600;color:#3f6212;text-align:center}@media (min-width: 900px){.host-play-layout{display:grid;grid-template-columns:minmax(260px,1fr) minmax(280px,440px);gap:1.5rem;align-items:start}}.host-last-call-text{font-size:clamp(1.25rem,3vw,1.85rem);font-weight:700;color:var(--primary);margin:.25rem 0 0;line-height:1.2}.bingo-grid-host{max-width:440px;margin-left:auto;margin-right:auto}.call-order-list{max-height:220px;overflow:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
