body {
    font-family: Arial, sans-serif;
}
h1 {
    text-align: center;
    margin-bottom: 20px;
}
.server-list {
    display: flex;
    flex-direction: column;
    gap: 15px; /* Расстояние между блоками серверов */
    max-width: 900px;
    margin: 0 auto;
}
.server-item {
    background: white;
    border-radius: 8px;
    padding: 15px;
    display: flex;
    align-items: center;
    box-shadow: 0 6px 9px rgba(0, 0, 0, 0.2);
    position: relative; /* Нужно для позиционирования номера (если он абсолютный) */
    /* overflow: hidden; /* Скрываем элементы, выходящие за границы, если нужно */ /* Убрал, чтобы не мешало тегам, если они выходят за пределы */

    /* Начальные стили для анимации появления */
    /* Элементы изначально скрыты и немного сдвинуты вниз */
    opacity: 0;
    transform: translateY(20px);
    /* Плавный переход для opacity и transform */
    transition: opacity 0.6s ease-out, transform 0.6s ease-out; /* Увеличим время анимации */
}

/* Стиль для элемента после загрузки статуса (для анимации) */
/* Класс 'loaded' добавляется JavaScript после получения статуса */
.server-item.loaded {
    opacity: 1;
    transform: translateY(0); /* Возвращаем на исходную позицию */
}

/* Стили для номера сервера */
.server-number {
    position: absolute;
    top: 10px;
    left: 10px;
    font-size: 1.2em; /* Размер номера */
    font-weight: bold;
    color: #303030; /* Цвет номера */
    opacity: 0.4; /* Полупрозрачность */
    z-index: 1; /* Чтобы был поверх контента */
}

/* Стили для иконки сервера */
.server-icon {
    width: 64px; /* Размер иконки */
    height: 64px;
    margin-right: 20px; /* Отступ справа от иконки */
    flex-shrink: 0; /* Предотвращаем сжатие иконки */
    border-radius: 4px; /* Немного скруглим углы */
}

/* Блок с основной информацией о сервере */
.server-info {
    flex-grow: 1; /* Занимает все доступное пространство */
    margin-right: 30px; /* Отступ перед кнопкой */
    /* Добавляем min-width: 0; чтобы flex-item мог сжиматься ниже своего содержимого */
    min-width: 0;
}

.server-name {
    margin: 0; /* Убираем стандартные отступы, добавляем нижний */
    font-size: 1.2em; /* Размер названия */
    color: #000000;
    /* --- Стили для обрезки текста с многоточием --- */
    white-space: nowrap; /* Запрещаем перенос строки */
    overflow: hidden; /* Скрываем текст, который не помещается */
    text-overflow: ellipsis; /* Добавляем многоточие */
    /* --- Конец стилей для обрезки --- */
}

/* Контейнер для IP адреса (кликабельный) */
.server-ip-container {
    display: inline-block; /* Чтобы занимал только нужную ширину */
    background-color: #e9ecef; /* Светлый фон */
    border: 1px solid #ced4da; /* Серая рамка */
    border-radius: 4px;
    padding: 5px 10px;
    font-family: Andale Mono, monospace;/* Моноширинный шрифт для IP */
    color: #495057; /* Темный цвет текста */
    cursor: pointer;
    text-decoration: none !important; /* Убираем стандартное подчеркивание */
    transition: background-color 0.2s ease;
}
.server-ip-container:hover {
    background-color: #dee2e6; /* Цвет фона при наведении */
}


/* Стили для индикатора статуса (кружок + текст) */
.status-indicator {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
    font-size: 0.9em;
}

.status-circle {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin-right: 8px;
    background-color: #ccc; /* Цвет по умолчанию (загрузка) */
}

