/* =============================================
 * САНМАРИНО — КАТАЛОГ ТОВАРОВ
 * product-archive.css
 * Изоляция: #sanmarino-catalog-page
 * ============================================= */

#sanmarino-catalog-page { width: 100%; }
#sanmarino-catalog-page * { box-sizing: border-box; }

#sanmarino-catalog-page .sc-container {
    max-width: var(--container-width, 1400px);
    margin: 0 auto;
    padding: 40px 20px 80px;
}

/* ХЛЕБНЫЕ КРОШКИ */
#sanmarino-catalog-page .breadcrumbs {
    display: flex; align-items: center; flex-wrap: wrap; gap: 10px;
    margin-bottom: 25px; font-size: 13px; color: var(--brand-link); opacity: 0.8;
}
#sanmarino-catalog-page .breadcrumbs span { color: #ccc; }
#sanmarino-catalog-page .breadcrumbs a:hover { color: var(--brand-action); opacity: 1; }

/* ЗАГОЛОВОК + СОРТИРОВКА */
#sanmarino-catalog-page .catalog-header {
    display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 25px; flex-wrap: wrap; gap: 20px;
}
#sanmarino-catalog-page h1 { font-size: 32px; font-weight: 800; color: var(--brand-dark); margin: 0; line-height: 1.1; }
#sanmarino-catalog-page .product-count { font-size: 14px; color: var(--color-gray); font-weight: 500; margin-left: 10px; vertical-align: middle; }

#sanmarino-catalog-page .sort-wrap {
    display: flex; align-items: center; gap: 10px;
    background: rgba(255,255,255,0.5); padding: 8px 15px; border-radius: 10px; border: 1px solid rgba(255,255,255,0.8);
}
#sanmarino-catalog-page .sort-label { font-size: 13px; color: var(--color-gray); }
#sanmarino-catalog-page .sort-select {
    border: none; background: transparent; font-family: 'Inter', sans-serif;
    font-weight: 600; color: var(--brand-dark); cursor: pointer; outline: none; font-size: 14px;
    padding: 0; -webkit-appearance: none; appearance: none;
}

/* БЫСТРЫЕ ТЕГИ */
#sanmarino-catalog-page .quick-tags { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 30px; }
#sanmarino-catalog-page .q-tag {
    background: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.8);
    padding: 8px 16px; border-radius: 50px; font-size: 13px; font-weight: 500;
    color: var(--brand-dark); transition: 0.2s; cursor: pointer; text-decoration: none; display: inline-block;
}
#sanmarino-catalog-page .q-tag:hover {
    background: var(--brand-link); color: white; border-color: var(--brand-link); transform: translateY(-2px);
}

/* ОСНОВНАЯ СЕТКА */
#sanmarino-catalog-page .catalog-layout {
    display: grid; grid-template-columns: 280px 1fr; gap: 30px; align-items: start;
}

/* === САЙДБАР ФИЛЬТРОВ === */
#sanmarino-catalog-page .filters-sidebar {
    background: var(--glass-bg); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border); border-radius: var(--radius-lg, 20px); padding: 25px;
    position: sticky; top: 120px; box-shadow: var(--glass-shadow);
}
#sanmarino-catalog-page .filter-group {
    margin-bottom: 25px; padding-bottom: 25px; border-bottom: 1px solid rgba(0,0,0,0.05);
}
#sanmarino-catalog-page .filter-group:last-of-type { border: none; margin: 0; padding: 0; }
#sanmarino-catalog-page .f-title {
    font-weight: 700; font-size: 15px; margin-bottom: 15px;
    display: flex; justify-content: space-between; cursor: pointer; color: var(--brand-dark);
}

/* Чекбоксы */
#sanmarino-catalog-page .checkbox-list { display: flex; flex-direction: column; gap: 10px; max-height: 200px; overflow-y: auto; }
#sanmarino-catalog-page .custom-checkbox {
    display: flex; align-items: center; gap: 10px; font-size: 14px; cursor: pointer; color: var(--brand-dark);
}
#sanmarino-catalog-page .custom-checkbox input { display: none; }
#sanmarino-catalog-page .checkmark {
    width: 18px; height: 18px; border: 2px solid #ccc; border-radius: 4px;
    display: flex; align-items: center; justify-content: center; transition: 0.2s; background: #fff; flex-shrink: 0;
}
#sanmarino-catalog-page .custom-checkbox input:checked + .checkmark { background: var(--brand-action); border-color: var(--brand-action); }
#sanmarino-catalog-page .checkmark::after { content: '✔'; color: white; font-size: 10px; display: none; }
#sanmarino-catalog-page .custom-checkbox input:checked + .checkmark::after { display: block; }
#sanmarino-catalog-page .count-badge { font-size: 11px; color: var(--color-gray); margin-left: auto; }

