﻿body {
    background: #fcfaf8;
    color: #2f2a26;
}

.catalog-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 16px 48px;
}

.catalog-hero {
    background: linear-gradient(180deg, #fffefe 0%, #f7f2ee 100%);
    border: 1px solid #efe5de;
    border-radius: 28px;
    padding: 28px 20px;
    box-shadow: 0 12px 40px rgba(84, 59, 42, 0.06);
    margin-bottom: 24px;
}

.catalog-hero__content {
    max-width: 680px;
}

.catalog-badge {
    display: inline-block;
    padding: 8px 14px;
    border-radius: 999px;
    background: #f5ece5;
    color: #8a6d5a;
    font-size: 13px;
    margin-bottom: 14px;
}

.catalog-title {
    font-size: 30px;
    line-height: 1.1;
    margin: 0 0 12px;
    color: #342b25;
}

.catalog-subtitle {
    font-size: 16px;
    color: #7b6b61;
    margin: 0;
}

.catalog-sections {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.catalog-section-card {
    display: block;
    text-decoration: none;
    color: inherit;
    background: #fff;
    border: 1px solid #efe5de;
    border-radius: 24px;
    padding: 20px 18px;
    box-shadow: 0 10px 32px rgba(84, 59, 42, 0.05);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

    .catalog-section-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 16px 36px rgba(84, 59, 42, 0.08);
    }

.catalog-section-card__title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 10px;
}

.catalog-section-card__link {
    font-size: 14px;
    color: #9a7e6a;
}

.catalog-breadcrumbs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 14px;
    color: #8d7d72;
    margin-bottom: 18px;
}

    .catalog-breadcrumbs a {
        color: #8d7d72;
        text-decoration: none;
    }

.catalog-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.catalog-sidebar__box {
    background: #fff;
    border: 1px solid #efe5de;
    border-radius: 24px;
    padding: 18px;
    box-shadow: 0 10px 32px rgba(84, 59, 42, 0.05);
}

.catalog-sidebar__title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 14px;
}

.catalog-category-link {
    display: block;
    padding: 10px 12px;
    border-radius: 14px;
    text-decoration: none;
    color: #4c4038;
    margin-bottom: 6px;
    background: transparent;
}

    .catalog-category-link:hover {
        background: #f8f1eb;
    }

.catalog-category-link--child {
    padding-left: 28px;
    color: #78695f;
}

.catalog-category-link.is-active {
    background: #f3e7dd;
    color: #553e31;
    font-weight: 600;
}

.catalog-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.bouquet-card {
    display: block;
    text-decoration: none;
    color: inherit;
    background: #fff;
    border: 1px solid #efe5de;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 10px 32px rgba(84, 59, 42, 0.05);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

    .bouquet-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 16px 36px rgba(84, 59, 42, 0.08);
    }

.bouquet-card__image-wrap {
    aspect-ratio: 1 / 1;
    background: #f6f0eb;
    overflow: hidden;
}

.bouquet-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.bouquet-card__placeholder {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #9b8a7f;
    font-size: 15px;
}

.bouquet-card__placeholder--large {
    min-height: 420px;
}

.bouquet-card__body {
    padding: 16px;
}

.bouquet-card__title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 8px;
    line-height: 1.25;
}

.bouquet-card__price {
    font-size: 17px;
    color: #725846;
    font-weight: 600;
}

.catalog-empty {
    background: #fff;
    border: 1px solid #efe5de;
    border-radius: 24px;
    padding: 24px;
    color: #7d6f66;
}

.bouquet-details {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}

.bouquet-details__main-image-wrap {
    background: #fff;
    border: 1px solid #efe5de;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 10px 32px rgba(84, 59, 42, 0.05);
}

.bouquet-details__main-image {
    display: block;
    width: 100%;
    max-height: 620px;
    object-fit: cover;
}

.bouquet-details__thumbs {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
}

.bouquet-details__thumb {
    width: 82px;
    height: 82px;
    object-fit: cover;
    border-radius: 14px;
    border: 1px solid #efe5de;
    background: #fff;
}

.bouquet-details__price {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 16px;
    color: #5b4336;
}

.bouquet-details__categories {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 18px;
}

.bouquet-details__category {
    background: #f5ebe3;
    color: #6d5646;
    padding: 8px 12px;
    border-radius: 999px;
    font-size: 13px;
}

.bouquet-details__description {
    background: #fff;
    border: 1px solid #efe5de;
    border-radius: 24px;
    padding: 18px;
    box-shadow: 0 10px 32px rgba(84, 59, 42, 0.05);
    line-height: 1.65;
}

@media (min-width: 700px) {
    .catalog-sections {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .catalog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 992px) {
    .catalog-layout {
        grid-template-columns: 300px 1fr;
        align-items: start;
    }

    .catalog-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .bouquet-details {
        grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
        align-items: start;
    }
}
