@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.farcaster-gate-image{position:fixed;top:30px;left:-40px;z-index:30;pointer-events:none}.farcaster-gate-image img{width:260px;height:auto;opacity:1}.gate-background-image{position:fixed;bottom:280px;right:0;z-index:29;pointer-events:none}.gate-background-image img{width:320px;height:auto;opacity:1}.header-container{position:fixed;top:20px;left:20px;right:20px;max-width:500px;margin:0 auto;z-index:50;background:linear-gradient(138deg,#5a2a7e 1.6%,#704189 106.55%);border-radius:16px;padding:0 16px;height:92px;color:#fff;box-shadow:0 20px 40px rgba(0,0,0,.3);display:flex;justify-content:space-between;align-items:center}.header-logo{height:60px;width:auto}.main-container{position:fixed;bottom:20px;left:20px;right:20px;max-width:500px;margin:0 auto;z-index:50}.room-gatekeeper{background-color:#fff;border-radius:16px;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.1);padding:0;width:100%;position:relative;z-index:1;font-family:Inter,sans-serif}.access-requirements-section{background-size:cover;background-position:50%;background-repeat:no-repeat;color:#fff;padding:32px 24px 24px;position:relative}.dark-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1}.content-container{position:relative;z-index:2}.welcome-text{font-size:.82rem;font-weight:500;margin-bottom:1.5rem;color:#fff;text-align:left;font-family:Inter,sans-serif;line-height:1.5}.entry-status-container{margin-bottom:1rem;display:flex;flex-direction:row;gap:.5rem;align-items:center}.entry-status-display{flex:1 1;padding:.75rem;background-color:hsla(0,0%,100%,.1);border-radius:6px;font-size:.775rem;display:flex;justify-content:left;align-items:left}.entry-status-text{font-weight:500;font-family:Inter,sans-serif}.entry-status-text.granted{color:#86efac}.entry-status-text.denied{color:#fca5a5}.swap-button{padding:12px 16px;border-radius:6px;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6 50%,#a855f7);color:#fff;font-size:.775rem;font-weight:500;cursor:pointer;font-family:Inter,sans-serif;box-shadow:0 2px 4px rgba(0,0,0,.1);white-space:nowrap;flex-shrink:0;transition:opacity .2s ease}.swap-button:disabled{cursor:not-allowed;opacity:.5}.action-buttons-container{display:flex;flex-direction:column;gap:.5rem;margin-bottom:0;align-items:stretch}.enter-room-button{padding:1rem;border-radius:8px;border:none;font-size:1rem;font-weight:600;cursor:pointer;font-family:Inter,sans-serif;transition:background-color .2s ease;height:calc(1rem * 2 + 1rem);display:flex;align-items:center;justify-content:center}.enter-room-button,.enter-room-button:enabled{background-color:#fff;color:#1f2937}.enter-room-button:enabled:hover{background-color:hsla(0,0%,100%,.95)}.enter-room-button:disabled{background-color:hsla(0,0%,100%,.6);color:rgba(31,41,55,.5);cursor:not-allowed;opacity:.6}.enter-room-button .loading-container{display:flex;align-items:center;justify-content:center;gap:.5rem}.loading-spinner{width:16px;height:16px;border:2px solid rgba(31,41,55,.3);border-top-color:rgba(31,41,55,.8);border-radius:50%;animation:spin 1s linear infinite}.lobbies-button{padding:calc(1rem - 2px);border-radius:8px;border:2px solid hsla(0,0%,100%,.8);background-color:transparent;color:hsla(0,0%,100%,.9);font-size:1rem;font-weight:600;cursor:pointer;font-family:Inter,sans-serif;transition:opacity .2s ease,background-color .2s ease,border-color .2s ease;height:calc(1rem * 2 + 1rem);display:flex;align-items:center;justify-content:center}.lobbies-button:hover{background-color:hsla(0,0%,100%,.1);border-color:#fff}.lobby-list{background-color:transparent;border-radius:8px;padding:0;margin-bottom:1rem;max-height:65vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.lobby-list-inner{display:flex;flex-direction:column;gap:.5rem}@media (max-width:768px){.access-requirements-section:has(.lobby-list){padding:16px 12px}}@media (max-width:768px){.room-gatekeeper.show-lobbies .access-requirements-section{padding:16px 12px}}.back-button-container{display:flex;justify-content:flex-start;gap:.75rem;align-items:center}.back-button.ghost-button{padding:.75rem;border-radius:8px;border:2px solid hsla(0,0%,100%,.4);background-color:transparent;color:hsla(0,0%,100%,.9);cursor:pointer;font-family:Inter,sans-serif;display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex-shrink:0;transition:border-color .2s ease,background-color .2s ease}.back-button.ghost-button:hover{border-color:hsla(0,0%,100%,.7);background-color:hsla(0,0%,100%,.1)}.back-button.ghost-button img{width:20px;height:20px;opacity:.9;filter:brightness(0) invert(1)}.create-lobby-button{padding:.75rem 1rem;border-radius:8px;border:none;background-color:hsla(0,0%,100%,.9);color:#1f2937;cursor:pointer;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;display:flex;align-items:center;justify-content:center;height:48px;flex:1 1;white-space:nowrap;transition:background-color .2s ease,transform .1s ease}.create-lobby-button:hover{background-color:#fff;transform:translateY(-1px)}.create-lobby-button:active{transform:translateY(0)}.error-message{background-color:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#fca5a5}.error-message,.success-message{margin-top:1rem;padding:.75rem;font-size:.875rem;text-align:left;font-family:Inter,sans-serif}.success-message{background-color:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.3);border-radius:6px;color:#86efac}.success-message-title{margin-bottom:.5rem;font-weight:600}.success-message-text,.success-message-title{font-family:Inter,sans-serif}.lobby-list::-webkit-scrollbar{display:none}.lobby-scroll-container{scrollbar-width:thin;scrollbar-color:hsla(0,0%,100%,.3) hsla(0,0%,100%,.1)}.lobby-separator{width:100%;height:.5px;background-color:hsla(0,0%,100%,.25);margin:.05rem 0;border:none}.fullscreen-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#fefefe;z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-in}.loading-content{text-align:left;padding:2rem;max-width:500px;animation:slideUp .5s ease-out}.loading-logo{margin-bottom:2rem;animation:pulse 2s ease-in-out infinite}.loading-logo img{width:200px;height:auto;filter:drop-shadow(0 0 20px rgba(255,255,255,.3))}.pulsing-logo{animation:pulse 2s ease-in-out infinite}.loading-title{font-size:2rem;font-weight:700;margin-bottom:2rem;text-align:left}.loading-description,.loading-title{color:#000;font-family:Inter,sans-serif}.loading-description{margin-bottom:3rem}.loading-description p{font-size:1rem;margin:.25rem 0;padding:0;background:transparent;border-radius:0;text-align:left}.loading-description p:first-child{animation-delay:.1s}.loading-description p:nth-child(2){animation-delay:.2s}.loading-description p:nth-child(3){animation-delay:.3s}.loading-description p:nth-child(4){animation-delay:.4s}.loading-description p:nth-child(5){animation-delay:.5s}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem}.loading-spinner-large{width:50px;height:50px;border:4px solid hsla(0,0%,100%,.2);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:1rem;color:hsla(0,0%,100%,.8);font-family:Inter,sans-serif;font-weight:500}.welcome-close-button{padding:1rem 2rem;border-radius:12px;border:2px solid #000;background:transparent;color:#000;font-size:1.1rem;font-weight:700;cursor:pointer;font-family:Inter,sans-serif;transition:all .3s ease;margin-top:1rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}.welcome-close-button:hover{background:rgba(0,0,0,.05);border-color:#000;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.welcome-close-button:active{transform:translateY(0)}@media (max-width:768px){.loading-content{padding:1.5rem}.loading-logo img{width:150px}.loading-title{font-size:1.5rem;margin-bottom:1.5rem}.loading-description p{font-size:.9rem;padding:0;margin:.2rem 0}.loading-spinner-large{width:40px;height:40px}}