/**
 * Поисковые компоненты
 * Стили для поля поиска и подсказок
 */

/* Контейнер поиска */
.gc-search-container {
    position: relative;
    z-index: 100; /* Выше карточек, но ниже navbar */
}

/* ─── Паттерн 1: обёртка «инпут + кнопка» (статичная кнопка рядом) ──────────
   Контейнер сам является визуальным «полем» — border + border-radius.
   Используй вместе с .gc-input и .gc-search-button внутри.              */
.gc-search-input-wrapper {
    display: flex;
    align-items: stretch;
    box-sizing: border-box;
    /* Внешняя капа = одиночный .gc-input (40px): бордер входит в высоту, иначе +2px к «полю» */
    height: var(--spacing-1-5xl);
    min-height: var(--spacing-1-5xl);
    border: 1px solid var(--ui-border);
    border-radius: var(--radius-field);
    overflow: hidden;
    background: var(--ui-field-bg);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.gc-search-input-wrapper:focus-within {
    border-color: var(--accent-link);
    box-shadow: 0 0 0 3px var(--ui-focus-ring);
}

/* Ошибка валидации на вложенном .gc-input (бордер у поля снят — подсвечиваем оболочку) */
.gc-search-input-wrapper:has(.gc-input.is-invalid) {
    border-color: var(--danger-color);
    box-shadow: 0 0 0 3px rgba(var(--danger-color-rgb), 0.15);
}

.gc-search-input-wrapper:has(.gc-input.is-invalid):focus-within {
    border-color: var(--danger-color);
    box-shadow: 0 0 0 3px rgba(var(--danger-color-rgb), 0.15);
}

/* Сегмент удаления в составном поле (опции опроса и т.п.) */
.gc-search-input-wrapper .gc-search-button.poll-option-remove:hover {
    color: var(--danger-color);
    background-color: var(--ui-danger-soft);
}

/* Поле внутри обёртки: только .gc-input (см. комментарий выше).
   Если ошибочно добавили .gc-search-input (паттерн с абсолютной кнопкой) — сбрасываем его
   высоту и отступы, чтобы не получить 48px и лишний padding справа. */
.gc-search-input-wrapper .gc-input,
.gc-search-input-wrapper .gc-search-input {
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    flex: 1;
    min-width: 0;
    min-height: 0;
    height: 100%;
    padding: 0 var(--spacing-mdl);
}

/* Сбрасываем hover/focus — визуальные состояния теперь на wrapper */
.gc-search-input-wrapper .gc-input:hover,
.gc-search-input-wrapper .gc-input:focus,
.gc-search-input-wrapper .gc-search-input:hover,
.gc-search-input-wrapper .gc-search-input:focus {
    border: none;
    box-shadow: none;
    background: transparent;
    outline: none;
}

/* Readonly внутри wrapper — без disabled-вида (opacity, cursor, color) */
.gc-search-input-wrapper .gc-input[readonly],
.gc-search-input-wrapper .gc-search-input[readonly] {
    opacity: 1;
    cursor: default;
    color: var(--font-primary);
    background: transparent;
}

/* Кнопка внутри обёртки: статичная, нейтральная */
.gc-search-input-wrapper .gc-search-button {
    position: static;
    transform: none;
    height: auto;
    width: auto;
    min-width: 40px;
    background: transparent;
    color: var(--font-secondary);
    border: none;
    border-left: 1px solid var(--ui-border);
    border-radius: 0;
}

.gc-search-input-wrapper .gc-search-button:hover {
    background: var(--ui-surface-2);
    color: var(--font-primary);
    transform: none;
}

.gc-search-input-wrapper .gc-search-button:active {
    background: var(--ui-surface-3);
    transform: none;
}

/* Поле ввода поиска */
.gc-search-input {
    width: 100%;
    height: 48px;
    background-color: var(--ui-field-bg);
    border: 1px solid var(--ui-border);
    border-radius: var(--radius-field);
    color: var(--font-primary);
    padding: 0 48px 0 16px;
    font-size: var(--font-size-mdl);
    transition: all 0.3s ease;
}

.gc-search-input:hover {
    border-color: var(--ui-border-strong);
}

.gc-search-input:focus {
    outline: none;
    border-color: var(--accent-link);
    box-shadow: 0 0 0 3px var(--ui-focus-ring);
}

/* ─── Паттерн 2: абсолютная кнопка поиска (внутри .gc-search-input) ─────────
   Позиционируется поверх инпута справа. Используется на страницах поиска.   */
.gc-search-button {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background-color: var(--accent-link);
    color: white;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background-color var(--transition-fast);
}

/* Только смена цвета — без scale, чтобы кнопка не выходила за границу инпута */
.gc-search-button:hover {
    background-color: var(--accent-link-hover, #e04a20);
    transform: translateY(-50%);
}

.gc-search-button:active {
    background-color: var(--accent-link-hover, #e04a20);
    transform: translateY(-50%);
}

/* Контейнер для результатов поиска */
.gc-search-results {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    background-color: var(--ui-surface-1);
    border-radius: var(--radius-field);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    z-index: 1051;
    max-height: 400px;
    overflow-y: auto;
    border: 1px solid var(--ui-border);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    backdrop-filter: blur(10px);
}

.gc-search-results.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Результат поиска */
.gc-search-result {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm); /* 12px - отступ между аватаром и контентом */
    padding: var(--spacing-mdl) var(--spacing-sm); /* 12px 8px для компактности */
    border-bottom: 1px solid var(--border-secondary);
    text-decoration: none;
    transition: all 0.15s ease;
}

.gc-search-result:last-child {
    border-bottom: none;
}

.gc-search-result:hover {
    background-color: var(--ui-hover-bg);
}

/* Изображение результата */
.gc-search-result-img {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    overflow: hidden;
    flex-shrink: 0;
    background-color: var(--ui-surface-2);
}

.gc-search-result-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Стиль для иконки (когда нет изображения) */
.gc-search-result-icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--ui-surface-2);
    border-radius: var(--radius-md);
    color: var(--font-secondary);
}

