.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);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

/* Стиль для элемента после загрузки статуса (для анимации) */
.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: 10px; /* Уменьшим отступ, т.к. кнопка и издание будут абсолютно позиционированы */
    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-flex; /* Используем inline-flex для выравнивания иконки */
    align-items: center;
    background-color: #e9ecef;
    border: 1px solid #ced4da;
    border-radius: 4px;
    padding: 5px 10px;
    font-family: Andale Mono, monospace;
    color: #495057;
    cursor: pointer;
    text-decoration: none !important;
    transition: background-color 0.2s ease;
}
.server-ip-container:hover {
    background-color: #dee2e6;
}
.server-ip-container .fas.fa-copy {
    margin-left: 8px; /* Отступ между текстом IP и иконкой */
    font-size: 0.9em; /* Размер иконки */
    color: #6c757d; /* Цвет иконки */
}


/* Стили для индикатора статуса (кружок + текст) */
.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;
}


/* --- Стили для блока издания (АБСОЛЮТНОЕ ПОЗИЦИОНИРОВАНИЕ) --- */
.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; }
/* Стили для Bedrock Edition */
.edition-bedrock { background-color: #1829ff; }
/* Стили для Unknown Edition */
.edition-unknown { background-color: #9E9E9E; }
.edition-both { background-color: #7426ed; }


/* --- Стили для кнопки "Перейти к серверу" (АБСОЛЮТНОЕ ПОЗИЦИОНИРОВАНИЕ) --- */
.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;
}

/* --- Стили для красивого уведомления о копировании --- */
.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;
    gap: 5px;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-top: 10px;
    margin-bottom: 10px;
    /* Удалены position, top, right, max-width, z-index */
}

/* --- Стили для отдельного тега в списке (АДАПТИРОВАНО из .tag-item-selectable) --- */
.server-tag {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.7em; /* Размер шрифта как в .tag-item-selectable */
    font-weight: bold; /* Жирный шрифт как в .tag-item-selectable */
    text-transform: uppercase; /* Верхний регистр как в .tag-item-selectable */
    box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.2); /* Легкая тень для списка */
    white-space: nowrap;
    line-height: 1;
    user-select: none;
    opacity: 0.9; /* Небольшая прозрачность как в .tag-item-selectable */
    text-shadow: none;
    /* Цвет фона и текста задаются инлайн в HTML */
}


/* --- Стили для формы поиска --- */
.search-form-container {
    background-color: #f9f9f9;
    border: 1px solid #ddd;
    padding: 20px;
    margin-bottom: 20px;
    border-radius: 8px;
}

.search-form .form-group {
    margin-bottom: 15px;
}

.search-form label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
}

.search-form .form-control {
    width: 100%;
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box;
}

.search-form .edition-filter-options label {
    display: inline-block;
    margin-right: 15px;
    font-weight: normal;
}

.search-form .tags-filter .tags-checkbox-list {
    max-height: 150px;
    overflow-y: auto;
    border: 1px solid #ccc;
    padding: 10px;
    border-radius: 4px;
    background-color: #fff;
}

/* Стиль для метки тега в форме поиска */
.search-form .tags-filter .tag-checkbox-label {
    margin: 3px;
    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.2); /* Легкая тень */
    white-space: nowrap;
    line-height: 1;
    cursor: pointer;
    transition: opacity 0.2s ease, box-shadow 0.2s ease; /* Добавляем transition для тени */
    user-select: none;
    border: 1px solid transparent; /* Оставляем для консистентности */
    opacity: 0.9;
    text-shadow: none;
    position: relative; /* Нужен для input[type="checkbox"] */
}

.search-form .tags-filter .tag-checkbox-label:hover {
    opacity: 1;
}

.search-form .tags-filter .tag-checkbox-label input[type="checkbox"] {
    position: absolute; /* Абсолютное позиционирование для скрытия чекбокса */
    opacity: 0;
    cursor: pointer;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    margin: 0;
    z-index: 1; /* Чтобы чекбокс был над текстом тега для клика */
}

/* Стиль для выбранного тега (класс 'selected-tag' добавляется JavaScript) */
.search-form .tags-filter .tag-checkbox-label.selected-tag {
    box-shadow: 7px 7px 7px rgba(0, 0, 0, 0.7), /* Увеличенная черная тень */
    0 0 0 3px rgba(6, 82, 0, 0.9);
    opacity: 1; /* Убедимся, что выбранный тег полностью непрозрачен */
}

