﻿:root {
    --ukr-bg: #fff8dc; /* light yellow */
    --ukr-fg: #002551; /* Rich Navy */
    --ukr-accent: #8B0000;
}

.game-field {
    background: var(--ukr-bg) !important;
}

/* Reset external "card" around the article (hang on the parent) */
.ukr-frame-reset {
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Topic of the article */
.ukr-theme {
    background: var(--ukr-bg) !important;
    color: var(--ukr-fg) !important;
    padding: 16px;
    border-radius: 8px;
    margin: 0 !important;
}

    .ukr-theme * {
        background-color: transparent !important;
        color: var(--ukr-fg) !important;
    }

    .ukr-theme a {
        color: var(--ukr-fg) !important;
        text-decoration: underline;
        text-underline-offset: 2px;
    }

    .ukr-theme hr {
        border-color: var(--ukr-fg) !important;
        opacity: .4;
    }

    .ukr-theme .border {
        border-color: var(--ukr-fg) !important;
    }

    .ukr-theme blockquote {
        border-left: 4px solid var(--ukr-fg);
        padding-left: 12px;
    }

    .ukr-theme .btn, .ukr-theme button {
        background: var(--ukr-fg);
        color: var(--ukr-bg);
        border-color: var(--ukr-fg);
    }

        .ukr-theme .btn:hover, .ukr-theme button:hover {
            background: #002855;
            border-color: #002855;
        }

    .ukr-theme ::selection {
        background: #ffe27a;
        color: #002855;
    }

    /*Remove the "pads" from the inner containers */
    .ukr-theme .game-field,
    .ukr-theme .card,
    .ukr-theme .panel,
    .ukr-theme .container,
    .ukr-theme .content,
    .ukr-theme .row,
    .ukr-theme [class^="col-"] {
        background: transparent !important;
        box-shadow: none !important;
        border: 0 !important;
    }

/* Custom tooltip in flag colors */
.custom-tooltip {
    position: relative;
    display: inline-block;
}

    .custom-tooltip .tt {
        position: absolute;
        left: 50%;
        bottom: 100%;
        transform: translateX(-50%);
        background: var(--ukr-bg);
        color: var(--ukr-fg);
        border: 1px solid var(--ukr-fg);
        padding: 6px 10px;
        border-radius: 6px;
        white-space: nowrap;
        font-weight: 700;
        box-shadow: 0 2px 6px rgba(0,0,0,.15);
        opacity: 0;
        visibility: hidden;
        transition: opacity .2s;
        pointer-events: none;
        z-index: 10;
    }

    .custom-tooltip:hover .tt, .custom-tooltip:focus-within .tt {
        opacity: 1;
        visibility: visible;
    }

    .custom-tooltip .tt::before, .custom-tooltip .tt::after {
        content: "";
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%);
        border: 6px solid transparent;
    }

    .custom-tooltip .tt::before {
        border-top-color: var(--ukr-fg);
    }

    .custom-tooltip .tt::after {
        margin-top: -2px;
        border-top-color: var(--ukr-bg);
    }

.ukr-theme .scientific-link {
    color: #5DADE2 !important;
    font-weight: 600 !important;
    text-decoration: underline !important;
}

.ethnogenesis-table {
    --ethn-bg: #fff8dc;
    --ethn-fg: #002551;
    --ethn-accent: #8B0000;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background: var(--ethn-bg);
    color: var(--ethn-fg);
    margin: 0;
    padding: 20px;
}

.ethnogenesis-container {
    max-width: 1200px;
    margin: 0 auto;
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1);
    overflow: hidden;
}

