:root{color-scheme:dark;--felt: #1a1d24;--felt-2: #0e1117;--felt-3: #050608;--ink: #f0f2f5;--muted: #9ca5b5;--dim: #6f7888;--panel: #0e1018;--panel-2: #161922;--panel-3: #1a1d27;--line: rgba(255, 255, 255, .1);--gold: oklch(.68 .14 70);--gold-2: oklch(.79 .17 73);--pink: oklch(.85 .15 92);--blue: oklch(.68 .14 70);--green: oklch(.85 .15 92);--danger: #ff7468;--card-bg: #ffffff;--card-edge: #c7cad4;--card-red: #d8232a;--card-black: #18181c;--shadow: 0 18px 45px rgba(0, 0, 0, .42);--button-shadow: 0 5px 0 rgba(73, 55, 20, .95), 0 14px 28px rgba(0, 0, 0, .32)}*{box-sizing:border-box}html{min-height:100%;background:var(--felt-3)}body{margin:0;min-height:100vh;font-family:Fredoka,Segoe UI,system-ui,sans-serif;background:radial-gradient(120% 90% at 50% 28%,color-mix(in oklab,var(--felt) 92%,white 4%) 0%,var(--felt) 34%,var(--felt-3) 100%);color:var(--ink)}body:before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(140% 120% at 50% 30%,transparent 36%,rgba(0,0,0,.72) 100%),repeating-linear-gradient(45deg,rgba(0,0,0,.055) 0 1px,transparent 1px 5px),repeating-linear-gradient(-45deg,rgba(0,0,0,.055) 0 1px,transparent 1px 5px);mix-blend-mode:multiply}#app{position:relative;width:min(100%,980px);margin:0 auto;padding:10px 10px 28px}.topbar{display:flex;align-items:end;gap:10px;padding:4px 2px 10px;margin-bottom:8px;border-bottom:1px solid var(--line)}.topbar h1{margin:0;color:#fff;font-size:1.6rem;line-height:1;letter-spacing:0;text-shadow:0 1px 0 rgba(89,64,20,.95),0 0 18px color-mix(in oklab,var(--gold-2) 55%,transparent)}.subtitle{color:var(--muted);font-size:.82rem}button{min-height:42px;border:1px solid rgba(255,255,255,.18);border-radius:7px;padding:9px 14px;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#1d1406;box-shadow:var(--button-shadow);cursor:pointer;font:700 .9rem/1 Fredoka,Segoe UI,system-ui,sans-serif;letter-spacing:0;text-transform:uppercase;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}button:hover{transform:translateY(-2px);filter:saturate(1.12)}button:active{transform:translateY(3px) scale(.98);box-shadow:0 2px #6b4516,0 8px 18px #00000059}button.secondary{background:linear-gradient(180deg,#1b1f29f5,#0d0f15fa);color:var(--ink);border-color:#ffffff24;box-shadow:0 4px #07080cf2,0 12px 26px #00000047}button.small{min-height:34px;padding:6px 9px;font-size:.7rem;border-radius:6px}button:disabled{cursor:not-allowed;opacity:.48;filter:grayscale(.6);transform:none}button.sortbtn.on,.seattoggle.on{border-color:color-mix(in oklab,var(--pink) 65%,white 10%);box-shadow:0 4px #604f16e0,0 0 22px color-mix(in oklab,var(--pink) 28%,transparent)}.scorepanel,.setup,.online,.handoff,.handover,.lasttrick{position:relative;background:linear-gradient(180deg,#161922f7,#0e1018fc),var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)}.scorepanel{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-bottom:10px;padding:10px;border-radius:8px;transform:rotate(-.35deg)}.scorecell{min-width:0;padding:8px 9px;border:1px solid rgba(255,255,255,.08);border-radius:6px;background:#ffffff08;box-shadow:inset 0 0 0 1px #ffffff08}.scorecell .label{margin-bottom:4px;color:var(--dim);font-size:.66rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.scorecell .subnote{margin-bottom:4px;color:var(--dim);font-size:.58rem;line-height:1.15}.scorecell .value{overflow-wrap:anywhere;color:var(--ink);font-size:1rem;font-weight:900;line-height:1.05}.scorecell .value.big{color:var(--gold);font-size:1.65rem;text-shadow:0 2px 0 rgba(82,62,16,.95)}.crosses{min-height:1em;color:var(--pink);font-weight:900;letter-spacing:0}.table{display:grid;grid-template-areas:". north ." "west center east" ". south .";grid-template-columns:minmax(76px,.92fr) minmax(170px,1.18fr) minmax(76px,.92fr);gap:8px;align-items:center;min-height:300px;max-width:940px;margin-inline:auto;margin-bottom:10px;padding:14px 12px;border:1px solid rgba(255,255,255,.08);border-radius:8px;background:radial-gradient(ellipse at center,rgba(255,255,255,.06),transparent 58%),linear-gradient(180deg,#0c0e14eb,#08090ee0);box-shadow:inset 0 0 45px #00000059,0 20px 55px #00000047}.seat{position:relative;min-width:0;padding-top:4px;padding-bottom:2px;text-align:center}.seat.north{grid-area:north}.seat.west{grid-area:west}.seat.east{grid-area:east}.center{grid-area:center;min-width:0;text-align:center}.seat .seatname{display:inline-flex;max-width:100%;align-items:center;flex-wrap:wrap;justify-content:center;gap:4px;position:relative;z-index:2;color:var(--muted);font-size:.78rem;font-weight:900;line-height:1.1}.seat .seatname.active{color:#16110a;background:var(--pink);text-shadow:none;box-shadow:0 0 0 1px #ffffff1f,0 0 16px color-mix(in oklab,var(--pink) 40%,transparent)}.seat .seatname.partner:after{content:"♥";color:var(--pink)}.seatmeta{margin-top:4px;position:relative;z-index:2;color:var(--dim);font-size:.66rem}.seat-token{display:inline-flex;align-items:center;justify-content:center;min-height:18px;border-radius:4px;padding:2px 5px;font-size:.62rem;font-weight:1000;line-height:1;letter-spacing:0}.seat-token.declarer{margin-left:2px;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#1a1208;box-shadow:0 0 0 1px #fff8df26,0 4px 10px #0003}.seat-token.dealer{margin-left:2px;background:linear-gradient(180deg,color-mix(in oklab,var(--gold) 72%,white 8%),color-mix(in oklab,var(--gold) 68%,black 20%));color:#041016;opacity:.9;transform:scale(.93)}.declarer-banner{display:inline-flex;align-items:center;gap:7px;margin-bottom:8px;padding:7px 10px;border:1px solid rgba(255,255,255,.14);border-radius:6px;background:linear-gradient(180deg,#191309f2,#0e0c0af5);box-shadow:0 4px #4f3a10e6,0 12px 24px #00000047}.declarer-banner .declarer-name{color:var(--gold);font-size:.88rem;font-weight:1000;line-height:1}.declarer-inline{margin-left:0}.declarer-cell .value{display:flex;align-items:center;flex-wrap:wrap;gap:5px}.tag{display:inline-flex;align-items:center;min-height:18px;border-radius:4px;padding:2px 5px;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#1a1208;font-size:.62rem;font-weight:900;line-height:1}.tag.dealer{background:linear-gradient(180deg,var(--blue),#1d7aa3);color:#041016}.backrow,.backfan{position:relative;display:inline-block;width:clamp(150px,22vw,212px);min-height:76px;margin-top:14px;margin-inline:auto;overflow:visible;z-index:1}.backrow.north,.backfan.north{transform:rotate(180deg)}.backrow.west,.backfan.west{transform:rotate(90deg)}.backrow.east,.backfan.east{transform:rotate(-90deg)}.backrow .cardback,.backfan .cardback{position:absolute;left:calc(50% - 16px);top:0;border:1px solid rgba(255,255,255,.5);background:linear-gradient(180deg,rgba(255,255,255,.08),transparent 45%),linear-gradient(180deg,#8e1825,#67111a);box-shadow:inset 0 0 0 2px #ffffff14,0 5px 12px #00000047;transform:translate(var(--fan-x, 0),var(--fan-y, 0)) rotate(var(--fan-rot, 0deg));animation:dealFromDeck .22s ease both;animation-delay:var(--deal-delay, 0ms)}.pilecard{border:1px solid rgba(255,255,255,.5);background:linear-gradient(180deg,rgba(255,255,255,.08),transparent 45%),linear-gradient(180deg,#8e1825,#67111a);box-shadow:inset 0 0 0 2px #ffffff14,0 5px 12px #00000047}.cardback{width:38px;height:56px;border-radius:6px;transform-origin:50% 100%}.card{position:relative;display:inline-flex;flex-direction:column;justify-content:space-between;width:clamp(56px,15vw,86px);height:clamp(82px,21vw,122px);padding:6px 7px;border:2px solid var(--card-edge);border-radius:8px;background:radial-gradient(circle at 50% 12%,rgba(255,255,255,.86),transparent 24%),linear-gradient(180deg,#fff,#e6e7ed);box-shadow:0 4px #9096a2f2,0 15px 24px #00000061;color:var(--card-black);font-size:1.06rem;font-weight:1000;line-height:1;user-select:none;transform:translate(var(--fan-x, 0),var(--fan-y, 0)) rotate(var(--fan-rot, 0deg));transform-origin:50% 92%;transition:transform .13s ease,box-shadow .13s ease,filter .13s ease,opacity .13s ease}.card.red{color:var(--card-red)}.card .corner-top,.card .corner-bottom{position:relative;z-index:1}.card .corner-bottom{align-self:flex-end;transform:rotate(180deg)}.card .card-center{position:absolute;inset:0;display:grid;place-items:center;padding-bottom:2px;font-size:1.85rem;line-height:1;opacity:.95}.card.playable{cursor:pointer;outline:3px solid color-mix(in oklab,var(--pink) 75%,white 10%);outline-offset:3px;box-shadow:0 4px #725f19f2,0 0 28px color-mix(in oklab,var(--pink) 28%,transparent),0 18px 28px #0000006b}.card.playable:hover{transform:translate(var(--fan-x, 0),calc(var(--fan-y, 0) - 8px)) rotate(var(--fan-rot, 0deg)) scale(1.025)}.card.disabled{cursor:not-allowed;opacity:.38;filter:grayscale(.7)}.card.dealing{animation:dealFromDeck .22s ease both;animation-delay:var(--deal-delay, 0ms)}.center .trick{display:flex;min-height:118px;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.dealstack{position:relative;width:74px;height:94px;margin:10px auto 0}.dealcardback{position:absolute;inset:0;border:1px solid rgba(70,216,255,.45);border-radius:6px;background:linear-gradient(135deg,rgba(255,79,184,.28),transparent 28%),repeating-linear-gradient(45deg,#12343b,#12343b 4px,#1e6070 4px 8px);box-shadow:inset 0 0 0 2px #fff8df14,0 6px 14px #00000047;animation:dealFromDeck .24s ease both;animation-delay:var(--deal-delay, 0ms)}.dealcardback:nth-child(1){--fan-x: 0px;--fan-y: 0px;--fan-rot: -3deg;--deal-delay: 0ms}.dealcardback:nth-child(2){--fan-x: 7px;--fan-y: -5px;--fan-rot: 4deg;--deal-delay: 45ms}.dealcardback:nth-child(3){--fan-x: -6px;--fan-y: 5px;--fan-rot: -5deg;--deal-delay: 90ms}.dealcardback:nth-child(4){--fan-x: 5px;--fan-y: 7px;--fan-rot: 2deg;--deal-delay: 135ms}.trickcard{text-align:center;animation:dealIn .18s ease both}.trickdiamond{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(3,auto);align-items:center;justify-items:center;gap:6px;min-height:206px}.trickdiamond-slot.top{grid-column:2;grid-row:1}.trickdiamond-slot.right{grid-column:3;grid-row:2}.trickdiamond-slot.bottom{grid-column:2;grid-row:3}.trickdiamond-slot.left{grid-column:1;grid-row:2}.trickdiamond-slot .card{transform:translate(0) rotate(0)}.trickcard .who{margin-bottom:4px;color:var(--muted);font-size:.7rem;font-weight:900}.center .trickinfo,.bidreason{color:var(--muted);font-size:.82rem;line-height:1.25}.biddingturn{margin-bottom:6px;color:var(--blue);font-size:.84rem;font-weight:900}.bigbid,.winner-banner{color:var(--gold);font-weight:1000;line-height:1.02;text-shadow:0 4px 0 #67330f,0 0 20px rgba(255,216,106,.35)}.bigbid{font-size:2.1rem;animation:pop .21s ease both}.bigbid.quiet{color:var(--ink);text-shadow:0 2px 0 rgba(0,0,0,.28)}.bigbid.pass{color:var(--muted);text-shadow:0 3px 0 rgba(0,0,0,.35)}.winner-banner{margin-bottom:8px;font-size:1.75rem;animation:pop .24s ease both}.trumpbadge{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:10px 14px;border:2px solid var(--gold);border-radius:8px;background:linear-gradient(90deg,rgba(255,79,184,.18),transparent 28%),linear-gradient(180deg,#241b17,#11100f);box-shadow:0 5px #5f3716,0 18px 34px #00000059;transform:rotate(.35deg)}.trumpbadge .tb-label{color:var(--gold);font-size:.7rem;font-weight:1000;letter-spacing:0;text-transform:uppercase}.trumpbadge .tb-suit{color:var(--ink);font-size:1.55rem;font-weight:1000;line-height:1}.trumpbadge.red .tb-suit{color:#ff6f7e}.trumpbadge.black .tb-suit{color:#fff7e5}.trumpbadge .tb-x2{border-radius:5px;padding:3px 7px;background:var(--pink);color:#fff;font-size:.9rem;font-weight:1000}.piles{display:flex;justify-content:center;gap:22px;margin:8px 0 4px}.pile{min-width:110px;cursor:pointer;text-align:center}.pile-stack{position:relative;width:62px;height:62px;margin-inline:auto;min-height:62px;overflow:visible}.pile-stack.diamond{transform:rotate(45deg)}.pilecard{position:absolute;left:50%;top:50%;width:18px;height:27px;border-radius:3px;transform-origin:50% 100%;margin:0}.pile-label,.pilehint,.small{color:var(--muted);font-size:.76rem;line-height:1.25}.pile-label{margin-top:4px;font-weight:800}.pilehint{text-align:center;margin-bottom:8px}.lasttrick{margin-bottom:10px;max-width:420px;margin-inline:auto;padding:10px;border-radius:8px}.lasttrick-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;font-size:.85rem;font-weight:900}.hand-wrap{margin:10px 0}.hand-label,.bid-current{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;color:var(--ink);font-size:.9rem;font-weight:900}.bid-current{color:var(--gold);font-size:1rem}.sortrow{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px;margin-left:0}.sortrow.compact{padding:3px;border-radius:999px;background:#fff8df0d;border:1px solid rgba(255,248,223,.12)}.sortrow.compact .sortbtn.small{min-height:30px;padding:5px 9px}.hand{display:flex;flex-wrap:nowrap;gap:0;align-items:flex-end;justify-content:center;overflow-x:auto;padding:2px 16px 6px;scrollbar-width:none}.hand .card{flex:0 0 auto;margin-left:clamp(-18px,-1.4vw,-12px)}.hand .card:first-child{margin-left:0}.hand .card:last-child{margin-right:16px}.hand::-webkit-scrollbar{display:none}.actions,.bidcontrols,.hostbox,.inviterow,.online-head{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.actions,.bidcontrols,.hostbox{margin-bottom:10px}.boardcontrols{justify-content:center}.trumpcontrols button{min-width:124px}.message{margin-bottom:10px;padding:10px 12px;border:1px solid rgba(255,116,104,.7);border-radius:7px;background:#68181880;color:#ffe4df;font-size:.86rem;font-weight:800}.handover,.handoff,.setup,.online{border-radius:8px;padding:16px}.handover{margin-bottom:10px;border-color:#ff4fb86b}.handover h3,.setup h2,.online h2,.online h3{margin:0 0 10px;color:var(--gold);font-weight:1000;line-height:1.05;text-shadow:0 3px 0 #5d3212}.setup p,.online p{max-width:68ch;color:var(--muted);line-height:1.38}.setup .presets{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:12px 0}.quicklabel{font-weight:900}.setuprow{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:8px 10px;max-width:520px;padding:8px 0;border-bottom:1px solid rgba(255,248,223,.08)}.seatno{flex:1 1 170px;font-weight:900}.seatno em{color:var(--muted);font-size:.8rem;font-style:normal;font-weight:700}.seattoggle{flex:0 0 auto;min-width:92px}.seatnameinput{flex:1 1 190px;min-width:0;min-height:42px;border:1px solid rgba(255,255,255,.14);border-radius:7px;padding:8px 10px;background:#090b10e6;color:var(--ink);font:700 .9rem/1.1 Fredoka,Segoe UI,system-ui,sans-serif;box-shadow:inset 0 0 0 1px #ffffff08}.seatnameinput::placeholder{color:var(--dim)}#startmatch,#dobid,#dopass{margin-top:8px;font-size:.95rem}.sep{border:none;border-top:1px solid var(--line);margin:18px 0}.online-head{justify-content:space-between;margin-bottom:12px}.online .code{display:inline-block;border:1px solid rgba(255,255,255,.18);border-radius:6px;padding:3px 7px;background:#ffffff08;color:var(--gold);font-family:Cascadia Mono,Consolas,monospace;font-size:.95em;letter-spacing:0}.conn{border:1px solid currentColor;border-radius:999px;padding:5px 9px;font-size:.76rem;font-weight:900}.conn.connected{color:var(--green)}.conn.connecting{color:var(--gold)}.conn.disconnected{color:var(--danger)}.invite,.namebox{margin:12px 0}.invite label,.namebox label{display:block;color:var(--muted);font-size:.82rem;font-weight:900}.inviterow{margin-top:6px}.inviterow input{flex:1 1 220px;min-width:0;min-height:42px;border:1px solid rgba(255,255,255,.14);border-radius:7px;padding:8px 10px;background:#090b10e6;color:var(--ink);font:700 .9rem/1.1 Fredoka,Segoe UI,system-ui,sans-serif}.qr{display:block;width:152px;height:152px;margin-top:10px;border:5px solid var(--card-bg);border-radius:8px;background:#fff;box-shadow:0 14px 30px #00000059;image-rendering:pixelated}.lseats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin:10px 0 14px}.lseat{min-height:118px;padding:12px;border:1px solid rgba(255,248,223,.14);border-radius:8px;background:linear-gradient(180deg,#183027d9,#081612e6);box-shadow:inset 0 0 0 1px #ffffff08}.lseat.mine{border-color:var(--gold);box-shadow:0 0 0 2px #ffd86a1f,0 0 24px #ffd86a2e}.lseat.empty{border-style:dashed;opacity:.86}.lseat.disconnected{border-color:#ff7468bf}.lseat-top,.lseat-state{color:var(--muted);font-size:.76rem;font-weight:800}.lseat-name{margin:8px 0;color:var(--ink);font-size:1.05rem;font-weight:1000}.handoff{margin-bottom:10px;text-align:center;border-color:#ffd86a80}.handoff-title{margin-bottom:6px;color:var(--gold);font-size:1.4rem;font-weight:1000}.handoff-sub{margin-bottom:12px;color:var(--muted);font-size:.9rem}.log{max-height:150px;overflow-y:auto;border-radius:7px;padding:10px;background:#00000038;color:var(--muted);font-size:.8rem}.log div{padding:2px 0;border-bottom:1px solid rgba(255,255,255,.06)}@keyframes pop{0%{opacity:0;transform:translateY(6px) scale(.9) rotate(-1deg)}70%{opacity:1;transform:translateY(-1px) scale(1.04) rotate(.5deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@keyframes dealIn{0%{opacity:0;transform:translateY(10px) rotate(-3deg) scale(.92)}to{opacity:1;transform:translateY(0) rotate(0) scale(1)}}@keyframes dealFromDeck{0%{opacity:0;transform:translate(calc(var(--fan-x, 0px) * .08),calc(12px + var(--fan-y, 0px) * .08)) rotate(calc(var(--fan-rot, 0deg) * .4)) scale(.86)}to{opacity:1;transform:translate(var(--fan-x, 0px),var(--fan-y, 0px)) rotate(var(--fan-rot, 0deg)) scale(1)}}@media(max-width:760px){#app{padding-inline:8px}.scorepanel{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;transform:none}.scorecell{padding:7px}.table{grid-template-columns:minmax(58px,.78fr) minmax(126px,1.34fr) minmax(58px,.78fr);min-height:270px;padding:10px 8px}.card{font-size:.96rem}.card .card-center{font-size:1.55rem}.backrow,.backfan{width:clamp(120px,24vw,172px);min-height:62px;margin-top:10px}.declarer-banner{max-width:100%}.bigbid{font-size:1.65rem}.winner-banner{font-size:1.35rem}.hand{gap:0}.trumpcontrols button{min-width:0;flex:1 1 120px}.setup{overflow-x:hidden}.setup .presets{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}.quicklabel{grid-column:1 / -1}.setup .presets button{min-width:0;padding-inline:8px}.setuprow{max-width:none}.seattoggle{min-width:0;padding-inline:8px}.seatnameinput{flex:1 1 160px;padding-inline:8px}}@media(max-width:460px){.topbar{align-items:start;flex-direction:column;gap:4px}.scorepanel{grid-template-columns:repeat(2,minmax(0,1fr))}.table{grid-template-areas:"north north" "west east" "center center";grid-template-columns:1fr 1fr;min-height:0}.center .trick{min-height:96px}.hand{justify-content:flex-start;padding-inline:14px;scroll-padding-inline:14px}.hand .card{margin-left:clamp(-14px,-2.8vw,-10px)}.hand .card:last-child{margin-right:14px}.piles{gap:10px}.pile{min-width:0;flex:1}.pile-stack{width:54px;height:54px;min-height:54px}.setuprow,.online-head{align-items:stretch}.setuprow .seatno{flex-basis:100%}.setuprow .seatnameinput{flex:1 1 100%}.setuprow .seattoggle{width:100%}.setup,.online,.handoff,.handover{padding:14px 10px}.inviterow input{flex-basis:100%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:1ms!important}}
