.roster-page{position:relative;display:grid;gap:2rem}.roster-hero{background:radial-gradient(500px 320px at 10% 10%,rgba(255,91,46,.2),transparent 65%),radial-gradient(420px 260px at 90% 0%,rgba(90,209,200,.18),transparent 60%),#0c0d12eb;border:1px solid rgba(255,255,255,.12);border-radius:26px;padding:2.5rem 2.25rem;box-shadow:var(--shadow-soft)}.roster-actions{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center;margin-top:1.25rem}.roster-input{flex:1;min-width:220px;padding:.75rem 1rem;border-radius:16px;border:1px solid rgba(255,255,255,.16);background:#0a0b0fbf;color:var(--text);font-size:.95rem;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.roster-input::placeholder{color:#f7f2e773}.roster-input:focus{border-color:#ff5b2e99;box-shadow:0 0 0 3px #ff5b2e33;background:#0e0f14d9}.roster-count{padding:.4rem .9rem;border-radius:999px;border:1px solid rgba(245,180,87,.5);background:#f5b45729;color:var(--accent);font-weight:700;font-size:.65rem;text-transform:uppercase;letter-spacing:.2em}.roster-state,.roster-empty{text-align:center;padding:2.5rem 1.5rem;border-radius:20px;border:1px dashed rgba(255,255,255,.16);color:#f7f2e799;background:#0c0d1299}.roster-empty.error{border-color:#f8717173;color:#f87171}.roster-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;align-items:stretch;justify-items:center}.member-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.2rem 1.1rem;text-align:center;width:100%;border-radius:20px}.member-card:hover{transform:translateY(-2px);border-color:#ffffff38}.member-card.member{background:linear-gradient(160deg,#ff5b2e2e,#0a0b0fe6);border-color:#ff5b2e52}.member-avatar{width:64px;height:64px;border-radius:18px;object-fit:cover;background:#0c0d12b3;border:1px solid rgba(255,255,255,.18);box-shadow:0 10px 24px #00000073}.team-avatar-placeholder{display:grid;place-items:center;font-weight:700;font-size:1.05rem;color:var(--text);text-transform:uppercase;letter-spacing:.12em;background:linear-gradient(160deg,#f5b45740,#0a0b0fe6);border-color:#f5b45766}.member-info{flex:1;text-align:center;max-width:100%;display:flex;flex-direction:column;align-items:center;gap:.2rem}.member-name{font-weight:600;color:var(--text);font-size:.95rem}.member-role{font-size:.8rem;color:#f7f2e7a6}.member-team{font-size:.7rem;color:#f7f2e7a6;text-transform:uppercase;letter-spacing:.12em}.roster-card{width:100%;max-width:220px;min-height:180px;aspect-ratio:4 / 3.2;justify-content:center;text-decoration:none;cursor:pointer}.roster-card .member-name,.roster-card .member-role,.roster-card .member-team{max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-inline:.25rem}.roster-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem 0}.pagination-btn{padding:.5rem 1.2rem;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#0a0b0fbf;color:var(--text);font-size:.9rem;cursor:pointer;transition:border-color .2s,background .2s}.pagination-btn:hover:not(:disabled){border-color:#ff5b2e99;background:#0e0f14d9}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-info{color:#f7f2e7b3;font-size:.9rem;min-width:100px;text-align:center}@media(max-width:640px){.roster-hero{padding:2rem 1.5rem}.roster-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}@media(max-width:400px){.roster-hero{padding:1.5rem 1.1rem;border-radius:20px}.roster-actions{gap:.65rem}}.roster-search-wrap{position:relative;flex:1;min-width:220px}.roster-search-icon{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);width:15px;height:15px;color:#f7f2e766;pointer-events:none;transition:color .2s ease}.roster-search-wrap:focus-within .roster-search-icon{color:#ff5b2eb3}.roster-search-wrap .roster-input{width:100%;padding-left:2.4rem}@keyframes rosterCardIn{0%{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.roster-page--players .roster-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;align-items:stretch}.player-card{position:relative;flex:0 1 162px;min-width:130px;display:flex;flex-direction:column;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(160deg,#12131af5,#090a0eeb);overflow:hidden;text-decoration:none;cursor:pointer;box-shadow:0 4px 18px #00000059;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease;animation:rosterCardIn .4s ease both;animation-delay:var(--delay, 0ms)}.player-card:hover{transform:translateY(-5px) scale(1.015);border-color:#ffffff2b;box-shadow:0 14px 38px #00000080,0 0 28px #ff5b2e1c}.player-card.has-team:hover{box-shadow:0 14px 38px #00000080,0 0 28px #f5b45721}.player-card-banner{height:58px;flex-shrink:0;background-size:cover;background-position:center top;position:relative}.player-card-banner:after{content:"";position:absolute;bottom:0;left:0;right:0;height:22px;background:linear-gradient(to bottom,transparent,rgba(9,10,14,.9));pointer-events:none}.player-card-banner--empty{background:linear-gradient(135deg,hsl(var(--hue, 20),40%,15%),hsl(var(--hue, 20),30%,9%))}.player-card-avatar-wrap{display:flex;justify-content:center;margin-top:-30px;padding:0 1rem;position:relative;z-index:1}.player-card-avatar-img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid rgb(9,10,14);box-shadow:0 4px 18px #0000008c;transition:border-color .22s ease}.player-card:hover .player-card-avatar-img{border-color:#12131a}.player-card.has-team:hover .player-card-avatar-img{border-color:#1e1808}.player-card-avatar-initials{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,hsl(var(--hue, 20),50%,26%),hsl(var(--hue, 20),40%,16%));color:hsl(var(--hue, 20),65%,84%);border-color:hsl(var(--hue, 20),42%,30%);font-family:var(--font-display);font-size:2.1rem;letter-spacing:.02em}.player-card-body{padding:.45rem .8rem 1.1rem;display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center;flex:1}.player-card-name{font-weight:700;font-size:.9rem;color:var(--text);max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.player-card-team{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;justify-content:center;max-width:100%}.player-card-tag{font-size:.63rem;font-weight:800;text-transform:uppercase;letter-spacing:.2em;padding:.25rem .65rem;border-radius:5px;background:linear-gradient(135deg,#f5b45738,#ff641e1f);border:1px solid rgba(245,180,87,.55);color:var(--gold);white-space:nowrap;flex-shrink:0;text-shadow:0 0 8px rgba(245,180,87,.55);box-shadow:0 1px 8px #f5b4571f,inset 0 1px #ffffff12;transition:border-color .2s ease,box-shadow .2s ease,text-shadow .2s ease}.player-card:hover .player-card-tag{border-color:#f5b457d1;box-shadow:0 1px 14px #f5b45747,inset 0 1px #ffffff1a;text-shadow:0 0 12px rgba(245,180,87,.85)}.player-card-no-team{font-size:.65rem;color:#f7f2e747;font-style:italic}.roster-skeleton{flex:0 1 162px;min-width:130px;border-radius:20px;border:1px solid rgba(255,255,255,.06);padding:0;display:flex;flex-direction:column;align-items:center;background:#0c0d12cc;overflow:hidden}.skeleton-banner{width:100%;height:58px;flex-shrink:0;background:linear-gradient(90deg,#ffffff08,#ffffff12,#ffffff08 160px);background-size:400px 100%;animation:shimmer 1.5s infinite linear}.skeleton-body{display:flex;flex-direction:column;align-items:center;gap:.7rem;padding:0 .8rem 1.1rem;margin-top:-22px;width:100%}.skeleton-avatar{width:78px;height:78px;border-radius:50%;background:linear-gradient(90deg,#ffffff0a,#ffffff17,#ffffff0a 160px);background-size:400px 100%;animation:shimmer 1.5s infinite linear}.skeleton-line{height:11px;width:66%;border-radius:99px;background:linear-gradient(90deg,#ffffff0a,#ffffff17,#ffffff0a 160px);background-size:400px 100%;animation:shimmer 1.5s infinite linear}.skeleton-line.short{width:42%;animation-delay:.2s}@media(max-width:640px){.roster-page--players .roster-grid{gap:.75rem}.player-card,.roster-skeleton{flex-basis:140px;min-width:120px}}.roster-page--teams .roster-grid{grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:1rem;align-items:stretch;justify-items:stretch}.team-card{position:relative;display:flex;flex-direction:column;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(160deg,#12131af5,#090a0eeb);overflow:hidden;text-decoration:none;cursor:pointer;box-shadow:0 4px 18px #00000059;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease;animation:rosterCardIn .4s ease both;animation-delay:var(--delay, 0ms)}.team-card:hover{transform:translateY(-5px) scale(1.015);border-color:#ffffff2b;box-shadow:0 14px 38px #00000080,0 0 28px #f5b45721}.team-card-banner{height:58px;flex-shrink:0;background:linear-gradient(135deg,hsl(var(--hue, 38),55%,18%),hsl(var(--hue, 38),40%,10%));position:relative}.team-card-banner:after{content:"";position:absolute;bottom:0;left:0;right:0;height:22px;background:linear-gradient(to bottom,transparent,rgba(9,10,14,.9));pointer-events:none}.team-card-logo-wrap{display:flex;justify-content:center;margin-top:-30px;padding:0 1rem;position:relative;z-index:1}.team-card-logo-img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid rgb(9,10,14);box-shadow:0 4px 18px #0000008c;transition:border-color .22s ease;background:#0c0d12b3}.team-card:hover .team-card-logo-img{border-color:#12131a}.team-card-logo-placeholder{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid rgb(9,10,14);box-shadow:0 4px 18px #0000008c;background:linear-gradient(135deg,hsl(var(--hue, 38),50%,26%),hsl(var(--hue, 38),40%,16%));color:hsl(var(--hue, 38),65%,84%);border-color:hsl(var(--hue, 38),42%,30%);font-family:var(--font-display);font-size:2.1rem;font-weight:700;letter-spacing:.02em;transition:border-color .22s ease}.team-card:hover .team-card-logo-placeholder{border-color:#12131a}.team-card-body{padding:.45rem .8rem 1.1rem;display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center;flex:1}.team-card-name{font-weight:700;font-size:.9rem;color:var(--text);max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.team-card-meta{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;justify-content:center;max-width:100%}.team-card-tag{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;padding:.16rem .42rem;border-radius:99px;background:#f5b45721;border:1px solid rgba(245,180,87,.36);color:var(--gold);white-space:nowrap;flex-shrink:0}.team-card-members{font-size:.68rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:640px){.roster-page--teams .roster-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}}
