/* ======================================================
   MataderosBarrial — Rubros SEO / Guía por rubros
   Fase 1.1: alineado visualmente con Guía de Anunciantes.
   Usa la misma paleta, jerarquía, bordes, sombras, badges y botones.
   ====================================================== */

.rubros-main {
    background: #f6f8f7;
}

/* Hero: mismo clima visual que guia-hero-v2 */
.rubros-hero {
    background:
        linear-gradient(135deg, rgba(0,0,0,.88), rgba(0,70,60,.86)),
        radial-gradient(circle at top right, rgba(0,168,150,.35), transparent 45%);
    color: #fff;
    padding: 58px 0 42px;
}

.rubros-hero .kicker {
    display: inline-flex;
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(0,168,150,.18);
    border: 1px solid rgba(255,255,255,.22);
    color: #d7fff8;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    font-size: .78rem;
    margin-bottom: 14px;
}

.rubros-hero h1 {
    max-width: 900px;
    margin: 0 0 14px;
    font-size: clamp(2.1rem, 5vw, 3.65rem);
    line-height: 1.02;
    letter-spacing: -.035em;
    color: #fff;
}

.rubros-hero p {
    max-width: 780px;
    color: rgba(255,255,255,.88);
    font-size: 1.08rem;
    margin: 0;
}

.rubros-section {
    padding: 38px 0 70px;
}

.rubros-head {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: flex-end;
    margin-bottom: 24px;
}

.rubros-head h2 {
    margin: 0;
    color: #111827;
    font-size: clamp(1.35rem, 2vw, 2rem);
    line-height: 1.15;
}

.rubros-head p {
    margin: 7px 0 0;
    color: #667085;
}

.rubros-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(245px, 1fr));
    gap: 20px;
}

.rubro-card,
.rubro-empty {
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 22px;
    padding: 20px;
    box-shadow: 0 12px 30px rgba(15,23,42,.06);
}

.rubro-card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 190px;
    transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}

.rubro-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 42px rgba(15,23,42,.10);
    border-color: rgba(0,168,150,.24);
}

.rubro-card h3,
.rubro-empty h2 {
    margin: 0;
    color: #111827;
    font-size: 1.15rem;
    line-height: 1.22;
}

.rubro-card p,
.rubro-empty p {
    margin: 0;
    color: #475467;
    line-height: 1.55;
}

.rubro-count {
    display: inline-flex;
    align-items: center;
    width: max-content;
    border-radius: 999px;
    padding: 5px 10px;
    background: #ecfdf5;
    color: #047857;
    border: 1px solid rgba(15,23,42,.10);
    font-weight: 900;
    font-size: .78rem;
    line-height: 1;
}

.rubro-btn {
    margin-top: auto;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    min-height: 38px;
    border-radius: 12px;
    padding: 8px 14px;
    text-decoration: none !important;
    font-weight: 850;
    font-size: .92rem;
    background: var(--primary, #00A896);
    color: #fff !important;
    border: 1px solid var(--primary, #00A896);
    transition: transform .12s ease, filter .12s ease, box-shadow .12s ease;
}

.rubro-btn:hover {
    transform: translateY(-1px);
    filter: brightness(.98);
    box-shadow: 0 10px 22px rgba(15,23,42,.12);
    color: #fff !important;
}

.rubro-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 30px;
    align-items: start;
}

.rubro-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
}

/* Las cards de resultados usan .guia-card para respetar Guía.
   Estas reglas solo ajustan detalles específicos del módulo rubros. */
.rubro-result-card .guia-actions {
    margin-top: 16px;
}

.rubro-result-card .guia-btn-more {
    grid-column: 1 / -1;
}

.rubro-related-note {
    margin: 12px 0 0;
    color: #667085;
    font-size: .9rem;
}

.rubro-related-note strong {
    color: #344054;
}

.rubro-side {
    background: #f8faf9;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 22px;
    padding: 22px;
    position: sticky;
    top: 90px;
    box-shadow: 0 12px 30px rgba(15,23,42,.06);
}

.rubro-side h2 {
    margin: 0 0 8px;
    color: #111827;
    font-size: 1.25rem;
    line-height: 1.18;
}

.rubro-side p {
    color: #475467;
    margin: 0 0 14px;
    line-height: 1.6;
}

.rubro-side a {
    display: block;
    margin-top: 10px;
    color: var(--primary-dark, #007565);
    font-weight: 900;
    text-decoration: none;
}

.rubro-side a:hover {
    color: var(--primary, #00A896);
}

/* Compatibilidad con markup anterior, por si alguna página quedó cacheada. */
.rubro-anunciante {
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 22px;
    padding: 20px;
    box-shadow: 0 12px 30px rgba(15,23,42,.06);
}

.rubro-anunciante h2 {
    margin: 0 0 8px;
    color: #111827;
    font-size: 1.15rem;
}

.rubro-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-bottom: 10px;
}

.rubro-chip {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 5px 10px;
    font-size: .72rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: .02em;
    border: 1px solid rgba(15,23,42,.10);
    background: #ecfdf5;
    color: #047857;
}

.rubro-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.rubro-actions a {
    border-radius: 12px;
    padding: 8px 12px;
    font-size: .9rem;
    font-weight: 850;
    text-decoration: none !important;
}

.rubro-primary {
    background: var(--primary, #00A896);
    color: #fff !important;
}

.rubro-soft {
    background: #dcfce7;
    color: #14532d !important;
    border: 1px solid #bbf7d0;
}

@media (max-width: 860px) {
    .rubro-layout {
        grid-template-columns: 1fr;
    }
    .rubro-side {
        position: static;
    }
    .rubros-head {
        display: block;
    }
    .rubros-head .rubro-btn {
        margin-top: 14px;
    }
}

@media (max-width: 760px) {
    .rubros-hero {
        padding: 46px 0 34px;
    }
    .rubro-list,
    .rubros-grid {
        grid-template-columns: 1fr;
    }
}
