/* ═══════════════════════════════════════════════
   GEO CATALOG — styles .geo-nav__dropdown hr
   /css/geo/style.css
   ═══════════════════════════════════════════════ */

/* ── Змінні ─────────────────────────────────── */
:root {
    --geo-accent:     #e05a2b;
    --geo-accent-2:   #f07a4b;
    --geo-dark:       #1a1a2e;
    --geo-mid:        #2d2d44;
    --geo-light:      #f7f5f2;
    --geo-border:     #e0dbd4;
    --geo-text:       #222;
    --geo-muted:      #888;
    --geo-white:      #ffffff;
    --geo-shadow:     0 4px 24px rgba(0,0,0,0.10);
    --geo-shadow-lg:  0 8px 40px rgba(0,0,0,0.16);
    --geo-radius:     10px;
    --geo-radius-sm:  6px;
}

/* ═══════════════════════════════════════════════
   TOPBAR VIEWER BUTTON
   (потрібно поза медіа-запитом — працює і на десктопі і мобілці)
   ═══════════════════════════════════════════════ */
.topbar-viewer {
    display: inline-block;
    background: #e91e63;
    color: #fff !important;
    font-size: 13px;
    font-weight: 700;
    padding: 7px 14px;
    border-radius: 20px;
    text-decoration: none !important;
    white-space: nowrap;
    line-height: 1;
}
.mobile-top-bar .logo a {
    color: inherit;
    text-decoration: none;
}

/* ═══════════════════════════════════════════════
   ХЛІБНІ КРИХТИ З ВИПАДАЮЧИМ МЕНЮ
   ═══════════════════════════════════════════════ */

.geo-nav {
    display: block;
    margin-bottom: 28px;
    padding: 14px 18px;
    background: var(--geo-white);
    border-radius: var(--geo-radius);
    box-shadow: var(--geo-shadow);
    border: 1px solid var(--geo-border);
    position: relative;
    z-index: 100;
}

.geo-nav__scroll {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 4px;
    overflow: visible;
}

.geo-nav__crumb {
    display: flex;
    align-items: center;
    gap: 4px;
    position: relative;
}

.geo-nav__sep {
    color: var(--geo-muted);
    font-size: 14px;
    padding: 0 2px;
    user-select: none;
}

.geo-nav__link {
    color: var(--geo-accent);
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.01em;
    padding: 4px 6px;
    border-radius: var(--geo-radius-sm);
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
}
.geo-nav__link:hover {
    background: rgba(224,90,43,0.08);
    color: #b03a10;
}

.geo-nav__current {
    font-size: 14px;
    font-weight: 700;
    color: var(--geo-text);
    padding: 4px 6px;
    white-space: nowrap;
}

.geo-nav__drop-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background: #888;               /* сірий */
	font-weight: 900;
    color: #fff;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-size: 13px;
    line-height: 1;
    transition: background 0.18s, transform 0.18s;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}
.geo-nav__drop-btn:hover { background: #666; }
.geo-nav__drop-btn.open  { background: #444; transform: rotate(180deg); }

.geo-nav__dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 220px;
    max-width: 320px;
    max-height: 320px;
    overflow-y: auto;
    background: var(--geo-white);
    border: 1px solid var(--geo-border);
    border-radius: var(--geo-radius);
    box-shadow: var(--geo-shadow-lg);
    z-index: 500;
    padding: 6px 0;
    animation: geoDropIn 0.18s ease;
}
.geo-nav__dropdown.open { display: block; }

@keyframes geoDropIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.geo-nav__dropdown::-webkit-scrollbar { width: 4px; }
.geo-nav__dropdown::-webkit-scrollbar-track { background: transparent; }
.geo-nav__dropdown::-webkit-scrollbar-thumb { background: var(--geo-border); border-radius: 2px; }

.geo-nav__dropdown a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 16px;
    font-size: 13px;
    color: var(--geo-text);
    text-decoration: none;
    transition: background 0.12s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.geo-nav__dropdown a:hover {
    background: var(--geo-light);
    color: var(--geo-accent);
}
.geo-nav__dropdown a.active {
    background: rgba(224,90,43,0.08);
    color: var(--geo-accent);
    font-weight: 600;
}

.geo-nav__dropdown a .geo-kind {
    font-size: 10px;
    background: var(--geo-light);
    border: 1px solid var(--geo-border);
    border-radius: 3px;
    padding: 1px 4px;
    color: var(--geo-muted);
    flex-shrink: 0;
}

.geo-nav__dropdown-group {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--geo-muted);
    padding: 10px 16px 4px;
}

