Загрузка данных
<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<!-- Bootstrap CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.1/dist/css/bootstrap.min.css"
rel="stylesheet"
integrity="sha384-+0n0xVW2eSR5OomGNYDnhzAbDsOXxcvSN1TPprVMTNDbiYZCxYbOOl7+AMvyTG2x"
crossorigin="anonymous"
>
<!-- Google Fonts -->
<link href="https://fonts.googleapis.com/css2?family=Bangers&family=Roboto:wght@300;400;700&display=swap" rel="stylesheet">
<!-- Font Awesome Icons -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
<title>Marvel Heroes Gallery</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Roboto', sans-serif;
background: linear-gradient(135deg, #0a0a0a 0%, #1a1a2e 100%);
color: #fff;
overflow-x: hidden;
}
/* Стиль навбара в стиле Marvel */
.navbar {
background: linear-gradient(135deg, #e23636 0%, #b81b1b 100%) !important;
box-shadow: 0 4px 20px rgba(0,0,0,0.3);
border-bottom: 3px solid #f5c518;
}
.navbar-brand {
font-family: 'Bangers', cursive;
font-size: 2rem !important;
letter-spacing: 2px;
color: #fff !important;
text-shadow: 3px 3px 0px #000;
transition: transform 0.3s ease;
}
.navbar-brand:hover {
transform: scale(1.05);
}
/* Заголовок */
.hero-title {
font-family: 'Bangers', cursive;
font-size: 3.5rem;
text-align: center;
margin: 30px 0;
letter-spacing: 3px;
background: linear-gradient(135deg, #f5c518, #e23636);
-webkit-background-clip: text;
background-clip: text;
color: transparent;
text-shadow: 2px 2px 10px rgba(0,0,0,0.5);
animation: fadeInDown 0.8s ease;
}
@keyframes fadeInDown {
from {
opacity: 0;
transform: translateY(-30px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
/* Карточки персонажей */
.character-card {
background: linear-gradient(145deg, #1e1e2e, #252535);
border: none;
border-radius: 20px;
overflow: hidden;
transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
cursor: pointer;
box-shadow: 0 10px 20px rgba(0,0,0,0.3);
height: 100%;
}
.character-card:hover {
transform: translateY(-10px) scale(1.02);
box-shadow: 0 20px 40px rgba(226,54,54,0.3);
}
.card-img-top {
height: 350px;
object-fit: cover;
transition: transform 0.5s ease;
filter: brightness(0.9);
}
.character-card:hover .card-img-top {
transform: scale(1.05);
filter: brightness(1);
}
.card-body {
padding: 1.5rem;
background: linear-gradient(to top, #1a1a2e, #252535);
}
.card-title {
font-family: 'Bangers', cursive;
font-size: 1.8rem;
color: #f5c518;
margin-bottom: 0.5rem;
text-shadow: 1px 1px 0px #000;
}
.card-text {
font-size: 0.9rem;
color: #ccc;
line-height: 1.5;
max-height: 80px;
overflow-y: auto;
}
/* Кастомный скролл */
.card-text::-webkit-scrollbar {
width: 5px;
}
.card-text::-webkit-scrollbar-track {
background: #333;
border-radius: 10px;
}
.card-text::-webkit-scrollbar-thumb {
background: #e23636;
border-radius: 10px;
}
/* Спиннер */
.spinner-border {
width: 4rem;
height: 4rem;
border-width: 0.4rem;
}
/* Модальное окно */
.modal-content {
background: linear-gradient(135deg, #1e1e2e, #2a2a3a);
border: 2px solid #e23636;
border-radius: 25px;
color: white;
}
.modal-header {
border-bottom: 2px solid #f5c518;
background: linear-gradient(135deg, #e23636, #b81b1b);
border-radius: 23px 23px 0 0;
}
.modal-title {
font-family: 'Bangers', cursive;
font-size: 2rem;
letter-spacing: 2px;
}
.modal-body img {
border-radius: 15px;
box-shadow: 0 5px 15px rgba(0,0,0,0.5);
width: 100%;
max-width: 250px;
margin: 0 auto 20px;
display: block;
border: 3px solid #f5c518;
}
.btn-close-white {
filter: brightness(0) invert(1);
}
/* Кнопка закрытия в модалке */
.btn-marvel {
background: #e23636;
color: white;
border: none;
padding: 8px 25px;
border-radius: 50px;
font-weight: bold;
transition: all 0.3s ease;
}
.btn-marvel:hover {
background: #f5c518;
color: #000;
transform: scale(1.05);
}
/* Анимация для карточек при загрузке */
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(30px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.row > div {
animation: fadeInUp 0.6s ease forwards;
}
/* Футер */
.footer {
text-align: center;
padding: 30px;
margin-top: 50px;
background: linear-gradient(135deg, #0a0a0a, #1a1a2e);
border-top: 1px solid #e23636;
color: #888;
font-size: 0.9rem;
}
/* Адаптивность */
@media (max-width: 768px) {
.hero-title {
font-size: 2.5rem;
}
.card-img-top {
height: 250px;
}
.card-title {
font-size: 1.4rem;
}
}
</style>
</head>
<body>
<nav class="navbar navbar-dark">
<div class="container-fluid">
<a href="#" class="navbar-brand">
<i class="fas fa-mask"></i> MARVEL <i class="fas fa-bolt"></i>
</a>
</div>
</nav>
<div class="container">
<h1 class="hero-title">
<i class="fas fa-star"></i> Персонажи Marvel <i class="fas fa-star"></i>
</h1>
<div class="row" id="character-card-box">
<div class="d-flex justify-content-center">
<div class="spinner-border text-danger center" role="status">
<span class="visually-hidden">Loading...</span>
</div>
</div>
</div>
<div id="character-modal-box"></div>
</div>
<footer class="footer">
<p><i class="fas fa-copyright"></i> 2026 Marvel Heroes Gallery | Powered by Marvel API</p>
</footer>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.1/dist/js/bootstrap.bundle.min.js"
integrity="sha384-gtEjrD/SeCtmISkJkNUaaKMoLD0//ElJ19smozuHV6z3Iehds+3Ulb9Bn9Plx0x4"
crossorigin="anonymous"
></script>
<script src="index.js"></script>
<script src="start.js"></script>
<script>
document.addEventListener("DOMContentLoaded", () => {
start();
});
</script>
</body>
</html>