.status-indicator.online .status-circle { background-color: #28a745; /* Зеленый для онлайн */ }
.status-indicator.offline .status-circle { background-color: #dc3545; /* Красный для офлайн */ }
.status-indicator.error .status-circle { background-color: #ffc107; /* Желтый для ошибки */ }

.status-text {
    font-weight: bold;
}
.status-indicator.online .status-text { color: #28a745; }
.status-indicator.offline .status-text { color: #dc3545; }
.status-indicator.error .status-text { color: #ffc107; }


/* Стили для строк деталей (Состояние, Версия, Игроки) */
.server-status, .server-version, .server-players {
    margin: 5px 0;
    color: #555;
    font-size: 0.9em;
}

.detail-label {
    font-weight: bold;
    margin-right: 5px;
}

.detail-value {
    font-weight: normal; /* Значения не жирные */
}

 /* Стили для строки ошибки */
.status-error-row {
    margin: 5px 0;
    color: #dc3545; /* Красный цвет для ошибки */
    font-size: 0.9em;
}
.status-error-message {
    font-weight: normal;
}

/* Стили для MOTD */
.motd {
    font-weight: bold;
    color: #db001c;
    word-break: break-word;
    margin-top: 10px; /* Добавляем отступ сверху, если теги над ним */
    margin-bottom: 10px;
}

/* Стили для текста "Добавлен X назад" */
.text-muted {
    font-size: 0.9em;
    color: #888;
}

/* Стили для кнопки "Перейти к серверу" */
.detail-button {
    position: absolute-right;
    display: inline-block; /* Или flex-item */
    padding: 10px 15px;
    background-color: #427f01; /* Зеленый цвет */
    color: white;
    text-decoration: none;
    border-radius: 5px;
    transition: background-color 0.2s ease;
    align-self: flex-start; /* Выравниваем кнопку по верху */
    flex-shrink: 0; /* Предотвращаем сжатие кнопки */
}
.detail-button:hover {
    background-color: #08631c; /* Темнее зеленый при наведении */
}

/* --- CSS для цветов Minecraft (из вашего кода) --- */
.minecraft-color-black { color: #000000; }
.minecraft-color-dark_blue { color: #0000AA; }
.minecraft-color-dark_green { color: #00AA00; }
.minecraft-color-dark_aqua { color: #00AAAA; }
.minecraft-color-dark_red { color: #AA0000; }
.minecraft-color-dark_purple { color: #AA00AA; }
.minecraft-color-gold { color: #FFAA00; }
.minecraft-color-gray { color: #AAAAAA; }
.minecraft-color-dark_gray { color: #555555; }
.minecraft-color-blue { color: #5555FF; }
.minecraft-color-green { color: #55FF55; }
.minecraft-color-aqua { color: #55FFFF; }
.minecraft-color-red { color: #FF5555; }
.minecraft-color-light_purple { color: #FF55FF; }
.minecraft-color-yellow { color: #FFFF55; }
.minecraft-color-white { color: #FFFFFF; }

/* --- CSS для форматов Minecraft (из вашего кода) --- */
.minecraft-bold { font-weight: bold; }
.minecraft-italic { font-style: italic; }
.minecraft-underline { text-decoration: underline; }
.minecraft-strikethrough { text-decoration: line-through; }
.minecraft-obfuscated {
  display: inline-block; /* Важно для правильного применения стилей и JS */
}

/* --- Стили для красивого уведомления о копировании (из вашего кода) --- */
.copy-notification {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    background-color: #333;
    color: white;
    padding: 12px 25px;
    border-radius: 5px;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
}
.copy-notification.show {
    opacity: 1;
    visibility: visible;
}

/* --- Стили для блока с тегами (ИЗМЕНЕНО) --- */
.server-tags-container {
    display: flex; /* Используем flexbox для расположения тегов */
    gap: 5px; /* Расстояние между тегами */
    flex-wrap: wrap; /* Позволяет тегам переноситься на новую строку */
    justify-content: flex-start; /* Выравнивает теги по левому краю контейнера */
    margin-top: 10px; /* Добавляем отступ сверху, чтобы отделить от строки игроков */
    margin-bottom: 10px; /* Добавляем отступ снизу, чтобы отделить от MOTD */
    /* Удалены: position, top, right, max-width, z-index */
}

/* --- Стили для отдельного тега --- */
.server-tag {
    display: inline-block; /* Отображаем как строчно-блочный элемент */
    padding: 4px 8px; /* Внутренние отступы */
    border-radius: 4px; /* Скругленные углы */
    font-size: 0.7em; /* Размер шрифта (немного меньше основного текста) */
    font-weight: bold; /* Жирный шрифт */
    text-transform: uppercase; /* Текст тега в верхнем регистре (опционально) */
    box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.3); /* Тень для эффекта объема/поднятия */
    /* Цвет фона и текста задаются инлайн в HTML */
    white-space: nowrap; /* Запрещаем перенос текста внутри тега */
    line-height: 1; /* Убираем лишний межстрочный интервал */
}


/* Общие стили для блока издания */
.server-edition {
    display: inline-block; /* Позволяет применять padding и margin */
    padding: 3px 8px; /* Внутренние отступы */
    border-radius: 5px; /* Скругление углов */
    color: white; /* Цвет текста */
    font-weight: bold; /* Жирный текст */
    margin-left: 5px; /* Небольшой отступ слева, если стоит рядом с другим текстом */
    white-space: nowrap; /* Предотвращает перенос текста */
    justify-content: flex-end;
    position: absolute-right;
}

/* Стили для Java Edition (зеленый фон) */
.edition-java {
    background-color: #279103; /* Зеленый цвет */
    margin-right: -140px;
}

/* Стили для Bedrock Edition (синий фон) */
.edition-bedrock {
    background-color: #1829ff; /* Синий цвет */
    margin-right: -155px;
}

/* Стили для Unknown Edition (серый фон, если нужно) */
.edition-unknown {
    background-color: #9E9E9E; /* Серый цвет */
    margin-right: -155px;
}

.edition-both {
    background-color: #7426ed;
    margin-right: -155px;
}
/* --- Адаптивность --- */
@media (max-width: 600px) {
    .server-item {
        display: grid;
        place-items: center;
        flex-direction: column;
        align-items: flex-start;
        padding-top: 40px; /* Увеличим верхний отступ, чтобы освободить место для издания и номера */
        padding-bottom: 60px; /* Увеличим нижний отступ для кнопки */
    }
    .server-number {
         position: static; /* Убираем абсолютное позиционирование на маленьких экранах */
         margin-bottom: 10px;
         font-size: 1.2em;
    }
    .server-icon {
        place-items: center;
        margin-right: 0;
        margin-bottom: 10px;
    }
    .server-info {
        width: 100%;
        margin-right: 0;
        margin-bottom: 15px;
        min-width: auto;
    }
     .server-name {
         white-space: normal;
         overflow: visible;
         text-overflow: clip;
     }
     .server-ip-container {
         display: flex; /* Используем flex для центрирования содержимого */
         justify-content: center; /* Центрируем по горизонтали */
         width: 100%;
         box-sizing: border-box; /* Учитываем padding в ширине */
         margin-bottom: 10px; /* Отступ после IP */
     }
     .server-ip-container .fas.fa-copy {
         margin-left: 5px;
     }

     /* Адаптивность для тегов на маленьких экранах */
    .server-tags-container {
        width: 100%;
        margin-top: 10px;
        margin-bottom: 10px;
        justify-content: flex-start;
        padding: 0;
        box-sizing: border-box;
    }
    .server-tag {
        /* Нет специфичных изменений, необходимых здесь для мобильных */
    }

    /* Адаптивность для издания (АБСОЛЮТНОЕ ПОЗИЦИОНИРОВАНИЕ НА МОБИЛЬНЫХ) */
    .server-edition {
        top: 10px; /* Сдвигаем немного вверх */
    }

    /* Адаптивность для кнопки (АБСОЛЮТНОЕ ПОЗИЦИОНИРОВАНИЕ НА МОБИЛЬНЫХ) */
    .detail-button {

        position: absolute; /* Сохраняем абсолютное позиционирование */
        bottom: 10px; /* Сдвигаем немного вверх */
        left: 50%; /* Центрируем по горизонтали */
        transform: translateX(-50%); /* Сдвигаем обратно на половину своей ширины */
        width: calc(100% - 30px); /* Занимает почти всю ширину с отступами (15px слева и 15px справа) */
        max-width: 80%; /* Ограничиваем максимальную ширину */
        text-align: center;
        font-size: 0.9em;
    }

    /* Адаптивность для формы поиска */
    .search-form-container {
        padding: 15px; /* Уменьшаем padding */
    }
    .search-form .edition-filter-options label {
        display: block; /* Каждая радио-кнопка на новой строке */
        margin-right: 0;
        margin-bottom: 5px; /* Отступ между радио-кнопками */
    }
    .search-form .tags-filter .tags-checkbox-list {
        max-height: 100px; /* Возможно, уменьшим высоту списка тегов */
    }
    .search-form button[type="submit"],
    .search-form .btn-secondary {
        width: 100%; /* Кнопки на всю ширину */
        margin-right: 0;
        margin-bottom: 10px; /* Отступ между кнопками */
    }
    /* Убираем margin-bottom у последней кнопки в группе на мобильных */
    .search-form .form-group:last-of-type button:last-child,
    .search-form .form-group:last-of-type .btn-secondary:last-child {
         margin-bottom: 0;
    }
    .edition-java{
    margin-right: 0px;
    }
    .edition-bedrock{
    margin-right: 0px;
    }
    .edition-unknown{
    margin-right: 0px;
    }
    .edition-both{
    margin-right: 0px;
    }
}
