/* static/css/main.css */

/* 1. Глобальные переменные и стили */
:root {
    --primary-color: #e67e22;      /* Яркий оранжевый акцент */
    --secondary-color: #34495e;    /* Темно-синий для текста и элементов */
    --background-color: #ecf0f1;   /* Очень светлый серо-голубой фон */
    --surface-color: #ffffff;      /* Белый для карточек и шапки */
    --border-color: #bdc3c7;       /* Мягкий серый для границ */
    --font-family: 'Exo 2', sans-serif; /* Технический, современный шрифт */
    --border-radius: 4px;
    --box-shadow: 0 5px 15px rgba(0, 0, 0, 0.07);
}

body {
    font-family: var(--font-family);
    background-color: var(--background-color);
    color: var(--secondary-color);
    /* --- ОБНОВЛЕННЫЙ ИНТЕРЕСНЫЙ ФОН --- */
    background-image: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23bdc3c7' fill-opacity='0.2'%3E%3Cpath fill-rule='evenodd' d='M11 0l5 5-6 6-5-5 6-6zM21 10l5 5-6 6-5-5 6-6zM31 20l5 5-6 6-5-5 6-6zM41 30l5 5-6 6-5-5 6-6zM51 40l5 5-6 6-5-5 6-6zM61 50l5 5-6 6-5-5 6-6zM71 60l5 5-6 6-5-5 6-6zM1 60l5 5-6 6-5-5 6-6zM11 70l5 5-6 6-5-5 6-6zM21 0l5 5-6 6-5-5 6-6zM31 10l5 5-6 6-5-5 6-6zM41 20l5 5-6 6-5-5 6-6zM51 30l5 5-6 6-5-5 6-6zM61 40l5 5-6 6-5-5 6-6zM71 50l5 5-6 6-5-5 6-6zM1 50l5 5-6 6-5-5 6-6zM11 60l5 5-6 6-5-5 6-6zM21 70l5 5-6 6-5-5 6-6zM31 0l5 5-6 6-5-5 6-6zM41 10l5 5-6 6-5-5 6-6zM51 20l5 5-6 6-5-5 6-6zM61 30l5 5-6 6-5-5 6-6zM71 40l5 5-6 6-5-5 6-6zM1 30l5 5-6 6-5-5 6-6zM11 40l5 5-6 6-5-5 6-6zM21 50l5 5-6 6-5-5 6-6zM31 60l5 5-6 6-5-5 6-6zM41 70l5 5-6 6-5-5 6-6zM51 0l5 5-6 6-5-5 6-6zM61 10l5 5-6 6-5-5 6-6zM71 20l5 5-6 6-5-5 6-6zM1 10l5 5-6 6-5-5 6-6zM11 20l5 5-6 6-5-5 6-6zM21 30l5 5-6 6-5-5 6-6zM31 40l5 5-6 6-5-5 6-6zM41 50l5 5-6 6-5-5 6-6zM51 60l5 5-6 6-5-5 6-6zM61 70l5 5-6 6-5-5 6-6z'/%3E%3C/g%3E%3C/svg%3E");
}

/* 2. Новая двухэтажная шапка */
.site-header-top {
    background-color: var(--secondary-color);
    color: #ecf0f1;
    font-size: 0.85rem;
    padding: 0.5rem 0;
}
.site-header-top a {
    color: #ecf0f1;
    text-decoration: none;
}
.site-header-top a:hover {
    color: var(--primary-color);
}

.site-header-main {
    background-color: var(--surface-color);
    box-shadow: var(--box-shadow);
}

.site-logo {
    font-weight: 700;
    font-size: 1.8rem;
    color: var(--secondary-color);
}
.site-logo:hover {
    color: var(--primary-color);
}
.main-nav .nav-link {
    font-weight: 600;
    color: var(--secondary-color);
    font-size: 1.1rem;
}
.main-nav .nav-link:hover {
    color: var(--primary-color);
}

