:root{--bg:#0b1210;--card:#0f1c18;--text:#e8f3ef;--muted:#a6c0b7;--accent:#3ddc97;--danger:#ff4d4d;--border:rgba(255,255,255,.08);--shadow: 0 10px 30px rgba(0,0,0,.35)}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(1000px 600px at 30% 0%,rgba(61,220,151,.18),transparent),radial-gradient(800px 500px at 70% 10%,rgba(255,77,77,.1),transparent),var(--bg);color:var(--text)}code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.app{min-height:100vh}.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);background:#00000040;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.brand{display:flex;gap:12px;align-items:center}.logo{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:#3ddc972e;border:1px solid var(--border)}.title{font-weight:800}.sub{font-size:12px;color:var(--muted)}.right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.page{padding:16px}.grid1{display:grid;grid-template-columns:1fr;gap:14px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid3{display:grid;grid-template-columns:340px 1fr 340px;gap:14px}@media (max-width: 1100px){.grid3{grid-template-columns:1fr}}@media (max-width: 860px){.grid2{grid-template-columns:1fr}}.card{background:linear-gradient(180deg,#12261fa6,#0f1c18d9);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}.cardHeader{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 10px;border-bottom:1px solid var(--border)}.cardTitle{font-weight:800}.cardBody{padding:14px}.pill{display:inline-flex;gap:6px;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#0000002e;font-size:12px}.muted{color:var(--muted)}.small{font-size:12px}.form{display:flex;flex-direction:column;gap:8px}label{font-size:12px;color:var(--muted)}input,select{background:#00000040;color:var(--text);border:1px solid var(--border);border-radius:12px;padding:10px 12px;outline:none}input:focus,select:focus{border-color:#3ddc9759;box-shadow:0 0 0 4px #3ddc9714}.btn{border:none;border-radius:14px;padding:10px 12px;cursor:pointer;background:var(--accent);color:#042014;font-weight:800}.btn.ghost{background:#00000038;border:1px solid var(--border);color:var(--text);font-weight:700}.btn.danger{background:#ff4d4d2e;border:1px solid rgba(255,77,77,.35);color:#ffd4d4}.btn:disabled{opacity:.45;cursor:not-allowed}.row{display:flex;gap:10px;align-items:center}.row.wrap{flex-wrap:wrap}.divider{height:1px;background:var(--border);margin:10px 0}.toast{position:fixed;right:16px;bottom:16px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow);z-index:20;max-width:320px}.toast.ok{border-color:#3ddc9759}.toast.err{border-color:#ff4d4d59}.toast.warn{border-color:#ffc83d59}.players{display:flex;flex-direction:column;gap:8px}.player{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#0000002e}.player.active{outline:2px solid rgba(61,220,151,.35)}.status{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid var(--border)}.status.connected{border-color:#3ddc9759}.status.disconnected{opacity:.7}.tableList{display:flex;flex-direction:column;gap:10px}.tableRow{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px;border:1px solid var(--border);border-radius:14px;background:#0000002e}.rowTitle{font-weight:900}.bjTable{display:flex;flex-direction:column;gap:12px}.bjDealer{border:1px solid var(--border);border-radius:14px;padding:10px;background:#0000002e}.bjSeats{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width: 760px){.bjSeats{grid-template-columns:1fr}}.bjSeat{border:1px solid var(--border);border-radius:14px;padding:10px;background:#0000002e}.bjSeat.turn{outline:2px solid rgba(61,220,151,.35)}.seatTop{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.handRow{display:flex;gap:10px;flex-wrap:wrap}.hand{border:1px dashed rgba(255,255,255,.12);border-radius:12px;padding:8px;min-width:150px}.hand.active{border-style:solid;border-color:#3ddc9759}.cards{display:flex;gap:6px;flex-wrap:wrap}.bjCard{width:44px;height:60px;border-radius:10px;border:1px solid var(--border);background:#ffffff0f;display:flex;flex-direction:column;justify-content:space-between;padding:6px}.bjCard.hidden{background:#00000059}.bjCard .r{font-weight:900}.bjControls{border:1px solid var(--border);border-radius:14px;padding:10px;background:#0000002e}.rTable{display:flex;flex-direction:column;gap:10px}.rHeader{display:flex;gap:10px;flex-wrap:wrap}.rGrid{display:grid;grid-template-columns:1.2fr .8fr;gap:10px}@media (max-width: 900px){.rGrid{grid-template-columns:1fr}}.rBoard,.rBets{border:1px solid var(--border);border-radius:14px;padding:10px;background:#0000002e}.rActions{display:flex;flex-direction:column;gap:10px;margin-top:8px}.betsList{display:flex;flex-direction:column;gap:8px;margin-top:10px}.betRow{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#00000029}.adminFab{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:16px;border:1px solid var(--border);background:#00000047;color:var(--text);box-shadow:var(--shadow);cursor:pointer}.adminFab:hover{border-color:#3ddc9740}.rouletteBoard{margin-top:12px;display:grid;grid-template-columns:70px 1fr;gap:10px;align-items:start}.cell{border:1px solid var(--border);border-radius:12px;background:#0000002e;color:var(--text);padding:10px 8px;font-weight:900}.cell.clickable{cursor:pointer}.cell:disabled{opacity:.45;cursor:not-allowed}.zero{height:100%;min-height:420px;background:#3ddc971f}.numbers{display:grid;grid-template-columns:1fr;gap:6px}.row3{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.num{text-align:center}.num.red{background:#ff4d4d24;border-color:#ff4d4d38}.num.black{background:#00000052}.outside{grid-column:2 / 3;margin-top:10px;display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.out{font-weight:800}.out.red{background:#ff4d4d24;border-color:#ff4d4d38}.out.black{background:#00000052}@media (max-width: 900px){.rouletteBoard{grid-template-columns:1fr}.zero{min-height:70px}.outside{grid-column:1 / -1;grid-template-columns:repeat(3,1fr)}}.card3d{width:52px;height:72px;perspective:800px;animation:dealIn .22s ease-out both}@keyframes dealIn{0%{transform:translateY(-8px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.cardInner{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .3s ease}.card3d.hidden .cardInner{transform:rotateY(180deg)}.cardFace{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:12px;border:1px solid rgba(255,255,255,.14);box-shadow:0 8px 18px #00000059;overflow:hidden}.cardFace.front{background:linear-gradient(180deg,#ffffff29,#ffffff0f)}.cardFace.back{background:linear-gradient(180deg,#3ddc972e,#00000047);transform:rotateY(180deg)}.corner{position:absolute;top:6px;left:6px;display:flex;flex-direction:column;font-weight:900;line-height:1}.corner.br{top:auto;left:auto;bottom:6px;right:6px;transform:rotate(180deg)}.corner .rank{font-size:14px}.corner .suit{font-size:12px;opacity:.95}.pip{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:26px;opacity:.9;filter:drop-shadow(0 6px 10px rgba(0,0,0,.25))}.red{color:#ff6a6a}.black{color:#f3f6ff}.backPattern{position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:repeating-linear-gradient(45deg,#0003,#0003 8px,#ffffff0f 8px,#ffffff0f 16px);transform:rotate(12deg)}.backMark{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:26px;opacity:.8}.bjDealer .cards,.hand .cards{gap:8px}.bjTable.dealing{animation:tablePulse .6s ease-out}@keyframes tablePulse{0%{filter:brightness(1)}30%{filter:brightness(1.08)}to{filter:brightness(1)}}.rouletteLayout{display:grid;grid-template-columns:380px 1fr;gap:12px;margin-top:12px}@media (max-width: 1100px){.rouletteLayout{grid-template-columns:1fr}}.wheelWrap{position:relative;border:1px solid var(--border);border-radius:18px;background:#0000002e;padding:14px;overflow:hidden;box-shadow:var(--shadow)}.pointer{position:absolute;top:8px;left:50%;transform:translate(-50%);font-size:16px;opacity:.9;z-index:3}.wheel{width:280px;height:280px;border-radius:999px;position:relative;margin:12px auto 10px;border:1px solid rgba(255,255,255,.14);box-shadow:0 18px 40px #00000073;transition:transform 2.4s cubic-bezier(.15,.88,.18,1);background:#00000038}.wheel.spinning{filter:brightness(1.05)}.slice{position:absolute;width:50%;height:50%;top:50%;left:50%;transform-origin:0% 0%;border:1px solid rgba(255,255,255,.06);background:#ffffff0a;overflow:hidden}.slice.red{background:#ff4d4d29}.slice.black{background:#00000042}.slice.green{background:#3ddc9733}.sliceLabel{position:absolute;top:-2px;left:8px;font-size:10px;font-weight:900;opacity:.95}.wheelCenter{position:absolute;top:38%;right:38%;bottom:38%;left:38%;border-radius:999px;display:grid;place-items:center;background:#00000073;border:1px solid rgba(255,255,255,.12);font-size:18px}.wheelMeta{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.tableBets{display:flex;flex-direction:column;gap:10px}.bjResult{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.pill.ok{border-color:#3ddc9759}.pill.bad{border-color:#ff4d4d59}.wheelWrap{background:radial-gradient(220px 220px at 50% 45%,#ffffff1a,#0000),linear-gradient(180deg,#0003,#0000004d)}.wheel{width:320px;height:320px;margin:14px auto 10px;background:radial-gradient(140px 140px at 50% 50%,#0000008c,#0000001f),radial-gradient(260px 260px at 50% 50%,#3ddc971a,#0000)}.wheel:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:999px;border:2px solid rgba(255,255,255,.1);box-shadow:0 0 0 10px #0003 inset,0 18px 55px #0000008c}.ballTrack{position:absolute;top:-18px;right:-18px;bottom:-18px;left:-18px;border-radius:999px;border:1px dashed rgba(255,255,255,.1);opacity:.7}.ball{position:absolute;top:50%;left:50%;width:10px;height:10px;border-radius:999px;background:#fffffff2;box-shadow:0 0 0 3px #ffffff14,0 8px 18px #0009;transform:translate(-50%,-50%) translateY(-178px)}.wheel.spinning .ball{animation:ballOrbit .9s linear infinite}@keyframes ballOrbit{0%{transform:translate(-50%,-50%) rotate(0) translateY(-178px) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg) translateY(-178px) rotate(-360deg)}}.wheelStatic{width:340px;height:340px;margin:12px auto 10px;position:relative;border-radius:999px;-webkit-user-select:none;user-select:none}.wheelImg{width:100%;height:100%;object-fit:contain;border-radius:999px;display:block;pointer-events:none;filter:drop-shadow(0 18px 40px rgba(0,0,0,.45))}.ballArm{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;transition:transform 2.4s cubic-bezier(.15,.88,.18,1);will-change:transform}.ballArm .ball{position:absolute;left:50%;top:50%;width:10px;height:10px;border-radius:999px;background:#fffffff2;box-shadow:0 0 0 3px #ffffff14,0 8px 18px #0009;transform:translate(-50%,-50%) translateY(-165px)}.rTable{height:100%}.rGrid{height:calc(100% + -0px);display:grid;grid-template-columns:1fr 360px;gap:12px}.rBoard,.rBets{min-height:0;overflow:hidden}.betsList{overflow:auto;max-height:calc(100% - 56px);padding-right:6px}.tableBets{overflow:hidden;min-height:0}.rouletteLayout{height:100%;align-items:start}@media (max-width: 1100px){.rGrid{grid-template-columns:1fr}.betsList{max-height:220px}}.wheelStatic{width:320px;height:320px}.ballArm .ball{transform:translate(-50%,-50%) translateY(-120px);transition:transform .22s ease}.rouletteBoard .cell{padding:8px 6px;border-radius:10px}.rouletteBoard{margin-top:10px}.outside{grid-template-columns:repeat(6,1fr)}.appShell{min-height:100vh;width:100%;display:grid;place-items:start center;padding:16px}.app{width:min(1200px,100%);min-height:calc(100vh - 32px);display:flex;flex-direction:column;gap:12px}.page{flex:1;min-height:0}.rTable,.bjTable{min-height:0}html,body,#root{height:100%}body{margin:0}.appShell{min-height:100%;width:100%;display:flex;flex-direction:column}.app{width:100%;height:100%;display:flex;flex-direction:column}.grid2{display:grid;grid-template-columns:repeat(2,minmax(360px,1fr));gap:14px}.grid3{display:grid;grid-template-columns:minmax(280px,360px) 1fr minmax(280px,360px);gap:14px}@media (max-width: 1200px){.grid3{grid-template-columns:1fr}}@media (max-width: 820px){.grid2{grid-template-columns:1fr}}.rGrid{height:100%;display:grid;grid-template-columns:1fr 340px;gap:12px}@media (max-width: 1050px){.rGrid{grid-template-columns:1fr}}.rBoard,.rBets{min-height:0}.betsList{max-height:260px}.chipDot{position:absolute;width:10px;height:10px;background:gold;border-radius:50%;top:4px;right:4px;box-shadow:0 0 6px gold}.dealCardAnim{animation:dealMove .3s ease-out}@keyframes dealMove{0%{transform:translateY(-40px);opacity:0}to{transform:translateY(0);opacity:1}}.col{display:flex;flex-direction:column}.chipsStack{position:absolute;bottom:4px;left:6px;height:18px;pointer-events:none}.chipMini{position:absolute;width:18px;height:18px;border-radius:999px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 18px #00000059;display:grid;place-items:center;font-size:9px;font-weight:900;color:#000000bf}.chipMore{position:absolute;height:18px;padding:0 6px;border-radius:999px;background:#ffffffd9;color:#000000d9;font-size:9px;font-weight:900;display:grid;place-items:center;box-shadow:0 8px 18px #00000059;border:1px solid rgba(0,0,0,.1)}.codeBox{white-space:pre-wrap;word-break:break-word;background:#00000059;border:1px solid var(--border);border-radius:12px;padding:12px;font-size:12px;line-height:1.35}.playersBar{display:flex;gap:6px;flex-wrap:wrap;font-size:12px;padding:6px 8px}.playerBadge{background:#222;padding:4px 6px;border-radius:6px}.betRow{display:flex;justify-content:space-between;font-size:12px;padding:2px 0}.betName{font-weight:600;margin-right:6px}.betInline{font-size:12px;display:block;padding:2px 0}.betsContainer{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow:auto}.betsPlayerBlock{background:#1b1b1b;padding:8px;border-radius:8px;border:1px solid #2c2c2c}.betsPlayerHeader{display:flex;justify-content:space-between;font-weight:600;font-size:13px;margin-bottom:6px}.betsPlayerName{color:gold}.betsPlayerTotal{color:#aaa}.betsPlayerList{display:flex;flex-direction:column;gap:3px;font-size:12px}.betsRow{display:flex;justify-content:space-between;opacity:.9}
