.lobby{min-height:100vh;background:linear-gradient(135deg,#1e5128,#2d6a4f,#1e5128);display:flex;align-items:center;justify-content:center;padding:20px}.lobby-card{background:#000c;border-radius:16px;padding:48px;max-width:500px;width:100%;box-shadow:0 8px 32px #00000080}.lobby-card h1{color:gold;text-align:center;margin:0 0 32px;font-size:42px;text-shadow:0 2px 10px rgba(255,215,0,.3)}.lobby-card h2{color:#fff;text-align:center;margin:0 0 24px;font-size:24px}.menu{display:flex;flex-direction:column;gap:16px}.menu-button{padding:20px;font-size:20px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:all .3s;color:#fff}.menu-button.create{background:#4caf50}.menu-button.create:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.menu-button.join{background:#2196f3}.menu-button.join:hover{background:#0b7dda;transform:translateY(-2px);box-shadow:0 4px 12px #2196f366}.form{display:flex;flex-direction:column;gap:16px}.back-button{align-self:flex-start;background:transparent;border:none;color:#ffffffb3;cursor:pointer;font-size:16px;padding:8px;transition:color .3s}.back-button:hover{color:#fff}.input{padding:16px;font-size:16px;border:2px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a;color:#fff;transition:border-color .3s}.input::placeholder{color:#ffffff80}.input:focus{outline:none;border-color:#4caf50}.code-input{text-transform:uppercase;text-align:center;font-size:24px;letter-spacing:4px;font-weight:700}.action-button{padding:16px;font-size:18px;font-weight:700;border:none;border-radius:8px;background:#4caf50;color:#fff;cursor:pointer;transition:all .3s}.action-button:hover:not(:disabled){background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.action-button:disabled{opacity:.5;cursor:not-allowed}.waiting-room{text-align:center}.room-code{background:#ffffff1a;padding:24px;border-radius:8px;margin:24px 0;display:flex;flex-direction:column;gap:12px;align-items:center}.room-code .label{color:#ffffffb3;font-size:14px}.code-container{display:flex;align-items:center;gap:12px}.room-code .code{color:gold;font-size:36px;font-weight:700;letter-spacing:8px;font-family:monospace}.copy-button{background:#ffffff0d;color:#ffffffb3;border:2px solid rgba(255,255,255,.2);padding:8px;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.copy-button:hover{background:#ffffff1a;border-color:#fff6;color:#fff}.copy-button:active{transform:scale(.95)}.copied-message{color:#4caf50;font-size:14px;font-weight:500;animation:fadeInOut 1.5s ease-in-out}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-5px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-5px)}}.instructions{color:#fffc;font-size:14px;margin:16px 0}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#4caf50;border-radius:50%;animation:spin 1s linear infinite;margin:24px auto 0}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:#f4433633;border:2px solid #f44336;color:#ffcdd2;padding:12px;border-radius:8px;margin-bottom:16px;text-align:center}.card{width:42px;height:60px;border-radius:5px;background:#fff;border:2px solid #333;box-sizing:border-box;box-shadow:0 2px 4px #0003;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;transition:transform .2s,box-shadow .2s;flex-shrink:0;overflow:visible}.card:hover{transform:translateY(-4px);box-shadow:0 4px 8px #0000004d}.card[draggable=true]{cursor:grab;will-change:transform}.card[draggable=true]:active{cursor:grabbing}@media(hover:none)and (pointer:coarse){.card[draggable=true]{touch-action:none;-webkit-user-drag:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.card{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}}.card-back{background:linear-gradient(135deg,#667eea,#764ba2);cursor:default}.card-back:hover{transform:none}.card-pattern{width:100%;height:100%;background-image:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(255,255,255,.1) 8px,rgba(255,255,255,.1) 16px);border-radius:5px}.card-face{display:flex;flex-direction:column;justify-content:space-between;padding:4px;width:100%;height:100%;box-sizing:border-box;overflow:visible}.card-corner{display:flex;flex-direction:column;align-items:center;line-height:1;flex-shrink:0}.card-corner.top-left{align-self:flex-start}.card-corner.bottom-right{align-self:flex-end;transform:rotate(180deg);margin-top:auto;position:relative}.rank{font-size:14px;font-weight:700;font-family:Georgia,serif}.suit{font-size:12px}.card-center{display:flex;align-items:center;justify-content:center;flex:1;min-height:0;flex-shrink:1}.suit-large{font-size:26px}.red{color:#dc143c}.black{color:#000}@keyframes cardPickedUp{0%,to{transform:scale(1);box-shadow:0 2px 4px #0003}50%{transform:scale(1.15);box-shadow:0 0 30px gold,0 6px 12px #0006}}@keyframes cardPlaced{0%{box-shadow:0 2px 4px #0003}50%{box-shadow:0 0 30px #0f0,0 6px 12px #0006}to{box-shadow:0 2px 4px #0003}}.card.opponent-picked-up{animation:cardPickedUp 1s ease-in-out}.card.opponent-placed{animation:cardPlaced 1s ease-in-out}@media(max-width:768px){.card{width:52px;height:74px;min-width:44px;min-height:44px}.rank{font-size:16px}.suit{font-size:14px}.suit-large{font-size:30px}}.pile{position:relative;min-width:54px;min-height:72px;padding:6px;border:2px dashed rgba(255,255,255,.3);border-radius:6px;background:#0000001a;transition:all .2s;overflow:visible}@media(hover:none)and (pointer:coarse){.pile{touch-action:none}}.pile:hover{background:#00000026}.pile.highlight-drop{border-color:#4caf50;background:#4caf5033;box-shadow:0 0 20px #4caf5080}.pile-label{position:absolute;top:-7px;left:7px;background:#000000b3;color:#fff;padding:2px 6px;border-radius:3px;font-size:9px;font-weight:700;z-index:1}.pile-cards{display:flex;flex-direction:column;align-items:center;min-height:60px;overflow:visible;width:100%}.pile-tableau{min-width:auto;min-height:auto}.pile-tableau .pile-cards{flex-direction:row;align-items:flex-start;min-height:70px}.pile-tableau .card,.pile-foundation .card{width:50px;height:70px}.left-tableau .pile-tableau .pile-cards{flex-direction:row-reverse}.left-tableau .pile-tableau .pile-cards .card{margin-left:0!important;margin-right:-28px}.left-tableau .pile-tableau .pile-cards .card:first-child{margin-right:0}.right-tableau .pile-tableau .pile-cards{flex-direction:row}.right-tableau .pile-tableau .pile-cards .card{margin-left:-28px}.right-tableau .pile-tableau .pile-cards .card:first-child{margin-left:0}.empty-pile-placeholder{width:42px;height:60px;border:2px dashed rgba(255,255,255,.5);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#ffffff4d}.pile-foundation .empty-pile-placeholder{width:50px;height:70px}.foundation-suit{font-size:28px}.pile-count{position:absolute;bottom:3px;right:3px;background:#000c;color:#fff;padding:2px 5px;border-radius:10px;font-size:9px;font-weight:700}.pile-stock{min-width:64px}.pile-stock .empty-pile-placeholder{width:42px;height:60px}.pile-stock .card{width:50px;height:70px}.landscape-card-wrapper{width:70px;height:70px;display:flex;align-items:center;justify-content:center;overflow:visible;position:relative;flex-shrink:0}.landscape-card-wrapper .card{transform:rotate(90deg);transform-origin:center center;background-color:#fff!important;position:relative;overflow:visible;width:50px;height:70px}.landscape-card-wrapper .card:hover{transform:rotate(90deg) scale(1.02);transform-origin:center center}.pile-waste,.pile-reserve{min-width:82px;min-height:auto;padding:6px;overflow:visible;position:relative}.pile-waste .pile-cards,.pile-reserve .pile-cards{min-height:auto;overflow:visible}.pile-waste .empty-pile-placeholder,.pile-reserve .empty-pile-placeholder{width:70px;height:50px}.pile.valid-drop-target{border-color:#4caf50;background:#4caf5033;box-shadow:0 0 20px #4caf5080;animation:pulse-glow 1.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #4caf5080}50%{box-shadow:0 0 30px #4caf50cc}}.pile.invalid-drop{animation:shake .4s ease-in-out;border-color:#f44336}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@media(max-width:768px){.landscape-card-wrapper .card{transform:none}.landscape-card-wrapper .card:hover{transform:scale(1.02)}.pile-tableau .card{width:56px;height:80px}.pile-tableau .pile-cards{min-height:80px}.pile-foundation .card,.pile-foundation .empty-pile-placeholder{width:56px;height:80px}.left-tableau .pile-tableau .pile-cards .card{margin-right:-24px!important}.right-tableau .pile-tableau .pile-cards .card{margin-left:-24px!important}.landscape-card-wrapper{width:56px;height:80px}.pile-waste,.pile-reserve{min-width:68px}.pile-waste .empty-pile-placeholder,.pile-reserve .empty-pile-placeholder{width:56px;height:80px}.pile-stock{min-width:70px}.pile-stock .card,.pile-stock .empty-pile-placeholder{width:56px;height:80px}}.disconnection-banner{position:fixed;top:0;left:0;right:0;background:#ffa500f2;padding:16px;z-index:9999;box-shadow:0 4px 12px #0000004d;animation:slideDown .3s ease-out}.disconnection-banner.reconnection-message{background:#4caf50f2}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.banner-message{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:600;color:#fff}.warning-icon,.reconnection-icon{font-size:24px}.banner-details{display:flex;align-items:center;gap:20px;color:#fff;font-size:16px}.waiting-text{font-style:italic}.timer{font-weight:700;font-size:18px;padding:4px 12px;border-radius:4px;background:#0003}.timer-green{color:#4caf50}.timer-yellow{color:#ffc107}.timer-red{color:#f44336;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.end-game-button{background:#d32f2f;color:#fff;border:none;padding:10px 24px;font-size:16px;font-weight:600;border-radius:6px;cursor:pointer;transition:background .2s ease}.end-game-button:hover{background:#b71c1c}.end-game-button:active{transform:scale(.98)}@media(max-width:768px){.disconnection-banner{padding:12px}.banner-content{flex-direction:column;align-items:stretch;gap:12px}.banner-message{font-size:16px;justify-content:center}.banner-details{flex-direction:column;gap:8px;align-items:center}.end-game-button{width:100%}}.flying-card-container{width:42px;height:60px;transition:all 1s cubic-bezier(.25,.46,.45,.94);transform:scale(1);filter:drop-shadow(0 0 20px rgba(255,215,0,.9))}.flying-card-container.flying{left:var(--to-x)!important;top:var(--to-y)!important;transform:scale(1);filter:drop-shadow(0 0 10px rgba(0,255,0,.7))}@keyframes flyingGlow{0%,to{filter:drop-shadow(0 0 15px rgba(255,215,0,.9))}50%{filter:drop-shadow(0 0 30px rgba(255,215,0,1))}}.flying-card-container.flying{animation:flyingGlow .8s ease-in-out infinite}.game-board{width:100vw;min-height:100vh;height:100dvh;height:100vh;max-width:100%;background:linear-gradient(135deg,#1e5128,#2d6a4f,#1e5128);padding:12px;display:flex;flex-direction:row;gap:12px;justify-content:center;align-items:flex-start;overflow:auto;box-sizing:border-box}@media(hover:none)and (pointer:coarse){.game-board{touch-action:pan-x pan-y}}.tableau-column{display:flex;flex-direction:column;gap:10px;width:270px;background:#0000004d;border-radius:10px;padding:10px;flex-shrink:0}.tableau-spacer{height:248px}.tableau-column.left-tableau{border:2px solid #4CAF50;box-shadow:0 0 20px #4caf504d}.tableau-column.right-tableau{border:2px solid rgba(255,255,255,.2)}.tableau-vertical{display:flex;flex-direction:column;gap:6px}.section-label{color:#fff;font-size:12px;font-weight:700;text-align:center;padding:6px;background:#00000080;border-radius:4px}.center-column{display:flex;flex-direction:column;gap:10px;align-items:center}.player-area{display:flex;flex-direction:column;gap:8px;background:#0000004d;border-radius:10px;padding:10px;align-items:center;overflow:visible}.player-area.current-player-area{border:2px solid #4CAF50;box-shadow:0 0 20px #4caf504d}.player-area.opponent-area{border:2px solid rgba(255,255,255,.2)}.player-header{display:flex;flex-direction:row;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.player-header h3{margin:0;color:#fff;font-size:16px;text-align:center}.turn-indicator{background:#4caf50;color:#fff;padding:3px 8px;border-radius:8px;font-size:11px;font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.player-piles{display:flex;flex-direction:row;gap:6px;padding:10px;background:#0003;border-radius:8px;justify-content:center;overflow:visible}.waste-reserve-stack{display:flex;flex-direction:column;gap:6px;overflow:visible}.player-stats{display:flex;flex-direction:row;gap:10px;font-size:11px;color:#fffc}.player-stats span{color:#4caf50;font-weight:700}.foundations-vertical{display:flex;flex-direction:column;gap:6px;background:#0003;padding:10px;border-radius:10px}.foundations-columns{display:flex;gap:8px}.foundation-column{display:flex;flex-direction:column;gap:6px}.end-turn-button{background:#ff9800;color:#fff;border:none;padding:5px 12px;font-size:11px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #0000004d}.end-turn-button:hover{background:#f57c00;transform:translateY(-2px);box-shadow:0 6px 16px #ff980066}.end-turn-button:active{transform:translateY(0)}.stop-button{background:#f44336;color:#fff;border:none;padding:5px 12px;font-size:11px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #0000004d;animation:pulse-stop 2s infinite}.stop-button:hover{background:#d32f2f;transform:translateY(-2px);box-shadow:0 6px 16px #f4433680}.stop-button:active{transform:translateY(0)}.stop-button:disabled{background:#999;cursor:not-allowed;animation:none;opacity:.5}.stop-button:disabled:hover{background:#999;transform:none;box-shadow:0 2px 4px #0000004d}@keyframes pulse-stop{0%,to{box-shadow:0 2px 4px #0000004d}50%{box-shadow:0 4px 12px #f4433699}}.game-over{display:flex;align-items:center;justify-content:center;width:100%}.winner-announcement{background:#000000e6;padding:40px;border-radius:12px;text-align:center;border:3px solid #FFD700;box-shadow:0 0 40px #ffd70080}.winner-announcement h1{color:gold;font-size:40px;margin:0 0 20px;text-shadow:0 0 20px rgba(255,215,0,.5)}.game-result{color:#fff;font-size:18px;margin:0 0 10px}.countdown-timer{color:#ffa726;font-size:14px;font-weight:700;margin:0 0 20px;transition:all .3s}.countdown-timer.countdown-urgent{color:#f44336;font-size:16px;animation:pulse 1s infinite}.waiting-message{color:gold;font-size:16px;font-weight:700;margin:0;animation:pulse 2s infinite}.game-over-buttons{display:flex;gap:16px;justify-content:center}.play-again-button{background:#4caf50;color:#fff;border:none;padding:12px 24px;font-size:16px;font-weight:700;border-radius:8px;cursor:pointer;transition:all .3s;box-shadow:0 4px 8px #0000004d}.play-again-button:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 6px 16px #4caf5066}.play-again-button:active{transform:translateY(0)}.leave-game-button{background:#757575;color:#fff;border:none;padding:12px 24px;font-size:16px;font-weight:700;border-radius:8px;cursor:pointer;transition:all .3s;box-shadow:0 4px 8px #0000004d}.leave-game-button:hover{background:#616161;transform:translateY(-2px);box-shadow:0 6px 16px #75757566}.leave-game-button:active{transform:translateY(0)}@media(max-width:1400px){.game-board{padding:8px;gap:8px}.tableau-column{width:264px;padding:8px}.player-area,.foundations-vertical{padding:8px}}@media(max-width:1200px){.game-board{padding:6px;gap:6px}.tableau-column{width:260px;padding:6px}.player-area,.foundations-vertical{padding:6px}.foundations-columns{gap:6px}}@media(max-width:768px){.tableau-column{width:356px;padding:6px}.foundations-columns,.player-piles{flex-direction:column}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1e5128,#2d6a4f,#1e5128);color:#fff;font-size:24px}
