/* ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
 * MAS Â· Recent activity Â· style
 * Bloque 08 Â· timeline mixta + filter pills Â· 5 badges colored
 * ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ */

/* Tokens locales (no en system.css) */
.mas-recent {
    --mas-recent-pink:  #9D3868;  /* darkened from #C24F8F for AA contrast 4.5:1 on light pink bg */
    --mas-recent-earth: #5a4733;
}

.mas-recent {
    max-width: var(--content-max, 1280px);
    margin: 0 auto;
    padding: var(--space-20, 80px) var(--grid-margin, 64px);
    background: var(--color-bg, #FFFFFF);
    color: var(--color-text, #1A1A1A);
}

/* âââ header âââ */
.mas-recent__head {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: var(--space-16, 64px);
    align-items: end;
    padding-bottom: var(--space-8, 32px);
    margin-bottom: var(--space-8, 32px);
    border-bottom: 0.5px solid var(--color-border, #E3E6EA);
}
.mas-recent__kicker {
    font-family: var(--font-sans);
    font-size: var(--fs-xs, 11px);
    color: var(--color-accent-strong, #8E1530);
    letter-spacing: var(--tr-wider, 0.15em);
    text-transform: uppercase;
    font-weight: var(--fw-semibold, 600);
    margin: 0 0 var(--space-3, 12px);
}
.mas-recent__kicker::before { content: ''; }

.mas-recent__title {
    font-family: var(--font-serif);
    font-weight: var(--fw-regular, 400);
    font-size: var(--fs-4xl, 48px);
    line-height: var(--lh-snug, 1.15);
    letter-spacing: var(--tr-display, -0.025em);
    margin: 0;
    color: var(--color-text, #1A1A1A);
}
.mas-recent__title em {
    font-style: italic;
    color: var(--color-blue, #0A3161);
    font-weight: var(--fw-medium, 500);
}

.mas-recent__desc {
    font-family: var(--font-serif);
    font-size: var(--fs-lg, 18px);
    line-height: var(--lh-relaxed, 1.55);
    color: var(--color-text-secondary, #555);
    margin: 0;
    padding-bottom: var(--space-2, 8px);
}
.mas-recent__desc em {
    font-style: italic;
    color: var(--color-blue, #0A3161);
}

/* âââ filter pills âââ */
.mas-recent__filters {
    display: flex;
    gap: var(--space-2, 8px);
    margin-bottom: var(--space-8, 32px);
    flex-wrap: wrap;
}
.mas-recent__pill {
    font-family: var(--font-sans);
    font-size: var(--fs-sm, 13px);
    font-weight: var(--fw-semibold, 600);
    letter-spacing: var(--tr-wide, 0.05em);
    padding: var(--space-2, 8px) var(--space-5, 20px);
    background: transparent;
    border: 1px solid var(--color-border, #E3E6EA);
    border-radius: var(--radius-pill, 9999px);
    color: var(--color-text-secondary, #555);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2, 8px);
    transition: background var(--t-fast, 150ms), color var(--t-fast, 150ms), border-color var(--t-fast, 150ms);
    /* a11y target-size */
    min-height: 36px;
}
.mas-recent__pill:hover {
    border-color: var(--color-accent, #B31942);
    color: var(--color-accent, #B31942);
}
.mas-recent__pill:focus-visible {
    outline: 2px solid var(--color-accent, #B31942);
    outline-offset: 2px;
}
.mas-recent__pill.is-active {
    background: var(--color-text, #1A1A1A);
    color: var(--color-ink-on-dark, #FAFBFC);
    border-color: var(--color-text, #1A1A1A);
}
.mas-recent__pill-count {
    font-size: var(--fs-2xs, 10px);
    color: var(--color-text-muted, #6B6B6B);
    background: var(--color-bg-alt, #F4F6F9);
    padding: 1px var(--space-2, 8px);
    border-radius: var(--radius-pill, 9999px);
    font-variant-numeric: tabular-nums;
}
.mas-recent__pill.is-active .mas-recent__pill-count {
    background: rgba(255, 255, 255, 0.15);
    color: var(--color-ink-on-dark, #FAFBFC);
}

/* âââ lista timeline âââ */
.mas-recent__list {
    list-style: none;
    padding: 0;
    margin: 0;
    border-top: 0.5px solid var(--color-border, #E3E6EA);
}
.mas-recent__item {
    display: grid;
    grid-template-columns: 120px 100px 1fr 240px;
    gap: var(--space-5, 20px);
    padding: var(--space-5, 20px) var(--space-3, 12px);
    border-bottom: 0.5px solid var(--color-border, #E3E6EA);
    align-items: center;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    transition: background var(--t-fast, 150ms), padding-left var(--t-fast, 150ms);
    position: relative;
}
.mas-recent__item:hover {
    background: rgba(179, 25, 66, 0.04);
    padding-left: var(--space-5, 20px);
}
.mas-recent__item:focus-visible {
    outline: 2px solid var(--color-accent, #B31942);
    outline-offset: -2px;
}
.mas-recent__item.is-dim {
    opacity: 0.25;
    pointer-events: none;
    transition: opacity var(--t-base, 300ms);
}
/* Filtro real: el item que no matchea se oculta (su <li> sale del layout). */
.mas-recent__list li.is-hidden { display: none; }

.mas-recent__date {
    font-family: var(--font-sans);
    font-size: var(--fs-xs, 11px);
    color: var(--color-text-muted, #6B6B6B);
    letter-spacing: var(--tr-wide, 0.05em);
    font-variant-numeric: tabular-nums;
}
.mas-recent__date strong {
    color: var(--color-text, #1A1A1A);
    font-weight: var(--fw-semibold, 600);
}

.mas-recent__badge {
    font-family: var(--font-sans);
    font-size: var(--fs-2xs, 10px);
    font-weight: var(--fw-semibold, 600);
    letter-spacing: var(--tr-wider, 0.15em);
    text-transform: uppercase;
    padding: 3px var(--space-3, 12px);
    border-radius: var(--radius-pill, 9999px);
    justify-self: start;
    white-space: nowrap;
}
.mas-recent__badge--essay   { background: rgba(179, 25, 66, 0.10);  color: var(--color-accent, #B31942); }
.mas-recent__badge--podcast { background: rgba(10, 49, 97, 0.10);   color: var(--color-blue, #0A3161); }
.mas-recent__badge--paper   { background: var(--color-text, #1A1A1A); color: var(--color-ink-on-dark, #FAFBFC); }
.mas-recent__badge--talk    { background: rgba(194, 79, 143, 0.10); color: var(--mas-recent-pink); }
.mas-recent__badge--media   { background: rgba(169, 196, 228, 0.18); color: var(--mas-recent-earth); }
.mas-recent__badge--fieldnote { background: rgba(26, 26, 26, 0.07); color: var(--color-text-secondary, #4A4A45); }

.mas-recent__item-title {
    font-family: var(--font-serif);
    font-weight: var(--fw-regular, 400);
    font-size: var(--fs-lg, 18px);
    line-height: var(--lh-snug, 1.15);
    letter-spacing: var(--tr-tight, -0.015em);
    color: var(--color-text, #1A1A1A);
    margin: 0;
}
.mas-recent__item-title em {
    font-style: italic;
    color: var(--color-blue, #0A3161);
}

.mas-recent__source {
    font-family: var(--font-sans);
    font-size: var(--fs-xs, 11px);
    color: var(--color-text-muted, #6B6B6B);
    letter-spacing: var(--tr-wide, 0.05em);
    text-align: right;
    display: flex;
    flex-direction: column;
    gap: var(--space-1, 4px);
    align-items: flex-end;
}
.mas-recent__source-main strong {
    color: var(--color-text, #1A1A1A);
    font-weight: var(--fw-semibold, 600);
}
.mas-recent__source-meta {
    font-size: var(--fs-2xs, 10px);
    color: var(--color-text-muted, #6B6B6B);
    font-variant-numeric: tabular-nums;
}

/* âââ footer âââ */
.mas-recent__foot {
    margin-top: var(--space-10, 40px);
    padding-top: var(--space-6, 24px);
    border-top: 0.5px solid var(--color-border, #E3E6EA);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-4, 16px);
    flex-wrap: wrap;
}
.mas-recent__total {
    font-family: var(--font-sans);
    font-size: var(--fs-xs, 11px);
    color: var(--color-text-muted, #6B6B6B);
    letter-spacing: var(--tr-wide, 0.05em);
}
.mas-recent__total strong {
    color: var(--color-accent, #B31942);
    font-weight: var(--fw-semibold, 600);
}
.mas-recent__cta {
    font-family: var(--font-sans);
    font-size: var(--fs-xs, 11px);
    font-weight: var(--fw-semibold, 600);
    letter-spacing: var(--tr-wide, 0.05em);
    text-transform: uppercase;
    color: var(--color-text, #1A1A1A);
    text-decoration: none;
    border-bottom: 1px solid var(--color-text, #1A1A1A);
    padding-bottom: 2px;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2, 8px);
    transition: color var(--t-fast, 150ms), border-color var(--t-fast, 150ms);
    /* a11y target-size â el text-link es OK al ser inline, pero subimos padding para confort */
    padding-top: var(--space-2, 8px);
    padding-bottom: var(--space-2, 8px);
}
.mas-recent__cta:hover {
    color: var(--color-accent, #B31942);
    border-color: var(--color-accent, #B31942);
}
.mas-recent__cta-arr {
    transition: transform var(--t-fast, 150ms);
}
.mas-recent__cta:hover .mas-recent__cta-arr {
    transform: translateX(3px);
}

/* ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
 * Responsive
 * ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ */

@media (max-width: 1023px) {
    .mas-recent {
        padding-left: var(--space-8, 32px);
        padding-right: var(--space-8, 32px);
    }
    .mas-recent__head {
        grid-template-columns: 1fr;
        gap: var(--space-6, 24px);
        align-items: start;
    }
    .mas-recent__title { font-size: var(--fs-3xl, 36px); }
    /* timeline reduce columnas */
    .mas-recent__item {
        grid-template-columns: 100px 90px 1fr 180px;
        gap: var(--space-4, 16px);
    }
    .mas-recent__source { font-size: var(--fs-2xs, 10px); }
}

@media (max-width: 767px) {
    .mas-recent {
        padding: var(--space-16, 64px) var(--space-5, 20px);
    }
    .mas-recent__title { font-size: var(--fs-2xl, 28px); }
    .mas-recent__desc { font-size: var(--fs-base, 16px); }
    /* timeline: stack en 2 filas, date+badge arriba, title+source abajo */
    .mas-recent__item {
        grid-template-columns: auto 1fr;
        grid-template-areas:
            "date  badge"
            "title title"
            "src   src";
        gap: var(--space-2, 8px) var(--space-3, 12px);
        align-items: start;
        padding: var(--space-4, 16px) 0;
    }
    .mas-recent__date   { grid-area: date; }
    .mas-recent__badge  { grid-area: badge; justify-self: end; }
    .mas-recent__item-title { grid-area: title; font-size: var(--fs-base, 16px); }
    .mas-recent__source {
        grid-area: src;
        text-align: left;
        align-items: flex-start;
        flex-direction: row;
        gap: var(--space-3, 12px);
        flex-wrap: wrap;
    }
    .mas-recent__item:hover { padding-left: 0; }
    .mas-recent__foot {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-3, 12px);
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .mas-recent__pill,
    .mas-recent__item,
    .mas-recent__cta,
    .mas-recent__cta-arr {
        transition: none;
    }
}
