:root{--felt: #0f3d2e;--felt-2: #0c3325;--panel: #14241d;--line: #2a4a3c;--text: #eaf3ee;--muted: #9fbcae;--gold: #e7c873;--accent: #2f8f5b;--danger: #c0504d}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:radial-gradient(circle at 50% 0%,var(--felt),var(--felt-2));color:var(--text);-webkit-tap-highlight-color:transparent}button{font:inherit;cursor:pointer}.app{display:flex;flex-direction:column;height:100%}.topbar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--felt-2);border-bottom:1px solid var(--line)}.brand{font-weight:700;color:var(--gold)}.spacer{flex:1}.who{color:var(--muted)}.card-panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.25rem;max-width:420px;width:100%}.auth{display:grid;place-items:center;flex:1;padding:1rem}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-form h1{margin:0;color:var(--gold)}input,select{padding:.7rem;border-radius:8px;border:1px solid var(--line);background:#0d1b15;color:var(--text);font-size:1rem}.field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.75rem}.field span{color:var(--muted);font-size:.85rem}button.primary{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:.7rem 1rem;font-weight:600}button.primary:disabled{background:#2a4a3c;color:var(--muted)}button.danger{background:var(--danger);color:#fff;border:none;border-radius:8px;padding:.7rem 1rem}button.link{background:none;border:none;color:var(--muted);text-decoration:underline}.actions button:not(.primary):not(.danger):not(.link){background:#1d3429;color:var(--text);border:1px solid var(--line);border-radius:8px;padding:.7rem .9rem}.actions button:disabled{opacity:.4}.actions button:enabled:not(.link){box-shadow:0 0 0 1px var(--accent),0 0 9px #5fc88c66}.error-text{color:#ffb4b4;font-size:.9rem}.muted{color:var(--muted)}.small{font-size:.8rem}.lobby{flex:1;display:flex;flex-wrap:wrap;gap:1rem;padding:1rem;align-content:flex-start;justify-content:center}.code{font-family:ui-monospace,monospace;letter-spacing:.2em;color:var(--gold)}.members{list-style:none;padding:0;margin:.5rem 0}.members li{padding:.4rem 0;display:flex;align-items:center;gap:.5rem}.members li.offline{opacity:.5}.dot{width:9px;height:9px;border-radius:50%;display:inline-block}.dot.on{background:#57d98a}.dot.off{background:#777}.tag{font-size:.7rem;background:var(--line);border-radius:4px;padding:1px 5px;color:var(--muted)}.table{flex:1;display:flex;flex-direction:column;padding:.5rem;gap:.5rem;overflow:hidden}.game-toolbar{display:flex;align-items:center;gap:1rem;flex:0 0 auto}.danger-text{color:var(--danger)}.rooms-head{display:flex;align-items:center;justify-content:space-between}.room-list{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.5rem}.room-list li{display:flex;align-items:center;gap:.6rem}.room-list li .muted{flex:1}.room-list li button{padding:.4rem .8rem}.add-bot{display:flex;gap:.5rem;margin-bottom:.75rem}.add-bot select{flex:0 0 auto}.add-bot button{background:#1d3429;color:var(--text);border:1px solid var(--line);border-radius:8px;padding:.5rem .9rem}.add-bot button:disabled{opacity:.4}.felt{position:relative;flex:1;min-height:0;width:100%;max-width:1000px;margin:.25rem auto;border-radius:46%/42%;background:radial-gradient(ellipse at 50% 45%,#15543c,var(--felt) 60%,var(--felt-2));border:10px solid #5b3a21;box-shadow:inset 0 0 60px #0009,0 6px 22px #0007}.felt-center{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.seat{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:.3rem;width:240px}.seat.books-above{flex-direction:column-reverse}.seat-plate{display:flex;align-items:center;gap:.35rem;font-size:.85rem;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:.3rem .55rem;white-space:nowrap}.seat-plate.active{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}.seat-plate.mine{border-color:var(--accent)}.seat-backs{display:flex;gap:.3rem}.seat-books{display:flex;flex-wrap:wrap;justify-content:center;gap:.3rem;max-width:240px}.piles{display:flex;gap:1rem}.pile{display:flex;flex-direction:column;align-items:center;gap:.25rem}.empty-pile{width:46px;height:64px;border:1px dashed var(--line);border-radius:8px;display:grid;place-items:center;color:var(--muted);font-size:.7rem}.turn-banner{font-size:.95rem}.pcard{width:58px;height:81px;border-radius:8px;border:1px solid #00000033;background:#fdfdf7;display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;flex:0 0 auto;transition:transform .08s}.pcard img{width:100%;height:100%;object-fit:contain;display:block}.pcard.selected{transform:translateY(-12px);box-shadow:0 0 0 2px var(--gold)}.pcard.playable{outline:2px solid var(--accent);outline-offset:1px;animation:pcard-playable 1.6s ease-in-out infinite}@keyframes pcard-playable{0%,to{outline-color:var(--accent)}50%{outline-color:#5fc88c}}@media (prefers-reduced-motion: reduce){.pcard.playable{animation:none}}.card-back{width:50px;height:70px;border-radius:8px;background:repeating-linear-gradient(45deg,#2a4a3c,#2a4a3c 6px,#224033 6px,#224033 12px);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text)}.back-count{font-weight:700}.back-label{font-size:.6rem;color:var(--muted)}.book{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.2rem;border-radius:8px;border:1px solid var(--line);background:#14241d;color:var(--text)}.book.tappable{cursor:pointer}.book.clean{background:#b5273b;border-color:#7d1426}.book.dirty{background:#20262b;border-color:#000}.book.clean .book-count,.book.dirty .book-count{color:#fff}.book.targeted{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold)}.book-fan{display:flex}.book-fan .pcard{width:38px;height:53px;border-radius:5px;pointer-events:none}.book-fan .pcard:not(:first-child){margin-left:-20px}.book-count{font-size:.65rem;color:var(--muted)}.book.closed{position:relative;padding:3px;font-weight:700}.book.closed .pcard{width:48px;height:67px;pointer-events:none}.book.closed .book-rank{font-size:1.1rem;color:#fff}.book.closed .book-count{position:absolute;right:1px;bottom:1px;background:#000a;color:#fff;border-radius:4px;padding:0 3px;font-size:.6rem;line-height:1.35}.book.closed.clean{box-shadow:2px 2px #7d1426,4px 4px #5c0f1c}.book.closed.dirty{box-shadow:2px 2px #000,4px 4px #0008}.book.closed.targeted{box-shadow:0 0 0 2px var(--gold)}.book-rank{font-size:1.1rem}.book.threes{color:var(--gold);justify-content:center;padding:.3rem .4rem;font-size:.8rem}.myzone{background:var(--felt-2);border-top:1px solid var(--line);padding:.5rem;border-radius:12px 12px 0 0;flex:0 0 auto}.hand{display:flex;gap:.35rem;overflow-x:auto;padding:.75rem .25rem .5rem}.sort-controls{margin-left:.6rem;display:inline-flex;align-items:center;gap:.25rem}.sort-controls button{background:#1d3429;border:1px solid var(--line);color:var(--text);border-radius:6px;width:26px;height:24px;line-height:1;padding:0}.sort-controls button.active{border-color:var(--gold);color:var(--gold)}.tray{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}.tray-meld{background:#1d3429;border:1px solid var(--line);border-radius:6px;padding:.2rem .4rem;font-size:.8rem}.tray-meld .x{background:none;border:none;color:var(--danger);font-size:1rem}.actions{display:flex;flex-wrap:wrap;gap:.5rem;padding-top:.25rem}.scores{margin:1rem auto}.score-table{width:100%;border-collapse:collapse;margin:.75rem 0}.score-table th,.score-table td{border-bottom:1px solid var(--line);padding:.4rem .5rem;text-align:center}.score-table th:first-child,.score-table td:first-child{text-align:left}.myzone.spectating{text-align:center;padding:1rem}.chatdock{position:fixed;right:1rem;bottom:1rem;z-index:20}.chat-fab{position:relative;width:52px;height:52px;border-radius:50%;border:1px solid var(--line);background:var(--accent);font-size:1.4rem;box-shadow:0 4px 14px #0007}.chat-fab .badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;border-radius:10px;font-size:.7rem;padding:1px 6px}.chat-panel{width:min(340px,92vw);height:min(440px,70vh);display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 8px 28px #0008}.chat-head{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--felt-2);border-bottom:1px solid var(--line)}.chat-head .x{background:none;border:none;color:var(--muted);font-size:1.2rem}.chat-msgs{flex:1;overflow-y:auto;padding:.5rem .75rem;display:flex;flex-direction:column;gap:.35rem}.chat-msg{font-size:.9rem;line-height:1.3}.chat-msg b{color:var(--gold)}.chat-msg.me b{color:#8fe3b0}.chat-input{display:flex;gap:.4rem;padding:.5rem;border-top:1px solid var(--line)}.chat-input input{flex:1;min-width:0}.watchers{color:var(--muted);font-size:.85rem}.toast{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);background:var(--danger);color:#fff;padding:.6rem 1rem;border-radius:8px;box-shadow:0 4px 16px #0006;max-width:90vw}@media (min-width: 700px){.pcard{width:70px;height:98px}}.view-menu{position:relative;margin-left:auto}.view-menu-btn{font-size:1.2rem;line-height:1}.view-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30}.view-menu-pop{position:absolute;right:0;top:calc(100% + .35rem);z-index:31;display:flex;flex-direction:column;min-width:150px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:.25rem;box-shadow:0 8px 24px #0008}.view-menu-item{background:none;border:none;color:var(--text);text-align:left;padding:.45rem .6rem;border-radius:7px;font-size:.9rem}.view-menu-item:hover{background:#1d3429}.view-menu-item.active{color:var(--gold)}.view-menu-hint{display:block;color:var(--muted);font-size:.72rem}.view-table{overflow-y:auto}.view-table .felt{min-height:420px}.view-table .myzone{position:sticky;bottom:0;z-index:5}.view-compact .felt{min-height:min(300px,42vh);border-width:5px}.view-compact .felt-center{gap:.3rem}.view-compact .turn-banner{font-size:.8rem}.view-compact .seat{width:150px;gap:.2rem}.view-compact .seat-plate{font-size:.72rem;padding:.18rem .4rem}.view-compact .seat-books{max-width:150px}.view-compact .felt .pcard{width:42px;height:59px}.view-compact .empty-pile{width:38px;height:53px}.view-linear .felt{min-height:0;display:flex;flex-direction:column;gap:.5rem;padding:.25rem;margin:0;border:none;border-radius:0;background:none;box-shadow:none;overflow-y:auto}.view-linear .felt-center{position:static;transform:none;order:-1;width:100%;background:var(--felt-2);border:1px solid var(--line);border-radius:10px;padding:.5rem}.view-linear .seat,.view-linear .seat.books-above{position:static;transform:none;width:100%;flex-direction:row;align-items:center;gap:.5rem;background:var(--felt-2);border:1px solid var(--line);border-radius:10px;padding:.4rem .5rem}.view-linear .seat-books{max-width:none;margin-left:auto}
