Загрузка данных


<!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>