.ethnogenesis-header {
    background: linear-gradient(135deg, var(--ethn-fg), #003366);
    color: white;
    padding: 30px;
    text-align: center;
}

    .ethnogenesis-header .ethn-subtitle {
        margin-top: 10px;
        font-size: 1.1em;
        opacity: 0.9;
    }

.ethnogenesis-table-container {
    padding: 30px;
    overflow-x: auto;
}

.ethnogenesis-data-table {
    width: 100%;
    border-collapse: collapse;
    background: white;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

    .ethnogenesis-data-table th {
        background: var(--ethn-fg);
        color: white;
        padding: 18px 15px;
        font-weight: 600;
        text-align: left;
        font-size: 0.95em;
    }

    .ethnogenesis-data-table td {
        padding: 18px 15px;
        border-bottom: 1px solid #eee;
        vertical-align: top;
        line-height: 1.5;
    }

    .ethnogenesis-data-table tr:hover {
        background: #f8f9ff;
    }

.ethn-period {
    font-weight: 600;
    color: var(--ethn-accent);
    white-space: nowrap;
}

.ethn-culture {
    font-weight: 700;
    color: var(--ethn-fg);
    font-size: 1.05em;
}

.ethn-contribution {
    font-size: 0.95em;
}

.ethn-genetic {
    background: linear-gradient(90deg, #e3f2fd, transparent);
    font-weight: 600;
    color: var(--ethn-accent);
}

.ethn-symbol {
    font-style: italic;
    color: #666;
}

.ethnogenesis-conclusion {
    margin-top: 30px;
    padding: 25px;
    background: linear-gradient(135deg, #f0f8ff, #fff8dc);
    border-left: 5px solid var(--ethn-fg);
    border-radius: 0 8px 8px 0;
}

    .ethnogenesis-conclusion h3 {
        margin: 0 0 15px 0;
        color: var(--ethn-fg);
        font-size: 1.3em;
    }

    .ethnogenesis-conclusion p {
        margin: 10px 0;
        font-size: 1.05em;
        line-height: 1.6;
    }

.ethn-key-point {
    background: var(--ethn-fg);
    color: white;
    padding: 15px 20px;
    border-radius: 8px;
    margin-top: 20px;
    font-weight: 600;
}

.ethn-emoji {
    font-size: 1.2em;
    margin-right: 8px;
}

@@media (max-width: 768px) {
    .ethnogenesis-container {
        margin: 10px;
        border-radius: 8px;
    }

    .ethnogenesis-header {
        padding: 20px;
    }

    .ethnogenesis-table-container {
        padding: 15px;
    }

    .ethnogenesis-data-table th, .ethnogenesis-data-table td {
        padding: 12px 8px;
        font-size: 0.9em;
    }
}

/*-------------------------------------------------*/

/* Карточка для изображений и информации */
.info-card {
    background-color: #fff8dc;
    padding: 15px;
    border-radius: 8px;
    text-align: center;
    margin-bottom: 1.5rem; /* Добавляем отступ снизу */
}

    /* Стиль для рамки изображений внутри карточки */
    .info-card img {
        border: 2px solid #003366;
    }

/* Отдельный стиль для рамки изображений Zmiyiv Ramparts */
.info-card--ramparts img {
    border: 2px solid #002551;
}

/* Стиль для подписей к фото внутри карточки */
.info-card__caption {
    color: #003366;
    font-weight: 600;
    margin-top: 10px;
}

/* Отдельный стиль для подписей Zmiyiv Ramparts */
.info-card__caption--ramparts {
    color: #002551;
}

/* Утилитарный класс для центрирования текста */
.text-center {
    text-align: center;
}

/*========================================================================*/
/* Объединенная и правильная версия */
.ethnogenesis-header h1 {
    margin: 0;
    font-size: 1.8em;
    font-weight: 700;
    color: #FFD700 !important;
}

/*=================================================================*/
/* --- ФИНАЛЬНЫЙ НАБОР УТИЛИТАРНЫХ КЛАССОВ --- */

/* Выравнивание */
.text-center {
    text-align: center;
}

/* Цвета */
.text-accent-red {
    color: #8B0000 !important;
}

.text-primary-blue {
    color: #002551 !important;
}

/* Шрифт */
.font-bold {
    font-weight: 600 !important;
}

.font-size-large {
    font-size: 1.1em;
}

.font-size-x-large {
    font-size: 1.2em;
}

/* Отступы */
.margin-top-small {
    margin-top: 10px;
}

/* --- СТИЛИ ДЛЯ КОНКРЕТНЫХ ЭЛЕМЕНТОВ --- */

.ukr-theme blockquote {
    border-left: 4px solid var(--ukr-accent);
    padding-left: 12px;
    font-weight: 600;
    color: var(--ukr-accent);
}

/* --- ИСПРАВЛЕНИЯ ДЛЯ ТАБЛИЦЫ ЭТНОГЕНЕЗА --- */

.ethnogenesis-header .ethn-subtitle {
    color: #FFD700 !important;
}

.ethnogenesis-data-table .ethn-culture--accent {
    color: var(--ethn-accent);
}

.ethnogenesis-data-table .ethn-contribution--important {
    font-weight: 600;
}
/*--------------------------------------------------------*/
/* --- ФИНАЛЬНОЕ ДОПОЛНЕНИЕ ДЛЯ УНИКАЛЬНЫХ СЛУЧАЕВ --- */

/* Для цитаты с синей рамкой */
.blockquote-blue {
    border-left: 4px solid #002551;
    padding-left: 12px;
    font-style: italic;
    margin: 20px 0;
}

/* Для выделенного жирным синего текста в параграфе */
.p-highlight {
    font-weight: 600;
    color: #002551;
}