:root{--felt: #1f7a4d;--felt-edge: #14543494;color-scheme:light}:root,[data-theme=light]{--bg: #eef2f5;--bg-grad: radial-gradient( circle at 50% 0%, #ffffff 0%, #dde6ec 60%, #c9d6df 100% );--surface: #ffffff;--surface-2: #f3f6f9;--border: #d4dde4;--text: #15232e;--text-dim: #5a6b78;--primary: #1f7a4d;--primary-text: #ffffff;--accent: #b8860b;--danger: #c0392b;--shadow: 0 10px 30px rgba(20, 40, 60, .15);--felt: #2a8d5c}[data-theme=dark]{color-scheme:dark;--bg: #0c1218;--bg-grad: radial-gradient( circle at 50% 0%, #1a2733 0%, #0f171f 60%, #070b0f 100% );--surface: #16202b;--surface-2: #1d2935;--border: #2a3947;--text: #e8eef3;--text-dim: #93a3b1;--primary: #2ecc71;--primary-text: #06160d;--accent: #e0b84c;--danger: #ff6b5b;--shadow: 0 12px 34px rgba(0, 0, 0, .55);--felt: #176a42}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}#root{height:100dvh;overflow-x:hidden}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg-grad);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none;-webkit-text-size-adjust:100%;text-size-adjust:100%;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}button{font:inherit;cursor:pointer}:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem 1rem;min-height:44px;border-radius:10px;font-weight:600;touch-action:manipulation;transition:transform .08s ease,background .15s ease,box-shadow .15s ease}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--primary-text);border-color:transparent}.btn-ghost{background:transparent}.input{width:100%;padding:.6rem .8rem;min-height:44px;font-size:16px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);user-select:text;-webkit-user-select:text}.card-surface{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#080e148c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;padding:1rem}.modal{width:min(440px,100%);padding:1.6rem}.modal h2{margin:0 0 .3rem}.muted{color:var(--text-dim)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app{height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:.8rem;padding:.7rem 1rem;padding-top:max(.7rem,env(safe-area-inset-top));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--surface) 80%,transparent)}.brand{font-weight:800;letter-spacing:-.02em;font-size:1.15rem;white-space:nowrap}.brand .spades{color:var(--primary)}.name-btn{max-width:32vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spacer{flex:1}.pill{padding:.25rem .6rem;border-radius:999px;font-size:.78rem;font-weight:600;border:1px solid var(--border)}.pill.open{color:var(--primary)}.pill.closed{color:var(--danger)}.lobby{max-width:880px;margin:0 auto;padding:1.5rem 1rem 3rem;width:100%}.lobby-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.lobby h1{font-size:clamp(1.6rem,4vw,2.4rem);margin:.4rem 0 .2rem}.tile{padding:1.2rem;display:flex;flex-direction:column;gap:.7rem}.tile h3{margin:0}.row{display:flex;gap:.5rem;align-items:center}.checkbox{display:flex;align-items:center;gap:.5rem}.game{flex:1;position:relative;min-height:0;overflow:hidden}.canvas-wrap{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;touch-action:none}.canvas-wrap canvas{outline:none;touch-action:none}.hud{position:absolute;top:max(.8rem,env(safe-area-inset-top));left:max(.8rem,env(safe-area-inset-left));display:flex;flex-direction:column;gap:.6rem;max-width:230px;z-index:20;pointer-events:none}.hud .card-surface{padding:.7rem .9rem;pointer-events:auto}.hud-toggle{pointer-events:auto;align-self:flex-start;min-height:auto;padding:.3rem .6rem;font-size:.8rem;background:color-mix(in srgb,var(--surface) 80%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}@media(max-width:767px){.hud{max-width:62vw;max-height:70vh;overflow-y:auto;gap:.45rem}}.hud h4{margin:0 0 .3rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.score-table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}.score-table td,.score-table th{padding:.15rem .4rem;text-align:right}.score-table th:first-child,.score-table td:first-child{text-align:left}.vul{color:var(--danger);font-weight:700}.events{position:absolute;bottom:max(.8rem,env(safe-area-inset-bottom));left:max(.8rem,env(safe-area-inset-left));max-width:min(320px,60vw);z-index:20;font-size:.85rem}.gameid{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:1.1rem;letter-spacing:.18em;font-weight:700}.bidbox{position:absolute;bottom:max(.8rem,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);padding:.7rem;display:flex;flex-direction:column;gap:.4rem;width:min(440px,94vw);max-width:94vw;z-index:30;background:color-mix(in srgb,var(--surface) 80%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.bid-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.3rem}.play-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:.3rem;max-height:8rem;overflow-y:auto}.bid-cell{min-height:44px;padding:.4rem 0;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-weight:700;font-size:16px;touch-action:manipulation}.bid-cell.red{color:var(--danger)}.bid-cell:disabled{opacity:.3}.bid-actions{display:flex;gap:.3rem}.bid-actions .btn{flex:1;padding:.4rem}@media(max-width:767px){.bidbox{padding:.45rem;gap:.25rem;width:min(440px,98vw);max-height:70vh;overflow-y:auto}.bid-grid{gap:.2rem}.bid-cell{min-height:36px;font-size:14px;padding:.2rem 0}.bid-actions .btn{min-height:36px;padding:.25rem}}@media(max-height:500px){.hud{max-height:90vh;overflow-y:auto;max-width:190px;gap:.35rem}.bidbox{padding:.35rem;gap:.18rem;width:min(420px,66vw);max-height:94vh;overflow-y:auto}.bid-grid{gap:.18rem}.bid-cell{min-height:30px;font-size:13px;padding:.1rem 0}.bid-actions .btn{min-height:30px;padding:.18rem}.play-grid{max-height:6rem}}.result-banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;padding:1.4rem 2rem;width:min(92vw,420px);z-index:5}.result-banner h2{margin:0 0 .4rem}.toast{position:fixed;bottom:max(1rem,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);max-width:92vw;background:var(--danger);color:#fff;padding:.6rem 1rem;border-radius:10px;z-index:80;box-shadow:var(--shadow)}.toast-info{background:var(--primary);color:var(--primary-text)}.claim-bar{position:absolute;bottom:max(.8rem,env(safe-area-inset-bottom));right:max(.8rem,env(safe-area-inset-right));display:flex;gap:.4rem;z-index:20}.turn-dot{display:inline-block;width:.6rem;height:.6rem;border-radius:50%;background:var(--primary);margin-right:.3rem;animation:pulse 1.4s infinite}.seat-turn{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary),var(--shadow)}.conn-dot{display:inline-block;width:.55rem;height:.55rem;border-radius:50%;background:var(--text-dim);margin-right:.3rem;vertical-align:middle}.conn-dot.on{background:var(--primary)}.playbox-heading{text-align:center;font-weight:700;font-size:.9rem;margin-bottom:.45rem}.hint{position:absolute;top:max(.8rem,env(safe-area-inset-top));left:50%;transform:translate(-50%);width:min(360px,92vw);padding:.8rem 1rem;text-align:center;z-index:40}.hint p{margin:0 0 .6rem;font-size:.9rem;line-height:1.4}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--border)}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(max-width:640px){.topbar{gap:.4rem;padding-left:max(.6rem,env(safe-area-inset-left));padding-right:max(.6rem,env(safe-area-inset-right))}.topbar .btn{padding:.5rem .6rem}.brand{font-size:1rem}.pill{padding:.2rem .45rem;font-size:.7rem}.name-btn{max-width:22vw}.hud{flex-direction:row;flex-wrap:wrap;align-items:flex-start;max-width:none;right:max(.5rem,env(safe-area-inset-right));gap:.4rem;font-size:.8rem}.hud .card-surface{padding:.4rem .6rem}.hud h4{font-size:.68rem;margin-bottom:.15rem}.hud-auction{display:none}.gameid{font-size:.95rem;letter-spacing:.12em}.events{max-width:52vw;font-size:.78rem}}@media(max-height:450px)and (orientation:landscape){.hud{font-size:.72rem;gap:.3rem}.hud-auction{display:none}}@media(max-height:520px){.bidbox{padding:.4rem;gap:.25rem;max-height:calc(100dvh - 4.5rem);overflow-y:auto}.bid-grid{gap:.2rem}.bid-cell{min-height:34px;font-size:14px;padding:.2rem 0}.bid-actions .btn{min-height:36px}}
