:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#11130f;color:#fff7ea}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{margin:0;min-width:320px;background:#11130f}button,input{font:inherit}button{border:0;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}button:disabled{cursor:not-allowed;filter:grayscale(.45);opacity:.5}.app-shell{position:relative;width:100vw;height:100dvh;overflow:hidden;padding:max(10px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left));background:radial-gradient(circle at 50% 24%,rgba(93,56,36,.55),transparent 32%),linear-gradient(180deg,#2c160e,#10130f 42%,#07110c);touch-action:none;-webkit-user-select:none;user-select:none}.match-header{position:absolute;z-index:20;top:max(10px,env(safe-area-inset-top));left:max(10px,env(safe-area-inset-left));right:max(10px,env(safe-area-inset-right));height:58px;display:grid;grid-template-columns:46px minmax(0,1fr) auto 46px;align-items:center;gap:10px;pointer-events:none}.match-header>*{pointer-events:auto}.icon-button{width:46px;height:46px;display:grid;place-items:center;border:1px solid rgba(255,247,234,.28);border-radius:50%;background:#181311b8;box-shadow:inset 0 0 0 2px #0003,0 8px 20px #00000047;color:#fff7ea;font-size:22px;font-weight:800}.match-title,.turn-status,.error-banner,.chat-panel,.chat-peek{border:1px solid rgba(255,247,234,.14);background:#140d0bc7;box-shadow:0 10px 28px #00000038;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.match-title{justify-self:center;min-width:min(310px,48vw);max-width:520px;padding:8px 18px;border-radius:8px;text-align:center}.match-title strong,.match-title span,.turn-status span,.turn-status strong{display:block;min-width:0}.match-title strong{overflow:hidden;color:#fff7ea;font-size:16px;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.match-title span{color:#f6dca7;font-size:13px}.turn-status{display:grid;grid-template-columns:auto auto;align-items:center;gap:9px;padding:7px 10px 7px 14px;border-radius:999px}.turn-status span{color:#d8f4da;font-size:13px;font-weight:800;text-transform:capitalize}.timer{width:44px;height:44px;display:grid;place-items:center;border:4px solid #71d95f;border-radius:50%;background:#1c2019;color:#fff7ea;font-size:14px}.timer.warning{border-color:#ffcd53;color:#ffe59e}.error-banner{position:absolute;z-index:40;top:76px;left:50%;width:min(560px,calc(100vw - 28px));padding:10px 14px;border-color:#ff8d9f80;border-radius:8px;background:#5d1f2deb;color:#ffe8ee;transform:translate(-50%)}.table{position:absolute;top:78px;right:12px;bottom:320px;left:12px;min-height:0}.felt{position:relative;width:100%;height:100%;overflow:hidden;border:13px solid #5c3420;border-radius:44%/22%;background:radial-gradient(ellipse at 50% 44%,#39a470f5,#187c4cf5 48%,#0c4c31fa),#135f42;box-shadow:inset 0 0 0 6px #ffe2b01f,inset 0 22px 48px #ffffff14,inset 0 -28px 70px #00000047,0 18px 38px #00000057}.felt:before{content:"";position:absolute;top:18px;right:18px;bottom:18px;left:18px;border:1px solid rgba(255,255,255,.07);border-radius:inherit;pointer-events:none}.player-seat{position:absolute;z-index:2;width:clamp(106px,16vw,154px);display:grid;grid-template-columns:42px minmax(0,1fr);grid-template-rows:auto auto;gap:4px 8px;padding:7px;border:1px solid rgba(255,255,255,.15);border-radius:8px;background:#07241bc2;color:#fdf8ec;box-shadow:0 10px 24px #0000003d}.player-seat.active{border-color:#ffe561;box-shadow:0 0 0 3px #ffe56140,0 0 24px #ffe56159}.player-seat.self{background:#0a4833d1}.player-seat.dropped{opacity:.58}.seat-bottom{bottom:8px;left:50%;transform:translate(-50%)}.seat-top{top:9px;left:50%;transform:translate(-50%)}.seat-left{top:50%;left:14px;transform:translateY(-50%)}.seat-right{top:50%;right:14px;transform:translateY(-50%)}.seat-top-left{top:13px;left:22%;transform:translate(-50%)}.seat-top-right{top:13px;right:22%;transform:translate(50%)}.avatar{grid-row:1 / span 2;width:42px;height:42px;overflow:hidden;display:grid;place-items:center;border:3px solid #ffe1a0;border-radius:50%;background:linear-gradient(145deg,#f5bd5a,#8ad7be);color:#1a201c;font-size:13px;font-weight:900}.avatar img{width:100%;height:100%;object-fit:cover}.seat-info{min-width:0}.seat-info strong,.seat-info span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-info strong{font-size:14px}.seat-info span{color:#ffdc70;font-size:13px;font-weight:800}.seat-badges{display:flex;gap:4px;min-width:0;overflow:hidden}.seat-badges span{min-width:0;overflow:hidden;padding:3px 6px;border-radius:999px;background:#0000004d;color:#d7eee4;font-size:10px;text-overflow:ellipsis;white-space:nowrap}.table-center{position:absolute;top:50%;left:50%;display:grid;grid-template-columns:repeat(4,auto);align-items:center;gap:clamp(9px,2vw,18px);transform:translate(-50%,-50%)}.deck-pile,.discard-pile,.joker-panel,.finish-slot{width:clamp(72px,9vw,104px);min-height:clamp(90px,13vh,124px);display:grid;place-items:center;padding:8px;border:1px solid rgba(255,247,234,.18);border-radius:8px;background:#05241cad;color:#fff7ea;text-align:center;box-shadow:0 10px 24px #0000003d}.deck-pile{background:linear-gradient(135deg,#2a4c8be0,#102141f5),#182a59}.deck-pile span,.discard-pile span,.joker-panel span{color:#dff4e8;font-size:11px;font-weight:800;text-transform:uppercase}.deck-pile strong{font-size:clamp(24px,4vw,38px)}.deck-pile small{color:#c8d5e4;font-size:10px}.finish-slot{border-style:dashed;color:#fff7eab8;font-size:13px;font-weight:900;text-transform:uppercase}.finish-slot.available{border-color:#68dd67b3;background:#1d5f3cb8}.playing-card{width:clamp(46px,6vw,66px);height:clamp(68px,9vw,94px);display:flex;flex-direction:column;justify-content:space-between;flex:0 0 auto;padding:6px;border:1px solid rgba(0,0,0,.18);border-radius:7px;background:radial-gradient(circle at 76% 78%,rgba(233,221,192,.55),transparent 28%),#fffaf0;color:#111712;box-shadow:0 5px 9px #00000038;text-align:left;touch-action:none}.playing-card strong{font-size:clamp(18px,2.8vw,25px);line-height:1}.playing-card span{align-self:flex-end;color:currentColor;font-size:clamp(18px,2.8vw,28px);line-height:1}.playing-card.red{color:#c52831}.playing-card.joker{background:linear-gradient(160deg,#fffdf1,#fff0bd)}.playing-card.selected{transform:translateY(-6px);box-shadow:0 0 0 3px #ffda548c,0 10px 18px #00000047}.playing-card.dragging{opacity:.22}.playing-card.compact{width:clamp(42px,5.2vw,58px);height:clamp(60px,7.5vw,78px);pointer-events:none}.hand-tray{position:absolute;z-index:15;left:max(10px,env(safe-area-inset-left));right:max(10px,env(safe-area-inset-right));bottom:max(10px,env(safe-area-inset-bottom));display:grid;grid-template-rows:minmax(0,1fr) auto;gap:8px;max-height:308px;padding:0;border:0;border-radius:22px;background:transparent;color:#17221b}.hand-board{min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:8px;overflow:hidden;padding:12px 14px 14px;border:1px solid rgba(30,92,78,.08);border-radius:22px;background:#f6fffdf0;box-shadow:0 -12px 32px #00000047,0 10px 28px #225c4c2e}.hand-header{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0;color:#273427}.hand-header h2{margin:0;color:#111817;font-size:clamp(18px,2.4vw,25px);line-height:1}.hand-header span{display:block;margin-top:4px;color:#60706b;font-size:12px;font-weight:800}.hand-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.hand-actions button,.section-title button{min-height:36px;padding:7px 14px;border-radius:999px;background:#fff;color:#141918;font-size:13px;font-weight:900;box-shadow:0 4px 14px #14221e29}.hand-actions button:first-child{background:#5abf75;color:#fff}.group-legend{display:flex;align-items:center;justify-content:center;gap:clamp(9px,2vw,18px);min-height:18px;color:#131817;font-size:clamp(11px,1.7vw,14px);font-weight:800;line-height:1}.group-legend span{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.legend-dot{width:12px;height:12px;display:inline-block;border-radius:4px}.legend-dot.pure{background:#4d9bf7}.legend-dot.sequence{background:#11c978}.legend-dot.set{background:#b376f2}.legend-dot.invalid{background:#ff5c66}.group-board{min-height:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(138px,1fr));grid-auto-rows:minmax(78px,1fr);align-items:stretch;gap:10px;overflow:hidden}.plain-hand{min-height:0;display:flex;align-content:center;align-items:center;justify-content:center;flex-wrap:wrap;overflow:hidden;padding:6px 12px 0;row-gap:4px}.hand-group{min-width:0;display:grid;grid-template-rows:minmax(0,1fr) auto;align-items:stretch;overflow:hidden;padding:8px 9px 7px;border:5px solid #cfd5db;border-radius:14px;background:#ffffffb8}.hand-group.pure{border-color:#4d9bf7;background:#edf7ffe0}.hand-group.sequence{border-color:#11c978;background:#ebfff5e0}.hand-group.set{border-color:#b376f2;background:#f7efffe6}.hand-group.invalid{border-color:#ff5c66;background:#fff0f1eb}.hand-group.incomplete{border-color:#cfd5db;background:#f9fbfce6}.hand-cards{display:flex;align-items:center;justify-content:center;min-height:0;overflow:hidden;padding:0 8px 2px 0}.card-slot{display:block;margin-right:clamp(-24px,-2.6vw,-13px)}.plain-card-slot{display:block;margin-right:clamp(-20px,-2.2vw,-10px)}.card-slot:last-child,.plain-card-slot:last-child{margin-right:0}.group-label{justify-self:center;max-width:calc(100% - 8px);min-height:20px;overflow:hidden;padding:3px 9px;border-radius:999px;color:#fff;font-size:clamp(10px,1.45vw,12px);font-weight:900;text-align:center;text-overflow:ellipsis;white-space:nowrap}.group-label.pure{background:#4d9bf7}.group-label.sequence{background:#11a967}.group-label.set{background:#9861de}.group-label.invalid{background:#e94853}.group-label.incomplete{background:#7d8993}.controls{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.controls button{min-height:46px;padding:7px 8px;color:#fff;font-size:clamp(12px,1.8vw,16px);font-weight:900;box-shadow:inset 0 -3px #00000038,0 4px 10px #0000002e}.controls button:nth-child(1){background:linear-gradient(#31c35d,#14873f)}.controls button:nth-child(2){background:linear-gradient(#4fa5ef,#196bb1)}.discard-action{background:linear-gradient(#ffa33a,#d46b16)}.declare-action{background:linear-gradient(#a987f0,#6e52c7)}.drop-action{background:linear-gradient(#ff718a,#c7354f)}.chat-peek{position:absolute;z-index:25;right:16px;bottom:calc(max(10px,env(safe-area-inset-bottom)) + 318px);max-width:min(380px,calc(100vw - 32px));overflow:hidden;padding:8px 12px;border-radius:999px;color:#fff7ea;text-overflow:ellipsis;white-space:nowrap}.chat-panel{position:absolute;z-index:35;right:14px;bottom:calc(max(10px,env(safe-area-inset-bottom)) + 320px);width:min(340px,calc(100vw - 28px));max-height:min(360px,calc(100dvh - 280px));display:grid;grid-template-rows:auto 1fr auto;gap:10px;padding:12px;border-radius:8px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:8px}.section-title h2{margin:0;font-size:16px}.chat-log{min-height:80px;overflow:auto;display:flex;flex-direction:column;gap:8px;font-size:13px}.chat-input{display:grid;grid-template-columns:1fr auto;gap:8px}.chat-input input{width:100%;border:1px solid rgba(255,247,234,.18);border-radius:8px;background:#fff7ea14;color:#fff7ea;padding:9px 10px}.chat-input button{padding:9px 12px;background:#f0c15a;color:#20140d;font-weight:900}.drag-preview{position:fixed;z-index:80;top:0;left:0;pointer-events:none;filter:drop-shadow(0 18px 22px rgba(0,0,0,.38))}.modal-backdrop{position:fixed;z-index:90;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0000009e;padding:20px}.result-modal{width:min(620px,100%);border:1px solid rgba(255,247,234,.16);border-radius:8px;background:#17211f;padding:22px}.result-modal h2{margin:0}.result-list{display:grid;gap:8px;margin-top:16px}.result-row{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid rgba(255,247,234,.12);border-radius:8px;padding:10px 12px}@media(orientation:landscape)and (max-height:560px){.app-shell{padding:7px}.match-header{top:7px;left:7px;right:7px;height:43px;grid-template-columns:40px minmax(0,1fr) auto 40px}.icon-button{width:40px;height:40px;font-size:19px}.match-title{min-width:260px;padding:5px 12px}.match-title strong{font-size:14px}.match-title span{font-size:12px}.turn-status{padding:4px 8px 4px 10px}.timer{width:36px;height:36px;border-width:3px;font-size:12px}.table{top:50px;right:7px;bottom:140px;left:7px}.felt{border-width:10px;border-radius:38%/30%}.player-seat{width:112px;grid-template-columns:34px minmax(0,1fr);padding:5px}.avatar{width:34px;height:34px;border-width:2px;font-size:11px}.seat-info strong{font-size:12px}.seat-info span{font-size:11px}.seat-badges span{padding:2px 5px;font-size:9px}.seat-top,.seat-top-left,.seat-top-right{top:6px}.seat-left{left:8px}.seat-right{right:8px}.seat-bottom{bottom:4px}.table-center{gap:9px}.deck-pile,.discard-pile,.joker-panel,.finish-slot{width:68px;min-height:82px;padding:5px}.deck-pile strong{font-size:24px}.playing-card{width:44px;height:62px;padding:5px}.playing-card strong,.playing-card span{font-size:17px}.playing-card.compact{width:38px;height:54px}.hand-tray{left:7px;right:7px;bottom:7px;grid-template-columns:1fr minmax(280px,38vw);grid-template-rows:minmax(0,1fr);max-height:128px;gap:6px 8px}.hand-board{grid-column:1;padding:7px 9px 8px;gap:4px}.hand-header h2{font-size:15px}.hand-header span{display:none}.hand-actions button{min-height:27px;padding:4px 9px;font-size:11px}.group-legend{gap:8px;justify-content:flex-start;overflow:hidden;font-size:10px}.legend-dot{width:10px;height:10px;border-radius:3px}.group-board{grid-template-columns:repeat(auto-fit,minmax(102px,1fr));grid-auto-rows:minmax(56px,1fr);gap:5px}.hand-group{border-width:3px;border-radius:10px;padding:4px 5px}.hand-cards{min-height:0}.plain-hand{justify-content:flex-start;padding:0 4px}.card-slot{margin-right:-16px}.plain-card-slot{margin-right:-14px}.group-label{min-height:16px;padding:2px 6px;font-size:9px}.controls{grid-column:2;grid-row:1;grid-template-columns:repeat(2,minmax(0,1fr));align-content:stretch;gap:6px}.controls button{min-height:0;padding:5px 7px;font-size:12px}.chat-peek{bottom:141px}.chat-panel{bottom:141px;max-height:calc(100dvh - 194px)}}@media(max-width:520px)and (orientation:portrait){.match-header{height:54px;grid-template-columns:42px minmax(0,1fr) 42px}.match-header .turn-status{position:absolute;top:60px;left:50%;transform:translate(-50%)}.match-header .icon-button:last-child{grid-column:3}.match-title{min-width:0;width:100%;padding:7px 10px}.table{top:112px;right:8px;bottom:316px;left:8px}.felt{border-width:9px;border-radius:38%/20%}.player-seat{width:104px;grid-template-columns:34px minmax(0,1fr);padding:5px}.avatar{width:34px;height:34px;border-width:2px}.seat-info strong{font-size:12px}.seat-info span{font-size:11px}.seat-badges span{font-size:9px}.seat-left{left:4px}.seat-right{right:4px}.seat-top-left{left:27%}.seat-top-right{right:27%}.table-center{grid-template-columns:repeat(2,auto);gap:8px}.deck-pile,.discard-pile,.joker-panel,.finish-slot{width:72px;min-height:82px;padding:5px}.finish-slot{font-size:11px}.hand-tray{max-height:300px}.hand-board{padding:10px 10px 12px;gap:7px}.hand-header{align-items:flex-start}.hand-header h2{font-size:18px}.hand-header span{font-size:11px}.hand-actions{gap:5px}.hand-actions button{min-height:32px;padding:6px 10px;font-size:11px}.group-legend{gap:8px;justify-content:flex-start;overflow:hidden;font-size:10px}.legend-dot{width:10px;height:10px;border-radius:3px}.group-board{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:minmax(78px,1fr);gap:8px}.hand-group{border-width:4px;border-radius:12px;padding:6px 7px}.card-slot{margin-right:-21px}.plain-card-slot{margin-right:-17px}.controls{grid-template-columns:repeat(5,minmax(54px,1fr));overflow-x:auto;padding-bottom:1px;scrollbar-width:none}.controls::-webkit-scrollbar{display:none}.controls button{min-width:72px;min-height:44px;font-size:12px}.hand-group{min-width:0}}
