.board-container{justify-content:center;align-items:center;padding:20px;display:flex}.board-svg{filter:drop-shadow(0 4px 12px #0000004d);border-radius:4px}.board-bg{fill:#deb887;rx:4}.board-lines line{stroke:#5a3a1a;stroke-width:1.2px}.river-text{fill:#5a3a1a;text-anchor:middle;dominant-baseline:middle;letter-spacing:8px;font-family:KaiTi,STKaiti,楷体,serif;font-size:22px;font-weight:700}.piece-shadow{fill:#00000040;filter:blur(2px)}.piece-bg{stroke-width:1.5px}.piece-bg.red{fill:#fff8e8;stroke:#8b0000}.piece-bg.black{fill:#fff8e8;stroke:#1a1a1a}.piece-inner-ring{stroke-width:1px}.piece-bg.red+.piece-inner-ring{stroke:#8b0000}.piece-bg.black+.piece-inner-ring{stroke:#1a1a1a}.piece-text{text-anchor:middle;dominant-baseline:central;pointer-events:none;-webkit-user-select:none;user-select:none;font-family:KaiTi,STKaiti,楷体,serif;font-size:26px;font-weight:700}.piece-text.red{fill:#8b0000}.piece-text.black{fill:#1a1a1a}.piece-sel-ring{stroke:#2563eb;stroke-width:3px;stroke-dasharray:4 2;animation:1s linear infinite rotate-dash}.piece-capture-ring{stroke:#ef4444;stroke-width:2.5px;stroke-dasharray:6 3}.valid-dot{fill:#2563eb80;cursor:pointer;transition:fill .2s}.valid-dot:hover{fill:#2563ebcc}.piece-g{transition:transform .15s}.piece-g:hover{filter:brightness(1.05)}.piece-g.selected{filter:drop-shadow(0 0 6px #2563eb99)}.piece-g.in-check{animation:.4s infinite shake}.last-move-from{fill:#ffc80040;stroke:#c8960080;stroke-width:1.5px;stroke-dasharray:4 3;pointer-events:none}.last-move-to{fill:#ffc8004d;stroke:#dca000cc;stroke-width:2px;pointer-events:none}.last-move-line{stroke:#c8960066;stroke-width:2px;stroke-dasharray:6 4;pointer-events:none}@keyframes rotate-dash{to{stroke-dashoffset:-12px}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@media (width<=768px){.board-container{padding:8px}.board-svg{width:100%;height:auto}}.chat-wrapper{position:relative}.chat-toggle-btn{z-index:1000;color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:50%;width:56px;height:56px;font-size:24px;transition:transform .2s,background .2s;display:none;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 16px #2563eb66}.chat-toggle-btn:hover{background:#1d4ed8;transform:scale(1.08)}.toggle-icon{line-height:1}.unread-dot{background:#ef4444;border:2px solid #fff;border-radius:50%;width:12px;height:12px;position:absolute;top:6px;right:6px}.chat-backdrop{display:none}.chat-close-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:18px;transition:background .15s;display:none}.chat-close-btn:hover{background:#ffffff26}.chat-panel{background:#fff;border-radius:12px;flex-direction:column;width:360px;height:600px;display:flex;overflow:hidden;box-shadow:0 4px 16px #0000001f}.chat-header{color:#fff;background:#1a1a1a;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.chat-title{font-size:16px;font-weight:600}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex;overflow-y:auto}.chat-msg{align-items:flex-start;gap:8px;display:flex}.chat-msg.user{flex-direction:row-reverse}.msg-avatar{flex-shrink:0;font-size:24px}.msg-bubble{word-wrap:break-word;border-radius:12px;max-width:280px;padding:10px 14px;font-size:14px;line-height:1.6}.chat-msg.ai .msg-bubble{color:#1a1a1a;background:#f3f4f6;border-bottom-left-radius:4px}.chat-msg.user .msg-bubble{color:#fff;background:#2563eb;border-bottom-right-radius:4px}.msg-bubble.loading{color:#999;font-style:italic;animation:1.2s infinite pulse-text}@keyframes pulse-text{50%{opacity:.5}}.quick-questions{flex-wrap:wrap;gap:6px;padding:8px 12px;display:flex}.quick-btn{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:16px;padding:4px 10px;font-size:12px;transition:all .2s}.quick-btn:hover{color:#2563eb;background:#eff6ff;border-color:#2563eb}.quick-btn:disabled{opacity:.4;cursor:not-allowed}.chat-input-area{border-top:1px solid #e5e7eb;gap:8px;padding:10px 12px;display:flex}.chat-input{border:1px solid #d1d5db;border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:14px;transition:border-color .2s}.chat-input:focus{border-color:#2563eb}.chat-send-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600;transition:background .2s}.chat-send-btn:hover:not(:disabled){background:#1d4ed8}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-stop-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ef4444;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600;transition:background .2s}.chat-stop-btn:hover{background:#dc2626}.msg-bubble.streaming{border-left:3px solid #2563eb}.cursor{color:#2563eb;animation:.8s infinite blink-cursor}@keyframes blink-cursor{50%{opacity:0}}@media (width<=1099px){.chat-toggle-btn{justify-content:center;align-items:center;display:flex}.chat-wrapper.open .chat-backdrop{z-index:998;background:#00000040;display:block;position:fixed;inset:0}.chat-close-btn{display:block}.chat-panel{z-index:999;opacity:0;pointer-events:none;border-radius:16px;width:340px;height:480px;transition:opacity .25s,transform .25s;position:fixed;bottom:88px;right:16px;transform:translateY(20px)scale(.95);box-shadow:0 8px 40px #00000040}.chat-wrapper.open .chat-panel{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}}@media (width<=480px){.chat-panel{border-radius:16px;width:auto;height:60vh;max-height:480px;bottom:84px;left:8px;right:8px}.msg-bubble{max-width:240px}.chat-toggle-btn{width:50px;height:50px;font-size:22px;bottom:16px;right:16px}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.choose-side-overlay{justify-content:center;align-items:center;min-height:60vh;display:flex}.choose-side-content{text-align:center;background:#fff;border-radius:16px;padding:40px;box-shadow:0 8px 32px #00000026}.choose-side-content h2{color:#1a1a1a;margin-bottom:8px;font-size:28px}.choose-side-content p{color:#666;margin-bottom:32px;font-size:16px}.choose-side-buttons{justify-content:center;gap:24px;display:flex}.btn-red,.btn-black{cursor:pointer;border:3px solid #0000;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:24px 40px;font-size:18px;font-weight:600;transition:all .2s;display:flex}.btn-red{color:#8b0000;background:#fff5f5;border-color:#8b0000}.btn-red:hover{color:#fff;background:#8b0000;transform:scale(1.05)}.btn-black{color:#1a1a1a;background:#f5f5f5;border-color:#1a1a1a}.btn-black:hover{color:#fff;background:#1a1a1a;transform:scale(1.05)}.side-icon{font-family:KaiTi,STKaiti,楷体,serif;font-size:48px;line-height:1}.game-info{flex-wrap:wrap;justify-content:center;gap:24px;padding:12px 0;display:flex}.info-item{align-items:center;gap:6px;font-size:16px;display:flex}.info-label{color:#666}.player-indicator.red{color:#8b0000;font-weight:700}.player-indicator.black{color:#1a1a1a;font-weight:700}.check-warning{color:#ef4444;font-weight:700;animation:.8s infinite blink}@keyframes blink{50%{opacity:.3}}.control-panel{justify-content:center;gap:12px;padding:16px 0;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:16px;font-weight:600;transition:all .2s}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-secondary{color:#374151;background:#e5e7eb}.btn-secondary:hover:not(:disabled){background:#d1d5db}.game-over-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.game-over-content{text-align:center;background:#fff;border-radius:16px;padding:32px 48px;box-shadow:0 8px 32px #0000004d}.game-over-content h2{margin-bottom:12px;font-size:24px}.app-header{text-align:center;color:#fff;background:#1a1a1a;padding:12px}.app-header h1{margin:0;font-size:22px}.app-main{flex-direction:column;flex:1;align-items:center;padding:12px;display:flex}.app-footer{text-align:center;color:#999;padding:8px;font-size:12px}.difficulty-section,.side-section{margin-bottom:24px}.difficulty-section h3,.side-section h3{color:#333;margin-bottom:12px;font-size:18px}.side-hint{color:#666;margin-bottom:16px;font-size:14px}.difficulty-buttons{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.difficulty-btn{cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:12px;flex-direction:column;align-items:center;gap:4px;min-width:80px;padding:12px 16px;transition:all .2s;display:flex}.difficulty-btn:hover{background:#eff6ff;border-color:#2563eb}.difficulty-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.diff-name{font-size:16px;font-weight:700}.diff-desc{opacity:.7;font-size:11px}.diff-badge{color:#fff;background:#2563eb;border-radius:12px;padding:2px 10px;font-size:13px;font-weight:600}.game-layout{justify-content:center;align-items:flex-start;gap:20px;padding:12px 0;display:flex}.board-section{flex-shrink:0}@media (width<=1099px){.game-layout{flex-direction:column;align-items:center}}.game-info-bar{color:#374151;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;padding:8px 16px;font-size:14px;display:flex}.info-sep{color:#d1d5db}.lang-switch-btn{z-index:1000;color:#374151;cursor:pointer;background:#fffffff2;border:2px solid #d1d5db;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;transition:all .2s;display:flex;position:fixed;top:12px;right:12px;box-shadow:0 2px 8px #0000001a}.lang-switch-btn:hover{background:#f3f4f6;border-color:#6b7280;transform:scale(1.08)}:root{--color-primary:#2563eb;--color-primary-light:#3b82f6;--color-primary-dark:#1d4ed8;--color-board-bg:#f8fafc;--color-board-line:#94a3b8;--color-piece-red-bg:#fff;--color-piece-red-text:#ef4444;--color-piece-black-bg:#f1f5f9;--color-piece-black-text:#1e293b;--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--color-text-primary:#1e293b;--color-text-secondary:#475569;--color-text-tertiary:#64748b;--color-border:#e2e8f0;--color-divider:#cbd5e1;--color-bg:#fff;--color-card-bg:#f8fafc;--size-board-desktop:600px;--size-cell-desktop:60px;--size-piece-desktop:52px;--size-piece-font-desktop:28px;--size-cell-mobile:48px;--size-piece-mobile:48px;--size-piece-font-mobile:24px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:50%;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 2px 4px #0000001a;--shadow-lg:0 4px 8px #00000026;--duration-fast:.2s;--duration-normal:.3s;--duration-slow:.5s;--easing-ease-out:cubic-bezier(0, 0, .2, 1);--font-family-chinese:"Microsoft YaHei", "PingFang SC", "Hiragino Sans GB", "STHeiti", sans-serif;--font-weight-semibold:600}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-family-chinese);background-color:var(--color-bg);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{flex-direction:column;min-height:100vh;display:flex}@media (width<=1024px){:root{--size-board-desktop:500px;--size-cell-desktop:50px;--size-piece-desktop:48px;--size-piece-font-desktop:24px}}@media (width<=768px){:root{--size-board-desktop:min(90vw, 80vh);--size-cell-desktop:calc(var(--size-board-desktop) / 10);--size-piece-desktop:48px;--size-piece-font-desktop:24px}}.board-container{background-color:var(--color-bg);justify-content:center;align-items:center;padding:20px;display:flex}.board{width:var(--size-board-desktop);height:var(--size-board-desktop);background-color:var(--color-board-bg);border:2px solid var(--color-board-line);box-shadow:var(--shadow-lg);grid-template-rows:repeat(10,1fr);grid-template-columns:repeat(9,1fr);display:grid;position:relative}.cell{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;display:flex;position:relative}.river{font-size:calc(var(--size-cell-desktop) * .6);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);background-color:var(--color-board-bg);z-index:1;pointer-events:none;grid-area:5/1/6/10;justify-content:center;align-items:center;display:flex}.river:before,.river:after{content:"楚河 汉界";padding:0 10px;display:block}.cell:before{content:"";background-color:var(--color-board-line);z-index:0;height:1px;position:absolute;top:50%;left:0;right:0}.cell:after{content:"";background-color:var(--color-board-line);z-index:0;width:1px;position:absolute;top:0;bottom:0;left:50%}.palace-diagonal{background-color:var(--color-board-line);z-index:0;width:1px;height:140%;position:absolute;top:-20%;left:50%;transform:translate(-50%)rotate(45deg)}.piece{width:var(--size-piece-desktop);height:var(--size-piece-desktop);border-radius:var(--radius-full);background-color:var(--color-piece-red-bg);color:var(--color-piece-red-text);font-size:var(--size-piece-font-desktop);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-md);z-index:1;transition:all var(--duration-normal) var(--easing-ease-out);border:1px solid var(--color-border);justify-content:center;align-items:center;display:flex;position:relative}.piece.black{background-color:var(--color-piece-black-bg);color:var(--color-piece-black-text)}.piece.selected{box-shadow:0 0 0 2px var(--color-primary), var(--shadow-md);z-index:2;transform:scale(1.05)}.valid-move-indicator{width:calc(var(--size-piece-desktop) * .4);height:calc(var(--size-piece-desktop) * .4);background-color:var(--color-primary);border-radius:var(--radius-full);opacity:.6;z-index:2;animation:1.5s infinite pulse}@keyframes pulse{0%{opacity:.6;transform:scale(1)}50%{opacity:.8;transform:scale(1.2)}to{opacity:.6;transform:scale(1)}}.cell:first-child:after,.cell:nth-child(9n+1):after{height:50%;top:50%}.cell:last-child:after,.cell:nth-child(9n):after{height:50%;bottom:50%}.cell:nth-child(n+1):nth-child(-n+9):before{height:50%;top:50%}.cell:nth-child(n+73):before{height:50%;bottom:50%}@media (width<=768px){.piece{width:var(--size-piece-mobile);height:var(--size-piece-mobile);font-size:var(--size-piece-font-mobile)}.river{font-size:calc(var(--size-cell-desktop) * .5)}.valid-move-indicator{width:calc(var(--size-piece-mobile) * .4);height:calc(var(--size-piece-mobile) * .4)}}.piece.in-check{box-shadow:0 0 0 3px var(--color-error), var(--shadow-md);z-index:3;animation:.5s ease-in-out shake}.btn{border-radius:var(--radius-md);font-size:14px;font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-fast) var(--easing-ease-out);border:none;outline:none;padding:8px 16px}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-card-bg);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-border)}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover{background-color:#dc2626}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:hover{background-color:inherit}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background-color:var(--color-bg);border-bottom:1px solid var(--color-border);margin-bottom:20px;padding:16px 0}.app-header h1{text-align:center;color:var(--color-text-primary);font-size:24px}.app-main{flex-direction:column;flex:1;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:0 20px;display:flex}.game-info{background-color:var(--color-card-bg);border-radius:var(--radius-lg);border:1px solid var(--color-border);gap:32px;margin-bottom:20px;padding:16px 24px;display:flex}.info-item{align-items:center;gap:8px;display:flex}.info-label{color:var(--color-text-secondary);font-size:14px}.player-indicator{font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);padding:4px 12px}.player-indicator.red{color:var(--color-piece-red-text);background-color:#ef44441a}.player-indicator.black{color:var(--color-piece-black-text);background-color:#1e293b1a}.check-warning{background-color:var(--color-error);color:#fff;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);padding:4px 12px;font-size:14px;animation:1s infinite pulse}.move-count{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:16px}.board-section{margin:20px 0}.control-panel{gap:12px;margin-top:20px;display:flex}.app-footer{text-align:center;color:var(--color-text-tertiary);border-top:1px solid var(--color-border);margin-top:auto;padding:16px 0;font-size:12px}.game-over-overlay{z-index:1000;background-color:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-over-content{background-color:var(--color-bg);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-lg);padding:40px 60px;animation:.3s scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.game-over-content h2{color:var(--color-text-primary);margin-bottom:20px;font-size:32px}.game-over-content p{color:var(--color-text-secondary);margin-bottom:30px;font-size:20px}.palace-diagonal{background-color:var(--color-board-line);z-index:0;width:1px;height:140%;position:absolute;top:-20%;left:50%}.palace-diagonal:before{content:"";background-color:var(--color-board-line);width:100%;height:1px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-45deg)}@media (width<=768px){.app-header h1{font-size:20px}.game-info{flex-direction:column;gap:12px;padding:12px 16px}.control-panel{flex-direction:column}.btn{width:100%}}
