:root{--bg: #e9ddc0;--bg-card: #efe4c8;--bg-soft: #e6d7b6;--bg-input: #f7f0dc;--line: rgba(58, 44, 22, .14);--text: #2f291f;--muted: #948b73;--primary: #9e3b2f;--primary-dark: #883227;--primary-text: #f1e7cb;--green: #1c4733;--accent: #d29b32;--danger: #b23a2a;--felt-hi: #2b5e40;--felt-lo: #173a26;--wood-hi: #9c4d3a;--wood-lo: #5f2d22;--tray: rgba(0, 0, 0, .26);--tile-bg-1: #efe3c2;--tile-bg-2: #e6d7b0;--tile-bg-3: #d9c699;--blue-ink: #1f7fb8;--blue-pip: #1f7fb8;--red-ink: #d8503c;--red-pip: #d8503c;--orange-ink:#e8852b;--orange-pip:#e8852b;--black-ink: #3a352d;--black-pip: #3a352d;--page-hi: #f0e6cb;color-scheme:light}@media (prefers-color-scheme: dark){:root{--bg: #1d1810;--bg-card: #251e13;--bg-soft: #2e2517;--bg-input: #2c2417;--line: rgba(255, 255, 255, .1);--text: #e3d4ad;--muted: #a2967a;--primary: #b8483a;--primary-dark: #a23d31;--primary-text: #f5ecd4;--green: #2f7a52;--accent: #d9a73f;--danger: #e08163;--tray: rgba(0, 0, 0, .32);--page-hi: #251e13;color-scheme:dark}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Work Sans,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:radial-gradient(circle at 50% -10%,var(--page-hi),var(--bg) 60%);color:var(--text);-webkit-tap-highlight-color:transparent}#root{display:flex;flex-direction:column}.logo{font-family:Yeseva One,Georgia,serif;font-weight:400;font-size:2.7rem;letter-spacing:0;margin:0;color:var(--green);display:inline-flex;align-items:center;gap:.45rem}@media (prefers-color-scheme: dark){.logo{color:var(--text)}}.logo:before{content:"";width:.5em;height:.5em;border-radius:50%;background:var(--accent);box-shadow:inset 0 1px 1px #ffffff73}.tagline{color:var(--muted);margin-top:.4rem;font-weight:500}.splash,.home,.lobby{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;text-align:center}.spinner{width:38px;height:38px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.spinner{animation-duration:2s}}.card{background:var(--bg-card);border:1px solid var(--line);border-radius:18px;padding:1.5rem;width:100%;max-width:380px;display:flex;flex-direction:column;gap:.9rem;box-shadow:0 1px 2px #281e0f0f,0 24px 48px -28px #281e0f80}.card h2{font-family:Yeseva One,Georgia,serif;font-weight:400;letter-spacing:0;margin:0 0 .2rem;color:var(--text)}.field{display:flex;flex-direction:column;gap:.4rem;text-align:left;font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}input{background:var(--bg-input);border:1px solid var(--line);border-radius:10px;padding:.72rem .85rem;color:var(--text);font-family:inherit;font-size:1rem;width:100%}input::placeholder{color:var(--muted);opacity:.7}input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}.code-input{text-transform:uppercase;letter-spacing:.4em;text-align:center;font-weight:800;font-size:1.4rem;color:var(--green)}.join-row{display:flex;gap:.5rem}.join-row .code-input{flex:1}.divider{text-align:center;color:var(--muted);font-size:.8rem;font-weight:500;position:relative}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:var(--bg-input);color:var(--text);border-radius:10px;padding:.72rem 1rem;font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .05s ease,background .15s ease,opacity .15s ease,box-shadow .15s ease}.btn:hover{background:var(--bg-soft)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:transparent;color:var(--primary-text);box-shadow:0 3px 10px -2px #9e3b2f80}.btn-primary:hover{background:var(--primary-dark)}.btn-small{padding:.38rem .65rem;font-size:.8rem}.btn-link{background:none;border:none;color:var(--muted);text-decoration:underline;text-underline-offset:2px;padding:.4rem;font-weight:600}.btn-icon{width:2.4rem;height:2.4rem;padding:0;display:grid;place-items:center;font-size:1.15rem;line-height:1}.btn-icon.is-active{background:var(--green);border-color:transparent;color:#ede2c6}.error{color:var(--danger);font-size:.9rem;font-weight:600;margin:0}.hint{color:var(--muted);font-size:.9rem;font-weight:500;margin:0}.code-display{display:flex;align-items:center;gap:.6rem;background:var(--bg-input);border:1px solid var(--line);border-radius:12px;padding:.6rem .8rem}.code-label{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.code-value{font-size:1.4rem;font-weight:800;letter-spacing:.3em;color:var(--green);flex:1}.player-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.player-list li{display:flex;align-items:center;gap:.6rem;background:var(--bg-input);border:1px solid var(--line);border-radius:12px;padding:.55rem .7rem;text-align:left}.player-list li.me{border-color:var(--green);box-shadow:inset 0 0 0 1px var(--green)}.player-list .empty-slot{opacity:.5;border-style:dashed;background:transparent}.player-list .seat{width:1.7rem;height:1.7rem;display:grid;place-items:center;background:var(--accent);color:#3a2708;border-radius:50%;font-weight:800;font-size:.85rem}.player-list .empty-slot .seat{background:var(--bg-soft);color:var(--muted)}.player-list .name{flex:1;font-weight:600}.badge{font-size:.64rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.18rem .5rem;border-radius:999px;background:var(--bg-soft);border:1px solid var(--line);color:var(--muted)}.badge-you{background:var(--green);color:#ede2c6;border-color:transparent}.game{flex:1;display:flex;flex-direction:column;gap:.75rem;padding:.75rem;max-width:900px;width:100%;margin:0 auto}.game-bar{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}.turn-track{display:flex;gap:.4rem;flex-wrap:wrap}.turn-chip{display:flex;align-items:center;gap:.45rem;background:var(--bg-card);border:1px solid var(--line);border-radius:999px;padding:.32rem .7rem .32rem .4rem;font-size:.85rem;font-weight:600}.turn-chip.active{background:var(--green);border-color:transparent;color:#ede2c6}.turn-chip.active .chip-count{background:#00000038;color:#ede2c6}.turn-chip.me .chip-name{font-weight:800}.chip-count{background:var(--bg-soft);border-radius:999px;padding:0 .45rem;font-size:.75rem;font-weight:700;color:var(--muted)}.game-meta{display:flex;align-items:center;gap:.6rem;font-size:.85rem;font-weight:600;color:var(--muted)}.pool-count{background:var(--bg-card);border:1px solid var(--line);border-radius:999px;padding:.32rem .7rem;font-size:.78rem;color:var(--muted)}.menu{position:relative}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20}.menu-dropdown{position:absolute;right:0;top:calc(100% + 6px);width:190px;background:var(--bg-input);border:1px solid var(--line);border-radius:13px;box-shadow:0 16px 36px -10px #00000073;overflow:hidden;z-index:30}.menu-item{display:flex;align-items:center;gap:.7rem;width:100%;padding:.72rem .85rem;background:none;border:none;border-bottom:1px solid var(--line);font-family:inherit;font-size:.92rem;font-weight:600;color:var(--text);text-align:left;cursor:pointer}.menu-item:last-child{border-bottom:none}.menu-item:hover:not(:disabled){background:var(--bg-soft)}.menu-item:disabled{opacity:.4;cursor:not-allowed}.menu-item .menu-ico{width:1.1rem;text-align:center;color:var(--primary);flex:none}.menu-item.danger,.menu-item.danger .menu-ico{color:var(--primary)}.winner-banner{background:linear-gradient(120deg,var(--green),var(--accent));color:#1a1208;font-family:Yeseva One,Georgia,serif;font-weight:400;text-align:center;padding:.8rem;border-radius:14px}.table-area{position:relative;flex:1;background:repeating-linear-gradient(45deg,rgba(255,255,255,.025) 0 3px,transparent 3px 6px),radial-gradient(circle at 50% 0%,var(--felt-hi),var(--felt-lo) 72%);border:8px solid transparent;border-image:linear-gradient(180deg,var(--wood-hi),var(--wood-lo)) 1;border-radius:12px;padding:1rem;display:flex;flex-wrap:wrap;align-content:flex-start;gap:1.1rem;min-height:200px;box-shadow:inset 0 4px 30px #00000073,inset 0 0 0 1px #00000038}.table-area:before{content:"R";position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-family:Yeseva One,Georgia,serif;font-size:clamp(120px,28vw,260px);line-height:1;color:#ffffff0b;pointer-events:none;z-index:0;-webkit-user-select:none;user-select:none}.table-area>*{position:relative;z-index:1}.table-empty{color:#fff9;font-weight:500;margin:auto}.meld-row{display:flex;align-items:center;gap:4px;padding:6px;border-radius:10px;background:#0000002e;border:1.5px solid rgba(210,155,50,.5);min-height:60px;position:relative}.meld-row.meld-valid{border-color:#96dcaab3}.meld-row.meld-invalid{border-color:#e08163d9}.meld-grip{align-self:stretch;display:flex;align-items:center;justify-content:center;padding:0 3px;margin:-2px 1px -2px -2px;color:#ffffff73;font-size:.85rem;letter-spacing:-2px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.meld-grip:active{cursor:grabbing}.meld-drag-preview{box-shadow:0 14px 28px #0000008c;background:#143223f2}.new-meld-drop{min-height:60px;width:56px;box-sizing:border-box;border:2px dashed rgba(210,155,50,.5);border-radius:10px;display:grid;place-items:center;color:#f4e0b4b3;font-size:1.9rem;font-weight:400;line-height:1;padding:6px}.new-meld-drop.over{border-color:var(--accent);color:#fff4dd;background:#d29b3229}.rack-area{background:repeating-linear-gradient(90deg,rgba(0,0,0,.07) 0 2px,transparent 2px 8px),linear-gradient(180deg,var(--wood-hi),var(--wood-lo));border:1px solid rgba(0,0,0,.28);border-radius:12px;padding:5px;box-shadow:0 3px 10px #0003}.rack-grid{--slot-w: 46px;--slot-h: 62px;display:grid;grid-template-columns:repeat(auto-fill,var(--slot-w));grid-auto-rows:var(--slot-h);justify-content:center;gap:5px;max-height:42vh;overflow-y:auto;padding:8px;background:var(--tray);border-radius:8px;box-shadow:inset 0 3px 8px #00000080,inset 0 -1px #ffffff0f}.rack-slot{width:var(--slot-w);height:var(--slot-h);border-radius:8px;display:grid;place-items:center;background:#0000001a;box-shadow:inset 0 0 0 1px #ffffff08}.rack-slot.filled{background:transparent;box-shadow:none}.rack-slot.over{box-shadow:inset 0 0 0 2px var(--accent);background:#d29b3224}.tile{position:relative;width:44px;height:58px;background:linear-gradient(158deg,var(--tile-bg-1) 0%,var(--tile-bg-2) 60%,var(--tile-bg-3) 100%);border-radius:8px;display:grid;place-items:center;font-weight:700;font-size:1.5rem;cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:inset 0 2px 1px #fffcf0d9,inset 0 -4px 6px #8c64324d,0 3px 5px #28190a57;touch-action:none}.tile:active{cursor:grabbing}.tile-dragging{box-shadow:0 12px 24px #00000080;transform:scale(1.05)}.tile-pip{position:absolute;top:4px;left:5px;font-size:.62rem;line-height:1;pointer-events:none}.tile-orange .tile-pip{font-size:.8rem;top:1px}.tile-face{-webkit-text-stroke:.5px rgba(40,25,10,.24);paint-order:stroke fill}.tile-red .tile-face{color:var(--red-ink)}.tile-red .tile-pip{color:var(--red-pip)}.tile-blue .tile-face{color:var(--blue-ink)}.tile-blue .tile-pip{color:var(--blue-pip)}.tile-black .tile-face{color:var(--black-ink)}.tile-black .tile-pip{color:var(--black-pip)}.tile-orange .tile-face{color:var(--orange-ink)}.tile-orange .tile-pip{color:var(--orange-pip)}.tile-joker{background:linear-gradient(135deg,#fbe3a0,#e8b53d 55%,#cf8a2c)}.tile-joker .tile-face{color:#5a3a10;-webkit-text-stroke:0}.action-bar{display:flex;align-items:center;justify-content:flex-end;gap:.6rem;flex-wrap:wrap}.action-bar .hint{margin-right:auto}.btn-action{flex:0 1 280px;height:3rem;border-radius:12px;font-size:1.05rem;border-color:transparent}.btn-action.is-draw{background:var(--green);color:#ede2c6;box-shadow:0 3px 10px -2px #1c473380}.btn-action.is-draw:hover:not(:disabled){filter:brightness(1.06)}.btn-action.is-commit{background:var(--primary);color:var(--primary-text);box-shadow:0 3px 10px -2px #9e3b2f80}.btn-action.is-commit:hover:not(:disabled){background:var(--primary-dark)}.btn-action.is-reset{flex:0 0 auto;padding:0 1.1rem;background:var(--bg-input);color:var(--text);border-color:var(--line);box-shadow:none}.btn-action.is-reset:hover:not(:disabled){background:var(--bg-soft)}.game-error{text-align:right}@media (max-width: 480px){.game{gap:.5rem;padding:.5rem}.table-area{border-width:4px;padding:.7rem;min-height:0;gap:.8rem}.rack-area{padding:4px}.rack-grid{--slot-w: 44px;--slot-h: 58px;gap:4px;padding:7px}.tile{width:40px;height:54px;font-size:1.45rem}.tile-face{-webkit-text-stroke-width:.4px}.btn-action{flex:1 1 auto}.logo{font-size:2.1rem}}