/* Стиль для текста внутри тега при выборе чекбокса */
.search-form .tags-filter .tag-checkbox-label input[type="checkbox"]:checked + span {
    font-weight: bold;
    text-decoration: underline;
}


.search-form button[type="submit"],
.search-form .btn-secondary {
    padding: 10px 20px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    margin-right: 10px;
}

.search-form button[type="submit"] {
    background-color: #4f9900;
    color: white;
}

.search-form .btn-secondary {
    background-color: #6c757d;
    color: white;
    text-decoration: none;
    display: inline-block;
    text-align: center;
}


.search-results-info {
    margin-bottom: 20px;
    font-size: 1.1em;
    color: #555;
}


/* --- Обновленные стили для пагинации --- */
.pagination {
    display: flex; /* Используем flexbox для лучшего выравнивания */
    justify-content: center; /* Центрируем ссылки пагинации */
    margin-top: 30px; /* Увеличиваем отступ сверху */
    padding: 0; /* Убираем стандартные отступы списка */
    list-style: none; /* Убираем маркеры списка */
}

/* Стили для каждого элемента пагинации */
.page-item {
    margin: 0 4px; /* Небольшой отступ между элементами */
}

/* Стили для ссылок пагинации */
.page-link {
    display: block; /* Делаем ссылку блочным элементом, чтобы она заполняла li */
    padding: 10px 15px; /* Увеличиваем отступы для удобства нажатия */
    border: 1px solid #dee2e6; /* Более светлый цвет рамки */
    border-radius: 5px; /* Слегка скругленные углы */
    text-decoration: none;
    color: #427f01; /* Основной зеленый цвет текста */
    background-color: #fff; /* Белый фон */
    transition: all 0.3s ease; /* Плавные переходы для наведения/активного состояния */
    font-size: 0.95em; /* Немного уменьшенный размер шрифта */
    font-weight: 500; /* Средняя толщина шрифта */
    line-height: 1.2; /* Улучшаем выравнивание текста */
}

/* Стили для активной страницы */
.page-item.active .page-link {
    background-color: #427f01; /* Основной синий фон */
    border-color: #427f01; /* Соответствующий цвет рамки */
    color: white; /* Белый текст */
    box-shadow: 0 4px 8px rgba(0, 123, 255, 0.2); /* Легкая синяя тень */
    transform: translateY(-2px); /* Небольшой эффект поднятия */
}

/* Стили для ссылок при наведении */
.page-link:hover:not(.disabled) { /* Применяем эффект только если ссылка не отключена */
    background-color: #e9ecef; /* Светло-серый фон при наведении */
    border-color: #427f01; /* Темно-синяя рамка при наведении */
    color: #427f01; /* Темно-синий текст при наведении */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* Легкая тень при наведении */
}

/* Стили для отключенных (disabled) элементов */
.page-item.disabled .page-link {
    color: #6c757d; /* Серый текст */
    pointer-events: none; /* Отключаем события клика */
    background-color: #f8f9fa; /* Светлый фон */
    border-color: #dee2e6; /* Соответствующий цвет рамки */
    opacity: 0.7; /* Слегка прозрачный */
    cursor: not-allowed; /* Курсор "запрещено" */
    box-shadow: none; /* Убираем тень */
    transform: none; /* Убираем эффект поднятия */
}

/* Стили для "..." разделителя */
.page-item.disabled span.page-link {
    background-color: transparent; /* Прозрачный фон */
    border-color: transparent; /* Прозрачная рамка */
    color: #6c757d; /* Серый текст */
    padding: 10px 5px; /* Корректируем отступы для "..." */
    cursor: default; /* Стандартный курсор */
}


.pagination .step-links a,
.pagination .current {
    display: inline-block;
    padding: 8px 16px;
    margin: 0 5px;
    border: 1px solid #ddd;
    border-radius: 4px;
    text-decoration: none;
    color: #007bff;
}

.pagination .step-links a:hover {
    background-color: #f2f2f2;
}

.pagination .current {
    background-color: #007bff;
    color: white;
    border-color: #007bff;
    font-weight: bold;
}
/* Стили для 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 {
        padding: 10px 0px;

        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;
    }
}

/* --- Конец CSS файла --- */
