.app{width:100%}.page-header{padding:16px 0;text-align:center}.page-header h1{font-size:1.4rem;font-weight:600}.page-header p{color:var(--tg-hint);font-size:.85rem;margin-top:4px}.card{background:var(--tg-secondary-bg);border-radius:12px;padding:16px;margin-bottom:12px}.btn{display:block;width:100%;padding:12px;border:none;border-radius:10px;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .2s}.btn:active{opacity:.7}.btn-primary{background:var(--tg-btn);color:var(--tg-btn-text)}.btn-secondary{background:var(--tg-secondary-bg);color:var(--tg-text)}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--tg-hint)}.error-msg{text-align:center;color:#e74c3c;padding:20px}.nav-tabs{display:flex;justify-content:center;gap:4px;padding:8px 0;margin-bottom:12px;overflow-x:auto}.nav-tab{padding:8px 14px;border:none;border-radius:20px;font-size:.85rem;background:var(--tg-secondary-bg);color:var(--tg-text);cursor:pointer;white-space:nowrap}.nav-tab.active{background:var(--tg-btn);color:var(--tg-btn-text)}.admin-tabs{flex-wrap:nowrap}.filter-row{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.chip{padding:6px 12px;border-radius:999px;border:1px solid var(--tg-hint);background:transparent;color:var(--tg-text);font-size:.82rem;cursor:pointer;white-space:nowrap}.chip.on{background:var(--tg-btn);color:var(--tg-btn-text);border-color:var(--tg-btn)}.field-label{display:block;font-size:.8rem;color:var(--tg-hint);margin:12px 0 4px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.form-ok{color:#22c55e}.skill-progress{font-size:1rem}.skill-progress strong{font-size:1.4rem;color:#22c55e}.skill-bar{height:8px;border-radius:4px;background:var(--tg-secondary-bg);margin-top:8px;overflow:hidden}.skill-bar-fill{height:100%;background:#22c55e;transition:width .3s ease}.skill-grid{display:flex;flex-wrap:wrap;gap:6px}.skill-chip{padding:6px 10px;border-radius:8px;font-size:.82rem;background:var(--tg-secondary-bg);color:var(--tg-hint);border:1px solid transparent}.skill-chip.done{background:color-mix(in srgb,#22c55e 18%,transparent);color:var(--tg-text);border-color:#22c55e;font-weight:600}:root{--tg-bg: var(--tg-theme-bg-color, #ffffff);--tg-text: var(--tg-theme-text-color, #000000);--tg-hint: var(--tg-theme-hint-color, #999999);--tg-link: var(--tg-theme-link-color, #2481cc);--tg-btn: var(--tg-theme-button-color, #2481cc);--tg-btn-text: var(--tg-theme-button-text-color, #ffffff);--tg-secondary-bg: var(--tg-theme-secondary-bg-color, #f0f0f0);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;color:var(--tg-text);background-color:var(--tg-bg)}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh;-webkit-font-smoothing:antialiased}#root{max-width:480px;margin:0 auto;padding:0 16px 24px}@media(min-width:768px){#root{max-width:900px}}.progress-bar{height:4px;background:var(--tg-secondary-bg);border-radius:2px;margin:8px 0;overflow:hidden}.progress-fill{height:100%;background:var(--tg-btn);border-radius:2px;transition:width .3s ease}.step-counter{text-align:center;font-size:.8rem;color:var(--tg-hint);margin-bottom:8px}.step-card{padding:16px 0}.step-card h2{font-size:1.3rem;margin-bottom:4px}.step-subtitle{color:var(--tg-hint);font-size:.85rem;margin-bottom:12px}.step-content{margin-top:12px}.option-grid{display:grid;gap:8px}.option-grid.cols-1{grid-template-columns:1fr}.option-grid.cols-2{grid-template-columns:1fr 1fr}.option-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.option-grid.cols-4{grid-template-columns:repeat(4,1fr)}.option-grid.cols-5{grid-template-columns:repeat(5,1fr)}.option-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;border:2px solid transparent;border-radius:12px;background:var(--tg-secondary-bg);color:var(--tg-text);cursor:pointer;font-size:.9rem;gap:4px;transition:border-color .15s,background .15s}.option-btn:active{opacity:.8}.option-btn.selected{border-color:var(--tg-btn);background:color-mix(in srgb,var(--tg-btn) 10%,var(--tg-secondary-bg))}.option-btn.wide{flex-direction:row;justify-content:flex-start;gap:10px;padding:14px 16px}.option-btn.small{padding:10px 6px;font-size:.82rem}.option-icon{font-size:1.4rem}.option-label-sm{font-size:.75rem}.option-hint{font-size:.78rem;color:var(--tg-hint)}.text-input{width:100%;padding:14px 16px;border:2px solid var(--tg-secondary-bg);border-radius:12px;font-size:1rem;background:var(--tg-bg);color:var(--tg-text);outline:none}.text-input:focus{border-color:var(--tg-btn)}.onboarding-nav{display:flex;gap:8px;margin-top:16px}.onboarding-nav .btn{flex:1}.profile-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid color-mix(in srgb,var(--tg-hint) 15%,transparent)}.profile-row:last-child{border-bottom:none}.profile-label{color:var(--tg-hint);font-size:.9rem}.profile-value{font-weight:500;text-transform:capitalize}.card-title{font-size:.95rem;font-weight:600;margin-bottom:8px}.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.tag{padding:4px 10px;border-radius:16px;font-size:.8rem;background:color-mix(in srgb,var(--tg-btn) 15%,var(--tg-secondary-bg));text-transform:capitalize}.stats-row{display:flex;gap:16px}.stat{display:flex;flex-direction:column;align-items:center;flex:1}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.78rem;color:var(--tg-hint)}.heatmap-container{overflow-x:auto;margin:0 -16px;padding:0 16px}.heatmap-grid{display:grid;gap:3px;min-width:280px}.heatmap-corner{width:40px}.heatmap-header{text-align:center;font-size:.72rem;font-weight:600;color:var(--tg-hint);padding:4px 2px;text-transform:capitalize}.heatmap-day{display:flex;align-items:center;font-size:.78rem;font-weight:500;padding-right:6px}.heatmap-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:.85rem;font-weight:700;color:#1a1a1a;cursor:pointer;transition:outline .15s;min-height:36px}.heatmap-cell.selected{outline:2px solid var(--tg-btn);outline-offset:1px}.heatmap-legend{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:12px;font-size:.75rem;color:var(--tg-hint)}.legend-swatch{width:16px;height:16px;border-radius:4px}.slot-detail{background:var(--tg-secondary-bg);border-radius:12px;padding:16px;margin-top:16px}.slot-detail-title{font-size:1.05rem;font-weight:700;margin:0 0 4px}.slot-detail-count{font-size:.85rem;color:var(--tg-hint);margin:0 0 12px}.slot-detail-loading{text-align:center;color:var(--tg-hint);padding:12px 0;font-size:.85rem}.slot-detail-empty{text-align:center;color:var(--tg-hint);padding:8px 0;font-size:.85rem}.slot-player-list{display:flex;flex-direction:column;gap:8px}.slot-player-row{display:flex;justify-content:space-between;align-items:center;background:var(--tg-bg);border-radius:8px;padding:10px 12px}.slot-player-info{display:flex;flex-direction:column;gap:2px}.slot-player-name{font-weight:600;font-size:.9rem}.slot-player-skill{font-size:.78rem;color:var(--tg-hint)}.slot-player-tags{display:flex;gap:4px}.slot-tag{font-size:.7rem;padding:2px 8px;border-radius:10px;background:var(--tg-secondary-bg);color:var(--tg-hint);text-transform:capitalize}.slot-book-btn{margin-top:14px;width:100%;font-size:.95rem;padding:12px}.slot-detail-hint{text-align:center;color:var(--tg-hint);font-size:.8rem;margin-top:10px;font-style:italic}.coaching-card{display:flex;flex-direction:column;gap:8px}.coaching-header{display:flex;justify-content:space-between;align-items:center}.coaching-header h3{font-size:1rem}.coaching-type{font-size:.78rem;padding:3px 8px;border-radius:10px;background:color-mix(in srgb,var(--tg-btn) 15%,var(--tg-secondary-bg));text-transform:capitalize}.coaching-detail{display:flex;justify-content:space-between;font-size:.85rem;color:var(--tg-hint)}.coaching-desc{font-size:.85rem;color:var(--tg-hint)}.coaching-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.spots{font-size:.85rem;color:var(--tg-hint)}.spots.low{color:#e74c3c;font-weight:500}.joined-badge{padding:6px 16px;border-radius:8px;font-size:.85rem;font-weight:500;background:#22c55e;color:#fff}.feature-card{display:flex;gap:14px;align-items:flex-start}.feature-icon{font-size:1.8rem;flex-shrink:0}.feature-text h3{font-size:.95rem;font-weight:600;margin-bottom:2px}.feature-text p{font-size:.82rem;color:var(--tg-hint)}.open-matches-section{margin-top:20px;padding:0 16px}.open-matches-title{font-size:1.1rem;font-weight:600;margin-bottom:12px}.match-card{background:var(--tg-secondary-bg);border-radius:10px;padding:12px 14px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.match-card-info{display:flex;flex-direction:column;gap:2px}.match-card-creator{font-weight:600;font-size:.9rem}.match-card-time{font-size:.8rem;color:var(--tg-hint)}.match-card-action{display:flex;align-items:center;gap:8px}.match-card-spots{font-size:.8rem;color:var(--tg-hint)}.match-card-badge{padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500;background:var(--tg-secondary-bg);border:1px solid var(--tg-hint);color:var(--tg-hint)}.match-card-badge.joined{background:#22c55e;color:#fff;border-color:#22c55e}.match-join-btn{width:auto;padding:6px 16px;font-size:.85rem}.admin-page{padding:0 16px 24px}.admin-header{padding:12px 0;text-align:center;position:relative}.admin-header h1{font-size:1.3rem;font-weight:600}.admin-header p{color:var(--tg-hint);font-size:.85rem;margin-top:2px}.admin-back-btn{position:absolute;left:0;top:14px;background:none;border:none;color:var(--tg-btn);font-size:1rem;cursor:pointer;padding:4px 8px}.admin-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.admin-stat-card{background:var(--tg-secondary-bg);border-radius:12px;padding:14px 8px;text-align:center}.admin-stat-value{font-size:1.6rem;font-weight:700}.admin-stat-label{font-size:.72rem;color:var(--tg-hint);margin-top:2px}.admin-section{margin-bottom:20px}.leaderboard-legend{margin:8px 0 4px;padding:10px 12px;border:1px solid var(--tg-hint);border-radius:8px;background:var(--tg-secondary-bg);font-size:12px;line-height:1.4}.leaderboard-legend-row{display:flex;gap:8px;margin:2px 0}.leaderboard-legend-key{flex:0 0 56px;font-weight:600;text-align:right;color:var(--tg-text)}.leaderboard-legend-val{flex:1;opacity:.75}.band-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border:1px solid var(--tg-hint);border-radius:8px;background:var(--tg-secondary-bg);color:var(--tg-text);font-size:.95rem;cursor:pointer;text-align:left}.band-toggle:hover{filter:brightness(1.05)}.admin-section h2{font-size:1rem;font-weight:600;margin-bottom:10px}.admin-textarea{width:100%;padding:10px;border:1px solid var(--tg-hint);border-radius:8px;font-size:.9rem;resize:vertical;margin-bottom:8px;background:var(--tg-secondary-bg);color:var(--tg-text);box-sizing:border-box}.admin-send-result{font-size:.82rem;color:var(--tg-hint);margin-top:6px}.admin-search-row{display:flex;gap:8px;margin-bottom:10px}.admin-search-input{flex:1;width:100%;box-sizing:border-box;display:block;padding:8px 10px;border:1px solid var(--tg-hint);border-radius:8px;font-size:.9rem;font-family:inherit;background:var(--tg-secondary-bg);color:var(--tg-text);margin-bottom:8px}textarea.admin-search-input{resize:vertical}.admin-search-btn{width:auto;padding:8px 14px;font-size:.85rem}.admin-player-list{max-height:300px;overflow-y:auto}.admin-player-row{padding:10px 0;border-bottom:1px solid var(--tg-secondary-bg)}.admin-player-name{font-weight:500;font-size:.9rem}.admin-player-username{color:var(--tg-hint);font-size:.8rem;margin-left:6px;font-weight:400}.admin-player-meta{font-size:.78rem;color:var(--tg-hint);margin-top:2px}.admin-tag-incomplete{background:#fbbf24;color:#000;padding:1px 6px;border-radius:4px;font-size:.7rem;margin-left:6px}.admin-match-list{max-height:300px;overflow-y:auto}.admin-match-row{background:var(--tg-secondary-bg);border-radius:8px;padding:10px 12px;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center}.admin-match-info{display:flex;flex-direction:column;gap:2px}.admin-match-creator{font-weight:500;font-size:.9rem}.admin-match-time{font-size:.78rem;color:var(--tg-hint)}.admin-match-meta{display:flex;align-items:center;gap:8px}.admin-match-spots{font-size:.85rem;font-weight:500}.admin-match-status{padding:3px 8px;border-radius:4px;font-size:.72rem;font-weight:500;text-transform:uppercase}.status-open{background:#dcfce7;color:#166534}.status-full{background:#dbeafe;color:#1e40af}.status-cancelled{background:#fee2e2;color:#991b1b}.admin-empty{text-align:center;color:var(--tg-hint);font-size:.85rem;padding:16px 0}
