/* Reset-ish */
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,Segoe UI,Arial;background: linear-gradient(rgba(7, 16, 23, 0.85), rgba(3, 18, 26, 0.9)), url('https://github.com/glitterinzem-star/list/raw/eb19b47512794568c09bc9e9c087eba26a1acc55/fon.jpg') no-repeat center center fixed;
background-size: cover;} .container{max-width:1100px;margin:0 auto;padding:20px}
/* Header */
.site-header{position:sticky;top:0;background:linear-gradient(180deg, rgba(2,6,23,0.6), rgba(2,6,23,0.3));backdrop-filter:blur(6px);border-bottom:1px solid rgba(255,255,255,0.02);z-index:10}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.logo{font-weight:700;text-decoration:none;color:#ffb86b;font-size:20px;cursor:pointer}
.main-nav{display:flex;gap:16px}
.main-nav a{color:#e0e0e0;text-decoration:none;cursor:pointer;white-space:nowrap;border-radius:999px;padding:6px 12px;transition:all 0.2s ease}
.main-nav a:hover{background:rgba(255,184,107,0.1)}
.main-nav a:active{background:rgba(255,184,107,0.3);transform:scale(0.95)}
.main-nav a.active{color:#ffb86b;font-weight:600;background:rgba(255,184,107,0.15)}
/* Hero */
.hero{text-align:center;padding:28px 0}
.hero h1{font-size:40px;margin:6px 0}
.subtitle{color:var(--muted);margin-bottom:12px}
/* Controls */
.controls{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:6px}
.controls input, .controls select{padding:10px 12px;border-radius:999px;border:1px solid rgba(255,255,255,0.04);background:var(--glass);color:inherit;min-width:180px}
.btn{padding:10px 14px;border-radius:999px;border:0;background:var(--accent);color:#071017;cursor:pointer;font-weight:700;text-decoration:none;display:inline-block;transition:all 0.2s ease}
.btn:active{background:#ffa03c;transform:scale(0.95)}
/* Grid - 5 cards per row */
.cards-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:18px}
.card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.18));padding:14px;border-radius:12px;display:flex;gap:14px;align-items:flex-start;box-shadow:0 8px 20px rgba(2,6,23,0.6);border:1px solid rgba(255,255,255,0.03)}
.card img{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0}
.card-body{flex:1}
.nick-row{display:flex;align-items:center;gap:8px;justify-content:space-between}
.nick{margin:0;font-size:18px;color:#ffffff}
.badge{padding:6px 8px;border-radius:999px;font-weight:700;font-size:12px;color:#071017}
.badge.owner{background:gold}
.badge.high{background:#ff8c00}
.badge.medium{background:#1e90ff}
.badge.low{background:gray;color:#fff}
.badge.banned{background:crimson;color:#fff}
.role{margin:6px 0;color:var(--accent);font-weight:600}
.desc{margin:0;color:var(--muted);font-size:13px}
.card a.link-profile{display:inline-block;margin-top:8px;text-decoration:none;color:var(--accent);font-weight:700;cursor:pointer}
/* Profile page */
.profile-card{background:var(--card);padding:18px;border-radius:12px}
.profile-card .bigavatar{width:120px;height:120px;border-radius:50%;object-fit:cover;margin-right:18px}
.profile-top{display:flex;gap:18px;align-items:center}
.profile-meta{color:var(--muted);margin-top:6px}
/* Apply form */
.apply-form{max-width:700px;margin:0 auto;margin-top:12px;display:grid;gap:10px}
.apply-form label{display:flex;flex-direction:column;color:var(--muted);font-size:14px}
.apply-form input, .apply-form select, .apply-form textarea{padding:10px;border-radius:999px;border:1px solid rgba(255,255,255,0.04);background:var(--glass);color:inherit}
.apply-form textarea{min-height:90px;resize:vertical;border-radius:12px}
.format-info{background:rgba(255,255,255,0.03);padding:16px;border-radius:12px;margin-bottom:20px;border:1px solid rgba(255,255,255,0.05)}
.format-info h3{color:var(--accent);margin-top:0}
/* Footer */
.site-footer{padding:18px 0;text-align:center;color:var(--muted);border-top:1px solid rgba(255,255,255,0.02);margin-top:36px}
/* Страницы */
.page{display:none;}
.page.active{display:block;}
/* Mobile */
@media (max-width:1100px){
.cards-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:900px){
.cards-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:720px){
.profile-top{flex-direction:column;align-items:flex-start}
.cards-grid{grid-template-columns:repeat(2,1fr)}
.hero h1{font-size:28px}
.header-inner{flex-direction:column;gap:12px;text-align:center}
.main-nav{gap:12px;justify-content:center}
.controls{flex-direction:column;align-items:center}
.controls input, .controls select{width:100%;max-width:300px}
.btn{width:100%;max-width:300px;text-align:center}
}
@media (max-width:480px){
.container{padding:12px}
.hero{padding:20px 0}
.hero h1{font-size:24px}
.cards-grid{grid-template-columns:1fr;gap:12px}
.card{flex-direction:column;text-align:center;align-items:center}
.card img{margin-bottom:8px}
.profile-top{flex-direction:column;text-align:center;align-items:center}
.profile-card .bigavatar{margin-right:0;margin-bottom:12px}
}
.hint {
color: var(--muted);
font-style: italic;
text-align: center;
padding: 20px;
}
/* Номер в карточке */
.number {
display: inline-block;
background: rgba(255, 184, 107, 0.1);
padding: 3px 8px;
border-radius: 6px;
font-size: 12px;
margin-top: 4px;
color: var(--accent);
border: 1px solid rgba(255, 184, 107, 0.2);
}
Список участников, отсортированный по старшинству
<div class="controls">
<input id="search" placeholder="Поиск по нику, номеру или описанию..." aria-label="Поиск" />
<select id="filterMedia" aria-label="Фильтр по медийке">
<option value="all">Все медийки</option>
<option value="owner">Разработчик</option>
<option value="Высокая медийка">Высокая медийка</option>
<option value="Средняя медийка">Средняя медийка</option>
<option value="Малая медийка">Малая медийка</option>
<option value="Бомж/скамер">Бомж/скамер</option>
</select>
<select id="filterRank" aria-label="Фильтр по рангу">
<option value="all">Все ранги</option>
<option value="owner">разработчик</option>
<option value="high">Высокая</option>
<option value="medium">Средняя</option>
<option value="low">Малая</option>
<option value="banned">Бомж/скамер</option>
</select>
<button id="resetBtn" class="btn">Сброс</button>
</div>
</section>
<section>
<div id="cards" class="cards-grid" aria-live="polite"></div>
</section>
</div>
<!-- Страница профиля -->
<div id="profilePage" class="page">
<div id="profileCard" class="profile-card" aria-live="polite">
<p class="hint">Зайдите на профиль через ссылку "Смотреть профиль" на главной или добавьте параметр ?user=Nick</p>
</div>
</div>
<!-- Страница заявки -->
<div id="applyPage" class="page">
<section class="hero">
<h1>Подать заявку</h1>
<p class="subtitle">Заполните форму для добавления в Fame List</p>
</section>
<div class="format-info">
<h3>Формат заявки</h3>
<p>Для подачи заявки нажмите кнопку ниже - она откроет Telegram-бота, где нужно будет отправить информацию в следующем формате:</p>
<p><strong>Ник:</strong> Ваш никнейм в телеграмм</p>
<p><strong>Ссылка на профиль телеграмм:</strong> https://t.me/username</p>
<p><strong>Медийность:</strong> Высокая/Средняя/Малая</p>
<p><strong>Как пришёл в KM:</strong> Описание как вы появились в KM</p>
</div>
<div style="text-align: center; margin-top: 30px;">
<a href="https://t.me/PsulistHelp_Bot" class="btn" target="_blank" style="padding: 12px 24px; font-size: 16px;">
Подать заявку в бота
</a>
</div>
</div>
© Fame List — @Psulist
Медийка: ${person.media || person.rankName || '-'}
${person.desc || ''}
Номер: ${person.number || 'не указан'}
В КМ с: ${person.since || '-'}
Параметр user не указан. Откройте профиль через ссылку 'Смотреть профиль' на главной.
`; return; } const person = people.find(p => p.nick.toLowerCase() === nick.toLowerCase()); if (!person) { profileContainer.innerHTML = `Пользователь ${escapeHtml(nick)} не найден.
`; return; } profileContainer.innerHTML = `Медийка: ${person.media || '-'}
Номер: ${person.number || 'не указан'}
В КМ с: ${person.since || '-'}
Ссылка: ${person.profile}
${person.desc || '-'}