:root{--bg: #0f2a1e;--bg-2: #133a29;--felt: #16513a;--felt-edge: #0c3325;--ink: #f3f6f3;--ink-dim: #b6c9be;--gold: #e7c558;--accent: #4fb286;--danger: #e2685f;--card-bg: #fbfdfb;--card-ink: #15241b;--card-red: #c33;--radius: 12px;--tap: 44px;--pad: clamp(8px, 2vw, 16px);font-family:ui-rounded,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif}*{box-sizing:border-box}html,body{margin:0;height:100%;background:radial-gradient(circle at 50% 30%,var(--bg-2),var(--bg));color:var(--ink);overflow:hidden;-webkit-text-size-adjust:100%}#root{height:100%}.app{height:100dvh;display:flex;flex-direction:column;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);position:relative}.btn{min-height:var(--tap);min-width:var(--tap);padding:0 16px;border-radius:10px;border:1px solid transparent;font:inherit;font-weight:600;cursor:pointer;color:var(--ink);background:#ffffff14;transition:transform .08s ease,background .15s ease}.btn:active{transform:translateY(1px) scale(.99)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--accent);color:#06251a}.btn--accent{background:var(--gold);color:#2a2207}.btn--ghost{background:#ffffff0f;border-color:#ffffff2e}.btn--block{width:100%}.btn--sm{min-height:36px;padding:0 12px;font-size:.85rem}.btn--round{border-radius:999px;width:var(--tap);padding:0;font-size:1.4rem;line-height:1}.conn-ribbon{position:absolute;top:8px;left:50%;transform:translate(-50%);background:#0009;color:var(--gold);padding:4px 14px;border-radius:999px;font-size:.8rem;z-index:50}.landing,.lobby,.splash{margin:auto;width:min(440px,92vw);padding:var(--pad);display:flex;flex-direction:column;gap:16px;overflow-y:auto;max-height:100%}.splash{text-align:center;color:var(--ink-dim)}.landing__title,.lobby__title{font-size:2.4rem;margin:0;letter-spacing:.05em;color:var(--gold)}.landing__sub,.lobby__sub{margin:0;color:var(--ink-dim)}.landing__error{color:var(--danger);margin:0;font-size:.9rem}.field{display:flex;flex-direction:column;gap:6px;border:0;padding:0;margin:0}.field__label{font-size:.85rem;color:var(--ink-dim)}.field__input{min-height:var(--tap);padding:0 12px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#00000040;color:var(--ink);font:inherit}.landing__form{display:flex;flex-direction:column;gap:16px}.seg{display:flex;gap:8px}.seg__btn{flex:1;min-height:var(--tap);border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#0003;color:var(--ink);font:inherit;cursor:pointer}.seg__btn.is-active{background:var(--accent);color:#06251a;border-color:var(--accent)}.landing__preview{list-style:none;margin:0;padding:0;display:grid;gap:6px}.landing__preview li{display:flex;gap:10px;align-items:center;background:#0003;padding:6px 10px;border-radius:8px}.landing__preview li.is-open{opacity:.55}.landing__preview-seat{width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:var(--felt);font-size:.8rem}.lobby__share{background:#00000038;padding:12px;border-radius:var(--radius);display:flex;flex-direction:column;gap:6px}.lobby__share-label{font-size:.8rem;color:var(--ink-dim)}.lobby__share-row{display:flex;gap:8px;align-items:center}.lobby__link{flex:1;background:#0000004d;padding:8px 10px;border-radius:8px;font-size:.8rem;word-break:break-all;user-select:all}.lobby__hint,.lobby__count{font-size:.82rem;color:var(--ink-dim);margin:0}.lobby__seats{list-style:none;margin:0;padding:0;display:grid;gap:8px}.seat-row{display:grid;grid-template-columns:auto auto 1fr auto;gap:10px;align-items:center;background:#00000038;padding:10px 12px;border-radius:10px;min-height:var(--tap)}.seat-row--you{outline:2px solid var(--gold)}.seat-row--empty{opacity:.6}.seat-row__badge{width:26px;height:26px;display:grid;place-items:center;border-radius:50%;background:var(--felt);font-weight:700}.seat-row__team{font-size:.75rem;color:var(--ink-dim)}.seat-row__nick{font-weight:600}.seat-row__tag{font-size:.7rem;background:var(--gold);color:#2a2207;border-radius:4px;padding:1px 5px}.seat-row__dot{width:10px;height:10px;border-radius:50%;background:#fff3}.seat-row__dot.is-on{background:var(--accent)}.lobby__foot{display:flex;flex-direction:column;gap:10px}.game{flex:1;display:grid;grid-template-rows:auto 1fr auto auto;gap:6px;padding:var(--pad);min-height:0}.scoreboard{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;background:#00000047;border-radius:10px;padding:6px 12px;position:relative}.scoreboard__team{display:flex;align-items:baseline;gap:8px}.scoreboard__team--b{justify-content:flex-end}.scoreboard__name{font-size:.8rem;color:var(--ink-dim)}.scoreboard__total{font-size:1.4rem;font-weight:800;font-variant-numeric:tabular-nums}.scoreboard__total.pos{color:var(--accent)}.scoreboard__total.neg{color:var(--danger)}.scoreboard__sets{color:var(--gold);letter-spacing:2px}.scoreboard__mid{text-align:center;font-size:.65rem;color:var(--ink-dim);display:flex;flex-direction:column}.scoreboard__bid{position:absolute;bottom:-18px;left:50%;transform:translate(-50%);font-size:.72rem;color:var(--gold);white-space:nowrap}.game__board{position:relative;min-height:0;display:grid;place-items:center}.game__marker{position:absolute;top:4px;right:4px}.table-grid{width:100%;height:100%;display:grid;grid-template-areas:".    north ." "west center east" ".    south .";grid-template-columns:1fr 1.4fr 1fr;grid-template-rows:1fr 1.2fr 1fr;gap:4px;background:radial-gradient(ellipse at center,var(--felt),var(--felt-edge));border-radius:20px;padding:8px;box-shadow:inset 0 0 0 3px #00000040}.pod--south{grid-area:south}.pod--north{grid-area:north}.pod--west{grid-area:west}.pod--east{grid-area:east}.table-center{grid-area:center;display:grid;place-items:center;text-align:center}.table-center__hint{font-size:.72rem;color:var(--ink-dim);margin:0}.pod{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px;border-radius:10px;min-width:0}.pod--act{background:#e7c55829;outline:1px solid var(--gold)}.pod--empty{opacity:.45}.pod--satout{opacity:.7}.pod__id{display:flex;align-items:center;gap:5px;font-size:.8rem;max-width:100%}.pod__seat-no{width:18px;height:18px;display:grid;place-items:center;border-radius:50%;background:#0006;font-size:.7rem}.pod__nick{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:9ch}.pod--you .pod__nick{color:var(--gold)}.pod__conn{width:8px;height:8px;border-radius:50%;background:var(--accent)}.pod__conn.is-off{background:var(--danger)}.pod__meta{display:flex;flex-wrap:wrap;gap:3px;justify-content:center}.tag{font-size:.62rem;padding:1px 5px;border-radius:4px;background:#0006;color:var(--ink-dim)}.tag--declarer{background:var(--gold);color:#2a2207}.tag--lead{background:var(--accent);color:#06251a}.tag--satout{background:var(--danger);color:#2a0c0a}.pod__count{font-size:.66rem;color:var(--ink-dim)}.pod__satout-cards{font-style:italic}.pod__play{min-height:56px;display:grid;place-items:center}.pod__lead-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:.7}.card{--w: 58px;width:var(--w);height:calc(var(--w) * 1.4);border-radius:8px;position:relative;user-select:none;flex:0 0 auto}.card--sm{--w: 38px}.card--lg{--w: 66px}.card--interactive{cursor:pointer}.card__face{position:absolute;inset:0;background:var(--card-bg);color:var(--card-ink);border-radius:8px;box-shadow:0 1px 3px #00000080;display:grid;place-items:center}.card__face--red{color:var(--card-red)}.card__back{position:absolute;inset:0;border-radius:8px;background:repeating-linear-gradient(45deg,#2b4f7a,#2b4f7a 5px,#224066 5px 10px);box-shadow:0 1px 3px #00000080}.card__center{font-size:calc(var(--w) * .55);line-height:1}.card__corner{position:absolute;display:flex;flex-direction:column;align-items:center;font-weight:700;line-height:1}.card__corner--tl{top:3px;left:4px}.card__corner--br{bottom:3px;right:4px;transform:rotate(180deg)}.card__rank{font-size:calc(var(--w) * .26)}.card__suit{font-size:calc(var(--w) * .22)}.card--legal .card__face{outline:2px solid var(--accent);outline-offset:1px}.card--sel{transform:translateY(-10px);z-index:2}.card--disabled .card__face{filter:grayscale(.7) brightness(.8);opacity:.6}.hand{display:flex;justify-content:center;gap:2px;padding:8px 6px 4px;overflow-x:auto;touch-action:none;scrollbar-width:thin;min-height:calc(66px * 1.4 + 16px)}.hand__slot{transition:transform .16s ease;outline:none}.hand--reduced .hand__slot{transition:none}.hand--satout{flex-direction:column;align-items:center;gap:6px;opacity:.85}.hand__satout-cards{display:flex;justify-content:center;gap:2px}.hand__satout-label{margin:0;font-size:.82rem;color:var(--ink-dim);font-style:italic}.prompts{min-height:0}.panel{background:#00000057;border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:8px}.panel__title{margin:0;font-size:1rem}.panel__hint{margin:0;font-size:.85rem;color:var(--ink-dim)}.panel__hint--soft{opacity:.8}.panel__warn{margin:0;font-size:.82rem;color:var(--gold)}.panel__note{margin:0;font-size:.78rem;color:var(--accent)}.panel__actions{display:flex;gap:8px;flex-wrap:wrap}.bid-stepper{display:flex;align-items:center;justify-content:center;gap:16px}.bid-stepper__val{font-size:2rem;font-weight:800;min-width:2ch;text-align:center;font-variant-numeric:tabular-nums}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mode-card{text-align:left;display:flex;flex-direction:column;gap:3px;padding:8px;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:#00000040;color:var(--ink);cursor:pointer;min-height:var(--tap)}.mode-card.is-active{border-color:var(--gold);background:#e7c55824}.mode-card__label{font-weight:700;font-size:.9rem}.mode-card__blurb{font-size:.72rem;color:var(--ink-dim)}.suit-row{display:flex;gap:8px}.suit-btn{flex:1;min-height:var(--tap);font-size:1.5rem;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:var(--card-bg);color:var(--card-ink);cursor:pointer}.suit-btn--red{color:var(--card-red)}.suit-btn.is-active{outline:3px solid var(--gold)}.bidlog{display:flex;flex-wrap:wrap;gap:6px;font-size:.74rem;color:var(--ink-dim);justify-content:center}.bidlog__item{background:#00000040;padding:2px 8px;border-radius:999px}.satout-banner{text-align:center;font-size:.82rem;color:var(--gold);background:#0000004d;border-radius:8px;padding:6px;margin:0}.marker{background:#0006;border-radius:10px;padding:6px 10px;font-size:.78rem;text-align:center;max-width:150px}.marker__closed,.marker__open{display:flex;flex-direction:column;align-items:center;gap:2px}.marker__face-down{font-size:1.4rem;font-weight:800;color:var(--gold)}.marker__caption{font-size:.66rem;color:var(--ink-dim)}.marker__peek{font-size:.68rem;background:none;border:1px solid rgba(255,255,255,.2);color:var(--ink-dim);border-radius:6px;padding:2px 6px;cursor:pointer}.marker__mine{color:var(--gold);font-weight:700}.marker__suit{font-size:1.5rem}.marker__suit.is-red,.is-red{color:var(--card-red)}.marker__mode{font-weight:700}.marker__rank{font-size:.66rem;color:var(--ink-dim)}.peek{text-align:center;position:relative}.peek__overlay{position:absolute;bottom:110%;left:50%;transform:translate(-50%);background:#000000d9;border-radius:12px;padding:10px;z-index:30;box-shadow:0 6px 24px #00000080}.peek__cards{display:flex;gap:6px}.peek__play{display:flex;flex-direction:column;align-items:center;gap:3px}.peek__play.is-winner{outline:2px solid var(--gold);border-radius:8px;padding:2px}.peek__who{font-size:.66rem;color:var(--ink-dim);max-width:7ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.peek__winner{margin:6px 0 0;font-size:.74rem;color:var(--gold)}.reveal{position:fixed;inset:0;background:#0009;display:grid;place-items:center;padding:var(--pad);z-index:40}.reveal__card{background:var(--bg-2);border-radius:var(--radius);padding:16px;width:min(560px,94vw);max-height:90dvh;overflow-y:auto;display:flex;flex-direction:column;gap:12px;box-shadow:0 12px 40px #0009}.reveal__title{margin:0;font-size:1.2rem}.reveal__title--win{color:var(--gold)}.made{color:var(--accent)}.failed{color:var(--danger)}.reveal__lines{list-style:none;margin:0;padding:0;display:grid;gap:3px;font-size:.88rem;color:var(--ink-dim)}.reveal__delta{color:var(--ink);font-weight:700}.reveal__set{margin:0;color:var(--gold);font-weight:700}.reveal__marker{margin:0;font-size:.85rem}.reveal__hands{display:grid;gap:8px}.reveal__hand{background:#00000038;border-radius:8px;padding:6px 8px}.reveal__hand--satout{outline:1px solid var(--danger)}.reveal__hand-nick{font-size:.78rem;color:var(--ink-dim)}.reveal__hand-cards{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.reveal__actions{display:flex;justify-content:flex-end}.reveal__pending{color:var(--ink-dim);text-align:center}@media(orientation:landscape)and (max-height:520px){.table-grid{grid-template-rows:.9fr 1fr .9fr}.card{--w: 46px}.card--lg{--w: 52px}.hand{min-height:84.8px}.bid-stepper__val{font-size:1.5rem}}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
