.mode-select{max-width:500px;margin:0 auto;padding:2rem;text-align:center}.mode-select h1{font-size:2.5rem;margin-bottom:1rem;color:#646cff}.mode-select-description{font-size:1.2rem;color:#ffffffb3;margin-bottom:2rem}.mode-buttons{display:flex;flex-direction:column;gap:1.5rem}.mode-button{display:flex;flex-direction:column;align-items:center;padding:1.5rem 2rem;border:2px solid #444;border-radius:12px;background-color:#2a2a2a;cursor:pointer;transition:all .2s ease}.mode-button:hover{border-color:#646cff;background-color:#3a3a3a;transform:translateY(-2px)}.mode-icon{font-size:3rem;margin-bottom:.5rem}.mode-title{font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:.3rem}.mode-description{font-size:.95rem;color:#fff9}.local-button:hover{border-color:#4caf50}.online-button:hover{border-color:#2196f3}.ai-button:hover{border-color:#ff9800}.about-button{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:2rem;padding:.75rem 1.5rem;border:2px solid #444;border-radius:8px;background-color:transparent;color:#ffffffb3;font-size:1rem;cursor:pointer;transition:all .2s ease}.about-button:hover{border-color:#646cff;color:#fff;background-color:#646cff1a}.about-icon{font-size:1.2rem}.streaming-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:2rem;padding:.75rem 1rem;color:#ffffff80;font-size:.85rem}.streaming-icon{font-size:1rem}@media (max-width: 600px){.mode-select{padding:1rem}.mode-select h1{font-size:2rem}.mode-button{padding:1.2rem 1.5rem}.mode-icon{font-size:2.5rem}.mode-title{font-size:1.2rem}.streaming-footer{font-size:.75rem}}.about-dialog{border:2px solid #646cff;border-radius:12px;padding:0;max-width:500px;width:90%;background-color:#1a1a1a;box-shadow:0 8px 32px #00000080;margin:auto}.about-dialog::backdrop{background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.about-dialog-content{padding:0}.about-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #444}.about-dialog-header h2{margin:0;font-size:1.5rem;color:#646cff}.about-dialog .close-button{background:none;border:none;font-size:2rem;color:#fff9;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.about-dialog .close-button:hover{background-color:#2a2a2a;color:#ffffffde}.about-dialog-body{padding:1.5rem;text-align:center}.about-carousel{display:flex;align-items:center;justify-content:center;gap:1rem;min-height:200px}.nav-arrow{background:none;border:none;font-size:1.5rem;color:#646cff;cursor:pointer;padding:.5rem;transition:opacity .2s,transform .2s;flex-shrink:0}.nav-arrow:hover:not(:disabled){transform:scale(1.2)}.nav-arrow:disabled{opacity:.3;cursor:not-allowed}.about-page{flex:1;display:flex;flex-direction:column;align-items:center;gap:.75rem;max-width:300px}.about-emoji{font-size:4rem;line-height:1}.about-page-title{margin:0;font-size:1.3rem;color:#fff;font-weight:700}.about-page-description{margin:0;font-size:.95rem;color:#fffc;line-height:1.6}.page-indicators{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem}.indicator{width:10px;height:10px;border-radius:50%;border:2px solid #646cff;background:transparent;cursor:pointer;padding:0;transition:background-color .2s}.indicator:hover{background-color:#646cff80}.indicator.active{background-color:#646cff}.about-dialog-footer{padding:1rem 1.5rem 1.5rem;display:flex;justify-content:center}.close-dialog-button{padding:.75rem 2rem;border:none;border-radius:8px;background-color:#646cff;color:#fff;font-size:1rem;cursor:pointer;transition:background-color .2s}.close-dialog-button:hover{background-color:#535bf2}@media (max-width: 600px){.about-dialog{max-width:95%}.about-dialog-header,.about-dialog-body{padding:1rem}.about-carousel{gap:.5rem;min-height:180px}.nav-arrow{font-size:1.2rem;padding:.25rem}.about-emoji{font-size:3rem}.about-page-title{font-size:1.1rem}.about-page-description{font-size:.9rem}.about-dialog-footer{padding:.75rem 1rem 1rem}}.rule-dialog{border:2px solid #646cff;border-radius:12px;padding:0;max-width:600px;width:90%;background-color:#1a1a1a;box-shadow:0 8px 32px #00000080;margin:auto}.rule-dialog::backdrop{background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rule-dialog-content{padding:0}.rule-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #444}.rule-dialog-header h2{margin:0;font-size:1.5rem;color:#646cff}.close-button{background:none;border:none;font-size:2rem;color:#fff9;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background-color:#2a2a2a;color:#ffffffde}.rule-dialog-body{padding:1.5rem;text-align:left}.rule-dialog-body ul{margin:0;padding-left:1.5rem;list-style-type:disc;line-height:1.8}.rule-dialog-body li{margin-bottom:.75rem;line-height:1.8;color:#ffffffde}.rule-dialog-body li:last-child{margin-bottom:0}.emoji-history-dialog{border:2px solid #646cff;border-radius:12px;padding:0;max-width:500px;width:90%;max-height:80vh;background-color:#1a1a1a;box-shadow:0 8px 32px #00000080;margin:auto;overflow:hidden}.emoji-history-dialog::backdrop{background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.emoji-history-dialog-content{padding:0;display:flex;flex-direction:column;max-height:inherit;overflow:hidden}.emoji-history-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #444}.emoji-history-dialog-header h2{margin:0;font-size:1.5rem;color:#646cff}.emoji-history-dialog .close-button{background:none;border:none;font-size:2rem;color:#fff9;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.emoji-history-dialog .close-button:hover{background-color:#2a2a2a;color:#ffffffde}.emoji-history-dialog-body{padding:1.5rem;text-align:left;overflow-y:auto;flex:1;min-height:0}.emoji-history-dialog-body h3{margin:0 0 1rem;font-size:1.1rem;color:#ffffffde}.no-history{color:#ffffff80;text-align:center;padding:2rem}.emoji-history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;background-color:#2a2a2a}.history-emoji{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem}.history-emoji img{width:1.5rem;height:1.5rem}.history-labels{flex:1;display:flex;flex-direction:column;gap:.25rem}.history-label-en{font-size:.95rem;color:#ffffffde}.history-label-ja{font-size:.85rem;color:#ffffff80}.emoji-history-dialog-footer{padding:1.5rem;border-top:1px solid #444;display:flex;justify-content:center}.rematch-button{background-color:#646cff;color:#fff;border:none;padding:.75rem 2rem;font-size:1rem;border-radius:8px;cursor:pointer;transition:background-color .2s}.rematch-button:hover:not(:disabled){background-color:#535bf2}.rematch-button:disabled{background-color:#444;cursor:not-allowed}.online-lobby{max-width:500px;margin:0 auto;padding:2rem;text-align:center}.online-lobby h1{font-size:2.5rem;margin-bottom:2rem;color:#646cff}.online-lobby h2{font-size:1.3rem;margin-bottom:.5rem;color:#fff}.network-notice{background-color:#ffc10726;border:1px solid rgba(255,193,7,.5);color:#ffc107;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;line-height:1.4}.error-message{background-color:#f4433633;border:1px solid #f44336;color:#f44336;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.lobby-options{background-color:#2a2a2a;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.lobby-option{padding:1rem 0}.lobby-option p{color:#fff9;margin-bottom:1rem;font-size:.95rem}.divider{display:flex;align-items:center;margin:1rem 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background-color:#444}.divider span{padding:0 1rem;color:#ffffff80;font-size:.9rem}.play-order-section{margin-bottom:1rem}.play-order-section label{display:block;margin-bottom:.5rem;font-size:.95rem;color:#fffc}.play-order-buttons{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.play-order-btn{padding:.5rem 1rem;border:2px solid #444;border-radius:6px;background-color:#1a1a1a;color:#fff;cursor:pointer;transition:all .2s ease;font-size:.9rem;white-space:nowrap}.play-order-btn:hover{border-color:#646cff;background-color:#2a2a2a}.play-order-btn.selected{border-color:#646cff;background-color:#646cff;color:#fff}.create-button,.join-button{padding:.8rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.create-button{background-color:#4caf50;color:#fff;width:100%}.create-button:hover:not(:disabled){background-color:#45a049}.create-button:disabled{opacity:.6;cursor:not-allowed}.join-form{display:flex;gap:.5rem}.join-form input{flex:1;padding:.8rem 1rem;font-size:1.3rem;font-family:monospace;letter-spacing:.1rem;border:2px solid #444;border-radius:8px;background-color:#1a1a1a;color:#fff;text-align:center;max-width:350px}.join-form input:focus{outline:none;border-color:#646cff}.join-form input::placeholder{color:#ffffff4d;font-size:1rem}.join-button{background-color:#2196f3;color:#fff;white-space:nowrap}.join-button:hover:not(:disabled){background-color:#1976d2}.join-button:disabled{opacity:.6;cursor:not-allowed}.back-button{padding:.6rem 1.5rem;font-size:1rem;background-color:#444;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.back-button:hover{background-color:#555}.waiting-room{background-color:#2a2a2a;border-radius:12px;padding:2rem;margin-bottom:1.5rem}.qr-code-container{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:1rem}.qr-code-container svg{padding:12px;background-color:#fff;border-radius:12px}.qr-message{font-size:.9rem;color:#ffffffb3}.waiting-room .divider{margin:1.5rem 0}.waiting-message{font-size:1.2rem;color:#fff;margin-bottom:1.5rem}.room-id-display{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem}.room-id-label{font-size:.9rem;color:#fff9}.room-id-value{font-size:2rem;font-family:monospace;font-weight:700;color:#646cff;letter-spacing:.15rem;word-break:break-all;text-align:center}.copy-buttons{display:flex;gap:.5rem;justify-content:center}.copy-button{padding:.4rem 1rem;font-size:.9rem;background-color:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.copy-button:hover{background-color:#535bf2}.share-message{font-size:.95rem;color:#fff9;margin-bottom:1.5rem}.connecting{background-color:#2a2a2a;border-radius:12px;padding:3rem;margin-bottom:1.5rem}.connecting p{font-size:1.2rem;color:#fff;margin-top:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #444;border-top-color:#646cff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 600px){.online-lobby{padding:1rem}.online-lobby h1{font-size:2rem}.lobby-options{padding:1rem}.join-form{flex-direction:column}.join-form input{max-width:280px;font-size:1.1rem;margin:0 auto}.room-id-value{font-size:1.5rem}}.ai-setup{max-width:400px;margin:0 auto;padding:2rem;text-align:center}.ai-setup h2{margin-bottom:2rem;color:#646cff}.setup-section{margin-bottom:2rem}.setup-section label{display:block;margin-bottom:.75rem;font-size:1.1rem;color:#fffc}.difficulty-buttons,.order-buttons{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.difficulty-btn,.order-btn{padding:.75rem 1.5rem;border:2px solid #444;border-radius:8px;background-color:#2a2a2a;color:#fff;cursor:pointer;transition:all .2s ease;font-size:1rem;white-space:nowrap;min-width:80px}.difficulty-btn:hover,.order-btn:hover{border-color:#646cff;background-color:#3a3a3a}.difficulty-btn.selected,.order-btn.selected{border-color:#646cff;background-color:#646cff;color:#fff}.start-button{width:100%;padding:1rem 2rem;margin-top:1.5rem;margin-bottom:1rem;border:none;border-radius:8px;background-color:#4caf50;color:#fff;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .2s ease}.start-button:hover{background-color:#45a049;transform:translateY(-2px)}.ai-setup .back-button{margin-top:.5rem}.ai-thinking{color:#ffc107;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.win-text{color:#4caf50;font-weight:700}.lose-text{color:#f44336;font-weight:700}@media (max-width: 600px){.ai-setup{padding:1rem}.difficulty-btn,.order-btn{padding:.6rem 1rem;font-size:.9rem}.start-button{padding:.8rem 1.5rem;font-size:1.1rem}}.language-selector{position:absolute;top:1rem;right:1rem;z-index:100}.language-selector-button{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#ffffffde;font-size:.875rem;cursor:pointer;transition:all .2s ease}.language-selector-button:hover{background:#fff3}.language-icon{font-size:1rem}.language-name{font-weight:500}.language-arrow{font-size:.625rem;transition:transform .2s ease}.language-arrow.open{transform:rotate(180deg)}.language-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:150px;max-height:300px;overflow-y:auto;margin:0;padding:.5rem 0;background:#2a2a3e;border:1px solid rgba(255,255,255,.2);border-radius:8px;box-shadow:0 4px 12px #00000080;list-style:none}.language-dropdown::-webkit-scrollbar{width:6px}.language-dropdown::-webkit-scrollbar-track{background:transparent}.language-dropdown::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.language-option{display:block;width:100%;padding:.5rem 1rem;background:none;border:none;color:#ffffffde;font-size:.875rem;text-align:left;cursor:pointer;transition:background .2s ease}.language-option:hover{background:#ffffff26}.language-option.active{background:#6366f166;font-weight:600}.app{max-width:600px;margin:0 auto;padding:2rem;text-align:center}.online-info{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;padding:.5rem 1rem;background-color:#646cff1a;border-radius:8px;font-size:.95rem;font-family:monospace;letter-spacing:.05rem;flex-wrap:wrap}.connection-status{padding:.2rem .6rem;border-radius:4px;font-weight:600}.connection-status.connected{background-color:#4caf5033;color:#4caf50}.room-info{color:#fffc}.player-role{color:#646cff;font-weight:600}h1{font-size:2.5rem;margin-bottom:1.5rem;color:#646cff}.game-info{margin-bottom:1.5rem}.status{font-size:1.5rem;font-weight:700;margin-bottom:1rem;color:#fff}.player-text{font-weight:700}.player1-text{color:#4caf50}.player2-text{color:#f44336}.current-emoji{margin:1.5rem 0;padding:1rem;background-color:#646cff1a;border-radius:8px;border:2px solid #646cff}.emoji-display{margin-bottom:.5rem}.emoji-large{font-size:4rem;display:inline-block}.emoji-large img{width:80px;height:80px;vertical-align:middle}.emoji-label{font-size:1.2rem;color:#ffffffde;font-weight:500;text-transform:capitalize}.player-info{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem}.player-indicator{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease;opacity:.5}.player-indicator.active-player1{opacity:1;background-color:#4caf5033;border:2px solid #4caf50;font-weight:700;color:#4caf50}.player-indicator.active-player2{opacity:1;background-color:#f4433633;border:2px solid #f44336;font-weight:700;color:#f44336}.player-symbol{font-size:1.5rem;font-weight:700;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.player1-symbol{color:#4caf50;background-color:#4caf501a}.player2-symbol{color:#f44336;background-color:#f443361a}.board{display:inline-block;border:3px solid #646cff;border-radius:8px;padding:4px;background-color:#1a1a1a;margin-bottom:1.5rem}.board-row{display:flex}.cell{width:80px;height:80px;border:2px solid #444;background-color:#2a2a2a;font-size:2.5rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin:2px;border-radius:4px;position:relative}.cell img{width:50px;height:50px}.cell[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;padding:6px 12px;background-color:#000000e6;color:#fff;font-size:.875rem;white-space:nowrap;border-radius:4px;pointer-events:none;z-index:1000;animation:tooltipFadeIn .2s ease-in-out}.cell[data-tooltip]:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:2px;border:6px solid transparent;border-top-color:#000000e6;pointer-events:none;z-index:1000;animation:tooltipFadeIn .2s ease-in-out}@keyframes tooltipFadeIn{0%{opacity:0}to{opacity:1}}.cell:hover:not(.player1):not(.player2){background-color:#3a3a3a;border-color:#646cff}.cell.player1{background-color:#4caf5033;color:#4caf50;cursor:default}.cell.player2{background-color:#f4433633;color:#f44336;cursor:default}.button-group{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.reset-button,.rule-button,.result-button{font-size:1.2rem;padding:.8rem 2rem;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:background-color .2s ease;white-space:nowrap}.reset-button{background-color:#646cff}.reset-button:hover{background-color:#535bf2}.reset-button:active{background-color:#4248d4}.rule-button{background-color:#4caf50}.rule-button:hover{background-color:#45a049}.rule-button:active{background-color:#3d8b40}.result-button{background-color:#ff9800}.result-button:hover{background-color:#f57c00}.result-button:active{background-color:#e65100}.back-button{background-color:#666}.back-button:hover{background-color:#777}.back-button:active{background-color:#555}.disconnected-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;background-color:#f443361a;border:2px solid #f44336;border-radius:12px;margin-top:2rem}.disconnected-icon{font-size:4rem;margin-bottom:1rem}.disconnected-screen h2{color:#f44336;margin-bottom:.5rem;font-size:1.8rem}.disconnected-screen p{color:#ffffffb3;margin-bottom:2rem;font-size:1.1rem}.disconnected-screen .back-button{font-size:1.2rem;padding:.8rem 2rem;background-color:#646cff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:background-color .2s ease}.disconnected-screen .back-button:hover{background-color:#535bf2}@media (max-width: 600px){.app{padding:1rem}h1{font-size:2rem}.cell{width:60px;height:60px;font-size:2rem}.player-info{flex-direction:column;gap:.5rem}.disconnected-screen{padding:2rem 1rem}.disconnected-icon{font-size:3rem}.disconnected-screen h2{font-size:1.5rem}}:root{font-family:Inter,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}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;margin:0 auto;text-align:center}
