/**
 * Изображения с skeleton loader
 * Автоматически показывает skeleton пока изображение загружается
 */

.gc-image-wrapper {
    position: relative;
    overflow: hidden;
    display: inline-block;
    width: 100%;
}

/* Скелетон показывается пока изображение загружается */
.gc-image-wrapper .gc-skeleton {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    transition: opacity 0.3s ease;
}

/* Само изображение */
.gc-image-wrapper img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.3s ease;
    position: relative;
    z-index: 2;
}

/* Пока изображение не загружено */
.gc-image-wrapper.loading img {
    opacity: 0;
}

.gc-image-wrapper.loading .gc-skeleton {
    opacity: 1;
}

/* Когда изображение загружено */
.gc-image-wrapper.loaded .gc-skeleton {
    opacity: 0;
    pointer-events: none;
}

.gc-image-wrapper.loaded img {
    opacity: 1;
}

/* Варианты для разных пропорций */

/* Аватар - круглый */
.gc-image-wrapper-avatar {
    border-radius: 50%;
    aspect-ratio: 1 / 1;
}

.gc-image-wrapper-avatar .gc-skeleton {
    border-radius: 50%;
}

.gc-image-wrapper-avatar img {
    border-radius: 50%;
}

/* Обложка - 3:1 */
.gc-image-wrapper-cover {
    border-radius: var(--radius-lg);
    aspect-ratio: 3 / 1;
}

.gc-image-wrapper-cover .gc-skeleton {
    border-radius: var(--radius-lg);
}

.gc-image-wrapper-cover img {
    border-radius: var(--radius-lg);
}

/* Оружие - 4:3 */
.gc-image-wrapper-weapon {
    border-radius: var(--radius-lg);
    aspect-ratio: 4 / 3;
}

.gc-image-wrapper-weapon .gc-skeleton {
    border-radius: var(--radius-lg);
}

.gc-image-wrapper-weapon img {
    border-radius: var(--radius-lg);
}

/* Квадрат - 1:1 */
.gc-image-wrapper-square {
    border-radius: var(--radius-md);
    aspect-ratio: 1 / 1;
}

.gc-image-wrapper-square .gc-skeleton {
    border-radius: var(--radius-md);
}

.gc-image-wrapper-square img {
    border-radius: var(--radius-md);
}

/* 16:9 - для event covers */
.gc-image-wrapper-16-9 {
    border-radius: var(--radius-lg);
    aspect-ratio: 16 / 9;
}

.gc-image-wrapper-16-9 .gc-skeleton {
    border-radius: var(--radius-lg);
}

.gc-image-wrapper-16-9 img {
    border-radius: var(--radius-lg);
}

/* Размеры для аватаров */
.gc-image-wrapper-avatar-sm {
    width: 32px;
    height: 32px;
}

.gc-image-wrapper-avatar-md {
    width: 48px;
    height: 48px;
}

.gc-image-wrapper-avatar-lg {
    width: 64px;
    height: 64px;
}

.gc-image-wrapper-avatar-xl {
    width: 96px;
    height: 96px;
}

.gc-image-wrapper-avatar-2xl {
    width: 128px;
    height: 128px;
}

/* При ошибке загрузки */
.gc-image-wrapper.error .gc-skeleton {
    opacity: 0.3;
    animation: none;
}

.gc-image-wrapper.error img {
    opacity: 0.5;
}
