:root{color:#18201c;background:#f4f1e8;font-family:Inter,Noto Sans TC,Microsoft JhengHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}.appShell{min-height:100vh;padding:18px;display:flex;flex-direction:column;gap:14px}.topBar{min-height:68px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;color:#f7f1de;background:#173d35;border:1px solid #0d2a24;border-radius:8px;box-shadow:0 12px 28px #151e1b29}.topBar h1,.topBar p,.panelBlock h2{margin:0}.topBar h1{font-size:22px;line-height:1.1}.topBar p{margin-top:4px;color:#d9cda6;font-size:14px}.topActions{display:flex;gap:8px}.iconButton,.primaryButton,.secondaryButton,.readyButton,.tingButton,.winButton{min-height:42px;border:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.iconButton{width:42px;color:#173d35;background:#f7f1de}.primaryButton{color:#fff9ed;background:#b64c38;padding:0 18px}.secondaryButton,.readyButton,.tingButton{color:#173d35;background:#e2d6b4;padding:0 14px}.readyButton{width:100%}.readyButton.ready,.winButton{color:#fff9ed;background:#1f6f8b}.authPanel,.lobbyPanel{width:min(720px,100%);margin:auto;padding:18px;display:grid;gap:14px;background:#fffaf0;border:1px solid #dbd0b7;border-radius:8px}.authPanel label,.joinBox{display:grid;gap:8px}input{width:100%;min-height:44px;padding:0 12px;color:#17221e;background:#fff;border:1px solid #cfc3aa;border-radius:8px}.identity{display:flex;justify-content:space-between;gap:12px;padding:12px;background:#f1ead9;border-radius:8px}.modePicker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.modeOption,.botButton{min-height:38px;border:1px solid #cfc3aa;border-radius:8px;color:#173d35;background:#fffdf5;font-weight:800}.modeOption.active,.botButton{color:#fff9ed;background:#1f6f8b;border-color:#1f6f8b}.gameLayout{flex:1;min-height:0;display:grid;grid-template-columns:280px minmax(0,1fr) 300px;gap:14px}.sidePanel,.tableSurface{min-width:0}.sidePanel{display:flex;flex-direction:column;gap:12px}.panelBlock{padding:14px;background:#fffaf0;border:1px solid #dbd0b7;border-radius:8px}.panelBlock h2{margin-bottom:10px;font-size:15px}.seatList{display:grid;gap:8px}.seatRow{min-height:58px;display:grid;grid-template-columns:38px minmax(0,1fr) auto;align-items:center;gap:10px}.seatRow strong,.seatRow p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seatRow p{margin:2px 0 0;color:#61726a;font-size:12px}.windBadge,.statePill{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;font-weight:800}.windBadge{width:34px;height:34px;color:#fffaf0;background:#173d35}.statePill{min-width:58px;min-height:28px;padding:0 8px;color:#52635c;background:#ece3cc;font-size:12px}.statePill.ready{color:#fff;background:#1f6f8b}.botButton{min-width:58px;min-height:30px}.compactStats dl{margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.compactStats dt{color:#61726a;font-size:12px}.compactStats dd{margin:2px 0 0;font-weight:800}.riichiStats dl{margin:0 0 10px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.riichiStats dt{color:#61726a;font-size:12px}.riichiStats dd{margin:2px 0 0;font-weight:800}.doraStrip{display:flex;align-items:center;gap:6px;color:#61726a;font-size:12px;font-weight:800}.tableSurface{display:grid;grid-template-rows:minmax(420px,1fr) auto auto;gap:12px}.mahjongTable,.tableEmpty{position:relative;min-height:420px;overflow:hidden;background:#1f5a45;border:1px solid #123a2d;border-radius:8px;box-shadow:inset 0 0 0 8px #fffaf014}.tableEmpty{display:grid;place-items:center;align-content:center;gap:10px;color:#fffaf0;font-weight:800}.tableSeat{position:absolute;display:grid;gap:8px;min-width:210px}.seatPosition0{left:50%;bottom:18px;transform:translate(-50%)}.seatPosition1{right:18px;top:50%;transform:translateY(-50%)}.seatPosition2{left:50%;top:18px;transform:translate(-50%)}.seatPosition3{left:18px;top:50%;transform:translateY(-50%)}.playerPlate{min-height:42px;padding:8px 10px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;align-items:center;color:#fffaf0;background:#091c15b8;border:1px solid rgba(255,250,240,.2);border-radius:8px}.playerPlate.active{border-color:#f5c44f;box-shadow:0 0 0 2px #f5c44f47}.playerPlate strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playerPlate small{color:#d9cda6}.meldStrip,.discardRiver,.miniTileRow,.patterns{display:flex;flex-wrap:wrap;gap:4px}.discardRiver{min-height:58px;max-width:260px}.tableCenter{position:absolute;left:50%;top:50%;width:min(220px,42%);min-height:128px;transform:translate(-50%,-50%);display:grid;place-items:center;gap:8px;color:#fffaf0;background:#0d2a2494;border:1px solid rgba(255,250,240,.18);border-radius:8px}.tableInfo{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;text-align:center;font-size:12px;font-weight:800}.tableInfo span{min-width:0;padding:4px 5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:#fffaf01f;border-radius:6px}.handDock{min-height:106px;padding:18px 10px 10px;display:flex;align-items:end;gap:5px;overflow-x:auto;background:#173d35;border-radius:8px}.tileButton{position:relative;flex:0 0 44px;width:44px;height:68px;padding:2px;display:inline-flex;align-items:center;justify-content:center;color:#18201c;background:#fffdf5;border:1px solid #d7c7a1;border-radius:6px;box-shadow:0 4px #c8b783;font-size:18px;font-weight:900;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease,margin-left .12s ease}.tileButton.highlighted{border-color:#f5c44f}.tileButton.drawn{margin-left:10px}.tileButton.tingHint,.tileButton.actionHint{transform:translateY(-8px)}.tileButton.tingHint{border-color:#1f6f8b;box-shadow:0 4px #18586f}.tileButton.actionHint{border-color:#b64c38;box-shadow:0 4px #8a392b}.tileButton.selected{transform:translateY(-14px);border-color:#f5c44f;box-shadow:0 5px #b98d1f}.tileButton.tingHint:disabled,.tileButton.actionHint:disabled{opacity:1}.tileImage{width:100%;height:100%;object-fit:contain;display:block}.tileFallback{line-height:1.05}.miniTile{position:relative;width:24px;min-width:24px;height:34px;padding:1px;display:inline-flex;align-items:center;justify-content:center;color:#18201c;background:#fffdf5;border:1px solid #d7c7a1;border-radius:5px;font-size:13px;font-weight:800;overflow:hidden}.tileButton.redFive:after,.miniTile.redFive:after{content:"";position:absolute;right:3px;top:3px;width:7px;height:7px;border-radius:999px;background:#d82e2f;box-shadow:0 0 0 1px #fffdf5}.miniTile.redFive:after{right:2px;top:2px;width:5px;height:5px}.miniTile.flower{color:#8a3d2f;background:#ffe8d6}.actionDock{min-height:52px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px}.tingButton{color:#fff9ed;background:#173d35}.tingHintList{display:grid;gap:8px}.tingHintRow{display:grid;grid-template-columns:auto auto auto minmax(0,1fr);align-items:center;gap:6px;font-size:13px;font-weight:800}.tingHintRow .miniTileRow{min-width:0}.notice{min-height:42px;padding:8px 12px;display:flex;align-items:center;gap:8px;border-radius:8px}.notice.error{color:#fff;background:#9d3f35}.notice button{margin-left:auto;color:inherit;background:transparent;border:0}.muted{color:#6b776f;font-size:14px}.settlement h2{display:flex;align-items:center;gap:6px}.settlement strong{display:block;margin-bottom:10px}.patterns span{padding:4px 7px;color:#173d35;background:#e2d6b4;border-radius:6px;font-size:12px;font-weight:800}.payments p{margin:8px 0 0;font-size:14px}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1120px){.gameLayout{grid-template-columns:1fr;grid-template-rows:auto auto auto}.sidePanel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.tableSurface{order:2}}@media(max-width:720px){.appShell{padding:10px}.topBar{align-items:start}.sidePanel{grid-template-columns:1fr}.tableSurface{grid-template-rows:minmax(320px,1fr) auto auto}.mahjongTable,.tableEmpty{min-height:320px}.tableSeat{min-width:136px;gap:5px}.discardRiver{max-width:142px;min-height:44px}.playerPlate{min-height:36px;padding:6px 7px;gap:5px;font-size:12px}.tableCenter{width:min(158px,48%);min-height:104px;font-size:12px}.tableInfo{gap:4px;font-size:11px}.handDock{position:sticky;bottom:0;z-index:4;min-height:92px;padding:16px 8px 8px}.actionDock{position:sticky;bottom:92px;z-index:5;padding:4px;background:#f4f1e8}.tileButton{flex-basis:38px;width:38px;height:62px;font-size:16px}.tileButton.drawn{margin-left:8px}}
