.App{text-align:center;min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2)}.App-header{flex:0 0 auto}.App-header{background-color:#282c34e6;padding:4px 20px;color:#fff;box-shadow:0 2px 10px #0000001a}.App-header h1{margin:0;font-size:1.1rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin:8px;box-shadow:0 4px 15px #0003}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff}.btn-success{background:linear-gradient(45deg,#56ab2f,#a8e6cf);color:#fff}.btn-warning{background:linear-gradient(45deg,#f093fb,#f5576c);color:#fff}.btn-danger{background:linear-gradient(45deg,#ff6b6b,#ee5a52);color:#fff}.error-message{position:fixed;top:20px;right:20px;background:linear-gradient(45deg,#ff6b6b,#ee5a52);color:#fff;padding:15px 20px;border-radius:10px;box-shadow:0 4px 20px #ff6b6b4d;z-index:1000;display:flex;align-items:center;gap:15px;max-width:400px;animation:slideInRight .3s ease-out}.error-text{flex:1;font-weight:500}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;z-index:9999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.loading-overlay span{margin-top:20px;font-size:1.2rem;font-weight:500}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn:disabled:hover{transform:none;box-shadow:0 4px 15px #0003}.card-container{background:#fffffff2;border-radius:15px;padding:20px;margin:20px;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(max-width:768px){.App-header h1{font-size:2rem}.btn{padding:10px 20px;font-size:14px}}@media(max-width:900px)and (orientation:portrait)and (hover:none)and (pointer:coarse){.App-header{display:none}}.action-panel{background-color:#f8f9fa;border-radius:10px;padding:15px;margin-top:20px;box-shadow:0 2px 5px #0000001a}.action-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;border-bottom:1px solid #e9ecef;padding-bottom:10px}.action-panel h3{margin:0;font-size:1.2rem;color:#343a40}.action-tip{font-size:1rem;color:#0d6efd;font-weight:500}.action-selection{margin-bottom:15px;background-color:#e9ecef;padding:10px;border-radius:8px}.action-selection p{margin:0 0 8px;font-size:.9rem;color:#495057}.matching-actions{display:flex;flex-wrap:wrap;gap:8px}.action-option{background-color:#fff;border:1px solid #ced4da;border-radius:5px;padding:5px 10px;cursor:pointer;transition:all .2s ease}.action-option:hover{background-color:#f1f3f5}.action-option.selected{background-color:#e7f5ff;border-color:#4dabf7;color:#1864ab}.action-buttons{display:flex;gap:10px;margin-bottom:15px}.btn{padding:8px 16px;border:none;border-radius:5px;cursor:pointer;font-weight:500;transition:all .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover:not(:disabled){background-color:#218838}.btn-warning{background-color:#ffc107;color:#212529}.btn-warning:hover:not(:disabled){background-color:#e0a800}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.action-tips{font-size:.9rem;color:#6c757d;padding:10px;background-color:#f8f9fa;border-radius:5px;border-left:3px solid #0d6efd}.waiting-indicator{display:flex;flex-direction:column;align-items:center;padding:20px 0}.spinner-small{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-bottom:20px;max-height:200px;overflow-y:auto;padding:5px}.action-item{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #dee2e6;border-radius:10px;padding:12px;cursor:pointer;transition:all .3s ease;position:relative;min-height:80px;display:flex;flex-direction:column;justify-content:space-between}.action-item:hover{transform:translateY(-2px);box-shadow:0 4px 15px #00000026;border-color:#667eea}.action-item.selected{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;transform:translateY(-2px);box-shadow:0 6px 20px #667eea4d}.action-item.matching{border-color:#28a745;background:linear-gradient(135deg,#d4edda,#c3e6cb)}.action-item.matching:after{content:"✓ 匹配";position:absolute;top:5px;right:5px;background:#28a745;color:#fff;padding:2px 6px;border-radius:10px;font-size:.7rem;font-weight:700}.action-item.pass-action{background:linear-gradient(135deg,#ffeaa7,#fdcb6e);border-color:#e17055}.action-item.pass-action.selected{background:linear-gradient(135deg,#e17055,#d63031)}.action-type{font-weight:600;font-size:.95rem;margin-bottom:5px;text-align:center}.action-cards{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin-top:5px}.action-card{background:#fffc;color:#333;padding:2px 6px;border-radius:5px;font-size:.75rem;font-weight:500;border:1px solid rgba(0,0,0,.1)}.action-item.selected .action-card{background:#ffffffe6}.more-cards{color:#666;font-style:italic;font-size:.7rem}.matching-indicator{position:absolute;top:5px;right:5px;background:#28a745;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}.no-actions{grid-column:1 / -1;text-align:center;padding:40px;color:#666;font-style:italic;background:#0000000d;border-radius:10px;border:2px dashed #ddd}@media(max-width:768px){.action-panel{padding:15px}.action-panel-header{flex-direction:column;align-items:stretch;gap:10px}.action-panel-header h3{text-align:center}.action-count{text-align:center;align-self:center}.actions-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;max-height:160px}.action-item{padding:10px;min-height:70px}.action-type{font-size:.85rem}.action-buttons{flex-direction:column}.action-buttons .btn{max-width:none}}@media(max-width:480px){.actions-grid{grid-template-columns:1fr 1fr;gap:6px}.action-item{padding:8px;min-height:60px}.action-type{font-size:.8rem}.action-card{font-size:.7rem;padding:1px 4px}}.action-panel-container{display:flex;justify-content:center;align-items:center;gap:15px;padding:2px 0}.action-button{padding:9px 26px;border-radius:25px;border:none;font-size:15px;font-weight:700;color:#fff;cursor:pointer;box-shadow:0 4px 15px #0003;transition:all .2s ease-in-out;display:flex;align-items:center;gap:6px}.action-button:disabled{background:linear-gradient(145deg,#9ca3af,#6b7280);cursor:not-allowed;box-shadow:none;opacity:.7}.play-btn{background:linear-gradient(145deg,#10b981,#059669)}.play-btn:not(:disabled):hover{background:linear-gradient(145deg,#059669,#047857)}.pass-btn{background:linear-gradient(145deg,#f59e0b,#d97706)}.pass-btn:not(:disabled):hover{background:linear-gradient(145deg,#d97706,#b45309)}.hint-btn{background:linear-gradient(145deg,#8b5cf6,#7c3aed)}.hint-btn:not(:disabled):hover{background:linear-gradient(145deg,#7c3aed,#6d28d9)}.action-button:not(:disabled):hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000004d}.action-button:not(:disabled):active{transform:translateY(-1px);box-shadow:0 3px 10px #0003}.waiting-indicator{display:flex;align-items:center;gap:10px;padding:10px 20px;background:#ffffff1a;border-radius:20px;color:#fffc;font-size:.9rem}.waiting-indicator .spinner-small{margin-bottom:0}.card{background-color:#fff;border:1px solid #b0b0b0;border-radius:8px;box-shadow:0 2px 5px #0000001a;position:relative;font-family:Helvetica Neue,Arial,sans-serif;font-weight:700}.card-content{position:absolute;top:4px;left:5px;text-align:left}.card-rank{font-size:20px;line-height:1}.card-suit{font-size:18px;line-height:1}.card-red{color:#d90000}.card-black{color:#000}.card-body-suit{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:30px;opacity:.8}.card-joker .card-body-suit{font-size:20px}.card-small{width:38px;height:52px}.card-normal{width:56px;height:78px}.card-large{width:72px;height:100px}.joker-corner-icon{display:block;width:15px;height:15px}.joker-center-icon{position:absolute;top:52%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px}.card-small .joker-corner-icon{width:11px;height:11px}.card-small .joker-center-icon{width:22px;height:22px}.card-interactive{cursor:pointer}.card-interactive:hover{transform:scale(1.02);box-shadow:0 8px 25px #0003,0 4px 8px #00000026,inset 0 1px 2px #ffffffe6;border-color:#667eea;background:linear-gradient(145deg,#fff,#f1f3f4)}.card-selected{border-color:#667eea;box-shadow:0 12px 30px #667eea4d,0 6px 15px #0003,inset 0 1px 3px #ffffffe6,0 0 0 3px #667eea33;background:linear-gradient(145deg,#f8f9ff,#e6efff);transform:scale(1.05)}.card-selected:after{content:"";position:absolute;inset:-2px;border:2px solid #667eea;border-radius:12px;background:linear-gradient(45deg,#667eea1a,#667eea0d);z-index:-1}.card-small .card-rank{font-size:.8rem}.card-small .card-suit{font-size:1rem}.card-normal .card-rank{font-size:1.05rem;font-weight:800}.card-normal .card-suit{font-size:1.2rem}.card-large .card-rank{font-size:1.8rem}.card-large .card-suit{font-size:2rem}.card-joker{background:linear-gradient(145deg,#fff3cd,#ffeaa7);border-color:#ffc107;box-shadow:0 4px 12px #ffc1074d,0 2px 4px #0000001a,inset 0 1px 2px #ffffffe6}.card-big-joker{background:linear-gradient(145deg,#ffe6e6,#ffcccb);border-color:#dc3545;box-shadow:0 4px 12px #dc35454d,0 2px 4px #0000001a,inset 0 1px 2px #ffffffe6}.card-small-joker{background:linear-gradient(145deg,#e6f3ff,#cce7ff);border-color:#007bff;box-shadow:0 4px 12px #007bff4d,0 2px 4px #0000001a,inset 0 1px 2px #ffffffe6}.card-joker .card-content{font-weight:700}.card-big-joker .card-content{color:#dc3545;text-shadow:0 1px 3px rgba(255,255,255,.9)}.card-small-joker .card-content{color:#007bff;text-shadow:0 1px 3px rgba(255,255,255,.9)}.joker-rank{font-size:.9rem!important;margin-bottom:2px}.joker-symbol{font-size:1.4rem!important;margin-top:-2px}.card-normal .joker-rank{font-size:1.1rem!important}.card-normal .joker-symbol{font-size:1.6rem!important}.card-empty{background:linear-gradient(145deg,#f8f9fa,#e9ecef);border:2px dashed #ced4da;color:#6c757d;font-style:italic;opacity:.6}.card:disabled,.card.disabled{opacity:.5;cursor:not-allowed;filter:grayscale(30%)}@keyframes cardFlip{0%{transform:rotateY(0)}50%{transform:rotateY(90deg)}to{transform:rotateY(0)}}.card.flip{animation:cardFlip .6s ease-in-out}@media(max-width:768px){.card-normal{width:60px;height:84px}.card-small{width:40px;height:56px}.card-normal .card-rank{font-size:1.2rem}.card-normal .card-suit{font-size:1.4rem}.card-small .card-rank{font-size:.7rem}.card-small .card-suit{font-size:.9rem}.card-normal .joker-rank{font-size:1rem!important}.card-normal .joker-symbol{font-size:1.4rem!important}}@media(max-width:480px){.card-normal{width:50px;height:70px}.card-small{width:35px;height:49px}.card-normal .card-rank{font-size:1rem;font-weight:700}.card-normal .card-suit{font-size:1.2rem}.card-small .card-rank{font-size:.6rem}.card-small .card-suit{font-size:.8rem}.card-normal .joker-rank{font-size:.9rem!important}.card-normal .joker-symbol{font-size:1.2rem!important}}.card-highlight{animation:cardGlow 2s ease-in-out infinite}@keyframes cardGlow{0%,to{box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a}50%{box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a,0 0 20px #ffd70099}}.debug-panel{--debug-drawer-width: min(360px, 36vw);position:absolute;top:0;right:0;bottom:0;z-index:60;width:var(--debug-drawer-width);overflow:auto;padding:12px;background:#101a1d;color:#e9f2ef;border-left:1px solid rgba(255,255,255,.12);box-shadow:-18px 0 34px #00000052}.debug-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.debug-panel h2,.debug-panel h3{margin:0}.debug-panel h2{font-size:18px}.debug-panel h3{font-size:13px;margin-bottom:8px}.debug-panel-header span,.debug-empty{font-size:12px;opacity:.72}.debug-seed{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debug-header-actions{display:grid;justify-items:end;gap:6px}.debug-close{min-height:28px;border:1px solid rgba(255,255,255,.16);border-radius:6px;padding:0 10px;color:#e9f2ef;background:#ffffff14;cursor:pointer}.debug-close:hover{background:#ffffff24}.debug-section{padding:10px 0;border-top:1px solid rgba(255,255,255,.1)}.debug-row{display:flex;justify-content:space-between;gap:12px;font-size:12px}.debug-hand-row{display:grid;grid-template-columns:28px 1fr;gap:6px;align-items:center;margin-bottom:6px}.debug-seat-label{font-size:12px;font-weight:800;color:#ffef9f}.debug-hand-cards{display:flex;overflow:hidden}.debug-hand-cards .card+.card{margin-left:-24px}.debug-actions{display:grid;gap:4px;max-height:320px;overflow:auto;padding-right:2px}.debug-action-btn{min-height:30px;display:grid;grid-template-columns:100px 1fr;gap:6px;align-items:center;text-align:left;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:#e9f2ef;background:#ffffff0f;cursor:pointer}.debug-action-btn:hover{background:#ffffff1f}.debug-action-btn small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.72}.debug-panel pre{margin:0;white-space:pre-wrap;font-size:11px;max-height:220px;overflow:auto}@media(max-width:900px){.debug-panel{display:none}}.game-board-shell{--debug-drawer-width: min(360px, 36vw);position:relative;width:100%;min-height:0;flex:1;display:flex;background:#123528;overflow:hidden}.game-board{position:relative;flex:1;min-width:0;min-height:0;display:grid;grid-template-rows:92px minmax(150px,1fr) 174px;grid-template-columns:150px minmax(420px,1fr) 150px;grid-template-areas:". top ." "left center right" "bottom bottom bottom";gap:10px;padding:10px 14px;overflow:hidden;box-sizing:border-box;background:linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.035) 1px,transparent 1px),#123528;background-size:32px 32px}.game-board.loading{display:flex;justify-content:center;align-items:center;color:#fff}.loading-spinner{text-align:center;color:#fff}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.game-board .game-status{position:absolute;top:10px;left:14px;z-index:22;margin-bottom:0}.board-toolbar{position:absolute;top:10px;right:14px;display:flex;gap:6px;z-index:21}.speed-segment{display:flex;border:1px solid rgba(255,255,255,.2);border-radius:8px;overflow:hidden}.speed-segment button,.debug-toggle{min-height:30px;border:0;padding:0 10px;color:#fff;background:#00000061;cursor:pointer}.speed-segment button+button{border-left:1px solid rgba(255,255,255,.16)}.speed-segment button.active,.debug-toggle.active{background:#1f7a5c}.speed-segment button:disabled{opacity:.46;cursor:default}.top-player-zone{grid-area:top;justify-self:center;align-self:end}.left-player-zone{grid-area:left;align-self:center;justify-self:start}.right-player-zone{grid-area:right;align-self:center;justify-self:end}.bottom-player-zone{grid-area:bottom;position:relative;min-width:0;display:grid;grid-template-rows:auto auto minmax(92px,1fr);align-items:end;padding:8px 14px 4px;border-radius:12px 12px 0 0;border:1px solid rgba(255,255,255,.15);background:#06141280}.center-table{grid-area:center;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#0000002e;box-shadow:inset 0 0 0 1px #ffffff0a}.bottom-player-meta{position:absolute;left:14px;top:8px;display:flex;align-items:center;gap:8px;color:#fff;z-index:12}.bottom-avatar{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;background:#1f7a5c;font-size:13px;font-weight:800}.bottom-avatar.active-turn{box-shadow:0 0 0 3px #ffd166,0 0 14px #ffd166b3}.bottom-player-name{font-size:13px;font-weight:800}.bottom-player-detail{font-size:11px;opacity:.78}.action-area{display:flex;justify-content:center;align-items:center;min-height:42px;width:100%}.current-player-cards{width:100%;min-width:0;display:flex;justify-content:center;align-items:flex-end}.game-over-modal{position:fixed;inset:0;background:#000000c7;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{max-width:420px;width:min(90vw,420px);padding:28px;border-radius:12px;text-align:center;color:#fff;background:#123528;border:1px solid rgba(255,255,255,.18);box-shadow:0 20px 60px #0000005c}.modal-content h2{margin:0 0 18px}.winner-team{font-size:20px;font-weight:800}.team-details{opacity:.82}.finish-order{margin:16px 0;padding:12px;border-radius:8px;background:#ffffff14}.player-ranks{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.rank-badge{padding:5px 9px;border-radius:999px;background:#ffffff1f}@media(max-width:900px)and (orientation:landscape){.game-board{grid-template-rows:60px minmax(98px,1fr) 128px;grid-template-columns:104px minmax(280px,1fr) 104px;gap:6px;padding:6px 8px}.game-board .game-status{top:6px;left:8px;width:112px}.board-toolbar{top:6px;right:8px}.speed-segment button,.debug-toggle{min-height:28px;padding:0 8px;font-size:12px}.debug-toggle{display:none}.bottom-player-zone{grid-template-rows:auto minmax(82px,1fr);padding:4px 8px 2px}.bottom-player-meta{display:none}.action-area{min-height:34px}}.game-status{position:relative;z-index:22;width:168px}.status-dock-button{width:100%;min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:8px;background:#061412b8;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:0 10px;color:#fff;font-size:13px;font-weight:800;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dock-caret{font-size:12px;opacity:.85}.dock-alert{padding:2px 7px;border-radius:999px;background:#1f7a5c;color:#fff;font-size:11px}.dock-alert.game-over{background:#bd3b34}.status-dock-button:hover{background:#0d2b24d6}.status-details{position:absolute;top:calc(100% + 6px);left:0;width:236px;background:#fffffff7;color:#20242b;border-radius:8px;padding:10px;box-shadow:0 12px 32px #00000040;z-index:30}.status-section+.status-section{margin-top:10px;padding-top:10px;border-top:1px solid #e7e9ef}.status-section-title{margin-bottom:6px;color:#5a6370;font-size:12px;font-weight:800}.recent-play-row{display:grid;grid-template-columns:54px minmax(0,1fr);gap:8px;align-items:center;padding:4px 0;font-size:12px}.recent-play-row span,.remaining-cell span{color:#697281}.recent-play-row strong{overflow:hidden;color:#1e2d2a;text-overflow:ellipsis;white-space:nowrap}.recent-play-row.pass strong{color:#8a929d}.status-empty{color:#8a929d;font-size:12px}.remaining-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.remaining-cell{display:flex;align-items:center;justify-content:space-between;min-width:0;padding:5px 7px;border-radius:6px;background:#eef3f0;font-size:12px}.remaining-cell strong{color:#0e4f3d;font-size:14px}.remaining-cell.danger{background:#fff1ea}.remaining-cell.danger strong{color:#bd3b34}.status-restart{width:100%;margin-top:10px;padding:7px 12px;font-size:13px;border-radius:8px}@media(max-width:900px)and (orientation:landscape){.status-dock-button{min-height:30px;padding:0 8px;font-size:12px}.status-details{top:0;left:calc(100% + 6px);width:212px;max-height:calc(100vh - 48px);overflow:auto;padding:8px}.status-section+.status-section{margin-top:8px;padding-top:8px}.recent-play-row{padding:2px 0}.status-restart{margin-top:8px;padding:6px 10px}}.hand-cards-container{background:transparent;border-radius:0;padding:0;box-shadow:none;width:100%;display:flex;flex-direction:column;align-items:center;position:relative}.hand-cards-header{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px;padding:0;border-bottom:none}.hand-cards-header h3{color:#ffffffe6;font-size:13px;font-weight:600;margin:0;text-shadow:0 1px 3px rgba(0,0,0,.3)}.card-count{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;padding:3px 10px;border-radius:15px;font-size:12px;font-weight:600;box-shadow:0 2px 8px #667eea4d}.selected-count{background:linear-gradient(45deg,#56ab2f,#a8e6cf);color:#fff;padding:3px 10px;border-radius:15px;font-size:12px;font-weight:600;animation:pulse-selected 2s infinite;box-shadow:0 2px 8px #56ab2f4d}@keyframes pulse-selected{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.hand-cards{display:flex;justify-content:center;align-items:flex-end;padding:4px 0;position:relative;height:96px;margin:0 auto;touch-action:none;user-select:none;-webkit-user-select:none}.hand-cards.empty{justify-content:center;align-items:center;color:#fff9;font-style:italic;background:#ffffff0d;border-radius:12px;border:2px dashed rgba(255,255,255,.2);min-height:96px;height:96px;width:220px}.hand-card{position:absolute;top:0;touch-action:none;transition:top .12s ease-out,transform .12s ease-out}.hand-card.interactive{cursor:pointer}.hand-card.interactive:not(.selected):hover{transform:translateY(-12px)}.hand-card.selected{transform:scale(1.05)}.hand-cards-tip{margin-top:2px;width:100%;text-align:center;color:#ffffffd9;font-size:12px}.hand-cards-tip p{margin:0}@media(max-width:768px){.hand-cards{height:92px}}.landscape-guard{display:none}.landscape-content{min-height:0;flex:1;display:flex}@media(max-width:900px)and (orientation:portrait)and (hover:none)and (pointer:coarse){.landscape-content{display:none}.landscape-guard{min-height:100vh;display:grid;place-content:center;gap:10px;padding:24px;text-align:center;color:#fff;background:#123528}.rotate-device-icon{font-size:44px;line-height:1}.rotate-title{font-size:22px;font-weight:800}.rotate-copy{font-size:14px;opacity:.82}}.play-area{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative}.table-center{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:500px}.table-surface{background:#ffffff0d;border-radius:20px;padding:20px;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:2px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d,inset 0 2px 10px #ffffff1a;position:relative;min-height:96px;display:flex;flex-direction:column;justify-content:space-between;align-items:center}.game-level{position:absolute;top:10px;left:15px;display:flex;align-items:center;gap:5px;background:linear-gradient(45deg,gold,#ffb347);color:#333;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700;box-shadow:0 2px 8px #ffd7004d}.level-icon{font-size:14px}.level-text{font-size:11px}.current-cards-display{display:flex;flex-direction:column;align-items:center;gap:10px;flex:1;justify-content:center}.current-play-info{display:flex;flex-direction:column;align-items:center;gap:5px;margin-bottom:10px}.current-player-name{color:gold;font-weight:700;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.current-play-type{background:linear-gradient(45deg,#ff6b6b,#ff8e8e);color:#fff;padding:4px 12px;border-radius:15px;font-size:12px;font-weight:700;box-shadow:0 2px 8px #ff6b6b4d}.current-cards{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;align-items:center}.empty-table{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:#fff9;text-align:center}.table-logo{font-size:48px;margin-bottom:10px;opacity:.7;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.empty-table p{font-size:14px;margin:0;opacity:.8}.turn-indicator-center{position:absolute;bottom:10px;right:15px;display:flex;align-items:center;gap:5px;background:linear-gradient(45deg,#2ed573,#7bed9f);color:#fff;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;box-shadow:0 2px 8px #2ed5734d;animation:pulse-green 2s infinite}@keyframes pulse-green{0%{transform:scale(1);opacity:1}50%{transform:scale(1.02);opacity:.9}to{transform:scale(1);opacity:1}}.turn-arrow{font-size:10px;animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translate(0)}50%{transform:translate(2px)}}.mini-history{background:#0003;border-radius:10px;padding:8px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1);width:100%;max-width:300px}.history-title{color:#fffc;font-size:10px;font-weight:700;margin-bottom:5px;text-align:center}.history-items{display:flex;flex-direction:column;gap:2px}.mini-history-item{display:flex;justify-content:space-between;align-items:center;padding:2px 6px;border-radius:6px;background:#ffffff0d;font-size:10px}.mini-history-item.pass{opacity:.6}.mini-player{color:gold;font-weight:700;min-width:30px}.mini-action{color:#ffffffe6;text-align:right}.game-status-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10}.status-badge{display:flex;align-items:center;gap:8px;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border-radius:20px;font-weight:700;box-shadow:0 8px 25px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);animation:slideIn .5s ease-out}.status-badge.game-over{background:linear-gradient(45deg,#ff6b6b,#ee5a52)}.status-badge.round-end{background:linear-gradient(45deg,#4ecdc4,#44a08d)}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-60%)}to{opacity:1;transform:translate(-50%,-50%)}}.status-icon{font-size:20px}.table-center.loading{justify-content:center;align-items:center;min-height:150px}.loading-indicator{font-size:36px;animation:spin 2s linear infinite;margin-bottom:10px}.table-center.loading p{color:#ffffffb3;margin:0;font-size:14px}@media(max-width:768px){.table-surface{padding:15px;min-height:150px}.table-logo{font-size:36px}.current-cards{gap:3px}.mini-history{max-width:250px}.game-level{top:8px;left:12px;padding:3px 6px}.turn-indicator-center{bottom:8px;right:12px;padding:3px 8px}}@media(max-width:480px){.table-surface{padding:12px;min-height:120px}.current-play-info{gap:3px}.current-player-name{font-size:12px}.current-play-type{font-size:10px;padding:3px 8px}.status-badge{padding:8px 15px;font-size:14px}}.player-seat{position:relative;color:#fff;min-width:104px;min-height:72px}.seat-meta{display:flex;align-items:center;gap:8px;width:fit-content;padding:6px 8px;background:#061412b8;border:1px solid rgba(255,255,255,.18);border-radius:8px}.seat-avatar{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:#1f7a5c;font-size:12px;font-weight:700}.player-seat.is-active .seat-meta{border-color:#ffd166;box-shadow:0 0 0 2px #ffd16666}.seat-name{font-size:13px;font-weight:700}.seat-count{font-size:12px;opacity:.82}.seat-card-backs{display:flex;margin-top:8px}.seat-card-backs.horizontal{flex-direction:row}.seat-card-backs.vertical{flex-direction:column}.seat-card-backs.horizontal .seat-card-back+.seat-card-back{margin-left:-14px}.seat-card-backs.vertical .seat-card-back+.seat-card-back{margin-top:-22px}.seat-card-back{width:24px;height:34px;border-radius:4px;border:1px solid rgba(255,255,255,.34);background:linear-gradient(135deg,rgba(255,255,255,.22),transparent 40%),linear-gradient(135deg,#234d75,#513c86);box-shadow:0 2px 8px #00000052}.seat-latest-play{position:absolute;display:flex;align-items:center;gap:6px;min-height:42px;pointer-events:none;z-index:10}.seat-play-cards{display:flex;filter:drop-shadow(0 3px 6px rgba(0,0,0,.35))}.seat-play-cards .card+.card{margin-left:-18px}.seat-pass-chip,.seat-action-label{flex:0 0 auto;padding:4px 10px;border-radius:999px;background:#00000094;border:1px solid rgba(255,255,255,.2);font-size:12px;font-weight:700}.seat-action-label{color:#ffef9f}.player-seat-top .seat-latest-play{left:50%;bottom:-44px;transform:translate(-50%)}.player-seat-left .seat-latest-play{left:100%;top:50%;transform:translate(10px,-50%)}.player-seat-right .seat-latest-play{right:100%;top:50%;transform:translate(-10px,-50%);flex-direction:row-reverse}.player-seat-right .seat-play-cards{flex-direction:row-reverse}.player-seat-right .seat-play-cards .card+.card{margin-left:0;margin-right:-18px}.player-seat-bottom .seat-latest-play{left:50%;top:-48px;transform:translate(-50%)}.player-seat-bottom{min-width:0;min-height:0}.seat-debug-hand{display:flex;max-width:240px;overflow:hidden;margin-top:6px}.seat-debug-hand .card+.card{margin-left:-22px}@media(max-width:900px)and (orientation:landscape){.seat-meta{gap:6px;padding:4px 6px}.seat-avatar{width:26px;height:26px;font-size:11px}.seat-name{font-size:12px}.seat-count{font-size:11px}.seat-card-back{width:18px;height:26px}}.game-setup{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 100px);padding:20px}.setup-container{background:#fffffff2;border-radius:20px;padding:40px;max-width:800px;width:100%;box-shadow:0 20px 60px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.setup-container h2{color:#333;margin-bottom:30px;font-size:2.5rem;text-align:center}.setup-container h3{color:#555;margin-bottom:20px;font-size:1.5rem;border-bottom:2px solid #667eea;padding-bottom:10px}.mode-selection{margin-bottom:30px}.mode-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.mode-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border:3px solid transparent;border-radius:15px;padding:30px;cursor:pointer;transition:all .3s ease;text-align:center}.mode-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0003}.mode-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.mode-icon{font-size:3rem;margin-bottom:15px}.mode-card h4{margin:0 0 10px;font-size:1.3rem}.mode-card p{margin:0;font-size:1rem;opacity:.8}.agent-config{margin-bottom:30px}.config-note{background:#e8f4f8;border-left:4px solid #667eea;padding:15px;margin-bottom:20px;border-radius:5px;font-style:italic;color:#555}.player-config-new{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px}.player-slot-new{background-color:#3e3e5a;border-radius:8px;padding:15px;border:1px solid #5a5a7a;transition:all .3s ease}.player-slot-new.human{box-shadow:0 0 15px #76bdff66;border-color:#76bdff}.player-slot-new.ai{box-shadow:0 0 15px #ff6a6a66;border-color:#ff6a6a}.player-slot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.player-slot-header h4{margin:0;color:#e0e0ff}.player-type-toggle-large{display:flex;background-color:#2c2c44;border-radius:8px;overflow:hidden;border:1px solid #5a5a7a}.toggle-option{padding:10px 15px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease;flex-grow:1;justify-content:center;border-bottom:3px solid transparent}.toggle-option:not(.active){background-color:transparent;color:#a0a0c0}.toggle-option.active{background-color:#4a4a6a;color:#fff;font-weight:700}.toggle-option.active[onClick*=human]{border-color:#76bdff}.toggle-option.active[onClick*=ai]{border-color:#ff6a6a}.toggle-option:hover:not(.active){background-color:#383854}.toggle-icon{font-size:1.2rem}.agent-selector-new{margin-top:15px;padding-top:15px;border-top:1px solid #5a5a7a}.agent-selector-new label{display:block;margin-bottom:5px;font-weight:700;color:#c0c0e0}.llm-config-panel{margin-top:22px;padding:18px;background:#f7f8fb;border:1px solid #d9deeb;border-radius:8px;color:#222}.llm-config-header{display:flex;justify-content:space-between;gap:16px;align-items:baseline;margin-bottom:14px}.llm-config-header h3{margin:0;padding:0;border:0;color:#222;font-size:1.05rem}.llm-config-header p{margin:0;color:#5b6472;font-size:.9rem}.llm-config-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.llm-config-grid label{display:flex;flex-direction:column;gap:6px;color:#384052;font-size:.9rem;font-weight:700}.llm-config-grid input{width:100%;min-height:42px;border:1px solid #c9cfdd;border-radius:6px;padding:9px 11px;color:#222;background:#fff;font-size:.95rem}.llm-api-key-field{grid-column:1 / -1}.start-section{text-align:center;margin-top:40px}.setup-extra-options{display:flex;justify-content:center;gap:14px;align-items:center;max-width:620px;margin:0 auto 18px;color:#333;text-align:left}.debug-room-toggle{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:#444}.start-btn{font-size:1.2rem;padding:15px 40px;min-width:200px}@media(max-width:768px){.setup-container{padding:20px;margin:10px}.setup-container h2{font-size:2rem}.mode-cards{grid-template-columns:1fr}.agent-selector{flex-direction:column;align-items:stretch}.agent-selector label{margin-bottom:10px;text-align:center}.agent-select{margin-left:0}.player-config-new,.llm-config-grid{grid-template-columns:1fr}.llm-config-header{align-items:flex-start;flex-direction:column}}.connection-status{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;margin-bottom:15px;border-radius:8px;font-size:.9rem}.connection-status.connected{background-color:#4caf5026;border:1px solid rgba(76,175,80,.4)}.connection-status.disconnected{background-color:#f4433626;border:1px solid rgba(244,67,54,.4)}.status-dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.connected .status-dot{background-color:#4caf50;box-shadow:0 0 8px #4caf5099}.disconnected .status-dot{background-color:#f44336;box-shadow:0 0 8px #f4433699}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-weight:600}.connected .status-text{color:#4caf50}.disconnected .status-text{color:#f44336}.server-url{color:#a0a0c0;font-family:monospace;font-size:.85rem;background-color:#0003;padding:4px 10px;border-radius:4px}.lobby-container{max-width:800px;margin:20px auto;background-color:#2c2c44;border-radius:12px;padding:20px;box-shadow:0 10px 30px #0000004d}.lobby-tabs{display:flex;border-bottom:2px solid #4a4a6a;margin-bottom:20px}.tab-btn{padding:15px 30px;cursor:pointer;background-color:transparent;border:none;color:#a0a0c0;font-size:1.1rem;font-weight:600;transition:all .3s ease;border-bottom:3px solid transparent;margin-bottom:-2px}.tab-btn:hover:not(:disabled){background-color:#383854;color:#fff}.tab-btn:disabled{opacity:.5;cursor:not-allowed}.tab-btn.active{color:#fff;border-color:#76bdff}.join-room-section{padding:20px;text-align:center}.join-room-section h2{color:#e0e0ff;margin-bottom:20px}.join-input-group{display:flex;justify-content:center;gap:10px}.room-id-input{padding:12px 15px;font-size:1rem;border:1px solid #5a5a7a;border-radius:6px;background-color:#1e1e30;color:#fff;width:250px;text-align:center;text-transform:uppercase}.room-id-input::placeholder{color:#8080a0}.join-btn{padding:12px 25px}.waiting-room{text-align:center;padding:50px}.waiting-room h2{color:#e0e0ff}.waiting-room .room-id{background-color:#4a4a6a;color:#fff;padding:10px 20px;border-radius:8px;font-size:1.5rem;letter-spacing:2px;border:2px dashed #76bdff;display:inline-block;margin-top:10px}.server-settings-section{padding:20px}.server-settings-section h2{color:#e0e0ff;margin-bottom:10px;text-align:center}.settings-hint{color:#a0a0c0;text-align:center;margin-bottom:25px;font-size:.95rem}.server-input-group{display:flex;flex-direction:column;gap:10px;max-width:400px;margin:0 auto 20px}.server-input-group label{color:#c0c0e0;font-weight:600}.server-url-input{padding:12px 15px;font-size:1rem;border:1px solid #5a5a7a;border-radius:6px;background-color:#1e1e30;color:#fff;font-family:monospace}.server-url-input::placeholder{color:#8080a0}.connect-btn{padding:12px 25px;font-size:1rem}.connection-error{background-color:#f4433626;border:1px solid rgba(244,67,54,.4);color:#ff6b6b;padding:12px 15px;border-radius:6px;text-align:center;margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto}.server-tips{background-color:#76bdff1a;border:1px solid rgba(118,189,255,.3);border-radius:8px;padding:15px 20px;margin-top:20px}.server-tips h4{color:#76bdff;margin-bottom:10px}.server-tips ul{list-style:none;padding:0;margin:0}.server-tips li{color:#c0c0e0;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.9rem}.server-tips li:last-child{border-bottom:none}.server-tips code{background-color:#0000004d;padding:2px 8px;border-radius:4px;font-family:monospace;color:#ffcc80}.not-connected-hint{text-align:center;padding:40px 20px}.not-connected-hint h3{color:#ffcc80;margin-bottom:10px}.not-connected-hint p{color:#a0a0c0}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}::selection{background:#667eea4d;color:inherit}::-moz-selection{background:#667eea4d;color:inherit}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.hidden{display:none!important}.visible{display:block!important}.fade-in{animation:fadeIn .3s ease-in}.fade-out{animation:fadeOut .3s ease-out}.slide-in{animation:slideIn .3s ease-out}.bounce-in{animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
