:root{color-scheme:light;--paper: #eee4cf;--paper-2: #dfcfad;--ink: #251c16;--muted: #766852;--red: #b5332f;--red-dark: #7c201d;--black: #202020;--blue: #214e69;--gold: #c29a54;--shadow: rgba(38, 27, 18, .28)}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{overflow:hidden;background:radial-gradient(circle at 50% 18%,rgba(205,184,138,.34),transparent 36%),linear-gradient(180deg,#2a211b,#111);color:var(--ink);font-family:Songti SC,"Noto Serif CJK SC",STSong,ui-serif,serif;overscroll-behavior:none}button,input{font:inherit}button{min-height:46px;border:0;border-radius:4px;cursor:pointer;font-weight:900;letter-spacing:0;touch-action:manipulation}button:disabled{cursor:not-allowed;opacity:.48}input{width:100%;border:1px solid rgba(37,28,22,.28);border-radius:4px;background:#fffaecd1;color:var(--ink);outline:0;padding:12px 13px}.lobby-screen,.waiting-screen,.game-screen{position:relative;width:min(100vw,440px);height:100dvh;min-height:640px;margin:0 auto;overflow:hidden;background:var(--paper)}.lobby-screen,.waiting-screen{display:grid;align-content:center;gap:16px;padding:20px;background:linear-gradient(#eee4cfe8,#eee4cfe8),repeating-linear-gradient(90deg,rgba(0,0,0,.04) 0,rgba(0,0,0,.04) 1px,transparent 1px,transparent 14px)}.lobby-hero,.paper-header,.seat-grid,.waiting-actions,.card-peek,.hint-slip,.result-panel,.action-dock{border:1px solid rgba(37,28,22,.28);background:#f8efd8f0;box-shadow:0 18px 50px var(--shadow)}.lobby-hero{padding:24px}.signal-row{display:flex;align-items:center;gap:8px;color:var(--red-dark);font-size:13px;font-weight:900}.signal-dot{width:8px;height:8px;border-radius:50%;background:var(--red)}.signal-dot.online{background:#2f6f4e;box-shadow:0 0 14px #2f6f4e99}.lobby-hero h1{margin:14px 0 8px;color:var(--red-dark);font-size:43px;line-height:1.05;letter-spacing:0}.lobby-hero p{margin:0;color:var(--muted);line-height:1.65}.field{display:grid;gap:8px;margin-top:22px;color:var(--ink);font-size:13px;font-weight:900}.lobby-actions,.waiting-actions{display:grid;gap:12px;margin-top:18px}.join-row{display:grid;grid-template-columns:1fr 94px;gap:10px}.primary{background:var(--red);color:#fff7e8;box-shadow:0 3px 0 var(--red-dark)}.secondary{background:var(--black);color:#fff7e8;box-shadow:0 3px #000}.ghost{border:1px solid rgba(37,28,22,.34);background:#fffaeca3;color:var(--ink)}.small{min-height:38px;padding:0 16px}.paper-header{display:flex;align-items:center;justify-content:space-between;padding:16px}.paper-header div{display:grid;gap:2px}.paper-header span{color:var(--muted);font-size:12px;font-weight:800}.paper-header strong{color:var(--red-dark);font-size:30px}.seat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:14px}.seat-card{display:grid;min-height:92px;align-content:center;gap:5px;border:1px solid rgba(37,28,22,.22);background:#fffaecb8;color:var(--ink);text-align:left;padding:12px}.seat-card span,.seat-card em{color:var(--muted);font-size:11px;font-style:normal;font-weight:800}.seat-card strong{font-size:18px}.seat-card.occupied{background:#2a2a2a;color:#fff7e8}.seat-card.mine{outline:3px solid var(--gold)}.game-canvas-host{position:absolute;inset:0;overflow:hidden}.game-canvas{display:block;width:100%;height:100%}.card-peek{position:absolute;left:18px;right:18px;bottom:96px;display:grid;grid-template-columns:92px 1fr;gap:10px;padding:10px 12px;pointer-events:none}.card-peek span{color:var(--red-dark);font-size:10px;font-weight:900}.card-peek strong{display:block;margin-top:3px;font-size:17px}.card-peek p{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.card-peek.disabled{opacity:.72}.card-peek.disabled span{color:var(--muted)}.hint-slip{position:absolute;left:18px;right:18px;top:56px;display:grid;gap:4px;padding:9px 12px;pointer-events:none}.hint-slip strong{color:var(--red-dark);font-size:11px}.hint-slip span{color:var(--ink);font-size:12px}.target-rail{position:absolute;left:18px;right:18px;top:176px;display:grid;grid-template-columns:38px 1fr;align-items:center;gap:8px;padding:5px 9px;border:1px solid rgba(37,28,22,.24);background:#f8efd8e6;box-shadow:0 10px 28px #261b1229}.target-rail span{color:var(--muted);font-size:12px;font-weight:900}.target-rail div{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}.target-rail div::-webkit-scrollbar{display:none}.target-rail button{flex:0 0 auto;min-height:29px;padding:0 10px;border:1px solid rgba(37,28,22,.28);background:#fffaecb3;color:var(--ink);font-size:12px}.target-rail button.selected{border-color:var(--red);background:var(--red);color:#fff7e8}.game-screen.with-targets .hint-slip{top:58px}.role-guide-trigger{position:absolute;top:56px;right:14px;z-index:4;min-height:32px;padding:0 12px;border:1px solid rgba(37,28,22,.36);background:#202020e0;color:#fff7e8;box-shadow:0 8px 22px #261b122e;font-size:12px}.sound-toggle{position:absolute;top:56px;right:72px;z-index:4;min-height:32px;padding:0 10px;border:1px solid rgba(37,28,22,.36);background:#7c201de6;color:#fff7e8;box-shadow:0 8px 22px #261b122e;font-size:12px}.sound-toggle.off{background:#fffaecc7;color:var(--muted)}.fullscreen-toggle{position:absolute;top:56px;right:128px;z-index:4;width:48px;min-height:32px;padding:0;border:1px solid rgba(37,28,22,.36);background:#fffaecdb;color:var(--ink);box-shadow:0 8px 22px #261b122e;font-size:12px}.fullscreen-toggle.active{background:#7c201de6;color:#fff7e8}.hint-slip{right:136px}.game-screen.fullscreen-capable .hint-slip{right:190px}.role-guide-backdrop{position:absolute;inset:0;z-index:8;display:grid;align-items:end;background:#120e0b61}.role-guide-sheet{max-height:min(62dvh,530px);padding:14px 14px calc(14px + env(safe-area-inset-bottom));border-top:1px solid rgba(37,28,22,.36);background:#eee4cffa;box-shadow:0 -18px 46px #00000047}.role-guide-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.role-guide-head div{display:grid;gap:2px}.role-guide-head span{color:var(--muted);font-size:11px;font-weight:900}.role-guide-head strong{color:var(--red-dark);font-size:22px}.role-guide-list{display:grid;gap:8px;max-height:calc(min(62dvh,530px) - 90px);overflow-y:auto;padding-right:2px;scrollbar-width:none}.role-guide-list::-webkit-scrollbar{display:none}.role-guide-item{display:grid;grid-template-columns:86px 1fr;gap:10px;align-items:center;min-height:68px;padding:10px 11px;border:1px solid rgba(37,28,22,.2);background:#fffaecb8}.role-guide-item.current{border-color:var(--gold);box-shadow:inset 4px 0 0 var(--gold)}.role-guide-item div{display:grid;gap:4px}.role-guide-item strong{color:var(--ink);font-size:15px}.role-guide-item span{color:var(--red-dark);font-size:11px;font-weight:900}.role-guide-item p{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.action-dock{position:absolute;left:0;right:0;bottom:0;display:grid;grid-template-columns:1fr 168px;gap:12px;min-height:82px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));border-right:0;border-bottom:0;border-left:0}.action-text{display:grid;align-content:center;gap:4px;min-width:0}.action-text strong{overflow:hidden;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.action-text span{color:var(--muted);font-size:11px;line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.dock-buttons{display:grid;grid-template-columns:1fr;gap:8px}.dock-buttons:has(.ghost){grid-template-columns:74px 1fr}.result-panel{position:absolute;left:24px;right:24px;top:50%;display:grid;gap:10px;padding:18px;transform:translateY(-50%);text-align:center}.result-panel strong{color:var(--red-dark);font-size:25px}.result-panel span{color:var(--muted);line-height:1.55}.toast{position:absolute;left:18px;right:18px;bottom:100px;z-index:5;padding:12px 14px;background:var(--black);color:#fff7e8;box-shadow:0 12px 32px #00000047;text-align:center}@media(max-height:740px){.card-peek{display:none}.action-dock{min-height:74px}}