/* 3. Карточки для категорий и товаров */
.blueprint-card {
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    transition: all 0.3s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.blueprint-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--box-shadow);
    border-color: var(--primary-color);
}
.card-header-icon {
    background-color: var(--secondary-color);
    color: var(--surface-color);
    padding: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.card-header-icon h5 {
    margin: 0;
    color: var(--surface-color);
}
.card-header-icon .fas {
    font-size: 1.5rem;
    opacity: 0.7;
}
.blueprint-card .card-body {
    padding: 1.5rem;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}
.product-price {
    font-size: 2rem;
    font-weight: 700;
    color: var(--secondary-color);
    margin: 1rem 0;
}

/* 4. Кнопки */
.btn-primary {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.btn-primary:hover {
    background-color: #d35400;
    border-color: #d35400;
}

/* 5. Подвал */
.site-footer {
    background-color: var(--secondary-color);
    color: #bdc3c7;
    padding: 3rem 0;
    margin-top: 4rem;
}
.site-footer h5 {
    color: var(--surface-color);
}
.site-footer a {
    color: #bdc3c7;
}
.site-footer a:hover {
    color: var(--primary-color);
}
/* 6. Новый стиль для карточек категорий (Вариант 3) */
.category-card {
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    /* Ключевой элемент дизайна - акцентная линия слева */
    border-left: 5px solid var(--secondary-color);
    border-radius: var(--border-radius);
    padding: 1.5rem 2rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: all 0.2s ease-in-out;
}

.category-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--box-shadow);
    /* При наведении меняем цвет акцентной линии */
    border-left-color: var(--primary-color);
}

.category-card-title {
    color: var(--secondary-color);
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0;
}

/* Стили для небольшого описания под названием */
.category-card-description {
    color: #7f8c8d; /* приглушенный текст */
    font-size: 0.9rem;
    margin-top: 0.5rem;
    flex-grow: 1; /* заставляет описание занимать доступное место */
}

/* 12. Стиль для акцентной ссылки в навигации */
.nav-link--bonus {
    color: #0d6efd !important; /* Яркий синий цвет */
    font-weight: 700;          /* Делаем шрифт жирнее, чтобы выделялся */

    /* 👇 НОВАЯ СТРОКА: добавляем плавность для эффекта */
    transition: transform 0.2s ease-in-out;
}

/* 👇 НОВЫЙ БЛОК: сам эффект увеличения при наведении */
.nav-link--bonus:hover {
    transform: scale(1.1); /* Увеличиваем на 10% */
}

.category-card-link {
    color: var(--secondary-color);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.8rem;
    letter-spacing: 1px;
    align-self: flex-end; /* прижимаем ссылку к правому краю */
    transition: color 0.2s ease;
}

.category-card:hover .category-card-link {
    color: var(--primary-color);
}


/* 7. Стили для карточек товаров */
.product-card-image-container {
    height: 200px; /* Фиксированная высота контейнера */
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden; /* Обрезаем выступающие части изображения */
    border-radius: var(--border-radius) var(--border-radius) 0 0; /* Скругляем верхние углы */
    background-color: #f8f9fa; /* Цвет фона на случай прозрачных изображений */
}

.product-card-image {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain; /* Вписываем изображение с сохранением пропорций */
}

.blueprint-card .card-body {
    padding: 1rem; /* Уменьшил отступы внутри карточки */
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

/* --- НОВЫЙ БЛОК --- */
/* Добавляем этот блок для выравнивания карточек по высоте */
.product-card-title {
    min-height: 2.6rem;
    margin-bottom: 0.5rem;
}

/* --- ИЗМЕНЕНИЕ ЗДЕСЬ --- */
/* Этот блок уже был, мы просто убеждаемся, что он выглядит так */
.product-card-title a {
    color: var(--secondary-color);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.3;

    /* Свойства для обрезки длинных названий */
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2; /* Ограничиваем до двух строк */
    -webkit-box-orient: vertical;
}

.product-card-title a:hover {
    color: var(--primary-color);
}

.product-price {
    font-size: 1.3rem; /* Уменьшил размер шрифта цены */
    font-weight: 700;
    color: var(--secondary-color);
    margin-top: 0.5rem;
    margin-bottom: 0;
}

/* 8. Стили для формы добавления в корзину в карточке товара */
.blueprint-card .card-body form {
    display: flex;
    justify-content: space-between;
}

.blueprint-card .card-body form select {
    max-width: 70px; /* Ограничиваем ширину поля для количества */
    margin-right: 10px;
}

.blueprint-card .card-body form .btn {
    flex-grow: 1; /* Кнопка занимает оставшееся место */
}

/* 9. Стили для мобильной навигации */
.navbar {
    padding-top: 0.8rem;
    padding-bottom: 0.8rem;
}

.navbar-brand {
    padding-top: 0;
    padding-bottom: 0;
}

.navbar-toggler {
    border: none;
}

.navbar-toggler:focus {
    box-shadow: 0 0 0 0.25rem var(--primary-color-translucent, rgba(230, 126, 34, 0.25));
}

@media (max-width: 991.98px) {
    .main-nav .nav-link, .site-header-main .nav-link {
        padding: 0.8rem 0;
        font-size: 1.2rem;
        text-align: center;
    }
}


/* 10. Homepage Banner Styles (Адаптивный) */
.carousel-image {
    height: 500px; /* Высота для больших экранов (десктопы) */
    object-fit: cover;
}

@media (max-width: 991.98px) {
    /* Высота для средних экранов (планшеты) */
    .carousel-image {
        height: 350px;
    }
}

@media (max-width: 767.98px) {
    /* Высота для малых экранов (смартфоны) */
    .carousel-image {
        height: 250px;
    }
}

/* 11. Стили для нового блока "Наши преимущества" */
.advantage-card {
    padding: 2rem 1.5rem;
    background-color: var(--surface-color);
    border-radius: var(--border-radius);
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
}

.advantage-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--box-shadow);
    border-color: var(--primary-color);
}

