1 Commits

Author SHA1 Message Date
04d41ad5f7 Spinter Cell 2026-03-12 13:33:45 +03:00

View File

@@ -1,259 +1,535 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang="ru"> <html lang="ru">
<head> <head>
<meta charset="UTF-8"> <meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Екатерина Иванова — Product Manager</title> <title>Evgeniy Spirin | DevOps</title>
<!-- Google Fonts + Font Awesome --> <!-- Моноширинный шрифт -->
<link rel="preconnect" href="https://fonts.googleapis.com"> <link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,400;14..32,500;14..32,600&display=swap" rel="stylesheet"> <link href="https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap" rel="stylesheet">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css"> <!-- Font Awesome -->
<style> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
* { margin: 0; padding: 0; box-sizing: border-box; } <style>
body { /* Стили для сплеш-скрина (экран загрузки) */
background: #f4f6f9; #splash {
font-family: 'Inter', sans-serif; position: fixed;
color: #1e293b; top: 0;
line-height: 1.5; left: 0;
padding: 2rem 1rem; width: 100%;
} height: 100%;
.resume { background-color: #0a0f0a;
max-width: 1050px; color: #00ff99;
margin: 0 auto; font-family: 'JetBrains Mono', monospace;
background: white; z-index: 9999;
border-radius: 32px; display: flex;
box-shadow: 0 25px 50px -12px rgba(0,0,0,0.15); flex-direction: column;
display: grid; justify-content: center;
grid-template-columns: 300px 1fr; align-items: center;
overflow: hidden; text-align: center;
} transition: opacity 1s ease;
/* Левая панель */ opacity: 1;
.sidebar { pointer-events: none; /* чтобы не мешать кликам после скрытия */
background: #f8fafc; }
padding: 2rem 1.5rem; #splash.hidden {
border-right: 1px solid #e2e8f0; opacity: 0;
} pointer-events: none;
.avatar { }
width: 140px; .splash-content {
height: 140px; max-width: 600px;
border-radius: 50%; padding: 2rem;
object-fit: cover; border: 2px solid #00cc44;
border: 4px solid white; box-shadow: 0 0 40px #00ff99;
box-shadow: 0 8px 16px rgba(0,0,0,0.05); background: rgba(0, 10, 0, 0.8);
margin-bottom: 1.5rem; }
} .splash-title {
.sidebar h1 { font-size: 2rem;
font-size: 1.8rem; font-weight: 700;
font-weight: 600; margin-bottom: 1rem;
margin-bottom: 0.25rem; text-transform: uppercase;
} letter-spacing: 4px;
.sidebar .title { text-shadow: 0 0 10px #0f0;
color: #475569; }
font-weight: 500; .splash-text {
margin-bottom: 1.5rem; font-size: 1.2rem;
padding-bottom: 1.5rem; margin-bottom: 2rem;
border-bottom: 1px solid #e2e8f0; color: #b3ffb3;
} }
.info-item { .progress-bar {
display: flex; width: 100%;
align-items: center; height: 4px;
gap: 0.75rem; background: #1a3a1a;
margin-bottom: 1rem; margin: 1rem 0;
color: #334155; position: relative;
} overflow: hidden;
.info-item i { }
width: 20px; .progress-fill {
color: #3b82f6; width: 0%;
} height: 100%;
.info-item a { background: #00ff99;
color: inherit; animation: fill 2.5s ease-out forwards;
text-decoration: none; }
} @keyframes fill {
.info-item a:hover { 0% { width: 0%; }
color: #3b82f6; 100% { width: 100%; }
} }
.skills-side h3 { .dots {
font-size: 1.1rem; display: inline-block;
margin: 2rem 0 1rem 0; width: 3rem;
} text-align: left;
.skill-tags { }
display: flex; .dots::after {
flex-wrap: wrap; content: '...';
gap: 0.5rem; animation: dots 1.5s steps(3, end) infinite;
} }
.skill-tags span { @keyframes dots {
background: white; 0%, 20% { content: '.'; }
padding: 0.3rem 1rem; 40% { content: '..'; }
border-radius: 40px; 60%, 100% { content: '...'; }
font-size: 0.85rem; }
border: 1px solid #e2e8f0;
font-weight: 500; /* Основные стили (как в предыдущей версии) */
} * {
/* Правая панель */ margin: 0;
.main { padding: 0;
padding: 2rem 2rem 2rem 1.5rem; box-sizing: border-box;
} }
.section { body {
margin-bottom: 2.5rem; background-color: #0b0f0b;
} font-family: 'JetBrains Mono', monospace;
.section h2 { color: #c3ffc3;
font-size: 1.5rem; line-height: 1.6;
font-weight: 600; padding: 2rem 1rem;
margin-bottom: 1.2rem; background-image: radial-gradient(circle at 10% 20%, rgba(0, 255, 65, 0.02) 0%, transparent 30%);
position: relative; }
display: inline-block; .grid-overlay {
} position: fixed;
.section h2:after { top: 0;
content: ''; left: 0;
position: absolute; width: 100%;
left: 0; height: 100%;
bottom: -6px; background-image:
width: 50px; linear-gradient(rgba(0, 255, 0, 0.02) 1px, transparent 1px),
height: 3px; linear-gradient(90deg, rgba(0, 255, 0, 0.02) 1px, transparent 1px);
background: #3b82f6; background-size: 40px 40px;
border-radius: 2px; pointer-events: none;
} z-index: 0;
.exp-item { }
margin-bottom: 1.8rem; .container {
} max-width: 1200px;
.exp-header { margin: 0 auto;
display: flex; background: rgba(10, 20, 10, 0.7);
justify-content: space-between; backdrop-filter: blur(4px);
align-items: baseline; border: 2px solid #00cc44;
flex-wrap: wrap; box-shadow: 0 0 30px rgba(0, 255, 65, 0.3);
margin-bottom: 0.5rem; padding: 2.5rem;
} border-radius: 0px;
.exp-header h3 { position: relative;
font-size: 1.2rem; z-index: 2;
font-weight: 600; }
} .section-title {
.exp-date { font-size: 1.6rem;
color: #64748b; font-weight: 700;
font-size: 0.9rem; text-transform: uppercase;
} letter-spacing: 3px;
.exp-company { margin-bottom: 2rem;
color: #3b82f6; position: relative;
font-weight: 500; display: inline-block;
margin-bottom: 0.5rem; color: #00ff99;
} text-shadow: 0 0 8px #00ff99;
.exp-desc { border-bottom: 2px solid #00cc44;
color: #334155; padding-bottom: 8px;
font-size: 0.95rem; }
list-style-type: disc; .section-title:before {
padding-left: 1.2rem; content: '>';
} margin-right: 10px;
.exp-desc li { color: #00ff99;
margin-bottom: 0.3rem; }
} .profile {
.project-card { display: flex;
background: #f8fafc; flex-wrap: wrap;
border-radius: 16px; gap: 2.5rem;
padding: 1.2rem; align-items: center;
margin-bottom: 1rem; margin-bottom: 3rem;
border: 1px solid #e2e8f0; border: 1px solid #00cc44;
} padding: 2rem;
.project-card h3 { background: rgba(0, 20, 0, 0.4);
font-size: 1.1rem; }
margin-bottom: 0.5rem; .profile-avatar {
display: flex; width: 150px;
align-items: center; height: 150px;
gap: 0.5rem; border-radius: 50%;
} object-fit: cover;
.project-card h3 i { border: 3px solid #00ff99;
color: #3b82f6; box-shadow: 0 0 25px #00ff99;
} filter: grayscale(100%) contrast(1.2);
.project-tech { }
display: flex; .profile-info h1 {
flex-wrap: wrap; font-size: 3rem;
gap: 0.4rem; font-weight: 700;
margin-top: 0.8rem; letter-spacing: 2px;
} margin-bottom: 0.5rem;
.project-tech span { text-shadow: 0 0 10px #0f0;
background: white; }
padding: 0.2rem 0.8rem; .profile-info .title {
border-radius: 30px; font-size: 1.3rem;
font-size: 0.8rem; color: #a0ffa0;
border: 1px solid #e2e8f0; margin-bottom: 1rem;
} }
@media (max-width: 700px) { .location {
.resume { grid-template-columns: 1fr; } display: flex;
.sidebar { border-right: none; border-bottom: 1px solid #e2e8f0; } align-items: center;
} gap: 0.5rem;
</style> color: #00cc44;
font-size: 1rem;
margin-bottom: 1.5rem;
border: 1px dashed #00cc44;
padding: 0.4rem 1rem;
width: fit-content;
}
.contacts {
display: flex;
flex-wrap: wrap;
gap: 2rem;
}
.contacts a {
color: #b3ffb3;
text-decoration: none;
display: flex;
align-items: center;
gap: 0.5rem;
font-size: 1rem;
border: 1px solid transparent;
padding: 0.3rem 0.8rem;
transition: 0.2s;
}
.contacts a:hover {
border-color: #00ff99;
box-shadow: 0 0 15px #00ff99;
background: rgba(0, 255, 65, 0.1);
color: #fff;
}
.contacts i {
font-size: 1.2rem;
color: #00ff99;
}
.about {
margin-bottom: 3rem;
border-left: 4px solid #00cc44;
padding-left: 1.5rem;
}
.about p {
font-size: 1.1rem;
color: #d0ffd0;
}
.skills-grid {
display: flex;
flex-wrap: wrap;
gap: 1rem;
margin-bottom: 3rem;
}
.skill-item {
background: #1a2a1a;
border: 1px solid #00cc44;
padding: 0.6rem 1.5rem;
font-size: 1rem;
font-weight: 500;
color: #b3ffb3;
box-shadow: 0 0 5px #00cc44;
transition: 0.2s;
display: flex;
align-items: center;
gap: 8px;
}
.skill-item i {
color: #00ff99;
}
.skill-item:hover {
background: #2a3a2a;
box-shadow: 0 0 20px #00ff99;
border-color: #00ff99;
}
.projects-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
gap: 2rem;
margin-bottom: 3rem;
}
.project-card {
background: #0f1a0f;
border: 2px solid #1e4d1e;
padding: 1.8rem;
transition: 0.2s;
position: relative;
}
.project-card:before {
content: '';
position: absolute;
top: 5px;
left: 5px;
right: 5px;
bottom: 5px;
border: 1px dashed #00cc44;
pointer-events: none;
}
.project-card:hover {
border-color: #00ff99;
box-shadow: 0 0 30px rgba(0, 255, 65, 0.4);
}
.project-card h3 {
font-size: 1.5rem;
margin-bottom: 1rem;
color: #00ff99;
}
.project-card p {
color: #b0ffb0;
margin-bottom: 1.5rem;
}
.project-tech {
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
}
.project-tech span {
background: #1f331f;
border: 1px solid #1e6d1e;
padding: 0.2rem 1rem;
font-size: 0.85rem;
color: #b3ffb3;
}
.project-link {
display: inline-block;
margin-top: 1.5rem;
color: #00ff99;
text-decoration: none;
border-bottom: 1px dotted #00ff99;
font-weight: 500;
}
.project-link i {
transition: transform 0.2s;
}
.project-link:hover i {
transform: translateX(5px);
}
.experience-list {
display: flex;
flex-direction: column;
gap: 2rem;
}
.exp-item {
border: 1px solid #1e6d1e;
padding: 1.5rem;
background: rgba(0, 20, 0, 0.3);
}
.exp-header {
display: flex;
justify-content: space-between;
align-items: baseline;
flex-wrap: wrap;
margin-bottom: 0.8rem;
}
.exp-header h3 {
font-size: 1.4rem;
color: #90ff90;
}
.exp-date {
color: #00cc44;
font-size: 1rem;
border: 1px solid #1e6d1e;
padding: 0.2rem 1rem;
}
.exp-company {
color: #a0ffa0;
margin-bottom: 1rem;
font-size: 1rem;
display: inline-block;
background: #1a2a1a;
padding: 0.2rem 1rem;
}
.exp-desc {
list-style-type: none;
}
.exp-desc li {
margin-bottom: 0.5rem;
padding-left: 1.5rem;
position: relative;
}
.exp-desc li:before {
content: '>';
position: absolute;
left: 0;
color: #00ff99;
font-weight: bold;
}
.footer {
margin-top: 3rem;
border-top: 2px solid #00cc44;
padding-top: 1.5rem;
display: flex;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
color: #00cc44;
}
.footer .cursor {
display: inline-block;
width: 12px;
height: 20px;
background: #00ff99;
animation: blink 1s infinite;
margin-left: 5px;
}
@keyframes blink {
0%, 100% { opacity: 1; }
50% { opacity: 0; }
}
.footer .prompt:before {
content: 'guest@sc-cell:~$';
color: #00ff99;
margin-right: 10px;
}
@media (max-width: 700px) {
.container { padding: 1.5rem; }
.profile { flex-direction: column; text-align: center; }
.location { margin-left: auto; margin-right: auto; }
}
</style>
</head> </head>
<body> <body>
<div class="resume"> <!-- Сплеш-скрин (загрузочный экран) -->
<!-- Левая колонка --> <div id="splash">
<div class="sidebar"> <div class="splash-content">
<img src="https://via.placeholder.com/140" alt="avatar" class="avatar"> <div class="splash-title">█ ВЗЛОМ █</div>
<h1>Екатерина Иванова</h1> <div class="splash-text">
<div class="title">Product Manager / Tech Lead</div> Производится взлом системы<span class="dots"></span>
<div class="info-item"><i class="fas fa-map-marker-alt"></i> Санкт-Петербург</div> </div>
<div class="info-item"><i class="fas fa-envelope"></i> <a href="mailto:ek@example.dev">ek@example.dev</a></div> <div class="progress-bar">
<div class="info-item"><i class="fas fa-phone-alt"></i> <a href="tel:+78121234567">+7 812 123-45-67</a></div> <div class="progress-fill"></div>
<div class="info-item"><i class="fab fa-github"></i> <a href="#">/ekaterina-dev</a></div> </div>
<div class="info-item"><i class="fab fa-linkedin"></i> <a href="#">/in/ekaterina</a></div> <div style="font-size:0.9rem; color:#0f0;">Доступ разрешён через 3...</div>
<div class="skills-side">
<h3>Технические навыки</h3>
<div class="skill-tags">
<span>Product Strategy</span><span>Agile</span><span>User Research</span>
<span>Python</span><span>SQL</span><span>Tableau</span><span>A/B testing</span>
<span>Jira</span><span>Confluence</span><span>Figma</span>
</div> </div>
</div>
</div> </div>
<!-- Правая колонка --> <!-- Фоновая сетка -->
<div class="main"> <div class="grid-overlay"></div>
<section class="section">
<h2>О себе</h2>
<p>Продуктовый менеджер с инженерным бэкграундом. 7+ лет опыта в разработке и управлении цифровыми продуктами. Умею выявлять потребности пользователей, формулировать гипотезы и доводить продукты до релиза.</p>
</section>
<section class="section"> <!-- Основной контент -->
<h2>Опыт работы</h2> <div class="container">
<div class="exp-item"> <!-- Профиль -->
<div class="exp-header"> <div class="profile">
<h3>Senior Product Manager</h3> <img src="https://i.imgur.com/p5kRCHS.jpeg" alt="Avatar" class="profile-avatar"> <!-- замените на своё фото -->
<span class="exp-date">2021 — наст. время</span> <div class="profile-info">
</div> <h1>Evgeniy Spirin</h1>
<div class="exp-company">SkyEng, удалённо</div> <div class="title">DevOps// Splinter Cell fan</div>
<ul class="exp-desc"> <div class="location">
<li>Управление платформой для онлайн-обучения (MAU 2M). Рост конверсии в платёж на 18%.</li> <i class="fas fa-map-marker-alt"></i> Нижний Новгород, Россия
<li>Запуск мобильного приложения с нуля: аналитика, прототипы, работа с командой разработки.</li> </div>
<li>Внедрение системы аналитики Amplitude и дашбордов для продуктовых метрик.</li> <div class="contacts">
</ul> <a href="mailto:oit_vpn@grenu4.ru"><i class="fas fa-envelope"></i> oit_vpn@grenu4.ru</a>
<a href="https://t.me/y0zhyck"><i class="fab fa-telegram"></i> @Y0zhyck</a>
<a href="https://git.grenu4.ru/y0zhyck"><i class="fab fa-github"></i> My private GIT</a>
<a href="#"><i class="fas fa-shield-alt"></i> secure</a>
</div>
</div>
</div> </div>
<div class="exp-item">
<div class="exp-header">
<h3>Product Owner</h3>
<span class="exp-date">2018 — 2021</span>
</div>
<div class="exp-company">Тинькофф, Москва</div>
<ul class="exp-desc">
<li>Развитие интернет-банка для юридических лиц, приоритизация бэклога.</li>
<li>Проведение пользовательских интервью и юзабилити-тестирований.</li>
<li>Координация трёх scrum-команд, релиз каждые две недели.</li>
</ul>
</div>
</section>
<section class="section"> <!-- О себе -->
<h2>Проекты</h2> <section class="about">
<div class="project-card"> <h2 class="section-title">Досье</h2>
<h3><i class="fas fa-chart-pie"></i> Дашборд метрик продукта</h3> <p>Специалист по инфраструктуре с опытом работы в режиме полной скрытности. Обеспечиваю надёжность и безопасность систем, автоматизирую всё, что движется. Владею арсеналом DevOps-инструментов, как Сэм Фишер своими гаджетами.</p>
<p>Разработала прототип и ТЗ для внутреннего дашборда, который объединил данные из нескольких источников. Внедрение сократило время подготовки отчётов на 70%.</p> </section>
<div class="project-tech"><span>SQL</span><span>Tableau</span><span>Redash</span></div>
<!-- Навыки (инвентарь) -->
<section>
<h2 class="section-title">Инвентарь</h2>
<div class="skills-grid">
<div class="skill-item"><i class="fas fa-terminal"></i> CI/CD (GitLab, GitHub)</div>
<div class="skill-item"><i class="fas fa-cubes"></i> Kubernetes</div>
<div class="skill-item"><i class="fab fa-docker"></i> Docker</div>
<div class="skill-item"><i class="fas fa-code-branch"></i> Terraform</div>
<div class="skill-item"><i class="fas fa-cog"></i> Ansible</div>
<div class="skill-item"><i class="fab fa-golang"></i> Golang</div>
<div class="skill-item"><i class="fas fa-chart-line"></i> Prometheus/Grafana</div>
<div class="skill-item"><i class="fas fa-lock"></i> Security (Vault, mTLS)</div>
</div>
</section>
<!-- Проекты (операции) -->
<section>
<h2 class="section-title">Секретные операции</h2>
<div class="projects-grid">
<div class="project-card">
<h3>◉ Cloud VPN</h3>
<p>Распределённая VPN-сеть на базе K8s. Мультипротокольность: VLESS, Trojan, Shadowsocks.</p>
<div class="project-tech">
<span>K8s</span><span>Xray</span><span>Prometheus</span>
</div>
<a href="#" class="project-link">Раскрыть детали <i class="fas fa-arrow-right"></i></a>
</div>
<div class="project-card">
<h3>◉ K8s Cost Optimizer</h3>
<p>Инструмент скрытого наблюдения за затратами в кластере. Поддержка AWS, GCP, Azure.</p>
<div class="project-tech">
<span>Golang</span><span>Prometheus</span><span>Cloud APIs</span>
</div>
<a href="#" class="project-link">Раскрыть детали <i class="fas fa-arrow-right"></i></a>
</div>
<div class="project-card">
<h3>◉ Torrent Blocker</h3>
<p>Система обнаружения и блокировки торрент-трафика на VPN-серверах. Автоматическое внесение в чёрный список.</p>
<div class="project-tech">
<span>Python</span><span>iptables</span><span>Telegram API</span>
</div>
<a href="#" class="project-link">Раскрыть детали <i class="fas fa-arrow-right"></i></a>
</div>
</div>
</section>
<!-- Опыт работы (послужной список) -->
<section>
<h2 class="section-title">Послужной список</h2>
<div class="experience-list">
<div class="exp-item">
<div class="exp-header">
<h3>DevOps Engineer</h3>
<span class="exp-date">2025 — н.в.</span>
</div>
<div class="exp-company">Ziteh, Nizhniy Novgorod (скрытый отдел)</div>
<ul class="exp-desc">
<li>Миграция монолитов в Kubernetes (архитектура нулевого доверия).</li>
<li>Оптимизация CI/CD pipelines сокращение времени сборки на 40%.</li>
<li>Внедрение Service Mesh (Istio) для безопасной связи микросервисов.</li>
</ul>
</div>
<div class="exp-item">
<div class="exp-header">
<h3>System Administrator (спецподразделение)</h3>
<span class="exp-date">2019 — 2024</span>
</div>
<div class="exp-company">Renaissance Heavy Industries, Tobolsk</div>
<ul class="exp-desc">
<li>Обеспечение бесперебойной работы инфраструктуры крупного промышленного комплекса.</li>
<li>Настройка сетей и систем мониторинга, достижение 99.9% аптайма.</li>
</ul>
</div>
</div>
</section>
<!-- Подвал в стиле командной строки -->
<div class="footer">
<div class="prompt">ready for orders <span class="cursor"></span></div>
<div>© 2026-2030 Evgeniy Spirin // Третий эшелон</div>
</div> </div>
<div class="project-card">
<h3><i class="fas fa-robot"></i> Чат-бот для поддержки</h3>
<p>Инициировала и курировала создание бота, который обрабатывает 60% типовых обращений. Интеграция с CRM и базами знаний.</p>
<div class="project-tech"><span>Python</span><span>Dialogflow</span><span>API</span></div>
</div>
</section>
</div> </div>
</div>
<!-- Скрипт для скрытия сплеш-скрина -->
<script>
window.addEventListener('load', function() {
// Показываем сплеш минимум 2 секунды (чтобы анимация прогресс-бара завершилась)
setTimeout(function() {
document.getElementById('splash').classList.add('hidden');
}, 2800); // чуть меньше времени анимации, чтобы не было пустого ожидания
});
</script>
</body> </body>
</html> </html>