:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#1e293b;background-color:#f1f5f9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}:root{--font-pixel: "Press Start 2P", monospace}.app{min-height:100vh;display:flex;flex-direction:column;background:#f1f5f9}.site-header{padding:.75rem 1rem;text-align:center;border-bottom:2px solid #cbd5e1;background:#fff}.site-logo{font-family:var(--font-pixel);font-size:.85rem;color:#0d9488;text-decoration:none;letter-spacing:.04em;line-height:2.5}.site-logo:hover{color:#0f766e}.main{flex:1;padding:1rem;max-width:800px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box}h1{font-family:var(--font-pixel);font-size:clamp(1rem,3.5vw,1.4rem);margin:0 0 1rem;color:#1e293b;letter-spacing:.02em;line-height:2.5}h2{font-family:var(--font-pixel);font-size:.8rem;color:#1e293b;line-height:2.5}h3{font-family:var(--font-pixel);font-size:.7rem;color:#1e293b;line-height:2.5}h4{font-family:var(--font-pixel);font-size:.65rem;color:#1e293b;line-height:2.5}button{font-family:var(--font-pixel);font-size:.7rem;padding:.6rem 1rem;cursor:pointer;border-radius:3px;border:2px solid #d1d5db;background:#fff;min-height:44px;line-height:2.3;transition:background .15s,box-shadow .15s,transform .1s}button:hover:not(:disabled){background:#f8fafc;box-shadow:3px 3px #0000001a}button:active:not(:disabled){transform:translate(1px,1px);box-shadow:1px 1px #0000001a}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:#0d9488;color:#fff;border:3px solid #0a7a70}button.primary:hover:not(:disabled){background:#0f766e;box-shadow:3px 3px #0d94884d}button.skip{background:#f59e0b;color:#fff;border:3px solid #d97706;font-weight:600}button.skip:hover:not(:disabled){background:#d97706;box-shadow:3px 3px #f59e0b4d}button.skip-penalty{background:#ef4444;color:#fff;border:3px solid #dc2626;font-weight:600}button.skip-penalty:hover:not(:disabled){background:#dc2626;box-shadow:3px 3px #ef44444d}input{font-size:1rem;padding:.5rem;border-radius:3px;border:2px solid #d1d5db;min-height:44px;width:100%;max-width:280px;transition:border-color .15s,box-shadow .15s}input:focus{outline:none;border-color:#0d9488;box-shadow:3px 3px #0d948826}.label{display:block;margin-bottom:.25rem;font-weight:500}.form-group{margin-bottom:1rem}.status{font-family:var(--font-pixel);font-size:.5rem;color:#94a3b8;margin-bottom:.5rem;line-height:2.5}.status.connected{color:#059669}.status.disconnected{color:#dc2626;font-weight:500}.card{background:#fff;border-radius:4px;padding:1.5rem;box-shadow:4px 4px #0000001a;margin-bottom:1rem;border:2px solid #cbd5e1;width:100%;box-sizing:border-box}.copy-code{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.copy-code input{max-width:120px;font-family:var(--font-pixel);letter-spacing:.1em;font-size:.85rem}.copy-code button{flex-shrink:0}.player-list{list-style:none;padding:0;margin:0}.player-list li{padding:.5rem 0;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.player-list li:last-child{border-bottom:none}.badge{font-family:var(--font-pixel);font-size:.45rem;padding:.3rem .5rem;border-radius:2px;background:#e5e7eb;margin-right:.25rem;line-height:2.3}.badge.ready{background:#d1fae5;color:#065f46}.badge.not-ready{background:#fee2e2;color:#991b1b}.badge.bot-badge{background:#fef3c7;color:#92400e}.badge.connected{background:#d1fae5;color:#065f46}.badge.disconnected{background:#fee2e2;color:#991b1b}.footer{font-family:var(--font-pixel);padding:1.25rem 1rem;font-size:.45rem;color:#94a3b8;text-align:center;border-top:2px solid #cbd5e1;width:100%;line-height:2.6}.footer p{margin:.4rem 0}.footer a{color:#0d9488}.dice-card{min-height:280px}.dice-card .dice-display{margin:.5rem 0 1rem}.dice-action-area{min-height:52px;margin:.5rem 0 .25rem}.dice-action-area button{width:100%;box-sizing:border-box}.dice-row{display:flex;gap:.5rem;margin-bottom:.5rem}.die{width:2.8rem;height:2.8rem;border-radius:3px;display:inline-flex;align-items:center;justify-content:center;box-shadow:3px 3px #00000040;border:2px solid rgba(0,0,0,.2)}.die-rolling{animation:diceRoll .5s ease-out}@keyframes diceRoll{0%{transform:rotate(0)}15%{transform:rotate(-18deg)}30%{transform:rotate(14deg)}45%{transform:rotate(-10deg)}60%{transform:rotate(6deg)}75%{transform:rotate(-3deg)}90%{transform:rotate(1deg)}to{transform:rotate(0)}}.die-face{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:1.6rem;height:1.6rem;gap:1px}.pip{width:7px;height:7px;border-radius:1px;align-self:center;justify-self:center;background:transparent}.pip.visible{background:currentColor}.phase-prompt{width:100%;font-size:.9rem;color:#475569;margin:0 0 .25rem;line-height:1.5}.choices{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.choices button{flex:1 1 auto}.scoresheets{margin-top:1.5rem}.scoresheet-wrap{margin-bottom:1rem}.scoresheet-wrap h3{font-size:.7rem}.scoresheet{border:2px solid #cbd5e1;border-radius:4px;overflow:hidden;max-width:fit-content;width:100%}@media(max-width:539px){.scoresheet{max-width:100%}}.sheet-row{display:flex;align-items:center;padding:.15rem .5rem;gap:.3rem}.row-label{width:2.5rem;min-width:1.8rem;flex-shrink:1;font-weight:600;font-size:.875rem;text-transform:capitalize}.sheet-row .cell{flex:1;min-width:0;max-width:2.5rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;border-radius:2px;background:#ffffff80}.special-divider{width:2px;height:1.5rem;background:#0003;margin:0 2px;flex-shrink:0}.special-cell{border:2px dashed rgba(0,0,0,.25)}.sheet-row .cell.crossed{background:#00000014;padding:0}.hand-x{width:85%;height:85%;display:block}.lock-cell{width:1.25rem;flex-shrink:0;font-size:.875rem;text-align:center}.lock-cell.locked{opacity:1}.lock-cell:not(.locked){opacity:.3}.strikes{display:flex;gap:.35rem;padding:.25rem .5rem}.strike-box{width:1.6rem;height:1.6rem;border:2px dashed #ccc;border-radius:2px;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700;color:#ddd;-webkit-user-select:none;user-select:none}.strike-box.struck{border:2px solid #333;color:#111}.cell.valid-click{outline:2px solid #0d9488;cursor:pointer;font-weight:700;animation:softPulse 1.5s ease-in-out infinite}@keyframes softPulse{0%,to{outline-color:#0d9488;background:#0d948814}50%{outline-color:#5eead4;background:#0d94882e}}.lock-cell.valid-click{cursor:pointer;opacity:1}.turn-indicator{font-size:.9rem;font-weight:600;color:#475569;margin:0 0 .5rem}.first-roller-msg{font-weight:600;color:#059669;margin:0 0 .5rem}.scoresheet-you{margin-bottom:1rem}@media(min-width:540px){.scoresheet-you .sheet-row{padding:.2rem .6rem;gap:.35rem}.scoresheet-you .row-label{width:3.2rem;min-width:2.5rem;font-size:1rem}.scoresheet-you .sheet-row .cell{max-width:3.2rem;height:2.6rem;font-size:1.05rem}.scoresheet-you .special-divider{height:2rem}.scoresheet-you .lock-cell{width:1.5rem;font-size:1rem}.scoresheet-you .strikes{gap:.4rem;padding:.3rem .6rem}.scoresheet-you .strike-box{width:2rem;height:2rem;font-size:1.1rem}.scoresheet-you .score-summary{font-size:.9rem;padding:.5rem .6rem}}.scoresheet-others{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:2px solid #cbd5e1}.scoresheet-others h3{width:100%;margin:0 0 .5rem;font-size:.7rem}.scoresheet-others .compact{min-width:200px}.scoresheet-others .compact .sheet-row .cell{min-width:1.2rem;max-width:1.8rem;height:1.5rem;font-size:.75rem}.sheet-row.row-locked{opacity:.55;pointer-events:none;position:relative;background-image:repeating-linear-gradient(-45deg,transparent,transparent 6px,rgba(0,0,0,.1) 6px,rgba(0,0,0,.1) 8px)}.sheet-row.row-locked:after{content:"LOCKED";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-pixel);font-weight:800;font-size:.65rem;letter-spacing:.15em;line-height:2.5;color:#00000059;pointer-events:none;text-transform:uppercase}.lock-modal-backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.lock-modal{background:#fff;border-radius:4px;padding:2rem 2.5rem;text-align:center;box-shadow:6px 6px #0003;border:3px solid #cbd5e1;max-width:320px;width:90%;animation:modalPop .25s ease}.lock-modal-icon{font-size:2.5rem;display:block;margin-bottom:.75rem}.lock-modal-text{font-family:var(--font-pixel);font-size:.7rem;font-weight:600;color:#1e293b;margin:0 0 1.25rem;line-height:2.5}.lock-modal button{min-width:100px}.first-player-modal{min-height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center}.first-player-spinning{font-family:var(--font-pixel);font-size:.8rem;font-weight:700;color:#1e293b;margin:0;min-height:2rem;line-height:2.5}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalPop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.score-summary{display:flex;flex-wrap:wrap;gap:.5rem 1rem;padding:.4rem .5rem;font-size:.8rem;border-top:1px solid #e5e7eb}.score-item{font-weight:600}.score-penalty{color:#6b7280}.score-total{color:#111;font-weight:700}.score-breakdown{margin-top:1rem}.breakdown-header,.breakdown-row{display:grid;grid-template-columns:2fr repeat(6,1fr);gap:.25rem;padding:.4rem 0;font-size:.85rem;text-align:center}.breakdown-header{font-weight:700;border-bottom:2px solid #e5e7eb;font-size:.75rem;color:#6b7280}.breakdown-row{border-bottom:1px solid #f3f4f6}.breakdown-row.winner-row{background:#ecfdf5;font-weight:600}.breakdown-name{text-align:left}.game-over-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}.scoring-legend{margin-top:1rem;padding-top:.75rem;border-top:1px solid #e5e7eb;font-size:.75rem}.legend-title{font-family:var(--font-pixel);font-size:.52rem;font-weight:600;margin-bottom:.25rem;display:block;line-height:2.5}.legend-grid{display:flex;flex-wrap:wrap;gap:.25rem .5rem}.legend-entry{display:flex;gap:.15rem}.legend-crosses{color:#6b7280}.legend-pts{font-weight:600}.error{font-family:var(--font-pixel);color:#dc2626;font-size:.58rem;margin-top:.25rem;line-height:2.5}.waiting-dots:after{content:"";animation:dots 1.4s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.die{transition:transform .2s ease}.sheet-row .cell{transition:background .2s ease}.strike-box{transition:color .3s ease,border-color .3s ease}.divider-text{font-family:var(--font-pixel);display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:#94a3b8;font-size:.58rem}.divider-text:before,.divider-text:after{content:"";flex:1;height:2px;background:#cbd5e1}.game-header-row{display:flex;align-items:center;justify-content:space-between}.game-header-row h1{margin-bottom:0}.header-actions{display:flex;align-items:center;gap:.5rem}.mute-btn{font-family:inherit;font-size:1.1rem;padding:.3rem .5rem;min-height:0;line-height:1;border:2px solid #d1d5db;background:#f9fafb;border-radius:3px}.mute-btn:hover:not(:disabled){background:#e2e8f0}.leave-btn{font-size:.58rem;padding:.35rem .75rem;min-height:0;color:#6b7280;border-color:#d1d5db;background:#f9fafb}.leave-btn:hover:not(:disabled){color:#dc2626;border-color:#fca5a5;background:#fef2f2}.game-paused-banner{background:#fef3c7;border:2px solid #f59e0b;color:#92400e;padding:.75rem 1rem;border-radius:4px;font-weight:600;text-align:center;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap;animation:fadeIn .3s ease}.game-paused-banner button{background:#dc2626;color:#fff;border:3px solid #b91c1c;font-size:.58rem;padding:.35rem .75rem;min-height:0}.game-paused-banner button:hover:not(:disabled){background:#b91c1c}.lobby-card{text-align:center}.lobby-card h1{margin-bottom:.25rem}.lobby-card h3{text-align:left;margin-top:1.25rem;margin-bottom:.25rem}.lobby-dice-strip{display:flex;justify-content:center;gap:.6rem;margin-bottom:.75rem}.lobby-die{width:2.6rem;height:2.6rem;border-radius:3px}.landing-tagline{font-family:var(--font-pixel);font-size:.45rem;color:#64748b;margin:0 0 .75rem;text-align:center;line-height:2.6}.lobby-color-bar{display:flex;justify-content:center;gap:.4rem;margin-bottom:.75rem}.lobby-color-dot{width:8px;height:8px;border-radius:2px;display:inline-block}.lobby-code-display{margin-bottom:1rem}.lobby-code-display .label{font-size:.85rem;color:#64748b;margin-bottom:.4rem}.lobby-code-box{display:inline-flex;align-items:center;gap:.5rem;border:3px solid #cbd5e1;border-radius:4px;padding:.4rem .5rem .4rem 1rem;background:#f8fafc}.lobby-code-text{font-family:var(--font-pixel);font-size:1.05rem;font-weight:700;letter-spacing:.15em;color:#1e293b}.player-name-row{display:flex;align-items:center;gap:.4rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0;white-space:nowrap}.player-actions button{font-size:.52rem;padding:.2rem .5rem;min-height:0}.player-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.landing-about{text-align:left}.landing-about h2{font-size:.7rem;margin:0 0 .5rem}.landing-about h3{font-size:.65rem;margin:1.25rem 0 .4rem}.landing-about p{font-size:.9rem;color:#475569;line-height:1.6;margin:0 0 .5rem}.how-it-works,.feature-list{padding-left:1.25rem;margin:.25rem 0 0;font-size:.9rem;color:#475569;line-height:1.8}.how-to-play-page{text-align:left}.how-to-play-page h1{font-size:.92rem;margin-bottom:.5rem}.how-to-play-page h2{font-size:.7rem;margin:1.75rem 0 .5rem;padding-top:1rem;border-top:2px solid #cbd5e1}.how-to-play-page h2:first-of-type{border-top:none;padding-top:0}.how-to-play-page h3{font-size:.65rem;margin:1rem 0 .35rem}.how-to-play-page p,.how-to-play-page li,.how-to-play-page dd{font-size:.9rem;color:#475569;line-height:1.7}.how-to-play-page ol,.how-to-play-page ul{padding-left:1.25rem;margin:.25rem 0 .5rem}.htp-intro{font-size:1rem!important;color:#334155!important;margin-bottom:1rem}.htp-steps li{margin-bottom:.35rem}.back-link{font-family:var(--font-pixel);display:inline-block;font-size:.58rem;color:#0d9488;text-decoration:none;margin-bottom:1rem;line-height:2.5}.back-link:hover{text-decoration:underline}.scoring-table-wrap{overflow-x:auto;margin:.5rem 0}.scoring-table{border-collapse:collapse;font-size:.85rem;width:100%}.scoring-table th,.scoring-table td{border:2px solid #cbd5e1;padding:.35rem .5rem;text-align:center}.scoring-table th{background:#f8fafc;font-weight:600;color:#1e293b}.scoring-table td{color:#475569}.faq-list{margin:.5rem 0}.faq-list dt{font-weight:600;color:#1e293b;margin-top:.75rem;font-size:.9rem}.faq-list dd{margin:.2rem 0 0}.htp-cta{text-align:center;margin-top:2rem;padding-top:1.25rem;border-top:2px solid #cbd5e1}.htp-play-btn{font-family:var(--font-pixel);display:inline-block;text-decoration:none;padding:.75rem 2rem;font-size:.65rem;font-weight:600;border-radius:3px;border:3px solid #0a7a70;line-height:2.5}.footer a{color:#0d9488;text-decoration:none}.footer a:hover{text-decoration:underline}