.geo-nav__dropdown hr {
    border: none;
    border-top: 1px solid var(--geo-border);
    margin: 4px 0;
}

.geo-nav__hint {
    font-size: 14px;
    color: var(--geo-muted);
    font-style: italic;
    padding: 4px 6px;
    white-space: nowrap;
}
.geo-nav__drop-btn--hint {
    width: auto;
    height: auto;
    border-radius: 20px;
    background: #f0f0f0;
    color: #555;
    font-size: 13px;
    font-weight: 500;
    padding: 4px 10px;
    font-style: italic;
}
.geo-nav__drop-btn--hint:hover {
    background: #e0e0e0;
    color: #222;
}
/* ═══════════════════════════════════════════════
   БАНЕР ЗНАЙОМСТВ
   ═══════════════════════════════════════════════ */

.geo-dating-banner {
    background: linear-gradient(135deg, var(--geo-dark) 0%, var(--geo-mid) 100%);
    border-radius: var(--geo-radius);
    padding: 24px 28px;
    margin-bottom: 28px;
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
    box-shadow: var(--geo-shadow);
}

.geo-dating-banner__title {
    color: #fff;
    font-size: 17px;
    font-weight: 700;
    flex: 1;
    min-width: 160px;
}

.geo-dating-banner__count {
    color: rgba(255,255,255,0.7);
    font-size: 13px;
}
.geo-dating-banner__count strong {
    color: var(--geo-accent-2);
    font-size: 16px;
}

