.room-view{box-sizing:border-box;width:100%;min-height:100vh;background:linear-gradient(180deg,#2a1f2f,#1a1422 60%);color:#f5f5f0;display:flex;flex-direction:column;align-items:stretch;padding:24px;font-family:inherit}.room-view[data-in-room=true][data-phase=in_game]{padding:0;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.room-header{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:32px;position:relative}.room-header[data-mode=compact]{margin-bottom:16px;min-height:40px}.room-identity-corner{position:absolute;top:0;right:0}.room-title{margin:0;font-size:28px;color:#f0c040;letter-spacing:.05em}.room-subtitle{margin:0;font-size:13px;color:#9a8ab8}.room-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:24px;max-width:720px;margin:0 auto;width:100%}.room-body[data-mode=game]{max-width:none;margin:0;padding:0;align-items:stretch;justify-content:center}.room-placeholder{max-width:480px;text-align:center;padding:24px;border:1px dashed #5A7A9A;border-radius:8px;background:#2a2a2a73;color:#c0bfc0;font-size:14px;line-height:1.5}.room-placeholder code{background:#1f1828;color:#f0c040;padding:1px 6px;border-radius:3px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.identity-panel{box-sizing:border-box;width:100%;max-width:480px;margin:0 auto;padding:18px 20px;background:#2a2a2a8c;border:1px solid #3A3A3A;border-radius:10px;color:#f5f5f0;display:flex;flex-direction:column;gap:16px}.identity-heading{margin:0;font-size:14px;font-weight:700;color:#c0bfc0;text-transform:uppercase;letter-spacing:.06em}.identity-row{display:flex;align-items:flex-start;gap:16px}.identity-fields{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.identity-label{font-size:12px;color:#9a8ab8;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.identity-name-input{width:100%;box-sizing:border-box;min-height:44px;padding:8px 12px;background:#1f1828;color:#f5f5f0;border:1px solid #5A5A5A;border-radius:6px;font-family:inherit;font-size:15px}.identity-name-input:focus{outline:2px solid #F0C040;outline-offset:1px;border-color:#f0c040}.identity-name-input[aria-invalid=true]{border-color:#e03048}.identity-name-error{color:#e03048;font-size:12px;font-weight:600}.identity-counter{color:#5a7a9a;font-size:11px;text-align:right}.identity-colors{border:0;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.identity-color-row{display:flex;flex-wrap:wrap;gap:10px}.identity-color-swatch{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;border:2px solid transparent;padding:0;cursor:pointer;box-shadow:inset 0 1px #ffffff2e,0 1px 2px #00000059}.identity-color-swatch:focus-visible{outline:2px solid #F0C040;outline-offset:3px}.identity-color-swatch.selected{border-color:#f5f5f0;box-shadow:0 0 0 2px #1a1422,0 0 0 4px #f0c040}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.identity-loading{color:#9a8ab8;font-size:13px;text-align:center}.identity-badge{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;background:#2a2a2ab3;border:1px solid #3A3A3A;border-radius:999px;color:#f5f5f0;font-family:inherit;font-size:13px;cursor:pointer;transition:border-color .12s ease,background-color .12s ease}.identity-badge:hover,.identity-badge:focus-visible{border-color:#f0c040;background:#3a3a3ad9;outline:none}.identity-badge-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.identity-modal-backdrop{position:fixed;inset:0;background:#0a0810b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.identity-modal{width:100%;max-width:480px;background:#1a1422;border:1px solid #3A3A3A;border-radius:12px;box-shadow:0 24px 48px #00000080;color:#f5f5f0;padding:20px 22px;display:flex;flex-direction:column;gap:16px}.identity-modal-header{display:flex;align-items:center;justify-content:space-between}.identity-modal-title{margin:0;font-size:16px;color:#f0c040;letter-spacing:.05em;text-transform:uppercase}.identity-modal-close{background:transparent;border:0;color:#c0bfc0;font-size:24px;line-height:1;cursor:pointer;padding:4px 10px;border-radius:6px}.identity-modal-close:hover,.identity-modal-close:focus-visible{color:#f5f5f0;background:#ffffff0f;outline:none}.identity-modal-footer{display:flex;justify-content:flex-end}.identity-modal-done{min-width:96px;padding:10px 18px;background:#3dba52;border:0;border-radius:8px;color:#0a0810;font-family:inherit;font-weight:700;font-size:14px;cursor:pointer}.identity-modal-done:hover,.identity-modal-done:focus-visible{filter:brightness(1.08);outline:2px solid #F0C040;outline-offset:2px}.room-occupant-kick{margin-left:auto;min-height:36px;padding:6px 12px;background:transparent;color:#e03048;border:1px solid #E03048;border-radius:6px;font-family:inherit;font-size:12px;font-weight:700;letter-spacing:.04em;cursor:pointer}.room-occupant-kick:hover{background:#e030482e}.room-occupant-kick:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.room-removed-banner{padding:14px 18px;background:#e030482e;border:1px solid #E03048;border-radius:8px;color:#f5f5f0;font-weight:700;text-align:center}.room-occupant-ready{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:13px;font-weight:700;line-height:1;user-select:none}.room-occupant-ready.ready{color:#3dba52}.room-occupant-ready.not-ready{color:#5a5a5a}.room-settings{box-sizing:border-box;width:100%;max-width:480px;margin:0 auto;padding:18px 20px;background:#2a2a2a73;border:1px solid #3A3A3A;border-radius:10px;color:#f5f5f0;display:flex;flex-direction:column;gap:14px}.room-settings.readonly{background:#1f182873}.room-settings-heading{margin:0;font-size:13px;font-weight:700;color:#c0bfc0;text-transform:uppercase;letter-spacing:.06em}.room-settings-group{display:flex;flex-direction:column;gap:6px;border:0;margin:0;padding:0}.room-settings-label{font-size:12px;color:#9a8ab8;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.room-settings-radio-row{display:flex;gap:16px;flex-wrap:wrap}.room-settings-radio{display:inline-flex;align-items:center;gap:8px;min-height:44px;padding:6px 12px;cursor:pointer}.room-settings-radio input{width:18px;height:18px;accent-color:#F0C040;cursor:pointer}.room-settings-radio input:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.room-settings-select{width:100%;min-height:44px;padding:8px 12px;background:#1f1828;color:#f5f5f0;border:1px solid #5A5A5A;border-radius:6px;font-family:inherit;font-size:15px;cursor:pointer}.room-settings-select:focus{outline:2px solid #F0C040;outline-offset:1px;border-color:#f0c040}.room-settings-toggle{display:inline-flex;align-items:center;gap:10px;min-height:44px;cursor:pointer}.room-settings-toggle input{width:20px;height:20px;accent-color:#3DBA52;cursor:pointer}.room-settings-toggle input:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.room-settings-readonly-list{margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.room-settings-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px dashed #3A3A3A}.room-settings-row:last-child{border-bottom:0}.room-settings-row dt{color:#9a8ab8;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.room-settings-row dd{margin:0;color:#f5f5f0;font-weight:700}.start-game-wrap{display:flex;flex-direction:column;gap:6px;align-items:stretch}.start-game-button{min-height:56px;padding:14px 18px;background:#f0a030;color:#1a1422;border:none;border-radius:8px;font-family:inherit;font-size:17px;font-weight:800;cursor:pointer;letter-spacing:.04em}.start-game-button:hover:not(:disabled){background:#f8b040}.start-game-button:disabled,.start-game-button[aria-disabled=true]{background:#5a5a5a;color:#c0bfc0;cursor:not-allowed;opacity:.75}.start-game-button:focus-visible{outline:2px solid #F0C040;outline-offset:3px}.start-game-reason{margin:0;font-size:12px;color:#f0a030;text-align:center}.game-starting-placeholder{box-sizing:border-box;width:100%;max-width:560px;margin:24px auto 0;padding:32px 24px;background:#1f1828bf;border:2px dashed #F0A030;border-radius:12px;color:#f5f5f0;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}.game-starting-title{margin:0;font-size:22px;color:#f0c040;letter-spacing:.04em}.game-starting-line{margin:0;font-size:14px;color:#c0bfc0}.game-starting-placeholder-tag{margin:0;font-size:12px;color:#f0a030;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.game-starting-return{margin-top:8px;min-height:44px;padding:8px 16px;background:transparent;color:#9a8ab8;border:1px solid #5A5A5A;border-radius:6px;font-family:inherit;font-size:12px;cursor:pointer}.game-starting-return:hover{border-color:#f0c040;color:#f0c040}.game-starting-return:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.networked-game-view{display:flex;flex-direction:column;gap:12px;align-items:center;width:100%}.networked-game-header{display:flex;align-items:center;gap:12px;font-family:inherit;color:var(--text-primary, #F5F5F0);width:100%;max-width:1024px;padding:12px 16px;box-sizing:border-box}.networked-game-header-spacer{flex:1}.networked-game-status{font-weight:600;font-size:14px}.networked-game-toast{background:#dc3c3c2e;color:#f5c0c0;padding:4px 12px;border-radius:4px;font-size:12px;border:1px solid rgba(220,60,60,.45)}.networked-game-leave{background:transparent;color:#f5f5f0;border:1px solid #5A7A9A;border-radius:6px;padding:6px 14px;font-family:inherit;font-size:13px;cursor:pointer}.networked-game-leave:hover,.networked-game-leave:focus-visible{border-color:#f0c040;outline:none}.networked-end-of-hand{display:flex;justify-content:center}.bid-timer-bar{position:relative;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden;margin-top:6px}.bid-timer-bar__fill{height:100%;background:linear-gradient(90deg,#3dba52,#f0a030 60%,#dc3030);transition:width 80ms linear}.ready-toggle{align-self:stretch;min-height:44px;padding:10px 18px;border-radius:8px;font-family:inherit;font-size:14px;font-weight:700;letter-spacing:.04em;cursor:pointer;border:2px solid #5A5A5A;background:transparent;color:#c0bfc0;transition:background-color .12s ease,color .12s ease,border-color .12s ease}.ready-toggle.not-ready{border-color:#5a5a5a;color:#c0bfc0;background:#2a2a2a59}.ready-toggle.ready{border-color:#3dba52;color:#1a1422;background:#3dba52}.ready-toggle.ready:hover{background:#4dce65}.ready-toggle.not-ready:hover{border-color:#c0bfc0;color:#f5f5f0}.ready-toggle:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.start-game-button.all-ready{box-shadow:0 0 0 3px #f0c040,0 0 0 6px #f0c04059}.room-lobby{box-sizing:border-box;width:100%;max-width:480px;margin:0 auto;padding:18px 20px;background:#2a2a2a8c;border:1px solid #3A3A3A;border-radius:10px;color:#f5f5f0;display:flex;flex-direction:column;gap:16px}.room-lobby.in-room{background:#1f1828b3;border-color:#5a7a9a}.room-lobby.in-game{max-width:none;background:transparent;border:0;padding:0;margin:0;gap:0;width:100%;align-items:center}.room-lobby-actions{display:flex;gap:12px;flex-wrap:wrap}.room-cta{flex:1;min-width:0;min-height:48px;padding:12px 16px;border-radius:8px;border:none;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer}.room-cta.create{background:#3dba52;color:#1a1422}.room-cta.create:hover:not(:disabled){background:#4dce65}.room-cta.join{background:transparent;color:#f5f5f0;border:1px solid #5A7A9A}.room-cta.join:hover:not(:disabled){background:#5a7a9a2e}.room-cta:disabled,.room-cta[aria-disabled=true]{opacity:.5;cursor:not-allowed}.room-cta:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.room-lobby-hint{margin:0;color:#9a8ab8;font-size:12px;text-align:center}.room-join-form{display:flex;flex-direction:column;gap:8px;padding-top:8px;border-top:1px dashed #3A3A3A}.room-join-label{font-size:12px;color:#9a8ab8;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.room-join-input{width:100%;box-sizing:border-box;min-height:44px;padding:8px 12px;background:#1f1828;color:#f0c040;border:1px solid #5A5A5A;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:22px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;text-align:center}.room-join-input:focus{outline:2px solid #F0C040;outline-offset:1px;border-color:#f0c040}.room-join-input[aria-invalid=true]{border-color:#e03048}.room-join-submit{align-self:flex-end;min-height:44px;padding:10px 20px;background:#5a7a9a;color:#1a1422;border:none;border-radius:6px;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}.room-join-submit:disabled{opacity:.5;cursor:not-allowed}.room-join-submit:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.room-join-error{color:#e03048;font-size:13px;font-weight:600}.room-code{display:flex;flex-direction:column;gap:6px;align-items:center;padding:12px 16px;background:#1f1828d9;border:1px solid #5A7A9A;border-radius:8px}.room-code-label{font-size:11px;color:#9a8ab8;text-transform:uppercase;letter-spacing:.08em}.room-code-row{display:flex;align-items:center;gap:12px}.room-code-value{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:32px;letter-spacing:.1em;color:#f0c040;user-select:all}.room-code-copy{min-height:44px;min-width:70px;padding:8px 14px;background:#5a7a9a;color:#1a1422;border:none;border-radius:6px;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer}.room-code-copy:focus-visible{outline:2px solid #F0C040;outline-offset:2px}.room-occupants{display:flex;flex-direction:column;gap:10px}.room-occupants-heading{margin:0;font-size:13px;font-weight:700;color:#c0bfc0;text-transform:uppercase;letter-spacing:.06em}.room-occupants-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.room-occupant{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#1a142299;border:1px solid transparent;border-radius:6px}.room-occupant.is-you{border-color:#f0c040}.room-occupant-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.room-occupant-name-row{display:flex;align-items:center;gap:6px}.room-occupant-name{font-weight:700;color:#f5f5f0}.is-you .room-occupant-name{color:#f0c040}.room-occupant-badge{font-size:10px;color:#1a1422;background:#f0c040;padding:1px 6px;border-radius:8px;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.room-occupant-host{font-size:16px;color:#f0c040}.room-occupant-status{display:flex;align-items:center;gap:6px;font-size:11px;color:#9a8ab8}.room-occupant-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.room-occupant-status-label{text-transform:uppercase;letter-spacing:.05em}.room-leave{align-self:flex-end;min-height:44px;padding:10px 16px;background:transparent;color:#c0bfc0;border:1px solid #5A5A5A;border-radius:6px;font-family:inherit;font-size:13px;cursor:pointer}.room-leave:hover{border-color:#e03048;color:#e03048}.room-leave:focus-visible{outline:2px solid #F0C040;outline-offset:2px}html.crt-subtle:before,html.crt-full:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9000;background-image:repeating-linear-gradient(to bottom,rgba(0,0,0,.15) 0,rgba(0,0,0,.15) 1px,transparent 1px,transparent 2px)}html.crt-subtle:after,html.crt-full:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9001;background:radial-gradient(ellipse at center,#0000 55%,#0006)}html.crt-full body{text-shadow:0 0 2px rgba(255,255,255,.8),0 0 8px rgba(100,120,255,.15)}@keyframes crt-flicker{0%,to{opacity:1}47%{opacity:1}48%{opacity:.98}49%{opacity:1}50%{opacity:.99}51%{opacity:1}}html.crt-full:before{animation:crt-flicker .25s infinite}@media (prefers-reduced-motion: reduce){html.crt-full:before{animation:none}}@media (prefers-contrast: more){html.crt-subtle:after,html.crt-full:after{display:none}html.crt-full body{text-shadow:none}}
