/* Import shared utilities to avoid duplication */
@import url('shared-utilities.css');

/* Стили для статуса доступности товара */
.availability-badge {
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
}

.availability-badge:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.availability-badge.available {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(34, 197, 94, 0.1) 100%);
    border-color: rgba(34, 197, 94, 0.4);
}

.availability-badge.unavailable {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.2) 0%, rgba(239, 68, 68, 0.1) 100%);
    border-color: rgba(239, 68, 68, 0.4);
}

.availability-status-dot {
    box-shadow: 0 0 10px currentColor;
    animation: pulse-glow 2s infinite;
}

@keyframes pulse-glow {
    0%, 100% {
        opacity: 1;
        box-shadow: 0 0 5px currentColor;
    }
    50% {
        opacity: 0.8;
        box-shadow: 0 0 15px currentColor;
    }
}

/* Улучшенные стили для атрибутов товара */
.attribute-option {
    /* Минимальная высота для мобильных устройств (44px - рекомендация Apple) */
    min-height: 44px;
    /* Оптимальная высота для desktop */
    height: auto;
    /* Smooth transitions */
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    /* Backdrop blur для эффекта стекла */
    backdrop-filter: blur(4px);
    /* Поддержка touch devices */
    -webkit-tap-highlight-color: transparent;
    /* Улучшенная типографика */
    font-weight: 500;
    letter-spacing: -0.01em;
    /* Улучшенное отображение длинных названий */
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Контейнер для текста внутри кнопки */
.attribute-option span {
    /* Для длинных названий - перенос слов */
    word-break: break-word;
    hyphens: auto;
}

.attribute-option:hover {
    /* Более плавный hover эффект */
    transform: translateY(-1px) scale(1.02);
    box-shadow: 0 4px 12px rgba(225, 247, 251, 0.1);
}

.attribute-option:active {
    /* Feedback при нажатии */
    transform: translateY(0) scale(0.98);
    transition: all 0.1s ease;
}

.attribute-option.ring-2 {
    /* Выбранный атрибут */
    ring-color: rgba(225, 247, 251, 0.6);
    background: linear-gradient(135deg, rgba(225, 247, 251, 0.15) 0%, rgba(225, 247, 251, 0.05) 100%);
    border-color: rgba(225, 247, 251, 0.6);
    box-shadow: 0 0 20px rgba(225, 247, 251, 0.2);
}

/* Компактные кнопки для list режима */
.flavor-grid.list-view .flavor-item {
    /* Минимальная высота для мобильных остается */
    min-height: 36px;
    /* Компактный padding */
    padding: 6px 12px;
    /* Адаптивный размер текста */
    font-size: 0.75rem;
    line-height: 1.25;
    /* Авто-ширина по содержимому */
    width: auto;
    white-space: nowrap;
}

/* Улучшенный поиск */
.flavor-search {
    backdrop-filter: blur(8px);
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.flavor-search:focus {
    backdrop-filter: blur(12px);
    box-shadow: 
        inset 0 2px 4px rgba(0, 0, 0, 0.1),
        0 0 0 2px rgba(225, 247, 251, 0.5);
}

/* Анимации для поиска */
.search-result-message {
    /* Используем общую анимацию из shared-utilities.css */
    animation: fadeInUp 0.3s ease-out;
}

/* Note: @keyframes fadeInUp moved to shared-utilities.css to avoid duplication */

/* Улучшения для кнопки добавления в корзину */
.add-to-cart-btn-disabled {
    background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%);
    cursor: not-allowed;
    position: relative;
    overflow: hidden;
}

.add-to-cart-btn-disabled::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    transition: left 0.5s;
}

.add-to-cart-btn-disabled:hover::before {
    left: 100%;
}

/* Стили для блока цены с индикатором наличия */
.price-block .flex {
    align-items: flex-start;
    gap: 1rem;
}

/* Responsive improvements */
@media (max-width: 768px) {
    .availability-badge {
        padding: 6px 10px;
        font-size: 0.75rem;
    }
    
    .availability-status-dot {
        width: 6px;
        height: 6px;
    }
    
    /* На мобильных делаем кнопки атрибутов немного крупнее */
    .attribute-option {
        min-height: 48px;
        padding: 8px 12px;
        font-size: 0.875rem;
    }
    
    /* Компактный list режим на мобильных */
    .flavor-grid.list-view .flavor-item {
        min-height: 40px;
        padding: 8px 12px;
        font-size: 0.8rem;
    }
    
    /* Поиск на полную ширину на мобильных */
    .flavor-search {
        width: 100% !important;
    }
    
    /* На мобильных располагаем цену и статус вертикально */
    .price-block .flex {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }
    
    /* Цена занимает всю ширину на мобильных */
    .price-block #product-price {
        font-size: 1.75rem;
    }
}

@media (max-width: 480px) {
    .availability-badge {
        padding: 4px 8px;
        font-size: 0.7rem;
    }
    
    .availability-status-dot {
        width: 5px;
        height: 5px;
    }
    
    /* Очень маленькие экраны - максимальная компактность */
    .flavor-grid.list-view .flavor-item {
        min-height: 36px;
        padding: 6px 10px;
        font-size: 0.75rem;
    }
    
    /* На очень маленьких экранах - одна колонка */
    .flavor-grid.grid-view .flavor-container {
        grid-template-columns: repeat(1, 1fr);
    }
    
    /* Увеличиваем высоту для длинных названий */
    .flavor-grid.grid-view .flavor-item {
        min-height: 60px;
        height: auto;
    }
}

/* Дополнительные улучшения для больших экранов */
@media (min-width: 768px) {
    /* На средних экранах увеличиваем высоту для длинных названий */
    .flavor-grid.grid-view .flavor-item {
        min-height: 70px;
    }
}

@media (min-width: 1024px) {
    .flavor-grid.grid-view .flavor-container {
        grid-template-columns: repeat(5, 1fr);
    }
    
    /* На больших экранах делаем кнопки выше */
    .flavor-grid.grid-view .flavor-item {
        min-height: 80px;
    }
}

@media (min-width: 1280px) {
    .flavor-grid.grid-view .flavor-container {
        grid-template-columns: repeat(6, 1fr);
    }
}

@media (max-width: 639px) {
    .flavor-controls {
        flex-wrap: nowrap;
    }
} 