:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;width:100%;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root,[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f7f8fa;--bg-tertiary: #e2e8f0;--bg-gradient: linear-gradient(135deg, #667eea 0%, #e74c3c 100%);--text-primary: #2d3748;--text-secondary: #718096;--text-tertiary: #a0aec0;--text-inverse: #ffffff;--border-primary: #e2e8f0;--border-secondary: #cbd5e0;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .15)}[data-theme=dark]{--bg-primary: #1a202c;--bg-secondary: #2d3748;--bg-tertiary: #4a5568;--bg-gradient: linear-gradient(135deg, #3b5bdb 0%, #c0392b 100%);--text-primary: #f7fafc;--text-secondary: #e2e8f0;--text-tertiary: #cbd5e0;--text-inverse: #1a202c;--border-primary: #4a5568;--border-secondary: #2d3748;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4)}*{box-sizing:border-box}input,select,textarea{background:var(--bg-primary);color:var(--text-primary);transition:background .3s ease,color .3s ease}.app{min-height:100vh;width:100%;max-width:100%;background:var(--bg-secondary);color:var(--text-primary);display:flex;flex-direction:column;transition:background .3s ease,color .3s ease}.top-navbar{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#667eea,#e74c3c);box-shadow:0 4px 12px #00000026;padding:.5rem 1.5rem;display:flex;justify-content:space-between;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;box-sizing:border-box}.brand-title{flex:1;display:flex;justify-content:center;align-items:center}.brand-title h1{color:#fff;font-family:Oswald,sans-serif;font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin:0;text-shadow:2px 2px 6px rgba(0,0,0,.3)}.menu-container{position:relative;width:48px}.menu-button{background:#fff3;color:#fff;border:none;width:48px;height:48px;border-radius:12px;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.menu-button:hover{background:#ffffff4d;transform:scale(1.05)}.dropdown-menu{position:absolute;top:calc(100% + .5rem);left:0;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden;animation:dropdownSlide .2s ease-out;z-index:1001}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{width:100%;padding:.875rem 1.25rem;background:var(--bg-primary);border:none;text-align:left;cursor:pointer;font-size:1rem;color:var(--text-primary);transition:background .2s ease;display:flex;align-items:center;gap:.5rem}.dropdown-item:hover{background:var(--bg-secondary)}.dropdown-icon{width:18px;height:18px;flex-shrink:0;opacity:.7}.dropdown-item:hover .dropdown-icon,.logout-item .dropdown-icon{opacity:1}.dropdown-divider{height:1px;background:var(--border-primary);margin:.25rem 0}.dropdown-inventory{padding:.5rem 1.25rem .6rem}.dropdown-inv-header{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted, #666);margin-bottom:.35rem}.inv-row{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.82rem;color:var(--text-primary, #fff)}.inv-row-active{color:gold}.inv-icon{width:18px;text-align:center;flex-shrink:0;font-size:.9rem}.inv-label{flex:1;font-size:.82rem}.inv-badge{font-size:.75rem;font-weight:700;background:#667eea2e;color:#a5b4fc;border:1px solid rgba(102,126,234,.3);border-radius:10px;padding:1px 7px;min-width:22px;text-align:center}.inv-timer{font-size:.72rem;color:#ffd700b3;font-variant-numeric:tabular-nums;white-space:nowrap}.inv-empty{font-size:.75rem;color:var(--text-muted, #666);font-style:italic;padding:.1rem 0}.nav-right{display:flex;align-items:center;gap:.5rem}.nav-coins{display:inline-flex;align-items:center;gap:.3rem;background:#ffd70026;border:1px solid rgba(255,215,0,.4);border-radius:20px;padding:.3rem .7rem;cursor:pointer;transition:background .18s,transform .15s}.nav-coins:hover{background:#ffd70040;transform:translateY(-1px)}.nav-coins-icon{font-size:.85rem}.nav-coins-value{font-size:.8rem;font-weight:700;color:#b8860b}.notif-container{position:relative}.notif-btn{position:relative;background:transparent;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s;color:#fff}.notif-btn svg{width:28px;height:28px}.notif-btn:hover{transform:scale(1.12)}.notif-badge{position:absolute;top:-4px;right:-4px;background:#e53e3e;color:#fff;font-size:.65rem;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid transparent;background-clip:padding-box;line-height:1}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:var(--bg-primary);border:1.5px solid var(--border-primary);border-radius:14px;box-shadow:0 8px 32px #0000002e;overflow:hidden;z-index:1100;animation:dropdownSlide .18s ease-out}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem .7rem;border-bottom:1px solid var(--border-primary)}.notif-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.notif-count{font-size:.75rem;font-weight:700;background:#667eea1f;color:#667eea;border-radius:10px;padding:.15rem .5rem}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.75rem 1rem;color:var(--text-tertiary);font-size:.9rem}.notif-empty-icon{font-size:1.6rem;opacity:.5}.notif-list{max-height:340px;overflow-y:auto}.notif-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-primary);transition:background .15s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-secondary)}.notif-item-avatar{width:38px;height:38px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;overflow:hidden;border:1.5px solid var(--border-primary)}.notif-item-avatar img{width:100%;height:100%;object-fit:cover}.notif-item-info{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0}.notif-item-name{font-size:.88rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-text{font-size:.78rem;color:var(--text-secondary)}.notif-item-time{font-size:.7rem;color:var(--text-tertiary);margin-top:1px}.notif-read{opacity:.6}.notif-item-actions{display:flex;gap:.35rem;flex-shrink:0}.notif-accept-btn,.notif-reject-btn{width:30px;height:30px;border:none;border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.notif-accept-btn{background:#48bb7826;color:#38a169}.notif-accept-btn:hover{background:#38a169;color:#fff}.notif-reject-btn{background:#e53e3e1a;color:#e53e3e}.notif-reject-btn:hover{background:#e53e3e;color:#fff}.notif-item-system{background:var(--bg-secondary)}.notif-type-icon{font-size:1rem;flex-shrink:0}.notif-type-icon.friend_accepted{color:#38a169}.notif-type-icon.friend_rejected{font-size:.8rem;color:var(--text-tertiary)}.profile-icon{background:#fff3;color:#fff;border:none;width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;padding:0}.profile-icon:hover{background:#ffffff4d;transform:scale(1.05)}.nav-profile-img{width:44px;height:44px;object-fit:cover;border-radius:50%;display:block;flex-shrink:0}.bottom-navbar{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);box-shadow:0 -1px 0 var(--border-primary),0 -4px 12px var(--shadow-sm);display:flex;justify-content:space-around;align-items:center;padding:.5rem 0;z-index:1000;transition:background .3s ease}.bottom-nav-item{background:none;border:none;outline:none;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;padding:.5rem 1rem;gap:.25rem;transition:all .3s ease;color:var(--text-tertiary);flex:1;max-width:100px}.bottom-nav-item:focus-visible{outline:none}.bottom-nav-item:hover{transform:translateY(-2px);color:#667eea}.bottom-nav-item.active{color:#667eea}.bottom-nav-item.active .bottom-nav-icon{transform:scale(1.2)}.bottom-nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.bottom-nav-icon svg{width:24px;height:24px}.bottom-nav-label{font-size:.75rem;font-weight:600;white-space:nowrap}.bottom-nav-item.home-btn{max-width:70px;position:relative;margin-top:-18px;z-index:10;padding:0}.bottom-nav-item.home-btn .bottom-nav-icon{width:56px;height:56px;background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #667eea4d;border:3px solid white;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;color:#fff}.bottom-nav-item.home-btn .bottom-nav-icon svg{width:26px;height:26px;stroke:#fff}.bottom-nav-item.home-btn:hover .bottom-nav-icon{transform:translateY(-3px);box-shadow:0 8px 20px #667eea73}.bottom-nav-item.home-btn.active .bottom-nav-icon{transform:translateY(-2px);box-shadow:0 0 0 3px #667eead9,0 0 0 6px #667eea2e,0 8px 22px #667eea80}@media(max-width:480px){.bottom-nav-item.home-btn{margin-top:-14px}.bottom-nav-item.home-btn .bottom-nav-icon{width:48px;height:48px}.bottom-nav-item.home-btn .bottom-nav-icon svg{width:22px;height:22px}}.main-content{flex:1;width:100%;max-width:100%;margin:0;padding:.75rem 1.5rem;padding-top:calc(.75rem + 60px);padding-bottom:calc(.75rem + 90px);box-sizing:border-box;overflow-x:hidden}.main-content:has(.map-page){padding:60px 0 0!important;max-width:100%!important;width:100%!important;margin:0!important;overflow-x:hidden!important}@media(min-width:768px){.main-content{padding:1rem 1.5rem;padding-top:calc(1rem + 60px);padding-bottom:calc(1rem + 90px);width:100%;max-width:100%}.main-content:has(.map-page){padding:clamp(1.5rem,3vw,3rem)!important;padding-top:calc(clamp(1.5rem,3vw,3rem) + 60px)!important;max-width:100%!important;width:100%!important;margin:0!important}.main-content:has(.map-expanded){padding:0!important;max-width:100vw!important;width:100vw!important}}@media(min-width:1440px){.main-content{width:100%;max-width:100%;margin:0;padding:1rem 1.5rem;padding-top:calc(1rem + 60px);padding-bottom:calc(1rem + 90px)}.main-content:has(.map-page){padding:clamp(1.5rem,3vw,3rem)!important;padding-top:calc(clamp(1.5rem,3vw,3rem) + 60px)!important;max-width:100%!important;width:100%!important;margin:0!important}.main-content:has(.map-expanded){padding:0!important;max-width:100vw!important;width:100vw!important}}@media(min-width:1920px){.main-content{width:100%;max-width:100%}.main-content:has(.map-page){max-width:100vw!important;width:100vw!important;padding:0!important;margin:0!important}}.page-content{animation:fadeIn .3s ease-in;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden;display:flex;flex-direction:column;flex:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-content h2{color:#fff;font-size:clamp(1.5rem,5vw,2.5rem);margin-top:0;margin-bottom:clamp(.75rem,2vw,1.25rem);text-shadow:2px 2px 4px rgba(0,0,0,.2);width:100%}@media(min-width:768px){.page-content h2{font-size:clamp(2rem,4vw,3rem)}}.workout-form{background:var(--bg-secondary);padding:clamp(1.25rem,4vw,2rem);border-radius:clamp(8px,1.5vw,12px);margin-bottom:clamp(1.5rem,3vw,2rem);width:100%;box-sizing:border-box}.workout-form h2{margin-top:0;color:var(--text-primary);font-size:clamp(1.25rem,3vw,1.75rem)}.workout-form input{width:100%;padding:clamp(.65rem,2vw,.85rem);margin-bottom:1rem;border:2px solid #ddd;border-radius:clamp(4px,1vw,6px);font-size:clamp(.9rem,2vw,1rem);box-sizing:border-box}.workout-form input:focus{outline:none;border-color:#4a90e2}.workout-form button{width:100%;padding:clamp(.75rem,2.5vw,1rem);background:#4a90e2;color:#fff;border:none;border-radius:clamp(4px,1vw,6px);font-size:clamp(.95rem,2vw,1.1rem);cursor:pointer;font-weight:700;transition:background .3s ease}.workout-form button:hover{background:#357abd}.workout-list h2{color:var(--text-primary);margin-bottom:clamp(.75rem,2vw,1rem);font-size:clamp(1.25rem,3vw,1.75rem)}.workout-item{display:flex;flex-direction:column;gap:.75rem;background:var(--bg-primary);padding:clamp(1rem,3vw,1.5rem);margin-bottom:clamp(.75rem,2vw,1rem);border-radius:clamp(8px,1.5vw,12px);border:1px solid var(--border-primary);box-shadow:0 2px 4px #0000001a;box-sizing:border-box}@media(min-width:600px){.workout-item{flex-direction:row;justify-content:space-between;align-items:center}}.workout-info h3{margin:0 0 .5rem;color:var(--text-primary);font-size:clamp(1rem,2.5vw,1.25rem)}.workout-info p{margin:0;color:var(--text-secondary);font-size:clamp(.9rem,2vw,1rem)}.workout-info small{color:var(--text-tertiary);font-size:clamp(.8rem,1.8vw,.9rem)}.delete-btn{padding:clamp(.5rem,2vw,.65rem) clamp(.85rem,2.5vw,1.25rem);background:#e74c3c;color:#fff;border:none;border-radius:clamp(4px,1vw,6px);cursor:pointer;font-weight:700;font-size:clamp(.85rem,2vw,1rem);transition:background .3s ease;align-self:flex-start}@media(min-width:600px){.delete-btn{align-self:center}}.delete-btn:hover{background:#c0392b}.page-content.map-page{padding:0!important;margin:0!important;width:100%!important;max-width:100%!important;min-height:calc(100vh - 165px);display:flex;flex-direction:column;position:relative;overflow-x:hidden}.map-mode-toggle{display:flex;gap:.5rem;padding:.75rem 1.5rem 0;flex-shrink:0}.map-mode-btn{flex:1;padding:.55rem 1rem;border-radius:10px;border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-secondary);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.map-mode-btn.active{background:#667eea;color:#fff;border-color:#667eea}.map-mode-btn:not(.active):hover{background:var(--bg-tertiary);color:var(--text-primary)}.map-page-layout{display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1.25rem);width:100%;height:auto;padding:.75rem 1.5rem 1rem;box-sizing:border-box}.page-content.map-page.map-expanded .map-page-layout{padding:0;gap:0}.map-section{flex:0 0 auto;height:clamp(260px,42vh,500px);display:flex;flex-direction:column;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px #00000026;transition:all .3s ease}.map-section.expanded{position:fixed;inset:85px 0 80px;flex:none;width:100vw;height:calc(100vh - 165px);border-radius:0;z-index:100}.map-section-header{display:flex;justify-content:space-between;align-items:center;padding:clamp(.75rem,2vw,1.25rem);background:linear-gradient(135deg,#667eea,#e74c3c);border-bottom:2px solid rgba(255,255,255,.1)}.map-section-header h3{color:#fff;margin:0;font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:600}.expand-btn{background:#fff3;color:#fff;border:none;padding:clamp(.5rem,1.5vw,.75rem) clamp(.75rem,2vw,1rem);border-radius:8px;cursor:pointer;font-size:clamp(.85rem,1.8vw,1rem);font-weight:600;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.expand-btn:hover{background:#ffffff4d;transform:scale(1.05)}.map-container-small{flex:1;width:100%;height:100%;overflow:hidden;position:relative}.routes-section{flex:1;min-height:300px;overflow-y:auto;overflow-x:hidden;background:#fff;border-radius:16px;box-shadow:0 8px 24px #00000026}.page-content.map-page h2{position:absolute;top:1rem;left:50%;transform:translate(-50%);z-index:10;background:#fffffff2;padding:clamp(.5rem,2vw,.75rem) clamp(1rem,3vw,2rem);border-radius:12px;box-shadow:0 4px 12px #00000026;margin:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:none}.map-container{width:100%;height:100%;flex:1;border-radius:0;overflow:hidden;box-shadow:none;background:#fff;box-sizing:border-box}@media(max-width:768px){.page-content.map-page{min-height:calc(100vh - 140px)!important;width:100%!important;max-width:100%!important}.map-page-layout{gap:.75rem;padding:.75rem 1.5rem}.page-content.map-page.map-expanded .map-page-layout{padding:0;gap:0}.map-section{height:clamp(240px,38vh,360px)}.map-section.expanded{top:70px;bottom:70px;height:calc(100vh - 140px);position:fixed;overflow-y:auto}.routes-section{min-height:260px}.page-content.map-page h2{font-size:clamp(1.25rem,4vw,1.5rem);padding:.5rem 1rem}}@media(min-width:769px){.page-content.map-page{min-height:calc(100vh - 165px)!important;width:100%!important;max-width:100%!important}.map-section.expanded{top:85px;bottom:80px;height:calc(100vh - 165px);position:fixed;overflow-y:auto}}@media(min-width:1440px){.page-content.map-page{min-height:calc(100vh - 181px)!important;width:100%!important;max-width:100%!important}.map-section.expanded{top:101px;bottom:80px;height:calc(100vh - 181px);position:fixed;overflow-y:auto}.map-section{height:clamp(320px,46vh,560px)}}@media(min-width:1920px){.page-content.map-page{min-height:calc(100vh - 197px)!important;width:100%!important;max-width:100%!important}.map-section.expanded{top:117px;bottom:80px;height:calc(100vh - 197px);position:fixed;overflow-y:auto}.map-section{height:clamp(380px,50vh,650px)}}.placeholder-card{background:#fff;padding:clamp(1.5rem,5vw,3rem);border-radius:clamp(12px,2vw,16px);box-shadow:0 8px 24px #00000026;text-align:center;height:calc(100vh - 165px - clamp(1.5rem,4vw,4rem));display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:100%;box-sizing:border-box}@media(max-width:768px){.placeholder-card{height:calc(100vh - 140px - clamp(3rem,5vw,4rem))}}@media(min-width:769px){.placeholder-card{height:calc(100vh - 165px - clamp(3rem,6vw,6rem))}}@media(min-width:1440px){.placeholder-card{height:calc(100vh - 181px - 4rem)}}@media(min-width:1920px){.placeholder-card{height:calc(100vh - 197px - 4rem)}}.placeholder-card p{color:var(--text-secondary);font-size:clamp(.95rem,2.5vw,1.2rem);margin:.5rem 0;max-width:90%}@media(min-width:768px){.placeholder-card p{font-size:clamp(1.1rem,1.8vw,1.4rem)}}.coming-soon{color:#667eea!important;font-weight:700;font-size:clamp(1.1rem,3vw,1.5rem)!important;margin-top:1rem!important}@media(min-width:768px){.coming-soon{font-size:clamp(1.4rem,2.5vw,1.8rem)!important}}.challenges-grid{display:grid;grid-template-columns:1fr;gap:clamp(1rem,3vw,2rem);margin-bottom:clamp(1rem,3vw,2rem);width:100%}@media(min-width:768px){.challenges-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(1.5rem,2.5vw,2.5rem)}}@media(min-width:1024px){.challenges-grid{grid-template-columns:repeat(2,1fr);gap:clamp(2rem,3vw,3rem)}}.challenge-section{background:transparent;padding:0;border-radius:0;box-shadow:none;width:100%;box-sizing:border-box;margin-bottom:clamp(1rem,2.5vw,1.5rem)}.challenge-section h3{color:#667eea;font-size:clamp(1.15rem,3.5vw,1.5rem);margin-top:0;margin-bottom:clamp(.75rem,2.5vw,1.5rem);font-weight:700}@media(min-width:768px){.challenge-section h3{font-size:clamp(1.35rem,2.5vw,1.75rem)}}.leaderboard-section{background:transparent;padding:0;border-radius:0;box-shadow:none;width:100%;box-sizing:border-box}.progress-bar{width:100%;height:clamp(20px,3vw,28px);background:#e0e0e0;border-radius:clamp(8px,1.5vw,12px);overflow:hidden;margin:clamp(.75rem,2.5vw,1.5rem) 0}@media(min-width:768px){.progress-bar{height:clamp(22px,2.5vw,26px)}}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#e74c3c);transition:width .3s ease}@media(max-width:480px){.top-navbar{padding:.5rem 1rem}.brand-title h1{font-size:clamp(1rem,5vw,1.15rem)}.menu-button,.profile-icon{width:38px;height:38px;font-size:1.2rem}.menu-container{width:38px}.dropdown-menu{min-width:180px;font-size:.9rem}.dropdown-item{padding:.75rem 1rem;font-size:.9rem}.bottom-nav-item{padding:.4rem .25rem}.bottom-nav-icon,.bottom-nav-icon svg{width:20px;height:20px}.bottom-nav-label{font-size:.65rem}}@media(min-width:481px)and (max-width:767px){.top-navbar{padding:.5rem 1.25rem}.brand-title h1{font-size:clamp(1.2rem,4vw,1.4rem)}.menu-button,.profile-icon{width:44px;height:44px;font-size:1.35rem}.menu-container{width:44px}.bottom-nav-icon,.bottom-nav-icon svg{width:22px;height:22px}.bottom-nav-label{font-size:.7rem}}@media(min-width:768px)and (max-width:1023px){.top-navbar{padding:.5rem 1.5rem}.brand-title h1{font-size:clamp(1.4rem,3vw,1.75rem)}.menu-button,.profile-icon{width:48px;height:48px;font-size:1.5rem}.bottom-nav-icon,.bottom-nav-icon svg{width:24px;height:24px}.bottom-nav-label{font-size:.75rem}}@media(min-width:1024px)and (max-width:1439px){.top-navbar{padding:.65rem 2rem}.brand-title h1{font-size:clamp(1.65rem,2.5vw,1.85rem)}.bottom-nav-icon,.bottom-nav-icon svg{width:24px;height:24px}.bottom-nav-label{font-size:.8rem}}@media(min-width:1440px)and (max-width:1919px){.top-navbar{padding:.75rem 3rem}.brand-title h1{font-size:2rem}.bottom-nav-icon,.bottom-nav-icon svg{width:26px;height:26px}.bottom-nav-label{font-size:.875rem}.menu-button,.profile-icon{width:52px;height:52px;font-size:1.6rem}}@media(min-width:1920px){.top-navbar{padding:.85rem 4rem}.brand-title h1{font-size:2.25rem}.bottom-nav-icon,.bottom-nav-icon svg{width:28px;height:28px}.bottom-nav-label{font-size:1rem}.menu-button,.profile-icon{width:56px;height:56px;font-size:1.75rem}.dropdown-menu{min-width:240px}.dropdown-item{padding:1rem 1.5rem;font-size:1.1rem}}@media(max-height:600px)and (orientation:landscape){.placeholder-card{min-height:200px}.main-content{padding-bottom:calc(clamp(.5rem,2vw,1rem) + 80px)}}.dropdown-user-info{padding:1rem 1.25rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;font-weight:600}.dropdown-user-info p{margin:0;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-item{color:#667eea;font-weight:600}.admin-item:hover{background:#667eea14;color:#5a67d8}.logout-item{color:#e53e3e;font-weight:600}.logout-item:hover{background:#e53e3e14;color:#c53030}.add-gym-section{margin-top:clamp(1rem,2vw,1.5rem);width:100%;padding:0 1.5rem calc(1.5rem + 90px);box-sizing:border-box}.add-gym-toggle-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;border:none;border-radius:12px;font-size:clamp(1rem,2.5vw,1.1rem);font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea66;display:flex;align-items:center;justify-content:center;gap:.5rem}.add-gym-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.gym-submission-wrapper{margin-top:1.5rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.streak-aura-1{box-shadow:0 0 0 3px #fbbf24b3,0 0 12px #fbbf2466!important}.streak-aura-2{box-shadow:0 0 0 3px #60a5fa,0 0 16px #60a5fa8c!important}.streak-aura-3{box-shadow:0 0 0 3px #a78bfa,0 0 20px #a78bfaa6!important}.streak-aura-4{animation:aura-gold-pulse 1.8s ease-in-out infinite}.streak-aura-5{animation:aura-rainbow 3s linear infinite}@keyframes aura-gold-pulse{0%,to{box-shadow:0 0 0 3px #f59e0b,0 0 18px #f59e0b99}50%{box-shadow:0 0 0 5px #f59e0b,0 0 32px #f59e0bf2}}@keyframes aura-rainbow{0%{box-shadow:0 0 0 3px #f87171,0 0 22px #f87171bf}20%{box-shadow:0 0 0 3px #fb923c,0 0 22px #fb923cbf}40%{box-shadow:0 0 0 3px #facc15,0 0 22px #facc15bf}60%{box-shadow:0 0 0 3px #4ade80,0 0 22px #4ade80bf}80%{box-shadow:0 0 0 3px #60a5fa,0 0 22px #60a5fabf}to{box-shadow:0 0 0 3px #f87171,0 0 22px #f87171bf}}.guest-prompt-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1.5rem;animation:gpFadeIn .18s ease}@keyframes gpFadeIn{0%{opacity:0}to{opacity:1}}.guest-prompt-card{background:var(--bg-primary);border-radius:20px;padding:2rem 1.75rem 1.5rem;max-width:360px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:gpSlideUp .2s ease}@keyframes gpSlideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.guest-prompt-icon{font-size:2.5rem;margin-bottom:.75rem}.guest-prompt-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin:0 0 .6rem}.guest-prompt-body{font-size:.92rem;color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.5}.guest-prompt-perks{display:flex;flex-direction:column;gap:.3rem;margin:0 0 1.25rem;text-align:left}.guest-prompt-perks span{font-size:.85rem;color:var(--text-secondary)}.guest-prompt-actions{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.85rem}.guest-prompt-signup{padding:.8rem;border:none;border-radius:12px;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .2s}.guest-prompt-signup:hover{opacity:.9;transform:translateY(-1px)}.guest-prompt-login{padding:.75rem;border:2px solid var(--border-primary);border-radius:12px;background:transparent;color:var(--text-primary);font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .2s,background .2s}.guest-prompt-login:hover{border-color:#667eea;background:var(--bg-secondary)}.guest-prompt-dismiss{background:none;border:none;color:var(--text-tertiary);font-size:.85rem;cursor:pointer;padding:.25rem;transition:color .2s}.guest-prompt-dismiss:hover{color:var(--text-secondary)}.srp-overlay{position:fixed;inset:0;background:#000000bf;z-index:9100;display:flex;align-items:center;justify-content:center;padding:1rem}.srp-card{position:relative;border-radius:22px;padding:2rem 1.75rem 1.5rem;text-align:center;max-width:300px;width:100%;animation:srp-pop .45s cubic-bezier(.34,1.56,.64,1) both;isolation:isolate}@keyframes srp-pop{0%{transform:scale(.65) translateY(24px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.srp-emoji{font-size:2.8rem;line-height:1;margin-bottom:.5rem}.srp-title{font-size:1.45rem;font-weight:900;letter-spacing:.03em;margin-bottom:.9rem;line-height:1.1}.srp-rank-row{display:flex;align-items:baseline;justify-content:center;gap:.4rem;margin-bottom:.7rem}.srp-rank-num{font-size:2.6rem;font-weight:900;line-height:1}.srp-rank-of{font-size:.88rem;opacity:.65}.srp-top-badge{display:inline-block;border-radius:20px;padding:.28rem .9rem;font-size:.82rem;font-weight:800;letter-spacing:.04em;margin-bottom:.6rem}.srp-pr-badge{display:inline-block;border-radius:20px;padding:.28rem .9rem;font-size:.82rem;font-weight:800;letter-spacing:.03em;margin-bottom:.5rem;background:#f5a6232e;color:#ffc840;border:1px solid rgba(245,166,35,.4)}.srp-early-note{font-size:.7rem;opacity:.5;margin-top:-.3rem;margin-bottom:.5rem}.srp-sub{font-size:.84rem;opacity:.72;line-height:1.45;margin-bottom:1.4rem}.srp-close-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:inherit;border-radius:12px;padding:.55rem 1.5rem;font-size:.9rem;font-weight:700;cursor:pointer;transition:background .15s}.srp-close-btn:hover{background:#ffffff38}.srp-tier-0{background:linear-gradient(145deg,#242424,#181818);color:#d4d4d4;border:1px solid rgba(255,255,255,.08);box-shadow:0 16px 48px #0000008c}.srp-tier-0 .srp-top-badge{background:#ffffff14;color:#888}.srp-tier-0 .srp-rank-num{color:#e0e0e0}.srp-tier-1{background:linear-gradient(145deg,#0c1a38,#142248);color:#b8d4ff;border:1px solid rgba(80,140,255,.28);box-shadow:0 0 32px #3c78ff33,0 16px 48px #0000008c}.srp-tier-1 .srp-top-badge{background:#3c78ff2e;color:#7ab0ff;border:1px solid rgba(60,120,255,.3)}.srp-tier-1 .srp-rank-num{color:#90c0ff}.srp-tier-2{background:linear-gradient(145deg,#081a0e,#0e2814);color:#90f0b0;border:1px solid rgba(40,190,80,.3);box-shadow:0 0 44px #1eaa4638,0 16px 48px #0000008c}.srp-tier-2 .srp-top-badge{background:#1eaa462e;color:#50d880;border:1px solid rgba(30,170,70,.3)}.srp-tier-2 .srp-rank-num{color:#60e890}.srp-tier-3{background:linear-gradient(145deg,#180e00,#261600);color:#ffe060;border:1px solid rgba(220,160,0,.38);box-shadow:0 0 52px #d2960047,0 16px 48px #0000008c;animation:srp-pop .45s cubic-bezier(.34,1.56,.64,1) both,srp-gold-pulse 3s ease-in-out .5s infinite}.srp-tier-3 .srp-top-badge{background:#d2960033;color:#ffc830;border:1px solid rgba(210,150,0,.38)}.srp-tier-3 .srp-rank-num{color:#ffd040}@keyframes srp-gold-pulse{0%,to{box-shadow:0 0 52px #d2960047,0 16px 48px #0000008c}50%{box-shadow:0 0 80px #d2960085,0 16px 48px #0000008c}}.srp-tier-4{background:linear-gradient(145deg,#180700,#2c1000);color:#ffbb60;border:2px solid transparent;box-shadow:0 0 65px #ff640061,0 16px 48px #0000008c;animation:srp-pop .45s cubic-bezier(.34,1.56,.64,1) both,srp-amber-pulse 2.2s ease-in-out .5s infinite}.srp-tier-4:before{content:"";position:absolute;inset:-2px;border-radius:24px;background:linear-gradient(90deg,#ff6000,#ffb000,#ff8000,#ff6000);background-size:300% 100%;animation:srp-shift 2s linear infinite;z-index:-1}.srp-tier-4 .srp-top-badge{background:#ff640038;color:#ff8830;border:1px solid rgba(255,100,0,.42)}.srp-tier-4 .srp-rank-num{color:#ffaa40}@keyframes srp-amber-pulse{0%,to{box-shadow:0 0 65px #ff640061,0 16px 48px #0000008c}50%{box-shadow:0 0 100px #ff6400a6,0 16px 48px #0000008c}}@keyframes srp-shift{0%{background-position:0% 50%}to{background-position:300% 50%}}.srp-tier-5{background:linear-gradient(145deg,#0e001e,#180030);color:#d8b0ff;border:2px solid transparent;box-shadow:0 0 80px #963cff7a,0 16px 48px #0000008c;animation:srp-pop .45s cubic-bezier(.34,1.56,.64,1) both,srp-violet-pulse 2s ease-in-out .5s infinite}.srp-tier-5:before{content:"";position:absolute;inset:-2px;border-radius:24px;background:linear-gradient(90deg,#7000ff,#ff00c0,#4040ff,#ff00c0,#7000ff);background-size:400% 100%;animation:srp-shift 1.8s linear infinite;z-index:-1}.srp-tier-5 .srp-top-badge{background:#7800ff38;color:#b060ff;border:1px solid rgba(150,60,255,.4)}.srp-tier-5 .srp-rank-num{color:#c080ff}.srp-tier-5 .srp-title{text-shadow:0 0 18px rgba(180,80,255,.7)}.srp-sparkles{position:absolute;inset:0;border-radius:22px;pointer-events:none;overflow:visible}.srp-sparkles:before,.srp-sparkles:after{position:absolute;font-size:1.1rem;animation:srp-float 2.8s ease-in-out infinite}.srp-sparkles:before{content:"✦";top:12%;left:6%;color:#c060ff;animation-delay:0s}.srp-sparkles:after{content:"✦";top:8%;right:8%;color:#ff60c0;animation-delay:1.2s}@keyframes srp-violet-pulse{0%,to{box-shadow:0 0 80px #963cff7a,0 16px 48px #0000008c}50%{box-shadow:0 0 120px #963cffbf,0 16px 48px #0000008c}}@keyframes srp-float{0%,to{transform:translateY(0) rotate(0) scale(1);opacity:.55}50%{transform:translateY(-10px) rotate(22deg) scale(1.2);opacity:1}}.srp-tier-6{background:radial-gradient(ellipse at 38% 32%,#0d1240,#06081e,#020308);color:#c8dcff;border:2px solid transparent;box-shadow:0 0 90px #2850dc80,0 0 50px #5028b447,0 16px 48px #000000b3;animation:srp-pop .45s cubic-bezier(.34,1.56,.64,1) both,srp-cosmos-breathe 3s ease-in-out .5s infinite}.srp-tier-6:before{content:"";position:absolute;inset:-3px;border-radius:25px;background:conic-gradient(from 0deg,#0030a0,#1060e0,#60a8ff,#e8f0ff,#80b0ff,#2050c0,#0030a0);background-size:100% 100%;animation:srp-stellar-spin 4s linear infinite;z-index:-1}.srp-tier-6 .srp-title{background:linear-gradient(90deg,#e0eeff,#fff,#a8c8ff,#fff,#e0eeff);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:srp-starlight-slide 2.4s ease-in-out infinite alternate;letter-spacing:.1em;text-shadow:none}.srp-tier-6 .srp-rank-num{background:linear-gradient(135deg,#fff,#c0d8ff,#fff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 10px rgba(120,180,255,.9))}.srp-tier-6 .srp-top-badge{background:#1e46c847;color:#90c0ff;border:1px solid rgba(80,140,255,.4);text-shadow:0 0 8px rgba(120,180,255,.5)}.srp-prism-ring{position:absolute;inset:-28px;border-radius:50px;background:radial-gradient(ellipse at 50% 50%,rgba(60,100,255,.18) 0%,rgba(40,30,160,.12) 40%,rgba(10,20,80,.06) 70%,transparent 100%);opacity:1;animation:srp-nebula-drift 6s ease-in-out .5s infinite alternate;z-index:-2;filter:blur(12px)}.srp-tier-6 .srp-sparkles:before{content:"★";color:#d0e8ff;top:10%;left:7%;font-size:1.1rem}.srp-tier-6 .srp-sparkles:after{content:"★";color:#a0c4ff;top:7%;right:7%;font-size:1.3rem;animation-delay:1.4s}@keyframes srp-cosmos-breathe{0%,to{box-shadow:0 0 90px #2850dc80,0 0 50px #5028b447,0 16px 48px #000000b3}50%{box-shadow:0 0 140px #2850dccc,0 0 80px #5028b480,0 16px 48px #000000b3}}@keyframes srp-stellar-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes srp-starlight-slide{0%{background-position:0% 50%}to{background-position:300% 50%}}@keyframes srp-nebula-drift{0%{transform:scale(1) rotate(0);opacity:.9}50%{transform:scale(1.12) rotate(8deg);opacity:1}to{transform:scale(1.05) rotate(-4deg);opacity:.85}}.challenge-container{background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-md);overflow:hidden}.challenge-tabs{display:flex;background:var(--bg-tertiary);border-radius:50px;padding:4px;margin:clamp(.75rem,2vw,1rem)}.challenge-tab{flex:1;padding:clamp(.6rem,1.8vw,.8rem);background:transparent;border:none;border-radius:50px;font-size:clamp(.95rem,2vw,1.1rem);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .25s ease}.challenge-tab:hover{color:#667eea;background:#667eea1a}.challenge-tab.active{background:linear-gradient(135deg,#667eea,#e74c3c);color:var(--bg-primary);box-shadow:0 2px 8px #667eea59}.challenge-content{padding:clamp(1rem,3vw,1.5rem);text-align:center}@keyframes spin{to{transform:rotate(360deg)}}.challenge-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:clamp(1.5rem,4vw,2.5rem);color:var(--text-secondary);font-size:clamp(.95rem,2vw,1.1rem)}.challenge-loading:before{content:"";width:32px;height:32px;border:3px solid rgba(102,126,234,.2);border-top-color:#667eea;border-radius:50%;animation:spin .7s linear infinite}.challenge-empty{text-align:center;padding:clamp(1.5rem,4vw,2.5rem);color:var(--text-secondary);font-size:clamp(.95rem,2vw,1.1rem)}.challenge-header{display:flex;flex-direction:column;align-items:center;gap:.35rem;margin-bottom:clamp(.75rem,2vw,1rem);padding-bottom:clamp(.65rem,1.8vw,.85rem);border-bottom:1.5px solid rgba(102,126,234,.3);text-align:center}.challenge-header h3{margin:0;color:var(--text-primary);font-size:clamp(1.2rem,3vw,1.6rem);font-weight:800;letter-spacing:-.01em;background:linear-gradient(135deg,#667eea,#e74c3c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.challenge-date{color:var(--text-secondary);font-size:clamp(.78rem,1.8vw,.88rem);font-weight:500}.challenge-badge,.challenge-type-badge{display:inline-block;padding:.2rem .65rem;background:#667eea1f;color:#667eea;border-radius:50px;font-size:clamp(.72rem,1.6vw,.82rem);font-weight:700;text-transform:capitalize;letter-spacing:.03em;white-space:nowrap;flex-shrink:0}.challenge-details{margin-bottom:clamp(1rem,2.5vw,1.5rem);text-align:center}.challenge-description{color:var(--text-primary);line-height:1.65;margin:0 0 clamp(.75rem,2vw,1rem);font-size:clamp(.95rem,2.2vw,1.05rem);font-weight:400}.challenge-instructions{color:var(--text-secondary);line-height:1.6;margin:0 0 clamp(.75rem,2vw,1rem);font-size:clamp(.88rem,2vw,.98rem);padding:clamp(.65rem,1.8vw,.85rem) clamp(.85rem,2vw,1rem);background:var(--bg-secondary);border-radius:8px;border-left:3px solid #667eea}.challenge-meta-row{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.challenge-meta-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color, rgba(255,255,255,.1));border-radius:50px;font-size:clamp(.78rem,1.8vw,.88rem);color:var(--text-primary);font-weight:500}.challenge-meta-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#667eea}.exercise-list{margin:clamp(1rem,2.5vw,1.5rem) 0;padding:clamp(1.25rem,3vw,1.75rem);background:linear-gradient(135deg,#667eea1f,#e74c3c1f);border-radius:12px;border-left:5px solid #667eea;box-shadow:var(--shadow-sm)}.exercise-list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:clamp(.5rem,1.5vw,.75rem)}.exercise-list li{padding:clamp(.6rem,1.8vw,.85rem);background:var(--bg-primary);border-radius:8px;font-size:clamp(1.1rem,2.6vw,1.35rem);color:var(--text-primary);font-weight:500;display:flex;align-items:center;gap:clamp(.6rem,1.8vw,.85rem);transition:transform .2s ease}.exercise-list li:hover{transform:translate(4px)}.exercise-list li:before{content:"💪";font-size:clamp(1.3rem,3vw,1.6rem);flex-shrink:0}.challenge-form{background:var(--bg-secondary);padding:clamp(.85rem,2.5vw,1.15rem);border-radius:8px}.form-row{display:flex;gap:clamp(.5rem,1.5vw,.75rem);margin-bottom:clamp(.5rem,1.5vw,.75rem)}.time-input-row,.rounds-input-row{justify-content:flex-start;align-items:center}.time-input-row .gender-select,.rounds-input-row .gender-select{flex:0 0 auto;min-width:clamp(90px,15vw,110px)}.time-input-group,.rounds-input-group{display:flex;align-items:center;gap:.5rem;padding:clamp(.6rem,1.8vw,.75rem);background:var(--bg-secondary);border-radius:8px;border:2px solid var(--border-primary)}.time-input,.rounds-input{width:clamp(60px,15vw,80px);padding:clamp(.5rem,1.5vw,.65rem);border:1px solid var(--border-secondary);border-radius:6px;font-size:clamp(.95rem,2vw,1.1rem);text-align:center;background:var(--bg-primary);color:var(--text-primary)}.time-input:focus,.rounds-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.time-separator,.rounds-separator{font-size:clamp(1.2rem,2.8vw,1.5rem);font-weight:700;color:var(--text-primary)}.score-input{width:100%;padding:clamp(.6rem,1.8vw,.75rem);border:2px solid var(--border-primary);border-radius:8px;font-size:clamp(.95rem,2vw,1.1rem);background:var(--bg-secondary);color:var(--text-primary)}.challenge-form input,.challenge-form .gender-select{flex:1;padding:clamp(.55rem,2vw,.75rem);border:2px solid var(--border-secondary);border-radius:6px;font-size:clamp(.9rem,2vw,1rem);box-sizing:border-box;transition:border-color .3s ease;background:var(--bg-primary);cursor:pointer}.challenge-form input:focus,.challenge-form .gender-select:focus{outline:none;border-color:#667eea}.challenge-form .gender-select{min-width:clamp(90px,15vw,110px)}.submit-row{display:flex;align-items:center;gap:clamp(.75rem,2vw,1rem);margin-top:clamp(.5rem,1.5vw,.75rem)}.social-post-checkbox{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:clamp(.85rem,1.9vw,.95rem);color:var(--text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none}.social-post-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#667eea}.social-post-checkbox:hover{color:var(--text-primary)}.submit-btn{flex:1;padding:clamp(.65rem,2vw,.85rem);background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:50px;font-size:clamp(.95rem,2vw,1.05rem);cursor:pointer;font-weight:700;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.already-submitted-banner{background:#48bb781f;border:2px solid #48bb78;border-radius:12px;padding:1rem 1.25rem;color:#2f855a;font-weight:600;font-size:clamp(.95rem,2vw,1.05rem);text-align:center;margin-top:1rem}[data-theme=dark] .already-submitted-banner{color:#68d391}.success-message{color:#4caf50;margin-top:.5rem;font-weight:700;text-align:center;font-size:clamp(.85rem,1.8vw,.95rem)}.progress-container{margin:clamp(1rem,2.5vw,1.5rem) 0}.progress-stats{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:clamp(.75rem,2vw,1rem)}.progress-current{font-size:clamp(2rem,5vw,3rem);font-weight:700;color:#667eea}.progress-separator{font-size:clamp(1.5rem,4vw,2rem);color:var(--text-tertiary);font-weight:300}.progress-target{font-size:clamp(1.5rem,4vw,2rem);font-weight:600;color:var(--text-secondary)}.progress-label{font-size:clamp(1rem,2.5vw,1.25rem);color:var(--text-secondary);font-weight:500;margin-left:.25rem}.progress-bar-wrapper{width:100%;height:clamp(20px,3vw,28px);background:var(--bg-tertiary);border-radius:50px;overflow:hidden;margin-bottom:clamp(.5rem,1.5vw,.75rem)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#e74c3c);transition:width .5s ease;box-shadow:0 2px 8px #667eea66;border-radius:50px}.progress-percentage{text-align:center;font-size:clamp(.9rem,2vw,1.05rem);color:#667eea;font-weight:700}.weekly-tips{background:#667eea14;padding:clamp(.85rem,2.5vw,1.15rem);border-radius:8px;margin-top:clamp(1rem,2.5vw,1.5rem);border-left:4px solid #667eea}.weekly-tips h4{margin:0 0 clamp(.5rem,1.5vw,.75rem) 0;color:#667eea;font-size:clamp(1rem,2.2vw,1.15rem);font-weight:700}.weekly-tips ul{list-style:none;padding:0;margin:0}.weekly-tips li{padding:clamp(.3rem,1vw,.4rem) 0;padding-left:clamp(1rem,2.5vw,1.25rem);position:relative;font-size:clamp(.9rem,2vw,1rem);color:var(--text-primary)}.weekly-tips li:before{content:"✓";position:absolute;left:0;color:#667eea;font-weight:700}.video-inline-toggle{display:flex;align-items:center;gap:.3rem;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:clamp(.5rem,1.5vw,.65rem) clamp(.5rem,1.5vw,.65rem);background:var(--bg-secondary);border:2px solid var(--border-secondary);border-radius:6px;font-size:clamp(.85rem,2vw,.95rem);font-weight:600;color:var(--text-primary);transition:border-color .2s}.video-inline-toggle:has(input:checked){border-color:#667eea;background:#667eea14}.video-inline-toggle input[type=checkbox]{display:none}.video-xp-badge{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:.75rem;font-weight:800;padding:.15rem .55rem;border-radius:50px;letter-spacing:.03em;box-shadow:0 2px 6px #f59e0b66}.video-file-wrapper{margin-top:clamp(.6rem,1.5vw,.75rem)}.video-file-input{display:none}.video-file-label{display:inline-flex;align-items:center;gap:.4rem;padding:clamp(.5rem,1.5vw,.65rem) clamp(1rem,2.5vw,1.25rem);background:var(--bg-primary);border:2px dashed rgba(102,126,234,.5);border-radius:8px;font-size:clamp(.85rem,1.9vw,.95rem);font-weight:600;color:#667eea;cursor:pointer;transition:all .2s ease;width:100%;box-sizing:border-box;justify-content:center}.video-file-label:hover{border-color:#667eea;background:#667eea14}@media(max-width:480px){.form-row{flex-direction:column}}.battle-toast{position:fixed;top:1.25rem;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;padding:.7rem 1.25rem;border-radius:24px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:.5rem;box-shadow:0 4px 20px #00000040;z-index:9999;animation:battle-toast-in .3s ease,battle-toast-out .4s ease 3.6s forwards;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}.battle-toast-icon{font-size:1.1rem;flex-shrink:0}@keyframes battle-toast-in{0%{opacity:0;transform:translate(-50%) translateY(-14px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes battle-toast-out{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-14px)}}.challenge-actions-row{padding:0 clamp(.75rem,2vw,1rem) clamp(.5rem,1.5vw,.75rem)}.battles-trigger-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:clamp(.55rem,1.8vw,.7rem) clamp(.75rem,2vw,1rem);border:none;border-radius:8px;font-family:Oswald,sans-serif;font-size:clamp(1rem,2.5vw,1.15rem);font-weight:400;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;position:relative;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;box-shadow:0 3px 10px #667eea59;transition:all .2s ease}.battles-trigger-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px);box-shadow:0 5px 14px #667eea73}.battles-trigger-btn:disabled{opacity:.45;cursor:not-allowed}.battles-tabs{display:flex;background:var(--bg-secondary);border-radius:8px;padding:3px;margin-bottom:1rem;gap:2px}.battles-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.45rem .5rem;background:transparent;border:none;border-radius:6px;font-size:clamp(.82rem,2vw,.92rem);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.battles-tab.active{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;box-shadow:0 2px 6px #667eea4d}.battles-title{font-family:Oswald,sans-serif;letter-spacing:.06em;text-transform:uppercase}.caf-badge{display:inline-flex;align-items:center;justify-content:center;background:#e74c3c;color:#fff;font-size:.7rem;font-weight:700;border-radius:50px;min-width:18px;height:18px;padding:0 5px;margin-left:2px}.caf-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.caf-modal{background:var(--bg-primary);border-radius:16px;width:100%;max-width:420px;max-height:80vh;overflow-y:auto;padding:1.25rem;box-shadow:0 8px 32px #00000059}.caf-panel{max-width:460px}.caf-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.caf-title{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.caf-close{background:none;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:.15rem .4rem;border-radius:6px;transition:background .15s}.caf-close:hover{background:var(--bg-secondary)}.caf-sub{font-size:.85rem;color:var(--text-secondary);margin:0 0 1rem}.caf-loading,.caf-empty{text-align:center;color:var(--text-secondary);padding:1.5rem 0;font-size:.9rem}.caf-friend-list{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.5rem;max-height:320px;overflow-y:auto}.caf-friend-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem .65rem;background:var(--bg-secondary);border-radius:10px}.caf-friend-info{display:flex;align-items:center;gap:.65rem;min-width:0}.caf-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.caf-avatar-icon{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);font-size:1.1rem}.caf-friend-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.caf-send-btn{flex-shrink:0;padding:.35rem .85rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;border:none;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}.caf-send-btn:hover:not(:disabled){opacity:.85}.caf-send-btn.caf-sent{background:#27ae60}.caf-send-btn:disabled{opacity:.55;cursor:not-allowed}.caf-share-row{border-top:1px solid var(--border-color, rgba(255,255,255,.1));padding-top:.85rem}.caf-share-btn{width:100%;padding:.65rem;background:var(--bg-secondary);border:1.5px dashed var(--border-color, rgba(255,255,255,.18));border-radius:8px;color:var(--text-primary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.caf-share-btn:hover{background:var(--bg-tertiary)}.caf-share-btn.caf-copied{border-color:#27ae60;color:#27ae60}.caf-section{margin-bottom:1.1rem}.caf-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin:0 0 .5rem}.caf-challenge-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .75rem;background:var(--bg-secondary);border-radius:10px;margin-bottom:.4rem}.caf-challenge-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.caf-challenge-name{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.caf-challenge-type{font-size:.75rem;color:var(--text-secondary);text-transform:capitalize}.caf-scores{font-size:.78rem;color:var(--text-secondary)}.caf-challenge-actions{display:flex;gap:.4rem;flex-shrink:0}.caf-accept-btn,.caf-decline-btn{padding:.3rem .7rem;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s}.caf-accept-btn{background:#27ae60;color:#fff}.caf-decline-btn{background:var(--bg-tertiary);color:var(--text-secondary)}.caf-accept-btn:hover,.caf-decline-btn:hover{opacity:.8}.caf-status-badge{font-size:.75rem;font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);padding:.2rem .55rem;border-radius:50px;flex-shrink:0}.caf-result-badge{font-size:.85rem;font-weight:800;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.caf-win{background:#27ae6026;color:#27ae60}.caf-loss{background:#e74c3c1f;color:#e74c3c}.caf-completed-row .caf-challenge-info{gap:.15rem}.battle-vs-card{position:relative;border-radius:16px;padding:1rem 1rem 1.1rem;margin-bottom:.75rem;background:linear-gradient(160deg,#0f0c29,#1a1a3e,#24243e);overflow:hidden;z-index:0}.battle-vs-card:before{content:"";position:absolute;inset:-2px;border-radius:18px;background:conic-gradient(#ff6b00,gold,#ff0080,#667eea,#00d4ff,#ff6b00);animation:battle-border-spin 3s linear infinite;z-index:-1}.battle-vs-card:after{content:"";position:absolute;inset:2px;border-radius:14px;background:linear-gradient(160deg,#0f0c29,#1a1a3e,#24243e);z-index:-1}@keyframes battle-border-spin{to{filter:hue-rotate(360deg)}}.battle-vs-header{display:flex;flex-direction:column;align-items:center;gap:.15rem;margin-bottom:1rem}.battle-vs-workout{font-size:1rem;font-weight:700;color:#fff;text-align:center}.battle-vs-type{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff73}.battle-vs-arena{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.battle-vs-fighter{flex:1;display:flex;flex-direction:column;align-items:center;gap:.35rem}.battle-vs-avatar-wrap{width:54px;height:54px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.2);flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#ffffff14}.battle-vs-avatar{width:100%;height:100%;object-fit:cover}.battle-vs-avatar-placeholder{font-size:1.6rem;line-height:1}.battle-vs-name{font-size:.8rem;font-weight:700;color:#ffffffd9;text-align:center;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.battle-vs-status{font-size:.72rem;font-weight:600;padding:.2rem .5rem;border-radius:50px;text-align:center}.battle-vs-status.scored{background:#27ae6040;color:#2ecc71}.battle-vs-status.waiting{background:#ffffff14;color:#ffffff80;animation:battle-waiting-pulse 2s ease-in-out infinite}@keyframes battle-waiting-pulse{0%,to{opacity:1}50%{opacity:.45}}.battle-vs-emblem{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex-shrink:0}.battle-vs-sword{font-size:1.6rem;animation:battle-sword-pulse 1.5s ease-in-out infinite}@keyframes battle-sword-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 4px rgba(255,180,0,.6))}50%{transform:scale(1.2);filter:drop-shadow(0 0 10px rgba(255,180,0,1))}}.battle-vs-text{font-size:.75rem;font-weight:900;letter-spacing:.1em;color:#ffffff80}.battle-toast.battle-toast-clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.battle-toast.battle-toast-clickable:hover{filter:brightness(1.1)}.battle-toast-cta{font-size:.78rem;font-weight:800;opacity:.85;margin-left:.15rem;flex-shrink:0}.battle-result-card{position:relative;border-radius:16px;padding:1.1rem 1rem 1.25rem;margin-bottom:.85rem;background:linear-gradient(160deg,#0f0c29,#1a1a3e,#24243e);overflow:hidden;z-index:0}.battle-result-highlight{box-shadow:0 0 0 2px gold,0 6px 24px #ffd70040}.battle-result-dismiss{position:absolute;top:.55rem;right:.6rem;background:#ffffff1a;border:none;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;color:#ffffff8c;font-size:.7rem;cursor:pointer;transition:background .15s}.battle-result-dismiss:hover{background:#fff3;color:#fff}.battle-result-banner{text-align:center;font-family:Oswald,sans-serif;font-size:clamp(1.1rem,3.5vw,1.45rem);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.25rem;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.battle-result-workout{text-align:center;font-size:.85rem;font-weight:600;color:#ffffff80;margin-bottom:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.battle-result-arena{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.battle-result-fighter{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;position:relative}.battle-result-fighter.winner .battle-vs-avatar-wrap{border-color:gold;box-shadow:0 0 12px #ffd70080}.battle-result-fighter.loser{opacity:.55}.battle-result-crown{position:absolute;top:-18px;font-size:1.1rem;filter:drop-shadow(0 2px 4px rgba(255,215,0,.7))}.battle-result-fighter-name{font-size:.8rem;font-weight:700;color:#ffffffd9;text-align:center;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.battle-result-score{font-family:Oswald,sans-serif;font-size:clamp(1rem,3vw,1.2rem);font-weight:700;color:#fff;letter-spacing:.04em}.battle-result-fighter.winner .battle-result-score{color:gold}.battle-result-vs-sep{font-size:.75rem;font-weight:900;letter-spacing:.1em;color:#ffffff59;flex-shrink:0}.caf-tie{background:#667eea26;color:#667eea}.squad-lb-section{display:flex;flex-direction:column;gap:.75rem;padding-top:.5rem}.squad-lb-subtitle{font-size:.78rem;color:var(--text-secondary);margin:0;text-align:center}.squad-lb-list{display:flex;flex-direction:column;gap:.4rem}.squad-lb-row{display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;background:var(--bg-secondary, rgba(255,255,255,.04));border:1px solid var(--border-color, rgba(255,255,255,.06));border-radius:10px}.squad-lb-row.squad-lb-top3{background:#667eea12;border-color:#667eea33}.squad-lb-rank{font-size:1rem;min-width:2rem;text-align:center;flex-shrink:0;line-height:1}.squad-tag-pill{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.65rem;font-weight:800;letter-spacing:.05em;padding:.2rem .45rem;border-radius:6px;flex-shrink:0;min-width:2rem;text-align:center}.squad-lb-info{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.squad-lb-name{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.squad-lb-meta{font-size:.72rem;color:var(--text-secondary)}.squad-lb-xp{font-size:.82rem;font-weight:700;color:#667eea;flex-shrink:0;white-space:nowrap}.leaderboard{background:var(--bg-primary);padding:clamp(1rem,3vw,1.5rem);border-radius:12px;width:100%;max-width:100%;box-sizing:border-box;box-shadow:var(--shadow-md)}.leaderboard-header{display:flex;flex-direction:column;align-items:center;gap:.6rem;margin-bottom:clamp(.75rem,2vw,1rem);padding-bottom:clamp(.65rem,1.8vw,.85rem);border-bottom:1.5px solid rgba(102,126,234,.35);text-align:center}.leaderboard-header h2{margin:0;font-family:Oswald,Impact,Arial Narrow,sans-serif;font-size:clamp(2rem,6vw,3rem);font-weight:400;letter-spacing:.08em;text-transform:uppercase;background:linear-gradient(135deg,#667eea,#e74c3c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.leaderboard-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:clamp(.75rem,2vw,1rem);padding-bottom:clamp(.65rem,1.8vw,.85rem);border-bottom:1.5px solid rgba(102,126,234,.35)}.lb-filter-wrap{position:relative;flex-shrink:0}.lb-filter-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .85rem;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:clamp(.82rem,2vw,.92rem);font-weight:600;cursor:pointer;transition:all .2s;position:relative}.lb-filter-btn:hover{background:var(--bg-tertiary);border-color:#667eea;color:#667eea}.lb-filter-dot{width:7px;height:7px;border-radius:50%;background:#e74c3c;flex-shrink:0}.lb-filter-panel{position:absolute;top:calc(100% + .4rem);right:0;background:var(--bg-primary);border:1.5px solid var(--border-primary);border-radius:12px;box-shadow:0 8px 24px #0003;padding:.85rem;min-width:200px;z-index:200;animation:slideDown .15s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.lb-filter-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#667eea;margin:0 0 .4rem}.lb-filter-label:not(:first-child){margin-top:.75rem}.lb-filter-group{display:flex;gap:.35rem;flex-wrap:wrap}.lb-filter-option{padding:.3rem .65rem;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.lb-filter-option:hover{border-color:#667eea;color:#667eea}.lb-filter-option.active{background:linear-gradient(135deg,#667eea,#e74c3c);border-color:transparent;color:#fff}.lb-refresh-btn{width:100%;margin-top:.85rem;padding:.45rem;background:var(--bg-secondary);border:1.5px dashed var(--border-primary);border-radius:8px;color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.lb-refresh-btn:hover{background:var(--bg-tertiary);color:#667eea;border-color:#667eea}.no-scores{text-align:center;color:var(--text-secondary);padding:clamp(1.5rem,4vw,2rem);background:var(--bg-secondary);border-radius:8px;font-size:clamp(.9rem,2vw,1rem);border:2px dashed var(--border-secondary)}.podium-stage{display:flex;align-items:flex-end;justify-content:center;gap:clamp(.5rem,2vw,1rem);margin:clamp(.75rem,2vw,1.25rem) 0 clamp(1.25rem,3vw,1.75rem)}.podium-slot{display:flex;flex-direction:column;align-items:center;flex:1;max-width:140px}.podium-slot.podium-empty{opacity:0;pointer-events:none}.podium-avatar{width:clamp(40px,10vw,54px);height:clamp(40px,10vw,54px);border-radius:50%;background:linear-gradient(135deg,#667eea,#e74c3c);display:flex;align-items:center;justify-content:center;font-family:Oswald,sans-serif;font-size:clamp(1.1rem,3vw,1.4rem);font-weight:700;color:#fff;margin-bottom:.4rem;flex-shrink:0}.podium-avatar-empty{background:var(--bg-tertiary);color:var(--text-secondary);border:2px dashed var(--border-primary)}.podium-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.podium-name-empty{color:var(--text-secondary)}.podium-first .podium-avatar{width:clamp(50px,13vw,68px);height:clamp(50px,13vw,68px);font-size:clamp(1.3rem,3.5vw,1.6rem);box-shadow:0 0 0 3px gold,0 4px 16px #ffd70066}.podium-name{font-family:Oswald,sans-serif;font-size:clamp(.8rem,2.2vw,1rem);font-weight:700;letter-spacing:.04em;color:var(--text-primary);text-transform:uppercase;text-align:center;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.2rem}.podium-score{font-size:clamp(.78rem,2vw,.9rem);font-weight:600;color:#667eea;margin-bottom:.5rem}.podium-block{width:100%;display:flex;align-items:center;justify-content:center;border-radius:8px 8px 4px 4px}.podium-first .podium-block{height:clamp(70px,16vw,96px);background:linear-gradient(180deg,gold,#f0a500);box-shadow:0 -3px 12px #ffd70066}.podium-second .podium-block{height:clamp(50px,12vw,72px);background:linear-gradient(180deg,silver,#9a9a9a);box-shadow:0 -2px 8px #c0c0c04d}.podium-third .podium-block{height:clamp(36px,9vw,52px);background:linear-gradient(180deg,#cd7f32,#a0622a);box-shadow:0 -2px 8px #cd7f324d}.podium-rank-label{font-family:Oswald,sans-serif;font-size:clamp(.85rem,2.2vw,1.05rem);font-weight:700;letter-spacing:.1em;color:#0000008c}.leaderboard-list{display:flex;flex-direction:column;gap:clamp(.4rem,1.5vw,.55rem)}.leaderboard-item{display:flex;flex-direction:row;align-items:center;gap:clamp(.65rem,2vw,1rem);background:var(--bg-secondary);padding:clamp(.6rem,2vw,.85rem) clamp(.75rem,2.5vw,1rem);border-radius:8px;border:1px solid var(--border-primary);transition:transform .15s,box-shadow .15s;box-sizing:border-box}.leaderboard-item:hover{transform:translate(3px);box-shadow:0 2px 8px #0000001a}.rank{font-family:Oswald,sans-serif;font-size:clamp(.95rem,2.5vw,1.1rem);font-weight:700;letter-spacing:.03em;min-width:36px;text-align:center;color:var(--text-secondary)}.user-info{flex:1;display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-width:0}.user-name{font-weight:700;color:var(--text-primary);font-size:clamp(.88rem,2.2vw,1rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.score{color:#667eea;font-weight:700;font-size:clamp(.88rem,2vw,1rem);white-space:nowrap;flex-shrink:0}.timestamp{color:var(--text-tertiary);font-size:clamp(.72rem,1.6vw,.82rem);white-space:nowrap;flex-shrink:0}.show-more-btn{width:100%;padding:clamp(.6rem,1.8vw,.75rem);margin-top:.25rem;background:var(--bg-secondary);border:1.5px dashed var(--border-primary);border-radius:8px;color:var(--text-secondary);font-size:clamp(.82rem,2vw,.92rem);font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.02em}.show-more-btn:hover{background:var(--bg-tertiary);color:#667eea;border-color:#667eea}.map-wrapper{width:100%;height:100%;position:relative;border-radius:0;overflow:hidden}.google-map{width:100%;height:100%;border-radius:0}.map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;padding:clamp(1rem,3vw,2rem);border-radius:12px;box-shadow:var(--shadow-md);font-size:clamp(1rem,2.5vw,1.2rem);color:#667eea;font-weight:600;z-index:10}.map-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:clamp(1.5rem,4vw,3rem);text-align:center;background:var(--bg-primary);border-radius:0;z-index:5;position:relative}.map-error h3{color:#667eea;font-size:clamp(1.25rem,3vw,1.75rem);margin-bottom:1rem}.map-error p{color:var(--text-secondary);font-size:clamp(.95rem,2vw,1.1rem);margin:.5rem 0;max-width:600px}.map-error-banner{position:absolute;top:1rem;left:50%;transform:translate(-50%);background:#ffc107f2;color:var(--text-primary);padding:clamp(.5rem,2vw,.75rem) clamp(1rem,3vw,1.5rem);border-radius:8px;font-size:clamp(.85rem,2vw,1rem);font-weight:600;z-index:100;box-shadow:var(--shadow-md);max-width:90%}.custom-marker{font-size:clamp(2rem,5vw,3rem);cursor:pointer;transition:transform .2s ease}.custom-marker:hover{transform:scale(1.2)}.gym-marker{font-size:1.75rem;cursor:pointer;transition:transform .15s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.gym-marker:hover,.gym-marker.selected{transform:scale(1.25)}.map-gyms-loading{position:absolute;top:1rem;left:50%;transform:translate(-50%);background:#fffffff2;color:#667eea;font-size:.88rem;font-weight:600;padding:.5rem 1rem;border-radius:20px;box-shadow:0 2px 8px #00000026;z-index:10;white-space:nowrap}.gym-info-card{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);background:var(--bg-primary, #fff);border-radius:14px;padding:1rem 1.25rem;box-shadow:0 4px 20px #0000002e;z-index:20;min-width:220px;max-width:320px;width:max-content}.gym-info-close{position:absolute;top:.6rem;right:.6rem;background:none;border:none;font-size:.9rem;color:var(--text-secondary, #666);cursor:pointer;line-height:1;padding:.15rem .3rem}.gym-info-name{font-size:.95rem;font-weight:700;color:var(--text-primary, #1a1a1a);margin-bottom:.3rem;padding-right:1.5rem}.gym-info-address{font-size:.8rem;color:var(--text-secondary, #666);margin-bottom:.3rem}.gym-info-rating{font-size:.82rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:.25rem}.gym-info-rating-count{font-weight:400;color:var(--text-secondary, #666)}.gym-info-hours{font-size:.78rem;font-weight:600}.gym-info-hours.open{color:#22c55e}.gym-info-hours.closed{color:#ef4444}@media(max-width:768px){.map-wrapper,.google-map{border-radius:0}}.gym-routes-container{padding:clamp(1rem,3vw,2rem);padding-bottom:clamp(1.5rem,4vw,2.5rem);width:100%;box-sizing:border-box}.routes-header{margin-bottom:clamp(1.5rem,3vw,2.5rem);display:flex;flex-direction:column;align-items:center}.routes-header-top{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:clamp(1rem,2.5vw,1.5rem)}.routes-header h2{font-size:clamp(1.4rem,3.5vw,2rem);color:#667eea;margin:0;font-weight:700;text-align:center}.content-mode-toggle{display:flex;gap:.35rem;background:var(--bg-secondary);border-radius:10px;padding:.25rem;border:1px solid var(--border-primary)}.content-mode-btn{padding:.35rem .85rem;border-radius:7px;border:none;background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.content-mode-btn.active{background:#667eea;color:#fff}.content-mode-btn:not(.active):hover{background:var(--bg-tertiary);color:var(--text-primary)}.gyms-flat-list{display:flex;flex-direction:column;gap:.6rem}.gym-flat-card{display:flex;align-items:stretch;background:var(--bg-secondary);border-radius:12px;overflow:hidden;cursor:pointer;transition:background .15s,transform .15s;border:1px solid var(--border-primary)}.gym-flat-card:hover{background:var(--bg-tertiary);transform:translateY(-1px)}.gym-flat-card.gym-flat-done{opacity:.75}.gym-flat-accent{width:4px;flex-shrink:0}.gym-flat-body{flex:1;padding:.7rem .9rem;display:flex;flex-direction:column;gap:.2rem}.gym-flat-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.gym-flat-name{font-size:.92rem;font-weight:700;color:var(--text-primary)}.gym-flat-check{font-size:.8rem;font-weight:700;color:#22c55e;background:#22c55e1f;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gym-flat-route{font-size:.75rem;font-weight:600}.gym-flat-challenge{font-size:.78rem;color:var(--text-secondary);line-height:1.4}.theme-dropdown{position:relative;display:inline-block;margin:0 auto}.theme-dropdown-trigger{display:inline-flex;align-items:center;gap:.55rem;padding:.7rem 1.1rem .7rem .85rem;background:var(--bg-primary);border:2px solid var(--td-color, #667eea);border-radius:14px;cursor:pointer;font-size:.97rem;font-weight:700;color:var(--text-primary);transition:box-shadow .2s,border-color .2s,background .2s;box-shadow:0 2px 8px #00000012;min-width:200px;-webkit-user-select:none;user-select:none}.theme-dropdown-trigger:hover,.theme-dropdown-trigger.open{box-shadow:0 4px 16px #00000021;background:var(--bg-secondary)}.td-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.td-icon{font-size:1.2rem;line-height:1;flex-shrink:0}.td-label{flex:1;text-align:left;font-size:.95rem}.td-count{background:#667eea1f;color:#667eea;border-radius:20px;padding:.1rem .5rem;font-size:.75rem;font-weight:700;flex-shrink:0}.td-chevron{width:16px;height:16px;color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.td-chevron.open{transform:rotate(180deg)}.theme-dropdown-menu{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);min-width:240px;background:var(--bg-primary);border:1.5px solid var(--border-primary);border-radius:14px;box-shadow:0 8px 32px #00000026,0 2px 8px #00000014;overflow:hidden;z-index:200;animation:tdMenuIn .15s ease}@keyframes tdMenuIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.theme-dropdown-item{display:flex;align-items:center;gap:.65rem;width:100%;padding:.7rem 1rem;border:none;background:transparent;cursor:pointer;font-size:.93rem;font-weight:600;color:var(--text-primary);text-align:left;transition:background .15s;position:relative}.theme-dropdown-item:hover{background:var(--bg-secondary)}.theme-dropdown-item.active{background:#667eea14}.theme-dropdown-item+.theme-dropdown-item{border-top:1px solid var(--border-primary)}.tdi-accent{width:4px;height:28px;border-radius:2px;flex-shrink:0;opacity:.75}.theme-dropdown-item.active .tdi-accent{opacity:1}.tdi-icon{font-size:1.15rem;line-height:1;width:24px;text-align:center;flex-shrink:0}.tdi-name{flex:1}.tdi-count{font-size:.75rem;font-weight:700;color:var(--text-tertiary);background:var(--bg-secondary);border-radius:20px;padding:.1rem .45rem;flex-shrink:0}.theme-dropdown-item.active .tdi-count{background:#667eea26;color:#667eea}.tdi-check{width:14px;height:14px;color:var(--td-color);flex-shrink:0}.routes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr));gap:clamp(1rem,2.5vw,1.5rem);width:100%}.route-card{background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.route-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.route-card.route-completed{background:linear-gradient(160deg,#f6c90e0f,#ffd70008);box-shadow:0 4px 24px #f6c90e2e,var(--shadow-lg);border:1.5px solid rgba(246,201,14,.35)}.route-card.route-completed:hover{box-shadow:0 8px 32px #f6c90e47,var(--shadow-lg);transform:translateY(-4px)}.completed-banner{display:flex;align-items:center;gap:.5rem;padding:.55rem 1.25rem;background:linear-gradient(135deg,#f6c90e,#f09819);color:#1a1200;font-weight:700}.completed-banner-icon{font-size:1rem}.completed-banner-text{font-size:.88rem;font-weight:800;letter-spacing:.4px;flex:1}.completed-banner-badge{font-size:1.1rem}.route-icon-completed{color:#1a1200;font-size:clamp(1.4rem,3.5vw,2rem)!important;font-weight:900;box-shadow:0 0 0 3px #f6c90e66,0 0 16px #f6c90e4d}.route-name-completed{background:linear-gradient(135deg,#c8920a,#e6a817);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=dark] .route-name-completed{background:linear-gradient(135deg,#f6c90e,gold);-webkit-background-clip:text;background-clip:text}.progress-text-completed{color:#c8920a;font-weight:700}[data-theme=dark] .progress-text-completed{color:#f6c90e}.route-card.locked-route{opacity:.8;background:var(--bg-secondary)}.route-card.locked-route:hover{transform:none;box-shadow:var(--shadow-lg);cursor:not-allowed}.route-card.route-just-unlocked{animation:unlockPulse .6s ease forwards;position:relative}@keyframes unlockPulse{0%{box-shadow:0 0 #667eeab3}40%{box-shadow:0 0 0 14px #667eea40}to{box-shadow:0 0 #667eea00}}.unlock-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;animation:unlockSlideIn .4s ease,unlockFadeOut .5s ease 3s forwards;overflow:hidden}@keyframes unlockSlideIn{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:60px;padding-top:.55rem;padding-bottom:.55rem}}@keyframes unlockFadeOut{0%{opacity:1;max-height:60px;padding-top:.55rem;padding-bottom:.55rem}to{opacity:0;max-height:0;padding-top:0;padding-bottom:0}}.unlock-banner-icon{font-size:1.1rem}.unlock-banner-text{font-size:.9rem;font-weight:700;letter-spacing:.3px}.locked-text{color:var(--text-tertiary);font-size:.85em;font-weight:500}.locked-message{color:var(--text-secondary);font-size:clamp(.85rem,1.8vw,.95rem);font-style:italic;margin-top:.5rem}.route-card-header{padding:clamp(1.25rem,3vw,1.75rem);display:flex;align-items:center;gap:clamp(1rem,2vw,1.5rem);cursor:pointer;border-left:4px solid;transition:background-color .2s ease}.route-card-header:hover{background-color:var(--bg-secondary)}.route-icon{width:clamp(3rem,8vw,4rem);height:clamp(3rem,8vw,4rem);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:clamp(1.75rem,4vw,2.5rem);flex-shrink:0}.route-info{flex:1;min-width:0}.route-info h3{font-size:clamp(1.1rem,2.5vw,1.4rem);color:var(--text-primary);margin:0 0 .4rem;font-weight:600}.route-remote-chip{display:inline-block;font-size:.75rem;font-weight:600;color:#e74c3c;background:#e74c3c1f;border:1px solid rgba(231,76,60,.3);border-radius:50px;padding:.15rem .55rem;margin-bottom:.5rem;letter-spacing:.3px}.route-progress{display:flex;flex-direction:column;gap:.5rem}.progress-bar{height:8px;background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;transition:width .3s ease;border-radius:4px}.progress-text{font-size:clamp(.85rem,1.8vw,1rem);color:var(--text-secondary);font-weight:500}.route-badge{font-size:clamp(1.75rem,4vw,2.5rem);flex-shrink:0}.badge-earned{display:block;animation:bounce 1s ease infinite}.badge-locked{opacity:.3}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.route-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.route-modal{background:var(--bg-primary);border-radius:16px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;padding:clamp(1.25rem,3vw,1.75rem);position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .25s ease}.route-modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg-secondary);border:none;border-radius:50%;width:2rem;height:2rem;font-size:1rem;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:background .2s}.route-modal-close:hover{background:var(--border-primary)}.route-modal-header{display:flex;align-items:center;gap:1rem;border-left:4px solid;padding-left:1rem;margin-bottom:1.25rem}.route-modal-icon{width:3rem;height:3rem;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.route-modal-header h2{font-size:clamp(1.1rem,3vw,1.4rem);color:var(--text-primary);margin:0 0 .2rem}.route-modal-header p{font-size:.9rem;color:var(--text-secondary);margin:0}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.gyms-list{margin:clamp(1rem,2.5vw,1.5rem) 0;display:flex;flex-direction:column;gap:.75rem}.gym-item{display:flex;align-items:center;gap:1rem;padding:clamp(.75rem,2vw,1rem);background:var(--bg-primary);border-radius:8px;border:2px solid transparent;transition:all .2s ease}.gym-item:hover{border-color:#667eea;transform:translate(4px);cursor:pointer}.gym-item.completed{background-color:#48bb781a;border-color:#68d391}.gym-number{width:clamp(1.75rem,4vw,2rem);height:clamp(1.75rem,4vw,2rem);border-radius:50%;background-color:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:clamp(.85rem,1.8vw,1rem);flex-shrink:0}.gym-item.completed .gym-number{background-color:#48bb78}.gym-name{flex:1;font-size:clamp(.95rem,2vw,1.1rem);color:var(--text-primary);font-weight:500}.gym-check{color:#48bb78;font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700}.start-route-btn{width:100%;padding:clamp(.85rem,2vw,1rem);border:none;border-radius:8px;color:var(--bg-primary);font-size:clamp(1rem,2.2vw,1.15rem);font-weight:600;cursor:pointer;transition:transform .2s ease,opacity .2s ease;margin-bottom:clamp(.5rem,1.5vw,1rem)}.start-route-btn:hover{opacity:.9;transform:translateY(-2px)}.start-route-btn:active{transform:translateY(0)}@media(max-width:768px){.routes-grid{grid-template-columns:1fr}.route-card-header{flex-wrap:wrap}.route-badge{order:-1;margin-left:auto}.theme-selector{gap:.5rem;padding:.75rem}.theme-button{padding:.6rem 1rem;font-size:.85rem}.theme-icon{font-size:1.1rem}}@media(max-width:480px){.gym-routes-container{padding:clamp(.75rem,2vw,1rem)}.route-info h3{font-size:clamp(1rem,2.5vw,1.2rem)}.gym-item{gap:.75rem}.theme-selector{flex-direction:column;gap:.5rem}.theme-button{width:100%;justify-content:center}}.gym-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gym-modal{background:var(--bg-primary);border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:1rem;right:1rem;background:#0000001a;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1.5rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1}.modal-close:hover{background:#0003;color:var(--text-primary);transform:scale(1.1)}.modal-header{padding:clamp(1.75rem,4vw,2.5rem);padding-right:4rem;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-left:5px solid;position:relative}.modal-header h2{margin:0 0 .75rem;font-size:clamp(1.5rem,3.5vw,2rem);color:var(--text-primary);font-weight:700}.modal-remote-badge{display:inline-block;font-size:clamp(.8rem,1.8vw,.9rem);font-weight:600;color:#e74c3c;background:#e74c3c1a;border:1px solid rgba(231,76,60,.25);border-radius:6px;padding:.3rem .7rem}.modal-route-badge{display:inline-block;color:var(--bg-primary);padding:.4rem 1rem;border-radius:50px;font-size:clamp(.85rem,1.8vw,.95rem);font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #0003}.modal-content{padding:clamp(1.5rem,3vw,2rem);display:flex;flex-direction:column;gap:clamp(1.25rem,2.5vw,1.75rem)}.modal-section{display:flex;gap:1.25rem;align-items:flex-start}.modal-icon{width:clamp(2.5rem,5vw,3rem);height:clamp(2.5rem,5vw,3rem);background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:clamp(1.25rem,3vw,1.5rem);flex-shrink:0;box-shadow:0 4px 12px #667eea4d}.modal-info{flex:1}.modal-info h4{margin:0 0 .5rem;font-size:clamp(1rem,2.2vw,1.15rem);color:#667eea;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.modal-info p{margin:0;font-size:clamp(.95rem,2vw,1.1rem);color:var(--text-secondary);line-height:1.6}.difficulty-badge{display:inline-block;padding:.5rem 1.25rem;border-radius:50px;font-weight:700;font-size:clamp(.95rem,2vw,1.05rem);text-transform:uppercase;letter-spacing:.5px}.difficulty-beginner{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;box-shadow:0 2px 8px #48bb784d}.difficulty-intermediate{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff;box-shadow:0 2px 8px #ed89364d}.difficulty-advanced{background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff;box-shadow:0 2px 8px #e53e3e4d}.difficulty-elite,.difficulty-all-levels{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;box-shadow:0 2px 8px #667eea4d}.target-score{font-weight:600;color:#667eea;background:linear-gradient(135deg,#667eea1a,#e74c3c1a);padding:.75rem 1rem;border-radius:8px;border-left:4px solid #667eea}.score-input-section{margin-top:1rem;padding:1rem;background:var(--bg-secondary);border-radius:12px}.time-input-group,.rounds-input-group,.reps-input-group{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.time-input,.rounds-input,.reps-input{padding:clamp(.65rem,2vw,.85rem) clamp(.85rem,2.2vw,1rem);border:2px solid var(--border-primary);border-radius:8px;font-size:clamp(1rem,2.2vw,1.15rem);font-weight:600;width:clamp(4rem,12vw,6rem);background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease;text-align:center}.time-input:focus,.rounds-input:focus,.reps-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.time-separator,.rounds-separator{font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700;color:#667eea}.reps-input{width:100%;max-width:12rem}.score-error{margin-top:.75rem;padding:.75rem 1rem;background:linear-gradient(135deg,#fff5f5,#fed7d7);border-left:4px solid #e53e3e;border-radius:8px;color:#c53030;font-weight:600;font-size:clamp(.9rem,2vw,1rem)}.modal-completed-badge{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#f0fff4,#c6f6d5);border-radius:12px;border:2px solid #48bb78;margin-top:.5rem}.completed-icon{font-size:clamp(1.75rem,4vw,2.25rem)}.completed-text{font-size:clamp(1.05rem,2.3vw,1.25rem);font-weight:700;color:#22543d}.modal-actions{padding:clamp(1.5rem,3vw,2rem);padding-top:0;display:flex;gap:1rem;flex-wrap:wrap}.modal-btn{flex:1;min-width:140px;padding:clamp(.85rem,2vw,1.1rem);border:none;border-radius:12px;font-size:clamp(1rem,2.2vw,1.15rem);font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.modal-btn-primary{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;box-shadow:0 4px 12px #667eea66}.modal-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.modal-btn-secondary{background:var(--bg-primary);color:#667eea;border:2px solid #667eea}.modal-btn-secondary:hover{background:var(--bg-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.qr-gate-section{background:linear-gradient(135deg,#667eea0f,#764ba20f);border:1.5px dashed rgba(102,126,234,.4);border-radius:12px;padding:clamp(1rem,2.5vw,1.25rem)}.qr-gate-icon{background:linear-gradient(135deg,#667eea,#e74c3c)!important}.qr-scan-btn{margin-top:.85rem;display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;border:none;border-radius:8px;font-size:clamp(.9rem,2vw,1rem);font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 3px 10px #667eea59}.qr-scan-btn:hover{transform:translateY(-2px);box-shadow:0 5px 14px #667eea73}.qr-scanner-section{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:clamp(1rem,2.5vw,1.5rem);background:#000;border-radius:12px;overflow:hidden}.qr-scanner-header{text-align:center;color:#fff}.qr-scanner-header h4{margin:0 0 .25rem;font-size:clamp(1rem,2.2vw,1.15rem);color:#fff;text-transform:uppercase;letter-spacing:.5px}.qr-scanner-header p{margin:0;font-size:clamp(.82rem,1.8vw,.92rem);color:#ffffffa6}.qr-viewport{position:relative;width:100%;max-width:280px;aspect-ratio:1;border-radius:8px;overflow:hidden}.qr-video{width:100%;height:100%;object-fit:cover;display:block}.qr-frame-overlay{position:absolute;inset:0;pointer-events:none}.qr-corner{position:absolute;width:24px;height:24px;border-color:#667eea;border-style:solid}.qr-corner-tl{top:8px;left:8px;border-width:3px 0 0 3px;border-radius:3px 0 0}.qr-corner-tr{top:8px;right:8px;border-width:3px 3px 0 0;border-radius:0 3px 0 0}.qr-corner-bl{bottom:8px;left:8px;border-width:0 0 3px 3px;border-radius:0 0 0 3px}.qr-corner-br{bottom:8px;right:8px;border-width:0 3px 3px 0;border-radius:0 0 3px}.qr-error{width:100%;padding:.65rem .9rem;background:#e53e3e26;border:1px solid rgba(229,62,62,.5);border-radius:8px;color:#fc8181;font-size:clamp(.85rem,1.9vw,.95rem);font-weight:600;text-align:center}.qr-cancel-btn{padding:.55rem 1.5rem;background:#ffffff1a;color:#fffc;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:clamp(.88rem,2vw,.95rem);font-weight:600;cursor:pointer;transition:background .2s ease}.qr-cancel-btn:hover{background:#ffffff2e}.qr-verified-banner{display:flex;align-items:center;gap:.65rem;padding:.85rem 1.1rem;background:linear-gradient(135deg,#48bb781f,#38a1691f);border:1.5px solid #68d391;border-radius:10px}.qr-verified-icon{font-size:1.3rem;flex-shrink:0}.qr-verified-text{font-size:clamp(.9rem,2vw,1rem);font-weight:700;color:#276749}[data-theme=dark] .qr-verified-text{color:#9ae6b4}.gym-modal-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-primary);margin-bottom:1.25rem}.gym-modal-tab{flex:1;padding:.75rem 1rem;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;font-size:clamp(.9rem,2vw,1rem);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.gym-modal-tab.active{color:#667eea;border-bottom-color:#667eea}.gym-modal-tab:hover:not(.active){color:var(--text-primary)}.gym-challenge-leaderboard{padding:0 .25rem;margin-bottom:1.25rem}.gym-leaderboard-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.85rem}.gym-leaderboard-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.gym-leaderboard-count{font-size:.8rem;color:var(--text-secondary)}.gym-leaderboard-divider{text-align:center;color:var(--text-tertiary);font-size:.85rem;letter-spacing:4px;padding:.4rem 0}.gym-leaderboard-unranked{text-align:center;font-size:.82rem;color:var(--text-secondary);font-style:italic;margin:.5rem 0 0;padding:0}.gym-leaderboard-empty{color:var(--text-secondary);font-style:italic;font-size:.95rem;text-align:center;padding:1.5rem 0;margin:0}.gym-leaderboard-list{display:flex;flex-direction:column;gap:.5rem}.gym-leaderboard-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem;background:var(--bg-secondary);border-radius:8px;border:1.5px solid var(--border-primary)}.gym-leaderboard-row.gym-leaderboard-me{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea73}.gym-lb-rank{font-size:1rem;min-width:2rem;text-align:center;flex-shrink:0}.gym-lb-name{flex:1;font-size:.92rem;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gym-leaderboard-me .gym-lb-name{color:#667eea;font-weight:700}.gym-lb-score{font-size:.9rem;font-weight:700;color:var(--text-primary);flex-shrink:0}@media(max-width:480px){.gym-modal{max-height:95vh}.modal-actions{flex-direction:column}.modal-btn{min-width:100%}.modal-section{gap:1rem}}.profile-container{padding:clamp(.5rem,2vw,1rem);max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(1.5rem,3vw,2rem);padding-bottom:clamp(2rem,4vw,3rem)}.profile-banner-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}.profile-header-card{background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:20px;padding:clamp(1.5rem,4vw,3rem);display:flex;align-items:center;gap:clamp(1.5rem,3vw,2.5rem);box-shadow:0 8px 24px #00000026;color:#fff;position:relative;transition:background .4s ease}.level-row-frame-dot{display:inline-block;width:1.4rem;height:1.4rem;border-radius:50%;border:3px solid #cd7f32;vertical-align:middle}.frame-tier-group{margin-bottom:1rem}.frame-tier-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:.5rem}.frame-tier-row{display:flex;flex-wrap:wrap;gap:.6rem}.frame-swatch-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;background:none;border:none;cursor:pointer;padding:.3rem;border-radius:8px;transition:background .15s;position:relative}.frame-swatch-btn:hover:not(.frame-swatch-locked){background:#ffffff0f}.frame-swatch-btn.frame-swatch-active{background:#ffffff1a}.frame-swatch-btn.frame-swatch-locked{cursor:not-allowed;opacity:.45}.frame-swatch-ring{width:2.6rem;height:2.6rem}.frame-swatch-avatar{width:100%;height:100%;border-radius:50%;background:var(--bg-primary, #1a1a2e)}.frame-none-swatch{border:2px dashed rgba(255,255,255,.2);border-radius:50%}.frame-swatch-label{font-size:.6rem;color:var(--text-secondary);text-align:center;max-width:3.5rem;line-height:1.2}.frame-swatch-lock{position:absolute;top:.1rem;right:.1rem;font-size:.55rem;font-weight:700;color:#ffffff80;background:#00000080;border-radius:3px;padding:0 .2rem}.profile-theme-btn{position:absolute;top:.75rem;right:.75rem;width:2.2rem;height:2.2rem;border-radius:50%;border:none;background:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;color:#fff}.profile-theme-btn:hover{background:#ffffff59;transform:scale(1.1)}.theme-modal{max-width:460px}.theme-section{margin-bottom:1.5rem}.theme-section:last-child{margin-bottom:0}.theme-section-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:.6rem;display:flex;align-items:center;gap:.5rem}.theme-unlock-tag{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:4px;padding:0 .35rem;font-size:.65rem;color:var(--text-muted, #888);text-transform:none;letter-spacing:0}.theme-swatches{display:flex;flex-wrap:wrap;gap:.5rem}.gradients-grid{gap:.5rem}.theme-swatch{border:2px solid transparent;border-radius:8px;cursor:pointer;position:relative;transition:transform .15s,border-color .15s;display:flex;align-items:center;justify-content:center;overflow:hidden}.color-swatch{width:2.4rem;height:2.4rem;border-radius:50%}.gradient-swatch{width:5rem;height:2.8rem;border-radius:8px}.theme-swatch:hover:not(.theme-swatch-locked){transform:scale(1.08);border-color:#fff}.theme-swatch-active{border-color:#fff!important;box-shadow:0 0 0 3px #fff6}.theme-swatch-locked{cursor:not-allowed}.theme-check{color:#fff;font-size:1.1rem;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.6);pointer-events:none}.theme-lock-label{font-size:.6rem;font-weight:700;color:#ffffffb3;text-shadow:0 1px 2px rgba(0,0,0,.8);pointer-events:none}.profile-avatar{flex-shrink:0;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.4rem}.profile-level-badge{display:inline-block;background:linear-gradient(135deg,gold,#ffed4e);color:#333;font-weight:800;font-size:.72rem;padding:.18rem .7rem;border-radius:20px;letter-spacing:.04em;box-shadow:0 2px 6px #0003;white-space:nowrap}.avatar-circle{width:clamp(80px,15vw,120px);height:clamp(80px,15vw,120px);border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 4px 16px #0003}.avatar-icon{font-size:clamp(2.5rem,8vw,4rem);color:#667eea}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-clickable{cursor:pointer;transition:transform .2s ease}.avatar-clickable:hover{transform:scale(1.05)}.avatar-edit-overlay{position:absolute;bottom:0;left:0;right:0;height:38%;background:#0000008c;border-radius:0 0 50% 50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;opacity:0;transition:opacity .2s ease;z-index:1}.avatar-clickable:hover .avatar-edit-overlay{opacity:1}.avatar-file-input{display:none}.avatar-uploading{font-size:2rem;animation:spin 1s linear infinite;color:#667eea}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-info{flex:1;position:relative;z-index:1}.profile-name{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;margin:0 0 .25rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.stat-card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.stat-card-clickable:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea40}.profile-add-friend-btn{margin-top:.25rem;padding:.35rem 1rem;border:none;border-radius:20px;background:#ffffff40;color:#fff;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-add-friend-btn:hover{background:#fff6}.profile-friend-chip{display:inline-block;margin-top:.25rem;padding:.3rem .85rem;border-radius:20px;background:#fff3;color:#fff;font-size:.82rem;font-weight:700}.profile-friend-chip.pending{background:#ffffff1f;opacity:.8}.profile-handle{font-size:clamp(.9rem,2vw,1.05rem);font-weight:600;margin:0 0 .5rem;opacity:.85;color:#ffffffe6;letter-spacing:.3px}.profile-title{font-size:clamp(1.1rem,2.5vw,1.4rem);margin:0 0 .25rem;opacity:.95;font-weight:600}.member-since{font-size:clamp(.9rem,2vw,1.1rem);margin:0;opacity:.85}.xp-card{background:var(--bg-primary);border-radius:16px;padding:clamp(1.5rem,3vw,2rem);box-shadow:var(--shadow-lg)}.xp-card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.xp-card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 0 2px #667eea44}.xp-levels-hint{font-size:.8rem;color:#667eea;font-weight:500}.xp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.xp-header h3{font-size:clamp(1.25rem,3vw,1.6rem);color:#667eea;margin:0;font-weight:700}.xp-text{font-size:clamp(1rem,2.2vw,1.2rem);color:var(--text-secondary);font-weight:600}.xp-bar{width:100%;height:clamp(32px,5vw,40px);background:var(--bg-tertiary);border-radius:50px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a}.xp-fill{height:100%;background:linear-gradient(90deg,#667eea,#e74c3c);border-radius:50px;transition:width .5s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:1rem;box-shadow:0 2px 8px #667eea66}.xp-percentage{color:var(--bg-primary);font-weight:700;font-size:clamp(.9rem,2vw,1.1rem);text-shadow:1px 1px 2px rgba(0,0,0,.3)}.xp-remaining{margin-top:.75rem;font-size:clamp(.9rem,2vw,1.05rem);color:var(--text-secondary);text-align:center;margin-bottom:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:clamp(1rem,2.5vw,1.5rem)}.stat-card{background:var(--bg-primary);border-radius:16px;padding:clamp(1.25rem,3vw,1.75rem);text-align:center;box-shadow:var(--shadow-lg);transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-icon{font-size:clamp(2rem,5vw,3rem);margin-bottom:.5rem}.stat-value{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:#667eea;margin-bottom:.25rem}.stat-label{font-size:clamp(.9rem,2vw,1.05rem);color:var(--text-secondary);font-weight:600}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:clamp(1rem,2.5vw,1.5rem);flex-wrap:wrap;gap:.75rem}.section-header h3{font-size:clamp(1.5rem,3.5vw,2rem);color:#667eea;margin:0;font-weight:700}.progress-badge{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;padding:clamp(.4rem,1.5vw,.6rem) clamp(.85rem,2vw,1.2rem);border-radius:50px;font-weight:700;font-size:clamp(.9rem,2vw,1.1rem);box-shadow:0 2px 8px #667eea4d}.section-description{color:var(--text-secondary);font-size:clamp(.95rem,2vw,1.1rem);margin:0 0 1.5rem}.invite-card{background:var(--bg-primary);border-radius:16px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem;border:1px solid var(--border-primary)}.invite-card-header{display:flex;align-items:center;gap:.85rem}.invite-card-icon{font-size:1.75rem;line-height:1}.invite-card-title{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.invite-card-sub{font-size:.8rem;color:var(--text-secondary);margin-top:.15rem}.invite-stats-row{display:flex;gap:0}.invite-stat{flex:1;text-align:center;padding:.5rem 0}.invite-stat+.invite-stat{border-left:1px solid var(--border-primary)}.invite-stat-value{font-size:1.4rem;font-weight:800;color:var(--text-primary);line-height:1.1}.invite-stat-max{font-size:.9rem;font-weight:500;color:var(--text-secondary)}.invite-stat-label{font-size:.75rem;color:var(--text-secondary);margin-top:.2rem}.invite-copy-btn{width:100%;padding:.75rem;border-radius:10px;border:none;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s}.invite-copy-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.invite-copy-btn:active:not(:disabled){transform:translateY(0)}.invite-copy-btn.invite-copied{background:linear-gradient(135deg,#2ecc71,#1a9050)}.invite-copy-btn.invite-limit-reached,.invite-copy-btn:disabled{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;opacity:.7}.achievements-section{background:var(--bg-primary);border-radius:16px;padding:clamp(1.5rem,3vw,2rem);box-shadow:var(--shadow-lg)}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.achievement-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.4rem;padding:.9rem .6rem .75rem;border-radius:12px;border:2px solid var(--border-primary);transition:all .2s ease;background:var(--bg-secondary)}.achievement-card.earned{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#667eea;box-shadow:0 2px 8px #667eea33}.achievement-card.earned:hover{transform:translateY(-2px);box-shadow:0 4px 14px #667eea4d}.achievement-card.locked{opacity:.5}.achievement-icon{font-size:2rem;line-height:1;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.achievement-icon img{width:2rem;height:2rem;object-fit:contain}.achievement-info{width:100%}.achievement-name{font-size:.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.2rem;line-height:1.2}.achievement-desc{font-size:.68rem;color:var(--text-secondary);line-height:1.3;margin-bottom:.2rem}.achievement-date{font-size:.68rem;color:#667eea;font-weight:600}.achievement-locked{font-size:.68rem;color:var(--text-tertiary);font-weight:600}.badges-section{background:var(--bg-primary);border-radius:16px;padding:clamp(1.5rem,3vw,2rem);box-shadow:var(--shadow-lg)}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:clamp(1.25rem,3vw,1.75rem)}.badge-card{display:flex;flex-direction:column;align-items:center;padding:clamp(1.5rem,3vw,2rem);border-radius:16px;border:3px solid;transition:all .3s ease;background:var(--bg-secondary);text-align:center}.badge-card.earned{background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);box-shadow:var(--shadow-lg)}.badge-card.earned:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px #0003}.badge-card.locked{opacity:.5}.badge-icon-large{width:clamp(70px,12vw,90px);height:clamp(70px,12vw,90px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(2.5rem,6vw,3.5rem);margin-bottom:1rem;box-shadow:var(--shadow-md);color:var(--bg-primary);overflow:hidden}.badge-img,.badge-preview-img-small{width:100%;height:100%;object-fit:cover;border-radius:50%}.badge-info{width:100%}.badge-theme{font-size:clamp(.85rem,1.8vw,.95rem);color:#667eea;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.badge-name{font-size:clamp(1.05rem,2.3vw,1.25rem);font-weight:700;color:var(--text-primary);margin-bottom:.5rem;line-height:1.3}.badge-date{font-size:clamp(.85rem,1.8vw,.95rem);color:#48bb78;font-weight:600}.badge-locked-text{font-size:clamp(.85rem,1.8vw,.95rem);color:var(--text-tertiary);font-weight:600}.featured-items-row{display:flex;gap:.5rem;margin-top:.85rem;flex-wrap:wrap}.featured-item-badge{width:clamp(34px,6vw,42px);height:clamp(34px,6vw,42px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(1rem,2.5vw,1.3rem);background:#ffffff2e;border:2px solid rgba(255,255,255,.45);box-shadow:0 2px 8px #0003;transition:transform .2s ease}.featured-item-badge:hover{transform:scale(1.12)}.feature-btn{background:none;border:1px solid var(--border-primary);border-radius:6px;padding:.2rem .55rem;font-size:clamp(.75rem,1.6vw,.85rem);cursor:pointer;color:var(--text-secondary);margin-top:.4rem;transition:all .2s ease;white-space:nowrap}.feature-btn:hover:not(.feature-disabled){border-color:#667eea;color:#667eea}.feature-btn.featured{background:linear-gradient(135deg,#667eea,#e74c3c);border-color:transparent;color:#fff}.feature-btn.feature-disabled{opacity:.35;cursor:not-allowed}.preview-clickable{cursor:pointer;transition:box-shadow .2s ease,transform .2s ease}.preview-clickable:hover{box-shadow:0 8px 32px #667eea40;transform:translateY(-2px)}.preview-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.preview-icon{width:clamp(48px,8vw,60px);height:clamp(48px,8vw,60px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(1.4rem,3.5vw,1.8rem);flex-shrink:0;transition:transform .2s ease}.preview-icon:hover{transform:scale(1.1)}.preview-icon.earned-preview{background:linear-gradient(135deg,#667eea26,#e74c3c26);border:2px solid #667eea;box-shadow:0 2px 8px #667eea4d}.preview-icon.badge-preview{background:unset;border:none;box-shadow:0 2px 8px #0003}.preview-icon.locked-preview{background:var(--bg-tertiary);border:2px solid var(--border-primary);opacity:.5}.preview-icon img{width:100%;height:100%;object-fit:contain}.preview-view-all{margin-left:auto;color:#667eea;font-weight:700;font-size:clamp(.9rem,2vw,1rem);white-space:nowrap;opacity:.85;transition:opacity .2s ease}.preview-clickable:hover .preview-view-all{opacity:1}.profile-modal-overlay{position:fixed;inset:0;background:#0009;z-index:1000;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,3vw,2rem);padding-bottom:clamp(5rem,10vw,7rem);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto}.profile-modal{background:var(--bg-primary);border-radius:20px;width:100%;max-width:500px;height:70vh;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #00000059;animation:modal-pop .25s ease;margin:auto}@keyframes modal-pop{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.profile-modal-header{display:flex;align-items:center;justify-content:space-between;padding:clamp(1.25rem,3vw,1.75rem) clamp(1.25rem,3vw,1.75rem) 1rem;border-bottom:2px solid var(--border-primary);flex-shrink:0}.profile-modal-header h3{margin:0;font-size:clamp(1.4rem,3.5vw,1.8rem);color:#667eea;font-weight:700}.modal-header-right{display:flex;align-items:center;gap:.75rem}.modal-close-btn{background:var(--bg-secondary);border:none;border-radius:50%;width:36px;height:36px;font-size:1rem;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:background .2s ease;flex-shrink:0;padding:0}.modal-close-btn:hover{background:var(--bg-tertiary)}.profile-modal-body{overflow-y:auto;padding:clamp(1.25rem,3vw,1.75rem);flex:1}@media(max-width:768px){.profile-header-card{flex-direction:column;text-align:center}.stats-grid{grid-template-columns:repeat(2,1fr)}.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.badges-grid{grid-template-columns:1fr}}@media(max-width:480px){.profile-container{padding:clamp(.75rem,2vw,1rem)}.stats-grid{grid-template-columns:1fr}.xp-header{flex-direction:column;align-items:flex-start}}.stat-card-clickable{cursor:pointer;position:relative}.stat-card-hint{font-size:.7rem;color:#667eea;font-weight:700;margin-top:.3rem;letter-spacing:.02em;opacity:.8}.stat-card-clickable:hover .stat-card-hint{opacity:1}.stat-card-streak{justify-content:center}.stat-streak-row{display:flex;align-items:center;gap:.6rem;width:100%;justify-content:center}.stat-streak-item{display:flex;flex-direction:column;align-items:center;gap:.1rem}.stat-streak-divider{width:1px;height:2rem;background:var(--border-primary);flex-shrink:0}.battle-log-list{display:flex;flex-direction:column;gap:.5rem}.battle-log-row{display:flex;align-items:center;gap:.75rem;padding:.75rem .9rem;border-radius:10px;position:relative;overflow:hidden}.battle-log-win{background:#27ae601a;border:1px solid rgba(39,174,96,.25)}.battle-log-loss{background:#e74c3c14;border:1px solid rgba(231,76,60,.2)}.battle-log-tie{background:#667eea14;border:1px solid rgba(102,126,234,.2)}.battle-log-result-bar{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:10px 0 0 10px}.battle-log-win .battle-log-result-bar{background:#27ae60}.battle-log-loss .battle-log-result-bar{background:#e74c3c}.battle-log-tie .battle-log-result-bar{background:#667eea}.battle-log-info{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0;padding-left:.25rem}.battle-log-workout{font-size:.88rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.battle-log-opponent{font-size:.75rem;color:var(--text-secondary)}.battle-log-date{font-size:.7rem;color:var(--text-tertiary)}.battle-log-scores{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;flex-shrink:0}.battle-log-score-you,.battle-log-score-them{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.battle-log-score-you{font-weight:700;color:var(--text-primary)}.battle-log-badge{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:900;flex-shrink:0}.battle-log-badge.win{background:#27ae6033;color:#27ae60}.battle-log-badge.loss{background:#e74c3c26;color:#e74c3c}.battle-log-badge.tie{background:#667eea26;color:#667eea}.profile-posts-list{display:flex;flex-direction:column;gap:.75rem}.profile-post-item{background:var(--bg-secondary);border-radius:12px;padding:.9rem 1rem;border:1px solid var(--border-primary);display:flex;flex-direction:column;gap:.4rem}.profile-post-top{display:flex;align-items:center;justify-content:space-between}.profile-post-type-icon{font-size:1.1rem}.profile-post-time{font-size:.78rem;color:var(--text-secondary)}.profile-post-content{font-size:.95rem;color:var(--text-primary);margin:0;line-height:1.45}.profile-post-details,.profile-post-score{font-size:.85rem;color:var(--text-secondary);margin:0}.profile-post-video{width:100%;border-radius:8px;max-height:200px;object-fit:cover}.profile-post-stats{display:flex;gap:.75rem;font-size:.82rem;color:var(--text-secondary);margin-top:.2rem}.wlog-empty{text-align:center;color:var(--text-secondary);padding:2rem 1rem;font-size:clamp(.9rem,2vw,1rem);line-height:1.6}.wlog-list{display:flex;flex-direction:column;gap:.6rem}.wlog-entry{display:flex;align-items:center;gap:.85rem;padding:clamp(.7rem,2vw,.9rem) clamp(.85rem,2.5vw,1.1rem);background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-primary);transition:transform .15s ease}.wlog-entry:hover{transform:translate(3px)}.wlog-type-badge{font-size:clamp(.7rem,1.6vw,.8rem);font-weight:700;padding:.2rem .55rem;border-radius:50px;white-space:nowrap;flex-shrink:0}.wlog-type-badge[data-type=daily]{background:#667eea26;color:#667eea}.wlog-type-badge[data-type=weekly]{background:#e74c3c26;color:#e74c3c}.wlog-main{flex:1;min-width:0}.wlog-name{font-size:clamp(.9rem,2vw,1rem);font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wlog-date{font-size:clamp(.75rem,1.7vw,.85rem);color:var(--text-secondary);margin-top:.15rem}.wlog-right{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.wlog-score{font-size:clamp(.9rem,2vw,1.05rem);font-weight:800;color:#667eea;font-variant-numeric:tabular-nums}.wlog-video-badge{font-size:.68rem;font-weight:700;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:.1rem .4rem;border-radius:50px;white-space:nowrap}.levels-modal-body{display:flex;flex-direction:column;gap:1rem;flex:1;min-height:0;overflow:hidden;padding:clamp(1.25rem,3vw,1.75rem)}.levels-current-banner{display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,#667eea22,#764ba222);border:1px solid #667eea44;border-radius:12px;padding:1rem 1.25rem}.levels-current-icon{font-size:2.2rem;flex-shrink:0}.levels-current-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#667eea}.levels-current-name{font-size:1.1rem;font-weight:800;color:var(--text-primary)}.levels-current-level{font-size:.8rem;color:var(--text-secondary);margin-top:.1rem}.levels-xp-mini{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;flex-shrink:0}.levels-xp-mini-bar{width:80px;height:6px;background:var(--bg-tertiary);border-radius:50px;overflow:hidden}.levels-xp-mini-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:50px}.levels-xp-mini span{font-size:.72rem;color:var(--text-secondary);font-weight:600}.levels-next-banner{display:flex;align-items:flex-start;gap:.75rem;background:var(--bg-secondary);border:1px dashed #f59e0b88;border-radius:10px;padding:.85rem 1rem;font-size:1.1rem}.levels-next-label{font-size:.75rem;font-weight:700;color:#f59e0b;text-transform:uppercase;letter-spacing:.06em}.levels-next-unlock{font-size:.88rem;color:var(--text-secondary);margin-top:.15rem}.levels-list{display:flex;flex-direction:column;gap:.4rem;flex:1;min-height:0;overflow-y:auto;padding-right:.3rem}.level-entry{border-radius:12px;overflow:hidden;background:var(--bg-secondary);opacity:.5;flex-shrink:0}.level-entry-earned{opacity:1}.level-entry-current{border:2px solid #667eea;background:linear-gradient(135deg,var(--bg-secondary),#667eea18);opacity:1}.level-entry-next{border:2px dashed #f59e0b99;opacity:.9}.level-entry-row{display:flex;align-items:center;gap:1rem;width:100%;padding:1.1rem 1.25rem;background:none;border:none;cursor:pointer;text-align:left;color:inherit}.level-entry-row-empty{cursor:default}.level-entry-badge{flex-shrink:0;min-width:3.2rem;padding:.3rem .5rem;font-size:1.25rem;font-weight:800;color:var(--text-secondary);text-align:center;background:var(--bg-tertiary);border-radius:8px;line-height:1}.level-entry-earned .level-entry-badge{color:var(--text-primary)}.level-entry-current .level-entry-badge{background:#667eea22;color:#667eea}.level-entry-icon{flex-shrink:0;font-size:1.6rem;width:2rem;text-align:center}.level-entry-label{flex:1;font-size:1.2rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.level-entry-row-empty .level-entry-label{color:var(--text-secondary);font-weight:400}.level-entry-chevron{flex-shrink:0;font-size:1.4rem;color:var(--text-secondary);transition:transform .18s ease;display:inline-block;line-height:1}.level-entry-chevron.open{transform:rotate(90deg)}.level-unlock-items{display:flex;flex-direction:column;gap:.65rem;padding:.75rem 1.25rem 1rem;border-top:1px solid rgba(255,255,255,.08)}.level-unlock-item{display:flex;align-items:center;gap:.75rem}.level-unlock-item-icon{flex-shrink:0;width:28px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.level-unlock-item-text{font-size:1rem;color:var(--text-secondary);line-height:1.4}.level-row-icon{font-size:1.3rem;flex-shrink:0;width:28px;text-align:center}.level-row-info{flex:1;display:flex;flex-direction:column;gap:.1rem}.level-row-name{font-size:.9rem;font-weight:700;color:var(--text-primary)}.level-row-unlock{font-size:.78rem;color:var(--text-secondary)}.level-row-gradient-dot{display:inline-block;width:1.4rem;height:1.4rem;border-radius:4px;border:2px solid rgba(255,255,255,.15);vertical-align:middle}.level-row-color-swatches{display:flex;gap:.3rem;margin-top:.3rem;flex-wrap:wrap}.level-row-color-dot{width:1rem;height:1rem;border-radius:50%;display:inline-block;border:1.5px solid rgba(255,255,255,.2);flex-shrink:0}.level-row-num{font-size:.75rem;font-weight:700;color:var(--text-tertiary);flex-shrink:0}.guest-profile-card{max-width:420px;margin:4rem auto;background:var(--bg-primary);border-radius:24px;padding:2.5rem 2rem;text-align:center;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:1rem}.guest-profile-icon{font-size:3.5rem;width:80px;height:80px;background:var(--bg-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center}.guest-profile-title{font-size:1.4rem;font-weight:800;color:var(--text-primary);margin:0}.guest-profile-body{font-size:.92rem;color:var(--text-secondary);line-height:1.55;margin:0}.guest-profile-perks{display:flex;flex-direction:column;gap:.35rem;text-align:left;width:100%}.guest-profile-perks span{font-size:.88rem;color:var(--text-secondary)}.guest-profile-signup{width:100%;padding:.9rem;border:none;border-radius:14px;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s}.guest-profile-signup:hover{opacity:.9;transform:translateY(-1px)}.guest-profile-login{background:none;border:none;color:#667eea;font-size:.88rem;font-weight:600;cursor:pointer;padding:.25rem}.customize-modal{max-width:480px}.customize-tab-track{position:relative;display:flex;background:var(--bg-tertiary, #1e1e2e);border-radius:50px;padding:4px;margin:0 0 1.25rem;gap:0}.customize-tab-pill{position:absolute;top:4px;left:4px;width:calc((100% - 8px) / 3);height:calc(100% - 8px);background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:50px;transition:transform .22s cubic-bezier(.4,0,.2,1);pointer-events:none;z-index:0;box-shadow:0 2px 8px #667eea59}.customize-tab-pill.pill-mid{transform:translate(100%)}.customize-tab-pill.pill-right{transform:translate(200%)}.customize-tab-btn{flex:1;position:relative;z-index:1;background:none;border:none;border-radius:50px;padding:.45rem 0;font-size:.88rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:color .18s}.customize-tab-btn.tab-active{color:#fff}.customize-preview{border-radius:14px;overflow:hidden;margin-bottom:1.25rem;box-shadow:0 4px 14px #00000040}.customize-preview-banner{display:flex;align-items:center;gap:.9rem;padding:.9rem 1rem;position:relative;overflow:hidden;transition:background .35s ease}.customize-preview-avatar{flex-shrink:0;position:relative;z-index:1}.customize-preview-circle{width:2.8rem;height:2.8rem;border-radius:50%;background:var(--bg-primary, #1a1a2e);display:flex;align-items:center;justify-content:center;font-size:1.4rem;overflow:hidden}.customize-preview-circle.large{width:5rem;height:5rem;font-size:2.4rem}.customize-preview-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.customize-preview-info{display:flex;flex-direction:column;gap:.2rem;position:relative;z-index:1}.customize-preview-name{font-size:.95rem;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.4)}.customize-preview-level{font-size:.75rem;color:#ffffffbf;font-weight:500}.customize-preview-frame-area{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.4rem 1rem;background:var(--bg-tertiary, #1e1e2e)}.customize-preview-frame-label{font-size:.78rem;color:var(--text-secondary);font-weight:600}.customize-body{max-height:45vh;overflow-y:auto;padding-right:.25rem}.banner-season-label{display:flex;align-items:center;gap:.5rem}.banner-season-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.banner-pass-tag{background:#ffd7001f;border-color:#ffd7004d;color:gold!important}.banner-shop-tag{background:#a064ff1f;border-color:#a064ff4d;color:#c084fc!important}.banner-swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.banner-swatch-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;background:none;border:2px solid transparent;border-radius:10px;padding:.3rem;cursor:pointer;transition:border-color .15s,transform .15s}.banner-swatch-btn:hover{transform:translateY(-2px);border-color:#ffffff4d}.banner-swatch-active{border-color:#fff!important}.banner-swatch-preview{width:100%;height:48px;border-radius:7px;position:relative;display:flex;align-items:center;justify-content:center}.banner-swatch-check{font-size:1.1rem;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.8)}.banner-swatch-label{font-size:.7rem;font-weight:600;color:var(--text-secondary);text-align:center}.banner-swatch-tag{font-size:.6rem;font-weight:700;letter-spacing:.5px;padding:2px 6px;border-radius:8px}.banner-swatch-tag.tag-pass{background:#ffd7001f;color:gold}.banner-swatch-tag.tag-shop{background:#a064ff1f;color:#c084fc}.banner-swatch-locked{cursor:not-allowed;opacity:.6}.banner-swatch-locked:hover{transform:none!important;border-color:transparent!important}.banner-swatch-dim{filter:grayscale(.7) brightness(.45)}.banner-swatch-lock-icon{position:absolute;font-size:1rem;top:50%;left:50%;transform:translate(-50%,-50%);filter:none}.banner-pass-tag{background:#ffd7001a!important;color:gold!important;border-color:#ffd70040!important}.banner-shop-tag{background:#a064ff1a!important;color:#c084fc!important;border-color:#a064ff40!important}.name-style-iron-style{background:linear-gradient(135deg,#4a5060,#8090a0,#c8d4e0 50%,#fff 60%,#8090a0,#4a5060);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-iron-willed{background:linear-gradient(135deg,#8b3a00,#c50 30%,#ff8c00 55%,#fa3 72%,#c50 87%,#8b3a00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-gold{background:linear-gradient(135deg,gold,#ff8c00,gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-silver{background:linear-gradient(135deg,#b0b0b0,#fff,#b0b0b0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-fire{background:linear-gradient(135deg,#f20,#ff8c00,#f40);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-ice{background:linear-gradient(135deg,#00bfff,#e8f8ff,#00bfff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-neon{color:#0f8!important;-webkit-text-fill-color:#00ff88!important;text-shadow:0 0 8px #00ff88,0 0 18px rgba(0,255,136,.5),0 0 32px rgba(0,255,136,.25)}.name-style-crimson{background:linear-gradient(135deg,#8b0000,#dc143c,#8b0000);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-violet{background:linear-gradient(135deg,#50c,#c6f,#50c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-style-rainbow{background:linear-gradient(90deg,red,#ff7f00,#ff0,#0c0,#00f,#8b00ff,red);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:name-rainbow 3s linear infinite}@keyframes name-rainbow{0%{background-position:0% 50%}to{background-position:200% 50%}}.name-style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.5rem}.name-swatch-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .25rem;background:var(--bg-tertiary, #1e1e2e);border:1.5px solid transparent;border-radius:10px;cursor:pointer;transition:border-color .15s,transform .12s;position:relative}.name-swatch-btn:hover{transform:scale(1.04)}.name-swatch-btn.name-swatch-active{border-color:#667eea}.name-swatch-btn.name-swatch-locked{opacity:.55;cursor:default}.name-swatch-preview{font-size:1.3rem;font-weight:800;color:#fff;line-height:1.2;min-height:1.6rem;display:flex;align-items:center;justify-content:center}.name-swatch-dim{opacity:.45}.name-swatch-label{font-size:.62rem;color:#aaa;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:64px}.name-swatch-lock{font-size:.58rem;color:#e74c3c;background:#e74c3c1f;border-radius:4px;padding:1px 4px}.name-swatch-price{font-size:.6rem;color:gold;display:flex;align-items:center;gap:2px}.name-swatch-lock-icon{position:absolute;top:4px;right:4px;font-size:.65rem;opacity:.7}.customize-preview-name-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding:1.25rem 1rem;background:var(--bg-secondary, #12122a);border-radius:12px;min-height:72px}.customize-preview-name-big{font-size:1.4rem;font-weight:800;color:#fff;line-height:1.2;text-align:center;word-break:break-word}.pr-preview-card{background:var(--bg-primary);border-radius:16px;padding:clamp(1.5rem,3vw,2rem);box-shadow:var(--shadow-lg);cursor:pointer;transition:filter .15s}.pr-preview-card:hover{filter:brightness(1.06)}.pr-preview-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.pr-chip{display:flex;align-items:center;gap:.3rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:.28rem .65rem .28rem .45rem;font-size:.78rem}.pr-chip-icon{font-size:.9rem;line-height:1}.pr-chip-name{color:var(--text-secondary, rgba(255,255,255,.5));font-weight:500}.pr-chip-val{font-weight:800;color:var(--cat-color, #667eea);margin-left:.2rem}.pr-preview-empty{font-size:.82rem;color:var(--text-secondary, rgba(255,255,255,.35));margin:0 0 .75rem}.pr-hint{text-align:center;font-size:.75rem;color:var(--text-secondary, rgba(255,255,255,.35));margin:.5rem 0 0}.pr-category{background:var(--card-bg, rgba(255,255,255,.04));border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:16px;overflow:hidden}.pr-category-header{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.08));background:#ffffff05;border-left:3px solid var(--cat-color, #667eea)}.pr-cat-icon{font-size:1.1rem;line-height:1}.pr-cat-name{font-size:.8rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary, rgba(255,255,255,.55))}.pr-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}@media(min-width:540px){.pr-grid{grid-template-columns:1fr 1fr 1fr}}.pr-record{padding:.8rem 1rem;border-right:1px solid var(--border-color, rgba(255,255,255,.06));border-bottom:1px solid var(--border-color, rgba(255,255,255,.06));transition:background .15s}.pr-record:nth-child(2n){border-right:none}@media(min-width:540px){.pr-record:nth-child(2n){border-right:1px solid var(--border-color, rgba(255,255,255,.06))}.pr-record:nth-child(3n){border-right:none}}.pr-record-name{font-size:.72rem;font-weight:600;color:var(--text-secondary, rgba(255,255,255,.45));margin-bottom:.3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pr-record-value{font-size:1.05rem;font-weight:800;color:var(--text-primary, rgba(255,255,255,.9));line-height:1.1}.pr-record.pr-set .pr-record-value{color:var(--cat-color, #667eea)}.pr-unset{color:var(--text-secondary, rgba(255,255,255,.2));font-weight:400}.pr-record.pr-clickable{cursor:pointer}.pr-record.pr-clickable:hover{background:#ffffff0a}.pr-edit-overlay{position:fixed;inset:0;background:#000000a6;z-index:9050;display:flex;align-items:center;justify-content:center;padding:1rem}.pr-edit-modal{background:var(--card-bg, #1a1a2e);border:1px solid var(--border-color, rgba(255,255,255,.12));border-radius:18px;width:100%;max-width:320px;overflow:hidden;animation:pr-modal-in .25s cubic-bezier(.34,1.4,.64,1) both}@keyframes pr-modal-in{0%{transform:scale(.88) translateY(12px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.pr-edit-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.1rem .9rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.08));border-left:3px solid var(--cat-color, #667eea)}.pr-edit-title{font-size:1rem;font-weight:800;color:var(--text-primary, #fff)}.pr-edit-close{background:none;border:none;color:var(--text-secondary, rgba(255,255,255,.4));font-size:.9rem;cursor:pointer;padding:.2rem .3rem;line-height:1}.pr-edit-body{padding:1.1rem 1.1rem .8rem}.pr-edit-weight-row{display:flex;gap:.6rem;align-items:center}.pr-edit-input{flex:1;background:#ffffff12;border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:.65rem .9rem;font-size:1.3rem;font-weight:700;color:var(--text-primary, #fff);text-align:center;outline:none;transition:border-color .15s;width:100%}.pr-edit-input:focus{border-color:var(--cat-color, #667eea)}.pr-edit-input-full{width:100%;box-sizing:border-box}.pr-edit-input[type=number]::-webkit-inner-spin-button,.pr-edit-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.pr-edit-input[type=number]{-moz-appearance:textfield}.pr-edit-unit-toggle{display:flex;flex-direction:column;gap:.3rem;flex-shrink:0}.pr-unit-btn{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:7px;padding:.3rem .7rem;font-size:.78rem;font-weight:700;color:var(--text-secondary, rgba(255,255,255,.45));cursor:pointer;transition:background .14s,color .14s}.pr-unit-btn.active{background:var(--cat-color, #667eea);border-color:transparent;color:#fff}.pr-edit-actions{display:flex;gap:.6rem;padding:0 1.1rem 1.1rem}.pr-clear-btn{flex:1;background:#ff50501f;border:1px solid rgba(255,80,80,.25);border-radius:10px;padding:.65rem;font-size:.86rem;font-weight:700;color:#ff6060;cursor:pointer;transition:background .15s}.pr-clear-btn:hover{background:#ff505038}.pr-save-btn{flex:2;background:var(--cat-color, #667eea);border:none;border-radius:10px;padding:.65rem;font-size:.9rem;font-weight:700;color:#fff;cursor:pointer;transition:opacity .15s}.pr-save-btn:disabled{opacity:.4;cursor:not-allowed}.avatar-frame-ring{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;line-height:0;flex-shrink:0}.frame-bronze-1{padding:3px;background:#cd7f32}.frame-bronze-2{padding:4px;background:linear-gradient(135deg,#a05c1e,#cd7f32 40%,#e8a858,#cd7f32,#a05c1e);box-shadow:0 0 8px #cd7f3273}.frame-bronze-3{padding:5px;background:linear-gradient(135deg,#7a3e0a,#cd7f32,#f0b060,#cd7f32,#7a3e0a);box-shadow:0 0 0 2px #cd7f3240,0 0 14px #cd7f328c}.frame-silver-1{padding:3px;background:#b0b0b0}.frame-silver-2{padding:4px;background:linear-gradient(135deg,gray,silver 40%,#f0f0f0,silver,gray);box-shadow:0 0 8px #c0c0c080}.frame-silver-3{padding:5px;background:transparent}.frame-silver-3:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#606060,silver 30%,#fff,silver 70%,#606060);box-shadow:0 0 0 2px #c0c0c04d,0 0 16px #dcdcdcb3;animation:frame-silver-shimmer 3s ease-in-out infinite;z-index:0}.frame-silver-3>.avatar-circle,.frame-silver-3>.frame-swatch-avatar,.frame-silver-3>.levelup-frame-avatar,.frame-silver-3>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-silver-shimmer{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}.frame-gold-1{padding:3px;background:#daa520}.frame-gold-2{padding:4px;background:linear-gradient(135deg,#b8860b,gold 40%,#ffec6e,gold,#b8860b);box-shadow:0 0 10px #ffd7008c}.frame-gold-3{padding:5px;background:linear-gradient(135deg,#8b6914,gold 30%,#fffacd,gold 70%,#8b6914);animation:frame-gold-pulse 2s ease-in-out infinite}@keyframes frame-gold-pulse{0%,to{box-shadow:0 0 0 2px #ffd7004d,0 0 14px #ffd7008c}50%{box-shadow:0 0 0 3px #ffd70080,0 0 26px #ffd700e6}}.frame-platinum-1{padding:4px;background:linear-gradient(135deg,#8e9eab,#c8d6e5 40%,#eef4fb,#c8d6e5,#8e9eab);box-shadow:0 0 10px #c8d6e58c}.frame-platinum-2{padding:5px;background:transparent}.frame-platinum-2:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#6a7d8e,#c8d6e5 30%,#fff,#c8d6e5 70%,#6a7d8e);box-shadow:0 0 0 2px #c8d6e566,0 0 18px #c8d6e5bf;animation:frame-platinum-sweep 2.5s ease-in-out infinite;z-index:0}.frame-platinum-2>.avatar-circle,.frame-platinum-2>.frame-swatch-avatar,.frame-platinum-2>.levelup-frame-avatar,.frame-platinum-2>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-platinum-sweep{0%,to{filter:brightness(1) saturate(1)}50%{filter:brightness(1.2) saturate(1.1)}}.frame-diamond-1{padding:4px;background:linear-gradient(135deg,#00acc1,#4dd0e1 40%,#b2ebf2,#4dd0e1,#00acc1);box-shadow:0 0 14px #4dd0e1a6}.frame-diamond-2{padding:5px;background:transparent}.frame-diamond-2:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#006978,#4dd0e1,#e0ffff,#4dd0e1,#006978);box-shadow:0 0 0 2px #4dd0e166,0 0 22px #4dd0e1d9;animation:frame-diamond-spark 1.8s ease-in-out infinite;z-index:0}.frame-diamond-2>.avatar-circle,.frame-diamond-2>.frame-swatch-avatar,.frame-diamond-2>.levelup-frame-avatar,.frame-diamond-2>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-diamond-spark{0%,to{filter:brightness(1) saturate(1)}40%{filter:brightness(1.35) saturate(1.3)}80%{filter:brightness(.9) saturate(.9)}}.frame-legendary{padding:5px;background:transparent}.frame-legendary:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(red,#f70,#ff0,#0f0,#07f,#8b00ff,red);animation:frame-legendary-hue 4s linear infinite;z-index:0}.frame-legendary>.avatar-circle,.frame-legendary>.frame-swatch-avatar,.frame-legendary>.levelup-frame-avatar,.frame-legendary>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-legendary-hue{to{filter:hue-rotate(360deg)}}.frame-mythic{padding:5px;background:transparent}.frame-mythic:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(#4a0099,#93f,#c6f,#f0c,#93f,#4a0099);animation:frame-mythic-pulse 2s ease-in-out infinite;z-index:0}.frame-mythic>.avatar-circle,.frame-mythic>.frame-swatch-avatar,.frame-mythic>.levelup-frame-avatar,.frame-mythic>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-mythic-pulse{0%,to{box-shadow:0 0 0 2px #9933ff59,0 0 20px #9933ffbf;filter:brightness(1)}50%{box-shadow:0 0 0 3px #cc66ff8c,0 0 36px #cc66fff2;filter:brightness(1.3)}}.frame-celestial{padding:5px;background:transparent}.frame-celestial:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(#03b,#48f,#acf,#fff,#acf,#48f,#03b);animation:frame-celestial-flash 1.8s ease-in-out infinite;z-index:0}.frame-celestial>.avatar-circle,.frame-celestial>.frame-swatch-avatar,.frame-celestial>.levelup-frame-avatar,.frame-celestial>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-celestial-flash{0%,to{box-shadow:0 0 0 2px #64a0ff66,0 0 26px #64a0ffd9;filter:brightness(1) saturate(1)}45%{box-shadow:0 0 0 3px #c8e1ffa6,0 0 46px #c8e1ff;filter:brightness(1.55) saturate(1.25)}}.frame-infernal{padding:5px;background:transparent}.frame-infernal:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(#800,#d20,#f60,#fa0,#f60,#d20,#800);animation:frame-infernal-blaze 1.2s ease-in-out infinite;z-index:0}.frame-infernal>.avatar-circle,.frame-infernal>.frame-swatch-avatar,.frame-infernal>.levelup-frame-avatar,.frame-infernal>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-infernal-blaze{0%,to{box-shadow:0 0 0 2px #dc500073,0 0 24px #dc5000e6;filter:brightness(1) saturate(1)}50%{box-shadow:0 0 0 3px #ff8c0099,0 0 44px #ff5000;filter:brightness(1.35) saturate(1.35)}}.frame-ethereal{padding:6px;background:transparent}.frame-ethereal:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(#0fc,#0af,#80f,#f0a,#0fc);animation:frame-ethereal-aurora 4s linear infinite;z-index:0}.frame-ethereal>.avatar-circle,.frame-ethereal>.frame-swatch-avatar,.frame-ethereal>.levelup-frame-avatar,.frame-ethereal>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-ethereal-aurora{0%{filter:hue-rotate(0deg) brightness(1);box-shadow:0 0 0 2px #00ffb466,0 0 30px #00c8ffd9}50%{filter:hue-rotate(180deg) brightness(1.25);box-shadow:0 0 0 3px #b400ff8c,0 0 48px #6400fff2}to{filter:hue-rotate(360deg) brightness(1);box-shadow:0 0 0 2px #00ffb466,0 0 30px #00c8ffd9}}.frame-apex{padding:6px;background:transparent}.frame-apex:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(#b8860b,gold,#fffacd,gold,#fa0,gold,#fffacd,gold,#b8860b);animation:frame-apex-crown 1.4s ease-in-out infinite;z-index:0}.frame-apex>.avatar-circle,.frame-apex>.frame-swatch-avatar,.frame-apex>.levelup-frame-avatar,.frame-apex>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-apex-crown{0%,to{box-shadow:0 0 0 2px #ffd70080,0 0 0 5px #ffd70026,0 0 32px #ffd700e6;filter:brightness(1) saturate(1.1)}50%{box-shadow:0 0 0 3px #ffe600b3,0 0 0 7px #ffd70047,0 0 56px #ffdc00;filter:brightness(1.45) saturate(1.35)}}.frame-iron-forge{padding:6px;background:transparent}.frame-iron-forge:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#333,#888 30%,#ccc,#888 70%,#333);box-shadow:0 0 0 2px #444,0 0 0 4px #222,0 0 12px #ff960033;z-index:0}.frame-iron-forge>.avatar-circle,.frame-iron-forge>.frame-swatch-avatar,.frame-iron-forge>.levelup-frame-avatar,.frame-iron-forge>.customize-preview-circle{position:relative;z-index:1}.frame-ember-ring{padding:6px;background:transparent}.frame-ember-ring:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#f20,#ff6000 30%,#fa0,#ff6000 70%,#f20);animation:frame-ember-blaze 1.4s ease-in-out infinite;z-index:0}.frame-ember-ring>.avatar-circle,.frame-ember-ring>.frame-swatch-avatar,.frame-ember-ring>.levelup-frame-avatar,.frame-ember-ring>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-ember-blaze{0%,to{box-shadow:0 0 0 2px #ff640066,0 0 20px #ff5000b3,0 0 40px #ff3c004d}50%{box-shadow:0 0 0 3px #ff8c0099,0 0 36px #ff6400,0 0 60px #ff3c0080}}.frame-molten-ring,.frame-molten-pulse{background:transparent}.frame-lightning-arc{padding:5px;background:transparent}.frame-lightning-arc:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#04f,#0af 30%,#8df,#0af 70%,#04f);animation:frame-lightning-arc-pulse 1.6s ease-in-out infinite;z-index:0}.frame-lightning-arc>.avatar-circle,.frame-lightning-arc>.frame-swatch-avatar,.frame-lightning-arc>.levelup-frame-avatar,.frame-lightning-arc>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-lightning-arc-pulse{0%,to{box-shadow:0 0 0 2px #00aaff4d,0 0 18px #0afc,0 0 36px #0064ff66}50%{box-shadow:0 0 0 3px #00c8ff80,0 0 32px #00c8ff,0 0 56px #0064ff99}}.frame-neon-arc{padding:6px;background:transparent}.frame-neon-arc:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#f0c,#c0f 30%,#0cf,#c0f 70%,#f0c);animation:frame-neon-arc-glow 1.8s ease-in-out infinite;z-index:0}.frame-neon-arc>.avatar-circle,.frame-neon-arc>.frame-swatch-avatar,.frame-neon-arc>.levelup-frame-avatar,.frame-neon-arc>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-neon-arc-glow{0%,to{box-shadow:0 0 0 2px #ff00c84d,0 0 20px #c800ffcc,0 0 40px #6400ff66}50%{box-shadow:0 0 0 3px #ff00ff80,0 0 36px #f0f,0 0 64px #6400ff99}}.frame-alpine-crest{padding:6px;background:transparent}.frame-alpine-crest:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#1b3a5c,#5ba3d9 30%,#d4eaf7,#5ba3d9 70%,#1b3a5c);box-shadow:0 0 0 2px #5ba3d94d,0 0 16px #5ba3d980;z-index:0}.frame-alpine-crest>.avatar-circle,.frame-alpine-crest>.frame-swatch-avatar,.frame-alpine-crest>.levelup-frame-avatar,.frame-alpine-crest>.customize-preview-circle{position:relative;z-index:1}.frame-glacier-halo{padding:7px;background:transparent}.frame-glacier-halo:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#003060,#3ad,#adf 50%,#fff,#adf 80%,#3ad,#003060);animation:frame-glacier-shimmer 2.2s ease-in-out infinite;z-index:0}.frame-glacier-halo>.avatar-circle,.frame-glacier-halo>.frame-swatch-avatar,.frame-glacier-halo>.levelup-frame-avatar,.frame-glacier-halo>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-glacier-shimmer{0%,to{box-shadow:0 0 0 3px #aadcff33,0 0 22px #33aaddb3,0 0 44px #0050a04d;filter:brightness(1)}50%{box-shadow:0 0 0 4px #c8f0ff66,0 0 36px #64c8ff,0 0 60px #0078dc80;filter:brightness(1.2)}}.frame-circuit{padding:5px;background:transparent}.frame-circuit:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#054,#0fc 30%,#4fe,#0fc 70%,#054);animation:frame-circuit-pulse 1.8s ease-in-out infinite;z-index:0}.frame-circuit>.avatar-circle,.frame-circuit>.frame-swatch-avatar,.frame-circuit>.levelup-frame-avatar,.frame-circuit>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-circuit-pulse{0%,to{box-shadow:0 0 0 2px #00ffc833,0 0 16px #00ffc8b3,0 0 32px #00c89666}50%{box-shadow:0 0 0 3px #00ffdc66,0 0 28px #00ffc8,0 0 50px #00c89699}}.frame-synthwave-ring{padding:7px;background:transparent}.frame-synthwave-ring:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#f0f,#a0f,#50f,#a0f,#f0f);animation:frame-synthwave-glow 2s ease-in-out infinite;z-index:0}.frame-synthwave-ring>.avatar-circle,.frame-synthwave-ring>.frame-swatch-avatar,.frame-synthwave-ring>.levelup-frame-avatar,.frame-synthwave-ring>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-synthwave-glow{0%,to{box-shadow:0 0 0 3px #c800ff33,0 0 20px #ff00ffb3,0 0 40px #6400c866}50%{box-shadow:0 0 0 4px #f0f6,0 0 36px #f0f,0 0 60px #9600ff99}}.frame-cosmic-throne{padding:7px;background:transparent}.frame-cosmic-throne:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 0deg,gold,#9b59b6,#3498db,#2ecc71,#e74c3c,gold);animation:frame-cosmic-spin 4s linear infinite;z-index:0}.frame-cosmic-throne>.avatar-circle,.frame-cosmic-throne>.frame-swatch-avatar,.frame-cosmic-throne>.levelup-frame-avatar,.frame-cosmic-throne>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-cosmic-spin{0%{filter:hue-rotate(0deg);box-shadow:0 0 0 3px #6400c84d,0 0 24px #b464ffb3,0 0 48px #64009666}50%{filter:hue-rotate(180deg);box-shadow:0 0 0 4px #c800ff80,0 0 40px #f0f,0 0 70px #6400c899}to{filter:hue-rotate(360deg);box-shadow:0 0 0 3px #6400c84d,0 0 24px #b464ffb3,0 0 48px #64009666}}.frame-abyssal{padding:7px;background:transparent}.frame-abyssal:before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 50% -50%,#80f,#1a0030 40%,#000 70%);box-shadow:0 0 0 2px #1a0030,0 0 0 4px #000,0 0 24px #6400c880;z-index:0}.frame-abyssal>.avatar-circle,.frame-abyssal>.frame-swatch-avatar,.frame-abyssal>.levelup-frame-avatar,.frame-abyssal>.customize-preview-circle{position:relative;z-index:1}.frame-apex-glow{padding:6px;background:transparent}.frame-apex-glow:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(#b8860b,gold,#fffacd,gold,#fa0,gold,#fffacd,gold,#b8860b);animation:frame-apex-glow-pulse 1.2s ease-in-out infinite;z-index:0}.frame-apex-glow>.avatar-circle,.frame-apex-glow>.frame-swatch-avatar,.frame-apex-glow>.levelup-frame-avatar,.frame-apex-glow>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-apex-glow-pulse{0%,to{box-shadow:0 0 0 2px #ffd70080,0 0 0 5px #ffd70026,0 0 32px #ffd700e6;filter:brightness(1)}50%{box-shadow:0 0 0 4px #ffe600cc,0 0 0 8px #ffd7004d,0 0 64px #ffdc00;filter:brightness(1.6)}}.frame-infernal-pulse{padding:5px;background:transparent}.frame-infernal-pulse:before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(#800,#d20,#f60,#fa0,#f60,#d20,#800);animation:frame-infernal-pulse-blaze 1s ease-in-out infinite;z-index:0}.frame-infernal-pulse>.avatar-circle,.frame-infernal-pulse>.frame-swatch-avatar,.frame-infernal-pulse>.levelup-frame-avatar,.frame-infernal-pulse>.customize-preview-circle{position:relative;z-index:1}@keyframes frame-infernal-pulse-blaze{0%,to{box-shadow:0 0 0 2px #ff55004d,0 0 22px #f50c;filter:brightness(1) saturate(1)}50%{box-shadow:0 0 0 4px #f509,0 0 44px #f50,0 0 70px #ff280099;filter:brightness(1.5) saturate(1.4)}}.banner-forge{background:linear-gradient(135deg,#1a0500,#3d1100 30%,#7a3500 55%,#c86400 75%,#ff9a3c)!important}.banner-molten{background:radial-gradient(ellipse at 30% 70%,#ff4500,#c20,#600 60%,#1a0000)!important}.banner-iron-city{background:repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0px,rgba(255,255,255,.03) 1px,transparent 1px,transparent 40px),linear-gradient(180deg,#1a1a1a,#2d2d2d 40%,#444,#1a1a1a)!important}.banner-anvil{background:linear-gradient(160deg,#0a0a0a,#1f1f1f 40%,#3a3a3a 70%,#5c5c5c 90%,#888)!important}.banner-ember{background:radial-gradient(ellipse at 50% 100%,#ff6000,#c30 25%,#400 60%,#0d0000)!important}.banner-afterburn{background:linear-gradient(105deg,#000,#1a0030 20%,#3d00a0 50%,#80f,#f0a)!important}.banner-neon-dash{background:repeating-linear-gradient(70deg,transparent,transparent 38px,rgba(0,255,255,.06) 38px,rgba(0,255,255,.06) 40px),repeating-linear-gradient(70deg,transparent,transparent 58px,rgba(255,0,200,.05) 58px,rgba(255,0,200,.05) 60px),linear-gradient(105deg,#050510,#0a0025)!important}.banner-voltage{background:linear-gradient(135deg,#000814,#001d3d 40%,#003566,#0077b6)!important}.banner-supersonic{background:linear-gradient(100deg,#000,#12002f,#5200a3 60%,#be00ff 85%,#ff006e)!important}.banner-turbine{background:conic-gradient(from 200deg at 110% 50%,#000,#013,#026,#04c,#026,#000 300deg)!important}.banner-alpine{background:linear-gradient(180deg,#1a3a5c,#2d6a9f 35%,#5ba3d9 60%,#4d8fbf,#2a6a9a)!important}.banner-peak{background:linear-gradient(165deg,#0d1b2a,#1b3a5c,#2d6a9f,#5a8ab4,#3a6a99)!important}.banner-glacier{background:linear-gradient(135deg,#003060,#0066a0 30%,#3ad 55%,#28b 75%,#1166a0)!important}.banner-highland{background:linear-gradient(180deg,#1a3300,#2e5c00 25%,#4d9900,#70cc33,#38a 85%,#1a6688)!important}.banner-storm-peak{background:radial-gradient(ellipse at 70% 20%,rgba(200,220,255,.15) 0%,transparent 50%),linear-gradient(160deg,#0a0a14,#1a1a2e 30%,#2d3a5c 55%,#4a5c80 75%,#8099c0)!important}.banner-vice-city{background:repeating-linear-gradient(45deg,rgba(255,0,255,.04) 0px,rgba(255,0,255,.04) 1px,transparent 1px,transparent 20px),repeating-linear-gradient(-45deg,rgba(0,255,255,.03) 0px,rgba(0,255,255,.03) 1px,transparent 1px,transparent 30px),linear-gradient(135deg,#0d001a,#1a0033 30%,#2d0055 55%,#507 75%,#203)!important}.banner-grid-night{background:linear-gradient(rgba(0,255,200,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,200,.07) 1px,transparent 1px),linear-gradient(160deg,#020209,#050518,#080824)!important;background-size:30px 30px,30px 30px,100% 100%!important}.banner-synthwave{background:linear-gradient(175deg,#102,#204 30%,#60a,#f0f 80%,#f60)!important}.banner-arcade{background:repeating-linear-gradient(0deg,rgba(255,255,0,.04) 0px,rgba(255,255,0,.04) 2px,transparent 2px,transparent 24px),linear-gradient(135deg,#04040e,#0a0a20)!important}.banner-downtown{background:radial-gradient(ellipse at 50% 100%,#603,#302,#0d000e 70%,#000)!important}.banner-celestial-war{background:radial-gradient(ellipse at 20% 50%,rgba(255,215,0,.12) 0%,transparent 40%),radial-gradient(ellipse at 80% 30%,rgba(100,0,255,.15) 0%,transparent 40%),linear-gradient(135deg,#000428,#004e92,#6a0dad 60%,#e040fb 85%,gold)!important}.banner-infernal-rise{background:radial-gradient(ellipse at 50% 110%,rgba(255,100,0,.3) 0%,transparent 50%),linear-gradient(135deg,#0a0000,#3d0000,#900 50%,#c30 70%,#f60,#fa0)!important}.banner-apex-prime{background:radial-gradient(ellipse at 50% 50%,rgba(255,215,0,.15) 0%,transparent 60%),linear-gradient(135deg,#1a1200,#3d2a00,#856200 40%,#c6a94b 55%,#e8c060,gold 75%,#c6a94b 88%,#1a1200)!important}.banner-void-rift{background:radial-gradient(ellipse at 40% 50%,rgba(120,0,255,.2) 0%,transparent 35%),radial-gradient(ellipse at 70% 40%,rgba(0,200,255,.1) 0%,transparent 30%),linear-gradient(135deg,#000,#0d0221 30%,#1a0050,#000 80%,#1a0221)!important}.banner-prism-break{background:linear-gradient(100deg,#c00,#c50,#aa0,#080,#00c,#60c,#c00)!important}.groups-container{display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1rem);padding-bottom:2rem}.group-section-card{background:var(--bg-primary);border-radius:16px;padding:clamp(1rem,3vw,1.25rem);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:.75rem}.group-section-header{display:flex;align-items:center;justify-content:space-between}.group-section-title{font-size:clamp(.9rem,2.5vw,1rem);font-weight:700;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.group-count-badge{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;font-size:.7rem;font-weight:700;min-width:1.25rem;height:1.25rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0 .35rem}.group-tag-pill{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.75rem;font-weight:800;letter-spacing:.06em;padding:.3rem .6rem;border-radius:8px;flex-shrink:0;min-width:2.5rem;text-align:center}.group-tag-pill.sm{font-size:.65rem;padding:.2rem .45rem;border-radius:6px}.groups-list{display:flex;flex-direction:column;gap:.5rem}.group-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary, rgba(255,255,255,.04));border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:12px;cursor:pointer;transition:background .15s,transform .1s;text-align:left;width:100%}.group-card:hover{background:var(--bg-hover, rgba(102,126,234,.08));transform:translateY(-1px)}.group-card-info{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.group-card-name{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-card-meta{font-size:.78rem;color:var(--text-secondary)}.group-card-arrow{font-size:1.4rem;color:var(--text-secondary);line-height:1}.group-invite-card{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border-color, rgba(255,255,255,.06))}.group-invite-card:last-child{border-bottom:none}.group-search-result{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border-color, rgba(255,255,255,.06))}.group-search-result:last-child{border-bottom:none}.group-create-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;padding:.35rem .9rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.group-create-btn:hover{opacity:.88;transform:translateY(-1px)}.groups-back-btn{background:none;border:none;color:#667eea;font-size:.9rem;font-weight:600;cursor:pointer;padding:.25rem 0;align-self:flex-start}.groups-back-btn:hover{text-decoration:underline}.group-detail-card{background:linear-gradient(135deg,#667eea1f,#764ba21f);border:1px solid rgba(102,126,234,.3);border-radius:16px;padding:clamp(1rem,3vw,1.5rem);display:flex;flex-direction:column;gap:.75rem}.group-detail-header{display:flex;align-items:flex-start;gap:1rem}.group-detail-meta{display:flex;flex-direction:column;gap:.25rem}.group-detail-name{font-size:clamp(1.1rem,3vw,1.4rem);font-weight:800;color:var(--text-primary);margin:0}.group-detail-info{font-size:.82rem;color:var(--text-secondary)}.group-detail-desc{font-size:.9rem;color:var(--text-secondary);margin:0;line-height:1.5}.group-members-list{display:flex;flex-direction:column;gap:.5rem}.group-member-row,.group-request-row{display:flex;align-items:center;gap:.6rem;padding:.4rem 0;border-bottom:1px solid var(--border-color, rgba(255,255,255,.06))}.group-member-row:last-child,.group-request-row:last-child{border-bottom:none}.group-member-avatar{font-size:1.4rem;flex-shrink:0;line-height:1}.group-member-name{flex:1;font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.group-role-badge{font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:.15rem .5rem;border-radius:999px;flex-shrink:0}.group-role-badge.owner,.group-role-badge.leader{background:#ffc4002e;color:#ffc400}.group-role-badge.admin,.group-role-badge.officer{background:#667eea2e;color:#667eea}.group-role-action-btn{font-size:.72rem;font-weight:700;padding:.2rem .55rem;border-radius:6px;background:#667eea1a;color:#667eea;border:1px solid rgba(102,126,234,.25);cursor:pointer;transition:background .15s;white-space:nowrap}.group-role-action-btn:hover{background:#667eea33}.group-kick-btn{font-size:.72rem;font-weight:700;padding:.2rem .55rem;border-radius:6px;background:#e74c3c1a;color:#e74c3c;border:1px solid rgba(231,76,60,.3);cursor:pointer;transition:background .15s;white-space:nowrap}.group-kick-btn:hover{background:#e74c3c33}.group-row-actions{display:flex;gap:.4rem;flex-shrink:0}.group-invite-info{flex:1;display:flex;flex-direction:column;min-width:0}.group-invite-handle{font-size:.75rem;color:var(--text-secondary)}.group-visibility-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.group-visibility-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.group-lb-rank{font-size:1rem;min-width:2rem;text-align:center;flex-shrink:0;line-height:1}.group-xp-chip{font-size:.78rem;font-weight:700;color:#667eea;background:#667eea1f;padding:.15rem .5rem;border-radius:999px;flex-shrink:0;white-space:nowrap}.group-leave-btn{background:#e74c3c1f;color:#e74c3c;border:1px solid rgba(231,76,60,.3);border-radius:12px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;width:100%}.group-leave-btn:hover{background:#e74c3c38}.group-detail-location{font-size:.82rem;color:#667eea;font-weight:500;margin-top:.1rem}.group-location-section{padding-top:.65rem;border-top:1px solid var(--border-color, rgba(255,255,255,.08))}.group-location-toggle{background:none;border:none;color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;padding:0;transition:color .15s}.group-location-toggle:hover{color:#667eea}.group-location-editor{display:flex;flex-direction:column;gap:.5rem}.group-location-input-row{display:flex;gap:.5rem;align-items:center}.group-location-input{flex:1;padding:.5rem .75rem;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:.88rem;font-family:inherit;outline:none;transition:border-color .15s}.group-location-input:focus{border-color:#667eea}.group-location-gps-btn{flex-shrink:0;padding:.45rem .8rem;background:#667eea1f;border:1.5px solid rgba(102,126,234,.3);border-radius:8px;color:#667eea;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.group-location-gps-btn:hover:not(:disabled){background:#667eea33}.group-location-gps-btn:disabled{opacity:.5;cursor:default}.group-location-coords-hint{margin:0;font-size:.72rem;color:var(--text-secondary);font-style:italic}.group-location-actions{display:flex;justify-content:flex-end;gap:.5rem}.group-rec-hint{font-size:.7rem;color:var(--text-secondary);font-weight:500;flex-shrink:0}.group-rec-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border-color, rgba(255,255,255,.06))}.group-rec-row:last-child{border-bottom:none}.group-rec-meta-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-top:.15rem}.group-rec-badge{font-size:.62rem;font-weight:700;padding:.15rem .45rem;border-radius:999px;flex-shrink:0;letter-spacing:.02em}.group-rec-badge-active{background:#e7761e1f;color:#e7761e}.group-rec-badge-near{background:#667eea1f;color:#667eea}.squad-challenge-meta-row{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}.squad-challenge-name{font-size:1rem;font-weight:700;color:var(--text-primary);flex:1;min-width:0}.squad-type-chip{font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:#667eea26;color:#667eea;padding:.2rem .55rem;border-radius:999px;flex-shrink:0}.squad-challenge-deadline-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.squad-deadline-text{font-size:.8rem;color:var(--text-secondary)}.squad-close-btn{background:none;border:1px solid rgba(231,76,60,.4);border-radius:6px;color:#e74c3c;font-size:.75rem;font-weight:600;padding:.2rem .55rem;cursor:pointer;transition:background .15s}.squad-close-btn:hover{background:#e74c3c1a}.squad-score-submit-row{display:flex;gap:.5rem;align-items:center}.squad-score-input{flex:1;padding:.5rem .75rem;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:.88rem;outline:none;transition:border-color .15s}.squad-score-input:focus{border-color:#667eea}.squad-my-score-banner{margin:0;padding:.45rem .75rem;background:#667eea1a;border:1px solid rgba(102,126,234,.25);border-radius:8px;font-size:.85rem;color:var(--text-primary)}.squad-scores-list{display:flex;flex-direction:column;gap:.35rem}.squad-scores-label{margin:0 0 .15rem;font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.squad-score-row{display:flex;align-items:center;gap:.6rem;padding:.35rem .5rem;border-radius:8px;background:var(--bg-secondary)}.squad-score-row.squad-score-mine{background:#667eea1a;border:1px solid rgba(102,126,234,.2)}.squad-score-name{flex:1;font-size:.88rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.squad-score-value{font-size:.88rem;font-weight:700;color:#667eea;flex-shrink:0}.group-event-card{display:flex;flex-direction:column;gap:.4rem;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:12px}.group-event-card.group-event-past{opacity:.55}.group-event-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.group-event-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.group-event-date{font-size:.75rem;color:#667eea;font-weight:600;flex-shrink:0}.group-event-desc{margin:0;font-size:.82rem;color:var(--text-secondary);line-height:1.45}.group-event-location{margin:0;font-size:.8rem;color:var(--text-secondary)}.group-event-counts{display:flex;gap:.75rem;font-size:.78rem;color:var(--text-secondary)}.group-event-rsvp-row{display:flex;gap:.4rem;flex-wrap:wrap}.group-rsvp-btn{padding:.28rem .7rem;background:var(--bg-tertiary, rgba(255,255,255,.05));border:1.5px solid var(--border-primary);border-radius:999px;color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.group-rsvp-btn:hover{border-color:#667eea;color:#667eea}.group-rsvp-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff}.group-member-col{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.group-member-alltime{font-size:.7rem;color:var(--text-secondary)}.group-xp-col{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.group-active-fire{font-size:.9rem;line-height:1}.group-select{padding:.4rem .65rem;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:.88rem;outline:none;cursor:pointer;transition:border-color .15s}.group-select:focus{border-color:#667eea}.group-datetime-input{padding:.4rem .65rem;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:.85rem;outline:none;transition:border-color .15s;color-scheme:dark}.group-datetime-input:focus{border-color:#667eea}.group-detail-tabs{display:flex;gap:.25rem;padding:.15rem;background:var(--bg-secondary, rgba(255,255,255,.04));border-radius:12px;border:1px solid var(--border-color, rgba(255,255,255,.08))}.group-detail-tab{flex:1;padding:.5rem .75rem;background:none;border:none;border-radius:9px;font-size:.84rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s;display:flex;align-items:center;justify-content:center;gap:.4rem;white-space:nowrap}.group-detail-tab:hover{color:var(--text-primary);background:var(--bg-hover, rgba(102,126,234,.06))}.group-detail-tab.active{background:linear-gradient(135deg,#667eea2e,#764ba22e);color:#667eea}.group-tab-badge{background:#667eea;color:#fff;font-size:.62rem;font-weight:800;min-width:1.1rem;height:1.1rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0 .3rem;line-height:1}.group-chat-card{background:var(--bg-primary);border-radius:16px;padding:0;box-shadow:var(--shadow-md);display:flex;flex-direction:column;overflow:hidden;min-height:0}.group-chat-messages{flex:1;overflow-y:auto;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.1rem;min-height:280px;max-height:420px;scroll-behavior:smooth}.group-chat-messages::-webkit-scrollbar{width:4px}.group-chat-messages::-webkit-scrollbar-track{background:transparent}.group-chat-messages::-webkit-scrollbar-thumb{background:var(--border-color, rgba(255,255,255,.12));border-radius:999px}.group-chat-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:2.5rem 1rem;font-size:.88rem;color:var(--text-secondary);text-align:center;min-height:200px}.group-chat-row{display:flex;flex-direction:column;align-items:flex-start;margin-top:.65rem}.group-chat-row.own{align-items:flex-end}.group-chat-row+.group-chat-row{margin-top:.15rem}.group-chat-row.first-in-group{margin-top:.65rem}.group-chat-sender{display:flex;align-items:center;gap:.4rem;margin-bottom:.2rem;padding:0 .25rem}.group-chat-sender-name{font-size:.75rem;font-weight:700;color:var(--text-secondary)}.group-chat-role-pill{font-size:.6rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:.1rem .4rem;border-radius:999px;flex-shrink:0}.group-chat-role-pill.leader{background:#ffc40026;color:#ffc400}.group-chat-role-pill.officer{background:#667eea26;color:#667eea}.group-chat-bubble{max-width:min(72%,320px);padding:.5rem .75rem;background:var(--bg-secondary, rgba(255,255,255,.06));border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:16px 16px 16px 4px;display:flex;flex-direction:column;gap:.2rem}.group-chat-bubble.own{background:linear-gradient(135deg,#667eea38,#764ba238);border-color:#667eea4d;border-radius:16px 16px 4px}.group-chat-bubble.no-tail{border-radius:16px}.group-chat-text{font-size:.88rem;color:var(--text-primary);line-height:1.45;word-break:break-word}.group-chat-time{font-size:.65rem;color:var(--text-secondary);align-self:flex-end;opacity:.7}.group-chat-input-row{display:flex;gap:.5rem;align-items:center;padding:.6rem .75rem;border-top:1px solid var(--border-color, rgba(255,255,255,.08));background:var(--bg-primary)}.group-chat-input{flex:1;padding:.5rem .85rem;background:var(--bg-secondary, rgba(255,255,255,.05));border:1.5px solid var(--border-color, rgba(255,255,255,.1));border-radius:999px;color:var(--text-primary);font-size:.88rem;font-family:inherit;outline:none;transition:border-color .15s}.group-chat-input:focus{border-color:#667eea}.group-chat-input::placeholder{color:var(--text-secondary);opacity:.6}.group-chat-send-btn{flex-shrink:0;width:2.2rem;height:2.2rem;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s,transform .1s}.group-chat-send-btn:hover:not(:disabled){opacity:.85;transform:scale(1.06)}.group-chat-send-btn:disabled{opacity:.35;cursor:default}.social-container{padding:clamp(.5rem,2vw,1rem);max-width:800px;margin:0 auto;width:100%}.social-tabs{display:flex;background:var(--bg-tertiary);border-radius:50px;padding:4px;margin-bottom:clamp(1rem,2.5vw,1.5rem)}.social-tab{flex:1;padding:clamp(.6rem,1.8vw,.8rem);background:transparent;border:none;border-radius:50px;font-size:clamp(.95rem,2vw,1.1rem);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .25s ease;white-space:nowrap}.social-tab:hover{color:#667eea;background:#667eea1a}.social-tab.active{background:linear-gradient(135deg,#667eea,#e74c3c);color:var(--bg-primary);box-shadow:0 2px 8px #667eea59}.social-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.1rem;height:1.1rem;padding:0 .3rem;margin-left:.35rem;background:#e74c3c;color:#fff;font-size:.65rem;font-weight:700;border-radius:99px;line-height:1;vertical-align:middle}.social-tab.active .social-tab-badge{background:#ffffff4d}.invite-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,#667eea1f,#e74c3c1a);border:1px solid rgba(102,126,234,.25);border-radius:14px;padding:clamp(.9rem,2.5vw,1.2rem) clamp(1rem,3vw,1.5rem);margin-bottom:clamp(.75rem,2vw,1rem)}.invite-card-text{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.invite-card-title{font-size:clamp(.95rem,2vw,1.05rem);font-weight:700;color:var(--text-primary)}.invite-card-blurb{font-size:clamp(.8rem,1.8vw,.88rem);color:var(--text-secondary);line-height:1.4}.invite-btn{flex-shrink:0;padding:.55rem 1.2rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;border:none;border-radius:50px;font-size:clamp(.85rem,1.8vw,.95rem);font-weight:700;cursor:pointer;white-space:nowrap;transition:opacity .2s}.invite-btn:hover{opacity:.85}.feed-section{display:flex;flex-direction:column;gap:clamp(1rem,2.5vw,1.25rem)}.feed-filters{display:flex;gap:.75rem;margin-bottom:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-primary)}.filter-btn{flex:1;padding:.75rem 1rem;background:var(--bg-primary);color:var(--text-secondary);border:2px solid var(--border-primary);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.filter-btn:hover{background:var(--bg-tertiary);border-color:var(--border-secondary)}.filter-btn.active{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;border-color:#667eea;box-shadow:var(--shadow-sm)}.post-card{background:var(--bg-primary);border-radius:12px;padding:clamp(1rem,3vw,1.5rem);box-shadow:var(--shadow-md);transition:box-shadow .3s ease}.post-card:hover{box-shadow:var(--shadow-lg)}.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:clamp(.75rem,2vw,1rem)}.post-user{display:flex;align-items:center;gap:clamp(.6rem,1.5vw,.75rem)}.social-post-frame,.social-friend-frame,.social-search-frame,.social-rec-frame{flex-shrink:0;line-height:0}.user-avatar{font-size:clamp(1.75rem,3.5vw,2.25rem);width:clamp(2.5rem,5vw,3rem);height:clamp(2.5rem,5vw,3rem);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:50%}.user-avatar-img{width:clamp(2.5rem,5vw,3rem);height:clamp(2.5rem,5vw,3rem);border-radius:50%;object-fit:cover;border:2px solid var(--border-primary)}.user-details{display:flex;flex-direction:column}.user-name{font-weight:700;font-size:clamp(.95rem,2vw,1.1rem);color:var(--text-primary)}.user-name-row{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.user-feat-badge{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;background:#667eea26;border:1px solid rgba(102,126,234,.3);flex-shrink:0}.post-time{font-size:clamp(.75rem,1.8vw,.85rem);color:var(--text-tertiary)}.post-type-icon{font-size:clamp(1.25rem,2.5vw,1.5rem)}.post-content{margin-bottom:clamp(.75rem,2vw,1rem)}.post-text{font-size:clamp(.95rem,2vw,1.05rem);color:var(--text-primary);line-height:1.5;margin:0 0 clamp(.5rem,1.5vw,.75rem) 0}.post-details{background:linear-gradient(135deg,#667eea1a,#e74c3c1a);padding:clamp(.6rem,2vw,.75rem) clamp(.75rem,2.5vw,1rem);border-radius:8px;font-size:clamp(.9rem,2vw,1rem);color:#667eea;font-weight:600;display:flex;align-items:center;justify-content:space-between}.post-badge{font-size:clamp(1.25rem,2.5vw,1.5rem)}.post-score{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;padding:clamp(.5rem,1.5vw,.6rem) clamp(.75rem,2vw,1rem);border-radius:8px;font-size:clamp(.9rem,2vw,1rem);font-weight:600;margin-top:clamp(.5rem,1.5vw,.75rem);display:inline-block}.score-value{font-size:clamp(1rem,2.5vw,1.2rem);margin-left:.5rem}.post-stats{display:flex;gap:clamp(1rem,3vw,1.5rem);padding:clamp(.5rem,1.5vw,.75rem) 0;border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary);margin-bottom:clamp(.5rem,1.5vw,.75rem)}.stat-item{font-size:clamp(.85rem,1.8vw,.95rem);color:var(--text-secondary);font-weight:500}.post-actions{display:flex;gap:clamp(.5rem,2vw,1rem)}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:clamp(.5rem,1.5vw,.65rem);background:transparent;border:none;border-radius:8px;cursor:pointer;font-size:clamp(.9rem,2vw,1rem);font-weight:600;color:var(--text-secondary);transition:all .3s ease}.action-btn:hover{background:#667eea1a;color:#667eea}.action-btn.liked{color:#e53e3e}.action-icon{font-size:clamp(1.1rem,2.5vw,1.3rem)}.comments-section{margin-top:clamp(.75rem,2vw,1rem);padding-top:clamp(.75rem,2vw,1rem);border-top:1px solid var(--border-primary)}.comment-item{margin-bottom:clamp(.75rem,2vw,1rem);padding:clamp(.6rem,1.5vw,.75rem);background:var(--bg-secondary);border-radius:8px}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.comment-user{font-weight:700;font-size:clamp(.85rem,1.8vw,.95rem);color:#667eea}.comment-time{font-size:clamp(.75rem,1.6vw,.8rem);color:var(--text-tertiary)}.comment-text{font-size:clamp(.9rem,1.8vw,1rem);color:var(--text-primary);margin:0;line-height:1.4}.comment-input-container{display:flex;gap:clamp(.5rem,1.5vw,.75rem);margin-top:clamp(.75rem,2vw,1rem)}.comment-input{flex:1;padding:clamp(.6rem,1.5vw,.75rem);border:2px solid var(--border-primary);border-radius:8px;font-size:clamp(.9rem,2vw,1rem);transition:border-color .3s ease}.comment-input:focus{outline:none;border-color:#667eea}.comment-submit-btn{padding:clamp(.6rem,1.5vw,.75rem) clamp(1rem,2.5vw,1.25rem);background:linear-gradient(135deg,#667eea,#e74c3c);color:var(--bg-primary);border:none;border-radius:8px;font-weight:600;font-size:clamp(.9rem,2vw,1rem);cursor:pointer;transition:transform .2s ease}.comment-submit-btn:hover{transform:translateY(-2px)}.friends-section{padding:clamp(.5rem,1.5vw,1rem)}.pending-requests-section{margin-bottom:1.5rem;background:var(--bg-secondary);border-radius:12px;padding:1rem;border:1px solid var(--border-primary)}.pending-requests-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.pending-requests-badge{background:var(--accent-primary);color:#fff;font-size:.72rem;font-weight:700;border-radius:999px;padding:.1rem .5rem;line-height:1.4}.friends-grid{display:flex;flex-direction:column;gap:.6rem}.friend-card{background:var(--bg-primary);border-radius:14px;padding:.75rem 1rem;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:.85rem;transition:background .2s}.friend-card:hover{background:var(--bg-secondary)}.friend-avatar-large{flex-shrink:0;font-size:1.3rem;width:46px;height:46px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:50%;overflow:hidden;object-fit:cover}img.friend-avatar-large{background:none}.friend-card-info{flex:1;min-width:0}.friend-name{font-size:.95rem;color:var(--text-primary);font-weight:700;margin:0 0 .2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-stats{display:flex;gap:.9rem}.friend-stat{display:flex;align-items:baseline;gap:.25rem}.stat-value{font-size:.88rem;font-weight:700;color:#667eea}.stat-label{font-size:.75rem;color:var(--text-secondary)}.friend-action-btn{flex-shrink:0;padding:.45rem 1rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;border:none;border-radius:50px;font-weight:600;font-size:.82rem;cursor:pointer;transition:opacity .2s;white-space:nowrap}.friend-action-btn:hover{opacity:.85}.search-section{padding:clamp(.5rem,1.5vw,1rem)}.search-bar-container{display:flex;gap:.5rem;margin-bottom:clamp(1.25rem,3vw,1.5rem)}.search-input{flex:1;min-width:0;padding:clamp(.75rem,2vw,1rem) clamp(1rem,2.5vw,1.25rem);border:2px solid var(--border-primary);border-radius:12px;font-size:clamp(.95rem,2vw,1.05rem);transition:border-color .3s ease;box-sizing:border-box;background:var(--bg-primary);color:var(--text-primary)}.search-input:focus{outline:none;border-color:#667eea}.search-icon{font-size:1.1rem;line-height:1}.search-results-title{font-size:clamp(1.1rem,2.5vw,1.3rem);color:var(--text-primary);margin:0 0 clamp(1rem,2.5vw,1.25rem) 0;font-weight:700}.search-results{background:var(--bg-primary);border-radius:12px;padding:clamp(1rem,2.5vw,1.25rem);box-shadow:var(--shadow-md)}.user-search-item{display:flex;align-items:center;gap:clamp(.75rem,2vw,1rem);padding:clamp(.75rem,2vw,1rem);border-bottom:1px solid var(--border-primary);transition:background .2s ease}.user-search-item:last-child{border-bottom:none}.user-search-item:hover{background:var(--bg-secondary);border-radius:8px}.search-user-avatar{font-size:clamp(1.5rem,3vw,1.75rem);width:clamp(2.5rem,5vw,3rem);height:clamp(2.5rem,5vw,3rem);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:50%;flex-shrink:0}.search-user-name{flex:1;font-size:clamp(.95rem,2vw,1.05rem);font-weight:600;color:var(--text-primary)}.add-friend-btn,.pending-btn,.friends-btn{padding:clamp(.5rem,1.5vw,.6rem) clamp(.85rem,2.5vw,1.15rem);border:none;border-radius:8px;font-weight:600;font-size:clamp(.85rem,1.8vw,.95rem);cursor:pointer;transition:all .2s ease;white-space:nowrap}.add-friend-btn{background:linear-gradient(135deg,#667eea,#e74c3c);color:var(--bg-primary)}.add-friend-btn:hover{transform:translateY(-2px);box-shadow:0 2px 8px #667eea66}.pending-btn{background:#ffd93d;color:var(--text-primary);cursor:default}.friends-btn{background:#48bb78;color:var(--bg-primary);cursor:default}.no-results{text-align:center;color:var(--text-tertiary);font-size:clamp(.95rem,2vw,1.05rem);padding:clamp(1.5rem,3vw,2rem)}.social-loading{text-align:center;color:#667eea;font-size:clamp(.95rem,2vw,1.05rem);padding:clamp(1.5rem,3vw,2rem);font-weight:600}.search-hint{text-align:center;color:var(--text-tertiary);font-size:clamp(.95rem,2vw,1.05rem);padding:clamp(1.5rem,3vw,2rem);font-style:italic}.search-button{display:flex;align-items:center;justify-content:center;gap:.35rem;flex-shrink:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:0 1.25rem;font-size:.92rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .2s;white-space:nowrap}.search-button:hover{opacity:.88;transform:translateY(-1px)}.search-user-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.search-user-clickable{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0;cursor:pointer}.search-user-clickable:hover .search-user-name{color:#667eea;text-decoration:underline}.search-user-handle{font-size:.82rem;color:#667eea;font-family:monospace;font-weight:600}.search-user-stats{font-size:clamp(.8rem,1.8vw,.9rem);color:var(--text-tertiary)}.requests-section{padding:clamp(.5rem,1.5vw,1rem)}.requests-title{font-size:clamp(1.1rem,2.5vw,1.3rem);color:var(--text-primary);margin:0 0 clamp(1rem,2.5vw,1.25rem) 0;font-weight:700}.requests-list{background:var(--bg-primary);border-radius:12px;padding:clamp(.5rem,1.5vw,.75rem);box-shadow:var(--shadow-md)}.request-item{display:flex;align-items:center;gap:clamp(.75rem,2vw,1rem);padding:clamp(.75rem,2vw,1rem);border-bottom:1px solid var(--border-primary);transition:background .2s ease}.request-item:last-child{border-bottom:none}.request-item:hover{background:var(--bg-secondary);border-radius:8px}.request-avatar{font-size:clamp(1.5rem,3vw,1.75rem);width:clamp(2.5rem,5vw,3rem);height:clamp(2.5rem,5vw,3rem);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#e74c3c);border-radius:50%;flex-shrink:0;object-fit:cover}.request-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.request-name{font-size:clamp(.95rem,2vw,1.05rem);font-weight:600;color:var(--text-primary)}.request-time{font-size:clamp(.8rem,1.8vw,.9rem);color:var(--text-tertiary)}.request-actions{display:flex;gap:.5rem}.accept-btn,.reject-btn{padding:clamp(.5rem,1.5vw,.6rem) clamp(.85rem,2.5vw,1.15rem);border:none;border-radius:8px;font-weight:600;font-size:clamp(.85rem,1.8vw,.95rem);cursor:pointer;transition:all .2s ease;white-space:nowrap}.accept-btn{background:linear-gradient(135deg,#48bb78,#38a169);color:var(--bg-primary)}.accept-btn:hover{transform:translateY(-2px);box-shadow:0 2px 8px #48bb7866}.reject-btn{background:#e53e3e;color:var(--bg-primary)}.reject-btn:hover{transform:translateY(-2px);box-shadow:0 2px 8px #e53e3e66}.recommendations-section{margin-bottom:1.5rem}.recommendations-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem}.recommendations-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0}.friends-list-header{margin-top:.5rem;padding-top:1.25rem;border-top:1px solid var(--border-primary)}.sent-request-chip{flex-shrink:0;padding:.4rem .85rem;border-radius:50px;border:1.5px solid rgba(102,126,234,.4);background:#667eea14;color:#667eea;font-size:.78rem;font-weight:600;white-space:nowrap}.recommendations-loading{display:flex;align-items:center;gap:.6rem;color:var(--text-secondary);font-size:.9rem;padding:.5rem 0}@keyframes recSpin{to{transform:rotate(360deg)}}.rec-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(102,126,234,.2);border-top-color:#667eea;border-radius:50%;animation:recSpin .7s linear infinite;flex-shrink:0}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.85rem}.rec-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.1rem .75rem .85rem;background:var(--bg-primary);border:1.5px solid var(--border-primary);border-radius:14px;text-align:center;transition:box-shadow .2s,border-color .2s}.rec-card:hover{border-color:#667eea;box-shadow:0 4px 16px #667eea1f}.rec-dismiss{position:absolute;top:6px;right:6px;width:20px;height:20px;border:none;background:transparent;color:var(--text-tertiary);font-size:.7rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;padding:0;line-height:1}.rec-dismiss:hover{background:var(--bg-secondary);color:var(--text-primary)}.rec-avatar-wrap{margin-bottom:.2rem}.rec-avatar{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid var(--border-primary)}.rec-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);font-size:1.6rem;border:2px solid var(--border-primary)}.rec-name{font-size:.88rem;font-weight:700;color:var(--text-primary);line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rec-handle{font-size:.75rem;color:#667eea;font-family:monospace;font-weight:600}.rec-mutual{font-size:.75rem;color:var(--text-secondary)}.rec-add-btn{margin-top:.2rem;padding:.35rem .75rem;border:none;border-radius:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.8rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .2s;white-space:nowrap}.rec-add-btn:hover{opacity:.88;transform:translateY(-1px)}.rec-add-btn.accept{background:linear-gradient(135deg,#48bb78,#38a169)}.rec-status-chip{margin-top:.2rem;display:inline-block;padding:.3rem .7rem;border-radius:20px;font-size:.76rem;font-weight:700}.rec-status-chip.friends{background:#48bb7826;color:#38a169}.rec-status-chip.pending{background:#667eea1f;color:#667eea}@media(max-width:768px){.post-actions{flex-direction:row}.action-btn{font-size:clamp(.85rem,2vw,.9rem);padding:clamp(.5rem,1.5vw,.6rem)}.recommendations-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.composer-fab{position:fixed;bottom:clamp(6rem,12vw,8rem);right:clamp(1rem,3vw,1.75rem);width:clamp(48px,7vw,60px);height:clamp(48px,7vw,60px);border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:0 6px 20px #667eea8c;z-index:200;transition:transform .2s,box-shadow .2s}.composer-fab:hover{transform:scale(1.1);box-shadow:0 8px 28px #667eeab3}.composer-fab svg{width:48%;height:48%;display:block}.composer-modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.composer-modal{background:var(--bg-primary);border-radius:18px;width:100%;max-width:520px;box-shadow:0 8px 40px #00000059;overflow:hidden;animation:composer-slide-up .2s ease}@keyframes composer-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.composer-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .75rem;border-bottom:1px solid var(--border-primary)}.composer-modal-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.composer-modal-close{background:none;border:none;color:var(--text-tertiary);font-size:1rem;cursor:pointer;padding:.25rem .5rem;border-radius:50%;line-height:1;transition:background .15s}.composer-modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.composer-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.composer-type-row{display:flex;gap:.5rem;flex-wrap:wrap}.composer-type-btn{padding:.3rem .85rem;border-radius:50px;border:1.5px solid var(--border-primary);background:none;color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.composer-type-btn.active{border-color:#667eea;background:#667eea18;color:#667eea}.composer-textarea{width:100%;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:10px;padding:.75rem 1rem;font-size:.95rem;color:var(--text-primary);resize:none;font-family:inherit;line-height:1.5;box-sizing:border-box;transition:border-color .15s}.composer-textarea:focus{outline:none;border-color:#667eea}.composer-score-input{width:100%;background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:10px;padding:.6rem 1rem;font-size:.9rem;color:var(--text-primary);font-family:inherit;box-sizing:border-box}.composer-score-input:focus{outline:none;border-color:#667eea}.composer-footer{display:flex;align-items:center;justify-content:space-between}.composer-char-count{font-size:.78rem;color:var(--text-tertiary)}.composer-actions{display:flex;gap:.6rem}.composer-cancel{padding:.5rem 1rem;border-radius:50px;border:1.5px solid var(--border-primary);background:none;color:var(--text-secondary);font-size:.88rem;font-weight:600;cursor:pointer}.composer-submit{padding:.5rem 1.25rem;border-radius:50px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.88rem;font-weight:700;cursor:pointer;transition:opacity .15s}.composer-submit:disabled{opacity:.45;cursor:not-allowed}.composer-submit:not(:disabled):hover{opacity:.9}.composer-video-row{display:flex;align-items:center;gap:.5rem}.composer-video-label{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border-radius:50px;border:1.5px dashed var(--border-primary);font-size:.82rem;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s}.composer-video-label:hover{border-color:#667eea;color:#667eea}.composer-video-remove{background:none;border:none;color:var(--text-tertiary);font-size:.85rem;cursor:pointer;padding:.2rem .4rem}.composer-video-error{font-size:.82rem;color:#e74c3c;margin:0}.social-activity-header{display:flex;align-items:center;gap:.65rem;margin:1.5rem 0 .9rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.social-activity-header:before,.social-activity-header:after{content:"";flex:1;height:1px;background:var(--border-primary)}.activity-feed-list{display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1rem)}.group-activity-slot{display:flex;flex-direction:column;padding:0 0 .5rem}.group-activity-slot .social-activity-header{margin-top:.25rem}.group-activity-slot .post-card{border-radius:14px;border:1px solid var(--border-primary)}.post-video{width:100%;max-height:340px;border-radius:10px;margin-top:.5rem;background:#000;display:block}.settings-container{padding:clamp(.5rem,2vw,1rem);max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(1rem,2.5vw,1.5rem)}.settings-title{font-size:clamp(1.5rem,4vw,2rem);color:var(--text-primary);margin:0 0 clamp(1rem,2.5vw,1.5rem) 0;font-weight:700}.settings-loading{color:var(--text-secondary);text-align:center;padding:2rem;font-size:clamp(.95rem,2vw,1.05rem)}.settings-tabs{display:flex;gap:.5rem;background:var(--bg-primary);padding:.5rem;border-radius:12px;box-shadow:var(--shadow-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{flex:1;min-width:100px;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:clamp(.75rem,2vw,1rem);background:transparent;border:none;border-radius:8px;font-size:clamp(.85rem,1.8vw,.95rem);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.settings-tab:hover{background:var(--bg-secondary)}.settings-tab.active{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff}.tab-icon{font-size:clamp(1.2rem,3vw,1.4rem)}.settings-content{display:flex;flex-direction:column;gap:clamp(1rem,2.5vw,1.5rem)}.settings-section{background:var(--bg-primary);border-radius:16px;padding:clamp(1.25rem,3vw,1.75rem);box-shadow:var(--shadow-md)}.section-title{font-size:clamp(1.1rem,2.5vw,1.3rem);color:var(--text-primary);margin:0 0 .5rem;font-weight:700}.section-description{font-size:clamp(.88rem,2vw,1rem);color:var(--text-secondary);margin:0 0 clamp(1rem,2.5vw,1.5rem) 0;line-height:1.5}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:clamp(1rem,2.5vw,1.25rem) 0;border-bottom:1px solid var(--border-primary)}.setting-item:last-child{border-bottom:none;padding-bottom:0}.setting-item:first-child{padding-top:0}.setting-info{flex:1}.setting-label{font-size:clamp(.95rem,2vw,1.05rem);font-weight:600;color:var(--text-primary);display:block;margin-bottom:.25rem}.setting-hint{font-size:clamp(.82rem,1.8vw,.92rem);color:var(--text-tertiary);margin:0}.theme-selector{display:flex;gap:.5rem;flex-wrap:wrap}.theme-option{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:clamp(.75rem,2vw,1rem);background:var(--bg-secondary);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease;min-width:80px}.theme-option:hover{background:var(--bg-tertiary);transform:translateY(-2px)}.theme-option.active{background:linear-gradient(135deg,#667eea15,#e74c3c15);border-color:#667eea}.theme-icon{font-size:clamp(1.5rem,4vw,1.75rem)}.theme-name{font-size:clamp(.82rem,1.8vw,.92rem);font-weight:600;color:var(--text-primary)}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e0;transition:.3s;border-radius:50px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#667eea,#e74c3c)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.wearables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:clamp(.75rem,2vw,1rem)}.wearable-card{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:12px;padding:clamp(1rem,2.5vw,1.25rem);display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1rem);transition:all .2s ease}.wearable-card:hover{border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.wearable-header{display:flex;gap:clamp(.75rem,2vw,1rem);align-items:flex-start}.wearable-icon{font-size:clamp(1.75rem,4vw,2rem);flex-shrink:0}.wearable-info{flex:1}.wearable-name{font-size:clamp(1rem,2.2vw,1.15rem);font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.wearable-description{font-size:clamp(.85rem,1.9vw,.95rem);color:var(--text-secondary);margin:0;line-height:1.4}.wearable-connect-btn{width:100%;padding:clamp(.65rem,1.8vw,.85rem);background:var(--bg-tertiary);color:var(--text-tertiary);border:none;border-radius:8px;font-weight:600;font-size:clamp(.88rem,2vw,1rem);cursor:not-allowed;transition:all .2s ease}.wearable-connect-btn:not(:disabled){background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;cursor:pointer}.wearable-connect-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.sync-info-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,200px),1fr));gap:clamp(.75rem,2vw,1rem)}.sync-info-card{background:linear-gradient(135deg,#667eea15,#e74c3c15);border:2px solid #667eea30;border-radius:12px;padding:clamp(1rem,2.5vw,1.25rem);display:flex;gap:clamp(.75rem,2vw,1rem);align-items:flex-start}.sync-info-icon{font-size:clamp(1.5rem,3.5vw,1.75rem);flex-shrink:0}.sync-info-content h4{font-size:clamp(.95rem,2vw,1.05rem);font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.sync-info-content p{font-size:clamp(.82rem,1.8vw,.92rem);color:var(--text-secondary);margin:0;line-height:1.4}.account-info{display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1rem)}.account-field{display:flex;flex-direction:column;gap:.25rem;padding:clamp(.75rem,2vw,1rem);background:var(--bg-secondary);border-radius:8px}.account-field label{font-size:clamp(.82rem,1.8vw,.92rem);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.account-field p{font-size:clamp(.95rem,2vw,1.05rem);font-weight:600;color:var(--text-primary);margin:0}.settings-action-btn{width:100%;padding:clamp(.75rem,2vw,1rem);border:none;border-radius:8px;font-weight:600;font-size:clamp(.95rem,2vw,1.05rem);cursor:pointer;transition:all .2s ease;margin-top:.5rem}.settings-action-btn.secondary{background:var(--bg-tertiary);color:var(--text-primary)}.settings-action-btn.secondary:hover{background:var(--border-secondary);transform:translateY(-2px)}.settings-action-btn.danger{background:#e53e3e;color:#fff}.settings-action-btn.danger:hover{background:#c53030;transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e66}.settings-action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.settings-action-btn.primary:hover:not(:disabled){opacity:.88;transform:translateY(-2px)}.settings-action-btn.small{width:auto;padding:.4rem .9rem;font-size:.88rem}.settings-action-btn:disabled{opacity:.5;cursor:not-allowed}.handle-display-row{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.handle-display{font-size:1.1rem;font-weight:700;color:#667eea;font-family:monospace}.handle-editor{display:flex;flex-direction:column;gap:.5rem;max-width:320px}.handle-input-wrap{display:flex;align-items:center;border:2px solid var(--border-primary);border-radius:10px;overflow:hidden;transition:border-color .2s;background:var(--bg-primary)}.handle-input-wrap:focus-within{border-color:#667eea}.handle-at{padding:0 .5rem 0 .75rem;font-size:1rem;font-weight:700;color:#667eea;-webkit-user-select:none;user-select:none;font-family:monospace}.handle-input{flex:1;border:none;outline:none;padding:.6rem .75rem .6rem 0;font-size:1rem;font-family:monospace;background:transparent;color:var(--text-primary)}.handle-input.error{color:#e53e3e}.handle-error{font-size:.82rem;color:#e53e3e;margin:0}.handle-success{font-size:.85rem;color:#38a169;font-weight:600;margin:.5rem 0 0}.handle-editor-actions{display:flex;gap:.5rem;flex-wrap:wrap}@media(max-width:768px){.setting-item{flex-direction:column;align-items:flex-start;gap:1rem}.theme-selector{width:100%}.theme-option{flex:1}.toggle-switch{align-self:flex-start}}@media(max-width:480px){.settings-tabs{padding:.35rem}.settings-tab{min-width:85px;padding:.65rem}}.gym-submission-container{max-width:800px;margin:0 auto;padding:clamp(1rem,3vw,2rem);padding-right:clamp(2rem,5vw,3rem)}.gym-submission-header{text-align:center;margin-bottom:2rem}.gym-submission-header h2{color:var(--text-primary);font-size:clamp(1.75rem,4vw,2.5rem);margin:0 0 .5rem}.gym-submission-header p{color:var(--text-secondary);font-size:clamp(.95rem,2vw,1.1rem);margin:0}.success-banner{background:#48bb78;color:var(--bg-primary);padding:1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center;font-weight:600}.error-banner{background:#f56565;color:var(--bg-primary);padding:1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center;font-weight:600}.gym-submission-form{background:var(--bg-primary);border-radius:16px;padding:clamp(1.5rem,4vw,2.5rem);box-shadow:0 10px 40px #0003}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid var(--border-primary)}.form-section:last-of-type{border-bottom:none;margin-bottom:1.5rem}.form-section h3{color:var(--text-primary);font-size:clamp(1.25rem,3vw,1.5rem);margin:0 0 1.25rem}.form-group{margin-bottom:1.25rem;flex:1}.form-group label{display:block;color:var(--text-secondary);font-weight:600;margin-bottom:.5rem;font-size:clamp(.9rem,2vw,.95rem)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:2px solid var(--border-primary);border-radius:8px;font-size:clamp(.9rem,2vw,1rem);font-family:inherit;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:flex;gap:1rem;flex-wrap:wrap}.form-row .form-group{min-width:200px}.submit-gym-btn{width:100%;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#e74c3c);color:var(--bg-primary);border:none;border-radius:8px;font-size:clamp(1rem,2.5vw,1.1rem);font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #667eea66}.submit-gym-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.submit-gym-btn:disabled{opacity:.6;cursor:not-allowed}.challenge-section-form{border:1.5px solid rgba(102,126,234,.35);background:linear-gradient(135deg,#667eea0a,#764ba20a)}.challenge-section-title{display:flex;align-items:center;gap:.65rem;margin-bottom:.4rem}.challenge-section-title h3{margin:0}.challenge-optional-badge{padding:.2rem .65rem;background:#667eea1f;color:#667eea;border-radius:50px;font-size:.75rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase}.challenge-section-desc{font-size:clamp(.85rem,1.9vw,.95rem);color:var(--text-secondary);margin-bottom:clamp(1rem,2.5vw,1.25rem)!important;line-height:1.5}.exercise-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.65rem}.exercise-row{display:flex;gap:.6rem;align-items:center}.exercise-movement{flex:2}.exercise-reps{flex:1}.exercise-remove-btn{flex-shrink:0;width:32px;height:32px;padding:0;background:#e53e3e1a;color:#e53e3e;border:1.5px solid rgba(229,62,62,.3);border-radius:6px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.exercise-remove-btn:hover{background:#e53e3e33}.add-exercise-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;background:transparent;color:#667eea;border:1.5px dashed #667eea;border-radius:8px;font-size:clamp(.85rem,1.9vw,.92rem);font-weight:600;cursor:pointer;transition:all .15s ease}.add-exercise-btn:hover{background:#667eea14}.qr-info-banner{display:flex;gap:.85rem;align-items:flex-start;margin-top:1rem;padding:.9rem 1.1rem;background:linear-gradient(135deg,#667eea12,#764ba212);border:1.5px solid rgba(102,126,234,.3);border-radius:10px}.qr-info-icon{font-size:1.5rem;flex-shrink:0;margin-top:.1rem}.qr-info-banner strong{display:block;font-size:.95rem;color:#667eea;margin-bottom:.25rem}.qr-info-banner p{margin:0;font-size:.88rem;color:var(--text-secondary);line-height:1.5}@media(max-width:600px){.form-row{flex-direction:column}.form-row .form-group{min-width:100%}}.sp-root{display:flex;flex-direction:column;gap:0;position:relative;min-height:400px;overflow-x:hidden;width:100%;box-sizing:border-box}.sp-no-season,.sp-loading{text-align:center;padding:3rem 1rem;color:#888;font-size:.95rem}.sp-header{position:relative;border-radius:14px 14px 0 0;overflow:hidden;padding:clamp(1rem,4vw,1.5rem) clamp(1rem,4vw,1.5rem) clamp(.9rem,3vw,1.25rem);color:#fff;min-height:190px;box-sizing:border-box;transition:min-height .3s ease,padding .3s ease}.sp-header-collapsed{min-height:0;padding:.6rem clamp(1rem,4vw,1.5rem)}.sp-header-collapsed .sp-header-eyebrow,.sp-header-collapsed .sp-header-theme{max-height:0;opacity:0;margin:0;overflow:hidden}.sp-header-collapsed .sp-header-title{font-size:1rem;margin:0}.sp-header-collapsed .sp-header-top{gap:.4rem}.sp-header-collapsed .sp-days-num{font-size:1rem}.sp-header-collapsed .sp-days-label{display:none}.sp-header-collapsed .sp-days-pill{padding:.2rem .5rem;min-width:0}.sp-header-collapsed .sp-xp-row,.sp-header-collapsed .sp-tier-progress{max-height:0;opacity:0;overflow:hidden;margin:0}.sp-header-collapsed .sp-xp-section{gap:.2rem}.sp-header-collapsed .sp-header-content{gap:.5rem}.sp-header-eyebrow,.sp-header-theme{transition:max-height .3s ease,opacity .2s ease,margin .3s ease;max-height:3rem;overflow:hidden}.sp-header-title{transition:font-size .3s ease}.sp-xp-row,.sp-tier-progress{transition:max-height .3s ease,opacity .2s ease;max-height:4rem;overflow:hidden}.sp-header-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#0000008c,#00000040);z-index:0}.sp-header-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:1rem}.sp-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.sp-header-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.8;margin-bottom:.25rem}.sp-header-title{margin:0 0 .2rem;font-size:1.5rem;font-weight:800;line-height:1.1;text-shadow:0 1px 4px rgba(0,0,0,.4)}.sp-header-theme{font-size:.78rem;opacity:.75}.sp-header-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.sp-days-pill{background:#ffffff26;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);border-radius:10px;padding:.35rem .75rem;text-align:center;min-width:64px}.sp-days-num{display:block;font-size:1.4rem;font-weight:800;line-height:1}.sp-days-label{display:block;font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;opacity:.8}.sp-pass-owned{background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:20px;padding:.35rem .9rem;font-size:.78rem;font-weight:700;letter-spacing:.04em}.sp-buy-pass-btn{display:flex;align-items:center;gap:.35rem;background:var(--season-color, #ff8c00);color:#fff;border:none;border-radius:10px;padding:.5rem 1rem;font-size:.8rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.sp-buy-pass-btn:hover{opacity:.9;transform:scale(1.02)}.sp-xp-section{display:flex;flex-direction:column;gap:.35rem}.sp-xp-row{display:flex;justify-content:space-between;align-items:center}.sp-xp-label{font-size:.82rem;font-weight:700}.sp-xp-value{font-size:.72rem;opacity:.75}.sp-xp-bar-bg{height:8px;background:#fff3;border-radius:4px;overflow:hidden}.sp-xp-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.sp-tier-progress{display:flex;flex-direction:column;gap:.2rem;opacity:.8}.sp-tier-sub{font-size:.68rem;opacity:.8}.sp-tier-bar-bg{height:4px;background:#ffffff26;border-radius:2px;overflow:hidden}.sp-tier-bar-fill{height:100%;border-radius:2px;opacity:.7;transition:width .4s ease}.sp-track-wrap{background:#fff;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 14px 14px}.sp-track-header-row{display:grid;grid-template-columns:44px 1fr 1fr;padding:.55rem .75rem;background:#f8f9fa;border-bottom:1px solid #e5e7eb;border-radius:0;position:sticky;top:0;z-index:3}.sp-track-hcol{font-size:.65rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#888}.sp-track-hcol-free{color:#444}.sp-track-hcol-premium{color:#b8860b}.sp-track-hcol-cta{font-weight:400;opacity:.7}.sp-track-rows{display:flex;flex-direction:column}.sp-track-row{display:grid;grid-template-columns:44px 1fr 1fr;border-bottom:1px solid #f0f0f0;min-height:62px;align-items:stretch;transition:background .15s}.sp-track-row:last-child{border-bottom:none}.sp-row-current{background:#fffbf0}.sp-row-final{background:linear-gradient(135deg,#fffbf0,#fff8e1)}.sp-row-locked{opacity:.6}.sp-row-tier{display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:#bbb;border-right:1px solid #f0f0f0;padding:.5rem 0;gap:4px;position:relative}.sp-row-unlocked .sp-row-tier{color:#555}.sp-row-current .sp-row-tier{font-size:.85rem}.sp-row-current-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.sp-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.4rem .35rem;gap:.2rem;text-align:center;position:relative}.sp-cell-empty{justify-content:center}.sp-cell-dash{font-size:.9rem;color:#ddd}.sp-cell-icon{font-size:1.1rem;line-height:1}.sp-cell-label{font-size:.63rem;font-weight:600;color:#555;line-height:1.2;max-width:100%}.sp-cell-free.sp-cell-claimable,.sp-cell-free.sp-cell-claimed{background:#22c55e0f}.sp-cell-premium.sp-cell-claimable,.sp-cell-premium.sp-cell-claimed{background:#b8860b0f}.sp-cell-claimed .sp-cell-icon,.sp-cell-claimed .sp-cell-label{color:#22c55e}.sp-cell-locked .sp-cell-icon,.sp-cell-locked .sp-cell-label{opacity:.45}.sp-cell-clickable{cursor:pointer;transition:background .12s,transform .1s}.sp-cell-clickable:hover{background:#0000000a;transform:scale(1.03)}.sp-claim-btn{margin-top:.2rem;padding:.2rem .55rem;font-size:.6rem;font-weight:700;border:none;border-radius:6px;background:#22c55e;color:#fff;cursor:pointer;transition:opacity .15s,transform .1s;text-transform:uppercase;letter-spacing:.04em}.sp-claim-btn:hover{opacity:.85;transform:scale(1.04)}.sp-cell-premium .sp-claim-btn{background:#b8860b}.sp-premium-col{position:relative}.sp-premium-col-locked .sp-cell{opacity:.45}.sp-premium-lock{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1rem;z-index:2;pointer-events:none}.sp-premium-col-locked .sp-cell-empty .sp-premium-lock,.sp-premium-col-locked .sp-cell-empty+.sp-premium-lock{display:none}.sp-upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#fffbf0,#fff8e1);border:1px solid rgba(184,134,11,.25);border-radius:12px;margin-top:.75rem;flex-wrap:wrap}.sp-upgrade-text{display:flex;flex-direction:column;gap:.2rem}.sp-upgrade-text strong{font-size:.9rem;font-weight:800;color:#92400e}.sp-upgrade-text span{font-size:.75rem;color:#78350f;opacity:.85}.sp-upgrade-btn{display:flex;align-items:center;gap:.35rem;background:var(--season-color, #ff8c00);color:#fff;border:none;border-radius:10px;padding:.55rem 1.1rem;font-size:.82rem;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .15s,transform .1s}.sp-upgrade-btn:hover{opacity:.9;transform:scale(1.02)}.sp-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.sp-confirm-modal{background:#fff;border-radius:16px;padding:1.75rem 1.5rem;max-width:360px;width:100%;position:relative;text-align:center;box-shadow:0 20px 60px #0000004d}.sp-confirm-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:1rem;cursor:pointer;color:#888;padding:.2rem .4rem}.sp-confirm-icon{font-size:2.5rem;margin-bottom:.5rem}.sp-confirm-title{margin:0 0 .15rem;font-size:1.1rem;font-weight:800;color:#111}.sp-confirm-subtitle{font-size:.78rem;color:#888;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.sp-confirm-price{display:flex;align-items:center;justify-content:center;gap:.3rem;font-size:1.3rem;font-weight:800;color:#b8860b;margin-bottom:.75rem}.sp-confirm-perks{list-style:none;padding:0;margin:0 0 .75rem;text-align:left;display:flex;flex-direction:column;gap:.3rem}.sp-confirm-perks li{font-size:.78rem;color:#333}.sp-confirm-note{font-size:.72rem;color:#666;margin:0 0 1rem}.sp-confirm-low{color:#ef4444;font-weight:600}.sp-confirm-actions{display:flex;gap:.6rem}.sp-confirm-cancel{flex:1;padding:.6rem;border:1px solid #ddd;border-radius:10px;background:none;color:#555;font-size:.85rem;font-weight:600;cursor:pointer}.sp-confirm-buy{flex:2;padding:.6rem;border:none;border-radius:10px;background:var(--season-color, #ff8c00);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;transition:opacity .15s}.sp-confirm-buy:disabled{opacity:.5;cursor:not-allowed}.sp-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);padding:.6rem 1.2rem;border-radius:24px;font-size:.85rem;font-weight:600;white-space:nowrap;z-index:2000;box-shadow:0 4px 16px #0003}.sp-toast-success{background:#22c55e;color:#fff}.sp-toast-error{background:#ef4444;color:#fff}.sp-preview-modal{background:#fff;border-radius:16px;padding:1.75rem 1.5rem 1.25rem;max-width:320px;width:100%;position:relative;text-align:center;box-shadow:0 20px 60px #0000004d}.sp-preview-type{font-size:.72rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}.sp-preview-tags{display:flex;justify-content:center;gap:.4rem;margin-bottom:.8rem}.sp-preview-tag{background:#f3f4f6;border-radius:20px;padding:.2rem .6rem;font-size:.7rem;font-weight:700;color:#555}.sp-preview-bundle{list-style:none;padding:0;margin:0 0 .75rem;text-align:left;display:flex;flex-direction:column;gap:.25rem;background:#f8f9fa;border-radius:10px;padding:.6rem .8rem}.sp-preview-bundle li{font-size:.75rem;color:#333}.sp-preview-status{font-size:.8rem;font-weight:700;padding:.4rem .75rem;border-radius:20px;margin-bottom:1rem;display:inline-block}.sp-preview-status-claimed,.sp-preview-status-ready{background:#22c55e1f;color:#16a34a}.sp-preview-status-locked{background:#6464641a;color:#666}.sp-preview-status-premium{background:#b8860b1a;color:#92400e}.sp-preview-actions{display:flex;flex-direction:column;gap:.5rem}.sp-cosmetic-banner{position:relative;width:100%;height:90px;border-radius:10px;overflow:hidden;margin-bottom:.85rem;display:flex;align-items:flex-end}.sp-cosmetic-banner-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}.sp-cosmetic-banner-overlay{position:absolute;inset:0;background:linear-gradient(to top,#000000a6,#00000026);z-index:1}.sp-cosmetic-banner-content{position:relative;z-index:2;display:flex;align-items:center;gap:.5rem;padding:.5rem .65rem}.sp-cosmetic-avatar-ring{width:32px;height:32px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.7);flex-shrink:0;background:#555;display:flex;align-items:center;justify-content:center}.sp-cosmetic-avatar-img{width:100%;height:100%;object-fit:cover;display:block}.sp-cosmetic-avatar-fallback{font-size:1rem;line-height:1}.sp-cosmetic-banner-name{font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-cosmetic-frame-area{display:flex;justify-content:center;align-items:center;padding:.75rem 0 .5rem;margin-bottom:.35rem}.sp-cosmetic-frame-ring{width:80px!important;height:80px!important}.sp-cosmetic-frame-swatch{overflow:hidden;display:flex;align-items:center;justify-content:center;background:#e5e7eb}.home-container{padding:0;width:100%;max-width:1400px;margin:0 auto;box-sizing:border-box;overflow-x:hidden;display:flex;flex-direction:column;gap:clamp(1rem,2.5vw,1.5rem)}.home-loading{color:#fff;text-align:center;padding:2rem}.home-card{background:var(--bg-primary);border-radius:16px;padding:clamp(1.25rem,3vw,1.75rem);box-shadow:var(--shadow-md);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;min-width:0;width:100%;box-sizing:border-box}.home-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.home-profile-card{display:flex;align-items:center;gap:clamp(1rem,3vw,1.5rem)}.home-avatar{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.35rem}.home-avatar-img{width:clamp(52px,14vw,72px);height:clamp(52px,14vw,72px);border-radius:50%;object-fit:cover;display:block}.home-avatar-icon{display:flex;align-items:center;justify-content:center;width:clamp(52px,14vw,72px);height:clamp(52px,14vw,72px);border-radius:50%;background:var(--bg-secondary);font-size:clamp(1.75rem,5vw,2.25rem)}.home-activity-frame{flex-shrink:0;line-height:0}.home-level-badge{display:inline-block;background:linear-gradient(135deg,gold,#ffed4e);color:#333;font-weight:800;font-size:.7rem;padding:.18rem .65rem;border-radius:20px;letter-spacing:.04em;box-shadow:0 2px 6px #0000002e;white-space:nowrap}.home-profile-info{flex:1;min-width:0}.home-profile-info h3{margin:0 0 .25rem;font-size:clamp(1.1rem,2.8vw,1.4rem);color:var(--text-primary);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-handle{margin:0 0 .3rem;font-size:clamp(.8rem,1.8vw,.88rem);color:#667eea;font-weight:600}.home-xp-label{margin:0 0 .4rem;font-size:clamp(.8rem,1.8vw,.92rem);color:var(--text-secondary);font-weight:600}.home-xp-bar-track{width:100%;height:8px;background:var(--bg-tertiary);border-radius:50px;overflow:hidden}.home-xp-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#e74c3c);border-radius:50px;transition:width .4s ease}.home-streak-row{display:flex;align-items:center;gap:.3rem;margin-top:.5rem}.home-streak-flame{font-size:clamp(.95rem,2.2vw,1.1rem);line-height:1}.home-streak-count{font-size:clamp(1rem,2.5vw,1.2rem);font-weight:800;color:#ed8936;line-height:1}.home-streak-label{font-size:clamp(.78rem,1.7vw,.88rem);color:var(--text-secondary);font-weight:500}.home-streak-start{color:var(--text-tertiary);font-style:italic}.home-streak-best{margin-left:auto;font-size:clamp(.72rem,1.5vw,.82rem);color:var(--text-tertiary);font-weight:500;white-space:nowrap}.home-featured-row{display:flex;gap:.4rem;margin-top:.6rem;flex-wrap:wrap}.home-feat-badge{width:clamp(24px,4vw,30px);height:clamp(24px,4vw,30px);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:clamp(.75rem,2vw,.95rem);background:#667eea26;border:1.5px solid rgba(102,126,234,.35);flex-shrink:0}.home-section-title{margin:0 0 clamp(.75rem,2vw,1rem) 0;font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#a78bfa}[data-theme=dark] .home-section-title{color:#4f46e5}.home-empty-message{margin:0;color:var(--text-secondary);font-size:clamp(.9rem,2vw,1rem);font-style:italic}.home-routes-list{display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1rem)}.home-route-item{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:.25rem .85rem;align-items:center}.home-route-icon{grid-row:1 / 3;width:clamp(2.25rem,7vw,2.75rem);height:clamp(2.25rem,7vw,2.75rem);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:clamp(1.2rem,3.5vw,1.5rem)}.home-route-details{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.home-route-name{font-size:clamp(.92rem,2.2vw,1.05rem);color:var(--text-primary);font-weight:600}.home-route-progress{font-size:clamp(.8rem,1.8vw,.9rem);color:var(--text-secondary);font-weight:600;white-space:nowrap}.home-route-progress-bar-track{grid-column:2;width:100%;height:6px;background:var(--bg-tertiary);border-radius:50px;overflow:hidden}.home-route-progress-bar-fill{height:100%;border-radius:50px;transition:width .3s ease}.home-route-start{grid-column:2;font-size:clamp(.82rem,1.9vw,.92rem);font-weight:700;align-self:start}.home-challenge-card{position:relative;overflow:hidden;border-radius:18px;padding:clamp(1.1rem,3vw,1.5rem);background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border:1px solid rgba(102,126,234,.3);cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 24px #0000004d}.home-challenge-card:before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(102,126,234,.25) 0%,transparent 70%);pointer-events:none}.home-challenge-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #667eea40}.hc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.hc-label{font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#a78bfa}.hc-date{font-size:.75rem;color:#ffffff73;font-weight:500}.hc-title{margin:0 0 .75rem;font-size:clamp(1.3rem,4vw,1.7rem);font-weight:800;color:#fff;line-height:1.2;letter-spacing:-.02em}.hc-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.85rem}.hc-badge{font-size:.72rem;font-weight:700;padding:.25rem .6rem;border-radius:999px;letter-spacing:.02em}.hc-badge-difficulty{background:#ffffff1a;color:#fff}.hc-diff-beginner{background:#34d39933;color:#34d399}.hc-diff-intermediate{background:#fbbf2433;color:#fbbf24}.hc-diff-advanced{background:#ef444433;color:#f87171}.hc-diff-elite{background:#a78bfa33;color:#a78bfa}.hc-badge-type{background:#667eea33;color:#818cf8}.hc-badge-score{background:#ffffff14;color:#ffffffb3}.hc-desc{margin:0 0 .85rem;font-size:clamp(.85rem,2vw,.95rem);color:#ffffffa6;line-height:1.5}.hc-exercises{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.85rem}.hc-exercise-chip{font-size:.78rem;font-weight:600;padding:.2rem .6rem;border-radius:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#fffc}.hc-target{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem .75rem;border-radius:8px;background:#667eea1f;border:1px solid rgba(102,126,234,.2);width:fit-content}.hc-target-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#818cf8}.hc-target-value{font-size:.88rem;font-weight:700;color:#fff}.hc-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem;padding-top:.85rem;border-top:1px solid rgba(255,255,255,.08)}.hc-xp{font-size:.8rem;font-weight:700;color:#fbbf24;background:#fbbf241f;padding:.2rem .55rem;border-radius:999px;border:1px solid rgba(251,191,36,.25)}.hc-cta{font-size:.9rem;font-weight:700;color:#a78bfa;letter-spacing:.01em}.hc-empty{display:flex;flex-direction:column;align-items:center;padding:1.5rem 0;gap:.5rem}.hc-empty-icon{font-size:2rem}.hc-empty p{margin:0;color:#ffffff73;font-size:.9rem}[data-theme=dark] .home-challenge-card{background:linear-gradient(135deg,#f0f4ff,#e8eeff 60%,#f5f0ff);border:1px solid rgba(102,126,234,.2);box-shadow:0 4px 32px #667eea33}[data-theme=dark] .home-challenge-card:before{background:radial-gradient(circle,rgba(102,126,234,.15) 0%,transparent 70%)}[data-theme=dark] .home-challenge-card:hover{box-shadow:0 8px 40px #667eea4d}[data-theme=dark] .hc-label{color:#4f46e5}[data-theme=dark] .hc-date{color:#0006}[data-theme=dark] .hc-title{color:#1e1b4b}[data-theme=dark] .hc-desc{color:#1e1b4ba6}[data-theme=dark] .hc-badge-type{background:#6366f11f;color:#4f46e5}[data-theme=dark] .hc-badge-score{background:#0000000f;color:#0009}[data-theme=dark] .hc-diff-beginner{background:#10b9811f;color:#059669}[data-theme=dark] .hc-diff-intermediate{background:#d977061f;color:#b45309}[data-theme=dark] .hc-diff-advanced{background:#dc26261f;color:#dc2626}[data-theme=dark] .hc-diff-elite{background:#6d28d91f;color:#7c3aed}[data-theme=dark] .hc-exercise-chip{background:#0000000f;border-color:#0000001a;color:#000000b3}[data-theme=dark] .hc-target{background:#6366f114;border-color:#6366f133}[data-theme=dark] .hc-target-label{color:#4f46e5}[data-theme=dark] .hc-target-value{color:#1e1b4b}[data-theme=dark] .hc-footer{border-top-color:#00000014}[data-theme=dark] .hc-xp{color:#b45309;background:#d977061a;border-color:#d9770633}[data-theme=dark] .hc-cta{color:#4f46e5}[data-theme=dark] .hc-empty p{color:#0006}.home-promo-header{display:flex;justify-content:space-between;align-items:center}.home-promo-header .home-section-title{margin-bottom:0}.home-promo-see-all{font-size:clamp(.82rem,1.9vw,.95rem);color:#667eea;font-weight:600}.home-promo-coming-badge{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:.2rem .6rem;border-radius:50px}.home-promo-coming-soon{cursor:default}.home-promo-cs-body{display:flex;align-items:center;gap:1rem;margin-top:1.25rem;padding:1rem 1.25rem;background:var(--bg-secondary);border-radius:12px;border:1px dashed var(--border-primary)}.home-promo-cs-icon{font-size:2rem;flex-shrink:0}.home-promo-cs-text{font-size:.88rem;color:var(--text-secondary);line-height:1.5;margin:0}.home-promo-list{display:flex;gap:clamp(.75rem,2.5vw,1rem);overflow-x:auto;padding:clamp(.75rem,2vw,1rem) 0 .25rem 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.home-promo-list::-webkit-scrollbar{display:none}.home-promo-item{flex-shrink:0;width:clamp(110px,28vw,150px);background:var(--bg-secondary);border-radius:12px;padding:clamp(.6rem,1.8vw,.9rem);display:flex;flex-direction:column;align-items:center;gap:.3rem;position:relative;transition:background .2s ease}.home-promo-item:hover{background:var(--bg-tertiary)}.home-promo-badge{position:absolute;top:-8px;right:-8px;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;font-size:clamp(.62rem,1.5vw,.72rem);font-weight:700;padding:3px 6px;border-radius:50px;white-space:nowrap;box-shadow:0 2px 6px #e74c3c66}.home-promo-emoji{font-size:clamp(1.6rem,5vw,2rem);line-height:1;margin-top:.25rem}.home-promo-name{margin:0;font-size:clamp(.78rem,1.8vw,.88rem);color:var(--text-primary);font-weight:600;text-align:center;line-height:1.2}.home-promo-prices{display:flex;gap:.4rem;align-items:baseline;margin-top:.15rem}.home-promo-price-old{font-size:clamp(.72rem,1.6vw,.82rem);color:var(--text-tertiary);text-decoration:line-through}.home-promo-price-new{font-size:clamp(.88rem,2vw,1rem);color:#667eea;font-weight:700}.home-shop-preview-card{cursor:pointer}.home-shop-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.home-shop-preview-header .home-section-title{margin-bottom:0}.home-shop-preview-cta{font-size:clamp(.82rem,1.9vw,.95rem);color:#667eea;font-weight:600}.home-shop-season-banner{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:10px;background:var(--season-bg, rgba(0,0,0,.05));border:1px solid var(--season-border, rgba(0,0,0,.1));margin-bottom:.75rem}.home-shop-season-icon{font-size:1.4rem;flex-shrink:0}.home-shop-season-info{flex:1;display:flex;flex-direction:column;gap:.05rem}.home-shop-season-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--season-color)}.home-shop-season-name{font-size:.88rem;font-weight:700;color:var(--text-primary)}.home-shop-season-price{flex-shrink:0}.home-shop-season-price-value{font-size:.82rem;font-weight:700;color:#b8860b;background:#b8860b1f;border:1px solid rgba(184,134,11,.25);padding:.2rem .5rem;border-radius:20px}.home-shop-section-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.04em;margin-bottom:.5rem;margin-top:.1rem}.home-shop-carousel-wrap{position:relative}.home-shop-carousel{display:flex;gap:.5rem;overflow-x:auto;padding:.25rem 0 .4rem;scrollbar-width:none;scroll-snap-type:x mandatory}.home-shop-carousel::-webkit-scrollbar{display:none}.home-shop-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:26px;height:26px;border-radius:50%;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-primary);font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000001f;transition:background .15s,transform .15s;padding:0}.home-shop-carousel-btn:hover{background:var(--bg-secondary);transform:translateY(-50%) scale(1.08)}.home-shop-carousel-btn-left{left:-13px}.home-shop-carousel-btn-right{right:-13px}.home-shop-item-chip{flex-shrink:0;scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;gap:.25rem;width:clamp(72px,20vw,96px);background:var(--bg-secondary);border-radius:10px;padding:.5rem .4rem .45rem;transition:background .2s;position:relative}.home-shop-item-chip:hover{background:var(--bg-tertiary)}.home-shop-type-badge{font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.1rem .35rem;border-radius:20px;line-height:1.4}.home-shop-type-frame{background:#667eea26;color:#667eea}.home-shop-type-banner{background:#b8860b26;color:#b8860b}.home-shop-frame-ring{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center}.home-shop-frame-placeholder{font-size:1.15rem;line-height:1}.home-shop-banner-swatch{width:100%;height:34px;border-radius:7px;overflow:hidden}.home-shop-item-name{font-size:.7rem;font-weight:600;color:var(--text-primary);text-align:center;line-height:1.2}.home-shop-item-price{font-size:.65rem;font-weight:700;color:#b8860b}.home-social-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.home-social-see-all{font-size:.82rem;font-weight:600;color:#667eea}.home-activity-list{display:flex;flex-direction:column;gap:0}.home-activity-item{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.7rem 0;border-bottom:1px solid var(--border-primary)}.home-activity-item:last-child{border-bottom:none;padding-bottom:0}.home-activity-left{display:flex;align-items:flex-start;gap:.6rem;flex:1;min-width:0}.home-activity-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.home-activity-avatar-placeholder{background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:1.1rem}.home-activity-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}.home-activity-name{font-size:.88rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-activity-content{font-size:.82rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-activity-details{font-size:.76rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-activity-right{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;flex-shrink:0}.home-activity-icon{font-size:1rem}.home-activity-time{font-size:.72rem;color:var(--text-tertiary);white-space:nowrap}.home-activity-stats{display:flex;gap:.5rem;font-size:.72rem;color:var(--text-tertiary);font-weight:600}.home-social-empty{display:flex;flex-direction:column;align-items:center;padding:1.25rem 0 .5rem;gap:.4rem;text-align:center}.home-social-empty-icon{font-size:1.8rem}.home-social-empty p{margin:0;font-size:.88rem;color:var(--text-secondary)}.home-social-empty-cta{font-size:.82rem;font-weight:700;color:#667eea;cursor:pointer;margin-top:.2rem}.home-tasks-card{cursor:default}.home-tasks-subtitle{margin:-.5rem 0 .75rem;font-size:clamp(.82rem,1.8vw,.92rem);color:var(--text-secondary);font-weight:500}.home-tasks-list{display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1rem)}.home-task-item{display:flex;justify-content:space-between;align-items:center;padding:clamp(.85rem,2.2vw,1.1rem);background:var(--bg-secondary);border-radius:12px;transition:all .2s ease}.home-task-item.completed{background:linear-gradient(135deg,#48bb7815,#38a16915);border:2px solid #48bb78}.home-task-item:not(.completed):hover{background:var(--bg-tertiary)}.home-task-info{display:flex;align-items:center;gap:clamp(.75rem,2vw,1rem);flex:1}.home-task-icon{font-size:clamp(1.75rem,4.5vw,2rem);flex-shrink:0}.home-task-details{display:flex;flex-direction:column;gap:.15rem}.home-task-name{font-size:clamp(.95rem,2.2vw,1.05rem);font-weight:700;color:var(--text-primary)}.home-task-desc{font-size:clamp(.8rem,1.8vw,.88rem);color:var(--text-secondary);font-weight:500}.home-task-btn{padding:clamp(.5rem,1.5vw,.65rem) clamp(.85rem,2.5vw,1.15rem);background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:clamp(.85rem,1.9vw,.95rem);cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.home-task-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.home-task-check{font-size:clamp(1.5rem,3.5vw,1.75rem);color:#48bb78;font-weight:700;flex-shrink:0}.home-tasks-complete-banner{margin-top:clamp(.75rem,2vw,1rem);padding:clamp(.75rem,2vw,1rem);background:linear-gradient(135deg,#ffd70015,#ffed4e15);border:2px solid #ffd700;border-radius:12px;text-align:center;font-weight:700;font-size:clamp(.92rem,2.1vw,1.05rem);color:var(--text-primary)}.home-tasks-card-done{padding:.75rem clamp(1.25rem,3vw,1.75rem);cursor:default;background:linear-gradient(135deg,#48bb7808,#38a16908);border:1.5px solid #48bb7840}.home-tasks-done-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.home-tasks-done-left{display:flex;align-items:center;gap:.65rem}.home-tasks-done-icon{font-size:1.3rem;flex-shrink:0}.home-tasks-done-title{display:block;font-size:.9rem;font-weight:700;color:var(--text-primary);line-height:1.2}.home-tasks-done-sub{display:block;font-size:.7rem;color:#48bb78;font-weight:600;margin-top:.1rem}.home-tasks-done-checks{display:flex;gap:.3rem;flex-shrink:0}.home-tasks-done-check{width:22px;height:22px;border-radius:50%;background:#48bb78;color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center}.home-task-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.home-task-modal{background:var(--bg-primary);border-radius:16px;padding:clamp(1.5rem,4vw,2rem);width:min(90%,400px);box-shadow:0 8px 32px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.home-task-modal-title{margin:0 0 clamp(1rem,2.5vw,1.25rem) 0;font-size:clamp(1.1rem,2.5vw,1.3rem);color:var(--text-primary);font-weight:700;text-align:center}.home-task-modal-input{width:100%;padding:clamp(.75rem,2vw,1rem);border:2px solid var(--border-primary);border-radius:8px;font-size:clamp(.95rem,2vw,1.05rem);margin-bottom:clamp(1rem,2.5vw,1.25rem);box-sizing:border-box;transition:border-color .2s ease;background:var(--bg-primary);color:var(--text-primary)}.home-task-modal-input:focus{outline:none;border-color:#667eea}.home-task-modal-actions{display:flex;gap:clamp(.75rem,2vw,1rem)}.home-task-modal-btn{flex:1;padding:clamp(.75rem,2vw,1rem);border:none;border-radius:8px;font-weight:700;font-size:clamp(.95rem,2vw,1.05rem);cursor:pointer;transition:all .2s ease}.home-task-modal-btn.cancel{background:var(--bg-tertiary);color:var(--text-primary)}.home-task-modal-btn.cancel:hover{background:var(--border-secondary);transform:translateY(-2px)}.home-task-modal-btn.submit{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff}.home-task-modal-btn.submit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media(max-width:480px){.home-route-details{flex-direction:column;gap:.1rem}.home-route-progress{font-size:.78rem}.home-task-item{flex-direction:column;align-items:flex-start;gap:.75rem}.home-task-btn,.home-task-check{align-self:flex-end}}.home-pass-card{display:flex;flex-direction:column;gap:.85rem;border-left:4px solid var(--season-color, #ff8c00);cursor:pointer}.home-pass-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.home-pass-title-group{display:flex;align-items:center;gap:.6rem;min-width:0}.home-pass-icon{font-size:1.5rem;flex-shrink:0}.home-pass-season-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--season-color, #ff8c00);line-height:1;margin-bottom:.15rem}.home-pass-season-name{font-size:.95rem;font-weight:800;color:var(--text-primary);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-pass-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;flex-shrink:0}.home-pass-days-pill{display:flex;flex-direction:column;align-items:center;background:color-mix(in srgb,var(--season-color, #ff8c00) 12%,transparent);border:1px solid color-mix(in srgb,var(--season-color, #ff8c00) 30%,transparent);border-radius:8px;padding:.2rem .5rem;line-height:1}.home-pass-days-num{font-size:1.05rem;font-weight:800;color:var(--season-color, #ff8c00)}.home-pass-days-label{font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.home-pass-view-cta{font-size:.72rem;font-weight:700;color:var(--season-color, #ff8c00);opacity:.75}.home-pass-progress-section{display:flex;flex-direction:column;gap:.4rem}.home-pass-tier-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.home-pass-tier-label{font-size:.82rem;font-weight:600;color:var(--text-primary)}.home-pass-xp-note{font-size:.7rem;color:var(--text-secondary);white-space:nowrap}.home-pass-xp-note.home-pass-max{color:var(--season-color, #ff8c00);font-weight:700}.home-pass-bar-bg{height:7px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.home-pass-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.home-pass-upcoming{display:flex;flex-direction:column;gap:.45rem}.home-pass-upcoming-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.home-pass-rewards-row{display:flex;gap:.5rem;flex-wrap:wrap}.home-pass-reward-chip{display:flex;flex-direction:column;gap:.25rem;background:var(--bg-secondary);border-radius:10px;padding:.5rem .65rem;min-width:80px;flex:1;max-width:160px}.home-pass-reward-tier{font-size:.62rem;font-weight:800;letter-spacing:.06em}.home-pass-reward-item{display:flex;align-items:center;gap:.3rem}.home-pass-reward-icon{font-size:.9rem;flex-shrink:0}.home-pass-reward-name{font-size:.65rem;font-weight:600;color:var(--text-primary);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90px}.home-pass-reward-free{opacity:1}.home-pass-reward-premium .home-pass-reward-name{color:#b8860b}.home-pass-reward-premium .home-pass-reward-icon{opacity:.85}.home-pass-complete-banner{text-align:center;font-size:.82rem;font-weight:700;color:var(--season-color, #ff8c00);background:color-mix(in srgb,var(--season-color, #ff8c00) 10%,transparent);border-radius:8px;padding:.5rem}.home-pass-modal-overlay{position:fixed;inset:0;background:#0009;z-index:900;display:flex;align-items:center;justify-content:center;padding:1rem;pointer-events:all}.home-pass-modal-container{position:relative;width:100%;max-width:460px;height:calc(100vh - 260px);max-height:calc(100vh - 260px);display:flex;flex-direction:column;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px #0006}.home-pass-modal-container .sp-root{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.home-pass-modal-container .sp-header{flex-shrink:0}.home-pass-modal-container .sp-track-wrap{flex:1;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch;border-radius:0;border-bottom:none}.home-pass-modal-container .sp-upgrade-banner{flex-shrink:0;margin-top:0;border-radius:0;border-left:none;border-right:none;border-bottom:none;border-top:1px solid rgba(184,134,11,.25)}.home-pass-modal-close{position:absolute;top:.6rem;right:.6rem;z-index:10;background:#ffffffe6;border:none;border-radius:50%;width:30px;height:30px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000040;line-height:1}.home-shield-badge{font-size:.75rem;padding:2px 6px;background:#64b4ff26;border:1px solid rgba(100,180,255,.3);border-radius:20px;color:#8cf;cursor:default;white-space:nowrap}.home-boosts-row{display:flex;align-items:center;gap:.5rem;margin-top:.45rem;flex-wrap:wrap}.home-boost-active{display:flex;align-items:center;gap:.35rem;padding:4px 10px;background:#ffc8001f;border:1px solid rgba(255,200,0,.3);border-radius:20px;font-size:.78rem}.home-boost-active-icon{font-size:.85rem}.home-boost-active-label{color:gold;font-weight:600}.home-boost-active-timer{color:#ffd700a6;font-size:.72rem;font-variant-numeric:tabular-nums}.home-boost-btn{display:flex;align-items:center;gap:.3rem;padding:4px 10px;background:#667eea26;border:1px solid rgba(102,126,234,.35);border-radius:20px;color:#a5b4fc;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.home-boost-btn:hover{background:#667eea47;transform:scale(1.04)}.home-boost-btn-2x{background:#ef44441f;border-color:#ef44444d;color:#fca5a5}.home-boost-btn-2x:hover{background:#ef44443d}.home-boost-qty{font-size:.68rem;opacity:.7;font-weight:400}.admin-panel{padding:clamp(1rem,3vw,2rem);max-width:800px;margin:0 auto}.admin-panel h2{font-size:clamp(1.75rem,4vw,2.5rem);color:#667eea;margin-bottom:.5rem;font-weight:700}.admin-description{font-size:clamp(.95rem,2vw,1.1rem);color:var(--text-secondary);margin-bottom:clamp(1.5rem,3vw,2rem)}.admin-section{background:var(--bg-primary);border-radius:12px;padding:clamp(1.25rem,3vw,1.75rem);margin-bottom:clamp(1.25rem,3vw,1.5rem);box-shadow:var(--shadow-md)}.admin-section h3{font-size:clamp(1.25rem,2.5vw,1.5rem);color:var(--text-primary);margin:0 0 clamp(.5rem,1.5vw,.75rem) 0;font-weight:700}.admin-section>p{font-size:clamp(.9rem,2vw,1rem);color:var(--text-secondary);margin:0 0 clamp(1rem,2.5vw,1.25rem) 0}.admin-input-group{margin-bottom:clamp(1rem,2.5vw,1.25rem)}.admin-input-group label{display:block;font-weight:600;font-size:clamp(.9rem,2vw,1rem);color:var(--text-primary);margin-bottom:.5rem}.admin-input-group input{width:100%;max-width:200px;padding:clamp(.6rem,1.5vw,.75rem);border:2px solid var(--border-primary);border-radius:8px;font-size:clamp(.95rem,2vw,1.05rem);transition:border-color .3s ease}.admin-input-group input:focus{outline:none;border-color:#667eea}.admin-input-group input:disabled{background:var(--bg-secondary);cursor:not-allowed}.admin-btn{padding:clamp(.75rem,2vw,1rem) clamp(1.5rem,3vw,2rem);border:none;border-radius:8px;font-weight:700;font-size:clamp(.95rem,2vw,1.05rem);cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.admin-btn:disabled{opacity:.6;cursor:not-allowed}.admin-btn.primary{background:linear-gradient(135deg,#667eea,#e74c3c);color:var(--bg-primary);box-shadow:0 4px 8px #667eea4d}.admin-btn.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.admin-btn.danger{background:linear-gradient(135deg,#e53e3e,#c53030);color:var(--bg-primary);box-shadow:0 4px 8px #e53e3e4d}.admin-btn.danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #e53e3e66}.admin-info{margin-top:clamp(1rem,2.5vw,1.25rem);padding:clamp(.75rem,2vw,1rem);background:#667eea1a;border-radius:8px;border-left:4px solid #667eea}.admin-info p{margin:.5rem 0;font-size:clamp(.85rem,1.8vw,.95rem);color:var(--text-primary)}.admin-info p:first-child{margin-top:0}.admin-info p:last-child{margin-bottom:0}.danger-zone{border:2px solid #e53e3e;background:#e53e3e0d}.danger-zone h3{color:#e53e3e}.admin-result{margin-top:clamp(1.25rem,3vw,1.5rem);padding:clamp(1rem,2.5vw,1.25rem);border-radius:12px;box-shadow:var(--shadow-md)}.admin-result.success{background:linear-gradient(135deg,#48bb781a,#38a1691a);border-left:4px solid #48bb78}.admin-result.error{background:linear-gradient(135deg,#e53e3e1a,#c530301a);border-left:4px solid #e53e3e}.admin-result h4{font-size:clamp(1.1rem,2.5vw,1.3rem);margin:0 0 .5rem;font-weight:700}.admin-result.success h4{color:#48bb78}.admin-result.error h4{color:#e53e3e}.admin-result p{margin:.5rem 0;font-size:clamp(.9rem,2vw,1rem);color:var(--text-primary)}.result-details{margin-top:clamp(.75rem,2vw,1rem);padding:clamp(.75rem,2vw,1rem);background:#0000000d;border-radius:8px}.result-details p{margin:.25rem 0;font-size:clamp(.85rem,1.8vw,.95rem);font-family:monospace}.admin-empty{margin-top:.75rem;color:var(--text-tertiary);font-style:italic;font-size:.95rem}.gym-submissions-list{display:flex;flex-direction:column;gap:.85rem;margin-top:1rem}.gym-submission-card{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem 1.15rem;background:var(--bg-secondary);border-radius:10px;border:1.5px solid var(--border-primary)}.gym-sub-info{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.gym-sub-info strong{font-size:1rem;color:var(--text-primary)}.gym-sub-type{font-size:.82rem;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.4px}.gym-sub-address,.gym-sub-owner,.gym-sub-desc{font-size:.88rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gym-sub-challenge{font-size:.82rem;color:#667eea;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gym-sub-actions{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.admin-btn.secondary{background:var(--bg-secondary);color:#667eea;border:2px solid #667eea}.admin-btn.secondary:hover:not(:disabled){background:var(--bg-tertiary)}.admin-btn.small{padding:.45rem .9rem;font-size:.88rem;min-width:90px}.qr-approval-result{margin-top:1.25rem;padding:1.25rem;background:linear-gradient(135deg,#48bb7814,#38a16914);border:1.5px solid #68d391;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.qr-approval-header{display:flex;align-items:flex-start;gap:.75rem;text-align:left;width:100%}.qr-approval-icon{font-size:1.5rem;flex-shrink:0}.qr-approval-header strong{font-size:1rem;color:var(--text-primary)}.qr-approval-header p{margin:.2rem 0 0;font-size:.88rem;color:var(--text-secondary)}.qr-approval-img{width:200px;height:200px;border-radius:8px;border:3px solid var(--border-primary)}.qr-approval-value{font-size:.75rem;font-family:monospace;color:var(--text-tertiary);word-break:break-all;margin:0}.admin-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-primary);padding-bottom:0}.admin-tab-btn{padding:.6rem 1.1rem;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;background:transparent;color:var(--text-secondary);font-size:.92rem;font-weight:600;cursor:pointer;border-radius:6px 6px 0 0;transition:color .2s,border-color .2s,background .2s;white-space:nowrap}.admin-tab-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.admin-tab-btn.active{color:#667eea;border-bottom-color:#667eea;background:transparent}.sub-filter-bar{display:flex;flex-wrap:wrap;gap:.4rem;margin:1rem 0 .75rem}.sub-filter-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .8rem;border:1.5px solid var(--border-primary);border-radius:20px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;text-transform:capitalize}.sub-filter-btn:hover{border-color:#667eea;color:#667eea}.sub-filter-btn.active{background:#667eea;border-color:#667eea;color:#fff}.sub-filter-count{background:#00000026;border-radius:10px;padding:0 .4rem;font-size:.75rem;min-width:18px;text-align:center}.sub-filter-btn.active .sub-filter-count{background:#ffffff40}.gym-submission-card{background:var(--bg-secondary);border-radius:10px;border:1.5px solid var(--border-primary);overflow:hidden;transition:border-color .2s}.gym-submission-card.expanded{border-color:#667eea}.gym-sub-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.1rem;cursor:pointer;-webkit-user-select:none;user-select:none;gap:1rem}.gym-sub-header:hover{background:var(--bg-tertiary)}.gym-sub-header-left{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.gym-sub-header-left strong{font-size:.97rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gym-sub-header-right{display:flex;align-items:center;gap:.6rem;flex-shrink:0}.sub-status-badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:700;color:#fff;text-transform:capitalize;letter-spacing:.3px}.sub-expand-icon{color:var(--text-tertiary);font-size:.75rem}.gym-sub-detail{padding:0 1.1rem 1.1rem;border-top:1px solid var(--border-primary)}.gym-sub-detail-grid{display:flex;flex-direction:column;gap:.5rem;margin-top:.9rem}.gym-sub-detail-row{display:grid;grid-template-columns:100px 1fr;gap:.5rem;font-size:.88rem;align-items:start}.detail-label{font-weight:700;color:var(--text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.4px;padding-top:.05rem}.gym-sub-detail .gym-sub-actions{display:flex;flex-direction:row;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.routes-section-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);margin:.75rem 0 0}.custom-routes-list{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem;max-height:320px;overflow-y:auto;padding-right:.25rem}.custom-route-row{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:10px;border:1.5px solid var(--border-primary);transition:border-color .2s}.custom-route-row.route-row-active{border-color:#667eea;background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(102,126,234,.08) 100%)}.custom-route-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.custom-route-info{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.custom-route-info strong{font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.custom-route-info span{font-size:.8rem;color:var(--text-secondary)}.custom-route-actions{display:flex;gap:.4rem;flex-shrink:0}.badge-upload-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.qr-toggle-label{display:flex;align-items:center;gap:.6rem;cursor:pointer;padding:.6rem .75rem;border-radius:8px;border:1.5px solid var(--border-primary);background:var(--bg-secondary);transition:border-color .2s}.qr-toggle-label:hover{border-color:#667eea}.qr-toggle-label input[type=checkbox]{width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:#667eea}.qr-toggle-text{font-size:.88rem;color:var(--text-secondary)}.badge-upload-preview{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--border-primary)}.badge-file-label{cursor:pointer}.gym-picker{background:var(--bg-primary);border:1.5px solid #667eea;border-radius:10px;padding:.85rem;margin-bottom:1rem;max-height:220px;overflow-y:auto}.gym-picker-item{display:flex;flex-direction:column;gap:.1rem;padding:.6rem .75rem;border-radius:7px;cursor:pointer;transition:background .15s}.gym-picker-item:hover{background:var(--bg-secondary)}.gym-picker-item strong{font-size:.92rem;color:var(--text-primary)}.gym-picker-item span{font-size:.8rem;color:var(--text-secondary)}.gym-slot{background:var(--bg-secondary);border:1.5px solid var(--border-primary);border-radius:10px;margin-bottom:.85rem;overflow:hidden}.gym-slot-header{display:flex;align-items:center;gap:.6rem;padding:.65rem .85rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);-webkit-user-select:none;user-select:none}.gym-slot-header:hover{background:var(--bg-secondary)}.gym-slot-chevron{font-size:.65rem;color:var(--text-tertiary);flex-shrink:0}.gym-slot-number{width:24px;height:24px;background:#667eea;color:#fff;border-radius:50%;font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gym-slot-name-input{flex:1;padding:.35rem .65rem;border:1.5px solid var(--border-primary);border-radius:6px;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);min-width:0}.gym-slot-name-input:focus{outline:none;border-color:#667eea}.gym-slot-controls{display:flex;gap:.25rem;flex-shrink:0}.slot-control-btn{width:28px;height:28px;padding:0;border:1.5px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.slot-control-btn:hover:not(:disabled){border-color:#667eea;color:#667eea}.slot-control-btn.danger:hover:not(:disabled){border-color:#e53e3e;color:#e53e3e}.slot-control-btn:disabled{opacity:.3;cursor:not-allowed}.gym-slot-fields{padding:.9rem .85rem}.gym-slot-fields .admin-input-group{margin-bottom:.75rem}.gym-slot-fields .admin-input-group:last-child{margin-bottom:0}.gym-slot-fields .admin-input-group input,.gym-slot-fields .admin-input-group select,.gym-slot-fields .admin-input-group textarea{max-width:100%;width:100%}.gym-slot-fields .admin-input-group textarea{padding:.5rem .65rem;border:1.5px solid var(--border-primary);border-radius:8px;font-size:.9rem;resize:vertical;background:var(--bg-primary);color:var(--text-primary);font-family:inherit}.gym-slot-fields .admin-input-group textarea:focus{outline:none;border-color:#667eea}.gym-slot-fields .admin-input-group select{padding:.5rem .65rem;border:1.5px solid var(--border-primary);border-radius:8px;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.gym-slot-fields .admin-input-group select:focus{outline:none;border-color:#667eea}.route-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.75rem}.route-form-grid .admin-input-group{margin-bottom:0}.route-form-grid .admin-input-group input,.route-form-grid .admin-input-group select{max-width:100%;width:100%;padding:.5rem .65rem;border:1.5px solid var(--border-primary);border-radius:8px;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary)}.route-form-grid .admin-input-group input:focus,.route-form-grid .admin-input-group select:focus{outline:none;border-color:#667eea}.wod-subtabs{display:flex;gap:.35rem;margin-bottom:1.25rem;background:var(--bg-secondary);border-radius:10px;padding:4px}.wod-subtab{flex:1;padding:.5rem 1rem;border:none;border-radius:7px;font-size:.92rem;font-weight:600;color:var(--text-secondary);background:transparent;cursor:pointer;transition:all .2s}.wod-subtab.active{background:linear-gradient(135deg,#667eea,#e74c3c);color:#fff;box-shadow:0 2px 6px #667eea4d}.wod-cal-top{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem}.wod-mode-toggle{display:flex;background:var(--bg-secondary);border-radius:8px;padding:3px;gap:2px;flex-shrink:0}.wod-mode-toggle button{padding:.38rem .9rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;color:var(--text-secondary);background:transparent;cursor:pointer;transition:all .2s;white-space:nowrap}.wod-mode-toggle button.active{background:var(--bg-primary);color:#667eea;box-shadow:0 1px 4px #0000001f}.wod-cal-nav{display:flex;align-items:center;gap:.6rem;flex:1;justify-content:center}.wod-nav-btn{width:32px;height:32px;border:1.5px solid var(--border-primary);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.wod-nav-btn:hover{border-color:#667eea;color:#667eea}.wod-month-label{font-size:1rem;font-weight:700;color:var(--text-primary);min-width:140px;text-align:center;letter-spacing:.01em}.wod-cal-loading{text-align:center;padding:2.5rem;color:var(--text-secondary);font-size:.95rem}.wod-cal-wrap{margin-bottom:1.25rem}.wod-dow-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:4px}.wod-dow{text-align:center;font-size:.72rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:.25rem 0}.wod-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.wod-day-cell{aspect-ratio:1;border-radius:8px;border:1.5px solid var(--border-primary);background:var(--bg-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;position:relative;min-height:42px}.wod-day-cell.empty{background:transparent;border-color:transparent;cursor:default;pointer-events:none}.wod-day-cell:not(.empty):hover{border-color:#667eea;transform:scale(1.04)}.wod-day-cell.has-wod{background:#27ae601f;border-color:#27ae6073}.wod-day-cell.has-wod:hover{background:#27ae6038;border-color:#27ae60}.wod-day-cell.selected{border-color:#667eea!important;background:#667eea1f!important;box-shadow:0 0 0 2px #667eea4d}.wod-day-cell.today .wod-day-num{color:#667eea;font-weight:800}.wod-day-num{font-size:clamp(.78rem,2vw,.9rem);font-weight:600;color:var(--text-primary);line-height:1}.wod-day-pip{width:5px;height:5px;border-radius:50%;background:#27ae60;margin-top:3px;flex-shrink:0}.wod-cal-legend{display:flex;align-items:center;gap:1.25rem;margin-top:.75rem;font-size:.78rem;color:var(--text-secondary)}.wod-legend-dot{display:inline-block;width:12px;height:12px;border-radius:3px;border:1.5px solid;margin-right:.35rem;vertical-align:middle}.wod-legend-dot.has-wod{background:#27ae6026;border-color:#27ae608c}.wod-legend-dot.empty-day{background:var(--bg-secondary);border-color:var(--border-primary)}.wod-week-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}.wod-week-row{display:flex;align-items:center;gap:1rem;padding:.7rem 1rem;border-radius:10px;border:1.5px solid var(--border-primary);background:var(--bg-secondary);cursor:pointer;transition:all .15s}.wod-week-row:hover{border-color:#667eea}.wod-week-row.has-challenge{background:#27ae6014;border-color:#27ae6066}.wod-week-row.has-challenge:hover{border-color:#27ae60;background:#27ae6026}.wod-week-row.selected{border-color:#667eea!important;background:#667eea1a!important;box-shadow:0 0 0 2px #667eea40}.wod-week-id{font-family:Oswald,monospace;font-size:.85rem;font-weight:700;color:#667eea;min-width:68px;letter-spacing:.04em}.wod-week-range{flex:1;font-size:.88rem;color:var(--text-primary);font-weight:500}.wod-week-badge{font-size:.78rem;font-weight:700;padding:.2rem .6rem;border-radius:20px;flex-shrink:0}.wod-week-badge.set{background:#27ae6026;color:#27ae60}.wod-week-badge.empty{background:var(--bg-tertiary);color:var(--text-secondary);border:1px dashed var(--border-primary)}.wod-form{margin-top:1.5rem;padding:1.25rem;background:var(--bg-secondary);border-radius:12px;border:1.5px solid #667eea;box-shadow:0 0 0 3px #667eea1a}.wod-form-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding-bottom:.85rem;border-bottom:1px solid var(--border-primary)}.wod-form-title{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.wod-form-date{font-family:Oswald,monospace;font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:.04em}.wod-form-range{font-size:.85rem;color:var(--text-secondary);font-weight:500}.wod-form-mode-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#667eea;background:#667eea1a;padding:.15rem .55rem;border-radius:20px}.wod-form-loading{text-align:center;padding:1.5rem;color:var(--text-secondary);font-size:.95rem}.wod-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;margin-bottom:.75rem}.wod-form-grid .admin-input-group{margin-bottom:0}.wod-form-grid .admin-input-group.full-col{grid-column:1 / -1}.wod-form-grid .admin-input-group input,.wod-form-grid .admin-input-group select{max-width:100%;width:100%;padding:.5rem .65rem;border:1.5px solid var(--border-primary);border-radius:8px;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary)}.wod-form-grid .admin-input-group input:focus,.wod-form-grid .admin-input-group select:focus{outline:none;border-color:#667eea}.wod-optional{font-size:.75rem;font-weight:400;color:var(--text-tertiary)}.wod-textarea-group{margin-bottom:.75rem}.wod-textarea-group textarea{width:100%;padding:.6rem .75rem;border:1.5px solid var(--border-primary);border-radius:8px;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;resize:vertical;box-sizing:border-box}.wod-textarea-group textarea:focus{outline:none;border-color:#667eea}.wod-exercise-list{display:flex;flex-direction:column;gap:.4rem}.wod-exercise-row{display:flex;align-items:center;gap:.5rem}.wod-exercise-num{width:22px;height:22px;border-radius:50%;background:#667eea26;color:#667eea;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wod-exercise-row input{flex:1;padding:.45rem .65rem;border:1.5px solid var(--border-primary);border-radius:7px;font-size:.88rem;background:var(--bg-primary);color:var(--text-primary)}.wod-exercise-row input:focus{outline:none;border-color:#667eea}.wod-form-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-primary)}@media(max-width:768px){.admin-tab-btn{padding:.5rem .7rem;font-size:.82rem}.admin-btn{width:100%;justify-content:center}.gym-sub-actions,.custom-route-actions{flex-direction:row;width:100%}.admin-btn.small{flex:1}.gym-sub-detail-row{grid-template-columns:80px 1fr}.route-form-grid{grid-template-columns:1fr 1fr}}.levelup-overlay{position:fixed;inset:0;background:#000000b8;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:levelup-bg-in .3s ease}@keyframes levelup-bg-in{0%{opacity:0}to{opacity:1}}.levelup-card{position:relative;background:linear-gradient(160deg,#1a1a2e,#16213e,#0f3460);border:1px solid rgba(102,126,234,.4);border-radius:24px;padding:2.5rem 2rem 2rem;width:100%;max-width:380px;text-align:center;overflow:hidden;box-shadow:0 0 60px #667eea59,0 24px 64px #0009;animation:levelup-card-in .45s cubic-bezier(.34,1.56,.64,1)}@keyframes levelup-card-in{0%{opacity:0;transform:scale(.6) translateY(40px)}to{opacity:1;transform:scale(1) translateY(0)}}.levelup-card:before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%);animation:levelup-sheen 2.5s ease .5s infinite;pointer-events:none}@keyframes levelup-sheen{0%{transform:translate(-100%)}to{transform:translate(200%)}}.levelup-confetti{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;top:-12px;left:var(--x);width:var(--size);height:var(--size);background:var(--color);opacity:0;animation:confetti-fall 2s ease-in var(--delay) forwards}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0) translate(0) rotate(0)}60%{opacity:1}to{opacity:0;transform:translateY(380px) translate(var(--drift)) rotate(var(--spin))}}.levelup-stars{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.levelup-star{position:absolute;top:50%;left:50%;font-size:.85rem;color:#f6d365;opacity:0;animation:star-burst .9s ease calc(var(--si) * .08s + .3s) forwards;--angle: calc(var(--si) * 45deg);--dist: 110px}@keyframes star-burst{0%{opacity:0;transform:translate(-50%,-50%) rotate(var(--angle)) translateY(0)}40%{opacity:1}to{opacity:0;transform:translate(-50%,-50%) rotate(var(--angle)) translateY(calc(-1 * var(--dist)))}}.levelup-badge-wrap{display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-bottom:1rem;position:relative;z-index:1}.levelup-badge{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:2.6rem;box-shadow:0 0 0 6px #667eea40,0 0 30px #667eea80;animation:badge-pop .6s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes badge-pop{0%{transform:scale(0)}to{transform:scale(1)}}.levelup-badge-level{font-size:.78rem;font-weight:800;letter-spacing:.12em;color:#667eea;background:#667eea26;padding:.2rem .7rem;border-radius:50px;border:1px solid rgba(102,126,234,.3)}.levelup-headline{font-size:clamp(1.8rem,6vw,2.4rem);font-weight:900;margin:0 0 .25rem;background:linear-gradient(135deg,#fff,#c3cfe2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:levelup-text-in .4s ease .35s both;position:relative;z-index:1}.levelup-rank{font-size:1.1rem;font-weight:700;color:#a78bfa;margin:0 0 1.25rem;letter-spacing:.04em;animation:levelup-text-in .4s ease .45s both;position:relative;z-index:1}@keyframes levelup-text-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.levelup-unlock{background:#667eea1f;border:1px solid rgba(102,126,234,.3);border-radius:14px;padding:.9rem 1.1rem;margin-bottom:1rem;position:relative;z-index:1;animation:levelup-text-in .4s ease .55s both}.levelup-unlock-chip{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.1em;color:#667eea;text-transform:uppercase;margin-bottom:.4rem}.levelup-unlock-text{font-size:.9rem;color:#ffffffd9;line-height:1.5;margin:0}.levelup-unlock-theme{background:#ffc8501a;border-color:#ffc8504d;animation-delay:.65s}.levelup-unlock-chip-theme{color:gold}.levelup-theme-swatches{display:flex;gap:.4rem;margin-top:.55rem;flex-wrap:wrap}.levelup-color-dot{width:1.3rem;height:1.3rem;border-radius:50%;border:2px solid rgba(255,255,255,.3);display:inline-block;flex-shrink:0}.levelup-gradient-preview{height:1.5rem;border-radius:8px;margin-top:.55rem;border:2px solid rgba(255,255,255,.2)}.levelup-unlock-frame{background:#b482321f;border-color:#cd7f3259;animation-delay:.7s}.levelup-unlock-chip-frame{color:#cd7f32}.levelup-frame-preview{margin-top:.6rem;width:3rem;height:3rem;align-self:center}.levelup-frame-avatar{width:100%;height:100%;border-radius:50%;background:#1a1a2e}.levelup-next{font-size:.82rem;color:#ffffff73;margin:0 0 1.5rem;position:relative;z-index:1;animation:levelup-text-in .4s ease .6s both}.levelup-next strong{color:#ffffffb3}.levelup-cta{width:100%;padding:.85rem;border-radius:50px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1rem;font-weight:800;cursor:pointer;position:relative;z-index:1;box-shadow:0 4px 20px #667eea73;transition:transform .15s,box-shadow .15s;animation:levelup-text-in .4s ease .65s both}.levelup-cta:hover{transform:translateY(-2px);box-shadow:0 6px 26px #667eea99}.levelup-cta:active{transform:translateY(0)}.ap-overlay{position:fixed;inset:0;background:#000000b8;z-index:9150;display:flex;align-items:center;justify-content:center;padding:1rem}.ap-card{position:relative;display:flex;align-items:center;gap:1.4rem;background:linear-gradient(135deg,#1c1000,#110a00,#160c00);border:1px solid rgba(210,140,10,.38);border-radius:20px;padding:1.6rem 1.75rem;max-width:370px;width:100%;box-shadow:0 0 55px #be780047,0 16px 48px #000000a6;animation:ap-stamp .42s cubic-bezier(.22,1.4,.6,1) both;isolation:isolate;overflow:hidden}.ap-card:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(255,200,60,.055) 50%,transparent 65%);background-size:250% 100%;animation:ap-sheen 3s ease-in-out .7s infinite;pointer-events:none;z-index:1}@keyframes ap-stamp{0%{transform:scale(.72) perspective(600px) rotateX(14deg);opacity:0}to{transform:scale(1) perspective(600px) rotateX(0);opacity:1}}@keyframes ap-sheen{0%{background-position:-100% 0}55%{background-position:200% 0}to{background-position:200% 0}}.ap-halo-wrap{position:relative;flex-shrink:0;width:72px;height:72px;display:flex;align-items:center;justify-content:center}.ap-halo{position:absolute;inset:-5px;border-radius:50%;background:conic-gradient(from 0deg,#a05500,#ffcc30,#d08000,#ffe060,#a05500);animation:ap-halo-spin 3s linear infinite;filter:blur(1.5px);opacity:.85}.ap-halo:after{content:"";position:absolute;inset:5px;border-radius:50%;background:#110a00}.ap-icon{position:relative;z-index:1;font-size:2.4rem;line-height:1;width:56px;height:56px;display:flex;align-items:center;justify-content:center;animation:ap-icon-pop .38s cubic-bezier(.34,1.56,.64,1) .12s both}.ap-icon img{width:56px;height:56px;object-fit:contain}@keyframes ap-icon-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}@keyframes ap-halo-spin{to{transform:rotate(360deg)}}.ap-body{flex:1;min-width:0;position:relative;z-index:2}.ap-eyebrow{font-size:.64rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:#c87800;margin-bottom:.25rem;animation:ap-fade-up .35s ease .18s both}.ap-name{font-size:1.2rem;font-weight:900;color:#ffe07a;line-height:1.15;margin-bottom:.3rem;animation:ap-fade-up .35s ease .28s both}.ap-desc{font-size:.78rem;color:#ffd26e99;line-height:1.4;margin-bottom:1rem;animation:ap-fade-up .35s ease .38s both}.ap-close-btn{background:#be780033;border:1px solid rgba(200,130,0,.4);color:#ffcc50;border-radius:10px;padding:.42rem 1.1rem;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s;animation:ap-fade-up .35s ease .48s both}.ap-close-btn:hover{background:#be78005c}@keyframes ap-fade-up{0%{opacity:0;transform:translateY(7px)}to{opacity:1;transform:translateY(0)}}.shop-container{max-width:1100px;margin:0 auto;padding-bottom:5rem;color:var(--text-primary, #111827);box-sizing:border-box;width:100%;overflow-x:hidden}.shop-hero{position:relative;border-radius:20px;overflow:hidden;margin:.75rem .75rem 0;min-height:180px;display:flex;align-items:center}.shop-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(255,215,0,.18) 0%,transparent 45%),radial-gradient(ellipse at 80% 30%,rgba(160,0,255,.2) 0%,transparent 45%),radial-gradient(ellipse at 60% 80%,rgba(255,80,0,.12) 0%,transparent 40%),linear-gradient(135deg,#0a0010,#120020,#1a0030 60%,#0d0018)}.shop-hero-bg:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,215,0,.025) 0px,rgba(255,215,0,.025) 1px,transparent 1px,transparent 28px),repeating-linear-gradient(-45deg,rgba(160,0,255,.02) 0px,rgba(160,0,255,.02) 1px,transparent 1px,transparent 40px)}.shop-hero-content{position:relative;z-index:1;padding:2rem}.shop-hero-eyebrow{font-size:.65rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:gold;margin-bottom:.5rem}.shop-hero-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:900;line-height:1.1;background:linear-gradient(90deg,gold,#fff,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.4rem}.shop-hero-sub{font-size:.9rem;color:#ffffffe0;max-width:420px;line-height:1.5}.shop-hero-coins{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;background:#ffd7001a;border:1px solid rgba(255,215,0,.25);border-radius:20px;padding:.3rem .8rem;font-size:.78rem;color:gold;font-weight:600}.shop-tabs{display:flex;gap:.4rem;padding:.75rem .75rem 0;overflow-x:auto;scrollbar-width:none}.shop-tabs::-webkit-scrollbar{display:none}.shop-tab{flex-shrink:0;background:#0000000d;border:1px solid rgba(0,0,0,.1);border-radius:20px;padding:.45rem 1rem;color:var(--text-secondary, #4b5563);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap}.shop-tab:hover{background:#00000017;color:var(--text-primary, #111827)}.shop-tab-active{background:#ffd70026;border-color:#ffd70066;color:gold}.shop-content{padding:0 .75rem}.shop-section{margin-top:2rem}.shop-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.shop-section-title{font-size:1.1rem;font-weight:800;color:var(--text-primary, #111827);display:flex;align-items:center;gap:.5rem;margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-section-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.shop-section-badge{font-size:.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;border-radius:20px;border:1px solid rgba(0,0,0,.15);color:var(--text-secondary, #6b7280);background:#0000000d;white-space:nowrap}.shop-section-badge.new{background:#ff50501f;border-color:#ff50504d;color:#f87171}.shop-section-badge.gold{background:#ffd7001a;border-color:#ffd7004d;color:gold}.sp-spotlight{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.sp-spotlight-bg{position:relative;display:flex;gap:1.5rem;flex-wrap:wrap}.sp-spotlight-overlay{position:absolute;inset:0;background:#000000a6}.sp-spotlight-left,.sp-spotlight-right{position:relative;z-index:1}.sp-spotlight-left{flex:1;min-width:min(220px,100%);padding:1.75rem 1.5rem}.sp-spotlight-eyebrow{font-size:.65rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:#ffffffe0;margin-bottom:.4rem}.sp-spotlight-title{font-size:1.7rem;font-weight:900;color:#fff;margin:0 0 .35rem;text-shadow:0 2px 12px rgba(0,0,0,.6)}.sp-spotlight-desc{font-size:.82rem;color:#ffffffe0;margin-bottom:1.2rem}.sp-spotlight-frames{display:flex;gap:.75rem;flex-wrap:wrap}.sp-spotlight-frame{display:flex;align-items:center;justify-content:center}.sp-spotlight-avatar{width:38px;height:38px;border-radius:50%;background:#1a1a2e;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.sp-spotlight-banner-row{margin-top:.85rem}.sp-spotlight-banner-label{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.7;margin-bottom:.3rem;color:#fff}.sp-spotlight-banner-chip{position:relative;height:52px;width:min(200px,100%);border-radius:8px;overflow:hidden;display:flex;align-items:flex-end;padding:.3rem .45rem;box-shadow:0 2px 8px #00000059}.sp-spotlight-banner-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}.sp-spotlight-banner-chip-name{position:relative;z-index:1;font-size:.62rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.9);background:#00000059;padding:.1rem .35rem;border-radius:4px;white-space:nowrap}.sp-spotlight-right{padding:1.25rem;display:flex;align-items:center;justify-content:center;min-width:min(220px,100%);width:100%}.sp-spotlight-price-card{background:#0000008c;border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:1.25rem 1.5rem;width:100%;max-width:260px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sp-spotlight-price{font-size:2.2rem;font-weight:900;color:#fff;line-height:1}.sp-spotlight-price-desc{font-size:.75rem;color:#ffffffd1;margin-bottom:1rem}.sp-spotlight-perks{list-style:none;padding:0;margin:0 0 1.2rem;display:flex;flex-direction:column;gap:.35rem}.sp-spotlight-perks li{font-size:.8rem;color:#ffffffeb}.sp-spotlight-buy-btn{width:100%;padding:.7rem 1rem;border-radius:10px;border:none;font-size:.95rem;font-weight:800;cursor:pointer;letter-spacing:.5px;background:var(--season-color, #ffd700);color:#000;box-shadow:0 4px 20px color-mix(in srgb,var(--season-color, #ffd700) 50%,transparent);transition:filter .18s,transform .15s}.sp-spotlight-buy-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.sp-spotlight-free{font-size:.68rem;color:#ffffffad;text-align:center;margin-top:.6rem}.sp-spotlight-track-btn{width:100%;padding:.55rem;border-radius:10px;border:1px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:background .15s}.sp-spotlight-track-btn:hover{background:#fff3}.sp-track-overlay{position:fixed;inset:0;background:#000000bf;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.sp-track-modal{background:var(--bg-primary);border-radius:18px;width:100%;max-width:380px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 64px #0000008c;position:relative}.sp-track-close{position:absolute;top:.6rem;right:.6rem;z-index:10;background:#00000073;border:none;color:#fff;width:26px;height:26px;border-radius:50%;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.sp-track-header{position:relative;padding:.85rem .85rem .75rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem;min-height:80px;flex-shrink:0}.sp-track-header-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#000000a6,#00000073)}.sp-track-header-content{position:relative;z-index:1;flex:1}.sp-track-eyebrow{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff9;display:block;margin-bottom:.15rem}.sp-track-title{font-size:1.1rem;font-weight:800;color:#fff;margin:0}.sp-track-buy-btn{position:relative;z-index:1;flex-shrink:0;padding:.4rem .7rem;border-radius:9px;border:none;background:var(--season-color, #667eea);color:#fff;font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:filter .15s}.sp-track-buy-btn:hover{filter:brightness(1.15)}.sp-track-col-headers{display:grid;grid-template-columns:28px 1fr 1fr;gap:.4rem;padding:.4rem .65rem;border-bottom:1px solid var(--border-primary);flex-shrink:0;background:var(--bg-secondary)}.sp-track-col-header{font-size:.65rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;text-align:center;padding:.2rem 0;border-radius:5px}.sp-track-col-header-free{color:#22c55e;background:#22c55e1a;border:1px solid rgba(34,197,94,.2)}.sp-track-col-header-premium{color:#b8860b;background:#b8860b1f;border:1px solid rgba(184,134,11,.3)}.sp-track-slot{height:224px;overflow:hidden;position:relative;flex-shrink:0}.sp-track-slot-fade-top,.sp-track-slot-fade-bottom{position:absolute;left:0;right:0;height:52px;z-index:2;pointer-events:none}.sp-track-slot-fade-top{top:0;background:linear-gradient(to bottom,var(--bg-primary) 20%,transparent)}.sp-track-slot-fade-bottom{bottom:0;background:linear-gradient(to top,var(--bg-primary) 20%,transparent)}.sp-track-rows{height:100%;overflow-y:auto;scroll-snap-type:y mandatory;scrollbar-width:none;padding-bottom:168px}.sp-track-rows::-webkit-scrollbar{display:none}.sp-track-row{display:grid;grid-template-columns:28px 1fr 1fr;gap:.4rem;padding:.3rem .65rem;scroll-snap-align:start;border-bottom:1px solid var(--border-primary);height:56px;align-items:center;box-sizing:border-box;transition:background .15s}.sp-track-row:hover{background:var(--bg-secondary)}.sp-track-row-final{background:#b8860b0f;border-color:#b8860b40}.sp-track-row-tier{font-size:.7rem;font-weight:800;text-align:center;line-height:1}.sp-track-cell{display:flex;align-items:center;gap:.3rem;padding:.3rem .4rem;border-radius:7px;border:1px solid transparent;height:40px;box-sizing:border-box}.sp-track-cell-free{background:#22c55e0f;border-color:#22c55e26}.sp-track-cell-premium{background:#b8860b1a;border-color:#b8860b47;box-shadow:inset 0 0 0 1px #ffd70014}.sp-track-cell-empty{background:transparent;border-color:transparent;opacity:.25}.sp-track-cell-icon{font-size:1rem;line-height:1;flex-shrink:0}.sp-track-cell-label{font-size:.65rem;font-weight:600;color:var(--text-primary);line-height:1.25}.sp-track-cell-dash{font-size:.9rem;color:var(--text-secondary);margin:auto}.sp-track-footer-note{text-align:center;font-size:.65rem;color:var(--text-secondary);padding:.4rem 1rem;border-top:1px solid var(--border-primary);margin:0;flex-shrink:0}.sp-pass-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.sp-card{background:#1c1c2a;border:1px solid rgba(255,255,255,.07);border-radius:14px;overflow:hidden;transition:transform .2s,box-shadow .2s}.sp-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #00000080}.sp-card-active{border-color:#ffd7004d;box-shadow:0 0 0 1px #ffd70026}.sp-card-banner{position:relative;height:100px}.sp-card-banner-overlay{position:absolute;inset:0;background:#0009}.sp-card-banner-content{position:relative;z-index:1;padding:.75rem 1rem}.sp-season-num{font-size:.6rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#ffffffe0}.sp-season-name{font-size:1.1rem;font-weight:800;color:#fff;margin:.15rem 0 .2rem}.sp-season-theme{font-size:.7rem;color:#ffffffd9;margin:0}.sp-active-badge{position:absolute;top:.6rem;right:.6rem;z-index:2;background:gold;color:#000;font-size:.55rem;font-weight:900;letter-spacing:1.5px;padding:3px 8px;border-radius:10px}.sp-card-body{padding:.9rem 1rem 1rem}.sp-rewards-preview{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.8rem}.sp-reward-frame{display:flex;align-items:center;justify-content:center}.sp-reward-avatar{width:30px;height:30px;border-radius:50%;background:#1a1a2e;display:flex;align-items:center;justify-content:center;font-size:.85rem}.sp-reward-banner-thumb{width:38px;height:24px;border-radius:5px;border:1px solid rgba(255,255,255,.12)}.sp-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sp-price-block{flex:1}.sp-price{font-size:1.3rem;font-weight:900;color:#fff}.sp-price-sub{font-size:.65rem;color:#ffffffbf;display:block}.sp-buy-btn{padding:.5rem .9rem;border-radius:8px;border:none;font-size:.8rem;font-weight:800;cursor:pointer;background:var(--season-color, #ffd700);color:#000;transition:filter .18s;white-space:nowrap}.sp-buy-btn:hover{filter:brightness(1.2)}.sp-buy-btn:not(.sp-buy-btn-active){background:#ffffff14;color:#ffffff9e;cursor:not-allowed}.sp-track-section{margin-top:1.5rem}.sp-track-title{font-size:.9rem;font-weight:700;color:var(--text-primary, #111827);margin-bottom:.75rem}.sp-track-scroll{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.sp-track-node{min-width:72px;flex-shrink:0;display:flex;flex-direction:column;gap:.3rem}.sp-track-tier{font-size:.6rem;font-weight:700;color:var(--text-secondary, #6b7280);text-align:center}.sp-track-reward{border-radius:8px;padding:.4rem .3rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;min-height:52px;justify-content:center}.sp-track-free{background:#0000000a;border:1px solid rgba(0,0,0,.1)}.sp-track-premium{background:#ffd70014;border:1px solid rgba(255,215,0,.2)}.sp-track-icon{font-size:1.2rem}.sp-track-label{font-size:.58rem;color:var(--text-secondary, #6b7280);text-align:center;line-height:1.3}.sp-track-premium .sp-track-label{color:gold}.sp-track-legend{display:flex;gap:1rem;margin-top:.5rem;font-size:.7rem}.sp-legend-free{color:var(--text-secondary, #6b7280)}.sp-legend-premium{color:gold}.shop-grid{display:grid;gap:.85rem}.shop-grid-frames{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.shop-grid-banners{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.shop-item-card{background:#1c1c2a;border:1px solid rgba(255,255,255,.07);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}.shop-item-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px #00000080}.shop-item-preview{background:#0d0d18;display:flex;align-items:center;justify-content:center;padding:1.4rem 1rem;position:relative;min-height:100px}.shop-frame-ring{display:flex;align-items:center;justify-content:center}.shop-frame-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#2a2a3e,#1a1a28);display:flex;align-items:center;justify-content:center;font-size:1.4rem}.shop-animated-badge{position:absolute;bottom:.4rem;right:.4rem;font-size:.6rem;font-weight:700;background:#a064ff33;border:1px solid rgba(160,100,255,.4);color:#c084fc;padding:2px 7px;border-radius:8px}.shop-banner-preview{height:90px;position:relative;display:flex;align-items:flex-end;padding:.5rem .75rem}.shop-banner-preview:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.3) 50%,transparent 100%);z-index:1}.shop-banner-name{position:relative;z-index:2;font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.8)}.shop-item-info{padding:.65rem .8rem .5rem;flex:1}.shop-item-name{font-size:.85rem;font-weight:700;color:var(--text-primary, #111827);margin-bottom:.3rem}.shop-item-sub{font-size:.7rem;color:var(--text-secondary, #6b7280);margin-bottom:.25rem}.shop-item-price{font-size:.82rem;font-weight:700;color:gold;display:flex;align-items:center;gap:.25rem}.shop-item-pass-price{font-size:.75rem}.shop-coin-icon{font-size:.9rem}.shop-buy-btn{margin:0 .8rem .8rem;padding:.5rem .75rem;border-radius:8px;border:none;font-size:.78rem;font-weight:800;cursor:pointer;letter-spacing:.3px;transition:filter .18s,transform .15s}.shop-buy-btn:hover{filter:brightness(1.18);transform:translateY(-1px)}.shop-buy-btn-coin{background:#ffd70026;border:1px solid rgba(255,215,0,.3);color:gold}.shop-buy-btn-coin:hover{background:#ffd70040}.shop-buy-btn-pass{background:#ffffff12;border:1px solid color-mix(in srgb,var(--season-color, #fff) 40%,transparent);color:var(--season-color, #fff)}.shop-buy-btn-pass:hover{background:color-mix(in srgb,var(--season-color, #fff) 15%,transparent)}.shop-pass-frame-card .shop-item-preview{background:#0d0d18}.shop-coins-desc{font-size:.85rem;color:var(--text-secondary, #6b7280);margin:0 0 1.25rem;line-height:1.5}.shop-coins-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(140px,22vw,180px),1fr));gap:1rem}.shop-coin-card{background:#1c1c2a;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.25rem 1rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.3rem;position:relative;transition:transform .2s,box-shadow .2s}.shop-coin-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px #00000073}.shop-coin-card-popular{border-color:#ffd70080;box-shadow:0 0 0 1px #ffd70033}.shop-coin-card-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:linear-gradient(90deg,gold,#ff8c00);color:#000;font-size:.6rem;font-weight:900;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;border-radius:10px;white-space:nowrap}.shop-coin-card-visual{display:flex;align-items:center;justify-content:center;margin:.75rem 0 .5rem;min-height:120px}.coin-pack-img{width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(255,215,0,.3));border-radius:12px}.coin-stack{position:relative}.coin-img-layer{position:absolute;left:0;width:72px;height:72px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5));border-radius:50%}.shop-coin-card-amount{font-size:1.5rem;font-weight:900;color:gold}.shop-coin-card-label{font-size:.8rem;font-weight:700;color:#e8e8f0}.shop-coin-card-bonus{font-size:.7rem;font-weight:700;color:#4ade80;background:#4ade801a;border:1px solid rgba(74,222,128,.25);padding:2px 8px;border-radius:8px}.shop-coin-card-note{font-size:.65rem;color:#ffffff80;text-align:center}.shop-coin-card-btn{margin-top:.6rem;width:100%;padding:.55rem .75rem;border-radius:9px;border:none;font-size:.9rem;font-weight:800;cursor:pointer;background:linear-gradient(135deg,gold,#ff8c00);color:#000;transition:filter .18s,transform .15s}.shop-coin-card-popular .shop-coin-card-btn{box-shadow:0 4px 16px #ffd7004d}.shop-coin-card-btn:hover{filter:brightness(1.12);transform:translateY(-1px)}.shop-toast{position:fixed;bottom:6rem;left:50%;transform:translate(-50%);z-index:1100;padding:.75rem 1.5rem;border-radius:12px;font-size:.88rem;font-weight:700;white-space:nowrap;animation:shopToastIn .25s ease}.shop-toast-success{background:#1a3d1a;border:1px solid #4ade80;color:#4ade80}.shop-toast-error{background:#3d1a1a;border:1px solid #f87171;color:#f87171}@keyframes shopToastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.shop-item-card-clickable{cursor:pointer}.shop-preview-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.shop-preview-modal{background:#15151f;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;max-width:380px;width:100%;position:relative;text-align:center}.shop-preview-close{position:absolute;top:.75rem;right:.75rem;background:#ffffff12;border:none;color:#ffffffc7;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center}.shop-preview-frame-stage{position:relative;display:flex;align-items:center;justify-content:center;background:#0d0d18;border-radius:14px;padding:2.5rem 1rem;margin-bottom:1.25rem}.shop-preview-frame-ring{display:flex;align-items:center;justify-content:center}.shop-preview-frame-avatar{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,#2a2a3e,#1a1a28);display:flex;align-items:center;justify-content:center;font-size:2.4rem}.shop-preview-animated-badge{position:absolute;bottom:.6rem;right:.6rem;font-size:.65rem;font-weight:700;background:#a064ff33;border:1px solid rgba(160,100,255,.4);color:#c084fc;padding:3px 8px;border-radius:8px}.shop-preview-banner-stage{position:relative;height:160px;border-radius:14px;overflow:hidden;margin-bottom:1.25rem;display:flex;align-items:flex-end;padding:1rem 1.25rem}.shop-preview-banner-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.2) 60%,transparent 100%)}.shop-preview-banner-profile{position:relative;z-index:1;display:flex;align-items:center;gap:.75rem}.shop-preview-banner-avatar{width:48px;height:48px;border-radius:50%;background:#0006;border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;font-size:1.4rem}.shop-preview-banner-username{font-size:.95rem;font-weight:800;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.8)}.shop-preview-banner-sub{font-size:.72rem;color:#ffffffc7;text-shadow:0 1px 3px rgba(0,0,0,.8)}.shop-preview-name{font-size:1.1rem;font-weight:800;color:#e8e8f0;margin-bottom:.2rem}.shop-preview-meta{font-size:.75rem;color:#ffffff8c;margin-bottom:.75rem}.shop-preview-price{font-size:1.15rem;font-weight:800;color:gold;margin-bottom:1.1rem;display:flex;align-items:center;justify-content:center;gap:.3rem}.shop-preview-buy-btn{width:100%;padding:.7rem 1rem;border-radius:10px;border:none;font-size:.95rem;font-weight:800;cursor:pointer;background:linear-gradient(135deg,gold,#ff8c00);color:#000;transition:filter .18s,transform .15s}.shop-preview-buy-btn:hover{filter:brightness(1.12);transform:translateY(-1px)}.shop-confirm-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.shop-confirm-modal{background:#15151f;border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:2rem 1.75rem;max-width:360px;width:100%;position:relative;text-align:center}.shop-confirm-close{position:absolute;top:.75rem;right:.75rem;background:#ffffff12;border:none;color:#ffffffc7;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center}.shop-confirm-icon{font-size:2.4rem;margin-bottom:.75rem}.shop-confirm-title{font-size:1.1rem;font-weight:800;color:#e8e8f0;margin:0 0 .3rem}.shop-confirm-price{font-size:1.4rem;font-weight:900;color:gold;margin-bottom:.75rem}.shop-confirm-desc{font-size:.8rem;color:#ffffffd1;line-height:1.5;margin-bottom:1.25rem}.shop-confirm-actions{display:flex;gap:.6rem}.shop-confirm-cancel{flex:1;padding:.6rem;border-radius:9px;border:1px solid rgba(255,255,255,.1);background:transparent;color:#ffffffd1;font-size:.85rem;font-weight:600;cursor:pointer}.shop-confirm-buy{flex:2;padding:.6rem;border-radius:9px;border:none;background:linear-gradient(135deg,gold,#ff8c00);color:#000;font-size:.85rem;font-weight:800;cursor:pointer;transition:filter .18s}.shop-confirm-buy:hover{filter:brightness(1.12)}.shop-container{padding-left:clamp(0rem,2vw,1rem);padding-right:clamp(0rem,2vw,1rem)}.shop-hero{margin:clamp(.4rem,1.5vw,.75rem) clamp(.4rem,1.5vw,.75rem) 0}.shop-hero-content{padding:clamp(1.25rem,4vw,2rem) clamp(1rem,4vw,2rem)}.shop-tabs{padding:clamp(.5rem,2vw,.75rem) clamp(.4rem,1.5vw,.75rem) 0;gap:clamp(.25rem,1vw,.4rem)}.shop-content{padding:0 clamp(.4rem,1.5vw,.75rem)}.shop-section{margin-top:clamp(1.25rem,4vw,2rem)}.shop-grid-frames{grid-template-columns:repeat(auto-fill,minmax(clamp(120px,22vw,160px),1fr))}.shop-grid-banners{grid-template-columns:repeat(auto-fill,minmax(clamp(150px,35vw,210px),1fr))}.sp-pass-grid{grid-template-columns:repeat(auto-fill,minmax(clamp(200px,42vw,260px),1fr))}@media(min-width:900px){.shop-grid-frames{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.shop-grid-banners{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.sp-pass-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media(max-width:899px)and (min-width:480px){.sp-spotlight-bg{flex-direction:column}.sp-spotlight-right{padding:0 1.25rem 1.25rem}.sp-spotlight-price-card{max-width:100%}.sp-spotlight-left{padding:1.5rem 1.25rem;min-width:0}.shop-preview-frame-avatar{width:72px;height:72px;font-size:2rem}}@media(max-width:479px){.shop-hero{border-radius:14px;min-height:140px}.shop-hero-sub{font-size:.8rem}.shop-tab{padding:.4rem .65rem;font-size:.76rem}.sp-spotlight-bg{flex-direction:column}.sp-spotlight-left{padding:1.1rem 1rem;min-width:0}.sp-spotlight-right{padding:0 1rem 1.1rem;min-width:0}.sp-spotlight-price-card{max-width:100%}.sp-spotlight-title{font-size:1.25rem}.sp-spotlight-price{font-size:1.75rem}.shop-grid-frames{grid-template-columns:repeat(2,1fr);gap:.6rem}.shop-grid-banners,.sp-pass-grid{grid-template-columns:1fr}.shop-section-header{flex-wrap:wrap;gap:.4rem}.shop-section-title{font-size:.95rem;white-space:normal}.shop-section-badge{font-size:.58rem;padding:2px 7px}.shop-item-preview{padding:1rem .75rem;min-height:85px}.shop-frame-avatar{width:44px;height:44px;font-size:1.2rem}.shop-item-info{padding:.5rem .65rem .4rem}.shop-item-name{font-size:.78rem}.shop-buy-btn{margin:0 .65rem .65rem;font-size:.72rem}.shop-coin-card{padding:1rem .75rem .75rem}.shop-coin-card-visual{min-height:90px;margin:.5rem 0 .25rem}.shop-coin-card-amount{font-size:1.25rem}.shop-coin-card-label{font-size:.72rem}.shop-coins-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.shop-preview-modal{padding:1.1rem;border-radius:16px}.shop-preview-frame-stage{padding:1.5rem .75rem}.shop-preview-frame-avatar{width:72px;height:72px;font-size:2rem}.shop-preview-banner-stage{height:130px}.shop-confirm-modal{padding:1.5rem 1.1rem}.shop-confirm-desc{font-size:.75rem}}@media(max-width:359px){.shop-tab{padding:.35rem .55rem;font-size:.72rem}.shop-hero-title{font-size:1.4rem}.shop-hero-sub{font-size:.75rem}.shop-hero-coins{font-size:.72rem}.shop-grid-frames{grid-template-columns:repeat(2,1fr);gap:.4rem}.shop-coins-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.shop-coin-card{padding:.85rem .6rem .6rem}.shop-coin-card-visual{min-height:75px}.shop-coin-card-amount{font-size:1.1rem}.sp-spotlight-left{padding:.9rem .85rem}.sp-spotlight-title{font-size:1.1rem}.sp-spotlight-price{font-size:1.5rem}.sp-spotlight-price-card{padding:1rem}.sp-spotlight-perks li{font-size:.72rem}.shop-confirm-modal{padding:1.25rem .9rem}.shop-item-info{padding:.4rem .5rem .3rem}.shop-item-name{font-size:.72rem}.shop-buy-btn{margin:0 .5rem .5rem;font-size:.68rem}}.auth-container{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#e74c3c);padding:clamp(1rem,3vw,2rem)}.auth-card{background:var(--bg-primary);border-radius:16px;padding:clamp(2rem,5vw,3.5rem);max-width:600px;width:100%;box-shadow:0 20px 60px #0000004d}.auth-card h2{margin:0 0 .5rem;font-size:clamp(1.75rem,4vw,2.25rem);color:var(--text-primary);text-align:center}.auth-subtitle{color:#4a5568;text-align:center;margin:0 0 2rem;font-size:clamp(.9rem,2vw,1rem)}[data-theme=dark] .auth-subtitle{color:var(--text-secondary)}.auth-error{background:#fef2f2;color:#991b1b;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;font-weight:600;border:1px solid #fca5a5}[data-theme=dark] .auth-error{background:#450a0a;color:#fca5a5;border-color:#7f1d1d}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-primary);font-weight:600;font-size:clamp(.9rem,2vw,.95rem)}.form-group input{padding:.75rem 1rem;border:2px solid #a0aec0;border-radius:8px;font-size:clamp(.9rem,2vw,1rem);transition:all .2s;font-family:inherit}[data-theme=dark] .form-group input{border-color:#4a5568}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.auth-btn{margin-top:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#4338ca,#b91c1c);color:#fff;border:none;border-radius:8px;font-size:clamp(1rem,2.5vw,1.1rem);font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #4338ca66}.auth-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:1.5rem;color:#4a5568;font-size:clamp(.9rem,2vw,.95rem)}[data-theme=dark] .auth-footer{color:var(--text-secondary)}.auth-footer a{color:#3730a3;text-decoration:none;font-weight:600;transition:color .2s}[data-theme=dark] .auth-footer a{color:#818cf8}.auth-footer a:hover{color:#991b1b;text-decoration:underline}[data-theme=dark] .auth-footer a:hover{color:#fca5a5}.auth-divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:#4a5568;font-size:.875rem}[data-theme=dark] .auth-divider{color:var(--text-secondary)}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-primary)}.auth-divider span{padding:0 1rem;font-weight:600}.google-btn{width:100%;padding:.875rem 1.5rem;background:var(--bg-primary);color:var(--text-primary);border:2px solid var(--border-secondary);border-radius:8px;font-size:clamp(1rem,2.5vw,1rem);font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:inherit}.google-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.google-btn:disabled{opacity:.6;cursor:not-allowed}.google-btn svg{flex-shrink:0}.guest-btn{width:100%;padding:.8rem;border:2px solid var(--border-secondary);border-radius:12px;background:transparent;color:#4a5568;font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .2s,color .2s,background .2s;margin-bottom:.4rem}[data-theme=dark] .guest-btn{color:var(--text-secondary)}.guest-btn:hover:not(:disabled){border-color:var(--border-secondary);color:var(--text-primary);background:var(--bg-secondary)}.guest-btn:disabled{opacity:.5;cursor:not-allowed}.guest-note{text-align:center;font-size:.78rem;color:#4a5568;margin:0}[data-theme=dark] .guest-note{color:var(--text-secondary)}@media(max-width:480px){.auth-container{padding:1rem}.auth-card{padding:1.5rem}}
