*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #18181b;--primary-hover: #27272a;--accent: #7FE87D;--accent-hover: #5BC85A;--text-primary: #09090b;--text-secondary: #71717a;--text-tertiary: #a1a1aa;--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f4f4f5;--border-primary: #e4e4e7;--border-secondary: #d4d4d8;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--error: #ef4444;--success: #10b981;--warning: #f59e0b}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);line-height:1.5}.gradient-bg{background:var(--bg-primary);min-height:100vh}.container{max-width:480px;margin:0 auto;padding:20px}.btn{padding:10px 16px;border:1px solid var(--border-primary);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--bg-primary);color:var(--text-primary)}.btn-primary{background:var(--primary);color:var(--bg-primary);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.btn-gradient{background:var(--accent);color:var(--text-primary);border:none;font-weight:600}.btn-gradient:hover{background:var(--accent-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.input-group{margin-bottom:16px}.input-group label{display:block;margin-bottom:6px;font-weight:500;font-size:13px;color:var(--text-primary)}.input-group input,.input-group select,.input-group textarea{width:100%;padding:9px 12px;border:1px solid var(--border-primary);border-radius:6px;font-size:14px;transition:all .15s ease;background:var(--bg-primary);color:var(--text-primary)}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #18181b0d}.input-group textarea{resize:vertical;min-height:80px;font-family:inherit}.input-error{border-color:var(--error)!important}.error-text{color:var(--error);font-size:12px;margin-top:4px}.card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:20px;margin-bottom:16px}.logo{font-size:28px;font-weight:700;color:var(--text-primary);text-align:center;letter-spacing:-.5px;margin-bottom:8px}.spinner{border:2px solid var(--border-primary);border-top:2px solid var(--primary);border-radius:50%;width:20px;height:20px;animation:spin .6s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.text-center{text-align:center}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-16{margin-top:16px}.text-sm{font-size:13px}.text-muted{color:var(--text-secondary)}a{color:var(--text-primary);text-decoration:none;font-weight:500}a:hover{color:var(--text-secondary)}@media(max-width:480px){.container{padding:16px}.logo{font-size:24px}.btn{padding:9px 14px}}.intro-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-secondary)}.intro-content{width:100%;max-width:400px}.logo-section{text-align:center;margin-bottom:40px}.tagline{color:var(--text-secondary);font-size:15px;font-weight:400;margin-top:8px}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:var(--error);padding:12px 16px;border-radius:6px;font-size:13px;text-align:center;margin-bottom:16px}.role-selection-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-secondary)}.role-content{width:100%;max-width:420px}.roles-grid{display:flex;flex-direction:column;gap:10px}.role-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:18px;cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.role-card:hover{border-color:var(--border-secondary);background:var(--bg-secondary)}.role-card.selected{border-color:var(--primary);background:var(--bg-tertiary)}.role-title{font-size:16px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.role-description{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.player-setup-page{background:var(--bg-secondary);min-height:100vh;padding:20px 0}.setup-header{text-align:center;margin-bottom:28px}.logo-small{font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px;margin-bottom:10px}.setup-header h2{font-size:20px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.section-title{font-size:16px;font-weight:600;margin-bottom:14px;color:var(--text-primary)}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:480px){.input-row{grid-template-columns:1fr}}.messages-container{display:grid;grid-template-columns:280px 1fr;gap:14px;height:calc(100vh - 200px);max-height:600px}.conversations-list{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow-y:auto;padding:8px 0}.conversation-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .15s;position:relative}.conversation-item:hover{background:var(--bg-secondary)}.conversation-item.active{background:var(--bg-tertiary);border-left:2px solid var(--primary)}.conversation-avatar{width:42px;height:42px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.conversation-info{flex:1;min-width:0}.conversation-name{font-weight:600;font-size:13px;margin-bottom:2px;color:var(--text-primary)}.conversation-preview{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{width:8px;height:8px;background:var(--accent);border-radius:50%;flex-shrink:0}.messages-panel{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;display:flex;flex-direction:column;overflow:hidden}.messages-header{padding:14px 16px;border-bottom:1px solid var(--border-primary)}.messages-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.messages-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.message{display:flex;width:100%}.message.sent{justify-content:flex-end}.message.received{justify-content:flex-start}.message-bubble{max-width:70%;padding:9px 12px;border-radius:8px;word-wrap:break-word}.message.sent .message-bubble{background:var(--primary);color:var(--bg-primary);border-bottom-right-radius:3px}.message.received .message-bubble{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:3px;border:1px solid var(--border-primary)}.message-text{font-size:13px;line-height:1.4;margin-bottom:3px}.message-time{font-size:11px;opacity:.6;text-align:right}.message-input-form{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--border-primary)}.message-input{flex:1;padding:8px 12px;border:1px solid var(--border-primary);border-radius:6px;font-size:13px;outline:none;background:var(--bg-primary);color:var(--text-primary)}.message-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #18181b0d}.messages-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;min-height:200px;color:var(--text-secondary);font-size:13px}@media(max-width:768px){.messages-container{grid-template-columns:1fr;height:auto;max-height:none}.conversations-list{max-height:300px}.messages-panel{min-height:400px}.message-bubble{max-width:85%}}.form-visualization{margin-top:20px;padding:20px;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;border:2px solid #e2e8f0;box-shadow:0 4px 12px #00000014}.p5-canvas{display:flex;justify-content:center;align-items:center;margin:0 auto 20px;overflow-x:auto}.p5-canvas canvas{border-radius:12px;box-shadow:0 6px 16px #0000001f;max-width:100%;height:auto}.corrections-detail{margin-top:24px;padding:20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;border-left:5px solid #f59e0b;box-shadow:0 2px 8px #f59e0b33}.corrections-detail h4{margin:0 0 16px;color:#92400e;font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}.corrections-detail h4:before{content:"💡";font-size:20px}.corrections-detail ul{margin:0;padding:0;list-style:none}.corrections-detail li{margin:12px 0;padding:12px 12px 12px 40px;position:relative;line-height:1.7;color:#78350f;background:#fff9;border-radius:8px;font-size:15px;font-weight:500}.correction-bullet{position:absolute;left:12px;color:#f59e0b;font-weight:700;font-size:18px}@media(max-width:480px){.form-visualization{padding:12px}.p5-canvas{overflow-x:auto}.p5-canvas canvas{max-width:100%}.corrections-detail{padding:16px}.corrections-detail li{font-size:14px;padding:10px 10px 10px 32px}}.player-dashboard{min-height:100vh;background:var(--bg-secondary)}.dashboard-header{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);padding:14px 0;position:sticky;top:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center}.logo-small{color:var(--text-primary);font-weight:700;font-size:18px;letter-spacing:-.3px}.btn-logout{padding:7px 14px;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-logout:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.nav-tabs{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);margin-bottom:20px}.tabs{display:flex;gap:4px;padding:8px 0;overflow-x:auto}.tab{padding:7px 14px;border:none;background:transparent;color:var(--text-secondary);font-weight:500;font-size:14px;cursor:pointer;border-radius:6px;transition:all .15s ease;white-space:nowrap}.tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.tab.active{background:var(--bg-tertiary);color:var(--text-primary)}.page-title{font-size:20px;font-weight:600;margin-bottom:16px}.badge{display:inline-block;padding:3px 8px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:4px;font-size:12px;color:var(--text-secondary);font-weight:500}.leaderboard-list{display:flex;flex-direction:column;gap:1px;background:var(--border-primary);border-radius:8px;overflow:hidden}.leaderboard-item{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--bg-primary)}.rank{font-size:14px;font-weight:600;color:var(--text-secondary);min-width:40px}.player-info{flex:1;display:flex;flex-direction:column;gap:4px}.rating{font-size:16px;font-weight:600;color:var(--text-primary)}.profile-card{margin-top:0}.profile-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.profile-avatar{width:56px;height:56px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-primary);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:600;color:var(--text-primary)}.profile-info h2{margin:0;font-size:20px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding-top:16px;border-top:1px solid var(--border-primary)}.stat{text-align:center}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:13px;color:var(--text-secondary);margin-top:2px}.upload-card{margin-bottom:20px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-header h3{margin:0;font-size:16px;font-weight:600}.btn-close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--text-tertiary);padding:0;width:24px;height:24px}.btn-close:hover{color:var(--text-secondary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.section-header h3{margin:0;font-size:16px;font-weight:600}.empty-state{padding:40px 20px;text-align:center}.videos-grid{display:grid;gap:14px}.video-card{padding:0;overflow:hidden;transition:border-color .15s ease}.video-card:hover{border-color:var(--border-secondary)}.video-player{width:100%;height:auto;max-height:400px;background:#000;border-radius:7px 7px 0 0;object-fit:cover}.video-info{padding:14px;background:var(--bg-primary)}.video-info h4{margin:0 0 6px;font-size:15px;font-weight:600;color:var(--text-primary)}.ai-score{display:inline-block;background:var(--bg-tertiary);color:var(--text-primary);padding:6px 10px;border-radius:6px;font-size:13px;font-weight:600;margin-top:8px;border:1px solid var(--border-primary)}.ai-feedback{margin-top:12px;padding:12px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-primary)}.ai-feedback summary{cursor:pointer;font-weight:500;color:var(--text-primary);font-size:13px;padding:4px 0;-webkit-user-select:none;user-select:none}.ai-feedback summary:hover{color:var(--text-secondary)}.ai-feedback p{margin:10px 0 0;line-height:1.6;color:var(--text-secondary);font-size:13px}.ai-feedback[open] summary{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border-primary)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.mt-8{margin-top:8px}@media(max-width:480px){.stats-grid{gap:10px}.stat-value{font-size:20px}.profile-info h2{font-size:18px}.profile-avatar{width:48px;height:48px;font-size:18px}.tabs{gap:3px;padding:6px 0}.tab{padding:6px 12px;font-size:13px}.page-title{font-size:18px;margin-bottom:14px}.video-info h4{font-size:14px}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;position:relative}.player-profile-modal{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{margin:0;font-size:24px;font-weight:700;color:var(--text-dark)}.modal-close{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.modal-close:hover{background:#f0f0f0}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:12px;position:sticky;bottom:0;background:#fff}.player-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:24px}.stat-card{background:var(--bg-secondary);padding:12px;border-radius:8px;text-align:center}.stat-card .stat-label{font-size:12px;color:#666;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-card .stat-value{font-size:18px;font-weight:700;color:var(--text-dark)}.profile-section{margin-bottom:24px}.profile-section h3{font-size:18px;font-weight:700;margin-bottom:12px;color:var(--text-dark)}.profile-section p{font-size:14px;color:#666;line-height:1.6}.videos-grid{display:grid;gap:16px}.video-card{background:var(--bg-secondary);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s;border:2px solid transparent}.video-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.video-thumbnail{position:relative;background:linear-gradient(135deg,#667eea,#764ba2);height:160px;display:flex;align-items:center;justify-content:center}.video-play-icon{font-size:48px;color:#fff;opacity:.9}.video-duration{position:absolute;bottom:8px;right:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.video-info{padding:12px}.video-info h4{font-size:14px;font-weight:600;margin-bottom:4px;color:var(--text-dark)}.video-info .text-muted{font-size:12px;color:#999;margin-bottom:8px}.ai-score-badge{display:inline-block;background:var(--primary);color:var(--text-dark);padding:4px 10px;border-radius:12px;font-size:12px;font-weight:700}.video-analysis{padding:16px;background:#fff;border-top:1px solid #e0e0e0;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.video-analysis h4{font-size:16px;font-weight:700;margin-bottom:12px;color:var(--text-dark)}.analysis-content{font-size:14px;color:#666}.analysis-score{display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);padding:12px;border-radius:8px;margin-bottom:12px}.score-label{font-weight:600;color:#666}.score-value{font-size:24px;font-weight:700;color:var(--primary)}.feedback-text{background:#f9f9f9;padding:12px;border-radius:8px;margin-bottom:12px;line-height:1.6;font-size:13px}.insight-section{margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.insight-section h5{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text-dark)}.insight-section ul{list-style:none;padding:0;margin:0}.insight-section li{padding:6px 0 6px 20px;position:relative;font-size:13px;color:#666}.insight-section li:before{content:"•";position:absolute;left:8px;color:var(--primary);font-weight:700}@media(max-width:480px){.modal-content{max-height:100vh;border-radius:0}.modal-header h2{font-size:20px}.player-stats-grid{grid-template-columns:repeat(2,1fr)}.video-thumbnail{height:120px}.video-play-icon{font-size:36px}}.btn-secondary{background:#e0e0e0;color:var(--text-dark);border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#d0d0d0}.message-box{width:100%;display:flex;flex-direction:column;gap:12px}.message-input{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:80px}.message-input:focus{outline:none;border-color:var(--primary)}.message-actions{display:flex;gap:12px;justify-content:flex-end}.swipe-container{display:flex;flex-direction:column;align-items:center;padding:20px 0}.player-card{background:var(--bg-white);border-radius:16px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:400px;overflow:hidden}.player-card-header{background:linear-gradient(135deg,var(--gradient-start),var(--gradient-mid),var(--gradient-end));padding:24px;display:flex;gap:16px;align-items:center}.player-avatar-large{width:80px;height:80px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:var(--text-dark);flex-shrink:0}.player-card-info{flex:1}.player-card-info h2{margin:0 0 4px;font-size:22px;color:var(--text-dark)}.player-card-body{padding:20px}.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.stat-item{text-align:center;padding:12px;background:var(--bg-light);border-radius:8px}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-value{font-size:18px;font-weight:700;color:var(--primary-dark)}.swipe-actions{display:flex;justify-content:center;gap:20px;padding:20px;border-top:1px solid var(--border)}.swipe-btn{width:64px;height:64px;border-radius:50%;border:none;font-size:28px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.swipe-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.swipe-btn:active{transform:scale(.95)}.swipe-btn-pass{background:#ff4458;color:#fff}.swipe-btn-like{background:var(--primary);color:var(--text-dark)}.swipe-btn-pass:hover{background:#e6323f}.swipe-btn-like:hover{background:var(--primary-dark)}@media(max-width:480px){.player-card{max-width:100%}.player-avatar-large{width:64px;height:64px;font-size:28px}.player-card-info h2{font-size:18px}.stat-row{gap:8px}.stat-item{padding:8px}.stat-value{font-size:16px}.swipe-btn{width:56px;height:56px;font-size:24px}}.admin-dashboard{display:flex;min-height:100vh;background:var(--bg-secondary)}.admin-sidebar{width:240px;background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.admin-logo{padding:20px 16px;border-bottom:1px solid var(--border-primary)}.admin-logo h2{margin:0 0 2px;font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.admin-logo p{margin:0;font-size:12px;color:var(--text-secondary)}.role-switcher{padding:16px;border-bottom:1px solid var(--border-primary)}.role-switcher h3{margin:0 0 10px;font-size:11px;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-switch-btn{width:100%;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-primary);transition:all .15s ease;margin-bottom:6px;text-align:left}.role-switch-btn:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.admin-nav{flex:1;padding:8px 0}.admin-nav-item{width:100%;padding:8px 16px;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;font-size:13px;font-weight:500;transition:all .15s ease;border-left:2px solid transparent;text-align:left}.admin-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.admin-nav-item.active{background:var(--bg-tertiary);color:var(--text-primary);border-left-color:var(--primary)}.admin-stats-mini{padding:16px;border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-around}.stat-mini{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:10px;color:var(--text-secondary);margin-top:2px}.admin-logout{padding:8px 16px;margin:12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.admin-logout:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.admin-content{flex:1;margin-left:240px;padding:24px;overflow-y:auto}.section-container{max-width:1200px;margin:0 auto}.section-header{margin-bottom:24px}.section-header h1{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 6px}.section-header p{font-size:14px;color:var(--text-secondary);margin:0}.info-card{background:var(--bg-primary);border:1px solid var(--border-primary);padding:20px;border-radius:8px;margin-bottom:20px}.info-card h3{margin:0 0 10px;color:var(--text-primary);font-size:16px;font-weight:600}.info-card p{color:var(--text-secondary);margin:0 0 12px;line-height:1.6;font-size:14px}.info-card ul{margin:0;padding-left:18px;color:var(--text-secondary);line-height:1.7;font-size:14px}.videos-table,.rankings-table{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;margin-bottom:20px;overflow:hidden}.videos-table table,.rankings-table table{width:100%;border-collapse:collapse}.videos-table th,.rankings-table th{background:var(--bg-secondary);padding:10px 14px;text-align:left;font-weight:600;font-size:12px;color:var(--text-primary);border-bottom:1px solid var(--border-primary)}.videos-table td,.rankings-table td{padding:10px 14px;border-bottom:1px solid var(--border-primary);font-size:13px;color:var(--text-secondary)}.videos-table tr:last-child td,.rankings-table tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:capitalize}.status-badge.analyzed{background:#f0fdf4;color:#15803d;border:1px solid #86efac}.status-badge.processing{background:#fef9e7;color:#92400e;border:1px solid #fde047}.score-value{font-weight:600;color:var(--text-primary)}.btn{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-primary{background:var(--primary);color:var(--bg-primary);border:none}.btn-primary:hover{background:var(--primary-hover)}.btn-small{padding:5px 12px;font-size:12px}.teams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:20px}.team-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:16px}.team-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-primary)}.team-header h3{margin:0;font-size:15px;color:var(--text-primary);font-weight:600}.team-sport{background:var(--bg-tertiary);padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;color:var(--text-secondary)}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:20px}.tool-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:18px}.tool-card h3{margin:0 0 8px;color:var(--text-primary);font-size:15px;font-weight:600}.tool-card p{color:var(--text-secondary);margin:0 0 10px;font-size:13px;line-height:1.6}.simulation-controls{margin-bottom:24px}.simulation-results{background:var(--bg-primary);border:1px solid var(--border-primary);padding:20px;border-radius:8px}.sim-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.sim-stat{text-align:center;padding:16px;background:var(--bg-secondary);border-radius:6px}.sim-value{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.sim-label{color:var(--text-secondary);font-size:13px}.models-running h3{margin:0 0 16px;color:var(--text-primary);font-size:15px;font-weight:600}.model-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.model-name{width:140px;font-weight:500;color:var(--text-primary);font-size:13px}.progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.model-progress{width:45px;text-align:right;font-weight:500;color:var(--text-secondary);font-size:12px}.region-selector{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.region-btn{padding:7px 14px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-primary);transition:all .15s ease}.region-btn:hover{border-color:var(--border-secondary);background:var(--bg-secondary)}.region-btn.active{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-secondary)}@media(max-width:1024px){.admin-sidebar{width:200px}.admin-content{margin-left:200px}}.tool-desc{color:var(--text-secondary);font-size:13px;margin:0 0 12px;line-height:1.5}.tool-detail-panel{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:24px;margin-top:24px}.tool-detail-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.tool-detail-header h2{margin:0 0 4px;font-size:20px;font-weight:700;color:var(--text-primary)}.tool-detail-header p{margin:0;font-size:13px;color:var(--text-secondary)}.games-badge{background:var(--bg-tertiary);padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;color:var(--text-primary)}.progress-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.progress-stat{background:var(--bg-secondary);padding:16px;border-radius:6px;text-align:center}.progress-stat .stat-number{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.progress-stat .stat-label{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.stat-trend{font-size:11px;font-weight:600;margin-top:4px}.stat-trend.positive{color:#15803d}.stat-trend.negative{color:#dc2626}.progress-chart-container{margin-bottom:24px}.progress-chart-container h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--text-primary)}.progress-table{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.progress-table table{width:100%;border-collapse:collapse}.progress-table th{background:var(--bg-secondary);padding:10px 14px;text-align:left;font-weight:600;font-size:12px;color:var(--text-primary);border-bottom:1px solid var(--border-primary)}.progress-table td{padding:10px 14px;border-bottom:1px solid var(--border-primary);font-size:13px;color:var(--text-secondary)}.progress-table tr:last-child td{border-bottom:none}.score-badge{display:inline-block;padding:4px 10px;background:var(--bg-tertiary);border-radius:4px;font-weight:600;color:var(--text-primary);font-size:12px}.insights-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.insight-card{padding:16px;border-radius:6px;border:1px solid var(--border-primary)}.insight-card.strength{background:#f0fdf4;border-color:#86efac}.insight-card.improvement{background:#fef3c7;border-color:#fde047}.insight-card h4{margin:0 0 10px;font-size:14px;font-weight:600;color:var(--text-primary)}.insight-card ul{margin:0;padding-left:20px;font-size:13px;color:var(--text-secondary);line-height:1.8}.workouts-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.workout-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:20px}.workout-card.completed{opacity:.7;background:var(--bg-secondary)}.workout-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.workout-header h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.workout-player{margin:0;font-size:12px;color:var(--text-secondary)}.workout-meta{display:flex;gap:8px;align-items:center}.status-tag{padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.status-tag.active{background:#dbeafe;color:#1e40af}.status-tag.completed{background:#d1fae5;color:#065f46}.points-tag{padding:4px 10px;background:var(--primary);color:#fff;border-radius:4px;font-size:11px;font-weight:600}.workout-desc{margin:0 0 12px;font-size:14px;color:var(--text-secondary);line-height:1.5}.workout-details{display:flex;gap:24px;margin-bottom:16px;padding:12px;background:var(--bg-secondary);border-radius:6px}.detail-item{display:flex;gap:6px;font-size:13px}.detail-label{color:var(--text-tertiary);font-weight:500}.detail-value{color:var(--text-primary);font-weight:600}.deadline-value{display:flex;align-items:center;gap:4px}.deadline-icon{font-size:14px}.workout-exercises{margin-bottom:16px}.workout-exercises h4{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--text-primary)}.workout-exercises ul{margin:0;padding-left:20px;font-size:13px;color:var(--text-secondary);line-height:1.8}.workout-actions{display:flex;gap:10px}.btn-proof{padding:8px 16px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-proof:hover{background:var(--primary-hover)}.btn-secondary-small{padding:8px 16px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-secondary-small:hover{border-color:var(--border-secondary);background:var(--bg-tertiary)}.contests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:24px}.contest-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:18px}.contest-card.completed{opacity:.7;background:var(--bg-secondary)}.contest-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-primary)}.contest-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.contest-type{padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.contest-type.individual{background:#e0e7ff;color:#3730a3}.contest-type.team{background:#dcfce7;color:#166534}.contest-desc{margin:0 0 16px;font-size:13px;color:var(--text-secondary);line-height:1.5}.contest-meta{margin-bottom:12px}.meta-item{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border-primary);font-size:13px}.meta-item:last-child{border-bottom:none}.meta-label{color:var(--text-tertiary);font-weight:500}.meta-value{color:var(--text-primary);font-weight:600}.meta-value.prize{color:var(--primary)}.contest-status{margin-bottom:12px}.status-indicator{display:inline-block;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.status-indicator.active{background:#dbeafe;color:#1e40af}.status-indicator.completed{background:#d1fae5;color:#065f46}.btn-secondary{padding:8px 16px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-secondary:hover{border-color:var(--border-secondary);background:var(--bg-tertiary)}.team-record{background:var(--primary);color:#fff;padding:8px 16px;border-radius:6px;font-size:16px;font-weight:700}.analytics-overview{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.analytics-stat{background:var(--bg-secondary);padding:16px;border-radius:6px;text-align:center}.analytics-stat .stat-number{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.analytics-stat .stat-label{font-size:12px;color:var(--text-secondary)}.top-performers{margin-bottom:24px}.top-performers h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--text-primary)}.performers-table{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.performers-table table{width:100%;border-collapse:collapse}.performers-table th{background:var(--bg-secondary);padding:10px 14px;text-align:left;font-weight:600;font-size:12px;color:var(--text-primary);border-bottom:1px solid var(--border-primary)}.performers-table td{padding:10px 14px;border-bottom:1px solid var(--border-primary);font-size:13px;color:var(--text-secondary)}.performers-table tr:last-child td{border-bottom:none}.trend-indicator{font-size:18px;font-weight:600}.trend-indicator.up{color:#15803d}.trend-indicator.down{color:#dc2626}.trend-indicator.stable{color:#6b7280}.formations-analysis{margin-bottom:24px}.formations-analysis h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--text-primary)}.formations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.formation-card{background:var(--bg-secondary);padding:16px;border-radius:6px}.formation-card h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-primary)}.formation-stats{display:flex;justify-content:space-around}.formation-stat{text-align:center}.formation-stat .stat-label{font-size:11px;color:var(--text-tertiary);margin-bottom:4px;display:block}.formation-stat .stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.action-section{margin-top:20px;display:flex;gap:12px}@media(max-width:1024px){.admin-sidebar{width:200px}.admin-content{margin-left:200px}.progress-stats-grid,.analytics-overview{grid-template-columns:repeat(2,1fr)}.formations-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-dashboard{flex-direction:column}.admin-sidebar{width:100%;position:static;height:auto}.admin-content{margin-left:0;padding:16px}.teams-grid,.tools-grid,.progress-stats-grid,.analytics-overview,.insights-grid,.formations-grid,.contests-grid{grid-template-columns:1fr}}.contests-page{min-height:100vh;background:var(--bg-secondary);padding:20px 16px}.contests-header{text-align:center;margin-bottom:28px}.contests-header h1{font-size:24px;font-weight:700;margin-bottom:6px;color:var(--text-primary);letter-spacing:-.3px}.contests-header .subtitle{font-size:14px;color:var(--text-secondary);margin:0}.contests-filters{max-width:1200px;margin:0 auto 24px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:16px;display:flex;gap:20px;flex-wrap:wrap;align-items:center}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-weight:500;color:var(--text-primary);font-size:13px}.filter-buttons{display:flex;gap:6px}.filter-btn{padding:6px 12px;border:1px solid var(--border-primary);background:var(--bg-primary);border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .15s}.filter-btn:hover{border-color:var(--border-secondary);background:var(--bg-secondary);color:var(--text-primary)}.filter-btn.active{background:var(--primary);color:var(--bg-primary);border-color:var(--primary)}.sport-select{padding:6px 12px;border:1px solid var(--border-primary);border-radius:6px;font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer;background:var(--bg-primary);min-width:140px}.sport-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #18181b0d}.contests-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.contest-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:18px;cursor:pointer;transition:all .15s ease}.contest-card:hover{border-color:var(--border-secondary);background:var(--bg-secondary)}.contest-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.contest-sport{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.contest-badge{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.badge-active{background:#f0fdf4;color:#15803d;border:1px solid #86efac}.badge-upcoming{background:#fef9e7;color:#92400e;border:1px solid #fde047}.badge-completed{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary)}.contest-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:10px;line-height:1.3}.contest-description{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:14px}.contest-metric{display:flex;align-items:center;gap:8px;padding:10px;background:var(--bg-tertiary);border-radius:6px;margin-bottom:10px;border:1px solid var(--border-primary)}.metric-icon{font-size:16px}.metric-name{font-size:13px;font-weight:500;color:var(--text-primary)}.contest-prize{display:flex;align-items:center;gap:8px;padding:10px;background:#fef9e7;border:1px solid #fde047;border-radius:6px;margin-bottom:14px}.prize-icon{font-size:16px}.prize-text{font-size:12px;font-weight:600;color:#92400e}.contest-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--border-primary);margin-bottom:6px}.contest-participants,.contest-time{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-secondary);font-weight:500}.participants-icon,.time-icon{font-size:14px}.contest-dates{text-align:center;margin-top:6px}.contest-dates small{font-size:11px;color:var(--text-tertiary);font-weight:400}.empty-state{grid-column:1 / -1;text-align:center;padding:50px 20px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px}.empty-state h3{font-size:18px;color:var(--text-primary);margin-bottom:6px;font-weight:600}.empty-state p{font-size:14px;color:var(--text-secondary)}@media(max-width:768px){.contests-header h1{font-size:22px}.contests-filters{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column;align-items:stretch;gap:6px}.filter-buttons{justify-content:stretch}.filter-btn{flex:1}.contests-grid{grid-template-columns:1fr}}.contest-detail-page{min-height:100vh;background:#f9fafb;padding-bottom:40px}.back-btn{position:fixed;top:20px;left:20px;padding:10px 20px;background:#fff;border:none;border-radius:8px;font-weight:600;color:#667eea;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:all .2s;z-index:100}.back-btn:hover{transform:translate(-4px);box-shadow:0 4px 12px #00000026}.contest-hero{background:linear-gradient(135deg,#667eea,#764ba2);padding:80px 20px 60px;color:#fff}.contest-hero-content{max-width:1200px;margin:0 auto}.contest-hero-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.contest-sport-tag{padding:6px 16px;background:#fff3;border-radius:20px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.contest-status-badge{padding:6px 16px;border-radius:20px;font-size:13px;font-weight:700;text-transform:uppercase}.contest-hero-title{font-size:42px;font-weight:800;margin-bottom:16px;line-height:1.2}.contest-hero-description{font-size:18px;opacity:.95;max-width:800px;line-height:1.6;margin-bottom:32px}.contest-hero-stats{display:flex;gap:32px;margin-bottom:24px;flex-wrap:wrap}.hero-stat{display:flex;align-items:center;gap:12px}.hero-stat-icon{font-size:32px}.hero-stat-label{font-size:12px;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.hero-stat-value{font-size:20px;font-weight:700}.contest-prize-banner{display:inline-flex;align-items:center;gap:12px;padding:16px 24px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:2px solid rgba(255,255,255,.3)}.prize-banner-icon{font-size:28px}.prize-banner-text{font-size:16px;font-weight:700}.contest-content{max-width:1200px;margin:-30px auto 0;padding:0 20px;display:grid;grid-template-columns:1fr 350px;gap:24px;align-items:start}.contest-main{display:flex;flex-direction:column;gap:24px}.contest-section{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 12px #00000014}.section-title{font-size:22px;font-weight:700;color:#1f2937;margin-bottom:20px}.rules-content{font-size:15px;line-height:1.8;color:#4b5563}.submission-section{border:3px solid #667eea}.upload-zone{position:relative}.video-input{display:none}.upload-label{display:flex;align-items:center;gap:20px;padding:40px;border:3px dashed #d1d5db;border-radius:12px;cursor:pointer;transition:all .3s;background:#f9fafb}.upload-label:hover{border-color:#667eea;background:#f3f4f6}.upload-icon{font-size:48px}.upload-title{font-size:18px;font-weight:700;color:#1f2937;margin-bottom:4px}.upload-subtitle{font-size:14px;color:#6b7280}.video-preview-section{display:flex;flex-direction:column;gap:16px}.video-preview{width:100%;max-height:400px;border-radius:12px;background:#000}.submission-actions{display:flex;gap:12px}.submission-actions .btn{flex:1;padding:14px;font-size:16px;font-weight:700}.upload-progress{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.upload-progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s}.my-submission-section{border:3px solid #10b981}.my-submission-card{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:start}.submission-score{text-align:center;padding:24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:12px}.score-label{font-size:12px;text-transform:uppercase;opacity:.9;margin-bottom:8px}.score-value{font-size:48px;font-weight:800;margin-bottom:4px}.score-metric{font-size:13px;opacity:.9}.submission-info{display:flex;flex-direction:column;gap:12px}.submission-status,.submission-date{font-size:14px;color:#6b7280}.status-badge{padding:4px 12px;border-radius:8px;font-size:12px;font-weight:700;text-transform:uppercase}.status-verified{background:#d1fae5;color:#065f46}.submission-analysis{padding:16px;background:#f9fafb;border-radius:8px;font-size:14px;line-height:1.6}.submission-analysis strong{display:block;margin-bottom:8px;color:#1f2937}.submission-analysis p{color:#4b5563;margin:0}.leaderboard-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 12px #00000014;position:sticky;top:20px}.leaderboard-empty{text-align:center;padding:40px 20px;color:#9ca3af}.leaderboard-list{display:flex;flex-direction:column;gap:12px}.leaderboard-entry{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border-radius:8px;transition:all .2s}.leaderboard-entry:hover{background:#f3f4f6;transform:translate(4px)}.leaderboard-entry.top-three{background:linear-gradient(135deg,#fef3c7,#fde68a);font-weight:600}.entry-rank{font-size:20px;font-weight:800;min-width:40px;text-align:center}.entry-info{flex:1}.entry-name{font-size:14px;font-weight:700;color:#1f2937;margin-bottom:2px}.entry-details{font-size:12px;color:#6b7280}.entry-score{text-align:right}.entry-score-value{font-size:18px;font-weight:800;color:#667eea}.entry-score-label{font-size:11px;color:#6b7280;text-transform:uppercase}.error-state{max-width:600px;margin:100px auto;text-align:center;padding:40px;background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a}.error-state h2{margin-bottom:20px;color:#1f2937}@media(max-width:968px){.contest-content{grid-template-columns:1fr}.leaderboard-section{position:static}.my-submission-card{grid-template-columns:1fr}}@media(max-width:768px){.contest-hero-title{font-size:28px}.contest-hero-description{font-size:16px}.contest-hero-stats{gap:16px}.hero-stat-value{font-size:16px}.submission-actions{flex-direction:column}.back-btn{position:static;margin:20px}}.leaderboards-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:24px 16px 60px}.leaderboards-header{text-align:center;color:#fff;margin-bottom:32px}.leaderboards-header h1{font-size:42px;font-weight:800;margin-bottom:8px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.leaderboards-header .subtitle{font-size:18px;opacity:.9;margin:0}.leaderboards-controls{max-width:1200px;margin:0 auto 32px;background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 12px #0000001a;display:flex;gap:24px;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:12px}.control-group label{font-weight:700;color:#1f2937;font-size:14px}.control-select{padding:10px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:600;color:#1f2937;background:#fff;cursor:pointer;min-width:180px}.control-select:focus{outline:none;border-color:#667eea}.leaderboards-content{max-width:1200px;margin:0 auto}.podium{display:flex;align-items:flex-end;justify-content:center;gap:16px;margin-bottom:48px;padding:40px 20px}.podium-position{display:flex;flex-direction:column;align-items:center}.podium-player{display:flex;flex-direction:column;align-items:center;margin-bottom:16px;background:#fff;padding:24px 20px;border-radius:16px;box-shadow:0 8px 24px #00000026;min-width:200px}.first-place .podium-player{padding:32px 24px;transform:scale(1.1)}.podium-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;margin-bottom:12px;border:4px solid white;box-shadow:0 4px 12px #0003}.podium-avatar.champion{width:100px;height:100px;font-size:40px;border:6px solid #fbbf24;box-shadow:0 0 24px #fbbf2480}.podium-rank{font-size:36px;margin-bottom:8px}.first-place .podium-rank{font-size:48px}.podium-name{font-size:16px;font-weight:700;color:#1f2937;text-align:center;margin-bottom:8px}.first-place .podium-name{font-size:18px}.podium-score{font-size:24px;font-weight:800;color:#667eea}.first-place .podium-score{font-size:32px}.podium-stand{width:180px;background:linear-gradient(135deg,#d1d5db,#9ca3af);color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:800;border-radius:12px 12px 0 0;box-shadow:0 4px 12px #0000001a}.podium-stand.first{height:160px;background:linear-gradient(135deg,#fbbf24,#f59e0b);width:200px}.podium-stand.second{height:120px;background:linear-gradient(135deg,#d1d5db,#9ca3af)}.podium-stand.third{height:90px;background:linear-gradient(135deg,#cd7f32,#b87333)}.rankings-table{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.table-header{display:grid;grid-template-columns:80px 1fr 120px 120px 100px 100px 120px;gap:16px;padding:20px 24px;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-bottom:2px solid #e5e7eb}.header-cell{font-size:13px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.table-body{max-height:600px;overflow-y:auto}.table-row{display:grid;grid-template-columns:80px 1fr 120px 120px 100px 100px 120px;gap:16px;padding:16px 24px;border-bottom:1px solid #f3f4f6;transition:all .2s}.table-row:hover{background:#f9fafb}.table-row.top-three{background:linear-gradient(90deg,#fef3c7 0%,transparent 100%)}.table-row.top-three:hover{background:linear-gradient(90deg,#fde68a 0%,transparent 100%)}.table-cell{display:flex;align-items:center;font-size:14px}.rank-col{justify-content:center}.rank-badge{font-size:20px;font-weight:800}.player-col{justify-content:flex-start}.player-info{display:flex;align-items:center;gap:12px}.player-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.player-name{font-size:15px;font-weight:700;color:#1f2937;margin-bottom:2px}.player-details{font-size:12px;color:#6b7280}.stat-col{justify-content:center}.stat-value{font-size:16px;font-weight:700;color:#1f2937}.stat-value.gold{color:#f59e0b}.empty-state{background:#fff;border-radius:16px;padding:80px 40px;text-align:center;box-shadow:0 4px 12px #0000001a}.empty-state h3{font-size:28px;color:#1f2937;margin-bottom:12px}.empty-state p{font-size:16px;color:#6b7280}@media(max-width:968px){.table-header,.table-row{grid-template-columns:60px 1fr 80px 80px;gap:12px}.header-cell:nth-child(n+5),.table-cell:nth-child(n+5){display:none}.podium{flex-wrap:wrap;gap:24px}.podium-position{order:0}.first-place{order:-1;width:100%}}@media(max-width:640px){.leaderboards-header h1{font-size:28px}.leaderboards-controls{flex-direction:column}.control-group{width:100%;justify-content:space-between}.control-select{flex:1}.podium-player{min-width:140px;padding:16px 12px}.podium-avatar{width:60px;height:60px;font-size:24px}.podium-avatar.champion{width:80px;height:80px;font-size:32px}.podium-stand{width:140px;font-size:36px}.podium-stand.first{height:120px;width:160px}.podium-stand.second{height:90px}.podium-stand.third{height:70px}}
