:root{color-scheme:dark;--bg: #0e2a1a;--felt: #134d2c;--tile-bg: #f4ead0;--tile-pip: #1a1a1a;--tile-pip-trump: #b53d3d;--text: #f5f5f0;--muted: #9bbfa8;--accent: #f4c948;--danger: #d65a5a}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px}button{background:var(--accent);color:#1a1a1a;border:none;padding:.6rem 1.2rem;border-radius:6px;font-weight:600;cursor:pointer}button:disabled{opacity:.4;cursor:not-allowed}button.secondary{background:transparent;color:var(--text);border:1px solid var(--muted)}input,select{background:#ffffff0f;color:var(--text);border:1px solid rgba(255,255,255,.2);padding:.5rem .7rem;border-radius:6px;font-size:1rem}.app{display:flex;flex-direction:column;min-height:100%}.home{margin:0 auto;max-width:480px;padding:2rem 1.5rem}.home h1{font-size:2rem;margin:0 0 .5rem}.home .tagline{color:var(--muted);margin-bottom:2rem}.actions{display:flex;flex-direction:column;gap:.75rem}.divider{height:1px;background:#ffffff1a;margin:1.5rem 0}.row{display:flex;gap:.5rem;align-items:center}.field{display:flex;flex-direction:column;gap:.3rem}.field label{color:var(--muted);font-size:.85rem}.lobby{margin:0 auto;max-width:720px;padding:1.5rem}.seats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin:1.25rem 0}.seat{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.85rem;display:flex;justify-content:space-between;align-items:center}.seat .team{color:var(--muted);font-size:.8rem}.seat.you{border-color:var(--accent)}.table-screen{display:grid;grid-template-rows:auto 1fr auto;height:100vh}.scoreboard{display:flex;justify-content:space-between;padding:.75rem 1rem;background:#00000040}.scoreboard .marks{font-size:1.4rem;font-weight:600}.felt{background:var(--felt);display:flex;flex-direction:column;justify-content:space-between;padding:1rem;position:relative;overflow:hidden}.trick-area{display:flex;justify-content:center;align-items:center;gap:.5rem;flex-wrap:wrap;flex:1}.played-tile{display:flex;flex-direction:column;align-items:center;gap:.25rem;font-size:.75rem;color:var(--muted)}.hand{display:flex;gap:.4rem;justify-content:center;padding:.75rem;background:#00000040;flex-wrap:wrap}.tile{background:transparent;border:2px solid transparent;border-radius:6px;padding:0;cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-block;line-height:0;transition:transform .1s ease}.tile.disabled{opacity:.45;cursor:not-allowed}.tile.legal{border-color:var(--accent);box-shadow:0 0 8px #f4c94859}.tile:active:not(.disabled){transform:translateY(1px)}.tile svg{display:block;border-radius:4px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.25))}.bidding{display:flex;flex-direction:column;gap:.6rem;padding:1rem;background:#000000c7;border-radius:10px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:300px;max-width:360px}.trump-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}.trump-btn{background:#ffffff14;color:var(--text);border:1px solid rgba(255,255,255,.18);padding:.5rem .4rem;border-radius:6px;font-weight:500;cursor:pointer;white-space:nowrap}.trump-btn:hover{background:#ffffff24}.error{background:var(--danger);color:#fff;padding:.6rem 1rem;border-radius:6px;margin:.75rem 0}.muted{color:var(--muted)}.recap-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000008c;z-index:10}.recap-card{background:#141414f2;border-radius:14px;padding:1.2rem 1.5rem;min-width:280px;max-width:360px;box-shadow:0 10px 40px #00000080;text-align:center;border:1px solid rgba(255,255,255,.1)}.recap-verdict{font-size:2rem;font-weight:800;letter-spacing:.05em;margin-bottom:.5rem}.recap-line{margin-bottom:.75rem;font-size:1.05rem}.recap-points{display:flex;justify-content:space-around;margin:.5rem 0 .75rem}.recap-num{font-size:1.6rem;font-weight:700}.recap-marks{display:flex;flex-direction:column;gap:.25rem;font-weight:600;margin-bottom:.75rem;color:var(--accent)}.recap-totals{font-size:.9rem;margin-bottom:.4rem}.recap-next{font-size:.8rem;font-style:italic}
