/* Оптимизированный group_header.css */

/* CSS кастомные свойства для лучшего performance и maintainability */
:root {
    --group-avatar-size: 150px;
    --group-border-radius: 12px;
    --group-avatar-border-radius: 50px;
    --group-shadow: 0 6px 12px rgba(0, 0, 0, 0.06);
    --group-gap: 1rem;
    --group-gap-sm: 0.5rem;
    --transition-fast: 150ms ease-out;
}

/* Основной контейнер - используем contain для оптимизации */
.group-header {
    background: var(--ig-surface, #fff);
    border-radius: var(--group-border-radius);
    margin-bottom: 1.25rem;
    contain: layout style;
    display: flex;
}

.group-header__inner {
    display: flex;
    gap: var(--group-gap);
}

/* Левая секция - оптимизировано для flexbox */
.group-header__left {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--group-gap-sm);
    padding: var(--group-gap);
}

/* Аватар - оптимизация изображений */
.group-avatar {
    width: var(--group-avatar-size);
    height: var(--group-avatar-size);
    border-radius: var(--group-avatar-border-radius);
    object-fit: cover;
    display: block;
    margin-bottom: 0.625rem;
    box-shadow: var(--group-shadow);
    border: 1px solid var(--ig-border, #e6e6e6);
    /* GPU ускорение для трансформаций */
    will-change: transform;
    transition: transform var(--transition-fast);
}

.group-avatar:hover {
    transform: scale(1.02);
}

/* Placeholder аватар - используем flexbox вместо inline-flex */
.group-avatar--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #f3f4f6, #e9ecef);
    color: var(--ig-primary, #111);
    font-weight: 700;
    font-size: clamp(1.5rem, 4vw, 2rem); /* Адаптивный размер шрифта */
}

.group-avatar__letter {
    line-height: 1;
}

/* Центральная секция */
/* справа от .group-header__left */
.group-header__center {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.group-title {
    margin: 0;
    font-size: clamp(1.25rem, 3vw, 1.6rem);
    line-height: 1.1;
    color: var(--ig-primary, #111);
    font-weight: 700;
    /* Оптимизация рендеринга текста */
    text-rendering: optimizeLegibility;
    font-display: swap;
}

.group-subtitle {
    margin: 0.25rem 0 0;
    color: var(--ig-secondary, #666);
    font-size: 0.95rem;
}

.group-description {
    margin: 0.5rem 0 0;
    color: var(--ig-secondary, #555);
    font-size: 0.95rem;
    line-height: 1.4;
}

/* Метаинформация */
.group-meta {
    display: flex;
    gap: 0.75rem;
    margin-top: 0.5rem;
    flex-wrap: wrap;
}

.group-meta__item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--ig-secondary, #666);
    font-size: 0.85rem;
}

/* Оптимизация SVG иконок */
.meta-icon {
    width: 16px;
    height: 16px;
    fill: currentColor;
    opacity: 0.7;
    flex-shrink: 0; /* Предотвращаем сжатие иконок */
}

/* Кнопки */
.group-header__left-buttons {
    display: flex;
    flex-direction: column;
    gap: var(--group-gap-sm);
    margin-top: var(--group-gap-sm);
}

.btn-join {
    padding: 0.5rem 0.75rem;
    border-radius: 0.625rem;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--group-gap-sm);
    font-size: 0.9rem;
    border: none;
    transition: all var(--transition-fast);
    text-decoration: none;
    /* GPU ускорение для hover эффектов */
    will-change: background-color, transform;
}

.btn-join:hover {
    transform: translateY(-1px);
}

.btn-primary.btn-join {
    background: var(--ig-primary, #0b5ed7);
    color: #fff;
}

.btn-primary.btn-join:hover {
    background: color-mix(in srgb, var(--ig-primary, #0b5ed7) 90%, black);
}

.btn-light.btn-join {
    background: var(--ig-surface, #fff);
    color: var(--ig-primary, #111);
    border: 1px solid var(--ig-border, #ddd);
}

.btn-light.btn-join:hover {
    background: color-mix(in srgb, var(--ig-surface, #fff) 95%, black);
}

.additional-text {
    font-size: 0.85rem;
}

/* Кнопка редактирования */
.group-edit-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--ig-surface, #fff);
    border: 1px solid var(--ig-border, #e6e6e6);
    color: var(--ig-secondary, #666);
    transition: all var(--transition-fast);
    margin-top: var(--group-gap-sm);
    text-decoration: none;
}

.group-edit-btn:hover {
    background: var(--ig-primary, #0b5ed7);
    color: #fff;
    transform: scale(1.1);
}

/* Expandable content */
.expandable-content {
    line-height: 1.4;
}

.group-header__center a {
    color: var(--color-link);
    -webkit-font-smoothing: subpixel-antialiased;
    cursor: pointer;
    background-image: linear-gradient(transparent calc(100% - 2px), var(--color-link-hover) 2px);
    background-size: 0% 100%;
    background-repeat: no-repeat;
    background-position: 0 0;
    animation: multiline-flow 2s infinite;
    text-decoration: none;
    font-weight: 600;
}

.group-header__center a:hover {
    color: var(--color-link-hover, color-mix(in srgb, var(--ig-primary, #0b5ed7) 80%, black));
    background-size: 100% 2px;
}

.content-full {
    margin-bottom: 0.625rem;
}

.truncated-text {
    display: inline;
}

/* Форма членства */
.membership-form {
    margin: 0;
}

/* Responsive - мобильная оптимизация */
@media (max-width: 768px) {
    :root {
        --group-avatar-size: 120px;
        --group-gap: 0.75rem;
    }

    .group-header__inner {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: var(--group-gap);
    }

    .group-header__left {
        align-items: center;
    }

    .group-avatar {
        margin: 0 0 0.625rem 0;
    }

    .group-avatar--placeholder {
        font-size: clamp(1.25rem, 6vw, 1.75rem);
    }

    .group-header__left-buttons {
        justify-content: center;
        flex-wrap: wrap;
    }

    .btn-join {
        min-width: 120px;
    }

    .group-title {
        font-size: clamp(1.1rem, 4vw, 1.4rem);
    }
}

/* Очень маленькие экраны */
@media (max-width: 480px) {
    :root {
        --group-avatar-size: 100px;
        --group-gap: 0.5rem;
    }

    .group-header {
        margin-bottom: 1rem;
    }

    .btn-join {
        padding: 0.5rem;
        font-size: 0.85rem;
        min-width: 100px;
    }
}

/* Preference медиа-запросы для accessibility */
@media (prefers-reduced-motion: reduce) {
    .group-avatar,
    .btn-join,
    .group-edit-btn,
    .group-header__center a {
        transition: none;
    }

    .group-avatar:hover,
    .btn-join:hover,
    .group-edit-btn:hover {
        transform: none;
    }
}

/* Темная тема */
@media (prefers-color-scheme: dark) {
    .group-avatar--placeholder {
        background: linear-gradient(135deg, #374151, #4b5563);
        color: #f9fafb;
    }
}

/* Высококонтрастный режим */
@media (forced-colors: active) {
    .group-avatar {
        border: 2px solid;
    }

    .btn-join {
        border: 1px solid;
    }
}