@import"https://fonts.googleapis.com/css2?family=Montserrat+Alternates:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap";.toast-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:12px 24px;border-radius:100px;font-family:var(--font-primary);font-weight:600;font-size:15px;color:var(--color-white);box-shadow:0 4px 12px #0000004d;animation:toast-in .3s ease,toast-out .3s ease 2.7s;pointer-events:auto;cursor:pointer;white-space:nowrap}.toast-success{background:var(--color-success)}.toast-info{background:var(--color-primary)}.toast-error{background:var(--color-error)}@keyframes toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.header{display:flex;align-items:center;justify-content:center;flex-direction:column;padding:2rem 1rem;gap:1rem;position:relative}.dev-auth-toggle{position:absolute;top:1rem;right:1rem;padding:6px 12px;background:#7878804d;border:1px solid rgba(120,120,128,.5);border-radius:8px;color:#fff;font-size:12px;cursor:pointer;opacity:.6;transition:opacity .2s}.dev-auth-toggle:hover{opacity:1}.logo{width:180px}.title-section{display:flex;flex-direction:column;align-items:center;margin-top:2rem}.gamehub-title{font-family:var(--font-gilroy-bold);font-size:64px;font-weight:700;margin:0;color:#fff}.algorithmic-subtitle{font-family:var(--font-gilroy-bold);font-size:40px;color:#fff;opacity:.8;margin:0}.deals-section{margin-top:3rem}.deals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}@media (min-width: 769px){.header{padding:3rem 2rem}.gamehub-title{font-size:80px}.algorithmic-subtitle{font-size:50px}main{display:flex;align-items:end;justify-content:center;flex-direction:row;padding:4rem 2rem;gap:4rem}}@media (max-width: 768px){.header{flex-direction:column;gap:.5rem}.gamehub-title{font-size:2rem}.algorithmic-subtitle{font-size:1.2rem}.game-card{flex-direction:column;gap:1rem}.stats{flex-wrap:wrap;justify-content:center}.buttons{justify-content:center}}.game-card{align-items:center;margin-top:-30%;max-width:400px}.game-illustration{transform:translateY(35%)}.game-title{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;margin-top:-4.5rem}.game-content{aspect-ratio:1.2 / 1;flex:1;display:flex;flex-direction:column;gap:1rem;-webkit-backdrop-filter:blur(180px);backdrop-filter:blur(180px);justify-content:end;border-radius:32px;padding:2rem}.game-description{font-family:var(--font-gilroy-ulight);font-size:17px;line-height:115%;color:#fff;margin:0;text-align:center}.stats{display:flex;align-items:center;justify-content:center;gap:1rem}.stat{display:flex;flex-direction:column;align-items:center}.stat-label{font-family:var(--font-gilroy-ulight);font-size:.9rem;color:#fff9}.stat-value{font-size:1.5rem;font-weight:700;color:#fff}.divider{width:1px;height:40px;background:var(--color-border)}.buttons{display:flex;gap:1rem;flex-direction:column}.btn{padding:.75rem 1.5rem;border:none;border-radius:32px;font-size:1rem;font-weight:700;cursor:pointer;transition:all var(--transition-normal);font-family:var(--font-primary);text-shadow:-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,1px 1px 0 #000}.rating-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.rating-btn:hover{background:#fff3}.play-btn{background:var(--color-warning);color:#fff}.play-btn:hover{background:#ffed4e}@media (min-width: 769px){.game-content{min-height:300px;align-items:center}.game-card{margin:0;transform:translateY(-150px)}.game-title{transform:translateY(-35%)}.buttons{flex-direction:column;width:100%}}.rounded-input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-sm)}.rounded-input-label{font-family:var(--font-primary);font-weight:300;font-size:17px;color:var(--color-white);padding:0 var(--spacing-lg)}.rounded-input-container{position:relative;display:flex;align-items:center}.rounded-input{padding:var(--spacing-lg);background:var(--color-bg-secondary);border:none;border-radius:var(--radius-2xl);font-family:var(--font-primary);font-weight:300;font-size:17px;color:var(--color-white);outline:none;height:50px;width:100%;padding-right:44px}.rounded-input::placeholder{color:var(--color-text-secondary)}.rounded-input-clear{position:absolute;right:var(--spacing-md);display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-overlay-hover);border:none;border-radius:50%;color:var(--color-white);cursor:pointer;user-select:none;-webkit-user-select:none}.rounded-input-clear:hover{background:#78788099}.rounded-input-wrapper.disabled{opacity:.5}.rounded-input-wrapper.disabled .rounded-input{cursor:not-allowed}.header-section{display:flex;flex-direction:column;gap:var(--spacing-sm);align-items:center}.start-page .game-illustration{transform:none}.title{font-family:var(--font-primary);font-weight:700;font-size:47px;line-height:41px;letter-spacing:4%;color:var(--color-success);text-transform:uppercase;text-align:center;margin:0}.description{font-family:var(--font-primary);font-weight:400;font-size:15px;line-height:23px;letter-spacing:-1%;color:var(--color-text-secondary);text-align:center;margin:0;max-width:350px}.contacts-section{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:14px var(--spacing-lg);background:var(--color-bg-secondary);border-radius:var(--radius-xl)}.stats-row{display:flex;justify-content:space-between;align-items:center}.stat-item{display:flex;flex-direction:column}.start-page .stat-value{font-family:var(--font-primary);font-weight:600;font-size:17px;color:var(--color-white)}.start-page .stat-label{font-family:var(--font-primary);font-weight:500;font-size:13px;color:var(--color-text-secondary)}.online-status{display:flex;justify-content:space-between}.online-text{font-family:var(--font-primary);font-weight:600;font-size:13px;color:var(--color-success)}.divider-icon{display:none}.players-section{display:flex;gap:var(--spacing-lg);overflow-x:auto;padding-bottom:10px;flex-direction:row;-ms-overflow-style:none;scrollbar-width:none}.players-section::-webkit-scrollbar{display:none}.player-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.player-avatar{border-radius:32px;background:linear-gradient(210deg,#fa1182,#f81185,#dd11f0,#c211f6 0%,#bb11f4 16%,#b711f3 52%,#a593eb 98%,#6789e6 100%,#5888e3)}.player-name{font-family:var(--font-primary);font-weight:500;text-align:center;color:var(--color-white);line-height:1.2;width:min-content;font-size:x-small}.actions-section{display:flex;flex-direction:column;gap:32px}.quick-play-btn{padding:14px 20px;background:var(--color-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-primary);font-weight:600;font-size:17px;color:#fff;cursor:pointer;align-self:stretch;text-align:center;width:100%}.or-divider{display:flex;align-items:center;gap:20px}.horizontal-divider{height:1px;background-color:var(--color-border);width:100%;margin:5px 0}.line-icon{flex:1;height:1px;background:#3a3a3c}.or-text{font-family:var(--font-primary);font-weight:600;font-size:17px;color:#3a3a3c}.buttons-row{display:flex;flex-direction:column;gap:20px}.action-btn{padding:14px 20px;background:var(--color-overlay);border:none;border-radius:var(--radius-full);font-family:var(--font-primary);font-weight:600;font-size:17px;color:var(--color-white);cursor:pointer;text-align:center}.theme-toggle{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-overlay);border-radius:var(--radius-full)}.theme-text{font-family:var(--font-primary);font-weight:600;font-size:17px;color:var(--color-text-primary)}.toggle-switch{width:65px;height:28px;border-radius:100px;display:flex;align-items:center;padding:2px;cursor:pointer;transition:background .3s}.toggle-knob{width:40px;height:25px;background:#fff;border-radius:100px;transition:transform .3s,box-shadow .3s;box-shadow:0 1px 3px #0000004d}.input-button-col{display:flex;flex-direction:column;gap:20px;align-items:stretch}@media (min-width: 769px){.title{font-size:26px;font-weight:600;line-height:1.2}.description{font-size:17px;line-height:23px;max-width:none}.actions-section{gap:28px}.input-section{flex:1}.rounded-input{height:auto;min-height:50px}.quick-play-btn{flex:1;align-self:center}.buttons-row{flex-direction:column}.action-btn{flex:1}}@media (max-width: 430px){.title{font-size:40px;line-height:35px}.description{font-size:14px;max-width:100%}.player-card:nth-child(n+6){display:none}}.page{display:flex;flex-direction:column;min-height:100vh;gap:20px;background:var(--color-bg-primary);font-family:var(--font-primary);color:var(--color-text-primary);padding:var(--spacing-2xl) var(--spacing-lg)}.auth-user-display{padding:14px 20px;background:var(--color-bg-secondary);border-radius:var(--radius-full);min-height:50px;display:flex;align-items:center}.auth-user-name{font-family:var(--font-primary);font-weight:600;font-size:17px;color:var(--color-white)}@media (min-width: 769px){.page{padding:64px 30% 32px}}@media (max-width: 430px){.page{padding:36px 20px 32px}}.select-wrapper{display:flex;flex-direction:column;gap:var(--spacing-md)}.select-label{font-family:var(--font-primary);font-weight:400;font-size:17px;color:var(--color-white);padding:0 var(--spacing-lg)}.select-options{display:flex;flex-direction:column;background:var(--color-bg-secondary);border-radius:var(--radius-2xl);overflow:hidden}.select-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);cursor:pointer;transition:background var(--transition-fast)}.select-option:hover:not(.disabled){background:var(--color-bg-tertiary)}.select-option.disabled{opacity:.5;cursor:not-allowed}.select-radio{display:none}.select-radio-custom{width:20px;height:20px;border-radius:50%;border:2px solid var(--color-text-secondary);flex-shrink:0;position:relative;transition:border-color var(--transition-fast)}.select-option:hover .select-radio-custom{border-color:var(--color-text-secondary)}.select-option.selected .select-radio-custom{border-color:var(--color-primary)}.select-option.selected .select-radio-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:var(--color-primary);border-radius:50%}.select-option-content{display:flex;flex-direction:column;gap:var(--spacing-xs);text-align:left}.select-option-label{font-family:var(--font-primary);font-weight:300;font-size:15px;color:var(--color-white)}.select-option-description{font-family:var(--font-primary);font-size:13px;color:var(--color-text-secondary)}.modal-header{margin-bottom:20px}.invite-header-row{display:flex;justify-content:space-between;align-items:center;gap:40px}.header-content{display:flex;flex-direction:row;gap:12px}.modal-header h2,.invite-header-row h2{font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:20px;color:var(--color-white);margin:0}.invite-header-row h2{font-size:26px;letter-spacing:-1%;text-align:left}.header-count{font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:26px;letter-spacing:-1%;color:#5a5a5e;margin:0}.close-button-text{width:45px;height:45px;background:none;border:none;color:#5a5a5e;font-size:40px;cursor:pointer}.modal-footer{position:fixed;bottom:0;left:0;right:0;padding:36px 33%;margin-top:24px}@media (max-width: 430px){.modal-footer{padding:0 24px 36px}}.search-icon{width:24px;height:24px;flex-shrink:0;fill:unset}.filter-button{display:flex;align-items:center;justify-content:center;gap:4px;padding:7px 14px;background:#7878802e;border:none;border-radius:1000px;font-family:SF Pro,sans-serif;font-weight:400;font-size:15px;line-height:20px;color:#ebebf599;cursor:pointer;white-space:nowrap}.contacts-list{display:flex;flex-direction:column;gap:20px;padding-bottom:64px}.contact-group{display:flex;flex-direction:column;gap:16px}.group-title{font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;letter-spacing:-1%;color:var(--color-white);margin:0;padding-left:16px}.group-contacts{display:flex;flex-direction:column;gap:0;padding:0 16px}.contact-card{display:flex;align-items:center;gap:12px;padding:16px 0;border-bottom:1px solid #3A3A3C}.contact-card:last-child{border-bottom:none}.contact-avatar{width:40px;height:40px;border-radius:20px;background:linear-gradient(210deg,#fa76ff,#f876ff,#dd75fa,#ca74f6 0%,#bf73f4 16%,#bb73f3 52%,#a55deb 98%,#8b43e2 100%,#823adf);flex-shrink:0}.contact-info{display:flex;flex-direction:column;gap:4px}.contact-name{font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;letter-spacing:-1%;color:#fff;margin:0}.contact-games{font-family:Montserrat Alternates,sans-serif;font-weight:400;font-size:13px;letter-spacing:-1%;color:#ebebf599;margin:0}.invite-section{position:fixed;bottom:0;left:0;right:0;background:#2c2c2e;border-radius:24px 24px 0 0;padding:16px 24px;max-width:430px;margin:0 auto}.invite-button{width:100%;padding:14px 20px;background:#5e5ce6;border:none;border-radius:1000px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;color:#fff;cursor:pointer;text-align:center}@media (max-width: 430px){.invite-section{padding:16px 20px}}.contacts-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}@media (min-width: 769px){#root{background-color:#1c1c1e}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;padding:36px 24px}.modal-content{background:#1c1c1e;border-radius:24px;width:100%;max-width:430px;height:auto;position:relative;color:#fff;font-family:Montserrat Alternates,sans-serif;display:flex;flex-direction:column}.modal-content.invite-modal{padding:0 0 80px}.modal-close{background:none;border:none;cursor:pointer;height:33px}.invite-modal h2{margin:0;font-size:26px;font-weight:600;letter-spacing:-1%;text-align:left}.modal-body{display:flex;flex-direction:column;gap:36px}.code-section{display:flex;flex-direction:column;gap:20px}.code-card{background:#2c2c2e;border-radius:26px;padding:16px;display:flex;flex-direction:column;gap:12px}.code-label{font-size:13px;font-weight:500;letter-spacing:-1%;text-transform:uppercase;color:#ebebf54d;text-align:center}.code-display{display:flex;flex-direction:row;justify-content:center;gap:10px}.code-char{font-family:Montserrat Alternates,sans-serif;font-weight:700;text-align:center;font-size:36px;font-weight:600;letter-spacing:-1%;background-color:#3a3a3d;width:3rem;height:3rem;border-radius:12px;color:#807feb}.code-button{flex:1;padding:7px 14px;border:none;border-radius:1000px;font-family:inherit;font-weight:600;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.copy-button{background:#7676803d;color:#fff}.copy-button:hover{background:#7676805c}.share-button{background:#5e5ce6;color:#fff}.share-button:hover{background:#4a4ac8}.input-section,.group-section,.input-group{display:flex;flex-direction:column;gap:16px}.input-group label{font-size:17px;font-weight:500;letter-spacing:-1%;color:#fff}.friend-code-input,.group-select{background:#2c2c2e;border:none;border-radius:26px;padding:0 16px;height:52px;color:#fff;font-family:inherit;font-size:17px;outline:none;width:100%}.group-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url('data:image/svg+xml;charset=UTF-8,%3csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"%3e%3cpolyline points="6,9 12,15 18,9"%3e%3c/polyline%3e%3c/svg%3e');background-repeat:no-repeat;background-position:right 16px center;background-size:16px;padding-right:40px}.player-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.player-menu{position:fixed;z-index:1000;background:var(--color-bg-secondary);border-radius:12px;padding:10px;min-width:256px;box-shadow:0 12px 40px #00000080}.player-menu-content{display:flex;flex-direction:column;gap:4px}.player-menu-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:background var(--transition-fast);width:100%;text-align:left}.player-menu-item:hover:not(.disabled){background:var(--color-bg-tertiary)}.player-menu-item.disabled{opacity:.4;cursor:not-allowed}.player-menu-item-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-menu-item-icon img{width:16px;height:16px}.player-menu-item-label{font-family:var(--font-primary);font-size:15px;font-weight:400;color:var(--color-white)}.player-menu-item.destructive .player-menu-item-label{color:var(--color-error)}.player-menu-item.destructive .player-menu-item-icon img{opacity:.7}.contacts-list-wrapper{display:flex;flex-direction:column;gap:var(--spacing-md)}.contacts-list-label{font-family:var(--font-primary);font-weight:400;font-size:17px;color:var(--color-white);padding:0 var(--spacing-lg)}.contacts-list-options{display:flex;flex-direction:column;background:var(--color-bg-secondary);border-radius:var(--radius-2xl);overflow:hidden}.contacts-list-option{cursor:pointer;transition:background var(--transition-fast)}.contacts-list-option-avatar{width:40px;height:40px;flex-shrink:0}.contacts-list-option:hover:not(.disabled){background:var(--color-bg-tertiary)}.contacts-list-option.contacts-listed{background:#5e5ce626}.contacts-list-option-content{display:flex;flex-direction:column;gap:var(--spacing-xs);text-align:left}.contacts-list-option-label{font-family:var(--font-primary);font-weight:300;font-size:15px;color:var(--color-white)}.contacts-list-option-description{font-family:var(--font-primary);font-size:13px;color:var(--color-text-secondary)}.contacts-list-option-ready{margin-left:auto}.contacts-list-option-ready svg{margin-right:10px}.contacts-list-option-data{display:flex;align-items:center;flex-direction:row;gap:var(--spacing-md);padding:var(--spacing-lg)}.search-section{display:flex;flex-direction:column;gap:16px}.search-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--color-bg-secondary);border-radius:999px}.search-icon{width:24px;height:24px;flex-shrink:0}.search-input{flex:1;background:none;border:none;outline:none;color:var(--color-text-secondary);font-weight:400;font-size:18px;line-height:24px}.filters-section{display:flex;flex-direction:column;gap:16px}.filters-container{display:flex;gap:6px;overflow-x:auto;padding:10px 0}@media (max-width: 768px){.filters-container{scrollbar-width:none;-ms-overflow-style:none}.filters-container::-webkit-scrollbar{display:none}}.filter-button{display:flex;align-items:center;justify-content:center;gap:4px;padding:7px 14px;background:#7878802e;border:none;border-radius:1000px;font-family:SF Pro,sans-serif;font-weight:400;font-size:15px;line-height:20px;color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;transition:background-color .2s,color .2s}.filter-button.active{background:#5e5ce6;color:#fff}.filter-button:hover:not(.active){background:#7878804d}.page-header{display:flex;flex-direction:column;gap:8px;margin-bottom:40px;align-self:center;width:100%}.back-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:#4d4d56;font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:15px;cursor:pointer;align-self:flex-start;padding:0 0 5px}.back-arrow{font-size:15px}.page-header-title{font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:26px;line-height:32px;color:var(--color-white);margin:0;text-align:left}.page-header-subtitle{font-family:Montserrat Alternates,sans-serif;font-weight:400;font-size:17px;line-height:20px;color:var(--font-primary);text-align:left;margin:0}@media (max-width: 430px){.page-header-title{font-size:22px;line-height:28px}.page-header-subtitle{font-size:17px;line-height:18px}}.content{display:flex;flex-direction:column;gap:40px;max-width:640px;width:100%;align-self:center}.form-container{display:flex;flex-direction:column;gap:20px;padding:20px;background:#2c2c2e;border-radius:26px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:17px;color:#fff}.form-input,.form-select{padding:16px;background:#1c1c1e;border:none;border-radius:12px;font-family:Montserrat Alternates,sans-serif;font-weight:400;font-size:17px;color:#fff;outline:none}.form-select{cursor:pointer}.checkbox-label{display:flex;align-items:center;gap:12px;font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:17px;color:#fff;cursor:pointer}.checkbox{width:20px;height:20px;accent-color:#5E5CE6}.players-header{display:flex;justify-content:space-between;align-items:center}.players-title{font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;color:#fff}.invite-btn{padding:8px 16px;background:#7878803d;border:none;border-radius:1000px;font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:15px;color:#fff;cursor:pointer}.empty{opacity:.5}.empty-avatar{width:48px;height:48px;border-radius:32px;background:#48484a;border:2px dashed #787880}.empty-text{font-family:Montserrat Alternates,sans-serif;font-weight:400;font-size:12px;color:#ebebf599;text-align:center}.create-room-btn{padding:16px 32px;background:#5e5ce6;border:none;border-radius:1000px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;color:#fff;cursor:pointer;align-self:center;min-width:200px}@media (max-width: 430px){.page-title{font-size:22px;line-height:28px}.page-subtitle{font-size:14px;line-height:18px}.form-container{padding:16px}.form-input,.form-select{padding:14px;font-size:16px}.invite-btn{padding:6px 12px;font-size:14px}.players-list{gap:12px}.create-room-btn{padding:14px 24px;font-size:16px}}.room-header{display:flex;flex-direction:column;gap:32px}.room-title{font-size:26px;font-weight:600;margin:0;line-height:1.2}.room-description{font-size:17px;font-weight:400;line-height:23px;color:#ebebf599;margin:0}.room-content{display:flex;flex-direction:column;gap:32px}@media (min-width: 769px){.room-title{font-size:26px;line-height:32px}.room-description{font-size:17px;line-height:23px}.code-header{gap:20px}.players-list{gap:24px}}.room-players-section{display:flex;gap:var(--spacing-lg);overflow-x:auto;padding-bottom:10px;flex-direction:column;-ms-overflow-style:none;scrollbar-width:none}.room-players-section::-webkit-scrollbar{display:none}.connection-overlay{display:flex;align-items:center;justify-content:center;min-height:60vh}.connection-message{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px;background:#2c2c2e;border-radius:26px;text-align:center}.connection-message p{margin:0;font-size:17px;font-weight:500;color:#ebebf5cc}.connection-message.error p{color:#ff453a}.connection-message button{padding:12px 24px;background:#5e5ce6;border:none;border-radius:12px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:16px;color:#fff;cursor:pointer}.spinner{width:32px;height:32px;border:3px solid rgba(235,235,245,.2);border-top-color:#5e5ce6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.code-section-container{background:var(--color-bg-secondary);border-radius:26px;padding:16px;display:flex;flex-direction:column;gap:20px;box-sizing:border-box}.code-section-label{font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:13px;color:var(--color-white);text-transform:uppercase;letter-spacing:-1%}.code-section-display{display:flex;gap:12px;justify-content:center}.code-section-char{width:100%;aspect-ratio:1 / 1;background:#7878802e;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:20px;color:#807feb}.code-section-actions{display:flex;gap:12px}.code-section-btn{flex:1;height:32px;border:none;border-radius:1000px;font-family:Montserrat Alternates,sans-serif;font-weight:300;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px}.code-section-copy{background:#7676803d;color:var(--color-white)}.code-section-share{background:#5e5ce6;color:#fff}.invite-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background:#1c1c1e;z-index:2000;padding:64px 30% 32px;display:flex;flex-direction:column;gap:32px}.invite-fullscreen-content{width:100%;color:#fff;font-family:Montserrat Alternates,sans-serif;display:flex;flex-direction:column;gap:40px}.invite-fullscreen .modal-body{display:flex;flex-direction:column;gap:36px}.invite-fullscreen .modal-footer{margin-top:auto}.invite-fullscreen .add-button{width:100%;padding:16px;background:#5e5ce6;border:none;border-radius:1000px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;color:#fff;cursor:pointer}.invite-fullscreen .invite-fullscreen-content .modal-body .input-section,.invite-fullscreen .invite-fullscreen-content .modal-body .group-section{display:flex;flex-direction:column;gap:8px}.invite-fullscreen .invite-fullscreen-content .modal-body .input-group label{font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:15px;color:#fff}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#78788063;display:flex;align-items:center;justify-content:center;z-index:1000;padding:14px}.confirm-modal-content{width:300px;background:var(--color-bg-secondary);border-radius:24px;padding:14px;display:flex;flex-direction:column;gap:10px}.confirm-modal-title{font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;color:var(--color-white);margin:0;text-align:center;line-height:1.3}.confirm-modal-description{font-family:Montserrat Alternates,sans-serif;font-weight:400;font-size:13px;color:#ebebf599;margin:0;text-align:center;line-height:1.4}.confirm-modal-actions{display:flex;gap:10px;margin-top:4px}.confirm-modal-cancel,.confirm-modal-confirm{flex:1;padding:14px;border-radius:12px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;cursor:pointer;transition:opacity .2s ease}.confirm-modal-cancel{background:var(--color-bg-primary);border:none;color:var(--color-white)}.confirm-modal-confirm{background:var(--color-bg-primary);border:none;color:#0a84ff}.confirm-modal-confirm.danger{color:#ff453a}.confirm-modal-cancel:hover,.confirm-modal-confirm:hover{opacity:.8}.join-header{display:flex;flex-direction:column;gap:32px}.join-title{font-size:26px;font-weight:600;margin:0;line-height:1.2}.join-description{font-size:17px;font-weight:400;line-height:23px;color:#ebebf599;margin:0}.header-actions{display:flex;justify-content:flex-start;align-items:center;gap:0}.back-btn{display:flex;align-items:center;gap:4px;padding:7px 14px;background:transparent;border:none;border-radius:40px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:14px;color:#fff;cursor:pointer}.back-icon{font-size:16px}.join-content{display:flex;flex-direction:column;gap:32px}.code-section{min-height:168px}.code-card{padding:16px;background:#2c2c2e;border-radius:26px;min-height:168px}.code-header{display:flex;justify-content:space-between;align-items:center;gap:20px}.code-header h3{font-size:13px;font-weight:500;margin:0;text-transform:uppercase;color:#ebebf54d;display:flex;align-items:center;gap:12px}.code-buttons{display:flex;gap:12px}.copy-code-btn{display:flex;align-items:center;gap:4px;padding:7px 14px;background:#7676803d;border:1px solid rgba(118,118,128,.24);border-radius:1000px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:14px;color:#fff;cursor:pointer;margin:0}.share-btn{display:flex;align-items:center;gap:4px;padding:7px 14px;background:#5e5ce6;border:1px solid #5e5ce6;border-radius:1000px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:14px;color:#fff;cursor:pointer;margin:0}.share-icon{font-size:16px}.players-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--radius-2xl);gap:16px}.players-header h3{font-size:17px;font-weight:600;margin:0}.ready-indicator{display:flex;align-items:center;gap:12px;font-size:17px;font-weight:500;color:#ebebf54d}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.player-info{flex-grow:1;min-width:0}.ready-badge{font-size:17px}@media (min-width: 769px){.join-title{font-size:26px;line-height:32px}.join-description{font-size:17px;line-height:23px}.code-header{gap:20px}.players-list{gap:24px}}.ready-badge{font-size:17px;font-weight:500;color:#ebebf54d}.host-badge{font-size:13px;font-weight:600;padding:4px 8px;background:#30d158;border-radius:8px;color:#fff}.invite-btn{font-size:14px;font-weight:500;padding:8px 16px;border-radius:8px;border:1px solid #3a3a3c;background:#2c2c2e;color:#787880;cursor:pointer;transition:all .2s ease}.invite-btn:hover{background:#3a3a3c;color:#fff}.join-players-section{display:flex;gap:var(--spacing-lg);overflow-x:auto;padding-bottom:10px;flex-direction:column;-ms-overflow-style:none;scrollbar-width:none}.join-players-section::-webkit-scrollbar{display:none}.room-card{display:flex;flex-direction:column;gap:16px;padding:14px 16px;background:var(--color-bg-secondary);border-radius:24px;cursor:pointer;transition:background-color .2s}.room-card:hover{background:var(--color-bg-tertiary)}.room-card-header{display:flex;justify-content:space-between;align-items:flex-start}.room-card-title-section{display:flex;flex-direction:column;gap:2px}.room-card-title{margin:0;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:17px;letter-spacing:-1%;color:var(--color-white)}.room-card-time{font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:13px;letter-spacing:-1%;color:var(--color-text-secondary)}.room-card-status{display:flex;align-items:center;justify-content:center;padding:2px 4px;border-radius:4px;font-family:Montserrat Alternates,sans-serif;font-weight:600;font-size:13px;letter-spacing:-1%}.status-открытая{background:#30d15826;color:#30d158}.status-закрытая{background:#ff453a26;color:#ff453a}.status-приватная{background:#ff9f0a26;color:#ff9f0a}.room-card-body{display:flex;flex-direction:column;gap:8px}.room-card-participants-count{font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:15px;letter-spacing:-1%;color:var(--color-text-secondary)}.room-card-participants{display:flex;flex-wrap:wrap;gap:4px}.participant-chip{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 4px;background:#7878802e;border-radius:999px}.participant-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden}.participant-name{font-family:Montserrat Alternates,sans-serif;font-weight:500;font-size:15px;letter-spacing:-1%;color:#fff}:root{--color-bg-primary: #1C1C1E;--color-bg-secondary: #2C2C2E;--color-bg-tertiary: #333334;--color-primary: #5E5CE6;--color-success: #34C759;--color-warning: #FFD700;--color-error: #FF453A;--color-white: #FFFFFF;--color-text-primary: #FFFFFF;--color-text-secondary: rgba(235, 235, 245, .6);--color-border: rgba(255, 255, 255, .1);--color-overlay: rgba(120, 120, 128, .24);--color-overlay-hover: rgba(120, 120, 128, .4);--font-primary: "Montserrat Alternates", sans-serif;--font-gilroy-light: GilroyLight;--font-gilroy-regular: GilroyRegular;--font-gilroy-bold: GilroyBold;--font-gilroy-ulight: GilroyULight;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 26px;--radius-full: 1000px;--transition-fast: .15s ease;--transition-normal: .3s ease}.light-theme{--color-bg-primary: #F2F2F7;--color-bg-secondary: #FFFFFF;--color-bg-tertiary: #C7C7CC;--color-primary: #5856D6;--color-success: #34C759;--color-warning: #FFD700;--color-error: #FF3B30;--color-white: #000000;--color-text-primary: #000000;--color-text-secondary: rgba(60, 60, 67, .6);--color-border: #C7C7CC;--color-overlay: rgba(120, 120, 128, .12);--color-overlay-hover: rgba(120, 120, 128, .4)}@font-face{font-family:GilroyLight;src:url(/fonts/Gilroy-Light.ttf)}@font-face{font-family:GilroyRegular;src:url(/fonts/Gilroy-Regular.ttf)}@font-face{font-family:GilroyBold;src:url(/fonts/Gilroy-Bold.ttf)}@font-face{font-family:GilroyULight;src:url(/fonts/Gilroy-UltraLight.ttf)}body{margin:0;font-family:var(--font-primary);background:linear-gradient(var(--color-bg-primary) 0%,var(--color-bg-tertiary) 100%);color:var(--color-text-primary);min-height:100vh;overflow-x:hidden}html{background:var(--color-bg-primary);overflow-x:hidden}*{box-sizing:border-box;font-family:var(--font-gilroy-regular)}.app-container{min-height:100vh;display:flex;flex-direction:column}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--color-bg-secondary);border-radius:var(--radius-xl);padding:var(--spacing-2xl);max-width:400px;width:90%;max-height:80vh;overflow-y:auto;position:relative}.modal-body{display:flex;flex-direction:column;gap:20px}.code-section{display:flex;flex-direction:column;gap:16px}.code-card{background:var(--color-bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.code-label{font-family:var(--font-primary);font-weight:500;font-size:15px;color:var(--color-text-secondary)}.code-display{display:flex;gap:8px;justify-content:center}.code-char{background:var(--color-primary);color:var(--color-white);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-family:var(--font-primary);font-weight:600;font-size:18px}.code-actions{display:flex;gap:12px}.code-button{flex:1;padding:var(--spacing-md);border:none;border-radius:var(--radius-full);font-family:var(--font-primary);font-weight:600;font-size:15px;cursor:pointer}.copy-button{background:var(--color-overlay);color:var(--color-white)}.share-button{background:var(--color-primary);color:var(--color-white)}.input-section,.group-section{display:flex;flex-direction:column;gap:8px}.input-group label{font-family:var(--font-primary);font-weight:500;font-size:15px;color:var(--color-white)}.friend-code-input,.group-select{padding:var(--spacing-md);background:var(--color-bg-primary);border:none;border-radius:var(--radius-md);font-family:var(--font-primary);font-weight:400;font-size:15px;color:var(--color-white);outline:none}.group-select{cursor:pointer}.add-button{width:100%;padding:14px;background:var(--color-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-primary);font-weight:600;font-size:17px;color:#fff;cursor:pointer;transition:background-color .2s}.add-button:hover{background:#4a4ac8}.remove-button{width:100%;padding:14px;background:var(--color-bg-secondary);border:none;border-radius:var(--radius-full);font-family:var(--font-primary);font-weight:600;font-size:17px;color:var(--color-error);cursor:pointer;transition:background-color .2s}.remove-button:hover{background:var(--color-bg-tertiary)}
