*{margin:0;padding:0;box-sizing:border-box}:root{--bg-gradient-start: #ffecd2;--bg-gradient-end: #fcb69f;--text-primary: #1f2937;--text-secondary: #666;--primary-color: #8B5CF6;--secondary-color: #EC4899;--board-bg: #ffffff;--cell-border: #e5e7eb;--cell-hover: rgba(139, 92, 246, .1)}body[data-theme=dark]{--bg-gradient-start: #1a1a2e;--bg-gradient-end: #16213e;--text-primary: #e5e7eb;--text-secondary: #9ca3af;--primary-color: #8B5CF6;--secondary-color: #EC4899;--board-bg: #2d3748;--cell-border: #4a5568;--cell-hover: rgba(139, 92, 246, .2)}body[data-theme=ocean]{--bg-gradient-start: #0093E9;--bg-gradient-end: #80D0C7;--text-primary: #1f2937;--text-secondary: #2c5f6f;--primary-color: #06b6d4;--secondary-color: #3b82f6;--board-bg: #f0fdfa;--cell-border: #99f6e4;--cell-hover: rgba(6, 182, 212, .1)}body[data-theme=forest]{--bg-gradient-start: #4CAF50;--bg-gradient-end: #81C784;--text-primary: #1b4332;--text-secondary: #2d6a4f;--primary-color: #2d6a4f;--secondary-color: #52b788;--board-bg: #f1faee;--cell-border: #95d5b2;--cell-hover: rgba(45, 106, 79, .1)}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation;-webkit-user-select:none;user-select:none;overflow-x:hidden;width:100%;color:var(--text-primary);transition:background .5s ease,color .3s ease}button{font-family:inherit;-webkit-tap-highlight-color:transparent}button,a{touch-action:manipulation}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.stat-emoji,.difficulty-button .emoji{font-family:"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji",sans-serif;display:inline-block;line-height:1}.cell{width:100px;height:100px;background:#fff;border:3px solid #e0e0e0;border-radius:12px;font-size:48px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.cell:hover:not(.occupied){background:#f0f0f0;transform:scale(1.05);box-shadow:0 4px 12px #0000001a}.cell:active:not(.occupied){transform:scale(.95)}.cell.occupied{cursor:not-allowed}.cell.winning{background:linear-gradient(135deg,#fbbf24,#f59e0b);animation:pulse .6s ease-in-out;border-color:#f59e0b}.symbol{display:block;animation:pop-in .3s cubic-bezier(.68,-.55,.265,1.55)}.player-x{color:#3b82f6;text-shadow:2px 2px 4px rgba(59,130,246,.3)}.player-o{color:#ef4444;text-shadow:2px 2px 4px rgba(239,68,68,.3)}@keyframes pop-in{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media(max-width:768px){.cell{width:85px;height:85px;font-size:42px;border-width:2px}}@media(max-width:480px){.cell{width:min(calc((100vw - 60px) / 3),80px);height:min(calc((100vw - 60px) / 3),80px);font-size:36px;border-width:2px;border-radius:10px}}@media(max-width:375px){.cell{width:min(calc((100vw - 50px) / 3),70px);height:min(calc((100vw - 50px) / 3),70px);font-size:32px;border-radius:8px}}.cell.connect-four-cell{width:70px;height:70px;background:#fff;border:4px solid #1e40af;border-radius:50%;margin:4px;position:relative;overflow:visible}.cell.connect-four-cell:hover:not(.occupied):not(:disabled){background:#dbeafe;transform:scale(1.08);border-color:#3b82f6}.cell.connect-four-cell:disabled{cursor:not-allowed;opacity:.7}.cell.connect-four-cell .piece{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;position:absolute;top:0;left:0}.cell.connect-four-cell .piece-inner{width:90%;height:90%;border-radius:50%;background:inherit;box-shadow:inset 0 -2px 8px #0003}.cell.connect-four-cell .player-red{background:radial-gradient(circle at 30% 30%,#fca5a5,#dc2626);box-shadow:0 4px 8px #dc26264d}.cell.connect-four-cell .player-yellow{background:radial-gradient(circle at 30% 30%,#fef08a,#eab308);box-shadow:0 4px 8px #eab3084d}.cell.connect-four-cell.winning{background:linear-gradient(135deg,#fbbf24,#f59e0b);animation:pulse-connect-four .6s ease-in-out infinite;border-color:#f59e0b}@keyframes pulse-connect-four{0%,to{transform:scale(1);box-shadow:0 0 #fbbf24b3}50%{transform:scale(1.1);box-shadow:0 0 0 10px #fbbf2400}}@keyframes drop-animation{0%{transform:translateY(var(--drop-distance));opacity:0}to{transform:translateY(0);opacity:1}}.cell.connect-four-cell.drop-row-0 .piece{--drop-distance: -80px;animation:drop-animation .3s cubic-bezier(.34,1.56,.64,1)}.cell.connect-four-cell.drop-row-1 .piece{--drop-distance: -160px;animation:drop-animation .35s cubic-bezier(.34,1.56,.64,1)}.cell.connect-four-cell.drop-row-2 .piece{--drop-distance: -240px;animation:drop-animation .4s cubic-bezier(.34,1.56,.64,1)}.cell.connect-four-cell.drop-row-3 .piece{--drop-distance: -320px;animation:drop-animation .45s cubic-bezier(.34,1.56,.64,1)}.cell.connect-four-cell.drop-row-4 .piece{--drop-distance: -400px;animation:drop-animation .5s cubic-bezier(.34,1.56,.64,1)}.cell.connect-four-cell.drop-row-5 .piece{--drop-distance: -480px;animation:drop-animation .55s cubic-bezier(.34,1.56,.64,1)}@media(max-width:768px){.cell.connect-four-cell{width:60px;height:60px;margin:3px}}@media(max-width:480px){.cell.connect-four-cell{width:min(calc((100vw - 80px) / 7),50px);height:min(calc((100vw - 80px) / 7),50px);margin:2px;border-width:3px}}.board{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 10px 30px #0003;width:fit-content;margin:0 auto}.board.connect-four{display:flex;flex-direction:column;gap:0;padding:20px;background:linear-gradient(135deg,#2563eb,#1e40af);border-radius:12px;box-shadow:0 10px 40px #2563eb4d}.board-row{display:flex;gap:0}@media(max-width:768px){.board{gap:8px;padding:15px;border-radius:16px}}@media(max-width:480px){.board{gap:6px;padding:12px;border-radius:12px;max-width:calc(100vw - 20px)}}@media(max-width:375px){.board{gap:5px;padding:10px}}.game-status{text-align:center;margin:20px 0;padding:20px;background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;width:100%;max-width:500px;box-sizing:border-box}.game-status h2{margin:0;font-size:28px;color:#333;font-weight:700}.game-status.game-over{animation:celebration .6s ease-in-out}@keyframes celebration{0%,to{transform:scale(1)}25%{transform:scale(1.05) rotate(-2deg)}75%{transform:scale(1.05) rotate(2deg)}}@media(max-width:768px){.game-status{padding:18px;margin:15px 0}.game-status h2{font-size:24px}}@media(max-width:480px){.game-status{padding:15px;margin:15px 10px;max-width:calc(100vw - 20px)}.game-status h2{font-size:20px}}@media(max-width:375px){.game-status{padding:12px;margin:10px 5px}.game-status h2{font-size:18px}}.difficulty-selector{text-align:center;margin:20px 0;width:100%;box-sizing:border-box}.difficulty-selector h3{font-size:20px;color:#333;margin-bottom:15px;font-weight:600}.difficulty-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.difficulty-button{padding:12px 24px;border:3px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px;min-width:120px}.difficulty-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000026;border-color:#667eea}.difficulty-button:active:not(:disabled){transform:translateY(0)}.difficulty-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 6px 20px #667eea66}.difficulty-button:disabled{opacity:.5;cursor:not-allowed}.difficulty-button .emoji{font-size:24px}.difficulty-button .label{font-size:16px}@media(max-width:768px){.difficulty-selector h3{font-size:18px}.difficulty-buttons{gap:12px}.difficulty-button{min-width:110px;padding:11px 20px}}@media(max-width:480px){.difficulty-selector{margin:15px 0;padding:0 10px}.difficulty-selector h3{font-size:16px;margin-bottom:12px}.difficulty-buttons{gap:8px;flex-direction:column;align-items:stretch}.difficulty-button{min-width:auto;width:100%;max-width:300px;margin:0 auto;padding:12px 20px;font-size:15px;justify-content:center}.difficulty-button .emoji{font-size:22px}.difficulty-button .label{font-size:15px}}@media(max-width:375px){.difficulty-selector h3{font-size:15px}.difficulty-button{padding:10px 16px;font-size:14px}.difficulty-button .emoji{font-size:20px}.difficulty-button .label{font-size:14px}}.statistics{background:#fff;border-radius:15px;padding:20px;box-shadow:0 4px 15px #0000001a;margin:20px auto;width:100%;max-width:500px;box-sizing:border-box}.statistics h3{text-align:center;font-size:20px;color:#333;margin-bottom:15px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:20px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:15px 10px;border-radius:12px;transition:transform .2s ease}.stat-item:hover{transform:translateY(-3px)}.stat-item.win{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24}.stat-item.loss{background:linear-gradient(135deg,#fecaca,#fca5a5);border:2px solid #ef4444}.stat-item.draw{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);border:2px solid #8b5cf6}.stat-emoji{font-size:32px}.stat-value{font-size:28px;font-weight:800;color:#333}.stat-label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.win-rate{text-align:center;margin-top:15px}.win-rate p{font-size:16px;color:#666;margin-bottom:10px}.win-rate strong{font-size:20px;color:#667eea}.progress-bar{width:100%;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .5s ease;border-radius:6px}.reset-stats-button{width:100%;padding:10px 20px;margin-top:15px;font-size:14px;font-weight:600;background:linear-gradient(135deg,#fecaca,#fca5a5);color:#991b1b;border:2px solid #ef4444;border-radius:10px;cursor:pointer;transition:all .3s ease}.reset-stats-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.reset-stats-button:active{transform:translateY(0)}@media(max-width:768px){.statistics{padding:18px;margin:15px auto}.stats-grid{gap:12px}.stat-emoji{font-size:28px}.stat-value{font-size:26px}}@media(max-width:480px){.statistics{padding:15px;margin:15px 10px;max-width:calc(100vw - 20px)}.statistics h3{font-size:18px}.stats-grid{gap:8px}.stat-item{padding:10px 6px}.stat-emoji{font-size:24px}.stat-value{font-size:22px}.stat-label{font-size:10px}.win-rate p{font-size:14px}.win-rate strong{font-size:18px}.reset-stats-button{font-size:13px;padding:10px 16px}}@media(max-width:375px){.statistics{padding:12px;margin:10px 5px}.stats-grid{gap:6px}.stat-item{padding:8px 4px}.stat-emoji,.stat-value{font-size:20px}.stat-label{font-size:9px}}.streaks-section{display:flex;gap:12px;margin:20px 0}.streak-item{flex:1;display:flex;align-items:center;gap:12px;padding:12px;background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);border:2px solid rgba(251,191,36,.3);border-radius:12px}.streak-icon{font-size:28px}.streak-details{display:flex;flex-direction:column;gap:2px}.streak-label{font-size:12px;color:#666;font-weight:500}.streak-value{font-size:24px;font-weight:800;color:#f59e0b}.mode-stats{margin:20px 0}.mode-stats h4{text-align:center;font-size:16px;color:#333;margin:0 0 12px;font-weight:600}.mode-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mode-stat{background:#00000005;border:2px solid rgba(0,0,0,.1);border-radius:12px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:8px}.mode-stat-header{display:flex;flex-direction:column;align-items:center;gap:4px}.mode-icon{font-size:24px}.mode-name{font-size:12px;font-weight:600;color:#666}.mode-stat-values{display:flex;gap:8px;font-size:13px;font-weight:600}.mode-wins{color:#10b981}.mode-losses{color:#ef4444}.mode-draws{color:#f59e0b}@media(max-width:480px){.streaks-section{flex-direction:column;gap:8px}.mode-stats-grid{gap:8px}.mode-stat{padding:8px}.mode-icon{font-size:20px}.mode-name{font-size:11px}.mode-stat-values{font-size:11px;gap:6px}}.volume-control{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fffffff2;border-radius:12px;box-shadow:0 2px 8px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:200px}.mute-button{background:none;border:none;font-size:24px;cursor:pointer;padding:4px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.mute-button:hover{background:#8b5cf61a;transform:scale(1.1)}.mute-button:active{transform:scale(.95)}.mute-button:focus-visible{outline:2px solid #8B5CF6;outline-offset:2px}.volume-slider-container{display:flex;align-items:center;gap:12px;flex:1}.volume-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,#8b5cf6,#ec4899);outline:none;opacity:.9;transition:opacity .2s;cursor:pointer}.volume-slider:hover{opacity:1}.volume-slider:disabled{opacity:.3;cursor:not-allowed}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s ease}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 6px #0000004d}.volume-slider::-webkit-slider-thumb:active{transform:scale(1.1)}.volume-slider::-moz-range-thumb{width:18px;height:18px;border:none;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s ease}.volume-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 6px #0000004d}.volume-slider::-moz-range-thumb:active{transform:scale(1.1)}.volume-label{font-weight:600;color:#1f2937;font-size:14px;min-width:40px;text-align:right}@media(max-width:768px){.volume-control{min-width:160px;gap:8px;padding:10px 12px}.mute-button{font-size:20px;width:36px;height:36px}.volume-label{font-size:13px;min-width:35px}}@media(max-width:480px){.volume-control{min-width:140px}.volume-slider{height:8px}.volume-slider::-webkit-slider-thumb{width:20px;height:20px}.volume-slider::-moz-range-thumb{width:20px;height:20px}}.game-mode-selector{display:flex;gap:12px;justify-content:center;align-items:center;margin:20px 0;flex-wrap:wrap}.mode-button{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 24px;background:#ffffffe6;border:3px solid transparent;border-radius:16px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a;min-width:140px}.mode-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 16px #8b5cf64d;border-color:#8b5cf64d}.mode-button:active:not(:disabled){transform:translateY(-1px)}.mode-button.active{background:linear-gradient(135deg,#8b5cf6,#ec4899);border-color:#8b5cf6;color:#fff;box-shadow:0 6px 20px #8b5cf666}.mode-button:disabled{opacity:.5;cursor:not-allowed}.mode-icon{font-size:32px;transition:transform .3s ease}.mode-button:hover:not(:disabled) .mode-icon{transform:scale(1.15)}.mode-button.active .mode-icon{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.mode-label{font-size:14px;font-weight:600;text-align:center;line-height:1.3}.mode-button.active .mode-label{color:#fff}@media(max-width:768px){.game-mode-selector{gap:10px}.mode-button{padding:14px 20px;min-width:120px}.mode-icon{font-size:28px}.mode-label{font-size:13px}}@media(max-width:480px){.game-mode-selector{gap:8px;flex-direction:column;width:100%}.mode-button{flex-direction:row;justify-content:flex-start;padding:12px 16px;width:100%;max-width:300px;min-width:0}.mode-icon{font-size:24px}.mode-label{font-size:14px;text-align:left;flex:1}}.player-names{display:flex;flex-direction:column;align-items:center;gap:12px;margin:16px 0}.edit-names-button{padding:10px 20px;font-size:14px;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.edit-names-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.names-inputs{display:flex;flex-direction:column;gap:12px;padding:20px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 16px #0000001a;width:100%;max-width:400px}.name-input-group{display:flex;flex-direction:column;gap:6px}.name-input-group label{font-size:14px;font-weight:600;color:#1f2937;display:flex;align-items:center;gap:6px}.player-icon{font-size:18px}.name-input-group input{padding:12px 16px;font-size:16px;border:2px solid #e5e7eb;border-radius:10px;transition:all .3s ease;font-family:inherit}.name-input-group input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.done-button{padding:12px 24px;font-size:16px;font-weight:600;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;margin-top:8px}.done-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #10b9814d}.current-names{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#ffffffe6;border-radius:12px;box-shadow:0 2px 8px #0000001a}.player-tag{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;color:#1f2937}.vs{font-weight:800;color:#8b5cf6;font-size:12px;text-transform:uppercase}@media(max-width:480px){.names-inputs{padding:16px;max-width:100%}.name-input-group input{font-size:14px;padding:10px 12px}.current-names{flex-direction:column;gap:8px;padding:12px 16px}.player-tag{font-size:13px}.vs{font-size:11px}}.theme-selector{display:flex;flex-direction:column;align-items:center;gap:12px;margin:16px 0;padding:16px;background:#ffffffe6;border-radius:16px;box-shadow:0 4px 12px #0000001a}.theme-label{font-size:16px;font-weight:700;color:var(--text-primary, #1f2937);display:flex;align-items:center;gap:8px}.theme-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.theme-button{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;background:#ffffffe6;border:3px solid transparent;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;min-width:80px}.theme-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.theme-button.active{border-color:var(--primary-color, #8B5CF6);background:linear-gradient(135deg,#8b5cf61a,#ec48991a);transform:translateY(-2px);box-shadow:0 4px 16px #8b5cf64d}.theme-icon{font-size:24px}.theme-name{font-size:12px;font-weight:600;color:var(--text-primary, #1f2937)}@media(max-width:480px){.theme-selector{padding:12px}.theme-buttons{gap:8px}.theme-button{min-width:70px;padding:10px 12px}.theme-icon{font-size:20px}.theme-name{font-size:11px}}.connection-status{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;transition:all .3s ease;position:fixed;top:20px;right:20px;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a}.connection-icon{font-size:12px;animation:pulse 2s infinite}.connection-text{font-size:13px;letter-spacing:.3px}.connection-transport{font-size:12px;opacity:.8;margin-left:4px;cursor:help}.connection-status.connected{background:#10b98126;color:var(--success-color, #10b981);border:1px solid rgba(16,185,129,.3)}.connection-status.connected .connection-icon{animation:none}.connection-status.connecting,.connection-status.reconnecting{background:#fbbf2426;color:var(--warning-color, #f59e0b);border:1px solid rgba(251,191,36,.3)}.connection-status.connecting .connection-icon,.connection-status.reconnecting .connection-icon{animation:pulse 1s infinite}.connection-status.disconnected{background:#ef444426;color:var(--error-color, #ef4444);border:1px solid rgba(239,68,68,.3)}.connection-status.disconnected .connection-icon{animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:768px){.connection-status{top:10px;right:10px;padding:6px 12px;font-size:12px}.connection-icon{font-size:10px}.connection-text{font-size:11px}}body[data-theme=dark] .connection-status{box-shadow:0 2px 8px #0000004d}body[data-theme=dark] .connection-status.connected{background:#10b98133}body[data-theme=dark] .connection-status.connecting,body[data-theme=dark] .connection-status.reconnecting{background:#fbbf2433}body[data-theme=dark] .connection-status.disconnected{background:#ef444433}.matchmaking-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:20px}.matchmaking-card{background:var(--card-bg, rgba(255, 255, 255, .95));border-radius:24px;padding:48px 40px;box-shadow:0 8px 32px #0000001f;max-width:500px;width:100%;text-align:center;animation:slideIn .4s ease-out}.matchmaking-card h2{margin:0 0 24px;font-size:28px;color:var(--text-color, #333);font-weight:700}.player-info{margin-bottom:32px;padding:12px 20px;background:var(--primary-light, rgba(59, 130, 246, .1));border-radius:12px;display:inline-block}.player-name{font-size:18px;font-weight:600;color:var(--primary-color, #3b82f6)}.searching-animation{margin:40px 0}.spinner{display:flex;justify-content:center;gap:12px;margin-bottom:20px}.dot{width:16px;height:16px;border-radius:50%;background:var(--primary-color, #3b82f6);animation:bounce 1.4s infinite ease-in-out}.dot-1{animation-delay:-.32s}.dot-2{animation-delay:-.16s}.dot-3{animation-delay:0s}@keyframes bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.searching-text{font-size:18px;color:var(--text-secondary, #666);margin:0;font-weight:500}.matchmaking-stats{display:flex;gap:24px;justify-content:center;margin:32px 0;padding:24px;background:var(--secondary-bg, rgba(0, 0, 0, .03));border-radius:16px}.stat{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.stat-icon{font-size:32px}.stat-value{font-size:28px;font-weight:700;color:var(--primary-color, #3b82f6)}.stat-label{font-size:12px;color:var(--text-secondary, #666);text-align:center;line-height:1.4}.cancel-button{background:var(--error-color, #ef4444);color:#fff;border:none;padding:14px 32px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:16px;width:100%;max-width:200px}.cancel-button:hover{background:var(--error-dark, #dc2626);transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.cancel-button:active{transform:translateY(0)}.matchmaking-tips{margin-top:24px;padding:16px;background:var(--info-light, rgba(59, 130, 246, .05));border-radius:12px;border:1px solid var(--info-border, rgba(59, 130, 246, .2))}.tip{margin:0;font-size:14px;color:var(--text-secondary, #666);line-height:1.6}.matchmaking-card.match-found{background:linear-gradient(135deg,var(--success-light, rgba(16, 185, 129, .1)) 0%,var(--primary-light, rgba(59, 130, 246, .1)) 100%);border:2px solid var(--success-color, #10b981)}.match-found-icon{font-size:80px;margin-bottom:24px;animation:celebrate .6s ease-out}@keyframes celebrate{0%{transform:scale(0) rotate(-180deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.match-countdown{font-size:24px;font-weight:700;color:var(--primary-color, #3b82f6);margin:16px 0 0;animation:pulse 1s infinite}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.matchmaking-card{padding:32px 24px}.matchmaking-card h2{font-size:24px}.matchmaking-stats{flex-direction:column;gap:16px}.stat{flex-direction:row;justify-content:center;gap:12px}.stat-icon{font-size:24px}.stat-value{font-size:20px}.stat-label{text-align:left;flex:1}}body[data-theme=dark] .matchmaking-card{background:#1e1e1ef2;box-shadow:0 8px 32px #0006}body[data-theme=dark] .matchmaking-stats{background:#ffffff0d}body[data-theme=dark] .matchmaking-tips{background:#3b82f61a;border-color:#3b82f64d}.opponent-name{font-size:20px;color:var(--text-color, #333);margin:16px 0;font-weight:600}.name-confirmation{margin-top:32px}.confirmation-text{font-size:18px;color:var(--text-color, #333);margin-bottom:24px;line-height:1.6}.confirmation-text strong{color:var(--primary-color, #3b82f6);font-weight:700}.confirmation-buttons{display:flex;gap:16px;justify-content:center;margin-bottom:16px}.confirm-button{background:var(--success-color, #10b981);color:#fff;border:none;padding:14px 32px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;flex:1;max-width:200px}.confirm-button:hover{background:var(--success-dark, #059669);transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.confirm-button:active{transform:translateY(0)}.name-confirmation .cancel-button{flex:1;margin-top:0}.hint-text{font-size:13px;color:var(--text-secondary, #666);margin-top:16px;line-height:1.5;padding:12px;background:var(--warning-light, rgba(245, 158, 11, .1));border-radius:8px;border:1px solid var(--warning-border, rgba(245, 158, 11, .2))}body[data-theme=dark] .confirmation-text,body[data-theme=dark] .opponent-name{color:var(--text-color, #fff)}body[data-theme=dark] .hint-text{background:#f59e0b26;border-color:#f59e0b4d}.game-history{width:100%;max-width:500px;margin:20px 0;background:var(--card-bg, rgba(255, 255, 255, .95));border-radius:16px;padding:24px;box-shadow:0 4px 16px #0000001a}.game-history h3{margin:0 0 20px;font-size:24px;color:var(--text-color, #333);text-align:center}.no-history,.no-results{text-align:center;color:var(--text-secondary, #666);font-size:16px;padding:20px}.history-filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;justify-content:center}.filter-btn{padding:8px 16px;border:2px solid var(--border-color, #e0e0e0);background:#fff;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;color:var(--text-color, #333)}.filter-btn:hover{border-color:var(--primary-color, #3b82f6);background:var(--primary-light, rgba(59, 130, 246, .1))}.filter-btn.active{background:var(--primary-color, #3b82f6);color:#fff;border-color:var(--primary-color, #3b82f6)}.history-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding-right:4px}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track{background:#0000000d;border-radius:10px}.history-list::-webkit-scrollbar-thumb{background:var(--primary-color, #3b82f6);border-radius:10px}.history-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;background:#00000005;border:2px solid transparent;transition:all .3s ease}.history-item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.history-item.result-win{border-color:#10b9814d;background:#10b9810d}.history-item.result-loss{border-color:#ef44444d;background:#ef44440d}.history-item.result-draw{border-color:#fbbf244d;background:#fbbf240d}.history-icon{font-size:28px;flex-shrink:0}.history-details{flex:1;min-width:0}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.history-mode{font-size:14px;font-weight:600;color:var(--text-color, #333)}.history-result{font-size:13px;font-weight:600;padding:2px 8px;border-radius:6px}.result-win .history-result{color:#10b981;background:#10b98126}.result-loss .history-result{color:#ef4444;background:#ef444426}.result-draw .history-result{color:#f59e0b;background:#fbbf2426}.history-info{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-secondary, #666)}.history-opponent{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-date{flex-shrink:0;margin-left:8px}@media(max-width:768px){.game-history{padding:16px}.game-history h3{font-size:20px}.filter-btn{padding:6px 12px;font-size:13px}.history-item{padding:10px}.history-icon{font-size:24px}}body[data-theme=dark] .game-history{background:#1e1e1ef2}body[data-theme=dark] .filter-btn{background:#ffffff0d;border-color:#ffffff1a}body[data-theme=dark] .filter-btn:hover{background:#3b82f633}body[data-theme=dark] .history-item{background:#ffffff08}.achievements{width:100%;max-width:500px;margin:20px 0;background:var(--card-bg, rgba(255, 255, 255, .95));border-radius:16px;padding:24px;box-shadow:0 4px 16px #0000001a}.achievements h3{margin:0 0 12px;font-size:24px;color:var(--text-color, #333);text-align:center}.achievements-progress{text-align:center;font-size:16px;font-weight:600;color:var(--primary-color, #3b82f6);margin:0 0 20px}.achievements-grid{display:grid;gap:12px}.achievement-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;background:#00000005;border:2px solid rgba(0,0,0,.1);transition:all .3s ease;position:relative}.achievement-item.unlocked{background:linear-gradient(135deg,#10b9811a,#3b82f61a);border-color:#10b9814d}.achievement-item.locked{opacity:.5;filter:grayscale(50%)}.achievement-item.unlocked:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98133}.achievement-icon{font-size:32px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff80;border-radius:50%}.achievement-item.unlocked .achievement-icon{background:#10b98126}.achievement-details{flex:1;min-width:0}.achievement-name{font-size:16px;font-weight:700;color:var(--text-color, #333);margin-bottom:4px}.achievement-description{font-size:13px;color:var(--text-secondary, #666);line-height:1.4}.achievement-unlocked-date{font-size:11px;color:#10b981;margin-top:4px;font-weight:500}.achievement-check{position:absolute;top:8px;right:8px;width:24px;height:24px;background:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}@media(max-width:768px){.achievements{padding:16px}.achievements h3{font-size:20px}.achievement-icon{font-size:28px;width:40px;height:40px}.achievement-name{font-size:14px}.achievement-description{font-size:12px}}body[data-theme=dark] .achievements{background:#1e1e1ef2}body[data-theme=dark] .achievement-item{background:#ffffff08;border-color:#ffffff1a}body[data-theme=dark] .achievement-item.unlocked{background:linear-gradient(135deg,#10b98126,#3b82f626);border-color:#10b98166}body[data-theme=dark] .achievement-icon{background:#0000004d}body[data-theme=dark] .achievement-item.unlocked .achievement-icon{background:#10b98133}.quick-chat{position:fixed;bottom:20px;right:20px;z-index:999}.chat-toggle{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;font-size:28px;cursor:pointer;box-shadow:0 4px 16px #667eea66;transition:all .3s ease;display:flex;align-items:center;justify-content:center;position:relative}.chat-toggle:hover{transform:scale(1.1);box-shadow:0 6px 20px #667eea80}.chat-toggle:active{transform:scale(.95)}.message-badge{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;animation:pulse-badge 1s infinite}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.unread-badge{background:#f59e0b;animation:pulse-urgent .8s infinite}@keyframes pulse-urgent{0%,to{transform:scale(1);box-shadow:0 0 #f59e0bb3}50%{transform:scale(1.15);box-shadow:0 0 0 8px #f59e0b00}}.chat-toggle.has-unread{box-shadow:0 4px 16px #f59e0b99}.chat-toggle.has-unread:hover{box-shadow:0 6px 20px #f59e0bb3}.chat-toggle.pulse{animation:pulse-button .8s ease-in-out 3}@keyframes pulse-button{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.chat-panel{position:absolute;bottom:70px;right:0;width:320px;max-height:500px;background:var(--card-bg, rgba(255, 255, 255, .98));border-radius:16px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.chat-header h4{margin:0;font-size:16px;font-weight:600}.chat-header-actions{display:flex;gap:8px}.chat-tab-btn,.chat-close-btn{background:#fff3;border:none;color:#fff;padding:4px 12px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.chat-tab-btn:hover,.chat-close-btn:hover{background:#ffffff4d}.chat-close-btn{padding:4px 8px;font-size:16px}.chat-content{flex:1;overflow-y:auto;padding:16px}.chat-messages{display:flex;flex-direction:column;gap:12px;min-height:300px;max-height:400px}.no-messages{text-align:center;color:var(--text-secondary, #666);font-size:14px;padding:40px 20px}.chat-message{display:flex;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.sent{justify-content:flex-end}.chat-message.received{justify-content:flex-start}.message-bubble{max-width:75%;padding:10px 14px;border-radius:16px;display:flex;flex-direction:column;gap:4px}.chat-message.sent .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.chat-message.received .message-bubble{background:#0000000f;color:var(--text-color, #333);border-bottom-left-radius:4px}.message-text{font-size:14px;line-height:1.4}.message-time{font-size:10px;opacity:.7;align-self:flex-end}.quick-messages{padding:8px 0}.quick-messages-hint{font-size:13px;color:var(--text-secondary, #666);margin:0 0 12px;text-align:center}.quick-messages-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.quick-message-btn{display:flex;align-items:center;gap:8px;padding:12px;background:#667eea14;border:2px solid rgba(102,126,234,.2);border-radius:12px;cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:500;color:var(--text-color, #333)}.quick-message-btn:hover{background:#667eea26;border-color:#667eea66;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.quick-message-btn:active{transform:translateY(0)}.message-emoji{font-size:20px}.message-label{flex:1;text-align:left}@media(max-width:768px){.quick-chat{bottom:10px;right:10px}.chat-toggle{width:50px;height:50px;font-size:24px}.chat-panel{width:calc(100vw - 20px);max-width:320px;bottom:65px}.quick-messages-grid{grid-template-columns:1fr}}body[data-theme=dark] .chat-panel{background:#1e1e1efa}body[data-theme=dark] .chat-message.received .message-bubble{background:#ffffff1a}body[data-theme=dark] .quick-message-btn{background:#667eea26;border-color:#667eea4d}.player-alias{margin:10px 0;padding:10px;background:#ffffff1a;border-radius:8px}.alias-display{display:flex;align-items:center;gap:8px}.alias-label{font-size:14px;color:#ffffffb3}.alias-name{font-size:16px;font-weight:700;color:#fff;flex:1}.alias-edit-btn{background:#fff3;border:none;border-radius:4px;padding:4px 8px;cursor:pointer;transition:background .2s}.alias-edit-btn:hover{background:#ffffff4d}.alias-edit{display:flex;gap:6px;align-items:center}.alias-input{flex:1;padding:8px 12px;font-size:16px;border:2px solid rgba(255,255,255,.3);border-radius:4px;background:#ffffff1a;color:#fff}.alias-input:focus{outline:none;border-color:#fff9}.alias-save-btn,.alias-cancel-btn{padding:8px 12px;font-size:16px;font-weight:700;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.alias-save-btn{background:#4caf50;color:#fff}.alias-save-btn:hover{background:#45a049}.alias-cancel-btn{background:#f44336;color:#fff}.alias-cancel-btn:hover{background:#da190b}.game-container{max-width:600px;margin:0 auto;padding:20px;display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;box-sizing:border-box;min-height:100vh}.game-header{text-align:center;margin-bottom:10px}.game-header h1{font-size:48px;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;letter-spacing:2px}.game-header .subtitle{font-size:18px;color:#666;margin:10px 0 0;font-weight:500}.new-game-button{padding:15px 40px;font-size:20px;font-weight:700;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:15px;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 20px #f5576c4d;margin-top:20px}.new-game-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #f5576c66}.new-game-button:active{transform:translateY(-1px)}.settings-section{display:flex;justify-content:center;align-items:center;width:100%;margin-top:10px}.game-footer{text-align:center;margin-top:30px;color:#999;font-size:14px}@media(max-width:768px){.game-container{padding:15px;gap:15px}.game-header h1{font-size:36px;letter-spacing:1px}.game-header .subtitle{font-size:16px}.new-game-button{padding:12px 30px;font-size:18px;width:auto}}@media(max-width:480px){.game-container{padding:10px;gap:12px}.game-header h1{font-size:28px;letter-spacing:.5px}.game-header .subtitle{font-size:14px}.new-game-button{padding:12px 24px;font-size:16px;width:100%;max-width:300px}.game-footer{font-size:12px;margin-top:20px}}.online-game-info{width:100%;max-width:400px;margin:10px 0}.turn-indicator{text-align:center;font-size:18px;font-weight:600;padding:12px 24px;border-radius:12px;margin:0}.your-turn{color:#10b981;background:#10b9811a;padding:8px 16px;border-radius:8px;display:inline-block;animation:pulse 2s infinite}.opponent-turn{color:#ef4444;background:#ef44441a;padding:8px 16px;border-radius:8px;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.online-game-end-actions{width:100%;max-width:500px;margin-top:20px}.rematch-button{padding:15px 30px;font-size:18px;font-weight:700;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d;margin-right:10px}.rematch-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.leave-button{padding:15px 30px;font-size:18px;font-weight:700;background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6b72804d}.leave-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6b728066}.rematch-waiting,.rematch-request,.rematch-declined{text-align:center;padding:20px;background:#ffffff0d;border-radius:12px;margin:10px 0}.rematch-waiting p,.rematch-declined p{font-size:16px;margin-bottom:15px;color:var(--text-color)}.rematch-message{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--text-color)}.rematch-buttons{display:flex;gap:10px;justify-content:center}.accept-button{padding:12px 30px;font-size:16px;font-weight:700;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.accept-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.decline-button{padding:12px 30px;font-size:16px;font-weight:700;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #ef44444d}.decline-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}@media(max-width:375px){.game-container{padding:8px}.game-header h1{font-size:24px}.game-header .subtitle{font-size:13px}.new-game-button{padding:10px 20px;font-size:15px}.rematch-button,.leave-button{padding:12px 20px;font-size:16px}.rematch-buttons{flex-direction:column}}#root{width:100%;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px}
