.virtual-gamepad{-webkit-touch-callout:none;align-items:center;background:linear-gradient(180deg,#0000,#000c 20%,#000000e6);bottom:0;display:flex;height:200px;justify-content:space-between;left:0;padding:20px 30px;position:fixed;right:0;user-select:none;-webkit-user-select:none;z-index:1000}.dpad-container{align-items:center;display:flex;justify-content:center}.dpad{grid-gap:2px;display:grid;gap:2px;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr;height:120px;width:120px}.dpad-btn{-webkit-touch-callout:none;align-items:center;background:linear-gradient(145deg,#2a2a2a,#1a1a1a);border:2px solid #333;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;justify-content:center;touch-action:manipulation;transition:all .1s ease;user-select:none;-webkit-user-select:none}.dpad-btn:active{background:linear-gradient(145deg,#1db954,#1ed760);border-color:#1db954;box-shadow:inset 0 2px 4px #0000004d;transform:scale(.95)}.dpad-up{border-radius:8px 8px 4px 4px;grid-column:2;grid-row:1}.dpad-middle{align-items:center;display:flex;grid-column:1/4;grid-row:2}.dpad-left{border-radius:8px 4px 4px 8px;flex:1 1}.dpad-center{background:#1a1a1a;border:2px solid #333;border-radius:50%;height:36px;margin:0 2px;width:36px}.dpad-right{border-radius:4px 8px 8px 4px;flex:1 1}.dpad-down{border-radius:4px 4px 8px 8px;grid-column:2;grid-row:3}.action-buttons{flex-direction:column;justify-content:center}.action-buttons,.action-row{align-items:center;display:flex}.action-row{gap:15px}.action-btn{-webkit-touch-callout:none;align-items:center;background:linear-gradient(145deg,#2a2a2a,#1a1a1a);border:3px solid #333;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:60px;justify-content:center;touch-action:manipulation;transition:all .1s ease;user-select:none;-webkit-user-select:none;width:60px}.action-btn:active{box-shadow:inset 0 2px 4px #0000004d;transform:scale(.9)}.action-btn:active,.btn-a{background:linear-gradient(145deg,#dc3545,#c82333);border-color:#dc3545}.btn-a:active{background:linear-gradient(145deg,#c82333,#a71e2a)}.btn-b{background:linear-gradient(145deg,#ffc107,#e0a800);border-color:#ffc107;color:#000}.btn-b:active{background:linear-gradient(145deg,#e0a800,#c69500)}.center-buttons{align-items:center;display:flex;gap:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.center-btn{-webkit-touch-callout:none;background:linear-gradient(145deg,#2a2a2a,#1a1a1a);border:2px solid #333;border-radius:20px;color:#fff;cursor:pointer;font-size:12px;font-weight:700;min-width:60px;padding:8px 16px;touch-action:manipulation;transition:all .1s ease;user-select:none;-webkit-user-select:none}.center-btn:active{background:linear-gradient(145deg,#6c757d,#5a6268);border-color:#6c757d;box-shadow:inset 0 2px 4px #0000004d;transform:scale(.95)}@media screen and (orientation:landscape) and (max-height:500px){.virtual-gamepad{height:150px;padding:15px 25px}.bottom-row,.top-row{display:contents}.center-buttons{left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.action-buttons.tilted{height:auto;position:static;width:auto}.action-buttons.tilted .action-btn{position:static;transform:none}.dpad{height:100px;width:100px}.dpad-btn{font-size:16px}.dpad-center{height:30px;width:30px}.action-btn{font-size:18px;height:50px;width:50px}.action-row{gap:12px}.center-buttons{gap:15px}.center-btn{font-size:11px;min-width:50px;padding:6px 12px}}@media screen and (max-width:480px){.virtual-gamepad{padding:15px 20px}.dpad{height:100px;width:100px}.action-btn{font-size:18px;height:55px;width:55px}.center-buttons{gap:15px}}.virtual-gamepad *{-webkit-touch-callout:none;touch-action:manipulation;-webkit-user-select:none;user-select:none}.virtual-gamepad{transform:translateZ(0)}.action-btn,.action-buttons,.center-btn,.center-buttons,.dpad-btn,.dpad-container{contain:layout style paint;transform:translateZ(0);will-change:transform}.action-btn.pressed,.center-btn.pressed,.dpad-btn.pressed{box-shadow:inset 0 2px 4px #0000004d;transform:scale(.9)}.dpad-btn.pressed{background:linear-gradient(145deg,#1db954,#1ed760);border-color:#1db954}.action-btn.pressed.btn-a{background:linear-gradient(145deg,#c82333,#a71e2a)}.action-btn.pressed.btn-b{background:linear-gradient(145deg,#e0a800,#c69500)}.center-btn.pressed{background:linear-gradient(145deg,#6c757d,#5a6268);border-color:#6c757d}.joystick-container{align-items:center;display:flex;height:150px;justify-content:center;position:relative;width:150px}.joystick-base{background:#50505066;border:2px solid #fff3;border-radius:50%;box-shadow:inset 0 0 20px #0006;height:100%;position:absolute;width:100%}.joystick-handle{background:linear-gradient(145deg,#3c3c3c,#2a2a2a);border:2px solid #444;border-radius:50%;cursor:pointer;height:65px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:transform .05s;width:65px;will-change:transform}@media screen and (orientation:landscape) and (max-height:500px){.joystick-container{height:130px;width:130px}.joystick-handle{height:60px;width:60px}}@media screen and (orientation:portrait){.virtual-gamepad{background:linear-gradient(180deg,#0000,#000000b3 15%,#000000d9);border-radius:20px;bottom:60px;box-sizing:border-box;flex-direction:column;height:260px;justify-content:flex-end;left:50%;max-width:480px;padding:10px;right:auto;transform:translateX(-50%);width:95%}.top-row{display:flex;justify-content:center;margin-bottom:15px;width:100%}.center-buttons{gap:40px;position:static;transform:none}.bottom-row{align-items:center;display:flex;justify-content:space-between;width:100%}.action-buttons.tilted{align-items:center;display:flex;height:150px;justify-content:center;position:relative;width:150px}.action-buttons.tilted .action-btn{position:absolute}.action-buttons.tilted .btn-b{height:60px;transform:translate(-32px,20px);width:60px}.action-buttons.tilted .btn-a{height:60px;transform:translate(32px,-20px);width:60px}}.mobile-game-controller{overflow:hidden}.game-content,.mobile-game-controller{height:100%;position:relative;width:100%}.mobile-controls{display:flex;gap:10px;position:fixed;right:20px;top:20px;z-index:999}.mobile-control-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border:2px solid #fff3;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:44px;justify-content:center;touch-action:manipulation;transition:all .2s ease;user-select:none;-webkit-user-select:none;width:44px}.mobile-control-btn:hover{background:#1db954cc;border-color:#1db95480;transform:scale(1.05)}.mobile-control-btn:active{transform:scale(.95)}.orientation-prompt{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.orientation-prompt-content{background:linear-gradient(145deg,#1a1a1a,#2a2a2a);border:1px solid #333;border-radius:16px;box-shadow:0 20px 40px #00000080;max-width:400px;padding:32px;text-align:center;width:100%}.orientation-icon{animation:rotate 2s ease-in-out infinite;font-size:48px;margin-bottom:16px}@keyframes rotate{0%,to{transform:rotate(0deg)}50%{transform:rotate(90deg)}}.orientation-prompt-content h3{color:#fff;font-size:24px;font-weight:700;margin-bottom:12px}.orientation-prompt-content p{color:#b3b3b3;font-size:16px;line-height:1.5;margin-bottom:24px}.orientation-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.orientation-btn{border:none;border-radius:25px;cursor:pointer;font-size:14px;font-weight:600;min-width:120px;padding:12px 24px;transition:all .2s ease}.orientation-btn.primary{background:linear-gradient(45deg,#1db954,#1ed760);color:#fff}.orientation-btn.primary:hover{background:linear-gradient(45deg,#1ed760,#17c653);box-shadow:0 4px 12px #1db9544d;transform:translateY(-2px)}.orientation-btn.secondary{background:#0000;border:2px solid #333;color:#b3b3b3}.orientation-btn.secondary:hover{background:#333;border-color:#555;color:#fff}.mobile-game-controller.fullscreen{background:#000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}.mobile-game-controller.fullscreen .game-content{align-items:center;background:#000;display:flex;justify-content:center}.mobile-game-controller.fullscreen .mobile-controls{right:env(safe-area-inset-right,20px);top:env(safe-area-inset-top,20px)}.mobile-game-controller.landscape.fullscreen .game-content{padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0)}@media screen and (orientation:landscape) and (max-height:500px){.mobile-controls{gap:8px;right:10px;top:10px}.mobile-control-btn{font-size:16px;height:40px;width:40px}.orientation-prompt-content{max-width:350px;padding:24px}.orientation-icon{font-size:36px;margin-bottom:12px}.orientation-prompt-content h3{font-size:20px;margin-bottom:8px}.orientation-prompt-content p{font-size:14px;margin-bottom:20px}.orientation-btn{font-size:13px;min-width:100px;padding:10px 20px}}@media screen and (max-width:480px){.mobile-controls{right:15px;top:15px}.orientation-prompt-content{margin:0 10px;padding:24px 20px}.orientation-actions{align-items:center;flex-direction:column}.orientation-btn{max-width:200px;width:100%}}.mobile-game-controller *{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.game-content,.mobile-game-controller,.virtual-gamepad{contain:layout style paint;will-change:transform}@supports (padding:max(0px)){.mobile-game-controller.fullscreen .mobile-controls{right:max(env(safe-area-inset-right),20px);top:max(env(safe-area-inset-top),20px)}.mobile-game-controller.landscape.fullscreen .game-content{padding:max(env(safe-area-inset-top),0px) max(env(safe-area-inset-right),0px) max(env(safe-area-inset-bottom),0px) max(env(safe-area-inset-left),0px)}}*{margin:0;padding:0}body{background-color:#000;color:#fff;font-family:Circular,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow:hidden}.app{background:linear-gradient(135deg,#121212,#1e1e1e);display:flex;height:100vh}.sidebar{background:linear-gradient(180deg,#000,#121212);border-right:1px solid #282828;display:flex;flex-direction:column;position:relative;width:280px}.sidebar-header{border-bottom:1px solid #282828;padding:20px}.logo{align-items:center;display:flex;gap:12px}.logo-icon{filter:drop-shadow(0 0 10px rgba(29,185,84,.5));font-size:28px}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#1db954,#1ed760);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700}.sidebar-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.sidebar-footer{background:#0000004d;border-top:1px solid #282828;padding:16px}.quick-actions{gap:8px}.quick-action-btn,.quick-actions{display:flex;justify-content:center}.quick-action-btn{align-items:center;background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border:1px solid #333;border-radius:8px;color:#b3b3b3;cursor:pointer;font-size:18px;height:40px;transition:all .2s ease;width:40px}.quick-action-btn:hover{background:linear-gradient(135deg,#1db954,#1ed760);box-shadow:0 4px 12px #1db9544d;color:#fff;transform:translateY(-2px)}.quick-action-btn:active{transform:translateY(0)}.main-content{background:linear-gradient(180deg,#1e1e1e,#121212);display:flex;flex:1 1;flex-direction:column;overflow:hidden}.top-bar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000001a;border-bottom:1px solid #282828;display:flex;justify-content:space-between;padding:16px 32px}.top-bar-left{display:flex;gap:8px}.nav-button{align-items:center;background:#000;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.nav-button:hover{background:#1a1a1a;transform:scale(1.05)}.nav-button:disabled{cursor:not-allowed;opacity:.5}.top-bar-center{flex:1 1;margin:0 32px;max-width:400px}.search-bar{align-items:center;background:#2a2a2a;border-radius:500px;display:flex;padding:8px 16px;position:relative;transition:all .2s ease}.search-bar:focus-within{background:#333;box-shadow:0 0 0 2px #1db954}.search-icon{color:#a7a7a7;margin-right:12px}.search-bar input{background:none;border:none;color:#fff;flex:1 1;font-size:14px;outline:none}.search-bar input::placeholder{color:#a7a7a7}.top-bar-right,.user-profile{align-items:center;display:flex}.user-profile{background:#000;border-radius:20px;cursor:pointer;gap:8px;padding:4px 8px;transition:all .2s ease}.user-profile:hover{background:#1a1a1a}.avatar{align-items:center;background:#1db954;border-radius:50%;display:flex;font-size:14px;height:28px;justify-content:center;width:28px}.username{font-size:14px;font-weight:600}.content-area{flex:1 1;overflow-y:auto;padding:24px 32px}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;bottom:0;color:#fff;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #333;border-radius:50%;border-top-color:#1db954;height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.game-section,.help-section,.upload-section{margin-bottom:48px}.multiplayer-badge{align-items:center;background:linear-gradient(45deg,#1db954,#1ed760);border-radius:16px;display:flex;font-size:12px;font-weight:600;gap:8px;padding:6px 12px}.badge-icon{font-size:14px}.game-container{background:linear-gradient(145deg,#1a1a1a,#2a2a2a);border:1px solid #333;border-radius:12px;box-shadow:0 8px 32px #0000004d;padding:24px}.game-display{align-items:center;display:flex;flex-grow:1;justify-content:center;margin-bottom:24px;text-align:center}.game-display canvas{border-radius:8px;box-shadow:0 4px 20px #00000080;height:100%;max-width:100%;object-fit:contain;width:100%}.game-controls{display:flex;justify-content:center}.help-section,.upload-section{background:linear-gradient(145deg,#1a1a1a,#2a2a2a);border:1px solid #333;border-radius:12px;box-shadow:0 8px 32px #0000004d;padding:24px}.help-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.help-card{background:linear-gradient(145deg,#2a2a2a,#1a1a1a);border:1px solid #333;border-radius:8px;padding:20px;text-align:center;transition:all .3s ease}.help-card:hover{border-color:#1db954;box-shadow:0 8px 25px #1db95433;transform:translateY(-4px)}.help-icon{filter:drop-shadow(0 0 10px rgba(29,185,84,.3));font-size:32px;margin-bottom:12px}.help-card h3{color:#fff;font-size:18px;font-weight:600;margin-bottom:8px}.help-card p{color:#b3b3b3;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:#121212}::-webkit-scrollbar-thumb{background:#535353;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#727272}button{cursor:pointer;font-family:inherit;transition:all .2s ease}button:hover:not(:disabled){transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0)}button:disabled{cursor:not-allowed;opacity:.5}.main-content.mobile{background:#000;padding:0}.main-content.mobile .top-bar{display:none}.main-content.mobile .content-area{height:100vh;overflow-y:auto;padding:10px}.main-content.mobile .game-container{background:#0000;border:none;box-shadow:none;margin-bottom:0;padding:0}.main-content.mobile .game-display{margin-bottom:10px}.main-content.mobile .game-display canvas{border-radius:4px;height:auto;max-width:100%;width:100%}.main-content.mobile .game-controls{display:none}.main-content.mobile .upload-section{margin-bottom:10px}.main-content.mobile .game-library,.main-content.mobile .upload-section{background:#1a1a1acc;border-radius:8px;padding:16px}@media (max-width:1024px){.sidebar{width:240px}.logo-text{font-size:18px}.content-area{padding:16px 24px}.help-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.app{flex-direction:column}.sidebar{border-bottom:1px solid #282828;border-right:none;height:200px;width:100%}.sidebar-header{padding:12px 16px}.logo-text{font-size:16px}.sidebar-content{flex:1 1}.sidebar-footer{padding:12px 16px}.quick-actions{gap:6px}.quick-action-btn{font-size:16px;height:36px;width:36px}.top-bar{padding:12px 16px}.top-bar-center{margin:0 16px}.content-area{padding:16px}.section-title{font-size:20px}.game-container{padding:16px}.help-grid{gap:16px;grid-template-columns:1fr}}@media (max-width:480px){.logo-text,.nav-text,.top-bar-center,.username{display:none}.section-header{align-items:flex-start;flex-direction:column;gap:12px}}@media screen and (max-width:768px) and (orientation:portrait){.main-content.mobile .content-area{padding-bottom:220px}}@media screen and (orientation:landscape) and (max-height:500px){.main-content.mobile{height:100vh;overflow:hidden;position:relative}.main-content.mobile .content-area{height:100%;overflow-y:auto;padding:0}.main-content.mobile .game-section{background:#000;display:flex;flex-direction:column;height:100%;left:0;padding:5px;position:absolute;right:0;top:0;z-index:999}.main-content.mobile .game-container,.main-content.mobile .game-display{align-items:center;display:flex;flex-grow:1;justify-content:center;min-height:0;width:100%}.main-content.mobile .game-display canvas{height:100%;max-width:100%;object-fit:contain;width:100%}.main-content.mobile .upload-section{margin-top:calc(100vh - 180px)}.main-content.mobile .game-section .section-header{display:none}.main-content.mobile .game-container{border:none;box-shadow:none;padding:0}}@media (hover:none) and (pointer:coarse){.main-content.mobile button{min-height:44px;min-width:44px}.main-content.mobile .section-header{margin-bottom:16px}}@supports (padding:max(0px)){.main-content.mobile{padding-left:max(env(safe-area-inset-left),0px);padding-right:max(env(safe-area-inset-right),0px);padding-top:max(env(safe-area-inset-top),0px)}.main-content.mobile .content-area{padding-bottom:max(env(safe-area-inset-bottom),220px)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.game-section,.help-section,.upload-section{animation:fadeIn .6s ease-out}.help-card:first-child{animation-delay:.1s}.help-card:nth-child(2){animation-delay:.2s}.help-card:nth-child(3){animation-delay:.3s}.help-card:nth-child(4){animation-delay:.4s}.back-button{background:none;border:none;color:#b3b3b3;cursor:pointer;font-size:14px;margin-bottom:24px;padding:8px 0;transition:color .2s ease}.back-button:hover{color:#fff}.game-header{margin-bottom:32px}.game-hero{align-items:flex-end;background:linear-gradient(135deg,#1db9541a,#1ed7600d);border:1px solid #1db95433;border-radius:12px;display:flex;gap:24px;padding:32px}.game-hero-cover{align-items:center;background:linear-gradient(45deg,#1db954,#1ed760);border-radius:8px;box-shadow:0 8px 32px #1db9544d;display:flex;flex-shrink:0;font-size:64px;height:120px;justify-content:center;width:120px}.game-hero-info{flex:1 1}.game-hero-title{color:#fff;font-size:48px;font-weight:900;line-height:1.1;margin:0 0 8px}.game-hero-meta{color:#b3b3b3;font-size:14px;margin:0 0 16px}.game-hero-description{color:#a7a7a7;font-size:16px;line-height:1.4;margin:0 0 16px}:focus{outline:2px solid #1db954;outline-offset:2px}::selection{background:#1db954;color:#fff}@media (max-width:768px){.game-hero{align-items:center;flex-direction:column;gap:16px;padding:24px;text-align:center}.game-hero-cover{font-size:48px;height:100px;width:100px}.game-hero-title{font-size:32px}.game-hero-description,.game-hero-meta{font-size:14px}}.main-content.view-game .game-library,.main-content.view-home .game-section{display:none}.game-container:fullscreen{align-items:center;background:#000;border:none;box-shadow:none;display:flex;justify-content:center;padding:0}.game-container:fullscreen .game-display{height:100%;margin:0;width:100%}.game-container:fullscreen .game-display canvas{border-radius:0;box-shadow:none;height:100%;max-width:100%;object-fit:contain;width:100%}.game-container:fullscreen .game-controls{display:none}.game-library{padding:0}.categories-section,.featured-section,.recent-section{margin-bottom:48px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.section-title{color:#fff;font-size:24px;font-weight:700;margin:0}.show-all-btn{background:none;border:none;color:#b3b3b3;cursor:pointer;font-size:14px;font-weight:600;transition:color .2s ease}.show-all-btn:hover{color:#fff}.games-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.game-card{background:linear-gradient(145deg,#1a1a1a,#2a2a2a);border:1px solid #0000;border-radius:8px;cursor:pointer;overflow:hidden;padding:16px;position:relative;transition:all .3s ease}.game-card:hover{background:linear-gradient(145deg,#2a2a2a,#3a3a3a);border-color:#1db954;box-shadow:0 8px 25px #0006;transform:translateY(-4px)}.game-cover{align-items:center;background:linear-gradient(45deg,#1db954,#1ed760);border-radius:6px;display:flex;height:120px;justify-content:center;margin-bottom:12px;overflow:hidden;position:relative;width:100%}.cover-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-size:48px}.play-button{align-items:center;background:#1db954;border-radius:50%;bottom:8px;box-shadow:0 4px 12px #1db95466;color:#000;display:flex;font-size:12px;font-weight:700;height:32px;justify-content:center;opacity:0;position:absolute;right:8px;transform:translateY(8px);transition:all .3s ease;width:32px}.game-card:hover .play-button{opacity:1;transform:translateY(0)}.game-info{text-align:left}.game-title{color:#fff;font-size:16px;font-weight:600;line-height:1.2;margin:0 0 4px}.game-meta{color:#b3b3b3;font-size:12px;margin:0 0 8px}.game-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#a7a7a7;display:-webkit-box;font-size:12px;line-height:1.3;margin:0;overflow:hidden}.recent-games{display:flex;flex-direction:column;gap:8px}.recent-game-item{align-items:center;background:#0000;border-radius:4px;cursor:pointer;display:flex;gap:12px;padding:8px 12px;transition:all .2s ease}.recent-game-item:hover{background:#1a1a1a}.recent-cover{align-items:center;background:linear-gradient(45deg,#1db954,#1ed760);border-radius:4px;display:flex;flex-shrink:0;font-size:20px;height:40px;justify-content:center;width:40px}.recent-info{flex:1 1;min-width:0}.recent-title{color:#fff;font-size:14px;font-weight:500;margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-meta{color:#b3b3b3;font-size:12px;margin:0}.recent-actions{display:flex;gap:8px;opacity:0;transition:opacity .2s ease}.recent-game-item:hover .recent-actions{opacity:1}.like-btn,.play-btn{align-items:center;background:none;border:none;border-radius:50%;color:#b3b3b3;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.like-btn:hover{background:#1db9541a;color:#1db954}.play-btn:hover{background:#ffffff1a;color:#fff}.categories-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.category-card{border-radius:8px;cursor:pointer;display:flex;flex-direction:column;height:100px;justify-content:flex-end;overflow:hidden;padding:16px;position:relative;transition:all .3s ease}.category-card:before{background:linear-gradient(135deg,#0000004d,#000000b3);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.category-card h3,.category-card p{color:#fff;margin:0;position:relative;z-index:2}.category-card h3{font-size:16px;font-weight:600;margin-bottom:4px}.category-card p{font-size:12px;opacity:.9}.category-card:hover{box-shadow:0 8px 25px #0000004d;transform:scale(1.05)}.category-card.platform{background:linear-gradient(135deg,#ff6b6b,#ee5a24)}.category-card.action{background:linear-gradient(135deg,#4834d4,#686de0)}.category-card.rpg{background:linear-gradient(135deg,#00d2d3,#54a0ff)}.category-card.multiplayer{background:linear-gradient(135deg,#1db954,#1ed760)}@media (max-width:768px){.games-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.game-card{padding:12px}.game-cover{height:100px}.cover-icon{font-size:36px}.section-title{font-size:20px}.categories-grid{gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.category-card{height:80px;padding:12px}.category-card h3{font-size:14px}.category-card p{font-size:11px}}@media (max-width:480px){.games-grid{gap:12px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.recent-game-item{padding:6px 8px}.recent-cover{font-size:16px;height:32px;width:32px}.recent-title{font-size:13px}.recent-meta{font-size:11px}}.room-user-list{background:linear-gradient(180deg,#1a1a1a,#121212);border-radius:8px;display:flex;flex-direction:column;height:100%;overflow:hidden}.room-header{background:linear-gradient(135deg,#1db9541a,#1ed7600d);border-bottom:1px solid #333;padding:20px}.room-header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.room-title{color:#fff;font-size:18px;font-weight:700;margin:0}.refresh-btn{align-items:center;background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border:1px solid #333;border-radius:6px;color:#b3b3b3;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.refresh-btn:hover{background:linear-gradient(135deg,#1db954,#1ed760);box-shadow:0 2px 8px #1db9544d;color:#fff;transform:rotate(180deg)}.room-info{display:flex;flex-direction:column;gap:8px}.room-name{background:#1db9541a;border-radius:4px;color:#1db954;display:inline-block;font-size:14px;font-weight:600;padding:4px 8px;width:fit-content}.room-status{align-items:center;display:flex;font-size:12px;gap:6px}.status-indicator{font-size:14px}.status-text{color:#b3b3b3;font-weight:500}.status-indicator.waiting{color:orange}.status-indicator.playing{color:#1db954}.status-indicator.paused{color:#ff6b6b}.status-indicator.ended{color:#666}.player-list{flex:1 1;overflow-y:auto;padding:16px}.player-item{align-items:center;background:linear-gradient(135deg,#2a2a2a,#1e1e1e);border:1px solid #333;border-radius:8px;display:flex;gap:12px;margin-bottom:8px;padding:12px;transition:all .2s ease}.player-item:hover{background:linear-gradient(135deg,#333,#2a2a2a);border-color:#444;transform:translateY(-1px)}.player-item.current-player{background:linear-gradient(135deg,#1db9541a,#1ed7600d);border-color:#1db954}.player-avatar{align-items:center;background:linear-gradient(45deg,#1db954,#1ed760);border-radius:50%;box-shadow:0 2px 8px #1db9544d;display:flex;flex-shrink:0;font-size:20px;height:40px;justify-content:center;width:40px}.player-info{flex:1 1;min-width:0}.player-name{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:600;gap:6px;margin-bottom:4px}.you-badge{color:#1db954;font-size:11px;font-weight:500}.player-details{display:flex;flex-direction:column;gap:2px;margin-bottom:4px}.player-role{color:orange;font-size:11px;font-weight:500}.player-status{color:#b3b3b3;font-size:11px}.player-join-time{color:#666;font-size:10px}.player-actions{align-items:center;display:flex;gap:8px}.ready-indicator{color:#1db954;font-size:18px}.waiting-indicator{animation:pulse 2s infinite;color:orange;font-size:18px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.room-stats{background:#0000004d;border-top:1px solid #333;padding:16px}.stat-item{align-items:center;display:flex;font-size:12px;justify-content:space-between;margin-bottom:8px}.stat-item:last-child{margin-bottom:0}.stat-label{color:#b3b3b3}.stat-value{color:#fff;font-weight:600}.no-connection,.no-players,.no-room{align-items:center;color:#666;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.no-connection-icon,.no-players-icon,.no-room-icon{font-size:48px;margin-bottom:16px;opacity:.5}.no-connection p,.no-players p,.no-room p{color:#888;font-size:14px;margin:0}.no-room .hint{color:#666;font-size:12px;margin-top:8px}.player-list::-webkit-scrollbar{width:6px}.player-list::-webkit-scrollbar-track{background:#1a1a1a}.player-list::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.player-list::-webkit-scrollbar-thumb:hover{background:#444}@media (max-width:768px){.room-header{padding:16px}.room-title{font-size:16px}.player-list{padding:12px}.player-item{padding:10px}.player-avatar{font-size:18px;height:36px;width:36px}.player-name{font-size:13px}.room-stats{padding:12px}}.player-item{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.loading-players{align-items:center;color:#666;display:flex;justify-content:center;padding:20px}.loading-spinner-small{animation:spin 1s linear infinite;border:2px solid #333;border-radius:50%;border-top-color:#1db954;height:20px;margin-right:10px;width:20px}.status-indicator.playing{animation:glow 2s ease-in-out infinite alternate}@keyframes glow{0%{text-shadow:0 0 5px #1db95480}to{text-shadow:0 0 10px #1db954cc}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;overflow-x:hidden;overscroll-behavior:none;will-change:scroll-position}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{contain:layout style paint;min-height:100vh;will-change:transform}@media (max-width:768px){body{-webkit-touch-callout:none;touch-action:pan-x pan-y;-webkit-user-select:none;user-select:none}#root{height:100vh;height:100dvh;overflow:hidden}}*{backface-visibility:hidden;-webkit-backface-visibility:hidden}canvas{contain:layout style paint;image-rendering:pixelated;will-change:transform}