/* Цена */
#sanmarino-catalog-page .price-inputs { display: flex; gap: 10px; margin-bottom: 15px; }
#sanmarino-catalog-page .p-input { width: 50%; padding: 8px; border: 1px solid #ddd; border-radius: 8px; font-family: inherit; font-size: 13px; }
#sanmarino-catalog-page .range-track { height: 4px; background: #ddd; border-radius: 2px; position: relative; }
#sanmarino-catalog-page .range-fill { position: absolute; left: 20%; width: 50%; height: 100%; background: var(--brand-action); border-radius: 2px; }

#sanmarino-catalog-page .btn-apply-filters {
    width: 100%; background: var(--brand-dark); color: white; padding: 12px; border-radius: 8px;
    border: none; font-weight: 600; font-family: 'Inter', sans-serif; cursor: pointer; transition: 0.2s; font-size: 14px; margin-top: 20px;
}
#sanmarino-catalog-page .btn-apply-filters:hover { background: var(--brand-link); }

/* === СЕТКА ТОВАРОВ === */
#sanmarino-catalog-page .products-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px;
}

/* === КАРТОЧКА ТОВАРА === */
#sanmarino-catalog-page .prod-card {
    background: #fff; border-radius: 16px; padding: 20px; position: relative;
    transition: all 0.3s ease; border: 1px solid transparent;
    display: flex; flex-direction: column; justify-content: space-between;
}
#sanmarino-catalog-page .prod-card:hover {
    transform: translateY(-5px); box-shadow: 0 15px 30px rgba(12,39,68,0.1);
    border-color: rgba(236,103,46,0.2); z-index: 2;
}

/* Бейджи */
#sanmarino-catalog-page .pc-badges { position: absolute; top: 15px; left: 15px; display: flex; flex-direction: column; gap: 5px; z-index: 5; }
#sanmarino-catalog-page .pc-badge { font-size: 10px; font-weight: 700; color: white; padding: 4px 8px; border-radius: 6px; text-transform: uppercase; display: inline-block; }
#sanmarino-catalog-page .pc-badge.sale { background: var(--brand-action); }
#sanmarino-catalog-page .pc-badge.new { background: var(--brand-link); }

/* Сердце */
#sanmarino-catalog-page .pc-actions { position: absolute; top: 15px; right: 15px; z-index: 5; opacity: 0; transition: 0.2s; }
#sanmarino-catalog-page .prod-card:hover .pc-actions { opacity: 1; }
#sanmarino-catalog-page .pc-action-btn {
    width: 32px; height: 32px; background: rgba(255,255,255,0.9); border-radius: 50%;
    display: flex; align-items: center; justify-content: center; cursor: pointer;
    color: var(--color-gray); box-shadow: 0 2px 10px rgba(0,0,0,0.1); transition: 0.2s;
}
#sanmarino-catalog-page .pc-action-btn:hover { color: var(--brand-action); }

/* Изображение */
#sanmarino-catalog-page .pc-img-wrap { position: relative; padding-bottom: 100%; margin-bottom: 15px; overflow: hidden; display: block; }
#sanmarino-catalog-page .pc-img-wrap img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: contain; transition: 0.3s; }
#sanmarino-catalog-page .prod-card:hover .pc-img-wrap img { transform: scale(1.05); }

/* Контент */
#sanmarino-catalog-page .pc-info { flex-grow: 1; display: flex; flex-direction: column; }
#sanmarino-catalog-page .pc-brand { font-size: 11px; color: var(--color-gray); font-weight: 600; text-transform: uppercase; margin-bottom: 4px; letter-spacing: 0.3px; }
#sanmarino-catalog-page .pc-title {
    font-size: 14px; font-weight: 600; color: var(--brand-dark); line-height: 1.4; margin-bottom: 10px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
#sanmarino-catalog-page .pc-title:hover { color: var(--brand-link); }

/* Спеки */
#sanmarino-catalog-page .pc-specs { margin-bottom: 15px; font-size: 12px; color: #555; }
#sanmarino-catalog-page .pc-spec-item { display: flex; justify-content: space-between; margin-bottom: 4px; border-bottom: 1px dotted #eee; padding-bottom: 3px; }
#sanmarino-catalog-page .pc-spec-item span:first-child { color: #888; }

/* Цена + кнопка */
#sanmarino-catalog-page .pc-bottom { margin-top: auto; }
#sanmarino-catalog-page .pc-price-row { display: flex; align-items: flex-end; gap: 8px; margin-bottom: 12px; }
#sanmarino-catalog-page .pc-price { font-size: 20px; font-weight: 800; color: var(--brand-dark); }
#sanmarino-catalog-page .pc-old-price { font-size: 13px; text-decoration: line-through; color: #aaa; padding-bottom: 2px; }

