:root{color-scheme:light;--bg-0: #eef3f7;--bg-1: #e3ebf1;--surface: #ffffff;--surface-2: #f3f6f9;--panel: #ffffff;--ink: #1b2733;--text: #1b2733;--muted: #566879;--line: rgba(22, 42, 62, .1);--line-strong: rgba(22, 42, 62, .18);--jade: #12a06a;--jade-deep: #0c8456;--jade-soft: #e7f6ee;--red: #d8453a;--red-soft: #fbe9e7;--gold: #c4892b;--gold-soft: #b9842c;--shadow: 0 8px 24px rgba(28, 48, 68, .08);--shadow-lg: 0 18px 44px rgba(28, 48, 68, .14);--radius: 12px;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--ink);background:radial-gradient(circle at 50% -8%,rgba(18,160,106,.08),transparent 42%),radial-gradient(circle at 100% 100%,rgba(196,137,43,.06),transparent 40%),linear-gradient(180deg,var(--bg-0),var(--bg-1))}.auth-shell{min-height:100vh;height:auto;align-items:center;justify-content:center;padding:28px}.auth-card{width:min(480px,100%);padding:24px;border:1px solid rgba(18,160,106,.18);border-radius:18px;background:linear-gradient(180deg,#fffffff2,#f8fbfaef);box-shadow:var(--shadow-lg)}.loading-card{min-height:150px;display:grid;align-content:center}.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px}.auth-brand strong{display:block;font-size:27px;line-height:1.15}.auth-brand small{display:block;margin-top:4px;color:var(--muted);font-size:13px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:4px;margin-bottom:18px;border-radius:12px;background:var(--surface-2)}.auth-tabs button{height:44px;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:10px;color:var(--muted);font-weight:800}.auth-tabs button.on{color:var(--jade-deep);background:#fff;box-shadow:0 4px 12px #1c304414}.auth-form{display:grid;gap:12px}.auth-form label{display:grid;gap:7px;font-weight:800;color:#314457}.auth-form label span{font-size:13px}.auth-form input{height:48px;width:100%;padding:0 14px;border:1px solid var(--line-strong);border-radius:12px;background:#fff;font-weight:750}.auth-error{padding:10px 12px;border:1px solid rgba(216,69,58,.22);border-radius:10px;background:var(--red-soft);color:#a7352d;font-weight:750}.auth-submit{height:50px;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;background:var(--jade);color:#fff;font-weight:900;box-shadow:0 12px 24px #12a06a38}.auth-submit:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.auth-note{margin:14px 2px 0;color:var(--muted);font-size:13px;line-height:1.55}.auth-announcement,.hall-announcement{padding:11px 13px;border:1px solid rgba(196,137,43,.24);border-radius:12px;background:linear-gradient(135deg,#fff8e9,#fff);color:#7b551b;font-weight:800;line-height:1.5}.auth-announcement{margin-bottom:14px}.hall-announcement{margin-top:-2px}.admin-shell{min-height:100vh;display:grid;grid-template-columns:248px minmax(0,1fr);background:linear-gradient(180deg,#eef5f2,#e8eef3);color:var(--ink)}.admin-nav{min-height:100vh;display:flex;flex-direction:column;gap:18px;padding:18px;border-right:1px solid var(--line);background:#ffffffd9}.admin-brand{display:flex;align-items:center;gap:12px;padding-bottom:8px}.admin-brand strong,.admin-top strong{display:block;font-size:20px}.admin-brand small,.admin-top span,.admin-account small{display:block;color:var(--muted);font-size:12px}.admin-nav nav{display:grid;gap:7px}.admin-nav nav button,.admin-back,.admin-account button,.admin-toolbar button,.admin-create-user button,.admin-table button,.settings-panel .primary,.admin-denied button{min-height:40px;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);border-radius:10px;background:#fff;font-weight:850}.admin-nav nav button{justify-content:flex-start;padding:0 12px;color:#34485b}.admin-nav nav button.on,.settings-panel .primary,.admin-create-user button{color:#fff;border-color:var(--jade);background:var(--jade)}.admin-back{margin-top:auto;color:var(--jade-deep)}.admin-main{min-width:0;padding:18px;overflow:auto}.admin-top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.admin-account{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--line);border-radius:12px;background:#fff}.admin-error,.admin-toast{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:11px 12px;border-radius:10px;font-weight:850}.admin-error{border:1px solid rgba(216,69,58,.24);background:var(--red-soft);color:#a7352d}.admin-toast{border:1px solid rgba(18,160,106,.2);background:var(--jade-soft);color:var(--jade-deep)}.admin-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.admin-metric,.admin-panel{border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow)}.admin-metric{display:grid;gap:8px;padding:16px}.admin-metric svg{color:var(--jade)}.admin-metric span{color:var(--muted);font-size:13px}.admin-metric strong{font-size:28px}.admin-panel{padding:14px}.admin-panel.wide{grid-column:1 / -1}.admin-panel h3,.admin-toolbar h3{display:flex;align-items:center;gap:8px;margin:0}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.admin-search{min-width:min(360px,100%);height:42px;display:flex;align-items:center;gap:8px;padding:0 12px;border:1px solid var(--line);border-radius:10px;background:var(--surface-2)}.admin-search input,.admin-create-user input,.admin-create-user select,.admin-field input,.admin-field select,.admin-field textarea,.engine-settings input,.admin-table select{width:100%;min-width:0;border:1px solid var(--line-strong);border-radius:10px;background:#fff;padding:0 10px;font-weight:750}.admin-search input{border:0;background:transparent;padding:0}.admin-create-user{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:12px}.admin-create-user input,.admin-create-user select,.admin-field input,.admin-field select,.engine-settings input,.admin-table select{height:40px}.admin-table{display:grid;gap:8px}.admin-table article{display:grid;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.users-table article{grid-template-columns:minmax(180px,1.4fr) 120px 120px 80px 90px 44px}.room-table article,.games-table article{grid-template-columns:160px 1.2fr 1fr 140px 96px}.admin-user-cell{min-width:0;display:flex;align-items:center;gap:10px}.admin-user-cell span,.admin-table strong{min-width:0;display:grid}.admin-user-cell b,.admin-table strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-user-cell small,.admin-table small,.admin-help{color:var(--muted)}.admin-table .danger{color:#a7352d;border-color:#d8453a3d}.admin-table .danger:disabled{opacity:.4}.outcome.win{color:var(--jade-deep)}.outcome.loss{color:#a7352d}.settings-panel{max-width:980px}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.admin-field{display:grid;gap:6px;font-weight:850}.admin-field textarea{min-height:96px;padding:10px;resize:vertical}.admin-toggle{min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;border:1px solid var(--line);border-radius:12px;background:var(--surface-2);font-weight:850}.admin-toggle b{width:48px;height:28px;padding:3px;border-radius:999px;background:#9aa8b5}.admin-toggle i{display:block;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .16s}.admin-toggle.on{border-color:#12a06a59;background:var(--jade-soft)}.admin-toggle.on b{background:var(--jade)}.admin-toggle.on i{transform:translate(20px)}.engine-settings{display:grid;gap:10px}.engine-settings article{display:grid;grid-template-columns:80px 1fr 100px 180px;gap:8px;align-items:center}.admin-list{display:grid;gap:8px}.admin-list p{margin:0;display:grid;grid-template-columns:120px 120px 1fr auto;gap:8px;align-items:center;padding:9px 10px;border:1px solid var(--line);border-radius:10px;background:var(--surface-2)}.admin-list.compact p{grid-template-columns:120px 1fr auto}.admin-denied{min-height:100vh;display:grid;place-content:center;justify-items:center;gap:12px;padding:24px;text-align:center}.account-panel{display:grid;grid-template-columns:auto 1fr;gap:10px 12px;align-items:center;padding:12px;margin:4px 0 14px;border:1px solid rgba(18,160,106,.18);border-radius:12px;background:linear-gradient(135deg,var(--jade-soft),#fff)}.account-panel strong,.user-main strong{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-panel span,.user-main span{display:block;color:var(--muted);font-size:12px}.account-panel button{height:38px;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid rgba(18,160,106,.22);border-radius:10px;background:#fff;color:var(--jade-deep);font-weight:850}.account-panel .logout-btn{color:#a7352d;border-color:#d8453a38}.admin-dialog{width:min(920px,calc(100vw - 28px));max-height:min(720px,calc(100vh - 28px));display:flex;flex-direction:column;gap:14px;padding:18px;border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:var(--shadow-lg)}.admin-dialog header,.admin-dialog footer{display:flex;align-items:center;justify-content:space-between;gap:14px}.admin-dialog header span{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:900}.admin-dialog header small{display:block;margin-top:4px;color:var(--muted)}.admin-dialog footer{padding-top:4px;color:var(--muted);font-size:13px}.admin-dialog footer span{display:flex;align-items:center;gap:6px}.admin-dialog footer button{height:40px;min-width:96px;border-radius:10px;background:var(--jade);color:#fff;font-weight:900}.user-list{min-height:0;overflow:auto;display:grid;gap:10px;padding-right:2px}.user-row{display:grid;grid-template-columns:minmax(210px,1.2fr) minmax(130px,.7fr) 130px 120px 44px;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.user-row.disabled{background:#f8f9fa;opacity:.76}.user-main{min-width:0;display:flex;align-items:center;gap:10px}.admin-badge{display:inline-flex;align-items:center;gap:4px;margin-top:4px;color:var(--gold);font-size:12px;font-style:normal;font-weight:850}.user-row input,.user-row select{height:40px;min-width:0;border:1px solid var(--line-strong);border-radius:10px;background:#fff;padding:0 10px;font-weight:750}.icon-btn.danger{color:#a7352d}.icon-btn.danger:disabled{opacity:.35;cursor:not-allowed}.admin-empty{min-height:120px;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--muted);border:1px dashed var(--line-strong);border-radius:12px}.ops-shell{grid-template-columns:272px minmax(0,1fr);background:#f4f7f5}.ops-nav{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:14px;padding:18px 12px;border-right:1px solid rgba(11,41,38,.18);background:#12312f;color:#edf7f2}.ops-brand,.ops-account{display:flex;align-items:center;gap:11px}.ops-brand{padding:4px 8px 14px;border-bottom:1px solid rgba(255,255,255,.12)}.ops-brand strong{display:block;font-size:20px;letter-spacing:0}.ops-brand small,.ops-nav small,.ops-top span,.ops-account small,.ops-metric small,.ops-section header p,.ops-note,.ops-table small,.ops-history small,.ops-field small,.ops-savebar small{color:var(--muted);font-size:12px}.ops-nav small,.ops-brand small{color:#edf7f29e}.ops-nav nav{min-height:0;overflow:auto;display:grid;gap:6px;padding-right:2px}.ops-nav nav button,.ops-back,.ops-toolbar button,.ops-table button,.ops-create-user button,.preset-actions button,.ops-add-row,.ops-savebar button,.ops-history button,.ops-modal footer button{min-height:40px;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid #dfe7e2;border-radius:10px;background:#fff;font-weight:800}.ops-nav nav button{justify-content:flex-start;min-height:48px;padding:9px 11px;border-color:transparent;background:transparent;color:#edf7f2d1}.ops-nav nav button span{display:grid;gap:1px;text-align:left}.ops-nav nav button.on{color:#0d2a27;border-color:#ffffff14;background:#f5fbf7;box-shadow:0 12px 28px #00000029}.ops-back{margin-top:auto;color:#d9efe5;border-color:#ffffff24;background:#ffffff0f}.ops-main{min-width:0;padding:22px 24px 92px}.ops-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.ops-top strong{display:block;margin-top:2px;font-size:28px;letter-spacing:0}.ops-top-status{display:flex;align-items:center;gap:9px}.ops-account{padding:6px;border:1px solid #dfe7e2;border-radius:12px;background:#fff}.ops-account span{display:grid;min-width:92px;font-weight:850}.ops-account button{height:34px;display:flex;align-items:center;gap:6px;padding:0 10px;border:1px solid rgba(216,69,58,.18);border-radius:9px;color:#a7352d;font-weight:850}.ops-pill{min-height:28px;display:inline-flex;align-items:center;justify-content:center;padding:0 10px;border:1px solid #dfe7e2;border-radius:999px;background:#fff;color:#405568;font-size:12px;font-weight:900;white-space:nowrap}.ops-pill.good{color:var(--jade-deep);border-color:#12a06a38;background:#ecf8f2}.ops-pill.warn{color:#946515;border-color:#da9d3452;background:#fff8e8}.ops-pill.bad{color:#a7352d;border-color:#d8453a42;background:var(--red-soft)}.ops-dashboard{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.ops-metric,.ops-section{border:1px solid #dde7e2;border-radius:12px;background:#fff;box-shadow:0 10px 26px #172f2b0f}.ops-metric{min-height:116px;display:grid;align-content:space-between;gap:8px;padding:15px}.ops-metric span{display:flex;align-items:center;justify-content:space-between;color:var(--jade);font-weight:850}.ops-metric strong{font-size:28px;letter-spacing:0}.ops-section{min-width:0;overflow:hidden;padding:18px}.ops-dashboard .ops-section{grid-column:span 3}.ops-section header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #edf1ee}.ops-section h3{display:flex;align-items:center;gap:8px;margin:0;font-size:19px}.ops-section header p{max-width:520px;margin:2px 0 0;text-align:right}.ops-two-col{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.78fr);gap:14px;align-items:start}.ops-engine-layout{grid-template-columns:1fr}.ops-engine-layout .ops-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.ops-engine-layout .ops-section:nth-child(2){background:linear-gradient(180deg,#fff,#fbfdfb)}.ops-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.ops-create-user{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-bottom:12px}.ops-create-user input,.ops-create-user select,.ops-field input,.ops-field select,.ops-field textarea,.ops-presets input,.engine-compute-control select,.engine-strength-row input[type=number],.ops-levels input,.ops-table select{width:100%;min-width:0;border:1px solid #d5dfda;border-radius:9px;background:#fff;padding:0 10px;font-weight:720}.ops-create-user input,.ops-create-user select,.ops-field input,.ops-field select,.ops-presets input,.engine-compute-control select,.engine-strength-row input[type=number],.ops-levels input,.ops-table select{height:40px}.ops-field{display:grid;gap:7px;font-weight:800}.ops-field span{display:flex;align-items:center;justify-content:space-between;gap:10px}.ops-field textarea{min-height:118px;padding:10px;resize:vertical}.ops-card-grid,.ops-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.ops-form-grid.top{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:14px}.ops-form-stack{display:grid;gap:10px}.ops-toggle{min-height:52px;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 11px;border:1px solid #dce6e1;border-radius:10px;background:#fbfcfb;text-align:left}.ops-toggle span{display:grid;gap:2px}.ops-toggle i{width:42px;height:24px;flex:0 0 auto;padding:3px;border-radius:999px;background:#9aa8b5}.ops-toggle i:before{content:"";display:block;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .16s}.ops-toggle.on{border-color:#12a06a4d;background:#edf8f2}.ops-toggle.on i{background:var(--jade)}.ops-toggle.on i:before{transform:translate(18px)}.ops-table,.ops-presets,.ops-levels,.ops-activity,.ops-audit,.ops-history,.ops-diff{display:grid;gap:8px}.ops-table article,.ops-presets article,.ops-levels article,.ops-audit article,.ops-history article,.ops-diff article{display:grid;align-items:center;gap:10px;padding:10px;border:1px solid #e0e7e3;border-radius:10px;background:#fbfcfb}.ops-table.users article{grid-template-columns:minmax(210px,1.5fr) 122px 122px 76px 90px 44px}.ops-table.rooms article{grid-template-columns:150px 1.3fr 1fr 130px 96px}.ops-table.games article{grid-template-columns:170px 1fr 1fr 110px 60px}.ops-table article.disabled{opacity:.72;background:#f8f9fb}.ops-user-cell{min-width:0;display:flex;align-items:center;gap:10px}.ops-user-cell span,.ops-table strong,.ops-history article div{min-width:0;display:grid}.ops-user-cell b,.ops-table strong,.ops-history b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ops-table .danger,.preset-actions .danger,.ops-modal .danger{color:#a7352d;border-color:#d8453a40;background:#fff}.ops-table button:disabled,.preset-actions button:disabled{opacity:.4;cursor:not-allowed}.ops-presets article{grid-template-columns:34px 1fr 110px 96px 132px 190px}.drag-handle{height:34px;display:grid;place-items:center;border-radius:9px;background:#eef4f1;color:var(--jade-deep);font-weight:900}.preset-actions{display:grid;grid-template-columns:1fr 1fr 40px;gap:6px}.ops-add-row{min-height:46px;color:var(--jade-deep);border-style:dashed;background:#fff}.ops-levels article{grid-template-columns:72px minmax(130px,1fr) minmax(150px,1fr) 90px minmax(170px,1.2fr) 96px;gap:8px}.ops-levels .ops-engine-level-card{display:grid;grid-template-columns:180px minmax(0,1fr);gap:18px;align-items:stretch;padding:16px;background:linear-gradient(180deg,#fff,#fbfdfc)}.engine-level-title{min-width:0;display:flex;flex-direction:column;justify-content:space-between;gap:14px;padding:12px;border:1px solid #e1e9e5;border-radius:10px;background:#f7faf8}.engine-level-title span{display:block;margin-bottom:4px;color:#687887;font-size:12px;font-weight:800}.engine-level-title strong{color:#0f2c3f;font-size:24px}.engine-level-title .ops-toggle{min-height:42px;background:#fff}.engine-level-fields{min-width:0;display:grid;grid-template-columns:minmax(150px,.9fr) minmax(170px,1fr) 110px minmax(260px,1.45fr);gap:12px;align-items:start}.engine-compute-control{display:grid;gap:8px}.engine-strength-row{display:grid;grid-template-columns:minmax(120px,1fr) 88px 42px;gap:8px;align-items:center}.engine-strength-row input[type=range]{width:100%;accent-color:var(--jade)}.engine-strength-row b{color:#526579;font-size:13px}.engine-compute-control small{color:#667685;font-size:12px;line-height:1.45}.ops-levels-head{display:grid;grid-template-columns:72px minmax(130px,1fr) minmax(150px,1fr) 90px minmax(170px,1.2fr) 96px;gap:8px;padding:0 10px 6px;color:#667685;font-size:12px;font-weight:850}.ops-levels article>strong{display:inline-flex;align-items:center;min-height:32px;color:#18344a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ops-levels .ops-toggle{min-height:40px;justify-content:center;gap:7px;padding:0 8px}.ops-levels .ops-toggle span{display:block;font-size:13px;text-align:center;white-space:nowrap}.ops-levels .ops-toggle i{width:34px;height:20px;padding:2px}.ops-levels .ops-toggle i:before{width:16px;height:16px}.ops-levels .ops-toggle.on i:before{transform:translate(14px)}.ops-note{margin:12px 0 0;padding:10px 12px;border:1px dashed rgba(218,157,52,.4);border-radius:10px;background:#fffaf0}.ops-activity p{display:grid;grid-template-columns:130px 1fr auto;gap:10px;margin:0;padding:10px;border:1px solid var(--line);border-radius:10px;background:var(--surface-2)}.ops-config-strip{display:flex;flex-wrap:wrap;gap:8px}.ops-audit article{grid-template-columns:120px 150px 1fr auto}.ops-history article{grid-template-columns:1fr 90px 92px}.ops-diff article{grid-template-columns:150px minmax(0,1fr) minmax(0,1fr)}.ops-diff span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:8px;border-radius:8px;background:#fff;color:#526579;font-size:12px}.ops-empty{min-height:128px;display:grid;place-items:center;border:1px dashed var(--line-strong);border-radius:12px;color:var(--muted);background:var(--surface-2)}.ops-savebar{position:fixed;right:20px;bottom:18px;left:300px;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid rgba(18,160,106,.28);border-radius:14px;background:#fffffff0;box-shadow:0 18px 48px #1934462e;backdrop-filter:blur(14px)}.ops-savebar span{display:grid;gap:2px}.ops-savebar .primary,.ops-modal .primary{color:#fff;border-color:var(--jade);background:var(--jade)}.ops-modal{width:min(520px,calc(100vw - 28px));display:grid;gap:16px;padding:18px;border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:var(--shadow-lg)}.ops-modal header{display:flex;gap:12px;align-items:flex-start}.ops-modal header strong{display:block;font-size:20px}.ops-modal header p{margin:4px 0 0;color:var(--muted)}.ops-modal footer{display:flex;justify-content:flex-end;gap:10px}button,select,input{font:inherit;color:inherit}button{border:0;background:none;cursor:pointer}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid rgba(12,132,86,.72);outline-offset:3px}.app{min-height:100vh;height:100vh;display:flex;flex-direction:column}.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:12px 22px;border-bottom:1px solid var(--line);background:#ffffffd9;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:linear-gradient(145deg,#e9b65c,#c4892b);color:#3a2a10;font-family:Songti SC,Georgia,serif;font-size:24px;font-weight:800;box-shadow:inset 0 1px #ffffff80,0 4px 12px #c4892b4d}.brand strong{display:block;color:var(--ink);font-size:19px;letter-spacing:.3px}.brand small{color:var(--muted);font-size:12px}.topbar-center{min-width:0;display:flex;justify-content:center;gap:10px}.mode-pill{min-width:0;display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:var(--jade-soft);color:var(--jade-deep);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mode-pill.subtle{color:var(--muted);background:var(--surface-2)}.mode-pill.engine-fallback{color:#9a6a1e;background:#fbf2df;border-color:#c4892b59}.mode-pill svg{color:var(--jade)}.topbar-actions{display:flex;justify-content:flex-end;gap:8px}.icon-btn{width:42px;height:42px;display:grid;place-items:center;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);transition:background .15s,border-color .15s}.icon-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--line-strong)}.icon-btn:disabled{opacity:.4;cursor:default}.xq-avatar{flex:0 0 auto;display:grid;place-items:center;border-radius:50%;color:#fff;font-family:Songti SC,Georgia,serif;font-weight:800;box-shadow:inset 0 2px 4px #ffffff59,inset 0 -3px 6px #0000002e,0 3px 8px #1c304433}.xq-avatar.ai{background:radial-gradient(circle at 32% 28%,#4a7d97,#234a5c);color:#d9f1ea}.xq-avatar.waiting{background:var(--surface-2);color:var(--muted);box-shadow:inset 0 0 0 1px var(--line-strong)}.rank-emblem{flex:0 0 auto;filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}.diff-stars{display:inline-flex;gap:2px;color:var(--gold)}.diff-stars svg{color:#162a3e2e}.diff-stars svg.on{color:#e0a23a}.hall{flex:1;min-height:0;overflow:auto;display:grid;align-content:start;gap:18px;width:100%;max-width:1120px;margin:0 auto;padding:clamp(18px,3vw,36px)}.hall-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px}.profile-card{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:16px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);justify-self:start}.profile-meta{display:grid;gap:5px;min-width:0}.profile-name{width:7.5em;max-width:160px;min-height:42px;border:0;background:transparent;color:var(--ink);font-size:17px;font-weight:700;padding:2px 4px;border-radius:6px}.profile-name:hover,.profile-name:focus{background:var(--surface-2)}.profile-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.rating-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;background:var(--jade-soft);color:var(--jade-deep);font-size:12px;font-weight:700}.profile-stats{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:12px;color:var(--muted)}.profile-stats .stat b{color:var(--ink);font-size:13px;margin-right:1px}.profile-stats .win b{color:var(--jade)}.profile-stats .loss b{color:var(--red)}.profile-stats .rate{display:inline-flex;align-items:center;gap:4px;color:var(--gold)}.hall-title{display:flex;align-items:center;gap:10px;justify-self:center}.hall-title strong{display:block;color:var(--ink);font-size:18px}.hall-title small{color:var(--muted);font-size:12px}.brand-mark.big{width:46px;height:46px;font-size:26px}.hall-header-actions{display:flex;gap:8px;justify-self:end}.mode-switch{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;padding:5px;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.mode-switch button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:50px;border-radius:9px;color:var(--muted);font-size:16px;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.mode-switch button:hover{color:var(--ink);background:var(--surface-2)}.mode-switch button.on{color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep));box-shadow:0 8px 18px #12a06a47}.hall-controls{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.ctrl-group{display:inline-flex;align-items:center;gap:6px;padding:6px 8px;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.ctrl-icon{display:grid;place-items:center;color:var(--muted);padding:0 2px}.ctrl-chip{min-width:44px;min-height:42px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;color:var(--ink);font-size:13px;font-variant-numeric:tabular-nums;border:1px solid transparent}.ctrl-chip:hover{background:var(--surface-2)}.ctrl-chip.on{background:var(--jade-soft);color:var(--jade-deep);border-color:#12a06a59}.ctrl-chip.icon{padding:0 8px}.side-disc{width:22px;height:22px;display:grid;place-items:center;border-radius:50%;font-family:Songti SC,serif;font-size:13px;font-weight:800;color:#fff}.side-disc.red{background:linear-gradient(145deg,#e0594a,#b5392c)}.side-disc.black{background:linear-gradient(145deg,#41566a,#232f3c)}.ctrl-chip.swatch{width:42px;min-width:42px;height:42px;border-radius:8px;padding:0}.ctrl-chip.swatch.wood{background:radial-gradient(circle at 40% 35%,#f4dca9,#cf9c55)}.ctrl-chip.swatch.jade{background:radial-gradient(circle at 40% 35%,#c4e6d3,#71b092)}.ctrl-chip.swatch.on{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--jade)}.start-dock{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:18px;padding:14px 16px;border-radius:12px;border:1px solid rgba(18,160,106,.24);background:linear-gradient(135deg,#fffffff0,#e7f6eedb);box-shadow:var(--shadow)}.start-copy{min-width:0;display:grid;gap:4px}.start-copy span{color:var(--jade-deep);font-size:12px;font-weight:700}.start-copy strong{color:var(--ink);font-size:18px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.start-primary{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 20px;border-radius:10px;color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep));font-weight:800;box-shadow:0 10px 22px #12a06a47}.start-primary.subtle{color:var(--jade-deep);background:var(--jade-soft);box-shadow:none;border:1px solid rgba(18,160,106,.28)}.tables-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.tables-grid.online{grid-template-columns:repeat(2,1fr)}.table-card{display:grid;gap:8px;padding:11px;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);text-align:left;transition:transform .15s,border-color .15s,box-shadow .15s}.table-card:hover{transform:translateY(-1px);border-color:#12a06a73;box-shadow:var(--shadow-lg)}.table-card.preferred{border-color:#c4892b80}.table-card.single{max-width:360px}.table-felt{display:grid;gap:5px;padding:10px;border-radius:10px;background:linear-gradient(170deg,#f6f9f7,#eef4f1);border:1px solid var(--line)}.table-felt.compact{padding:12px 10px}.seat{display:flex;align-items:center;gap:10px;min-width:0}.seat-meta{display:grid;gap:3px;min-width:0}.seat-meta strong{color:var(--ink);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seat-badge{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:11px}.seat-note{color:var(--muted);font-size:11px}.seat.empty{opacity:.9}.seat-ghost{width:44px;height:44px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;border:1.5px dashed rgba(18,160,106,.4);color:var(--jade)}.seat-cta{color:var(--jade);font-size:11px}.table-divider{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:1px;margin:1px 0}.table-divider:before,.table-divider:after{content:"";height:1px;flex:1;background:var(--line)}.table-divider span,.table-divider svg{padding:0 8px;color:var(--jade)}.table-foot{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:0 4px;color:var(--muted);font-size:12px}.foot-time{display:inline-flex;align-items:center;gap:5px;color:var(--gold-soft)}.foot-hint{display:inline-flex;align-items:center;gap:5px}.foot-cta{display:inline-flex;align-items:center;gap:4px;color:var(--jade-deep);font-weight:700;padding:4px 10px;border-radius:999px;background:var(--jade-soft)}.table-card:hover .foot-cta{background:#12a06a2e}.table-card.room{gap:12px}.room-head{display:flex;align-items:center;gap:8px;color:var(--ink);font-size:15px;font-weight:700}.room-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px;border-radius:11px;border:1px solid var(--line-strong);background:var(--jade-soft);color:var(--jade-deep);font-size:14px}.room-action:hover:not(:disabled){background:#12a06a29}.room-action.go{border-color:transparent;color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep))}.room-action:disabled{opacity:.45;cursor:default}.join-body{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.online-lobby{display:grid;gap:14px}.online-tabs{display:inline-grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;width:min(430px,100%);padding:5px;border-radius:14px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.online-tabs button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:10px;color:var(--muted);font-weight:800;font-size:14px}.online-tabs button.on{color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep));box-shadow:0 10px 22px #12a06a38}.public-lobby-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.public-actions,.room-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.room-action.ghost{background:var(--surface);color:var(--ink)}.room-action.ghost.danger{color:#a73041;background:#fff5f6;border-color:#a7304133}.room-filters button{min-height:36px;padding:0 12px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--muted);font-size:13px;font-weight:800}.room-filters button.on{color:var(--jade-deep);background:var(--jade-soft);border-color:#12a06a42}.public-band-tabs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.public-band-tabs button{min-width:0;display:grid;gap:5px;align-content:start;min-height:88px;padding:13px 12px;border-radius:16px;border:1px solid rgba(203,213,225,.86);background:linear-gradient(180deg,#fff,#f7fafc);color:var(--muted);text-align:left;box-shadow:0 12px 30px #20323e12}.public-band-tabs button span{color:var(--ink);font-size:15px;font-weight:950}.public-band-tabs button strong{color:#526376;font-family:ui-monospace,monospace;font-size:12px;font-weight:900}.public-band-tabs button small{color:var(--muted);font-size:11px;font-weight:800;line-height:1.35}.public-band-tabs button.own{border-color:#12a06a47;background:linear-gradient(180deg,#fbfffd,#edf9f3)}.public-band-tabs button.on{border-color:#12a06a7a;box-shadow:0 0 0 3px #12a06a1f,0 16px 34px #127c5421}.public-band-tabs button.locked:not(.on){opacity:.74}.public-room-notice{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;border:1px solid rgba(203,213,225,.86);background:#ffffffdb;color:var(--muted);font-size:13px;font-weight:800}.public-room-notice strong{color:var(--ink);font-size:14px}.public-room-notice.own{border-color:#12a06a3d;background:var(--jade-soft)}.public-room-notice.locked{border-color:#be123c29;background:#fff7f8}.public-room-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.public-room-card{display:grid;gap:12px;padding:14px;border-radius:14px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);text-align:left}.public-room-card.playing{border-color:#12a06a42}.public-room-card.waiting{background:linear-gradient(180deg,#fff,#f4fbf7)}.public-room-card.ended{opacity:.78}.public-room-card.blocked{background:linear-gradient(180deg,#fff,#f6f8f9)}.public-room-card.blocked .public-table-visual{filter:saturate(.78);opacity:.84}.room-blocked-tip{margin:0;padding:8px 10px;border-radius:10px;background:#f4f7f8;color:var(--muted);font-size:12px;font-weight:800;line-height:1.45}.public-room-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.public-room-top>div{display:grid;gap:5px;min-width:0}.public-room-top strong{color:var(--ink);font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-band{width:max-content;max-width:100%;padding:3px 8px;border-radius:999px;background:#eef6ff;color:#315c8f;font-size:11px;font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-band.mismatch{background:#fff1f2;color:#be123c}.room-status{width:max-content;padding:4px 9px;border-radius:999px;font-size:11px;font-weight:900}.room-status.waiting{color:var(--jade-deep);background:var(--jade-soft)}.room-status.playing{color:#9b5d13;background:#fff2d7}.room-status.ended{color:var(--muted);background:var(--surface-2)}.room-code-mini{padding:4px 7px;border-radius:8px;background:var(--surface-2);color:var(--muted);font-family:ui-monospace,monospace;font-size:12px;font-weight:800}.public-table-visual{position:relative;min-height:190px;padding:24px 18px 32px;border-radius:18px;background:radial-gradient(circle at 50% 38%,#ffffffe0,#fff0 52%),linear-gradient(180deg,#fbfdfc,#edf5f1);border:1px solid rgba(18,160,106,.16);overflow:hidden}.public-table-visual:before{content:"";position:absolute;inset:12px;border-radius:18px;border:1px dashed rgba(32,80,105,.13);pointer-events:none}.xiangqi-table{position:absolute;left:50%;top:48%;width:72%;max-width:292px;aspect-ratio:1.72;transform:translate(-50%,-50%);border-radius:28px;border:10px solid #7b4a25;background:linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.07) 1px,transparent 1px),radial-gradient(circle at 34% 20%,#34bd87,#0f865e 70%);background-size:22px 22px,22px 22px,100% 100%;box-shadow:inset 0 0 0 2px #ffffff1f,inset 0 -16px 28px #0000002e,0 20px 30px #4a412f38;display:grid;place-items:center;color:#ffffffd1}.xiangqi-table:before,.xiangqi-table:after{content:"";position:absolute;width:24px;height:34px;border-radius:999px;background:linear-gradient(180deg,#9d6335,#70401f);bottom:-26px;box-shadow:0 7px 10px #4a412f38}.xiangqi-table:before{left:26%}.xiangqi-table:after{right:26%}.table-board-lines{position:absolute;inset:22px 46px;border:1px solid rgba(255,255,255,.16);border-radius:16px;background:linear-gradient(90deg,transparent calc(25% - .5px),rgba(255,255,255,.14) calc(25% - .5px) calc(25% + .5px),transparent calc(25% + .5px)),linear-gradient(90deg,transparent calc(50% - .5px),rgba(255,255,255,.14) calc(50% - .5px) calc(50% + .5px),transparent calc(50% + .5px)),linear-gradient(90deg,transparent calc(75% - .5px),rgba(255,255,255,.14) calc(75% - .5px) calc(75% + .5px),transparent calc(75% + .5px)),linear-gradient(0deg,transparent calc(33.33% - .5px),rgba(255,255,255,.14) calc(33.33% - .5px) calc(33.33% + .5px),transparent calc(33.33% + .5px)),linear-gradient(0deg,transparent calc(66.66% - .5px),rgba(255,255,255,.14) calc(66.66% - .5px) calc(66.66% + .5px),transparent calc(66.66% + .5px))}.table-center-mark{position:relative;z-index:1;padding:4px 9px;border-radius:999px;background:#0000002e;color:#ffffffd1;font-size:10px;font-weight:900;letter-spacing:.08em}.table-side-label{position:absolute;top:50%;transform:translateY(-50%);max-width:92px;min-width:58px;height:34px;display:flex;align-items:center;justify-content:center;padding:0 10px;border-radius:999px;background:#fffffff5;border:1px solid rgba(226,232,240,.9);font-size:12px;font-weight:900;box-shadow:0 10px 16px #0000002b;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.table-side-label.red{left:-28px;color:#a73041}.table-side-label.black{right:-28px;color:#111827}.table-side-label.empty{color:#64748bc7;border-style:dashed;background:#ffffffd1}.table-seat{position:absolute;z-index:2;display:flex;align-items:center;gap:7px;max-width:44%;padding:6px 9px;border-radius:999px;background:#ffffffe0;border:1px solid rgba(180,196,207,.68);color:var(--ink);font-size:12px;font-weight:900;box-shadow:0 10px 18px #2c414c1f}.table-seat span:last-child{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.table-seat.red{left:14px;top:18px}.table-seat.black{right:14px;bottom:18px;flex-direction:row-reverse}.seat-dot{width:26px;height:26px;flex:0 0 auto;border-radius:50%;display:block;border:2px dashed rgba(100,116,139,.35);background:#ffffffdb}.seat-dot.red{border-color:#ac304259}.seat-dot.black{border-color:#34415559}.spectator-rail{position:absolute;left:50%;bottom:8px;transform:translate(-50%);z-index:2;display:inline-flex;align-items:center;gap:4px;padding:5px 8px;border-radius:999px;background:#ffffffc7;color:var(--muted);font-size:11px;font-weight:800}.public-room-actions{display:grid;gap:8px}.public-room-actions.split{grid-template-columns:1fr auto}.public-room-meta{display:grid;grid-template-columns:repeat(4,minmax(0,auto));gap:8px;color:var(--muted);font-size:12px}.public-room-meta span{display:inline-flex;align-items:center;gap:4px;min-width:0}.public-empty-state,.empty-table{min-height:220px;align-content:center;justify-items:center;text-align:center;color:var(--muted);border-style:dashed}.public-empty-state{grid-column:1 / -1;min-height:120px;padding:22px;justify-items:start;text-align:left}.public-empty-state strong,.empty-table strong{color:var(--ink)}.empty-table{min-height:220px;color:var(--jade-deep);cursor:pointer;overflow:hidden}.empty-table span{color:var(--muted);font-size:13px}.empty-table-visual{position:relative;width:100%;min-height:190px;display:grid;place-items:center}.empty-table-felt{width:min(76%,260px);aspect-ratio:1.55;display:grid;place-items:center;align-content:center;gap:6px;border-radius:44%/34%;border:9px solid #8b572f;background:radial-gradient(circle at 34% 24%,#33bd88,#11845f 72%);color:#fff;box-shadow:inset 0 0 0 2px #ffffff21,inset 0 -15px 26px #00000029,0 19px 28px #4a412f30;transition:transform .16s,box-shadow .16s}.empty-table:hover .empty-table-felt{transform:translateY(-2px);box-shadow:inset 0 0 0 2px #ffffff21,inset 0 -15px 26px #00000029,0 24px 34px #4a412f40}.empty-table-felt svg{color:#fff}.empty-table-felt strong{color:#fff;font-size:18px}.empty-table-felt span{color:#ffffffc7;font-weight:800}.empty-chair{position:absolute;width:34px;height:22px;border-radius:999px;background:linear-gradient(180deg,#fff,#e7eef1);border:1px solid rgba(180,196,207,.82);box-shadow:0 8px 14px #2c414c1f}.empty-chair.top{top:10px;left:50%;transform:translate(-50%)}.empty-chair.right{right:13px;top:50%;transform:translateY(-50%) rotate(90deg)}.empty-chair.bottom{bottom:10px;left:50%;transform:translate(-50%)}.empty-chair.left{left:13px;top:50%;transform:translateY(-50%) rotate(90deg)}.private-room-panel{display:grid;gap:12px}.private-room-note{margin:0;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--muted);font-size:13px;font-weight:700}.room-err.lobby{margin:0}.mobile-quick-seat{display:none}.spin{animation:spin .8s linear infinite}.public-room-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.public-room-card.compact-table{gap:9px;min-height:0;padding:12px;border-radius:15px;box-shadow:0 12px 30px #1b2c3a16}.public-room-card.compact-table .public-room-top{align-items:center}.public-room-card.compact-table .public-room-top strong{font-size:15px}.public-room-card.compact-table .room-band{display:none}.public-room-card.compact-table .room-code-mini{font-size:11px;padding:4px 7px}.public-room-card.compact-table .table-player-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.public-room-card.compact-table .table-player{min-height:34px;padding:6px 9px;border-radius:11px}.public-room-card.compact-table .table-player strong{font-size:14px}.compact-table-strip{min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid rgba(203,213,225,.74);background:linear-gradient(90deg,#f8fcfa,#fff);color:var(--muted);font-size:12px;font-weight:850}.compact-table-strip.playing{border-color:#12a06a38;background:linear-gradient(90deg,#eefaf4,#fff)}.compact-table-strip.empty{min-height:34px;border-style:dashed;background:#fbfdfc}.compact-board-mark{color:var(--jade-deep);font-weight:950;white-space:nowrap}.public-room-card.compact-table.empty-table .empty-meta{grid-template-columns:1fr}.public-room-card.compact-table.empty-table .empty-meta span:nth-child(n+2){display:none}.public-room-card.compact-table .public-room-meta{grid-template-columns:repeat(4,minmax(0,auto));gap:7px;font-size:11.5px}.public-room-card.compact-table .room-action{min-height:38px;border-radius:11px}.public-room-card.compact-table .empty-table-actions,.public-room-card.compact-table .public-room-actions.split{grid-template-columns:repeat(2,minmax(0,1fr))}.public-room-card.compact-table .room-blocked-tip{padding:7px 9px;font-size:11.5px}.arena-play-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.arena-play-tabs button{min-width:0;display:grid;gap:2px;min-height:54px;padding:9px 12px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--ink);text-align:left;box-shadow:0 10px 22px #1b2c3a0f}.arena-play-tabs button.on{border-color:#12a06a57;background:linear-gradient(135deg,#139965,#0c815a);color:#fff;box-shadow:0 16px 30px #127c542e}.arena-play-tabs strong{font-size:14px;font-weight:950}.arena-play-tabs span{color:var(--muted);font-size:11px;font-weight:850}.arena-play-tabs button.on span{color:#fffc}.arena-mode-grid.single{grid-template-columns:minmax(0,1fr)}.arena-table-card .arena-table-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.arena-mini-table{min-height:72px}.arena-mini-table strong{display:flex;align-items:center;gap:5px;min-width:0}.arena-mini-table strong b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-style:normal}.arena-mini-table strong em{flex:0 0 auto;color:#94a3b8;font-size:11px;font-style:normal}.arena-mini-table .red-name{color:#a73041}.arena-mini-table .black-name{color:#111827}.immersive-match .board-column,.board-column{min-width:0;overflow:hidden}.immersive-match .board-frame,.board-frame{max-width:100%;overflow:hidden;box-sizing:border-box}.board-wrap{max-width:100%;overflow:hidden}@media (max-width:980px){.public-room-grid,.arena-table-card .arena-table-strip{grid-template-columns:1fr}}@media (max-width:560px){.hall{gap:10px}.hall-header{gap:8px;padding:0}.profile-card{min-height:64px;padding:9px 10px;border-radius:16px}.profile-card .avatar{width:42px!important;height:42px!important;font-size:20px!important}.profile-name-row{gap:6px}.profile-name{font-size:16px}.profile-stats{gap:7px;font-size:12px}.coin-badge,.rating-badge{min-height:24px;padding:2px 8px;font-size:11px}.hall-header-actions{gap:6px}.icon-btn{width:40px;height:40px;border-radius:12px}.mode-switch.quad{gap:7px;padding:6px;border-radius:16px}.mode-switch.quad button{min-height:44px;padding:7px 9px;border-radius:12px;gap:7px}.mode-switch .ms-label{font-size:13px}.hall-controls,.public-room-notice,.private-room-note{padding:10px 12px;border-radius:13px}.public-actions{grid-template-columns:1fr 1fr .8fr}.public-actions .room-action.go{display:inline-flex}.room-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.public-band-tabs button{min-height:56px;padding:9px 11px}.online-lobby .public-band-tabs,.arena-lobby .public-band-tabs{display:flex;overflow-x:auto;gap:7px;padding-bottom:2px;scrollbar-width:none}.online-lobby .public-band-tabs::-webkit-scrollbar,.arena-lobby .public-band-tabs::-webkit-scrollbar{display:none}.online-lobby .public-band-tabs button,.arena-lobby .public-band-tabs button{flex:0 0 168px;grid-template-columns:1fr;min-height:54px}.public-room-grid{padding-bottom:0}.public-room-card.compact-table{padding:10px;border-radius:14px}.public-room-card.compact-table .public-room-top{gap:8px}.public-room-card.compact-table .public-room-top strong{font-size:14px}.public-room-card.compact-table .table-player-row{grid-template-columns:repeat(2,minmax(0,1fr))}.public-room-card.compact-table .table-player{grid-template-columns:auto minmax(0,1fr);min-height:32px;padding:5px 7px}.public-room-card.compact-table .table-player span{font-size:10.5px}.public-room-card.compact-table .table-player strong{font-size:13px}.compact-table-strip{min-height:34px;padding:7px 8px;font-size:11px}.public-room-card.compact-table .public-room-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.public-room-card.compact-table.empty-table .public-room-meta{grid-template-columns:1fr}.public-room-card.compact-table.empty-table{gap:7px}.public-room-card.compact-table.empty-table .table-player-row,.public-room-card.compact-table.empty-table .compact-table-strip,.public-room-card.compact-table.empty-table .public-room-meta{display:none}.public-room-card.compact-table.empty-table .empty-table-actions{gap:6px}.public-room-card.compact-table.empty-table .room-action{min-height:34px}.public-room-card.compact-table .empty-table-actions,.public-room-card.compact-table .public-room-actions.split{grid-template-columns:repeat(2,minmax(0,1fr))}.public-room-card.compact-table .room-action{min-height:36px;font-size:13px}.mobile-quick-seat{display:none!important}.arena-hero{grid-template-columns:1fr;gap:10px;padding:12px}.arena-hero strong{font-size:20px}.arena-hero p{font-size:12px;line-height:1.45}.arena-wallet{grid-template-columns:auto 1fr auto;justify-items:start;align-items:center;padding:10px}.arena-wallet span{font-size:22px}.arena-wallet small{display:none}.arena-play-tabs{grid-template-columns:1fr;gap:7px}.arena-play-tabs button{min-height:46px;grid-template-columns:1fr auto;align-items:center}.arena-card{gap:10px}.table-card{padding:12px}.table-card .table-felt{min-height:150px}.study-card{gap:12px}.study-copy p{font-size:12.5px;line-height:1.55}}.public-room-card{gap:13px;padding:16px;border-radius:18px;border:1px solid rgba(203,213,225,.86);background:linear-gradient(180deg,#fffffffa,#fafdfcf5);box-shadow:0 18px 44px #1b2c3a1c}.public-room-card.waiting{background:linear-gradient(180deg,#fff,#f7fcf9)}.public-room-card.playing{border-color:#12a06a47;box-shadow:0 18px 46px #127c541f}.public-room-top strong{font-size:17px;letter-spacing:0}.public-table-visual.table-room-scene{min-height:190px;padding:16px 18px 30px;display:grid;place-items:center;border-radius:18px;background:radial-gradient(circle at 50% 42%,#fffffff2,#ffffff73 42%,#ecf6f1c7 70%),linear-gradient(180deg,#fbfefd,#edf6f1);border:1px solid rgba(18,160,106,.15);overflow:hidden}.public-table-visual.table-room-scene:before{inset:13px;border-radius:16px;border:1px solid rgba(151,185,170,.22);border-style:solid;background:linear-gradient(90deg,transparent 49%,rgba(151,185,170,.14) 49% 51%,transparent 51%),linear-gradient(180deg,transparent 49%,rgba(151,185,170,.14) 49% 51%,transparent 51%);pointer-events:none}.table-player-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;align-items:stretch}.table-player{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:7px;min-height:38px;padding:7px 10px;border-radius:12px;border:1px solid rgba(203,213,225,.86);background:#ffffffe6;box-shadow:0 8px 18px #20323e0f}.table-player span{color:var(--muted);font-size:11px;font-weight:900;white-space:nowrap}.table-player strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;line-height:1.1;letter-spacing:0}.table-player.red strong{color:#a73041}.table-player.black strong{color:#111827}.table-player.empty{background:#f8fafcb8;border-style:dashed}.table-player.empty strong{color:#64748bbd}.xiangqi-table.refined{position:relative;left:auto;top:auto;width:min(74%,280px);max-width:none;aspect-ratio:1.68;transform:none;border-radius:30px;border:12px solid #8a552c;background:linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.08) 1px,transparent 1px),radial-gradient(circle at 38% 24%,#38c28e,#0d805d 74%);background-size:24px 24px,24px 24px,100% 100%;box-shadow:inset 0 0 0 2px #ffffff24,inset 0 -18px 30px #0000002e,0 22px 34px #59402538;z-index:1}.xiangqi-table.refined:before,.xiangqi-table.refined:after{display:none}.xiangqi-table.refined .table-board-lines{inset:22px 48px;border-radius:14px;border-color:#ffffff2e}.xiangqi-table.refined .table-center-mark{font-size:10px;letter-spacing:.06em;padding:5px 10px;background:#00412e47}.table-chair{position:absolute;top:50%;width:34px;height:54px;border-radius:999px;transform:translateY(-50%);border:1px solid rgba(182,196,207,.9);background:linear-gradient(180deg,#fff,#e6eef2);box-shadow:0 10px 18px #2c414c29}.table-chair.red{left:-36px}.table-chair.black{right:-36px}.seat-nameplate{position:absolute;z-index:4;top:50%;width:112px;min-height:48px;display:grid;gap:2px;align-content:center;padding:8px 12px;border-radius:14px;background:#fffffff0;border:1px solid rgba(203,213,225,.92);box-shadow:0 14px 24px #20323e24;overflow:hidden}.seat-nameplate.red{left:18px;color:#a73041}.seat-nameplate.black{right:18px;color:#111827}.seat-nameplate .seat-side{color:var(--muted);font-size:10px;font-weight:900;letter-spacing:0}.seat-nameplate strong{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;line-height:1.1;letter-spacing:0}.seat-nameplate.red strong{color:#a73041}.seat-nameplate.black strong{color:#111827}.spectator-rail{bottom:9px;padding:6px 9px;border:1px solid rgba(203,213,225,.78);background:#ffffffe0;box-shadow:0 8px 16px #2c414c14}.public-room-actions{grid-template-columns:1fr;align-items:stretch}.public-room-actions.split{grid-template-columns:repeat(2,minmax(0,1fr))}.red-seat-action{color:#a73041;background:#fff4f5;border-color:#a7304133}.red-seat-action:hover:not(:disabled){background:#ffe9ec}.black-seat-action{color:#162033;background:#f5f7fa;border-color:#16203329}.black-seat-action:hover:not(:disabled){background:#e9eef4}.empty-table{min-height:auto;cursor:default;justify-items:stretch;align-content:start;text-align:left}.empty-table-visual{height:190px;min-height:0;display:grid;place-items:center;padding:16px 18px 30px;border-radius:16px;border:1px dashed rgba(151,185,170,.35);background:linear-gradient(180deg,#fbfefd,#f0f7f3)}.empty-table-felt{width:min(74%,280px);border-width:12px;border-radius:30px;aspect-ratio:1.68;display:grid;place-items:center;align-content:center;background:radial-gradient(circle at 36% 20%,#36bd8a,#0d805d 74%);box-shadow:inset 0 0 0 2px #ffffff24,inset 0 -17px 28px #0000002b,0 18px 28px #5940252b}.empty-table-felt strong{font-size:17px}.empty-table-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.public-room-meta.empty-meta{color:#64748bdb}@media (max-width:640px){.public-band-tabs{grid-template-columns:1fr;gap:8px}.public-band-tabs button{min-height:auto;grid-template-columns:1fr auto;align-items:center}.public-band-tabs button small{grid-column:1 / -1}.public-room-notice{align-items:flex-start;flex-direction:column;gap:5px}.public-room-card{padding:14px;border-radius:16px}.public-table-visual.table-room-scene{min-height:176px;padding:16px 12px 30px}.xiangqi-table.refined{width:74%;border-width:10px}.empty-table-visual{height:176px;min-height:0;padding:16px 12px 30px}.empty-table-felt{width:74%;border-width:10px}.table-player-row{grid-template-columns:1fr;gap:6px}.table-player{min-height:36px;padding:7px 9px}.seat-nameplate{top:auto;bottom:24px;width:calc(50% - 22px);min-height:44px;padding:7px 10px}.seat-nameplate.red{left:12px}.seat-nameplate.black{right:12px}.seat-nameplate strong{font-size:14px}.table-chair.red{left:-28px}.table-chair.black{right:-28px}.public-room-actions.split,.empty-table-actions{grid-template-columns:1fr}}.code-input{display:flex;align-items:center;gap:8px;padding:0 12px;min-height:44px;border-radius:11px;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--muted)}.code-input input{flex:1;min-width:0;border:0;background:transparent;color:var(--ink);font-family:ui-monospace,monospace;font-size:18px;letter-spacing:3px;text-transform:uppercase}.room-err{margin:0;color:var(--red);font-size:12px;display:flex;align-items:center;gap:6px}.room-tip{margin:0;color:var(--muted);font-size:12px}.history-block{display:grid;gap:10px}.history-head{display:flex;align-items:center;justify-content:space-between}.history-head>span{display:inline-flex;align-items:center;gap:7px;color:var(--ink);font-size:14px;font-weight:600}.history-head small{color:var(--muted);font-size:12px}.history-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.history-row{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);text-align:left;transition:transform .12s,border-color .12s}.history-row:hover{transform:translateY(-1px);border-color:#12a06a66}.hist-badge{width:26px;height:26px;flex:0 0 auto;display:grid;place-items:center;border-radius:8px;font-size:13px;font-weight:800}.hist-badge.win{background:var(--jade-soft);color:var(--jade-deep)}.hist-badge.loss{background:var(--red-soft);color:var(--red)}.hist-badge.draw{background:var(--surface-2);color:var(--muted)}.hist-main{display:grid;gap:2px;min-width:0}.hist-main strong{color:var(--ink);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-main span{color:var(--muted);font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-date{color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums}.hist-play{color:var(--jade);flex:0 0 auto}.puzzle-block{display:grid;gap:10px}.puzzle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.puzzle-tile{display:grid;gap:6px;align-content:start;text-align:left;padding:12px;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);transition:transform .12s,border-color .12s}.puzzle-tile:hover{transform:translateY(-2px);border-color:#12a06a73}.puzzle-tile strong{color:var(--ink);font-size:16px}.pz-top{display:flex;align-items:center;justify-content:space-between}.pz-level{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.pz-level.lv1{background:var(--jade-soft);color:var(--jade-deep)}.pz-level.lv2{background:#fbf2df;color:#b8821f}.pz-level.lv3{background:var(--red-soft);color:var(--red)}.pz-stars{color:var(--gold);font-size:12px;letter-spacing:1px}.pz-stars .dim{color:var(--line-strong)}.pz-theme{color:var(--muted);font-size:12.5px}.pz-foot{display:flex;align-items:center;justify-content:space-between;margin-top:3px}.pz-you{font-size:11.5px;color:var(--muted)}.pz-go{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--jade-deep)}.study-block{display:grid;gap:10px}.study-card{display:grid;grid-template-columns:minmax(180px,240px) minmax(0,1fr) auto;align-items:center;gap:20px;text-align:left;padding:14px;border-radius:12px;border:1px solid rgba(18,160,106,.24);background:linear-gradient(135deg,#fffffff5,#f3f8f6f0),radial-gradient(circle at 16% 16%,rgba(196,137,43,.14),transparent 34%);box-shadow:var(--shadow);transition:transform .14s,border-color .14s,box-shadow .14s}.study-card:hover{transform:translateY(-2px);border-color:#12a06a7a;box-shadow:var(--shadow-lg)}.study-entry-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,340px);gap:12px;align-items:stretch}.study-board-preview{aspect-ratio:9 / 10;min-height:0;max-height:260px;display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(10,1fr);position:relative;overflow:hidden;border-radius:12px;border:1px solid rgba(74,40,15,.24);background:radial-gradient(circle at 50% 40%,#f3d9a6,#d5a45d)}.study-board-preview span{border-right:1px solid rgba(74,40,15,.24);border-bottom:1px solid rgba(74,40,15,.24)}.study-board-preview b{position:absolute;top:50%;transform:translateY(-50%);color:#4a280f94;font-family:Songti SC,Georgia,serif;font-size:18px;letter-spacing:3px}.study-board-preview b:first-of-type{left:18%}.study-board-preview b:last-of-type{right:18%}.study-copy{display:grid;gap:7px;min-width:0}.study-kicker{color:var(--jade-deep);font-size:12px;font-weight:800}.study-copy strong{color:var(--ink);font-size:22px}.study-copy p{margin:0;color:var(--muted);font-size:13px;line-height:1.65}.study-tags{display:flex;flex-wrap:wrap;gap:6px}.study-tags span{padding:4px 9px;border-radius:999px;background:var(--jade-soft);color:var(--jade-deep);font-size:12px;font-weight:700}.study-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px;padding:0 16px;border-radius:12px;color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep));font-size:14px;font-weight:800;white-space:nowrap}.import-card{display:grid;align-content:start;gap:10px;padding:14px;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.import-card strong{color:var(--ink);font-size:18px}.import-card textarea,.fen-import textarea{width:100%;resize:vertical;min-height:92px;padding:10px 12px;border-radius:10px;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--ink);font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.5}.import-error,.share-status{margin:0;font-size:12px;line-height:1.5}.import-error,.share-status.err{color:var(--red)}.share-status.ok{color:var(--jade-deep)}.puzzle-card{gap:9px}.puzzle-meta{display:flex;align-items:center;gap:8px}.pz-side{font-size:12px;color:var(--muted)}.puzzle-goal{margin:2px 0 0;display:flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--jade-deep)}.puzzle-tip{margin:0;font-size:12.5px;color:var(--ink);line-height:1.6}.puzzle-hintline{margin:0;font-size:11.5px;color:var(--muted)}.control-grid.puzzle{display:flex;flex-wrap:wrap}.control-grid.puzzle button{flex:1 1 0;min-width:84px}.study-share-card{gap:10px}.share-actions{display:grid;grid-template-columns:1fr 1fr;gap:7px}.share-actions button,.share-import{min-height:44px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-size:12.5px;font-weight:700}.share-actions button:hover:not(:disabled),.share-import:hover:not(:disabled){background:#e9eef3;border-color:var(--line-strong)}.share-actions button:disabled,.share-import:disabled{opacity:.45;cursor:default}.share-import{width:100%;color:#fff;border-color:transparent;background:linear-gradient(145deg,var(--jade),var(--jade-deep))}.fen-import{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:700}.invite-panel{display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;padding:22px;border-radius:18px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.invite-text{display:grid;gap:12px;min-width:0}.invite-label{color:var(--jade-deep);font-size:13px;font-weight:600}.invite-code{display:flex;gap:8px}.invite-code span{width:44px;height:54px;display:grid;place-items:center;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);font-family:ui-monospace,monospace;font-size:28px;font-weight:700;color:var(--ink)}.invite-seats{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--ink);font-size:13px}.invite-seats>span{display:inline-flex;align-items:center;gap:7px}.invite-seats .vs-mini{color:var(--muted);font-weight:700;font-size:11px}.invite-seats .waiting-seat{color:var(--muted)}.invite-actions{display:flex;flex-wrap:wrap;gap:8px}.invite-actions button{display:inline-flex;align-items:center;gap:6px;min-height:38px;padding:0 14px;border-radius:10px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);font-size:13px}.invite-actions button:hover{background:var(--surface-2)}.room-action.big{min-height:48px;font-size:15px}.invite-qr{display:grid;justify-items:center;gap:8px}.invite-qr small{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:12px}.qr-svg{border-radius:12px;border:1px solid var(--line);padding:8px;background:#fff;box-shadow:var(--shadow)}.arena{flex:1;min-height:0;display:grid;grid-template-columns:280px minmax(520px,1fr) 320px;gap:14px;padding:16px 20px}.immersive-match .arena{grid-template-columns:minmax(520px,1fr) 300px;padding:18px 22px}.immersive-match .board-frame{max-width:min(100%,820px)}.board-column{min-height:0;height:100%;display:grid;place-items:center;min-width:0}.board-frame{min-height:0;height:100%;width:100%;max-width:min(100%,780px);display:grid;grid-template-rows:minmax(0,1fr);place-items:stretch}.board-wrap{min-height:0;position:relative;display:flex;align-items:center;justify-content:center}.emote-bubble{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:9;padding:8px 15px;border-radius:999px;background:#fffffff5;border:1px solid var(--line);box-shadow:var(--shadow-lg);color:var(--ink);font-size:14px;white-space:nowrap;pointer-events:none;animation:emote-pop .28s ease-out,emote-fade .4s ease 2.8s forwards}.emote-bubble b{color:var(--jade-deep)}.emote-bubble.red b{color:var(--red)}.emote-bubble.black b{color:#3c4a57}@keyframes emote-pop{0%{transform:translate(-50%) translateY(-8px) scale(.9);opacity:0}to{transform:translate(-50%) translateY(0) scale(1);opacity:1}}@keyframes emote-fade{to{opacity:0}}.emote-bar{display:flex;flex-wrap:wrap;gap:6px}.emote-bar button{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;border-radius:999px;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-size:13px}.emote-bar button:hover{background:#e9eef3}.emote-bar button span{font-size:11.5px;color:var(--muted)}.rail{min-height:0;height:100%;display:flex;flex-direction:column;gap:10px;overflow:auto}.rail>*{flex-shrink:0}.assist-toggle{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.assist-toggle>span{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:13px;font-weight:600}.mini-switch{width:40px;height:23px;border-radius:999px;background:#162a3e29;position:relative;transition:background .18s;flex:0 0 auto}.mini-switch>span{position:absolute;top:3px;left:3px;width:17px;height:17px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .18s}.mini-switch.on{background:var(--jade)}.mini-switch.on>span{transform:translate(17px)}.room-info-card{gap:10px}.ri-players{display:grid;gap:6px}.ri-players span{display:flex;align-items:center;gap:7px;color:var(--ink);font-size:13px}.ri-players b{width:18px;height:18px;flex:0 0 auto;display:grid;place-items:center;border-radius:5px;font-family:Songti SC,serif;font-size:11px;font-weight:800}.ri-players b.red{background:var(--red-soft);color:var(--red)}.ri-players b.black{background:#e7edf2;color:#3c4a57}.ri-spec{color:var(--muted)!important;font-size:12px}.ri-events{display:grid;gap:5px}.ri-event{display:flex;align-items:center;gap:8px;font-size:12px}.ri-event span{color:var(--muted);flex:0 0 auto;font-variant-numeric:tabular-nums}.ri-event em{font-style:normal;color:#44525f;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card{display:grid;gap:10px;padding:14px;border-radius:14px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.card-head{display:flex;align-items:center;justify-content:space-between}.card-head>span{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13px}.card-head>strong{color:var(--ink);font-size:14px;font-variant-numeric:tabular-nums}.card-head>strong.red{color:var(--red)}.card-head>strong.black{color:#44525f}.eval-graph-card{gap:6px}.eval-graph{width:100%;height:86px;display:block}.eg-field{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;align-items:stretch}.eg-axis{display:flex;flex-direction:column;justify-content:space-between;padding:1px 0;color:var(--muted);font-size:10px;line-height:1}.eg-axis span:first-child{color:var(--red)}.eg-axis span:last-child{color:#44525f}.eg-mid{stroke:var(--line-strong);stroke-width:1;stroke-dasharray:3 3}.eg-line{stroke:var(--jade-deep);stroke-width:2;vector-effect:non-scaling-stroke}.eg-cursor{stroke:var(--gold);stroke-width:1.5;vector-effect:non-scaling-stroke;opacity:.8}.eval-graph.seekable{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.eval-graph.seekable:active{cursor:grabbing}.eg-mark{stroke:var(--surface);stroke-width:1.4;cursor:pointer;transition:stroke-width .12s ease}.eg-mark.inaccuracy{fill:#b8821f}.eg-mark.mistake{fill:#d2700f}.eg-mark.blunder{fill:var(--red);animation:eg-pulse 1.7s ease-in-out infinite}.eg-mark:hover{stroke-width:2.4}@keyframes eg-pulse{0%,to{opacity:1}50%{opacity:.5}}.info-card{gap:12px}.ic-main{display:flex;align-items:center;gap:12px}.ic-icon{width:38px;height:38px;flex:0 0 auto;display:grid;place-items:center;border-radius:10px;background:var(--jade-soft);color:var(--jade-deep)}.ic-main small{color:var(--muted);font-size:11px;display:block}.ic-main strong{color:var(--ink);font-size:16px}.ic-chips{display:flex;flex-wrap:wrap;gap:6px}.ic-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-size:11.5px}.ic-chip.phase{font-weight:600}.ic-chip.phase.开局{background:var(--jade-soft);color:var(--jade-deep)}.ic-chip.phase.中局{background:#fdf0d9;color:#9a6a1e}.ic-chip.phase.残局{background:#fbe6e3;color:var(--red)}.material-card{gap:10px}.balance-bar{height:8px;border-radius:999px;overflow:hidden;background:linear-gradient(#3a4859,#2d3a48)}.bal-red{height:100%;background:linear-gradient(90deg,#e0594a,#c83a2d);transition:width .4s ease}.mat-line{display:flex;align-items:flex-start;gap:8px;min-height:24px}.mat-tag{flex:0 0 auto;width:20px;height:20px;display:grid;place-items:center;border-radius:6px;font-family:Songti SC,serif;font-size:12px;font-weight:800}.mat-tag.red{background:var(--red-soft);color:var(--red)}.mat-tag.black{background:#e7edf2;color:#3c4a57}.mat-chips{display:flex;flex-wrap:wrap;gap:2px;align-items:center}.mat-empty{color:#6a7b8c80;font-size:12px}.board-stage{position:relative;height:100%;aspect-ratio:9 / 10;max-width:100%;container-type:inline-size;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}.theme-wood{background:linear-gradient(135deg,#ffffff0f,#0000000d),repeating-linear-gradient(92deg,#7846190d 0 7px,#78461900 7px 16px),radial-gradient(circle at 50% 34%,#f4dca9,#e7be80 58%,#d2a25c);--board-line: rgba(74, 40, 15, .5);--board-edge: rgba(74, 40, 15, .85);--river-fill: rgba(90, 55, 25, .5) }.theme-jade{background:linear-gradient(135deg,#ffffff1a,#0000000d),radial-gradient(circle at 50% 34%,#d2ecdd,#a9d6bf 58%,#84bd9f);--board-line: rgba(15, 60, 45, .5);--board-edge: rgba(12, 48, 36, .85);--river-fill: rgba(18, 60, 46, .5) }.theme-rosewood{background:linear-gradient(135deg,#ffffff0a,#00000026),repeating-linear-gradient(92deg,#2a140814 0 7px,#2a140800 7px 16px),radial-gradient(circle at 50% 34%,#8a5230,#6e3f22 58%,#522d16);--board-line: rgba(245, 228, 200, .5);--board-edge: rgba(250, 236, 212, .8);--river-fill: rgba(240, 222, 190, .62) }.theme-rosewood .board-bg{fill:#ffffff0a}.theme-dark{background:linear-gradient(135deg,#ffffff0a,#00000026),radial-gradient(circle at 50% 34%,#33455a,#27384a 58%,#1b2735);--board-line: rgba(186, 206, 226, .42);--board-edge: rgba(206, 222, 238, .72);--river-fill: rgba(176, 198, 220, .6) }.theme-dark .board-bg{fill:#ffffff0a}.board-lines{position:absolute;inset:0;width:100%;height:100%}.board-bg{fill:#ffffff0f;stroke:var(--board-edge);stroke-width:3}.grid-line{stroke:var(--board-line);stroke-width:1.4}.xq-marker path{stroke:var(--board-line);stroke-width:1.6;fill:none}.river-text{fill:var(--river-fill);font-family:Songti SC,Georgia,serif;font-size:25px;font-weight:700;letter-spacing:3px;opacity:.85}.cell-mark{position:absolute;transform:translate(-50%,-50%);pointer-events:none;border-radius:7px}.cell-mark.last{width:11cqw;height:11cqw;z-index:2;background:#12a06a2e;box-shadow:inset 0 0 0 2px #12a06a73}.cell-mark.selected{width:11.4cqw;height:11.4cqw;z-index:5;border-radius:9px;border:2px solid rgba(18,160,106,.95);box-shadow:0 0 14px #12a06a73}.cell-mark.check{width:12cqw;height:12cqw;z-index:5;border-radius:50%;border:2.5px solid var(--red);box-shadow:0 0 16px #d8453a99;animation:pulse 1.1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.legal-hint{position:absolute;transform:translate(-50%,-50%);pointer-events:none;z-index:5;border-radius:50%}.legal-hint.move{width:3.6cqw;height:3.6cqw;background:#12a06acc;box-shadow:0 0 7px #12a06a80}.legal-hint.capture{width:11.6cqw;height:11.6cqw;border:3px solid rgba(18,160,106,.85)}.xq-piece{position:absolute;transform:translate(-50%,-50%);width:10.6cqw;height:10.6cqw;display:grid;place-items:center;border-radius:50%;background:radial-gradient(circle at 34% 28%,#fff8e8,#f1dcae 52%,#cda864);box-shadow:inset 0 0 0 1.5px #78461973,inset 0 2px 5px #ffffff8c,inset 0 -3px 6px #78461940,0 4px 9px #0000004d;font-family:Songti SC,STKaiti,Georgia,serif;font-weight:800;line-height:1;z-index:6;pointer-events:none;-webkit-user-select:none;user-select:none;transition:left .27s cubic-bezier(.22,1,.36,1),top .27s cubic-bezier(.22,1,.36,1),box-shadow .18s,transform .18s}.xq-piece span{font-size:6.4cqw}.xq-piece.red span{color:#c0271b}.xq-piece.black span{color:#1b2a24}.xq-piece.selected{box-shadow:inset 0 0 0 2px #12a06ab3,0 0 0 3px #12a06a99,0 8px 16px #0006;transform:translate(-50%,-54%) scale(1.05)}.hint-arrow{position:absolute;inset:0;width:100%;height:100%;z-index:7;pointer-events:none}.hint-arrow line{stroke:#12a06ae6;stroke-width:7;stroke-linecap:round}.hint-arrow marker path{fill:#12a06ae6}.suggest-arrow{position:absolute;inset:0;width:100%;height:100%;z-index:7;pointer-events:none}.suggest-arrow line{stroke:#0c8456;stroke-width:7;stroke-linecap:round;stroke-dasharray:9 7;animation:dashmove .7s linear infinite}.suggest-arrow marker path{fill:#0c8456}@keyframes dashmove{to{stroke-dashoffset:-16}}.hit-layer{position:absolute;inset:0;z-index:8}.hit{position:absolute;transform:translate(-50%,-50%);width:10.6cqw;height:10.6cqw;border-radius:50%;background:transparent;transition:background .12s}.board-stage:not(.locked) .hit:hover{background:radial-gradient(circle,rgba(18,160,106,.14),transparent 68%)}.board-stage.locked .hit{cursor:default}.hit:focus-visible{outline:2px solid rgba(18,160,106,.85);outline-offset:-4px}.player-bar{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:9px;padding:8px 12px 8px 10px;border-radius:14px;background:#ffffff8c;border:1px solid rgba(255,255,255,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 3px 12px #1c30440d;transition:background .2s,box-shadow .2s,border-color .2s}.player-bar.active{background:#ffffffeb;border-color:#12a06a59;box-shadow:0 6px 18px #12a06a1f}.player-bar.active:before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;background:var(--jade)}.player-meta{min-width:0;display:grid;gap:3px}.player-name-row{display:flex;align-items:center;gap:5px;min-width:0;min-height:20px}.player-name-row strong{color:var(--ink);font-size:15px;min-width:0;flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-tag{flex:0 0 auto;width:18px;height:18px;display:grid;place-items:center;border-radius:5px;font-family:Songti SC,serif;font-size:11px;font-weight:800}.side-tag.red{background:var(--red-soft);color:var(--red)}.side-tag.black{background:#e7edf2;color:#3c4a57}.thinking-dot{display:none;color:var(--jade);font-size:12px;line-height:1;white-space:nowrap}.thinking-dot.on{display:none}@keyframes blink{50%{opacity:.4}}.player-sub{display:flex;align-items:center;gap:8px;min-height:22px}.player-sub>span{color:var(--muted);font-size:12px;white-space:nowrap}.player-sub .player-subtitle{min-width:0;overflow:hidden;text-overflow:ellipsis}.player-name-row .side-tag,.player-name-row .rank-emblem,.player-sub .elo-chip{flex:0 0 auto}.captured-row{display:flex;flex-wrap:wrap;gap:2px;min-width:0}.captured-chip{display:inline-flex;align-items:center;font-family:Songti SC,Georgia,serif;font-size:14px;font-weight:700;line-height:1}.captured-chip.red{color:#d8453a}.captured-chip.black{color:#3c4a57}.captured-chip em{font-style:normal;font-size:10px;color:var(--muted);margin-left:1px}.captured-empty{color:#6a7b8c66;font-size:12px}.adv-badge{color:var(--jade-deep)!important;font-weight:700;font-size:12px;background:var(--jade-soft);padding:1px 7px;border-radius:999px}.player-clock{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-variant-numeric:tabular-nums;font-size:25px;font-weight:700;letter-spacing:.5px;color:var(--muted);padding:6px 12px;border-radius:12px;background:#1c30440d;min-width:96px;transition:color .2s,background .2s,box-shadow .2s}.player-clock.running{color:var(--ink);background:var(--jade-soft);box-shadow:inset 0 0 0 1px #12a06a4d}.player-clock.running:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--jade);animation:clock-pulse 1.5s ease-out infinite}@keyframes clock-pulse{0%{box-shadow:0 0 #12a06a73}70%{box-shadow:0 0 0 6px #12a06a00}to{box-shadow:0 0 #12a06a00}}.player-clock.low{color:var(--red);background:var(--red-soft);box-shadow:inset 0 0 0 1px #d8453a4d;animation:blink 1s infinite}.player-clock.low:before{background:var(--red);animation:none}.sidebar{min-height:0;display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.sidebar>.clock-stack{order:0}.clock-stack{display:grid;gap:8px}.clock-stack .player-bar{background:var(--surface-2);border:1px solid var(--line);-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none}.clock-stack .player-bar.active{background:var(--jade-soft);border-color:#12a06a59}.clock-stack .player-clock{min-width:86px;font-size:22px}.elo-chip{flex:0 0 auto;padding:1px 7px;border-radius:999px;background:#1c30440f;color:var(--muted);font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}.clock-stack .player-bar.active .elo-chip{background:#12a06a24;color:var(--jade-deep)}.sidebar>.status-banner{order:1}.sidebar>.emote-bar{order:2}.sidebar>.match-controls{order:1}.sidebar>.control-grid,.sidebar>.study-stepbar{order:3}.sidebar>.lobby-link{order:4}.sidebar>.panel-head{order:5}.sidebar>.move-toggle{order:6}.sidebar>.panel-body{order:7}.sidebar>.nav-row{order:8}.sidebar>.back-live{order:9}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:7px;color:var(--muted);font-size:13px;font-weight:600;padding:0 2px}.panel-head>span{display:inline-flex;align-items:center;gap:6px}.panel-tools{display:inline-flex;gap:2px}.panel-tools button{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;color:var(--muted);border:1px solid transparent;transition:background .12s,color .12s,border-color .12s}.panel-tools button:hover:not(:disabled){background:var(--surface-2);color:var(--ink);border-color:var(--line)}.panel-tools button:disabled{opacity:.38;cursor:default}.panel-tools button.on{color:var(--jade-deep);background:var(--jade-soft);border-color:#12a06a40}.tool-toast{align-self:flex-start;padding:4px 11px;border-radius:999px;background:var(--jade-soft);color:var(--jade-deep);font-size:12px;font-weight:600;animation:emote-pop .2s ease-out}.fen-bar{display:grid;gap:6px}.fen-bar textarea{width:100%;min-width:0;resize:vertical;min-height:66px;padding:8px 10px;border-radius:9px;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--ink);font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.5}.fen-bar button{min-height:40px;padding:0 16px;border-radius:9px;border:0;color:#fff;font-weight:700;font-size:13px;background:linear-gradient(145deg,var(--jade),var(--jade-deep))}.fen-bar button:disabled{opacity:.45;cursor:default}.sidebar>.tool-toast,.sidebar>.fen-bar{order:5}.status-banner{display:grid;gap:3px;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2)}.status-banner strong{font-size:16px;color:var(--ink)}.status-banner span{font-size:12.5px;color:var(--muted);line-height:1.5}.status-banner.ready{border-color:#12a06a66;background:var(--jade-soft)}.status-banner.ready strong{color:var(--jade-deep)}.status-banner.waiting,.status-banner.thinking{background:#faf1df;border-color:#c4892b4d}.status-banner.thinking strong{color:var(--gold-soft)}.status-banner.alert,.status-banner.end{background:var(--red-soft);border-color:#d8453a66}.status-banner.alert strong,.status-banner.end strong{color:var(--red)}.status-banner.review{background:var(--surface-2)}.status-banner.review strong{color:var(--ink)}.immersive-match .sidebar{align-self:center;height:auto;gap:12px}.immersive-match .sidebar>:not(.clock-stack):not(.match-controls){display:none!important}.match-controls{display:grid;grid-template-columns:1fr 1fr;gap:8px}.match-controls button{min-height:46px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:11px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-weight:800}.match-controls button:hover:not(:disabled){background:var(--surface-2);border-color:var(--line-strong)}.match-controls button.danger{border-color:#d8453a42;color:var(--red);background:var(--red-soft)}.match-controls button:disabled{opacity:.45;cursor:default}.panel-tabs{display:flex;gap:6px}.panel-tabs button{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 6px;border-radius:9px;border:1px solid transparent;color:var(--muted);font-size:13px}.panel-tabs button:hover{background:var(--surface-2)}.panel-tabs button.on{color:var(--jade-deep);background:var(--jade-soft);border-color:#12a06a40}.panel-body{flex:1;min-height:64px;overflow:auto}.move-toggle{display:none;min-height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);color:var(--jade-deep);font-size:13px;font-weight:700}.analysis-card{gap:9px}.ana-sub{display:flex;align-items:center;justify-content:space-between;gap:8px}.move-list{display:grid;gap:4px;align-content:start}.empty-note{margin:0;padding:6px 4px;color:var(--muted);font-size:12.5px;line-height:1.45}.move-row{display:grid;grid-template-columns:30px 1fr 1fr;gap:6px;align-items:center}.move-no{color:var(--muted);font-size:12px;text-align:center}.move-cell{padding:7px 10px;border-radius:7px;background:var(--surface-2);color:var(--ink);font-size:14px;text-align:left;font-family:Songti SC,Georgia,serif}.move-cell:hover:not(.empty){background:#e9eef3}.move-cell.current{background:var(--jade-soft);color:var(--jade-deep);box-shadow:inset 0 0 0 1px #12a06a66}.move-cell.empty{background:transparent;cursor:default}.q-mark{font-style:normal;font-family:Inter,system-ui,sans-serif;font-size:10px;font-weight:800;line-height:1;margin-left:1px;vertical-align:2px}.q-mark.q-great{color:var(--jade-deep)}.q-mark.q-inaccuracy{color:#b8821f}.q-mark.q-mistake{color:#d2700f}.q-mark.q-blunder{color:var(--red)}.move-cell.reviewing{box-shadow:inset 0 0 0 2px var(--jade)}.move-cell.qc-great:not(.current){background:var(--jade-soft)}.move-cell.qc-inaccuracy:not(.current){background:#fbf2df}.move-cell.qc-mistake:not(.current){background:#fbeede}.move-cell.qc-blunder:not(.current){background:var(--red-soft)}.review-card{gap:9px}.review-verdict{margin:0;padding:8px 11px;border-radius:9px;background:var(--surface-2);border-left:3px solid var(--jade);color:var(--ink);font-size:12.5px;line-height:1.55;font-weight:600}.rev-acc{color:var(--jade-deep)!important;font-size:17px!important;font-weight:800}.rev-acc small{font-size:11px;color:var(--muted);font-weight:600;margin-left:1px}.review-run{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 10px;border:0;border-radius:9px;background:var(--jade);color:#fff;font-weight:700;font-size:13px;cursor:pointer;transition:filter .15s ease}.review-run:hover{filter:brightness(1.06)}.review-progress{display:grid;gap:6px}.rp-bar{height:7px;border-radius:4px;background:var(--surface-2);overflow:hidden}.rp-bar span{display:block;height:100%;background:var(--jade);transition:width .25s ease}.review-progress small{color:var(--muted);font-size:11px;font-variant-numeric:tabular-nums}.review-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px}.rs-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 8px;border-radius:7px;background:var(--surface-2);font-size:12px;color:var(--muted)}.rs-chip b{font-size:14px;font-weight:800;font-variant-numeric:tabular-nums}.rs-chip.q-great{color:var(--jade-deep);background:var(--jade-soft)}.rs-chip.q-inaccuracy{color:#b8821f;background:#fbf2df}.rs-chip.q-mistake{color:#d2700f;background:#fbeede}.rs-chip.q-blunder{color:var(--red);background:var(--red-soft)}.review-hint{margin:0;font-size:11px;color:var(--muted);line-height:1.5}.review-mistakes{display:grid;gap:5px}.rm-head{color:var(--muted);font-size:11.5px;font-weight:700}.rm-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;padding:7px 9px;border-radius:8px;border:1px solid var(--line);background:var(--surface-2);text-align:left;transition:background .12s,border-color .12s}.rm-row:hover{background:#e9eef3;border-color:var(--line-strong)}.rm-no{color:var(--muted);font-size:11.5px;font-variant-numeric:tabular-nums}.rm-actual{font-family:Songti SC,Georgia,serif;font-size:14px;color:var(--ink)}.rm-actual em{font-style:normal;font-size:10px;font-weight:800;margin-left:2px}.rm-row.q-blunder .rm-actual em{color:var(--red)}.rm-row.q-mistake .rm-actual em{color:#d2700f}.rm-row.q-inaccuracy .rm-actual em{color:#b8821f}.rm-better{display:inline-flex;align-items:center;gap:4px;font-family:Songti SC,Georgia,serif;font-size:14px;font-weight:700;color:var(--jade-deep)}.suggest-caption{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px;padding:8px 12px;border-radius:10px;background:var(--jade-soft);border:1px solid rgba(18,160,106,.28);color:var(--jade-deep);font-size:13px}.suggest-caption b{font-family:Songti SC,Georgia,serif;font-size:14px}.suggest-caption i{font-style:normal;color:var(--muted);font-size:12px;margin-left:auto}.analysis-panel{display:grid;gap:14px;align-content:start}.ana-eval{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.ana-eval>div{display:grid;gap:3px}.ana-eval span{color:var(--muted);font-size:12px}.ana-eval strong{color:var(--ink);font-size:18px}.ana-eval strong.red{color:var(--red)}.ana-eval strong.black{color:#44525f}.ana-depth{flex:0 0 auto;color:var(--muted);font-size:12px;padding:4px 9px;border-radius:999px;background:var(--surface-2)}.ana-best{display:grid;gap:8px}.ana-best-head{display:flex;align-items:center;justify-content:space-between}.ana-best-head>span{color:var(--muted);font-size:12px}.ana-mark{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;border:1px solid rgba(18,160,106,.35);background:var(--jade-soft);color:var(--jade-deep);font-size:12px}.ana-mark:hover{background:#12a06a29}.pv-line{display:flex;flex-wrap:wrap;gap:4px;align-content:flex-start;padding:2px 0;min-height:64px}.pv-line span{padding:5px 9px;border-radius:7px;background:var(--surface-2);color:var(--ink);font-size:13.5px;font-family:Songti SC,Georgia,serif;border:2px solid transparent;background-clip:padding-box}.pv-line .pv-best{background:var(--jade-soft);color:var(--jade-deep);font-weight:700;border-color:#12a06a59}.fen-row{display:grid;gap:5px}.fen-row span{color:var(--muted);font-size:11px}.fen-row code{display:block;padding:8px 10px;border-radius:8px;background:var(--surface-2);color:#4a5a6a;font-size:11px;line-height:1.5;word-break:break-all}.nav-row{display:flex;align-items:center;gap:6px;justify-content:center}.nav-label{flex:1;text-align:center;color:var(--muted);font-size:13px}.back-live{padding:9px;border-radius:10px;border:1px solid rgba(18,160,106,.4);background:var(--jade-soft);color:var(--jade-deep);font-size:13px}.study-stepbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.study-stepbar button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:46px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:14px;font-weight:700;transition:background .15s,border-color .15s,transform .15s}.study-stepbar button:hover:not(:disabled){background:var(--surface-2);border-color:var(--line-strong);transform:translateY(-1px)}.study-stepbar button:nth-child(2){border-color:#12a06a59;background:var(--jade-soft);color:var(--jade-deep)}.study-stepbar button:disabled{opacity:.45;cursor:default}.control-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.control-grid.replay{grid-template-columns:1fr 1fr}.control-grid button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:42px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:13px;transition:background .15s,border-color .15s}.control-grid button:hover:not(:disabled){background:var(--surface-2);border-color:var(--line-strong)}.control-grid button.primary{border-color:transparent;background:linear-gradient(145deg,var(--jade),var(--jade-deep));color:#fff}.control-grid button:disabled{opacity:.4;cursor:default}.lobby-link{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px;border-radius:10px;color:var(--muted);font-size:13px;border:1px solid transparent}.lobby-link:hover{color:var(--ink);border-color:var(--line)}.modal-backdrop{position:fixed;inset:0;z-index:40;display:grid;place-items:center;padding:20px;background:#14233252;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-backdrop.right{place-items:stretch;justify-content:flex-end;padding:0}.result-modal{width:min(420px,100%);display:grid;gap:12px;justify-items:center;text-align:center;padding:28px;border-radius:18px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-lg)}.result-trophy{width:60px;height:60px;display:grid;place-items:center;border-radius:50%;color:#fff;background:linear-gradient(145deg,#e9b65c,#c4892b)}.result-modal.win .result-trophy{background:linear-gradient(145deg,var(--jade),var(--jade-deep))}.result-modal.loss .result-trophy{background:linear-gradient(145deg,#97a3ad,#5d6b78)}.result-modal strong{font-size:26px;color:var(--ink)}.result-modal.win strong{color:var(--jade-deep)}.result-modal p{margin:0;color:var(--muted);line-height:1.6;font-size:14px}.result-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:6px}.result-actions button{min-height:44px;padding:0 18px;border-radius:11px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);font-size:14px}.result-actions button:hover{background:var(--surface-2)}.result-actions button.primary{display:inline-flex;align-items:center;gap:7px;border-color:transparent;color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep))}.confirm-dialog{width:min(380px,100%);display:grid;gap:12px;padding:24px;border-radius:16px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-lg)}.confirm-dialog strong{font-size:19px;color:var(--ink)}.confirm-dialog p{margin:0;color:var(--muted);line-height:1.6;font-size:14px}.confirm-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.confirm-actions button{min-height:44px;border-radius:11px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink)}.confirm-actions button:hover{background:var(--surface-2)}.confirm-actions button.primary{border-color:transparent;color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep))}.confirm-actions button.danger{border-color:transparent;background:linear-gradient(145deg,#e0594a,#b5392c);color:#fff}.time-dialog{width:min(560px,100%);display:grid;gap:16px;padding:18px;border-radius:16px;border:1px solid var(--line);background:linear-gradient(180deg,#fffffff7,#f6fbf8f5);box-shadow:var(--shadow-lg)}.time-dialog-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.time-dialog-head>div{display:grid;gap:4px}.time-dialog-head span{display:inline-flex;align-items:center;gap:6px;color:var(--jade-deep);font-size:12px;font-weight:700}.time-dialog-head strong{color:var(--ink);font-size:22px}.time-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.time-summary>div{min-width:0;display:grid;gap:3px;padding:12px;border-radius:12px;border:1px solid rgba(18,160,106,.18);background:var(--jade-soft)}.time-summary span{color:var(--muted);font-size:12px}.time-summary strong{color:var(--jade-deep);font-size:18px;font-variant-numeric:tabular-nums}.time-section{display:grid;gap:9px}.time-section-label{color:var(--ink);font-size:13px;font-weight:800}.time-presets{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.time-preset{min-height:58px;display:grid;place-items:center;gap:2px;padding:8px;border-radius:11px;border:1px solid var(--line);background:var(--surface);color:var(--ink)}.time-preset b{font-size:15px;font-variant-numeric:tabular-nums}.time-preset span{color:var(--muted);font-size:11px}.time-preset:hover{background:var(--surface-2)}.time-preset.on{border-color:#12a06a66;background:var(--jade-soft);color:var(--jade-deep)}.time-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.time-fields label{display:grid;gap:9px;padding:12px;border-radius:12px;border:1px solid var(--line);background:var(--surface)}.time-fields label>span{display:flex;justify-content:space-between;gap:10px;color:var(--ink);font-size:13px;font-weight:700}.time-fields label>span b{color:var(--muted);font-size:12px;font-weight:600}.time-input-row{display:grid;grid-template-columns:minmax(0,1fr) 68px;gap:10px;align-items:center}.time-input-row input[type=range]{width:100%;accent-color:var(--jade)}.time-input-row input[type=number]{width:68px;height:40px;border-radius:9px;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--ink);font-weight:800;text-align:center;font-variant-numeric:tabular-nums}.time-side-group{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.time-side-group button{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 10px;border-radius:11px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-weight:700}.time-side-group button.on{border-color:#12a06a66;background:var(--jade-soft);color:var(--jade-deep)}.competition-switch{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:13px;border-radius:12px;border:1px solid var(--line);background:var(--surface);text-align:left;color:var(--ink)}.competition-switch:hover{background:var(--surface-2)}.competition-switch.on{border-color:#12a06a66;background:linear-gradient(135deg,var(--jade-soft),#fff)}.competition-mark{width:38px;height:38px;display:grid;place-items:center;border-radius:11px;color:#9a6a1e;background:#faf1df;border:1px solid #c4892b40}.competition-switch.on .competition-mark{color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep));border-color:transparent}.competition-switch span:nth-child(2){min-width:0;display:grid;gap:2px}.competition-switch strong{font-size:14px;color:var(--ink)}.competition-switch small{color:var(--muted);font-size:12px;line-height:1.45}.competition-switch b{padding:5px 9px;border-radius:999px;color:var(--muted);background:var(--surface-2);font-size:12px;white-space:nowrap}.competition-switch.on b{color:var(--jade-deep);background:var(--jade-soft)}.time-dialog-actions{display:grid;grid-template-columns:1fr 1.4fr;gap:10px}.time-dialog-actions button{min-height:46px;border-radius:11px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);font-weight:800}.time-dialog-actions button.primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-color:transparent;color:#fff;background:linear-gradient(145deg,var(--jade),var(--jade-deep));box-shadow:0 10px 22px #12a06a3d}.settings-drawer{width:min(400px,100vw);height:100%;display:grid;grid-template-rows:auto 1fr;gap:18px;padding:22px;border-left:1px solid var(--line);background:var(--surface);box-shadow:-18px 0 50px #1c30442e}.settings-drawer header{display:flex;align-items:center;justify-content:space-between}.settings-drawer header strong{display:block;font-size:20px;color:var(--ink)}.settings-drawer header span{color:var(--muted);font-size:13px}.pref-section{display:grid;gap:10px;align-content:start}.pref-select{display:grid;gap:8px;color:var(--muted);font-size:13px}.pref-select select{min-height:44px;padding:0 12px;border-radius:11px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink)}.pref-toggle{display:flex;align-items:center;justify-content:space-between;min-height:52px;padding:0 16px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-size:14px}.pref-toggle.on{border-color:#12a06a66}.pref-switch{width:42px;height:24px;border-radius:999px;background:#162a3e2e;position:relative;transition:background .18s}.pref-switch span{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .18s}.pref-toggle.on .pref-switch{background:var(--jade)}.pref-toggle.on .pref-switch span{transform:translate(18px)}select{color-scheme:light}@media (max-width:1180px){.public-room-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-engine-layout{grid-template-columns:1fr}.ops-engine-layout .ops-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-levels-head,.ops-levels article{grid-template-columns:64px minmax(110px,1fr) minmax(120px,1fr) 80px minmax(140px,1fr) 92px}.ops-levels .ops-engine-level-card{grid-template-columns:160px minmax(0,1fr)}.engine-level-fields{grid-template-columns:repeat(2,minmax(0,1fr))}.arena{grid-template-columns:minmax(176px,208px) minmax(0,1fr) 288px;gap:12px;padding:14px 16px}.eval-graph{height:74px}}@media (max-width:900px){.ops-shell{grid-template-columns:1fr}.ops-nav{position:sticky;z-index:8;height:auto;min-height:0;border-right:0;border-bottom:1px solid var(--line)}.ops-nav nav{grid-template-columns:repeat(5,minmax(0,1fr));overflow:visible}.ops-nav nav button{justify-content:center;min-height:48px;padding:8px}.ops-nav nav button span{display:none}.ops-back{display:none}.ops-main{padding:14px 14px 92px}.ops-dashboard{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-dashboard .ops-section{grid-column:1 / -1}.ops-two-col{grid-template-columns:1fr}.ops-create-user,.ops-form-grid.top{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-table.users article,.ops-table.rooms article,.ops-table.games article,.ops-levels-head,.ops-presets article,.ops-levels article,.ops-audit article,.ops-history article,.ops-diff article{grid-template-columns:1fr;align-items:stretch}.ops-levels .ops-engine-level-card{grid-template-columns:1fr}.engine-level-title{flex-direction:row;align-items:center}.ops-levels-head{display:none}.preset-actions{grid-template-columns:1fr 1fr 44px}.ops-savebar{left:14px;right:14px;bottom:12px}.admin-shell{grid-template-columns:1fr}.admin-nav{min-height:auto;position:sticky;top:0;z-index:5;border-right:0;border-bottom:1px solid var(--line)}.admin-nav nav{grid-template-columns:repeat(4,minmax(0,1fr))}.admin-nav nav button{justify-content:center;padding:0 8px}.admin-nav nav button span{display:none}.admin-back{display:none}.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-create-user,.admin-form-grid{grid-template-columns:1fr}.users-table article,.room-table article,.games-table article,.engine-settings article,.admin-list p,.admin-list.compact p{grid-template-columns:1fr;align-items:stretch}.admin-table button{width:100%}.app{height:auto;min-height:100vh}.arena{grid-template-columns:1fr;grid-template-rows:none;padding:14px}.immersive-match .arena{grid-template-columns:1fr;grid-template-rows:none;align-content:start;gap:12px;padding:12px}.sidebar{order:2;grid-column:1;grid-row:auto;grid-template-rows:none}.immersive-match .sidebar{width:min(100%,430px);justify-self:center;align-self:stretch}.board-column{order:1;grid-column:1;height:auto}.rail{order:3;grid-column:1;grid-row:auto;flex-direction:row;flex-wrap:wrap;overflow:visible}.rail .card{flex:1 1 220px}.board-frame{height:auto;grid-template-rows:auto auto auto;width:100%;max-width:620px;margin:0 auto}.board-wrap{height:auto}.board-stage{height:auto;width:min(92vw,62vh);aspect-ratio:9 / 10}.panel-body{max-height:260px}.move-toggle{display:inline-flex;align-items:center;justify-content:center}.panel-body:not(.open){display:none}.tables-grid,.puzzle-grid{grid-template-columns:repeat(2,1fr)}.study-card,.study-entry-grid{grid-template-columns:1fr}.study-action{width:100%}}@media (max-width:640px){.ops-top,.ops-top-status,.ops-toolbar,.ops-section header,.ops-savebar,.ops-modal footer{align-items:stretch;flex-direction:column}.ops-top-status{width:100%}.ops-account{justify-content:space-between}.ops-dashboard,.ops-create-user,.ops-card-grid,.ops-form-grid,.ops-form-grid.top,.engine-level-fields{grid-template-columns:1fr}.ops-section header p{max-width:none;text-align:left}.ops-nav nav{grid-template-columns:repeat(4,minmax(0,1fr))}.ops-nav nav button{min-height:42px}.ops-nav nav button svg{width:17px;height:17px}.ops-main{padding:12px 12px 150px}.ops-savebar{gap:8px}.ops-savebar button,.ops-modal footer button{width:100%}.ops-metric{min-height:104px}.admin-main{padding:12px}.admin-top,.admin-account,.admin-toolbar{align-items:stretch;flex-direction:column}.admin-grid{grid-template-columns:1fr}.admin-search{min-width:0;width:100%}.auth-shell{padding:14px}.auth-card{padding:18px;border-radius:16px}.auth-brand strong{font-size:23px}.admin-dialog{padding:14px;border-radius:14px}.admin-dialog header,.admin-dialog footer{align-items:flex-start;flex-direction:column}.user-row{grid-template-columns:1fr;align-items:stretch}.user-row .icon-btn{width:100%;justify-content:center}.modal-backdrop{padding:12px}.time-dialog{max-height:calc(100vh - 24px);overflow:auto;padding:14px;border-radius:14px}.time-dialog-head strong{font-size:20px}.time-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.time-summary>div{padding:9px 8px}.time-summary span{font-size:11px}.time-summary strong{font-size:14px}.time-presets{grid-template-columns:repeat(2,1fr)}.time-fields{grid-template-columns:1fr}.time-side-group{grid-template-columns:repeat(3,minmax(0,1fr))}.time-side-group button{min-height:44px;gap:5px;padding:0 6px;font-size:12px}.competition-switch{grid-template-columns:auto minmax(0,1fr);gap:10px;padding:10px}.competition-switch b{grid-column:1 / -1;justify-self:start}.time-dialog-actions{grid-template-columns:1fr}.topbar{grid-template-columns:auto 1fr auto}.topbar .brand small,.topbar-center{display:none}.arena{padding:12px}.board-stage{width:min(calc(100vw - 28px),62dvh)}.control-grid{grid-template-columns:repeat(2,1fr)}.player-clock{font-size:20px;min-width:64px}.rail .card{flex:1 1 100%}.hall-header{grid-template-columns:1fr auto}.hall-title{display:none}.mode-switch button{min-height:50px;font-size:14px;gap:6px}.hall-controls{gap:10px}.ctrl-group{width:100%;justify-content:center}.start-dock{grid-template-columns:1fr;gap:12px}.start-primary{width:100%}.tables-grid,.tables-grid.online{grid-template-columns:1fr}.public-lobby-toolbar{align-items:stretch;flex-direction:column}.public-actions{display:grid;grid-template-columns:1fr 1fr;width:100%}.public-actions .room-action.go{display:none}.public-actions .room-action{width:100%}.room-filters{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));width:100%;gap:6px}.room-filters button{padding:0 6px;font-size:12px}.public-room-grid{grid-template-columns:1fr;padding-bottom:74px}.public-room-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.public-room-actions.split{grid-template-columns:1fr}.xiangqi-table{width:78%;border-width:9px}.table-side-label{max-width:76px;min-width:52px;height:32px;font-size:11px;padding:0 8px}.table-side-label.red{left:-22px}.table-side-label.black{right:-22px}.online-tabs{width:100%}.join-body{grid-template-columns:1fr}.mobile-quick-seat{position:fixed;left:12px;right:12px;bottom:12px;z-index:30;display:block}.mobile-quick-seat .room-action{width:100%;box-shadow:0 14px 34px #0d8e603f}.table-card.single{max-width:none}.invite-panel{grid-template-columns:1fr;justify-items:center}.invite-text{width:100%}.history-list,.puzzle-grid{grid-template-columns:1fr}.study-board-preview{min-height:112px}}.mode-switch.quad{grid-template-columns:repeat(4,1fr)}.mode-switch.quad button{flex-direction:row;justify-content:flex-start;gap:11px;min-height:62px;padding:10px 14px;text-align:left}.mode-switch.quad button>svg{flex:0 0 auto}.mode-switch .ms-text{display:grid;gap:1px;min-width:0}.mode-switch .ms-label{font-size:15px;font-weight:700;line-height:1.2;white-space:nowrap}.mode-switch .ms-sub{font-size:11.5px;font-weight:500;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mode-switch.quad button.on .ms-sub{color:#fffc}.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:2px}.section-head>span{display:inline-flex;align-items:center;gap:7px;color:var(--ink);font-size:14px;font-weight:700}.section-head>span svg{color:var(--jade)}.section-head small{color:var(--muted);font-size:12px;text-align:right}.ctrl-note{align-self:center;color:var(--muted);font-size:12px;line-height:1.5}.empty-card{display:grid;justify-items:center;gap:8px;padding:26px 22px;border-radius:16px;border:1px dashed var(--line-strong);background:var(--surface);color:var(--muted);text-align:center}.empty-card svg{color:var(--jade)}.empty-card p{margin:0;font-size:13px;line-height:1.7;max-width:46ch}.puzzle-tile.solved{border-color:#12a06a59}.puzzle-tile.solved .pz-go{color:var(--jade-deep)}@media (max-width:560px){.mode-switch.quad{grid-template-columns:repeat(2,1fr)}.mode-switch.quad button{min-height:52px}.mode-switch .ms-sub{display:none}}.analysis-card{min-height:150px}.analysis-card .pv-line{min-height:64px;align-content:flex-start}.analysis-card .empty-note{display:flex;align-items:center;min-height:64px}.coin-badge{display:inline-flex;align-items:center;gap:5px;min-height:28px;padding:3px 10px;border-radius:999px;border:1px solid rgba(196,137,43,.28);background:#fff8e8;color:#8a5a16;font-size:12px;font-weight:850}.coin-badge.claimable{color:#fff;background:linear-gradient(145deg,#d99b34,#b66d15);box-shadow:0 8px 18px #c4892b2e}.arena-lobby{display:grid;gap:14px}.arena-hero{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:14px;align-items:stretch;padding:18px;border-radius:18px;border:1px solid rgba(196,137,43,.24);background:linear-gradient(135deg,#fffdf8,#f3fbf6);box-shadow:var(--shadow)}.arena-kicker{display:inline-flex;align-items:center;gap:6px;margin-bottom:8px;padding:5px 10px;border-radius:999px;background:#fff3d7;color:#925f13;font-size:12px;font-weight:900}.arena-hero strong{display:block;color:var(--ink);font-size:24px;line-height:1.2}.arena-hero p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.6}.arena-wallet{display:grid;justify-items:center;align-content:center;gap:5px;padding:14px;border-radius:16px;background:#fff;border:1px solid rgba(196,137,43,.22);box-shadow:0 14px 28px #5f482014}.arena-wallet svg{color:var(--gold)}.arena-wallet span{color:#6f4610;font-size:28px;font-weight:950}.arena-wallet small{color:var(--muted);font-size:12px;font-weight:800}.arena-wallet button{min-height:32px;padding:0 12px;border-radius:999px;background:var(--jade-soft);color:var(--jade-deep);font-size:12px;font-weight:900}.arena-wallet button:disabled{opacity:.55}.arena-band-tabs{margin-top:2px}.arena-mode-grid{display:grid;grid-template-columns:1.08fr 1fr 1fr;gap:14px;align-items:stretch}.arena-card{display:grid;gap:12px;min-width:0;padding:16px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fbfa);box-shadow:var(--shadow)}.arena-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.arena-card-head span{display:inline-flex;align-items:center;gap:7px;color:var(--ink);font-size:16px;font-weight:950}.arena-card-head small{color:var(--muted);font-size:12px;font-weight:850}.king-stage{display:grid;gap:10px;padding:14px;border-radius:16px;background:radial-gradient(circle at 50% 25%,rgba(18,160,106,.16),transparent 58%),linear-gradient(180deg,#f5fbf8,#fff);border:1px solid rgba(18,160,106,.17)}.champion-plate{display:grid;gap:5px;justify-items:center;padding:16px 12px;border-radius:18px;border:8px solid #8a5529;background:radial-gradient(circle at 40% 20%,#36bf88,#0d875d 76%);color:#fff;box-shadow:inset 0 -18px 30px #0000002e,0 16px 26px #433b2b29}.champion-plate span,.champion-plate small{color:#fffc;font-size:12px;font-weight:850}.champion-plate strong{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:24px;font-weight:950}.challenge-rules{display:flex;flex-wrap:wrap;gap:7px}.challenge-rules span{display:inline-flex;align-items:center;gap:5px;padding:5px 8px;border-radius:999px;background:#f2f5f7;color:#526376;font-size:11px;font-weight:850}.queue-list{display:grid;gap:6px;align-content:start;padding:10px;border-radius:14px;background:#f7fafc;border:1px solid rgba(203,213,225,.72);color:var(--muted);font-size:12px;font-weight:800}.queue-list strong{color:var(--ink);font-size:13px}.queue-list .muted{color:#8291a1}.arena-actions{display:grid;gap:8px;align-self:end}.arena-actions.split{grid-template-columns:1fr 1fr}.arena-table-strip{display:grid;gap:8px}.arena-mini-table{min-width:0;display:grid;gap:3px;padding:10px 12px;border-radius:13px;border:1px solid rgba(203,213,225,.9);background:#fff;color:var(--muted);text-align:left}.arena-mini-table.mine{border-color:#12a06a6b;background:var(--jade-soft)}.arena-mini-table span{color:var(--jade-deep);font-size:11px;font-weight:900}.arena-mini-table strong{color:var(--ink);font-size:13px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.arena-mini-table small{color:var(--muted);font-size:11px;font-weight:800}.tournament-clock{display:grid;gap:5px;justify-items:center;padding:18px;border-radius:16px;background:linear-gradient(135deg,#fff8e8,#fff);border:1px solid rgba(196,137,43,.2)}.tournament-clock span,.tournament-clock small{color:var(--muted);font-size:12px;font-weight:850}.tournament-clock strong{color:#7a4f14;font-size:22px}@media (max-width:980px){.arena-hero,.arena-mode-grid{grid-template-columns:1fr}}@media (max-width:560px){.arena-card,.arena-hero{padding:12px;border-radius:14px}.arena-actions.split{grid-template-columns:1fr}}.pv-line .pv-step{cursor:default;outline:none;min-height:32px;display:inline-flex;align-items:center;transition:background .12s,color .12s,box-shadow .12s}.pv-line .pv-step.clickable{cursor:pointer}.pv-line .pv-step:hover,.pv-line .pv-step:focus-visible{background:#faf1df;color:#9a6a1e;border-color:#c4892b80;box-shadow:none}.pv-line .pv-step.pv-best:hover,.pv-line .pv-step.pv-best:focus-visible{background:#fbeaca}.suggest-caption.pv{background:#faf1df;border-color:#c4892b59;color:#9a6a1e}.suggest-caption.pv b{color:#8a5e1a;font-family:Songti SC,Georgia,serif}.pv-arrow{position:absolute;inset:0;width:100%;height:100%;z-index:7;pointer-events:none}.pv-arrow line{stroke:#c4892b;stroke-width:7;stroke-linecap:round;stroke-dasharray:10 7;animation:dashmove .7s linear infinite}.pv-arrow marker path{fill:#c4892b}.cell-mark.pv-target{width:11.6cqw;height:11.6cqw;z-index:5;border-radius:50%;border:2.5px solid #c4892b;box-shadow:0 0 14px #c4892b80;animation:pulse 1.1s ease-in-out infinite}.board-caption{position:absolute;left:50%;bottom:10px;transform:translate(-50%);z-index:9;display:inline-flex;align-items:center;gap:7px;max-width:92%;padding:7px 14px;border-radius:999px;font-size:13px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;background:#fffffff2;border:1px solid var(--line);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:emote-pop .2s ease-out}.board-caption svg{flex:0 0 auto}.board-caption b{font-family:Songti SC,Georgia,serif;font-weight:700}.board-caption.pv{color:#9a6a1e;border-color:#c4892b66}.board-caption.pv svg,.board-caption.pv b{color:#9a6a1e}.board-caption.review{color:var(--jade-deep);border-color:#12a06a45}.board-caption.review svg,.board-caption.review b{color:var(--jade-deep)}.cloud-card{gap:9px}.card-head>strong.jade{color:var(--jade-deep)}.card-head>strong.muted{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-weight:600;font-size:12px}.card-head>strong.loading:before{content:"";width:12px;height:12px;border-radius:50%;border:2px solid #12a06a40;border-top-color:var(--jade);animation:spin .8s linear infinite}.cloud-moves{display:flex;flex-wrap:wrap;gap:5px;min-height:62px;align-content:flex-start}.cloud-move{display:inline-flex;align-items:center;gap:5px;min-height:36px;padding:7px 10px;border-radius:8px;background:var(--surface-2);color:var(--ink);font-size:13px;cursor:default;border:1px solid transparent;transition:background .12s,box-shadow .12s,border-color .12s}.cloud-move b{font-family:Songti SC,Georgia,serif;font-weight:700}.cloud-move em{font-style:normal;font-variant-numeric:tabular-nums;font-size:11.5px;color:var(--muted)}.cloud-move.clickable{cursor:pointer}.cloud-move:hover,.cloud-move:focus-visible{background:#e9eef3;border-color:var(--line-strong);outline:none}.cloud-move.r2{background:var(--jade-soft)}.cloud-move.r2 b,.cloud-move.r2 em{color:var(--jade-deep)}.cloud-move.r2:hover,.cloud-move.r2:focus-visible{box-shadow:inset 0 0 0 1px #12a06a59}.cloud-move.r0{background:#fbf2df}.cloud-move.r0 b,.cloud-move.r0 em{color:#9a6a1e}.cloud-card .cloud-empty{display:flex;align-items:center;min-height:62px;margin:0}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:560px){.public-actions{grid-template-columns:1fr 1fr .72fr;gap:7px}.public-actions .room-action.go{display:inline-flex}.public-actions .room-action{min-height:40px;padding:0 8px;font-size:13px}.mobile-quick-seat{display:none!important;position:static}.public-room-grid{padding-bottom:0}}
