@import url(https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;700;900&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#8b4513,tan 50%,#f4a460);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{font-size:16px;padding:12px 24px}button:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}button:active{transform:translateY(0)}input{border:2px solid #ddd;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .3s ease}input:focus{border-color:#8b0000;outline:none}.container{padding:2rem}.loading:after{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#8b0000;content:"";display:inline-block;height:20px;margin-left:10px;width:20px}@media (max-width:768px){.card,.container{padding:1rem}button{font-size:14px;padding:10px 20px}}*{box-sizing:border-box;margin:0;padding:0}body{animation:gradientShift 10s ease infinite;background:linear-gradient(135deg,#8b4513,peru 20%,#deb887 40%,wheat 60%,#deb887 80%,#8b4513);background-attachment:fixed;background-size:400% 400%;color:#333;font-family:"Noto Serif SC",KaiTi,SimKai,STKaiti,Microsoft YaHei,serif;min-height:100vh}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.App{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#8b0000,peru);box-shadow:0 2px 10px #0000004d;color:#fff;padding:1rem 2rem}.app-header h1{align-items:center;cursor:pointer;display:flex;font-size:2rem;gap:.5rem;transition:transform .2s ease}.app-header h1:hover{transform:scale(1.05)}.header-icon{font-size:2.5rem}.header-chinese{font-size:1.5rem;opacity:.8}.app-main{flex:1 1;padding:2rem}.container{margin:0 auto;max-width:800px}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:15px;box-shadow:0 8px 32px #0003;padding:2rem}.home-container{margin:0 auto;max-width:1200px;text-align:center}.home-header{margin-bottom:3rem}.home-title{color:#8b0000;font-size:3rem;margin-bottom:.5rem;text-shadow:2px 2px 4px #0000004d}.home-subtitle{color:#666;font-size:1.2rem;margin-bottom:2rem}.game-options{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.game-option{background:#ffffffe6;border:2px solid #0000;border-radius:15px;cursor:pointer;padding:2rem;transition:all .3s ease}.game-option:hover{border-color:#8b0000;box-shadow:0 10px 30px #0003;transform:translateY(-5px)}.option-icon{font-size:3rem;margin-bottom:1rem}.option-title{color:#8b0000;font-size:1.5rem;margin-bottom:.5rem}.option-description{color:#666;font-size:1rem}.game-info{background:#ffffffe6;border-radius:15px;padding:2rem;text-align:left}.info-section h3{color:#8b0000;margin-bottom:1rem}.features-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.feature{padding:1rem;text-align:center}.feature-icon{font-size:2rem;margin-bottom:.5rem}.feature h4{color:#8b0000;margin-bottom:.5rem}.xiangqi-board{animation:woodGrain 20s ease-in-out infinite alternate;background:linear-gradient(135deg,wheat,#faebd7 50%,wheat);background-image:radial-gradient(circle at 25% 25%,#8b451326 0,#0000 50%),radial-gradient(circle at 75% 75%,#8b451326 0,#0000 50%),linear-gradient(90deg,#8b451308 50%,#0000 0),linear-gradient(#8b451308 50%,#0000 0),linear-gradient(135deg,wheat,#faebd7 50%,wheat);background-size:100% 100%,100% 100%,20px 20px,20px 20px,100% 100%;border:6px solid #2f1b14;border-radius:15px;box-shadow:0 15px 50px #0006,inset 0 0 30px #8b451333,inset 0 0 10px #deb8874d;height:800px;margin:0 auto;overflow:hidden;position:relative;width:720px}.xiangqi-board:before{background-image:linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(90deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14),linear-gradient(180deg,#2f1b14 0,#2f1b14);background-position:0 0,0 11.11%,0 22.22%,0 33.33%,0 44.44%,0 55.56%,0 66.67%,0 77.78%,0 88.89%,0 100%,0 0,12.5% 0,25% 0,37.5% 0,50% 0,62.5% 0,75% 0,87.5% 0,100% 0;background-repeat:no-repeat;background-size:100% 2px,100% 2px,100% 2px,100% 2px,100% 2px,100% 2px,100% 2px,100% 2px,100% 2px,100% 2px,2px 100%,2px 100%,2px 100%,2px 100%,2px 100%,2px 100%,2px 100%,2px 100%,2px 100%;bottom:5%;content:"";left:5%;pointer-events:none;position:absolute;right:5%;top:5%;z-index:1}.xiangqi-board.flipped,.xiangqi-board.flipped .xiangqi-piece{transform:rotate(180deg)}.xiangqi-point{background:#0000;border-radius:50%;transition:all .2s ease}.xiangqi-point:hover{background:#8b451333!important;border-radius:20px}.xiangqi-point.selected{background:#ffd70099!important;border-radius:20px;box-shadow:0 0 15px #ffd700cc}.xiangqi-point.possible-move{background:#228b2266!important;border-radius:20px}.xiangqi-point.possible-move:before{background:#228b22;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 6px #0000004d;content:"";height:12px;pointer-events:none;position:absolute;width:12px;z-index:1}.intersection-point{transition:all .2s ease}.xiangqi-point:hover .intersection-point{background:#8b0000!important;transform:scale(1.5)}.xiangqi-piece{align-items:center;background:linear-gradient(135deg,#fff,#f8f8ff);border:3px solid;border-radius:50%;box-shadow:0 4px 12px #0006,inset 0 1px 3px #fffc;cursor:pointer;display:flex;font-family:"Noto Serif SC",KaiTi,SimKai,STKaiti,serif;font-size:22px;font-weight:900;height:40px;justify-content:center;transition:all .2s ease;width:40px;z-index:4}.xiangqi-piece.red{border-color:#dc143c;color:#dc143c;text-shadow:0 1px 2px #dc143c4d}.xiangqi-piece.black{border-color:#2f4f4f;color:#2f4f4f;text-shadow:0 1px 2px #2f4f4f4d}.xiangqi-piece:hover{box-shadow:0 6px 18px #00000080,inset 0 1px 3px #ffffffe6;transform:scale(1.15)}.river-decoration{align-items:center;background:linear-gradient(90deg,#0000,#4682b426 20%,#4682b440 50%,#4682b426 80%,#0000);border-bottom:1px solid #4682b44d;border-top:1px solid #4682b44d;display:flex;height:10%;justify-content:space-between;left:5%;pointer-events:none;position:absolute;right:5%;top:50%;transform:translateY(-50%);z-index:2}.river-text{color:#2f4f4f;font-family:"Noto Serif SC",KaiTi,SimKai,STKaiti,serif;font-size:18px;font-weight:900;letter-spacing:2px;text-shadow:1px 1px 0 #fffc,2px 2px 4px #4682b466}.river-text.left{margin-left:10px;padding-left:5px}.river-text.right{margin-right:10px;padding-right:5px}.game-container{margin:0 auto;max-width:1400px}.game-header{align-items:center;background:#ffffffe6;border-radius:10px;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1rem 2rem}.game-header h2{color:#8b0000}.connection-status{border-radius:20px;font-size:.9rem;font-weight:700;padding:.5rem 1rem}.connection-status.connected{background:#228b2233;color:#228b22}.connection-status.reconnecting{background:#ffa50033;color:#ff8c00}.connection-status.disconnected{background:#f003;color:#dc143c}.game-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 300px;margin-bottom:2rem}.game-board-section{position:relative}.game-end-overlay{align-items:center;background:#000c;border-radius:10px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.game-end-message{background:#fff;border-radius:15px;box-shadow:0 8px 32px #0000004d;padding:2rem;text-align:center}.game-end-message h3{color:#8b0000;font-size:2rem;margin-bottom:1rem}.game-sidebar{background:#fffffff2;border-radius:15px;height:-webkit-fit-content;height:fit-content;padding:1.5rem}.players-section h3{color:#8b0000;margin-bottom:1rem;text-align:center}.player-info{background:#f0f0f0cc;border-radius:10px;margin-bottom:.5rem;padding:1rem;transition:all .3s ease}.player-info.active{background:#ffd7004d;border:2px solid gold}.player-info.my-player{border-left:4px solid #228b22}.player-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.player-color{font-size:1.2rem}.player-name{flex:1 1;font-weight:700}.player-time{color:#333;font-family:monospace;font-size:1.1rem;font-weight:700}.player-info.active .player-time{color:#dc143c}.game-info{margin:1.5rem 0}.turn-indicator h4{color:#8b0000;margin-bottom:.5rem}.turn-display{border-radius:20px;font-weight:700;padding:.5rem 1rem;text-align:center}.turn-display.red{background:#dc143c33;color:#dc143c}.turn-display.black{background:#2f4f4f33;color:#2f4f4f}.your-turn{font-size:.8rem;opacity:.8}.check-indicator{margin:1rem 0;text-align:center}.check-indicator .warning{background:#ffa50033;border-radius:20px;color:#ff8c00;font-weight:700;padding:.5rem 1rem}.game-controls{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.game-rules-quick{background:#f0f0f080;border-radius:10px;margin-top:1.5rem;padding:1rem}.game-rules-quick h4{color:#8b0000;margin-bottom:.5rem}.game-rules-quick ul{list-style:none;padding:0}.game-rules-quick li{font-size:.9rem;margin-bottom:.3rem}.chat-icon-container{bottom:2rem;cursor:pointer;position:fixed;right:2rem;z-index:1000}.chat-icon{align-items:center;background:#8b0000;border-radius:50%;box-shadow:0 4px 12px #0000004d;display:flex;font-size:24px;height:60px;justify-content:center;transition:all .3s ease;width:60px}.chat-icon:hover{background:brown;transform:scale(1.1)}.chat-notification-badge{align-items:center;background:#dc143c;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;position:absolute;right:-5px;top:-5px;width:24px}.chat-popup{background:#fff;border-radius:15px;bottom:100px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;height:400px;position:fixed;right:2rem;width:350px;z-index:1001}.chat-header{align-items:center;background:#8b0000;border-radius:15px 15px 0 0;color:#fff;display:flex;justify-content:space-between;padding:1rem}.chat-close-btn{background:none;border:none;color:#fff;cursor:pointer;font-size:1.2rem}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:.5rem;overflow-y:auto;padding:1rem}.no-messages{color:#666;font-style:italic;margin-top:2rem;text-align:center}.chat-message{border-radius:15px;font-size:.9rem;max-width:80%;padding:.5rem 1rem}.chat-message.my-message{align-self:flex-end;background:#8b0000;color:#fff}.chat-message.opponent-message{align-self:flex-start;background:#f0f0f0;color:#333}.message-header{display:flex;font-size:.7rem;justify-content:space-between;margin-bottom:.2rem;opacity:.8}.chat-input-form{border-top:1px solid #eee;padding:1rem}.chat-input-container{display:flex;gap:.5rem}.chat-input{border:1px solid #ddd;border-radius:20px;flex:1 1;outline:none;padding:.5rem}.send-button{background:#8b0000;border:none;border-radius:20px;color:#fff;cursor:pointer;padding:.5rem 1rem}.send-button:disabled{cursor:not-allowed;opacity:.5}.form-group{margin-bottom:1.5rem}.form-group label{color:#8b0000;display:block;font-weight:700;margin-bottom:.5rem}.form-group input,.form-group select{border:2px solid #ddd;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#8b0000;outline:none}.form-group small{color:#666;display:block;font-size:.8rem;margin-top:.25rem}.room-check-input,.room-id-input{display:flex;gap:.5rem}.room-check-input input,.room-id-input input{flex:1 1}.check-btn,.generate-btn{background:#8b0000;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:.75rem 1rem;white-space:nowrap}.checkbox-group,.checkbox-label{align-items:center;display:flex;gap:.5rem}.checkbox-label{cursor:pointer}.form-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.primary-button{background:linear-gradient(135deg,#8b0000,peru);color:#fff}.primary-button:hover{box-shadow:0 4px 12px #8b00004d;transform:translateY(-2px)}.secondary-button{background:#fff;border:2px solid #8b0000;color:#8b0000}.secondary-button:hover{background:#8b0000;color:#fff}.danger-button{background:#dc143c;color:#fff}.danger-button:hover{background:#b22222}.success-button{background:#228b22;color:#fff}.success-button:hover{background:#32cd32}button:disabled{cursor:not-allowed;opacity:.5;transform:none}.loading{color:#8b0000;font-size:1.2rem;padding:2rem;text-align:center}.error{background:#dc143c1a;border:1px solid #dc143c4d;border-radius:8px;color:#dc143c}.error,.success{margin:1rem 0;padding:1rem}.success{background:#228b221a;border:1px solid #228b224d;border-radius:8px;color:#228b22}.warning{background:#ffa5001a;border:1px solid #ffa5004d;border-radius:8px;color:#ff8c00;margin:1rem 0;padding:1rem}.environment-info{background:#000c;border-radius:5px;color:#fff;font-family:monospace;font-size:.8rem;padding:.5rem;position:fixed;right:10px;top:10px;z-index:9999}.env-label{color:gold;font-weight:700}.env-value{color:#90ee90}.env-api{color:#87ceeb;font-size:.7rem;word-break:break-all}@media (max-width:768px){.app-header{padding:1rem}.app-header h1{font-size:1.5rem}.app-main{padding:1rem}.game-content{gap:1rem;grid-template-columns:1fr}.xiangqi-board{height:99.9vw;max-height:444px;max-width:400px;width:90vw}.xiangqi-piece{border-width:2px;font-size:18px;height:32px;width:32px}.intersection-point{height:4px!important;width:4px!important}.chat-popup{right:1rem;width:300px}.home-title{font-size:2rem}.game-options{grid-template-columns:1fr}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#8b0000;height:40px;margin:0 auto 1rem;width:40px}.rules-content{background:#fffffff2;border-radius:15px;margin:0 auto;max-width:1000px;padding:2rem}.rules-section{margin-bottom:2rem}.rules-section h2{border-bottom:2px solid #8b0000;color:#8b0000;margin-bottom:1rem;padding-bottom:.5rem}.pieces-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1rem}.piece-info{background:#f0f0f080;border-radius:10px;padding:1rem}.piece-info h3{color:#8b0000;margin-bottom:.5rem}.piece-symbols{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}.red-piece{border:2px solid #dc143c;border-radius:50%;color:#dc143c}.black-piece,.red-piece{align-items:center;background:#fff;display:flex;font-size:2rem;height:50px;justify-content:center;width:50px}.black-piece{border:2px solid #2f4f4f;border-radius:50%;color:#2f4f4f}.special-rules{grid-gap:1rem;display:grid;gap:1rem}.rule{background:#f0f0f080;border-radius:10px;padding:1rem}.rule h4{color:#8b0000;margin-bottom:.5rem}.rules-actions{margin-top:2rem}.rules-actions,.searching{text-align:center}.search-animation h3{color:#8b0000;margin-bottom:2rem}.search-info{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin:2rem 0;text-align:left}.search-details,.search-status,.search-tips{background:#f0f0f080;border-radius:10px;padding:1rem}.search-tips{margin:2rem 0;text-align:left}.search-tips h4{color:#8b0000;margin-bottom:.5rem}.room-info{background:#f0f0f04d;border-radius:10px;margin:1rem 0;padding:1.5rem}.room-info h3{color:#8b0000;margin-bottom:1rem}.room-details{grid-gap:.5rem;display:grid;gap:.5rem}.detail-item{align-items:center;background:#ffffff80;border-radius:5px;display:flex;justify-content:space-between;padding:.5rem}.label{color:#8b0000;font-weight:700}.value{color:#333}.players-list{display:flex;flex-direction:column;gap:.25rem}.player{border-radius:15px;font-size:.9rem;padding:.25rem .5rem}.player.red{background:#dc143c1a;color:#dc143c}.player.black{background:#2f4f4f1a;color:#2f4f4f}.player.empty{background:#8080801a;color:#666;font-style:italic}.single-player-form{display:flex;flex-direction:column;gap:1.5rem}.difficulty-options{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:.5rem}.difficulty-option{align-items:center;background:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.difficulty-option:hover{border-color:#8b0000;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.difficulty-option.selected{background:linear-gradient(135deg,#8b0000,peru);border-color:#8b0000;color:#fff}.difficulty-icon{font-size:2rem;min-width:40px;text-align:center}.difficulty-content h4{font-size:1.1rem;margin-bottom:.25rem}.difficulty-content p{font-size:.9rem;opacity:.8}.ai-thinking{animation:pulse 1.5s ease-in-out infinite;color:#8b0000;font-weight:700}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.move-history{background:#ffffff1a;border-radius:8px;margin-top:2rem;padding:1rem}.move-history h4{color:#8b0000;margin-bottom:.5rem}.moves-list{display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto}.move-entry{align-items:center;border-radius:4px;display:flex;font-size:.9rem;gap:.5rem;padding:.25rem .5rem}.move-entry.ai-move{background:#ff45001a}.move-entry.human-move{background:#0080001a}.move-number{font-weight:700;min-width:30px}.move-notation{flex:1 1;font-family:monospace}.move-player{font-size:1.1rem}.game-end-actions{display:flex;gap:1rem;margin-top:1rem}@keyframes pieceGlow{0%,to{box-shadow:0 4px 12px #0006,inset 0 1px 3px #fffc}50%{box-shadow:0 6px 18px #00000080,inset 0 1px 3px #ffffffe6,0 0 15px #dc143c4d}}@keyframes intersectionPulse{0%,to{background:#2f1b14;transform:scale(1)}50%{background:#8b0000;transform:scale(1.3)}}.xiangqi-piece.black:hover,.xiangqi-piece.red:hover{animation:pieceGlow 1s ease-in-out infinite}.xiangqi-point.selected .intersection-point{animation:intersectionPulse 1s ease-in-out infinite}.palace-diagonal-svg-line{filter:drop-shadow(0 0 .5px rgba(47,27,20,.3))}@media (max-width:768px){.palace-diagonal-svg-line{stroke-width:.2}}
/*# sourceMappingURL=main.96b90779.css.map*/