.geo-dating-banner__links {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════
   КНОПКИ ЗНАЙОМСТВ
   ═══════════════════════════════════════════════ */

.geo-dating-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: transform 0.15s, box-shadow 0.15s, filter 0.15s;
    white-space: nowrap;
}
.geo-dating-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.2);
    filter: brightness(1.08);
}
.geo-dating-btn--women { background: #e8437a; color: #fff; }
.geo-dating-btn--men   { background: #2a7de1; color: #fff; }

/* ═══════════════════════════════════════════════
   СПИСОК ДОЧІРНІХ МІСЦЬ
   ═══════════════════════════════════════════════ */

.geo-children {
    background: var(--geo-white);
    border-radius: var(--geo-radius);
    padding: 24px 28px;
    box-shadow: var(--geo-shadow);
    border: 1px solid var(--geo-border);
}

.geo-children h2 {
    font-size: 16px;
    font-weight: 700;
    color: var(--geo-text);
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--geo-light);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.geo-children__list {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 6px;
}

.geo-children__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 12px;
    border-radius: var(--geo-radius-sm);
    transition: background 0.12s;
}
.geo-children__item:hover { background: var(--geo-light); }

.geo-children__name {
    color: var(--geo-text);
    text-decoration: none;
    font-size: 14px;
    flex: 1;
    transition: color 0.12s;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.geo-children__name:hover { color: var(--geo-accent); }

.geo-children__dating {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}
.geo-children__dating a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    font-size: 12px;
    text-decoration: none;
    transition: transform 0.15s;
}
.geo-children__dating a:first-child {
    background: rgba(232,67,122,0.12);
    color: #e8437a;
}
.geo-children__dating a:last-child {
    background: rgba(42,125,225,0.12);
    color: #2a7de1;
}
.geo-children__dating a:hover { transform: scale(1.2); }

/* ═══════════════════════════════════════════════
   H1 ЗАГОЛОВОК
   ═══════════════════════════════════════════════ */

.geo-page-title {
    font-size: 28px;
    font-weight: 800;
    color: var(--geo-text);
    margin-bottom: 20px;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

/* ═══════════════════════════════════════════════
   ГЕРБ МІСТА
   ═══════════════════════════════════════════════ */

.heraldry {
    float: left;
    margin: 0 20px 16px 0;
    padding: 10px;
    background: var(--geo-white);
    border: 1px solid var(--geo-border);
    border-radius: var(--geo-radius);
    box-shadow: var(--geo-shadow);
    line-height: 0;
}

.heraldry img {
    width: 120px;
    height: 120px;
    object-fit: contain;
    display: block;
}

@media (max-width: 480px) {
    .heraldry {
        float: none;
        display: flex;
        justify-content: center;
        margin: 0 0 16px 0;
    }
}

/* ═══════════════════════════════════════════════
   MOBILE  ≤ 1024px
   ═══════════════════════════════════════════════ */

@media (max-width: 1024px) {

    .geo-nav {
        border-radius: 0;
        border-left: none;
        border-right: none;
        padding: 10px 12px;
        margin-bottom: 12px;
        overflow: visible;
    }

    .geo-nav__scroll {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        gap: 4px;
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 2px;
        width: 100%;
    }
    .geo-nav__scroll::-webkit-scrollbar { display: none; }

    .geo-nav__link,
    .geo-nav__current { font-size: 15px; padding: 4px 4px; white-space: nowrap; }
    .geo-nav__sep { font-size: 13px; padding: 0 1px; flex-shrink: 0; }
    .geo-nav__drop-btn { width: 26px; height: 26px; font-size: 12px; flex-shrink: 0; }

    /* Дропдаун — просто фіксований відносно кнопки, не повноекранний */
    .geo-nav__dropdown {
        position: fixed !important;
        /* top — встановлюється через JS */
        left: 8px !important;
        right: 8px !important;
        width: auto !important;
        max-width: none !important;
        max-height: 60vh !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
        z-index: 9999 !important;
        border-radius: 10px !important;
        border: 1px solid var(--geo-border) !important;
        background: #fff !important;
        box-shadow: 0 8px 32px rgba(0,0,0,0.18) !important;
        padding: 6px 0 !important;
    }

    .geo-nav__dropdown-group {
        color: var(--geo-muted) !important;
        font-size: 11px;
        padding: 8px 16px 4px;
    }

    .geo-nav__dropdown a {
        color: var(--geo-text) !important;
        font-size: 16px !important;
        padding: 13px 16px !important;
        border-bottom: 1px solid var(--geo-border) !important;
        white-space: normal !important;
    }
    .geo-nav__dropdown a:last-child { border-bottom: none !important; }
    .geo-nav__dropdown a:hover { background: var(--geo-light) !important; }
    .geo-nav__dropdown a.active {
        background: rgba(224,90,43,0.08) !important;
        color: var(--geo-accent) !important;
        font-weight: 700 !important;
    }

    .geo-page-title { font-size: 22px; margin-bottom: 12px; padding: 0 12px; }

    .geo-dating-btn {
        flex: 1; justify-content: center;
        padding: 13px 14px; font-size: 15px; font-weight: 700; border-radius: 30px;
    }

    .geo-children {
        border-radius: 0; border-left: none; border-right: none;
        padding: 16px 12px; box-shadow: none;
        border-top: 1px solid var(--geo-border);
        border-bottom: 1px solid var(--geo-border);
    }
    .geo-children h2 { font-size: 13px; margin-bottom: 12px; padding-bottom: 8px; }
    .geo-children__list { grid-template-columns: 1fr 1fr; gap: 4px; }
    .geo-children__item { padding: 9px 6px; }
    .geo-children__name { font-size: 15px; }
    .geo-children__dating a { width: 34px; height: 34px; font-size: 15px; }

}

@media (max-width: 480px) {
    .geo-children__list { grid-template-columns: 1fr; }
    .geo-page-title { font-size: 20px; }
}