#sanmarino-catalog-page .pc-btn {
    width: 100%; background: var(--brand-action); color: white; border: none; padding: 10px; border-radius: 8px;
    font-weight: 600; font-family: 'Inter', sans-serif; cursor: pointer; transition: 0.2s;
    display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 14px; text-decoration: none;
}
#sanmarino-catalog-page .pc-btn:hover { background: #d65620; color: white; }
#sanmarino-catalog-page .pc-btn i { font-size: 16px; font-weight: normal; }
#sanmarino-catalog-page .pc-btn-disabled { background: #ddd; color: #999; cursor: not-allowed; }
#sanmarino-catalog-page .pc-btn-disabled:hover { background: #ddd; transform: none; }

/* Доставка */
#sanmarino-catalog-page .pc-delivery { font-size: 11px; color: var(--color-success); margin-top: 10px; display: flex; align-items: center; gap: 4px; }

/* AJAX кнопка */
#sanmarino-catalog-page .pc-btn.loading::after {
    content: ''; width: 14px; height: 14px; border: 2px solid rgba(255,255,255,0.3);
    border-top-color: #fff; border-radius: 50%; animation: sm-spin 0.6s linear infinite; margin-left: 5px;
}
#sanmarino-catalog-page .pc-btn.added { background: var(--color-success); }
@keyframes sm-spin { to { transform: rotate(360deg); } }

/* ПАГИНАЦИЯ */
#sanmarino-catalog-page .catalog-pagination { margin-top: 50px; display: flex; justify-content: center; }
#sanmarino-catalog-page .catalog-pagination .page-numbers { list-style: none; display: flex; gap: 8px; padding: 0; margin: 0; }
#sanmarino-catalog-page .catalog-pagination .page-numbers li { list-style: none; }
#sanmarino-catalog-page .catalog-pagination .page-numbers a,
#sanmarino-catalog-page .catalog-pagination .page-numbers span {
    display: flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px;
    border-radius: 10px; font-size: 14px; font-weight: 600; transition: 0.2s; color: var(--brand-dark);
    background: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.8); text-decoration: none;
}
#sanmarino-catalog-page .catalog-pagination .page-numbers a:hover { background: var(--brand-link); color: white; border-color: var(--brand-link); }
#sanmarino-catalog-page .catalog-pagination .page-numbers .current { background: var(--brand-action); color: white; border-color: var(--brand-action); }

/* НЕТ ТОВАРОВ */
#sanmarino-catalog-page .no-products-found {
    text-align: center; padding: 60px 20px; background: var(--glass-bg); backdrop-filter: var(--glass-blur);
    border: var(--glass-border); border-radius: var(--radius-lg); grid-column: 1 / -1;
}
#sanmarino-catalog-page .no-products-found a { color: var(--brand-link); font-weight: 600; }

/* SEO ТЕКСТ */
#sanmarino-catalog-page .category-seo-text { margin-top: 50px; padding: 30px; font-size: 14px; line-height: 1.7; color: var(--brand-dark); opacity: 0.85; }

/* МОБИЛЬНАЯ КНОПКА ФИЛЬТРОВ */
#sanmarino-catalog-page .mobile-filter-btn {
    display: none; width: 100%; background: #fff; border: 1px solid #ddd; padding: 12px; border-radius: 8px;
    font-weight: 600; font-family: 'Inter', sans-serif; margin-bottom: 20px;
    align-items: center; justify-content: center; gap: 10px; cursor: pointer; font-size: 14px; color: var(--brand-dark);
}

/* АДАПТИВНОСТЬ */
@media (max-width: 1100px) { #sanmarino-catalog-page .catalog-layout { grid-template-columns: 250px 1fr; gap: 20px; } }
@media (max-width: 900px) {
    #sanmarino-catalog-page .catalog-layout { grid-template-columns: 1fr; }
    #sanmarino-catalog-page .filters-sidebar { display: none; }
    #sanmarino-catalog-page .filters-sidebar.is-open {
        display: block; position: fixed; top: 0; left: 0; width: 320px; height: 100vh; z-index: 9999;
        border-radius: 0 var(--radius-lg) var(--radius-lg) 0; overflow-y: auto; box-shadow: 5px 0 30px rgba(0,0,0,0.2);
    }
    #sanmarino-catalog-page .mobile-filter-btn { display: flex; }
    #sanmarino-catalog-page .sort-wrap { width: 100%; justify-content: space-between; }
    #sanmarino-catalog-page h1 { font-size: 24px; }
}
@media (max-width: 600px) {
    #sanmarino-catalog-page .sc-container { padding-left: 15px; padding-right: 15px; padding-top: 25px; }
    #sanmarino-catalog-page .products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    #sanmarino-catalog-page .prod-card { padding: 12px; }
    #sanmarino-catalog-page .pc-price { font-size: 16px; }
    #sanmarino-catalog-page .pc-title { font-size: 12px; }
    #sanmarino-catalog-page .pc-specs { display: none; }
}
