.homeContainer{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(#04729e,#918686);padding:20px}.homeContainer h2{color:#fff;font-size:48px;margin-bottom:30px;text-align:center}#buttonsContainer{display:flex;flex-direction:column;gap:15px;min-width:300px}#buttonsContainer button{padding:15px 30px;font-size:18px;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:.2s;color:#fff}#createRoomButton{background:#28a745}#joinRoomButton{background:#007bff}#buttonsContainer button:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.formContainer{display:flex;flex-direction:column;gap:15px;min-width:300px}.formContainer input{padding:12px;border:none;border-radius:8px;font-size:16px}.formContainer button{padding:12px;font-size:16px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:.2s;color:#fff}.formContainer button[type=button]{background:#1d3850}.formContainer button[type=submit]{background:#28a745}.formContainer button:hover{transform:scale(1.05)}.formContainer button:disabled{opacity:.5;cursor:not-allowed}.lobbyContainer{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(#04729e,#918686);padding:20px;color:#fff}.lobbyCard{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:30px;border-radius:15px;max-width:500px;width:100%;box-shadow:0 8px 32px #0000004d}.lobbyCard h2{margin:0 0 20px;text-align:center}.roomCode{display:flex;align-items:center;justify-content:center;gap:10px;background:#0000004d;padding:15px;border-radius:10px;text-align:center;margin-bottom:20px;font-size:18px;font-weight:700;word-break:break-all;flex-wrap:wrap}.copyRoomButton{cursor:pointer;padding:12px;border:none;border-radius:8px;font-weight:700;background-color:#5252e6d8;color:#fff}.playerList{list-style:none;padding:0;margin:20px 0}.playerList li{padding:10px 15px;background:#ffffff1a;margin-bottom:8px;border-radius:8px}.playerList li.hostStyle{background:#ffd7004d;border:2px solid gold}.lobbyButtons{display:flex;flex-direction:column;gap:10px;margin-top:20px}.lobbyButtons button{flex:1;padding:12px;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:.2s}.lobbyButtons button:hover{transform:scale(1.05)}.lobbyButtons button:disabled{opacity:.5;cursor:not-allowed}.leaveButton{background:#dc3545;color:#fff;width:100%;padding:12px;border:none;border-radius:8px;font-weight:700;cursor:pointer;margin-top:10px;transition:.2s}.leaveButton:hover{background:#c82333;transform:scale(1.02)}.card{width:40px;height:60px;border:1px solid rgba(26,32,44,.28);border-radius:6px;background:#fffaf0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;position:relative;box-shadow:0 2px 4px #00000038,inset 0 0 0 1px #ffffffb3;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;-webkit-user-select:none;user-select:none}.cardFace{background:radial-gradient(circle at 50% 38%,#ffffffe6,#fffaf0f2 42%,#f5eee1);overflow:hidden}.cardFace:after{content:"";position:absolute;inset:4px;border:1px solid rgba(45,55,72,.12);border-radius:4px;pointer-events:none}.card.interactive{cursor:pointer}.card.interactive:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0000003d,inset 0 0 0 1px #fffc}.card.interactive:focus-visible{outline:3px solid rgba(65,185,255,.95);outline-offset:3px}.cardCorner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:.9;font-size:11px;font-weight:800;letter-spacing:0}.topCorner{top:5px;left:5px}.bottomCorner{right:5px;bottom:5px;transform:rotate(180deg)}.cardSuit{font-size:28px;line-height:1;filter:drop-shadow(0 1px 0 rgba(255,255,255,.45))}.redSuit{color:#c1121f}.blackSuit{color:#1f2933}.cardHidden{background:linear-gradient(135deg,rgba(255,255,255,.18) 0 25%,transparent 25% 50%,rgba(255,255,255,.18) 50% 75%,transparent 75%),linear-gradient(145deg,#0f766e,#12355b);background-size:10px 10px,100% 100%;color:#fff;overflow:hidden}.cardHidden:after{content:"";position:absolute;inset:5px;border:1px solid rgba(255,255,255,.55);border-radius:4px}.cardBackPattern{width:20px;height:30px;border-radius:50%;border:2px solid rgba(255,255,255,.7);box-shadow:0 0 0 4px #ffffff1f,inset 0 0 10px #ffffff2e}.card.selected{transform:translateY(-10px);border-color:#f6c453;box-shadow:0 10px 18px #00000047,0 0 0 3px #f6c453bf,inset 0 0 0 1px #ffffffd9}.gameContainer{--card-width: 40px;--card-height: 60px;--trick-card-width: calc(var(--card-width)*.5);--trick-card-height: calc(var(--card-height)*.5);--avatar-size: 60px;--avatar-border: 3px;--dealer-color: #f6c453;--you-color: #11e04f;--current-turn-color: #69dbff;--table-background: #0f6b4f;--table-border: rgba(235, 224, 197, .85);--table-width: min(760px, 78vw);--table-height: min(500px, 58vh);--gap-small: 5px;--gap-medium: 10px;--gap-large: 20px;width:100vw;height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at 50% 30%,rgba(252,211,77,.14),transparent 22%),linear-gradient(145deg,#102a43,#243b53,#1f2933);padding:20px;box-sizing:border-box;overflow:hidden}.playersContainer{position:absolute;width:var(--table-width);height:var(--table-height);border-radius:50%;background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.12),transparent 28%),repeating-radial-gradient(ellipse at center,rgba(255,255,255,.03) 0 2px,transparent 2px 8px),linear-gradient(145deg,#13795b 0%,var(--table-background) 55%,#094734 100%);border:9px solid var(--table-border);top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 24px 70px #0000006b,inset 0 0 0 10px #472a167a,inset 0 16px 32px #ffffff14,inset 0 -24px 40px #00000052}.playerAvatar{position:absolute;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:140px;padding:7px 10px;border-radius:14px;background:#0f172aa3;border:1px solid rgba(255,255,255,.14);box-shadow:0 10px 24px #00000040;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease,opacity .2s ease}.avatarCircle{width:var(--avatar-size);height:var(--avatar-size);border-radius:50%;border:var(--avatar-border) solid rgba(255,255,255,.88);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:18px;letter-spacing:0;text-shadow:0 1px 2px rgba(0,0,0,.45);box-shadow:inset 0 -10px 18px #0000002e}.playerAvatar.dealer .avatarCircle{border-color:var(--dealer-color);box-shadow:0 0 0 3px #f6c45338,0 0 18px #f6c45380,inset 0 -10px 18px #0000002e}.playerAvatar.currentTurn{border-color:#69dbffc2;box-shadow:0 0 0 3px #69dbff26,0 18px 30px #00000052}.playerAvatar.currentTurn .avatarCircle{border-width:4px;border-color:var(--current-turn-color)}.playerAvatar.currentTurn:before{content:"";position:absolute;inset:-5px;border:2px solid rgba(105,219,255,.45);border-radius:18px;animation:turnPulse 1.5s ease-in-out infinite;pointer-events:none}.playerName{color:#fff;font-size:14px;font-weight:600;text-align:center;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playerMeta{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.playerBadges{display:flex;flex-wrap:wrap;justify-content:center;gap:4px;min-height:18px}.playerBadge{padding:2px 6px;border-radius:999px;font-size:10px;font-weight:800;line-height:1.2;color:#fff;background:#ffffff24}.dealerBadge{color:#2d2100;background:var(--dealer-color)}.youBadge{color:#000;background:var(--you-color)}.turnBadge{color:#082f49;background:var(--current-turn-color)}.outBadge{background:#94a3b88c}.trickBadge{background:#14b8a6b3}.playerScore{position:absolute;top:-13px;right:12px;background:#080d17e0;color:#fff;padding:4px 9px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid rgba(255,255,255,.18)}.playerCards{display:flex;gap:0;margin-top:2px;justify-content:center;align-items:center;min-height:25px;max-width:96px;flex-wrap:nowrap}.playerCards .card{width:18px;height:27px;flex:0 0 auto;border-radius:4px}.playerCards .card+.card{margin-left:-9px}.playerCards .cardBackPattern,.wonTricks .cardBackPattern{width:10px;height:15px;border-width:1px}.cardCountBadge,.trickCountBadge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:20px;margin-left:5px;padding:0 5px;border-radius:999px;color:#fff;font-size:10px;font-weight:800;background:#0f172ad1;border:1px solid rgba(255,255,255,.16)}.trickCountBadge{color:#2d2100;background:#f6c453}.playerArea{display:flex;flex-direction:column;align-items:center;gap:15px;padding:14px 18px;background:#080d17b8;border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:0 -12px 32px #0000003d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20}.playerHand{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;align-items:center}.leaveRoomButton{position:absolute;top:20px;right:20px;padding:10px 20px;background:#dc3545e6;color:#fff;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:.2s;z-index:100}.leaveRoomButton:hover{background:#dc3545;transform:scale(1.05)}.actions{display:flex;gap:10px}.actions button{padding:10px 20px;font-size:16px;font-weight:700;border:none;border-radius:8px;background:#0b79b9;color:#fff;cursor:pointer;transition:transform .2s;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.actions button:hover{transform:scale(1.05)}.actions button:disabled{opacity:.5;cursor:not-allowed}.playerOut{opacity:.62;filter:grayscale(.8)}.playerAvatar.seat-1{top:-78px;left:50%;transform:translate(-50%)}.playerAvatar.seat-2{top:16%;right:-104px;transform:translateY(-50%)}.playerAvatar.seat-3{bottom:-72px;right:20%;transform:translate(50%)}.playerAvatar.seat-4{bottom:-72px;left:20%;transform:translate(-50%)}.playerAvatar.seat-5{top:16%;left:-104px;transform:translateY(-50%)}@keyframes turnPulse{0%,to{opacity:.35;transform:scale(1)}50%{opacity:.8;transform:scale(1.035)}}@media(max-width:768px){.playerArea{padding-bottom:max(80px,env(safe-area-inset-bottom))}.gameContainer{--card-width: 40px;--card-height: 60px;--trick-card-width: calc(var(--card-width)*.5);--trick-card-height: calc(var(--card-width)*.5);--avatar-size: 40px;--table-width: 84vw;--table-height: 46vh;padding:5px}.tableArea{margin-bottom:10px}.playersContainer{width:80vw;height:50vh;max-width:var(--table-width);max-height:var(--table-height);border-width:6px}.playerAvatar{min-width:96px;padding:5px;border-radius:12px}.avatarCircle{width:var(--avatar-size);height:var(--avatar-size);font-size:12px}.playerName{font-size:11px;max-width:84px}.playerBadge{font-size:9px;padding:2px 5px}.playerScore{font-size:10px;padding:2px 5px;top:-9px;right:6px}.card{width:var(--card-width);height:var(--card-height);font-size:15px}.playerHand{gap:5px}.actions button{padding:12px 16px;font-size:14px;min-width:80px}.playerCards .card{width:14px;height:21px;font-size:10px}.playerCards .card+.card{margin-left:-7px}.playerCards{flex-wrap:nowrap;justify-content:center;max-width:64px;min-height:21px}.wonTricks{flex-wrap:nowrap;justify-content:center;max-width:64px;min-height:18px}.wonTricks .card{width:14px;height:19px}.wonTricks .card+.card{margin-left:-7px}.cardCountBadge,.trickCountBadge{min-width:18px;height:16px;margin-left:3px;padding:0 4px;font-size:9px}.playerAvatar.seat-1{top:-54px;left:50%;transform:translate(-50%)}.playerAvatar.seat-2{right:-62px;top:20%;transform:translateY(-50%)}.playerAvatar.seat-3{bottom:-58px;right:14%}.playerAvatar.seat-4{bottom:-58px;left:14%}.playerAvatar.seat-5{left:-62px;top:20%;transform:translateY(-50%)}.leaveRoomButton{top:20px;right:20px;padding:5px 10px;font-size:.7rem}.gameOverModal{padding:25px}.winnerTitle{font-size:1.8rem}.winnerName{font-size:1.5rem}.scoreRow{padding:10px}.playerNameScore,.playerScoreValue{font-size:1rem}}.modalOverlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.gameOverModal{background:linear-gradient(#667eea,#764ba2);padding:40px;border-radius:20px;box-shadow:0 10px 50px #00000080;text-align:center;max-width:500px;width:90%;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.winnerTitle{color:gold;font-size:2.5rem}.winnerName{color:#fff;font-size:2rem;margin:0 0 30px}.finalScores{background:#ffffff1a;padding:20px;border-radius:10px;margin-bottom:30px}.finalScores h3{color:#fff;margin:0 0 15px;font-size:1.3rem}.scoreRow{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;margin:8px 0;background:#ffffff1a;border-radius:8px;color:#fff;transition:.2s}.scoreRow:hover{background:#fff3;transform:translate(5px)}.scoreRow.firstPlace{background:linear-gradient(90deg,#ffd7004d,#ffd7001a);border:2px solid #FFD700}.rank{font-weight:700;font-size:1.2rem;min-width:40px}.playerNameScore{flex:1;text-align:left;font-size:1.1rem;padding:0 15px}.playerScoreValue{font-weight:700;font-size:1.2rem;color:gold}.returnButton{padding:15px 40px;font-size:1.1rem;font-weight:700;background:linear-gradient(#28a745,#20c997);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:.2s;width:100%}.returnButton:hover{transform:scale(1.05);box-shadow:0 5px 20px #28a74566}.waitingText{color:#fff;font-size:1.1rem;margin:0;padding:15px}.tableArea{flex:1;display:flex;justify-content:center;align-items:center;position:relative;margin-bottom:20px}.tableCenter{display:flex;gap:var(--gap-large);align-items:center;justify-content:center;min-width:190px;min-height:130px;padding:18px 26px;border-radius:999px;background:#042f2e57;border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 0 24px #0000002e,0 8px 24px #00000029;z-index:10}.wonTricks{display:flex;gap:0;margin-top:2px;align-items:center;justify-content:center;min-height:23px;max-width:94px;flex-wrap:nowrap}.wonTricks .card{width:var(--trick-card-width);height:var(--trick-card-height);flex:0 0 auto}.wonTricks .card+.card{margin-left:-9px}.wonTricks .wonTrickCard{background:linear-gradient(135deg,rgba(45,33,0,.18) 0 25%,transparent 25% 50%,rgba(45,33,0,.18) 50% 75%,transparent 75%),linear-gradient(145deg,#f6c453,#c2410c);background-size:9px 9px,100% 100%;border-color:#ffedd5b8}.wonTricks .wonTrickCard:after{border-color:#ffffff94}.deckContainer{position:relative;min-width:var(--card-width);min-height:var(--card-height)}.deckCount{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;text-shadow:1px 1px 2px black;pointer-events:none}.playedCards{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;display:flex;align-items:center;justify-content:center}.playedCards .card{position:absolute}.playedCards .card:nth-child(1){transform:translate(-40px) rotate(-5deg);z-index:1}.playedCards .card:nth-child(2){transform:translate(-20px) rotate(-2deg);z-index:2}.playedCards .card:nth-child(3){transform:translate(0);z-index:3}.playedCards .card:nth-child(4){transform:translate(20px) rotate(2deg);z-index:4}.playedCards .card:nth-child(5){transform:translate(40px) rotate(5deg);z-index:5}.trumpContainer{position:absolute;display:flex;flex-direction:column;align-items:center;font-size:5rem;font-weight:700;z-index:-1;opacity:.18;filter:drop-shadow(0 2px 2px rgba(255,255,255,.24))}.trumpContainer.red{color:#f87171}.trumpContainer.black{color:#0f172a}.loadingBackground{width:100vw;min-height:100vh;display:flex;justify-content:center;align-items:center;background:radial-gradient(circle at 50% 34%,rgba(246,196,83,.16),transparent 28%),linear-gradient(#04729e,#918686);color:#fff;padding:24px}.loadingContent{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.loadingContent h1{font-size:clamp(2.4rem,8vw,4.5rem);line-height:1;letter-spacing:0;margin-top:6px;text-shadow:0 3px 16px rgba(0,0,0,.25)}.loadingContent p{font-size:1rem;font-weight:700;color:#ffffffd6;text-shadow:0 2px 10px rgba(0,0,0,.22)}.retryConnectionButton{min-height:44px;padding:10px 20px;border:1px solid rgba(255,255,255,.36);border-radius:8px;background:#0f172a6b;color:#fff;font-size:.95rem;font-weight:800;cursor:pointer;transition:transform .18s ease,background .18s ease}.retryConnectionButton:hover{background:#0f172a99;transform:translateY(-1px)}*{margin:0;padding:0;box-sizing:border-box}body,html,#root{width:100%;height:100%;overflow:hidden;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.errorPopup{position:fixed;top:20px;right:20px;z-index:1000;animation:slideIn .5s ease-out}.errorContent{background:#dc3545f2;color:#fff;padding:15px 20px;border-radius:8px;box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:column;gap:10px;max-width:300px}.errorContent p{margin:0;font-weight:500}.errorContent button{padding:8px 16px;background:#fff;color:#dc3545;border:none;border-radius:5px;font-weight:700;cursor:pointer}.errorContent button:hover{background:#f8f9fa}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.errorPopup{top:10px;left:10px;right:10px}.errorContent{max-width:100%;padding:12px 15px;font-size:14px}.errorContent button{padding:10px 16px;font-size:14px;width:100%}}
