*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.card{width:70px;height:100px;background:linear-gradient(145deg,#fff,#f5f5f5);border-radius:8px;border:2px solid #333;position:relative;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;-webkit-user-select:none;user-select:none;box-shadow:0 2px 4px #0000001a}.card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 8px 20px #0003}.card.selected{transform:translateY(-12px) scale(1.05);box-shadow:0 12px 25px #4caf5066;border-color:#4caf50;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 12px 25px #4caf5066}50%{box-shadow:0 12px 30px #4caf5099}}.card.small{width:50px;height:70px;font-size:.8em;cursor:default}.card.small:hover{transform:none;box-shadow:0 2px 4px #0000001a}.card.dragging{opacity:.3}.card.hearts{color:#e53935}.card.hearts .card-center{text-shadow:0 2px 4px rgba(229,57,53,.3)}.card.spades{color:#212121}.card.spades .card-center{text-shadow:0 2px 4px rgba(0,0,0,.2)}.card.diamonds{color:#e53935}.card.diamonds .card-center{text-shadow:0 2px 4px rgba(229,57,53,.3)}.card.clubs{color:#212121}.card.clubs .card-center{text-shadow:0 2px 4px rgba(0,0,0,.2)}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;font-size:12px;font-weight:700;line-height:1}.card.small .card-corner{font-size:10px}.top-left{top:4px;left:4px}.bottom-right{bottom:4px;right:4px;transform:rotate(180deg)}.card-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px}.card.small .card-center{font-size:20px}.card-value{font-size:14px}.card.small .card-value{font-size:11px}.card-suit{font-size:12px}.card.small .card-suit{font-size:10px}.board{display:grid;grid-template-columns:repeat(3,1fr);background:#2d5a27;padding:20px;border-radius:12px;box-shadow:inset 0 2px 10px #0000004d;position:relative;touch-action:manipulation}.cell{width:90px;height:110px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;position:relative}.cell:nth-child(2),.cell:nth-child(5),.cell:nth-child(8){border-left:3px solid rgba(255,255,255,.4);border-right:3px solid rgba(255,255,255,.4)}.cell:nth-child(4),.cell:nth-child(5),.cell:nth-child(6){border-top:3px solid rgba(255,255,255,.4);border-bottom:3px solid rgba(255,255,255,.4)}.cell.clickable{cursor:pointer}.cell.clickable:hover{background:#ffffff26;transform:scale(1.02)}.cell.drop-target{cursor:grabbing}.cell.hovered{background:#4caf504d;box-shadow:inset 0 0 0 3px #4caf5099;transform:scale(1.05)}.card-stack{position:relative;width:50px;height:70px;pointer-events:none}.stacked-card{position:absolute;top:0;left:0;transition:transform .3s ease,box-shadow .3s ease;transform:translateY(calc(var(--stack-index) * -4px)) translate(calc(var(--stack-index) * 2px));pointer-events:none}.stacked-card:after{content:"";position:absolute;inset:0;border-radius:8px;box-shadow:0 2px 4px #0003;pointer-events:none}.empty-cell{width:100%;height:100%}.winning-line-svg{position:absolute;inset:20px;pointer-events:none;z-index:5}.winning-line{stroke-width:6;stroke-linecap:round;fill:none;stroke-dasharray:400;stroke-dashoffset:400;animation:draw-line .5s ease-out forwards}.winning-line.hearts,.winning-line.diamonds{stroke:#b42828b3}.winning-line.spades,.winning-line.clubs{stroke:#1e1e1eb3}@keyframes draw-line{to{stroke-dashoffset:0}}.hand{margin-top:4px;touch-action:none}.hand-cards{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.game{display:flex;flex-direction:column;align-items:center;gap:15px}.player-header{display:flex;align-items:center;gap:15px}.suit-badge{font-size:18px;font-weight:700;padding:5px 12px;border-radius:20px;background:#f5f5f5}.suit-badge.hearts{color:#e53935;background:#ffebee}.suit-badge.spades{color:#212121;background:#f5f5f5}.card-count{color:#666;font-size:14px}.turn-indicator{font-size:20px;font-weight:700;padding:10px 20px;border-radius:8px;margin:5px 0;min-width:180px;text-align:center}.turn-indicator.my-turn{background:#e8f5e9;color:#2e7d32}.turn-indicator.their-turn{background:#fff3e0;color:#ef6c00}.turn-indicator.waiting{background:#f5f5f5;color:#666}.start-btn{font-size:20px;font-weight:700;padding:12px 32px;border-radius:8px;margin:5px 0;background:#2e7d32;color:#fff;border:none;cursor:pointer;transition:background .2s,transform .1s;min-width:180px}.start-btn:hover{background:#1b5e20}.start-btn:active{transform:scale(.98)}.hint{margin-top:10px;color:#666;font-size:14px;font-style:italic}.board-area{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:start;width:100%;gap:10px}.discard-column{display:flex;overflow:hidden}.discard-column:first-child{justify-content:flex-end}.discard-column:last-child{justify-content:flex-start}.discard-pile{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;background:#00000008;border-radius:8px;flex-shrink:0}.discard-pile.hearts{border:2px solid rgba(229,57,53,.2)}.discard-pile.spades{border:2px solid rgba(33,33,33,.2)}.discard-label{font-size:11px;color:#888;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.discard-cards{display:flex;flex-direction:column;align-items:center;position:relative}.discard-card-wrapper{transform:scale(.7);margin-bottom:-50px;position:relative}.discard-card-wrapper:last-child{margin-bottom:0}.mobile-discard-row{display:none}.board-wrapper{position:relative}.rematch-btn{font-size:18px;font-weight:700;padding:12px 24px;border-radius:8px;margin:5px 0;background:#1a1a2e;color:#fff;border:none;cursor:pointer;transition:background .2s,transform .1s}.rematch-btn:hover{background:#2a2a4e}.rematch-btn:active{transform:scale(.98)}.rematch-btn.pending{background:#666;cursor:not-allowed}.rematch-btn.opponent-ready{background:#2e7d32;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #2e7d3266}50%{box-shadow:0 0 0 8px #2e7d3200}}.game-over-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:32px;font-weight:700;border-radius:12px;background:#ffffffe6;z-index:10;animation:fade-in .3s ease-out}.elo-change{font-size:18px;margin-top:8px;font-weight:600}.elo-change.positive{color:#2e7d32}.elo-change.negative{color:#c62828}.game-over-overlay.win{color:#2e7d32;background:#e8f5e9f2}.game-over-overlay.lose{color:#c62828;background:#ffebeef2}.game-over-overlay.draw{color:#ef6c00;background:#fff3e0f2}.game-status-area{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;width:100%}.game-status-area .opponent-timer{justify-self:end}.game-status-area .my-timer{justify-self:start}.timer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 12px;border-radius:8px;background:#f5f5f5;transition:all .2s;min-width:120px}.timer-label{font-size:12px;color:#666}.timer-value{font-size:18px;font-weight:700;font-family:monospace;color:#333}.timer.active{background:#e3f2fd;box-shadow:0 0 0 2px #1976d2}.timer.active .timer-label{color:#1976d2}.timer.active .timer-value{color:#1565c0}.timer.low{background:#ffebee}.timer.low .timer-value{color:#c62828;animation:time-pulse .5s infinite}.timer.active.low{box-shadow:0 0 0 2px #c62828}@keyframes time-pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:430px){.board-area{display:flex;justify-content:center}.board-area .discard-column{display:none}.mobile-discard-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;margin-top:10px;justify-items:center}.mobile-discard-row .discard-card-wrapper{transform:scale(.6);margin-bottom:-44px}.mobile-discard-row .discard-card-wrapper:last-child{margin-bottom:0}.game-status-area{gap:6px}.timer{min-width:80px;padding:4px 8px}.timer-label{font-size:10px}.timer-value{font-size:14px}.turn-indicator{min-width:90px;padding:8px 10px;font-size:14px}.start-btn{min-width:90px;padding:8px 16px;font-size:14px}}.bughouse-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:1200px;position:relative}.bughouse-match-header{width:100%;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:12px}.bughouse-match-title{font-size:20px;font-weight:700;color:#333;text-align:center}.bughouse-boards{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:20px}.bughouse-board{background:#fff;border-radius:12px;padding:15px;display:flex;flex-direction:column;align-items:center;gap:10px}.team-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:12px}.team-badge.team-A{background:#ffebee;color:#c62828}.team-badge.team-B{background:#e3f2fd;color:#1565c0}.teammate-board{opacity:.95}.teammate-board .board-wrapper{pointer-events:none}.bughouse-status{width:100%;display:flex;justify-content:center}.bughouse-waiting{text-align:center;font-size:18px;color:#666;padding:40px}.bughouse-result{position:fixed;top:20px;left:50%;transform:translate(-50%);padding:15px 30px;border-radius:12px;font-size:24px;font-weight:700;z-index:100;animation:slide-down .5s ease-out;box-shadow:0 4px 20px #0000004d}.bughouse-result.win{background:#e8f5e9;color:#2e7d32;border:2px solid #4caf50}.bughouse-result.lose{background:#ffebee;color:#c62828;border:2px solid #ef5350}.bughouse-result.draw{background:#fff3e0;color:#ef6c00;border:2px solid #ffb74d}@keyframes slide-down{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.bughouse-board .player-header{display:flex;align-items:center;gap:10px;width:100%;justify-content:center}.bughouse-board .suit-badge{font-size:14px;font-weight:700;padding:4px 10px;border-radius:16px;background:#f5f5f5}.bughouse-board .suit-badge.hearts,.bughouse-board .suit-badge.diamonds{color:#e53935;background:#ffebee}.bughouse-board .suit-badge.spades,.bughouse-board .suit-badge.clubs{color:#212121;background:#f5f5f5}.bughouse-board .card-count{color:#666;font-size:12px}.bughouse-board .turn-indicator{font-size:14px;font-weight:700;padding:8px 16px;border-radius:8px;text-align:center}.bughouse-board .turn-indicator.my-turn{background:#e8f5e9;color:#2e7d32}.bughouse-board .turn-indicator.their-turn{background:#fff3e0;color:#ef6c00}.bughouse-board .turn-indicator.waiting{background:#f5f5f5;color:#666}.bughouse-board .start-btn{font-size:14px;font-weight:700;padding:8px 20px;border-radius:8px;background:#2e7d32;color:#fff;border:none;cursor:pointer;transition:background .2s}.bughouse-board .start-btn:hover{background:#1b5e20}.bughouse-board .rematch-btn{font-size:14px;font-weight:700;padding:8px 16px;border-radius:8px;background:#1a1a2e;color:#fff;border:none;cursor:pointer;transition:background .2s}.bughouse-board .rematch-btn:hover{background:#2a2a4e}.bughouse-board .rematch-btn.pending{background:#666;cursor:not-allowed}.bughouse-board .board-wrapper{position:relative}.bughouse-board .game-over-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;border-radius:12px;background:#ffffffe6;z-index:10;animation:fade-in .3s ease-out}.bughouse-board .game-over-overlay.win{color:#2e7d32;background:#e8f5e9f2}.bughouse-board .game-over-overlay.lose{color:#c62828;background:#ffebeef2}.bughouse-board .game-over-overlay.draw{color:#ef6c00;background:#fff3e0f2}@keyframes fade-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.drag-ghost{position:fixed;pointer-events:none;z-index:1000}.drag-ghost .card{transform:scale(1.1) rotate(2deg);box-shadow:0 15px 35px #0000004d;animation:none}.drag-ghost.dropping{transition:left .15s ease-out,top .15s ease-out}.drag-ghost.dropping .card{transform:none;box-shadow:0 2px 4px #0003}@media(max-width:900px){.bughouse-boards{grid-template-columns:1fr;gap:15px}.bughouse-board{padding:12px}.bughouse-result{font-size:18px;padding:10px 20px}}@media(max-width:430px){.bughouse-board{padding:10px}.team-badge{font-size:10px;padding:3px 8px}.bughouse-board .turn-indicator{font-size:12px;padding:6px 12px}.bughouse-result{font-size:16px;padding:8px 16px}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:40px 24px 24px;border-radius:12px;width:100%;max-width:400px;position:relative;box-shadow:0 4px 20px #00000026}.modal-close{position:absolute;top:10px;right:10px;background:#f0f0f0;border:none;font-size:18px;cursor:pointer;color:#666;line-height:1;padding:4px 8px;border-radius:4px;z-index:10}.modal-close:hover{background:#e0e0e0;color:#333}.modal-tabs{display:flex;gap:8px;margin-bottom:20px}.modal-tabs .tab{flex:1;padding:10px;border:none;background:#f0f0f0;cursor:pointer;border-radius:6px;font-size:14px;font-weight:500;transition:background .2s}.modal-tabs .tab:hover{background:#e0e0e0}.modal-tabs .tab.active{background:#4a90d9;color:#fff}.modal-content h2{margin:0 0 20px;text-align:center;font-size:20px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#333}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#4a90d9;box-shadow:0 0 0 2px #4a90d933}.username-status{display:block;margin-top:4px;font-size:12px}.username-status.checking{color:#666}.username-status.available{color:#22c55e}.username-status.taken{color:#ef4444}.auth-error{background:#fef2f2;color:#dc2626;padding:10px 12px;border-radius:6px;margin-bottom:16px;font-size:14px}.modal-content .btn{width:100%;padding:12px;font-size:15px}.modal-content .btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:430px){.modal-content{margin:16px;padding:20px;max-width:calc(100% - 32px)}.modal-tabs .tab{padding:8px;font-size:13px}.form-group input{padding:12px;font-size:16px}}.leaderboard{background:#f8f9fa;border-radius:12px;padding:16px;margin-top:20px;max-width:300px;margin-left:auto;margin-right:auto}.leaderboard-title{margin:0 0 12px;font-size:16px;color:#1a1a2e;text-align:center}.leaderboard-loading,.leaderboard-empty{color:#666;font-size:14px;text-align:center;margin:0}.leaderboard-list{display:flex;flex-direction:column;gap:6px}.leaderboard-row{display:flex;align-items:center;padding:8px 12px;background:#fff;border-radius:8px;font-size:14px}.leaderboard-row.current-user{background:#e8f4fd;border:1px solid #4a90d9}.leaderboard-rank{color:#888;font-weight:500;min-width:32px}.leaderboard-row:nth-child(1) .leaderboard-rank{color:gold}.leaderboard-row:nth-child(2) .leaderboard-rank{color:silver}.leaderboard-row:nth-child(3) .leaderboard-rank{color:#cd7f32}.leaderboard-name{flex:1;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-elo{font-weight:600;color:#1a1a2e;min-width:50px;text-align:right}@media(max-width:430px){.leaderboard{max-width:100%;margin-top:16px;padding:12px}.leaderboard-row{padding:6px 10px}}.sandbox{max-width:1000px;margin:0 auto;padding:20px}.sandbox h2{text-align:center;margin-bottom:20px;color:#333}.sandbox-card-picker{background:#f5f5f5;border-radius:12px;padding:16px;margin-bottom:20px}.picker-row{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.picker-row:last-child{margin-bottom:0}.picker-label{font-weight:700;min-width:60px}.picker-label.hearts{color:#e53935}.picker-label.spades{color:#212121}.picker-cards{display:flex;gap:4px;flex-wrap:wrap}.picker-card{cursor:grab;transition:opacity .2s,transform .2s;border-radius:8px}.picker-card:active{cursor:grabbing}.picker-card:hover:not(.used){transform:translateY(-4px)}.picker-card.used{opacity:.3;cursor:not-allowed}.picker-card.selected{outline:3px solid #4CAF50;transform:translateY(-4px)}.picker-hint{text-align:center;color:#666;font-size:12px;margin-top:12px}.sandbox-selected-indicator{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;background:#e8f5e9;border-radius:8px;margin-bottom:20px;font-weight:500}.sandbox-validation-error{padding:12px;background:#ffebee;border:1px solid #f44336;border-radius:8px;color:#c62828;text-align:center;margin-bottom:20px;font-weight:500}.sandbox-main-layout{display:flex;gap:30px;margin-bottom:20px}.sandbox-board-section{flex-shrink:0}.sandbox-board-section h3{margin-bottom:10px;text-align:center}.sandbox-board{display:grid;grid-template-columns:repeat(3,1fr);background:#2d5a27;padding:20px;border-radius:12px;box-shadow:inset 0 2px 10px #0000004d;gap:0}.sandbox-cell{width:90px;height:110px;display:flex;align-items:center;justify-content:center;position:relative;transition:background .2s,transform .2s,box-shadow .2s}.sandbox-cell:nth-child(2),.sandbox-cell:nth-child(5),.sandbox-cell:nth-child(8){border-left:3px solid rgba(255,255,255,.4);border-right:3px solid rgba(255,255,255,.4)}.sandbox-cell:nth-child(4),.sandbox-cell:nth-child(5),.sandbox-cell:nth-child(6){border-top:3px solid rgba(255,255,255,.4);border-bottom:3px solid rgba(255,255,255,.4)}.sandbox-cell.placeable{cursor:pointer}.sandbox-cell.placeable:hover{background:#ffffff26;transform:scale(1.02)}.sandbox-cell.hovered{background:#4caf504d;box-shadow:inset 0 0 0 3px #4caf5099;transform:scale(1.05)}.sandbox-stack{position:relative;width:50px;height:70px}.sandbox-stacked-card{position:absolute;top:0;left:0;transform:translateY(calc(var(--stack-index) * -4px)) translate(calc(var(--stack-index) * 2px));cursor:grab}.sandbox-stacked-card:active{cursor:grabbing}.sandbox-stacked-card:hover{outline:2px solid #f44336;z-index:10}.sandbox-empty-cell{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.sandbox-side-section{flex:1;display:flex;flex-direction:column;gap:20px}.sandbox-player-section{background:#f5f5f5;border-radius:12px;padding:16px}.sandbox-player-section h4{margin:0 0 12px;font-size:16px}.sandbox-player-section h4.hearts{color:#e53935}.sandbox-player-section h4.spades{color:#212121}.area-label{font-size:12px;color:#666;margin-bottom:4px;display:block}.sandbox-hand-area{margin-bottom:12px}.sandbox-hand{display:flex;gap:4px;flex-wrap:wrap;min-height:74px;padding:8px;background:#fff;border-radius:8px;border:2px dashed #ddd;transition:border-color .2s,background .2s}.sandbox-hand.placeable{border-color:#4caf50;background:#e8f5e9;cursor:pointer}.sandbox-hand-card{cursor:grab;transition:transform .2s}.sandbox-hand-card:active{cursor:grabbing}.sandbox-hand-card:hover{transform:translateY(-4px);outline:2px solid #f44336}.empty-hint{color:#999;font-size:12px;display:flex;align-items:center;justify-content:center;width:100%}.add-more-hint{display:flex;align-items:center;justify-content:center;width:40px;height:60px;border:2px dashed #4CAF50;border-radius:6px;color:#4caf50;font-size:24px;font-weight:700;cursor:pointer}.sandbox-draw-pile-area{margin-bottom:12px}.sandbox-draw-pile{display:flex;flex-direction:column;gap:4px;min-height:50px;padding:8px;background:#fff;border-radius:8px;border:2px dashed #ddd;transition:border-color .2s,background .2s;max-height:200px;overflow-y:auto}.sandbox-draw-pile.placeable{border-color:#4caf50;background:#e8f5e9;cursor:pointer}.draw-pile-item{display:flex;align-items:center;gap:8px}.draw-pile-card{cursor:grab}.draw-pile-card:active{cursor:grabbing}.draw-pile-card:hover{outline:2px solid #f44336}.draw-pile-controls{display:flex;flex-direction:column;gap:2px}.pile-btn{padding:2px 8px;font-size:12px;border:1px solid #ccc;background:#fff;border-radius:4px;cursor:pointer}.pile-btn:hover:not(:disabled){background:#eee}.pile-btn:disabled{opacity:.3;cursor:not-allowed}.sandbox-discard-area{margin-bottom:0}.sandbox-discard{display:flex;gap:4px;flex-wrap:wrap;min-height:50px;padding:8px;background:#fff;border-radius:8px;border:2px dashed #ddd;transition:border-color .2s,background .2s}.sandbox-discard.placeable{border-color:#4caf50;background:#e8f5e9;cursor:pointer}.sandbox-discard-card{cursor:grab}.sandbox-discard-card:active{cursor:grabbing}.sandbox-discard-card:hover{outline:2px solid #f44336}.sandbox-first-turn{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:20px;padding:12px;background:#f5f5f5;border-radius:8px}.radio-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-weight:500}.radio-label.hearts{color:#e53935}.radio-label.spades{color:#212121}.sandbox-buttons{display:flex;justify-content:center;gap:12px;margin-bottom:20px}.sandbox-back{display:flex;justify-content:center;margin-top:20px;padding-top:20px;border-top:1px solid #eee}.sandbox-play-layout{display:flex;flex-direction:column;align-items:center;gap:24px;padding-bottom:20px}.sandbox-turn-indicator{font-size:20px;font-weight:700;padding:10px 20px;border-radius:8px;text-align:center}.sandbox-turn-indicator.hearts{color:#e53935;background:#e539351a}.sandbox-turn-indicator.spades{color:#212121;background:#2121211a}.sandbox-play-board{margin:0 auto;position:relative}.sandbox-game-over-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;background:#ffffffe6;border-radius:12px;z-index:10}.sandbox-game-over-overlay.hearts{color:#e53935}.sandbox-game-over-overlay.spades{color:#212121}.sandbox-game-over-overlay.draw{color:#666}.sandbox-play-hands{display:flex;gap:30px;justify-content:center;flex-wrap:wrap}.sandbox-play-hand-section{background:#f5f5f5;border-radius:12px;padding:16px;min-width:200px;transition:box-shadow .2s}.sandbox-play-hand-section.active{box-shadow:0 0 0 3px #4caf50}.sandbox-play-hand-section h4{margin:0 0 12px;text-align:center}.sandbox-play-hand-section h4.hearts{color:#e53935}.sandbox-play-hand-section h4.spades{color:#212121}.sandbox-play-hand{display:flex;gap:6px;flex-wrap:wrap;min-height:100px;justify-content:center}.sandbox-play-card{cursor:pointer;transition:transform .2s,opacity .2s}.sandbox-play-card:hover:not(.disabled){transform:translateY(-8px)}.sandbox-play-card.selected{transform:translateY(-12px)}.sandbox-play-card.disabled{opacity:.5;cursor:not-allowed}.sandbox-play-hand-section,.sandbox-play-hand,.sandbox-play-card{touch-action:none}.sandbox-play-info{display:flex;justify-content:space-around;margin-top:12px;font-size:12px;color:#666}.sandbox-drag-ghost{position:fixed;pointer-events:none;z-index:1000}.sandbox-drag-ghost .card{transform:scale(1.1) rotate(2deg);box-shadow:0 15px 35px #0000004d;animation:none}.sandbox-drag-ghost.dropping{transition:left .15s ease-out,top .15s ease-out}.sandbox-drag-ghost.dropping .card{transform:none;box-shadow:0 2px 4px #0003}.sandbox-card-picker,.sandbox-board,.sandbox-board-section,.sandbox-side-section,.sandbox-hand,.sandbox-draw-pile,.sandbox-discard,.picker-card,.sandbox-stacked-card,.sandbox-hand-card,.draw-pile-card,.sandbox-discard-card{touch-action:none}@media(max-width:768px){.sandbox-main-layout{flex-direction:column}.sandbox-board-section{display:flex;flex-direction:column;align-items:center}.picker-cards{justify-content:center}.sandbox-play-hands{flex-direction:column;align-items:center}.sandbox-play-hand-section{width:100%;max-width:400px}}.app{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;justify-content:center;padding:20px}.container{background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a;padding:45px 30px 30px;max-width:600px;width:100%;text-align:center;overflow:hidden;position:relative}.container.bughouse{max-width:1240px;overflow:visible}h1{margin:0;font-size:2rem;color:#1a1a2e}h1.clickable{cursor:pointer}h1.clickable:hover{text-decoration:underline}.subtitle{color:#666;margin-top:5px;margin-bottom:20px}.error{background:#ffebee;color:#c62828;padding:10px 15px;border-radius:8px;margin-bottom:15px}.disconnect-notice{background:#fff3e0;color:#ef6c00;padding:10px 15px;border-radius:8px;margin-bottom:15px;font-size:14px}.lobby{display:flex;flex-direction:column;gap:20px}.btn{padding:12px 24px;font-size:16px;border:none;border-radius:8px;cursor:pointer;background:#e0e0e0;color:#333;transition:background .2s,transform .1s}.btn:hover{background:#d0d0d0}.btn:active{transform:scale(.98)}.btn.primary{background:#1a1a2e;color:#fff}.btn.primary:hover{background:#2a2a4e}.btn.bot{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none}.btn.bot:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#7c3aed)}.btn.bot:disabled{background:linear-gradient(135deg,#9ca3af,#a1a1aa)}.btn.small{padding:8px 16px;font-size:14px}.btn.large{padding:16px 48px;font-size:20px}.invite-banner{background:linear-gradient(135deg,#4caf50,#2d5a27);color:#fff;padding:15px 25px;border-radius:12px;font-size:1.2rem;font-weight:600}.divider{color:#999;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#ddd}.divider:before{left:0}.divider:after{right:0}.join-form{display:flex;gap:10px;justify-content:center}.join-form input{padding:12px 16px;font-size:16px;border:2px solid #ddd;border-radius:8px;width:180px}.join-form input:focus{outline:none;border-color:#1a1a2e}.rules-toggle-container{margin:-10px 0 10px}.rules-toggle{background:none;border:none;color:#999;font-size:11px;cursor:pointer;text-decoration:underline;padding:0}.rules-toggle:hover{color:#666}.rules{text-align:left;background:#f5f5f5;padding:20px;border-radius:12px;margin-top:0}.rules.rules-dropdown{font-size:13px;padding:15px}.rules.rules-dropdown ul{padding-left:18px}.rules.rules-dropdown li{margin:3px 0}.rules h3{margin:0 0 10px;color:#333}.rules ul{margin:0;padding-left:20px;color:#666}.rules li{margin:5px 0}.waiting{display:flex;flex-direction:column;align-items:center;gap:15px}.game-code{display:flex;align-items:center;gap:15px;background:#f5f5f5;padding:15px 20px;border-radius:8px}.game-code strong{font-size:1.3rem;font-family:monospace;letter-spacing:2px}.share-hint{color:#666;font-size:14px}.time-select{display:flex;flex-direction:column;gap:20px;align-items:center}.time-select h2{margin:0;color:#1a1a2e}.time-options{display:flex;flex-direction:column;gap:10px;width:100%;max-width:250px}.btn.time-option{padding:14px 24px;font-size:16px;background:#f5f5f5;border:2px solid transparent;transition:all .2s}.btn.time-option:hover{background:#e8e8e8;border-color:#1a1a2e}.btn.back-btn{margin-top:10px;background:transparent;color:#666;font-size:14px}.btn.back-btn:hover{color:#333;background:transparent}.bot-select{display:flex;flex-direction:column;gap:20px;align-items:center}.bot-select h2{margin:0;color:#1a1a2e}.bot-options{display:flex;flex-direction:column;gap:10px;width:100%;max-width:250px}.btn.bot-option{padding:14px 24px;font-size:16px;background:#f5f5f5;border:2px solid transparent;transition:all .2s}.btn.bot-option:hover{background:#e8e8e8;border-color:#1a1a2e}.auth-header{position:absolute;top:12px;right:15px;display:flex;align-items:center;gap:8px;background:#f5f5f5;padding:6px 12px;border-radius:20px;font-size:13px}.auth-username{color:#333;font-weight:500}.auth-elo{color:#666;font-size:12px;padding:2px 6px;background:#e8e8e8;border-radius:4px}.auth-header .btn.small{padding:4px 10px;font-size:12px}.auth-section{margin-top:10px;display:flex;flex-direction:column;align-items:center;gap:12px}.auth-divider{color:#999;font-size:14px;position:relative;width:100%;text-align:center}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:35%;height:1px;background:#ddd}.auth-divider:before{left:5%}.auth-divider:after{right:5%}.auth-buttons{display:flex;gap:10px}.auth-divider-line{width:100%;height:1px;background:#ddd;margin-top:10px}@media(max-width:430px){.app{padding:10px 10px 40px}.container{padding:40px 15px 30px;overflow:visible}.auth-header{top:8px;right:8px;padding:4px 10px;font-size:12px}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:24px;border-radius:12px;text-align:center;max-width:320px;box-shadow:0 4px 20px #0003}.modal p{margin:0 0 20px;font-size:16px;color:#333}.modal-buttons{display:flex;gap:12px;justify-content:center}