.advantage-icon {
    font-size: 3rem;
    color: var(--primary-color);
    margin-bottom: 1rem;
}

/* --- Стили для аватара в шапке сайта --- */
.header-profile-link {
    color: #ecf0f1;
    transition: all 0.2s ease;
}
.header-profile-link:hover {
    color: var(--primary-color);
}

.header-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%; /* Делает изображение круглым */
    object-fit: cover; /* Гарантирует, что изображение заполнит круг без искажений */
    border: 2px solid var(--border-color); /* Добавляет рамку */
    transition: border-color 0.2s ease;
}

.header-profile-link:hover .header-avatar {
    border-color: var(--primary-color); /* При наведении на ссылку, рамка аватара меняет цвет */
}


/* _________

 */

/*
 * =========================================
 * Стили для нового подвала (Footer)
 * =========================================
 */
.site-footer {
    background-color: #222529; /* Темный фон */
    color: #adb5bd; /* Светло-серый цвет текста */
    padding: 4rem 0;
    font-size: 0.9rem;
}

/* Делаем текст описания видимым */
.site-footer .footer-description {
    color: #adb5bd;
}

.site-footer .footer-heading {
    color: #ffffff; /* Белый цвет для заголовков */
    font-weight: 600;
    margin-bottom: 1.5rem;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: .5px;
}

.site-footer .site-logo {
    color: #ffffff;
    font-size: 1.5rem;
    font-weight: 700;
    transition: color 0.3s ease;
}

.site-footer .site-logo:hover {
    color: #0d6efd; /* Основной синий цвет Bootstrap */
}

.site-footer .footer-links li,
.site-footer .footer-contacts li {
    margin-bottom: 0.8rem;
}

.site-footer .footer-links a,
.site-footer .footer-contacts a {
    color: #adb5bd;
    text-decoration: none;
    transition: color 0.3s ease;
}

.site-footer .footer-links a:hover,
.site-footer .footer-contacts a:hover {
    color: #ffffff;
    text-decoration: underline;
}

.site-footer .footer-contacts i {
    font-size: 1rem;
    color: #0d6efd;
    margin-top: 4px;
}

/* Стили для ссылки на мобильное приложение */
.footer-app-link {
    display: inline-flex;
    align-items: center;
    padding: 8px 15px;
    border: 1px solid #495057;
    border-radius: 5px;
    text-decoration: none;
    color: #adb5bd;
    transition: all 0.3s ease;
}

.footer-app-link:hover {
    color: #ffffff;
    background-color: #0d6efd;
    border-color: #0d6efd;
}

.site-footer .footer-social .social-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background-color: #343a40;
    color: #ffffff;
    text-decoration: none;
    margin-right: 8px;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.site-footer .footer-social .social-icon:hover {
    background-color: #0d6efd;
    transform: translateY(-2px);
}

.site-footer .border-top {
    border-color: #3f454a !important; /* Более светлая линия-разделитель */
}
.footer-contacts .footer-email {
    overflow-wrap: break-word;
    word-break: break-all;
}

/* --- Стили для сообщений в стиле Bootstrap --- */

/* Базовый стиль для всех сообщений */
.alert {
  padding: 1rem;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  border-radius: 0.25rem;
}

/* Красный для ошибок (класс .alert-error) */
.alert-error {
  color: #721c24;
  background-color: #f8d7da;
  border-color: #f5c6cb;
}

/* Зеленый для успеха (класс .alert-success) */
.alert-success {
  color: #155724;
  background-color: #d4edda;
  border-color: #c3e6cb;
}

/* Желтый для предупреждений (класс .alert-warning) */
.alert-warning {
  color: #856404;
  background-color: #fff3cd;
  border-color: #ffeeba;
}

/* Синий для информации (класс .alert-info) */
.alert-info {
  color: #0c5460;
  background-color: #d1ecf1;
  border-color: #bee5eb;
}

@media (max-width: 576px) {
    .category-card-title {
        font-size: 1.2rem;
    }
    .category-card {
        padding: 1rem 1.2rem;
    }
}