/* Информация результата */
.gc-search-result-info {
    flex-grow: 1;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xs); /* 3px - отступ между заголовком и деталями */
}

.gc-search-result-title {
    font-size: var(--font-size-mdl); /* 14px */
    font-weight: 600;
    color: var(--font-primary);
    margin: 0; /* Сброс margin */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.gc-search-result-details {
    font-size: var(--font-size-sm); /* 14px */
    color: var(--font-secondary);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs); /* 4px - отступ между иконкой и текстом */
}

.gc-search-result-details i {
    font-size: var(--font-size-xs); /* 12px */
}

/* Все результаты */
.gc-search-all-results {
    display: block;
    padding: var(--spacing-mdl); /* 12px */
    text-align: center;
    background-color: var(--bg-content-main);
    color: var(--accent-link);
    text-decoration: none;
    font-weight: 500;
    font-size: var(--font-size-mdl); /* 14px */
    border-top: 1px solid var(--ui-border);
    transition: all 0.2s ease;
}

.gc-search-all-results:hover {
    background-color: var(--bg-content-secondary);
    color: var(--accent-link-hover, #e04a20);
}

.gc-search-all-results i {
    transition: transform 0.2s ease;
}

.gc-search-all-results:hover i {
    transform: translateX(3px);
}

/* Состояние загрузки */
.gc-search-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs); /* 12px - отступ между точками и текстом */
    padding: var(--spacing-lg); /* 24px */
    text-align: center;
}

/* Анимация точек загрузки */
.gc-search-loading-dots {
    display: flex;
    justify-content: center;
    gap: var(--spacing-2xs); /* 3px между точками */
}

.gc-search-loading-dots div {
    width: var(--spacing-sm); /* 8px */
    height: var(--spacing-sm); /* 8px */
    background-color: var(--accent-link, #F15A30);
    border-radius: 50%;
    animation: gc-search-dots-bounce 1.4s infinite ease-in-out both;
}

.gc-search-loading-dots div:nth-child(1) {
    animation-delay: -0.32s;
}

.gc-search-loading-dots div:nth-child(2) {
    animation-delay: -0.16s;
}

@keyframes gc-search-dots-bounce {
    0%, 80%, 100% {
        transform: scale(0);
        opacity: 0.5;
    }
    40% {
        transform: scale(1);
        opacity: 1;
    }
}

.gc-search-loading-text {
    font-size: var(--font-size-mdl); /* 14px */
    color: var(--font-secondary);
}

/* Пустые результаты */
.gc-search-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs); /* 12px - отступ между иконкой и текстом */
    padding: var(--spacing-lg) var(--spacing-md); /* 24px 16px */
    text-align: center;
}

.gc-search-empty-icon {
    font-size: var(--font-size-3xl); /* 30px */
    color: var(--font-secondary);
    opacity: 0.5;
}

.gc-search-empty-text {
    font-size: var(--font-size-mdl); /* 14px */
    color: var(--font-secondary);
    margin: 0; /* Сброс margin */
}

/* Адаптивность для мобильных */
@media (max-width: 576px) {
    .gc-search-input {
        height: 42px;
        font-size: var(--font-size-mdl); /* 14px */
    }
    
    .gc-search-button {
        width: 28px;
        height: 28px;
    }
    
    .gc-search-result {
        padding: var(--spacing-3sm) var(--spacing-mdl); /* 10px 12px */
    }
    
    .gc-search-result-img {
        width: 40px;
        height: 40px;
    }
    
    .gc-search-result-icon {
        width: 40px;
        height: 40px;
    }
    
    .gc-search-result-icon i {
        font-size: var(--font-size-lg) !important; /* 18px */
    }
}