:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;width:100vw;height:100vh;overflow:hidden}#root{width:100%;height:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#222}a:hover{color:#747bff}button{background-color:#f9f9f9}}.hold-button{position:relative;overflow:hidden;cursor:pointer;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;touch-action:manipulation}.hold-button-content{position:relative;z-index:2;pointer-events:none}.hold-button-progress{position:absolute;left:0;top:0;bottom:0;background-color:#ffffff4d;z-index:1;transition:width 0ms linear;pointer-events:none}.hold-button.holding{opacity:.9}#sidebar{position:absolute;top:0;left:0;width:220px;max-height:100%;padding:1em;background:#1e1e1e99;-webkit-user-select:none;user-select:none;overflow-y:auto;z-index:100}.sidebar-content{display:flex;flex-direction:column;gap:.75rem}.btn{padding:.5rem 1rem;background:#666;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.btn:hover{background:#777}.btn-deal{background:#ffc107;color:#000;font-weight:700;font-size:16px;padding:.75rem}.btn-deal:hover{background:#ffcd38}.setup-section,.settings-section{display:flex;flex-direction:column;gap:.5rem}.btn-setup-toggle,.btn-more-toggle{background:#444}.setup-controls,.settings-controls{display:flex;flex-direction:column;gap:.5rem;padding:.5rem;background:#0000004d;border-radius:4px}.select-control{padding:.4rem;background:#333;color:#fff;border:1px solid #555;border-radius:4px;font-size:13px}.points-row{display:flex;gap:.5rem}.btn-row{display:flex;gap:.5rem;margin-top:.5rem}.btn-secondary{background:#555}.btn-secondary:hover{background:#666}.points-row .select-control{flex:1}.btn-reset{background:#444;flex-shrink:0}.dealer-honba-row{display:flex;gap:.5rem}.dealer-honba-row .btn{flex:1;background:#666}.settings-controls label{display:flex;align-items:center;gap:.5rem;font-size:13px;color:#ccc;cursor:pointer;padding:.25rem 0}.settings-controls input[type=checkbox]{cursor:pointer}.instructions{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #444}.instructions h4{font-size:14px;margin-bottom:.5rem;color:#ffc107}.instructions p{font-size:12px;line-height:1.6;margin:0;color:#ccc}.instructions b{color:#fff}#sidebar::-webkit-scrollbar{width:8px}#sidebar::-webkit-scrollbar-track{background:#0000004d}#sidebar::-webkit-scrollbar-thumb{background:#555;border-radius:4px}#sidebar::-webkit-scrollbar-thumb:hover{background:#666}.help-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.help-content{background:#2a2a2a;border:2px solid #444;border-radius:8px;max-width:800px;max-height:90vh;width:90%;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080}.help-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #444;background:#333;border-radius:6px 6px 0 0}.help-header h2{margin:0;color:#fff;font-size:1.5rem;font-weight:600}.help-close{background:transparent;border:none;color:#aaa;font-size:2rem;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:color .2s}.help-close:hover{color:#fff}.help-body{flex:1;overflow-y:auto;padding:2rem;color:#e0e0e0}.help-section{margin-bottom:2rem}.help-section:last-child{margin-bottom:0}.help-section h3{color:#ff9;font-size:1.2rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #444}.help-table{width:100%;border-collapse:collapse}.help-table tr{border-bottom:1px solid #3a3a3a}.help-table tr:last-child{border-bottom:none}.help-table td{padding:.75rem 1rem}.help-key{font-family:Monaco,Courier New,monospace;font-weight:600;color:#ff9;white-space:nowrap;width:200px;background:#333;border-radius:4px}.help-desc{color:#ccc}.help-footer{padding:1.5rem 2rem;border-top:2px solid #444;background:#333;border-radius:0 0 6px 6px;text-align:center}.help-close-button{background:#555;border:1px solid #666;color:#fff;padding:.5rem 2rem;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.help-close-button:hover{background:#666}.help-body::-webkit-scrollbar{width:8px}.help-body::-webkit-scrollbar-track{background:#222}.help-body::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.help-body::-webkit-scrollbar-thumb:hover{background:#666}.performance-stats{position:fixed;top:1rem;left:1rem;background:#000000d9;border:1px solid #444;border-radius:6px;padding:1rem;z-index:1000;font-family:Monaco,Courier New,monospace;font-size:.875rem;min-width:200px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0000004d}.performance-header{color:#ff9;font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #444}.performance-row{display:flex;justify-content:space-between;margin-bottom:.5rem;color:#fff}.performance-label{color:#aaa}.performance-value{color:#4caf50;font-weight:600}.performance-warn{color:#ff9800!important}.performance-hint{margin-top:.75rem;padding-top:.5rem;border-top:1px solid #444;color:#666;font-size:.75rem;text-align:center}.game-panel{position:fixed;bottom:1rem;left:1rem;background:#000000d9;border:1px solid #444;border-radius:8px;min-width:280px;max-width:320px;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 4px 12px #0006;overflow:hidden}.game-panel-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #444}.connection-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-disconnected .connection-indicator{background:#888}.status-connecting .connection-indicator{background:orange;animation:pulse 2s ease-in-out infinite}.status-connected .connection-indicator{background:#4caf50;animation:pulse 2s ease-in-out infinite}.connection-text{color:#fff;font-size:.875rem;font-weight:600;flex:1}.game-panel-section{padding:1rem;border-bottom:1px solid #333}.game-panel-section:last-child{border-bottom:none}.game-panel-nickname-row{display:flex;gap:.5rem;margin-bottom:.5rem}.game-panel-nickname{flex:1;padding:.5rem;background:#ffffff14;border:1px solid #555;border-radius:4px;color:#fff;font-size:.875rem;font-family:inherit}.game-panel-nickname-submit{flex-shrink:0;min-width:40px;padding:.5rem}.game-panel-nickname::placeholder{color:#888}.game-panel-nickname:focus{outline:none;border-color:#ff9;background:#ffffff1f}.game-panel-buttons{display:flex;gap:.5rem}.game-panel-button{flex:1;padding:.5rem 1rem;background:#ffffff1a;border:1px solid #666;border-radius:4px;color:#fff;cursor:pointer;font-size:.875rem;transition:all .2s;font-weight:500}.game-panel-button:hover{background:#fff3;border-color:#888}.game-panel-button:active{transform:scale(.98)}.game-panel-status{margin-top:.5rem;padding:.5rem;background:#ffa50026;border:1px solid rgba(255,165,0,.3);border-radius:4px;color:orange;font-size:.75rem;text-align:center}.game-panel-subheader{color:#ff9;font-weight:600;font-size:.875rem;margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between}.player-edit-nickname-button{background:transparent;border:1px solid #666;color:#ff9;padding:.25rem .5rem;border-radius:3px;font-size:.875rem;cursor:pointer;transition:all .2s}.player-edit-nickname-button:hover{background:#ffff991a;border-color:#ff9}.player-nickname-edit{margin-bottom:.75rem}.player-nickname-input{width:100%;background:#00000080;border:1px solid #666;color:#fff;padding:.5rem;border-radius:4px;font-size:.875rem;font-family:inherit}.player-nickname-input:focus{outline:none;border-color:#ff9;background:#000000b3}.player-row{display:flex;align-items:center;gap:.5rem;padding:.5rem;margin-bottom:.5rem;border-radius:4px;background:#0000004d;transition:background .2s}.player-row:last-of-type{margin-bottom:0}.player-row:hover{background:#00000080}.player-current{background:#ffff991a!important;border:1px solid rgba(255,255,153,.3)}.player-empty{opacity:.6}.player-seat-indicator{width:45px;height:28px;display:flex;align-items:center;justify-content:center;background:#222;border-radius:4px;font-size:.7rem;font-weight:600;flex-shrink:0}.player-seat-indicator[data-seat="0"]{color:#4caf50}.player-seat-indicator[data-seat="1"]{color:#f44336}.player-seat-indicator[data-seat="2"]{color:#fff}.player-seat-indicator[data-seat="3"]{color:#2196f3}.player-nickname{flex:1;color:#fff;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-status{font-size:.75rem;flex-shrink:0}.status-online{color:#4caf50}.status-offline{color:#888}.player-dealer-badge{background:orange;color:#000;padding:.125rem .4rem;border-radius:3px;font-size:.625rem;font-weight:600;text-transform:uppercase;flex-shrink:0}.player-take-seat-button{background:#555;border:1px solid #666;color:#fff;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;cursor:pointer;transition:background .2s;flex:1}.player-take-seat-button:hover{background:#666}.player-leave-button{width:100%;background:#c62828;border:1px solid #d32f2f;color:#fff;padding:.5rem;border-radius:4px;font-size:.875rem;cursor:pointer;margin-top:.75rem;transition:background .2s;font-weight:600}.player-leave-button:hover{background:#d32f2f}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.remote-cursor{position:absolute;width:20px;height:20px;border:2px solid;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:500;visibility:hidden}.remote-cursor-label{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;padding:2px 6px;border-radius:3px;font-size:.625rem;font-weight:600;color:#000;white-space:nowrap;box-shadow:0 2px 4px #0000004d}.remote-cursor.seat-0{border-color:#4caf50}.remote-cursor.seat-1{border-color:#f44336}.remote-cursor.seat-2{border-color:#fff}.remote-cursor.seat-3{border-color:#2196f3}.app-container{position:fixed;inset:0;background-color:#222}.scene-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:100vh;overflow:hidden;cursor:default}.scene-container.hovering{cursor:pointer}.scene-container.dragging{cursor:grabbing!important}.loading-overlay,.error-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#000000b3;color:#fff;font-size:1.5rem;z-index:1000}.error-overlay{background-color:#8b0000cc}#selection{position:absolute;border:2px solid rgba(255,255,153,.8);background:#ffff991a;pointer-events:none;visibility:hidden;z-index:100}.scene-container.selecting{cursor:crosshair}
